BSONDocument
@dynamicMemberLookup
public struct BSONDocumentextension BSONDocument: Collectionextension BSONDocument: Sequenceextension BSONDocument: ExpressibleByDictionaryLiteralextension BSONDocument: Hashableextension BSONDocument: Equatableextension BSONDocument: CustomStringConvertibleextension BSONDocument: ContentA struct representing the BSON document type.
- 
                  
                  The element type of a document: a tuple containing an individual key-value pair. DeclarationSwift public typealias KeyValuePair = (key: String, value: BSON)
- 
                  
                  Initializes a new, empty BSONDocument.DeclarationSwift public init()
- 
                  
                  Initializes a new BSONDocumentfrom the provided BSON data.Throws Throws: - InvalidArgumentErrorif the data passed is invalid BSON
 See also DeclarationSwift public init(fromBSON bson: Data) throws
- 
                  
                  Initializes a new BSONDocument from the provided BSON data. The buffer must have readableBytes equal to the BSON’s leading size indicator. Throws Throws: - InvalidArgumentErrorif the data passed is invalid BSON
 See also DeclarationSwift public init(fromBSON bson: ByteBuffer) throws
- 
                  
                  Initialize a new BSONDocumentfrom the provided BSON data without validating the elements. The first four bytes must accurately reflect the length of the buffer, however.If invalid BSON data is provided, undefined behavior or server-side errors may occur when using the resultant BSONDocument.Throws BSONError.InvalidArgumentErrorif the provided BSON’s length does not match the encoded length.DeclarationSwift public init(fromBSONWithoutValidatingElements bson: ByteBuffer) throws
- 
                  
                  Constructs a new BSONDocumentfrom the provided JSON text.Throws DecodingErrorifjsonis a partial match or is malformed.DeclarationSwift public init(fromJSON json: Data) throwsParametersfromJSONa JSON document as Datato parse into aBSONDocumentReturn Valuethe parsed BSONDocument
- 
                  
                  Convenience initializer for constructing a BSONDocumentfrom aString.Throws DecodingErrorifjsonis a partial match or is malformed.DeclarationSwift public init(fromJSON json: String) throws
- 
                  
                  Returns the relaxed extended JSON representation of this BSONDocument. On error, an empty string will be returned.DeclarationSwift public func toExtendedJSONString() -> String
- 
                  
                  Returns the canonical extended JSON representation of this BSONDocument. On error, an empty string will be returned.DeclarationSwift public func toCanonicalExtendedJSONString() -> String
- 
                  
                  The keys in this BSONDocument.DeclarationSwift public var keys: [String] { get }
- 
                  
                  The values in this BSONDocument.DeclarationSwift public var values: [BSON] { get }
- 
                  
                  The number of (key, value) pairs stored at the top level of this document. DeclarationSwift public var count: Int { get }
- 
                  
                  A copy of the ByteBufferbacking this document, containing raw BSON data. AsByteBuffers implement copy-on-write, this copy will share byte storage with this document until either the document or the returned buffer is mutated.DeclarationSwift public var buffer: ByteBuffer { get }
- 
                  
                  Returns a Datacontaining a copy of the raw BSON data backing this document.DeclarationSwift public func toData() -> Data
- 
                  
                  Returns a Booleanindicating whether thisBSONDocumentcontains the provided key.DeclarationSwift public func hasKey(_ key: String) -> Bool
- 
                  
                  Allows getting and setting values on the document via subscript syntax. For example: let d = BSONDocument() d["a"] = 1 print(d["a"]) // prints 1A nil return value indicates that the key does not exist in the BSONDocument. A true BSON null is returned asBSON.null.DeclarationSwift public subscript(key: String) -> BSON? { get set }
- 
                  
                  Looks up the specified key in the document and returns its corresponding value, or returns defaultValueif the key is not present.For example: let d: BSONDocument = ["hello": "world"] print(d["hello", default: "foo"]) // prints "world" print(d["a", default: "foo"]) // prints "foo"Declaration
- 
                  
                  Allows getting and setting values on the document using dot-notation syntax. For example: let d = BSONDocument() d.a = 1 print(d.a) // prints 1A nil return value indicates that the key does not exist in the BSONDocument. A true BSON null is returned asBSON.null.DeclarationSwift public subscript(dynamicMember member: String) -> BSON? { get set }
- 
                  
                  Returns a copy of this document with an _idelement prepended. If the document already contains an_id, returns the document as-is.Throws BSONError.DocumentTooLargeErrorif adding the_idwould make the document exceed the maximum allowed size for a document.DeclarationSwift public func withID() throws -> BSONDocument
- 
                  
                  The index type of a document. DeclarationSwift public typealias Index = Int
- 
                  
                  Returns the start index of the Document. DeclarationSwift public var startIndex: Index { get }
- 
                  
                  Returns the end index of the Document. DeclarationSwift public var endIndex: Index { get }
- 
                  
                  Returns the index after the given index for this Document. 
- 
                  
                  Allows access to a KeyValuePairfrom theBSONDocument, given the position of the desiredKeyValuePairheld within. This method does not guarantee constant-time (O(1)) access.DeclarationSwift public subscript(position: Index) -> KeyValuePair { get }
- 
                  
                  Allows access to a KeyValuePairfrom theBSONDocument, given a range of indices of the desiredKeyValuePair‘s held within. This method does not guarantee constant-time (O(1)) access.DeclarationSwift public subscript(bounds: Range<Index>) -> BSONDocument { get }
- 
                  
                  The type that is returned from methods such as dropFirst()andsplit().DeclarationSwift public typealias SubSequence = BSONDocument
- 
                  
                  Returns a Boolindicating whether the document is empty.DeclarationSwift public var isEmpty: Bool { get }
- 
                  
                  Returns a DocumentIteratorover the values in thisDocument.DeclarationSwift public func makeIterator() -> BSONDocumentIterator
- 
                  
                  DeclarationSwift @inlinable public func map<T>( _ transform: (Element) throws -> T ) rethrows -> [T]
- 
                  
                  Returns a new document containing the keys of this document with the values transformed by the given closure. Throws An error if transformthrows an error.DeclarationParameterstransformReturn ValueA document containing the keys and transformed values of this document. 
- 
                  
                  Returns a document containing all but the given number of initial key-value pairs. DeclarationSwift public func dropFirst(_ n: Int) -> BSONDocumentParameterskThe number of key-value pairs to drop from the beginning of the document. k must be > 0. Return ValueA document starting after the specified number of key-value pairs. 
- 
                  
                  Returns a document containing all but the given number of final key-value pairs. DeclarationSwift public func dropLast(_ n: Int) -> BSONDocumentParameterskThe number of key-value pairs to drop from the end of the document. Must be greater than or equal to zero. Return ValueA document leaving off the specified number of final key-value pairs. 
- 
                  
                  Returns a document by skipping the initial, consecutive key-value pairs that satisfy the given predicate. Throws An error if predicatethrows an error.DeclarationSwift public func drop(while predicate: (KeyValuePair) throws -> Bool) rethrows -> BSONDocumentParameterspredicateA closure that takes a key-value pair as its argument and returns a boolean indicating whether the key-value pair should be included in the result. Return ValueA document starting after the initial, consecutive key-value pairs that satisfy predicate.
- 
                  
                  Returns a document, up to the specified maximum length, containing the initial key-value pairs of the document. DeclarationSwift public func prefix(_ maxLength: Int) -> BSONDocumentParametersmaxLengthThe maximum length for the returned document. Must be greater than or equal to zero. Return ValueA document starting at the beginning of this document with at most maxLengthkey-value pairs.
- 
                  
                  Returns a document containing the initial, consecutive key-value pairs that satisfy the given predicate. Throws An error if predicatethrows an error.DeclarationSwift public func prefix(while predicate: (KeyValuePair) throws -> Bool) rethrows -> BSONDocumentParameterspredicateA closure that takes a key-value pair as its argument and returns a boolean indicating whether the key-value pair should be included in the result. Return ValueA document containing the initial, consecutive key-value pairs that satisfy predicate.
- 
                  
                  Returns a document, up to the specified maximum length, containing the final key-value pairs of the document. DeclarationSwift public func suffix(_ maxLength: Int) -> BSONDocumentParametersmaxLengthThe maximum length for the returned document. Must be greater than or equal to zero. Return ValueA document ending at the end of this document with at most maxLengthkey-value pairs.
- 
                  
                  Returns the longest possible subsequences of the document, in order, that don’t contain key-value pairs satisfying the given predicate. Key-value pairs that are used to split the document are not returned as part of any subsequence. DeclarationSwift public func split( maxSplits: Int = Int.max, omittingEmptySubsequences: Bool = true, whereSeparator isSeparator: (KeyValuePair) throws -> Bool ) rethrows -> [BSONDocument]ParametersmaxSplitsThe maximum number of times to split the document, or one less than the number of subsequences to return. If maxSplits+ 1 subsequences are returned, the last one is a suffix of the original document containing the remaining key-value pairs.maxSplitsmust be greater than or equal to zero. The default value isInt.max.omittingEmptySubsequencesIf false, an empty document is returned in the result for each pair of consecutive key-value pairs satisfying the isSeparatorpredicate and for each key-value pair at the start or end of the document satisfying theisSeparatorpredicate. If true, only nonempty documents are returned. The default value is true.isSeparatorA closure that returns true if its argument should be used to split the document and otherwise returns false. Return ValueAn array of documents, split from this document’s key-value pairs. 
- 
                  
                  Initializes a BSONDocumentusing a dictionary literal where the keys areStringsand the values areBSONs. For example:d: BSONDocument = ["a" : 1 ]DeclarationSwift public init(dictionaryLiteral keyValuePairs: (String, BSON)...)ParametersdictionaryLiterala [String: BSON] Return Valuea new BSONDocument
- 
                  
                  DeclarationSwift public func hash(into hasher: inout Hasher)
- 
                  
                  DeclarationSwift public static func == (lhs: BSONDocument, rhs: BSONDocument) -> Bool
- 
                  
                  DeclarationSwift public var description: String { get }
- 
                  
                  Returns whether this BSONDocumentcontains exactly the same key/value pairs as the providedBSONDocument, regardless of the order of the keys.Warning: This method is much less efficient than checking for regular equality since the document is internally ordered. DeclarationSwift public func equalsIgnoreKeyOrder(_ other: BSONDocument) -> BoolParametersothera BSONDocumentto compare this document with.Return Valuea Boolindicating whether the two documents are equal.
- 
                  
                  Returns a new document containing the elements of the document that satisfy the given predicate. Throws An error if isIncludedthrows an error.DeclarationSwift public func filter(_ isIncluded: (KeyValuePair) throws -> Bool) rethrows -> BSONDocumentParametersisIncludedA closure that takes a key-value pair as its argument and returns a Boolindicating whether the pair should be included in the returned document.Return ValueA document containing the key-value pairs that isIncludedallows.
 View on GitHub
            View on GitHub
           Install in Dash
            Install in Dash
           BSONDocument Structure Reference
      BSONDocument Structure Reference