|
Couchbase Lite C
Couchbase Lite C API
|
A CBLDocument is essentially a JSON object with an ID string that's unique in its database. More...
Typedefs | |
| typedef struct CBLDocument | CBLDocument |
| An in-memory copy of a document. | |
Variables | |
| CBL_PUBLIC const FLSlice | kCBLTypeProperty |
| "@type" | |
Document lifecycle | |
| enum | CBLConcurrencyControl : uint8_t { kCBLConcurrencyControlLastWriteWins , kCBLConcurrencyControlFailOnConflict } |
| typedef bool(* | CBLConflictHandler) (void *_cbl_nullable context, CBLDocument *_cbl_nullable documentBeingSaved, const CBLDocument *_cbl_nullable conflictingDocument) |
| Custom conflict handler for use when saving or deleting a document. | |
| CBLINLINE const CBLDocument * | CBLDocument_Retain (const CBLDocument *_cbl_nullable t) |
| CBLINLINE void | CBLDocument_Release (const CBLDocument *_cbl_nullable t) |
Mutable documents | |
The type CBLDocument* without a const qualifier refers to a mutable document instance. A mutable document exposes its properties as a mutable dictionary, so you can change them in place and then call CBLDatabase_SaveDocument to persist the changes. | |
| _cbl_warn_unused CBLDocument * | CBLDocument_Create (void) |
| Creates a new, empty document in memory, with a randomly-generated unique ID. | |
| _cbl_warn_unused CBLDocument * | CBLDocument_CreateWithID (FLString docID) |
| Creates a new, empty document in memory, with the given ID. | |
| _cbl_warn_unused CBLDocument * | CBLDocument_MutableCopy (const CBLDocument *original) |
| Creates a new mutable CBLDocument instance that refers to the same document as the original. | |
Document properties and metadata | |
A document's body is essentially a JSON object. The properties are accessed in memory using the Fleece API, with the body itself being a dictionary). | |
| FLString | CBLDocument_ID (const CBLDocument *) |
| Returns a document's ID. | |
| FLString | CBLDocument_RevisionID (const CBLDocument *) |
| Returns a document's revision ID, which is a short opaque string that's guaranteed to be unique to every change made to the document. | |
| uint64_t | CBLDocument_Timestamp (const CBLDocument *) |
| The hybrid logical timestamp in nanoseconds since epoch that the revision was created. | |
| uint64_t | CBLDocument_Sequence (const CBLDocument *) |
| Returns a document's current sequence in the local database. | |
| CBLCollection *_cbl_nullable | CBLDocument_Collection (const CBLDocument *) |
| Returns a document's collection or NULL for the new document that hasn't been saved. | |
| FLDict | CBLDocument_Properties (const CBLDocument *) |
| Returns a document's properties as a dictionary. | |
| FLMutableDict | CBLDocument_MutableProperties (CBLDocument *) |
| Returns a mutable document's properties as a mutable dictionary. | |
| void | CBLDocument_SetProperties (CBLDocument *, FLMutableDict properties) |
| Sets a mutable document's properties. | |
| _cbl_warn_unused FLSliceResult | CBLDocument_CreateJSON (const CBLDocument *) |
| Returns a document's properties as JSON. | |
| bool | CBLDocument_SetJSON (CBLDocument *, FLSlice json, CBLError *_cbl_nullable outError) |
| Sets a mutable document's properties from a JSON string. | |
A CBLDocument is essentially a JSON object with an ID string that's unique in its database.
| typedef bool(* CBLConflictHandler) (void *_cbl_nullable context, CBLDocument *_cbl_nullable documentBeingSaved, const CBLDocument *_cbl_nullable conflictingDocument) |
Custom conflict handler for use when saving or deleting a document.
This handler is called if the save would cause a conflict, i.e. if the document in the database has been updated (probably by a pull replicator, or by application code on another thread) since it was loaded into the CBLDocument being saved.
| context | The value of the context parameter you passed to CBLCollection_SaveDocumentWithConflictHandler. |
| documentBeingSaved | The document being saved (same as the parameter you passed to CBLCollection_SaveDocumentWithConflictHandler.) The callback may modify this document's properties as necessary to resolve the conflict. |
| conflictingDocument | The revision of the document currently in the database, which has been changed since documentBeingSaved was loaded. May be NULL, meaning that the document has been deleted. |
| typedef struct CBLDocument CBLDocument |
An in-memory copy of a document.
CBLDocument objects can be mutable or immutable. Immutable objects are referenced by const pointers; mutable ones by non-const pointers. This prevents you from accidentally calling a mutable-document function on an immutable document.
| enum CBLConcurrencyControl : uint8_t |
| CBLCollection *_cbl_nullable CBLDocument_Collection | ( | const CBLDocument * | ) |
Returns a document's collection or NULL for the new document that hasn't been saved.
| _cbl_warn_unused CBLDocument * CBLDocument_Create | ( | void | ) |
Creates a new, empty document in memory, with a randomly-generated unique ID.
It will not be added to a database until saved.
| _cbl_warn_unused FLSliceResult CBLDocument_CreateJSON | ( | const CBLDocument * | ) |
Returns a document's properties as JSON.
| _cbl_warn_unused CBLDocument * CBLDocument_CreateWithID | ( | FLString | docID | ) |
Creates a new, empty document in memory, with the given ID.
It will not be added to a database until saved.
| docID | The ID of the new document, or NULL to assign a new unique ID. |
| FLString CBLDocument_ID | ( | const CBLDocument * | ) |
Returns a document's ID.
| _cbl_warn_unused CBLDocument * CBLDocument_MutableCopy | ( | const CBLDocument * | original | ) |
Creates a new mutable CBLDocument instance that refers to the same document as the original.
If the original document has unsaved changes, the new one will also start out with the same changes; but mutating one document thereafter will not affect the other.
| FLMutableDict CBLDocument_MutableProperties | ( | CBLDocument * | ) |
Returns a mutable document's properties as a mutable dictionary.
You may modify this dictionary and then call CBLDatabase_SaveDocument to persist the changes.
| FLDict CBLDocument_Properties | ( | const CBLDocument * | ) |
Returns a document's properties as a dictionary.
| CBLINLINE void CBLDocument_Release | ( | const CBLDocument *_cbl_nullable | t | ) |
| CBLINLINE const CBLDocument * CBLDocument_Retain | ( | const CBLDocument *_cbl_nullable | t | ) |
| FLString CBLDocument_RevisionID | ( | const CBLDocument * | ) |
Returns a document's revision ID, which is a short opaque string that's guaranteed to be unique to every change made to the document.
If the document doesn't exist yet, this function returns NULL.
| uint64_t CBLDocument_Sequence | ( | const CBLDocument * | ) |
Returns a document's current sequence in the local database.
This number increases every time the document is saved, and a more recently saved document will have a greater sequence number than one saved earlier, so sequences may be used as an abstract 'clock' to tell relative modification times.
| bool CBLDocument_SetJSON | ( | CBLDocument * | , |
| FLSlice | json, | ||
| CBLError *_cbl_nullable | outError ) |
Sets a mutable document's properties from a JSON string.
| void CBLDocument_SetProperties | ( | CBLDocument * | , |
| FLMutableDict | properties ) |
Sets a mutable document's properties.
Call CBLDatabase_SaveDocument to persist the changes.
| uint64_t CBLDocument_Timestamp | ( | const CBLDocument * | ) |
The hybrid logical timestamp in nanoseconds since epoch that the revision was created.
|
extern |
"@type"