mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Use nmake's inline file creation to automate .rsp files.
This is noticeably faster than a sequence of 'echo' commands, because the file gets created all in one go. The most natural approach to this job would also hide the file's contents, but doing it this way with a 'type' command lets me see the file on nmake's standard output, so that the build log should still contain everything useful for debugging build problems.
This commit is contained in:
parent
a9f591eaa8
commit
7f95ebc0bf
20
mkfiles.pl
20
mkfiles.pl
@ -648,27 +648,25 @@ if (defined $makefiles{'vc'}) {
|
|||||||
foreach $p (&prognames("G:C")) {
|
foreach $p (&prognames("G:C")) {
|
||||||
($prog, $type) = split ",", $p;
|
($prog, $type) = split ",", $p;
|
||||||
$objstr = &objects($p, "X.obj", "X.res", undef);
|
$objstr = &objects($p, "X.obj", "X.res", undef);
|
||||||
print &splitline("$prog.exe: " . $objstr . " $prog.rsp"), "\n";
|
print &splitline("$prog.exe: " . $objstr), "\n";
|
||||||
print "\tlink \$(LFLAGS) \$(XLFLAGS) -out:$prog.exe -map:$prog.map \@$prog.rsp\n\n";
|
|
||||||
}
|
|
||||||
foreach $p (&prognames("G:C")) {
|
|
||||||
($prog, $type) = split ",", $p;
|
|
||||||
print $prog, ".rsp: \$(MAKEFILE)\n";
|
|
||||||
$objstr = &objects($p, "X.obj", "X.res", "X.lib");
|
$objstr = &objects($p, "X.obj", "X.res", "X.lib");
|
||||||
|
$subsys = ($type eq "G") ? "windows" : "console";
|
||||||
|
$inlinefilename = "link_$prog";
|
||||||
|
print "\ttype <<$inlinefilename\n";
|
||||||
@objlist = split " ", $objstr;
|
@objlist = split " ", $objstr;
|
||||||
@objlines = ("");
|
@objlines = ("");
|
||||||
foreach $i (@objlist) {
|
foreach $i (@objlist) {
|
||||||
if (length($objlines[$#objlines] . " $i") > 50) {
|
if (length($objlines[$#objlines] . " $i") > 72) {
|
||||||
push @objlines, "";
|
push @objlines, "";
|
||||||
}
|
}
|
||||||
$objlines[$#objlines] .= " $i";
|
$objlines[$#objlines] .= " $i";
|
||||||
}
|
}
|
||||||
$subsys = ($type eq "G") ? "windows" : "console";
|
|
||||||
print "\techo /nologo /subsystem:$subsys > $prog.rsp\n";
|
|
||||||
for ($i=0; $i<=$#objlines; $i++) {
|
for ($i=0; $i<=$#objlines; $i++) {
|
||||||
print "\techo$objlines[$i] >> $prog.rsp\n";
|
print "$objlines[$i]\n";
|
||||||
}
|
}
|
||||||
print "\n";
|
print "<<\n";
|
||||||
|
print "\tlink \$(LFLAGS) \$(XLFLAGS) -out:$prog.exe -map:$prog.map -nologo -subsystem:$subsys \@$inlinefilename\n\n";
|
||||||
}
|
}
|
||||||
foreach $d (&deps("X.obj", "X.res", $dirpfx, "\\", "vc")) {
|
foreach $d (&deps("X.obj", "X.res", $dirpfx, "\\", "vc")) {
|
||||||
$extradeps = $forceobj{$d->{obj_orig}} ? ["*.c","*.h","*.rc"] : [];
|
$extradeps = $forceobj{$d->{obj_orig}} ? ["*.c","*.h","*.rc"] : [];
|
||||||
|
Loading…
Reference in New Issue
Block a user