aboutsummaryrefslogtreecommitdiff
path: root/src/nodemetadata.h
blob: 8d1298212d9e702eab99f1c6c457b5179273aea8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*
Minetest
Copyright (C) 2010-2013 celeron55, Perttu Ahola <celeron55@gmail.com>

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/

#ifndef NODEMETADATA_HEADER
#define NODEMETADATA_HEADER

#include "irr_v3d.h"
#include <iostream>
#include <vector>
#include "util/string.h"

/*
	NodeMetadata stores arbitary amounts of data for special blocks.
	Used for furnaces, chests and signs.

	There are two interaction methods: inventory menu and text input.
	Only one can be used for a single metadata, thus only inventory OR
	text input should exist in a metadata.
*/

class Inventory;
class IItemDefManager;

class NodeMetadata
{
public:
	NodeMetadata(IItemDefManager *item_def_mgr);
	~NodeMetadata();

	void serialize(std::ostream &os) const;
	void deSerialize(std::istream &is);

	void clear();

	// Generic key/value store
	std::string getString(const std::string &name, unsigned short recursion = 0) const;
	void setString(const std::string &name, const std::string &var);
	// Support variable names in values
	std::string resolveString(const std::string &str, unsigned short recursion = 0) const;
	StringMap getStrings() const
	{
		return m_stringvars;
	}

	// The inventory
	Inventory *getInventory()
	{
		return m_inventory;
	}

private:
	StringMap m_stringvars;
	Inventory *m_inventory;
};


/*
	List of metadata of all the nodes of a block
*/

class NodeMetadataList
{
public:
	~NodeMetadataList();

	void serialize(std::ostream &os) const;
	void deSerialize(std::istream &is, IItemDefManager *item_def_mgr);

	// Add all keys in this list to the vector keys
	std::vector<v3s16> getAllKeys();
	// Get pointer to data
	NodeMetadata *get(v3s16 p);
	// Deletes data
	void remove(v3s16 p);
	// Deletes old data and sets a new one
	void set(v3s16 p, NodeMetadata *d);
	// Deletes all
	void clear();

private:
	std::map<v3s16, NodeMetadata *> m_data;
};

#endif

while (i < s.length()) { if (s[i] != L'\x1b') { m_string += s[i]; m_colors.push_back(color); ++i; continue; } ++i; size_t start_index = i; size_t length; if (i == s.length()) { break; } if (s[i] == L'(') { ++i; ++start_index; while (i < s.length() && s[i] != L')') { if (s[i] == L'\\') { ++i; } ++i; } length = i - start_index; ++i; } else { ++i; length = 1; } std::wstring escape_sequence(s, start_index, length); std::vector<std::wstring> parts = split(escape_sequence, L'@'); if (parts[0] == L"c") { if (parts.size() < 2) { continue; } parseColorString(wide_to_utf8(parts[1]), color, true); } else if (parts[0] == L"b") { if (parts.size() < 2) { continue; } parseColorString(wide_to_utf8(parts[1]), m_background, true); m_has_background = true; } continue; } } void EnrichedString::addChar(const EnrichedString &source, size_t i) { m_string += source.m_string[i]; m_colors.push_back(source.m_colors[i]); } void EnrichedString::addCharNoColor(wchar_t c) { m_string += c; if (m_colors.empty()) { m_colors.push_back(SColor(255, 255, 255, 255)); } else { m_colors.push_back(m_colors[m_colors.size() - 1]); } } EnrichedString EnrichedString::operator+(const EnrichedString &other) const { std::vector<SColor> result; result.insert(result.end(), m_colors.begin(), m_colors.end()); result.insert(result.end(), other.m_colors.begin(), other.m_colors.end()); return EnrichedString(m_string + other.m_string, result); } void EnrichedString::operator+=(const EnrichedString &other) { m_string += other.m_string; m_colors.insert(m_colors.end(), other.m_colors.begin(), other.m_colors.end()); } EnrichedString EnrichedString::substr(size_t pos, size_t len) const { if (pos == m_string.length()) { return EnrichedString(); } if (len == std::string::npos || pos + len > m_string.length()) { return EnrichedString( m_string.substr(pos, std::string::npos), std::vector<SColor>(m_colors.begin() + pos, m_colors.end()) ); } else { return EnrichedString( m_string.substr(pos, len), std::vector<SColor>(m_colors.begin() + pos, m_colors.begin() + pos + len) ); } } const wchar_t *EnrichedString::c_str() const { return m_string.c_str(); } const std::vector<SColor> &EnrichedString::getColors() const { return m_colors; } const std::wstring &EnrichedString::getString() const { return m_string; }