summaryrefslogtreecommitdiffstats
path: root/BaseTools/BuildEnv
diff options
context:
space:
mode:
authorjljusten <jljusten@6f19259b-4bc3-4df7-8a09-765794883524>2007-12-11 09:03:30 +0000
committerjljusten <jljusten@6f19259b-4bc3-4df7-8a09-765794883524>2007-12-11 09:03:30 +0000
commit66dcb2f08a49419bd5857459fbd3de7b983b6605 (patch)
tree98263a0cc29c984054092f034ae004956e509fb4 /BaseTools/BuildEnv
parentb2c5e194a80f85c733a57814dece83a4b816f07b (diff)
downloadedk2-66dcb2f08a49419bd5857459fbd3de7b983b6605.tar.gz
edk2-66dcb2f08a49419bd5857459fbd3de7b983b6605.tar.bz2
edk2-66dcb2f08a49419bd5857459fbd3de7b983b6605.zip
modified edk2/BaseTools/BuildEnv:
deleted edk2/BaseTools/BuildEnv.py: Resolve https://edk2.tianocore.org/servlets/Scarab/id/EDKT557 "All code in the edk2 tree must not require third party tools for running the provided tools." which refers to the usage of python by BuildEnv.py. /sigh git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@4386 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'BaseTools/BuildEnv')
-rw-r--r--BaseTools/BuildEnv264
1 files changed, 243 insertions, 21 deletions
diff --git a/BaseTools/BuildEnv b/BaseTools/BuildEnv
index 08a84d4352..8e7343a73b 100644
--- a/BaseTools/BuildEnv
+++ b/BaseTools/BuildEnv
@@ -8,32 +8,254 @@
# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+#
# Setup the environment for unix-like systems running a bash-like shell.
# This file must be "sourced" not merely executed. For example: ". edksetup.sh"
+#
-if [ ! -e ./BaseTools/BuildEnv.py ]
-then
- echo Run this script from the base of your tree. For example:
- echo " cd /Path/To/Edk/Root"
- echo " . BaseTools/BuildEnv"
- return
-fi
+SetWorkspace() {
-#
-# First, we run a python tool that will ask the user to configure
-# the environment in a (relatively) user friendly manner.
-#
-python ./BaseTools/BuildEnv.py $*
+ #
+ # If WORKSPACE is already set, then we can return right now
+ #
+ if [ -n "$WORKSPACE" ]
+ then
+ return 0
+ fi
+
+ if [ ! ${BASH_SOURCE[0]} -ef ./BaseTools/BuildEnv ]
+ then
+ echo Run this script from the base of your tree. For example:
+ echo " cd /Path/To/Edk/Root"
+ echo " . BaseTools/BuildEnv"
+ return -1
+ fi
+
+ #
+ # Set $WORKSPACE
+ #
+ export WORKSPACE=`pwd`
+
+ return 0
+
+}
+
+RestorePreviousConfiguration() {
+ #
+ # Restore previous configuration
+ #
+ PREVIOUS_CONF_FILE=Conf/BuildEnv.sh2
+ if [ -e $PREVIOUS_CONF_FILE ]
+ then
+ echo Loading previous configuration from \$WORKSPACE/$PREVIOUS_CONF_FILE
+ . $WORKSPACE/$PREVIOUS_CONF_FILE
+ fi
+}
+
+GenerateShellCodeToSetVariable() {
+ VARIABLE=$1
+ OUTPUT_FILE=$2
+ VAR_VALUE="echo \${${VARIABLE}}"
+ VAR_VALUE=`eval $VAR_VALUE`
+ echo "if [ -z \"\$${VARIABLE}\" ]" >> $OUTPUT_FILE
+ echo "then" >> $OUTPUT_FILE
+ echo " export ${VARIABLE}=${VAR_VALUE}" >> $OUTPUT_FILE
+ echo "fi" >> $OUTPUT_FILE
+}
+
+GenerateShellCodeToUpdatePath() {
+ OUTPUT_FILE=$1
+ echo "if [ -e $EDK_TOOLS_PATH_BIN ]" >> $OUTPUT_FILE
+ echo "then" >> $OUTPUT_FILE
+ echo " if [ "\${PATH/$EDK_TOOLS_PATH_BIN/}" == "\$PATH" ]" >> $OUTPUT_FILE
+ echo " then" >> $OUTPUT_FILE
+ echo " export PATH=$EDK_TOOLS_PATH_BIN:\$PATH" >> $OUTPUT_FILE
+ echo " fi" >> $OUTPUT_FILE
+ echo "fi" >> $OUTPUT_FILE
+}
+
+StoreCurrentConfiguration() {
+ #
+ # Write configuration to a shell script to allow for configuration to be
+ # easily reloaded.
+ #
+ OUTPUT_FILE=Conf/BuildEnv.sh2
+ #echo Storing current configuration into \$WORKSPACE/$OUTPUT_FILE
+ OUTPUT_FILE=$WORKSPACE/$OUTPUT_FILE
+ echo "# Auto-generated by ${BASH_SOURCE[0]}" > $OUTPUT_FILE
+ GenerateShellCodeToSetVariable WORKSPACE $OUTPUT_FILE
+ GenerateShellCodeToSetVariable EDK_TOOLS_PATH $OUTPUT_FILE
+ GenerateShellCodeToUpdatePath $OUTPUT_FILE
+}
+
+SetEdkToolsPath() {
+
+ #
+ # If EDK_TOOLS_PATH is already set, then we can return right now
+ #
+ if [ -n "$EDK_TOOLS_PATH" ]
+ then
+ return 0
+ fi
+
+ #
+ # Figure out a uniq directory name from the uname command
+ #
+ UNAME_DIRNAME=`uname -sm`
+ UNAME_DIRNAME=${UNAME_DIRNAME// /-}
+ UNAME_DIRNAME=${UNAME_DIRNAME//\//-}
+
+ #
+ # Try $WORKSPACE/Conf/EdkTools
+ #
+ if [ -e $WORKSPACE/Conf/EdkTools ]
+ then
+ export EDK_TOOLS_PATH=$WORKSPACE/Conf/EdkTools
+ return 0
+ fi
+
+ #
+ # Try $WORKSPACE/Conf/BaseToolsSource
+ #
+ if [ -e $WORKSPACE/Conf/BaseToolsSource ]
+ then
+ export EDK_TOOLS_PATH=$WORKSPACE/Conf/BaseToolsSource
+ return 0
+ fi
+
+ #
+ # Try $WORKSPACE/BaseTools/Bin/$UNAME_DIRNAME
+ #
+ if [ -e $WORKSPACE/BaseTools/Bin/$UNAME_DIRNAME ]
+ then
+ export EDK_TOOLS_PATH=$WORKSPACE/BaseTools
+ return 0
+ fi
+
+ echo "Unable to determine EDK_TOOLS_PATH"
+ echo
+ echo "You may need to download the 'BaseTools' from buildtools.tianocore.org."
+ echo "After downloading, either create a symbolic link to the source at"
+ echo "\$WORKSPACE/Conf/BaseToolsSource, or set the EDK_TOOLS_PATH environment"
+ echo "variable."
+
+}
+
+GetBaseToolsBinSubDir() {
+ #
+ # Figure out a uniq directory name from the uname command
+ #
+ UNAME_DIRNAME=`uname -sm`
+ UNAME_DIRNAME=${UNAME_DIRNAME// /-}
+ UNAME_DIRNAME=${UNAME_DIRNAME//\//-}
+ echo $UNAME_DIRNAME
+}
+
+GetEdkToolsPathBinDirectory() {
+ #
+ # Figure out a uniq directory name from the uname command
+ #
+ BIN_SUB_DIR=`GetBaseToolsBinSubDir`
+
+ if [ -e $EDK_TOOLS_PATH/PseudoBin/$BIN_SUB_DIR ]
+ then
+ EDK_TOOLS_PATH_BIN=$EDK_TOOLS_PATH/PseudoBin/$BIN_SUB_DIR
+ else
+ EDK_TOOLS_PATH_BIN=$EDK_TOOLS_PATH/Bin/$BIN_SUB_DIR
+ fi
+
+ echo $EDK_TOOLS_PATH_BIN
+}
+
+AddEdkToolsToPath() {
+
+ #
+ # If EDK_TOOLS_PATH is not set, then we cannot update PATH
+ #
+ if [ -z "$EDK_TOOLS_PATH" ]
+ then
+ return -1
+ fi
+
+ EDK_TOOLS_PATH_BIN=`GetEdkToolsPathBinDirectory`
+
+ if [ ! -e $EDK_TOOLS_PATH_BIN ]
+ then
+ echo "Unable to find expected bin path under \$EDK_TOOLS_PATH!"
+ echo "> $EDK_TOOLS_PATH_BIN"
+ return -1
+ fi
+
+ if [ "${PATH/$EDK_TOOLS_PATH_BIN/}" == "$PATH" ]
+ then
+ export PATH=$EDK_TOOLS_PATH_BIN:$PATH
+ return 0
+ fi
+
+}
+
+CopySingleTemplateFile() {
+
+ SRC_FILENAME=BaseTools/Conf/$1.template
+ DST_FILENAME=Conf/$1.txt
+
+ if [ -e $WORKSPACE/$DST_FILENAME ]
+ then
+ return
+ fi
+
+ echo "Copying \$WORKSPACE/$SRC_FILENAME"
+ echo " to \$WORKSPACE/$DST_FILENAME"
+ SRC_FILENAME=$WORKSPACE/$SRC_FILENAME
+ DST_FILENAME=$WORKSPACE/$DST_FILENAME
+ cp $SRC_FILENAME $DST_FILENAME
+
+}
+
+CopyTemplateFiles() {
+
+ CopySingleTemplateFile build_rule
+ CopySingleTemplateFile FrameworkDatabase
+ CopySingleTemplateFile tools_def
+ CopySingleTemplateFile target
+
+}
+
+ScriptMain() {
+
+ SetWorkspace
+ if [ -z $WORKSPACE ]
+ then
+ echo "Failure setting WORKSPACE"
+ return -1
+ fi
+
+ RestorePreviousConfiguration
+
+ SetEdkToolsPath
+ if [ -z $EDK_TOOLS_PATH ]
+ then
+ return -1
+ fi
+
+ AddEdkToolsToPath
+ if [ $? -ne 0 ]
+ then
+ echo "Failure adding EDK Tools into PATH!"
+ return -1
+ fi
+
+ StoreCurrentConfiguration
+
+ echo WORKSPACE: $WORKSPACE
+ echo EDK_TOOLS_PATH: $EDK_TOOLS_PATH
+
+ CopyTemplateFiles
+
+}
#
-# The python tool will write ./Conf/BuildEnv.sh to actually configure
-# the environment.
+# Run the main function
#
-if [ -e ./Conf/BuildEnv.sh ]
-then
- . ./Conf/BuildEnv.sh
-else
- echo There was a failure while trying to setup the environment!
-fi
-
+ScriptMain