No project description provided
Project description
DinoBytes
DinoBytes is a dynamic serialization framework designed to simplify network communication by providing a robust set of tools for serializing and deserializing messages using the MessagePack format. With its easy-to-use decorator and base class, DinoBytes makes defining and handling network messages both efficient and intuitive, suitable for applications ranging from simple messaging systems to complex distributed architectures.
Features
- Automatic Message Type Registration: Utilizes a decorator to automatically register class types and assign unique identifiers, ensuring a smooth serialization and deserialization process.
- Simplified Serialization: Offers a straightforward method (
to_bytes) for converting class objects into serialized bytes. - Effortless Deserialization: Allows for easy conversion of bytes back into class objects using the
from_bytesmethod, facilitating quick and reliable class parsing. - Streamlined Message Definition: Leverages Python's dataclass decorator within the custom
dbytedecorator to reduce boilerplate and enhance readability when defining new class types. - Message Registry: Automatically maintains a registry of class types, simplifying the process of managing different kinds of network messages within your application.
Installation
Install DinoBytes using pip:
pip install dinobytes
Quick Start
Defining a Message
from dinobytes import dbyte
@dbyte
class MyMessage:
content: str
Serializing a Message
message = MyMessage(content="Hello, DinoBytes!")
serialized_message = message.to_bytes() # or bytes(message)
Deserializing a Message
received_message = MyMessage.from_bytes(serialized_message)
print(received_message.content) # Output: Hello, DinoBytes!
The unpackd convenience method can also be used to automatically unpack into the correct type:
from dinobytes import unpackd
received_message = unpackd(serialized_message)
print(received_message.content) # Output: Hello, DinoBytes!
More examples
from dataclasses import dataclass
from dinobytes import dbyte, unpackd
@dbyte
class Parent:
def __init__(self, children: list[Child] | None =None):
self.children = children or []
def __repr__(self):
return f"Parent(children={self.children})"
@dbyte
@dataclass
class Child:
name:str = '<default>'
parent = Parent()
child = Child(name="Jimothy")
parent.children.append(child)
serialized = bytes(parent)
print(serialized)
print(unpackd(serialized))
Output:
b'\x92\x00\x91\xc4\n\x92\x01\xa7Jimothy'
Parent(children=[Child(name='Jimothy')])
from dataclasses import dataclass
from dinobytes import dbyte, unpackd
@dbyte
@dataclass
class ClassA:
value: int
@dbyte
@dataclass
class ClassB:
value: str
@dbyte
@dataclass
class ClassC:
value:list[int]
classA = ClassA(1)
classB = ClassB('hello')
classC = ClassC([1,2,3])
for x in [
bytes(classB),
bytes(classC),
bytes(classA)
]:
match unpackd(x):
case ClassA(value):
print(f'ClassA: {value=}')
case ClassB(value):
print(f'ClassB: {value=}')
case ClassC(value):
print(f'ClassC: {value=}')
case _:
print('unknown class')
Output:
ClassB: value='hello'
ClassC: value=[1, 2, 3]
ClassA: value=1
Contributing
Contributions to DinoBytes are welcome! Whether it's bug reports, feature requests, or code contributions, please feel free to reach out or submit a pull request. For major changes, please open an issue first to discuss what you would like to change.
License
DinoBytes is released under the Apache 2.0 License. See the LICENSE file for more details.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dinobytes-0.4.0.tar.gz.
File metadata
- Download URL: dinobytes-0.4.0.tar.gz
- Upload date:
- Size: 7.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.11.3 Darwin/23.2.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ec5a6fac497ae5a0d49a8a9c3104f08f2362431ff1a10e6c17e61343a87d54f8
|
|
| MD5 |
12aee180b334e66276286f767d9f7f36
|
|
| BLAKE2b-256 |
7632941257e0705c5ad28fb1fce117a94fd805b4f4ad5025d8b7126d2734782c
|
File details
Details for the file dinobytes-0.4.0-py3-none-any.whl.
File metadata
- Download URL: dinobytes-0.4.0-py3-none-any.whl
- Upload date:
- Size: 7.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.11.3 Darwin/23.2.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5ebc524f4ed57eae1fd9c75016943a560c1e89c93d4c90a4eb5c94107d45f324
|
|
| MD5 |
35b080862544697ad531602976cd178b
|
|
| BLAKE2b-256 |
6341b4d36078783aba1c8d2cd6bbec6e9c37a5cece912d03ca066bd5ec618484
|