office-gobmx/framework/source/fwe/xml/toolboxdocumenthandler.cxx
Noel Grandin ca8c59c7e6 use more concrete UNO type in framework
Change-Id: I3ee54f3967339ab52c04f48a047bc29fc5161680
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/173159
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
2024-09-11 16:14:54 +02:00

712 lines
27 KiB
C++

/* -*- 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 <xml/toolboxdocumenthandler.hxx>
#include <xml/toolboxconfigurationdefines.hxx>
#include <com/sun/star/xml/sax/SAXException.hpp>
#include <com/sun/star/xml/sax/XExtendedDocumentHandler.hpp>
#include <com/sun/star/ui/ItemType.hpp>
#include <com/sun/star/ui/ItemStyle.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <com/sun/star/container/XIndexAccess.hpp>
#include <com/sun/star/container/XIndexContainer.hpp>
#include <sal/config.h>
#include <sal/macros.h>
#include <vcl/settings.hxx>
#include <rtl/ref.hxx>
#include <rtl/ustrbuf.hxx>
#include <comphelper/propertysequence.hxx>
#include <comphelper/propertyvalue.hxx>
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::xml::sax;
constexpr OUStringLiteral TOOLBAR_DOCTYPE = u"<!DOCTYPE toolbar:toolbar PUBLIC \"-//OpenOffice.org//DTD OfficeDocument 1.0//EN\" \"toolbar.dtd\">";
namespace framework
{
// Property names of a menu/menu item ItemDescriptor
constexpr OUString ITEM_DESCRIPTOR_COMMANDURL = u"CommandURL"_ustr;
constexpr OUString ITEM_DESCRIPTOR_LABEL = u"Label"_ustr;
constexpr OUString ITEM_DESCRIPTOR_TYPE = u"Type"_ustr;
constexpr OUString ITEM_DESCRIPTOR_STYLE = u"Style"_ustr;
constexpr OUString ITEM_DESCRIPTOR_VISIBLE = u"IsVisible"_ustr;
static void ExtractToolbarParameters( const Sequence< PropertyValue >& rProp,
OUString& rCommandURL,
OUString& rLabel,
sal_Int16& rStyle,
bool& rVisible,
sal_Int16& rType )
{
for ( const PropertyValue& rEntry : rProp )
{
if ( rEntry.Name == ITEM_DESCRIPTOR_COMMANDURL )
rEntry.Value >>= rCommandURL;
else if ( rEntry.Name == ITEM_DESCRIPTOR_LABEL )
rEntry.Value >>= rLabel;
else if ( rEntry.Name == ITEM_DESCRIPTOR_TYPE )
rEntry.Value >>= rType;
else if ( rEntry.Name == ITEM_DESCRIPTOR_VISIBLE )
rEntry.Value >>= rVisible;
else if ( rEntry.Name == ITEM_DESCRIPTOR_STYLE )
rEntry.Value >>= rStyle;
}
}
namespace {
struct ToolboxStyleItem
{
sal_Int16 nBit;
OUString attrName;
};
}
constexpr ToolboxStyleItem Styles[ ] = {
{ css::ui::ItemStyle::RADIO_CHECK, ATTRIBUTE_ITEMSTYLE_RADIO },
{ css::ui::ItemStyle::ALIGN_LEFT, ATTRIBUTE_ITEMSTYLE_LEFT },
{ css::ui::ItemStyle::AUTO_SIZE, ATTRIBUTE_ITEMSTYLE_AUTO },
{ css::ui::ItemStyle::REPEAT, ATTRIBUTE_ITEMSTYLE_REPEAT },
{ css::ui::ItemStyle::DROPDOWN_ONLY, ATTRIBUTE_ITEMSTYLE_DROPDOWNONLY },
{ css::ui::ItemStyle::DROP_DOWN, ATTRIBUTE_ITEMSTYLE_DROPDOWN },
{ css::ui::ItemStyle::ICON, ATTRIBUTE_ITEMSTYLE_IMAGE },
{ css::ui::ItemStyle::TEXT, ATTRIBUTE_ITEMSTYLE_TEXT },
};
sal_Int32 const nStyleItemEntries = SAL_N_ELEMENTS(Styles);
namespace {
struct ToolBarEntryProperty
{
OReadToolBoxDocumentHandler::ToolBox_XML_Namespace nNamespace;
OUString aEntryName;
};
}
ToolBarEntryProperty constexpr ToolBoxEntries[OReadToolBoxDocumentHandler::TB_XML_ENTRY_COUNT] =
{
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, u"toolbar"_ustr },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, u"toolbaritem"_ustr },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, u"toolbarspace"_ustr },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, u"toolbarbreak"_ustr },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, u"toolbarseparator"_ustr },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, ATTRIBUTE_TEXT },
{ OReadToolBoxDocumentHandler::TB_NS_XLINK, ATTRIBUTE_URL },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, ATTRIBUTE_VISIBLE },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, ATTRIBUTE_ITEMSTYLE },
{ OReadToolBoxDocumentHandler::TB_NS_TOOLBAR, ATTRIBUTE_UINAME },
};
OReadToolBoxDocumentHandler::OReadToolBoxDocumentHandler( const Reference< XIndexContainer >& rItemContainer ) :
m_rItemContainer( rItemContainer ),
m_aType( ITEM_DESCRIPTOR_TYPE ),
m_aLabel( ITEM_DESCRIPTOR_LABEL ),
m_aStyle( ITEM_DESCRIPTOR_STYLE ),
m_aIsVisible( ITEM_DESCRIPTOR_VISIBLE ),
m_aCommandURL( ITEM_DESCRIPTOR_COMMANDURL )
{
// create hash map
for ( int i = 0; i < TB_XML_ENTRY_COUNT; i++ )
{
if ( ToolBoxEntries[i].nNamespace == TB_NS_TOOLBAR )
{
OUString temp = XMLNS_TOOLBAR XMLNS_FILTER_SEPARATOR +
ToolBoxEntries[i].aEntryName;
m_aToolBoxMap.emplace( temp, static_cast<ToolBox_XML_Entry>(i) );
}
else
{
OUString temp = XMLNS_XLINK XMLNS_FILTER_SEPARATOR +
ToolBoxEntries[i].aEntryName;
m_aToolBoxMap.emplace( temp, static_cast<ToolBox_XML_Entry>(i) );
}
}
m_bToolBarStartFound = false;
m_bToolBarItemStartFound = false;
m_bToolBarSpaceStartFound = false;
m_bToolBarBreakStartFound = false;
m_bToolBarSeparatorStartFound = false;
}
OReadToolBoxDocumentHandler::~OReadToolBoxDocumentHandler()
{
}
// XDocumentHandler
void SAL_CALL OReadToolBoxDocumentHandler::startDocument()
{
}
void SAL_CALL OReadToolBoxDocumentHandler::endDocument()
{
if ( m_bToolBarStartFound )
{
OUString aErrorMessage = getErrorLineString() + "No matching start or end element 'toolbar' found!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
}
void SAL_CALL OReadToolBoxDocumentHandler::startElement(
const OUString& aName, const Reference< XAttributeList > &xAttribs )
{
ToolBoxHashMap::const_iterator pToolBoxEntry = m_aToolBoxMap.find( aName );
if ( pToolBoxEntry == m_aToolBoxMap.end() )
return;
switch ( pToolBoxEntry->second )
{
case TB_ELEMENT_TOOLBAR:
{
if ( m_bToolBarStartFound )
{
OUString aErrorMessage = getErrorLineString() + "Element 'toolbar:toolbar' cannot be embedded into 'toolbar:toolbar'!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
else
{
// Check if we have a UI name set in our XML file
OUString aUIName;
for ( sal_Int16 n = 0; n < xAttribs->getLength(); n++ )
{
pToolBoxEntry = m_aToolBoxMap.find( xAttribs->getNameByIndex( n ) );
if ( pToolBoxEntry != m_aToolBoxMap.end() )
{
switch ( pToolBoxEntry->second )
{
case TB_ATTRIBUTE_UINAME:
aUIName = xAttribs->getValueByIndex( n );
break;
default:
break;
}
}
}
if ( !aUIName.isEmpty() )
{
// Try to set UI name as a container property
Reference< XPropertySet > xPropSet( m_rItemContainer, UNO_QUERY );
if ( xPropSet.is() )
{
try
{
xPropSet->setPropertyValue(u"UIName"_ustr, Any( aUIName ) );
}
catch ( const UnknownPropertyException& )
{
}
}
}
}
m_bToolBarStartFound = true;
}
break;
case TB_ELEMENT_TOOLBARITEM:
{
if ( !m_bToolBarStartFound )
{
OUString aErrorMessage = getErrorLineString() + "Element 'toolbar:toolbaritem' must be embedded into element 'toolbar:toolbar'!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
if ( m_bToolBarSeparatorStartFound ||
m_bToolBarBreakStartFound ||
m_bToolBarSpaceStartFound ||
m_bToolBarItemStartFound )
{
OUString aErrorMessage = getErrorLineString() + "Element toolbar:toolbaritem is not a container!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
bool bAttributeURL = false;
m_bToolBarItemStartFound = true;
OUString aLabel;
OUString aCommandURL;
sal_uInt16 nItemBits( 0 );
bool bVisible( true );
for ( sal_Int16 n = 0; n < xAttribs->getLength(); n++ )
{
pToolBoxEntry = m_aToolBoxMap.find( xAttribs->getNameByIndex( n ) );
if ( pToolBoxEntry != m_aToolBoxMap.end() )
{
switch ( pToolBoxEntry->second )
{
case TB_ATTRIBUTE_TEXT:
{
aLabel = xAttribs->getValueByIndex( n );
}
break;
case TB_ATTRIBUTE_URL:
{
bAttributeURL = true;
aCommandURL = xAttribs->getValueByIndex( n );
}
break;
case TB_ATTRIBUTE_VISIBLE:
{
if ( xAttribs->getValueByIndex( n ) == ATTRIBUTE_BOOLEAN_TRUE )
bVisible = true;
else if ( xAttribs->getValueByIndex( n ) == ATTRIBUTE_BOOLEAN_FALSE )
bVisible = false;
else
{
OUString aErrorMessage = getErrorLineString() + "Attribute toolbar:visible must have value 'true' or 'false'!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
}
break;
case TB_ATTRIBUTE_STYLE:
{
// read space separated item style list
OUString aTemp = xAttribs->getValueByIndex( n );
sal_Int32 nIndex = 0;
do
{
OUString aToken = aTemp.getToken( 0, ' ', nIndex );
if ( !aToken.isEmpty() )
{
if ( aToken == ATTRIBUTE_ITEMSTYLE_RADIO )
nItemBits |= css::ui::ItemStyle::RADIO_CHECK;
else if ( aToken == ATTRIBUTE_ITEMSTYLE_LEFT )
nItemBits |= css::ui::ItemStyle::ALIGN_LEFT;
else if ( aToken == ATTRIBUTE_ITEMSTYLE_AUTOSIZE )
nItemBits |= css::ui::ItemStyle::AUTO_SIZE;
else if ( aToken == ATTRIBUTE_ITEMSTYLE_REPEAT )
nItemBits |= css::ui::ItemStyle::REPEAT;
else if ( aToken == ATTRIBUTE_ITEMSTYLE_DROPDOWNONLY )
nItemBits |= css::ui::ItemStyle::DROPDOWN_ONLY;
else if ( aToken == ATTRIBUTE_ITEMSTYLE_DROPDOWN )
nItemBits |= css::ui::ItemStyle::DROP_DOWN;
else if ( aToken == ATTRIBUTE_ITEMSTYLE_TEXT )
nItemBits |= css::ui::ItemStyle::TEXT;
else if ( aToken == ATTRIBUTE_ITEMSTYLE_IMAGE )
nItemBits |= css::ui::ItemStyle::ICON;
}
}
while ( nIndex >= 0 );
}
break;
default:
break;
}
}
} // for
if ( !bAttributeURL )
{
OUString aErrorMessage = getErrorLineString() + "Required attribute toolbar:url must have a value!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
if ( !aCommandURL.isEmpty() )
{
//fix for fdo#39370
/// check whether RTL interface or not
if(AllSettings::GetLayoutRTL()){
if (aCommandURL == ".uno:ParaLeftToRight")
aCommandURL = ".uno:ParaRightToLeft";
else if (aCommandURL == ".uno:ParaRightToLeft")
aCommandURL = ".uno:ParaLeftToRight";
else if (aCommandURL == ".uno:LeftPara")
aCommandURL = ".uno:RightPara";
else if (aCommandURL == ".uno:RightPara")
aCommandURL = ".uno:LeftPara";
else if (aCommandURL == ".uno:AlignLeft")
aCommandURL = ".uno:AlignRight";
else if (aCommandURL == ".uno:AlignRight")
aCommandURL = ".uno:AlignLeft";
else if (aCommandURL == ".uno:WrapLeft")
aCommandURL = ".uno:WrapRight";
else if (aCommandURL == ".uno:WrapRight")
aCommandURL = ".uno:WrapLeft";
}
auto aToolbarItemProp( comphelper::InitPropertySequence( {
{ m_aCommandURL, css::uno::Any( aCommandURL ) },
{ m_aLabel, css::uno::Any( aLabel ) },
{ m_aType, css::uno::Any( css::ui::ItemType::DEFAULT ) },
{ m_aStyle, css::uno::Any( nItemBits ) },
{ m_aIsVisible, css::uno::Any( bVisible ) },
} ) );
m_rItemContainer->insertByIndex( m_rItemContainer->getCount(), Any( aToolbarItemProp ) );
}
}
break;
case TB_ELEMENT_TOOLBARSPACE:
{
if ( m_bToolBarSeparatorStartFound ||
m_bToolBarBreakStartFound ||
m_bToolBarSpaceStartFound ||
m_bToolBarItemStartFound )
{
OUString aErrorMessage = getErrorLineString() + "Element toolbar:toolbarspace is not a container!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarSpaceStartFound = true;
Sequence< PropertyValue > aToolbarItemProp{
comphelper::makePropertyValue(m_aCommandURL, OUString()),
comphelper::makePropertyValue(m_aType, css::ui::ItemType::SEPARATOR_SPACE)
};
m_rItemContainer->insertByIndex( m_rItemContainer->getCount(), Any( aToolbarItemProp ) );
}
break;
case TB_ELEMENT_TOOLBARBREAK:
{
if ( m_bToolBarSeparatorStartFound ||
m_bToolBarBreakStartFound ||
m_bToolBarSpaceStartFound ||
m_bToolBarItemStartFound )
{
OUString aErrorMessage = getErrorLineString() + "Element toolbar:toolbarbreak is not a container!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarBreakStartFound = true;
Sequence< PropertyValue > aToolbarItemProp{
comphelper::makePropertyValue(m_aCommandURL, OUString()),
comphelper::makePropertyValue(m_aType, css::ui::ItemType::SEPARATOR_LINEBREAK)
};
m_rItemContainer->insertByIndex( m_rItemContainer->getCount(), Any( aToolbarItemProp ) );
}
break;
case TB_ELEMENT_TOOLBARSEPARATOR:
{
if ( m_bToolBarSeparatorStartFound ||
m_bToolBarBreakStartFound ||
m_bToolBarSpaceStartFound ||
m_bToolBarItemStartFound )
{
OUString aErrorMessage = getErrorLineString() + "Element toolbar:toolbarseparator is not a container!";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarSeparatorStartFound = true;
Sequence< PropertyValue > aToolbarItemProp{
comphelper::makePropertyValue(m_aCommandURL, OUString()),
comphelper::makePropertyValue(m_aType, css::ui::ItemType::SEPARATOR_LINE)
};
m_rItemContainer->insertByIndex( m_rItemContainer->getCount(), Any( aToolbarItemProp ) );
}
break;
default:
break;
}
}
void SAL_CALL OReadToolBoxDocumentHandler::endElement(const OUString& aName)
{
ToolBoxHashMap::const_iterator pToolBoxEntry = m_aToolBoxMap.find( aName );
if ( pToolBoxEntry == m_aToolBoxMap.end() )
return;
switch ( pToolBoxEntry->second )
{
case TB_ELEMENT_TOOLBAR:
{
if ( !m_bToolBarStartFound )
{
OUString aErrorMessage = getErrorLineString() + "End element 'toolbar' found, but no start element 'toolbar'";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarStartFound = false;
}
break;
case TB_ELEMENT_TOOLBARITEM:
{
if ( !m_bToolBarItemStartFound )
{
OUString aErrorMessage = getErrorLineString() + "End element 'toolbar:toolbaritem' found, but no start element 'toolbar:toolbaritem'";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarItemStartFound = false;
}
break;
case TB_ELEMENT_TOOLBARBREAK:
{
if ( !m_bToolBarBreakStartFound )
{
OUString aErrorMessage = getErrorLineString() + "End element 'toolbar:toolbarbreak' found, but no start element 'toolbar:toolbarbreak'";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarBreakStartFound = false;
}
break;
case TB_ELEMENT_TOOLBARSPACE:
{
if ( !m_bToolBarSpaceStartFound )
{
OUString aErrorMessage = getErrorLineString() + "End element 'toolbar:toolbarspace' found, but no start element 'toolbar:toolbarspace'";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarSpaceStartFound = false;
}
break;
case TB_ELEMENT_TOOLBARSEPARATOR:
{
if ( !m_bToolBarSeparatorStartFound )
{
OUString aErrorMessage = getErrorLineString() + "End element 'toolbar:toolbarseparator' found, but no start element 'toolbar:toolbarseparator'";
throw SAXException( aErrorMessage, Reference< XInterface >(), Any() );
}
m_bToolBarSeparatorStartFound = false;
}
break;
default: break;
}
}
void SAL_CALL OReadToolBoxDocumentHandler::characters(const OUString&)
{
}
void SAL_CALL OReadToolBoxDocumentHandler::ignorableWhitespace(const OUString&)
{
}
void SAL_CALL OReadToolBoxDocumentHandler::processingInstruction(
const OUString& /*aTarget*/, const OUString& /*aData*/ )
{
}
void SAL_CALL OReadToolBoxDocumentHandler::setDocumentLocator(
const Reference< XLocator > &xLocator)
{
m_xLocator = xLocator;
}
OUString OReadToolBoxDocumentHandler::getErrorLineString()
{
if ( m_xLocator.is() )
return "Line: " + OUString::number( m_xLocator->getLineNumber() ) + " - ";
else
return OUString();
}
// OWriteToolBoxDocumentHandler
OWriteToolBoxDocumentHandler::OWriteToolBoxDocumentHandler(
const Reference< XIndexAccess >& rItemAccess,
Reference< XDocumentHandler > const & rWriteDocumentHandler ) :
m_xWriteDocumentHandler( rWriteDocumentHandler ),
m_rItemAccess( rItemAccess )
{
m_xEmptyList = new ::comphelper::AttributeList;
m_aXMLXlinkNS = XMLNS_XLINK_PREFIX;
m_aXMLToolbarNS = XMLNS_TOOLBAR_PREFIX;
}
OWriteToolBoxDocumentHandler::~OWriteToolBoxDocumentHandler()
{
}
void OWriteToolBoxDocumentHandler::WriteToolBoxDocument()
{
m_xWriteDocumentHandler->startDocument();
// write DOCTYPE line!
Reference< XExtendedDocumentHandler > xExtendedDocHandler( m_xWriteDocumentHandler, UNO_QUERY );
if ( xExtendedDocHandler.is() )
{
xExtendedDocHandler->unknown( TOOLBAR_DOCTYPE );
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
}
OUString aUIName;
Reference< XPropertySet > xPropSet( m_rItemAccess, UNO_QUERY );
if ( xPropSet.is() )
{
try
{
xPropSet->getPropertyValue(u"UIName"_ustr) >>= aUIName;
}
catch ( const UnknownPropertyException& )
{
}
}
rtl::Reference<::comphelper::AttributeList> pList = new ::comphelper::AttributeList;
pList->AddAttribute( ATTRIBUTE_XMLNS_TOOLBAR,
u"" XMLNS_TOOLBAR ""_ustr );
pList->AddAttribute( ATTRIBUTE_XMLNS_XLINK,
u"" XMLNS_XLINK ""_ustr );
if ( !aUIName.isEmpty() )
pList->AddAttribute( m_aXMLToolbarNS + ATTRIBUTE_UINAME,
aUIName );
m_xWriteDocumentHandler->startElement( ELEMENT_NS_TOOLBAR, pList );
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
sal_Int32 nItemCount = m_rItemAccess->getCount();
Any aAny;
for ( sal_Int32 nItemPos = 0; nItemPos < nItemCount; nItemPos++ )
{
Sequence< PropertyValue > aProps;
aAny = m_rItemAccess->getByIndex( nItemPos );
if ( aAny >>= aProps )
{
OUString aCommandURL;
OUString aLabel;
bool bVisible( true );
sal_Int16 nType( css::ui::ItemType::DEFAULT );
sal_Int16 nStyle( 0 );
ExtractToolbarParameters( aProps, aCommandURL, aLabel, nStyle, bVisible, nType );
if ( nType == css::ui::ItemType::DEFAULT )
WriteToolBoxItem( aCommandURL, aLabel, nStyle, bVisible );
else if ( nType == css::ui::ItemType::SEPARATOR_SPACE )
WriteToolBoxSpace();
else if ( nType == css::ui::ItemType::SEPARATOR_LINE )
WriteToolBoxSeparator();
else if ( nType == css::ui::ItemType::SEPARATOR_LINEBREAK )
WriteToolBoxBreak();
}
}
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->endElement( ELEMENT_NS_TOOLBAR );
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->endDocument();
}
// protected member functions
void OWriteToolBoxDocumentHandler::WriteToolBoxItem(
const OUString& rCommandURL,
const OUString& rLabel,
sal_Int16 nStyle,
bool bVisible )
{
rtl::Reference<::comphelper::AttributeList> pList = new ::comphelper::AttributeList;
if ( m_aAttributeURL.isEmpty() )
{
m_aAttributeURL = m_aXMLXlinkNS + ATTRIBUTE_URL;
}
// save required attribute (URL)
pList->AddAttribute( m_aAttributeURL, rCommandURL );
if ( !rLabel.isEmpty() )
{
pList->AddAttribute( m_aXMLToolbarNS + ATTRIBUTE_TEXT,
rLabel );
}
if ( !bVisible )
{
pList->AddAttribute( m_aXMLToolbarNS + ATTRIBUTE_VISIBLE,
ATTRIBUTE_BOOLEAN_FALSE );
}
if ( nStyle > 0 )
{
OUStringBuffer aValue;
const ToolboxStyleItem* pStyle = Styles;
for ( sal_Int32 nIndex = 0; nIndex < nStyleItemEntries; ++nIndex, ++pStyle )
{
if ( nStyle & pStyle->nBit )
{
if ( !aValue.isEmpty() )
aValue.append(" ");
aValue.append( pStyle->attrName );
}
}
pList->AddAttribute( m_aXMLToolbarNS + ATTRIBUTE_ITEMSTYLE,
aValue.makeStringAndClear() );
}
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->startElement( ELEMENT_NS_TOOLBARITEM, pList );
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->endElement( ELEMENT_NS_TOOLBARITEM );
}
void OWriteToolBoxDocumentHandler::WriteToolBoxSpace()
{
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->startElement( ELEMENT_NS_TOOLBARSPACE, m_xEmptyList );
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->endElement( ELEMENT_NS_TOOLBARSPACE );
}
void OWriteToolBoxDocumentHandler::WriteToolBoxBreak()
{
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->startElement( ELEMENT_NS_TOOLBARBREAK, m_xEmptyList );
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->endElement( ELEMENT_NS_TOOLBARBREAK );
}
void OWriteToolBoxDocumentHandler::WriteToolBoxSeparator()
{
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->startElement( ELEMENT_NS_TOOLBARSEPARATOR, m_xEmptyList );
m_xWriteDocumentHandler->ignorableWhitespace( OUString() );
m_xWriteDocumentHandler->endElement( ELEMENT_NS_TOOLBARSEPARATOR );
}
} // namespace framework
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */