summaryrefslogtreecommitdiff
path: root/vendor/go.mongodb.org/mongo-driver/bson/unmarshal.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/go.mongodb.org/mongo-driver/bson/unmarshal.go')
-rw-r--r--vendor/go.mongodb.org/mongo-driver/bson/unmarshal.go177
1 files changed, 0 insertions, 177 deletions
diff --git a/vendor/go.mongodb.org/mongo-driver/bson/unmarshal.go b/vendor/go.mongodb.org/mongo-driver/bson/unmarshal.go
deleted file mode 100644
index 66da17ee0..000000000
--- a/vendor/go.mongodb.org/mongo-driver/bson/unmarshal.go
+++ /dev/null
@@ -1,177 +0,0 @@
-// Copyright (C) MongoDB, Inc. 2017-present.
-//
-// Licensed under the Apache License, Version 2.0 (the "License"); you may
-// not use this file except in compliance with the License. You may obtain
-// a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
-
-package bson
-
-import (
- "bytes"
-
- "go.mongodb.org/mongo-driver/bson/bsoncodec"
- "go.mongodb.org/mongo-driver/bson/bsonrw"
- "go.mongodb.org/mongo-driver/bson/bsontype"
-)
-
-// Unmarshaler is the interface implemented by types that can unmarshal a BSON
-// document representation of themselves. The input can be assumed to be a valid
-// encoding of a BSON document. UnmarshalBSON must copy the JSON data if it
-// wishes to retain the data after returning.
-//
-// Unmarshaler is only used to unmarshal full BSON documents. To create custom
-// BSON unmarshaling behavior for individual values in a BSON document,
-// implement the ValueUnmarshaler interface instead.
-type Unmarshaler interface {
- UnmarshalBSON([]byte) error
-}
-
-// ValueUnmarshaler is the interface implemented by types that can unmarshal a
-// BSON value representation of themselves. The input can be assumed to be a
-// valid encoding of a BSON value. UnmarshalBSONValue must copy the BSON value
-// bytes if it wishes to retain the data after returning.
-//
-// ValueUnmarshaler is only used to unmarshal individual values in a BSON
-// document. To create custom BSON unmarshaling behavior for an entire BSON
-// document, implement the Unmarshaler interface instead.
-type ValueUnmarshaler interface {
- UnmarshalBSONValue(bsontype.Type, []byte) error
-}
-
-// Unmarshal parses the BSON-encoded data and stores the result in the value
-// pointed to by val. If val is nil or not a pointer, Unmarshal returns
-// InvalidUnmarshalError.
-func Unmarshal(data []byte, val interface{}) error {
- return UnmarshalWithRegistry(DefaultRegistry, data, val)
-}
-
-// UnmarshalWithRegistry parses the BSON-encoded data using Registry r and
-// stores the result in the value pointed to by val. If val is nil or not
-// a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
-//
-// Deprecated: Use [NewDecoder] and specify the Registry by calling [Decoder.SetRegistry] instead:
-//
-// dec, err := bson.NewDecoder(bsonrw.NewBSONDocumentReader(data))
-// if err != nil {
-// panic(err)
-// }
-// dec.SetRegistry(reg)
-//
-// See [Decoder] for more examples.
-func UnmarshalWithRegistry(r *bsoncodec.Registry, data []byte, val interface{}) error {
- vr := bsonrw.NewBSONDocumentReader(data)
- return unmarshalFromReader(bsoncodec.DecodeContext{Registry: r}, vr, val)
-}
-
-// UnmarshalWithContext parses the BSON-encoded data using DecodeContext dc and
-// stores the result in the value pointed to by val. If val is nil or not
-// a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
-//
-// Deprecated: Use [NewDecoder] and use the Decoder configuration methods to set the desired unmarshal
-// behavior instead:
-//
-// dec, err := bson.NewDecoder(bsonrw.NewBSONDocumentReader(data))
-// if err != nil {
-// panic(err)
-// }
-// dec.DefaultDocumentM()
-//
-// See [Decoder] for more examples.
-func UnmarshalWithContext(dc bsoncodec.DecodeContext, data []byte, val interface{}) error {
- vr := bsonrw.NewBSONDocumentReader(data)
- return unmarshalFromReader(dc, vr, val)
-}
-
-// UnmarshalValue parses the BSON value of type t with bson.DefaultRegistry and
-// stores the result in the value pointed to by val. If val is nil or not a pointer,
-// UnmarshalValue returns an error.
-func UnmarshalValue(t bsontype.Type, data []byte, val interface{}) error {
- return UnmarshalValueWithRegistry(DefaultRegistry, t, data, val)
-}
-
-// UnmarshalValueWithRegistry parses the BSON value of type t with registry r and
-// stores the result in the value pointed to by val. If val is nil or not a pointer,
-// UnmarshalValue returns an error.
-//
-// Deprecated: Using a custom registry to unmarshal individual BSON values will not be supported in
-// Go Driver 2.0.
-func UnmarshalValueWithRegistry(r *bsoncodec.Registry, t bsontype.Type, data []byte, val interface{}) error {
- vr := bsonrw.NewBSONValueReader(t, data)
- return unmarshalFromReader(bsoncodec.DecodeContext{Registry: r}, vr, val)
-}
-
-// UnmarshalExtJSON parses the extended JSON-encoded data and stores the result
-// in the value pointed to by val. If val is nil or not a pointer, Unmarshal
-// returns InvalidUnmarshalError.
-func UnmarshalExtJSON(data []byte, canonical bool, val interface{}) error {
- return UnmarshalExtJSONWithRegistry(DefaultRegistry, data, canonical, val)
-}
-
-// UnmarshalExtJSONWithRegistry parses the extended JSON-encoded data using
-// Registry r and stores the result in the value pointed to by val. If val is
-// nil or not a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
-//
-// Deprecated: Use [NewDecoder] and specify the Registry by calling [Decoder.SetRegistry] instead:
-//
-// vr, err := bsonrw.NewExtJSONValueReader(bytes.NewReader(data), true)
-// if err != nil {
-// panic(err)
-// }
-// dec, err := bson.NewDecoder(vr)
-// if err != nil {
-// panic(err)
-// }
-// dec.SetRegistry(reg)
-//
-// See [Decoder] for more examples.
-func UnmarshalExtJSONWithRegistry(r *bsoncodec.Registry, data []byte, canonical bool, val interface{}) error {
- ejvr, err := bsonrw.NewExtJSONValueReader(bytes.NewReader(data), canonical)
- if err != nil {
- return err
- }
-
- return unmarshalFromReader(bsoncodec.DecodeContext{Registry: r}, ejvr, val)
-}
-
-// UnmarshalExtJSONWithContext parses the extended JSON-encoded data using
-// DecodeContext dc and stores the result in the value pointed to by val. If val is
-// nil or not a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
-//
-// Deprecated: Use [NewDecoder] and use the Decoder configuration methods to set the desired unmarshal
-// behavior instead:
-//
-// vr, err := bsonrw.NewExtJSONValueReader(bytes.NewReader(data), true)
-// if err != nil {
-// panic(err)
-// }
-// dec, err := bson.NewDecoder(vr)
-// if err != nil {
-// panic(err)
-// }
-// dec.DefaultDocumentM()
-//
-// See [Decoder] for more examples.
-func UnmarshalExtJSONWithContext(dc bsoncodec.DecodeContext, data []byte, canonical bool, val interface{}) error {
- ejvr, err := bsonrw.NewExtJSONValueReader(bytes.NewReader(data), canonical)
- if err != nil {
- return err
- }
-
- return unmarshalFromReader(dc, ejvr, val)
-}
-
-func unmarshalFromReader(dc bsoncodec.DecodeContext, vr bsonrw.ValueReader, val interface{}) error {
- dec := decPool.Get().(*Decoder)
- defer decPool.Put(dec)
-
- err := dec.Reset(vr)
- if err != nil {
- return err
- }
- err = dec.SetContext(dc)
- if err != nil {
- return err
- }
-
- return dec.Decode(val)
-}