Added a profile build target (release with debug symbols).
Release doesn't have debug symbols anymore.
This commit is contained in:
parent
60b57ca00d
commit
6eda5d9d4a
32
cdc.d
32
cdc.d
|
@ -138,7 +138,7 @@ void main(string[] args)
|
||||||
|
|
||||||
scope(failure){help(); core.stdc.stdlib.exit(-1);}
|
scope(failure){help(); core.stdc.stdlib.exit(-1);}
|
||||||
|
|
||||||
string[] extra_args = ["-gc", "-w", "-wi"];
|
string[] extra_args = ["-w", "-wi"];
|
||||||
|
|
||||||
args = args[1 .. $];
|
args = args[1 .. $];
|
||||||
foreach(arg; args)
|
foreach(arg; args)
|
||||||
|
@ -154,11 +154,15 @@ void main(string[] args)
|
||||||
}
|
}
|
||||||
if(args.length > 0 && args[$ - 1][0] != '-'){target = args[$ - 1];}
|
if(args.length > 0 && args[$ - 1][0] != '-'){target = args[$ - 1];}
|
||||||
|
|
||||||
string[] dbg = ["-debug"];
|
string[] dbg = ["-debug", "-gc"];
|
||||||
string[] optimize = ["-O", "-inline", "-release"];
|
string[] optimize = ["-O", "-inline", "-release"];
|
||||||
|
string[] profile = ["-O", "-inline", "-release", "-gc"];
|
||||||
string[] lib_src = ["dyaml/", "yaml.d"];
|
string[] lib_src = ["dyaml/", "yaml.d"];
|
||||||
|
|
||||||
void compile_(string[] args, string[] files){compile(files, args ~ extra_args);}
|
void compile_(string[] args, string[] files)
|
||||||
|
{
|
||||||
|
compile(files, args ~ extra_args);
|
||||||
|
}
|
||||||
|
|
||||||
void build_unittest()
|
void build_unittest()
|
||||||
{
|
{
|
||||||
|
@ -178,6 +182,12 @@ void main(string[] args)
|
||||||
compile_(optimize ~ ["-oflibdyaml", "-lib"], lib_src);
|
compile_(optimize ~ ["-oflibdyaml", "-lib"], lib_src);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void build_profile()
|
||||||
|
{
|
||||||
|
writeln("building profile target");
|
||||||
|
compile_(profile ~ ["-oflibdyaml", "-lib"], lib_src);
|
||||||
|
}
|
||||||
|
|
||||||
void build_tar_gz()
|
void build_tar_gz()
|
||||||
{
|
{
|
||||||
if(system("git archive HEAD | gzip -9v > dyaml.tar.gz") != 0)
|
if(system("git archive HEAD | gzip -9v > dyaml.tar.gz") != 0)
|
||||||
|
@ -204,13 +214,11 @@ void main(string[] args)
|
||||||
|
|
||||||
void build(string[] targets ...)
|
void build(string[] targets ...)
|
||||||
{
|
{
|
||||||
foreach(target; targets)
|
foreach(target; targets) switch(target)
|
||||||
{
|
{
|
||||||
switch(target)
|
|
||||||
{
|
|
||||||
//case "examples": build_examples(); break;
|
|
||||||
case "debug": build_debug(); break;
|
case "debug": build_debug(); break;
|
||||||
case "release": build_release(); break;
|
case "release": build_release(); break;
|
||||||
|
case "profile": build_profile(); break;
|
||||||
case "unittest": build_unittest(); break;
|
case "unittest": build_unittest(); break;
|
||||||
case "tar.gz": build_tar_gz(); break;
|
case "tar.gz": build_tar_gz(); break;
|
||||||
case "tar.xz": build_tar_xz(); break;
|
case "tar.xz": build_tar_xz(); break;
|
||||||
|
@ -221,7 +229,6 @@ void main(string[] args)
|
||||||
writeln("available targets: 'debug', 'release', 'all'");
|
writeln("available targets: 'debug', 'release', 'all'");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
try{build(target);}
|
try{build(target);}
|
||||||
catch(CompileException e){writeln("Could not compile: " ~ e.msg);}
|
catch(CompileException e){writeln("Could not compile: " ~ e.msg);}
|
||||||
|
@ -245,11 +252,12 @@ void help()
|
||||||
"Available build targets:\n"
|
"Available build targets:\n"
|
||||||
" unittest Build unit tests.\n"
|
" unittest Build unit tests.\n"
|
||||||
" debug Debug information, unittests, contracts built in.\n"
|
" debug Debug information, unittests, contracts built in.\n"
|
||||||
" No optimizations. Target binary name: 'pong-debug'\n"
|
" No optimizations.\n"
|
||||||
" release Debug information, no unittests, contracts.\n"
|
" release No debug information, no unittests, contracts.\n"
|
||||||
" Optimizations, inlining enabled.\n"
|
" Optimizations, inlining enabled.\n"
|
||||||
" Target binary name: 'pong-release'\n"
|
" profile Debug information, no unittests, contracts.\n"
|
||||||
" all All of the above.\n"
|
" Optimizations, inlining enabled.\n"
|
||||||
|
" all Unittest, debug and release.\n"
|
||||||
" tar.gz Needs git, gzip: Create a tar.gz package.\n"
|
" tar.gz Needs git, gzip: Create a tar.gz package.\n"
|
||||||
" tar.xz Needs git, xz: Create a tar.xz package.\n"
|
" tar.xz Needs git, xz: Create a tar.xz package.\n"
|
||||||
" zip Needs zip: Create a zip package.\n"
|
" zip Needs zip: Create a zip package.\n"
|
||||||
|
|
Loading…
Reference in a new issue