diff options
Diffstat (limited to 'sc/source/filter/xml/XMLColumnRowGroupExport.cxx')
-rw-r--r-- | sc/source/filter/xml/XMLColumnRowGroupExport.cxx | 187 |
1 files changed, 187 insertions, 0 deletions
diff --git a/sc/source/filter/xml/XMLColumnRowGroupExport.cxx b/sc/source/filter/xml/XMLColumnRowGroupExport.cxx new file mode 100644 index 000000000000..4c2929de02e3 --- /dev/null +++ b/sc/source/filter/xml/XMLColumnRowGroupExport.cxx @@ -0,0 +1,187 @@ +/************************************************************************* + * + * 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 --------------------------------------------------------------- +#include "XMLColumnRowGroupExport.hxx" +#include "xmlexprt.hxx" +#include <xmloff/nmspmap.hxx> +#include <xmloff/xmltoken.hxx> +#include <xmloff/xmlnmspe.hxx> + +#include <algorithm> + +using namespace xmloff::token; + +ScMyColumnRowGroup::ScMyColumnRowGroup() +{ +} + +sal_Bool ScMyColumnRowGroup::operator<(const ScMyColumnRowGroup& rGroup) const +{ + if (rGroup.nField > nField) + return sal_True; + else + if (rGroup.nField == nField && rGroup.nLevel > nLevel) + return sal_True; + else + return sal_False; +} + +ScMyOpenCloseColumnRowGroup::ScMyOpenCloseColumnRowGroup(ScXMLExport& rTempExport, sal_uInt32 nToken) + : rExport(rTempExport), + rName(rExport.GetNamespaceMap().GetQNameByKey(XML_NAMESPACE_TABLE, GetXMLToken(XMLTokenEnum(nToken)))), + aTableStart(), + aTableEnd() +{ +} + +ScMyOpenCloseColumnRowGroup::~ScMyOpenCloseColumnRowGroup() +{ +} + +void ScMyOpenCloseColumnRowGroup::NewTable() +{ + aTableStart.clear(); + aTableEnd.clear(); +} + +void ScMyOpenCloseColumnRowGroup::AddGroup(const ScMyColumnRowGroup& aGroup, const sal_Int32 nEndField) +{ + aTableStart.push_back(aGroup); + aTableEnd.push_back(nEndField); +} + +sal_Bool ScMyOpenCloseColumnRowGroup::IsGroupStart(const sal_Int32 nField) +{ + sal_Bool bGroupStart(sal_False); + if (!aTableStart.empty()) + { + ScMyColumnRowGroupVec::iterator aItr(aTableStart.begin()); + sal_Int32 nItrField = aItr->nField; + if ( nItrField < nField ) + { + // #103327# when used to find repeated rows at the beginning of a group, + // aTableStart may contain entries before nField. They must be skipped here + // (they will be used for OpenGroups later in the right order). + + ScMyColumnRowGroupVec::iterator aEnd(aTableStart.end()); + while ( aItr != aEnd && nItrField < nField ) + { + ++aItr; + if ( aItr != aEnd ) + nItrField = aItr->nField; + } + } + + if (nItrField == nField) + bGroupStart = sal_True; + } + return bGroupStart; +} + +void ScMyOpenCloseColumnRowGroup::OpenGroup(const ScMyColumnRowGroup& rGroup) +{ + if (!rGroup.bDisplay) + rExport.AddAttribute(XML_NAMESPACE_TABLE, XML_DISPLAY, XML_FALSE); + rExport.StartElement( rName, sal_True); +} + +void ScMyOpenCloseColumnRowGroup::OpenGroups(const sal_Int32 nField) +{ + ScMyColumnRowGroupVec::iterator aItr(aTableStart.begin()); + ScMyColumnRowGroupVec::iterator aEndItr(aTableStart.end()); + sal_Bool bReady(sal_False); + while(!bReady && aItr != aEndItr) + { + if (aItr->nField == nField) + { + OpenGroup(*aItr); + aItr = aTableStart.erase(aItr); + } + else + bReady = sal_True; + } +} + +sal_Bool ScMyOpenCloseColumnRowGroup::IsGroupEnd(const sal_Int32 nField) +{ + sal_Bool bGroupEnd(sal_False); + if (!aTableEnd.empty()) + { + if (*(aTableEnd.begin()) == nField) + bGroupEnd = sal_True; + } + return bGroupEnd; +} + +void ScMyOpenCloseColumnRowGroup::CloseGroup() +{ + rExport.EndElement( rName, sal_True ); +} + +void ScMyOpenCloseColumnRowGroup::CloseGroups(const sal_Int32 nField) +{ + ScMyFieldGroupVec::iterator aItr(aTableEnd.begin()); + ScMyFieldGroupVec::iterator aEndItr(aTableEnd.end()); + sal_Bool bReady(sal_False); + while(!bReady && aItr != aEndItr) + { + if (*aItr == nField) + { + CloseGroup(); + aItr = aTableEnd.erase(aItr); + } + else + bReady = sal_True; + } +} + +sal_Int32 ScMyOpenCloseColumnRowGroup::GetLast() +{ + sal_Int32 maximum(-1); + ScMyFieldGroupVec::iterator i(aTableEnd.begin()); + ScMyFieldGroupVec::iterator endi(aTableEnd.end()); + while (i != endi) + { + if (*i > maximum) + maximum = *i; + ++i; + } + return maximum; +} + +void ScMyOpenCloseColumnRowGroup::Sort() +{ + aTableStart.sort(); + aTableEnd.sort(); +} + |