Merge pull request #40 from pupil1337/clean-compiledb
commit
25b371e573
33
SConstruct
33
SConstruct
|
@ -5,15 +5,6 @@ import sys
|
|||
from methods import print_error
|
||||
|
||||
|
||||
def normalize_path(val, env):
|
||||
return val if os.path.isabs(val) else os.path.join(env.Dir("#").abspath, val)
|
||||
|
||||
|
||||
def validate_parent_dir(key, val, env):
|
||||
if not os.path.isdir(normalize_path(os.path.dirname(val), env)):
|
||||
raise UserError("'%s' is not a directory: %s" % (key, os.path.dirname(val)))
|
||||
|
||||
|
||||
libname = "EXTENSION-NAME"
|
||||
projectdir = "demo"
|
||||
|
||||
|
@ -23,33 +14,11 @@ customs = ["custom.py"]
|
|||
customs = [os.path.abspath(path) for path in customs]
|
||||
|
||||
opts = Variables(customs, ARGUMENTS)
|
||||
opts.Add(
|
||||
BoolVariable(
|
||||
key="compiledb",
|
||||
help="Generate compilation DB (`compile_commands.json`) for external tools",
|
||||
default=localEnv.get("compiledb", False),
|
||||
)
|
||||
)
|
||||
opts.Add(
|
||||
PathVariable(
|
||||
key="compiledb_file",
|
||||
help="Path to a custom `compile_commands.json` file",
|
||||
default=localEnv.get("compiledb_file", "compile_commands.json"),
|
||||
validator=validate_parent_dir,
|
||||
)
|
||||
)
|
||||
opts.Update(localEnv)
|
||||
|
||||
Help(opts.GenerateHelpText(localEnv))
|
||||
|
||||
env = localEnv.Clone()
|
||||
env["compiledb"] = False
|
||||
|
||||
env.Tool("compilation_db")
|
||||
compilation_db = env.CompilationDatabase(
|
||||
normalize_path(localEnv["compiledb_file"], localEnv)
|
||||
)
|
||||
env.Alias("compiledb", compilation_db)
|
||||
|
||||
submodule_initialized = False
|
||||
dir_name = 'godot-cpp'
|
||||
|
@ -92,6 +61,4 @@ library = env.SharedLibrary(
|
|||
copy = env.InstallAs("{}/bin/{}/{}lib{}".format(projectdir, env["platform"], filepath, file), library)
|
||||
|
||||
default_args = [library, copy]
|
||||
if localEnv.get("compiledb", False):
|
||||
default_args += [compilation_db]
|
||||
Default(*default_args)
|
||||
|
|
Loading…
Reference in New Issue