builder.pl 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730
  1. #!perl
  2. #NOTE: this script assumes you are running the Cygwin perl, which uses the
  3. # Cygwin file paths (i.e. '/' corresponds to 'C:\cygwin')
  4. my $WIN_INSTALLDIR="\\\\dimbo\\panda\\win";
  5. # $ENV{'USE_COMPILER'} = "INTEL"; # experiment
  6. # my $WIN_INSTALLDIR="\\\\cxgeorge-d01\\c\\win";
  7. ### DEBUG SETTINGS
  8. # my $DEBUG_TREECOPY = 1;
  9. my $DEBUG_GENERATE_PYTHON_CODE_ONLY = 0;
  10. #$DEBUG_GENERATE_PYTHON_CODE_ONLY=1;
  11. if ($ENV{'DEBUG_GENERATE_PYTHON_CODE_ONLY'} ne '') {
  12. $DEBUG_GENERATE_PYTHON_CODE_ONLY = 1;
  13. }
  14. # my $DO_ARCHIVE_AND_COPY_ONLY = 1;
  15. my $DONT_ARCHIVE_OLD_BUILDS = 0;
  16. my $BLD_DTOOL_ONLY=0;
  17. my $DIRPATH_SEPARATOR=':'; # set to ';' for non-cygwin NT perl
  18. my @inst_dirnames=("archive","debug","install","release","publish");
  19. my $ARCHIVENUM=0;
  20. my $DEBUGNUM=1;
  21. my $INSTALLNUM=2;
  22. my $RELEASENUM=3;
  23. my $PUBLISHNUM=4;
  24. my @inst_dirs;
  25. for(my $i=0;$i<=$#inst_dirnames;$i++) {
  26. $inst_dirs[$i]=$WIN_INSTALLDIR."\\".$inst_dirnames[$i];
  27. }
  28. #if(! $DEBUG_GENERATE_PYTHON_CODE_ONLY) {
  29. # $ENV{'PANDA_OPTIMIZE'}='4'; # var has meaning to my special Config.pp
  30. #}
  31. $ENV{'WINTOOLS'} = '/home/builder/player/wintools';
  32. #$ENV{'PPREMAKE_CONFIG'} = '/usr/local/etc/Config.pp'; old location
  33. $ENV{'PPREMAKE_CONFIG'} = $ENV{'WINTOOLS'}.'/panda/etc/Config.pp';
  34. $ENV{'TCSH_NO_CSHRC_CHDIR'}='1';
  35. $ENV{'ENABLE_PROFILING'}='1'; # generate .map files
  36. # needed to add this to fix version.rc path in ppremake?
  37. $ENV{'DTOOL'} = '/home/builder/player/dtool';
  38. $ENV{'HOME'}="/home/builder";
  39. $ENV{'USER'}="builder";
  40. $ENV{'USERNAME'}=$ENV{'USER'};
  41. my $DONT_ARCHIVE_OLD_BUILDS = (($ENV{'DONT_ARCHIVE_OLD_BUILDS'} ne "") || $DONT_ARCHIVE_OLD_BUILDS);
  42. sub logmsg() {
  43. my $msg = shift;
  44. print $msg."\n";
  45. open(LOGFILE,">>".$fulllogfilename) || die "can't open log file '$fulllogfilename'\n";
  46. print LOGFILE $msg."\n";
  47. close(LOGFILE);
  48. }
  49. #could change this to use eval, but it would require doubling the '\''s again in filename
  50. sub mychdir() {
  51. my $newdir = shift;
  52. my $retval = chdir($newdir);
  53. &logmsg("chdir(".$newdir.")");
  54. if(! $retval) {
  55. &logmsg("chdir(".$newdir.") failed!!");
  56. exit(1);
  57. }
  58. }
  59. sub mymkdir() {
  60. my $newdir=shift;
  61. if(!(-e $newdir)) {
  62. if(!mkdir($newdir,0xfff)) {
  63. &logmsg("cant create new dir '".$newdir."' !!");
  64. exit(1);
  65. }
  66. }
  67. }
  68. sub myrename() {
  69. my $n1 = shift;
  70. my $n2 = shift;
  71. my $retval;
  72. &logmsg("rename(".$n1.",".$n2.")");
  73. if(-e $n2) {
  74. # find name we can move old target to
  75. my $newnum=1;
  76. while(-e $n2.".old.".$newnum) {
  77. $newnum++;
  78. }
  79. $newconflicttargetname=$n2.".old.".$newnum;
  80. &logmsg("avoiding rename conflict, renaming old ".$n2." to ".$newconflicttargetname);
  81. $retval = rename($n2,$newconflicttargetname);
  82. if(! $retval) {
  83. &logmsg("rename failing, giving up (check if files or dirs are open in other apps)");
  84. exit(1);
  85. }
  86. }
  87. $retval = rename($n1,$n2);
  88. if(! $retval) {
  89. &logmsg("rename(".$n1.",".$n2.") failed!!! (check if files or dirs are open in other apps)");
  90. exit(1);
  91. }
  92. }
  93. sub myexecstr() {
  94. my $cmdstr = shift;
  95. my $errstr = shift;
  96. my $dologstr = shift;
  97. my $exec_cshrc_type = shift;
  98. if($dologstr eq "DO_LOG") {
  99. if($exec_cshrc_type eq "NT cmd") {
  100. $cmdstr.=" >> ".$fulllogfilename_win." 2>&1"; # 2>&1 tells nt cmd.exe to redirect stderr to stdout
  101. } else {
  102. $cmdstr.=" >>& ".$fulllogfilename; # for tcsh
  103. }
  104. &logmsg($cmdstr);
  105. }
  106. my $savedhome = $ENV{'HOME'};
  107. if( $exec_cshrc_type eq "NO_CSHRC") {
  108. # change $HOME so .cshrc doesn't get sources by tcsh
  109. $ENV{'HOME'}="/";
  110. } elsif( $exec_cshrc_type eq "NO_PANDA_ATTACH") {
  111. $ENV{'TCSH_NO_PANDA_ATTACH'}="1";
  112. }
  113. if($exec_cshrc_type eq "NT cmd") {
  114. my @args = ("cmd.exe", "/c", "$cmdstr");
  115. $retval = system(@args);
  116. } else {
  117. my @args = ("tcsh.exe", "-c", "$cmdstr");
  118. $retval = system(@args);
  119. }
  120. if($retval!=0) {
  121. if(($retval>=256) || ($retval<=-256)) {
  122. $retval= $retval/256; # actual retval
  123. }
  124. if($errstr eq "") {
  125. &logmsg($cmdstr." failed!!!!! continuing anyway...\nError return value=".$retval);
  126. } elsif($errstr ne "nomsg") {
  127. &logmsg($errstr."\nError return value=".$retval);
  128. exit($retval);
  129. }
  130. }
  131. if($exec_cshrc_type eq "NO_CSHRC") {
  132. $ENV{'HOME'}=$savedhome;
  133. } elsif( $exec_cshrc_type eq "NO_PANDA_ATTACH") {
  134. delete $ENV{'TCSH_NO_PANDA_ATTACH'};
  135. }
  136. }
  137. sub gettimestr() {
  138. my ($sec,$min,$hour,$mday,$mon,$year,$wday) = localtime(time);
  139. $mon++;
  140. return $mon."/".$mday." ".$hour.":".($min<10 ? "0":"").$min;
  141. }
  142. sub appendpath() {
  143. # note cygwin perl.exe requires ':' instead of ';' as path dir separator
  144. foreach $dir1 (@_) {
  145. $ENV{'PATH'}.=$DIRPATH_SEPARATOR.$CYGBLDROOT.$dir1;
  146. }
  147. }
  148. sub make_bsc_file() {
  149. &logmsg("*** Generating panda.bsc at ".&gettimestr()." ***");
  150. # &mychdir($CYGBLDROOT."/debug");
  151. # $outputdir=$WINBLDROOT."\\debug";
  152. &mychdir($CYGBLDROOT);
  153. $outputdir=$WINBLDROOT;
  154. $outputname="panda.bsc";
  155. $outputfilepath=$outputdir."\\".$outputname;
  156. $cmdfilepath=$outputdir."\\makebsc.txt";
  157. #open(FILES, "where -r . *.sbr |") || die "Couldn't run 'where'!\n";
  158. #requires unix/cygwin style find.exe
  159. open(FILES, "find ".$dirstodostr." -name \"*.sbr\" -print |") || die "Couldn't run 'find'!\n";
  160. open(OUTFILE, ">".$cmdfilepath) || die "Couldn't open ".$cmdfilepath."!\n";
  161. $filename = <FILES>; #skip initial line
  162. $filestr="";
  163. $duline = <FILES>;
  164. chop $duline;
  165. $filestr=$duline;
  166. while ($duline = <FILES>)
  167. {
  168. chop $duline; # Remove the newline from the end of the filename
  169. $filestr=$filestr."\n".$duline;
  170. }
  171. print OUTFILE "/n /o ".$outputfilepath." \n";
  172. print OUTFILE "$filestr","\n";
  173. close(OUTFILE);
  174. close(FILES);
  175. $bscmake_str="bscmake /o ".$outputfilepath." @".$cmdfilepath."\n";
  176. &myexecstr($bscmake_str,"bscmake failed!!!", "DO_LOG","NT cmd");
  177. &myexecstr("copy ".$outputfilepath." ".$inst_dirs[$DEBUGNUM], "copy of ".$outputfilepath." failed!!", "DO_LOG","NT cmd");
  178. unlink($cmdfilepath);
  179. &mychdir($CYGBLDROOT);
  180. }
  181. sub addpathsfromfile() {
  182. my $dirname = shift;
  183. my $envvarname = shift;
  184. my $pathfile=$WINBLDROOT."\\".$dirname."\\src\\configfiles\\".$dirname.".pth";
  185. if(!open(PTHFILE, $pathfile)) {
  186. &logmsg("Couldn't open ".$pathfile."!");
  187. exit(1);
  188. }
  189. my @filestrs=<PTHFILE>;
  190. close(PTHFILE);
  191. foreach my $i (@filestrs) {
  192. chop($i);
  193. $i =~ s/\//\\/g; # switch fwdslash to backslsh
  194. # print $i,"\n";
  195. $ENV{$envvarname}.=";".$WINBLDROOT."\\".$dirname."\\".$i;
  196. }
  197. }
  198. sub AddPckgPath() {
  199. my $pckg = shift;
  200. $ENV{'PATH'}.=":".$ENV{$pckg}."/bin:".$ENV{$pckg}."/lib";
  201. }
  202. sub gen_python_code() {
  203. &mychdir($CYGBLDROOT."/direct/bin");
  204. # ETC_PATH required by generatePythonCode?
  205. $ENV{'ETC_PATH'}='/home/builder/player/panda/etc /home/builder/player/direct/etc /home/builder/player/dtool/etc /home/builder/player/toontown/etc /home/builder/player/pandatool/etc';
  206. my $origpath=$ENV{'PATH'}; # save now, restore path after done
  207. # start new path just for this fn
  208. $ENV{'PATH'}="/bin";
  209. &AddPckgPath('WINTOOLS');
  210. &AddPckgPath('DTOOL');
  211. &AddPckgPath('PANDATOOL');
  212. &AddPckgPath('PANDA');
  213. &AddPckgPath('DIRECT');
  214. &AddPckgPath('TOONTOWN');
  215. # $ENV{'PATH'}=$ENV{'WINTOOLS'}."/bin:".$ENV{'WINTOOLS'}."/lib:/bin:/contrib/bin:/mscommon/Tools/WinNT:/mscommon/MSDev98/Bin:/mscommon/Tools:/msvc98/bin:/home/builder/player/dtool/bin:/home/builder/player/dtool/lib:/home/builder/player/direct/bin:/home/builder/player/direct/lib::/home/builder/player/toontown/bin:/home/builder/player/toontown/lib:/home/builder/player/panda/lib:/home/builder/player/panda/bin:/usr/local/bin:.:/c/WINNT/system32:/c/WINNT:/c/WINNT/System32/Wbem:/c/bin:/mspsdk/Bin/:/mspsdk/Bin/WinNT:/mscommon/Tools/WinNT:/mscommon/MSDev98/Bin:/mscommon/Tools:/msvc98/bin:/home/builder/scripts:/home/builder/player/pandatool/bin:/home/builder/player/pandatool/lib";
  216. $ENV{'PATH'}.=":/mscommon/Tools/WinNT:/mscommon/MSDev98/Bin:/mscommon/Tools:/msvc98/bin:/usr/local/bin:.:/c/WINNT/system32:/c/WINNT:/c/bin:/mspsdk/Bin/:/mspsdk/Bin/WinNT:/mscommon/Tools/WinNT:/mscommon/Tools:/home/builder/scripts:";
  217. $ENV{'PATH'}.=$ENV{'WINTOOLS'}."/sdk/python/Tcl/bin:".$ENV{'WINTOOLS'}."/sdk/python/Tcl/lib";
  218. $ENV{'PYTHONPATH'}= $WINBLDROOT."\\direct\\src\\showbase;".$WINBLDROOT."\\panda\\lib;".$WINBLDROOT."\\dtool\\lib;".$WINBLDROOT."\\wintools\\bin;".$WINBLDROOT."\\wintools\\lib;";
  219. $ENV{'PYTHONPATH'}.= $WINBLDROOT."\\wintools\\sdk\\python\\Python-2.0\\Lib;".$WINBLDROOT."\\wintools\\sdk\\python\\Python-2.0\\DLLs;";
  220. # direct/src/showbase/sitecustomize.py will add paths based on CTPROJS
  221. $ENV{'CTPROJS'}="TOONTOWN:personal DIRECT:personal PANDA:personal WINTOOLS:personal DTOOL:personal";
  222. # my $directsrcroot=$WINBLDROOT."\\direct\\src";
  223. # this should be unnecessary if sitecustomize.py sees CTPROJS
  224. # # add stuff from etc/[dir].pth
  225. # &addpathsfromfile("direct","PYTHONPATH");
  226. # &addpathsfromfile("toontown","PYTHONPATH");
  227. $ENV{'TCSH_NO_CHANGEPATH'}='1';
  228. # old way that tried to do genPyCode directly
  229. # $outputdir = $WINBLDROOT."\\direct\\lib\\py";
  230. # &mymkdir($outputdir);
  231. # $outputdir.= "\\Opt".$ENV{'PANDA_OPTIMIZE'}."-Win32";
  232. # &mymkdir($outputdir);
  233. # now back to 1 build-type per tree
  234. #
  235. # my $genpyth_str;
  236. # my $genargstr="-v -d";
  237. #
  238. # if(($ENV{'PANDA_OPTIMIZE'} eq '1') || ($ENV{'PANDA_OPTIMIZE'} eq '2')) {
  239. # $genpyth_str="python_d -v -OO ";
  240. # $genargstr="-O ".$genargstr;
  241. # } else {
  242. # $genpyth_str="python -v -O ";
  243. # $genargstr="-O ".$genargstr;
  244. # }
  245. # $genpyth_str.="generatePythonCode ".$genargstr." '".$outputdir."' -e '".$WINBLDROOT."\\direct\\src\\extensions' -i libdtoolconfig libpandaexpress libpanda libpandaphysics libdirect libtoontown";
  246. # &myexecstr($genpyth_str,"generate python code failed!!!","DO_LOG","NO_PANDA_ATTACH");
  247. $genpy_args{'1'} = 'win-debug';
  248. $genpy_args{'2'} = 'win-debug';
  249. $genpy_args{'3'} = 'win-release';
  250. $genpy_args{'4'} = 'win-publish';
  251. $genpy_arg1 = "-t ".$genpy_args{$ENV{'PANDA_OPTIMIZE'}};
  252. &myexecstr("genPyCode ".$genpy_arg1,"genPyCode failed","DO_LOG","NO_PANDA_ATTACH");
  253. $ENV{'PATH'}=$origpath;
  254. delete $ENV{'TCSH_NO_CHANGEPATH'};
  255. &mychdir($CYGBLDROOT);
  256. }
  257. my $newdayarchivedirname;
  258. sub archivetree() {
  259. $treenum=shift;
  260. if(!(-e $inst_dirs[$treenum])) {
  261. return;
  262. }
  263. if($newdayarchivename eq "") {
  264. ($devicenum,$inodenum,$mode,$nlink,$uid,$gid,$rdev,$size,$atime,$mtime,$ctime,$blksize,$blocks)
  265. = stat($inst_dirs[$treenum]."\\dtool\\Sources.pp");
  266. ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst)
  267. = localtime($mtime);
  268. $mon++;
  269. $newdayarchivedirname=$inst_dirs[$ARCHIVENUM]."\\".($mon<10 ? "0":"").$mon."-".($mday<10 ? "0":"").$mday;
  270. &mymkdir($newdayarchivedirname);
  271. }
  272. &logmsg("*** Archiving ".$inst_dirnames[$treenum]." build on install server at ".&gettimestr()." ***");
  273. my $archdirname=$newdayarchivedirname."\\".$inst_dirnames[$treenum];
  274. &myrename($inst_dirs[$treenum],$archdirname);
  275. foreach my $dir1 (@dirstodolist) {
  276. # copy DLL .pdb/.map up to lib dir so we can blow away metalibs subdir
  277. # could do this is the makefiles instead
  278. &myexecstr("( for /R ".$archdirname."\\".$dir1."\\metalibs %i in (lib*.pdb lib*.map) do copy %i ".$archdirname."\\".$dir1."\\lib )","nomsg","DO_LOG","NT cmd");
  279. if($dir1 eq "panda") {
  280. # dll/exe not under metalibs
  281. &myexecstr("( for /R ".$archdirname."\\".$dir1."\\src\\audiotraits %i in (lib*.pdb lib*.map) do copy %i ".$archdirname."\\".$dir1."\\lib )","nomsg","DO_LOG","NT cmd");
  282. &myexecstr("( for /R ".$archdirname."\\".$dir1."\\src\\shader %i in (lib*.pdb lib*.map) do copy %i ".$archdirname."\\".$dir1."\\lib )","nomsg","DO_LOG","NT cmd");
  283. &myexecstr("( for /R ".$archdirname."\\".$dir1."\\src\\testbed %i in (*.pdb *.map) do copy %i ".$archdirname."\\".$dir1."\\bin )","nomsg","DO_LOG","NT cmd");
  284. }
  285. # NT cmd 'for' always returns 144 for some reason, impossible to detect error cond, so just dont check retval
  286. # delete old objs/pdbs/etc out of archived trees (just blow away the Opt[Win32] dir)
  287. # &myexecstr("( for /D /R ".$archdirname."\\".$dir1."\\src %i in (Opt*Win32) do rd /s /q %i )","nomsg","DO_LOG","NT cmd");
  288. # instead blow away src,CVS,include,metalibs dirs completely
  289. # doing every rd twice since windows-samba-RAID link seems to screw up and cause some files to not be deleted the 1st time
  290. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\src","nomsg","DO_LOG","NT cmd");
  291. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\CVS","nomsg","DO_LOG","NT cmd");
  292. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\include","nomsg","DO_LOG","NT cmd");
  293. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\metalibs","nomsg","DO_LOG","NT cmd");
  294. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\src","nomsg","DO_LOG","NT cmd");
  295. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\CVS","nomsg","DO_LOG","NT cmd");
  296. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\include","nomsg","DO_LOG","NT cmd");
  297. &myexecstr("rd /s /q ".$archdirname."\\".$dir1."\\metalibs","nomsg","DO_LOG","NT cmd");
  298. # del xtra files at root of subdirs
  299. &myexecstr("del /Q /F ".$archdirname."\\".$dir1."\\*","nomsg","DO_LOG","NT cmd");
  300. }
  301. # delete old browse files
  302. &myexecstr("del /q ".$archdirname."\\*.bsc","nomsg","DO_LOG","NT cmd");
  303. # delete wintools, right now its too big to archive
  304. &myexecstr("rd /s /q ".$archdirname."\\wintools","nomsg","DO_LOG","NT cmd");
  305. &myexecstr("rd /s /q ".$archdirname."\\wintools","nomsg","DO_LOG","NT cmd");
  306. # could also move .pdb from metalibs to lib, then del metalibs, include, src dirs
  307. }
  308. sub checkoutfiles {
  309. my $existing_module_str="";
  310. my $nonexisting_module_str="";
  311. &mychdir($CYGBLDROOT);
  312. foreach my $dir1 (@dirstodolist) {
  313. if(-e $dir1) {
  314. $existing_module_str.=$dir1." ";
  315. } else {
  316. $nonexisting_module_str.=$dir1." ";
  317. }
  318. }
  319. if($existing_module_str ne "") {
  320. # flaw: will bomb if any CVS subdirs are missing
  321. &myexecstr("( for /D /R . %i in (Opt*Win32) do rd /s /q %i )","nomsg","DO_LOG","NT cmd");
  322. &logmsg("*** REMOVING ALL FILES IN OLD SRC TREES ***");
  323. # use cvs update to grab new copy
  324. # note: instead of blowing these away, may want to rename and save them
  325. # also, I could just blow everything away and check out again
  326. # cant blow away if people are sitting in those dirs, so we do this instead
  327. $rmcmd="find ".$existing_module_str." -path '*CVS*' -prune -or -not -name 'bldlog*' -and -not -type d -print | xargs --no-run-if-empty -n 40 rm";
  328. #&myexecstr($rmcmd,"Removal of old files failed!","DO_LOG","NO_CSHRC");
  329. &myexecstr($rmcmd,"Removal of old files failed!","DO_LOG","NO_PANDA_ATTACH");
  330. &myexecstr("cvs update -d -R ".$existing_module_str." |& egrep -v 'Updating|^\\?'",
  331. "cvs update failed!","DO_LOG","NO_PANDA_ATTACH");
  332. }
  333. if($nonexisting_module_str ne "") {
  334. &myexecstr("cvs checkout -R ".$nonexisting_module_str." |& egrep -v 'Updating|^\\?'",
  335. "cvs checkout failed!","DO_LOG","NO_PANDA_ATTACH");
  336. }
  337. }
  338. sub buildall() {
  339. $treenum=shift;
  340. # DTOOL ppremake may have already run by DTOOL 'initialize make'
  341. if($DO_ARCHIVE_AND_COPY_ONLY) {
  342. goto 'ARCHIVE_AND_COPY';
  343. }
  344. &logmsg("*** Starting ".uc($inst_dirnames[$treenum])." Build (Opt=".$ENV{'PANDA_OPTIMIZE'}.") at ".&gettimestr()." ***");
  345. &checkoutfiles();
  346. # cant do attachment, since that often hangs on NT
  347. # must use non-attachment build system (BUILD_TYPE 'gmsvc', not 'stopgap', in $PPREMAKE_CONFIG)
  348. # hacks to fix multiproc build issue (cp file to dir occurs before dir creation, need to adjust makefiles to fix this)
  349. foreach my $dir1 (@dirstodolist) {
  350. &mymkdir($CYGBLDROOT."/".$dir1."/etc");
  351. &mymkdir($CYGBLDROOT."/".$dir1."/bin");
  352. &mymkdir($CYGBLDROOT."/".$dir1."/lib");
  353. &mymkdir($CYGBLDROOT."/".$dir1."/include");
  354. }
  355. &mymkdir($CYGBLDROOT."/dtool/include/parser-inc"); # hack to fix makefile multiproc issue
  356. &mymkdir($CYGBLDROOT."/pandatool/shared"); # hack to fix makefile multiproc issue
  357. foreach my $dir1 (@dirstodolist) {
  358. my $dir1_upcase = uc($dir1);
  359. &logmsg("*** PPREMAKE ".$dir1_upcase." (BUILDTYPE=".$ENV{'PANDA_BUILD_TYPE'}.") ***");
  360. &mychdir($CYGBLDROOT."/".$dir1);
  361. &myexecstr("ppremake",$dir1_upcase." ppremake failed!","DO_LOG","NO_PANDA_ATTACH");
  362. }
  363. # debug stuff
  364. # &mychdir($CYGBLDROOT);
  365. # &myexecstr("dir dtool","dir failed","DO_LOG","NT cmd");
  366. $makecmd="make";
  367. $shellarg="NO_PANDA_ATTACH";
  368. if($ENV{'PANDA_BUILD_TYPE'} eq 'msvc') {
  369. $makecmd="nmake";
  370. $shellarg="NT cmd";
  371. }
  372. foreach my $dir1 (@dirstodolist) {
  373. my $dir1_upcase = uc($dir1);
  374. &logmsg("*** BUILDING ".$dir1_upcase." at ".&gettimestr()." ***");
  375. &mychdir($CYGBLDROOT."/".$dir1);
  376. &myexecstr($makecmd." install",$dir1_upcase." ".$makecmd." install failed!","DO_LOG",$shellarg);
  377. }
  378. &mychdir($CYGBLDROOT); # get out of src dirs to allow them to be moved/renamed
  379. unlink($CYGBLDROOT."/dtool/dtool_config.h"); # fix freakish NTFS bug, this file is regenerated by ppremake anyway
  380. if($#dirstodolist>1) {
  381. &gen_python_code(); # must run AFTER toontown bld
  382. }
  383. ARCHIVE_AND_COPY:
  384. &mychdir($CYGBLDROOT); # get out of src dirs to allow them to be moved/renamed
  385. # archive old current srvr build & copy build to server, if its accessible
  386. if(!(-e $WIN_INSTALLDIR)) {
  387. &logmsg("ERROR: Cant access install directory!! (Is Server down??) ".$WIN_INSTALLDIR);
  388. &logmsg("Skipping archive and copy-build-to-server steps for ".$inst_dirnames[$treenum]." build");
  389. return;
  390. }
  391. if($DONT_ARCHIVE_OLD_BUILDS) {
  392. &myexecstr("rd /s /q ".$inst_dirs[$treenum],"DO_LOG","NT cmd"); # dont bother checking errors here, probably just some shell has the dir cd'd to
  393. } else {
  394. &archivetree($treenum);
  395. }
  396. &logmsg("*** Copying ".$inst_dirnames[$treenum]." build to install server at ".&gettimestr()." ***");
  397. &mymkdir($inst_dirs[$treenum]);
  398. my $xcopy_opt_str="/E /K /C /R /Y /H /I ";
  399. if($DEBUG_TREECOPY) {
  400. $xcopy_opt_str.="/T "; #debug only
  401. }
  402. if($treenum == $DEBUGNUM) {
  403. # get rid of .sbr files before copying
  404. &myexecstr("echo .sbr > C:\\junk","echo .sbr failed!!", "DO_LOG","NT cmd");
  405. $xcopy_opt_str.=" /EXCLUDE:C:\\junk";
  406. }
  407. # hopefully there are no extra dirs underneath
  408. # add wintools to dir copy list
  409. # dont want to add wintools to global dirstodo, treat it separately
  410. unshift(dirstodolist,"wintools");
  411. foreach my $dir1 (@dirstodolist) {
  412. &mymkdir($inst_dirs[$treenum]."\\".$dir1);
  413. &myexecstr("\\WINNT\\system32\\xcopy ".$xcopy_opt_str." ".$WINBLDROOT."\\".$dir1."\\* ".$inst_dirs[$treenum]."\\".$dir1,
  414. "xcopy of ".$inst_dirnames[$treenum]." tree failed!!", "DO_LOG","NT cmd");
  415. }
  416. shift(dirstodolist);
  417. }
  418. # assumes environment already attached to TOOL/PANDA/DIRECT/TOONTOWN
  419. # assumes cygwin env, BLDROOT must use fwd slashes
  420. if($ENV{'BLDROOT'} eq "") {
  421. $ENV{'BLDROOT'} = "/home/builder/player";
  422. }
  423. if($ENV{'CYGWIN_ROOT'} eq "") {
  424. $ENV{'CYGWIN_ROOT'} = "C:\\Cygwin";
  425. }
  426. $CYGROOT= $ENV{'CYGWIN_ROOT'};
  427. $CYGROOT =~ s/(.*)\\$/$1/; # get rid of trailing '\'
  428. #$CYGROOT =~ s/\\/\//g; # switch backslash to fwdslash (setting up for cygwin)
  429. $CYGBLDROOT = $ENV{'BLDROOT'};
  430. print "\$CYGBLDROOT='",$CYGBLDROOT,"'\n";
  431. if(($CYGBLDROOT eq "")||(!(-e $CYGBLDROOT))) {
  432. die "Bad \$CYGBLDROOT !!\n";
  433. }
  434. $WINBLDROOT=$CYGROOT.$CYGBLDROOT;
  435. $WINBLDROOT =~ s/\//\\/g; # switch fwdslash to backslash
  436. print "\$WINBLDROOT='",$WINBLDROOT,"'\n";
  437. my ($sec,$min,$hour,$mday,$mon,$year,$wday) = localtime(time);
  438. $mon++;
  439. $logfilenamebase="bldlog-".($mon<10 ? "0":"").$mon."-".($mday<10 ? "0":"").$mday.".txt";
  440. $fulllogfilename = $CYGBLDROOT."/".$logfilenamebase;
  441. $fulllogfilename_win = $WINBLDROOT."\\".$logfilenamebase;
  442. # recreate the log to blow away any old one
  443. open(LOGFILE,">".$fulllogfilename) || die "can't open log file '$fulllogfilename'\n";
  444. close(LOGFILE);
  445. &logmsg("*** Panda Build Log Started at ".&gettimestr()." ***");
  446. my @do_install_dir;
  447. my @dir_build_type;
  448. for($ii=0;$ii<=$#PUBLISHNUM;$ii++) {
  449. if($#ARGV<0) {
  450. $do_install_dir=1;
  451. } else {
  452. $do_install_dir=0;
  453. }
  454. $dir_build_type=0;
  455. }
  456. my $g_last_dirnum=0;
  457. for($ii=0;$ii<=$#ARGV;$ii++) {
  458. if(uc($ARGV[$ii]) eq uc($inst_dirnames[$INSTALLNUM])) {
  459. $g_last_dirnum=$INSTALLNUM;
  460. } elsif(uc($ARGV[$ii]) eq uc($inst_dirnames[$DEBUGNUM])) {
  461. $g_last_dirnum=$DEBUGNUM;
  462. } elsif(uc($ARGV[$ii]) eq uc($inst_dirnames[$RELEASENUM])) {
  463. $g_last_dirnum=$RELEASENUM;
  464. } elsif(uc($ARGV[$ii]) eq uc($inst_dirnames[$PUBLISHNUM])) {
  465. $g_last_dirnum=$PUBLISHNUM;
  466. } elsif(uc($ARGV[$ii]) eq "NMAKE") {
  467. $dir_build_type[$g_last_dirnum]=1;
  468. next;
  469. } else {
  470. &logmsg("invalid argument '".$ARGV[0]."' to builder.pl. arg must be 'install','debug', or 'release', or 'publish'\n");
  471. exit(1);
  472. }
  473. $do_install_dir[$g_last_dirnum]=1;
  474. }
  475. if(!(-e $WIN_INSTALLDIR)) {
  476. &logmsg("ERROR: Cant access install directory!! ".$WIN_INSTALLDIR);
  477. exit(1);
  478. }
  479. &mychdir($CYGBLDROOT);
  480. if($BLD_DTOOL_ONLY) {
  481. @dirstodolist=("dtool");
  482. } else {
  483. @dirstodolist=("dtool","panda","pandatool","direct","toontown");
  484. }
  485. $dirstodostr="";
  486. foreach my $dir1 (@dirstodolist) {
  487. $dirstodostr.=$dir1." ";
  488. }
  489. # makes ppremake build headers, libs in module dirs (panda/lib,dtool/bin,etc), not /usr/local/panda/inc...
  490. foreach my $dir1 (@dirstodolist) {
  491. my $dir1_upcase = uc($dir1);
  492. $ENV{$dir1_upcase}=$CYGBLDROOT."/".$dir1;
  493. # need this since we are building in src dirs, not install dir
  494. # so 'interrogate' needs to find its dlls when building panda, etc
  495. &appendpath("/".$dir1."/bin","/".$dir1."/lib");
  496. }
  497. # pick up cygwin utils
  498. $ENV{'PATH'}=$ENV{'WINTOOLS'}."/bin".$DIRPATH_SEPARATOR.$ENV{'WINTOOLS'}."/lib".$DIRPATH_SEPARATOR."/bin".$DIRPATH_SEPARATOR."/contrib/bin".$DIRPATH_SEPARATOR.$ENV{'PATH'}."/c/WINNT/system32".$DIRPATH_SEPARATOR."/c/WINNT";
  499. # want build to pick up python dll's from /usr/lib before /c/python16
  500. # $ENV{'PATH'}="/usr/lib".$DIRPATH_SEPARATOR.$ENV{'PATH'}; not needed
  501. if(! $DEBUG_GENERATE_PYTHON_CODE_ONLY) {
  502. # update wintools
  503. unlink("wintools\\bin\\dos2unix.exe"); # rm a file so egrep doesnt find 0 non-Updating/?? lines and return failure
  504. &myexecstr("cvs update -d -R wintools |& egrep -v 'Updating|^\\?'", "cvs update failed!","DO_LOG","NO_PANDA_ATTACH");
  505. }
  506. if($DEBUG_TREECOPY) {
  507. goto 'DBGTREECOPY';
  508. }
  509. if($DEBUG_GENERATE_PYTHON_CODE_ONLY) {
  510. &gen_python_code();
  511. exit(0);
  512. }
  513. # goto 'SKIP_REMOVE';
  514. SKIP_REMOVE:
  515. # this doesnt work unless you can completely remove the dirs, since cvs checkout
  516. # bombs if dirs exist but CVS dirs do not.
  517. if($do_install_dir[$INSTALLNUM]) {
  518. if($dir_build_type[$INSTALLNUM]) {
  519. $ENV{'PANDA_BUILD_TYPE'} = 'msvc';
  520. } else {
  521. $ENV{'PANDA_BUILD_TYPE'} = 'gmsvc';
  522. }
  523. $ENV{'PANDA_OPTIMIZE'}='2';
  524. &buildall($INSTALLNUM);
  525. }
  526. if($do_install_dir[$RELEASENUM]) {
  527. if($dir_build_type[$RELEASENUM]) {
  528. $ENV{'PANDA_BUILD_TYPE'} = 'msvc';
  529. } else {
  530. $ENV{'PANDA_BUILD_TYPE'} = 'gmsvc';
  531. }
  532. $ENV{'PANDA_OPTIMIZE'}='3';
  533. &buildall($RELEASENUM);
  534. }
  535. BEFORE_DBGBUILD:
  536. if($do_install_dir[$DEBUGNUM]) {
  537. if($dir_build_type[$DEBUGNUM]) {
  538. $ENV{'PANDA_BUILD_TYPE'} = 'msvc';
  539. } else {
  540. $ENV{'PANDA_BUILD_TYPE'} = 'gmsvc';
  541. }
  542. $ENV{'USE_BROWSEINFO'}='1'; # make .sbr files
  543. if(! $DEBUG_GENERATE_PYTHON_CODE_ONLY) {
  544. $ENV{'PANDA_OPTIMIZE'}='1';
  545. }
  546. &buildall($DEBUGNUM);
  547. &make_bsc_file();
  548. delete $ENV{'USE_BROWSEINFO'};
  549. &myexecstr("del /s *.sbr","nomsg","DO_LOG","NT cmd");
  550. }
  551. AFTER_DBGBUILD:
  552. if($do_install_dir[$PUBLISHNUM]) {
  553. if($dir_build_type[$PUBLISHNUM]) {
  554. $ENV{'PANDA_BUILD_TYPE'} = 'msvc';
  555. } else {
  556. $ENV{'PANDA_BUILD_TYPE'} = 'gmsvc';
  557. }
  558. $ENV{'PANDA_OPTIMIZE'}='4';
  559. &buildall($PUBLISHNUM);
  560. }
  561. &logmsg("*** Panda Build Log Finished at ".&gettimestr()." ***");
  562. # store log in 'debug' dir
  563. &myexecstr("copy ".$fulllogfilename_win." ".$inst_dirs[$g_last_dirnum], "copy of ".$fulllogfilename_win." failed!!", "","NT cmd");
  564. exit(0);
  565. # TODO:
  566. # compress old archived blds?
  567. # build DLLs with version stamp set by this script
  568. # implement build-specific opttype mode