mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-30 16:56:41 +03:00
a91d319839
* scripts: moved ufbt code * ufbt: fixed tool path * ufbt: fixed linter/formatter target descriptions * scripts: ufbt: cleanup * fbt: moved fap launch target to tools; ufbt fixes * fbt: fixed missing headers from SDK * ufbt: removed debug output * ufbt: moved project template to main codebase * ufbt: fixed vscode_dist * ufbt: path naming changes * fbt: error message for older ufbt versions * ufbt: docs fixes * ufbt: fixed build dir location * fbt: fixes for extapps objcopy * fbt: extapps: removed extra debug output; fixed formatting * ufbt: handle launch target for multiple known apps * ufbt: dropping wrapper; linter fixes * ufbt: fixed boostrap path * ufbt: renamed entrypoint * ufbt: updated vscode config * ufbt: moved sconsign db location * ufbt: fixed sconsign path * fbt: SDK builders rework * fbt: reworked sdk packaging * ufbt: additional checks and state processing * ufbt: fixed sdk state file location * dist: not packaging pycache * dump commit json content * Github: more workflow debug prints * Github: fix incorrect commit meta extraction in get_env.py * ufbt, fbt: changed SConsEnvironmentError->StopError * fbtenv: no longer needs SCRIPT_PATH pre-set * ufbt: fixed sdk state check * scripts: exception fixes for storage.py * scripts: fbtenv: added FBT_TOOLCHAIN_PATH for on Windows for compat * ufbt: app template: creating .gitkeep for images folder * ufbt: app template: fixed .gitkeep creation * docs: formatting fixes for AppManifests; added link to ufbt * fbt: added link to PyPI for old ufbt versions * sdk: fixed dir component paths Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
159 lines
3.9 KiB
Plaintext
159 lines
3.9 KiB
Plaintext
from dataclasses import dataclass, field
|
|
from os.path import dirname
|
|
|
|
from SCons.Node import NodeList
|
|
from SCons.Warnings import warn, WarningOnByDefault
|
|
from SCons.Errors import UserError
|
|
|
|
Import("ENV")
|
|
|
|
from fbt.appmanifest import FlipperAppType
|
|
|
|
appenv = ENV["APPENV"] = ENV.Clone(
|
|
tools=[
|
|
"fbt_extapps",
|
|
"fbt_assets",
|
|
"fbt_sdk",
|
|
],
|
|
RESOURCES_ROOT=ENV.Dir("#/assets/resources"),
|
|
)
|
|
|
|
appenv.Replace(
|
|
LINKER_SCRIPT_PATH=appenv["APP_LINKER_SCRIPT_PATH"],
|
|
)
|
|
|
|
appenv.AppendUnique(
|
|
CCFLAGS=[
|
|
"-ggdb3",
|
|
"-mword-relocations",
|
|
"-mlong-calls",
|
|
"-fno-common",
|
|
"-nostdlib",
|
|
"-fvisibility=hidden",
|
|
],
|
|
LINKFLAGS=[
|
|
"-Ur",
|
|
"-Wl,-Ur",
|
|
# "-Wl,--orphan-handling=error",
|
|
"-Bsymbolic",
|
|
"-nostartfiles",
|
|
"-mlong-calls",
|
|
"-fno-common",
|
|
"-nostdlib",
|
|
"-Wl,--gc-sections",
|
|
"-Wl,--no-export-dynamic",
|
|
"-fvisibility=hidden",
|
|
"-Wl,-e${APP_ENTRY}",
|
|
"-Xlinker",
|
|
"-Map=${TARGET}.map",
|
|
"-specs=nano.specs",
|
|
"-specs=nosys.specs",
|
|
],
|
|
LIBS=[
|
|
"m",
|
|
"gcc",
|
|
"stdc++",
|
|
"supc++",
|
|
],
|
|
)
|
|
|
|
|
|
@dataclass
|
|
class FlipperExtAppBuildArtifacts:
|
|
application_map: dict = field(default_factory=dict)
|
|
resources_dist: NodeList = field(default_factory=NodeList)
|
|
sdk_tree: NodeList = field(default_factory=NodeList)
|
|
|
|
|
|
apps_to_build_as_faps = [
|
|
FlipperAppType.PLUGIN,
|
|
FlipperAppType.EXTERNAL,
|
|
FlipperAppType.DEBUG,
|
|
]
|
|
|
|
known_extapps = [
|
|
app
|
|
for apptype in apps_to_build_as_faps
|
|
for app in appenv["APPBUILD"].get_apps_of_type(apptype, True)
|
|
]
|
|
|
|
# Ugly access to global option
|
|
if extra_app_list := GetOption("extra_ext_apps"):
|
|
known_extapps.extend(map(appenv["APPMGR"].get, extra_app_list.split(",")))
|
|
|
|
incompatible_apps = []
|
|
for app in known_extapps:
|
|
if not app.supports_hardware_target(appenv.subst("f${TARGET_HW}")):
|
|
incompatible_apps.append(app)
|
|
continue
|
|
|
|
appenv.BuildAppElf(app)
|
|
|
|
extapps = FlipperExtAppBuildArtifacts()
|
|
extapps.application_map = appenv["EXT_APPS"]
|
|
|
|
if incompatible_apps:
|
|
warn(
|
|
WarningOnByDefault,
|
|
f"Skipping build of {len(incompatible_apps)} incompatible app(s): "
|
|
+ ", ".join(f"'{app.name}' (id '{app.appid}')" for app in incompatible_apps),
|
|
)
|
|
|
|
if appenv["FORCE"]:
|
|
appenv.AlwaysBuild(
|
|
list(app_artifact.compact for app_artifact in extapps.application_map.values())
|
|
)
|
|
|
|
|
|
Alias(
|
|
"faps",
|
|
list(app_artifact.validator for app_artifact in extapps.application_map.values()),
|
|
)
|
|
|
|
extapps.resources_dist = appenv.FapDist(appenv["RESOURCES_ROOT"], [])
|
|
|
|
|
|
if appsrc := appenv.subst("$APPSRC"):
|
|
appenv.AddAppLaunchTarget(appsrc, "launch_app")
|
|
|
|
|
|
# SDK management
|
|
|
|
amalgamated_api = "${BUILD_DIR}/sdk_origin"
|
|
sdk_source = appenv.ApiAmalgamator(
|
|
amalgamated_api,
|
|
# Deps on root SDK headers and generated files
|
|
(appenv["SDK_HEADERS"], appenv["FW_ASSETS_HEADERS"]),
|
|
)
|
|
# Extra deps on headers included in deeper levels
|
|
# Available on second and subsequent builds
|
|
Depends(sdk_source, appenv.ProcessSdkDepends(f"{amalgamated_api}.d"))
|
|
|
|
appenv["SDK_DIR"] = appenv.Dir("${BUILD_DIR}/sdk_headers")
|
|
sdk_header_tree = appenv.SDKHeaderTreeExtractor(appenv["SDK_DIR"], amalgamated_api)
|
|
# AlwaysBuild(sdk_tree)
|
|
Alias("sdk_tree", sdk_header_tree)
|
|
extapps.sdk_tree = sdk_header_tree
|
|
|
|
api_check = appenv.ApiTableValidator(appenv["SDK_DEFINITION"], amalgamated_api)
|
|
Precious(api_check)
|
|
NoClean(api_check)
|
|
AlwaysBuild(api_check)
|
|
Alias("api_check", api_check)
|
|
|
|
firmware_apitable = appenv.ApiSymbolTable(
|
|
"${BUILD_DIR}/assets/compiled/firmware_api_table.h", appenv["SDK_DEFINITION"]
|
|
)
|
|
Alias("api_table", firmware_apitable)
|
|
ENV.Replace(
|
|
FW_API_TABLE=firmware_apitable,
|
|
_APP_ICONS=appenv["_APP_ICONS"],
|
|
)
|
|
|
|
|
|
if appenv["FORCE"]:
|
|
appenv.AlwaysBuild(sdk_source, sdk_header_tree, api_check, firmware_apitable)
|
|
|
|
|
|
Return("extapps")
|