X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglprint.funcs.t;h=111748e91e3f546c9e189bd70f74971d5f5134a6;hb=HEAD;hp=5f703e1be510ff81272d0765d53530308930923c;hpb=6a5b15f6382ca79e2b5f724585d29b73a40e8194;p=gldbg.git diff --git a/source/glprint.funcs.t b/source/glprint.funcs.t index 5f703e1..111748e 100644 --- a/source/glprint.funcs.t +++ b/source/glprint.funcs.t @@ -1,4 +1,3 @@ -# $Id$ w('static void print_%s(void *user_data', func.name) if ret.ctype!="void": w(', %s ret', ret.ctype) @@ -9,11 +8,19 @@ wl('{') wl(' GlPrintData *gpd = (GlPrintData *)user_data;') w(' snprintf(gpd->buffer, gpd->bufsize, "%s(', func.name) first = True +pname = None for p in params: if not first: w(', ') + if p.name=="pname": + pname = p if p.kind=="value": - w('%s', p.io[1]) + if pname and p.name=="param" and p.base_ctype=="GLint": + w('%%s') + elif p.type=="TextureComponentCount": + w('%%s') + else: + w('%s', p.io[1]) elif p.kind=="reference" and not p.io: w('', p.type) else: @@ -26,8 +33,15 @@ w('"') for p in params+[ret]: if p.ctype!="void": if p.kind=="value": - if len(p.io)>=3 and p.io[2]: - w(', %s(%s, "%s")', p.io[2], p.name, p.type) + if pname and p.name=="param" and p.base_ctype=="GLint": + w(', print_parameter(%s, %s)', pname.name, p.name) + elif p.type=="TextureComponentCount": + w(', print_internal_format(%s)', p.name) + elif len(p.io)>=3 and p.io[2]: + if p.io[2][0]=='(': + w(', %s%s', p.io[2], p.name) + else: + w(', %s(%s, "%s")', p.io[2], p.name, p.type) else: w(', %s', p.name) elif p.kind=="reference" and not p.io: