/* 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 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 */ #include "StdAfx.h" #include "funchandlers.h" #include "misc.h" #include "dialogs/dialogs-gtk.h" #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; // plugin name char* PLUGIN_NAME = "bobToolz"; // commands in the menu static char* PLUGIN_COMMANDS = "About...,-,Reset Textures...,PitOMatic,-,Vis Viewer,Brush Cleanup,Polygon Builder,Caulk Selection,-,Tree Planter,Drop Entity,Plot Splines,-,Merge Patches,Split patches,Turn edge"; // globals GtkWidget *g_pRadiantWnd = NULL; static const char *PLUGIN_ABOUT = "bobToolz for SDRadiant\n" "by digibob (digibob@splashdamage.com)\n" "http://www.splashdamage.com\n\n" "Additional Contributors:\n" "MarsMattel, RR2DO2\n"; extern "C" const char* QERPlug_Init( void* hApp, void* pMainWidget ) { g_pRadiantWnd = (GtkWidget*)pMainWidget; return "bobToolz for GTKradiant"; } extern "C" const char* QERPlug_GetName() { return PLUGIN_NAME; } 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) { 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...") ) { DoResetTextures(); } 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); } } #define NUM_TOOLBARBUTTONS 9 unsigned int ToolbarButtonCount( void ) { return NUM_TOOLBARBUTTONS; } // Load a xpm file and return a pixmap widget. 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); gdk_pixmap_unref (gdkpixmap); gdk_pixmap_unref (mask); return pixmap; } 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; }; CBobtoolzToolbarButton g_bobtoolzToolbarButtons[NUM_TOOLBARBUTTONS]; const IToolbarButton* GetToolbarButton(unsigned int index) { g_bobtoolzToolbarButtons[index].mIndex = index; return &g_bobtoolzToolbarButtons[index]; } // ============================================================================= // SYNAPSE class CSynapseClientBobtoolz : public CSynapseClient { public: // CSynapseClient API bool RequestAPI(APIDescriptor_t *pAPI); const char* GetInfo(); CSynapseClientBobtoolz() { } virtual ~CSynapseClientBobtoolz() { } }; CSynapseServer* g_pSynapseServer = NULL; 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 ) { #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; } 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; } char* GetFilename(char* buffer, const char* filename) { strcpy(buffer, g_pSynapseServer->GetModuleFilename(&g_SynapseClient)); StripFilename( buffer ); strcat(buffer, "/"); strcat(buffer, filename); buffer = UnixToDosPath(buffer); return buffer; }