Added a profile build target (release with debug symbols).

Release doesn't have debug symbols anymore.
This commit is contained in:
Ferdinand Majerech 2011-10-26 06:39:06 +02:00
parent 60b57ca00d
commit 6eda5d9d4a

32
cdc.d
View file

@ -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"