当前仓库属于暂停状态,部分功能使用受限,详情请查阅 仓库状态说明
1 Star 0 Fork 9

李海/Multi-environ Technology
暂停

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
pymake5.py 61.71 KB
一键复制 编辑 原始数据 按行查看 历史
tianduanrui 提交于 2017-10-06 01:24 . update pymake6 new logic for compile
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369
# -*- coding: utf-8 -*-
#!/usr/bin/env python
"""PyMake 5.0.
Usage:
pymake5.py source
pymake5.py source root [ <source-root-path> ]
pymake5.py source config [ --add | --del | --mod | --switch | --restore | --show ] [ <config-file-name> ] [<new-config-file-name>]
pymake5.py set value ( path | cmd | var | proj ) ( --add | --del | --mod ) <group> <name> [ <value> ]
pymake5.py set current ( path | cmd | var | proj | exe ) ( --add | --del | --mod ) <name> [ <values> ... ]
pymake5.py set working ( path | cmd | var | proj | exe ) <name>
pymake5.py set store (--add | --del | --mod ) <name> [ <value> ]
pymake5.py set stream (--add | --del | --mod ) <name> [ <values> ... ]
pymake5.py list ( path | cmd | var | proj | store | exe ) [--raw] [<name>]
pymake5.py exe [ <name> ]
pymake5.py (-h | --help)
pymake5.py --version
Command:
source switch to another source file
set path config work directory
set cmd
set var
set proj config project's pattern
set current
set working switch to current env path project or stream
set command
set stream
list list configed values
Options:
-h --help Show this screen.
--version Show version.
--add
--del
--mod add or delete or modify a config or path
--switch switch to another source
--var
--path
--cmd
--stream show cmd list
--show display haved stream config files
--restore reset to pymake.json stream config file
"""
import os
import re
import sys
import shutil
import time
import json
import copy
import types
from pycore.pycore import *
from pycore.docopt import docopt
from collections import OrderedDict
def main_function():
d = {
"path+": {
"mac": {
"dev-root": "/Users/abel/Develop"
},
"win": {
"dev-root": "E:/abel/Develop"
},
"common": {
"src-root": "${dev-root}/a0-develop",
"prod-root": "${dev-root}/b1-product",
"tool-root": "${dev-root}/b0-toolskits",
"build-root": "${dev-root}/c0-buildstation",
"test-root": "${dev-root}/c1-test",
"webrc-root": "${dev-root}/c2-webrc"
},
"macQt": {
"Qt5.9Bin": "${tool-root}/Libraries/QtLibraries/5.9.1/clang_64/bin"
},
"macOS": {
"cmake-path": "${tool-root}/compliers/CMake.app/Contents/bin"
},
"androidQt": {
"Qt5.8Bin": "${tool-root}/Libraries/QtLibraries/5.9.1/android_x86/bin"
},
"androidQt-arm": {
"Qt5.9Bin": "${tool-root}/Libraries/QtLibraries/5.9.1/android_armv7/bin"
},
"macJava": {
"android-root": "${tool-root}//AndroidGroupLibraries",
"java-path": "${android-root}/java-macosx/Java/JavaVirtualMachines/jdk1.8.0_111.jdk/Contents/Home/bin",
"android-sdk": "${android-root}/android-sdk-macosx/platform-tools",
"ant-path": "${android-root}/apache-ant-1.10.1/bin"
},
"android-ndk-arm": {
"ndk-path": "${android-root}/android-ndk-r13b/toolchains/arm-linux-androideabi-4.9/prebuilt/darwin-x86_64/bin"
},
"android-ndk-x86": {
"ndk-path": "${android-root}/android-ndk-r13b/toolchains/x86-4.9/prebuilt/darwin-x86_64/bin"
},
"android-ndk-x86_64": {
"ndk-path": "${android-root}/android-ndk-r13b/toolchains/x86_64-4.9/prebuilt/darwin-x86_64/bin"
},
"win7OS": {}
},
"command": {
"unix": {
"mkdir": "mkdir -p",
"cd": "cd",
"make": "make"
},
"win": {
"cd": "cd /d"
},
"mingw32": {
"make": "mingw32-make"
},
"androidQt": {
"deployqt": "androiddeployqt"
},
"macQt": {
"deployqt": "macdeployqt"
}
},
"variable": {
"undetemined": {
"os-sdk": "/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks"
},
"my-special-var": {
"PYCMD_MYNAME": "T.D.R",
"a_special_var_const": "hello world"
},
"mac": {
"dev-root": "/Users/abel/Develop"
},
"win": {
"dev-root": "E:/abel/Develop"
},
"common": {
"src-root": "${dev-root}/a0-develop",
"prod-root": "${dev-root}/b1-product",
"tool-root": "${dev-root}/b0-toolskits",
"build-root": "${dev-root}/c0-buildstation",
"test-root": "${dev-root}/c1-test",
"webrc-root": "${dev-root}/c2-webrc"
},
"ios": {
"QtVer": "5.9.1",
"QKIT": "iOS",
"QtSDK": "ios",
"QSYSNAME": "iOS",
"BUILDTYPE": "Release",
"QSYSNAME_BUILDTYPE": "${QSYSNAME}/${BUILDTYPE}",
"os-sdk": "/Applications/Xcode.app/Contents/Developer/Platforms/xxxx.platform/Developer/SDKs/xxx.sdk/System/Library/Frameworks"
},
"macQt": {
"QKIT": "macOS",
"QTDIR": "${tool-root}/Libraries/QtLibraries/5.9.1/clang_64"
},
"androidQt": {
"QKIT": "Android",
"QTDIR": "${tool-root}/Libraries/QtLibraries/5.8/android_x86",
"QTSPEC": "android-g++",
"QTCONFIG": "x86"
},
"androidQt-arm": {
"QKIT": "Android",
"QTDIR": "${tool-root}/Libraries/QtLibraries/5.8/android_armv7"
},
"macCmake": {
"cmake-bin": "CMake.app/Contents/bin"
},
"macOS": {},
"macJava": {
"JAVA_HOME": "${dev-root}/b0-toolskits/AndroidGroupLibraries/java-macosx/Java/JavaVirtualMachines/jdk1.8.0_111.jdk/Contents/Home",
"CLASSPATH": ".:${JAVA_HOME}/lib/dt/jar:${JAVA_HOME}/lib/tools.jar"
},
"android-arm": {
"ANDROID_API_VERSION": "android-23",
"ANDROID_SDK_ROOT": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-sdk-macosx",
"ANDROID_NDK_ROOT": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-ndk-r13b",
"ANDROID_NDK_HOST": "darwin-x86_64",
"ANDROID_NDK_TOOLCHAIN_PREFIX": "arm-linux-androideabi",
"ANDROID_NDK_TOOLCHAIN_VERSION": "4.9",
"ANDROID_NDK_PLATFORM": "android-23",
"NDK_TOOLCHAIN_PATH": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-ndk-r13b/toolchains/arm-linux-androideabi-4.9/prebuilt/darwin-x86_64",
"NDK_TOOLS_PREFIX": "arm-linux-androideabi"
},
"temp": {
"NDK_ROOT": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-ndk-r13b",
"NDK_PLATFORM": "android-23",
"ANDROID_TARGET_ARCH": "x86",
"NDK_TOOLCHAIN_PREFIX": "x86",
"NDK_TOOLCHAIN_VERSION": "4.9",
"NDK_TOOLS_PREFIX": "i686-linux-android",
"NDK_HOST": "darwin-x86_64"
},
"android-x86": {
"ANDROID_NDK_ROOT": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-ndk-r13b",
"ANDROID_NDK_PLATFORM": "android-23",
"ANDROID_TARGET_ARCH": "x86",
"ANDROID_NDK_TOOLCHAIN_PREFIX": "x86",
"ANDROID_NDK_TOOLCHAIN_VERSION": "4.9",
"ANDROID_NDK_TOOLS_PREFIX": "i686-linux-android",
"ANDROID_NDK_HOST": "darwin-x86_64",
"ANDROID_SDK_ROOT": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-sdk-macosx",
"ANDROID_SDK_BUILD_TOOLS_REVISION": "26.0.2"
},
"android-x86_64": {
"ANDROID_API_VERSION": "android-23",
"ANDROID_SDK_ROOT": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-sdk-macosx",
"ANDROID_NDK_ROOT": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-ndk-r13b",
"ANDROID_NDK_HOST": "darwin-x86_64",
"ANDROID_NDK_TOOLCHAIN_PREFIX": "x86_64-linux-android",
"ANDROID_NDK_TOOLCHAIN_VERSION": "4.9",
"ANDROID_NDK_PLATFORM": "android-23",
"NDK_TOOLCHAIN_PATH": "${dev-root}/b0-toolskits/AndroidGroupLibraries/android-ndk-r13b/toolchains/x86_64-4.9/prebuilt/darwin-x86_64",
"NDK_TOOLS_PREFIX": "x86_64-linux-android"
}
},
"project": {
"mac": {
"dev-root": "/Users/abel/Develop"
},
"common": {
"src-root": "${dev-root}/a0-develop",
"prod-root": "${dev-root}/b1-product",
"tool-root": "${dev-root}/b0-toolskits",
"build-root": "${dev-root}/c0-buildstation",
"test-root": "${dev-root}/c1-test",
"webrc-root": "${dev-root}/c2-webrc"
},
"macQt": {
"QSYSNAME": "MacOS"
},
"android64Qt": {
"QSYSNAME": "Android_x86-64"
},
"androidQt": {
"QSYSNAME": "Android"
},
"androidQt-arm": {
"QSYSNAME": "Android-arm"
},
"release": {
"BUILDTYPE": "Release",
"QSYSNAME_BUILDTYPE": "${QSYSNAME}/${BUILDTYPE}"
},
"debug": {
"BUILDTYPE": "Debug",
"QSYSNAME_BUILDTYPE": "${QSYSNAME}/${BUILDTYPE}"
},
"qqt": {
"prod-name": "QQt",
"proj-name": "a0-qqtfoundation",
"build-path": "${build-root}/${proj-name}/${QSYSNAME_BUILDTYPE}",
"source-path": "${src-root}/${proj-name}",
"qmake-file": "${proj-name}.pro",
"bin-path": "${build-path}/src/bin"
},
"qqt-app": {
"prod-name": "qqtframe",
"proj-name": "a0-qqtfoundation",
"source-path": "${src-root}/${proj-name}",
"build-path": "${build-root}/${proj-name}/${QSYSNAME_BUILDTYPE}",
"qmake-file": "${proj-name}.pro",
"bin-path": "${build-path}/examples/${prod-name}/bin",
"lib-dep": "${build-path}/src/bin/QQt.framework",
"lib-dep-name": "QQt.framework/Versions/1/QQt"
},
"export": {
"app-bundle": "${prod-name}.app",
"app-native": "${bin-path}/${app-bundle}/Contents/MacOS",
"lib-native": "${bin-path}/${app-bundle}/Contents/Frameworks",
"lib-bundle": "${prod-name}.framework"
},
"wiz": {
"build-path": ""
},
"myfamily": {
"": ""
},
"qt-source": {
"build-path": "${tool-root}/Libraries/QtLibraries/Source/qt5"
},
"qt-build": {
"source-path": "${tool-root}/Source/qt5",
"build-path": "${build-root}/Qt5-5.8"
},
"qt-android-arm": {
"install-path": "${tool-root}/Libraries/QtLibraries/5.9.1/android_armv7_6.0r13b_gcc"
},
"qt-android-x86": {
"install-path": "${tool-root}/Libraries/QtLibraries/5.8/android_x86-print"
}
},
"store-command": {
"why-to-set-these": "I'm not similar to these command, so list them here, rather than forgotten them",
"here": "cl-command, sys-command",
"here-1": "replace? no, append? easy!",
"mk-build-path": "${mkdir} ${build-path}",
"cd-build-path": "${cd} ${build-path}",
"cd-prod-path": "${cd} ${prod-root}",
"cd-bin-path": "${cd} ${bin-path}",
"cd-install-path": "${cd} ${install-path}",
"cmake": "cmake -G\"Unix Makefiles\" -DCMAKE_INSTALL_PREFIX=${prod-root} ${source-path}",
"cmake-xcode": "cmake -GXCode -DCMAKE_INSTALL_PREFIX=${prod-root} ${source-path}",
"cmake-rmcache": "rm -f CMakeCache.txt",
"qmake": "qmake ${source-path}/${qmake-file} -spec ${QTSPEC} CONFIG+=${QTCONFIG}",
"qmake-all": "${make} qmake_all",
"make": "${make} -j4",
"make-clean": "${make} clean in ${build-path}",
"make-install": "${make} install",
"deployqt": "${deployqt} ${bin-path}/${app-bundle} -verbose=1",
"deployqt-dmg": "${deployqt} -dmg",
"deployqt-help": "${deployqt} --help",
"cp-dep": "cp -fr ${lib-dep} ${lib-native}",
"install_name_tool": "install_name_tool -change ${lib-dep-name} @rpath/${lib-dep-name} ${app-native}/${prod-name} ",
"macdep": "install_name_tool -change $LibDep @rpath/$LibDep ${app-native}/${prod-name} ",
"configure-qt5-android": "${source-path}/configure -prefix ${install-path} -hostprefix ${install-path} -xplatform android-g++ -release -nomake tests -nomake examples -android-ndk $ANDROID_NDK_ROOT -android-sdk $ANDROID_SDK_ROOT -android-ndk-host $ANDROID_NDK_HOST -android-toolchain-version $ANDROID_NDK_TOOLCHAIN_VERSION -skip qtwebkit-examples -no-warnings-are-errors",
"pwd": "pwd",
"var": "echo 'qtdir:' $QTDIR ",
"var2": "echo 'qtdir:' ${QTDIR} ",
"msg": "echo 'work complete!'"
},
"store-stream": {
"build": [
"mk-build-path",
"cd-build-path",
"qmake",
"qmake-all",
"make",
"msg"
],
"rebuild": [
"mk-build-path",
"cd-build-path",
"qmake",
"make-clean",
"make",
"msg"
],
"clean": [
"cd-build-path",
"make-clean",
"msg"
],
"install": [
"cd-build-path",
"make-install"
],
"macdeployqt+lib": [
"cd-build-path",
"deployqt",
"cp-dep",
"install_name_tool",
"msg"
],
"qt-creator": [
"\"/Applications/Qt Creator.app/Contents/MacOS/Qt Creator\""
],
"build-qt5-android": [
"mk-build-path",
"cd-build-path",
"configure-qt5-android",
"make",
"make install"
],
"t1": [
"macdeployqt --help"
],
"t": [
"pwd",
"pwd",
"var",
"var2",
"pwd",
"msg",
"var2",
"set ${build-path}",
"macdeployqt --help"
],
"test-android": [
"cd-install-path",
"pwd",
"which java",
"java --version",
"adb version",
"ant"
]
},
"store-current": {
"path+": {
"mac": [
"mac",
"common",
"macQt",
"macOS"
],
"android-x86": [
"mac",
"common",
"androidQt",
"macJava",
"android-ndk-x86"
],
"android-arm": [
"mac",
"common",
"androidQt-arm",
"macJava",
"android-ndk-arm"
],
"androidQt": [
"mac",
"common",
"macJava",
"android-ndk-x86"
],
"current": "androidQt"
},
"command": {
"mac": [
"unix",
"macQt"
],
"android": [
"unix",
"androidQt"
],
"current": "android"
},
"variable": {
"mac": [
"mac",
"common",
"macQt",
"macCmake",
"macOS"
],
"android-x86": [
"mac",
"common",
"androidQt",
"macJava",
"android-x86"
],
"android-arm": [
"mac",
"common",
"androidQt-arm",
"macJava",
"android-arm"
],
"androidQt": [
"mac",
"common",
"macJava",
"android-x86"
],
"current": "androidQt"
},
"project": {
"qqt": [
"mac",
"common",
"varQt",
"qqt-example",
"export"
],
"qqt-app": [
"mac",
"common",
"androidQt",
"release",
"qqt-app",
"export"
],
"qt-android": [
"mac",
"common",
"macQt",
"release",
"qt-build",
"qt-android-x86"
],
"current": "qt-android"
},
"execute": {
"t1": [
"t1"
],
"t": [
"t"
],
"build": [
"build"
],
"build-mac": [
"build",
"macdeployqt+lib"
],
"qt-creator": [
"qt-creator"
],
"build-qt5-android": [
"build-qt5-android"
],
"current": "build-qt5-android"
}
}
}
"""
[pymake]
[source]
root = ~/.pymake
config = pymake.json
"""
userroot = getuserroot()
pymakeroot = userroot + os.path.sep + '.pymake'
if (not os.path.exists(pymakeroot)):
os.makedirs(pymakeroot)
#initial pymake.ini
pymakeini = pymakeroot + os.path.sep + 'pymake.ini'
conf = MyConfigParser()
conf.read(pymakeini)
if( not conf.has_section('pymake') ):
conf.add_section('pymake')
conf.write(open(pymakeini, 'w'))
if( not conf.has_section('source') ):
conf.add_section('source')
conf.write(open(pymakeini, 'w'))
if( not conf.has_option('source', 'root') ):
conf.set('source', 'root', pymakeroot)
conf.write(open(pymakeini, 'w'))
if(not conf.has_option('source', 'config')):
conf.set('source', 'config', 'pymake.json')
conf.write(open(pymakeini, 'w'))
sourceroot = conf.get('source', 'root')
os.chdir(sourceroot)
if (os.path.abspath(sourceroot) == os.path.abspath(pymakeroot)):
print("I checked you use pymakeroot to be sourceroot, suggest you use source command changing one.")
args = docopt(__doc__, version='pymake5.py v5.0')
#print(args)
pymakesuffix = '.json'
while (True):
if(args['source'] is True):
if(args['root'] is True):
if ( args['<source-root-path>'] is not None):
conf.set('source', 'root', args['<source-root-path>'])
conf.write(open(pymakeini, 'w'))
print ("success root: %s" % args['<source-root-path>'])
else:
print ("root: %s" % sourceroot)
elif(args['config'] is True):
if(args['--del'] is True):
if (args['<config-file-name>'] is not None and args['<config-file-name>'] == 'pymake.json'):
print('You can\'t remove pymake\'s file...')
elif (args['<config-file-name>'] is not None and args['<config-file-name>'].endswith(pymakesuffix)):
os.remove(args['<config-file-name>'])
conf.set('source', 'config', 'pymake.json')
conf.write(open(pymakeini, 'w'))
print ("success: %s" % args['<config-file-name>'])
else:
print ('You can\'t remove pymake.json and un.json\'s file...')
elif(args['--add'] is True):
if (args['<config-file-name>'] is not None and args['<config-file-name>'].endswith(pymakesuffix) and args['<config-file-name>'] != 'pymake.json'):
f = conf.get('source', 'config')
if( f != args['<config-file-name>']):
shutil.copyfile(f, args['<config-file-name>'])
conf.set('source', 'config', args['<config-file-name>'])
conf.write(open(pymakeini, 'w'))
print ("success: %s" % args['<config-file-name>'])
else:
print('You can\'t add same named file...')
else:
print ('You can\'t add pymake.json and un.json\'s file...')
elif (args['--mod'] is True):
if ( ( args['<config-file-name>'] and args['<new-config-file-name>']) is not None and args['<config-file-name>'].endswith(pymakesuffix)):
os.rename(args['<config-file-name>'],args['<new-config-file-name>'])
f = conf.get('source', 'config')
if (f == args['<config-file-name>']):
conf.set('source', 'config',args['<new-config-file-name>'])
conf.write(open(pymakeini, 'w'))
print ("success: %s" % args['<new-config-file-name>'])
else:
print ('You can\'t mod pymake.json and un.json\'s file...')
elif(args['--show'] is True):
files = os.listdir(os.getcwd())
for f in files:
if (f.endswith(pymakesuffix)):
print(f)
elif(args['--restore'] is True):
conf.set('source', 'config', 'pymake.json')
conf.write(open(pymakeini, 'w'))
print ("success: %s" % 'pymake.json')
elif (args['--switch'] is True or ( args['<config-file-name>'] is not None )):
if (args['<config-file-name>'] is not None and args['<config-file-name>'].endswith(pymakesuffix) ):
if (os.path.exists(args['<config-file-name>'])):
conf.set('source', 'config', args['<config-file-name>'])
conf.write(open(pymakeini, 'w'))
print("switch to source config: %s" % args['<config-file-name>'])
else:
print("source file %s isn't exists, please --add it" % args['<config-file-name>'])
else:
print ('You can\'t switch pymake.json and un.json\'s file...')
else:
print ("conf: %s" % conf.get("source", "config"))
else:
r = conf.get('source', 'root')
f = conf.get('source', 'config')
print ("root: %s" % (r))
print ("conf: %s" % (f))
return
else:
''
break
file = conf.get('source', 'config')
#print ("root: %s config: %s" % (sourceroot, file))
print("use source config: %s/%s" % (sourceroot, file) )
if (os.path.abspath(sourceroot) != os.path.abspath(pymakeroot)):
if (not os.path.exists('pymake.json')):
writeJsonData('pymake.json', d)
if(not os.path.exists(file)):
return
config = readJsonData(file)
#print(config)
#set
while (True):
if (args['set'] == True):
if( args['value'] is True):
if (args['path'] is True):
if (args['--add'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
config['path+'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
elif (args['--del'] == True):
if (args['<group>'] and args["<name>"] is not None):
if (config['path+'][args['<group>']].__contains__(args['<name>'])):
config['path+'][args['<group>']].__delitem__(args['<name>'])
print ("successed %s:%s" % (args['<group>'], args['<name>']))
else :
print ("failed %s:%s" % (args['<group>'], args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
if (config['path+'][args['<group>']].__contains__(args['<name>'])):
config['path+'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
''
else:
''
elif (args['cmd'] is True):
if (args['--add'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
config['command'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
elif (args['--del'] == True):
if (args['<group>'] and args["<name>"] is not None):
if (config['command'][args['<group>']].__contains__(args['<name>'])):
config['command'][args['<group>']].__delitem__(args['<name>'])
print ("successed %s:%s" % (args['<group>'], args['<name>']))
else:
print ("failed %s:%s" % (args['<group>'], args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
if (config['command'][args['<group>']].__contains__(args['<name>'])):
config['command'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
''
else:
''
elif (args['var'] is True):
if (args['--add'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
config['variable'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
elif (args['--del'] == True):
if (args['<group>'] and args["<name>"] is not None):
if (config['variable'][args['<group>']].__contains__(args['<name>'])):
config['variable'][args['<group>']].__delitem__(args['<name>'])
print ("successed %s:%s" % (args['<group>'], args['<name>']))
else:
print ("failed %s:%s" % (args['<group>'], args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
if (config['variable'][args['<group>']].__contains__(args['<name>'])):
config['variable'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
''
else:
''
elif (args['proj'] is True):
if (args['--add'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
config['project'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
elif (args['--del'] == True):
if (args['<group>'] and args["<name>"] is not None):
if (config['project'][args['<group>']].__contains__(args['<name>'])):
config['project'][args['<group>']].__delitem__(args['<name>'])
print ("successed %s:%s" % (args['<group>'], args['<name>']))
else:
print ("failed %s:%s" % (args['<group>'], args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<group>'] and args['<name>'] and args["<value>"] is not None):
if (config['project'][args['<group>']].__contains__(args['<name>'])):
config['project'][args['<group>']][args['<name>']] = args["<value>"]
print ("successed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
print ("failed %s:%s:%s" % (args['<group>'], args['<name>'], args["<value>"]))
else:
''
else:
''
elif ( args['current'] is True ):
if (args['path'] is True):
if (args['--add'] == True):
if (args['<name>'] and args["<values>"] is not None):
config["store-current"]["path+"][args['<name>']] = args["<values>"]
print ( "successed %s:%s" % (args['<name>'],args[ "<values>"]))
else:
print ( "failed %s:%s" % (args['<name>'],args[ "<values>"]))
elif (args['--del'] == True):
if (args["<name>"] is not None):
if (config["store-current"]["path+"].__contains__(args['<name>'])):
config["store-current"]["path+"].__delitem__(args['<name>'])
print ("successed %s" % (args['<name>']))
else:
print ("failed %s" % (args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<name>'] and args["<values>"] is not None):
if (config["store-current"]["path+"].__contains__(args['<name>'])):
config["store-current"]["path+"][args['<name>']] = args["<values>"]
print ("successed %s:%s" % (args['<name>'],args["<values>"]))
else:
print ("failed %s:%s" % (args['<name>'],args["<values>"]))
else:
''
else:
''
elif (args['cmd'] is True):
if (args['--add'] == True):
if (args['<name>'] and args["<values>"] is not None):
config["store-current"]["command"][args['<name>']] = args["<values>"]
print ( "successed %s:%s" % (args['<name>'],args[ "<values>"]))
else:
print ( "failed %s:%s" % (args['<name>'],args[ "<values>"]))
elif (args['--del'] == True):
if (args["<name>"] is not None):
if (config["store-current"]["command"].__contains__(args['<name>'])):
config["store-current"]["command"].__delitem__(args['<name>'])
print ("successed %s" % (args['<name>']))
else:
print ("failed %s" % (args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<name>'] and args["<values>"] is not None):
if (config["store-current"]["command"].__contains__(args['<name>'])):
config["store-current"]["command"][args['<name>']] = args["<values>"]
print ("successed %s:%s" % (args['<name>'],args["<values>"]))
else:
print ("failed %s:%s" % (args['<name>'],args["<values>"]))
else:
''
else:
''
elif (args['var'] is True):
if (args['--add'] == True):
if (args['<name>'] and args["<values>"] is not None):
config["store-current"]["variable"][args['<name>']] = args["<values>"]
print ( "successed %s:%s" % (args['<name>'],args[ "<values>"]))
else:
print ( "failed %s:%s" % (args['<name>'],args[ "<values>"]))
elif (args['--del'] == True):
if (args["<name>"] is not None):
if (config["store-current"]["variable"].__contains__(args['<name>'])):
config["store-current"]["variable"].__delitem__(args['<name>'])
print ("successed %s" % (args['<name>']))
else:
print ("failed %s" % (args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<name>'] and args["<values>"] is not None):
if (config["store-current"]["variable"].__contains__(args['<name>'])):
config["store-current"]["variable"][args['<name>']] = args["<values>"]
print ("successed %s:%s" % (args['<name>'],args["<values>"]))
else:
print ("failed %s:%s" % (args['<name>'],args["<values>"]))
else:
''
else:
''
elif (args['proj'] is True):
if (args['--add'] == True):
if (args['<name>'] and args["<values>"] is not None):
config["store-current"]["project"][args['<name>']] = args["<values>"]
print ( "successed %s:%s" % (args['<name>'],args[ "<values>"]))
else:
print ( "failed %s:%s" % (args['<name>'],args[ "<values>"]))
elif (args['--del'] == True):
if (args["<name>"] is not None):
if (config["store-current"]["project"].__contains__(args['<name>'])):
config["store-current"]["project"].__delitem__(args['<name>'])
print ("successed %s" % (args['<name>']))
else:
print ("failed %s" % (args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<name>'] and args["<values>"] is not None):
if (config["store-current"]["project"].__contains__(args['<name>'])):
config["store-current"]["project"][args['<name>']] = args["<values>"]
print ("successed %s:%s" % (args['<name>'],args["<values>"]))
else:
print ("failed %s:%s" % (args['<name>'],args["<values>"]))
else:
''
else:
''
elif (args['exe'] is True):
if (args['--add'] == True):
if (args['<name>'] and args["<values>"] is not None):
config["store-current"]["execute"][args['<name>']] = args["<values>"]
print ( "successed %s:%s" % (args['<name>'],args[ "<values>"]))
else:
print ( "failed %s:%s" % (args['<name>'],args[ "<values>"]))
elif (args['--del'] == True):
if (args["<name>"] is not None):
if (config["store-current"]["execute"].__contains__(args['<name>'])):
config["store-current"]["execute"].__delitem__(args['<name>'])
print ("successed %s" % (args['<name>']))
else:
print ("failed %s" % (args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<name>'] and args["<values>"] is not None):
if (config["store-current"]["execute"].__contains__(args['<name>'])):
config["store-current"]["execute"][args['<name>']] = args["<values>"]
print ("successed %s:%s" % (args['<name>'],args["<values>"]))
else:
print ("failed %s:%s" % (args['<name>'],args["<values>"]))
else:
''
else:
''
else:
''
elif ( args['working'] is True ):
if (args['path'] is True):
if(config["store-current"]["path+"].__contains__(args['<name>'])):
config["store-current"]["path+"]['current'] = args["<name>"]
print ("successed %s" % (args['<name>']))
else :
print ("failed %s" % (args['<name>']))
elif (args['cmd'] is True):
if(config["store-current"]["command"].__contains__(args['<name>'])):
config["store-current"]["command"]['current'] = args["<name>"]
print ("successed %s" % (args['<name>']))
else :
print ("failed %s" % (args['<name>']))
elif (args['var'] is True):
if(config["store-current"]["variable"].__contains__(args['<name>'])):
config["store-current"]["variable"]['current'] = args["<name>"]
print ("successed %s" % (args['<name>']))
else :
print ("failed %s" % (args['<name>']))
elif (args['proj'] is True):
if(config["store-current"]["project"].__contains__(args['<name>'])):
config["store-current"]["project"]['current'] = args["<name>"]
print ("successed %s" % (args['<name>']))
else :
print ("failed %s" % (args['<name>']))
elif (args['exe'] is True):
if(config["store-current"]["execute"].__contains__(args['<name>'])):
config["store-current"]["execute"]['current'] = args["<name>"]
print ("successed %s" % (args['<name>']))
else :
print ("failed %s" % (args['<name>']))
else:
''
elif (args['store'] is True):
if (args['--add'] == True):
if (args['<name>'] and args["<value>"] is not None):
config['store-command'][args['<name>']] = args["<value>"]
print ("successed %s:%s" % (args['<name>'], args["<value>"]))
else:
print ("failed %s:%s" % (args['<name>'], args["<value>"]))
elif (args['--del'] == True):
if (args["<name>"] is not None):
if (config['store-command'].__contains__(args['<name>'])):
config['store-command'].__delitem__(args['<name>'])
print ("successed %s" % (args['<name>']))
else:
print ("failed %s" % (args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<name>'] and args["<value>"] is not None):
if (config['store-command'].__contains__(args['<name>'])):
config['store-command'][args['<name>']] = args["<value>"]
print ("successed %s:%s" % (args['<name>'], args["<value>"]))
else:
print ("failed %s:%s" % (args['<name>'], args["<value>"]))
else:
''
else:
''
elif (args['stream'] is True):
if (args['--add'] == True):
if (args['<name>'] and args["<values>"] is not None):
config["store-stream"][args['<name>']] = args["<values>"]
print ("successed %s:%s" % (args['<name>'],args["<values>"]))
else:
print ("failed %s:%s" % (args['<name>'],args["<values>"]))
elif (args['--del'] == True):
if (args["<name>"] is not None):
if (config['store-stream'].__contains__(args['<name>'])):
config["store-stream"].__delitem__(args['<name>'])
print ("successed %s" % (args['<name>']))
else:
print ("failed %s" % (args['<name>']))
else:
''
elif (args['--mod'] == True):
if (args['<name>'] and args["<values>"] is not None):
config["store-stream"][args['<name>']] = args["<values>"]
print ("successed %s:%s" % (args['<name>'],args["<values>"]))
else:
print ("failed %s:%s" % (args['<name>'],args["<values>"]))
else:
''
else:
''
# print(config)
writeJsonData(file, config)
return
else:
''
break
### config -> raw config
rawconfig = copy.deepcopy(config)
# print ( config )
# print ( rawconfig )
# replace path+ 's ${...}
# path+
current_vars = rawconfig["store-current"]['path+']["current"]
for ( name ) in rawconfig['store-current']['path+'][current_vars]:
for (key, value) in rawconfig["path+"][name].items():
#print (key) #...
startpos = 0
while (True):
#print (startpos)
index = value.find('${', startpos)
if (index == -1):
break
index2 = value.find('}', index)
startpos = index2
key_replace = value[index:index2 + 1]
#print ( key0 ) #${...}
key_from = key_replace.split('{')[1].split('}')[0].strip()
#print ( key1 ) #...
# find in up of this name and self
for ( finding ) in rawconfig['store-current']["path+"][current_vars]:
for (find_key, find_value) in rawconfig["path+"][finding].items():
if(find_key == key_from):
rawconfig["path+"][name][key] = rawconfig["path+"][name][key].replace(key_replace,
rawconfig["path+"][finding][
key_from])
break
if( finding == name ):
break;
# replace command 's ${...}
# command
current_vars = rawconfig["store-current"]['command']["current"]
for ( name ) in rawconfig['store-current']['command'][current_vars]:
for (key, value) in rawconfig["command"][name].items():
#print (key) #...
startpos = 0
while (True):
#print (startpos)
index = value.find('${', startpos)
if (index == -1):
break
index2 = value.find('}', index)
startpos = index2
key_replace = value[index:index2 + 1]
#print ( key0 ) #${...}
key_from = key_replace.split('{')[1].split('}')[0].strip()
#print ( key1 ) #...
# find in up of this name and self
for ( finding ) in rawconfig['store-current']["command"][current_vars]:
if(rawconfig["command"][finding].has_key(key_from)):
rawconfig["command"][name][key] = rawconfig["command"][name][key].replace(key_replace, rawconfig["command"][finding][key_from])
if( finding == name ):
break;
# replace variable 's ${...}
# variable
current_vars = rawconfig["store-current"]['variable']["current"]
for ( name ) in rawconfig['store-current']['variable'][current_vars]:
for (key, value) in rawconfig["variable"][name].items():
#print (key) #...
startpos = 0
while (True):
#print (startpos)
index = value.find('${', startpos)
if (index == -1):
break
index2 = value.find('}', index)
startpos = index2
key_replace = value[index:index2 + 1]
#print ( key0 ) #${...}
key_from = key_replace.split('{')[1].split('}')[0].strip()
#print ( key1 ) #...
# find in up of this name and self
for ( finding ) in rawconfig['store-current']["variable"][current_vars]:
for (find_key, find_value) in rawconfig["variable"][finding].items():
if(find_key == key_from):
rawconfig["variable"][name][key] = rawconfig["variable"][name][key].replace(
key_replace,rawconfig["variable"][finding][key_from])
break
if( finding == name ):
break;
# replace project 's ${...}
# project
current_vars = rawconfig["store-current"]['project']["current"]
for ( name ) in rawconfig['store-current']['project'][current_vars]:
for (key, value) in rawconfig["project"][name].items():
#print (key) #...
startpos = 0
while (True):
#print (startpos)
index = value.find('${', startpos)
if (index == -1):
break
index2 = value.find('}', index)
startpos = index2
key_replace = value[index:index2 + 1]
#print ( key0 ) #${...}
key_from = key_replace.split('{')[1].split('}')[0].strip()
#print ( key1 ) #...
# find in up of this name and self
for ( finding ) in rawconfig['store-current']['project'][current_vars]:
for (find_key, find_value) in rawconfig["project"][finding].items():
if(find_key == key_from):
rawconfig["project"][name][key] = rawconfig["project"][name][key].replace(key_replace,
rawconfig["project"][finding][
key_from])
break
if( finding == name ):
break;
# replace store-command's ${...}
# path+ command variable project store-command
for (key, value) in rawconfig["store-command"].items():
#print (key) #...
startpos = 0
while (True):
#print (startpos)
index = value.find('${', startpos)
if (index == -1):
break
index2 = value.find('}', index)
startpos = index2
key_replace = value[index:index2 + 1]
#print ( key0 ) #${...}
key_from = key_replace.split('{')[1].split('}')[0].strip()
#print ( key1 ) #...
# find in path+
current_vars = rawconfig["store-current"]['path+']["current"]
for ( finding ) in rawconfig['store-current']['path+'][current_vars]:
for (find_key, find_value) in rawconfig["path+"][finding].items():
if (find_key == key_from):
rawconfig["store-command"][key] = rawconfig["store-command"][key].replace(
key_replace,rawconfig["path+"][finding][key_from])
break
# find in command
current_vars = rawconfig["store-current"]['command']["current"]
for ( finding ) in rawconfig['store-current']['command'][current_vars]:
for (find_key, find_value) in rawconfig["command"][finding].items():
if (find_key == key_from):
rawconfig["store-command"][key] = rawconfig["store-command"][key].replace(key_replace,rawconfig["command"][finding][key_from])
break
# find in variable
current_vars = rawconfig["store-current"]['variable']["current"]
for ( finding ) in rawconfig['store-current']['variable'][current_vars]:
for (find_key, find_value) in rawconfig["variable"][finding].items():
if (find_key == key_from):
rawconfig["store-command"][key] = rawconfig["store-command"][key].replace(
key_replace,rawconfig["variable"][finding][key_from])
break
# find in project
current_vars = rawconfig["store-current"]['project']["current"]
for ( finding ) in rawconfig['store-current']['project'][current_vars]:
for (find_key, find_value) in rawconfig["project"][finding].items():
if (find_key == key_from):
rawconfig["store-command"][key] = rawconfig["store-command"][key].replace(
key_replace,rawconfig["project"][finding][key_from])
break
# self
for (find_key) in rawconfig["store-command"].items():
if (find_key == key_from):
rawconfig["store-command"][key] = rawconfig["store-command"][key].replace(
key_replace, rawconfig["store-command"][key_from])
break
def has_key(dict0, key_from):
for (find_key, find_value) in dict0.items():
if (find_key == key_from):
return True
return False
# replace store-stream's ${}
# path+ command variable project command
for (cmd, stream) in rawconfig["store-stream"].items():
#print (key) #...
if (isinstance(stream, type("str"))):
continue
step = 0
for value in stream:
startpos = 0
while (True):
# print (startpos)
# print (value)
index = value.find('${', startpos)
if (index == -1):
break
index2 = value.find('}', index)
startpos = index2
key_replace = value[index:index2 + 1]
#print ( key0 ) #${...}
key_from = key_replace.split('{')[1].split('}')[0].strip()
#print ( key1 ) #...
# find in path+
current_vars = rawconfig["store-current"]['path+']["current"]
for ( finding ) in rawconfig['store-current']['path+'][current_vars]:
if( has_key(rawconfig["path+"][finding], key_from) ):
rawconfig['store-stream'][cmd][step] = rawconfig['store-stream'][cmd][step].replace(key_replace, rawconfig["path+"][finding][key_from])
# find in command
current_vars = rawconfig["store-current"]['command']["current"]
for ( finding ) in rawconfig['store-current']['command'][current_vars]:
if(has_key(rawconfig["command"][finding], key_from)):
rawconfig['store-stream'][cmd][step] = rawconfig['store-stream'][cmd][step].replace(key_replace, rawconfig["command"][finding][key_from])
# find in variable
current_vars = rawconfig["store-current"]['variable']["current"]
for ( finding ) in rawconfig['store-current']['variable'][current_vars]:
if(has_key(rawconfig["variable"][finding], key_from)):
rawconfig['store-stream'][cmd][step] = rawconfig['store-stream'][cmd][step].replace(key_replace, rawconfig["variable"][finding][key_from])
# find in project
current_vars = rawconfig["store-current"]['project']["current"]
for ( finding ) in rawconfig['store-current']['project'][current_vars]:
if(has_key(rawconfig["project"][finding], key_from)):
rawconfig['store-stream'][cmd][step] = rawconfig['store-stream'][cmd][step].replace(key_replace, rawconfig["project"][finding][key_from])
step += 1
# expand store-stream's command
# store-command
for (cmd, stream) in rawconfig["store-stream"].items():
#print (key) #...
if (isinstance(stream, type("str"))):
continue
step = 0
for command in stream:
if(has_key(rawconfig["store-command"], command)):
rawconfig['store-stream'][cmd][step] = rawconfig['store-stream'][cmd][step].replace(command, rawconfig["store-command"][command])
else:
''
#print ("can't find command %s:%s" % ( cmd, command ))
step += 1
#list command
while (True):
if (args['list'] == True):
if ( args['--raw'] == True ):
list_config = rawconfig
else:
list_config = config
if( args['path'] == True):
current_vars = list_config['store-current']['path+']['current']
print ("group %s" % current_vars)
for current_group in list_config['store-current']['path+'][current_vars]:
dict0 = copy.deepcopy(list_config['path+'][current_group])
for (k, v) in dict0.items():
print("%-24s %s" % (k, v) )
elif( args['cmd'] == True):
current_vars = list_config['store-current']['command']['current']
print ("group %s" % current_vars)
for current_group in list_config['store-current']['command'][current_vars]:
dict0 = copy.deepcopy(list_config['command'][current_group])
for (k, v) in dict0.items():
print("%-24s %s" % (k, v) )
elif( args['var'] == True):
current_vars = list_config['store-current']['variable']['current']
print ("group %s" % current_vars)
for current_group in list_config['store-current']['variable'][current_vars]:
dict0 = copy.deepcopy(list_config['variable'][current_group])
for (k, v) in dict0.items():
print("%-24s %s" % (k, v) )
elif( args['proj'] == True):
current_vars = list_config['store-current']['project']['current']
print ("group %s" % current_vars)
for current_group in list_config['store-current']['project'][current_vars]:
dict0 = copy.deepcopy(list_config['project'][current_group])
for (k, v) in dict0.items():
print("%-24s %s" % (k, v) )
elif( args['store'] == True):
dict0 = copy.deepcopy(list_config['store-command'])
for (k, v) in dict0.items():
print("%-24s %s" % (k, v) )
elif( args['exe'] == True):
current_vars = list_config['store-current']["execute"]['current']
if(args['<name>'] is not None):
current_vars = args['<name>']
print ("group %s" % current_vars)
list0 = []
for current_group in list_config['store-current']['execute'][current_vars]:
list0.extend(copy.deepcopy(list_config['store-stream'][current_group]))
step = 1
for v1 in list0:
print("%-3s %s" % (step, v1))
step += 1
else:
print("")
return
else:
''
break
# set into env
env = os.environ
# variable
current_vars = rawconfig["store-current"]['variable']['current']
for ( name ) in rawconfig["store-current"]['variable'][current_vars]:
for (key, value) in rawconfig["variable"][name].items():
env[key] = value
for (key, value) in env.items():
#print ("%-24s %s" % (key, value) )
''
# path+
current_vars = rawconfig["store-current"]['path+']['current']
for ( name ) in rawconfig["store-current"]['path+'][current_vars]:
for (key, value) in rawconfig["path+"][name].items():
env["PATH"] = value + os.path.pathsep + env["PATH"]
#print(env["PATH"].replace(os.path.pathsep, '\n'))
while ( True ):
if( args['exe'] == True ):
current_vars = rawconfig['store-current']["execute"]['current']
if(args['<name>'] is not None):
current_vars = args['<name>']
else:
print("")
#print ("group %s" % current_vars)
list0 = []
if( rawconfig['store-current']['execute'].has_key(current_vars) ):
for current_group in rawconfig['store-current']['execute'][current_vars]:
list0.extend(copy.deepcopy(rawconfig['store-stream'][current_group]))
elif( rawconfig['store-stream'].__contains__ (current_vars) ):
for current_group in rawconfig['store-stream'][current_vars]:
list0.append(copy.deepcopy(rawconfig['store-command'][current_group]))
elif( rawconfig['store-command'].__contains__ (current_vars) ):
list0.append(copy.deepcopy(rawconfig['store-command'][current_vars]))
else:
list0.append(current_vars)
communicateWithCommandLine(list0)
os._exit(0)
return
else:
''
break
return
if __name__ == '__main__':
main_function()
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Python
1
https://gitee.com/seatiger/PyMake.git
git@gitee.com:seatiger/PyMake.git
seatiger
PyMake
Multi-environ Technology
master

搜索帮助