This document outlines the guidelines for contributing to the RE:SS3D project. If you have any questions, feel free to ask on out discussions page or discord server.
Also, check out https://ss3d.space/contribute/, which has a breakdown of the different contributions types as well as links for asset kits, guides, and to-do boards for each type.
The game itself is made in Unity and written in C#, check out our code (C#) style guide. We use Mirror for networking and there is a helpful document explaining its use with Unity here.
Option A.
- Clone this (SS3D) repository.
- Download Unity Hub.
- Download the current Unity version that the project tells you.
Option B.
- Clone this (SS3D) repository.
- Download Unity 2019.3.12 or newer and open the folder containing the project in Unity.
[YouTube Tutorial - Unity] RE:SS3D Load Scenes
- Drag 'MainMenu.Scene' (in /Assets/Content/Scenes/) into the scene window. This is the only scene required to run the project, so without this scene loaded you cannot run it. Also, delete any default/untitled scenes that Unity loaded when it launched.
- (Optional - If you plan to run multiple clients to test multiplayer) Build the project via File > Build or Build Settings.
- Hit the play button at the top of the Unity window.
[YouTube Tutorial - Unity] RE:SS3D Play Test
- Click 'Host' to take you to the server host lobby.
- Click 'Admin' to take you to the server host settings.
- Select and load a map.
- Once the map is loaded, click 'Start' to start the round. Click 'Exit' to return from the settings page back to the lobby page.
- Click 'Exit' to return from the settings page back to the lobby page.
- Click 'Embark' to join the round.
- (Optional - If you are testing with multiple clients) Open the built client from step 2 of the setup process. Click 'Join' to join the lobby of the locally hosted server. Click 'Embark' to join the round.
The set of people responsible for making sure the contribution cycle runs smoothly and that the changes made to the project are wanted, correct, and functional. On the Github these people are labeled "members", and on the Discord they are known as "Centcom".
The project maintainers have the following goals:
- To prioritize issues and pull requests so the most important changes get focused on and added to the project first.
- To make sure no contributions, however minor, don't get overlooked. Despite some contributions having greater priority, all contributions are created equal.
- To verify that contributions comply with our standards, will not break the project, and are wanted, before they are accepted into the project.
To start contributing via GitHub, first you should fork this GitHub repository, using the 'Fork' button in the upper right corner of this page. Naturally, this requires a GitHub account. You will commit your changes to your fork and then make a pull request to merge it into our repository. Learn more about pull requests here.
Over time your fork will become out-dated as the main project's repository continues to be added upon. GitHub has made a pretty clear guide on how to sync your fork, to keep it up to date with the SS3D repository.
Before reporting a bug, please check the our issues to see if the bug has already reported. Bugs are categorized into 3 groups:
Bug (Unconfirmed) - Some kind of error reported by an individual but needs confirmation. Bug (Confirmed) - Bugs that have been confirmed by another contributor. Bug (Can't Confirm) - Bugs that have tried to be replicated but were unsuccessful.
If you are unfamiliar with issues, GitHub has a helpful guide here. Use one of the templates when creating your issue, as the information it requests helps you help us help you more efficiently.
Explain the problem clearly and include any additional details to help maintainers reproduce the problem:
- Use a clear and descriptive title for the issue to identify the problem.
- Describe the steps to reproduce the problem as specifically and detailed as possible.
- Describe the behavior you observed and point out the problem with that behavior.
- Describe the expected behavior that should happen instead.
- Include pictures/videos to show the steps taken to demonstrate the problem.
- Include your game version and OS to help track if the problem is version specific.
- Include your game settings to help track if the problem is settings specific.
- If you're reporting a game crash, include a crash report with the error log. It's location depends on your operating system, so follow this official guide.
- If the problem isn't triggered by a specific action, describe what you were doing before the problem happened.
Pull requests allow the maintainers to review any changes and verify they are wanted and don't break anything in the existing project. Similarly to issues, you should use the template when making a new PR and provide as much detail as possible.
- Pull requests should merge into the master branch.
- The title and description should be clear and concise.
- If the PR is attempting to fix an issue, reference the issue number in the PR description ("Fixes #number").
- Include pictures/videos in your pull request whenever possible.
To get a hold of the project, you need a git client. Git is the software that manages the source. GitHub is the website that we use to host it. If you are new, GitHub Desktop is easiest for beginners.
- Use the present imperative tense ("Add feature" not "Added feature", "Move cursor to..." not "Moves cursor to...").
- Limit the first line to 72 characters or less.
- Reference issues and pull requests liberally after the first line.
When (re)naming files and folders always do so using 'PascalCase', this makes naming consistant which helps with organization and clarity.
Ex. "LockerDoorAnimationController.file" would be correct, not "Locker Door Animation Controller.file", not "lockerdoor animation controller.file", not "AnimationController - LockerDoor.file".