support odf flat xml formats
This commit is contained in:
parent
4de12c11b7
commit
3e141cb2d5
@ -609,6 +609,7 @@ filters/rclscribus \
|
|||||||
filters/rclshowinfo \
|
filters/rclshowinfo \
|
||||||
filters/rclsiduxman \
|
filters/rclsiduxman \
|
||||||
filters/rclsoff.py \
|
filters/rclsoff.py \
|
||||||
|
filters/rclsoff-flat.py \
|
||||||
filters/rclsvg.py \
|
filters/rclsvg.py \
|
||||||
filters/rcltar \
|
filters/rcltar \
|
||||||
filters/rcltex \
|
filters/rcltex \
|
||||||
|
|||||||
204
src/filters/rclsoff-flat.py
Executable file
204
src/filters/rclsoff-flat.py
Executable file
@ -0,0 +1,204 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
# Copyright (C) 2014 J.F.Dockes
|
||||||
|
# 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 2 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, write to the
|
||||||
|
# Free Software Foundation, Inc.,
|
||||||
|
# 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
######################################
|
||||||
|
|
||||||
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import sys
|
||||||
|
import rclexecm
|
||||||
|
import rclxslt
|
||||||
|
from zipfile import ZipFile
|
||||||
|
|
||||||
|
stylesheet_meta = '''<?xml version="1.0"?>
|
||||||
|
<xsl:stylesheet version="1.0"
|
||||||
|
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
||||||
|
xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0"
|
||||||
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0"
|
||||||
|
xmlns:ooo="http://openoffice.org/2004/office"
|
||||||
|
exclude-result-prefixes="office xlink meta ooo dc"
|
||||||
|
>
|
||||||
|
|
||||||
|
<xsl:output method="html" encoding="UTF-8"/>
|
||||||
|
|
||||||
|
|
||||||
|
<xsl:template match="/office:document">
|
||||||
|
<xsl:apply-templates select="/office:document/office:meta" />
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="office:document/office:meta">
|
||||||
|
<xsl:apply-templates select="dc:title"/>
|
||||||
|
<xsl:apply-templates select="dc:description"/>
|
||||||
|
<xsl:apply-templates select="dc:subject"/>
|
||||||
|
<xsl:apply-templates select="meta:keyword"/>
|
||||||
|
<xsl:apply-templates select="dc:creator"/>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="dc:title">
|
||||||
|
<title> <xsl:value-of select="."/> </title><xsl:text>
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="dc:description">
|
||||||
|
<meta>
|
||||||
|
<xsl:attribute name="name">abstract</xsl:attribute>
|
||||||
|
<xsl:attribute name="content">
|
||||||
|
<xsl:value-of select="."/>
|
||||||
|
</xsl:attribute>
|
||||||
|
</meta><xsl:text>
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="dc:subject">
|
||||||
|
<meta>
|
||||||
|
<xsl:attribute name="name">keywords</xsl:attribute>
|
||||||
|
<xsl:attribute name="content">
|
||||||
|
<xsl:value-of select="."/>
|
||||||
|
</xsl:attribute>
|
||||||
|
</meta><xsl:text>
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="dc:creator">
|
||||||
|
<meta>
|
||||||
|
<xsl:attribute name="name">author</xsl:attribute>
|
||||||
|
<xsl:attribute name="content">
|
||||||
|
<xsl:value-of select="."/>
|
||||||
|
</xsl:attribute>
|
||||||
|
</meta><xsl:text>
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="meta:keyword">
|
||||||
|
<meta>
|
||||||
|
<xsl:attribute name="name">keywords</xsl:attribute>
|
||||||
|
<xsl:attribute name="content">
|
||||||
|
<xsl:value-of select="."/>
|
||||||
|
</xsl:attribute>
|
||||||
|
</meta><xsl:text>
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
</xsl:stylesheet>
|
||||||
|
'''
|
||||||
|
|
||||||
|
stylesheet_content = '''<?xml version="1.0"?>
|
||||||
|
<xsl:stylesheet version="1.0"
|
||||||
|
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
||||||
|
xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0"
|
||||||
|
xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0"
|
||||||
|
exclude-result-prefixes="text office"
|
||||||
|
>
|
||||||
|
|
||||||
|
<xsl:template match="office:settings"><xsl:text></xsl:text></xsl:template>
|
||||||
|
<xsl:template match="office:meta"><xsl:text></xsl:text></xsl:template>
|
||||||
|
<xsl:template match="office:scripts"><xsl:text></xsl:text></xsl:template>
|
||||||
|
<xsl:template match="office:font-face-decls"><xsl:text></xsl:text></xsl:template>
|
||||||
|
<xsl:template match="office:styles"><xsl:text></xsl:text></xsl:template>
|
||||||
|
<xsl:template match="office:automatic-styles"><xsl:text></xsl:text></xsl:template>
|
||||||
|
<xsl:template match="office:master-styles"><xsl:text></xsl:text></xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<xsl:template match="text:p">
|
||||||
|
<p><xsl:apply-templates/></p><xsl:text>
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="text:h">
|
||||||
|
<p><xsl:apply-templates/></p><xsl:text>
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="text:s">
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="text:line-break">
|
||||||
|
<br />
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="text:tab">
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
</xsl:stylesheet>
|
||||||
|
'''
|
||||||
|
|
||||||
|
class OOExtractor:
|
||||||
|
def __init__(self, em):
|
||||||
|
self.em = em
|
||||||
|
self.currentindex = 0
|
||||||
|
|
||||||
|
def extractone(self, params):
|
||||||
|
if "filename:" not in params:
|
||||||
|
self.em.rclog("extractone: no mime or file name")
|
||||||
|
return (False, "", "", rclexecm.RclExecM.eofnow)
|
||||||
|
fn = params["filename:"]
|
||||||
|
|
||||||
|
try:
|
||||||
|
f = open(fn)
|
||||||
|
data = f.read()
|
||||||
|
f.close()
|
||||||
|
except Exception as err:
|
||||||
|
self.em.rclog("open failed: %s" % err)
|
||||||
|
return (False, "", "", rclexecm.RclExecM.eofnow)
|
||||||
|
|
||||||
|
docdata = b'<html>\n<head>\n<meta http-equiv="Content-Type"' \
|
||||||
|
b'content="text/html; charset=UTF-8">\n'
|
||||||
|
|
||||||
|
try:
|
||||||
|
res = rclxslt.apply_sheet_data(stylesheet_meta, data)
|
||||||
|
docdata += res
|
||||||
|
except:
|
||||||
|
# To be checked. I'm under the impression that I get this when
|
||||||
|
# nothing matches?
|
||||||
|
#self.em.rclog("no/bad metadata in %s" % fn)
|
||||||
|
pass
|
||||||
|
|
||||||
|
docdata += b'</head><body>'
|
||||||
|
|
||||||
|
try:
|
||||||
|
res = rclxslt.apply_sheet_data(stylesheet_content, data)
|
||||||
|
docdata += res
|
||||||
|
docdata += b'</body></html>'
|
||||||
|
except Exception as err:
|
||||||
|
self.em.rclog("bad data in %s: %s" % (fn, err))
|
||||||
|
return (False, "", "", rclexecm.RclExecM.eofnow)
|
||||||
|
|
||||||
|
return (True, docdata, "", rclexecm.RclExecM.eofnext)
|
||||||
|
|
||||||
|
###### File type handler api, used by rclexecm ---------->
|
||||||
|
def openfile(self, params):
|
||||||
|
self.currentindex = 0
|
||||||
|
return True
|
||||||
|
|
||||||
|
def getipath(self, params):
|
||||||
|
return self.extractone(params)
|
||||||
|
|
||||||
|
def getnext(self, params):
|
||||||
|
if self.currentindex >= 1:
|
||||||
|
return (False, "", "", rclexecm.RclExecM.eofnow)
|
||||||
|
else:
|
||||||
|
ret= self.extractone(params)
|
||||||
|
self.currentindex += 1
|
||||||
|
return ret
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
proto = rclexecm.RclExecM()
|
||||||
|
extract = OOExtractor(proto)
|
||||||
|
rclexecm.main(proto, extract)
|
||||||
@ -72,6 +72,9 @@ application/vnd.oasis.opendocument.text-template = execm rclsoff.py
|
|||||||
application/vnd.oasis.opendocument.presentation = execm rclsoff.py
|
application/vnd.oasis.opendocument.presentation = execm rclsoff.py
|
||||||
application/vnd.oasis.opendocument.spreadsheet = execm rclsoff.py
|
application/vnd.oasis.opendocument.spreadsheet = execm rclsoff.py
|
||||||
application/vnd.oasis.opendocument.graphics = execm rclsoff.py
|
application/vnd.oasis.opendocument.graphics = execm rclsoff.py
|
||||||
|
application/vnd.oasis.opendocument.spreadsheet-flat-xml = execm rclsoff-flat.py
|
||||||
|
application/vnd.oasis.opendocument.presentation-flat-xml = execm rclsoff-flat.py
|
||||||
|
application/vnd.oasis.opendocument.spreadsheet-flat-xml = execm rclsoff-flat.py
|
||||||
application/vnd.openxmlformats-officedocument.wordprocessingml.document = \
|
application/vnd.openxmlformats-officedocument.wordprocessingml.document = \
|
||||||
execm rclopxml.py
|
execm rclopxml.py
|
||||||
application/vnd.openxmlformats-officedocument.wordprocessingml.template = \
|
application/vnd.openxmlformats-officedocument.wordprocessingml.template = \
|
||||||
|
|||||||
@ -112,6 +112,10 @@
|
|||||||
.sxg = application/vnd.sun.xml.writer.global
|
.sxg = application/vnd.sun.xml.writer.global
|
||||||
.stw = application/vnd.sun.xml.writer.template
|
.stw = application/vnd.sun.xml.writer.template
|
||||||
|
|
||||||
|
.fods = application/vnd.oasis.opendocument.spreadsheet-flat-xml
|
||||||
|
.fodp = application/vnd.oasis.opendocument.presentation-flat-xml
|
||||||
|
.fods = application/vnd.oasis.opendocument.spreadsheet-flat-xml
|
||||||
|
|
||||||
# ms openxml
|
# ms openxml
|
||||||
.docm = application/vnd.ms-word.document.macroEnabled.12
|
.docm = application/vnd.ms-word.document.macroEnabled.12
|
||||||
.docx = application/vnd.openxmlformats-officedocument.wordprocessingml.document
|
.docx = application/vnd.openxmlformats-officedocument.wordprocessingml.document
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user