Skip to main content

Mutable Object Declaration - 支持声明与实现分离的类定义库

Project description

mutobj

Python 3.11+ License: MIT

mutobj (Mutable Object Declaration) - 支持声明与实现分离的 Python 类定义库。

特性

  • 声明与实现分离 - 类似 C/C++ 头文件模式
  • Extension 机制 - 为类添加私有状态而不污染接口
  • IDE 友好 - 完整支持 mypy/pyright 和 IDE 跳转
  • 继承支持 - 完整的类继承和方法覆盖
  • 零依赖 - 纯 Python 实现,无外部依赖

安装

pip install mutobj

快速开始

声明文件 (user.py)

import mutobj

class User(mutobj.Declaration):
    name: str
    age: int

    def greet(self) -> str:
        """返回问候语"""
        ...

实现文件 (user_impl.py)

import mutobj
from .user import User

@mutobj.impl(User.greet)
def greet(self: User) -> str:
    return f"Hello, I'm {self.name}!"

使用

from user import User
import user_impl  # 导入以注册实现

user = User(name="Alice", age=25)
print(user.greet())  # "Hello, I'm Alice!"

Extension 机制

为类添加私有状态:

class UserExt(mutobj.Extension[User]):
    _login_count: int = 0

    def __extension_init__(self):
        self._login_count = 0

@mutobj.impl(User.greet)
def greet(self: User) -> str:
    ext = UserExt.of(self)
    ext._login_count += 1
    return f"Hello, {self.name}! (login #{ext._login_count})"

支持的功能

功能 状态
属性声明
方法声明与实现
Property
classmethod
staticmethod
继承
Extension
类型检查

文档

开发

# 安装开发依赖
pip install -e ".[dev]"

# 运行测试
pytest

# 类型检查
mypy src/mutobj

发布

Tag 触发自动发布(PyPI Trusted Publishers,无需 token):

git tag v0.2.x
git push origin v0.2.x

源码版本保持 x.y.999,CI 从 tag 提取正式版本号替换后构建发布。

License

MIT License - 详见 LICENSE

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

mutobj-0.5.0.tar.gz (32.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mutobj-0.5.0-py3-none-any.whl (14.1 kB view details)

Uploaded Python 3

File details

Details for the file mutobj-0.5.0.tar.gz.

File metadata

  • Download URL: mutobj-0.5.0.tar.gz
  • Upload date:
  • Size: 32.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mutobj-0.5.0.tar.gz
Algorithm Hash digest
SHA256 0a0fec43bca3e3937010907262f57ccf1271fcce63cfeda48edcbf18b80c6748
MD5 08f115bc620e2e1a92e609c471334eb9
BLAKE2b-256 4e5f739980ea97a13dab6dacb7b2186f4f2b9cd1df01fc8ac852505b59b045fd

See more details on using hashes here.

Provenance

The following attestation bundles were made for mutobj-0.5.0.tar.gz:

Publisher: release.yml on tiwb/mutobj

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mutobj-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: mutobj-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 14.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mutobj-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 634cfe5b86419d3f8ab3c382c045d6353a0145148ce6f48b47df1845b166e60f
MD5 0b4f115c0dac7d817d4a2eb3ef4a634d
BLAKE2b-256 9ad78c7441dc829eb34d8006b4e9c95d6165e2ae71f53b431f89fc4092c16b53

See more details on using hashes here.

Provenance

The following attestation bundles were made for mutobj-0.5.0-py3-none-any.whl:

Publisher: release.yml on tiwb/mutobj

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page