mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-07-11 19:37:12 +02:00
bin
module
vendor
CPR
ConcurrentQueue
Fmt
JSMN
MaxmindDB
POCO
ApacheConnector
CppParser
CppUnit
Crypto
Data
Encodings
Foundation
cmake
include
Poco
Dynamic
ASCIIEncoding.h
AbstractCache.h
AbstractDelegate.h
AbstractEvent.h
AbstractObserver.h
AbstractPriorityDelegate.h
AbstractStrategy.h
AccessExpirationDecorator.h
AccessExpireCache.h
AccessExpireLRUCache.h
AccessExpireStrategy.h
ActiveDispatcher.h
ActiveMethod.h
ActiveResult.h
ActiveRunnable.h
ActiveStarter.h
Activity.h
Alignment.h
Any.h
ArchiveStrategy.h
Array.h
Ascii.h
AsyncChannel.h
AtomicCounter.h
AtomicFlag.h
AutoPtr.h
AutoReleasePool.h
Base32Decoder.h
Base32Encoder.h
Base64Decoder.h
Base64Encoder.h
BasicEvent.h
BinaryReader.h
BinaryWriter.h
Buffer.h
BufferAllocator.h
BufferedBidirectionalStreamBuf.h
BufferedStreamBuf.h
Bugcheck.h
ByteOrder.h
Channel.h
Checksum.h
ClassLibrary.h
ClassLoader.h
Clock.h
Condition.h
Config.h
Configurable.h
ConsoleChannel.h
CountingStream.h
DataURIStream.h
DataURIStreamFactory.h
DateTime.h
DateTimeFormat.h
DateTimeFormatter.h
DateTimeParser.h
Debugger.h
DefaultStrategy.h
DeflatingStream.h
Delegate.h
DigestEngine.h
DigestStream.h
DirectoryIterator.h
DirectoryIteratorStrategy.h
DirectoryIterator_UNIX.h
DirectoryIterator_WIN32U.h
DirectoryWatcher.h
DynamicAny.h
DynamicAnyHolder.h
DynamicFactory.h
DynamicStruct.h
Environment.h
Environment_UNIX.h
Environment_VX.h
Environment_WIN32U.h
Environment_WINCE.h
Error.h
ErrorHandler.h
Event.h
EventArgs.h
EventChannel.h
EventLogChannel.h
Event_POSIX.h
Event_VX.h
Event_WIN32.h
Exception.h
ExpirationDecorator.h
Expire.h
ExpireCache.h
ExpireLRUCache.h
ExpireStrategy.h
FIFOBuffer.h
FIFOBufferStream.h
FIFOEvent.h
FIFOStrategy.h
FPEnvironment.h
FPEnvironment_C99.h
FPEnvironment_DEC.h
FPEnvironment_DUMMY.h
FPEnvironment_QNX.h
FPEnvironment_SUN.h
FPEnvironment_WIN32.h
File.h
FileChannel.h
FileStream.h
FileStreamFactory.h
FileStream_POSIX.h
FileStream_WIN32.h
File_UNIX.h
File_VX.h
File_WIN32U.h
File_WINCE.h
Format.h
Formatter.h
FormattingChannel.h
Foundation.h
FunctionDelegate.h
FunctionPriorityDelegate.h
Glob.h
HMACEngine.h
Hash.h
HashFunction.h
HashMap.h
HashSet.h
HashStatistic.h
HashTable.h
HexBinaryDecoder.h
HexBinaryEncoder.h
InflatingStream.h
Instantiator.h
JSONString.h
KeyValueArgs.h
LRUCache.h
LRUStrategy.h
Latin1Encoding.h
Latin2Encoding.h
Latin9Encoding.h
LineEndingConverter.h
LinearHashTable.h
ListMap.h
LocalDateTime.h
LogFile.h
LogFile_STD.h
LogFile_WIN32U.h
LogStream.h
Logger.h
LoggingFactory.h
LoggingRegistry.h
MD4Engine.h
MD5Engine.h
Manifest.h
MemoryPool.h
MemoryStream.h
Message.h
MetaObject.h
MetaProgramming.h
Mutex.h
Mutex_POSIX.h
Mutex_VX.h
Mutex_WIN32.h
Mutex_WINCE.h
NObserver.h
NamedEvent.h
NamedEvent_Android.h
NamedEvent_UNIX.h
NamedEvent_WIN32U.h
NamedMutex.h
NamedMutex_Android.h
NamedMutex_UNIX.h
NamedMutex_WIN32U.h
NamedTuple.h
NestedDiagnosticContext.h
Notification.h
NotificationCenter.h
NotificationQueue.h
NotificationStrategy.h
NullChannel.h
NullStream.h
Nullable.h
NumberFormatter.h
NumberParser.h
NumericString.h
ObjectPool.h
Observer.h
Optional.h
OrderedMap.h
OrderedSet.h
PBKDF2Engine.h
Path.h
Path_UNIX.h
Path_WIN32U.h
Path_WINCE.h
PatternFormatter.h
Pipe.h
PipeImpl.h
PipeImpl_DUMMY.h
PipeImpl_POSIX.h
PipeImpl_WIN32.h
PipeStream.h
Platform.h
Platform_POSIX.h
Platform_VX.h
Platform_WIN32.h
Poco.h
PriorityDelegate.h
PriorityEvent.h
PriorityExpire.h
PriorityNotificationQueue.h
PriorityStrategy.h
Process.h
Process_UNIX.h
Process_VX.h
Process_WIN32U.h
Process_WINCE.h
PurgeStrategy.h
RWLock.h
RWLock_Android.h
RWLock_POSIX.h
RWLock_VX.h
RWLock_WIN32.h
RWLock_WINCE.h
Random.h
RandomStream.h
RecursiveDirectoryIterator.h
RecursiveDirectoryIteratorImpl.h
RefCountedObject.h
RegularExpression.h
RotateStrategy.h
Runnable.h
RunnableAdapter.h
SHA1Engine.h
SHA2Engine.h
ScopedLock.h
ScopedUnlock.h
Semaphore.h
Semaphore_POSIX.h
Semaphore_VX.h
Semaphore_WIN32.h
SharedLibrary.h
SharedLibrary_HPUX.h
SharedLibrary_UNIX.h
SharedLibrary_VX.h
SharedLibrary_WIN32U.h
SharedMemory.h
SharedMemory_DUMMY.h
SharedMemory_POSIX.h
SharedMemory_WIN32.h
SharedPtr.h
SignalHandler.h
SimpleFileChannel.h
SimpleHashTable.h
SingletonHolder.h
SortedDirectoryIterator.h
SplitterChannel.h
Stopwatch.h
StrategyCollection.h
StreamChannel.h
StreamConverter.h
StreamCopier.h
StreamTokenizer.h
StreamUtil.h
String.h
StringTokenizer.h
SynchronizedObject.h
SyslogChannel.h
Task.h
TaskManager.h
TaskNotification.h
TeeStream.h
TemporaryFile.h
TextBufferIterator.h
TextConverter.h
TextEncoding.h
TextIterator.h
Thread.h
ThreadLocal.h
ThreadPool.h
ThreadTarget.h
Thread_POSIX.h
Thread_VX.h
Thread_WIN32.h
Thread_WINCE.h
TimedNotificationQueue.h
Timer.h
Timespan.h
Timestamp.h
Timezone.h
Token.h
Tuple.h
TypeList.h
Types.h
URI.h
URIStreamFactory.h
URIStreamOpener.h
UTF16Encoding.h
UTF32Encoding.h
UTF8Encoding.h
UTF8String.h
UTFString.h
UUID.h
UUIDGenerator.h
UnWindows.h
UnbufferedStreamBuf.h
Unicode.h
UnicodeConverter.h
UniqueAccessExpireCache.h
UniqueAccessExpireLRUCache.h
UniqueAccessExpireStrategy.h
UniqueExpireCache.h
UniqueExpireLRUCache.h
UniqueExpireStrategy.h
ValidArgs.h
Version.h
Void.h
Windows1250Encoding.h
Windows1251Encoding.h
Windows1252Encoding.h
WindowsConsoleChannel.h
ordered_hash.h
ordered_map.h
ordered_set.h
zconf.h
zlib.h
samples
src
testsuite
wcelibcex-1.0
CMakeLists.txt
Foundation_vs140.sln
Foundation_vs140.vcxproj
Foundation_vs140.vcxproj.filters
Foundation_vs150.sln
Foundation_vs150.vcxproj
Foundation_vs150.vcxproj.filters
Foundation_vs160.sln
Foundation_vs160.vcxproj
Foundation_vs160.vcxproj.filters
Makefile
extradirs
JSON
JWT
MongoDB
Net
NetSSL_OpenSSL
NetSSL_Win
PDF
PageCompiler
PocoDoc
ProGen
Redis
SevenZip
Util
XML
Zip
appveyor
build
cmake
contrib
doc
packaging
patches
release
travis
.gitattributes
.gitignore
.gitmodules
.travis.yml
CHANGELOG
CMakeLists.txt
CODE_OF_CONDUCT.md
CONTRIBUTING.md
CONTRIBUTORS
LICENSE
Makefile
NEWS
README
README.md
VERSION
appveyor.yml
build_cmake.cmd
build_cmake.sh
build_vs140.cmd
build_vs150.cmd
build_vs160.cmd
buildwin.cmd
buildwin.ps1
components
configure
cppignore.lnx
cppignore.win
env.bat
env.sh
libversion
SimpleIni
Squirrel
TinyDir
ZMQ
CMakeLists.txt
.gitignore
.gitmodules
CMakeLists.txt
LICENSE
README.md
Switched to POCO library for unified platform/library interface. Deprecated the external module API. It was creating more problems than solving. Removed most built-in libraries in favor of system libraries for easier maintenance. Cleaned and secured code with help from static analyzers.
266 lines
5.5 KiB
C++
266 lines
5.5 KiB
C++
//
|
|
// ListMap.h
|
|
//
|
|
// Library: Foundation
|
|
// Package: Core
|
|
// Module: ListMap
|
|
//
|
|
// Definition of the ListMap class.
|
|
//
|
|
// Copyright (c) 2006, Applied Informatics Software Engineering GmbH.
|
|
// and Contributors.
|
|
//
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
//
|
|
|
|
|
|
#ifndef Foundation_ListMap_INCLUDED
|
|
#define Foundation_ListMap_INCLUDED
|
|
|
|
|
|
#include "Poco/Foundation.h"
|
|
#include "Poco/String.h"
|
|
#include "Poco/Exception.h"
|
|
#include <vector>
|
|
#include <utility>
|
|
|
|
|
|
namespace Poco {
|
|
|
|
|
|
template <class Key, class Mapped, class Container = std::vector<std::pair<Key, Mapped>>, bool CaseSensitive = false>
|
|
class ListMap
|
|
/// This class implements a multimap in terms of a sequential container.
|
|
/// The use for this type of associative container is wherever automatic
|
|
/// ordering of elements is not desirable. Naturally, this container will
|
|
/// have inferior data retrieval performance and it is not recommended for
|
|
/// use with large datasets. The main purpose within POCO is for Internet
|
|
/// messages (email message, http headers etc), to prevent automatic
|
|
/// header entry reordering.
|
|
{
|
|
public:
|
|
using KeyType = Key;
|
|
using MappedType = Mapped;
|
|
using Reference = Mapped&;
|
|
using ConstReference = const Mapped&;
|
|
using Pointer = Mapped*;
|
|
using ConstPointer = const Mapped*;
|
|
|
|
using ValueType = typename Container::value_type;
|
|
using SizeType = typename Container::size_type;
|
|
using Iterator = typename Container::iterator;
|
|
using ConstIterator = typename Container::const_iterator;
|
|
|
|
ListMap()
|
|
/// Creates an empty ListMap.
|
|
{
|
|
}
|
|
|
|
explicit ListMap(std::size_t initialReserve):
|
|
_container(initialReserve)
|
|
/// Creates the ListMap with room for initialReserve entries.
|
|
{
|
|
}
|
|
|
|
ListMap(const ListMap& other):
|
|
_container(other._container)
|
|
{
|
|
}
|
|
|
|
ListMap(ListMap&& other) noexcept:
|
|
_container(std::move(other._container))
|
|
{
|
|
}
|
|
|
|
ListMap& operator = (const ListMap& map)
|
|
/// Assigns another ListMap.
|
|
{
|
|
ListMap tmp(map);
|
|
swap(tmp);
|
|
return *this;
|
|
}
|
|
|
|
ListMap& operator = (ListMap&& map) noexcept
|
|
/// Assigns another ListMap.
|
|
{
|
|
_container = std::move(map._container);
|
|
return *this;
|
|
}
|
|
|
|
void swap(ListMap& map)
|
|
/// Swaps the ListMap with another one.
|
|
{
|
|
_container.swap(map._container);
|
|
}
|
|
|
|
ConstIterator begin() const
|
|
/// Returns the beginning of the map.
|
|
{
|
|
return _container.begin();
|
|
}
|
|
|
|
ConstIterator end() const
|
|
/// Returns the end of the map.
|
|
{
|
|
return _container.end();
|
|
}
|
|
|
|
Iterator begin()
|
|
/// Returns the beginning of the map.
|
|
{
|
|
return _container.begin();
|
|
}
|
|
|
|
Iterator end()
|
|
/// Returns the end of the map.
|
|
{
|
|
return _container.end();
|
|
}
|
|
|
|
ConstIterator find(const KeyType& key) const
|
|
/// Finds the first occurrence of the key and
|
|
/// returns iterator pointing to the found entry
|
|
/// or iterator pointing to the end if entry is
|
|
/// not found.
|
|
{
|
|
typename Container::const_iterator it = _container.begin();
|
|
typename Container::const_iterator itEnd = _container.end();
|
|
for(; it != itEnd; ++it)
|
|
{
|
|
if (isEqual(it->first, key)) return it;
|
|
}
|
|
return itEnd;
|
|
}
|
|
|
|
Iterator find(const KeyType& key)
|
|
/// Finds the first occurrence of the key and
|
|
/// returns iterator pointing to the found entry
|
|
/// or iterator pointing to the end if entry is
|
|
/// not found.
|
|
{
|
|
typename Container::iterator it = _container.begin();
|
|
typename Container::iterator itEnd = _container.end();
|
|
for(; it != itEnd; ++it)
|
|
{
|
|
if (isEqual(it->first, key)) return it;
|
|
}
|
|
return itEnd;
|
|
}
|
|
|
|
Iterator insert(const ValueType& val)
|
|
/// Inserts the value into the map. If one or more values
|
|
/// already exist, new value is inserted at the end of the
|
|
/// block. Thus, all the equal value entries are located
|
|
/// sequentially at all times.
|
|
/// Returns iterator pointing to the newly inserted value
|
|
{
|
|
Iterator it = find(val.first);
|
|
while (it != _container.end() && isEqual(it->first, val.first)) ++it;
|
|
return _container.insert(it, val);
|
|
}
|
|
|
|
void erase(Iterator it)
|
|
{
|
|
_container.erase(it);
|
|
}
|
|
|
|
SizeType erase(const KeyType& key)
|
|
{
|
|
SizeType count = 0;
|
|
Iterator it = find(key);
|
|
bool removed = false;
|
|
while (it != _container.end())
|
|
{
|
|
if (isEqual(it->first, key))
|
|
{
|
|
++count;
|
|
it = _container.erase(it);
|
|
removed = true;
|
|
}
|
|
else
|
|
{
|
|
if (removed) return count;
|
|
++it;
|
|
}
|
|
}
|
|
return count;
|
|
}
|
|
|
|
void clear()
|
|
{
|
|
_container.clear();
|
|
}
|
|
|
|
std::size_t size() const
|
|
{
|
|
return _container.size();
|
|
}
|
|
|
|
bool empty() const
|
|
{
|
|
return _container.empty();
|
|
}
|
|
|
|
ConstReference operator [] (const KeyType& key) const
|
|
{
|
|
ConstIterator it = find(key);
|
|
if (it != _container.end())
|
|
return it->second;
|
|
else
|
|
throw NotFoundException();
|
|
}
|
|
|
|
Reference operator [] (const KeyType& key)
|
|
{
|
|
Iterator it = find(key);
|
|
if (it != _container.end())
|
|
{
|
|
return it->second;
|
|
}
|
|
else
|
|
{
|
|
ValueType value(key, Mapped());
|
|
Iterator itInsert = insert(value);
|
|
return itInsert->second;
|
|
}
|
|
}
|
|
|
|
private:
|
|
template <typename T1, typename T2>
|
|
bool isEqual(T1 val1, T2 val2) const
|
|
{
|
|
return val1 == val2;
|
|
}
|
|
|
|
bool isEqual(const std::string& s1, const std::string& s2) const
|
|
{
|
|
if (!CaseSensitive)
|
|
return Poco::icompare(s1, s2) == 0;
|
|
else
|
|
return s1 == s2;
|
|
}
|
|
|
|
bool isEqual(const std::string& s1, const char* s2) const
|
|
{
|
|
return isEqual(s1, std::string(s2));
|
|
}
|
|
|
|
bool isEqual(const char* s1, const std::string& s2) const
|
|
{
|
|
return isEqual(std::string(s1), s2);
|
|
}
|
|
|
|
bool isEqual(const char* s1, const char* s2) const
|
|
{
|
|
return isEqual(std::string(s1), std::string(s2));
|
|
}
|
|
|
|
Container _container;
|
|
};
|
|
|
|
|
|
} // namespace Poco
|
|
|
|
|
|
#endif // Foundation_ListMap_INCLUDED
|