diff --git a/debian/README.Debian b/debian/README.Debian new file mode 100644 index 0000000..62c030b --- /dev/null +++ b/debian/README.Debian @@ -0,0 +1,6 @@ +drprint for Debian +------------------ + +<possible notes regarding this package - if none, delete this file> + + -- Leonardo Robol <leo@robol.it> Thu, 15 Oct 2009 10:39:41 +0200 diff --git a/debian/changelog b/debian/changelog new file mode 100644 index 0000000..2d91e43 --- /dev/null +++ b/debian/changelog @@ -0,0 +1,19 @@ +drprint (0.6-3) karmic; urgency=low + + * Cambiato il metodo per ottenere il nome utente + + -- Leonardo Robol <leonardo@debby> Thu, 15 Oct 2009 11:18:11 +0200 + +drprint (0.6-2) unstable; urgency=low + + * Modificato il file .desktop in modo che appaia anche in Accessori + + -- Leonardo Robol <leonardo@debby> Thu, 15 Oct 2009 10:59:52 +0200 + +drprint (0.6-1) unstable; urgency=low + + * Initial release (Closes: #nnnn) <nnnn is the bug number of your ITP> + * Chuido il bug quando si selezionava un range di stampa + * Aggiunta l'immagine di drprint + + -- Leonardo Robol <leonardo@debby> Thu, 15 Oct 2009 10:47:21 +0200 diff --git a/debian/compat b/debian/compat new file mode 100644 index 0000000..7f8f011 --- /dev/null +++ b/debian/compat @@ -0,0 +1 @@ +7 diff --git a/debian/control b/debian/control new file mode 100644 index 0000000..6b8cf49 --- /dev/null +++ b/debian/control @@ -0,0 +1,15 @@ +Source: drprint +Section: unknown +Priority: extra +Maintainer: Leonardo Robol <leo@robol.it> +Build-Depends: debhelper (>= 7) +Standards-Version: 3.8.1 +Homepage: <insert the upstream URL, if relevant> + +Package: drprint +Architecture: all +Depends: ${misc:Depends} +Description: Interfaccia GTK per stampare sulle stampanti di dm.unipi.it + Interfaccia GTK che permette di mandare in stampa file + ps e pdf sulle stampanti del dipartimento di matematica + a Pisa a patto di avere accesso SSH al server ssh.dm.unipi.it diff --git a/debian/copyright b/debian/copyright new file mode 100644 index 0000000..c48f1c2 --- /dev/null +++ b/debian/copyright @@ -0,0 +1,44 @@ +This package was debianized by: + + Leonardo Robol <leo@robol.it> on Thu, 15 Oct 2009 10:39:41 +0200 + +It was downloaded from: + + <url://example.com> + +Upstream Author(s): + + <put author's name and email here> + <likewise for another author> + +Copyright: + + <Copyright (C) YYYY Firstname Lastname> + <likewise for another author> + +License: + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This package is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. + +On Debian systems, the complete text of the GNU General +Public License version 3 can be found in `/usr/share/common-licenses/GPL-3'. + +The Debian packaging is: + + Copyright (C) 2009 Leonardo Robol <leo@robol.it> + +and is licensed under the GPL version 3, see above. + +# Please also look if there are files or directories which have a +# different copyright/license attached and list them here. diff --git a/debian/cron.d.ex b/debian/cron.d.ex new file mode 100644 index 0000000..3bec3a4 --- /dev/null +++ b/debian/cron.d.ex @@ -0,0 +1,4 @@ +# +# Regular cron jobs for the drprint package +# +0 4 * * * root [ -x /usr/bin/drprint_maintenance ] && /usr/bin/drprint_maintenance diff --git a/debian/dirs b/debian/dirs new file mode 100644 index 0000000..ca882bb --- /dev/null +++ b/debian/dirs @@ -0,0 +1,2 @@ +usr/bin +usr/sbin diff --git a/debian/docs b/debian/docs new file mode 100644 index 0000000..e69de29 diff --git a/debian/drprint.debhelper.log b/debian/drprint.debhelper.log new file mode 100644 index 0000000..02a3317 --- /dev/null +++ b/debian/drprint.debhelper.log @@ -0,0 +1,65 @@ +dh_prep +dh_installdirs +dh_installchangelogs +dh_installdocs +dh_installexamples +dh_installman +dh_link +dh_compress +dh_fixperms +dh_installdeb +dh_gencontrol +dh_md5sums +dh_builddeb +dh_prep +dh_installdirs +dh_installchangelogs +dh_installdocs +dh_installexamples +dh_installman +dh_link +dh_compress +dh_fixperms +dh_installdeb +dh_gencontrol +dh_md5sums +dh_builddeb +dh_prep +dh_installdirs +dh_installchangelogs +dh_installdocs +dh_installexamples +dh_installman +dh_link +dh_compress +dh_fixperms +dh_installdeb +dh_gencontrol +dh_md5sums +dh_builddeb +dh_prep +dh_installdirs +dh_installchangelogs +dh_installdocs +dh_installexamples +dh_installman +dh_link +dh_compress +dh_fixperms +dh_installdeb +dh_gencontrol +dh_md5sums +dh_builddeb +dh_prep +dh_installdirs +dh_installchangelogs +dh_installdocs +dh_installexamples +dh_installman +dh_link +dh_compress +dh_fixperms +dh_installdeb +dh_gencontrol +dh_md5sums +dh_builddeb diff --git a/debian/drprint.default.ex b/debian/drprint.default.ex new file mode 100644 index 0000000..368eb66 --- /dev/null +++ b/debian/drprint.default.ex @@ -0,0 +1,10 @@ +# Defaults for drprint initscript +# sourced by /etc/init.d/drprint +# installed at /etc/default/drprint by the maintainer scripts + +# +# This is a POSIX shell fragment +# + +# Additional options that are passed to the Daemon. +DAEMON_OPTS="" diff --git a/debian/drprint.doc-base.EX b/debian/drprint.doc-base.EX new file mode 100644 index 0000000..9987381 --- /dev/null +++ b/debian/drprint.doc-base.EX @@ -0,0 +1,20 @@ +Document: drprint +Title: Debian drprint Manual +Author: <insert document author here> +Abstract: This manual describes what drprint is + and how it can be used to + manage online manuals on Debian systems. +Section: unknown + +Format: debiandoc-sgml +Files: /usr/share/doc/drprint/drprint.sgml.gz + +Format: postscript +Files: /usr/share/doc/drprint/drprint.ps.gz + +Format: text +Files: /usr/share/doc/drprint/drprint.text.gz + +Format: HTML +Index: /usr/share/doc/drprint/html/index.html +Files: /usr/share/doc/drprint/html/*.html diff --git a/debian/drprint.substvars b/debian/drprint.substvars new file mode 100644 index 0000000..abd3ebe --- /dev/null +++ b/debian/drprint.substvars @@ -0,0 +1 @@ +misc:Depends= diff --git a/debian/drprint/DEBIAN/control b/debian/drprint/DEBIAN/control new file mode 100644 index 0000000..12daf37 --- /dev/null +++ b/debian/drprint/DEBIAN/control @@ -0,0 +1,12 @@ +Package: drprint +Version: 0.6-3 +Architecture: all +Maintainer: Leonardo Robol <leo@robol.it> +Installed-Size: 184 +Section: unknown +Priority: extra +Homepage: <insert the upstream URL, if relevant> +Description: Interfaccia GTK per stampare sulle stampanti di dm.unipi.it + Interfaccia GTK che permette di mandare in stampa file + ps e pdf sulle stampanti del dipartimento di matematica + a Pisa a patto di avere accesso SSH al server ssh.dm.unipi.it diff --git a/debian/drprint/DEBIAN/md5sums b/debian/drprint/DEBIAN/md5sums new file mode 100644 index 0000000..91e75c9 --- /dev/null +++ b/debian/drprint/DEBIAN/md5sums @@ -0,0 +1,18 @@ +210b7fdd83ad02e6844ca947e51b5b65 usr/share/doc/drprint/copyright +26c7ce37223627121a25054233df4b6b usr/share/doc/drprint/changelog.Debian.gz +fe6673b9521294403f77f7aa80e76e62 usr/share/doc/drprint/README.Debian +f7aa3012efd5b01be9c79d0639ec1350 usr/local/bin/drprint +ba8997cac5fea103ebd9d94ea8f3ca98 usr/local/lib/python2.6/dist-packages/DrPrintGui/Dialogs.py +2baa975a03736b1864533548e3ec92b5 usr/local/lib/python2.6/dist-packages/DrPrintGui/Input.py +bbabfe3bc2e2918a8fa6867b0b210ed1 usr/local/lib/python2.6/dist-packages/DrPrintGui/MainWin.py +ef21f631795819b8494c14938a3ab45e usr/local/lib/python2.6/dist-packages/DrPrintGui/Dialogs.pyc +d41d8cd98f00b204e9800998ecf8427e usr/local/lib/python2.6/dist-packages/DrPrintGui/__init__.py +30705d4ecde4b4de1f16a7ed9d30295c usr/local/lib/python2.6/dist-packages/DrPrintGui/__init__.pyc +371ce2b4d07ffed97380bbaada7f7a90 usr/local/lib/python2.6/dist-packages/DrPrintGui/MainWin.pyc +d01fa8ab27243b43006e416b8800e72f usr/local/lib/python2.6/dist-packages/DrPrintGui/Input.pyc +6e95598efbfcd3cedb2df0d55083d28e usr/local/lib/python2.6/dist-packages/DrPrintBackend.pyc +d017a23432b720ea110a28f498d2673a usr/local/lib/python2.6/dist-packages/DrPrintBackend.py +67ff218ed969602f5df1cc016298c2ad usr/local/lib/python2.6/dist-packages/DrPrint-0.3.egg-info +e7cd4902a940e3e4ddd25545ef6a34be usr/local/share/applications/drprint.desktop +267aed785f5614bab9a43ed7dfcb96bd usr/local/share/pixmaps/drprint.png +b4149fabeb9884087e0730bca5cb5073 usr/local/share/drprint/drprint_gui.png diff --git a/debian/drprint/usr/local/bin/drprint b/debian/drprint/usr/local/bin/drprint new file mode 100755 index 0000000..ce877e4 --- /dev/null +++ b/debian/drprint/usr/local/bin/drprint @@ -0,0 +1,27 @@ +#!/usr/bin/env python + +import gtk, pygtk +from DrPrintGui.MainWin import MainWin +from DrPrintBackend import Backend + +if __name__ == "__main__": + + + ## Load the Backend that will perform + ## all the hard work without being seen + ## by the end user. That is -- the sad + ## story of every backend. + backend = Backend() + + ## ...and then the main win! The one + ## that will try to attract end user + ## with her .. ( find a good word ) + ## P.S.: We give her a backend, without + ## it she will be useless. + mw = MainWin(backend) + + ## Show all :) + mw.show() + + ## ..and let's go! + gtk.main() diff --git a/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrint-0.3.egg-info b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrint-0.3.egg-info new file mode 100644 index 0000000..81bb9ff --- /dev/null +++ b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrint-0.3.egg-info @@ -0,0 +1,10 @@ +Metadata-Version: 1.0 +Name: DrPrint +Version: 0.3 +Summary: UNKNOWN +Home-page: http://www.robol.it/~leonardo/ +Author: Leonardo Robol +Author-email: leo@robol.it +License: GPL +Description: UNKNOWN +Platform: UNKNOWN diff --git a/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintBackend.py b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintBackend.py new file mode 100644 index 0000000..190f5f2 --- /dev/null +++ b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintBackend.py @@ -0,0 +1,90 @@ +## Some useful function to help DrPrint to +# -*- coding: utf-8 -*- + +import paramiko, gobject + +class Backend(gobject.GObject): + + def __init__(self): + super(Backend, self).__init__() + + gobject.signal_new("auth_failed", Backend, gobject.SIGNAL_RUN_FIRST, None, ()) + gobject.signal_new('io_error', Backend, gobject.SIGNAL_RUN_FIRST, None, ()) + + def send_print(self, printer, username, password, page_per_page, filename, page_range, copies, orientation, sides): + # Get printer name + print "Selected printer: %s" % printer + + # Get connection + client = paramiko.SSHClient() + client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) + + try: + client.connect('ssh.dm.unipi.it', + port=22, + username=username, + password=password) + except paramiko.AuthenticationException, e: + self.emit('auth_failed') + return + + channel = client.get_transport().open_session() + + print "Printing %s" % filename + + try: + f = open(filename, 'r') + except IOError: + self.emit('io_error') + return + + # Questo è inevitabile.. :) + cmd = "lpr -P%s " % printer + + # Nunmero di pagine + if copies.isdigit(): + cmd = cmd + "-# %s " % copies + + + cmd_opts = "" + + ## Pagine logiche per pagine + if not page_per_page == 1: + cmd_opts += "-o number-up=%s " % str(page_per_page) + + ## Da a + if not page_range == None: + cmd_opts += "-o page-ranges=%s " % page_range + + ## Orientazione (se è vuoto è verticale) + if not orientation == "": + cmd_opts += "-o %s " % orientation + + ## Long edge, short edge ed amici vari + cmd_opts += "-o sides=%s " % sides + + ## Se ci sono opzioni dai il -o e specificale + if not cmd_opts == "": + cmd = cmd + "%s" % cmd_opts + + + ## Diamo il comando sul canale e infiliamo il file + ## dentro lo stdin :) + print "Eseguo %s" % cmd + + channel.exec_command(cmd) + try: + content = f.read() + except IOError: + self.emit('io_error') + return + + try: + channel.sendall( content ) + except socket.timeout, socket.error: + self.emit('io_error') + return + f.close() + channel.close() + + print "Printed %s on %s" % (filename, printer) diff --git a/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/Dialogs.py b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/Dialogs.py new file mode 100644 index 0000000..9a632c9 --- /dev/null +++ b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/Dialogs.py @@ -0,0 +1,27 @@ +import gtk, pygtk + +class Dialog(gtk.Dialog): + + def __init__(self, title=None, buttons=None, text=None): + + gtk.Dialog.__init__(self, title, + None, + 0, + buttons) + + + +class ErrorDialog(Dialog): + + def __init__(self, error, message): + + Dialog.__init__(self, "Errore: %s" % error, + buttons = (gtk.STOCK_OK, gtk.RESPONSE_OK) + ) + + label = gtk.Label() + label.set_markup(message) + self.get_content_area().pack_start( label , False, False, 15 ) + label.show() + + diff --git a/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/Input.py b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/Input.py new file mode 100644 index 0000000..b008115 --- /dev/null +++ b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/Input.py @@ -0,0 +1,375 @@ +## This library provides User Input fields + +import gtk, pygtk, gobject, os + +class LeftAlignedLabel(gtk.Alignment): + + def __init__(self, markup, left_padding=0): + + gtk.Alignment.__init__(self, 0,0.5,0,0) + + label = gtk.Label() + label.set_markup(markup) + plw = PaddingLeftWidget(label, left_padding) + + self.add(plw) + plw.show() + +class PaddingLeftWidget(gtk.Table): + + def __init__(self, widget, padding_left): + + gtk.Table.__init__(self, 1, 2, False) + label = gtk.Label() + self.set_col_spacing(0, padding_left) + self.attach(label, 0,1,0,1, False, False) + self.attach(widget, 1,2,0,1, False, False) + + label.show() + widget.show() + + +class UsernameField(gtk.Entry): + + def __init__(self, parent=None): + + gtk.Entry.__init__(self) + + self.set_text( os.getenv("USER") ) + + +class PasswordField(gtk.Entry): + + def __init__(self, parent=None): + + gtk.Entry.__init__(self) + + self.set_text ("Password") + self.set_visibility(False) + +class AuthBlock(gtk.HBox): + + def __init__(self, default_spacing=5, left_padding=0): + + gtk.HBox.__init__(self) + + self.user_field = UsernameField() + self.password_field = PasswordField() + + vbox1 = gtk.VBox() + vbox2 = gtk.VBox() + + label = LeftAlignedLabel("Utente", 20) + vbox1.pack_start( label ) + label.show() + + label = LeftAlignedLabel("Password", 20) + vbox1.pack_start( label ) + label.show() + + vbox2.pack_start(self.user_field) + vbox2.pack_start(self.password_field) + + self.user_field.show() + self.password_field.show() + + self.pack_start(vbox1) + self.pack_start(vbox2) + + vbox1.show() + vbox2.show() + + def get_username(self): + return self.user_field.get_text() + + def get_password(self): + return self.password_field.get_text() + +class PrintButton(gtk.Button): + + def __init__(self, parent=None): + + gtk.Button.__init__(self, "Stampa") + + +class SelectFileWidget(gtk.HBox): + + def __init__(self): + gtk.HBox.__init__(self) + self.set_spacing (5) + + self.Filename = gtk.Entry() + self.Browser = gtk.Button("Sfoglia") + + self.Filename.set_tooltip_text("Se hai bisogno di stampare \ +da un programma clicca File -> Stampa -> Stampa su file e crea un \ +file .ps da selezionare qui") + + self.Browser.connect('clicked', self.SelectFile) + + self.pack_start(self.Filename, 1) + self.pack_start(self.Browser, 1) + self.Filename.show() + self.Browser.show() + + def SelectFile(self, window): + + chooser = gtk.FileChooserDialog( + title = "Seleziona file da stampare", + parent = None, + action=gtk.FILE_CHOOSER_ACTION_OPEN, + buttons=(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL, gtk.STOCK_OPEN, gtk.RESPONSE_OK) ) + if chooser.run() == gtk.RESPONSE_OK: + self.Filename.set_text(chooser.get_filename()) + + chooser.destroy() + + def GetFile(self): + return self.Filename.get_text() + + +class PrinterComboBox(gtk.HBox): + + def __init__(self): + + gtk.HBox.__init__(self) + self.combobox = gtk.combo_box_new_text() + self.combobox.append_text("cdc7") + self.combobox.append_text("cdcpt") + self.combobox.append_text("cdc8") + self.combobox.append_text("cdc4") + self.combobox.append_text("cdc9") + + self.combobox.set_active(1) + + self.pack_start( self.combobox ) + self.combobox.show() + + def get_printer(self): + return self.combobox.get_active_text() + + +class PagePerPageComboBox(gtk.HBox): + + def __init__(self): + gtk.HBox.__init__(self) + self.combobox = gtk.combo_box_new_text() + self.combobox.append_text("1") + self.combobox.append_text("2") + self.combobox.append_text("4") + + self.combobox.set_active(0) + + self.pack_start( self.combobox ) + self.combobox.show() + + def get_page_per_page(self): + return self.combobox.get_active_text() + +class PrinterSettingsBlock(gtk.HBox): + + def __init__(self, default_spacing = 5, left_padding=0): + + gtk.HBox.__init__(self) + + vbox1 = gtk.VBox(False, default_spacing) + vbox2 = gtk.VBox(False, default_spacing) + + self.set_spacing(default_spacing) + + label = LeftAlignedLabel("Stampante", 20) + vbox1.pack_start(label) + label.show() + + self.printer_chooser = PrinterComboBox() + vbox2.pack_start( self.printer_chooser ) + self.printer_chooser.show() + + label = LeftAlignedLabel("File", 20) + vbox1.pack_start( label ) + label.show() + + self.select_file_widget = SelectFileWidget() + vbox2.pack_start (self.select_file_widget) + self.select_file_widget.show() + + label = LeftAlignedLabel("Pagine per foglio", 20) + vbox1.pack_start(label) + label.show() + + self.page_per_page = PagePerPageComboBox() + vbox2.pack_start(self.page_per_page) + self.page_per_page.show() + + label = LeftAlignedLabel("Numero di copie", 20) + vbox1.pack_start(label) + label.show() + + self.copies = CopiesField() + vbox2.pack_start(self.copies) + self.copies.show() + + self.pack_start(vbox1) + self.pack_start(vbox2) + + vbox1.show() + vbox2.show() + + def get_filename(self): + return self.select_file_widget.GetFile() + + def get_printer(self): + return self.printer_chooser.get_printer() + + def get_page_per_page(self): + return self.page_per_page.get_page_per_page() + + def get_copies(self): + return self.copies.get_copies() + + + +class PageRangeBlock(gtk.VBox): + + def __init__(self): + + gtk.VBox.__init__(self) + + self.check_button = gtk.CheckButton("Stampa solo una parte del documento", + True) + + self.check_button.set_active(False) + + self.check_button.connect('clicked', self.check_button_callback) + + self.pack_start(self.check_button) + self.check_button.show() + + self.hbox = gtk.HBox() + + self.range_field = gtk.Entry() + self.range_field.set_tooltip_text("Indicare pagine e/o intervalli separati da virgole, ad esempio \"1,3-10,12,13,15-17\"") + + label = LeftAlignedLabel("Range di pagine", 20) + self.hbox.pack_start(label) + self.hbox.pack_start(self.range_field) + label.show() + + self.pack_start(self.hbox) + + self.range_field.show() + + self.hbox.show() + self.hbox.set_spacing( 5 ) + self.hbox.set_sensitive(False) + + def check_button_callback(self, obj): + + if self.check_button.get_active() == False: + self.hbox.set_sensitive(False) + else: + self.hbox.set_sensitive(True) + + def get_page_range(self): + + if self.check_button.get_active() == False: + return None + + return self.range_field.get_text() + + +class CopiesField(gtk.SpinButton): + + def __init__(self): + + gtk.SpinButton.__init__(self) + self.set_digits(0) + self.set_increments(1,10) + self.set_range(0,999) + self.set_value(1) + + def get_copies(self): + return str(self.get_value()) + + + +class OrientationSelect(gtk.HBox): + + def __init__(self): + + gtk.HBox.__init__(self) + + # Un etichetta per capire a cosa servono questi radio button + label = LeftAlignedLabel("Orientamento", 20) + self.pack_start( label ) + label.show() + + # I radio button :) + self.landscape = gtk.RadioButton(None, + "Orizzontale", + True) + + self.portrait = gtk.RadioButton(self.landscape, + "Verticale", + True) + self.pack_start(self.landscape) + self.pack_start(self.portrait) + + self.landscape.show () + self.portrait.show () + + self.portrait.set_active(True) + + def get_orientation(self): + + if self.landscape.get_active(): + return "landscape" + + if self.portrait.get_active(): + return "" + + ## Questo non dovrebbe succedere + return None + +class SidesSelect(gtk.VBox): + + def __init__(self): + + gtk.VBox.__init__(self) + + self.one_sided = gtk.RadioButton(None, + "Solo fronte", + True) + self.two_sided_short_edge = gtk.RadioButton(self.one_sided, + "Fronte retro sul lato corto", + True) + self.two_sided_long_edge = gtk.RadioButton(self.one_sided, + "Fronte retro sul lato lungo", + True) + + for widget in (self.one_sided, + self.two_sided_short_edge, + self.two_sided_long_edge) : + a = PaddingLeftWidget(widget, 20) + self.pack_start(a) + a.show() + + self.two_sided_long_edge.set_active(True) + + def get_sides_select(self): + + if( self.one_sided.get_active() ): + return "one-sided" + + if( self.two_sided_short_edge.get_active() ): + return "two-sided-short-edge" + + if( self.two_sided_long_edge.get_active() ): + return "two-sided-long-edge" + + + + + + + diff --git a/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/MainWin.py b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/MainWin.py new file mode 100644 index 0000000..2993a05 --- /dev/null +++ b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/MainWin.py @@ -0,0 +1,178 @@ +## This library is part of DrPrintGui +# -*- coding: utf-8 -*- +## This file provide the MainWin object, +## that is the main window of the DrPrint +## application + + +__author__ = 'Leonardo Robol <leo@robol.it>' + +import gtk, pygtk +import os +import sys + +from Input import AuthBlock, PrinterSettingsBlock, PrintButton, LeftAlignedLabel, PageRangeBlock, OrientationSelect, SidesSelect +from Dialogs import ErrorDialog + +class MainWin(gtk.Window): + """MainWin object for DrPrint""" + + def __init__(self, backend=None): + + self.backend = backend + + gtk.Window.__init__(self, gtk.WINDOW_TOPLEVEL) + + self.set_title = "DrPrint 0.2" + self.set_border_width(10) + + self.default_spacing = 5 + + self.connect('destroy' , gtk.main_quit) + + self.build() + + self.connect_all() + + def build(self): + """This function builds up the interface using pieces + from DrPrintGui""" + + # The main Layout VBox + layout_box = gtk.VBox() + layout_box.set_spacing( self.default_spacing ) + + # Inseriamo l'immagine di Dr Print + image_file = "/usr/share/drprint/drprint_gui.png" + try: + os.stat(image_file) + except OSError: + image_file = "/usr/local/share/drprint/drprint_gui.png" + try: + os.stat(image_file) + except OSError: + image_file = "drprint_gui.png" + drprint_img = gtk.image_new_from_file(image_file) + + # Qualche istruzinoe preliminare + label = gtk.Label() + label.set_markup("<b>Come usare questo programma:</b>\n\ +<b>1)</b> Inserire nome utente e password \n<b>2)</b> Scegliere il file da stampare e la\ + stampante \n<b>3)</b> Premere il tasto stampa") + + hbox = gtk.HBox(); + hbox.show() + hbox.set_spacing(self.default_spacing) + + hbox.pack_start(drprint_img) + drprint_img.show() + + hbox.pack_start( label ) + label.show() + + layout_box.pack_start(hbox, 20) + + label = LeftAlignedLabel("<b>Autenticazione (sui computer dell'Aula 4)</b>") + layout_box.pack_start( label ) + label.show() + + self.auth_block = AuthBlock(self.default_spacing, 10) + layout_box.pack_start ( self.auth_block ) + self.auth_block.show() + + # The PDF file loading and print settings + label = LeftAlignedLabel("<b>Configurazione stampante</b>") + layout_box.pack_start(label) + label.show() + + self.printer_settings_block = PrinterSettingsBlock(self.default_spacing) + layout_box.pack_start(self.printer_settings_block) + self.printer_settings_block.show() + + self.orientation_select = OrientationSelect() + layout_box.pack_start(self.orientation_select) + self.orientation_select.show() + + label = LeftAlignedLabel("<b>Configurazione Avanzata</b>") + layout_box.pack_start(label) + label.show() + + self.page_range_block = PageRangeBlock() + layout_box.pack_start(self.page_range_block) + self.page_range_block.show() + + label = LeftAlignedLabel( "<b>Fronte retro</b>" ) + layout_box.pack_start(label) + label.show() + + self.sides_select = SidesSelect() + layout_box.pack_start(self.sides_select) + self.sides_select.show() + + self.print_button = PrintButton() + layout_box.pack_start(self.print_button) + self.print_button.show() + + + self.add (layout_box) + layout_box.show() + + + def connect_all(self): + self.print_button.connect('clicked', self.print_button_clicked_callback) + self.backend.connect('auth_failed', self.auth_failed_callback) + self.backend.connect('io_error', self.io_error_callback) + + def print_button_clicked_callback(self, widget): + if not self.backend == None: + printer = self.printer_settings_block.get_printer() + username = self.auth_block.get_username() + password = self.auth_block.get_password() + filename = self.printer_settings_block.get_filename() + page_per_page = self.printer_settings_block.get_page_per_page() + page_range = self.page_range_block.get_page_range() + copies = self.printer_settings_block.get_copies() + orientation = self.orientation_select.get_orientation() + sides = self.sides_select.get_sides_select() + + self.backend.send_print(printer = printer, + username = username, + password = password, + filename = filename, + page_per_page = page_per_page, + page_range = page_range, + copies = copies, + orientation=orientation, + sides = sides) + else: + self.debug( "Sembra che non ci sia un backend attaccato\ + a questa interfaccia, quindi non faccio nulla") + + def auth_failed_callback(self, obj): + """Questa funzione gestisce l'eventualità che utente + e password siano errati""" + self.debug("Autenticazione fallita") + dialog = ErrorDialog("Autenticazione Fallita", + "<b>Autenticazione Fallita</b>\nLo username e la password forniti non sono\n\ +corretti. L'autenticazione su ssh.dm.unipi.it\nnon è andata a buon fine.") + dialog.run() + dialog.destroy() + + def io_error_callback(self, obj): + + self.debug("Errore di I/O") + dialog = ErrorDialog("Errore di I/O", + "<b>Errore di I/O</b>\n\ +C'è stato un errore nella lettura o nella\n \ +trasmissione del file.") + + dialog.run() + dialog.destroy() + + + + def debug(self, text): + print text + + + diff --git a/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/__init__.py b/debian/drprint/usr/local/lib/python2.6/dist-packages/DrPrintGui/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/debian/drprint/usr/local/share/applications/drprint.desktop b/debian/drprint/usr/local/share/applications/drprint.desktop new file mode 100644 index 0000000..7cd2777 --- /dev/null +++ b/debian/drprint/usr/local/share/applications/drprint.desktop @@ -0,0 +1,11 @@ +[Desktop Entry] +Encoding=UTF-8 +Name=DrPrint +Comment[it]=Stampa sulle stampanti della rete dm.unipi.it +Comment[en]= Print using dm.unipi.it network printers +Exec=drprint +Terminal=false +Type=Application +StartupNotify=false +Categories=GNOME;Utility +Icon=drprint diff --git a/debian/drprint/usr/local/share/drprint/drprint_gui.png b/debian/drprint/usr/local/share/drprint/drprint_gui.png new file mode 100644 index 0000000..308bead Binary files /dev/null and b/debian/drprint/usr/local/share/drprint/drprint_gui.png differ diff --git a/debian/drprint/usr/local/share/pixmaps/drprint.png b/debian/drprint/usr/local/share/pixmaps/drprint.png new file mode 100644 index 0000000..e30589e Binary files /dev/null and b/debian/drprint/usr/local/share/pixmaps/drprint.png differ diff --git a/debian/drprint/usr/share/doc/drprint/README.Debian b/debian/drprint/usr/share/doc/drprint/README.Debian new file mode 100644 index 0000000..62c030b --- /dev/null +++ b/debian/drprint/usr/share/doc/drprint/README.Debian @@ -0,0 +1,6 @@ +drprint for Debian +------------------ + +<possible notes regarding this package - if none, delete this file> + + -- Leonardo Robol <leo@robol.it> Thu, 15 Oct 2009 10:39:41 +0200 diff --git a/debian/drprint/usr/share/doc/drprint/changelog.Debian.gz b/debian/drprint/usr/share/doc/drprint/changelog.Debian.gz new file mode 100644 index 0000000..c4278a7 Binary files /dev/null and b/debian/drprint/usr/share/doc/drprint/changelog.Debian.gz differ diff --git a/debian/drprint/usr/share/doc/drprint/copyright b/debian/drprint/usr/share/doc/drprint/copyright new file mode 100644 index 0000000..c48f1c2 --- /dev/null +++ b/debian/drprint/usr/share/doc/drprint/copyright @@ -0,0 +1,44 @@ +This package was debianized by: + + Leonardo Robol <leo@robol.it> on Thu, 15 Oct 2009 10:39:41 +0200 + +It was downloaded from: + + <url://example.com> + +Upstream Author(s): + + <put author's name and email here> + <likewise for another author> + +Copyright: + + <Copyright (C) YYYY Firstname Lastname> + <likewise for another author> + +License: + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This package is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. + +On Debian systems, the complete text of the GNU General +Public License version 3 can be found in `/usr/share/common-licenses/GPL-3'. + +The Debian packaging is: + + Copyright (C) 2009 Leonardo Robol <leo@robol.it> + +and is licensed under the GPL version 3, see above. + +# Please also look if there are files or directories which have a +# different copyright/license attached and list them here. diff --git a/debian/emacsen-install.ex b/debian/emacsen-install.ex new file mode 100644 index 0000000..88fda77 --- /dev/null +++ b/debian/emacsen-install.ex @@ -0,0 +1,45 @@ +#! /bin/sh -e +# /usr/lib/emacsen-common/packages/install/drprint + +# Written by Jim Van Zandt <jrv@debian.org>, borrowing heavily +# from the install scripts for gettext by Santiago Vila +# <sanvila@ctv.es> and octave by Dirk Eddelbuettel <edd@debian.org>. + +FLAVOR=$1 +PACKAGE=drprint + +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/share/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 --git a/debian/emacsen-remove.ex b/debian/emacsen-remove.ex new file mode 100644 index 0000000..0fb6690 --- /dev/null +++ b/debian/emacsen-remove.ex @@ -0,0 +1,15 @@ +#!/bin/sh -e +# /usr/lib/emacsen-common/packages/remove/drprint + +FLAVOR=$1 +PACKAGE=drprint + +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/share/info/drprint.info.gz + fi + + echo remove/${PACKAGE}: purging byte-compiled files for ${FLAVOR} + rm -rf /usr/share/${FLAVOR}/site-lisp/${PACKAGE} +fi diff --git a/debian/emacsen-startup.ex b/debian/emacsen-startup.ex new file mode 100644 index 0000000..8c80ca6 --- /dev/null +++ b/debian/emacsen-startup.ex @@ -0,0 +1,25 @@ +;; -*-emacs-lisp-*- +;; +;; Emacs startup file, e.g. /etc/emacs/site-start.d/50drprint.el +;; for the Debian drprint package +;; +;; Originally contributed by Nils Naumann <naumann@unileoben.ac.at> +;; Modified by Dirk Eddelbuettel <edd@debian.org> +;; Adapted for dh-make by Jim Van Zandt <jrv@debian.org> + +;; The drprint 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/drprint"))) +;; If package-dir does not exist, the drprint 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 'drprint-mode "drprint-mode" + "Major mode for editing drprint files." t) + (add-to-list 'auto-mode-alist '("\\.drprint$" . drprint-mode)))) + diff --git a/debian/files b/debian/files new file mode 100644 index 0000000..3910bcd --- /dev/null +++ b/debian/files @@ -0,0 +1,5 @@ +drprint_0.6-1_all.deb unknown extra +drprint_0.6-2_all.deb unknown extra +drprint_0.6-2_all.deb unknown extra +drprint_0.6-2_all.deb unknown extra +drprint_0.6-3_all.deb unknown extra diff --git a/debian/init.d.ex b/debian/init.d.ex new file mode 100644 index 0000000..da3e8f8 --- /dev/null +++ b/debian/init.d.ex @@ -0,0 +1,157 @@ +#! /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 <miquels@cistron.nl>. +# Modified for Debian +# by Ian Murdock <imurdock@gnu.ai.mit.edu>. +# Further changes by Javier Fernandez-Sanguino <jfs@debian.org> +# +# 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/drprint +NAME=drprint +DESC=drprint + +test -x $DAEMON || exit 0 + +LOGDIR=/var/log/drprint +PIDFILE=/var/run/$NAME.pid +DODTIME=1 # Time to wait for the server to die, in seconds + # If this value is set too low you might not + # let some servers to die gracefully and + # 'restart' will not work + +# Include drprint defaults if available +if [ -f /etc/default/drprint ] ; then + . /etc/default/drprint +fi + +set -e + +running_pid() +{ + # Check if a given process pid's cmdline matches a given name + pid=$1 + name=$2 + [ -z "$pid" ] && return 1 + [ ! -d /proc/$pid ] && return 1 + cmd=`cat /proc/$pid/cmdline | tr "\000" "\n"|head -n 1 |cut -d : -f 1` + # Is this the expected child? + [ "$cmd" != "$name" ] && return 1 + return 0 +} + +running() +{ +# Check if the process is running looking at /proc +# (works for all users) + + # No pidfile, probably no daemon present + [ ! -f "$PIDFILE" ] && return 1 + # Obtain the pid and check it against the binary name + pid=`cat $PIDFILE` + running_pid $pid $DAEMON || return 1 + return 0 +} + +force_stop() { +# Forcefully kill the process + [ ! -f "$PIDFILE" ] && return + if running ; then + kill -15 $pid + # Is it really dead? + [ -n "$DODTIME" ] && sleep "$DODTIME"s + if running ; then + kill -9 $pid + [ -n "$DODTIME" ] && sleep "$DODTIME"s + if running ; then + echo "Cannot kill $LABEL (pid=$pid)!" + exit 1 + fi + fi + fi + rm -f $PIDFILE + return 0 +} + +case "$1" in + start) + echo -n "Starting $DESC: " + start-stop-daemon --start --quiet --pidfile $PIDFILE \ + --exec $DAEMON -- $DAEMON_OPTS + if running ; then + echo "$NAME." + else + echo " ERROR." + fi + ;; + stop) + echo -n "Stopping $DESC: " + start-stop-daemon --stop --quiet --pidfile $PIDFILE \ + --exec $DAEMON + echo "$NAME." + ;; + force-stop) + echo -n "Forcefully stopping $DESC: " + force_stop + if ! running ; then + echo "$NAME." + else + echo " ERROR." + fi + ;; + #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 + [ -n "$DODTIME" ] && sleep $DODTIME + start-stop-daemon --start --quiet --pidfile \ + /var/run/$NAME.pid --exec $DAEMON -- $DAEMON_OPTS + echo "$NAME." + ;; + status) + echo -n "$LABEL is " + if running ; then + echo "running" + else + echo " not running." + exit 1 + fi + ;; + *) + N=/etc/init.d/$NAME + # echo "Usage: $N {start|stop|restart|reload|force-reload}" >&2 + echo "Usage: $N {start|stop|restart|force-reload|status|force-stop}" >&2 + exit 1 + ;; +esac + +exit 0 diff --git a/debian/init.d.lsb.ex b/debian/init.d.lsb.ex new file mode 100644 index 0000000..ee19fff --- /dev/null +++ b/debian/init.d.lsb.ex @@ -0,0 +1,296 @@ +#!/bin/sh +# +# Example init.d script with LSB support. +# +# Please read this init.d carefully and modify the sections to +# adjust it to the program you want to run. +# +# Copyright (c) 2007 Javier Fernandez-Sanguino <jfs@debian.org> +# +# This is free software; you may redistribute it and/or modify +# it under the terms of the GNU General Public License as +# published by the Free Software Foundation; either version 2, +# or (at your option) any later version. +# +# This is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License with +# the Debian operating system, in /usr/share/common-licenses/GPL; if +# not, write to the Free Software Foundation, Inc., 59 Temple Place, +# Suite 330, Boston, MA 02111-1307 USA +# +### BEGIN INIT INFO +# Provides: drprint +# Required-Start: $network $local_fs +# Required-Stop: +# Should-Start: $named +# Should-Stop: +# Default-Start: 2 3 4 5 +# Default-Stop: 0 1 6 +# Short-Description: <Enter a short description of the sortware> +# Description: <Enter a long description of the software> +# <...> +# <...> +### END INIT INFO + +PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin + +DAEMON=/usr/sbin/drprint # Introduce the server's location here +NAME=#PACKAGE # Introduce the short server's name here +DESC=#PACKAGE # Introduce a short description here +LOGDIR=/var/log/drprint # Log directory to use + +PIDFILE=/var/run/$NAME.pid + +test -x $DAEMON || exit 0 + +. /lib/lsb/init-functions + +# Default options, these can be overriden by the information +# at /etc/default/$NAME +DAEMON_OPTS="" # Additional options given to the server + +DIETIME=10 # Time to wait for the server to die, in seconds + # If this value is set too low you might not + # let some servers to die gracefully and + # 'restart' will not work + +#STARTTIME=2 # Time to wait for the server to start, in seconds + # If this value is set each time the server is + # started (on start or restart) the script will + # stall to try to determine if it is running + # If it is not set and the server takes time + # to setup a pid file the log message might + # be a false positive (says it did not start + # when it actually did) + +LOGFILE=$LOGDIR/$NAME.log # Server logfile +#DAEMONUSER=drprint # Users to run the daemons as. If this value + # is set start-stop-daemon will chuid the server + +# Include defaults if available +if [ -f /etc/default/$NAME ] ; then + . /etc/default/$NAME +fi + +# Use this if you want the user to explicitly set 'RUN' in +# /etc/default/ +#if [ "x$RUN" != "xyes" ] ; then +# log_failure_msg "$NAME disabled, please adjust the configuration to your needs " +# log_failure_msg "and then set RUN to 'yes' in /etc/default/$NAME to enable it." +# exit 1 +#fi + +# Check that the user exists (if we set a user) +# Does the user exist? +if [ -n "$DAEMONUSER" ] ; then + if getent passwd | grep -q "^$DAEMONUSER:"; then + # Obtain the uid and gid + DAEMONUID=`getent passwd |grep "^$DAEMONUSER:" | awk -F : '{print $3}'` + DAEMONGID=`getent passwd |grep "^$DAEMONUSER:" | awk -F : '{print $4}'` + else + log_failure_msg "The user $DAEMONUSER, required to run $NAME does not exist." + exit 1 + fi +fi + + +set -e + +running_pid() { +# Check if a given process pid's cmdline matches a given name + pid=$1 + name=$2 + [ -z "$pid" ] && return 1 + [ ! -d /proc/$pid ] && return 1 + cmd=`cat /proc/$pid/cmdline | tr "\000" "\n"|head -n 1 |cut -d : -f 1` + # Is this the expected server + [ "$cmd" != "$name" ] && return 1 + return 0 +} + +running() { +# Check if the process is running looking at /proc +# (works for all users) + + # No pidfile, probably no daemon present + [ ! -f "$PIDFILE" ] && return 1 + pid=`cat $PIDFILE` + running_pid $pid $DAEMON || return 1 + return 0 +} + +start_server() { +# Start the process using the wrapper + if [ -z "$DAEMONUSER" ] ; then + start_daemon -p $PIDFILE $DAEMON $DAEMON_OPTS + errcode=$? + else +# if we are using a daemonuser then change the user id + start-stop-daemon --start --quiet --pidfile $PIDFILE \ + --chuid $DAEMONUSER \ + --exec $DAEMON -- $DAEMON_OPTS + errcode=$? + fi + return $errcode +} + +stop_server() { +# Stop the process using the wrapper + if [ -z "$DAEMONUSER" ] ; then + killproc -p $PIDFILE $DAEMON + errcode=$? + else +# if we are using a daemonuser then look for process that match + start-stop-daemon --stop --quiet --pidfile $PIDFILE \ + --user $DAEMONUSER \ + --exec $DAEMON + errcode=$? + fi + + return $errcode +} + +reload_server() { + [ ! -f "$PIDFILE" ] && return 1 + pid=pidofproc $PIDFILE # This is the daemon's pid + # Send a SIGHUP + kill -1 $pid + return $? +} + +force_stop() { +# Force the process to die killing it manually + [ ! -e "$PIDFILE" ] && return + if running ; then + kill -15 $pid + # Is it really dead? + sleep "$DIETIME"s + if running ; then + kill -9 $pid + sleep "$DIETIME"s + if running ; then + echo "Cannot kill $NAME (pid=$pid)!" + exit 1 + fi + fi + fi + rm -f $PIDFILE +} + + +case "$1" in + start) + log_daemon_msg "Starting $DESC " "$NAME" + # Check if it's running first + if running ; then + log_progress_msg "apparently already running" + log_end_msg 0 + exit 0 + fi + if start_server ; then + # NOTE: Some servers might die some time after they start, + # this code will detect this issue if STARTTIME is set + # to a reasonable value + [ -n "$STARTTIME" ] && sleep $STARTTIME # Wait some time + if running ; then + # It's ok, the server started and is running + log_end_msg 0 + else + # It is not running after we did start + log_end_msg 1 + fi + else + # Either we could not start it + log_end_msg 1 + fi + ;; + stop) + log_daemon_msg "Stopping $DESC" "$NAME" + if running ; then + # Only stop the server if we see it running + errcode=0 + stop_server || errcode=$? + log_end_msg $errcode + else + # If it's not running don't do anything + log_progress_msg "apparently not running" + log_end_msg 0 + exit 0 + fi + ;; + force-stop) + # First try to stop gracefully the program + $0 stop + if running; then + # If it's still running try to kill it more forcefully + log_daemon_msg "Stopping (force) $DESC" "$NAME" + errcode=0 + force_stop || errcode=$? + log_end_msg $errcode + fi + ;; + restart|force-reload) + log_daemon_msg "Restarting $DESC" "$NAME" + errcode=0 + stop_server || errcode=$? + # Wait some sensible amount, some server need this + [ -n "$DIETIME" ] && sleep $DIETIME + start_server || errcode=$? + [ -n "$STARTTIME" ] && sleep $STARTTIME + running || errcode=$? + log_end_msg $errcode + ;; + status) + + log_daemon_msg "Checking status of $DESC" "$NAME" + if running ; then + log_progress_msg "running" + log_end_msg 0 + else + log_progress_msg "apparently not running" + log_end_msg 1 + exit 1 + fi + ;; + # Use this if the daemon cannot reload + reload) + log_warning_msg "Reloading $NAME daemon: not implemented, as the daemon" + log_warning_msg "cannot re-read the config file (use restart)." + ;; + # And this if it cann + #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. + # + # log_daemon_msg "Reloading $DESC configuration files" "$NAME" + # if running ; then + # reload_server + # if ! running ; then + # Process died after we tried to reload + # log_progress_msg "died on reload" + # log_end_msg 1 + # exit 1 + # fi + # else + # log_progress_msg "server is not running" + # log_end_msg 1 + # exit 1 + # fi + #;; + + *) + N=/etc/init.d/$NAME + echo "Usage: $N {start|stop|force-stop|restart|force-reload|status}" >&2 + exit 1 + ;; +esac + +exit 0 diff --git a/debian/manpage.1.ex b/debian/manpage.1.ex new file mode 100644 index 0000000..2ea365a --- /dev/null +++ b/debian/manpage.1.ex @@ -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 DRPRINT SECTION "October 15, 2009" +.\" 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 <n> insert n+1 empty lines +.\" for manpage-specific macros, see man(7) +.SH NAME +drprint \- program to do something +.SH SYNOPSIS +.B drprint +.RI [ options ] " files" ... +.br +.B bar +.RI [ options ] " files" ... +.SH DESCRIPTION +This manual page documents briefly the +.B drprint +and +.B bar +commands. +.PP +.\" TeX users may be more comfortable with the \fB<whatever>\fP and +.\" \fI<whatever>\fP escape sequences to invode bold face and italics, +.\" respectively. +\fBdrprint\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 +drprint was written by <upstream author>. +.PP +This manual page was written by Leonardo Robol <leo@robol.it>, +for the Debian project (and may be used by others). diff --git a/debian/manpage.sgml.ex b/debian/manpage.sgml.ex new file mode 100644 index 0000000..f768482 --- /dev/null +++ b/debian/manpage.sgml.ex @@ -0,0 +1,154 @@ +<!doctype refentry PUBLIC "-//OASIS//DTD DocBook V4.1//EN" [ + +<!-- Process this file with docbook-to-man to generate an nroff manual + page: `docbook-to-man manpage.sgml > 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. + + --> + + <!-- Fill in your name for FIRSTNAME and SURNAME. --> + <!ENTITY dhfirstname "<firstname>FIRSTNAME</firstname>"> + <!ENTITY dhsurname "<surname>SURNAME</surname>"> + <!-- Please adjust the date whenever revising the manpage. --> + <!ENTITY dhdate "<date>October 15, 2009</date>"> + <!-- SECTION should be 1-8, maybe w/ subsection other parameters are + allowed: see man(7), man(1). --> + <!ENTITY dhsection "<manvolnum>SECTION</manvolnum>"> + <!ENTITY dhemail "<email>leo@robol.it</email>"> + <!ENTITY dhusername "Leonardo Robol"> + <!ENTITY dhucpackage "<refentrytitle>DRPRINT</refentrytitle>"> + <!ENTITY dhpackage "drprint"> + + <!ENTITY debian "<productname>Debian</productname>"> + <!ENTITY gnu "<acronym>GNU</acronym>"> + <!ENTITY gpl "&gnu; <acronym>GPL</acronym>"> +]> + +<refentry> + <refentryinfo> + <address> + &dhemail; + </address> + <author> + &dhfirstname; + &dhsurname; + </author> + <copyright> + <year>2003</year> + <holder>&dhusername;</holder> + </copyright> + &dhdate; + </refentryinfo> + <refmeta> + &dhucpackage; + + &dhsection; + </refmeta> + <refnamediv> + <refname>&dhpackage;</refname> + + <refpurpose>program to do something</refpurpose> + </refnamediv> + <refsynopsisdiv> + <cmdsynopsis> + <command>&dhpackage;</command> + + <arg><option>-e <replaceable>this</replaceable></option></arg> + + <arg><option>--example <replaceable>that</replaceable></option></arg> + </cmdsynopsis> + </refsynopsisdiv> + <refsect1> + <title>DESCRIPTION</title> + + <para>This manual page documents briefly the + <command>&dhpackage;</command> and <command>bar</command> + commands.</para> + + <para>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; + <application>Info</application> format; see below.</para> + + <para><command>&dhpackage;</command> is a program that...</para> + + </refsect1> + <refsect1> + <title>OPTIONS</title> + + <para>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 + <application>Info</application> files.</para> + + <variablelist> + <varlistentry> + <term><option>-h</option> + <option>--help</option> + </term> + <listitem> + <para>Show summary of options.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><option>-v</option> + <option>--version</option> + </term> + <listitem> + <para>Show version of program.</para> + </listitem> + </varlistentry> + </variablelist> + </refsect1> + <refsect1> + <title>SEE ALSO</title> + + <para>bar (1), baz (1).</para> + + <para>The programs are documented fully by <citetitle>The Rise and + Fall of a Fooish Bar</citetitle> available via the + <application>Info</application> system.</para> + </refsect1> + <refsect1> + <title>AUTHOR</title> + + <para>This manual page was written by &dhusername; &dhemail; for + the &debian; system (and 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. + </para> + <para> + On Debian systems, the complete text of the GNU General Public + License can be found in /usr/share/common-licenses/GPL. + </para> + + </refsect1> +</refentry> + +<!-- Keep this comment at the end of the file +Local variables: +mode: sgml +sgml-omittag:t +sgml-shorttag:t +sgml-minimize-attributes:nil +sgml-always-quote-attributes:t +sgml-indent-step:2 +sgml-indent-data:t +sgml-parent-document:nil +sgml-default-dtd-file:nil +sgml-exposed-tags:nil +sgml-local-catalogs:nil +sgml-local-ecat-files:nil +End: +--> diff --git a/debian/manpage.xml.ex b/debian/manpage.xml.ex new file mode 100644 index 0000000..706f726 --- /dev/null +++ b/debian/manpage.xml.ex @@ -0,0 +1,291 @@ +<?xml version='1.0' encoding='UTF-8'?> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" +"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [ + +<!-- + +`xsltproc -''-nonet \ + -''-param man.charmap.use.subset "0" \ + -''-param make.year.ranges "1" \ + -''-param make.single.year.ranges "1" \ + /usr/share/xml/docbook/stylesheet/nwalsh/manpages/docbook.xsl \ + manpage.xml' + +A manual page <package>.<section> will be generated. You may view the +manual page with: nroff -man <package>.<section> | 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 -''-param man.charmap.use.subset "0" + +manpage.1: manpage.xml + $(XP) $(DB2MAN) $< + +The xsltproc binary is found in the xsltproc package. The XSL files are in +docbook-xsl. A description of the parameters you can use can be found in the +docbook-xsl-doc-* packages. 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. +Alternatively use the xmlto command/package. That will also automatically +pull in xsltproc and docbook-xsl. + +Notes for using docbook2x: docbook2x-man does not automatically create the +AUTHOR(S) and COPYRIGHT sections. In this case, please add them manually as +<refsect1> ... </refsect1>. + +To disable the automatic creation of the AUTHOR(S) and COPYRIGHT sections +read /usr/share/doc/docbook-xsl/doc/manpages/authors.html. This file can be +found in the docbook-xsl-doc-html package. + +Validation can be done using: `xmllint -''-noout -''-valid manpage.xml` + +General documentation about man-pages and man-page-formatting: +man(1), man(7), http://www.tldp.org/HOWTO/Man-Page/ + +--> + + <!-- Fill in your name for FIRSTNAME and SURNAME. --> + <!ENTITY dhfirstname "FIRSTNAME"> + <!ENTITY dhsurname "SURNAME"> + <!-- dhusername could also be set to "&firstname; &surname;". --> + <!ENTITY dhusername "Leonardo Robol"> + <!ENTITY dhemail "leo@robol.it"> + <!-- SECTION should be 1-8, maybe w/ subsection other parameters are + allowed: see man(7), man(1) and + http://www.tldp.org/HOWTO/Man-Page/q2.html. --> + <!ENTITY dhsection "SECTION"> + <!-- TITLE should be something like "User commands" or similar (see + http://www.tldp.org/HOWTO/Man-Page/q2.html). --> + <!ENTITY dhtitle "drprint User Manual"> + <!ENTITY dhucpackage "DRPRINT"> + <!ENTITY dhpackage "drprint"> +]> + +<refentry> + <refentryinfo> + <title>&dhtitle;</title> + <productname>&dhpackage;</productname> + <authorgroup> + <author> + <firstname>&dhfirstname;</firstname> + <surname>&dhsurname;</surname> + <contrib>Wrote this manpage for the Debian system.</contrib> + <address> + <email>&dhemail;</email> + </address> + </author> + </authorgroup> + <copyright> + <year>2007</year> + <holder>&dhusername;</holder> + </copyright> + <legalnotice> + <para>This manual page was written for the Debian system + (and may be used by others).</para> + <para>Permission is granted to copy, distribute and/or modify this + document under the terms of the GNU General Public License, + Version 2 or (at your option) any later version published by + the Free Software Foundation.</para> + <para>On Debian systems, the complete text of the GNU General Public + License can be found in + <filename>/usr/share/common-licenses/GPL</filename>.</para> + </legalnotice> + </refentryinfo> + <refmeta> + <refentrytitle>&dhucpackage;</refentrytitle> + <manvolnum>&dhsection;</manvolnum> + </refmeta> + <refnamediv> + <refname>&dhpackage;</refname> + <refpurpose>program to do something</refpurpose> + </refnamediv> + <refsynopsisdiv> + <cmdsynopsis> + <command>&dhpackage;</command> + <!-- These are several examples, how syntaxes could look --> + <arg choice="plain"><option>-e <replaceable>this</replaceable></option></arg> + <arg choice="opt"><option>--example=<parameter>that</parameter></option></arg> + <arg choice="opt"> + <group choice="req"> + <arg choice="plain"><option>-e</option></arg> + <arg choice="plain"><option>--example</option></arg> + </group> + <replaceable class="option">this</replaceable> + </arg> + <arg choice="opt"> + <group choice="req"> + <arg choice="plain"><option>-e</option></arg> + <arg choice="plain"><option>--example</option></arg> + </group> + <group choice="req"> + <arg choice="plain"><replaceable>this</replaceable></arg> + <arg choice="plain"><replaceable>that</replaceable></arg> + </group> + </arg> + </cmdsynopsis> + <cmdsynopsis> + <command>&dhpackage;</command> + <!-- Normally the help and version options make the programs stop + right after outputting the requested information. --> + <group choice="opt"> + <arg choice="plain"> + <group choice="req"> + <arg choice="plain"><option>-h</option></arg> + <arg choice="plain"><option>--help</option></arg> + </group> + </arg> + <arg choice="plain"> + <group choice="req"> + <arg choice="plain"><option>-v</option></arg> + <arg choice="plain"><option>--version</option></arg> + </group> + </arg> + </group> + </cmdsynopsis> + </refsynopsisdiv> + <refsect1 id="description"> + <title>DESCRIPTION</title> + <para>This manual page documents briefly the + <command>&dhpackage;</command> and <command>bar</command> + commands.</para> + <para>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 <citerefentry> + <refentrytitle>info</refentrytitle> + <manvolnum>1</manvolnum> + </citerefentry> format; see below.</para> + <para><command>&dhpackage;</command> is a program that...</para> + </refsect1> + <refsect1 id="options"> + <title>OPTIONS</title> + <para>The program follows 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 + <citerefentry> + <refentrytitle>info</refentrytitle> + <manvolnum>1</manvolnum> + </citerefentry> files.</para> + <variablelist> + <!-- Use the variablelist.term.separator and the + variablelist.term.break.after parameters to + control the term elements. --> + <varlistentry> + <term><option>-e <replaceable>this</replaceable></option></term> + <term><option>--example=<replaceable>that</replaceable></option></term> + <listitem> + <para>Does this and that.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><option>-h</option></term> + <term><option>--help</option></term> + <listitem> + <para>Show summary of options.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><option>-v</option></term> + <term><option>--version</option></term> + <listitem> + <para>Show version of program.</para> + </listitem> + </varlistentry> + </variablelist> + </refsect1> + <refsect1 id="files"> + <title>FILES</title> + <variablelist> + <varlistentry> + <term><filename>/etc/foo.conf</filename></term> + <listitem> + <para>The system-wide configuration file to control the + behaviour of <application>&dhpackage;</application>. See + <citerefentry> + <refentrytitle>foo.conf</refentrytitle> + <manvolnum>5</manvolnum> + </citerefentry> for further details.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><filename>${HOME}/.foo.conf</filename></term> + <listitem> + <para>The per-user configuration file to control the + behaviour of <application>&dhpackage;</application>. See + <citerefentry> + <refentrytitle>foo.conf</refentrytitle> + <manvolnum>5</manvolnum> + </citerefentry> for further details.</para> + </listitem> + </varlistentry> + </variablelist> + </refsect1> + <refsect1 id="environment"> + <title>ENVIONMENT</title> + <variablelist> + <varlistentry> + <term><envar>FOO_CONF</envar></term> + <listitem> + <para>If used, the defined file is used as configuration + file (see also <xref linkend="files"/>).</para> + </listitem> + </varlistentry> + </variablelist> + </refsect1> + <refsect1 id="diagnostics"> + <title>DIAGNOSTICS</title> + <para>The following diagnostics may be issued + on <filename class="devicefile">stderr</filename>:</para> + <variablelist> + <varlistentry> + <term><errortext>Bad configuration file. Exiting.</errortext></term> + <listitem> + <para>The configuration file seems to contain a broken configuration + line. Use the <option>--verbose</option> option, to get more info. + </para> + </listitem> + </varlistentry> + </variablelist> + <para><command>&dhpackage;</command> provides some return codes, that can + be used in scripts:</para> + <segmentedlist> + <segtitle>Code</segtitle> + <segtitle>Diagnostic</segtitle> + <seglistitem> + <seg><errorcode>0</errorcode></seg> + <seg>Program exited successfully.</seg> + </seglistitem> + <seglistitem> + <seg><errorcode>1</errorcode></seg> + <seg>The configuration file seems to be broken.</seg> + </seglistitem> + </segmentedlist> + </refsect1> + <refsect1 id="bugs"> + <!-- Or use this section to tell about upstream BTS. --> + <title>BUGS</title> + <para>The program is currently limited to only work + with the <package>foobar</package> library.</para> + <para>The upstreams <acronym>BTS</acronym> can be found + at <ulink url="http://bugzilla.foo.tld"/>.</para> + </refsect1> + <refsect1 id="see_also"> + <title>SEE ALSO</title> + <!-- In alpabetical order. --> + <para><citerefentry> + <refentrytitle>bar</refentrytitle> + <manvolnum>1</manvolnum> + </citerefentry>, <citerefentry> + <refentrytitle>baz</refentrytitle> + <manvolnum>1</manvolnum> + </citerefentry>, <citerefentry> + <refentrytitle>foo.conf</refentrytitle> + <manvolnum>5</manvolnum> + </citerefentry></para> + <para>The programs are documented fully by <citetitle>The Rise and + Fall of a Fooish Bar</citetitle> available via the <citerefentry> + <refentrytitle>info</refentrytitle> + <manvolnum>1</manvolnum> + </citerefentry> system.</para> + </refsect1> +</refentry> + diff --git a/debian/menu.ex b/debian/menu.ex new file mode 100644 index 0000000..d14174f --- /dev/null +++ b/debian/menu.ex @@ -0,0 +1,2 @@ +?package(drprint):needs="X11|text|vc|wm" section="Applications/see-menu-manual"\ + title="drprint" command="/usr/bin/drprint" diff --git a/debian/postinst.ex b/debian/postinst.ex new file mode 100644 index 0000000..72100c6 --- /dev/null +++ b/debian/postinst.ex @@ -0,0 +1,39 @@ +#!/bin/sh +# postinst script for drprint +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * <postinst> `configure' <most-recently-configured-version> +# * <old-postinst> `abort-upgrade' <new version> +# * <conflictor's-postinst> `abort-remove' `in-favour' <package> +# <new-version> +# * <postinst> `abort-remove' +# * <deconfigured's-postinst> `abort-deconfigure' `in-favour' +# <failed-install-package> <version> `removing' +# <conflicting-package> <version> +# 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 --git a/debian/postrm.ex b/debian/postrm.ex new file mode 100644 index 0000000..f7f86ae --- /dev/null +++ b/debian/postrm.ex @@ -0,0 +1,37 @@ +#!/bin/sh +# postrm script for drprint +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * <postrm> `remove' +# * <postrm> `purge' +# * <old-postrm> `upgrade' <new-version> +# * <new-postrm> `failed-upgrade' <old-version> +# * <new-postrm> `abort-install' +# * <new-postrm> `abort-install' <old-version> +# * <new-postrm> `abort-upgrade' <old-version> +# * <disappearer's-postrm> `disappear' <overwriter> +# <overwriter-version> +# 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 --git a/debian/preinst.ex b/debian/preinst.ex new file mode 100644 index 0000000..d9b7f3e --- /dev/null +++ b/debian/preinst.ex @@ -0,0 +1,35 @@ +#!/bin/sh +# preinst script for drprint +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * <new-preinst> `install' +# * <new-preinst> `install' <old-version> +# * <new-preinst> `upgrade' <old-version> +# * <old-preinst> `abort-upgrade' <new-version> +# 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 --git a/debian/prerm.ex b/debian/prerm.ex new file mode 100644 index 0000000..e922ea0 --- /dev/null +++ b/debian/prerm.ex @@ -0,0 +1,38 @@ +#!/bin/sh +# prerm script for drprint +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * <prerm> `remove' +# * <old-prerm> `upgrade' <new-version> +# * <new-prerm> `failed-upgrade' <old-version> +# * <conflictor's-prerm> `remove' `in-favour' <package> <new-version> +# * <deconfigured's-prerm> `deconfigure' `in-favour' +# <package-being-installed> <version> `removing' +# <conflicting-package> <version> +# 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 --git a/debian/rules b/debian/rules new file mode 100755 index 0000000..d71e577 --- /dev/null +++ b/debian/rules @@ -0,0 +1,92 @@ +#!/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. + +# Uncomment this to turn on verbose mode. +#export DH_VERBOSE=1 + + + + + +configure: configure-stamp +configure-stamp: + dh_testdir + # Add here commands to configure the package. + + touch configure-stamp + + +build: build-stamp + +build-stamp: configure-stamp + dh_testdir + + # Add here commands to compile the package. + # $(MAKE) + #docbook-to-man debian/drprint.sgml > drprint.1 + + touch $@ + +clean: + dh_testdir + dh_testroot + rm -f build-stamp configure-stamp + + # Add here commands to clean up after the build process. + # $(MAKE) clean + python setup.py clean + rm build -rf + dh_clean + +install: build + dh_testdir + dh_testroot + dh_prep + dh_installdirs + + # Add here commands to install the package into debian/drprint. + python setup.py install --root=$(CURDIR)/debian/drprint install + + +# Build architecture-independent files here. +binary-indep: install + dh_testdir + dh_testroot + dh_installchangelogs + dh_installdocs + dh_installexamples +# dh_install +# dh_installmenu +# dh_installdebconf +# dh_installlogrotate +# dh_installemacsen +# dh_installpam +# dh_installmime +# dh_installinit +# dh_installcron +# dh_installinfo +# dh_installwm +# dh_installudev +# dh_lintian +# dh_undocumented + dh_installman + dh_link + dh_compress + dh_fixperms +# dh_perl +# dh_python + dh_installdeb + dh_gencontrol + dh_md5sums + dh_builddeb + +# Build architecture-dependent files here. +binary-arch: install + +binary: binary-indep binary-arch +.PHONY: build clean binary-indep binary-arch binary install configure diff --git a/debian/watch.ex b/debian/watch.ex new file mode 100644 index 0000000..3780b29 --- /dev/null +++ b/debian/watch.ex @@ -0,0 +1,23 @@ +# 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 +# <Webpage URL> <string match> +#http://www.example.com/downloads.php drprint-(.*)\.tar\.gz + +# Uncomment to examine a Webserver directory +#http://www.example.com/pub/drprint-(.*)\.tar\.gz + +# Uncommment to examine a FTP server +#ftp://ftp.example.com/pub/drprint-(.*)\.tar\.gz debian uupdate + +# Uncomment to find new files on sourceforge, for devscripts >= 2.9 +# http://sf.net/drprint/drprint-(.*)\.tar\.gz + +# Uncomment to find new files on GooglePages +# http://example.googlepages.com/foo.html drprint-(.*)\.tar\.gz