mirror of
https://github.com/go-gitea/gitea
synced 2024-11-07 18:54:25 +00:00
1790f01dd9
* Upgrade xorm to v1.2.2 (#16663) Backport #16663 Fix #16683 * Add test to ensure that dumping of login sources remains correct (#16847) #16831 has occurred because of a missed regression. This PR adds a simple test to try to prevent this occuring again. Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
79 lines
1.6 KiB
Go
Vendored
79 lines
1.6 KiB
Go
Vendored
package decoder
|
|
|
|
import (
|
|
"unsafe"
|
|
|
|
"github.com/goccy/go-json/internal/errors"
|
|
)
|
|
|
|
type boolDecoder struct {
|
|
structName string
|
|
fieldName string
|
|
}
|
|
|
|
func newBoolDecoder(structName, fieldName string) *boolDecoder {
|
|
return &boolDecoder{structName: structName, fieldName: fieldName}
|
|
}
|
|
|
|
func (d *boolDecoder) DecodeStream(s *Stream, depth int64, p unsafe.Pointer) error {
|
|
c := s.skipWhiteSpace()
|
|
for {
|
|
switch c {
|
|
case 't':
|
|
if err := trueBytes(s); err != nil {
|
|
return err
|
|
}
|
|
**(**bool)(unsafe.Pointer(&p)) = true
|
|
return nil
|
|
case 'f':
|
|
if err := falseBytes(s); err != nil {
|
|
return err
|
|
}
|
|
**(**bool)(unsafe.Pointer(&p)) = false
|
|
return nil
|
|
case 'n':
|
|
if err := nullBytes(s); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
case nul:
|
|
if s.read() {
|
|
c = s.char()
|
|
continue
|
|
}
|
|
goto ERROR
|
|
}
|
|
break
|
|
}
|
|
ERROR:
|
|
return errors.ErrUnexpectedEndOfJSON("bool", s.totalOffset())
|
|
}
|
|
|
|
func (d *boolDecoder) Decode(ctx *RuntimeContext, cursor, depth int64, p unsafe.Pointer) (int64, error) {
|
|
buf := ctx.Buf
|
|
cursor = skipWhiteSpace(buf, cursor)
|
|
switch buf[cursor] {
|
|
case 't':
|
|
if err := validateTrue(buf, cursor); err != nil {
|
|
return 0, err
|
|
}
|
|
cursor += 4
|
|
**(**bool)(unsafe.Pointer(&p)) = true
|
|
return cursor, nil
|
|
case 'f':
|
|
if err := validateFalse(buf, cursor); err != nil {
|
|
return 0, err
|
|
}
|
|
cursor += 5
|
|
**(**bool)(unsafe.Pointer(&p)) = false
|
|
return cursor, nil
|
|
case 'n':
|
|
if err := validateNull(buf, cursor); err != nil {
|
|
return 0, err
|
|
}
|
|
cursor += 4
|
|
return cursor, nil
|
|
}
|
|
return 0, errors.ErrUnexpectedEndOfJSON("bool", cursor)
|
|
}
|