Expand pgtype.Value interface
- Include and rename ConvertFrom to Set - Add Get - Include AssignTo
This commit is contained in:
+14
-3
@@ -16,7 +16,7 @@ type TimestampArray struct {
|
||||
Status Status
|
||||
}
|
||||
|
||||
func (dst *TimestampArray) ConvertFrom(src interface{}) error {
|
||||
func (dst *TimestampArray) Set(src interface{}) error {
|
||||
switch value := src.(type) {
|
||||
case TimestampArray:
|
||||
*dst = value
|
||||
@@ -29,7 +29,7 @@ func (dst *TimestampArray) ConvertFrom(src interface{}) error {
|
||||
} else {
|
||||
elements := make([]Timestamp, len(value))
|
||||
for i := range value {
|
||||
if err := elements[i].ConvertFrom(value[i]); err != nil {
|
||||
if err := elements[i].Set(value[i]); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
@@ -42,7 +42,7 @@ func (dst *TimestampArray) ConvertFrom(src interface{}) error {
|
||||
|
||||
default:
|
||||
if originalSrc, ok := underlyingSliceType(src); ok {
|
||||
return dst.ConvertFrom(originalSrc)
|
||||
return dst.Set(originalSrc)
|
||||
}
|
||||
return fmt.Errorf("cannot convert %v to Timestamp", value)
|
||||
}
|
||||
@@ -50,6 +50,17 @@ func (dst *TimestampArray) ConvertFrom(src interface{}) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (dst *TimestampArray) Get() interface{} {
|
||||
switch dst.Status {
|
||||
case Present:
|
||||
return dst
|
||||
case Null:
|
||||
return nil
|
||||
default:
|
||||
return dst.Status
|
||||
}
|
||||
}
|
||||
|
||||
func (src *TimestampArray) AssignTo(dst interface{}) error {
|
||||
switch v := dst.(type) {
|
||||
|
||||
|
||||
Reference in New Issue
Block a user