summaryrefslogtreecommitdiff
path: root/reportdesign/source/filter/xml/xmlFixedContent.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'reportdesign/source/filter/xml/xmlFixedContent.cxx')
-rw-r--r--reportdesign/source/filter/xml/xmlFixedContent.cxx244
1 files changed, 244 insertions, 0 deletions
diff --git a/reportdesign/source/filter/xml/xmlFixedContent.cxx b/reportdesign/source/filter/xml/xmlFixedContent.cxx
new file mode 100644
index 000000000000..284a678227e9
--- /dev/null
+++ b/reportdesign/source/filter/xml/xmlFixedContent.cxx
@@ -0,0 +1,244 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * 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.
+ *
+ ************************************************************************/
+#include "precompiled_reportdesign.hxx"
+#include "xmlFixedContent.hxx"
+#include "xmlfilter.hxx"
+#include <xmloff/xmltoken.hxx>
+#include <xmloff/xmlnmspe.hxx>
+#include <xmloff/nmspmap.hxx>
+#include "xmlEnums.hxx"
+#include "xmlReportElement.hxx"
+#include <tools/debug.hxx>
+#include <com/sun/star/report/XShape.hpp>
+#include "xmlCell.hxx"
+#include "xmlstrings.hrc"
+#include <com/sun/star/report/XShape.hpp>
+#include <com/sun/star/report/XFormattedField.hpp>
+#include <com/sun/star/report/XFixedText.hpp>
+#include <com/sun/star/text/ControlCharacter.hpp>
+#include "xmlTable.hxx"
+#include <xmloff/XMLCharContext.hxx>
+
+namespace rptxml
+{
+ using namespace ::com::sun::star;
+
+class OXMLCharContent : public XMLCharContext
+{
+ OXMLFixedContent* m_pFixedContent;
+ OXMLCharContent(const OXMLCharContent&);
+ void operator =(const OXMLCharContent&);
+public:
+ OXMLCharContent(
+ SvXMLImport& rImport,
+ OXMLFixedContent* _pFixedContent,
+ sal_uInt16 nPrfx,
+ const ::rtl::OUString& rLName,
+ const uno::Reference< xml::sax::XAttributeList > & xAttrList,
+ sal_Unicode c,
+ sal_Bool bCount );
+ OXMLCharContent(
+ SvXMLImport& rImport,
+ OXMLFixedContent* _pFixedContent,
+ sal_uInt16 nPrfx,
+ const ::rtl::OUString& rLName,
+ const uno::Reference< xml::sax::XAttributeList > & xAttrList,
+ sal_Int16 nControl );
+
+ virtual void InsertControlCharacter(sal_Int16 _nControl);
+ virtual void InsertString(const ::rtl::OUString& _sString);
+};
+OXMLCharContent::OXMLCharContent(
+ SvXMLImport& rImport,
+ OXMLFixedContent* _pFixedContent,
+ sal_uInt16 nPrfx,
+ const ::rtl::OUString& rLName,
+ const uno::Reference< xml::sax::XAttributeList > & xAttrList,
+ sal_Unicode c,
+ sal_Bool bCount )
+ : XMLCharContext(rImport,nPrfx,rLName,xAttrList,c,bCount)
+ ,m_pFixedContent(_pFixedContent)
+{
+}
+// -----------------------------------------------------------------------------
+OXMLCharContent::OXMLCharContent(
+ SvXMLImport& rImport,
+ OXMLFixedContent* _pFixedContent,
+ sal_uInt16 nPrfx,
+ const ::rtl::OUString& rLName,
+ const uno::Reference< xml::sax::XAttributeList > & xAttrList,
+ sal_Int16 nControl )
+ : XMLCharContext(rImport,nPrfx,rLName,xAttrList,nControl)
+ ,m_pFixedContent(_pFixedContent)
+{
+}
+// -----------------------------------------------------------------------------
+void OXMLCharContent::InsertControlCharacter(sal_Int16 _nControl)
+{
+ switch( _nControl )
+ {
+ case ControlCharacter::LINE_BREAK:
+ m_pFixedContent->Characters(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("\n")));
+ break;
+ default:
+ OSL_ENSURE(0,"Not supported control character");
+ break;
+ }
+}
+// -----------------------------------------------------------------------------
+void OXMLCharContent::InsertString(const ::rtl::OUString& _sString)
+{
+ m_pFixedContent->Characters(_sString);
+}
+// -----------------------------------------------------------------------------
+
+DBG_NAME( rpt_OXMLFixedContent )
+
+OXMLFixedContent::OXMLFixedContent( ORptFilter& rImport,
+ sal_uInt16 nPrfx, const ::rtl::OUString& rLName
+ ,OXMLCell& _rCell
+ ,OXMLTable* _pContainer
+ ,OXMLFixedContent* _pInP) :
+ OXMLReportElementBase( rImport, nPrfx, rLName,NULL,_pContainer)
+,m_rCell(_rCell)
+,m_pInP(_pInP)
+,m_bFormattedField(false)
+{
+ DBG_CTOR( rpt_OXMLFixedContent,NULL);
+}
+// -----------------------------------------------------------------------------
+
+OXMLFixedContent::~OXMLFixedContent()
+{
+
+ DBG_DTOR( rpt_OXMLFixedContent,NULL);
+}
+// -----------------------------------------------------------------------------
+// -----------------------------------------------------------------------------
+SvXMLImportContext* OXMLFixedContent::_CreateChildContext(
+ sal_uInt16 nPrefix,
+ const ::rtl::OUString& rLocalName,
+ const Reference< XAttributeList > & xAttrList )
+{
+ SvXMLImportContext *pContext = OXMLReportElementBase::_CreateChildContext(nPrefix,rLocalName,xAttrList);
+ if ( pContext )
+ return pContext;
+
+ static const ::rtl::OUString s_sStringConcat(RTL_CONSTASCII_USTRINGPARAM(" & "));
+ const SvXMLTokenMap& rTokenMap = m_rImport.GetCellElemTokenMap();
+ Reference<XMultiServiceFactory> xFactor = m_rImport.getServiceFactory();
+
+ m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP );
+ const sal_uInt16 nToken = rTokenMap.Get( nPrefix, rLocalName );
+ switch( nToken )
+ {
+ case XML_TOK_P:
+ pContext = new OXMLFixedContent(m_rImport,nPrefix, rLocalName,m_rCell,m_pContainer,this);
+ break;
+ case XML_TOK_TEXT_TAB_STOP:
+ pContext = new OXMLCharContent( m_rImport, this,nPrefix,
+ rLocalName, xAttrList,
+ 0x0009, sal_False );
+ break;
+
+ case XML_TOK_TEXT_LINE_BREAK:
+ pContext = new OXMLCharContent( m_rImport, this,nPrefix,
+ rLocalName, xAttrList,
+ ControlCharacter::LINE_BREAK );
+ break;
+
+ case XML_TOK_TEXT_S:
+ pContext = new OXMLCharContent( m_rImport, this,nPrefix,
+ rLocalName, xAttrList,
+ 0x0020, sal_True );
+ break;
+ case XML_TOK_PAGE_NUMBER:
+ m_sPageText += s_sStringConcat + ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(" PageNumber()"));
+ m_bFormattedField = true;
+ break;
+ case XML_TOK_PAGE_COUNT:
+ m_sPageText += s_sStringConcat + ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(" PageCount()"));
+ m_bFormattedField = true;
+ break;
+ default:
+ ;
+ }
+ return pContext;
+}
+// -----------------------------------------------------------------------------
+void OXMLFixedContent::EndElement()
+{
+ if ( m_pInP )
+ {
+ const Reference<XMultiServiceFactory> xFactor(m_rImport.GetModel(),uno::UNO_QUERY);
+ if ( m_bFormattedField )
+ {
+ uno::Reference< uno::XInterface> xInt = xFactor->createInstance(SERVICE_FORMATTEDFIELD);
+ Reference< report::XFormattedField > xControl(xInt,uno::UNO_QUERY);
+ xControl->setDataField(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("rpt:")) + m_sPageText);
+ OSL_ENSURE(xControl.is(),"Could not create FormattedField!");
+ m_pInP->m_xComponent = xControl.get();
+ m_xComponent = xControl.get();
+ }
+ else
+ {
+ Reference< XFixedText > xControl(xFactor->createInstance(SERVICE_FIXEDTEXT),uno::UNO_QUERY);
+ OSL_ENSURE(xControl.is(),"Could not create FixedContent!");
+ m_pInP->m_xComponent = xControl.get();
+ m_xComponent = xControl.get();
+ xControl->setLabel(m_sLabel);
+ }
+
+ m_pContainer->addCell(m_xComponent);
+ m_rCell.setComponent(m_xComponent);
+
+ OXMLReportElementBase::EndElement();
+ }
+}
+// -----------------------------------------------------------------------------
+void OXMLFixedContent::Characters( const ::rtl::OUString& rChars )
+{
+ m_sLabel += rChars;
+ if ( rChars.getLength() )
+ {
+ static const ::rtl::OUString s_Quote(RTL_CONSTASCII_USTRINGPARAM("\""));
+ if ( m_sPageText.getLength() )
+ {
+ static const ::rtl::OUString s_sStringConcat(RTL_CONSTASCII_USTRINGPARAM(" & "));
+ m_sPageText += s_sStringConcat;
+ }
+
+ m_sPageText += s_Quote + rChars + s_Quote;
+ }
+}
+
+//----------------------------------------------------------------------------
+} // namespace rptxml
+// -----------------------------------------------------------------------------
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */