Allowing pyglet to select the best configuration based on a template is sufficient for most applications, however some complex programs may want to specify their own algorithm for selecting a set of OpenGL attributes.
You can enumerate a screen's configs using the get_matching_configs method. You must supply a template as a minimum specification, but you can supply an "empty" template (one with no attributes set) to get a list of all configurations supported by the screen.
In the following example, all configurations with either an auxilliary buffer or an accumulation buffer are printed:
platform = pyglet.window.get_platform() display = platform.get_default_display() screen = display.get_default_screen() for config in screen.get_matching_configs(gl.Config()): if config.aux_buffers or config.accum_red_size: print config
As well as supporting more complex configuration selection algorithms, enumeration allows you to efficiently find the maximum value of an attribute (for example, the maximum samples per pixel), or present a list of possible configurations to the user.