diff options
Diffstat (limited to 'sax/source/expatwrap/attrlistimpl.cxx')
-rw-r--r-- | sax/source/expatwrap/attrlistimpl.cxx | 168 |
1 files changed, 168 insertions, 0 deletions
diff --git a/sax/source/expatwrap/attrlistimpl.cxx b/sax/source/expatwrap/attrlistimpl.cxx new file mode 100644 index 000000000000..114eb653f648 --- /dev/null +++ b/sax/source/expatwrap/attrlistimpl.cxx @@ -0,0 +1,168 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +#include "attrlistimpl.hxx" + +#include <vector> + +#include <cppuhelper/weak.hxx> + +using namespace ::std; +using namespace ::rtl; +using namespace ::cppu; +using namespace ::com::sun::star::uno; +using namespace ::com::sun::star::util; +using namespace ::com::sun::star::xml::sax; + + +namespace sax_expatwrap { +struct TagAttribute +{ + TagAttribute() + {} + TagAttribute( const OUString &aName, const OUString &aType , const OUString &aValue ) + { + this->sName = aName; + this->sType = aType; + this->sValue = aValue; + } + + OUString sName; + OUString sType; + OUString sValue; +}; + +struct AttributeList_impl +{ + AttributeList_impl() + { + // performance improvement during adding + vecAttribute.reserve(20); + } + vector<struct TagAttribute> vecAttribute; +}; + + + +sal_Int16 AttributeList::getLength(void) throw (RuntimeException) +{ + return static_cast<sal_Int16>(m_pImpl->vecAttribute.size()); +} + + +AttributeList::AttributeList( const AttributeList &r ) : + cppu::WeakImplHelper2<XAttributeList, XCloneable>() +{ + m_pImpl = new AttributeList_impl; + *m_pImpl = *(r.m_pImpl); +} + +OUString AttributeList::getNameByIndex(sal_Int16 i) throw (RuntimeException) +{ + if( std::vector< TagAttribute >::size_type(i) < m_pImpl->vecAttribute.size() ) { + return m_pImpl->vecAttribute[i].sName; + } + return OUString(); +} + + +OUString AttributeList::getTypeByIndex(sal_Int16 i) throw (RuntimeException) +{ + if( std::vector< TagAttribute >::size_type(i) < m_pImpl->vecAttribute.size() ) { + return m_pImpl->vecAttribute[i].sType; + } + return OUString(); +} + +OUString AttributeList::getValueByIndex(sal_Int16 i) throw (RuntimeException) +{ + if( std::vector< TagAttribute >::size_type(i) < m_pImpl->vecAttribute.size() ) { + return m_pImpl->vecAttribute[i].sValue; + } + return OUString(); + +} + +OUString AttributeList::getTypeByName( const OUString& sName ) throw (RuntimeException) +{ + vector<struct TagAttribute>::iterator ii = m_pImpl->vecAttribute.begin(); + + for( ; ii != m_pImpl->vecAttribute.end() ; ii ++ ) { + if( (*ii).sName == sName ) { + return (*ii).sType; + } + } + return OUString(); +} + +OUString AttributeList::getValueByName(const OUString& sName) throw (RuntimeException) +{ + vector<struct TagAttribute>::iterator ii = m_pImpl->vecAttribute.begin(); + + for( ; ii != m_pImpl->vecAttribute.end() ; ii ++ ) { + if( (*ii).sName == sName ) { + return (*ii).sValue; + } + } + return OUString(); +} + + +Reference< XCloneable > AttributeList::createClone() throw (RuntimeException) +{ + AttributeList *p = new AttributeList( *this ); + return Reference< XCloneable > ( (XCloneable * ) p ); +} + + + +AttributeList::AttributeList() +{ + m_pImpl = new AttributeList_impl; +} + + + +AttributeList::~AttributeList() +{ + delete m_pImpl; +} + + +void AttributeList::addAttribute( const OUString &sName , + const OUString &sType , + const OUString &sValue ) +{ + m_pImpl->vecAttribute.push_back( TagAttribute( sName , sType , sValue ) ); +} + +void AttributeList::clear() +{ + m_pImpl->vecAttribute.clear(); +} + +} |