Invocables¶
Invocables exist as a way to setup the EDK2 environment in a consistent way such that any script could be run in the context of a UEFI environment. The base_abstract_invocable describes the necessities of the EDK2 environment, to be provided by the user however they wish. Built on top of that, edk2_invocable is an attempt to do as much parsing and setup for the user as possible to minimize the requirements of individual invocable scripts.
To kick off a script, just Invoke().
base_abstract_invocable¶
example: Sample_InvocableHelloWorld.py
provided functions¶
Invoke¶
Main function. Parses command line options, configures logging, bootstraps environment, loads plugins, and finally calls Go.
ConfigureLogging¶
Sets up logging using information from GetWorkspaceRoot, GetLoggingLevel, GetLoggingFileName, and GetLoggingFolderRelativeToRoot.
abstract functions¶
ParseCommandLineOptions is your opportunity to use argparser or look at sys.argv before kicking off setup. If the environment isn't meant to be verifiable (maybe this script involves setting up or unpacking the environment), GetVerifyCheckRequired can return False to bypass that step. After that, GetWorkspaceRoot and GetActiveScopes is used to get the necessary information about the environment and set everything up. Go will be called after all that setup.
Note: logging before ConfigureLogging gets called causes logging to be setup twice (once implicitly by calling it early and then again by ConfigureLogging) and you will see duplicate messages in your console. To avoid this, do not log in ParseCommandLineOptions, GetLoggingLevel, GetWorkspaceRoot, GetLoggingFolderRelativeToRoot, or GetLoggingFileName. If you must have output, use print() or log another way.
edk2_invocable¶
Example: edk2toolext\invocables\edk2_update.py
Basically just base_abstract_invocable + settings parsing.
functions¶
ParseCommandLineOptions¶
This is implemented for the user. It requires a Python settings file be provided. After importing the settings file,
another argparser is created, which is passed to the invoking script and to the settings file. Additionally, key value
pairs in the format KEY=VALUE
will be read into the build environment, accessible by calling
shell_environment.GetBuildVars().GetValue(KEY)
. For example, to skip loading the compiler plugin, pass
CompilerPlugin=skip
as an extra argument when calling your script.
GetSettingsClass¶
This must provide a Python class that edk2_invocable can expect to find instantiated by your settings script.
multi inheritance¶
Example: NXP
In Python it is allowed and it will be helpful for you as long as you don't try to get too creative with it. GetActiveScopes, GetWorkspaceRoot, AddCommandLineOptions, RetrieveCommandLineOptions are required to be in each Settings class. Using a platform as an example, PlatformSetup, Update, and PlatformBuild all require settings classes, but they can all be provided by the same implementation with multi-inherence. The caveat is that you will not know which parent class is invoking you. If that is required, it will be necessary to break that settings class out into it's own class. It is also worth noting that multiple classes can live in the same file and the correct one will still be located by the loading logic.
In the PlatformBuild scenario, it is even possible to have UefiBuilder, UpdateSettingsManager, SetupSettingsManager, and BuildSettingsManager all in one class.