Thanks for considering to contribute to resvg_nif. ❤
Bug reports, feature suggestions, and pull requests for any open issues are very welcome. Issues can be reported on GitHub: https://github.com/mrdotb/resvg_nif/issues/new.
Please read and follow our Code of Conduct.
In order to setup the development environment you need to have some dependencies installed on your machine:
Checkout the resvg_nif repository with
$ git clone [email protected]:mrdotb/resvg_nif.git
Then step into the project directory and install the dependencies with
mix deps.get
To force local compilation you need to set the env
export RESVG_BUILD=1
Here’s how to contribute:
- Fork it (https://github.com/mrdotb/resvg_nif/fork)
- Create your feature branch (git checkout -b feature/my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin feature/my-new-feature)
- Create a new Pull Request
Try to add tests along with your new feature. This will ensure that your code does not break existing functionality and that your feature is working as expected. You can run the tests with:
mix test
If you’ve changed any Elixir code or Rust code, please run Elixir’s and Rust's code formatter before committing your changes:
mix format.all
This will keep the code style consistent and future code diffs as small as possible.
For detailed info about what needs to be done in order to publish a new version of
the resvg package on hex.pm, please refer to the release flow section in the
precompilation guide
of rustler_precompiled
.
As a contributor, please keep in mind this project is free and open source software. Maintainers are not paid to work on it, so there might be times were the maintainers seem unresponsive. If you have that feeling, please be patient and be assured, that all team members try their best to review your contribution and reply to you as soon as their time allows.