diff options
Diffstat (limited to 'binfilter/bf_sc/source/filter/xml/sc_XMLColumnRowGroupExport.cxx')
-rw-r--r-- | binfilter/bf_sc/source/filter/xml/sc_XMLColumnRowGroupExport.cxx | 185 |
1 files changed, 185 insertions, 0 deletions
diff --git a/binfilter/bf_sc/source/filter/xml/sc_XMLColumnRowGroupExport.cxx b/binfilter/bf_sc/source/filter/xml/sc_XMLColumnRowGroupExport.cxx new file mode 100644 index 000000000000..2e1e371bcb84 --- /dev/null +++ b/binfilter/bf_sc/source/filter/xml/sc_XMLColumnRowGroupExport.cxx @@ -0,0 +1,185 @@ +/* -*- 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. + * + ************************************************************************/ + +#ifdef _MSC_VER +#pragma hdrstop +#endif + +// INCLUDE --------------------------------------------------------------- + +#include "XMLColumnRowGroupExport.hxx" +#include "xmlexprt.hxx" + +#include <bf_xmloff/nmspmap.hxx> +#include <bf_xmloff/xmlnmspe.hxx> + +#include <algorithm> +namespace binfilter { + +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), + aTableStart(), + aTableEnd(), + rName(rExport.GetNamespaceMap().GetQNameByKey(XML_NAMESPACE_TABLE, GetXMLToken(XMLTokenEnum(nToken)))) +{ +} + +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(); + sal_Bool bReady(sal_False); + while(!bReady && aItr != aTableStart.end()) + { + 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(); + sal_Bool bReady(sal_False); + while(!bReady && aItr != aTableEnd.end()) + { + if (*aItr == nField) + { + CloseGroup(); + aItr = aTableEnd.erase(aItr); + } + else + bReady = sal_True; + } +} + +sal_Int32 ScMyOpenCloseColumnRowGroup::GetLast() +{ + sal_Int32 maximum(-1); + for (ScMyFieldGroupVec::iterator i = aTableEnd.begin(); i != aTableEnd.end(); i++) + if (*i > maximum) + maximum = *i; + return maximum; +} + +void ScMyOpenCloseColumnRowGroup::Sort() +{ + aTableStart.sort(); + aTableEnd.sort(); +} + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |