--- name: init_cpp_app kind: pipeline lang: bash domain: pipelines version: "1.1.0" purity: impure signature: "init_cpp_app(name: string, [--project

] [--domain ] [--desc ] [--tags ]) -> void" description: "Scaffolder estandar de apps C++ del registry. Genera main.cpp + CMakeLists.txt + app.md siguiendo el patron canonico (cfg.about/log/panels, sin app_menubar manual, dockspace via framework), registra la app en cpp/CMakeLists.txt, inicializa repo Gitea dataforge/ y ejecuta fn index." tags: [cpp, imgui, scaffold, pipeline, bash, launcher, cpp-tables] uses_functions: - ensure_repo_synced_bash_infra uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [] params: - name: name desc: "nombre de la app (snake_case). Sera el id en registry.db y el repo dataforge/" - name: "--project" desc: "proyecto bajo projects/ donde crear la app (opcional). Si se omite va a cpp/apps//" - name: "--domain" desc: "dominio del registry (default: tools)" - name: "--desc" desc: "descripcion breve (frontmatter description + cfg.about/cfg.title)" - name: "--tags" desc: "tags CSV adicionales para el frontmatter (siempre se anade 'imgui')" output: "estructura completa de la app + entry registrada en cpp/CMakeLists.txt + repo Gitea + fn index" tested: false tests: [] test_file_path: "" file_path: "bash/functions/pipelines/init_cpp_app.sh" --- ## Ejemplo ```bash # App suelta en cpp/apps// fn run init_cpp_app my_tool --desc "Herramienta para X" # App dentro de un proyecto fn run init_cpp_app finance_panel --project budget --desc "Panel de finanzas" --tags "finance,dashboard" ``` ## Que genera ```

/ main.cpp # Plantilla canonica: panels[] + cfg.about + cfg.log + run_app(cfg, render) + data_table comentado CMakeLists.txt # add_imgui_app( main.cpp) + target_link_libraries fn_table_viz (con guard) app.md # Frontmatter completo (lang:cpp, framework:imgui, dir_path, repo_url) + uses_functions comentados ``` Y ademas: - Registra `add_subdirectory(apps/)` (o el bloque `_DIR` para projects) en `cpp/CMakeLists.txt`. - Crea repo Gitea `dataforge/` con master + commit inicial via `ensure_repo_synced_bash_infra` (requiere `GITEA_URL` y `GITEA_TOKEN`). - Ejecuta `fn index` para registrar la app en `registry.db`. ## Plantilla `main.cpp` La plantilla cumple `cpp/PATTERNS.md`: - NO llama `app_menubar` manual (lo dibuja el framework). - NO llama `DockSpaceOverViewport` (auto_dockspace=true por defecto). - Declara `panels[]` con un panel "Main" toggleable. - Setea `cfg.about` (window About) y `cfg.log` (logger + ventana Logs). - Include `viz/data_table.h` comentado + panel "Data" comentado en `render()` — descomentar para activar `data_table::render()`. ## Activar data_table::render() 1. En `main.cpp`: descomentar `#include "viz/data_table.h"` y el bloque del panel Data en `render()`. 2. En `app.md`: descomentar los 12 IDs del stack `fn_table_viz` en `uses_functions`. 3. El `CMakeLists.txt` ya linka `fn_table_viz` via guard `if(TARGET fn_table_viz)` — sin cambio manual. 4. Poblar `data_tables` con tus `data_table::TableInput` y el panel aparece en el DockSpace. ## Cuando usarla Cuando necesites crear una app C++ nueva que siga el patron canonico del registry. Es el unico camino autorizado para crear apps en `cpp/apps/` o `projects/*/apps/` — nunca escribir `main.cpp` + `CMakeLists.txt` a mano. ## Gotchas - Si `GITEA_URL`/`GITEA_TOKEN` no estan seteados, solo hace `git init` local (no crea repo remoto). - `fn_table_viz` requiere que `vendor/lua` este presente en `cpp/`; el guard `if(TARGET fn_table_viz)` evita errores de link si no esta disponible. - El bloque de `uses_functions` en `app.md` queda comentado intencionalmente — descomenta solo las funciones que la app realmente use para mantener el grafo de dependencias limpio. ## Despues de crear 1. Si usas `data_table::render()`: descomentar include + panel en `main.cpp`, descomentar IDs en `app.md`, ejecutar `fn index`. 2. Para otras funciones del registry: anadir paths absolutos en `CMakeLists.txt` y los IDs en `uses_functions` de `app.md`. 3. Build: `cd cpp && cmake --build build --target -j`. ## Capability growth log v1.1.0 (2026-05-15) — Auto-wires fn_table_viz; new apps get target_link_libraries + commented data_table template.