package pgtype

import (
	
	
	
	
	
	

	
)

type Path struct {
	P      []Vec2
	Closed bool
	Status Status
}

func ( *Path) ( interface{}) error {
	return fmt.Errorf("cannot convert %v to Path", )
}

func ( Path) () interface{} {
	switch .Status {
	case Present:
		return 
	case Null:
		return nil
	default:
		return .Status
	}
}

func ( *Path) ( interface{}) error {
	return fmt.Errorf("cannot assign %v to %T", , )
}

func ( *Path) ( *ConnInfo,  []byte) error {
	if  == nil {
		* = Path{Status: Null}
		return nil
	}

	if len() < 7 {
		return fmt.Errorf("invalid length for Path: %v", len())
	}

	 := [0] == '('
	 := make([]Vec2, 0)

	 := string([2:])

	for {
		 := strings.IndexByte(, ',')
		,  := strconv.ParseFloat([:], 64)
		if  != nil {
			return 
		}

		 = [+1:]
		 = strings.IndexByte(, ')')

		,  := strconv.ParseFloat([:], 64)
		if  != nil {
			return 
		}

		 = append(, Vec2{, })

		if +3 < len() {
			 = [+3:]
		} else {
			break
		}
	}

	* = Path{P: , Closed: , Status: Present}
	return nil
}

func ( *Path) ( *ConnInfo,  []byte) error {
	if  == nil {
		* = Path{Status: Null}
		return nil
	}

	if len() < 5 {
		return fmt.Errorf("invalid length for Path: %v", len())
	}

	 := [0] == 1
	 := int(binary.BigEndian.Uint32([1:]))

	 := 5

	if 5+*16 != len() {
		return fmt.Errorf("invalid length for Path with %d points: %v", , len())
	}

	 := make([]Vec2, )
	for  := 0;  < len(); ++ {
		 := binary.BigEndian.Uint64([:])
		 += 8
		 := binary.BigEndian.Uint64([:])
		 += 8
		[] = Vec2{math.Float64frombits(), math.Float64frombits()}
	}

	* = Path{
		P:      ,
		Closed: ,
		Status: Present,
	}
	return nil
}

func ( Path) ( *ConnInfo,  []byte) ([]byte, error) {
	switch .Status {
	case Null:
		return nil, nil
	case Undefined:
		return nil, errUndefined
	}

	var ,  byte
	if .Closed {
		 = '('
		 = ')'
	} else {
		 = '['
		 = ']'
	}
	 = append(, )

	for ,  := range .P {
		if  > 0 {
			 = append(, ',')
		}
		 = append(, fmt.Sprintf(`(%s,%s)`,
			strconv.FormatFloat(.X, 'f', -1, 64),
			strconv.FormatFloat(.Y, 'f', -1, 64),
		)...)
	}

	return append(, ), nil
}

func ( Path) ( *ConnInfo,  []byte) ([]byte, error) {
	switch .Status {
	case Null:
		return nil, nil
	case Undefined:
		return nil, errUndefined
	}

	var  byte
	if .Closed {
		 = 1
	}
	 = append(, )

	 = pgio.AppendInt32(, int32(len(.P)))

	for ,  := range .P {
		 = pgio.AppendUint64(, math.Float64bits(.X))
		 = pgio.AppendUint64(, math.Float64bits(.Y))
	}

	return , nil
}
Scan implements the database/sql Scanner interface.
func ( *Path) ( interface{}) error {
	if  == nil {
		* = Path{Status: Null}
		return nil
	}

	switch src := .(type) {
	case string:
		return .DecodeText(nil, []byte())
	case []byte:
		 := make([]byte, len())
		copy(, )
		return .DecodeText(nil, )
	}

	return fmt.Errorf("cannot scan %T", )
}
Value implements the database/sql/driver Valuer interface.
func ( Path) () (driver.Value, error) {
	return EncodeValueText()