classno


Nameclassno JSON
Version 0.0.6 PyPI version JSON
download
home_pagehttps://github.com/kuderr/classno
SummaryNone
upload_time2025-01-07 12:58:17
maintainerNone
docs_urlNone
authorkuderr
requires_python<4.0,>=3.10
licenseX11-distribute-modifications-variant
keywords library
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Classno

[![pypi](https://img.shields.io/pypi/v/classno.svg)](https://pypi.org/project/classno/)
[![downloads](https://static.pepy.tech/badge/classno)](https://www.pepy.tech/projects/classno)
[![downloads](https://static.pepy.tech/badge/classno/month)](https://www.pepy.tech/projects/classno)
[![versions](https://img.shields.io/pypi/pyversions/classno.svg)](https://github.com/kuderr/classno)
[![license](https://img.shields.io/github/license/kuderr/classno.svg)](https://github.com/kuderr/classno/blob/master/LICENSE)

Classno is a lightweight and extensible Python library for data modeling, schema definition, and validation. It provides a clean and intuitive way to define data classes with various features like type validation, immutability, private fields, and automatic type casting.

## Key Features

- Type hints validation
- Immutable objects
- Private fields
- Automatic type casting
- Customizable comparison behavior
- Default values and factory functions
- Nested object support
- Slots optimization
- Rich comparison methods

## Installation

```bash
pip install classno
```

## Basic Usage

### Simple Data Class

```python
from classno import Classno, field

class User(Classno):
    name: str
    age: int = 0
    email: str = field(default="")

# Create an instance
user = User(name="John", age=30)
```

### Features Configuration

Features can be enabled by setting the `__features__` class attribute:

```python
from classno import Classno, Features

class Config(Classno):
    __features__ = Features.VALIDATION | Features.FROZEN

    host: str
    port: int = 8080
```

Available features:

- `Features.EQ` - Enable equality comparison
- `Features.ORDER` - Enable ordering operations
- `Features.HASH` - Make instances hashable
- `Features.SLOTS` - Use slots for memory optimization
- `Features.FROZEN` - Make instances immutable
- `Features.PRIVATE` - Enable private field access
- `Features.VALIDATION` - Enable type validation
- `Features.LOSSY_AUTOCAST` - Enable automatic type casting

### Field Configuration

Fields can be configured using the `field()` function:

```python
from classno import Classno, field
from datetime import datetime

class Post(Classno):
    title: str
    content: str = ""
    created_at: datetime = field(default_factory=datetime.now)
    metadata: dict = field(default_factory=dict, metadata={"indexed": True})
```

### Type Validation

```python
class ValidatedModel(Classno):
    __features__ = Features.VALIDATION

    numbers: list[int]
    mapping: dict[str, float]

# This will raise TypeError if types don't match
model = ValidatedModel(
    numbers=[1, 2, 3],
    mapping={"a": 1.0, "b": 2.0}
)
```

### Immutable Objects

```python
class ImmutableConfig(Classno):
    __features__ = Features.IMMUTABLE  # Combines FROZEN, SLOTS, and HASH

    host: str
    port: int = 8080

config = ImmutableConfig(host="localhost")
# Attempting to modify will raise an exception
config.port = 9000  # Raises Exception
```

### Private Fields

```python
class PrivateFields(Classno):
    __features__ = Features.PRIVATE

    name: str
    secret: str  # Can only be accessed with _secret prefix for rw, secret for ro

obj = PrivateFields(name="public")
obj._secret = "hidden"  # OK
obj.secret  # OK
obj.secret = "hidden"  # Raises Exception
```

### Nested Objects

```python
class Address(Classno):
    street: str
    city: str

class Person(Classno):
    name: str
    address: Address

# Create nested structure
person = Person(
    name="John",
    address=Address(street="123 Main St", city="Boston")
)
```

## Customization

### Custom Comparison Keys

```python
class CustomCompare(Classno):
    __hash_keys__ = {"id"}  # Keys used for hashing
    __eq_keys__ = {"id", "name"}  # Keys used for equality comparison
    __order_keys__ = {"name"}  # Keys used for ordering

    id: int
    name: str
    description: str
```

## Best Practices

1. Use type hints for all fields
2. Enable appropriate features based on your needs
3. Use `field()` for complex field configurations
4. Consider using `Features.SLOTS` for better memory usage
5. Enable validation when type safety is important

## Error Handling

The library raises appropriate exceptions for:

- Type validation errors
- Missing required fields
- Immutability violations
- Invalid field access
- Incorrect feature combinations

# Authors

- Dmitriy Kudryavtsev - author - [kuderr](https://github.com/kuderr)

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/kuderr/classno",
    "name": "classno",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.10",
    "maintainer_email": null,
    "keywords": "library",
    "author": "kuderr",
    "author_email": "dakudryavcev@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/ff/85/304d25a91462e64098c21f531f4487fb7ce76d10c3520bb359b121cef123/classno-0.0.6.tar.gz",
    "platform": null,
    "description": "# Classno\n\n[![pypi](https://img.shields.io/pypi/v/classno.svg)](https://pypi.org/project/classno/)\n[![downloads](https://static.pepy.tech/badge/classno)](https://www.pepy.tech/projects/classno)\n[![downloads](https://static.pepy.tech/badge/classno/month)](https://www.pepy.tech/projects/classno)\n[![versions](https://img.shields.io/pypi/pyversions/classno.svg)](https://github.com/kuderr/classno)\n[![license](https://img.shields.io/github/license/kuderr/classno.svg)](https://github.com/kuderr/classno/blob/master/LICENSE)\n\nClassno is a lightweight and extensible Python library for data modeling, schema definition, and validation. It provides a clean and intuitive way to define data classes with various features like type validation, immutability, private fields, and automatic type casting.\n\n## Key Features\n\n- Type hints validation\n- Immutable objects\n- Private fields\n- Automatic type casting\n- Customizable comparison behavior\n- Default values and factory functions\n- Nested object support\n- Slots optimization\n- Rich comparison methods\n\n## Installation\n\n```bash\npip install classno\n```\n\n## Basic Usage\n\n### Simple Data Class\n\n```python\nfrom classno import Classno, field\n\nclass User(Classno):\n    name: str\n    age: int = 0\n    email: str = field(default=\"\")\n\n# Create an instance\nuser = User(name=\"John\", age=30)\n```\n\n### Features Configuration\n\nFeatures can be enabled by setting the `__features__` class attribute:\n\n```python\nfrom classno import Classno, Features\n\nclass Config(Classno):\n    __features__ = Features.VALIDATION | Features.FROZEN\n\n    host: str\n    port: int = 8080\n```\n\nAvailable features:\n\n- `Features.EQ` - Enable equality comparison\n- `Features.ORDER` - Enable ordering operations\n- `Features.HASH` - Make instances hashable\n- `Features.SLOTS` - Use slots for memory optimization\n- `Features.FROZEN` - Make instances immutable\n- `Features.PRIVATE` - Enable private field access\n- `Features.VALIDATION` - Enable type validation\n- `Features.LOSSY_AUTOCAST` - Enable automatic type casting\n\n### Field Configuration\n\nFields can be configured using the `field()` function:\n\n```python\nfrom classno import Classno, field\nfrom datetime import datetime\n\nclass Post(Classno):\n    title: str\n    content: str = \"\"\n    created_at: datetime = field(default_factory=datetime.now)\n    metadata: dict = field(default_factory=dict, metadata={\"indexed\": True})\n```\n\n### Type Validation\n\n```python\nclass ValidatedModel(Classno):\n    __features__ = Features.VALIDATION\n\n    numbers: list[int]\n    mapping: dict[str, float]\n\n# This will raise TypeError if types don't match\nmodel = ValidatedModel(\n    numbers=[1, 2, 3],\n    mapping={\"a\": 1.0, \"b\": 2.0}\n)\n```\n\n### Immutable Objects\n\n```python\nclass ImmutableConfig(Classno):\n    __features__ = Features.IMMUTABLE  # Combines FROZEN, SLOTS, and HASH\n\n    host: str\n    port: int = 8080\n\nconfig = ImmutableConfig(host=\"localhost\")\n# Attempting to modify will raise an exception\nconfig.port = 9000  # Raises Exception\n```\n\n### Private Fields\n\n```python\nclass PrivateFields(Classno):\n    __features__ = Features.PRIVATE\n\n    name: str\n    secret: str  # Can only be accessed with _secret prefix for rw, secret for ro\n\nobj = PrivateFields(name=\"public\")\nobj._secret = \"hidden\"  # OK\nobj.secret  # OK\nobj.secret = \"hidden\"  # Raises Exception\n```\n\n### Nested Objects\n\n```python\nclass Address(Classno):\n    street: str\n    city: str\n\nclass Person(Classno):\n    name: str\n    address: Address\n\n# Create nested structure\nperson = Person(\n    name=\"John\",\n    address=Address(street=\"123 Main St\", city=\"Boston\")\n)\n```\n\n## Customization\n\n### Custom Comparison Keys\n\n```python\nclass CustomCompare(Classno):\n    __hash_keys__ = {\"id\"}  # Keys used for hashing\n    __eq_keys__ = {\"id\", \"name\"}  # Keys used for equality comparison\n    __order_keys__ = {\"name\"}  # Keys used for ordering\n\n    id: int\n    name: str\n    description: str\n```\n\n## Best Practices\n\n1. Use type hints for all fields\n2. Enable appropriate features based on your needs\n3. Use `field()` for complex field configurations\n4. Consider using `Features.SLOTS` for better memory usage\n5. Enable validation when type safety is important\n\n## Error Handling\n\nThe library raises appropriate exceptions for:\n\n- Type validation errors\n- Missing required fields\n- Immutability violations\n- Invalid field access\n- Incorrect feature combinations\n\n# Authors\n\n- Dmitriy Kudryavtsev - author - [kuderr](https://github.com/kuderr)\n",
    "bugtrack_url": null,
    "license": "X11-distribute-modifications-variant",
    "summary": null,
    "version": "0.0.6",
    "project_urls": {
        "Bug Tracker": "https://github.com/kuderr/classno/issues",
        "Homepage": "https://github.com/kuderr/classno",
        "Repository": "https://github.com/kuderr/classno"
    },
    "split_keywords": [
        "library"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "9f74fa2f636d587d4846275fef7adaf047bbf418bbe8351afed8e13c9bb81fc8",
                "md5": "824ca8887eebf777d75ee4bb244335dd",
                "sha256": "5c1cf937b0a413e3ce957084dda7faec7d48e3b37deec387de149941f372d077"
            },
            "downloads": -1,
            "filename": "classno-0.0.6-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "824ca8887eebf777d75ee4bb244335dd",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.10",
            "size": 11231,
            "upload_time": "2025-01-07T12:58:15",
            "upload_time_iso_8601": "2025-01-07T12:58:15.644949Z",
            "url": "https://files.pythonhosted.org/packages/9f/74/fa2f636d587d4846275fef7adaf047bbf418bbe8351afed8e13c9bb81fc8/classno-0.0.6-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ff85304d25a91462e64098c21f531f4487fb7ce76d10c3520bb359b121cef123",
                "md5": "a12acbe038a9afe9e5b7d643f32afdb8",
                "sha256": "caa2176d23e1503a9ce78a3d460901f2c3b8001fec86ab2f5ed4cf2eab7a454e"
            },
            "downloads": -1,
            "filename": "classno-0.0.6.tar.gz",
            "has_sig": false,
            "md5_digest": "a12acbe038a9afe9e5b7d643f32afdb8",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.10",
            "size": 9493,
            "upload_time": "2025-01-07T12:58:17",
            "upload_time_iso_8601": "2025-01-07T12:58:17.986409Z",
            "url": "https://files.pythonhosted.org/packages/ff/85/304d25a91462e64098c21f531f4487fb7ce76d10c3520bb359b121cef123/classno-0.0.6.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-07 12:58:17",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "kuderr",
    "github_project": "classno",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "classno"
}
        
Elapsed time: 0.42898s