/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: elementimport.cxx,v $ * $Revision: 1.60.56.1 $ * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_xmloff.hxx" #include #include "elementimport.hxx" #include #include #include #include "strings.hxx" #include "callbacks.hxx" #include "attriblistmerge.hxx" #include "xmlnmspe.hxx" #include "eventimport.hxx" #include #include "formenums.hxx" #include #include "gridcolumnproptranslator.hxx" #include #include /** === begin UNO includes === **/ #include #include #include #include #include #include #include /** === end UNO includes === **/ #include #include #include #include //......................................................................... namespace xmloff { //......................................................................... using namespace ::xmloff::token; using namespace ::com::sun::star; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::awt; using namespace ::com::sun::star::container; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::script; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::form; using namespace ::com::sun::star::xml; using namespace ::com::sun::star::util; using namespace ::com::sun::star::text; using namespace ::comphelper; #define PROPID_VALUE 1 #define PROPID_CURRENT_VALUE 2 #define PROPID_MIN_VALUE 3 #define PROPID_MAX_VALUE 4 //===================================================================== struct PropertyValueLess { sal_Bool operator()(const PropertyValue& _rLeft, const PropertyValue& _rRight) { return _rLeft.Name < _rRight.Name; } }; //===================================================================== struct PropertyValueCompare : public ::std::binary_function< PropertyValue, ::rtl::OUString, bool> { bool operator() (const PropertyValue& lhs, const ::rtl::OUString& rhs) const { return lhs.Name == rhs; } bool operator() (const ::rtl::OUString& lhs, const PropertyValue& rhs) const { return lhs == rhs.Name; } }; //===================================================================== template void pushBackSequenceElement(Sequence< ELEMENT >& _rContainer, const ELEMENT& _rElement) { sal_Int32 nLen = _rContainer.getLength(); _rContainer.realloc(nLen + 1); _rContainer[nLen] = _rElement; } //===================================================================== //= OElementNameMap //===================================================================== //--------------------------------------------------------------------- OElementNameMap::MapString2Element OElementNameMap::s_sElementTranslations; //--------------------------------------------------------------------- const OControlElement::ElementType& operator ++(OControlElement::ElementType& _e) { OControlElement::ElementType e = _e; sal_Int32 nAsInt = static_cast(e); _e = static_cast( ++nAsInt ); return _e; } //--------------------------------------------------------------------- OControlElement::ElementType OElementNameMap::getElementType(const ::rtl::OUString& _rName) { if (0 == s_sElementTranslations.size()) { // initialize for (ElementType eType=(ElementType)0; eTypesecond; return UNKNOWN; } //===================================================================== //= OElementImport //===================================================================== //--------------------------------------------------------------------- OElementImport::OElementImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer) :OPropertyImport(_rImport, _nPrefix, _rName) ,m_rFormImport(_rImport) ,m_rEventManager(_rEventManager) ,m_pStyleElement( NULL ) ,m_xParentContainer(_rxParentContainer) { OSL_ENSURE(m_xParentContainer.is(), "OElementImport::OElementImport: invalid parent container!"); } //--------------------------------------------------------------------- OElementImport::~OElementImport() { } //--------------------------------------------------------------------- void OElementImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { ENTER_LOG_CONTEXT( "xmloff::OElementImport - importing one element" ); // call the base class. This should give us enough information (especially the service name) // to create our UNO element OPropertyImport::StartElement(_rxAttrList); // create the element m_xElement = createElement(); } //--------------------------------------------------------------------- SvXMLImportContext* OElementImport::CreateChildContext(sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, const Reference< sax::XAttributeList >& _rxAttrList) { if( token::IsXMLToken(_rLocalName, token::XML_EVENT_LISTENERS) && (XML_NAMESPACE_OFFICE == _nPrefix)) return new OFormEventsImportContext(m_rFormImport.getGlobalContext(), _nPrefix, _rLocalName, *this); return OPropertyImport::CreateChildContext(_nPrefix, _rLocalName, _rxAttrList); } //--------------------------------------------------------------------- void OElementImport::EndElement() { OSL_ENSURE(m_xElement.is(), "OElementImport::EndElement: invalid element created!"); if (!m_xElement.is()) return; // set all the properties we collected #if OSL_DEBUG_LEVEL > 0 // check if the object has all the properties // (We do this in the non-pro version only. Doing it all the time would be much to expensive) Reference< XPropertySetInfo > xPropInfo = m_xElement->getPropertySetInfo(); if (xPropInfo.is()) { for ( PropertyValueArray::iterator aCheck = m_aValues.begin(); aCheck != m_aValues.end(); ++aCheck ) { OSL_ENSURE(xPropInfo->hasPropertyByName(aCheck->Name), ::rtl::OString("OElementImport::EndElement: read a property (") += ::rtl::OString(aCheck->Name.getStr(), aCheck->Name.getLength(), RTL_TEXTENCODING_ASCII_US) += ::rtl::OString(") which does not exist on the element!")); } } #endif OSL_ENSURE(!m_aValues.empty(), "OElementImport::EndElement: no properties read!"); // set the properties Reference< XMultiPropertySet > xMultiProps(m_xElement, UNO_QUERY); sal_Bool bSuccess = sal_False; if (xMultiProps.is()) { // translate our properties so that the XMultiPropertySet can handle them // sort our property value array so that we can use it in a setPropertyValues ::std::sort( m_aValues.begin(), m_aValues.end(), PropertyValueLess()); // the names Sequence< ::rtl::OUString > aNames(m_aValues.size()); ::rtl::OUString* pNames = aNames.getArray(); // the values Sequence< Any > aValues(m_aValues.size()); Any* pValues = aValues.getArray(); // copy for ( PropertyValueArray::iterator aPropValues = m_aValues.begin(); aPropValues != m_aValues.end(); ++aPropValues, ++pNames, ++pValues ) { *pNames = aPropValues->Name; *pValues = aPropValues->Value; } try { xMultiProps->setPropertyValues(aNames, aValues); bSuccess = sal_True; } catch(Exception&) { OSL_ENSURE(sal_False, "OElementImport::EndElement: could not set the properties (using the XMultiPropertySet)!"); } } if (!bSuccess) { // no XMultiPropertySet or setting all properties at once failed for ( PropertyValueArray::iterator aPropValues = m_aValues.begin(); aPropValues != m_aValues.end(); ++aPropValues ) { // this try/catch here is expensive, but because this is just a fallback which should normally not be // used it's acceptable this way ... try { m_xElement->setPropertyValue(aPropValues->Name, aPropValues->Value); } catch(Exception&) { OSL_ENSURE(sal_False, ::rtl::OString("OElementImport::EndElement: could not set the property \"") += ::rtl::OString(aPropValues->Name.getStr(), aPropValues->Name.getLength(), RTL_TEXTENCODING_ASCII_US) += ::rtl::OString("\"!")); } } } // set the generic properties implImportGenericProperties(); // set the style properties if ( m_pStyleElement && m_xElement.is() ) { Reference< XPropertySet > xPropTranslation = new OGridColumnPropertyTranslator( Reference< XMultiPropertySet >( m_xElement, UNO_QUERY ) ); const_cast< XMLTextStyleContext* >( m_pStyleElement )->FillPropertySet( xPropTranslation ); ::rtl::OUString sNumberStyleName = const_cast< XMLTextStyleContext* >( m_pStyleElement )->GetDataStyleName( ); if ( sNumberStyleName.getLength() ) // the style also has a number (sub) style m_rContext.applyControlNumberStyle( m_xElement, sNumberStyleName ); } // insert the element into the parent container if (!m_sName.getLength()) { OSL_ENSURE(sal_False, "OElementImport::EndElement: did not find a name attribute!"); m_sName = implGetDefaultName(); } m_xParentContainer->insertByName(m_sName, makeAny(m_xElement)); LEAVE_LOG_CONTEXT( ); } //--------------------------------------------------------------------- void OElementImport::implImportGenericProperties() { if ( m_aGenericValues.empty() ) return; Reference< XPropertySetInfo > xPropSetInfo = m_xElement->getPropertySetInfo(); Reference< XPropertyContainer > xDynamicProperties( m_xElement, UNO_QUERY ); for ( PropertyValueArray::iterator aPropValues = m_aGenericValues.begin(); aPropValues != m_aGenericValues.end(); ++aPropValues ) { // check property type for numeric types before setting // the property try { // if such a property does not yet exist at the element, create it if necessary bool bExistentProperty = xPropSetInfo->hasPropertyByName( aPropValues->Name ); if ( !bExistentProperty ) { if ( !xDynamicProperties.is() ) { #if OSL_DEBUG_LEVEL > 0 ::rtl::OString aMessage( "OElementImport::implImportGenericProperties: encountered an unknown property (" ); aMessage += ::rtl::OUStringToOString( aPropValues->Name, RTL_TEXTENCODING_ASCII_US ); aMessage += "), but component is no PropertyBag!"; OSL_ENSURE( false, aMessage.getStr() ); #endif continue; } xDynamicProperties->addProperty( aPropValues->Name, PropertyAttribute::BOUND | PropertyAttribute::REMOVEABLE, aPropValues->Value ); // re-fetch the PropertySetInfo xPropSetInfo = m_xElement->getPropertySetInfo(); } // determine the type of the value (source forthe following conversion) TypeClass eValueTypeClass = aPropValues->Value.getValueTypeClass(); sal_Bool bValueIsSequence = TypeClass_SEQUENCE == eValueTypeClass; if ( bValueIsSequence ) { uno::Type aSimpleType( getSequenceElementType( aPropValues->Value.getValueType() ) ); eValueTypeClass = aSimpleType.getTypeClass(); } // determine the type of the property (target forthe following conversion) Property aProperty( xPropSetInfo->getPropertyByName( aPropValues->Name ) ); TypeClass ePropTypeClass = aProperty.Type.getTypeClass(); sal_Bool bPropIsSequence = TypeClass_SEQUENCE == ePropTypeClass; if( bPropIsSequence ) { uno::Type aSimpleType( ::comphelper::getSequenceElementType( aProperty.Type ) ); ePropTypeClass = aSimpleType.getTypeClass(); } if ( bPropIsSequence != bValueIsSequence ) { OSL_ENSURE( false, "OElementImport::implImportGenericProperties: either both value and property should be a sequence, or none of them!" ); continue; } if ( bValueIsSequence ) { OSL_ENSURE( eValueTypeClass == TypeClass_ANY, "OElementImport::implImportGenericProperties: only ANYs should have been imported as generic list property!" ); // (OPropertyImport should produce only Sequencer< Any >, since it cannot know the real type OSL_ENSURE( ePropTypeClass == TypeClass_SHORT, "OElementImport::implImportGenericProperties: conversion to sequences other than 'sequence< short >' not implemented, yet!" ); Sequence< Any > aXMLValueList; aPropValues->Value >>= aXMLValueList; Sequence< sal_Int16 > aPropertyValueList( aXMLValueList.getLength() ); const Any* pXMLValue = aXMLValueList.getConstArray(); sal_Int16* pPropValue = aPropertyValueList.getArray(); for ( sal_Int32 i=0; i>= nVal ); *pPropValue = static_cast< sal_Int16 >( nVal ); } aPropValues->Value <<= aPropertyValueList; } else if ( ePropTypeClass != eValueTypeClass ) { switch ( eValueTypeClass ) { case TypeClass_DOUBLE: { double nVal = 0; aPropValues->Value >>= nVal; switch( ePropTypeClass ) { case TypeClass_BYTE: aPropValues->Value <<= static_cast< sal_Int8 >( nVal ); break; case TypeClass_SHORT: aPropValues->Value <<= static_cast< sal_Int16 >( nVal ); break; case TypeClass_LONG: case TypeClass_ENUM: aPropValues->Value <<= static_cast< sal_Int32 >( nVal ); break; case TypeClass_HYPER: aPropValues->Value <<= static_cast< sal_Int64 >( nVal ); break; default: OSL_ENSURE( false, "OElementImport::implImportGenericProperties: unsupported value type!" ); break; } } break; default: OSL_ENSURE( false, "OElementImport::implImportGenericProperties: non-double values not supported!" ); break; } } m_xElement->setPropertyValue( aPropValues->Name, aPropValues->Value ); } catch(Exception&) { OSL_ENSURE(sal_False, ::rtl::OString("OElementImport::EndElement: could not set the property \"") += ::rtl::OString(aPropValues->Name.getStr(), aPropValues->Name.getLength(), RTL_TEXTENCODING_ASCII_US) += ::rtl::OString("\"!")); } } } //--------------------------------------------------------------------- ::rtl::OUString OElementImport::implGetDefaultName() const { // no optimization here. If this method gets called, the XML stream did not contain a name for the // element, which is a heavy error. So in this case we don't care for performance Sequence< ::rtl::OUString > aNames = m_xParentContainer->getElementNames(); static const ::rtl::OUString sUnnamedName = ::rtl::OUString::createFromAscii("unnamed"); ::rtl::OUString sReturn; const ::rtl::OUString* pNames = NULL; const ::rtl::OUString* pNamesEnd = aNames.getConstArray() + aNames.getLength(); for (sal_Int32 i=0; i<32768; ++i) // the limit is nearly arbitrary ... { // assemble the new name (suggestion) sReturn = sUnnamedName; sReturn += ::rtl::OUString::valueOf(i); // check the existence (this is the bad performance part ....) for (pNames = aNames.getConstArray(); pNames OElementImport::createElement() { Reference< XPropertySet > xReturn; if (m_sServiceName.getLength()) { Reference< XInterface > xPure = m_rFormImport.getServiceFactory()->createInstance(m_sServiceName); OSL_ENSURE(xPure.is(), ::rtl::OString("OElementImport::createElement: service factory gave me no object (service name: ") += ::rtl::OString(m_sServiceName.getStr(), m_sServiceName.getLength(), RTL_TEXTENCODING_ASCII_US) += ::rtl::OString(")!")); xReturn = Reference< XPropertySet >(xPure, UNO_QUERY); } else OSL_ENSURE(sal_False, "OElementImport::createElement: no service name to create an element!"); return xReturn; } //--------------------------------------------------------------------- void OElementImport::registerEvents(const Sequence< ScriptEventDescriptor >& _rEvents) { OSL_ENSURE(m_xElement.is(), "OElementImport::registerEvents: no element to register events for!"); m_rEventManager.registerEvents(m_xElement, _rEvents); } //--------------------------------------------------------------------- void OElementImport::simulateDefaultedAttribute(const sal_Char* _pAttributeName, const ::rtl::OUString& _rPropertyName, const sal_Char* _pAttributeDefault) { Reference< XPropertySetInfo > xPropsInfo; if ( m_xElement.is()) { xPropsInfo=m_xElement->getPropertySetInfo(); } OSL_ENSURE( xPropsInfo.is(), "OPropertyImport::simulateDefaultedAttribute: the component should be more gossipy about it's properties!" ); if ( !xPropsInfo.is() || xPropsInfo->hasPropertyByName( _rPropertyName ) ) { ::rtl::OUString sLocalAttrName = ::rtl::OUString::createFromAscii(_pAttributeName); if ( !encounteredAttribute( sLocalAttrName ) ) handleAttribute( XML_NAMESPACE_FORM, sLocalAttrName, ::rtl::OUString::createFromAscii( _pAttributeDefault ) ); } } //===================================================================== //= OControlImport //===================================================================== //--------------------------------------------------------------------- OControlImport::OControlImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer) :OElementImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer) ,m_eElementType(OControlElement::UNKNOWN) { } //--------------------------------------------------------------------- OControlImport::OControlImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OElementImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer) ,m_eElementType(_eType) { } //--------------------------------------------------------------------- void OControlImport::addOuterAttributes(const Reference< sax::XAttributeList >& _rxOuterAttribs) { OSL_ENSURE(!m_xOuterAttributes.is(), "OControlImport::addOuterAttributes: already have these attributes!"); m_xOuterAttributes = _rxOuterAttribs; } //--------------------------------------------------------------------- void OControlImport::handleAttribute(sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue) { if ( !m_sControlId.getLength() && _rLocalName.equalsAscii( OAttributeMetaData::getCommonControlAttributeName( CCA_CONTROL_ID ) ) ) { // it's the control id m_sControlId = _rValue; } else if ( _rLocalName.equalsAscii( OAttributeMetaData::getBindingAttributeName( BA_LINKED_CELL ) ) ) { // it's the address of a spreadsheet cell m_sBoundCellAddress = _rValue; } else if ( _nNamespaceKey == XML_NAMESPACE_XFORMS && IsXMLToken( _rLocalName, XML_BIND ) ) { m_sBindingID = _rValue; } else if ( _nNamespaceKey == XML_NAMESPACE_FORM && IsXMLToken( _rLocalName, XML_XFORMS_LIST_SOURCE ) ) { m_sListBindingID = _rValue; } else if ( (_nNamespaceKey == XML_NAMESPACE_FORM && IsXMLToken( _rLocalName, XML_XFORMS_SUBMISSION ) ) || ( _nNamespaceKey == XML_NAMESPACE_XFORMS && IsXMLToken( _rLocalName, XML_SUBMISSION ) ) ) { m_sSubmissionID = _rValue; } else { sal_Int32 nHandle = -1; if ( _rLocalName.equalsAscii( OAttributeMetaData::getCommonControlAttributeName( CCA_VALUE ) ) ) nHandle = PROPID_VALUE; else if ( _rLocalName.equalsAscii( OAttributeMetaData::getCommonControlAttributeName( CCA_CURRENT_VALUE ) ) ) nHandle = PROPID_CURRENT_VALUE; else if ( _rLocalName.equalsAscii( OAttributeMetaData::getSpecialAttributeName( SCA_MIN_VALUE ) ) ) nHandle = PROPID_MIN_VALUE; else if ( _rLocalName.equalsAscii( OAttributeMetaData::getSpecialAttributeName( SCA_MAX_VALUE ) ) ) nHandle = PROPID_MAX_VALUE; if ( nHandle != -1 ) { // for the moment, simply remember the name and the value PropertyValue aProp; aProp.Name = _rLocalName; aProp.Handle = nHandle; aProp.Value <<= _rValue; m_aValueProperties.push_back(aProp); } else if ( _rLocalName.equalsAscii( OAttributeMetaData::getSpecialAttributeName( SCA_REPEAT_DELAY ) ) ) { ::Time aTime; sal_Int32 nFractions = 0; if ( SvXMLUnitConverter::convertTimeDuration( _rValue, aTime, &nFractions ) ) { PropertyValue aProp; aProp.Name = PROPERTY_REPEAT_DELAY; aProp.Value <<= (sal_Int32)( ( ( aTime.GetMSFromTime() / 1000 ) * 1000 ) + nFractions ); implPushBackPropertyValue(aProp); } } else OElementImport::handleAttribute(_nNamespaceKey, _rLocalName, _rValue); } } //--------------------------------------------------------------------- void OControlImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { ::com::sun::star::uno::Reference< ::com::sun::star::xml::sax::XAttributeList > xAttributes; if( m_xOuterAttributes.is() ) { // merge the attribute lists OAttribListMerger* pMerger = new OAttribListMerger; // our own one pMerger->addList(_rxAttrList); // and the ones of our enclosing element pMerger->addList(m_xOuterAttributes); xAttributes = pMerger; } else { xAttributes = _rxAttrList; } // let the base class handle all the attributes OElementImport::StartElement(xAttributes); if (m_aValueProperties.size() && m_xElement.is()) { // get the property set info Reference< XPropertySetInfo > xPropsInfo = m_xElement->getPropertySetInfo(); if (!xPropsInfo.is()) { OSL_ENSURE(sal_False, "OControlImport::StartElement: no PropertySetInfo!"); return; } const sal_Char* pValueProperty = NULL; const sal_Char* pCurrentValueProperty = NULL; const sal_Char* pMinValueProperty = NULL; const sal_Char* pMaxValueProperty = NULL; sal_Bool bRetrievedValues = sal_False; sal_Bool bRetrievedValueLimits = sal_False; // get the class id of our element sal_Int16 nClassId = FormComponentType::CONTROL; m_xElement->getPropertyValue(PROPERTY_CLASSID) >>= nClassId; // translate the value properties we collected in handleAttributes for ( PropertyValueArray::iterator aValueProps = m_aValueProperties.begin(); aValueProps != m_aValueProperties.end(); ++aValueProps ) { switch (aValueProps->Handle) { case PROPID_VALUE: case PROPID_CURRENT_VALUE: { // get the property names if (!bRetrievedValues) { getValuePropertyNames(m_eElementType, nClassId, pCurrentValueProperty, pValueProperty); bRetrievedValues = sal_True; } OSL_ENSURE((PROPID_VALUE != aValueProps->Handle) || pValueProperty, "OControlImport::StartElement: the control does not have a value property!"); OSL_ENSURE((PROPID_CURRENT_VALUE != aValueProps->Handle) || pCurrentValueProperty, "OControlImport::StartElement: the control does not have a current-value property!"); // transfer the name if (PROPID_VALUE == aValueProps->Handle) aValueProps->Name = ::rtl::OUString::createFromAscii(pValueProperty); else aValueProps->Name = ::rtl::OUString::createFromAscii(pCurrentValueProperty); } break; case PROPID_MIN_VALUE: case PROPID_MAX_VALUE: { // get the property names if (!bRetrievedValueLimits) { getValueLimitPropertyNames(nClassId, pMinValueProperty, pMaxValueProperty); bRetrievedValueLimits = sal_True; } OSL_ENSURE((PROPID_MIN_VALUE != aValueProps->Handle) || pMinValueProperty, "OControlImport::StartElement: the control does not have a value property!"); OSL_ENSURE((PROPID_MAX_VALUE != aValueProps->Handle) || pMaxValueProperty, "OControlImport::StartElement: the control does not have a current-value property!"); // transfer the name if (PROPID_MIN_VALUE == aValueProps->Handle) aValueProps->Name = ::rtl::OUString::createFromAscii(pMinValueProperty); else aValueProps->Name = ::rtl::OUString::createFromAscii(pMaxValueProperty); } break; } // translate the value implTranslateValueProperty(xPropsInfo, *aValueProps); // add the property to the base class' array implPushBackPropertyValue(*aValueProps); } } } //--------------------------------------------------------------------- void OControlImport::implTranslateValueProperty(const Reference< XPropertySetInfo >& _rxPropInfo, PropertyValue& _rPropValue) { OSL_ENSURE(_rxPropInfo->hasPropertyByName(_rPropValue.Name), "OControlImport::implTranslateValueProperty: invalid property name!"); // retrieve the type of the property Property aProp = _rxPropInfo->getPropertyByName(_rPropValue.Name); // the untranslated string value as read in handleAttribute ::rtl::OUString sValue; #if OSL_DEBUG_LEVEL > 0 sal_Bool bSuccess = #endif _rPropValue.Value >>= sValue; OSL_ENSURE(bSuccess, "OControlImport::implTranslateValueProperty: supposed to be called with non-translated string values!"); if (TypeClass_ANY == aProp.Type.getTypeClass()) { // we have exactly 2 properties where this type class is allowed: OSL_ENSURE( (0 == _rPropValue.Name.compareToAscii(PROPERTY_EFFECTIVE_VALUE)) || (0 == _rPropValue.Name.compareToAscii(PROPERTY_EFFECTIVE_DEFAULT)), "OControlImport::implTranslateValueProperty: invalid property type/name combination!"); // Both properties are allowed to have a double or a string value, // so first try to convert the string into a number double nValue; if (GetImport().GetMM100UnitConverter().convertDouble(nValue, sValue)) _rPropValue.Value <<= nValue; else _rPropValue.Value <<= sValue; } else _rPropValue.Value = PropertyConversion::convertString(GetImport(), aProp.Type, sValue); } //--------------------------------------------------------------------- void OControlImport::EndElement() { OSL_ENSURE(m_xElement.is(), "OControlImport::EndElement: invalid control!"); if ( !m_xElement.is() ) return; // register our control with it's id if (m_sControlId.getLength()) m_rFormImport.getControlIdMap().registerControlId(m_xElement, m_sControlId); // it's allowed to have no control id. In this case we're importing a column // one more pre-work to do: // when we set default values, then by definition the respective value is set // to this default value, too. This means if the sequence contains for example // a DefaultText value, then the Text will be affected by this, too. // In case the Text is not part of the property sequence (or occurs _before_ // the DefaultText, which can happen for other value/default-value property names), // this means that the Text (the value property) is incorrectly imported. // #102475# - 04.09.2002 - fs@openoffice.org sal_Bool bRestoreValuePropertyValue = sal_False; Any aValuePropertyValue; sal_Int16 nClassId = FormComponentType::CONTROL; try { // get the class id of our element m_xElement->getPropertyValue(PROPERTY_CLASSID) >>= nClassId; } catch( const Exception& ) { OSL_ENSURE( sal_False, "OControlImport::EndElement: caught an exception while retrieving the class id!" ); } const sal_Char* pValueProperty = NULL; const sal_Char* pDefaultValueProperty = NULL; getRuntimeValuePropertyNames(m_eElementType, nClassId, pValueProperty, pDefaultValueProperty); if ( pDefaultValueProperty && pValueProperty ) { sal_Bool bNonDefaultValuePropertyValue = sal_False; // is the "value property" part of the sequence? // look up this property in our sequence for ( PropertyValueArray::iterator aCheck = m_aValues.begin(); ( aCheck != m_aValues.end() ); ++aCheck ) { if ( aCheck->Name.equalsAscii( pDefaultValueProperty ) ) bRestoreValuePropertyValue = sal_True; else if ( aCheck->Name.equalsAscii( pValueProperty ) ) { bNonDefaultValuePropertyValue = sal_True; // we need to restore the value property we found here, nothing else aValuePropertyValue = aCheck->Value; } } if ( bRestoreValuePropertyValue && !bNonDefaultValuePropertyValue ) { // found it -> need to remember (and restore) the "value property value", which is not set explicitly try { aValuePropertyValue = m_xElement->getPropertyValue( ::rtl::OUString::createFromAscii( pValueProperty ) ); } catch( const Exception& ) { OSL_ENSURE( sal_False, "OControlImport::EndElement: caught an exception while retrieving the current value property!" ); } } } // let the base class set all the values OElementImport::EndElement(); // restore the "value property value", if necessary if ( bRestoreValuePropertyValue && pValueProperty ) { try { m_xElement->setPropertyValue( ::rtl::OUString::createFromAscii( pValueProperty ), aValuePropertyValue ); } catch( const Exception& ) { OSL_ENSURE( sal_False, "OControlImport::EndElement: caught an exception while restoring the value property!" ); } } // the external cell binding, if applicable if ( m_xElement.is() && m_sBoundCellAddress.getLength() ) doRegisterCellValueBinding( m_sBoundCellAddress ); // XForms binding, if applicable if ( m_xElement.is() && m_sBindingID.getLength() ) doRegisterXFormsValueBinding( m_sBindingID ); // XForms list binding, if applicable if ( m_xElement.is() && m_sListBindingID.getLength() ) doRegisterXFormsListBinding( m_sListBindingID ); // XForms submission, if applicable if ( m_xElement.is() && m_sSubmissionID.getLength() ) doRegisterXFormsSubmission( m_sSubmissionID ); } //--------------------------------------------------------------------- void OControlImport::doRegisterCellValueBinding( const ::rtl::OUString& _rBoundCellAddress ) { OSL_PRECOND( m_xElement.is(), "OControlImport::doRegisterCellValueBinding: invalid element!" ); OSL_PRECOND( _rBoundCellAddress.getLength(), "OControlImport::doRegisterCellValueBinding: invalid address!" ); m_rContext.registerCellValueBinding( m_xElement, _rBoundCellAddress ); } //--------------------------------------------------------------------- void OControlImport::doRegisterXFormsValueBinding( const ::rtl::OUString& _rBindingID ) { OSL_PRECOND( m_xElement.is(), "need element" ); OSL_PRECOND( _rBindingID.getLength() > 0, "binding ID is not valid" ); m_rContext.registerXFormsValueBinding( m_xElement, _rBindingID ); } //--------------------------------------------------------------------- void OControlImport::doRegisterXFormsListBinding( const ::rtl::OUString& _rBindingID ) { OSL_PRECOND( m_xElement.is(), "need element" ); OSL_PRECOND( _rBindingID.getLength() > 0, "binding ID is not valid" ); m_rContext.registerXFormsListBinding( m_xElement, _rBindingID ); } //--------------------------------------------------------------------- void OControlImport::doRegisterXFormsSubmission( const ::rtl::OUString& _rSubmissionID ) { OSL_PRECOND( m_xElement.is(), "need element" ); OSL_PRECOND( _rSubmissionID.getLength() > 0, "binding ID is not valid" ); m_rContext.registerXFormsSubmission( m_xElement, _rSubmissionID ); } //--------------------------------------------------------------------- //added by BerryJia for fixing bug102407 2002-11-5 Reference< XPropertySet > OControlImport::createElement() { Reference xPropSet = OElementImport::createElement(); if(xPropSet.is()) { Reference xInfo(xPropSet->getPropertySetInfo()); if(xInfo.is() && xInfo->hasPropertyByName(PROPERTY_ALIGN)) { Any aValue; xPropSet->setPropertyValue(PROPERTY_ALIGN,aValue); } } return xPropSet; } //===================================================================== //= OImagePositionImport //===================================================================== //--------------------------------------------------------------------- OImagePositionImport::OImagePositionImport( IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType ) :OControlImport( _rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType ) ,m_nImagePosition( -1 ) ,m_nImageAlign( 0 ) ,m_bHaveImagePosition( sal_False ) { } //--------------------------------------------------------------------- void OImagePositionImport::handleAttribute( sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue ) { if ( _rLocalName == GetXMLToken( XML_IMAGE_POSITION ) ) { OSL_VERIFY( PropertyConversion::convertString( m_rContext.getGlobalContext(), ::getCppuType( &m_nImagePosition ), _rValue, OEnumMapper::getEnumMap( OEnumMapper::epImagePosition ) ) >>= m_nImagePosition ); m_bHaveImagePosition = sal_True; } else if ( _rLocalName == GetXMLToken( XML_IMAGE_ALIGN ) ) { OSL_VERIFY( PropertyConversion::convertString( m_rContext.getGlobalContext(), ::getCppuType( &m_nImageAlign ), _rValue, OEnumMapper::getEnumMap( OEnumMapper::epImageAlign ) ) >>= m_nImageAlign ); } else OControlImport::handleAttribute( _nNamespaceKey, _rLocalName, _rValue ); } //--------------------------------------------------------------------- void OImagePositionImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { OControlImport::StartElement( _rxAttrList ); if ( m_bHaveImagePosition ) { sal_Int16 nUnoImagePosition = ImagePosition::Centered; if ( m_nImagePosition >= 0 ) { OSL_ENSURE( ( m_nImagePosition <= 3 ) && ( m_nImageAlign >= 0 ) && ( m_nImageAlign < 3 ), "OImagePositionImport::StartElement: unknown image align and/or position!" ); nUnoImagePosition = m_nImagePosition * 3 + m_nImageAlign; } PropertyValue aImagePosition; aImagePosition.Name = PROPERTY_IMAGE_POSITION; aImagePosition.Value <<= nUnoImagePosition; implPushBackPropertyValue( aImagePosition ); } } //===================================================================== //= OReferredControlImport //===================================================================== //--------------------------------------------------------------------- OReferredControlImport::OReferredControlImport( IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType ) :OControlImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer) { } //--------------------------------------------------------------------- void OReferredControlImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { OControlImport::StartElement(_rxAttrList); // the base class should have created the control, so we can register it if (m_sReferringControls.getLength()) m_rFormImport.getControlIdMap().registerControlReferences(m_xElement, m_sReferringControls); } //--------------------------------------------------------------------- void OReferredControlImport::handleAttribute(sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue) { static const ::rtl::OUString s_sReferenceAttributeName = ::rtl::OUString::createFromAscii(OAttributeMetaData::getCommonControlAttributeName(CCA_FOR)); if (_rLocalName == s_sReferenceAttributeName) m_sReferringControls = _rValue; else OControlImport::handleAttribute(_nNamespaceKey, _rLocalName, _rValue); } //===================================================================== //= OPasswordImport //===================================================================== //--------------------------------------------------------------------- OPasswordImport::OPasswordImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OControlImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType) { } //--------------------------------------------------------------------- void OPasswordImport::handleAttribute(sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue) { static const ::rtl::OUString s_sEchoCharAttributeName = ::rtl::OUString::createFromAscii(OAttributeMetaData::getSpecialAttributeName(SCA_ECHO_CHAR)); if (_rLocalName == s_sEchoCharAttributeName) { // need a special handling for the EchoChar property PropertyValue aEchoChar; aEchoChar.Name = PROPERTY_ECHOCHAR; OSL_ENSURE(_rValue.getLength() == 1, "OPasswordImport::handleAttribute: invalid echo char attribute!"); // we ourself should not have written values other than of length 1 if (_rValue.getLength() >= 1) aEchoChar.Value <<= (sal_Int16)_rValue.getStr()[0]; else aEchoChar.Value <<= (sal_Int16)0; implPushBackPropertyValue(aEchoChar); } else OControlImport::handleAttribute(_nNamespaceKey, _rLocalName, _rValue); } //===================================================================== //= ORadioImport //===================================================================== //--------------------------------------------------------------------- ORadioImport::ORadioImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OImagePositionImport( _rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType ) { } //--------------------------------------------------------------------- void ORadioImport::handleAttribute(sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue) { // need special handling for the State & CurrentState properties: // they're stored as booleans, but expected to be int16 properties if ( _rLocalName.equalsAscii( OAttributeMetaData::getCommonControlAttributeName( CCA_CURRENT_SELECTED ) ) || _rLocalName.equalsAscii( OAttributeMetaData::getCommonControlAttributeName( CCA_SELECTED ) ) ) { const OAttribute2Property::AttributeAssignment* pProperty = m_rContext.getAttributeMap().getAttributeTranslation(_rLocalName); OSL_ENSURE(pProperty, "ORadioImport::handleAttribute: invalid property map!"); if (pProperty) { Any aBooleanValue = PropertyConversion::convertString(m_rContext.getGlobalContext(), pProperty->aPropertyType, _rValue, pProperty->pEnumMap); // create and store a new PropertyValue PropertyValue aNewValue; aNewValue.Name = pProperty->sPropertyName; aNewValue.Value <<= (sal_Int16)::cppu::any2bool(aBooleanValue); implPushBackPropertyValue(aNewValue); } } else OImagePositionImport::handleAttribute( _nNamespaceKey, _rLocalName, _rValue ); } //===================================================================== //= OURLReferenceImport //===================================================================== OURLReferenceImport::OURLReferenceImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OImagePositionImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType) { } //--------------------------------------------------------------------- void OURLReferenceImport::handleAttribute(sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue) { static const sal_Char* s_pTargetLocationAttributeName = OAttributeMetaData::getCommonControlAttributeName( CCA_TARGET_LOCATION ); static const sal_Char* s_pImageDataAttributeName = OAttributeMetaData::getCommonControlAttributeName( CCA_IMAGE_DATA ); // need to make the URL absolute if // * it's the image-data attribute // * it's the target-location attribute, and we're dealign with an object which has the respective property sal_Bool bMakeAbsolute = ( 0 == _rLocalName.compareToAscii( s_pImageDataAttributeName ) ) || ( ( 0 == _rLocalName.compareToAscii( s_pTargetLocationAttributeName ) ) && ( ( OControlElement::BUTTON == m_eElementType ) || ( OControlElement::IMAGE == m_eElementType ) ) ); if ( bMakeAbsolute && ( _rValue.getLength() > 0 ) ) { // make a global URL out of the local one ::rtl::OUString sAdjustedValue = m_rContext.getGlobalContext().ResolveGraphicObjectURL( _rValue, FALSE ); OImagePositionImport::handleAttribute( _nNamespaceKey, _rLocalName, sAdjustedValue ); } else OImagePositionImport::handleAttribute( _nNamespaceKey, _rLocalName, _rValue ); } //===================================================================== //= OButtonImport //===================================================================== //--------------------------------------------------------------------- OButtonImport::OButtonImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OURLReferenceImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType) { enableTrackAttributes(); } //--------------------------------------------------------------------- void OButtonImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { OURLReferenceImport::StartElement(_rxAttrList); // handle the target-frame attribute simulateDefaultedAttribute(OAttributeMetaData::getCommonControlAttributeName(CCA_TARGET_FRAME), PROPERTY_TARGETFRAME, "_blank"); } //===================================================================== //= OValueRangeImport //===================================================================== //--------------------------------------------------------------------- OValueRangeImport::OValueRangeImport( IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType ) :OControlImport( _rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType ) ,m_nStepSizeValue( 1 ) { } //--------------------------------------------------------------------- void OValueRangeImport::handleAttribute( sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue ) { if ( _rLocalName.equalsAscii( OAttributeMetaData::getSpecialAttributeName( SCA_STEP_SIZE ) ) ) { GetImport().GetMM100UnitConverter().convertNumber( m_nStepSizeValue, _rValue ); } else OControlImport::handleAttribute( _nNamespaceKey, _rLocalName, _rValue ); } //--------------------------------------------------------------------- void OValueRangeImport::StartElement( const Reference< sax::XAttributeList >& _rxAttrList ) { OControlImport::StartElement( _rxAttrList ); Reference< XPropertySetInfo > xPropInfo; if ( m_xElement.is() ) xPropInfo = m_xElement->getPropertySetInfo(); if ( xPropInfo.is() ) { if ( xPropInfo->hasPropertyByName( PROPERTY_SPIN_INCREMENT ) ) m_xElement->setPropertyValue( PROPERTY_SPIN_INCREMENT, makeAny( m_nStepSizeValue ) ); else if ( xPropInfo->hasPropertyByName( PROPERTY_LINE_INCREMENT ) ) m_xElement->setPropertyValue( PROPERTY_LINE_INCREMENT, makeAny( m_nStepSizeValue ) ); } } //===================================================================== //= OTextLikeImport //===================================================================== //--------------------------------------------------------------------- OTextLikeImport::OTextLikeImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OControlImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType) ,m_bEncounteredTextPara( false ) { enableTrackAttributes(); } //--------------------------------------------------------------------- SvXMLImportContext* OTextLikeImport::CreateChildContext( sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, const Reference< sax::XAttributeList >& _rxAttrList ) { if ( _rLocalName.equalsIgnoreAsciiCaseAscii( "p" ) && ( XML_NAMESPACE_TEXT == _nPrefix ) ) { OSL_ENSURE( m_eElementType == OControlElement::TEXT_AREA, "OTextLikeImport::CreateChildContext: text paragraphs in a non-text-area?" ); if ( m_eElementType == OControlElement::TEXT_AREA ) { Reference< XText > xTextElement( m_xElement, UNO_QUERY ); if ( xTextElement.is() ) { UniReference < XMLTextImportHelper > xTextImportHelper( m_rContext.getGlobalContext().GetTextImport() ); if ( !m_xCursor.is() ) { m_xOldCursor = xTextImportHelper->GetCursor(); m_xCursor = xTextElement->createTextCursor(); if ( m_xCursor.is() ) xTextImportHelper->SetCursor( m_xCursor ); } if ( m_xCursor.is() ) { m_bEncounteredTextPara = true; return xTextImportHelper->CreateTextChildContext( m_rContext.getGlobalContext(), _nPrefix, _rLocalName, _rxAttrList ); } } else { // in theory, we could accumulate all the text portions (without formatting), // and set it as Text property at the model ... } } } return OControlImport::CreateChildContext( _nPrefix, _rLocalName, _rxAttrList ); } //--------------------------------------------------------------------- void OTextLikeImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { OControlImport::StartElement(_rxAttrList); // handle the convert-empty-to-null attribute, whose default is different from the property default sal_Bool bHaveEmptyIsNull = sal_False; // unfortunately, different classes are imported by this class ('cause they're represented by the // same XML element), though not all of them know this property. // So we have to do a check ... if (m_xElement.is()) { Reference< XPropertySetInfo > xProps = m_xElement->getPropertySetInfo(); if (xProps.is()) bHaveEmptyIsNull = xProps->hasPropertyByName(PROPERTY_EMPTY_IS_NULL); } if (bHaveEmptyIsNull) simulateDefaultedAttribute(OAttributeMetaData::getDatabaseAttributeName(DA_CONVERT_EMPTY), PROPERTY_EMPTY_IS_NULL, "false"); } //--------------------------------------------------------------------- struct EqualHandle : public ::std::unary_function< PropertyValue, bool > { sal_Int32 m_nHandle; EqualHandle( sal_Int32 _nHandle ) : m_nHandle( _nHandle ) { } inline bool operator()( const PropertyValue& _rProp ) { if ( _rProp.Handle == m_nHandle ) return true; return false; } }; //--------------------------------------------------------------------- void OTextLikeImport::removeRedundantCurrentValue() { if ( m_bEncounteredTextPara ) { // In case the text is written in the text:p elements, we need to ignore what we read as // current-value attribute, since it's redundant. // fortunately, OElementImport tagged the value property with the PROPID_CURRENT_VALUE // handle, so we do not need to determine the name of our value property here // (normally, it should be "Text", since no other controls than the edit field should // have the text:p elements) PropertyValueArray::iterator aValuePropertyPos = ::std::find_if( m_aValues.begin(), m_aValues.end(), EqualHandle( PROPID_CURRENT_VALUE ) ); if ( aValuePropertyPos != m_aValues.end() ) { OSL_ENSURE( aValuePropertyPos->Name == PROPERTY_TEXT, "OTextLikeImport::EndElement: text:p was present, but our value property is *not* 'Text'!" ); if ( aValuePropertyPos->Name == PROPERTY_TEXT ) { ::std::copy( aValuePropertyPos + 1, m_aValues.end(), aValuePropertyPos ); m_aValues.resize( m_aValues.size() - 1 ); } } // additionally, we need to set the "RichText" property of our element to TRUE // (the presence of the text:p is used as indicator for the value of the RichText property) sal_Bool bHasRichTextProperty = sal_False; Reference< XPropertySetInfo > xPropInfo; if ( m_xElement.is() ) xPropInfo = m_xElement->getPropertySetInfo(); if ( xPropInfo.is() ) bHasRichTextProperty = xPropInfo->hasPropertyByName( PROPERTY_RICH_TEXT ); OSL_ENSURE( bHasRichTextProperty, "OTextLikeImport::EndElement: text:p, but no rich text control?" ); if ( bHasRichTextProperty ) m_xElement->setPropertyValue( PROPERTY_RICH_TEXT, makeAny( (sal_Bool)sal_True ) ); } // Note that we do *not* set the RichText property (in case our element has one) to sal_False here // since this is the default of this property, anyway. } //--------------------------------------------------------------------- struct EqualName : public ::std::unary_function< PropertyValue, bool > { ::rtl::OUString m_sName; EqualName( const ::rtl::OUString& _rName ) : m_sName( _rName ) { } inline bool operator()( const PropertyValue& _rProp ) { if ( _rProp.Name == m_sName ) return true; return false; } }; //--------------------------------------------------------------------- void OTextLikeImport::adjustDefaultControlProperty() { // In OpenOffice.org 2.0, we changed the implementation of the css.form.component.TextField (the model of a text field control), // so that it now uses another default control. So if we encounter a text field where the *old* default // control property is writting, we are not allowed to use it PropertyValueArray::iterator aDefaultControlPropertyPos = ::std::find_if( m_aValues.begin(), m_aValues.end(), EqualName( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "DefaultControl" ) ) ) ); if ( aDefaultControlPropertyPos != m_aValues.end() ) { ::rtl::OUString sDefaultControl; OSL_VERIFY( aDefaultControlPropertyPos->Value >>= sDefaultControl ); if ( sDefaultControl.equalsAscii( "stardiv.one.form.control.Edit" ) ) { // complete remove this property value from the array. Today's "default value" of the "DefaultControl" // property is sufficient ::std::copy( aDefaultControlPropertyPos + 1, m_aValues.end(), aDefaultControlPropertyPos ); m_aValues.resize( m_aValues.size() - 1 ); } } } //--------------------------------------------------------------------- void OTextLikeImport::EndElement() { removeRedundantCurrentValue(); adjustDefaultControlProperty(); // let the base class do the stuff OControlImport::EndElement(); // some cleanups UniReference < XMLTextImportHelper > xTextImportHelper( m_rContext.getGlobalContext().GetTextImport() ); if ( m_xCursor.is() ) { // delete the newline which has been imported errornously // TODO (fs): stole this code somewhere - why don't we fix the text import?? m_xCursor->gotoEnd( sal_False ); m_xCursor->goLeft( 1, sal_True ); m_xCursor->setString( ::rtl::OUString() ); // reset cursor xTextImportHelper->ResetCursor(); } if ( m_xOldCursor.is() ) xTextImportHelper->SetCursor( m_xOldCursor ); } //===================================================================== //= OListAndComboImport //===================================================================== //--------------------------------------------------------------------- OListAndComboImport::OListAndComboImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OControlImport(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, _eType) ,m_nEmptyListItems( 0 ) ,m_nEmptyValueItems( 0 ) ,m_bEncounteredLSAttrib( sal_False ) ,m_bLinkWithIndexes( sal_False ) { if (OControlElement::COMBOBOX == m_eElementType) enableTrackAttributes(); } //--------------------------------------------------------------------- SvXMLImportContext* OListAndComboImport::CreateChildContext(sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, const Reference< sax::XAttributeList >& _rxAttrList) { // is it the "option" sub tag of a listbox ? static const ::rtl::OUString s_sOptionElementName = ::rtl::OUString::createFromAscii("option"); if (s_sOptionElementName == _rLocalName) return new OListOptionImport(GetImport(), _nPrefix, _rLocalName, this); // is it the "item" sub tag of a combobox ? static const ::rtl::OUString s_sItemElementName = ::rtl::OUString::createFromAscii("item"); if (s_sItemElementName == _rLocalName) return new OComboItemImport(GetImport(), _nPrefix, _rLocalName, this); // everything else return OControlImport::CreateChildContext(_nPrefix, _rLocalName, _rxAttrList); } //--------------------------------------------------------------------- void OListAndComboImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { m_bLinkWithIndexes = sal_False; OControlImport::StartElement(_rxAttrList); if (OControlElement::COMBOBOX == m_eElementType) { // for the auto-completion // the attribute default does not equal the property default, so in case we did not read this attribute, // we have to simulate it simulateDefaultedAttribute( OAttributeMetaData::getSpecialAttributeName( SCA_AUTOMATIC_COMPLETION ), PROPERTY_AUTOCOMPLETE, "false"); // same for the convert-empty-to-null attribute, which's default is different from the property default simulateDefaultedAttribute( OAttributeMetaData::getDatabaseAttributeName( DA_CONVERT_EMPTY ), PROPERTY_EMPTY_IS_NULL, "false"); } } //--------------------------------------------------------------------- void OListAndComboImport::EndElement() { // append the list source property the the properties sequence of our importer // the string item list PropertyValue aItemList; aItemList.Name = PROPERTY_STRING_ITEM_LIST; aItemList.Value <<= m_aListSource; implPushBackPropertyValue(aItemList); if (OControlElement::LISTBOX == m_eElementType) { OSL_ENSURE((m_aListSource.getLength() + m_nEmptyListItems) == (m_aValueList.getLength() + m_nEmptyValueItems), "OListAndComboImport::EndElement: inconsistence between labels and values!"); if ( !m_bEncounteredLSAttrib ) { // the value sequence PropertyValue aValueList; aValueList.Name = PROPERTY_LISTSOURCE; aValueList.Value <<= m_aValueList; implPushBackPropertyValue(aValueList); } // the select sequence PropertyValue aSelected; aSelected.Name = PROPERTY_SELECT_SEQ; aSelected.Value <<= m_aSelectedSeq; implPushBackPropertyValue(aSelected); // the default select sequence PropertyValue aDefaultSelected; aDefaultSelected.Name = PROPERTY_DEFAULT_SELECT_SEQ; aDefaultSelected.Value <<= m_aDefaultSelectedSeq; implPushBackPropertyValue(aDefaultSelected); } OControlImport::EndElement(); // the external list source, if applicable if ( m_xElement.is() && m_sCellListSource.getLength() ) m_rContext.registerCellRangeListSource( m_xElement, m_sCellListSource ); } //--------------------------------------------------------------------- void OListAndComboImport::doRegisterCellValueBinding( const ::rtl::OUString& _rBoundCellAddress ) { ::rtl::OUString sBoundCellAddress( _rBoundCellAddress ); if ( m_bLinkWithIndexes ) { // This is a HACK. We register a string which is no valid address, but allows // (somewhere else) to determine that a non-standard binding should be created. // This hack is acceptable for OOo 1.1.1, since the file format for value // bindings of form controls is to be changed afterwards, anyway. sBoundCellAddress += ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( ":index" ) ); } OControlImport::doRegisterCellValueBinding( sBoundCellAddress ); } //--------------------------------------------------------------------- void OListAndComboImport::handleAttribute(sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue) { static const ::rtl::OUString s_sListSourceAttributeName = ::rtl::OUString::createFromAscii(OAttributeMetaData::getDatabaseAttributeName(DA_LIST_SOURCE)); if (s_sListSourceAttributeName == _rLocalName) { PropertyValue aListSource; aListSource.Name = PROPERTY_LISTSOURCE; // it's the ListSource attribute m_bEncounteredLSAttrib = sal_True; if ( OControlElement::COMBOBOX == m_eElementType ) { aListSource.Value <<= _rValue; } else { // a listbox which has a list-source attribute must have a list-source-type of something // not equal to ValueList. // In this case, the list-source value is simply the one and only element of the ListSource property. Sequence< ::rtl::OUString > aListSourcePropValue( 1 ); aListSourcePropValue[0] = _rValue; aListSource.Value <<= aListSourcePropValue; } implPushBackPropertyValue( aListSource ); } else if ( _rLocalName.equalsAscii( OAttributeMetaData::getBindingAttributeName( BA_LIST_CELL_RANGE ) ) ) { m_sCellListSource = _rValue; } else if ( _rLocalName.equalsAscii( OAttributeMetaData::getBindingAttributeName( BA_LIST_LINKING_TYPE ) ) ) { sal_Int16 nLinkageType = 0; PropertyConversion::convertString( m_rContext.getGlobalContext(), ::getCppuType( static_cast< sal_Int16* >( NULL ) ), _rValue, OEnumMapper::getEnumMap( OEnumMapper::epListLinkageType ) ) >>= nLinkageType; m_bLinkWithIndexes = ( nLinkageType != 0 ); } else OControlImport::handleAttribute(_nNamespaceKey, _rLocalName, _rValue); } //--------------------------------------------------------------------- void OListAndComboImport::implPushBackLabel(const ::rtl::OUString& _rLabel) { OSL_ENSURE(!m_nEmptyListItems, "OListAndComboImport::implPushBackValue: label list is already done!"); if (!m_nEmptyListItems) pushBackSequenceElement(m_aListSource, _rLabel); } //--------------------------------------------------------------------- void OListAndComboImport::implPushBackValue(const ::rtl::OUString& _rValue) { OSL_ENSURE(!m_nEmptyValueItems, "OListAndComboImport::implPushBackValue: value list is already done!"); if (!m_nEmptyValueItems) { OSL_ENSURE( !m_bEncounteredLSAttrib, "OListAndComboImport::implPushBackValue: invalid structure! Did you save this document with a version prior SRC641 m?" ); // We already had the list-source attribute, which means that the ListSourceType is // not ValueList, which means that the ListSource should contain only one string in // the first element of the sequence // All other values in the file are invalid pushBackSequenceElement( m_aValueList, _rValue ); } } //--------------------------------------------------------------------- void OListAndComboImport::implEmptyLabelFound() { ++m_nEmptyListItems; } //--------------------------------------------------------------------- void OListAndComboImport::implEmptyValueFound() { ++m_nEmptyValueItems; } //--------------------------------------------------------------------- void OListAndComboImport::implSelectCurrentItem() { OSL_ENSURE((m_aListSource.getLength() + m_nEmptyListItems) == (m_aValueList.getLength() + m_nEmptyValueItems), "OListAndComboImport::implSelectCurrentItem: inconsistence between labels and values!"); sal_Int16 nItemNumber = (sal_Int16)(m_aListSource.getLength() - 1 + m_nEmptyListItems); pushBackSequenceElement(m_aSelectedSeq, nItemNumber); } //--------------------------------------------------------------------- void OListAndComboImport::implDefaultSelectCurrentItem() { OSL_ENSURE((m_aListSource.getLength() + m_nEmptyListItems) == (m_aValueList.getLength() + m_nEmptyValueItems), "OListAndComboImport::implDefaultSelectCurrentItem: inconsistence between labels and values!"); sal_Int16 nItemNumber = (sal_Int16)(m_aListSource.getLength() - 1 + m_nEmptyListItems); pushBackSequenceElement(m_aDefaultSelectedSeq, nItemNumber); } //===================================================================== //= OListOptionImport //===================================================================== //--------------------------------------------------------------------- OListOptionImport::OListOptionImport(SvXMLImport& _rImport, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const OListAndComboImportRef& _rListBox) :SvXMLImportContext(_rImport, _nPrefix, _rName) ,m_xListBoxImport(_rListBox) { } //--------------------------------------------------------------------- void OListOptionImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { // the label and the value const ::rtl::OUString sLabelAttribute = GetImport().GetNamespaceMap().GetQNameByKey( GetPrefix(), ::rtl::OUString::createFromAscii("label")); const ::rtl::OUString sValueAttribute = GetImport().GetNamespaceMap().GetQNameByKey( GetPrefix(), ::rtl::OUString::createFromAscii("value")); // ------------------- // the label attribute ::rtl::OUString sValue = _rxAttrList->getValueByName(sLabelAttribute); sal_Bool bNonexistentAttribute = sal_False; if (!sValue.getLength()) if (0 == _rxAttrList->getTypeByName(sLabelAttribute).getLength()) // this attribute does not really exist bNonexistentAttribute = sal_True; if (bNonexistentAttribute) m_xListBoxImport->implEmptyLabelFound(); else m_xListBoxImport->implPushBackLabel( sValue ); // ------------------- // the value attribute sValue = _rxAttrList->getValueByName(sValueAttribute); bNonexistentAttribute = sal_False; if (!sValue.getLength()) if (0 == _rxAttrList->getTypeByName(sValueAttribute).getLength()) // this attribute does not really exist bNonexistentAttribute = sal_True; if (bNonexistentAttribute) m_xListBoxImport->implEmptyValueFound(); else m_xListBoxImport->implPushBackValue( sValue ); // the current-selected and selected const ::rtl::OUString sSelectedAttribute = GetImport().GetNamespaceMap().GetQNameByKey( GetPrefix(), ::rtl::OUString::createFromAscii(OAttributeMetaData::getCommonControlAttributeName(CCA_CURRENT_SELECTED))); const ::rtl::OUString sDefaultSelectedAttribute = GetImport().GetNamespaceMap().GetQNameByKey( GetPrefix(), ::rtl::OUString::createFromAscii(OAttributeMetaData::getCommonControlAttributeName(CCA_SELECTED))); // propagate the selected flag sal_Bool bSelected; GetImport().GetMM100UnitConverter().convertBool(bSelected, _rxAttrList->getValueByName(sSelectedAttribute)); if (bSelected) m_xListBoxImport->implSelectCurrentItem(); // same for the default selected sal_Bool bDefaultSelected; GetImport().GetMM100UnitConverter().convertBool(bDefaultSelected, _rxAttrList->getValueByName(sDefaultSelectedAttribute)); if (bDefaultSelected) m_xListBoxImport->implDefaultSelectCurrentItem(); SvXMLImportContext::StartElement(_rxAttrList); } //===================================================================== //= OComboItemImport //===================================================================== //--------------------------------------------------------------------- OComboItemImport::OComboItemImport(SvXMLImport& _rImport, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const OListAndComboImportRef& _rListBox) :SvXMLImportContext(_rImport, _nPrefix, _rName) ,m_xListBoxImport(_rListBox) { } //--------------------------------------------------------------------- void OComboItemImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { const ::rtl::OUString sLabelAttributeName = GetImport().GetNamespaceMap().GetQNameByKey( GetPrefix(), ::rtl::OUString::createFromAscii(OAttributeMetaData::getCommonControlAttributeName(CCA_LABEL))); m_xListBoxImport->implPushBackLabel(_rxAttrList->getValueByName(sLabelAttributeName)); SvXMLImportContext::StartElement(_rxAttrList); } //===================================================================== //= OColumnWrapperImport //===================================================================== //--------------------------------------------------------------------- OColumnWrapperImport::OColumnWrapperImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer) :SvXMLImportContext(_rImport.getGlobalContext(), _nPrefix, _rName) ,m_xParentContainer(_rxParentContainer) ,m_rFormImport(_rImport) ,m_rEventManager(_rEventManager) { } //--------------------------------------------------------------------- SvXMLImportContext* OColumnWrapperImport::CreateChildContext(sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, const Reference< sax::XAttributeList >&) { OControlImport* pReturn = implCreateChildContext(_nPrefix, _rLocalName, OElementNameMap::getElementType(_rLocalName)); if (pReturn) { OSL_ENSURE(m_xOwnAttributes.is(), "OColumnWrapperImport::CreateChildContext: had no form:column element!"); pReturn->addOuterAttributes(m_xOwnAttributes); } return pReturn; } //--------------------------------------------------------------------- void OColumnWrapperImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { OSL_ENSURE(!m_xOwnAttributes.is(), "OColumnWrapperImport::StartElement: aready have the cloned list!"); // clone the attributes Reference< XCloneable > xCloneList(_rxAttrList, UNO_QUERY); OSL_ENSURE(xCloneList.is(), "OColumnWrapperImport::StartElement: AttributeList not cloneable!"); if ( xCloneList.is() ) m_xOwnAttributes = Reference< sax::XAttributeList >(xCloneList->createClone(), UNO_QUERY); OSL_ENSURE(m_xOwnAttributes.is(), "OColumnWrapperImport::StartElement: no cloned list!"); } //--------------------------------------------------------------------- OControlImport* OColumnWrapperImport::implCreateChildContext( sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, OControlElement::ElementType _eType) { OSL_ENSURE( (OControlElement::TEXT == _eType) || (OControlElement::TEXT_AREA == _eType) || (OControlElement::FORMATTED_TEXT == _eType) || (OControlElement::CHECKBOX == _eType) || (OControlElement::LISTBOX == _eType) || (OControlElement::COMBOBOX == _eType), "OColumnWrapperImport::implCreateChildContext: invalid or unrecognized sub element!"); switch (_eType) { case OControlElement::COMBOBOX: case OControlElement::LISTBOX: return new OColumnImport(m_rFormImport, m_rEventManager, _nPrefix, _rLocalName, m_xParentContainer, _eType ); case OControlElement::PASSWORD: return new OColumnImport(m_rFormImport, m_rEventManager, _nPrefix, _rLocalName, m_xParentContainer, _eType ); case OControlElement::TEXT: case OControlElement::TEXT_AREA: case OControlElement::FORMATTED_TEXT: return new OColumnImport< OTextLikeImport >( m_rFormImport, m_rEventManager, _nPrefix, _rLocalName, m_xParentContainer, _eType ); default: return new OColumnImport(m_rFormImport, m_rEventManager, _nPrefix, _rLocalName, m_xParentContainer, _eType ); } } //===================================================================== //= OGridImport //===================================================================== //--------------------------------------------------------------------- OGridImport::OGridImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer, OControlElement::ElementType _eType) :OGridImport_Base(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, "column") { setElementType(_eType); } //--------------------------------------------------------------------- SvXMLImportContext* OGridImport::implCreateControlWrapper(sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName) { return new OColumnWrapperImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer); } //===================================================================== //= OFormImport //===================================================================== //--------------------------------------------------------------------- OFormImport::OFormImport(IFormsImportContext& _rImport, IEventAttacherManager& _rEventManager, sal_uInt16 _nPrefix, const ::rtl::OUString& _rName, const Reference< XNameContainer >& _rxParentContainer) :OFormImport_Base(_rImport, _rEventManager, _nPrefix, _rName, _rxParentContainer, "control") { enableTrackAttributes(); } //--------------------------------------------------------------------- SvXMLImportContext* OFormImport::CreateChildContext(sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, const Reference< sax::XAttributeList >& _rxAttrList) { if( token::IsXMLToken(_rLocalName, token::XML_FORM) ) return new OFormImport( m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer); else if ( token::IsXMLToken(_rLocalName, token::XML_CONNECTION_RESOURCE) ) return new OXMLDataSourceImport(GetImport(), _nPrefix, _rLocalName, _rxAttrList,m_xElement); else if( token::IsXMLToken(_rLocalName, token::XML_EVENT_LISTENERS) && (XML_NAMESPACE_OFFICE == _nPrefix) || token::IsXMLToken( _rLocalName, token::XML_PROPERTIES) ) return OElementImport::CreateChildContext( _nPrefix, _rLocalName, _rxAttrList ); else return implCreateChildContext( _nPrefix, _rLocalName, OElementNameMap::getElementType(_rLocalName) ); } //--------------------------------------------------------------------- void OFormImport::StartElement(const Reference< sax::XAttributeList >& _rxAttrList) { m_rFormImport.enterEventContext(); OFormImport_Base::StartElement(_rxAttrList); // handle the target-frame attribute simulateDefaultedAttribute(OAttributeMetaData::getCommonControlAttributeName(CCA_TARGET_FRAME), PROPERTY_TARGETFRAME, "_blank"); } //--------------------------------------------------------------------- void OFormImport::EndElement() { OFormImport_Base::EndElement(); m_rFormImport.leaveEventContext(); } //--------------------------------------------------------------------- SvXMLImportContext* OFormImport::implCreateControlWrapper(sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName) { OSL_ENSURE( !this, "illegal call to OFormImport::implCreateControlWrapper" ); return new SvXMLImportContext(GetImport(), _nPrefix, _rLocalName ); } //--------------------------------------------------------------------- void OFormImport::handleAttribute(sal_uInt16 _nNamespaceKey, const ::rtl::OUString& _rLocalName, const ::rtl::OUString& _rValue) { // handle the master/details field attributes (they're way too special to let the OPropertyImport handle them) static const ::rtl::OUString s_sMasterFieldsAttributeName = ::rtl::OUString::createFromAscii(OAttributeMetaData::getFormAttributeName(faMasterFields)); static const ::rtl::OUString s_sDetailFieldsAttributeName = ::rtl::OUString::createFromAscii(OAttributeMetaData::getFormAttributeName(faDetailFiels)); if (s_sMasterFieldsAttributeName == _rLocalName) implTranslateStringListProperty(PROPERTY_MASTERFIELDS, _rValue); else if (s_sDetailFieldsAttributeName == _rLocalName) implTranslateStringListProperty(PROPERTY_DETAILFIELDS, _rValue); else OFormImport_Base::handleAttribute(_nNamespaceKey, _rLocalName, _rValue); } //--------------------------------------------------------------------- void OFormImport::implTranslateStringListProperty(const ::rtl::OUString& _rPropertyName, const ::rtl::OUString& _rValue) { PropertyValue aProp; aProp.Name = _rPropertyName; Sequence< ::rtl::OUString > aList; // split up the value string if (_rValue.getLength()) { // For the moment, we build a vector instead of a Sequence. It's easier to handle because of it's // push_back method ::std::vector< ::rtl::OUString > aElements; // estimate the number of tokens sal_Int32 nEstimate = 0, nLength = _rValue.getLength(); const sal_Unicode* pChars = _rValue.getStr(); for (sal_Int32 i=0; i= 2) && (sElement.getStr()[0] == '"') && (sElement.getStr()[nElementLength - 1] == '"'), "OFormImport::implTranslateStringListProperty: invalid quoted element name."); sElement = sElement.copy(1, nElementLength - 2); aElements.push_back(sElement); // swith to the next element nElementStart = 1 + nNextSep; } while (nElementStart < nLength); ::rtl::OUString *pElements = aElements.empty() ? 0 : &aElements[0]; aList = Sequence< ::rtl::OUString >(pElements, aElements.size()); } else { OSL_ENSURE(sal_False, "OFormImport::implTranslateStringListProperty: invalid value (empty)!"); } aProp.Value <<= aList; // add the property to the base class' array implPushBackPropertyValue(aProp); } //===================================================================== //= OXMLDataSourceImport //===================================================================== OXMLDataSourceImport::OXMLDataSourceImport( SvXMLImport& _rImport ,sal_uInt16 nPrfx , const ::rtl::OUString& _sLocalName ,const Reference< ::com::sun::star::xml::sax::XAttributeList > & _xAttrList ,const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet >& _xElement) : SvXMLImportContext( _rImport, nPrfx, _sLocalName ) { OSL_ENSURE(_xAttrList.is(),"Attribute list is NULL!"); const SvXMLNamespaceMap& rMap = _rImport.GetNamespaceMap(); sal_Int16 nLength = (_xElement.is() && _xAttrList.is()) ? _xAttrList->getLength() : 0; for(sal_Int16 i = 0; i < nLength; ++i) { ::rtl::OUString sLocalName; ::rtl::OUString sAttrName = _xAttrList->getNameByIndex( i ); sal_uInt16 nPrefix = rMap.GetKeyByAttrName( sAttrName, &sLocalName ); if ( ( nPrefix == OAttributeMetaData::getCommonControlAttributeNamespace( CCA_TARGET_LOCATION ) ) && ( sLocalName.equalsAscii( OAttributeMetaData::getCommonControlAttributeName( CCA_TARGET_LOCATION ) ) ) ) { ::rtl::OUString sValue = _xAttrList->getValueByIndex( i ); INetURLObject aURL(sValue); if ( aURL.GetProtocol() == INET_PROT_FILE ) _xElement->setPropertyValue(PROPERTY_DATASOURCENAME,makeAny(sValue)); else _xElement->setPropertyValue(PROPERTY_URL,makeAny(sValue)); // the url is the "sdbc:" string break; } } } //--------------------------------------------------------------------- OControlImport* OFormImport::implCreateChildContext( sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, OControlElement::ElementType _eType ) { switch (_eType) { case OControlElement::TEXT: case OControlElement::TEXT_AREA: case OControlElement::FORMATTED_TEXT: return new OTextLikeImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); case OControlElement::BUTTON: case OControlElement::IMAGE: case OControlElement::IMAGE_FRAME: return new OButtonImport( m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType ); case OControlElement::COMBOBOX: case OControlElement::LISTBOX: return new OListAndComboImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); case OControlElement::RADIO: return new ORadioImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); case OControlElement::CHECKBOX: return new OImagePositionImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); case OControlElement::PASSWORD: return new OPasswordImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); case OControlElement::FRAME: case OControlElement::FIXED_TEXT: return new OReferredControlImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); case OControlElement::GRID: return new OGridImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); case OControlElement::VALUERANGE: return new OValueRangeImport( m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType ); default: return new OControlImport(m_rFormImport, *this, _nPrefix, _rLocalName, m_xMeAsContainer, _eType); } } //......................................................................... } // namespace xmloff //.........................................................................