Documentation ¶
Index ¶
Constants ¶
View Source
const ( // Denotes that a destination field must be copied to. If copying fails then a panic will ensue. TagMust uint8 = 1 << iota // Denotes that the program should not panic when the must flag is on and // value is not copied. The program will return an error instead. TagNoPanic // Won't apply default tags if value is a pointer TagSkipPtrs // Some default converter types for a nicer syntax String string = "" Bool bool = false Int int = 0 Float32 float32 = 0 Float64 float64 = 0 )
These flags define options for tag handling
Variables ¶
View Source
var ( ErrInvalidCopyDestination = errors.New("copy destination is invalid") ErrInvalidCopyFrom = errors.New("copy from is invalid") ErrMapKeyNotMatch = errors.New("map's key type doesn't match") ErrNotSupported = errors.New("not supported") ErrFieldNameTagStartNotUpperCase = errors.New("copier field name tag must be start upper case") )
Functions ¶
func CopyWithOption ¶
CopyWithOption copy with option
Types ¶
type Option ¶
type Option struct { // setting this value to true will ignore copying zero values of all the fields, including bools, as well as a // struct having all it's fields set to their zero values respectively (see IsZero() in reflect/value.go) IgnoreEmpty bool DeepCopy bool Converters []TypeConverter DefaultSourceFlags uint8 DefaultTargetFlags uint8 // If the field is not present on the origin, we won't overwrite it SkipFieldIfNotInFrom bool // contains filtered or unexported fields }
Option sets copy options
type TypeConverter ¶
type TypeConverter struct { SrcType interface{} DstType interface{} Fn func(src interface{}) (dst interface{}, err error) }
Click to show internal directories.
Click to hide internal directories.