In order to add a new language to Citation Hunt, two steps are necessary:
- The interface needs to be translated (see below)
- Some configuration needs to be added in the code for the new language
Please check the Meta page on Citation Hunt to see the information we'll need to configure the new language, and also have a look at Setting up a local Citation Hunt if you'd like to try doing it yourself!
The first step to bringing Citation Hunt to a new language is to translate its interface. If you want to help with that, please head over to Translate Wiki.
Code changes are more than welcome too! Take a look at the issues, or file your own.
The run-tests.sh
script will run all tests for you. You may want to install it
as a pre-push hook on git:
ln -s ../../run-tests.sh .git/hooks/pre-push
The tests are also run by Travis-CI for pull requests.
For more technical contributions, you will likely want to set up a local instance of Citation Hunt. Let's do that.
It's highly recommended that you use a virtualenv for running Citation Hunt:
$ virtualenv ch-venv
$ cd ch-venv
$ . bin/activate
Dependencies are managed via a requirements.txt
file:
$ git clone https://github.com/eggpi/citationhunt
$ cd citationhunt
$ pip install -r requirements.txt
Note: we depend on the lxml package, which may require additional dependencies that are not listed in the requirements file.
If you are using Ubuntu (or some derived system), you may also need to run:
$ # Ubuntu only!
$ apt-get install libxml2-dev libxslt1-dev python-dev
to get the dependencies to install properly.
For MacOS, you may need to install openssl separately and ensure the MySQL dependencies can link to it by setting an environment variable while installing requirements:
$ # MacOS only!
$ brew install openssl
$ export LIBRARY_PATH=$LIBRARY_PATH:/usr/local/opt/openssl/lib
$ pip install -r requirements.txt
You're nearly ready to run the server, but you will need a database for it to
work. At this point, make sure you have a working local MySQL installation —
it can be something as simple as a MySQL server listening on localhost
that
you can access as root.
On MacOS, you may need to ensure you are running a pre-9.0 version of MySQL, which allows password authentication, as that is the method used in Toolforge. See this StackOverflow question for more information.
Then, please proceed to Generating the database locally, which will allow you to try Citation Hunt locally with any language.
Once the database has been generated, you're all set! Just run app.py
and point your browser to
localhost:5000
:
$ DEBUG=1 REPLICA_MY_CNF=/path/to/replica.my.cnf python app.py
Adding DEBUG=1
to the environment will run the server in Flask's debug
mode and enable HTTP
access (the default is to redirect all URLs to HTTPS, which causes certificate
errors when running locally).