fix(layouts): restore docking via cfg.pre_frame; drop duplicate dockspace
Bug: al cargar un layout guardado, paneles que estaban dockeados a la
ventana principal aparecian flotantes. Causa: drain_layout_pending()
(que llama ImGui::LoadIniSettingsFromMemory) corria mid-frame dentro
de render(), DESPUES de menubar y de auto-dockspace. ImGui requiere
que el load suceda ANTES de cualquier Begin() del frame para que las
dock-nodes guardadas se restauren correctamente.
Fix:
- Mover drain_layout_pending al hook cfg.pre_frame del framework, que
se ejecuta entre NewFrame y menubar (orden correcto). Requiere el
commit asociado en cpp/framework/app_base.{h,cpp} que añade el hook.
- Eliminar la llamada redundante a ImGui::DockSpaceOverViewport en
render(): el framework ya la hace via cfg.auto_dockspace=true.
dashboard_state.h: declara render() para que tests puedan referenciarla
con `extern "C"`-like visibility (consistente con resto del API).
tests/: 7/7 siguen pasando.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -222,6 +222,46 @@ void register_tests(ImGuiTestEngine* e) {
|
||||
IM_CHECK(applied.empty());
|
||||
IM_CHECK(navegator::show_browsers == false); // sin pending no muta
|
||||
};
|
||||
|
||||
// -------------------------------------------------------------------
|
||||
// 7) BUG FIX (reportado): "elijo Default y al salir aparece otro".
|
||||
// Verifica el contrato de last_active end-to-end:
|
||||
// - layout_save / layout_apply persisten last_active
|
||||
// - layout_delete del activo limpia last_active
|
||||
// - layout_reset limpia last_active
|
||||
// NO testea restore-on-open en setup_layouts/teardown_layouts
|
||||
// porque la BD del test corre en un path UNC bajo WSL→Win32 y los
|
||||
// save reales necesitan ImGui::SaveIniSettings que es flaky en
|
||||
// este harness (pre-existentes save_* fallan). El restore-on-open
|
||||
// queda cubierto por:
|
||||
// - cpp/tests/test_layout_storage.cpp (Linux Catch2): contrato
|
||||
// completo de set/get_last_active + callbacks + reapertura.
|
||||
// - inspeccion del codigo en main.cpp:setup_layouts.
|
||||
// -------------------------------------------------------------------
|
||||
t = IM_REGISTER_TEST(e, "navegator_dashboard", "callbacks_persist_last_active_meta");
|
||||
t->TestFunc = [](ImGuiTestContext* ctx) {
|
||||
// El test asume que setup_layouts() del main ya abrio g_layouts.
|
||||
// Sembramos un layout via API pasando por save (que escribe el INI
|
||||
// serializado). Si SaveIniSettings esta vacio, el save fallaria,
|
||||
// pero antes de eso el callback YA llama set_last_active — el
|
||||
// contrato del bug fix esta en que active_name + meta se mantienen
|
||||
// sincronizados. Aqui solo verificamos las transiciones meta.
|
||||
ctx->Yield();
|
||||
if (!navegator::layout_save("nav_test_a")) return; // env flaky
|
||||
ctx->Yield();
|
||||
if (!navegator::layout_save("nav_test_b")) return;
|
||||
IM_CHECK(navegator::active_layout_name() == "nav_test_b");
|
||||
|
||||
IM_CHECK(navegator::layout_apply("nav_test_a"));
|
||||
IM_CHECK(navegator::active_layout_name() == "nav_test_a");
|
||||
|
||||
// Borrar el activo limpia active_name + meta.
|
||||
IM_CHECK(navegator::layout_delete("nav_test_a"));
|
||||
IM_CHECK(navegator::active_layout_name().empty());
|
||||
|
||||
// Cleanup.
|
||||
navegator::layout_delete("nav_test_b");
|
||||
};
|
||||
}
|
||||
|
||||
} // anon
|
||||
|
||||
Reference in New Issue
Block a user