File: exceptional.py

package info (click to toggle)
pyopengl 3.0.0~b6-3
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 5,696 kB
  • ctags: 26,182
  • sloc: python: 34,233; ansic: 70; sh: 26; makefile: 15
file content (43 lines) | stat: -rw-r--r-- 1,585 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
"""GLE exceptional functions (specialised signatures"""
from OpenGL.raw import GLE as raw
from OpenGL.raw.GLE import annotations as simple

from OpenGL import wrapper, arrays

class _lengthOfArgname( object ):
	"""Calculates the length of a given argname over a divisor value"""
	def __init__( self, arrayName, divisor, arrayType = arrays.GLdoubleArray ):
		self.arrayName = arrayName
		self.divisor = divisor
		self.arrayType = arrayType
	def finalise( self, wrapper ):
		self.arrayIndex = wrapper.pyArgIndex( self.arrayName )
	def __call__( self, pyArgs, index, wrappedOperation ):
		"""Get the length of pyArgs[2], a glDoubleArray"""
		return self.arrayType.arraySize( pyArgs[self.arrayIndex] )//self.divisor
def _baseWrap( base, lengthName='ncp', contourName='contour', divisor=2 ):
	"""Do the basic wrapping operation for a GLE function"""
	return wrapper.wrapper( base ).setPyConverter(
		lengthName,
	).setCConverter(
		lengthName, _lengthOfArgname( contourName, divisor, arrays.GLdoubleArray ),
	)

gleLathe = _baseWrap( simple.gleLathe )
glePolyCone = _baseWrap( simple.glePolyCone, 'npoints', 'point_array', 3)
glePolyCylinder = _baseWrap( simple.glePolyCylinder, 'npoints', 'point_array', 3)
gleScrew = _baseWrap( simple.gleScrew )
gleSpiral = _baseWrap( simple.gleSpiral )

gleExtrusion = _baseWrap( 
	_baseWrap( simple.gleExtrusion ),
	'npoints', 'point_array', 3
)
gleSuperExtrusion = _baseWrap( 
	_baseWrap( simple.gleSuperExtrusion ),
	'npoints', 'point_array', 3
)
gleTwistExtrusion = _baseWrap( 
	_baseWrap( simple.gleTwistExtrusion ),
	'npoints', 'point_array', 3
)