test fix
[catalyst.git] / catalyst
index b00f1c96cb3d78cdd89fa7847383545f1a312f0e..8337824ece92454a3e340f0b0aa58dacef6008ad 100755 (executable)
--- a/catalyst
+++ b/catalyst
@@ -2,91 +2,87 @@
 
 import os,sys,imp,string
 
-#This allows plugins (and this code) to import modules in the /modules dir
-sys.path.append(os.getcwd()+"/modules")
+def usage():
+       print "Usage: catalyst [-f file] [variable=value ...]"
+       print " -h --help               print this usage and exit"
+       print " -v --version            display version information"
+       print " -f --file               read specified file for build instructions"
+       print " variable=value          specify a variable/value pair"
 
-from catalyst_support import *
+def vers():
+       print "Gentoo catalyst, version "+version
+       print "Copyright 2003-2004 Gentoo Technologies, Inc."
+       print "Distributed under the GNU General Public License version 2"
 
-def usage():
-       print "usage: meep!"
+version="1.0"
 
 if len(sys.argv)==1 or sys.argv[1] in ["-h","--help"]:
        usage()
        sys.exit(1)
-"""
-Overview of catalyst operation
-==============================
-
-* The program starts, and the local machine type is detected. 
-
-* Based on this information, catalyst determines what kind of machine types
-  it can build for (amd64 and ia64 can build for x86 as well, for example.)
-  The appropriate arch plugins are loaded, which contain builder classes
-  for each supported sub-arch.
-
-* Command-line arguments are parsed. If specified, a spec file is read.
-
-* These build variables are stored in an internal "spec" object, which will
-  be a standard python dictionary. This spec dictionary contains all relevant
-  build-related information.
-
-* The spec object is passed to the appropriate target constructor.
-  The target constructor updates the spec object to contain data relevant
-  to the particular target (stage1, stage3, grp, etc.)
-
-*** PROTOTYPE CODE UP TO HERE IS COMPLETE (drobbins, 26 Oct '03)
-
-* The full data of the spec object is written to disc, so there is a complete
-  record of all variables that will be used to build what we're building.  This
-  will allow for another person to re-use this information to replicate our
-  work (it should be possible to distribute a spec file along with a portage
-  snapshot and a starter tarball, and our build can be replicated exactly on
-  any machine.) The spec object contains data like CFLAGS, CHOST, subarch,
-  mainarch, the profile used to build, and for GRP and LiveCDs the complete
-  package build list. This is important to allow work to be replicated. It's
-  possible that the stage1/2/3.sh and other scripts should be distributed as
-  well, to allow proper replication of work.
-
-* The build process begins by calling the appropriate method of the builder
-  instance. This includes cleanup, setup of chroot, entering the chroot,
-  running the appropriate bash build script, checking for error conditions,
-  and finishing up.
-  
-* The catalyst process is now complete :)
-"""
-
-#map current machine information from uname() to the mainarch we are running
-#under
-
-import targets
-targetmap={}
-targets.register(targetmap)
-
-print "Available targets:",string.join(targetmap.keys())
-
+elif sys.argv[1] in ["-v","--version"]:
+       vers()
+       sys.exit(1)
 if os.getuid()!=0:
        #non-root callers can't go any further than here. 
-       die("This script requires root privileges to operate.") 
+       print "catalyst: This script requires root privileges to operate."
+       sys.exit(1)
 
 myspec={}
-#these would come from /etc/catalyst.conf:
-myspec["storedir"]="/var/tmp/catalyst"
-myspec["sharedir"]="/usr/share/catalyst"
-#these would come from there too?:
-myspec["distdir"]="/usr/portage/distfiles"
-myspec["portdir"]="/usr/portage"
-
-#all the main program needs to do is figure out the target. The rest of the args go to the
-#target constructor
+myconf={}
+if os.path.exists("/etc/catalyst.conf"):
+       try:
+               execfile("/etc/catalyst.conf",myconf,myconf)
+       except:
+               print "catalyst: Unable to /etc/catalyst.conf config file (syntax error)"
+               sys.exit(1)
+
+confdefaults={ "storedir":"/var/tmp/catalyst","sharedir":"/usr/share/catalyst","distdir":"/usr/portage/distfiles",
+"portdir":"/usr/portage","options":"ccache"}
+
+for x in confdefaults.keys():
+       if myconf.has_key(x):
+               print "Setting",x,"to config file value \""+myconf[x]+"\""
+               myspec[x]=myconf[x]
+       else:
+               print "Setting",x,"to default value \""+confdefaults[x]+"\""
+               myspec[x]=confdefaults[x]
 
-#call target constructor, pass our "myspec" settings as well as cmdline arguments for parsing
-
-addlargs={}
-arg_parse(myspec,addlargs)
-if not targetmap.has_key(myspec["target"]):
-       raise CatalystError,"Target \""+myspec["target"]+"\" not available."
-mytarget=targetmap[myspec["target"]](myspec,addlargs)
-mytarget.run()
+#This allows plugins (and this code) to import modules in the /modules dir
+sys.path.append(myspec["sharedir"]+"/modules")
+try:
+       from catalyst_support import *
+       import targets
+except ImportError:
+       print "catalyst: python modules not found in "+myspec["sharedir"]+"/modules; exiting."
+       sys.exit(1)
 
-# ./catalyst subarch=pentium4 version_stamp=20031016 target=stage3 rel_type=default rel_version=1.4 snapshot=20031016 source_subpath=default-x86-1.4/stage2-pentium4-20031016
+targetmap={}
+targets.register(targetmap)
 
+if "ccache" in string.split(myspec["options"]):
+       if not os.path.exists("/root/.ccache"):
+               os.makedirs("/root/.ccache")
+       print "Compiler cache support enabled."
+       myspec["CCACHE"]="1"
+if "pkgcache" in string.split(myspec["options"]):
+       print "Package cache support enabled."
+       myspec["PKGCACHE"]="1"
+
+if sys.argv[1] in ["-f", "--file" ]:
+       try:
+               addlargs=read_spec(sys.argv[2])
+       except:
+               raise CatalystError,"Unable to read spec file: "+sys.argv[2]
+       unparsedargs=sys.argv[3:]
+else:
+       addlargs={}
+       unparsedargs=sys.argv[1:]
+try:
+       arg_parse(myspec,addlargs,unparsedargs)
+       if not targetmap.has_key(myspec["target"]):
+               raise CatalystError,"Target \""+myspec["target"]+"\" not available."
+       mytarget=targetmap[myspec["target"]](myspec,addlargs)
+       
+       mytarget.run()
+except CatalystError:
+       sys.exit(1)