2017-09-12 21:25:43 +08:00
|
|
|
import os
|
2017-10-19 18:39:41 +08:00
|
|
|
from argparse import ArgumentParser
|
|
|
|
|
|
|
|
try:
|
|
|
|
import jail
|
|
|
|
APOLLO = True
|
|
|
|
except:
|
|
|
|
import jail_faker as jail
|
|
|
|
APOLLO = False
|
|
|
|
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
WALL_TIME = "wall_time"
|
|
|
|
CPU_TIME = "cpu_time"
|
2017-09-13 22:57:15 +08:00
|
|
|
MAX_MEMORY = "max_memory"
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
DIR_PATH = os.path.dirname(os.path.realpath(__file__))
|
|
|
|
|
2017-10-19 18:39:41 +08:00
|
|
|
|
2017-09-12 21:25:43 +08:00
|
|
|
def get_absolute_path(path, base=""):
|
|
|
|
if base == "build":
|
2017-09-15 19:23:05 +08:00
|
|
|
extra = "../../build"
|
2017-09-12 21:25:43 +08:00
|
|
|
elif base == "build_release":
|
2017-09-15 19:23:05 +08:00
|
|
|
extra = "../../build_release"
|
2017-09-12 21:25:43 +08:00
|
|
|
elif base == "libs":
|
2017-09-15 19:23:05 +08:00
|
|
|
extra = "../../libs"
|
2017-09-12 21:25:43 +08:00
|
|
|
elif base == "config":
|
2017-09-15 19:23:05 +08:00
|
|
|
extra = "../../config"
|
2017-09-12 21:25:43 +08:00
|
|
|
else:
|
|
|
|
extra = ""
|
|
|
|
return os.path.normpath(os.path.join(DIR_PATH, extra, path))
|
2017-10-19 18:39:41 +08:00
|
|
|
|
|
|
|
|
|
|
|
# Assign process to cpus passed by flag_name flag from args. If process is
|
|
|
|
# running on Apollo that flag is obligatory, otherwise is ignored. flag_name
|
|
|
|
# should not contain leading dashed.
|
|
|
|
def set_cpus(flag_name, process, args):
|
|
|
|
argp = ArgumentParser()
|
|
|
|
# named, optional arguments
|
|
|
|
argp.add_argument("--" + flag_name, nargs="+", type=int, help="cpus that "
|
|
|
|
"will be used by process. Obligatory on Apollo, ignored "
|
|
|
|
"otherwise.")
|
|
|
|
args, _ = argp.parse_known_args(args)
|
|
|
|
attr_flag_name = flag_name.replace("-", "_")
|
|
|
|
cpus = getattr(args, attr_flag_name)
|
|
|
|
assert not APOLLO or cpus, \
|
|
|
|
"flag --{} is obligatory on Apollo".format(flag_name)
|
|
|
|
if cpus:
|
|
|
|
process.set_cpus(cpus)
|