summaryrefslogtreecommitdiff
path: root/xmloff/source/transform/PersAttrListTContext.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'xmloff/source/transform/PersAttrListTContext.hxx')
-rw-r--r--xmloff/source/transform/PersAttrListTContext.hxx125
1 files changed, 125 insertions, 0 deletions
diff --git a/xmloff/source/transform/PersAttrListTContext.hxx b/xmloff/source/transform/PersAttrListTContext.hxx
new file mode 100644
index 000000000000..2fb823224f07
--- /dev/null
+++ b/xmloff/source/transform/PersAttrListTContext.hxx
@@ -0,0 +1,125 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2008 by Sun Microsystems, Inc.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * $RCSfile: PersAttrListTContext.hxx,v $
+ * $Revision: 1.7 $
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org 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 Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+#ifndef _XMLOFF_PERSATTRLISTTCONTEXT_HXX
+#define _XMLOFF_PERSATTRLISTTCONTEXT_HXX
+
+#include <xmloff/xmltoken.hxx>
+#include "TransformerContext.hxx"
+
+
+class XMLPersAttrListTContext : public XMLTransformerContext
+{
+
+ ::com::sun::star::uno::Reference<
+ ::com::sun::star::xml::sax::XAttributeList > m_xAttrList;
+ ::rtl::OUString m_aElemQName;
+ sal_uInt16 m_nActionMap;
+
+protected:
+
+ void SetExportQName( const ::rtl::OUString& r ) { m_aElemQName = r; }
+
+public:
+ TYPEINFO();
+
+ // A contexts constructor does anything that is required if an element
+ // starts. Namespace processing has been done already.
+ // Note that virtual methods cannot be used inside constructors. Use
+ // StartElement instead if this is required.
+ XMLPersAttrListTContext( XMLTransformerBase& rTransformer,
+ const ::rtl::OUString& rQName );
+
+ // attr list persistence + attribute processing
+ XMLPersAttrListTContext( XMLTransformerBase& rTransformer,
+ const ::rtl::OUString& rQName,
+ sal_uInt16 nActionMap );
+
+ // attr list persistence + renaming
+ XMLPersAttrListTContext( XMLTransformerBase& rTransformer,
+ const ::rtl::OUString& rQName,
+ sal_uInt16 nPrefix,
+ ::xmloff::token::XMLTokenEnum eToken );
+
+ // attr list persistence + renaming + attribute processing
+ XMLPersAttrListTContext( XMLTransformerBase& rTransformer,
+ const ::rtl::OUString& rQName,
+ sal_uInt16 nPrefix,
+ ::xmloff::token::XMLTokenEnum eToken,
+ sal_uInt16 nActionMap );
+
+ // A contexts destructor does anything that is required if an element
+ // ends. By default, nothing is done.
+ // Note that virtual methods cannot be used inside destructors. Use
+ // EndElement instead if this is required.
+ virtual ~XMLPersAttrListTContext();
+
+ // Create a childs element context. By default, the import's
+ // CreateContext method is called to create a new default context.
+ virtual XMLTransformerContext *CreateChildContext( sal_uInt16 nPrefix,
+ const ::rtl::OUString& rLocalName,
+ const ::rtl::OUString& rQName,
+ const ::com::sun::star::uno::Reference< ::com::sun::star::xml::sax::XAttributeList >& xAttrList );
+
+ // StartElement is called after a context has been constructed and
+ // before a elements context is parsed. It may be used for actions that
+ // require virtual methods. The default is to do nothing.
+ virtual void StartElement( const ::com::sun::star::uno::Reference< ::com::sun::star::xml::sax::XAttributeList >& xAttrList );
+
+ // EndElement is called before a context will be destructed, but
+ // after a elements context has been parsed. It may be used for actions
+ // that require virtual methods. The default is to do nothing.
+ virtual void EndElement();
+
+ // This method is called for all characters that are contained in the
+ // current element.
+ virtual void Characters( const ::rtl::OUString& rChars );
+
+ virtual sal_Bool IsPersistent() const;
+ virtual void Export();
+ virtual void ExportContent();
+
+ const ::rtl::OUString& GetExportQName() const { return m_aElemQName; }
+
+ void AddAttribute( sal_uInt16 nAPrefix,
+ ::xmloff::token::XMLTokenEnum eAToken,
+ ::xmloff::token::XMLTokenEnum eVToken );
+
+ void AddAttribute( sal_uInt16 nAPrefix,
+ ::xmloff::token::XMLTokenEnum eAToken,
+ const ::rtl::OUString & rValue );
+
+ ::com::sun::star::uno::Reference<
+ ::com::sun::star::xml::sax::XAttributeList >
+ GetAttrList() const;
+};
+
+#endif // _XMLOFF_PERSATTRLISTTCONTEXT_HXX
+