xrdp/xorg/X11R7.6/buildx.sh

361 lines
8.9 KiB
Bash
Raw Normal View History

2011-11-18 08:57:45 +08:00
#!/bin/sh
2011-11-18 11:47:27 +08:00
# build.sh: a script for building X11R7.6 X server for use with xrdp #
2012-02-02 15:21:56 +08:00
# Copyright 2011-2012 Jay Sorg Jay.Sorg@gmail.com
2011-11-18 08:57:45 +08:00
#
# Authors
# Jay Sorg Jay.Sorg@gmail.com
# Laxmikant Rashinkar LK.Rashinkar@gmail.com
#
2011-11-18 08:57:45 +08:00
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
2011-11-18 08:57:45 +08:00
# http://www.apache.org/licenses/LICENSE-2.0
#
2011-11-18 08:57:45 +08:00
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
2011-11-18 11:47:27 +08:00
# flex bison libxml2-dev intltool
2011-11-19 11:55:50 +08:00
# xsltproc
2012-03-08 13:02:41 +08:00
# xutils-dev python-libxml2
2011-11-18 11:47:27 +08:00
2011-11-18 08:57:45 +08:00
download_file()
{
file=$1
cd downloads
echo "downloading file $file"
if [ "$file" = "pixman-0.15.20.tar.bz2" ]; then
wget -cq http://ftp.x.org/pub/individual/lib/$file
status=$?
cd ..
return $status
elif [ "$file" = "libdrm-2.4.26.tar.bz2" ]; then
wget -cq http://dri.freedesktop.org/libdrm/$file
status=$?
cd ..
return $status
elif [ "$file" = "MesaLib-7.10.3.tar.bz2" ]; then
wget -cq ftp://ftp.freedesktop.org/pub/mesa/7.10.3/$file
status=$?
cd ..
return $status
elif [ "$file" = "expat-2.0.1.tar.gz" ]; then
2012-03-09 12:23:50 +08:00
wget -cq http://server1.xrdp.org/xrdp/expat-2.0.1.tar.gz
2011-11-18 08:57:45 +08:00
status=$?
cd ..
return $status
elif [ "$file" = "freetype-2.4.6.tar.bz2" ]; then
wget -cq http://download.savannah.gnu.org/releases/freetype/freetype-2.4.6.tar.bz2
status=$?
cd ..
return $status
elif [ "$file" = "xkeyboard-config-2.0.tar.bz2" ]; then
2011-11-18 11:47:27 +08:00
wget -cq http://www.x.org/releases/individual/data/xkeyboard-config/xkeyboard-config-2.0.tar.bz2
status=$?
cd ..
return $status
elif [ "$file" = "makedepend-1.0.3.tar.bz2" ]; then
wget -cq http://xorg.freedesktop.org/releases/individual/util/makedepend-1.0.3.tar.bz2
2011-11-18 08:57:45 +08:00
status=$?
cd ..
return $status
2011-11-18 14:59:52 +08:00
elif [ "$file" = "libxml2-sources-2.7.8.tar.gz" ]; then
wget -cq ftp://ftp.xmlsoft.org/libxml2/libxml2-sources-2.7.8.tar.gz
status=$?
cd ..
return $status
2011-11-19 11:55:50 +08:00
elif [ "$file" = "Python-2.5.tar.bz2" ]; then
wget -cq http://www.python.org/ftp/python/2.5/Python-2.5.tar.bz2
status=$?
cd ..
return $status
2011-11-19 02:31:14 +08:00
elif [ "$file" = "Python-2.7.tar.bz2" ]; then
wget -cq http://www.python.org/ftp/python/2.7/Python-2.7.tar.bz2
2011-11-18 17:07:18 +08:00
status=$?
cd ..
return $status
2011-11-19 11:55:50 +08:00
elif [ "$file" = "expat-2.0.1.tar.gz" ]; then
wget -cq http://server1.xrdp.org/xrdp/expat-2.0.1.tar.gz
status=$?
cd ..
return $status
elif [ "$file" = "cairo-1.8.8.tar.gz" ]; then
wget -cq http://server1.xrdp.org/xrdp/cairo-1.8.8.tar.gz
status=$?
cd ..
return $status
elif [ "$file" = "libpng-1.2.46.tar.gz" ]; then
wget -cq http://server1.xrdp.org/xrdp/libpng-1.2.46.tar.gz
status=$?
cd ..
return $status
elif [ "$file" = "intltool-0.41.1.tar.gz" ]; then
wget -cq http://launchpad.net/intltool/trunk/0.41.1/+download/intltool-0.41.1.tar.gz
status=$?
cd ..
return $status
2011-11-19 16:21:09 +08:00
elif [ "$file" = "libxslt-1.1.26.tar.gz" ]; then
wget -cq ftp://xmlsoft.org/libxslt/libxslt-1.1.26.tar.gz
status=$?
cd ..
return $status
2011-11-20 12:57:52 +08:00
elif [ "$file" = "fontconfig-2.8.0.tar.gz" ]; then
wget -cq http://server1.xrdp.org/xrdp/fontconfig-2.8.0.tar.gz
status=$?
cd ..
return $status
2011-11-18 08:57:45 +08:00
else
wget -cq $download_url/$file
status=$?
cd ..
return $status
fi
}
remove_modules()
{
if [ -d cookies ]; then
rm cookies/*
fi
if [ ! -d build_dir ]; then
echo ""
echo "build_dir does not exist; nothing to delete"
echo ""
exit 0
fi
cd build_dir
while read line
do
mod_dir=`echo $line | cut -d':' -f2`
if [ -d $mod_dir ]; then
rm -rf $mod_dir
fi
done < ../$data_file
cd ..
}
make_it()
{
mod_file=$1
mod_name=$2
mod_args=$3
count=`expr $count + 1`
# if a cookie with $mod_name exists...
if [ -e cookies/$mod_name ]; then
# ...package has already been built
return 0
fi
echo ""
echo "*** processing module $mod_name ($count of $num_modules) ***"
echo ""
# download file
download_file $mod_file
if [ $? -ne 0 ]; then
echo ""
echo "failed to download $mod_file - aborting build"
echo ""
exit 1
fi
cd build_dir
# if pkg has not yet been extracted, do so now
if [ ! -d $mod_name ]; then
echo $mod_file | grep -q tar.bz2
if [ $? -eq 0 ]; then
tar xjf ../downloads/$mod_file > /dev/null 2>&1
else
tar xzf ../downloads/$mod_file > /dev/null 2>&1
fi
if [ $? -ne 0 ]; then
echo "error extracting module $mod_name"
exit 1
fi
fi
2011-11-19 11:55:50 +08:00
# patch and configure module - we only need to do this once
2011-11-18 08:57:45 +08:00
cd $mod_name
2011-11-19 11:55:50 +08:00
# check for patches
if [ -e ../../$mod_name.patch ]; then
2011-11-19 12:45:48 +08:00
patch -p1 < ../../$mod_name.patch
2011-11-19 11:55:50 +08:00
fi
# now configure
2012-03-08 13:02:41 +08:00
echo "executing ./configure --prefix=$PREFIX_DIR $mod_args"
2011-11-18 08:57:45 +08:00
./configure --prefix=$PREFIX_DIR $mod_args
if [ $? -ne 0 ]; then
echo "configuration failed for module $mn"
exit 1
fi
# make module
make
if [ $? -ne 0 ]; then
echo ""
echo "make failed for module $mod_name"
echo ""
exit 1
fi
# install module
make install
if [ $? -ne 0 ]; then
echo ""
echo "make install failed for module $mod_name"
echo ""
exit 1
fi
2011-11-19 11:55:50 +08:00
# special case after installing python make this sym link
# so Mesa builds using this python version
case "$mod_name" in
*Python-2*)
ln -s python $PREFIX_DIR/bin/python2
;;
esac
2011-11-18 08:57:45 +08:00
cd ../..
touch cookies/$mod_name
return 0
}
# this is where we store list of modules to be processed
data_file=x11_file_list.txt
# this is the default download location for most modules
download_url=http://www.x.org/releases/X11R7.6/src/everything
num_modules=`cat $data_file | wc -l`
count=0
##########################
# program flow starts here
##########################
if [ $# -lt 1 ]; then
echo ""
echo "usage: build.sh <installation dir>"
echo "usage: build.sh <clean>"
2012-02-02 15:21:56 +08:00
echo "usage: build.sh default"
echo "usage: build.sh <installation dir> drop - set env and run bash in rdp dir"
2011-11-18 08:57:45 +08:00
echo ""
exit 1
fi
# remove all modules
if [ "$1" = "clean" ]; then
echo "removing source modules"
remove_modules
exit 0
fi
2012-02-02 15:21:56 +08:00
if [ "$1" = "default" ]; then
export PREFIX_DIR=$PWD/staging
else
export PREFIX_DIR=$1
fi
if ! test -d $PREFIX_DIR; then
echo "dir does not exit, creating [$PREFIX_DIR]"
mkdir $PREFIX_DIR
if ! test $? -eq 0; then
echo "mkdir failed [$PREFIX_DIR]"
exit 0
fi
fi
echo "using $PREFIX_DIR"
2011-11-18 08:57:45 +08:00
export PKG_CONFIG_PATH=$PREFIX_DIR/lib/pkgconfig:$PREFIX_DIR/share/pkgconfig
2012-03-09 12:23:50 +08:00
export PATH=$PREFIX_DIR/bin:$PATH
export LDFLAGS=-Wl,-rpath=$PREFIX_DIR/lib
export CFLAGS="-I$PREFIX_DIR/include -fPIC -O2"
2011-11-18 08:57:45 +08:00
2011-11-18 11:47:27 +08:00
# prefix dir must exist...
2011-11-18 08:57:45 +08:00
if [ ! -d $PREFIX_DIR ]; then
2011-11-18 11:47:27 +08:00
mkdir -p $PREFIX_DIR
if [ $? -ne 0 ]; then
echo "$PREFIX_DIR does not exist; failed to create it - cannot continue"
exit 1
fi
2011-11-18 08:57:45 +08:00
fi
2011-11-18 11:47:27 +08:00
# ...and be writable
2011-11-18 08:57:45 +08:00
if [ ! -w $PREFIX_DIR ]; then
echo "directory $PREFIX_DIR is not writable - cannot continue"
exit 1
fi
# create a downloads dir
if [ ! -d downloads ]; then
mkdir downloads
if [ $? -ne 0 ]; then
echo "error creating downloads directory"
exit 1
fi
fi
# this is where we do the actual build
if [ ! -d build_dir ]; then
mkdir build_dir
if [ $? -ne 0 ]; then
echo "error creating build_dir directory"
exit 1
fi
fi
# this is where we store cookie files
if [ ! -d cookies ]; then
mkdir cookies
if [ $? -ne 0 ]; then
echo "error creating cookies directory"
exit 1
fi
fi
while read line
do
mod_file=`echo $line | cut -d':' -f1`
mod_dir=`echo $line | cut -d':' -f2`
mod_args=`echo $line | cut -d':' -f3`
2011-11-18 11:47:27 +08:00
mod_args=`eval echo $mod_args`
2011-11-18 08:57:45 +08:00
make_it $mod_file $mod_dir "$mod_args"
done < $data_file
2011-11-19 12:45:48 +08:00
2012-03-08 13:02:41 +08:00
echo "build for X OK"
X11RDPBASE=$PREFIX_DIR
export X11RDPBASE
cd rdp
make
# this will copy the build X server with the other X server binaries
strip X11rdp
cp X11rdp $X11RDPBASE/bin
if [ "$2" = "drop" ]; then
2012-03-08 13:02:41 +08:00
echo ""
2012-03-11 07:48:29 +08:00
echo "dropping you in dir, type exit to get out"
bash
2012-03-08 13:02:41 +08:00
exit 1
fi
2011-11-19 12:45:48 +08:00
echo "All done"