]> de.git.xonotic.org Git - xonotic/netradiant.git/blobdiff - plugins/mapxml/plugin.cpp
Merge branch 'TimePath/gtk++' into 'master'
[xonotic/netradiant.git] / plugins / mapxml / plugin.cpp
index ba178c8850706ed2b9797b82e102b7ee847a7b74..b144a415f9fd3b4226c72fd330c35ca17485e7f0 100644 (file)
@@ -1,74 +1,96 @@
-#include "plugin.h"
+/*
+   Copyright (C) 2001-2006, William Joseph.
+   All Rights Reserved.
 
-// =============================================================================
-// Globals
+   This file is part of GtkRadiant.
 
-// function tables
-_QERFuncTable_1 g_FuncTable;
-_QERShadersTable g_ShadersTable;
-_QEREntityTable g_EntityTable;
-_QERBrushTable g_BrushTable;
-_QERPatchTable g_PatchTable;
+   GtkRadiant is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
 
-// =============================================================================
-// SYNAPSE
+   GtkRadiant 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 General Public License for more details.
 
-CSynapseServer* g_pSynapseServer = NULL;
-CSynapseClientXMap g_SynapseClient;
+   You should have received a copy of the GNU General Public License
+   along with GtkRadiant; if not, write to the Free Software
+   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ */
 
-static const XMLConfigEntry_t entries[] =
+#include "ibrush.h"
+#include "ipatch.h"
+#include "ifiletypes.h"
+#include "ieclass.h"
+#include "qerplugin.h"
+
+#include "modulesystem/singletonmodule.h"
+#include "typesystem.h"
+
+#include "xmlparse.h"
+#include "xmlwrite.h"
+
+
+class MapXMLDependencies :
+       public GlobalRadiantModuleRef,
+       public GlobalBrushModuleRef,
+       public GlobalFiletypesModuleRef,
+       public GlobalEntityClassManagerModuleRef,
+       public GlobalSceneGraphModuleRef
 {
-       { SHADERS_MAJOR, SYN_REQUIRE, sizeof( g_ShadersTable ), &g_ShadersTable },
-       { NULL, SYN_UNKNOWN, 0, NULL }
+PatchModuleRef m_patchDef2Doom3Module;
+PatchModuleRef m_patchDoom3Module;
+public:
+MapXMLDependencies() :
+       GlobalBrushModuleRef( GlobalRadiant().getRequiredGameDescriptionKeyValue( "brushtypes" ) ),
+       GlobalEntityClassManagerModuleRef( GlobalRadiant().getRequiredGameDescriptionKeyValue( "entityclass" ) ),
+       m_patchDef2Doom3Module( "def2doom3" ),
+       m_patchDoom3Module( "doom3" ){
+}
+BrushCreator& getBrushDoom3(){
+       return GlobalBrushModule::getTable();
+}
+PatchCreator& getPatchDoom3(){
+       return *m_patchDoom3Module.getTable();
+}
+PatchCreator& getPatchDef2Doom3(){
+       return *m_patchDef2Doom3Module.getTable();
+}
 };
 
-#if __GNUC__ >= 4
-#pragma GCC visibility push(default)
-#endif
-extern "C" CSynapseClient * SYNAPSE_DLL_EXPORT Synapse_EnumerateInterfaces( const char *version, CSynapseServer *pServer ) {
-#if __GNUC__ >= 4
-#pragma GCC visibility pop
-#endif
-       if ( strcmp( version, SYNAPSE_VERSION ) ) {
-               Syn_Printf( "ERROR: synapse API version mismatch: should be '" SYNAPSE_VERSION "', got '%s'\n", version );
-               return NULL;
-       }
-       g_pSynapseServer = pServer;
-       g_pSynapseServer->IncRef();
-       Set_Syn_Printf( g_pSynapseServer->Get_Syn_Printf() );
-
-       g_SynapseClient.AddAPI( MAP_MAJOR, "mapxml", sizeof( _QERPlugMapTable ) );
-       g_SynapseClient.AddAPI( RADIANT_MAJOR, NULL, sizeof( _QERFuncTable_1 ), SYN_REQUIRE, &g_FuncTable );
-       g_SynapseClient.AddAPI( ENTITY_MAJOR, NULL, sizeof( g_EntityTable ), SYN_REQUIRE, &g_EntityTable );
-       g_SynapseClient.AddAPI( BRUSH_MAJOR, NULL, sizeof( g_BrushTable ), SYN_REQUIRE, &g_BrushTable );
-       g_SynapseClient.AddAPI( PATCH_MAJOR, NULL, sizeof( g_PatchTable ), SYN_REQUIRE, &g_PatchTable );
-
-       if ( !g_SynapseClient.ConfigXML( pServer, NULL, entries ) ) {
-               return NULL;
-       }
-
-       return &g_SynapseClient;
+class MapXMLAPI : public TypeSystemRef, public MapFormat
+{
+public:
+typedef MapFormat Type;
+STRING_CONSTANT( Name, "xmldoom3" );
+
+MapXMLAPI(){
+       GlobalFiletypesModule::getTable().addType( Type::Name(), Name(), filetype_t( "xml doom3 maps", "*.xmap" ) );
+}
+MapFormat* getTable(){
+       return this;
+}
+
+void readGraph( scene::Node& root, TextInputStream& inputStream, EntityCreator& entityTable ) const {
+       Map_Read( root, inputStream, entityTable );
 }
+void writeGraph( scene::Node& root, GraphTraversalFunc traverse, TextOutputStream& outputStream ) const {
+       Map_Write( root, traverse, outputStream );
+}
+};
 
-bool CSynapseClientXMap::RequestAPI( APIDescriptor_t *pAPI ){
-       if ( !strcmp( pAPI->major_name, MAP_MAJOR ) ) {
-               _QERPlugMapTable* pTable = static_cast<_QERPlugMapTable*>( pAPI->mpTable );
-               pTable->m_pfnMap_Read = &Map_Read;
-               pTable->m_pfnMap_Write = &Map_Write;
+typedef SingletonModule<MapXMLAPI, MapXMLDependencies> MapXMLModule;
 
-               return true;
-       }
+MapXMLModule g_MapXMLModule;
 
-       Syn_Printf( "ERROR: RequestAPI( '%s' ) not found in '%s'\n", pAPI->major_name, GetInfo() );
-       return false;
-}
 
-#include "version.h"
 
-const char* CSynapseClientXMap::GetInfo(){
-       return "XMAP module built " __DATE__ " " RADIANT_VERSION;
-}
+extern "C" void RADIANT_DLLEXPORT Radiant_RegisterModules( ModuleServer& server ){
+       GlobalErrorStream::instance().setOutputStream( server.getErrorStream() );
+       GlobalOutputStream::instance().setOutputStream( server.getOutputStream() );
+       GlobalDebugMessageHandler::instance().setHandler( server.getDebugMessageHandler() );
+       GlobalModuleServer::instance().set( server );
 
-const char* CSynapseClientXMap::GetName(){
-       return "xmap";
+       g_MapXMLModule.selfRegister();
 }