From 6e9aae628d84e187da47b02a4492a1ea113bbcbc Mon Sep 17 00:00:00 2001 From: BongaTheProto <93835010+BongaTheProto@users.noreply.github.com> Date: Sat, 20 Jul 2024 04:20:15 -0500 Subject: [PATCH 1/7] Modularization guidelines --- README.md | 7 +- modular_zzplurt/readme.md | 165 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 167 insertions(+), 5 deletions(-) create mode 100644 modular_zzplurt/readme.md diff --git a/README.md b/README.md index d5a055a2cde68..d5527ffec1837 100644 --- a/README.md +++ b/README.md @@ -23,13 +23,11 @@ Space Station 13 is a paranoia-laden round-based roleplaying game set against th ## Contribution Rules and Guidelines **1. Do Not Be A Dick** -- The S.P.L.U.R.T. main repository is run by and contributed by volunteers. You are not entitled to our time and energy. We reserve the right to permanently remove anyone who does not show both our contributor's and maintainer's common decency. +- The S.P.L.U.R.T. main repository is run by and contributed by volunteers. Please be considerate with the people who help maintaining our station. We reserve the right to permanently remove anyone who does not show both our contributor's and maintainer's common decency. **2. Modularization Standards Will be Upheld** - This codebase is a active downstream to Bubberstation with frequent upstream merges. -- Modularization must be strictly upheld for code stability. (Ask a maintainer if you have any questions!) -- Basically, **try to edit Modular Splurt files first** Then ``//SPLURT EDIT`` comments on any core files (TG, Skyrat, or Bubberstation) for trackability. -- This is a place for when more concrete guidelines are created. +- Modularization is key to attain code stability, please read our [modularization guide](./modular_zzplurt/readme.md) for more information, or ask any of our maintainers in our discord. **3. The Licensing is Non-negotiable** - You are free to take, redistribute, modify, and readapt any code or commit found on this repository. @@ -42,7 +40,6 @@ Space Station 13 is a paranoia-laden round-based roleplaying game set against th - You are entitled to credit yourself with comments and you are entitled to waive the attribution requirement choosing not to be identified as the creator if you wish. - If you do not like how your assets were modified or used, it is required that the other person [remove the attribution information upon request](https://wiki.creativecommons.org/wiki/License_Versions#Licensors_may_request_removal_of_attribution). - Modifications or adaptions must disclose the source, the author, and [any changes you've made](https://wiki.creativecommons.org/wiki/License_Versions#Modifications_and_adaptations_must_be_indicated). -- Goonstation code is incompatible with this codebase and will not be accepted. *Credit: [Goonstation contribution guidelines](https://hackmd.io/@goonstation/docs/%2F%40goonstation%2Fcontribute#What-if-I-change-my-mind-about-my-contributions-being-published)* diff --git a/modular_zzplurt/readme.md b/modular_zzplurt/readme.md new file mode 100644 index 0000000000000..914ae35775ad8 --- /dev/null +++ b/modular_zzplurt/readme.md @@ -0,0 +1,165 @@ +# The Modularization Handbook - S.P.L.U.R.T. Style, v1.0 + +## Introduction + +Welcome to the S.P.L.U.R.T. station's modularization handbook! Our goal is to make contributing to our codebase as easy and comfy as possible for coders while upkeeping our code standards. We understand that maintaining a codebase that's a fork of another can be challenging, but with the right practices, we can keep our code clean, organized, and easy to manage. This handbook outlines our modularization protocols and coding standards to help you get started. + +If you'd like to know more about coding, contributing and contribution standards, feel free to read this repository's [contribution guides](./.github/guides)! + +## Important Note - Test Your Pull Requests + +You are responsible for testing your content. Please do not mark a pull request as ready for review until you have thoroughly tested it. If you need a separate client for testing, you can use a guest account by logging out of BYOND and connecting to your test server. Test merges are for stress tests, not for finding bugs that could have been caught with local testing. + +## The Nature of Conflicts + +Conflicts can arise when changes are made to the same lines of code in different branches. For example, if the original code is: + +```byond +var/something = 1 +``` + +And we change it to: + +```diff +- var/something = 1 ++ var/something = 2 //SPLURT EDIT +``` + +But upstream changes it to: + +```diff +- var/something = 1 ++ var/something = 4 +``` + +This results in a conflict that needs to be resolved manually. Our solution is modularization. + +## The Modularization Protocol + +Modularization is the practice of organizing code into separate, self-contained modules that can be developed, tested, and maintained independently. In the context of our codebase, this means placing as much as possible of the new code, icons, sounds, and other assets into the `modular_zzplurt` folder. This approach helps keep our core codebase clean and reduces the likelihood of conflicts when merging changes. By following a structure that resembles the main repository within the `modular_zzplurt` folder, we ensure that our modular code is easy to navigate and manage. This also allows us to make changes and add new features without directly modifying the core files, thereby maintaining the integrity and stability of the main codebase. + +Our modularization protocols are founded on three pillars: + +1. **Modularize anything that's reasonable to modularize:** This includes anything that can be modularized without decreasing its quality or the quality of existing code, and won't logically cause more issues by modularizing than not doing it. +2. **Use commenting conventions for non-modular edits:** When editing non-modular code, make sure to adequately use the commenting conventions to ensure it is known that it's a non-modular edit. +3. **It's ok to mess up:** These rules are intended less as a set of guidelines for contributors to strictly follow, but rather coding standards that we all collectively help to attain, for examble through maintainers helping any contributors fulfill them in their pull requests. + +### Modular Overrides + +Modular overrides allow us to extend or modify the behavior of existing code without directly editing the core files. This is done by creating new definitions or modifying existing ones in a way that they can be easily integrated into the core codebase. There are two main types of modular overrides: Variable Overrides and Proc Overrides. + +#### Variable Overrides + +Variable overrides allow you to modify existing variables in a modular fashion. This is useful when you need to introduce new properties to existing objects without altering the core code. For example: + +```byond +/obj/item/gun + var/muzzle_flash = TRUE + + ... + +/obj/item/gun + muzzle_flash = FALSE +``` + +In this example, a new variable muzzle_flash is added to the /obj/item/gun object with a value of `TRUE`. The value of this variable is later changed to `FALSE` through overriding. + +#### Proc Overrides + +Proc overrides allow you to extend or modify the behavior of existing procedures (procs) without directly editing the core files. This is done by defining a new proc that calls the original proc and then adds the new behavior. For example: + +```byond +/obj/item/gun/shoot_live_shot(mob/living/user, pointblank = 0, atom/pbtarget = null, message = 1) + . = ..() // Call the original proc and set its value to the default return value + if(muzzle_flash) + spawn_sparks(src) // Add new behavior +``` + +In this example, the shoot_live_shot proc is overridden to add a new behavior (spawning sparks) after calling the original proc. This ensures that the new behavior is added without modifying the core code. + +#### When to Use Modular Overrides + +Modular overrides should be used whenever possible to keep the core codebase clean and maintainable. However, it's important to use them judiciously and ensure that they do not introduce performance issues or make the code harder to understand and maintain. Specifically: + +- **Use modular overrides when they won't cause more issues than not modularizing them:** If a modular override would introduce significant complexity, performance issues, or maintenance challenges, it may be better to make a non-modular edit with proper commenting. +- **Avoid unnecessary overrides:** Do not override procs or variables unless it is necessary for your feature or fix. Unnecessary overrides can lead to maintenance headaches and potential conflicts with upstream changes. +- **Document your overrides:** Clearly documenting any modular overrides in your code and helps maintainers and other contributors understand the changes and their purpose. +By following these guidelines, we can ensure that our codebase remains clean, maintainable, and easy to navigate, while still allowing for the flexibility to add new features and make necessary changes. + +## Folder Structure + +Instead of using different modules for every different bit of the game, we prefer to use a structure that resembles the structure of the repo itself inside our modular folder. This means we have one coding folder for all the code, one icons folder, one sounds folder, etc. + +- **Code:** Any .dm files should go in `modular_zzplurt/code/`. +- **Icons:** Any .dmi files should go in `modular_zzplurt/icons/`. +- **Sounds:** Any sound files should go in `modular_zzplurt/sounds/`. + +## Commenting Conventions + +When making non-modular changes to the core code, please use the following commenting conventions or similar: + +- **Addition:** + +```byond + //SPLURT EDIT ADDITION BEGIN - FEATURE_NAME - (Optional Reason/comment) + var/adminEmergencyNoRecall = FALSE + var/lastMode = SHUTTLE_IDLE + var/lastCallTime = 6000 + //SPLURT EDIT ADDITION END +``` + +- **Removal:** + +```byond + //SPLURT EDIT REMOVAL BEGIN - FEATURE_NAME - (Optional Reason/comment) + /* + for(var/obj/docking_port/stationary/S in stationary) + if(S.id = id) + return S + */ + //SPLURT EDIT REMOVAL END + WARNING("couldn't find dock with id: [id]") +``` + +- **Change:** + +```byond + //SPLURT EDIT CHANGE BEGIN - FEATURE_NAME - (Optional Reason/comment) + //if(SHUTTLE_STRANDED, SHUTTLE_ESCAPE) - SPLURT EDIT - ORIGINAL + if(SHUTTLE_STRANDED, SHUTTLE_ESCAPE, SHUTTLE_DISABLED) + //SPLURT EDIT CHANGE END + return 1 +``` + +## Modular Defines + +Our modular defines are located at `code/__DEFINES/~~~splurt_defines`. If you have a define that's used in more than one file, it must be declared here. If you have a define that's used in one file and won't be used anywhere else, declare it at the top and `#undef MY_DEFINE` at the bottom of the file. + +## Binary Files and Maps + +It's preferable to use modular binary files (sounds, icons, assets, etc.) to add content rather than editing non-modular binary files. This should always be your first option when working with binary files. However, if it is absolutely necessary, you may edit non-modular binary files. Remember, if you want to edit maps or binary files, you must install the hooks located in tools/hooks/install.bat. + +### Maps + +When editing maps, especially those that exist in the upstream codebase, the first option should be to use the automapper. The automapper allows you to make modular edits to maps by applying changes through predefined templates and coordinates, ensuring that the core map files remain untouched. + +There are two main ways to use the automapper: the simple area automapper for small changes and the template automapper for larger changes. + +1. **Simple Area Automapper:** + + - Use this for small changes, such as adding a single item to an area. + - Define the item and its location in the automapper configuration. + - This will place the specified item at the given coordinates in the specified area. + +2. **Template Automapper:** + + - Use this for larger changes, such as modifying entire rooms or sections of the map. + - Create a template file that defines the changes you want to make. + - Add entries to the automapper_config.toml file to specify where and how the template should be applied. + - This will apply the changes defined in the template file at the given coordinates. + +Direct edits to the map files should only be made if the automapper is not sufficient for the intended edits. This ensures that our map changes remain modular and easier to manage. + +## Afterword + +We hope this handbook makes contributing to S.P.L.U.R.T. a pleasant experience. Remember, these guidelines are here to help maintain the quality and organization of our codebase. If you have any questions or need assistance, don't hesitate to reach out to our maintainers or the community. Happy coding! From c0986ba12878edcaa05710b451d96c2c6c737f77 Mon Sep 17 00:00:00 2001 From: BongaTheProto <93835010+BongaTheProto@users.noreply.github.com> Date: Sat, 20 Jul 2024 19:05:16 -0500 Subject: [PATCH 2/7] Update README.md Co-authored-by: Elizabeth <81447825+liz-lavenza@users.noreply.github.com> --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index d5527ffec1837..436acfb974e3a 100644 --- a/README.md +++ b/README.md @@ -23,7 +23,7 @@ Space Station 13 is a paranoia-laden round-based roleplaying game set against th ## Contribution Rules and Guidelines **1. Do Not Be A Dick** -- The S.P.L.U.R.T. main repository is run by and contributed by volunteers. Please be considerate with the people who help maintaining our station. We reserve the right to permanently remove anyone who does not show both our contributor's and maintainer's common decency. +- The S.P.L.U.R.T. main repository is run by and contributed by volunteers. Please be considerate with the people who help maintain our codebase. We reserve the right to permanently remove anyone who does not show both our contributors and maintainers common decency. **2. Modularization Standards Will be Upheld** - This codebase is a active downstream to Bubberstation with frequent upstream merges. From 57160d714d4db9d870c461cb3c45b36b5e8cdd80 Mon Sep 17 00:00:00 2001 From: BongaTheProto <93835010+BongaTheProto@users.noreply.github.com> Date: Sat, 20 Jul 2024 19:06:10 -0500 Subject: [PATCH 3/7] Update modular_zzplurt/readme.md Co-authored-by: Elizabeth <81447825+liz-lavenza@users.noreply.github.com> --- modular_zzplurt/readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modular_zzplurt/readme.md b/modular_zzplurt/readme.md index 914ae35775ad8..8e6d403a69924 100644 --- a/modular_zzplurt/readme.md +++ b/modular_zzplurt/readme.md @@ -2,7 +2,7 @@ ## Introduction -Welcome to the S.P.L.U.R.T. station's modularization handbook! Our goal is to make contributing to our codebase as easy and comfy as possible for coders while upkeeping our code standards. We understand that maintaining a codebase that's a fork of another can be challenging, but with the right practices, we can keep our code clean, organized, and easy to manage. This handbook outlines our modularization protocols and coding standards to help you get started. +Welcome to the S.P.L.U.R.T. codebase's modularization handbook! Our goal is to make contributing to our codebase as easy and comfy as possible for coders while upkeeping our code standards. We understand that maintaining a codebase that's a fork of another can be challenging, but with the right practices, we can keep our code clean, organized, and easy to manage. This handbook outlines our modularization protocols and coding standards to help you get started. If you'd like to know more about coding, contributing and contribution standards, feel free to read this repository's [contribution guides](./.github/guides)! From 24b6bde4837c43c724ea17b05d268edc3745587a Mon Sep 17 00:00:00 2001 From: BongaTheProto <93835010+BongaTheProto@users.noreply.github.com> Date: Sat, 20 Jul 2024 19:06:28 -0500 Subject: [PATCH 4/7] Update modular_zzplurt/readme.md Co-authored-by: Elizabeth <81447825+liz-lavenza@users.noreply.github.com> --- modular_zzplurt/readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modular_zzplurt/readme.md b/modular_zzplurt/readme.md index 8e6d403a69924..ddabda6980d3a 100644 --- a/modular_zzplurt/readme.md +++ b/modular_zzplurt/readme.md @@ -41,7 +41,7 @@ Modularization is the practice of organizing code into separate, self-contained Our modularization protocols are founded on three pillars: 1. **Modularize anything that's reasonable to modularize:** This includes anything that can be modularized without decreasing its quality or the quality of existing code, and won't logically cause more issues by modularizing than not doing it. -2. **Use commenting conventions for non-modular edits:** When editing non-modular code, make sure to adequately use the commenting conventions to ensure it is known that it's a non-modular edit. +2. **Use commenting conventions for non-modular edits:** When editing non-modular code, make sure to adequately use the [commenting conventions](#commenting-conventions) to ensure it is known that it's a non-modular edit. 3. **It's ok to mess up:** These rules are intended less as a set of guidelines for contributors to strictly follow, but rather coding standards that we all collectively help to attain, for examble through maintainers helping any contributors fulfill them in their pull requests. ### Modular Overrides From 60a80b17930f47619450af1dbacdd4cabdde92ed Mon Sep 17 00:00:00 2001 From: BongaTheProto <93835010+BongaTheProto@users.noreply.github.com> Date: Sat, 20 Jul 2024 19:06:56 -0500 Subject: [PATCH 5/7] Update modular_zzplurt/readme.md Co-authored-by: Elizabeth <81447825+liz-lavenza@users.noreply.github.com> --- modular_zzplurt/readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modular_zzplurt/readme.md b/modular_zzplurt/readme.md index ddabda6980d3a..1096c3a2d3cc5 100644 --- a/modular_zzplurt/readme.md +++ b/modular_zzplurt/readme.md @@ -42,7 +42,7 @@ Our modularization protocols are founded on three pillars: 1. **Modularize anything that's reasonable to modularize:** This includes anything that can be modularized without decreasing its quality or the quality of existing code, and won't logically cause more issues by modularizing than not doing it. 2. **Use commenting conventions for non-modular edits:** When editing non-modular code, make sure to adequately use the [commenting conventions](#commenting-conventions) to ensure it is known that it's a non-modular edit. -3. **It's ok to mess up:** These rules are intended less as a set of guidelines for contributors to strictly follow, but rather coding standards that we all collectively help to attain, for examble through maintainers helping any contributors fulfill them in their pull requests. +3. **It's ok to mess up:** These guidelines are intended less as a set of ironclad rules for contributors to strictly follow, but rather coding standards that we all collectively help to attain, for example through maintainers helping any contributors fulfill them in their pull requests. ### Modular Overrides From 60d60a4261a9363f686ae4cfd6718f8adaca59aa Mon Sep 17 00:00:00 2001 From: BongaTheProto <93835010+BongaTheProto@users.noreply.github.com> Date: Sat, 20 Jul 2024 19:07:17 -0500 Subject: [PATCH 6/7] Update modular_zzplurt/readme.md Co-authored-by: Elizabeth <81447825+liz-lavenza@users.noreply.github.com> --- modular_zzplurt/readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modular_zzplurt/readme.md b/modular_zzplurt/readme.md index 1096c3a2d3cc5..b9bc448272fe1 100644 --- a/modular_zzplurt/readme.md +++ b/modular_zzplurt/readme.md @@ -83,7 +83,7 @@ Modular overrides should be used whenever possible to keep the core codebase cle - **Use modular overrides when they won't cause more issues than not modularizing them:** If a modular override would introduce significant complexity, performance issues, or maintenance challenges, it may be better to make a non-modular edit with proper commenting. - **Avoid unnecessary overrides:** Do not override procs or variables unless it is necessary for your feature or fix. Unnecessary overrides can lead to maintenance headaches and potential conflicts with upstream changes. -- **Document your overrides:** Clearly documenting any modular overrides in your code and helps maintainers and other contributors understand the changes and their purpose. +- **Document your overrides:** Clearly documenting any modular overrides in your code helps maintainers and other contributors understand your changes and their purpose. By following these guidelines, we can ensure that our codebase remains clean, maintainable, and easy to navigate, while still allowing for the flexibility to add new features and make necessary changes. ## Folder Structure From 0e8bc7d18bb25684ffccac8233b69aebcf87a17c Mon Sep 17 00:00:00 2001 From: BongaTheProto <93835010+BongaTheProto@users.noreply.github.com> Date: Sun, 21 Jul 2024 22:39:47 -0500 Subject: [PATCH 7/7] adds the suggestions --- README.md | 1 + modular_zzplurt/readme.md | 18 ++++++++++++++++-- 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 436acfb974e3a..af6a52b8bc89a 100644 --- a/README.md +++ b/README.md @@ -40,6 +40,7 @@ Space Station 13 is a paranoia-laden round-based roleplaying game set against th - You are entitled to credit yourself with comments and you are entitled to waive the attribution requirement choosing not to be identified as the creator if you wish. - If you do not like how your assets were modified or used, it is required that the other person [remove the attribution information upon request](https://wiki.creativecommons.org/wiki/License_Versions#Licensors_may_request_removal_of_attribution). - Modifications or adaptions must disclose the source, the author, and [any changes you've made](https://wiki.creativecommons.org/wiki/License_Versions#Modifications_and_adaptations_must_be_indicated). +- Goonstation code is incompatible with this codebase due to its licensing. *Credit: [Goonstation contribution guidelines](https://hackmd.io/@goonstation/docs/%2F%40goonstation%2Fcontribute#What-if-I-change-my-mind-about-my-contributions-being-published)* diff --git a/modular_zzplurt/readme.md b/modular_zzplurt/readme.md index b9bc448272fe1..60a870a00f1aa 100644 --- a/modular_zzplurt/readme.md +++ b/modular_zzplurt/readme.md @@ -46,7 +46,9 @@ Our modularization protocols are founded on three pillars: ### Modular Overrides -Modular overrides allow us to extend or modify the behavior of existing code without directly editing the core files. This is done by creating new definitions or modifying existing ones in a way that they can be easily integrated into the core codebase. There are two main types of modular overrides: Variable Overrides and Proc Overrides. +Modular overrides allow us to extend or modify the behavior of existing code without directly editing the core files. This is done by creating new definitions or modifying existing ones in a way that they can be easily integrated into the core codebase. + +There are two main types of modular overrides: Variable Overrides and Proc Overrides. #### Variable Overrides @@ -77,13 +79,23 @@ Proc overrides allow you to extend or modify the behavior of existing procedures In this example, the shoot_live_shot proc is overridden to add a new behavior (spawning sparks) after calling the original proc. This ensures that the new behavior is added without modifying the core code. +#### How and Why Modular Overrides Work + +Modular overrides work by leveraging BYOND's file inclusion and proc definition order. When BYOND compiles the code, it processes files and definitions in the order that they're included in [tgstation.dme](./../tgstation.dme). BYOND orders said includes in alphabetical order, with `_` being before all letters, and `~` being after. + +Proc overrides run in the order of last-defined to first-defined. This means that the most recently defined proc will be the one that is executed. By placing our overrides in files that are included later in the compilation process, we ensure that they take precedence over earlier definitions. + +#### Why modular_zzplurt? + +The folder is named `modular_zzplurt` rather than `modular_splurt` to ensure that it comes after all other `modular_` folders in the alphabetical order. This guarantees that our modular overrides are processed last, allowing them to effectively override any previous definitions. + #### When to Use Modular Overrides Modular overrides should be used whenever possible to keep the core codebase clean and maintainable. However, it's important to use them judiciously and ensure that they do not introduce performance issues or make the code harder to understand and maintain. Specifically: - **Use modular overrides when they won't cause more issues than not modularizing them:** If a modular override would introduce significant complexity, performance issues, or maintenance challenges, it may be better to make a non-modular edit with proper commenting. -- **Avoid unnecessary overrides:** Do not override procs or variables unless it is necessary for your feature or fix. Unnecessary overrides can lead to maintenance headaches and potential conflicts with upstream changes. - **Document your overrides:** Clearly documenting any modular overrides in your code helps maintainers and other contributors understand your changes and their purpose. + By following these guidelines, we can ensure that our codebase remains clean, maintainable, and easy to navigate, while still allowing for the flexibility to add new features and make necessary changes. ## Folder Structure @@ -139,6 +151,8 @@ Our modular defines are located at `code/__DEFINES/~~~splurt_defines`. If you ha It's preferable to use modular binary files (sounds, icons, assets, etc.) to add content rather than editing non-modular binary files. This should always be your first option when working with binary files. However, if it is absolutely necessary, you may edit non-modular binary files. Remember, if you want to edit maps or binary files, you must install the hooks located in tools/hooks/install.bat. +**For sound files** the only accepted format to use in the codebase is `.ogg`. All files should be as compressed as possible to not bloat our rsc files. + ### Maps When editing maps, especially those that exist in the upstream codebase, the first option should be to use the automapper. The automapper allows you to make modular edits to maps by applying changes through predefined templates and coordinates, ensuring that the core map files remain untouched.