]> de.git.xonotic.org Git - xonotic/netradiant.git/blobdiff - tools/quake2/qdata_heretic2/book.c
uncrustify! now the code is only ugly on the *inside*
[xonotic/netradiant.git] / tools / quake2 / qdata_heretic2 / book.c
index fd8072cbc81a5594f71e87e9a192e1eced43de4b..412aefe88062523444e3f071a037e8f8fb0c7c70 100644 (file)
 /*
-Copyright (C) 1999-2007 id Software, Inc. and contributors.
-For a list of contributors, see the accompanying CONTRIBUTORS file.
+   Copyright (C) 1999-2007 id Software, Inc. and contributors.
+   For a list of contributors, see the accompanying CONTRIBUTORS file.
 
-This file is part of GtkRadiant.
+   This file is part of GtkRadiant.
 
-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.
+   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.
 
-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.
+   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.
 
-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
-*/
+   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
+ */
 
 
 #include "qdata.h"
 
-byte                   *byteimage, *lbmpalette;
-int                            byteimagewidth, byteimageheight;
+byte            *byteimage, *lbmpalette;
+int byteimagewidth, byteimageheight;
 
-qboolean               TrueColorImage;
-int                            longimagewidth, longimageheight;
+qboolean TrueColorImage;
+int longimagewidth, longimageheight;
 
-char                   book_prefix[1024];
-byte                   buffer[640 * 480];
-unsigned long  bufferl[640 * 480];
+char book_prefix[1024];
+byte buffer[640 * 480];
+unsigned long bufferl[640 * 480];
 
-miptex_t *CreateBook8(byte *buffer, int w, int h, byte *palette, int *FinalSize)
-{
-       miptex_t        *mp;
-       int                     i, j;
-       byte            *pos;
-       int                     size;
+miptex_t *CreateBook8( byte *buffer, int w, int h, byte *palette, int *FinalSize ){
+       miptex_t    *mp;
+       int i, j;
+       byte        *pos;
+       int size;
 
-       size = sizeof(*mp) + (w * h);
-       mp = (miptex_t *)SafeMalloc(size, "CreateBook8");
-       memset(mp, 0, size);
+       size = sizeof( *mp ) + ( w * h );
+       mp = (miptex_t *)SafeMalloc( size, "CreateBook8" );
+       memset( mp, 0, size );
 
        mp->version = MIP_VERSION;
 
-       for(i=j=0;i<256;i++,j+=3)
+       for ( i = j = 0; i < 256; i++,j += 3 )
        {
                mp->palette[i].r = palette[j];
-               mp->palette[i].g = palette[j+1];
-               mp->palette[i].b = palette[j+2];
+               mp->palette[i].g = palette[j + 1];
+               mp->palette[i].b = palette[j + 2];
        }
-       pos = (byte *)(mp + 1);
+       pos = (byte *)( mp + 1 );
 
        mp->width[0] = w;
        mp->height[0] = h;
-       mp->offsets[0] = sizeof(*mp);
-       memcpy(pos, buffer, w * h);
+       mp->offsets[0] = sizeof( *mp );
+       memcpy( pos, buffer, w * h );
 
        *FinalSize = size;
-       return(mp);
+       return( mp );
 }
 
-miptex32_t *CreateBook32(long *buffer, int w, int h, int *FinalSize)
-{
-       miptex32_t      *mp;
-       byte            *pos;
-       int                     size;
+miptex32_t *CreateBook32( long *buffer, int w, int h, int *FinalSize ){
+       miptex32_t  *mp;
+       byte        *pos;
+       int size;
 
-       size = sizeof(*mp) + (w * h * 4);
-       mp = (miptex32_t *)SafeMalloc(size, "CreateBook32");
-       memset(mp, 0, size);
+       size = sizeof( *mp ) + ( w * h * 4 );
+       mp = (miptex32_t *)SafeMalloc( size, "CreateBook32" );
+       memset( mp, 0, size );
 
        mp->version = MIP32_VERSION;
 
-       pos = (byte *)(mp + 1);
+       pos = (byte *)( mp + 1 );
 
        mp->width[0] = w;
        mp->height[0] = h;
-       mp->offsets[0] = sizeof(*mp);
-       memcpy(pos, buffer, w * h * 4);
+       mp->offsets[0] = sizeof( *mp );
+       memcpy( pos, buffer, w * h * 4 );
 
        *FinalSize = size;
-       return(mp);
+       return( mp );
 }
 
 
 // Routines to chop a random sized image into gl texture friendly chunks
 
-typedef struct rect_s 
+typedef struct rect_s
 {
-       int             x, y;
-       int             w, h;
-       char    name[4];
+       int x, y;
+       int w, h;
+       char name[4];
 } rect_t;
 
-int GetCoords(int x, int store[MAX_MD2SKINS])
-{
-       int             index, start, delta;
+int GetCoords( int x, int store[MAX_MD2SKINS] ){
+       int index, start, delta;
 
        index = 0;
        start = 0;
        delta = 256;
 
        store[index++] = start;
-       while(x)
+       while ( x )
        {
-               if(x >= delta)
-               {
+               if ( x >= delta ) {
                        start += delta;
                        store[index++] = start;
                        x -= delta;
@@ -117,21 +113,20 @@ int GetCoords(int x, int store[MAX_MD2SKINS])
                        delta >>= 1;
                }
        }
-       return(index);
+       return( index );
 }
 
-int ChopImage(int w, int h, rect_t coords[MAX_MD2SKINS])
-{
-       int             xs[MAX_MD2SKINS], ys[MAX_MD2SKINS];
-       int             xcount, ycount, x, y, index;
+int ChopImage( int w, int h, rect_t coords[MAX_MD2SKINS] ){
+       int xs[MAX_MD2SKINS], ys[MAX_MD2SKINS];
+       int xcount, ycount, x, y, index;
 
        index = 0;
-       xcount = GetCoords(w, xs) - 1;
-       ycount = GetCoords(h, ys) - 1;
+       xcount = GetCoords( w, xs ) - 1;
+       ycount = GetCoords( h, ys ) - 1;
 
-       for(y = 0; y < ycount; y++)
+       for ( y = 0; y < ycount; y++ )
        {
-               for(x = 0; x < xcount; x++, index++)
+               for ( x = 0; x < xcount; x++, index++ )
                {
                        coords[index].x = xs[x];
                        coords[index].y = ys[y];
@@ -142,52 +137,52 @@ int ChopImage(int w, int h, rect_t coords[MAX_MD2SKINS])
                        coords[index].name[2] = 0;
                }
        }
-       return(index);
+       return( index );
 }
 
 /*
-===============
-Cmd_Pic
-===============
-*/
+   ===============
+   Cmd_Pic
+   ===============
+ */
 
-void Cmd_Book()
-{
-       int             xl,yl,xh,yh,w,h;
+void Cmd_Book(){
+       int xl,yl,xh,yh,w,h;
        byte            *dest, *source;
-       int                             flags, value, contents;
-       char                    lumpname[64];
-       char                    filename[1024];
-       unsigned long   *destl, *sourcel;
-       int             linedelta, x, y;
-       int                             size;
-       miptex_t                *qtex;
-       miptex32_t              *qtex32;
-       float                   scale_x, scale_y;
-       int                             numrects, i;
-       rect_t                  coords[MAX_MD2SKINS];
-       bookframe_t             bframes[MAX_MD2SKINS];
-       bookframe_t             *bf;
-       book_t                  book;
-
-       GetScriptToken (false);
-       strcpy (lumpname, token);
-       
-       GetScriptToken (false);
-       xl = atoi (token);
-       GetScriptToken (false);
-       yl = atoi (token);
-       GetScriptToken (false);
-       w = atoi (token);
-       GetScriptToken (false);
-       h = atoi (token);
+       int flags, value, contents;
+       char lumpname[64];
+       char filename[1024];
+       unsigned long   *destl, *sourcel;
+       int linedelta, x, y;
+       int size;
+       miptex_t        *qtex;
+       miptex32_t      *qtex32;
+       float scale_x, scale_y;
+       int numrects, i;
+       rect_t coords[MAX_MD2SKINS];
+       bookframe_t bframes[MAX_MD2SKINS];
+       bookframe_t     *bf;
+       book_t book;
+
+       GetScriptToken( false );
+       strcpy( lumpname, token );
+
+       GetScriptToken( false );
+       xl = atoi( token );
+       GetScriptToken( false );
+       yl = atoi( token );
+       GetScriptToken( false );
+       w = atoi( token );
+       GetScriptToken( false );
+       h = atoi( token );
 
        total_x += w;
        total_y += h;
        total_textures++;
 
-       if ( (w & 7) || (h & 7) )
-               Error ("line %i: miptex sizes must be multiples of 8", scriptline);
+       if ( ( w & 7 ) || ( h & 7 ) ) {
+               Error( "line %i: miptex sizes must be multiples of 8", scriptline );
+       }
 
        flags = 0;
        contents = 0;
@@ -195,54 +190,53 @@ void Cmd_Book()
 
        scale_x = scale_y = 0.5;
 
-       if (g_release)
+       if ( g_release ) {
                return;
+       }
 
-       if(TrueColorImage)
-       {
+       if ( TrueColorImage ) {
                xh = xl + w;
                yh = yl + h;
 
-               if (xl >= longimagewidth || xh > longimagewidth ||
-                       yl >= longimageheight || yh > longimageheight)
-               {
-                       Error ("line %i: bad clip dimmensions (%d,%d) (%d,%d) > image (%d,%d)", scriptline, xl,yl,w,h,longimagewidth,longimageheight);
+               if ( xl >= longimagewidth || xh > longimagewidth ||
+                        yl >= longimageheight || yh > longimageheight ) {
+                       Error( "line %i: bad clip dimmensions (%d,%d) (%d,%d) > image (%d,%d)", scriptline, xl,yl,w,h,longimagewidth,longimageheight );
                }
 
-               sourcel = (unsigned long *) longimage + (yl * longimagewidth) + xl;
+               sourcel = (unsigned long *) longimage + ( yl * longimagewidth ) + xl;
                destl = (unsigned long *) longimage;
-               linedelta = (longimagewidth - w);
+               linedelta = ( longimagewidth - w );
 
-               for(y = yl; y < yh; y++)
+               for ( y = yl; y < yh; y++ )
                {
-                       for(x = xl; x < xh; x++)
+                       for ( x = xl; x < xh; x++ )
                        {
-                               *destl++ = *sourcel++;  // RGBA
+                               *destl++ = *sourcel++;  // RGBA
                        }
                        sourcel += linedelta;
                }
 
                // Get rectangles to chop into
-               numrects = ChopImage(w, h, coords);
+               numrects = ChopImage( w, h, coords );
 
                bf = bframes;
-               for(i = 0; i < numrects; i++, bf++)
+               for ( i = 0; i < numrects; i++, bf++ )
                {
                        // Copy section of image to buffer
-                       sourcel = (unsigned long *) longimage + (coords[i].y * w) + coords[i].x;
+                       sourcel = (unsigned long *) longimage + ( coords[i].y * w ) + coords[i].x;
                        destl = bufferl;
                        linedelta = w - coords[i].w;
 
-                       for(y = 0; y < coords[i].h; y++)
+                       for ( y = 0; y < coords[i].h; y++ )
                        {
-                               for(x = 0; x < coords[i].w; x++)
+                               for ( x = 0; x < coords[i].w; x++ )
                                {
                                        *destl++ = *sourcel++;
                                }
                                sourcel += linedelta;
                        }
 
-                       qtex32 = CreateBook32(bufferl, coords[i].w, coords[i].h, &size);
+                       qtex32 = CreateBook32( bufferl, coords[i].w, coords[i].h, &size );
 
                        qtex32->flags = flags;
                        qtex32->contents = contents;
@@ -250,21 +244,21 @@ void Cmd_Book()
                        qtex32->scale_x = scale_x;
                        qtex32->scale_y = scale_y;
 
-                       sprintf (filename, "%sbook/%s/%s_%s.m32", gamedir, book_prefix, lumpname, coords[i].name);
-                       sprintf (qtex32->name, "%s/%s_%s.m32", book_prefix, lumpname, coords[i].name);
+                       sprintf( filename, "%sbook/%s/%s_%s.m32", gamedir, book_prefix, lumpname, coords[i].name );
+                       sprintf( qtex32->name, "%s/%s_%s.m32", book_prefix, lumpname, coords[i].name );
 
-                       strcpy(bf->name, qtex32->name);
+                       strcpy( bf->name, qtex32->name );
                        bf->x = coords[i].x;
                        bf->y = coords[i].y;
                        bf->w = coords[i].w;
                        bf->h = coords[i].h;
-               //
-               // write it out
-               //
-                       printf ("writing %s\n", filename);
-                       SaveFile (filename, (byte *)qtex32, size);
+                       //
+                       // write it out
+                       //
+                       printf( "writing %s\n", filename );
+                       SaveFile( filename, (byte *)qtex32, size );
 
-                       free (qtex32);
+                       free( qtex32 );
                }
        }
        else
@@ -272,20 +266,19 @@ void Cmd_Book()
                xh = xl + w;
                yh = yl + h;
 
-               if (xl >= byteimagewidth || xh > byteimagewidth ||
-                       yl >= byteimageheight || yh > byteimageheight)
-               {
-                       Error ("line %i: bad clip dimmensions (%d,%d) (%d,%d) > image (%d,%d)", scriptline, xl,yl,w,h,byteimagewidth,byteimageheight);
+               if ( xl >= byteimagewidth || xh > byteimagewidth ||
+                        yl >= byteimageheight || yh > byteimageheight ) {
+                       Error( "line %i: bad clip dimmensions (%d,%d) (%d,%d) > image (%d,%d)", scriptline, xl,yl,w,h,byteimagewidth,byteimageheight );
                }
 
                // Copy image to top left
-               source = byteimage + yl*byteimagewidth + xl;
+               source = byteimage + yl * byteimagewidth + xl;
                dest = byteimage;
                linedelta = byteimagewidth - w;
 
-               for(y = yl; y < yh; y++)
+               for ( y = yl; y < yh; y++ )
                {
-                       for(x = xl; x < xh; x++)
+                       for ( x = xl; x < xh; x++ )
                        {
                                *dest++ = *source++;
                        }
@@ -293,80 +286,79 @@ void Cmd_Book()
                }
 
                // Get rectangles to chop into
-               numrects = ChopImage(w, h, coords);
+               numrects = ChopImage( w, h, coords );
 
                bf = bframes;
-               for(i = 0; i < numrects; i++, bf++)
+               for ( i = 0; i < numrects; i++, bf++ )
                {
                        // Copy section of image to buffer
-                       source = byteimage + (coords[i].y * w) + coords[i].x;
+                       source = byteimage + ( coords[i].y * w ) + coords[i].x;
                        dest = buffer;
                        linedelta = w - coords[i].w;
 
-                       for(y = 0; y < coords[i].h; y++)
+                       for ( y = 0; y < coords[i].h; y++ )
                        {
-                               for(x = 0; x < coords[i].w; x++)
+                               for ( x = 0; x < coords[i].w; x++ )
                                {
                                        *dest++ = *source++;
                                }
                                source += linedelta;
                        }
 
-                       qtex = CreateBook8(buffer, coords[i].w, coords[i].h, lbmpalette, &size);
+                       qtex = CreateBook8( buffer, coords[i].w, coords[i].h, lbmpalette, &size );
 
                        qtex->flags = flags;
                        qtex->contents = contents;
                        qtex->value = value;
 
-                       sprintf (filename, "%sbook/%s/%s_%s.m8", gamedir, book_prefix, lumpname, coords[i].name);
-                       sprintf (qtex->name, "%s/%s_%s.m8", book_prefix, lumpname, coords[i].name);
+                       sprintf( filename, "%sbook/%s/%s_%s.m8", gamedir, book_prefix, lumpname, coords[i].name );
+                       sprintf( qtex->name, "%s/%s_%s.m8", book_prefix, lumpname, coords[i].name );
 
-                       strcpy(bf->name, qtex->name);
+                       strcpy( bf->name, qtex->name );
                        bf->x = coords[i].x;
                        bf->y = coords[i].y;
                        bf->w = coords[i].w;
                        bf->h = coords[i].h;
-               //
-               // write it out
-               //
-                       printf ("writing %s\n", filename);
-                       SaveFile (filename, (byte *)qtex, size);
+                       //
+                       // write it out
+                       //
+                       printf( "writing %s\n", filename );
+                       SaveFile( filename, (byte *)qtex, size );
 
-                       free (qtex);
+                       free( qtex );
                }
        }
        // Set up descriptor
-       size = sizeof(bookframe_t) * numrects;
+       size = sizeof( bookframe_t ) * numrects;
 
        book.bheader.ident = IDBOOKHEADER;
        book.bheader.version = BOOK_VERSION;
        book.bheader.num_segments = numrects;
        book.bheader.total_w = w;
        book.bheader.total_h = h;
-       memcpy(book.bframes, bframes, size);
+       memcpy( book.bframes, bframes, size );
 
        // Save out segment descriptor
-       sprintf (filename, "%sBook/%s/%s.bk", gamedir, book_prefix, lumpname);
-       printf ("writing %s\n", filename);
-       SaveFile (filename, (byte *)&book, size + sizeof(bookheader_t));
+       sprintf( filename, "%sBook/%s/%s.bk", gamedir, book_prefix, lumpname );
+       printf( "writing %s\n", filename );
+       SaveFile( filename, (byte *)&book, size + sizeof( bookheader_t ) );
 }
 
 /*
-===============
-Cmd_picdir
-===============
-*/
-void Cmd_Bookdir (void)
-{
-       char    filename[1024];
-
-       GetScriptToken (false);
-       strcpy (book_prefix, token);
+   ===============
+   Cmd_picdir
+   ===============
+ */
+void Cmd_Bookdir( void ){
+       char filename[1024];
+
+       GetScriptToken( false );
+       strcpy( book_prefix, token );
        // create the directory if needed
-       sprintf (filename, "%sBook", gamedir);
-       Q_mkdir (filename); 
-       sprintf (filename, "%sBook/%s", gamedir, book_prefix);
-       Q_mkdir (filename); 
+       sprintf( filename, "%sBook", gamedir );
+       Q_mkdir( filename );
+       sprintf( filename, "%sBook/%s", gamedir, book_prefix );
+       Q_mkdir( filename );
 }
 
 // end