Skip to content

Settings API

Andy Williams edited this page Jul 24, 2019 · 20 revisions

To provide a clean and consistent API for settings and storage we need to be clear about what is application local (user preferences) vs global (system settings). Also some things can be set by environment variables to override settings.

App.UniqueID

For the sections below about app storage we will require a App.UniqueID which will have to be set through a new constructor or directly on the app instance. Global settings can function without this addition. This could be added without breaking the existing API and helpful errors can indicate when storage functions are used without an appropriate identifier set.

App.Preferences

A key value store of preferences for an application.

Get(key):value

Access a user configuration that was stored previously.

Set(key, value)

Allows an application to store a user configuration for later access.

Additional methods to follow...

Typed versions (like GetFloat or SetBool) could improve the API.

We should support complex types as well - see JSON or XML marshalling for potential inspiration.

App.SecurePreferences

A proposed extension would allow encrypted storage of application secret preferences.

App.Documents

A place where an application can store user documents - within the standard user documents directory. This will usually be a simple filesystem abstraction but may vary across different platforms.

Create

Create a new (empty) document with a simple string identifier (like filename).

Load

Load an existing document from it's identifier. Will error if the document does not exist.

Remove

Delete a named document from the storage.

List

Return a list of available documents for the given application.

App.Cache

The correct location to cache documents or assets that you don't want to keep in memory.

Save

Create a new cache entry with specified name and content.

Load

Get the content of a named cache entry.

Remove

Clear the content of a named cache entry.


Merged for 1.2

The items in this section have been implemented

fyne.Settings

The settings API for fyne provides information about global values. These can be configured by the user of a system. Some of these values can be overridden by the application.

Theme

The user can set their preferred theme that will apply to applications if they don't override.

It can be overridden by the user with FYNE_THEME. It can also be set by the application if the developer wants to use a custom theme.

AddChangeListener

An application can listen to changes in global settings. This will occur if a user changes their settings like by using the fyne_settings helper.

Welcome to the Fyne wiki.

Project documentation

Getting involved

Platform details

Clone this wiki locally