Files
brahman/crates/apps/nahual-shell/src/main.rs
T
sergio 550c98f275 refactor(monorepo): reorganización lógica + renames + SDDs + split CHANGELOG
Reorganización física de crates/:
- core/ (mezclaba 6 propósitos) se divide en protocol/, init/, runtime/, compat/
- shared/ (3 crates) se redistribuye en protocol/ e init/
- lapaloma (sub-módulo de ui_engine) se promueve a modules/pineal/

Renames de proyectos:
- shipote → shuma (runtime de sandboxes)
- nouser → akasha (explorador de Mónadas)
- yahweh → nahual (motor GPUI, antes ui_engine/)
- lapaloma → pineal (data-viz agnóstica)

Fraccionamiento UI → core agnóstico:
- vista-core (DeckState + snap, 175 LOC, 5 tests verdes)
- barra-core (Task + render_html + sanitize, 90 LOC, 5 tests verdes)
- vista-web y barra-web ahora son thin DOM bindings

Documentación nueva:
- 16 SDDs por subdirectorio (≤80 LOC c/u): protocol/init/runtime/compat
  + 10 módulos + apps/
- docs/STATUS.md con cifras reales por proyecto
- docs/ROADMAP.md con plan a finalización (6 hitos, ~6-8 semanas)
- CHANGELOG.md particionado en docs/changelog/<proyecto>.md (7 buckets)

Automatización:
- scripts/reorg.py — script idempotente que: git mv directorios, renombra
  package names, recomputa path = refs, reescribe imports rust, actualiza
  workspace Cargo.toml. Soporta --dry-run.
- scripts/split-changelog.py — particiona CHANGELOG por componente.

Validación:
- cargo check --workspace pasa (124 crates + 2 nuevos cores).
- 10 tests adicionales (5 en vista-core + 5 en barra-core) verdes.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-19 14:48:34 +00:00

69 lines
2.3 KiB
Rust

//! Yahweh — bootstrap GPUI.
//!
//! Fase 6: además del LayoutModel, la Shell crea un `AppBus` (Entity) y se
//! lo pasa al LayoutHost. El bus circula a viewers (TextViewer,
//! ImageViewer) que se subscriben directo, y el LayoutHost forwardea los
//! eventos tipados de los explorers (FileExplorer, DatabaseExplorer)
//! traducidos a AppEvent.
mod brahman_client;
mod hot_reload;
mod layout_host;
mod layout_model;
mod managed_tree;
mod persister;
mod status_panel;
use gpui::{App, Application, Bounds, WindowBounds, WindowOptions, prelude::*, px, size};
use nahual_bus::AppBus;
use nahual_core::LayerConfig;
use nahual_theme::Theme;
use crate::layout_host::LayoutHost;
use crate::layout_model::LayoutModel;
use crate::persister::Persister;
const LAYOUT_PATH: &str = "layout.json";
fn main() {
// Sidecar brahman: nahual se presenta al Init antes de levantar GPUI.
// No bloquea: si el Init no está, el thread loggea y termina.
brahman_client::spawn();
Application::new().run(|cx: &mut App| {
Theme::install_default(cx);
let config = LayerConfig::load_or_default(LAYOUT_PATH);
let bounds = Bounds::centered(None, size(px(1300.), px(800.)), cx);
cx.open_window(
WindowOptions {
window_bounds: Some(WindowBounds::Windowed(bounds)),
..Default::default()
},
|_w, cx| {
let model = cx.new(|_| LayoutModel::new(config.clone()));
let bus = cx.new(|_| AppBus);
let persister = cx.new(|cx| {
Persister::new(LAYOUT_PATH.into(), model.clone(), cx)
});
// Hot-reload: notify watcher en el dir del JSON. El
// watcher debe mantenerse vivo (drop ⇒ stop), así que lo
// movemos a una static atómica vía Box::leak.
match hot_reload::spawn_watch(LAYOUT_PATH.into(), model.clone(), cx) {
Ok(watcher) => {
Box::leak(Box::new(watcher));
}
Err(e) => {
eprintln!("[hot_reload] no se pudo iniciar watcher: {}", e);
}
}
cx.new(|cx| LayoutHost::new(model, bus, persister, cx))
},
)
.unwrap();
cx.activate(true);
});
}