2 GenSurf plugin for GtkRadiant
3 Copyright (C) 2001 David Hyde, Loki software and qeradiant.com
5 This library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 This library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with this library; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 #include <uilib/uilib.h>
24 // Global plugin FuncTable
25 _QERFuncTable_1 g_FuncTable;
26 _QERQglTable g_GLTable;
27 _QERUIGtkTable g_UIGtkTable;
28 _QEREntityTable __ENTITYTABLENAME;
29 _QERBrushTable __BRUSHTABLENAME;
30 _QERPatchTable __PATCHTABLENAME;
31 bool SingleBrushSelected;
36 const char* QERPlug_Init( void* hApp, void* pMainWidget ){
37 g_pRadiantWnd = ui::Window::from(pMainWidget);
39 return "GenSurf for Q3Radiant";
42 const char* QERPlug_GetName(){
46 const char* QERPlug_GetCommandList(){
47 return "Wall facing 270...;Wall facing 180...;Wall facing 90...;Wall facing 0...;"
48 "Ceiling...;Ground surface...;-;About...";
51 // vMin/vMax provide the bounds of the selection, they are zero if there is no selection
52 // if there is a selection, bSingleBrush will be true if a single brush is selected
53 // if so, typical plugin behaviour (such as primitive creation) would use the bounds as
54 // a rule to create the primitive, then delete the selection
55 void QERPlug_Dispatch( const char *p, vec3_t vMin, vec3_t vMax, bool bSingleBrush ){
56 bool Generate = false;
59 if ( GenSurfInit() ) {
64 if ( !strcmp( p, "Ground surface..." ) ) {
65 SingleBrushSelected = bSingleBrush;
67 if ( SingleBrushSelected ) {
72 Z00 = Z01 = Z10 = Z11 = vMax[2];
76 else if ( !strcmp( p, "Ceiling..." ) ) {
77 SingleBrushSelected = bSingleBrush;
79 if ( SingleBrushSelected ) {
84 Z00 = Z01 = Z10 = Z11 = vMin[2];
88 else if ( !strcmp( p, "Wall facing 0..." ) ) {
89 SingleBrushSelected = bSingleBrush;
91 if ( SingleBrushSelected ) {
96 Z00 = Z01 = Z10 = Z11 = vMax[0];
100 else if ( !strcmp( p, "Wall facing 90..." ) ) {
101 SingleBrushSelected = bSingleBrush;
103 if ( SingleBrushSelected ) {
108 Z00 = Z01 = Z10 = Z11 = vMax[1];
112 else if ( !strcmp( p, "Wall facing 180..." ) ) {
113 SingleBrushSelected = bSingleBrush;
115 if ( SingleBrushSelected ) {
120 Z00 = Z01 = Z10 = Z11 = vMin[0];
124 else if ( !strcmp( p, "Wall facing 270..." ) ) {
125 SingleBrushSelected = bSingleBrush;
127 if ( SingleBrushSelected ) {
132 Z00 = Z01 = Z10 = Z11 = vMin[1];
136 else if ( !strcmp( p,"About..." ) ) {
137 About( g_pRadiantWnd );
141 if ( SingleBrushSelected ) {
149 // =============================================================================
154 class GenSurfSynapseClient : public CSynapseClient
157 // CSynapseClient API
158 bool RequestAPI( APIDescriptor_t *pAPI );
159 const char* GetInfo();
161 GenSurfSynapseClient() { }
162 virtual ~GenSurfSynapseClient() { }
165 CSynapseServer* g_pSynapseServer = NULL;
166 GenSurfSynapseClient g_SynapseClient;
168 extern "C" CSynapseClient * SYNAPSE_DLL_EXPORT Synapse_EnumerateInterfaces( const char *version, CSynapseServer *pServer ){
169 if ( strcmp( version, SYNAPSE_VERSION ) ) {
170 Syn_Printf( "ERROR: synapse API version mismatch: should be '" SYNAPSE_VERSION "', got '%s'\n", version );
173 g_pSynapseServer = pServer;
174 g_pSynapseServer->IncRef();
175 Set_Syn_Printf( g_pSynapseServer->Get_Syn_Printf() );
177 g_SynapseClient.AddAPI( PLUGIN_MAJOR, "gtkgensurf", sizeof( _QERPluginTable ) );
179 g_SynapseClient.AddAPI( RADIANT_MAJOR, NULL, sizeof( _QERFuncTable_1 ), SYN_REQUIRE, &g_FuncTable );
180 g_SynapseClient.AddAPI( UIGTK_MAJOR, NULL, sizeof( _QERUIGtkTable ), SYN_REQUIRE, &g_UIGtkTable );
181 g_SynapseClient.AddAPI( QGL_MAJOR, NULL, sizeof( _QERQglTable ), SYN_REQUIRE, &g_GLTable );
182 g_SynapseClient.AddAPI( ENTITY_MAJOR, NULL, sizeof( _QEREntityTable ), SYN_REQUIRE, &g_EntityTable );
184 return &g_SynapseClient;
187 bool GenSurfSynapseClient::RequestAPI( APIDescriptor_t *pAPI ){
188 if ( !strcmp( pAPI->major_name, PLUGIN_MAJOR ) ) {
189 _QERPluginTable* pTable = static_cast<_QERPluginTable*>( pAPI->mpTable );
191 pTable->m_pfnQERPlug_Init = QERPlug_Init;
192 pTable->m_pfnQERPlug_GetName = QERPlug_GetName;
193 pTable->m_pfnQERPlug_GetCommandList = QERPlug_GetCommandList;
194 pTable->m_pfnQERPlug_Dispatch = QERPlug_Dispatch;
198 Syn_Printf( "ERROR: RequestAPI( '%s' ) not found in '%s'\n", pAPI->major_name, GetInfo() );
202 const char* GenSurfSynapseClient::GetInfo(){
203 return "GtkGenSurf - built " __DATE__ " " RADIANT_VERSION;