Skip to content

Latest commit

 

History

History
78 lines (53 loc) · 5.39 KB

CONTRIBUTING.md

File metadata and controls

78 lines (53 loc) · 5.39 KB

Contribution Guidelines

General Notice

We reserve the right to remove any pull request or issue at any time for any reason.

We hope not to have to excercise this right, but recognize that any open-source project may attract poor or malicious contribution attempts.

Unless a potential contributor is acting maliciously, we will attempt to provide notice of why their contributions have been denied.

Code formatting

There are many ways of formatting code (particularly in regard to indentation and brackets), and it is helpful for projects to hold to a given format for consistency and clarity. Unfortunately, the AM2R Community Updates have passed through many hands and, combined with the occasional oddity from source reconstruction, has provided for an exceptionally messy codebase.

Moving forward, we will be holding to a fairly strict set of formatting rules in an attempt to remedy this and will deny pull requests until their formatting is fixed, even if they are otherwise excellent contributions. On a related note, pull requests that simply change existing formatting for consistency's sake are more than welcome.

We generally hold to the Allman Style of code indentation and bracketing, with a slight modification for if/else readability. It looks like this:

if (codeFormatIsGood) {
    show_debug_message("Cool beams!");
} 
else {
    show_debug_message(":(");
}

Please comment your code thoroughly. We don't need a breakdown of every single line of code, but we must be able to tell what your code is doing with a quick perusal.

Comments should always be in English and generally follow proper grammar and sentence structuring norms. Other contributors must be able to understand what you are saying.

Comment lines should not be unecessarily long. Rule of thumb: if you have to scroll to read them, you're doing it wrong. Multiline comments should be used instead:

/*
    Please don't make me ask you to modify your pull request for readability.
    It's not that hard, and saves the next programmer a lot of trouble :)
*/

In keeping with GM:S conventions, all functions/methods should use snake_case.

Variables (local, global, and temporary) should use camelCase.

Enums and variables used as constants should use UPPERCASE.

Sprites, sounds, backgrounds/tilesets, shaders, fonts, and objects should all hold to a camelCase format with an appropriate prefix:

sSpriteName, sndSoundName, bgBackgroundName/tlTilesetName, shShaderName, fontFontName, and oObjectName.

Rooms should hold to the format of rm_roomName.

We will not typically accept pull requests that implement new timelines, shaders, fonts, or rooms. Here's why:

  • Timelines are too integrated with GML Drag 'n' Drop and can be easily replicated with proper state machines. Two currently exist, but they will eventually be replaced.
  • Shaders are difficult to provide quality control for thanks to differences in evaluation on various GPU models. The two that we currently utilize already have issues with various GPUs (or lack thereof), and providing support for more would require a low cost/benefit ratio. Shaders can also cause significant performance drops on Linux and Android devices.
  • Fonts are already plentiful in AM2R. Additional characters for localization support aside, it has what it needs for every situation/scale, and we seek to maintain visual consistency within the project.
  • New rooms are almost always outside of project scope.

Why we reject Enhancement/Feature requests

Over the years, we have unfortunately had to reject many community-provided ideas for the AM2R Community Updates in the best interest of the project's design.

We may reject Enhancement/Feature requests for many reasons, but they usually boil down to one of three: project bloat, project scope, and feasibility.

Project bloat is an issue that occurs when a project has too many options and/or features and becomes overwhelming and/or uncohesive. This was an issue in the past when we added a massive amount of toggleable features via the modifiers.ini file, and we have worked to reduce this for some time.

Project scope is the set of overarching goals for a project and the boundaries it should stay within. When something is "outside of project scope," it means that it does not fall within the project's goals. Enhancements/Features that are outside of project scope could create feature bloat, cause a project to lose its focus, or provide a large waste of time.

Ridley is outside of project scope.

Feasibility is a balance of the effort required to implement an Enhancement/Feature versus the benefit of implementing said Enhancement/Feature. Some ideas are really cool and would fit within project scope, but simply aren't worth the time and effort to implement. This is less of a concern now that the project is open source and can have more contributors, but is still always worth keeping in mind.

List of notable rejected Enhancement/Feature requests

  • Ridley (scope)
  • SA-X (scope/feasibility)
  • Phantoon (scope)
  • New bosses in general (scope/bloat)
  • New areas (scope/bloat)
  • New powerups (scope/bloat)
  • Beam Combos (scope/bloat)
  • Anything placed behind the broken pipe (scope/bloat)
  • Vita port (feasibility, lack of legitimate access to export module)
  • New Suit variants (scope/bloat/feasibility)
  • Texturepack support (bloat/feasibility)
  • New difficulties (bloat/scope)