[Libreoffice-commits] core.git: writerfilter/CustomTarget_source.mk writerfilter/source

Miklos Vajna vmiklos at collabora.co.uk
Tue Jul 15 12:24:21 PDT 2014


 writerfilter/CustomTarget_source.mk        |    6 -
 writerfilter/source/ooxml/factory_ns.py    |   83 ++++++++++++++++
 writerfilter/source/ooxml/factory_ns.xsl   |  150 -----------------------------
 writerfilter/source/ooxml/factorytools.xsl |   11 --
 4 files changed, 86 insertions(+), 164 deletions(-)

New commits:
commit 3f2d6c7f7a6ef825b9431a3d270bc75b84069a32
Author: Miklos Vajna <vmiklos at collabora.co.uk>
Date:   Tue Jul 15 21:13:01 2014 +0200

    writerfilter: convert factory_ns to Python
    
    Change-Id: I64996b3f96f51ba80ade636c13a2919410672a27

diff --git a/writerfilter/CustomTarget_source.mk b/writerfilter/CustomTarget_source.mk
index 9fdaf00..b84e235 100644
--- a/writerfilter/CustomTarget_source.mk
+++ b/writerfilter/CustomTarget_source.mk
@@ -125,9 +125,9 @@ $(writerfilter_WORK)/ooxml/OOXMLFactory%.cxx : $(writerfilter_SRC)/ooxml/factory
 	$(call gb_Output_announce,$(subst $(WORKDIR)/,,$@),build,XSL,1)
 	$(call gb_Helper_abbreviate_dirs, $(writerfilter_XSLTCOMMAND) --stringparam file $@ $< $(writerfilter_GEN_ooxml_Model_processed)) > $@
 
-$(writerfilter_WORK)/ooxml/OOXMLFactory%.hxx : $(writerfilter_SRC)/ooxml/factory_ns.xsl $(writerfilter_GEN_ooxml_Model_processed)
-	$(call gb_Output_announce,$(subst $(WORKDIR)/,,$@),build,XSL,1)
-	$(call gb_Helper_abbreviate_dirs, $(writerfilter_XSLTCOMMAND) --stringparam file $@ $< $(writerfilter_GEN_ooxml_Model_processed)) > $@
+$(writerfilter_WORK)/ooxml/OOXMLFactory%.hxx : $(writerfilter_SRC)/ooxml/factory_ns.py $(writerfilter_GEN_ooxml_Model_processed)
+	$(call gb_Output_announce,$(subst $(WORKDIR)/,,$@),build,PY ,1)
+	$(call gb_Helper_abbreviate_dirs, $(writerfilter_PYTHONCOMMAND) $< $(writerfilter_GEN_ooxml_Model_processed) $@) > $@
 
 
 $(call gb_CustomTarget_get_target,writerfilter/source) : $(writerfilter_ALL)
diff --git a/writerfilter/source/ooxml/factory_ns.py b/writerfilter/source/ooxml/factory_ns.py
new file mode 100644
index 0000000..edd0718
--- /dev/null
+++ b/writerfilter/source/ooxml/factory_ns.py
@@ -0,0 +1,83 @@
+#!/usr/bin/env python
+#
+# This file is part of the LibreOffice project.
+#
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+#
+
+from __future__ import print_function
+from xml.dom import minidom
+import sys
+
+
+def createHeader(model, ns):
+    nsToken = ns.replace('-', '_')
+    print("""
+#ifndef INCLUDED_OOXML_FACTORY_%s_HXX
+#define INCLUDED_OOXML_FACTORY_%s_HXX
+#include "ooxml/OOXMLFactory.hxx"
+#include "OOXMLFactory_generated.hxx"
+#include "ooxml/OOXMLnamespaceids.hxx"
+#include "ooxml/resourceids.hxx"
+
+namespace writerfilter {
+namespace ooxml {
+
+/// @cond GENERATED
+""" % (nsToken.upper(), nsToken.upper()))
+
+    print("""class OOXMLFactory_%s : public OOXMLFactory_ns
+{
+public:
+    typedef boost::shared_ptr <OOXMLFactory_ns> Pointer_t;
+
+    static Pointer_t getInstance();
+
+    virtual AttributeToResourceMapPointer createAttributeToResourceMap(Id nId);
+    virtual ListValueMapPointer createListValueMap(Id nId);
+    virtual CreateElementMapPointer createCreateElementMap(Id nId);
+    virtual TokenToIdMapPointer createTokenToIdMap(Id nId);
+#ifdef DEBUG_DOMAINMAPPER
+    virtual string getDefineName(Id nId) const;
+#endif
+""" % nsToken)
+
+    actions = []
+    for nsNode in [i for i in model.getElementsByTagName("namespace") if i.getAttribute("name") == ns]:
+        for resource in nsNode.getElementsByTagName("resource"):
+            for action in [i.getAttribute("name") for i in resource.childNodes if i.nodeType == minidom.Node.ELEMENT_NODE and i.tagName == "action"]:
+                if action != "characters" and action not in actions:
+                    actions.append(action)
+    for action in actions:
+        print("    void %sAction(OOXMLFastContextHandler* pHandler);" % action)
+
+    print("""virtual void charactersAction(OOXMLFastContextHandler* pHandler, const OUString & sText);
+    virtual void attributeAction(OOXMLFastContextHandler* pHandler, Token_t nToken, OOXMLValue::Pointer_t pValue);
+
+#ifdef DEBUG_DOMAINMAPPER
+    virtual string getName() const;
+#endif
+
+
+    virtual ~OOXMLFactory_%s();
+
+protected:
+    static Pointer_t m_pInstance;
+
+    OOXMLFactory_%s();
+};
+""" % (nsToken, nsToken))
+
+    print("""/// @endcond
+}}
+#endif //INCLUDED_OOXML_FACTORY_%s_HXX""" % nsToken.upper())
+
+modelPath = sys.argv[1]
+filePath = sys.argv[2]
+model = minidom.parse(modelPath)
+ns = filePath.split('OOXMLFactory_')[1].split('.hxx')[0]
+createHeader(model, ns)
+
+# vim:set shiftwidth=4 softtabstop=4 expandtab:
diff --git a/writerfilter/source/ooxml/factory_ns.xsl b/writerfilter/source/ooxml/factory_ns.xsl
deleted file mode 100644
index 59a2940..0000000
--- a/writerfilter/source/ooxml/factory_ns.xsl
+++ /dev/null
@@ -1,150 +0,0 @@
-<!--
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- *
- * This file incorporates work covered by the following license notice:
- *
- *   Licensed to the Apache Software Foundation (ASF) under one or more
- *   contributor license agreements. See the NOTICE file distributed
- *   with this work for additional information regarding copyright
- *   ownership. The ASF licenses this file to you under the Apache
- *   License, Version 2.0 (the "License"); you may not use this file
- *   except in compliance with the License. You may obtain a copy of
- *   the License at http://www.apache.org/licenses/LICENSE-2.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:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" 
-    xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" 
-    xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" 
-    xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" 
-    xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible: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:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" 
-    xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" 
-    xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" 
-    xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" 
-    xmlns:math="http://www.w3.org/1998/Math/MathML" 
-    xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" 
-    xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" 
-    xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0" 
-    xmlns:ooo="http://openoffice.org/2004/office" 
-    xmlns:ooow="http://openoffice.org/2004/writer" 
-    xmlns:oooc="http://openoffice.org/2004/calc" 
-    xmlns:dom="http://www.w3.org/2001/xml-events" 
-    xmlns:xforms="http://www.w3.org/2002/xforms" 
-    xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
-    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
-    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"  
-    xmlns:rng="http://relaxng.org/ns/structure/1.0"
-    xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#" 
-    xmlns:UML = 'org.omg.xmi.namespace.UML' xml:space="default">
-  <xsl:output method="text" />
-  <xsl:param name="prefix"/>
-  
-  <xsl:include href="factorytools.xsl"/>
-
-<xsl:template name="factoryactiondecls">
-    <xsl:variable name="ns" select="@name"/>
-    <xsl:for-each select="resource/action[not(@name='characters')]">
-        <xsl:sort select="@name"/>
-        <xsl:if test="generate-id(key('actions', @name)[ancestor::namespace/@name=$ns][1]) = generate-id(.)">
-            <xsl:text>
-    void </xsl:text>
-            <xsl:value-of select="@name"/>
-            <xsl:text>Action(OOXMLFastContextHandler * pHandler</xsl:text>
-            <xsl:text>);</xsl:text>
-        </xsl:if>
-    </xsl:for-each>
-    <xsl:text>
-    virtual void charactersAction(OOXMLFastContextHandler * pHandler, const OUString & sText);</xsl:text>
-</xsl:template>
-
-<!-- factorydecl -->
-<xsl:template name="factorydecl">
-    <xsl:variable name="classname">
-        <xsl:call-template name="factoryclassname"/>
-    </xsl:variable>
-    <xsl:text>
-class </xsl:text>
-    <xsl:value-of select="$classname"/>
-    <xsl:text> : public OOXMLFactory_ns
-{
-public:
-    typedef boost::shared_ptr < OOXMLFactory_ns > Pointer_t;
-    
-    static Pointer_t getInstance();
-    
-    virtual AttributeToResourceMapPointer createAttributeToResourceMap(Id nId);
-    virtual ListValueMapPointer createListValueMap(Id nId);
-    virtual CreateElementMapPointer createCreateElementMap(Id nId);
-    virtual TokenToIdMapPointer createTokenToIdMap(Id nId);
-#ifdef DEBUG_DOMAINMAPPER
-    virtual string getDefineName(Id nId) const;</xsl:text>
-#endif
-    <xsl:call-template name="factoryactiondecls"/>
-    virtual void attributeAction(OOXMLFastContextHandler * pHandler, Token_t nToken, OOXMLValue::Pointer_t pValue);
-
-#ifdef DEBUG_DOMAINMAPPER
-    virtual string getName() const;
-#endif
-    <xsl:text>
-    
-    virtual ~</xsl:text>
-    <xsl:value-of select="$classname"/>
-    <xsl:text>();
-    
-protected:
-    static Pointer_t m_pInstance;
-
-    </xsl:text>
-    <xsl:value-of select="$classname"/>
-    <xsl:text>();
-};
-    </xsl:text>
-</xsl:template>
-
-  <xsl:template match="/">
-    <xsl:variable name="ns" select="substring-before(substring-after($file, 'OOXMLFactory_'), '.hxx')"/>
-    <xsl:variable name="incguard">
-      <xsl:text>INCLUDED_OOXML_FACTORY_</xsl:text>
-      <xsl:value-of select="translate($ns, 'abcdefghijklmnopqrstuvwxyz-', 'ABCDEFGHIJKLMNOPQRSTUVWXYZ_')"/>
-      <xsl:text>_HXX</xsl:text>
-    </xsl:variable>
-    <xsl:call-template name="licenseheader"/>
-    <xsl:text>
-#ifndef </xsl:text>
-    <xsl:value-of select="$incguard"/>
-    <xsl:text>
-#define </xsl:text>
-    <xsl:value-of select="$incguard"/>
-    <xsl:text>
-#include "ooxml/OOXMLFactory.hxx"
-#include "OOXMLFactory_generated.hxx"
-#include "ooxml/OOXMLnamespaceids.hxx"
-#include "ooxml/resourceids.hxx"
-
-namespace writerfilter {
-namespace ooxml {
-
-/// @cond GENERATED
-    </xsl:text>
-    <xsl:for-each select="/model/namespace[@name=$ns]">
-        <xsl:call-template name="factorydecl"/>
-    </xsl:for-each>
-    <xsl:text>
-/// @endcond
-}}
-#endif //</xsl:text>
-    <xsl:value-of select="$incguard"/>
-    <xsl:text>&#xa;</xsl:text>
-</xsl:template>
-
-</xsl:stylesheet>
diff --git a/writerfilter/source/ooxml/factorytools.xsl b/writerfilter/source/ooxml/factorytools.xsl
index 337d258..e99669a 100644
--- a/writerfilter/source/ooxml/factorytools.xsl
+++ b/writerfilter/source/ooxml/factorytools.xsl
@@ -71,17 +71,6 @@
 
 <xsl:key name="same-token-name" match="rng:element|rng:attribute" use="@localname"/>
 
-<!-- license header -->
-<xsl:template name="licenseheader">
-  <xsl:text>
-/*      
-
-    THIS FILE IS GENERATED AUTOMATICALLY! DO NOT EDIT!
-    
-*/
-&#xa;</xsl:text>
-</xsl:template>
-
 <!--
 IDENTIFIERs
 -->


More information about the Libreoffice-commits mailing list