summaryrefslogtreecommitdiff
path: root/src/nodemetadata.h
diff options
context:
space:
mode:
authorPerttu Ahola <celeron55@gmail.com>2011-11-25 15:17:54 +0200
committerPerttu Ahola <celeron55@gmail.com>2011-11-29 19:13:50 +0200
commit3b3ca65562375b3cfdf8919acae8c3259df05c91 (patch)
treeccf15b1acd9b6bc1bbbd809f0fa7b0875c51d4f6 /src/nodemetadata.h
parent697ff926ce62ad1800159246a66e4bf629b61194 (diff)
downloadminetest-3b3ca65562375b3cfdf8919acae8c3259df05c91.tar.gz
minetest-3b3ca65562375b3cfdf8919acae8c3259df05c91.tar.bz2
minetest-3b3ca65562375b3cfdf8919acae8c3259df05c91.zip
Add names to NodeMetadata
Diffstat (limited to 'src/nodemetadata.h')
-rw-r--r--src/nodemetadata.h8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/nodemetadata.h b/src/nodemetadata.h
index 9eb08678a..67b80b642 100644
--- a/src/nodemetadata.h
+++ b/src/nodemetadata.h
@@ -20,7 +20,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#ifndef NODEMETADATA_HEADER
#define NODEMETADATA_HEADER
-#include "common_irrlicht.h"
+#include "irrlichttypes.h"
#include <string>
#include <iostream>
@@ -44,11 +44,12 @@ public:
NodeMetadata(IGameDef *gamedef);
virtual ~NodeMetadata();
+ static NodeMetadata* create(const std::string &name, IGameDef *gamedef);
static NodeMetadata* deSerialize(std::istream &is, IGameDef *gamedef);
void serialize(std::ostream &os);
- // This usually is the CONTENT_ value
virtual u16 typeId() const = 0;
+ virtual const char* typeName() const = 0;
virtual NodeMetadata* clone(IGameDef *gamedef) = 0;
virtual void serializeBody(std::ostream &os) = 0;
virtual std::string infoText() {return "";}
@@ -69,10 +70,11 @@ public:
virtual std::string getText(){ return ""; }
virtual void setText(const std::string &t){}
protected:
- static void registerType(u16 id, Factory f);
+ static void registerType(u16 id, const std::string &name, Factory f);
IGameDef *m_gamedef;
private:
static core::map<u16, Factory> m_types;
+ static core::map<std::string, Factory> m_names;
};
/*