/* -*- 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 . */ #ifndef INCLUDED_FRAMEWORK_INC_STDTYPES_H #define INCLUDED_FRAMEWORK_INC_STDTYPES_H #include #include #include #include #include #include #include #include namespace framework{ /** Own hash functions used for stl-structures ... e.g. hash tables/maps ... */ struct ShortHashCode { size_t operator()( const ::sal_Int16& nShort ) const { return (size_t)nShort; } }; struct Int32HashCode { size_t operator()( const ::sal_Int32& nValue ) const { return (size_t)nValue; } }; struct KeyEventHashCode { size_t operator()( const css::awt::KeyEvent& aEvent ) const { return (size_t)(aEvent.KeyCode + //aEvent.KeyChar + //aEvent.KeyFunc + aEvent.Modifiers); } }; struct KeyEventEqualsFunc { bool operator()(const css::awt::KeyEvent aKey1, const css::awt::KeyEvent aKey2) const { return ( (aKey1.KeyCode == aKey2.KeyCode ) && //(aKey1.KeyChar == aKey2.KeyChar ) && //(aKey1.KeyFunc == aKey2.KeyFunc ) && (aKey1.Modifiers == aKey2.Modifiers) ); } }; //_________________________________________________________________________________________________________________ /** Basic string list based on a std::vector() It implements some additional funtionality which can be useful but is missing at the normal vector implementation. */ class OUStringList : public ::comphelper::SequenceAsVector< OUString > { public: // insert given element as the first one into the vector void push_front( const OUString& sElement ) { insert( begin(), sElement ); } // search for given element iterator find( const OUString& sElement ) { return ::std::find(begin(), end(), sElement); } const_iterator findConst( const OUString& sElement ) const { return ::std::find(begin(), end(), sElement); } // the only way to free used memory realy! void free() { OUStringList().swap( *this ); } }; //_________________________________________________________________________________________________________________ /** Basic string queue based on a std::queue() It implements some additional funtionality which can be useful but is missing at the normal std implementation. */ typedef ::std::queue< OUString > OUStringQueue; //_________________________________________________________________________________________________________________ /** Basic hash based on a boost::unordered_map() which provides key=[OUString] and value=[template type] pairs It implements some additional funtionality which can be useful but is missing at the normal hash implementation. */ template< class TType > class BaseHash : public ::boost::unordered_map< OUString , TType , OUStringHash , ::std::equal_to< OUString > > { public: // the only way to free used memory realy! void free() { BaseHash().swap( *this ); } }; //_________________________________________________________________________________________________________________ /** Basic OUString hash. Key and values are OUStrings. */ typedef BaseHash< OUString > OUStringHashMap; //_________________________________________________________________________________________________________________ /** It can be used to map names (e.g. of properties) to her corresponding handles. Our helper class OPropertySetHelper works optimized with handles but sometimes we have only a property name. Mapping between these two parts of a property should be done in the fastest way :-) */ typedef BaseHash< sal_Int32 > NameToHandleHash; //_________________________________________________________________________________________________________________ /** Sometimes we need this template to implement listener container ... and we need it at different positions ... So it's better to declare it one times only! */ typedef ::cppu::OMultiTypeInterfaceContainerHelperVar< OUString , OUStringHash > ListenerHash; } // namespace framework #endif // INCLUDED_FRAMEWORK_INC_STDTYPES_H /* vim:set shiftwidth=4 softtabstop=4 expandtab: */