mirror of
https://github.com/platformio/platformio-core.git
synced 2025-07-31 10:37:13 +02:00
Add package requirements for PIO Plus
This commit is contained in:
@ -20,7 +20,10 @@ from platform import system
|
|||||||
from platformio import exception, util
|
from platformio import exception, util
|
||||||
from platformio.managers.package import PackageManager
|
from platformio.managers.package import PackageManager
|
||||||
|
|
||||||
PACKAGE_DEPS = {"pysite": "pysite-pioplus", "tool": "tool-pioplus"}
|
PACKAGE_DEPS = {"pysite": {"name": "pysite-pioplus",
|
||||||
|
"requirements": ">=0.1.0"},
|
||||||
|
"tool": {"name": "tool-pioplus",
|
||||||
|
"requirements": ">=0.2.0"}}
|
||||||
|
|
||||||
|
|
||||||
class PioPlusPackageManager(PackageManager):
|
class PioPlusPackageManager(PackageManager):
|
||||||
@ -34,24 +37,29 @@ class PioPlusPackageManager(PackageManager):
|
|||||||
|
|
||||||
def pioplus_install():
|
def pioplus_install():
|
||||||
pm = PioPlusPackageManager()
|
pm = PioPlusPackageManager()
|
||||||
for name in PACKAGE_DEPS.values():
|
for item in PACKAGE_DEPS.values():
|
||||||
pm.install(name, silent=True)
|
pm.install(item['name'], item['requirements'], silent=True)
|
||||||
|
|
||||||
|
|
||||||
def pioplus_update():
|
def pioplus_update():
|
||||||
pm = PioPlusPackageManager()
|
pm = PioPlusPackageManager()
|
||||||
for name in PACKAGE_DEPS.values():
|
for item in PACKAGE_DEPS.values():
|
||||||
pm.update(name)
|
package_dir = pm.get_package_dir(item['name'], item['requirements'])
|
||||||
|
if package_dir:
|
||||||
|
pm.update(item['name'], item['requirements'])
|
||||||
|
|
||||||
|
|
||||||
def pioplus_call(args, **kwargs):
|
def pioplus_call(args, **kwargs):
|
||||||
pioplus_install()
|
pioplus_install()
|
||||||
pm = PioPlusPackageManager()
|
pm = PioPlusPackageManager()
|
||||||
pioplus_path = join(pm.get_package_dir(PACKAGE_DEPS['tool']), "pioplus")
|
pioplus_path = join(
|
||||||
|
pm.get_package_dir(PACKAGE_DEPS['tool']['name'],
|
||||||
|
PACKAGE_DEPS['tool']['requirements']), "pioplus")
|
||||||
if system() == "Linux":
|
if system() == "Linux":
|
||||||
os.environ['LD_LIBRARY_PATH'] = dirname(pioplus_path)
|
os.environ['LD_LIBRARY_PATH'] = dirname(pioplus_path)
|
||||||
os.environ['PYTHONEXEPATH'] = util.get_pythonexe_path()
|
os.environ['PYTHONEXEPATH'] = util.get_pythonexe_path()
|
||||||
os.environ['PYTHONPYSITEDIR'] = pm.get_package_dir(PACKAGE_DEPS['pysite'])
|
os.environ['PYTHONPYSITEDIR'] = pm.get_package_dir(
|
||||||
|
PACKAGE_DEPS['pysite']['name'], PACKAGE_DEPS['pysite']['requirements'])
|
||||||
util.copy_pythonpath_to_osenv()
|
util.copy_pythonpath_to_osenv()
|
||||||
if subprocess.call([pioplus_path] + args, **kwargs) != 0:
|
if subprocess.call([pioplus_path] + args, **kwargs) != 0:
|
||||||
raise exception.ReturnErrorCode()
|
raise exception.ReturnErrorCode()
|
||||||
|
Reference in New Issue
Block a user