/usr/share/pyshared/pkpgpdls/ooo.py is in pkpgcounter 3.50-7.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | # -*- coding: ISO-8859-15 -*-
#
# pkpgcounter : a generic Page Description Language parser
#
# (c) 2003, 2004, 2005, 2006, 2007 Jerome Alet <alet@librelogiciel.com>
# 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 program 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/>.
#
# $Id: ooo.py 374 2007-12-09 14:26:15Z jerome $
#
"""This modules implements a page counter for OpenDocument documents."""
import sys
import zipfile
import pdlparser
class Parser(pdlparser.PDLParser) :
"""A parser for OpenOffice.org documents."""
totiffcommands = [ 'xvfb-run -a abiword --import-extension=.odt --print="| gs -sDEVICE=tiff24nc -dPARANOIDSAFER -dNOPAUSE -dBATCH -dQUIET -r\"%(dpi)i\" -sOutputFile=\"%(outfname)s\" -" "%(infname)s"' ]
required = [ "xvfb-run", "xauth", "abiword", "gs" ]
format = "ISO/IEC DIS 26300"
def isValid(self) :
"""Returns True if data is OpenDocument, else False."""
if self.firstblock[:2] == "PK" :
try :
self.archive = zipfile.ZipFile(self.filename)
self.contentxml = self.archive.read("content.xml")
self.metaxml = self.archive.read("meta.xml")
except :
return False
else :
return True
else :
return False
def getJobSize(self) :
"""Counts pages in an OpenOffice.org document.
Algorithm by Jerome Alet.
"""
pagecount = 0
try :
# First try with Text documents
index = self.metaxml.index("meta:page-count=")
pagecount = int(self.metaxml[index:].split('"')[1])
except :
# Now try with Impress documents
pagecount = self.contentxml.count("<draw:page ")
if not pagecount :
# Probably a Spreadsheet document
raise pdlparser.PDLParserError, "OpenOffice.org's spreadsheet documents are not yet supported."
return pagecount
|