Skip to main content

10x Platform Core

Project description

py10x-core

Unified, identity-driven, dependency-aware object model for Python
—with lazy dependency graph, persistence, automatic UI editors, and more

Python 3.11+ License: MIT

Jerboa Logo

🚀 Why py10x?

Standard Python objects have no shared identity layer and no automatic dependency tracking.
py10x-core turns them into a coherent, dependency-aware graph of connected identifiable objects — a single shared layer that feels unified across modules, files and processes.

Key superpowers:

  • Global Identity & Sharing
    Objects with identical ID Traits are automatically the same logical entity.
    Change a value in one place → every reference sees the update instantly (global cache).

  • Lazy Dependency Graph
    Computed traits (derived values) are calculated only when accessed.
    Dependencies are tracked automatically — no manual invalidation, no recompute storms.

  • Deep Persistence
    Complex nested object graphs saved to Traitable Store (MongoDB or in-memory).
    Built-in versioning, history tracking, transparent lazy loading.

  • Automatic UI Editors
    Define your data model once → get native two-way editors for Rio (web) or Qt (desktop).
    No manual UI code for viewing/editing traitables.

This approach dramatically reduces boilerplate while giving you fine-grained control over computation timing and persistence behavior.


🏁 Hello World

By default, the Traitable constructor accepts only ID traits. For how the framework uses identity and storage to resolve or create instances, see How Traitables Are Created in the Getting Started guide.

from core_10x.traitable import Traitable, T, RT
from core_10x.exec_control import GRAPH_ON, CACHE_ONLY

class Developer(Traitable):
    handle: str      = T(T.ID)           # ← identity trait → global sharing
    coffee_cups: int = T(default=0)      # persistent
    energy: int      = RT()              # runtime-only (not stored)

    def energy_get(self) -> int:
        return self.coffee_cups * 20

# In-memory mode (no storage), dependency graph on.
with CACHE_ONLY(), GRAPH_ON():
    dev = Developer(handle="ghost")
    dev.coffee_cups = 5
    print(dev.energy)           # 100 ← computed lazily on first access

    dev.coffee_cups = 6
    print(dev.energy)           # 120  ← recomputed due to dependency change

    # Same identity → same object
    dev2 = Developer(handle="ghost")
    print(dev2.energy)          # 120  ← shared via global cache

Want automatic persistence, per-class stores, store unions, querying, nested objects, UI generation, verifiers, and more? → Dive into GETTING_STARTED.md for the full technical manual.


🧠 When Should You Use py10x?

py10x-core is a good fit when:

  • Your application has rich domain models with derived fields
  • You need deterministic object identity
  • You want automatic dependency tracking
  • You want persistence and UI derived from the same model

It may be overkill for simple scripts, stateless APIs, or lightweight validation-only use cases.

If your system has evolving state and relationships, py10x-core removes a large amount of manual synchronization code.


🔍 How Is This Different?

Unlike dataclasses or Pydantic:

  • Objects have deterministic identity based on ID traits
  • Identical identity traits resolve to the same logical entity
  • Derived fields are lazily computed and dependency-tracked

Unlike traditional ORMs:

  • Identity is not tied to a database row
  • Persistence is optional and pluggable

Unlike reactive frameworks:

  • Dependencies are tracked automatically
  • Computation is lazy by default

🤝 Contact & Support

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

py10x_core-0.2.3rc5.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

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

py10x_core-0.2.3rc5-py3-none-any.whl (455.3 kB view details)

Uploaded Python 3

File details

Details for the file py10x_core-0.2.3rc5.tar.gz.

File metadata

  • Download URL: py10x_core-0.2.3rc5.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.21 {"installer":{"name":"uv","version":"0.11.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for py10x_core-0.2.3rc5.tar.gz
Algorithm Hash digest
SHA256 b8a0f7184eb293fd0d42e52e6c0645bdb0656236daff061e6b88fe36e6ead531
MD5 b8f1f28c1b13fd13e716eccc4b2cba60
BLAKE2b-256 8db0bfc3834d78268c520c65eb42733d42a380c4545e431d7665f2df1c1fa488

See more details on using hashes here.

File details

Details for the file py10x_core-0.2.3rc5-py3-none-any.whl.

File metadata

  • Download URL: py10x_core-0.2.3rc5-py3-none-any.whl
  • Upload date:
  • Size: 455.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.21 {"installer":{"name":"uv","version":"0.11.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for py10x_core-0.2.3rc5-py3-none-any.whl
Algorithm Hash digest
SHA256 43a72390e1071605cc96357aea6e9ecb9df9ef7c5c60911f08301aa4669f4185
MD5 f63cc3cc44f30afdf67764903dc4651d
BLAKE2b-256 8599bb702b6afbbcdd659b1a871f86df1437193226e2072ca70ed9753c24988e

See more details on using hashes here.

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