mirror of https://github.com/milvus-io/milvus.git
213 lines
4.9 KiB
Go
213 lines
4.9 KiB
Go
// Licensed to the LF AI & Data foundation under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you under the Apache License, Version 2.0 (the
|
|
// "License"); you may not use this file except in compliance
|
|
// with the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package storage
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/apache/arrow/go/v17/arrow"
|
|
"github.com/apache/arrow/go/v17/arrow/array"
|
|
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/schemapb"
|
|
)
|
|
|
|
func AppendValueAt(builder array.Builder, a arrow.Array, idx int, defaultValue *schemapb.ValueField) error {
|
|
switch b := builder.(type) {
|
|
case *array.BooleanBuilder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(defaultValue.GetBoolData())
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
ba, ok := a.(*array.Boolean)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if ba.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(ba.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.Int8Builder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(int8(defaultValue.GetIntData()))
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
ia, ok := a.(*array.Int8)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if ia.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(ia.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.Int16Builder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(int16(defaultValue.GetIntData()))
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
ia, ok := a.(*array.Int16)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if ia.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(ia.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.Int32Builder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(defaultValue.GetIntData())
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
ia, ok := a.(*array.Int32)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if ia.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(ia.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.Int64Builder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(defaultValue.GetLongData())
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
ia, ok := a.(*array.Int64)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if ia.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(ia.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.Float32Builder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(defaultValue.GetFloatData())
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
fa, ok := a.(*array.Float32)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if fa.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(fa.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.Float64Builder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(defaultValue.GetDoubleData())
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
fa, ok := a.(*array.Float64)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if fa.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(fa.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.StringBuilder:
|
|
if a == nil {
|
|
if defaultValue != nil {
|
|
b.Append(defaultValue.GetStringData())
|
|
} else {
|
|
b.AppendNull()
|
|
}
|
|
return nil
|
|
}
|
|
sa, ok := a.(*array.String)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if sa.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(sa.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.BinaryBuilder:
|
|
// array type, not support defaultValue now
|
|
if a == nil {
|
|
b.AppendNull()
|
|
return nil
|
|
}
|
|
ba, ok := a.(*array.Binary)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if ba.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(ba.Value(idx))
|
|
}
|
|
return nil
|
|
case *array.FixedSizeBinaryBuilder:
|
|
ba, ok := a.(*array.FixedSizeBinary)
|
|
if !ok {
|
|
return fmt.Errorf("invalid value type %T, expect %T", a.DataType(), builder.Type())
|
|
}
|
|
if ba.IsNull(idx) {
|
|
b.AppendNull()
|
|
} else {
|
|
b.Append(ba.Value(idx))
|
|
}
|
|
return nil
|
|
default:
|
|
return fmt.Errorf("unsupported builder type: %T", builder)
|
|
}
|
|
}
|