summaryrefslogtreecommitdiff
path: root/hwpfilter/source/attributes.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'hwpfilter/source/attributes.cxx')
-rw-r--r--hwpfilter/source/attributes.cxx168
1 files changed, 168 insertions, 0 deletions
diff --git a/hwpfilter/source/attributes.cxx b/hwpfilter/source/attributes.cxx
new file mode 100644
index 000000000000..46f8d85c6118
--- /dev/null
+++ b/hwpfilter/source/attributes.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.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_hwpfilter.hxx"
+
+#include <assert.h>
+#ifndef __SGI_STL_VECTOR
+#include <vector>
+#endif
+#include "attributes.hxx"
+
+//using namespace ::std;
+
+struct TagAttribute
+{
+ TagAttribute(){}
+ TagAttribute( const OUString &rName, const OUString &rType , const OUString &rValue )
+ {
+ sName = rName;
+ sType = rType;
+ sValue = rValue;
+ }
+
+ OUString sName;
+ OUString sType;
+ OUString sValue;
+};
+
+struct AttributeListImpl_impl
+{
+ AttributeListImpl_impl()
+ {
+// performance improvement during adding
+ vecAttribute.reserve(20);
+ }
+ std::vector<struct TagAttribute> vecAttribute;
+};
+
+sal_Int16 SAL_CALL AttributeListImpl::getLength(void) throw (RuntimeException)
+{
+ return (sal_Int16)m_pImpl->vecAttribute.size();
+}
+
+
+AttributeListImpl::AttributeListImpl( const AttributeListImpl &r ) :
+cppu::WeakImplHelper1<com::sun::star::xml::sax::XAttributeList>( r )
+{
+ m_pImpl = new AttributeListImpl_impl;
+ *m_pImpl = *(r.m_pImpl);
+}
+
+
+OUString AttributeListImpl::getNameByIndex(sal_Int16 i) throw (RuntimeException)
+{
+ sal_uInt32 i2 = sal::static_int_cast<sal_Int16>(i);
+ if( i >= 0 && i2 < m_pImpl->vecAttribute.size() )
+ {
+ return m_pImpl->vecAttribute[i].sName;
+ }
+ return OUString();
+}
+
+
+OUString AttributeListImpl::getTypeByIndex(sal_Int16 i) throw (RuntimeException)
+{
+ sal_uInt32 i2 = sal::static_int_cast<sal_Int16>(i);
+ if( i >= 0 && i2 < m_pImpl->vecAttribute.size() )
+ {
+ return m_pImpl->vecAttribute[i].sType;
+ }
+ return OUString();
+}
+
+
+OUString AttributeListImpl::getValueByIndex(sal_Int16 i) throw (RuntimeException)
+{
+ sal_uInt32 i2 = sal::static_int_cast<sal_Int16>(i);
+ if( i >= 0 && i2 < m_pImpl->vecAttribute.size() )
+ {
+ return m_pImpl->vecAttribute[i].sValue;
+ }
+ return OUString();
+
+}
+
+
+OUString AttributeListImpl::getTypeByName( const OUString& sName ) throw (RuntimeException)
+{
+ std::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 AttributeListImpl::getValueByName(const OUString& sName) throw (RuntimeException)
+{
+ std::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();
+}
+
+
+AttributeListImpl::AttributeListImpl()
+{
+ m_pImpl = new AttributeListImpl_impl;
+}
+
+
+AttributeListImpl::~AttributeListImpl()
+{
+ delete m_pImpl;
+}
+
+
+void AttributeListImpl::addAttribute( const OUString &sName ,
+const OUString &sType ,
+const OUString &sValue )
+{
+ m_pImpl->vecAttribute.push_back( TagAttribute( sName , sType , sValue ) );
+}
+
+
+void AttributeListImpl::clear()
+{
+ std::vector<struct TagAttribute> dummy;
+ m_pImpl->vecAttribute.swap( dummy );
+
+ assert( ! getLength() );
+}