diff --git a/README.md b/README.md index a40eae04..e126975c 100644 --- a/README.md +++ b/README.md @@ -2,20 +2,18 @@ This is the branch for the v5 version of BetterEdit, which is only for [Geode](https://geode-sdk.org) - if you're looking for the old standalone version, see the [v4](https://github.com/HJfod/BetterEdit/tree/v4) and [v4-min](https://github.com/HJfod/BetterEdit/tree/v4-min) branches. -### Please note that BE 5 is still in very early stages of development, and many features are yet to be added. +### :warning: Please note that BE 5 is still in very early stages of development, and many features are yet to be added. BetterEdit 5 is currently available as an alpha version on both **Windows and Mac**. Android support is planned in the future. -If you'd like to try the next generation of BetterEdit out for yourself, you can get the latest binary from [releases](https://github.com/HJfod/BetterEdit/releases/latest) (download `BetterEdit.geode`). +If you'd like to try the next generation of BetterEdit out for yourself, you can get the latest binary from [releases](https://github.com/HJfod/BetterEdit/releases) (download `be_team.betteredit.geode`). If you would like to report any issues or suggest features, feel free to use the [issues](https://github.com/HJfod/BetterEdit/issues) tab. ## Contributing -The source code of BetterEdit is available here mostly as an educational resource for other modders as well as for users to check the code. - -However, if you would like to contribute, [pull requests](https://github.com/HJfod/BetterEdit/pulls) are accepted. +See the [Contribution Guidelines](/docs/Contributing.md). ## Alpha Testing -If you'd like to test out BE 5, you can find the latest binaries in [releases](https://github.com/HJfod/BetterEdit/releases/tag/v5.0.0-alpha). Please post any bugs you find / features you'd like to suggest [as an issue](https://github.com/HJfod/BetterEdit/issues/new). If you'd like, there's also a [dedicated Discord server](https://discord.gg/UGHDfzQtpz) for the mod. +If you'd like to test out BE 5, you can find the latest binaries in [releases](https://github.com/HJfod/BetterEdit/releases). Please post any bugs you find / features you'd like to suggest [as an issue](https://github.com/HJfod/BetterEdit/issues/new). If you'd like, there's also a [dedicated Discord server](https://discord.gg/UGHDfzQtpz) for the mod. diff --git a/docs/Contributing.md b/docs/Contributing.md new file mode 100644 index 00000000..c8e5a1a8 --- /dev/null +++ b/docs/Contributing.md @@ -0,0 +1,179 @@ + +# Contributing to BetterEdit + +Thank you for your interest in contributing to this mod! Here are some guidelines you should follow when working with BE. + +## Development team + +BetterEdit is lead & managed by HJfod as the original developer of the mod. Alongside him there are other developers, who all have equal rights to contribute code, review pull requests, release updates, etc.. Development is mostly handled on [the BE 5 Discord server](https://discord.gg/UGHDfzQtpz). + +If you'd like to join the dev team, the easiest way is to just express your interest in doing so [on the Discord](https://discord.gg/UGHDfzQtpz), or just open up a Pull Request. Joining the Discord is not at all mandatory to contribute code, but it is where all the devs can discuss together and get immediate feedback from users. + +## Basic info about the codebase + +BetterEdit 5 is developed using [Geode](https://geode-sdk.org), making it a required installation for all contributors. Aside from the basic Geode toolkit, BE currently doesn't require any additional special tools, though this may change in the future. + +BetterEdit is split into two mods: BetterEdit and EditorAPI. The former is the mod you all know; it adds all the QoL features like Start Pos tools and better color selection menu. The latter is a general API mod that introduces a bunch of endpoints for adding stuff to the editor, such as new build tabs. This is where any features that other mods could depend on should go; BetterEdit should just be about using EditorAPI & other APIs to contribute its features. + +An overview of the BE codebase's structure: + + - `api` is the folder for EditorAPI + - `docs` is a bunch of documentation for developers, such as contribution guidelines + - `resources` is where all resources such as sprites live + - `src` is for all the source files related to BetterEdit + - `src/features` is for all of BE's features + - `src/other` is for other source files, such as utilities and such + +The main unit of the BetterEdit codebase is a **feature**. This is stuff like Smart Start Pos, better color selection menu, View Tab, etc.. Each feature should be a **self-contained file or folder** inside the `src/features` directory. If the feature is small, such as additional keybinds, then it should just be one source file. If it needs multiple source files for legibility, it should be one folder - however, **all the code related to that feature should be contained within that folder**. + +Features **should not normally depend on other features**. If it seems like a feature depends on another, consider the following: + + - Does the feature only depend on a small part of the other feature? Could that part be extracted into a shared API in either EditorAPI or `src/other`? + - Is the feature really just an extension of the other feature? Should its code just be added to the original feature? + +However, some features may be logically distinct and not extractable into a shared API, in which case depending on another feature is fine. The feature being depended on should be moved to a folder (if not already) and expose headers for the parts to depend on. + +## Branches + +The development of BetterEdit is handled using branches, and every developer should use their own branches. In fact, **pushing directly to the `main` branch is disallowed**, and may only be done so through PRs that have succesfully passed [the build action](https://github.com/HJfod/BetterEdit/actions/workflows/build.yml). This is to ensure that the `main` branch always consists of code that has been tested and that succesfully builds - `main` should not be a development branch. + +**Branches should mainly be made per-feature or per-contribution**, and only contain changes relevant for that one contribution. For example, this document was developed on an `updated-docs` branch, which only added new Markdown files under `docs`. + +## What features should I add? + +This is generally up to you! You can look for [features from `v4`](https://github.com/HJfod/BetterEdit/tree/v4) that haven't been ported yet, or [scroll the `#ideas` chat](https://discord.com/channels/1087452688956006471/1087452843725815938) on the Discord server to find any features that peek your interest. + +However, there are some restrictions on what features you can add: + + - All features must be strictly editor-related. This is not a general GD improvement mod + - Not all features from v4 were good ideas, and 1:1 parity is *not* a goal + +Alongside these restrictions on what features you can add, there are also some guidelines on *how* you should implement them: + + - v4's implementations were generally bad - don't just blindly port them as-is, but think of how the features could be better presented, further expanded, more generalized, etc. + - Prioritize ease-of-use and UX clarity - BetterEdit is meant to deobfuscate the editor + - Avoid excessive hooking, especially with destructors, which may be unstable + - Avoid byte patching and other platform-specific code at all costs + - Add as much customization as possible, but always provide sane defaults + - Don't reinvent the wheel + +And as a final addition, here's an overview of **the philosophy of BetterEdit**: + + - BetterEdit is primarily a mod about **refinement** - *not* a major redesign of the entire editor + - However, don't be afraid to disregard established muscle memory if the alternative is a significant improvement (such as the new edit tab with grouped arrows) + - BetterEdit's target audience is primarily **intermediate to experienced creators** - while features that make the editor easier to learn for newcomers are welcome, they are not our main goal + - BetterEdit aims to **follow GD's established UX and UI primitives** rather than break them + - BetterEdit should still take pride in having good UX within GD's contraints + - BetterEdit should not be constrained to any one area of the editor - anything that relates to building levels is within its limits + - BetterEdit should make the editor better (as per its name) + +## Adding a feature + +Once you have a feature in mind that you believe fits all these standards, you can get by to implementing it! Here's the **basic implementation guide**: + + - Create a new branch with the name of your feature (for example `auto-color-triggers`) + - Add a new source file for it under `src/features`, or a directory if it contains many files (for example `src/features/AutoColorTriggers.cpp` or `src/features/AutoColorTriggers/logic.cpp`) + - Develope & test your feature + - Add a new setting for the feature in [`mod.json`](https://github.com/HJfod/BetterEdit/blob/main/mod.json#L9) and make sure the feature is toggled by it + - [Open a Pull Request](https://github.com/HJfod/BetterEdit/pulls) once you are confident your feature is **ready for production** + +Once you have opened your PR, other team members can test your branch and make sure it works as expected. Afterwards, if the build passes on all platforms, HJfod will merge it, or you may merge it yourself if you have the access to do so. + +## Code style guidelines + +In general, [follow Geode's code style guidelines](https://docs.geode-sdk.org/source/styling/). In addition, BetterEdit has some specific extra notes: + +### Always use braces for `if`, `for`, and `while` statements, even if the body is just one piece of code +```cpp +// Correct +if (...) { + stmt +} + +// Wrong +if (...) + stmt +``` +The only exception is if the body is a return statement: +```cpp +// Correct +if (...) + return ...; + +// This is correct too though; the above case is usually only for the initial check for Super::init failing +if (...) { + return ...; +} +``` + +### Field names should not use the `m_` prefix, since it is already included in `m_fields`: +```cpp +// Correct +int thing; +... +m_fields->thing; + +// Wrong +int m_thing; +... +m_fields->m_thing; +``` + +### Member accesses should never use `this->`, member function calls should always have `this->` +```cpp +// Correct +m_stuff; +m_fields->thing; +this->updateUI(); + +// Wrong +this->m_stuff; +this->m_fields->thing; +updateUI(); +``` + +### Switch cases longer than one statement should be wrapped in braces +```cpp +switch (thing) { + case x: { + ... + } break; +} +``` + +### Avoid too many line breaks, but separate logically distinct things +```cpp +// Correct +if (...) { + ... +} +callThing(); + +this->updateUI(); +this->updateSaws(); + +// Wrong +if (...) { + ... +} + +callThing(); +this->updateUI(); + +this->updateSaws(); +``` + +### Every file should have one empty line at the end +That's it + +### Long macro definitions should use multiple lines with the backticks aligned and follow same rules as other stuff +```cpp +// Correct +#define MACRO(x) \ + if (x) { \ + ... \ + } + +// Wrong +#define MACRO(x) if (x) {...} +```