]> de.git.xonotic.org Git - xonotic/netradiant.git/blobdiff - contrib/bobtoolz/bobToolz-GTK.cpp
uncrustify! now the code is only ugly on the *inside*
[xonotic/netradiant.git] / contrib / bobtoolz / bobToolz-GTK.cpp
index d824df5402b7d040dcb33a64d15ac7d681001309..1cd1155229a4aee9312f78d3c4a3c9213f394e15 100644 (file)
@@ -1,21 +1,21 @@
 /*
-BobToolz plugin for GtkRadiant
-Copyright (C) 2001 Gordon Biggans
+   BobToolz plugin for GtkRadiant
+   Copyright (C) 2001 Gordon Biggans
 
-This library 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 library 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 library 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.
+   This library 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 library; if not, write to the Free Software
-Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
-*/
+   You should have received a copy of the GNU Lesser General Public
+   License along with this library; if not, write to the Free Software
+   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ */
 
 #include "StdAfx.h"
 
@@ -26,14 +26,14 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 #include "../../libs/cmdlib.h"
 
 // Radiant function table
-_QERFuncTable_1                          g_FuncTable;
-_QERAppDataTable                 g_AppDataTable;
-_QERBrushTable                   g_BrushTable;
-_QERShadersTable                 g_ShadersTable;                       // vvvvvvvvvvvvvvvvvvvv
-_QERSelectedFaceTable g_SelectedFaceTable;     // to get texture sizes
-_QERQglTable                             g_QglTable;                           // for path plotting (hooking to DBobView)
-_QERUITable                                      g_MessageTable;                       // for path plotting (listening for update)
-_QEREntityTable                          g_EntityTable;
+_QERFuncTable_1 g_FuncTable;
+_QERAppDataTable g_AppDataTable;
+_QERBrushTable g_BrushTable;
+_QERShadersTable g_ShadersTable;                    // vvvvvvvvvvvvvvvvvvvv
+_QERSelectedFaceTable g_SelectedFaceTable;  // to get texture sizes
+_QERQglTable g_QglTable;                                // for path plotting (hooking to DBobView)
+_QERUITable g_MessageTable;                             // for path plotting (listening for update)
+_QEREntityTable g_EntityTable;
 
 // plugin name
 const char* PLUGIN_NAME = "bobToolz";
@@ -44,7 +44,7 @@ static const char* PLUGIN_COMMANDS = "About...,-,Reset Textures...,PitOMatic,-,V
 // globals
 GtkWidget *g_pRadiantWnd = NULL;
 
-static const char *PLUGIN_ABOUT =      "bobToolz for SDRadiant\n"
+static const char *PLUGIN_ABOUT =   "bobToolz for SDRadiant\n"
                                                                        "by digibob (digibob@splashdamage.com)\n"
                                                                        "http://www.splashdamage.com\n\n"
                                                                        "Additional Contributors:\n"
@@ -64,35 +64,47 @@ extern "C" const char* QERPlug_GetCommandList() {
        return PLUGIN_COMMANDS;
 }
 
-extern "C" void QERPlug_Dispatch (const char *p, vec3_t vMin, vec3_t vMax, bool bSingleBrush) {
+extern "C" void QERPlug_Dispatch( const char *p, vec3_t vMin, vec3_t vMax, bool bSingleBrush ) {
        LoadLists();
 
-       if( !stricmp( p, "brush cleanup" ) ) {
-    DoFixBrushes();
-  } else if( !stricmp( p, "polygon builder" ) ) {
-    DoPolygonsTB();
-  } else if( !stricmp( p, "caulk selection" ) ) {
-    DoCaulkSelection();
-  } else if( !stricmp( p, "tree planter" ) ) {
-    DoTreePlanter();
-  } else if( !stricmp( p, "plot splines" ) ) {
-    DoTrainPathPlot();
-  } else if( !stricmp( p, "drop entity" ) ) {
-    DoDropEnts();
-  } else if( !stricmp( p, "merge patches" ) ) {
-    DoMergePatches();
-  } else if( !stricmp( p, "split patches" ) ) {
-    DoSplitPatch();
-  } else if( !stricmp( p, "turn edge" ) ) {
-    DoFlipTerrain();
-  } else if( !stricmp(p, "reset textures...") ) {
+       if ( !stricmp( p, "brush cleanup" ) ) {
+               DoFixBrushes();
+       }
+       else if ( !stricmp( p, "polygon builder" ) ) {
+               DoPolygonsTB();
+       }
+       else if ( !stricmp( p, "caulk selection" ) ) {
+               DoCaulkSelection();
+       }
+       else if ( !stricmp( p, "tree planter" ) ) {
+               DoTreePlanter();
+       }
+       else if ( !stricmp( p, "plot splines" ) ) {
+               DoTrainPathPlot();
+       }
+       else if ( !stricmp( p, "drop entity" ) ) {
+               DoDropEnts();
+       }
+       else if ( !stricmp( p, "merge patches" ) ) {
+               DoMergePatches();
+       }
+       else if ( !stricmp( p, "split patches" ) ) {
+               DoSplitPatch();
+       }
+       else if ( !stricmp( p, "turn edge" ) ) {
+               DoFlipTerrain();
+       }
+       else if ( !stricmp( p, "reset textures..." ) ) {
                DoResetTextures();
-       } else if( !stricmp(p, "pitomatic") ) {
-               DoPitBuilder(vMin, vMax);
-       } else if( !stricmp(p, "vis viewer") ) {
+       }
+       else if ( !stricmp( p, "pitomatic" ) ) {
+               DoPitBuilder( vMin, vMax );
+       }
+       else if ( !stricmp( p, "vis viewer" ) ) {
                DoVisAnalyse();
-       } else if( !stricmp(p, "about...") ) {
-               DoMessageBox(PLUGIN_ABOUT, "About", IDOK);
+       }
+       else if ( !stricmp( p, "about..." ) ) {
+               DoMessageBox( PLUGIN_ABOUT, "About", IDOK );
        }
 }
 
@@ -103,16 +115,16 @@ unsigned int ToolbarButtonCount( void ) {
 }
 
 // Load a xpm file and return a pixmap widget.
-GtkWidget* new_pixmap (char* filename) {
+GtkWidget* new_pixmap( char* filename ) {
        GdkPixmap *gdkpixmap;
        GdkBitmap *mask;
        GtkWidget *pixmap;
 
-       g_FuncTable.m_pfnLoadBitmap(filename, (void **)&gdkpixmap, (void **)&mask);
-       pixmap = gtk_pixmap_new (gdkpixmap, mask);
+       g_FuncTable.m_pfnLoadBitmap( filename, (void **)&gdkpixmap, (void **)&mask );
+       pixmap = gtk_pixmap_new( gdkpixmap, mask );
 
-       gdk_pixmap_unref (gdkpixmap);
-       gdk_pixmap_unref (mask);
+       gdk_pixmap_unref( gdkpixmap );
+       gdk_pixmap_unref( mask );
 
        return pixmap;
 }
@@ -120,85 +132,79 @@ GtkWidget* new_pixmap (char* filename) {
 class CBobtoolzToolbarButton : public IToolbarButton
 {
 public:
-  virtual const char* getImage() const
-  {
-    switch( mIndex ) {
-      case 0: return "bobtoolz_cleanup.bmp";
-      case 1: return "bobtoolz_poly.bmp";
-      case 2: return "bobtoolz_caulk.bmp";
-      case 3: return "bobtoolz_treeplanter.bmp";
-      case 4: return "bobtoolz_trainpathplot.bmp";
-      case 5: return "bobtoolz_dropent.bmp";
-      case 6: return "bobtoolz_merge.bmp";
-      case 7: return "bobtoolz_split.bmp";
-      case 8: return "bobtoolz_turnedge.bmp";
-    }
-    return NULL;
-  }
-  virtual EType getType() const
-  {
-    switch( mIndex ) {
-      case 3: return eToggleButton;
-      default: return eButton;
-    }
-  }
-  virtual const char* getText() const
-  {
-    switch( mIndex ) {
-      case 0: return "Cleanup";
-      case 1: return "Polygons";
-      case 2: return "Caulk";
-      case 3: return "Tree Planter";
-      case 4: return "Plot Splines";
-      case 5: return "Drop Entity";
-      case 6: return "Merge Patches";
-      case 7: return "Split Patches";
-      case 8: return "Flip Terrain";
-    }
-    return NULL;
-  }
-  virtual const char* getTooltip() const
-  {
-    switch( mIndex ) {
-      case 0: return "Brush Cleanup";
-      case 1: return "Polygons";
-      case 2: return "Caulk selection";
-      case 3: return "Tree Planter";
-      case 4: return "Plot Splines";
-      case 5: return "Drop Entity";
-      case 6: return "Merge Patches";
-      case 7: return "Split Patches";
-      case 8: return "Flip Terrain";
-    }
-    return NULL;
-  }
-
-  virtual void activate() const
-  {
-       LoadLists();
-
-    switch( mIndex ) {
-      case 0: DoFixBrushes(); break;
-      case 1: DoPolygonsTB(); break;
-      case 2: DoCaulkSelection(); break;
-      case 3: DoTreePlanter(); break;
-      case 4: DoTrainPathPlot(); break;
-      case 5: DoDropEnts(); break;
-      case 6: DoMergePatches(); break;
-      case 7: DoSplitPatch(); break;
-      case 8: DoFlipTerrain(); break;
-    }
-  }
-
-  int mIndex;
+virtual const char* getImage() const {
+       switch ( mIndex ) {
+       case 0: return "bobtoolz_cleanup.bmp";
+       case 1: return "bobtoolz_poly.bmp";
+       case 2: return "bobtoolz_caulk.bmp";
+       case 3: return "bobtoolz_treeplanter.bmp";
+       case 4: return "bobtoolz_trainpathplot.bmp";
+       case 5: return "bobtoolz_dropent.bmp";
+       case 6: return "bobtoolz_merge.bmp";
+       case 7: return "bobtoolz_split.bmp";
+       case 8: return "bobtoolz_turnedge.bmp";
+       }
+       return NULL;
+}
+virtual EType getType() const {
+       switch ( mIndex ) {
+       case 3: return eToggleButton;
+       default: return eButton;
+       }
+}
+virtual const char* getText() const {
+       switch ( mIndex ) {
+       case 0: return "Cleanup";
+       case 1: return "Polygons";
+       case 2: return "Caulk";
+       case 3: return "Tree Planter";
+       case 4: return "Plot Splines";
+       case 5: return "Drop Entity";
+       case 6: return "Merge Patches";
+       case 7: return "Split Patches";
+       case 8: return "Flip Terrain";
+       }
+       return NULL;
+}
+virtual const char* getTooltip() const {
+       switch ( mIndex ) {
+       case 0: return "Brush Cleanup";
+       case 1: return "Polygons";
+       case 2: return "Caulk selection";
+       case 3: return "Tree Planter";
+       case 4: return "Plot Splines";
+       case 5: return "Drop Entity";
+       case 6: return "Merge Patches";
+       case 7: return "Split Patches";
+       case 8: return "Flip Terrain";
+       }
+       return NULL;
+}
+
+virtual void activate() const {
+       LoadLists();
+
+       switch ( mIndex ) {
+       case 0: DoFixBrushes(); break;
+       case 1: DoPolygonsTB(); break;
+       case 2: DoCaulkSelection(); break;
+       case 3: DoTreePlanter(); break;
+       case 4: DoTrainPathPlot(); break;
+       case 5: DoDropEnts(); break;
+       case 6: DoMergePatches(); break;
+       case 7: DoSplitPatch(); break;
+       case 8: DoFlipTerrain(); break;
+       }
+}
+
+int mIndex;
 };
 
 CBobtoolzToolbarButton g_bobtoolzToolbarButtons[NUM_TOOLBARBUTTONS];
 
-const IToolbarButton* GetToolbarButton(unsigned int index)
-{
-  g_bobtoolzToolbarButtons[index].mIndex = index;
-  return &g_bobtoolzToolbarButtons[index];
+const IToolbarButton* GetToolbarButton( unsigned int index ){
+       g_bobtoolzToolbarButtons[index].mIndex = index;
+       return &g_bobtoolzToolbarButtons[index];
 }
 
 // =============================================================================
@@ -207,12 +213,12 @@ const IToolbarButton* GetToolbarButton(unsigned int index)
 class CSynapseClientBobtoolz : public CSynapseClient
 {
 public:
-  // CSynapseClient API
-  bool RequestAPI(APIDescriptor_t *pAPI);
-  const char* GetInfo();
+// CSynapseClient API
+bool RequestAPI( APIDescriptor_t *pAPI );
+const char* GetInfo();
 
-  CSynapseClientBobtoolz() { }
-  virtual ~CSynapseClientBobtoolz() { }
+CSynapseClientBobtoolz() { }
+virtual ~CSynapseClientBobtoolz() { }
 };
 
 
@@ -222,76 +228,70 @@ CSynapseClientBobtoolz g_SynapseClient;
 #if __GNUC__ >= 4
 #pragma GCC visibility push(default)
 #endif
-extern "C" CSynapseClient* SYNAPSE_DLL_EXPORT Synapse_EnumerateInterfaces( const char *version, CSynapseServer *pServer ) {
+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(TOOLBAR_MAJOR, BOBTOOLZ_MINOR, sizeof(_QERPlugToolbarTable));
-  g_SynapseClient.AddAPI(PLUGIN_MAJOR, BOBTOOLZ_MINOR, sizeof(_QERPluginTable));
-
-  g_SynapseClient.AddAPI(DATA_MAJOR, NULL, sizeof(g_AppDataTable), SYN_REQUIRE, &g_AppDataTable);
-  g_SynapseClient.AddAPI(BRUSH_MAJOR, NULL, sizeof(g_BrushTable), SYN_REQUIRE, &g_BrushTable);
-  g_SynapseClient.AddAPI(SHADERS_MAJOR, "*", sizeof(g_ShadersTable), SYN_REQUIRE, &g_ShadersTable);
-  g_SynapseClient.AddAPI(ENTITY_MAJOR, NULL, sizeof(g_EntityTable), SYN_REQUIRE, &g_EntityTable);
-  g_SynapseClient.AddAPI(SELECTEDFACE_MAJOR, NULL, sizeof(g_SelectedFaceTable), SYN_REQUIRE, &g_SelectedFaceTable);
-  g_SynapseClient.AddAPI(UI_MAJOR, NULL, sizeof(g_MessageTable), SYN_REQUIRE, &g_MessageTable);
-  g_SynapseClient.AddAPI(RADIANT_MAJOR, NULL, sizeof(g_FuncTable), SYN_REQUIRE, &g_FuncTable);
-  g_SynapseClient.AddAPI(QGL_MAJOR, NULL, sizeof(g_QglTable), SYN_REQUIRE, &g_QglTable);
-
-  return &g_SynapseClient;
+       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( TOOLBAR_MAJOR, BOBTOOLZ_MINOR, sizeof( _QERPlugToolbarTable ) );
+       g_SynapseClient.AddAPI( PLUGIN_MAJOR, BOBTOOLZ_MINOR, sizeof( _QERPluginTable ) );
+
+       g_SynapseClient.AddAPI( DATA_MAJOR, NULL, sizeof( g_AppDataTable ), SYN_REQUIRE, &g_AppDataTable );
+       g_SynapseClient.AddAPI( BRUSH_MAJOR, NULL, sizeof( g_BrushTable ), SYN_REQUIRE, &g_BrushTable );
+       g_SynapseClient.AddAPI( SHADERS_MAJOR, "*", sizeof( g_ShadersTable ), SYN_REQUIRE, &g_ShadersTable );
+       g_SynapseClient.AddAPI( ENTITY_MAJOR, NULL, sizeof( g_EntityTable ), SYN_REQUIRE, &g_EntityTable );
+       g_SynapseClient.AddAPI( SELECTEDFACE_MAJOR, NULL, sizeof( g_SelectedFaceTable ), SYN_REQUIRE, &g_SelectedFaceTable );
+       g_SynapseClient.AddAPI( UI_MAJOR, NULL, sizeof( g_MessageTable ), SYN_REQUIRE, &g_MessageTable );
+       g_SynapseClient.AddAPI( RADIANT_MAJOR, NULL, sizeof( g_FuncTable ), SYN_REQUIRE, &g_FuncTable );
+       g_SynapseClient.AddAPI( QGL_MAJOR, NULL, sizeof( g_QglTable ), SYN_REQUIRE, &g_QglTable );
+
+       return &g_SynapseClient;
 }
 
-bool CSynapseClientBobtoolz::RequestAPI(APIDescriptor_t *pAPI)
-{
-  if( !strcmp(pAPI->minor_name, BOBTOOLZ_MINOR) )
-  {
-    if( !strcmp(pAPI->major_name, PLUGIN_MAJOR) )
-    {
-      _QERPluginTable* pTable= static_cast<_QERPluginTable*>(pAPI->mpTable);
-
-      pTable->m_pfnQERPlug_Init = QERPlug_Init;
-      pTable->m_pfnQERPlug_GetName = QERPlug_GetName;
-      pTable->m_pfnQERPlug_GetCommandList = QERPlug_GetCommandList;
-      pTable->m_pfnQERPlug_Dispatch = QERPlug_Dispatch;
-
-      return true;
-    }
-    else if( !strcmp(pAPI->major_name, TOOLBAR_MAJOR) )
-    {
-      _QERPlugToolbarTable* pTable= static_cast<_QERPlugToolbarTable*>(pAPI->mpTable);
-
-      pTable->m_pfnToolbarButtonCount = &ToolbarButtonCount;
-      pTable->m_pfnGetToolbarButton = &GetToolbarButton;
-
-      return true;
-    }
-  }
-
-  Syn_Printf("ERROR: RequestAPI( '%s' ) not found in '%s'\n", pAPI->major_name, GetInfo());
-  return false;
+bool CSynapseClientBobtoolz::RequestAPI( APIDescriptor_t *pAPI ){
+       if ( !strcmp( pAPI->minor_name, BOBTOOLZ_MINOR ) ) {
+               if ( !strcmp( pAPI->major_name, PLUGIN_MAJOR ) ) {
+                       _QERPluginTable* pTable = static_cast<_QERPluginTable*>( pAPI->mpTable );
+
+                       pTable->m_pfnQERPlug_Init = QERPlug_Init;
+                       pTable->m_pfnQERPlug_GetName = QERPlug_GetName;
+                       pTable->m_pfnQERPlug_GetCommandList = QERPlug_GetCommandList;
+                       pTable->m_pfnQERPlug_Dispatch = QERPlug_Dispatch;
+
+                       return true;
+               }
+               else if ( !strcmp( pAPI->major_name, TOOLBAR_MAJOR ) ) {
+                       _QERPlugToolbarTable* pTable = static_cast<_QERPlugToolbarTable*>( pAPI->mpTable );
+
+                       pTable->m_pfnToolbarButtonCount = &ToolbarButtonCount;
+                       pTable->m_pfnGetToolbarButton = &GetToolbarButton;
+
+                       return true;
+               }
+       }
+
+       Syn_Printf( "ERROR: RequestAPI( '%s' ) not found in '%s'\n", pAPI->major_name, GetInfo() );
+       return false;
 }
 
 #include "version.h"
 
-const char* CSynapseClientBobtoolz::GetInfo()
-{
-  return "bobToolz module built " __DATE__ " " RADIANT_VERSION;
+const char* CSynapseClientBobtoolz::GetInfo(){
+       return "bobToolz module built " __DATE__ " " RADIANT_VERSION;
 }
 
-char* GetFilename(char* buffer, const char* filename) {
-       strcpy(buffer, g_pSynapseServer->GetModuleFilename(&g_SynapseClient));
+char* GetFilename( char* buffer, const char* filename ) {
+       strcpy( buffer, g_pSynapseServer->GetModuleFilename( &g_SynapseClient ) );
        StripFilename( buffer );
-       strcat(buffer, "/");
-       strcat(buffer, filename);
-       buffer = UnixToDosPath(buffer);
+       strcat( buffer, "/" );
+       strcat( buffer, filename );
+       buffer = UnixToDosPath( buffer );
        return buffer;
 }