X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgldecoder.c;fp=source%2Fgldecoder.c;h=999acccc9cec140d141f5db97f878af136282cdf;hb=fab9ed5163a8f4ef5314bc67e48d1690d1126649;hp=6444fcaac8515b5054f7ea97a09ce354f6577f1b;hpb=0205804a10fe3beb01ed0135fde052d13b045570;p=gldbg.git diff --git a/source/gldecoder.c b/source/gldecoder.c index 6444fca..999accc 100644 --- a/source/gldecoder.c +++ b/source/gldecoder.c @@ -1,7 +1,7 @@ /* $Id$ This file is part of gldbg -Copyright © 2009 Mikko Rasa, Mikkosoft Productions +Copyright © 2009-2010 Mikko Rasa, Mikkosoft Productions Distributed under the GPL */ @@ -9,17 +9,8 @@ Distributed under the GPL #include #include "functions.h" #include "gldecoder.h" -#include "tmpalloc.h" +#include "packet.h" -typedef struct sGlPacket -{ - const char *ptr; - unsigned chunk; - unsigned total; -} GlPacket; - -static void read_short(short *, GlPacket *); -static void read_int(int *, GlPacket *); static int decode_func(GlDecoder *, unsigned short, GlPacket *); static int decode_gldfunc(GlDecoder *, unsigned short, GlPacket *); @@ -44,158 +35,28 @@ void gldecoder_delete(GlDecoder *dec) int gldecoder_decode(GlDecoder *dec, const char *data, unsigned len) { + GlPacket *pkt; unsigned short func; - GlPacket packet; - - if(lentotal==0) - return; - pkt->chunk = pkt->total; - read_int((int *)&pkt->chunk, pkt); - pkt->chunk &= 0x7FFFFFFF; -} - -static void read_generic(void *v, unsigned size, int byteswap, GlPacket *pkt) -{ - if(pkt->chunk==0) - next_chunk(pkt); - - if(pkt->chunk>=size) - { - // TODO: Actually implement byteswap if needed - (void)byteswap; - memcpy(v, pkt->ptr, size); - pkt->ptr += size; - pkt->chunk -= size; - pkt->total -= size; - } - else - { - memset(v, 0, size); - pkt->total -= pkt->chunk; - pkt->chunk = 0; - } -} - -static void read_char(char *v, GlPacket *pkt) -{ - read_generic(v, 1, 0, pkt); -} - -static void read_short(short *v, GlPacket *pkt) -{ - read_generic(v, sizeof(short), 1, pkt); -} - -static void read_int(int *v, GlPacket *pkt) -{ - read_generic(v, sizeof(int), 1, pkt); -} - -static void read_long(long *v, GlPacket *pkt) -{ - read_generic(v, sizeof(long), 1, pkt); -} - -static void read_long_long(long long *v, GlPacket *pkt) -{ - read_generic(v, sizeof(long long), 1, pkt); -} - -static void read_float(float *v, GlPacket *pkt) -{ - read_generic(v, sizeof(float), 1, pkt); -} - -static void read_double(double *v, GlPacket *pkt) -{ - read_generic(v, sizeof(double), 1, pkt); -} - -typedef const void *pointer; - -static void read_pointer(pointer *v, GlPacket *pkt) -{ - read_generic(v, sizeof(pointer), 1, pkt); -} - -static void read_data(pointer *v, GlPacket *pkt) -{ - int vlen; - read_int(&vlen, pkt); - if(vlen) - *v = pkt->ptr; - else - *v = NULL; - pkt->ptr += vlen; - pkt->chunk -= vlen; - pkt->total -= vlen; -} - -typedef const char *string; - -static void read_string(string *v, GlPacket *pkt) -{ - read_data((pointer *)v, pkt); -} - -static void read_string_array(string **v, GlPacket *pkt) -{ - int count; - int i; - read_int(&count, pkt); - *v = (string *)tmpalloc(count*sizeof(string)); - for(i=0; igldError) dec->gldError(dec->user_data, code); }