- Contributing code to Matrix
- Android Studio settings
- Compilation
- I want to help translating Element
- I want to submit a PR to fix an issue
- Thanks
Please read https://github.com/matrix-org/synapse/blob/master/CONTRIBUTING.md
Element X Android support can be found in this room: .
The rest of the document contains specific rules for Matrix Android projects
Please set the "hard wrap" setting of Android Studio to 160 chars, this is the setting we use internally to format the source code (Menu Settings/Editor/Code Style
then Hard wrap at
).
Please ensure that you're using the project formatting rules (which are in the project at .idea/codeStyles/), and format the file before committing them.
This project should compile without any special action. Just clone it and open it with Android Studio, or compile from command line using gradlew
.
For now strings are coming from Element Android project, so:
- If you want to fix an issue with an English string, please submit a PR on Element Android.
- If you want to fix an issue in other languages, or add a missing translation, or even add a new language, please use Weblate.
Please have a look in the dedicated documentation about pull request.
Please check if a corresponding issue exists. If yes, please let us know in a comment that you're working on it. If an issue does not exist yet, it may be relevant to open a new issue and let us know that you're implementing it.
This project is full Kotlin. Please do not write Java classes.
Please create at least one file under ./changelog.d containing details about your change. Towncrier will be used when preparing the release.
Towncrier says to use the PR number for the filename, but the issue number is also fine.
Supported filename extensions are:
.feature
: Signifying a new feature in Element Android or in the Matrix SDK..bugfix
: Signifying a bug fix..wip
: Signifying a work in progress change, typically a component of a larger feature which will be enabled once all tasks are complete..doc
: Signifying a documentation improvement..misc
: Any other changes.
See https://github.com/twisted/towncrier#news-fragments if you need more details.
Make sure the following commands execute without any error:
./gradlew check
Some separate commands can also be run, see below.
./gradlew ktlintCheck --continue
Note that you can run
./gradlew ktlintFormat
For ktlint to fix some detected errors for you (you still have to check and commit the fix of course)
knit is a tool which checks markdown files on the project. Also it generates/updates the table of content (toc) of the markdown files.
So everytime the toc should be updated, just run
./gradlew knit
and commit the changes.
The CI will check that markdown files are up to date by running
./gradlew knitCheck
./gradlew lint
Make sure the following commands execute without any error:
./gradlew test
Element X is currently supported on Android Lollipop (API 21+): please test your change on an Android device (or Android emulator) running with API 21. Many issues can happen (including crashes) on older devices. Also, if possible, please test your change on a real device. Testing on Android emulator may not be sufficient.
You should consider adding Unit tests with your PR, and also integration tests (AndroidTest). Please refer to this document to install and run the integration test environment.
For now strings are coming from Element Android project, so please read the documentation from there.
Please consider accessibility as an important point. As a minimum requirement, in layout XML files please use attributes such as android:contentDescription
and android:importantForAccessibility
, and test with a screen reader if it's working well. You can add new string resources, dedicated to accessibility, in this case, please prefix theirs id with a11y_
.
For instance, when updating the image src
of an ImageView, please also consider updating its contentDescription
. A good example is a play pause button.
When adding or editing @Composable
, make sure that you create a @Preview
function, with suffix Preview
. This will also create a UI test automatically.
Feel free to add an entry in file AUTHORS.md
Thanks for contributing to Matrix projects!