Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

183 lines
5.6 KiB

2 years ago
#!/usr/bin/env python
# @HEADER
# ************************************************************************
#
# TriBITS: Tribal Build, Integrate, and Test System
# Copyright 2013 Sandia Corporation
#
# Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
# the U.S. Government retains certain rights in this software.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# 3. Neither the name of the Corporation nor the names of the
# contributors may be used to endorse or promote products derived from
# this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
# EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
# ************************************************************************
# @HEADER
#
# Defaults
#
autoconfBaseName = "autoconf"
autoconfDefaultVersion = "2.69"
autoconfSupportedVersions = ["2.69"]
autoconfTarballVersions = {
"2.69" : "2.69"
}
#
# Script code
#
from InstallProgramDriver import *
from GeneralScriptSupport import *
class AutoconfInstall:
def __init__(self):
self.dummy = None
#
# Called before even knowing the product version
#
def getScriptName(self):
return "install-autoconf.py"
def getProductBaseName(self):
return autoconfBaseName
def getProductDefaultVersion(self):
return autoconfDefaultVersion
def getProductSupportedVersions(self):
return autoconfSupportedVersions
#
# Called after knowing the product version but before parsing the
# command-line.
#
def getProductName(self, version):
return autoconfBaseName+"-"+version
def getBaseDirName(self, version):
return autoconfBaseName+"-"+version+"-base"
def getExtraHelpStr(self, version):
return """
This script builds Autoconf"""+self.getProductName(version)+""" from source compiled with the
configured C compilers in your path.
NOTE: The assumed directory structure of the download source provided by the
command --download-cmnd=<download-cmnd> is:
autoconf-<version>-base/
autoconf-<full-version>.tar.gz
"""
def injectExtraCmndLineOptions(self, clp, version):
setStdDownloadCmndOption(self, clp, version)
clp.add_option(
"--extra-configure-options", dest="extraConfigureOptions", type="string", \
default="", \
help="Extra options to add to the 'configure' command for "+self.getProductName(version)+"." \
+" Note: This does not override the hard-coded configure options." )
def echoExtraCmndLineOptions(self, inOptions):
cmndLine = ""
cmndLine += " --download-cmnd='"+inOptions.downloadCmnd+"' \\\n"
cmndLine += " --extra-configure-options='"+inOptions.extraConfigureOptions+"' \\\n"
return cmndLine
#
# Called after parsing the command-line
#
def setup(self, inOptions):
self.inOptions = inOptions
self.baseDir = os.getcwd()
self.autoconfBaseDir = self.baseDir+"/"+self.getBaseDirName(self.inOptions.version)
autoconfVersionFull = autoconfTarballVersions[self.inOptions.version]
self.autoconfTarball = "autoconf-"+autoconfVersionFull+".tar.gz"
self.autoconfSrcDir = "autoconf-"+autoconfVersionFull
self.autoconfBuildBaseDir = self.autoconfBaseDir+"/autoconf-build"
self.scriptBaseDir = getScriptBaseDir()
#
# Called after setup()
#
def doDownload(self):
removeDirIfExists(self.autoconfBaseDir, True)
echoRunSysCmnd(self.inOptions.downloadCmnd)
def doUntar(self):
# Find the full name of the source tarball
echoChDir(self.autoconfBaseDir)
echoRunSysCmnd("tar -xzf "+self.autoconfTarball)
def doConfigure(self):
createDir(self.autoconfBuildBaseDir, True, True)
echoRunSysCmnd(
"../"+self.autoconfSrcDir+"/configure "+\
" "+self.inOptions.extraConfigureOptions+\
" --prefix="+self.inOptions.installDir,
extraEnv={"CFLAGS":"-O3"},
)
def doBuild(self):
echoChDir(self.autoconfBuildBaseDir)
echoRunSysCmnd("make " + getParallelOpt(self.inOptions, "-j") \
+ self.inOptions.makeOptions)
def doInstall(self):
echoChDir(self.autoconfBuildBaseDir)
echoRunSysCmnd("make " + getParallelOpt(self.inOptions, "-j") \
+ self.inOptions.makeOptions + " install")
def getFinalInstructions(self):
return """
To use the installed version of autoconf-"""+self.inOptions.version+""" add the path:
"""+self.inOptions.installDir+"""/bin
to your path and that should be it!
"""
#
# Executable statements
#
autoconfInstaller = InstallProgramDriver(AutoconfInstall())
autoconfInstaller.runDriver()