550c98f275
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>
69 lines
2.3 KiB
Rust
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);
|
|
});
|
|
}
|