summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'dev-db/monetdb')
-rw-r--r--dev-db/monetdb/ChangeLog14
-rw-r--r--dev-db/monetdb/Manifest12
-rw-r--r--dev-db/monetdb/files/digest-monetdb-4.8.24
-rw-r--r--dev-db/monetdb/files/monetdb-4.8.2-gentoo-MapiClient.patch11
-rw-r--r--dev-db/monetdb/files/monetdb-4.8.2-gentoo-conf.patch32
-rw-r--r--dev-db/monetdb/files/monetdb-4.8.2-startup.mil28
-rw-r--r--dev-db/monetdb/files/monetdb-start.sh16
-rw-r--r--dev-db/monetdb/files/monetdb-stop.sh26
-rw-r--r--dev-db/monetdb/files/monetdb.conf-4.8.215
-rw-r--r--dev-db/monetdb/files/monetdb.init-4.8.217
-rw-r--r--dev-db/monetdb/files/monetdb_config.sh21
-rw-r--r--dev-db/monetdb/metadata.xml20
-rw-r--r--dev-db/monetdb/monetdb-4.8.2.ebuild194
13 files changed, 410 insertions, 0 deletions
diff --git a/dev-db/monetdb/ChangeLog b/dev-db/monetdb/ChangeLog
new file mode 100644
index 000000000000..107f7827abe0
--- /dev/null
+++ b/dev-db/monetdb/ChangeLog
@@ -0,0 +1,14 @@
+# ChangeLog for dev-db/monetdb
+# Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2
+# $Header: /var/cvsroot/gentoo-x86/dev-db/monetdb/ChangeLog,v 1.1 2005/08/07 13:23:17 grobian Exp $
+
+*monetdb-4.8.2 (06 Aug 2005)
+
+ 06 Aug 2005; Fabian Groffen <grobian@gentoo.org>
+ +files/monetdb.conf-4.8.2, +files/monetdb.init-4.8.2,
+ +files/monetdb-4.8.2-gentoo-MapiClient.patch,
+ +files/monetdb-4.8.2-gentoo-conf.patch, +files/monetdb-4.8.2-startup.mil,
+ +files/monetdb-start.sh, +files/monetdb-stop.sh, +files/monetdb_config.sh,
+ +metadata.xml, +monetdb-4.8.2.ebuild:
+ Initial import of MonetDB 4.8.2 with SQL and XQuery support
+
diff --git a/dev-db/monetdb/Manifest b/dev-db/monetdb/Manifest
new file mode 100644
index 000000000000..0fc577118aed
--- /dev/null
+++ b/dev-db/monetdb/Manifest
@@ -0,0 +1,12 @@
+MD5 05841054d5996b2f58ff1160cb39f9d7 monetdb-4.8.2.ebuild 6334
+MD5 24272f95d7629d85f9268b0275643cba ChangeLog 643
+MD5 ca9ff61fbe7d29f666c1ffdc61bb168d metadata.xml 801
+MD5 a9a2dbac1941306b506077c635415e7e files/monetdb_config.sh 653
+MD5 739a372d2ff096d674002e3253eb4dad files/monetdb-4.8.2-startup.mil 929
+MD5 e97ba2fc5180dac248822b8264841013 files/monetdb-start.sh 379
+MD5 be0eaed8b26f07c98efcbb9d59e15a64 files/monetdb-4.8.2-gentoo-conf.patch 1038
+MD5 cae0e46fdfa11ea1f0be120005076b83 files/monetdb.init-4.8.2 328
+MD5 09aa9eafe8a4c3073b669baa9ea6ea6d files/monetdb.conf-4.8.2 768
+MD5 ab73e512460465c2653accc427d52e37 files/digest-monetdb-4.8.2 299
+MD5 324a083e56c76f02a3ba9ac34c188066 files/monetdb-4.8.2-gentoo-MapiClient.patch 311
+MD5 07e71d02ee02ca4ebfbc4db68fa4f40e files/monetdb-stop.sh 626
diff --git a/dev-db/monetdb/files/digest-monetdb-4.8.2 b/dev-db/monetdb/files/digest-monetdb-4.8.2
new file mode 100644
index 000000000000..ce79c605363a
--- /dev/null
+++ b/dev-db/monetdb/files/digest-monetdb-4.8.2
@@ -0,0 +1,4 @@
+MD5 5504707be924ec2c283d2285f72444d5 MonetDB-4.8.2.tar.gz 21260095
+MD5 76d4d4005675b7ed18cf98579124dbfe MonetDB-SQL-2.8.2.tar.gz 1063441
+MD5 5dec7614cd1835e6c1898eb8bb337ac4 MonetDB-XQuery-0.8.2.tar.gz 873414
+MD5 436151071d03a7256a419b779d0c834c monetdb-pathfinder-bison-sources-0.8.2.tar.bz2 79380
diff --git a/dev-db/monetdb/files/monetdb-4.8.2-gentoo-MapiClient.patch b/dev-db/monetdb/files/monetdb-4.8.2-gentoo-MapiClient.patch
new file mode 100644
index 000000000000..e7e25ac4e751
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb-4.8.2-gentoo-MapiClient.patch
@@ -0,0 +1,11 @@
+--- MonetDB-4.8.2/src/mapi/clients/C/MapiClient.mx 2005-01-21 17:25:11.000000000 +0100
++++ MapiClient.mx 2005-02-09 13:34:51.251310750 +0100
+@@ -1285,7 +1285,7 @@
+ {
+ opt *set = NULL;
+ int setlen;
+- char *language = "mil";
++ char *language = "sql";
+ int port = 0;
+ char *user = NULL;
+ char *passwd = NULL;
diff --git a/dev-db/monetdb/files/monetdb-4.8.2-gentoo-conf.patch b/dev-db/monetdb/files/monetdb-4.8.2-gentoo-conf.patch
new file mode 100644
index 000000000000..7f7a83e0b9e6
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb-4.8.2-gentoo-conf.patch
@@ -0,0 +1,32 @@
+--- MonetDB-4.8.2/conf/MonetDB.conf.in 2004-10-26 02:02:16.000000000 +0200
++++ MonetDB.conf.in 2004-10-28 21:04:52.958269189 +0200
+@@ -20,7 +20,7 @@
+ # the name of the database to use below. Note that you can use
+ # multiple databases, but that you have to edit the database name
+ # and restart MonetDB.
+-gdk_dbname=demo
++gdk_dbname=default
+
+ # The options below deal with various aspects of memory usage behaviour.
+ # If you don't know what these values mean, you should leave them alone.
+@@ -64,11 +64,6 @@
+ #
+ #gdk_version <ver> create BATs in old formats[out of date?]
+
+-
+-# General client Section
+-#=======================
+-#host=localhost #the host the server runs on
+-
+ # MonetDB Section
+ #================
+ # Administrator user name
+@@ -81,7 +76,7 @@
+ # Where do the MonetDB modules reside?
+ monet_mod_path=@libdir@@DIRSEP@@PACKAGE@
+ # Start Mserver in daemon mode, or start with MIL interactive interface?
+-monet_daemon=no
++monet_daemon=yes
+
+ # Monet Application Interface Section
+ #====================================
diff --git a/dev-db/monetdb/files/monetdb-4.8.2-startup.mil b/dev-db/monetdb/files/monetdb-4.8.2-startup.mil
new file mode 100644
index 000000000000..4698229c174d
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb-4.8.2-startup.mil
@@ -0,0 +1,28 @@
+# Gentoo MonetDB startup.mil script -- Fabian Groffen grobian@gentoo.org
+#
+# This script starts the SQL, XQuery and Mapi modules and activates a
+# listening socket for all of them on their default port. This results
+# in three ports of your system being occupied. By default the ports
+# are as follows:
+# SQL server: 45123
+# XQuery server: 45789
+# Mapi server: 50000
+
+# should connections be bound to localhost or 0.0.0.0? Set to true here
+# to allow foreign connections. Defaults to false (only local).
+var allow_foreign_connections := false;
+
+#
+# If were only looking for whatever you could change, you can stop
+# reading at this point and save your changes. Don't change anything
+# below if you don't know what you're doing.
+#
+
+module(sql_server);
+sql_server_start(allow_foreign_connections);
+
+module(pathfinder);
+xquery_server_start(allow_foreign_connections);
+
+module(mapi);
+mapi_start(allow_foreign_connections);
diff --git a/dev-db/monetdb/files/monetdb-start.sh b/dev-db/monetdb/files/monetdb-start.sh
new file mode 100644
index 000000000000..b43f4d924e3b
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb-start.sh
@@ -0,0 +1,16 @@
+#! /bin/sh
+
+LOG=/var/log/monetdb/Mserver.log
+echo `date` Starting MonetDB >> $LOG
+/usr/bin/Mserver $@ >> $LOG 2>&1 &
+MPID=$!
+echo `date` Mserver started, PID: $MPID >> $LOG
+rm -f ~monetdb/Mserver.pid > /dev/null
+sleep 2
+ALIVE=`ps --no-heading --format pid -p $MPID`
+if [ $ALIVE -eq $MPID ]; then
+ echo $MPID > ~monetdb/Mserver.pid
+else
+ echo Mserver died immediately
+ exit -1
+fi
diff --git a/dev-db/monetdb/files/monetdb-stop.sh b/dev-db/monetdb/files/monetdb-stop.sh
new file mode 100644
index 000000000000..aa562e814f98
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb-stop.sh
@@ -0,0 +1,26 @@
+#! /bin/sh
+
+LOG=/var/log/monetdb/Mserver.log
+if [ -f ~monetdb/Mserver.pid ]; then
+ MPID=`cat ~monetdb/Mserver.pid`
+else
+ echo "No Mserver PID found"
+ exit -1
+fi
+
+echo `date` Stopping MonetDB \(PID: $MPID\) >> $LOG
+kill -TERM $MPID || exit -1
+sleep 1
+ALIVE=`ps --no-heading --format pid -p $MPID`
+if [ "$ALIVE" = "$MPID" ]; then
+ echo Mserver still alive after TERM, trying KILL... >> $LOG
+ kill -KILL $MPID
+ sleep 2
+ ALIVE=`ps --no-heading --format pid -p $MPID`
+ if [ "$ALIVE" = "$MPID" ]; then
+ echo "Failed to stop process $MPID"
+ exit -1
+ fi
+fi
+echo `date` Mserver stopped >> $LOG
+rm -f ~monetdb/Mserver.pid > /dev/null
diff --git a/dev-db/monetdb/files/monetdb.conf-4.8.2 b/dev-db/monetdb/files/monetdb.conf-4.8.2
new file mode 100644
index 000000000000..cfc4abd12099
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb.conf-4.8.2
@@ -0,0 +1,15 @@
+# The user to run the MonetDB database as. It is recommended to
+# leave this as is, portage created this user during installation
+MDB_USER=monetdb
+MDB_GROUP=monetdb
+
+# MonetDB must be started with a startup script which tells it what
+# to do. Most users will not want to change this startup script
+# as it loads the SQL, XQuery (pathfinder) and Mapi modules which
+# allow for SQL, XQuery and MIL connections.
+# If you have special demands, point this variable to your own script
+# which contains the desired commands.
+# Note: for security reasons by default all listening connections are
+# bound to 127.0.0.1. If you need connections to be bound at 0.0.0.0
+# have a look at the default startup script to enable this.
+MDB_STARTUPSCRIPTS=~monetdb/monetdb-startup.mil
diff --git a/dev-db/monetdb/files/monetdb.init-4.8.2 b/dev-db/monetdb/files/monetdb.init-4.8.2
new file mode 100644
index 000000000000..5b58a8bcc4e5
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb.init-4.8.2
@@ -0,0 +1,17 @@
+#!/sbin/runscript
+
+depend() {
+ use net
+}
+
+start() {
+ ebegin "Starting MonetDB"
+ start-stop-daemon -c $MDB_USER:$MDB_GROUP --start --exec ~monetdb/monetdb-start.sh -- $MDB_STARTUPSCRIPTS
+ eend $?
+}
+
+stop() {
+ ebegin "Stopping MonetDB"
+ start-stop-daemon -c $MDB_USER:$MDB_GROUP --start --exec ~monetdb/monetdb-stop.sh
+ eend $?
+}
diff --git a/dev-db/monetdb/files/monetdb_config.sh b/dev-db/monetdb/files/monetdb_config.sh
new file mode 100644
index 000000000000..eab7f36cc5f5
--- /dev/null
+++ b/dev-db/monetdb/files/monetdb_config.sh
@@ -0,0 +1,21 @@
+#! /bin/sh
+
+MYINCLUDES="-I$_MONETDB_INCLUDEDIR \
+ -I$_MONETDB_INCLUDEDIR/common \
+ -I$_MONETDB_INCLUDEDIR/gdk \
+ -I$_MONETDB_INCLUDEDIR/monet \
+ -I$_MONETDB_INCLUDEDIR/plain \
+ -I$_MONETDB_INCLUDEDIR/contrib \
+ -I$_MONETDB_INCLUDEDIR/mapi \
+ -I$_MONETDB_INCLUDEDIR/C"
+
+case $1 in
+ --version ) echo $_MONETDB_VERSION; break;;
+ --cflags ) echo $MYINCLUDES; break;;
+ --includes ) echo $MYINCLUDES; break;;
+ --pkgincludedir ) echo $_MONETDB_INCLUDEDIR; break;;
+ --libs ) echo $_MONETDB_LIBS; break;;
+ --modpath ) echo $_MONETDB_MOD_PATH; break;;
+ --prefix ) echo $_MONETDB_PREFIX; break;;
+ --classpath ) echo $_MONETDB_CLASSPATH; break;;
+esac
diff --git a/dev-db/monetdb/metadata.xml b/dev-db/monetdb/metadata.xml
new file mode 100644
index 000000000000..d242c945a7ce
--- /dev/null
+++ b/dev-db/monetdb/metadata.xml
@@ -0,0 +1,20 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
+<pkgmetadata>
+ <herd>no-herd</herd>
+ <maintainer>
+ <email>grobian@gentoo.org</email>
+ <name>Fabian Groffen</name>
+ </maintainer>
+ <longdescription>
+ MonetDB is a main-memory database developed at CWI the
+ Netherlands. The main-memory focus of the database has resulted
+ in a column based way of dealing with relational tables. Due to
+ this unconventional approach, MonetDB can be a very fast
+ database for complex queries, and as such in use (and perfectly
+ suitable) for intensive data-mining tasks.
+ MonetDB 4 supports its own kernel language, MIL, the
+ conventional SQL query language and the relatively new XML
+ querying language, XQuery.
+ </longdescription>
+</pkgmetadata>
diff --git a/dev-db/monetdb/monetdb-4.8.2.ebuild b/dev-db/monetdb/monetdb-4.8.2.ebuild
new file mode 100644
index 000000000000..6c30c63dd760
--- /dev/null
+++ b/dev-db/monetdb/monetdb-4.8.2.ebuild
@@ -0,0 +1,194 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/dev-db/monetdb/monetdb-4.8.2.ebuild,v 1.1 2005/08/07 13:23:17 grobian Exp $
+
+inherit flag-o-matic eutils
+
+DESCRIPTION="A main-memory relational database for SQL, XQuery and MIL"
+HOMEPAGE="http://monetdb.cwi.nl/"
+PV_SQL=2.8.2
+PV_XQ=0.8.2
+SRC_URI="mirror://sourceforge/monetdb/MonetDB-${PV}.tar.gz
+ mirror://sourceforge/monetdb/MonetDB-SQL-${PV_SQL}.tar.gz
+ mirror://sourceforge/monetdb/MonetDB-XQuery-${PV_XQ}.tar.gz
+ ppc-macos? ( mirror://gentoo/monetdb-pathfinder-bison-sources-0.8.2.tar.bz2 )"
+LICENSE="MonetDBPL-1.1 PathfinderPL-1.1"
+SLOT="0"
+KEYWORDS="~x86 ~ppc-macos"
+IUSE="java readline"
+
+DEPEND="virtual/libc
+ sys-devel/flex
+ ppc-macos? ( sys-devel/bison )
+ !ppc-macos? ( >=sys-devel/bison-1.33 )
+ >=sys-devel/gcc-3.3*
+ java? ( >=virtual/jdk-1.4* )
+ readline? ( >=sys-libs/readline-4.1 )
+ dev-libs/libxml2"
+
+DATA_DIR="/var/lib/MonetDB"
+
+pkg_setup() {
+ if [ -x ${DATA_DIR}/dbfarm ] || [ -x ${DATA_DIR}/log ]; then
+ while read line; do eerror "${line}"; done <<EOF
+MonetDB ${MY_PV} cannot upgrade your existing SQL databases. You must
+export your existing SQL databases to a file using "JdbcClient -D" and
+then restore them when you have upgraded completey using
+"JdbcClient -f".
+
+If you have MIL BATs, aging from before MonetDB 4.8.0 your have to
+convert those after upgrading. See the following for more information
+on upgrading from previous database versions:
+http://monetdb.cwi.nl/TechDocs/FrontEnds/SQL/upgrade/
+http://monetdb.cwi.nl/TechDocs/FrontEnds/mil/upgrade/
+
+You must remove your entire database directory to continue.
+(database directory = ${DATA_DIR}).
+EOF
+ die "Cannot upgrade automatically."
+ fi
+
+ enewgroup monetdb
+ enewuser monetdb -1 /bin/bash ${DATA_DIR} monetdb
+}
+
+src_unpack() {
+ unpack ${A} || die
+
+ epatch ${FILESDIR}/monetdb-${PV}-gentoo-conf.patch
+ epatch ${FILESDIR}/monetdb-${PV}-gentoo-MapiClient.patch
+}
+
+src_compile() {
+ # The tar has capitals, the ebuild doesn't...
+ cd ${WORKDIR}/MonetDB-${PV}
+
+ econf \
+ "--enable-optimize" \
+ $(use_with java) \
+ $(use_with readline) \
+ || die "econf monetdb failed"
+
+ emake || die "emake monetdb failed"
+
+ # make the header files available to the sql and xquery compilation
+ mkdir include
+ cd include
+ ln -s ../src/common
+ ln -s ../src/gdk
+ ln -s ../src/monet
+ ln -s ../src/modules/plain
+ ln -s ../src/modules/contrib
+ ln -s ../src/mapi
+ ln -s ../src/mapi/clients/C
+ ln -s ../monetdb_config.h
+ ln -s ../sysdefs.h
+
+ cd ${WORKDIR}/MonetDB-${PV}
+ mkdir -p lib/MonetDB
+ cd lib/MonetDB
+ find ../.. -name "lib_*" -exec ln -s {} ';' >& /dev/null
+ ln -s . .libs
+
+ cd ${WORKDIR}/MonetDB-${PV}/lib
+ find .. -name "lib*" -exec ln -s {} ';' >& /dev/null
+ ln -s . .libs
+
+ cd ${WORKDIR}/MonetDB-${PV}
+ mkdir bin
+ cd bin
+ ln -s ../src/mel/mel
+ ln -s ../src/utils/Mx/Mx
+
+ # enable the fool-script
+ MYWD=`echo ${WORKDIR} | sed -re 's/\//\\\\\//g'`
+ sed -r \
+ -e "s/\\$\_MONETDB\_INCLUDEDIR/${MYWD}\/MonetDB-${PV}\/include/g" \
+ -e "s/\\$\_MONETDB\_VERSION/${PV}/g" \
+ -e "s/\\$\_MONETDB\_LIBS/-L${MYWD}\/MonetDB-${PV}\/lib\/MonetDB -L${MYWD}\/MonetDB-${PV}\/lib/g" \
+ -e "s/\\$\_MONETDB\_MOD_PATH/${MYWD}\/MonetDB-${PV}\/include/g" \
+ -e "s/\\$\_MONETDB\_PREFIX/${MYWD}\/MonetDB-${PV}/g" \
+ -e "s/\\$\_MONETDB\_CLASSPATH/${MYWD}\/MonetDB-${PV}\/src\/mapi\/clients\/java\/mapi.jar/g" \
+ ${FILESDIR}/monetdb_config.sh > \
+ ${WORKDIR}/MonetDB-${PV}/bin/monetdb-config
+ chmod 744 ${WORKDIR}/MonetDB-${PV}/bin/monetdb-config
+
+ # configure and make SQL
+ cd ${WORKDIR}/sql-${PV_SQL}
+ econf MONETDB_CONFIG=${WORKDIR}/MonetDB-${PV}/bin/monetdb-config \
+ "--with-monet=${WORKDIR}/MonetDB-${PV}" \
+ "--enable-optimize" \
+ `use_with java` || die
+ emake || die "emake sql failed"
+
+ # configure and make XQuery, because it relies on >=bison-1.33 which we
+ # might not have, we apply a special patch with bison 2.0 generated
+ # files. This is especially useful for OSX users, as this allows
+ # them to use this package without having to overwrite their system
+ # installed bison 1.28
+ cd ${WORKDIR}/pathfinder-${PV_XQ}
+ # has_version/best_version do not take package.provided into
+ # account! thus we assume OSX users don't have the right bison :(
+ if use ppc-macos; then
+ einfo "extracting extra files for older bison users"
+ tar -jxf ${DISTDIR}/monetdb-pathfinder-bison-sources-${PV_XQ}.tar.bz2
+ fi
+ econf MONETDB_CONFIG=${WORKDIR}/MonetDB-${PV}/bin/monetdb-config \
+ "--with-monet=${WORKDIR}/MonetDB-${PV} " \
+ "--enable-optimize" || die
+ emake || die "emake xquery failed"
+}
+
+src_install() {
+ # The tar has capitals, the ebuild doesn't...
+ cd ${WORKDIR}/MonetDB-${PV}
+ einstall || die "failed to install monetdb"
+
+ cd ${WORKDIR}/sql-${PV_SQL}
+ einstall || die "failed to install sql"
+
+ cd ${WORKDIR}/pathfinder-${PV_XQ}
+ einstall || die "failed to install xquery"
+
+ exeinto /etc/init.d/
+ newexe ${FILESDIR}/${PN}.init-${PV} monetdb || die "init.d script"
+
+ insinto /etc/conf.d/
+ newins ${FILESDIR}/${PN}.conf-${PV} monetdb || die "conf.d file"
+
+ diropts -m750
+ dodir ${DATA_DIR} /var/log/${PN}
+
+ exeinto ${DATA_DIR}
+ newexe ${FILESDIR}/${PN}-start.sh ${PN}-start.sh || die "start script"
+ newexe ${FILESDIR}/${PN}-stop.sh ${PN}-stop.sh || die "stop script"
+
+ insinto ${DATA_DIR}
+ newins ${FILESDIR}/${PN}-${PV}-startup.mil ${PN}-startup.mil || die "startup MIL script"
+
+ # set right permissions
+ chown -R monetdb:monetdb ${D}/${DATA_DIR}
+ fowners monetdb:monetdb /var/log/${PN}
+
+ # remove Mx and mel, they are only needed for compilation
+ rm -f ${D}/usr/bin/Mx ${D}/usr/bin/mel ${D}/usr/bin/idxmx
+ # remove windows crap
+ rm -f ${D}/usr/bin/*.bat
+ # remove perl DBD on ppc-macos, since it gets installed in the wrong
+ # location and getting it right is not just a simple thing
+ use ppc-macos && rm -Rf ${D}/usr/Network > /dev/null
+}
+
+pkg_postinst() {
+ while read line; do einfo "${line}"; done <<EOF
+MonetDB has been installed on your system, using data directory
+${DATA_DIR}. To get started using SQL, XQuery or MIL see:
+
+http://monetdb.cwi.nl/GettingStarted/
+
+If you have upgraded from version 4.6.2 or below you should restore your
+SQL databases, as well as convert your MIL BATs. See also:
+http://monetdb.cwi.nl/TechDocs/FrontEnds/SQL/upgrade/
+http://monetdb.cwi.nl/TechDocs/FrontEnds/mil/upgrade/
+EOF
+}