mirror of
https://github.com/ByteWelder/Tactility.git
synced 2026-02-18 19:03:16 +00:00
## New
- Read property files with `PropertiesFile`
- Support `boot.properties` so the user can specify the launcher app and an optional app to start after the launcher finishes. (see `BootProperties.cpp`)
- Create registry for CPU affinity and update code to make use of it
- `AppRegistration` and `ServiceRegistration` now also ensure that the `/data` directories always exist for all apps
- `Notes` is now the default app for opening text files. `TextViewer` is removed entirely. Created `tt::app:🎶:start(path)` function.
- WiFi settings moved from NVS to properties file.
- Specify `*.ap.properties` file on the SD card for automatic WiFi settings import on start-up.
- Added `file::getLock(path)` and `file::withLock(path, function)` to do safe file operations on SD cards
## Improvements
- Update TinyUSB to `1.7.6~1`
- Improved `Boot.cpp` code. General code quality fixes and some restructuring to improve readability.
- `tt::string` functionality improvements
- Rename `AppRegistry` to `AppRegistration`
- Rename `ServiceRegistry` to `ServiceRegistration`
- Cleanup in `Notes.cpp`
- `FileTest.cpp` fix for PC
- Created `TestFile` helper class for tests, which automatically deletes files after the test.
- Renamed `Partitions.h` to `MountPoints.h`
- Created `std::string getMountPoints()` function for easy re-use
- Other code quality improvements
- `SdCardDevice`'s `getState()` and `isMounted()` now have a timeout argument
## Fixes
- ELF loading now has a lock so to avoid a bug when 2 ELF apps are loaded in parallel
44 lines
1.2 KiB
C
44 lines
1.2 KiB
C
#pragma once
|
|
|
|
#include "tt_app_manifest.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef void* AppHandle;
|
|
|
|
/** @return the bundle that belongs to this application, or null if it wasn't started with parameters. */
|
|
BundleHandle _Nullable tt_app_get_parameters(AppHandle handle);
|
|
|
|
/**
|
|
* Set the result before closing an app.
|
|
* The result and bundle are passed along to the app that launched this app, when this app is closed.
|
|
* @param[in] handle the app context handle to set the result for
|
|
* @param[in] result the result state to set
|
|
* @param[in] bundle the result bundle to set
|
|
*/
|
|
void tt_app_set_result(AppHandle handle, AppResult result, BundleHandle _Nullable bundle);
|
|
|
|
/** @return true if a result was set for this app context */
|
|
bool tt_app_has_result(AppHandle handle);
|
|
|
|
/**
|
|
* Start an app by id.
|
|
* @param[in] appId the app manifest id
|
|
*/
|
|
void tt_app_start(const char* appId);
|
|
|
|
/** Stop the currently running app */
|
|
void tt_app_stop();
|
|
|
|
/**
|
|
* Start an app by id and bundle.
|
|
* @param[in] appId the app manifest id
|
|
* @param[in] parameters the parameters to pass onto the starting app
|
|
*/
|
|
void tt_app_start_with_bundle(const char* appId, BundleHandle parameters);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif |