summaryrefslogtreecommitdiff
path: root/sc/source/filter/xml/XMLDetectiveContext.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'sc/source/filter/xml/XMLDetectiveContext.cxx')
-rw-r--r--sc/source/filter/xml/XMLDetectiveContext.cxx266
1 files changed, 0 insertions, 266 deletions
diff --git a/sc/source/filter/xml/XMLDetectiveContext.cxx b/sc/source/filter/xml/XMLDetectiveContext.cxx
deleted file mode 100644
index 8762d6ec3..000000000
--- a/sc/source/filter/xml/XMLDetectiveContext.cxx
+++ /dev/null
@@ -1,266 +0,0 @@
-/* -*- 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.
- *
- ************************************************************************/
-
-// MARKER(update_precomp.py): autogen include statement, do not remove
-#include "precompiled_sc.hxx"
-
-
-
-//___________________________________________________________________
-#include "XMLDetectiveContext.hxx"
-#include <xmloff/nmspmap.hxx>
-#include <xmloff/xmltoken.hxx>
-#include <xmloff/xmluconv.hxx>
-#include "convuno.hxx"
-#include "xmlimprt.hxx"
-#include "XMLConverter.hxx"
-#include "rangeutl.hxx"
-
-#include <algorithm>
-
-using ::rtl::OUString;
-using namespace ::com::sun::star;
-using namespace xmloff::token;
-
-
-//___________________________________________________________________
-
-ScMyImpDetectiveObj::ScMyImpDetectiveObj() :
- aSourceRange(),
- eObjType( SC_DETOBJ_NONE ),
- bHasError( false )
-{
-}
-
-//___________________________________________________________________
-
-sal_Bool ScMyImpDetectiveOp::operator<(const ScMyImpDetectiveOp& rDetOp) const
-{
- return (nIndex < rDetOp.nIndex);
-}
-
-void ScMyImpDetectiveOpArray::Sort()
-{
- aDetectiveOpList.sort();
-}
-
-sal_Bool ScMyImpDetectiveOpArray::GetFirstOp( ScMyImpDetectiveOp& rDetOp )
-{
- if( aDetectiveOpList.empty() )
- return false;
- ScMyImpDetectiveOpList::iterator aItr = aDetectiveOpList.begin();
- rDetOp = *aItr;
- aDetectiveOpList.erase( aItr );
- return sal_True;
-}
-
-
-//___________________________________________________________________
-
-ScXMLDetectiveContext::ScXMLDetectiveContext(
- ScXMLImport& rImport,
- sal_uInt16 nPrfx,
- const OUString& rLName,
- ScMyImpDetectiveObjVec* pNewDetectiveObjVec ) :
- SvXMLImportContext( rImport, nPrfx, rLName ),
- pDetectiveObjVec( pNewDetectiveObjVec )
-{
-}
-
-ScXMLDetectiveContext::~ScXMLDetectiveContext()
-{
-}
-
-SvXMLImportContext *ScXMLDetectiveContext::CreateChildContext(
- sal_uInt16 nPrefix,
- const OUString& rLName,
- const uno::Reference< xml::sax::XAttributeList>& xAttrList )
-{
- SvXMLImportContext* pContext = NULL;
- const SvXMLTokenMap& rTokenMap = GetScImport().GetDetectiveElemTokenMap();
-
- switch( rTokenMap.Get( nPrefix, rLName ) )
- {
- case XML_TOK_DETECTIVE_ELEM_HIGHLIGHTED:
- pContext = new ScXMLDetectiveHighlightedContext( GetScImport(), nPrefix, rLName, xAttrList, pDetectiveObjVec );
- break;
- case XML_TOK_DETECTIVE_ELEM_OPERATION:
- pContext = new ScXMLDetectiveOperationContext( GetScImport(), nPrefix, rLName, xAttrList );
- break;
- }
- if( !pContext )
- pContext = new SvXMLImportContext( GetImport(), nPrefix, rLName );
-
- return pContext;
-}
-
-void ScXMLDetectiveContext::EndElement()
-{
-}
-
-
-//___________________________________________________________________
-
-ScXMLDetectiveHighlightedContext::ScXMLDetectiveHighlightedContext(
- ScXMLImport& rImport,
- sal_uInt16 nPrfx,
- const OUString& rLName,
- const uno::Reference< xml::sax::XAttributeList >& xAttrList,
- ScMyImpDetectiveObjVec* pNewDetectiveObjVec ):
- SvXMLImportContext( rImport, nPrfx, rLName ),
- pDetectiveObjVec( pNewDetectiveObjVec ),
- aDetectiveObj(),
- bValid( false )
-{
- if( !xAttrList.is() ) return;
-
- sal_Int16 nAttrCount = xAttrList->getLength();
- const SvXMLTokenMap& rAttrTokenMap = GetScImport().GetDetectiveHighlightedAttrTokenMap();
-
- for( sal_Int16 nIndex = 0; nIndex < nAttrCount; ++nIndex )
- {
- const rtl::OUString& sAttrName (xAttrList->getNameByIndex( nIndex ));
- const rtl::OUString& sValue (xAttrList->getValueByIndex( nIndex ));
- OUString aLocalName;
- sal_uInt16 nPrefix = GetScImport().GetNamespaceMap().GetKeyByAttrName( sAttrName, &aLocalName );
-
- switch( rAttrTokenMap.Get( nPrefix, aLocalName ) )
- {
- case XML_TOK_DETECTIVE_HIGHLIGHTED_ATTR_CELL_RANGE:
- {
- sal_Int32 nOffset(0);
- ScXMLImport::MutexGuard aGuard(GetScImport());
- bValid = ScRangeStringConverter::GetRangeFromString( aDetectiveObj.aSourceRange, sValue, GetScImport().GetDocument(), ::formula::FormulaGrammar::CONV_OOO, nOffset );
- }
- break;
- case XML_TOK_DETECTIVE_HIGHLIGHTED_ATTR_DIRECTION:
- aDetectiveObj.eObjType = ScXMLConverter::GetDetObjTypeFromString( sValue );
- break;
- case XML_TOK_DETECTIVE_HIGHLIGHTED_ATTR_CONTAINS_ERROR:
- aDetectiveObj.bHasError = IsXMLToken(sValue, XML_TRUE);
- break;
- case XML_TOK_DETECTIVE_HIGHLIGHTED_ATTR_MARKED_INVALID:
- {
- if (IsXMLToken(sValue, XML_TRUE))
- aDetectiveObj.eObjType = SC_DETOBJ_CIRCLE;
- }
- break;
- }
- }
-}
-
-ScXMLDetectiveHighlightedContext::~ScXMLDetectiveHighlightedContext()
-{
-}
-
-SvXMLImportContext *ScXMLDetectiveHighlightedContext::CreateChildContext(
- sal_uInt16 nPrefix,
- const OUString& rLName,
- const uno::Reference< xml::sax::XAttributeList>& /* xAttrList */ )
-{
- return new SvXMLImportContext( GetImport(), nPrefix, rLName );
-}
-
-void ScXMLDetectiveHighlightedContext::EndElement()
-{
- switch( aDetectiveObj.eObjType )
- {
- case SC_DETOBJ_ARROW:
- case SC_DETOBJ_TOOTHERTAB:
- break;
- case SC_DETOBJ_FROMOTHERTAB:
- case SC_DETOBJ_CIRCLE:
- bValid = sal_True;
- break;
- default:
- bValid = false;
- }
- if( bValid )
- pDetectiveObjVec->push_back( aDetectiveObj );
-}
-
-
-//___________________________________________________________________
-
-ScXMLDetectiveOperationContext::ScXMLDetectiveOperationContext(
- ScXMLImport& rImport,
- sal_uInt16 nPrfx,
- const OUString& rLName,
- const uno::Reference< xml::sax::XAttributeList >& xAttrList ) :
- SvXMLImportContext( rImport, nPrfx, rLName ),
- aDetectiveOp(),
- bHasType( false )
-{
- if( !xAttrList.is() ) return;
-
- sal_Int16 nAttrCount = xAttrList->getLength();
- const SvXMLTokenMap& rAttrTokenMap = GetScImport().GetDetectiveOperationAttrTokenMap();
-
- for( sal_Int16 nIndex = 0; nIndex < nAttrCount; ++nIndex )
- {
- const rtl::OUString& sAttrName (xAttrList->getNameByIndex( nIndex ));
- const rtl::OUString& sValue (xAttrList->getValueByIndex( nIndex ));
- OUString aLocalName;
- sal_uInt16 nPrefix = GetScImport().GetNamespaceMap().GetKeyByAttrName( sAttrName, &aLocalName );
-
- switch( rAttrTokenMap.Get( nPrefix, aLocalName ) )
- {
- case XML_TOK_DETECTIVE_OPERATION_ATTR_NAME:
- bHasType = ScXMLConverter::GetDetOpTypeFromString( aDetectiveOp.eOpType, sValue );
- break;
- case XML_TOK_DETECTIVE_OPERATION_ATTR_INDEX:
- {
- sal_Int32 nValue;
- if( SvXMLUnitConverter::convertNumber( nValue, sValue, 0 ) )
- aDetectiveOp.nIndex = nValue;
- }
- break;
- }
- }
- ScUnoConversion::FillScAddress( aDetectiveOp.aPosition, rImport.GetTables().GetRealCellPos() );
-}
-
-ScXMLDetectiveOperationContext::~ScXMLDetectiveOperationContext()
-{
-}
-
-SvXMLImportContext *ScXMLDetectiveOperationContext::CreateChildContext(
- sal_uInt16 nPrefix,
- const OUString& rLName,
- const uno::Reference< xml::sax::XAttributeList>& /* xAttrList */ )
-{
- return new SvXMLImportContext( GetImport(), nPrefix, rLName );
-}
-
-void ScXMLDetectiveOperationContext::EndElement()
-{
- if( bHasType && (aDetectiveOp.nIndex >= 0) )
- GetScImport().GetDetectiveOpArray()->AddDetectiveOp( aDetectiveOp );
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */