# HG changeset patch # User Carl Byington # Date 1213133335 25200 # Node ID 535075b4d261a769688c70984945ef1be1efdd07 # Parent 87216aefc6df7706b2a22ed467c8e1dd645d4897 Patch from Joachim Metz for debian packaging, and fix for incorrect length on lz decompression. diff -r 87216aefc6df -r 535075b4d261 ChangeLog --- a/ChangeLog Sat Jun 07 15:53:08 2008 -0700 +++ b/ChangeLog Tue Jun 10 14:28:55 2008 -0700 @@ -1,3 +1,8 @@ +LibPST 0.6.12 (2008-06-10) +=============================== + * Patch from Joachim Metz for debian packaging, and fix + for incorrect length on lz decompression. + LibPST 0.6.11 (2008-06-03) =============================== * Use ftello/fseeko to properly handle large files. diff -r 87216aefc6df -r 535075b4d261 Makefile.am --- a/Makefile.am Sat Jun 07 15:53:08 2008 -0700 +++ b/Makefile.am Tue Jun 10 14:28:55 2008 -0700 @@ -3,3 +3,4 @@ html_DATA = AUTHORS COPYING ChangeLog NEWS README CLEANFILES = xml/libpst xml/Makefile EXTRA_DIST = Doxyfile libpst.html.tar.gz libpst.spec $(wildcard xml/M*) $(wildcard xml/h*) $(wildcard xml/lib*) + diff -r 87216aefc6df -r 535075b4d261 NEWS --- a/NEWS Sat Jun 07 15:53:08 2008 -0700 +++ b/NEWS Tue Jun 10 14:28:55 2008 -0700 @@ -1,3 +1,4 @@ +0.6.12 2008-06-10 Patch from Joachim Metz for debian packaging, and fix for incorrect length on lz decompression. 0.6.11 2008-06-03 Use ftello/fseeko to properly handle large files. 0.6.10 2008-05-29 Patch from Robert Simpson for doubly-linked list and arrays of unicode strings. 0.6.9 2008-05-16 Patch from Joachim Metz for 64 bit compile. diff -r 87216aefc6df -r 535075b4d261 configure.in --- a/configure.in Sat Jun 07 15:53:08 2008 -0700 +++ b/configure.in Tue Jun 10 14:28:55 2008 -0700 @@ -76,8 +76,10 @@ AC_MSG_RESULT([no]) ) + AC_OUTPUT( \ Makefile \ + debian/changelog \ libpst.spec \ html/Makefile \ info/Makefile \ diff -r 87216aefc6df -r 535075b4d261 debian/changelog --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/changelog Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,6 @@ +libpst (0.6.12-1) unstable; urgency=low + + * Initial release + + -- Joachim Metz Thu, 29 May 2008 15:37:06 +0200 + diff -r 87216aefc6df -r 535075b4d261 debian/changelog.in --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/changelog.in Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,6 @@ +libpst (@VERSION@-1) unstable; urgency=low + + * Initial release + + -- Joachim Metz Thu, 29 May 2008 15:37:06 +0200 + diff -r 87216aefc6df -r 535075b4d261 debian/compat --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/compat Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,1 @@ +5 diff -r 87216aefc6df -r 535075b4d261 debian/control --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/control Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,17 @@ +Source: libpst +Section: utils +Priority: extra +Maintainer: Joachim Metz +Build-Depends: debhelper (>= 5), autotools-dev, libfreetype6-dev, libgd2-noxpm-dev, zlib1g-dev, libjpeg62-dev +Standards-Version: 3.7.2 + +Package: libpst +Architecture: any +Depends: ImageMagick, ${shlibs:Depends}, ${misc:Depends} +Description: Utilities to convert Outlook .pst files to other formats + The Libpst utilities include readpst which can convert email messages + to both mbox and MH mailbox formats, pst2ldif which can convert the + contacts to .ldif format for import into ldap databases, and pst2dii + which can convert email messages to the DII load file format used by + Summation. + diff -r 87216aefc6df -r 535075b4d261 debian/copyright --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/copyright Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,41 @@ +This package was debianized by Joachim Metz on +Thu, 29 May 2008 15:37:06 +0200. + +It was downloaded from + +Upstream maintainter: Carl Byington + +Copyright: + +Original version by: + Dave Smith + Dave Smith + +Current maintainer: + Carl Byington + +With contributions by: + Joseph Nahmias -- bounces + Joseph Nahmias + Arne Ahrend + Nigel Horne + Chris Halls + Stevens Miller + Brad Hards + Alexander Grau + Antonio Palama + Sean Loaring + James Woodcock + +License: + + + + +The Debian packaging is (C) 2008, Joachim Metz and +is licensed under the GPL, see `/usr/share/common-licenses/GPL'. + + +# Please also look if there are files or directories which have a +# different copyright/license attached and list them here. + diff -r 87216aefc6df -r 535075b4d261 debian/cron.d.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/cron.d.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,4 @@ +# +# Regular cron jobs for the libpst package +# +0 4 * * * root libpst_maintenance diff -r 87216aefc6df -r 535075b4d261 debian/emacsen-install.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/emacsen-install.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,45 @@ +#! /bin/sh -e +# /usr/lib/emacsen-common/packages/install/libpst + +# Written by Jim Van Zandt , borrowing heavily +# from the install scripts for gettext by Santiago Vila +# and octave by Dirk Eddelbuettel . + +FLAVOR=$1 +PACKAGE=libpst + +if [ ${FLAVOR} = emacs ]; then exit 0; fi + +echo install/${PACKAGE}: Handling install for emacsen flavor ${FLAVOR} + +#FLAVORTEST=`echo $FLAVOR | cut -c-6` +#if [ ${FLAVORTEST} = xemacs ] ; then +# SITEFLAG="-no-site-file" +#else +# SITEFLAG="--no-site-file" +#fi +FLAGS="${SITEFLAG} -q -batch -l path.el -f batch-byte-compile" + +ELDIR=/usr/share/emacs/site-lisp/${PACKAGE} +ELCDIR=/usr/share/${FLAVOR}/site-lisp/${PACKAGE} + +# Install-info-altdir does not actually exist. +# Maybe somebody will write it. +if test -x /usr/sbin/install-info-altdir; then + echo install/${PACKAGE}: install Info links for ${FLAVOR} + install-info-altdir --quiet --section "" "" --dirname=${FLAVOR} /usr/info/${PACKAGE}.info.gz +fi + +install -m 755 -d ${ELCDIR} +cd ${ELDIR} +FILES=`echo *.el` +cp ${FILES} ${ELCDIR} +cd ${ELCDIR} + +cat << EOF > path.el +(setq load-path (cons "." load-path) byte-compile-warnings nil) +EOF +${FLAVOR} ${FLAGS} ${FILES} +rm -f *.el path.el + +exit 0 diff -r 87216aefc6df -r 535075b4d261 debian/emacsen-remove.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/emacsen-remove.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,15 @@ +#!/bin/sh -e +# /usr/lib/emacsen-common/packages/remove/libpst + +FLAVOR=$1 +PACKAGE=libpst + +if [ ${FLAVOR} != emacs ]; then + if test -x /usr/sbin/install-info-altdir; then + echo remove/${PACKAGE}: removing Info links for ${FLAVOR} + install-info-altdir --quiet --remove --dirname=${FLAVOR} /usr/info/libpst.info.gz + fi + + echo remove/${PACKAGE}: purging byte-compiled files for ${FLAVOR} + rm -rf /usr/share/${FLAVOR}/site-lisp/${PACKAGE} +fi diff -r 87216aefc6df -r 535075b4d261 debian/emacsen-startup.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/emacsen-startup.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,25 @@ +;; -*-emacs-lisp-*- +;; +;; Emacs startup file, e.g. /etc/emacs/site-start.d/50libpst.el +;; for the Debian libpst package +;; +;; Originally contributed by Nils Naumann +;; Modified by Dirk Eddelbuettel +;; Adapted for dh-make by Jim Van Zandt + +;; The libpst package follows the Debian/GNU Linux 'emacsen' policy and +;; byte-compiles its elisp files for each 'emacs flavor' (emacs19, +;; xemacs19, emacs20, xemacs20...). The compiled code is then +;; installed in a subdirectory of the respective site-lisp directory. +;; We have to add this to the load-path: +(let ((package-dir (concat "/usr/share/" + (symbol-name flavor) + "/site-lisp/libpst"))) +;; If package-dir does not exist, the libpst package must have +;; removed but not purged, and we should skip the setup. + (when (file-directory-p package-dir) + (setq load-path (cons package-dir load-path)) + (autoload 'libpst-mode "libpst-mode" + "Major mode for editing libpst files." t) + (add-to-list 'auto-mode-alist '("\\.libpst$" . libpst-mode)))) + diff -r 87216aefc6df -r 535075b4d261 debian/init.d.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/init.d.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,81 @@ +#! /bin/sh +# +# skeleton example file to build /etc/init.d/ scripts. +# This file should be used to construct scripts for /etc/init.d. +# +# Written by Miquel van Smoorenburg . +# Modified for Debian +# by Ian Murdock . +# +# Version: @(#)skeleton 1.9 26-Feb-2001 miquels@cistron.nl +# + +PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin +DAEMON=/usr/sbin/libpst +NAME=libpst +DESC=libpst + +test -x $DAEMON || exit 0 + +# Include libpst defaults if available +if [ -f /etc/default/libpst ] ; then + . /etc/default/libpst +fi + +set -e + +case "$1" in + start) + echo -n "Starting $DESC: " + start-stop-daemon --start --quiet --pidfile /var/run/$NAME.pid \ + --exec $DAEMON -- $DAEMON_OPTS + echo "$NAME." + ;; + stop) + echo -n "Stopping $DESC: " + start-stop-daemon --stop --quiet --pidfile /var/run/$NAME.pid \ + --exec $DAEMON + echo "$NAME." + ;; + #reload) + # + # If the daemon can reload its config files on the fly + # for example by sending it SIGHUP, do it here. + # + # If the daemon responds to changes in its config file + # directly anyway, make this a do-nothing entry. + # + # echo "Reloading $DESC configuration files." + # start-stop-daemon --stop --signal 1 --quiet --pidfile \ + # /var/run/$NAME.pid --exec $DAEMON + #;; + force-reload) + # + # If the "reload" option is implemented, move the "force-reload" + # option to the "reload" entry above. If not, "force-reload" is + # just the same as "restart" except that it does nothing if the + # daemon isn't already running. + # check wether $DAEMON is running. If so, restart + start-stop-daemon --stop --test --quiet --pidfile \ + /var/run/$NAME.pid --exec $DAEMON \ + && $0 restart \ + || exit 0 + ;; + restart) + echo -n "Restarting $DESC: " + start-stop-daemon --stop --quiet --pidfile \ + /var/run/$NAME.pid --exec $DAEMON + sleep 1 + start-stop-daemon --start --quiet --pidfile \ + /var/run/$NAME.pid --exec $DAEMON -- $DAEMON_OPTS + echo "$NAME." + ;; + *) + N=/etc/init.d/$NAME + # echo "Usage: $N {start|stop|restart|reload|force-reload}" >&2 + echo "Usage: $N {start|stop|restart|force-reload}" >&2 + exit 1 + ;; +esac + +exit 0 diff -r 87216aefc6df -r 535075b4d261 debian/libpst-default.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/libpst-default.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,10 @@ +# Defaults for libpst initscript +# sourced by /etc/init.d/libpst +# installed at /etc/default/libpst by the maintainer scripts + +# +# This is a POSIX shell fragment +# + +# Additional options that are passed to the Daemon. +DAEMON_OPTS="" diff -r 87216aefc6df -r 535075b4d261 debian/libpst.dirs --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/libpst.dirs Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,3 @@ +usr/bin +usr/share/man/man1 +usr/share/man/man5 diff -r 87216aefc6df -r 535075b4d261 debian/libpst.doc-base.EX --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/libpst.doc-base.EX Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,22 @@ +Document: libpst +Title: Debian libpst Manual +Author: +Abstract: This manual describes what libpst is + and how it can be used to + manage online manuals on Debian systems. +Section: unknown + +Format: debiandoc-sgml +Files: /usr/share/doc/libpst/libpst.sgml.gz + +Format: postscript +Files: /usr/share/doc/libpst/libpst.ps.gz + +Format: text +Files: /usr/share/doc/libpst/libpst.text.gz + +Format: HTML +Index: /usr/share/doc/libpst/html/index.html +Files: /usr/share/doc/libpst/html/*.html + + diff -r 87216aefc6df -r 535075b4d261 debian/libpst.docs --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/libpst.docs Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,6 @@ +AUTHORS +COPYING +INSTALL +NEWS +README +TODO diff -r 87216aefc6df -r 535075b4d261 debian/libpst.install --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/libpst.install Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,3 @@ +usr/bin/* +usr/share/man/man1/* +usr/share/man/man5/* diff -r 87216aefc6df -r 535075b4d261 debian/manpage.1.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/manpage.1.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,59 @@ +.\" Hey, EMACS: -*- nroff -*- +.\" First parameter, NAME, should be all caps +.\" Second parameter, SECTION, should be 1-8, maybe w/ subsection +.\" other parameters are allowed: see man(7), man(1) +.TH LIBPST SECTION "May 29, 2008" +.\" Please adjust this date whenever revising the manpage. +.\" +.\" Some roff macros, for reference: +.\" .nh disable hyphenation +.\" .hy enable hyphenation +.\" .ad l left justify +.\" .ad b justify to both left and right margins +.\" .nf disable filling +.\" .fi enable filling +.\" .br insert line break +.\" .sp insert n+1 empty lines +.\" for manpage-specific macros, see man(7) +.SH NAME +libpst \- program to do something +.SH SYNOPSIS +.B libpst +.RI [ options ] " files" ... +.br +.B bar +.RI [ options ] " files" ... +.SH DESCRIPTION +This manual page documents briefly the +.B libpst +and +.B bar +commands. +.PP +.\" TeX users may be more comfortable with the \fB\fP and +.\" \fI\fP escape sequences to invode bold face and italics, +.\" respectively. +\fBlibpst\fP is a program that... +.SH OPTIONS +These programs follow the usual GNU command line syntax, with long +options starting with two dashes (`-'). +A summary of options is included below. +For a complete description, see the Info files. +.TP +.B \-h, \-\-help +Show summary of options. +.TP +.B \-v, \-\-version +Show version of program. +.SH SEE ALSO +.BR bar (1), +.BR baz (1). +.br +The programs are documented fully by +.IR "The Rise and Fall of a Fooish Bar" , +available via the Info system. +.SH AUTHOR +libpst was written by . +.PP +This manual page was written by Joachim Metz , +for the Debian project (but may be used by others). diff -r 87216aefc6df -r 535075b4d261 debian/manpage.sgml.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/manpage.sgml.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,156 @@ + manpage.1'. You may view + the manual page with: `docbook-to-man manpage.sgml | nroff -man | + less'. A typical entry in a Makefile or Makefile.am is: + +manpage.1: manpage.sgml + docbook-to-man $< > $@ + + + The docbook-to-man binary is found in the docbook-to-man package. + Please remember that if you create the nroff version in one of the + debian/rules file targets (such as build), you will need to include + docbook-to-man in your Build-Depends control field. + + --> + + + FIRSTNAME"> + SURNAME"> + + May 29, 2008"> + + SECTION"> + forensics@hoffmannbv.nl"> + + LIBPST"> + + + Debian"> + GNU"> + GPL"> +]> + + + +
+ &dhemail; +
+ + &dhfirstname; + &dhsurname; + + + 2003 + &dhusername; + + &dhdate; +
+ + &dhucpackage; + + &dhsection; + + + &dhpackage; + + program to do something + + + + &dhpackage; + + + + + + + + DESCRIPTION + + This manual page documents briefly the + &dhpackage; and bar + commands. + + This manual page was written for the &debian; distribution + because the original program does not have a manual page. + Instead, it has documentation in the &gnu; + Info format; see below. + + &dhpackage; is a program that... + + + + OPTIONS + + These programs follow the usual &gnu; command line syntax, + with long options starting with two dashes (`-'). A summary of + options is included below. For a complete description, see the + Info files. + + + + + + + + Show summary of options. + + + + + + + + Show version of program. + + + + + + SEE ALSO + + bar (1), baz (1). + + The programs are documented fully by The Rise and + Fall of a Fooish Bar available via the + Info system. + + + AUTHOR + + This manual page was written by &dhusername; &dhemail; for + the &debian; system (but may be used by others). Permission is + granted to copy, distribute and/or modify this document under + the terms of the &gnu; General Public License, Version 2 any + later version published by the Free Software Foundation. + + + On Debian systems, the complete text of the GNU General Public + License can be found in /usr/share/common-licenses/GPL. + + + +
+ + + + diff -r 87216aefc6df -r 535075b4d261 debian/manpage.xml.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/manpage.xml.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,148 @@ + +.
will be generated. You may view the +manual page with: nroff -man .
| less'. A +typical entry in a Makefile or Makefile.am is: + +DB2MAN=/usr/share/sgml/docbook/stylesheet/xsl/nwalsh/\ +manpages/docbook.xsl +XP=xsltproc -''-nonet + +manpage.1: manpage.dbk + $(XP) $(DB2MAN) $< + +The xsltproc binary is found in the xsltproc package. The +XSL files are in docbook-xsl. Please remember that if you +create the nroff version in one of the debian/rules file +targets (such as build), you will need to include xsltproc +and docbook-xsl in your Build-Depends control field. + +--> + + + FIRSTNAME"> + SURNAME"> + + May 29, 2008"> + + SECTION"> + forensics@hoffmannbv.nl"> + + LIBPST"> + + + Debian"> + GNU"> + GPL"> +]> + + + +
+ &dhemail; +
+ + &dhfirstname; + &dhsurname; + + + 2003 + &dhusername; + + &dhdate; +
+ + &dhucpackage; + + &dhsection; + + + &dhpackage; + + program to do something + + + + &dhpackage; + + + + + + + + DESCRIPTION + + This manual page documents briefly the + &dhpackage; and bar + commands. + + This manual page was written for the &debian; distribution + because the original program does not have a manual page. + Instead, it has documentation in the &gnu; + Info format; see below. + + &dhpackage; is a program that... + + + + OPTIONS + + These programs follow the usual &gnu; command line syntax, + with long options starting with two dashes (`-'). A summary of + options is included below. For a complete description, see the + Info files. + + + + + + + + Show summary of options. + + + + + + + + Show version of program. + + + + + + SEE ALSO + + bar (1), baz (1). + + The programs are documented fully by The Rise and + Fall of a Fooish Bar available via the + Info system. + + + AUTHOR + + This manual page was written by &dhusername; &dhemail; for + the &debian; system (but may be used by others). Permission is + granted to copy, distribute and/or modify this document under + the terms of the &gnu; General Public License, Version 2 any + later version published by the Free Software Foundation. + + + On Debian systems, the complete text of the GNU General Public + License can be found in /usr/share/common-licenses/GPL. + + + +
+ diff -r 87216aefc6df -r 535075b4d261 debian/menu.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/menu.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,2 @@ +?package(libpst):needs="X11|text|vc|wm" section="Apps/see-menu-manual"\ + title="libpst" command="/usr/bin/libpst" diff -r 87216aefc6df -r 535075b4d261 debian/postinst.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/postinst.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,41 @@ +#!/bin/sh +# postinst script for libpst +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `configure' +# * `abort-upgrade' +# * `abort-remove' `in-favour' +# +# * `abort-remove' +# * `abort-deconfigure' `in-favour' +# `removing' +# +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + configure) + ;; + + abort-upgrade|abort-remove|abort-deconfigure) + ;; + + *) + echo "postinst called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 + + diff -r 87216aefc6df -r 535075b4d261 debian/postrm.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/postrm.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,39 @@ +#!/bin/sh +# postrm script for libpst +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `remove' +# * `purge' +# * `upgrade' +# * `failed-upgrade' +# * `abort-install' +# * `abort-install' +# * `abort-upgrade' +# * `disappear' +# +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + purge|remove|upgrade|failed-upgrade|abort-install|abort-upgrade|disappear) + ;; + + *) + echo "postrm called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 + + diff -r 87216aefc6df -r 535075b4d261 debian/preinst.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/preinst.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,37 @@ +#!/bin/sh +# preinst script for libpst +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `install' +# * `install' +# * `upgrade' +# * `abort-upgrade' +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + install|upgrade) + ;; + + abort-upgrade) + ;; + + *) + echo "preinst called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 + + diff -r 87216aefc6df -r 535075b4d261 debian/prerm.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/prerm.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,40 @@ +#!/bin/sh +# prerm script for libpst +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `remove' +# * `upgrade' +# * `failed-upgrade' +# * `remove' `in-favour' +# * `deconfigure' `in-favour' +# `removing' +# +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + remove|upgrade|deconfigure) + ;; + + failed-upgrade) + ;; + + *) + echo "prerm called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 + + diff -r 87216aefc6df -r 535075b4d261 debian/rules --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/rules Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,137 @@ +#!/usr/bin/make -f +# -*- makefile -*- +# Sample debian/rules that uses debhelper. +# +# This file was originally written by Joey Hess and Craig Small. +# As a special exception, when this file is copied by dh-make into a +# dh-make output file, you may use that output file without restriction. +# This special exception was added by Craig Small in version 0.37 of dh-make. +# +# Modified to make a template file for a multi-binary package with separated +# build-arch and build-indep targets by Bill Allombert 2001 + +# Uncomment this to turn on verbose mode. +#export DH_VERBOSE=1 + +# This has to be exported to make some magic below work. +export DH_OPTIONS + +# These are used for cross-compiling and for saving the configure script +# from having to guess our platform (since we know it already) +DEB_HOST_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE) +DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE) + + +CFLAGS = -Wall -g + +ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS))) + CFLAGS += -O0 +else + CFLAGS += -O2 +endif + +config.status: configure + dh_testdir + # Add here commands to configure the package. + ./configure --host=$(DEB_HOST_GNU_TYPE) --build=$(DEB_BUILD_GNU_TYPE) --prefix=/usr --mandir=\$${prefix}/share/man --infodir=\$${prefix}/share/info CFLAGS="$(CFLAGS)" LDFLAGS="-Wl,-z,defs" + + +#Architecture +build: build-arch build-indep + +build-arch: build-arch-stamp +build-arch-stamp: config.status + + # Add here commands to compile the arch part of the package. + #$(MAKE) + touch $@ + +build-indep: build-indep-stamp +build-indep-stamp: config.status + + # Add here commands to compile the indep part of the package. + #$(MAKE) doc + touch $@ + +clean: + dh_testdir + dh_testroot + rm -f build-arch-stamp build-indep-stamp #CONFIGURE-STAMP# + + # Add here commands to clean up after the build process. + -$(MAKE) distclean +ifneq "$(wildcard /usr/share/misc/config.sub)" "" + cp -f /usr/share/misc/config.sub config.sub +endif +ifneq "$(wildcard /usr/share/misc/config.guess)" "" + cp -f /usr/share/misc/config.guess config.guess +endif + + + dh_clean + +install: install-indep install-arch +install-indep: + dh_testdir + dh_testroot + dh_clean -k -i + dh_installdirs -i + + # Add here commands to install the indep part of the package into + # debian/-doc. + #INSTALLDOC# + + dh_install -i + +install-arch: + dh_testdir + dh_testroot + dh_clean -k -s + dh_installdirs -s + + # Add here commands to install the arch part of the package into + # debian/tmp. + $(MAKE) DESTDIR=$(CURDIR)/debian/tmp install + + dh_install -s --list-missing --sourcedir=$(CURDIR)/debian/tmp +# Must not depend on anything. This is to be called by +# binary-arch/binary-indep +# in another 'make' thread. +binary-common: + dh_testdir + dh_testroot + dh_installchangelogs ChangeLog + dh_installdocs + dh_installexamples +# dh_installmenu +# dh_installdebconf +# dh_installlogrotate +# dh_installemacsen +# dh_installpam +# dh_installmime +# dh_python +# dh_installinit +# dh_installcron + dh_installinfo + dh_installman + dh_link + dh_strip + dh_compress + dh_fixperms +# dh_perl + dh_makeshlibs -V + dh_installdeb + dh_shlibdeps -L libpst -l debian/tmp/usr/lib + dh_gencontrol + dh_md5sums + dh_builddeb +# Build architecture independant packages using the common target. +binary-indep: build-indep install-indep + $(MAKE) -f debian/rules DH_OPTIONS=-i binary-common + +# Build architecture dependant packages using the common target. +binary-arch: build-arch install-arch + $(MAKE) -f debian/rules DH_OPTIONS=-s binary-common + +binary: binary-arch binary-indep +.PHONY: build clean binary-indep binary-arch binary install install-indep install-arch diff -r 87216aefc6df -r 535075b4d261 debian/watch.ex --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/debian/watch.ex Tue Jun 10 14:28:55 2008 -0700 @@ -0,0 +1,22 @@ +# Example watch control file for uscan +# Rename this file to "watch" and then you can run the "uscan" command +# to check for upstream updates and more. +# See uscan(1) for format + +# Compulsory line, this is a version 3 file +version=3 + +# Uncomment to examine a Webpage +# +#http://www.example.com/downloads.php libpst-(.*)\.tar\.gz + +# Uncomment to examine a Webserver directory +#http://www.example.com/pub/libpst-(.*)\.tar\.gz + +# Uncommment to examine a FTP server +#ftp://ftp.example.com/pub/libpst-(.*)\.tar\.gz debian uupdate + +# Uncomment to find new files on sourceforge, for debscripts >= 2.9 +# http://sf.net/libpst/libpst-(.*)\.tar\.gz + + diff -r 87216aefc6df -r 535075b4d261 libpst.spec.in --- a/libpst.spec.in Sat Jun 07 15:53:08 2008 -0700 +++ b/libpst.spec.in Tue Jun 10 14:28:55 2008 -0700 @@ -47,6 +47,10 @@ %changelog +* Tue Jun 10 2008 Carl Byington - 0.6.12-1 +- Patch from Joachim Metz for debian packaging and +- fix for incorrect length on lz decompression + * Tue Jun 03 2008 Carl Byington - 0.6.11-1 - Use ftello/fseeko to properly handle large files. - Document and properly use datasize field in b5 blocks. diff -r 87216aefc6df -r 535075b4d261 src/lzfu.c --- a/src/lzfu.c Sat Jun 07 15:53:08 2008 -0700 +++ b/src/lzfu.c Tue Jun 10 14:28:55 2008 -0700 @@ -70,10 +70,12 @@ //printf("compressed: %s\n", (lzfuhdr.dwMagic == LZFU_COMPRESSED ? "yes" : "no")); //printf("CRC : %#x\n", lzfuhdr.dwCRC); //printf("\n"); - out_size = lzfuhdr.cbRawSize + 3; // two braces and a null terminator + out_size = lzfuhdr.cbRawSize; out_buf = (char*)xmalloc(out_size); in_ptr = sizeof(lzfuhdr); - in_size = (lzfuhdr.cbSize < compsize) ? lzfuhdr.cbSize : compsize; + // Make sure to correct lzfuhdr.cbSize with 4 bytes before comparing + // to compsize + in_size = (lzfuhdr.cbSize + 4 < compsize) ? lzfuhdr.cbSize + 4 : compsize; while (in_ptr < in_size) { flags = (unsigned char)(rtfcomp[in_ptr++]); flag_mask = 1; @@ -100,6 +102,9 @@ dict[dict_length]=c1; dict_length = (dict_length+1) % 4096; if (out_ptr < out_size) out_buf[out_ptr++] = (char)c1; + // required for dictionary wrap around + // otherwise 0 byte values are referenced incorrectly + dict[dict_length] = 0; } } } else { @@ -110,16 +115,14 @@ dict[dict_length] = c1; dict_length = (dict_length+1)%4096; if (out_ptr < out_size) out_buf[out_ptr++] = (char)c1; + // required for dictionary wrap around + // otherwise 0 byte values are referenced incorrect + dict[dict_length] = 0; } } flag_mask <<= 1; } } - // the compressed version doesn't appear to drop the closing - // braces onto the doc, so we do that here. - if (out_ptr < out_size) out_buf[out_ptr++] = '}'; - if (out_ptr < out_size) out_buf[out_ptr++] = '}'; - *size = out_ptr; - if (out_ptr < out_size) out_buf[out_ptr++] = '\0'; + // the RTF data is terminated with }}\0\0 return out_buf; }