For enabling reproducible dependency installations, this project uses pipenv
.
Pipenv in this projects requires Python version 3.7 or higher, which can be
installed for example with pyenv
, https://github.com/pyenv/pyenv.
You can check your current version with python --version
.
Follow the steps below to install the correct Python version if not already found.
To install all necessary dependencies for pyenv and Python, run the following command:
sudo apt-get update && sudo apt-get upgrade && sudo apt-get install -y build-essential libssl-dev zlib1g-dev libbz2-dev libreadline-dev libsqlite3-dev wget curl llvm libncurses5-dev libncursesw5-dev xz-utils tk-dev libffi-dev liblzma-dev python-openssl git
To install pyenv with the official installer, run curl https://pyenv.run | bash
.
Then, to add pyenv to your path, add these three lines to the end of your ~/.bashrc
file using your preferred text editor.
export PATH="/home/$USER/.pyenv/bin:$PATH"
eval "$(pyenv init -)"
eval "$(pyenv virtualenv-init -)"
Then run source ~/.bashrc
.
Next, install the correct Python version with pyenv
, by running
pyenv install 3.7.8
. Then, to enable the correct Python version to be used
for SurroRTG SDK, navigate to the root of your cloned surrortg-sdk
repository
in your terminal, and run pyenv local 3.7.8
.
To install all of the dependencies, run first pip install pipenv
and then
pipenv sync
.
Then you can enter the virtual environment with pipenv shell
(and exit with
exit
). There are also scrotps such as pipenv run arcade
for starting test
games, check Pipfile for more scripts.
There is a surroctl
command line control available for more convenient game
development. To install run ./scripts/install_surroctl.sh
and afterwards run
surroctl --help
for more info.
We're following PEP8,
and have the formatter black
and linter flake8
setup. Imports are ordered
following
PEP8's import recommendations
with isort
.
These tools are run in Bitbucket pipelines and Githubs Actions to ensure properly formatted code, but the use of pre-commit hooks is highly recommended.
For this purpose, there are settings for pre-commit tool in the project. To
use it, run pipenv sync --dev
.
One of the pre-commit hooks, markdownlint, uses and requires Ruby with a version
above 2.6. In Ubuntu 20.04, this can be installed with sudo apt-get install ruby-full
.
In older Ubuntu distributions, the version in the distribution's repositories
is too old, and the correct version can be installed with ruby version manager,
rvm by running the command below.
sudo apt-get update
sudo apt-get install gcc autoconf curl g++ gnupg automake bison libc6-dev libffi-dev libgdbm-dev libncurses5-dev libsqlite3-dev pkg-config sqlite3 zlib1g-dev libtool libyaml-dev make libgmp-dev libreadline-dev libssl-dev
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB
curl -sSL https://get.rvm.io | bash -s stable
source ~/.rvm/scripts/rvm
rvm install 2.7.0
rvm use 2.7.0 --default
Then run pre-commit install
in the project root to install the pre-commit hooks.
The project uses codespell
to check for spelling mistakes. It runs both as a
pre-commit hook and in the pipelines. It searches for spelling mistakes and suggests
alternatives for the mistakes. Sometimes words that have meaningful purpose in
our context are not recognized by the codespell and might end up failing the pre-commits
and pipelines because of that. In that case, you can add the word to be ignored
by codespell into the file .codespell-ignore
, on its own line.
Enter the virtual environment with pipenv shell
.
Then run python -m <module_name>
in project the root,
e.g python -m games.rvr.game
.
To exit the shell simply run exit
.
Create a new game at dev.surrogate.tv/admin
. Then start the GE, and submit
options for single player.
Next, copy games/dummy_game/config_sample.toml
file to your preferred location,
and add the game's device_id
, token
and id
to it. Then save surrortg
streamer binary to your machine.
Start the Python robot from the project root with:
pipenv run dummy --conf=<PATH_TO_YOUR_CONFIG_TOML>
and the surrortg streamer from the save location with:
./surrortg --conf=<PATH_TO_YOUR_CONFIG_TOML>
Now you should be able to queue and play the game.
Commands from player are sent as JSON with following template:
{
type: <type>,
id: <input-id>,
command: <type-specific json object>
}
Refer to device classes for message format definitions for specific types
Then go through the unittests the tests by running pipenv run tests
To build the documentation, first run pipenv sync --dev
.
Then to build docs page or pdf docs use
pipenv run docs
or pipenv run pdf-docs
.
To also open the docs page or pdf, you can add --
before the command
and -f
to open on Firefox or -c
to open in Chromium.
For example: pipenv run -- docs -f
Also to serve the docs page in http://localhost:8000 you can use
pipenv run -- docs -s
After building, the documentation can be found in
docs/build/html/index.html
or docs/build/latex/surrortgsdk.pdf
The documentation files and READMEs should use Markdown or reStructuredText syntax whenever possible, instead of HTML + CSS. This allows the files to be readable and easily editable even when they are not rendered properly.
The global CSS styling rules can be edited at
docs/source/_static/css/custom.css
, but this should be done carefully as it
affects all documentation pages.