2 # (C) Copyright IBM Corporation 2004, 2005
5 # Permission is hereby granted, free of charge, to any person obtaining a
6 # copy of this software and associated documentation files (the "Software"),
7 # to deal in the Software without restriction, including without limitation
8 # on the rights to use, copy, modify, merge, publish, distribute, sub
9 # license, and/or sell copies of the Software, and to permit persons to whom
10 # the Software is furnished to do so, subject to the following conditions:
12 # The above copyright notice and this permission notice (including the next
13 # paragraph) shall be included in all copies or substantial portions of the
16 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 # FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
19 # IBM AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
25 # Ian Romanick <idr@us.ibm.com>
34 class PrintGlProcs(gl_XML
.gl_print_base
):
35 def __init__(self
, es
=False):
36 gl_XML
.gl_print_base
.__init
__(self
)
39 self
.name
= "gl_procs.py (from Mesa)"
40 self
.license
= license
.bsd_license_template
% ( \
41 """Copyright (C) 1999-2001 Brian Paul All Rights Reserved.
42 (C) Copyright IBM Corporation 2004, 2006""", "BRIAN PAUL, IBM")
44 def printRealHeader(self
):
46 /* This file is only included by glapi.c and is used for
47 * the GetProcAddress() function
52 #if defined(NEED_FUNCTION_POINTER) || defined(GLX_INDIRECT_RENDERING)
58 #if !defined(NEED_FUNCTION_POINTER) && !defined(GLX_INDIRECT_RENDERING)
59 # define NAME_FUNC_OFFSET(n,f1,f2,f3,o) { n , o }
60 #elif defined(NEED_FUNCTION_POINTER) && !defined(GLX_INDIRECT_RENDERING)
61 # define NAME_FUNC_OFFSET(n,f1,f2,f3,o) { n , (_glapi_proc) f1 , o }
62 #elif defined(NEED_FUNCTION_POINTER) && defined(GLX_INDIRECT_RENDERING)
63 # define NAME_FUNC_OFFSET(n,f1,f2,f3,o) { n , (_glapi_proc) f2 , o }
64 #elif !defined(NEED_FUNCTION_POINTER) && defined(GLX_INDIRECT_RENDERING)
65 # define NAME_FUNC_OFFSET(n,f1,f2,f3,o) { n , (_glapi_proc) f3 , o }
71 def printRealFooter(self
):
73 print '#undef NAME_FUNC_OFFSET'
76 def printFunctionString(self
, name
):
77 print ' "gl%s\\0"' % (name
)
79 def printBody(self
, api
):
81 print 'static const char gl_string_table[] ='
85 for func
in api
.functionIterateByOffset():
86 name
= func
.dispatch_name()
87 self
.printFunctionString(func
.name
)
88 table
.append((base_offset
, "gl" + name
, "gl" + name
, "NULL", func
.offset
))
90 # The length of the function's name, plus 2 for "gl",
93 base_offset
+= len(func
.name
) + 3
96 for func
in api
.functionIterateByOffset():
97 for n
in func
.entry_points
:
99 name
= func
.dispatch_name()
100 self
.printFunctionString( n
)
102 if func
.has_different_protocol(n
):
103 alt_name
= "gl" + func
.static_glx_name(n
)
104 table
.append((base_offset
, "gl" + name
, alt_name
, alt_name
, func
.offset
))
106 table
.append((base_offset
, "gl" + name
, "gl" + name
, "NULL", func
.offset
))
108 base_offset
+= len(n
) + 3
114 print "#ifdef USE_MGL_NAMESPACE"
115 for func
in api
.functionIterateByOffset():
116 for n
in func
.entry_points
:
117 if (not func
.is_static_entry_point(func
.name
)) or (func
.has_different_protocol(n
) and not func
.is_static_entry_point(n
)):
118 print '#define gl_dispatch_stub_%u mgl_dispatch_stub_%u' % (func
.offset
, func
.offset
)
120 print "#endif /* USE_MGL_NAMESPACE */"
123 print '#if defined(NEED_FUNCTION_POINTER) || defined(GLX_INDIRECT_RENDERING)'
124 for func
in api
.functionIterateByOffset():
125 for n
in func
.entry_points
:
126 if (not func
.is_static_entry_point(func
.name
)) or (func
.has_different_protocol(n
) and not func
.is_static_entry_point(n
)):
127 print '%s GLAPIENTRY gl_dispatch_stub_%u(%s);' % (func
.return_type
, func
.offset
, func
.get_parameter_string())
132 for func
in api
.functionIterateByOffset():
133 for n
in func
.entry_points
:
134 cat
, num
= api
.get_category_for_name(n
)
135 if (cat
.startswith("es") or cat
.startswith("GL_OES")):
136 if not categories
.has_key(cat
):
138 proto
= 'GLAPI %s GLAPIENTRY %s(%s);' \
139 % (func
.return_type
, "gl" + n
, func
.get_parameter_string(n
))
140 categories
[cat
].append(proto
)
143 print '/* OpenGL ES specific prototypes */'
145 keys
= categories
.keys()
148 print '/* category %s */' % key
149 print "\n".join(categories
[key
])
152 print '#endif /* defined(NEED_FUNCTION_POINTER) || defined(GLX_INDIRECT_RENDERING) */'
155 print 'static const glprocs_table_t static_functions[] = {'
158 print ' NAME_FUNC_OFFSET(%5u, %s, %s, %s, %d),' % info
160 print ' NAME_FUNC_OFFSET(-1, NULL, NULL, NULL, 0)'
166 """Parse arguments and return a namepsace."""
168 parser
= argparse
.ArgumentParser()
169 parser
.add_argument('-f', '--filename',
170 default
='gl_API.xml',
171 metavar
="input_file_name",
173 help="Path to an XML description of OpenGL API.")
174 parser
.add_argument('-c', '--es-version',
177 help="filter functions for es")
178 return parser
.parse_args()
184 api
= gl_XML
.parse_GL_API(args
.file_name
, glX_XML
.glx_item_factory())
185 PrintGlProcs(args
.es
).Print(api
)
188 if __name__
== '__main__':