fix merge error
This commit is contained in:
@@ -56,68 +56,6 @@ map_file = os.path.join(env.subst("$PROJECT_DIR"), env.subst("$PROGNAME") + ".ma
|
|||||||
if os.path.exists(map_file):
|
if os.path.exists(map_file):
|
||||||
os.remove(map_file)
|
os.remove(map_file)
|
||||||
|
|
||||||
def install_standard_python_deps():
|
|
||||||
def _get_installed_standard_pip_packages():
|
|
||||||
result = {}
|
|
||||||
packages = {}
|
|
||||||
pip_output = subprocess.check_output(
|
|
||||||
[
|
|
||||||
env.subst("$PYTHONEXE"),
|
|
||||||
"-m",
|
|
||||||
"pip",
|
|
||||||
"list",
|
|
||||||
"--format=json",
|
|
||||||
"--disable-pip-version-check",
|
|
||||||
]
|
|
||||||
)
|
|
||||||
try:
|
|
||||||
packages = json.loads(pip_output)
|
|
||||||
except:
|
|
||||||
print("Warning! Couldn't extract the list of installed Python packages.")
|
|
||||||
return {}
|
|
||||||
for p in packages:
|
|
||||||
result[p["name"]] = pepver_to_semver(p["version"])
|
|
||||||
|
|
||||||
return result
|
|
||||||
|
|
||||||
deps = {
|
|
||||||
"wheel": ">=0.35.1",
|
|
||||||
"rich-click": ">=1.8.6",
|
|
||||||
"PyYAML": ">=6.0.2",
|
|
||||||
"intelhex": ">=2.3.0",
|
|
||||||
"rich": ">=14.0.0",
|
|
||||||
"esp-idf-size": ">=1.6.1"
|
|
||||||
}
|
|
||||||
|
|
||||||
installed_packages = _get_installed_standard_pip_packages()
|
|
||||||
packages_to_install = []
|
|
||||||
for package, spec in deps.items():
|
|
||||||
if package not in installed_packages:
|
|
||||||
packages_to_install.append(package)
|
|
||||||
else:
|
|
||||||
version_spec = semantic_version.Spec(spec)
|
|
||||||
if not version_spec.match(installed_packages[package]):
|
|
||||||
packages_to_install.append(package)
|
|
||||||
|
|
||||||
if packages_to_install:
|
|
||||||
env.Execute(
|
|
||||||
env.VerboseAction(
|
|
||||||
(
|
|
||||||
'"$PYTHONEXE" -m pip install -U -q -q -q '
|
|
||||||
+ " ".join(
|
|
||||||
[
|
|
||||||
'"%s%s"' % (p, deps[p])
|
|
||||||
for p in packages_to_install
|
|
||||||
]
|
|
||||||
)
|
|
||||||
),
|
|
||||||
"Installing standard Python dependencies",
|
|
||||||
)
|
|
||||||
)
|
|
||||||
return
|
|
||||||
|
|
||||||
install_standard_python_deps()
|
|
||||||
|
|
||||||
# Allow changes in folders of managed components
|
# Allow changes in folders of managed components
|
||||||
os.environ["IDF_COMPONENT_OVERWRITE_MANAGED_COMPONENTS"] = "1"
|
os.environ["IDF_COMPONENT_OVERWRITE_MANAGED_COMPONENTS"] = "1"
|
||||||
|
|
||||||
@@ -173,7 +111,7 @@ if "arduino" in env.subst("$PIOFRAMEWORK"):
|
|||||||
os.rename(ARDUINO_FRAMEWORK_DIR, new_path)
|
os.rename(ARDUINO_FRAMEWORK_DIR, new_path)
|
||||||
ARDUINO_FRAMEWORK_DIR = new_path
|
ARDUINO_FRAMEWORK_DIR = new_path
|
||||||
assert ARDUINO_FRAMEWORK_DIR and os.path.isdir(ARDUINO_FRAMEWORK_DIR)
|
assert ARDUINO_FRAMEWORK_DIR and os.path.isdir(ARDUINO_FRAMEWORK_DIR)
|
||||||
arduino_libs_mcu = join(platform.get_package_dir("framework-arduinoespressif32-libs"),mcu)
|
arduino_libs_mcu = join(platform.get_package_dir("framework-arduinoespressif32-libs"), mcu)
|
||||||
|
|
||||||
BUILD_DIR = env.subst("$BUILD_DIR")
|
BUILD_DIR = env.subst("$BUILD_DIR")
|
||||||
PROJECT_DIR = env.subst("$PROJECT_DIR")
|
PROJECT_DIR = env.subst("$PROJECT_DIR")
|
||||||
@@ -1548,24 +1486,17 @@ def generate_mbedtls_bundle(sdk_config):
|
|||||||
|
|
||||||
|
|
||||||
def install_python_deps():
|
def install_python_deps():
|
||||||
def _get_installed_pip_packages(python_exe_path):
|
def _get_installed_uv_packages(python_exe_path):
|
||||||
result = {}
|
result = {}
|
||||||
packages = {}
|
|
||||||
pip_output = subprocess.check_output(
|
|
||||||
[
|
|
||||||
python_exe_path,
|
|
||||||
"-m",
|
|
||||||
"pip",
|
|
||||||
"list",
|
|
||||||
"--format=json",
|
|
||||||
"--disable-pip-version-check",
|
|
||||||
]
|
|
||||||
)
|
|
||||||
try:
|
try:
|
||||||
packages = json.loads(pip_output)
|
uv_output = subprocess.check_output([
|
||||||
except:
|
"uv", "pip", "list", "--python", python_exe_path, "--format=json"
|
||||||
print("Warning! Couldn't extract the list of installed Python packages.")
|
])
|
||||||
|
packages = json.loads(uv_output)
|
||||||
|
except (subprocess.CalledProcessError, json.JSONDecodeError, OSError) as e:
|
||||||
|
print(f"Warning! Couldn't extract the list of installed Python packages: {e}")
|
||||||
return {}
|
return {}
|
||||||
|
|
||||||
for p in packages:
|
for p in packages:
|
||||||
result[p["name"]] = pepver_to_semver(p["version"])
|
result[p["name"]] = pepver_to_semver(p["version"])
|
||||||
|
|
||||||
@@ -1576,13 +1507,13 @@ def install_python_deps():
|
|||||||
return
|
return
|
||||||
|
|
||||||
deps = {
|
deps = {
|
||||||
"wheel": ">=0.35.1",
|
"uv": ">=0.1.0",
|
||||||
# https://github.com/platformio/platformio-core/issues/4614
|
# https://github.com/platformio/platformio-core/issues/4614
|
||||||
"urllib3": "<2",
|
"urllib3": "<2",
|
||||||
# https://github.com/platformio/platform-espressif32/issues/635
|
# https://github.com/platformio/platform-espressif32/issues/635
|
||||||
"cryptography": "~=44.0.0",
|
"cryptography": "~=44.0.0",
|
||||||
"pyparsing": ">=3.1.0,<4",
|
"pyparsing": ">=3.1.0,<4",
|
||||||
"idf-component-manager": "~=2.0.1",
|
"idf-component-manager": "~=2.2",
|
||||||
"esp-idf-kconfig": "~=2.5.0"
|
"esp-idf-kconfig": "~=2.5.0"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1590,7 +1521,7 @@ def install_python_deps():
|
|||||||
deps["chardet"] = ">=3.0.2,<4"
|
deps["chardet"] = ">=3.0.2,<4"
|
||||||
|
|
||||||
python_exe_path = get_python_exe()
|
python_exe_path = get_python_exe()
|
||||||
installed_packages = _get_installed_pip_packages(python_exe_path)
|
installed_packages = _get_installed_uv_packages(python_exe_path)
|
||||||
packages_to_install = []
|
packages_to_install = []
|
||||||
for package, spec in deps.items():
|
for package, spec in deps.items():
|
||||||
if package not in installed_packages:
|
if package not in installed_packages:
|
||||||
@@ -1601,21 +1532,22 @@ def install_python_deps():
|
|||||||
packages_to_install.append(package)
|
packages_to_install.append(package)
|
||||||
|
|
||||||
if packages_to_install:
|
if packages_to_install:
|
||||||
|
packages_str = " ".join(['"%s%s"' % (p, deps[p]) for p in packages_to_install])
|
||||||
|
|
||||||
|
# Use uv to install packages in the specific Python environment
|
||||||
env.Execute(
|
env.Execute(
|
||||||
env.VerboseAction(
|
env.VerboseAction(
|
||||||
(
|
f'uv pip install --python "{python_exe_path}" {packages_str}',
|
||||||
'"%s" -m pip install -U -q -q -q ' % python_exe_path
|
"Installing ESP-IDF's Python dependencies with uv",
|
||||||
+ " ".join(['"%s%s"' % (p, deps[p]) for p in packages_to_install])
|
|
||||||
),
|
|
||||||
"Installing ESP-IDF's Python dependencies",
|
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
if IS_WINDOWS and "windows-curses" not in installed_packages:
|
if IS_WINDOWS and "windows-curses" not in installed_packages:
|
||||||
|
# Install windows-curses in the IDF Python environment
|
||||||
env.Execute(
|
env.Execute(
|
||||||
env.VerboseAction(
|
env.VerboseAction(
|
||||||
'"%s" -m pip install -q -q -q windows-curses' % python_exe_path,
|
f'uv pip install --python "{python_exe_path}" windows-curses',
|
||||||
"Installing windows-curses package",
|
"Installing windows-curses package with uv",
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user