package pgdialect

import (
	
	
	

	
)

type ArrayValue struct {
	v reflect.Value

	append schema.AppenderFunc
	scan   schema.ScannerFunc
}

// Array accepts a slice and returns a wrapper for working with PostgreSQL
// array data type.
//
// For struct fields you can use array tag:
//
//    Emails  []string `bun:",array"`
func ( interface{}) *ArrayValue {
	 := reflect.ValueOf()
	if !.IsValid() {
		panic(fmt.Errorf("bun: Array(nil)"))
	}

	return &ArrayValue{
		v: ,

		append: arrayAppender(.Type()),
		scan:   arrayScanner(.Type()),
	}
}

var (
	_ schema.QueryAppender = (*ArrayValue)(nil)
	_ sql.Scanner          = (*ArrayValue)(nil)
)

func ( *ArrayValue) ( schema.Formatter,  []byte) ([]byte, error) {
	if .append == nil {
		panic(fmt.Errorf("bun: Array(unsupported %s)", .v.Type()))
	}
	return .append(, , .v), nil
}

func ( *ArrayValue) ( interface{}) error {
	if .scan == nil {
		return fmt.Errorf("bun: Array(unsupported %s)", .v.Type())
	}
	if .v.Kind() != reflect.Ptr {
		return fmt.Errorf("bun: Array(non-pointer %s)", .v.Type())
	}
	return .scan(.v, )
}

func ( *ArrayValue) () interface{} {
	if .v.IsValid() {
		return .v.Interface()
	}
	return nil
}