API reference
Array
Bases: BaseType
, Generic[T]
A collection used to store data in an indexed sequence structure, similar to a Python list
.
doc
property
The document this shared type belongs to.
Raises:
Type | Description |
---|---|
RuntimeError
|
Not integrated in a document yet. |
__add__(value)
Extends the array with a list of items:
Doc()["array"] = array = Array(["foo"])
array += ["bar", "baz"]
assert array.to_py() == ["foo", "bar", "baz"]
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value
|
list[T]
|
The items that will extend the array. |
required |
Returns:
Type | Description |
---|---|
Array[T]
|
The extended array. |
__contains__(item)
Checks if the given item is in the array:
Doc()["array"] = array = Array(["foo", "bar"])
assert "baz" not in array
Parameters:
Name | Type | Description | Default |
---|---|---|---|
item
|
T
|
The item to look for in the array. |
required |
Returns:
Type | Description |
---|---|
bool
|
True if the item was found. |
__delitem__(key)
Removes the item at the given index from the array:
Doc()["array"] = array = Array(["foo", "bar", "baz"])
del array[2]
assert array.to_py() == ["foo", "bar"]
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
int | slice
|
The index of the item to remove. |
required |
Raises:
Type | Description |
---|---|
RuntimeError
|
Array indices must be integers or slices. |
__getitem__(key)
__getitem__(key: int) -> T
__getitem__(key: slice) -> list[T]
Gets the item at the given index:
Doc()["array"] = array = Array(["foo", "bar", "baz"])
assert array[1] == "bar"
Returns:
Type | Description |
---|---|
The item at the given index. |
__init__(init=None, *, _doc=None, _integrated=None)
Creates an array with an optional initial value:
array0 = Array()
array1 = Array(["foo", 3, array0])
Parameters:
Name | Type | Description | Default |
---|---|---|---|
init
|
list[T] | None
|
The list from which to initialize the array. |
None
|
__iter__()
Doc()["array"] = array = Array(["foo", "foo"])
for value in array:
assert value == "foo"
__len__()
Doc()["array"] = array = Array([2, 3, 0])
assert len(array) == 3
Returns:
Type | Description |
---|---|
int
|
The length of the array. |
__radd__(value)
Prepends a list of items to the array:
Doc()["array"] = array = Array(["bar", "baz"])
array = ["foo"] + array
assert array.to_py() == ["foo", "bar", "baz"]
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value
|
list[T]
|
The list of items to prepend. |
required |
Returns:
Type | Description |
---|---|
Array[T]
|
The prepended array. |
__setitem__(key, value)
__setitem__(key: int, value: T) -> None
__setitem__(key: slice, value: list[T]) -> None
Replaces the item at the given index with a new item:
Doc()["array"] = array = Array(["foo", "bar"])
array[1] = "baz"
assert array.to_py() == ["foo", "baz"]
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
The index of the item to replace. |
required | |
value
|
The new item to set. |
required |
Raises:
Type | Description |
---|---|
RuntimeError
|
Index must be of type integer. |
__str__()
Doc()["array"] = array = Array([2, 3, 0])
assert str(array) == "[2,3,0]"
Returns:
Type | Description |
---|---|
str
|
The string representation of the array. |
append(value)
Appends an item to the array.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value
|
T
|
The item to append to the array. |
required |
clear()
Removes all items from the array.
extend(value)
Extends the array with a list of items.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value
|
list[T]
|
The items that will extend the array. |
required |
insert(index, object)
Inserts an item at a given index in the array.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
index
|
int
|
The index where to insert the item. |
required |
object
|
T
|
The item to insert in the array. |
required |
move(source_index, destination_index)
Moves an item in the array from a source index to a destination index.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
source_index
|
int
|
The index of the item to move. |
required |
destination_index
|
int
|
The index where the item will be inserted. |
required |
observe(callback)
Subscribes a callback to be called with the array event.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[ArrayEvent], None]
|
The callback to call with the ArrayEvent. |
required |
observe_deep(callback)
Subscribes a callback for all events emitted by this and nested collaborative types.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[list[BaseEvent]], None]
|
The callback to call with the list of events. |
required |
pop(index=-1)
Removes the item at the given index from the array, and returns it. If no index is passed, removes and returns the last item.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
index
|
int
|
The optional index of the item to pop. |
-1
|
Returns:
Type | Description |
---|---|
T
|
The item at the given index, or the last item. |
to_py()
Recursively converts the array's items to Python objects, and
returns them in a list. If the array was not yet inserted in a document,
returns None
if the array was not initialized.
Returns:
Type | Description |
---|---|
list[T] | None
|
The array recursively converted to Python objects, or |
unobserve(subscription)
Unsubscribes to changes using the given subscription.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
subscription
|
Subscription
|
The subscription to unregister. |
required |
ArrayEvent
Bases: BaseEvent
An array change event.
Attributes:
Name | Type | Description |
---|---|---|
target |
Array
|
The changed array. |
delta |
list[dict[str, Any]]
|
A list of items describing the changes. |
path |
list[int | str]
|
A list with the indices pointing to the array that was changed. |
Awareness
meta
property
The clients' metadata.
states
property
The client states.
__init__(ydoc, *, outdated_timeout=30000)
apply_awareness_update(update, origin)
Applies the binary update and notifies subscribers with changes.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
update
|
bytes
|
The binary update. |
required |
origin
|
Any
|
The origin of the update. |
required |
encode_awareness_update(client_ids)
Creates an encoded awareness update of the clients given by their IDs.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
client_ids
|
list[int]
|
The list of client IDs for which to create an update. |
required |
Returns:
Type | Description |
---|---|
bytes
|
The encoded awareness update. |
get_local_state()
Returns:
Type | Description |
---|---|
dict[str, Any] | None
|
The local state, if any. |
observe(callback)
Registers the given callback to awareness changes.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[str, tuple[dict[str, Any], Any]], None]
|
The callback to call with the awareness changes. |
required |
Returns:
Type | Description |
---|---|
str
|
The subscription ID that can be used to unobserve. |
remove_awareness_states(client_ids, origin)
Removes awareness states for clients given by their IDs.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
client_ids
|
list[int]
|
The list of client IDs for which to remove the awareness states. |
required |
origin
|
Any
|
The origin of the update. |
required |
set_local_state(state)
Updates the local state and meta, and sends the changes to subscribers.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
state
|
dict[str, Any] | None
|
The new local state, if any. |
required |
set_local_state_field(field, value)
Sets a local state field.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
field
|
str
|
The field of the local state to set. |
required |
value
|
Any
|
The value associated with the field. |
required |
start(*, task_status=TASK_STATUS_IGNORED)
async
Starts updating the awareness periodically.
stop()
async
Stops updating the awareness periodically.
unobserve(id)
Unregisters the given subscription ID from awareness changes.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
id
|
str
|
The subscription ID to unregister. |
required |
Decoder
A decoder capable of reading messages from a byte stream.
__init__(stream)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
stream
|
bytes
|
The byte stream from which to read messages. |
required |
read_message()
Reads a message from the byte stream, ready to read the next message if any.
Returns:
Type | Description |
---|---|
bytes | None
|
The current message, if any. |
read_messages()
A generator that reads messages from the byte stream.
Returns:
Type | Description |
---|---|
Iterator[bytes]
|
A generator that yields messages. |
read_var_string()
Reads a message as an UTF-8 string from the byte stream, ready to read the next message if any.
Returns:
Type | Description |
---|---|
str
|
The current message as a string. |
read_var_uint()
Decodes the current message length.
Returns:
Type | Description |
---|---|
int
|
The decoded length of the message. |
Doc
Bases: BaseDoc
, Generic[T]
A shared document.
All shared types live within the scope of their corresponding documents. All updates are generated on a per-document basis. All operations on shared types happen in a transaction, whose lifetime is also bound to a document.
client_id
property
The document client ID.
guid
property
The GUID of the document.
__getitem__(key)
Gets the document root type corresponding to the given key:
text = doc["text"]
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
str
|
The key of the root type to get. |
required |
Returns:
Type | Description |
---|---|
T
|
The document root type. |
__init__(init={}, *, client_id=None, doc=None, Model=None, allow_multithreading=False)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
init
|
dict[str, T]
|
The initial root types of the document. |
{}
|
client_id
|
int | None
|
An optional client ID for the document. |
None
|
allow_multithreading
|
bool
|
Whether to allow the document to be used in different threads. |
False
|
__iter__()
Returns:
Type | Description |
---|---|
Iterable[str]
|
An iterable over the keys of the document root types. |
__setitem__(key, value)
Sets a document root type:
doc["text"] = Text("Hello")
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
str
|
The name of the root type. |
required |
value
|
T
|
The root type. |
required |
Raises:
Type | Description |
---|---|
RuntimeError
|
Key must be of type string. |
apply_update(update)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
update
|
bytes
|
The update to apply to the document. |
required |
get(key, *, type)
Gets the document root type corresponding to the given key. If it already exists, it will be cast to the given type (if different), otherwise a new root type is created.
doc.get("text", type=Text)
Returns:
Type | Description |
---|---|
T
|
The root type corresponding to the given key, cast to the given type. |
get_state()
Returns:
Type | Description |
---|---|
bytes
|
The current document state. |
get_update(state=None)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
state
|
bytes | None
|
The optional document state from which to get the update. |
None
|
Returns:
Type | Description |
---|---|
bytes
|
The update from the given document state (if any), or from the document creation. |
items()
Returns:
Type | Description |
---|---|
Iterable[tuple[str, T]]
|
An iterable over the key-value pairs of document root types. |
keys()
Returns:
Type | Description |
---|---|
Iterable[str]
|
An iterable over the names of the document root types. |
new_transaction(origin=None, timeout=None)
Creates a new transaction. Unlike transaction(), this method will not reuse an ongoing transaction. If there is already an ongoing transaction, this method will wait (with an optional timeout) until the current transaction has finished. There are two ways to do so:
-
Use an async context manager:
In this case you most likely access the document in the same thread, which means that the Doc can be created withasync with doc.new_transaction(): ...
allow_multithreading=False
. -
Use a (sync) context manager:
In this case you want to use multithreading, as the ongoing transaction must run in another thread (otherwise this will deadlock), which means that the Doc must have been created withwith doc.new_transaction(): ...
allow_multithreading=True
.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
origin
|
Any
|
An optional origin to set on this transaction. |
None
|
timeout
|
float | None
|
An optional timeout (in seconds) to acquire a new transaction. |
None
|
Raises:
Type | Description |
---|---|
RuntimeError
|
Already in a transaction. |
TimeoutError
|
Could not acquire transaction. |
Returns:
Type | Description |
---|---|
NewTransaction
|
A new transaction. |
observe(callback)
Subscribes a callback to be called with the document change event.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[TransactionEvent], None]
|
The callback to call with the [TransactionEvent][pycrdt.TransactionEvent]. |
required |
Returns:
Type | Description |
---|---|
Subscription
|
The subscription that can be used to unobserve(). |
observe_subdocs(callback)
Subscribes a callback to be called with the document subdoc change event.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[SubdocsEvent], None]
|
The callback to call with the [SubdocsEvent][pycrdt.SubdocsEvent]. |
required |
Returns:
Type | Description |
---|---|
Subscription
|
The subscription that can be used to unobserve(). |
transaction(origin=None)
Creates a new transaction or gets the current one, if any. If an origin is passed and there is already an ongoing transaction, the passed origin must be the same as the origin of the current transaction.
This method must be used with a context manager:
with doc.transaction():
...
Parameters:
Name | Type | Description | Default |
---|---|---|---|
origin
|
Any
|
An optional origin to set on this transaction. |
None
|
Raises:
Type | Description |
---|---|
RuntimeError
|
Nested transactions must have same origin as root transaction. |
Returns:
Type | Description |
---|---|
Transaction
|
A new transaction or the current one. |
unobserve(subscription)
Unsubscribes to changes using the given subscription.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
subscription
|
Subscription
|
The subscription to unregister. |
required |
values()
Returns:
Type | Description |
---|---|
Iterable[T]
|
An iterable over the document root types. |
Encoder
An encoder capable of writing messages to a binary stream.
to_bytes()
Returns:
Type | Description |
---|---|
bytes
|
The binary stream. |
write_var_string(text)
Encodes a string.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
text
|
str
|
The string to encode. |
required |
write_var_uint(num)
Encodes a number.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
num
|
int
|
The number to encode. |
required |
Map
Bases: BaseType
, Generic[T]
A collection used to store key-value entries in an unordered manner, similar to a Python dict
.
doc
property
The document this shared type belongs to.
Raises:
Type | Description |
---|---|
RuntimeError
|
Not integrated in a document yet. |
__contains__(item)
Checks if the given key is in the map:
Doc()["map0"] = map0 = Map({"foo": 0, "bar": 0})
assert "baz" not in map0:
Parameters:
Name | Type | Description | Default |
---|---|---|---|
item
|
str
|
The key to look for in the map. |
required |
Returns:
Type | Description |
---|---|
bool
|
True if the key was found. |
__delitem__(key)
Removes the item at the given key from the map:
Doc()["map0"] = map0 = Map({"foo": 0, "bar": 1})
del map0["foo"]
assert map0.to_py() == {"bar": 1}
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
str
|
The key of the item to remove. |
required |
__getitem__(key)
Gets the value at the given key:
Doc()["map0"] = map0 = Map({"foo": 0, "bar": 1})
assert map0["foo"] == 0
Returns:
Type | Description |
---|---|
T
|
The value at the given key. |
__init__(init=None, *, _doc=None, _integrated=None)
Creates a map with an optional initial value:
map0 = Map()
map1 = Map({"foo": 0, "bar": 3, "baz": map0})
Parameters:
Name | Type | Description | Default |
---|---|---|---|
init
|
dict[str, T] | None
|
The list from which to initialize the array. |
None
|
__iter__()
Doc()["map0"] = map0 = Map({"foo": 0, "bar": 0})
for key in m0:
assert map[key] == 0
__len__()
Doc()["map0"] = map0 = Map({"foo": 0, "bar": 1})
assert len(map0) == 2
__setitem__(key, value)
Sets a value at the given key:
Doc()["map0"] = map0 = Map({"foo": 0, "bar": 1})
map0["foo"] = 2
assert map0["foo"] == 2
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
str
|
The key to set. |
required |
value
|
T
|
The value to set. |
required |
Raises:
Type | Description |
---|---|
RuntimeError
|
Key must be of type string. |
__str__()
Doc()["map0"] = map0 = Map({"foo": 0, "bar": 1})
assert str(map0) == '{"foo":0,"bar":1}'
Returns:
Type | Description |
---|---|
str
|
The string representation of the map. |
clear()
Removes all entries from the map.
get(*args)
get(key: str) -> T | None
get(key: str, default_value: T_DefaultValue) -> T | T_DefaultValue
Returns the value corresponding to the given key if it exists, otherwise
returns the default value if passed, or None
.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
args
|
The key of the value to get, and an optional default value. |
()
|
Returns:
Type | Description |
---|---|
The value at the given key, or the default value or |
items()
Returns:
Type | Description |
---|---|
Iterable[tuple[str, T]]
|
An iterable over the key-value pairs of the map. |
keys()
Returns:
Type | Description |
---|---|
Iterable[str]
|
An iterable over the keys of the map. |
observe(callback)
observe_deep(callback)
Subscribes a callback for all events emitted by this and nested collaborative types.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[list[BaseEvent]], None]
|
The callback to call with the list of events. |
required |
pop(*args)
pop(key: str) -> T
pop(key: str, default_value: T_DefaultValue) -> T | T_DefaultValue
Removes the entry at the given key from the map, and returns the corresponding value.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
args
|
The key of the value to pop, and an optional default value. |
()
|
Returns:
Type | Description |
---|---|
The value at the given key, or the default value if passed. |
to_py()
Recursively converts the map's items to Python objects, and
returns them in a dict
. If the map was not yet inserted in a document,
returns None
if the map was not initialized.
Returns:
Type | Description |
---|---|
dict[str, T] | None
|
The map recursively converted to Python objects, or |
unobserve(subscription)
Unsubscribes to changes using the given subscription.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
subscription
|
Subscription
|
The subscription to unregister. |
required |
update(value)
Sets entries in the map from all entries in the passed dict
.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value
|
dict[str, T]
|
The |
required |
values()
Returns:
Type | Description |
---|---|
Iterable[T]
|
An iterable over the values of the map. |
MapEvent
Bases: BaseEvent
A map change event.
Attributes:
Name | Type | Description |
---|---|---|
target |
Map
|
The changed map. |
delta |
list[dict[str, Any]]
|
A list of items describing the changes. |
path |
list[int | str]
|
A list with the indices pointing to the map that was changed. |
NewTransaction
Bases: Transaction
A read-write transaction that can be used to mutate a document. It can be used with a context manager or an async context manager (see Doc.new_transaction()):
with doc.new_transaction():
...
async with doc.new_transaction():
...
origin
property
The origin of the transaction.
Raises:
Type | Description |
---|---|
RuntimeError
|
No current transaction. |
ReadTransaction
Bases: Transaction
A read-only transaction that cannot be used to mutate a document.
origin
property
The origin of the transaction.
Raises:
Type | Description |
---|---|
RuntimeError
|
No current transaction. |
Text
Bases: BaseType
A shared data type used for collaborative text editing, similar to a Python str
.
doc
property
The document this shared type belongs to.
Raises:
Type | Description |
---|---|
RuntimeError
|
Not integrated in a document yet. |
__contains__(item)
Checks if the given string is in the text:
Doc()["text"] = text = Text("Hello, World!")
assert "World" in text
Parameters:
Name | Type | Description | Default |
---|---|---|---|
item
|
str
|
The string to look for in the text. |
required |
Returns:
Type | Description |
---|---|
bool
|
True if the string was found. |
__delitem__(key)
Removes the characters at the given index or slice:
Doc()["text"] = text = Text("Hello, World!")
del text[5]
assert str(text) == "Hello World!"
del text[5:]
assert str(text) == "Hello"
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
int | slice
|
The index or the slice of the characters to remove. |
required |
Raises:
Type | Description |
---|---|
RuntimeError
|
Step not supported. |
RuntimeError
|
Negative start not supported. |
RuntimeError
|
Negative stop not supported. |
__getitem__(key)
Gets the characters at the given index or slice:
Doc()["text"] = text = Text("Hello, World!")
assert text[:5] == "Hello"
Returns:
Type | Description |
---|---|
str
|
The characters at the given index or slice. |
__iadd__(value)
Concatenates a string to the text:
Doc()["text"] = text = Text("Hello")
text += ", World!"
assert str(text) == "Hello, World!"
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value
|
str
|
The string to concatenate. |
required |
Returns:
Type | Description |
---|---|
Text
|
The concatenated text. |
__init__(init=None, *, _doc=None, _integrated=None)
Creates a text with an optional initial value:
text = Text("Hello, World!")
Parameters:
Name | Type | Description | Default |
---|---|---|---|
init
|
str | None
|
The string from which to initialize the text. |
None
|
__iter__()
Doc()["text"] = text = Text("***")
for character in text:
assert character == "*"
Returns:
Type | Description |
---|---|
Iterator[str]
|
An iterable over the characters of the text. |
__len__()
Doc()["text"] = text = Text("Hello")
assert len(text) == 5
Returns:
Type | Description |
---|---|
int
|
The length of the text. |
__setitem__(key, value)
Replaces the characters at the given index or slice with new characters:
Doc()["text"] = text = Text("Hello, World!")
text[7:12] = "Brian"
assert text == "Hello, Brian!"
Parameters:
Name | Type | Description | Default |
---|---|---|---|
key
|
int | slice
|
The index or slice of the characters to replace. |
required |
value
|
str
|
The new characters to set. |
required |
Raises:
Type | Description |
---|---|
RuntimeError
|
Step not supported. |
RuntimeError
|
Negative start not supported. |
RuntimeError
|
Negative stop not supported. |
RuntimeError
|
Single item assigned value must have a length of 1. |
__str__()
Returns:
Type | Description |
---|---|
str
|
The text as a Python |
clear()
Remove the entire range of characters.
diff()
Returns:
Type | Description |
---|---|
list[tuple[Any, dict[str, Any] | None]]
|
A list of formatted chunks that the current text corresponds to. Each list item is a tuple containing the chunk's content and formatting attributes. The content is usually the text as a string, but may be other data for embedded objects. |
format(start, stop, attrs)
Applies formatting attributes to a section of text between given start and stop indices.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
start
|
int
|
The index at which to start applying attributes (included). |
required |
stop
|
int
|
The index at which to stop applying attributes (excluded). |
required |
attrs
|
dict[str, Any]
|
The formatting attributes to apply. |
required |
insert(index, value, attrs=None)
Inserts a string at a given index in the text, with optional attributes.
Doc()["text"] = text = Text("Hello World!")
text.insert(5, ",")
assert text == "Hello, World!"
Parameters:
Name | Type | Description | Default |
---|---|---|---|
index
|
int
|
The index where to insert the string. |
required |
value
|
str
|
The string to insert in the text. |
required |
attrs
|
dict[str, Any] | None
|
The formatting of attributes to apply. |
None
|
insert_embed(index, value, attrs=None)
Insert a value as an embed at a given index in the text, with optional attributes.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
index
|
int
|
The index where to insert the embedded content. |
required |
value
|
Any
|
The value to embed. |
required |
attrs
|
dict[str, Any] | None
|
The formatting attributes to apply. |
None
|
observe(callback)
observe_deep(callback)
Subscribes a callback for all events emitted by this and nested collaborative types.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[list[BaseEvent]], None]
|
The callback to call with the list of events. |
required |
to_py()
Returns:
Type | Description |
---|---|
str | None
|
The text as a Python |
unobserve(subscription)
Unsubscribes to changes using the given subscription.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
subscription
|
Subscription
|
The subscription to unregister. |
required |
TextEvent
Bases: BaseEvent
A text change event.
Attributes:
Name | Type | Description |
---|---|---|
target |
Text
|
The changed text. |
delta |
list[dict[str, Any]]
|
A list of items describing the changes. |
path |
list[int | str]
|
A list with the indices pointing to the text that was changed. |
Transaction
A read-write transaction that can be used to mutate a document. It must be used with a context manager (see Doc.transaction()):
with doc.transaction():
...
origin
property
The origin of the transaction.
Raises:
Type | Description |
---|---|
RuntimeError
|
No current transaction. |
TypedArray
Bases: Typed
, Generic[T]
A container for an Array where values have types that can be
other typed containers, e.g. a TypedMap. The subclass of TypedArray[T]
must have a special type: T
annotation where T
is the same type.
The underlying Array
can be accessed with the special _
attribute.
from pycrdt import Array, TypedArray, TypedDoc, TypedMap
class MyMap(TypedMap):
name: str
toggle: bool
nested: Array[bool]
class MyArray(TypedArray[MyMap]):
type: MyMap
class MyDoc(TypedDoc):
array0: MyArray
doc = MyDoc()
map0 = MyMap()
doc.array0.append(map0)
map0.name = "foo"
map0.toggle = True
map0.nested = Array([True, False])
print(doc.array0._.to_py())
# [{'name': 'foo', 'toggle': True, 'nested': [True, False]}]
print(doc.array0[0].name)
# foo
print(doc.array0[0].toggle)
# True
print(doc.array0[0].nested.to_py())
# [True, False]
TypedDoc
Bases: Typed
A container for a Doc where root shared values have types associated
with specific keys. The underlying Doc
can be accessed with the special _
attribute.
from pycrdt import Array, Doc, Map, Text, TypedDoc
class MyDoc(TypedDoc):
map0: Map[int]
array0: Array[bool]
text0: Text
doc = MyDoc()
doc.map0["foo"] = 3
doc.array0.append(True)
doc.text0 += "Hello"
untyped_doc: Doc = doc._
TypedMap
Bases: Typed
A container for a Map where values have types associated with
specific keys. The underlying Map
can be accessed with the special _
attribute.
from pycrdt import Array, Map, TypedDoc, TypedMap
class MyMap(TypedMap):
name: str
toggle: bool
nested: Array[bool]
class MyDoc(TypedDoc):
map0: MyMap
doc = MyDoc()
doc.map0.name = "John"
doc.map0.toggle = True
doc.map0.nested = Array([True, False])
print(doc.map0._.to_py())
# {'nested': [True, False], 'toggle': True, 'name': 'John'}
UndoManager
The undo manager allows to perform undo/redo operations on shared types.
It can be initialized either with a Doc or with scopes.
Scopes are a list of shared types integrated in a document.
If initialized with a Doc
, scopes can later be expanded.
Changes can be undone/redone by batches using time intervals.
It is possible to include/exclude changes by transaction origin in undo/redo operations.
redo_stack
property
The list of redoable actions.
undo_stack
property
The list of undoable actions.
__init__(*, doc=None, scopes=[], capture_timeout_millis=500)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
doc
|
Doc | None
|
The document the undo manager will work with. |
None
|
scopes
|
list[BaseType]
|
A list of shared types the undo manager will work with. |
[]
|
capture_timeout_millis
|
int
|
A time interval for grouping changes that will be undone/redone. |
500
|
Raises:
Type | Description |
---|---|
RuntimeError
|
UndoManager must be created with doc or scopes. |
can_redo()
Returns:
Type | Description |
---|---|
bool
|
True if there are changes to redo. |
can_undo()
Returns:
Type | Description |
---|---|
bool
|
True if there are changes to undo. |
clear()
Clears all [StackItem][pycrdt.StackItem]s stored in this undo manager, effectively resetting its state.
exclude_origin(origin)
Removes a transaction origin from the list of origins tracked by this undo manager.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
origin
|
Any
|
The origin to exclude. |
required |
expand_scope(scope)
Expands the scope of shared types for this undo manager.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
scope
|
BaseType
|
The shared type to include. |
required |
include_origin(origin)
Extends the list of transactions origin tracked by this undo manager.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
origin
|
Any
|
The origin to include. |
required |
redo()
Perform a redo operation.
Returns:
Type | Description |
---|---|
bool
|
True if some changes were redone. |
undo()
Perform an undo operation.
Returns:
Type | Description |
---|---|
bool
|
True if some changes were undone. |
XmlElement
Bases: _XmlFragmentTraitMixin
, _XmlTraitMixin
attributes
property
A dict-like view into this object's attributes.
children
property
A list-like view into this object's child nodes.
doc
property
The document this shared type belongs to.
Raises:
Type | Description |
---|---|
RuntimeError
|
Not integrated in a document yet. |
parent
property
The parent of this node, if any.
tag
property
The element's tag, if any.
__init__(tag=None, attributes=None, contents=None, *, _doc=None, _integrated=None)
Creates an XML element.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
tag
|
str | None
|
The tag of the element (required). |
None
|
attributes
|
dict[str, str] | Iterable[tuple[str, str]] | None
|
The optional attributes of the element. |
None
|
contents
|
Iterable[XmlFragment | XmlElement | XmlText] | None
|
The optional contents of the element. |
None
|
observe_deep(callback)
Subscribes a callback for all events emitted by this and nested collaborative types.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[list[BaseEvent]], None]
|
The callback to call with the list of events. |
required |
unobserve(subscription)
Unsubscribes to changes using the given subscription.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
subscription
|
Subscription
|
The subscription to unregister. |
required |
XmlFragment
Bases: _XmlFragmentTraitMixin
children
property
A list-like view into this object's child nodes.
doc
property
The document this shared type belongs to.
Raises:
Type | Description |
---|---|
RuntimeError
|
Not integrated in a document yet. |
parent
property
The parent of this node, if any.
observe_deep(callback)
Subscribes a callback for all events emitted by this and nested collaborative types.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[list[BaseEvent]], None]
|
The callback to call with the list of events. |
required |
unobserve(subscription)
Unsubscribes to changes using the given subscription.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
subscription
|
Subscription
|
The subscription to unregister. |
required |
XmlText
Bases: _XmlTraitMixin
A piece of text in an XML tree.
This is similar to a Text, but instead of existing in a Doc on its own, it is a child of XmlElement or XmlFragment.
attributes
property
A dict-like view into this object's attributes.
doc
property
The document this shared type belongs to.
Raises:
Type | Description |
---|---|
RuntimeError
|
Not integrated in a document yet. |
parent
property
The parent of this node, if any.
clear()
Removes the entire range of characters.
diff()
Returns:
Type | Description |
---|---|
list[tuple[Any, dict[str, Any] | None]]
|
A list of formatted chunks that the current text corresponds to. Each list item is a tuple containing the chunk's contents and formatting attributes. The contents is usually the text as a string, but may be other data for embedded objects. |
format(start, stop, attrs)
Formats existing text with attributes.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
start
|
int
|
The index at which to start applying the attributes (included). |
required |
stop
|
int
|
The index at which to stop applying the attributes (excluded). |
required |
attrs
|
dict[str, Any]
|
The attributes to apply. |
required |
insert(index, value, attrs=None)
Inserts text at a given index, with optional attributes.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
index
|
int
|
The index at which to insert the text. |
required |
value
|
str
|
The text to insert. |
required |
attrs
|
Mapping[str, Any] | None
|
The optional attributes. |
None
|
insert_embed(index, value, attrs=None)
Insert an embed at a given index in the text, with optional attributes.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
index
|
int
|
The index at which to insert the embed. |
required |
value
|
Any
|
The embed to insert. |
required |
attrs
|
dict[str, Any] | None
|
The optional attributes. |
None
|
observe_deep(callback)
Subscribes a callback for all events emitted by this and nested collaborative types.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
callback
|
Callable[[list[BaseEvent]], None]
|
The callback to call with the list of events. |
required |
unobserve(subscription)
Unsubscribes to changes using the given subscription.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
subscription
|
Subscription
|
The subscription to unregister. |
required |
YMessageType
Bases: IntEnum
A generic Y message type.
Attributes:
Name | Type | Description |
---|---|---|
SYNC |
A message type used for synchronizing documents. |
|
AWARENESS |
A message type used for the awareness protocol. |
YSyncMessageType
Bases: IntEnum
A message type used for synchronizing documents.
Attributes:
Name | Type | Description |
---|---|---|
SYNC_STEP1 |
A synchronization message type used to send a document state. |
|
SYNC_STEP2 |
A synchronization message type used to reply to a SYNC_STEP1, consisting of all missing updates and all deletions. |
|
SYNC_UPDATE |
A synchronization message type used to send document updates. |
create_awareness_message(data)
create_sync_message(ydoc)
Creates a SYNC_STEP1 message that contains the state of a Doc.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
ydoc
|
Doc
|
The Doc for which to create the message. |
required |
Returns:
Type | Description |
---|---|
bytes
|
A SYNC_STEP1 message. |
create_update_message(data)
Creates a SYNC_UPDATE message that contains a document update.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
data
|
bytes
|
The document update. |
required |
Returns:
Type | Description |
---|---|
bytes
|
A SYNC_UPDATE message. |
handle_sync_message(message, ydoc)
Processes a synchronization message on a document.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
message
|
bytes
|
A synchronization message. |
required |
ydoc
|
Doc
|
The Doc that this message targets. |
required |
Returns:
Type | Description |
---|---|
bytes | None
|
The SYNC_STEP2 reply message, if the message |
bytes | None
|
was a SYNC_STEP1. |
get_state(update)
Returns a state from an update.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
update
|
bytes
|
The update from which to get the state. |
required |
Returns:
Type | Description |
---|---|
bytes
|
The state corresponding to the update. |
get_update(update, state)
Returns an update consisting of all changes from a given update which have not been seen in the given state.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
update
|
bytes
|
The update from which to get all missing changes in the given state. |
required |
state
|
bytes
|
The state from which to get missing changes that are in the given update. |
required |
Returns:
Type | Description |
---|---|
bytes
|
The changes from the given update not present in the given state. |
merge_updates(*updates)
Returns an update consisting of a combination of all given updates.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
updates
|
bytes
|
The updates to merge. |
()
|
Returns:
Type | Description |
---|---|
bytes
|
The merged updates. |
read_message(stream)
Reads a message from a byte stream.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
stream
|
bytes
|
The byte stream from which to read the message. |
required |
Returns:
Type | Description |
---|---|
bytes
|
The message read from the byte stream. |
write_message(stream)
Writes a stream in a message.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
stream
|
bytes
|
The byte stream to write in a message. |
required |
Returns:
Type | Description |
---|---|
bytes
|
The message containing the stream. |
write_var_uint(num)
Encodes a payload length.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
num
|
int
|
The payload length to encode. |
required |
Returns:
Type | Description |
---|---|
bytes
|
The encoded payload length. |