mirror of
https://github.com/Next-Flip/Momentum-Firmware.git
synced 2026-04-24 03:29:57 -07:00
Make settings menus external -21.7kb DFU
This commit is contained in:
@@ -248,7 +248,6 @@ class AppBuildset:
|
||||
FlipperAppType.APP,
|
||||
FlipperAppType.DEBUG,
|
||||
FlipperAppType.ARCHIVE,
|
||||
FlipperAppType.SETTINGS,
|
||||
FlipperAppType.STARTUP,
|
||||
)
|
||||
EXTERNAL_APP_TYPES_MAP = {
|
||||
@@ -257,6 +256,7 @@ class AppBuildset:
|
||||
FlipperAppType.PLUGIN: True,
|
||||
FlipperAppType.DEBUG: True,
|
||||
FlipperAppType.MENUEXTERNAL: False,
|
||||
FlipperAppType.SETTINGS: False,
|
||||
}
|
||||
|
||||
@classmethod
|
||||
|
||||
@@ -23,20 +23,22 @@ class ApplicationsCGenerator:
|
||||
FlipperAppType.SYSTEM: ("FlipperInternalApplication", "FLIPPER_SYSTEM_APPS"),
|
||||
FlipperAppType.APP: ("FlipperInternalApplication", "FLIPPER_APPS"),
|
||||
FlipperAppType.DEBUG: ("FlipperInternalApplication", "FLIPPER_DEBUG_APPS"),
|
||||
FlipperAppType.SETTINGS: (
|
||||
"FlipperInternalApplication",
|
||||
"FLIPPER_SETTINGS_APPS",
|
||||
),
|
||||
FlipperAppType.STARTUP: (
|
||||
"FlipperInternalOnStartHook",
|
||||
"FLIPPER_ON_SYSTEM_START",
|
||||
),
|
||||
}
|
||||
|
||||
APP_EXTERNAL_TYPE = (
|
||||
"FlipperExternalApplication",
|
||||
"FLIPPER_EXTERNAL_APPS",
|
||||
)
|
||||
EXTERNAL_TYPE_MAP = {
|
||||
FlipperAppType.MENUEXTERNAL: (
|
||||
"FlipperExternalApplication",
|
||||
"FLIPPER_EXTERNAL_APPS",
|
||||
),
|
||||
FlipperAppType.SETTINGS: (
|
||||
"FlipperExternalApplication",
|
||||
"FLIPPER_SETTINGS_APPS",
|
||||
),
|
||||
}
|
||||
|
||||
def __init__(self, buildset: AppBuildset, autorun_app: str = ""):
|
||||
self.buildset = buildset
|
||||
@@ -100,12 +102,15 @@ class ApplicationsCGenerator:
|
||||
]
|
||||
)
|
||||
|
||||
entry_type, entry_block = self.APP_EXTERNAL_TYPE
|
||||
external_apps = self.buildset.get_apps_of_type(FlipperAppType.MENUEXTERNAL)
|
||||
contents.append(f"const {entry_type} {entry_block}[] = {{")
|
||||
contents.append(",\n".join(map(self.get_external_app_descr, external_apps)))
|
||||
contents.append("};")
|
||||
contents.append(f"const size_t {entry_block}_COUNT = COUNT_OF({entry_block});")
|
||||
for apptype in self.EXTERNAL_TYPE_MAP:
|
||||
entry_type, entry_block = self.EXTERNAL_TYPE_MAP[apptype]
|
||||
external_apps = self.buildset.get_apps_of_type(apptype)
|
||||
contents.append(f"const {entry_type} {entry_block}[] = {{")
|
||||
contents.append(",\n".join(map(self.get_external_app_descr, external_apps)))
|
||||
contents.append("};")
|
||||
contents.append(
|
||||
f"const size_t {entry_block}_COUNT = COUNT_OF({entry_block});"
|
||||
)
|
||||
|
||||
return "\n".join(contents)
|
||||
|
||||
|
||||
@@ -488,6 +488,7 @@ def _gather_app_components(env, appname) -> AppDeploymentComponents:
|
||||
if host_app.apptype in [
|
||||
FlipperAppType.EXTERNAL,
|
||||
FlipperAppType.MENUEXTERNAL,
|
||||
FlipperAppType.SETTINGS,
|
||||
]:
|
||||
components.add_app(host_app)
|
||||
else:
|
||||
|
||||
@@ -232,6 +232,7 @@ apps_to_build_as_faps = [
|
||||
FlipperAppType.PLUGIN,
|
||||
FlipperAppType.EXTERNAL,
|
||||
FlipperAppType.MENUEXTERNAL,
|
||||
FlipperAppType.SETTINGS,
|
||||
]
|
||||
|
||||
known_extapps = [
|
||||
|
||||
Reference in New Issue
Block a user