For the migration of the internal Gradle runner, I'm running into trouble with the Preferences class.
Problem description
Currently Preferences is tightly coupled with the PDE through the use of the Base, Messages, Toolkit and Language classes. These classes do not operate outside of the PDE, thus not allowing reuse of the Preferences class in other modules within Processing (e.g. Gradle plugins, Processing CLI, Processing pre-processor, etc.)
Proposed solution
Migrate the Preferences class to a standalone version.
- Completing the migration of Preferences to be standalone from
:app by moving it to a :app:utils module.
- Move functionality dependent on
:app into a AppPreferences class or into other relevant areas of the PDE
- Adding callback events/listeners when a preference changes
- Tests that will declare and test the functionality of
Preferences, a few of the top of my head would be:
- Test if the defaults are loaded and saved without creating changes
- Test if
\ work
- Test if the preferences file is created if it does not yet exist
- Any other tests to make sure we have backwards compatibility
- A Github Action that will run the Tests on all supported platforms
- Bonus: Removing the dependency on
core
Steps taken so far
- In IntelliJ IDEA create a new module
utils in the app folder with the following settings (see image below)
- Add package
processing.utils to the newly created module
- Refactoring the class by right clicking the
Prefrences class and Refactor -> Move Class... and moving it to the newly created processing.utils package

For the migration of the internal Gradle runner, I'm running into trouble with the
Preferencesclass.Problem description
Currently
Preferencesis tightly coupled with the PDE through the use of theBase,Messages,ToolkitandLanguageclasses. These classes do not operate outside of the PDE, thus not allowing reuse of thePreferencesclass in other modules within Processing (e.g. Gradle plugins, Processing CLI, Processing pre-processor, etc.)Proposed solution
Migrate the
Preferencesclass to a standalone version.:appby moving it to a:app:utilsmodule.:appinto aAppPreferencesclass or into other relevant areas of the PDEPreferences, a few of the top of my head would be:\workcoreSteps taken so far
utilsin theappfolder with the following settings (see image below)processing.utilsto the newly created modulePrefrencesclass andRefactor -> Move Class...and moving it to the newly createdprocessing.utilspackage