2 Copyright (C) 1999-2007 id Software, Inc. and contributors.
\r
3 For a list of contributors, see the accompanying CONTRIBUTORS file.
\r
5 This file is part of GtkRadiant.
\r
7 GtkRadiant is free software; you can redistribute it and/or modify
\r
8 it under the terms of the GNU General Public License as published by
\r
9 the Free Software Foundation; either version 2 of the License, or
\r
10 (at your option) any later version.
\r
12 GtkRadiant is distributed in the hope that it will be useful,
\r
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
15 GNU General Public License for more details.
\r
17 You should have received a copy of the GNU General Public License
\r
18 along with GtkRadiant; if not, write to the Free Software
\r
19 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
\r
32 #define qfalse false
\r
36 extern qboolean verbose;
\r
39 extern qboolean drawflag;
\r
40 extern qboolean noprune;
\r
41 extern qboolean glview;
\r
42 extern qboolean nodetail;
\r
43 extern qboolean fulldetail;
\r
44 extern qboolean onlyents;
\r
45 extern qboolean nomerge;
\r
46 extern qboolean nowater;
\r
47 extern qboolean nofill;
\r
48 extern qboolean nocsg;
\r
49 extern qboolean noweld;
\r
50 extern qboolean noshare;
\r
51 extern qboolean nosubdiv;
\r
52 extern qboolean notjunc;
\r
53 extern qboolean noopt;
\r
54 extern qboolean leaktest;
\r
55 extern qboolean verboseentities;
\r
56 extern char outbase[32];
\r
57 extern int block_xl, block_xh, block_yl, block_yh;
\r
58 extern vec_t microvolume;
\r
59 extern float subdivide_size;
\r
62 extern char inbase[32];
\r
63 extern qboolean fastvis;
\r
64 extern qboolean nosort;
\r
65 extern int testlevel;
\r
68 extern qboolean dumppatches;
\r
69 extern int numbounce;
\r
70 extern qboolean extrasamples;
\r
71 extern float subdiv;
\r
72 extern float lightscale;
\r
73 extern float direct_scale;
\r
74 extern float entity_scale;
\r
75 extern qboolean nopvs;
\r
76 extern float ambient;
\r
77 extern float maxlight;
\r
80 void InitPaths( int *argc, char **argv );
\r
84 returns a pseudorandom number between 0 and 1
\r
87 vec_t Random( void )
\r
89 return (vec_t) rand() / RAND_MAX;
\r
99 static void ExitQ2Map( void )
\r
102 if( mapDrawSurfs != NULL )
\r
103 free( mapDrawSurfs );
\r
110 emits statistics about the bsp file
\r
115 char source[ 1024 ], ext[ 64 ];
\r
119 Sys_Printf ("\n----- INFO ----\n\n");
\r
122 if( mapname == NULL )
\r
124 Sys_Printf( "No files to dump info for.\n");
\r
128 /* enable info mode */
\r
129 //infoMode = qtrue;
\r
132 /* mangle filename and get size */
\r
133 strcpy( source, mapname );
\r
134 ExtractFileExtension( source, ext );
\r
135 if( !Q_stricmp( ext, "map" ) )
\r
136 StripExtension( source );
\r
137 DefaultExtension( source, ".bsp" );
\r
138 f = fopen( source, "rb" );
\r
141 size = Q_filelength (f);
\r
147 /* load the bsp file and print lump sizes */
\r
148 Sys_Printf( "Map: %s\n\n", source );
\r
150 Sys_Printf( "-----------------------------------------------------\n" );
\r
152 LoadBSPFile( source );
\r
153 PrintBSPFileSizes();
\r
155 Sys_Printf( "-----------------------------------------------------\n" );
\r
158 Sys_Printf( "Total: %d B = %.3f kB = %.3f MB\n", size, size / 1024.0, size / (1024.0 * 1024.0) );
\r
160 Sys_Printf( "-----------------------------------------------------\n" );
\r
170 amaze and confuse your enemies with wierd scaled maps!
\r
173 int ScaleBSPMain( int argc, char **argv )
\r
184 Sys_Printf( "Usage: q3map -scale <value> [-v] <mapname>\n" );
\r
189 scale = atof( argv[ argc - 2 ] );
\r
190 if( scale == 0.0f )
\r
192 Sys_Printf( "Usage: q3map -scale <value> [-v] <mapname>\n" );
\r
193 Sys_Printf( "Non-zero scale value required.\n" );
\r
197 // do some path mangling
\r
198 strcpy( source, ExpandArg( argv[ argc - 1 ] ) );
\r
199 StripExtension( source );
\r
200 DefaultExtension( source, ".bsp" );
\r
203 Sys_Printf( "Loading %s\n", source );
\r
204 LoadBSPFile( source );
\r
208 Sys_Printf( "--- ScaleBSP ---\n" );
\r
209 Sys_FPrintf( SYS_VRB, "%9d entities\n", numEntities );
\r
211 // scale entity keys
\r
212 for( i = 0; i < numBSPEntities && i < numEntities; i++ )
\r
215 GetVectorForKey( &entities[ i ], "origin", vec );
\r
216 if( (vec[ 0 ] + vec[ 1 ] + vec[ 2 ]) )
\r
218 VectorScale( vec, scale, vec );
\r
219 sprintf( str, "%f %f %f", vec[ 0 ], vec[ 1 ], vec[ 2 ] );
\r
220 SetKeyValue( &entities[ i ], "origin", str );
\r
224 f = FloatForKey( &entities[ i ], "lip" );
\r
228 sprintf( str, "%f", f );
\r
229 SetKeyValue( &entities[ i ], "lip", str );
\r
234 for( i = 0; i < numBSPModels; i++ )
\r
236 VectorScale( bspModels[ i ].mins, scale, bspModels[ i ].mins );
\r
237 VectorScale( bspModels[ i ].maxs, scale, bspModels[ i ].maxs );
\r
241 for( i = 0; i < numBSPNodes; i++ )
\r
243 VectorScale( bspNodes[ i ].mins, scale, bspNodes[ i ].mins );
\r
244 VectorScale( bspNodes[ i ].maxs, scale, bspNodes[ i ].maxs );
\r
248 for( i = 0; i < numBSPLeafs; i++ )
\r
250 VectorScale( bspLeafs[ i ].mins, scale, bspLeafs[ i ].mins );
\r
251 VectorScale( bspLeafs[ i ].maxs, scale, bspLeafs[ i ].maxs );
\r
254 // scale drawverts
\r
255 for( i = 0; i < numBSPDrawVerts; i++ )
\r
256 VectorScale( bspDrawVerts[ i ].xyz, scale, bspDrawVerts[ i ].xyz );
\r
259 for( i = 0; i < numBSPPlanes; i++ )
\r
260 bspPlanes[ i ].dist *= scale;
\r
263 GetVectorForKey( &entities[ 0 ], "gridsize", vec );
\r
264 if( (vec[ 0 ] + vec[ 1 ] + vec[ 2 ]) == 0.0f )
\r
265 VectorCopy( gridSize, vec );
\r
266 VectorScale( vec, scale, vec );
\r
267 sprintf( str, "%f %f %f", vec[ 0 ], vec[ 1 ], vec[ 2 ] );
\r
268 SetKeyValue( &entities[ 0 ], "gridsize", str );
\r
272 StripExtension( source );
\r
273 DefaultExtension( source, "_s.bsp" );
\r
274 Sys_Printf( "Writing %s\n", source );
\r
275 WriteBSPFile( source );
\r
277 // return to sender
\r
285 main argument processing function for bsp conversion
\r
288 int ConvertBSPMain( int argc, char **argv )
\r
291 int (*convertFunc)( char * );
\r
295 convertFunc = ConvertBSPToASE;
\r
300 Sys_Printf( "Usage: q3map -scale <value> [-v] <mapname>\n" );
\r
304 // process arguments
\r
305 for( i = 1; i < (argc - 1); i++ )
\r
307 // -format map|ase|...
\r
308 if( !strcmp( argv[ i ], "-format" ) )
\r
311 if( !Q_stricmp( argv[ i ], "ase" ) )
\r
312 convertFunc = ConvertBSPToASE;
\r
313 else if( !Q_stricmp( argv[ i ], "map" ) )
\r
314 convertFunc = ConvertBSPToMap;
\r
316 Sys_Printf( "Unknown conversion format \"%s\". Defaulting to ASE.\n", argv[ i ] );
\r
320 // clean up map name
\r
321 strcpy( source, ExpandArg( argv[ i ] ) );
\r
322 StripExtension( source );
\r
323 DefaultExtension( source, ".bsp" );
\r
327 Sys_Printf( "Loading %s\n", source );
\r
329 // ydnar: load surface file
\r
330 //% LoadSurfaceExtraFile( source );
\r
332 LoadBSPFile( source );
\r
334 // parse bsp entities
\r
338 return convertFunc( source );
\r
342 int Check_BSP_Options( int argc, char **argv )
\r
346 for (i=1 ; i<argc ; i++)
\r
348 if (!strcmp(argv[i],"-glview"))
\r
352 else if (!strcmp(argv[i], "-draw"))
\r
354 Sys_Printf ("drawflag = true\n");
\r
357 else if (!strcmp(argv[i], "-noweld"))
\r
359 Sys_Printf ("noweld = true\n");
\r
362 else if (!strcmp(argv[i], "-nocsg"))
\r
364 Sys_Printf ("nocsg = true\n");
\r
367 else if (!strcmp(argv[i], "-noshare"))
\r
369 Sys_Printf ("noshare = true\n");
\r
372 else if (!strcmp(argv[i], "-notjunc"))
\r
374 Sys_Printf ("notjunc = true\n");
\r
377 else if (!strcmp(argv[i], "-nowater"))
\r
379 Sys_Printf ("nowater = true\n");
\r
382 else if (!strcmp(argv[i], "-noopt"))
\r
384 Sys_Printf ("noopt = true\n");
\r
387 else if (!strcmp(argv[i], "-noprune"))
\r
389 Sys_Printf ("noprune = true\n");
\r
392 else if (!strcmp(argv[i], "-nofill"))
\r
394 Sys_Printf ("nofill = true\n");
\r
397 else if (!strcmp(argv[i], "-nomerge"))
\r
399 Sys_Printf ("nomerge = true\n");
\r
402 else if (!strcmp(argv[i], "-nosubdiv"))
\r
404 Sys_Printf ("nosubdiv = true\n");
\r
407 else if (!strcmp(argv[i], "-nodetail"))
\r
409 Sys_Printf ("nodetail = true\n");
\r
412 else if (!strcmp(argv[i], "-fulldetail"))
\r
414 Sys_Printf ("fulldetail = true\n");
\r
417 else if (!strcmp(argv[i], "-onlyents"))
\r
419 Sys_Printf ("onlyents = true\n");
\r
422 else if (!strcmp(argv[i], "-micro"))
\r
424 microvolume = atof(argv[i+1]);
\r
425 Sys_Printf ("microvolume = %f\n", microvolume);
\r
428 else if (!strcmp(argv[i], "-leaktest"))
\r
430 Sys_Printf ("leaktest = true\n");
\r
433 else if (!strcmp(argv[i], "-verboseentities"))
\r
435 Sys_Printf ("verboseentities = true\n");
\r
436 verboseentities = true;
\r
438 else if (!strcmp(argv[i], "-chop"))
\r
440 subdivide_size = atof(argv[i+1]);
\r
441 Sys_Printf ("subdivide_size = %f\n", subdivide_size);
\r
444 else if (!strcmp(argv[i], "-block"))
\r
446 block_xl = block_xh = atoi(argv[i+1]);
\r
447 block_yl = block_yh = atoi(argv[i+2]);
\r
448 Sys_Printf ("block: %i,%i\n", block_xl, block_yl);
\r
451 else if (!strcmp(argv[i], "-blocks"))
\r
453 block_xl = atoi(argv[i+1]);
\r
454 block_yl = atoi(argv[i+2]);
\r
455 block_xh = atoi(argv[i+3]);
\r
456 block_yh = atoi(argv[i+4]);
\r
457 Sys_Printf ("blocks: %i,%i to %i,%i\n",
\r
458 block_xl, block_yl, block_xh, block_yh);
\r
461 else if (!strcmp (argv[i],"-tmpout"))
\r
463 strcpy (outbase, "/tmp");
\r
473 int Check_VIS_Options( int argc, char **argv )
\r
477 for (i=1 ; i<argc ; i++)
\r
479 if (!strcmp(argv[i], "-fast"))
\r
481 Sys_Printf ("fastvis = true\n");
\r
484 else if (!strcmp(argv[i], "-level"))
\r
486 testlevel = atoi(argv[i+1]);
\r
487 Sys_Printf ("testlevel = %i\n", testlevel);
\r
490 else if (!strcmp (argv[i],"-nosort"))
\r
492 Sys_Printf ("nosort = true\n");
\r
495 else if (!strcmp (argv[i],"-tmpin"))
\r
496 strcpy (inbase, "/tmp");
\r
497 else if (!strcmp (argv[i],"-tmpout"))
\r
498 strcpy (outbase, "/tmp");
\r
506 int Check_RAD_Options( int argc, char **argv )
\r
510 for (i=1 ; i<argc ; i++)
\r
512 if (!strcmp(argv[i],"-dump"))
\r
513 dumppatches = true;
\r
514 else if (!strcmp(argv[i],"-bounce"))
\r
516 numbounce = atoi (argv[i+1]);
\r
519 else if (!strcmp(argv[i],"-extra"))
\r
521 extrasamples = true;
\r
522 Sys_Printf ("extrasamples = true\n");
\r
524 else if (!strcmp(argv[i],"-chop"))
\r
526 subdiv = atoi (argv[i+1]);
\r
529 else if (!strcmp(argv[i],"-scale"))
\r
531 lightscale = atof (argv[i+1]);
\r
534 else if (!strcmp(argv[i],"-direct"))
\r
536 direct_scale *= atof(argv[i+1]);
\r
537 Sys_Printf ("direct light scaling at %f\n", direct_scale);
\r
540 else if (!strcmp(argv[i],"-entity"))
\r
542 entity_scale *= atof(argv[i+1]);
\r
543 Sys_Printf ("entity light scaling at %f\n", entity_scale);
\r
546 else if (!strcmp(argv[i],"-glview"))
\r
549 Sys_Printf ("glview = true\n");
\r
551 else if (!strcmp(argv[i],"-nopvs"))
\r
554 Sys_Printf ("nopvs = true\n");
\r
556 else if (!strcmp(argv[i],"-ambient"))
\r
558 ambient = atof (argv[i+1]) * 128;
\r
561 else if (!strcmp(argv[i],"-maxlight"))
\r
563 maxlight = atof (argv[i+1]) * 128;
\r
566 else if (!strcmp (argv[i],"-tmpin"))
\r
567 strcpy (inbase, "/tmp");
\r
568 else if (!strcmp (argv[i],"-tmpout"))
\r
569 strcpy (outbase, "/tmp");
\r
581 int main( int argc, char **argv )
\r
589 qboolean do_info=qfalse;
\r
590 qboolean do_bsp=qfalse;
\r
591 qboolean do_vis=qfalse;
\r
592 qboolean do_rad=qfalse;
\r
595 /* we want consistent 'randomness' */
\r
599 start = I_FloatTime();
\r
601 Sys_Printf( "\nQ2Map - Ver. 1.0\n" );
\r
603 /* set exit call */
\r
604 //atexit( ExitQ3Map );
\r
610 Sys_Printf(" %s: -game [quake2,heretic2] -fs_basepath basepath -info -bsp -vis -rad mapname\n",argv[0]);
\r
613 /* read general options first */
\r
614 for( i = 1; i < argc; i++ )
\r
617 if( !strcmp( argv[ i ], "-connect" ) )
\r
620 Broadcast_Setup( argv[ i ] );
\r
624 else if( !strcmp( argv[ i ], "-v" ) )
\r
630 else if( !strcmp( argv[ i ], "-threads" ) )
\r
633 numthreads = atoi( argv[ i ] );
\r
635 else if( !strcmp( argv[ i ], "-game" ) )
\r
638 strncpy (game, argv[ i ] , 64);
\r
643 /* set number of threads */
\r
644 ThreadSetDefault();
\r
646 /* ydnar: new path initialization */
\r
647 InitPaths( &argc, argv );
\r
649 /* read compiling options */
\r
650 for( i = 1; i < argc; i++ )
\r
653 if( !strcmp( argv[ i ], "-info" ) )
\r
659 if( !strcmp( argv[ i ], "-bsp" ) )
\r
663 alt_argv= (char **) ( argv + i );
\r
664 Check_BSP_Options( alt_argc, alt_argv );
\r
668 if( !strcmp( argv[ i ], "-vis" ) )
\r
672 alt_argv= (char **) ( argv + i );
\r
673 Check_VIS_Options( alt_argc, alt_argv );
\r
677 if( !strcmp( argv[ i ], "-rad" ) )
\r
681 alt_argv= (char **) ( argv + i );
\r
682 Check_RAD_Options( alt_argc, alt_argv );
\r
687 strncpy( game, "quake2", 7);
\r
689 Sys_Printf("Game: %s\n", game);
\r
691 if ( !do_info && !do_bsp && !do_vis && !do_rad)
\r
692 Sys_Printf("ERROR: -bsp, -vis, -light, nor -info specified.\nWhat to you want me to do?\n\n");
\r
695 mapname=argv[argc-1];
\r
709 end = I_FloatTime();
\r
710 total_time = (int) (end-start);
\r
711 Sys_Printf("\nTotal Time: ");
\r
712 if ( total_time > 59 )
\r
713 Sys_Printf("%d Minutes ", total_time/60 );
\r
714 Sys_Printf( "%d Seconds\n", total_time%60 );
\r
716 /* shut down connection */
\r
717 Broadcast_Shutdown();
\r
719 /* return any error code */
\r