tianocore / edk2-edkrepo Goto Github PK
View Code? Open in Web Editor NEWRepository for the edkrepo utility
License: Other
Repository for the edkrepo utility
License: Other
If you have two combo ("combo_A" and "combo_B"), both with sparseCheckout="true" on a remote repo ("repo"), but there is a section defined for "combo_A", and a global section used by all combo, the following two cases can happen:
While on "combo_A", running "edkrepo checkout combo_B" will not run the "Resetting sparse checkout state..." step and "Performing sparse checkout..." step.
While on "combo_B", running "edkrepo checkout combo_A" will not run the "Resetting sparse checkout state..." step and "Performing sparse checkout..." step.
-workaround: calling "edkrepo sync" after the 'checkout' command will reset to correct sparse checkout settings.
While on "combo_A", running "edkrepo checkout combo_A" will always cause the "Resetting sparse checkout state..." step and "Performing sparse checkout..." step to be run.
-workaround: none. this just makes the edkrepo checkout command take longer.
test environment: edkrepo 3.1.0, Python 3.8.10, git 2.39.1.windows.1, Windows 11.
There is a unicode character \u200b (Zero width space) because of which there are errors in running f2f-cherry-pick. The other commands are running fine. So, the issue is with some file related to f2f-cherry-pick.
For better organization sync command specific strings should be removed from the common string location
https://peps.python.org/pep-0008/#maximum-line-length
There may be areas in the code where some lines are of a very long length (>120 characters). Propose shortening them by breaking into multiple lines via the following protocol:
Please submit one PR with one commit for each of the following categories:
In the sync -u flow the repo source tuples for the initial and new sources are compared. Items that are acceptable to change such as branch, sparse checkout status, etc... are used in this calculation causing the source to be erroneously identified as different and raising a manifest changed exception
Brief: Introduce more kwargs option in "edkrepo log" command
Command "edkrepo log" is defined under:
It retrieve commit messages through gitpython module called under:
The API being used from gitpython is Repo.iter_commits()
Hence iter_commits could accept more argument such as:
Feature request:
when running edkrepo sync -u
and there is a change in the cloned repository list, the most recent version of EdkRepo prints:
Failed to update manifest.
Without any additional information. When running edkrepo sync -uv
you get the following additional message:
The latest manifest for project, <project_name>, requires a change in currently cloned repositories.
To complete this operation please rerun the command with the --override flag
Exiting without performing sync operations.
Failed to update manifest.
This message should not be gated by --verbose
EdkRepo must provide a set of common methods for configuring and working with Python virtual environments as defined in project manifest files.
This is a pre-requisite for completing #60
When using just the name of a pin file it is unable to be located in the global manifest repo. In this case .xml must be appended to the name to properly locate the file.
The manifest parser must support listing a PatchSet in the
<Combination> <Source localRoot=" remote='' (branch|commit|tag) or patchSet='' /> </Combination>
The support for branch/commit/tags and patchSets must be mutually exclusive; if both are present then parsing must fail.
This issue depends on the completion of #73
Create a PatchSet or two that reference a git branch name as the parentSha.
e.g. the "master" branch of the Tianocore Edk2 repo:
<PatchSet remote="Edk2Repo" name="edk2_test_B" parentSha="edk2_test_A" fetchBranch="master">
</PatchSet>
<PatchSet remote="Edk2Repo" name="edk2_test_A" parentSha="master" fetchBranch="master">
</PatchSet>
When using these PatchSet as part of a combination, if there is not a 'tag' on the repo that conflicts with the 'branch' name, then the PatchSet will use the branch as the base of the Dynamic Branch Creation PatchSet branch.
Expected result:
PatchSet were proposed to report an error and revert to previous combo if the base parentSha is not a 'tag' or a commit 'SHA', since no way to guarantee a PatchSet can apply without a merge error to a changing Branch codebase.
Test system: edkrepo 3.1.0, python 3.8.8, Windows 11
On Windows 11, in the "C:\ProgramData\edkrepo" folder, delete the "edk2-edkrepo-manifest-main" manifest-repo folder if it has already been cloned before.
Run a Command Prompt as Administrator, and run "edkrepo manifest". A new "Cloning global manifest repository" will occur.
"Cloning global manifest repository to: C:\ProgramData\edkrepo\edk2-edkrepo-manifest-main from: https://github.com/tianocore/edk2-edkrepo-manifest.git"
Run a Command Prompt as a non-Administrator, and run "edkrepo manifest". "edkrepo manifest" command fails with the following error:
"""
The git command: git remote get-url --all origin failed to complete successfully with the following errors.
stderr: 'fatal: detected dubious ownership in repository at 'C:/ProgramData/edkrepo/edk2-edkrepo-manifest-main'
'C:/ProgramData/edkrepo/edk2-edkrepo-manifest-main' is owned by:
'S-1-5-32-544'
but the current user is:
'S-1-5-21-725345543-602162358-527237240-2219279'
To add an exception for this directory, call:
git config --global --add safe.directory C:/ProgramData/edkrepo/edk2-edkrepo-manifest-main'
"""
Workaround:
In the "C:\ProgramData\edkrepo" folder, delete the "edk2-edkrepo-manifest-main" manifest-repo folder, then run "edkrepo manifest" from a non-Administrator Command Prompt to cause the "Cloning global manifest repository" to occur again. After this, both Administrator Command Prompt and non-Administrator Command Prompt can run "edkrepo manifest".
test system configuration:
edkrepo 3.1.0, Python 3.8.10, git version 2.39.1.windows.1, Windows 11
All prints in the f2f-cherry-pick command should be updated to use the new print methods defined in common/ui_functions.py
checkout combo with PatchSet failure does not revert to previous combo
Steps to reproduce:
Clone the Intel-MinPlatform edkrepo project.
Modify the /repo/Manifest.xml file to add a new local combination with an invalid PatchSet.
Example below reverts the same commit twice in a row.
<PatchSets>
<PatchSet remote="Edk2Repo" name="edk2_negative_test" parentSha="edk2-stable202302" fetchBranch="master">
<Revert sha="f80f052277c88a67c55e107b550f504eeea947d3" />
<Revert sha="f80f052277c88a67c55e107b550f504eeea947d3" />
</PatchSet>
</PatchSets>
<Combination name="negative_test" description="negative patchset test">
<Source localRoot="edk2" remote="Edk2Repo" patchSet="edk2_negative_test" sparseCheckout="true" enableSubmodule="true" />
<Source localRoot="edk2-platforms" remote="Edk2PlatformsRepo" branch="master" sparseCheckout="true" />
<Source localRoot="edk2-non-osi" remote="Edk2NonOsiRepo" branch="master" sparseCheckout="true" />
<Source localRoot="FSP" remote="FspRepo" branch="master" sparseCheckout="false" />
</Combination>
Attempt to checkout the new local "negative_test" combo. The PatchSet failure is detected, but the combo continues to be checked out.
"""
Failed to revert to the commit f80f052277c88a67c55e107b550f504eeea947d3
Failed to apply one of the patchset operations. Checking out back to the default branch
Checking out master branch for edk2-platforms repo ...
Checking out master branch for edk2-non-osi repo ...
Checking out master branch for FSP repo ...
"""
Expected result: a detected bad PatchSet failure should be treated as a checkout combo failure, and trigger a revert to the previous checkout combo, or to the default combo if no previous combo.
test system:
edkrepo 3.1.0, Python 3.8.10, git version 2.39.1.windows.1, Windows 11
edkrepo manifest file Combination and PatchSet can include git tag information, but "edkrepo sync" does not detect or notify user if tags locally and tags on the Remote have somehow deviated from each other.
In some other cases, "edkrepo sync" and "edkrepo sync --fetch" may not create all the same local tags as a fresh 'edkrepo clone' will.
Manually running 'git fetch --tags' on each of the repo seems to work as a workaround for both cases.
edkrepo 3.1.0, git version 2.39.1.windows.1
https://peps.python.org/pep-0008/#blank-lines
Ensure all code in edkrepo fits the following criteria:
In short, all classes should have 2 blank lines surrounding them, all global level functions should have 2 blank lines surrounding them, and all methods inside of a class should have 1 blank line surrounding them.
Please submit one PR with one commit for each of the following categories:
The manifest parser must provide a method get_patchsets_for_combo(combo_name)
which returns a dictionary with the key being the source.name for the Source listing the patchset and the value being a PatchSet Tuple
Add "edkrepo clean" support for "-ff" option.
"git clean" supports "-f" and "-ff".
https://git-scm.com/docs/git-clean
"Git will refuse to modify untracked nested git repositories (directories with a .git subdirectory) unless a second -f is given."
With edkrepo 3.1.1, "edkrepo clean" does not error when "-ff" is used, but only supports the behavior of "-f".
Create a Combination that uses enableSubmodule on newer edk2 stable tag.
<Source localRoot="Edk2" remote="Edk2Repo" tag="edk2-stable202305" enableSubmodule="true" />
Manually checkout older Edk2 stable tag.
git checkout edk2-stable202105
git status
Untracked files:
(use "git add <file>..." to include in what will be committed)
MdePkg/Library/BaseFdtLib/
MdePkg/Library/MipiSysTLib/
UnitTestFrameworkPkg/Library/GoogleTestLib/
UnitTestFrameworkPkg/Library/SubhookLib/
"edkrepo clean -ffd" runs, but does not remove Untracked files.
"git clean -ffd" runs, and removes Untracked files.
EdkRepo Sync has heuristics to detect the scenario where changes in the remote branch layout can cause errors when fetching all branches. For example, if one changes a branch name from refs/heads/a/b/c to refs/heads/a/b/c/d, then "c" changes from a file to a directory. This will cause the following error when running fetch:
error: cannot lock ref 'refs/remotes/origin/a/b/c/d': 'refs/remotes/origin/a/b/c' exists; cannot create 'refs/remotes/origin/a/b/c/d'
This change adds an additional heuristic that triggers the automatic
remote prune for the case of "error: cannot lock ref". This should catch more cases of the problem above.
checkout_repos() added one parameter: global_manifest_path
On Windows 11 with Python 3.7.9 installed, followed the build steps in the readme.md
py -3 -m pip install wheel
cd build-scripts
build_windows_installer.bat
cd ..
py -3 setup.py install
edkrepo commands fail with the error:
The system cannot find the file C:\windows\edkrepo.exe.
Running the generated "dist/EdkRepoSetup-3.1.0.0.exe" file fails with:
"""
Found Python 3.7.9
Error: Python version 3.8.8 or later is required to run EdkRepo. Please install it before continuing.
Installation Failed.
"""
If edkrepo is going to say it has Python 3.5 and later support on Windows, need one of the install methods such as the install from source steps to work for Python 3.7.9.
During an "edkrepo sync --update-local-manifest" call, the dynamic branch creation json file can be corrupted by the addition of a new branch name row of the currently checked-out dynamic branch being added directly under the first "patch_file" instance in the json file.
example:
"patch_file": [],
"edk2_test1": "edk2_test1_2023/01/27_15_53_34"
This json file corruption leads to two new branches being created during the sync, with the messages:
"Info: A branch with the same name detected. Renaming the old..."
"Info: A branch with the same name detected. Renaming the old..."
After the json file is corrupted, additional "edkrepo checkout [combo]" result in each displaying the message "Info: A branch with the same name detected. Renaming the old..."
Then creates another new dynamic branch, and modifies again the name of the extra branch located under the first "patch_file" instance.
Seen on edkrepo 3.1.0, Python 3.8.10, Windows 11
edkrepo clone [test manifest]
//json file is created with default dynamic branch
edkrepo checkout [test combo]
//json file adds non-default dynamic branch
edkrepo sync --update-local-manifest
//json file corruption occurs
The manifest parser must be updated to support defining and enabling python virtual environments. To do so the following changes must be implemented:
Update the definition of combos to add the venv_enable and venv_cfg_path data. These should be optional. venv_enable should take True or False
<Combination name=""
description= =""
venv_enable=True|False>
<Source localRoot=""
remote=""
branch|tag|sha= =""
sparseCheckout =""
venv_cfg=path to req.txt />
</Combination>
Update the combo and repo source properties as follows:
Combination = namedtuple('Combination', ['name', 'description', ‘venv_enable’])
venv_enable returns True|False If not present in manifest default value is false
RepoSource = namedtuple('RepoSource', ['root', 'remote_name', 'remote_url', 'branch', 'commit', 'sparse', 'enable_submodule', 'tag', 'venv_cfg’]
Can 'edkrepo clean' add support for [-x] as an argument similar to 'git clean [-x]' ?
e.g. 'edkrepo clean -fdx'
If edkrepo is run on manifest files that were designed for newer edkrepo tool versions, the commands could fail entirely, or known bugs could be encountered.
There is not yet a way for a manifest maintainer to notify the manifest consumers about which edkrepo tool version is required to use the latest manifest file version, or notify the manifest consumer if the version will change (e.g. if a newer Manifest update will included a combo with a multi-patch daisy-chained PatchSet, I want the manifest file to enforce a minimum edkrepo tool version of 3.1.1)
I request an optional MinimumEdkrepoVersion field in the ProjectInfo section to be able to specify the minimum EdkRepo tool version required to use the current latest Manifest file.
If a user tries 'edkrepo clone', but the manifest MinimumEdkrepoVersion is not met, the clone should notify the user of the minimum EdkRepo version required, and prevent the edkrepo clone.
If a user tried 'edkrepo sync -u', but the new manifest will have a higher MinimumEdkrepoVersion than the local user's EdkRepo tool, then the user should be notified that a new minimum EdkRepo version is required and the local manifest file will not be updated.
"edkrepo checkout" between two combo with similar tags does not update the "HEAD detached at " message for the repo.
Create three tags on a repo, tag_a , tag_b, tag_a2, where tag_a and tag_a2 are associated to the same commit.
Create three Combination in a manifest, combo_a, combo_b, and combo_a2 that use the tags above.
Checkout combo_a , then combo_a2, and check status:
edkrepo checkout combo_a
edkrepo checkout combo_a2
edkrepo status
edkrepo status (and git status) shows "HEAD detached at tag_a", functionally correct, but unexpected for combo_a2.
Checkout combo_a , combo_b, then combo_a2, and check status:
edkrepo checkout combo_a
edkrepo checkout combo_b
edkrepo checkout combo_a2
edkrepo status
edkrepo status (and git status) shows "HEAD detached at tag_a2" as expect for combo_a2.
Similar behavior when running just git commands below:
git checkout tag_a
git checkout tag_a2
git status
Tested on git version 2.39.1.windows.1
EdkRepo should be able to install and run inside a Windows container environment. This requires the following changes:
The definition of manifest repos whether in the edkrepo.cfg or edkrepo_user.cfg file include the repository URL, local directory to be cloned to and the branch to be used as shown below:
[manifest-repos]
edk2-edkrepo-manifest
[edk2-edkrepo-manifest]
URL = https://github.com/tianocore/edk2-edkrepo-manifest.git
Branch = main
LocalPath = edk2-edkrepo-manifest-main
To improve performance and reduce disk usage the clone of the global manifest repository should only include the specified branch. For the above configuration file this could be accomplished using the following git clone command see https://git-scm.com/docs/git-clone:
git clone https://github.com/tianocore/edk2-edkrepo-manifest.git edk2-edkrepo-manifest-main --single-branch --branch main
The method pull_single_manifest_repo() in edk2-edkrepo\edkrepo\common\manifest_repos_maintenance.py should be updated to use the --single-branch and --branch flags to accommodate this.
Title
Installing EdkRepo on Raspberry Pi OS will cause X11 to crash during startup on the next reboot. This causes the desktop environment to become inaccessible.
The root cause for this issue is that the X11 startup script on Raspberry Pi will blindly run all scripts in /etc/profile.d using /bin/sh (which defaults to dash on Raspberry Pi) without any regard for the #! line at the start of the script. This seems like a bug in Raspberry Pi OS.
Attempting to execute the EdkRepo bash completions using dash will result in syntax errors. The reason for this is setting command completions requires one to use the COMREPLY variable, which is required to be an array. Arrays are a bash-specific extension that is not in the POSIX standard, so that syntax will be considered invalid.
Raspberry Pi OS installs a script in /etc/profile.d that will check if the current interpreter is bash and then run the command completion scripts in /usr/share/bash-completion/completions. Therefore, the workaround for this issue is to place the command completion script there. This also has the benefit of bash-completions providing a performance boost by only running completion scripts for the command that is currently being typed by the user.
The generate_pin_etree() method should also include the complete PatchSets section in the pin file.
Additionally the following section should not be based solely on a tag, branch or SHA:
for src_tuple in repo_source_list: if (src_tuple.root is None or src_tuple.remote_name is None or src_tuple.remote_url is None or (src_tuple.commit is None and src_tuple.branch is None and src_tuple.tag is None)): raise ValueError("Invalid input: empty values in source list")
The logic should be:
if (src_tuple.root is None or src_tuple.remote_name is None or src_tuple.remote_url is None or ((src_tuple.commit is None and src_tuple.branch is None and src_tuple.tag is None) and src_tuple.patch_set is None)):
It should also be verified that the src_tuple lists either a (branch, tag and/or SHA) or a PatchSet
The error codes defined in edkrepo_exception.py should be consecutive starting at 100 ex the following:
class EdkrepoWorkspaceCorruptException(EdkrepoException):
def __ini__(self, message):
super().__init__(message, 118)
class EdkrepoWarningException(EdkrepoException):
def __init__(self, message):
super().__init__(message, 123)
class EdkrepoGitException(EdkrepoException):
def __init__(self, message):
super().__init__(message, 129)
Should change to:
class EdkrepoWorkspaceCorruptException(EdkrepoException):
def __ini__(self, message):
super().__init__(message, 118)
class EdkrepoWarningException(EdkrepoException):
def __init__(self, message):
super().__init__(message, 119)
class EdkrepoGitException(EdkrepoException):
def __init__(self, message):
super().__init__(message, 120)
Currently, two PatchSet can be chained together to create a dynamic branch.
If a third or more PatchSet is chained in a row, these PatchSet fail to create a dynamic branch when used, and non-gracefully fails when the PatchSet steps are attempted on the wrong branch or commit.
edkrepo 3.1.0
Add the ability to get the list of repositories that EdkRepo knows about in either human readable text or in machine parseable JSON format.
Found Python 3.11.1
Git Version: 2.39.1
Running git lfs install
Searching for existing EdkRepo installations...
Determining currently installed Python packages...
Uninstalling current version of edkrepo
Version 4.0.0 of package smmap is already installed
Version 4.0.7 of package gitdb is already installed
Version 3.1.14 of package GitPython is already installed
Version 0.4.4 of package colorama is already installed
Installing edkrepo version 3.1.0
Windows directory is in %PATH%.
Creating edkrepo launcher in Git Bash...
Creating python launcher in Git Bash...
Creating python3 launcher in Git Bash...
Installing EdkRepo command completion...
Copied win_edkrepo_prompt.sh
C:\windows\edkrepo.exe
C:\Program Files\Git\etc\profile.d\edkrepo_completions.sh
Traceback (most recent call last):
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_entry_point.py", line 94, in main
return(func())
^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_cli.py", line 161, in main
command = command_factory.create_composite_command()
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 85, in create_composite_command
commands = get_commands()
^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 73, in get_commands
if in_same_module and _is_command(cls[1]):
^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 32, in _is_command
if func[0] == 'get_metadata' and len(inspect.getargspec(func[1])[0]) == 1:
^^^^^^^^^^^^^^^^^^
AttributeError: module 'inspect' has no attribute 'getargspec'
Traceback (most recent call last):
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_entry_point.py", line 94, in main
return(func())
^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_cli.py", line 161, in main
command = command_factory.create_composite_command()
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 85, in create_composite_command
commands = get_commands()
^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 73, in get_commands
if in_same_module and _is_command(cls[1]):
^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 32, in _is_command
if func[0] == 'get_metadata' and len(inspect.getargspec(func[1])[0]) == 1:
^^^^^^^^^^^^^^^^^^
AttributeError: module 'inspect' has no attribute 'getargspec'. Did you mean: 'getargs'?
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "", line 198, in _run_module_as_main
File "", line 88, in run_code
File "C:\windows\edkrepo.exe_main.py", line 7, in
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_entry_point.py", line 99, in main
return edkrepo.edkrepo_cli.main()
^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_cli.py", line 161, in main
command = command_factory.create_composite_command()
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 85, in create_composite_command
commands = get_commands()
^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 73, in get_commands
if in_same_module and _is_command(cls[1]):
^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 32, in _is_command
if func[0] == 'get_metadata' and len(inspect.getargspec(func[1])[0]) == 1:
^^^^^^^^^^^^^^^^^^
AttributeError: module 'inspect' has no attribute 'getargspec'. Did you mean: 'getargs'?
Unable to launch preferred entry point. Launching default entry point edkrepo.edkrepo_cli.py
Installation Error:
System.InvalidOperationException: generate-command-completion-script failed with status 1
at TianoCore.EdkRepoInstaller.InstallWorker.PerformInstall(Action2 ReportComplete, Action
1 ReportProgress, Action1 AllowCancel, Func
1 CancelPending)
at TianoCore.EdkRepoInstaller.ProgressWindow.WorkerThread()
Installation Failed.
https://peps.python.org/pep-0008/#comments
Need to standardize comments throughout the code:
# example comment
print('some code') # example comment
"""docstring"""
"""
docstring
docstring
"""
Please submit one PR with one commit for each of the following categories:
Currently the maintenance command only prints out that it is removing stale include ifs from the git config file.
https://peps.python.org/pep-0008/#imports
We want imports to be strategically separated in the following method:
All of these imports should be blocks, with a blank line separating them.
Please submit one PR with one commit for each of the following categories:
With per combo sparse checkout settings the edkrepo combo is not performning the sparse checkout correctly.
edkrepo checkout X
has different results than
edkrepo sparse --disable
edkrepo sparse --enable
Getting the following error during install:
Found Python 3.11.1
Git Version: 2.27.0
Running git lfs install
Searching for existing EdkRepo installations...
Determining currently installed Python packages...
Uninstalling current version of edkrepo
Version 4.0.0 of package smmap is already installed
Version 4.0.7 of package gitdb is already installed
Version 3.1.14 of package GitPython is already installed
Version 0.4.4 of package colorama is already installed
Installing edkrepo version 3.1.0
Windows directory is in %PATH%.
Creating edkrepo launcher in Git Bash...
Creating python launcher in Git Bash...
Creating python3 launcher in Git Bash...
Installing EdkRepo command completion...
Copied win_edkrepo_prompt.sh
C:\windows\edkrepo.exe
C:\Program Files\Git\etc\profile.d\edkrepo_completions.sh
Traceback (most recent call last):
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_entry_point.py", line 94, in main
return(func())
^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_cli.py", line 161, in main
command = command_factory.create_composite_command()
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 85, in create_composite_command
commands = get_commands()
^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 73, in get_commands
if in_same_module and _is_command(cls[1]):
^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 32, in _is_command
if func[0] == 'get_metadata' and len(inspect.getargspec(func[1])[0]) == 1:
^^^^^^^^^^^^^^^^^^
AttributeError: module 'inspect' has no attribute 'getargspec'
Traceback (most recent call last):
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_entry_point.py", line 94, in main
return(func())
^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\edkrepo_cli.py", line 161, in main
command = command_factory.create_composite_command()
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\klwoo\AppData\Local\Programs\Python\Python311\Lib\site-packages\edkrepo\commands\command_factory.py", line 85, in create_composite_command
Must be completed after #75 #77 #76
EdkRepo must provide a set of common functionality to do the following:
The Edkrepo 3.1.0 release Windows installers is flagged by Windows 11 as a risky app.
Steps to reproduce:
Download the EdkRepoSetup-3.1.0.0.exe Windows installer from edk2-edkrepo releases page.
https://github.com/tianocore/edk2-edkrepo/releases/download/edkrepo-v3.1.0/EdkRepoSetup-3.1.0.0.exe
Attempt to run EdkRepoSetup-3.1.0.0.exe from Downloads folder.
Windows protected your PC
Microsoft Defender SmartScreen prevented an unrecognized app from starting. Running this app might put your PC at risk.
More Info
App: EdkRepoSetup-3.1.0.0.exe
Publisher: Unknown publisher
Workaround:
Click "More info", then click "Run anyway".
Test system: Windows 11
Request the next edkrepo release provide a Windows installer that won't trigger this warning for new users.
When run without the -v flag no output is given.
When the -v flag is provided the following stack trace is output:
Traceback (most recent call last): File "C:\Python38\lib\site-packages\edkrepo_internal\edkrepo_cli.py", line 304, in main command.run_command(command_name, parsed_args, config) File "C:\Python38\lib\site-packages\edkrepo\commands\composite_command.py", line 38, in run_command return command.run_command(args, config) File "C:\Python38\lib\site-packages\edkrepo\commands\list_pins_command.py", line 125, in run_command less_output = subprocess.Popen([str(less_path), '-F', '-R', '-S', '-X', '-K'], stdin=subprocess.PIP E, stdout=sys.stdout, universal_newlines=True) File "C:\Python38\lib\subprocess.py", line 808, in __init__ errread, errwrite) = self._get_handles(stdin, stdout, stderr) File "C:\Python38\lib\subprocess.py", line 1178, in _get_handles c2pwrite = msvcrt.get_osfhandle(stdout.fileno()) io.UnsupportedOperation: fileno
When the lookup of a project fails the sync command should alert the user that they cannot located the entry in a manifest repository but proceed with syncing the workspace.
If combo being cloned has venv_enable == True defined in the project manifest file EdkRepo must create and configure an appropriate python virtual environment.
The manifest parser must support defining PatchSets with the following syntax. These patch sets can be referenced in the source's defined in a combo and be leveraged by EdkRepo dynamically create custom local branches for users based on a recipe.
This ticket is to add initial support for parsing these new sections.
<PatchSets>
<PatchSet remote='' name='' parentSha='' fetchBranch='' />
<Patch file=''/>
<Revert sha=''/>
<CherryPick sha='' sourceRemote='' sourceBranch=''/>
</PatchSet>
</PatchSets>
PatchSet data should be made available as a named tuple following the precedent set by other publicly accessible data from the parser and should be as follows:
PatchSet = namedtuple('PatchSet', ['remote', 'name', 'parent_sha', 'fetch_branch'])
Individual patch operations (patch, revert and cherry-pick) should also be implemented as named tuples defined as follows:
PatchOperation = namedtuple('PatchOperation',['type', 'file', 'sha', 'source_remote', 'source_branch'])
Type can be one of: Patch, Revert or CherryPick. Data not used by the given operation type should be populated as None
The following methods and/or properties should be implemented:
A declarative, efficient, and flexible JavaScript library for building user interfaces.
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google ❤️ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.