4coder/code
PS be632574e6 Added yeet sheet implementation 2024-05-13 19:29:16 -07:00
..
bin adding execute permissions to build-mac-dev.sh 2024-03-22 18:16:17 -06:00
custom Added yeet sheet implementation 2024-05-13 19:29:16 -07:00
docs
generated Add 'code/' from commit '1459ef7cbce753b056ea148b29c9dc3f8a721261' 2022-11-18 13:37:07 +00:00
metal
opengl
platform_linux
platform_mac Fixing issue where keyUp events aren't sent for keys that become modified by the command key 2024-03-22 17:55:59 -06:00
platform_unix
platform_win32 Removed custom/audio 2024-02-10 14:25:13 -08:00
ship_files Added scope highlight colors 2024-05-13 17:24:33 -07:00
site Add 'code/' from commit '1459ef7cbce753b056ea148b29c9dc3f8a721261' 2022-11-18 13:37:07 +00:00
.gitignore Add 'code/' from commit '1459ef7cbce753b056ea148b29c9dc3f8a721261' 2022-11-18 13:37:07 +00:00
4ed.cpp
4ed.h
4ed_api_check.cpp
4ed_api_definition.cpp
4ed_api_definition.h
4ed_api_definition_main.cpp
4ed_api_implementation.cpp
4ed_api_parser.cpp
4ed_api_parser_main.cpp
4ed_app_models.cpp
4ed_app_models.h
4ed_app_target.cpp
4ed_buffer.cpp
4ed_buffer.h
4ed_buffer_model.h
4ed_cli.cpp
4ed_cli.h
4ed_coroutine.cpp
4ed_coroutine.h
4ed_cursor_codes.h
4ed_dynamic_variables.cpp
4ed_dynamic_variables.h
4ed_edit.cpp
4ed_edit.h
4ed_file.cpp Removed File_Edit_Positions.last_set_type since it was always set but never read 2024-05-13 17:42:38 -07:00
4ed_file.h Removed File_Edit_Positions.last_set_type since it was always set but never read 2024-05-13 17:42:38 -07:00
4ed_font_api.cpp
4ed_font_interface.h
4ed_font_provider_freetype.cpp
4ed_font_provider_freetype.h
4ed_font_set.cpp
4ed_font_set.h
4ed_generate_keycodes.cpp
4ed_graphics_api.cpp
4ed_history.cpp
4ed_history.h
4ed_hot_directory.cpp
4ed_hot_directory.h
4ed_layout.cpp
4ed_layout.h
4ed_log.cpp
4ed_log.h
4ed_mem.cpp
4ed_render_target.cpp
4ed_render_target.h
4ed_string_matching.cpp
4ed_system_api.cpp
4ed_text_layout.cpp
4ed_text_layout.h
4ed_translation.cpp
4ed_translation.h
4ed_view.cpp Removed File_Edit_Positions.last_set_type since it was always set but never read 2024-05-13 17:42:38 -07:00
4ed_view.h Removed File_Edit_Positions.last_set_type since it was always set but never read 2024-05-13 17:42:38 -07:00
4ed_working_set.cpp Project generation uses treat_as_code extensions to create project include patterns 2024-02-10 18:45:05 -08:00
4ed_working_set.h
README.md
project.4coder

README.md

Welcome to the 4coder code base.

This codebase was authored by Allen Webster from 2014-2022, with help from a number of contributors:

  • Casey Muratori
  • "insofaras" Alex Baines
  • Yuval Dolev
  • Ryan Fleury

Also thanks to all those who supported the project, financially and/or through all your detailed feedback.

As of May 31st 2022, I am freezing this codebase and open sourcing it.

I DO NOT recommend learning from this codebase, especially not with an uncritical eye. It may be a useful reference for certain algorithms and architectural ideas, and it certainly contains some cautionary tales. But if you are a beginner, I encourage you to aim for more than emulating the style and structure of this codebase.

I will not be taking pull requests, or any other form of contribution in this repository. Since I am no longer maintaining this codebase, it is my intention that users who rely on 4coder will have the option to fork the codebase, fix their issues, or carry what I started in new directions according to their own vision if they would like.

The license I chose for this codebase is the very permissive MIT license. For the sake of clarity in the community of 4coder users, I ask that new forks of this codebase be given unique names.

In this readme you will find:

  1. License (MIT)
  2. Build Instructions
  3. Notes on Major Issues

License

Copyright (c) 2022 Allen Webster

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Build Instructions

  1. Create an empty folder named "4ed" to contain the codebase.
  2. Clone the repository
  3. Rename the folder containing the repository to "code"
  4. At the same level as the "4ed" folder, clone the "4coder-non-source" repository
  5. A. On windows setup the visual studio command line magic sauce so that "cl" works B. On linux setup g++ C. On mac setup clang
  6. Navigate to the "4ed/code" folder.
  7. A. On windows run "bin\build.bat" B. On linux run "bin\build-linux.sh" C. On linux run "bin\build-mac.sh"

Notes on Major Issues

  1. The build system and organization of files is extremely complicated. There is a 4ed_build.cpp that defines how builds run, and the build scripts have to build and run this C++ file. The file is pretty chaotic since it cannot rely on the codebase's usual helpers. On top of that there is a totally separate build system for the custom layer which is also a big gigantic mess of its own. It involves several stages of compilation, and a number of metaprograms.

  2. The documentation system is over complicated & the documentation is incomplete. There is very little documentation for the internals or the complicated layers of helpers.

  3. The lexer generator is way too complicated, and the built-in support for language features is not fully developed. The background threaded parsing is not very carefully organized and is not very flexible, so it's hard to add new languages at any level of the system.

  4. There are a few layers of overcomplicated configuration parsers.

  5. Mac support has not been maintained for several versions.

  6. The codebase has a very weak base layer with key features that were added very late, so lots of code was written in the absence of useful features to bind things together. To make matters worse the base layer is split by the distinction of custom layer & core layer, leading to some double definitions and some incosistencies.