Instead of each mutation being a flag that gets checked at some unique point in BotanySystem somewhere, they're now EntityEffects that get applied when the mutation occurs and when produce is harvested. One new list was added to SeedData so that multiple other fields could be removed. All the non-stat-change mutations that have been rolled are added to the Mutations list, and get applied to the plant when the mutation occurs or when a seed with the mutation is planted. Produce get mutations applied at harvest if they apply to the produce, and carry all of the plant's mutations over as a seed. This gets rid of the one-off checks for things like Slippery, Bioluminescent, Sentient, etc. The base odds of a mutation applying should be equal to the odds of the original mutation check. It pretended to have 1 bit flip (on averge) per mutation power, and odds of each mutation was the odds of one of its bit being flipped (1 /275 * bits). The 'thermometer code' applied for numbers will be replaced with simple random rolls, as both average out to the middle value. The new checks are much easier to understand and don't obfuscate the actual changes of something happening behind 3 layers of math. The biggest player-facing change is that Potency will be able to get over 65 significantly more often than it did in the previous system, but it will be just as common to get low values as high ones. Mutation definitions have been moved to a .yml file. These include the odds per tick per mutagen strength of that mutation applying that tick, the effect applied, if it applies to the plant and/or its produce. This makes mutations simpler to add and edit. This PR is limited specifically to the mutation logic. Improving other aspects of the system will be done in other PRs per the design document. Mutations was chosen first because its got the largest amount of one-off checks scattered all over that could be consolidated. Once this is merged, mutations could be contributed to the codebase with minimal extra work for later botany refactor PRs. |
||
|---|---|---|
| .github | ||
| .run | ||
| .vscode | ||
| BuildChecker | ||
| BuildFiles/Mac/Space Station 14.app/Contents | ||
| Content.Benchmarks | ||
| Content.Client | ||
| Content.Docfx | ||
| Content.IntegrationTests | ||
| Content.MapRenderer | ||
| Content.Packaging | ||
| Content.PatreonParser | ||
| Content.Replay | ||
| Content.Server | ||
| Content.Server.Database | ||
| Content.Shared | ||
| Content.Shared.Database | ||
| Content.Tests | ||
| Content.Tools | ||
| Content.YAMLLinter | ||
| Pow3r | ||
| Resources | ||
| RobustToolbox@0f60ad9018 | ||
| Tools | ||
| .editorconfig | ||
| .envrc | ||
| .gitattributes | ||
| .gitignore | ||
| .gitmodules | ||
| Directory.Packages.props | ||
| LEGAL.md | ||
| LICENSE-AGPLv3.txt | ||
| LICENSE-MIT.txt | ||
| README.md | ||
| RUN_THIS.py | ||
| RunBoth-Debug.bat | ||
| RunBoth-Tools.bat | ||
| RunBoth.bat | ||
| SECURITY.md | ||
| SpaceStation14.sln | ||
| SpaceStation14.sln.DotSettings | ||
| bors.toml | ||
| flake.lock | ||
| flake.nix | ||
| global.json | ||
| nuget.config | ||
| omnisharp.json | ||
| runclient-Debug.bat | ||
| runclient-Tools.bat | ||
| runclient-Tools.sh | ||
| runclient.bat | ||
| runclient.sh | ||
| runserver-Debug.bat | ||
| runserver-Tools.bat | ||
| runserver-Tools.sh | ||
| runserver.bat | ||
| runserver.sh | ||
| shell.nix | ||
README.md

Delta-V is a fork of Space Station 14, embracing a mixture of classic SS13 chaos and experimentation only possible with the new engine.
Space Station 14 is a remake of SS13 that runs on Robust Toolbox, a homegrown engine written in C#.
Delta-V is a continuation of the Nyanotrasen fork. Any work done in a non-base namespace may contain incorrect attributes due to rewrites and recommitting.
Links
DeltaV
Space Station 14
Website | Discord | Forum | Steam | Standalone Download
Documentation/Wiki
The docs site has documentation on SS14s content, engine, game design and more. It has lots of resources for new contributors to the project.
Contributing
We are happy to accept contributions from anybody. Get in Discord if you want to help. We've got a list of issues that need to be done and anybody can pick them up. Don't be afraid to ask for help either!
We are currently accepting translations of the game on our main repository. If you would like to translate the game into another language check the #localization channel in our Discord
If you make any contributions, please make sure to read the markers section in MARKERS.md Any changes made to files belonging to our upstream should be properly marked in accordance to what is specified there.
Building
- Clone this repo.
- Run
RUN_THIS.pyto init submodules and download the engine. - Compile the solution.
More detailed instructions on building the project.
License
Content contributed to this repository after commit 87c70a89a6 is licensed under the GNU Affero General Public License version 3.0, unless otherwise stated. See LICENSE-AGPLv3.txt.
Content contributed to this repository before commit 87c70a89a6 is licensed under the MIT license, unless otherwise stated. See LICENSE-MIT.txt.
87c70a89a67d0521a56388e6b1c3f2cb947943e4 was pushed on February 17th 2024 at 21:48 UTC
Most assets are licensed under CC-BY-SA 3.0 unless stated otherwise. Assets have their license and the copyright in the metadata file. Example.
Note that some assets are licensed under the non-commercial CC-BY-NC-SA 3.0 or similar non-commercial licenses and will need to be removed if you wish to use this project commercially.