2019-12-29 10:35:06 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "tarray.h"
|
|
|
|
#include "zstring.h"
|
2020-01-29 17:10:07 +00:00
|
|
|
#include "dobject.h"
|
2019-12-29 10:35:06 +00:00
|
|
|
|
2020-01-29 17:10:07 +00:00
|
|
|
#include <memory>
|
2019-12-31 15:26:52 +00:00
|
|
|
|
2020-01-29 17:10:07 +00:00
|
|
|
/**
|
|
|
|
* @brief The Dictionary class exists to be exported to ZScript.
|
|
|
|
*
|
|
|
|
* It is a string-to-string map.
|
|
|
|
*
|
|
|
|
* It is derived from DObject to be a part of normal GC process.
|
|
|
|
*/
|
2020-02-06 14:20:33 +00:00
|
|
|
class Dictionary final : public DObject
|
2019-12-31 15:26:52 +00:00
|
|
|
{
|
2020-01-29 17:10:07 +00:00
|
|
|
DECLARE_CLASS(Dictionary, DObject)
|
2019-12-31 15:26:52 +00:00
|
|
|
|
2020-01-29 17:10:07 +00:00
|
|
|
public:
|
|
|
|
|
2020-02-06 14:20:33 +00:00
|
|
|
using StringMap = TMap<FString, FString>;
|
|
|
|
using ConstIterator = StringMap::ConstIterator;
|
|
|
|
using ConstPair = StringMap::ConstPair;
|
|
|
|
|
2020-01-29 17:10:07 +00:00
|
|
|
void Serialize(FSerializer &arc) override;
|
2020-02-06 14:20:33 +00:00
|
|
|
|
|
|
|
StringMap Map;
|
2020-01-29 17:10:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The DictionaryIterator class exists to be exported to ZScript.
|
|
|
|
*
|
|
|
|
* It provides iterating over a Dictionary. The order is not specified.
|
|
|
|
*
|
|
|
|
* It is derived from DObject to be a part of normal GC process.
|
|
|
|
*/
|
|
|
|
class DictionaryIterator final : public DObject
|
|
|
|
{
|
|
|
|
DECLARE_CLASS(DictionaryIterator, DObject)
|
|
|
|
HAS_OBJECT_POINTERS
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
~DictionaryIterator() override = default;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* IMPLEMENT_CLASS macro needs a constructor without parameters.
|
|
|
|
*
|
|
|
|
* @see init().
|
|
|
|
*/
|
|
|
|
DictionaryIterator();
|
|
|
|
|
2020-02-06 14:20:33 +00:00
|
|
|
void Serialize(FSerializer &arc) override;
|
2020-01-29 17:10:07 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief init function complements constructor.
|
|
|
|
* @attention always call init after constructing DictionaryIterator.
|
|
|
|
*/
|
|
|
|
void init(Dictionary *dict);
|
|
|
|
|
|
|
|
std::unique_ptr<Dictionary::ConstIterator> Iterator;
|
2019-12-31 15:26:52 +00:00
|
|
|
Dictionary::ConstPair *Pair;
|
2020-01-29 17:10:07 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Dictionary attribute exists for holding a pointer to iterated
|
|
|
|
* dictionary, so it is known by GC.
|
|
|
|
*/
|
|
|
|
Dictionary *Dict;
|
2019-12-31 15:26:52 +00:00
|
|
|
};
|