A place for discussing all apps in general + anything else you want to say.
- This general discussion repository is used for bugs and suggestions that affect multiple apps. For issues affecting only 1 app, use its separate repository.
- If you are reporting a bug, provide steps for reproducing, and mention your app and OS version.
- Ensure you use the latest app version and read the in-app FAQ before reporting anything.
- Check if the issue has already been reported. Use search with some keywords.
- If the feature request is already reported, give it a "👍" to increase its priority and please avoid comments like
+1
orI need this too!
as they do not add anything useful. - If the bug is already reported and has
needs triage
and/ordevice/software specific
labels, write a comment mentioning your device model and OS version. Any additional information like reproduction steps or screenshots will be greatly appreciated. - Please make sure to report your issue in English only, it'll be ignored otherwise. You can use translators if you need to.
- Every project contains a
.editorconfig
file, with definitions of required indentations, newlines, etc. - Always format the code (
Ctrl + Alt + L
) and optimize imports (Ctrl + Alt + O
) before creating a pull request. - If you add a new icon, make sure it is prefixed with "ic_", it is white, and try using vectors.
- If you change something in the UI, test the visibility with all themes, including Black & White and System default (Material You) on Android 12+. Test the changes by using the biggest system font size too.
- Use the existing code style and naming conventions; do not bring your own style.
- Always use brackets, even at 1 liner "if", "return" or "continue" statements, etc.
- If you add a new model or work with Gson, test the build in release mode with Proguard enabled as well.
- There is no real functionality change between build flavors, only some About button visibility differences, Rate Us dialog, and More Apps From Us buttons not showing up or so.
If you try fixing a bug or adding a new feature, make sure that it is already reported at the given repository and the report is open without label needs triage
. If the given issue is closed or still has needs triage
label, your pull request will likely be rejected. The only exceptions are critical bugs that we weren't able to classify yet.
Creating pull requests with some changes is a lot simpler than most people think. Most suggestions are related to translating strings, there are 2 ways to do it.
You can find our apps on Weblate at https://hosted.weblate.org/projects/fossify/, you can see untranslated strings there easily.
However, if you prefer the old-style file updating via Github, you can still do it. The process is the following:
- Log in to GitHub.
- Find the file with the strings (
app/src/main/res/values(-xx)/strings
, for example, the Italian translation of the Gallery is at https://github.com/FossifyOrg/Gallery/blob/master/app/src/main/res/values-it/strings.xml). - Click the pencil button at the top right corner of the file.
- Edit the file with your suggestions.
- Add a commit message under the file, to the text field which has a hint similar to "Update strings.xml". Just type in what you have done, for example, "updating Spanish strings".
- Click
Propose file change
. - Click the green button
Create pull request
. - Thank yourself!
- Change only the string which is between ">" and
</string>
, not the first one after the "name=" tag, also not the strings between<!--
and-->
. - Please escape apostrophes, meaning you have to put a backslash before every apostrophe to make it look like: \'
To find the proper language file at the Gallery, go to https://github.com/FossifyOrg/Gallery/blob/master/app/src/main/res, then look for a "values-[language code]" folder. Use the strings.xml
file inside it. If you can't find your language code, the file might not be translated to your language at all yet, and you will have to create a whole new file.
You will most likely want to add a new file only if you translate an app into a new language. Doing it is actually not difficult at all, just read on.
- Log in to GitHub.
- Find the place where the new file belongs. If it's really a translation of the strings in a new language, go to
app/src/main/res
, for example https://github.com/FossifyOrg/Camera/tree/master/app/src/main/res. - At the top right corner click at
Create new file
. - After the
res
folder, you can type in your folder path. For creating a German translation just type invalues-de/
(wherede
is the country code). The new folder will be added automatically after typing the slash. - Add a file name, i.e.,
strings.xml
(the path should look similar to the image below) - Copy the contents of an already existing
strings.xml
file into the new file (for example, the content of https://github.com/FossifyOrg/Camera/blob/master/app/src/main/res/values/strings.xml). - Add your string translations.
- Add a commit message under the file, to the text field which has a "Create new file" hint. Just type in what you have done, for example, "adding Spanish strings".
- Press
Propose new file
. - Click the green button
Create pull request
. - Thank yourself!
- Change only the string which is between ">" and
</string>
, not the first one after the "name=" tag. - Please escape apostrophes, meaning you have to put a backslash before every apostrophe to make it look like: \'