2 # ===========================================================================
5 # build.sh - extract, configure, build and install the X Window System
8 # build.sh [options] [prefix]
12 # The script ultimate goal is to build all of the X Window and some of its
13 # dependencies from source.
15 # X.Org Modular Tree Developer's Guide
17 # Please consult the guide at http://www.x.org/wiki/ModularDevelopersGuide
18 # It provides detailed instructions on the build tools to install, where to
19 # find the script and how to invoke it.
21 # The X Window System Source Code
23 # The source code is hosted by freedesktop.org and is composed of over 200
24 # modules under the git source code management system. X.Org releases are
25 # available at http://www.x.org/releases/ in the form of software packages.
29 # The script goes through its list of modules to build. If the source code is
30 # not on disk, it attempts to obtain it from git if the --clone option is
31 # specified. If not, it looks for a package archive file on disk. If it is
32 # still not found, the module is skipped.
34 # The script then runs the appropriate configure script, either autogen.sh
35 # for git modules or the autoconf generated configure script for package
39 # Over time, functionality have been added to help building a large
40 # number modules. Progress report, handling build breaks, supporting the
41 # GNU Build System features, final build report, and so on.
43 # Building from a Custom Modules List
45 # Starting from the list generated using the -L option, remove unwanted
46 # modules. You may also add your own module or add specific configure
47 # options for some modules to meet your configuration needs. Using the
48 # --modfile option, your list replaces the built-in list of the script.
50 # Resuming Build After a Break
52 # The script can resume building at the last point of failure. This saves a
53 # lot of build time as the modules already built are skipped. The --autoresume
54 # option can be used with --modfile such that only the modules you care about
55 # are built and revisited until successful completion.
57 # Specifying Custom Build Commands
59 # By default, the script invokes the make program with the target "all" and
60 # "install". Some options like -c, -D, or -d alter the targets the make
61 # program builds, but you can specify your own command instead. Using the
62 # --cmd option, provide a different make or git command.
64 # Specifying Configuration Options to Specific Modules
66 # In the modulesfile used by the --modfile option, add any configuration
67 # options you want to pass to the modules as it gets configures by autoconf.
68 # Write the configure options next to the module name in the file.
69 # It could be something like --enable-strict-compilation for example.
72 # -a Do NOT run auto config tools (autogen.sh, configure)
73 # -b Use .build.unknown build directory
74 # -c Run make clean in addition to "all install"
75 # -D Run make dist in addition to "all install"
76 # -d Run make distcheck in addition "all install"
77 # -g Compile and link with debug information
78 # -L Just list modules to build
79 # -h, --help Display this help and exit successfully
80 # -n Do not quit after error; just print error message
82 # Build just this module/component
83 # -p Update source code before building (git pull --rebase)
84 # -s sudo The command name providing superuser privilege
85 # --autoresume resumefile
86 # Append module being built to, and autoresume from, resumefile
87 # --check Run make check in addition "all install"
88 # --clone Clone non-existing repositories (uses \$GITROOT if set)
90 # Execute arbitrary git, gmake, or make command
92 # Pass options to autgen.sh/configure of all modules
93 # --modfile modulesfile
94 # Only process the module/components specified in modulesfile
95 # Any text after, and on the same line as, the module/component
96 # is assumed to be configuration options for the configuration
97 # of each module/component specifically
98 # --retry-v1 Remake 'all' on failure with Automake silent rules disabled
101 # An absolute filename where GNU "make" will install binaries, libraries and
102 # other installable files. The value is passed to Autoconf through the
107 # When using --autoresume, the script reads and skips modules tagged with
108 # "PASS" and resume building at the module tagged with "FAIL". The resumefile
109 # file is not intended to be user edited.
112 # When using --modfile, the script replaces its internal modules list with
113 # the list contained in the file. This allows you to build only the modules
114 # you care about and to add third party modules or modules you create.
115 # It is helpful to initialized the file using the -L option.#
118 # Environment variables specific to build.sh:
120 # PREFIX Install architecture-independent files in PREFIX [/usr/local]
121 # Each module/components is invoked with --prefix
122 # EPREFIX Install architecture-dependent files in EPREFIX [PREFIX]
123 # Each module/components is invoked with --exec-prefix
124 # BINDIR Install user executables [EPREFIX/bin]
125 # Each module/components is invoked with --bindir
126 # DATAROOTDIR Install read-only arch-independent data root [PREFIX/share]
127 # Each module/components is invoked with --datarootdir
128 # DATADIR Install read-only architecture-independent data [DATAROOTDIR]
129 # Each module/components is invoked with --datadir
130 # LIBDIR Install object code libraries [EPREFIX/lib]
131 # Each module/components is invoked with --libdir
133 # Modifiable single-machine data [PREFIX/var]
134 # Each module/components is invoked with --localstatedir
135 # QUIET Do not print messages saying which checks are being made
136 # Each module/components is invoked with --quite
137 # GITROOT Source code repository path [git://anongit.freedesktop.org/git]
138 # Optional when using --clone to update source code before building
139 # CONFFLAGS Configure options to pass to all Autoconf configure scripts
140 # Refer to 'configure --help' from any module/components
142 # Environment variables defined by the GNU Build System:
144 # ACLOCAL The aclocal cmd name [aclocal -I ${DESTDIR}/${DATADIR}/aclocal]
145 # DESTDIR Path to the staging area where installed objects are relocated
146 # MAKE The name of the make command [make]
147 # MAKEFLAGS Options to pass to all $(MAKE) invocations
148 # CC C compiler command
149 # CFLAGS C compiler flags
150 # LDFLAGS linker flags, e.g. -L<lib dir> if you have libraries in a
151 # nonstandard directory <lib dir>
152 # CPPFLAGS C/C++/Objective C preprocessor flags, e.g. -I<include dir> if
153 # you have headers in a nonstandard directory <include dir>
156 # Environment variables defined by the shell:
157 # PATH List of directories that the shell searches for commands
158 # $DESTDIR/$BINDIR is prepended
160 # Environment variables defined by the dynamic linker:
162 # List directories that the linker searches for shared objects
163 # $DESTDIR/$LIBDIR is prepended
165 # Environment variables defined by the pkg-config system:
168 # List directories that pkg-config searches for libraries
169 # $DESTDIR/$DATADIR/pkgconfig and
170 # $DESTDIR/$LIBDIR/pkgconfig are prepended
173 # This script is intended to run on any platform supported by X.Org.
174 # The script must be able to run in a Bourne shell.
176 # ===========================================================================
180 Environment variables specific to build.sh:
181 PREFIX Install architecture-independent files in PREFIX [/usr/local]
182 Each module/components is invoked with --prefix
183 EPREFIX Install architecture-dependent files in EPREFIX [PREFIX]
184 Each module/components is invoked with --exec-prefix
185 BINDIR Install user executables [EPREFIX/bin]
186 Each module/components is invoked with --bindir
187 DATAROOTDIR Install read-only arch-independent data root [PREFIX/share]
188 Each module/components is invoked with --datarootdir
189 DATADIR Install read-only architecture-independent data [DATAROOTDIR]
190 Each module/components is invoked with --datadir
191 LIBDIR Install object code libraries [EPREFIX/lib]
192 Each module/components is invoked with --libdir
194 Modifiable single-machine data [PREFIX/var]
195 Each module/components is invoked with --localstatedir
196 QUIET Do not print messages saying which checks are being made
197 Each module/components is invoked with --quite
198 GITROOT Source code repository path [git://anongit.freedesktop.org/git]
199 Optional when using --clone to update source code before building
200 CONFFLAGS Configure options to pass to all Autoconf configure scripts
201 Refer to 'configure --help' from any module/components
203 Environment variables defined by the GNU Build System:
204 ACLOCAL The aclocal cmd name [aclocal -I \${DESTDIR}/\${DATADIR}/aclocal]
205 DESTDIR Path to the staging area where installed objects are relocated
206 MAKE The name of the make command [make]
207 MAKEFLAGS Options to pass to all \$(MAKE) invocations
208 CC C compiler command
209 CFLAGS C compiler flags
210 LDFLAGS linker flags, e.g. -L<lib dir> if you have libraries in a
211 nonstandard directory <lib dir>
212 CPPFLAGS C/C++/Objective C preprocessor flags, e.g. -I<include dir> if
213 you have headers in a nonstandard directory <include dir>
216 Environment variables defined by the shell:
217 PATH List of directories that the shell searches for commands
218 \$DESTDIR/\$BINDIR is prepended
220 Environment variables defined by the dynamic linker:
222 List directories that the linker searches for shared objects
223 \$DESTDIR/\$LIBDIR is prepended
225 Environment variables defined by the pkg-config system:
227 List directories that pkg-config searches for libraries
228 \$DESTDIR/\$DATADIR/pkgconfig and
229 \$DESTDIR/\$LIBDIR/pkgconfig are prepended
235 # Remember if the user had supplied a value through env var or cmd line
236 # A value from cmd line takes precedence of the shell environment
237 PREFIX_USER
=${PREFIX:+yes}
238 EPREFIX_USER
=${EPREFIX:+yes}
239 BINDIR_USER
=${BINDIR:+yes}
240 DATAROOTDIR_USER
=${DATAROOTDIR:+yes}
241 DATADIR_USER
=${DATADIR:+yes}
242 LIBDIR_USER
=${LIBDIR:+yes}
243 LOCALSTATEDIR_USER
=${LOCALSTATEDIR:+yes}
245 # Assign a default value if no value was supplied by the user
246 PREFIX
=${PREFIX:-/usr/local}
247 EPREFIX
=${EPREFIX:-$PREFIX}
248 BINDIR
=${BINDIR:-$EPREFIX/bin}
249 DATAROOTDIR
=${DATAROOTDIR:-$PREFIX/share}
250 DATADIR
=${DATADIR:-$DATAROOTDIR}
251 LIBDIR
=${LIBDIR:-$EPREFIX/lib}
252 LOCALSTATEDIR
=${LOCALSTATEDIR:-$PREFIX/var}
254 # Support previous usage of LIBDIR which was a subdir relative to PREFIX
255 # We use EPREFIX as this is what PREFIX really meant at the time
256 if [ X
"$LIBDIR" != X
]; then
257 if [ X
"`expr $LIBDIR : "\
(.\
)"`" != X
/ ]; then
259 echo "Warning: this usage of \$LIBDIR is deprecated. Use a full path name."
260 echo "The supplied value \"$LIBDIR\" has been replaced with $EPREFIX/$LIBDIR."
262 LIBDIR
=$EPREFIX/$LIBDIR
266 # All directories variables must be full path names
267 check_full_path
$PREFIX PREFIX
268 check_full_path
$EPREFIX EPREFIX
269 check_full_path
$BINDIR BINDIR
270 check_full_path
$DATAROOTDIR DATAROOTDIR
271 check_full_path
$DATADIR DATADIR
272 check_full_path
$LIBDIR LIBDIR
273 check_full_path
$LOCALSTATEDIR LOCALSTATEDIR
275 # This will catch the case where user forgets to set PREFIX
276 # and does not have write permission in the /usr/local default location
277 check_writable_dir
${DESTDIR}${PREFIX} PREFIX
279 # Must create local aclocal dir or aclocal fails
280 ACLOCAL_LOCALDIR
="${DESTDIR}${DATADIR}/aclocal"
281 $SUDO mkdir
-p ${ACLOCAL_LOCALDIR}
283 # The following is required to make aclocal find our .m4 macros
284 ACLOCAL
=${ACLOCAL:="aclocal"}
285 ACLOCAL
="${ACLOCAL} -I ${ACLOCAL_LOCALDIR}"
288 # The following is required to make pkg-config find our .pc metadata files
289 PKG_CONFIG_PATH
=${DESTDIR}${DATADIR}/pkgconfig:${DESTDIR}${LIBDIR}/pkgconfig${PKG_CONFIG_PATH+:$PKG_CONFIG_PATH}
290 export PKG_CONFIG_PATH
292 # Set the library path so that locally built libs will be found by apps
293 LD_LIBRARY_PATH
=${DESTDIR}${LIBDIR}${LD_LIBRARY_PATH+:$LD_LIBRARY_PATH}
294 export LD_LIBRARY_PATH
296 # Set the path so that locally built apps will be found and used
297 PATH
=${DESTDIR}${BINDIR}${PATH+:$PATH}
300 # Choose which make program to use
303 # Create the log file directory
304 $SUDO mkdir
-p ${DESTDIR}${LOCALSTATEDIR}/log
307 # explain where a failure occurred
308 # if you find this message in the build output it can help tell you where the failure occurred
310 # $1 - which command failed
319 echo "build.sh: \"$cmd\" failed on $module${component:+/}$component"
320 failed_components
="$failed_components $module${component:+/}$component"
323 # print a pretty title to separate the processing of each module
327 # $3 - configuration options
335 if [ X
"$module" = X
]; then
340 echo "======================================================================"
341 echo "== Processing: \"$module${component:+/}$component\""
342 echo "== configuration options: $CONFFLAGS $confopts"
345 # Search for tarballs in either cwd or under a module directory
346 # The tarball is always extracted in either one of these locations:
347 # - modules with components: under the module subdir (e.g lib/libX11-1.4.0)
348 # - modules without components: under cwd (e.g xserver-1.14.0)
349 # The tarballs are expected to be under one of the locations described above
350 # The location of the tarball does not dictate where it is extracted
355 # 0 - good (either no tarballs or successful extract)
361 # The package stem is the part of the tar file name that identifies
362 # the git module archived source. Ex: xclock, pixman, libX11
363 # For modules without components, the module name is used by default.
364 pkg_stem
=${component:-$module}
366 # Handle special cases where the module or component directory
367 # does not match the package name and/or the package root dir
371 "cursors") pkg_stem
="xcursor-themes" ;;
372 "bitmaps") pkg_stem
="xbitmaps" ;;
376 if [ X
"$component" != X
"encodings" ]; then
377 pkg_stem
="font-$component"
382 "libXRes") pkg_stem
="libXres" ;;
383 "libxtrans") pkg_stem
="xtrans" ;;
388 "x11proto") pkg_stem
="xproto" ;;
393 "cf") pkg_stem
="xorg-cf-files" ;;
394 "macros") pkg_stem
="util-macros" ;;
403 pkg_stem
="libpthread-stubs"
409 pkg_stem
="xcb-$component"
424 pkg_stem
="xorg-server"
428 # Search for tarballs in both the module and the src top directory
429 for ii
in $module .
; do
430 for jj
in bz2 gz xz
; do
432 # Select from the list the last tarball with a specific pkg_stem
433 pkg_tarfile
=`ls -1rt $ii/$pkg_stem-[0-9]*.tar.$jj 2> /dev/null | tail -n 1`
435 # Extract the tarball under the module directory
436 # For modules without components, extract in top level dir
437 if [ X
"$pkg_tarfile" != X
]; then
439 # Get the package version and archived toplevel directory
440 pkg_version
=`echo $pkg_tarfile | sed 's,.*'$pkg_stem'-\(.*\)\.tar\.'$jj',\1,'`
441 pkg_root_dir
="$pkg_stem-$pkg_version"
442 pkg_root_dir
=`echo $pkg_root_dir | sed 's,MesaLib,Mesa,'`
444 # Find where to extract the tar file
446 if [ X
"$component" = X
]; then
447 # For modules with no components (i.e xserver)
451 # For modules with components (i.e xcb/proto or lib/libXi)
452 pkg_extract_dir
=$module
453 SRCDIR
=$module/$pkg_root_dir
456 if [ ! -d $SRCDIR ]; then
469 tar $pkg_tar_opts $pkg_tarfile -C $pkg_extract_dir
470 if [ $?
-ne 0 ]; then
472 echo "Unable to extract $pkg_tarfile for $module module"
473 failed
tar $module $component
485 # perform a clone of a git repository
486 # this function provides the mapping between module/component names
487 # and their location in the fd.o repository
490 # $2 - component (optional)
498 if [ X
"$module" = X
]; then
499 echo "clone() required first argument is missing"
524 DIR
="$module${component:+/}$component"
525 GITROOT
=${GITROOT:="git://anongit.freedesktop.org/git"}
527 if [ ! -d "$DIR" ]; then
528 git clone
"$GITROOT/$BASEDIR$DIR" "$DIR"
529 if [ $?
-ne 0 ]; then
530 echo "Failed to clone $module${component:+/}$component. Ignoring."
531 clonefailed_components
="$clonefailed_components $module${component:+/}$component"
536 if [ $?
-ne 0 ]; then
537 echo "Failed to cd to $module${component:+/}$component. Ignoring."
538 clonefailed_components
="$clonefailed_components $module${component:+/}$component"
543 if [ $?
-ne 0 ]; then
544 echo "Failed to initialize $module${component:+/}$component submodule. Ignoring."
545 clonefailed_components
="$clonefailed_components $module${component:+/}$component"
549 if [ $?
-ne 0 ]; then
550 echo "Failed to update $module${component:+/}$component submodule. Ignoring."
551 clonefailed_components
="$clonefailed_components $module${component:+/}$component"
556 echo "git cannot clone into an existing directory $module${component:+/}$component"
563 # perform processing of each module/component
567 # $3 - configure options
578 if [ X
"$module" = X
]; then
579 echo "process() required first argument is missing"
583 module_title
$module "$component" "$confopts"
587 if [ -f $module${component:+/}$component/autogen.sh
]; then
588 SRCDIR
="$module${component:+/}$component"
590 elif [ X
"$CLONE" != X
]; then
591 clone
$module $component
592 if [ $?
-eq 0 ]; then
593 SRCDIR
="$module${component:+/}$component"
598 checkfortars
$module $component
599 if [ $?
-eq 0 ]; then
600 if [ X
"$SRCDIR" = X
]; then
601 echo "$module${component:+/}$component does not exist, skipping."
602 nonexistent_components
="$nonexistent_components $module${component:+/}$component"
613 if [ $?
-ne 0 ]; then
614 failed cd1
$module $component
618 if [ X
"$GITCMD" != X
]; then
623 if [ $rtn -ne 0 ]; then
624 failed
"$GITCMD" $module $component
630 if [ X
"$PULL" != X
]; then
632 if [ $?
-ne 0 ]; then
633 failed
"git pull" $module $component
637 # The parent module knows which commit the submodule should be at
639 if [ $?
-ne 0 ]; then
640 failed
"git submodule update" $module $component
645 # Build outside source directory
646 if [ X
"$DIR_ARCH" != X
] ; then
648 if [ $?
-ne 0 ]; then
649 failed mkdir
$module $component
654 if [ $?
-ne 0 ]; then
655 failed cd2
$module $component
661 # Use "sh autogen.sh" since some scripts are not executable in CVS
662 if [ $needs_config -eq 1 ] ||
[ X
"$NOAUTOGEN" = X
]; then
663 sh
${DIR_CONFIG}/${CONFCMD} \
664 ${PREFIX_USER:+--prefix="$PREFIX"} \
665 ${EPREFIX_USER:+--exec-prefix="$EPREFIX"} \
666 ${BINDIR_USER:+--bindir="$BINDIR"} \
667 ${DATAROOTDIR_USER:+--datarootdir="$DATAROOTDIR"} \
668 ${DATADIR_USER:+--datadir="$DATADIR"} \
669 ${LIBDIR_USER:+--libdir="$LIBDIR"} \
670 ${LOCALSTATEDIR_USER:+--localstatedir="$LOCALSTATEDIR"} \
672 ${CONFFLAGS} $confopts \
675 ${CPPFLAGS:+CPPFLAGS="$CPPFLAGS"} \
676 ${CFLAGS:+CFLAGS="$CFLAGS"} \
677 ${LDFLAGS:+LDFLAGS="$LDFLAGS"}
678 if [ $?
-ne 0 ]; then
679 failed
${CONFCMD} $module $component
685 # A custom 'make' target list was supplied through --cmd option
686 if [ X
"$MAKECMD" != X
]; then
687 ${MAKE} $MAKEFLAGS $MAKECMD
691 if [ $rtn -ne 0 ]; then
692 failed
"$MAKE $MAKEFLAGS $MAKECMD" $module $component
699 if [ $?
-ne 0 ]; then
700 # Rerun with Automake silent rules disabled to see failing gcc statement
701 if [ X
"$RETRY_VERBOSE" != X
]; then
703 echo "build.sh: Rebuilding $component with Automake silent rules disabled"
704 ${MAKE} $MAKEFLAGS V
=1
706 failed
"$MAKE $MAKEFLAGS" $module $component
711 if [ X
"$CHECK" != X
]; then
712 ${MAKE} $MAKEFLAGS check
713 if [ $?
-ne 0 ]; then
714 failed
"$MAKE $MAKEFLAGS check" $module $component
720 if [ X
"$CLEAN" != X
]; then
721 ${MAKE} $MAKEFLAGS clean
722 if [ $?
-ne 0 ]; then
723 failed
"$MAKE $MAKEFLAGS clean" $module $component
729 if [ X
"$DIST" != X
]; then
730 ${MAKE} $MAKEFLAGS dist
731 if [ $?
-ne 0 ]; then
732 failed
"$MAKE $MAKEFLAGS dist" $module $component
738 if [ X
"$DISTCHECK" != X
]; then
739 ${MAKE} $MAKEFLAGS distcheck
740 if [ $?
-ne 0 ]; then
741 failed
"$MAKE $MAKEFLAGS distcheck" $module $component
747 $SUDO env LD_LIBRARY_PATH
=$LD_LIBRARY_PATH ${MAKE} $MAKEFLAGS install
748 if [ $?
-ne 0 ]; then
749 failed
"$SUDO env LD_LIBRARY_PATH=$LD_LIBRARY_PATH $MAKE $MAKEFLAGS install" $module $component
759 # process each module/component and handle:
760 # LISTONLY, RESUME, NOQUIT, and BUILD_ONE
764 # $3 - configure options
772 if [ X
"$LISTONLY" != X
]; then
773 echo "$module${component:+/}$component"
777 if [ X
"$RESUME" != X
]; then
778 if [ X
"$RESUME" = X
"$module${component:+/}$component" ]; then
780 # Resume build at this module
782 echo "Skipping $module${component:+/}$component..."
787 process
$module "$component" "$confopts"
789 if [ X
"$BUILT_MODULES_FILE" != X
]; then
790 if [ $process_rtn -ne 0 ]; then
791 echo "FAIL: $module${component:+/}$component" >> $BUILT_MODULES_FILE
793 echo "PASS: $module${component:+/}$component" >> $BUILT_MODULES_FILE
797 if [ $process_rtn -ne 0 ]; then
798 echo "build.sh: error processing: \"$module${component:+/}$component\""
799 if [ X
"$NOQUIT" = X
]; then
805 if [ X
"$BUILD_ONE" != X
]; then
806 echo "Single-component build complete"
811 # protocol headers have no build order dependencies
815 build proto applewmproto
818 build proto windowswmproto
821 build proto bigreqsproto
822 build proto compositeproto
823 build proto damageproto
825 build proto dri2proto
826 build proto dri3proto
827 build proto fixesproto
828 build proto fontsproto
830 build proto inputproto
832 build proto presentproto
833 build proto randrproto
834 build proto recordproto
835 build proto renderproto
836 build proto resourceproto
837 build proto scrnsaverproto
838 build proto videoproto
840 build proto xcmiscproto
841 build proto xextproto
842 build proto xf86bigfontproto
843 build proto xf86dgaproto
844 build proto xf86driproto
845 build proto xf86vidmodeproto
846 build proto xineramaproto
850 # bitmaps is needed for building apps, so has to be done separately first
851 # cursors depends on apps/xcursorgen
852 # xkbdata is obsolete - use xkbdesc from xkeyboard-config instead
858 # All protocol modules must be installed before the libs (okay, that's an
859 # overstatement, but all protocol modules should be installed anyway)
861 # the libraries have a dependency order:
862 # xtrans, Xau, Xdmcp before anything else
863 # fontenc before Xfont
866 # (X11 and SM) before Xt
867 # Xt before Xmu and Xpm
868 # Xext before any other extension library
869 # Xfixes before Xcomposite
870 # Xp before XprintUtil before XprintAppUtil
876 build xcb pthread-stubs
880 build xcb util-keysyms
881 build xcb util-renderutil
890 build lib libWindowsWM
904 build lib libXcomposite
911 build lib libXinerama
915 build lib libXScrnSaver
918 build lib libxshmfence
924 build lib libXxf86dga
926 build lib libpciaccess
930 # Most apps depend at least on libX11.
932 # bdftopcf depends on libXfont
933 # mkfontscale depends on libfontenc and libfreetype
934 # mkfontdir depends on mkfontscale
936 # TODO: detailed breakdown of which apps require which libs
940 build app beforelight
950 build app mkcomposecache
952 build app mkfontscale
955 build app rendercheck
1000 build app xlsclients
1030 # The server requires at least the following libraries:
1031 # Xfont, Xau, Xdmcp, pciaccess
1036 build_driver_input
() {
1037 # Some drivers are only buildable on some OS'es
1040 build driver xf86-input-evdev
1041 build driver xf86-input-joystick
1043 FreeBSD | NetBSD | OpenBSD | Dragonfly | GNU
/kFreeBSD
)
1044 build driver xf86-input-joystick
1048 # And some drivers are only buildable on some CPUs.
1050 i
*86 | amd64 | x86_64 | i86pc
)
1051 build driver xf86-input-vmmouse
1055 build driver xf86-input-keyboard
1056 build driver xf86-input-mouse
1057 build driver xf86-input-synaptics
1058 build driver xf86-input-void
1061 build_driver_video
() {
1062 # Some drivers are only buildable on some OS'es
1067 build driver xf86-video-sunffb
1072 build driver xf86-video-wsfb
1073 build driver xf86-video-sunffb
1076 build driver xf86-video-sisusb
1077 build driver xf86-video-sunffb
1078 build driver xf86-video-v4l
1079 build driver xf86-video-xgixp
1082 # AMD Geode CPU. Driver contains 32 bit assembler code
1083 build driver xf86-video-geode
1089 # Some drivers are only buildable on some architectures
1092 build driver xf86-video-suncg14
1093 build driver xf86-video-suncg3
1094 build driver xf86-video-suncg6
1095 build driver xf86-video-sunleo
1096 build driver xf86-video-suntcx
1098 i
*86 | amd64 | x86_64 | i86pc
)
1099 build driver xf86-video-i740
1100 build driver xf86-video-intel
1104 build driver xf86-video-apm
1105 build driver xf86-video-ark
1106 build driver xf86-video-ast
1107 build driver xf86-video-ati
1108 build driver xf86-video-chips
1109 build driver xf86-video-cirrus
1110 build driver xf86-video-dummy
1111 build driver xf86-video-fbdev
1112 # build driver xf86-video-glide
1113 build driver xf86-video-glint
1114 build driver xf86-video-i128
1115 build driver xf86-video-mach64
1116 build driver xf86-video-mga
1117 build driver xf86-video-modesetting
1118 build driver xf86-video-neomagic
1119 build driver xf86-video-nv
1120 build driver xf86-video-rendition
1121 build driver xf86-video-r128
1122 build driver xf86-video-s3
1123 build driver xf86-video-s3virge
1124 build driver xf86-video-savage
1125 build driver xf86-video-siliconmotion
1126 build driver xf86-video-sis
1127 build driver xf86-video-tdfx
1128 build driver xf86-video-tga
1129 build driver xf86-video-trident
1130 build driver xf86-video-tseng
1131 build driver xf86-video-vesa
1132 build driver xf86-video-vmware
1133 build driver xf86-video-voodoo
1136 # The server must be built before the drivers
1138 # XQuartz doesn't need these...
1143 # Build the Wrapper library for evdev devices
1153 # All fonts require mkfontscale and mkfontdir to be available
1155 # The following fonts require bdftopcf to be available:
1156 # adobe-100dpi, adobe-75dpi, adobe-utopia-100dpi, adobe-utopia-75dpi,
1157 # arabic-misc, bh-100dpi, bh-75dpi, bh-lucidatypewriter-100dpi,
1158 # bh-lucidatypewriter-75dpi, bitstream-100dpi, bitstream-75dpi,
1159 # cronyx-cyrillic, cursor-misc, daewoo-misc, dec-misc, isas-misc,
1160 # jis-misc, micro-misc, misc-cyrillic, misc-misc, mutt-misc,
1161 # schumacher-misc, screen-cyrillic, sony-misc, sun-misc and
1164 # The font util component must be built before any of the fonts, since they
1165 # use the fontutil.m4 installed by it. (As do several other modules, such
1166 # as libfontenc and app/xfs, which is why it is moved up to the top.)
1168 # The alias component is recommended to be installed after the other fonts
1169 # since the fonts.alias files reference specific fonts installed from the
1170 # other font components
1172 build font encodings
1173 build font adobe-100dpi
1174 build font adobe-75dpi
1175 build font adobe-utopia-100dpi
1176 build font adobe-utopia-75dpi
1177 build font adobe-utopia-type1
1178 build font arabic-misc
1179 build font bh-100dpi
1181 build font bh-lucidatypewriter-100dpi
1182 build font bh-lucidatypewriter-75dpi
1185 build font bitstream-100dpi
1186 build font bitstream-75dpi
1187 build font bitstream-type1
1188 build font cronyx-cyrillic
1189 build font cursor-misc
1190 build font daewoo-misc
1192 build font ibm-type1
1193 build font isas-misc
1195 build font micro-misc
1196 build font misc-cyrillic
1197 build font misc-ethiopic
1198 build font misc-meltho
1199 build font misc-misc
1200 build font mutt-misc
1201 build font schumacher-misc
1202 build font screen-cyrillic
1203 build font sony-misc
1205 build font winitzki-cyrillic
1206 build font xfree86-type1
1210 # makedepend requires xproto
1214 build util gccmakedep
1217 build xkeyboard-config
""
1220 # xorg-docs requires xorg-sgml-doctools
1222 build doc xorg-sgml-doctools
1226 # just process the sub-projects supplied in the given file ($MODFILE)
1227 # in the order in which they are found in the list
1228 # (prerequisites and ordering are the responsibility of the user)
1230 # $MODFILE - readable file containing list of modules to process
1231 # and their optional configuration options
1237 process_module_file
() {
1239 if [ X
"$MODFILE" = X
]; then
1240 echo "internal process_module_file() error, \$MODFILE is empty"
1243 if [ ! -r "$MODFILE" ]; then
1244 echo "module file '$MODFILE' is not readable or does not exist"
1248 # read from input file, skipping blank and comment lines
1251 if [ X
"$line" = X
]; then
1255 # skip comment lines
1256 echo "$line" |
grep "^#" > /dev
/null
1257 if [ $?
-eq 0 ]; then
1261 # parse each line to extract module, component and options name
1262 field1
=`echo $line | cut -d' ' -f1`
1263 module
=`echo $field1 | cut -d'/' -f1`
1264 component
=`echo $field1 | cut -d'/' -s -f2`
1265 confopts
=`echo $line | cut -d' ' -s -f2-`
1267 build
$module "$component" "$confopts"
1275 basename="`expr "//$0" : '.*/\([^/]*\)'`"
1276 echo "Usage: $basename [options] [prefix]"
1278 echo " -a Do NOT run auto config tools (autogen.sh, configure)"
1279 echo " -b Use .build.unknown build directory"
1280 echo " -c Run make clean in addition to \"all install\""
1281 echo " -D Run make dist in addition to \"all install\""
1282 echo " -d Run make distcheck in addition \"all install\""
1283 echo " -g Compile and link with debug information"
1284 echo " -h, --help Display this help and exit successfully"
1285 echo " -n Do not quit after error; just print error message"
1286 echo " -o module/component"
1287 echo " Build just this module/component"
1288 echo " -p Update source code before building (git pull --rebase)"
1289 echo " -s sudo The command name providing superuser privilege"
1290 echo " --autoresume resumefile"
1291 echo " Append module being built to, and autoresume from, <file>"
1292 echo " --check Run make check in addition \"all install\""
1293 echo " --clone Clone non-existing repositories (uses \$GITROOT if set)"
1294 echo " --cmd command"
1295 echo " Execute arbitrary git, gmake, or make command"
1296 echo " --confflags options"
1297 echo " Pass options to autgen.sh/configure of all modules"
1298 echo " --modfile modulefile"
1299 echo " Only process the module/components specified in modulefile"
1300 echo " Any text after, and on the same line as, the module/component"
1301 echo " is assumed to be configuration options for the configuration"
1302 echo " of each module/component specifically"
1303 echo " --retry-v1 Remake 'all' on failure with Automake silent rules disabled"
1305 echo "Usage: $basename -L"
1306 echo " -L Just list modules to build"
1311 # Ensure the named variable value contains a full path name
1313 # $1 - the variable value (the path to examine)
1314 # $2 - the name of the variable
1316 # returns nothing or exit on error with message
1317 check_full_path
() {
1320 if [ X
"`expr $path : "\
(.\
)"`" != X
/ ]; then
1321 echo "The path \"$path\" supplied by \"$varname\" must be a full path name"
1328 # Ensure the named variable value contains a writable directory
1330 # $1 - the variable value (the path to examine)
1331 # $2 - the name of the variable
1333 # returns nothing or exit on error with message
1334 check_writable_dir
() {
1337 if [ X
"$SUDO" = X
]; then
1338 if [ ! -d "$path" ] ||
[ ! -w "$path" ]; then
1339 echo "The path \"$path\" supplied by \"$varname\" must be a writable directory"
1347 # perform sanity checks on cmdline args which require arguments
1349 # $1 - the option being examined
1350 # $2 - the argument to the option
1352 # if it returns, everything is good
1353 # otherwise it exit's
1358 if [ X
"$option" = X
]; then
1359 echo "internal required_arg() error, missing first argument"
1363 # check for an argument
1364 if [ X
"$arg" = X
]; then
1365 echo "the '$option' option is missing its required argument"
1371 # does the argument look like an option?
1372 echo $arg |
grep "^-" > /dev
/null
1373 if [ $?
-eq 0 ]; then
1374 echo "the argument '$arg' of option '$option' looks like an option itself"
1381 #------------------------------------------------------------------------------
1383 #------------------------------------------------------------------------------
1385 # Initialize variables controlling end of run reports
1386 failed_components
=""
1387 nonexistent_components
=""
1388 clonefailed_components
=""
1390 # Set variables supporting multiple binaries for a single source tree
1391 HAVE_ARCH
="`uname -i`"
1395 # Set variables for conditionally building some components
1401 # Process command line args
1409 DIR_ARCH
=".build.$HAVE_ARCH"
1422 CFLAGS
="${CFLAGS} -g3 -O0"
1435 if [ -n "$BUILT_MODULES_FILE" ]; then
1436 echo "The '-o' and '--autoresume' options are mutually exclusive."
1442 RESUME
=`echo $1 | sed "s,/$,,"`
1454 if [ -n "$BUILD_ONE" ]; then
1455 echo "The '-o' and '--autoresume' options are mutually exclusive."
1461 BUILT_MODULES_FILE
=$1
1472 cmd1
=`echo $1 | cut -d' ' -f1`
1473 cmd2
=`echo $1 | cut -d' ' -f2`
1475 # verify the command exists
1476 which $cmd1 > /dev
/null
2>&1
1477 if [ $?
-ne 0 ]; then
1478 echo "The specified command '$cmd1' does not appear to exist"
1492 echo "The script can only process 'make', 'gmake', or 'git' commands"
1493 echo "It can't process '$cmd1' commands"
1507 if [ ! -r "$1" ]; then
1508 echo "can't find/read file '$1'"
1517 if [ X
"$too_many" = Xyes
]; then
1518 echo "unrecognized and/or too many command-line arguments"
1519 echo " PREFIX: $PREFIX"
1520 echo " Extra arguments: $1"
1526 # check that 'prefix' doesn't look like an option
1527 echo $1 |
grep "^-" > /dev
/null
1528 if [ $?
-eq 0 ]; then
1529 echo "'prefix' appears to be an option"
1543 # All user input has been obtained, set-up the user shell variables
1544 if [ X
"$LISTONLY" = X
]; then
1546 echo "Building to run $HOST_OS / $HOST_CPU ($HOST)"
1550 # if there is a BUILT_MODULES_FILE
1551 # then start off by checking for and trying to build any modules which failed
1552 # and aren't the last line
1553 if [ X
"$BUILT_MODULES_FILE" != X
-a -r "$BUILT_MODULES_FILE" ]; then
1554 built_lines
=`cat $BUILT_MODULES_FILE | wc -l | sed 's:^ *::'`
1555 built_lines_m1
=`expr $built_lines - 1`
1556 orig_BUILT_MODULES_FILE
=$BUILT_MODULES_FILE
1557 unset BUILT_MODULES_FILE
1560 built_status
=`echo $line | cut -c-6`
1561 if [ X
"$built_status" = X
"FAIL: " ]; then
1562 line
=`echo $line | cut -c7-`
1563 field1
=`echo $line | cut -d' ' -f1`
1564 module
=`echo $field1 | cut -d'/' -f1`
1565 component
=`echo $field1 | cut -d'/' -s -f2`
1566 confopts
=`echo $line | cut -d' ' -s -f2-`
1570 # quick check for the module in $MODFILE (if present)
1571 if [ X
"$MODFILE" = X
]; then
1572 build
$module "$component" "$confopts"
1573 if [ $?
-eq 0 ]; then
1577 cat $MODFILE |
grep "$module${component:+/}$component" > /dev
/null
1578 if [ $?
-eq 0 ]; then
1579 build
$module "$component" "$confopts"
1580 if [ $?
-eq 0 ]; then
1586 if [ X
"$build_ret" = X
"PASS" ]; then
1588 if [ $?
-ne 0 ]; then
1589 echo "can't create tmp file, $orig_BUILT_MODULES_FILE not modified"
1591 head -n `expr $curline - 1` $orig_BUILT_MODULES_FILE > $built_temp
1592 echo "PASS: $module${component:+/}$component" >> $built_temp
1593 tail -n `expr $built_lines - $curline` $orig_BUILT_MODULES_FILE >> $built_temp
1594 mv $built_temp $orig_BUILT_MODULES_FILE
1598 if [ $curline -eq $built_lines_m1 ]; then
1601 curline
=`expr $curline + 1`
1602 done <"$orig_BUILT_MODULES_FILE"
1604 BUILT_MODULES_FILE
=$orig_BUILT_MODULES_FILE
1605 RESUME
=`tail -n 1 $BUILT_MODULES_FILE | cut -c7-`
1607 # remove last line of $BUILT_MODULES_FILE
1608 # to avoid a duplicate entry
1610 if [ $?
-ne 0 ]; then
1611 echo "can't create tmp file, last built item will be duplicated"
1613 head -n $built_lines_m1 $BUILT_MODULES_FILE > $built_temp
1614 mv $built_temp $BUILT_MODULES_FILE
1618 if [ X
"$MODFILE" = X
]; then
1619 # We must install the global macros before anything else
1625 # Required by mesa and depends on xproto
1626 build util makedepend
1641 if [ X
"$LISTONLY" != X
]; then
1645 # Print the end date/time to compare with the start date/time
1648 # Report about components that failed for one reason or another
1649 if [ X
"$nonexistent_components" != X
]; then
1651 echo "***** Skipped components (not available) *****"
1652 echo "Could neither find a git repository (at the <module/component> paths)"
1653 echo "or a tarball (at the <module/> paths or ./) for:"
1654 echo " <module/component>"
1655 for mod
in $nonexistent_components; do
1658 echo "You may want to provide the --clone option to build.sh"
1659 echo "to automatically git-clone the missing components"
1663 if [ X
"$failed_components" != X
]; then
1665 echo "***** Failed components *****"
1666 for mod
in $failed_components; do
1672 if [ X
"$CLONE" != X
] && [ X
"$clonefailed_components" != X
]; then
1674 echo "***** Components failed to clone *****"
1675 for mod
in $clonefailed_components; do