mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-22 06:16:01 +00:00 
			
		
		
		
	Add initial draft of structured data def parser to parse enums only for now
This commit is contained in:
		| @@ -0,0 +1,13 @@ | ||||
| #include "CommonStructuredDataDef.h" | ||||
|  | ||||
| CommonStructuredDataDef::CommonStructuredDataDef() | ||||
|     : CommonStructuredDataDef(0) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDef::CommonStructuredDataDef(const int version) | ||||
|     : m_version(version), | ||||
|       m_checksum(0u), | ||||
|       m_size(0u) | ||||
| { | ||||
| } | ||||
| @@ -0,0 +1,24 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <memory> | ||||
| #include <vector> | ||||
|  | ||||
| #include "CommonStructuredDataDefEnum.h" | ||||
| #include "CommonStructuredDataDefStruct.h" | ||||
|  | ||||
| class CommonStructuredDataDef | ||||
| { | ||||
| public: | ||||
|     std::vector<std::unique_ptr<CommonStructuredDataDefEnum>> m_enums; | ||||
|     std::vector< std::unique_ptr<CommonStructuredDataDefStruct>> m_structs; | ||||
|     std::vector<CommonStructuredDataDefIndexedArray> m_indexed_arrays; | ||||
|     std::vector<CommonStructuredDataDefEnumedArray> m_enumed_arrays; | ||||
|  | ||||
|     int m_version; | ||||
|     size_t m_checksum; | ||||
|     CommonStructuredDataDefType m_root_type; | ||||
|     size_t m_size; | ||||
|  | ||||
|     CommonStructuredDataDef(); | ||||
|     explicit CommonStructuredDataDef(int version); | ||||
| }; | ||||
| @@ -0,0 +1,20 @@ | ||||
| #include "CommonStructuredDataDefEnum.h" | ||||
|  | ||||
| CommonStructuredDataDefEnumEntry::CommonStructuredDataDefEnumEntry() | ||||
|     : m_value(0u) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefEnumEntry::CommonStructuredDataDefEnumEntry(std::string name, const size_t value) | ||||
|     : m_name(std::move(name)), | ||||
|       m_value(value) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefEnum::CommonStructuredDataDefEnum() | ||||
| = default; | ||||
|  | ||||
| CommonStructuredDataDefEnum::CommonStructuredDataDefEnum(std::string name) | ||||
|     : m_name(std::move(name)) | ||||
| { | ||||
| } | ||||
| @@ -0,0 +1,21 @@ | ||||
| #pragma once | ||||
| #include <string> | ||||
| #include <vector> | ||||
|  | ||||
| struct CommonStructuredDataDefEnumEntry | ||||
| { | ||||
|     std::string m_name; | ||||
|     size_t m_value; | ||||
|  | ||||
|     CommonStructuredDataDefEnumEntry(); | ||||
|     CommonStructuredDataDefEnumEntry(std::string name, size_t value); | ||||
| }; | ||||
|  | ||||
| struct CommonStructuredDataDefEnum | ||||
| { | ||||
|     std::string m_name; | ||||
|     std::vector<CommonStructuredDataDefEnumEntry> m_entries; | ||||
|  | ||||
|     CommonStructuredDataDefEnum(); | ||||
|     explicit CommonStructuredDataDefEnum(std::string name); | ||||
| }; | ||||
| @@ -0,0 +1,30 @@ | ||||
| #include "CommonStructuredDataDefStruct.h" | ||||
|  | ||||
| CommonStructuredDataDefStructEntry::CommonStructuredDataDefStructEntry() | ||||
|     : m_offset(0u) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefStructEntry::CommonStructuredDataDefStructEntry(std::string name) | ||||
|     : m_name(std::move(name)), | ||||
|       m_offset(0u) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefStructEntry::CommonStructuredDataDefStructEntry(std::string name, const CommonStructuredDataDefType type, const size_t offset) | ||||
|     : m_name(std::move(name)), | ||||
|       m_type(type), | ||||
|       m_offset(offset) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefStruct::CommonStructuredDataDefStruct() | ||||
|     : m_size(0u) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefStruct::CommonStructuredDataDefStruct(std::string name) | ||||
|     : m_name(std::move(name)), | ||||
|       m_size(0u) | ||||
| { | ||||
| } | ||||
| @@ -0,0 +1,27 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <string> | ||||
| #include <vector> | ||||
|  | ||||
| #include "CommonStructuredDataDefTypes.h" | ||||
|  | ||||
| struct CommonStructuredDataDefStructEntry | ||||
| { | ||||
|     std::string m_name; | ||||
|     CommonStructuredDataDefType m_type; | ||||
|     size_t m_offset; | ||||
|  | ||||
|     CommonStructuredDataDefStructEntry(); | ||||
|     explicit CommonStructuredDataDefStructEntry(std::string name); | ||||
|     CommonStructuredDataDefStructEntry(std::string name, CommonStructuredDataDefType type, size_t offset); | ||||
| }; | ||||
|  | ||||
| struct CommonStructuredDataDefStruct | ||||
| { | ||||
|     std::string m_name; | ||||
|     std::vector<CommonStructuredDataDefStructEntry> m_entries; | ||||
|     size_t m_size; | ||||
|  | ||||
|     CommonStructuredDataDefStruct(); | ||||
|     explicit CommonStructuredDataDefStruct(std::string name); | ||||
| }; | ||||
| @@ -0,0 +1,41 @@ | ||||
| #include "CommonStructuredDataDefTypes.h" | ||||
|  | ||||
| CommonStructuredDataDefType::CommonStructuredDataDefType() | ||||
|     : m_category(CommonStructuredDataDefTypeCategory::UNKNOWN), | ||||
|       m_info({0}) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefType::CommonStructuredDataDefType(const CommonStructuredDataDefTypeCategory category) | ||||
|     : m_category(category), | ||||
|       m_info({0}) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefType::CommonStructuredDataDefType(const CommonStructuredDataDefTypeCategory category, const size_t extraInfo) | ||||
|     : m_category(category), | ||||
|       m_info({extraInfo}) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefIndexedArray::CommonStructuredDataDefIndexedArray() | ||||
|     : m_array_size(0u) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefIndexedArray::CommonStructuredDataDefIndexedArray(const CommonStructuredDataDefType type, const size_t arraySize) | ||||
|     : m_array_type(type), | ||||
|       m_array_size(arraySize) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefEnumedArray::CommonStructuredDataDefEnumedArray() | ||||
|     : m_enum_index(0u) | ||||
| { | ||||
| } | ||||
|  | ||||
| CommonStructuredDataDefEnumedArray::CommonStructuredDataDefEnumedArray(const CommonStructuredDataDefType type, const size_t enumIndex) | ||||
|     : m_array_type(type), | ||||
|       m_enum_index(enumIndex) | ||||
| { | ||||
| } | ||||
| @@ -0,0 +1,52 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <cstddef> | ||||
|  | ||||
| enum class CommonStructuredDataDefTypeCategory | ||||
| { | ||||
|     UNKNOWN, | ||||
|     INT, | ||||
|     BYTE, | ||||
|     BOOL, | ||||
|     STRING, | ||||
|     FLOAT, | ||||
|     SHORT, | ||||
|     ENUM, | ||||
|     STRUCT, | ||||
|     INDEXED_ARRAY, | ||||
|     ENUM_ARRAY | ||||
| }; | ||||
|  | ||||
| union CommonStructuredDataDefTypeExtraInfo | ||||
| { | ||||
|     size_t string_length; | ||||
|     size_t type_index; | ||||
| }; | ||||
|  | ||||
| struct CommonStructuredDataDefType | ||||
| { | ||||
|     CommonStructuredDataDefTypeCategory m_category; | ||||
|     CommonStructuredDataDefTypeExtraInfo m_info; | ||||
|  | ||||
|     CommonStructuredDataDefType(); | ||||
|     explicit CommonStructuredDataDefType(CommonStructuredDataDefTypeCategory category); | ||||
|     CommonStructuredDataDefType(CommonStructuredDataDefTypeCategory category, size_t extraInfo); | ||||
| }; | ||||
|  | ||||
| struct CommonStructuredDataDefIndexedArray | ||||
| { | ||||
|     CommonStructuredDataDefType m_array_type; | ||||
|     size_t m_array_size; | ||||
|  | ||||
|     CommonStructuredDataDefIndexedArray(); | ||||
|     CommonStructuredDataDefIndexedArray(CommonStructuredDataDefType type, size_t arraySize); | ||||
| }; | ||||
|  | ||||
| struct CommonStructuredDataDefEnumedArray | ||||
| { | ||||
|     CommonStructuredDataDefType m_array_type; | ||||
|     size_t m_enum_index; | ||||
|  | ||||
|     CommonStructuredDataDefEnumedArray(); | ||||
|     CommonStructuredDataDefEnumedArray(CommonStructuredDataDefType type, size_t enumIndex); | ||||
| }; | ||||
| @@ -0,0 +1,99 @@ | ||||
| #include "StructuredDataDefDefScopeSequences.h" | ||||
|  | ||||
| #include "Parsing/Simple/Matcher/SimpleMatcherFactory.h" | ||||
|  | ||||
| namespace sdd::def_scope_sequences | ||||
| { | ||||
|     class SequenceEnum final : public StructuredDataDefParser::sequence_t | ||||
|     { | ||||
|         static constexpr auto CAPTURE_NAME = 1; | ||||
|  | ||||
|     public: | ||||
|         SequenceEnum() | ||||
|         { | ||||
|             const SimpleMatcherFactory create(this); | ||||
|  | ||||
|             AddMatchers({ | ||||
|                 create.Keyword("enum"), | ||||
|                 create.Identifier().Capture(CAPTURE_NAME), | ||||
|                 create.Char('{') | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|     protected: | ||||
|         void ProcessMatch(StructuredDataDefParserState* state, SequenceResult<SimpleParserValue>& result) const override | ||||
|         { | ||||
|             assert(state->m_current_def); | ||||
|  | ||||
|             auto newEnum = std::make_unique<CommonStructuredDataDefEnum>(result.NextCapture(CAPTURE_NAME).IdentifierValue()); | ||||
|             state->m_current_enum = newEnum.get(); | ||||
|             state->m_current_def->m_enums.emplace_back(std::move(newEnum)); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     class SequenceStruct final : public StructuredDataDefParser::sequence_t | ||||
|     { | ||||
|         static constexpr auto CAPTURE_NAME = 1; | ||||
|  | ||||
|     public: | ||||
|         SequenceStruct() | ||||
|         { | ||||
|             const SimpleMatcherFactory create(this); | ||||
|  | ||||
|             AddMatchers({ | ||||
|                 create.Keyword("struct"), | ||||
|                 create.Identifier().Capture(CAPTURE_NAME), | ||||
|                 create.Char('{') | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|     protected: | ||||
|         void ProcessMatch(StructuredDataDefParserState* state, SequenceResult<SimpleParserValue>& result) const override | ||||
|         { | ||||
|             assert(state->m_current_def); | ||||
|  | ||||
|             auto newStruct = std::make_unique<CommonStructuredDataDefStruct>(result.NextCapture(CAPTURE_NAME).IdentifierValue()); | ||||
|             state->m_current_struct = newStruct.get(); | ||||
|             state->m_current_def->m_structs.emplace_back(std::move(newStruct)); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     class SequenceCloseScope final : public StructuredDataDefParser::sequence_t | ||||
|     { | ||||
|         static constexpr auto CAPTURE_NAME = 1; | ||||
|  | ||||
|     public: | ||||
|         SequenceCloseScope() | ||||
|         { | ||||
|             const SimpleMatcherFactory create(this); | ||||
|  | ||||
|             AddMatchers({ | ||||
|                 create.Char('}') | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|     protected: | ||||
|         void ProcessMatch(StructuredDataDefParserState* state, SequenceResult<SimpleParserValue>& result) const override | ||||
|         { | ||||
|             assert(state->m_current_enum == nullptr); | ||||
|             assert(state->m_current_struct == nullptr); | ||||
|  | ||||
|             state->m_current_def = nullptr; | ||||
|         } | ||||
|     }; | ||||
| } | ||||
|  | ||||
| using namespace sdd; | ||||
| using namespace def_scope_sequences; | ||||
|  | ||||
| StructuredDataDefDefScopeSequences::StructuredDataDefDefScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, | ||||
|                                                                        std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences) | ||||
|     : AbstractScopeSequenceHolder(allSequences, scopeSequences) | ||||
| { | ||||
| } | ||||
|  | ||||
| void StructuredDataDefDefScopeSequences::AddSequences() const | ||||
| { | ||||
|     AddSequence(std::make_unique<SequenceEnum>()); | ||||
|     AddSequence(std::make_unique<SequenceStruct>()); | ||||
| } | ||||
| @@ -0,0 +1,15 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "Parsing/Sequence/AbstractScopeSequenceHolder.h" | ||||
| #include "Parsing/StructuredDataDef/StructuredDataDefParser.h" | ||||
|  | ||||
| namespace sdd | ||||
| { | ||||
|     class StructuredDataDefDefScopeSequences final : AbstractScopeSequenceHolder<StructuredDataDefParser> | ||||
|     { | ||||
|     public: | ||||
|         StructuredDataDefDefScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences); | ||||
|  | ||||
|         void AddSequences() const; | ||||
|     }; | ||||
| } | ||||
| @@ -0,0 +1,77 @@ | ||||
| #include "StructuredDataDefEnumScopeSequences.h" | ||||
|  | ||||
| #include <algorithm> | ||||
|  | ||||
| #include "Parsing/Simple/Matcher/SimpleMatcherFactory.h" | ||||
|  | ||||
| namespace sdd::enum_scope_sequences | ||||
| { | ||||
|     class SequenceEnumEntry final : public StructuredDataDefParser::sequence_t | ||||
|     { | ||||
|         static constexpr auto CAPTURE_ENTRY_VALUE = 1; | ||||
|  | ||||
|     public: | ||||
|         SequenceEnumEntry() | ||||
|         { | ||||
|             const SimpleMatcherFactory create(this); | ||||
|  | ||||
|             AddMatchers({ | ||||
|                 create.String().Capture(CAPTURE_ENTRY_VALUE), | ||||
|                 create.Or({ | ||||
|                     create.Char(','), | ||||
|                     create.Char('}').NoConsume() | ||||
|                 }) | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|     protected: | ||||
|         void ProcessMatch(StructuredDataDefParserState* state, SequenceResult<SimpleParserValue>& result) const override | ||||
|         { | ||||
|             assert(state->m_current_enum); | ||||
|  | ||||
|             state->m_current_enum->m_entries.emplace_back(result.NextCapture(CAPTURE_ENTRY_VALUE).StringValue(), state->m_current_enum->m_entries.size()); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     class SequenceCloseEnum final : public StructuredDataDefParser::sequence_t | ||||
|     { | ||||
|     public: | ||||
|         SequenceCloseEnum() | ||||
|         { | ||||
|             const SimpleMatcherFactory create(this); | ||||
|  | ||||
|             AddMatchers({ | ||||
|                 create.Char('}'), | ||||
|                 create.Optional(create.Char(';')) | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|     protected: | ||||
|         void ProcessMatch(StructuredDataDefParserState* state, SequenceResult<SimpleParserValue>& result) const override | ||||
|         { | ||||
|             assert(state->m_current_enum != nullptr); | ||||
|  | ||||
|             std::sort(state->m_current_enum->m_entries.begin(), state->m_current_enum->m_entries.end(), [](const CommonStructuredDataDefEnumEntry& e1, const CommonStructuredDataDefEnumEntry& e2) | ||||
|             { | ||||
|                 return e1.m_name < e2.m_name; | ||||
|             }); | ||||
|  | ||||
|             state->m_current_enum = nullptr; | ||||
|         } | ||||
|     }; | ||||
| } | ||||
|  | ||||
| using namespace sdd; | ||||
| using namespace enum_scope_sequences; | ||||
|  | ||||
| StructuredDataDefEnumScopeSequences::StructuredDataDefEnumScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, | ||||
|                                                                          std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences) | ||||
|     : AbstractScopeSequenceHolder(allSequences, scopeSequences) | ||||
| { | ||||
| } | ||||
|  | ||||
| void StructuredDataDefEnumScopeSequences::AddSequences() const | ||||
| { | ||||
|     AddSequence(std::make_unique<SequenceCloseEnum>()); | ||||
|     AddSequence(std::make_unique<SequenceEnumEntry>()); | ||||
| } | ||||
| @@ -0,0 +1,15 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "Parsing/Sequence/AbstractScopeSequenceHolder.h" | ||||
| #include "Parsing/StructuredDataDef/StructuredDataDefParser.h" | ||||
|  | ||||
| namespace sdd | ||||
| { | ||||
|     class StructuredDataDefEnumScopeSequences final : AbstractScopeSequenceHolder<StructuredDataDefParser> | ||||
|     { | ||||
|     public: | ||||
|         StructuredDataDefEnumScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences); | ||||
|  | ||||
|         void AddSequences() const; | ||||
|     }; | ||||
| } | ||||
| @@ -0,0 +1,45 @@ | ||||
| #include "StructuredDataDefNoScopeSequences.h" | ||||
|  | ||||
| #include "Parsing/Simple/Matcher/SimpleMatcherFactory.h" | ||||
|  | ||||
| namespace sdd::no_scope_sequences | ||||
| { | ||||
|     class SequenceVersion final : public StructuredDataDefParser::sequence_t | ||||
|     { | ||||
|         static constexpr auto CAPTURE_VERSION = 1; | ||||
|  | ||||
|     public: | ||||
|         SequenceVersion() | ||||
|         { | ||||
|             const SimpleMatcherFactory create(this); | ||||
|  | ||||
|             AddMatchers({ | ||||
|                 create.Keyword("version"), | ||||
|                 create.Integer().Capture(CAPTURE_VERSION), | ||||
|                 create.Char('{') | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|     protected: | ||||
|         void ProcessMatch(StructuredDataDefParserState* state, SequenceResult<SimpleParserValue>& result) const override | ||||
|         { | ||||
|             auto newDef = std::make_unique<CommonStructuredDataDef>(result.NextCapture(CAPTURE_VERSION).IntegerValue()); | ||||
|             state->m_current_def = newDef.get(); | ||||
|             state->m_defs.emplace_back(std::move(newDef)); | ||||
|         } | ||||
|     }; | ||||
| } | ||||
|  | ||||
| using namespace sdd; | ||||
| using namespace no_scope_sequences; | ||||
|  | ||||
| StructuredDataDefNoScopeSequences::StructuredDataDefNoScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, | ||||
|                                                                      std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences) | ||||
|     : AbstractScopeSequenceHolder(allSequences, scopeSequences) | ||||
| { | ||||
| } | ||||
|  | ||||
| void StructuredDataDefNoScopeSequences::AddSequences() const | ||||
| { | ||||
|     AddSequence(std::make_unique<SequenceVersion>()); | ||||
| } | ||||
| @@ -0,0 +1,15 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "Parsing/Sequence/AbstractScopeSequenceHolder.h" | ||||
| #include "Parsing/StructuredDataDef/StructuredDataDefParser.h" | ||||
|  | ||||
| namespace sdd | ||||
| { | ||||
|     class StructuredDataDefNoScopeSequences final : AbstractScopeSequenceHolder<StructuredDataDefParser> | ||||
|     { | ||||
|     public: | ||||
|         StructuredDataDefNoScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences); | ||||
|  | ||||
|         void AddSequences() const; | ||||
|     }; | ||||
| } | ||||
| @@ -0,0 +1,47 @@ | ||||
| #include "StructuredDataDefStructScopeSequences.h" | ||||
|  | ||||
| #include "Parsing/Simple/Matcher/SimpleMatcherFactory.h" | ||||
|  | ||||
| namespace sdd::struct_scope_sequences | ||||
| { | ||||
|     class SequenceVersion final : public StructuredDataDefParser::sequence_t | ||||
|     { | ||||
|         static constexpr auto CAPTURE_VERSION = 1; | ||||
|  | ||||
|     public: | ||||
|         SequenceVersion() | ||||
|         { | ||||
|             const SimpleMatcherFactory create(this); | ||||
|  | ||||
|             AddMatchers({ | ||||
|                 create.Keyword("version"), | ||||
|                 create.Integer().Capture(CAPTURE_VERSION), | ||||
|                 create.Char('{') | ||||
|                 }); | ||||
|         } | ||||
|  | ||||
|     protected: | ||||
|         void ProcessMatch(StructuredDataDefParserState* state, SequenceResult<SimpleParserValue>& result) const override | ||||
|         { | ||||
|             auto newDef = std::make_unique<CommonStructuredDataDef>(); | ||||
|             newDef->m_version = result.NextCapture(CAPTURE_VERSION).IntegerValue(); | ||||
|  | ||||
|             state->m_current_def = newDef.get(); | ||||
|             state->m_defs.emplace_back(std::move(newDef)); | ||||
|         } | ||||
|     }; | ||||
| } | ||||
|  | ||||
| using namespace sdd; | ||||
| using namespace struct_scope_sequences; | ||||
|  | ||||
| StructuredDataDefStructScopeSequences::StructuredDataDefStructScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, | ||||
|                                                                              std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences) | ||||
|     : AbstractScopeSequenceHolder(allSequences, scopeSequences) | ||||
| { | ||||
| } | ||||
|  | ||||
| void StructuredDataDefStructScopeSequences::AddSequences() const | ||||
| { | ||||
|     AddSequence(std::make_unique<SequenceVersion>()); | ||||
| } | ||||
| @@ -0,0 +1,15 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "Parsing/Sequence/AbstractScopeSequenceHolder.h" | ||||
| #include "Parsing/StructuredDataDef/StructuredDataDefParser.h" | ||||
|  | ||||
| namespace sdd | ||||
| { | ||||
|     class StructuredDataDefStructScopeSequences final : AbstractScopeSequenceHolder<StructuredDataDefParser> | ||||
|     { | ||||
|     public: | ||||
|         StructuredDataDefStructScopeSequences(std::vector<std::unique_ptr<StructuredDataDefParser::sequence_t>>& allSequences, std::vector<StructuredDataDefParser::sequence_t*>& scopeSequences); | ||||
|  | ||||
|         void AddSequences() const; | ||||
|     }; | ||||
| } | ||||
| @@ -0,0 +1,54 @@ | ||||
| #include "StructuredDataDefParser.h" | ||||
|  | ||||
| #include "Sequence/StructuredDataDefDefScopeSequences.h" | ||||
| #include "Sequence/StructuredDataDefEnumScopeSequences.h" | ||||
| #include "Sequence/StructuredDataDefNoScopeSequences.h" | ||||
| #include "Sequence/StructuredDataDefStructScopeSequences.h" | ||||
|  | ||||
| using namespace sdd; | ||||
|  | ||||
| StructuredDataDefParser::StructuredDataDefParser(SimpleLexer* lexer) | ||||
|     : AbstractParser(lexer, std::make_unique<StructuredDataDefParserState>()) | ||||
| { | ||||
|     CreateSequenceCollections(); | ||||
| } | ||||
|  | ||||
| void StructuredDataDefParser::CreateSequenceCollections() | ||||
| { | ||||
|     m_all_tests.clear(); | ||||
|     m_no_scope_tests.clear(); | ||||
|     m_def_tests.clear(); | ||||
|     m_enum_tests.clear(); | ||||
|     m_struct_tests.clear(); | ||||
|  | ||||
|     const StructuredDataDefNoScopeSequences noScopeSequences(m_all_tests, m_no_scope_tests); | ||||
|     noScopeSequences.AddSequences(); | ||||
|  | ||||
|     const StructuredDataDefDefScopeSequences defScopeSequences(m_all_tests, m_def_tests); | ||||
|     defScopeSequences.AddSequences(); | ||||
|  | ||||
|     const StructuredDataDefEnumScopeSequences enumScopeSequences(m_all_tests, m_enum_tests); | ||||
|     enumScopeSequences.AddSequences(); | ||||
|  | ||||
|     const StructuredDataDefStructScopeSequences structScopeSequences(m_all_tests, m_struct_tests); | ||||
|     structScopeSequences.AddSequences(); | ||||
| } | ||||
|  | ||||
| const std::vector<StructuredDataDefParser::sequence_t*>& StructuredDataDefParser::GetTestsForState() | ||||
| { | ||||
|     if (!m_state->m_current_def) | ||||
|         return m_no_scope_tests; | ||||
|  | ||||
|     if (m_state->m_current_enum) | ||||
|         return m_enum_tests; | ||||
|  | ||||
|     if (m_state->m_current_struct) | ||||
|         return m_struct_tests; | ||||
|  | ||||
|     return m_def_tests; | ||||
| } | ||||
|  | ||||
| std::vector<std::unique_ptr<CommonStructuredDataDef>> StructuredDataDefParser::GetDefs() const | ||||
| { | ||||
|     return std::move(m_state->m_defs); | ||||
| } | ||||
| @@ -0,0 +1,29 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "Utils/ClassUtils.h" | ||||
| #include "StructuredDataDefParserState.h" | ||||
| #include "Domain/CommonStructuredDataDef.h" | ||||
| #include "Parsing/Simple/SimpleLexer.h" | ||||
| #include "Parsing/Simple/SimpleParserValue.h" | ||||
| #include "Parsing/Impl/AbstractParser.h" | ||||
|  | ||||
| namespace sdd | ||||
| { | ||||
|     class StructuredDataDefParser final : public AbstractParser<SimpleParserValue, StructuredDataDefParserState> | ||||
|     { | ||||
|         std::vector<std::unique_ptr<sequence_t>> m_all_tests; | ||||
|         std::vector<sequence_t*> m_no_scope_tests; | ||||
|         std::vector<sequence_t*> m_def_tests; | ||||
|         std::vector<sequence_t*> m_enum_tests; | ||||
|         std::vector<sequence_t*> m_struct_tests; | ||||
|          | ||||
|         void CreateSequenceCollections(); | ||||
|  | ||||
|     protected: | ||||
|         const std::vector<sequence_t*>& GetTestsForState() override; | ||||
|  | ||||
|     public: | ||||
|         explicit StructuredDataDefParser(SimpleLexer* lexer); | ||||
|         _NODISCARD std::vector<std::unique_ptr<CommonStructuredDataDef>> GetDefs() const; | ||||
|     }; | ||||
| } | ||||
| @@ -0,0 +1,10 @@ | ||||
| #include "StructuredDataDefParserState.h" | ||||
|  | ||||
| using namespace sdd; | ||||
|  | ||||
| StructuredDataDefParserState::StructuredDataDefParserState() | ||||
|     : m_current_def(nullptr), | ||||
|       m_current_enum(nullptr), | ||||
|       m_current_struct(nullptr) | ||||
| { | ||||
| } | ||||
| @@ -0,0 +1,20 @@ | ||||
| #pragma once | ||||
| #include <memory> | ||||
| #include <vector> | ||||
|  | ||||
| #include "Domain/CommonStructuredDataDef.h" | ||||
|  | ||||
| namespace sdd | ||||
| { | ||||
|     class StructuredDataDefParserState | ||||
|     { | ||||
|     public: | ||||
|         std::vector<std::unique_ptr<CommonStructuredDataDef>> m_defs; | ||||
|  | ||||
|         CommonStructuredDataDef* m_current_def; | ||||
|         CommonStructuredDataDefEnum* m_current_enum; | ||||
|         CommonStructuredDataDefStruct* m_current_struct; | ||||
|  | ||||
|         StructuredDataDefParserState(); | ||||
|     }; | ||||
| } | ||||
| @@ -0,0 +1,60 @@ | ||||
| #include "StructuredDataDefReader.h" | ||||
|  | ||||
| #include "StructuredDataDefParser.h" | ||||
| #include "Parsing/Impl/CommentRemovingStreamProxy.h" | ||||
| #include "Parsing/Impl/DefinesStreamProxy.h" | ||||
| #include "Parsing/Impl/IncludingStreamProxy.h" | ||||
| #include "Parsing/Impl/ParserMultiInputStream.h" | ||||
| #include "Parsing/Impl/ParserSingleInputStream.h" | ||||
|  | ||||
| using namespace sdd; | ||||
|  | ||||
| StructuredDataDefReader::StructuredDataDefReader(std::istream& stream, std::string fileName) | ||||
|     : StructuredDataDefReader(stream, std::move(fileName), nullptr) | ||||
| { | ||||
| } | ||||
|  | ||||
| StructuredDataDefReader::StructuredDataDefReader(std::istream& stream, std::string fileName, include_callback_t includeCallback) | ||||
|     : m_file_name(std::move(fileName)), | ||||
|       m_stream(nullptr) | ||||
| { | ||||
|     OpenBaseStream(stream, std::move(includeCallback)); | ||||
|     SetupStreamProxies(); | ||||
|     m_stream = m_open_streams.back().get(); | ||||
| } | ||||
|  | ||||
| bool StructuredDataDefReader::OpenBaseStream(std::istream& stream, include_callback_t includeCallback) | ||||
| { | ||||
|     if (includeCallback) | ||||
|         m_open_streams.emplace_back(std::make_unique<ParserMultiInputStream>(stream, m_file_name, std::move(includeCallback))); | ||||
|     else | ||||
|         m_open_streams.emplace_back(std::make_unique<ParserSingleInputStream>(stream, m_file_name)); | ||||
|  | ||||
|     return true; | ||||
| } | ||||
|  | ||||
| void StructuredDataDefReader::SetupStreamProxies() | ||||
| { | ||||
|     m_open_streams.emplace_back(std::make_unique<CommentRemovingStreamProxy>(m_open_streams.back().get())); | ||||
|     m_open_streams.emplace_back(std::make_unique<IncludingStreamProxy>(m_open_streams.back().get())); | ||||
|     m_open_streams.emplace_back(std::make_unique<DefinesStreamProxy>(m_open_streams.back().get())); | ||||
|  | ||||
|     m_stream = m_open_streams.back().get(); | ||||
| } | ||||
|  | ||||
| std::vector<std::unique_ptr<CommonStructuredDataDef>> StructuredDataDefReader::ReadStructureDataDefs() | ||||
| { | ||||
|     SimpleLexer::Config lexerConfig; | ||||
|     lexerConfig.m_emit_new_line_tokens = false; | ||||
|     lexerConfig.m_read_strings = true; | ||||
|     lexerConfig.m_read_numbers = true; | ||||
|     const auto lexer = std::make_unique<SimpleLexer>(m_stream, std::move(lexerConfig)); | ||||
|  | ||||
|     const auto parser = std::make_unique<StructuredDataDefParser>(lexer.get()); | ||||
|  | ||||
|     if (parser->Parse()) | ||||
|         return parser->GetDefs(); | ||||
|  | ||||
|     std::cout << "Parsing structured data def file \"" << m_file_name << "\" failed!" << std::endl; | ||||
|     return {}; | ||||
| } | ||||
| @@ -0,0 +1,28 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <memory> | ||||
| #include <string> | ||||
| #include <vector> | ||||
|  | ||||
| #include "Domain/CommonStructuredDataDef.h" | ||||
| #include "Parsing/IParserLineStream.h" | ||||
|  | ||||
| class StructuredDataDefReader | ||||
| { | ||||
| public: | ||||
|     using include_callback_t = std::function<std::unique_ptr<std::istream>(const std::string& filename, const std::string& sourceFile)>; | ||||
|  | ||||
| private: | ||||
|     std::string m_file_name; | ||||
|     IParserLineStream* m_stream; | ||||
|     std::vector<std::unique_ptr<IParserLineStream>> m_open_streams; | ||||
|  | ||||
|     bool OpenBaseStream(std::istream& stream, include_callback_t includeCallback); | ||||
|     void SetupStreamProxies(); | ||||
|  | ||||
| public: | ||||
|     StructuredDataDefReader(std::istream& stream, std::string fileName); | ||||
|     StructuredDataDefReader(std::istream& stream, std::string fileName, include_callback_t includeCallback); | ||||
|  | ||||
|     std::vector<std::unique_ptr<CommonStructuredDataDef>> ReadStructureDataDefs(); | ||||
| }; | ||||
		Reference in New Issue
	
	Block a user