glNewList

create or replace a display list

Signature

glEndList( ( void ) )-> void
glEndList( )
glNewList( GLuint ( list ) , GLenum ( mode ) )-> void
glNewList( list , mode )

Parameters

VariablesDescription
list
Specifies the display-list name.
mode
Specifies the compilation mode, which can be GL_COMPILE or GL_COMPILE_AND_EXECUTE .

Description

Display lists are groups of GL commands that have been stored for subsequent execution. Display lists are created with glNewList . All subsequent commands are placed in the display list, in the order issued, until glEndList is called.
glNewList has two arguments. The first argument, list , is a positive integer that becomes the unique name for the display list. Names can be created and reserved with glGenLists and tested for uniqueness with glIsList . The second argument, mode , is a symbolic constant that can assume one of two values:
GL_COMPILE
Commands are merely compiled.
GL_COMPILE_AND_EXECUTE
Commands are executed as they are compiled into the display list.
Similarly, glTexImage1D , glTexImage2D , and glTexImage3D are executed immediately and not compiled into the display list when their first argument is GL_PROXY_TEXTURE_1D , GL_PROXY_TEXTURE_1D , or GL_PROXY_TEXTURE_3D , respectively.
When the
ARB_imaging
extension is supported, glHistogram executes immediately when its argument is GL_PROXY_HISTOGRAM . Similarly, glColorTable executes immediately when its first argument is GL_PROXY_COLOR_TABLE , GL_PROXY_POST_CONVOLUTION_COLOR_TABLE , or GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE .
For OpenGL versions 1.3 and greater, or when the
ARB_multitexture
extension is supported, glClientActiveTexture is not compiled into display lists, but executed immediately.
When glEndList is encountered, the display-list definition is completed by associating the list with the unique name list (specified in the glNewList command). If a display list with name list already exists, it is replaced only when glEndList is called.

Notes

glCallList and glCallLists can be entered into display lists. Commands in the display list or lists executed by glCallList or glCallLists are not included in the display list being created, even if the list creation mode is GL_COMPILE_AND_EXECUTE .
A display list is just a group of commands and arguments, so errors generated by commands in a display list must be generated when the list is executed. If the list is created in GL_COMPILE mode, errors are not generated until the list is executed.

Errors

GL_INVALID_VALUE is generated if list is 0.
GL_INVALID_ENUM is generated if mode is not an accepted value.
GL_INVALID_OPERATION is generated if glEndList is called without a preceding glNewList , or if glNewList is called while a display list is being defined.
GL_INVALID_OPERATION is generated if glNewList or glEndList is executed between the execution of glBegin and the corresponding execution of glEnd .
GL_OUT_OF_MEMORY is generated if there is insufficient memory to compile the display list. If the GL version is 1.1 or greater, no change is made to the previous contents of the display list, if any, and no other change is made to the GL state. (It is as if no attempt had been made to create the new display list.)

Associated Gets

glGet with argument GL_LIST_INDEX
glGet with argument GL_LIST_MODE

See Also

Sample Code References

The following code samples have been found which appear to reference the functions described here. Take care that the code may be old, broken or not even use PyOpenGL.

glEndList
OpenGLContext OpenGLContext/displaylist.py Lines: 37
OpenGLContext OpenGLContext/scenegraph/text/wxfont.py Lines: 110
OpenGLContext tests/dek_surf.py Lines: 58
OpenGLContext tests/dek_texturesurf.py Lines: 73
OpenGLContext tests/redbook_alpha3D.py Lines: 84, 89
OpenGL-Demo PyOpenGL-Demo/NeHe/lesson12.py Lines: 103, 115
OpenGL-Demo PyOpenGL-Demo/NeHe/lesson43/glFreeType.py Lines: 125, 179
OpenGL-Demo PyOpenGL-Demo/proesch/nurbs/nurbs.py Lines: 48, 191, 197
OpenGL-Demo PyOpenGL-Demo/dek/texturesurf.py Lines: 97
OpenGL-Demo PyOpenGL-Demo/dek/OglSurface/triangle.py Lines: 80, 105
OpenGL-Demo PyOpenGL-Demo/GLUT/gears.py Lines: 239, 245, 251
OpenGL-Demo PyOpenGL-Demo/GLUT/molehill.py Lines: 173
OpenGL-Demo PyOpenGL-Demo/GLUT/tom/lorentz.py Lines: 36
OpenGL-Demo PyOpenGL-Demo/GLUT/tom/text.py Lines: 28
OpenGL-Demo PyOpenGL-Demo/redbook/teapots.py Lines: 96
OpenGL-Demo PyOpenGL-Demo/tom/demo.py Lines: 84
OpenGL-Demo PyOpenGL-Demo/tom/lorentz.py Lines: 46
OpenGL-Demo PyOpenGL-Demo/tom/text.py Lines: 14
{Artistic License} PymmLib pymmlib/mmLib/OpenGLDriver.py Lines: 85
{LGPL} PyUI2 renderers/openglGlut.py Lines: 83
{LGPL} PyUI2 renderers/openglPygame.py Lines: 64, 306
{LGPL} PyUI2 renderers/openglSoya.py Lines: 61
{LGPL} PyUI2 system/openglgraphics.py Lines: 65, 358
{LGPL} VisionEgg VisionEgg/SphereMap.py Lines: 210, 219, 488, 770, 1130, 1168
{LGPL} VisionEgg VisionEgg/Textures.py Lines: 1971
{LGPL} PyMT pymt/obj.py Lines: 21, 126
{LGPL} PyMT pymt/graphx/statement.py Lines: 53, 102
{LGPL} PyMT pymt/lib/squirtle.py Lines: 15, 468
{LGPL} Pyggel pyggel/data.py Lines: 215
{LGPL} pygl2d pygl2d/image.py Lines: 142
{LGPL or GPL or MPL} Kamaelia Code/Python/Kamaelia/Kamaelia/UI/OpenGL/OpenGLComponent.py Lines: 393
{LGPL or GPL or MPL} Kamaelia Sketches/CL/Topology3D/Utils/TopologyViewer3D.py Lines: 323
{LGPL or GPL or MPL} Kamaelia Sketches/CL/Topology3D/THF/Kamaelia/UI/OpenGL/OpenGLComponent.py Lines: 390
{LGPL or GPL or MPL} Kamaelia Sketches/CL/Topology3D/THF/Sketches/playground/Object3D.py Lines: 189
{LGPL or GPL or MPL} Kamaelia Sketches/THF/3D/playground/Object3D.py Lines: 189
{GPL3} OpenGL-Programmable 02-displaylist.py Lines: 84
glNewList
OpenGLContext OpenGLContext/displaylist.py Lines: 30
OpenGLContext OpenGLContext/scenegraph/text/wxfont.py Lines: 92
OpenGLContext tests/dek_surf.py Lines: 55
OpenGLContext tests/dek_texturesurf.py Lines: 71
OpenGLContext tests/redbook_alpha3D.py Lines: 82, 87
OpenGL-Demo PyOpenGL-Demo/NeHe/lesson12.py Lines: 75, 107
OpenGL-Demo PyOpenGL-Demo/proesch/nurbs/nurbs.py Lines: 46, 189, 194
OpenGL-Demo PyOpenGL-Demo/dek/texturesurf.py Lines: 95
OpenGL-Demo PyOpenGL-Demo/dek/OglSurface/triangle.py Lines: 43, 87
OpenGL-Demo PyOpenGL-Demo/GLUT/gears.py Lines: 236, 242, 248
OpenGL-Demo PyOpenGL-Demo/GLUT/molehill.py Lines: 140
OpenGL-Demo PyOpenGL-Demo/GLUT/tom/lorentz.py Lines: 32
OpenGL-Demo PyOpenGL-Demo/GLUT/tom/text.py Lines: 24
OpenGL-Demo PyOpenGL-Demo/redbook/teapots.py Lines: 92
OpenGL-Demo PyOpenGL-Demo/tom/demo.py Lines: 81
OpenGL-Demo PyOpenGL-Demo/tom/lorentz.py Lines: 26
OpenGL-Demo PyOpenGL-Demo/tom/text.py Lines: 11
{Artistic License} PymmLib pymmlib/mmLib/OpenGLDriver.py Lines: 78
{LGPL} PyUI2 renderers/openglGlut.py Lines: 81
{LGPL} PyUI2 renderers/openglPygame.py Lines: 62, 295
{LGPL} PyUI2 renderers/openglSoya.py Lines: 59
{LGPL} PyUI2 system/openglgraphics.py Lines: 59, 347
{LGPL} VisionEgg VisionEgg/SphereMap.py Lines: 198, 212, 444, 724, 1080, 1132
{LGPL} VisionEgg VisionEgg/Textures.py Lines: 1935, 1937
{LGPL} PyMT pymt/obj.py Lines: 21, 124
{LGPL} PyMT pymt/graphx/statement.py Lines: 53, 96
{LGPL} PyMT pymt/lib/squirtle.py Lines: 15, 466
{LGPL} Pyggel pyggel/data.py Lines: 211
{LGPL} pygl2d pygl2d/image.py Lines: 134
{LGPL or GPL or MPL} Kamaelia Code/Python/Kamaelia/Kamaelia/UI/OpenGL/OpenGLComponent.py Lines: 391
{LGPL or GPL or MPL} Kamaelia Sketches/CL/Topology3D/Utils/TopologyViewer3D.py Lines: 321
{LGPL or GPL or MPL} Kamaelia Sketches/CL/Topology3D/THF/Kamaelia/UI/OpenGL/OpenGLComponent.py Lines: 388
{LGPL or GPL or MPL} Kamaelia Sketches/CL/Topology3D/THF/Sketches/playground/Object3D.py Lines: 187
{LGPL or GPL or MPL} Kamaelia Sketches/THF/3D/playground/Object3D.py Lines: 187
{GPL3} OpenGL-Programmable 02-displaylist.py Lines: 82