From 45e708a0ddc3309abce4034738014266c5bd20ad Mon Sep 17 00:00:00 2001 From: Joao Paulo Magalhaes Date: Thu, 23 Apr 2020 22:59:59 +0200 Subject: [PATCH] [wip] improving detection of proj dir and build dir --- src/c4/cmany/args.py | 20 ++++++++++++-------- src/c4/cmany/project.py | 35 +++++++++++++++++++++++++++++++++-- 2 files changed, 45 insertions(+), 10 deletions(-) diff --git a/src/c4/cmany/args.py b/src/c4/cmany/args.py index 99c0904..3018b5f 100644 --- a/src/c4/cmany/args.py +++ b/src/c4/cmany/args.py @@ -143,14 +143,18 @@ def _handle_hidden_args__skip_rest(args): # ----------------------------------------------------------------------------- def add_basic(parser): - parser.add_argument("proj_dir", nargs="?", default=".", - help="""the directory where the project's CMakeLists.txt - is located. An empty argument will default to the - current directory ie, \".\". Passing a directory which - does not contain a CMakeLists.txt will cause an error.""") - parser.add_argument("--build-dir", default="./build", - help="set the build root (defaults to ./build)") - parser.add_argument("--install-dir", default="./install", + parser.add_argument("-P", "--proj-dir", default=None, + help="""the directory where the project's + CMakeLists.txt is located. An empty argument will + default to the current directory ie, "." or, if + the current directory is a build directory containing + CMakeCache.txt, the source directory for that + build directory. Passing a directory which + does not contain a CMakeLists.txt or CMakeCache.txt + will cause an error.""") + parser.add_argument("-B", "--build-root", default="./build", + help="set the build root (defaults to ./build). ") + parser.add_argument("-I", "--install-root", default="./install", help="set the install root (defaults to ./install)") parser.add_argument("-j", "--jobs", default=cpu_count(), help="""use the given number of parallel jobs diff --git a/src/c4/cmany/project.py b/src/c4/cmany/project.py index fcc316e..36598c1 100644 --- a/src/c4/cmany/project.py +++ b/src/c4/cmany/project.py @@ -42,6 +42,25 @@ def _getdir(attr_name, default, kwargs, cwd): return d +def _is_cmake_folder(folder): + if folder is None: + return False + dbg("exists?", folder) + if not _pexists(folder): + dbg("does not exist:", folder) + return None + dbg("exists:", folder) + if _pexists(folder, "CMakeLists.txt"): + dbg("found CMakeLists.txt in", folder) + return folder + dbg("CMakeLists.txt not found in", folder) + if _pexists(folder, "CMakeCache.txt"): + dbg("found CMakeCache.txt in", folder) + return folder + dbg("CMakeCache.txt not found in", folder) + return None + + # ----------------------------------------------------------------------------- class Project: @@ -56,10 +75,18 @@ def __init__(self, **kwargs): pdir = kwargs.get('proj_dir') dbg("cwd:", cwd) dbg("proj_dir:", pdir) - if pdir is None: - raise err.ProjDirNotFound(None) if pdir == ".": pdir = cwd + elif pdir is None: + dbg("proj_dir not given") + if pdir is None and self.targets: + dbg("is the first target a cmake directory?", self.targets[0]) + pdir = _is_cmake_folder(self.targets[0]) + if pdir is not None: + self.targets = self.targets[1:] + if pdir is None: + dbg("picking current directory", cwd) + pdir = cwd pdir = util.abspath(pdir) dbg("proj_dir, abs:", pdir) # @@ -81,6 +108,10 @@ def __init__(self, **kwargs): self.install_dir = os.path.dirname(ch['CMAKE_INSTALL_PREFIX'].val) self.root_dir = ch['CMAKE_HOME_DIRECTORY'].val self.cmakelists = os.path.join(self.root_dir, "CMakeLists.txt") + else: + self.build_dir = None + self.install_dir = None + self.root_dir = pdir # dbg("root_dir:", self.root_dir) dbg("build_dir:", self.build_dir)