about summary refs log tree commit diff
path: root/src/engine/masterserver.h
diff options
context:
space:
mode:
authorMagnus Auvinen <magnus.auvinen@gmail.com>2010-05-29 07:25:38 +0000
committerMagnus Auvinen <magnus.auvinen@gmail.com>2010-05-29 07:25:38 +0000
commit72c06a258940696093f255fb1061beb58e1cdd0b (patch)
tree36b9a7712eec2d4f07837eab9c38ef1c5af85319 /src/engine/masterserver.h
parente56feb597bc743677633432f77513b02907fd169 (diff)
downloadzcatch-72c06a258940696093f255fb1061beb58e1cdd0b.tar.gz
zcatch-72c06a258940696093f255fb1061beb58e1cdd0b.zip
copied refactor to trunk
Diffstat (limited to 'src/engine/masterserver.h')
-rw-r--r--src/engine/masterserver.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/engine/masterserver.h b/src/engine/masterserver.h
new file mode 100644
index 00000000..9d16e85f
--- /dev/null
+++ b/src/engine/masterserver.h
@@ -0,0 +1,40 @@
+#ifndef ENGINE_MASTERSERVER_H
+#define ENGINE_MASTERSERVER_H
+
+#include "kernel.h"
+
+class IMasterServer : public IInterface
+{
+	MACRO_INTERFACE("masterserver", 0)
+public:
+
+	enum
+	{
+		MAX_MASTERSERVERS=4
+	};
+
+	virtual void Init(class CEngine *pEngine) = 0;
+	virtual void SetDefault() = 0;
+	virtual int Load() = 0;
+	virtual int Save() = 0;
+
+	virtual int RefreshAddresses() = 0;
+	virtual void Update() = 0;
+	virtual int IsRefreshing() = 0;
+	virtual void DumpServers() = 0;
+	virtual NETADDR GetAddr(int Index) = 0;
+	virtual const char *GetName(int Index) = 0;
+};
+
+class IEngineMasterServer : public IMasterServer
+{
+	MACRO_INTERFACE("enginemasterserver", 0)
+public:
+};
+
+extern IEngineMasterServer *CreateEngineMasterServer();
+
+#endif
+
+
+