This makes the function a little simpler by using a special case for the initial "ARB", and just walking the str as a sequence rather than indexing into it.
It also uses a list to join rather than overwritting a str over and over again. Signed-off-by: Dylan Baker <dylanx.c.ba...@intel.com> --- src/mapi/glapi/gen/glX_proto_send.py | 33 +++++++++++++++++++-------------- 1 file changed, 19 insertions(+), 14 deletions(-) diff --git a/src/mapi/glapi/gen/glX_proto_send.py b/src/mapi/glapi/gen/glX_proto_send.py index 5388163..800f7a3 100644 --- a/src/mapi/glapi/gen/glX_proto_send.py +++ b/src/mapi/glapi/gen/glX_proto_send.py @@ -38,20 +38,25 @@ import glX_proto_common import license -def convertStringForXCB(string_): - tmp = "" - special = ["ARB"] - i = 0 - while i < len(string_): - if string_[i:i+3] in special: - tmp = '%s_%s' % (tmp, string_[i:i+3].lower()) - i = i + 2 - elif string_[i].isupper(): - tmp = '%s_%s' % (tmp, string_[i].lower()) +def convert_string_for_xcb(string_): + """Convert an OpenGL name into the form XCB wants. + + This means all lower, with more underscores. + + """ + new = [] + slice_ = 0 + + if string_.startswith('ARB'): + new.append('arb_') + slice_ = 4 + + for c in string_[slice_:]: + if c.isupper(): + new.extend(['_', c.lower()]) else: - tmp = '%s%s' % (tmp, string_[i]) - i += 1 - return tmp + new.append(c) + return ''.join(new) def hash_pixel_function(func): @@ -633,7 +638,7 @@ class PrintGlxProtoStubs(glX_proto_common.glx_print_proto): print ' printf("\\tUsing XCB.\\n");' print ' xcb_connection_t *c = XGetXCBConnection(dpy);' print ' (void) __glXFlushRenderBuffer(gc, gc->pc);' - xcb_name = 'xcb_glx%s' % convertStringForXCB(name) + xcb_name = 'xcb_glx%s' % convert_string_for_xcb(name) iparams = [] extra_iparams = [] -- 2.8.0 _______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/mesa-dev