[185] | 1 | #! /usr/bin/env python |
---|
| 2 | # -*- coding: ISO-8859-15 -*- |
---|
| 3 | # |
---|
| 4 | # pkpgcounter : a generic Page Description Language parser |
---|
| 5 | # |
---|
[443] | 6 | # (c) 2003, 2004, 2005, 2006, 2007 Jerome Alet <alet@librelogiciel.com> |
---|
[463] | 7 | # This program is free software: you can redistribute it and/or modify |
---|
[185] | 8 | # it under the terms of the GNU General Public License as published by |
---|
[463] | 9 | # the Free Software Foundation, either version 3 of the License, or |
---|
[185] | 10 | # (at your option) any later version. |
---|
[463] | 11 | # |
---|
[185] | 12 | # This program is distributed in the hope that it will be useful, |
---|
| 13 | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
| 14 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
| 15 | # GNU General Public License for more details. |
---|
| 16 | # |
---|
| 17 | # You should have received a copy of the GNU General Public License |
---|
[463] | 18 | # along with this program. If not, see <http://www.gnu.org/licenses/>. |
---|
[185] | 19 | # |
---|
| 20 | # $Id$ |
---|
| 21 | # |
---|
| 22 | # |
---|
| 23 | |
---|
[211] | 24 | import sys |
---|
[235] | 25 | from pkpgpdls.version import __version__, __author__, __authoremail__, \ |
---|
[223] | 26 | __years__, __gplblurb__ |
---|
[235] | 27 | from pkpgpdls import analyzer |
---|
[186] | 28 | |
---|
[223] | 29 | __doc__ = """pkpgcounter v%(__version__)s (c) %(__years__)s %(__author__)s |
---|
| 30 | |
---|
| 31 | pkpgcounter is a generic Page Description Language parser. |
---|
| 32 | |
---|
| 33 | pkpgcounter parses any number of input files and/or its standard input |
---|
| 34 | and outputs the number of pages needed to print these documents. |
---|
| 35 | |
---|
[369] | 36 | pkpgcounter can also compute the percent of ink coverage in different |
---|
| 37 | colorspaces for several file formats. |
---|
[223] | 38 | |
---|
[375] | 39 | pkpgcounter currently recognizes the following document formats : |
---|
[369] | 40 | |
---|
[223] | 41 | * PostScript (both DSC compliant and binary) |
---|
| 42 | * PDF |
---|
| 43 | * PCLXL (aka PCL6) |
---|
| 44 | * PCL3/4/5 (mostly) |
---|
| 45 | * DVI |
---|
[418] | 46 | * Plain text |
---|
[223] | 47 | * TIFF |
---|
| 48 | * ESC/P2 |
---|
[346] | 49 | * OpenDocument (ISO/IEC DIS 26300) |
---|
[329] | 50 | * Zenographics ZjStream |
---|
[386] | 51 | * Samsung QPDL (aka SPL2) |
---|
[418] | 52 | * Samsung SPL1 |
---|
[223] | 53 | |
---|
[418] | 54 | The five latter ones, as well as some TIFF documents, are currently |
---|
[375] | 55 | only supported in page counting mode. |
---|
[369] | 56 | |
---|
[223] | 57 | command line usage : |
---|
| 58 | |
---|
| 59 | pkpgcounter [options] [files] |
---|
| 60 | |
---|
| 61 | options : |
---|
| 62 | |
---|
[369] | 63 | -v | --version Prints pkpgcounter's version number then exits. |
---|
| 64 | -h | --help Prints this message then exits. |
---|
[223] | 65 | |
---|
[369] | 66 | -d | --debug Activate debug mode. |
---|
[223] | 67 | |
---|
[369] | 68 | -cCOLORSPACE, --colorspace=COLORSPACE |
---|
| 69 | Activate the computation of ink usage, and defines the |
---|
[439] | 70 | colorspace to use. Supported values are 'BW' (Black), |
---|
| 71 | 'RGB', 'CMYK', 'CMY', and 'GC' (Grayscale vs Color). |
---|
| 72 | 'GC' is useful if you only need to differentiate |
---|
| 73 | grayscale pages from coloured pages but don't care |
---|
| 74 | about ink usage per se. |
---|
[369] | 75 | |
---|
| 76 | -rRESOLUTION, --resolution=RESOLUTION |
---|
| 77 | The resolution in DPI to use when checking ink usage. |
---|
| 78 | Lower resolution is faster but less accurate. Default |
---|
| 79 | is 72 dpi. |
---|
| 80 | |
---|
[223] | 81 | examples : |
---|
| 82 | |
---|
| 83 | $ pkpgcounter file1.ps file2.escp2 file3.pclxl <file4.pcl345 |
---|
| 84 | |
---|
| 85 | Will launch pkpgcounter and will output the total number of pages |
---|
| 86 | needed to print all the documents specified. |
---|
| 87 | |
---|
[369] | 88 | $ pkpgcounter --colorspace bw --resolution 150 file1.ps |
---|
| 89 | |
---|
| 90 | Will output the percent of black ink needed on each page of |
---|
[374] | 91 | the file1.ps file rendered at 150 dpi. |
---|
[369] | 92 | |
---|
[223] | 93 | %(__gplblurb__)s |
---|
| 94 | |
---|
| 95 | Please e-mail bugs to: %(__authoremail__)s""" |
---|
| 96 | |
---|
[199] | 97 | if __name__ == "__main__" : |
---|
[211] | 98 | if (len(sys.argv) >= 2) and (sys.argv[1] in ("-h", "--help")) : |
---|
[223] | 99 | print __doc__ % globals() |
---|
[211] | 100 | else : |
---|
| 101 | analyzer.main() |
---|