Kaydet (Commit) a5b4cb3f authored tarafından Troy Rollo's avatar Troy Rollo Kaydeden (comit) Michael Stahl

tdf#103091 conditional style conditions not saved

Change-Id: Iccf3eb531ee3382d27105e5ccce6013707a646b6
Reviewed-on: https://gerrit.libreoffice.org/38451Tested-by: 's avatarJenkins <ci@libreoffice.org>
Reviewed-by: 's avatarMichael Stahl <mstahl@redhat.com>
üst 3c641c9c
......@@ -1997,7 +1997,8 @@ void SwXStyle::SetPropertyValues_Impl(const uno::Sequence<OUString>& rPropertyNa
{
if(!m_pDoc)
throw uno::RuntimeException();
const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(m_rEntry.m_nPropMapType);
sal_Int8 nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : m_rEntry.m_nPropMapType;
const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
const SfxItemPropertyMap &rMap = pPropSet->getPropertyMap();
if(rPropertyNames.getLength() != rValues.getLength())
throw lang::IllegalArgumentException();
......
......@@ -31,6 +31,7 @@
#include "docary.hxx"
#include <IDocumentStylePoolAccess.hxx>
#include "unostyle.hxx"
#include "unoprnms.hxx"
#include "fmtpdsc.hxx"
#include "pagedesc.hxx"
#include <xmloff/xmlnmspe.hxx>
......@@ -44,6 +45,7 @@
#include <xmloff/XMLTextMasterStylesContext.hxx>
#include <xmloff/XMLTextShapeStyleContext.hxx>
#include <xmloff/XMLGraphicsDefaultStyle.hxx>
#include <com/sun/star/beans/XPropertySet.hpp>
#include "xmlimp.hxx"
#include "xmltbli.hxx"
#include "cellatr.hxx"
......@@ -51,10 +53,13 @@
#include <xmloff/attrlist.hxx>
#include <unotxdoc.hxx>
#include <docsh.hxx>
#include <ccoll.hxx>
#include <memory>
using namespace ::com::sun::star;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::uno;
using namespace ::xmloff::token;
class SwXMLConditionParser_Impl
......@@ -205,6 +210,10 @@ public:
const uno::Reference< xml::sax::XAttributeList > & xAttrList );
bool IsValid() const { return Master_CollCondition::NONE != nCondition; }
Master_CollCondition getCondition() const { return nCondition; }
sal_uInt32 getSubCondition() const { return nSubCondition; }
OUString const &getApplyStyle() const { return sApplyStyle; }
};
SwXMLConditionContext_Impl::SwXMLConditionContext_Impl(
......@@ -250,10 +259,12 @@ typedef std::vector<rtl::Reference<SwXMLConditionContext_Impl>> SwXMLConditions_
class SwXMLTextStyleContext_Impl : public XMLTextStyleContext
{
std::unique_ptr<SwXMLConditions_Impl> pConditions;
uno::Reference < style::XStyle > xNewStyle;
protected:
virtual uno::Reference < style::XStyle > Create() override;
virtual void Finish( bool bOverwrite ) override;
public:
......@@ -273,7 +284,6 @@ public:
uno::Reference < style::XStyle > SwXMLTextStyleContext_Impl::Create()
{
uno::Reference < style::XStyle > xNewStyle;
if( pConditions && XML_STYLE_FAMILY_TEXT_PARAGRAPH == GetFamily() )
{
......@@ -295,6 +305,46 @@ uno::Reference < style::XStyle > SwXMLTextStyleContext_Impl::Create()
return xNewStyle;
}
void
SwXMLTextStyleContext_Impl::Finish( bool bOverwrite )
{
if( pConditions && XML_STYLE_FAMILY_TEXT_PARAGRAPH == GetFamily() && xNewStyle.is() )
{
CommandStruct const *aCommands = SwCondCollItem::GetCmds();
Reference< XPropertySet > xPropSet( xNewStyle, UNO_QUERY );
uno::Sequence< beans::NamedValue > aSeq( pConditions->size() );
std::vector<rtl::Reference<SwXMLConditionContext_Impl>>::size_type i;
unsigned j;
for( i = 0; i < pConditions->size(); ++i )
{
if( (*pConditions)[i]->IsValid() )
{
Master_CollCondition nCond = (*pConditions)[i]->getCondition();
sal_uInt32 nSubCond = (*pConditions)[i]->getSubCondition();
for( j = 0; j < COND_COMMAND_COUNT; ++j )
{
if( aCommands[j].nCnd == nCond &&
aCommands[j].nSubCond == nSubCond )
{
aSeq[i].Name = GetCommandContextByIndex( j );
aSeq[i].Value <<= GetImport().GetStyleDisplayName( GetFamily(), (*pConditions)[i]->getApplyStyle() );
break;
}
}
}
}
xPropSet->setPropertyValue( UNO_NAME_PARA_STYLE_CONDITIONS, uno::makeAny( aSeq ) );
}
XMLTextStyleContext::Finish( bOverwrite );
}
SwXMLTextStyleContext_Impl::SwXMLTextStyleContext_Impl( SwXMLImport& rImport,
sal_uInt16 nPrfx, const OUString& rLName,
const uno::Reference< xml::sax::XAttributeList > & xAttrList,
......
......@@ -252,6 +252,7 @@ $(eval $(call gb_Library_add_exception_objects,xo,\
xmloff/source/style/postuhdl \
xmloff/source/style/prhdlfac \
xmloff/source/style/prstylei \
xmloff/source/style/prstylecond \
xmloff/source/style/shadwhdl \
xmloff/source/style/shdwdhdl \
xmloff/source/style/styleexp \
......
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
OUString GetParaStyleCondExternal( OUString const &);
OUString GetParaStyleCondInternal( OUString const &);
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#include <rtl/ustring.hxx>
#include "prstylecond.hxx"
#include <xmloff/xmltoken.hxx>
using namespace ::xmloff::token;
static struct ConditionMap
{
char const* aInternal;
XMLTokenEnum nExternal;
int aValue;
} aConditionMap[] =
{
{ "TableHeader", XML_TABLE_HEADER, -1 },
{ "Table", XML_TABLE, -1 },
{ "Frame", XML_TEXT_BOX, -1 }, // FIXME - Not in ODF spec
{ "Section", XML_SECTION, -1 },
{ "Footnote", XML_FOOTNOTE, -1 },
{ "Endnote", XML_ENDNOTE, -1 },
{ "Header", XML_HEADER, -1 },
{ "Footer", XML_FOOTER, -1 },
{ "OutlineLevel1", XML_OUTLINE_LEVEL, 1 },
{ "OutlineLevel2", XML_OUTLINE_LEVEL, 2 },
{ "OutlineLevel3", XML_OUTLINE_LEVEL, 3 },
{ "OutlineLevel4", XML_OUTLINE_LEVEL, 4 },
{ "OutlineLevel5", XML_OUTLINE_LEVEL, 5 },
{ "OutlineLevel6", XML_OUTLINE_LEVEL, 6 },
{ "OutlineLevel7", XML_OUTLINE_LEVEL, 7 },
{ "OutlineLevel8", XML_OUTLINE_LEVEL, 8 },
{ "OutlineLevel9", XML_OUTLINE_LEVEL, 9 },
{ "OutlineLevel10", XML_OUTLINE_LEVEL, 10 },
{ "NumberingLevel1", XML_LIST_LEVEL, 1 },
{ "NumberingLevel2", XML_LIST_LEVEL, 2 },
{ "NumberingLevel3", XML_LIST_LEVEL, 3 },
{ "NumberingLevel4", XML_LIST_LEVEL, 4 },
{ "NumberingLevel5", XML_LIST_LEVEL, 5 },
{ "NumberingLevel6", XML_LIST_LEVEL, 6 },
{ "NumberingLevel7", XML_LIST_LEVEL, 7 },
{ "NumberingLevel8", XML_LIST_LEVEL, 8 },
{ "NumberingLevel9", XML_LIST_LEVEL, 9 },
{ "NumberingLevel10", XML_LIST_LEVEL, 10 }
};
#define CONDITION_COUNT (sizeof(aConditionMap) / sizeof(aConditionMap[0]))
OUString GetParaStyleCondExternal( OUString const &internal)
{
unsigned i;
for(i = 0; i < CONDITION_COUNT; ++i)
{
if(internal.compareToAscii( aConditionMap[i].aInternal ) == 0)
{
OUString aResult( GetXMLToken( aConditionMap[i].nExternal ) );
aResult += "()";
if( aConditionMap[i].aValue != -1 )
{
aResult += "=";
aResult += OUString::number( aConditionMap[i].aValue );
}
return aResult;
}
}
return OUString();
}
OUString GetParaStyleCondInternal( OUString const &external)
{
sal_Int32 paren = external.indexOf('(');
if( paren > 0 && external[paren + 1] == ')' )
{
OUString stub( external.getStr(), paren );
int numval = -1;
unsigned i;
if(external.getLength() > paren + 2)
{
if(external[paren + 2] == '=')
{
OUString num( external.getStr() + 3 );
numval = num.toInt32();
}
else
{
return OUString();
}
}
for(i = 0; i < CONDITION_COUNT; ++i)
{
if( aConditionMap[i].aValue == numval &&
stub == GetXMLToken( aConditionMap[i].nExternal ) )
{
return OUString( aConditionMap[i].aInternal,
strlen( aConditionMap[i].aInternal ),
RTL_TEXTENCODING_ASCII_US );
}
}
}
return OUString();
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
......@@ -32,6 +32,7 @@
#include <com/sun/star/style/XStyleFamiliesSupplier.hpp>
#include <com/sun/star/style/XStyle.hpp>
#include <com/sun/star/container/XNameContainer.hpp>
#include <com/sun/star/beans/NamedValue.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <com/sun/star/beans/XPropertyState.hpp>
#include <com/sun/star/document/XEventsSupplier.hpp>
......@@ -43,6 +44,7 @@
#include <xmloff/maptype.hxx>
#include <memory>
#include <set>
#include "prstylecond.hxx"
using namespace ::com::sun::star;
using namespace ::com::sun::star::uno;
......@@ -75,8 +77,54 @@ void XMLStyleExport::exportStyleAttributes( const Reference< XStyle >& )
{
}
void XMLStyleExport::exportStyleContent( const Reference< XStyle >& )
void XMLStyleExport::exportStyleContent( const Reference< XStyle >& rStyle )
{
Reference< XPropertySet > xPropSet( rStyle, UNO_QUERY );
try
{
uno::Any aProperty = xPropSet->getPropertyValue( "ParaStyleConditions" );
uno::Sequence< beans::NamedValue > aSeq;
int i;
aProperty >>= aSeq;
for(i = 0; i < aSeq.getLength(); ++i)
{
beans::NamedValue const& aNamedCond = aSeq[i];
OUString aStyleName;
if ( aNamedCond.Value >>= aStyleName )
{
if ( aStyleName.getLength() > 0 )
{
OUString aExternal = GetParaStyleCondExternal( aNamedCond.Name );
if (aExternal.getLength() > 0)
{
bool bEncoded;
GetExport().AddAttribute( XML_NAMESPACE_STYLE,
XML_CONDITION,
aExternal);
GetExport().AddAttribute( XML_NAMESPACE_STYLE,
XML_APPLY_STYLE_NAME,
GetExport().EncodeStyleName( aStyleName,
&bEncoded ) );
SvXMLElementExport aElem( GetExport(),
XML_NAMESPACE_STYLE,
XML_MAP,
true,
true );
}
}
}
}
}
catch( const beans::UnknownPropertyException& )
{
}
}
bool XMLStyleExport::exportStyle(
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment