]>
git.saurik.com Git - wxWidgets.git/blob - wxPython/distrib/all/build-all
   2 #---------------------------------------------------------------------- 
   4 # Purpose:     Master build script for building all the wxPython 
   5 #              installers and such on all the build machines in 
   6 #              my lab, and then distributing the results as needed. 
   8 #              This will replace the build-all bash script and is 
   9 #              needed because the needs of the build have outgrown 
  10 #              what I can do with bash. 
  14 # Created:     05-Nov-2004 
  16 # Copyright:   (c) 2004 by Total Control Software 
  17 # Licence:     wxWindows license 
  18 #---------------------------------------------------------------------- 
  23 from taskrunner 
import Job
, Task
, TaskRunner
, Config
 
  25 #---------------------------------------------------------------------- 
  28 CFGFILE 
= "./distrib/all/build-environ.cfg" 
  32 #---------------------------------------------------------------------- 
  33 # Define all the build tasks 
  38 #---------------------------------------------------------------------- 
  40 def getTasks(config_env
): 
  41     # Things that need to be done before any of the builds 
  43         Job("", "distrib/all/build-setup", env
=config_env
), 
  44         Job("", "distrib/all/build-docs", env
=config_env
), 
  45         Job("", "distrib/all/build-sources", env
=config_env
), 
  48     # Build tasks.  Anything that can be done in parallel (depends greatly 
  49     # on the nature of the build machines configurations...) is a separate 
  52 ##     jaguarTask = Task( Job("whopper.23", "distrib/all/build-osx", 
  53 ##                            [config.OSX_HOST_jaguar, "2.3", "ansi"], env=config_env) ) 
  55     pantherTask 
= Task( [ Job("bigmac.23",  
  56                               "distrib/all/build-osx", 
  57                               [config
.OSX_HOST_panther
, "2.3", "both"], env
=config_env
), 
  59                               "distrib/all/build-osx", 
  60                               [config
.OSX_HOST_panther
, "2.4", "both"], env
=config_env
) 
  63     tigerTask 
=  Task([ #Job("smallfry.23", 
  64                         #    "distrib/all/build-osx", 
  65                         #    [config.OSX_HOST_tiger, "2.3", "both"], env=config_env), 
  67                             "distrib/all/build-osx", 
  68                             [config
.OSX_HOST_tiger
, "2.4", "both", "universal"], env
=config_env
), 
  70                             "distrib/all/build-osx", 
  71                             [config
.OSX_HOST_tiger
, "2.5", "both", "universal"], env
=config_env
) 
  76         [ #Job("beast.23",     "distrib/all/build-windows", ["2.3"], env=config_env), 
  77 #          Job("co-rh9.23",    "distrib/all/build-rpm", ["beast", "co-rh9",   "rh9",   "2.3"], env=config_env), 
  78           Job("beast.24",     "distrib/all/build-windows", ["2.4"], env
=config_env
), 
  79 #          Job("co-rh9.24",    "distrib/all/build-rpm", ["beast", "co-rh9",   "rh9",   "2.4"], env=config_env), 
  80           Job("beast.25",     "distrib/all/build-windows", ["2.5"], env
=config_env
), 
  81           Job("co-mdk2006.24","distrib/all/build-rpm", ["beast", "co-mdk2006", "mdk2006", "2.4"], env
=config_env
), 
  85         [ #Job("co-fc2.23",    "distrib/all/build-rpm", ["beast", "co-fc2",     "fc2",     "2.3"], env=config_env), 
  86           Job("co-fc4.24",    "distrib/all/build-rpm", ["beast", "co-fc4",     "fc4",     "2.4"], env
=config_env
), 
  87           Job("co-mdk102.24", "distrib/all/build-rpm", ["beast", "co-mdk102",  "mdk102",  "2.4"], env
=config_env
), 
  88 #          Job("co-mdk2006.24","distrib/all/build-rpm", ["beast", "co-mdk2006", "mdk2006", "2.4"], env=config_env), 
  92         Job("xavier", "distrib/all/build-deb", ["xavier", "/work/chroot/dapper", "dapper"], env
=config_env
), 
  95     buildTasks 
= [ #jaguarTask, 
 103     # Finalization.  This is for things that must wait until all the 
 104     # builds are done, such as copying the installers someplace, sending 
 106     finalizationTask 
= Task( Job("", "distrib/all/build-finalize", env
=config_env
) ) 
 108     return initialTask
, buildTasks
, finalizationTask
 
 111 #---------------------------------------------------------------------- 
 115     print "Usage: build-all [command flags...]" 
 118     print "   dryrun       Do the build, but don't copy anywhere (default)" 
 119     print "   daily        Do a daily build, copy to starship" 
 120     print "   release      Do a normal release (cantidate) build, copy to starship" 
 122     print "optional command flags:" 
 123     print "   skipsource   Don't build the source archives, use the ones" 
 124     print "                already in the staging dir." 
 125     print "   onlysource   Exit after building the source and docs archives" 
 126     print "   skipdocs     Don't rebuild the docs" 
 127     print "   skipwin      Don't do the remote Windows build" 
 128     print "   skiposx      Don't do the remote OSX build" 
 129     print "   skiprpm      Don't do the remote Linux (RPM) build" 
 130     print "   skipdeb      Don't do the remote Linux (DEB) build" 
 131     print "   skipclean    Don't do the cleanup step on the remote builds" 
 132     print "   skipupload   Don't upload the builds to starship" 
 133     print "   ansi         Also do the ansi builds" 
 135     print "   nocohost     Don't start the coLinux sessions if they are" 
 136     print "                not already online" 
 140 #---------------------------------------------------------------------- 
 143     # Make sure we are running in the right directory.  TODO: make 
 144     # this test more robust.  Currenly we just test for the presence 
 145     # of 'wxPython' and 'wx' subdirs. 
 146     if not os
.path
.isdir("wxPython") or not os
.path
.isdir("wx"): 
 147         print "Please run this script from the root wxPython directory." 
 152     # Check command line flags 
 154         if flag 
in ["dryrun", "daily", "release"]: 
 157         elif flag 
== "skipsource": 
 158             config
.skipsource 
= "yes" 
 160         elif flag 
== "onlysource": 
 161             config
.onlysource 
= "yes" 
 163         elif flag 
== "skipdocs": 
 164             config
.skipdocs 
= "yes" 
 166         elif flag 
== "skipnewdocs": 
 167             config
.skipnewdocs 
= "yes" 
 169         elif flag 
== "skipwin": 
 170             config
.skipwin 
= "yes" 
 172         elif flag 
== "skiposx": 
 173             config
.skiposx 
= "yes" 
 175         elif flag 
== "skipdeb": 
 176             config
.skipdeb 
= "yes" 
 178         elif flag 
== "skiprpm": 
 179             config
.skiprpm 
= "yes" 
 181         elif flag 
== "skipclean": 
 182             config
.skipclean 
= "yes" 
 184         elif flag 
== "skipupload": 
 185             config
.skipupload 
= "yes" 
 188             config
.buildansi 
= "yes" 
 190         elif flag 
== "nocohost": 
 191             config
.startcohost 
= "no" 
 194             print 'Unknown flag: "%s"' % flag
 
 199     # ensure the staging area exists 
 200     if not os
.path
.exists(config
.STAGING_DIR
): 
 201         os
.makedirs(config
.STAGING_DIR
) 
 203     # Figure out the wxPython version number, possibly adjusted for being a daily build 
 204     if config
.KIND 
== "daily": 
 206         config
.DAILY 
= time
.strftime("%Y%m%d")   # should it include the hour too?  2-digit year? 
 207         file("DAILY_BUILD", "w").write(config
.DAILY
) 
 210     v 
= config
.VERSION 
= setup
.VERSION
 
 211     config
.VER2 
= '.'.join(v
.split('.')[:2]) 
 213     config_env 
= config
.asDict() 
 214     config_env
.update(os
.environ
) 
 216     initialTask
, buildTasks
, finalizationTask 
= getTasks(config_env
) 
 218     print "Build getting started at: ", time
.ctime() 
 220     # Run the first task, which will create the docs and sources tarballs 
 221     tr 
= TaskRunner(initialTask
) 
 224     # cleanup the DAILY_BUILD file 
 225     if config
.KIND 
== "daily": 
 226         os
.unlink("DAILY_BUILD") 
 229     if rc 
!= 0 or config
.onlysource 
== "yes": 
 233     # Run the main build tasks 
 234     tr 
= TaskRunner(buildTasks
) 
 240     # when all the builds are done, run the finalization task 
 241     tr 
= TaskRunner(finalizationTask
) 
 247     print "Build finished at: ", time
.ctime() 
 253 if __name__ 
== "__main__":