summaryrefslogtreecommitdiff
path: root/x11/XFree86
diff options
context:
space:
mode:
authorDavid E. O'Brien <obrien@FreeBSD.org>2001-02-18 04:47:55 +0000
committerDavid E. O'Brien <obrien@FreeBSD.org>2001-02-18 04:47:55 +0000
commit2586f662eb4bf9aa6cfc7478040a43d6df0c10f6 (patch)
tree22c433fa6cc9df65735744aae1a61d230851ca6e /x11/XFree86
parentUpdate to 0.3.3. (diff)
Add needed support for building an X distribution that mirrors the
XFree86's own distribution layout. To use, define "BUILD_XDIST".
Notes
Notes: svn path=/head/; revision=38451
Diffstat (limited to 'x11/XFree86')
-rw-r--r--x11/XFree86/Makefile29
-rw-r--r--x11/XFree86/distinfo1
-rw-r--r--x11/XFree86/scripts/configure.build_xdist206
3 files changed, 229 insertions, 7 deletions
diff --git a/x11/XFree86/Makefile b/x11/XFree86/Makefile
index 81edb64c1d26..012783863c39 100644
--- a/x11/XFree86/Makefile
+++ b/x11/XFree86/Makefile
@@ -12,6 +12,9 @@ CATEGORIES= x11
MASTER_SITES= ${MASTER_SITE_XFREE}
MASTER_SITE_SUBDIR= ${PORTVERSION}
DISTFILES= X336src-1.tgz X336src-2.tgz
+.if defined(BUILD_XDIST)
+DISTFILES+= X336src-3.tgz
+.endif
PATCH_SITES= ftp://ftp.xfree.org/pub/XFree86/3.3.6/fixes/ \
ftp://ftp.freesoftware.com/pub/XFree86/3.3.6/fixes/ \
@@ -24,24 +27,24 @@ PATCHFILES= fix-01-r128 fix-04-s3trio3d2x fix-05-s3trio3d fix-06-s3trio3d2x\
MAINTAINER= jmz@FreeBSD.org
WRKSRC= ${WRKDIR}/${DIST_SUBDIR}
+SCRIPTDIR= ${WRKDIR}/scripts
INSTALLS_SHLIB= yes
-.if (${MACHINE} != "alpha")
-#NO_PACKAGE= package available from XFree86
-.endif
ALL_TARGET= World
INSTALL_TARGET= install install.man
+.if defined(BUILD_XDIST)
+INSTALL_TARGET+= install.linkkit
+.endif
DIST_SUBDIR= xc
PATCH_DIST_ARGS=-p2 -E -d ${WRKDIR}/xc/programs --quiet
-SCRIPTS_ENV= OSVERSION=${OSVERSION}
+SCRIPTS_ENV= OSVERSION=${OSVERSION} MACHINE=${MACHINE} \
+ MACHINE_ARCH=${MACHINE_ARCH}
# can't use USE_X_PREFIX here -- it will cause a circular dependency
PREFIX= ${X11BASE}
MTREE_FILE= /etc/mtree/BSD.x11.dist
.if (${MACHINE} == "pc98")
-SCRIPTS_ENV+= MACHINE=pc98
PLIST= ${PKGDIR}/pkg-plist.pc98
.endif
.if (${MACHINE} == "alpha")
-SCRIPTS_ENV+= MACHINE=alpha
PLIST= ${PKGDIR}/pkg-plist.alpha
.endif
@@ -69,6 +72,10 @@ pre-fetch:
post-extract:
@${MV} ${WRKSRC}/programs/Xserver/hw/xfree86/vga256/drivers/i810/os-support/linux/agpgart.h ${WRKSRC}/programs/Xserver/hw/xfree86/vga256/drivers/i810/
+.if defined(BUILD_XDIST)
+ @${CP} ${WRKSRC}/programs/Xserver/hw/xfree86/LinkKit/README \
+ ${WRKSRC}/programs/Xserver/hw/xfree86/doc/sgml
+.endif
@if [ -r ${FILESDIR}/config ]; then \
${ECHO} Using your existing ${FILESDIR}/config ; \
${CP} ${FILESDIR}/config ${WRKDIR}/config ; \
@@ -76,10 +83,18 @@ post-extract:
.include <bsd.port.pre.mk>
-.if !exists(${FILESDIR}/config)
+.if !defined(BUILD_XDIST) && !exists(${FILESDIR}/config)
IS_INTERACTIVE= yes # configure script asks questions
.endif
+pre-configure:
+ @${MKDIR} ${SCRIPTDIR}
+.if defined(BUILD_XDIST)
+ @${CP} ${MASTERDIR}/scripts/configure.build_xdist ${SCRIPTDIR}
+.else
+ @${CP} ${MASTERDIR}/scripts/configure ${SCRIPTDIR}
+.endif
+
pre-install:
${MKDIR} ${X11BASE}
diff --git a/x11/XFree86/distinfo b/x11/XFree86/distinfo
index b38c7e8e2ad3..76df313a8264 100644
--- a/x11/XFree86/distinfo
+++ b/x11/XFree86/distinfo
@@ -1,5 +1,6 @@
MD5 (xc/X336src-1.tgz) = bbfa360d10ce91ab37f24f197a31b485
MD5 (xc/X336src-2.tgz) = 897daa223b5b67b8314ed8835cc17539
+MD5 (xc/X336src-3.tgz) = 4b1d9d353f8b4cba678f7c156b872330
MD5 (xc/fix-01-r128) = a62387e13b970c5a83e9a0822c30344f
MD5 (xc/fix-04-s3trio3d2x) = 75569a9d49bb45b8ecb311ab3f8c2469
MD5 (xc/fix-05-s3trio3d) = eb8fd33328c8b5fbd0410472339dee44
diff --git a/x11/XFree86/scripts/configure.build_xdist b/x11/XFree86/scripts/configure.build_xdist
new file mode 100644
index 000000000000..a306fe62e917
--- /dev/null
+++ b/x11/XFree86/scripts/configure.build_xdist
@@ -0,0 +1,206 @@
+#!/bin/sh
+
+F=$WRKDIR/config
+WH=$WRKDIR/xc/lib/Xdmcp/Wraphelp.c
+configure () {
+rm -f $F
+
+# Tk detection
+tkversion=
+for v in 42 80 81 82 83; do
+ if [ -f /usr/local/lib/libtk$v.a ]; then
+ tkversion=$v
+ case $tkversion in
+ 42)
+ tclversion=76
+ tclLversion=7.6
+ tkLversion=4.2
+ ;;
+ 80)
+ tclversion=80
+ tclLversion=8.0
+ tkLversion=8.0
+ ;;
+ 81)
+ tclversion=81
+ tclLversion=8.1
+ tkLversion=8.1
+ ;;
+ 82)
+ tclversion=82
+ tclLversion=8.2
+ tkLversion=8.2
+ ;;
+ 83)
+ tclversion=83
+ tclLversion=8.3
+ tkLversion=8.3
+ ;;
+ esac
+ fi
+done
+
+# Japanese Tk detection
+jptkversion=
+for v in 42jp 80jp; do
+ if [ -f /usr/local/lib/libtk$v.a ]; then
+ jptkversion=$v
+ case $jptkversion in
+ 42jp)
+ jptclversion=76jp
+ jptclLversion=7.6jp
+ jptkLversion=4.2jp
+ ;;
+ 80jp)
+ jptclversion=80jp
+ jptclLversion=8.0jp
+ jptkLversion=8.0jp
+ ;;
+ esac
+ fi
+done
+if [ X$jptkversion != X ]; then
+ echo "Using Japanized tk-$jptkLversion"
+ echo "#define HasJpTk YES" >>$F
+ echo "#define JpTkLibDir /usr/local/lib" >>$F
+ echo "#define JpTkIncDir /usr/local/include/tk$jptkLversion" >>$F
+ echo "#define JpTkLibName tk$jptkversion" >>$F
+ echo "#define HasJpTcl YES" >>$F
+ echo "#define JpTclLibDir /usr/local/lib" >>$F
+ echo "#define JpTclIncDir /usr/local/include/tcl$jptclLversion" >>$F
+ echo "#define JpTclLibName tcl$jptclversion" >>$F
+fi
+
+if [ X$tkversion != X ]; then
+ echo "Using tk-$tkLversion"
+ echo "#define HasTk YES" >>$F
+ echo "#define TkLibDir /usr/local/lib" >>$F
+ echo "#define TkIncDir /usr/local/include/tk$tkLversion" >>$F
+ echo "#define TkLibName tk$tkversion" >>$F
+ echo "#define HasTcl YES" >>$F
+ echo "#define TclLibDir /usr/local/lib" >>$F
+ echo "#define TclIncDir /usr/local/include/tcl$tclLversion" >>$F
+ echo "#define TclLibName tcl$tclversion" >>$F
+fi
+
+if [ X$tkversion != X -a X$jptkversion != X ]; then
+ echo "#define BuildXF86Setup YES" >>$F
+ echo "#define XF86SetupUsesStaticTk YES" >>$F
+ echo "#define XF86SetupUsesStaticTcl YES" >>$F
+else
+cat <<EOF
+*** I don't see the static library for tk version $tkversion in /usr/local/lib.
+*** XF86Setup will not be installed. If you want to build this program
+*** install tk 4.2 or 8.x first.
+
+EOF
+fi
+
+# Build the default server set for each machine
+
+if [ X"${MACHINE_ARCH}" = X"i386" ]; then
+ echo "#define BuildPC98Servers YES" >>$F
+
+ if [ X"${MACHINE}" = X"pc98" ]; then
+ # Don't build normal i386 servers on PC98
+ echo "#undef XF86SVGAServer" >>$F
+ echo "#define XF86SVGAServer NO" >>$F
+ servers="VGA16 VGA16Dual Mono MonoDual S3 S3V I8514 Mach8 Mach32 Mach64 P9000 AGX W32 I128 GLINT"
+ for i in $servers; do
+ echo "#undef XF86${i}Server" >>$F
+ echo "#define XF86${i}Server NO" >>$F
+ done
+ fi
+elif [ X"${MACHINE}" == X"alpha" ]; then
+ # force the VGA16 driver on the Alpha
+ echo "#define XF86VGA16Server YES" >>$F
+fi
+
+echo "#define XVirtualFramebufferServer YES" >>$F
+
+if [ X"${MACHINE}" != X"pc98" ]; then
+if [ X"${MACHINE}" = X"alpha" ]; then
+cat >> $F <<END
+#define XF86SvgaDrivers nv mga tvga8900 s3v generic
+#define XF86Vga16Drivers tvga8900 generic
+END
+else
+cat >> $F <<END
+#define XF86SvgaDrivers nv et4000 et3000 pvga1 gvga r128 ati sis tvga8900 \
+ cirrus ncr77c22 compaq mga oak al2101 ali \
+ cl64xx video7 ark mx realtek apm s3_savage s3v \
+ s3_svga neo chips cyrix rendition p9x00 \
+ spc8110 i740 i810 tdfx smi generic
+END
+fi
+fi
+
+echo "#define InstallXdmConfig YES" >> $F
+echo "#define InstallXinitConfig YES" >> $F
+echo "#define InstallFSConfig YES" >> $F
+
+echo "#undef BuildFontServer" >>$F
+echo "#define BuildFontServer YES" >>$F
+echo "#undef InstallFSConfig" >>$F
+echo "#define InstallFSConfig YES" >>$F
+
+if [ X${MACHINE} != X"alpha" ]; then
+ echo "#define JoystickSupport YES" >> $F
+fi
+
+echo "#define ForceNormalLib YES" >> $F
+
+# ELF detection
+if [ `sysctl -n kern.osreldate` -ge 300004 -a X`objformat` = Xelf ]; then
+ ELF=yes
+else
+ ELF=no
+fi
+
+if [ ${OSVERSION} -ge 300000 ]; then
+ echo "#define HasSecureRPC YES" >> $F
+fi
+
+cpwh=NO
+
+ if [ -f $WH ] ; then
+ echo "==> $WH found in source distribution."
+ elif [ -f $DISTDIR/xc/Wraphelp.c ] ; then
+ echo "==> Wraphelp.c found in DISTDIR directory, copying to source tree."
+ cpwh=$DISTDIR/xc/Wraphelp.c
+ elif [ -f $FILESDIR/Wraphelp.c ] ; then
+ echo "==> Wraphelp.c found in files directory, copying to source tree."
+ cpwh=$FILESDIR/Wraphelp.c
+ else
+ echo "==> Wraphelp.c not found, DES support NOT enabled."
+ cpwh=NO
+ fi
+if [ $cpwh != NO ]; then
+ echo "#define HasXdmAuth YES" >> $F
+fi
+
+echo "#define HasPam YES" >> $F
+if [ X${MACHINE} != X"alpha" ]; then
+echo "#define InstallJapaneseDocs YES" >> $F
+echo "#define HasSgmlFmt YES" >> $F
+echo "#define BuildAllDocs YES" >> $F
+fi
+}
+
+if [ ! -r $F ]; then
+ configure
+elif grep 'HasXdmAuth.*YES' $F >/dev/null; then
+ for i in $DISTDIR/xc $FILESDIR; do
+ if [ -r $i/Wraphelp.c ]; then
+ cpwh=$i/Wraphelp.c
+ fi
+ done
+fi
+
+if [ X$cpwh != XNO ]; then
+ tr -d '\r' < $cpwh > $WH
+fi
+
+cat $F >> $WRKDIR/xc/config/cf/xf86site.def
+
+exit 0