2021-03-08 11:56:43 +00:00
# Contributing to obs-websocket
## Translating obs-websocket to your language
Localization happens on [Crowdin ](https://crowdin.com/project/obs-websocket )
## Branches
2021-04-26 15:46:11 +00:00
**Development happens on `master` **
2021-03-08 11:56:43 +00:00
## Writing code for obs-websocket
### Code Formatting Guidelines
2021-04-26 15:46:11 +00:00
* Function and variable names: camelCase for variables, MixedCaps for method names
2021-03-08 11:56:43 +00:00
2021-04-26 15:46:11 +00:00
* Request and Event names should use MixedCaps names. Keep naming conformity of request naming using similar terms like `Get` , `Set` , `Get[x]List` , `Start[x]` , `Toggle[x]` .
2021-03-08 11:56:43 +00:00
2021-06-15 06:31:42 +00:00
* Request and Event json properties/fields should use camelCase. Try to use existing property names.
2021-03-08 11:56:43 +00:00
2021-06-15 06:31:42 +00:00
* Code is indented with Tabs. Assume they are 4 columns wide
2021-03-08 11:56:43 +00:00
2021-04-26 15:46:11 +00:00
* 80 columns max code width. (Comments/docs can be larger)
2021-03-08 11:56:43 +00:00
* New and updated requests/events must always come with accompanying documentation comments (see existing protocol elements for examples).
These are required to automatically generate the [protocol specification document ](docs/generated/protocol.md ).
### Code Best-Practices
* Favor return-early code and avoid wrapping huge portions of code in conditionals. As an example, this:
```cpp
2021-11-17 09:32:37 +00:00
if (success)
2021-06-15 06:31:42 +00:00
return RequestResult::Success();
2021-11-17 09:32:37 +00:00
else
2021-06-15 06:31:42 +00:00
return RequestResult::Error(RequestStatus::GenericError);
2021-03-08 11:56:43 +00:00
```
is better like this:
```cpp
2021-11-17 09:32:37 +00:00
if (!success)
2021-06-15 06:31:42 +00:00
return RequestResult::Error(RequestStatus::GenericError);
2021-11-17 09:32:37 +00:00
2021-06-15 06:31:42 +00:00
return RequestResult::Success();
2021-03-08 11:56:43 +00:00
```
2021-11-17 09:32:37 +00:00
* Try to use the [built-in ](https://github.com/obs-websocket/obs-websocket/blob/master/src/requesthandler/rpc/Request.h ) request checks when possible.
2021-06-15 06:31:42 +00:00
* Refer to existing requests for usage examples.
2021-03-08 11:56:43 +00:00
* Some example common response/request property names are:
* `sceneName` - The name of a scene
2021-06-15 06:31:42 +00:00
* `inputName` - The name of an input
* `sourceName` - The name of a source (only for when multiple source types apply)
* `sceneItemEnabled` - Whether a scene item is enabled
* Response parameters which have no attributed data due to an invalid state should be set to `null` (versus being left out)
* For example, when `GetSceneList` is called and OBS is not in studio mode, `currentPreviewSceneName` will be `null`
2021-11-17 09:32:37 +00:00
* If a request's core response data depends on a state, an error should be thrown. See `GetCurrentPreviewScene` as an example.
* In general, try to match the style of existing code as best as possible. We try our best to keep a consistent code style, and may suggest nitpicks as necessary.
2021-03-08 11:56:43 +00:00
### Commit Guidelines
* Commits follow the 50/72 standard:
2021-11-17 09:32:37 +00:00
* 50 characters suggested max for the commit title (absolute maximum 72 including scope)
2021-03-08 11:56:43 +00:00
* One empty line after the title
* Description wrapped to 72 columns max width per line.
* Commit titles:
* Use present tense
* Prefix the title with a "scope" name
* e.g: "CI: fix wrong behaviour when packaging for OS X"
* Typical scopes: CI, General, Requests, Events, Server
**Example commit:**
```
2021-06-15 06:31:42 +00:00
Requests: Add GetSceneList
2021-03-08 11:56:43 +00:00
2021-06-15 06:31:42 +00:00
Adds a new request called `GetSceneList` which returns the current
scene, along with an array of objects, each one with a scene name
and index.
2021-03-08 11:56:43 +00:00
```
### Pull Requests
2021-04-26 15:46:11 +00:00
* Pull Requests must never be based off your fork's main branch (in this case, `master` ).
2021-03-08 11:56:43 +00:00
* Start your work in a newly named branch based on the upstream main one (e.g.: `feature/cool-new-feature` , `bugfix/fix-palakis-mistakes` , ...)
* If your work is not done yet, but for any reason you need to PR it (like collecting discussions, testing with CI, getting testers),
create it as a Draft Pull Request (open the little arrow menu next to the "Create pull request" button, then select "Create draft pull request").