c48638fe87
Módulo nuevo `modules/tahuantinsuyu/` con 9 crates reusables + app `apps/tahuantinsuyu` ejecutable que abre la ventana del explorador y coordina los widgets: - tahuantinsuyu-card: Card Brahman + spawn_sidecar (flows chart-request/chart-result). - tahuantinsuyu-model: tipos agnósticos (Group/Contact/Chart, StoredBirthData, StoredChartConfig, ChartKind, TreeSelection). - tahuantinsuyu-store: persistencia SQLite (rusqlite) con migración v1, CRUD por entidad y descenso recursivo `charts_under_group`. - tahuantinsuyu-engine: bridge agnóstico al canvas vía `RenderModel` (Layer/Glyph/Geometry). Feature `eternal-bridge` (off por default) reservada para enchufar eternal-astrology desde ~/eternal. - tahuantinsuyu-modules: registry de módulos pluggables (Module trait + Control schema) con `NatalModule` placeholder. - tahuantinsuyu-theme: AstroPalette (elementos / modos / planetas / aspectos) con variantes dark + light sobre yahweh-theme. - tahuantinsuyu-canvas: widget GPUI con CanvasState (Empty / Wheel / Thumbnails). Render placeholder hasta cablear la rueda real. - tahuantinsuyu-tree: explorador izquierdo sobre yahweh-widget-tree, prefijos g:/c:/h: para Group/Contact/Chart. - tahuantinsuyu-panel: control panel inferior que lee Controls de los módulos del registry y los pinta. - apps/tahuantinsuyu: binario `tahuantinsuyu` (launch_app-style) con Shell coordinador (tree↔canvas↔panel), DB en $XDG_DATA_HOME. Workspace Cargo.toml actualizado con los 10 miembros. `cargo check` verde, tests unitarios verdes (model/store/engine/modules/theme/card). Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
31 lines
1.1 KiB
TOML
31 lines
1.1 KiB
TOML
[package]
|
|
name = "tahuantinsuyu-engine"
|
|
version = { workspace = true }
|
|
edition = { workspace = true }
|
|
license = { workspace = true }
|
|
description = "Tahuantinsuyu — bridge entre el modelo agnóstico y eternal-astrology. Produce RenderModel agnóstico para el canvas."
|
|
|
|
[dependencies]
|
|
tahuantinsuyu-model = { path = "../tahuantinsuyu-model" }
|
|
serde = { workspace = true }
|
|
thiserror = { workspace = true }
|
|
|
|
# eternal-astrology vive en otro workspace (~/eternal). Lo enlazamos por
|
|
# path para que el bridge use la misma lógica validada que el harness de
|
|
# Sergio. Si el path no existe (CI sin eternal checked out), el feature
|
|
# `eternal-bridge` se apaga.
|
|
[dependencies.eternal-astrology]
|
|
path = "../../../../../eternal/eternal-astrology"
|
|
optional = true
|
|
|
|
[dependencies.eternal-sky]
|
|
path = "../../../../../eternal/eternal-sky"
|
|
optional = true
|
|
|
|
[features]
|
|
default = []
|
|
# Activa el bridge real contra eternal-astrology. Sin este feature, la
|
|
# engine sólo expone el RenderModel y mocks — útil para tests y para
|
|
# compilar la UI antes de que eternal esté disponible.
|
|
eternal-bridge = ["dep:eternal-astrology", "dep:eternal-sky"]
|