2024-03-08 03:34:21 -05: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.
2024-03-08 18:45:08 -05:00
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.
2024-05-04 11:52:52 -04:00
* 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).
2024-03-08 18:45:08 -05:00
2024-03-08 03:34:21 -05:00
The project is so far in a "codebase boostrapping" phase.
2024-03-08 18:45:08 -05:00
The project's is organized into 2 modules sectr_host & sectr.
2024-03-08 03:34:21 -05:00
The host module loads the main module & its memory. Hot-reloading it's dll when it detects a change.
2024-03-08 18:45:08 -05:00
The dependencies are:
2024-05-12 16:02:38 -04:00
* Odin Compiler (Slightly custom)
* Added #region , #endregion directives support for editors
2024-03-08 18:45:08 -05:00
* Odin repo's base, core, and vendor(raylib) libaries
* An ini parser
2024-05-13 21:53:08 -04:00
* backtrace
2024-03-08 18:45:08 -05:00
2024-05-11 22:38:05 -04:00
The client(sectr) module's organization is relatively flat due to the nature of odin's compiler, not allowing for cyclic dependencies across modules, and modules can only be in one directory.
2024-05-10 04:16:04 -04:00
This makes it difficult to unflatten, not something organic todo in a prototype...
2024-03-08 18:45:08 -05:00
2024-05-11 22:38:05 -04:00
Even so the notable groups are:
2024-03-08 18:45:08 -05:00
* 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
2024-05-13 21:53:08 -04:00
* Engine : Main loop, logging, client interface for host, etc
2024-05-11 22:38:05 -04:00
* Env : Core Memory & State definition + orchestration
2024-03-08 18:45:08 -05:00
* 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.
2024-05-13 21:53:08 -04:00
* 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.
2024-05-11 22:38:05 -04:00
* Input : All human input related features
* Base input features (polling & related) are platform abstracted from raylib
* Input Events
2024-03-08 18:45:08 -05:00
* Parser : AST generation, editing, and serialization. A 1/3 of this prototype will most likely be this alone.
2024-05-11 22:38:05 -04:00
* Project : Encpasulation of user config/state separate from persistent app config/state as a 'project'
* Manages the codebase (program model database)
* Manages workspaces : View compositions of the codebase
* UI : Core graphic user interface framework, AST visualzation & editing, backend visualization
2024-03-08 18:45:08 -05:00
* Will most likely be the bulk of this prototype.
2024-05-10 04:16:04 -04:00
* PIMGUI (Persistent Immediate Mode User Interface)
2024-05-11 22:38:05 -04:00
* Auto-layout
* Supports heavy procedural generation of box widgets
Due to the nature of the prototype there are 'sub-groups' such as the codebase being its own ordeal as well as the workspace.
They'll be elaborated in their own documentation
2024-05-04 11:52:52 -04:00
2024-05-04 12:59:08 -04:00
## Gallery
![img ](docs/assets/sectr_host_2024-03-09_04-30-27.png )
![img ](docs/assets/sectr_host_2024-05-04_12-29-39.png )
![img ](docs/assets/Code_2024-05-04_12-55-53.png )
2024-05-11 22:38:05 -04:00
![img ](docs/assets/sectr_host_2024-05-11_22-34-15.png )