Add package requirements for PIO Plus

This commit is contained in:
Ivan Kravets
2016-10-05 15:46:04 +03:00
parent 41c69797f2
commit 485ba19601

View File

@ -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()