The darktable project welcomes contributions:
- Code
- Documentation
- Testing (and any backtraces if you happpen to crash darktable)
- Translations
- Camera profiles.
- Tutorials, screencasts, etc.
See the darktable development page for more information.
Before you spend a lot of time working on a new feature, it's always best to discuss your proposed changes with us first. The best place to do that is in our IRC channel on irc.freenode.net, channel #darktable or the development mailing list, see here for more information. This will dramatically improve your chances of having your code merged, especially if we think you'll hang around to maintain it.
We like our code to be properly formatted. We have a well-defined coding style, and .clang-format style file represents it fully. You can enforce your commits to follow it:
- Install clang-format clang tool. Probably, any version will be ok, but the newer the better.
- You'll need to integrate
git
andclang-format
.
- For that, you will need to download
git-clang-format
from here or here. - Read it to check for nastiness.
- Warning: apparently, it only works with Python2, and does not work with Python3!
- Put it somewhere in your path (e.g.
~/bin
or/usr/local/bin
) and ensure that it is executable (chmod +x
).
- Now, step into your local clone of repository:
cd darktable/.git/hooks
- If you previously did not have a
pre-commit
hook:cp pre-commit.sample pre-commit && chmod +x pre-commit
- Open
pre-commit
with your favourite text editor, and append before the last block, here is how the end should look:
# format everything
res=$(git clang-format --diff | wc -l)
if [ $res -ne 1 ]
then
git clang-format
echo "Commit did not match clang-format"
exit 1;
fi
# If there are whitespace errors, print the offending file names and fail.
exec git diff-index --check --cached $against --
- Also, there is a Coding Style page on our redmine wiki.