Antkeeper
0.0.1
src
engine
i18n
string-table.cpp
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2023 Christopher J. Howard
3
*
4
* This file is part of Antkeeper source code.
5
*
6
* Antkeeper source code is free software: you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation, either version 3 of the License, or
9
* (at your option) any later version.
10
*
11
* Antkeeper source code is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
15
*
16
* You should have received a copy of the GNU General Public License
17
* along with Antkeeper source code. If not, see <http://www.gnu.org/licenses/>.
18
*/
19
20
#include <
engine/i18n/string-table.hpp
>
21
#include <
engine/resources/deserializer.hpp
>
22
#include <
engine/resources/resource-loader.hpp
>
23
32
template
<>
33
void
deserializer<i18n::string_table>::deserialize
(
i18n::string_table
& table,
deserialize_context
& ctx)
34
{
35
table.
rows
.clear();
36
37
std::vector<std::string> row;
38
std::string entry;
39
40
char
c;
41
while
(ctx.
read8
(
reinterpret_cast<
std::byte*
>
(&c), 1) == 1)
42
{
43
if
(c ==
'\t'
)
44
{
45
row.push_back(entry);
46
entry.clear();
47
}
48
else
if
(c ==
'\n'
)
49
{
50
row.push_back(entry);
51
entry.clear();
52
table.
rows
.push_back(row);
53
row.clear();
54
}
55
else
if
(c !=
'\r'
)
56
{
57
entry.push_back(c);
58
}
59
}
60
61
if
(!entry.empty())
62
{
63
row.push_back(entry);
64
}
65
66
if
(!row.empty())
67
{
68
table.
rows
.push_back(row);
69
}
70
}
71
72
template
<>
73
std::unique_ptr<i18n::string_table>
resource_loader<i18n::string_table>::load
(::
resource_manager
&
resource_manager
,
deserialize_context
& ctx)
74
{
75
auto
resource = std::make_unique<i18n::string_table>();
76
77
deserializer<i18n::string_table>
().
deserialize
(*resource, ctx);
78
79
return
resource;
80
}
resource_loader::load
static std::unique_ptr< T > load(::resource_manager &resource_manager, deserialize_context &ctx)
Loads a resource.
resource_manager
Manages the loading, caching, and saving of resources.
Definition:
resource-manager.hpp:38
deserializer.hpp
resource-loader.hpp
string-table.hpp
deserialize_context
Provides access to a deserialization state.
Definition:
deserialize-context.hpp:31
deserialize_context::read8
virtual std::size_t read8(std::byte *data, std::size_t count) noexcept(false)=0
Reads 8-bit (byte) data.
deserializer
Specializations of deserializer define the deserialization process for a given type.
Definition:
deserializer.hpp:32
deserializer::deserialize
void deserialize(T &value, deserialize_context &ctx)
Deserializes a value.
i18n::string_table
Table of strings.
Definition:
string-table.hpp:32
i18n::string_table::rows
std::vector< std::vector< std::string > > rows
Rows of column strings.
Definition:
string-table.hpp:34