summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormezz <mezz@df743ca5-7f9a-e211-a948-0013205c9059>2012-07-06 10:48:09 +0800
committermezz <mezz@df743ca5-7f9a-e211-a948-0013205c9059>2012-07-06 10:48:09 +0800
commitacea36189b24f5377282490d68d34a0cdc544131 (patch)
treec8f842b0fcab1e1318461aa5e70c99e5f07f55dc
parenta23518167259f9d5b988dd7aa0880fb1747b0a47 (diff)
downloadmarcuscom-ports-experimental-acea36189b24f5377282490d68d34a0cdc544131.tar.gz
marcuscom-ports-experimental-acea36189b24f5377282490d68d34a0cdc544131.tar.zst
marcuscom-ports-experimental-acea36189b24f5377282490d68d34a0cdc544131.zip
Add MATE ports, at 1.2.x version. It's incomplete and only has 10 ports at
the moment. More will be repocopied. I know that there is 1.4 that is coming very soon and I will update these ports when it's releasing. Check in TODO-mate for the TODO list. git-svn-id: svn://creme-brulee.marcuscom.com/ports-experimental/trunk@17442 df743ca5-7f9a-e211-a948-0013205c9059
-rw-r--r--Mk/bsd.mate.mk290
-rw-r--r--Mk/bsd.port.mk6467
-rw-r--r--Mk/bsd.sites.mk1534
-rw-r--r--TODO-mate38
-rw-r--r--devel/libmatecomponent/Makefile38
-rw-r--r--devel/libmatecomponent/distinfo2
-rw-r--r--devel/libmatecomponent/files/patch-activation-server_Makefile.am11
-rw-r--r--devel/libmatecomponent/files/patch-activation-server_activation-server-main.c11
-rw-r--r--devel/libmatecomponent/files/patch-utils_matecomponent-slay.in21
-rw-r--r--devel/libmatecomponent/pkg-descr5
-rw-r--r--devel/libmatecomponent/pkg-plist329
-rw-r--r--devel/mate-common/Makefile24
-rw-r--r--devel/mate-common/distinfo2
-rw-r--r--devel/mate-common/pkg-descr4
-rw-r--r--devel/mate-common/pkg-plist8
-rw-r--r--devel/mate-conf/Makefile56
-rw-r--r--devel/mate-conf/distinfo2
-rw-r--r--devel/mate-conf/files/patch-gsettings_mateconfsettingsbackend.c9
-rw-r--r--devel/mate-conf/files/patch-mateconf_default.path.in11
-rw-r--r--devel/mate-conf/pkg-descr18
-rw-r--r--devel/mate-conf/pkg-plist214
-rw-r--r--devel/mate-corba/Makefile45
-rw-r--r--devel/mate-corba/distinfo2
-rw-r--r--devel/mate-corba/files/patch-src_orb_orb-core_matecorba-typelib.c10
-rw-r--r--devel/mate-corba/pkg-descr5
-rw-r--r--devel/mate-corba/pkg-plist101
-rw-r--r--devel/mate-vfs/Makefile117
-rw-r--r--devel/mate-vfs/distinfo2
-rw-r--r--devel/mate-vfs/files/patch-libmatevfs_mate-vfs-application-registry.c26
-rw-r--r--devel/mate-vfs/files/patch-libmatevfs_mate-vfs-filesystem-type.c18
-rw-r--r--devel/mate-vfs/files/patch-libmatevfs_mate-vfs-hal-mounts.c33
-rw-r--r--devel/mate-vfs/files/patch-libmatevfs_xdgmime.c11
-rw-r--r--devel/mate-vfs/files/patch-libmatevfs_xdgmimecache.h12
-rw-r--r--devel/mate-vfs/files/patch-mate-vfs-2.0.pc.in9
-rw-r--r--devel/mate-vfs/files/patch-mate-vfs-module-2.0.pc.in9
-rw-r--r--devel/mate-vfs/files/patch-modules_file-method-acl.c11
-rw-r--r--devel/mate-vfs/files/patch-modules_gzip-method.c10
-rw-r--r--devel/mate-vfs/pkg-deinstall.in20
-rw-r--r--devel/mate-vfs/pkg-descr7
-rw-r--r--devel/mate-vfs/pkg-install.in20
-rw-r--r--devel/mate-vfs/pkg-plist320
-rw-r--r--graphics/libmatecanvas/Makefile35
-rw-r--r--graphics/libmatecanvas/distinfo2
-rw-r--r--graphics/libmatecanvas/files/patch-libmatecanvas_mate-canvas-shape.c11
-rw-r--r--graphics/libmatecanvas/pkg-descr3
-rw-r--r--graphics/libmatecanvas/pkg-plist186
-rw-r--r--misc/mate-mime-data/Makefile28
-rw-r--r--misc/mate-mime-data/distinfo2
-rw-r--r--misc/mate-mime-data/files/patch-mate-vfs.applications18
-rw-r--r--misc/mate-mime-data/pkg-descr4
-rw-r--r--misc/mate-mime-data/pkg-plist92
-rw-r--r--textproc/mate-doc-utils/Makefile47
-rw-r--r--textproc/mate-doc-utils/distinfo2
-rw-r--r--textproc/mate-doc-utils/pkg-descr7
-rw-r--r--textproc/mate-doc-utils/pkg-plist307
-rw-r--r--x11-toolkits/libmatecomponentui/Makefile35
-rw-r--r--x11-toolkits/libmatecomponentui/distinfo2
-rw-r--r--x11-toolkits/libmatecomponentui/files/patch-bonobo_bonobo-ui-util.c21
-rw-r--r--x11-toolkits/libmatecomponentui/pkg-descr7
-rw-r--r--x11-toolkits/libmatecomponentui/pkg-plist234
-rw-r--r--x11/libmate/Makefile66
-rw-r--r--x11/libmate/distinfo2
-rw-r--r--x11/libmate/files/patch-libmate_Makefile.am11
-rw-r--r--x11/libmate/files/patch-libmate_libmate-2.0.pc.in9
-rw-r--r--x11/libmate/files/patch-libmate_mate-util.c18
-rw-r--r--x11/libmate/files/pkg-deinstall.in20
-rw-r--r--x11/libmate/pkg-descr3
-rw-r--r--x11/libmate/pkg-plist219
68 files changed, 11273 insertions, 0 deletions
diff --git a/Mk/bsd.mate.mk b/Mk/bsd.mate.mk
new file mode 100644
index 0000000..e080e51
--- /dev/null
+++ b/Mk/bsd.mate.mk
@@ -0,0 +1,290 @@
+#-*- tab-width: 4; -*-
+# ex:ts=4
+#
+# $FreeBSD$
+# $NetBSD$
+# $MCom$
+#
+# Please view me with 4 column tabs!
+
+#######################################################
+#
+# *** WARNING: Disable MARCUSCOM before merge in FreeBSD!
+# Please also remove this section before merging into FreeBSD.
+#
+#MARCUSCOM_CVS=yes
+
+# ======================= USERS =================================
+#
+# There are no significant user-definable settings in here.
+# This file is a framework to make it easier to create MATE ports.
+#
+# ======================= /USERS ================================
+
+.if !defined(_POSTMKINCLUDED) && !defined(Mate_Pre_Include)
+
+# Please make sure all changes to this file are passed through the maintainer.
+# Do not commit them yourself (unless of course you're the Port's Wraith ;).
+Mate_Include_MAINTAINER= gnome@FreeBSD.org
+Mate_Pre_Include= bsd.mate.mk
+
+# This section defines possible names of MATE components and all information
+# necessary for ports to use those components.
+
+# Ports can use this as follows:
+#
+# USE_MATE= gnomeprint bonobo
+#
+# .include <bsd.port.mk>
+#
+# As a result proper LIB_DEPENDS/RUN_DEPENDS will be added and CONFIGURE_ENV
+# and MAKE_ENV defined.
+#
+
+# non-version specific components
+_USE_MATE_ALL= autogen intlhack intltool ltasneededhack lthack ltverhack \
+ matehack
+
+# MATE components
+_USE_MATE_ALL+= canvas common component componentui conf corba docutils \
+ mimedata lib vfs
+
+MATE_MAKEFILEIN?= Makefile.*
+SCROLLKEEPER_DIR= /var/db/rarian
+matehack_PRE_PATCH= ${FIND} ${WRKSRC} -name "${MATE_MAKEFILEIN}*" -type f | ${XARGS} ${REINPLACE_CMD} -e \
+ 's|[(]libdir[)]/locale|(prefix)/share/locale|g ; \
+ s|[(]libdir[)]/pkgconfig|(prefix)/libdata/pkgconfig|g ; \
+ s|[(]datadir[)]/pkgconfig|(prefix)/libdata/pkgconfig|g ; \
+ s|[(]prefix[)]/lib/pkgconfig|(prefix)/libdata/pkgconfig|g ; \
+ s|[$$][(]localstatedir[)]/scrollkeeper|${SCROLLKEEPER_DIR}|g ; \
+ s|[(]libdir[)]/matecomponent/servers|(prefix)/libdata/matecomponent/servers|g' ; \
+ ${FIND} ${WRKSRC} -name "configure" -type f | ${XARGS} ${REINPLACE_CMD} -e \
+ 's|-lpthread|${PTHREAD_LIBS}|g ; \
+ s|DATADIRNAME=lib|DATADIRNAME=share|g ; \
+ s|{libdir}/locale|{prefix}/share/locale|g'
+
+lthack_PRE_PATCH= ${FIND} ${WRKSRC} -name "configure" -type f | ${XARGS} ${REINPLACE_CMD} -e \
+ '/^LIBTOOL_DEPS="$$ac_aux_dir\/ltmain.sh"$$/s|$$|; $$ac_aux_dir/ltconfig $$LIBTOOL_DEPS;|'
+
+canvas_DETECT= ${LOCALBASE}/libdata/pkgconfig/libmatecanvas-2.0.pc
+canvas_BUILD_DEPENDS= ${canvas_DETECT}:${PORTSDIR}/graphics/libmatecanvas
+canvas_LIB_DEPENDS= matecanvas-2:${PORTSDIR}/graphics/libmatecanvas
+canvas_RUN_DEPENDS= ${canvas_DETECT}:${PORTSDIR}/graphics/libmatecanvas
+
+common_DETECT= ${LOCALBASE}/bin/mate-autogen
+common_BUILD_DEPENDS= ${common_DETECT}:${PORTSDIR}/devel/mate-common
+common_RUN_DEPENDS= ${common_DETECT}:${PORTSDIR}/devel/mate-common
+
+component_DETECT= ${LOCALBASE}/libdata/pkgconfig/libmatecomponent-2.0.pc
+component_BUILD_DEPENDS=${component_DETECT}:${PORTSDIR}/devel/libmatecomponent
+component_LIB_DEPENDS= matecomponent-2:${PORTSDIR}/devel/libmatecomponent
+component_RUN_DEPENDS= ${component_DETECT}:${PORTSDIR}/devel/libmatecomponent
+
+componentui_DETECT= ${LOCALBASE}/libdata/pkgconfig/libmatecomponentui-2.0.pc
+componentui_BUILD_DEPENDS=${componentui_DETECT}:${PORTSDIR}/x11-toolkits/libmatecomponentui
+componentui_LIB_DEPENDS=matecomponentui-2:${PORTSDIR}/x11-toolkits/libmatecomponentui
+componentui_RUN_DEPENDS=${componentui_DETECT}:${PORTSDIR}/x11-toolkits/libmatecomponentui
+
+conf_DETECT= ${LOCALBASE}/libdata/pkgconfig/mateconf-2.0.pc
+conf_BUILD_DEPENDS= ${conf_DETECT}:${PORTSDIR}/devel/mate-conf
+conf_LIB_DEPENDS= mateconf-2:${PORTSDIR}/devel/mate-conf
+conf_RUN_DEPENDS= ${conf_DETECT}:${PORTSDIR}/devel/mate-conf
+MATECONF_CONFIG_OPTIONS?=merged
+MATECONF_CONFIG_DIRECTORY?=etc/mateconf/mateconf.xml.defaults
+MATECONF_CONFIG_SOURCE?=xml:${MATECONF_CONFIG_OPTIONS}:${PREFIX}/${MATECONF_CONFIG_DIRECTORY}
+MATECONF_PREFIX= --with-mateconf-source=${MATECONF_CONFIG_SOURCE}
+
+corba_DETECT= ${LOCALBASE}/libdata/pkgconfig/MateCORBA-2.0.pc
+corba_BUILD_DEPENDS= ${corba_DETECT}:${PORTSDIR}/devel/mate-corba
+corba_LIB_DEPENDS= MateCORBA-2:${PORTSDIR}/devel/mate-corba
+corba_RUN_DEPENDS= ${corba_DETECT}:${PORTSDIR}/devel/mate-corba
+
+docutils_DETECT= ${LOCALBASE}/libdata/pkgconfig/mate-doc-utils.pc
+docutils_BUILD_DEPENDS= ${docutils_DETECT}:${PORTSDIR}/textproc/mate-doc-utils
+docutils_RUN_DEPENDS= ${docutils_DETECT}:${PORTSDIR}/textproc/mate-doc-utils
+
+intltool_DETECT= ${LOCALBASE}/bin/intltool-extract
+intltool_BUILD_DEPENDS= ${intltool_DETECT}:${PORTSDIR}/textproc/intltool
+
+intlhack_PRE_PATCH= ${FIND} ${WRKSRC} -name "intltool-merge.in" | ${XARGS} ${REINPLACE_CMD} -e \
+ 's|mkdir $$lang or|mkdir $$lang, 0777 or| ; \
+ s|^push @INC, "/.*|push @INC, "${LOCALBASE}/share/intltool";| ; \
+ s|/usr/bin/iconv|${LOCALBASE}/bin/iconv|g ; \
+ s|unpack *[(]'"'"'U\*'"'"'|unpack ('"'"'C*'"'"'|'
+.if ${USE_MATE:Mintlhack}!=""
+USE_MATE+= intltool
+.endif
+
+lib_DETECT= ${LOCALBASE}/libdata/pkgconfig/libmate-2.0.pc
+lib_BUILD_DEPENDS= ${lib_DETECT}:${PORTSDIR}/x11/libmate
+lib_LIB_DEPENDS= mate-2:${PORTSDIR}/x11/libmate
+lib_RUN_DEPENDS= ${lib_DETECT}:${PORTSDIR}/x11/libmate
+
+mimedata_DETECT= ${LOCALBASE}/libdata/pkgconfig/mate-mime-data-2.0.pc
+mimedata_BUILD_DEPENDS= ${mimedata_DETECT}:${PORTSDIR}/misc/mate-mime-data
+mimedata_RUN_DEPENDS= ${mimedata_DETECT}:${PORTSDIR}/misc/mate-mime-data
+
+vfs_DETECT= ${LOCALBASE}/libdata/pkgconfig/mate-vfs-2.0.pc
+vfs_BUILD_DEPENDS= ${vfs_DETECT}:${PORTSDIR}/devel/mate-vfs
+vfs_LIB_DEPENDS= matevfs-2:${PORTSDIR}/devel/mate-vfs
+vfs_RUN_DEPENDS= ${vfs_DETECT}:${PORTSDIR}/devel/mate-vfs
+
+# End component definition section
+
+.endif
+# End of optional part.
+
+.if defined(_POSTMKINCLUDED) && !defined(Mate_Post_Include)
+
+Mate_Post_Include= bsd.mate.mk
+
+.if defined(USE_MATE)
+# Then handle the ltverhack component (it has to be done here, because
+# we rely on some bsd.autotools.mk variables, and bsd.autotools.mk is
+# included in the post-makefile section).
+.if defined(_AUTOTOOL_libtool)
+lthacks_CONFIGURE_ENV= ac_cv_path_DOLT_BASH=
+lthacks_PRE_PATCH= ${CP} -pf ${LTMAIN} ${WRKDIR}/mate-ltmain.sh && \
+ ${CP} -pf ${LIBTOOL} ${WRKDIR}/mate-libtool && \
+ for file in ${LIBTOOLFILES}; do \
+ ${REINPLACE_CMD} -e \
+ '/^ltmain=/!s|$$ac_aux_dir/ltmain\.sh|${LIBTOOLFLAGS} ${WRKDIR}/mate-ltmain.sh|g; \
+ /^LIBTOOL=/s|$$(top_builddir)/libtool|${WRKDIR}/mate-libtool|g' \
+ ${PATCH_WRKSRC}/$$file; \
+ done;
+.else
+. if ${USE_MATE:Mltverhack*}!="" || ${USE_MATE:Mltasneededhack}!=""
+IGNORE= cannot install: ${PORTNAME} uses the ltverhack and/or ltasneededhack MATE components but does not use libtool
+. endif
+.endif
+
+.if ${USE_MATE:Mltverhack\:*:C/^[^:]+:([^:]+).*/\1/}==""
+ltverhack_LIB_VERSION= major=.`expr $$current - $$age`
+.else
+ltverhack_LIB_VERSION= major=".${USE_MATE:Mltverhack\:*:C/^[^:]+:([^:]+).*/\1/}"
+.endif
+ltverhack_PATCH_DEPENDS=${LIBTOOL_DEPENDS}
+ltverhack_PRE_PATCH= for file in mate-ltmain.sh mate-libtool; do \
+ if [ -f ${WRKDIR}/$$file ]; then \
+ ${REINPLACE_CMD} -e \
+ '/freebsd-elf)/,/;;/ s|major="\.$$current"|${ltverhack_LIB_VERSION}|; \
+ /freebsd-elf)/,/;;/ s|versuffix="\.$$current"|versuffix="$$major"|' \
+ ${WRKDIR}/$$file; \
+ fi; \
+ done
+
+ltasneededhack_PATCH_DEPENDS=${LIBTOOL_DEPENDS}
+ltasneededhack_PRE_PATCH= if [ -f ${WRKDIR}/mate-libtool ]; then \
+ ${REINPLACE_CMD} -e \
+ '/^archive_cmds=/s/-shared/-shared -Wl,--as-needed/ ; \
+ /^archive_expsym_cmds=/s/-shared/-shared -Wl,--as-needed/' \
+ ${WRKDIR}/mate-libtool; \
+ fi
+
+
+# Comparing between USE_MATE and _USE_MATE_ALL to make sure the component
+# exists in _USE_MATE_ALL. If it does not exist then give an error about it.
+. for component in ${USE_MATE:C/^([^:]+).*/\1/}
+. if ${_USE_MATE_ALL:M${component}}==""
+.error cannot install: Unknown component USE_MATE=${component}
+. endif
+. endfor
+
+. if ${USE_MATE:Mltverhack*}!= "" || ${USE_MATE:Mltasneededhack}!= ""
+MATE_PRE_PATCH+= ${lthacks_PRE_PATCH}
+CONFIGURE_ENV+= ${lthacks_CONFIGURE_ENV}
+. endif
+
+. for component in ${USE_MATE:C/^([^:]+).*/\1/}
+. if defined(${component}_PATCH_DEPENDS)
+PATCH_DEPENDS+= ${${component}_PATCH_DEPENDS}
+. endif
+
+. if defined(${component}_DETECT)
+. if ${USE_MATE:M${component}\:build}!=""
+BUILD_DEPENDS+= ${${component}_BUILD_DEPENDS}
+. elif ${USE_MATE:M${component}\:run}!=""
+RUN_DEPENDS+= ${${component}_RUN_DEPENDS}
+. else
+. if defined(${component}_LIB_DEPENDS)
+LIB_DEPENDS+= ${${component}_LIB_DEPENDS}
+. else
+BUILD_DEPENDS+= ${${component}_BUILD_DEPENDS}
+RUN_DEPENDS+= ${${component}_RUN_DEPENDS}
+. endif
+. endif
+. endif
+
+. if defined(${component}_CONFIGURE_TARGET)
+CONFIGURE_ARGS+=${${component}_CONFIGURE_ARGS}
+. endif
+
+. if defined(${component}_CONFIGURE_ENV)
+CONFIGURE_ENV+= ${${component}_CONFIGURE_ENV}
+. endif
+
+. if defined(${component}_MAKE_ENV)
+MAKE_ENV+= ${${component}_MAKE_ENV}
+. endif
+
+. if !defined(CONFIGURE_TARGET) && defined(${component}_CONFIGURE_TARGET)
+CONFIGURE_TARGET= ${${component}_CONFIGURE_TARGET}
+. endif
+
+. if defined(${component}_PRE_PATCH)
+MATE_PRE_PATCH+= ; ${${component}_PRE_PATCH}
+. endif
+. endfor
+.endif # USE_MATE check
+
+.if ${USE_MATE:Mautogen}!=""
+
+CONFIGURE_ENV+= NOCONFIGURE=yes
+
+pre-configure: mate-pre-configure
+
+mate-pre-configure:
+ @(cd ${CONFIGURE_WRKSRC} ; ${SETENV} ${CONFIGURE_ENV} ./autogen.sh)
+.endif
+
+.if defined(MATE_PRE_PATCH)
+
+pre-configure-script: mate-pre-configure-script
+
+mate-pre-configure-script:
+ @${MATE_PRE_PATCH:C/^;//1}
+.endif
+
+.if ${MAINTAINER}=="gnome@FreeBSD.org"
+CONFIGURE_FAIL_MESSAGE= "Please run the gnomelogalyzer, available from \"http://www.freebsd.org/gnome/gnomelogalyzer.sh\", which will diagnose the problem and suggest a solution. If - and only if - the gnomelogalyzer cannot solve the problem, report the build failure to the FreeBSD MATE team at ${MAINTAINER}, and attach (a) \"${CONFIGURE_WRKSRC}/${CONFIGURE_LOG}\", (b) the output of the failed make command, and (c) the gnomelogalyzer output. Also, it might be a good idea to provide an overview of all packages installed on your system (i.e. an \`ls ${PKG_DBDIR}\`). Put your attachment up on any website, copy-and-paste into http://freebsd-gnome.pastebin.com, or use send-pr(1) with the attachment. Try to avoid sending any attachments to the mailing list (${MAINTAINER}), because attachments sent to FreeBSD mailing lists are usually discarded by the mailing list software."
+.endif
+
+
+.if defined(MATECONF_SCHEMAS) || (defined(_USE_MATE) && ${_USE_MATE:Mmatehier}!="")
+pre-su-install: mate-pre-su-install
+post-install: mate-post-install
+
+mate-pre-su-install:
+.if defined(_USE_MATE) && ${_USE_MATE:Mmatehier}!="" && !defined(NO_MTREE)
+ @${MTREE_CMD} ${MTREE_ARGS:S/${MTREE_FILE}/${MATE_MTREE_FILE}/} ${PREFIX}/ >/dev/null
+.endif
+.if defined(MATECONF_SCHEMAS)
+ @${MKDIR} ${PREFIX}/etc/mateconf/mateconf.xml.defaults/
+.else
+ @${DO_NADA}
+.endif
+
+mate-post-install:
+. if defined(MATECONF_SCHEMAS)
+ @for i in ${MATECONF_SCHEMAS}; do \
+ ${ECHO_CMD} "@unexec env MATECONF_CONFIG_SOURCE=xml:${MATECONF_CONFIG_OPTIONS}:%D/${MATECONF_CONFIG_DIRECTORY} mateconftool-2 --makefile-uninstall-rule %D/etc/mateconf/schemas/$${i} > /dev/null || /usr/bin/true" \
+ >> ${TMPPLIST}; \
+ ${ECHO_CMD} "etc/mateconf/schemas/$${i}" >> ${TMPPLIST}; \
+ ${ECHO_CMD} "@exec env MATECONF_CONFIG_SOURCE=xml:${MATECONF_CONFIG_OPTIONS}:%D/${MATECONF_CONFIG_DIRECTORY} mateconftool-2 --makefile-install-rule %D/etc/mateconf/schemas/$${i} > /dev/null || /usr/bin/true" \
+ >> ${TMPPLIST}; \
+ done
+. endif
+.endif
+
+.endif
+# End of use part.
diff --git a/Mk/bsd.port.mk b/Mk/bsd.port.mk
new file mode 100644
index 0000000..294f2f7
--- /dev/null
+++ b/Mk/bsd.port.mk
@@ -0,0 +1,6467 @@
+#-*- tab-width: 4; -*-
+# ex:ts=4
+#
+# $FreeBSD: ports/Mk/bsd.port.mk,v 1.729 2012/06/15 12:04:52 bapt Exp $
+# $NetBSD: $
+#
+# bsd.port.mk - 940820 Jordan K. Hubbard.
+# This file is in the public domain.
+#
+# Please view me with 4 column tabs!
+
+# This is the master file for the most common elements to all port
+# Makefile in the ports system. For a more general overview of its
+# use and importance, see the Porter's Handbook.
+
+# There are two different types of "maintainers" in the ports framework.
+# The maintainer alias of the bsd.port.mk file is listed below in the
+# FreeBSD_MAINTAINER entry. You should consult them if you have any
+# questions/suggestions regarding this file.
+#
+# DO NOT COMMIT CHANGES TO THIS FILE BY YOURSELF, EVEN IF YOU DID NOT GET
+# A RESPONSE FROM THE MAINTAINER(S) WITHIN A REASONABLE TIMEFRAME! ALL
+# UNAUTHORISED CHANGES WILL BE UNCONDITIONALLY REVERTED!
+
+FreeBSD_MAINTAINER= portmgr@FreeBSD.org
+
+# For each port, the MAINTAINER variable is what you should consult for
+# contact information on the person(s) to contact if you have questions/
+# suggestions about that specific port. By default (if no MAINTAINER
+# is listed), a port is maintained by the subscribers of the ports@FreeBSD.org
+# mailing list, and any correspondence should be directed there.
+#
+# MAINTAINER - The e-mail address of the contact person for this port.
+# Default: ports@FreeBSD.org
+#
+# These are meta-variables that are automatically set to the system
+# you are running on. These are provided in case you need to take
+# different actions for different values.
+#
+# ARCH - The architecture of the target machine, such as would be
+# returned by "uname -p". (Note: Ports should test against
+# ARCH, and not the host machine's architecture which is
+# MACHINE_ARCH, to enable ports to be cross-built.)
+# OPSYS - Portability clause. This is the operating system the
+# makefile is being used on. Automatically set to
+# "FreeBSD," "NetBSD," or "OpenBSD" as appropriate.
+# OSREL - The release version (numeric) of the operating system.
+# OSVERSION - The value of __FreeBSD_version.
+#
+# This is the beginning of the list of all variables that need to be
+# defined in a port, listed in order that they should be included
+# to fit in with existing conventions. (Exception: MAINTAINER actually
+# should appear after EXTRACT_ONLY and before MASTER_SITE_BACKUP).
+#
+# These variables are used to identify your port.
+#
+# PORTNAME - Name of software. Mandatory.
+# PORTVERSION - Version of software. Mandatory when no DISTVERSION is given.
+# PORTREVISION - Version of port. Optional. Commonly used to indicate
+# that an update has happened that affects the port
+# framework itself, but not the distributed software
+# (e.g., local patches or Makefile changes).
+# PORTEPOCH - Optional. In certain odd cases, the PORTREVISION logic
+# can be fooled by ports that appear to go backwards
+# numerically (e.g. if port-0.3 is newer than port-1998).
+# In this case, incrementing PORTEPOCH forces the revision.
+# Default: 0 (no effect).
+# PKGNAME - Always defined as
+# ${PKGNAMEPREFIX}${PORTNAME}${PKGNAMESUFFIX}-${PORTVERSION}.
+# Do not define this in your Makefile.
+# PKGNAMEPREFIX - Prefix to specify that port is language-specific, etc.
+# Optional.
+# PKGNAMESUFFIX - Suffix to specify compilation options. Optional.
+# PKGVERSION - Always defined as
+# ${PORTVERSION}.
+# Do not define this in your Makefile.
+# UNIQUENAME - A name for your port that is globally unique. By default,
+# this is set to ${LATEST_LINK} when LATEST_LINK is set,
+# and to ${PKGNAMEPREFIX}${PORTNAME} otherwise.
+# DISTVERSION - Vendor version of the distribution.
+# Default: ${PORTVERSION}
+# DISTNAME - Name of port or distribution used in generating
+# WRKSRC and DISTFILES below.
+# Default:
+# ${PORTNAME}-${DISTVERSIONPREFIX}${DISTVERSION}${DISTVERSIONSUFFIX}
+# CATEGORIES - A list of descriptive categories into which this port falls.
+# Mandatory.
+#
+# These variable describe how to fetch files required for building the port.
+#
+# DISTFILES - Name(s) of archive file(s) containing distribution.
+# Set this to an empty string if the port doesn't require it.
+# Default: ${DISTNAME}${EXTRACT_SUFX}
+# EXTRACT_SUFX - Suffix for archive names
+# You never have to set both DISTFILES and EXTRACT_SUFX.
+# Default: .tar.bz2 if USE_BZIP2 is set, .zip if USE_ZIP is
+# set, .tar.xz if USE_XZ is set, .run if USE_MAKESELF is set,
+# .tar.gz otherwise).
+# MASTER_SITES - Primary location(s) for distribution files if not found
+# locally. See bsd.sites.mk for common choices for
+# MASTER_SITES.
+# MASTER_SITE_SUBDIR
+# - Subdirectory of MASTER_SITES. Will sometimes need to be
+# set to ${PORTNAME} for (e.g.) MASTER_SITE_SOURCEFORGE.
+# Only guaranteed to work for choices of ${MASTER_SITES}
+# defined in bsd.sites.mk.
+# Default: not set.
+# PATCHFILES - Name(s) of additional files that contain distribution
+# patches. Make will look for them at PATCH_SITES (see below).
+# They will automatically be uncompressed before patching if
+# the names end with ".gz", ".bz2" or ".Z".
+# Default: not set.
+# PATCH_SITES - Primary location(s) for distribution patch files
+# if not found locally.
+# DIST_SUBDIR - Suffix to ${DISTDIR}. If set, all ${DISTFILES} and
+# ${PATCHFILES} will be put in this subdirectory of
+# ${DISTDIR} (see below). Also they will be fetched in this
+# subdirectory from FreeBSD mirror sites.
+# ALLFILES - All of ${DISTFILES} and ${PATCHFILES}.
+# IGNOREFILES - If set, don't perform checksum checks on these files.
+# NOFETCHFILES - If set, don't download these files from the ${MASTER_SITES}
+# or ${MASTER_SITE_BACKUP} (but do from
+# ${MASTER_SITE_OVERRIDE})
+# EXTRACT_ONLY - If set, a subset of ${DISTFILES} you want to
+# actually extract.
+# ALWAYS_KEEP_DISTFILES
+# - If set, the package building cluster will save the distfiles
+# along with the packages. This may be required to comply with
+# some licenses, e.g. GPL in some cases.
+# Default: not set.
+#
+# (NOTE: by convention, the MAINTAINER entry (see above) should go here.)
+#
+# These variables are typically set in /etc/make.conf to indicate
+# the user's preferred location to fetch files from. You should
+# rarely need to set these.
+#
+# MASTER_SITE_BACKUP
+# - Backup location(s) for distribution files and patch
+# files if not found locally and ${MASTER_SITES}/${PATCH_SITES}
+# Default:
+# ftp://ftp.FreeBSD.org/pub/FreeBSD/ports/distfiles/${DIST_SUBDIR}/
+# MASTER_SITE_OVERRIDE
+# - If set, override the MASTER_SITES setting with this
+# value.
+# MASTER_SITE_FREEBSD
+# - If set, only use ${MASTER_SITE_BACKUP} for
+# MASTER_SITES.
+# CD_MOUNTPTS - List of CDROM mountpoints to look for distfiles under.
+# This variable supercedes CD_MOUNTPT, which is
+# obsolete.
+#
+# Set these if your port should not be built under certain circumstances.
+# These are string variables; you should set them to the reason why
+# they are necessary.
+#
+# RESTRICTED - Prevent the distribution of distfiles and packages to
+# the FTP sites or on CDROM (e.g. forbidden by license
+# considerations).
+# NO_CDROM - Packages and distfiles may not go on CDROM (e.g. must
+# not be re-sold) but can go on FTP sites.
+# NO_PACKAGE - Port should not be packaged for ftp sites or CDROMs,
+# but distfiles can be put on ftp sites and CDROMs.
+# FORBIDDEN - Package build should not be attempted because of
+# security vulnerabilities.
+# IGNORE - Package build should be skipped entirely (e.g.
+# because of serious unfixable problems in the build,
+# because it cannot be manually fetched, etc). Error
+# logs will not appear on pointyhat, so this should be
+# used sparingly.
+# BROKEN - Port is believed to be broken. Package builds will
+# still be attempted on the pointyhat package cluster to
+# test this assumption.
+# DEPRECATED - Port is deprecated to install. Advisory only.
+# EXPIRATION_DATE
+# - If DEPRECATED is set, determines a date when
+# the port is planed to remove. The date format is
+# ISO 8601 (YYYY-MM-DD).
+#
+# DISABLE_VULNERABILITIES
+# - If set, do not check if the port is listed in the
+# vulnerabilities database.
+#
+# In addition to RESTRICTED or NO_CDROM, if only a subset of distfiles
+# or patchfiles have redistribution restrictions, set the following
+# to the list of such files.
+#
+# RESTRICTED_FILES
+# - List of files that cannot be redistributed.
+# Default: "${DISTFILES} ${PATCHFILES}" if RESTRICTED
+# or NO_CDROM is set, empty otherwise.
+#
+# These variables are booleans, so you don't need to set them to the reason.
+#
+# IS_INTERACTIVE
+# - Set this if your port needs to interact with the user
+# during any step in a package build. User can then decide
+# to skip this port by setting ${BATCH}, or compiling only
+# the interactive ports by setting ${INTERACTIVE}.
+# Default: not set.
+# USE_SUBMAKE - Set this if you want that each of the port's main 6 targets
+# (extract, patch, configure, build, install and package) to be
+# executed in a separate make(1) process. Useful when one of
+# the stages needs to influence make(1) variables of the later
+# stages using ${WRKDIR}/Makefile.inc generated on the fly.
+# Default: not set.
+#
+# Set these if your port only makes sense to certain architectures.
+# They are lists containing names for them (e.g., "alpha i386").
+# (Defaults: not set.)
+#
+# ONLY_FOR_ARCHS
+# - Only build ports if ${ARCH} matches one of these.
+# NOT_FOR_ARCHS - Only build ports if ${ARCH} doesn't match one of these.
+# ONLY_FOR_ARCHS_REASON
+# ONLY_FOR_ARCHS_REASON_${ARCH}
+# - Reason why it's only for ${ONLY_FOR_ARCHS}s
+# NOT_FOR_ARCHS_REASON
+# NOT_FOR_ARCHS_REASON_${ARCH}
+# - Reason why it's not for ${NOT_FOR_ARCHS}s
+# IA32_BINARY_PORT
+# - Set this instead of ONLY_FOR_ARCHS if the given port
+# fetches and installs compiled i386 binaries.
+#
+# Dependency checking. Use these if your port requires another port
+# not in the list below. (Default: empty.)
+#
+# EXTRACT_DEPENDS
+# - A list of "path:dir[:target]" tuples of other ports this
+# package depends on in the "extract" stage. "path" is
+# the name of a file if it starts with a slash (/), an
+# executable otherwise. make will test for the existence
+# (if it is a full pathname) or search for it in your
+# $PATH (if it is an executable) and go into "dir" to do
+# a "make all install" if it's not found. If the third
+# field ("target") exists, it will be used instead of
+# ${DEPENDS_TARGET}. The first field also supports a
+# package name with a version range, in the form package>=1.2
+# if a particular version is desired.
+# PATCH_DEPENDS - A list of "path:dir[:target]" tuples of other ports this
+# package depends on in the "patch" stage. "path" is the
+# name of a file if it starts with a slash (/), an
+# executable otherwise. make will test for the existence
+# (if it is a full pathname) or search for it in your
+# $PATH (if it is an executable) and go into "dir" to do
+# a "make all install" if it's not found. If the third
+# field ("target") exists, it will be used instead of
+# ${DEPENDS_TARGET}. The first field also supports a
+# package name with a version range, in the form package>=1.2
+# if a particular version is desired.
+# FETCH_DEPENDS - A list of "path:dir[:target]" tuples of other ports this
+# package depends in the "fetch" stage. "path" is the
+# name of a file if it starts with a slash (/), an
+# executable otherwise. make will test for the
+# existence (if it is a full pathname) or search for
+# it in your $PATH (if it is an executable) and go
+# into "dir" to do a "make all install" if it's not
+# found. If the third field ("target") exists, it will
+# be used instead of ${DEPENDS_TARGET}. The first field
+# also supports a package name with a version range, in
+# the form package>=1.2 if a particular version is desired.
+# BUILD_DEPENDS - A list of "path:dir[:target]" tuples of other ports this
+# package depends to build (between the "extract" and
+# "build" stages, inclusive). The test done to
+# determine the existence of the dependency is the
+# same as FETCH_DEPENDS. If the third field ("target")
+# exists, it will be used instead of ${DEPENDS_TARGET}.
+# RUN_DEPENDS - A list of "path:dir[:target]" tuples of other ports this
+# package depends to run. The test done to determine
+# the existence of the dependency is the same as
+# FETCH_DEPENDS. This will be checked during the
+# "install" stage and the name of the dependency will
+# be put into the package as well. If the third field
+# ("target") exists, it will be used instead of
+# ${DEPENDS_TARGET}. The first field also supports a
+# package name with a version range, in the form package>=1.2
+# if a particular version is desired.
+# LIB_DEPENDS - A list of "lib:dir[:target]" tuples of other ports this
+# package depends on. "lib" is the name of a shared library.
+# make will use "ldconfig -r" to search for the library.
+# lib can contain extended regular expressions.
+# DEPENDS_TARGET
+# - The default target to execute when a port is calling a
+# dependency.
+# Default: install
+#
+# These variables control options about how a port gets built and/or
+# are shorthand notations for common sets of dependencies.
+# Use these if your port uses some of the common software packages. By
+# convention these should be set to 'yes', although they only need to be
+# defined. Defaults: not set, unless explicitly indicated below.
+#
+# Note: the distinction between the USE_* and WANT_* variables, and the
+# WITH_* and WITHOUT_* variables, are that the former are restricted to
+# usage inside the ports framework, and the latter are reserved for user-
+# settable options. (Setting USE_* in /etc/make.conf is always wrong).
+#
+# WITH_DEBUG - If set, debugging flags are added to CFLAGS and the
+# binaries don't get stripped by INSTALL_PROGRAM or
+# INSTALL_LIB. Besides, individual ports might
+# add their specific to produce binaries for debugging
+# purposes. You can override the debug flags that are
+# passed to the compiler by setting DEBUG_FLAGS. It is
+# set to "-g" at default.
+#
+# USE_BZIP2 - If set, this port tarballs use bzip2, not gzip, for
+# compression.
+# USE_XZ - If set, this port tarballs use xz (or lzma)
+# for compression
+# USE_ZIP - If set, this port distfile uses zip, not tar w/[bg]zip
+# for compression.
+# USE_MAKESELF - If set, this port distfile uses makeself, not tar w/[bg]zip
+# for compression.
+# USE_DOS2UNIX - If set to "YES", remove the ^M from all files
+# under ${WRKSRC}. If set to a string, remove in all
+# files under ${WRKSRC} with one of these names the ^Ms.
+# DOS2UNIX_REGEX
+# - Limit the ^M removal to files which name matches
+# the regular expression.
+# USE_GCC - If set, this port requires this version of gcc, either in
+# the system or installed from a port.
+# USE_CSTD - Override the default C language standard (gnu89, gnu99)
+# USE_BINUTILS - Use binutils suite from port instead of the version in base.
+# USE_GMAKE - If set, this port uses gmake.
+# GMAKE - Set to path of GNU make if not in $PATH.
+# Default: gmake
+##
+# USE_ICONV - If set, this port uses libiconv.
+# USE_GETTEXT - The port uses GNU gettext (libintl).
+# 'build' as a build-time dependency
+# 'yes' as a library dependency
+# 'run' as a run-time dependency
+##
+# USE_GHOSTSCRIPT
+# - If set, this port needs ghostscript to both
+# build and run. If a number is specified,
+# the specified version will be used.
+# The valid value is '7', '8', or '9' in that case.
+# USE_GHOSTSCRIPT_BUILD
+# - If set, this port needs ghostscript to build.
+# USE_GHOSTSCRIPT_RUN
+# - If set, this port needs ghostscript to run.
+# GHOSTSCRIPT_PORT
+# - The port that provides postscript functionality.
+# Some installations may wish to override the default
+# to specify a version without X11 and/or localized
+# versions for their nationality.
+# Default: print/ghostscript9
+# WITH_GHOSTSCRIPT_VER
+# - If set, the specified version of ghostscript will be
+# used. The valid value is "7", "8", or "9". Note that
+# this is for users, not for port maintainers. This
+# should not be used in Makefile.
+##
+# USE_BISON - Implies that the port uses bison in one way or another:
+# 'build', 'run', 'both', implying build,
+# runtime, and both build/run dependencies
+##
+# USE_IMAKE - If set, this port uses imake.
+# XMKMF - Set to path of `xmkmf' if not in $PATH
+# Default: xmkmf -a
+# USE_XLIB - If set, this port uses the X libraries. In the USE_LINUX
+# case the linux X libraries are referenced.
+# USE_DISPLAY - If set, this ports requires a (virtual) X11 environment
+# setup. If the environment variable DISPLAY Is not set,
+# then an extra build dependency on Xvfb is added. Further,
+# if PACKAGE_BUILDING is not set, then CONFIGURE_ENV and
+# MAKE_ENV are extended with a DISPLAY variable.
+#
+# USE_FREETYPE - If set, this port uses the freetype print libraries.
+# USE_GL - A list of Mesa or GL related dependencies needed by the port.
+# Supported components are: glut, glu, glw, gl and linux.
+# If set to "yes", this is equivalent to "glu". Note that
+# glew and glut depend on glu, glw and glu depend on gl.
+# USE_MOTIF - If set, this port uses a Motif toolkit. Implies USE_XORG+= xpm
+# NO_OPENMOTIF - If set, this port uses a custom Motif toolkit
+# instead of Openmotif.
+# Used only when USE_MOTIF is set.
+# WANT_LESSTIF - If set, this port uses Lesstif as Motif toolkit.
+# Used only when USE_MOTIF is set. Implies
+# NO_OPENMOTIF.
+##
+# USE_SDL - If set, this port uses the sdl libraries.
+# See bsd.sdl.mk for more information.
+##
+# USE_OPENAL - If set, this port relies on the OpenAL package.
+# Legal values are: al, soft, si, alut.
+# If set to an unknown value, the port is marked broken.
+# WANT_OPENAL - User-specific OpenAL wishes.
+# Legal values are: soft, si. The default is soft.
+##
+# USE_OPENSSL - If set, this port relies on the OpenSSL package.
+##
+# USE_OPENLDAP - If set, this port uses the OpenLDAP libraries.
+# Implies: WANT_OPENLDAP_VER?=24
+# WANT_OPENLDAP_VER
+# - Legal values are: 23, 24
+# If set to an unknown value, the port is marked BROKEN.
+# WANT_OPENLDAP_SASL
+# - If set, the system should use OpenLDAP libraries
+# with SASL support.
+##
+# USE_FAM - If set, this port uses the File Alteration Monitor.
+#
+# WANT_FAM_SYSTEM
+# - Legal values are: gamin (default),fam
+# If set to an unknown value, the port is marked IGNORE.
+##
+# USE_AUTOTOOLS - If set, this port uses various GNU autotools
+# (libtool, autoconf, autoheader, automake et al.)
+# See bsd.autotools.mk for more details.
+##
+# USE_SCONS - If set, this port uses the Python-based SCons build system
+# See bsd.scons.mk for more details.
+##
+# USE_EFL - If set, this port use EFL libraries.
+# Implies inclusion of bsd.efl.mk. (Also see
+# that file for more information on USE_EFL_*).
+# USE_FPC - If set, this port relies on the Free Pascal language.
+# Implies inclusion of bsd.fpc.mk. (Also see
+# that file for more information on WANT_FPC_*).
+# USE_JAVA - If set, this port relies on the Java language.
+# Implies inclusion of bsd.java.mk. (Also see
+# that file for more information on USE_JAVA_*).
+# USE_OCAML - If set, this port relies on the OCaml language.
+# Implies inclusion of bsd.ocaml.mk. (Also see
+# that file for more information on USE_OCAML*).
+# USE_PYTHON - If set, this port relies on the Python language.
+# Implies inclusion of bsd.python.mk. (Also see
+# that file for more information on USE_PYTHON_*
+# and USE_PYDISTUTILS).
+# USE_R_MOD - If set, this port uses the Comprehensive R Archive Network.
+# See bsd.cran.mk for more details.
+# USE_RUBY - If set, this port relies on the Ruby language.
+# Implies inclusion of bsd.ruby.mk. (Also see
+# that file for more information on USE_RUBY_*).
+# USE_GNUSTEP - If set, this port relies on the GNUstep system.
+# Implies the inclusion of bsd.gnustep.mk.
+# (Also see that file for more information on
+# USE_GNUSTEP_*).
+##
+# USE_GECKO - If set, this port uses the Gecko/Mozilla product.
+# See bsd.gecko.mk for more details.
+##
+# USE_GNOME - A list of the Gnome dependencies the port has (e.g.,
+# glib12, gtk12). Implies that the port needs Gnome.
+# Implies inclusion of bsd.gnome.mk. See bsd.gnome.mk
+# or http://www.FreeBSD.org/gnome/docs/porting.html
+# for more details.
+##
+# USE_MATE - A list of the MATE dependencies the port has (e.g.,
+# glib12, gtk12). Implies that the port needs Gnome.
+# Implies inclusion of bsd.mate.mk. See bsd.mate.mk
+# or http://www.FreeBSD.org/gnome/docs/porting.html
+# for more details.
+##
+# USE_LUA - If set, this port uses the Lua library and related
+# components. See bsd.lua.mk for more details.
+##
+# USE_WX - If set, this port uses the WxWidgets library and related
+# components. See bsd.wx.mk for more details.
+##
+# USE_KDEBASE_VER - Set to 3 to use the KDE windowing system.
+# Implies inclusion of bsd.kde.mk.
+#
+# USE_KDELIBS_VER - Set to 3 to use the KDE libraries.
+# Implies inclusion of bsd.kde.mk.
+#
+# USE_KDE4 - A list of the KDE4 dependencies the port has (e.g.,
+# kdelibs, kdebase). Implies that the port needs KDE.
+# Implies inclusion of bsd.kde4.mk. See bsd.kde4.mk
+# for more details.
+#
+# USE_QT_VER - Set to 3 or 4 to use the respective version
+# of the Qt libraries.
+# Implies inclusion of bsd.kde.mk or bsd.qt.mk.
+#
+# USE_QT4 - A list of the QT4 dependencies the port has (e.g,
+# corelib, webkit). Implies that the port needs Qt.
+# Implies the inclusion of bsd.qt.mk. See bsd.qt.mk
+# for more details.
+#
+# USE_LINUX - Set to yes to say the port needs the default linux base port.
+# Set to value <X>, if the port needs emulators/linux_base-<X>.
+# If set to "7", a dependency is registered to emulators/linux_base.
+# Implies appropriate settings for STRIP and STRIP_CMD.
+# USE_LINUX_PREFIX
+# - controls the action of PREFIX (see above). Only use this
+# if the port is a linux infrastructure port (e.g. contains libs
+# or a sound server which supports the FreeBSD native one),
+# use the default or the X11 prefix if it's a leaf port
+# (e.g. a game or program).
+# Implies NO_MTREE=yes, and, if USE_LDCONFIG is defined:
+# - USE_LINUX=yes
+# - appropriate invocation of the Linux ldconfig
+# USE_LINUX_RPM - Set to yes to pull in variables and targets useful to Linux
+# RPM ports.
+# Implies inclusion of bsd.linux-rpm.mk.
+#
+# LINUX_OSRELEASE - Contains the value of compat.linux.osrelease sysctl.
+# Will be used to distinguish which linux
+# infrastructure ports should be used.
+# Valid values: 2.4.2, 2.6.16.
+# AUTOMATIC_PLIST
+# - Set to yes to enable automatic packing list generation.
+# Currently has no effect unless USE_LINUX_RPM is set.
+#
+# OVERRIDE_LINUX_BASE_PORT
+# - This specifies the default linux base to use, for valid
+# values have a look at the description of USE_LINUX. This is
+# an user-only variable. Don't use it in any port, it's meant
+# to be used in make.conf.
+#
+# LINUX_BASE_PORT
+# - This is a read-only variable, it gets set to a value which is
+# usable in *_DEPENDS (e.g. BUILD_DEPENDS=${LINUX_BASE_PORT}).
+# It honors USE_LINUX=foo and OVERRIDE_LINUX_BASE_PORT.
+##
+# USE_XORG - Set to a list of X.org module dependencies.
+# Implies inclusion of bsd.xorg.mk.
+##
+# USE_RC_SUBR - If set, the ports startup/shutdown script uses the common
+# routines found in /etc/rc.subr.
+# If this is set to a list of files, these files will be
+# automatically added to ${SUB_FILES}, some %%VAR%%'s will
+# automatically be expanded, they will be installed in
+# ${PREFIX}/etc/rc.d and added to the packing list.
+# USE_RCORDER - List of rc.d startup scripts to be called early in the boot
+# process. This acts exactly like USE_RC_SUBR except that
+# scripts are installed in /etc/rc.d.
+# Because local rc.d scripts are included in the base rcorder
+# this option is not needed unless the port installs in the base.
+##
+# USE_APACHE - If set, this port relies on an apache webserver.
+#
+# USE_CDRTOOLS - If set, this port depends on sysutils/cdrtools.
+#
+# USE_NCURSES - If set, this port relies on the ncurses package.
+#
+# Conflict checking. Use if your port cannot be installed at the same time as
+# another package.
+#
+# CONFLICTS - A list of package name patterns that the port conflicts
+# with, separated by blanks. The names may include shell
+# pattern meta-characters "*", "?", "[", "]", and "!".
+# Example: apache*-1.2* apache*-1.3.[012345] apache-*+ssl_*
+#
+# CONFLICTS_BUILD
+# - Check conflict prior to the build.
+#
+# CONFLICTS_INSTALL
+# - Check conflict prior to the installation stage.
+#
+# Various directory definitions and variables to control them.
+# You rarely need to redefine any of these except WRKSRC and NO_WRKSUBDIR.
+#
+# LOCALBASE - Where non-X11 ports install things.
+# Default: /usr/local
+# LINUXBASE - Where Linux ports install things.
+# Default: /compat/linux
+# PREFIX - Where *this* port installs its files.
+# Default: ${LINUXBASE} if USE_LINUX_PREFIX is set,
+# otherwise ${LOCALBASE}
+#
+# IGNORE_PATH_CHECKS
+# - There are some sanity checks against PREFIX.
+# You can disable these checks with defining
+# this variable, but this is not recommended!
+# Only do this if you really know what you are
+# doing. These sanity checks are the following:
+# - PREFIX has to be an absolute path.
+# - PREFIX can't have a trailing slash.
+#
+# MASTERDIR - Where the port finds patches, package files, etc. Define
+# this is you have two or more ports that share most of the
+# files.
+# Default: ${.CURDIR}
+# PORTSDIR - The root of the ports tree.
+# Default: /usr/ports
+# DISTDIR - Where to search for and store copies of original sources
+# Default: ${PORTSDIR}/distfiles
+# PACKAGES - A top level directory where all packages go (rather than
+# going locally to each port).
+# Default: ${PORTSDIR}/packages
+# WRKDIRPREFIX - The place to root the temporary working directory
+# hierarchy.
+# Default: none
+# WRKDIR - A temporary working directory that gets *clobbered* on clean
+# Default: ${WRKDIRPREFIX}${.CURDIR}/work
+# WRKSRC - A subdirectory of ${WRKDIR} where the distribution actually
+# unpacks to.
+# Default: ${WRKDIR}/${DISTNAME} unless NO_WRKSUBDIR is set,
+# in which case simply ${WRKDIR}
+# NO_WRKSUBDIR - Assume port unpacks directly into ${WRKDIR}.
+# PATCHDIR - A directory containing any additional patches you made
+# to port this software to FreeBSD.
+# Default: ${MASTERDIR}/files
+# SCRIPTDIR - A directory containing any auxiliary scripts
+# Default: ${MASTERDIR}/scripts
+# FILESDIR - A directory containing any miscellaneous additional files.
+# Default: ${MASTERDIR}/files
+# PKGDIR - A directory containing any package creation files.
+# Default: ${MASTERDIR}
+# SRC_BASE - The root of the src tree. (Some ports require this to get
+# kernel sources). Default: /usr/src
+# UID_FILES - A list of files containing information about registered UIDs.
+# Note that files have decreasing priority.
+# GID_FILES - A list of files containing information about registered GIDs.
+# Note that files have decreasing priority.
+#
+# Variables that serve as convenient "aliases" for your *-install targets.
+# Use these like: "${INSTALL_PROGRAM} ${WRKSRC}/prog ${PREFIX}/bin".
+#
+# INSTALL_PROGRAM
+# - A command to install binary executables. (By
+# default, also strips them, unless ${STRIP} is
+# overridden to be the empty string).
+# INSTALL_KLD - As INSTALL_PROGRAM, but without the STRIP.
+# INSTALL_LIB - As INSTALL_DATA, but also strips the file.
+# INSTALL_SCRIPT
+# - A command to install executable scripts.
+# INSTALL_DATA - A command to install sharable data.
+# INSTALL_MAN - A command to install manpages. May or not compress,
+# depending on the value of MANCOMPRESSED (see below).
+#
+# Boolean to control whether manpages are installed.
+#
+# NO_INSTALL_MANPAGES
+# - If set, this port doesn't want to install any manpages.
+# Default: not set, i.e. manpages are installed by default.
+#
+# Set the following to specify all manpages that your port installs.
+# These manpages will be automatically listed in ${PLIST}. Depending
+# on the setting of NO_MANCOMPRESS, the make rules will compress the
+# manpages for you.
+#
+# MAN<sect> - A list of manpages, categorized by section. For
+# example, if your port has "man/man1/foo.1" and
+# "man/mann/bar.n", set "MAN1=foo.1" and "MANN=bar.n".
+# The available sections chars are "123456789LN".
+# MAN<sect>_<lang>
+# - If your port does not install all man pages for all
+# languages in MANLANG, language specific pages for
+# a language can be specified with this. For example,
+# if the port installs foo.1 in English, Japanese, and
+# German, bar.1 in English only, and baz.3 in German
+# only, set
+# MANLANG= "" de ja
+# MAN1= foo.1
+# MAN1_EN= bar.1
+# MAN3_DE= baz.3
+# MLINKS - A list of <source, target> tuples for creating links
+# for manpages. For example, "MLINKS= a.1 b.1 c.3 d.3"
+# will do an "ln -sf a.1 b.1" and "ln -sf c.3 d.3" in
+# appropriate directories. (Use this even if the port
+# installs its own manpage links so they will show up
+# correctly in ${PLIST}.)
+# MANPREFIX - The directory prefix for ${MAN<sect>} and ${MLINKS}.
+# Default: ${PREFIX}
+# MAN<sect>PREFIX
+# - If manual pages of some sections install in different
+# locations than others, use these.
+# Default: ${MANPREFIX}
+# MANCOMPRESSED - This variable can take values "yes", "no" or
+# "maybe". "yes" means manpages are installed
+# compressed; "no" means they are not; "maybe" means
+# it changes depending on the value of NO_MANCOMPRESS.
+# Default: "yes" if USE_IMAKE is set and NO_INSTALL_MANPAGES
+# is not set, and "no" otherwise.
+#
+# Set the following to specify all .info files your port installs.
+#
+# INFO - A list of .info files (omitting the trailing ".info");
+# only one entry per document! These files are listed in
+# the path relative to ${INFO_PATH}.
+# INFO_PATH - Path, where all .info files will be installed by your
+# port, relative to ${PREFIX}
+# Default: "share/info" if ${PREFIX} is equal to /usr
+# and "info" otherwise.
+#
+# Set the following to specify all documentation your port installs into
+# ${DOCSDIR}
+#
+# PORTDOCS - A list of files and directories relative to DOCSDIR.
+# Shell glob patterns can be used, directories include
+# the entire subtree of contained files and directories.
+# Should not be set when no documentation files are
+# installed.
+# Useful for dynamically generated documentation.
+#
+# Set the following to specify all documentation your port installs into
+# ${EXAMPLESDIR}
+#
+# PORTEXAMPLES - A list of files and directories relative to EXAMPLESDIR.
+# Shell glob patterns can be used, directories include
+# the entire subtree of contained files and directories.
+# Should not be set when no examples files are
+# installed.
+# Useful for dynamically generated examples.
+#
+# Set the following to specify all files and directories your port installs into
+# ${DATADIR}
+#
+# PORTDATA - A list of files and directories relative to DATADIR.
+# Shell glob patterns can be used, directories include
+# the entire subtree of contained files and directories.
+# Should not be set when no data files are
+# installed.
+# Useful for dynamically generated data files.
+#
+# Default targets and their behaviors:
+#
+# fetch - Retrieves missing ${DISTFILES} and ${PATCHFILES} for this
+# port.
+# fetch-list - Show list of commands to retrieve missing ${DISTFILES} and
+# ${PATCHFILES} for this port.
+# fetch-recursive
+# - Retrieves missing ${DISTFILES} and ${PATCHFILES} for this
+# port and dependencies.
+# fetch-recursive-list
+# - Show list of commands to retrieve missing ${DISTFILES} and
+# ${PATCHFILES} for this port and dependencies.
+# fetch-required
+# - Retrieves missing ${DISTFILES} and ${PATCHFILES} for this
+# port and dependencies.
+# fetch-required-list
+# - Show list of commands to retrieve missing ${DISTFILES} and
+# ${PATCHFILES} for this port and dependencies.
+# fetch-url-list
+# - Show list of URLS to retrieve missing ${DISTFILES} and
+# ${PATCHFILES} for this port.
+# fetch-urlall-list
+# - Show list of URLS to retrieve ${DISTFILES} and
+# ${PATCHFILES} for this port.
+#
+# all-depends-list
+# - Show all directories which are dependencies
+# for this port.
+# build-depends-list
+# - Show all directories which are build-dependencies
+# for this port.
+# package-depends-list
+# - Show all directories which are package-dependencies
+# for this port. This is based upon the dependency
+# tree as recorded in the Makefiles of the ports
+# collection, not as recorded in the currently
+# installed ports.
+# actual-package-depends
+# - Like package-depends-list but with the difference
+# that the dependencies of the currently installed
+# ports are used instead of the dependencies as
+# recorded in the ports collection.
+# run-depends-list
+# - Show all directories which are run-dependencies
+# for this port.
+#
+# extract - Unpacks ${DISTFILES} into ${WRKDIR}.
+# patch - Apply any provided patches to the source.
+# configure - Runs either GNU configure, one or more local configure
+# scripts or nothing, depending on what's available.
+# build - Actually compile the sources.
+# install - Install the results of a build.
+# reinstall - Install the results of a build, ignoring "already installed"
+# flag.
+# deinstall - Remove the installation.
+# deinstall-all - Remove all installations with the same PKGORIGIN.
+# package - Create a package from an _installed_ port.
+# package-recursive
+# - Create a package for a port and _all_ of its dependencies.
+# describe - Try to generate a one-line description for each port for
+# use in INDEX files and the like.
+# checkpatch - Do a "patch -C" instead of a "patch". Note that it may
+# give incorrect results if multiple patches deal with
+# the same file.
+# checksum - Use distinfo to ensure that your distfiles are valid.
+# checksum-recursive
+# - Run checksum in this port and all dependencies.
+# makesum - Generate distinfo (only do this for your own ports!).
+# clean - Remove ${WRKDIR} and other temporary files used for building.
+# clean-depends - Do a "make clean" for all dependencies.
+# config - Configure options for this port (using ${DIALOG}).
+# Automatically run prior to extract, patch, configure, build,
+# install, and package.
+# config-recursive
+# - Configure options for this port for a port and all its
+# dependencies.
+# showconfig - Display options config for this port.
+# showconfig-recursive
+# - Display options config for this port and all its
+# dependencies.
+# rmconfig - Remove the options config for this port.
+# rmconfig-recursive
+# - Remove the options config for this port and all its
+# dependencies.
+#
+# Default sequence for "all" is:
+#
+# check-sanity fetch checksum extract patch configure build
+#
+# Please read the comments in the targets section below; you
+# should be able to use the pre-* or post-* targets/scripts
+# (which are available for every stage except checksum) or
+# override the do-* targets to do pretty much anything you want.
+#
+# NEVER override the "regular" targets unless you want to open
+# a major can of worms.
+#
+# Set these variables if your port doesn't need some of the steps.
+# Note that there are no NO_PATCH or NO_CONFIGURE variables because
+# those steps are empty by default. NO_EXTRACT is not allowed anymore
+# since we need to at least create ${WRKDIR}. Also, NO_CHECKSUM is a user
+# variable and is not to be set in a port's Makefile. See above for NO_PACKAGE.
+#
+# NO_BUILD - Use a dummy (do-nothing) build target.
+# NO_INSTALL - Use a dummy (do-nothing) install target.
+#
+# Here are some variables used in various stages.
+#
+# For options:
+# OPTIONS - List of what WITH_<option> options this port accept. The
+# format is <option> "<description>" [on|off]
+# Example:
+# FLEXRESP "Flexible response to events" off
+# which tell that an option WITH_FLEXRESP exists for this port,
+# that by default it is not defined, and that the description to
+# show to a user in the config dialog is "Flexible response to
+# events". If you have more than one option, just chain them
+# into a single variable. NOTE: To make options work, you need
+# to include bsd.port.pre.mk before you start testing the
+# WITH_xyz variables.
+#
+# For fetch:
+#
+# FETCH_BINARY - Path to ftp/http fetch command if not in $PATH.
+# Default: "/usr/bin/fetch"
+# FETCH_ARGS - Arguments to ftp/http fetch command.
+# Default: "-AFpr"
+# FETCH_CMD - ftp/http fetch command.
+# Default: ${FETCH_BINARY} ${FETCH_ARGS}
+# FETCH_BEFORE_ARGS
+# - Arguments to ${FETCH_CMD} before filename.
+# Default: none
+# FETCH_AFTER_ARGS
+# - Arguments to ${FETCH_CMD} following filename.
+# Default: none
+# FETCH_ENV - Environment to pass to ${FETCH_CMD}.
+# Default: none
+# FETCH_REGET - Times to retry fetching of files on checksum errors.
+# Default: 1
+#
+# For extract:
+#
+# EXTRACT_CMD - Command for extracting archive: "bzip2" if USE_BZIP2
+# is set, "unzip" if USE_ZIP is set, "unmakeself" if
+# USE_MAKESELF if set, "gzip" otherwise.
+# EXTRACT_BEFORE_ARGS
+# - Arguments to ${EXTRACT_CMD} before filename.
+# Default: "-dc"
+# EXTRACT_AFTER_ARGS
+# - Arguments to ${EXTRACT_CMD} following filename.
+# default: "| tar -xf -"
+# EXTRACT_PRESERVE_OWNERSHIP
+# - Normally, when run as "root", the extract stage will
+# change the owner and group of all files under ${WRKDIR}
+# to 0:0. Set this variable if you want to turn off this
+# feature.
+# For patch:
+#
+# EXTRA_PATCHES - Define this variable if you have patches not in
+# ${PATCHDIR}. This usually happens when you need to
+# do some pre-processing before some distribution
+# patches can be applied. In that case, fetch them as
+# extra distfiles, put the processed results in
+# ${WRKDIR}, then point EXTRA_PATCHES to them.
+# The patches specified by this variable will be
+# applied after the normal distribution patches but
+# before those in ${PATCHDIR}.
+# PATCH_WRKSRC - Directory to apply patches in.
+# Default: ${WRKSRC}
+#
+# For configure:
+#
+# HAS_CONFIGURE - If set, this port has its own configure script. The
+# configure stage will not do anything if this is not set.
+# GNU_CONFIGURE - If set, you are using GNU configure (optional). Implies
+# HAS_CONFIGURE.
+# CONFIGURE_WRKSRC
+# - Directory to run configure in.
+# Default: ${WRKSRC}
+# CONFIGURE_SCRIPT
+# - Name of configure script, relative to ${CONFIGURE_WRKSRC}.
+# Default: "Makefile.PL" if PERL_CONFIGURE is set,
+# "configure" otherwise.
+# CONFIGURE_TARGET
+# - The name of target to call when GNU_CONFIGURE is
+# defined.
+# Default: ${ARCH}-portbld-freebsd${OSREL}
+# GNU_CONFIGURE_PREFIX
+# - The directory passed as prefix to the configure script if
+# GNU_CONFIGURE is set.
+# Default: ${PREFIX}
+# CONFIGURE_ARGS
+# - Pass these args to configure if ${HAS_CONFIGURE} is set.
+# Default: "--prefix=${GNU_CONFIGURE_PREFIX} --infodir=${PREFIX}/${INFO_PATH}
+# --mandir=${MANPREFIX}/man --build=${CONFIGURE_TARGET}" if
+# GNU_CONFIGURE is set, "CC=${CC} CFLAGS=${CFLAGS}
+# PREFIX=${PREFIX} INSTALLPRIVLIB=${PREFIX}/lib
+# INSTALLARCHLIB=${PREFIX}/lib" if PERL_CONFIGURE is set,
+# empty otherwise.
+# CONFIGURE_ENV - Pass these env (shell-like) to configure if
+# ${HAS_CONFIGURE} is set.
+# CONFIGURE_LOG - The name of configure log file. It will be printed to
+# the screen if configure fails.
+# Default: config.log
+# CONFIGURE_FAIL_MESSAGE
+# - A message displayed to users when configure
+# fails (note: this assumes the do-configure
+# target has not been overwritten). This message
+# will be passed through /usr/bin/fmt before
+# being shown to the user.
+#
+# WITHOUT_FBSD10_FIX Disable FreeBSD 10.0 autotools workaround.
+#
+# For build and install:
+#
+# MAKEFILE - Name of the makefile.
+# Default: Makefile
+# ALL_TARGET - Default target for sub-make in build stage.
+# Default: all
+# BUILD_WRKSRC - Directory to do build in (default: ${WRKSRC}).
+# MAKE_ENV - Additional environment vars passed to sub-make in build
+# and install stages.
+# Default: see below
+# MAKE_ARGS - Any extra arguments to sub-make in build and install stages.
+# Default: none
+##
+# MAKE_JOBS_SAFE
+# - This port can safely be built on multiple cpus in parallel.
+# The make will be invoked with -jX parameter where X equals
+# number of cores present in the system.
+# MAKE_JOBS_UNSAFE
+# - Disallow multiple jobs even when user set a global override.
+# To be used with known bad ports.
+# DISABLE_MAKE_JOBS
+# - Set to disable the multiple jobs feature. User settable.
+# FORCE_MAKE_JOBS
+# - Force all ports to be built with multiple jobs, except ports
+# that are explicitly marked MAKE_JOBS_UNSAFE. User settable.
+# MAKE_JOBS_NUMBER
+# - Override the number of make jobs to be used. User settable.
+#
+# For install:
+#
+# INSTALL_TARGET
+# - Default target for sub-make in install stage.
+# Default: install
+# INSTALL_WRKSRC
+# - Directory to install from
+# Default: ${WRKSRC}
+# NO_MTREE - If set, will not invoke mtree from bsd.port.mk from
+# the "install" target.
+# MTREE_FILE - The name of the mtree file.
+# Default: ${PORTSDIR}/Templates/BSD.local.dist or
+# /etc/mtree/BSD.usr.dist if ${PREFIX} == "/usr".
+# PLIST_DIRS - Directories to be added to packing list
+# PLIST_DIRSTRY - Directories to be added to packing list and try to remove them.
+# PLIST_FILES - Files and symbolic links to be added to packing list
+#
+# PLIST - Name of the `packing list' file.
+# Change this to ${WRKDIR}/PLIST or something if you
+# need to write to it. (It is not a good idea for a port
+# to write to any file outside ${WRKDIR} during a normal
+# build.)
+# Default: ${PKGDIR}/pkg-plist
+# TMPPLIST - Name of the `packing list' file after processing
+# Default: ${WRKDIR}/.PLIST.mktmp
+# PLIST_SUB - List of "variable=value" pair for substitution in ${PLIST}
+# Default: see below
+#
+# SUB_FILES - Files that should be passed through sed and redirected to
+# ${WRKDIR}.
+# - For each file specified in SUB_FILES, there must be a
+# corresponding file in ${FILESDIR} whose suffix is ".in". For
+# instance, if the Makefile specifies "SUB_FILES= pkg-message"
+# then there must be a file called pkg-message.in in
+# ${FILESDIR}.
+# - The substitution process is the same as PLIST_FILES, as
+# described below except that any line beginning with @comment
+# is deleted.
+# SUB_LIST - List of "variable=value" pair for substitution in ${SUB_FILES}
+# Some pairs are added by default: eg. PREFIX=${PREFIX}
+#
+# USE_LDCONFIG - If set to "yes", this adds ${PREFIX}/lib to the list of
+# directories to be searched for shared libraries.
+# Otherwise, this is a list of directories to be added to that
+# list. The directory names are written to
+# ${PREFIX}/libdata/ldconfig/${UNIQUENAME} which is then
+# used by the ldconfig startup script.
+# This mechanism replaces ldconfig scripts installed by some
+# ports, often under such names as 000.${UNQUENAME}.sh.
+# If USE_LINUX_PREFIX is defined, the Linux version of
+# ldconfig will be used instead of the native FreeBSD
+# version, and the directory list given will be ignored.
+# USE_LDCONFIG32
+# - Same as USE_LDCONFIG but the target file is
+# ${PREFIX}/libdata/ldconfig32/${UNIQUENAME} instead.
+# Note: that should only be used on 64-bit architectures.
+# NO_LDCONFIG_MTREE
+# - Denotes whether the libdata/ldconfig directory is part of
+# the mtree on a given OSVERSION system. If it is not, we
+# create the directory, pull in the ldconfig_compat port,
+# and clean up on de-installation. NOTE: this variable is
+# internal to bsd.port.mk and must not be set in your Makefile.
+#
+# DOCSDIR - Name of the directory to install the packages docs in.
+# Default: ${PREFIX}/share/doc/${PORTNAME}
+# DOCSDIR_REL - The DOCSDIR relative to ${PREFIX}
+# EXAMPLESDIR - Name of the directory to install the packages examples in.
+# Default: ${PREFIX}/share/examples/${PORTNAME}
+# EXAMPLESDIR_REL
+# - The EXAMPLESDIR relative to ${PREFIX}
+# DATADIR - Name of the directory to install the packages shared data in.
+# Default: ${PREFIX}/share/${PORTNAME}
+# DATADIR_REL - The DATADIR relative to ${PREFIX}
+#
+# WWWDIR - Name of the directory to install the packages www data in.
+# Default: ${PREFIX}/www/${PORTNAME}
+# WWWDIR_REL - The WWWDIR relative to ${PREFIX}
+#
+# USERS - List of users to create at install time. Each login must
+# have a corresponding entry in ${UID_FILES}.
+# GROUPS - List of groups to create at install time. Each group must
+# have a corresponding entry in ${GID_FILES}.
+#
+# DESKTOPDIR - Name of the directory to install ${DESKTOP_ENTRIES} in.
+# Default: ${PREFIX}/share/applications
+# DESKTOP_ENTRIES
+# - List of desktop entry files to generate and install in
+# ${DESKTOPDIR}. The format is
+# "Name" "Comment" "Icon" "Exec" "Categories" StartupNotify
+# Rules:
+# * Only add desktop entries for applications which do not
+# require a terminal (ie. X applications).
+# * If the upstream distribution already installs .desktop
+# files, you do not need to use this.
+# * If you require a more elaborate .desktop file than this
+# variable permits, write it yourself and install it
+# in ${DESKTOPDIR}.
+# Notes:
+# * Comment and Icon may be empty strings (""). Categories
+# may be an empty string in some cases (see below). The
+# other fields are mandatory.
+# * If Categories is an empty string, bsd.port.mk will try
+# to deduce a default value using the CATEGORIES variable.
+# If the deduction fails, you will have to set Categories
+# manually. You should check the generated value using
+# "make desktop-categories", and override it if necessary.
+# * Exec will also be used to name the .desktop file.
+# * The files will be automatically added to ${PLIST}.
+# Example:
+# "X Window Information" \
+# "Get information about X windows" \
+# "wininfo.png" \
+# "wininfo" \
+# "Application;System;" \
+# true
+# See http://standards.freedesktop.org/desktop-entry-spec/desktop-entry-spec-latest.html
+# for an explanation of the fields. If you need to create more
+# than one file, just chain them into a single variable.
+#
+# Note that the install target will automatically add manpages (see
+# above) and also substitute special sequences of characters (delimited
+# by "%%") as defined in PLIST_SUB to generate ${TMPPLIST}. For
+# instance, "OSREL=${OSREL}" in PLIST_SUB causes all occurrences of
+# "%%OSREL%%" in ${PLIST} to be substituted by the value of OSREL.
+# ${TMPPLIST} is generated before the do-install stage. If you are
+# generating the packing list on-the-fly, make sure it's generated before
+# do-install is called!
+#
+# For package:
+#
+# NO_LATEST_LINK
+# - Do not install the "Latest" link for package. Define this
+# if this port is a beta version of another stable port
+# which is also in the tree.
+# LATEST_LINK - Install the "Latest" link for the package as ___. Define
+# this if the "Latest" link name will be incorrectly determined.
+#
+# This is used in all stages:
+#
+# SCRIPTS_ENV - Additional environment vars passed to scripts in
+# ${SCRIPTDIR} executed by bsd.port.mk.
+# Default: see below
+#
+# Finally, variables to change if you want a special behavior. These
+# are for debugging purposes. Don't set them in your Makefile.
+#
+# ECHO_MSG - Used to print all the '===>' style prompts - override this
+# to turn them off.
+# Default: ${ECHO_CMD}
+# PATCH_DEBUG - If set, print out more information about the patches as
+# it attempts to apply them.
+# PKG_DBDIR - Where package installation is recorded; this directory
+# must not contain anything else.
+# Default: /var/db/pkg
+# PORT_DBDIR - Where port configuration options are recorded.
+# Default: /var/db/ports
+# NO_PKG_REGISTER
+# - Don't register a port installation as a package.
+# FORCE_PKG_REGISTER
+# - If set, it will overwrite any existing package
+# registration information in ${PKG_DBDIR}/${PKGNAME}.
+# NO_DEPENDS - Don't verify build of dependencies.
+# CHECKSUM_ALGORITHMS
+# - Different checksum algorithms to check for verifying the
+# integrity of the distfiles. The absence of the algorithm
+# in distinfo doesn't make it fail.
+# Default: sha256
+# NO_CHECKSUM - Don't verify the checksum. Typically used when
+# when you noticed the distfile you just fetched has
+# a different checksum and you intend to verify if
+# the port still works with it.
+# USE_PACKAGE_DEPENDS
+# - Install dependencies from existing packages instead
+# of building the port from scratch.
+# INSTALL_AS_USER
+# - Define this to install as the current user, intended
+# for systems where you have no root access.
+# DISABLE_SIZE - Do not check the size of a distfile even if the SIZE field
+# has been specified in distinfo. This is useful
+# when using an alternate FETCH_CMD.
+#
+# End of the list of all variables that need to be defined in a port.
+# Most port authors should not need to understand anything after this point.
+#
+
+# These need to be absolute since we don't know how deep in the ports
+# tree we are and thus can't go relative. They can, of course, be overridden
+# by individual Makefiles or local system make configuration.
+PORTSDIR?= /usr/ports
+LOCALBASE?= /usr/local
+LINUXBASE?= /compat/linux
+DISTDIR?= ${PORTSDIR}/distfiles
+_DISTDIR?= ${DISTDIR}/${DIST_SUBDIR}
+INDEXDIR?= ${PORTSDIR}
+SRC_BASE?= /usr/src
+
+.include "${PORTSDIR}/Mk/bsd.commands.mk"
+
+#
+# DESTDIR section to start a chrooted process if invoked with DESTDIR set
+#
+
+.if defined(DESTDIR) && !empty(DESTDIR) && !defined(CHROOTED) && \
+ !defined(BEFOREPORTMK) && !defined(INOPTIONSMK)
+
+.include "${PORTSDIR}/Mk/bsd.destdir.mk"
+
+.else
+
+# Look for ${PATCH_WRKSRC}/.../*.orig files, and (re-)create
+# ${FILEDIR}/patch-* files from them.
+
+.if !target(makepatch)
+makepatch:
+ @${MKDIR} ${FILESDIR}
+ @(cd ${PATCH_WRKSRC}; \
+ for i in `find . -type f -name '*.orig'`; do \
+ ORG=$$i; \
+ NEW=$${i%.orig}; \
+ OUT=${FILESDIR}`${ECHO} $${NEW} | \
+ ${SED} -e 's|/|__|g' \
+ -e 's|^\.__|/patch-|'`; \
+ ${ECHO} ${DIFF} -ud $${ORG} $${NEW} '>' $${OUT}; \
+ ${DIFF} -ud $${ORG} $${NEW} > $${OUT} || ${TRUE}; \
+ done \
+ )
+.endif
+
+
+# Start of options section
+.if defined(INOPTIONSMK) || ( !defined(USEOPTIONSMK) && !defined(AFTERPORTMK) )
+
+
+# Get the default maintainer
+MAINTAINER?= ports@FreeBSD.org
+
+# Get the architecture
+.if !defined(ARCH)
+ARCH!= ${UNAME} -p
+.endif
+
+# Kludge for pre-3.0 systems
+MACHINE_ARCH?= i386
+
+# Get the operating system type
+.if !defined(OPSYS)
+OPSYS!= ${UNAME} -s
+.endif
+
+# Get the operating system revision
+.if !defined(OSREL)
+OSREL!= ${UNAME} -r | ${SED} -e 's/[-(].*//'
+.endif
+
+# Get __FreeBSD_version
+.if !defined(OSVERSION)
+.if exists(/usr/include/sys/param.h)
+OSVERSION!= ${AWK} '/^\#define[[:blank:]]__FreeBSD_version/ {print $$3}' < /usr/include/sys/param.h
+.elif exists(${SRC_BASE}/sys/sys/param.h)
+OSVERSION!= ${AWK} '/^\#define[[:blank:]]__FreeBSD_version/ {print $$3}' < ${SRC_BASE}/sys/sys/param.h
+.else
+OSVERSION!= ${SYSCTL} -n kern.osreldate
+.endif
+.endif
+
+MASTERDIR?= ${.CURDIR}
+
+.if ${MASTERDIR} != ${.CURDIR}
+SLAVE_PORT?= yes
+MASTER_PORT?=${MASTERDIR:C/[^\/]+\/\.\.\///:C/[^\/]+\/\.\.\///:C/^.*\/([^\/]+\/[^\/]+)$/\\1/}
+.else
+SLAVE_PORT?= no
+MASTER_PORT?=
+.endif
+
+# If they exist, include Makefile.inc, then architecture/operating
+# system specific Makefiles, then local Makefile.local.
+
+.if ${MASTERDIR} != ${.CURDIR} && exists(${.CURDIR}/../Makefile.inc)
+.include "${.CURDIR}/../Makefile.inc"
+USE_SUBMAKE= yes
+.endif
+
+.if exists(${MASTERDIR}/../Makefile.inc)
+.include "${MASTERDIR}/../Makefile.inc"
+USE_SUBMAKE= yes
+.endif
+
+.if exists(${MASTERDIR}/Makefile.${ARCH}-${OPSYS})
+.include "${MASTERDIR}/Makefile.${ARCH}-${OPSYS}"
+USE_SUBMAKE= yes
+.elif exists(${MASTERDIR}/Makefile.${OPSYS})
+.include "${MASTERDIR}/Makefile.${OPSYS}"
+USE_SUBMAKE= yes
+.elif exists(${MASTERDIR}/Makefile.${ARCH})
+.include "${MASTERDIR}/Makefile.${ARCH}"
+USE_SUBMAKE= yes
+.endif
+
+.if exists(${MASTERDIR}/Makefile.local)
+.include "${MASTERDIR}/Makefile.local"
+USE_SUBMAKE= yes
+.endif
+
+# where 'make config' records user configuration options
+PORT_DBDIR?= /var/db/ports
+
+UID_FILES?= ${PORTSDIR}/UIDs
+GID_FILES?= ${PORTSDIR}/GIDs
+UID_OFFSET?= 0
+GID_OFFSET?= 0
+
+# predefined accounts from src/etc/master.passwd
+# alpha numeric sort order
+USERS_BLACKLIST= _dhcp _pflogd bin bind daemon games kmem mailnull man news nobody operator pop proxy root smmsp sshd toor tty uucp www
+
+LDCONFIG_DIR= libdata/ldconfig
+LDCONFIG32_DIR= libdata/ldconfig32
+
+.if defined(LATEST_LINK)
+UNIQUENAME?= ${LATEST_LINK}
+.else
+UNIQUENAME?= ${PKGNAMEPREFIX}${PORTNAME}
+.endif
+
+.endif
+
+DOS2UNIX_REGEX?= .*
+
+# At least KDE needs TMPDIR for the package building,
+# so we're setting it to the known default value.
+.if defined(PACKAGE_BUILDING)
+TMPDIR?= /tmp
+.endif # defined(PACKAGE_BUILDING)
+
+# Respect TMPDIR passed via make.conf or similar and pass it down
+# to configure and make.
+.if defined(TMPDIR)
+MAKE_ENV+= TMPDIR="${TMPDIR}"
+CONFIGURE_ENV+= TMPDIR="${TMPDIR}"
+.endif # defined(TMPDIR)
+
+# Reset value from bsd.own.mk.
+.if defined(WITH_DEBUG) && !defined(WITHOUT_DEBUG)
+STRIP= #none
+.endif
+
+.include "${PORTSDIR}/Mk/bsd.options.mk"
+
+# Start of pre-makefile section.
+.if !defined(AFTERPORTMK) && !defined(INOPTIONSMK)
+
+.if defined(_PREMKINCLUDED)
+check-makefile::
+ @${ECHO_MSG} "${PKGNAME}: Makefile error: you cannot include bsd.port[.pre].mk twice"
+ @${FALSE}
+.endif
+
+_PREMKINCLUDED= yes
+
+.if defined(PORTVERSION)
+.if ${PORTVERSION:M*[-_,]*}x != x
+IGNORE= PORTVERSION ${PORTVERSION} may not contain '-' '_' or ','
+.endif
+DISTVERSION?= ${PORTVERSION:S/:/::/g}
+.elif defined(DISTVERSION)
+PORTVERSION= ${DISTVERSION:L:C/([a-z])[a-z]+/\1/g:C/([0-9])([a-z])/\1.\2/g:C/:(.)/\1/g:C/[^a-z0-9+]+/./g}
+.endif
+
+PORTREVISION?= 0
+.if ${PORTREVISION} != 0
+_SUF1= _${PORTREVISION}
+.endif
+
+PORTEPOCH?= 0
+.if ${PORTEPOCH} != 0
+_SUF2= ,${PORTEPOCH}
+.endif
+
+PKGVERSION= ${PORTVERSION:C/[-_,]/./g}${_SUF1}${_SUF2}
+PKGNAME= ${PKGNAMEPREFIX}${PORTNAME}${PKGNAMESUFFIX}-${PKGVERSION}
+DISTNAME?= ${PORTNAME}-${DISTVERSIONPREFIX}${DISTVERSION:C/:(.)/\1/g}${DISTVERSIONSUFFIX}
+
+INDEXFILE?= INDEX-${OSVERSION:C/([0-9]*)[0-9]{5}/\1/}
+
+DOCSDIR?= ${PREFIX}/share/doc/${PORTNAME}
+EXAMPLESDIR?= ${PREFIX}/share/examples/${PORTNAME}
+DATADIR?= ${PREFIX}/share/${PORTNAME}
+WWWDIR?= ${PREFIX}/www/${PORTNAME}
+ETCDIR?= ${PREFIX}/etc/${PORTNAME}
+
+.if defined(USE_LINUX_RPM)
+.include "${PORTSDIR}/Mk/bsd.linux-rpm.mk"
+.endif
+
+.if defined(USE_LINUX_APPS)
+.include "${PORTSDIR}/Mk/bsd.linux-apps.mk"
+.endif
+
+.if defined(USE_XORG) || defined(XORG_CAT)
+.include "${PORTSDIR}/Mk/bsd.xorg.mk"
+.endif
+
+.if defined(USE_BZIP2)
+EXTRACT_SUFX?= .tar.bz2
+.elif defined(USE_ZIP)
+EXTRACT_SUFX?= .zip
+.elif defined(USE_XZ)
+EXTRACT_SUFX?= .tar.xz
+.elif defined(USE_MAKESELF)
+EXTRACT_SUFX?= .run
+.else
+EXTRACT_SUFX?= .tar.gz
+.endif
+PACKAGES?= ${PORTSDIR}/packages
+TEMPLATES?= ${PORTSDIR}/Templates
+
+PATCHDIR?= ${MASTERDIR}/files
+FILESDIR?= ${MASTERDIR}/files
+SCRIPTDIR?= ${MASTERDIR}/scripts
+PKGDIR?= ${MASTERDIR}
+
+.if defined(USE_LINUX_PREFIX)
+PREFIX?= ${LINUXBASE}
+NO_MTREE= yes
+.else
+PREFIX?= ${LOCALBASE}
+.endif
+
+.if defined(USE_LINUX_PREFIX)
+LDCONFIG_CMD?= ${LINUXBASE}/sbin/ldconfig -r ${LINUXBASE}
+.endif
+
+PKGCOMPATDIR?= ${LOCALBASE}/lib/compat/pkg
+
+.if defined(USE_LOCAL_MK)
+.include "${PORTSDIR}/Mk/bsd.local.mk"
+.endif
+
+.if defined(USE_OPENSSL)
+.include "${PORTSDIR}/Mk/bsd.openssl.mk"
+.endif
+
+.if defined(USE_EMACS)
+.include "${PORTSDIR}/Mk/bsd.emacs.mk"
+.endif
+
+.if defined(USE_GNUSTEP)
+.include "${PORTSDIR}/Mk/bsd.gnustep.mk"
+.endif
+
+.include "${PORTSDIR}/Mk/bsd.perl.mk"
+
+.if defined(USE_PHP)
+.include "${PORTSDIR}/Mk/bsd.php.mk"
+.endif
+
+.if defined(USE_PYTHON) || defined(USE_PYTHON_BUILD) || defined(USE_PYTHON_RUN)
+.include "${PORTSDIR}/Mk/bsd.python.mk"
+.endif
+
+.if defined(USE_EFL) || defined(WANT_EFL) || defined(USE_EFL_ESMART)
+.include "${PORTSDIR}/Mk/bsd.efl.mk"
+.endif
+
+.if defined(USE_FPC) || defined(WANT_FPC_BASE) || defined(WANT_FPC_ALL)
+.include "${PORTSDIR}/Mk/bsd.fpc.mk"
+.endif
+
+.if defined(USE_JAVA)
+.include "${PORTSDIR}/Mk/bsd.java.mk"
+.endif
+
+.if defined(USE_R_MOD)
+.include "${PORTSDIR}/Mk/bsd.cran.mk"
+.endif
+
+.if defined(USE_RUBY) || defined(USE_LIBRUBY)
+.include "${PORTSDIR}/Mk/bsd.ruby.mk"
+.endif
+
+.if defined(USE_OCAML)
+.include "${PORTSDIR}/Mk/bsd.ocaml.mk"
+.endif
+
+.if defined(USE_TCL) || defined(USE_TCL_BUILD) || defined(USE_TCL_RUN) || defined(USE_TCL_WRAPPER) || defined(USE_TK) || defined(USE_TK_BUILD) || defined(USE_TK_RUN) || defined(USE_TK_WRAPPER)
+.include "${PORTSDIR}/Mk/bsd.tcl.mk"
+.endif
+
+.if defined(USE_APACHE) || defined(USE_APACHE_BUILD) || defined(USE_APACHE_RUN)
+.include "${PORTSDIR}/Mk/bsd.apache.mk"
+.endif
+
+.if (defined(USE_QT_VER) && ${USE_QT_VER:L} == 3) || defined(USE_KDELIBS_VER) || defined(USE_KDEBASE_VER)
+.include "${PORTSDIR}/Mk/bsd.kde.mk"
+.endif
+
+.if defined(USE_QT_VER) && ${USE_QT_VER:L} == 4 || defined(USE_QT4)
+.include "${PORTSDIR}/Mk/bsd.qt.mk"
+.endif
+
+.if defined(USE_DRUPAL)
+.include "${PORTSDIR}/Mk/bsd.drupal.mk"
+.endif
+
+.if defined(WANT_GECKO) || defined(USE_GECKO) || defined(USE_FIREFOX) || defined(USE_FIREFOX_BUILD) || defined(USE_SEAMONKEY) || defined(USE_SEAMONKEY_BUILD) || defined(USE_THUNDERBIRD) || defined(USE_THUNDERBIRD_BUILD)
+.include "${PORTSDIR}/Mk/bsd.gecko.mk"
+.endif
+
+.if defined(WANT_GNOME) || defined(USE_GNOME) || defined(INSTALLS_ICONS)
+.include "${PORTSDIR}/Mk/bsd.gnome.mk"
+.endif
+
+.if defined(WANT_MATE) || defined(USE_MATE)
+.include "${PORTSDIR}/Mk/bsd.mate.mk"
+.endif
+
+.if defined(WANT_LUA) || defined(USE_LUA) || defined(USE_LUA_NOT)
+.include "${PORTSDIR}/Mk/bsd.lua.mk"
+.endif
+
+.if defined(WANT_WX) || defined(USE_WX) || defined(USE_WX_NOT)
+.include "${PORTSDIR}/Mk/bsd.wx.mk"
+.endif
+
+.if defined(WANT_GSTREAMER) || defined(USE_GSTREAMER) || defined(USE_GSTREAMER80)
+.include "${PORTSDIR}/Mk/bsd.gstreamer.mk"
+.endif
+
+.if defined(USE_QMAIL) || defined(USE_QMAIL_RUN) || defined(USE_QMAIL_BUILD) || defined(WANT_QMAIL)
+.include "${PORTSDIR}/Mk/bsd.mail.mk"
+.endif
+
+.if defined(USE_SDL) || defined(WANT_SDL)
+.include "${PORTSDIR}/Mk/bsd.sdl.mk"
+.endif
+
+.if defined(USE_XFCE)
+.include "${PORTSDIR}/Mk/bsd.xfce.mk"
+.endif
+
+.if defined(USE_KDE4) || defined(KDE4_BUILDENV)
+.include "${PORTSDIR}/Mk/bsd.kde4.mk"
+.endif
+
+.if defined(USE_NCURSES)
+.include "${PORTSDIR}/Mk/bsd.ncurses.mk"
+.endif
+
+# You can force skipping these test by defining IGNORE_PATH_CHECKS
+.if !defined(IGNORE_PATH_CHECKS)
+.if (${PREFIX:C,(^.).*,\1,} != "/")
+.BEGIN:
+ @${ECHO_MSG} "PREFIX must be defined as an absolute path so that when 'make'"
+ @${ECHO_MSG} "is invoked in the work area PREFIX points to the right place."
+ @${FALSE}
+.endif
+.endif
+
+# Location of mounted CDROM(s) to search for files
+CD_MOUNTPTS?= /cdrom ${CD_MOUNTPT}
+
+# Owner and group of the WWW user
+WWWOWN?= www
+WWWGRP?= www
+
+.endif
+# End of pre-makefile section.
+
+# Start of post-makefile section.
+.if !defined(BEFOREPORTMK) && !defined(INOPTIONSMK)
+
+.if defined(_POSTMKINCLUDED)
+check-makefile::
+ @${ECHO_MSG} "${PKGNAME}: Makefile error: you cannot include bsd.port[.post].mk twice"
+ @${FALSE}
+.endif
+
+_POSTMKINCLUDED= yes
+
+WRKDIR?= ${WRKDIRPREFIX}${.CURDIR}/work
+.if defined(NO_WRKSUBDIR)
+WRKSRC?= ${WRKDIR}
+.else
+WRKSRC?= ${WRKDIR}/${DISTNAME}
+.endif
+
+PATCH_WRKSRC?= ${WRKSRC}
+CONFIGURE_WRKSRC?= ${WRKSRC}
+BUILD_WRKSRC?= ${WRKSRC}
+INSTALL_WRKSRC?=${WRKSRC}
+
+PLIST_SUB+= OSREL=${OSREL} PREFIX=%D LOCALBASE=${LOCALBASE}
+SUB_LIST+= PREFIX=${PREFIX} LOCALBASE=${LOCALBASE} \
+ DATADIR=${DATADIR} DOCSDIR=${DOCSDIR} EXAMPLESDIR=${EXAMPLESDIR} \
+ WWWDIR=${WWWDIR} ETCDIR=${ETCDIR}
+
+PLIST_REINPLACE+= dirrmtry stopdaemon rmtry
+PLIST_REINPLACE_DIRRMTRY=s!^@dirrmtry \(.*\)!@unexec rmdir "%D/\1" 2>/dev/null || true!
+PLIST_REINPLACE_RMTRY=s!^@rmtry \(.*\)!@unexec rm -f %D/\1 2>/dev/null || true!
+PLIST_REINPLACE_STOPDAEMON=s!^@stopdaemon \(.*\)!@unexec %D/etc/rc.d/\1 forcestop 2>/dev/null || true!
+
+# kludge to strip trailing whitespace from CFLAGS;
+# sub-configure will not # survive double space
+CFLAGS:= ${CFLAGS:C/ $//}
+
+.if defined(WITHOUT_CPU_CFLAGS)
+.if defined(_CPUCFLAGS)
+.if !empty(_CPUCFLAGS)
+CFLAGS:= ${CFLAGS:C/${_CPUCFLAGS}//}
+.endif
+.endif
+.endif
+
+.if defined(WITH_DEBUG) && !defined(WITHOUT_DEBUG)
+STRIP_CMD= ${TRUE}
+DEBUG_FLAGS?= -g
+CFLAGS:= ${CFLAGS:N-O*:N-fno-strict*} ${DEBUG_FLAGS}
+.endif
+
+.if defined(NOPORTDOCS)
+PLIST_SUB+= PORTDOCS="@comment "
+.else
+PLIST_SUB+= PORTDOCS=""
+.endif
+
+.if defined(NOPORTEXAMPLES)
+PLIST_SUB+= PORTEXAMPLES="@comment "
+.else
+PLIST_SUB+= PORTEXAMPLES=""
+.endif
+
+.if defined(NOPORTDATA)
+PLIST_SUB+= PORTDATA="@comment "
+.else
+PLIST_SUB+= PORTDATA=""
+.endif
+
+CONFIGURE_SHELL?= ${SH}
+MAKE_SHELL?= ${SH}
+
+CONFIGURE_ENV+= SHELL=${SH} CONFIG_SHELL=${SH}
+MAKE_ENV+= SHELL=${SH} NO_LINT=YES
+
+.if defined(MANCOMPRESSED)
+.if ${MANCOMPRESSED} != yes && ${MANCOMPRESSED} != no && \
+ ${MANCOMPRESSED} != maybe
+check-makevars::
+ @${ECHO_MSG} "${PKGNAME}: Makefile error: value of MANCOMPRESSED (is \"${MANCOMPRESSED}\") can only be \"yes\", \"no\" or \"maybe\"".
+ @${FALSE}
+.endif
+.endif
+
+.if defined(USE_IMAKE) && !defined(NO_INSTALL_MANPAGES)
+MANCOMPRESSED?= yes
+.else
+MANCOMPRESSED?= no
+.endif
+
+.if defined(PATCHFILES)
+.if ${PATCHFILES:M*.zip}x != x
+PATCH_DEPENDS+= ${LOCALBASE}/bin/unzip:${PORTSDIR}/archivers/unzip
+.endif
+.endif
+
+# Check the compatibility layer for amd64/ia64
+
+.if ${ARCH} == "amd64" || ${ARCH} =="ia64"
+.if exists(/usr/lib32)
+HAVE_COMPAT_IA32_LIBS?= YES
+.endif
+.if !defined(HAVE_COMPAT_IA32_KERN)
+HAVE_COMPAT_IA32_KERN!= if ${SYSCTL} -n compat.ia32.maxvmem >/dev/null 2>&1; then echo YES; fi
+.endif
+.endif
+
+.if defined(IA32_BINARY_PORT) && ${ARCH} != "i386"
+.if ${ARCH} == "amd64" || ${ARCH} == "ia64"
+.if !defined(HAVE_COMPAT_IA32_KERN)
+IGNORE= requires a kernel with compiled-in IA32 compatibility
+.elif !defined(HAVE_COMPAT_IA32_LIBS)
+IGNORE= requires 32-bit libraries installed under /usr/lib32
+.endif
+_LDCONFIG_FLAGS=-32
+LIB32DIR= lib32
+.else
+IGNORE= requires i386 (or compatible) platform to run
+.endif
+.else
+LIB32DIR= lib
+.endif
+PLIST_SUB+= LIB32DIR=${LIB32DIR}
+
+.if defined(WITH_PKGNG)
+.if !defined(PKG_DEPENDS)
+PKG_DEPENDS+= ${LOCALBASE}/sbin/pkg:${PORTSDIR}/ports-mgmt/pkg
+.endif
+.endif
+
+.if defined(USE_ZIP)
+EXTRACT_DEPENDS+= ${LOCALBASE}/bin/unzip:${PORTSDIR}/archivers/unzip
+.endif
+.if defined(USE_XZ) && ( (${OSVERSION} >= 900000 && ${OSVERSION} < 900012) || ${OSVERSION} < 800505 )
+EXTRACT_DEPENDS+= ${LOCALBASE}/bin/xz:${PORTSDIR}/archivers/xz
+.endif
+.if defined(USE_MAKESELF)
+EXTRACT_DEPENDS+= unmakeself:${PORTSDIR}/archivers/unmakeself
+.endif
+.if defined(USE_GMAKE)
+BUILD_DEPENDS+= gmake:${PORTSDIR}/devel/gmake
+CONFIGURE_ENV+= MAKE=${GMAKE}
+.endif
+
+.if defined(USE_GCC) || defined(USE_FORTRAN)
+.include "${PORTSDIR}/Mk/bsd.gcc.mk"
+.endif
+
+.if defined(USE_BINUTILS) && !defined(DISABLE_BINUTILS)
+BUILD_DEPENDS+= ${LOCALBASE}/bin/as:${PORTSDIR}/devel/binutils
+BINUTILS?= ADDR2LINE AR AS CPPFILT GPROF LD NM OBJCOPY OBJDUMP RANLIB \
+ READELF SIZE STRINGS
+BINUTILS_NO_MAKE_ENV?=
+. for b in ${BINUTILS}
+${b}= ${LOCALBASE}/bin/${b:C/PP/++/:L}
+. if defined(GNU_CONFIGURE) || defined(BINUTILS_CONFIGURE)
+CONFIGURE_ENV+= ${b}="${${b}}"
+. endif
+. if ${BINUTILS_NO_MAKE_ENV:M${b}} == ""
+MAKE_ENV+= ${b}="${${b}}"
+. endif
+. endfor
+.endif
+
+.if defined(USE_OPENLDAP) || defined(WANT_OPENLDAP_VER)
+.include "${PORTSDIR}/Mk/bsd.ldap.mk"
+.endif
+
+.if defined(USE_OPENAL)
+_OPENAL_ALL= al si soft alut
+_OPENAL_LIBS= si soft
+# Default choice.
+_DEFAULT_OPENAL= soft
+
+_OPENAL_SOFT= openal.1:${PORTSDIR}/audio/openal-soft
+_OPENAL_SI= openal.0:${PORTSDIR}/audio/openal
+_OPENAL_ALUT= alut.1:${PORTSDIR}/audio/freealut
+
+.if exists(${LOCALBASE}/lib/libopenal.a)
+_HAVE_OPENAL= si
+.elif exists(${LOCALBASE}/bin/openal-info)
+_HAVE_OPENAL= soft
+.endif
+
+.if ${USE_OPENAL} == "yes"
+# Be friendly.
+USE_OPENAL= ${_DEFAULT_OPENAL}
+.endif
+
+__USED_OPENAL=
+_USE_OPENAL=
+.for component in ${USE_OPENAL}
+.if ${__USED_OPENAL:M${component}} == ""
+__USED_OPENAL+= ${component}
+
+.if ${_OPENAL_ALL:M${component}} == ""
+BROKEN= OPENAL mismatch: unknown component ${component}
+.elif ${_OPENAL_ALL:M${component}} == "al"
+
+# Check if the user wish matches the found OpenAL system.
+.if defined(WANT_OPENAL) && defined(_HAVE_OPENAL) && ${_HAVE_OPENAL} != ${WANT_OPENAL}
+BROKEN= OPENAL mismatch: ${_HAVE_OPENAL} is installed, but ${WANT_OPENAL} desired
+.endif # WANT_OPENAL
+
+.if defined(_HAVE_OPENAL)
+_OPENAL_SYSTEM= ${_HAVE_OPENAL}
+.elif defined(WANT_OPENAL)
+_OPENAL_SYSTEM= ${WANT_OPENAL}
+.else
+_OPENAL_SYSTEM= ${_DEFAULT_OPENAL}
+.endif # _HAVE_OPENAL
+
+_USE_OPENAL+= ${_OPENAL_${_OPENAL_SYSTEM:U}}
+
+.else # ${_OPENAL_ALL:M${component}} == ""
+
+.if ${_OPENAL_LIBS:M${component}} == ${component}
+# Check for the system implementation to use.
+.if defined(WANT_OPENAL) && ${WANT_OPENAL} != ${component}
+BROKEN= OPENAL mismatch: wants to use ${component}, while you wish to use ${WANT_OPENAL}
+.endif
+.if defined(_OPENAL_SYSTEM)
+BROKEN= OPENAL mismatch: cannot use ${component} and al together.
+.endif
+.if defined(_HAVE_OPENAL) && ${_HAVE_OPENAL} != ${component}
+BROKEN= OPENAL mismatch: wants to use ${component}, but ${_HAVE_OPENAL} is installed
+.endif
+
+_OPENAL_SYSTEM= ${component}
+
+.endif # ${_OPENAL_LIBS:M${component}} == ${component}
+
+_USE_OPENAL+= ${_OPENAL_${component:U}}
+
+.endif # ${_OPENAL_ALL:M${component}} == ""
+
+.endif # ${__USED_OPENAL:M${component} == ""
+.endfor # component in ${USE_OPENAL}
+
+.for dep in ${_USE_OPENAL}
+LIB_DEPENDS+= ${dep}
+.endfor
+
+.endif # USE_OPENAL
+
+.if defined(USE_FAM)
+DEFAULT_FAM_SYSTEM= gamin
+# Currently supported FAM systems
+FAM_SYSTEM_FAM= fam.0:${PORTSDIR}/devel/fam
+FAM_SYSTEM_GAMIN= fam.0:${PORTSDIR}/devel/gamin
+
+.if exists(${LOCALBASE}/libexec/gam_server)
+_HAVE_FAM_SYSTEM= gamin
+.elif exists(${LOCALBASE}/bin/fam)
+_HAVE_FAM_SYSTEM= fam
+.endif
+
+.if defined(WANT_FAM_SYSTEM)
+.if defined(WITH_FAM_SYSTEM) && ${WITH_FAM_SYSTEM}!=${WANT_FAM_SYSTEM}
+IGNORE= wants to use ${WANT_FAM_SYSTEM} as its FAM system, while you wish to use ${WITH_FAM_SYSTEM}
+.endif
+FAM_SYSTEM= ${WANT_FAM_SYSTEM}
+.elif defined(WITH_FAM_SYSTEM)
+FAM_SYSTEM= ${WITH_FAM_SYSTEM}
+.else
+.if defined(_HAVE_FAM_SYSTEM)
+FAM_SYSTEM= ${_HAVE_FAM_SYSTEM}
+.else
+FAM_SYSTEM= ${DEFAULT_FAM_SYSTEM}
+.endif
+.endif # WANT_FAM_SYSTEM
+
+.if defined(_HAVE_FAM_SYSTEM)
+.if ${_HAVE_FAM_SYSTEM}!= ${FAM_SYSTEM}
+BROKEN= FAM system mismatch: ${_HAVE_FAM_SYSTEM} is installed, while desired FAM system is ${FAM_SYSTEM}
+.endif
+.endif
+
+.if defined(FAM_SYSTEM_${FAM_SYSTEM:U})
+LIB_DEPENDS+= ${FAM_SYSTEM_${FAM_SYSTEM:U}}
+.else
+IGNORE= cannot be built with unknown FAM system: ${FAM_SYSTEM}
+.endif
+.endif # USE_FAM
+
+.if defined(USE_RC_SUBR) && ${USE_RC_SUBR:U} != "YES"
+SUB_FILES+= ${USE_RC_SUBR}
+.endif
+
+.if defined(USE_RCORDER)
+SUB_FILES+= ${USE_RCORDER}
+.endif
+
+.if defined(USE_LDCONFIG) && ${USE_LDCONFIG:L} == "yes"
+USE_LDCONFIG= ${PREFIX}/lib
+.endif
+.if defined(USE_LDCONFIG32) && ${USE_LDCONFIG32:L} == "yes"
+IGNORE= has USE_LDCONFIG32 set to yes, which is not correct
+.endif
+
+.if defined(USE_ICONV)
+LIB_DEPENDS+= iconv.3:${PORTSDIR}/converters/libiconv
+.endif
+
+.if defined(USE_GETTEXT)
+. if ${USE_GETTEXT:L} == "build"
+BUILD_DEPENDS+= xgettext:${PORTSDIR}/devel/gettext
+. elif ${USE_GETTEXT:L} == "run"
+RUN_DEPENDS+= xgettext:${PORTSDIR}/devel/gettext
+. elif ${USE_GETTEXT:L} == "yes"
+LIB_DEPENDS+= intl:${PORTSDIR}/devel/gettext
+. else
+IGNORE= USE_GETTEXT can be only one of build, run, or yes
+. endif
+.endif
+
+.if defined(USE_LINUX_PREFIX) && defined(USE_LDCONFIG)
+# we need ${LINUXBASE}/sbin/ldconfig
+USE_LINUX?= yes
+.endif
+
+.if defined(USE_LINUX)
+
+. if !defined(LINUX_OSRELEASE)
+LINUX_OSRELEASE!= ${ECHO_CMD} `${SYSCTL} -n compat.linux.osrelease 2>/dev/null`
+. endif
+
+# install(1) also does a brandelf on strip, so don't strip with FreeBSD tools.
+STRIP=
+. if exists(${LINUXBASE}/usr/bin/strip)
+STRIP_CMD= ${LINUXBASE}/usr/bin/strip
+. else
+STRIP_CMD= ${TRUE}
+. endif
+
+# Allow the user to specify another linux_base version.
+. if defined(OVERRIDE_LINUX_BASE_PORT)
+. if ${USE_LINUX:L} == yes
+USE_LINUX= ${OVERRIDE_LINUX_BASE_PORT}
+. endif
+. endif
+
+# NOTE: when you update the default linux_base version (case "yes"),
+# don't forget to update the Handbook!
+
+. if exists(${PORTSDIR}/emulators/linux_base-${USE_LINUX})
+LINUX_BASE_PORT= ${LINUXBASE}/bin/sh:${PORTSDIR}/emulators/linux_base-${USE_LINUX}
+. else
+. if ${USE_LINUX:L} == "yes"
+. if ${OSVERSION} < 800076 || ${LINUX_OSRELEASE} == "2.4.2"
+LINUX_BASE_PORT= ${LINUXBASE}/etc/fedora-release:${PORTSDIR}/emulators/linux_base-fc4
+. else
+LINUX_BASE_PORT= ${LINUXBASE}/etc/fedora-release:${PORTSDIR}/emulators/linux_base-f10
+. endif
+. else
+IGNORE= cannot be built: there is no emulators/linux_base-${USE_LINUX}, perhaps wrong use of USE_LINUX or OVERRIDE_LINUX_BASE_PORT
+. endif
+. endif
+
+RUN_DEPENDS+= ${LINUX_BASE_PORT}
+.endif
+
+.if defined(USE_MOTIF)
+USE_XORG+= xpm
+.if defined(WANT_LESSTIF)
+LIB_DEPENDS+= Xm:${PORTSDIR}/x11-toolkits/lesstif
+NO_OPENMOTIF= yes
+.endif
+.if !defined(NO_OPENMOTIF)
+LIB_DEPENDS+= Xm.4:${PORTSDIR}/x11-toolkits/open-motif
+.endif
+.endif
+
+.if defined(USE_FREETYPE)
+LIB_DEPENDS+= ttf.4:${PORTSDIR}/print/freetype
+.endif
+
+X_IMAKE_PORT= ${PORTSDIR}/devel/imake
+X_LIBRARIES_PORT= ${PORTSDIR}/x11/xorg-libraries
+X_CLIENTS_PORT= ${PORTSDIR}/x11/xorg-apps
+X_SERVER_PORT= ${PORTSDIR}/x11-servers/xorg-server
+X_FONTSERVER_PORT= ${PORTSDIR}/x11-fonts/xfs
+X_PRINTSERVER_PORT= ${PORTSDIR}/x11-servers/xorg-printserver
+X_VFBSERVER_PORT= ${PORTSDIR}/x11-servers/xorg-vfbserver
+X_NESTSERVER_PORT= ${PORTSDIR}/x11-servers/xorg-nestserver
+X_FONTS_ENCODINGS_PORT= ${PORTSDIR}/x11-fonts/encodings
+X_FONTS_MISC_PORT= ${PORTSDIR}/x11-fonts/xorg-fonts-miscbitmaps
+X_FONTS_100DPI_PORT= ${PORTSDIR}/x11-fonts/xorg-fonts-100dpi
+X_FONTS_75DPI_PORT= ${PORTSDIR}/x11-fonts/xorg-fonts-75dpi
+X_FONTS_CYRILLIC_PORT= ${PORTSDIR}/x11-fonts/xorg-fonts-cyrillic
+X_FONTS_TTF_PORT= ${PORTSDIR}/x11-fonts/xorg-fonts-truetype
+X_FONTS_TYPE1_PORT= ${PORTSDIR}/x11-fonts/xorg-fonts-type1
+X_FONTS_ALIAS_PORT= ${PORTSDIR}/x11-fonts/font-alias
+
+.if defined(USE_IMAKE)
+CONFIGURE_ENV+= IMAKECPP="${CPP}"
+MAKE_ENV+= IMAKECPP="${CPP}"
+MAKE_FLAGS?= CC="${CC}" CXX="${CXX}"
+BUILD_DEPENDS+= imake:${X_IMAKE_PORT}
+.endif
+
+.if defined(USE_DISPLAY) && !defined(DISPLAY)
+BUILD_DEPENDS+= Xvfb:${X_VFBSERVER_PORT} \
+ ${LOCALBASE}/lib/X11/fonts/misc/8x13O.pcf.gz:${X_FONTS_MISC_PORT} \
+ ${LOCALBASE}/lib/X11/fonts/misc/fonts.alias:${X_FONTS_ALIAS_PORT} \
+ ${LOCALBASE}/share/X11/xkb/rules/base:${PORTSDIR}/x11/xkeyboard-config \
+ xkbcomp:${PORTSDIR}/x11/xkbcomp
+.if !defined(PACKAGE_BUILDING)
+CONFIGURE_ENV+= DISPLAY="localhost:1001"
+MAKE_ENV+= DISPLAY="localhost:1001"
+.endif
+.endif
+
+XAWVER= 8
+PKG_IGNORE_DEPENDS?= 'this_port_does_not_exist'
+
+PLIST_SUB+= XAWVER=${XAWVER}
+
+_GL_gl_LIB_DEPENDS= GL.1:${PORTSDIR}/graphics/libGL
+_GL_glew_LIB_DEPENDS= GLEW.1:${PORTSDIR}/graphics/glew
+_GL_glu_LIB_DEPENDS= GLU.1:${PORTSDIR}/graphics/libGLU
+_GL_glw_LIB_DEPENDS= GLw.1:${PORTSDIR}/graphics/libGLw
+_GL_glut_LIB_DEPENDS= glut.3:${PORTSDIR}/graphics/libglut
+_GL_linux_RUN_DEPENDS= ${LINUXBASE}/usr/X11R6/lib/libGL.so.1:${PORTSDIR}/graphics/linux_dri
+
+.if defined(USE_GL)
+. if ${USE_GL:L} == "yes"
+USE_GL= glu
+. endif
+. for _component in ${USE_GL}
+. if !defined(_GL_${_component}_LIB_DEPENDS) && \
+ !defined(_GL_${_component}_RUN_DEPENDS)
+IGNORE= uses unknown GL component
+. else
+LIB_DEPENDS+= ${_GL_${_component}_LIB_DEPENDS}
+RUN_DEPENDS+= ${_GL_${_component}_RUN_DEPENDS}
+. endif
+. endfor
+.endif
+
+.if defined(USE_BISON)
+_BISON_DEPENDS= bison:${PORTSDIR}/devel/bison
+
+. if ${USE_BISON:L} == "build"
+BUILD_DEPENDS+= ${_BISON_DEPENDS}
+. elif ${USE_BISON:L} == "run"
+RUN_DEPENDS+= ${_BISON_DEPENDS}
+. elif ${USE_BISON:L} == "both"
+BUILD_DEPENDS+= ${_BISON_DEPENDS}
+RUN_DEPENDS+= ${_BISON_DEPENDS}
+. else
+IGNORE= uses unknown USE_BISON construct
+. endif
+
+.endif
+
+.if defined(WITH_PKGNG)
+.include "${PORTSDIR}/Mk/bsd.pkgng.mk"
+.endif
+.if defined(USE_LOCAL_MK)
+.include "${PORTSDIR}/Mk/bsd.local.mk"
+.endif
+
+.if defined(USE_XORG) || defined(XORG_CAT)
+.include "${PORTSDIR}/Mk/bsd.xorg.mk"
+.endif
+
+.if defined(USE_MYSQL) || defined(WANT_MYSQL_VER) || \
+ defined(USE_PGSQL) || defined(WANT_PGSQL_VER) || \
+ defined(USE_BDB) || defined(USE_SQLITE) || defined(USE_FIREBIRD)
+.include "${PORTSDIR}/Mk/bsd.database.mk"
+.endif
+
+.if defined(WANT_GSTREAMER) || defined(USE_GSTREAMER) || defined(USE_GSTREAMER80)
+.include "${PORTSDIR}/Mk/bsd.gstreamer.mk"
+.endif
+
+.if defined(USE_EFL) || defined(WANT_EFL) || defined(USE_EFL_ESMART)
+.include "${PORTSDIR}/Mk/bsd.efl.mk"
+.endif
+
+.if defined(USE_JAVA)
+.include "${PORTSDIR}/Mk/bsd.java.mk"
+.endif
+
+.if defined(USE_LINUX_RPM)
+.include "${PORTSDIR}/Mk/bsd.linux-rpm.mk"
+.endif
+
+.if defined(USE_LINUX_APPS)
+.include "${PORTSDIR}/Mk/bsd.linux-apps.mk"
+.endif
+
+.if defined(USE_QT_VER) && ${USE_QT_VER:L} == 4 || defined(USE_QT4)
+.include "${PORTSDIR}/Mk/bsd.qt.mk"
+.endif
+
+.if defined(USE_SCONS)
+.include "${PORTSDIR}/Mk/bsd.scons.mk"
+.endif
+
+.if defined(USE_SDL) || defined(WANT_SDL)
+.include "${PORTSDIR}/Mk/bsd.sdl.mk"
+.endif
+
+.include "${PORTSDIR}/Mk/bsd.perl.mk"
+
+.if defined(USE_PHP)
+.include "${PORTSDIR}/Mk/bsd.php.mk"
+.endif
+
+.if defined(USE_PYTHON)
+.include "${PORTSDIR}/Mk/bsd.python.mk"
+.endif
+
+.if defined(USE_TCL) || defined(USE_TCL_BUILD) || defined(USE_TK) || defined(USE_TK_BUILD)
+.include "${PORTSDIR}/Mk/bsd.tcl.mk"
+.endif
+
+.if defined(USE_LUA) || defined(USE_LUA_NOT)
+.include "${PORTSDIR}/Mk/bsd.lua.mk"
+.endif
+
+.if defined(USE_WX) || defined(USE_WX_NOT)
+.include "${PORTSDIR}/Mk/bsd.wx.mk"
+.endif
+
+.if defined(USE_APACHE) || defined(USE_APACHE_BUILD) || defined(USE_APACHE_RUN)
+.include "${PORTSDIR}/Mk/bsd.apache.mk"
+.endif
+
+.if defined(USE_AUTOTOOLS)
+.include "${PORTSDIR}/Mk/bsd.autotools.mk"
+.endif
+
+.if defined(USE_FPC) || defined(WANT_FPC_BASE) || defined(WANT_FPC_ALL)
+.include "${PORTSDIR}/Mk/bsd.fpc.mk"
+.endif
+
+.if defined(WANT_GECKO) || defined(USE_GECKO)
+.include "${PORTSDIR}/Mk/bsd.gecko.mk"
+.endif
+
+.if defined(WANT_GNOME) || defined(USE_GNOME)
+.include "${PORTSDIR}/Mk/bsd.gnome.mk"
+.endif
+
+.if defined(WANT_MATE) || defined(USE_MATE)
+.include "${PORTSDIR}/Mk/bsd.mate.mk"
+.endif
+
+.if defined(USE_XFCE)
+.include "${PORTSDIR}/Mk/bsd.xfce.mk"
+.endif
+
+.if defined(USE_KDE4)
+.include "${PORTSDIR}/Mk/bsd.kde4.mk"
+.endif
+
+.if defined(USE_CMAKE)
+.include "${PORTSDIR}/Mk/bsd.cmake.mk"
+.endif
+
+.if exists(${PORTSDIR}/../Makefile.inc)
+.include "${PORTSDIR}/../Makefile.inc"
+USE_SUBMAKE= yes
+.endif
+
+.if defined(USE_XLIB)
+. if defined(USE_LINUX)
+RUN_DEPENDS+= ${LINUXBASE}/usr/X11R6/lib/libXrender.so.1:${PORTSDIR}/x11/linux-xorg-libs
+. else
+BUILD_DEPENDS+= ${LOCALBASE}/libdata/xorg/libraries:${X_LIBRARIES_PORT}
+RUN_DEPENDS+= ${LOCALBASE}/libdata/xorg/libraries:${X_LIBRARIES_PORT}
+. endif
+.endif
+
+.if defined(USE_XLIB) || defined(USE_XORG)
+# Add explicit X options to avoid problems with false positives in configure
+.if defined(GNU_CONFIGURE)
+CONFIGURE_ARGS+=--x-libraries=${LOCALBASE}/lib --x-includes=${LOCALBASE}/include
+.endif
+.endif
+
+# Set the default for the installation of Postscript(TM)-
+# compatible functionality.
+.if !defined(USE_GHOSTSCRIPT)
+. if defined(USE_GHOSTSCRIPT_BUILD)
+_USE_GHOSTSCRIPT= ${USE_GHOSTSCRIPT_BUILD}
+. elif defined(USE_GHOSTSCRIPT_RUN)
+_USE_GHOSTSCRIPT= ${USE_GHOSTSCRIPT_RUN}
+. endif
+.else
+_USE_GHOSTSCRIPT= ${USE_GHOSTSCRIPT}
+.endif
+
+.if defined(WITH_GHOSTSCRIPT_VER) && !empty(WITH_GHOSTSCRIPT_VER:M[789])
+_USE_GHOSTSCRIPT_DEFAULT_VER= ${WITH_GHOSTSCRIPT_VER}
+.else
+_USE_GHOSTSCRIPT_DEFAULT_VER= 9
+.endif
+
+.if defined(_USE_GHOSTSCRIPT)
+. if !defined(WITHOUT_X11)
+_USE_GHOSTSCRIPT_PKGNAME_SUFFIX=
+. else
+_USE_GHOSTSCRIPT_PKGNAME_SUFFIX=-nox11
+. endif
+. if !empty(_USE_GHOSTSCRIPT:M[789])
+_USE_GHOSTSCRIPT_VER=${_USE_GHOSTSCRIPT:M[789]}
+. else
+_USE_GHOSTSCRIPT_VER=${_USE_GHOSTSCRIPT_DEFAULT_VER}
+. endif
+.else
+_USE_GHOSTSCRIPT_VER=${_USE_GHOSTSCRIPT_DEFAULT_VER}
+.endif
+
+# Sanity check
+.if defined(_USE_GHOSTSCRIPT) && defined(WITH_GHOSTSCRIPT_VER)
+. if empty(WITH_GHOSTSCRIPT_VER:M[789])
+. error You set an invalid value "${WITH_GHOSTSCRIPT_VER}" in WITH_GHOSTSCRIPT_VER. Abort.
+. elif ${_USE_GHOSTSCRIPT_VER} != ${WITH_GHOSTSCRIPT_VER}
+. error You set WITH_GHOSTSCRIPT_VER as ${WITH_GHOSTSCRIPT_VER} but ${PKGNAME} requires print/ghostscript${_USE_GHOSTSCRIPT_VER}. Abort.
+. endif
+.endif
+
+GHOSTSCRIPT_PORT?= print/ghostscript${_USE_GHOSTSCRIPT_VER}${_USE_GHOSTSCRIPT_PKGNAME_SUFFIX}
+
+# Set up the ghostscript dependencies.
+.if defined(USE_GHOSTSCRIPT) || defined(USE_GHOSTSCRIPT_BUILD)
+BUILD_DEPENDS+= gs:${PORTSDIR}/${GHOSTSCRIPT_PORT}
+.endif
+.if defined(USE_GHOSTSCRIPT) || defined(USE_GHOSTSCRIPT_RUN)
+RUN_DEPENDS+= gs:${PORTSDIR}/${GHOSTSCRIPT_PORT}
+.endif
+
+# Set up the cdrtools.
+.if defined(USE_CDRTOOLS)
+BUILD_DEPENDS+= cdrecord:${PORTSDIR}/sysutils/cdrtools
+RUN_DEPENDS+= cdrecord:${PORTSDIR}/sysutils/cdrtools
+.endif
+
+# Macro for doing in-place file editing using regexps
+REINPLACE_ARGS?= -i.bak
+REINPLACE_CMD?= ${SED} ${REINPLACE_ARGS}
+
+# Names of cookies used to skip already completed stages
+EXTRACT_COOKIE?= ${WRKDIR}/.extract_done.${PORTNAME}.${PREFIX:S/\//_/g}
+CONFIGURE_COOKIE?= ${WRKDIR}/.configure_done.${PORTNAME}.${PREFIX:S/\//_/g}
+INSTALL_COOKIE?= ${WRKDIR}/.install_done.${PORTNAME}.${PREFIX:S/\//_/g}
+BUILD_COOKIE?= ${WRKDIR}/.build_done.${PORTNAME}.${PREFIX:S/\//_/g}
+PATCH_COOKIE?= ${WRKDIR}/.patch_done.${PORTNAME}.${PREFIX:S/\//_/g}
+PACKAGE_COOKIE?= ${WRKDIR}/.package_done.${PORTNAME}.${PREFIX:S/\//_/g}
+
+# How to do nothing. Override if you, for some strange reason, would rather
+# do something.
+DO_NADA?= ${TRUE}
+
+# Use this as the first operand to always build dependency.
+NONEXISTENT?= /nonexistent
+
+CHECKSUM_ALGORITHMS?= sha256
+
+DISTINFO_FILE?= ${MASTERDIR}/distinfo
+
+MAKE_FLAGS?= -f
+MAKEFILE?= Makefile
+MAKE_ENV+= PREFIX=${PREFIX} \
+ LOCALBASE=${LOCALBASE} \
+ MOTIFLIB="${MOTIFLIB}" LIBDIR="${LIBDIR}" \
+ CC="${CC}" CFLAGS="${CFLAGS}" \
+ CPP="${CPP}" CPPFLAGS="${CPPFLAGS}" \
+ LDFLAGS="${LDFLAGS}" \
+ CXX="${CXX}" CXXFLAGS="${CXXFLAGS}" \
+ MANPREFIX="${MANPREFIX}"
+
+# Add -fno-strict-aliasing to CFLAGS with optimization level -O2 or higher.
+# gcc 4.x enable strict aliasing optimization with -O2 which is known to break
+# a lot of ports.
+.if !defined(WITHOUT_NO_STRICT_ALIASING)
+.if ${CC} != "icc"
+.if !empty(CFLAGS:M-O[23s]) && empty(CFLAGS:M-fno-strict-aliasing)
+CFLAGS+= -fno-strict-aliasing
+.endif
+.endif
+.endif
+
+.if defined(USE_CSTD)
+CFLAGS:= ${CFLAGS:N-std=*} -std=${USE_CSTD}
+.endif
+
+# Multiple make jobs support
+.if defined(DISABLE_MAKE_JOBS) || defined(MAKE_JOBS_UNSAFE)
+_MAKE_JOBS= #
+.else
+.if defined(MAKE_JOBS_SAFE) || defined(FORCE_MAKE_JOBS)
+MAKE_JOBS_NUMBER?= `${SYSCTL} -n kern.smp.cpus`
+_MAKE_JOBS?= -j${MAKE_JOBS_NUMBER}
+.if defined(FORCE_MAKE_JOBS) && !defined(MAKE_JOBS_SAFE)
+BUILD_FAIL_MESSAGE+= "You have chosen to use multiple make jobs (parallelization) for all ports. This port was not tested for this setting. Please remove FORCE_MAKE_JOBS and retry the build before reporting the failure to the maintainer."
+.endif
+.endif
+.endif
+
+PTHREAD_CFLAGS?=
+PTHREAD_LIBS?= -pthread
+
+.if exists(/usr/bin/fetch)
+FETCH_BINARY?= /usr/bin/fetch
+FETCH_ARGS?= -AFpr
+FETCH_REGET?= 1
+.if !defined(DISABLE_SIZE)
+FETCH_BEFORE_ARGS+= $${CKSIZE:+-S $$CKSIZE}
+.endif
+.else
+FETCH_BINARY?= /usr/bin/ftp
+FETCH_ARGS?= -R
+FETCH_REGET?= 0
+.endif
+FETCH_CMD?= ${FETCH_BINARY} ${FETCH_ARGS}
+
+.if defined(RANDOMIZE_MASTER_SITES)
+.if exists(/usr/games/random)
+RANDOM_CMD?= /usr/games/random
+RANDOM_ARGS?= "-w -f -"
+_RANDOMIZE_SITES= " |${RANDOM_CMD} ${RANDOM_ARGS}"
+.endif
+.endif
+
+TOUCH?= /usr/bin/touch
+TOUCH_FLAGS?= -f
+
+DISTORIG?= .bak.orig
+PATCH?= /usr/bin/patch
+PATCH_STRIP?= -p0
+PATCH_DIST_STRIP?= -p0
+.if defined(PATCH_DEBUG)
+PATCH_DEBUG_TMP= yes
+PATCH_ARGS?= -d ${PATCH_WRKSRC} -E ${PATCH_STRIP}
+PATCH_DIST_ARGS?= --suffix ${DISTORIG} -d ${PATCH_WRKSRC} -E ${PATCH_DIST_STRIP}
+.else
+PATCH_DEBUG_TMP= no
+PATCH_ARGS?= -d ${PATCH_WRKSRC} --forward --quiet -E ${PATCH_STRIP}
+PATCH_DIST_ARGS?= --suffix ${DISTORIG} -d ${PATCH_WRKSRC} --forward --quiet -E ${PATCH_DIST_STRIP}
+.endif
+.if defined(BATCH)
+PATCH_ARGS+= --batch
+PATCH_DIST_ARGS+= --batch
+.endif
+
+# Prevent breakage with VERSION_CONTROL=numbered
+PATCH_ARGS+= -V simple
+
+.if defined(PATCH_CHECK_ONLY)
+PATCH_ARGS+= -C
+PATCH_DIST_ARGS+= -C
+.endif
+
+.if ${PATCH} == "/usr/bin/patch"
+PATCH_ARGS+= --suffix .orig
+PATCH_DIST_ARGS+= --suffix .orig
+.endif
+
+TAR?= /usr/bin/tar
+
+# EXTRACT_SUFX is defined in .pre.mk section
+.if defined(USE_ZIP)
+EXTRACT_CMD?= ${UNZIP_CMD}
+EXTRACT_BEFORE_ARGS?= -qo
+EXTRACT_AFTER_ARGS?= -d ${WRKDIR}
+.elif defined(USE_MAKESELF)
+EXTRACT_CMD?= ${UNMAKESELF_CMD}
+EXTRACT_BEFORE_ARGS?=
+EXTRACT_AFTER_ARGS?=
+.else
+EXTRACT_BEFORE_ARGS?= -dc
+.if defined(EXTRACT_PRESERVE_OWNERSHIP)
+EXTRACT_AFTER_ARGS?= | ${TAR} -xf -
+.else
+EXTRACT_AFTER_ARGS?= | ${TAR} -xf - --no-same-owner --no-same-permissions
+.endif
+.if defined(USE_BZIP2)
+EXTRACT_CMD?= ${BZIP2_CMD}
+.elif defined(USE_XZ)
+EXTRACT_CMD?= ${XZ_CMD}
+.else
+EXTRACT_CMD?= ${GZIP_CMD}
+.endif
+.endif
+
+# Figure out where the local mtree file is
+.if !defined(MTREE_FILE) && !defined(NO_MTREE)
+.if ${PREFIX} == /usr
+MTREE_FILE= /etc/mtree/BSD.usr.dist
+.else
+MTREE_FILE= ${PORTSDIR}/Templates/BSD.local.dist
+.endif
+MTREE_FILE_DEFAULT=yes
+.endif
+MTREE_CMD?= /usr/sbin/mtree
+MTREE_ARGS?= -U ${MTREE_FOLLOWS_SYMLINKS} -f ${MTREE_FILE} -d -e -p
+
+READLINK_CMD?= /usr/bin/readlink
+
+# Determine whether or not we can use rootly owner/group functions.
+.if !defined(UID)
+UID!= ${ID} -u
+.endif
+.if ${UID} == 0
+_BINOWNGRP= -o ${BINOWN} -g ${BINGRP}
+_SHROWNGRP= -o ${SHAREOWN} -g ${SHAREGRP}
+_MANOWNGRP= -o ${MANOWN} -g ${MANGRP}
+.else
+_BINOWNGRP=
+_SHROWNGRP=
+_MANOWNGRP=
+.endif
+
+# A few aliases for *-install targets
+INSTALL_PROGRAM= \
+ ${INSTALL} ${COPY} ${STRIP} ${_BINOWNGRP} -m ${BINMODE}
+INSTALL_KLD= \
+ ${INSTALL} ${COPY} ${_BINOWNGRP} -m ${BINMODE}
+INSTALL_LIB= \
+ ${INSTALL} ${COPY} ${STRIP} ${_SHROWNGRP} -m ${SHAREMODE}
+INSTALL_SCRIPT= \
+ ${INSTALL} ${COPY} ${_BINOWNGRP} -m ${BINMODE}
+INSTALL_DATA= \
+ ${INSTALL} ${COPY} ${_SHROWNGRP} -m ${SHAREMODE}
+INSTALL_MAN= \
+ ${INSTALL} ${COPY} ${_MANOWNGRP} -m ${MANMODE}
+
+INSTALL_MACROS= BSD_INSTALL_PROGRAM="${INSTALL_PROGRAM}" \
+ BSD_INSTALL_LIB="${INSTALL_LIB}" \
+ BSD_INSTALL_SCRIPT="${INSTALL_SCRIPT}" \
+ BSD_INSTALL_DATA="${INSTALL_DATA}" \
+ BSD_INSTALL_MAN="${INSTALL_MAN}"
+MAKE_ENV+= ${INSTALL_MACROS}
+SCRIPTS_ENV+= ${INSTALL_MACROS}
+
+# Macro for copying entire directory tree with correct permissions
+.if ${UID} == 0
+COPYTREE_BIN= ${SH} -c '(${FIND} -d $$0 $$2 | ${CPIO} -dumpl $$1 >/dev/null \
+ 2>&1) && \
+ ${CHOWN} -R ${BINOWN}:${BINGRP} $$1 && \
+ ${FIND} -d $$0 $$2 -type d -exec chmod 755 $$1/{} \; && \
+ ${FIND} -d $$0 $$2 -type f -exec chmod ${BINMODE} $$1/{} \;' --
+COPYTREE_SHARE= ${SH} -c '(${FIND} -d $$0 $$2 | ${CPIO} -dumpl $$1 >/dev/null \
+ 2>&1) && \
+ ${CHOWN} -R ${SHAREOWN}:${SHAREGRP} $$1 && \
+ ${FIND} -d $$0 $$2 -type d -exec chmod 755 $$1/{} \; && \
+ ${FIND} -d $$0 $$2 -type f -exec chmod ${SHAREMODE} $$1/{} \;' --
+.else
+COPYTREE_BIN= ${SH} -c '(${FIND} -d $$0 $$2 | ${CPIO} -dumpl $$1 >/dev/null \
+ 2>&1) && \
+ ${FIND} -d $$0 $$2 -type d -exec chmod 755 $$1/{} \; && \
+ ${FIND} -d $$0 $$2 -type f -exec chmod ${BINMODE} $$1/{} \;' --
+COPYTREE_SHARE= ${SH} -c '(${FIND} -d $$0 $$2 | ${CPIO} -dumpl $$1 >/dev/null \
+ 2>&1) && \
+ ${FIND} -d $$0 $$2 -type d -exec chmod 755 $$1/{} \; && \
+ ${FIND} -d $$0 $$2 -type f -exec chmod ${SHAREMODE} $$1/{} \;' --
+.endif
+
+# The user can override the NO_PACKAGE by specifying this from
+# the make command line
+.if defined(FORCE_PACKAGE)
+.undef NO_PACKAGE
+.endif
+
+DESCR?= ${PKGDIR}/pkg-descr
+PLIST?= ${PKGDIR}/pkg-plist
+PKGINSTALL?= ${PKGDIR}/pkg-install
+PKGDEINSTALL?= ${PKGDIR}/pkg-deinstall
+PKGREQ?= ${PKGDIR}/pkg-req
+PKGMESSAGE?= ${PKGDIR}/pkg-message
+
+TMPPLIST?= ${WRKDIR}/.PLIST.mktmp
+TMPPLIST_SORT?= ${WRKDIR}/.PLIST.mktmp.sorted
+TMPGUCMD?= ${WRKDIR}/.PLIST.gucmd
+
+.for _CATEGORY in ${CATEGORIES}
+PKGCATEGORY?= ${_CATEGORY}
+.endfor
+_PORTDIRNAME= ${.CURDIR:T}
+PORTDIRNAME?= ${_PORTDIRNAME}
+PKGORIGIN?= ${PKGCATEGORY}/${PORTDIRNAME}
+
+
+.if !defined(PKG_ARGS)
+PKG_ARGS= -v -c -${COMMENT:Q} -d ${DESCR} -f ${TMPPLIST} -p ${PREFIX} -P "`cd ${.CURDIR} && ${MAKE} actual-package-depends | ${GREP} -v -E ${PKG_IGNORE_DEPENDS} | ${SORT} -u -t : -k 2`" ${EXTRA_PKG_ARGS} $${_LATE_PKG_ARGS}
+.if !defined(NO_MTREE)
+PKG_ARGS+= -m ${MTREE_FILE}
+.endif
+.if defined(PKGORIGIN)
+PKG_ARGS+= -o ${PKGORIGIN}
+.endif
+.if defined(CONFLICTS) && !defined(DISABLE_CONFLICTS)
+PKG_ARGS+= -C "${CONFLICTS}"
+.endif
+.if defined(CONFLICTS_INSTALL) && !defined(DISABLE_CONFLICTS)
+PKG_ARGS+= -C "${CONFLICTS_INSTALL}"
+.endif
+.endif
+.if defined(PKG_NOCOMPRESS)
+PKG_SUFX?= .tar
+.else
+.if defined(WITH_PKGNG)
+PKG_SUFX?= .txz
+.else
+PKG_SUFX?= .tbz
+.endif
+.endif
+# where pkg_add records its dirty deeds.
+PKG_DBDIR?= /var/db/pkg
+
+MOTIFLIB?= -L${LOCALBASE}/lib -lXm -lXp
+
+ALL_TARGET?= all
+INSTALL_TARGET?= install
+
+# Integrate with the license auditing framework
+.if !defined (DISABLE_LICENSES)
+.include "${PORTSDIR}/Mk/bsd.licenses.mk"
+.endif
+
+# Popular master sites
+.include "${PORTSDIR}/Mk/bsd.sites.mk"
+
+# Empty declaration to avoid "variable MASTER_SITES recursive" error
+MASTER_SITES?=
+PATCH_SITES?=
+_MASTER_SITES_DEFAULT?=
+_PATCH_SITES_DEFAULT?=
+
+# Feed internal _{MASTER,PATCH}_SITES_n where n is a group designation
+# as per grouping rules (:something)
+# Organize _{MASTER,PATCH}_SITES_{DEFAULT,[^/:]+} according to grouping
+# rules (:something)
+.for _S in ${MASTER_SITES}
+_S_TEMP= ${_S:S/^${_S:C@/?:[^/:]+$@/@}//:S/^://}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/,/ /g}
+_G_TEMP= ${_group}
+. if ${_G_TEMP} == all || ${_G_TEMP} == ALL || ${_G_TEMP} == default
+check-makevars::
+ @${ECHO_MSG} "Makefile error: the words all, ALL and default are reserved and cannot be"
+ @${ECHO_MSG} "used in group definitions. Please fix your MASTER_SITES"
+ @${FALSE}
+. endif
+_MASTER_SITES_${_group}+= ${_S:C@^(.*/):[^/:]+$@\1@}
+. endfor
+. else
+_MASTER_SITES_DEFAULT+= ${_S:C@^(.*/):[^/:]+$@\1@}
+. endif
+.endfor
+.for _S in ${PATCH_SITES}
+_S_TEMP= ${_S:S/^${_S:C@/:[^/:]+$@/@}//:S/^://}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/,/ /g}
+_G_TEMP= ${_group}
+. if ${_G_TEMP} == all || ${_G_TEMP} == ALL || ${_G_TEMP} == default
+check-makevars::
+ @${ECHO_MSG} "The words all, ALL and default are reserved and cannot be"
+ @${ECHO_MSG} "used in group definitions. Please fix your PATCH_SITES"
+ @${FALSE}
+. endif
+_PATCH_SITES_${_group}+= ${_S:C@^(.*/):[^/:]+$@\1@}
+. endfor
+. else
+_PATCH_SITES_DEFAULT+= ${_S:C@^(.*/):[^/:]+$@\1@}
+. endif
+.endfor
+
+# Feed internal _{MASTER,PATCH}_SITE_SUBDIR_n where n is a group designation
+# as per grouping rules (:something)
+# Organize _{MASTER,PATCH}_SITE_SUBDIR_{DEFAULT,[^/:]+} according to grouping
+# rules (:something)
+.for _S in ${MASTER_SITE_SUBDIR}
+_S_TEMP= ${_S:S/^${_S:C@/:[^/:]+$@/@}//:S/^://}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/,/ /g}
+_G_TEMP= ${_group}
+. if ${_G_TEMP} == all || ${_G_TEMP} == ALL || ${_G_TEMP} == default
+check-makevars::
+ @${ECHO_MSG} "Makefile error: the words all, ALL and default are reserved and cannot be"
+ @${ECHO_MSG} "used in group definitions. Please fix your MASTER_SITE_SUBDIR"
+ @${FALSE}
+. endif
+. if defined(_MASTER_SITES_${_group})
+_MASTER_SITE_SUBDIR_${_group}+= ${_S:C@^(.*)/:[^/:]+$@\1@}
+. endif
+. endfor
+. else
+. if defined(_MASTER_SITES_DEFAULT)
+_MASTER_SITE_SUBDIR_DEFAULT+= ${_S:C@^(.*)/:[^/:]+$@\1@}
+. endif
+. endif
+.endfor
+.for _S in ${PATCH_SITE_SUBDIR}
+_S_TEMP= ${_S:S/^${_S:C@/:[^/:]+$@/@}//:S/^://}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/,/ /g}
+_G_TEMP= ${_group}
+. if ${_G_TEMP} == all || ${_G_TEMP} == ALL || ${_G_TEMP} == default
+check-makevars::
+ @${ECHO_MSG} "Makefile error: the words all, ALL and default are reserved and cannot be"
+ @${ECHO_MSG} "used in group definitions. Please fix your PATCH_SITE_SUBDIR"
+ @${FALSE}
+. endif
+. if defined(_PATCH_SITES_${_group})
+_PATCH_SITE_SUBDIR_${_group}+= ${_S:C@^(.*)/:[^/:]+$@\1@}
+. endif
+. endfor
+. else
+. if defined(_PATCH_SITES_DEFAULT)
+_PATCH_SITE_SUBDIR_DEFAULT+= ${_S:C@^(.*)/:[^/:]+$@\1@}
+. endif
+. endif
+.endfor
+
+# Substitute subdirectory names
+# XXX simpler/faster solution but not the best space wise, suggestions please
+.for _S in ${MASTER_SITES}
+_S_TEMP= ${_S:S/^${_S:C@/:[^/:]+$@/@}//:S/^://}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/,/ /g}
+. if !defined(_MASTER_SITE_SUBDIR_${_group})
+MASTER_SITES_TMP= ${_MASTER_SITES_${_group}:S^%SUBDIR%/^^}
+. else
+_S_TEMP_TEMP= ${_MASTER_SITES_${_group}:M*%SUBDIR%/*}
+. if empty(_S_TEMP_TEMP)
+MASTER_SITES_TMP= ${_MASTER_SITES_${_group}}
+. else
+MASTER_SITES_TMP=
+. for site in ${_MASTER_SITES_${_group}}
+_S_TEMP_TEMP= ${site:M*%SUBDIR%/*}
+. if empty(_S_TEMP_TEMP)
+MASTER_SITES_TMP+= ${site}
+. else
+. for dir in ${_MASTER_SITE_SUBDIR_${_group}}
+MASTER_SITES_TMP+= ${site:S^%SUBDIR%^\${dir}^}
+. endfor
+. endif
+. endfor
+. endif
+. endif
+_MASTER_SITES_${_group}:= ${MASTER_SITES_TMP}
+. endfor
+. endif
+.endfor
+.if defined(_MASTER_SITE_SUBDIR_DEFAULT)
+_S_TEMP= ${_MASTER_SITES_DEFAULT:M*%SUBDIR%/*}
+. if empty(_S_TEMP)
+MASTER_SITES_TMP= ${_MASTER_SITES_DEFAULT}
+. else
+MASTER_SITES_TMP=
+. for site in ${_MASTER_SITES_DEFAULT}
+_S_TEMP_TEMP= ${site:M*%SUBDIR%/*}
+. if empty(_S_TEMP_TEMP)
+MASTER_SITES_TMP+= ${site}
+. else
+. for dir in ${_MASTER_SITE_SUBDIR_DEFAULT}
+MASTER_SITES_TMP+= ${site:S^%SUBDIR%^\${dir}^}
+. endfor
+. endif
+. endfor
+. endif
+.else
+MASTER_SITES_TMP= ${_MASTER_SITES_DEFAULT:S^%SUBDIR%/^^}
+.endif
+_MASTER_SITES_DEFAULT:= ${MASTER_SITES_TMP}
+MASTER_SITES_TMP=
+.for _S in ${PATCH_SITES}
+_S_TEMP= ${_S:S/^${_S:C@/:[^/:]+$@/@}//:S/^://}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/,/ /g}
+. if !defined(_PATCH_SITE_SUBDIR_${_group})
+PATCH_SITES_TMP= ${_PATCH_SITES_${_group}:S^%SUBDIR%/^^}
+. else
+_S_TEMP_TEMP= ${_PATCH_SITES_${_group}:M*%SUBDIR%/*}
+. if empty(_S_TEMP_TEMP)
+PATCH_SITES_TMP= ${_PATCH_SITES_${_group}}
+. else
+PATCH_SITES_TMP=
+. for site in ${_PATCH_SITES_${_group}}
+_S_TEMP_TEMP= ${site:M*%SUBDIR%/*}
+. if empty(_S_TEMP_TEMP)
+PATCH_SITES_TMP+= ${site}
+. else
+. for dir in ${_PATCH_SITE_SUBDIR_${_group}}
+PATCH_SITES_TMP+= ${site:S^%SUBDIR%^\${dir}^}
+. endfor
+. endif
+. endfor
+. endif
+. endif
+_PATCH_SITES_${_group}:= ${PATCH_SITES_TMP}
+. endfor
+. endif
+.endfor
+.if defined(_PATCH_SITE_SUBDIR_DEFAULT)
+_S_TEMP= ${_PATCH_SITES_DEFAULT:M*%SUBDIR%/*}
+. if empty(_S_TEMP)
+PATCH_SITES_TMP= ${_PATCH_SITES_DEFAULT}
+. else
+PATCH_SITES_TMP=
+. for site in ${_PATCH_SITES_DEFAULT}
+_S_TEMP_TEMP= ${site:M*%SUBDIR%/*}
+. if empty(_S_TEMP_TEMP)
+PATCH_SITES_TMP+= ${site}
+. else
+. for dir in ${_PATCH_SITE_SUBDIR_DEFAULT}
+PATCH_SITES_TMP+= ${site:S^%SUBDIR%^\${dir}^}
+. endfor
+. endif
+. endfor
+. endif
+.else
+PATCH_SITES_TMP= ${_PATCH_SITES_DEFAULT:S^%SUBDIR%/^^}
+.endif
+_PATCH_SITES_DEFAULT:= ${PATCH_SITES_TMP}
+PATCH_SITES_TMP=
+
+# The primary backup site.
+MASTER_SITE_BACKUP?= \
+ ftp://ftp.FreeBSD.org/pub/FreeBSD/ports/distfiles/${DIST_SUBDIR}/
+MASTER_SITE_BACKUP:= ${MASTER_SITE_BACKUP:S^\${DIST_SUBDIR}/^^}
+
+# If the user has MASTER_SITE_FREEBSD set, go to the FreeBSD repository
+# for everything, but don't search it twice by appending it to the end.
+.if defined(MASTER_SITE_FREEBSD)
+_MASTER_SITE_OVERRIDE:= ${MASTER_SITE_BACKUP}
+_MASTER_SITE_BACKUP:= # empty
+.else
+_MASTER_SITE_OVERRIDE= ${MASTER_SITE_OVERRIDE}
+_MASTER_SITE_BACKUP= ${MASTER_SITE_BACKUP}
+.endif
+
+# Search CDROM first if mounted, symlink instead of copy if
+# FETCH_SYMLINK_DISTFILES is set
+.for MOUNTPT in ${CD_MOUNTPTS}
+.if exists(${MOUNTPT}/ports/distfiles)
+_MASTER_SITE_OVERRIDE:= file:${MOUNTPT}/ports/distfiles/${DIST_SUBDIR}/ ${_MASTER_SITE_OVERRIDE}
+.if defined(FETCH_SYMLINK_DISTFILES)
+FETCH_BEFORE_ARGS+= -l
+.endif
+.endif
+.endfor
+
+NOFETCHFILES?=
+
+# Organize DISTFILES, PATCHFILES, _MASTER_SITES_ALL, _PATCH_SITES_ALL
+# according to grouping rules (:something)
+DISTFILES?= ${DISTNAME}${EXTRACT_SUFX}
+_MASTER_SITES_ALL= ${_MASTER_SITES_DEFAULT}
+_PATCH_SITES_ALL= ${_PATCH_SITES_DEFAULT}
+_G_TEMP= DEFAULT
+.for _D in ${DISTFILES}
+_D_TEMP= ${_D:S/^${_D:C/:[^:]+$//}//}
+. if !empty(_D_TEMP)
+. for _group in ${_D_TEMP:S/^://:S/,/ /g}
+. if !defined(_MASTER_SITES_${_group})
+_G_TEMP_TEMP= ${_G_TEMP:M/${_group}/}
+. if empty(_G_TEMP_TEMP)
+_G_TEMP+= ${_group}
+_MASTER_SITES_ALL+= ${_MASTER_SITES_${_group}}
+. endif
+. endif
+. endfor
+_DISTFILES+= ${_D:C/:[^:]+$//}
+. else
+_DISTFILES+= ${_D}
+. endif
+.endfor
+_G_TEMP= DEFAULT
+.for _P in ${PATCHFILES}
+_P_TEMP= ${_P:S/^${_P:C/:[^:]+$//}//}
+. if !empty(_P_TEMP)
+. for _group in ${_P_TEMP:S/^://:S/,/ /g}
+. if !defined(_PATCH_SITES_${_group})
+_G_TEMP_TEMP= ${_G_TEMP:M/${_group}/}
+. if empty(_G_TEMP_TEMP)
+_G_TEMP+= ${_group}
+_PATCH_SITES_ALL+= ${_PATCH_SITES_${_group}}
+. endif
+. endif
+. endfor
+_PATCHFILES+= ${_P:C/:[^:]+$//}
+. else
+_PATCHFILES+= ${_P}
+. endif
+.endfor
+_G_TEMP=
+_G_TEMP_TEMP=
+ALLFILES?= ${_DISTFILES} ${_PATCHFILES}
+
+#
+# Sort the master site list according to the patterns in MASTER_SORT
+#
+MASTER_SORT?=
+MASTER_SORT_REGEX?=
+MASTER_SORT_REGEX+= ${MASTER_SORT:S|.|\\.|g:S|^|://[^/]*|:S|$|/|}
+
+MASTER_SORT_AWK= BEGIN { RS = " "; ORS = " "; IGNORECASE = 1 ; gl = "${MASTER_SORT_REGEX:S|\\|\\\\|g}"; }
+.for srt in ${MASTER_SORT_REGEX}
+MASTER_SORT_AWK+= /${srt:S|/|\\/|g}/ { good["${srt:S|\\|\\\\|g}"] = good["${srt:S|\\|\\\\|g}"] " " $$0 ; next; }
+.endfor
+MASTER_SORT_AWK+= { rest = rest " " $$0; } END { n=split(gl, gla); for(i=1;i<=n;i++) { print good[gla[i]]; } print rest; }
+
+SORTED_MASTER_SITES_DEFAULT_CMD= cd ${.CURDIR} && ${MAKE} master-sites-DEFAULT
+SORTED_PATCH_SITES_DEFAULT_CMD= cd ${.CURDIR} && ${MAKE} patch-sites-DEFAULT
+SORTED_MASTER_SITES_ALL_CMD= cd ${.CURDIR} && ${MAKE} master-sites-ALL
+SORTED_PATCH_SITES_ALL_CMD= cd ${.CURDIR} && ${MAKE} patch-sites-ALL
+
+#
+# Sort the master site list according to the patterns in MASTER_SORT
+# according to grouping rules (:something)
+#
+# for use in the fetch targets
+.for _S in ${MASTER_SITES}
+_S_TEMP= ${_S:S/^${_S:C@/:[^/:]+$@/@}//}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/^://:S/,/ /g}
+. if !target(master-sites-${_group})
+SORTED_MASTER_SITES_${_group}_CMD= cd ${.CURDIR} && ${MAKE} master-sites-${_group}
+master-sites-${_group}:
+ @${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} '${_MASTER_SITES_${_group}}' | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}
+. endif
+. endfor
+. endif
+.endfor
+.for _S in ${PATCH_SITES}
+_S_TEMP= ${_S:S/^${_S:C@/:[^/:]+$@/@}//}
+. if !empty(_S_TEMP)
+. for _group in ${_S_TEMP:S/^://:S/,/ /g}
+. if !target(patch-sites-${_group})
+SORTED_PATCH_SITES_${_group}_CMD= cd ${.CURDIR} && ${MAKE} patch-sites-${_group}
+patch-sites-${_group}:
+ @${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} '${_PATCH_SITES_${_group}}' | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}
+. endif
+. endfor
+. endif
+.endfor
+
+#
+# Hackery to enable simple fetch targets with several dynamic MASTER_SITES
+#
+_MASTER_SITES_ENV= _MASTER_SITES_DEFAULT="${_MASTER_SITES_DEFAULT}"
+.for _F in ${DISTFILES}
+_F_TEMP= ${_F:S/^${_F:C/:[^:]+$//}//:S/^://}
+. if !empty(_F_TEMP)
+. for _group in ${_F_TEMP:S/,/ /g}
+. if defined(_MASTER_SITES_${_group})
+_MASTER_SITES_ENV+= _MASTER_SITES_${_group}="${_MASTER_SITES_${_group}}"
+. endif
+. endfor
+. endif
+.endfor
+_PATCH_SITES_ENV= _PATCH_SITES_DEFAULT="${_PATCH_SITES_DEFAULT}"
+.for _F in ${PATCHFILES}
+_F_TEMP= ${_F:S/^${_F:C/:[^:]+$//}//:S/^://}
+. if !empty(_F_TEMP)
+. for _group in ${_F_TEMP:S/,/ /g}
+. if defined(_PATCH_SITES_${_group})
+_PATCH_SITES_ENV+= _PATCH_SITES_${_group}="${_PATCH_SITES_${_group}}"
+. endif
+. endfor
+. endif
+.endfor
+
+master-sites-ALL:
+ @${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} '${_MASTER_SITES_ALL}' | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}
+patch-sites-ALL:
+ @${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} '${_PATCH_SITES_ALL}' | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}
+# has similar effect to old targets, i.e., access only {MASTER,PATCH}_SITES, not working with the new _n variables
+master-sites-DEFAULT:
+ @${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} '${_MASTER_SITES_DEFAULT}' | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}
+patch-sites-DEFAULT:
+ @${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} '${_PATCH_SITES_DEFAULT}' | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}
+
+# synonyms, mnemonics
+master-sites-all: master-sites-ALL
+patch-sites-all: patch-sites-ALL
+master-sites-default: master-sites-DEFAULT
+patch-sites-default: patch-sites-DEFAULT
+
+# compatibility with old behavior
+master-sites: master-sites-DEFAULT
+patch-sites: patch-sites-DEFAULT
+
+.if defined(IGNOREFILES)
+.if !defined(CKSUMFILES)
+CKSUMFILES!= \
+ for file in ${ALLFILES}; do \
+ ignore=0; \
+ for tmp in ${IGNOREFILES}; do \
+ if [ "$$file" = "$$tmp" ]; then \
+ ignore=1; \
+ fi; \
+ done; \
+ if [ "$$ignore" = 0 ]; then \
+ ${ECHO_CMD} "$$file"; \
+ fi; \
+ done
+.endif
+.else
+CKSUMFILES= ${ALLFILES}
+.endif
+
+# List of all files, with ${DIST_SUBDIR} in front. Used for checksum.
+.if defined(DIST_SUBDIR)
+.if defined(CKSUMFILES) && ${CKSUMFILES}!=""
+_CKSUMFILES?= ${CKSUMFILES:S/^/${DIST_SUBDIR}\//}
+.endif
+.if defined(IGNOREFILES) && ${IGNOREFILES}!=""
+_IGNOREFILES?= ${IGNOREFILES:S/^/${DIST_SUBDIR}\//}
+.endif
+.else
+_CKSUMFILES?= ${CKSUMFILES}
+_IGNOREFILES?= ${IGNOREFILES}
+.endif
+
+# This is what is actually going to be extracted, and is overridable
+# by user.
+EXTRACT_ONLY?= ${_DISTFILES}
+
+.if !target(maintainer)
+maintainer:
+ @${ECHO_CMD} "${MAINTAINER}"
+.endif
+
+.if !target(check-makefile)
+check-makefile::
+ @${DO_NADA}
+.endif
+
+.if !defined(CATEGORIES)
+check-categories:
+ @${ECHO_MSG} "${PKGNAME}: Makefile error: CATEGORIES is mandatory."
+ @${FALSE}
+.else
+
+VALID_CATEGORIES+= accessibility afterstep arabic archivers astro audio \
+ benchmarks biology cad chinese comms converters databases \
+ deskutils devel docs dns editors elisp emulators enlightenment finance french ftp \
+ games geography german gnome gnustep graphics hamradio haskell hebrew hungarian \
+ ipv6 irc japanese java kde kld korean lang linux lisp \
+ mail mate math mbone misc multimedia net net-im net-mgmt net-p2p news \
+ palm parallel pear perl5 plan9 polish portuguese ports-mgmt \
+ print python ruby rubygems russian \
+ scheme science security shells spanish sysutils \
+ tcl textproc tk \
+ ukrainian vietnamese windowmaker www \
+ x11 x11-clocks x11-drivers x11-fm x11-fonts x11-servers x11-themes \
+ x11-toolkits x11-wm xfce zope
+
+check-categories:
+.for cat in ${CATEGORIES}
+. if empty(VALID_CATEGORIES:M${cat})
+ @${ECHO_MSG} "${PKGNAME}: Makefile error: category ${cat} not in list of valid categories."; \
+ ${FALSE};
+. endif
+.endfor
+.endif
+
+.if !target(check-makevars)
+check-makevars::
+ @${DO_NADA}
+.endif
+
+.if !target(check-depends)
+check-depends:
+ @${DO_NADA}
+.endif
+
+PKGREPOSITORYSUBDIR?= All
+PKGREPOSITORY?= ${PACKAGES}/${PKGREPOSITORYSUBDIR}
+.if exists(${PACKAGES})
+PKGFILE?= ${PKGREPOSITORY}/${PKGNAME}${PKG_SUFX}
+.else
+PKGFILE?= ${.CURDIR}/${PKGNAME}${PKG_SUFX}
+.endif
+
+# The "latest version" link -- ${PKGNAME} minus everthing after the last '-'
+PKGLATESTREPOSITORY?= ${PACKAGES}/Latest
+PKGBASE?= ${PKGNAMEPREFIX}${PORTNAME}${PKGNAMESUFFIX}
+LATEST_LINK?= ${PKGBASE}
+PKGLATESTFILE= ${PKGLATESTREPOSITORY}/${LATEST_LINK}${PKG_SUFX}
+
+CONFIGURE_SCRIPT?= configure
+CONFIGURE_TARGET?= ${ARCH}-portbld-freebsd${OSREL}
+CONFIGURE_TARGET:= ${CONFIGURE_TARGET:S/--build=//}
+CONFIGURE_LOG?= config.log
+
+# A default message to print if do-configure fails.
+CONFIGURE_FAIL_MESSAGE?= "Please report the problem to ${MAINTAINER} [maintainer] and attach the \"${CONFIGURE_WRKSRC}/${CONFIGURE_LOG}\" including the output of the failure of your make command. Also, it might be a good idea to provide an overview of all packages installed on your system (e.g. an \`ls ${PKG_DBDIR}\`)."
+
+.if defined(GNU_CONFIGURE)
+# Maximum command line length
+.if !defined(CONFIGURE_MAX_CMD_LEN)
+CONFIGURE_MAX_CMD_LEN!= ${SYSCTL} -n kern.argmax
+.endif
+GNU_CONFIGURE_PREFIX?= ${PREFIX}
+CONFIGURE_ARGS+= --prefix=${GNU_CONFIGURE_PREFIX} $${_LATE_CONFIGURE_ARGS}
+CONFIGURE_ENV+= lt_cv_sys_max_cmd_len=${CONFIGURE_MAX_CMD_LEN}
+HAS_CONFIGURE= yes
+
+SET_LATE_CONFIGURE_ARGS= \
+ _LATE_CONFIGURE_ARGS="" ; \
+ if [ ! -z "`./${CONFIGURE_SCRIPT} --help 2>&1 | ${GREP} -- '--mandir'`" ]; then \
+ _LATE_CONFIGURE_ARGS="$${_LATE_CONFIGURE_ARGS} --mandir=${MANPREFIX}/man" ; \
+ fi ; \
+ if [ ! -z "`./${CONFIGURE_SCRIPT} --help 2>&1 | ${GREP} -- '--infodir'`" ]; then \
+ _LATE_CONFIGURE_ARGS="$${_LATE_CONFIGURE_ARGS} --infodir=${PREFIX}/${INFO_PATH}/${INFO_SUBDIR}" ; \
+ fi ; \
+ if [ -z "`./${CONFIGURE_SCRIPT} --version 2>&1 | ${EGREP} -i '(autoconf.*2\.13|Unrecognized option)'`" ]; then \
+ _LATE_CONFIGURE_ARGS="$${_LATE_CONFIGURE_ARGS} --build=${CONFIGURE_TARGET}" ; \
+ else \
+ _LATE_CONFIGURE_ARGS="$${_LATE_CONFIGURE_ARGS} ${CONFIGURE_TARGET}" ; \
+ fi ;
+.endif
+
+# Passed to most of script invocations
+SCRIPTS_ENV+= CURDIR=${MASTERDIR} DISTDIR=${DISTDIR} \
+ WRKDIR=${WRKDIR} WRKSRC=${WRKSRC} PATCHDIR=${PATCHDIR} \
+ SCRIPTDIR=${SCRIPTDIR} FILESDIR=${FILESDIR} \
+ PORTSDIR=${PORTSDIR} PREFIX=${PREFIX} LOCALBASE=${LOCALBASE}
+
+.if defined(BATCH)
+SCRIPTS_ENV+= BATCH=yes
+.endif
+
+.if ${PREFIX} == /usr
+MANPREFIX?= /usr/share
+.else
+MANPREFIX?= ${PREFIX}
+.endif
+
+.for sect in 1 2 3 4 5 6 7 8 9
+MAN${sect}PREFIX?= ${MANPREFIX}
+.endfor
+MANLPREFIX?= ${MANPREFIX}
+MANNPREFIX?= ${MANPREFIX}
+
+MANLANG?= "" # english only by default
+
+.if !defined(NO_MANCOMPRESS)
+MANEXT= .gz
+.endif
+
+.if (defined(MLINKS) || defined(_MLINKS_PREPEND)) && !defined(_MLINKS)
+__pmlinks!= ${ECHO_CMD} '${MLINKS:S/ / /}' | ${AWK} \
+ '{ if (NF % 2 != 0) { print "broken"; exit; } \
+ for (i=1; i<=NF; i++) { \
+ if ($$i ~ /^-$$/ && i != 1 && i % 2 != 0) \
+ { $$i = $$(i-2); printf " " $$i " "; } \
+ else if ($$i ~ /^[^ ]+\.[1-9ln][^. ]*$$/ || $$i ~ /^\//) \
+ printf " " $$i " "; \
+ else \
+ { print "broken"; exit; } \
+ } \
+ }' | ${SED} -e 's \([^/ ][^ ]*\.\(.\)[^. ]*\) $${MAN\2PREFIX}/$$$$$$$${__lang}/man\2/\1${MANEXT}g' -e 's/ //g' -e 's/MANlPREFIX/MANLPREFIX/g' -e 's/MANnPREFIX/MANNPREFIX/g'
+.if ${__pmlinks:Mbroken} == "broken"
+check-makevars::
+ @${ECHO_MSG} "${PKGNAME}: Makefile error: unable to parse MLINKS."
+ @${FALSE}
+.endif
+_MLINKS= ${_MLINKS_PREPEND}
+
+.for lang in ${MANLANG:S%^%man/%:S%^man/""$%man%}
+.for ___pmlinks in ${__pmlinks}
+.for __lang in ${lang}
+_MLINKS+= ${___pmlinks:S// /g}
+.endfor
+.endfor
+.endfor
+.endif
+_COUNT=0
+.for ___tpmlinks in ${_MLINKS}
+.if ${_COUNT} == "1"
+_TMLINKS+= ${___tpmlinks}
+_COUNT=0
+.else
+_COUNT=1
+.endif
+.endfor
+
+.for manlang in ${MANLANG:S%^%man/%:S%^man/""$%man%}
+
+.for sect in 1 2 3 4 5 6 7 8 9 L N
+# MAN${sect} is for man pages installed for all languages in MANLANG for a given
+# section.
+.if defined(MAN${sect})
+_MANPAGES+= ${MAN${sect}:S%^%${MAN${sect}PREFIX}/${manlang}/man${sect:L}/%}
+.endif
+
+# Language specific MAN${sect} variables are for man pages installed in that
+# language, but not necessarily all languages in MANLANG.
+.if defined(MAN${sect}_${manlang:S%^man/%%:U})
+_MANPAGES+= ${MAN${sect}_${manlang:S%^man/%%:U}:S%^%${MAN${sect}PREFIX}/${manlang}/man${sect:L}/%}
+.endif
+
+.endfor
+
+.endfor
+
+# Special case for English, since it is defined with "" in MANLANG rather than
+# a language name and does not have man pages installed in a lang subdirectory
+# of MAN${sect}PREFIX.
+.for sect in 1 2 3 4 5 6 7 8 9 L N
+.if defined(MAN${sect}_EN)
+_MANPAGES+= ${MAN${sect}_EN:S%^%${MAN${sect}PREFIX}/man/man${sect:L}/%}
+.endif
+.endfor
+
+.if !defined(_TMLINKS)
+_TMLINKS=
+.endif
+
+.if defined(_MANPAGES)
+
+.if defined(NO_MANCOMPRESS)
+__MANPAGES:= ${_MANPAGES:S%^${PREFIX}/%%}
+.else
+__MANPAGES:= ${_MANPAGES:S%^${PREFIX}/%%:S%$%.gz%}
+.endif
+
+.if ${MANCOMPRESSED} == "yes"
+_MANPAGES:= ${_MANPAGES:S%$%.gz%}
+.endif
+
+.endif
+
+.if ${PREFIX} == /usr
+INFO_PATH?= share/info
+.else
+INFO_PATH?= info
+.endif
+
+.if defined(INFO)
+. for D in ${INFO:H}
+RD:= ${D}
+. if ${RD} != "."
+. if !defined(INFO_SUBDIR)
+INFO_SUBDIR:= ${RD}
+. elif ${INFO_SUBDIR} != ${RD}
+BROKEN= only one subdirectory in INFO is allowed
+. endif
+. endif
+.undef RD
+. endfor
+.endif
+
+DOCSDIR_REL?= ${DOCSDIR:S,^${PREFIX}/,,}
+EXAMPLESDIR_REL?= ${EXAMPLESDIR:S,^${PREFIX}/,,}
+DATADIR_REL?= ${DATADIR:S,^${PREFIX}/,,}
+WWWDIR_REL?= ${WWWDIR:S,^${PREFIX}/,,}
+ETCDIR_REL?= ${ETCDIR:S,^${PREFIX}/,,}
+
+PLIST_SUB+= DOCSDIR="${DOCSDIR_REL}" \
+ EXAMPLESDIR="${EXAMPLESDIR_REL}" \
+ DATADIR="${DATADIR_REL}" \
+ WWWDIR="${WWWDIR_REL}" \
+ ETCDIR="${ETCDIR_REL}"
+
+DESKTOPDIR?= ${PREFIX}/share/applications
+_DESKTOPDIR_REL= ${DESKTOPDIR:S,^${PREFIX}/,,}/
+
+.if ${_DESKTOPDIR_REL} == ${DESKTOPDIR}/
+# DESKTOPDIR is not beneath PREFIX
+_DESKTOPDIR_REL=
+.endif
+
+.MAIN: all
+
+################################################################
+# Many ways to disable a port.
+#
+# If we're in BATCH mode and the port is interactive, or we're
+# in interactive mode and the port is non-interactive, skip all
+# the important targets. The reason we have two modes is that
+# one might want to leave a build in BATCH mode running
+# overnight, then come back in the morning and do _only_ the
+# interactive ones that required your intervention.
+#
+# Ignore ports that can't be resold if building for a CDROM.
+#
+# Don't build a port if it's restricted and we don't want to get
+# into that.
+#
+# Don't build a port if it's broken, unless we're running a parallel
+# build (in case it's fixed).
+#
+# Don't build a port if it's forbidden for whatever reason.
+#
+# Don't build a port if the system is too old.
+################################################################
+
+# Check the machine architectures
+.if defined(ONLY_FOR_ARCHS)
+.for __ARCH in ${ONLY_FOR_ARCHS}
+.if ${ARCH:M${__ARCH}} != ""
+__ARCH_OK?= 1
+.endif
+.endfor
+.else
+__ARCH_OK?= 1
+.endif
+
+.if defined(NOT_FOR_ARCHS)
+.for __NARCH in ${NOT_FOR_ARCHS}
+.if ${ARCH:M${__NARCH}} != ""
+.undef __ARCH_OK
+.endif
+.endfor
+.endif
+
+.if !defined(__ARCH_OK)
+.if defined(ONLY_FOR_ARCHS)
+IGNORE= is only for ${ONLY_FOR_ARCHS},
+.else # defined(NOT_FOR_ARCHS)
+IGNORE= does not run on ${NOT_FOR_ARCHS},
+.endif
+IGNORE+= while you are running ${ARCH}
+
+.if defined(ONLY_FOR_ARCHS_REASON_${ARCH})
+IGNORE+= (reason: ${ONLY_FOR_ARCHS_REASON_${ARCH}})
+.elif defined(ONLY_FOR_ARCHS_REASON)
+IGNORE+= (reason: ${ONLY_FOR_ARCHS_REASON})
+.endif
+
+.if defined(NOT_FOR_ARCHS_REASON_${ARCH})
+IGNORE+= (reason: ${NOT_FOR_ARCHS_REASON_${ARCH}})
+.elif defined(NOT_FOR_ARCHS_REASON)
+IGNORE+= (reason: ${NOT_FOR_ARCHS_REASON})
+.endif
+
+.endif
+
+# Check the user interaction and legal issues
+.if !defined(NO_IGNORE)
+.if (defined(IS_INTERACTIVE) && defined(BATCH))
+IGNORE= is an interactive port
+.elif (!defined(IS_INTERACTIVE) && defined(INTERACTIVE))
+IGNORE= is not an interactive port
+.elif (defined(NO_CDROM) && defined(FOR_CDROM))
+IGNORE= may not be placed on a CDROM: ${NO_CDROM}
+.elif (defined(RESTRICTED) && defined(NO_RESTRICTED))
+IGNORE= is restricted: ${RESTRICTED}
+.elif defined(BROKEN)
+.if !defined(TRYBROKEN)
+IGNORE= is marked as broken: ${BROKEN}
+.endif
+.elif defined(FORBIDDEN)
+IGNORE= is forbidden: ${FORBIDDEN}
+.endif
+
+.if (defined(MANUAL_PACKAGE_BUILD) && defined(PACKAGE_BUILDING))
+IGNORE= has to be built manually: ${MANUAL_PACKAGE_BUILD}
+clean:
+ @${IGNORECMD}
+.endif
+
+.if defined(IGNORE)
+.if defined(IGNORE_SILENT)
+IGNORECMD= ${DO_NADA}
+.else
+IGNORECMD= ${ECHO_MSG} "===> ${PKGNAME} "${IGNORE:Q}.;exit 1
+.endif
+
+.for target in check-sanity fetch checksum extract patch configure all build install reinstall package
+.if !target(${target})
+${target}:
+ @${IGNORECMD}
+.if defined(INSTALLS_DEPENDS)
+ @${FALSE}
+.endif
+.endif
+.endfor
+
+.endif
+
+.endif
+
+.if defined(IGNORE) || defined(NO_PACKAGE)
+ignorelist: package-name
+.else
+ignorelist:
+ @${DO_NADA}
+.endif
+
+.if defined(IGNORE) || defined(NO_PACKAGE)
+ignorelist-verbose:
+.if defined(IGNORE)
+ @${ECHO_CMD} "${PKGNAME}|IGNORE: "${IGNORE:Q}
+.else
+ @${ECHO_CMD} "${PKGNAME}|NO_PACKAGE: "${NO_PACKAGE:Q}
+.endif
+.else
+ignorelist-verbose:
+ @${DO_NADA}
+.endif
+
+################################################################
+# Clean directories for ftp or CDROM.
+################################################################
+
+.if !defined(LICENSE)
+
+.if defined(RESTRICTED)
+clean-restricted: delete-distfiles delete-package
+clean-restricted-list: delete-distfiles-list delete-package-list
+RESTRICTED_FILES?= ${_DISTFILES} ${_PATCHFILES}
+.else
+clean-restricted:
+clean-restricted-list:
+.endif
+
+.if defined(NO_CDROM)
+clean-for-cdrom: delete-distfiles delete-package
+clean-for-cdrom-list: delete-distfiles-list delete-package-list
+RESTRICTED_FILES?= ${_DISTFILES} ${_PATCHFILES}
+.else
+clean-for-cdrom:
+clean-for-cdrom-list:
+.endif
+
+.endif # !defined(LICENSE)
+
+.if defined(ALL_HOOK)
+all:
+ @cd ${.CURDIR} && ${SETENV} CURDIR=${.CURDIR} DISTNAME=${DISTNAME} \
+ DISTDIR=${DISTDIR} WRKDIR=${WRKDIR} WRKSRC=${WRKSRC} \
+ PATCHDIR=${PATCHDIR} SCRIPTDIR=${SCRIPTDIR} \
+ FILESDIR=${FILESDIR} PORTSDIR=${PORTSDIR} PREFIX=${PREFIX} \
+ BUILD_DEPENDS="${BUILD_DEPENDS}" RUN_DEPENDS="${RUN_DEPENDS}" \
+ CONFLICTS="${CONFLICTS}" \
+ ${ALL_HOOK}
+.endif
+
+.if !target(all)
+all: build
+.endif
+
+.if !defined(DEPENDS_TARGET)
+.if defined(DEPENDS_PRECLEAN)
+DEPENDS_TARGET= clean
+DEPENDS_ARGS= NOCLEANDEPENDS=yes
+.endif
+.if make(reinstall)
+DEPENDS_TARGET+= reinstall
+.else
+DEPENDS_TARGET+= install
+.endif
+.if defined(DEPENDS_CLEAN)
+DEPENDS_TARGET+= clean
+DEPENDS_ARGS+= NOCLEANDEPENDS=yes
+.endif
+.endif
+
+################################################################
+#
+# Do preliminary work to detect if we need to run the config
+# target or not.
+#
+################################################################
+.if ((!defined(OPTIONS_DEFINE) && !defined(OPTIONS_SINGLE) && !defined(OPTIONS_MULTI)) \
+ || defined(CONFIG_DONE_${UNIQUENAME:U}) || \
+ defined(PACKAGE_BUILDING) || defined(BATCH))
+_OPTIONS_OK=yes
+.endif
+
+################################################################
+# The following are used to create easy dummy targets for
+# disabling some bit of default target behavior you don't want.
+# They still check to see if the target exists, and if so don't
+# do anything, since you might want to set this globally for a
+# group of ports in a Makefile.inc, but still be able to
+# override from an individual Makefile.
+################################################################
+
+# Disable checksum
+.if defined(NO_CHECKSUM) && !target(checksum)
+checksum: fetch
+ @${DO_NADA}
+.endif
+
+# Disable build
+.if defined(NO_BUILD) && !target(build)
+build: configure
+ @${TOUCH} ${TOUCH_FLAGS} ${BUILD_COOKIE}
+.endif
+
+# Disable install
+.if defined(NO_INSTALL) && !target(do-install)
+do-install:
+ @${DO_NADA}
+.endif
+
+# Disable package
+.if defined(NO_PACKAGE) && !target(package)
+package:
+.if defined(IGNORE_SILENT)
+ @${DO_NADA}
+.else
+ @${ECHO_MSG} "===> ${PKGNAME} may not be packaged: "${NO_PACKAGE:Q}.
+.endif
+.endif
+
+# Disable describe
+.if defined(NO_DESCRIBE) && !target(describe)
+describe:
+ @${DO_NADA}
+.endif
+
+################################################################
+# More standard targets start here.
+#
+# These are the body of the build/install framework. If you are
+# not happy with the default actions, and you can't solve it by
+# adding pre-* or post-* targets/scripts, override these.
+################################################################
+
+# Pre-everything
+
+pre-everything::
+ @${DO_NADA}
+
+buildanyway-message:
+.if defined(TRYBROKEN) && defined(BROKEN)
+ @${ECHO_MSG} "Trying build of ${PKGNAME} even though it is marked BROKEN."
+.else
+ @${DO_NADA}
+.endif
+
+options-message:
+.if defined(GNOME_OPTION_MSG) && (!defined(PACKAGE_BUILDING) || !defined(BATCH))
+ @for m in ${GNOME_OPTION_MSG}; do \
+ ${ECHO_MSG} $$m; \
+ done
+.else
+ @${DO_NADA}
+.endif
+.if defined(_OPTIONS_READ)
+ @${ECHO_MSG} "===> Found saved configuration for ${_OPTIONS_READ}"
+.endif
+
+
+# Warn user about deprecated packages. Advisory only.
+
+.if !target(check-deprecated)
+check-deprecated:
+.if defined(DEPRECATED)
+ @${ECHO_MSG} "===> NOTICE:"
+ @${ECHO_MSG}
+ @${ECHO_MSG} "This port is deprecated; you may wish to reconsider installing it:"
+ @${ECHO_MSG}
+ @${ECHO_MSG} ${DEPRECATED:Q}.
+ @${ECHO_MSG}
+.if defined(EXPIRATION_DATE)
+ @${ECHO_MSG} "It is scheduled to be removed on or after ${EXPIRATION_DATE}."
+ @${ECHO_MSG}
+.endif
+.endif
+.endif
+
+# Check if the port is listed in the vulnerability database
+
+.if defined(WITH_PKGNG)
+AUDITFILE?= ${PKG_DBDIR}/auditfile
+_EXTRACT_AUDITFILE= ${CAT} "${AUDITFILE}"
+.else
+AUDITFILE?= /var/db/portaudit/auditfile.tbz
+_EXTRACT_AUDITFILE= ${TAR} -jxOf "${AUDITFILE}" auditfile
+.endif
+
+check-vulnerable:
+.if !defined(DISABLE_VULNERABILITIES) && !defined(PACKAGE_BUILDING)
+ @if [ -f "${AUDITFILE}" ]; then \
+ if [ -n "${WITH_PKGNG}" ]; then \
+ vlist=`${PKG_BIN} audit "${PKGNAME}"`; \
+ elif [ -x "${LOCALBASE}/sbin/portaudit" ]; then \
+ vlist=`${LOCALBASE}/sbin/portaudit -X 14 "${PKGNAME}" \
+ 2>&1 | grep -vE '^[0-9]+ problem\(s\) found.' \
+ || true`; \
+ else \
+ ${ECHO_MSG} "===> portaudit database exists, however, portaudit is not installed!"; \
+ fi; \
+ if [ -n "$$vlist" ]; then \
+ ${ECHO_MSG} "===> ${PKGNAME} has known vulnerabilities:"; \
+ ${ECHO_MSG} "$$vlist"; \
+ ${ECHO_MSG} "=> Please update your ports tree and try again."; \
+ exit 1; \
+ fi; \
+ fi
+.endif
+
+# set alg to any of SIZE, SHA256 (or any other checksum algorithm):
+DISTINFO_DATA?= if [ \( -n "${DISABLE_SIZE}" -a -n "${NO_CHECKSUM}" \) -o ! -f "${DISTINFO_FILE}" ]; then exit; fi; \
+ DIR=${DIST_SUBDIR}; ${AWK} -v alg=$$alg -v file=$${DIR:+$$DIR/}$${file} \
+ '$$1 == alg && $$2 == "(" file ")" {print $$4}' ${DISTINFO_FILE}
+
+# Fetch
+
+.if !target(do-fetch)
+do-fetch:
+ @${MKDIR} ${_DISTDIR}
+ @cd ${_DISTDIR};\
+ ${_MASTER_SITES_ENV} ; \
+ for _file in ${DISTFILES}; do \
+ file=$${_file%%:*}; \
+ if [ $$_file = $$file ]; then \
+ select=''; \
+ else \
+ select=`${ECHO_CMD} $${_file##*:} | ${SED} -e 's/,/ /g'` ; \
+ fi; \
+ force_fetch=false; \
+ filebasename=$${file##*/}; \
+ for afile in ${FORCE_FETCH}; do \
+ afile=$${afile##*/}; \
+ if [ "x$$afile" = "x$$filebasename" ]; then \
+ force_fetch=true; \
+ fi; \
+ done; \
+ if [ ! -f $$file -a ! -f $$filebasename -o "$$force_fetch" = "true" ]; then \
+ if [ -L $$file -o -L $$filebasename ]; then \
+ ${ECHO_MSG} "=> ${_DISTDIR}/$$file is a broken symlink."; \
+ ${ECHO_MSG} "=> Perhaps a filesystem (most likely a CD) isn't mounted?"; \
+ ${ECHO_MSG} "=> Please correct this problem and try again."; \
+ exit 1; \
+ fi; \
+ if [ -f ${DISTINFO_FILE} -a "x${NO_CHECKSUM}" = "x" ]; then \
+ _sha256sum=`alg=SHA256; ${DISTINFO_DATA}`; \
+ if [ -z "$$_sha256sum" ]; then \
+ ${ECHO_MSG} "=> $${DIR:+$$DIR/}$$file is not in ${DISTINFO_FILE}."; \
+ ${ECHO_MSG} "=> Either ${DISTINFO_FILE} is out of date, or"; \
+ ${ECHO_MSG} "=> $${DIR:+$$DIR/}$$file is spelled incorrectly."; \
+ exit 1; \
+ fi; \
+ fi; \
+ ${ECHO_MSG} "=> $$file doesn't seem to exist in ${_DISTDIR}."; \
+ if [ ! -w ${DISTDIR} ]; then \
+ ${ECHO_MSG} "=> ${DISTDIR} is not writable by you; cannot fetch."; \
+ exit 1; \
+ fi; \
+ if [ ! -z "$$select" ] ; then \
+ __MASTER_SITES_TMP= ; \
+ for group in $$select; do \
+ if [ ! -z \$${_MASTER_SITES_$${group}} ] ; then \
+ eval ___MASTER_SITES_TMP="\$${_MASTER_SITES_$${group}}" ; \
+ __MASTER_SITES_TMP="$${__MASTER_SITES_TMP} $${___MASTER_SITES_TMP}" ; \
+ fi; \
+ done; \
+ ___MASTER_SITES_TMP= ; \
+ SORTED_MASTER_SITES_CMD_TMP="${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} $${__MASTER_SITES_TMP} | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}" ; \
+ else \
+ SORTED_MASTER_SITES_CMD_TMP="${SORTED_MASTER_SITES_DEFAULT_CMD}" ; \
+ fi; \
+ for site in `eval $$SORTED_MASTER_SITES_CMD_TMP ${_RANDOMIZE_SITES}`; do \
+ ${ECHO_MSG} "=> Attempting to fetch $${site}$${file}"; \
+ CKSIZE=`alg=SIZE; ${DISTINFO_DATA}`; \
+ case $${file} in \
+ */*) ${MKDIR} $${file%/*}; \
+ args="-o $${file} $${site}$${file}";; \
+ *) args=$${site}$${file};; \
+ esac; \
+ if ${SETENV} ${FETCH_ENV} ${FETCH_CMD} ${FETCH_BEFORE_ARGS} $${args} ${FETCH_AFTER_ARGS}; then \
+ continue 2; \
+ fi; \
+ done; \
+ ${ECHO_MSG} "=> Couldn't fetch it - please try to retrieve this";\
+ ${ECHO_MSG} "=> port manually into ${_DISTDIR} and try again."; \
+ exit 1; \
+ fi; \
+ done
+.if defined(PATCHFILES)
+ @cd ${_DISTDIR};\
+ ${_PATCH_SITES_ENV} ; \
+ for _file in ${PATCHFILES}; do \
+ file=`${ECHO_CMD} $$_file | ${SED} -E -e 's/:[^:]+$$//'` ; \
+ select=`${ECHO_CMD} $${_file#$${file}} | ${SED} -e 's/^://' -e 's/,/ /g'` ; \
+ force_fetch=false; \
+ filebasename=$${file##*/}; \
+ for afile in ${FORCE_FETCH}; do \
+ afile=$${afile##*/}; \
+ if [ "x$$afile" = "x$$filebasename" ]; then \
+ force_fetch=true; \
+ fi; \
+ done; \
+ if [ ! -f $$file -a ! -f $$filebasename -o "$$force_fetch" = "true" ]; then \
+ if [ -L $$file -o -L $${file##*/} ]; then \
+ ${ECHO_MSG} "=> ${_DISTDIR}/$$file is a broken symlink."; \
+ ${ECHO_MSG} "=> Perhaps a filesystem (most likely a CD) isn't mounted?"; \
+ ${ECHO_MSG} "=> Please correct this problem and try again."; \
+ exit 1; \
+ fi; \
+ ${ECHO_MSG} "=> $$file doesn't seem to exist in ${_DISTDIR}."; \
+ if [ ! -z "$$select" ] ; then \
+ __PATCH_SITES_TMP= ; \
+ for group in $$select; do \
+ if [ ! -z \$${_PATCH_SITES_$${group}} ] ; then \
+ eval ___PATCH_SITES_TMP="\$${_PATCH_SITES_$${group}}" ; \
+ __PATCH_SITES_TMP="$${__PATCH_SITES_TMP} $${___PATCH_SITES_TMP}" ; \
+ fi; \
+ done; \
+ ___PATCH_SITES_TMP= ; \
+ SORTED_PATCH_SITES_CMD_TMP="${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} $${__PATCH_SITES_TMP} | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}" ; \
+ else \
+ SORTED_PATCH_SITES_CMD_TMP="${SORTED_PATCH_SITES_DEFAULT_CMD}" ; \
+ fi; \
+ for site in `eval $$SORTED_PATCH_SITES_CMD_TMP`; do \
+ ${ECHO_MSG} "=> Attempting to fetch $${site}$${file}"; \
+ CKSIZE=`alg=SIZE; ${DISTINFO_DATA}`; \
+ case $${file} in \
+ */*) ${MKDIR} $${file%/*}; \
+ args="-o $${file} $${site}$${file}";; \
+ *) args=$${site}$${file};; \
+ esac; \
+ if ${SETENV} ${FETCH_ENV} ${FETCH_CMD} ${FETCH_BEFORE_ARGS} $${args} ${FETCH_AFTER_ARGS}; then \
+ continue 2; \
+ fi; \
+ done; \
+ ${ECHO_MSG} "=> Couldn't fetch it - please try to retrieve this";\
+ ${ECHO_MSG} "=> port manually into ${_DISTDIR} and try again."; \
+ exit 1; \
+ fi; \
+ done
+.endif
+.endif
+
+# Extract
+
+.if !target(do-extract)
+do-extract:
+ @${RM} -rf ${WRKDIR}
+ @${MKDIR} ${WRKDIR}
+ @for file in ${EXTRACT_ONLY}; do \
+ if ! (cd ${WRKDIR} && ${EXTRACT_CMD} ${EXTRACT_BEFORE_ARGS} ${_DISTDIR}/$$file ${EXTRACT_AFTER_ARGS});\
+ then \
+ exit 1; \
+ fi; \
+ done
+.if !defined(EXTRACT_PRESERVE_OWNERSHIP)
+ @if [ ${UID} = 0 ]; then \
+ ${CHMOD} -R ug-s ${WRKDIR}; \
+ ${CHOWN} -R 0:0 ${WRKDIR}; \
+ fi
+.endif
+.endif
+
+# Patch
+
+.if !target(patch-dos2unix)
+patch-dos2unix:
+.if defined(USE_DOS2UNIX)
+.if ${USE_DOS2UNIX:U}=="YES"
+ @${ECHO_MSG} "===> Converting DOS text files to UNIX text files"
+ @${FIND} -E ${WRKSRC} -type f -iregex '${DOS2UNIX_REGEX}' -print0 | \
+ ${XARGS} -0 ${REINPLACE_CMD} -i '' -e 's/ $$//'
+.else
+ @${ECHO_MSG} "===> Converting DOS text file to UNIX text file: ${f}"
+.if ${USE_DOS2UNIX:M*/*}
+.for f in ${USE_DOS2UNIX}
+ @${REINPLACE_CMD} -i '' -e 's/ $$//' ${WRKSRC}/${f}
+.endfor
+.else
+.for f in ${USE_DOS2UNIX}
+ @${FIND} ${WRKSRC} -type f -name '${f}' -print0 | \
+ ${XARGS} -0 ${REINPLACE_CMD} -i '' -e 's/ $$//'
+.endfor
+.endif
+.endif
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+.if !target(do-patch)
+do-patch:
+.if defined(PATCHFILES)
+ @${ECHO_MSG} "===> Applying distribution patches for ${PKGNAME}"
+ @(cd ${_DISTDIR}; \
+ for i in ${_PATCHFILES}; do \
+ if [ ${PATCH_DEBUG_TMP} = yes ]; then \
+ ${ECHO_MSG} "===> Applying distribution patch $$i" ; \
+ fi; \
+ case $$i in \
+ *.Z|*.gz) \
+ ${GZCAT} $$i | ${PATCH} ${PATCH_DIST_ARGS}; \
+ ;; \
+ *.bz2) \
+ ${BZCAT} $$i | ${PATCH} ${PATCH_DIST_ARGS}; \
+ ;; \
+ *) \
+ ${PATCH} ${PATCH_DIST_ARGS} < $$i; \
+ ;; \
+ esac; \
+ done)
+.endif
+.if defined(EXTRA_PATCHES)
+ @for i in ${EXTRA_PATCHES}; do \
+ ${ECHO_MSG} "===> Applying extra patch $$i"; \
+ ${PATCH} ${PATCH_ARGS} < $$i; \
+ done
+.endif
+ @if [ -d ${PATCHDIR} ]; then \
+ if [ "`${ECHO_CMD} ${PATCHDIR}/patch-*`" != "${PATCHDIR}/patch-*" ]; then \
+ ${ECHO_MSG} "===> Applying ${OPSYS} patches for ${PKGNAME}" ; \
+ PATCHES_APPLIED="" ; \
+ for i in ${PATCHDIR}/patch-*; do \
+ case $$i in \
+ *.orig|*.rej|*~|*,v) \
+ ${ECHO_MSG} "===> Ignoring patchfile $$i" ; \
+ ;; \
+ *) \
+ if [ ${PATCH_DEBUG_TMP} = yes ]; then \
+ ${ECHO_MSG} "===> Applying ${OPSYS} patch $$i" ; \
+ fi; \
+ if ${PATCH} ${PATCH_ARGS} < $$i ; then \
+ PATCHES_APPLIED="$$PATCHES_APPLIED $$i" ; \
+ else \
+ ${ECHO_MSG} `${ECHO_CMD} "=> Patch $$i failed to apply cleanly." | ${SED} "s|${PATCHDIR}/||"` ; \
+ if [ x"$$PATCHES_APPLIED" != x"" ]; then \
+ ${ECHO_MSG} `${ECHO_CMD} "=> Patch(es) $$PATCHES_APPLIED applied cleanly." | ${SED} "s|${PATCHDIR}/||g"` ; \
+ fi; \
+ ${FALSE} ; \
+ fi; \
+ ;; \
+ esac; \
+ done; \
+ fi; \
+ fi
+.endif
+
+.if !target(run-autotools-fixup)
+run-autotools-fixup:
+# Work around an issue where FreeBSD 10.0 is detected as FreeBSD 1.x.
+.if ${OSVERSION} >= 1000000 && !defined(WITHOUT_FBSD10_FIX)
+ -@for f in `${FIND} ${WRKDIR} -type f \( -name config.libpath -o \
+ -name config.rpath -o -name configure -o -name libtool.m4 -o \
+ -name ltconfig -o -name libtool -o -name aclocal.m4 -o \
+ -name acinclude.m4 \)` ; do \
+ ${SED} -i.fbsd10bak \
+ -e 's|freebsd1\*)|freebsd1.\*)|g' \
+ -e 's|freebsd\[12\]\*)|freebsd[12].*)|g' \
+ -e 's|freebsd\[123\]\*)|freebsd[123].*)|g' \
+ -e 's|freebsd\[\[12\]\]\*)|freebsd[[12]].*)|g' \
+ -e 's|freebsd\[\[123\]\]\*)|freebsd[[123]].*)|g' \
+ $${f} ; \
+ ${TOUCH} ${TOUCH_FLAGS} -mr $${f}.fbsd10bak $${f} ; \
+ ${RM} -f $${f}.fbsd10bak ; \
+ ${ECHO_MSG} "===> FreeBSD 10 autotools fix applied to $${f}"; \
+ done
+.endif
+.endif
+
+.if !target(configure-autotools)
+configure-autotools:
+ @${DO_NADA}
+.endif
+
+.if !target(run-autotools)
+run-autotools:
+ @${DO_NADA}
+.endif
+
+# Configure
+
+.if !target(do-configure)
+do-configure:
+ @if [ -f ${SCRIPTDIR}/configure ]; then \
+ cd ${.CURDIR} && ${SETENV} ${SCRIPTS_ENV} ${SH} \
+ ${SCRIPTDIR}/configure; \
+ fi
+.if defined(GNU_CONFIGURE)
+ @CONFIG_GUESS_DIRS=$$(${FIND} ${WRKDIR} -name config.guess -o -name config.sub \
+ | ${XARGS} -n 1 ${DIRNAME}); \
+ for _D in $${CONFIG_GUESS_DIRS}; do \
+ ${CP} -f ${TEMPLATES}/config.guess $${_D}/config.guess; \
+ ${CHMOD} a+rx $${_D}/config.guess; \
+ ${CP} -f ${TEMPLATES}/config.sub $${_D}/config.sub; \
+ ${CHMOD} a+rx $${_D}/config.sub; \
+ done
+.endif
+.if defined(HAS_CONFIGURE)
+ @(cd ${CONFIGURE_WRKSRC} && \
+ ${SET_LATE_CONFIGURE_ARGS} \
+ if ! ${SETENV} CC="${CC}" CPP="${CPP}" CXX="${CXX}" \
+ CFLAGS="${CFLAGS}" CPPFLAGS="${CPPFLAGS}" CXXFLAGS="${CXXFLAGS}" \
+ LDFLAGS="${LDFLAGS}" \
+ INSTALL="/usr/bin/install -c ${_BINOWNGRP}" \
+ INSTALL_DATA="${INSTALL_DATA}" \
+ INSTALL_LIB="${INSTALL_LIB}" \
+ INSTALL_PROGRAM="${INSTALL_PROGRAM}" \
+ INSTALL_SCRIPT="${INSTALL_SCRIPT}" \
+ ${CONFIGURE_ENV} ./${CONFIGURE_SCRIPT} ${CONFIGURE_ARGS}; then \
+ ${ECHO_MSG} "===> Script \"${CONFIGURE_SCRIPT}\" failed unexpectedly."; \
+ (${ECHO_CMD} ${CONFIGURE_FAIL_MESSAGE}) | ${FMT} 75 79 ; \
+ ${FALSE}; \
+ fi)
+.endif
+.if defined(USE_IMAKE)
+ @(cd ${CONFIGURE_WRKSRC}; ${SETENV} ${MAKE_ENV} ${XMKMF})
+.endif
+.endif
+
+# Build
+
+.if !target(do-build)
+do-build:
+.if defined(USE_GMAKE)
+ @(cd ${BUILD_WRKSRC}; if ! ${SETENV} ${MAKE_ENV} ${GMAKE} ${MAKE_FLAGS} ${MAKEFILE} ${_MAKE_JOBS} ${MAKE_ARGS} ${ALL_TARGET}; then \
+ if [ x != x${BUILD_FAIL_MESSAGE} ] ; then \
+ ${ECHO_MSG} "===> Compilation failed unexpectedly."; \
+ (${ECHO_CMD} ${BUILD_FAIL_MESSAGE}) | ${FMT} 75 79 ; \
+ fi; \
+ ${FALSE}; \
+ fi)
+.else
+ @(cd ${BUILD_WRKSRC}; if ! ${SETENV} ${MAKE_ENV} ${MAKE} ${MAKE_FLAGS} ${MAKEFILE} ${_MAKE_JOBS} ${MAKE_ARGS} ${ALL_TARGET}; then \
+ if [ x != x${BUILD_FAIL_MESSAGE} ] ; then \
+ ${ECHO_MSG} "===> Compilation failed unexpectedly."; \
+ (${ECHO_CMD} ${BUILD_FAIL_MESSAGE}) | ${FMT} 75 79 ; \
+ fi; \
+ ${FALSE}; \
+ fi)
+.endif
+.endif
+
+# Check conflicts
+
+.if !target(check-conflicts)
+check-conflicts: check-build-conflicts check-install-conflicts
+.endif
+
+.if !target(check-build-conflicts)
+check-build-conflicts:
+.if ( defined(CONFLICTS) || defined(CONFLICTS_BUILD) ) && !defined(DISABLE_CONFLICTS) && !defined(DEFER_CONFLICTS_CHECK)
+ @found=`${PKG_INFO} -I ${CONFLICTS:C/.+/'&'/} ${CONFLICTS_BUILD:C/.+/'&'/} 2>/dev/null | ${AWK} '{print $$1}'`; \
+ conflicts_with=; \
+ for entry in $${found}; do \
+ if ${PKG_INFO} -e $${entry} ; then \
+ prfx=`${PKG_INFO} -q -p "$${entry}" 2> /dev/null | ${SED} -ne '1s/^@cwd //p'`; \
+ orgn=`${PKG_INFO} -q -o "$${entry}" 2> /dev/null`; \
+ if [ "/${PREFIX}" = "/$${prfx}" -a "/${PKGORIGIN}" != "/$${orgn}" ]; then \
+ conflicts_with="$${conflicts_with} $${entry}"; \
+ fi; \
+ fi; \
+ done; \
+ if [ -n "$${conflicts_with}" ]; then \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} "===> ${PKGNAME} conflicts with installed package(s): "; \
+ for entry in $${conflicts_with}; do \
+ ${ECHO_MSG} " $${entry}"; \
+ done; \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} " They will not build together."; \
+ ${ECHO_MSG} " Please remove them first with pkg_delete(1)."; \
+ exit 1; \
+ fi
+.endif
+.endif
+
+.if !target(identify-install-conflicts)
+identify-install-conflicts:
+.if ( defined(CONFLICTS) || defined(CONFLICTS_INSTALL) ) && !defined(DISABLE_CONFLICTS)
+ @found=`${PKG_INFO} -I ${CONFLICTS:C/.+/'&'/} ${CONFLICTS_INSTALL:C/.+/'&'/} 2>/dev/null | ${AWK} '{print $$1}'`; \
+ conflicts_with=; \
+ for entry in $${found}; do \
+ if ${PKG_INFO} -e $${entry} ; then \
+ prfx=`${PKG_INFO} -q -p "$${entry}" 2> /dev/null | ${SED} -ne '1s/^@cwd //p'`; \
+ orgn=`${PKG_INFO} -q -o "$${entry}" 2> /dev/null`; \
+ if [ "/${PREFIX}" = "/$${prfx}" -a "/${PKGORIGIN}" != "/$${orgn}" ]; then \
+ conflicts_with="$${conflicts_with} $${entry}"; \
+ fi; \
+ fi; \
+ done; \
+ if [ -n "$${conflicts_with}" ]; then \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} "===> ${PKGNAME} conflicts with installed package(s): "; \
+ for entry in $${conflicts_with}; do \
+ ${ECHO_MSG} " $${entry}"; \
+ done; \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} " They install files into the same place."; \
+ ${ECHO_MSG} " You may want to stop build with Ctrl + C."; \
+ sleep 10; \
+ fi
+.endif
+.endif
+
+.if !target(check-install-conflicts)
+check-install-conflicts:
+.if ( defined(CONFLICTS) || defined(CONFLICTS_INSTALL) || ( defined(CONFLICTS_BUILD) && defined(DEFER_CONFLICTS_CHECK) ) ) && !defined(DISABLE_CONFLICTS)
+.if defined(DEFER_CONFLICTS_CHECK)
+ @found=`${PKG_INFO} -I ${CONFLICTS:C/.+/'&'/} ${CONFLICTS_BUILD:C/.+/'&'/} ${CONFLICTS_INSTALL:C/.+/'&'/} 2>/dev/null | ${AWK} '{print $$1}'`; \
+ conflicts_with=; \
+ for entry in $${found}; do \
+ if ${PKG_INFO} -e $${entry} ; then \
+ prfx=`${PKG_INFO} -q -p "$${entry}" 2> /dev/null | ${SED} -ne '1s/^@cwd //p'`; \
+ orgn=`${PKG_INFO} -q -o "$${entry}" 2> /dev/null`; \
+ if [ "/${PREFIX}" = "/$${prfx}" -a "/${PKGORIGIN}" != "/$${orgn}" ]; then \
+ conflicts_with="$${conflicts_with} $${entry}"; \
+ fi; \
+ fi; \
+ done; \
+ if [ -n "$${conflicts_with}" ]; then \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} "===> ${PKGNAME} conflicts with installed package(s): "; \
+ for entry in $${conflicts_with}; do \
+ ${ECHO_MSG} " $${entry}"; \
+ done; \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} " Please remove them first with pkg_delete(1)."; \
+ exit 1; \
+ fi
+.else
+ @found=`${PKG_INFO} -I ${CONFLICTS:C/.+/'&'/} ${CONFLICTS_INSTALL:C/.+/'&'/} 2>/dev/null | ${AWK} '{print $$1}'`; \
+ conflicts_with=; \
+ for entry in $${found}; do \
+ if ${PKG_INFO} -e $${entry} ; then \
+ prfx=`${PKG_INFO} -q -p "$${entry}" 2> /dev/null | ${SED} -ne '1s/^@cwd //p'`; \
+ orgn=`${PKG_INFO} -q -o "$${entry}" 2> /dev/null`; \
+ if [ "/${PREFIX}" = "/$${prfx}" -a "/${PKGORIGIN}" != "/$${orgn}" ]; then \
+ conflicts_with="$${conflicts_with} $${entry}"; \
+ fi; \
+ fi; \
+ done; \
+ if [ -n "$${conflicts_with}" ]; then \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} "===> ${PKGNAME} conflicts with installed package(s): "; \
+ for entry in $${conflicts_with}; do \
+ ${ECHO_MSG} " $${entry}"; \
+ done; \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} " They install files into the same place."; \
+ ${ECHO_MSG} " Please remove them first with pkg_delete(1)."; \
+ exit 1; \
+ fi
+.endif # defined(DEFER_CONFLICTS_CHECK)
+.endif
+.endif
+
+# Install
+
+.if !target(do-install)
+do-install:
+.if defined(USE_GMAKE)
+ @(cd ${INSTALL_WRKSRC} && ${SETENV} ${MAKE_ENV} ${GMAKE} ${MAKE_FLAGS} ${MAKEFILE} ${MAKE_ARGS} ${INSTALL_TARGET})
+.if defined(USE_IMAKE) && !defined(NO_INSTALL_MANPAGES)
+ @(cd ${INSTALL_WRKSRC} && ${SETENV} ${MAKE_ENV} ${GMAKE} ${MAKE_FLAGS} ${MAKEFILE} ${MAKE_ARGS} install.man)
+.endif
+.else # !defined(USE_GMAKE)
+ @(cd ${INSTALL_WRKSRC} && ${SETENV} ${MAKE_ENV} ${MAKE} ${MAKE_FLAGS} ${MAKEFILE} ${MAKE_ARGS} ${INSTALL_TARGET})
+.if defined(USE_IMAKE) && !defined(NO_INSTALL_MANPAGES)
+ @(cd ${INSTALL_WRKSRC} && ${SETENV} ${MAKE_ENV} ${MAKE} ${MAKE_FLAGS} ${MAKEFILE} ${MAKE_ARGS} install.man)
+.endif
+.endif
+.endif
+
+# Package
+
+.if !target(do-package)
+do-package: ${TMPPLIST}
+ @if [ -d ${PACKAGES} ]; then \
+ if [ ! -d ${PKGREPOSITORY} ]; then \
+ if ! ${MKDIR} ${PKGREPOSITORY}; then \
+ ${ECHO_MSG} "=> Can't create directory ${PKGREPOSITORY}."; \
+ exit 1; \
+ fi; \
+ fi; \
+ fi
+ @if ${PKG_CMD} -b ${PKGNAME} ${PKGFILE}; then \
+ if [ -d ${PACKAGES} ]; then \
+ cd ${.CURDIR} && eval ${MAKE} package-links; \
+ fi; \
+ else \
+ cd ${.CURDIR} && eval ${MAKE} delete-package; \
+ exit 1; \
+ fi
+.endif
+
+# Some support rules for do-package
+
+.if !target(package-links)
+package-links: delete-package-links
+ @for cat in ${CATEGORIES}; do \
+ if [ ! -d ${PACKAGES}/$$cat ]; then \
+ if ! ${MKDIR} ${PACKAGES}/$$cat; then \
+ ${ECHO_MSG} "=> Can't create directory ${PACKAGES}/$$cat."; \
+ exit 1; \
+ fi; \
+ fi; \
+ ${LN} -sf `${ECHO_CMD} $$cat | ${SED} -e 'sa[^/]*a..ag'`/${PKGREPOSITORYSUBDIR}/${PKGNAME}${PKG_SUFX} ${PACKAGES}/$$cat; \
+ done
+.if !defined(NO_LATEST_LINK)
+ @if [ ! -d ${PKGLATESTREPOSITORY} ]; then \
+ if ! ${MKDIR} ${PKGLATESTREPOSITORY}; then \
+ ${ECHO_MSG} "=> Can't create directory ${PKGLATESTREPOSITORY}."; \
+ exit 1; \
+ fi; \
+ fi
+ @${LN} -s ../${PKGREPOSITORYSUBDIR}/${PKGNAME}${PKG_SUFX} ${PKGLATESTFILE}
+.endif
+.endif
+
+.if !target(delete-package-links)
+delete-package-links:
+ @for cat in ${CATEGORIES}; do \
+ ${RM} -f ${PACKAGES}/$$cat/${PKGNAME}${PKG_SUFX}; \
+ done
+.if !defined(NO_LATEST_LINK)
+ @${RM} -f ${PKGLATESTFILE}
+.endif
+.endif
+
+.if !target(delete-package)
+delete-package: delete-package-links
+ @${RM} -f ${PKGFILE}
+.endif
+
+.if !target(delete-package-links-list)
+delete-package-links-list:
+ @for cat in ${CATEGORIES}; do \
+ ${ECHO_CMD} ${RM} -f ${PACKAGES}/$$cat/${PKGNAME}${PKG_SUFX}; \
+ done
+.if !defined(NO_LATEST_LINK)
+ @${ECHO_CMD} ${RM} -f ${PKGLATESTFILE}
+.endif
+.endif
+
+.if !target(delete-package-list)
+delete-package-list: delete-package-links-list
+ @${ECHO_CMD} "[ -f ${PKGFILE} ] && (${ECHO_CMD} deleting ${PKGFILE}; ${RM} -f ${PKGFILE})"
+.endif
+
+# Utility targets follow
+
+.if !target(check-already-installed)
+check-already-installed: ${TMPPLIST_SORT}
+.if !defined(NO_PKG_REGISTER) && !defined(FORCE_PKG_REGISTER)
+ @${ECHO_MSG} "===> Checking if ${PKGORIGIN} already installed"; \
+ ${MKDIR} ${PKG_DBDIR}; \
+ already_installed=`${PKG_INFO} -q -O ${PKGORIGIN}`; \
+ if [ -n "$${already_installed}" ]; then \
+ for p in $${already_installed}; do \
+ prfx=`${PKG_INFO} -q -p $${p} 2> /dev/null | ${SED} -ne '1s|^@cwd ||p'`; \
+ if [ "x${PREFIX}" = "x$${prfx}" ]; then \
+ df=`${PKG_INFO} -q -f $${p} 2> /dev/null | ${GREP} -v "^@" | ${SORT} -u | ${COMM} -12 - ${TMPPLIST_SORT}`; \
+ if [ -n "$${df}" ]; then \
+ found_package=$${p}; \
+ break; \
+ fi; \
+ fi; \
+ done; \
+ fi; \
+ if [ -d ${PKG_DBDIR}/${PKGNAME} -o -n "$${found_package}" ]; then \
+ if [ -d ${PKG_DBDIR}/${PKGNAME} ]; then \
+ ${ECHO_CMD} "===> ${PKGNAME} is already installed"; \
+ else \
+ ${ECHO_CMD} "===> An older version of ${PKGORIGIN} is already installed ($${found_package})"; \
+ fi; \
+ ${ECHO_MSG} " You may wish to \`\`make deinstall'' and install this port again"; \
+ ${ECHO_MSG} " by \`\`make reinstall'' to upgrade it properly."; \
+ ${ECHO_MSG} " If you really wish to overwrite the old port of ${PKGORIGIN}"; \
+ ${ECHO_MSG} " without deleting it first, set the variable \"FORCE_PKG_REGISTER\""; \
+ ${ECHO_MSG} " in your environment or the \"make install\" command line."; \
+ exit 1; \
+ fi
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+.if !target(check-umask)
+check-umask:
+ @if [ `${SH} -c umask` != 0022 ]; then \
+ ${ECHO_MSG} "===> Warning: your umask is \"`${SH} -c umask`"\".; \
+ ${ECHO_MSG} " If this is not desired, set it to an appropriate value"; \
+ ${ECHO_MSG} " and install this port again by \`\`make reinstall''."; \
+ fi
+.endif
+
+.if !target(install-mtree)
+install-mtree:
+ @${MKDIR} ${PREFIX}
+ @if [ ${UID} != 0 ]; then \
+ if [ -w ${PREFIX}/ ]; then \
+ ${ECHO_MSG} "Warning: not superuser, you may get some errors during installation."; \
+ else \
+ ${ECHO_MSG} "Error: ${PREFIX}/ not writable."; \
+ ${FALSE}; \
+ fi; \
+ fi
+.if !defined(NO_MTREE)
+ @if [ ${UID} = 0 ]; then \
+ if [ ! -f ${MTREE_FILE} ]; then \
+ ${ECHO_MSG} "Error: mtree file \"${MTREE_FILE}\" is missing."; \
+ ${ECHO_MSG} "Copy it from a suitable location (e.g., ${SRC_BASE}/etc/mtree) and try again."; \
+ exit 1; \
+ else \
+ ${MTREE_CMD} ${MTREE_ARGS} ${PREFIX}/ >/dev/null; \
+ if [ ${PREFIX} = ${LOCALBASE} -a "${MTREE_FILE_DEFAULT}" = "yes" ]; then \
+ cd ${PREFIX}/share/nls; \
+ for link in POSIX en_US.US-ASCII; \
+ do \
+ if [ x"`${READLINK_CMD} $${link}`" != x"C" ]; \
+ then \
+ ${LN} -shf C $${link}; \
+ fi; \
+ done; \
+ fi; \
+ fi; \
+ else \
+ ${ECHO_MSG} "Warning: not superuser, can't run mtree."; \
+ ${ECHO_MSG} "You may want to become root and try again to ensure correct permissions."; \
+ fi
+.endif
+.endif
+
+.if !target(install-ldconfig-file)
+install-ldconfig-file:
+.if defined(USE_LDCONFIG) || defined(USE_LDCONFIG32)
+.if defined(USE_LDCONFIG)
+.if defined(USE_LINUX_PREFIX)
+ @${ECHO_MSG} "===> Running linux ldconfig"
+ ${LDCONFIG_CMD}
+.else
+.if !defined(INSTALL_AS_USER)
+ @${ECHO_MSG} "===> Running ldconfig"
+ ${LDCONFIG} -m ${USE_LDCONFIG}
+.else
+ @${ECHO_MSG} "===> Running ldconfig (errors are ignored)"
+ -${LDCONFIG} -m ${USE_LDCONFIG}
+.endif
+.if ${USE_LDCONFIG} != "${PREFIX}/lib" && !defined(INSTALL_AS_USER)
+ @${ECHO_MSG} "===> Installing ldconfig configuration file"
+.if defined(NO_LDCONFIG_MTREE)
+ @${MKDIR} ${PREFIX}/${LDCONFIG_DIR}
+.endif
+ @${ECHO_CMD} ${USE_LDCONFIG} | ${TR} ' ' '\n' \
+ > ${PREFIX}/${LDCONFIG_DIR}/${UNIQUENAME}
+ @${ECHO_CMD} "@cwd" >> ${TMPPLIST}
+ @${ECHO_CMD} ${LDCONFIG_DIR}/${UNIQUENAME} >> ${TMPPLIST}
+.if defined(NO_LDCONFIG_MTREE)
+ @${ECHO_CMD} "@unexec rmdir ${LDCONFIG_DIR} >/dev/null 2>&1 || true" >> ${TMPPLIST}
+.endif
+.endif
+.endif
+.endif
+.if defined(USE_LDCONFIG32)
+.if !defined(INSTALL_AS_USER)
+ @${ECHO_MSG} "===> Running ldconfig"
+ ${LDCONFIG} -32 -m ${USE_LDCONFIG32}
+.else
+ @${ECHO_MSG} "===> Running ldconfig (errors are ignored)"
+ -${LDCONFIG} -32 -m ${USE_LDCONFIG32}
+.endif
+.if !defined(INSTALL_AS_USER)
+ @${ECHO_MSG} "===> Installing 32-bit ldconfig configuration file"
+.if defined(NO_LDCONFIG_MTREE)
+ @${MKDIR} ${PREFIX}/${LDCONFIG_32DIR}
+.endif
+ @${ECHO_CMD} ${USE_LDCONFIG32} | ${TR} ' ' '\n' \
+ > ${PREFIX}/${LDCONFIG32_DIR}/${UNIQUENAME}
+ @${ECHO_CMD} "@cwd" >> ${TMPPLIST}
+ @${ECHO_CMD} ${LDCONFIG32_DIR}/${UNIQUENAME} >> ${TMPPLIST}
+.if defined(NO_LDCONFIG_MTREE)
+ @${ECHO_CMD} "@unexec rmdir ${LDCONFIG32_DIR} >/dev/null 2>&1" >> ${TMPPLIST}
+.endif
+.endif
+.endif
+.if defined(INSTALLS_SHLIB)
+ @${ECHO_MSG} "INSTALLS_SHLIB is deprecated. Use USE_LDCONFIG instead."
+.endif
+.endif
+.endif
+
+.if !target(create-users-groups)
+create-users-groups:
+.if defined(GROUPS) || defined(USERS)
+.if defined(GROUPS)
+.for _file in ${GID_FILES}
+.if !exists(${_file})
+ @${ECHO_CMD} "** ${_file} doesn't exist. Exiting."; exit 1
+.endif
+.endfor
+ @${ECHO_MSG} "===> Creating users and/or groups."
+ @${ECHO_CMD} "@exec echo \"===> Creating users and/or groups.\"" >> ${TMPPLIST}
+.for _group in ${GROUPS}
+# _bgpd:*:130:
+ @if ! ${GREP} -h ^${_group}: ${GID_FILES} >/dev/null 2>&1; then \
+ ${ECHO_CMD} "** Cannot find any information about group \`${_group}' in ${GID_FILES}."; \
+ exit 1; \
+ fi
+ @IFS=":"; ${GREP} -h ^${_group}: ${GID_FILES} | head -n 1 | while read group foo gid members; do \
+ gid=$$(($$gid+${GID_OFFSET})); \
+ if ! ${PW} groupshow $$group >/dev/null 2>&1; then \
+ ${ECHO_MSG} "Creating group \`$$group' with gid \`$$gid'."; \
+ ${PW} groupadd $$group -g $$gid; \
+ else \
+ ${ECHO_MSG} "Using existing group \`$$group'."; \
+ fi; \
+ ${ECHO_CMD} "@exec if ! ${PW} groupshow $$group >/dev/null 2>&1; then \
+ echo \"Creating group '$$group' with gid '$$gid'.\"; \
+ ${PW} groupadd $$group -g $$gid; else echo \"Using existing group '$$group'.\"; fi" >> ${TMPPLIST}; \
+ done
+.endfor
+.endif
+.if defined(USERS)
+.for _file in ${UID_FILES}
+.if !exists(${_file})
+ @${ECHO_CMD} "** ${_file} doesn't exist. Exiting."; exit 1
+.endif
+.endfor
+.for _user in ${USERS}
+# _bgpd:*:130:130:BGP Daemon:/var/empty:/sbin/nologin
+ @if ! ${GREP} -h ^${_user}: ${UID_FILES} >/dev/null 2>&1; then \
+ ${ECHO_CMD} "** Cannot find any information about user \`${_user}' in ${UID_FILES}."; \
+ exit 1; \
+ fi
+ @IFS=":"; ${GREP} -h ^${_user}: ${UID_FILES} | head -n 1 | while read login passwd uid gid class change expire gecos homedir shell; do \
+ uid=$$(($$uid+${UID_OFFSET})); \
+ gid=$$(($$gid+${GID_OFFSET})); \
+ class="$${class:+-L }$$class"; \
+ homedir=$$(echo $$homedir | sed "s|^/usr/local|${PREFIX}|"); \
+ if ! ${PW} usershow $$login >/dev/null 2>&1; then \
+ ${ECHO_MSG} "Creating user \`$$login' with uid \`$$uid'."; \
+ eval ${PW} useradd $$login -u $$uid -g $$gid $$class -c \"$$gecos\" -d $$homedir -s $$shell; \
+ case $$homedir in /nonexistent|/var/empty) ;; *) ${INSTALL} -d -g $$gid -o $$uid $$homedir;; esac; \
+ else \
+ ${ECHO_MSG} "Using existing user \`$$login'."; \
+ fi; \
+ ${ECHO_CMD} "@exec if ! ${PW} usershow $$login >/dev/null 2>&1; then \
+ echo \"Creating user '$$login' with uid '$$uid'.\"; \
+ ${PW} useradd $$login -u $$uid -g $$gid $$class -c \"$$gecos\" -d $$homedir -s $$shell; \
+ else echo \"Using existing user '$$login'.\"; fi" >> ${TMPPLIST}; \
+ case $$homedir in /nonexistent|/var/empty) ;; *) ${ECHO_CMD} "@exec ${INSTALL} -d -g $$gid -o $$uid $$homedir" >> ${TMPPLIST};; esac; \
+ done
+.endfor
+.if defined(GROUPS)
+.for _group in ${GROUPS}
+# mail:*:6:postfix,clamav
+ @IFS=":"; ${GREP} -h ^${_group}: ${GID_FILES} | head -n 1 | while read group foo gid members; do \
+ gid=$$(($$gid+${GID_OFFSET})); \
+ IFS=","; for _login in $$members; do \
+ for _user in ${USERS}; do \
+ if [ "x$${_user}" = "x$${_login}" ]; then \
+ if ! ${PW} groupshow ${_group} | ${GREP} -qw $${_login}; then \
+ ${ECHO_MSG} "Adding user \`$${_login}' to group \`${_group}'."; \
+ ${PW} groupmod ${_group} -m $${_login}; \
+ fi; \
+ ${ECHO_CMD} "@exec if ! ${PW} groupshow ${_group} | ${GREP} -qw $${_login}; then \
+ echo \"Adding user '$${_login}' to group '${_group}'.\"; \
+ ${PW} groupmod ${_group} -m $${_login}; fi" >> ${TMPPLIST}; \
+ fi; \
+ done; \
+ done; \
+ done
+.endfor
+.endif
+.if defined(USERS)
+.for _user in ${USERS}
+ @if [ ! ${USERS_BLACKLIST:M${_user}} ]; then \
+ ${ECHO_CMD} "@unexec if ${PW} usershow ${_user} >/dev/null 2>&1; then \
+ echo \"==> You should manually remove the \\\"${_user}\\\" user. \"; fi" >> ${TMPPLIST}; \
+ fi
+.endfor
+.endif
+.endif
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+# PR ports/152498
+# XXX Make sure the commands to create group(s)
+# and user(s) are the first in pkg-plist
+.if !target(fix-plist-sequence)
+fix-plist-sequence: ${TMPPLIST}
+.if defined(GROUPS) || defined(USERS)
+ @${ECHO_CMD} "===> Correct pkg-plist sequence to create group(s) and user(s)"
+ @${EGREP} -e '^@exec echo.*Creating users and' -e '^@exec.*${PW}' -e '^@exec ${INSTALL} -d -g' ${TMPPLIST} > ${TMPGUCMD}
+ @${EGREP} -v -e '^@exec echo.*Creating users and' -e '^@exec.*${PW}' -e '^@exec ${INSTALL} -d -g' ${TMPPLIST} >> ${TMPGUCMD}
+ @${MV} -f ${TMPGUCMD} ${TMPPLIST}
+.endif
+.endif
+
+.if !defined(DISABLE_SECURITY_CHECK)
+.if !target(security-check)
+security-check:
+# Scan PLIST for:
+# 1. setugid files
+# 2. accept()/recvfrom() which indicates network listening capability
+# 3. insecure functions (gets/mktemp/tempnam/[XXX])
+# 4. startup scripts, in conjunction with 2.
+# 5. world-writable files/dirs
+#
+ -@${RM} -f ${WRKDIR}/.PLIST.setuid ${WRKDIR}/.PLIST.writable ${WRKDIR}/.PLIST.objdump; \
+ ${AWK} -v prefix='${PREFIX}' ' \
+ match($$0, /^@cwd /) { prefix = substr($$0, RSTART + RLENGTH); if (prefix == "/") prefix=""; next; } \
+ /^@/ { next; } \
+ /^\// { print; next; } \
+ { print prefix "/" $$0; } \
+ ' ${TMPPLIST} > ${WRKDIR}/.PLIST.flattened; \
+ ${TR} '\n' '\0' < ${WRKDIR}/.PLIST.flattened \
+ | ${XARGS} -0 -J % ${FIND} % -prune ! -type l -type f \( -perm -4000 -o -perm -2000 \) \( -perm -0010 -o -perm -0001 \) 2> /dev/null > ${WRKDIR}/.PLIST.setuid; \
+ ${TR} '\n' '\0' < ${WRKDIR}/.PLIST.flattened \
+ | ${XARGS} -0 -J % ${FIND} % -prune -perm -0002 \! -type l 2> /dev/null > ${WRKDIR}/.PLIST.writable; \
+ ${TR} '\n' '\0' < ${WRKDIR}/.PLIST.flattened \
+ | ${XARGS} -0 -J % ${FIND} % -prune ! -type l -type f -print0 2> /dev/null \
+ | ${XARGS} -0 -n 1 ${OBJDUMP} -R 2> /dev/null > ${WRKDIR}/.PLIST.objdump; \
+ if \
+ ! ${AWK} -v audit="$${PORTS_AUDIT}" -f ${PORTSDIR}/Tools/scripts/security-check.awk \
+ ${WRKDIR}/.PLIST.flattened ${WRKDIR}/.PLIST.objdump ${WRKDIR}/.PLIST.setuid ${WRKDIR}/.PLIST.writable; \
+ then \
+ www_site=$$(cd ${.CURDIR} && ${MAKE} www-site); \
+ if [ ! -z "$${www_site}" ]; then \
+ ${ECHO_MSG}; \
+ ${ECHO_MSG} " For more information, and contact details about the security"; \
+ ${ECHO_MSG} " status of this software, see the following webpage: "; \
+ ${ECHO_MSG} "$${www_site}"; \
+ fi; \
+ fi
+.endif
+.else # i.e. defined(DISABLE_SECURITY_CHECK)
+security-check:
+ @${ECHO_MSG} " WARNING: Security check has been disabled."
+.endif # !defined(DISABLE_SECURITY_CHECK)
+
+################################################################
+# Skeleton targets start here
+#
+# You shouldn't have to change these. Either add the pre-* or
+# post-* targets/scripts or redefine the do-* targets. These
+# targets don't do anything other than checking for cookies and
+# call the necessary targets/scripts.
+################################################################
+
+# Please note that the order of the following targets is important, and
+# should not be modified.
+
+.if defined(CHROOTED)
+_CHROOT_SEQ= post-chroot
+.else
+_CHROOT_SEQ=
+.endif
+_SANITY_SEQ= ${_CHROOT_SEQ} pre-everything check-makefile \
+ check-categories check-makevars check-desktop-entries \
+ check-depends identify-install-conflicts check-deprecated \
+ check-vulnerable check-license check-config buildanyway-message \
+ options-message
+
+_PKG_DEP= check-sanity
+_PKG_SEQ= pkg-depends
+_FETCH_DEP= pkg
+_FETCH_SEQ= fetch-depends pre-fetch pre-fetch-script \
+ do-fetch post-fetch post-fetch-script
+_EXTRACT_DEP= fetch
+_EXTRACT_SEQ= check-build-conflicts extract-message checksum extract-depends \
+ pre-extract pre-extract-script do-extract \
+ post-extract post-extract-script
+_PATCH_DEP= extract
+_PATCH_SEQ= ask-license patch-message patch-depends patch-dos2unix pre-patch \
+ pre-patch-script do-patch post-patch post-patch-script
+_CONFIGURE_DEP= patch
+_CONFIGURE_SEQ= build-depends lib-depends configure-message run-autotools-fixup \
+ configure-autotools pre-configure pre-configure-script \
+ run-autotools do-configure post-configure post-configure-script
+_BUILD_DEP= configure
+_BUILD_SEQ= build-message pre-build pre-build-script do-build \
+ post-build post-build-script
+_INSTALL_DEP= build
+_INSTALL_SEQ= install-message check-install-conflicts run-depends lib-depends apply-slist pre-install \
+ pre-install-script generate-plist check-already-installed
+_INSTALL_SUSEQ= check-umask install-mtree pre-su-install \
+ pre-su-install-script create-users-groups do-install \
+ install-desktop-entries install-license install-rc-script \
+ post-install post-install-script add-plist-info \
+ add-plist-docs add-plist-examples add-plist-data \
+ add-plist-post fix-plist-sequence compress-man \
+ install-ldconfig-file fake-pkg security-check
+_PACKAGE_DEP= install
+_PACKAGE_SEQ= package-message pre-package pre-package-script \
+ do-package post-package-script
+
+.if !target(post-chroot)
+post-chroot:
+ @${DO_NADA}
+.endif
+
+.if !target(check-sanity)
+check-sanity: ${_SANITY_SEQ}
+.endif
+
+# XXX MCL might need to move in loop below?
+.if !target(fetch)
+fetch: ${_FETCH_DEP} ${_FETCH_SEQ}
+.endif
+
+.if !target(pkg)
+pkg: ${_PKG_DEP} ${_PKG_SEQ}
+.endif
+
+# Main logic. The loop generates 6 main targets and using cookies
+# ensures that those already completed are skipped.
+
+.for target in extract patch configure build install package
+
+.if !target(${target}) && defined(_OPTIONS_OK)
+${target}: ${${target:U}_COOKIE}
+.elif !target(${target})
+${target}: config-conditional
+ @cd ${.CURDIR} && ${MAKE} CONFIG_DONE_${UNIQUENAME:U}=1 ${${target:U}_COOKIE}
+.elif target(${target}) && defined(IGNORE)
+.endif
+
+.if !exists(${${target:U}_COOKIE})
+
+.if ${UID} != 0 && defined(_${target:U}_SUSEQ) && !defined(INSTALL_AS_USER)
+.if defined(USE_SUBMAKE)
+${${target:U}_COOKIE}: ${_${target:U}_DEP}
+ @cd ${.CURDIR} && ${MAKE} ${_${target:U}_SEQ}
+.else
+${${target:U}_COOKIE}: ${_${target:U}_DEP} ${_${target:U}_SEQ}
+.endif
+ @${ECHO_MSG} "===> Switching to root credentials for '${target}' target"
+ @cd ${.CURDIR} && \
+ ${SU_CMD} "${MAKE} ${_${target:U}_SUSEQ}"
+ @${ECHO_MSG} "===> Returning to user credentials"
+ @${TOUCH} ${TOUCH_FLAGS} ${.TARGET}
+.elif defined(USE_SUBMAKE)
+${${target:U}_COOKIE}: ${_${target:U}_DEP}
+ @cd ${.CURDIR} && \
+ ${MAKE} ${_${target:U}_SEQ} ${_${target:U}_SUSEQ}
+ @${TOUCH} ${TOUCH_FLAGS} ${.TARGET}
+.else
+${${target:U}_COOKIE}: ${_${target:U}_DEP} ${_${target:U}_SEQ} ${_${target:U}_SUSEQ}
+ @${TOUCH} ${TOUCH_FLAGS} ${.TARGET}
+.endif
+
+.else
+${${target:U}_COOKIE}::
+ @if [ -e ${.TARGET} ]; then \
+ ${DO_NADA}; \
+ else \
+ cd ${.CURDIR} && ${MAKE} ${.TARGET}; \
+ fi
+.endif
+
+.endfor
+
+# Enforce order for -jN builds
+
+.ORDER: ${_SANITY_SEQ}
+.ORDER: ${_PKG_DEP} ${_PKG_SEQ}
+.ORDER: ${_FETCH_DEP} ${_FETCH_SEQ}
+.ORDER: ${_EXTRACT_DEP} ${_EXTRACT_SEQ}
+.ORDER: ${_PATCH_DEP} ${_PATCH_SEQ}
+.ORDER: ${_CONFIGURE_DEP} ${_CONFIGURE_SEQ}
+.ORDER: ${_BUILD_DEP} ${_BUILD_SEQ}
+.ORDER: ${_INSTALL_DEP} ${_INSTALL_SEQ}
+.ORDER: ${_PACKAGE_DEP} ${_PACKAGE_SEQ}
+
+extract-message:
+ @${ECHO_MSG} "===> Extracting for ${PKGNAME}"
+patch-message:
+ @${ECHO_MSG} "===> Patching for ${PKGNAME}"
+configure-message:
+ @${ECHO_MSG} "===> Configuring for ${PKGNAME}"
+build-message:
+ @${ECHO_MSG} "===> Building for ${PKGNAME}"
+install-message:
+ @${ECHO_MSG} "===> Installing for ${PKGNAME}"
+package-message:
+ @${ECHO_MSG} "===> Building package for ${PKGNAME}"
+
+# Empty pre-* and post-* targets
+
+.for stage in pre post
+.for name in pkg check-sanity fetch extract patch configure build install package
+
+.if !target(${stage}-${name})
+${stage}-${name}:
+ @${DO_NADA}
+.endif
+
+.if !target(${stage}-${name}-script)
+${stage}-${name}-script:
+ @if [ -f ${SCRIPTDIR}/${.TARGET:S/-script$//} ]; then \
+ cd ${.CURDIR} && ${SETENV} ${SCRIPTS_ENV} ${SH} \
+ ${SCRIPTDIR}/${.TARGET:S/-script$//}; \
+ fi
+.endif
+
+.endfor
+.endfor
+
+# Special cases for su
+.if !target(pre-su-install)
+pre-su-install:
+ @${DO_NADA}
+.endif
+
+.if !target(pre-su-install-script)
+pre-su-install-script:
+ @${DO_NADA}
+.endif
+
+
+.if !target(pretty-print-www-site)
+pretty-print-www-site:
+ @www_site=$$(cd ${.CURDIR} && ${MAKE} www-site); \
+ if [ -n "$${www_site}" ]; then \
+ ${ECHO_MSG} -n " and/or visit the "; \
+ ${ECHO_MSG} -n "<a href=\"$${www_site}\">web site</a>"; \
+ ${ECHO_MSG} " for futher informations"; \
+ fi
+.endif
+
+################################################################
+# Some more targets supplied for users' convenience
+################################################################
+
+# Checkpatch
+#
+# Special target to verify patches
+
+.if !target(checkpatch)
+checkpatch:
+ @cd ${.CURDIR} && ${MAKE} PATCH_CHECK_ONLY=yes ${_PATCH_DEP} ${_PATCH_SEQ}
+.endif
+
+# Reinstall
+#
+# Special target to re-run install
+
+.if !target(reinstall)
+reinstall:
+ @${RM} -f ${INSTALL_COOKIE} ${PACKAGE_COOKIE}
+ @cd ${.CURDIR} && DEPENDS_TARGET="${DEPENDS_TARGET}" ${MAKE} -DFORCE_PKG_REGISTER install
+.endif
+
+# Deinstall
+#
+# Special target to remove installation
+
+.if !target(deinstall)
+deinstall:
+.if ${UID} != 0 && !defined(INSTALL_AS_USER)
+ @${ECHO_MSG} "===> Switching to root credentials for '${.TARGET}' target"
+ @cd ${.CURDIR} && \
+ ${SU_CMD} "${MAKE} ${.TARGET}"
+ @${ECHO_MSG} "===> Returning to user credentials"
+.else
+ @${ECHO_MSG} "===> Deinstalling for ${PKGORIGIN}"
+ @found_names=`${PKG_INFO} -q -O ${PKGORIGIN}`; \
+ for p in $${found_names}; do \
+ check_name=`${ECHO_CMD} $${p} | ${SED} -e 's/-[^-]*$$//'`; \
+ if [ "$${check_name}" = "${PKGBASE}" ]; then \
+ prfx=`${PKG_INFO} -q -p $${p} 2> /dev/null | ${SED} -ne '1s|^@cwd ||p'`; \
+ if [ "x${PREFIX}" = "x$${prfx}" ]; then \
+ ${ECHO_MSG} "===> Deinstalling $${p}"; \
+ ${PKG_DELETE} -f $${p}; \
+ else \
+ ${ECHO_MSG} "===> $${p} has a different PREFIX: $${prfx}, skipping"; \
+ fi; \
+ fi; \
+ done; \
+ if [ -z "$${found_names}" ]; then \
+ ${ECHO_MSG} "===> ${PKGBASE} not installed, skipping"; \
+ fi
+ @${RM} -f ${INSTALL_COOKIE} ${PACKAGE_COOKIE}
+.endif
+.endif
+
+# Deinstall-all
+#
+# Special target to remove installation of all ports of the same origin
+
+.if !target(deinstall-all)
+deinstall-all:
+.if ${UID} != 0 && !defined(INSTALL_AS_USER)
+ @${ECHO_MSG} "===> Switching to root credentials for '${.TARGET}' target"
+ @cd ${.CURDIR} && \
+ ${SU_CMD} "${MAKE} ${.TARGET}"
+ @${ECHO_MSG} "===> Returning to user credentials"
+.else
+ @${ECHO_MSG} "===> Deinstalling for ${PKGORIGIN}"
+ @deinstall_names=`${PKG_INFO} -q -O ${PKGORIGIN}`; \
+ for oldpkgorigin in $$(${GREP} "|${PKGORIGIN}|" ${PORTSDIR}/MOVED | ${CUT} -f 1 -d '|' | ${SORT} -u); do \
+ deinstall_names="$${deinstall_names} $$(${PKG_INFO} -q -O $${oldpkgorigin})"; \
+ done; \
+ if [ -n "$${deinstall_names}" ]; then \
+ for d in $${deinstall_names}; do \
+ ${ECHO_MSG} "===> Deinstalling $${d}"; \
+ ${PKG_DELETE} -f $${d}; \
+ done; \
+ else \
+ ${ECHO_MSG} "===> ${PKGORIGIN} not installed, skipping"; \
+ fi; \
+ ${RM} -f ${INSTALL_COOKIE} ${PACKAGE_COOKIE}
+.endif
+.endif
+
+# Cleaning up
+
+.if !target(do-clean)
+do-clean:
+ @if [ -d ${WRKDIR} ]; then \
+ if [ -w ${WRKDIR} ]; then \
+ ${RM} -rf ${WRKDIR}; \
+ else \
+ ${ECHO_MSG} "===> ${WRKDIR} not writable, skipping"; \
+ fi; \
+ fi
+.endif
+
+.if !target(clean)
+clean:
+.if !defined(NOCLEANDEPENDS)
+ @cd ${.CURDIR} && ${MAKE} limited-clean-depends
+.endif
+ @${ECHO_MSG} "===> Cleaning for ${PKGNAME}"
+.if target(pre-clean)
+ @cd ${.CURDIR} && ${MAKE} pre-clean
+.endif
+ @cd ${.CURDIR} && ${MAKE} do-clean
+.if target(post-clean)
+ @cd ${.CURDIR} && ${MAKE} post-clean
+.endif
+.endif
+
+.if !target(pre-distclean)
+pre-distclean:
+ @${DO_NADA}
+.endif
+
+.if !target(distclean)
+distclean: pre-distclean clean
+ @cd ${.CURDIR} && ${MAKE} delete-distfiles RESTRICTED_FILES="${_DISTFILES} ${_PATCHFILES}"
+.endif
+
+.if !target(delete-distfiles)
+delete-distfiles:
+ @${ECHO_MSG} "===> Deleting distfiles for ${PKGNAME}"
+ @(if [ "X${RESTRICTED_FILES}" != "X" -a -d ${_DISTDIR} ]; then \
+ cd ${_DISTDIR}; \
+ for file in ${RESTRICTED_FILES}; do \
+ ${RM} -f $${file}; \
+ dir=$${file%/*}; \
+ if [ "$${dir}" != "$${file}" ]; then \
+ ${RMDIR} -p $${dir} >/dev/null 2>&1 || :; \
+ fi; \
+ done; \
+ fi)
+.if defined(DIST_SUBDIR)
+ -@${RMDIR} ${_DISTDIR} >/dev/null 2>&1 || ${TRUE}
+.endif
+.endif
+
+.if !target(delete-distfiles-list)
+delete-distfiles-list:
+ @${ECHO_CMD} "# ${PKGNAME}"
+ @if [ "X${RESTRICTED_FILES}" != "X" ]; then \
+ for file in ${RESTRICTED_FILES}; do \
+ ${ECHO_CMD} "[ -f ${_DISTDIR}/$$file ] && (${ECHO_CMD} deleting ${_DISTDIR}/$$file; ${RM} -f ${_DISTDIR}/$$file)"; \
+ dir=$${file%/*}; \
+ if [ "$${dir}" != "$${file}" ]; then \
+ ${ECHO_CMD} "(cd ${_DISTDIR} && ${RMDIR} -p $${dir} 2>/dev/null)"; \
+ fi; \
+ done; \
+ fi
+.if defined(DIST_SUBDIR)
+ @${ECHO_CMD} "${RMDIR} ${_DISTDIR} 2>/dev/null || ${TRUE}"
+.endif
+.endif
+
+# Prints out a list of files to fetch (useful to do a batch fetch)
+
+.if !target(fetch-list)
+fetch-list:
+ @${MKDIR} ${_DISTDIR}
+ @(cd ${_DISTDIR}; \
+ ${_MASTER_SITES_ENV} ; \
+ for _file in ${DISTFILES}; do \
+ file=`${ECHO_CMD} $$_file | ${SED} -E -e 's/:[^:]+$$//'` ; \
+ select=`${ECHO_CMD} $${_file#$${file}} | ${SED} -e 's/^://' -e 's/,/ /g'` ; \
+ if [ ! -f $$file -a ! -f $${file##*/} ]; then \
+ if [ ! -z "$$select" ] ; then \
+ __MASTER_SITES_TMP= ; \
+ for group in $$select; do \
+ if [ ! -z \$${_MASTER_SITES_$${group}} ] ; then \
+ eval ___MASTER_SITES_TMP=\$${_MASTER_SITES_$${group}} ; \
+ __MASTER_SITES_TMP="$${__MASTER_SITES_TMP} $${___MASTER_SITES_TMP}" ; \
+ fi; \
+ done; \
+ ___MASTER_SITES_TMP= ; \
+ SORTED_MASTER_SITES_CMD_TMP="${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} $${__MASTER_SITES_TMP} | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}" ; \
+ else \
+ SORTED_MASTER_SITES_CMD_TMP="${SORTED_MASTER_SITES_DEFAULT_CMD}" ; \
+ fi; \
+ for site in `eval $$SORTED_MASTER_SITES_CMD_TMP ${_RANDOMIZE_SITES}`; do \
+ if [ ! -z "`${ECHO_CMD} ${NOFETCHFILES} | ${GREP} -w $${file}`" ]; then \
+ if [ -z "`${ECHO_CMD} ${MASTER_SITE_OVERRIDE} | ${GREP} -w $${site}`" ]; then \
+ continue; \
+ fi; \
+ fi; \
+ DIR=${DIST_SUBDIR};\
+ CKSIZE=`alg=SIZE; ${DISTINFO_DATA}`; \
+ case $${file} in \
+ */*) args="-o $${file} $${site}$${file}";; \
+ *) args=$${site}$${file};; \
+ esac; \
+ ${ECHO_CMD} -n ${SETENV} ${FETCH_ENV} ${FETCH_CMD} ${FETCH_BEFORE_ARGS} $${args} "${FETCH_AFTER_ARGS}" '|| ' ; \
+ done; \
+ ${ECHO_CMD} "${ECHO_CMD} $${file} not fetched" ; \
+ fi; \
+ done)
+.if defined(PATCHFILES)
+ @(cd ${_DISTDIR}; \
+ ${_PATCH_SITES_ENV} ; \
+ for _file in ${PATCHFILES}; do \
+ file=`${ECHO_CMD} $$_file | ${SED} -E -e 's/:[^:]+$$//'` ; \
+ select=`${ECHO_CMD} $${_file#$${file}} | ${SED} -e 's/^://' -e 's/,/ /g'` ; \
+ if [ ! -f $$file -a ! -f $${file##*/} ]; then \
+ if [ ! -z "$$select" ] ; then \
+ __PATCH_SITES_TMP= ; \
+ for group in $$select; do \
+ if [ ! -z \$${_PATCH_SITES_$${group}} ] ; then \
+ eval ___PATCH_SITES_TMP=\$${_PATCH_SITES_$${group}} ; \
+ __PATCH_SITES_TMP="$${__PATCH_SITES_TMP} $${___PATCH_SITES_TMP}" ; \
+ fi; \
+ done; \
+ ___PATCH_SITES_TMP= ; \
+ SORTED_PATCH_SITES_CMD_TMP="${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} $${__PATCH_SITES_TMP} | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}" ; \
+ else \
+ SORTED_PATCH_SITES_CMD_TMP="${SORTED_PATCH_SITES_DEFAULT_CMD}" ; \
+ fi; \
+ for site in `eval $$SORTED_PATCH_SITES_CMD_TMP ${_RANDOMIZE_SITES}`; do \
+ CKSIZE=`alg=SIZE; ${DISTINFO_DATA}`; \
+ case $${file} in \
+ */*) args="-o $${file} $${site}$${file}";; \
+ *) args=$${site}$${file};; \
+ esac; \
+ ${ECHO_CMD} -n ${SETENV} ${FETCH_ENV} ${FETCH_CMD} ${FETCH_BEFORE_ARGS} $${args} "${FETCH_AFTER_ARGS}" '|| ' ; \
+ done; \
+ ${ECHO_CMD} "${ECHO_CMD} $${file} not fetched" ; \
+ fi; \
+ done)
+.endif
+.endif
+
+.if !target(fetch-url-list-int)
+fetch-url-list-int:
+ @${MKDIR} ${_DISTDIR}
+ @(cd ${_DISTDIR}; \
+ ${_MASTER_SITES_ENV}; \
+ for _file in ${DISTFILES}; do \
+ file=`${ECHO_CMD} $$_file | ${SED} -E -e 's/:[^:]+$$//'` ; \
+ fileptn=`${ECHO_CMD} $$file | ${SED} 's|/|\\\\/|g;s/\./\\\\./g;s/\+/\\\\+/g;s/\?/\\\\?/g'` ; \
+ select=`${ECHO_CMD} $${_file#$${file}} | ${SED} -e 's/^://' -e 's/,/ /g'` ; \
+ if [ ! -z "${LISTALL}" -o ! -f $$file -a ! -f $${file##*/} ]; then \
+ if [ ! -z "$$select" ] ; then \
+ __MASTER_SITES_TMP= ; \
+ for group in $$select; do \
+ if [ ! -z \$${_MASTER_SITES_$${group}} ] ; then \
+ eval ___MASTER_SITES_TMP=\$${_MASTER_SITES_$${group}} ; \
+ __MASTER_SITES_TMP="$${__MASTER_SITES_TMP} $${___MASTER_SITES_TMP}" ; \
+ fi \
+ done; \
+ ___MASTER_SITES_TMP= ; \
+ SORTED_MASTER_SITES_CMD_TMP="${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} $${__MASTER_SITES_TMP} | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}" ; \
+ else \
+ SORTED_MASTER_SITES_CMD_TMP="${SORTED_MASTER_SITES_DEFAULT_CMD}" ; \
+ fi ; \
+ for site in `eval $$SORTED_MASTER_SITES_CMD_TMP ${_RANDOMIZE_SITES}`; do \
+ DIR=${DIST_SUBDIR:S/\//\\\\\//g:S/./\\\\./g:S/+/\\\\+/g:S/?/\\\\?/g}; \
+ CKSIZE=`${AWK} "/^SIZE \($${DIR:+$$DIR\/}$$fileptn\)/"'{print $$4}' ${DISTINFO_FILE}`; \
+ case $${file} in \
+ */*) args="-o $${file} $${site}$${file}";; \
+ *) args=$${site}$${file};; \
+ esac; \
+ ${ECHO_CMD} $${args} ; \
+ done; \
+ fi \
+ done)
+.if defined(PATCHFILES)
+ @(cd ${_DISTDIR}; \
+ ${_PATCH_SITES_ENV} ; \
+ for _file in ${PATCHFILES}; do \
+ file=`${ECHO_CMD} $$_file | ${SED} -E -e 's/:[^:]+$$//'` ; \
+ fileptn=`${ECHO_CMD} $$file | ${SED} 's|/|\\\\/|g;s/\./\\\\./g;s/\+/\\\\+/g;s/\?/\\\\?/g'` ; \
+ select=`${ECHO_CMD} $${_file#$${file}} | ${SED} -e 's/^://' -e 's/,/ /g'` ; \
+ if [ ! -z "${LISTALL}" -o ! -f $$file -a ! -f $${file##*/} ]; then \
+ if [ ! -z "$$select" ] ; then \
+ __PATCH_SITES_TMP= ; \
+ for group in $$select; do \
+ if [ ! -z \$${_PATCH_SITES_$${group}} ] ; then \
+ eval ___PATCH_SITES_TMP=\$${_PATCH_SITES_$${group}} ; \
+ __PATCH_SITES_TMP="$${__PATCH_SITES_TMP} $${___PATCH_SITES_TMP}" ; \
+ fi \
+ done; \
+ ___PATCH_SITES_TMP= ; \
+ SORTED_PATCH_SITES_CMD_TMP="${ECHO_CMD} ${_MASTER_SITE_OVERRIDE} `${ECHO_CMD} $${__PATCH_SITES_TMP} | ${AWK} '${MASTER_SORT_AWK:S|\\|\\\\|g}'` ${_MASTER_SITE_BACKUP}" ; \
+ else \
+ SORTED_PATCH_SITES_CMD_TMP="${SORTED_PATCH_SITES_DEFAULT_CMD}" ; \
+ fi ; \
+ for site in `eval $$SORTED_PATCH_SITES_CMD_TMP ${_RANDOMIZE_SITES}`; do \
+ DIR=${DIST_SUBDIR:S/\//\\\\\//g:S/./\\\\./g:S/+/\\\\+/g:S/?/\\\\?/g}; \
+ CKSIZE=`${AWK} "/^SIZE \($${DIR:+$$DIR\/}$$fileptn\)/"'{print $$4}' ${DISTINFO_FILE}`; \
+ case $${file} in \
+ */*) args="-o $${file} $${site}$${file}";; \
+ *) args=$${site}$${file};; \
+ esac; \
+ ${ECHO_CMD} $${args} ; \
+ done; \
+ fi \
+ done)
+.endif
+.endif
+
+.if !target(fetch-urlall-list)
+fetch-urlall-list:
+ @cd ${.CURDIR} && LISTALL=yes ${MAKE} fetch-url-list-int
+.endif
+
+.if !target(fetch-url-list)
+fetch-url-list:
+ @cd ${.CURDIR} && ${MAKE} fetch-url-list-int
+.endif
+
+# Generates patches.
+
+update-patches:
+ @toedit=`PATCH_WRKSRC=${PATCH_WRKSRC} \
+ PATCHDIR=${PATCHDIR} \
+ PATCH_LIST=${PATCHDIR}/patch-* \
+ DIFF_ARGS=${DIFF_ARGS} \
+ DISTORIG=${DISTORIG} \
+ ${SH} ${PORTSDIR}/Tools/scripts/update-patches`; \
+ case $$toedit in "");; \
+ *) ${ECHO_CMD} -n 'edit patches: '; read i; \
+ cd ${PATCHDIR} && $${VISUAL:-$${EDIT:-/usr/bin/vi}} $$toedit;; esac
+
+# Checksumming utilities
+
+check-checksum-algorithms:
+ @ \
+ ${checksum_init} \
+ \
+ for alg in ${CHECKSUM_ALGORITHMS:U}; do \
+ eval alg_executable=\$$$$alg; \
+ if [ -z "$$alg_executable" ]; then \
+ ${ECHO_MSG} "Checksum algorithm $$alg: Couldn't find the executable."; \
+ ${ECHO_MSG} "Set $$alg=/path/to/$$alg in /etc/make.conf and try again."; \
+ exit 1; \
+ fi; \
+ done; \
+
+checksum_init=\
+ SHA256=${SHA256};
+
+.if !target(makesum)
+makesum: check-checksum-algorithms
+ @cd ${.CURDIR} && ${MAKE} fetch NO_CHECKSUM=yes \
+ DISABLE_SIZE=yes
+ @if [ -f ${DISTINFO_FILE} ]; then ${CAT} /dev/null > ${DISTINFO_FILE}; fi
+ @( \
+ cd ${DISTDIR}; \
+ \
+ ${checksum_init} \
+ \
+ for file in ${_CKSUMFILES}; do \
+ for alg in ${CHECKSUM_ALGORITHMS:U}; do \
+ eval alg_executable=\$$$$alg; \
+ \
+ if [ $$alg_executable != "NO" ]; then \
+ $$alg_executable $$file >> ${DISTINFO_FILE}; \
+ fi; \
+ done; \
+ ${ECHO_CMD} "SIZE ($$file) = "`${LS} -ALln $$file | ${AWK} '{print $$5}'` >> ${DISTINFO_FILE}; \
+ done \
+ )
+ @for file in ${_IGNOREFILES}; do \
+ for alg in ${CHECKSUM_ALGORITHMS:U}; do \
+ ${ECHO_CMD} "$$alg ($$file) = IGNORE" >> ${DISTINFO_FILE}; \
+ done; \
+ done
+.endif
+
+.if !target(checksum)
+checksum: fetch check-checksum-algorithms
+ @${checksum_init} \
+ if [ -f ${DISTINFO_FILE} ]; then \
+ cd ${DISTDIR}; OK="";\
+ for file in ${_CKSUMFILES}; do \
+ ignored="true"; \
+ _file=$${file#${DIST_SUBDIR}/*}; \
+ for alg in ${CHECKSUM_ALGORITHMS:U}; do \
+ ignore="false"; \
+ eval alg_executable=\$$$$alg; \
+ \
+ if [ $$alg_executable != "NO" ]; then \
+ MKSUM=`$$alg_executable < $$file`; \
+ CKSUM=`file=$$_file; ${DISTINFO_DATA}`; \
+ else \
+ ignore="true"; \
+ fi; \
+ \
+ if [ $$ignore = "false" -a -z "$$CKSUM" ]; then \
+ ${ECHO_MSG} "=> No $$alg checksum recorded for $$file."; \
+ ignore="true"; \
+ fi; \
+ \
+ if [ "$$CKSUM" = "IGNORE" ]; then \
+ ${ECHO_MSG} "=> $$alg Checksum for $$file is set to IGNORE in distinfo file even though"; \
+ ${ECHO_MSG} " the file is not in the "'$$'"{IGNOREFILES} list."; \
+ ignore="true"; \
+ OK=${FALSE}; \
+ fi; \
+ \
+ if [ $$ignore = "false" ]; then \
+ match="false"; \
+ for chksum in $$CKSUM; do \
+ if [ "$$chksum" = "$$MKSUM" ]; then \
+ match="true"; \
+ break; \
+ fi; \
+ done; \
+ if [ $$match = "true" ]; then \
+ ${ECHO_MSG} "=> $$alg Checksum OK for $$file."; \
+ ignored="false"; \
+ else \
+ ${ECHO_MSG} "=> $$alg Checksum mismatch for $$file."; \
+ refetchlist="$$refetchlist$$file "; \
+ OK="$${OK:-retry}"; \
+ ignored="false"; \
+ fi; \
+ fi; \
+ done; \
+ \
+ if [ $$ignored = "true" ]; then \
+ ${ECHO_MSG} "=> No suitable checksum found for $$file."; \
+ OK="${FALSE}"; \
+ fi; \
+ \
+ done; \
+ \
+ for file in ${_IGNOREFILES}; do \
+ _file=$${file#${DIST_SUBDIR}/*}; \
+ ignored="true"; \
+ alreadymatched="false"; \
+ for alg in ${CHECKSUM_ALGORITHMS:U}; do \
+ ignore="false"; \
+ eval alg_executable=\$$$$alg; \
+ \
+ if [ $$alg_executable != "NO" ]; then \
+ CKSUM=`file=$$_file; ${DISTINFO_DATA}`; \
+ else \
+ ignore="true"; \
+ fi; \
+ \
+ if [ $$ignore = "false" ]; then \
+ if [ -z "$$CKSUM" ]; then \
+ ${ECHO_MSG} "=> No $$alg checksum for $$file recorded (expected IGNORE)"; \
+ OK="$$alreadymatched"; \
+ elif [ $$CKSUM != "IGNORE" ]; then \
+ ${ECHO_MSG} "=> $$alg Checksum for $$file is not set to IGNORE in distinfo file even though"; \
+ ${ECHO_MSG} " the file is in the "'$$'"{IGNOREFILES} list."; \
+ OK="false"; \
+ else \
+ ignored="false"; \
+ alreadymatched="true"; \
+ fi; \
+ fi; \
+ done; \
+ \
+ if ( [ $$ignored = "true" ]) ; then \
+ ${ECHO_MSG} "=> No suitable checksum found for $$file."; \
+ OK="false"; \
+ fi; \
+ \
+ done; \
+ \
+ if [ "$${OK:=true}" = "retry" ] && [ ${FETCH_REGET} -gt 0 ]; then \
+ ${ECHO_MSG} "===> Refetch for ${FETCH_REGET} more times files: $$refetchlist"; \
+ if ( cd ${.CURDIR} && \
+ ${MAKE} ${.MAKEFLAGS} FORCE_FETCH="$$refetchlist" FETCH_REGET="`${EXPR} ${FETCH_REGET} - 1`" fetch); then \
+ if ( cd ${.CURDIR} && \
+ ${MAKE} ${.MAKEFLAGS} FETCH_REGET="`${EXPR} ${FETCH_REGET} - 1`" checksum ); then \
+ OK="true"; \
+ fi; \
+ fi; \
+ fi; \
+ \
+ if [ "$$OK" != "true" -a ${FETCH_REGET} -eq 0 ]; then \
+ ${ECHO_MSG} "===> Giving up on fetching files: $$refetchlist"; \
+ ${ECHO_MSG} "Make sure the Makefile and distinfo file (${DISTINFO_FILE})"; \
+ ${ECHO_MSG} "are up to date. If you are absolutely sure you want to override this"; \
+ ${ECHO_MSG} "check, type \"make NO_CHECKSUM=yes [other args]\"."; \
+ exit 1; \
+ fi; \
+ if [ "$$OK" != "true" ]; then \
+ exit 1; \
+ fi; \
+ elif [ -n "${_CKSUMFILES:M*}" ]; then \
+ ${ECHO_MSG} "=> No checksum file (${DISTINFO_FILE})."; \
+ fi
+.endif
+
+################################################################
+# The special package-building targets
+# You probably won't need to touch these
+################################################################
+
+# Nobody should want to override this unless PKGNAME is simply bogus.
+
+.if !target(package-name)
+package-name:
+ @${ECHO_CMD} ${PKGNAME}
+.endif
+
+# Build a package but don't check the package cookie
+
+.if !target(repackage)
+repackage: pre-repackage package
+
+pre-repackage:
+ @${RM} -f ${PACKAGE_COOKIE}
+.endif
+
+# Build a package but don't check the cookie for installation, also don't
+# install package cookie
+
+.if !target(package-noinstall)
+package-noinstall:
+ @${MKDIR} ${WRKDIR}
+ @cd ${.CURDIR} && ${MAKE} pre-package \
+ pre-package-script do-package post-package-script
+ @${RM} -f ${TMPPLIST}
+ -@${RMDIR} ${WRKDIR}
+.endif
+
+################################################################
+# Dependency checking
+################################################################
+
+.if !target(depends)
+depends: pkg-depends extract-depends patch-depends lib-depends fetch-depends build-depends run-depends
+
+.if defined(ALWAYS_BUILD_DEPENDS)
+_DEPEND_ALWAYS= 1
+.else
+_DEPEND_ALWAYS= 0
+.endif
+
+_INSTALL_DEPENDS= \
+ if [ X${USE_PACKAGE_DEPENDS} != "X" ]; then \
+ subpkgfile=`(cd $$dir; ${MAKE} $$depends_args -V PKGFILE)`; \
+ subpkgname=$${subpkgfile%-*} ; \
+ subpkgname=$${subpkgname\#\#*/} ; \
+ if [ -r "$${subpkgfile}" -a "$$target" = "${DEPENDS_TARGET}" ]; then \
+ ${ECHO_MSG} "===> Installing existing package $${subpkgfile}"; \
+ if [ -n "${WITH_PKGNG}" -a $${subpkgname} = "pkg" ]; then \
+ [ -d ${WRKDIR} ] || ${MKDIR} ${WRKDIR} ; \
+ ${TAR} xf $${subpkgfile} -C ${WRKDIR} -s ",/.*/,,g" "*/pkg-static" ; \
+ ${WRKDIR}/pkg-static add $${subpkgfile}; \
+ ${RM} -f ${WRKDIR}/pkg-static; \
+ else \
+ ${PKG_ADD} $${subpkgfile}; \
+ fi; \
+ else \
+ (cd $$dir; ${MAKE} -DINSTALLS_DEPENDS $$target $$depends_args) ; \
+ fi; \
+ else \
+ (cd $$dir; ${MAKE} -DINSTALLS_DEPENDS $$target $$depends_args) ; \
+ fi; \
+ ${ECHO_MSG} "===> Returning to build of ${PKGNAME}";
+
+.for deptype in PKG EXTRACT PATCH FETCH BUILD RUN
+${deptype:L}-depends:
+.if defined(${deptype}_DEPENDS)
+.if !defined(NO_DEPENDS)
+ @for i in `${ECHO_CMD} "${${deptype}_DEPENDS}"`; do \
+ prog=$${i%%:*}; \
+ if [ -z "$$prog" ]; then \
+ ${ECHO_MSG} "Error: there is an empty port dependency in ${deptype}_DEPENDS."; \
+ break; \
+ fi; \
+ dir=`${ECHO_CMD} $$i | ${SED} -e 's/[^:]*://'`; \
+ if ${EXPR} "$$dir" : '.*:' > /dev/null; then \
+ target=$${dir##*:}; \
+ dir=$${dir%%:*}; \
+ if [ X${DEPENDS_PRECLEAN} != "X" ]; then \
+ target="clean $$target"; \
+ depends_args="$$depends_args NOCLEANDEPENDS=yes"; \
+ fi; \
+ if [ X${DEPENDS_CLEAN} != "X" ]; then \
+ target="$$target clean"; \
+ depends_args="$$depends_args NOCLEANDEPENDS=yes"; \
+ fi; \
+ else \
+ target="${DEPENDS_TARGET}"; \
+ depends_args="${DEPENDS_ARGS}"; \
+ fi; \
+ if ${EXPR} "$$prog" : \\/ >/dev/null; then \
+ if [ -e "$$prog" ]; then \
+ if [ "$$prog" = "${NONEXISTENT}" ]; then \
+ ${ECHO_MSG} "Error: ${NONEXISTENT} exists. Please remove it, and restart the build."; \
+ ${FALSE}; \
+ else \
+ ${ECHO_MSG} "===> ${PKGNAME} depends on file: $$prog - found"; \
+ if [ ${_DEPEND_ALWAYS} = 1 ]; then \
+ ${ECHO_MSG} " (but building it anyway)"; \
+ notfound=1; \
+ else \
+ notfound=0; \
+ fi; \
+ fi; \
+ else \
+ ${ECHO_MSG} "===> ${PKGNAME} depends on file: $$prog - not found"; \
+ notfound=1; \
+ fi; \
+ else \
+ case $${prog} in \
+ *\>*|*\<*|*=*) pkg=yes;; \
+ *) pkg="";; \
+ esac; \
+ if [ "$$pkg" != "" ]; then \
+ if ${PKG_INFO} "$$prog" > /dev/null 2>&1 ; then \
+ ${ECHO_MSG} "===> ${PKGNAME} depends on package: $$prog - found"; \
+ if [ ${_DEPEND_ALWAYS} = 1 ]; then \
+ ${ECHO_MSG} " (but building it anyway)"; \
+ notfound=1; \
+ else \
+ notfound=0; \
+ fi; \
+ else \
+ ${ECHO_MSG} "===> ${PKGNAME} depends on package: $$prog - not found"; \
+ notfound=1; \
+ fi; \
+ if [ $$notfound != 0 ]; then \
+ inverse_dep=`${ECHO_CMD} $$prog | ${SED} \
+ -e 's/<=/=gt=/; s/</=ge=/; s/>=/=lt=/; s/>/=le=/' \
+ -e 's/=gt=/>/; s/=ge=/>=/; s/=lt=/</; s/=le=/<=/'`; \
+ pkg_info=`${PKG_INFO} -E "$$inverse_dep" || ${TRUE}`; \
+ if [ "$$pkg_info" != "" ]; then \
+ ${ECHO_MSG} "===> Found $$pkg_info, but you need to upgrade to $$prog."; \
+ exit 1; \
+ fi; \
+ fi; \
+ elif ${WHICH} "$$prog" > /dev/null 2>&1 ; then \
+ ${ECHO_MSG} "===> ${PKGNAME} depends on executable: $$prog - found"; \
+ if [ ${_DEPEND_ALWAYS} = 1 ]; then \
+ ${ECHO_MSG} " (but building it anyway)"; \
+ notfound=1; \
+ else \
+ notfound=0; \
+ fi; \
+ else \
+ ${ECHO_MSG} "===> ${PKGNAME} depends on executable: $$prog - not found"; \
+ notfound=1; \
+ fi; \
+ fi; \
+ if [ $$notfound != 0 ]; then \
+ ${ECHO_MSG} "===> Verifying $$target for $$prog in $$dir"; \
+ if [ ! -d "$$dir" ]; then \
+ ${ECHO_MSG} " => No directory for $$prog. Skipping.."; \
+ else \
+ ${_INSTALL_DEPENDS} \
+ fi; \
+ fi; \
+ done
+.endif
+.else
+ @${DO_NADA}
+.endif
+.endfor
+
+lib-depends:
+.if defined(LIB_DEPENDS) && !defined(NO_DEPENDS)
+ @for i in ${LIB_DEPENDS}; do \
+ lib=$${i%%:*}; \
+ pattern="`${ECHO_CMD} $$lib | ${SED} -E -e 's/\./\\\\./g' -e 's/(\\\\)?\+/\\\\+/g'`"\
+ dir=$${i#*:}; \
+ target=$${i##*:}; \
+ if ${TEST} $$dir = $$target; then \
+ target="${DEPENDS_TARGET}"; \
+ depends_args="${DEPENDS_ARGS}"; \
+ else \
+ dir=$${dir%%:*}; \
+ fi; \
+ ${ECHO_MSG} -n "===> ${PKGNAME} depends on shared library: $$lib"; \
+ if ${LDCONFIG} ${_LDCONFIG_FLAGS} -r | ${GREP} -vwF -e "${PKGCOMPATDIR}" | ${GREP} -qwE -e "-l$$pattern"; then \
+ ${ECHO_MSG} " - found"; \
+ if [ ${_DEPEND_ALWAYS} = 1 ]; then \
+ ${ECHO_MSG} " (but building it anyway)"; \
+ notfound=1; \
+ else \
+ notfound=0; \
+ fi; \
+ else \
+ ${ECHO_MSG} " - not found"; \
+ notfound=1; \
+ fi; \
+ if [ $$notfound != 0 ]; then \
+ ${ECHO_MSG} "===> Verifying $$target for $$lib in $$dir"; \
+ if [ ! -d "$$dir" ]; then \
+ ${ECHO_MSG} " => No directory for $$lib. Skipping.."; \
+ else \
+ ${_INSTALL_DEPENDS} \
+ if ! ${LDCONFIG} ${_LDCONFIG_FLAGS} -r | ${GREP} -vwF -e "${PKGCOMPATDIR}" | ${GREP} -qwE -e "-l$$pattern"; then \
+ ${ECHO_MSG} "Error: shared library \"$$lib\" does not exist"; \
+ ${FALSE}; \
+ fi; \
+ fi; \
+ fi; \
+ done
+.endif
+
+.endif
+
+# Dependency lists: both build and runtime, recursive. Print out directory names.
+
+_UNIFIED_DEPENDS=${PKG_DEPENDS} ${EXTRACT_DEPENDS} ${PATCH_DEPENDS} ${FETCH_DEPENDS} ${BUILD_DEPENDS} ${LIB_DEPENDS} ${RUN_DEPENDS}
+_DEPEND_DIRS= ${_UNIFIED_DEPENDS:C,^[^:]*:([^:]*).*$,\1,}
+
+all-depends-list:
+ @${ALL-DEPENDS-LIST}
+
+ALL-DEPENDS-LIST= \
+ L="${_DEPEND_DIRS}"; \
+ checked=""; \
+ while [ -n "$$L" ]; do \
+ l=""; \
+ for d in $$L; do \
+ case $$checked in \
+ $$d\ *|*\ $$d\ *|*\ $$d) \
+ continue;; \
+ esac; \
+ checked="$$checked $$d"; \
+ if [ ! -d $$d ]; then \
+ ${ECHO_MSG} "${PKGNAME}: \"$$d\" non-existent -- dependency list incomplete" >&2; \
+ continue; \
+ fi; \
+ ${ECHO_CMD} $$d; \
+ if ! children=$$(cd $$d && ${MAKE} -V _DEPEND_DIRS); then\
+ ${ECHO_MSG} "${PKGNAME}: \"$$d\" erroneous -- dependency list incomplete" >&2; \
+ continue; \
+ fi; \
+ for child in $$children; do \
+ case "$$checked $$l" in \
+ $$child\ *|*\ $$child\ *|*\ $$child) \
+ continue;; \
+ esac; \
+ l="$$l $$child"; \
+ done; \
+ done; \
+ L=$$l; \
+ done
+
+CLEAN-DEPENDS-FULL= \
+ L="${_DEPEND_DIRS}"; \
+ checked=""; \
+ while [ -n "$$L" ]; do \
+ l=""; \
+ for d in $$L; do \
+ case $$checked in \
+ $$d\ *|*\ $$d\ *|*\ $$d) \
+ continue;; \
+ esac; \
+ checked="$$checked $$d"; \
+ if [ ! -d $$d ]; then \
+ ${ECHO_MSG} "${PKGNAME}: \"$$d\" non-existent -- dependency list incomplete" >&2; \
+ continue; \
+ fi; \
+ if ! children=$$(cd $$d && ${MAKE} -V WRKDIR -V _DEPEND_DIRS); then \
+ ${ECHO_MSG} "${PKGNAME}: \"$$d\" erroneous -- dependency list incomplete" >&2; \
+ continue; \
+ fi; \
+ state=0; \
+ for child in $$children; do \
+ case $$state in \
+ 0) \
+ if [ -d $$child ]; then \
+ ${ECHO_CMD} $$d; \
+ fi; \
+ state=1;; \
+ 1) \
+ case "$$checked $$l" in \
+ $$child\ *|*\ $$child\ *|*\ $$child) \
+ continue;; \
+ esac; \
+ l="$$l $$child";; \
+ esac; \
+ done; \
+ done; \
+ L=$$l; \
+ done
+
+CLEAN-DEPENDS-LIMITED= \
+ L="${_DEPEND_DIRS}"; \
+ checked=""; \
+ while [ -n "$$L" ]; do \
+ l=""; \
+ for d in $$L; do \
+ case $$checked in \
+ $$d\ *|*\ $$d\ *|*\ $$d) \
+ continue;; \
+ esac; \
+ checked="$$checked $$d"; \
+ if [ ! -d $$d ]; then \
+ ${ECHO_MSG} "${PKGNAME}: \"$$d\" non-existent -- dependency list incomplete" >&2; \
+ continue; \
+ fi; \
+ if ! children=$$(cd $$d && ${MAKE} -V WRKDIR -V _DEPEND_DIRS); then \
+ ${ECHO_MSG} "${PKGNAME}: \"$$d\" erroneous -- dependency list incomplete" >&2; \
+ continue; \
+ fi; \
+ state=0; \
+ for child in $$children; do \
+ case $$state in \
+ 0) \
+ if [ ! -d $$child ]; then \
+ break; \
+ fi; \
+ state=1; \
+ ${ECHO_CMD} $$d;; \
+ 1) \
+ case "$$checked $$l" in \
+ $$child\ *|*\ $$child\ *|*\ $$child) \
+ continue;; \
+ esac; \
+ l="$$l $$child";; \
+ esac; \
+ done; \
+ done; \
+ L=$$l; \
+ done
+
+.if !target(clean-depends)
+clean-depends:
+ @for dir in $$(${CLEAN-DEPENDS-FULL}); do \
+ (cd $$dir; ${MAKE} NOCLEANDEPENDS=yes clean); \
+ done
+.endif
+
+.if !target(limited-clean-depends)
+limited-clean-depends:
+ @for dir in $$(${CLEAN-DEPENDS-LIMITED}); do \
+ (cd $$dir; ${MAKE} NOCLEANDEPENDS=yes clean); \
+ done
+.endif
+
+.if !target(deinstall-depends)
+deinstall-depends:
+ @for dir in $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} deinstall); \
+ done
+.endif
+
+.if !target(fetch-recursive)
+fetch-recursive:
+ @${ECHO_MSG} "===> Fetching all distfiles for ${PKGNAME} and dependencies"
+ @for dir in ${.CURDIR} $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} fetch); \
+ done
+.endif
+
+.if !target(fetch-recursive-list)
+fetch-recursive-list:
+ @for dir in ${.CURDIR} $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} fetch-list); \
+ done
+.endif
+
+# Used by fetch-required and fetch-required list, this script looks
+# at each of the dependencies. If 3 items are specified in the tuple,
+# such as foo:${PORTSDIR}/graphics/foo:extract, the first item (foo)
+# is examined. Only if it begins with a / and does not exist on the
+# file-system will ``make targ'' proceed.
+# For more usual (dual-item) dependency tuples, the ``make targ''
+# proceeds, if the exact package, which the directory WOULD'VE installed,
+# is not yet installed.
+# This is the exact behaviour of the old code, and it may need
+# revisiting. For example, the entire first case seems dubious, and in
+# the second case we, probably, should be satisfied with _any_ (earlier)
+# package, with the same origin as that of the dir.
+#
+# -mi
+FETCH_LIST?= for i in $$deps; do \
+ prog=$${i%%:*}; dir=$${i\#*:}; \
+ case $$dir in \
+ *:*) if [ $$prog != $${prog\#/} -o ! -e $$prog ]; then \
+ dir=$${dir%%:*}; \
+ else \
+ continue; \
+ fi;; \
+ *) if [ -d ${PKG_DBDIR}/$$(cd $$dir; ${MAKE} -V PKGNAME) ]; then \
+ continue; \
+ fi;; \
+ esac; \
+ echo cd $$dir; cd $$dir; ${MAKE} $$targ; \
+ done
+
+.if !target(fetch-required)
+fetch-required: fetch
+.if defined(NO_DEPENDS)
+ @${ECHO_MSG} "===> NO_DEPENDS is set, not fetching any other distfiles for ${PKGNAME}"
+.else
+ @${ECHO_MSG} "===> Fetching all required distfiles for ${PKGNAME} and dependencies"
+.for deptype in PKG EXTRACT PATCH FETCH BUILD RUN
+.if defined(${deptype}_DEPENDS)
+ @targ=fetch; deps="${${deptype}_DEPENDS}"; ${FETCH_LIST}
+.endif
+.endfor
+.endif
+
+.endif
+
+.if !target(fetch-required-list)
+fetch-required-list: fetch-list
+.if !defined(NO_DEPENDS)
+.for deptype in PKG EXTRACT PATCH FETCH BUILD RUN
+.if defined(${deptype}_DEPENDS)
+ @targ=fetch-list; deps="${${deptype}_DEPENDS}"; ${FETCH_LIST}
+.endif
+.endfor
+.endif
+.endif
+
+.if !target(checksum-recursive)
+checksum-recursive:
+ @${ECHO_MSG} "===> Fetching and checking checksums for ${PKGNAME} and dependencies"
+ @for dir in ${.CURDIR} $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} checksum); \
+ done
+.endif
+
+# Dependency lists: build and runtime. Print out directory names.
+
+build-depends-list:
+.if defined(PKG_DEPENDS) || defined(EXTRACT_DEPENDS) || defined(PATCH_DEPENDS) || defined(FETCH_DEPENDS) || defined(BUILD_DEPENDS) || defined(LIB_DEPENDS)
+ @${BUILD-DEPENDS-LIST}
+.endif
+
+BUILD-DEPENDS-LIST= \
+ for dir in $$(${ECHO_CMD} "${PKG_DEPENDS} ${EXTRACT_DEPENDS} ${PATCH_DEPENDS} ${FETCH_DEPENDS} ${BUILD_DEPENDS} ${LIB_DEPENDS}" | ${SED} -E -e 's,([^: ]*):([^: ]*)(:[^ ]*)?,\2,g' -e 'y/ /\n/'| ${SORT} -u); do \
+ if [ -d $$dir ]; then \
+ ${ECHO_CMD} $$dir; \
+ else \
+ ${ECHO_MSG} "${PKGNAME}: \"$$dir\" non-existent -- dependency list incomplete" >&2; \
+ fi; \
+ done | ${SORT} -u
+
+run-depends-list:
+.if defined(LIB_DEPENDS) || defined(RUN_DEPENDS)
+ @${RUN-DEPENDS-LIST}
+.endif
+
+RUN-DEPENDS-LIST= \
+ for dir in $$(${ECHO_CMD} "${_LIB_RUN_DEPENDS:C,.*:([^:]*).*,\1,}" | ${SED} -e 'y/ /\n/' | ${SORT} -u); do \
+ if [ -d $$dir ]; then \
+ ${ECHO_CMD} $$dir; \
+ else \
+ ${ECHO_MSG} "${PKGNAME}: \"$$dir\" non-existent -- dependency list incomplete" >&2; \
+ fi; \
+ done | ${SORT} -u
+
+# Package (recursive runtime) dependency list. Print out both directory names
+# and package names.
+
+package-depends-list:
+.if defined(CHILD_DEPENDS) || defined(LIB_DEPENDS) || defined(RUN_DEPENDS)
+ @${PACKAGE-DEPENDS-LIST}
+.endif
+
+_LIB_RUN_DEPENDS= ${LIB_DEPENDS} ${RUN_DEPENDS}
+PACKAGE-DEPENDS-LIST?= \
+ if [ "${CHILD_DEPENDS}" ]; then \
+ installed=$$(${PKG_INFO} -qO ${PKGORIGIN} 2>/dev/null || \
+ ${TRUE}); \
+ if [ "$$installed" ]; then \
+ break; \
+ fi; \
+ if [ -z "$$installed" ]; then \
+ installed="${PKGNAME}"; \
+ fi; \
+ for pkgname in $$installed; do \
+ ${ECHO_CMD} "$$pkgname ${.CURDIR} ${PKGORIGIN}"; \
+ done; \
+ fi; \
+ checked="${PARENT_CHECKED}"; \
+ for dir in ${_LIB_RUN_DEPENDS:C,[^:]*:([^:]*):?.*,\1,}; do \
+ dir=$$(${REALPATH} $$dir); \
+ if [ -d $$dir ]; then \
+ case $$checked in \
+ $$dir|$$dir\ *|*\ $$dir|*\ $$dir\ *) continue;; \
+ esac; \
+ childout=$$(cd $$dir; ${MAKE} CHILD_DEPENDS=yes PARENT_CHECKED="$$checked" package-depends-list); \
+ set -- $$childout; \
+ childdir=""; \
+ while [ $$\# != 0 ]; do \
+ childdir="$$childdir $$2"; \
+ ${ECHO_CMD} "$$1 $$2 $$3"; \
+ shift 3; \
+ done; \
+ checked="$$dir $$childdir $$checked"; \
+ else \
+ ${ECHO_MSG} "${PKGNAME}: \"$$dir\" non-existent -- dependency list incomplete" >&2; \
+ fi; \
+ done
+
+ACTUAL-PACKAGE-DEPENDS?= \
+ if [ "${_LIB_RUN_DEPENDS}" != " " ]; then \
+ origins=$$(for pkgname in ${PKG_DBDIR}/*; do \
+ if [ -e $$pkgname/+CONTENTS ]; then \
+ ${ECHO_CMD} $${pkgname\#\#*/}; \
+ ${SED} -n -e "s/@comment ORIGIN://p" $$pkgname/+CONTENTS; \
+ fi; \
+ done); \
+ for dir in ${_LIB_RUN_DEPENDS:C,[^:]*:([^:]*):?.*,\1,}; do \
+ tmp=$${dir\#${PORTSDIR}/}; \
+ if [ "$$tmp" = "$$dir" ]; then \
+ tmp=$${dir%/*}; \
+ dir=$${tmp\#\#*/}/$${dir\#\#*/}; \
+ else \
+ dir=$$tmp; \
+ fi; \
+ set -- $$origins; \
+ while [ $$\# -gt 1 ]; do \
+ if [ ! -d "${PORTSDIR}/$$2" ]; then \
+ shift; \
+ continue; \
+ fi; \
+ if [ "$$dir" = "$$2" ]; then \
+ ${ECHO_CMD} $$1:$$dir; \
+ if [ -e ${PKG_DBDIR}/$$1/+CONTENTS -a -z "${EXPLICIT_PACKAGE_DEPENDS}" ]; then \
+ packagelist="$$packagelist ${PKG_DBDIR}/$$1/+CONTENTS"; \
+ fi; \
+ break; \
+ fi; \
+ shift 2; \
+ done; \
+ done; \
+ [ -z "$$packagelist" ] || ${AWK} -F '( |:)' 'BEGIN { pkgname="broken_contents" } /@pkgdep / { pkgname=$$2 } /@comment DEPORIGIN:/ { printf "%s:%s\n", pkgname, $$3; pkgname="broken_contents" }' $$packagelist; \
+ fi
+
+# Print out package names.
+
+package-depends:
+ @${PACKAGE-DEPENDS-LIST} | ${AWK} '{print $$1":"$$3}'
+
+actual-package-depends:
+ @${ACTUAL-PACKAGE-DEPENDS}
+
+# Build packages for port and dependencies
+
+package-recursive: package
+ @for dir in $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} package-noinstall); \
+ done
+
+# Show missing dependencies
+missing:
+ @_origins=$$(${PKG_INFO} -aoq); \
+ for dir in $$(${ALL-DEPENDS-LIST}); do \
+ _origin=$${dir##${PORTSDIR}/}; \
+ if ! $$(${ECHO_CMD} $${_origins} | ${GREP} -q $${_origin}); then \
+ ${ECHO_CMD} $${_origin}; \
+ fi; \
+ done
+
+################################################################
+# Everything after here are internal targets and really
+# shouldn't be touched by anybody but the release engineers.
+################################################################
+
+# This target generates an index entry suitable for aggregation into
+# a large index. Format is:
+#
+# distribution-name|port-path|installation-prefix|comment| \
+# description-file|maintainer|categories|extract-depends| \
+# patch-depends|fetch-depends|build-depends|run-depends|www site
+#
+# If this ever changes, portmgr should contact the portsnap maintainer
+# first to avoid gratuitous breakage.
+
+. if !target(describe)
+_EXTRACT_DEPENDS=${EXTRACT_DEPENDS:C/^[^ :]+:([^ :]+)(:[^ :]+)?/\1/:O:u}
+_PATCH_DEPENDS=${PATCH_DEPENDS:C/^[^ :]+:([^ :]+)(:[^ :]+)?/\1/:O:u}
+_FETCH_DEPENDS=${FETCH_DEPENDS:C/^[^ :]+:([^ :]+)(:[^ :]+)?/\1/:O:u}
+_LIB_DEPENDS=${LIB_DEPENDS:C/^[^ :]+:([^ :]+)(:[^ :]+)?/\1/:O:u}
+_BUILD_DEPENDS=${BUILD_DEPENDS:C/^[^ :]+:([^ :]+)(:[^ :]+)?/\1/:O:u} ${_LIB_DEPENDS}
+_RUN_DEPENDS=${RUN_DEPENDS:C/^[^ :]+:([^ :]+)(:[^ :]+)?/\1/:O:u} ${_LIB_DEPENDS}
+. if exists(${DESCR})
+_DESCR=${DESCR}
+. else
+_DESCR=/dev/null
+. endif
+
+. if defined(BUILDING_INDEX) && defined(INDEX_PORTS)
+INDEX_OUT=${INDEX_TMPDIR}/${INDEXFILE}.desc.aggr
+. else
+INDEX_OUT=/dev/stdout
+. endif
+
+describe:
+ @(${ECHO_CMD} -n "${PKGNAME}|${.CURDIR}|${PREFIX}|"; \
+ ${ECHO_CMD} -n ${COMMENT:Q}; \
+ ${ECHO_CMD} -n "|${_DESCR}|${MAINTAINER}|${CATEGORIES}|${_EXTRACT_DEPENDS}|${_PATCH_DEPENDS}|${_FETCH_DEPENDS}|${_BUILD_DEPENDS:O:u}|${_RUN_DEPENDS:O:u}|"; \
+ while read one two discard; do \
+ case "$$one" in \
+ WWW:) case "$$two" in \
+ https://*|http://*|ftp://*) ${ECHO_CMD} -n "$$two" ;; \
+ *) ${ECHO_CMD} -n "http://$$two" ;; \
+ esac; \
+ break; \
+ ;; \
+ esac; \
+ done < ${DESCR}; ${ECHO_CMD}) >>${INDEX_OUT}
+. endif
+
+www-site:
+.if exists(${DESCR})
+ @${AWK} '$$1 ~ /^WWW:/ {print $$2}' ${DESCR} | ${HEAD} -1
+.else
+ @${ECHO_CMD}
+.endif
+
+.if !target(readmes)
+readmes: readme
+.endif
+
+.if !target(readme)
+readme:
+ @${RM} -f ${.CURDIR}/README.html
+ @cd ${.CURDIR} && ${MAKE} ${.CURDIR}/README.html
+.endif
+
+${.CURDIR}/README.html:
+ @${ECHO_MSG} "===> Creating README.html for ${PKGNAME}"
+ @${SED} -e 's|%%PORT%%|'$$(${ECHO_CMD} ${.CURDIR} | \
+ ${SED} -e 's|.*/\([^/]*/[^/]*\)$$|\1|')'|g' \
+ -e 's|%%PKG%%|${PKGNAME}|g' \
+ -e 's|%%COMMENT%%|'"$$(${ECHO_CMD} ${COMMENT:Q})"'|' \
+ -e '/%%COMMENT%%/d' \
+ -e 's|%%DESCR%%|'"$$(${ECHO_CMD} ${DESCR} | \
+ ${SED} -e 's|${.CURDIR}/||')"'|' \
+ -e 's|%%EMAIL%%|'"$$(${ECHO_CMD} "${MAINTAINER}" | \
+ ${SED} -e 's/([^)]*)//;s/.*<//;s/>.*//')"'|g' \
+ -e 's|%%MAINTAINER%%|${MAINTAINER}|g' \
+ -e 's|%%WEBSITE%%|'"$$(cd ${.CURDIR} && eval ${MAKE} pretty-print-www-site)"'|' \
+ -e 's|%%BUILD_DEPENDS%%|'"$$(cd ${.CURDIR} && eval ${MAKE} pretty-print-build-depends-list)"'|' \
+ -e 's|%%RUN_DEPENDS%%|'"$$(cd ${.CURDIR} && eval ${MAKE} pretty-print-run-depends-list)"'|' \
+ -e 's|%%TOP%%|'"$$(${ECHO_CMD} ${CATEGORIES} | \
+ ${SED} -e 's| .*||' -e 's|[^/]*|..|g')"'/..|' \
+ ${TEMPLATES}/README.port >> ${.TARGET}
+
+# The following two targets require an up-to-date INDEX in ${PORTSDIR}
+
+_PRETTY_PRINT_DEPENDS_LIST=\
+ if [ ! -r ${INDEXDIR}/${INDEXFILE} ] ; then \
+ ${ECHO_MSG} "${.TARGET} requires an INDEX file (${INDEXFILE}). Please run make index or make fetchindex."; \
+ else \
+ target=${.TARGET:C/pretty-print-(.*)-depends-list/\1/} ; \
+ if [ "$$target" = "build" ] ; then fldnum=8 ; else fldnum=9 ; fi; \
+ ${ECHO_MSG} -n 'This port requires package(s) "' ; \
+ ${ECHO_MSG} -n `${AWK} -F\| "\\$$1 ~ /^${PKGNAME}/ {print \\$$$${fldnum};}" ${INDEXDIR}/${INDEXFILE}` ; \
+ ${ECHO_MSG} "\" to $$target."; \
+ fi;
+
+
+.if !target(pretty-print-build-depends-list)
+pretty-print-build-depends-list:
+.if defined(PKG_PEPENDS) || defined(EXTRACT_DEPENDS) || defined(PATCH_DEPENDS) || \
+ defined(FETCH_DEPENDS) || defined(BUILD_DEPENDS) || defined(LIB_DEPENDS)
+ @${_PRETTY_PRINT_DEPENDS_LIST}
+.endif
+.endif
+
+.if !target(pretty-print-run-depends-list)
+pretty-print-run-depends-list:
+.if defined(RUN_DEPENDS) || defined(LIB_DEPENDS)
+ @${_PRETTY_PRINT_DEPENDS_LIST}
+.endif
+.endif
+
+_SUB_LIST_TEMP= ${SUB_LIST:S/$/!g/:S/^/ -e s!%%/:S/=/%%!/}
+.if !target(apply-slist)
+apply-slist:
+.if defined(SUB_FILES)
+.for file in ${SUB_FILES}
+.if !exists(${FILESDIR}/${file}.in)
+ @${ECHO_MSG} "** Missing ${FILESDIR}/${file}.in for ${PKGNAME}."; exit 1
+.else
+ @${SED} ${_SUB_LIST_TEMP} -e '/^@comment /d' ${FILESDIR}/${file}.in > ${WRKDIR}/${file}
+.endif
+.endfor
+.for i in pkg-message pkg-install pkg-deinstall pkg-req
+.if ${SUB_FILES:M${i}*}!=""
+${i:S/-//:U}= ${WRKDIR}/${SUB_FILES:M${i}*}
+.endif
+.endfor
+.endif
+.endif
+
+# Generate packing list. Also tests to make sure all required package
+# files exist.
+
+.if !target(generate-plist)
+generate-plist:
+ @${ECHO_MSG} "===> Generating temporary packing list"
+ @${MKDIR} `${DIRNAME} ${TMPPLIST}`
+ @if [ ! -f ${DESCR} ]; then ${ECHO_MSG} "** Missing pkg-descr for ${PKGNAME}."; exit 1; fi
+ @>${TMPPLIST}
+ @for file in ${PLIST_FILES}; do \
+ ${ECHO_CMD} $${file} | ${SED} ${PLIST_SUB:S/$/!g/:S/^/ -e s!%%/:S/=/%%!/} >> ${TMPPLIST}; \
+ done
+ @for man in ${__MANPAGES}; do \
+ ${ECHO_CMD} $${man} >> ${TMPPLIST}; \
+ done
+.for _PREFIX in ${PREFIX}
+.if ${_TMLINKS:M${_PREFIX}*}x != x
+ @for i in ${_TMLINKS:M${_PREFIX}*:S|^${_PREFIX}/||}; do \
+ ${ECHO_CMD} "$$i" >> ${TMPPLIST}; \
+ done
+.endif
+.if ${_TMLINKS:N${_PREFIX}*}x != x
+ @${ECHO_CMD} @cwd / >> ${TMPPLIST}
+ @for i in ${_TMLINKS:N${_PREFIX}*:S|^/||}; do \
+ ${ECHO_CMD} "$$i" >> ${TMPPLIST}; \
+ done
+ @${ECHO_CMD} '@cwd ${PREFIX}' >> ${TMPPLIST}
+.endif
+.endfor
+ @if [ -f ${PLIST} ]; then \
+ ${SED} ${PLIST_SUB:S/$/!g/:S/^/ -e s!%%/:S/=/%%!/} ${PLIST} >> ${TMPPLIST}; \
+ fi
+
+.for dir in ${PLIST_DIRS}
+ @${ECHO_CMD} ${dir} | ${SED} ${PLIST_SUB:S/$/!g/:S/^/ -e s!%%/:S/=/%%!/} -e 's,^,@dirrm ,' >> ${TMPPLIST}
+.endfor
+.for dir in ${PLIST_DIRSTRY}
+ @${ECHO_CMD} ${dir} | ${SED} ${PLIST_SUB:S/$/!g/:S/^/ -e s!%%/:S/=/%%!/} -e 's,^,@dirrmtry ,' >> ${TMPPLIST}
+.endfor
+
+.for reinplace in ${PLIST_REINPLACE}
+.if defined(PLIST_REINPLACE_${reinplace:U})
+ @${SED} -i "" -e '${PLIST_REINPLACE_${reinplace:U}}' ${TMPPLIST}
+.endif
+.endfor
+
+.if defined(USE_LINUX_PREFIX)
+.if defined(USE_LDCONFIG)
+ @${ECHO_CMD} "@exec ${LDCONFIG_CMD}" >> ${TMPPLIST}
+ @${ECHO_CMD} "@unexec ${LDCONFIG_CMD}" >> ${TMPPLIST}
+.endif
+.else
+.if defined(USE_LDCONFIG)
+.if !defined(INSTALL_AS_USER)
+ @${ECHO_CMD} "@exec ${LDCONFIG} -m ${USE_LDCONFIG}" >> ${TMPPLIST}
+ @${ECHO_CMD} "@unexec ${LDCONFIG} -R" >> ${TMPPLIST}
+.else
+ @${ECHO_CMD} "@exec ${LDCONFIG} -m ${USE_LDCONFIG} || ${TRUE}" >> ${TMPPLIST}
+ @${ECHO_CMD} "@unexec ${LDCONFIG} -R || ${TRUE}" >> ${TMPPLIST}
+.endif
+.endif
+.if defined(USE_LDCONFIG32)
+.if !defined(INSTALL_AS_USER)
+ @${ECHO_CMD} "@exec ${LDCONFIG} -32 -m ${USE_LDCONFIG32}" >> ${TMPPLIST}
+ @${ECHO_CMD} "@unexec ${LDCONFIG} -32 -R" >> ${TMPPLIST}
+.else
+ @${ECHO_CMD} "@exec ${LDCONFIG} -32 -m ${USE_LDCONFIG32} || ${TRUE}" >> ${TMPPLIST}
+ @${ECHO_CMD} "@unexec ${LDCONFIG} -32 -R || ${TRUE}" >> ${TMPPLIST}
+.endif
+.endif
+.endif
+.endif
+
+${TMPPLIST}:
+ @cd ${.CURDIR} && ${MAKE} generate-plist
+
+${TMPPLIST_SORT}: ${TMPPLIST}
+ @${SORT} -u ${TMPPLIST} >${TMPPLIST_SORT}
+
+.if !target(add-plist-docs)
+add-plist-docs:
+.if defined(PORTDOCS) && !defined(NOPORTDOCS)
+ @if ${EGREP} -qe '^@cw?d' ${TMPPLIST} && \
+ [ "`${SED} -En -e '/^@cw?d[ ]*/s,,,p' ${TMPPLIST} | ${TAIL} -n 1`" != "${PREFIX}" ]; then \
+ ${ECHO_CMD} "@cwd ${PREFIX}" >> ${TMPPLIST}; \
+ fi
+.for x in ${PORTDOCS}
+ @if ${ECHO_CMD} "${x}"| ${AWK} '$$1 ~ /(\*|\||\[|\]|\?|\{|\}|\$$)/ { exit 1};'; then \
+ if [ ! -e ${DOCSDIR}/${x} ]; then \
+ ${ECHO_CMD} ${DOCSDIR_REL}/${x} >> ${TMPPLIST}; \
+ fi;fi
+.endfor
+ @${FIND} -P ${PORTDOCS:S/^/${DOCSDIR}\//} ! -type d 2>/dev/null | \
+ ${SED} -ne 's,^${PREFIX}/,,p' >> ${TMPPLIST}
+ @${FIND} -P -d ${PORTDOCS:S/^/${DOCSDIR}\//} -type d 2>/dev/null | \
+ ${SED} -ne 's,^${PREFIX}/,@dirrm ,p' >> ${TMPPLIST}
+ @${ECHO_CMD} "@dirrm ${DOCSDIR_REL}" >> ${TMPPLIST}
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+.if !target(add-plist-examples)
+add-plist-examples:
+.if defined(PORTEXAMPLES) && !defined(NOPORTEXAMPLES)
+ @if ${EGREP} -qe '^@cw?d' ${TMPPLIST} && \
+ [ "`${SED} -En -e '/^@cw?d[ ]*/s,,,p' ${TMPPLIST} | ${TAIL} -n 1`" != "${PREFIX}" ]; then \
+ ${ECHO_CMD} "@cwd ${PREFIX}" >> ${TMPPLIST}; \
+ fi
+.for x in ${PORTEXAMPLES}
+ @if ${ECHO_CMD} "${x}"| ${AWK} '$$1 ~ /(\*|\||\[|\]|\?|\{|\}|\$$)/ { exit 1};'; then \
+ if [ ! -e ${EXAMPLESDIR}/${x} ]; then \
+ ${ECHO_CMD} ${EXAMPLESDIR}/${x} | \
+ ${SED} -e 's,^${PREFIX}/,,' >> ${TMPPLIST}; \
+ fi;fi
+.endfor
+ @${FIND} -P ${PORTEXAMPLES:S/^/${EXAMPLESDIR}\//} ! -type d 2>/dev/null | \
+ ${SED} -ne 's,^${PREFIX}/,,p' >> ${TMPPLIST}
+ @${FIND} -P -d ${PORTEXAMPLES:S/^/${EXAMPLESDIR}\//} -type d 2>/dev/null | \
+ ${SED} -ne 's,^${PREFIX}/,@dirrm ,p' >> ${TMPPLIST}
+ @${ECHO_CMD} "@dirrm ${EXAMPLESDIR:S,^${PREFIX}/,,}" >> ${TMPPLIST}
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+.if !target(add-plist-data)
+add-plist-data:
+.if defined(PORTDATA) && !defined(NOPORTDATA)
+ @if ${EGREP} -qe '^@cw?d' ${TMPPLIST} && \
+ [ "`${SED} -En -e '/^@cw?d[ ]*/s,,,p' ${TMPPLIST} | ${TAIL} -n 1`" != "${PREFIX}" ]; then \
+ ${ECHO_CMD} "@cwd ${PREFIX}" >> ${TMPPLIST}; \
+ fi
+.for x in ${PORTDATA}
+ @if ${ECHO_CMD} "${x}"| ${AWK} '$$1 ~ /(\*|\||\[|\]|\?|\{|\}|\$$)/ { exit 1};'; then \
+ if [ ! -e ${DATADIR}/${x} ]; then \
+ ${ECHO_CMD} ${DATADIR}/${x} | \
+ ${SED} -e 's,^${PREFIX}/,,' >> ${TMPPLIST}; \
+ fi;fi
+.endfor
+ @${FIND} -P ${PORTDATA:S/^/${DATADIR}\//} ! -type d 2>/dev/null | \
+ ${SED} -ne 's,^${PREFIX}/,,p' >> ${TMPPLIST}
+ @${FIND} -P -d ${PORTDATA:S/^/${DATADIR}\//} -type d 2>/dev/null | \
+ ${SED} -ne 's,^${PREFIX}/,@dirrm ,p' >> ${TMPPLIST}
+ @${ECHO_CMD} "@dirrm ${DATADIR:S,^${PREFIX}/,,}" >> ${TMPPLIST}
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+.if !target(add-plist-info)
+add-plist-info:
+# Process GNU INFO files at package install/deinstall time
+.if defined(INFO)
+.for i in ${INFO}
+ install-info --quiet ${PREFIX}/${INFO_PATH}/$i.info ${PREFIX}/${INFO_PATH}/dir
+ @${ECHO_CMD} "@unexec install-info --quiet --delete %D/${INFO_PATH}/$i.info %D/${INFO_PATH}/dir" \
+ >> ${TMPPLIST}
+ @${LS} ${PREFIX}/${INFO_PATH}/$i.info* | ${SED} -e s:${PREFIX}/::g >> ${TMPPLIST}
+ @${ECHO_CMD} "@exec install-info --quiet %D/${INFO_PATH}/$i.info %D/${INFO_PATH}/dir" \
+ >> ${TMPPLIST}
+.endfor
+.if defined(INFO_SUBDIR)
+ @${ECHO_CMD} "@unexec ${RMDIR} %D/${INFO_PATH}/${INFO_SUBDIR} 2> /dev/null || true" >> ${TMPPLIST}
+.endif
+.if (${PREFIX} != "/usr")
+ @${ECHO_CMD} "@unexec if [ -f %D/${INFO_PATH}/dir ]; then if sed -e '1,/Menu:/d' %D/${INFO_PATH}/dir | grep -q '^[*] '; then true; else rm %D/${INFO_PATH}/dir; fi; fi" >> ${TMPPLIST}
+.if (${PREFIX} != ${LOCALBASE} && ${PREFIX} != ${LINUXBASE})
+ @${ECHO_CMD} "@unexec rmdir %D/${INFO_PATH} 2>/dev/null || true" >> ${TMPPLIST}
+.endif
+.endif
+.endif
+.endif
+
+# If we're installing into a non-standard PREFIX, we need to remove that directory at
+# deinstall-time
+.if !target(add-plist-post)
+add-plist-post:
+.if (${PREFIX} != ${LOCALBASE} && ${PREFIX} != ${LINUXBASE} && ${PREFIX} != "/usr")
+ @${ECHO_CMD} "@unexec rmdir %D 2> /dev/null || true" >> ${TMPPLIST}
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+.if !target(install-rc-script)
+install-rc-script:
+.if defined(USE_RCORDER) || defined(USE_RC_SUBR) && ${USE_RC_SUBR:U} != "YES"
+.if defined(USE_RCORDER)
+ @${ECHO_MSG} "===> Installing early rc.d startup script(s)"
+ @${ECHO_CMD} "@cwd /" >> ${TMPPLIST}
+ @for i in ${USE_RCORDER}; do \
+ ${INSTALL_SCRIPT} ${WRKDIR}/$${i} /etc/rc.d/$${i%.sh}; \
+ ${ECHO_CMD} "etc/rc.d/$${i%.sh}" >> ${TMPPLIST}; \
+ done
+ @${ECHO_CMD} "@cwd ${PREFIX}" >> ${TMPPLIST}
+.endif
+.if defined(USE_RC_SUBR) && ${USE_RC_SUBR:U} != "YES"
+ @${ECHO_MSG} "===> Installing rc.d startup script(s)"
+ @${ECHO_CMD} "@cwd ${PREFIX}" >> ${TMPPLIST}
+ @for i in ${USE_RC_SUBR}; do \
+ ${INSTALL_SCRIPT} ${WRKDIR}/$${i} ${PREFIX}/etc/rc.d/$${i%.sh}; \
+ ${ECHO_CMD} "etc/rc.d/$${i%.sh}" >> ${TMPPLIST}; \
+ done
+.endif
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+# Compress (or uncompress) and symlink manpages.
+.if !target(compress-man)
+compress-man:
+.if defined(_MANPAGES) || defined(_MLINKS)
+.if ${MANCOMPRESSED} == yes && defined(NO_MANCOMPRESS)
+ @${ECHO_MSG} "===> Uncompressing manual pages for ${PKGNAME}"
+ @_manpages='${_MANPAGES:S/'/'\''/g}' && [ "$${_manpages}" != "" ] && ( eval ${GUNZIP_CMD} $${_manpages} ) || ${TRUE}
+.elif ${MANCOMPRESSED} == no && !defined(NO_MANCOMPRESS)
+ @${ECHO_MSG} "===> Compressing manual pages for ${PKGNAME}"
+ @_manpages='${_MANPAGES:S/'/'\''/g}' && [ "$${_manpages}" != "" ] && ( eval ${GZIP_CMD} $${_manpages} ) || ${TRUE}
+.endif
+.if defined(_MLINKS)
+ @set -- ${_MLINKS}; \
+ while :; do \
+ [ $$# -eq 0 ] && break || ${TRUE}; \
+ ${RM} -f $${2%.gz}; ${RM} -f $$2.gz; \
+ ${LN} -fs `${ECHO_CMD} $$1 $$2 | ${AWK} '{ \
+ z=split($$1, a, /\//); x=split($$2, b, /\//); \
+ while (a[i] == b[i]) i++; \
+ for (q=i; q<x; q++) printf "../"; \
+ for (; i<z; i++) printf a[i] "/"; printf a[z]; }'` $$2; \
+ shift; shift; \
+ done
+.endif
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+# Fake installation of package so that user can pkg_delete it later.
+# Also, make sure that an installed port is recognized correctly in
+# accordance to the @pkgdep directive in the packing lists
+
+.if !target(fake-pkg)
+fake-pkg:
+.if !defined(NO_PKG_REGISTER)
+ @if [ ! -d ${PKG_DBDIR} ]; then ${RM} -f ${PKG_DBDIR}; ${MKDIR} ${PKG_DBDIR}; fi
+ @${RM} -f /tmp/${PKGNAME}-required-by
+.if defined(FORCE_PKG_REGISTER)
+ @if [ -e ${PKG_DBDIR}/${PKGNAME}/+REQUIRED_BY ]; then \
+ ${CP} ${PKG_DBDIR}/${PKGNAME}/+REQUIRED_BY /tmp/${PKGNAME}-required-by; \
+ fi
+ @${RM} -rf ${PKG_DBDIR}/${PKGNAME}
+.endif
+ @if [ ! -d ${PKG_DBDIR}/${PKGNAME} ]; then \
+ ${ECHO_MSG} "===> Registering installation for ${PKGNAME}"; \
+ ${MKDIR} ${PKG_DBDIR}/${PKGNAME}; \
+ ${PKG_CMD} ${PKG_ARGS} -O ${PKGFILE} > ${PKG_DBDIR}/${PKGNAME}/+CONTENTS; \
+ ${CP} ${DESCR} ${PKG_DBDIR}/${PKGNAME}/+DESC; \
+ ${ECHO_CMD} ${COMMENT:Q} > ${PKG_DBDIR}/${PKGNAME}/+COMMENT; \
+ if [ -f ${PKGINSTALL} ]; then \
+ ${CP} ${PKGINSTALL} ${PKG_DBDIR}/${PKGNAME}/+INSTALL; \
+ fi; \
+ if [ -f ${PKGDEINSTALL} ]; then \
+ ${CP} ${PKGDEINSTALL} ${PKG_DBDIR}/${PKGNAME}/+DEINSTALL; \
+ fi; \
+ if [ -f ${PKGREQ} ]; then \
+ ${CP} ${PKGREQ} ${PKG_DBDIR}/${PKGNAME}/+REQUIRE; \
+ fi; \
+ if [ -f ${PKGMESSAGE} ]; then \
+ ${CP} ${PKGMESSAGE} ${PKG_DBDIR}/${PKGNAME}/+DISPLAY; \
+ ${ECHO_CMD} "@display +DISPLAY" >> ${PKG_DBDIR}/${PKGNAME}/+CONTENTS; \
+ fi; \
+ for dep in `${PKG_INFO} -qf ${PKGNAME} | ${AWK} '/^@pkgdep / {print $$2}' | ${SORT} -u`; do \
+ if [ -d ${PKG_DBDIR}/$$dep -a -z `${ECHO_CMD} $$dep | ${GREP} -E ${PKG_IGNORE_DEPENDS}` ]; then \
+ if ! ${GREP} ^${PKGNAME}$$ ${PKG_DBDIR}/$$dep/+REQUIRED_BY \
+ >/dev/null 2>&1; then \
+ ${ECHO_CMD} ${PKGNAME} >> ${PKG_DBDIR}/$$dep/+REQUIRED_BY; \
+ fi; \
+ fi; \
+ done; \
+ fi
+.if !defined(NO_MTREE)
+ @if [ -f ${MTREE_FILE} ]; then \
+ ${CP} ${MTREE_FILE} ${PKG_DBDIR}/${PKGNAME}/+MTREE_DIRS; \
+ fi
+.endif
+ @if [ -e /tmp/${PKGNAME}-required-by ]; then \
+ ${CAT} /tmp/${PKGNAME}-required-by >> ${PKG_DBDIR}/${PKGNAME}/+REQUIRED_BY; \
+ ${RM} -f /tmp/${PKGNAME}-required-by; \
+ fi
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+# Depend is generally meaningless for arbitrary ports, but if someone wants
+# one they can override this. This is just to catch people who've gotten into
+# the habit of typing `make depend all install' as a matter of course.
+#
+.if !target(depend)
+depend:
+.endif
+
+# Same goes for tags
+.if !target(tags)
+tags:
+.endif
+
+.if !defined(NOPRECIOUSMAKEVARS)
+# These won't change, so we can pass them through the environment
+.MAKEFLAGS: \
+ ARCH="${ARCH:S/"/"'"'"/g:S/\$/\$\$/g:S/\\/\\\\/g}" \
+ OPSYS="${OPSYS:S/"/"'"'"/g:S/\$/\$\$/g:S/\\/\\\\/g}" \
+ OSREL="${OSREL:S/"/"'"'"/g:S/\$/\$\$/g:S/\\/\\\\/g}" \
+ OSVERSION="${OSVERSION:S/"/"'"'"/g:S/\$/\$\$/g:S/\\/\\\\/g}" \
+ SYSTEMVERSION="${SYSTEMVERSION:S/"/"'"'"/g:S/\$/\$\$/g:S/\\/\\\\/g}"
+.endif
+
+.if !target(pre-check-config)
+pre-check-config:
+.for single in ${OPTIONS_SINGLE}
+. for opt in ${OPTIONS_SINGLE_${single}}
+. if empty(ALL_OPTIONS:M${single}) || !empty(PORT_OPTIONS:M${single})
+. if !empty(PORT_OPTIONS:M${opt})
+. if defined(OPTFOUND)
+OPTIONS_WRONG_SINGLE+= ${single}
+. else
+OPTFOUND= true
+. endif
+. endif
+. else
+# if conditional and if the condition is unchecked, remove opt from the list of
+# set options
+PORT_OPTIONS:= ${PORT_OPTIONS:N${opt}}
+OPTNOCHECK= true
+. endif
+. endfor
+. if !defined(OPTFOUND) && !defined(OPTNOCHECK)
+OPTIONS_WRONG_SINGLE+= ${single}
+. endif
+. undef OPTFOUND
+. undef OPTNOCHECK
+.endfor
+.undef single
+
+.for multi in ${OPTIONS_MULTI}
+. for opt in ${OPTIONS_MULTI_${multi}}
+. if empty(ALL_OPTIONS:M${multi}) || !empty(PORT_OPTIONS:M${multi})
+. if !empty(PORT_OPTIONS:M${opt})
+OPTFOUND= true
+. endif
+. else
+# if conditional and if the condition is unchecked, remove opt from the list of
+# set options
+PORT_OPTIONS:= ${PORT_OPTIONS:N${opt}}
+OPTNOCHECK= true
+. endif
+. endfor
+. if !defined(OPTFOUND) && !defined(OPTNOCHECK)
+OPTIONS_WRONG_MULTI+= ${multi}
+. endif
+. undef OPTFOUND
+. undef OPTNOCHECK
+.endfor
+.undef multi
+.undef opt
+.endif #pre-check-config
+
+.if !target(_check-config)
+_check-config: pre-check-config
+.for multi in ${OPTIONS_WRONG_MULTI}
+ @${ECHO_MSG} "====> You must check at least one option in the ${multi} multi"
+.endfor
+.for single in ${OPTIONS_WRONG_SINGLE}
+ @${ECHO_MSG} "====> You must select one and only one option from the ${single} single"
+.endfor
+.if !empty(OPTIONS_WRONG_MULTI) || !empty(OPTIONS_WRONG_SINGLE)
+_CHECK_CONFIG_ERROR= true
+.endif
+.endif # _check-config
+
+.if !target(check-config)
+check-config: _check-config
+.if !empty(_CHECK_CONFIG_ERROR)
+ @exit 1
+.endif
+.endif # check-config
+
+.if !target(sanity-config)
+sanity-config: _check-config
+.if !empty(_CHECK_CONFIG_ERROR)
+ @echo -n "Config is invalid. Re-edit? [Y/N] "; \
+ read answer; \
+ case $$answer in \
+ [Nn]|[Nn][Oo]) \
+ exit 0; \
+ esac; \
+ cd ${.CURDIR} && ${MAKE} config
+.endif
+.endif # sanity-config
+
+.if !target(pre-config)
+pre-config:
+_COMPLETE_OPTIONS_LIST:= ${ALL_OPTIONS}
+.for opt in ${ALL_OPTIONS}
+. if empty(PORT_OPTIONS:M${opt})
+DEFOPTIONS+= ${opt} ""${${opt}_DESC:Q} off
+. else
+DEFOPTIONS+= ${opt} ""${${opt}_DESC:Q} on
+. endif
+.endfor
+.for multi in ${OPTIONS_MULTI}
+. for opt in ${OPTIONS_MULTI_${multi}}
+_COMPLETE_OPTIONS_LIST+= ${opt}
+. if empty(PORT_OPTIONS:M${opt})
+DEFOPTIONS+= ${opt} "M(${multi}): "${${opt}_DESC:Q} off
+. else
+DEFOPTIONS+= ${opt} "M(${multi}): "${${opt}_DESC:Q} on
+. endif
+. endfor
+.endfor
+.for single in ${OPTIONS_SINGLE}
+. for opt in ${OPTIONS_SINGLE_${single}}
+_COMPLETE_OPTIONS_LIST+= ${opt}
+. if empty(PORT_OPTIONS:M${opt})
+DEFOPTIONS+= ${opt} "S(${single}): "${${opt}_DESC:Q} off
+. else
+DEFOPTIONS+= ${opt} "S(${single}): "${${opt}_DESC:Q} on
+. endif
+. endfor
+.endfor
+
+_COMPLETE_OPTIONS_LIST:= ${_COMPLETE_OPTIONS_LIST:u}
+.undef multi
+.undef single
+.undef opt
+.endif # pre-config
+
+.if !target(config)
+config: pre-config
+.if empty(ALL_OPTIONS) && empty(OPTIONS_SINGLE) && empty(OPTIONS_MULTI)
+ @${ECHO_MSG} "===> No options to configure"
+.else
+.if ${UID} != 0 && !defined(INSTALL_AS_USER)
+ @optionsdir=${OPTIONSFILE}; optionsdir=$${optionsdir%/*}; \
+ ${ECHO_MSG} "===> Switching to root credentials to create $${optionsdir}"; \
+ (${SU_CMD} "${SH} -c \"${MKDIR} $${optionsdir} 2> /dev/null\"") || \
+ (${ECHO_MSG} "===> Cannot create $${optionsdir}, check permissions"; exit 1); \
+ ${ECHO_MSG} "===> Returning to user credentials"
+.else
+ @(optionsdir=${OPTIONSFILE}; optionsdir=$${optionsdir%/*}; \
+ ${MKDIR} $${optionsdir} 2> /dev/null) || \
+ (${ECHO_MSG} "===> Cannot create $${optionsdir}, check permissions"; exit 1)
+.endif
+ @TMPOPTIONSFILE=$$(mktemp -t portoptions); \
+ trap "${RM} -f $${TMPOPTIONSFILE}; exit 1" 1 2 3 5 10 13 15; \
+ ${DIALOG} --checklist "Options for ${PKGNAME:C/-([^-]+)$/ \1/}" 21 70 15 ${DEFOPTIONS} 2> $${TMPOPTIONSFILE} || { \
+ ${RM} -f $${TMPOPTIONSFILE}; \
+ ${ECHO_MSG} "===> Options unchanged"; \
+ exit 0; \
+ }; \
+ if [ ! -e $${TMPOPTIONSFILE} ]; then \
+ ${ECHO_MSG} "===> No user-specified options to save for ${PKGNAME}"; \
+ exit 0; \
+ fi; \
+ SELOPTIONS=$$(${CAT} $${TMPOPTIONSFILE}); \
+ ${RM} -f $${TMPOPTIONSFILE}; \
+ TMPOPTIONSFILE=$$(mktemp -t portoptions); \
+ trap "${RM} -f $${TMPOPTIONSFILE}; exit 1" 1 2 3 5 10 13 15; \
+ ${ECHO_CMD} "# This file is auto-generated by 'make config'." > $${TMPOPTIONSFILE}; \
+ ${ECHO_CMD} "# Options for ${PKGNAME}" >> $${TMPOPTIONSFILE}; \
+ ${ECHO_CMD} "_OPTIONS_READ=${PKGNAME}" >> $${TMPOPTIONSFILE}; \
+ ${ECHO_CMD} "_FILE_COMPLETE_OPTIONS_LIST=${_COMPLETE_OPTIONS_LIST}" >> $${TMPOPTIONSFILE}; \
+ for i in ${_COMPLETE_OPTIONS_LIST}; do \
+ if ${ECHO_CMD} $${SELOPTIONS} | ${GREP} -qw $${i}; then \
+ ${ECHO_CMD} "OPTIONS_FILE_SET+=$${i}" >> $${TMPOPTIONSFILE}; \
+ else \
+ ${ECHO_CMD} "OPTIONS_FILE_UNSET+=$${i}" >> $${TMPOPTIONSFILE}; \
+ fi; \
+ done; \
+ if [ ${UID} != 0 -a "x${INSTALL_AS_USER}" = "x" ]; then \
+ ${ECHO_MSG} "===> Switching to root credentials to write ${OPTIONSFILE}"; \
+ ${SU_CMD} "${CAT} $${TMPOPTIONSFILE} > ${OPTIONSFILE}"; \
+ ${ECHO_MSG} "===> Returning to user credentials"; \
+ else \
+ ${CAT} $${TMPOPTIONSFILE} > ${OPTIONSFILE}; \
+ fi; \
+ ${RM} -f $${TMPOPTIONSFILE}
+ @cd ${.CURDIR} && ${MAKE} sanity-config
+.endif
+.endif # config
+
+.if !target(config-recursive)
+config-recursive:
+ @${ECHO_MSG} "===> Setting user-specified options for ${PKGNAME} and dependencies";
+ @for dir in ${.CURDIR} $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} config-conditional); \
+ done
+.endif # config-recursive
+
+.if !target(config-conditional)
+config-conditional: pre-config
+.if defined(_COMPLETE_OPTIONS_LIST) && !defined(NO_DIALOG)
+. if !defined(_FILE_COMPLETE_OPTIONS_LIST) || ${_COMPLETE_OPTIONS_LIST:O} != ${_FILE_COMPLETE_OPTIONS_LIST:O}
+ @cd ${.CURDIR} && ${MAKE} config;
+. endif
+.endif
+.endif # config-conditional
+
+.if !target(showconfig)
+.include "${PORTSDIR}/Mk/bsd.options.desc.mk"
+showconfig:
+.if !empty(ALL_OPTIONS) || !empty(OPTIONS_SINGLE) || !empty(OPTIONS_MULTI)
+ @${ECHO_MSG} "===> The following configuration options are available for ${PKGNAME}":
+.for opt in ${ALL_OPTIONS}
+. if empty(PORT_OPTIONS:M${opt})
+ @${ECHO_MSG} -n " ${opt}=off"
+. else
+ @${ECHO_MSG} -n " ${opt}=on"
+. endif
+. if !empty(${opt}_DESC)
+ @${ECHO_MSG} -n ": "${${opt}_DESC:Q}
+. endif
+ @${ECHO_MSG} ""
+.endfor
+#multi and conditional multis
+.for multi in ${OPTIONS_MULTI}
+ @${ECHO_MSG} "====> Options available for the multi ${multi}: you have to choose at least one of them"
+. for opt in ${OPTIONS_MULTI_${multi}}
+. if empty(PORT_OPTIONS:M${opt})
+ @${ECHO_MSG} -n " ${opt}=off"
+. else
+ @${ECHO_MSG} -n " ${opt}=on"
+. endif
+. if !empty(${opt}_DESC)
+ @${ECHO_MSG} -n ": "${${opt}_DESC:Q}
+. endif
+ @${ECHO_MSG} ""
+. endfor
+.endfor
+#single and conditional singles
+
+.for single in ${OPTIONS_SINGLE}
+ @${ECHO_MSG} "====> Options available for the single ${single}: you have to select exactly one of them"
+. for opt in ${OPTIONS_SINGLE_${single}}
+. if empty(PORT_OPTIONS:M${opt})
+ @${ECHO_MSG} -n " ${opt}=off"
+. else
+ @${ECHO_MSG} -n " ${opt}=on"
+. endif
+. if !empty(${opt}_DESC)
+ @${ECHO_MSG} -n ": "${${opt}_DESC:Q}
+. endif
+ @${ECHO_MSG} ""
+. endfor
+.endfor
+
+.undef multi
+.undef single
+.undef opt
+ @${ECHO_MSG} "===> Use 'make config' to modify these settings"
+.endif
+.endif # showconfig
+
+.if !target(showconfig-recursive)
+showconfig-recursive:
+ @${ECHO_MSG} "===> The following configuration options are available for ${PKGNAME} and dependencies";
+ @for dir in ${.CURDIR} $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} showconfig); \
+ done
+.endif # showconfig-recursive
+
+.if !target(rmconfig)
+rmconfig:
+.if exists(${OPTIONSFILE})
+ -@${ECHO_MSG} "===> Removing user-configured options for ${PKGNAME}"; \
+ optionsdir=${OPTIONSFILE}; optionsdir=$${optionsdir%/*}; \
+ if [ ${UID} != 0 -a "x${INSTALL_AS_USER}" = "x" ]; then \
+ ${ECHO_MSG} "===> Switching to root credentials to remove ${OPTIONSFILE} and $${optionsdir}"; \
+ ${SU_CMD} "${RM} -f ${OPTIONSFILE} ; \
+ ${RMDIR} $${optionsdir}"; \
+ ${ECHO_MSG} "===> Returning to user credentials"; \
+ else \
+ ${RM} -f ${OPTIONSFILE}; \
+ ${RMDIR} $${optionsdir} 2>/dev/null || return 0; \
+ fi
+.else
+ @${ECHO_MSG} "===> No user-specified options configured for ${PKGNAME}"
+.endif
+.endif # rmconfig
+
+.if !target(rmconfig-recursive)
+rmconfig-recursive:
+ @${ECHO_MSG} "===> Removing user-specified options for ${PKGNAME} and dependencies";
+ @for dir in ${.CURDIR} $$(${ALL-DEPENDS-LIST}); do \
+ (cd $$dir; ${MAKE} rmconfig); \
+ done
+.endif # rmconfig-recursive
+
+.if !target(pretty-print-config)
+pretty-print-config:
+.for opt in ${ALL_OPTIONS}
+. if empty(PORT_OPTIONS:M${opt})
+ @${ECHO_MSG} -n "-${opt} "
+. else
+ @${ECHO_MSG} -n "+${opt} "
+. endif
+.endfor
+.for multi in ${OPTIONS_MULTI}
+ @${ECHO_MSG} -n "${multi}[ "
+. for opt in ${OPTIONS_MULTI_${multi}}
+. if empty(PORT_OPTIONS:M${opt})
+ @${ECHO_MSG} -n "-${opt} "
+. else
+ @${ECHO_MSG} -n "+${opt} "
+. endif
+. endfor
+ @${ECHO_MSG} -n "] "
+.endfor
+.for single in ${OPTIONS_SINGLE}
+ @${ECHO_MSG} -n "${single}( "
+. for opt in ${OPTIONS_SINGLE_${single}}
+. if empty(PORT_OPTIONS:M${opt})
+ @${ECHO_MSG} -n "-${opt} "
+. else
+ @${ECHO_MSG} -n "+${opt} "
+. endif
+. endfor
+ @${ECHO_MSG} -n ") "
+.endfor
+.undef multi
+.undef single
+.undef opt
+ @${ECHO_MSG} ""
+.endif # pretty-print-config
+
+desktop-categories:
+ @categories=""; \
+ for native_category in ${CATEGORIES}; do \
+ c=""; \
+ case $$native_category in \
+ accessibility) c="Accessibility Utility" ;; \
+ archivers) c="Archiving" ;; \
+ astro) c="Astronomy Science Education" ;; \
+ audio) c="Audio AudioVideo" ;; \
+ benchmarks) c="System" ;; \
+ biology) c="Biology Science Education" ;; \
+ cad) c="Engineering" ;; \
+ databases) c="Database" ;; \
+ deskutils) c="Utility" ;; \
+ devel) c="Development" ;; \
+ dns) c="Network" ;; \
+ elisp) c="Development" ;; \
+ emulators) c="Emulator" ;; \
+ finance) c="Finance Office" ;; \
+ ftp) c="FileTransfer Network" ;; \
+ games) c="Game" ;; \
+ gnome) c="GNOME GTK" ;; \
+ mate) c="MATE GTK" ;; \
+ graphics) c="Graphics" ;; \
+ hamradio) c="HamRadio" ;; \
+ haskell) c="Development" ;; \
+ ipv6) c="Network" ;; \
+ irc) c="IRCClient Network" ;; \
+ java) c="Java Development" ;; \
+ kde) c="KDE QT" ;; \
+ lang) c="Development" ;; \
+ lisp) c="Development" ;; \
+ mail) c="Email Office Network" ;; \
+ mbone) c="Network AudioVideo" ;; \
+ multimedia) c="AudioVideo" ;; \
+ net) c="Network" ;; \
+ net-im) c="InstantMessaging Network" ;; \
+ net-mgmt) c="Network" ;; \
+ net-p2p) c="P2P Network" ;; \
+ news) c="News" ;; \
+ pear) c="WebDevelopment Development" ;; \
+ perl5) c="Development" ;; \
+ python) c="Development" ;; \
+ ruby) c="Development" ;; \
+ rubygems) c="Development" ;; \
+ scheme) c="Development" ;; \
+ science) c="Science Education" ;; \
+ security) c="Security System" ;; \
+ shells) c="Shell" ;; \
+ sysutils) c="System Utility" ;; \
+ tcl*|tk*) c="Development" ;; \
+ www) c="Network" ;; \
+ x11-clocks) c="Clock Utility" ;; \
+ x11-fm) c="FileManager" ;; \
+ xfce) c="GTK" ;; \
+ zope) c="WebDevelopment Development" ;; \
+ esac; \
+ if [ -n "$$c" ]; then \
+ categories="$$categories $$c"; \
+ fi; \
+ done; \
+ if [ -n "$$categories" ]; then \
+ for c in Application $$categories; do ${ECHO_MSG} "$$c"; done \
+ | ${SORT} -u | ${TR} '\n' ';'; \
+ ${ECHO_MSG}; \
+ fi
+
+VALID_DESKTOP_CATEGORIES+= Application Core Development Building Debugger IDE \
+ GUIDesigner Profiling RevisionControl Translation Office Calendar \
+ ContactManagement Database Dictionary Chart Email Finance FlowChart PDA \
+ ProjectManagement Presentation Spreadsheet WordProcessor Graphics \
+ 2DGraphics VectorGraphics RasterGraphics 3DGraphics Scanning OCR \
+ Photography Viewer Settings DesktopSettings HardwareSettings \
+ PackageManager Network Dialup InstantMessaging IRCClient FileTransfer \
+ HamRadio News P2P RemoteAccess Telephony WebBrowser WebDevelopment \
+ AudioVideo Audio Midi Mixer Sequencer Tuner Video TV AudioVideoEditing \
+ Player Recorder DiscBurning Game ActionGame AdventureGame ArcadeGame \
+ BoardGame BlocksGame CardGame KidsGame LogicGame RolePlaying Simulation \
+ SportsGame StrategyGame Education Art Construction Music Languages \
+ Science Astronomy Biology Chemistry Geology Math MedicalSoftware Physics \
+ Teaching Amusement Applet Archiving Electronics Emulator Engineering \
+ FileManager Shell Screensaver TerminalEmulator TrayIcon System Filesystem \
+ Monitor Security Utility Accessibility Calculator Clock TextEditor KDE \
+ GNOME GTK MATE Qt Motif Java ConsoleOnly AdvancedSettings
+
+check-desktop-entries:
+.if defined(DESKTOP_ENTRIES)
+ @set -- ${DESKTOP_ENTRIES} XXX; \
+ if [ `${EXPR} \( $$# - 1 \) % 6` -ne 0 ]; then \
+ ${ECHO_MSG} "${PKGNAME}: Makefile error: the DESKTOP_ENTRIES list must contain one or more groups of 6 elements"; \
+ exit 1; \
+ fi; \
+ num=1; \
+ while [ $$# -gt 6 ]; do \
+ entry="#$$num"; \
+ if [ -n "$$4" ]; then \
+ entry="$$entry ($$4)"; \
+ elif [ -n "$$1" ]; then \
+ entry="$$entry ($$1)"; \
+ fi; \
+ if [ -z "$$1" ]; then \
+ ${ECHO_MSG} "${PKGNAME}: Makefile error: in desktop entry $$entry: field 1 (Name) is empty"; \
+ exit 1; \
+ fi; \
+ if [ -z "$$4" ]; then \
+ ${ECHO_MSG} "${PKGNAME}: Makefile error: in desktop entry $$entry: field 4 (Exec) is empty"; \
+ exit 1; \
+ fi; \
+ if [ -n "$$5" ]; then \
+ for c in `${ECHO_CMD} "$$5" | ${TR} ';' ' '`; do \
+ if ! ${ECHO_CMD} ${VALID_DESKTOP_CATEGORIES} | ${GREP} -wq $$c; then \
+ ${ECHO_CMD} "${PKGNAME}: Makefile error: in desktop entry $$entry: category $$c is not a valid desktop category"; \
+ exit 1; \
+ fi; \
+ done; \
+ if ! ${ECHO_CMD} "$$5" | ${GREP} -q ';$$'; then \
+ ${ECHO_MSG} "${PKGNAME}: Makefile error: in desktop entry $$entry: field 5 (Categories) does not end with a semicolon"; \
+ exit 1; \
+ fi; \
+ else \
+ if [ -z "`cd ${.CURDIR} && ${MAKE} desktop-categories`" ]; then \
+ ${ECHO_MSG} "${PKGNAME}: Makefile error: in desktop entry $$entry: field 5 (Categories) is empty and could not be deduced from the CATEGORIES variable"; \
+ exit 1; \
+ fi; \
+ fi; \
+ if [ -z "$$6" ]; then \
+ ${ECHO_MSG} "${PKGNAME}: Makefile error: in desktop entry $$entry: field 6 (StartupNotify) is empty"; \
+ exit 1; \
+ fi; \
+ if [ "x$$6" != "xtrue" ] && [ "x$$6" != "xfalse" ]; then \
+ ${ECHO_MSG} "${PKGNAME}: Makefile error: in desktop entry $$entry: field 6 (StartupNotify) is not \"true\" or \"false\""; \
+ exit 1; \
+ fi; \
+ shift 6; \
+ num=`${EXPR} $$num + 1`; \
+ done
+.else
+ @${DO_NADA}
+.endif
+
+.if !target(install-desktop-entries)
+install-desktop-entries:
+.if defined(DESKTOP_ENTRIES)
+ @(${MKDIR} "${DESKTOPDIR}" 2> /dev/null) || \
+ (${ECHO_MSG} "===> Cannot create ${DESKTOPDIR}, check permissions"; exit 1)
+ @set -- ${DESKTOP_ENTRIES} XXX; \
+ if [ -z "${_DESKTOPDIR_REL}" ]; then \
+ ${ECHO_CMD} "@cwd ${DESKTOPDIR}" >> ${TMPPLIST}; \
+ fi; \
+ while [ $$# -gt 6 ]; do \
+ filename="`${ECHO_CMD} "$$4" | ${TR} -cd [:alnum:]`.desktop"; \
+ pathname="${DESKTOPDIR}/$$filename"; \
+ categories="$$5"; \
+ if [ -z "$$categories" ]; then \
+ categories="`cd ${.CURDIR} && ${MAKE} desktop-categories`"; \
+ fi; \
+ ${ECHO_CMD} "${_DESKTOPDIR_REL}$$filename" >> ${TMPPLIST}; \
+ ${ECHO_CMD} "[Desktop Entry]" > $$pathname; \
+ ${ECHO_CMD} "Type=Application" >> $$pathname; \
+ ${ECHO_CMD} "Version=0.9.4" >> $$pathname; \
+ ${ECHO_CMD} "Encoding=UTF-8" >> $$pathname; \
+ ${ECHO_CMD} "Name=$$1" >> $$pathname; \
+ if [ -n "$$2" ]; then \
+ ${ECHO_CMD} "Comment=$$2" >> $$pathname; \
+ fi; \
+ if [ -n "$$3" ]; then \
+ ${ECHO_CMD} "Icon=$$3" >> $$pathname; \
+ fi; \
+ ${ECHO_CMD} "Exec=$$4" >> $$pathname; \
+ ${ECHO_CMD} "Categories=$$categories" >> $$pathname; \
+ ${ECHO_CMD} "StartupNotify=$$6" >> $$pathname; \
+ shift 6; \
+ done; \
+ ${ECHO_CMD} "@unexec rmdir ${DESKTOPDIR} 2>/dev/null || true" >> ${TMPPLIST}; \
+ if [ -z "${_DESKTOPDIR_REL}" ]; then \
+ ${ECHO_CMD} "@cwd ${PREFIX}" >> ${TMPPLIST}; \
+ fi
+.else
+ @${DO_NADA}
+.endif
+.endif
+
+.if !target(check-license)
+check-license:
+ @${DO_NADA}
+.endif
+
+.if !target(ask-license)
+ask-license:
+ @${DO_NADA}
+.endif
+
+.if !target(install-license)
+install-license:
+ @${DO_NADA}
+.endif
+
+.endif
+# End of post-makefile section.
+
+.endif
+# End of the DESTDIR if statement
diff --git a/Mk/bsd.sites.mk b/Mk/bsd.sites.mk
new file mode 100644
index 0000000..55164f8
--- /dev/null
+++ b/Mk/bsd.sites.mk
@@ -0,0 +1,1534 @@
+# bsd.sites.mk - Popular master sites.
+#
+# Sites_MAINTAINER= ports@FreeBSD.org
+#
+# This file does not have any designated maintainer, so feel free to
+# commit to it yourself. However, it is generally a good idea to
+# notify the principal maintainer in case you have a change to one of
+# the software environments (KDE, GNOME, etc.).
+#
+# Also, this file is included from bsd.port.mk for all invocations, so
+# committing a syntax error to this file is a cardinal sin, and will
+# be punished accordingly. DO NOT COMMIT SOMETHING YOU HAVEN'T TESTED.
+# You have been warned. :)
+#
+# Note: because it is included for all invocations, please keep the size
+# of this file manageable. If a distfile is unfetchable from the first
+# few dozen locations, it is unlikely to be fetchable from any past that,
+# and those fetch failures will simply waste time and bandwidth. Please
+# pick a globally representative subset.
+#
+# Note: all entries should terminate with a slash.
+#
+# $FreeBSD: ports/Mk/bsd.sites.mk,v 1.573 2012/06/16 07:42:23 bf Exp $
+#
+
+# Where to put distfiles that don't have any other master site
+.if !defined(IGNORE_MASTER_SITE_LOCAL)
+MASTER_SITE_LOCAL+= \
+ ftp://ftp.FreeBSD.org/pub/FreeBSD/ports/local-distfiles/%SUBDIR%/ \
+ ftp://ftp.se.FreeBSD.org/pub/FreeBSD/ports/local-distfiles/%SUBDIR%/ \
+ ftp://ftp.uk.FreeBSD.org/pub/FreeBSD/ports/local-distfiles/%SUBDIR%/ \
+ ftp://ftp.ru.FreeBSD.org/pub/FreeBSD/ports/local-distfiles/%SUBDIR%/ \
+ ftp://ftp.jp.FreeBSD.org/pub/FreeBSD/ports/local-distfiles/%SUBDIR%/ \
+ ftp://ftp.tw.FreeBSD.org/pub/FreeBSD/ports/local-distfiles/%SUBDIR%/ \
+ ftp://ftp.cn.FreeBSD.org/pub/FreeBSD/ports/local-distfiles/%SUBDIR%/
+
+MASTER_SITE_PORTS_JP+= \
+ ftp://ports.jp.FreeBSD.org/pub/FreeBSD-jp/ports-jp/LOCAL_PORTS/%SUBDIR%/ \
+ ftp://ftp4.jp.FreeBSD.org/pub/FreeBSD-jp/ports-jp/LOCAL_PORTS/%SUBDIR%/ \
+ ftp://ftp.ics.es.osaka-u.ac.jp/pub/mirrors/FreeBSD-jp/ports-jp/LOCAL_PORTS/%SUBDIR%/
+.endif
+
+##
+## KEEP THIS LIST SORTED
+##
+
+.if !defined(IGNORE_MASTER_SITE_AFTERSTEP)
+MASTER_SITE_AFTERSTEP+= \
+ ftp://ftp.afterstep.org/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/X11/AfterStep/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/X/AfterStep/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_APACHE)
+MASTER_SITE_APACHE+= \
+ http://www.apache.org/dist/%SUBDIR%/ \
+ http://archive.apache.org/dist/%SUBDIR%/ \
+ ftp://ftp-stud.fht-esslingen.de/pub/Mirrors/ftp.apache.org/dist/%SUBDIR%/ \
+ ftp://mir1.ovh.net/ftp.apache.org/dist/%SUBDIR%/ \
+ ftp://ftp.forthnet.gr/pub/www/apache/%SUBDIR%/ \
+ ftp://xenia.sote.hu/pub/mirrors/www.apache.org/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/mirrors/www.apache.org/dist/%SUBDIR%/ \
+ ftp://ftp.rhnet.is/pub/apache/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,net/apache/&,} \
+ ftp://ftp.task.gda.pl/pub/www/apache/dist/%SUBDIR%/ \
+ ftp://sunsite.icm.edu.pl/pub/www/apache/dist/%SUBDIR%/ \
+ ftp://apache.rinet.ru/pub/mirror/apache.org/dist/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/www/servers/apache/dist/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_APACHE_COMMONS_BINARIES)
+MASTER_SITE_APACHE_COMMONS_BINARIES+= \
+ ${MASTER_SITE_APACHE:S,%SUBDIR%,commons/&/binaries,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_APACHE_COMMONS_SOURCE)
+MASTER_SITE_APACHE_COMMONS_SOURCE+= \
+ ${MASTER_SITE_APACHE:S,%SUBDIR%,commons/&/source,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_APACHE_HTTPD)
+MASTER_SITE_APACHE_HTTPD+= \
+ ${MASTER_SITE_APACHE:S,%SUBDIR%,httpd/&,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_APACHE_JAKARTA)
+MASTER_SITE_APACHE_JAKARTA+= \
+ ${MASTER_SITE_APACHE:S,%SUBDIR%,jakarta/&,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_APACHE_TOMCAT)
+MASTER_SITE_APACHE_TOMCAT+= \
+ ${MASTER_SITE_APACHE:S,%SUBDIR%,tomcat/&,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_APACHE_XML)
+MASTER_SITE_APACHE_XML+= \
+ ${MASTER_SITE_APACHE:S,%SUBDIR%,xml/&,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_BERLIOS)
+MASTER_SITE_BERLIOS+= \
+ http://download.berlios.de/%SUBDIR%/ \
+ http://download2.berlios.de/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_CENKES)
+MASTER_SITE_CENKES+= \
+ http://bsd2.cenkes.org/%SUBDIR%/ \
+ http://bsd3.cenkes.org/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_CHEESESHOP)
+MASTER_SITE_CHEESESHOP+= \
+ http://pypi.python.org/packages/%SUBDIR%/ \
+ http://b.pypi.python.org/packages/%SUBDIR%/ \
+ http://c.pypi.python.org/packages/%SUBDIR%/ \
+ http://d.pypi.python.org/packages/%SUBDIR%/ \
+ http://e.pypi.python.org/packages/%SUBDIR%/ \
+ http://f.pypi.python.org/packages/%SUBDIR%/ \
+ http://pypi.inqbus.de/${DISTNAME:S/${DISTVERSION}//:S/-//}/ \
+ http://pypi.it.uwosh.edu/${DISTNAME:S/${DISTVERSION}//:S/-//}/ \
+ http://pypi.python.jp/${DISTNAME:S/${DISTVERSION}//:S/-//}/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_COMP_SOURCES)
+MASTER_SITE_COMP_SOURCES+= \
+ ftp://gatekeeper.dec.com/pub/usenet/comp.sources.%SUBDIR%/ \
+ ftp://ftp.uu.net/usenet/comp.sources.%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_CRITICAL)
+MASTER_SITE_CRITICAL+= \
+ http://critical.ch/distfiles/%SUBDIR%/ \
+ http://energy.critical.ch/distfiles/%SUBDIR%/ \
+ http://snow.critical.ch/distfiles/%SUBDIR%/ \
+ http://www.bluestop.org/distfiles/%SUBDIR%/ \
+ http://fneu.fr/distfiles/%SUBDIR%/ \
+ ftp://ftp.c.saper.info/distfiles/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_CSME)
+MASTER_SITE_CSME+= ${MASTER_SITE_CENKES}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_DEBIAN)
+MASTER_SITE_DEBIAN+= \
+ http://www.gtlib.gatech.edu/pub/debian/%SUBDIR%/ \
+ ftp://ftp.us.debian.org/debian/%SUBDIR%/ \
+ ${MASTER_SITE_DEBIAN_NON_US:S,/debian-non-US/,/debian/,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_DEBIAN_NON_US)
+MASTER_SITE_DEBIAN_NON_US+= \
+ ftp://ftp.au.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.bg.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.br.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.cl.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.cz.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.de.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.ee.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.es.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.fi.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.fr.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.hk.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.hr.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.hu.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.ie.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.is.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.it.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.jp.debian.org/debian-non-US/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,linux/debian/debian-non-US/&,} \
+ ftp://ftp.nl.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.no.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.pl.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.ru.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.se.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.si.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.sk.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.uk.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.wa.au.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp2.de.debian.org/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.snt.utwente.nl/pub/linux/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.df.lth.se/pub/debian-non-US/%SUBDIR%/ \
+ ftp://ftp.acc.umu.se/debian-non-US/%SUBDIR%/ \
+ ftp://mirror.symnds.com/debian-non-US/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_DEBIAN_POOL)
+MASTER_SITE_DEBIAN_POOL+= \
+ ${MASTER_SITE_DEBIAN:C|(/%SUBDIR%/)|/pool/main/${PORTNAME:C/^(.).*$/\1/}/${PORTNAME}/|}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_EASYSW)
+MASTER_SITE_EASYSW+= \
+ http://ftp.easysw.com/pub/%SUBDIR%/ \
+ ftp://ftp.easysw.com/pub/%SUBDIR%/ \
+ ftp://ftp.rz.tu-bs.de/pub/mirror/ftp.easysw.com/ftp/pub/%SUBDIR%/ \
+ http://ftp.funet.fi/pub/mirrors/ftp.easysw.com/pub/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/mirrors/ftp.easysw.com/pub/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_ECLIPSE)
+MASTER_SITE_ECLIPSE+= \
+ ftp://sunsite.informatik.rwth-aachen.de/pub/mirror/eclipse/%SUBDIR%/ \
+ http://sunsite.informatik.rwth-aachen.de/eclipse/downloads/drops/%SUBDIR%/ \
+ ftp://ftp.tu-clausthal.de/pub/eclipse/downloads/drops/%SUBDIR%/ \
+ http://ftp-stud.fht-esslingen.de/pub/Mirrors/eclipse/%SUBDIR%/ \
+ ftp://ftp.unixag-zw.fh-kl.de/pub/mirrors/eclipse/drops/%SUBDIR%/ \
+ http://eclipse.teccomm.les.inf.puc-rio.br/downloads/drops/%SUBDIR%/ \
+ http://www.dawnspill.hu/mirror/eclipse/downloads/drops/%SUBDIR%/ \
+ http://mirrors.ibiblio.org/pub/mirrors/eclipse/eclipse/downloads/drops/%SUBDIR%/ \
+ http://www.eclipse.ps.pl/downloads/drops/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,misc/eclipse/downloads/drops/&,} \
+ ftp://sunsite.cnlab-switch.ch/mirror/eclipse/eclipse/downloads/drops/%SUBDIR%/ \
+ http://download.eclipse.org/eclipse/downloads/drops/%SUBDIR%/ \
+ ftp://download.eclipse.org/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_EXIM)
+MASTER_SITE_EXIM+= \
+ ftp://ftp.exim.org/pub/exim/%SUBDIR%/ \
+ ftp://exim.inode.at/exim/%SUBDIR%/ \
+ ftp://exim-ftp.itsoft.at/exim/exim/%SUBDIR%/ \
+ http://exim-ftp.itsoft.at/exim/%SUBDIR%/ \
+ ftp://ftp.easynet.be/exim/exim/%SUBDIR%/ \
+ ftp://mirror.kn.vutbr.cz/pub/ftp.exim.org/exim/%SUBDIR%/ \
+ http://exim.mirror.fr/exim/%SUBDIR%/ \
+ ftp://ftp.doc.cs.univ-paris8.fr/mirrors/ftp.exim.org/exim/%SUBDIR%/ \
+ http://mirrors.zerg.biz/exim/exim/%SUBDIR%/ \
+ http://dl.ambiweb.de/mirrors/ftp.exim.org/exim/%SUBDIR%/ \
+ ftp://exim.noris.de/exim/%SUBDIR%/ \
+ ftp://ftp.bytemine.net/exim/exim/%SUBDIR%/ \
+ ftp://exim.mirror.iphh.net/ftp/exim/%SUBDIR%/ \
+ http://exim.mirror.iphh.net/ftp/exim/%SUBDIR%/ \
+ ftp://ftp.fu-berlin.de/unix/mail/exim/%SUBDIR%/ \
+ http://exim-ftp.octet.hu/exim/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/pub/exim/%SUBDIR%/ \
+ http://ftp.heanet.ie/pub/exim/%SUBDIR%/ \
+ http://washitake.com/mail/exim/mirror/exim/%SUBDIR%/ \
+ ftp://ftp.tin.org/pub/mail/exim/%SUBDIR%/ \
+ http://exim.psshee.com/ftp/exim/%SUBDIR%/ \
+ ftp://mirror.hostfuss.com/exim/ftp/exim/%SUBDIR%/ \
+ http://mirror.hostfuss.com/exim/ftp/exim/%SUBDIR%/ \
+ ftp://ftp.nl.uu.net/pub/unix/mail/exim/exim/%SUBDIR%/ \
+ ftp://ftp.easynet.nl/mirror/exim/exim/%SUBDIR%/ \
+ ftp://sunsite.uio.no/pub/mail/exim/exim/%SUBDIR%/ \
+ http://piotrkosoft.net/pub/mirrors/ftp.exim.org/exim/%SUBDIR%/ \
+ ftp://ftp.piotrkosoft.net/pub/mirrors/ftp.exim.org/exim/%SUBDIR%/ \
+ ftp://sunsite.icm.edu.pl/pub/unix/mail/exim/exim/%SUBDIR%/ \
+ http://sunsite.icm.edu.pl/pub/unix/mail/exim/exim/%SUBDIR%/ \
+ ftp://ftp.is.co.za/networking/mail/mta/exim/ftp/exim/%SUBDIR%/ \
+ ftp://mirrors.dominios.pt/pub/ftp.exim.org/exim/%SUBDIR%/ \
+ ftp://mirror.switch.ch/mirror/exim/exim/%SUBDIR%/ \
+ http://mirror.switch.ch/ftp/mirror/exim/exim/%SUBDIR%/ \
+ ftp://ftp.reaper.org/pub/exim/exim/%SUBDIR%/ \
+ ftp://sunsite.cnlab-switch.ch/mirror/exim/exim/%SUBDIR%/ \
+ ftp://ftp.demon.co.uk/pub/mirrors/exim/%SUBDIR%/ \
+ ftp://mirror.tje.me.uk/pub/mirrors/ftp.exim.org/exim/%SUBDIR%/ \
+ http://mirror.tje.me.uk/pub/mirrors/ftp.exim.org/exim/%SUBDIR%/ \
+ ftp://mirrors.24-7-solutions.net/pub/exim/ftp/exim/%SUBDIR%/ \
+ http://mirrors.24-7-solutions.net/pub/exim/ftp/exim/%SUBDIR%/ \
+ ftp://ftp.fsckit.net/pub/exim/exim/%SUBDIR%/ \
+ ftp://idcnetwork.org/pub/exim/exim/%SUBDIR%/ \
+ http://ftp.exim.llorien.org/exim/%SUBDIR%
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_FEDORA_LINUX)
+MASTER_SITE_FEDORA_LINUX+= \
+ http://archives.fedoraproject.org/pub/archive/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.udl.es/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.sunet.se/pub/Linux/distributions/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/Linux/distributions/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.udl.es/pub/fedora/linux/core/%SUBDIR%/ \
+ http://mirrors.kernel.org/fedora/core/%SUBDIR%/ \
+ ftp://mirrors.kernel.org/fedora/core/%SUBDIR%/ \
+ http://mirror.web-ster.com/fedora/core/%SUBDIR%/ \
+ ftp://mirror.web-ster.com/fedora/core/%SUBDIR%/ \
+ http://rpmfind.net/linux/fedora/core/%SUBDIR%/ \
+ ftp://rpmfind.net/linux/fedora/core/%SUBDIR%/ \
+ ftp://ftp.gtlib.gatech.edu/pub/fedora.redhat/linux/core/%SUBDIR%/ \
+ ftp://fedora.mirrors.tds.net/pub/fedora-core/%SUBDIR%/ \
+ http://ftp.ndlug.nd.edu/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.ndlug.nd.edu/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.belnet.be/linux/fedora/linux/core/%SUBDIR%/ \
+ http://sunsite.mff.cuni.cz/pub/fedora/%SUBDIR%/ \
+ ftp://sunsite.mff.cuni.cz/pub/fedora/%SUBDIR%/ \
+ ftp://ultra.linux.cz/pub/fedora/%SUBDIR%/ \
+ http://fr2.rpmfind.net/linux/fedora/core/%SUBDIR%/ \
+ ftp://fr2.rpmfind.net/linux/fedora/core/%SUBDIR%/ \
+ http://wftp.tu-chemnitz.de/pub/linux/fedora-core/%SUBDIR%/ \
+ ftp://ftp.tu-chemnitz.de/pub/linux/fedora-core/%SUBDIR%/ \
+ http://ftp.heanet.ie/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://alviss.et.tudelft.nl/pub/fedora/core/%SUBDIR%/ \
+ http://ftp.surfnet.nl/ftp/pub/os/Linux/distr/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.surfnet.nl/pub/os/Linux/distr/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.nluug.nl/ftp/pub/os/Linux/distr/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.nluug.nl/pub/os/Linux/distr/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.uninett.no/pub/linux/Fedora/core/%SUBDIR%/ \
+ http://ftp.man.poznan.pl/pub/linux/fedora/core/%SUBDIR%/ \
+ ftp://ftp.man.poznan.pl/pub/linux/fedora/%SUBDIR%/ \
+ http://ftp.ps.pl/pub/linux/fedora-core/%SUBDIR%/ \
+ ftp://ftp.ps.pl/pub/linux/fedora-core/%SUBDIR%/ \
+ ftp://ftp.kappa.ro/pub/Linux/Distributions/fedora/%SUBDIR%/ \
+ http://www.mirrorservice.org/sites/download.fedora.redhat.com/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/download.fedora.redhat.com/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.hostrino.com/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.sfc.wide.ad.jp/pub/Linux/Fedora/core/%SUBDIR%/ \
+ http://ftp.kddilabs.jp/Linux/packages/fedora/core/%SUBDIR%/ \
+ ftp://ftp.kddilabs.jp/Linux/packages/fedora/core/%SUBDIR%/ \
+ ftp://ftp.riken.go.jp/pub/Linux/fedora/core/%SUBDIR%/ \
+ http://ftp.isu.edu.tw/pub/Linux/Fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.isu.edu.tw/pub/Linux/Fedora/linux/core/%SUBDIR%/ \
+ http://www.las.ic.unicamp.br/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://www.las.ic.unicamp.br/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://mirror.netglobalis.net/pub/fedora/%SUBDIR%/ \
+ http://mirror.pacific.net.au/linux/redhat/fedora/%SUBDIR%/ \
+ ftp://mirror.pacific.net.au/linux/redhat/fedora/%SUBDIR%/ \
+ http://download.fedora.redhat.com/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.univie.ac.at/systems/linux/fedora/core/%SUBDIR%/ \
+ http://mirror.aarnet.edu.au/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://mirror.aarnet.edu.au/pub/fedora/linux/core/%SUBDIR%/ \
+ http://fedora.mirror.iweb.ca/core/%SUBDIR%/ \
+ ftp://fedora.mirror.iweb.ca/core/%SUBDIR%/ \
+ ftp://ftp.telus.net/pub/fedora/linux/core/%SUBDIR%/ \
+ http://fedora.arcticnetwork.ca/linux/core/%SUBDIR%/ \
+ http://www.muug.mb.ca/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.muug.mb.ca/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.solnet.ch/mirror/fedora/linux/core/%SUBDIR%/ \
+ http://mirror.karneval.cz/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.telmexchile.cl/Unix/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.sh.cvut.cz/MIRRORS/fedora/%SUBDIR%/ \
+ ftp://ftp.sh.cvut.cz/MIRRORS/fedora/%SUBDIR%/ \
+ http://sunsite.mff.cuni.cz/MIRRORS/fedora.redhat.com/linux/core/%SUBDIR%/ \
+ ftp://sunsite.mff.cuni.cz/MIRRORS/fedora.redhat.com/linux/core/%SUBDIR%/ \
+ http://ftp-stud.hs-esslingen.de/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp-stud.hs-esslingen.de/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.uni-erlangen.de/pub/Linux/MIRROR.fedora/core/%SUBDIR%/ \
+ ftp://ftp.uni-muenster.de/pub/linux/distributions/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.uni-bayreuth.de/linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.uni-bayreuth.de/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.fu-berlin.de/linux/fedora/core/%SUBDIR%/ \
+ http://ftp.uni-koeln.de/mirrors/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.uni-koeln.de/mirrors/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.informatik.uni-frankfurt.de/pub/linux/Mirror/ftp.redhat.com/fedora/core/%SUBDIR%/ \
+ http://mirrors.ircam.fr/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://mirrors.ircam.fr/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.crihan.fr/mirrors/fedora.redhat.com/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.crihan.fr/mirrors/fedora.redhat.com/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.univ-pau.fr/pub/mirrors/fedora/%SUBDIR%/ \
+ ftp://ftp.lip6.fr/pub/linux/distributions/fedora/%SUBDIR%/ \
+ http://fr.rpmfind.net/linux/fedora/core/%SUBDIR%/ \
+ http://www.gtlib.gatech.edu/pub/fedora.redhat/linux/core/%SUBDIR%/ \
+ http://ftp.rhnet.is/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.rhnet.is/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.unina.it/pub/linux/distributions/fedora/%SUBDIR%/ \
+ ftp://ftp.unina.it/pub/linux/distributions/fedora/%SUBDIR%/ \
+ http://ftp.iij.ad.jp/pub/linux/fedora/core/%SUBDIR%/ \
+ ftp://ftp.iij.ad.jp/pub/linux/fedora/core/%SUBDIR%/ \
+ http://ftp.dti.ad.jp/pub/Linux/Fedora/core/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/Linux/Fedora/core/%SUBDIR%/ \
+ http://ftp.nara.wide.ad.jp/pub/Linux/fedora/core/%SUBDIR%/ \
+ http://ftp.yz.yamagata-u.ac.jp/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.yz.yamagata-u.ac.jp/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.jaist.ac.jp/pub/Linux/Fedora/core/%SUBDIR%/ \
+ ftp://ftp.jaist.ac.jp/pub/Linux/Fedora/core/%SUBDIR%/ \
+ http://ftp.riken.jp/Linux/fedora/core/%SUBDIR%/ \
+ ftp://ftp.kreonet.re.kr/pub/Linux/fedora/core/%SUBDIR%/ \
+ ftp://fedora.ifc.unam.mx/linux/fedora/core/%SUBDIR%/ \
+ ftp://ftp.easynet.nl/mirror/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.quicknet.nl/pub/Linux/download.fedora.redhat.com/core/%SUBDIR%/ \
+ ftp://ftp.uib.no/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.tpnet.pl/d17/fedora/%SUBDIR%/ \
+ http://ftp.wsisiz.edu.pl/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.pbone.net/pub/fedora/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.pwr.wroc.pl/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.pwr.wroc.pl/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://mirrors.hpcf.upr.edu/pub/Mirrors/redhat/download.fedora.redhat.com/%SUBDIR%/ \
+ http://ftp.astral.ro/mirrors/fedora/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.astral.ro/mirrors/fedora/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.iasi.roedu.net/mirrors/fedora.redhat.com/fedora/%SUBDIR%/ \
+ ftp://ftp.rdsor.ro/pub/Linux/Distributions/Fedora/%SUBDIR%/ \
+ http://ftp.chg.ru/pub/Linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.chg.ru/pub/Linux/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.rhd.ru/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.rhd.ru/pub/fedora/linux/core/%SUBDIR%/ \
+ http://ftp.port80.se/fedora/core/%SUBDIR%/ \
+ ftp://ftp.port80.se/fedora/core/%SUBDIR%/ \
+ http://ftp.upjs.sk/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.upjs.sk/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.tlk-l.net/pub/mirrors/fedora.redhat.com/linux/core/%SUBDIR%/ \
+ http://limestone.uoregon.edu/ftp/fedora/%SUBDIR%/ \
+ ftp://limestone.uoregon.edu/fedora/%SUBDIR%/ \
+ ftp://fedora.bu.edu/core/%SUBDIR%/ \
+ http://mirror.anl.gov/pub/fedora-linux-core/%SUBDIR%/ \
+ ftp://mirror.anl.gov/pub/fedora-linux-core/%SUBDIR%/ \
+ ftp://ftp.cse.buffalo.edu/pub/Linux/fedora/linux/core/%SUBDIR%/ \
+ ftp://ftp.applios.net/pub/fedora/linux/core/%SUBDIR%/ \
+ http://mirror.steadfast.net/fedora/core/%SUBDIR%/ \
+ http://mirror.eas.muohio.edu/fedora/linux/core/%SUBDIR%/ \
+ http://mirror.engr.sjsu.edu/pub/fedora/linux/core/%SUBDIR%/ \
+ ftp://wuarchive.wustl.edu/pub/linux/distributions/fedora/%SUBDIR%/ \
+ http://www.gtlib.gatech.edu/pub/fedora.redhat/linux/core/%SUBDIR%/ \
+ ftp://ftp.gtlib.gatech.edu/pub/fedora.redhat/linux/core/%SUBDIR%/ \
+ http://mirror.cogentco.com/pub/linux/fedora/linux/core/%SUBDIR%/ \
+ http://mirrors.tummy.com/pub/fedora.redhat.com/fedora/linux/core/%SUBDIR%/ \
+ ftp://mirrors.tummy.com/pub/fedora.redhat.com/fedora/linux/core/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_FESTIVAL)
+MASTER_SITE_FESTIVAL+= \
+ http://www.festvox.org/packed/festival/%SUBDIR%/ \
+ http://www.cstr.ed.ac.uk/downloads/festival/%SUBDIR%/ \
+ http://stuff.mit.edu/afs/sipb/project/speech-tools/src/festival/festvox.org/packed/festival/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_FESTIVAL_OGI)
+MASTER_SITE_FESTIVAL_OGI+= \
+ ftp://ftp.tuwien.ac.at/opsys/linux/blinux/festival/mirror.ogi-synth_home/ \
+ http://www.cslu.ogi.edu/tts/download/data/
+.endif
+
+#
+# FreeBSD mirror sites
+#
+# For the full list, see the Handbook:
+#
+# http://www.FreeBSD.org/doc/en_US.ISO8859-1/books/handbook/mirrors-ftp.html
+#
+.if !defined(IGNORE_MASTER_SITE_FREEBSD_ORG)
+MASTER_SITE_FREEBSD_ORG+= \
+ ftp://ftp.FreeBSD.org/pub/FreeBSD/%SUBDIR%/ \
+ ftp://ftp.se.FreeBSD.org/pub/FreeBSD/%SUBDIR%/ \
+ ftp://ftp.jp.FreeBSD.org/pub/FreeBSD/%SUBDIR%/ \
+ ftp://ftp.uk.FreeBSD.org/pub/FreeBSD/%SUBDIR%/ \
+ ftp://ftp.ru.FreeBSD.org/pub/FreeBSD/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/FreeBSD/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GCC)
+MASTER_SITE_GCC+= \
+ ${MASTER_SITE_SOURCEWARE:S,%SUBDIR%,gcc/&,} \
+ ftp://gcc.gnu.org/pub/gcc/%SUBDIR%/ \
+ ftp://mirrors.laffeycomputer.com/pub/gcc.gnu.org/pub/gcc/%SUBDIR%/ \
+ ftp://ftp.lip6.fr/pub/gcc/%SUBDIR%/ \
+ ftp://ftp.irisa.fr/pub/mirrors/gcc.gnu.org/gcc/%SUBDIR%/ \
+ ftp://ftp.uvsq.fr/pub/gcc/%SUBDIR%/ \
+ ftp://ftp.gwdg.de/pub/misc/gcc/%SUBDIR%/ \
+ ftp://ftp.mpi-sb.mpg.de/pub/gnu/mirror/gcc.gnu.org/pub/gcc/%SUBDIR%/ \
+ ftp://ftp.iij.ad.jp/pub/gnu/gnu/gcc/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/lang/gcc/%SUBDIR%/ \
+ ftp://ftp.nluug.nl/mirror/languages/gcc/%SUBDIR%/ \
+ ftp://ftp.nctu.edu.tw/computer-languages/C/gcc/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/sources.redhat.com/pub/gcc/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/gnu/gcc/%SUBDIR%/ \
+ ftp://mirror.aarnet.edu.au/pub/gnu/gcc/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GENTOO)
+MASTER_SITE_GENTOO+= \
+ http://ftp.roedu.net/pub/mirrors/gentoo.org/%SUBDIR%/ \
+ http://distro.ibiblio.org/pub/linux/distributions/gentoo/%SUBDIR%/ \
+ http://gentoo.mirrors.pair.com/%SUBDIR%/ \
+ http://gentoo.chem.wisc.edu/gentoo/%SUBDIR%/ \
+ http://adelie.polymtl.ca/%SUBDIR%/ \
+ http://mirrors.tds.net/gentoo/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/www.ibiblio.org/gentoo/%SUBDIR%/ \
+ http://ftp.belnet.be/mirror/rsync.gentoo.org/gentoo/%SUBDIR%/ \
+ http://ftp.easynet.nl/mirror/gentoo/%SUBDIR%/ \
+ http://ftp.snt.utwente.nl/pub/os/linux/gentoo/%SUBDIR%/ \
+ http://trumpetti.atm.tut.fi/gentoo/%SUBDIR%/ \
+ http://sunsite.cnlab-switch.ch/ftp/mirror/gentoo/%SUBDIR%/ \
+ http://linux.rz.ruhr-uni-bochum.de/download/gentoo-mirror/%SUBDIR%/ \
+ http://ftp.uni-erlangen.de/pub/mirrors/gentoo/%SUBDIR%/ \
+ http://darkstar.ist.utl.pt/gentoo/%SUBDIR%/ \
+ http://gentoo.inode.at/%SUBDIR%/ \
+ http://ftp.rhnet.is/pub/gentoo/%SUBDIR%/ \
+ http://gentoo.mirror.sdv.fr/%SUBDIR%/ \
+ http://gentoo.gg3.net/%SUBDIR%/ \
+ http://gentoo.kems.net/%SUBDIR%/ \
+ ftp://ftp.gtlib.gatech.edu/pub/gentoo/%SUBDIR%/ \
+ ftp://mirror.iawnet.sandia.gov/pub/gentoo/%SUBDIR%/ \
+ ftp://ftp.ussg.iu.edu/pub/linux/gentoo/%SUBDIR%/ \
+ ftp://ftp.ucsb.edu/pub/mirrors/linux/gentoo/%SUBDIR%/ \
+ ftp://gentoo.mirrors.pair.com/%SUBDIR%/ \
+ ftp://mirrors.tds.net/gentoo/%SUBDIR%/ \
+ ftp://ftp.belnet.be/mirror/rsync.gentoo.org/gentoo/%SUBDIR%/ \
+ ftp://ftp.easynet.nl/mirror/gentoo/%SUBDIR%/ \
+ ftp://ftp.snt.utwente.nl/pub/os/linux/gentoo/%SUBDIR%/ \
+ ftp://trumpetti.atm.tut.fi/gentoo/%SUBDIR%/ \
+ ftp://sunsite.cnlab-switch.ch/mirror/gentoo/%SUBDIR%/ \
+ ftp://ftp.join.uni-muenster.de/pub/linux/distributions/gentoo/%SUBDIR%/\
+ ftp://ftp6.uni-muenster.de/pub/linux/distributions/gentoo/%SUBDIR%/ \
+ ftp://ftp.tu-clausthal.de/pub/linux/gentoo/%SUBDIR%/ \
+ ftp://sunsite.informatik.rwth-aachen.de/pub/Linux/gentoo/%SUBDIR%/ \
+ ftp://linux.rz.ruhr-uni-bochum.de/gentoo-mirror/%SUBDIR%/ \
+ ftp://ftp.uni-erlangen.de/pub/mirrors/gentoo/%SUBDIR%/ \
+ ftp://darkstar.ist.utl.pt/pub/gentoo/%SUBDIR%/ \
+ ftp://gentoo.inode.at/source/%SUBDIR%/ \
+ ftp://ftp.rhnet.is/pub/gentoo/%SUBDIR%/ \
+ ftp://files.gentoo.gr/%SUBDIR%/ \
+ ftp://ftp.ecc.u-tokyo.ac.jp/GENTOO/%SUBDIR%/ \
+ ftp://gentoo.kems.net/pub/mirrors/gentoo/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GET_E)
+MASTER_SITE_GET_E+= \
+ http://www0.get-e.org/%SUBDIR%/_files/ \
+ http://www1.get-e.org/%SUBDIR%/_files/ \
+ http://www2.get-e.org/%SUBDIR%/_files/ \
+ http://www3.get-e.org/%SUBDIR%/_files/ \
+ http://www4.get-e.org/%SUBDIR%/_files/ \
+ http://www5.get-e.org/%SUBDIR%/_files/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GNOME)
+MASTER_SITE_GNOME+= \
+ ftp://ftp.belnet.be/mirror/ftp.gnome.org/%SUBDIR%/ \
+ http://ftp.acc.umu.se/pub/GNOME/%SUBDIR%/ \
+ ftp://ftp.cse.buffalo.edu/pub/Gnome/%SUBDIR%/ \
+ http://fr2.rpmfind.net/linux/gnome.org/%SUBDIR%/ \
+ http://www.gtlib.gatech.edu/pub/gnome/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/X/gnome/%SUBDIR%/ \
+ http://linorg.usp.br/gnome/%SUBDIR%/ \
+ http://mirror.aarnet.edu.au/pub/gnome/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,X/gnome/&,} \
+ ftp://ftp.kddlabs.co.jp/pub/GNOME/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.gnome.org/pub/GNOME/%SUBDIR%/ \
+ ftp://ftp.nara.wide.ad.jp/pub/X11/GNOME/%SUBDIR%/ \
+ http://ftp.gnome.org/pub/GNOME/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GNU)
+MASTER_SITE_GNU+= \
+ http://ftp.gnu.org/gnu/%SUBDIR%/ \
+ ftp://ftp.gnu.org/gnu/%SUBDIR%/ \
+ http://www.gtlib.gatech.edu/pub/gnu/gnu/%SUBDIR%/ \
+ http://mirrors.kernel.org/gnu/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/GNU/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/GNU/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,GNU/&,} \
+ ftp://ftp.mirrorservice.org/sites/ftp.gnu.org/gnu/%SUBDIR%/ \
+ ftp://ftp.informatik.hu-berlin.de/pub/gnu/gnu/%SUBDIR%/ \
+ ftp://ftp.informatik.rwth-aachen.de/pub/mirror/ftp.gnu.org/pub/gnu/%SUBDIR%/ \
+ http://ftp.funet.fi/pub/gnu/prep/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GNUPG)
+MASTER_SITE_GNUPG+= \
+ http://gnupg.org.favoritelinks.net/%SUBDIR%/ \
+ http://mirror.tje.me.uk/pub/mirrors/ftp.gnupg.org/%SUBDIR%/ \
+ http://dotsrc.org/%SUBDIR%/ \
+ ftp://ftp.freenet.de/pub/ftp.gnupg.org/gcrypt/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.gnupg.org/gcrypt/%SUBDIR%/ \
+ ftp://ftp.iasi.roedu.net/pub/mirrors/ftp.gnupg.org/%SUBDIR%/ \
+ ftp://mirror.cict.fr/gnupg/%SUBDIR%/ \
+ http://artfiles.org/gnupg.org/%SUBDIR%/ \
+ ftp://ftp.franken.de/pub/crypt/mirror/ftp.gnupg.org/gcrypt/%SUBDIR%/ \
+ ftp://ftp.crysys.hu/pub/gnupg/%SUBDIR%/ \
+ ftp://ftp.hi.is/pub/mirrors/gnupg/%SUBDIR%/ \
+ http://ftp.heanet.ie/mirrors/ftp.gnupg.org/gcrypt/%SUBDIR%/ \
+ http://gpg-mirror.5coluna.com/ftp/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/security/gnupg/%SUBDIR%/ \
+ ftp://mirror.switch.ch/mirror/gnupg/%SUBDIR%/ \
+ http://www.mirrorservice.org/sites/ftp.gnupg.org/gcrypt/%SUBDIR%/ \
+ ftp://ftp.gnupg.org/gcrypt/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GNUSTEP)
+MASTER_SITE_GNUSTEP+= \
+ ftp://ftp.gnustep.org/pub/gnustep/%SUBDIR%/ \
+ http://ftp.gnustep.org/pub/gnustep/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GNUSTEP_CH)
+MASTER_SITE_GNUSTEP_CH+= \
+ http://io.debian.net/~tar/ports/distfiles/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GNU_ALPHA)
+MASTER_SITE_GNU_ALPHA+= \
+ ftp://alpha.gnu.org/pub/gnu/%SUBDIR%/ \
+ ftp://ftp.lublin.pl/mirror/alpha.gnu.org/gnu/%SUBDIR%/ \
+ ftp://ftp.ps.pl/mirrors/alpha.gnu.org/pub/gnu/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/mirrors/alpha.gnu.org/gnu/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_GOOGLE_CODE)
+PROJECTHOST?= ${PORTNAME}
+MASTER_SITE_GOOGLE_CODE+= \
+ http://${PROJECTHOST}.googlecode.com/files/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_HORDE)
+MASTER_SITE_HORDE+= \
+ http://ftp.horde.org/pub/%SUBDIR%/ \
+ ftp://ftp.horde.org/pub/%SUBDIR%/ \
+ ftp://ftp.at.horde.org/infosys/webapps/horde/%SUBDIR%/ \
+ ftp://ftp.de.horde.org/mirrors/ftp.de.horde.org/pub/%SUBDIR%/ \
+ ftp://ftp.se.horde.org/mirror/horde/pub/%SUBDIR%/ \
+ ftp://ftp.tw.horde.org/pub/%SUBDIR%/ \
+ ftp://ftp.us.horde.org/pub/software/horde//%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_IDSOFTWARE)
+MASTER_SITE_IDSOFTWARE+= \
+ ftp://ftp.chg.ru/pub/games/idgames/idstuff/%SUBDIR%/ \
+ http://ftp4.de.freesbie.org/pub/misc/ftp.idsoftware.com/idstuff/%SUBDIR%/ \
+ ftp://ftp.fasta.fh-dortmund.de/mirror/idstuff/%SUBDIR%/ \
+ ftp://ftp.fu-berlin.de/pc/games/idgames/idstuff/%SUBDIR%/ \
+ ftp://ftp.gamers.org/pub/idgames/idstuff/%SUBDIR%/ \
+ http://ftp.iinet.net.au/games/idstuff/%SUBDIR%/ \
+ ftp://ftp.mirror.nl/disk2/idsoftware/idstuff/%SUBDIR%/ \
+ ftp://ftp.nsu.ru/mirrors/ftp.idsoftware.com/idstuff/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/vendors/idgames/idstuff/%SUBDIR%/ \
+ ftp://ftp.omen.net.au/games/idstuff/%SUBDIR%/ \
+ ftp://ftp.idsoftware.com/idstuff/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_ISC)
+MASTER_SITE_ISC+= \
+ ftp://ftp.isc.org/isc/%SUBDIR%/ \
+ ftp://ftp.ciril.fr/pub/isc/%SUBDIR%/ \
+ ftp://ftp.freenet.de/pub/ftp.isc.org/isc/%SUBDIR%/ \
+ ftp://ftp.iij.ad.jp/pub/network/isc/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/net/isc/%SUBDIR%/ \
+ ftp://ftp.u-aizu.ac.jp/pub/net/isc/%SUBDIR%/ \
+ ftp://ftp.task.gda.pl/mirror/ftp.isc.org/isc/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/network/isc/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.isc.org/isc/%SUBDIR%/ \
+ ftp://ftp.nominum.com/pub/isc/%SUBDIR%/ \
+ ftp://ftp.ripe.net/mirrors/sites/ftp.isc.org/isc/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/net/isc/isc/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/mirrors/ftp.isc.org/isc/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_KENAI)
+MASTER_SITE_KENAI+= \
+ http://projectkenai.com/downloads/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_KDE)
+MASTER_SITE_KDE+= \
+ http://mirrors.isc.org/pub/kde/%SUBDIR%/ \
+ ftp://ftp.gtlib.gatech.edu/pub/kde/%SUBDIR%/ \
+ ftp://ftp.informatik.hu-berlin.de/pub/Mirrors/ftp.kde.org/%SUBDIR%/ \
+ http://ftp.gtlib.gatech.edu/pub/kde/%SUBDIR%/ \
+ ftp://ftp.oregonstate.edu/pub/kde/%SUBDIR%/ \
+ ftp://ftp.solnet.ch/mirror/KDE/%SUBDIR%/ \
+ ftp://gd.tuwien.ac.at/kde/%SUBDIR%/ \
+ http://gd.tuwien.ac.at/kde/%SUBDIR%/ \
+ ftp://kde.mirrors.tds.net/pub/kde/%SUBDIR%/ \
+ http://kde.mirrors.tds.net/pub/kde/%SUBDIR%/ \
+ ftp://ftp.rz.uni-wuerzburg.de/pub/unix/kde/%SUBDIR%/ \
+ http://mirrors.dotsrc.org/kde/%SUBDIR%/ \
+ ftp://mirrors.dotsrc.org/kde/%SUBDIR%/ \
+ http://kambing.vlsm.org/kde/%SUBDIR%/ \
+ http://mirrors.evolva.ro/kdeftp/%SUBDIR%/ \
+ ftp://ftp.iasi.roedu.net/pub/mirrors/ftp.kde.org/%SUBDIR%/ \
+ ftp://ftp.fi.muni.cz/pub/kde/%SUBDIR%/ \
+ http://ftp.fi.muni.cz/pub/kde/%SUBDIR%/ \
+ ftp://ftp.tuniv.szczecin.pl/pub/kde/%SUBDIR%/ \
+ http://ftp.tuniv.szczecin.pl/pub/kde/%SUBDIR%/ \
+ ftp://sunsite.icm.edu.pl/pub/unix/kde/%SUBDIR%/ \
+ http://sunsite.icm.edu.pl/pub/unix/kde/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/X11/kde/%SUBDIR%/ \
+ http://ftp.sunet.se/pub/X11/kde/%SUBDIR%/ \
+ ftp://ftp.kde.org/pub/kde/%SUBDIR%/ \
+ http://ftp.scarlet.be/pub/kde/%SUBDIR%/ \
+ ftp://ftp.unina.it/pub/Linux/kde/%SUBDIR%/ \
+ http://ftp.unina.it/pub/Linux/kde/%SUBDIR%/ \
+ ftp://ftp.belnet.be/packages/kde/%SUBDIR%/ \
+ ftp://ftp.gwdg.de/pub/x11/kde/%SUBDIR%/ \
+ http://ftp.belnet.be/packages/kde/%SUBDIR%/ \
+ ftp://ftp.lip6.fr/pub/X11/kde/%SUBDIR%/ \
+ http://www-ftp.lip6.fr/pub/X11/kde/%SUBDIR%/ \
+ ftp://ftp.rhnet.is/pub/kde/%SUBDIR%/ \
+ http://ftp.rhnet.is/pub/kde/%SUBDIR%/ \
+ http://ftp-stud.fht-esslingen.de/Mirrors/ftp.kde.org/pub/kde/%SUBDIR%/ \
+ ftp://kde.paralax.org/%SUBDIR%/ \
+ ftp://ftp.cronyx.ru/pub/mirror/kde/%SUBDIR%/ \
+ http://kde.cs.nctu.edu.tw/%SUBDIR%/ \
+ http://ftp.twaren.net/Unix/X/KDE/%SUBDIR%/ \
+ ftp://ftp.na.kde.org/pub/kde/%SUBDIR%/ \
+ ftp://ftp.fu-berlin.de/pub/unix/X11/gui/kde/%SUBDIR%/ \
+ ftp://sunsite.informatik.rwth-aachen.de/pub/Linux/kde/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/X11/kde/%SUBDIR%/ \
+ http://ftp.ntua.gr/pub/X11/kde/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/mirrors/ftp.kde.org/%SUBDIR%/ \
+ http://ftp.heanet.ie/mirrors/ftp.kde.org/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/pub/X11/kde/%SUBDIR%/ \
+ http://ftp.kddlabs.co.jp/pub/X11/kde/%SUBDIR%/ \
+ ftp://ftp.yz.yamagata-u.ac.jp/pub/X11/wm/kde/%SUBDIR%/ \
+ http://ftp.yz.yamagata-u.ac.jp/pub/X11/wm/kde/%SUBDIR%/ \
+ ftp://ftp.ussg.iu.edu/pub/kde/%SUBDIR%/ \
+ http://ftp.ussg.iu.edu/kde/%SUBDIR%/ \
+ ftp://mirror.pacific.net.au/kde/%SUBDIR%/ \
+ http://mirror.pacific.net.au/kde/%SUBDIR%/ \
+ ftp://ftp.sayclub.com/pub/X/KDE/%SUBDIR%/ \
+ http://ftp.sayclub.com/pub/X/KDE/%SUBDIR%/ \
+ ftp://carroll.aset.psu.edu/pub/kde/%SUBDIR%/ \
+ http://mirror.cc.columbia.edu/pub/software/kde/%SUBDIR%/ \
+ ftp://fr2.rpmfind.net/linux/KDE/%SUBDIR%/ \
+ http://fr2.rpmfind.net/linux/KDE/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.kde.org/pub/kde/%SUBDIR%/ \
+ http://www.mirrorservice.org/sites/ftp.kde.org/pub/kde/%SUBDIR%/ \
+ ftp://ftp.xcp.kiev.ua/ftp.kde.org/%SUBDIR%/ \
+ ftp://ftp-stud.fht-esslingen.de/pub/Mirrors/ftp.kde.org/pub/kde/%SUBDIR%/ \
+ http://ftp.gwdg.de/pub/x11/kde/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,X/kde/&,} \
+ ftp://ftp.funet.fi/pub/mirrors/ftp.kde.org/pub/kde/%SUBDIR%/ \
+ http://ftp.funet.fi/pub/mirrors/ftp.kde.org/pub/kde/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_LOGILAB)
+MASTER_SITE_LOGILAB+= \
+ http://ftp.logilab.org/pub/%SUBDIR%/ \
+ ftp://ftp.logilab.org/pub/%SUBDIR%/ \
+ ftp://ftp.logilab.fr/pub/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_MATE)
+MASTER_SITE_MATE+= \
+ http://pub.mate-desktop.org/releases/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_MOZDEV)
+MASTER_SITE_MOZDEV+= \
+ http://ftp.scarlet.be/pub/mozdev/%SUBDIR%/ \
+ http://ftp.rz.tu-bs.de/pub/mirror/downloads.mozdev.org/%SUBDIR%/ \
+ http://ftp.ntua.gr/pub/www/mozdev/%SUBDIR%/ \
+ http://ftp.heanet.ie/pub/mozdev/%SUBDIR%/ \
+ http://mozdev.oregonstate.edu/%SUBDIR%/ \
+ http://ftp.ntua.gr/pub/www/mozdev/%SUBDIR%/ \
+ http://www.devlib.org/mozdev/%SUBDIR%/ \
+ http://ftp.iasi.roedu.net/mirrors/mozdev.org/%SUBDIR%/ \
+ ftp://mozdev.secsup.org/pub/software/mozdev/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/pub/mozdev/%SUBDIR%/ \
+ ftp://ftp.iasi.roedu.net/pub/mirrors/mozdev.org/%SUBDIR%/ \
+ http://mirrors.ibiblio.org/pub/mirrors/mozdev.org/%SUBDIR%/ \
+ http://ftp.osuosl.org/pub/mozdev/%SUBDIR%/
+.endif
+
+# releases.mozilla.org mirror sites
+#
+# For the full list, see the following:
+#
+# http://www.mozilla.org/mirrors.html
+#
+.if !defined(IGNORE_MASTER_SITE_MOZILLA)
+MASTER_SITE_MOZILLA+= \
+ https://ftp.mozilla.org/pub/mozilla.org/%SUBDIR%/ \
+ http://mirror3.mirrors.tds.net/pub/mozilla.org/%SUBDIR%/ \
+ http://mozilla.isc.org/pub/mozilla.org/%SUBDIR%/ \
+ http://releases.mozilla.org/pub/mozilla.org/%SUBDIR%/ \
+ http://kyoto-mz-dl.sinet.ad.jp/pub/mozilla.org/%SUBDIR%/ \
+ http://jp-nii01.mozilla.org/pub/mozilla.org/%SUBDIR%/ \
+ http://jp-nii02.mozilla.org/pub/mozilla.org/%SUBDIR%/ \
+ http://mozilla.mtk.nao.ac.jp/pub/mozilla.org/%SUBDIR%/ \
+ http://mirror.internode.on.net/pub/mozilla/%SUBDIR%/ \
+ http://ftp.acc.umu.se/pub/mozilla.org/%SUBDIR%/ \
+ http://mozilla.c3sl.ufpr.br/releases/%SUBDIR%/ \
+ http://www.gtlib.gatech.edu/pub/mozilla.org/%SUBDIR%/ \
+ ftp://ftp.mozilla.org/pub/mozilla.org/%SUBDIR%/ \
+ ftp://ftp.fh-wolfenbuettel.de/pub/www/mozilla/%SUBDIR%/ \
+ ftp://ftp.informatik.rwth-aachen.de/pub/mirror/ftp.mozilla.org/pub/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,net/www/mozilla/&,} \
+ http://ftp.twaren.net/Unix/Mozilla/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_MOZILLA_EXTENDED)
+MASTER_SITE_MOZILLA_EXTENDED+= \
+ http://releases.mozilla.org/pub/mozilla.org/%SUBDIR%/ \
+ ${MASTER_SITE_MOZILLA}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_MYSQL)
+MASTER_SITE_MYSQL+= \
+ ftp://ftp.fi.muni.cz/pub/mysql/Downloads/%SUBDIR%/ \
+ http://mysql.mirrors.cybercity.dk/Downloads/%SUBDIR%/ \
+ ftp://ftp.fh-wolfenbuettel.de/pub/database/mysql/Downloads/%SUBDIR%/ \
+ ftp://ftp.gwdg.de/pub/misc/mysql/Downloads/%SUBDIR%/ \
+ http://netmirror.org/mirror/mysql.com/Downloads/%SUBDIR%/ \
+ ftp://netmirror.org/mysql.com/Downloads/%SUBDIR%/ \
+ http://mirrors.ntua.gr/MySQL/Downloads/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/databases/mysql/Downloads/%SUBDIR%/ \
+ http://mysql.sote.hu/Downloads/%SUBDIR%/ \
+ ftp://ftp.rhnet.is/pub/mysql/Downloads/%SUBDIR%/ \
+ ftp://mirror.widexs.nl/pub/mysql/Downloads/%SUBDIR%/ \
+ ftp://mirror.switch.ch/mirror/mysql/Downloads/%SUBDIR%/ \
+ http://mysql.dp.ua/Downloads/%SUBDIR%/ \
+ http://mysql.mirrored.ca/Downloads/%SUBDIR%/ \
+ ftp://mirror.services.wisc.edu/mirrors/mysql/Downloads/%SUBDIR%/ \
+ http://mysql.mirrors.pair.com/Downloads/%SUBDIR%/ \
+ ftp://ftp.linorg.usp.br/mysql/Downloads/%SUBDIR%/ \
+ ftp://ftp.cbn.net.id/mirror/mysql/Downloads/%SUBDIR%/ \
+ ftp://ftp.easynet.be/mysql/Downloads/%SUBDIR%/ \
+ http://download.softagency.net/MySQL/Downloads/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_NETBSD)
+MASTER_SITE_NETBSD+= \
+ ftp://ftp.netbsd.org/pub/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.iastate.edu/pub/netbsd/packages/distfiles/%SUBDIR%/ \
+ ftp://netbsd.secsup.org/pub/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.plig.net/pub/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.proxad.net/mirrors/ftp.netbsd.org/packages/distfiles/%SUBDIR%/\
+ ftp://ftp.unina.it/pub/Unix/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.uninett.no/bsd/unix/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://sunsite.uio.no/bsd/unix/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.demon.co.uk/pub/mirrors/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.uk.netbsd.org/pub/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,NetBSD/packages/distfiles/&,} \
+ ftp://ftp.dti.ad.jp/pub/NetBSD/packages/distfiles/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/NetBSD/packages/distfiles/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_NETLIB)
+MASTER_SITE_NETLIB+= \
+ ftp://ftp.netlib.org/%SUBDIR%/ \
+ http://www.netlib.org/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/netlib.bell-labs.com/netlib/%SUBDIR%/ \
+ http://www.mirrorservice.org/sites/netlib.bell-labs.com/netlib/%SUBDIR%/ \
+ ftp://ftp.netlib.no/netlib/%SUBDIR%/ \
+ http://www.netlib.no/netlib/%SUBDIR%/ \
+ ftp://ftp.irisa.fr/pub/netlib/%SUBDIR%/ \
+ http://artfiles.org/netlib.org/%SUBDIR%/ \
+ http://netlib.amss.ac.cn/%SUBDIR%/ \
+ http://netlib.caspur.it/%SUBDIR%/ \
+ http://netlib.sandia.gov/%SUBDIR%/ \
+ http://phase.hpcc.jp/mirrors/netlib/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_NVIDIA)
+MASTER_SITE_NVIDIA+= \
+ http://jp.download.nvidia.com/%SUBDIR%/ \
+ http://us.download.nvidia.com/%SUBDIR%/ \
+ http://tw.download.nvidia.com/%SUBDIR%/ \
+ http://download.nvidia.com/%SUBDIR%/ \
+ http://download1.nvidia.com/%SUBDIR%/ \
+ ftp://download.nvidia.com/%SUBDIR%/ \
+ ftp://download1.nvidia.com/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_OPENBSD)
+MASTER_SITE_OPENBSD+= \
+ http://anga.funkfeuer.at/ftp/pub/OpenBSD/%SUBDIR%/ \
+ http://spargel.kd85.com/ftp/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.eu.openbsd.org/pub/OpenBSD/%SUBDIR%/ \
+ http://obsd.cec.mtu.edu/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.openbsd.org/pub/OpenBSD/%SUBDIR%/ \
+ ftp://openbsd.informatik.uni-erlangen.de/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp5.usa.openbsd.org/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp3.usa.openbsd.org/pub/OpenBSD/%SUBDIR%/ \
+ ftp://rt.fm/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.heanet.ie/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.belnet.be/packages/openbsd/%SUBDIR%/ \
+ http://mirror.public-internet.co.uk/ftp/OpenBSD/%SUBDIR%/ \
+ http://mirror.pacific.net.au/OpenBSD/%SUBDIR%/ \
+ http://ftp.openbsd.dk/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.estpak.ee/pub/OpenBSD/%SUBDIR%/ \
+ http://mirror.internode.on.net/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.chg.ru/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.arcane-networks.fr/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.netbsd.se/OpenBSD/%SUBDIR%/ \
+ http://openbsd.cs.pu.edu.tw/%SUBDIR%/ \
+ http://ftp.wu-wien.ac.at/pub/OpenBSD/%SUBDIR%/ \
+ http://www.mirrorservice.org/pub/OpenBSD/%SUBDIR%/ \
+ http://mirror.switch.ch/ftp/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.jaist.ac.jp/pub/OpenBSD/%SUBDIR%/ \
+ http://ftp.cc.uoc.gr/mirrors/OpenBSD/%SUBDIR%/ \
+ http://mirror.hostfuss.com/pub/OpenBSD/%SUBDIR%/ \
+ http://ivete.fis.unb.br/mirror/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.stacken.kth.se/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.ca.openbsd.org/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.freebsdchina.org/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.dkuug.dk/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.jyu.fi/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.irisa.fr/pub/OpenBSD/%SUBDIR%/ \
+ ftp://openbsd.ftp.fu-berlin.de/pub/OpenBSD/%SUBDIR%/ \
+ ftp://mirror.roothell.org/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.nara.wide.ad.jp/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.inet.no/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.nluug.nl/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.gamma.ru/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.rediris.es/pub/OpenBSD/%SUBDIR%/ \
+ ftp://ftp.su.se/pub/OpenBSD/%SUBDIR%/ \
+ ftp://osmirrors.cerias.purdue.edu/pub/OpenBSD/%SUBDIR%/ \
+ ftp://mirror.iawnet.sandia.gov/pub/OpenBSD/%SUBDIR%/ \
+ ftp://carroll.cac.psu.edu/pub/OpenBSD/%SUBDIR%/ \
+ ftp://openbsd.mirrors.tds.net/pub/OpenBSD/%SUBDIR%/ \
+ http://mirrors.nic.funet.fi/pub/OpenBSD/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_OSSP)
+MASTER_SITE_OSSP+= \
+ ftp://ftp.ossp.org/pkg/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/utils/ossp/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_PACKETSTORM)
+MASTER_SITE_PACKETSTORM+= \
+ http://dl.packetstormsecurity.net/%SUBDIR%/ \
+ http://packetstorm.codar.com.br/%SUBDIR%/ \
+ http://packetstorm.crazydog.pt/%SUBDIR%/ \
+ http://packetstorm.igor.onlinedirect.bg/%SUBDIR%/ \
+ http://packetstorm.interhost.co.il/%SUBDIR%/ \
+ http://packetstorm.foofus.com/%SUBDIR%/ \
+ http://packetstorm.linuxsecurity.com/%SUBDIR%/ \
+ http://packetstorm.tacticalflex.com/%SUBDIR%/ \
+ http://packetstorm.unixteacher.org/%SUBDIR%/ \
+ http://packetstorm.wowhacker.com/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_PERL_CPAN)
+
+_PERL_CPAN_SORT?= modules/by-module
+
+# Please add URI to MASTER_SITE_PERL_CPAN_BY instead of this one.
+MASTER_SITE_PERL_CPAN?=
+
+MASTER_SITE_PERL_CPAN_BY+= \
+ ftp://ftp.cpan.org/pub/CPAN/%CPANSORT%/%SUBDIR%/ \
+ http://www.cpan.dk/%CPANSORT%/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/lang/perl/CPAN/%CPANSORT%/%SUBDIR%/ \
+ http://ftp.jaist.ac.jp/pub/CPAN/%CPANSORT%/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/lang/CPAN/%CPANSORT%/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/lang/perl/CPAN/%CPANSORT%/%SUBDIR%/ \
+ ftp://mirror.hiwaay.net/CPAN/%CPANSORT%/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.funet.fi/pub/languages/perl/CPAN/%CPANSORT%/%SUBDIR%/ \
+ http://at.cpan.org/%CPANSORT%/%SUBDIR%/ \
+ ftp://ftp.auckland.ac.nz/pub/perl/CPAN/%CPANSORT%/%SUBDIR%/ \
+ http://backpan.perl.org/%CPANSORT%/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/languages/perl/CPAN/%CPANSORT%/%SUBDIR%/ \
+ http://cpan.nctu.edu.tw/%CPANSORT%/%SUBDIR%/ \
+ http://ftp.twaren.net/Unix/Lang/CPAN/%CPANSORT%/%SUBDIR%/ \
+ ftp://ftp.cpan.org/pub/CPAN/modules/by-module/%SUBDIR%/ \
+ http://www.cpan.dk/modules/by-module/%SUBDIR%/
+
+_PERL_CPAN_FLAG=${MASTER_SITE_SUBDIR:C/(CPAN):.*$/\1/}
+_PERL_CPAN_ID= ${MASTER_SITE_SUBDIR:C/^CPAN:(.)(.)(.*)$/\1\/\1\2\/\1\2\3/}
+
+.if !empty(_PERL_CPAN_ID) && ${_PERL_CPAN_FLAG:L} == "cpan"
+ _PERL_CPAN_SORT=authors/id/${_PERL_CPAN_ID}
+ MASTER_SITE_PERL_CPAN=${MASTER_SITE_PERL_CPAN_BY:S/%CPANSORT%/${_PERL_CPAN_SORT}/:S/%SUBDIR%\///}
+.else
+ MASTER_SITE_PERL_CPAN=${MASTER_SITE_PERL_CPAN_BY:S/%CPANSORT%/${_PERL_CPAN_SORT}/}
+.endif
+
+.endif
+
+#
+# PostgreSQL mirror sites
+#
+# For the full list, see the following:
+#
+# http://wwwmaster.postgresql.org/download/mirrors-ftp
+#
+# Before update mirror list please consult with fenner's distfiles survey.
+#
+.if !defined(IGNORE_MASTER_SITE_PGSQL)
+MASTER_SITE_PGSQL+= \
+ ftp://ftp.se.postgresql.org/pub/databases/relational/postgresql/%SUBDIR%/ \
+ ftp://ftp9.us.postgresql.org/pub/mirrors/postgresql/%SUBDIR%/ \
+ ftp://ftp10.us.postgresql.org/pub/postgresql/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,misc/db/postgresql/&,} \
+ ftp://ftp.at.postgresql.org/db/www.postgresql.org/pub/%SUBDIR%/ \
+ ftp://ftp.be.postgresql.org/postgresql/%SUBDIR%/ \
+ ftp://ftp2.cz.postgresql.org/pub/postgresql/%SUBDIR%/ \
+ ftp://ftp.ee.postgresql.org/mirrors/postgresql/%SUBDIR%/ \
+ ftp://ftp.de.postgresql.org/mirror/postgresql/%SUBDIR%/ \
+ ftp://ftp3.de.postgresql.org/pub/Mirrors/ftp.postgresql.org/%SUBDIR%/ \
+ ftp://ftp.gr.postgresql.org/pub/databases/postgresql/%SUBDIR%/ \
+ ftp://ftp.ie.postgresql.org/mirrors/ftp.postgresql.org/pub/%SUBDIR%/ \
+ ftp://ftp2.it.postgresql.org/mirrors/postgres/%SUBDIR%/ \
+ http://ftp2.jp.postgresql.org/pub/postgresql/%SUBDIR%/ \
+ ftp://ftp.lv.postgresql.org/pub/postgresql/%SUBDIR%/ \
+ ftp://ftp2.nl.postgresql.org/mirror/postgresql/%SUBDIR%/ \
+ ftp://ftp6.pl.postgresql.org/pub/postgresql/%SUBDIR%/ \
+ ftp://ftp7.pl.postgresql.org/pub/mirror/ftp.postgresql.org/%SUBDIR%/ \
+ ftp://ftp6.ro.postgresql.org/pub/mirrors/ftp.postgresql.org/%SUBDIR%/ \
+ ftp://ftp2.ru.postgresql.org/pub/databases/postgresql/%SUBDIR%/ \
+ ftp://ftp3.ru.postgresql.org/pub/mirror/postgresql/pub/%SUBDIR%/ \
+ ftp://ftp5.es.postgresql.org/mirror/postgresql/%SUBDIR%/ \
+ ftp://ftp3.tw.postgresql.org/pub/postgresql/%SUBDIR%/ \
+ ftp://ftp.postgresql.org/pub/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_PHP)
+MASTER_SITE_PHP+= \
+ http://dk.php.net/%SUBDIR%/ \
+ http://de.php.net/%SUBDIR%/ \
+ http://es.php.net/%SUBDIR%/ \
+ http://fi.php.net/%SUBDIR%/ \
+ http://fr.php.net/%SUBDIR%/ \
+ http://gr.php.net/%SUBDIR%/ \
+ http://it.php.net/%SUBDIR%/ \
+ http://jp.php.net/%SUBDIR%/ \
+ http://se.php.net/%SUBDIR%/ \
+ http://uk3.php.net/%SUBDIR%/ \
+ http://us2.php.net/%SUBDIR%/ \
+ http://br.php.net/%SUBDIR%/ \
+ http://cn.php.net/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,net/www/php/&,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_PYTHON)
+MASTER_SITE_PYTHON+= \
+ http://www.python.org/%SUBDIR%/ \
+ http://python.ilisys.com.au/%SUBDIR%/ \
+ http://ftp.easynet.be/python/%SUBDIR%/ \
+ http://www.linux.org.hk/mirror/python/%SUBDIR%/ \
+ http://mirrors.sunsite.dk/pythonwww/%SUBDIR%/ \
+ http://python.emdia.fi/%SUBDIR%/ \
+ http://SunSITE.Informatik.RWTH-Aachen.DE/python/%SUBDIR%/ \
+ http://www.auth.gr/mirrors/python/%SUBDIR%/ \
+ http://www.cwi.nl/www.python.org/%SUBDIR%/ \
+ http://gnu.kookel.org/ftp/www.python.org/%SUBDIR%/ \
+ http://python.holywar.net/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.python.org/pub/www.python.org/%SUBDIR%/ \
+ http://mirrors.ccs.neu.edu/Python/pub/www.python.org/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_QMAIL)
+MASTER_SITE_QMAIL+= \
+ http://qmail.geto.net/%SUBDIR%/ \
+ http://qmail.palomine.net/%SUBDIR%/ \
+ http://qmail.mirrors.summersault.com/%SUBDIR%/ \
+ http://qmail.cdsinet.net/%SUBDIR%/ \
+ http://qmail.glasswings.com.au/%SUBDIR%/ \
+ http://qmail.psshee.com/%SUBDIR%/ \
+ http://mirrors.sunsite.dk/qmailwww/%SUBDIR%/ \
+ http://www.agria.hu/qmail/%SUBDIR%/ \
+ http://qmail.rhnet.is/%SUBDIR%/ \
+ http://mirrors.dataloss.nl/www.qmail.org/%SUBDIR%/ \
+ http://www.math.ntnu.no/mirror/www.qmail.org/%SUBDIR%/ \
+ http://qmail.netvisao.pt/%SUBDIR%/ \
+ http://qmail.ipg.sk/%SUBDIR%/ \
+ http://qmail.omnis.ch/%SUBDIR%/ \
+ http://qmail.asylog.net/%SUBDIR%/ \
+ http://qmail.blueyonder.co.uk/%SUBDIR%/ \
+ http://www.qmail.org/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_QT)
+MASTER_SITE_QT+= \
+ http://releases.qt-project.org/qt4/source/%SUBDIR%/ \
+ http://mi.mirror.garr.it/mirrors/qt/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/mirrors/trolltech/pub/qt/source/%SUBDIR%/ \
+ http://download.qt.nokia.com/qt/source/%SUBDIR%/ \
+ ftp://ftp.trolltech.com/qt/source/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_REDHAT_LINUX)
+MASTER_SITE_REDHAT_LINUX+= \
+ http://mirrors.usc.edu/pub/linux/distributions/redhat/redhat/linux/%SUBDIR%/ \
+ http://www.gtlib.gatech.edu/pub/redhat/linux/%SUBDIR%/ \
+ ftp://mirror.cs.wisc.edu/pub/mirrors/linux/redhat/%SUBDIR%/ \
+ ftp://ftp.nluug.nl/site/ftp.redhat.com/redhat/linux/%SUBDIR%/ \
+ ftp://ftp.icm.edu.pl/pub/linux/redhat/linux/%SUBDIR%/ \
+ ftp://ftp.riken.go.jp/pub/Linux/redhat/linux/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/pub/Linux/packages/RedHat/redhat/linux/%SUBDIR%/
+.endif
+
+#
+# RingServers in Japan
+#
+#
+# Note: If you know which of the RingServers is nearest to you,
+# please specify it in your /etc/make.conf. (The server list is
+# available at http://www.ring.gr.jp/)
+#
+# You can choose either http or ftp to access to a server:
+#
+# http://<server>/archives/%SUBDIR%/
+# ftp://<server>/pub/%SUBDIR%/
+#
+# {www,ftp}.dnsbalance.ring.gr.jp redirects requests to one of the
+# least busy servers at the moment at the DNS lookup level. (safe to
+# use with "fetch -A")
+#
+# {www,ftp}.t.ring.gr.jp redirects requests to one of the nearest
+# servers at the DNS lookup level. (safe to use with "fetch -A")
+#
+.if !defined(IGNORE_MASTER_SITE_RINGSERVER)
+MASTER_SITE_RINGSERVER+= \
+ http://ring.nict.go.jp/archives/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_RUBY)
+MASTER_SITE_RUBY+= \
+ ftp://ftp.SpringDaemons.com/pub/ruby/ruby/%SUBDIR%/ \
+ ftp://ftp.ruby-lang.org/pub/ruby/%SUBDIR%/ \
+ http://www.ibiblio.org/pub/languages/ruby/%SUBDIR%/ \
+ ftp://xyz.lcs.mit.edu/pub/ruby/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,lang/ruby/&,} \
+ ftp://ftp.fu-berlin.de/unix/languages/ruby/%SUBDIR%/ \
+ ftp://ftp.easynet.be/ruby/ruby/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/lang/ruby/%SUBDIR%/ \
+ ftp://ftp.kr.FreeBSD.org/pub/ruby/%SUBDIR%/ \
+ http://mirrors.sunsite.dk/ruby/%SUBDIR%/ \
+ ftp://ftp.iDaemons.org/pub/mirror/ftp.ruby-lang.org/ruby/%SUBDIR%/
+.endif
+
+# See http://rubyforge.org/credits/
+.if !defined(IGNORE_MASTER_SITE_RUBYFORGE)
+MASTER_SITE_RUBYFORGE+= \
+ http://files.rubyforge.vm.bytemark.co.uk/%SUBDIR%/
+.endif
+
+# See http://rubygems.org/pages/about
+.if !defined(IGNORE_MASTER_SITE_RUBYGEMS)
+MASTER_SITE_RUBYGEMS+= \
+ http://production.s3.rubygems.org/gems/%SUBDIR%/ \
+ http://production.cf.rubygems.org/gems/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_SAMBA)
+MASTER_SITE_SAMBA+= \
+ http://us1.samba.org/samba/ftp/%SUBDIR%/ \
+ http://us2.samba.org/samba/ftp/%SUBDIR%/ \
+ http://us4.samba.org/samba/ftp/%SUBDIR%/ \
+ http://us3.samba.org/samba/ftp/%SUBDIR%/ \
+ ftp://ca.samba.org/%SUBDIR%/ \
+ ftp://de.samba.org/samba.org/%SUBDIR%/ \
+ ftp://ftp.oss.eznetsols.org/samba/%SUBDIR%/ \
+ ftp://ftp.easynet.be/samba/%SUBDIR%/ \
+ ftp://ftp.linuxforum.net/ftp.samba.org/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,net/samba/&,}
+.endif
+
+# List: http://download.savannah.gnu.org/mirmon/
+.if !defined(IGNORE_MASTER_SITE_SAVANNAH)
+MASTER_SITE_SAVANNAH+= \
+ http://nongnu.askapache.com/%SUBDIR%/ \
+ http://mirror.lihnidos.org/GNU/savannah/%SUBDIR%/ \
+ http://ftp.twaren.net/Unix/NonGNU/%SUBDIR%/ \
+ ftp://ftp.twaren.net/Unix/NonGNU/%SUBDIR%/ \
+ http://gnu.mirrors.pair.com/savannah/savannah/%SUBDIR%/ \
+ ftp://gnu.mirrors.pair.com/savannah/%SUBDIR%/ \
+ http://download-mirror.savannah.gnu.org/releases/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_SOURCEFORGE)
+.for mirror in heanet sunet iweb switch surfnet kent freefr \
+ voxel jaist osdn nchc ncu internode ufpr waix
+# garr dfn ovh (redirect as of 2009-Sep-02)
+MASTER_SITE_SOURCEFORGE+= \
+ http://${mirror}.dl.sourceforge.net/project/%SUBDIR%/
+.endfor
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_SOURCEFORGE_JP)
+.for mirror in keihanna osdn qgpop
+MASTER_SITE_SOURCEFORGE_JP+= \
+ http://${mirror}.dl.sourceforge.jp/%SUBDIR%/
+.endfor
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_SOURCEWARE)
+MASTER_SITE_SOURCEWARE+= \
+ http://mirrors.kernel.org/sources.redhat.com/%SUBDIR%/ \
+ http://gd.tuwien.ac.at/gnu/sourceware/%SUBDIR%/ \
+ http://sources-redhat.mirrors.airband.net/%SUBDIR%/ \
+ http://ftp.cs.pu.edu.tw/Linux/sourceware/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/mirrors/sources.redhat.com/pub/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_SUDO)
+MASTER_SITE_SUDO+= \
+ http://www.sudo.ws/sudo/dist/ \
+ http://ftp.arcane-networks.fr/pub/mirrors/sudo/ \
+ http://sudo.p8ra.de/sudo/dist/ \
+ http://sudo.cybermirror.org/ \
+ http://sudo-ftp.basemirror.de/ \
+ http://core.ring.gr.jp/archives/misc/sudo/ \
+ http://www.ring.gr.jp/archives/misc/sudo/ \
+ http://ftp.twaren.net/Unix/Security/Sudo/ \
+ ftp://ftp.sudo.ws/pub/sudo/ \
+ ftp://plier.ucar.edu/pub/sudo/ \
+ ftp://obsd.isc.org/pub/sudo/ \
+ ftp://ftp.uwsg.indiana.edu/pub/security/sudo/ \
+ ftp://ftp.tuwien.ac.at/utils/admin-tools/sudo/ \
+ ftp://sunsite.ualberta.ca/pub/Mirror/sudo/ \
+ ftp://ftp.csc.cuhk.edu.hk/pub/packages/unix-tools/sudo/ \
+ ftp://zoot.tele.dk/pub/sudo/ \
+ ftp://ftp.in2p3.fr/pub/sudo/ \
+ ftp://ftp.arcane-networks.fr/pub/mirrors/sudo/ \
+ ftp://ftp.usbm.de/pub/sudo/ \
+ ftp://ftp.cs.tu-berlin.de/pub/misc/sudo/ \
+ ftp://ftp.informatik.uni-hamburg.de/pub/os/unix/utils/sudo/ \
+ ftp://ftp.st.ryukoku.ac.jp/pub/security/tool/sudo/ \
+ ftp://ftp.cin.nihon-u.ac.jp/pub/misc/sudo/ \
+ ftp://core.ring.gr.jp/pub/misc/sudo/ \
+ ftp://ftp.ring.gr.jp/pub/misc/sudo/ \
+ ftp://sunsite.icm.edu.pl/packages/sudo/ \
+ ftp://mirror.cdmon.com/pub/sudo/ \
+ ftp://ftp.twaren.net/Unix/Security/Sudo/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_SUNSITE)
+MASTER_SITE_SUNSITE+= \
+ http://www.ibiblio.org/pub/Linux/%SUBDIR%/ \
+ http://www.gtlib.gatech.edu/pub/Linux/%SUBDIR%/ \
+ ftp://ftp.cs.tu-berlin.de/pub/linux/Mirrors/sunsite.unc.edu/%SUBDIR%/ \
+ ftp://ftp.physics.auth.gr/pub/mirrors/ibiblio/Linux/%SUBDIR%/ \
+ ftp://ftp.nluug.nl/pub/metalab/%SUBDIR%/ \
+ ftp://ftp.nvg.ntnu.no/pub/mirrors/metalab.unc.edu/%SUBDIR%/ \
+ ftp://ftp.icm.edu.pl/pub/Linux/sunsite/%SUBDIR%/ \
+ ftp://ftp.cse.cuhk.edu.hk/pub4/Linux/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/Linux/metalab.unc.edu/%SUBDIR%/ \
+ ftp://ftp.chg.ru/pub/Linux/sunsite/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_SUSE)
+MASTER_SITE_SUSE+= \
+ http://mirrors.usc.edu/pub/linux/distributions/suse/%SUBDIR%/ \
+ http://mirror.usu.edu/mirrors/suse/%SUBDIR%/ \
+ ftp://mirror.mcs.anl.gov/pub/suse/%SUBDIR%/ \
+ ftp://chuck.ucs.indiana.edu/linux/suse/suse/%SUBDIR%/ \
+ ftp://distro.ibiblio.org/pub/linux/distributions/suse/suse/%SUBDIR%/ \
+ ftp://ftp.oregonstate.edu/pub/suse/suse/%SUBDIR%/ \
+ ftp://ftp.sunsite.utk.edu/pub/linux/suse/suse/%SUBDIR%/ \
+ http://sunsite.utk.edu/ftp/pub/linux/suse/suse/%SUBDIR%/ \
+ http://mirror.tamu.edu/suse/%SUBDIR%/ \
+ ftp://ftp.empiricalnetworks.com/pub/suse/%SUBDIR%/ \
+ http://suse.cs.utah.edu/suse/%SUBDIR%/ \
+ ftp://ftp.belnet.be/linux/suse/suse/%SUBDIR%/ \
+ http://ftp.unicamp.br/pub/suse/%SUBDIR%/ \
+ ftp://mirrors.netbg.com/suse/%SUBDIR%/ \
+ ftp://ftp.suse.cl/pub/suse/%SUBDIR%/ \
+ http://ftp.sh.cvut.cz/MIRRORS/SuSE/pub/%SUBDIR%/ \
+ ftp://ftp.linux.ee/pub/suse/suse/%SUBDIR%/ \
+ ftp://garbo.uwasa.fi/pub/mirrors/suse/%SUBDIR%/ \
+ http://fr2.rpmfind.net/linux/SuSE-Linux/%SUBDIR%/ \
+ http://ftp.iut-bm.univ-fcomte.fr/Suse/suse/%SUBDIR%/ \
+ ftp://ftp.gwdg.de/pub/linux/suse/ftp.suse.com/suse/%SUBDIR%/ \
+ ftp://sunsite.informatik.rwth-aachen.de/pub/Linux/suse/%SUBDIR%/ \
+ ftp://ftp.rz.hu-berlin.de/pub/mirrors/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ ftp://ftp.tu-chemnitz.de/pub/linux/suse/ftp.suse.com/suse/%SUBDIR%/ \
+ ftp://ftp.tu-cottbus.de/pub/unix/linux/suse.com/suse/%SUBDIR%/ \
+ http://ftp.uni-erlangen.de/pub/Linux/MIRROR.suse/pub/suse/%SUBDIR%/ \
+ http://ftp-stud.fht-esslingen.de/pub/Mirrors/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ ftp://ftp.hs.uni-hamburg.de/pub/unix/linux/suse/%SUBDIR%/ \
+ ftp://ftp.rrzn.uni-hannover.de/pub/mirror/linux/suse/%SUBDIR%/ \
+ http://ftp.tu-ilmenau.de/Mirrors/ftp.suse.com/%SUBDIR%/ \
+ ftp://ftp.uni-kassel.de/pub/linux/suse/%SUBDIR%/ \
+ ftp://ftp.join.uni-muenster.de/pub/linux/distributions/suse/%SUBDIR%/ \
+ ftp://ftp.uni-rostock.de/pub/systems/unix/linux/suse/%SUBDIR%/ \
+ ftp://ftp.mpi-sb.mpg.de/pub/linux/mirror/ftp.suse.com/suse/%SUBDIR%/ \
+ ftp://ftp.uni-kl.de/pub/linux/suse/%SUBDIR%/ \
+ ftp://ftp.uni-siegen.de/pub/suse/%SUBDIR%/ \
+ ftp://ftp.uni-mainz.de/pub/software/Linux/suse/%SUBDIR%/ \
+ ftp://ftp.uni-heidelberg.de/pub/linux/suse/%SUBDIR%/ \
+ ftp://ftp.rz.uni-ulm.de/pub/mirrors/suse/%SUBDIR%/ \
+ ftp://ftp.rz.uni-wuerzburg.de/pub/linux/MIRROR.suse/%SUBDIR%/ \
+ ftp://ftp.freenet.de/pub/.disk1/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ ftp://ftp.hu-berlin.de/pub/mirrors/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ ftp://ftp.rz.uni-kiel.de/pub2/linux/suse/%SUBDIR%/ \
+ http://mirrors.sth.sze.hu/linux/suse/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/mirrors/ftp.suse.com/pub/suse/ftp.suse.com/suse/%SUBDIR%/ \
+ ftp://ftp.unina.it/pub/linux/distributions/SuSE/ftp.suse.com/suse/%SUBDIR%/ \
+ ftp://ftp.uniroma2.it/Linux/suse/pub/suse/%SUBDIR%/ \
+ ftp://ftp.riken.jp/Linux/suse/suse/%SUBDIR%/ \
+ ftp://ftp.kddilabs.jp/Linux/packages/SuSE/suse/%SUBDIR%/ \
+ ftp://ftp.novell.co.jp/pub/suse/suse/%SUBDIR%/ \
+ ftp://ftp.kreonet.re.kr/pub/Linux/suse/%SUBDIR%/ \
+ http://ftp.tpnet.pl/vol/d7/ftp.suse.com/%SUBDIR%/ \
+ ftp://ftp.icm.edu.pl/packages/linux-suse/%SUBDIR%/ \
+ http://ftp.iasi.roedu.net/pub/mirrors/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ http://ftp.idilis.ro/mirrors/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/Linux/distributions/suse/suse/%SUBDIR%/ \
+ ftp://ftp.solnet.ch/mirror/SuSE/%SUBDIR%/ \
+ ftp://sunsite.cnlab-switch.ch/mirror/SuSE/suse/%SUBDIR%/ \
+ http://ftp.isu.edu.tw/pub/Linux/SuSE/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ http://www.mirrorservice.org/sites/ftp.suse.com/pub/suse/%SUBDIR%/ \
+ ftp://ftp.kde.org/pub/suse/ftp.suse.com/suse/%SUBDIR%/ \
+ ftp://ftp.suse.com/pub/suse/%SUBDIR%/ \
+ ftp://ftp.softnet.tuc.gr/pub/linux/suse/suse/%SUBDIR%/ \
+ http://ftp.softnet.tuc.gr/pub/linux/suse/suse/%SUBDIR%/ \
+ ftp://ftp.is.co.za/linux/distributions/suse/%SUBDIR%/ \
+ http://ftp.sun.ac.za/ftp/mirrorsites/suse/%SUBDIR%/ \
+ ftp://ftp.rediris.es/pub/linux/distributions/suse/pub/suse/%SUBDIR%/ \
+ ftp://ftp.cb.spb.ru/.1/Linux-Distrib/Suse/%SUBDIR%/ \
+ ftp://ftp.neva.ru/.1/Linux-Distrib/Suse/%SUBDIR%/ \
+ ftp://ftp.chg.ru/pub/Linux/SuSE/suse/%SUBDIR%/ \
+ http://mirror.pacific.net.au/linux/suse/%SUBDIR%/ \
+ ftp://mirror.aarnet.edu.au/pub/suse/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_TCLTK)
+MASTER_SITE_TCLTK+= \
+ ftp://ftp.tcl.tk/pub/tcl/%SUBDIR%/ \
+ ftp://sunsite.utk.edu/pub/tcl/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/lang/tcl/ftp.scriptics.com/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.tcl.tk/pub/tcl/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/languages/tcl/tcl/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_TEX_CTAN)
+MASTER_SITE_TEX_CTAN+= \
+ ftp://ctan.unsw.edu.au/tex-archive/%SUBDIR%/ \
+ ftp://ftp.tex.ac.uk/tex-archive/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/CTAN/%SUBDIR%/ \
+ ftp://ctan.tug.org/tex-archive/%SUBDIR%/ \
+ ftp://ftp.dante.de/tex-archive/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,text/CTAN/&,} \
+ ftp://ftp.chg.ru/pub/TeX/CTAN/%SUBDIR%/ \
+ ftp://mirror.macomnet.net/pub/CTAN/%SUBDIR%/ \
+ ftp://ftp.funet.fi/pub/TeX/CTAN/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_THEMES)
+MASTER_SITE_THEMES+= \
+ http://download.freshmeat.net/themes/%SUBDIR%/ \
+ ftp://gd.tuwien.ac.at/opsys/linux/freshmeat/themes/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_TUCOWS)
+.for mirror in ankara blueyonder casemanl chariot clix dataphone dialog epix \
+ fastweb genotec hellasonline iinets inspirenet latvia mclink netvisao \
+ ns-linux nyi otenet personainternet pl-task ukms
+MASTER_SITE_TUCOWS+= \
+ http://${mirror}.linux.tucows.com/files/%SUBDIR%/
+.endfor
+MASTER_SITE_TUCOWS+= \
+ http://www12.tucows.com/linux/files/%SUBDIR%/ \
+ http://linux.tucows.gunadarma.ac.id/files/%SUBDIR%/ \
+ http://linuxberg.ankara.edu.tr/files/%SUBDIR%/
+.endif
+
+# List: http://www.vim.org/mirrors.php
+# Updated: 2011-09-12
+.if !defined(IGNORE_MASTER_SITE_VIM)
+MASTER_SITE_VIM+= \
+ http://ftp.au.vim.org/pub/vim/unix/ \
+ http://ftp.gr.vim.org/pub/vim/unix/ \
+ http://ftp.ie.vim.org/pub/ftp.vim.org/pub/vim/unix/ \
+ http://ftp.ro.vim.org/mirrors/ftp.vim.org/unix/ \
+ http://ftp.stut.edu.tw/vim/unix/ \
+ http://ftp.tw.vim.org/pub/vim/unix/ \
+ http://ftp2.pl.vim.org/pub/vim/unix/ \
+ http://ftp2.tw.vim.org/pub/vim/unix/ \
+ http://ftp2.uk.vim.org/pub/vim/unix/ \
+ http://mirror.hostfuss.com/pub/vim/unix/ \
+ http://tweedo.com/mirror/ftp.vim.org/unix/ \
+ http://vim.cybermirror.org/unix/ \
+ http://vim.mirror.fr/unix/ \
+ http://vim.site2nd.org/unix/ \
+ http://ftp.vim.org/pub/vim/unix/ \
+ ftp://ftp.ca.vim.org/pub/vim/unix/ \
+ ftp://ftp.cz.vim.org/vim/unix/ \
+ ftp://ftp.de.vim.org/unix/ \
+ ftp://ftp.home.vim.org/pub/vim/unix/ \
+ ftp://ftp.is.vim.org/pub/vim/unix/ \
+ ftp://ftp.jp.vim.org/pub/vim/unix/ \
+ ftp://ftp.kr.vim.org/pub/vim/unix/ \
+ ftp://ftp.nl.vim.org/pub/vim/unix/ \
+ ftp://ftp.sk.vim.org/pub/vim/unix/ \
+ ftp://ftp.stut.edu.tw/pub/vim/unix/ \
+ ftp://ftp.tw.vim.org/pub/vim/unix/ \
+ ftp://ftp.uk.vim.org/pub/vim/unix/ \
+ ftp://ftp3.de.vim.org/pub/vim/unix/ \
+ ftp://ftp3.nl.vim.org/pub/vim/unix/ \
+ ftp://ftp9.us.vim.org/pub/vim/unix/ \
+ ftp://vim.tsu.ru/pub/vim/unix/ \
+ ftp://ftp.vim.org/pub/vim/unix/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_WINDOWMAKER)
+MASTER_SITE_WINDOWMAKER+= \
+ ftp://ftp.windowmaker.info/pub/%SUBDIR%/ \
+ ftp://ftp.uvsq.fr/pub/X11/window-managers/windowmaker/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/X/WindowMaker/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_XCONTRIB)
+MASTER_SITE_XCONTRIB+= \
+ ftp://ftp.gwdg.de/pub/x11/x.org/contrib/%SUBDIR%/ \
+ ftp://ftp.x.org/contrib/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/X11/ftp.x.org/contrib/%SUBDIR%/ \
+ ftp://ftp.dti.ad.jp/pub/X/XFree86/mirror/X.Org/contrib/%SUBDIR%/ \
+ ftp://ftp.kddlabs.co.jp/X11/ftp.x.org/contrib/%SUBDIR%/ \
+ ftp://ftp2.x.org/contrib/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,X/opengroup/contrib/&,} \
+ ftp://ftp.mirrorservice.org/sites/ftp.x.org/contrib/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_XEMACS)
+MASTER_SITE_XEMACS+= \
+ http://ftp.it.xemacs.org/%SUBDIR%/ \
+ http://ftp.pt.xemacs.org/%SUBDIR%/ \
+ http://xemacsftp.hkmirror.org/%SUBDIR%/ \
+ http://ftp.dti.ad.jp/pub/unix/editor/xemacs/%SUBDIR%/ \
+ http://ftp.xemacs.org/pub/xemacs/%SUBDIR%/ \
+ ftp://ftp.be.xemacs.org/xemacs/%SUBDIR%/ \
+ ftp://ftp.ch.xemacs.org/mirror/xemacs/%SUBDIR%/ \
+ ftp://ftp.de.xemacs.org/pub/ftp.xemacs.org/tux/xemacs/%SUBDIR%/ \
+ ftp://ftp.fi.xemacs.org/pub/mirrors/ftp.xemacs.org/pub/tux/xemacs/%SUBDIR%/ \
+ ftp://ftp.fr.xemacs.org/pub/xemacs/%SUBDIR%/ \
+ ftp://ftp.gr.xemacs.org/mirrors/XEmacs/ftp/%SUBDIR%/ \
+ ftp://ftp.heanet.ie/mirrors/ftp.xemacs.org/%SUBDIR%/ \
+ ftp://ftp.ie.xemacs.org/mirrors/ftp.xemacs.org/pub/xemacs/%SUBDIR%/ \
+ ftp://ftp.no.xemacs.org/pub/xemacs/%SUBDIR%/ \
+ ftp://ftp.pasteur.fr/pub/computing/xemacs/%SUBDIR%/ \
+ ftp://ftp.sa.xemacs.org/pub/xemacs.org/%SUBDIR%/ \
+ ftp://ftp.se.xemacs.org/pub/gnu/xemacs/%SUBDIR%/ \
+ ftp://ftp.tw.xemacs.org/Unix/Editors/XEmacs/%SUBDIR%/ \
+ ftp://ftp.uk.xemacs.org/sites/ftp.xemacs.org/pub/xemacs/%SUBDIR%/ \
+ ftp://ftp.yz.yamagata-u.ac.jp/pub/misc/xemacs/%SUBDIR%/ \
+ ftp://xemacs.xmundo.net/pub/mirrors/xemacs/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,text/xemacs/&,}
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_XFCE)
+MASTER_SITE_XFCE+= \
+ http://slackware.dreamhost.com/xfce/%SUBDIR%/ \
+ http://mirror.perldude.de/archive.xfce.org/%SUBDIR%/ \
+ http://archive.be.xfce.org/%SUBDIR%/ \
+ http://archive.be2.xfce.org/%SUBDIR%/ \
+ http://archive.se.xfce.org/%SUBDIR%/ \
+ http://archive.al-us.xfce.org/%SUBDIR%/ \
+ http://mirrors.tummy.com/pub/archive.xfce.org/%SUBDIR%/ \
+ http://mirror.yongbok.net/X11/xfce-mirror/%SUBDIR%/ \
+ http://xfce.ognisco.com/%SUBDIR%/ \
+ http://mirror.sinn3r.org/xfce/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_XORG)
+MASTER_SITE_XORG+= \
+ ftp://ftp.cs.cuhk.edu.hk/pub/X11/%SUBDIR%/ \
+ ftp://ftp.unicamp.br/pub/X11/releases/%SUBDIR%/ \
+ ftp://ftp.ntua.gr/pub/X11/X.org/%SUBDIR%/ \
+ ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,X/opengroup/&/,} \
+ ftp://ftp.task.gda.pl/mirror/ftp.x.org/pub/%SUBDIR%/ \
+ ftp://ftp.sunet.se/pub/X11/ftp.x.org/%SUBDIR%/ \
+ ftp://ftp.mirrorservice.org/sites/ftp.x.org/pub/%SUBDIR%/ \
+ ftp://sunsite.uio.no/pub/X11/%SUBDIR%/ \
+ http://xorg.freedesktop.org/%SUBDIR%/ \
+ http://xorg.freedesktop.org/releases/%SUBDIR%/ \
+ ftp://ftp.x.org/pub/%SUBDIR%/
+.endif
+
+.if !defined(IGNORE_MASTER_SITE_KERNEL_ORG)
+MASTER_SITE_KERNEL_ORG+= \
+ http://kernel.org/pub/%SUBDIR%/ \
+ http://www.us.kernel.org/pub/%SUBDIR%/ \
+ http://www.no.kernel.org/pub/%SUBDIR%/ \
+ http://www.de.kernel.org/pub/%SUBDIR%/ \
+ http://www.it.kernel.org/pub/%SUBDIR%/ \
+ http://www.ru.kernel.org/pub/%SUBDIR%/ \
+ http://www.au.kernel.org/pub/%SUBDIR%/ \
+ http://ftp.ntu.edu.tw/%SUBDIR%/ \
+ http://ftp.sunet.se/pub/Linux/kernel.org/%SUBDIR%/ \
+ http://ftp.yandex.ru/pub/%SUBDIR%/ \
+ http://ftp.heanet.ie/pub/%SUBDIR%/ \
+ http://slackware.cs.utah.edu/pub/kernel.org/pub/%SUBDIR%/
+.endif
+
+# Macro magic
+
+MASTER_SITES_ABBREVS= CPAN:PERL_CPAN \
+ NL:NETLIB \
+ SF:SOURCEFORGE \
+ SFJP:SOURCEFORGE_JP \
+ RG:RUBYGEMS \
+ RF:RUBYFORGE
+MASTER_SITES_SUBDIRS= \
+ APACHE_JAKARTA:${PORTNAME:S,-,/,}/source \
+ BERLIOS:${PORTNAME:L} \
+ CENKES:myports \
+ CHEESESHOP:source/${DISTNAME:C/(.).*/\1/}/${DISTNAME:C/(.*)-[0-9].*/\1/} \
+ CSME:myports \
+ DEBIAN:pool/main/${PORTNAME:C/^((lib)?.).*$/\1/}/${PORTNAME} \
+ GCC:releases/${DISTNAME} \
+ GNOME:sources/${PORTNAME}/${PORTVERSION:C/^([0-9]+\.[0-9]+).*/\1/} \
+ GNU:${PORTNAME} \
+ HORDE:${PORTNAME} \
+ LOGILAB:${PORTNAME} \
+ MATE:${PORTVERSION:C/^([0-9]+\.[0-9]+).*/\1/} \
+ MOZDEV:${PORTNAME:L} \
+ NETLIB:${PORTNAME} \
+ PERL_CPAN:${PORTNAME:C/-.*//} \
+ PNET:${PNET_MASTER_SITE_SUBDIR} \
+ PYTHON:${PYTHON_MASTER_SITE_SUBDIR} \
+ RUBY_DBI:${RUBY_DBI_MASTER_SITE_SUBDIR} \
+ RUBY_GNOME:${RUBY_GNOME_MASTER_SITE_SUBDIR} \
+ SAVANNAH:${PORTNAME:L} \
+ SOURCEFORGE:${PORTNAME:L}/${PORTNAME:L}/${PORTVERSION} \
+ RUBYFORGE:${PORTNAME:L}
+
+.if defined(MASTER_SITES) && ${MASTER_SITES:N*\:/*}
+
+.for _site__ in ${MASTER_SITES}
+_site_=${_site__}
+. if ${_site_:M*\:/*}
+MASTER_SITES_EXP+= ${_site_}
+MASTER_SITES_EXP:= ${MASTER_SITES_EXP}
+. else
+_site_urlpath_= ${_site_:C@^(.*):[^/:]+$@\1@}
+. if ${_site_urlpath_:M*/*}
+_site_url_= ${_site_urlpath_:C@^([^/]+)/.*$@\1@}
+_site_subdir_= ${_site_urlpath_:S/^${_site_urlpath_:C@^([^/]+)/.*$@\1@}//:S!^/!!:S!/$!!}
+. else
+_site_url_= ${_site_urlpath_}
+.undef _site_subdir_
+. endif
+_site_group_= ${_site_:S/^${_site_:C@^(.*):[^/:]+$@\1@}//:S/^://}
+. for _abbrev_ in ${MASTER_SITES_ABBREVS}
+. if ${_site_url_} == ${_abbrev_:C/:.*//}
+_site_url_= ${_abbrev_:C/.*://}
+. endif
+. endfor
+. for _subdir_ in ${MASTER_SITES_SUBDIRS}
+. if ${_site_url_} == ${_subdir_:C/:.*//} && !defined(MASTER_SITE_SUBDIR)
+_site_subdir_?= ${_subdir_:C/.*://}
+. endif
+. endfor
+. ifdef MASTER_SITE_${_site_url_}
+. ifdef _site_subdir_
+MASTER_SITES_EXP+= ${MASTER_SITE_${_site_url_}:S^%SUBDIR%^${_site_subdir_}^:S/$/:${_site_group_}/:S/:$//}
+. else
+MASTER_SITES_EXP+= ${MASTER_SITE_${_site_url_}:S/$/:${_site_group_}/:S/:$//}
+. endif
+MASTER_SITES_EXP:= ${MASTER_SITES_EXP}
+. endif
+. endif
+.endfor
+MASTER_SITES= ${MASTER_SITES_EXP}
+
+.endif
diff --git a/TODO-mate b/TODO-mate
new file mode 100644
index 0000000..ac21c98
--- /dev/null
+++ b/TODO-mate
@@ -0,0 +1,38 @@
+-Clean up in the bsd.mate.mk.
+-Document in the bsd.mate.mk.
+-Create matehier and clean up all pkg-plist.
+-Test these ports in the runtime.
+-Ports that need to be recopied. The single space means that it's done.
+
+------------------------------
+ devel/gnome-common -> devel/mate-common
+ textproc/gnome-doc-utils -> textproc/mate-doc-utils
+ devel/ORBit2 -> devel/mate-corba
+ devel/gconf2 -> devel/mate-conf
+ devel/libbonobo -> devel/libmatecomponent
+ misc/gnome-mime-data -> misc/mate-mime-data
+ devel/gnome-vfs -> devel/mate-vfs
+ x11/libgnome -> x11/libmate
+ graphics/libgnomecanvas -> graphics/libmatecanvas
+ x11-toolkits/libbonoboui -> x11-toolkits/libmatecomponentui
+security/libgnome-keyring -> security/libmatekeyring
+security/gnome-keyring -> security/mate-keyring
+x11-toolkits/libgnomeui -> x11-toolkits/libmateui
+devel/libnotify -> devel/libmatenotify
+x11/libgnomekbd -> x11/libmatekbd
+net/libgweather -> net/libmateweather
+misc/gnome-icon-theme -> misc/mate-icon-theme
+x11/zenity -> x11/mate-dialogs
+x11/gnome-desktop -> x11/mate-desktop
+x11-fm/nautilus -> x11-fm/mate-file-manager (or caja?)
+deskutils/notification-daemon -> deskutils/mate-notification-daemon
+x11-themes/gnome-backgrounds -> x11-themes/mate-backgrounds
+x11/gnome-menus -> x11/mate-menus
+x11-wm/metacity -> x11-wm/mate-window-manager (or marco?)
+sysutils/polkit-gnome -> sysutils/mate-polkit
+sysutils/gnome-settings-daemon -> sysutils/mate-settings-daemon
+sysutils/gnome-control-center -> sysutils/mate-control-center
+x11/gnome-panel -> x11/mate-panel
+x11/gnome-session -> x11/mate-session-manager (or mate-session?)
+x11-themes/gnome-themes -> x11-themes/mate-themes
+------------------------------
diff --git a/devel/libmatecomponent/Makefile b/devel/libmatecomponent/Makefile
new file mode 100644
index 0000000..143e06f
--- /dev/null
+++ b/devel/libmatecomponent/Makefile
@@ -0,0 +1,38 @@
+# New ports collection makefile for: libbonobo
+# Date Created: 14 February 2002
+# Whom: Maxim Sobolev <sobomax@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= libmatecomponent
+PORTVERSION= 1.2.1
+CATEGORIES= devel mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= A component and compound document system for MATE
+
+BUILD_DEPENDS= gtkdoc-check:${PORTSDIR}/textproc/gtk-doc
+LIB_DEPENDS= popt.0:${PORTSDIR}/devel/popt
+
+USE_XZ= yes
+USE_MATE= autogen common:build corba intlhack ltverhack matehack
+USE_BISON= build
+USE_GMAKE= yes
+USE_GNOME= libxml2
+USE_PERL5= yes
+USE_GETTEXT= yes
+USE_LDCONFIG= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env libtool libtoolize:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --with-html-dir=${PREFIX}/share/doc \
+ --disable-gtk-doc
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib ${PTHREAD_LIBS}
+
+MAN1= matecomponent-activation-server.1
+
+.include <bsd.port.mk>
diff --git a/devel/libmatecomponent/distinfo b/devel/libmatecomponent/distinfo
new file mode 100644
index 0000000..5908582
--- /dev/null
+++ b/devel/libmatecomponent/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/libmatecomponent-1.2.1.tar.xz) = de9a842c5b329c68c852dfe3c686c908f77f52c2f0533e10f22c130e1a7df9d5
+SIZE (mate/libmatecomponent-1.2.1.tar.xz) = 752516
diff --git a/devel/libmatecomponent/files/patch-activation-server_Makefile.am b/devel/libmatecomponent/files/patch-activation-server_Makefile.am
new file mode 100644
index 0000000..b89036e
--- /dev/null
+++ b/devel/libmatecomponent/files/patch-activation-server_Makefile.am
@@ -0,0 +1,11 @@
+--- activation-server/Makefile.am.orig 2012-07-05 15:29:51.000000000 -0500
++++ activation-server/Makefile.am 2012-07-05 15:32:37.000000000 -0500
+@@ -12,7 +12,7 @@
+ -I$(top_builddir)/matecomponent-activation \
+ -I$(top_srcdir)/matecomponent-activation \
+ -DPREFIX=\""$(prefix)"\" \
+- -DSERVERINFODIR=\"$(libdir)/matecomponent/servers\" \
++ -DSERVERINFODIR=\"$(prefix)/libdata/matecomponent/servers:${LOCALBASE}/libdata/matecomponent/servers\" \
+ -DSERVER_LOCALEDIR=\""${prefix}/${DATADIRNAME}/locale"\" \
+ $(SERVER_CFLAGS) \
+ $(WARN_CFLAGS) \
diff --git a/devel/libmatecomponent/files/patch-activation-server_activation-server-main.c b/devel/libmatecomponent/files/patch-activation-server_activation-server-main.c
new file mode 100644
index 0000000..964a5ee
--- /dev/null
+++ b/devel/libmatecomponent/files/patch-activation-server_activation-server-main.c
@@ -0,0 +1,11 @@
+--- activation-server/activation-server-main.c.orig 2012-07-04 23:17:22.000000000 -0500
++++ activation-server/activation-server-main.c 2012-07-04 23:17:42.000000000 -0500
+@@ -239,7 +239,7 @@
+ g_string_append (mate_od_source_dir,
+ mate_dirs[i]);
+ g_string_append (mate_od_source_dir,
+- "/lib/matecomponent/servers" G_SEARCHPATH_SEPARATOR_S);
++ "/libdata/matecomponent/servers" G_SEARCHPATH_SEPARATOR_S);
+ }
+ g_strfreev (mate_dirs);
+ g_string_append (real_od_source_dir,
diff --git a/devel/libmatecomponent/files/patch-utils_matecomponent-slay.in b/devel/libmatecomponent/files/patch-utils_matecomponent-slay.in
new file mode 100644
index 0000000..0da0012
--- /dev/null
+++ b/devel/libmatecomponent/files/patch-utils_matecomponent-slay.in
@@ -0,0 +1,21 @@
+--- utils/matecomponent-slay.in.orig 2012-07-04 23:13:41.000000000 -0500
++++ utils/matecomponent-slay.in 2012-07-04 23:14:52.000000000 -0500
+@@ -64,15 +64,15 @@
+
+ # get MateComponent files
+ #
+-@matecomponent_dirs = ( "@prefix@/lib/matecomponent/servers" );
++@matecomponent_dirs = ( "@prefix@/libdata/matecomponent/servers" );
+ foreach $dir (split(':', $ENV{'MATECOMPONENT_ACTIVATION_INFO_PATH'})) {
+ if (-d $dir) {
+ push @matecomponent_dirs, $dir;
+ }
+ }
+ foreach $dir (split(':', $ENV{'MATE2_PATH'})) {
+- if (-d "$dir/lib/matecomponent/servers") {
+- push @matecomponent_dirs, "$dir/lib/matecomponent/servers";
++ if (-d "$dir/libdata/matecomponent/servers") {
++ push @matecomponent_dirs, "$dir/libdata/matecomponent/servers";
+ }
+ }
+
diff --git a/devel/libmatecomponent/pkg-descr b/devel/libmatecomponent/pkg-descr
new file mode 100644
index 0000000..2f45fa5
--- /dev/null
+++ b/devel/libmatecomponent/pkg-descr
@@ -0,0 +1,5 @@
+libmatecomponent is a set of language- and system-independent CORBA interfaces
+for creating reusable components and controls, and for creating
+compound documents.
+
+WWW: http://mate-desktop.org/
diff --git a/devel/libmatecomponent/pkg-plist b/devel/libmatecomponent/pkg-plist
new file mode 100644
index 0000000..9b1b49c
--- /dev/null
+++ b/devel/libmatecomponent/pkg-plist
@@ -0,0 +1,329 @@
+bin/matecomponent-activation-client
+bin/matecomponent-activation-run-query
+bin/matecomponent-echo-client-2
+bin/matecomponent-slay
+etc/matecomponent-activation/matecomponent-activation-config.xml
+include/libmatecomponent-2.0/libmatecomponent.h
+include/libmatecomponent-2.0/matecomponent/MateComponent.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-app-client.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-application.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-arg.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-context.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-event-source.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-exception.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-foreign-object.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-generic-factory.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-i18n.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-item-container.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-item-handler.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-listener.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-macros.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-main.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-moniker-extender.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-moniker-simple.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-moniker-util.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-moniker.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-object.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-persist-client.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-persist-file.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-persist-stream.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-persist.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-property-bag-client.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-property-bag.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-shlib-factory.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-storage-memory.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-storage.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-stream-client.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-stream-memory.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-stream.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-types.h
+include/libmatecomponent-2.0/matecomponent/matecomponent-xobject.h
+include/matecomponent-activation-2.0/matecomponent-activation/MateComponent_Activation_types.h
+include/matecomponent-activation-2.0/matecomponent-activation/MateComponent_GenericFactory.h
+include/matecomponent-activation-2.0/matecomponent-activation/MateComponent_Unknown.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-activate.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-async.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-init.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-mime.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-register.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-server-info.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-shlib.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation-version.h
+include/matecomponent-activation-2.0/matecomponent-activation/matecomponent-activation.h
+lib/libmatecomponent-2.a
+lib/libmatecomponent-2.la
+lib/libmatecomponent-2.so
+lib/libmatecomponent-2.so.0
+lib/libmatecomponent-activation.a
+lib/libmatecomponent-activation.la
+lib/libmatecomponent-activation.so
+lib/libmatecomponent-activation.so.4
+lib/matecomponent-2.0/samples/matecomponent-echo-2
+lib/matecomponent/monikers/libmoniker_std_2.a
+lib/matecomponent/monikers/libmoniker_std_2.la
+lib/matecomponent/monikers/libmoniker_std_2.so
+lib/matecorba-2.0/MateComponent_module.a
+lib/matecorba-2.0/MateComponent_module.la
+lib/matecorba-2.0/MateComponent_module.so
+libdata/matecomponent/servers/MateComponent_CosNaming_NamingContext.server
+libdata/matecomponent/servers/MateComponent_Moniker_std.server
+libdata/matecomponent/servers/MateComponent_Sample_Echo.server
+libdata/pkgconfig/libmatecomponent-2.0.pc
+libdata/pkgconfig/matecomponent-activation-2.0.pc
+libexec/matecomponent-activation-server
+sbin/matecomponent-activation-sysconf
+%%DOCSDIR%%/debugging.html
+%%DOCSDIR%%/factories.html
+%%DOCSDIR%%/general.html
+%%DOCSDIR%%/home.png
+%%DOCSDIR%%/index.html
+%%DOCSDIR%%/index.sgml
+%%DOCSDIR%%/ix01.html
+%%DOCSDIR%%/left.png
+%%DOCSDIR%%/libmatecomponent-faq.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-app-client.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-application.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-arg.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-config-database.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-context.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-event-source.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-exception.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-generic-factory.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-i18n.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-item-container.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-item-handler.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-listener.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-main.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-moniker-context.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-moniker-extender.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-moniker-simple.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-moniker-util.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-moniker.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-object.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-persist-client.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-persist-file.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-persist-stream.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-persist.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-property-bag-client.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-property-bag.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-running-context.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-shlib-factory.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-shutdown.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-storage-memory.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-storage.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-stream-client.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-stream-memory.html
+%%DOCSDIR%%/libmatecomponent-matecomponent-types.html
+%%DOCSDIR%%/libmatecomponent.devhelp
+%%DOCSDIR%%/libmatecomponent.devhelp2
+%%DOCSDIR%%/misc.html
+%%DOCSDIR%%/monikers-overview.html
+%%DOCSDIR%%/monikers.html
+%%DOCSDIR%%/persist-file.png
+%%DOCSDIR%%/persist-storage.png
+%%DOCSDIR%%/persist-stream.png
+%%DOCSDIR%%/persist.html
+%%DOCSDIR%%/persist.png
+%%DOCSDIR%%/properties.html
+%%DOCSDIR%%/property-bags.html
+%%DOCSDIR%%/refcounting.html
+%%DOCSDIR%%/right.png
+%%DOCSDIR%%/running-context.png
+%%DOCSDIR%%/storage.png
+%%DOCSDIR%%/stream.png
+%%DOCSDIR%%/streams.html
+%%DOCSDIR%%/style.css
+%%DOCSDIR%%/unknown.png
+%%DOCSDIR%%/up.png
+share/doc/matecomponent-activation/api-reference.html
+share/doc/matecomponent-activation/architecture.html
+share/doc/matecomponent-activation/async-activation.html
+share/doc/matecomponent-activation/attribute-tag.html
+share/doc/matecomponent-activation/checklist.html
+share/doc/matecomponent-activation/configuring.html
+share/doc/matecomponent-activation/home.png
+share/doc/matecomponent-activation/index.html
+share/doc/matecomponent-activation/index.sgml
+share/doc/matecomponent-activation/left.png
+share/doc/matecomponent-activation/lgpl.html
+share/doc/matecomponent-activation/matecomponent-activation-Debugging.html
+share/doc/matecomponent-activation/matecomponent-activation-Initialization.html
+share/doc/matecomponent-activation/matecomponent-activation-Query-and-Activation.html
+share/doc/matecomponent-activation/matecomponent-activation-Registration.html
+share/doc/matecomponent-activation/matecomponent-activation-Utilities.html
+share/doc/matecomponent-activation/matecomponent-activation.devhelp
+share/doc/matecomponent-activation/matecomponent-activation.devhelp2
+share/doc/matecomponent-activation/matecomponent-activation.png
+share/doc/matecomponent-activation/migrating.html
+share/doc/matecomponent-activation/query-langage.html
+share/doc/matecomponent-activation/query-syntax.html
+share/doc/matecomponent-activation/right.png
+share/doc/matecomponent-activation/server-arch.html
+share/doc/matecomponent-activation/server-xml-reference.html
+share/doc/matecomponent-activation/style.css
+share/doc/matecomponent-activation/terms.html
+share/doc/matecomponent-activation/tutorial.html
+share/doc/matecomponent-activation/up.png
+share/idl/matecomponent-2.0/MateComponent.idl
+share/idl/matecomponent-2.0/MateComponent_Application.idl
+share/idl/matecomponent-2.0/MateComponent_Canvas.idl
+share/idl/matecomponent-2.0/MateComponent_Clipboard.idl
+share/idl/matecomponent-2.0/MateComponent_Context.idl
+share/idl/matecomponent-2.0/MateComponent_Control.idl
+share/idl/matecomponent-2.0/MateComponent_Embeddable.idl
+share/idl/matecomponent-2.0/MateComponent_Exception.idl
+share/idl/matecomponent-2.0/MateComponent_Gdk.idl
+share/idl/matecomponent-2.0/MateComponent_ItemContainer.idl
+share/idl/matecomponent-2.0/MateComponent_Listener.idl
+share/idl/matecomponent-2.0/MateComponent_Moniker.idl
+share/idl/matecomponent-2.0/MateComponent_Persist.idl
+share/idl/matecomponent-2.0/MateComponent_Print.idl
+share/idl/matecomponent-2.0/MateComponent_Property.idl
+share/idl/matecomponent-2.0/MateComponent_Sample_Echo.idl
+share/idl/matecomponent-2.0/MateComponent_Storage.idl
+share/idl/matecomponent-2.0/MateComponent_UI.idl
+share/idl/matecomponent-2.0/MateComponent_Zoomable.idl
+share/idl/matecomponent-activation-2.0/MateComponent_ActivationContext.idl
+share/idl/matecomponent-activation-2.0/MateComponent_Activation_types.idl
+share/idl/matecomponent-activation-2.0/MateComponent_GenericFactory.idl
+share/idl/matecomponent-activation-2.0/MateComponent_ObjectDirectory.idl
+share/idl/matecomponent-activation-2.0/MateComponent_Unknown.idl
+share/locale/am/LC_MESSAGES/libmatecomponent.mo
+share/locale/ar/LC_MESSAGES/libmatecomponent.mo
+share/locale/as/LC_MESSAGES/libmatecomponent.mo
+share/locale/ast/LC_MESSAGES/libmatecomponent.mo
+share/locale/az/LC_MESSAGES/libmatecomponent.mo
+share/locale/be/LC_MESSAGES/libmatecomponent.mo
+share/locale/bg/LC_MESSAGES/libmatecomponent.mo
+share/locale/bn/LC_MESSAGES/libmatecomponent.mo
+share/locale/bn_IN/LC_MESSAGES/libmatecomponent.mo
+share/locale/br/LC_MESSAGES/libmatecomponent.mo
+share/locale/bs/LC_MESSAGES/libmatecomponent.mo
+share/locale/ca/LC_MESSAGES/libmatecomponent.mo
+share/locale/ca@valencia/LC_MESSAGES/libmatecomponent.mo
+share/locale/cs/LC_MESSAGES/libmatecomponent.mo
+share/locale/cy/LC_MESSAGES/libmatecomponent.mo
+share/locale/da/LC_MESSAGES/libmatecomponent.mo
+share/locale/de/LC_MESSAGES/libmatecomponent.mo
+share/locale/dz/LC_MESSAGES/libmatecomponent.mo
+share/locale/el/LC_MESSAGES/libmatecomponent.mo
+share/locale/en@shaw/LC_MESSAGES/libmatecomponent.mo
+share/locale/en_CA/LC_MESSAGES/libmatecomponent.mo
+share/locale/en_GB/LC_MESSAGES/libmatecomponent.mo
+share/locale/eo/LC_MESSAGES/libmatecomponent.mo
+share/locale/es/LC_MESSAGES/libmatecomponent.mo
+share/locale/et/LC_MESSAGES/libmatecomponent.mo
+share/locale/eu/LC_MESSAGES/libmatecomponent.mo
+share/locale/fa/LC_MESSAGES/libmatecomponent.mo
+share/locale/fi/LC_MESSAGES/libmatecomponent.mo
+share/locale/fr/LC_MESSAGES/libmatecomponent.mo
+share/locale/ga/LC_MESSAGES/libmatecomponent.mo
+share/locale/gl/LC_MESSAGES/libmatecomponent.mo
+share/locale/gu/LC_MESSAGES/libmatecomponent.mo
+share/locale/he/LC_MESSAGES/libmatecomponent.mo
+share/locale/hi/LC_MESSAGES/libmatecomponent.mo
+share/locale/hr/LC_MESSAGES/libmatecomponent.mo
+share/locale/hu/LC_MESSAGES/libmatecomponent.mo
+share/locale/hy/LC_MESSAGES/libmatecomponent.mo
+share/locale/id/LC_MESSAGES/libmatecomponent.mo
+share/locale/is/LC_MESSAGES/libmatecomponent.mo
+share/locale/it/LC_MESSAGES/libmatecomponent.mo
+share/locale/ja/LC_MESSAGES/libmatecomponent.mo
+share/locale/ka/LC_MESSAGES/libmatecomponent.mo
+share/locale/kn/LC_MESSAGES/libmatecomponent.mo
+share/locale/ko/LC_MESSAGES/libmatecomponent.mo
+share/locale/ku/LC_MESSAGES/libmatecomponent.mo
+share/locale/li/LC_MESSAGES/libmatecomponent.mo
+share/locale/lt/LC_MESSAGES/libmatecomponent.mo
+share/locale/lv/LC_MESSAGES/libmatecomponent.mo
+share/locale/mai/LC_MESSAGES/libmatecomponent.mo
+share/locale/mg/LC_MESSAGES/libmatecomponent.mo
+share/locale/mk/LC_MESSAGES/libmatecomponent.mo
+share/locale/ml/LC_MESSAGES/libmatecomponent.mo
+share/locale/mn/LC_MESSAGES/libmatecomponent.mo
+share/locale/mr/LC_MESSAGES/libmatecomponent.mo
+share/locale/ms/LC_MESSAGES/libmatecomponent.mo
+share/locale/nb/LC_MESSAGES/libmatecomponent.mo
+share/locale/ne/LC_MESSAGES/libmatecomponent.mo
+share/locale/nl/LC_MESSAGES/libmatecomponent.mo
+share/locale/nn/LC_MESSAGES/libmatecomponent.mo
+share/locale/oc/LC_MESSAGES/libmatecomponent.mo
+share/locale/or/LC_MESSAGES/libmatecomponent.mo
+share/locale/pa/LC_MESSAGES/libmatecomponent.mo
+share/locale/pl/LC_MESSAGES/libmatecomponent.mo
+share/locale/pt/LC_MESSAGES/libmatecomponent.mo
+share/locale/pt_BR/LC_MESSAGES/libmatecomponent.mo
+share/locale/ro/LC_MESSAGES/libmatecomponent.mo
+share/locale/ru/LC_MESSAGES/libmatecomponent.mo
+share/locale/rw/LC_MESSAGES/libmatecomponent.mo
+share/locale/sk/LC_MESSAGES/libmatecomponent.mo
+share/locale/sl/LC_MESSAGES/libmatecomponent.mo
+share/locale/sq/LC_MESSAGES/libmatecomponent.mo
+share/locale/sr/LC_MESSAGES/libmatecomponent.mo
+share/locale/sr@latin/LC_MESSAGES/libmatecomponent.mo
+share/locale/sv/LC_MESSAGES/libmatecomponent.mo
+share/locale/ta/LC_MESSAGES/libmatecomponent.mo
+share/locale/te/LC_MESSAGES/libmatecomponent.mo
+share/locale/th/LC_MESSAGES/libmatecomponent.mo
+share/locale/tr/LC_MESSAGES/libmatecomponent.mo
+share/locale/uk/LC_MESSAGES/libmatecomponent.mo
+share/locale/vi/LC_MESSAGES/libmatecomponent.mo
+share/locale/wa/LC_MESSAGES/libmatecomponent.mo
+share/locale/xh/LC_MESSAGES/libmatecomponent.mo
+share/locale/yi/LC_MESSAGES/libmatecomponent.mo
+share/locale/zh_CN/LC_MESSAGES/libmatecomponent.mo
+share/locale/zh_HK/LC_MESSAGES/libmatecomponent.mo
+share/locale/zh_TW/LC_MESSAGES/libmatecomponent.mo
+@dirrmtry share/locale/zh_HK/LC_MESSAGES
+@dirrmtry share/locale/zh_HK
+@dirrmtry share/locale/yi/LC_MESSAGES
+@dirrmtry share/locale/yi
+@dirrmtry share/locale/xh/LC_MESSAGES
+@dirrmtry share/locale/xh
+@dirrmtry share/locale/te/LC_MESSAGES
+@dirrmtry share/locale/te
+@dirrmtry share/locale/sr@latin/LC_MESSAGES
+@dirrmtry share/locale/sr@latin
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/oc/LC_MESSAGES
+@dirrmtry share/locale/oc
+@dirrmtry share/locale/mr/LC_MESSAGES
+@dirrmtry share/locale/mr
+@dirrmtry share/locale/mg/LC_MESSAGES
+@dirrmtry share/locale/mg
+@dirrmtry share/locale/mai/LC_MESSAGES
+@dirrmtry share/locale/mai
+@dirrmtry share/locale/ku/LC_MESSAGES
+@dirrmtry share/locale/ku
+@dirrmtry share/locale/hy/LC_MESSAGES
+@dirrmtry share/locale/hy
+@dirrmtry share/locale/en@shaw/LC_MESSAGES
+@dirrmtry share/locale/en@shaw
+@dirrmtry share/locale/dz/LC_MESSAGES
+@dirrmtry share/locale/dz
+@dirrmtry share/locale/ca@valencia/LC_MESSAGES
+@dirrmtry share/locale/ca@valencia
+@dirrmtry share/locale/bn_IN/LC_MESSAGES
+@dirrmtry share/locale/bn_IN
+@dirrmtry share/locale/ast/LC_MESSAGES
+@dirrmtry share/locale/ast
+@dirrmtry share/locale/as/LC_MESSAGES
+@dirrmtry share/locale/as
+@dirrm share/idl/matecomponent-activation-2.0
+@dirrm share/idl/matecomponent-2.0
+@dirrm share/idl
+@dirrm share/doc/matecomponent-activation
+@dirrm %%DOCSDIR%%
+@dirrm libdata/matecomponent/servers
+@dirrm libdata/matecomponent
+@dirrm lib/matecorba-2.0
+@dirrm lib/matecomponent/monikers
+@dirrm lib/matecomponent-2.0/samples
+@dirrm lib/matecomponent-2.0
+@dirrm lib/matecomponent
+@dirrm include/matecomponent-activation-2.0/matecomponent-activation
+@dirrm include/matecomponent-activation-2.0
+@dirrm include/libmatecomponent-2.0/matecomponent
+@dirrm include/libmatecomponent-2.0
+@dirrm etc/matecomponent-activation
diff --git a/devel/mate-common/Makefile b/devel/mate-common/Makefile
new file mode 100644
index 0000000..69423ce
--- /dev/null
+++ b/devel/mate-common/Makefile
@@ -0,0 +1,24 @@
+# New ports collection makefile for: gnomecommon
+# Date created: 04 April 2002
+# Whom: Joe Marcus Clarke <marcus@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= mate-common
+PORTVERSION= 1.2.2
+CATEGORIES= devel mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= Common automake macros for MATE
+
+USE_XZ= yes
+USE_MATE= autogen
+USE_GMAKE= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env
+GNU_CONFIGURE= yes
+
+.include <bsd.port.mk>
diff --git a/devel/mate-common/distinfo b/devel/mate-common/distinfo
new file mode 100644
index 0000000..09276a1
--- /dev/null
+++ b/devel/mate-common/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/mate-common-1.2.2.tar.xz) = f380f021336f6edbfdcc0f846a79efa9b3bdd8cf362bacc81c22d4dd0625f18d
+SIZE (mate/mate-common-1.2.2.tar.xz) = 22496
diff --git a/devel/mate-common/pkg-descr b/devel/mate-common/pkg-descr
new file mode 100644
index 0000000..cc145d2
--- /dev/null
+++ b/devel/mate-common/pkg-descr
@@ -0,0 +1,4 @@
+This is a collection of automake macros used for developing new MATE
+applications.
+
+WWW: http://mate-desktop.org/
diff --git a/devel/mate-common/pkg-plist b/devel/mate-common/pkg-plist
new file mode 100644
index 0000000..1580f9c
--- /dev/null
+++ b/devel/mate-common/pkg-plist
@@ -0,0 +1,8 @@
+bin/mate-autogen
+bin/mate-doc-common
+share/aclocal/mate-common.m4
+share/aclocal/mate-compiler-flags.m4
+%%DATADIR%%/data/omf.make
+%%DATADIR%%/data/xmldocs.make
+@dirrm %%DATADIR%%/data
+@dirrm %%DATADIR%%
diff --git a/devel/mate-conf/Makefile b/devel/mate-conf/Makefile
new file mode 100644
index 0000000..bed75dd
--- /dev/null
+++ b/devel/mate-conf/Makefile
@@ -0,0 +1,56 @@
+# New ports collection makefile for: gconf2
+# Date created: 28th June 2000
+# Whom: Ade Lovett <ade@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= mate-conf
+PORTVERSION= 1.2.1
+CATEGORIES= devel mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= A configuration database system for MATE
+
+BUILD_DEPENDS= gtkdoc-check:${PORTSDIR}/textproc/gtk-doc \
+ g-ir-scanner:${PORTSDIR}/devel/gobject-introspection
+LIB_DEPENDS= dbus-glib-1.2:${PORTSDIR}/devel/dbus-glib \
+ polkit-gobject-1.0:${PORTSDIR}/sysutils/polkit
+
+USE_XZ= yes
+USE_MATE= autogen common:build corba ltverhack intlhack matehack
+USE_GMAKE= yes
+USE_GNOME= gtk20 libxml2
+USE_GETTEXT= yes
+USE_LDCONFIG= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env libtool libtoolize:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --with-html-dir=${PREFIX}/share/doc \
+ --disable-gtk-doc \
+ --with-gtk=2.0
+
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib
+MAN1= mateconf-gsettings-data-convert.1 \
+ mateconf-gsettings-schema-convert.1 mateconftool-2.1
+
+OPTIONS= LDAP "Enable LDAP support" off
+
+.include <bsd.port.pre.mk>
+
+.if defined(WITH_LDAP)
+USE_OPENLDAP= yes
+CONFIGURE_ARGS+=--with-openldap
+PLIST_SUB+= LDAP=""
+.else
+CONFIGURE_ARGS+=--without-openldap
+PLIST_SUB+= LDAP="@comment "
+.endif
+
+post-install:
+ -${LOCALBASE}/bin/gio-querymodules ${PREFIX}/lib/gio/modules
+
+.include <bsd.port.post.mk>
diff --git a/devel/mate-conf/distinfo b/devel/mate-conf/distinfo
new file mode 100644
index 0000000..74c4956
--- /dev/null
+++ b/devel/mate-conf/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/mate-conf-1.2.1.tar.xz) = 343576f6d96fc432218cbf3ed4f009f7fa8e4ec17683c76ffe2272797d540ce0
+SIZE (mate/mate-conf-1.2.1.tar.xz) = 1037472
diff --git a/devel/mate-conf/files/patch-gsettings_mateconfsettingsbackend.c b/devel/mate-conf/files/patch-gsettings_mateconfsettingsbackend.c
new file mode 100644
index 0000000..c852888
--- /dev/null
+++ b/devel/mate-conf/files/patch-gsettings_mateconfsettingsbackend.c
@@ -0,0 +1,9 @@
+--- gsettings/mateconfsettingsbackend.c.orig 2010-11-14 12:54:57.000000000 -0500
++++ gsettings/mateconfsettingsbackend.c 2010-11-14 12:55:08.000000000 -0500
+@@ -924,5 +924,5 @@ gconf_settings_backend_register (GIOModu
+ g_io_extension_point_implement (G_SETTINGS_BACKEND_EXTENSION_POINT_NAME,
+ MATECONF_TYPE_SETTINGS_BACKEND,
+ "mateconf",
+- -1);
++ 10);
+ }
diff --git a/devel/mate-conf/files/patch-mateconf_default.path.in b/devel/mate-conf/files/patch-mateconf_default.path.in
new file mode 100644
index 0000000..ba8c40b
--- /dev/null
+++ b/devel/mate-conf/files/patch-mateconf_default.path.in
@@ -0,0 +1,11 @@
+--- mateconf/default.path.in.orig 2009-03-06 17:10:54.000000000 -0500
++++ mateconf/default.path.in 2009-03-06 17:11:25.000000000 -0500
+@@ -21,7 +21,7 @@ include "$(HOME)/.mateconf.path"
+ xml:readwrite:$(HOME)/.mateconf
+
+ # Location for system-wide settings that are set by the defaults mechanism
+-xml:readonly:/etc/mateconf/mateconf.xml.system
++xml:readonly:@sysmateconfdir@/mateconf.xml.system
+
+ # To read in any defaults settings that the Sys Admin may have created
+ # prior to a desktop system upgrade. The SysAdmin can stick default values
diff --git a/devel/mate-conf/pkg-descr b/devel/mate-conf/pkg-descr
new file mode 100644
index 0000000..895a6ee
--- /dev/null
+++ b/devel/mate-conf/pkg-descr
@@ -0,0 +1,18 @@
+mate-conf extends the concept of a configuration registry. It provides
+a simple way for applications and administrators to store data;
+often mate-conf is used to store preferences for applications.
+
+Some of the features of mate-conf are:
+mate-conf provides:
+
+ * Documentation for each configuration key, so that administrators
+ can better modify the value.
+
+ * Notifications to interested applications when configuration data
+ is changed. The notification service works across networks,
+ affecting all login sessions for a single user.
+
+ * Proper locking so that configuration data doesn't get corrupted
+ when accessed by multiple applications at the same time.
+
+WWW: http://mate-desktop.org/
diff --git a/devel/mate-conf/pkg-plist b/devel/mate-conf/pkg-plist
new file mode 100644
index 0000000..b629d94
--- /dev/null
+++ b/devel/mate-conf/pkg-plist
@@ -0,0 +1,214 @@
+bin/mateconf-gsettings-data-convert
+bin/mateconf-gsettings-schema-convert
+bin/mateconf-merge-tree
+bin/mateconftool-2
+etc/dbus-1/system.d/org.mate.MateConf.Defaults.conf
+%%LDAP%%etc/mateconf/2/evoldap.conf
+etc/mateconf/2/path
+etc/xdg/autostart/mateconf-gsettings-data-convert.desktop
+include/mateconf/2/mateconf/mateconf-changeset.h
+include/mateconf/2/mateconf/mateconf-client.h
+include/mateconf/2/mateconf/mateconf-engine.h
+include/mateconf/2/mateconf/mateconf-enum-types.h
+include/mateconf/2/mateconf/mateconf-error.h
+include/mateconf/2/mateconf/mateconf-listeners.h
+include/mateconf/2/mateconf/mateconf-schema.h
+include/mateconf/2/mateconf/mateconf-value.h
+include/mateconf/2/mateconf/mateconf.h
+%%LDAP%%lib/MateConf/2/libmateconfbackend-evoldap.a
+%%LDAP%%lib/MateConf/2/libmateconfbackend-evoldap.la
+%%LDAP%%lib/MateConf/2/libmateconfbackend-evoldap.so
+lib/MateConf/2/libmateconfbackend-oldxml.a
+lib/MateConf/2/libmateconfbackend-oldxml.la
+lib/MateConf/2/libmateconfbackend-oldxml.so
+lib/MateConf/2/libmateconfbackend-xml.a
+lib/MateConf/2/libmateconfbackend-xml.la
+lib/MateConf/2/libmateconfbackend-xml.so
+lib/girepository-1.0/MateConf-2.0.typelib
+lib/gio/modules/libgsettingsmateconfbackend.a
+lib/gio/modules/libgsettingsmateconfbackend.la
+lib/gio/modules/libgsettingsmateconfbackend.so
+lib/libmateconf-2.a
+lib/libmateconf-2.la
+lib/libmateconf-2.so
+lib/libmateconf-2.so.4
+libdata/pkgconfig/mateconf-2.0.pc
+libexec/mateconf-defaults-mechanism
+libexec/mateconf-sanity-check-2
+libexec/mateconfd-2
+%%LDAP%%share/MateConf/schema/evoldap.schema
+share/aclocal/mateconf-2.m4
+share/dbus-1/services/org.mate.MateConf.service
+share/dbus-1/system-services/org.mate.MateConf.Defaults.service
+share/doc/mateconf/ch01.html
+share/doc/mateconf/home.png
+share/doc/mateconf/index.html
+share/doc/mateconf/index.sgml
+share/doc/mateconf/left.png
+share/doc/mateconf/mateconf-mateconf-backend.html
+share/doc/mateconf/mateconf-mateconf-changeset.html
+share/doc/mateconf/mateconf-mateconf-client.html
+share/doc/mateconf/mateconf-mateconf-engine.html
+share/doc/mateconf/mateconf-mateconf-error.html
+share/doc/mateconf/mateconf-mateconf-internals.html
+share/doc/mateconf/mateconf-mateconf-listeners.html
+share/doc/mateconf/mateconf-mateconf-locale.html
+share/doc/mateconf/mateconf-mateconf-schema.html
+share/doc/mateconf/mateconf-mateconf-sources.html
+share/doc/mateconf/mateconf-mateconf-value.html
+share/doc/mateconf/mateconf-mateconf.html
+share/doc/mateconf/mateconf.devhelp
+share/doc/mateconf/mateconf.devhelp2
+share/doc/mateconf/right.png
+share/doc/mateconf/style.css
+share/doc/mateconf/up.png
+share/gir-1.0/MateConf-2.0.gir
+share/locale/am/LC_MESSAGES/mate-conf.mo
+share/locale/ar/LC_MESSAGES/mate-conf.mo
+share/locale/as/LC_MESSAGES/mate-conf.mo
+share/locale/ast/LC_MESSAGES/mate-conf.mo
+share/locale/az/LC_MESSAGES/mate-conf.mo
+share/locale/be/LC_MESSAGES/mate-conf.mo
+share/locale/bg/LC_MESSAGES/mate-conf.mo
+share/locale/bn/LC_MESSAGES/mate-conf.mo
+share/locale/bn_IN/LC_MESSAGES/mate-conf.mo
+share/locale/bs/LC_MESSAGES/mate-conf.mo
+share/locale/ca/LC_MESSAGES/mate-conf.mo
+share/locale/ca@valencia/LC_MESSAGES/mate-conf.mo
+share/locale/cs/LC_MESSAGES/mate-conf.mo
+share/locale/cy/LC_MESSAGES/mate-conf.mo
+share/locale/da/LC_MESSAGES/mate-conf.mo
+share/locale/de/LC_MESSAGES/mate-conf.mo
+share/locale/dz/LC_MESSAGES/mate-conf.mo
+share/locale/el/LC_MESSAGES/mate-conf.mo
+share/locale/en@shaw/LC_MESSAGES/mate-conf.mo
+share/locale/en_CA/LC_MESSAGES/mate-conf.mo
+share/locale/en_GB/LC_MESSAGES/mate-conf.mo
+share/locale/es/LC_MESSAGES/mate-conf.mo
+share/locale/et/LC_MESSAGES/mate-conf.mo
+share/locale/eu/LC_MESSAGES/mate-conf.mo
+share/locale/fa/LC_MESSAGES/mate-conf.mo
+share/locale/fi/LC_MESSAGES/mate-conf.mo
+share/locale/fr/LC_MESSAGES/mate-conf.mo
+share/locale/ga/LC_MESSAGES/mate-conf.mo
+share/locale/gl/LC_MESSAGES/mate-conf.mo
+share/locale/gu/LC_MESSAGES/mate-conf.mo
+share/locale/he/LC_MESSAGES/mate-conf.mo
+share/locale/hi/LC_MESSAGES/mate-conf.mo
+share/locale/hr/LC_MESSAGES/mate-conf.mo
+share/locale/hu/LC_MESSAGES/mate-conf.mo
+share/locale/hy/LC_MESSAGES/mate-conf.mo
+share/locale/id/LC_MESSAGES/mate-conf.mo
+share/locale/is/LC_MESSAGES/mate-conf.mo
+share/locale/it/LC_MESSAGES/mate-conf.mo
+share/locale/ja/LC_MESSAGES/mate-conf.mo
+share/locale/ka/LC_MESSAGES/mate-conf.mo
+share/locale/kn/LC_MESSAGES/mate-conf.mo
+share/locale/ko/LC_MESSAGES/mate-conf.mo
+share/locale/ku/LC_MESSAGES/mate-conf.mo
+share/locale/lt/LC_MESSAGES/mate-conf.mo
+share/locale/lv/LC_MESSAGES/mate-conf.mo
+share/locale/mai/LC_MESSAGES/mate-conf.mo
+share/locale/mg/LC_MESSAGES/mate-conf.mo
+share/locale/mk/LC_MESSAGES/mate-conf.mo
+share/locale/ml/LC_MESSAGES/mate-conf.mo
+share/locale/mn/LC_MESSAGES/mate-conf.mo
+share/locale/mr/LC_MESSAGES/mate-conf.mo
+share/locale/ms/LC_MESSAGES/mate-conf.mo
+share/locale/nb/LC_MESSAGES/mate-conf.mo
+share/locale/ne/LC_MESSAGES/mate-conf.mo
+share/locale/nl/LC_MESSAGES/mate-conf.mo
+share/locale/nn/LC_MESSAGES/mate-conf.mo
+share/locale/oc/LC_MESSAGES/mate-conf.mo
+share/locale/or/LC_MESSAGES/mate-conf.mo
+share/locale/pa/LC_MESSAGES/mate-conf.mo
+share/locale/pl/LC_MESSAGES/mate-conf.mo
+share/locale/pt/LC_MESSAGES/mate-conf.mo
+share/locale/pt_BR/LC_MESSAGES/mate-conf.mo
+share/locale/ro/LC_MESSAGES/mate-conf.mo
+share/locale/ru/LC_MESSAGES/mate-conf.mo
+share/locale/rw/LC_MESSAGES/mate-conf.mo
+share/locale/si/LC_MESSAGES/mate-conf.mo
+share/locale/sk/LC_MESSAGES/mate-conf.mo
+share/locale/sl/LC_MESSAGES/mate-conf.mo
+share/locale/sq/LC_MESSAGES/mate-conf.mo
+share/locale/sr/LC_MESSAGES/mate-conf.mo
+share/locale/sr@latin/LC_MESSAGES/mate-conf.mo
+share/locale/sv/LC_MESSAGES/mate-conf.mo
+share/locale/ta/LC_MESSAGES/mate-conf.mo
+share/locale/te/LC_MESSAGES/mate-conf.mo
+share/locale/th/LC_MESSAGES/mate-conf.mo
+share/locale/tr/LC_MESSAGES/mate-conf.mo
+share/locale/uk/LC_MESSAGES/mate-conf.mo
+share/locale/vi/LC_MESSAGES/mate-conf.mo
+share/locale/xh/LC_MESSAGES/mate-conf.mo
+share/locale/yi/LC_MESSAGES/mate-conf.mo
+share/locale/zh_CN/LC_MESSAGES/mate-conf.mo
+share/locale/zh_HK/LC_MESSAGES/mate-conf.mo
+share/locale/zh_TW/LC_MESSAGES/mate-conf.mo
+share/polkit-1/actions/org.mate.mateconf.defaults.policy
+share/sgml/mateconf/mateconf-1.0.dtd
+@dirrm share/sgml/mateconf
+%%LDAP%%@dirrm share/MateConf/schema
+%%LDAP%%@dirrm share/MateConf
+@dirrm share/polkit-1/actions
+@dirrm share/polkit-1
+@dirrmtry share/locale/zh_HK/LC_MESSAGES
+@dirrmtry share/locale/zh_HK
+@dirrmtry share/locale/yi/LC_MESSAGES
+@dirrmtry share/locale/yi
+@dirrmtry share/locale/xh/LC_MESSAGES
+@dirrmtry share/locale/xh
+@dirrmtry share/locale/te/LC_MESSAGES
+@dirrmtry share/locale/te
+@dirrmtry share/locale/sr@latin/LC_MESSAGES
+@dirrmtry share/locale/sr@latin
+@dirrmtry share/locale/si/LC_MESSAGES
+@dirrmtry share/locale/si
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/oc/LC_MESSAGES
+@dirrmtry share/locale/oc
+@dirrmtry share/locale/mr/LC_MESSAGES
+@dirrmtry share/locale/mr
+@dirrmtry share/locale/mg/LC_MESSAGES
+@dirrmtry share/locale/mg
+@dirrmtry share/locale/mai/LC_MESSAGES
+@dirrmtry share/locale/mai
+@dirrmtry share/locale/ku/LC_MESSAGES
+@dirrmtry share/locale/ku
+@dirrmtry share/locale/hy/LC_MESSAGES
+@dirrmtry share/locale/hy
+@dirrmtry share/locale/en@shaw/LC_MESSAGES
+@dirrmtry share/locale/en@shaw
+@dirrmtry share/locale/dz/LC_MESSAGES
+@dirrmtry share/locale/dz
+@dirrmtry share/locale/ca@valencia/LC_MESSAGES
+@dirrmtry share/locale/ca@valencia
+@dirrmtry share/locale/bn_IN/LC_MESSAGES
+@dirrmtry share/locale/bn_IN
+@dirrmtry share/locale/ast/LC_MESSAGES
+@dirrmtry share/locale/ast
+@dirrmtry share/locale/as/LC_MESSAGES
+@dirrmtry share/locale/as
+@dirrm share/gir-1.0
+@dirrm share/doc/mateconf
+@dirrm share/dbus-1/system-services
+@dirrm share/dbus-1/services
+@dirrm share/dbus-1
+@dirrm lib/girepository-1.0
+@dirrm lib/MateConf/2
+@dirrm lib/MateConf
+@dirrm include/mateconf/2/mateconf
+@dirrm include/mateconf/2
+@dirrm include/mateconf
+@dirrm etc/xdg/autostart
+@dirrm etc/xdg
+@dirrm etc/mateconf/mateconf.xml.mandatory
+@dirrm etc/mateconf/mateconf.xml.defaults
+@dirrm etc/mateconf/2
+@dirrm etc/mateconf
+@dirrm etc/dbus-1/system.d
+@dirrm etc/dbus-1
+@exec %D/bin/gio-querymodules %D/lib/gio/modules 2>/dev/null || /usr/bin/true
+@unexec %D/bin/gio-querymodules %D/lib/gio/modules 2>/dev/null || /usr/bin/true
diff --git a/devel/mate-corba/Makefile b/devel/mate-corba/Makefile
new file mode 100644
index 0000000..f13b375
--- /dev/null
+++ b/devel/mate-corba/Makefile
@@ -0,0 +1,45 @@
+# New ports collection makefile for: orbit2
+# Date Created: 16 Aug 1998
+# Whom: Chia-liang Kao <clkao@CirX.ORG>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= mate-corba
+PORTVERSION= 1.2.2
+CATEGORIES= devel gnome
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= High-performance CORBA ORB with support for the C language
+
+BUILD_DEPENDS= gtkdoc-check:${PORTSDIR}/textproc/gtk-doc
+
+USE_XZ= yes
+USE_MATE= autogen common:build ltverhack matehack
+USE_GMAKE= yes
+USE_GNOME= glib20 libidl
+USE_GETTEXT= yes
+USE_LDCONFIG= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env libtool libtoolize:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --with-html-dir=${PREFIX}/share/doc \
+ --disable-gtk-doc
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib
+
+post-patch:
+ @${REINPLACE_CMD} -e 's|%%LOCALBASE%%|${LOCALBASE}|g' \
+ ${WRKSRC}/src/orb/orb-core/matecorba-typelib.c
+
+post-install:
+ @${ECHO_CMD} "ORBIIOPIPv4=0" > ${PREFIX}/etc/matecorbarc.default
+ @${ECHO_CMD} "ORBIIOPIPv6=0" >> ${PREFIX}/etc/matecorbarc.default
+ @if [ ! -f ${PREFIX}/etc/matecorbarc ]; then \
+ ${CP} -p ${PREFIX}/etc/matecorbarc.default ${PREFIX}/etc/matecorbarc ; \
+ fi
+ @${MKDIR} ${PREFIX}/lib/matecorba-2.0/idl-backends
+
+.include <bsd.port.mk>
diff --git a/devel/mate-corba/distinfo b/devel/mate-corba/distinfo
new file mode 100644
index 0000000..a293d69
--- /dev/null
+++ b/devel/mate-corba/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/mate-corba-1.2.2.tar.xz) = 46cd558e97c31d7ffeeb2c7f5ebc2c0e76dea6eae3c1801884b51f0470f2fc02
+SIZE (mate/mate-corba-1.2.2.tar.xz) = 379860
diff --git a/devel/mate-corba/files/patch-src_orb_orb-core_matecorba-typelib.c b/devel/mate-corba/files/patch-src_orb_orb-core_matecorba-typelib.c
new file mode 100644
index 0000000..84c67a7
--- /dev/null
+++ b/devel/mate-corba/files/patch-src_orb_orb-core_matecorba-typelib.c
@@ -0,0 +1,10 @@
+--- src/orb/orb-core/matecorba-typelib.c.orig 2007-07-27 10:58:37.000000000 -0500
++++ src/orb/orb-core/matecorba-typelib.c 2007-07-27 10:58:41.000000000 -0500
+@@ -218,6 +218,7 @@
+ paths = g_ptr_array_sized_new (8);
+
+ g_ptr_array_add (paths, g_strdup (MATECORBA_TYPELIB_DIR));
++ add_if_unique(paths, "%%LOCALBASE%%", TRUE);
+
+ if ((path = g_getenv ("MATECORBA_TYPELIB_PATH"))) {
+ char **strv;
diff --git a/devel/mate-corba/pkg-descr b/devel/mate-corba/pkg-descr
new file mode 100644
index 0000000..79f43b4
--- /dev/null
+++ b/devel/mate-corba/pkg-descr
@@ -0,0 +1,5 @@
+mate-corba is a high-performance CORBA ORB with support for the C language.
+It allows programs to communicate with each other, regardless of their
+physical and logical locations.
+
+WWW: http://mate-desktop.org/
diff --git a/devel/mate-corba/pkg-plist b/devel/mate-corba/pkg-plist
new file mode 100644
index 0000000..44f0915
--- /dev/null
+++ b/devel/mate-corba/pkg-plist
@@ -0,0 +1,101 @@
+bin/matecorba-idl-2
+bin/matecorba-ior-decode-2
+bin/matecorba-linc-cleanup-sockets
+bin/matecorba-typelib-dump
+bin/matecorba2-config
+@unexec if cmp -s %D/etc/matecorbarc.default %D/etc/matecorbarc; then rm -f %D/etc/matecorbarc; fi
+etc/matecorbarc.default
+@exec if [ ! -f %D/etc/matecorbarc ] ; then cp -p %D/%F %B/matecorbarc; fi
+include/matecorba-2.0/MateCORBAservices/CosNaming.h
+include/matecorba-2.0/MateCORBAservices/CosNaming_impl.h
+include/matecorba-2.0/MateCORBAservices/matecorba-imodule.h
+include/matecorba-2.0/matecorba-idl/matecorba-idl-backend.h
+include/matecorba-2.0/matecorba/dynamic/dynamic-defs.h
+include/matecorba-2.0/matecorba/dynamic/dynamic.h
+include/matecorba-2.0/matecorba/matecorba-config.h
+include/matecorba-2.0/matecorba/matecorba-types.h
+include/matecorba-2.0/matecorba/matecorba.h
+include/matecorba-2.0/matecorba/orb-core/allocators.h
+include/matecorba-2.0/matecorba/orb-core/corba-any-type.h
+include/matecorba-2.0/matecorba/orb-core/corba-any.h
+include/matecorba-2.0/matecorba/orb-core/corba-context-type.h
+include/matecorba-2.0/matecorba/orb-core/corba-context.h
+include/matecorba-2.0/matecorba/orb-core/corba-defs.h
+include/matecorba-2.0/matecorba/orb-core/corba-environment-type.h
+include/matecorba-2.0/matecorba/orb-core/corba-environment.h
+include/matecorba-2.0/matecorba/orb-core/corba-nvlist.h
+include/matecorba-2.0/matecorba/orb-core/corba-object-type.h
+include/matecorba-2.0/matecorba/orb-core/corba-object.h
+include/matecorba-2.0/matecorba/orb-core/corba-orb-type.h
+include/matecorba-2.0/matecorba/orb-core/corba-orb.h
+include/matecorba-2.0/matecorba/orb-core/corba-pobj.h
+include/matecorba-2.0/matecorba/orb-core/corba-policy-type.h
+include/matecorba-2.0/matecorba/orb-core/corba-string.h
+include/matecorba-2.0/matecorba/orb-core/corba-typecode-type.h
+include/matecorba-2.0/matecorba/orb-core/corba-typecode.h
+include/matecorba-2.0/matecorba/orb-core/iop-defs.h
+include/matecorba-2.0/matecorba/orb-core/matecorba-interface.h
+include/matecorba-2.0/matecorba/orb-core/matecorba-object.h
+include/matecorba-2.0/matecorba/orb-core/matecorba-small.h
+include/matecorba-2.0/matecorba/orb-core/orb-core-types.h
+include/matecorba-2.0/matecorba/orb-core/orb-core.h
+include/matecorba-2.0/matecorba/orb-core/orb-types.h
+include/matecorba-2.0/matecorba/poa/matecorba-adaptor.h
+include/matecorba-2.0/matecorba/poa/poa-basics.h
+include/matecorba-2.0/matecorba/poa/poa-defs.h
+include/matecorba-2.0/matecorba/poa/poa-policy.h
+include/matecorba-2.0/matecorba/poa/poa-types.h
+include/matecorba-2.0/matecorba/poa/poa.h
+include/matecorba-2.0/matecorba/poa/portableserver-current-type.h
+include/matecorba-2.0/matecorba/poa/portableserver-poa-type.h
+include/matecorba-2.0/matecorba/util/basic_types.h
+include/matecorba-2.0/matecorba/util/matecorba-genrand.h
+include/matecorba-2.0/matecorba/util/matecorba-util.h
+lib/libMateCORBA-2.a
+lib/libMateCORBA-2.la
+lib/libMateCORBA-2.so
+lib/libMateCORBA-2.so.0
+lib/libMateCORBA-imodule-2.a
+lib/libMateCORBA-imodule-2.la
+lib/libMateCORBA-imodule-2.so
+lib/libMateCORBA-imodule-2.so.0
+lib/libMateCORBACosNaming-2.a
+lib/libMateCORBACosNaming-2.la
+lib/libMateCORBACosNaming-2.so
+lib/libMateCORBACosNaming-2.so.0
+lib/libname-matecorba-server-2.a
+lib/matecorba-2.0/Everything_module.a
+lib/matecorba-2.0/Everything_module.la
+lib/matecorba-2.0/Everything_module.so
+libdata/pkgconfig/MateCORBA-2.0.pc
+libdata/pkgconfig/MateCORBA-CosNaming-2.0.pc
+libdata/pkgconfig/MateCORBA-idl-2.0.pc
+libdata/pkgconfig/MateCORBA-imodule-2.0.pc
+share/aclocal/MateCORBA2.m4
+share/doc/MateCORBA2/MateCORBA2-matecorba2-allocators.html
+share/doc/MateCORBA2/MateCORBA2-matecorba2-small.html
+share/doc/MateCORBA2/MateCORBA2.devhelp
+share/doc/MateCORBA2/MateCORBA2.devhelp2
+share/doc/MateCORBA2/general.html
+share/doc/MateCORBA2/home.png
+share/doc/MateCORBA2/index.html
+share/doc/MateCORBA2/index.sgml
+share/doc/MateCORBA2/left.png
+share/doc/MateCORBA2/right.png
+share/doc/MateCORBA2/style.css
+share/doc/MateCORBA2/up.png
+share/idl/matecorba-2.0/CosNaming.idl
+@dirrm share/idl/matecorba-2.0
+@dirrmtry share/idl
+@dirrm share/doc/MateCORBA2
+@exec /bin/mkdir -p %D/lib/matecorba-2.0/idl-backends
+@dirrmtry lib/matecorba-2.0/idl-backends
+@dirrmtry lib/matecorba-2.0
+@dirrm include/matecorba-2.0/matecorba/util
+@dirrm include/matecorba-2.0/matecorba/poa
+@dirrm include/matecorba-2.0/matecorba/orb-core
+@dirrm include/matecorba-2.0/matecorba/dynamic
+@dirrm include/matecorba-2.0/matecorba-idl
+@dirrm include/matecorba-2.0/matecorba
+@dirrm include/matecorba-2.0/MateCORBAservices
+@dirrm include/matecorba-2.0
diff --git a/devel/mate-vfs/Makefile b/devel/mate-vfs/Makefile
new file mode 100644
index 0000000..0c88fd2
--- /dev/null
+++ b/devel/mate-vfs/Makefile
@@ -0,0 +1,117 @@
+# New ports collection makefile for: gnomevfs2
+# Date created: 28th June 2000
+# Whom: Ade Lovett <ade@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= mate-vfs
+PORTVERSION= 1.2.1
+CATEGORIES= devel mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= MATE Virtual File System
+
+BUILD_DEPENDS= gtkdoc-check:${PORTSDIR}/textproc/gtk-doc
+LIB_DEPENDS= dbus-glib-1.2:${PORTSDIR}/devel/dbus-glib
+RUN_DEPENDS= ${LOCALBASE}/share/mime/magic:${PORTSDIR}/misc/shared-mime-info
+
+USE_XZ= yes
+USE_MATE= autogen common:build conf intlhack ltverhack matehack mimedata
+USE_GMAKE= yes
+USE_GNOME= glib20 libxml2
+USE_GETTEXT= yes
+USE_OPENSSL= yes
+USE_LDCONFIG= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env libtool libtoolize:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --enable-openssl \
+ --disable-gnutls \
+ --disable-howl \
+ --with-hal-mount=/sbin/mount \
+ --with-hal-umount=/sbin/umount \
+ --disable-gtk-doc \
+ --with-html-dir=${PREFIX}/share/doc \
+ ${MATECONF_PREFIX}
+CPPFLAGS+= ${PTHREAD_CFLAGS} -I${LOCALBASE}/include \
+ -DPTHREAD_LIB="${PTHREAD_LIBS}"
+LDFLAGS+= -L${LOCALBASE}/lib ${PTHREAD_LIBS}
+
+PKGINSTALL= ${WRKDIR}/pkg-install
+PKGDEINSTALL= ${WRKDIR}/pkg-deinstall
+
+MATECONF_SCHEMAS=desktop_default_applications.schemas \
+ desktop_mate_url_handlers.schemas system_dns_sd.schemas \
+ system_http_proxy.schemas system_smb.schemas
+
+OPTIONS= SAMBA "Enable SMB volume support" on \
+ MDNS "Enable Bonjour/Rendezvous support" on \
+ HAL "Enable HAL support" on \
+ FAM "Enable FAM support" on
+
+.include <bsd.port.pre.mk>
+
+.if !defined(WITHOUT_FAM)
+CONFIGURE_ARGS+=--enable-fam=yes
+USE_FAM= yes
+.else
+CONFIGURE_ARGS+=--disable-fam
+.endif
+
+.if exists(${LOCALBASE}/lib/libkrb5.so)
+LIB_DEPENDS+= krb5:${PORTSDIR}/security/heimdal
+.endif
+
+.if !defined(WITHOUT_HAL)
+CONFIGURE_ARGS+=--enable-hal
+LIB_DEPENDS+= hal.1:${PORTSDIR}/sysutils/hal
+.else
+CONFIGURE_ARGS+=--disable-hal
+.endif
+
+.if !defined(WITHOUT_SAMBA)
+LIB_DEPENDS+= smbclient.0:${PORTSDIR}/net/samba-libsmbclient
+PLIST_SUB+= SAMBA=""
+.else
+PLIST_SUB+= SAMBA="@comment "
+CONFIGURE_ARGS+=--disable-samba
+.endif
+
+.if !defined(WITHOUT_MDNS)
+LIB_DEPENDS+= avahi-client:${PORTSDIR}/net/avahi-app
+.else
+CONFIGURE_ARGS+=--disable-avahi
+.endif
+
+post-patch:
+ @${REINPLACE_CMD} -e 's|@PTHREAD_LIB@|${PTHREAD_LIBS}|' \
+ ${WRKSRC}/mate-vfs-2.0.pc.in ${WRKSRC}/mate-vfs-module-2.0.pc.in
+ @${REINPLACE_CMD} -e 's|[(]libdir[)]/mate-vfs-2.0/include|(includedir)/mate-vfs-2.0/include|g' \
+ ${WRKSRC}/libmatevfs/Makefile.am
+ @${REINPLACE_CMD} -e 's|/usr/local|${LOCALBASE}|g ; \
+ s|%%LOCALBASE%%|${LOCALBASE}|g' \
+ ${WRKSRC}/libmatevfs/xdgmime.c \
+ ${WRKSRC}/libmatevfs/mate-vfs-hal-mounts.c
+ @${REINPLACE_CMD} -e '/module_flags/s|-module -no-undefined|-module -no-undefined ${PTHREAD_LIB}|g' \
+ ${WRKSRC}/modules/Makefile.am
+ @${REINPLACE_CMD} -e 's|-lacl||g ; s|-ldl||g' \
+ ${WRKSRC}/configure.in
+ @${SED} -e 's|%%LOCALBASE%%|${LOCALBASE}|g' \
+ < ${MASTERDIR}/pkg-install.in > ${PKGINSTALL}
+ @${SED} -e 's|%%LOCALBASE%%|${LOCALBASE}|g' \
+ < ${MASTERDIR}/pkg-deinstall.in > ${PKGDEINSTALL}
+
+pre-configure:
+.if defined(WITHOUT_KERBEROS)
+ @${ECHO_CMD} "${PKGNAME}: KERBEROS is required."
+ @${FALSE}
+.endif
+
+post-install:
+ @${SETENV} PKG_PREFIX=${PREFIX} ${SH} ${PKGINSTALL} \
+ ${PKGNAME} POST-INSTALL
+
+.include <bsd.port.post.mk>
diff --git a/devel/mate-vfs/distinfo b/devel/mate-vfs/distinfo
new file mode 100644
index 0000000..8fea7c5
--- /dev/null
+++ b/devel/mate-vfs/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/mate-vfs-1.2.1.tar.xz) = 9ce0d26fcde09a7553a4842b33218b78af1470dbd41f8846f6d4ce5d5693d5a2
+SIZE (mate/mate-vfs-1.2.1.tar.xz) = 1144904
diff --git a/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-application-registry.c b/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-application-registry.c
new file mode 100644
index 0000000..c05b5a7
--- /dev/null
+++ b/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-application-registry.c
@@ -0,0 +1,26 @@
+--- libmatevfs/mate-vfs-application-registry.c.orig Sun May 22 23:09:39 2005
++++ libmatevfs/mate-vfs-application-registry.c Sun May 22 23:14:22 2005
+@@ -943,6 +943,8 @@ load_application_info (void)
+ static void
+ mate_vfs_application_registry_init (void)
+ {
++ gchar *tmp;
++
+ if (mate_vfs_application_registry_initialized)
+ return;
+
+@@ -963,6 +965,14 @@ mate_vfs_application_registry_init (voi
+ "application-registry",
+ NULL);
+ mate_registry_dir.system_dir = TRUE;
++
++ tmp = g_strconcat (g_get_home_dir(), "/.mate", NULL);
++ if (mkdir (tmp, 0700) &&
++ errno != EEXIST) {
++ g_warning("Could not create per-user MATE configuration directory: %s",
++ tmp);
++ }
++ g_free(tmp);
+
+ user_registry_dir.dirname = g_build_filename (g_get_home_dir(),
+ ".mate",
diff --git a/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-filesystem-type.c b/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-filesystem-type.c
new file mode 100644
index 0000000..f3bbd2e
--- /dev/null
+++ b/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-filesystem-type.c
@@ -0,0 +1,18 @@
+--- libmatevfs/mate-vfs-filesystem-type.c.orig 2009-10-08 10:03:36.000000000 -0400
++++ libmatevfs/mate-vfs-filesystem-type.c 2009-10-10 11:57:06.000000000 -0400
+@@ -70,6 +70,7 @@ static struct FSInfo fs_data[] = {
+ { "nfs" , N_("NFS Network Volume"), 1 },
+ { "ntfs" , N_("Windows NT Volume"), 0 },
+ { "ntfs-3g" , N_("Windows NT Volume"), 1 },
++ { "nullfs" , N_("BSD Loopback Volume"), 1 },
+ { "nilfs2" , N_("NILFS Linux Volume"), 1 },
+ { "nwfs" , N_("Netware Volume"), 0 },
+ { "proc" , N_("System Volume"), 0 },
+@@ -90,6 +91,7 @@ static struct FSInfo fs_data[] = {
+ { "xenix" , N_("Xenix Volume"), 0 },
+ { "xfs" , N_("XFS Linux Volume"), 1 },
+ { "xiafs" , N_("XIAFS Volume"), 0 },
++ { "zfs" , N_("ZFS Volume"), 1 },
+ { "cifs" , N_("CIFS Volume"), 1 },
+ };
+
diff --git a/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-hal-mounts.c b/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-hal-mounts.c
new file mode 100644
index 0000000..f6b732f
--- /dev/null
+++ b/devel/mate-vfs/files/patch-libmatevfs_mate-vfs-hal-mounts.c
@@ -0,0 +1,33 @@
+--- libmatevfs/mate-vfs-hal-mounts.c.orig Mon Aug 7 04:16:27 2006
++++ libmatevfs/mate-vfs-hal-mounts.c Sun Sep 17 17:39:48 2006
+@@ -627,20 +629,30 @@ _hal_volume_policy_check (MateVFSVolume
+ "/",
+ "/bin",
+ "/boot",
++ "/compat/linux/proc",
++ "/compat/linux/sys",
+ "/dev",
+ "/etc",
+ "/home",
+ "/lib",
+ "/lib64",
++ "/libexec",
+ "/media",
+ "/mnt",
+ "/opt",
++ "/rescue",
+ "/root",
+ "/sbin",
+ "/srv",
+ "/tmp",
+ "/usr",
++ "/usr/local",
++ "/usr/obj",
++ "/usr/ports",
++ "/usr/src",
++ "/usr/X11R6",
+ "/var",
++ "/var/tmp",
+ "/proc",
+ "/sbin",
+ NULL
diff --git a/devel/mate-vfs/files/patch-libmatevfs_xdgmime.c b/devel/mate-vfs/files/patch-libmatevfs_xdgmime.c
new file mode 100644
index 0000000..1061011
--- /dev/null
+++ b/devel/mate-vfs/files/patch-libmatevfs_xdgmime.c
@@ -0,0 +1,11 @@
+--- libmatevfs/xdgmime.c.orig Wed Aug 24 16:52:03 2005
++++ libmatevfs/xdgmime.c Wed Aug 24 16:52:47 2005
+@@ -234,7 +234,7 @@
+
+ xdg_data_dirs = getenv ("XDG_DATA_DIRS");
+ if (xdg_data_dirs == NULL)
+- xdg_data_dirs = "/usr/local/share/:/usr/share/";
++ xdg_data_dirs = "%%LOCALBASE%%/share/";
+
+ ptr = xdg_data_dirs;
+
diff --git a/devel/mate-vfs/files/patch-libmatevfs_xdgmimecache.h b/devel/mate-vfs/files/patch-libmatevfs_xdgmimecache.h
new file mode 100644
index 0000000..06e52ac
--- /dev/null
+++ b/devel/mate-vfs/files/patch-libmatevfs_xdgmimecache.h
@@ -0,0 +1,12 @@
+--- libmatevfs/xdgmimecache.h.orig 2008-06-12 10:25:40.000000000 -0400
++++ libmatevfs/xdgmimecache.h 2008-06-14 00:49:59.000000000 -0400
+@@ -46,6 +46,9 @@ typedef struct _XdgMimeCache XdgMimeCach
+ #define _xdg_mime_cache_get_icon XDG_RESERVED_ENTRY(cache_get_icon)
+ #define _xdg_mime_cache_get_generic_icon XDG_RESERVED_ENTRY(cache_get_generic_icon)
+ #define _xdg_mime_cache_glob_dump XDG_RESERVED_ENTRY(cache_glob_dump)
++#define _xdg_mime_cache_is_valid_mime_type XDG_RESERVED_ENTRY(cache_is_valid_mime_type)
++#define _xdg_mime_cache_mime_type_equal XDG_RESERVED_ENTRY(cache_mime_type_equal)
++#define _xdg_mime_cache_media_type_equal XDG_RESERVED_ENTRY(cache_media_type_equal)
+ #endif
+
+ extern XdgMimeCache **_caches;
diff --git a/devel/mate-vfs/files/patch-mate-vfs-2.0.pc.in b/devel/mate-vfs/files/patch-mate-vfs-2.0.pc.in
new file mode 100644
index 0000000..c81bcd2
--- /dev/null
+++ b/devel/mate-vfs/files/patch-mate-vfs-2.0.pc.in
@@ -0,0 +1,9 @@
+--- mate-vfs-2.0.pc.in.orig Tue Jul 11 07:31:58 2006
++++ mate-vfs-2.0.pc.in Tue Jul 11 09:33:47 2006
+@@ -8,5 +8,5 @@
+ Description: The MATE virtual file-system libraries
+ Version: @VERSION@
+ Requires: mateconf-2.0 gthread-2.0 gmodule-no-export-2.0 gobject-2.0
+-Libs: -L${libdir} -lmatevfs-2
++Libs: -L${libdir} -lmatevfs-2 @PTHREAD_LIB@
+ Cflags: -I${includedir}/mate-vfs-2.0 -I${libdir}/mate-vfs-2.0/include
diff --git a/devel/mate-vfs/files/patch-mate-vfs-module-2.0.pc.in b/devel/mate-vfs/files/patch-mate-vfs-module-2.0.pc.in
new file mode 100644
index 0000000..d672b66
--- /dev/null
+++ b/devel/mate-vfs/files/patch-mate-vfs-module-2.0.pc.in
@@ -0,0 +1,9 @@
+--- mate-vfs-module-2.0.pc.in.orig Tue Jul 11 07:31:58 2006
++++ mate-vfs-module-2.0.pc.in Tue Jul 11 09:34:36 2006
+@@ -8,5 +8,5 @@
+ Description: The MATE virtual file-system module include info
+ Version: @VERSION@
+ Requires: mateconf-2.0 gthread-2.0 gmodule-no-export-2.0 gobject-2.0
+-Libs: -L${libdir} -lmatevfs-2
++Libs: -L${libdir} -lmatevfs-2 @PTHREAD_LIB@
+ Cflags: -I${includedir}/mate-vfs-2.0 -I${includedir}/mate-vfs-module-2.0 -I${libdir}/mate-vfs-2.0/include
diff --git a/devel/mate-vfs/files/patch-modules_file-method-acl.c b/devel/mate-vfs/files/patch-modules_file-method-acl.c
new file mode 100644
index 0000000..7ec9a33
--- /dev/null
+++ b/devel/mate-vfs/files/patch-modules_file-method-acl.c
@@ -0,0 +1,11 @@
+--- modules/file-method-acl.c.orig Mon Jul 24 18:47:12 2006
++++ modules/file-method-acl.c Mon Jul 24 22:01:34 2006
+@@ -45,7 +45,7 @@
+ #endif
+
+ #ifdef HAVE_POSIX_ACL
+-# include <acl/libacl.h>
++# include <sys/acl.h>
+ #define HAVE_ACL 1
+ #endif
+
diff --git a/devel/mate-vfs/files/patch-modules_gzip-method.c b/devel/mate-vfs/files/patch-modules_gzip-method.c
new file mode 100644
index 0000000..3288d18
--- /dev/null
+++ b/devel/mate-vfs/files/patch-modules_gzip-method.c
@@ -0,0 +1,10 @@
+--- modules/gzip-method.c.orig 2010-03-25 16:05:12.000000000 -0400
++++ modules/gzip-method.c 2010-03-25 16:06:56.000000000 -0400
+@@ -30,6 +30,7 @@
+ #include <stdio.h>
+ #include <string.h>
+ #include <time.h>
++#undef _LARGEFILE64_SOURCE
+ #include <zlib.h>
+
+ struct _GZipMethodHandle {
diff --git a/devel/mate-vfs/pkg-deinstall.in b/devel/mate-vfs/pkg-deinstall.in
new file mode 100644
index 0000000..fb31c68
--- /dev/null
+++ b/devel/mate-vfs/pkg-deinstall.in
@@ -0,0 +1,20 @@
+#!/bin/sh
+#
+# $FreeBSD$
+# $MCom$
+#
+# Restore mateconf keys of libmate.
+
+if [ "$2" != "POST-DEINSTALL" ]; then
+ exit 0
+fi
+
+SCHEMAS=%%LOCALBASE%%/etc/mateconf/schemas/desktop_mate_applications_terminal.schemas
+
+if [ -f ${SCHEMAS} ]; then
+ env MATECONF_CONFIG_SOURCE=xml::%%LOCALBASE%%/etc/mateconf/mateconf.xml.defaults \
+ %%LOCALBASE%%/bin/mateconftool-2 --makefile-install-rule ${SCHEMAS} \
+ > /dev/null || /usr/bin/true
+fi
+
+exit 0
diff --git a/devel/mate-vfs/pkg-descr b/devel/mate-vfs/pkg-descr
new file mode 100644
index 0000000..a1d03c6
--- /dev/null
+++ b/devel/mate-vfs/pkg-descr
@@ -0,0 +1,7 @@
+The MATE Virtual File System allows applications and users to treat
+any number of file system concepts as a part of the local filesystem.
+With MateVFS, filesystems across the internet, on connected devices,
+and in multiple formats are as simple to access (and write code for)
+as any directory on the local machine.
+
+WWW: http://mate-desktop.org/
diff --git a/devel/mate-vfs/pkg-install.in b/devel/mate-vfs/pkg-install.in
new file mode 100644
index 0000000..6619cf5
--- /dev/null
+++ b/devel/mate-vfs/pkg-install.in
@@ -0,0 +1,20 @@
+#!/bin/sh
+#
+# $FreeBSD$
+# $MCom$
+#
+# Restore mateconf keys of libmate.
+
+if [ "$2" != "POST-INSTALL" ]; then
+ exit 0
+fi
+
+SCHEMAS=%%LOCALBASE%%/etc/mateconf/schemas/desktop_mate_applications_terminal.schemas
+
+if [ -f ${SCHEMAS} ]; then
+ env MATECONF_CONFIG_SOURCE=xml::%%LOCALBASE%%/etc/mateconf/mateconf.xml.defaults \
+ %%LOCALBASE%%/bin/mateconftool-2 --makefile-install-rule ${SCHEMAS} \
+ > /dev/null || /usr/bin/true
+fi
+
+exit 0
diff --git a/devel/mate-vfs/pkg-plist b/devel/mate-vfs/pkg-plist
new file mode 100644
index 0000000..2480dae
--- /dev/null
+++ b/devel/mate-vfs/pkg-plist
@@ -0,0 +1,320 @@
+bin/matevfs-cat
+bin/matevfs-copy
+bin/matevfs-df
+bin/matevfs-info
+bin/matevfs-ls
+bin/matevfs-mkdir
+bin/matevfs-monitor
+bin/matevfs-mv
+bin/matevfs-rm
+etc/mate-vfs-2.0/modules/default-modules.conf
+etc/mate-vfs-2.0/modules/smb-module.conf
+etc/mate-vfs-2.0/modules/ssl-modules.conf
+include/mate-vfs-2.0/include/mate-vfs-file-size.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-ace.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-acl.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-address.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-application-registry.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-async-ops.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-cancellation.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-context.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-directory.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-dns-sd.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-drive.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-enum-types.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-file-info.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-file-size.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-find-directory.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-handle.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-init.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-job-limit.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-mime-deprecated.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-mime-handlers.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-mime-info-cache.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-mime-monitor.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-mime-utils.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-mime.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-module-callback.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-monitor.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-ops.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-resolve.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-result.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-standard-callbacks.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-types.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-uri.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-utils.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-version.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-volume-monitor.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-volume.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs-xfer.h
+include/mate-vfs-2.0/libmatevfs/mate-vfs.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-cancellable-ops.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-inet-connection.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-method.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-mime-info.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-module-callback-module-api.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-module-shared.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-module.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-parse-ls.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-pty.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-socket-buffer.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-socket.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-ssl.h
+include/mate-vfs-module-2.0/libmatevfs/mate-vfs-transform.h
+lib/libmatevfs-2.a
+lib/libmatevfs-2.la
+lib/libmatevfs-2.so
+lib/libmatevfs-2.so.0
+lib/mate-vfs-2.0/modules/libbzip2.a
+lib/mate-vfs-2.0/modules/libbzip2.la
+lib/mate-vfs-2.0/modules/libbzip2.so
+lib/mate-vfs-2.0/modules/libcomputer.a
+lib/mate-vfs-2.0/modules/libcomputer.la
+lib/mate-vfs-2.0/modules/libcomputer.so
+lib/mate-vfs-2.0/modules/libdns-sd.a
+lib/mate-vfs-2.0/modules/libdns-sd.la
+lib/mate-vfs-2.0/modules/libdns-sd.so
+lib/mate-vfs-2.0/modules/libfile.a
+lib/mate-vfs-2.0/modules/libfile.la
+lib/mate-vfs-2.0/modules/libfile.so
+lib/mate-vfs-2.0/modules/libftp.a
+lib/mate-vfs-2.0/modules/libftp.la
+lib/mate-vfs-2.0/modules/libftp.so
+lib/mate-vfs-2.0/modules/libgzip.a
+lib/mate-vfs-2.0/modules/libgzip.la
+lib/mate-vfs-2.0/modules/libgzip.so
+lib/mate-vfs-2.0/modules/libhttp.a
+lib/mate-vfs-2.0/modules/libhttp.la
+lib/mate-vfs-2.0/modules/libhttp.so
+lib/mate-vfs-2.0/modules/libnetwork.a
+lib/mate-vfs-2.0/modules/libnetwork.la
+lib/mate-vfs-2.0/modules/libnetwork.so
+lib/mate-vfs-2.0/modules/libnntp.a
+lib/mate-vfs-2.0/modules/libnntp.la
+lib/mate-vfs-2.0/modules/libnntp.so
+lib/mate-vfs-2.0/modules/libsftp.a
+lib/mate-vfs-2.0/modules/libsftp.la
+lib/mate-vfs-2.0/modules/libsftp.so
+lib/mate-vfs-2.0/modules/libsmb.a
+lib/mate-vfs-2.0/modules/libsmb.la
+lib/mate-vfs-2.0/modules/libsmb.so
+lib/mate-vfs-2.0/modules/libtar.a
+lib/mate-vfs-2.0/modules/libtar.la
+lib/mate-vfs-2.0/modules/libtar.so
+lib/mate-vfs-2.0/modules/libvfs-test.a
+lib/mate-vfs-2.0/modules/libvfs-test.la
+lib/mate-vfs-2.0/modules/libvfs-test.so
+libdata/pkgconfig/mate-vfs-2.0.pc
+libdata/pkgconfig/mate-vfs-module-2.0.pc
+libexec/mate-vfs-daemon
+share/dbus-1/services/mate-vfs-daemon.service
+share/doc/mate-vfs-2.0/about.html
+share/doc/mate-vfs-2.0/data-types.html
+share/doc/mate-vfs-2.0/home.png
+share/doc/mate-vfs-2.0/index.html
+share/doc/mate-vfs-2.0/index.sgml
+share/doc/mate-vfs-2.0/left.png
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-application-registry.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-async-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-cancellation.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-context.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-directory-basic-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-directory-find-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-directory-list-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-dns-sd.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-drive.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-file-advanced-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-file-basic-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-file-info-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-file-info.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-file-rw-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-file-size.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-file-trunc-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-inet-connection.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-init.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-method.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-mime-database-deprecated.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-mime-database.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-mime-monitor.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-mime-utils.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-mime.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-module-callback-module-api.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-module-callback.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-module-shared.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-module.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-monitor.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-parse-ls.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-resolve.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-result.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-socket-buffer.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-socket.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-ssl.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-standard-callbacks.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-transform.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-uri.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-utils.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-volume-monitor.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-volume.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0-mate-vfs-xfer.html
+share/doc/mate-vfs-2.0/mate-vfs-2.0.devhelp
+share/doc/mate-vfs-2.0/mate-vfs-2.0.devhelp2
+share/doc/mate-vfs-2.0/mate-vfs-basic-file-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-directory-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-file-and-dirs-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-file-async-ops.html
+share/doc/mate-vfs-2.0/mate-vfs-first-steps.html
+share/doc/mate-vfs-2.0/mate-vfs-writing-modules.html
+share/doc/mate-vfs-2.0/mime-registry.html
+share/doc/mate-vfs-2.0/modules.html
+share/doc/mate-vfs-2.0/networking.html
+share/doc/mate-vfs-2.0/right.png
+share/doc/mate-vfs-2.0/style.css
+share/doc/mate-vfs-2.0/up.png
+share/doc/mate-vfs-2.0/volumes.html
+share/locale/af/LC_MESSAGES/mate-vfs.mo
+share/locale/am/LC_MESSAGES/mate-vfs.mo
+share/locale/ar/LC_MESSAGES/mate-vfs.mo
+share/locale/as/LC_MESSAGES/mate-vfs.mo
+share/locale/ast/LC_MESSAGES/mate-vfs.mo
+share/locale/az/LC_MESSAGES/mate-vfs.mo
+share/locale/be/LC_MESSAGES/mate-vfs.mo
+share/locale/bg/LC_MESSAGES/mate-vfs.mo
+share/locale/bn/LC_MESSAGES/mate-vfs.mo
+share/locale/bn_IN/LC_MESSAGES/mate-vfs.mo
+share/locale/bs/LC_MESSAGES/mate-vfs.mo
+share/locale/ca/LC_MESSAGES/mate-vfs.mo
+share/locale/ca@valencia/LC_MESSAGES/mate-vfs.mo
+share/locale/cs/LC_MESSAGES/mate-vfs.mo
+share/locale/cy/LC_MESSAGES/mate-vfs.mo
+share/locale/da/LC_MESSAGES/mate-vfs.mo
+share/locale/de/LC_MESSAGES/mate-vfs.mo
+share/locale/dz/LC_MESSAGES/mate-vfs.mo
+share/locale/el/LC_MESSAGES/mate-vfs.mo
+share/locale/en@shaw/LC_MESSAGES/mate-vfs.mo
+share/locale/en_CA/LC_MESSAGES/mate-vfs.mo
+share/locale/en_GB/LC_MESSAGES/mate-vfs.mo
+share/locale/eo/LC_MESSAGES/mate-vfs.mo
+share/locale/es/LC_MESSAGES/mate-vfs.mo
+share/locale/et/LC_MESSAGES/mate-vfs.mo
+share/locale/eu/LC_MESSAGES/mate-vfs.mo
+share/locale/fa/LC_MESSAGES/mate-vfs.mo
+share/locale/fi/LC_MESSAGES/mate-vfs.mo
+share/locale/fr/LC_MESSAGES/mate-vfs.mo
+share/locale/ga/LC_MESSAGES/mate-vfs.mo
+share/locale/gl/LC_MESSAGES/mate-vfs.mo
+share/locale/gu/LC_MESSAGES/mate-vfs.mo
+share/locale/he/LC_MESSAGES/mate-vfs.mo
+share/locale/hi/LC_MESSAGES/mate-vfs.mo
+share/locale/hr/LC_MESSAGES/mate-vfs.mo
+share/locale/hu/LC_MESSAGES/mate-vfs.mo
+share/locale/id/LC_MESSAGES/mate-vfs.mo
+share/locale/is/LC_MESSAGES/mate-vfs.mo
+share/locale/it/LC_MESSAGES/mate-vfs.mo
+share/locale/ja/LC_MESSAGES/mate-vfs.mo
+share/locale/ka/LC_MESSAGES/mate-vfs.mo
+share/locale/kn/LC_MESSAGES/mate-vfs.mo
+share/locale/ko/LC_MESSAGES/mate-vfs.mo
+share/locale/ku/LC_MESSAGES/mate-vfs.mo
+share/locale/li/LC_MESSAGES/mate-vfs.mo
+share/locale/lt/LC_MESSAGES/mate-vfs.mo
+share/locale/lv/LC_MESSAGES/mate-vfs.mo
+share/locale/mai/LC_MESSAGES/mate-vfs.mo
+share/locale/mg/LC_MESSAGES/mate-vfs.mo
+share/locale/mk/LC_MESSAGES/mate-vfs.mo
+share/locale/ml/LC_MESSAGES/mate-vfs.mo
+share/locale/mn/LC_MESSAGES/mate-vfs.mo
+share/locale/mr/LC_MESSAGES/mate-vfs.mo
+share/locale/ms/LC_MESSAGES/mate-vfs.mo
+share/locale/nb/LC_MESSAGES/mate-vfs.mo
+share/locale/ne/LC_MESSAGES/mate-vfs.mo
+share/locale/nl/LC_MESSAGES/mate-vfs.mo
+share/locale/nn/LC_MESSAGES/mate-vfs.mo
+share/locale/nso/LC_MESSAGES/mate-vfs.mo
+share/locale/oc/LC_MESSAGES/mate-vfs.mo
+share/locale/or/LC_MESSAGES/mate-vfs.mo
+share/locale/pa/LC_MESSAGES/mate-vfs.mo
+share/locale/pl/LC_MESSAGES/mate-vfs.mo
+share/locale/pt/LC_MESSAGES/mate-vfs.mo
+share/locale/pt_BR/LC_MESSAGES/mate-vfs.mo
+share/locale/ro/LC_MESSAGES/mate-vfs.mo
+share/locale/ru/LC_MESSAGES/mate-vfs.mo
+share/locale/rw/LC_MESSAGES/mate-vfs.mo
+share/locale/sk/LC_MESSAGES/mate-vfs.mo
+share/locale/sl/LC_MESSAGES/mate-vfs.mo
+share/locale/sq/LC_MESSAGES/mate-vfs.mo
+share/locale/sr/LC_MESSAGES/mate-vfs.mo
+share/locale/sr@ije/LC_MESSAGES/mate-vfs.mo
+share/locale/sr@latin/LC_MESSAGES/mate-vfs.mo
+share/locale/sv/LC_MESSAGES/mate-vfs.mo
+share/locale/ta/LC_MESSAGES/mate-vfs.mo
+share/locale/te/LC_MESSAGES/mate-vfs.mo
+share/locale/th/LC_MESSAGES/mate-vfs.mo
+share/locale/tr/LC_MESSAGES/mate-vfs.mo
+share/locale/uk/LC_MESSAGES/mate-vfs.mo
+share/locale/uz/LC_MESSAGES/mate-vfs.mo
+share/locale/uz@cyrillic/LC_MESSAGES/mate-vfs.mo
+share/locale/vi/LC_MESSAGES/mate-vfs.mo
+share/locale/wa/LC_MESSAGES/mate-vfs.mo
+share/locale/xh/LC_MESSAGES/mate-vfs.mo
+share/locale/yi/LC_MESSAGES/mate-vfs.mo
+share/locale/zh_CN/LC_MESSAGES/mate-vfs.mo
+share/locale/zh_HK/LC_MESSAGES/mate-vfs.mo
+share/locale/zh_TW/LC_MESSAGES/mate-vfs.mo
+share/locale/zu/LC_MESSAGES/mate-vfs.mo
+@dirrmtry share/locale/zu/LC_MESSAGES
+@dirrmtry share/locale/zu
+@dirrmtry share/locale/zh_HK/LC_MESSAGES
+@dirrmtry share/locale/zh_HK
+@dirrmtry share/locale/yi/LC_MESSAGES
+@dirrmtry share/locale/yi
+@dirrmtry share/locale/xh/LC_MESSAGES
+@dirrmtry share/locale/xh
+@dirrmtry share/locale/uz@cyrillic/LC_MESSAGES
+@dirrmtry share/locale/uz@cyrillic
+@dirrmtry share/locale/te/LC_MESSAGES
+@dirrmtry share/locale/te
+@dirrmtry share/locale/sr@latin/LC_MESSAGES
+@dirrmtry share/locale/sr@latin
+@dirrmtry share/locale/sr@ije/LC_MESSAGES
+@dirrmtry share/locale/sr@ije
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/oc/LC_MESSAGES
+@dirrmtry share/locale/oc
+@dirrmtry share/locale/nso/LC_MESSAGES
+@dirrmtry share/locale/nso
+@dirrmtry share/locale/mr/LC_MESSAGES
+@dirrmtry share/locale/mr
+@dirrmtry share/locale/mg/LC_MESSAGES
+@dirrmtry share/locale/mg
+@dirrmtry share/locale/mai/LC_MESSAGES
+@dirrmtry share/locale/mai
+@dirrmtry share/locale/ku/LC_MESSAGES
+@dirrmtry share/locale/ku
+@dirrmtry share/locale/en@shaw/LC_MESSAGES
+@dirrmtry share/locale/en@shaw
+@dirrmtry share/locale/dz/LC_MESSAGES
+@dirrmtry share/locale/dz
+@dirrmtry share/locale/ca@valencia/LC_MESSAGES
+@dirrmtry share/locale/ca@valencia
+@dirrmtry share/locale/bn_IN/LC_MESSAGES
+@dirrmtry share/locale/bn_IN
+@dirrmtry share/locale/ast/LC_MESSAGES
+@dirrmtry share/locale/ast
+@dirrmtry share/locale/as/LC_MESSAGES
+@dirrmtry share/locale/as
+@dirrm share/doc/mate-vfs-2.0
+@dirrm share/dbus-1/services
+@dirrm share/dbus-1
+@dirrm lib/mate-vfs-2.0/modules
+@dirrm lib/mate-vfs-2.0
+@dirrm include/mate-vfs-module-2.0/libmatevfs
+@dirrm include/mate-vfs-module-2.0
+@dirrm include/mate-vfs-2.0/libmatevfs
+@dirrm include/mate-vfs-2.0/include
+@dirrm include/mate-vfs-2.0
+@dirrm etc/mateconf/schemas
+@dirrm etc/mateconf/mateconf.xml.defaults
+@dirrm etc/mateconf
+@dirrm etc/mate-vfs-2.0/modules
+@dirrm etc/mate-vfs-2.0
diff --git a/graphics/libmatecanvas/Makefile b/graphics/libmatecanvas/Makefile
new file mode 100644
index 0000000..83fd115
--- /dev/null
+++ b/graphics/libmatecanvas/Makefile
@@ -0,0 +1,35 @@
+# New ports collection makefile for: gnomecanvas
+# Date created: 18 May 2001
+# Whom: Maxim Sobolev <sobomax@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= libmatecanvas
+PORTVERSION= 1.2.0
+CATEGORIES= graphics mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= A graphics library for MATE
+
+BUILD_DEPENDS= gtkdoc-check:${PORTSDIR}/textproc/gtk-doc
+
+USE_XZ= yes
+USE_MATE= autogen common:build intlhack ltverhack matehack
+USE_GMAKE= yes
+USE_GNOME= glib20 gtk20 libartlgpl2 libglade2 pango
+USE_GETTEXT= yes
+USE_LDCONFIG= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env libtool libtoolize:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --with-html-dir=${PREFIX}/share/doc \
+ --enable-glade \
+ --disable-gtk-doc \
+ --with-gtk=2.0
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib
+
+.include <bsd.port.mk>
diff --git a/graphics/libmatecanvas/distinfo b/graphics/libmatecanvas/distinfo
new file mode 100644
index 0000000..3aec257
--- /dev/null
+++ b/graphics/libmatecanvas/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/libmatecanvas-1.2.0.tar.xz) = 7d3897a692c3ab31cce24a194b921987a6c06b2bbb68c78724c9f0240e9e74a3
+SIZE (mate/libmatecanvas-1.2.0.tar.xz) = 284260
diff --git a/graphics/libmatecanvas/files/patch-libmatecanvas_mate-canvas-shape.c b/graphics/libmatecanvas/files/patch-libmatecanvas_mate-canvas-shape.c
new file mode 100644
index 0000000..ccb0413
--- /dev/null
+++ b/graphics/libmatecanvas/files/patch-libmatecanvas_mate-canvas-shape.c
@@ -0,0 +1,11 @@
+--- libmatecanvas/mate-canvas-shape.c.orig Fri May 20 16:55:35 2005
++++ libmatecanvas/mate-canvas-shape.c Fri May 20 16:55:41 2005
+@@ -1343,7 +1343,7 @@ gcbp_destroy_gdk (MateCanvasShape * sha
+ {
+ MateCanvasShapePrivGdk * gdk;
+
+- g_assert (!((MateCanvasItem *)shape)->canvas->aa);
++ /*g_assert (!((MateCanvasItem *)shape)->canvas->aa);*/
+
+ gdk = shape->priv->gdk;
+
diff --git a/graphics/libmatecanvas/pkg-descr b/graphics/libmatecanvas/pkg-descr
new file mode 100644
index 0000000..9d67178
--- /dev/null
+++ b/graphics/libmatecanvas/pkg-descr
@@ -0,0 +1,3 @@
+The MATECanvas library allows images to be used directly within GUIs.
+
+WWW: http://mate-desktop.org/
diff --git a/graphics/libmatecanvas/pkg-plist b/graphics/libmatecanvas/pkg-plist
new file mode 100644
index 0000000..1bc130e
--- /dev/null
+++ b/graphics/libmatecanvas/pkg-plist
@@ -0,0 +1,186 @@
+include/libmatecanvas-2.0/libmatecanvas/libmatecanvas.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-bpath.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-clipgroup.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-line.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-path-def.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-pixbuf.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-polygon.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-rect-ellipse.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-rich-text.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-shape.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-text.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-util.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas-widget.h
+include/libmatecanvas-2.0/libmatecanvas/mate-canvas.h
+lib/libglade/2.0/libgladematecanvas.a
+lib/libglade/2.0/libgladematecanvas.la
+lib/libglade/2.0/libgladematecanvas.so
+lib/libmatecanvas-2.a
+lib/libmatecanvas-2.la
+lib/libmatecanvas-2.so
+lib/libmatecanvas-2.so.0
+libdata/pkgconfig/libmatecanvas-2.0.pc
+%%DOCSDIR%%/MateCanvas.html
+%%DOCSDIR%%/MateCanvasBpath.html
+%%DOCSDIR%%/MateCanvasClipgroup.html
+%%DOCSDIR%%/MateCanvasEllipse.html
+%%DOCSDIR%%/MateCanvasGroup.html
+%%DOCSDIR%%/MateCanvasItem.html
+%%DOCSDIR%%/MateCanvasLine.html
+%%DOCSDIR%%/MateCanvasPixbuf.html
+%%DOCSDIR%%/MateCanvasPolygon.html
+%%DOCSDIR%%/MateCanvasRE.html
+%%DOCSDIR%%/MateCanvasRect.html
+%%DOCSDIR%%/MateCanvasRichText.html
+%%DOCSDIR%%/MateCanvasShape.html
+%%DOCSDIR%%/MateCanvasWidget.html
+%%DOCSDIR%%/ch01.html
+%%DOCSDIR%%/ch02.html
+%%DOCSDIR%%/home.png
+%%DOCSDIR%%/index.html
+%%DOCSDIR%%/index.sgml
+%%DOCSDIR%%/left.png
+%%DOCSDIR%%/libmatecanvas-mate-canvas-path-def.html
+%%DOCSDIR%%/libmatecanvas-mate-canvas-text.html
+%%DOCSDIR%%/libmatecanvas-mate-canvas-util.html
+%%DOCSDIR%%/libmatecanvas.devhelp
+%%DOCSDIR%%/libmatecanvas.devhelp2
+%%DOCSDIR%%/right.png
+%%DOCSDIR%%/style.css
+%%DOCSDIR%%/up.png
+share/locale/am/LC_MESSAGES/libmatecanvas.mo
+share/locale/ang/LC_MESSAGES/libmatecanvas.mo
+share/locale/ar/LC_MESSAGES/libmatecanvas.mo
+share/locale/as/LC_MESSAGES/libmatecanvas.mo
+share/locale/ast/LC_MESSAGES/libmatecanvas.mo
+share/locale/az/LC_MESSAGES/libmatecanvas.mo
+share/locale/be/LC_MESSAGES/libmatecanvas.mo
+share/locale/bg/LC_MESSAGES/libmatecanvas.mo
+share/locale/bn/LC_MESSAGES/libmatecanvas.mo
+share/locale/bn_IN/LC_MESSAGES/libmatecanvas.mo
+share/locale/br/LC_MESSAGES/libmatecanvas.mo
+share/locale/bs/LC_MESSAGES/libmatecanvas.mo
+share/locale/ca/LC_MESSAGES/libmatecanvas.mo
+share/locale/ca@valencia/LC_MESSAGES/libmatecanvas.mo
+share/locale/crh/LC_MESSAGES/libmatecanvas.mo
+share/locale/cs/LC_MESSAGES/libmatecanvas.mo
+share/locale/cy/LC_MESSAGES/libmatecanvas.mo
+share/locale/da/LC_MESSAGES/libmatecanvas.mo
+share/locale/de/LC_MESSAGES/libmatecanvas.mo
+share/locale/dz/LC_MESSAGES/libmatecanvas.mo
+share/locale/el/LC_MESSAGES/libmatecanvas.mo
+share/locale/en@shaw/LC_MESSAGES/libmatecanvas.mo
+share/locale/en_CA/LC_MESSAGES/libmatecanvas.mo
+share/locale/en_GB/LC_MESSAGES/libmatecanvas.mo
+share/locale/eo/LC_MESSAGES/libmatecanvas.mo
+share/locale/es/LC_MESSAGES/libmatecanvas.mo
+share/locale/et/LC_MESSAGES/libmatecanvas.mo
+share/locale/eu/LC_MESSAGES/libmatecanvas.mo
+share/locale/fa/LC_MESSAGES/libmatecanvas.mo
+share/locale/fi/LC_MESSAGES/libmatecanvas.mo
+share/locale/fr/LC_MESSAGES/libmatecanvas.mo
+share/locale/ga/LC_MESSAGES/libmatecanvas.mo
+share/locale/gl/LC_MESSAGES/libmatecanvas.mo
+share/locale/gu/LC_MESSAGES/libmatecanvas.mo
+share/locale/he/LC_MESSAGES/libmatecanvas.mo
+share/locale/hi/LC_MESSAGES/libmatecanvas.mo
+share/locale/hr/LC_MESSAGES/libmatecanvas.mo
+share/locale/hu/LC_MESSAGES/libmatecanvas.mo
+share/locale/id/LC_MESSAGES/libmatecanvas.mo
+share/locale/is/LC_MESSAGES/libmatecanvas.mo
+share/locale/it/LC_MESSAGES/libmatecanvas.mo
+share/locale/ja/LC_MESSAGES/libmatecanvas.mo
+share/locale/ka/LC_MESSAGES/libmatecanvas.mo
+share/locale/kn/LC_MESSAGES/libmatecanvas.mo
+share/locale/ko/LC_MESSAGES/libmatecanvas.mo
+share/locale/ku/LC_MESSAGES/libmatecanvas.mo
+share/locale/li/LC_MESSAGES/libmatecanvas.mo
+share/locale/lt/LC_MESSAGES/libmatecanvas.mo
+share/locale/lv/LC_MESSAGES/libmatecanvas.mo
+share/locale/mai/LC_MESSAGES/libmatecanvas.mo
+share/locale/mg/LC_MESSAGES/libmatecanvas.mo
+share/locale/mk/LC_MESSAGES/libmatecanvas.mo
+share/locale/ml/LC_MESSAGES/libmatecanvas.mo
+share/locale/mn/LC_MESSAGES/libmatecanvas.mo
+share/locale/mr/LC_MESSAGES/libmatecanvas.mo
+share/locale/ms/LC_MESSAGES/libmatecanvas.mo
+share/locale/nb/LC_MESSAGES/libmatecanvas.mo
+share/locale/ne/LC_MESSAGES/libmatecanvas.mo
+share/locale/nl/LC_MESSAGES/libmatecanvas.mo
+share/locale/nn/LC_MESSAGES/libmatecanvas.mo
+share/locale/oc/LC_MESSAGES/libmatecanvas.mo
+share/locale/or/LC_MESSAGES/libmatecanvas.mo
+share/locale/pa/LC_MESSAGES/libmatecanvas.mo
+share/locale/pl/LC_MESSAGES/libmatecanvas.mo
+share/locale/pt/LC_MESSAGES/libmatecanvas.mo
+share/locale/pt_BR/LC_MESSAGES/libmatecanvas.mo
+share/locale/ro/LC_MESSAGES/libmatecanvas.mo
+share/locale/ru/LC_MESSAGES/libmatecanvas.mo
+share/locale/rw/LC_MESSAGES/libmatecanvas.mo
+share/locale/sk/LC_MESSAGES/libmatecanvas.mo
+share/locale/sl/LC_MESSAGES/libmatecanvas.mo
+share/locale/sq/LC_MESSAGES/libmatecanvas.mo
+share/locale/sr/LC_MESSAGES/libmatecanvas.mo
+share/locale/sr@ije/LC_MESSAGES/libmatecanvas.mo
+share/locale/sr@latin/LC_MESSAGES/libmatecanvas.mo
+share/locale/sv/LC_MESSAGES/libmatecanvas.mo
+share/locale/ta/LC_MESSAGES/libmatecanvas.mo
+share/locale/te/LC_MESSAGES/libmatecanvas.mo
+share/locale/th/LC_MESSAGES/libmatecanvas.mo
+share/locale/tr/LC_MESSAGES/libmatecanvas.mo
+share/locale/tt/LC_MESSAGES/libmatecanvas.mo
+share/locale/uk/LC_MESSAGES/libmatecanvas.mo
+share/locale/vi/LC_MESSAGES/libmatecanvas.mo
+share/locale/wa/LC_MESSAGES/libmatecanvas.mo
+share/locale/xh/LC_MESSAGES/libmatecanvas.mo
+share/locale/yi/LC_MESSAGES/libmatecanvas.mo
+share/locale/zh_CN/LC_MESSAGES/libmatecanvas.mo
+share/locale/zh_HK/LC_MESSAGES/libmatecanvas.mo
+share/locale/zh_TW/LC_MESSAGES/libmatecanvas.mo
+@dirrmtry share/locale/zh_HK/LC_MESSAGES
+@dirrmtry share/locale/zh_HK
+@dirrmtry share/locale/yi/LC_MESSAGES
+@dirrmtry share/locale/yi
+@dirrmtry share/locale/xh/LC_MESSAGES
+@dirrmtry share/locale/xh
+@dirrmtry share/locale/tt/LC_MESSAGES
+@dirrmtry share/locale/tt
+@dirrmtry share/locale/te/LC_MESSAGES
+@dirrmtry share/locale/te
+@dirrmtry share/locale/sr@latin/LC_MESSAGES
+@dirrmtry share/locale/sr@latin
+@dirrmtry share/locale/sr@ije/LC_MESSAGES
+@dirrmtry share/locale/sr@ije
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/oc/LC_MESSAGES
+@dirrmtry share/locale/oc
+@dirrmtry share/locale/mr/LC_MESSAGES
+@dirrmtry share/locale/mr
+@dirrmtry share/locale/mg/LC_MESSAGES
+@dirrmtry share/locale/mg
+@dirrmtry share/locale/mai/LC_MESSAGES
+@dirrmtry share/locale/mai
+@dirrmtry share/locale/ku/LC_MESSAGES
+@dirrmtry share/locale/ku
+@dirrmtry share/locale/en@shaw/LC_MESSAGES
+@dirrmtry share/locale/en@shaw
+@dirrmtry share/locale/dz/LC_MESSAGES
+@dirrmtry share/locale/dz
+@dirrmtry share/locale/crh/LC_MESSAGES
+@dirrmtry share/locale/crh
+@dirrmtry share/locale/ca@valencia/LC_MESSAGES
+@dirrmtry share/locale/ca@valencia
+@dirrmtry share/locale/bn_IN/LC_MESSAGES
+@dirrmtry share/locale/bn_IN
+@dirrmtry share/locale/ast/LC_MESSAGES
+@dirrmtry share/locale/ast
+@dirrmtry share/locale/as/LC_MESSAGES
+@dirrmtry share/locale/as
+@dirrmtry share/locale/ang/LC_MESSAGES
+@dirrmtry share/locale/ang
+@dirrm %%DOCSDIR%%
+@dirrm lib/libglade/2.0
+@dirrm lib/libglade
+@dirrm include/libmatecanvas-2.0/libmatecanvas
+@dirrm include/libmatecanvas-2.0
diff --git a/misc/mate-mime-data/Makefile b/misc/mate-mime-data/Makefile
new file mode 100644
index 0000000..ae2123e
--- /dev/null
+++ b/misc/mate-mime-data/Makefile
@@ -0,0 +1,28 @@
+# New ports collection makefile for: gnomemimedata
+# Date created: 22 January 2002
+# Whom: Maxim Sobolev <sobomax@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= mate-mime-data
+PORTVERSION= 1.2.2
+CATEGORIES= misc mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= A MIME and Application database for MATE
+
+USE_XZ= yes
+USE_MATE= autogen common:build intlhack matehack
+USE_GMAKE= yes
+USE_GNOME= pkgconfig
+USE_GETTEXT= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env
+GNU_CONFIGURE= yes
+CONFIGURE_ENV= LIBS="-L${LOCALBASE}/lib -lintl"
+CPPFLAGS+= -I${LOCALBASE}/include
+
+.include <bsd.port.mk>
diff --git a/misc/mate-mime-data/distinfo b/misc/mate-mime-data/distinfo
new file mode 100644
index 0000000..f84bd18
--- /dev/null
+++ b/misc/mate-mime-data/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/mate-mime-data-1.2.2.tar.xz) = d810c6ddaa01eab16d178a535851a575771e622f43a2d776f3c10cf595e1ce42
+SIZE (mate/mate-mime-data-1.2.2.tar.xz) = 266048
diff --git a/misc/mate-mime-data/files/patch-mate-vfs.applications b/misc/mate-mime-data/files/patch-mate-vfs.applications
new file mode 100644
index 0000000..3cedf0e
--- /dev/null
+++ b/misc/mate-mime-data/files/patch-mate-vfs.applications
@@ -0,0 +1,18 @@
+--- mate-vfs.applications.orig Mon Dec 22 19:56:33 2003
++++ mate-vfs.applications Thu Apr 8 19:50:18 2004
+@@ -1,5 +1,5 @@
+ abiword
+- command=AbiWord-2.0
++ command=abiword
+ name=AbiWord
+ can_open_multiple_files=true
+ expects_uris=false
+@@ -55,7 +55,7 @@
+ mime_types=application/x-deb
+
+ electric_eyes
+- command=ee
++ command=ElectricEyes
+ name=Electric Eyes
+ can_open_multiple_files=true
+ expects_uris=false
diff --git a/misc/mate-mime-data/pkg-descr b/misc/mate-mime-data/pkg-descr
new file mode 100644
index 0000000..ac5a397
--- /dev/null
+++ b/misc/mate-mime-data/pkg-descr
@@ -0,0 +1,4 @@
+The base MIME and Application database for MATE. It is meant to be accessed
+through the MIME functions in MateVFS.
+
+WWW: http://mate-desktop.org/
diff --git a/misc/mate-mime-data/pkg-plist b/misc/mate-mime-data/pkg-plist
new file mode 100644
index 0000000..9717132
--- /dev/null
+++ b/misc/mate-mime-data/pkg-plist
@@ -0,0 +1,92 @@
+etc/mate-vfs-mime-magic
+libdata/pkgconfig/mate-mime-data-2.0.pc
+share/application-registry/mate-vfs.applications
+share/locale/af/LC_MESSAGES/mate-mime-data.mo
+share/locale/am/LC_MESSAGES/mate-mime-data.mo
+share/locale/ar/LC_MESSAGES/mate-mime-data.mo
+share/locale/az/LC_MESSAGES/mate-mime-data.mo
+share/locale/be/LC_MESSAGES/mate-mime-data.mo
+share/locale/bg/LC_MESSAGES/mate-mime-data.mo
+share/locale/bn/LC_MESSAGES/mate-mime-data.mo
+share/locale/bs/LC_MESSAGES/mate-mime-data.mo
+share/locale/ca/LC_MESSAGES/mate-mime-data.mo
+share/locale/cs/LC_MESSAGES/mate-mime-data.mo
+share/locale/cy/LC_MESSAGES/mate-mime-data.mo
+share/locale/da/LC_MESSAGES/mate-mime-data.mo
+share/locale/de/LC_MESSAGES/mate-mime-data.mo
+share/locale/el/LC_MESSAGES/mate-mime-data.mo
+share/locale/en_CA/LC_MESSAGES/mate-mime-data.mo
+share/locale/en_GB/LC_MESSAGES/mate-mime-data.mo
+share/locale/eo/LC_MESSAGES/mate-mime-data.mo
+share/locale/es/LC_MESSAGES/mate-mime-data.mo
+share/locale/et/LC_MESSAGES/mate-mime-data.mo
+share/locale/eu/LC_MESSAGES/mate-mime-data.mo
+share/locale/fa/LC_MESSAGES/mate-mime-data.mo
+share/locale/fi/LC_MESSAGES/mate-mime-data.mo
+share/locale/fr/LC_MESSAGES/mate-mime-data.mo
+share/locale/ga/LC_MESSAGES/mate-mime-data.mo
+share/locale/gl/LC_MESSAGES/mate-mime-data.mo
+share/locale/gu/LC_MESSAGES/mate-mime-data.mo
+share/locale/he/LC_MESSAGES/mate-mime-data.mo
+share/locale/hi/LC_MESSAGES/mate-mime-data.mo
+share/locale/hr/LC_MESSAGES/mate-mime-data.mo
+share/locale/hu/LC_MESSAGES/mate-mime-data.mo
+share/locale/id/LC_MESSAGES/mate-mime-data.mo
+share/locale/is/LC_MESSAGES/mate-mime-data.mo
+share/locale/it/LC_MESSAGES/mate-mime-data.mo
+share/locale/ja/LC_MESSAGES/mate-mime-data.mo
+share/locale/ko/LC_MESSAGES/mate-mime-data.mo
+share/locale/li/LC_MESSAGES/mate-mime-data.mo
+share/locale/lt/LC_MESSAGES/mate-mime-data.mo
+share/locale/lv/LC_MESSAGES/mate-mime-data.mo
+share/locale/mk/LC_MESSAGES/mate-mime-data.mo
+share/locale/ml/LC_MESSAGES/mate-mime-data.mo
+share/locale/mn/LC_MESSAGES/mate-mime-data.mo
+share/locale/ms/LC_MESSAGES/mate-mime-data.mo
+share/locale/nb/LC_MESSAGES/mate-mime-data.mo
+share/locale/ne/LC_MESSAGES/mate-mime-data.mo
+share/locale/nl/LC_MESSAGES/mate-mime-data.mo
+share/locale/nn/LC_MESSAGES/mate-mime-data.mo
+share/locale/nso/LC_MESSAGES/mate-mime-data.mo
+share/locale/pa/LC_MESSAGES/mate-mime-data.mo
+share/locale/pl/LC_MESSAGES/mate-mime-data.mo
+share/locale/pt/LC_MESSAGES/mate-mime-data.mo
+share/locale/pt_BR/LC_MESSAGES/mate-mime-data.mo
+share/locale/ro/LC_MESSAGES/mate-mime-data.mo
+share/locale/ru/LC_MESSAGES/mate-mime-data.mo
+share/locale/rw/LC_MESSAGES/mate-mime-data.mo
+share/locale/sk/LC_MESSAGES/mate-mime-data.mo
+share/locale/sl/LC_MESSAGES/mate-mime-data.mo
+share/locale/sq/LC_MESSAGES/mate-mime-data.mo
+share/locale/sr/LC_MESSAGES/mate-mime-data.mo
+share/locale/sr@Latn/LC_MESSAGES/mate-mime-data.mo
+share/locale/sr@ije/LC_MESSAGES/mate-mime-data.mo
+share/locale/sv/LC_MESSAGES/mate-mime-data.mo
+share/locale/ta/LC_MESSAGES/mate-mime-data.mo
+share/locale/th/LC_MESSAGES/mate-mime-data.mo
+share/locale/tk/LC_MESSAGES/mate-mime-data.mo
+share/locale/tr/LC_MESSAGES/mate-mime-data.mo
+share/locale/uk/LC_MESSAGES/mate-mime-data.mo
+share/locale/vi/LC_MESSAGES/mate-mime-data.mo
+share/locale/wa/LC_MESSAGES/mate-mime-data.mo
+share/locale/xh/LC_MESSAGES/mate-mime-data.mo
+share/locale/yi/LC_MESSAGES/mate-mime-data.mo
+share/locale/zh_CN/LC_MESSAGES/mate-mime-data.mo
+share/locale/zh_TW/LC_MESSAGES/mate-mime-data.mo
+share/locale/zu/LC_MESSAGES/mate-mime-data.mo
+share/mime-info/mate-vfs.keys
+share/mime-info/mate-vfs.mime
+@dirrm share/mime-info
+@dirrmtry share/locale/zu/LC_MESSAGES
+@dirrmtry share/locale/zu
+@dirrmtry share/locale/yi/LC_MESSAGES
+@dirrmtry share/locale/yi
+@dirrmtry share/locale/xh/LC_MESSAGES
+@dirrmtry share/locale/xh
+@dirrmtry share/locale/sr@ije/LC_MESSAGES
+@dirrmtry share/locale/sr@ije
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/nso/LC_MESSAGES
+@dirrmtry share/locale/nso
+@dirrm share/application-registry
diff --git a/textproc/mate-doc-utils/Makefile b/textproc/mate-doc-utils/Makefile
new file mode 100644
index 0000000..81bbf27
--- /dev/null
+++ b/textproc/mate-doc-utils/Makefile
@@ -0,0 +1,47 @@
+# New ports collection makefile for: gnome-doc-utils
+# Date created: 11 November 2004
+# Whom: Adam Weinberger <adamw@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= mate-doc-utils
+PORTVERSION= 1.2.1
+CATEGORIES= textproc mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= MATE doc utils
+
+BUILD_DEPENDS= rarian-sk-config:${PORTSDIR}/textproc/rarian \
+ ${PYTHON_SITELIBDIR}/libxml2mod.so:${PORTSDIR}/textproc/py-libxml2 \
+ gawk:${PORTSDIR}/lang/gawk
+RUN_DEPENDS= rarian-sk-config:${PORTSDIR}/textproc/rarian \
+ ${LOCALBASE}/share/xml/docbook/4.3/catalog.xml:${PORTSDIR}/textproc/docbook-xml-430 \
+ ${LOCALBASE}/share/xml/docbook/4.4/catalog.xml:${PORTSDIR}/textproc/docbook-xml-440
+
+USE_XZ= yes
+USE_MATE= autogen common:build matehack intlhack
+USE_GMAKE= yes
+USE_GNOME= libxml2 libxslt
+USE_PYTHON= build
+USE_GETTEXT= yes
+INSTALLS_OMF= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS=--with-omf-dir=${PREFIX}/share/omf
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib
+
+post-patch:
+ @${REINPLACE_CMD} -e 's|-W compat|--traditional|g' \
+ ${WRKSRC}/configure.in
+
+pre-install:
+ @${REINPLACE_CMD} -e 's|build_SUBDIRS = xml2po|build_SUBDIRS =|g ; \
+ s|po rng xslt|po xslt|g' \
+ ${WRKSRC}/Makefile
+
+.include <bsd.port.mk>
diff --git a/textproc/mate-doc-utils/distinfo b/textproc/mate-doc-utils/distinfo
new file mode 100644
index 0000000..3bb30ad
--- /dev/null
+++ b/textproc/mate-doc-utils/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/mate-doc-utils-1.2.1.tar.xz) = b537901a876db92805e4347590df2fb2ec5c913a69c12b52df5b20108a0beb10
+SIZE (mate/mate-doc-utils-1.2.1.tar.xz) = 349212
diff --git a/textproc/mate-doc-utils/pkg-descr b/textproc/mate-doc-utils/pkg-descr
new file mode 100644
index 0000000..437cee9
--- /dev/null
+++ b/textproc/mate-doc-utils/pkg-descr
@@ -0,0 +1,7 @@
+The MATE Doc Utils is a collection of documentation utilities for the MATE
+project. Notably, it contains utilities for building documentation and all
+auxiliary files in the source tree, and it contains the DocBook XSLT
+stylesheets that were once distributed with Yelp. Yelp requires MATE Doc
+Utils for the XSLT.
+
+WWW: http://mate-desktop.org/
diff --git a/textproc/mate-doc-utils/pkg-plist b/textproc/mate-doc-utils/pkg-plist
new file mode 100644
index 0000000..ae3abb5
--- /dev/null
+++ b/textproc/mate-doc-utils/pkg-plist
@@ -0,0 +1,307 @@
+bin/mate-doc-prepare
+bin/mate-doc-tool
+libdata/pkgconfig/mate-doc-utils.pc
+share/aclocal/mate-doc-utils.m4
+share/locale/ar/LC_MESSAGES/mate-doc-utils.mo
+share/locale/as/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ast/LC_MESSAGES/mate-doc-utils.mo
+share/locale/be@latin/LC_MESSAGES/mate-doc-utils.mo
+share/locale/bg/LC_MESSAGES/mate-doc-utils.mo
+share/locale/bn/LC_MESSAGES/mate-doc-utils.mo
+share/locale/bn_IN/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ca/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ca@valencia/LC_MESSAGES/mate-doc-utils.mo
+share/locale/cs/LC_MESSAGES/mate-doc-utils.mo
+share/locale/cy/LC_MESSAGES/mate-doc-utils.mo
+share/locale/da/LC_MESSAGES/mate-doc-utils.mo
+share/locale/de/LC_MESSAGES/mate-doc-utils.mo
+share/locale/dz/LC_MESSAGES/mate-doc-utils.mo
+share/locale/el/LC_MESSAGES/mate-doc-utils.mo
+share/locale/en@shaw/LC_MESSAGES/mate-doc-utils.mo
+share/locale/en_CA/LC_MESSAGES/mate-doc-utils.mo
+share/locale/en_GB/LC_MESSAGES/mate-doc-utils.mo
+share/locale/es/LC_MESSAGES/mate-doc-utils.mo
+share/locale/et/LC_MESSAGES/mate-doc-utils.mo
+share/locale/eu/LC_MESSAGES/mate-doc-utils.mo
+share/locale/fa/LC_MESSAGES/mate-doc-utils.mo
+share/locale/fi/LC_MESSAGES/mate-doc-utils.mo
+share/locale/fr/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ga/LC_MESSAGES/mate-doc-utils.mo
+share/locale/gl/LC_MESSAGES/mate-doc-utils.mo
+share/locale/gu/LC_MESSAGES/mate-doc-utils.mo
+share/locale/he/LC_MESSAGES/mate-doc-utils.mo
+share/locale/hi/LC_MESSAGES/mate-doc-utils.mo
+share/locale/hu/LC_MESSAGES/mate-doc-utils.mo
+share/locale/id/LC_MESSAGES/mate-doc-utils.mo
+share/locale/it/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ja/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ka/LC_MESSAGES/mate-doc-utils.mo
+share/locale/kn/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ko/LC_MESSAGES/mate-doc-utils.mo
+share/locale/lt/LC_MESSAGES/mate-doc-utils.mo
+share/locale/lv/LC_MESSAGES/mate-doc-utils.mo
+share/locale/mai/LC_MESSAGES/mate-doc-utils.mo
+share/locale/mg/LC_MESSAGES/mate-doc-utils.mo
+share/locale/mk/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ml/LC_MESSAGES/mate-doc-utils.mo
+share/locale/mn/LC_MESSAGES/mate-doc-utils.mo
+share/locale/mr/LC_MESSAGES/mate-doc-utils.mo
+share/locale/nb/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ne/LC_MESSAGES/mate-doc-utils.mo
+share/locale/nl/LC_MESSAGES/mate-doc-utils.mo
+share/locale/nn/LC_MESSAGES/mate-doc-utils.mo
+share/locale/oc/LC_MESSAGES/mate-doc-utils.mo
+share/locale/or/LC_MESSAGES/mate-doc-utils.mo
+share/locale/pa/LC_MESSAGES/mate-doc-utils.mo
+share/locale/pl/LC_MESSAGES/mate-doc-utils.mo
+share/locale/pt/LC_MESSAGES/mate-doc-utils.mo
+share/locale/pt_BR/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ro/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ru/LC_MESSAGES/mate-doc-utils.mo
+share/locale/rw/LC_MESSAGES/mate-doc-utils.mo
+share/locale/sk/LC_MESSAGES/mate-doc-utils.mo
+share/locale/sl/LC_MESSAGES/mate-doc-utils.mo
+share/locale/sq/LC_MESSAGES/mate-doc-utils.mo
+share/locale/sr/LC_MESSAGES/mate-doc-utils.mo
+share/locale/sr@latin/LC_MESSAGES/mate-doc-utils.mo
+share/locale/sv/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ta/LC_MESSAGES/mate-doc-utils.mo
+share/locale/te/LC_MESSAGES/mate-doc-utils.mo
+share/locale/th/LC_MESSAGES/mate-doc-utils.mo
+share/locale/tr/LC_MESSAGES/mate-doc-utils.mo
+share/locale/ug/LC_MESSAGES/mate-doc-utils.mo
+share/locale/uk/LC_MESSAGES/mate-doc-utils.mo
+share/locale/vi/LC_MESSAGES/mate-doc-utils.mo
+share/locale/wa/LC_MESSAGES/mate-doc-utils.mo
+share/locale/zh_CN/LC_MESSAGES/mate-doc-utils.mo
+share/locale/zh_HK/LC_MESSAGES/mate-doc-utils.mo
+share/locale/zh_TW/LC_MESSAGES/mate-doc-utils.mo
+%%DATADIR%%/icons/hicolor/48x48/status/admon-bug.png
+%%DATADIR%%/icons/hicolor/48x48/status/admon-caution.png
+%%DATADIR%%/icons/hicolor/48x48/status/admon-important.png
+%%DATADIR%%/icons/hicolor/48x48/status/admon-note.png
+%%DATADIR%%/icons/hicolor/48x48/status/admon-tip.png
+%%DATADIR%%/icons/hicolor/48x48/status/admon-warning.png
+%%DATADIR%%/icons/hicolor/scalable/status/admon-bug.svg
+%%DATADIR%%/icons/hicolor/scalable/status/admon-caution.svg
+%%DATADIR%%/icons/hicolor/scalable/status/admon-important.svg
+%%DATADIR%%/icons/hicolor/scalable/status/admon-note.svg
+%%DATADIR%%/icons/hicolor/scalable/status/admon-tip.svg
+%%DATADIR%%/icons/hicolor/scalable/status/admon-warning.svg
+%%DATADIR%%/mate-debian.sh
+%%DATADIR%%/mate-doc-utils.make
+%%DATADIR%%/template-document.xml
+%%DATADIR%%/template.make
+%%DATADIR%%/template.omf.in
+%%DATADIR%%/templates/legal.xml
+%%DATADIR%%/templates/mate-app-template.xml
+%%DATADIR%%/templates/mate-applet-template.xml
+%%DATADIR%%/watermarks/watermark-blockquote-00AB.png
+%%DATADIR%%/watermarks/watermark-blockquote-00BB.png
+%%DATADIR%%/watermarks/watermark-blockquote-201C.png
+%%DATADIR%%/watermarks/watermark-blockquote-201D.png
+%%DATADIR%%/watermarks/watermark-blockquote-201E.png
+%%DATADIR%%/watermarks/watermark-code-python.png
+%%DATADIR%%/watermarks/watermark-code.png
+share/mate/help/mate-doc-make/C/legal.xml
+share/mate/help/mate-doc-make/C/make-ref.xml
+share/mate/help/mate-doc-make/C/mate-doc-make.xml
+share/mate/help/mate-doc-make/de/legal.xml
+share/mate/help/mate-doc-make/de/make-ref.xml
+share/mate/help/mate-doc-make/de/mate-doc-make.xml
+share/mate/help/mate-doc-xslt/C/db-chunk.xml
+share/mate/help/mate-doc-xslt/C/db-common.xml
+share/mate/help/mate-doc-xslt/C/db-label.xml
+share/mate/help/mate-doc-xslt/C/db-title.xml
+share/mate/help/mate-doc-xslt/C/db-xref.xml
+share/mate/help/mate-doc-xslt/C/db2html-autotoc.xml
+share/mate/help/mate-doc-xslt/C/db2html-bibliography.xml
+share/mate/help/mate-doc-xslt/C/db2html-block.xml
+share/mate/help/mate-doc-xslt/C/db2html-callout.xml
+share/mate/help/mate-doc-xslt/C/db2html-classsynopsis.xml
+share/mate/help/mate-doc-xslt/C/db2html-cmdsynopsis.xml
+share/mate/help/mate-doc-xslt/C/db2html-css.xml
+share/mate/help/mate-doc-xslt/C/db2html-division.xml
+share/mate/help/mate-doc-xslt/C/db2html-ebnf.xml
+share/mate/help/mate-doc-xslt/C/db2html-footnote.xml
+share/mate/help/mate-doc-xslt/C/db2html-funcsynopsis.xml
+share/mate/help/mate-doc-xslt/C/db2html-index.xml
+share/mate/help/mate-doc-xslt/C/db2html-info.xml
+share/mate/help/mate-doc-xslt/C/db2html-inline.xml
+share/mate/help/mate-doc-xslt/C/db2html-l10n.xml
+share/mate/help/mate-doc-xslt/C/db2html-list.xml
+share/mate/help/mate-doc-xslt/C/db2html-media.xml
+share/mate/help/mate-doc-xslt/C/db2html-qanda.xml
+share/mate/help/mate-doc-xslt/C/db2html-refentry.xml
+share/mate/help/mate-doc-xslt/C/db2html-table.xml
+share/mate/help/mate-doc-xslt/C/db2html-title.xml
+share/mate/help/mate-doc-xslt/C/db2html-xref.xml
+share/mate/help/mate-doc-xslt/C/db2html.xml
+share/mate/help/mate-doc-xslt/C/db2omf.xml
+share/mate/help/mate-doc-xslt/C/db2xhtml.xml
+share/mate/help/mate-doc-xslt/C/gettext.xml
+share/mate/help/mate-doc-xslt/C/l10n-numbers.xml
+share/mate/help/mate-doc-xslt/C/legal.xml
+share/mate/help/mate-doc-xslt/C/mate-doc-xslt.xml
+share/mate/help/mate-doc-xslt/C/theme.xml
+share/mate/help/mate-doc-xslt/C/translating.xml
+share/mate/help/mate-doc-xslt/C/utils.xml
+share/mate/help/mate-doc-xslt/de/db-chunk.xml
+share/mate/help/mate-doc-xslt/de/db-common.xml
+share/mate/help/mate-doc-xslt/de/db-label.xml
+share/mate/help/mate-doc-xslt/de/db-title.xml
+share/mate/help/mate-doc-xslt/de/db-xref.xml
+share/mate/help/mate-doc-xslt/de/db2html-autotoc.xml
+share/mate/help/mate-doc-xslt/de/db2html-bibliography.xml
+share/mate/help/mate-doc-xslt/de/db2html-block.xml
+share/mate/help/mate-doc-xslt/de/db2html-callout.xml
+share/mate/help/mate-doc-xslt/de/db2html-classsynopsis.xml
+share/mate/help/mate-doc-xslt/de/db2html-cmdsynopsis.xml
+share/mate/help/mate-doc-xslt/de/db2html-css.xml
+share/mate/help/mate-doc-xslt/de/db2html-division.xml
+share/mate/help/mate-doc-xslt/de/db2html-ebnf.xml
+share/mate/help/mate-doc-xslt/de/db2html-footnote.xml
+share/mate/help/mate-doc-xslt/de/db2html-funcsynopsis.xml
+share/mate/help/mate-doc-xslt/de/db2html-index.xml
+share/mate/help/mate-doc-xslt/de/db2html-info.xml
+share/mate/help/mate-doc-xslt/de/db2html-inline.xml
+share/mate/help/mate-doc-xslt/de/db2html-l10n.xml
+share/mate/help/mate-doc-xslt/de/db2html-list.xml
+share/mate/help/mate-doc-xslt/de/db2html-media.xml
+share/mate/help/mate-doc-xslt/de/db2html-qanda.xml
+share/mate/help/mate-doc-xslt/de/db2html-refentry.xml
+share/mate/help/mate-doc-xslt/de/db2html-table.xml
+share/mate/help/mate-doc-xslt/de/db2html-title.xml
+share/mate/help/mate-doc-xslt/de/db2html-xref.xml
+share/mate/help/mate-doc-xslt/de/db2html.xml
+share/mate/help/mate-doc-xslt/de/db2omf.xml
+share/mate/help/mate-doc-xslt/de/db2xhtml.xml
+share/mate/help/mate-doc-xslt/de/gettext.xml
+share/mate/help/mate-doc-xslt/de/l10n-numbers.xml
+share/mate/help/mate-doc-xslt/de/legal.xml
+share/mate/help/mate-doc-xslt/de/mate-doc-xslt.xml
+share/mate/help/mate-doc-xslt/de/theme.xml
+share/mate/help/mate-doc-xslt/de/translating.xml
+share/mate/help/mate-doc-xslt/de/utils.xml
+share/omf/mate-doc-make/mate-doc-make-C.omf
+share/omf/mate-doc-make/mate-doc-make-de.omf
+share/omf/mate-doc-xslt/mate-doc-xslt-C.omf
+share/omf/mate-doc-xslt/mate-doc-xslt-de.omf
+share/xml/mate/xslt/common/theme.xsl
+share/xml/mate/xslt/common/utils.xsl
+share/xml/mate/xslt/docbook/common/db-chunk.xsl
+share/xml/mate/xslt/docbook/common/db-common.xsl
+share/xml/mate/xslt/docbook/common/db-label.xsl
+share/xml/mate/xslt/docbook/common/db-title.xsl
+share/xml/mate/xslt/docbook/common/db-xref.xsl
+share/xml/mate/xslt/docbook/html/db2html-autotoc.xsl
+share/xml/mate/xslt/docbook/html/db2html-bibliography.xsl
+share/xml/mate/xslt/docbook/html/db2html-block.xsl
+share/xml/mate/xslt/docbook/html/db2html-callout.xsl
+share/xml/mate/xslt/docbook/html/db2html-classsynopsis.xsl
+share/xml/mate/xslt/docbook/html/db2html-cmdsynopsis.xsl
+share/xml/mate/xslt/docbook/html/db2html-css.xsl
+share/xml/mate/xslt/docbook/html/db2html-division.xsl
+share/xml/mate/xslt/docbook/html/db2html-ebnf.xsl
+share/xml/mate/xslt/docbook/html/db2html-footnote.xsl
+share/xml/mate/xslt/docbook/html/db2html-funcsynopsis.xsl
+share/xml/mate/xslt/docbook/html/db2html-index.xsl
+share/xml/mate/xslt/docbook/html/db2html-info.xsl
+share/xml/mate/xslt/docbook/html/db2html-inline.xsl
+share/xml/mate/xslt/docbook/html/db2html-l10n.xsl
+share/xml/mate/xslt/docbook/html/db2html-list.xsl
+share/xml/mate/xslt/docbook/html/db2html-media.xsl
+share/xml/mate/xslt/docbook/html/db2html-qanda.xsl
+share/xml/mate/xslt/docbook/html/db2html-refentry.xsl
+share/xml/mate/xslt/docbook/html/db2html-suppressed.xsl
+share/xml/mate/xslt/docbook/html/db2html-table.xsl
+share/xml/mate/xslt/docbook/html/db2html-title.xsl
+share/xml/mate/xslt/docbook/html/db2html-xref.xsl
+share/xml/mate/xslt/docbook/html/db2html.xsl
+share/xml/mate/xslt/docbook/html/db2xhtml.xsl
+share/xml/mate/xslt/docbook/omf/db2omf.xsl
+share/xml/mate/xslt/docbook/utils/chunks.xsl
+share/xml/mate/xslt/docbook/utils/credits.xsl
+share/xml/mate/xslt/docbook/utils/figures.xsl
+share/xml/mate/xslt/docbook/utils/graphics.xsl
+share/xml/mate/xslt/docbook/utils/ids.xsl
+share/xml/mate/xslt/gettext/gettext.xsl
+share/xml/mate/xslt/gettext/l10n-numbers.xsl
+share/xml/mate/xslt/gettext/l10n.xml
+share/xml/mate/xslt/mallard/cache/mal-cache.xsl
+share/xml/mate/xslt/mallard/common/mal-chunk.xsl
+share/xml/mate/xslt/mallard/common/mal-link.xsl
+share/xml/mate/xslt/mallard/html/mal2html-block.xsl
+share/xml/mate/xslt/mallard/html/mal2html-css.xsl
+share/xml/mate/xslt/mallard/html/mal2html-inline.xsl
+share/xml/mate/xslt/mallard/html/mal2html-list.xsl
+share/xml/mate/xslt/mallard/html/mal2html-media.xsl
+share/xml/mate/xslt/mallard/html/mal2html-page.xsl
+share/xml/mate/xslt/mallard/html/mal2html-table.xsl
+share/xml/mate/xslt/mallard/html/mal2html.xsl
+share/xml/mate/xslt/mallard/html/mal2xhtml.xsl
+@dirrm share/xml/mate/xslt/mallard/html
+@dirrm share/xml/mate/xslt/mallard/common
+@dirrm share/xml/mate/xslt/mallard/cache
+@dirrm share/xml/mate/xslt/mallard
+@dirrm share/xml/mate/xslt/gettext
+@dirrm share/xml/mate/xslt/docbook/utils
+@dirrm share/xml/mate/xslt/docbook/omf
+@dirrm share/xml/mate/xslt/docbook/html
+@dirrm share/xml/mate/xslt/docbook/common
+@dirrm share/xml/mate/xslt/docbook
+@dirrm share/xml/mate/xslt/common
+@dirrm share/xml/mate/xslt
+@dirrm share/xml/mate
+@dirrm share/omf/mate-doc-xslt
+@dirrm share/omf/mate-doc-make
+@dirrm share/omf
+@dirrm share/mate/help/mate-doc-xslt/de
+@dirrm share/mate/help/mate-doc-xslt/C
+@dirrm share/mate/help/mate-doc-xslt
+@dirrm share/mate/help/mate-doc-make/de
+@dirrm share/mate/help/mate-doc-make/C
+@dirrm share/mate/help/mate-doc-make
+@dirrm share/mate/help
+@dirrm %%DATADIR%%/watermarks
+@dirrm %%DATADIR%%/templates
+@dirrm %%DATADIR%%/icons/hicolor/scalable/status
+@dirrm %%DATADIR%%/icons/hicolor/scalable
+@dirrm %%DATADIR%%/icons/hicolor/48x48/status
+@dirrm %%DATADIR%%/icons/hicolor/48x48
+@dirrm %%DATADIR%%/icons/hicolor
+@dirrm %%DATADIR%%/icons
+@dirrm %%DATADIR%%
+@dirrm share/mate
+@dirrmtry share/locale/zh_HK/LC_MESSAGES
+@dirrmtry share/locale/zh_HK
+@dirrmtry share/locale/ug/LC_MESSAGES
+@dirrmtry share/locale/ug
+@dirrmtry share/locale/te/LC_MESSAGES
+@dirrmtry share/locale/te
+@dirrmtry share/locale/sr@latin/LC_MESSAGES
+@dirrmtry share/locale/sr@latin
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/oc/LC_MESSAGES
+@dirrmtry share/locale/oc
+@dirrmtry share/locale/mr/LC_MESSAGES
+@dirrmtry share/locale/mr
+@dirrmtry share/locale/mg/LC_MESSAGES
+@dirrmtry share/locale/mg
+@dirrmtry share/locale/mai/LC_MESSAGES
+@dirrmtry share/locale/mai
+@dirrmtry share/locale/en@shaw/LC_MESSAGES
+@dirrmtry share/locale/en@shaw
+@dirrmtry share/locale/dz/LC_MESSAGES
+@dirrmtry share/locale/dz
+@dirrmtry share/locale/ca@valencia/LC_MESSAGES
+@dirrmtry share/locale/ca@valencia
+@dirrmtry share/locale/bn_IN/LC_MESSAGES
+@dirrmtry share/locale/bn_IN
+@dirrmtry share/locale/be@latin/LC_MESSAGES
+@dirrmtry share/locale/be@latin
+@dirrmtry share/locale/ast/LC_MESSAGES
+@dirrmtry share/locale/ast
+@dirrmtry share/locale/as/LC_MESSAGES
+@dirrmtry share/locale/as
diff --git a/x11-toolkits/libmatecomponentui/Makefile b/x11-toolkits/libmatecomponentui/Makefile
new file mode 100644
index 0000000..299184c
--- /dev/null
+++ b/x11-toolkits/libmatecomponentui/Makefile
@@ -0,0 +1,35 @@
+# New ports collection makefile for: libbonoboui
+# Date created: 04 April 2002
+# Whom: Joe Marcus Clarke <marcus@FreeBSD.org>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= libmatecomponentui
+PORTVERSION= 1.2.0
+CATEGORIES= x11-toolkits mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= GUI frontend to the libbonobo component of MATE
+
+BUILD_DEPENDS= gtkdoc-check:${PORTSDIR}/textproc/gtk-doc
+LIB_DEPENDS= popt.0:${PORTSDIR}/devel/popt
+
+USE_XZ= yes
+USE_MATE= autogen canvas common:build component conf intlhack lib \
+ ltverhack matehack
+USE_GMAKE= yes
+USE_GNOME= glib20 gtk20 libglade2 libxml2
+USE_GETTEXT= yes
+USE_LDCONFIG= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env libtool libtoolize:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --disable-gtk-doc \
+ --with-html-dir=${PREFIX}/share/doc
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib ${PTHREAD_LIBS}
+
+.include <bsd.port.mk>
diff --git a/x11-toolkits/libmatecomponentui/distinfo b/x11-toolkits/libmatecomponentui/distinfo
new file mode 100644
index 0000000..23b782a
--- /dev/null
+++ b/x11-toolkits/libmatecomponentui/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/libmatecomponentui-1.2.0.tar.xz) = 55dff6c6dd8e173d24336c29a3ab30b23c8432dc96d69942126ab1c63a8ce56c
+SIZE (mate/libmatecomponentui-1.2.0.tar.xz) = 534528
diff --git a/x11-toolkits/libmatecomponentui/files/patch-bonobo_bonobo-ui-util.c b/x11-toolkits/libmatecomponentui/files/patch-bonobo_bonobo-ui-util.c
new file mode 100644
index 0000000..acc0f89
--- /dev/null
+++ b/x11-toolkits/libmatecomponentui/files/patch-bonobo_bonobo-ui-util.c
@@ -0,0 +1,21 @@
+--- matecomponent/matecomponent-ui-util.c.orig Fri Feb 28 10:40:12 2003
++++ matecomponent/matecomponent-ui-util.c Wed Apr 16 10:13:23 2003
+@@ -558,14 +558,11 @@
+ else
+ prefix = NULL;
+
+- if (prefix)
++ datadir = NULL;
++ g_object_get (G_OBJECT (mate_program_get ()),
++ MATE_PARAM_APP_DATADIR, &datadir, NULL);
++ if (!datadir && prefix)
+ datadir = g_strdup_printf ("%s/share", prefix);
+-
+- else {
+- datadir = NULL;
+- g_object_get (G_OBJECT (mate_program_get ()),
+- MATE_PARAM_APP_DATADIR, &datadir, NULL);
+- }
+
+ if (!datadir) /* desparate fallback */
+ datadir = g_strdup (MATECOMPONENT_DATADIR);
diff --git a/x11-toolkits/libmatecomponentui/pkg-descr b/x11-toolkits/libmatecomponentui/pkg-descr
new file mode 100644
index 0000000..e5661cc
--- /dev/null
+++ b/x11-toolkits/libmatecomponentui/pkg-descr
@@ -0,0 +1,7 @@
+MateComponent is a set of language- and system-independant CORBA
+interfaces for creating reusable components and compound documents.
+
+libmatecomponentui includes a Gtk+-based implementation of the MateComponent
+interfaces.
+
+WWW: http://mate-desktop.org/
diff --git a/x11-toolkits/libmatecomponentui/pkg-plist b/x11-toolkits/libmatecomponentui/pkg-plist
new file mode 100644
index 0000000..58fa3de
--- /dev/null
+++ b/x11-toolkits/libmatecomponentui/pkg-plist
@@ -0,0 +1,234 @@
+bin/mate-test-moniker
+bin/matecomponent-browser
+include/libmatecomponentui-2.0/libmatecomponentui.h
+include/libmatecomponentui-2.0/matecomponent.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-canvas-component.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-canvas-item.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-control-frame.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-control.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-dock-band.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-dock-item.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-dock-layout.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-dock.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-file-selector-util.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-plug.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-property-control.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-selector-widget.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-selector.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-socket.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-component.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-config-widget.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-container.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-engine.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-main.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-node.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-sync.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-toolbar-button-item.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-toolbar-item.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-toolbar-toggle-button-item.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-toolbar.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-type-builtins.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-ui-util.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-widget.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-window.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-zoomable-frame.h
+include/libmatecomponentui-2.0/matecomponent/matecomponent-zoomable.h
+lib/libglade/2.0/libmatecomponent.a
+lib/libglade/2.0/libmatecomponent.la
+lib/libglade/2.0/libmatecomponent.so
+lib/libmatecomponentui-2.a
+lib/libmatecomponentui-2.la
+lib/libmatecomponentui-2.so
+lib/libmatecomponentui-2.so.0
+lib/matecomponent-2.0/samples/matecomponent-sample-controls-2
+libdata/matecomponent/servers/CanvDemo.server
+libdata/matecomponent/servers/MateComponent_Sample_Controls.server
+libdata/pkgconfig/libmatecomponentui-2.0.pc
+share/applications/matecomponent-browser.desktop
+%%DOCSDIR%%/ch01.html
+%%DOCSDIR%%/control-frame.png
+%%DOCSDIR%%/control.png
+%%DOCSDIR%%/home.png
+%%DOCSDIR%%/index.html
+%%DOCSDIR%%/index.sgml
+%%DOCSDIR%%/ix01.html
+%%DOCSDIR%%/left.png
+%%DOCSDIR%%/libmatecomponentui-faq.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-a11y.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-control-frame.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-control.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-file-selector-util.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-plug.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-property-control.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-selector-widget.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-selector.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-socket.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-component.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-container.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-engine-config.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-engine.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-node.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-preferences.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-sync.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-ui-util.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-widget.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-window.html
+%%DOCSDIR%%/libmatecomponentui-matecomponent-wrapper.html
+%%DOCSDIR%%/libmatecomponentui.devhelp
+%%DOCSDIR%%/libmatecomponentui.devhelp2
+%%DOCSDIR%%/matecomponent-controls.html
+%%DOCSDIR%%/matecomponent-support-utilities.html
+%%DOCSDIR%%/matecomponent-ui.html
+%%DOCSDIR%%/right.png
+%%DOCSDIR%%/style.css
+%%DOCSDIR%%/up.png
+share/locale/af/LC_MESSAGES/libmatecomponentui.mo
+share/locale/am/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ar/LC_MESSAGES/libmatecomponentui.mo
+share/locale/as/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ast/LC_MESSAGES/libmatecomponentui.mo
+share/locale/az/LC_MESSAGES/libmatecomponentui.mo
+share/locale/be/LC_MESSAGES/libmatecomponentui.mo
+share/locale/bg/LC_MESSAGES/libmatecomponentui.mo
+share/locale/bn/LC_MESSAGES/libmatecomponentui.mo
+share/locale/bn_IN/LC_MESSAGES/libmatecomponentui.mo
+share/locale/br/LC_MESSAGES/libmatecomponentui.mo
+share/locale/bs/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ca/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ca@valencia/LC_MESSAGES/libmatecomponentui.mo
+share/locale/cs/LC_MESSAGES/libmatecomponentui.mo
+share/locale/cy/LC_MESSAGES/libmatecomponentui.mo
+share/locale/da/LC_MESSAGES/libmatecomponentui.mo
+share/locale/de/LC_MESSAGES/libmatecomponentui.mo
+share/locale/dz/LC_MESSAGES/libmatecomponentui.mo
+share/locale/el/LC_MESSAGES/libmatecomponentui.mo
+share/locale/en@shaw/LC_MESSAGES/libmatecomponentui.mo
+share/locale/en_CA/LC_MESSAGES/libmatecomponentui.mo
+share/locale/en_GB/LC_MESSAGES/libmatecomponentui.mo
+share/locale/eo/LC_MESSAGES/libmatecomponentui.mo
+share/locale/es/LC_MESSAGES/libmatecomponentui.mo
+share/locale/et/LC_MESSAGES/libmatecomponentui.mo
+share/locale/eu/LC_MESSAGES/libmatecomponentui.mo
+share/locale/fa/LC_MESSAGES/libmatecomponentui.mo
+share/locale/fi/LC_MESSAGES/libmatecomponentui.mo
+share/locale/fr/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ga/LC_MESSAGES/libmatecomponentui.mo
+share/locale/gl/LC_MESSAGES/libmatecomponentui.mo
+share/locale/gu/LC_MESSAGES/libmatecomponentui.mo
+share/locale/he/LC_MESSAGES/libmatecomponentui.mo
+share/locale/hi/LC_MESSAGES/libmatecomponentui.mo
+share/locale/hr/LC_MESSAGES/libmatecomponentui.mo
+share/locale/hu/LC_MESSAGES/libmatecomponentui.mo
+share/locale/id/LC_MESSAGES/libmatecomponentui.mo
+share/locale/is/LC_MESSAGES/libmatecomponentui.mo
+share/locale/it/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ja/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ka/LC_MESSAGES/libmatecomponentui.mo
+share/locale/kn/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ko/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ku/LC_MESSAGES/libmatecomponentui.mo
+share/locale/li/LC_MESSAGES/libmatecomponentui.mo
+share/locale/lt/LC_MESSAGES/libmatecomponentui.mo
+share/locale/lv/LC_MESSAGES/libmatecomponentui.mo
+share/locale/mai/LC_MESSAGES/libmatecomponentui.mo
+share/locale/mg/LC_MESSAGES/libmatecomponentui.mo
+share/locale/mk/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ml/LC_MESSAGES/libmatecomponentui.mo
+share/locale/mn/LC_MESSAGES/libmatecomponentui.mo
+share/locale/mr/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ms/LC_MESSAGES/libmatecomponentui.mo
+share/locale/nb/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ne/LC_MESSAGES/libmatecomponentui.mo
+share/locale/nl/LC_MESSAGES/libmatecomponentui.mo
+share/locale/nn/LC_MESSAGES/libmatecomponentui.mo
+share/locale/nso/LC_MESSAGES/libmatecomponentui.mo
+share/locale/oc/LC_MESSAGES/libmatecomponentui.mo
+share/locale/or/LC_MESSAGES/libmatecomponentui.mo
+share/locale/pa/LC_MESSAGES/libmatecomponentui.mo
+share/locale/pl/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ps/LC_MESSAGES/libmatecomponentui.mo
+share/locale/pt/LC_MESSAGES/libmatecomponentui.mo
+share/locale/pt_BR/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ro/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ru/LC_MESSAGES/libmatecomponentui.mo
+share/locale/rw/LC_MESSAGES/libmatecomponentui.mo
+share/locale/si/LC_MESSAGES/libmatecomponentui.mo
+share/locale/sk/LC_MESSAGES/libmatecomponentui.mo
+share/locale/sl/LC_MESSAGES/libmatecomponentui.mo
+share/locale/sq/LC_MESSAGES/libmatecomponentui.mo
+share/locale/sr/LC_MESSAGES/libmatecomponentui.mo
+share/locale/sr@ije/LC_MESSAGES/libmatecomponentui.mo
+share/locale/sr@latin/LC_MESSAGES/libmatecomponentui.mo
+share/locale/sv/LC_MESSAGES/libmatecomponentui.mo
+share/locale/ta/LC_MESSAGES/libmatecomponentui.mo
+share/locale/te/LC_MESSAGES/libmatecomponentui.mo
+share/locale/th/LC_MESSAGES/libmatecomponentui.mo
+share/locale/tr/LC_MESSAGES/libmatecomponentui.mo
+share/locale/uk/LC_MESSAGES/libmatecomponentui.mo
+share/locale/vi/LC_MESSAGES/libmatecomponentui.mo
+share/locale/wa/LC_MESSAGES/libmatecomponentui.mo
+share/locale/xh/LC_MESSAGES/libmatecomponentui.mo
+share/locale/yi/LC_MESSAGES/libmatecomponentui.mo
+share/locale/zh_CN/LC_MESSAGES/libmatecomponentui.mo
+share/locale/zh_HK/LC_MESSAGES/libmatecomponentui.mo
+share/locale/zh_TW/LC_MESSAGES/libmatecomponentui.mo
+share/locale/zu/LC_MESSAGES/libmatecomponentui.mo
+share/mate-2.0/ui/MateComponent_Sample_Container-ui.xml
+share/mate-2.0/ui/MateComponent_Sample_Hello.xml
+share/mate-2.0/ui/matecomponent-browser.xml
+@dirrm share/mate-2.0/ui
+@dirrm share/mate-2.0
+@dirrmtry share/locale/zu/LC_MESSAGES
+@dirrmtry share/locale/zu
+@dirrmtry share/locale/zh_HK/LC_MESSAGES
+@dirrmtry share/locale/zh_HK
+@dirrmtry share/locale/yi/LC_MESSAGES
+@dirrmtry share/locale/yi
+@dirrmtry share/locale/xh/LC_MESSAGES
+@dirrmtry share/locale/xh
+@dirrmtry share/locale/te/LC_MESSAGES
+@dirrmtry share/locale/te
+@dirrmtry share/locale/sr@latin/LC_MESSAGES
+@dirrmtry share/locale/sr@latin
+@dirrmtry share/locale/sr@ije/LC_MESSAGES
+@dirrmtry share/locale/sr@ije
+@dirrmtry share/locale/si/LC_MESSAGES
+@dirrmtry share/locale/si
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/ps/LC_MESSAGES
+@dirrmtry share/locale/ps
+@dirrmtry share/locale/oc/LC_MESSAGES
+@dirrmtry share/locale/oc
+@dirrmtry share/locale/nso/LC_MESSAGES
+@dirrmtry share/locale/nso
+@dirrmtry share/locale/mr/LC_MESSAGES
+@dirrmtry share/locale/mr
+@dirrmtry share/locale/mg/LC_MESSAGES
+@dirrmtry share/locale/mg
+@dirrmtry share/locale/mai/LC_MESSAGES
+@dirrmtry share/locale/mai
+@dirrmtry share/locale/ku/LC_MESSAGES
+@dirrmtry share/locale/ku
+@dirrmtry share/locale/en@shaw/LC_MESSAGES
+@dirrmtry share/locale/en@shaw
+@dirrmtry share/locale/dz/LC_MESSAGES
+@dirrmtry share/locale/dz
+@dirrmtry share/locale/ca@valencia/LC_MESSAGES
+@dirrmtry share/locale/ca@valencia
+@dirrmtry share/locale/bn_IN/LC_MESSAGES
+@dirrmtry share/locale/bn_IN
+@dirrmtry share/locale/ast/LC_MESSAGES
+@dirrmtry share/locale/ast
+@dirrmtry share/locale/as/LC_MESSAGES
+@dirrmtry share/locale/as
+@dirrm %%DOCSDIR%%
+@dirrmtry share/applications
+@dirrm libdata/matecomponent/servers
+@dirrm libdata/matecomponent
+@dirrm lib/matecomponent-2.0/samples
+@dirrm lib/matecomponent-2.0
+@dirrm lib/libglade/2.0
+@dirrm lib/libglade
+@dirrm include/libmatecomponentui-2.0/matecomponent
+@dirrm include/libmatecomponentui-2.0
diff --git a/x11/libmate/Makefile b/x11/libmate/Makefile
new file mode 100644
index 0000000..4d73d67
--- /dev/null
+++ b/x11/libmate/Makefile
@@ -0,0 +1,66 @@
+# New ports collection makefile for: libgnome
+# Date created: 17 June 1998
+# Whom: Yukihiro Nakai <Nakai@technologist.com>
+#
+# $FreeBSD$
+# $MCom$
+#
+
+PORTNAME= libmate
+PORTVERSION= 1.2.0
+CATEGORIES= x11 mate
+MASTER_SITES= MATE
+DIST_SUBDIR= mate
+
+MAINTAINER= gnome@FreeBSD.org
+COMMENT= Libraries for MATE, a GNU desktop environment
+
+BUILD_DEPENDS= gtkdoc-check:${PORTSDIR}/textproc/gtk-doc
+LIB_DEPENDS= canberra-gtk.0:${PORTSDIR}/audio/libcanberra
+
+USE_XZ= yes
+USE_MATE= autogen common:build component conf intlhack ltverhack \
+ matehack vfs
+USE_XORG= xpm
+USE_BISON= build
+USE_GMAKE= yes
+USE_GNOME= glib20
+USE_GETTEXT= yes
+USE_LDCONFIG= yes
+USE_AUTOTOOLS= aclocal:env autoconf:env automake:env libtool libtoolize:env
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= ${MATECONF_PREFIX} \
+ --disable-gtk-doc \
+ --with-html-dir=${PREFIX}/share/doc
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib
+
+SUB_FILES= pkg-deinstall
+
+MAN7= mate-options.7
+
+MATECONF_SCHEMAS=desktop_mate_accessibility_keyboard.schemas \
+ desktop_mate_accessibility_startup.schemas \
+ desktop_mate_applications_at_mobility.schemas \
+ desktop_mate_applications_at_visual.schemas \
+ desktop_mate_applications_browser.schemas \
+ desktop_mate_applications_office.schemas \
+ desktop_mate_applications_terminal.schemas \
+ desktop_mate_applications_window_manager.schemas \
+ desktop_mate_background.schemas \
+ desktop_mate_file_views.schemas \
+ desktop_mate_interface.schemas \
+ desktop_mate_lockdown.schemas \
+ desktop_mate_peripherals_keyboard.schemas \
+ desktop_mate_peripherals_mouse.schemas \
+ desktop_mate_sound.schemas \
+ desktop_mate_thumbnail_cache.schemas \
+ desktop_mate_thumbnailers.schemas \
+ desktop_mate_typing_break.schemas
+
+post-patch:
+ @${REINPLACE_CMD} -e 's|%%LOCALBASE%%|${LOCALBASE}|' \
+ ${WRKSRC}/libmate/libmate-2.0.pc.in
+ @${REINPLACE_CMD} -e '/^$$/d' ${WRKSRC}/po/POTFILES.in
+
+.include <bsd.port.mk>
diff --git a/x11/libmate/distinfo b/x11/libmate/distinfo
new file mode 100644
index 0000000..dfcb640
--- /dev/null
+++ b/x11/libmate/distinfo
@@ -0,0 +1,2 @@
+SHA256 (mate/libmate-1.2.0.tar.xz) = 729971d0d998f4705ae2ca276f1d16d1580ced9f75a17ddf3de3f6f330e2f298
+SIZE (mate/libmate-1.2.0.tar.xz) = 626952
diff --git a/x11/libmate/files/patch-libmate_Makefile.am b/x11/libmate/files/patch-libmate_Makefile.am
new file mode 100644
index 0000000..b4cd8b6
--- /dev/null
+++ b/x11/libmate/files/patch-libmate_Makefile.am
@@ -0,0 +1,11 @@
+--- libmate/Makefile.am.orig 2012-07-05 15:54:30.000000000 -0500
++++ libmate/Makefile.am 2012-07-05 15:55:15.000000000 -0500
+@@ -13,6 +13,8 @@
+ libmateincludedir = $(includedir)/libmate-2.0/libmate
+
+ INCLUDES = \
++ -DPREFIX=\""$(PREFIX)"\" \
++ -DLOCALBASE=\""$(LOCALBASE)"\" \
+ -I.. \
+ -I$(srcdir)/.. \
+ $(WARN_CFLAGS) \
diff --git a/x11/libmate/files/patch-libmate_libmate-2.0.pc.in b/x11/libmate/files/patch-libmate_libmate-2.0.pc.in
new file mode 100644
index 0000000..c839ef0
--- /dev/null
+++ b/x11/libmate/files/patch-libmate_libmate-2.0.pc.in
@@ -0,0 +1,9 @@
+--- libmate/libmate-2.0.pc.in.orig 2012-07-05 15:51:55.000000000 -0500
++++ libmate/libmate-2.0.pc.in 2012-07-05 15:52:06.000000000 -0500
+@@ -10,5 +10,5 @@
+ Requires: glib-2.0 libmatecomponent-2.0
+ Requires.private: MateCORBA-2.0 mateconf-2.0 mate-vfs-2.0 @ESD_DEPS@
+ Version: @VERSION@
+-Libs: -L${libdir} -lmate-2 -lpopt
++Libs: -L${libdir} -L%%LOCALBASE%%/lib -lmate-2 -lpopt
+ Cflags: -I${includedir}/libmate-2.0
diff --git a/x11/libmate/files/patch-libmate_mate-util.c b/x11/libmate/files/patch-libmate_mate-util.c
new file mode 100644
index 0000000..709c57b
--- /dev/null
+++ b/x11/libmate/files/patch-libmate_mate-util.c
@@ -0,0 +1,18 @@
+--- libmate/mate-util.c.orig 2012-07-05 15:58:15.000000000 -0500
++++ libmate/mate-util.c 2012-07-05 16:00:05.000000000 -0500
+@@ -81,11 +81,10 @@
+ const char shells[][14] = {
+ /* Note that on some systems shells can also
+ * be installed in /usr/bin */
+- "/bin/bash", "/usr/bin/bash",
+- "/bin/zsh", "/usr/bin/zsh",
+- "/bin/tcsh", "/usr/bin/tcsh",
+- "/bin/ksh", "/usr/bin/ksh",
+- "/bin/csh", "/bin/sh"
++ LOCALBASE "/bin/bash",
++ LOCALBASE "/bin/zsh",
++ LOCALBASE "/bin/ksh",
++ 0
+ };
+
+ if (geteuid() == getuid() && getegid() == getgid())
diff --git a/x11/libmate/files/pkg-deinstall.in b/x11/libmate/files/pkg-deinstall.in
new file mode 100644
index 0000000..c831b51
--- /dev/null
+++ b/x11/libmate/files/pkg-deinstall.in
@@ -0,0 +1,20 @@
+#!/bin/sh
+#
+# $FreeBSD$
+# $MCom$
+#
+# Restore mateconf keys of mate-vfs.
+
+if [ "$2" != "POST-DEINSTALL" ]; then
+ exit 0
+fi
+
+SCHEMAS=%%LOCALBASE%%/etc/mateconf/schemas/desktop_default_applications.schemas
+
+if [ -f ${SCHEMAS} ]; then
+ env MATECONF_CONFIG_SOURCE=xml::%%LOCALBASE%%/etc/mateconf/mateconf.xml.defaults \
+ %%LOCALBASE%%/bin/mateconftool-2 --makefile-install-rule ${SCHEMAS} \
+ > /dev/null || /usr/bin/true
+fi
+
+exit 0
diff --git a/x11/libmate/pkg-descr b/x11/libmate/pkg-descr
new file mode 100644
index 0000000..d32f794
--- /dev/null
+++ b/x11/libmate/pkg-descr
@@ -0,0 +1,3 @@
+LibMATE provides the non-GUI backend for the MATE environment.
+
+WWW: http://mate-desktop.org/
diff --git a/x11/libmate/pkg-plist b/x11/libmate/pkg-plist
new file mode 100644
index 0000000..9ae4306
--- /dev/null
+++ b/x11/libmate/pkg-plist
@@ -0,0 +1,219 @@
+bin/mate-open
+etc/sound/events/gtk2-mate-events.soundlist
+etc/sound/events/mate.soundlist
+include/libmate-2.0/libmate/libmate.h
+include/libmate-2.0/libmate/libmatetypebuiltins.h
+include/libmate-2.0/libmate/mate-config.h
+include/libmate-2.0/libmate/mate-exec.h
+include/libmate-2.0/libmate/mate-help.h
+include/libmate-2.0/libmate/mate-i18n.h
+include/libmate-2.0/libmate/mate-init.h
+include/libmate-2.0/libmate/mate-macros.h
+include/libmate-2.0/libmate/mate-mateconf.h
+include/libmate-2.0/libmate/mate-program.h
+include/libmate-2.0/libmate/mate-score.h
+include/libmate-2.0/libmate/mate-sound.h
+include/libmate-2.0/libmate/mate-triggers.h
+include/libmate-2.0/libmate/mate-url.h
+include/libmate-2.0/libmate/mate-util.h
+lib/libmate-2.a
+lib/libmate-2.la
+lib/libmate-2.so
+lib/libmate-2.so.0
+lib/matecomponent/monikers/libmoniker_extra_2.a
+lib/matecomponent/monikers/libmoniker_extra_2.la
+lib/matecomponent/monikers/libmoniker_extra_2.so
+libdata/matecomponent/servers/MATE_Moniker_std.server
+libdata/pkgconfig/libmate-2.0.pc
+%%DOCSDIR%%/ch01.html
+%%DOCSDIR%%/ch02.html
+%%DOCSDIR%%/ch03.html
+%%DOCSDIR%%/ch04.html
+%%DOCSDIR%%/ch05.html
+%%DOCSDIR%%/ch06.html
+%%DOCSDIR%%/home.png
+%%DOCSDIR%%/index.html
+%%DOCSDIR%%/index.sgml
+%%DOCSDIR%%/ix01.html
+%%DOCSDIR%%/ix02.html
+%%DOCSDIR%%/ix03.html
+%%DOCSDIR%%/ix04.html
+%%DOCSDIR%%/ix05.html
+%%DOCSDIR%%/ix06.html
+%%DOCSDIR%%/ix07.html
+%%DOCSDIR%%/ix08.html
+%%DOCSDIR%%/ix09.html
+%%DOCSDIR%%/ix10.html
+%%DOCSDIR%%/left.png
+%%DOCSDIR%%/libmate-libmatetypebuiltins.html
+%%DOCSDIR%%/libmate-mate-config.html
+%%DOCSDIR%%/libmate-mate-exec.html
+%%DOCSDIR%%/libmate-mate-help.html
+%%DOCSDIR%%/libmate-mate-i18n.html
+%%DOCSDIR%%/libmate-mate-init.html
+%%DOCSDIR%%/libmate-mate-mateconf.html
+%%DOCSDIR%%/libmate-mate-program.html
+%%DOCSDIR%%/libmate-mate-score.html
+%%DOCSDIR%%/libmate-mate-sound.html
+%%DOCSDIR%%/libmate-mate-triggers.html
+%%DOCSDIR%%/libmate-mate-url.html
+%%DOCSDIR%%/libmate-mate-util.html
+%%DOCSDIR%%/libmate.devhelp
+%%DOCSDIR%%/libmate.devhelp2
+%%DOCSDIR%%/libmate.html
+%%DOCSDIR%%/right.png
+%%DOCSDIR%%/style.css
+%%DOCSDIR%%/up.png
+share/locale/am/LC_MESSAGES/libmate.mo
+share/locale/ar/LC_MESSAGES/libmate.mo
+share/locale/as/LC_MESSAGES/libmate.mo
+share/locale/ast/LC_MESSAGES/libmate.mo
+share/locale/az/LC_MESSAGES/libmate.mo
+share/locale/be/LC_MESSAGES/libmate.mo
+share/locale/bg/LC_MESSAGES/libmate.mo
+share/locale/bn/LC_MESSAGES/libmate.mo
+share/locale/bn_IN/LC_MESSAGES/libmate.mo
+share/locale/br/LC_MESSAGES/libmate.mo
+share/locale/bs/LC_MESSAGES/libmate.mo
+share/locale/ca/LC_MESSAGES/libmate.mo
+share/locale/ca@valencia/LC_MESSAGES/libmate.mo
+share/locale/crh/LC_MESSAGES/libmate.mo
+share/locale/cs/LC_MESSAGES/libmate.mo
+share/locale/cy/LC_MESSAGES/libmate.mo
+share/locale/da/LC_MESSAGES/libmate.mo
+share/locale/de/LC_MESSAGES/libmate.mo
+share/locale/dz/LC_MESSAGES/libmate.mo
+share/locale/el/LC_MESSAGES/libmate.mo
+share/locale/en@shaw/LC_MESSAGES/libmate.mo
+share/locale/en_CA/LC_MESSAGES/libmate.mo
+share/locale/en_GB/LC_MESSAGES/libmate.mo
+share/locale/eo/LC_MESSAGES/libmate.mo
+share/locale/es/LC_MESSAGES/libmate.mo
+share/locale/et/LC_MESSAGES/libmate.mo
+share/locale/eu/LC_MESSAGES/libmate.mo
+share/locale/fa/LC_MESSAGES/libmate.mo
+share/locale/fi/LC_MESSAGES/libmate.mo
+share/locale/fr/LC_MESSAGES/libmate.mo
+share/locale/fur/LC_MESSAGES/libmate.mo
+share/locale/ga/LC_MESSAGES/libmate.mo
+share/locale/gl/LC_MESSAGES/libmate.mo
+share/locale/gu/LC_MESSAGES/libmate.mo
+share/locale/he/LC_MESSAGES/libmate.mo
+share/locale/hi/LC_MESSAGES/libmate.mo
+share/locale/hr/LC_MESSAGES/libmate.mo
+share/locale/hu/LC_MESSAGES/libmate.mo
+share/locale/id/LC_MESSAGES/libmate.mo
+share/locale/is/LC_MESSAGES/libmate.mo
+share/locale/it/LC_MESSAGES/libmate.mo
+share/locale/ja/LC_MESSAGES/libmate.mo
+share/locale/ka/LC_MESSAGES/libmate.mo
+share/locale/kk/LC_MESSAGES/libmate.mo
+share/locale/kn/LC_MESSAGES/libmate.mo
+share/locale/ko/LC_MESSAGES/libmate.mo
+share/locale/ku/LC_MESSAGES/libmate.mo
+share/locale/lt/LC_MESSAGES/libmate.mo
+share/locale/lv/LC_MESSAGES/libmate.mo
+share/locale/mai/LC_MESSAGES/libmate.mo
+share/locale/mg/LC_MESSAGES/libmate.mo
+share/locale/mk/LC_MESSAGES/libmate.mo
+share/locale/ml/LC_MESSAGES/libmate.mo
+share/locale/mn/LC_MESSAGES/libmate.mo
+share/locale/mr/LC_MESSAGES/libmate.mo
+share/locale/ms/LC_MESSAGES/libmate.mo
+share/locale/nb/LC_MESSAGES/libmate.mo
+share/locale/nds/LC_MESSAGES/libmate.mo
+share/locale/ne/LC_MESSAGES/libmate.mo
+share/locale/nl/LC_MESSAGES/libmate.mo
+share/locale/nn/LC_MESSAGES/libmate.mo
+share/locale/oc/LC_MESSAGES/libmate.mo
+share/locale/or/LC_MESSAGES/libmate.mo
+share/locale/pa/LC_MESSAGES/libmate.mo
+share/locale/pl/LC_MESSAGES/libmate.mo
+share/locale/pt/LC_MESSAGES/libmate.mo
+share/locale/pt_BR/LC_MESSAGES/libmate.mo
+share/locale/ro/LC_MESSAGES/libmate.mo
+share/locale/ru/LC_MESSAGES/libmate.mo
+share/locale/rw/LC_MESSAGES/libmate.mo
+share/locale/si/LC_MESSAGES/libmate.mo
+share/locale/sk/LC_MESSAGES/libmate.mo
+share/locale/sl/LC_MESSAGES/libmate.mo
+share/locale/sq/LC_MESSAGES/libmate.mo
+share/locale/sr/LC_MESSAGES/libmate.mo
+share/locale/sr@ije/LC_MESSAGES/libmate.mo
+share/locale/sr@latin/LC_MESSAGES/libmate.mo
+share/locale/sv/LC_MESSAGES/libmate.mo
+share/locale/ta/LC_MESSAGES/libmate.mo
+share/locale/te/LC_MESSAGES/libmate.mo
+share/locale/th/LC_MESSAGES/libmate.mo
+share/locale/tr/LC_MESSAGES/libmate.mo
+share/locale/tt/LC_MESSAGES/libmate.mo
+share/locale/uk/LC_MESSAGES/libmate.mo
+share/locale/vi/LC_MESSAGES/libmate.mo
+share/locale/wa/LC_MESSAGES/libmate.mo
+share/locale/xh/LC_MESSAGES/libmate.mo
+share/locale/yi/LC_MESSAGES/libmate.mo
+share/locale/zh_CN/LC_MESSAGES/libmate.mo
+share/locale/zh_HK/LC_MESSAGES/libmate.mo
+share/locale/zh_TW/LC_MESSAGES/libmate.mo
+share/mate-background-properties/mate-default.xml
+@dirrm share/mate-background-properties
+@dirrmtry share/locale/zh_HK/LC_MESSAGES
+@dirrmtry share/locale/zh_HK
+@dirrmtry share/locale/yi/LC_MESSAGES
+@dirrmtry share/locale/yi
+@dirrmtry share/locale/xh/LC_MESSAGES
+@dirrmtry share/locale/xh
+@dirrmtry share/locale/tt/LC_MESSAGES
+@dirrmtry share/locale/tt
+@dirrmtry share/locale/te/LC_MESSAGES
+@dirrmtry share/locale/te
+@dirrmtry share/locale/sr@latin/LC_MESSAGES
+@dirrmtry share/locale/sr@latin
+@dirrmtry share/locale/sr@ije/LC_MESSAGES
+@dirrmtry share/locale/sr@ije
+@dirrmtry share/locale/si/LC_MESSAGES
+@dirrmtry share/locale/si
+@dirrmtry share/locale/rw/LC_MESSAGES
+@dirrmtry share/locale/rw
+@dirrmtry share/locale/oc/LC_MESSAGES
+@dirrmtry share/locale/oc
+@dirrmtry share/locale/nds/LC_MESSAGES
+@dirrmtry share/locale/nds
+@dirrmtry share/locale/mr/LC_MESSAGES
+@dirrmtry share/locale/mr
+@dirrmtry share/locale/mg/LC_MESSAGES
+@dirrmtry share/locale/mg
+@dirrmtry share/locale/mai/LC_MESSAGES
+@dirrmtry share/locale/mai
+@dirrmtry share/locale/ku/LC_MESSAGES
+@dirrmtry share/locale/ku
+@dirrmtry share/locale/kk/LC_MESSAGES
+@dirrmtry share/locale/kk
+@dirrmtry share/locale/fur/LC_MESSAGES
+@dirrmtry share/locale/fur
+@dirrmtry share/locale/en@shaw/LC_MESSAGES
+@dirrmtry share/locale/en@shaw
+@dirrmtry share/locale/dz/LC_MESSAGES
+@dirrmtry share/locale/dz
+@dirrmtry share/locale/crh/LC_MESSAGES
+@dirrmtry share/locale/crh
+@dirrmtry share/locale/ca@valencia/LC_MESSAGES
+@dirrmtry share/locale/ca@valencia
+@dirrmtry share/locale/bn_IN/LC_MESSAGES
+@dirrmtry share/locale/bn_IN
+@dirrmtry share/locale/ast/LC_MESSAGES
+@dirrmtry share/locale/ast
+@dirrmtry share/locale/as/LC_MESSAGES
+@dirrmtry share/locale/as
+@dirrm %%DOCSDIR%%
+@dirrm libdata/matecomponent/servers
+@dirrm libdata/matecomponent
+@dirrm lib/matecomponent/monikers
+@dirrm lib/matecomponent
+@dirrm include/libmate-2.0/libmate
+@dirrm include/libmate-2.0
+@dirrm etc/sound/events
+@dirrm etc/sound
+@dirrm etc/mateconf/schemas
+@dirrm etc/mateconf/mateconf.xml.defaults
+@dirrm etc/mateconf