2016-09-10 02:44:46 -05:00
# Contributing
## Translating
2020-02-22 16:16:01 -06:00
Translation is managed through [Transifex ](https://www.transifex.com/openstreetmap/umap/ ).
2020-02-26 14:31:39 -06:00
2020-04-26 10:46:28 -05:00
## Bug Triaging
2020-02-26 14:31:39 -06:00
You are very welcome to help us triaging [uMap issues ](https://github.com/umap-project/umap/issues ).
* Help other users by answering questions
* Give your point of view in discussions
* And so on...
## Development on Ubuntu
2020-04-26 10:46:28 -05:00
### Environment setup
2020-02-26 14:31:39 -06:00
Choose one of the following two config:
#### Config global to your desktop
Follow the procedure [Ubuntu from scratch ](ubuntu.md )
But instead using folders /etc/umap, you can create a ~/.umap folder.
This folder will contain the umap.conf file.
And for folder /srv/umap, you can create a ~/umap folder (We will remove this folder later)
You will have to set an env var, we will set it in your .bashrc:
nano ~/.bashrc
Add the following at the end of file:
```
# uMap
export UMAP_SETTINGS=~/.umap/umap.conf
```
Then refresh your terminal
source ~/.bashrc
Run your local uMap and check that it is working properly.
#### Config inside your local git repo
Follow the procedure [Ubuntu from scratch ](ubuntu.md )
You can use the local.py.sample in the git repo and copy it to your local git repo to umap/settings/local.py
See [Installation ](install.md )
### Hacking on the code
2023-03-24 10:35:14 -05:00
Create a workspace folder `~/wk` and go into it.
2020-02-26 14:31:39 -06:00
2023-03-24 10:35:14 -05:00
"git clone" the main repository and go in the `umap/` folder.
2020-02-26 14:31:39 -06:00
2023-03-24 10:35:14 -05:00
Once you are in the `umap/` folder, create a Python virtual environment:
2020-02-26 14:31:39 -06:00
2023-03-24 10:35:14 -05:00
python3 -m venv venv
source venv/bin/activate
2020-02-26 14:31:39 -06:00
2023-03-24 10:35:14 -05:00
Now, the `umap` command will be available.
2020-02-26 14:31:39 -06:00
2023-03-24 10:35:14 -05:00
*Note: if you close your terminal, you will need to re-run that command from `~/wk/umap` :*
2020-02-26 14:31:39 -06:00
2023-03-24 10:35:14 -05:00
source venv/bin/activate
2020-02-26 14:31:39 -06:00
2023-03-24 10:35:14 -05:00
To test your code, you will add to install umap from your git folder. Go to `~/wk/umap` and run:
2020-02-26 14:31:39 -06:00
2023-06-09 09:27:19 -05:00
make install
2020-02-26 14:31:39 -06:00
2020-04-26 10:46:28 -05:00
This command will check dependencies and install uMap from sources inside folder.
2020-02-26 14:31:39 -06:00
2022-10-26 11:48:14 -05:00
When installing from the git repository, do not forget to run `make installjs` and `make vendors` , before running `umap collectstatic` (as mentioned in [Ubuntu from scratch ](ubuntu.md )).
2023-03-24 10:35:14 -05:00
Create a PostgreSQL database and apply migrations to setup your database:
createdb umap
umap migrate
You should now be able to start your local uMap instance:
2020-02-26 14:31:39 -06:00
umap runserver 0.0.0.0:8000
### Update translations
Install needed tools:
apt install gettext transifex-client
Pull the translations from transifex website:
tx pull -f
Then you will need to update binary files with command:
2020-04-26 10:46:28 -05:00
2020-02-26 14:31:39 -06:00
make compilemessages
Done. You can now review and commit modified/added files.