xrdp/xorg/X11R7.6/buildx.sh

310 lines
6.7 KiB
Bash
Raw Normal View History

2011-11-18 04:57:45 +04:00
#!/bin/sh
# buildx.sh: a script for building X11R7.6 X server for use with xrdp
#
2013-06-05 11:22:15 +04:00
# Copyright 2011-2013 Jay Sorg Jay.Sorg@gmail.com
2011-11-18 04:57:45 +04:00
#
# Authors
# Jay Sorg Jay.Sorg@gmail.com
# Laxmikant Rashinkar LK.Rashinkar@gmail.com
#
2011-11-18 04:57:45 +04: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 04:57:45 +04:00
# http://www.apache.org/licenses/LICENSE-2.0
#
2011-11-18 04:57:45 +04: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.
2012-08-04 07:22:48 +04:00
# debian packages needed
# flex bison libxml2-dev intltool xsltproc xutils-dev python-libxml2 g++ xutils
2011-11-18 07:47:27 +04:00
2011-11-18 04:57:45 +04:00
download_file()
{
local file url status
2011-11-18 04:57:45 +04:00
file=$1
# if we already have the file, don't download it
if [ -r downloads/$file ]; then
return 0
fi
2011-11-18 04:57:45 +04:00
2013-08-13 22:06:25 +04:00
echo "downloading file $download_url/$file"
2013-03-18 19:22:35 +04:00
2013-06-05 11:22:15 +04:00
cd downloads
2013-08-13 22:06:25 +04:00
wget -cq $download_url/$file
status=$?
cd ..
return $status
2011-11-18 04:57:45 +04:00
}
remove_modules()
{
local mod_file mod_dir mod_args
2011-11-18 04:57:45 +04:00
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
while IFS=: read mod_file mod_dir mod_args
2011-11-18 04:57:45 +04:00
do
(cd build_dir; [ -d $mod_dir ] && rm -rf $mod_dir)
done < $data_file
2011-11-18 04:57:45 +04:00
}
2012-07-25 03:25:23 +04:00
extract_it()
2011-11-18 04:57:45 +04:00
{
local mod_file mod_name mod_args comp
2011-11-18 04:57:45 +04:00
mod_file=$1
mod_name=$2
mod_args=$3
2012-07-25 03:25:23 +04:00
if [ -e cookies/$mod_name.extracted ]; then
2011-11-18 04:57:45 +04:00
return 0
fi
# download file
if ! download_file $mod_file
then
2011-11-18 04:57:45 +04:00
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
case "$mod_file" in
*.tar.bz2) comp=j ;;
*.tar.gz) comp=z ;;
*.tar.xz) comp=J ;;
*.tar) comp= ;;
*) echo "unknown compressed module $mod_name" ; exit 1 ;;
esac
if ! tar x${comp}f ../downloads/$mod_file > /dev/null
then
2011-11-18 04:57:45 +04:00
echo "error extracting module $mod_name"
exit 1
fi
fi
2011-11-19 07:55:50 +04:00
# patch and configure module - we only need to do this once
2011-11-18 04:57:45 +04:00
cd $mod_name
2011-11-19 07:55:50 +04:00
# check for patches
if [ -e ../../$mod_name.patch ]; then
patch -p1 < ../../$mod_name.patch
2011-11-19 07:55:50 +04:00
fi
# now configure
2012-03-08 09:02:41 +04:00
echo "executing ./configure --prefix=$PREFIX_DIR $mod_args"
if ! ./configure --prefix=$PREFIX_DIR $mod_args
then
echo "configuration failed for module $mod_name"
2011-11-18 04:57:45 +04:00
exit 1
fi
2012-07-25 03:25:23 +04:00
cd ../..
touch cookies/$mod_name.extracted
}
make_it()
{
local mod_file mod_name mod_args
2012-07-25 03:25:23 +04:00
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.installed ]; then
# ...package has already been installed
return 0
fi
echo ""
echo "*** processing module $mod_name ($count of $num_modules) ***"
echo ""
if ! extract_it $mod_file $mod_name "$mod_args"
then
2011-11-18 04:57:45 +04:00
echo ""
2012-07-25 03:25:23 +04:00
echo "extract failed for module $mod_name"
2011-11-18 04:57:45 +04:00
echo ""
exit 1
fi
2012-07-25 03:25:23 +04:00
# make module
if [ ! -e cookies/$mod_name.made ]; then
if ! make -C build_dir/$mod_name
then
2012-07-25 03:25:23 +04:00
echo ""
echo "make failed for module $mod_name"
echo ""
exit 1
fi
touch cookies/$mod_name.made
fi
2011-11-18 04:57:45 +04:00
# install module
if ! make -C build_dir/$mod_name install
then
2011-11-18 04:57:45 +04:00
echo ""
echo "make install failed for module $mod_name"
echo ""
exit 1
fi
2011-11-19 07:55:50 +04: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 build_dir/$mod_name/$PREFIX_DIR/bin/python2
;;
2011-11-19 07:55:50 +04:00
esac
2012-07-25 03:25:23 +04:00
touch cookies/$mod_name.installed
2011-11-18 04:57:45 +04:00
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
2013-08-13 22:06:25 +04:00
# changed now to server1.xrdp.org
# was www.x.org/releases/X11R7.6/src/everything
download_url=http://server1.xrdp.org/xrdp/X11R7.6
2011-11-18 04:57:45 +04:00
num_modules=`cat $data_file | wc -l`
count=0
##########################
# program flow starts here
##########################
if [ $# -lt 1 ]; then
echo ""
echo "usage: buildx.sh <installation dir>"
echo "usage: buildx.sh <clean>"
echo "usage: buildx.sh default"
echo "usage: buildx.sh <installation dir> drop - set env and run bash in rdp dir"
2011-11-18 04:57:45 +04:00
echo ""
exit 1
fi
# remove all modules
if [ "$1" = "clean" ]; then
echo "removing source modules"
remove_modules
exit 0
fi
2012-02-02 11:21:56 +04: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 exist, creating [$PREFIX_DIR]"
if ! mkdir $PREFIX_DIR
then
2012-02-02 11:21:56 +04:00
echo "mkdir failed [$PREFIX_DIR]"
exit 0
fi
fi
echo "using $PREFIX_DIR"
2011-11-18 04:57:45 +04:00
export PKG_CONFIG_PATH=$PREFIX_DIR/lib/pkgconfig:$PREFIX_DIR/share/pkgconfig
2012-03-09 08:23:50 +04: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 04:57:45 +04:00
2011-11-18 07:47:27 +04:00
# prefix dir must exist...
2011-11-18 04:57:45 +04:00
if [ ! -d $PREFIX_DIR ]; then
if ! mkdir -p $PREFIX_DIR
then
2011-11-18 07:47:27 +04:00
echo "$PREFIX_DIR does not exist; failed to create it - cannot continue"
exit 1
fi
2011-11-18 04:57:45 +04:00
fi
2011-11-18 07:47:27 +04:00
# ...and be writable
2011-11-18 04:57:45 +04: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
if ! mkdir downloads
then
2011-11-18 04:57:45 +04:00
echo "error creating downloads directory"
exit 1
fi
fi
# this is where we do the actual build
if [ ! -d build_dir ]; then
if ! mkdir build_dir
then
2011-11-18 04:57:45 +04:00
echo "error creating build_dir directory"
exit 1
fi
fi
# this is where we store cookie files
if [ ! -d cookies ]; then
if ! mkdir cookies
then
2011-11-18 04:57:45 +04:00
echo "error creating cookies directory"
exit 1
fi
fi
while IFS=: read mod_file mod_dir mod_args
2011-11-18 04:57:45 +04:00
do
2011-11-18 07:47:27 +04:00
mod_args=`eval echo $mod_args`
2011-11-18 04:57:45 +04:00
make_it $mod_file $mod_dir "$mod_args"
done < $data_file
2011-11-19 08:45:48 +04:00
2012-03-08 09:02:41 +04:00
echo "build for X OK"
X11RDPBASE=$PREFIX_DIR
export X11RDPBASE
if ! make -C rdp
then
2012-07-25 03:25:23 +04:00
echo "error building rdp"
exit 1
fi
# this will copy the build X server with the other X server binaries
2013-06-05 11:22:15 +04:00
cd rdp
strip X11rdp
cp X11rdp $X11RDPBASE/bin
if [ "$2" = "drop" ]; then
echo ""
echo "dropping you in dir, type exit to get out"
bash
exit 1
2012-03-08 09:02:41 +04:00
fi
2011-11-19 08:45:48 +04:00
echo "All done"