We openly welcome patches for both the OMS framework and the Substratum application. Framework changes (including Theme Interfacer) are done through our Gerrit and changes to the Substratum app are done via pull requests. This will go over how to properly push your changes.
These will include new framework features and exposures.
Our framework changes are hosted at our SubstratumResources organization. Theme Interfacer changes are also done though Gerrit.
- Go to the Substratum Gerrit
- Click the sign in button in the upper left-hand corner
- Sign in with your Google account
- Click the avatar/name in the upper left-hand corner
- Create a username (this is permanent so choose wisely)
Follow Github's guide for generating SSH keys. Once you have generated those keys, go to our Gerrit, go to the same account settings page as above, click on the SSH Public Keys section, and add the full contents of the ~/.ssh/id_rsa.pub file that was generated.
Clone the repo from the link above. Everything is currently done on our n-mr2 branch for the framework and n-rootless branch for Theme Interfacer.
git clone -b n-mr2 <repo_url>
git clone -b n-rootless https://github.com/substratum/interfacer
Example:
git clone -b n-mr2 https://github.com/SubstratumResources/platform_frameworks_base
git add -A
git commit
Always make sure to make the commit message as detailed as possible. Also be sure to keep authorship intact if you had to manually add someone else's work.
If you haven't committed the change yet:
git commit --author="Name <email>"
If you have committed the change
git commit --amend --author="Name <email>"
Once your commit is in good shape, add a change ID:
curl -Lo .git/hooks/commit-msg https://substratum.review/tools/hooks/commit-msg
git commit --amend
Without this commit ID, you cannot push to Gerrit.
The push command takes the following format:
git push ssh://<USERNAME>@review.projektsubstratum.com:29418/<PROJECT> HEAD:refs/for/<BRANCH>
Our list of projects are available here.
Example:
git push ssh://[email protected]:29418/SubstratumResources/platform_frameworks_base HEAD:refs/for/n-mr2
If you need to make any changes to your patch, use git commit --amend
then push
again using the same command as above. Creating a new commit will push a new
change. Also be sure not to change the commit ID.
In order to have your change accepted into the Substratum repos, it will need to be reviewed by Substratum team members and members of the community. The following members have global merge rights and can review patches across all repos:
All of the team will check Gerrit periodically but Ivan, Nathan, Nick, and Surge are more active so adding one of them will give your patch a higher chance of getting merged quicker. They will assign your patch with a review, the meaning of which can be viewed here and here.
Be sure you know how to build the Substratum APK before attempting this.
Go to the Substratum repo and click on the fork button then select where you want the fork to reside.
git add -A
git commit
Always make sure to make the commit message as detailed as possible. Also be sure to keep authorship intact if you had to manually add someone else's work.
If you haven't committed the change yet:
git commit --author="Name <email>"
If you have committed the change
git commit --amend --author="Name <email>"
- Go to the Substratum repo page and click on the "New pull request" button.
- Click the blue "compare across forks" text.
- Find your fork in the list.
- If you need to comment on your changes further than the commit message does, add them to this text.
- Submit the pull request
We cannot promise that every change will be merged but we will evaluate the changes that are pushed in a fair manner. Theme template changes can be submitted in the same manner as the Substratum app.
If you would like to discuss development with us in depth, please reach out using the information in the main README to join our Slack.