Go to file
2024-05-10 19:50:37 -04:00
.vscode Bug fixes to allocators and containers 2024-05-06 23:29:47 -04:00
assets Font drawing is nice now 2024-02-13 17:16:39 -05:00
code small refactors for organization 2024-05-10 19:50:37 -04:00
docs AppUI lifted to its own file, Got horizontal and vertical boxes working 2024-05-10 19:20:50 -04:00
examples Got "Line LODs" working for the whitespace AST test, first step toward hboxes 2024-03-15 00:02:28 -04:00
scripts AppUI lifted to its own file, Got horizontal and vertical boxes working 2024-05-10 19:20:50 -04:00
thirdparty Move odin compiler and ols to their own directory separate from thirdparty packages: toolchain 2024-03-19 18:52:33 -04:00
toolchain AppUI lifted to its own file, Got horizontal and vertical boxes working 2024-05-10 19:20:50 -04:00
.ark_ignore latest (doing some ark vcs stuff) 2024-03-17 15:30:30 -04:00
.editorconfig Update editor config for odin support 2024-01-30 01:28:39 -05:00
.gitignore update build script to remove pdbs before building (msvc issues) 2024-03-20 20:50:46 -04:00
Debug.rdbg Memory setup for hot-reload & save states 2024-01-22 00:22:06 -05:00
launch.odin_old Minor cleanup for formatting, reverse verify condition usage 2024-02-23 09:36:23 -05:00
ols.json coordinate space math fixes, got resize handles working in settings menu prototype 2024-05-09 04:02:33 -04:00
Readme.md Fixed issue with ui_signal_from_box 2024-05-10 04:16:04 -04:00

Sectr Prototype

This prototype aims to flesh out ideas I've wanted to explore futher when it came to code editing and tools for code in general.

The things to explore:

  • 2D canvas for laying out code visualized in various types of ASTs
  • WYSIWYG frontend ASTs
  • Making AST editing as versatile as text editing.
  • High-performance generating a large amount of UI widget boxes with proper auto-layout & no perceptible rendering-lag or input lag for interactions (frametimes stable).
  • Model-View-Controller interface between code managed by a 'backend' (both in memory and filesystem) and the UX composition (which has separate filesystem composition).

The project is so far in a "codebase boostrapping" phase.

The project's is organized into 2 modules sectr_host & sectr. The host module loads the main module & its memory. Hot-reloading it's dll when it detects a change.

The dependencies are:

  • Odin Compiler
  • Odin repo's base, core, and vendor(raylib) libaries
  • An ini parser

The client(sectr) module's organization is relatively flat due to the nature of odin's module suste, not allowing for cyclic dependencies across modules, and modules can only be in one directory. This makes it difficult to unflatten, not something organic todo in a prototype...

Even so the notatble groups are:

  • API : Provides the overarching interface of the app's general behavior. Host uses this to provide the client its necessary data and exection env.
    • Has the following definitions: startup, shutdown, reload, tick, clean_frame
  • Grime : Name speaks for itself, stuff not directly related to the target features to iterate upon for the prototype.
    • Defining dependency aliases or procedure overload tables, rolling own allocator, data structures, etc.
  • Font Provider : Manages fonts.
    • When loading fonts, the provider currently uses raylib to generate bitmap glyth sheets for a range of font sizes at once.
    • Goal is to eventually render using SDF shaders.
  • Input : Standard input pooling and related features. Platform abstracted via raylib for now.
  • Parser : AST generation, editing, and serialization. A 1/3 of this prototype will most likely be this alone.
  • UI : AST visualzation & editing, backend visualization, project organizationa via workspaces (2d cavnases)
    • Will most likely be the bulk of this prototype.
    • PIMGUI (Persistent Immediate Mode User Interface)
    • Auto-layout with heavy procedural generation of box widgets

There is some unused code in code/__imgui_raddbg. Its a partial translation of some data structures from raddbg's ui.

img img img