From 2db54798d7ab1330f3a19914984f7d07e0c3341b Mon Sep 17 00:00:00 2001 From: Soren Jorvang Date: Tue, 15 Jun 2010 23:31:13 +0000 Subject: [PATCH] Import SDL 1.2.14 and GLEW 1.5.4. I am not replacing the following header files used by the Windows build, as I don't have a Windows build setup to test. Please point the Windows build at the header files inside these clean distribution packages and garbage collect the duplicates: GLew/*.h and SDL/Include_1.2. git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@5711 8ced0084-cf51-0410-be5f-012b33b47a6e --- Externals/GLew/LICENSE.txt | 73 + Externals/GLew/Makefile | 268 + Externals/GLew/README.txt | 18 + Externals/GLew/TODO.txt | 12 + Externals/GLew/auto/Makefile | 371 + .../GLew/auto/bin/fix_OML_sync_control.sh | 18 + Externals/GLew/auto/bin/make.pl | 188 + Externals/GLew/auto/bin/make_def_fun.pl | 35 + Externals/GLew/auto/bin/make_def_var.pl | 31 + Externals/GLew/auto/bin/make_header.pl | 71 + Externals/GLew/auto/bin/make_html.pl | 55 + Externals/GLew/auto/bin/make_info.pl | 59 + Externals/GLew/auto/bin/make_info_list.pl | 47 + Externals/GLew/auto/bin/make_init.pl | 55 + Externals/GLew/auto/bin/make_list.pl | 66 + Externals/GLew/auto/bin/make_str.pl | 53 + Externals/GLew/auto/bin/make_struct_fun.pl | 36 + Externals/GLew/auto/bin/make_struct_var.pl | 31 + Externals/GLew/auto/bin/parse_spec.pl | 335 + Externals/GLew/auto/bin/update_ext.sh | 280 + Externals/GLew/auto/bin/update_registry.sh | 24 + Externals/GLew/auto/blacklist | 15 + .../GLew/auto/core/GLX_ARB_get_proc_address | 4 + .../GLew/auto/core/GLX_ATI_pixel_format_float | 4 + .../GLew/auto/core/GLX_ATI_render_texture | 41 + .../auto/core/GLX_EXT_fbconfig_packed_float | 5 + .../GLew/auto/core/GLX_EXT_framebuffer_sRGB | 4 + Externals/GLew/auto/core/GLX_NV_float_buffer | 4 + .../GLew/auto/core/GLX_NV_vertex_array_range | 5 + .../auto/core/GLX_SGIS_shared_multisample | 5 + Externals/GLew/auto/core/GLX_SGIX_hyperpipe | 25 + .../GLew/auto/core/GLX_SGIX_swap_barrier | 5 + Externals/GLew/auto/core/GLX_SGIX_swap_group | 4 + Externals/GLew/auto/core/GLX_SUN_video_resize | 7 + Externals/GLew/auto/core/GLX_VERSION_1_2 | 4 + Externals/GLew/auto/core/GLX_VERSION_1_3 | 82 + Externals/GLew/auto/core/GLX_VERSION_1_4 | 6 + .../GLew/auto/core/GL_APPLE_float_pixels | 17 + .../GLew/auto/core/GL_APPLE_pixel_buffer | 4 + .../GLew/auto/core/GL_APPLE_texture_range | 12 + Externals/GLew/auto/core/GL_ARB_imaging | 112 + .../GLew/auto/core/GL_ARB_matrix_palette | 18 + Externals/GLew/auto/core/GL_ARB_multitexture | 72 + Externals/GLew/auto/core/GL_ARB_vertex_blend | 55 + .../GLew/auto/core/GL_ATIX_point_sprites | 9 + .../auto/core/GL_ATIX_texture_env_combine3 | 6 + .../GLew/auto/core/GL_ATIX_texture_env_route | 6 + .../GL_ATIX_vertex_shader_output_point_size | 4 + .../GLew/auto/core/GL_ATI_envmap_bumpmap | 15 + .../GLew/auto/core/GL_ATI_map_object_buffer | 5 + Externals/GLew/auto/core/GL_ATI_pn_triangles | 14 + .../GLew/auto/core/GL_ATI_separate_stencil | 9 + .../GLew/auto/core/GL_ATI_shader_texture_lod | 3 + .../auto/core/GL_ATI_texture_compression_3dc | 4 + .../GLew/auto/core/GL_ATI_vertex_streams | 50 + Externals/GLew/auto/core/GL_EXT_Cg_shader | 5 + .../GLew/auto/core/GL_EXT_bindable_uniform | 12 + .../GLew/auto/core/GL_EXT_depth_bounds_test | 6 + .../GLew/auto/core/GL_EXT_draw_instanced | 5 + .../GLew/auto/core/GL_EXT_draw_range_elements | 6 + Externals/GLew/auto/core/GL_EXT_fog_coord | 16 + .../GLew/auto/core/GL_EXT_framebuffer_sRGB | 5 + .../GLew/auto/core/GL_EXT_geometry_shader4 | 27 + .../auto/core/GL_EXT_gpu_program_parameters | 5 + Externals/GLew/auto/core/GL_EXT_gpu_shader4 | 63 + Externals/GLew/auto/core/GL_EXT_packed_float | 6 + .../GLew/auto/core/GL_EXT_pixel_buffer_object | 7 + .../GLew/auto/core/GL_EXT_secondary_color | 27 + Externals/GLew/auto/core/GL_EXT_texture_array | 11 + .../auto/core/GL_EXT_texture_buffer_object | 9 + .../auto/core/GL_EXT_texture_compression_latc | 7 + .../auto/core/GL_EXT_texture_compression_rgtc | 7 + .../GLew/auto/core/GL_EXT_texture_cube_map | 15 + .../GLew/auto/core/GL_EXT_texture_edge_clamp | 4 + .../GLew/auto/core/GL_EXT_texture_integer | 56 + .../GLew/auto/core/GL_EXT_texture_rectangle | 7 + .../auto/core/GL_EXT_texture_shared_exponent | 6 + Externals/GLew/auto/core/GL_EXT_timer_query | 6 + Externals/GLew/auto/core/GL_EXT_vertex_shader | 156 + Externals/GLew/auto/core/GL_KTX_buffer_region | 12 + .../GLew/auto/core/GL_NV_depth_buffer_float | 10 + .../auto/core/GL_NV_depth_range_unclamped | 8 + .../GLew/auto/core/GL_NV_fragment_program2 | 8 + .../GLew/auto/core/GL_NV_fragment_program4 | 3 + .../auto/core/GL_NV_fragment_program_option | 3 + .../GL_NV_framebuffer_multisample_coverage | 8 + .../GLew/auto/core/GL_NV_geometry_program4 | 7 + .../GLew/auto/core/GL_NV_geometry_shader4 | 3 + Externals/GLew/auto/core/GL_NV_gpu_program4 | 23 + .../auto/core/GL_NV_parameter_buffer_object | 11 + Externals/GLew/auto/core/GL_NV_present_video | 15 + .../auto/core/GL_NV_tessellation_program5 | 8 + .../GLew/auto/core/GL_NV_transform_feedback | 39 + .../auto/core/GL_NV_vertex_program2_option | 5 + .../GLew/auto/core/GL_NV_vertex_program3 | 4 + .../GLew/auto/core/GL_NV_vertex_program4 | 3 + Externals/GLew/auto/core/GL_SGIX_shadow | 7 + .../GLew/auto/core/GL_SUN_read_video_pixels | 4 + Externals/GLew/auto/core/GL_VERSION_1_2 | 48 + Externals/GLew/auto/core/GL_VERSION_1_3 | 146 + Externals/GLew/auto/core/GL_VERSION_1_4 | 89 + Externals/GLew/auto/core/GL_VERSION_1_5 | 74 + Externals/GLew/auto/core/GL_VERSION_2_0 | 181 + Externals/GLew/auto/core/GL_VERSION_2_1 | 32 + Externals/GLew/auto/core/GL_VERSION_3_0 | 166 + Externals/GLew/auto/core/GL_VERSION_3_1 | 41 + Externals/GLew/auto/core/GL_VERSION_3_2 | 28 + Externals/GLew/auto/core/GL_VERSION_3_3 | 11 + Externals/GLew/auto/core/GL_VERSION_4_0 | 25 + Externals/GLew/auto/core/GL_WIN_swap_hint | 4 + .../core/WGL_ATI_render_texture_rectangle | 4 + .../GLew/auto/core/WGL_EXT_framebuffer_sRGB | 4 + .../core/WGL_EXT_pixel_format_packed_float | 4 + Externals/GLew/auto/core/WGL_NV_gpu_affinity | 12 + .../GLew/auto/core/WGL_NV_vertex_array_range | 5 + Externals/GLew/auto/custom.txt | 7 + Externals/GLew/auto/doc/advanced.html | 176 + Externals/GLew/auto/doc/basic.html | 180 + Externals/GLew/auto/doc/credits.html | 25 + Externals/GLew/auto/doc/index.html | 100 + Externals/GLew/auto/doc/install.html | 126 + Externals/GLew/auto/doc/log.html | 602 + Externals/GLew/auto/extensions/.dummy | 0 .../GLew/auto/extensions/GLX_3DFX_multisample | 5 + .../auto/extensions/GLX_ARB_create_context | 9 + .../extensions/GLX_ARB_create_context_profile | 6 + .../auto/extensions/GLX_ARB_fbconfig_float | 5 + .../auto/extensions/GLX_ARB_framebuffer_sRGB | 4 + .../auto/extensions/GLX_ARB_get_proc_address | 4 + .../GLew/auto/extensions/GLX_ARB_multisample | 5 + .../extensions/GLX_ARB_vertex_buffer_object | 4 + .../extensions/GLX_ATI_pixel_format_float | 4 + .../auto/extensions/GLX_ATI_render_texture | 41 + .../extensions/GLX_EXT_fbconfig_packed_float | 5 + .../auto/extensions/GLX_EXT_framebuffer_sRGB | 4 + .../auto/extensions/GLX_EXT_import_context | 11 + .../GLew/auto/extensions/GLX_EXT_scene_marker | 3 + .../GLew/auto/extensions/GLX_EXT_swap_control | 6 + .../extensions/GLX_EXT_texture_from_pixmap | 36 + .../GLew/auto/extensions/GLX_EXT_visual_info | 19 + .../auto/extensions/GLX_EXT_visual_rating | 6 + .../GLew/auto/extensions/GLX_INTEL_swap_event | 7 + .../GLew/auto/extensions/GLX_MESA_agp_offset | 4 + .../auto/extensions/GLX_MESA_copy_sub_buffer | 4 + .../auto/extensions/GLX_MESA_pixmap_colormap | 4 + .../auto/extensions/GLX_MESA_release_buffers | 4 + .../auto/extensions/GLX_MESA_set_3dfx_mode | 6 + .../GLew/auto/extensions/GLX_NV_copy_image | 4 + .../GLew/auto/extensions/GLX_NV_float_buffer | 4 + .../GLew/auto/extensions/GLX_NV_present_video | 6 + .../GLew/auto/extensions/GLX_NV_swap_group | 9 + .../auto/extensions/GLX_NV_vertex_array_range | 5 + .../GLew/auto/extensions/GLX_NV_video_output | 19 + .../GLew/auto/extensions/GLX_OML_swap_method | 7 + .../GLew/auto/extensions/GLX_OML_sync_control | 8 + .../auto/extensions/GLX_SGIS_blended_overlay | 4 + .../GLew/auto/extensions/GLX_SGIS_color_range | 12 + .../GLew/auto/extensions/GLX_SGIS_multisample | 5 + .../extensions/GLX_SGIS_shared_multisample | 5 + .../GLew/auto/extensions/GLX_SGIX_fbconfig | 22 + .../GLew/auto/extensions/GLX_SGIX_hyperpipe | 25 + .../GLew/auto/extensions/GLX_SGIX_pbuffer | 35 + .../auto/extensions/GLX_SGIX_swap_barrier | 5 + .../GLew/auto/extensions/GLX_SGIX_swap_group | 4 + .../auto/extensions/GLX_SGIX_video_resize | 10 + .../extensions/GLX_SGIX_visual_select_group | 4 + .../GLew/auto/extensions/GLX_SGI_cushion | 4 + .../auto/extensions/GLX_SGI_make_current_read | 5 + .../GLew/auto/extensions/GLX_SGI_swap_control | 4 + .../GLew/auto/extensions/GLX_SGI_video_sync | 5 + .../extensions/GLX_SUN_get_transparent_index | 4 + .../GLew/auto/extensions/GLX_SUN_video_resize | 7 + .../GLew/auto/extensions/GL_3DFX_multisample | 7 + .../GLew/auto/extensions/GL_3DFX_tbuffer | 4 + .../GL_3DFX_texture_compression_FXT1 | 5 + .../auto/extensions/GL_AMD_conservative_depth | 3 + .../auto/extensions/GL_AMD_draw_buffers_blend | 7 + .../extensions/GL_AMD_performance_monitor | 23 + .../GL_AMD_seamless_cubemap_per_texture | 4 + .../extensions/GL_AMD_shader_stencil_export | 3 + .../auto/extensions/GL_AMD_texture_texture4 | 3 + .../GL_AMD_vertex_shader_tessellator | 12 + .../extensions/GL_APPLE_aux_depth_stencil | 4 + .../auto/extensions/GL_APPLE_client_storage | 4 + .../auto/extensions/GL_APPLE_element_array | 11 + Externals/GLew/auto/extensions/GL_APPLE_fence | 13 + .../auto/extensions/GL_APPLE_float_pixels | 17 + .../extensions/GL_APPLE_flush_buffer_range | 7 + .../auto/extensions/GL_APPLE_object_purgeable | 12 + .../auto/extensions/GL_APPLE_pixel_buffer | 4 + .../GLew/auto/extensions/GL_APPLE_rgb_422 | 6 + .../GLew/auto/extensions/GL_APPLE_row_bytes | 5 + .../auto/extensions/GL_APPLE_specular_vector | 4 + .../auto/extensions/GL_APPLE_texture_range | 12 + .../auto/extensions/GL_APPLE_transform_hint | 4 + .../extensions/GL_APPLE_vertex_array_object | 8 + .../extensions/GL_APPLE_vertex_array_range | 14 + .../GL_APPLE_vertex_program_evaluators | 20 + .../GLew/auto/extensions/GL_APPLE_ycbcr_422 | 6 + .../extensions/GL_ARB_blend_func_extended | 9 + .../auto/extensions/GL_ARB_color_buffer_float | 9 + .../GLew/auto/extensions/GL_ARB_compatibility | 3 + .../GLew/auto/extensions/GL_ARB_copy_buffer | 6 + .../auto/extensions/GL_ARB_depth_buffer_float | 6 + .../GLew/auto/extensions/GL_ARB_depth_clamp | 4 + .../GLew/auto/extensions/GL_ARB_depth_texture | 8 + .../GLew/auto/extensions/GL_ARB_draw_buffers | 21 + .../auto/extensions/GL_ARB_draw_buffers_blend | 7 + .../GL_ARB_draw_elements_base_vertex | 7 + .../GLew/auto/extensions/GL_ARB_draw_indirect | 7 + .../auto/extensions/GL_ARB_draw_instanced | 5 + .../GL_ARB_explicit_attrib_location | 3 + .../GL_ARB_fragment_coord_conventions | 3 + .../auto/extensions/GL_ARB_fragment_program | 18 + .../extensions/GL_ARB_fragment_program_shadow | 3 + .../auto/extensions/GL_ARB_fragment_shader | 6 + .../auto/extensions/GL_ARB_framebuffer_object | 97 + .../auto/extensions/GL_ARB_framebuffer_sRGB | 4 + .../auto/extensions/GL_ARB_geometry_shader4 | 26 + .../GLew/auto/extensions/GL_ARB_gpu_shader5 | 9 + .../auto/extensions/GL_ARB_gpu_shader_fp64 | 3 + .../auto/extensions/GL_ARB_half_float_pixel | 4 + .../auto/extensions/GL_ARB_half_float_vertex | 4 + Externals/GLew/auto/extensions/GL_ARB_imaging | 112 + .../auto/extensions/GL_ARB_instanced_arrays | 5 + .../auto/extensions/GL_ARB_map_buffer_range | 11 + .../auto/extensions/GL_ARB_matrix_palette | 18 + .../GLew/auto/extensions/GL_ARB_multisample | 13 + .../GLew/auto/extensions/GL_ARB_multitexture | 72 + .../auto/extensions/GL_ARB_occlusion_query | 16 + .../auto/extensions/GL_ARB_occlusion_query2 | 4 + .../extensions/GL_ARB_pixel_buffer_object | 7 + .../auto/extensions/GL_ARB_point_parameters | 9 + .../GLew/auto/extensions/GL_ARB_point_sprite | 5 + .../auto/extensions/GL_ARB_provoking_vertex | 8 + .../auto/extensions/GL_ARB_sample_shading | 6 + .../auto/extensions/GL_ARB_sampler_objects | 18 + .../auto/extensions/GL_ARB_seamless_cube_map | 4 + .../extensions/GL_ARB_shader_bit_encoding | 3 + .../auto/extensions/GL_ARB_shader_objects | 78 + .../auto/extensions/GL_ARB_shader_subroutine | 20 + .../auto/extensions/GL_ARB_shader_texture_lod | 3 + .../extensions/GL_ARB_shading_language_100 | 4 + .../GL_ARB_shading_language_include | 12 + Externals/GLew/auto/extensions/GL_ARB_shadow | 6 + .../auto/extensions/GL_ARB_shadow_ambient | 4 + Externals/GLew/auto/extensions/GL_ARB_sync | 25 + .../extensions/GL_ARB_tessellation_shader | 37 + .../extensions/GL_ARB_texture_border_clamp | 4 + .../extensions/GL_ARB_texture_buffer_object | 9 + .../GL_ARB_texture_buffer_object_rgb32 | 3 + .../extensions/GL_ARB_texture_compression | 21 + .../GL_ARB_texture_compression_bptc | 7 + .../GL_ARB_texture_compression_rgtc | 7 + .../auto/extensions/GL_ARB_texture_cube_map | 15 + .../extensions/GL_ARB_texture_cube_map_array | 10 + .../auto/extensions/GL_ARB_texture_env_add | 3 + .../extensions/GL_ARB_texture_env_combine | 25 + .../extensions/GL_ARB_texture_env_crossbar | 3 + .../auto/extensions/GL_ARB_texture_env_dot3 | 5 + .../GLew/auto/extensions/GL_ARB_texture_float | 23 + .../auto/extensions/GL_ARB_texture_gather | 6 + .../extensions/GL_ARB_texture_mirrored_repeat | 4 + .../extensions/GL_ARB_texture_multisample | 28 + .../GL_ARB_texture_non_power_of_two | 3 + .../auto/extensions/GL_ARB_texture_query_lod | 3 + .../auto/extensions/GL_ARB_texture_rectangle | 9 + .../GLew/auto/extensions/GL_ARB_texture_rg | 28 + .../auto/extensions/GL_ARB_texture_rgb10_a2ui | 4 + .../auto/extensions/GL_ARB_texture_swizzle | 8 + .../GLew/auto/extensions/GL_ARB_timer_query | 8 + .../extensions/GL_ARB_transform_feedback2 | 14 + .../extensions/GL_ARB_transform_feedback3 | 9 + .../auto/extensions/GL_ARB_transpose_matrix | 11 + .../extensions/GL_ARB_uniform_buffer_object | 46 + .../auto/extensions/GL_ARB_vertex_array_bgra | 4 + .../extensions/GL_ARB_vertex_array_object | 8 + .../GLew/auto/extensions/GL_ARB_vertex_blend | 55 + .../extensions/GL_ARB_vertex_buffer_object | 47 + .../auto/extensions/GL_ARB_vertex_program | 144 + .../GLew/auto/extensions/GL_ARB_vertex_shader | 13 + .../GL_ARB_vertex_type_2_10_10_10_rev | 43 + .../GLew/auto/extensions/GL_ARB_window_pos | 19 + .../auto/extensions/GL_ATIX_point_sprites | 9 + .../extensions/GL_ATIX_texture_env_combine3 | 6 + .../auto/extensions/GL_ATIX_texture_env_route | 6 + .../GL_ATIX_vertex_shader_output_point_size | 4 + .../GLew/auto/extensions/GL_ATI_draw_buffers | 21 + .../GLew/auto/extensions/GL_ATI_element_array | 9 + .../auto/extensions/GL_ATI_envmap_bumpmap | 15 + .../auto/extensions/GL_ATI_fragment_shader | 71 + .../auto/extensions/GL_ATI_map_object_buffer | 5 + Externals/GLew/auto/extensions/GL_ATI_meminfo | 6 + .../GLew/auto/extensions/GL_ATI_pn_triangles | 14 + .../auto/extensions/GL_ATI_separate_stencil | 9 + .../auto/extensions/GL_ATI_shader_texture_lod | 3 + .../extensions/GL_ATI_text_fragment_shader | 4 + .../extensions/GL_ATI_texture_compression_3dc | 4 + .../extensions/GL_ATI_texture_env_combine3 | 6 + .../GLew/auto/extensions/GL_ATI_texture_float | 15 + .../extensions/GL_ATI_texture_mirror_once | 5 + .../extensions/GL_ATI_vertex_array_object | 23 + .../GL_ATI_vertex_attrib_array_object | 6 + .../auto/extensions/GL_ATI_vertex_streams | 50 + .../GLew/auto/extensions/GL_EXT_422_pixels | 7 + .../GLew/auto/extensions/GL_EXT_Cg_shader | 5 + Externals/GLew/auto/extensions/GL_EXT_abgr | 4 + Externals/GLew/auto/extensions/GL_EXT_bgra | 5 + .../auto/extensions/GL_EXT_bindable_uniform | 12 + .../GLew/auto/extensions/GL_EXT_blend_color | 9 + .../extensions/GL_EXT_blend_equation_separate | 6 + .../extensions/GL_EXT_blend_func_separate | 8 + .../auto/extensions/GL_EXT_blend_logic_op | 3 + .../GLew/auto/extensions/GL_EXT_blend_minmax | 8 + .../auto/extensions/GL_EXT_blend_subtract | 5 + .../auto/extensions/GL_EXT_clip_volume_hint | 4 + Externals/GLew/auto/extensions/GL_EXT_cmyka | 7 + .../auto/extensions/GL_EXT_color_subtable | 5 + .../extensions/GL_EXT_compiled_vertex_array | 7 + .../GLew/auto/extensions/GL_EXT_convolution | 36 + .../auto/extensions/GL_EXT_coordinate_frame | 19 + .../GLew/auto/extensions/GL_EXT_copy_texture | 8 + .../GLew/auto/extensions/GL_EXT_cull_vertex | 8 + .../auto/extensions/GL_EXT_depth_bounds_test | 6 + .../extensions/GL_EXT_direct_state_access | 219 + .../GLew/auto/extensions/GL_EXT_draw_buffers2 | 9 + .../auto/extensions/GL_EXT_draw_instanced | 5 + .../extensions/GL_EXT_draw_range_elements | 6 + .../GLew/auto/extensions/GL_EXT_fog_coord | 16 + .../auto/extensions/GL_EXT_fragment_lighting | 35 + .../auto/extensions/GL_EXT_framebuffer_blit | 8 + .../extensions/GL_EXT_framebuffer_multisample | 9 + .../auto/extensions/GL_EXT_framebuffer_object | 71 + .../auto/extensions/GL_EXT_framebuffer_sRGB | 5 + .../auto/extensions/GL_EXT_geometry_shader4 | 27 + .../extensions/GL_EXT_gpu_program_parameters | 5 + .../GLew/auto/extensions/GL_EXT_gpu_shader4 | 63 + .../GLew/auto/extensions/GL_EXT_histogram | 26 + .../extensions/GL_EXT_index_array_formats | 3 + .../GLew/auto/extensions/GL_EXT_index_func | 4 + .../auto/extensions/GL_EXT_index_material | 4 + .../GLew/auto/extensions/GL_EXT_index_texture | 3 + .../GLew/auto/extensions/GL_EXT_light_texture | 16 + .../auto/extensions/GL_EXT_misc_attribute | 3 + .../auto/extensions/GL_EXT_multi_draw_arrays | 5 + .../GLew/auto/extensions/GL_EXT_multisample | 22 + .../extensions/GL_EXT_packed_depth_stencil | 7 + .../GLew/auto/extensions/GL_EXT_packed_float | 6 + .../GLew/auto/extensions/GL_EXT_packed_pixels | 8 + .../auto/extensions/GL_EXT_paletted_texture | 30 + .../extensions/GL_EXT_pixel_buffer_object | 7 + .../auto/extensions/GL_EXT_pixel_transform | 18 + .../GL_EXT_pixel_transform_color_table | 3 + .../auto/extensions/GL_EXT_point_parameters | 9 + .../auto/extensions/GL_EXT_polygon_offset | 7 + .../auto/extensions/GL_EXT_provoking_vertex | 8 + .../auto/extensions/GL_EXT_rescale_normal | 4 + .../GLew/auto/extensions/GL_EXT_scene_marker | 5 + .../auto/extensions/GL_EXT_secondary_color | 27 + .../extensions/GL_EXT_separate_shader_objects | 7 + .../extensions/GL_EXT_separate_specular_color | 6 + .../extensions/GL_EXT_shader_image_load_store | 60 + .../GLew/auto/extensions/GL_EXT_shadow_funcs | 3 + .../extensions/GL_EXT_shared_texture_palette | 4 + .../auto/extensions/GL_EXT_stencil_clear_tag | 5 + .../auto/extensions/GL_EXT_stencil_two_side | 6 + .../GLew/auto/extensions/GL_EXT_stencil_wrap | 5 + .../GLew/auto/extensions/GL_EXT_subtexture | 6 + Externals/GLew/auto/extensions/GL_EXT_texture | 45 + .../GLew/auto/extensions/GL_EXT_texture3D | 13 + .../GLew/auto/extensions/GL_EXT_texture_array | 11 + .../extensions/GL_EXT_texture_buffer_object | 9 + .../GL_EXT_texture_compression_dxt1 | 5 + .../GL_EXT_texture_compression_latc | 7 + .../GL_EXT_texture_compression_rgtc | 7 + .../GL_EXT_texture_compression_s3tc | 7 + .../auto/extensions/GL_EXT_texture_cube_map | 15 + .../auto/extensions/GL_EXT_texture_edge_clamp | 4 + .../GLew/auto/extensions/GL_EXT_texture_env | 14 + .../auto/extensions/GL_EXT_texture_env_add | 3 + .../extensions/GL_EXT_texture_env_combine | 24 + .../auto/extensions/GL_EXT_texture_env_dot3 | 5 + .../GL_EXT_texture_filter_anisotropic | 5 + .../auto/extensions/GL_EXT_texture_integer | 56 + .../auto/extensions/GL_EXT_texture_lod_bias | 6 + .../extensions/GL_EXT_texture_mirror_clamp | 6 + .../auto/extensions/GL_EXT_texture_object | 14 + .../extensions/GL_EXT_texture_perturb_normal | 6 + .../auto/extensions/GL_EXT_texture_rectangle | 7 + .../GLew/auto/extensions/GL_EXT_texture_sRGB | 19 + .../extensions/GL_EXT_texture_shared_exponent | 6 + .../GLew/auto/extensions/GL_EXT_texture_snorm | 28 + .../auto/extensions/GL_EXT_texture_swizzle | 8 + .../GLew/auto/extensions/GL_EXT_timer_query | 6 + .../auto/extensions/GL_EXT_transform_feedback | 25 + .../GLew/auto/extensions/GL_EXT_vertex_array | 45 + .../auto/extensions/GL_EXT_vertex_array_bgra | 4 + .../extensions/GL_EXT_vertex_attrib_64bit | 20 + .../GLew/auto/extensions/GL_EXT_vertex_shader | 156 + .../auto/extensions/GL_EXT_vertex_weighting | 19 + .../extensions/GL_GREMEDY_frame_terminator | 4 + .../auto/extensions/GL_GREMEDY_string_marker | 4 + .../extensions/GL_HP_convolution_border_modes | 3 + .../auto/extensions/GL_HP_image_transform | 9 + .../GLew/auto/extensions/GL_HP_occlusion_test | 5 + .../auto/extensions/GL_HP_texture_lighting | 3 + .../GLew/auto/extensions/GL_IBM_cull_vertex | 4 + .../extensions/GL_IBM_multimode_draw_arrays | 5 + .../auto/extensions/GL_IBM_rasterpos_clip | 4 + .../GLew/auto/extensions/GL_IBM_static_data | 5 + .../extensions/GL_IBM_texture_mirrored_repeat | 4 + .../auto/extensions/GL_IBM_vertex_array_lists | 27 + .../GLew/auto/extensions/GL_INGR_color_clamp | 11 + .../auto/extensions/GL_INGR_interlace_read | 4 + .../auto/extensions/GL_INTEL_parallel_arrays | 12 + .../auto/extensions/GL_INTEL_texture_scissor | 5 + .../GLew/auto/extensions/GL_KTX_buffer_region | 12 + .../auto/extensions/GL_MESAX_texture_stack | 9 + .../GLew/auto/extensions/GL_MESA_pack_invert | 4 + .../auto/extensions/GL_MESA_resize_buffers | 4 + .../GLew/auto/extensions/GL_MESA_window_pos | 27 + .../auto/extensions/GL_MESA_ycbcr_texture | 6 + .../GLew/auto/extensions/GL_NV_blend_square | 3 + .../auto/extensions/GL_NV_conditional_render | 9 + .../auto/extensions/GL_NV_copy_depth_to_color | 5 + .../GLew/auto/extensions/GL_NV_copy_image | 4 + .../auto/extensions/GL_NV_depth_buffer_float | 10 + .../GLew/auto/extensions/GL_NV_depth_clamp | 4 + .../extensions/GL_NV_depth_range_unclamped | 8 + .../GLew/auto/extensions/GL_NV_evaluators | 36 + .../extensions/GL_NV_explicit_multisample | 16 + Externals/GLew/auto/extensions/GL_NV_fence | 13 + .../GLew/auto/extensions/GL_NV_float_buffer | 18 + .../GLew/auto/extensions/GL_NV_fog_distance | 6 + .../auto/extensions/GL_NV_fragment_program | 15 + .../auto/extensions/GL_NV_fragment_program2 | 8 + .../auto/extensions/GL_NV_fragment_program4 | 3 + .../extensions/GL_NV_fragment_program_option | 3 + .../GL_NV_framebuffer_multisample_coverage | 8 + .../auto/extensions/GL_NV_geometry_program4 | 7 + .../auto/extensions/GL_NV_geometry_shader4 | 3 + .../GLew/auto/extensions/GL_NV_gpu_program4 | 23 + .../GLew/auto/extensions/GL_NV_gpu_program5 | 7 + .../auto/extensions/GL_NV_gpu_program_fp64 | 3 + .../GLew/auto/extensions/GL_NV_gpu_shader5 | 65 + .../GLew/auto/extensions/GL_NV_half_float | 51 + .../auto/extensions/GL_NV_light_max_exponent | 5 + .../extensions/GL_NV_multisample_filter_hint | 4 + .../auto/extensions/GL_NV_occlusion_query | 14 + .../extensions/GL_NV_packed_depth_stencil | 5 + .../extensions/GL_NV_parameter_buffer_object | 11 + .../extensions/GL_NV_parameter_buffer_object2 | 3 + .../auto/extensions/GL_NV_pixel_data_range | 11 + .../GLew/auto/extensions/GL_NV_point_sprite | 8 + .../GLew/auto/extensions/GL_NV_present_video | 15 + .../auto/extensions/GL_NV_primitive_restart | 7 + .../auto/extensions/GL_NV_register_combiners | 67 + .../auto/extensions/GL_NV_register_combiners2 | 6 + .../auto/extensions/GL_NV_shader_buffer_load | 19 + .../extensions/GL_NV_tessellation_program5 | 8 + .../GLew/auto/extensions/GL_NV_texgen_emboss | 6 + .../auto/extensions/GL_NV_texgen_reflection | 5 + .../auto/extensions/GL_NV_texture_barrier | 4 + .../extensions/GL_NV_texture_compression_vtc | 3 + .../extensions/GL_NV_texture_env_combine4 | 8 + .../extensions/GL_NV_texture_expand_normal | 4 + .../auto/extensions/GL_NV_texture_rectangle | 7 + .../GLew/auto/extensions/GL_NV_texture_shader | 76 + .../auto/extensions/GL_NV_texture_shader2 | 31 + .../auto/extensions/GL_NV_texture_shader3 | 20 + .../auto/extensions/GL_NV_transform_feedback | 39 + .../auto/extensions/GL_NV_transform_feedback2 | 14 + .../auto/extensions/GL_NV_vertex_array_range | 10 + .../auto/extensions/GL_NV_vertex_array_range2 | 4 + .../GL_NV_vertex_attrib_integer_64bit | 24 + .../GL_NV_vertex_buffer_unified_memory | 37 + .../GLew/auto/extensions/GL_NV_vertex_program | 150 + .../auto/extensions/GL_NV_vertex_program1_1 | 3 + .../auto/extensions/GL_NV_vertex_program2 | 3 + .../extensions/GL_NV_vertex_program2_option | 5 + .../auto/extensions/GL_NV_vertex_program3 | 4 + .../auto/extensions/GL_NV_vertex_program4 | 3 + .../auto/extensions/GL_OES_byte_coordinates | 4 + .../GL_OES_compressed_paletted_texture | 13 + .../GLew/auto/extensions/GL_OES_read_format | 5 + .../auto/extensions/GL_OES_single_precision | 9 + .../GLew/auto/extensions/GL_OML_interlace | 5 + .../GLew/auto/extensions/GL_OML_resample | 9 + .../GLew/auto/extensions/GL_OML_subsample | 5 + .../GLew/auto/extensions/GL_PGI_misc_hints | 23 + .../GLew/auto/extensions/GL_PGI_vertex_hints | 25 + .../extensions/GL_REND_screen_coordinates | 5 + Externals/GLew/auto/extensions/GL_S3_s3tc | 9 + .../GLew/auto/extensions/GL_SGIS_color_range | 12 + .../auto/extensions/GL_SGIS_detail_texture | 5 + .../GLew/auto/extensions/GL_SGIS_fog_function | 5 + .../auto/extensions/GL_SGIS_generate_mipmap | 5 + .../GLew/auto/extensions/GL_SGIS_multisample | 22 + .../auto/extensions/GL_SGIS_pixel_texture | 3 + .../auto/extensions/GL_SGIS_point_line_texgen | 11 + .../auto/extensions/GL_SGIS_sharpen_texture | 5 + .../GLew/auto/extensions/GL_SGIS_texture4D | 5 + .../extensions/GL_SGIS_texture_border_clamp | 4 + .../extensions/GL_SGIS_texture_edge_clamp | 4 + .../auto/extensions/GL_SGIS_texture_filter4 | 5 + .../GLew/auto/extensions/GL_SGIS_texture_lod | 7 + .../auto/extensions/GL_SGIS_texture_select | 3 + Externals/GLew/auto/extensions/GL_SGIX_async | 10 + .../auto/extensions/GL_SGIX_async_histogram | 5 + .../GLew/auto/extensions/GL_SGIX_async_pixel | 9 + .../extensions/GL_SGIX_blend_alpha_minmax | 5 + .../GLew/auto/extensions/GL_SGIX_clipmap | 3 + .../extensions/GL_SGIX_convolution_accuracy | 4 + .../auto/extensions/GL_SGIX_depth_texture | 6 + .../GLew/auto/extensions/GL_SGIX_flush_raster | 4 + .../GLew/auto/extensions/GL_SGIX_fog_offset | 5 + .../GLew/auto/extensions/GL_SGIX_fog_texture | 7 + .../GL_SGIX_fragment_specular_lighting | 20 + .../GLew/auto/extensions/GL_SGIX_framezoom | 4 + .../GLew/auto/extensions/GL_SGIX_interlace | 4 + .../auto/extensions/GL_SGIX_ir_instrument1 | 3 + .../auto/extensions/GL_SGIX_list_priority | 3 + .../auto/extensions/GL_SGIX_pixel_texture | 4 + .../extensions/GL_SGIX_pixel_texture_bits | 3 + .../auto/extensions/GL_SGIX_reference_plane | 4 + .../GLew/auto/extensions/GL_SGIX_resample | 8 + Externals/GLew/auto/extensions/GL_SGIX_shadow | 7 + .../auto/extensions/GL_SGIX_shadow_ambient | 4 + Externals/GLew/auto/extensions/GL_SGIX_sprite | 7 + .../auto/extensions/GL_SGIX_tag_sample_buffer | 4 + .../auto/extensions/GL_SGIX_texture_add_env | 3 + .../GL_SGIX_texture_coordinate_clamp | 6 + .../auto/extensions/GL_SGIX_texture_lod_bias | 3 + .../extensions/GL_SGIX_texture_multi_buffer | 4 + .../auto/extensions/GL_SGIX_texture_range | 31 + .../extensions/GL_SGIX_texture_scale_bias | 7 + .../auto/extensions/GL_SGIX_vertex_preclip | 5 + .../extensions/GL_SGIX_vertex_preclip_hint | 5 + Externals/GLew/auto/extensions/GL_SGIX_ycrcb | 3 + .../GLew/auto/extensions/GL_SGI_color_matrix | 14 + .../GLew/auto/extensions/GL_SGI_color_table | 26 + .../extensions/GL_SGI_texture_color_table | 5 + .../auto/extensions/GL_SUNX_constant_data | 6 + .../GL_SUN_convolution_border_modes | 4 + .../GLew/auto/extensions/GL_SUN_global_alpha | 13 + .../GLew/auto/extensions/GL_SUN_mesh_array | 5 + .../auto/extensions/GL_SUN_read_video_pixels | 4 + .../GLew/auto/extensions/GL_SUN_slice_accum | 4 + .../GLew/auto/extensions/GL_SUN_triangle_list | 27 + Externals/GLew/auto/extensions/GL_SUN_vertex | 43 + .../GLew/auto/extensions/GL_WIN_phong_shading | 5 + .../GLew/auto/extensions/GL_WIN_specular_fog | 4 + .../GLew/auto/extensions/GL_WIN_swap_hint | 4 + .../GLew/auto/extensions/WGL_3DFX_multisample | 5 + .../auto/extensions/WGL_3DL_stereo_control | 8 + .../auto/extensions/WGL_AMD_gpu_association | 22 + .../auto/extensions/WGL_ARB_buffer_region | 11 + .../auto/extensions/WGL_ARB_create_context | 10 + .../extensions/WGL_ARB_create_context_profile | 6 + .../auto/extensions/WGL_ARB_extensions_string | 4 + .../auto/extensions/WGL_ARB_framebuffer_sRGB | 4 + .../auto/extensions/WGL_ARB_make_current_read | 7 + .../GLew/auto/extensions/WGL_ARB_multisample | 5 + .../GLew/auto/extensions/WGL_ARB_pbuffer | 17 + .../GLew/auto/extensions/WGL_ARB_pixel_format | 55 + .../extensions/WGL_ARB_pixel_format_float | 4 + .../auto/extensions/WGL_ARB_render_texture | 39 + .../extensions/WGL_ATI_pixel_format_float | 6 + .../WGL_ATI_render_texture_rectangle | 4 + .../GLew/auto/extensions/WGL_EXT_depth_float | 4 + .../extensions/WGL_EXT_display_color_table | 7 + .../auto/extensions/WGL_EXT_extensions_string | 4 + .../auto/extensions/WGL_EXT_framebuffer_sRGB | 4 + .../auto/extensions/WGL_EXT_make_current_read | 6 + .../GLew/auto/extensions/WGL_EXT_multisample | 5 + .../GLew/auto/extensions/WGL_EXT_pbuffer | 18 + .../GLew/auto/extensions/WGL_EXT_pixel_format | 51 + .../WGL_EXT_pixel_format_packed_float | 4 + .../GLew/auto/extensions/WGL_EXT_swap_control | 5 + .../extensions/WGL_I3D_digital_video_control | 9 + Externals/GLew/auto/extensions/WGL_I3D_gamma | 9 + .../GLew/auto/extensions/WGL_I3D_genlock | 24 + .../GLew/auto/extensions/WGL_I3D_image_buffer | 9 + .../auto/extensions/WGL_I3D_swap_frame_lock | 7 + .../auto/extensions/WGL_I3D_swap_frame_usage | 7 + .../GLew/auto/extensions/WGL_NV_copy_image | 4 + .../GLew/auto/extensions/WGL_NV_float_buffer | 12 + .../GLew/auto/extensions/WGL_NV_gpu_affinity | 12 + .../GLew/auto/extensions/WGL_NV_present_video | 8 + .../extensions/WGL_NV_render_depth_texture | 9 + .../WGL_NV_render_texture_rectangle | 6 + .../GLew/auto/extensions/WGL_NV_swap_group | 9 + .../auto/extensions/WGL_NV_vertex_array_range | 5 + .../GLew/auto/extensions/WGL_NV_video_output | 23 + .../GLew/auto/extensions/WGL_OML_sync_control | 9 + Externals/GLew/auto/lib/OpenGL/Spec.pm | 202 + Externals/GLew/auto/src/footer.html | 4 + Externals/GLew/auto/src/glew.rc | 77 + Externals/GLew/auto/src/glew_head.c | 207 + Externals/GLew/auto/src/glew_head.h | 1073 + Externals/GLew/auto/src/glew_init_gl.c | 70 + Externals/GLew/auto/src/glew_init_glx.c | 52 + Externals/GLew/auto/src/glew_init_tail.c | 56 + Externals/GLew/auto/src/glew_init_wgl.c | 36 + Externals/GLew/auto/src/glew_license.h | 31 + Externals/GLew/auto/src/glew_str_glx.c | 21 + Externals/GLew/auto/src/glew_str_head.c | 13 + Externals/GLew/auto/src/glew_str_tail.c | 7 + Externals/GLew/auto/src/glew_str_wgl.c | 21 + Externals/GLew/auto/src/glew_tail.h | 74 + Externals/GLew/auto/src/glew_utils.c | 162 + Externals/GLew/auto/src/glew_utils.h | 101 + Externals/GLew/auto/src/glewinfo.rc | 57 + Externals/GLew/auto/src/glewinfo_gl.c | 7 + Externals/GLew/auto/src/glewinfo_glx.c | 6 + Externals/GLew/auto/src/glewinfo_head.c | 77 + Externals/GLew/auto/src/glewinfo_tail.c | 279 + Externals/GLew/auto/src/glewinfo_wgl.c | 8 + Externals/GLew/auto/src/glxew_head.h | 106 + Externals/GLew/auto/src/glxew_tail.h | 30 + Externals/GLew/auto/src/header.html | 98 + Externals/GLew/auto/src/khronos_license.h | 23 + Externals/GLew/auto/src/mesa_license.h | 24 + Externals/GLew/auto/src/visualinfo.rc | 57 + Externals/GLew/auto/src/wglew_head.h | 36 + Externals/GLew/auto/src/wglew_tail.h | 32 + Externals/GLew/build/vc6/Makefile | 28 + Externals/GLew/build/vc6/glew.dsw | 71 + Externals/GLew/build/vc6/glew.rc | 77 + Externals/GLew/build/vc6/glew_shared.dsp | 184 + Externals/GLew/build/vc6/glew_static.dsp | 162 + Externals/GLew/build/vc6/glewinfo.dsp | 159 + Externals/GLew/build/vc6/glewinfo.rc | 57 + Externals/GLew/build/vc6/visualinfo.dsp | 159 + Externals/GLew/build/vc6/visualinfo.rc | 57 + Externals/GLew/config/Makefile.cygming | 22 + Externals/GLew/config/Makefile.cygwin | 21 + Externals/GLew/config/Makefile.darwin | 26 + Externals/GLew/config/Makefile.freebsd | 20 + Externals/GLew/config/Makefile.gnu | 21 + Externals/GLew/config/Makefile.irix | 20 + Externals/GLew/config/Makefile.kfreebsd | 21 + Externals/GLew/config/Makefile.linux | 28 + Externals/GLew/config/Makefile.mingw | 19 + Externals/GLew/config/Makefile.solaris | 17 + Externals/GLew/config/config.guess | 1561 + Externals/GLew/config/version | 7 + Externals/GLew/doc/advanced.html | 278 + Externals/GLew/doc/basic.html | 282 + Externals/GLew/doc/credits.html | 127 + Externals/GLew/doc/glew.css | 187 + Externals/GLew/doc/glew.html | 513 + Externals/GLew/doc/glew.png | Bin 0 -> 9298 bytes Externals/GLew/doc/glew.txt | 28 + Externals/GLew/doc/glxew.html | 166 + Externals/GLew/doc/gpl.txt | 340 + Externals/GLew/doc/index.html | 202 + Externals/GLew/doc/install.html | 228 + Externals/GLew/doc/khronos.txt | 20 + Externals/GLew/doc/log.html | 704 + Externals/GLew/doc/mesa.txt | 21 + Externals/GLew/doc/new.png | Bin 0 -> 1180 bytes Externals/GLew/doc/ogl_sm.jpg | Bin 0 -> 1617 bytes Externals/GLew/doc/wglew.html | 156 + Externals/GLew/glew.pc.in | 10 + Externals/GLew/include/GL/glew.h | 14435 +++++++ Externals/GLew/include/GL/glxew.h | 1476 + Externals/GLew/include/GL/wglew.h | 1247 + Externals/GLew/src/glew.c | 14320 +++++++ Externals/GLew/src/glewinfo.c | 8441 ++++ Externals/GLew/src/visualinfo.c | 1173 + Externals/SDL/BUGS | 18 + Externals/SDL/Borland.html | 139 + Externals/SDL/Borland.zip | Bin 0 -> 157899 bytes Externals/SDL/COPYING | 458 + Externals/SDL/CREDITS | 94 + Externals/SDL/CWprojects.sea.bin | Bin 0 -> 476160 bytes Externals/SDL/INSTALL | 23 + Externals/SDL/MPWmake.sea.bin | Bin 0 -> 22144 bytes Externals/SDL/Makefile.dc | 111 + Externals/SDL/Makefile.in | 183 + Externals/SDL/Makefile.minimal | 42 + Externals/SDL/README | 49 + Externals/SDL/README-SDL.txt | 13 + Externals/SDL/README.AmigaOS | 12 + Externals/SDL/README.BeOS | 13 + Externals/SDL/README.CVS | 4 + Externals/SDL/README.DC | 32 + Externals/SDL/README.MacOS | 63 + Externals/SDL/README.MacOSX | 186 + Externals/SDL/README.MiNT | 250 + Externals/SDL/README.NDS | 22 + Externals/SDL/README.NanoX | 97 + Externals/SDL/README.OS2 | 281 + Externals/SDL/README.PS3 | 29 + Externals/SDL/README.PicoGUI | 50 + Externals/SDL/README.Porting | 56 + Externals/SDL/README.QNX | 155 + Externals/SDL/README.Qtopia | 84 + Externals/SDL/README.RISCOS | 130 + Externals/SDL/README.SVN | 23 + Externals/SDL/README.Symbian | 23 + Externals/SDL/README.Watcom | 133 + Externals/SDL/README.WinCE | 55 + Externals/SDL/README.wscons | 107 + Externals/SDL/SDL.qpg.in | 140 + Externals/SDL/SDL.spec | 113 + Externals/SDL/SDL.spec.in | 113 + Externals/SDL/TODO | 25 + Externals/SDL/VisualC.html | 171 + Externals/SDL/VisualC.zip | Bin 0 -> 43373 bytes Externals/SDL/VisualCE.zip | Bin 0 -> 56390 bytes Externals/SDL/Watcom-OS2.zip | Bin 0 -> 63088 bytes Externals/SDL/Watcom-Win32.zip | Bin 0 -> 3709 bytes Externals/SDL/WhatsNew | 727 + Externals/SDL/Xcode.tar.gz | Bin 0 -> 918433 bytes Externals/SDL/acinclude/alsa.m4 | 145 + Externals/SDL/acinclude/esd.m4 | 168 + Externals/SDL/acinclude/libtool.m4 | 7370 ++++ Externals/SDL/acinclude/ltdl.m4 | 806 + Externals/SDL/acinclude/ltoptions.m4 | 370 + Externals/SDL/acinclude/ltsugar.m4 | 125 + Externals/SDL/acinclude/ltversion.m4 | 25 + Externals/SDL/acinclude/lt~obsolete.m4 | 93 + Externals/SDL/autogen.sh | 19 + Externals/SDL/build-scripts/config.guess | 1494 + Externals/SDL/build-scripts/config.sub | 1700 + Externals/SDL/build-scripts/fatbuild.sh | 316 + Externals/SDL/build-scripts/install-sh | 323 + Externals/SDL/build-scripts/ltmain.sh | 8407 ++++ Externals/SDL/build-scripts/makedep.sh | 93 + Externals/SDL/build-scripts/mkinstalldirs | 99 + Externals/SDL/build-scripts/strip_fPIC.sh | 21 + Externals/SDL/configure | 33165 ++++++++++++++++ Externals/SDL/configure.in | 2916 ++ Externals/SDL/docs.html | 629 + Externals/SDL/docs/html/audio.html | 242 + Externals/SDL/docs/html/cdrom.html | 260 + Externals/SDL/docs/html/event.html | 216 + Externals/SDL/docs/html/eventfunctions.html | 481 + Externals/SDL/docs/html/eventstructures.html | 233 + Externals/SDL/docs/html/general.html | 225 + Externals/SDL/docs/html/guide.html | 174 + Externals/SDL/docs/html/guideaboutsdldoc.html | 148 + .../SDL/docs/html/guideaudioexamples.html | 228 + Externals/SDL/docs/html/guidebasicsinit.html | 240 + .../SDL/docs/html/guidecdromexamples.html | 275 + Externals/SDL/docs/html/guidecredits.html | 195 + .../SDL/docs/html/guideeventexamples.html | 247 + Externals/SDL/docs/html/guideexamples.html | 188 + Externals/SDL/docs/html/guideinput.html | 739 + .../SDL/docs/html/guideinputkeyboard.html | 746 + Externals/SDL/docs/html/guidepreface.html | 178 + Externals/SDL/docs/html/guidethebasics.html | 173 + .../SDL/docs/html/guidetimeexamples.html | 183 + Externals/SDL/docs/html/guidevideo.html | 463 + Externals/SDL/docs/html/guidevideoopengl.html | 730 + Externals/SDL/docs/html/index.html | 1156 + Externals/SDL/docs/html/joystick.html | 296 + Externals/SDL/docs/html/reference.html | 194 + Externals/SDL/docs/html/sdlactiveevent.html | 335 + Externals/SDL/docs/html/sdladdtimer.html | 296 + Externals/SDL/docs/html/sdlaudiocvt.html | 556 + Externals/SDL/docs/html/sdlaudiospec.html | 589 + Externals/SDL/docs/html/sdlblitsurface.html | 339 + Externals/SDL/docs/html/sdlbuildaudiocvt.html | 291 + Externals/SDL/docs/html/sdlcd.html | 359 + Externals/SDL/docs/html/sdlcdclose.html | 217 + Externals/SDL/docs/html/sdlcdeject.html | 226 + Externals/SDL/docs/html/sdlcdname.html | 239 + Externals/SDL/docs/html/sdlcdnumdrives.html | 205 + Externals/SDL/docs/html/sdlcdopen.html | 275 + Externals/SDL/docs/html/sdlcdpause.html | 233 + Externals/SDL/docs/html/sdlcdplay.html | 243 + Externals/SDL/docs/html/sdlcdplaytracks.html | 325 + Externals/SDL/docs/html/sdlcdresume.html | 233 + Externals/SDL/docs/html/sdlcdstatus.html | 273 + Externals/SDL/docs/html/sdlcdstop.html | 226 + Externals/SDL/docs/html/sdlcdtrack.html | 313 + Externals/SDL/docs/html/sdlcloseaudio.html | 205 + Externals/SDL/docs/html/sdlcolor.html | 300 + Externals/SDL/docs/html/sdlcondbroadcast.html | 224 + Externals/SDL/docs/html/sdlcondsignal.html | 224 + Externals/SDL/docs/html/sdlcondwait.html | 231 + .../SDL/docs/html/sdlcondwaittimeout.html | 230 + Externals/SDL/docs/html/sdlconvertaudio.html | 407 + .../SDL/docs/html/sdlconvertsurface.html | 271 + Externals/SDL/docs/html/sdlcreatecond.html | 240 + Externals/SDL/docs/html/sdlcreatecursor.html | 398 + Externals/SDL/docs/html/sdlcreatemutex.html | 249 + .../SDL/docs/html/sdlcreatergbsurface.html | 458 + .../docs/html/sdlcreatergbsurfacefrom.html | 256 + .../SDL/docs/html/sdlcreatesemaphore.html | 303 + Externals/SDL/docs/html/sdlcreatethread.html | 223 + .../SDL/docs/html/sdlcreateyuvoverlay.html | 256 + Externals/SDL/docs/html/sdldelay.html | 231 + Externals/SDL/docs/html/sdldestroycond.html | 206 + Externals/SDL/docs/html/sdldestroymutex.html | 209 + .../SDL/docs/html/sdldestroysemaphore.html | 278 + Externals/SDL/docs/html/sdldisplayformat.html | 262 + .../SDL/docs/html/sdldisplayformatalpha.html | 250 + .../SDL/docs/html/sdldisplayyuvoverlay.html | 246 + .../SDL/docs/html/sdlenablekeyrepeat.html | 238 + Externals/SDL/docs/html/sdlenableunicode.html | 252 + Externals/SDL/docs/html/sdlenvvars.html | 1227 + Externals/SDL/docs/html/sdlevent.html | 994 + Externals/SDL/docs/html/sdleventstate.html | 276 + Externals/SDL/docs/html/sdlexposeevent.html | 252 + Externals/SDL/docs/html/sdlfillrect.html | 291 + Externals/SDL/docs/html/sdlflip.html | 259 + Externals/SDL/docs/html/sdlfreecursor.html | 209 + Externals/SDL/docs/html/sdlfreesurface.html | 219 + Externals/SDL/docs/html/sdlfreewav.html | 222 + .../SDL/docs/html/sdlfreeyuvoverlay.html | 233 + Externals/SDL/docs/html/sdlgetappstate.html | 263 + .../SDL/docs/html/sdlgetaudiostatus.html | 221 + Externals/SDL/docs/html/sdlgetcliprect.html | 229 + Externals/SDL/docs/html/sdlgetcursor.html | 219 + Externals/SDL/docs/html/sdlgeterror.html | 205 + .../SDL/docs/html/sdlgeteventfilter.html | 235 + Externals/SDL/docs/html/sdlgetgammaramp.html | 219 + Externals/SDL/docs/html/sdlgetkeyname.html | 216 + Externals/SDL/docs/html/sdlgetkeystate.html | 253 + Externals/SDL/docs/html/sdlgetmodstate.html | 257 + Externals/SDL/docs/html/sdlgetmousestate.html | 253 + .../docs/html/sdlgetrelativemousestate.html | 235 + Externals/SDL/docs/html/sdlgetrgb.html | 231 + Externals/SDL/docs/html/sdlgetrgba.html | 222 + Externals/SDL/docs/html/sdlgetthreadid.html | 209 + Externals/SDL/docs/html/sdlgetticks.html | 206 + Externals/SDL/docs/html/sdlgetvideoinfo.html | 226 + .../SDL/docs/html/sdlgetvideosurface.html | 208 + Externals/SDL/docs/html/sdlglattr.html | 379 + .../SDL/docs/html/sdlglgetattribute.html | 247 + .../SDL/docs/html/sdlglgetprocaddress.html | 262 + Externals/SDL/docs/html/sdlglloadlibrary.html | 231 + .../SDL/docs/html/sdlglsetattribute.html | 286 + Externals/SDL/docs/html/sdlglswapbuffers.html | 212 + Externals/SDL/docs/html/sdlinit.html | 368 + Externals/SDL/docs/html/sdlinitsubsystem.html | 283 + Externals/SDL/docs/html/sdljoyaxisevent.html | 330 + Externals/SDL/docs/html/sdljoyballevent.html | 340 + .../SDL/docs/html/sdljoybuttonevent.html | 351 + Externals/SDL/docs/html/sdljoyhatevent.html | 413 + Externals/SDL/docs/html/sdljoystickclose.html | 223 + .../SDL/docs/html/sdljoystickeventstate.html | 290 + .../SDL/docs/html/sdljoystickgetaxis.html | 271 + .../SDL/docs/html/sdljoystickgetball.html | 262 + .../SDL/docs/html/sdljoystickgetbutton.html | 231 + .../SDL/docs/html/sdljoystickgethat.html | 297 + Externals/SDL/docs/html/sdljoystickindex.html | 218 + Externals/SDL/docs/html/sdljoystickname.html | 238 + .../SDL/docs/html/sdljoysticknumaxes.html | 225 + .../SDL/docs/html/sdljoysticknumballs.html | 225 + .../SDL/docs/html/sdljoysticknumbuttons.html | 225 + .../SDL/docs/html/sdljoysticknumhats.html | 225 + Externals/SDL/docs/html/sdljoystickopen.html | 259 + .../SDL/docs/html/sdljoystickopened.html | 233 + .../SDL/docs/html/sdljoystickupdate.html | 211 + Externals/SDL/docs/html/sdlkey.html | 2630 ++ Externals/SDL/docs/html/sdlkeyboardevent.html | 375 + Externals/SDL/docs/html/sdlkeysym.html | 355 + Externals/SDL/docs/html/sdlkillthread.html | 223 + Externals/SDL/docs/html/sdllistmodes.html | 310 + Externals/SDL/docs/html/sdlloadbmp.html | 219 + Externals/SDL/docs/html/sdlloadwav.html | 296 + Externals/SDL/docs/html/sdllockaudio.html | 208 + Externals/SDL/docs/html/sdllocksurface.html | 306 + .../SDL/docs/html/sdllockyuvoverlay.html | 252 + Externals/SDL/docs/html/sdlmaprgb.html | 254 + Externals/SDL/docs/html/sdlmaprgba.html | 242 + Externals/SDL/docs/html/sdlmixaudio.html | 237 + .../SDL/docs/html/sdlmousebuttonevent.html | 346 + .../SDL/docs/html/sdlmousemotionevent.html | 365 + Externals/SDL/docs/html/sdlmutexp.html | 241 + Externals/SDL/docs/html/sdlmutexv.html | 235 + Externals/SDL/docs/html/sdlnumjoysticks.html | 222 + Externals/SDL/docs/html/sdlopenaudio.html | 578 + Externals/SDL/docs/html/sdloverlay.html | 362 + Externals/SDL/docs/html/sdlpalette.html | 301 + Externals/SDL/docs/html/sdlpauseaudio.html | 221 + Externals/SDL/docs/html/sdlpeepevents.html | 321 + Externals/SDL/docs/html/sdlpixelformat.html | 528 + Externals/SDL/docs/html/sdlpollevent.html | 269 + Externals/SDL/docs/html/sdlpumpevents.html | 244 + Externals/SDL/docs/html/sdlpushevent.html | 266 + Externals/SDL/docs/html/sdlquit.html | 244 + Externals/SDL/docs/html/sdlquitevent.html | 263 + Externals/SDL/docs/html/sdlquitsubsystem.html | 248 + Externals/SDL/docs/html/sdlrect.html | 258 + Externals/SDL/docs/html/sdlremovetimer.html | 236 + Externals/SDL/docs/html/sdlresizeevent.html | 307 + Externals/SDL/docs/html/sdlsavebmp.html | 236 + Externals/SDL/docs/html/sdlsempost.html | 299 + Externals/SDL/docs/html/sdlsemtrywait.html | 319 + Externals/SDL/docs/html/sdlsemvalue.html | 273 + Externals/SDL/docs/html/sdlsemwait.html | 298 + .../SDL/docs/html/sdlsemwaittimeout.html | 322 + Externals/SDL/docs/html/sdlsetalpha.html | 500 + Externals/SDL/docs/html/sdlsetcliprect.html | 241 + Externals/SDL/docs/html/sdlsetcolorkey.html | 321 + Externals/SDL/docs/html/sdlsetcolors.html | 358 + Externals/SDL/docs/html/sdlsetcursor.html | 222 + .../SDL/docs/html/sdlseteventfilter.html | 284 + Externals/SDL/docs/html/sdlsetgamma.html | 231 + Externals/SDL/docs/html/sdlsetgammaramp.html | 230 + Externals/SDL/docs/html/sdlsetmodstate.html | 237 + Externals/SDL/docs/html/sdlsetpalette.html | 352 + Externals/SDL/docs/html/sdlsettimer.html | 267 + Externals/SDL/docs/html/sdlsetvideomode.html | 558 + Externals/SDL/docs/html/sdlshowcursor.html | 239 + Externals/SDL/docs/html/sdlsurface.html | 597 + Externals/SDL/docs/html/sdlsyswmevent.html | 233 + Externals/SDL/docs/html/sdlthreadid.html | 190 + Externals/SDL/docs/html/sdlunlockaudio.html | 211 + Externals/SDL/docs/html/sdlunlocksurface.html | 219 + .../SDL/docs/html/sdlunlockyuvoverlay.html | 225 + Externals/SDL/docs/html/sdlupdaterect.html | 266 + Externals/SDL/docs/html/sdlupdaterects.html | 255 + Externals/SDL/docs/html/sdluserevent.html | 337 + .../SDL/docs/html/sdlvideodrivername.html | 243 + Externals/SDL/docs/html/sdlvideoinfo.html | 408 + Externals/SDL/docs/html/sdlvideomodeok.html | 270 + Externals/SDL/docs/html/sdlwaitevent.html | 231 + Externals/SDL/docs/html/sdlwaitthread.html | 231 + Externals/SDL/docs/html/sdlwarpmouse.html | 205 + Externals/SDL/docs/html/sdlwasinit.html | 284 + Externals/SDL/docs/html/sdlwmgetcaption.html | 222 + Externals/SDL/docs/html/sdlwmgrabinput.html | 224 + .../SDL/docs/html/sdlwmiconifywindow.html | 211 + Externals/SDL/docs/html/sdlwmsetcaption.html | 212 + Externals/SDL/docs/html/sdlwmseticon.html | 260 + .../SDL/docs/html/sdlwmtogglefullscreen.html | 205 + Externals/SDL/docs/html/thread.html | 313 + Externals/SDL/docs/html/time.html | 206 + Externals/SDL/docs/html/video.html | 507 + Externals/SDL/docs/html/wm.html | 188 + Externals/SDL/docs/images/rainbow.gif | Bin 0 -> 1715 bytes Externals/SDL/docs/index.html | 55 + Externals/SDL/docs/man3/SDLKey.3 | 161 + Externals/SDL/docs/man3/SDL_ActiveEvent.3 | 38 + Externals/SDL/docs/man3/SDL_AddTimer.3 | 38 + Externals/SDL/docs/man3/SDL_AudioCVT.3 | 68 + Externals/SDL/docs/man3/SDL_AudioSpec.3 | 70 + Externals/SDL/docs/man3/SDL_BlitSurface.3 | 60 + Externals/SDL/docs/man3/SDL_BuildAudioCVT.3 | 23 + Externals/SDL/docs/man3/SDL_CD.3 | 57 + Externals/SDL/docs/man3/SDL_CDClose.3 | 15 + Externals/SDL/docs/man3/SDL_CDEject.3 | 18 + Externals/SDL/docs/man3/SDL_CDName.3 | 23 + Externals/SDL/docs/man3/SDL_CDNumDrives.3 | 15 + Externals/SDL/docs/man3/SDL_CDOpen.3 | 58 + Externals/SDL/docs/man3/SDL_CDPause.3 | 18 + Externals/SDL/docs/man3/SDL_CDPlay.3 | 18 + Externals/SDL/docs/man3/SDL_CDPlayTracks.3 | 47 + Externals/SDL/docs/man3/SDL_CDResume.3 | 18 + Externals/SDL/docs/man3/SDL_CDStatus.3 | 59 + Externals/SDL/docs/man3/SDL_CDStop.3 | 18 + Externals/SDL/docs/man3/SDL_CDtrack.3 | 40 + Externals/SDL/docs/man3/SDL_CloseAudio.3 | 15 + Externals/SDL/docs/man3/SDL_Color.3 | 34 + Externals/SDL/docs/man3/SDL_CondBroadcast.3 | 16 + Externals/SDL/docs/man3/SDL_CondSignal.3 | 16 + Externals/SDL/docs/man3/SDL_CondWait.3 | 16 + Externals/SDL/docs/man3/SDL_CondWaitTimeout.3 | 16 + Externals/SDL/docs/man3/SDL_ConvertAudio.3 | 95 + Externals/SDL/docs/man3/SDL_ConvertSurface.3 | 24 + Externals/SDL/docs/man3/SDL_CreateCond.3 | 31 + Externals/SDL/docs/man3/SDL_CreateCursor.3 | 120 + Externals/SDL/docs/man3/SDL_CreateMutex.3 | 43 + .../SDL/docs/man3/SDL_CreateRGBSurface.3 | 69 + .../SDL/docs/man3/SDL_CreateRGBSurfaceFrom.3 | 22 + Externals/SDL/docs/man3/SDL_CreateSemaphore.3 | 32 + Externals/SDL/docs/man3/SDL_CreateThread.3 | 16 + .../SDL/docs/man3/SDL_CreateYUVOverlay.3 | 17 + Externals/SDL/docs/man3/SDL_Delay.3 | 21 + Externals/SDL/docs/man3/SDL_DestroyCond.3 | 16 + Externals/SDL/docs/man3/SDL_DestroyMutex.3 | 16 + .../SDL/docs/man3/SDL_DestroySemaphore.3 | 26 + Externals/SDL/docs/man3/SDL_DisplayFormat.3 | 22 + .../SDL/docs/man3/SDL_DisplayFormatAlpha.3 | 22 + .../SDL/docs/man3/SDL_DisplayYUVOverlay.3 | 18 + Externals/SDL/docs/man3/SDL_EnableKeyRepeat.3 | 17 + Externals/SDL/docs/man3/SDL_EnableUNICODE.3 | 24 + Externals/SDL/docs/man3/SDL_Event.3 | 182 + Externals/SDL/docs/man3/SDL_EventState.3 | 23 + Externals/SDL/docs/man3/SDL_ExposeEvent.3 | 24 + Externals/SDL/docs/man3/SDL_FillRect.3 | 22 + Externals/SDL/docs/man3/SDL_Flip.3 | 20 + Externals/SDL/docs/man3/SDL_FreeCursor.3 | 15 + Externals/SDL/docs/man3/SDL_FreeSurface.3 | 15 + Externals/SDL/docs/man3/SDL_FreeWAV.3 | 15 + Externals/SDL/docs/man3/SDL_FreeYUVOverlay.3 | 15 + Externals/SDL/docs/man3/SDL_GL_GetAttribute.3 | 18 + .../SDL/docs/man3/SDL_GL_GetProcAddress.3 | 48 + Externals/SDL/docs/man3/SDL_GL_LoadLibrary.3 | 15 + Externals/SDL/docs/man3/SDL_GL_SetAttribute.3 | 40 + Externals/SDL/docs/man3/SDL_GL_SwapBuffers.3 | 15 + Externals/SDL/docs/man3/SDL_GLattr.3 | 47 + Externals/SDL/docs/man3/SDL_GetAppState.3 | 24 + Externals/SDL/docs/man3/SDL_GetAudioStatus.3 | 24 + Externals/SDL/docs/man3/SDL_GetClipRect.3 | 17 + Externals/SDL/docs/man3/SDL_GetCursor.3 | 15 + Externals/SDL/docs/man3/SDL_GetError.3 | 15 + Externals/SDL/docs/man3/SDL_GetEventFilter.3 | 23 + Externals/SDL/docs/man3/SDL_GetGamma.3 | 21 + Externals/SDL/docs/man3/SDL_GetGammaRamp.3 | 20 + Externals/SDL/docs/man3/SDL_GetKeyName.3 | 15 + Externals/SDL/docs/man3/SDL_GetKeyState.3 | 30 + Externals/SDL/docs/man3/SDL_GetModState.3 | 54 + Externals/SDL/docs/man3/SDL_GetMouseState.3 | 24 + Externals/SDL/docs/man3/SDL_GetRGB.3 | 17 + Externals/SDL/docs/man3/SDL_GetRGBA.3 | 19 + .../SDL/docs/man3/SDL_GetRelativeMouseState.3 | 15 + Externals/SDL/docs/man3/SDL_GetThreadID.3 | 16 + Externals/SDL/docs/man3/SDL_GetTicks.3 | 15 + Externals/SDL/docs/man3/SDL_GetVideoInfo.3 | 15 + Externals/SDL/docs/man3/SDL_GetVideoSurface.3 | 15 + Externals/SDL/docs/man3/SDL_Init.3 | 41 + Externals/SDL/docs/man3/SDL_InitSubSystem.3 | 41 + Externals/SDL/docs/man3/SDL_JoyAxisEvent.3 | 36 + Externals/SDL/docs/man3/SDL_JoyBallEvent.3 | 36 + Externals/SDL/docs/man3/SDL_JoyButtonEvent.3 | 36 + Externals/SDL/docs/man3/SDL_JoyHatEvent.3 | 56 + Externals/SDL/docs/man3/SDL_JoystickClose.3 | 15 + .../SDL/docs/man3/SDL_JoystickEventState.3 | 24 + Externals/SDL/docs/man3/SDL_JoystickGetAxis.3 | 32 + Externals/SDL/docs/man3/SDL_JoystickGetBall.3 | 37 + .../SDL/docs/man3/SDL_JoystickGetButton.3 | 18 + Externals/SDL/docs/man3/SDL_JoystickGetHat.3 | 36 + Externals/SDL/docs/man3/SDL_JoystickIndex.3 | 18 + Externals/SDL/docs/man3/SDL_JoystickName.3 | 32 + Externals/SDL/docs/man3/SDL_JoystickNumAxes.3 | 18 + .../SDL/docs/man3/SDL_JoystickNumBalls.3 | 18 + .../SDL/docs/man3/SDL_JoystickNumButtons.3 | 18 + Externals/SDL/docs/man3/SDL_JoystickNumHats.3 | 18 + Externals/SDL/docs/man3/SDL_JoystickOpen.3 | 51 + Externals/SDL/docs/man3/SDL_JoystickOpened.3 | 18 + Externals/SDL/docs/man3/SDL_JoystickUpdate.3 | 15 + Externals/SDL/docs/man3/SDL_KeyboardEvent.3 | 38 + Externals/SDL/docs/man3/SDL_KillThread.3 | 16 + Externals/SDL/docs/man3/SDL_ListModes.3 | 53 + Externals/SDL/docs/man3/SDL_LoadBMP.3 | 18 + Externals/SDL/docs/man3/SDL_LoadWAV.3 | 42 + Externals/SDL/docs/man3/SDL_LockAudio.3 | 15 + Externals/SDL/docs/man3/SDL_LockSurface.3 | 48 + Externals/SDL/docs/man3/SDL_LockYUVOverlay.3 | 18 + Externals/SDL/docs/man3/SDL_MapRGB.3 | 22 + Externals/SDL/docs/man3/SDL_MapRGBA.3 | 22 + Externals/SDL/docs/man3/SDL_MixAudio.3 | 21 + .../SDL/docs/man3/SDL_MouseButtonEvent.3 | 36 + .../SDL/docs/man3/SDL_MouseMotionEvent.3 | 38 + Externals/SDL/docs/man3/SDL_NumJoysticks.3 | 18 + Externals/SDL/docs/man3/SDL_OpenAudio.3 | 97 + Externals/SDL/docs/man3/SDL_Overlay.3 | 52 + Externals/SDL/docs/man3/SDL_Palette.3 | 26 + Externals/SDL/docs/man3/SDL_PauseAudio.3 | 15 + Externals/SDL/docs/man3/SDL_PeepEvents.3 | 26 + Externals/SDL/docs/man3/SDL_PixelFormat.3 | 140 + Externals/SDL/docs/man3/SDL_PollEvent.3 | 44 + Externals/SDL/docs/man3/SDL_PumpEvents.3 | 23 + Externals/SDL/docs/man3/SDL_PushEvent.3 | 27 + Externals/SDL/docs/man3/SDL_Quit.3 | 29 + Externals/SDL/docs/man3/SDL_QuitEvent.3 | 30 + Externals/SDL/docs/man3/SDL_QuitSubSystem.3 | 15 + Externals/SDL/docs/man3/SDL_RWFromFile.3 | 18 + Externals/SDL/docs/man3/SDL_Rect.3 | 26 + Externals/SDL/docs/man3/SDL_RemoveTimer.3 | 25 + Externals/SDL/docs/man3/SDL_ResizeEvent.3 | 28 + Externals/SDL/docs/man3/SDL_SaveBMP.3 | 18 + Externals/SDL/docs/man3/SDL_SemPost.3 | 28 + Externals/SDL/docs/man3/SDL_SemTryWait.3 | 41 + Externals/SDL/docs/man3/SDL_SemValue.3 | 26 + Externals/SDL/docs/man3/SDL_SemWait.3 | 34 + Externals/SDL/docs/man3/SDL_SemWaitTimeout.3 | 41 + Externals/SDL/docs/man3/SDL_SetAlpha.3 | 66 + Externals/SDL/docs/man3/SDL_SetClipRect.3 | 19 + Externals/SDL/docs/man3/SDL_SetColorKey.3 | 26 + Externals/SDL/docs/man3/SDL_SetColors.3 | 57 + Externals/SDL/docs/man3/SDL_SetCursor.3 | 15 + Externals/SDL/docs/man3/SDL_SetEventFilter.3 | 35 + Externals/SDL/docs/man3/SDL_SetGamma.3 | 22 + Externals/SDL/docs/man3/SDL_SetGammaRamp.3 | 22 + Externals/SDL/docs/man3/SDL_SetModState.3 | 35 + Externals/SDL/docs/man3/SDL_SetPalette.3 | 59 + Externals/SDL/docs/man3/SDL_SetTimer.3 | 39 + Externals/SDL/docs/man3/SDL_SetVideoMode.3 | 67 + Externals/SDL/docs/man3/SDL_ShowCursor.3 | 20 + Externals/SDL/docs/man3/SDL_Surface.3 | 96 + Externals/SDL/docs/man3/SDL_SysWMEvent.3 | 21 + Externals/SDL/docs/man3/SDL_ThreadID.3 | 13 + Externals/SDL/docs/man3/SDL_UnlockAudio.3 | 15 + Externals/SDL/docs/man3/SDL_UnlockSurface.3 | 17 + .../SDL/docs/man3/SDL_UnlockYUVOverlay.3 | 15 + Externals/SDL/docs/man3/SDL_UpdateRect.3 | 19 + Externals/SDL/docs/man3/SDL_UpdateRects.3 | 25 + Externals/SDL/docs/man3/SDL_UserEvent.3 | 47 + Externals/SDL/docs/man3/SDL_VideoDriverName.3 | 18 + Externals/SDL/docs/man3/SDL_VideoInfo.3 | 62 + Externals/SDL/docs/man3/SDL_VideoModeOK.3 | 44 + Externals/SDL/docs/man3/SDL_WM_GetCaption.3 | 15 + Externals/SDL/docs/man3/SDL_WM_GrabInput.3 | 28 + .../SDL/docs/man3/SDL_WM_IconifyWindow.3 | 15 + Externals/SDL/docs/man3/SDL_WM_SetCaption.3 | 15 + Externals/SDL/docs/man3/SDL_WM_SetIcon.3 | 27 + .../SDL/docs/man3/SDL_WM_ToggleFullScreen.3 | 15 + Externals/SDL/docs/man3/SDL_WaitEvent.3 | 17 + Externals/SDL/docs/man3/SDL_WaitThread.3 | 19 + Externals/SDL/docs/man3/SDL_WarpMouse.3 | 15 + Externals/SDL/docs/man3/SDL_WasInit.3 | 63 + Externals/SDL/docs/man3/SDL_keysym.3 | 69 + Externals/SDL/docs/man3/SDL_mutexP.3 | 18 + Externals/SDL/docs/man3/SDL_mutexV.3 | 18 + Externals/SDL/include/SDL.h | 101 + Externals/SDL/include/SDL_active.h | 63 + Externals/SDL/include/SDL_audio.h | 284 + Externals/SDL/include/SDL_byteorder.h | 29 + Externals/SDL/include/SDL_cdrom.h | 202 + Externals/SDL/include/SDL_config.h | 45 + Externals/SDL/include/SDL_config.h.default | 45 + Externals/SDL/include/SDL_config.h.in | 310 + Externals/SDL/include/SDL_config_dreamcast.h | 106 + Externals/SDL/include/SDL_config_macos.h | 112 + Externals/SDL/include/SDL_config_macosx.h | 150 + Externals/SDL/include/SDL_config_minimal.h | 62 + Externals/SDL/include/SDL_config_nds.h | 115 + Externals/SDL/include/SDL_config_os2.h | 141 + Externals/SDL/include/SDL_config_symbian.h | 146 + Externals/SDL/include/SDL_config_win32.h | 183 + Externals/SDL/include/SDL_copying.h | 22 + Externals/SDL/include/SDL_cpuinfo.h | 69 + Externals/SDL/include/SDL_endian.h | 209 + Externals/SDL/include/SDL_error.h | 72 + Externals/SDL/include/SDL_events.h | 356 + Externals/SDL/include/SDL_getenv.h | 28 + Externals/SDL/include/SDL_joystick.h | 187 + Externals/SDL/include/SDL_keyboard.h | 135 + Externals/SDL/include/SDL_keysym.h | 326 + Externals/SDL/include/SDL_loadso.h | 78 + Externals/SDL/include/SDL_main.h | 106 + Externals/SDL/include/SDL_mouse.h | 143 + Externals/SDL/include/SDL_mutex.h | 177 + Externals/SDL/include/SDL_name.h | 11 + Externals/SDL/include/SDL_opengl.h | 6556 +++ Externals/SDL/include/SDL_platform.h | 110 + Externals/SDL/include/SDL_quit.h | 55 + Externals/SDL/include/SDL_rwops.h | 155 + Externals/SDL/include/SDL_stdinc.h | 620 + Externals/SDL/include/SDL_syswm.h | 225 + Externals/SDL/include/SDL_thread.h | 120 + Externals/SDL/include/SDL_timer.h | 125 + Externals/SDL/include/SDL_types.h | 28 + Externals/SDL/include/SDL_version.h | 91 + Externals/SDL/include/SDL_video.h | 951 + Externals/SDL/include/begin_code.h | 191 + Externals/SDL/include/close_code.h | 46 + Externals/SDL/include/doxyfile | 946 + Externals/SDL/sdl-config.in | 60 + Externals/SDL/sdl.m4 | 183 + Externals/SDL/sdl.pc.in | 15 + Externals/SDL/src/SDL.c | 350 + Externals/SDL/src/SDL_error.c | 238 + Externals/SDL/src/SDL_error_c.h | 58 + Externals/SDL/src/SDL_fatal.c | 134 + Externals/SDL/src/SDL_fatal.h | 28 + Externals/SDL/src/audio/SDL_audio.c | 695 + Externals/SDL/src/audio/SDL_audio_c.h | 34 + Externals/SDL/src/audio/SDL_audiocvt.c | 1510 + Externals/SDL/src/audio/SDL_audiodev.c | 179 + Externals/SDL/src/audio/SDL_audiodev_c.h | 26 + Externals/SDL/src/audio/SDL_audiomem.h | 25 + Externals/SDL/src/audio/SDL_mixer.c | 264 + Externals/SDL/src/audio/SDL_mixer_MMX.c | 207 + Externals/SDL/src/audio/SDL_mixer_MMX.h | 17 + Externals/SDL/src/audio/SDL_mixer_MMX_VC.c | 183 + Externals/SDL/src/audio/SDL_mixer_MMX_VC.h | 38 + Externals/SDL/src/audio/SDL_mixer_m68k.c | 211 + Externals/SDL/src/audio/SDL_mixer_m68k.h | 36 + Externals/SDL/src/audio/SDL_sysaudio.h | 184 + Externals/SDL/src/audio/SDL_wave.c | 600 + Externals/SDL/src/audio/SDL_wave.h | 62 + Externals/SDL/src/audio/alsa/SDL_alsa_audio.c | 612 + Externals/SDL/src/audio/alsa/SDL_alsa_audio.h | 48 + Externals/SDL/src/audio/arts/SDL_artsaudio.c | 348 + Externals/SDL/src/audio/arts/SDL_artsaudio.h | 60 + Externals/SDL/src/audio/baudio/SDL_beaudio.cc | 225 + Externals/SDL/src/audio/baudio/SDL_beaudio.h | 39 + Externals/SDL/src/audio/bsd/SDL_bsdaudio.c | 404 + Externals/SDL/src/audio/bsd/SDL_bsdaudio.h | 58 + Externals/SDL/src/audio/dart/SDL_dart.c | 441 + Externals/SDL/src/audio/dart/SDL_dart.h | 63 + Externals/SDL/src/audio/dc/SDL_dcaudio.c | 246 + Externals/SDL/src/audio/dc/SDL_dcaudio.h | 41 + Externals/SDL/src/audio/dc/aica.c | 271 + Externals/SDL/src/audio/dc/aica.h | 40 + Externals/SDL/src/audio/disk/SDL_diskaudio.c | 186 + Externals/SDL/src/audio/disk/SDL_diskaudio.h | 41 + Externals/SDL/src/audio/dma/SDL_dmaaudio.c | 455 + Externals/SDL/src/audio/dma/SDL_dmaaudio.h | 59 + .../SDL/src/audio/dmedia/SDL_irixaudio.c | 242 + .../SDL/src/audio/dmedia/SDL_irixaudio.h | 45 + Externals/SDL/src/audio/dsp/SDL_dspaudio.c | 340 + Externals/SDL/src/audio/dsp/SDL_dspaudio.h | 53 + .../SDL/src/audio/dummy/SDL_dummyaudio.c | 156 + .../SDL/src/audio/dummy/SDL_dummyaudio.h | 40 + Externals/SDL/src/audio/esd/SDL_esdaudio.c | 323 + Externals/SDL/src/audio/esd/SDL_esdaudio.h | 57 + .../SDL/src/audio/macosx/SDL_coreaudio.c | 291 + .../SDL/src/audio/macosx/SDL_coreaudio.h | 45 + Externals/SDL/src/audio/macrom/SDL_romaudio.c | 496 + Externals/SDL/src/audio/macrom/SDL_romaudio.h | 50 + Externals/SDL/src/audio/mint/SDL_mintaudio.c | 215 + Externals/SDL/src/audio/mint/SDL_mintaudio.h | 157 + .../SDL/src/audio/mint/SDL_mintaudio_dma8.c | 361 + .../SDL/src/audio/mint/SDL_mintaudio_dma8.h | 85 + .../SDL/src/audio/mint/SDL_mintaudio_gsxb.c | 436 + .../SDL/src/audio/mint/SDL_mintaudio_gsxb.h | 108 + .../SDL/src/audio/mint/SDL_mintaudio_it.S | 281 + .../SDL/src/audio/mint/SDL_mintaudio_mcsn.c | 404 + .../SDL/src/audio/mint/SDL_mintaudio_mcsn.h | 59 + .../SDL/src/audio/mint/SDL_mintaudio_stfa.c | 323 + .../SDL/src/audio/mint/SDL_mintaudio_stfa.h | 100 + .../SDL/src/audio/mint/SDL_mintaudio_xbios.c | 495 + Externals/SDL/src/audio/mme/SDL_mmeaudio.c | 264 + Externals/SDL/src/audio/mme/SDL_mmeaudio.h | 51 + Externals/SDL/src/audio/nas/SDL_nasaudio.c | 423 + Externals/SDL/src/audio/nas/SDL_nasaudio.h | 62 + Externals/SDL/src/audio/nds/SDL_ndsaudio.c | 335 + Externals/SDL/src/audio/nds/SDL_ndsaudio.h | 40 + Externals/SDL/src/audio/nds/sound9.c | 61 + Externals/SDL/src/audio/nds/soundcommon.h | 80 + Externals/SDL/src/audio/nto/SDL_nto_audio.c | 507 + Externals/SDL/src/audio/nto/SDL_nto_audio.h | 68 + Externals/SDL/src/audio/paudio/SDL_paudio.c | 511 + Externals/SDL/src/audio/paudio/SDL_paudio.h | 57 + .../SDL/src/audio/pulse/SDL_pulseaudio.c | 534 + .../SDL/src/audio/pulse/SDL_pulseaudio.h | 71 + Externals/SDL/src/audio/sun/SDL_sunaudio.c | 432 + Externals/SDL/src/audio/sun/SDL_sunaudio.h | 55 + .../SDL/src/audio/symbian/SDL_epocaudio.cpp | 614 + .../SDL/src/audio/symbian/SDL_epocaudio.h | 37 + .../SDL/src/audio/symbian/streamplayer.cpp | 279 + .../SDL/src/audio/symbian/streamplayer.h | 89 + Externals/SDL/src/audio/ums/SDL_umsaudio.c | 547 + Externals/SDL/src/audio/ums/SDL_umsaudio.h | 50 + Externals/SDL/src/audio/windib/SDL_dibaudio.c | 322 + Externals/SDL/src/audio/windib/SDL_dibaudio.h | 49 + Externals/SDL/src/audio/windx5/SDL_dx5audio.c | 705 + Externals/SDL/src/audio/windx5/SDL_dx5audio.h | 55 + Externals/SDL/src/audio/windx5/directx.h | 84 + Externals/SDL/src/cdrom/SDL_cdrom.c | 341 + Externals/SDL/src/cdrom/SDL_syscdrom.h | 76 + Externals/SDL/src/cdrom/aix/SDL_syscdrom.c | 660 + Externals/SDL/src/cdrom/beos/SDL_syscdrom.cc | 412 + Externals/SDL/src/cdrom/bsdi/SDL_syscdrom.c | 542 + Externals/SDL/src/cdrom/dc/SDL_syscdrom.c | 167 + Externals/SDL/src/cdrom/dummy/SDL_syscdrom.c | 41 + .../SDL/src/cdrom/freebsd/SDL_syscdrom.c | 406 + Externals/SDL/src/cdrom/linux/SDL_syscdrom.c | 564 + Externals/SDL/src/cdrom/macos/SDL_syscdrom.c | 525 + .../SDL/src/cdrom/macos/SDL_syscdrom_c.h | 140 + .../SDL/src/cdrom/macosx/AudioFilePlayer.c | 360 + .../SDL/src/cdrom/macosx/AudioFilePlayer.h | 178 + .../src/cdrom/macosx/AudioFileReaderThread.c | 610 + Externals/SDL/src/cdrom/macosx/CDPlayer.c | 637 + Externals/SDL/src/cdrom/macosx/CDPlayer.h | 69 + .../SDL/src/cdrom/macosx/SDLOSXCAGuard.c | 199 + .../SDL/src/cdrom/macosx/SDLOSXCAGuard.h | 116 + Externals/SDL/src/cdrom/macosx/SDL_syscdrom.c | 514 + .../SDL/src/cdrom/macosx/SDL_syscdrom_c.h | 136 + Externals/SDL/src/cdrom/mint/SDL_syscdrom.c | 317 + .../SDL/src/cdrom/openbsd/SDL_syscdrom.c | 416 + Externals/SDL/src/cdrom/os2/SDL_syscdrom.c | 393 + Externals/SDL/src/cdrom/osf/SDL_syscdrom.c | 444 + Externals/SDL/src/cdrom/qnx/SDL_syscdrom.c | 551 + Externals/SDL/src/cdrom/win32/SDL_syscdrom.c | 386 + Externals/SDL/src/cpuinfo/SDL_cpuinfo.c | 479 + Externals/SDL/src/events/SDL_active.c | 95 + Externals/SDL/src/events/SDL_events.c | 502 + Externals/SDL/src/events/SDL_events_c.h | 83 + Externals/SDL/src/events/SDL_expose.c | 51 + Externals/SDL/src/events/SDL_keyboard.c | 614 + Externals/SDL/src/events/SDL_mouse.c | 268 + Externals/SDL/src/events/SDL_quit.c | 92 + Externals/SDL/src/events/SDL_resize.c | 76 + Externals/SDL/src/events/SDL_sysevents.h | 46 + Externals/SDL/src/file/SDL_rwops.c | 672 + Externals/SDL/src/hermes/COPYING.LIB | 438 + Externals/SDL/src/hermes/HeadMMX.h | 100 + Externals/SDL/src/hermes/HeadX86.h | 186 + Externals/SDL/src/hermes/README | 13 + Externals/SDL/src/hermes/common.inc | 9 + Externals/SDL/src/hermes/mmx_main.asm | 74 + Externals/SDL/src/hermes/mmxp2_32.asm | 405 + Externals/SDL/src/hermes/x86_main.asm | 75 + Externals/SDL/src/hermes/x86p_16.asm | 490 + Externals/SDL/src/hermes/x86p_32.asm | 1045 + Externals/SDL/src/joystick/SDL_joystick.c | 576 + Externals/SDL/src/joystick/SDL_joystick_c.h | 38 + Externals/SDL/src/joystick/SDL_sysjoystick.h | 82 + .../SDL/src/joystick/beos/SDL_bejoystick.cc | 237 + .../SDL/src/joystick/bsd/SDL_sysjoystick.c | 606 + .../src/joystick/darwin/10.3.9-FIX/IOHIDLib.h | 874 + .../SDL/src/joystick/darwin/SDL_sysjoystick.c | 846 + .../SDL/src/joystick/dc/SDL_sysjoystick.c | 193 + .../SDL/src/joystick/dummy/SDL_sysjoystick.c | 83 + .../SDL/src/joystick/linux/SDL_sysjoystick.c | 1202 + .../SDL/src/joystick/macos/SDL_sysjoystick.c | 320 + .../SDL/src/joystick/mint/SDL_sysjoystick.c | 826 + .../SDL/src/joystick/nds/SDL_sysjoystick.c | 150 + .../SDL/src/joystick/os2/SDL_sysjoystick.c | 668 + Externals/SDL/src/joystick/os2/joyos2.h | 177 + .../SDL/src/joystick/riscos/SDL_sysjoystick.c | 176 + .../SDL/src/joystick/win32/SDL_mmjoystick.c | 407 + Externals/SDL/src/loadso/beos/SDL_sysloadso.c | 72 + .../SDL/src/loadso/dlopen/SDL_sysloadso.c | 69 + .../SDL/src/loadso/dummy/SDL_sysloadso.c | 50 + .../SDL/src/loadso/macos/SDL_sysloadso.c | 106 + .../SDL/src/loadso/macosx/SDL_dlcompat.c | 1407 + Externals/SDL/src/loadso/mint/SDL_sysloadso.c | 62 + Externals/SDL/src/loadso/os2/SDL_sysloadso.c | 71 + .../SDL/src/loadso/win32/SDL_sysloadso.c | 139 + Externals/SDL/src/main/beos/SDL_BeApp.cc | 109 + Externals/SDL/src/main/beos/SDL_BeApp.h | 33 + Externals/SDL/src/main/dummy/SDL_dummy_main.c | 13 + Externals/SDL/src/main/macos/SDL.r | 58 + Externals/SDL/src/main/macos/SDL.shlib.r | 66 + Externals/SDL/src/main/macos/SDL_main.c | 610 + Externals/SDL/src/main/macos/SIZE.r | 24 + Externals/SDL/src/main/macos/exports/Makefile | 39 + Externals/SDL/src/main/macos/exports/SDL.x | 209 + .../SDL/src/main/macos/exports/gendef.pl | 43 + Externals/SDL/src/main/macosx/Info.plist.in | 24 + Externals/SDL/src/main/macosx/SDLMain.h | 16 + Externals/SDL/src/main/macosx/SDLMain.m | 381 + .../src/main/macosx/SDLMain.nib/classes.nib | 12 + .../SDL/src/main/macosx/SDLMain.nib/info.nib | 12 + .../src/main/macosx/SDLMain.nib/objects.nib | Bin 0 -> 1701 bytes Externals/SDL/src/main/macosx/info.nib | 1 + .../SDL/src/main/qtopia/SDL_qtopia_main.cc | 47 + .../SDL/src/main/symbian/EKA1/SDL_main.cpp | 152 + .../SDL/src/main/symbian/EKA2/SDL_main.cpp | 1035 + .../SDL/src/main/symbian/EKA2/sdlexe.cpp | 809 + .../SDL/src/main/symbian/EKA2/sdllib.cpp | 12 + .../src/main/symbian/EKA2/vectorbuffer.cpp | 62 + .../SDL/src/main/symbian/EKA2/vectorbuffer.h | 240 + Externals/SDL/src/main/win32/SDL_win32_main.c | 402 + Externals/SDL/src/main/win32/version.rc | 38 + Externals/SDL/src/stdlib/SDL_getenv.c | 247 + Externals/SDL/src/stdlib/SDL_iconv.c | 881 + Externals/SDL/src/stdlib/SDL_malloc.c | 5111 +++ Externals/SDL/src/stdlib/SDL_qsort.c | 443 + Externals/SDL/src/stdlib/SDL_stdlib.c | 620 + Externals/SDL/src/stdlib/SDL_string.c | 1248 + Externals/SDL/src/thread/SDL_systhread.h | 52 + Externals/SDL/src/thread/SDL_thread.c | 300 + Externals/SDL/src/thread/SDL_thread_c.h | 64 + Externals/SDL/src/thread/beos/SDL_syssem.c | 142 + Externals/SDL/src/thread/beos/SDL_systhread.c | 96 + .../SDL/src/thread/beos/SDL_systhread_c.h | 31 + Externals/SDL/src/thread/dc/SDL_syscond.c | 215 + Externals/SDL/src/thread/dc/SDL_syscond_c.h | 23 + Externals/SDL/src/thread/dc/SDL_sysmutex.c | 122 + Externals/SDL/src/thread/dc/SDL_sysmutex_c.h | 23 + Externals/SDL/src/thread/dc/SDL_syssem.c | 173 + Externals/SDL/src/thread/dc/SDL_syssem_c.h | 23 + Externals/SDL/src/thread/dc/SDL_systhread.c | 60 + Externals/SDL/src/thread/dc/SDL_systhread_c.h | 24 + .../SDL/src/thread/generic/SDL_syscond.c | 215 + .../SDL/src/thread/generic/SDL_sysmutex.c | 129 + .../SDL/src/thread/generic/SDL_sysmutex_c.h | 23 + Externals/SDL/src/thread/generic/SDL_syssem.c | 211 + .../SDL/src/thread/generic/SDL_systhread.c | 54 + .../SDL/src/thread/generic/SDL_systhread_c.h | 25 + Externals/SDL/src/thread/irix/SDL_syssem.c | 219 + Externals/SDL/src/thread/irix/SDL_systhread.c | 85 + .../SDL/src/thread/irix/SDL_systhread_c.h | 27 + Externals/SDL/src/thread/os2/SDL_syscond.c | 215 + Externals/SDL/src/thread/os2/SDL_syscond_c.h | 23 + Externals/SDL/src/thread/os2/SDL_sysmutex.c | 108 + Externals/SDL/src/thread/os2/SDL_syssem.c | 192 + Externals/SDL/src/thread/os2/SDL_systhread.c | 108 + .../SDL/src/thread/os2/SDL_systhread_c.h | 28 + Externals/SDL/src/thread/pth/SDL_syscond.c | 164 + Externals/SDL/src/thread/pth/SDL_sysmutex.c | 87 + Externals/SDL/src/thread/pth/SDL_sysmutex_c.h | 31 + Externals/SDL/src/thread/pth/SDL_systhread.c | 103 + .../SDL/src/thread/pth/SDL_systhread_c.h | 31 + .../SDL/src/thread/pthread/SDL_syscond.c | 155 + .../SDL/src/thread/pthread/SDL_sysmutex.c | 153 + .../SDL/src/thread/pthread/SDL_sysmutex_c.h | 31 + Externals/SDL/src/thread/pthread/SDL_syssem.c | 156 + .../SDL/src/thread/pthread/SDL_systhread.c | 120 + .../SDL/src/thread/pthread/SDL_systhread_c.h | 26 + Externals/SDL/src/thread/riscos/SDL_syscond.c | 160 + .../SDL/src/thread/riscos/SDL_sysmutex.c | 153 + .../SDL/src/thread/riscos/SDL_sysmutex_c.h | 34 + Externals/SDL/src/thread/riscos/SDL_syssem.c | 203 + .../SDL/src/thread/riscos/SDL_systhread.c | 144 + .../SDL/src/thread/riscos/SDL_systhread_c.h | 34 + .../SDL/src/thread/symbian/SDL_sysmutex.cpp | 130 + .../SDL/src/thread/symbian/SDL_syssem.cpp | 214 + .../SDL/src/thread/symbian/SDL_systhread.cpp | 146 + .../SDL/src/thread/symbian/SDL_systhread_c.h | 30 + Externals/SDL/src/thread/win32/SDL_sysmutex.c | 95 + Externals/SDL/src/thread/win32/SDL_syssem.c | 164 + .../SDL/src/thread/win32/SDL_systhread.c | 150 + .../SDL/src/thread/win32/SDL_systhread_c.h | 28 + .../SDL/src/thread/win32/win_ce_semaphore.c | 216 + .../SDL/src/thread/win32/win_ce_semaphore.h | 22 + Externals/SDL/src/timer/SDL_systimer.h | 40 + Externals/SDL/src/timer/SDL_timer.c | 285 + Externals/SDL/src/timer/SDL_timer_c.h | 46 + Externals/SDL/src/timer/beos/SDL_systimer.c | 95 + Externals/SDL/src/timer/dc/SDL_systimer.c | 100 + Externals/SDL/src/timer/dummy/SDL_systimer.c | 91 + Externals/SDL/src/timer/macos/FastTimes.c | 352 + Externals/SDL/src/timer/macos/FastTimes.h | 27 + Externals/SDL/src/timer/macos/SDL_MPWtimer.c | 152 + Externals/SDL/src/timer/macos/SDL_systimer.c | 186 + Externals/SDL/src/timer/mint/SDL_systimer.c | 147 + Externals/SDL/src/timer/mint/SDL_vbltimer.S | 159 + Externals/SDL/src/timer/mint/SDL_vbltimer_s.h | 35 + Externals/SDL/src/timer/nds/SDL_systimer.c | 73 + Externals/SDL/src/timer/os2/SDL_systimer.c | 227 + Externals/SDL/src/timer/riscos/SDL_systimer.c | 233 + .../SDL/src/timer/symbian/SDL_systimer.cpp | 114 + Externals/SDL/src/timer/unix/SDL_systimer.c | 240 + Externals/SDL/src/timer/win32/SDL_systimer.c | 160 + Externals/SDL/src/timer/wince/SDL_systimer.c | 198 + Externals/SDL/src/video/SDL_RLEaccel.c | 1943 + Externals/SDL/src/video/SDL_RLEaccel_c.h | 31 + Externals/SDL/src/video/SDL_blit.c | 360 + Externals/SDL/src/video/SDL_blit.h | 528 + Externals/SDL/src/video/SDL_blit_0.c | 471 + Externals/SDL/src/video/SDL_blit_1.c | 523 + Externals/SDL/src/video/SDL_blit_A.c | 2872 ++ Externals/SDL/src/video/SDL_blit_N.c | 2492 ++ Externals/SDL/src/video/SDL_bmp.c | 538 + Externals/SDL/src/video/SDL_cursor.c | 758 + Externals/SDL/src/video/SDL_cursor_c.h | 73 + Externals/SDL/src/video/SDL_gamma.c | 233 + Externals/SDL/src/video/SDL_glfuncs.h | 341 + Externals/SDL/src/video/SDL_leaks.h | 31 + Externals/SDL/src/video/SDL_pixels.c | 626 + Externals/SDL/src/video/SDL_pixels_c.h | 46 + Externals/SDL/src/video/SDL_stretch.c | 358 + Externals/SDL/src/video/SDL_stretch_c.h | 29 + Externals/SDL/src/video/SDL_surface.c | 941 + Externals/SDL/src/video/SDL_sysvideo.h | 424 + Externals/SDL/src/video/SDL_video.c | 1958 + Externals/SDL/src/video/SDL_yuv.c | 150 + Externals/SDL/src/video/SDL_yuv_mmx.c | 428 + Externals/SDL/src/video/SDL_yuv_sw.c | 1299 + Externals/SDL/src/video/SDL_yuv_sw_c.h | 37 + Externals/SDL/src/video/SDL_yuvfuncs.h | 37 + Externals/SDL/src/video/Xext/README | 10 + Externals/SDL/src/video/Xext/XME/xme.c | 410 + .../SDL/src/video/Xext/Xinerama/Xinerama.c | 324 + Externals/SDL/src/video/Xext/Xv/Xv.c | 1151 + Externals/SDL/src/video/Xext/Xv/Xvlibint.h | 81 + .../SDL/src/video/Xext/Xxf86dga/XF86DGA.c | 721 + .../SDL/src/video/Xext/Xxf86dga/XF86DGA2.c | 993 + .../SDL/src/video/Xext/Xxf86vm/XF86VMode.c | 1226 + .../SDL/src/video/Xext/extensions/Xext.h | 50 + .../SDL/src/video/Xext/extensions/Xinerama.h | 46 + Externals/SDL/src/video/Xext/extensions/Xv.h | 129 + .../SDL/src/video/Xext/extensions/Xvlib.h | 433 + .../SDL/src/video/Xext/extensions/Xvproto.h | 604 + .../SDL/src/video/Xext/extensions/extutil.h | 226 + .../src/video/Xext/extensions/panoramiXext.h | 52 + .../video/Xext/extensions/panoramiXproto.h | 192 + .../SDL/src/video/Xext/extensions/xf86dga.h | 265 + .../SDL/src/video/Xext/extensions/xf86dga1.h | 169 + .../src/video/Xext/extensions/xf86dga1str.h | 194 + .../src/video/Xext/extensions/xf86dgastr.h | 344 + .../SDL/src/video/Xext/extensions/xf86vmode.h | 314 + .../SDL/src/video/Xext/extensions/xf86vmstr.h | 546 + Externals/SDL/src/video/Xext/extensions/xme.h | 45 + Externals/SDL/src/video/aalib/SDL_aaevents.c | 202 + .../SDL/src/video/aalib/SDL_aaevents_c.h | 35 + Externals/SDL/src/video/aalib/SDL_aamouse.c | 35 + Externals/SDL/src/video/aalib/SDL_aamouse_c.h | 26 + Externals/SDL/src/video/aalib/SDL_aavideo.c | 388 + Externals/SDL/src/video/aalib/SDL_aavideo.h | 66 + .../SDL/src/video/ataricommon/SDL_ataric2p.S | 447 + .../src/video/ataricommon/SDL_ataric2p_s.h | 75 + .../src/video/ataricommon/SDL_ataridevmouse.c | 159 + .../video/ataricommon/SDL_ataridevmouse_c.h | 42 + .../SDL/src/video/ataricommon/SDL_atarieddi.S | 42 + .../src/video/ataricommon/SDL_atarieddi_s.h | 54 + .../src/video/ataricommon/SDL_atarievents.c | 239 + .../src/video/ataricommon/SDL_atarievents_c.h | 65 + .../SDL/src/video/ataricommon/SDL_atarigl.c | 1088 + .../SDL/src/video/ataricommon/SDL_atarigl_c.h | 109 + .../SDL/src/video/ataricommon/SDL_atarikeys.h | 140 + .../src/video/ataricommon/SDL_atarimxalloc.c | 52 + .../video/ataricommon/SDL_atarimxalloc_c.h | 47 + .../src/video/ataricommon/SDL_biosevents.c | 131 + .../src/video/ataricommon/SDL_biosevents_c.h | 42 + .../src/video/ataricommon/SDL_gemdosevents.c | 139 + .../video/ataricommon/SDL_gemdosevents_c.h | 42 + .../src/video/ataricommon/SDL_ikbdevents.c | 126 + .../src/video/ataricommon/SDL_ikbdevents_c.h | 42 + .../src/video/ataricommon/SDL_ikbdinterrupt.S | 260 + .../video/ataricommon/SDL_ikbdinterrupt_s.h | 61 + .../src/video/ataricommon/SDL_xbiosevents.c | 154 + .../src/video/ataricommon/SDL_xbiosevents_c.h | 48 + .../video/ataricommon/SDL_xbiosinterrupt.S | 172 + .../video/ataricommon/SDL_xbiosinterrupt_s.h | 52 + Externals/SDL/src/video/blank_cursor.h | 33 + Externals/SDL/src/video/bwindow/SDL_BView.h | 116 + Externals/SDL/src/video/bwindow/SDL_BWin.h | 284 + .../SDL/src/video/bwindow/SDL_lowvideo.h | 58 + .../SDL/src/video/bwindow/SDL_sysevents.cc | 398 + .../SDL/src/video/bwindow/SDL_sysevents_c.h | 31 + .../SDL/src/video/bwindow/SDL_sysmouse.cc | 153 + .../SDL/src/video/bwindow/SDL_sysmouse_c.h | 33 + .../SDL/src/video/bwindow/SDL_sysvideo.cc | 842 + Externals/SDL/src/video/bwindow/SDL_syswm.cc | 92 + Externals/SDL/src/video/bwindow/SDL_syswm_c.h | 32 + Externals/SDL/src/video/bwindow/SDL_sysyuv.cc | 314 + Externals/SDL/src/video/bwindow/SDL_sysyuv.h | 73 + Externals/SDL/src/video/caca/SDL_cacaevents.c | 101 + .../SDL/src/video/caca/SDL_cacaevents_c.h | 35 + Externals/SDL/src/video/caca/SDL_cacavideo.c | 304 + Externals/SDL/src/video/caca/SDL_cacavideo.h | 76 + Externals/SDL/src/video/dc/SDL_dcevents.c | 152 + Externals/SDL/src/video/dc/SDL_dcevents_c.h | 33 + Externals/SDL/src/video/dc/SDL_dcmouse.c | 35 + Externals/SDL/src/video/dc/SDL_dcmouse_c.h | 26 + Externals/SDL/src/video/dc/SDL_dcvideo.c | 445 + Externals/SDL/src/video/dc/SDL_dcvideo.h | 42 + Externals/SDL/src/video/default_cursor.h | 116 + Externals/SDL/src/video/dga/SDL_dgaevents.c | 163 + Externals/SDL/src/video/dga/SDL_dgaevents_c.h | 28 + Externals/SDL/src/video/dga/SDL_dgamouse.c | 35 + Externals/SDL/src/video/dga/SDL_dgamouse_c.h | 26 + Externals/SDL/src/video/dga/SDL_dgavideo.c | 1101 + Externals/SDL/src/video/dga/SDL_dgavideo.h | 124 + .../src/video/directfb/SDL_DirectFB_events.c | 210 + .../src/video/directfb/SDL_DirectFB_events.h | 29 + .../src/video/directfb/SDL_DirectFB_keys.h | 135 + .../src/video/directfb/SDL_DirectFB_video.c | 1171 + .../src/video/directfb/SDL_DirectFB_video.h | 62 + .../SDL/src/video/directfb/SDL_DirectFB_yuv.c | 290 + .../SDL/src/video/directfb/SDL_DirectFB_yuv.h | 38 + .../SDL/src/video/dummy/SDL_nullevents.c | 45 + .../SDL/src/video/dummy/SDL_nullevents_c.h | 33 + Externals/SDL/src/video/dummy/SDL_nullmouse.c | 33 + .../SDL/src/video/dummy/SDL_nullmouse_c.h | 26 + Externals/SDL/src/video/dummy/SDL_nullvideo.c | 239 + Externals/SDL/src/video/dummy/SDL_nullvideo.h | 40 + Externals/SDL/src/video/e_log.h | 140 + Externals/SDL/src/video/e_pow.h | 302 + Externals/SDL/src/video/e_sqrt.h | 493 + Externals/SDL/src/video/fbcon/3dfx_mmio.h | 56 + Externals/SDL/src/video/fbcon/3dfx_regs.h | 83 + Externals/SDL/src/video/fbcon/SDL_fb3dfx.c | 217 + Externals/SDL/src/video/fbcon/SDL_fb3dfx.h | 29 + Externals/SDL/src/video/fbcon/SDL_fbelo.c | 442 + Externals/SDL/src/video/fbcon/SDL_fbelo.h | 55 + Externals/SDL/src/video/fbcon/SDL_fbevents.c | 1245 + .../SDL/src/video/fbcon/SDL_fbevents_c.h | 38 + Externals/SDL/src/video/fbcon/SDL_fbkeys.h | 139 + Externals/SDL/src/video/fbcon/SDL_fbmatrox.c | 280 + Externals/SDL/src/video/fbcon/SDL_fbmatrox.h | 29 + Externals/SDL/src/video/fbcon/SDL_fbmouse.c | 33 + Externals/SDL/src/video/fbcon/SDL_fbmouse_c.h | 26 + Externals/SDL/src/video/fbcon/SDL_fbriva.c | 222 + Externals/SDL/src/video/fbcon/SDL_fbriva.h | 36 + Externals/SDL/src/video/fbcon/SDL_fbvideo.c | 1973 + Externals/SDL/src/video/fbcon/SDL_fbvideo.h | 200 + Externals/SDL/src/video/fbcon/matrox_mmio.h | 51 + Externals/SDL/src/video/fbcon/matrox_regs.h | 376 + Externals/SDL/src/video/fbcon/riva_mmio.h | 449 + Externals/SDL/src/video/fbcon/riva_regs.h | 43 + Externals/SDL/src/video/gapi/SDL_gapivideo.c | 1287 + Externals/SDL/src/video/gapi/SDL_gapivideo.h | 160 + Externals/SDL/src/video/gem/SDL_gemevents.c | 370 + Externals/SDL/src/video/gem/SDL_gemevents_c.h | 33 + Externals/SDL/src/video/gem/SDL_gemmouse.c | 204 + Externals/SDL/src/video/gem/SDL_gemmouse_c.h | 34 + Externals/SDL/src/video/gem/SDL_gemvideo.c | 1340 + Externals/SDL/src/video/gem/SDL_gemvideo.h | 191 + Externals/SDL/src/video/gem/SDL_gemwm.c | 116 + Externals/SDL/src/video/gem/SDL_gemwm_c.h | 37 + Externals/SDL/src/video/ggi/SDL_ggievents.c | 264 + Externals/SDL/src/video/ggi/SDL_ggievents_c.h | 29 + Externals/SDL/src/video/ggi/SDL_ggikeys.h | 135 + Externals/SDL/src/video/ggi/SDL_ggimouse.c | 32 + Externals/SDL/src/video/ggi/SDL_ggimouse_c.h | 26 + Externals/SDL/src/video/ggi/SDL_ggivideo.c | 378 + Externals/SDL/src/video/ggi/SDL_ggivideo.h | 48 + Externals/SDL/src/video/ipod/SDL_ipodvideo.c | 733 + Externals/SDL/src/video/ipod/SDL_ipodvideo.h | 38 + .../SDL/src/video/maccommon/SDL_lowvideo.h | 102 + .../SDL/src/video/maccommon/SDL_macevents.c | 746 + .../SDL/src/video/maccommon/SDL_macevents_c.h | 32 + Externals/SDL/src/video/maccommon/SDL_macgl.c | 197 + .../SDL/src/video/maccommon/SDL_macgl_c.h | 47 + .../SDL/src/video/maccommon/SDL_mackeys.h | 140 + .../SDL/src/video/maccommon/SDL_macmouse.c | 129 + .../SDL/src/video/maccommon/SDL_macmouse_c.h | 34 + Externals/SDL/src/video/maccommon/SDL_macwm.c | 442 + .../SDL/src/video/maccommon/SDL_macwm_c.h | 41 + Externals/SDL/src/video/macdsp/SDL_dspvideo.c | 1422 + Externals/SDL/src/video/macdsp/SDL_dspvideo.h | 54 + Externals/SDL/src/video/macrom/SDL_romvideo.c | 745 + Externals/SDL/src/video/macrom/SDL_romvideo.h | 29 + Externals/SDL/src/video/math_private.h | 173 + Externals/SDL/src/video/mmx.h | 704 + Externals/SDL/src/video/nanox/SDL_nxevents.c | 382 + .../SDL/src/video/nanox/SDL_nxevents_c.h | 32 + Externals/SDL/src/video/nanox/SDL_nximage.c | 230 + Externals/SDL/src/video/nanox/SDL_nximage_c.h | 35 + Externals/SDL/src/video/nanox/SDL_nxmodes.c | 84 + Externals/SDL/src/video/nanox/SDL_nxmodes_c.h | 34 + Externals/SDL/src/video/nanox/SDL_nxmouse.c | 79 + Externals/SDL/src/video/nanox/SDL_nxmouse_c.h | 29 + Externals/SDL/src/video/nanox/SDL_nxvideo.c | 544 + Externals/SDL/src/video/nanox/SDL_nxvideo.h | 96 + Externals/SDL/src/video/nanox/SDL_nxwm.c | 61 + Externals/SDL/src/video/nanox/SDL_nxwm_c.h | 32 + Externals/SDL/src/video/nds/SDL_ndsevents.c | 83 + Externals/SDL/src/video/nds/SDL_ndsevents_c.h | 51 + Externals/SDL/src/video/nds/SDL_ndsmouse.c | 34 + Externals/SDL/src/video/nds/SDL_ndsmouse_c.h | 26 + Externals/SDL/src/video/nds/SDL_ndsvideo.c | 500 + Externals/SDL/src/video/nds/SDL_ndsvideo.h | 61 + .../SDL/src/video/os2fslib/SDL_os2fslib.c | 3018 ++ .../SDL/src/video/os2fslib/SDL_os2fslib.h | 71 + Externals/SDL/src/video/os2fslib/SDL_vkeys.h | 74 + .../SDL/src/video/photon/SDL_ph_events.c | 624 + .../SDL/src/video/photon/SDL_ph_events_c.h | 37 + Externals/SDL/src/video/photon/SDL_ph_gl.c | 406 + Externals/SDL/src/video/photon/SDL_ph_gl.h | 41 + Externals/SDL/src/video/photon/SDL_ph_image.c | 1059 + .../SDL/src/video/photon/SDL_ph_image_c.h | 59 + Externals/SDL/src/video/photon/SDL_ph_modes.c | 390 + .../SDL/src/video/photon/SDL_ph_modes_c.h | 43 + Externals/SDL/src/video/photon/SDL_ph_mouse.c | 220 + .../SDL/src/video/photon/SDL_ph_mouse_c.h | 39 + Externals/SDL/src/video/photon/SDL_ph_video.c | 648 + Externals/SDL/src/video/photon/SDL_ph_video.h | 157 + Externals/SDL/src/video/photon/SDL_ph_wm.c | 118 + Externals/SDL/src/video/photon/SDL_ph_wm_c.h | 37 + Externals/SDL/src/video/photon/SDL_phyuv.c | 504 + Externals/SDL/src/video/photon/SDL_phyuv_c.h | 62 + .../SDL/src/video/picogui/SDL_pgevents.c | 117 + .../SDL/src/video/picogui/SDL_pgevents_c.h | 37 + Externals/SDL/src/video/picogui/SDL_pgvideo.c | 364 + Externals/SDL/src/video/picogui/SDL_pgvideo.h | 50 + Externals/SDL/src/video/ps2gs/SDL_gsevents.c | 977 + .../SDL/src/video/ps2gs/SDL_gsevents_c.h | 38 + Externals/SDL/src/video/ps2gs/SDL_gskeys.h | 139 + Externals/SDL/src/video/ps2gs/SDL_gsmouse.c | 146 + Externals/SDL/src/video/ps2gs/SDL_gsmouse_c.h | 37 + Externals/SDL/src/video/ps2gs/SDL_gsvideo.c | 689 + Externals/SDL/src/video/ps2gs/SDL_gsvideo.h | 95 + Externals/SDL/src/video/ps2gs/SDL_gsyuv.c | 461 + Externals/SDL/src/video/ps2gs/SDL_gsyuv_c.h | 37 + Externals/SDL/src/video/ps3/SDL_ps3events.c | 44 + Externals/SDL/src/video/ps3/SDL_ps3events_c.h | 41 + Externals/SDL/src/video/ps3/SDL_ps3video.c | 621 + Externals/SDL/src/video/ps3/SDL_ps3video.h | 165 + Externals/SDL/src/video/ps3/SDL_ps3yuv.c | 340 + Externals/SDL/src/video/ps3/SDL_ps3yuv_c.h | 44 + Externals/SDL/src/video/ps3/spulibs/Makefile | 83 + .../SDL/src/video/ps3/spulibs/bilin_scaler.c | 2050 + .../SDL/src/video/ps3/spulibs/fb_writer.c | 193 + .../SDL/src/video/ps3/spulibs/spu_common.h | 108 + .../src/video/ps3/spulibs/yuv2rgb_converter.c | 629 + Externals/SDL/src/video/qtopia/SDL_QPEApp.cc | 63 + Externals/SDL/src/video/qtopia/SDL_QPEApp.h | 33 + Externals/SDL/src/video/qtopia/SDL_QWin.cc | 527 + Externals/SDL/src/video/qtopia/SDL_QWin.h | 110 + Externals/SDL/src/video/qtopia/SDL_lowvideo.h | 65 + .../SDL/src/video/qtopia/SDL_sysevents.cc | 269 + .../SDL/src/video/qtopia/SDL_sysevents_c.h | 31 + .../SDL/src/video/qtopia/SDL_sysmouse.cc | 56 + .../SDL/src/video/qtopia/SDL_sysmouse_c.h | 32 + .../SDL/src/video/qtopia/SDL_sysvideo.cc | 403 + Externals/SDL/src/video/qtopia/SDL_syswm.cc | 35 + Externals/SDL/src/video/qtopia/SDL_syswm_c.h | 28 + Externals/SDL/src/video/quartz/CGS.h | 84 + .../SDL/src/video/quartz/SDL_QuartzEvents.m | 996 + Externals/SDL/src/video/quartz/SDL_QuartzGL.m | 292 + .../SDL/src/video/quartz/SDL_QuartzKeys.h | 146 + .../SDL/src/video/quartz/SDL_QuartzVideo.h | 228 + .../SDL/src/video/quartz/SDL_QuartzVideo.m | 1368 + Externals/SDL/src/video/quartz/SDL_QuartzWM.h | 27 + Externals/SDL/src/video/quartz/SDL_QuartzWM.m | 440 + .../SDL/src/video/quartz/SDL_QuartzWindow.h | 51 + .../SDL/src/video/quartz/SDL_QuartzWindow.m | 231 + .../SDL/src/video/riscos/SDL_riscosASM.S | 116 + .../video/riscos/SDL_riscosFullScreenVideo.c | 777 + .../SDL/src/video/riscos/SDL_riscosevents.c | 549 + .../SDL/src/video/riscos/SDL_riscosevents_c.h | 34 + .../SDL/src/video/riscos/SDL_riscosmouse.c | 371 + .../SDL/src/video/riscos/SDL_riscosmouse_c.h | 44 + .../SDL/src/video/riscos/SDL_riscossprite.c | 265 + .../SDL/src/video/riscos/SDL_riscostask.c | 350 + .../SDL/src/video/riscos/SDL_riscostask.h | 39 + .../SDL/src/video/riscos/SDL_riscosvideo.c | 316 + .../SDL/src/video/riscos/SDL_riscosvideo.h | 62 + Externals/SDL/src/video/riscos/SDL_wimppoll.c | 330 + .../SDL/src/video/riscos/SDL_wimpvideo.c | 501 + Externals/SDL/src/video/svga/SDL_svgaevents.c | 412 + .../SDL/src/video/svga/SDL_svgaevents_c.h | 35 + Externals/SDL/src/video/svga/SDL_svgamouse.c | 33 + .../SDL/src/video/svga/SDL_svgamouse_c.h | 26 + Externals/SDL/src/video/svga/SDL_svgavideo.c | 584 + Externals/SDL/src/video/svga/SDL_svgavideo.h | 58 + .../src/video/symbian/EKA1/SDL_epocevents.cpp | 626 + .../src/video/symbian/EKA1/SDL_epocvideo.cpp | 1356 + .../src/video/symbian/EKA1/SDL_epocvideo.h | 34 + .../src/video/symbian/EKA2/SDL_epocevents.cpp | 521 + .../src/video/symbian/EKA2/SDL_epocvideo.cpp | 594 + .../src/video/symbian/EKA2/SDL_epocvideo.h | 51 + Externals/SDL/src/video/symbian/EKA2/dsa.cpp | 1505 + .../SDL/src/video/symbian/EKA2/dsa_new.cpp | 1443 + .../SDL/src/video/symbian/EKA2/dsa_old.cpp | 1075 + .../SDL/src/video/symbian/SDL_epocevents_c.h | 60 + Externals/SDL/src/video/vgl/SDL_vglevents.c | 299 + Externals/SDL/src/video/vgl/SDL_vglevents_c.h | 155 + Externals/SDL/src/video/vgl/SDL_vglmouse.c | 56 + Externals/SDL/src/video/vgl/SDL_vglmouse_c.h | 32 + Externals/SDL/src/video/vgl/SDL_vglvideo.c | 640 + Externals/SDL/src/video/vgl/SDL_vglvideo.h | 65 + .../SDL/src/video/wincommon/SDL_lowvideo.h | 148 + .../SDL/src/video/wincommon/SDL_sysevents.c | 865 + .../SDL/src/video/wincommon/SDL_sysmouse.c | 259 + .../SDL/src/video/wincommon/SDL_sysmouse_c.h | 33 + Externals/SDL/src/video/wincommon/SDL_syswm.c | 297 + .../SDL/src/video/wincommon/SDL_syswm_c.h | 35 + Externals/SDL/src/video/wincommon/SDL_wingl.c | 647 + .../SDL/src/video/wincommon/SDL_wingl_c.h | 135 + Externals/SDL/src/video/wincommon/wmmsg.h | 1030 + .../SDL/src/video/windib/SDL_dibevents.c | 705 + .../SDL/src/video/windib/SDL_dibevents_c.h | 35 + Externals/SDL/src/video/windib/SDL_dibvideo.c | 1321 + Externals/SDL/src/video/windib/SDL_dibvideo.h | 59 + .../SDL/src/video/windib/SDL_gapidibvideo.h | 56 + Externals/SDL/src/video/windib/SDL_vkeys.h | 75 + .../SDL/src/video/windx5/SDL_dx5events.c | 1008 + .../SDL/src/video/windx5/SDL_dx5events_c.h | 37 + Externals/SDL/src/video/windx5/SDL_dx5video.c | 2536 ++ Externals/SDL/src/video/windx5/SDL_dx5video.h | 61 + Externals/SDL/src/video/windx5/SDL_dx5yuv.c | 296 + Externals/SDL/src/video/windx5/SDL_dx5yuv_c.h | 38 + Externals/SDL/src/video/windx5/directx.h | 100 + .../SDL/src/video/wscons/SDL_wsconsevents.c | 233 + .../SDL/src/video/wscons/SDL_wsconsevents_c.h | 36 + .../SDL/src/video/wscons/SDL_wsconsmouse.c | 33 + .../SDL/src/video/wscons/SDL_wsconsmouse_c.h | 26 + .../SDL/src/video/wscons/SDL_wsconsvideo.c | 609 + .../SDL/src/video/wscons/SDL_wsconsvideo.h | 76 + Externals/SDL/src/video/x11/SDL_x11dga.c | 90 + Externals/SDL/src/video/x11/SDL_x11dga_c.h | 33 + Externals/SDL/src/video/x11/SDL_x11dyn.c | 192 + Externals/SDL/src/video/x11/SDL_x11dyn.h | 93 + Externals/SDL/src/video/x11/SDL_x11events.c | 1396 + Externals/SDL/src/video/x11/SDL_x11events_c.h | 29 + Externals/SDL/src/video/x11/SDL_x11gamma.c | 142 + Externals/SDL/src/video/x11/SDL_x11gamma_c.h | 32 + Externals/SDL/src/video/x11/SDL_x11gl.c | 570 + Externals/SDL/src/video/x11/SDL_x11gl_c.h | 98 + Externals/SDL/src/video/x11/SDL_x11image.c | 318 + Externals/SDL/src/video/x11/SDL_x11image_c.h | 38 + Externals/SDL/src/video/x11/SDL_x11modes.c | 1145 + Externals/SDL/src/video/x11/SDL_x11modes_c.h | 43 + Externals/SDL/src/video/x11/SDL_x11mouse.c | 284 + Externals/SDL/src/video/x11/SDL_x11mouse_c.h | 33 + Externals/SDL/src/video/x11/SDL_x11sym.h | 195 + Externals/SDL/src/video/x11/SDL_x11video.c | 1549 + Externals/SDL/src/video/x11/SDL_x11video.h | 214 + Externals/SDL/src/video/x11/SDL_x11wm.c | 434 + Externals/SDL/src/video/x11/SDL_x11wm_c.h | 34 + Externals/SDL/src/video/x11/SDL_x11yuv.c | 538 + Externals/SDL/src/video/x11/SDL_x11yuv_c.h | 41 + Externals/SDL/src/video/xbios/SDL_xbios.c | 1117 + Externals/SDL/src/video/xbios/SDL_xbios.h | 121 + .../SDL/src/video/xbios/SDL_xbios_blowup.c | 77 + .../SDL/src/video/xbios/SDL_xbios_blowup.h | 86 + .../src/video/xbios/SDL_xbios_centscreen.c | 104 + .../src/video/xbios/SDL_xbios_centscreen.h | 118 + .../SDL/src/video/xbios/SDL_xbios_milan.c | 111 + .../SDL/src/video/xbios/SDL_xbios_milan.h | 138 + Externals/SDL/src/video/xbios/SDL_xbios_sb3.c | 83 + Externals/SDL/src/video/xbios/SDL_xbios_sb3.h | 82 + .../SDL/src/video/xbios/SDL_xbios_tveille.c | 52 + .../SDL/src/video/xbios/SDL_xbios_tveille.h | 70 + Externals/SDL/symbian.zip | Bin 0 -> 378899 bytes Externals/SDL/test/COPYING | 8 + Externals/SDL/test/Makefile.in | 117 + Externals/SDL/test/README | 35 + Externals/SDL/test/acinclude.m4 | 181 + Externals/SDL/test/aclocal.m4 | 181 + Externals/SDL/test/autogen.sh | 12 + Externals/SDL/test/checkkeys.c | 146 + Externals/SDL/test/configure | 5000 +++ Externals/SDL/test/configure.in | 105 + Externals/SDL/test/gcc-fat.sh | 134 + Externals/SDL/test/graywin.c | 257 + Externals/SDL/test/icon.bmp | Bin 0 -> 578 bytes Externals/SDL/test/loopwave.c | 114 + Externals/SDL/test/moose.dat | Bin 0 -> 56320 bytes Externals/SDL/test/picture.xbm | 14 + Externals/SDL/test/sail.bmp | Bin 0 -> 15858 bytes Externals/SDL/test/sample.bmp | Bin 0 -> 69202 bytes Externals/SDL/test/sample.wav | Bin 0 -> 121946 bytes Externals/SDL/test/testalpha.c | 537 + Externals/SDL/test/testbitmap.c | 184 + Externals/SDL/test/testblitspeed.c | 420 + Externals/SDL/test/testcdrom.c | 209 + Externals/SDL/test/testcursor.c | 216 + Externals/SDL/test/testdyngl.c | 209 + Externals/SDL/test/testerror.c | 61 + Externals/SDL/test/testfile.c | 182 + Externals/SDL/test/testgamma.c | 197 + Externals/SDL/test/testgl.c | 856 + Externals/SDL/test/testhread.c | 82 + Externals/SDL/test/testiconv.c | 73 + Externals/SDL/test/testjoystick.c | 188 + Externals/SDL/test/testkeys.c | 25 + Externals/SDL/test/testloadso.c | 71 + Externals/SDL/test/testlock.c | 102 + Externals/SDL/test/testoverlay.c | 594 + Externals/SDL/test/testoverlay2.c | 600 + Externals/SDL/test/testpalette.c | 342 + Externals/SDL/test/testplatform.c | 210 + Externals/SDL/test/testsem.c | 78 + Externals/SDL/test/testsprite.c | 323 + Externals/SDL/test/testtimer.c | 87 + Externals/SDL/test/testver.c | 37 + Externals/SDL/test/testvidinfo.c | 465 + Externals/SDL/test/testwin.c | 377 + Externals/SDL/test/testwm.c | 443 + Externals/SDL/test/threadwin.c | 338 + Externals/SDL/test/torturethread.c | 91 + Externals/SDL/test/utf8.txt | 287 + 1842 files changed, 398859 insertions(+) create mode 100644 Externals/GLew/LICENSE.txt create mode 100644 Externals/GLew/Makefile create mode 100644 Externals/GLew/README.txt create mode 100644 Externals/GLew/TODO.txt create mode 100644 Externals/GLew/auto/Makefile create mode 100755 Externals/GLew/auto/bin/fix_OML_sync_control.sh create mode 100755 Externals/GLew/auto/bin/make.pl create mode 100755 Externals/GLew/auto/bin/make_def_fun.pl create mode 100755 Externals/GLew/auto/bin/make_def_var.pl create mode 100755 Externals/GLew/auto/bin/make_header.pl create mode 100755 Externals/GLew/auto/bin/make_html.pl create mode 100755 Externals/GLew/auto/bin/make_info.pl create mode 100755 Externals/GLew/auto/bin/make_info_list.pl create mode 100755 Externals/GLew/auto/bin/make_init.pl create mode 100755 Externals/GLew/auto/bin/make_list.pl create mode 100755 Externals/GLew/auto/bin/make_str.pl create mode 100755 Externals/GLew/auto/bin/make_struct_fun.pl create mode 100755 Externals/GLew/auto/bin/make_struct_var.pl create mode 100755 Externals/GLew/auto/bin/parse_spec.pl create mode 100755 Externals/GLew/auto/bin/update_ext.sh create mode 100755 Externals/GLew/auto/bin/update_registry.sh create mode 100644 Externals/GLew/auto/blacklist create mode 100644 Externals/GLew/auto/core/GLX_ARB_get_proc_address create mode 100644 Externals/GLew/auto/core/GLX_ATI_pixel_format_float create mode 100644 Externals/GLew/auto/core/GLX_ATI_render_texture create mode 100644 Externals/GLew/auto/core/GLX_EXT_fbconfig_packed_float create mode 100644 Externals/GLew/auto/core/GLX_EXT_framebuffer_sRGB create mode 100644 Externals/GLew/auto/core/GLX_NV_float_buffer create mode 100644 Externals/GLew/auto/core/GLX_NV_vertex_array_range create mode 100644 Externals/GLew/auto/core/GLX_SGIS_shared_multisample create mode 100644 Externals/GLew/auto/core/GLX_SGIX_hyperpipe create mode 100644 Externals/GLew/auto/core/GLX_SGIX_swap_barrier create mode 100644 Externals/GLew/auto/core/GLX_SGIX_swap_group create mode 100644 Externals/GLew/auto/core/GLX_SUN_video_resize create mode 100644 Externals/GLew/auto/core/GLX_VERSION_1_2 create mode 100644 Externals/GLew/auto/core/GLX_VERSION_1_3 create mode 100644 Externals/GLew/auto/core/GLX_VERSION_1_4 create mode 100644 Externals/GLew/auto/core/GL_APPLE_float_pixels create mode 100644 Externals/GLew/auto/core/GL_APPLE_pixel_buffer create mode 100644 Externals/GLew/auto/core/GL_APPLE_texture_range create mode 100644 Externals/GLew/auto/core/GL_ARB_imaging create mode 100644 Externals/GLew/auto/core/GL_ARB_matrix_palette create mode 100644 Externals/GLew/auto/core/GL_ARB_multitexture create mode 100644 Externals/GLew/auto/core/GL_ARB_vertex_blend create mode 100644 Externals/GLew/auto/core/GL_ATIX_point_sprites create mode 100644 Externals/GLew/auto/core/GL_ATIX_texture_env_combine3 create mode 100644 Externals/GLew/auto/core/GL_ATIX_texture_env_route create mode 100644 Externals/GLew/auto/core/GL_ATIX_vertex_shader_output_point_size create mode 100644 Externals/GLew/auto/core/GL_ATI_envmap_bumpmap create mode 100644 Externals/GLew/auto/core/GL_ATI_map_object_buffer create mode 100644 Externals/GLew/auto/core/GL_ATI_pn_triangles create mode 100644 Externals/GLew/auto/core/GL_ATI_separate_stencil create mode 100644 Externals/GLew/auto/core/GL_ATI_shader_texture_lod create mode 100644 Externals/GLew/auto/core/GL_ATI_texture_compression_3dc create mode 100644 Externals/GLew/auto/core/GL_ATI_vertex_streams create mode 100644 Externals/GLew/auto/core/GL_EXT_Cg_shader create mode 100644 Externals/GLew/auto/core/GL_EXT_bindable_uniform create mode 100644 Externals/GLew/auto/core/GL_EXT_depth_bounds_test create mode 100644 Externals/GLew/auto/core/GL_EXT_draw_instanced create mode 100644 Externals/GLew/auto/core/GL_EXT_draw_range_elements create mode 100644 Externals/GLew/auto/core/GL_EXT_fog_coord create mode 100644 Externals/GLew/auto/core/GL_EXT_framebuffer_sRGB create mode 100644 Externals/GLew/auto/core/GL_EXT_geometry_shader4 create mode 100644 Externals/GLew/auto/core/GL_EXT_gpu_program_parameters create mode 100644 Externals/GLew/auto/core/GL_EXT_gpu_shader4 create mode 100644 Externals/GLew/auto/core/GL_EXT_packed_float create mode 100644 Externals/GLew/auto/core/GL_EXT_pixel_buffer_object create mode 100644 Externals/GLew/auto/core/GL_EXT_secondary_color create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_array create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_buffer_object create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_compression_latc create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_compression_rgtc create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_cube_map create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_edge_clamp create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_integer create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_rectangle create mode 100644 Externals/GLew/auto/core/GL_EXT_texture_shared_exponent create mode 100644 Externals/GLew/auto/core/GL_EXT_timer_query create mode 100644 Externals/GLew/auto/core/GL_EXT_vertex_shader create mode 100644 Externals/GLew/auto/core/GL_KTX_buffer_region create mode 100644 Externals/GLew/auto/core/GL_NV_depth_buffer_float create mode 100644 Externals/GLew/auto/core/GL_NV_depth_range_unclamped create mode 100644 Externals/GLew/auto/core/GL_NV_fragment_program2 create mode 100644 Externals/GLew/auto/core/GL_NV_fragment_program4 create mode 100644 Externals/GLew/auto/core/GL_NV_fragment_program_option create mode 100644 Externals/GLew/auto/core/GL_NV_framebuffer_multisample_coverage create mode 100644 Externals/GLew/auto/core/GL_NV_geometry_program4 create mode 100644 Externals/GLew/auto/core/GL_NV_geometry_shader4 create mode 100644 Externals/GLew/auto/core/GL_NV_gpu_program4 create mode 100644 Externals/GLew/auto/core/GL_NV_parameter_buffer_object create mode 100644 Externals/GLew/auto/core/GL_NV_present_video create mode 100644 Externals/GLew/auto/core/GL_NV_tessellation_program5 create mode 100644 Externals/GLew/auto/core/GL_NV_transform_feedback create mode 100644 Externals/GLew/auto/core/GL_NV_vertex_program2_option create mode 100644 Externals/GLew/auto/core/GL_NV_vertex_program3 create mode 100644 Externals/GLew/auto/core/GL_NV_vertex_program4 create mode 100644 Externals/GLew/auto/core/GL_SGIX_shadow create mode 100644 Externals/GLew/auto/core/GL_SUN_read_video_pixels create mode 100644 Externals/GLew/auto/core/GL_VERSION_1_2 create mode 100644 Externals/GLew/auto/core/GL_VERSION_1_3 create mode 100644 Externals/GLew/auto/core/GL_VERSION_1_4 create mode 100644 Externals/GLew/auto/core/GL_VERSION_1_5 create mode 100644 Externals/GLew/auto/core/GL_VERSION_2_0 create mode 100644 Externals/GLew/auto/core/GL_VERSION_2_1 create mode 100644 Externals/GLew/auto/core/GL_VERSION_3_0 create mode 100644 Externals/GLew/auto/core/GL_VERSION_3_1 create mode 100644 Externals/GLew/auto/core/GL_VERSION_3_2 create mode 100644 Externals/GLew/auto/core/GL_VERSION_3_3 create mode 100644 Externals/GLew/auto/core/GL_VERSION_4_0 create mode 100644 Externals/GLew/auto/core/GL_WIN_swap_hint create mode 100644 Externals/GLew/auto/core/WGL_ATI_render_texture_rectangle create mode 100644 Externals/GLew/auto/core/WGL_EXT_framebuffer_sRGB create mode 100644 Externals/GLew/auto/core/WGL_EXT_pixel_format_packed_float create mode 100644 Externals/GLew/auto/core/WGL_NV_gpu_affinity create mode 100644 Externals/GLew/auto/core/WGL_NV_vertex_array_range create mode 100644 Externals/GLew/auto/custom.txt create mode 100644 Externals/GLew/auto/doc/advanced.html create mode 100644 Externals/GLew/auto/doc/basic.html create mode 100644 Externals/GLew/auto/doc/credits.html create mode 100644 Externals/GLew/auto/doc/index.html create mode 100644 Externals/GLew/auto/doc/install.html create mode 100644 Externals/GLew/auto/doc/log.html create mode 100644 Externals/GLew/auto/extensions/.dummy create mode 100644 Externals/GLew/auto/extensions/GLX_3DFX_multisample create mode 100644 Externals/GLew/auto/extensions/GLX_ARB_create_context create mode 100644 Externals/GLew/auto/extensions/GLX_ARB_create_context_profile create mode 100644 Externals/GLew/auto/extensions/GLX_ARB_fbconfig_float create mode 100644 Externals/GLew/auto/extensions/GLX_ARB_framebuffer_sRGB create mode 100644 Externals/GLew/auto/extensions/GLX_ARB_get_proc_address create mode 100644 Externals/GLew/auto/extensions/GLX_ARB_multisample create mode 100644 Externals/GLew/auto/extensions/GLX_ARB_vertex_buffer_object create mode 100644 Externals/GLew/auto/extensions/GLX_ATI_pixel_format_float create mode 100644 Externals/GLew/auto/extensions/GLX_ATI_render_texture create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_fbconfig_packed_float create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_framebuffer_sRGB create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_import_context create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_scene_marker create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_swap_control create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_texture_from_pixmap create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_visual_info create mode 100644 Externals/GLew/auto/extensions/GLX_EXT_visual_rating create mode 100644 Externals/GLew/auto/extensions/GLX_INTEL_swap_event create mode 100644 Externals/GLew/auto/extensions/GLX_MESA_agp_offset create mode 100644 Externals/GLew/auto/extensions/GLX_MESA_copy_sub_buffer create mode 100644 Externals/GLew/auto/extensions/GLX_MESA_pixmap_colormap create mode 100644 Externals/GLew/auto/extensions/GLX_MESA_release_buffers create mode 100644 Externals/GLew/auto/extensions/GLX_MESA_set_3dfx_mode create mode 100644 Externals/GLew/auto/extensions/GLX_NV_copy_image create mode 100644 Externals/GLew/auto/extensions/GLX_NV_float_buffer create mode 100644 Externals/GLew/auto/extensions/GLX_NV_present_video create mode 100644 Externals/GLew/auto/extensions/GLX_NV_swap_group create mode 100644 Externals/GLew/auto/extensions/GLX_NV_vertex_array_range create mode 100644 Externals/GLew/auto/extensions/GLX_NV_video_output create mode 100644 Externals/GLew/auto/extensions/GLX_OML_swap_method create mode 100644 Externals/GLew/auto/extensions/GLX_OML_sync_control create mode 100644 Externals/GLew/auto/extensions/GLX_SGIS_blended_overlay create mode 100644 Externals/GLew/auto/extensions/GLX_SGIS_color_range create mode 100644 Externals/GLew/auto/extensions/GLX_SGIS_multisample create mode 100644 Externals/GLew/auto/extensions/GLX_SGIS_shared_multisample create mode 100644 Externals/GLew/auto/extensions/GLX_SGIX_fbconfig create mode 100644 Externals/GLew/auto/extensions/GLX_SGIX_hyperpipe create mode 100644 Externals/GLew/auto/extensions/GLX_SGIX_pbuffer create mode 100644 Externals/GLew/auto/extensions/GLX_SGIX_swap_barrier create mode 100644 Externals/GLew/auto/extensions/GLX_SGIX_swap_group create mode 100644 Externals/GLew/auto/extensions/GLX_SGIX_video_resize create mode 100644 Externals/GLew/auto/extensions/GLX_SGIX_visual_select_group create mode 100644 Externals/GLew/auto/extensions/GLX_SGI_cushion create mode 100644 Externals/GLew/auto/extensions/GLX_SGI_make_current_read create mode 100644 Externals/GLew/auto/extensions/GLX_SGI_swap_control create mode 100644 Externals/GLew/auto/extensions/GLX_SGI_video_sync create mode 100644 Externals/GLew/auto/extensions/GLX_SUN_get_transparent_index create mode 100644 Externals/GLew/auto/extensions/GLX_SUN_video_resize create mode 100644 Externals/GLew/auto/extensions/GL_3DFX_multisample create mode 100644 Externals/GLew/auto/extensions/GL_3DFX_tbuffer create mode 100644 Externals/GLew/auto/extensions/GL_3DFX_texture_compression_FXT1 create mode 100644 Externals/GLew/auto/extensions/GL_AMD_conservative_depth create mode 100644 Externals/GLew/auto/extensions/GL_AMD_draw_buffers_blend create mode 100644 Externals/GLew/auto/extensions/GL_AMD_performance_monitor create mode 100644 Externals/GLew/auto/extensions/GL_AMD_seamless_cubemap_per_texture create mode 100644 Externals/GLew/auto/extensions/GL_AMD_shader_stencil_export create mode 100644 Externals/GLew/auto/extensions/GL_AMD_texture_texture4 create mode 100644 Externals/GLew/auto/extensions/GL_AMD_vertex_shader_tessellator create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_aux_depth_stencil create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_client_storage create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_element_array create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_fence create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_float_pixels create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_flush_buffer_range create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_object_purgeable create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_pixel_buffer create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_rgb_422 create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_row_bytes create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_specular_vector create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_texture_range create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_transform_hint create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_vertex_array_object create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_vertex_array_range create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_vertex_program_evaluators create mode 100644 Externals/GLew/auto/extensions/GL_APPLE_ycbcr_422 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_blend_func_extended create mode 100644 Externals/GLew/auto/extensions/GL_ARB_color_buffer_float create mode 100644 Externals/GLew/auto/extensions/GL_ARB_compatibility create mode 100644 Externals/GLew/auto/extensions/GL_ARB_copy_buffer create mode 100644 Externals/GLew/auto/extensions/GL_ARB_depth_buffer_float create mode 100644 Externals/GLew/auto/extensions/GL_ARB_depth_clamp create mode 100644 Externals/GLew/auto/extensions/GL_ARB_depth_texture create mode 100644 Externals/GLew/auto/extensions/GL_ARB_draw_buffers create mode 100644 Externals/GLew/auto/extensions/GL_ARB_draw_buffers_blend create mode 100644 Externals/GLew/auto/extensions/GL_ARB_draw_elements_base_vertex create mode 100644 Externals/GLew/auto/extensions/GL_ARB_draw_indirect create mode 100644 Externals/GLew/auto/extensions/GL_ARB_draw_instanced create mode 100644 Externals/GLew/auto/extensions/GL_ARB_explicit_attrib_location create mode 100644 Externals/GLew/auto/extensions/GL_ARB_fragment_coord_conventions create mode 100644 Externals/GLew/auto/extensions/GL_ARB_fragment_program create mode 100644 Externals/GLew/auto/extensions/GL_ARB_fragment_program_shadow create mode 100644 Externals/GLew/auto/extensions/GL_ARB_fragment_shader create mode 100644 Externals/GLew/auto/extensions/GL_ARB_framebuffer_object create mode 100644 Externals/GLew/auto/extensions/GL_ARB_framebuffer_sRGB create mode 100644 Externals/GLew/auto/extensions/GL_ARB_geometry_shader4 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_gpu_shader5 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_gpu_shader_fp64 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_half_float_pixel create mode 100644 Externals/GLew/auto/extensions/GL_ARB_half_float_vertex create mode 100644 Externals/GLew/auto/extensions/GL_ARB_imaging create mode 100644 Externals/GLew/auto/extensions/GL_ARB_instanced_arrays create mode 100644 Externals/GLew/auto/extensions/GL_ARB_map_buffer_range create mode 100644 Externals/GLew/auto/extensions/GL_ARB_matrix_palette create mode 100644 Externals/GLew/auto/extensions/GL_ARB_multisample create mode 100644 Externals/GLew/auto/extensions/GL_ARB_multitexture create mode 100644 Externals/GLew/auto/extensions/GL_ARB_occlusion_query create mode 100644 Externals/GLew/auto/extensions/GL_ARB_occlusion_query2 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_pixel_buffer_object create mode 100644 Externals/GLew/auto/extensions/GL_ARB_point_parameters create mode 100644 Externals/GLew/auto/extensions/GL_ARB_point_sprite create mode 100644 Externals/GLew/auto/extensions/GL_ARB_provoking_vertex create mode 100644 Externals/GLew/auto/extensions/GL_ARB_sample_shading create mode 100644 Externals/GLew/auto/extensions/GL_ARB_sampler_objects create mode 100644 Externals/GLew/auto/extensions/GL_ARB_seamless_cube_map create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shader_bit_encoding create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shader_objects create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shader_subroutine create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shader_texture_lod create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shading_language_100 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shading_language_include create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shadow create mode 100644 Externals/GLew/auto/extensions/GL_ARB_shadow_ambient create mode 100644 Externals/GLew/auto/extensions/GL_ARB_sync create mode 100644 Externals/GLew/auto/extensions/GL_ARB_tessellation_shader create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_border_clamp create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object_rgb32 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_compression create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_compression_bptc create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_compression_rgtc create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_cube_map create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_cube_map_array create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_env_add create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_env_combine create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_env_crossbar create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_env_dot3 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_float create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_gather create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_mirrored_repeat create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_multisample create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_non_power_of_two create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_query_lod create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_rectangle create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_rg create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_rgb10_a2ui create mode 100644 Externals/GLew/auto/extensions/GL_ARB_texture_swizzle create mode 100644 Externals/GLew/auto/extensions/GL_ARB_timer_query create mode 100644 Externals/GLew/auto/extensions/GL_ARB_transform_feedback2 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_transform_feedback3 create mode 100644 Externals/GLew/auto/extensions/GL_ARB_transpose_matrix create mode 100644 Externals/GLew/auto/extensions/GL_ARB_uniform_buffer_object create mode 100644 Externals/GLew/auto/extensions/GL_ARB_vertex_array_bgra create mode 100644 Externals/GLew/auto/extensions/GL_ARB_vertex_array_object create mode 100644 Externals/GLew/auto/extensions/GL_ARB_vertex_blend create mode 100644 Externals/GLew/auto/extensions/GL_ARB_vertex_buffer_object create mode 100644 Externals/GLew/auto/extensions/GL_ARB_vertex_program create mode 100644 Externals/GLew/auto/extensions/GL_ARB_vertex_shader create mode 100644 Externals/GLew/auto/extensions/GL_ARB_vertex_type_2_10_10_10_rev create mode 100644 Externals/GLew/auto/extensions/GL_ARB_window_pos create mode 100644 Externals/GLew/auto/extensions/GL_ATIX_point_sprites create mode 100644 Externals/GLew/auto/extensions/GL_ATIX_texture_env_combine3 create mode 100644 Externals/GLew/auto/extensions/GL_ATIX_texture_env_route create mode 100644 Externals/GLew/auto/extensions/GL_ATIX_vertex_shader_output_point_size create mode 100644 Externals/GLew/auto/extensions/GL_ATI_draw_buffers create mode 100644 Externals/GLew/auto/extensions/GL_ATI_element_array create mode 100644 Externals/GLew/auto/extensions/GL_ATI_envmap_bumpmap create mode 100644 Externals/GLew/auto/extensions/GL_ATI_fragment_shader create mode 100644 Externals/GLew/auto/extensions/GL_ATI_map_object_buffer create mode 100644 Externals/GLew/auto/extensions/GL_ATI_meminfo create mode 100644 Externals/GLew/auto/extensions/GL_ATI_pn_triangles create mode 100644 Externals/GLew/auto/extensions/GL_ATI_separate_stencil create mode 100644 Externals/GLew/auto/extensions/GL_ATI_shader_texture_lod create mode 100644 Externals/GLew/auto/extensions/GL_ATI_text_fragment_shader create mode 100644 Externals/GLew/auto/extensions/GL_ATI_texture_compression_3dc create mode 100644 Externals/GLew/auto/extensions/GL_ATI_texture_env_combine3 create mode 100644 Externals/GLew/auto/extensions/GL_ATI_texture_float create mode 100644 Externals/GLew/auto/extensions/GL_ATI_texture_mirror_once create mode 100644 Externals/GLew/auto/extensions/GL_ATI_vertex_array_object create mode 100644 Externals/GLew/auto/extensions/GL_ATI_vertex_attrib_array_object create mode 100644 Externals/GLew/auto/extensions/GL_ATI_vertex_streams create mode 100644 Externals/GLew/auto/extensions/GL_EXT_422_pixels create mode 100644 Externals/GLew/auto/extensions/GL_EXT_Cg_shader create mode 100644 Externals/GLew/auto/extensions/GL_EXT_abgr create mode 100644 Externals/GLew/auto/extensions/GL_EXT_bgra create mode 100644 Externals/GLew/auto/extensions/GL_EXT_bindable_uniform create mode 100644 Externals/GLew/auto/extensions/GL_EXT_blend_color create mode 100644 Externals/GLew/auto/extensions/GL_EXT_blend_equation_separate create mode 100644 Externals/GLew/auto/extensions/GL_EXT_blend_func_separate create mode 100644 Externals/GLew/auto/extensions/GL_EXT_blend_logic_op create mode 100644 Externals/GLew/auto/extensions/GL_EXT_blend_minmax create mode 100644 Externals/GLew/auto/extensions/GL_EXT_blend_subtract create mode 100644 Externals/GLew/auto/extensions/GL_EXT_clip_volume_hint create mode 100644 Externals/GLew/auto/extensions/GL_EXT_cmyka create mode 100644 Externals/GLew/auto/extensions/GL_EXT_color_subtable create mode 100644 Externals/GLew/auto/extensions/GL_EXT_compiled_vertex_array create mode 100644 Externals/GLew/auto/extensions/GL_EXT_convolution create mode 100644 Externals/GLew/auto/extensions/GL_EXT_coordinate_frame create mode 100644 Externals/GLew/auto/extensions/GL_EXT_copy_texture create mode 100644 Externals/GLew/auto/extensions/GL_EXT_cull_vertex create mode 100644 Externals/GLew/auto/extensions/GL_EXT_depth_bounds_test create mode 100644 Externals/GLew/auto/extensions/GL_EXT_direct_state_access create mode 100644 Externals/GLew/auto/extensions/GL_EXT_draw_buffers2 create mode 100644 Externals/GLew/auto/extensions/GL_EXT_draw_instanced create mode 100644 Externals/GLew/auto/extensions/GL_EXT_draw_range_elements create mode 100644 Externals/GLew/auto/extensions/GL_EXT_fog_coord create mode 100644 Externals/GLew/auto/extensions/GL_EXT_fragment_lighting create mode 100644 Externals/GLew/auto/extensions/GL_EXT_framebuffer_blit create mode 100644 Externals/GLew/auto/extensions/GL_EXT_framebuffer_multisample create mode 100644 Externals/GLew/auto/extensions/GL_EXT_framebuffer_object create mode 100644 Externals/GLew/auto/extensions/GL_EXT_framebuffer_sRGB create mode 100644 Externals/GLew/auto/extensions/GL_EXT_geometry_shader4 create mode 100644 Externals/GLew/auto/extensions/GL_EXT_gpu_program_parameters create mode 100644 Externals/GLew/auto/extensions/GL_EXT_gpu_shader4 create mode 100644 Externals/GLew/auto/extensions/GL_EXT_histogram create mode 100644 Externals/GLew/auto/extensions/GL_EXT_index_array_formats create mode 100644 Externals/GLew/auto/extensions/GL_EXT_index_func create mode 100644 Externals/GLew/auto/extensions/GL_EXT_index_material create mode 100644 Externals/GLew/auto/extensions/GL_EXT_index_texture create mode 100644 Externals/GLew/auto/extensions/GL_EXT_light_texture create mode 100644 Externals/GLew/auto/extensions/GL_EXT_misc_attribute create mode 100644 Externals/GLew/auto/extensions/GL_EXT_multi_draw_arrays create mode 100644 Externals/GLew/auto/extensions/GL_EXT_multisample create mode 100644 Externals/GLew/auto/extensions/GL_EXT_packed_depth_stencil create mode 100644 Externals/GLew/auto/extensions/GL_EXT_packed_float create mode 100644 Externals/GLew/auto/extensions/GL_EXT_packed_pixels create mode 100644 Externals/GLew/auto/extensions/GL_EXT_paletted_texture create mode 100644 Externals/GLew/auto/extensions/GL_EXT_pixel_buffer_object create mode 100644 Externals/GLew/auto/extensions/GL_EXT_pixel_transform create mode 100644 Externals/GLew/auto/extensions/GL_EXT_pixel_transform_color_table create mode 100644 Externals/GLew/auto/extensions/GL_EXT_point_parameters create mode 100644 Externals/GLew/auto/extensions/GL_EXT_polygon_offset create mode 100644 Externals/GLew/auto/extensions/GL_EXT_provoking_vertex create mode 100644 Externals/GLew/auto/extensions/GL_EXT_rescale_normal create mode 100644 Externals/GLew/auto/extensions/GL_EXT_scene_marker create mode 100644 Externals/GLew/auto/extensions/GL_EXT_secondary_color create mode 100644 Externals/GLew/auto/extensions/GL_EXT_separate_shader_objects create mode 100644 Externals/GLew/auto/extensions/GL_EXT_separate_specular_color create mode 100644 Externals/GLew/auto/extensions/GL_EXT_shader_image_load_store create mode 100644 Externals/GLew/auto/extensions/GL_EXT_shadow_funcs create mode 100644 Externals/GLew/auto/extensions/GL_EXT_shared_texture_palette create mode 100644 Externals/GLew/auto/extensions/GL_EXT_stencil_clear_tag create mode 100644 Externals/GLew/auto/extensions/GL_EXT_stencil_two_side create mode 100644 Externals/GLew/auto/extensions/GL_EXT_stencil_wrap create mode 100644 Externals/GLew/auto/extensions/GL_EXT_subtexture create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture3D create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_array create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_buffer_object create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_compression_dxt1 create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_compression_latc create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_compression_rgtc create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_compression_s3tc create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_cube_map create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_edge_clamp create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_env create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_env_add create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_env_combine create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_env_dot3 create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_filter_anisotropic create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_integer create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_lod_bias create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_mirror_clamp create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_object create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_perturb_normal create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_rectangle create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_sRGB create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_shared_exponent create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_snorm create mode 100644 Externals/GLew/auto/extensions/GL_EXT_texture_swizzle create mode 100644 Externals/GLew/auto/extensions/GL_EXT_timer_query create mode 100644 Externals/GLew/auto/extensions/GL_EXT_transform_feedback create mode 100644 Externals/GLew/auto/extensions/GL_EXT_vertex_array create mode 100644 Externals/GLew/auto/extensions/GL_EXT_vertex_array_bgra create mode 100644 Externals/GLew/auto/extensions/GL_EXT_vertex_attrib_64bit create mode 100644 Externals/GLew/auto/extensions/GL_EXT_vertex_shader create mode 100644 Externals/GLew/auto/extensions/GL_EXT_vertex_weighting create mode 100644 Externals/GLew/auto/extensions/GL_GREMEDY_frame_terminator create mode 100644 Externals/GLew/auto/extensions/GL_GREMEDY_string_marker create mode 100644 Externals/GLew/auto/extensions/GL_HP_convolution_border_modes create mode 100644 Externals/GLew/auto/extensions/GL_HP_image_transform create mode 100644 Externals/GLew/auto/extensions/GL_HP_occlusion_test create mode 100644 Externals/GLew/auto/extensions/GL_HP_texture_lighting create mode 100644 Externals/GLew/auto/extensions/GL_IBM_cull_vertex create mode 100644 Externals/GLew/auto/extensions/GL_IBM_multimode_draw_arrays create mode 100644 Externals/GLew/auto/extensions/GL_IBM_rasterpos_clip create mode 100644 Externals/GLew/auto/extensions/GL_IBM_static_data create mode 100644 Externals/GLew/auto/extensions/GL_IBM_texture_mirrored_repeat create mode 100644 Externals/GLew/auto/extensions/GL_IBM_vertex_array_lists create mode 100644 Externals/GLew/auto/extensions/GL_INGR_color_clamp create mode 100644 Externals/GLew/auto/extensions/GL_INGR_interlace_read create mode 100644 Externals/GLew/auto/extensions/GL_INTEL_parallel_arrays create mode 100644 Externals/GLew/auto/extensions/GL_INTEL_texture_scissor create mode 100644 Externals/GLew/auto/extensions/GL_KTX_buffer_region create mode 100644 Externals/GLew/auto/extensions/GL_MESAX_texture_stack create mode 100644 Externals/GLew/auto/extensions/GL_MESA_pack_invert create mode 100644 Externals/GLew/auto/extensions/GL_MESA_resize_buffers create mode 100644 Externals/GLew/auto/extensions/GL_MESA_window_pos create mode 100644 Externals/GLew/auto/extensions/GL_MESA_ycbcr_texture create mode 100644 Externals/GLew/auto/extensions/GL_NV_blend_square create mode 100644 Externals/GLew/auto/extensions/GL_NV_conditional_render create mode 100644 Externals/GLew/auto/extensions/GL_NV_copy_depth_to_color create mode 100644 Externals/GLew/auto/extensions/GL_NV_copy_image create mode 100644 Externals/GLew/auto/extensions/GL_NV_depth_buffer_float create mode 100644 Externals/GLew/auto/extensions/GL_NV_depth_clamp create mode 100644 Externals/GLew/auto/extensions/GL_NV_depth_range_unclamped create mode 100644 Externals/GLew/auto/extensions/GL_NV_evaluators create mode 100644 Externals/GLew/auto/extensions/GL_NV_explicit_multisample create mode 100644 Externals/GLew/auto/extensions/GL_NV_fence create mode 100644 Externals/GLew/auto/extensions/GL_NV_float_buffer create mode 100644 Externals/GLew/auto/extensions/GL_NV_fog_distance create mode 100644 Externals/GLew/auto/extensions/GL_NV_fragment_program create mode 100644 Externals/GLew/auto/extensions/GL_NV_fragment_program2 create mode 100644 Externals/GLew/auto/extensions/GL_NV_fragment_program4 create mode 100644 Externals/GLew/auto/extensions/GL_NV_fragment_program_option create mode 100644 Externals/GLew/auto/extensions/GL_NV_framebuffer_multisample_coverage create mode 100644 Externals/GLew/auto/extensions/GL_NV_geometry_program4 create mode 100644 Externals/GLew/auto/extensions/GL_NV_geometry_shader4 create mode 100644 Externals/GLew/auto/extensions/GL_NV_gpu_program4 create mode 100644 Externals/GLew/auto/extensions/GL_NV_gpu_program5 create mode 100644 Externals/GLew/auto/extensions/GL_NV_gpu_program_fp64 create mode 100644 Externals/GLew/auto/extensions/GL_NV_gpu_shader5 create mode 100644 Externals/GLew/auto/extensions/GL_NV_half_float create mode 100644 Externals/GLew/auto/extensions/GL_NV_light_max_exponent create mode 100644 Externals/GLew/auto/extensions/GL_NV_multisample_filter_hint create mode 100644 Externals/GLew/auto/extensions/GL_NV_occlusion_query create mode 100644 Externals/GLew/auto/extensions/GL_NV_packed_depth_stencil create mode 100644 Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object create mode 100644 Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object2 create mode 100644 Externals/GLew/auto/extensions/GL_NV_pixel_data_range create mode 100644 Externals/GLew/auto/extensions/GL_NV_point_sprite create mode 100644 Externals/GLew/auto/extensions/GL_NV_present_video create mode 100644 Externals/GLew/auto/extensions/GL_NV_primitive_restart create mode 100644 Externals/GLew/auto/extensions/GL_NV_register_combiners create mode 100644 Externals/GLew/auto/extensions/GL_NV_register_combiners2 create mode 100644 Externals/GLew/auto/extensions/GL_NV_shader_buffer_load create mode 100644 Externals/GLew/auto/extensions/GL_NV_tessellation_program5 create mode 100644 Externals/GLew/auto/extensions/GL_NV_texgen_emboss create mode 100644 Externals/GLew/auto/extensions/GL_NV_texgen_reflection create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_barrier create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_compression_vtc create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_env_combine4 create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_expand_normal create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_rectangle create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_shader create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_shader2 create mode 100644 Externals/GLew/auto/extensions/GL_NV_texture_shader3 create mode 100644 Externals/GLew/auto/extensions/GL_NV_transform_feedback create mode 100644 Externals/GLew/auto/extensions/GL_NV_transform_feedback2 create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_array_range create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_array_range2 create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_attrib_integer_64bit create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_buffer_unified_memory create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_program create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_program1_1 create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_program2 create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_program2_option create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_program3 create mode 100644 Externals/GLew/auto/extensions/GL_NV_vertex_program4 create mode 100644 Externals/GLew/auto/extensions/GL_OES_byte_coordinates create mode 100644 Externals/GLew/auto/extensions/GL_OES_compressed_paletted_texture create mode 100644 Externals/GLew/auto/extensions/GL_OES_read_format create mode 100644 Externals/GLew/auto/extensions/GL_OES_single_precision create mode 100644 Externals/GLew/auto/extensions/GL_OML_interlace create mode 100644 Externals/GLew/auto/extensions/GL_OML_resample create mode 100644 Externals/GLew/auto/extensions/GL_OML_subsample create mode 100644 Externals/GLew/auto/extensions/GL_PGI_misc_hints create mode 100644 Externals/GLew/auto/extensions/GL_PGI_vertex_hints create mode 100644 Externals/GLew/auto/extensions/GL_REND_screen_coordinates create mode 100644 Externals/GLew/auto/extensions/GL_S3_s3tc create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_color_range create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_detail_texture create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_fog_function create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_generate_mipmap create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_multisample create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_pixel_texture create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_point_line_texgen create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_sharpen_texture create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_texture4D create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_texture_border_clamp create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_texture_edge_clamp create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_texture_filter4 create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_texture_lod create mode 100644 Externals/GLew/auto/extensions/GL_SGIS_texture_select create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_async create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_async_histogram create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_async_pixel create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_blend_alpha_minmax create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_clipmap create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_convolution_accuracy create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_depth_texture create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_flush_raster create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_fog_offset create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_fog_texture create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_fragment_specular_lighting create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_framezoom create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_interlace create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_ir_instrument1 create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_list_priority create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_pixel_texture create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_pixel_texture_bits create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_reference_plane create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_resample create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_shadow create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_shadow_ambient create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_sprite create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_tag_sample_buffer create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_texture_add_env create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_texture_coordinate_clamp create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_texture_lod_bias create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_texture_multi_buffer create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_texture_range create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_texture_scale_bias create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip_hint create mode 100644 Externals/GLew/auto/extensions/GL_SGIX_ycrcb create mode 100644 Externals/GLew/auto/extensions/GL_SGI_color_matrix create mode 100644 Externals/GLew/auto/extensions/GL_SGI_color_table create mode 100644 Externals/GLew/auto/extensions/GL_SGI_texture_color_table create mode 100644 Externals/GLew/auto/extensions/GL_SUNX_constant_data create mode 100644 Externals/GLew/auto/extensions/GL_SUN_convolution_border_modes create mode 100644 Externals/GLew/auto/extensions/GL_SUN_global_alpha create mode 100644 Externals/GLew/auto/extensions/GL_SUN_mesh_array create mode 100644 Externals/GLew/auto/extensions/GL_SUN_read_video_pixels create mode 100644 Externals/GLew/auto/extensions/GL_SUN_slice_accum create mode 100644 Externals/GLew/auto/extensions/GL_SUN_triangle_list create mode 100644 Externals/GLew/auto/extensions/GL_SUN_vertex create mode 100644 Externals/GLew/auto/extensions/GL_WIN_phong_shading create mode 100644 Externals/GLew/auto/extensions/GL_WIN_specular_fog create mode 100644 Externals/GLew/auto/extensions/GL_WIN_swap_hint create mode 100644 Externals/GLew/auto/extensions/WGL_3DFX_multisample create mode 100644 Externals/GLew/auto/extensions/WGL_3DL_stereo_control create mode 100644 Externals/GLew/auto/extensions/WGL_AMD_gpu_association create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_buffer_region create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_create_context create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_create_context_profile create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_extensions_string create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_framebuffer_sRGB create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_make_current_read create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_multisample create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_pbuffer create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_pixel_format create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_pixel_format_float create mode 100644 Externals/GLew/auto/extensions/WGL_ARB_render_texture create mode 100644 Externals/GLew/auto/extensions/WGL_ATI_pixel_format_float create mode 100644 Externals/GLew/auto/extensions/WGL_ATI_render_texture_rectangle create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_depth_float create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_display_color_table create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_extensions_string create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_framebuffer_sRGB create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_make_current_read create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_multisample create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_pbuffer create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_pixel_format create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_pixel_format_packed_float create mode 100644 Externals/GLew/auto/extensions/WGL_EXT_swap_control create mode 100644 Externals/GLew/auto/extensions/WGL_I3D_digital_video_control create mode 100644 Externals/GLew/auto/extensions/WGL_I3D_gamma create mode 100644 Externals/GLew/auto/extensions/WGL_I3D_genlock create mode 100644 Externals/GLew/auto/extensions/WGL_I3D_image_buffer create mode 100644 Externals/GLew/auto/extensions/WGL_I3D_swap_frame_lock create mode 100644 Externals/GLew/auto/extensions/WGL_I3D_swap_frame_usage create mode 100644 Externals/GLew/auto/extensions/WGL_NV_copy_image create mode 100644 Externals/GLew/auto/extensions/WGL_NV_float_buffer create mode 100644 Externals/GLew/auto/extensions/WGL_NV_gpu_affinity create mode 100644 Externals/GLew/auto/extensions/WGL_NV_present_video create mode 100644 Externals/GLew/auto/extensions/WGL_NV_render_depth_texture create mode 100644 Externals/GLew/auto/extensions/WGL_NV_render_texture_rectangle create mode 100644 Externals/GLew/auto/extensions/WGL_NV_swap_group create mode 100644 Externals/GLew/auto/extensions/WGL_NV_vertex_array_range create mode 100644 Externals/GLew/auto/extensions/WGL_NV_video_output create mode 100644 Externals/GLew/auto/extensions/WGL_OML_sync_control create mode 100644 Externals/GLew/auto/lib/OpenGL/Spec.pm create mode 100644 Externals/GLew/auto/src/footer.html create mode 100644 Externals/GLew/auto/src/glew.rc create mode 100644 Externals/GLew/auto/src/glew_head.c create mode 100644 Externals/GLew/auto/src/glew_head.h create mode 100644 Externals/GLew/auto/src/glew_init_gl.c create mode 100644 Externals/GLew/auto/src/glew_init_glx.c create mode 100644 Externals/GLew/auto/src/glew_init_tail.c create mode 100644 Externals/GLew/auto/src/glew_init_wgl.c create mode 100644 Externals/GLew/auto/src/glew_license.h create mode 100644 Externals/GLew/auto/src/glew_str_glx.c create mode 100644 Externals/GLew/auto/src/glew_str_head.c create mode 100644 Externals/GLew/auto/src/glew_str_tail.c create mode 100644 Externals/GLew/auto/src/glew_str_wgl.c create mode 100644 Externals/GLew/auto/src/glew_tail.h create mode 100644 Externals/GLew/auto/src/glew_utils.c create mode 100644 Externals/GLew/auto/src/glew_utils.h create mode 100644 Externals/GLew/auto/src/glewinfo.rc create mode 100644 Externals/GLew/auto/src/glewinfo_gl.c create mode 100644 Externals/GLew/auto/src/glewinfo_glx.c create mode 100644 Externals/GLew/auto/src/glewinfo_head.c create mode 100644 Externals/GLew/auto/src/glewinfo_tail.c create mode 100644 Externals/GLew/auto/src/glewinfo_wgl.c create mode 100644 Externals/GLew/auto/src/glxew_head.h create mode 100644 Externals/GLew/auto/src/glxew_tail.h create mode 100644 Externals/GLew/auto/src/header.html create mode 100644 Externals/GLew/auto/src/khronos_license.h create mode 100644 Externals/GLew/auto/src/mesa_license.h create mode 100644 Externals/GLew/auto/src/visualinfo.rc create mode 100644 Externals/GLew/auto/src/wglew_head.h create mode 100644 Externals/GLew/auto/src/wglew_tail.h create mode 100644 Externals/GLew/build/vc6/Makefile create mode 100644 Externals/GLew/build/vc6/glew.dsw create mode 100644 Externals/GLew/build/vc6/glew.rc create mode 100644 Externals/GLew/build/vc6/glew_shared.dsp create mode 100644 Externals/GLew/build/vc6/glew_static.dsp create mode 100644 Externals/GLew/build/vc6/glewinfo.dsp create mode 100644 Externals/GLew/build/vc6/glewinfo.rc create mode 100644 Externals/GLew/build/vc6/visualinfo.dsp create mode 100644 Externals/GLew/build/vc6/visualinfo.rc create mode 100644 Externals/GLew/config/Makefile.cygming create mode 100644 Externals/GLew/config/Makefile.cygwin create mode 100644 Externals/GLew/config/Makefile.darwin create mode 100644 Externals/GLew/config/Makefile.freebsd create mode 100644 Externals/GLew/config/Makefile.gnu create mode 100644 Externals/GLew/config/Makefile.irix create mode 100644 Externals/GLew/config/Makefile.kfreebsd create mode 100644 Externals/GLew/config/Makefile.linux create mode 100644 Externals/GLew/config/Makefile.mingw create mode 100644 Externals/GLew/config/Makefile.solaris create mode 100755 Externals/GLew/config/config.guess create mode 100644 Externals/GLew/config/version create mode 100644 Externals/GLew/doc/advanced.html create mode 100644 Externals/GLew/doc/basic.html create mode 100644 Externals/GLew/doc/credits.html create mode 100644 Externals/GLew/doc/glew.css create mode 100644 Externals/GLew/doc/glew.html create mode 100644 Externals/GLew/doc/glew.png create mode 100644 Externals/GLew/doc/glew.txt create mode 100644 Externals/GLew/doc/glxew.html create mode 100644 Externals/GLew/doc/gpl.txt create mode 100644 Externals/GLew/doc/index.html create mode 100644 Externals/GLew/doc/install.html create mode 100644 Externals/GLew/doc/khronos.txt create mode 100644 Externals/GLew/doc/log.html create mode 100644 Externals/GLew/doc/mesa.txt create mode 100644 Externals/GLew/doc/new.png create mode 100644 Externals/GLew/doc/ogl_sm.jpg create mode 100644 Externals/GLew/doc/wglew.html create mode 100644 Externals/GLew/glew.pc.in create mode 100644 Externals/GLew/include/GL/glew.h create mode 100644 Externals/GLew/include/GL/glxew.h create mode 100644 Externals/GLew/include/GL/wglew.h create mode 100644 Externals/GLew/src/glew.c create mode 100644 Externals/GLew/src/glewinfo.c create mode 100644 Externals/GLew/src/visualinfo.c create mode 100644 Externals/SDL/BUGS create mode 100644 Externals/SDL/Borland.html create mode 100644 Externals/SDL/Borland.zip create mode 100644 Externals/SDL/COPYING create mode 100644 Externals/SDL/CREDITS create mode 100644 Externals/SDL/CWprojects.sea.bin create mode 100644 Externals/SDL/INSTALL create mode 100644 Externals/SDL/MPWmake.sea.bin create mode 100644 Externals/SDL/Makefile.dc create mode 100644 Externals/SDL/Makefile.in create mode 100644 Externals/SDL/Makefile.minimal create mode 100644 Externals/SDL/README create mode 100644 Externals/SDL/README-SDL.txt create mode 100644 Externals/SDL/README.AmigaOS create mode 100644 Externals/SDL/README.BeOS create mode 100644 Externals/SDL/README.CVS create mode 100644 Externals/SDL/README.DC create mode 100644 Externals/SDL/README.MacOS create mode 100644 Externals/SDL/README.MacOSX create mode 100644 Externals/SDL/README.MiNT create mode 100644 Externals/SDL/README.NDS create mode 100644 Externals/SDL/README.NanoX create mode 100644 Externals/SDL/README.OS2 create mode 100644 Externals/SDL/README.PS3 create mode 100644 Externals/SDL/README.PicoGUI create mode 100644 Externals/SDL/README.Porting create mode 100644 Externals/SDL/README.QNX create mode 100644 Externals/SDL/README.Qtopia create mode 100644 Externals/SDL/README.RISCOS create mode 100644 Externals/SDL/README.SVN create mode 100644 Externals/SDL/README.Symbian create mode 100644 Externals/SDL/README.Watcom create mode 100644 Externals/SDL/README.WinCE create mode 100644 Externals/SDL/README.wscons create mode 100644 Externals/SDL/SDL.qpg.in create mode 100644 Externals/SDL/SDL.spec create mode 100644 Externals/SDL/SDL.spec.in create mode 100644 Externals/SDL/TODO create mode 100644 Externals/SDL/VisualC.html create mode 100644 Externals/SDL/VisualC.zip create mode 100644 Externals/SDL/VisualCE.zip create mode 100644 Externals/SDL/Watcom-OS2.zip create mode 100644 Externals/SDL/Watcom-Win32.zip create mode 100644 Externals/SDL/WhatsNew create mode 100644 Externals/SDL/Xcode.tar.gz create mode 100644 Externals/SDL/acinclude/alsa.m4 create mode 100644 Externals/SDL/acinclude/esd.m4 create mode 100644 Externals/SDL/acinclude/libtool.m4 create mode 100644 Externals/SDL/acinclude/ltdl.m4 create mode 100644 Externals/SDL/acinclude/ltoptions.m4 create mode 100644 Externals/SDL/acinclude/ltsugar.m4 create mode 100644 Externals/SDL/acinclude/ltversion.m4 create mode 100644 Externals/SDL/acinclude/lt~obsolete.m4 create mode 100755 Externals/SDL/autogen.sh create mode 100755 Externals/SDL/build-scripts/config.guess create mode 100755 Externals/SDL/build-scripts/config.sub create mode 100755 Externals/SDL/build-scripts/fatbuild.sh create mode 100755 Externals/SDL/build-scripts/install-sh create mode 100644 Externals/SDL/build-scripts/ltmain.sh create mode 100755 Externals/SDL/build-scripts/makedep.sh create mode 100755 Externals/SDL/build-scripts/mkinstalldirs create mode 100755 Externals/SDL/build-scripts/strip_fPIC.sh create mode 100755 Externals/SDL/configure create mode 100644 Externals/SDL/configure.in create mode 100644 Externals/SDL/docs.html create mode 100644 Externals/SDL/docs/html/audio.html create mode 100644 Externals/SDL/docs/html/cdrom.html create mode 100644 Externals/SDL/docs/html/event.html create mode 100644 Externals/SDL/docs/html/eventfunctions.html create mode 100644 Externals/SDL/docs/html/eventstructures.html create mode 100644 Externals/SDL/docs/html/general.html create mode 100644 Externals/SDL/docs/html/guide.html create mode 100644 Externals/SDL/docs/html/guideaboutsdldoc.html create mode 100644 Externals/SDL/docs/html/guideaudioexamples.html create mode 100644 Externals/SDL/docs/html/guidebasicsinit.html create mode 100644 Externals/SDL/docs/html/guidecdromexamples.html create mode 100644 Externals/SDL/docs/html/guidecredits.html create mode 100644 Externals/SDL/docs/html/guideeventexamples.html create mode 100644 Externals/SDL/docs/html/guideexamples.html create mode 100644 Externals/SDL/docs/html/guideinput.html create mode 100644 Externals/SDL/docs/html/guideinputkeyboard.html create mode 100644 Externals/SDL/docs/html/guidepreface.html create mode 100644 Externals/SDL/docs/html/guidethebasics.html create mode 100644 Externals/SDL/docs/html/guidetimeexamples.html create mode 100644 Externals/SDL/docs/html/guidevideo.html create mode 100644 Externals/SDL/docs/html/guidevideoopengl.html create mode 100644 Externals/SDL/docs/html/index.html create mode 100644 Externals/SDL/docs/html/joystick.html create mode 100644 Externals/SDL/docs/html/reference.html create mode 100644 Externals/SDL/docs/html/sdlactiveevent.html create mode 100644 Externals/SDL/docs/html/sdladdtimer.html create mode 100644 Externals/SDL/docs/html/sdlaudiocvt.html create mode 100644 Externals/SDL/docs/html/sdlaudiospec.html create mode 100644 Externals/SDL/docs/html/sdlblitsurface.html create mode 100644 Externals/SDL/docs/html/sdlbuildaudiocvt.html create mode 100644 Externals/SDL/docs/html/sdlcd.html create mode 100644 Externals/SDL/docs/html/sdlcdclose.html create mode 100644 Externals/SDL/docs/html/sdlcdeject.html create mode 100644 Externals/SDL/docs/html/sdlcdname.html create mode 100644 Externals/SDL/docs/html/sdlcdnumdrives.html create mode 100644 Externals/SDL/docs/html/sdlcdopen.html create mode 100644 Externals/SDL/docs/html/sdlcdpause.html create mode 100644 Externals/SDL/docs/html/sdlcdplay.html create mode 100644 Externals/SDL/docs/html/sdlcdplaytracks.html create mode 100644 Externals/SDL/docs/html/sdlcdresume.html create mode 100644 Externals/SDL/docs/html/sdlcdstatus.html create mode 100644 Externals/SDL/docs/html/sdlcdstop.html create mode 100644 Externals/SDL/docs/html/sdlcdtrack.html create mode 100644 Externals/SDL/docs/html/sdlcloseaudio.html create mode 100644 Externals/SDL/docs/html/sdlcolor.html create mode 100644 Externals/SDL/docs/html/sdlcondbroadcast.html create mode 100644 Externals/SDL/docs/html/sdlcondsignal.html create mode 100644 Externals/SDL/docs/html/sdlcondwait.html create mode 100644 Externals/SDL/docs/html/sdlcondwaittimeout.html create mode 100644 Externals/SDL/docs/html/sdlconvertaudio.html create mode 100644 Externals/SDL/docs/html/sdlconvertsurface.html create mode 100644 Externals/SDL/docs/html/sdlcreatecond.html create mode 100644 Externals/SDL/docs/html/sdlcreatecursor.html create mode 100644 Externals/SDL/docs/html/sdlcreatemutex.html create mode 100644 Externals/SDL/docs/html/sdlcreatergbsurface.html create mode 100644 Externals/SDL/docs/html/sdlcreatergbsurfacefrom.html create mode 100644 Externals/SDL/docs/html/sdlcreatesemaphore.html create mode 100644 Externals/SDL/docs/html/sdlcreatethread.html create mode 100644 Externals/SDL/docs/html/sdlcreateyuvoverlay.html create mode 100644 Externals/SDL/docs/html/sdldelay.html create mode 100644 Externals/SDL/docs/html/sdldestroycond.html create mode 100644 Externals/SDL/docs/html/sdldestroymutex.html create mode 100644 Externals/SDL/docs/html/sdldestroysemaphore.html create mode 100644 Externals/SDL/docs/html/sdldisplayformat.html create mode 100644 Externals/SDL/docs/html/sdldisplayformatalpha.html create mode 100644 Externals/SDL/docs/html/sdldisplayyuvoverlay.html create mode 100644 Externals/SDL/docs/html/sdlenablekeyrepeat.html create mode 100644 Externals/SDL/docs/html/sdlenableunicode.html create mode 100644 Externals/SDL/docs/html/sdlenvvars.html create mode 100644 Externals/SDL/docs/html/sdlevent.html create mode 100644 Externals/SDL/docs/html/sdleventstate.html create mode 100644 Externals/SDL/docs/html/sdlexposeevent.html create mode 100644 Externals/SDL/docs/html/sdlfillrect.html create mode 100644 Externals/SDL/docs/html/sdlflip.html create mode 100644 Externals/SDL/docs/html/sdlfreecursor.html create mode 100644 Externals/SDL/docs/html/sdlfreesurface.html create mode 100644 Externals/SDL/docs/html/sdlfreewav.html create mode 100644 Externals/SDL/docs/html/sdlfreeyuvoverlay.html create mode 100644 Externals/SDL/docs/html/sdlgetappstate.html create mode 100644 Externals/SDL/docs/html/sdlgetaudiostatus.html create mode 100644 Externals/SDL/docs/html/sdlgetcliprect.html create mode 100644 Externals/SDL/docs/html/sdlgetcursor.html create mode 100644 Externals/SDL/docs/html/sdlgeterror.html create mode 100644 Externals/SDL/docs/html/sdlgeteventfilter.html create mode 100644 Externals/SDL/docs/html/sdlgetgammaramp.html create mode 100644 Externals/SDL/docs/html/sdlgetkeyname.html create mode 100644 Externals/SDL/docs/html/sdlgetkeystate.html create mode 100644 Externals/SDL/docs/html/sdlgetmodstate.html create mode 100644 Externals/SDL/docs/html/sdlgetmousestate.html create mode 100644 Externals/SDL/docs/html/sdlgetrelativemousestate.html create mode 100644 Externals/SDL/docs/html/sdlgetrgb.html create mode 100644 Externals/SDL/docs/html/sdlgetrgba.html create mode 100644 Externals/SDL/docs/html/sdlgetthreadid.html create mode 100644 Externals/SDL/docs/html/sdlgetticks.html create mode 100644 Externals/SDL/docs/html/sdlgetvideoinfo.html create mode 100644 Externals/SDL/docs/html/sdlgetvideosurface.html create mode 100644 Externals/SDL/docs/html/sdlglattr.html create mode 100644 Externals/SDL/docs/html/sdlglgetattribute.html create mode 100644 Externals/SDL/docs/html/sdlglgetprocaddress.html create mode 100644 Externals/SDL/docs/html/sdlglloadlibrary.html create mode 100644 Externals/SDL/docs/html/sdlglsetattribute.html create mode 100644 Externals/SDL/docs/html/sdlglswapbuffers.html create mode 100644 Externals/SDL/docs/html/sdlinit.html create mode 100644 Externals/SDL/docs/html/sdlinitsubsystem.html create mode 100644 Externals/SDL/docs/html/sdljoyaxisevent.html create mode 100644 Externals/SDL/docs/html/sdljoyballevent.html create mode 100644 Externals/SDL/docs/html/sdljoybuttonevent.html create mode 100644 Externals/SDL/docs/html/sdljoyhatevent.html create mode 100644 Externals/SDL/docs/html/sdljoystickclose.html create mode 100644 Externals/SDL/docs/html/sdljoystickeventstate.html create mode 100644 Externals/SDL/docs/html/sdljoystickgetaxis.html create mode 100644 Externals/SDL/docs/html/sdljoystickgetball.html create mode 100644 Externals/SDL/docs/html/sdljoystickgetbutton.html create mode 100644 Externals/SDL/docs/html/sdljoystickgethat.html create mode 100644 Externals/SDL/docs/html/sdljoystickindex.html create mode 100644 Externals/SDL/docs/html/sdljoystickname.html create mode 100644 Externals/SDL/docs/html/sdljoysticknumaxes.html create mode 100644 Externals/SDL/docs/html/sdljoysticknumballs.html create mode 100644 Externals/SDL/docs/html/sdljoysticknumbuttons.html create mode 100644 Externals/SDL/docs/html/sdljoysticknumhats.html create mode 100644 Externals/SDL/docs/html/sdljoystickopen.html create mode 100644 Externals/SDL/docs/html/sdljoystickopened.html create mode 100644 Externals/SDL/docs/html/sdljoystickupdate.html create mode 100644 Externals/SDL/docs/html/sdlkey.html create mode 100644 Externals/SDL/docs/html/sdlkeyboardevent.html create mode 100644 Externals/SDL/docs/html/sdlkeysym.html create mode 100644 Externals/SDL/docs/html/sdlkillthread.html create mode 100644 Externals/SDL/docs/html/sdllistmodes.html create mode 100644 Externals/SDL/docs/html/sdlloadbmp.html create mode 100644 Externals/SDL/docs/html/sdlloadwav.html create mode 100644 Externals/SDL/docs/html/sdllockaudio.html create mode 100644 Externals/SDL/docs/html/sdllocksurface.html create mode 100644 Externals/SDL/docs/html/sdllockyuvoverlay.html create mode 100644 Externals/SDL/docs/html/sdlmaprgb.html create mode 100644 Externals/SDL/docs/html/sdlmaprgba.html create mode 100644 Externals/SDL/docs/html/sdlmixaudio.html create mode 100644 Externals/SDL/docs/html/sdlmousebuttonevent.html create mode 100644 Externals/SDL/docs/html/sdlmousemotionevent.html create mode 100644 Externals/SDL/docs/html/sdlmutexp.html create mode 100644 Externals/SDL/docs/html/sdlmutexv.html create mode 100644 Externals/SDL/docs/html/sdlnumjoysticks.html create mode 100644 Externals/SDL/docs/html/sdlopenaudio.html create mode 100644 Externals/SDL/docs/html/sdloverlay.html create mode 100644 Externals/SDL/docs/html/sdlpalette.html create mode 100644 Externals/SDL/docs/html/sdlpauseaudio.html create mode 100644 Externals/SDL/docs/html/sdlpeepevents.html create mode 100644 Externals/SDL/docs/html/sdlpixelformat.html create mode 100644 Externals/SDL/docs/html/sdlpollevent.html create mode 100644 Externals/SDL/docs/html/sdlpumpevents.html create mode 100644 Externals/SDL/docs/html/sdlpushevent.html create mode 100644 Externals/SDL/docs/html/sdlquit.html create mode 100644 Externals/SDL/docs/html/sdlquitevent.html create mode 100644 Externals/SDL/docs/html/sdlquitsubsystem.html create mode 100644 Externals/SDL/docs/html/sdlrect.html create mode 100644 Externals/SDL/docs/html/sdlremovetimer.html create mode 100644 Externals/SDL/docs/html/sdlresizeevent.html create mode 100644 Externals/SDL/docs/html/sdlsavebmp.html create mode 100644 Externals/SDL/docs/html/sdlsempost.html create mode 100644 Externals/SDL/docs/html/sdlsemtrywait.html create mode 100644 Externals/SDL/docs/html/sdlsemvalue.html create mode 100644 Externals/SDL/docs/html/sdlsemwait.html create mode 100644 Externals/SDL/docs/html/sdlsemwaittimeout.html create mode 100644 Externals/SDL/docs/html/sdlsetalpha.html create mode 100644 Externals/SDL/docs/html/sdlsetcliprect.html create mode 100644 Externals/SDL/docs/html/sdlsetcolorkey.html create mode 100644 Externals/SDL/docs/html/sdlsetcolors.html create mode 100644 Externals/SDL/docs/html/sdlsetcursor.html create mode 100644 Externals/SDL/docs/html/sdlseteventfilter.html create mode 100644 Externals/SDL/docs/html/sdlsetgamma.html create mode 100644 Externals/SDL/docs/html/sdlsetgammaramp.html create mode 100644 Externals/SDL/docs/html/sdlsetmodstate.html create mode 100644 Externals/SDL/docs/html/sdlsetpalette.html create mode 100644 Externals/SDL/docs/html/sdlsettimer.html create mode 100644 Externals/SDL/docs/html/sdlsetvideomode.html create mode 100644 Externals/SDL/docs/html/sdlshowcursor.html create mode 100644 Externals/SDL/docs/html/sdlsurface.html create mode 100644 Externals/SDL/docs/html/sdlsyswmevent.html create mode 100644 Externals/SDL/docs/html/sdlthreadid.html create mode 100644 Externals/SDL/docs/html/sdlunlockaudio.html create mode 100644 Externals/SDL/docs/html/sdlunlocksurface.html create mode 100644 Externals/SDL/docs/html/sdlunlockyuvoverlay.html create mode 100644 Externals/SDL/docs/html/sdlupdaterect.html create mode 100644 Externals/SDL/docs/html/sdlupdaterects.html create mode 100644 Externals/SDL/docs/html/sdluserevent.html create mode 100644 Externals/SDL/docs/html/sdlvideodrivername.html create mode 100644 Externals/SDL/docs/html/sdlvideoinfo.html create mode 100644 Externals/SDL/docs/html/sdlvideomodeok.html create mode 100644 Externals/SDL/docs/html/sdlwaitevent.html create mode 100644 Externals/SDL/docs/html/sdlwaitthread.html create mode 100644 Externals/SDL/docs/html/sdlwarpmouse.html create mode 100644 Externals/SDL/docs/html/sdlwasinit.html create mode 100644 Externals/SDL/docs/html/sdlwmgetcaption.html create mode 100644 Externals/SDL/docs/html/sdlwmgrabinput.html create mode 100644 Externals/SDL/docs/html/sdlwmiconifywindow.html create mode 100644 Externals/SDL/docs/html/sdlwmsetcaption.html create mode 100644 Externals/SDL/docs/html/sdlwmseticon.html create mode 100644 Externals/SDL/docs/html/sdlwmtogglefullscreen.html create mode 100644 Externals/SDL/docs/html/thread.html create mode 100644 Externals/SDL/docs/html/time.html create mode 100644 Externals/SDL/docs/html/video.html create mode 100644 Externals/SDL/docs/html/wm.html create mode 100644 Externals/SDL/docs/images/rainbow.gif create mode 100644 Externals/SDL/docs/index.html create mode 100644 Externals/SDL/docs/man3/SDLKey.3 create mode 100644 Externals/SDL/docs/man3/SDL_ActiveEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_AddTimer.3 create mode 100644 Externals/SDL/docs/man3/SDL_AudioCVT.3 create mode 100644 Externals/SDL/docs/man3/SDL_AudioSpec.3 create mode 100644 Externals/SDL/docs/man3/SDL_BlitSurface.3 create mode 100644 Externals/SDL/docs/man3/SDL_BuildAudioCVT.3 create mode 100644 Externals/SDL/docs/man3/SDL_CD.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDClose.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDEject.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDName.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDNumDrives.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDOpen.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDPause.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDPlay.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDPlayTracks.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDResume.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDStatus.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDStop.3 create mode 100644 Externals/SDL/docs/man3/SDL_CDtrack.3 create mode 100644 Externals/SDL/docs/man3/SDL_CloseAudio.3 create mode 100644 Externals/SDL/docs/man3/SDL_Color.3 create mode 100644 Externals/SDL/docs/man3/SDL_CondBroadcast.3 create mode 100644 Externals/SDL/docs/man3/SDL_CondSignal.3 create mode 100644 Externals/SDL/docs/man3/SDL_CondWait.3 create mode 100644 Externals/SDL/docs/man3/SDL_CondWaitTimeout.3 create mode 100644 Externals/SDL/docs/man3/SDL_ConvertAudio.3 create mode 100644 Externals/SDL/docs/man3/SDL_ConvertSurface.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateCond.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateCursor.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateMutex.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateRGBSurface.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateRGBSurfaceFrom.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateSemaphore.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateThread.3 create mode 100644 Externals/SDL/docs/man3/SDL_CreateYUVOverlay.3 create mode 100644 Externals/SDL/docs/man3/SDL_Delay.3 create mode 100644 Externals/SDL/docs/man3/SDL_DestroyCond.3 create mode 100644 Externals/SDL/docs/man3/SDL_DestroyMutex.3 create mode 100644 Externals/SDL/docs/man3/SDL_DestroySemaphore.3 create mode 100644 Externals/SDL/docs/man3/SDL_DisplayFormat.3 create mode 100644 Externals/SDL/docs/man3/SDL_DisplayFormatAlpha.3 create mode 100644 Externals/SDL/docs/man3/SDL_DisplayYUVOverlay.3 create mode 100644 Externals/SDL/docs/man3/SDL_EnableKeyRepeat.3 create mode 100644 Externals/SDL/docs/man3/SDL_EnableUNICODE.3 create mode 100644 Externals/SDL/docs/man3/SDL_Event.3 create mode 100644 Externals/SDL/docs/man3/SDL_EventState.3 create mode 100644 Externals/SDL/docs/man3/SDL_ExposeEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_FillRect.3 create mode 100644 Externals/SDL/docs/man3/SDL_Flip.3 create mode 100644 Externals/SDL/docs/man3/SDL_FreeCursor.3 create mode 100644 Externals/SDL/docs/man3/SDL_FreeSurface.3 create mode 100644 Externals/SDL/docs/man3/SDL_FreeWAV.3 create mode 100644 Externals/SDL/docs/man3/SDL_FreeYUVOverlay.3 create mode 100644 Externals/SDL/docs/man3/SDL_GL_GetAttribute.3 create mode 100644 Externals/SDL/docs/man3/SDL_GL_GetProcAddress.3 create mode 100644 Externals/SDL/docs/man3/SDL_GL_LoadLibrary.3 create mode 100644 Externals/SDL/docs/man3/SDL_GL_SetAttribute.3 create mode 100644 Externals/SDL/docs/man3/SDL_GL_SwapBuffers.3 create mode 100644 Externals/SDL/docs/man3/SDL_GLattr.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetAppState.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetAudioStatus.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetClipRect.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetCursor.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetError.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetEventFilter.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetGamma.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetGammaRamp.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetKeyName.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetKeyState.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetModState.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetMouseState.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetRGB.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetRGBA.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetRelativeMouseState.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetThreadID.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetTicks.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetVideoInfo.3 create mode 100644 Externals/SDL/docs/man3/SDL_GetVideoSurface.3 create mode 100644 Externals/SDL/docs/man3/SDL_Init.3 create mode 100644 Externals/SDL/docs/man3/SDL_InitSubSystem.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoyAxisEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoyBallEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoyButtonEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoyHatEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickClose.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickEventState.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickGetAxis.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickGetBall.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickGetButton.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickGetHat.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickIndex.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickName.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickNumAxes.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickNumBalls.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickNumButtons.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickNumHats.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickOpen.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickOpened.3 create mode 100644 Externals/SDL/docs/man3/SDL_JoystickUpdate.3 create mode 100644 Externals/SDL/docs/man3/SDL_KeyboardEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_KillThread.3 create mode 100644 Externals/SDL/docs/man3/SDL_ListModes.3 create mode 100644 Externals/SDL/docs/man3/SDL_LoadBMP.3 create mode 100644 Externals/SDL/docs/man3/SDL_LoadWAV.3 create mode 100644 Externals/SDL/docs/man3/SDL_LockAudio.3 create mode 100644 Externals/SDL/docs/man3/SDL_LockSurface.3 create mode 100644 Externals/SDL/docs/man3/SDL_LockYUVOverlay.3 create mode 100644 Externals/SDL/docs/man3/SDL_MapRGB.3 create mode 100644 Externals/SDL/docs/man3/SDL_MapRGBA.3 create mode 100644 Externals/SDL/docs/man3/SDL_MixAudio.3 create mode 100644 Externals/SDL/docs/man3/SDL_MouseButtonEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_MouseMotionEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_NumJoysticks.3 create mode 100644 Externals/SDL/docs/man3/SDL_OpenAudio.3 create mode 100644 Externals/SDL/docs/man3/SDL_Overlay.3 create mode 100644 Externals/SDL/docs/man3/SDL_Palette.3 create mode 100644 Externals/SDL/docs/man3/SDL_PauseAudio.3 create mode 100644 Externals/SDL/docs/man3/SDL_PeepEvents.3 create mode 100644 Externals/SDL/docs/man3/SDL_PixelFormat.3 create mode 100644 Externals/SDL/docs/man3/SDL_PollEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_PumpEvents.3 create mode 100644 Externals/SDL/docs/man3/SDL_PushEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_Quit.3 create mode 100644 Externals/SDL/docs/man3/SDL_QuitEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_QuitSubSystem.3 create mode 100644 Externals/SDL/docs/man3/SDL_RWFromFile.3 create mode 100644 Externals/SDL/docs/man3/SDL_Rect.3 create mode 100644 Externals/SDL/docs/man3/SDL_RemoveTimer.3 create mode 100644 Externals/SDL/docs/man3/SDL_ResizeEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_SaveBMP.3 create mode 100644 Externals/SDL/docs/man3/SDL_SemPost.3 create mode 100644 Externals/SDL/docs/man3/SDL_SemTryWait.3 create mode 100644 Externals/SDL/docs/man3/SDL_SemValue.3 create mode 100644 Externals/SDL/docs/man3/SDL_SemWait.3 create mode 100644 Externals/SDL/docs/man3/SDL_SemWaitTimeout.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetAlpha.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetClipRect.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetColorKey.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetColors.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetCursor.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetEventFilter.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetGamma.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetGammaRamp.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetModState.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetPalette.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetTimer.3 create mode 100644 Externals/SDL/docs/man3/SDL_SetVideoMode.3 create mode 100644 Externals/SDL/docs/man3/SDL_ShowCursor.3 create mode 100644 Externals/SDL/docs/man3/SDL_Surface.3 create mode 100644 Externals/SDL/docs/man3/SDL_SysWMEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_ThreadID.3 create mode 100644 Externals/SDL/docs/man3/SDL_UnlockAudio.3 create mode 100644 Externals/SDL/docs/man3/SDL_UnlockSurface.3 create mode 100644 Externals/SDL/docs/man3/SDL_UnlockYUVOverlay.3 create mode 100644 Externals/SDL/docs/man3/SDL_UpdateRect.3 create mode 100644 Externals/SDL/docs/man3/SDL_UpdateRects.3 create mode 100644 Externals/SDL/docs/man3/SDL_UserEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_VideoDriverName.3 create mode 100644 Externals/SDL/docs/man3/SDL_VideoInfo.3 create mode 100644 Externals/SDL/docs/man3/SDL_VideoModeOK.3 create mode 100644 Externals/SDL/docs/man3/SDL_WM_GetCaption.3 create mode 100644 Externals/SDL/docs/man3/SDL_WM_GrabInput.3 create mode 100644 Externals/SDL/docs/man3/SDL_WM_IconifyWindow.3 create mode 100644 Externals/SDL/docs/man3/SDL_WM_SetCaption.3 create mode 100644 Externals/SDL/docs/man3/SDL_WM_SetIcon.3 create mode 100644 Externals/SDL/docs/man3/SDL_WM_ToggleFullScreen.3 create mode 100644 Externals/SDL/docs/man3/SDL_WaitEvent.3 create mode 100644 Externals/SDL/docs/man3/SDL_WaitThread.3 create mode 100644 Externals/SDL/docs/man3/SDL_WarpMouse.3 create mode 100644 Externals/SDL/docs/man3/SDL_WasInit.3 create mode 100644 Externals/SDL/docs/man3/SDL_keysym.3 create mode 100644 Externals/SDL/docs/man3/SDL_mutexP.3 create mode 100644 Externals/SDL/docs/man3/SDL_mutexV.3 create mode 100644 Externals/SDL/include/SDL.h create mode 100644 Externals/SDL/include/SDL_active.h create mode 100644 Externals/SDL/include/SDL_audio.h create mode 100644 Externals/SDL/include/SDL_byteorder.h create mode 100644 Externals/SDL/include/SDL_cdrom.h create mode 100644 Externals/SDL/include/SDL_config.h create mode 100644 Externals/SDL/include/SDL_config.h.default create mode 100644 Externals/SDL/include/SDL_config.h.in create mode 100644 Externals/SDL/include/SDL_config_dreamcast.h create mode 100644 Externals/SDL/include/SDL_config_macos.h create mode 100644 Externals/SDL/include/SDL_config_macosx.h create mode 100644 Externals/SDL/include/SDL_config_minimal.h create mode 100644 Externals/SDL/include/SDL_config_nds.h create mode 100644 Externals/SDL/include/SDL_config_os2.h create mode 100644 Externals/SDL/include/SDL_config_symbian.h create mode 100644 Externals/SDL/include/SDL_config_win32.h create mode 100644 Externals/SDL/include/SDL_copying.h create mode 100644 Externals/SDL/include/SDL_cpuinfo.h create mode 100644 Externals/SDL/include/SDL_endian.h create mode 100644 Externals/SDL/include/SDL_error.h create mode 100644 Externals/SDL/include/SDL_events.h create mode 100644 Externals/SDL/include/SDL_getenv.h create mode 100644 Externals/SDL/include/SDL_joystick.h create mode 100644 Externals/SDL/include/SDL_keyboard.h create mode 100644 Externals/SDL/include/SDL_keysym.h create mode 100644 Externals/SDL/include/SDL_loadso.h create mode 100644 Externals/SDL/include/SDL_main.h create mode 100644 Externals/SDL/include/SDL_mouse.h create mode 100644 Externals/SDL/include/SDL_mutex.h create mode 100644 Externals/SDL/include/SDL_name.h create mode 100644 Externals/SDL/include/SDL_opengl.h create mode 100644 Externals/SDL/include/SDL_platform.h create mode 100644 Externals/SDL/include/SDL_quit.h create mode 100644 Externals/SDL/include/SDL_rwops.h create mode 100644 Externals/SDL/include/SDL_stdinc.h create mode 100644 Externals/SDL/include/SDL_syswm.h create mode 100644 Externals/SDL/include/SDL_thread.h create mode 100644 Externals/SDL/include/SDL_timer.h create mode 100644 Externals/SDL/include/SDL_types.h create mode 100644 Externals/SDL/include/SDL_version.h create mode 100644 Externals/SDL/include/SDL_video.h create mode 100644 Externals/SDL/include/begin_code.h create mode 100644 Externals/SDL/include/close_code.h create mode 100644 Externals/SDL/include/doxyfile create mode 100644 Externals/SDL/sdl-config.in create mode 100644 Externals/SDL/sdl.m4 create mode 100644 Externals/SDL/sdl.pc.in create mode 100644 Externals/SDL/src/SDL.c create mode 100644 Externals/SDL/src/SDL_error.c create mode 100644 Externals/SDL/src/SDL_error_c.h create mode 100644 Externals/SDL/src/SDL_fatal.c create mode 100644 Externals/SDL/src/SDL_fatal.h create mode 100644 Externals/SDL/src/audio/SDL_audio.c create mode 100644 Externals/SDL/src/audio/SDL_audio_c.h create mode 100644 Externals/SDL/src/audio/SDL_audiocvt.c create mode 100644 Externals/SDL/src/audio/SDL_audiodev.c create mode 100644 Externals/SDL/src/audio/SDL_audiodev_c.h create mode 100644 Externals/SDL/src/audio/SDL_audiomem.h create mode 100644 Externals/SDL/src/audio/SDL_mixer.c create mode 100644 Externals/SDL/src/audio/SDL_mixer_MMX.c create mode 100644 Externals/SDL/src/audio/SDL_mixer_MMX.h create mode 100644 Externals/SDL/src/audio/SDL_mixer_MMX_VC.c create mode 100644 Externals/SDL/src/audio/SDL_mixer_MMX_VC.h create mode 100644 Externals/SDL/src/audio/SDL_mixer_m68k.c create mode 100644 Externals/SDL/src/audio/SDL_mixer_m68k.h create mode 100644 Externals/SDL/src/audio/SDL_sysaudio.h create mode 100644 Externals/SDL/src/audio/SDL_wave.c create mode 100644 Externals/SDL/src/audio/SDL_wave.h create mode 100644 Externals/SDL/src/audio/alsa/SDL_alsa_audio.c create mode 100644 Externals/SDL/src/audio/alsa/SDL_alsa_audio.h create mode 100644 Externals/SDL/src/audio/arts/SDL_artsaudio.c create mode 100644 Externals/SDL/src/audio/arts/SDL_artsaudio.h create mode 100644 Externals/SDL/src/audio/baudio/SDL_beaudio.cc create mode 100644 Externals/SDL/src/audio/baudio/SDL_beaudio.h create mode 100644 Externals/SDL/src/audio/bsd/SDL_bsdaudio.c create mode 100644 Externals/SDL/src/audio/bsd/SDL_bsdaudio.h create mode 100644 Externals/SDL/src/audio/dart/SDL_dart.c create mode 100644 Externals/SDL/src/audio/dart/SDL_dart.h create mode 100644 Externals/SDL/src/audio/dc/SDL_dcaudio.c create mode 100644 Externals/SDL/src/audio/dc/SDL_dcaudio.h create mode 100644 Externals/SDL/src/audio/dc/aica.c create mode 100644 Externals/SDL/src/audio/dc/aica.h create mode 100644 Externals/SDL/src/audio/disk/SDL_diskaudio.c create mode 100644 Externals/SDL/src/audio/disk/SDL_diskaudio.h create mode 100644 Externals/SDL/src/audio/dma/SDL_dmaaudio.c create mode 100644 Externals/SDL/src/audio/dma/SDL_dmaaudio.h create mode 100644 Externals/SDL/src/audio/dmedia/SDL_irixaudio.c create mode 100644 Externals/SDL/src/audio/dmedia/SDL_irixaudio.h create mode 100644 Externals/SDL/src/audio/dsp/SDL_dspaudio.c create mode 100644 Externals/SDL/src/audio/dsp/SDL_dspaudio.h create mode 100644 Externals/SDL/src/audio/dummy/SDL_dummyaudio.c create mode 100644 Externals/SDL/src/audio/dummy/SDL_dummyaudio.h create mode 100644 Externals/SDL/src/audio/esd/SDL_esdaudio.c create mode 100644 Externals/SDL/src/audio/esd/SDL_esdaudio.h create mode 100644 Externals/SDL/src/audio/macosx/SDL_coreaudio.c create mode 100644 Externals/SDL/src/audio/macosx/SDL_coreaudio.h create mode 100644 Externals/SDL/src/audio/macrom/SDL_romaudio.c create mode 100644 Externals/SDL/src/audio/macrom/SDL_romaudio.h create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio.c create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio.h create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_dma8.c create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_dma8.h create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_gsxb.c create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_gsxb.h create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_it.S create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_mcsn.c create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_mcsn.h create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_stfa.c create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_stfa.h create mode 100644 Externals/SDL/src/audio/mint/SDL_mintaudio_xbios.c create mode 100644 Externals/SDL/src/audio/mme/SDL_mmeaudio.c create mode 100644 Externals/SDL/src/audio/mme/SDL_mmeaudio.h create mode 100644 Externals/SDL/src/audio/nas/SDL_nasaudio.c create mode 100644 Externals/SDL/src/audio/nas/SDL_nasaudio.h create mode 100644 Externals/SDL/src/audio/nds/SDL_ndsaudio.c create mode 100644 Externals/SDL/src/audio/nds/SDL_ndsaudio.h create mode 100644 Externals/SDL/src/audio/nds/sound9.c create mode 100644 Externals/SDL/src/audio/nds/soundcommon.h create mode 100644 Externals/SDL/src/audio/nto/SDL_nto_audio.c create mode 100644 Externals/SDL/src/audio/nto/SDL_nto_audio.h create mode 100644 Externals/SDL/src/audio/paudio/SDL_paudio.c create mode 100644 Externals/SDL/src/audio/paudio/SDL_paudio.h create mode 100644 Externals/SDL/src/audio/pulse/SDL_pulseaudio.c create mode 100644 Externals/SDL/src/audio/pulse/SDL_pulseaudio.h create mode 100644 Externals/SDL/src/audio/sun/SDL_sunaudio.c create mode 100644 Externals/SDL/src/audio/sun/SDL_sunaudio.h create mode 100644 Externals/SDL/src/audio/symbian/SDL_epocaudio.cpp create mode 100644 Externals/SDL/src/audio/symbian/SDL_epocaudio.h create mode 100644 Externals/SDL/src/audio/symbian/streamplayer.cpp create mode 100644 Externals/SDL/src/audio/symbian/streamplayer.h create mode 100644 Externals/SDL/src/audio/ums/SDL_umsaudio.c create mode 100644 Externals/SDL/src/audio/ums/SDL_umsaudio.h create mode 100644 Externals/SDL/src/audio/windib/SDL_dibaudio.c create mode 100644 Externals/SDL/src/audio/windib/SDL_dibaudio.h create mode 100644 Externals/SDL/src/audio/windx5/SDL_dx5audio.c create mode 100644 Externals/SDL/src/audio/windx5/SDL_dx5audio.h create mode 100644 Externals/SDL/src/audio/windx5/directx.h create mode 100644 Externals/SDL/src/cdrom/SDL_cdrom.c create mode 100644 Externals/SDL/src/cdrom/SDL_syscdrom.h create mode 100644 Externals/SDL/src/cdrom/aix/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/beos/SDL_syscdrom.cc create mode 100644 Externals/SDL/src/cdrom/bsdi/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/dc/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/dummy/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/freebsd/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/linux/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/macos/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/macos/SDL_syscdrom_c.h create mode 100644 Externals/SDL/src/cdrom/macosx/AudioFilePlayer.c create mode 100644 Externals/SDL/src/cdrom/macosx/AudioFilePlayer.h create mode 100644 Externals/SDL/src/cdrom/macosx/AudioFileReaderThread.c create mode 100644 Externals/SDL/src/cdrom/macosx/CDPlayer.c create mode 100644 Externals/SDL/src/cdrom/macosx/CDPlayer.h create mode 100644 Externals/SDL/src/cdrom/macosx/SDLOSXCAGuard.c create mode 100644 Externals/SDL/src/cdrom/macosx/SDLOSXCAGuard.h create mode 100644 Externals/SDL/src/cdrom/macosx/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/macosx/SDL_syscdrom_c.h create mode 100644 Externals/SDL/src/cdrom/mint/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/openbsd/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/os2/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/osf/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/qnx/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cdrom/win32/SDL_syscdrom.c create mode 100644 Externals/SDL/src/cpuinfo/SDL_cpuinfo.c create mode 100644 Externals/SDL/src/events/SDL_active.c create mode 100644 Externals/SDL/src/events/SDL_events.c create mode 100644 Externals/SDL/src/events/SDL_events_c.h create mode 100644 Externals/SDL/src/events/SDL_expose.c create mode 100644 Externals/SDL/src/events/SDL_keyboard.c create mode 100644 Externals/SDL/src/events/SDL_mouse.c create mode 100644 Externals/SDL/src/events/SDL_quit.c create mode 100644 Externals/SDL/src/events/SDL_resize.c create mode 100644 Externals/SDL/src/events/SDL_sysevents.h create mode 100644 Externals/SDL/src/file/SDL_rwops.c create mode 100644 Externals/SDL/src/hermes/COPYING.LIB create mode 100644 Externals/SDL/src/hermes/HeadMMX.h create mode 100644 Externals/SDL/src/hermes/HeadX86.h create mode 100644 Externals/SDL/src/hermes/README create mode 100644 Externals/SDL/src/hermes/common.inc create mode 100644 Externals/SDL/src/hermes/mmx_main.asm create mode 100644 Externals/SDL/src/hermes/mmxp2_32.asm create mode 100644 Externals/SDL/src/hermes/x86_main.asm create mode 100644 Externals/SDL/src/hermes/x86p_16.asm create mode 100644 Externals/SDL/src/hermes/x86p_32.asm create mode 100644 Externals/SDL/src/joystick/SDL_joystick.c create mode 100644 Externals/SDL/src/joystick/SDL_joystick_c.h create mode 100644 Externals/SDL/src/joystick/SDL_sysjoystick.h create mode 100644 Externals/SDL/src/joystick/beos/SDL_bejoystick.cc create mode 100644 Externals/SDL/src/joystick/bsd/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/darwin/10.3.9-FIX/IOHIDLib.h create mode 100644 Externals/SDL/src/joystick/darwin/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/dc/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/dummy/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/linux/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/macos/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/mint/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/nds/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/os2/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/os2/joyos2.h create mode 100644 Externals/SDL/src/joystick/riscos/SDL_sysjoystick.c create mode 100644 Externals/SDL/src/joystick/win32/SDL_mmjoystick.c create mode 100644 Externals/SDL/src/loadso/beos/SDL_sysloadso.c create mode 100644 Externals/SDL/src/loadso/dlopen/SDL_sysloadso.c create mode 100644 Externals/SDL/src/loadso/dummy/SDL_sysloadso.c create mode 100644 Externals/SDL/src/loadso/macos/SDL_sysloadso.c create mode 100644 Externals/SDL/src/loadso/macosx/SDL_dlcompat.c create mode 100644 Externals/SDL/src/loadso/mint/SDL_sysloadso.c create mode 100644 Externals/SDL/src/loadso/os2/SDL_sysloadso.c create mode 100644 Externals/SDL/src/loadso/win32/SDL_sysloadso.c create mode 100644 Externals/SDL/src/main/beos/SDL_BeApp.cc create mode 100644 Externals/SDL/src/main/beos/SDL_BeApp.h create mode 100644 Externals/SDL/src/main/dummy/SDL_dummy_main.c create mode 100644 Externals/SDL/src/main/macos/SDL.r create mode 100644 Externals/SDL/src/main/macos/SDL.shlib.r create mode 100644 Externals/SDL/src/main/macos/SDL_main.c create mode 100644 Externals/SDL/src/main/macos/SIZE.r create mode 100644 Externals/SDL/src/main/macos/exports/Makefile create mode 100644 Externals/SDL/src/main/macos/exports/SDL.x create mode 100644 Externals/SDL/src/main/macos/exports/gendef.pl create mode 100644 Externals/SDL/src/main/macosx/Info.plist.in create mode 100644 Externals/SDL/src/main/macosx/SDLMain.h create mode 100644 Externals/SDL/src/main/macosx/SDLMain.m create mode 100644 Externals/SDL/src/main/macosx/SDLMain.nib/classes.nib create mode 100644 Externals/SDL/src/main/macosx/SDLMain.nib/info.nib create mode 100644 Externals/SDL/src/main/macosx/SDLMain.nib/objects.nib create mode 100644 Externals/SDL/src/main/macosx/info.nib create mode 100644 Externals/SDL/src/main/qtopia/SDL_qtopia_main.cc create mode 100644 Externals/SDL/src/main/symbian/EKA1/SDL_main.cpp create mode 100644 Externals/SDL/src/main/symbian/EKA2/SDL_main.cpp create mode 100644 Externals/SDL/src/main/symbian/EKA2/sdlexe.cpp create mode 100644 Externals/SDL/src/main/symbian/EKA2/sdllib.cpp create mode 100644 Externals/SDL/src/main/symbian/EKA2/vectorbuffer.cpp create mode 100644 Externals/SDL/src/main/symbian/EKA2/vectorbuffer.h create mode 100644 Externals/SDL/src/main/win32/SDL_win32_main.c create mode 100644 Externals/SDL/src/main/win32/version.rc create mode 100644 Externals/SDL/src/stdlib/SDL_getenv.c create mode 100644 Externals/SDL/src/stdlib/SDL_iconv.c create mode 100644 Externals/SDL/src/stdlib/SDL_malloc.c create mode 100644 Externals/SDL/src/stdlib/SDL_qsort.c create mode 100644 Externals/SDL/src/stdlib/SDL_stdlib.c create mode 100644 Externals/SDL/src/stdlib/SDL_string.c create mode 100644 Externals/SDL/src/thread/SDL_systhread.h create mode 100644 Externals/SDL/src/thread/SDL_thread.c create mode 100644 Externals/SDL/src/thread/SDL_thread_c.h create mode 100644 Externals/SDL/src/thread/beos/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/beos/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/beos/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/dc/SDL_syscond.c create mode 100644 Externals/SDL/src/thread/dc/SDL_syscond_c.h create mode 100644 Externals/SDL/src/thread/dc/SDL_sysmutex.c create mode 100644 Externals/SDL/src/thread/dc/SDL_sysmutex_c.h create mode 100644 Externals/SDL/src/thread/dc/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/dc/SDL_syssem_c.h create mode 100644 Externals/SDL/src/thread/dc/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/dc/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/generic/SDL_syscond.c create mode 100644 Externals/SDL/src/thread/generic/SDL_sysmutex.c create mode 100644 Externals/SDL/src/thread/generic/SDL_sysmutex_c.h create mode 100644 Externals/SDL/src/thread/generic/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/generic/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/generic/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/irix/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/irix/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/irix/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/os2/SDL_syscond.c create mode 100644 Externals/SDL/src/thread/os2/SDL_syscond_c.h create mode 100644 Externals/SDL/src/thread/os2/SDL_sysmutex.c create mode 100644 Externals/SDL/src/thread/os2/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/os2/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/os2/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/pth/SDL_syscond.c create mode 100644 Externals/SDL/src/thread/pth/SDL_sysmutex.c create mode 100644 Externals/SDL/src/thread/pth/SDL_sysmutex_c.h create mode 100644 Externals/SDL/src/thread/pth/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/pth/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/pthread/SDL_syscond.c create mode 100644 Externals/SDL/src/thread/pthread/SDL_sysmutex.c create mode 100644 Externals/SDL/src/thread/pthread/SDL_sysmutex_c.h create mode 100644 Externals/SDL/src/thread/pthread/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/pthread/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/pthread/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/riscos/SDL_syscond.c create mode 100644 Externals/SDL/src/thread/riscos/SDL_sysmutex.c create mode 100644 Externals/SDL/src/thread/riscos/SDL_sysmutex_c.h create mode 100644 Externals/SDL/src/thread/riscos/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/riscos/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/riscos/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/symbian/SDL_sysmutex.cpp create mode 100644 Externals/SDL/src/thread/symbian/SDL_syssem.cpp create mode 100644 Externals/SDL/src/thread/symbian/SDL_systhread.cpp create mode 100644 Externals/SDL/src/thread/symbian/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/win32/SDL_sysmutex.c create mode 100644 Externals/SDL/src/thread/win32/SDL_syssem.c create mode 100644 Externals/SDL/src/thread/win32/SDL_systhread.c create mode 100644 Externals/SDL/src/thread/win32/SDL_systhread_c.h create mode 100644 Externals/SDL/src/thread/win32/win_ce_semaphore.c create mode 100644 Externals/SDL/src/thread/win32/win_ce_semaphore.h create mode 100644 Externals/SDL/src/timer/SDL_systimer.h create mode 100644 Externals/SDL/src/timer/SDL_timer.c create mode 100644 Externals/SDL/src/timer/SDL_timer_c.h create mode 100644 Externals/SDL/src/timer/beos/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/dc/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/dummy/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/macos/FastTimes.c create mode 100644 Externals/SDL/src/timer/macos/FastTimes.h create mode 100644 Externals/SDL/src/timer/macos/SDL_MPWtimer.c create mode 100644 Externals/SDL/src/timer/macos/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/mint/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/mint/SDL_vbltimer.S create mode 100644 Externals/SDL/src/timer/mint/SDL_vbltimer_s.h create mode 100644 Externals/SDL/src/timer/nds/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/os2/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/riscos/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/symbian/SDL_systimer.cpp create mode 100644 Externals/SDL/src/timer/unix/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/win32/SDL_systimer.c create mode 100644 Externals/SDL/src/timer/wince/SDL_systimer.c create mode 100644 Externals/SDL/src/video/SDL_RLEaccel.c create mode 100644 Externals/SDL/src/video/SDL_RLEaccel_c.h create mode 100644 Externals/SDL/src/video/SDL_blit.c create mode 100644 Externals/SDL/src/video/SDL_blit.h create mode 100644 Externals/SDL/src/video/SDL_blit_0.c create mode 100644 Externals/SDL/src/video/SDL_blit_1.c create mode 100644 Externals/SDL/src/video/SDL_blit_A.c create mode 100644 Externals/SDL/src/video/SDL_blit_N.c create mode 100644 Externals/SDL/src/video/SDL_bmp.c create mode 100644 Externals/SDL/src/video/SDL_cursor.c create mode 100644 Externals/SDL/src/video/SDL_cursor_c.h create mode 100644 Externals/SDL/src/video/SDL_gamma.c create mode 100644 Externals/SDL/src/video/SDL_glfuncs.h create mode 100644 Externals/SDL/src/video/SDL_leaks.h create mode 100644 Externals/SDL/src/video/SDL_pixels.c create mode 100644 Externals/SDL/src/video/SDL_pixels_c.h create mode 100644 Externals/SDL/src/video/SDL_stretch.c create mode 100644 Externals/SDL/src/video/SDL_stretch_c.h create mode 100644 Externals/SDL/src/video/SDL_surface.c create mode 100644 Externals/SDL/src/video/SDL_sysvideo.h create mode 100644 Externals/SDL/src/video/SDL_video.c create mode 100644 Externals/SDL/src/video/SDL_yuv.c create mode 100644 Externals/SDL/src/video/SDL_yuv_mmx.c create mode 100644 Externals/SDL/src/video/SDL_yuv_sw.c create mode 100644 Externals/SDL/src/video/SDL_yuv_sw_c.h create mode 100644 Externals/SDL/src/video/SDL_yuvfuncs.h create mode 100644 Externals/SDL/src/video/Xext/README create mode 100644 Externals/SDL/src/video/Xext/XME/xme.c create mode 100644 Externals/SDL/src/video/Xext/Xinerama/Xinerama.c create mode 100644 Externals/SDL/src/video/Xext/Xv/Xv.c create mode 100644 Externals/SDL/src/video/Xext/Xv/Xvlibint.h create mode 100644 Externals/SDL/src/video/Xext/Xxf86dga/XF86DGA.c create mode 100644 Externals/SDL/src/video/Xext/Xxf86dga/XF86DGA2.c create mode 100644 Externals/SDL/src/video/Xext/Xxf86vm/XF86VMode.c create mode 100644 Externals/SDL/src/video/Xext/extensions/Xext.h create mode 100644 Externals/SDL/src/video/Xext/extensions/Xinerama.h create mode 100644 Externals/SDL/src/video/Xext/extensions/Xv.h create mode 100644 Externals/SDL/src/video/Xext/extensions/Xvlib.h create mode 100644 Externals/SDL/src/video/Xext/extensions/Xvproto.h create mode 100644 Externals/SDL/src/video/Xext/extensions/extutil.h create mode 100644 Externals/SDL/src/video/Xext/extensions/panoramiXext.h create mode 100644 Externals/SDL/src/video/Xext/extensions/panoramiXproto.h create mode 100644 Externals/SDL/src/video/Xext/extensions/xf86dga.h create mode 100644 Externals/SDL/src/video/Xext/extensions/xf86dga1.h create mode 100644 Externals/SDL/src/video/Xext/extensions/xf86dga1str.h create mode 100644 Externals/SDL/src/video/Xext/extensions/xf86dgastr.h create mode 100644 Externals/SDL/src/video/Xext/extensions/xf86vmode.h create mode 100644 Externals/SDL/src/video/Xext/extensions/xf86vmstr.h create mode 100644 Externals/SDL/src/video/Xext/extensions/xme.h create mode 100644 Externals/SDL/src/video/aalib/SDL_aaevents.c create mode 100644 Externals/SDL/src/video/aalib/SDL_aaevents_c.h create mode 100644 Externals/SDL/src/video/aalib/SDL_aamouse.c create mode 100644 Externals/SDL/src/video/aalib/SDL_aamouse_c.h create mode 100644 Externals/SDL/src/video/aalib/SDL_aavideo.c create mode 100644 Externals/SDL/src/video/aalib/SDL_aavideo.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ataric2p.S create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ataric2p_s.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ataridevmouse.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ataridevmouse_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarieddi.S create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarieddi_s.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarievents.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarievents_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarigl.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarigl_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarikeys.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarimxalloc.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_atarimxalloc_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_biosevents.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_biosevents_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_gemdosevents.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_gemdosevents_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ikbdevents.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ikbdevents_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ikbdinterrupt.S create mode 100644 Externals/SDL/src/video/ataricommon/SDL_ikbdinterrupt_s.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_xbiosevents.c create mode 100644 Externals/SDL/src/video/ataricommon/SDL_xbiosevents_c.h create mode 100644 Externals/SDL/src/video/ataricommon/SDL_xbiosinterrupt.S create mode 100644 Externals/SDL/src/video/ataricommon/SDL_xbiosinterrupt_s.h create mode 100644 Externals/SDL/src/video/blank_cursor.h create mode 100644 Externals/SDL/src/video/bwindow/SDL_BView.h create mode 100644 Externals/SDL/src/video/bwindow/SDL_BWin.h create mode 100644 Externals/SDL/src/video/bwindow/SDL_lowvideo.h create mode 100644 Externals/SDL/src/video/bwindow/SDL_sysevents.cc create mode 100644 Externals/SDL/src/video/bwindow/SDL_sysevents_c.h create mode 100644 Externals/SDL/src/video/bwindow/SDL_sysmouse.cc create mode 100644 Externals/SDL/src/video/bwindow/SDL_sysmouse_c.h create mode 100644 Externals/SDL/src/video/bwindow/SDL_sysvideo.cc create mode 100644 Externals/SDL/src/video/bwindow/SDL_syswm.cc create mode 100644 Externals/SDL/src/video/bwindow/SDL_syswm_c.h create mode 100644 Externals/SDL/src/video/bwindow/SDL_sysyuv.cc create mode 100644 Externals/SDL/src/video/bwindow/SDL_sysyuv.h create mode 100644 Externals/SDL/src/video/caca/SDL_cacaevents.c create mode 100644 Externals/SDL/src/video/caca/SDL_cacaevents_c.h create mode 100644 Externals/SDL/src/video/caca/SDL_cacavideo.c create mode 100644 Externals/SDL/src/video/caca/SDL_cacavideo.h create mode 100644 Externals/SDL/src/video/dc/SDL_dcevents.c create mode 100644 Externals/SDL/src/video/dc/SDL_dcevents_c.h create mode 100644 Externals/SDL/src/video/dc/SDL_dcmouse.c create mode 100644 Externals/SDL/src/video/dc/SDL_dcmouse_c.h create mode 100644 Externals/SDL/src/video/dc/SDL_dcvideo.c create mode 100644 Externals/SDL/src/video/dc/SDL_dcvideo.h create mode 100644 Externals/SDL/src/video/default_cursor.h create mode 100644 Externals/SDL/src/video/dga/SDL_dgaevents.c create mode 100644 Externals/SDL/src/video/dga/SDL_dgaevents_c.h create mode 100644 Externals/SDL/src/video/dga/SDL_dgamouse.c create mode 100644 Externals/SDL/src/video/dga/SDL_dgamouse_c.h create mode 100644 Externals/SDL/src/video/dga/SDL_dgavideo.c create mode 100644 Externals/SDL/src/video/dga/SDL_dgavideo.h create mode 100644 Externals/SDL/src/video/directfb/SDL_DirectFB_events.c create mode 100644 Externals/SDL/src/video/directfb/SDL_DirectFB_events.h create mode 100644 Externals/SDL/src/video/directfb/SDL_DirectFB_keys.h create mode 100644 Externals/SDL/src/video/directfb/SDL_DirectFB_video.c create mode 100644 Externals/SDL/src/video/directfb/SDL_DirectFB_video.h create mode 100644 Externals/SDL/src/video/directfb/SDL_DirectFB_yuv.c create mode 100644 Externals/SDL/src/video/directfb/SDL_DirectFB_yuv.h create mode 100644 Externals/SDL/src/video/dummy/SDL_nullevents.c create mode 100644 Externals/SDL/src/video/dummy/SDL_nullevents_c.h create mode 100644 Externals/SDL/src/video/dummy/SDL_nullmouse.c create mode 100644 Externals/SDL/src/video/dummy/SDL_nullmouse_c.h create mode 100644 Externals/SDL/src/video/dummy/SDL_nullvideo.c create mode 100644 Externals/SDL/src/video/dummy/SDL_nullvideo.h create mode 100644 Externals/SDL/src/video/e_log.h create mode 100644 Externals/SDL/src/video/e_pow.h create mode 100644 Externals/SDL/src/video/e_sqrt.h create mode 100644 Externals/SDL/src/video/fbcon/3dfx_mmio.h create mode 100644 Externals/SDL/src/video/fbcon/3dfx_regs.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fb3dfx.c create mode 100644 Externals/SDL/src/video/fbcon/SDL_fb3dfx.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbelo.c create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbelo.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbevents.c create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbevents_c.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbkeys.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbmatrox.c create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbmatrox.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbmouse.c create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbmouse_c.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbriva.c create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbriva.h create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbvideo.c create mode 100644 Externals/SDL/src/video/fbcon/SDL_fbvideo.h create mode 100644 Externals/SDL/src/video/fbcon/matrox_mmio.h create mode 100644 Externals/SDL/src/video/fbcon/matrox_regs.h create mode 100644 Externals/SDL/src/video/fbcon/riva_mmio.h create mode 100644 Externals/SDL/src/video/fbcon/riva_regs.h create mode 100644 Externals/SDL/src/video/gapi/SDL_gapivideo.c create mode 100644 Externals/SDL/src/video/gapi/SDL_gapivideo.h create mode 100644 Externals/SDL/src/video/gem/SDL_gemevents.c create mode 100644 Externals/SDL/src/video/gem/SDL_gemevents_c.h create mode 100644 Externals/SDL/src/video/gem/SDL_gemmouse.c create mode 100644 Externals/SDL/src/video/gem/SDL_gemmouse_c.h create mode 100644 Externals/SDL/src/video/gem/SDL_gemvideo.c create mode 100644 Externals/SDL/src/video/gem/SDL_gemvideo.h create mode 100644 Externals/SDL/src/video/gem/SDL_gemwm.c create mode 100644 Externals/SDL/src/video/gem/SDL_gemwm_c.h create mode 100644 Externals/SDL/src/video/ggi/SDL_ggievents.c create mode 100755 Externals/SDL/src/video/ggi/SDL_ggievents_c.h create mode 100644 Externals/SDL/src/video/ggi/SDL_ggikeys.h create mode 100644 Externals/SDL/src/video/ggi/SDL_ggimouse.c create mode 100755 Externals/SDL/src/video/ggi/SDL_ggimouse_c.h create mode 100644 Externals/SDL/src/video/ggi/SDL_ggivideo.c create mode 100644 Externals/SDL/src/video/ggi/SDL_ggivideo.h create mode 100644 Externals/SDL/src/video/ipod/SDL_ipodvideo.c create mode 100644 Externals/SDL/src/video/ipod/SDL_ipodvideo.h create mode 100644 Externals/SDL/src/video/maccommon/SDL_lowvideo.h create mode 100644 Externals/SDL/src/video/maccommon/SDL_macevents.c create mode 100644 Externals/SDL/src/video/maccommon/SDL_macevents_c.h create mode 100644 Externals/SDL/src/video/maccommon/SDL_macgl.c create mode 100644 Externals/SDL/src/video/maccommon/SDL_macgl_c.h create mode 100644 Externals/SDL/src/video/maccommon/SDL_mackeys.h create mode 100644 Externals/SDL/src/video/maccommon/SDL_macmouse.c create mode 100644 Externals/SDL/src/video/maccommon/SDL_macmouse_c.h create mode 100644 Externals/SDL/src/video/maccommon/SDL_macwm.c create mode 100644 Externals/SDL/src/video/maccommon/SDL_macwm_c.h create mode 100644 Externals/SDL/src/video/macdsp/SDL_dspvideo.c create mode 100644 Externals/SDL/src/video/macdsp/SDL_dspvideo.h create mode 100644 Externals/SDL/src/video/macrom/SDL_romvideo.c create mode 100644 Externals/SDL/src/video/macrom/SDL_romvideo.h create mode 100644 Externals/SDL/src/video/math_private.h create mode 100644 Externals/SDL/src/video/mmx.h create mode 100644 Externals/SDL/src/video/nanox/SDL_nxevents.c create mode 100644 Externals/SDL/src/video/nanox/SDL_nxevents_c.h create mode 100644 Externals/SDL/src/video/nanox/SDL_nximage.c create mode 100644 Externals/SDL/src/video/nanox/SDL_nximage_c.h create mode 100644 Externals/SDL/src/video/nanox/SDL_nxmodes.c create mode 100644 Externals/SDL/src/video/nanox/SDL_nxmodes_c.h create mode 100644 Externals/SDL/src/video/nanox/SDL_nxmouse.c create mode 100644 Externals/SDL/src/video/nanox/SDL_nxmouse_c.h create mode 100644 Externals/SDL/src/video/nanox/SDL_nxvideo.c create mode 100644 Externals/SDL/src/video/nanox/SDL_nxvideo.h create mode 100644 Externals/SDL/src/video/nanox/SDL_nxwm.c create mode 100644 Externals/SDL/src/video/nanox/SDL_nxwm_c.h create mode 100644 Externals/SDL/src/video/nds/SDL_ndsevents.c create mode 100644 Externals/SDL/src/video/nds/SDL_ndsevents_c.h create mode 100644 Externals/SDL/src/video/nds/SDL_ndsmouse.c create mode 100644 Externals/SDL/src/video/nds/SDL_ndsmouse_c.h create mode 100644 Externals/SDL/src/video/nds/SDL_ndsvideo.c create mode 100644 Externals/SDL/src/video/nds/SDL_ndsvideo.h create mode 100644 Externals/SDL/src/video/os2fslib/SDL_os2fslib.c create mode 100644 Externals/SDL/src/video/os2fslib/SDL_os2fslib.h create mode 100644 Externals/SDL/src/video/os2fslib/SDL_vkeys.h create mode 100644 Externals/SDL/src/video/photon/SDL_ph_events.c create mode 100644 Externals/SDL/src/video/photon/SDL_ph_events_c.h create mode 100644 Externals/SDL/src/video/photon/SDL_ph_gl.c create mode 100644 Externals/SDL/src/video/photon/SDL_ph_gl.h create mode 100644 Externals/SDL/src/video/photon/SDL_ph_image.c create mode 100644 Externals/SDL/src/video/photon/SDL_ph_image_c.h create mode 100644 Externals/SDL/src/video/photon/SDL_ph_modes.c create mode 100644 Externals/SDL/src/video/photon/SDL_ph_modes_c.h create mode 100644 Externals/SDL/src/video/photon/SDL_ph_mouse.c create mode 100644 Externals/SDL/src/video/photon/SDL_ph_mouse_c.h create mode 100644 Externals/SDL/src/video/photon/SDL_ph_video.c create mode 100644 Externals/SDL/src/video/photon/SDL_ph_video.h create mode 100644 Externals/SDL/src/video/photon/SDL_ph_wm.c create mode 100644 Externals/SDL/src/video/photon/SDL_ph_wm_c.h create mode 100644 Externals/SDL/src/video/photon/SDL_phyuv.c create mode 100644 Externals/SDL/src/video/photon/SDL_phyuv_c.h create mode 100644 Externals/SDL/src/video/picogui/SDL_pgevents.c create mode 100644 Externals/SDL/src/video/picogui/SDL_pgevents_c.h create mode 100644 Externals/SDL/src/video/picogui/SDL_pgvideo.c create mode 100644 Externals/SDL/src/video/picogui/SDL_pgvideo.h create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsevents.c create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsevents_c.h create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gskeys.h create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsmouse.c create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsmouse_c.h create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsvideo.c create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsvideo.h create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsyuv.c create mode 100644 Externals/SDL/src/video/ps2gs/SDL_gsyuv_c.h create mode 100644 Externals/SDL/src/video/ps3/SDL_ps3events.c create mode 100644 Externals/SDL/src/video/ps3/SDL_ps3events_c.h create mode 100644 Externals/SDL/src/video/ps3/SDL_ps3video.c create mode 100644 Externals/SDL/src/video/ps3/SDL_ps3video.h create mode 100644 Externals/SDL/src/video/ps3/SDL_ps3yuv.c create mode 100644 Externals/SDL/src/video/ps3/SDL_ps3yuv_c.h create mode 100644 Externals/SDL/src/video/ps3/spulibs/Makefile create mode 100644 Externals/SDL/src/video/ps3/spulibs/bilin_scaler.c create mode 100644 Externals/SDL/src/video/ps3/spulibs/fb_writer.c create mode 100644 Externals/SDL/src/video/ps3/spulibs/spu_common.h create mode 100644 Externals/SDL/src/video/ps3/spulibs/yuv2rgb_converter.c create mode 100644 Externals/SDL/src/video/qtopia/SDL_QPEApp.cc create mode 100644 Externals/SDL/src/video/qtopia/SDL_QPEApp.h create mode 100644 Externals/SDL/src/video/qtopia/SDL_QWin.cc create mode 100644 Externals/SDL/src/video/qtopia/SDL_QWin.h create mode 100644 Externals/SDL/src/video/qtopia/SDL_lowvideo.h create mode 100644 Externals/SDL/src/video/qtopia/SDL_sysevents.cc create mode 100644 Externals/SDL/src/video/qtopia/SDL_sysevents_c.h create mode 100644 Externals/SDL/src/video/qtopia/SDL_sysmouse.cc create mode 100644 Externals/SDL/src/video/qtopia/SDL_sysmouse_c.h create mode 100644 Externals/SDL/src/video/qtopia/SDL_sysvideo.cc create mode 100644 Externals/SDL/src/video/qtopia/SDL_syswm.cc create mode 100644 Externals/SDL/src/video/qtopia/SDL_syswm_c.h create mode 100644 Externals/SDL/src/video/quartz/CGS.h create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzEvents.m create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzGL.m create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzKeys.h create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzVideo.h create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzVideo.m create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzWM.h create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzWM.m create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzWindow.h create mode 100644 Externals/SDL/src/video/quartz/SDL_QuartzWindow.m create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosASM.S create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosFullScreenVideo.c create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosevents.c create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosevents_c.h create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosmouse.c create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosmouse_c.h create mode 100644 Externals/SDL/src/video/riscos/SDL_riscossprite.c create mode 100644 Externals/SDL/src/video/riscos/SDL_riscostask.c create mode 100644 Externals/SDL/src/video/riscos/SDL_riscostask.h create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosvideo.c create mode 100644 Externals/SDL/src/video/riscos/SDL_riscosvideo.h create mode 100644 Externals/SDL/src/video/riscos/SDL_wimppoll.c create mode 100644 Externals/SDL/src/video/riscos/SDL_wimpvideo.c create mode 100644 Externals/SDL/src/video/svga/SDL_svgaevents.c create mode 100644 Externals/SDL/src/video/svga/SDL_svgaevents_c.h create mode 100644 Externals/SDL/src/video/svga/SDL_svgamouse.c create mode 100644 Externals/SDL/src/video/svga/SDL_svgamouse_c.h create mode 100644 Externals/SDL/src/video/svga/SDL_svgavideo.c create mode 100644 Externals/SDL/src/video/svga/SDL_svgavideo.h create mode 100644 Externals/SDL/src/video/symbian/EKA1/SDL_epocevents.cpp create mode 100644 Externals/SDL/src/video/symbian/EKA1/SDL_epocvideo.cpp create mode 100644 Externals/SDL/src/video/symbian/EKA1/SDL_epocvideo.h create mode 100644 Externals/SDL/src/video/symbian/EKA2/SDL_epocevents.cpp create mode 100644 Externals/SDL/src/video/symbian/EKA2/SDL_epocvideo.cpp create mode 100644 Externals/SDL/src/video/symbian/EKA2/SDL_epocvideo.h create mode 100644 Externals/SDL/src/video/symbian/EKA2/dsa.cpp create mode 100644 Externals/SDL/src/video/symbian/EKA2/dsa_new.cpp create mode 100644 Externals/SDL/src/video/symbian/EKA2/dsa_old.cpp create mode 100644 Externals/SDL/src/video/symbian/SDL_epocevents_c.h create mode 100644 Externals/SDL/src/video/vgl/SDL_vglevents.c create mode 100644 Externals/SDL/src/video/vgl/SDL_vglevents_c.h create mode 100644 Externals/SDL/src/video/vgl/SDL_vglmouse.c create mode 100644 Externals/SDL/src/video/vgl/SDL_vglmouse_c.h create mode 100644 Externals/SDL/src/video/vgl/SDL_vglvideo.c create mode 100644 Externals/SDL/src/video/vgl/SDL_vglvideo.h create mode 100644 Externals/SDL/src/video/wincommon/SDL_lowvideo.h create mode 100644 Externals/SDL/src/video/wincommon/SDL_sysevents.c create mode 100644 Externals/SDL/src/video/wincommon/SDL_sysmouse.c create mode 100644 Externals/SDL/src/video/wincommon/SDL_sysmouse_c.h create mode 100644 Externals/SDL/src/video/wincommon/SDL_syswm.c create mode 100644 Externals/SDL/src/video/wincommon/SDL_syswm_c.h create mode 100644 Externals/SDL/src/video/wincommon/SDL_wingl.c create mode 100644 Externals/SDL/src/video/wincommon/SDL_wingl_c.h create mode 100644 Externals/SDL/src/video/wincommon/wmmsg.h create mode 100644 Externals/SDL/src/video/windib/SDL_dibevents.c create mode 100644 Externals/SDL/src/video/windib/SDL_dibevents_c.h create mode 100644 Externals/SDL/src/video/windib/SDL_dibvideo.c create mode 100644 Externals/SDL/src/video/windib/SDL_dibvideo.h create mode 100644 Externals/SDL/src/video/windib/SDL_gapidibvideo.h create mode 100644 Externals/SDL/src/video/windib/SDL_vkeys.h create mode 100644 Externals/SDL/src/video/windx5/SDL_dx5events.c create mode 100644 Externals/SDL/src/video/windx5/SDL_dx5events_c.h create mode 100644 Externals/SDL/src/video/windx5/SDL_dx5video.c create mode 100644 Externals/SDL/src/video/windx5/SDL_dx5video.h create mode 100644 Externals/SDL/src/video/windx5/SDL_dx5yuv.c create mode 100644 Externals/SDL/src/video/windx5/SDL_dx5yuv_c.h create mode 100644 Externals/SDL/src/video/windx5/directx.h create mode 100644 Externals/SDL/src/video/wscons/SDL_wsconsevents.c create mode 100644 Externals/SDL/src/video/wscons/SDL_wsconsevents_c.h create mode 100644 Externals/SDL/src/video/wscons/SDL_wsconsmouse.c create mode 100644 Externals/SDL/src/video/wscons/SDL_wsconsmouse_c.h create mode 100644 Externals/SDL/src/video/wscons/SDL_wsconsvideo.c create mode 100644 Externals/SDL/src/video/wscons/SDL_wsconsvideo.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11dga.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11dga_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11dyn.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11dyn.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11events.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11events_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11gamma.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11gamma_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11gl.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11gl_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11image.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11image_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11modes.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11modes_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11mouse.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11mouse_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11sym.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11video.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11video.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11wm.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11wm_c.h create mode 100644 Externals/SDL/src/video/x11/SDL_x11yuv.c create mode 100644 Externals/SDL/src/video/x11/SDL_x11yuv_c.h create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios.c create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios.h create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_blowup.c create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_blowup.h create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_centscreen.c create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_centscreen.h create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_milan.c create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_milan.h create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_sb3.c create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_sb3.h create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_tveille.c create mode 100644 Externals/SDL/src/video/xbios/SDL_xbios_tveille.h create mode 100644 Externals/SDL/symbian.zip create mode 100644 Externals/SDL/test/COPYING create mode 100644 Externals/SDL/test/Makefile.in create mode 100644 Externals/SDL/test/README create mode 100644 Externals/SDL/test/acinclude.m4 create mode 100644 Externals/SDL/test/aclocal.m4 create mode 100755 Externals/SDL/test/autogen.sh create mode 100644 Externals/SDL/test/checkkeys.c create mode 100755 Externals/SDL/test/configure create mode 100644 Externals/SDL/test/configure.in create mode 100755 Externals/SDL/test/gcc-fat.sh create mode 100644 Externals/SDL/test/graywin.c create mode 100644 Externals/SDL/test/icon.bmp create mode 100644 Externals/SDL/test/loopwave.c create mode 100644 Externals/SDL/test/moose.dat create mode 100644 Externals/SDL/test/picture.xbm create mode 100644 Externals/SDL/test/sail.bmp create mode 100644 Externals/SDL/test/sample.bmp create mode 100644 Externals/SDL/test/sample.wav create mode 100644 Externals/SDL/test/testalpha.c create mode 100644 Externals/SDL/test/testbitmap.c create mode 100644 Externals/SDL/test/testblitspeed.c create mode 100644 Externals/SDL/test/testcdrom.c create mode 100644 Externals/SDL/test/testcursor.c create mode 100644 Externals/SDL/test/testdyngl.c create mode 100644 Externals/SDL/test/testerror.c create mode 100644 Externals/SDL/test/testfile.c create mode 100644 Externals/SDL/test/testgamma.c create mode 100644 Externals/SDL/test/testgl.c create mode 100644 Externals/SDL/test/testhread.c create mode 100644 Externals/SDL/test/testiconv.c create mode 100644 Externals/SDL/test/testjoystick.c create mode 100644 Externals/SDL/test/testkeys.c create mode 100644 Externals/SDL/test/testloadso.c create mode 100644 Externals/SDL/test/testlock.c create mode 100644 Externals/SDL/test/testoverlay.c create mode 100644 Externals/SDL/test/testoverlay2.c create mode 100644 Externals/SDL/test/testpalette.c create mode 100644 Externals/SDL/test/testplatform.c create mode 100644 Externals/SDL/test/testsem.c create mode 100644 Externals/SDL/test/testsprite.c create mode 100644 Externals/SDL/test/testtimer.c create mode 100644 Externals/SDL/test/testver.c create mode 100644 Externals/SDL/test/testvidinfo.c create mode 100644 Externals/SDL/test/testwin.c create mode 100644 Externals/SDL/test/testwm.c create mode 100644 Externals/SDL/test/threadwin.c create mode 100644 Externals/SDL/test/torturethread.c create mode 100644 Externals/SDL/test/utf8.txt diff --git a/Externals/GLew/LICENSE.txt b/Externals/GLew/LICENSE.txt new file mode 100644 index 0000000000..f7078042e9 --- /dev/null +++ b/Externals/GLew/LICENSE.txt @@ -0,0 +1,73 @@ +The OpenGL Extension Wrangler Library +Copyright (C) 2002-2007, Milan Ikits +Copyright (C) 2002-2007, Marcelo E. Magallon +Copyright (C) 2002, Lev Povalahev +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +* Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. +* The name of the author may be used to endorse or promote products + derived from this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +THE POSSIBILITY OF SUCH DAMAGE. + + +Mesa 3-D graphics library +Version: 7.0 + +Copyright (C) 1999-2007 Brian Paul All Rights Reserved. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the "Software"), +to deal in the Software without restriction, including without limitation +the rights to use, copy, modify, merge, publish, distribute, sublicense, +and/or sell copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included +in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN +AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + +Copyright (c) 2007 The Khronos Group Inc. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and/or associated documentation files (the +"Materials"), to deal in the Materials without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Materials, and to +permit persons to whom the Materials are furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be included +in all copies or substantial portions of the Materials. + +THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. diff --git a/Externals/GLew/Makefile b/Externals/GLew/Makefile new file mode 100644 index 0000000000..1eb3206dfe --- /dev/null +++ b/Externals/GLew/Makefile @@ -0,0 +1,268 @@ +#!gmake +## The OpenGL Extension Wrangler Library +## Copyright (C) 2002-2008, Milan Ikits +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002, Lev Povalahev +## All rights reserved. +## +## Redistribution and use in source and binary forms, with or without +## modification, are permitted provided that the following conditions are met: +## +## * Redistributions of source code must retain the above copyright notice, +## this list of conditions and the following disclaimer. +## * Redistributions in binary form must reproduce the above copyright notice, +## this list of conditions and the following disclaimer in the documentation +## and/or other materials provided with the distribution. +## * The name of the author may be used to endorse or promote products +## derived from this software without specific prior written permission. +## +## THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +## AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +## IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +## ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +## LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +## CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +## SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +## INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +## CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +## ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +## THE POSSIBILITY OF SUCH DAMAGE. + +include config/version + +SHELL = /bin/sh +SYSTEM = $(shell config/config.guess | cut -d - -f 3 | sed -e 's/[0-9\.]//g;') +SYSTEM.SUPPORTED = $(shell test -f config/Makefile.$(SYSTEM) && echo 1) + +ifeq ($(SYSTEM.SUPPORTED), 1) +include config/Makefile.$(SYSTEM) +else +$(error "Platform '$(SYSTEM)' not supported") +endif + +GLEW_DEST ?= /usr +BINDIR ?= $(GLEW_DEST)/bin +LIBDIR ?= $(GLEW_DEST)/lib +INCDIR ?= $(GLEW_DEST)/include/GL +SHARED_OBJ_EXT ?= o +TARDIR = ../glew-$(GLEW_VERSION) +TARBALL = ../glew-$(GLEW_VERSION).tar.gz + +DIST_DIR = glew-$(GLEW_VERSION) +DIST_WIN32 = glew-$(GLEW_VERSION)-win32.zip +DIST_SRC_ZIP = glew-$(GLEW_VERSION).zip +DIST_SRC_TGZ = glew-$(GLEW_VERSION).tgz + +AR = ar +INSTALL = install +STRIP = strip +RM = rm -f +LN = ln -sf +ifeq ($(MAKECMDGOALS), debug) +OPT = -g +else +OPT = $(POPT) +endif +INCLUDE = -Iinclude +CFLAGS = $(OPT) $(WARN) $(INCLUDE) $(CFLAGS.EXTRA) + +LIB.SRCS = src/glew.c +LIB.OBJS = $(LIB.SRCS:.c=.o) +LIB.SOBJS = $(LIB.SRCS:.c=.$(SHARED_OBJ_EXT)) +LIB.LDFLAGS = $(LDFLAGS.EXTRA) $(LDFLAGS.GL) +LIB.LIBS = $(GL_LDFLAGS) + +GLEWINFO.BIN = glewinfo$(BIN.SUFFIX) +GLEWINFO.BIN.SRCS = src/glewinfo.c +GLEWINFO.BIN.OBJS = $(GLEWINFO.BIN.SRCS:.c=.o) +VISUALINFO.BIN = visualinfo$(BIN.SUFFIX) +VISUALINFO.BIN.SRCS = src/visualinfo.c +VISUALINFO.BIN.OBJS = $(VISUALINFO.BIN.SRCS:.c=.o) +BIN.LIBS = -Llib $(LDFLAGS.DYNAMIC) -l$(NAME) $(LDFLAGS.EXTRA) $(LDFLAGS.GL) + +all debug: lib/$(LIB.SHARED) lib/$(LIB.STATIC) bin/$(GLEWINFO.BIN) bin/$(VISUALINFO.BIN) glew.pc + +lib: + mkdir lib + +lib/$(LIB.STATIC): $(LIB.OBJS) + $(AR) cr $@ $^ + +lib/$(LIB.SHARED): $(LIB.SOBJS) + $(LD) $(LDFLAGS.SO) -o $@ $^ $(LIB.LDFLAGS) $(LIB.LIBS) +ifeq ($(patsubst mingw%,mingw,$(SYSTEM)), mingw) +else + $(LN) $(LIB.SHARED) lib/$(LIB.SONAME) + $(LN) $(LIB.SHARED) lib/$(LIB.DEVLNK) +endif + +bin/$(GLEWINFO.BIN): $(GLEWINFO.BIN.OBJS) lib/$(LIB.SHARED) + $(CC) $(CFLAGS) -o $@ $(GLEWINFO.BIN.OBJS) $(BIN.LIBS) + +bin/$(VISUALINFO.BIN): $(VISUALINFO.BIN.OBJS) lib/$(LIB.SHARED) + $(CC) $(CFLAGS) -o $@ $(VISUALINFO.BIN.OBJS) $(BIN.LIBS) + +%.o: %.c + $(CC) -c $(CFLAGS) -o $@ $< + +src/glew.o: src/glew.c include/GL/glew.h include/GL/wglew.h include/GL/glxew.h + $(CC) $(CFLAGS) $(CFLAGS.SO) -o $@ -c $< + +src/glew.pic_o: src/glew.c include/GL/glew.h include/GL/wglew.h include/GL/glxew.h + $(CC) $(CFLAGS) $(PICFLAG) $(CFLAGS.SO) -o $@ -c $< + +glew.pc: glew.pc.in + sed \ + -e "s|@prefix@|$(GLEW_DEST)|g" \ + -e "s|@libdir@|$(LIBDIR)|g" \ + -e "s|@exec_prefix@|$(BINDIR)|g" \ + -e "s|@includedir@|$(INCDIR)|g" \ + -e "s|@version@|$(GLEW_VERSION)|g" \ + < $< > $@ + +install: all +# directories + $(INSTALL) -d -m 0755 $(BINDIR) + $(INSTALL) -d -m 0755 $(INCDIR) + $(INSTALL) -d -m 0755 $(LIBDIR) +# runtime +ifeq ($(patsubst mingw%,mingw,$(SYSTEM)), mingw) + $(STRIP) -x lib/$(LIB.SHARED) + $(INSTALL) -m 0644 lib/$(LIB.SHARED) $(BINDIR)/ +else + $(STRIP) -x lib/$(LIB.SHARED) + $(INSTALL) -m 0644 lib/$(LIB.SHARED) $(LIBDIR)/ + $(LN) $(LIB.SHARED) $(LIBDIR)/$(LIB.SONAME) +endif +# development files + $(INSTALL) -m 0644 include/GL/wglew.h $(INCDIR)/ + $(INSTALL) -m 0644 include/GL/glew.h $(INCDIR)/ + $(INSTALL) -m 0644 include/GL/glxew.h $(INCDIR)/ + $(INSTALL) -m 0644 glew.pc $(LIBDIR)/pkgconfig/ +ifeq ($(patsubst mingw%,mingw,$(SYSTEM)), mingw) + $(INSTALL) -m 0644 lib/$(LIB.DEVLNK) $(LIBDIR)/ +else + $(STRIP) -x lib/$(LIB.STATIC) + $(INSTALL) -m 0644 lib/$(LIB.STATIC) $(LIBDIR)/ + $(LN) $(LIB.SHARED) $(LIBDIR)/$(LIB.DEVLNK) +endif +# utilities + $(INSTALL) -s -m 0755 bin/$(GLEWINFO.BIN) bin/$(VISUALINFO.BIN) $(BINDIR)/ + +uninstall: + $(RM) $(INCDIR)/wglew.h + $(RM) $(INCDIR)/glew.h + $(RM) $(INCDIR)/glxew.h + $(RM) $(LIBDIR)/$(LIB.DEVLNK) +ifeq ($(patsubst mingw%,mingw,$(SYSTEM)), mingw) + $(RM) $(BINDIR)/$(LIB.SHARED) +else + $(RM) $(LIBDIR)/$(LIB.SONAME) + $(RM) $(LIBDIR)/$(LIB.SHARED) + $(RM) $(LIBDIR)/$(LIB.STATIC) +endif + $(RM) $(BINDIR)/$(GLEWINFO.BIN) $(BINDIR)/$(VISUALINFO.BIN) + +clean: + $(RM) $(LIB.OBJS) + $(RM) $(LIB.SOBJS) + $(RM) lib/$(LIB.STATIC) lib/$(LIB.SHARED) lib/$(LIB.DEVLNK) lib/$(LIB.SONAME) $(LIB.STATIC) + $(RM) $(GLEWINFO.BIN.OBJS) bin/$(GLEWINFO.BIN) $(VISUALINFO.BIN.OBJS) bin/$(VISUALINFO.BIN) + $(RM) glew.pc +# Compiler droppings + $(RM) so_locations + +distclean: clean + find . -name \*~ | xargs $(RM) + find . -name .\*.sw\? | xargs $(RM) + +tardist: + $(RM) -r $(TARDIR) + mkdir $(TARDIR) + cp -a . $(TARDIR) + find $(TARDIR) -name CVS -o -name .cvsignore | xargs $(RM) -r + find $(TARDIR) -name .svn | xargs $(RM) -r + $(MAKE) -C $(TARDIR) distclean + $(MAKE) -C $(TARDIR) + $(MAKE) -C $(TARDIR) distclean + $(RM) -r $(TARDIR)/auto/registry + env GZIP=-9 tar -C `dirname $(TARDIR)` -cvzf $(TARBALL) `basename $(TARDIR)` + +dist-win32: + $(RM) -r $(TARDIR) + mkdir -p $(TARDIR) + mkdir -p $(TARDIR)/bin + mkdir -p $(TARDIR)/lib + cp -a include $(TARDIR) + cp -a doc $(TARDIR) + cp -a *.txt $(TARDIR) + cp -a lib/glew32.lib $(TARDIR)/lib + cp -a lib/glew32s.lib $(TARDIR)/lib + cp -a bin/glew32.dll $(TARDIR)/bin + cp -a bin/glewinfo.exe $(TARDIR)/bin + cp -a bin/visualinfo.exe $(TARDIR)/bin + find $(TARDIR) -name CVS -o -name .cvsignore | xargs $(RM) -r + find $(TARDIR) -name .svn | xargs $(RM) -r + unix2dos $(TARDIR)/include/GL/*.h + unix2dos $(TARDIR)/doc/*.txt + unix2dos $(TARDIR)/doc/*.html + unix2dos $(TARDIR)/*.txt + rm -f ../$(DIST_WIN32) + cd .. && zip -rv9 $(DIST_WIN32) $(DIST_DIR) + +dist-src: + $(RM) -r $(TARDIR) + mkdir -p $(TARDIR) + mkdir -p $(TARDIR)/bin + mkdir -p $(TARDIR)/lib + cp -a auto $(TARDIR) + $(RM) -Rf $(TARDIR)/auto/registry + cp -a build $(TARDIR) + cp -a config $(TARDIR) + cp -a src $(TARDIR) + cp -a doc $(TARDIR) + cp -a include $(TARDIR) + cp -a *.txt $(TARDIR) + cp -a Makefile $(TARDIR) + cp -a glew.pc.in $(TARDIR) + find $(TARDIR) -name '*.o' | xargs $(RM) -r + find $(TARDIR) -name '*.pic_o' | xargs $(RM) -r + find $(TARDIR) -name '*~' | xargs $(RM) -r + find $(TARDIR) -name CVS -o -name .cvsignore | xargs $(RM) -r + find $(TARDIR) -name .svn | xargs $(RM) -r + unix2dos $(TARDIR)/config/* + unix2dos $(TARDIR)/auto/core/* + unix2dos $(TARDIR)/auto/extensions/* + find $(TARDIR) -name '*.h' | xargs unix2dos + find $(TARDIR) -name '*.c' | xargs unix2dos + find $(TARDIR) -name '*.txt' | xargs unix2dos + find $(TARDIR) -name '*.html' | xargs unix2dos + find $(TARDIR) -name '*.css' | xargs unix2dos + find $(TARDIR) -name '*.sh' | xargs unix2dos + find $(TARDIR) -name '*.pl' | xargs unix2dos + find $(TARDIR) -name 'Makefile' | xargs unix2dos + find $(TARDIR) -name '*.in' | xargs unix2dos + find $(TARDIR) -name '*.pm' | xargs unix2dos + find $(TARDIR) -name '*.rc' | xargs unix2dos + rm -f ../$(DIST_SRC_ZIP) + cd .. && zip -rv9 $(DIST_SRC_ZIP) $(DIST_DIR) + dos2unix $(TARDIR)/config/* + dos2unix $(TARDIR)/auto/core/* + dos2unix $(TARDIR)/auto/extensions/* + find $(TARDIR) -name '*.h' | xargs dos2unix + find $(TARDIR) -name '*.c' | xargs dos2unix + find $(TARDIR) -name '*.txt' | xargs dos2unix + find $(TARDIR) -name '*.html' | xargs dos2unix + find $(TARDIR) -name '*.css' | xargs dos2unix + find $(TARDIR) -name '*.sh' | xargs dos2unix + find $(TARDIR) -name '*.pl' | xargs dos2unix + find $(TARDIR) -name 'Makefile' | xargs dos2unix + find $(TARDIR) -name '*.in' | xargs dos2unix + find $(TARDIR) -name '*.pm' | xargs dos2unix + find $(TARDIR) -name '*.rc' | xargs dos2unix + cd .. && env GZIP=-9 tar cvzf $(DIST_SRC_TGZ) $(DIST_DIR) + +extensions: + $(MAKE) -C auto + +.PHONY: clean distclean tardist dist-win32 dist-src diff --git a/Externals/GLew/README.txt b/Externals/GLew/README.txt new file mode 100644 index 0000000000..1b19c53523 --- /dev/null +++ b/Externals/GLew/README.txt @@ -0,0 +1,18 @@ +See doc/index.html for more information. + +If you downloaded the tarball from the GLEW website, you just need to: + + Unix: + + make + + Windows: + + use the project file in build/vc6/ + +If you wish to build GLEW from scratch (update the extension data from +the net or add your own extension information), you need a Unix +environment (including wget, perl, and GNU make). The extension data +is regenerated from the top level source directory with: + + make extensions diff --git a/Externals/GLew/TODO.txt b/Externals/GLew/TODO.txt new file mode 100644 index 0000000000..d2701b652e --- /dev/null +++ b/Externals/GLew/TODO.txt @@ -0,0 +1,12 @@ +Major: + - add support for windows mini-client drivers + - add windows installer (msi) + - separate build of static and shared object files (for mingw and + cygwin) + - start designing GLEW 2.0 + +Minor: + - make auto scripts work with text mode cygwin mounts + - add support for all SUN, MTX, and OML extensions + - make auto/Makefile more robust against auto/core/*~ mistakes + - web poll on separating glew, glxew and wglew diff --git a/Externals/GLew/auto/Makefile b/Externals/GLew/auto/Makefile new file mode 100644 index 0000000000..1016df42ed --- /dev/null +++ b/Externals/GLew/auto/Makefile @@ -0,0 +1,371 @@ +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +include ../config/version + +#GLEW_SPLIT_SOURCE = yes + +SHELL = bash +REGISTRY = registry +REGISTRY_URL = http://www.opengl.org/registry/ +#http://oss.sgi.com/projects/ogl-sample/registry/ +BIN = bin +SRC = src +CORE = core +EXT = extensions +BLACKLIST = blacklist + +GL_CORE_SPEC := $(CORE)/GL_VERSION* +GLX_CORE_SPEC := $(CORE)/GLX_VERSION* +ifeq (custom,$(MAKECMDGOALS)) +#GL_CORE_SPEC := $(shell grep GL_VERSION custom.txt | sed -e 's/\(.*\)/$(CORE)\/\1/g;') +GL_EXT_SPEC := $(shell grep "^[ \t]*GL_" custom.txt | grep -v GL_VERSION | sed -e 's/\(.*\)/$(EXT)\/\1/g;') +WGL_EXT_SPEC := $(shell grep "^[ \t]*WGL_" custom.txt | sed -e 's/\(.*\)/$(EXT)\/\1/g;') +#GLX_CORE_SPEC := $(shell grep GLX_VERSION custom.txt | sed -e 's/\(.*\)/$(CORE)\/\1/g;') +GLX_EXT_SPEC := $(shell grep "^[ \t]*GLX_" custom.txt | grep -v GLX_VERSION | grep -v GLX_OML_sync_control | sed -e 's/\(.*\)/$(EXT)\/\1/g;') +else +GL_EXT_SPEC := $(EXT)/GL_* +WGL_EXT_SPEC := $(EXT)/WGL_* +GLX_EXT_SPEC := $(EXT)/GLX_* +endif + +PARSE_SPEC = parse_spec.pl +SYSTEM = $(strip $(shell uname -s)) + +TOP = .. +I.DEST = $(TOP)/include/GL +S.DEST = $(TOP)/src +D.DEST = $(TOP)/doc +B.DEST = $(TOP)/build/vc6 + +I.TARGETS = \ + $(I.DEST)/glew.h \ + $(I.DEST)/wglew.h \ + $(I.DEST)/glxew.h + +ifeq (yes,$(GLEW_SPLIT_SOURCE)) +S.TARGETS = \ + $(S.DEST)/glew_def.c \ + $(S.DEST)/glew_init.c \ + $(S.DEST)/glew_str.c \ + $(S.DEST)/glewinfo.c +else +S.TARGETS = \ + $(S.DEST)/glew.c \ + $(S.DEST)/glewinfo.c +endif + +D.TARGETS = \ + $(D.DEST)/index.html \ + $(D.DEST)/install.html \ + $(D.DEST)/basic.html \ + $(D.DEST)/advanced.html \ + $(D.DEST)/credits.html \ + $(D.DEST)/log.html \ + $(D.DEST)/glew.html \ + $(D.DEST)/wglew.html \ + $(D.DEST)/glxew.html + +B.TARGETS = \ + $(B.DEST)/glew.rc \ + $(B.DEST)/glewinfo.rc \ + $(B.DEST)/visualinfo.rc + +all custom: $(I.TARGETS) $(S.TARGETS) $(D.TARGETS) $(B.TARGETS) + +registry: $(REGISTRY)/.dummy +ext: $(EXT)/.dummy + +$(REGISTRY)/.dummy: $(BIN)/update_registry.sh + @echo "--------------------------------------------------------------------" + @echo "Downloading registry" + @echo "--------------------------------------------------------------------" + $(BIN)/update_registry.sh $(REGISTRY) $(REGISTRY_URL) + touch $@ + +$(EXT)/.dummy: $(REGISTRY)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating descriptors" + @echo "--------------------------------------------------------------------" + rm -rf $(EXT) + $(BIN)/update_ext.sh $(EXT) $(REGISTRY) $(BLACKLIST) +ifeq ($(patsubst Darwin%,Darwin,$(SYSTEM)), Darwin) + find $(CORE) -maxdepth 1 -type f | grep -v VERSION | grep -v "~" | \ + xargs -J % cp % $(EXT) +else + find $(CORE) -maxdepth 1 -type f | grep -v VERSION | grep -v "~" | \ + xargs cp --target-directory=$(EXT) +endif + touch $@ + +$(I.DEST)/glew.h: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating glew.h" + @echo "--------------------------------------------------------------------" + test -d $(I.DEST) || mkdir -p $(I.DEST) + cp -f $(SRC)/glew_license.h $@ + cat $(SRC)/mesa_license.h >> $@ + cat $(SRC)/khronos_license.h >> $@ + cat $(SRC)/glew_head.h >> $@ + $(BIN)/make_header.pl GLAPIENTRY GL $(GL_CORE_SPEC) >> $@ + $(BIN)/make_header.pl GLAPIENTRY GL $(GL_EXT_SPEC) >> $@ + echo -e "/* ------------------------------------------------------------------------- */\n\n#if defined(GLEW_MX) && defined(_WIN32)\n#define GLEW_FUN_EXPORT\n#else\n#define GLEW_FUN_EXPORT GLEWAPI\n#endif /* GLEW_MX */\n" >> $@ + echo -e "#if defined(GLEW_MX)\n#define GLEW_VAR_EXPORT\n#else\n#define GLEW_VAR_EXPORT GLEWAPI\n#endif /* GLEW_MX */\n" >> $@ + echo -e "#if defined(GLEW_MX) && defined(_WIN32)\nstruct GLEWContextStruct\n{\n#endif /* GLEW_MX */" >> $@ + $(BIN)/make_struct_fun.pl GLEW_FUN_EXPORT $(GL_CORE_SPEC) $(GL_EXT_SPEC) >> $@ + echo -e "\n#if defined(GLEW_MX) && !defined(_WIN32)\nstruct GLEWContextStruct\n{\n#endif /* GLEW_MX */\n" >> $@ + $(BIN)/make_struct_var.pl GLEW_VAR_EXPORT $(GL_CORE_SPEC) $(GL_EXT_SPEC) >> $@ + echo -e "\n#ifdef GLEW_MX\n}; /* GLEWContextStruct */\n#endif /* GLEW_MX */\n" >> $@ + perl -e 's/GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_2;/GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_1;\nGLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_2;/' -pi $@ + rm -f $@.bak + cat $(SRC)/glew_tail.h >> $@ + +$(I.DEST)/wglew.h: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating wglew.h" + @echo "--------------------------------------------------------------------" + cp -f $(SRC)/glew_license.h $@ + cat $(SRC)/khronos_license.h >> $@ + cat $(SRC)/wglew_head.h >> $@ + $(BIN)/make_header.pl WINAPI WGL $(WGL_EXT_SPEC) >> $@ + echo -e "/* ------------------------------------------------------------------------- */\n\n#ifdef GLEW_MX\n#define WGLEW_EXPORT\n#else\n#define WGLEW_EXPORT GLEWAPI\n#endif /* GLEW_MX */\n\n#ifdef GLEW_MX\nstruct WGLEWContextStruct\n{\n#endif /* GLEW_MX */" >> $@ + $(BIN)/make_struct_fun.pl WGLEW_EXPORT $(WGL_EXT_SPEC) >> $@ + $(BIN)/make_struct_var.pl WGLEW_EXPORT $(WGL_EXT_SPEC) >> $@ + echo -e "\n#ifdef GLEW_MX\n}; /* WGLEWContextStruct */\n#endif /* GLEW_MX */\n" >> $@ + cat $(SRC)/wglew_tail.h >> $@ + +$(I.DEST)/glxew.h: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating glxew.h" + @echo "--------------------------------------------------------------------" + cp -f $(SRC)/glew_license.h $@ + cat $(SRC)/mesa_license.h >> $@ + cat $(SRC)/khronos_license.h >> $@ + cat $(SRC)/glxew_head.h >> $@ + $(BIN)/make_header.pl '' GLX $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_header.pl '' GLX $(GLX_EXT_SPEC) >> $@ + echo -e "/* ------------------------------------------------------------------------- */\n\n#ifdef GLEW_MX\n#define GLXEW_EXPORT\n#else\n#define GLXEW_EXPORT extern\n#endif /* GLEW_MX */" >> $@ + $(BIN)/make_struct_fun.pl extern $(GLX_CORE_SPEC) $(GLX_EXT_SPEC) >> $@ + echo -e "\n#if defined(GLEW_MX)\nstruct GLXEWContextStruct\n{\n#endif /* GLEW_MX */\n" >> $@ + $(BIN)/make_struct_var.pl GLXEW_EXPORT $(GLX_CORE_SPEC) $(GLX_EXT_SPEC) >> $@ + echo -e "\n#ifdef GLEW_MX\n}; /* GLXEWContextStruct */\n#endif /* GLEW_MX */\n" >> $@ + perl -e 's/GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_2;/GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_0;\nGLXEW_EXPORT GLboolean __GLXEW_VERSION_1_1;\nGLXEW_EXPORT GLboolean __GLXEW_VERSION_1_2;/' -pi $@ + cat $(SRC)/glxew_tail.h >> $@ + $(BIN)/fix_OML_sync_control.sh $@ + +$(S.DEST)/glew.c: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating glew.c" + @echo "--------------------------------------------------------------------" + cp -f $(SRC)/glew_license.h $@ + cat $(SRC)/glew_head.c >> $@ + echo -e "\n#if !defined(_WIN32) || !defined(GLEW_MX)" >> $@ + $(BIN)/make_def_fun.pl GL $(GL_CORE_SPEC) >> $@ + $(BIN)/make_def_fun.pl GL $(GL_EXT_SPEC) >> $@ + echo -e "\n#endif /* !WIN32 || !GLEW_MX */" >> $@ + echo -e "\n#if !defined(GLEW_MX)" >> $@; + echo -e "\nGLboolean __GLEW_VERSION_1_1 = GL_FALSE;" >> $@ + $(BIN)/make_def_var.pl GL $(GL_CORE_SPEC) >> $@ + $(BIN)/make_def_var.pl GL $(GL_EXT_SPEC) >> $@ + echo -e "\n#endif /* !GLEW_MX */\n" >> $@; + $(BIN)/make_init.pl GL $(GL_CORE_SPEC) >> $@ + $(BIN)/make_init.pl GL $(GL_EXT_SPEC) >> $@ + cat $(SRC)/glew_init_gl.c >> $@ + $(BIN)/make_list.pl $(GL_CORE_SPEC) | grep -v '\"GL_VERSION' >> $@ + $(BIN)/make_list.pl $(GL_EXT_SPEC) >> $@ + echo -e "\n return GLEW_OK;\n}\n" >> $@ + echo -e "\n#if defined(_WIN32)" >> $@ + echo -e "\n#if !defined(GLEW_MX)" >> $@ + $(BIN)/make_def_fun.pl WGL $(WGL_EXT_SPEC) >> $@ + $(BIN)/make_def_var.pl WGL $(WGL_EXT_SPEC) >> $@ + echo -e "\n#endif /* !GLEW_MX */\n" >> $@; + $(BIN)/make_init.pl WGL $(WGL_EXT_SPEC) >> $@ + cat $(SRC)/glew_init_wgl.c >> $@ + $(BIN)/make_list.pl $(WGL_EXT_SPEC) >> $@ + echo -e "\n return GLEW_OK;\n}" >> $@; + echo -e "\n#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX)" >> $@ + $(BIN)/make_def_fun.pl GLX $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_def_fun.pl GLX $(GLX_EXT_SPEC) >> $@ + echo -e "\n#if !defined(GLEW_MX)" >> $@; + echo -e "\nGLboolean __GLXEW_VERSION_1_0 = GL_FALSE;" >> $@ + echo -e "GLboolean __GLXEW_VERSION_1_1 = GL_FALSE;" >> $@ + $(BIN)/make_def_var.pl GLX $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_def_var.pl GLX $(GLX_EXT_SPEC) >> $@ + echo -e "\n#endif /* !GLEW_MX */\n" >> $@; + $(BIN)/make_init.pl GLX $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_init.pl GLX $(GLX_EXT_SPEC) >> $@ + cat $(SRC)/glew_init_glx.c >> $@ + $(BIN)/make_list.pl $(CORE)/GLX_VERSION_1_3 | grep -v '\"GLX_VERSION' >> $@ + $(BIN)/make_list.pl $(GLX_EXT_SPEC) >> $@ + echo -e "\n return GLEW_OK;\n}" >> $@ + echo -e "\n#endif /* !__APPLE__ || GLEW_APPLE_GLX */\n" >> $@; + cat $(SRC)/glew_init_tail.c >> $@ + cat $(SRC)/glew_str_head.c >> $@ + $(BIN)/make_str.pl $(GL_CORE_SPEC) $(GL_EXT_SPEC) >> $@ + cat $(SRC)/glew_str_wgl.c >> $@ + $(BIN)/make_str.pl $(WGL_EXT_SPEC) >> $@ + cat $(SRC)/glew_str_glx.c >> $@ + $(BIN)/make_str.pl $(GLX_CORE_SPEC) $(GLX_EXT_SPEC) >> $@ + cat $(SRC)/glew_str_tail.c >> $@ + perl -e "s/GLEW_VERSION_STRING/$(GLEW_VERSION)/g" -pi $@ + perl -e "s/GLEW_VERSION_MAJOR_STRING/$(GLEW_MAJOR)/g" -pi $@ + perl -e "s/GLEW_VERSION_MINOR_STRING/$(GLEW_MINOR)/g" -pi $@ + perl -e "s/GLEW_VERSION_MICRO_STRING/$(GLEW_MICRO)/g" -pi $@ + perl -e "s/GLEW_ARB_vertex_shader = !_glewInit_GL_ARB_vertex_shader\(GLEW_CONTEXT_ARG_VAR_INIT\);/{ GLEW_ARB_vertex_shader = !_glewInit_GL_ARB_vertex_shader(GLEW_CONTEXT_ARG_VAR_INIT); _glewInit_GL_ARB_vertex_program(GLEW_CONTEXT_ARG_VAR_INIT); }/g" -pi $@ + perl -e "s/\(\(glColorSubTable = /((glBlendEquation = (PFNGLBLENDEQUATIONPROC)glewGetProcAddress((const GLubyte*)\"glBlendEquation\")) == NULL) || r;\n r = ((glColorSubTable = /g" -pi $@ + $(BIN)/fix_OML_sync_control.sh $@ + rm -f $@.bak + +$(S.DEST)/glew_def.c: $(EXT)/.dummy + cp -f $(SRC)/glew_license.h $@ + echo -e "#include \"glew_utils.h\"\n\n#if !defined(_WIN32) || !defined(GLEW_MX)" >> $@ + $(BIN)/make_def_fun.pl GL $(GL_CORE_SPEC) >> $@ + $(BIN)/make_def_fun.pl GL $(GL_EXT_SPEC) >> $@ + echo -e "\n#endif /* !WIN32 || !GLEW_MX */" >> $@ + echo -e "\n#if !defined(GLEW_MX)\n\nGLboolean __GLEW_VERSION_1_1 = GL_FALSE;" >> $@ + $(BIN)/make_def_var.pl GL $(GL_CORE_SPEC) >> $@ + $(BIN)/make_def_var.pl GL $(GL_EXT_SPEC) >> $@ + echo -e "\n#if defined(_WIN32)" >> $@ + $(BIN)/make_def_fun.pl WGL $(WGL_EXT_SPEC) >> $@ + $(BIN)/make_def_var.pl WGL $(WGL_EXT_SPEC) >> $@ + echo -e "\n#endif /* _WIN32 */" >> $@ + echo -e "\n#endif /* !GLEW_MX */" >> $@; + echo -e "\n#if !defined(_WIN32) && (!defined(__APPLE__) || defined(GLEW_APPLE_GLX))" >> $@ + $(BIN)/make_def_fun.pl GLX $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_def_fun.pl GLX $(GLX_EXT_SPEC) >> $@ + echo -e "\n#if !defined(GLEW_MX)" >> $@; + echo -e "\nGLboolean __GLXEW_VERSION_1_0 = GL_FALSE;" >> $@ + echo -e "GLboolean __GLXEW_VERSION_1_1 = GL_FALSE;" >> $@ + $(BIN)/make_def_var.pl GLX $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_def_var.pl GLX $(GLX_EXT_SPEC) >> $@ + echo -e "\n#endif /* !GLEW_MX */" >> $@; + echo -e "\n#endif /* !__APPLE__ || GLEW_APPLE_GLX */" >> $@; + rm -f $@.bak + +$(S.DEST)/glew_init.c: $(EXT)/.dummy + cp -f $(SRC)/glew_license.h $@ + echo -e "#include \"glew_utils.h\"\n" >> $@ + $(BIN)/make_init.pl GL $(GL_CORE_SPEC) >> $@ + $(BIN)/make_init.pl GL $(GL_EXT_SPEC) >> $@ + cat $(SRC)/glew_init_gl.c >> $@ + $(BIN)/make_list.pl $(GL_CORE_SPEC) | grep -v '\"GL_VERSION' >> $@ + $(BIN)/make_list.pl $(GL_EXT_SPEC) >> $@ + echo -e "\n return GLEW_OK;\n}\n\n#if defined(_WIN32)\n" >> $@; + $(BIN)/make_init.pl WGL $(WGL_EXT_SPEC) >> $@ + cat $(SRC)/glew_init_wgl.c >> $@ + $(BIN)/make_list.pl $(WGL_EXT_SPEC) >> $@ + echo -e "\n return GLEW_OK;\n}\n\n" >> $@; + echo -e "\n#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX)\n" >> $@ + $(BIN)/make_init.pl GLX $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_init.pl GLX $(GLX_EXT_SPEC) >> $@ + cat $(SRC)/glew_init_glx.c >> $@ + $(BIN)/make_list.pl $(CORE)/GLX_VERSION_1_3 | grep -v '\"GLX_VERSION' >> $@ + $(BIN)/make_list.pl $(GLX_EXT_SPEC) >> $@ + echo -e "\n return GLEW_OK;\n}\n\n#endif /* !__APPLE__ || GLEW_APPLE_GLX */\n" >> $@; + cat $(SRC)/glew_init_tail.c >> $@ + perl -e "s/GLEW_VERSION_STRING/$(GLEW_VERSION)/g" -pi $@ + perl -e "s/GLEW_VERSION_MAJOR_STRING/$(GLEW_MAJOR)/g" -pi $@ + perl -e "s/GLEW_VERSION_MINOR_STRING/$(GLEW_MINOR)/g" -pi $@ + perl -e "s/GLEW_VERSION_MICRO_STRING/$(GLEW_MICRO)/g" -pi $@ + perl -e "s/GLEW_ARB_vertex_shader = !_glewInit_GL_ARB_vertex_shader\(GLEW_CONTEXT_ARG_VAR_INIT\);/{ GLEW_ARB_vertex_shader = !_glewInit_GL_ARB_vertex_shader(GLEW_CONTEXT_ARG_VAR_INIT); _glewInit_GL_ARB_vertex_program(GLEW_CONTEXT_ARG_VAR_INIT); }/g" -pi $@ + perl -e "s/\(\(glBlendColor = /((glBlendEquation = (PFNGLBLENDEQUATIONPROC)glewGetProcAddress((const GLubyte*)\"glBlendEquation\")) == NULL) || r;\n r = ((glBlendColor = /g" -pi $@ + $(BIN)/fix_OML_sync_control.sh $@ + rm -f $@.bak + +$(S.DEST)/glew_str.c: $(EXT)/.dummy + cp -f $(SRC)/glew_license.h $@ + echo -e "\n#include \"glew_utils.h\"\n" >> $@ + cat $(SRC)/glew_str_head.c >> $@ + $(BIN)/make_str.pl $(GL_CORE_SPEC) $(GL_EXT_SPEC) >> $@ + cat $(SRC)/glew_str_wgl.c >> $@ + $(BIN)/make_str.pl $(WGL_EXT_SPEC) >> $@ + cat $(SRC)/glew_str_glx.c >> $@ + $(BIN)/make_str.pl $(GLX_CORE_SPEC) $(GLX_EXT_SPEC) >> $@ + cat $(SRC)/glew_str_tail.c >> $@ +# $(BIN)/fix_OML_sync_control.sh $@ +# perl -e "s/GLEW_VERSION_STRING/$(GLEW_VERSION)/g" -pi $@ +# perl -e "s/GLEW_ARB_vertex_shader = !_glewInit_GL_ARB_vertex_shader\(GLEW_CONTEXT_ARG_VAR_INIT\);/{ GLEW_ARB_vertex_shader = !_glewInit_GL_ARB_vertex_shader(GLEW_CONTEXT_ARG_VAR_INIT); _glewInit_GL_ARB_vertex_program(GLEW_CONTEXT_ARG_VAR_INIT); }/g" -pi $@ + rm -f $@.bak + +$(S.DEST)/glewinfo.c: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating glewinfo.c" + @echo "--------------------------------------------------------------------" + cp -f $(SRC)/glew_license.h $@ + cat $(SRC)/glewinfo_head.c >> $@ + $(BIN)/make_info.pl $(GL_CORE_SPEC) >> $@ + $(BIN)/make_info.pl $(GL_EXT_SPEC) >> $@ + echo -e "#ifdef _WIN32\n" >> $@ + $(BIN)/make_info.pl $(WGL_EXT_SPEC) >> $@ + echo -e "#else /* _UNIX */\n" >> $@ + $(BIN)/make_info.pl $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_info.pl $(GLX_EXT_SPEC) >> $@ + echo -e "#endif /* _WIN32 */\n" >> $@ + + cat $(SRC)/glewinfo_gl.c >> $@ + $(BIN)/make_info_list.pl $(GL_CORE_SPEC) >> $@ + $(BIN)/make_info_list.pl $(GL_EXT_SPEC) >> $@ + cat $(SRC)/glewinfo_wgl.c >> $@ + $(BIN)/make_info_list.pl $(WGL_EXT_SPEC) >> $@ + cat $(SRC)/glewinfo_glx.c >> $@ + $(BIN)/make_info_list.pl $(GLX_CORE_SPEC) >> $@ + $(BIN)/make_info_list.pl $(GLX_EXT_SPEC) >> $@ + cat $(SRC)/glewinfo_tail.c >> $@ + $(BIN)/fix_OML_sync_control.sh $@ + perl -e 's/"glColorSubTable"/"glBlendEquation", glBlendEquation == NULL);\n glewInfoFunc("glColorSubTable"/g' -pi $@ + rm -f $@.bak + +# Update documentation + +$(D.DEST)/%.html: doc/%.html + @echo "--------------------------------------------------------------------" + @echo "Creating $(@F)" + @echo "--------------------------------------------------------------------" + cat $(SRC)/header.html $< $(SRC)/footer.html | \ + sed 's#\(.*\)#\1#' > $@ + +$(D.DEST)/glew.html: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating glew.html" + @echo "--------------------------------------------------------------------" + cp -f $(SRC)/header.html $@ + echo -e "

Supported OpenGL Extensions

\n" >> $@ + $(BIN)/make_html.pl $(GL_EXT_SPEC) >> $@ + cat $(SRC)/footer.html >> $@ + sed -i 's#\(.*\)#\1#' $@ + +$(D.DEST)/wglew.html: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating wglew.html" + @echo "--------------------------------------------------------------------" + cp -f $(SRC)/header.html $@ + echo -e "

Supported WGL Extensions

\n" >> $@ + $(BIN)/make_html.pl $(WGL_EXT_SPEC) >> $@ + cat $(SRC)/footer.html >> $@ + sed -i 's#\(.*\)#\1#' $@ + +$(D.DEST)/glxew.html: $(EXT)/.dummy + @echo "--------------------------------------------------------------------" + @echo "Creating glxew.html" + @echo "--------------------------------------------------------------------" + cp -f $(SRC)/header.html $@ + echo -e "

Supported GLX Extensions

\n" >> $@ + $(BIN)/make_html.pl $(GLX_EXT_SPEC) >> $@ + cat $(SRC)/footer.html >> $@ + sed -i 's#\(.*\)#\1#' $@ + +$(B.DEST)/%.rc: src/%.rc $(EXT)/.dummy + perl -e "s/GLEW_MAJOR/$(GLEW_MAJOR)/g;s/GLEW_MINOR/$(GLEW_MINOR)/g;s/GLEW_MICRO/$(GLEW_MICRO)/g;" -p $< > $@ + +clean: + rm -rf $(I.TARGETS) $(S.TARGETS) $(D.TARGETS) $(B.TARGETS) + +clobber: clean + rm -rf $(EXT) + +destroy: clobber + rm -rf $(REGISTRY) diff --git a/Externals/GLew/auto/bin/fix_OML_sync_control.sh b/Externals/GLew/auto/bin/fix_OML_sync_control.sh new file mode 100755 index 0000000000..2579ab48fc --- /dev/null +++ b/Externals/GLew/auto/bin/fix_OML_sync_control.sh @@ -0,0 +1,18 @@ +#!/bin/sh +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +perl -e 's/#ifndef GLX_OML_sync_control/#if !defined(GLX_OML_sync_control) \&\& defined(__STDC_VERSION__) \&\& (__STDC_VERSION__ >= 199901L)\n#include /;' -pi $1 +perl -e 's/#ifdef GLX_OML_sync_control/#if defined(GLX_OML_sync_control) \&\& defined(__STDC_VERSION__) \&\& (__STDC_VERSION__ >= 199901L)\n#include /;' -pi $1 +perl -e 's/(extern PFNGLXGETMSCRATEOMLPROC __glewXGetMscRateOML;)/#ifdef GLX_OML_sync_control\n\1/' -pi $1 +perl -e 's/(extern PFNGLXWAITFORSBCOMLPROC __glewXWaitForSbcOML;)/\1\n#endif/' -pi $1 +perl -e 's/(extern GLboolean __GLXEW_OML_sync_control;)/#ifdef GLX_OML_sync_control\n\1\n#endif/' -pi $1 +perl -e 's/(PFNGLXGETMSCRATEOMLPROC __glewXGetMscRateOML = NULL;)/#ifdef GLX_OML_sync_control\n\1/' -pi $1 +perl -e 's/(PFNGLXWAITFORSBCOMLPROC __glewXWaitForSbcOML = NULL;)/\1\n#endif/' -pi $1 +perl -e 's/(GLboolean __GLXEW_OML_sync_control = GL_FALSE;)/#ifdef GLX_OML_sync_control\n\1\n#endif/' -pi $1 +rm -f $1.bak diff --git a/Externals/GLew/auto/bin/make.pl b/Externals/GLew/auto/bin/make.pl new file mode 100755 index 0000000000..c3e72c35b7 --- /dev/null +++ b/Externals/GLew/auto/bin/make.pl @@ -0,0 +1,188 @@ +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +my %regex = ( + extname => qr/^[A-Z][A-Za-z0-9_]+$/, + exturl => qr/^http.+$/, + function => qr/^(.+) ([a-z][a-z0-9_]*) \((.+)\)$/i, + token => qr/^([A-Z][A-Z0-9_x]*)\s+((?:0x)?[0-9A-Fa-f]+|[A-Z][A-Z0-9_]*)$/, + type => qr/^typedef\s+(.+)\s+([\*A-Za-z0-9_]+)$/, + exact => qr/.*;$/, +); + +# prefix function name with glew +sub prefixname($) +{ + my $name = $_[0]; + $name =~ s/^(.*)gl/__$1glew/; + return $name; +} + +# prefix function name with glew +sub prefix_varname($) +{ + my $name = $_[0]; + $name =~ s/^(.*)GL(X*)EW/__$1GL$2EW/; + return $name; +} + +#--------------------------------------------------------------------------------------- + +sub make_exact($) +{ + my $exact = $_[0]; + $exact =~ s/(; |{)/$1\n/g; + return $exact; +} + +sub make_separator($) +{ + my $extname = $_[0]; + my $l = length $extname; + my $s = (71 - $l)/2; + print "/* "; + my $j = 3; + for (my $i = 0; $i < $s; $i++) + { + print "-"; + $j++; + } + print " $_[0] "; + $j += $l + 2; + while ($j < 76) + { + print "-"; + $j++; + } + print " */\n\n"; +} + +#--------------------------------------------------------------------------------------- + +sub parse_ext($) +{ + my $filename = shift; + my %functions = (); + my %tokens = (); + my %types = (); + my @exacts = (); + my $extname = ""; # Full extension name GL_FOO_extension + my $exturl = ""; # Info URL + my $extstring = ""; # Relevant extension string + + open EXT, "<$filename" or return; + + # As of GLEW 1.5.3 the first three lines _must_ be + # the extension name, the URL and the GL extension + # string (which might be different to the name) + # + # For example GL_NV_geometry_program4 is available + # iff GL_NV_gpu_program4 appears in the extension + # string. + # + # For core OpenGL versions, the third line should + # be blank. + # + # If the URL is unknown, the second line should be + # blank. + + $extname = readline(*EXT); + $exturl = readline(*EXT); + $extstring = readline(*EXT); + + chomp($extname); + chomp($exturl); + chomp($extstring); + + while() + { + chomp; + if (s/^\s+//) + { + if (/$regex{exact}/) + { + push @exacts, $_; + } + elsif (/$regex{type}/) + { + my ($value, $name) = ($1, $2); + $types{$name} = $value; + } + elsif (/$regex{token}/) + { + my ($name, $value) = ($1, $2); + $tokens{$name} = $value; + } + elsif (/$regex{function}/) + { + my ($return, $name, $parms) = ($1, $2, $3); + $functions{$name} = { + rtype => $return, + parms => $parms, + }; + } else { + print STDERR "'$_' matched no regex.\n"; + } + } + } + + close EXT; + + return ($extname, $exturl, $extstring, \%types, \%tokens, \%functions, \@exacts); +} + +sub output_tokens($$) +{ + my ($tbl, $fnc) = @_; + if (keys %{$tbl}) + { + local $, = "\n"; + print "\n"; + print map { &{$fnc}($_, $tbl->{$_}) } sort { hex ${$tbl}{$a} <=> hex ${$tbl}{$b} } keys %{$tbl}; + print "\n"; + } else { + print STDERR "no keys in table!\n"; + } +} + +sub output_types($$) +{ + my ($tbl, $fnc) = @_; + if (keys %{$tbl}) + { + local $, = "\n"; + print "\n"; + print map { &{$fnc}($_, $tbl->{$_}) } sort { ${$tbl}{$a} cmp ${$tbl}{$b} } keys %{$tbl}; + print "\n"; + } +} + +sub output_decls($$) +{ + my ($tbl, $fnc) = @_; + if (keys %{$tbl}) + { + local $, = "\n"; + print "\n"; + print map { &{$fnc}($_, $tbl->{$_}) } sort keys %{$tbl}; + print "\n"; + } +} + +sub output_exacts($$) +{ + my ($tbl, $fnc) = @_; + if (scalar @{$tbl}) + { + local $, = "\n"; + print "\n"; + print map { &{$fnc}($_) } sort @{$tbl}; + print "\n"; + } +} + diff --git a/Externals/GLew/auto/bin/make_def_fun.pl b/Externals/GLew/auto/bin/make_def_fun.pl new file mode 100755 index 0000000000..40e67d5dc2 --- /dev/null +++ b/Externals/GLew/auto/bin/make_def_fun.pl @@ -0,0 +1,35 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +# function pointer declaration +sub make_pfn_decl($%) +{ + return "PFN" . (uc $_[0]) . "PROC " . prefixname($_[0]) . " = NULL;"; +} + +my @extlist = (); +my %extensions = (); + +our $type = shift; + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + output_decls($functions, \&make_pfn_decl); + } +} diff --git a/Externals/GLew/auto/bin/make_def_var.pl b/Externals/GLew/auto/bin/make_def_var.pl new file mode 100755 index 0000000000..e484194c0e --- /dev/null +++ b/Externals/GLew/auto/bin/make_def_var.pl @@ -0,0 +1,31 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +my @extlist = (); +my %extensions = (); + +our $type = shift; + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + my $extvar = $extname; + $extvar =~ s/GL(X*)_/GL$1EW_/; + print "GLboolean " . prefix_varname($extvar) . " = GL_FALSE;\n"; + } +} diff --git a/Externals/GLew/auto/bin/make_header.pl b/Externals/GLew/auto/bin/make_header.pl new file mode 100755 index 0000000000..e58b46fd30 --- /dev/null +++ b/Externals/GLew/auto/bin/make_header.pl @@ -0,0 +1,71 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +# token +sub make_define($$) +{ + return "#define $_[0] $_[1]" +} + +# type declaration +sub make_type($$) +{ + return "typedef $_[1] $_[0];" +} + +# function pointer type declaration +sub make_pfn_type($%) +{ + our $api; + return join(' ', "typedef", $_[1]->{rtype}, + "($api * PFN" . (uc $_[0]) . "PROC)", + "(" . $_[1]->{parms} . ")") . ";"; +} + +# function name alias +sub make_pfn_alias($%) +{ + our $type; + return join(" ", "#define", $_[0], $type . "EW_GET_FUN(" . prefixname($_[0]) . ")") +} + +my @extlist = (); +my %extensions = (); + +our $api = shift; +our $type = shift; + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + + make_separator($extname); + print "#ifndef $extname\n#define $extname 1\n"; + output_tokens($tokens, \&make_define); + output_types($types, \&make_type); + output_exacts($exacts, \&make_exact); + output_decls($functions, \&make_pfn_type); + output_decls($functions, \&make_pfn_alias); + + my $extvar = $extname; + $extvar =~ s/GL(X*)_/GL$1EW_/; + + print "\n#define $extvar " . $type . "EW_GET_VAR(" . prefix_varname($extvar) . ")\n"; + print "\n#endif /* $extname */\n\n"; + } +} diff --git a/Externals/GLew/auto/bin/make_html.pl b/Externals/GLew/auto/bin/make_html.pl new file mode 100755 index 0000000000..ee58196147 --- /dev/null +++ b/Externals/GLew/auto/bin/make_html.pl @@ -0,0 +1,55 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +#--------------------------------------------------------------------------------------- + +my @extlist = (); +my %extensions = (); +my $group = ""; +my $cur_group = ""; + +if (@ARGV) +{ + @extlist = @ARGV; + my $n = 1; + print "\n"; + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + $cur_group = $extname; + $cur_group =~ s/^(?:W?)GL(?:X?)_([A-Z0-9]+?)_.*$/$1/; + $extname =~ s/^(?:W?)GL(?:X?)_(.*)$/$1/; + if ($cur_group ne $group) + { + if ($group ne "") + { + print "\n"; + } + $group = $cur_group; + } + + { + if ($exturl) + { + print "\n"; + } + else + { + print "\n"; + } + $n++; + } + } + print "

$n $extname
$n $extname
\n" +} diff --git a/Externals/GLew/auto/bin/make_info.pl b/Externals/GLew/auto/bin/make_info.pl new file mode 100755 index 0000000000..5d0c7f6d32 --- /dev/null +++ b/Externals/GLew/auto/bin/make_info.pl @@ -0,0 +1,59 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +#--------------------------------------------------------------------------------------- + +# function pointer definition +sub make_pfn_info($%) +{ + my $name = $_[0]; + return " glewInfoFunc(\"$_[0]\", $name == NULL);"; +} + +#--------------------------------------------------------------------------------------- + +my @extlist = (); +my %extensions = (); + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + my $extvar = $extname; + $extvar =~ s/GL(X*)_/GL$1EW_/; + my $extpre = $extname; + $extpre =~ s/(GLX|GLW|GL).*/$1/; + $extpre = lc $extpre; + + #make_separator($extname); + print "#ifdef $extname\n\n"; + print "static void _glewInfo_$extname (void)\n{\n"; + if ($extvar =~ /VERSION/) + { + print " glewPrintExt(\"$extname\", $extvar, $extvar, $extvar);\n"; + } + else + { + print " glewPrintExt(\"$extname\", $extvar, $extpre" . + "ewIsSupported(\"$extname\"), $extpre" . + "ewGetExtension(\"$extstring\"));\n"; + } + output_decls($functions, \&make_pfn_info); + print "}\n\n"; + print "#endif /* $extname */\n\n"; + } +} diff --git a/Externals/GLew/auto/bin/make_info_list.pl b/Externals/GLew/auto/bin/make_info_list.pl new file mode 100755 index 0000000000..a55106d153 --- /dev/null +++ b/Externals/GLew/auto/bin/make_info_list.pl @@ -0,0 +1,47 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +#--------------------------------------------------------------------------------------- + +# function pointer definition +sub make_pfn_def($%) +{ + return "PFN" . (uc $_[0]) . "PROC " . prefixname($_[0]) . " = NULL;"; +} + +# function pointer definition +sub make_init_call($%) +{ + my $name = prefixname($_[0]); + return " r = r || (" . $name . " = (PFN" . (uc $_[0]) . "PROC)glewGetProcAddress((const GLubyte*)\"" . $name . "\")) == NULL;"; +} + +#--------------------------------------------------------------------------------------- + +my @extlist = (); +my %extensions = (); + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + + print "#ifdef $extname\n"; + print " _glewInfo_$extname();\n"; + print "#endif /* $extname */\n"; + } +} diff --git a/Externals/GLew/auto/bin/make_init.pl b/Externals/GLew/auto/bin/make_init.pl new file mode 100755 index 0000000000..70abc982c6 --- /dev/null +++ b/Externals/GLew/auto/bin/make_init.pl @@ -0,0 +1,55 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +#------------------------------------------------------------------------------- + +# function pointer definition +sub make_pfn_def_init($%) +{ + #my $name = prefixname($_[0]); + return " r = ((" . $_[0] . " = (PFN" . (uc $_[0]) . "PROC)glewGetProcAddress((const GLubyte*)\"" . $_[0] . "\")) == NULL) || r;"; +} + +#------------------------------------------------------------------------------- + +my @extlist = (); +my %extensions = (); + +our $type = shift; + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = + parse_ext($ext); + + #make_separator($extname); + print "#ifdef $extname\n\n"; + my $extvar = $extname; + my $extvardef = $extname; + $extvar =~ s/GL(X*)_/GL$1EW_/; + if (keys %$functions) + { + print "static GLboolean _glewInit_$extname (" . $type . + "EW_CONTEXT_ARG_DEF_INIT)\n{\n GLboolean r = GL_FALSE;\n"; + output_decls($functions, \&make_pfn_def_init); + print "\n return r;\n}\n\n"; + } + #print "\nGLboolean " . prefix_varname($extvar) . " = GL_FALSE;\n\n"; + print "#endif /* $extname */\n\n"; + } +} diff --git a/Externals/GLew/auto/bin/make_list.pl b/Externals/GLew/auto/bin/make_list.pl new file mode 100755 index 0000000000..ceaa479249 --- /dev/null +++ b/Externals/GLew/auto/bin/make_list.pl @@ -0,0 +1,66 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +#--------------------------------------------------------------------------------------- + +# function pointer definition +sub make_init_call($%) +{ + my $name = prefixname($_[0]); + return " r = r || (" . $_[0] . " = (PFN" . (uc $_[0]) . "PROC)glewGetProcAddress(\"" . $name . "\")) == NULL;"; +} + +#--------------------------------------------------------------------------------------- + +my @extlist = (); +my %extensions = (); + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + + my $extvar = $extname; + $extvar =~ s/GL(X*)_/GL$1EW_/; + + my $extpre = $extname; + $extpre =~ s/^(W?)GL(X?).*$/\l$1gl\l$2ew/; + + #my $pextvar = prefix_varname($extvar); + + print "#ifdef $extname\n"; + + if (length($extstring)) + { + print " CONST_CAST(" . $extvar . ") = " . $extpre . "GetExtension(\"$extstring\");\n"; + } + + if (keys %$functions) + { + if ($extname =~ /WGL_.*/) + { + print " if (glewExperimental || " . $extvar . "|| crippled) CONST_CAST(" . $extvar . ")= !_glewInit_$extname(GLEW_CONTEXT_ARG_VAR_INIT);\n"; + } + else + { + print " if (glewExperimental || " . $extvar . ") CONST_CAST(" . $extvar . ") = !_glewInit_$extname(GLEW_CONTEXT_ARG_VAR_INIT);\n"; + } + } + print "#endif /* $extname */\n"; + } + +} diff --git a/Externals/GLew/auto/bin/make_str.pl b/Externals/GLew/auto/bin/make_str.pl new file mode 100755 index 0000000000..ac4a366086 --- /dev/null +++ b/Externals/GLew/auto/bin/make_str.pl @@ -0,0 +1,53 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +my @extlist = (); +my %extensions = (); + +if (@ARGV) +{ + @extlist = @ARGV; + + my $curexttype = ""; + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + my $exttype = $extname; + $exttype =~ s/(W*?)GL(X*?)_(.*?_)(.*)/$3/; + my $extrem = $extname; + $extrem =~ s/(W*?)GL(X*?)_(.*?_)(.*)/$4/; + my $extvar = $extname; + $extvar =~ s/(W*)GL(X*)_/$1GL$2EW_/; + if(!($exttype =~ $curexttype)) + { + if(length($curexttype) > 0) + { + print " }\n"; + } + print " if (_glewStrSame2(&pos, &len, (const GLubyte*)\"$exttype\", " . length($exttype) . "))\n"; + print " {\n"; + $curexttype = $exttype; + } + print "#ifdef $extname\n"; + print " if (_glewStrSame3(&pos, &len, (const GLubyte*)\"$extrem\", ". length($extrem) . "))\n"; + #print " return $extvar;\n"; + print " {\n"; + print " ret = $extvar;\n"; + print " continue;\n"; + print " }\n"; + print "#endif\n"; + } + + print " }\n"; +} diff --git a/Externals/GLew/auto/bin/make_struct_fun.pl b/Externals/GLew/auto/bin/make_struct_fun.pl new file mode 100755 index 0000000000..c885960243 --- /dev/null +++ b/Externals/GLew/auto/bin/make_struct_fun.pl @@ -0,0 +1,36 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +# function pointer declaration +sub make_pfn_decl($%) +{ + our $export; + return $export . " PFN" . (uc $_[0]) . "PROC " . prefixname($_[0]) . ";"; +} + +my @extlist = (); +my %extensions = (); + +our $export = shift; + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + output_decls($functions, \&make_pfn_decl); + } +} diff --git a/Externals/GLew/auto/bin/make_struct_var.pl b/Externals/GLew/auto/bin/make_struct_var.pl new file mode 100755 index 0000000000..c7ba2f4995 --- /dev/null +++ b/Externals/GLew/auto/bin/make_struct_var.pl @@ -0,0 +1,31 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +do 'bin/make.pl'; + +my @extlist = (); +my %extensions = (); + +our $export = shift; + +if (@ARGV) +{ + @extlist = @ARGV; + + foreach my $ext (sort @extlist) + { + my ($extname, $exturl, $extstring, $types, $tokens, $functions, $exacts) = parse_ext($ext); + my $extvar = $extname; + $extvar =~ s/GL(X*)_/GL$1EW_/; + print $export . " GLboolean " . prefix_varname($extvar) . ";\n"; + } +} diff --git a/Externals/GLew/auto/bin/parse_spec.pl b/Externals/GLew/auto/bin/parse_spec.pl new file mode 100755 index 0000000000..d18fee730e --- /dev/null +++ b/Externals/GLew/auto/bin/parse_spec.pl @@ -0,0 +1,335 @@ +#!/usr/bin/perl +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +use strict; +use warnings; + +sub compile_regex +{ + my $regex = join('', @_); + return qr/$regex/ +} + +my @sections = ( + "Name", + "Name Strings?", + "New Procedures and Functions", + "New Tokens", +); + +my %typemap = ( + bitfield => "GLbitfield", + boolean => "GLboolean", + # fsck up in EXT_vertex_array + Boolean => "GLboolean", + byte => "GLbyte", + clampd => "GLclampd", + clampf => "GLclampf", + double => "GLdouble", + enum => "GLenum", + # Intel fsck up + Glenum => "GLenum", + float => "GLfloat", + half => "GLhalf", + int => "GLint", + short => "GLshort", + sizei => "GLsizei", + ubyte => "GLubyte", + uint => "GLuint", + ushort => "GLushort", + DMbuffer => "void *", + # Nvidia video output fsck up + int64EXT => "GLint64EXT", + uint64EXT=> "GLuint64EXT", + + # ARB VBO introduces these. + + sizeiptr => "GLsizeiptr", + intptr => "GLintptr", + sizeiptrARB => "GLsizeiptrARB", + intptrARB => "GLintptrARB", + + # ARB shader objects introduces these, charARB is at least 8 bits, + # handleARB is at least 32 bits + charARB => "GLcharARB", + handleARB => "GLhandleARB", + + # OpenGL 3.2 and GL_ARB_sync + + int64 => "GLint64", + uint64 => "GLuint64", + sync => "GLsync", + + # GLX 1.3 defines new types which might not be available at compile time + + #GLXFBConfig => "void*", + #GLXFBConfigID => "XID", + #GLXContextID => "XID", + #GLXWindow => "XID", + #GLXPbuffer => "XID", + + # Weird stuff to some SGIX extension + + #GLXFBConfigSGIX => "void*", + #GLXFBConfigIDSGIX => "XID", + +); + +my %voidtypemap = ( + void => "GLvoid", +); + +my %taboo_tokens = ( + GL_ZERO => 1, +); + +# list of function definitions to be ignored, unless they are being defined in +# the given spec. This is an ugly hack arround the fact that people writing +# spec files seem to shut down all brain activity while they are at this task. +# +# This will be moved to its own file eventually. +# +# (mem, 2003-03-19) + +my %fnc_ignore_list = ( + "BindProgramARB" => "ARB_vertex_program", + "ColorSubTableEXT" => "EXT_color_subtable", + "DeleteProgramsARB" => "ARB_vertex_program", + "GenProgramsARB" => "ARB_vertex_program", + "GetProgramEnvParameterdvARB" => "ARB_vertex_program", + "GetProgramEnvParameterfvARB" => "ARB_vertex_program", + "GetProgramLocalParameterdvARB" => "ARB_vertex_program", + "GetProgramLocalParameterfvARB" => "ARB_vertex_program", + "GetProgramStringARB" => "ARB_vertex_program", + "GetProgramivARB" => "ARB_vertex_program", + "IsProgramARB" => "ARB_vertex_program", + "ProgramEnvParameter4dARB" => "ARB_vertex_program", + "ProgramEnvParameter4dvARB" => "ARB_vertex_program", + "ProgramEnvParameter4fARB" => "ARB_vertex_program", + "ProgramEnvParameter4fvARB" => "ARB_vertex_program", + "ProgramLocalParameter4dARB" => "ARB_vertex_program", + "ProgramLocalParameter4dvARB" => "ARB_vertex_program", + "ProgramLocalParameter4fARB" => "ARB_vertex_program", + "ProgramLocalParameter4fvARB" => "ARB_vertex_program", + "ProgramStringARB" => "ARB_vertex_program", + "glXCreateContextAttribsARB" => "ARB_create_context_profile", + "wglCreateContextAttribsARB" => "WGL_ARB_create_context_profile", +); + +my %regex = ( + eofnc => qr/(?:\);?$|^$)/, # )$ | );$ | ^$ + extname => qr/^[A-Z][A-Za-z0-9_]+$/, + none => qr/^\(none\)$/, + function => qr/^(.+) ([a-z][a-z0-9_]*) \((.+)\)$/i, + prefix => qr/^(?:[aw]?gl|glX)/, # gl | agl | wgl | glX + tprefix => qr/^(?:[AW]?GL|GLX)_/, # GL_ | AGL_ | WGL_ | GLX_ + section => compile_regex('^(', join('|', @sections), ')$'), # sections in spec + token => qr/^([A-Z0-9][A-Z0-9_]*):?\s+((?:0x)?[0-9A-F]+)(.*)$/, # define tokens + types => compile_regex('\b(', join('|', keys %typemap), ')\b'), # var types + voidtype => compile_regex('\b(', keys %voidtypemap, ')\b '), # void type +); + +# reshapes the the function declaration from multiline to single line form +sub normalize_prototype +{ + local $_ = join(" ", @_); + s/\s+/ /g; # multiple whitespace -> single space + s/\<.*\>//g; # remove from direct state access extension + s/\<.*$//g; # remove incomplete from direct state access extension + s/\s*\(\s*/ \(/; # exactly one space before ( and none after + s/\s*\)\s*/\)/; # no space before or after ) + s/\s*\*([a-zA-Z])/\* $1/; # "* identifier" + s/\*wgl/\* wgl/; # "* wgl" + s/\*glX/\* glX/; # "* glX" + s/\.\.\./void/; # ... -> void + s/;$//; # remove ; at the end of the line + return $_; +} + +# Ugly hack to work arround the fact that functions are declared in more +# than one spec file. +sub ignore_function($$) +{ + return exists($fnc_ignore_list{$_[0]}) && $fnc_ignore_list{$_[0]} ne $_[1] +} + +sub parse_spec($) +{ + my $filename = shift; + my $extname = ""; + my $vendortag = ""; + my @extnames = (); + my %functions = (); + my %tokens = (); + + my $section = ""; + my @fnc = (); + + my %proc = ( + "Name" => sub { + if (/^([a-z0-9]+)_([a-z0-9_]+)/i) + { + $extname = "$1_$2"; + $vendortag = $1; + } + }, + + "Name Strings" => sub { + # Add extension name to extension list + + # Initially use $extname if (none) specified + if (/$regex{none}/) + { + $_ = $extname; + } + + if (/$regex{extname}/) + { + # prefix with "GL_" if prefix not present + s/^/GL_/ unless /$regex{tprefix}/o; + # Add extension name to extension list + push @extnames, $_; + } + }, + + "New Procedures and Functions" => sub { + # if line matches end of function + if (/$regex{eofnc}/) + { + # add line to function declaration + push @fnc, $_; + + # if normalized version of function looks like a function + if (normalize_prototype(@fnc) =~ /$regex{function}/) + { + # get return type, name, and arguments from regex + my ($return, $name, $parms) = ($1, $2, $3); + if (!ignore_function($name, $extname)) + { + # prefix with "gl" if prefix not present + $name =~ s/^/gl/ unless $name =~ /$regex{prefix}/; + # is this a pure GL function? + if ($name =~ /^gl/ && $name !~ /^glX/) + { + # apply typemaps + $return =~ s/$regex{types}/$typemap{$1}/og; + $return =~ s/void\*/GLvoid */og; + $parms =~ s/$regex{types}/$typemap{$1}/og; + $parms =~ s/$regex{voidtype}/$voidtypemap{$1}/og; + } + # add to functions hash + $functions{$name} = { + rtype => $return, + parms => $parms, + }; + } + } + # reset function declaration + @fnc = (); + } elsif ($_ ne "" and $_ ne "None") { + # if not eof, add line to function declaration + push @fnc, $_ + } + }, + + "New Tokens" => sub { + if (/$regex{token}/) + { + my ($name, $value) = ($1, $2); + # prefix with "GL_" if prefix not present + $name =~ s/^/GL_/ unless $name =~ /$regex{tprefix}/; + # Add (name, value) pair to tokens hash, unless it's taboo + $tokens{$name} = $value unless exists $taboo_tokens{$name}; + } + }, + ); + + # Some people can't read, the template clearly says "Name String_s_" + $proc{"Name String"} = $proc{"Name Strings"}; + + # Open spec file + open SPEC, "<$filename" or return; + + # For each line of SPEC + while() + { + # Delete trailing newline character + chomp; + # Remove trailing white spaces + s/\s+$//; + # If starts with a capital letter, it must be a new section + if (/^[A-Z]/) + { + # Match section name with one of the predefined names + $section = /$regex{section}/o ? $1 : "default"; + } else { + # Line is internal to a section + # Remove leading whitespace + s/^\s+//; + # Call appropriate section processing function if it exists + &{$proc{$section}} if exists $proc{$section}; + } + } + + close SPEC; + + return ($extname, \@extnames, \%tokens, \%functions); +} + +#---------------------------------------------------------------------------------------- + +my @speclist = (); +my %extensions = (); + +my $ext_dir = shift; +my $reg_http = "http://www.opengl.org/registry/specs/"; +#my $reg_http = "http://oss.sgi.com/projects/ogl-sample/"; + +# Take command line arguments or read list from file +if (@ARGV) +{ + @speclist = @ARGV; +} else { + local $/; #??? + @speclist = split "\n", (<>); +} + +foreach my $spec (sort @speclist) +{ + my ($extname, $extnames, $tokens, $functions) = parse_spec($spec); + + foreach my $ext (@{$extnames}) + { + my $info = "$ext_dir/" . $ext; + open EXT, ">$info"; + print EXT $ext . "\n"; # Extension name + my $specname = $spec; + $specname =~ s/registry\///; + print EXT $reg_http . $specname . "\n"; # Extension info URL + print EXT $ext . "\n"; # Extension string + + my $prefix = $ext; + $prefix =~ s/^(.+?)(_.+)$/$1/; + foreach my $token (sort { hex ${$tokens}{$a} <=> hex ${$tokens}{$b} } keys %{$tokens}) + { + if ($token =~ /^$prefix\_.*/i) + { + print EXT "\t" . $token . " " . ${\%{$tokens}}{$token} . "\n"; + } + } + foreach my $function (sort keys %{$functions}) + { + if ($function =~ /^$prefix.*/i) + { + print EXT "\t" . ${$functions}{$function}{rtype} . " " . $function . " (" . ${$functions}{$function}{parms} . ")" . "\n"; + } + } + close EXT; + } +} diff --git a/Externals/GLew/auto/bin/update_ext.sh b/Externals/GLew/auto/bin/update_ext.sh new file mode 100755 index 0000000000..c660c68b4d --- /dev/null +++ b/Externals/GLew/auto/bin/update_ext.sh @@ -0,0 +1,280 @@ +#!/bin/bash +## +## Copyright (C) 2002-2008, Marcelo E. Magallon +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. +## +## Parameters: +## +## $1: Extensions directory +## $2: Registry directory +## $3: The black list + +set -e + +if [ ! -d $1 ] ; then + mkdir $1 + +# Parse each of the extensions in the registry + find $2 -name doc -type d -prune -o -name \*.txt -print | \ + grep -v -f $3 | sort | bin/parse_spec.pl $1 + +# fix GL_NV_texture_compression_vtc + grep -v EXT $1/GL_NV_texture_compression_vtc > tmp + mv tmp $1/GL_NV_texture_compression_vtc + +# remove duplicates from GL_ARB_vertex_program and GL_ARB_fragment_program + grep -v -F -f $1/GL_ARB_vertex_program $1/GL_ARB_fragment_program > tmp + mv tmp $1/GL_ARB_fragment_program + +# remove duplicates from GLX_EXT_visual_rating and GLX_EXT_visual_info + grep -v -F -f $1/GLX_EXT_visual_info $1/GLX_EXT_visual_rating > tmp + mv tmp $1/GLX_EXT_visual_rating + +# GL_EXT_draw_buffers2 and GL_EXT_transform_feedback both define glGetBooleanIndexedvEXT but with different parameter names + grep -v glGetBooleanIndexedvEXT $1/GL_EXT_transform_feedback > tmp + mv tmp $1/GL_EXT_transform_feedback + +# GL_EXT_draw_buffers2 and GL_EXT_transform_feedback both define glGetIntegerIndexedvEXT but with different parameter names + grep -v glGetIntegerIndexedvEXT $1/GL_EXT_transform_feedback > tmp + mv tmp $1/GL_EXT_transform_feedback + +# remove duplicates from GL_NV_present_video and GLX_NV_present_video + grep -v -F -f $1/GLX_NV_present_video $1/GL_NV_present_video > tmp + mv tmp $1/GL_NV_present_video + +# fix WGL_NV_present_video + cat >> $1/WGL_NV_present_video <> $1/WGL_NV_video_output < tmp + mv tmp $1/GL_NV_occlusion_query + perl -e's/OCCLUSION_TEST_HP.*/OCCLUSION_TEST_HP 0x8165/' -pi \ + $1/GL_HP_occlusion_test + perl -e's/OCCLUSION_TEST_RESULT_HP.*/OCCLUSION_TEST_RESULT_HP 0x8166/' -pi \ + $1/GL_HP_occlusion_test + +# fix GLvoid in GL_ARB_vertex_buffer_objects + perl -e 's/ void\*/ GLvoid\*/g' -pi \ + $1/GL_ARB_vertex_buffer_object + +# add deprecated constants to GL_ATI_fragment_shader + cat >> $1/GL_ATI_fragment_shader <> $1/GL_NV_texture_shader <> $1/WGL_ATI_pixel_format_float <> $1/WGL_ARB_make_current_read <> $1/WGL_EXT_make_current_read <> $1/GL_ARB_vertex_buffer_object <> $1/GLX_EXT_import_context <> $1/GLX_OML_swap_method <> $1/GLX_SGIX_fbconfig <> $1/GLX_SGIX_pbuffer <> $1/GL_NV_half_float <> $1/WGL_ARB_pbuffer <> $1/WGL_EXT_pbuffer < tmp + mv tmp $1/GL_ARB_fragment_shader + grep -v -F -f $1/GL_ARB_shader_objects $1/GL_ARB_vertex_shader > tmp + mv tmp $1/GL_ARB_vertex_shader + +# remove duplicates in GL_ARB_vertex_program and GL_ARB_vertex_shader + grep -v -F -f $1/GL_ARB_vertex_program $1/GL_ARB_vertex_shader > tmp + mv tmp $1/GL_ARB_vertex_shader + +# remove triplicates in GL_ARB_fragment_program, GL_ARB_fragment_shader, +# and GL_ARB_vertex_shader + grep -v -F -f $1/GL_ARB_fragment_program $1/GL_ARB_fragment_shader > tmp + mv tmp $1/GL_ARB_fragment_shader + grep -v -F -f $1/GL_ARB_fragment_program $1/GL_ARB_vertex_shader > tmp + mv tmp $1/GL_ARB_vertex_shader + +# remove duplicates in GL_EXT_direct_state_access + grep -v "glGetBooleanIndexedvEXT" $1/GL_EXT_direct_state_access > tmp + mv tmp $1/GL_EXT_direct_state_access + grep -v "glGetIntegerIndexedvEXT" $1/GL_EXT_direct_state_access > tmp + mv tmp $1/GL_EXT_direct_state_access + grep -v "glDisableIndexedEXT" $1/GL_EXT_direct_state_access > tmp + mv tmp $1/GL_EXT_direct_state_access + grep -v "glEnableIndexedEXT" $1/GL_EXT_direct_state_access > tmp + mv tmp $1/GL_EXT_direct_state_access + grep -v "glIsEnabledIndexedEXT" $1/GL_EXT_direct_state_access > tmp + mv tmp $1/GL_EXT_direct_state_access + +# remove duplicates in GL_NV_explicit_multisample + grep -v "glGetBooleanIndexedvEXT" $1/GL_NV_explicit_multisample > tmp + mv tmp $1/GL_NV_explicit_multisample + grep -v "glGetIntegerIndexedvEXT" $1/GL_NV_explicit_multisample > tmp + mv tmp $1/GL_NV_explicit_multisample + +# fix bugs in GL_ARB_vertex_shader + grep -v "GL_FLOAT" $1/GL_ARB_vertex_shader > tmp + mv tmp $1/GL_ARB_vertex_shader + perl -e 's/handle /GLhandleARB /g' -pi $1/GL_ARB_vertex_shader + +# fix bugs in GL_ARB_shader_objects + grep -v "GL_FLOAT " $1/GL_ARB_shader_objects > tmp + mv tmp $1/GL_ARB_shader_objects + grep -v "GL_INT " $1/GL_ARB_shader_objects > tmp + mv tmp $1/GL_ARB_shader_objects + +# add typedefs to GL_ARB_shader_objects + cat >> $1/GL_ARB_shader_objects <> $1/GL_ARB_transpose_matrix <> $1/GL_EXT_framebuffer_multisample < tmp + mv tmp $1/GL_NV_gpu_program_fp64 + +# Filter glGetUniformui64vNV from GL_NV_shader_buffer_load + grep -v "glGetUniformui64vNV" $1/GL_NV_shader_buffer_load > tmp + mv tmp $1/GL_NV_shader_buffer_load + +# Filter out GL_ARB_gpu_shader_fp64 enums and functions + head -n3 $1/GL_ARB_gpu_shader_fp64 > tmp + mv tmp $1/GL_ARB_gpu_shader_fp64 + +# Filter out profile enumerations from GLX_ARB_create_context + grep -v "_PROFILE_" $1/GLX_ARB_create_context > tmp + mv tmp $1/GLX_ARB_create_context + +# Filter only profile related enumerations for GLX_ARB_create_context_profile + head -n3 $1/GLX_ARB_create_context_profile > tmp + grep "_PROFILE_" $1/GLX_ARB_create_context_profile >> tmp + mv tmp $1/GLX_ARB_create_context_profile + +# Filter out profile enumerations from WGL_ARB_create_context + grep -v "_PROFILE_" $1/WGL_ARB_create_context > tmp + mv tmp $1/WGL_ARB_create_context + +# Filter only profile related enumerations for WGL_ARB_create_context_profile + head -n3 $1/WGL_ARB_create_context_profile > tmp + grep "_PROFILE_" $1/WGL_ARB_create_context_profile >> tmp + mv tmp $1/WGL_ARB_create_context_profile + +# add missing function to GLX_NV_copy_image + cat >> $1/GLX_NV_copy_image <> $1/WGL_NV_copy_image < +## Copyright (C) 2002-2008, Milan Ikits +## +## This program is distributed under the terms and conditions of the GNU +## General Public License Version 2 as published by the Free Software +## Foundation or, at your option, any later version. + +set -e + +if [ ! -d $1 ] ; then + mkdir $1 +fi +cd $1 + +wget \ + --mirror \ + --no-parent \ + --no-host-directories \ + --cut-dirs=2 \ + --accept=txt,html \ + $2 + diff --git a/Externals/GLew/auto/blacklist b/Externals/GLew/auto/blacklist new file mode 100644 index 0000000000..e00128431a --- /dev/null +++ b/Externals/GLew/auto/blacklist @@ -0,0 +1,15 @@ +EXT/draw_range_elements.txt +EXT/static_vertex_array.txt +EXT/vertex_array_set.alt.txt +EXT/vertex_array_set.txt +EXT/nurbs_tessellator.txt +EXT/object_space_tess.txt +SGI/filter4_parameters.txt +SGIS/texture_color_mask.txt +SGIX/dmbuffer.txt +SGIX/instruments.txt +SGIX/video_source.txt +SGIX/hyperpipe_group.txt +OES/OES_fixed_point.txt +OES/OES_query_matrix.txt +NV/video_capture.txt diff --git a/Externals/GLew/auto/core/GLX_ARB_get_proc_address b/Externals/GLew/auto/core/GLX_ARB_get_proc_address new file mode 100644 index 0000000000..5c066d7d00 --- /dev/null +++ b/Externals/GLew/auto/core/GLX_ARB_get_proc_address @@ -0,0 +1,4 @@ +GLX_ARB_get_proc_address +http://oss.sgi.com/projects/ogl-sample/registry/ARB/get_proc_address.txt +GLX_ARB_get_proc_address + extern void ( * glXGetProcAddressARB (const GLubyte *procName)) (void); diff --git a/Externals/GLew/auto/core/GLX_ATI_pixel_format_float b/Externals/GLew/auto/core/GLX_ATI_pixel_format_float new file mode 100644 index 0000000000..854ca716ba --- /dev/null +++ b/Externals/GLew/auto/core/GLX_ATI_pixel_format_float @@ -0,0 +1,4 @@ +GLX_ATI_pixel_format_float + +GLX_ATI_pixel_format_float + GLX_RGBA_FLOAT_ATI_BIT 0x00000100 diff --git a/Externals/GLew/auto/core/GLX_ATI_render_texture b/Externals/GLew/auto/core/GLX_ATI_render_texture new file mode 100644 index 0000000000..254eb9f3bc --- /dev/null +++ b/Externals/GLew/auto/core/GLX_ATI_render_texture @@ -0,0 +1,41 @@ +GLX_ATI_render_texture + +GLX_ATI_render_texture + GLX_BIND_TO_TEXTURE_RGB_ATI 0x9800 + GLX_BIND_TO_TEXTURE_RGBA_ATI 0x9801 + GLX_TEXTURE_FORMAT_ATI 0x9802 + GLX_TEXTURE_TARGET_ATI 0x9803 + GLX_MIPMAP_TEXTURE_ATI 0x9804 + GLX_TEXTURE_RGB_ATI 0x9805 + GLX_TEXTURE_RGBA_ATI 0x9806 + GLX_NO_TEXTURE_ATI 0x9807 + GLX_TEXTURE_CUBE_MAP_ATI 0x9808 + GLX_TEXTURE_1D_ATI 0x9809 + GLX_TEXTURE_2D_ATI 0x980A + GLX_MIPMAP_LEVEL_ATI 0x980B + GLX_CUBE_MAP_FACE_ATI 0x980C + GLX_TEXTURE_CUBE_MAP_POSITIVE_X_ATI 0x980D + GLX_TEXTURE_CUBE_MAP_NEGATIVE_X_ATI 0x980E + GLX_TEXTURE_CUBE_MAP_POSITIVE_Y_ATI 0x980F + GLX_TEXTURE_CUBE_MAP_NEGATIVE_Y_ATI 0x9810 + GLX_TEXTURE_CUBE_MAP_POSITIVE_Z_ATI 0x9811 + GLX_TEXTURE_CUBE_MAP_NEGATIVE_Z_ATI 0x9812 + GLX_FRONT_LEFT_ATI 0x9813 + GLX_FRONT_RIGHT_ATI 0x9814 + GLX_BACK_LEFT_ATI 0x9815 + GLX_BACK_RIGHT_ATI 0x9816 + GLX_AUX0_ATI 0x9817 + GLX_AUX1_ATI 0x9818 + GLX_AUX2_ATI 0x9819 + GLX_AUX3_ATI 0x981A + GLX_AUX4_ATI 0x981B + GLX_AUX5_ATI 0x981C + GLX_AUX6_ATI 0x981D + GLX_AUX7_ATI 0x981E + GLX_AUX8_ATI 0x981F + GLX_AUX9_ATI 0x9820 + GLX_BIND_TO_TEXTURE_LUMINANCE_ATI 0x9821 + GLX_BIND_TO_TEXTURE_INTENSITY_ATI 0x9822 + void glXBindTexImageATI (Display *dpy, GLXPbuffer pbuf, int buffer) + void glXReleaseTexImageATI (Display *dpy, GLXPbuffer pbuf, int buffer) + void glXDrawableAttribATI (Display *dpy, GLXDrawable draw, const int *attrib_list) diff --git a/Externals/GLew/auto/core/GLX_EXT_fbconfig_packed_float b/Externals/GLew/auto/core/GLX_EXT_fbconfig_packed_float new file mode 100644 index 0000000000..7c7822d81a --- /dev/null +++ b/Externals/GLew/auto/core/GLX_EXT_fbconfig_packed_float @@ -0,0 +1,5 @@ +GLX_EXT_fbconfig_packed_float +http://developer.download.nvidia.com/opengl/specs/GL_EXT_packed_float.txt +GLX_EXT_fbconfig_packed_float + GLX_RGBA_UNSIGNED_FLOAT_TYPE_EXT 0x20B1 + GLX_RGBA_UNSIGNED_FLOAT_BIT_EXT 0x00000008 diff --git a/Externals/GLew/auto/core/GLX_EXT_framebuffer_sRGB b/Externals/GLew/auto/core/GLX_EXT_framebuffer_sRGB new file mode 100644 index 0000000000..f51c484afd --- /dev/null +++ b/Externals/GLew/auto/core/GLX_EXT_framebuffer_sRGB @@ -0,0 +1,4 @@ +GLX_EXT_framebuffer_sRGB +http://developer.download.nvidia.com/opengl/specs/GL_EXT_framebuffer_sRGB.txt +GLX_EXT_framebuffer_sRGB + GLX_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20B2 diff --git a/Externals/GLew/auto/core/GLX_NV_float_buffer b/Externals/GLew/auto/core/GLX_NV_float_buffer new file mode 100644 index 0000000000..cc9185ee94 --- /dev/null +++ b/Externals/GLew/auto/core/GLX_NV_float_buffer @@ -0,0 +1,4 @@ +GLX_NV_float_buffer +http://cvs1.nvidia.com/inc/GL/glxtokens.h +GLX_NV_float_buffer + GLX_FLOAT_COMPONENTS_NV 0x20B0 diff --git a/Externals/GLew/auto/core/GLX_NV_vertex_array_range b/Externals/GLew/auto/core/GLX_NV_vertex_array_range new file mode 100644 index 0000000000..11afe17406 --- /dev/null +++ b/Externals/GLew/auto/core/GLX_NV_vertex_array_range @@ -0,0 +1,5 @@ +GLX_NV_vertex_array_range +http://oss.sgi.com/projects/ogl-sample/registry/NV/vertex_array_range.txt +GLX_NV_vertex_array_range + void * glXAllocateMemoryNV (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority) + void glXFreeMemoryNV (void *pointer) diff --git a/Externals/GLew/auto/core/GLX_SGIS_shared_multisample b/Externals/GLew/auto/core/GLX_SGIS_shared_multisample new file mode 100644 index 0000000000..274e90f76e --- /dev/null +++ b/Externals/GLew/auto/core/GLX_SGIS_shared_multisample @@ -0,0 +1,5 @@ +GLX_SGIS_shared_multisample + +GLX_SGIS_shared_multisample + GLX_MULTISAMPLE_SUB_RECT_WIDTH_SGIS 0x8026 + GLX_MULTISAMPLE_SUB_RECT_HEIGHT_SGIS 0x8027 diff --git a/Externals/GLew/auto/core/GLX_SGIX_hyperpipe b/Externals/GLew/auto/core/GLX_SGIX_hyperpipe new file mode 100644 index 0000000000..79ec30295c --- /dev/null +++ b/Externals/GLew/auto/core/GLX_SGIX_hyperpipe @@ -0,0 +1,25 @@ +GLX_SGIX_hyperpipe +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/hyperpipe_group.txt +GLX_SGIX_hyperpipe + GLX_HYPERPIPE_ID_SGIX 0x8030 + GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX 80 + GLX_HYPERPIPE_DISPLAY_PIPE_SGIX 0x00000001 + GLX_HYPERPIPE_RENDER_PIPE_SGIX 0x00000002 + GLX_PIPE_RECT_SGIX 0x00000001 + GLX_PIPE_RECT_LIMITS_SGIX 0x00000002 + GLX_HYPERPIPE_STEREO_SGIX 0x00000003 + GLX_HYPERPIPE_PIXEL_AVERAGE_SGIX 0x00000004 + GLX_BAD_HYPERPIPE_CONFIG_SGIX 91 + GLX_BAD_HYPERPIPE_SGIX 92 + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int networkId; } GLXHyperpipeNetworkSGIX; + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int channel; unsigned int participationType; int timeSlice; } GLXHyperpipeConfigSGIX; + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int srcXOrigin; int srcYOrigin; int srcWidth; int srcHeight; int destXOrigin; int destYOrigin; int destWidth; int destHeight; } GLXPipeRect; + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int XOrigin; int YOrigin; int maxHeight; int maxWidth; } GLXPipeRectLimits; + GLXHyperpipeNetworkSGIX * glXQueryHyperpipeNetworkSGIX (Display *dpy, int *npipes) + int glXHyperpipeConfigSGIX (Display *dpy, int networkId, int npipes, GLXHyperpipeConfigSGIX *cfg, int *hpId) + GLXHyperpipeConfigSGIX * glXQueryHyperpipeConfigSGIX (Display *dpy, int hpId, int *npipes) + int glXDestroyHyperpipeConfigSGIX (Display *dpy, int hpId) + int glXBindHyperpipeSGIX (Display *dpy, int hpId) + int glXQueryHyperpipeBestAttribSGIX (Display *dpy, int timeSlice, int attrib, int size, void *attribList, void *returnAttribList) + int glXHyperpipeAttribSGIX (Display *dpy, int timeSlice, int attrib, int size, void *attribList) + int glXQueryHyperpipeAttribSGIX (Display *dpy, int timeSlice, int attrib, int size, void *returnAttribList) diff --git a/Externals/GLew/auto/core/GLX_SGIX_swap_barrier b/Externals/GLew/auto/core/GLX_SGIX_swap_barrier new file mode 100644 index 0000000000..57dd60dbb0 --- /dev/null +++ b/Externals/GLew/auto/core/GLX_SGIX_swap_barrier @@ -0,0 +1,5 @@ +GLX_SGIX_swap_barrier +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/swap_barrier.txt +GLX_SGIX_swap_barrier + void glXBindSwapBarrierSGIX (Display *dpy, GLXDrawable drawable, int barrier) + Bool glXQueryMaxSwapBarriersSGIX (Display *dpy, int screen, int *max) diff --git a/Externals/GLew/auto/core/GLX_SGIX_swap_group b/Externals/GLew/auto/core/GLX_SGIX_swap_group new file mode 100644 index 0000000000..3530604605 --- /dev/null +++ b/Externals/GLew/auto/core/GLX_SGIX_swap_group @@ -0,0 +1,4 @@ +GLX_SGIX_swap_group +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/swap_group.txt +GLX_SGIX_swap_group + void glXJoinSwapGroupSGIX (Display *dpy, GLXDrawable drawable, GLXDrawable member) diff --git a/Externals/GLew/auto/core/GLX_SUN_video_resize b/Externals/GLew/auto/core/GLX_SUN_video_resize new file mode 100644 index 0000000000..0a0cefe3db --- /dev/null +++ b/Externals/GLew/auto/core/GLX_SUN_video_resize @@ -0,0 +1,7 @@ +GLX_SUN_video_resize +http://wwws.sun.com/software/graphics/opengl/extensions/glx_sun_video_resize.txt +GLX_SUN_video_resize + GL_VIDEO_RESIZE_COMPENSATION_SUN 0x85CD + GLX_VIDEO_RESIZE_SUN 0x8171 + int glXVideoResizeSUN (Display* display, GLXDrawable window, float factor) + int glXGetVideoResizeSUN (Display* display, GLXDrawable window, float* factor) diff --git a/Externals/GLew/auto/core/GLX_VERSION_1_2 b/Externals/GLew/auto/core/GLX_VERSION_1_2 new file mode 100644 index 0000000000..39d7a09bc8 --- /dev/null +++ b/Externals/GLew/auto/core/GLX_VERSION_1_2 @@ -0,0 +1,4 @@ +GLX_VERSION_1_2 +http://www.opengl.org/documentation/specs/glx/glx1.2.ps +GLX_VERSION_1_2 + Display* glXGetCurrentDisplay (void) diff --git a/Externals/GLew/auto/core/GLX_VERSION_1_3 b/Externals/GLew/auto/core/GLX_VERSION_1_3 new file mode 100644 index 0000000000..46eedb979c --- /dev/null +++ b/Externals/GLew/auto/core/GLX_VERSION_1_3 @@ -0,0 +1,82 @@ +GLX_VERSION_1_3 +http://www.opengl.org/documentation/specs/glx/glx1.3.pdf +GLX_VERSION_1_3 + GLX_WINDOW_BIT 0x00000001 + GLX_PIXMAP_BIT 0x00000002 + GLX_PBUFFER_BIT 0x00000004 + GLX_RGBA_BIT 0x00000001 + GLX_COLOR_INDEX_BIT 0x00000002 + GLX_PBUFFER_CLOBBER_MASK 0x08000000 + GLX_FRONT_LEFT_BUFFER_BIT 0x00000001 + GLX_FRONT_RIGHT_BUFFER_BIT 0x00000002 + GLX_BACK_LEFT_BUFFER_BIT 0x00000004 + GLX_BACK_RIGHT_BUFFER_BIT 0x00000008 + GLX_AUX_BUFFERS_BIT 0x00000010 + GLX_DEPTH_BUFFER_BIT 0x00000020 + GLX_STENCIL_BUFFER_BIT 0x00000040 + GLX_ACCUM_BUFFER_BIT 0x00000080 + GLX_CONFIG_CAVEAT 0x20 + GLX_X_VISUAL_TYPE 0x22 + GLX_TRANSPARENT_TYPE 0x23 + GLX_TRANSPARENT_INDEX_VALUE 0x24 + GLX_TRANSPARENT_RED_VALUE 0x25 + GLX_TRANSPARENT_GREEN_VALUE 0x26 + GLX_TRANSPARENT_BLUE_VALUE 0x27 + GLX_TRANSPARENT_ALPHA_VALUE 0x28 + GLX_DONT_CARE 0xFFFFFFFF + GLX_NONE 0x8000 + GLX_SLOW_CONFIG 0x8001 + GLX_TRUE_COLOR 0x8002 + GLX_DIRECT_COLOR 0x8003 + GLX_PSEUDO_COLOR 0x8004 + GLX_STATIC_COLOR 0x8005 + GLX_GRAY_SCALE 0x8006 + GLX_STATIC_GRAY 0x8007 + GLX_TRANSPARENT_RGB 0x8008 + GLX_TRANSPARENT_INDEX 0x8009 + GLX_VISUAL_ID 0x800B + GLX_SCREEN 0x800C + GLX_NON_CONFORMANT_CONFIG 0x800D + GLX_DRAWABLE_TYPE 0x8010 + GLX_RENDER_TYPE 0x8011 + GLX_X_RENDERABLE 0x8012 + GLX_FBCONFIG_ID 0x8013 + GLX_RGBA_TYPE 0x8014 + GLX_COLOR_INDEX_TYPE 0x8015 + GLX_MAX_PBUFFER_WIDTH 0x8016 + GLX_MAX_PBUFFER_HEIGHT 0x8017 + GLX_MAX_PBUFFER_PIXELS 0x8018 + GLX_PRESERVED_CONTENTS 0x801B + GLX_LARGEST_PBUFFER 0x801C + GLX_WIDTH 0x801D + GLX_HEIGHT 0x801E + GLX_EVENT_MASK 0x801F + GLX_DAMAGED 0x8020 + GLX_SAVED 0x8021 + GLX_WINDOW 0x8022 + GLX_PBUFFER 0x8023 + GLX_PBUFFER_HEIGHT 0x8040 + GLX_PBUFFER_WIDTH 0x8041 + GLXFBConfig* glXChooseFBConfig (Display *dpy, int screen, const int *attrib_list, int *nelements) + GLXFBConfig* glXGetFBConfigs (Display *dpy, int screen, int *nelements) + XVisualInfo* glXGetVisualFromFBConfig (Display *dpy, GLXFBConfig config) + int glXGetFBConfigAttrib (Display *dpy, GLXFBConfig config, int attribute, int *value) + GLXWindow glXCreateWindow (Display *dpy, GLXFBConfig config, Window win, const int *attrib_list) + void glXDestroyWindow (Display *dpy, GLXWindow win) + GLXPixmap glXCreatePixmap (Display *dpy, GLXFBConfig config, Pixmap pixmap, const int *attrib_list) + void glXDestroyPixmap (Display *dpy, GLXPixmap pixmap) + GLXPbuffer glXCreatePbuffer (Display *dpy, GLXFBConfig config, const int *attrib_list) + void glXDestroyPbuffer (Display *dpy, GLXPbuffer pbuf) + void glXQueryDrawable (Display *dpy, GLXDrawable draw, int attribute, unsigned int *value) + GLXContext glXCreateNewContext (Display *dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct) + Bool glXMakeContextCurrent (Display *display, GLXDrawable draw, GLXDrawable read, GLXContext ctx) + GLXDrawable glXGetCurrentReadDrawable (void) + int glXQueryContext (Display *dpy, GLXContext ctx, int attribute, int *value) + void glXSelectEvent (Display *dpy, GLXDrawable draw, unsigned long event_mask) + void glXGetSelectedEvent (Display *dpy, GLXDrawable draw, unsigned long *event_mask) + typedef XID GLXWindow + typedef XID GLXPbuffer + typedef XID GLXFBConfigID + typedef struct __GLXFBConfigRec *GLXFBConfig + typedef struct { int event_type; int draw_type; unsigned long serial; Bool send_event; Display *display; GLXDrawable drawable; unsigned int buffer_mask; unsigned int aux_buffer; int x, y; int width, height; int count; } GLXPbufferClobberEvent; + typedef union __GLXEvent { GLXPbufferClobberEvent glxpbufferclobber; long pad[24]; } GLXEvent; diff --git a/Externals/GLew/auto/core/GLX_VERSION_1_4 b/Externals/GLew/auto/core/GLX_VERSION_1_4 new file mode 100644 index 0000000000..138262161e --- /dev/null +++ b/Externals/GLew/auto/core/GLX_VERSION_1_4 @@ -0,0 +1,6 @@ +GLX_VERSION_1_4 +http://www.opengl.org/documentation/specs/glx/glx1.4.pdf +GLX_VERSION_1_4 + GLX_SAMPLE_BUFFERS 100000 + GLX_SAMPLES 100001 + extern void ( * glXGetProcAddress (const GLubyte *procName)) (void); diff --git a/Externals/GLew/auto/core/GL_APPLE_float_pixels b/Externals/GLew/auto/core/GL_APPLE_float_pixels new file mode 100644 index 0000000000..8a60870eec --- /dev/null +++ b/Externals/GLew/auto/core/GL_APPLE_float_pixels @@ -0,0 +1,17 @@ +GL_APPLE_float_pixels +http://developer.apple.com/opengl/extensions/apple_float_pixels.html +GL_APPLE_float_pixels + GL_HALF_APPLE 0x140B + GL_COLOR_FLOAT_APPLE 0x8A0F + GL_RGBA_FLOAT32_APPLE 0x8814 + GL_RGB_FLOAT32_APPLE 0x8815 + GL_ALPHA_FLOAT32_APPLE 0x8816 + GL_INTENSITY_FLOAT32_APPLE 0x8817 + GL_LUMINANCE_FLOAT32_APPLE 0x8818 + GL_LUMINANCE_ALPHA_FLOAT32_APPLE 0x8819 + GL_RGBA_FLOAT16_APPLE 0x881A + GL_RGB_FLOAT16_APPLE 0x881B + GL_ALPHA_FLOAT16_APPLE 0x881C + GL_INTENSITY_FLOAT16_APPLE 0x881D + GL_LUMINANCE_FLOAT16_APPLE 0x881E + GL_LUMINANCE_ALPHA_FLOAT16_APPLE 0x881F diff --git a/Externals/GLew/auto/core/GL_APPLE_pixel_buffer b/Externals/GLew/auto/core/GL_APPLE_pixel_buffer new file mode 100644 index 0000000000..7449f2918e --- /dev/null +++ b/Externals/GLew/auto/core/GL_APPLE_pixel_buffer @@ -0,0 +1,4 @@ +GL_APPLE_pixel_buffer + +GL_APPLE_pixel_buffer + GL_MIN_PBUFFER_VIEWPORT_DIMS_APPLE 0x8A10 diff --git a/Externals/GLew/auto/core/GL_APPLE_texture_range b/Externals/GLew/auto/core/GL_APPLE_texture_range new file mode 100644 index 0000000000..8c5165d61d --- /dev/null +++ b/Externals/GLew/auto/core/GL_APPLE_texture_range @@ -0,0 +1,12 @@ +GL_APPLE_texture_range +http://developer.apple.com/opengl/extensions/apple_texture_range.html +GL_APPLE_texture_range + GL_TEXTURE_STORAGE_HINT_APPLE 0x85BC + GL_STORAGE_PRIVATE_APPLE 0x85BD + GL_STORAGE_CACHED_APPLE 0x85BE + GL_STORAGE_SHARED_APPLE 0x85BF + GL_TEXTURE_RANGE_LENGTH_APPLE 0x85B7 + GL_TEXTURE_RANGE_POINTER_APPLE 0x85B8 + void glTextureRangeAPPLE (GLenum target, GLsizei length, GLvoid *pointer) + void glGetTexParameterPointervAPPLE (GLenum target, GLenum pname, GLvoid **params) + diff --git a/Externals/GLew/auto/core/GL_ARB_imaging b/Externals/GLew/auto/core/GL_ARB_imaging new file mode 100644 index 0000000000..0efd0c1b8e --- /dev/null +++ b/Externals/GLew/auto/core/GL_ARB_imaging @@ -0,0 +1,112 @@ +GL_ARB_imaging + +GL_ARB_imaging + GL_CONSTANT_COLOR 0x8001 + GL_ONE_MINUS_CONSTANT_COLOR 0x8002 + GL_CONSTANT_ALPHA 0x8003 + GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 + GL_BLEND_COLOR 0x8005 + GL_FUNC_ADD 0x8006 + GL_MIN 0x8007 + GL_MAX 0x8008 + GL_BLEND_EQUATION 0x8009 + GL_FUNC_SUBTRACT 0x800A + GL_FUNC_REVERSE_SUBTRACT 0x800B + GL_CONVOLUTION_1D 0x8010 + GL_CONVOLUTION_2D 0x8011 + GL_SEPARABLE_2D 0x8012 + GL_CONVOLUTION_BORDER_MODE 0x8013 + GL_CONVOLUTION_FILTER_SCALE 0x8014 + GL_CONVOLUTION_FILTER_BIAS 0x8015 + GL_REDUCE 0x8016 + GL_CONVOLUTION_FORMAT 0x8017 + GL_CONVOLUTION_WIDTH 0x8018 + GL_CONVOLUTION_HEIGHT 0x8019 + GL_MAX_CONVOLUTION_WIDTH 0x801A + GL_MAX_CONVOLUTION_HEIGHT 0x801B + GL_POST_CONVOLUTION_RED_SCALE 0x801C + GL_POST_CONVOLUTION_GREEN_SCALE 0x801D + GL_POST_CONVOLUTION_BLUE_SCALE 0x801E + GL_POST_CONVOLUTION_ALPHA_SCALE 0x801F + GL_POST_CONVOLUTION_RED_BIAS 0x8020 + GL_POST_CONVOLUTION_GREEN_BIAS 0x8021 + GL_POST_CONVOLUTION_BLUE_BIAS 0x8022 + GL_POST_CONVOLUTION_ALPHA_BIAS 0x8023 + GL_HISTOGRAM 0x8024 + GL_PROXY_HISTOGRAM 0x8025 + GL_HISTOGRAM_WIDTH 0x8026 + GL_HISTOGRAM_FORMAT 0x8027 + GL_HISTOGRAM_RED_SIZE 0x8028 + GL_HISTOGRAM_GREEN_SIZE 0x8029 + GL_HISTOGRAM_BLUE_SIZE 0x802A + GL_HISTOGRAM_ALPHA_SIZE 0x802B + GL_HISTOGRAM_LUMINANCE_SIZE 0x802C + GL_HISTOGRAM_SINK 0x802D + GL_MINMAX 0x802E + GL_MINMAX_FORMAT 0x802F + GL_MINMAX_SINK 0x8030 + GL_TABLE_TOO_LARGE 0x8031 + GL_COLOR_MATRIX 0x80B1 + GL_COLOR_MATRIX_STACK_DEPTH 0x80B2 + GL_MAX_COLOR_MATRIX_STACK_DEPTH 0x80B3 + GL_POST_COLOR_MATRIX_RED_SCALE 0x80B4 + GL_POST_COLOR_MATRIX_GREEN_SCALE 0x80B5 + GL_POST_COLOR_MATRIX_BLUE_SCALE 0x80B6 + GL_POST_COLOR_MATRIX_ALPHA_SCALE 0x80B7 + GL_POST_COLOR_MATRIX_RED_BIAS 0x80B8 + GL_POST_COLOR_MATRIX_GREEN_BIAS 0x80B9 + GL_POST_COLOR_MATRIX_BLUE_BIAS 0x80BA + GL_POST_COLOR_MATRIX_ALPHA_BIAS 0x80BB + GL_COLOR_TABLE 0x80D0 + GL_POST_CONVOLUTION_COLOR_TABLE 0x80D1 + GL_POST_COLOR_MATRIX_COLOR_TABLE 0x80D2 + GL_PROXY_COLOR_TABLE 0x80D3 + GL_PROXY_POST_CONVOLUTION_COLOR_TABLE 0x80D4 + GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE 0x80D5 + GL_COLOR_TABLE_SCALE 0x80D6 + GL_COLOR_TABLE_BIAS 0x80D7 + GL_COLOR_TABLE_FORMAT 0x80D8 + GL_COLOR_TABLE_WIDTH 0x80D9 + GL_COLOR_TABLE_RED_SIZE 0x80DA + GL_COLOR_TABLE_GREEN_SIZE 0x80DB + GL_COLOR_TABLE_BLUE_SIZE 0x80DC + GL_COLOR_TABLE_ALPHA_SIZE 0x80DD + GL_COLOR_TABLE_LUMINANCE_SIZE 0x80DE + GL_COLOR_TABLE_INTENSITY_SIZE 0x80DF + GL_IGNORE_BORDER 0x8150 + GL_CONSTANT_BORDER 0x8151 + GL_WRAP_BORDER 0x8152 + GL_REPLICATE_BORDER 0x8153 + GL_CONVOLUTION_BORDER_COLOR 0x8154 + void glColorTable (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table) + void glColorSubTable (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data) + void glColorTableParameteriv (GLenum target, GLenum pname, const GLint *params) + void glColorTableParameterfv (GLenum target, GLenum pname, const GLfloat *params) + void glCopyColorSubTable (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width) + void glCopyColorTable (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width) + void glGetColorTable (GLenum target, GLenum format, GLenum type, GLvoid *table) + void glGetColorTableParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetColorTableParameteriv (GLenum target, GLenum pname, GLint *params) + void glHistogram (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink) + void glResetHistogram (GLenum target) + void glGetHistogram (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values) + void glGetHistogramParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetHistogramParameteriv (GLenum target, GLenum pname, GLint *params) + void glMinmax (GLenum target, GLenum internalformat, GLboolean sink) + void glResetMinmax (GLenum target) + void glGetMinmaxParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetMinmaxParameteriv (GLenum target, GLenum pname, GLint *params) + void glConvolutionFilter1D (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image) + void glConvolutionFilter2D (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image) + void glConvolutionParameterf (GLenum target, GLenum pname, GLfloat params) + void glConvolutionParameterfv (GLenum target, GLenum pname, const GLfloat *params) + void glConvolutionParameteri (GLenum target, GLenum pname, GLint params) + void glConvolutionParameteriv (GLenum target, GLenum pname, const GLint *params) + void glCopyConvolutionFilter1D (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width) + void glCopyConvolutionFilter2D (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height) + void glGetConvolutionFilter (GLenum target, GLenum format, GLenum type, GLvoid *image) + void glGetConvolutionParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetConvolutionParameteriv (GLenum target, GLenum pname, GLint *params) + void glSeparableFilter2D (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column) + void glGetSeparableFilter (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span) + void glGetMinmax (GLenum target, GLboolean reset, GLenum format, GLenum types, GLvoid *values) diff --git a/Externals/GLew/auto/core/GL_ARB_matrix_palette b/Externals/GLew/auto/core/GL_ARB_matrix_palette new file mode 100644 index 0000000000..4b67c15cf4 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ARB_matrix_palette @@ -0,0 +1,18 @@ +GL_ARB_matrix_palette +http://oss.sgi.com/projects/ogl-sample/registry/ARB/matrix_palette.txt +GL_ARB_matrix_palette + GL_MATRIX_PALETTE_ARB 0x8840 + GL_MAX_MATRIX_PALETTE_STACK_DEPTH_ARB 0x8841 + GL_MAX_PALETTE_MATRICES_ARB 0x8842 + GL_CURRENT_PALETTE_MATRIX_ARB 0x8843 + GL_MATRIX_INDEX_ARRAY_ARB 0x8844 + GL_CURRENT_MATRIX_INDEX_ARB 0x8845 + GL_MATRIX_INDEX_ARRAY_SIZE_ARB 0x8846 + GL_MATRIX_INDEX_ARRAY_TYPE_ARB 0x8847 + GL_MATRIX_INDEX_ARRAY_STRIDE_ARB 0x8848 + GL_MATRIX_INDEX_ARRAY_POINTER_ARB 0x8849 + void glCurrentPaletteMatrixARB (GLint index) + void glMatrixIndexPointerARB (GLint size, GLenum type, GLsizei stride, GLvoid *pointer) + void glMatrixIndexubvARB (GLint size, GLubyte *indices) + void glMatrixIndexusvARB (GLint size, GLushort *indices) + void glMatrixIndexuivARB (GLint size, GLuint *indices) diff --git a/Externals/GLew/auto/core/GL_ARB_multitexture b/Externals/GLew/auto/core/GL_ARB_multitexture new file mode 100644 index 0000000000..ee80791831 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ARB_multitexture @@ -0,0 +1,72 @@ +GL_ARB_multitexture +http://oss.sgi.com/projects/ogl-sample/registry/ARB/multitexture.txt +GL_ARB_multitexture + GL_TEXTURE0_ARB 0x84C0 + GL_TEXTURE1_ARB 0x84C1 + GL_TEXTURE2_ARB 0x84C2 + GL_TEXTURE3_ARB 0x84C3 + GL_TEXTURE4_ARB 0x84C4 + GL_TEXTURE5_ARB 0x84C5 + GL_TEXTURE6_ARB 0x84C6 + GL_TEXTURE7_ARB 0x84C7 + GL_TEXTURE8_ARB 0x84C8 + GL_TEXTURE9_ARB 0x84C9 + GL_TEXTURE10_ARB 0x84CA + GL_TEXTURE11_ARB 0x84CB + GL_TEXTURE12_ARB 0x84CC + GL_TEXTURE13_ARB 0x84CD + GL_TEXTURE14_ARB 0x84CE + GL_TEXTURE15_ARB 0x84CF + GL_TEXTURE16_ARB 0x84D0 + GL_TEXTURE17_ARB 0x84D1 + GL_TEXTURE18_ARB 0x84D2 + GL_TEXTURE19_ARB 0x84D3 + GL_TEXTURE20_ARB 0x84D4 + GL_TEXTURE21_ARB 0x84D5 + GL_TEXTURE22_ARB 0x84D6 + GL_TEXTURE23_ARB 0x84D7 + GL_TEXTURE24_ARB 0x84D8 + GL_TEXTURE25_ARB 0x84D9 + GL_TEXTURE26_ARB 0x84DA + GL_TEXTURE27_ARB 0x84DB + GL_TEXTURE28_ARB 0x84DC + GL_TEXTURE29_ARB 0x84DD + GL_TEXTURE30_ARB 0x84DE + GL_TEXTURE31_ARB 0x84DF + GL_ACTIVE_TEXTURE_ARB 0x84E0 + GL_CLIENT_ACTIVE_TEXTURE_ARB 0x84E1 + GL_MAX_TEXTURE_UNITS_ARB 0x84E2 + void glActiveTextureARB (GLenum texture) + void glClientActiveTextureARB (GLenum texture) + void glMultiTexCoord1dARB (GLenum target, GLdouble s) + void glMultiTexCoord1dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord1fARB (GLenum target, GLfloat s) + void glMultiTexCoord1fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord1iARB (GLenum target, GLint s) + void glMultiTexCoord1ivARB (GLenum target, const GLint *v) + void glMultiTexCoord1sARB (GLenum target, GLshort s) + void glMultiTexCoord1svARB (GLenum target, const GLshort *v) + void glMultiTexCoord2dARB (GLenum target, GLdouble s, GLdouble t) + void glMultiTexCoord2dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord2fARB (GLenum target, GLfloat s, GLfloat t) + void glMultiTexCoord2fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord2iARB (GLenum target, GLint s, GLint t) + void glMultiTexCoord2ivARB (GLenum target, const GLint *v) + void glMultiTexCoord2sARB (GLenum target, GLshort s, GLshort t) + void glMultiTexCoord2svARB (GLenum target, const GLshort *v) + void glMultiTexCoord3dARB (GLenum target, GLdouble s, GLdouble t, GLdouble r) + void glMultiTexCoord3dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord3fARB (GLenum target, GLfloat s, GLfloat t, GLfloat r) + void glMultiTexCoord3fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord3iARB (GLenum target, GLint s, GLint t, GLint r) + void glMultiTexCoord3ivARB (GLenum target, const GLint *v) + void glMultiTexCoord3sARB (GLenum target, GLshort s, GLshort t, GLshort r) + void glMultiTexCoord3svARB (GLenum target, const GLshort *v) + void glMultiTexCoord4dARB (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q) + void glMultiTexCoord4dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord4fARB (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q) + void glMultiTexCoord4fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord4iARB (GLenum target, GLint s, GLint t, GLint r, GLint q) + void glMultiTexCoord4ivARB (GLenum target, const GLint *v) + void glMultiTexCoord4sARB (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q) + void glMultiTexCoord4svARB (GLenum target, const GLshort *v) diff --git a/Externals/GLew/auto/core/GL_ARB_vertex_blend b/Externals/GLew/auto/core/GL_ARB_vertex_blend new file mode 100644 index 0000000000..8da2c785b9 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ARB_vertex_blend @@ -0,0 +1,55 @@ +GL_ARB_vertex_blend +http://oss.sgi.com/projects/ogl-sample/registry/ARB/vertex_blend.txt +GL_ARB_vertex_blend + GL_MAX_VERTEX_UNITS_ARB 0x86A4 + GL_ACTIVE_VERTEX_UNITS_ARB 0x86A5 + GL_WEIGHT_SUM_UNITY_ARB 0x86A6 + GL_VERTEX_BLEND_ARB 0x86A7 + GL_CURRENT_WEIGHT_ARB 0x86A8 + GL_WEIGHT_ARRAY_TYPE_ARB 0x86A9 + GL_WEIGHT_ARRAY_STRIDE_ARB 0x86AA + GL_WEIGHT_ARRAY_SIZE_ARB 0x86AB + GL_WEIGHT_ARRAY_POINTER_ARB 0x86AC + GL_WEIGHT_ARRAY_ARB 0x86AD + GL_MODELVIEW0_ARB 0x1700 + GL_MODELVIEW1_ARB 0x850A + GL_MODELVIEW2_ARB 0x8722 + GL_MODELVIEW3_ARB 0x8723 + GL_MODELVIEW4_ARB 0x8724 + GL_MODELVIEW5_ARB 0x8725 + GL_MODELVIEW6_ARB 0x8726 + GL_MODELVIEW7_ARB 0x8727 + GL_MODELVIEW8_ARB 0x8728 + GL_MODELVIEW9_ARB 0x8729 + GL_MODELVIEW10_ARB 0x872A + GL_MODELVIEW11_ARB 0x872B + GL_MODELVIEW12_ARB 0x872C + GL_MODELVIEW13_ARB 0x872D + GL_MODELVIEW14_ARB 0x872E + GL_MODELVIEW15_ARB 0x872F + GL_MODELVIEW16_ARB 0x8730 + GL_MODELVIEW17_ARB 0x8731 + GL_MODELVIEW18_ARB 0x8732 + GL_MODELVIEW19_ARB 0x8733 + GL_MODELVIEW20_ARB 0x8734 + GL_MODELVIEW21_ARB 0x8735 + GL_MODELVIEW22_ARB 0x8736 + GL_MODELVIEW23_ARB 0x8737 + GL_MODELVIEW24_ARB 0x8738 + GL_MODELVIEW25_ARB 0x8739 + GL_MODELVIEW26_ARB 0x873A + GL_MODELVIEW27_ARB 0x873B + GL_MODELVIEW28_ARB 0x873C + GL_MODELVIEW29_ARB 0x873D + GL_MODELVIEW30_ARB 0x873E + GL_MODELVIEW31_ARB 0x873F + void glWeightbvARB (GLint size, GLbyte *weights) + void glWeightsvARB (GLint size, GLshort *weights) + void glWeightivARB (GLint size, GLint *weights) + void glWeightfvARB (GLint size, GLfloat *weights) + void glWeightdvARB (GLint size, GLdouble *weights) + void glWeightubvARB (GLint size, GLubyte *weights) + void glWeightusvARB (GLint size, GLushort *weights) + void glWeightuivARB (GLint size, GLuint *weights) + void glWeightPointerARB (GLint size, GLenum type, GLsizei stride, GLvoid *pointer) + void glVertexBlendARB (GLint count) diff --git a/Externals/GLew/auto/core/GL_ATIX_point_sprites b/Externals/GLew/auto/core/GL_ATIX_point_sprites new file mode 100644 index 0000000000..0f4f574131 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATIX_point_sprites @@ -0,0 +1,9 @@ +GL_ATIX_point_sprites +http://www.ati.com/developer/atiopengl.pdf +GL_ATIX_point_sprites + GL_TEXTURE_POINT_MODE_ATIX 0x60B0 + GL_TEXTURE_POINT_ONE_COORD_ATIX 0x60B1 + GL_TEXTURE_POINT_SPRITE_ATIX 0x60B2 + GL_POINT_SPRITE_CULL_MODE_ATIX 0x60B3 + GL_POINT_SPRITE_CULL_CENTER_ATIX 0x60B4 + GL_POINT_SPRITE_CULL_CLIP_ATIX 0x60B5 diff --git a/Externals/GLew/auto/core/GL_ATIX_texture_env_combine3 b/Externals/GLew/auto/core/GL_ATIX_texture_env_combine3 new file mode 100644 index 0000000000..537426b95d --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATIX_texture_env_combine3 @@ -0,0 +1,6 @@ +GL_ATIX_texture_env_combine3 +http://www.ati.com/developer/atiopengl.pdf +GL_ATIX_texture_env_combine3 + GL_MODULATE_ADD_ATIX 0x8744 + GL_MODULATE_SIGNED_ADD_ATIX 0x8745 + GL_MODULATE_SUBTRACT_ATIX 0x8746 diff --git a/Externals/GLew/auto/core/GL_ATIX_texture_env_route b/Externals/GLew/auto/core/GL_ATIX_texture_env_route new file mode 100644 index 0000000000..939ae09b95 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATIX_texture_env_route @@ -0,0 +1,6 @@ +GL_ATIX_texture_env_route +http://www.ati.com/developer/sdk/RadeonSDK/Html/Info/ATIX_texture_env_route.txt +GL_ATIX_texture_env_route + GL_SECONDARY_COLOR_ATIX 0x8747 + GL_TEXTURE_OUTPUT_RGB_ATIX 0x8748 + GL_TEXTURE_OUTPUT_ALPHA_ATIX 0x8749 diff --git a/Externals/GLew/auto/core/GL_ATIX_vertex_shader_output_point_size b/Externals/GLew/auto/core/GL_ATIX_vertex_shader_output_point_size new file mode 100644 index 0000000000..277a3136cb --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATIX_vertex_shader_output_point_size @@ -0,0 +1,4 @@ +GL_ATIX_vertex_shader_output_point_size +http://www.ati.com/developer/atiopengl.pdf +GL_ATIX_vertex_shader_output_point_size + GL_OUTPUT_POINT_SIZE_ATIX 0x610E diff --git a/Externals/GLew/auto/core/GL_ATI_envmap_bumpmap b/Externals/GLew/auto/core/GL_ATI_envmap_bumpmap new file mode 100644 index 0000000000..fbd992551e --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATI_envmap_bumpmap @@ -0,0 +1,15 @@ +GL_ATI_envmap_bumpmap +http://oss.sgi.com/projects/ogl-sample/registry/ATI/envmap_bumpmap.txt +GL_ATI_envmap_bumpmap + GL_BUMP_ROT_MATRIX_ATI 0x8775 + GL_BUMP_ROT_MATRIX_SIZE_ATI 0x8776 + GL_BUMP_NUM_TEX_UNITS_ATI 0x8777 + GL_BUMP_TEX_UNITS_ATI 0x8778 + GL_DUDV_ATI 0x8779 + GL_DU8DV8_ATI 0x877A + GL_BUMP_ENVMAP_ATI 0x877B + GL_BUMP_TARGET_ATI 0x877C + void glTexBumpParameterivATI (GLenum pname, GLint *param) + void glTexBumpParameterfvATI (GLenum pname, GLfloat *param) + void glGetTexBumpParameterivATI (GLenum pname, GLint *param) + void glGetTexBumpParameterfvATI (GLenum pname, GLfloat *param) diff --git a/Externals/GLew/auto/core/GL_ATI_map_object_buffer b/Externals/GLew/auto/core/GL_ATI_map_object_buffer new file mode 100644 index 0000000000..f360fa2adc --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATI_map_object_buffer @@ -0,0 +1,5 @@ +GL_ATI_map_object_buffer +http://www.ati.com/developer/sdk/RADEONSDK/Html/Info/ATI_map_object_buffer.txt +GL_ATI_map_object_buffer + void* glMapObjectBufferATI (GLuint buffer) + void glUnmapObjectBufferATI (GLuint buffer) diff --git a/Externals/GLew/auto/core/GL_ATI_pn_triangles b/Externals/GLew/auto/core/GL_ATI_pn_triangles new file mode 100644 index 0000000000..7b353b5352 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATI_pn_triangles @@ -0,0 +1,14 @@ +GL_ATI_pn_triangles +http://www.ati.com/developer/sdk/RADEONSDK/Html/Info/ati_pn_triangles.txt +GL_ATI_pn_triangles + GL_PN_TRIANGLES_ATI 0x87F0 + GL_MAX_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F1 + GL_PN_TRIANGLES_POINT_MODE_ATI 0x87F2 + GL_PN_TRIANGLES_NORMAL_MODE_ATI 0x87F3 + GL_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F4 + GL_PN_TRIANGLES_POINT_MODE_LINEAR_ATI 0x87F5 + GL_PN_TRIANGLES_POINT_MODE_CUBIC_ATI 0x87F6 + GL_PN_TRIANGLES_NORMAL_MODE_LINEAR_ATI 0x87F7 + GL_PN_TRIANGLES_NORMAL_MODE_QUADRATIC_ATI 0x87F8 + void glPNTrianglesiATI (GLenum pname, GLint param) + void glPNTrianglesfATI (GLenum pname, GLfloat param) diff --git a/Externals/GLew/auto/core/GL_ATI_separate_stencil b/Externals/GLew/auto/core/GL_ATI_separate_stencil new file mode 100644 index 0000000000..c4d82abba9 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATI_separate_stencil @@ -0,0 +1,9 @@ +GL_ATI_separate_stencil +http://www.ati.com/developer/sdk/RadeonSDK/Html/Info/ATI_separate_stencil.txt +GL_ATI_separate_stencil + GL_STENCIL_BACK_FUNC_ATI 0x8800 + GL_STENCIL_BACK_FAIL_ATI 0x8801 + GL_STENCIL_BACK_PASS_DEPTH_FAIL_ATI 0x8802 + GL_STENCIL_BACK_PASS_DEPTH_PASS_ATI 0x8803 + void glStencilOpSeparateATI (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass) + void glStencilFuncSeparateATI (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask) diff --git a/Externals/GLew/auto/core/GL_ATI_shader_texture_lod b/Externals/GLew/auto/core/GL_ATI_shader_texture_lod new file mode 100644 index 0000000000..5fbc624a6b --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATI_shader_texture_lod @@ -0,0 +1,3 @@ +GL_ATI_shader_texture_lod + +GL_ATI_shader_texture_lod diff --git a/Externals/GLew/auto/core/GL_ATI_texture_compression_3dc b/Externals/GLew/auto/core/GL_ATI_texture_compression_3dc new file mode 100644 index 0000000000..2548b30ead --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATI_texture_compression_3dc @@ -0,0 +1,4 @@ +GL_ATI_texture_compression_3dc + +GL_ATI_texture_compression_3dc + GL_COMPRESSED_LUMINANCE_ALPHA_3DC_ATI 0x8837 diff --git a/Externals/GLew/auto/core/GL_ATI_vertex_streams b/Externals/GLew/auto/core/GL_ATI_vertex_streams new file mode 100644 index 0000000000..56005f9c50 --- /dev/null +++ b/Externals/GLew/auto/core/GL_ATI_vertex_streams @@ -0,0 +1,50 @@ +GL_ATI_vertex_streams +http://www.ati.com/developer/sdk/RADEONSDK/Html/Info/ATI_vertex_streams.txt +GL_ATI_vertex_streams + GL_MAX_VERTEX_STREAMS_ATI 0x876B + GL_VERTEX_SOURCE_ATI 0x876C + GL_VERTEX_STREAM0_ATI 0x876D + GL_VERTEX_STREAM1_ATI 0x876E + GL_VERTEX_STREAM2_ATI 0x876F + GL_VERTEX_STREAM3_ATI 0x8770 + GL_VERTEX_STREAM4_ATI 0x8771 + GL_VERTEX_STREAM5_ATI 0x8772 + GL_VERTEX_STREAM6_ATI 0x8773 + GL_VERTEX_STREAM7_ATI 0x8774 + void glClientActiveVertexStreamATI (GLenum stream) + void glVertexBlendEnviATI (GLenum pname, GLint param) + void glVertexBlendEnvfATI (GLenum pname, GLfloat param) + void glVertexStream2sATI (GLenum stream, GLshort x, GLshort y) + void glVertexStream2svATI (GLenum stream, const GLshort *v) + void glVertexStream2iATI (GLenum stream, GLint x, GLint y) + void glVertexStream2ivATI (GLenum stream, const GLint *v) + void glVertexStream2fATI (GLenum stream, GLfloat x, GLfloat y) + void glVertexStream2fvATI (GLenum stream, const GLfloat *v) + void glVertexStream2dATI (GLenum stream, GLdouble x, GLdouble y) + void glVertexStream2dvATI (GLenum stream, const GLdouble *v) + void glVertexStream3sATI (GLenum stream, GLshort x, GLshort y, GLshort z) + void glVertexStream3svATI (GLenum stream, const GLshort *v) + void glVertexStream3iATI (GLenum stream, GLint x, GLint y, GLint z) + void glVertexStream3ivATI (GLenum stream, const GLint *v) + void glVertexStream3fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z) + void glVertexStream3fvATI (GLenum stream, const GLfloat *v) + void glVertexStream3dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z) + void glVertexStream3dvATI (GLenum stream, const GLdouble *v) + void glVertexStream4sATI (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w) + void glVertexStream4svATI (GLenum stream, const GLshort *v) + void glVertexStream4iATI (GLenum stream, GLint x, GLint y, GLint z, GLint w) + void glVertexStream4ivATI (GLenum stream, const GLint *v) + void glVertexStream4fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glVertexStream4fvATI (GLenum stream, const GLfloat *v) + void glVertexStream4dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glVertexStream4dvATI (GLenum stream, const GLdouble *v) + void glNormalStream3bATI (GLenum stream, GLbyte x, GLbyte y, GLbyte z) + void glNormalStream3bvATI (GLenum stream, const GLbyte *v) + void glNormalStream3sATI (GLenum stream, GLshort x, GLshort y, GLshort z) + void glNormalStream3svATI (GLenum stream, const GLshort *v) + void glNormalStream3iATI (GLenum stream, GLint x, GLint y, GLint z) + void glNormalStream3ivATI (GLenum stream, const GLint *v) + void glNormalStream3fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z) + void glNormalStream3fvATI (GLenum stream, const GLfloat *v) + void glNormalStream3dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z) + void glNormalStream3dvATI (GLenum stream, const GLdouble *v) diff --git a/Externals/GLew/auto/core/GL_EXT_Cg_shader b/Externals/GLew/auto/core/GL_EXT_Cg_shader new file mode 100644 index 0000000000..34d3152931 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_Cg_shader @@ -0,0 +1,5 @@ +GL_EXT_Cg_shader +http://download.nvidia.com/developer/GLSL/GLSL%20Release%20Notes%20for%20Release%2060.pdf +GL_EXT_Cg_shader + GL_CG_VERTEX_SHADER_EXT 0x890E + GL_CG_FRAGMENT_SHADER_EXT 0x890F diff --git a/Externals/GLew/auto/core/GL_EXT_bindable_uniform b/Externals/GLew/auto/core/GL_EXT_bindable_uniform new file mode 100644 index 0000000000..809123b659 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_bindable_uniform @@ -0,0 +1,12 @@ +GL_EXT_bindable_uniform +http://developer.download.nvidia.com/opengl/specs/GL_EXT_bindable_uniform.txt +GL_EXT_bindable_uniform + GL_MAX_VERTEX_BINDABLE_UNIFORMS_EXT 0x8DE2 + GL_MAX_FRAGMENT_BINDABLE_UNIFORMS_EXT 0x8DE3 + GL_MAX_GEOMETRY_BINDABLE_UNIFORMS_EXT 0x8DE4 + GL_MAX_BINDABLE_UNIFORM_SIZE_EXT 0x8DED + GL_UNIFORM_BUFFER_BINDING_EXT 0x8DEF + GL_UNIFORM_BUFFER_EXT 0x8DEE + void glUniformBufferEXT (GLuint program, GLint location, GLuint buffer) + GLint glGetUniformBufferSizeEXT (GLuint program, GLint location) + GLintptr glGetUniformOffsetEXT (GLuint program, GLint location) diff --git a/Externals/GLew/auto/core/GL_EXT_depth_bounds_test b/Externals/GLew/auto/core/GL_EXT_depth_bounds_test new file mode 100644 index 0000000000..62528b7b0c --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_depth_bounds_test @@ -0,0 +1,6 @@ +GL_EXT_depth_bounds_test +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_depth_bounds_test.txt +GL_EXT_depth_bounds_test + GL_DEPTH_BOUNDS_TEST_EXT 0x8890 + GL_DEPTH_BOUNDS_EXT 0x8891 + void glDepthBoundsEXT (GLclampd zmin, GLclampd zmax) diff --git a/Externals/GLew/auto/core/GL_EXT_draw_instanced b/Externals/GLew/auto/core/GL_EXT_draw_instanced new file mode 100644 index 0000000000..afafa27f3e --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_draw_instanced @@ -0,0 +1,5 @@ +GL_EXT_draw_instanced +http://developer.download.nvidia.com/opengl/specs/GL_EXT_draw_instanced.txt +GL_EXT_draw_instanced + void glDrawArraysInstancedEXT (GLenum mode, GLint start, GLsizei count, GLsizei primcount) + void glDrawElementsInstancedEXT (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount) diff --git a/Externals/GLew/auto/core/GL_EXT_draw_range_elements b/Externals/GLew/auto/core/GL_EXT_draw_range_elements new file mode 100644 index 0000000000..2abc870ba2 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_draw_range_elements @@ -0,0 +1,6 @@ +GL_EXT_draw_range_elements +http://oss.sgi.com/projects/ogl-sample/registry/EXT/draw_range_elements.txt +GL_EXT_draw_range_elements + GL_MAX_ELEMENTS_VERTICES 0x80E8 + GL_MAX_ELEMENTS_INDICES 0x80E9 + void glDrawRangeElementsEXT (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices) diff --git a/Externals/GLew/auto/core/GL_EXT_fog_coord b/Externals/GLew/auto/core/GL_EXT_fog_coord new file mode 100644 index 0000000000..ac7868aa32 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_fog_coord @@ -0,0 +1,16 @@ +GL_EXT_fog_coord +http://oss.sgi.com/projects/ogl-sample/registry/EXT/fog_coord.txt +GL_EXT_fog_coord + GL_FOG_COORDINATE_SOURCE_EXT 0x8450 + GL_FOG_COORDINATE_EXT 0x8451 + GL_FRAGMENT_DEPTH_EXT 0x8452 + GL_CURRENT_FOG_COORDINATE_EXT 0x8453 + GL_FOG_COORDINATE_ARRAY_TYPE_EXT 0x8454 + GL_FOG_COORDINATE_ARRAY_STRIDE_EXT 0x8455 + GL_FOG_COORDINATE_ARRAY_POINTER_EXT 0x8456 + GL_FOG_COORDINATE_ARRAY_EXT 0x8457 + void glFogCoordfEXT (GLfloat coord) + void glFogCoordfvEXT (const GLfloat *coord) + void glFogCoorddEXT (GLdouble coord) + void glFogCoorddvEXT (const GLdouble *coord) + void glFogCoordPointerEXT (GLenum type, GLsizei stride, const GLvoid *pointer) diff --git a/Externals/GLew/auto/core/GL_EXT_framebuffer_sRGB b/Externals/GLew/auto/core/GL_EXT_framebuffer_sRGB new file mode 100644 index 0000000000..4ca897b1fd --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_framebuffer_sRGB @@ -0,0 +1,5 @@ +GL_EXT_framebuffer_sRGB +http://developer.download.nvidia.com/opengl/specs/GL_EXT_framebuffer_sRGB.txt +GL_EXT_framebuffer_sRGB + GL_FRAMEBUFFER_SRGB_EXT 0x8DB9 + GL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x8DBA diff --git a/Externals/GLew/auto/core/GL_EXT_geometry_shader4 b/Externals/GLew/auto/core/GL_EXT_geometry_shader4 new file mode 100644 index 0000000000..888e500ae0 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_geometry_shader4 @@ -0,0 +1,27 @@ +GL_EXT_geometry_shader4 +http://developer.download.nvidia.com/opengl/specs/GL_EXT_geometry_shader4.txt +GL_EXT_geometry_shader4 + GL_GEOMETRY_SHADER_EXT 0x8DD9 + GL_MAX_GEOMETRY_VARYING_COMPONENTS_EXT 0x8DDD + GL_MAX_VERTEX_VARYING_COMPONENTS_EXT 0x8DDE + GL_MAX_VARYING_COMPONENTS_EXT 0x8B4B + GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_EXT 0x8DDF + GL_MAX_GEOMETRY_OUTPUT_VERTICES_EXT 0x8DE0 + GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_EXT 0x8DE1 + GL_GEOMETRY_VERTICES_OUT_EXT 0x8DDA + GL_GEOMETRY_INPUT_TYPE_EXT 0x8DDB + GL_GEOMETRY_OUTPUT_TYPE_EXT 0x8DDC + GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_EXT 0x8C29 + GL_LINES_ADJACENCY_EXT 0xA + GL_LINE_STRIP_ADJACENCY_EXT 0xB + GL_TRIANGLES_ADJACENCY_EXT 0xC + GL_TRIANGLE_STRIP_ADJACENCY_EXT 0xD + GL_FRAMEBUFFER_ATTACHMENT_LAYERED_EXT 0x8DA7 + GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_EXT 0x8DA8 + GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_EXT 0x8DA9 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER_EXT 0x8CD4 + GL_PROGRAM_POINT_SIZE_EXT 0x8642 + void glProgramParameteriEXT (GLuint program, GLenum pname, GLint value) + void glFramebufferTextureEXT (GLenum target, GLenum attachment, GLuint texture, GLint level) + void glFramebufferTextureLayerEXT (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer) + void glFramebufferTextureFaceEXT (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face) diff --git a/Externals/GLew/auto/core/GL_EXT_gpu_program_parameters b/Externals/GLew/auto/core/GL_EXT_gpu_program_parameters new file mode 100644 index 0000000000..9048c98d96 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_gpu_program_parameters @@ -0,0 +1,5 @@ +GL_EXT_gpu_program_parameters +http://developer.download.nvidia.com/opengl/specs/GL_EXT_gpu_program_parameters.txt +GL_EXT_gpu_program_parameters + void glProgramEnvParameters4fvEXT (GLenum target, GLuint index, GLsizei count, const GLfloat* params) + void glProgramLocalParameters4fvEXT (GLenum target, GLuint index, GLsizei count, const GLfloat* params) diff --git a/Externals/GLew/auto/core/GL_EXT_gpu_shader4 b/Externals/GLew/auto/core/GL_EXT_gpu_shader4 new file mode 100644 index 0000000000..0e89f0db06 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_gpu_shader4 @@ -0,0 +1,63 @@ +GL_EXT_gpu_shader4 +http://developer.download.nvidia.com/opengl/specs/GL_EXT_gpu_shader4.txt +GL_EXT_gpu_shader4 + GL_SAMPLER_1D_ARRAY_EXT 0x8DC0 + GL_SAMPLER_2D_ARRAY_EXT 0x8DC1 + GL_SAMPLER_BUFFER_EXT 0x8DC2 + GL_SAMPLER_1D_ARRAY_SHADOW_EXT 0x8DC3 + GL_SAMPLER_2D_ARRAY_SHADOW_EXT 0x8DC4 + GL_SAMPLER_CUBE_SHADOW_EXT 0x8DC5 + GL_UNSIGNED_INT_VEC2_EXT 0x8DC6 + GL_UNSIGNED_INT_VEC3_EXT 0x8DC7 + GL_UNSIGNED_INT_VEC4_EXT 0x8DC8 + GL_INT_SAMPLER_1D_EXT 0x8DC9 + GL_INT_SAMPLER_2D_EXT 0x8DCA + GL_INT_SAMPLER_3D_EXT 0x8DCB + GL_INT_SAMPLER_CUBE_EXT 0x8DCC + GL_INT_SAMPLER_2D_RECT_EXT 0x8DCD + GL_INT_SAMPLER_1D_ARRAY_EXT 0x8DCE + GL_INT_SAMPLER_2D_ARRAY_EXT 0x8DCF + GL_INT_SAMPLER_BUFFER_EXT 0x8DD0 + GL_UNSIGNED_INT_SAMPLER_1D_EXT 0x8DD1 + GL_UNSIGNED_INT_SAMPLER_2D_EXT 0x8DD2 + GL_UNSIGNED_INT_SAMPLER_3D_EXT 0x8DD3 + GL_UNSIGNED_INT_SAMPLER_CUBE_EXT 0x8DD4 + GL_UNSIGNED_INT_SAMPLER_2D_RECT_EXT 0x8DD5 + GL_UNSIGNED_INT_SAMPLER_1D_ARRAY_EXT 0x8DD6 + GL_UNSIGNED_INT_SAMPLER_2D_ARRAY_EXT 0x8DD7 + GL_UNSIGNED_INT_SAMPLER_BUFFER_EXT 0x8DD8 + GL_VERTEX_ATTRIB_ARRAY_INTEGER_EXT 0x88FD + void glGetUniformuivEXT (GLuint program, GLint location, GLuint *params) + void glBindFragDataLocationEXT (GLuint program, GLuint color, const GLchar *name) + GLint glGetFragDataLocationEXT (GLuint program, const GLchar *name) + void glUniform1uiEXT (GLint location, GLuint v0) + void glUniform2uiEXT (GLint location, GLuint v0, GLuint v1) + void glUniform3uiEXT (GLint location, GLuint v0, GLuint v1, GLuint v2) + void glUniform4uiEXT (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3) + void glUniform1uivEXT (GLint location, GLsizei count, const GLuint *value) + void glUniform2uivEXT (GLint location, GLsizei count, const GLuint *value) + void glUniform3uivEXT (GLint location, GLsizei count, const GLuint *value) + void glUniform4uivEXT (GLint location, GLsizei count, const GLuint *value) + void glVertexAttribI1iEXT (GLuint index, GLint x) + void glVertexAttribI2iEXT (GLuint index, GLint x, GLint y) + void glVertexAttribI3iEXT (GLuint index, GLint x, GLint y, GLint z) + void glVertexAttribI4iEXT (GLuint index, GLint x, GLint y, GLint z, GLint w) + void glVertexAttribI1uiEXT (GLuint index, GLuint x) + void glVertexAttribI2uiEXT (GLuint index, GLuint x, GLuint y) + void glVertexAttribI3uiEXT (GLuint index, GLuint x, GLuint y, GLuint z) + void glVertexAttribI4uiEXT (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w) + void glVertexAttribI1ivEXT (GLuint index, const GLint *v) + void glVertexAttribI2ivEXT (GLuint index, const GLint *v) + void glVertexAttribI3ivEXT (GLuint index, const GLint *v) + void glVertexAttribI4ivEXT (GLuint index, const GLint *v) + void glVertexAttribI1uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI2uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI3uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI4uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI4bvEXT (GLuint index, const GLbyte *v) + void glVertexAttribI4svEXT (GLuint index, const GLshort *v) + void glVertexAttribI4ubvEXT (GLuint index, const GLubyte *v) + void glVertexAttribI4usvEXT (GLuint index, const GLushort *v) + void glVertexAttribIPointerEXT (GLuint index, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer) + void glGetVertexAttribIivEXT (GLuint index, GLenum pname, GLint *params) + void glGetVertexAttribIuivEXT (GLuint index, GLenum pname, GLuint *params) diff --git a/Externals/GLew/auto/core/GL_EXT_packed_float b/Externals/GLew/auto/core/GL_EXT_packed_float new file mode 100644 index 0000000000..bcb22557d6 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_packed_float @@ -0,0 +1,6 @@ +GL_EXT_packed_float +http://developer.download.nvidia.com/opengl/specs/GL_EXT_packed_float.txt +GL_EXT_packed_float + GL_R11F_G11F_B10F_EXT 0x8C3A + GL_UNSIGNED_INT_10F_11F_11F_REV_EXT 0x8C3B + GL_RGBA_SIGNED_COMPONENTS_EXT 0x8C3C diff --git a/Externals/GLew/auto/core/GL_EXT_pixel_buffer_object b/Externals/GLew/auto/core/GL_EXT_pixel_buffer_object new file mode 100644 index 0000000000..a7f8f2c80e --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_pixel_buffer_object @@ -0,0 +1,7 @@ +GL_EXT_pixel_buffer_object +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_pixel_buffer_object.txt +GL_EXT_pixel_buffer_object + GL_PIXEL_PACK_BUFFER_EXT 0x88EB + GL_PIXEL_UNPACK_BUFFER_EXT 0x88EC + GL_PIXEL_PACK_BUFFER_BINDING_EXT 0x88ED + GL_PIXEL_UNPACK_BUFFER_BINDING_EXT 0x88EF diff --git a/Externals/GLew/auto/core/GL_EXT_secondary_color b/Externals/GLew/auto/core/GL_EXT_secondary_color new file mode 100644 index 0000000000..490dc64320 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_secondary_color @@ -0,0 +1,27 @@ +GL_EXT_secondary_color +http://oss.sgi.com/projects/ogl-sample/registry/EXT/secondary_color.txt +GL_EXT_secondary_color + GL_COLOR_SUM_EXT 0x8458 + GL_CURRENT_SECONDARY_COLOR_EXT 0x8459 + GL_SECONDARY_COLOR_ARRAY_SIZE_EXT 0x845A + GL_SECONDARY_COLOR_ARRAY_TYPE_EXT 0x845B + GL_SECONDARY_COLOR_ARRAY_STRIDE_EXT 0x845C + GL_SECONDARY_COLOR_ARRAY_POINTER_EXT 0x845D + GL_SECONDARY_COLOR_ARRAY_EXT 0x845E + void glSecondaryColor3bEXT (GLbyte red, GLbyte green, GLbyte blue) + void glSecondaryColor3bvEXT (const GLbyte *v) + void glSecondaryColor3dEXT (GLdouble red, GLdouble green, GLdouble blue) + void glSecondaryColor3dvEXT (const GLdouble *v) + void glSecondaryColor3fEXT (GLfloat red, GLfloat green, GLfloat blue) + void glSecondaryColor3fvEXT (const GLfloat *v) + void glSecondaryColor3iEXT (GLint red, GLint green, GLint blue) + void glSecondaryColor3ivEXT (const GLint *v) + void glSecondaryColor3sEXT (GLshort red, GLshort green, GLshort blue) + void glSecondaryColor3svEXT (const GLshort *v) + void glSecondaryColor3ubEXT (GLubyte red, GLubyte green, GLubyte blue) + void glSecondaryColor3ubvEXT (const GLubyte *v) + void glSecondaryColor3uiEXT (GLuint red, GLuint green, GLuint blue) + void glSecondaryColor3uivEXT (const GLuint *v) + void glSecondaryColor3usEXT (GLushort red, GLushort green, GLushort blue) + void glSecondaryColor3usvEXT (const GLushort *v) + void glSecondaryColorPointerEXT (GLint size, GLenum type, GLsizei stride, GLvoid *pointer) diff --git a/Externals/GLew/auto/core/GL_EXT_texture_array b/Externals/GLew/auto/core/GL_EXT_texture_array new file mode 100644 index 0000000000..f61e72ebc3 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_array @@ -0,0 +1,11 @@ +GL_EXT_texture_array +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_array.txt +GL_EXT_texture_array + GL_TEXTURE_1D_ARRAY_EXT 0x8C18 + GL_PROXY_TEXTURE_1D_ARRAY_EXT 0x8C19 + GL_TEXTURE_2D_ARRAY_EXT 0x8C1A + GL_PROXY_TEXTURE_2D_ARRAY_EXT 0x8C1B + GL_TEXTURE_BINDING_1D_ARRAY_EXT 0x8C1C + GL_TEXTURE_BINDING_2D_ARRAY_EXT 0x8C1D + GL_MAX_ARRAY_TEXTURE_LAYERS_EXT 0x88FF + GL_COMPARE_REF_DEPTH_TO_TEXTURE_EXT 0x884E diff --git a/Externals/GLew/auto/core/GL_EXT_texture_buffer_object b/Externals/GLew/auto/core/GL_EXT_texture_buffer_object new file mode 100644 index 0000000000..c00e1f3367 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_buffer_object @@ -0,0 +1,9 @@ +GL_EXT_texture_buffer_object +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_buffer_object.txt +GL_EXT_texture_buffer_object + GL_TEXTURE_BUFFER_EXT 0x8C2A + GL_MAX_TEXTURE_BUFFER_SIZE_EXT 0x8C2B + GL_TEXTURE_BINDING_BUFFER_EXT 0x8C2C + GL_TEXTURE_BUFFER_DATA_STORE_BINDING_EXT 0x8C2D + GL_TEXTURE_BUFFER_FORMAT_EXT 0x8C2E + void glTexBufferEXT (GLenum target, GLenum internalformat, GLuint buffer) diff --git a/Externals/GLew/auto/core/GL_EXT_texture_compression_latc b/Externals/GLew/auto/core/GL_EXT_texture_compression_latc new file mode 100644 index 0000000000..ddf8d26449 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_compression_latc @@ -0,0 +1,7 @@ +GL_EXT_texture_compression_latc +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_compression_latc.txt +GL_EXT_texture_compression_latc + GL_COMPRESSED_LUMINANCE_LATC1_EXT 0x8C70 + GL_COMPRESSED_SIGNED_LUMINANCE_LATC1_EXT 0x8C71 + GL_COMPRESSED_LUMINANCE_ALPHA_LATC2_EXT 0x8C72 + GL_COMPRESSED_SIGNED_LUMINANCE_ALPHA_LATC2_EXT 0x8C73 diff --git a/Externals/GLew/auto/core/GL_EXT_texture_compression_rgtc b/Externals/GLew/auto/core/GL_EXT_texture_compression_rgtc new file mode 100644 index 0000000000..7c5c57ff83 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_compression_rgtc @@ -0,0 +1,7 @@ +GL_EXT_texture_compression_rgtc +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_compression_rgtc.txt +GL_EXT_texture_compression_rgtc + GL_COMPRESSED_RED_RGTC1_EXT 0x8DBB + GL_COMPRESSED_SIGNED_RED_RGTC1_EXT 0x8DBC + GL_COMPRESSED_RED_GREEN_RGTC2_EXT 0x8DBD + GL_COMPRESSED_SIGNED_RED_GREEN_RGTC2_EXT 0x8DBE diff --git a/Externals/GLew/auto/core/GL_EXT_texture_cube_map b/Externals/GLew/auto/core/GL_EXT_texture_cube_map new file mode 100644 index 0000000000..5909f4803c --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_cube_map @@ -0,0 +1,15 @@ +GL_EXT_texture_cube_map +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_texture_cube_map.txt +GL_EXT_texture_cube_map + GL_NORMAL_MAP_EXT 0x8511 + GL_REFLECTION_MAP_EXT 0x8512 + GL_TEXTURE_CUBE_MAP_EXT 0x8513 + GL_TEXTURE_BINDING_CUBE_MAP_EXT 0x8514 + GL_TEXTURE_CUBE_MAP_POSITIVE_X_EXT 0x8515 + GL_TEXTURE_CUBE_MAP_NEGATIVE_X_EXT 0x8516 + GL_TEXTURE_CUBE_MAP_POSITIVE_Y_EXT 0x8517 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_EXT 0x8518 + GL_TEXTURE_CUBE_MAP_POSITIVE_Z_EXT 0x8519 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_EXT 0x851A + GL_PROXY_TEXTURE_CUBE_MAP_EXT 0x851B + GL_MAX_CUBE_MAP_TEXTURE_SIZE_EXT 0x851C diff --git a/Externals/GLew/auto/core/GL_EXT_texture_edge_clamp b/Externals/GLew/auto/core/GL_EXT_texture_edge_clamp new file mode 100644 index 0000000000..4df0997d74 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_edge_clamp @@ -0,0 +1,4 @@ +GL_EXT_texture_edge_clamp +http://www.opengl.org/developers/documentation/Version1.2/1.2specs/texture_edge_clamp.txt +GL_EXT_texture_edge_clamp + GL_CLAMP_TO_EDGE_EXT 0x812F diff --git a/Externals/GLew/auto/core/GL_EXT_texture_integer b/Externals/GLew/auto/core/GL_EXT_texture_integer new file mode 100644 index 0000000000..1c57e40d87 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_integer @@ -0,0 +1,56 @@ +GL_EXT_texture_integer +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_integer.txt +GL_EXT_texture_integer + GL_RGBA32UI_EXT 0x8D70 + GL_RGB32UI_EXT 0x8D71 + GL_ALPHA32UI_EXT 0x8D72 + GL_INTENSITY32UI_EXT 0x8D73 + GL_LUMINANCE32UI_EXT 0x8D74 + GL_LUMINANCE_ALPHA32UI_EXT 0x8D75 + GL_RGBA16UI_EXT 0x8D76 + GL_RGB16UI_EXT 0x8D77 + GL_ALPHA16UI_EXT 0x8D78 + GL_INTENSITY16UI_EXT 0x8D79 + GL_LUMINANCE16UI_EXT 0x8D7A + GL_LUMINANCE_ALPHA16UI_EXT 0x8D7B + GL_RGBA8UI_EXT 0x8D7C + GL_RGB8UI_EXT 0x8D7D + GL_ALPHA8UI_EXT 0x8D7E + GL_INTENSITY8UI_EXT 0x8D7F + GL_LUMINANCE8UI_EXT 0x8D80 + GL_LUMINANCE_ALPHA8UI_EXT 0x8D81 + GL_RGBA32I_EXT 0x8D82 + GL_RGB32I_EXT 0x8D83 + GL_ALPHA32I_EXT 0x8D84 + GL_INTENSITY32I_EXT 0x8D85 + GL_LUMINANCE32I_EXT 0x8D86 + GL_LUMINANCE_ALPHA32I_EXT 0x8D87 + GL_RGBA16I_EXT 0x8D88 + GL_RGB16I_EXT 0x8D89 + GL_ALPHA16I_EXT 0x8D8A + GL_INTENSITY16I_EXT 0x8D8B + GL_LUMINANCE16I_EXT 0x8D8C + GL_LUMINANCE_ALPHA16I_EXT 0x8D8D + GL_RGBA8I_EXT 0x8D8E + GL_RGB8I_EXT 0x8D8F + GL_ALPHA8I_EXT 0x8D90 + GL_INTENSITY8I_EXT 0x8D91 + GL_LUMINANCE8I_EXT 0x8D92 + GL_LUMINANCE_ALPHA8I_EXT 0x8D93 + GL_RED_INTEGER_EXT 0x8D94 + GL_GREEN_INTEGER_EXT 0x8D95 + GL_BLUE_INTEGER_EXT 0x8D96 + GL_ALPHA_INTEGER_EXT 0x8D97 + GL_RGB_INTEGER_EXT 0x8D98 + GL_RGBA_INTEGER_EXT 0x8D99 + GL_BGR_INTEGER_EXT 0x8D9A + GL_BGRA_INTEGER_EXT 0x8D9B + GL_LUMINANCE_INTEGER_EXT 0x8D9C + GL_LUMINANCE_ALPHA_INTEGER_EXT 0x8D9D + GL_RGBA_INTEGER_MODE_EXT 0x8D9E + void glTexParameterIivEXT (GLenum target, GLenum pname, const GLint *params) + void glTexParameterIuivEXT (GLenum target, GLenum pname, const GLuint *params) + void glGetTexParameterIivEXT (GLenum target, GLenum pname, GLint *params) + void glGetTexParameterIuivEXT (GLenum target, GLenum pname, GLuint *params) + void glClearColorIiEXT (GLint red, GLint green, GLint blue, GLint alpha) + void glClearColorIuiEXT (GLuint red, GLuint green, GLuint blue, GLuint alpha) diff --git a/Externals/GLew/auto/core/GL_EXT_texture_rectangle b/Externals/GLew/auto/core/GL_EXT_texture_rectangle new file mode 100644 index 0000000000..4028a9e671 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_rectangle @@ -0,0 +1,7 @@ +GL_EXT_texture_rectangle +http://developer.apple.com/opengl/extensions/ext_texture_rectangle.html +GL_EXT_texture_rectangle + GL_TEXTURE_RECTANGLE_EXT 0x84F5 + GL_TEXTURE_BINDING_RECTANGLE_EXT 0x84F6 + GL_PROXY_TEXTURE_RECTANGLE_EXT 0x84F7 + GL_MAX_RECTANGLE_TEXTURE_SIZE_EXT 0x84F8 diff --git a/Externals/GLew/auto/core/GL_EXT_texture_shared_exponent b/Externals/GLew/auto/core/GL_EXT_texture_shared_exponent new file mode 100644 index 0000000000..4ff7efcd35 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_texture_shared_exponent @@ -0,0 +1,6 @@ +GL_EXT_texture_shared_exponent +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_shared_exponent.txt +GL_EXT_texture_shared_exponent + GL_RGB9_E5_EXT 0x8C3D + GL_UNSIGNED_INT_5_9_9_9_REV_EXT 0x8C3E + GL_TEXTURE_SHARED_SIZE_EXT 0x8C3F diff --git a/Externals/GLew/auto/core/GL_EXT_timer_query b/Externals/GLew/auto/core/GL_EXT_timer_query new file mode 100644 index 0000000000..390e6fc0cd --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_timer_query @@ -0,0 +1,6 @@ +GL_EXT_timer_query +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_timer_query.txt +GL_EXT_timer_query + GL_TIME_ELAPSED_EXT 0x88BF + void glGetQueryObjecti64vEXT (GLuint id, GLenum pname, GLint64EXT *params) + void glGetQueryObjectui64vEXT (GLuint id, GLenum pname, GLuint64EXT *params) diff --git a/Externals/GLew/auto/core/GL_EXT_vertex_shader b/Externals/GLew/auto/core/GL_EXT_vertex_shader new file mode 100644 index 0000000000..eb125b6083 --- /dev/null +++ b/Externals/GLew/auto/core/GL_EXT_vertex_shader @@ -0,0 +1,156 @@ +GL_EXT_vertex_shader +http://oss.sgi.com/projects/ogl-sample/registry/EXT/vertex_shader.txt +GL_EXT_vertex_shader + GL_VERTEX_SHADER_EXT 0x8780 + GL_VERTEX_SHADER_BINDING_EXT 0x8781 + GL_OP_INDEX_EXT 0x8782 + GL_OP_NEGATE_EXT 0x8783 + GL_OP_DOT3_EXT 0x8784 + GL_OP_DOT4_EXT 0x8785 + GL_OP_MUL_EXT 0x8786 + GL_OP_ADD_EXT 0x8787 + GL_OP_MADD_EXT 0x8788 + GL_OP_FRAC_EXT 0x8789 + GL_OP_MAX_EXT 0x878A + GL_OP_MIN_EXT 0x878B + GL_OP_SET_GE_EXT 0x878C + GL_OP_SET_LT_EXT 0x878D + GL_OP_CLAMP_EXT 0x878E + GL_OP_FLOOR_EXT 0x878F + GL_OP_ROUND_EXT 0x8790 + GL_OP_EXP_BASE_2_EXT 0x8791 + GL_OP_LOG_BASE_2_EXT 0x8792 + GL_OP_POWER_EXT 0x8793 + GL_OP_RECIP_EXT 0x8794 + GL_OP_RECIP_SQRT_EXT 0x8795 + GL_OP_SUB_EXT 0x8796 + GL_OP_CROSS_PRODUCT_EXT 0x8797 + GL_OP_MULTIPLY_MATRIX_EXT 0x8798 + GL_OP_MOV_EXT 0x8799 + GL_OUTPUT_VERTEX_EXT 0x879A + GL_OUTPUT_COLOR0_EXT 0x879B + GL_OUTPUT_COLOR1_EXT 0x879C + GL_OUTPUT_TEXTURE_COORD0_EXT 0x879D + GL_OUTPUT_TEXTURE_COORD1_EXT 0x879E + GL_OUTPUT_TEXTURE_COORD2_EXT 0x879F + GL_OUTPUT_TEXTURE_COORD3_EXT 0x87A0 + GL_OUTPUT_TEXTURE_COORD4_EXT 0x87A1 + GL_OUTPUT_TEXTURE_COORD5_EXT 0x87A2 + GL_OUTPUT_TEXTURE_COORD6_EXT 0x87A3 + GL_OUTPUT_TEXTURE_COORD7_EXT 0x87A4 + GL_OUTPUT_TEXTURE_COORD8_EXT 0x87A5 + GL_OUTPUT_TEXTURE_COORD9_EXT 0x87A6 + GL_OUTPUT_TEXTURE_COORD10_EXT 0x87A7 + GL_OUTPUT_TEXTURE_COORD11_EXT 0x87A8 + GL_OUTPUT_TEXTURE_COORD12_EXT 0x87A9 + GL_OUTPUT_TEXTURE_COORD13_EXT 0x87AA + GL_OUTPUT_TEXTURE_COORD14_EXT 0x87AB + GL_OUTPUT_TEXTURE_COORD15_EXT 0x87AC + GL_OUTPUT_TEXTURE_COORD16_EXT 0x87AD + GL_OUTPUT_TEXTURE_COORD17_EXT 0x87AE + GL_OUTPUT_TEXTURE_COORD18_EXT 0x87AF + GL_OUTPUT_TEXTURE_COORD19_EXT 0x87B0 + GL_OUTPUT_TEXTURE_COORD20_EXT 0x87B1 + GL_OUTPUT_TEXTURE_COORD21_EXT 0x87B2 + GL_OUTPUT_TEXTURE_COORD22_EXT 0x87B3 + GL_OUTPUT_TEXTURE_COORD23_EXT 0x87B4 + GL_OUTPUT_TEXTURE_COORD24_EXT 0x87B5 + GL_OUTPUT_TEXTURE_COORD25_EXT 0x87B6 + GL_OUTPUT_TEXTURE_COORD26_EXT 0x87B7 + GL_OUTPUT_TEXTURE_COORD27_EXT 0x87B8 + GL_OUTPUT_TEXTURE_COORD28_EXT 0x87B9 + GL_OUTPUT_TEXTURE_COORD29_EXT 0x87BA + GL_OUTPUT_TEXTURE_COORD30_EXT 0x87BB + GL_OUTPUT_TEXTURE_COORD31_EXT 0x87BC + GL_OUTPUT_FOG_EXT 0x87BD + GL_SCALAR_EXT 0x87BE + GL_VECTOR_EXT 0x87BF + GL_MATRIX_EXT 0x87C0 + GL_VARIANT_EXT 0x87C1 + GL_INVARIANT_EXT 0x87C2 + GL_LOCAL_CONSTANT_EXT 0x87C3 + GL_LOCAL_EXT 0x87C4 + GL_MAX_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87C5 + GL_MAX_VERTEX_SHADER_VARIANTS_EXT 0x87C6 + GL_MAX_VERTEX_SHADER_INVARIANTS_EXT 0x87C7 + GL_MAX_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87C8 + GL_MAX_VERTEX_SHADER_LOCALS_EXT 0x87C9 + GL_MAX_OPTIMIZED_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CA + GL_MAX_OPTIMIZED_VERTEX_SHADER_VARIANTS_EXT 0x87CB + GL_MAX_OPTIMIZED_VERTEX_SHADER_INVARIANTS_EXT 0x87CC + GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87CD + GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCALS_EXT 0x87CE + GL_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CF + GL_VERTEX_SHADER_VARIANTS_EXT 0x87D0 + GL_VERTEX_SHADER_INVARIANTS_EXT 0x87D1 + GL_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87D2 + GL_VERTEX_SHADER_LOCALS_EXT 0x87D3 + GL_VERTEX_SHADER_OPTIMIZED_EXT 0x87D4 + GL_X_EXT 0x87D5 + GL_Y_EXT 0x87D6 + GL_Z_EXT 0x87D7 + GL_W_EXT 0x87D8 + GL_NEGATIVE_X_EXT 0x87D9 + GL_NEGATIVE_Y_EXT 0x87DA + GL_NEGATIVE_Z_EXT 0x87DB + GL_NEGATIVE_W_EXT 0x87DC + GL_ZERO_EXT 0x87DD + GL_ONE_EXT 0x87DE + GL_NEGATIVE_ONE_EXT 0x87DF + GL_NORMALIZED_RANGE_EXT 0x87E0 + GL_FULL_RANGE_EXT 0x87E1 + GL_CURRENT_VERTEX_EXT 0x87E2 + GL_MVP_MATRIX_EXT 0x87E3 + GL_VARIANT_VALUE_EXT 0x87E4 + GL_VARIANT_DATATYPE_EXT 0x87E5 + GL_VARIANT_ARRAY_STRIDE_EXT 0x87E6 + GL_VARIANT_ARRAY_TYPE_EXT 0x87E7 + GL_VARIANT_ARRAY_EXT 0x87E8 + GL_VARIANT_ARRAY_POINTER_EXT 0x87E9 + GL_INVARIANT_VALUE_EXT 0x87EA + GL_INVARIANT_DATATYPE_EXT 0x87EB + GL_LOCAL_CONSTANT_VALUE_EXT 0x87EC + GL_LOCAL_CONSTANT_DATATYPE_EXT 0x87ED + + void glBeginVertexShaderEXT (void) + void glEndVertexShaderEXT (void) + void glBindVertexShaderEXT (GLuint id) + GLuint glGenVertexShadersEXT (GLuint range) + void glDeleteVertexShaderEXT (GLuint id) + void glShaderOp1EXT (GLenum op, GLuint res, GLuint arg1) + void glShaderOp2EXT (GLenum op, GLuint res, GLuint arg1, GLuint arg2) + void glShaderOp3EXT (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3) + void glSwizzleEXT (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW) + void glWriteMaskEXT (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW) + void glInsertComponentEXT (GLuint res, GLuint src, GLuint num) + void glExtractComponentEXT (GLuint res, GLuint src, GLuint num) + GLuint glGenSymbolsEXT (GLenum dataType, GLenum storageType, GLenum range, GLuint components) + void glSetInvariantEXT (GLuint id, GLenum type, GLvoid *addr) + void glSetLocalConstantEXT (GLuint id, GLenum type, GLvoid *addr) + void glVariantbvEXT (GLuint id, GLbyte *addr) + void glVariantsvEXT (GLuint id, GLshort *addr) + void glVariantivEXT (GLuint id, GLint *addr) + void glVariantfvEXT (GLuint id, GLfloat *addr) + void glVariantdvEXT (GLuint id, GLdouble *addr) + void glVariantubvEXT (GLuint id, GLubyte *addr) + void glVariantusvEXT (GLuint id, GLushort *addr) + void glVariantuivEXT (GLuint id, GLuint *addr) + void glVariantPointerEXT (GLuint id, GLenum type, GLuint stride, GLvoid *addr) + void glEnableVariantClientStateEXT (GLuint id) + void glDisableVariantClientStateEXT (GLuint id) + GLuint glBindLightParameterEXT (GLenum light, GLenum value) + GLuint glBindMaterialParameterEXT (GLenum face, GLenum value) + GLuint glBindTexGenParameterEXT (GLenum unit, GLenum coord, GLenum value) + GLuint glBindTextureUnitParameterEXT (GLenum unit, GLenum value) + GLuint glBindParameterEXT (GLenum value) + GLboolean glIsVariantEnabledEXT (GLuint id, GLenum cap) + void glGetVariantBooleanvEXT (GLuint id, GLenum value, GLboolean *data) + void glGetVariantIntegervEXT (GLuint id, GLenum value, GLint *data) + void glGetVariantFloatvEXT (GLuint id, GLenum value, GLfloat *data) + void glGetVariantPointervEXT (GLuint id, GLenum value, GLvoid **data) + void glGetInvariantBooleanvEXT (GLuint id, GLenum value, GLboolean *data) + void glGetInvariantIntegervEXT (GLuint id, GLenum value, GLint *data) + void glGetInvariantFloatvEXT (GLuint id, GLenum value, GLfloat *data) + void glGetLocalConstantBooleanvEXT (GLuint id, GLenum value, GLboolean *data) + void glGetLocalConstantIntegervEXT (GLuint id, GLenum value, GLint *data) + void glGetLocalConstantFloatvEXT (GLuint id, GLenum value, GLfloat *data) diff --git a/Externals/GLew/auto/core/GL_KTX_buffer_region b/Externals/GLew/auto/core/GL_KTX_buffer_region new file mode 100644 index 0000000000..22a59d3be3 --- /dev/null +++ b/Externals/GLew/auto/core/GL_KTX_buffer_region @@ -0,0 +1,12 @@ +GL_KTX_buffer_region + +GL_KTX_buffer_region + GL_KTX_FRONT_REGION 0x0 + GL_KTX_BACK_REGION 0x1 + GL_KTX_Z_REGION 0x2 + GL_KTX_STENCIL_REGION 0x3 + GLuint glBufferRegionEnabledEXT (void) + GLuint glNewBufferRegionEXT (GLenum region) + void glDeleteBufferRegionEXT (GLenum region) + void glReadBufferRegionEXT (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height) + void glDrawBufferRegionEXT (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height, GLint xDest, GLint yDest) diff --git a/Externals/GLew/auto/core/GL_NV_depth_buffer_float b/Externals/GLew/auto/core/GL_NV_depth_buffer_float new file mode 100644 index 0000000000..493b245589 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_depth_buffer_float @@ -0,0 +1,10 @@ +GL_NV_depth_buffer_float +http://developer.download.nvidia.com/opengl/specs/GL_NV_depth_buffer_float.txt +GL_NV_depth_buffer_float + GL_DEPTH_COMPONENT32F_NV 0x8DAB + GL_DEPTH32F_STENCIL8_NV 0x8DAC + GL_FLOAT_32_UNSIGNED_INT_24_8_REV_NV 0x8DAD + GL_DEPTH_BUFFER_FLOAT_MODE_NV 0x8DAF + void glDepthRangedNV (GLdouble zNear, GLdouble zFar) + void glClearDepthdNV (GLdouble depth) + void glDepthBoundsdNV (GLdouble zmin, GLdouble zmax) diff --git a/Externals/GLew/auto/core/GL_NV_depth_range_unclamped b/Externals/GLew/auto/core/GL_NV_depth_range_unclamped new file mode 100644 index 0000000000..62b4e59fa7 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_depth_range_unclamped @@ -0,0 +1,8 @@ +GL_NV_depth_range_unclamped + +GL_NV_depth_range_unclamped + GL_SAMPLE_COUNT_BITS_NV 0x8864 + GL_CURRENT_SAMPLE_COUNT_QUERY_NV 0x8865 + GL_QUERY_RESULT_NV 0x8866 + GL_QUERY_RESULT_AVAILABLE_NV 0x8867 + GL_SAMPLE_COUNT_NV 0x8914 diff --git a/Externals/GLew/auto/core/GL_NV_fragment_program2 b/Externals/GLew/auto/core/GL_NV_fragment_program2 new file mode 100644 index 0000000000..7fb59eea1b --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_fragment_program2 @@ -0,0 +1,8 @@ +GL_NV_fragment_program2 +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_fragment_program2.txt +GL_NV_fragment_program2 + GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 + GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 + GL_MAX_PROGRAM_IF_DEPTH_NV 0x88F6 + GL_MAX_PROGRAM_LOOP_DEPTH_NV 0x88F7 + GL_MAX_PROGRAM_LOOP_COUNT_NV 0x88F8 diff --git a/Externals/GLew/auto/core/GL_NV_fragment_program4 b/Externals/GLew/auto/core/GL_NV_fragment_program4 new file mode 100644 index 0000000000..0ae2598795 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_fragment_program4 @@ -0,0 +1,3 @@ +GL_NV_fragment_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_fragment_program4.txt +GL_NV_gpu_program4 diff --git a/Externals/GLew/auto/core/GL_NV_fragment_program_option b/Externals/GLew/auto/core/GL_NV_fragment_program_option new file mode 100644 index 0000000000..7af9731bd8 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_fragment_program_option @@ -0,0 +1,3 @@ +GL_NV_fragment_program_option +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_fragment_program_option.txt +GL_NV_fragment_program_option diff --git a/Externals/GLew/auto/core/GL_NV_framebuffer_multisample_coverage b/Externals/GLew/auto/core/GL_NV_framebuffer_multisample_coverage new file mode 100644 index 0000000000..d1d066056c --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_framebuffer_multisample_coverage @@ -0,0 +1,8 @@ +GL_NV_framebuffer_multisample_coverage +http://developer.download.nvidia.com/opengl/specs/GL_NV_framebuffer_multisample_coverage.txt +GL_NV_framebuffer_multisample_coverage + GL_RENDERBUFFER_COVERAGE_SAMPLES_NV 0x8CAB + GL_RENDERBUFFER_COLOR_SAMPLES_NV 0x8E10 + GL_MAX_MULTISAMPLE_COVERAGE_MODES_NV 0x8E11 + GL_MULTISAMPLE_COVERAGE_MODES_NV 0x8E12 + void glRenderbufferStorageMultisampleCoverageNV (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/core/GL_NV_geometry_program4 b/Externals/GLew/auto/core/GL_NV_geometry_program4 new file mode 100644 index 0000000000..3f82b195d3 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_geometry_program4 @@ -0,0 +1,7 @@ +GL_NV_geometry_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_geometry_program4.txt +GL_NV_gpu_program4 + GL_GEOMETRY_PROGRAM_NV 0x8C26 + GL_MAX_PROGRAM_OUTPUT_VERTICES_NV 0x8C27 + GL_MAX_PROGRAM_TOTAL_OUTPUT_COMPONENTS_NV 0x8C28 + void glProgramVertexLimitNV (GLenum target, GLint limit) diff --git a/Externals/GLew/auto/core/GL_NV_geometry_shader4 b/Externals/GLew/auto/core/GL_NV_geometry_shader4 new file mode 100644 index 0000000000..2040c0dbb3 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_geometry_shader4 @@ -0,0 +1,3 @@ +GL_NV_geometry_shader4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_geometry_shader4.txt +GL_NV_geometry_shader4 diff --git a/Externals/GLew/auto/core/GL_NV_gpu_program4 b/Externals/GLew/auto/core/GL_NV_gpu_program4 new file mode 100644 index 0000000000..030f68e1cc --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_gpu_program4 @@ -0,0 +1,23 @@ +GL_NV_gpu_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_gpu_program4.txt +GL_NV_gpu_program4 + GL_MIN_PROGRAM_TEXEL_OFFSET_NV 0x8904 + GL_MAX_PROGRAM_TEXEL_OFFSET_NV 0x8905 + GL_PROGRAM_ATTRIB_COMPONENTS_NV 0x8906 + GL_PROGRAM_RESULT_COMPONENTS_NV 0x8907 + GL_MAX_PROGRAM_ATTRIB_COMPONENTS_NV 0x8908 + GL_MAX_PROGRAM_RESULT_COMPONENTS_NV 0x8909 + GL_MAX_PROGRAM_GENERIC_ATTRIBS_NV 0x8DA5 + GL_MAX_PROGRAM_GENERIC_RESULTS_NV 0x8DA6 + void glProgramLocalParameterI4iNV (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w) + void glProgramLocalParameterI4ivNV (GLenum target, GLuint index, const GLint *params) + void glProgramLocalParametersI4ivNV (GLenum target, GLuint index, GLsizei count, const GLint *params) + void glProgramLocalParameterI4uiNV (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w) + void glProgramLocalParameterI4uivNV (GLenum target, GLuint index, const GLuint *params) + void glProgramLocalParametersI4uivNV (GLenum target, GLuint index, GLsizei count, const GLuint *params) + void glProgramEnvParameterI4iNV (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w) + void glProgramEnvParameterI4ivNV (GLenum target, GLuint index, const GLint *params) + void glProgramEnvParametersI4ivNV (GLenum target, GLuint index, GLsizei count, const GLint *params) + void glProgramEnvParameterI4uiNV (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w) + void glProgramEnvParameterI4uivNV (GLenum target, GLuint index, const GLuint *params) + void glProgramEnvParametersI4uivNV (GLenum target, GLuint index, GLsizei count, const GLuint *params) diff --git a/Externals/GLew/auto/core/GL_NV_parameter_buffer_object b/Externals/GLew/auto/core/GL_NV_parameter_buffer_object new file mode 100644 index 0000000000..d2525a1766 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_parameter_buffer_object @@ -0,0 +1,11 @@ +GL_NV_parameter_buffer_object +http://developer.download.nvidia.com/opengl/specs/GL_NV_parameter_buffer_object.txt +GL_NV_parameter_buffer_object + GL_VERTEX_PROGRAM_PARAMETER_BUFFER_NV 0x8DA2 + GL_GEOMETRY_PROGRAM_PARAMETER_BUFFER_NV 0x8DA3 + GL_FRAGMENT_PROGRAM_PARAMETER_BUFFER_NV 0x8DA4 + GL_MAX_PROGRAM_PARAMETER_BUFFER_BINDINGS_NV 0x8DA0 + GL_MAX_PROGRAM_PARAMETER_BUFFER_SIZE_NV 0x8DA1 + void glProgramBufferParametersfvNV (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLfloat *params) + void glProgramBufferParametersIivNV (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLint *params) + void glProgramBufferParametersIuivNV (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLuint *params) diff --git a/Externals/GLew/auto/core/GL_NV_present_video b/Externals/GLew/auto/core/GL_NV_present_video new file mode 100644 index 0000000000..893c74c8e9 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_present_video @@ -0,0 +1,15 @@ +GL_NV_present_video +http://www.opengl.org/registry/specs/NV/present_video.txt +GL_NV_present_video + GL_FRAME_NV 0x8E26 + GL_FIELDS_NV 0x8E27 + GL_CURRENT_TIME_NV 0x8E28 + GL_NUM_FILL_STREAMS_NV 0x8E29 + GL_PRESENT_TIME_NV 0x8E2A + GL_PRESENT_DURATION_NV 0x8E2B + void glGetVideoi64vNV (GLuint video_slot, GLenum pname, GLint64EXT* params) + void glGetVideoivNV (GLuint video_slot, GLenum pname, GLint* params) + void glGetVideoui64vNV (GLuint video_slot, GLenum pname, GLuint64EXT* params) + void glGetVideouivNV (GLuint video_slot, GLenum pname, GLuint* params) + void glPresentFrameDualFillNV (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLenum target1, GLuint fill1, GLenum target2, GLuint fill2, GLenum target3, GLuint fill3) + void glPresentFrameKeyedNV (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLuint key0, GLenum target1, GLuint fill1, GLuint key1) diff --git a/Externals/GLew/auto/core/GL_NV_tessellation_program5 b/Externals/GLew/auto/core/GL_NV_tessellation_program5 new file mode 100644 index 0000000000..b663c974dc --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_tessellation_program5 @@ -0,0 +1,8 @@ +GL_NV_tessellation_program5 +http://www.opengl.org/registry/specs/NV/tessellation_program5.txt +GL_NV_gpu_program5 + GL_MAX_PROGRAM_PATCH_ATTRIBS_NV 0x86D8 + GL_TESS_CONTROL_PROGRAM_NV 0x891E + GL_TESS_EVALUATION_PROGRAM_NV 0x891F + GL_TESS_CONTROL_PROGRAM_PARAMETER_BUFFER_NV 0x8C74 + GL_TESS_EVALUATION_PROGRAM_PARAMETER_BUFFER_NV 0x8C75 diff --git a/Externals/GLew/auto/core/GL_NV_transform_feedback b/Externals/GLew/auto/core/GL_NV_transform_feedback new file mode 100644 index 0000000000..fce47571e8 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_transform_feedback @@ -0,0 +1,39 @@ +GL_NV_transform_feedback +http://developer.download.nvidia.com/opengl/specs/GL_NV_transform_feedback.txt +GL_NV_transform_feedback + GL_BACK_PRIMARY_COLOR_NV 0x8C77 + GL_BACK_SECONDARY_COLOR_NV 0x8C78 + GL_TEXTURE_COORD_NV 0x8C79 + GL_CLIP_DISTANCE_NV 0x8C7A + GL_VERTEX_ID_NV 0x8C7B + GL_PRIMITIVE_ID_NV 0x8C7C + GL_GENERIC_ATTRIB_NV 0x8C7D + GL_TRANSFORM_FEEDBACK_ATTRIBS_NV 0x8C7E + GL_TRANSFORM_FEEDBACK_BUFFER_MODE_NV 0x8C7F + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_NV 0x8C80 + GL_ACTIVE_VARYINGS_NV 0x8C81 + GL_ACTIVE_VARYING_MAX_LENGTH_NV 0x8C82 + GL_TRANSFORM_FEEDBACK_VARYINGS_NV 0x8C83 + GL_TRANSFORM_FEEDBACK_BUFFER_START_NV 0x8C84 + GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_NV 0x8C85 + GL_TRANSFORM_FEEDBACK_RECORD_NV 0x8C86 + GL_PRIMITIVES_GENERATED_NV 0x8C87 + GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_NV 0x8C88 + GL_RASTERIZER_DISCARD_NV 0x8C89 + GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_NV 0x8C8A + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_NV 0x8C8B + GL_INTERLEAVED_ATTRIBS_NV 0x8C8C + GL_SEPARATE_ATTRIBS_NV 0x8C8D + GL_TRANSFORM_FEEDBACK_BUFFER_NV 0x8C8E + GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_NV 0x8C8F + void glBeginTransformFeedbackNV (GLenum primitiveMode) + void glEndTransformFeedbackNV (void) + void glTransformFeedbackAttribsNV (GLuint count, const GLint *attribs, GLenum bufferMode) + void glBindBufferRangeNV (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size) + void glBindBufferOffsetNV (GLenum target, GLuint index, GLuint buffer, GLintptr offset) + void glBindBufferBaseNV (GLenum target, GLuint index, GLuint buffer) + void glTransformFeedbackVaryingsNV (GLuint program, GLsizei count, const GLint *locations, GLenum bufferMode) + void glActiveVaryingNV (GLuint program, const GLchar *name) + GLint glGetVaryingLocationNV (GLuint program, const GLchar *name) + void glGetActiveVaryingNV (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name) + void glGetTransformFeedbackVaryingNV (GLuint program, GLuint index, GLint *location) diff --git a/Externals/GLew/auto/core/GL_NV_vertex_program2_option b/Externals/GLew/auto/core/GL_NV_vertex_program2_option new file mode 100644 index 0000000000..1fecc4c040 --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_vertex_program2_option @@ -0,0 +1,5 @@ +GL_NV_vertex_program2_option +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_vertex_program2_option.txt +GL_NV_vertex_program2_option + GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 + GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 diff --git a/Externals/GLew/auto/core/GL_NV_vertex_program3 b/Externals/GLew/auto/core/GL_NV_vertex_program3 new file mode 100644 index 0000000000..6510e0649c --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_vertex_program3 @@ -0,0 +1,4 @@ +GL_NV_vertex_program3 +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_vertex_program3.txt +GL_NV_vertex_program3 + MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C diff --git a/Externals/GLew/auto/core/GL_NV_vertex_program4 b/Externals/GLew/auto/core/GL_NV_vertex_program4 new file mode 100644 index 0000000000..7e61b3a95d --- /dev/null +++ b/Externals/GLew/auto/core/GL_NV_vertex_program4 @@ -0,0 +1,3 @@ +GL_NV_vertex_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_vertex_program4.txt +GL_NV_gpu_program4 diff --git a/Externals/GLew/auto/core/GL_SGIX_shadow b/Externals/GLew/auto/core/GL_SGIX_shadow new file mode 100644 index 0000000000..2b34cc83a9 --- /dev/null +++ b/Externals/GLew/auto/core/GL_SGIX_shadow @@ -0,0 +1,7 @@ +GL_SGIX_shadow +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/shadow.txt +GL_SGIX_shadow + GL_TEXTURE_COMPARE_SGIX 0x819A + GL_TEXTURE_COMPARE_OPERATOR_SGIX 0x819B + GL_TEXTURE_LEQUAL_R_SGIX 0x819C + GL_TEXTURE_GEQUAL_R_SGIX 0x819D diff --git a/Externals/GLew/auto/core/GL_SUN_read_video_pixels b/Externals/GLew/auto/core/GL_SUN_read_video_pixels new file mode 100644 index 0000000000..faa55f972c --- /dev/null +++ b/Externals/GLew/auto/core/GL_SUN_read_video_pixels @@ -0,0 +1,4 @@ +GL_SUN_read_video_pixels +http://wwws.sun.com/software/graphics/opengl/extensions/gl_sun_read_video_pixels.txt +GL_SUN_read_video_pixels + void glReadVideoPixelsSUN (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid* pixels) diff --git a/Externals/GLew/auto/core/GL_VERSION_1_2 b/Externals/GLew/auto/core/GL_VERSION_1_2 new file mode 100644 index 0000000000..fb5505427c --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_1_2 @@ -0,0 +1,48 @@ +GL_VERSION_1_2 +http://www.opengl.org/documentation/specs/version1.2/opengl1.2.1.pdf + + GL_UNSIGNED_BYTE_3_3_2 0x8032 + GL_UNSIGNED_SHORT_4_4_4_4 0x8033 + GL_UNSIGNED_SHORT_5_5_5_1 0x8034 + GL_UNSIGNED_INT_8_8_8_8 0x8035 + GL_UNSIGNED_INT_10_10_10_2 0x8036 + GL_RESCALE_NORMAL 0x803A + GL_UNSIGNED_BYTE_2_3_3_REV 0x8362 + GL_UNSIGNED_SHORT_5_6_5 0x8363 + GL_UNSIGNED_SHORT_5_6_5_REV 0x8364 + GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 + GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 + GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 + GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 + GL_BGR 0x80E0 + GL_BGRA 0x80E1 + GL_MAX_ELEMENTS_VERTICES 0x80E8 + GL_MAX_ELEMENTS_INDICES 0x80E9 + GL_CLAMP_TO_EDGE 0x812F + GL_TEXTURE_MIN_LOD 0x813A + GL_TEXTURE_MAX_LOD 0x813B + GL_TEXTURE_BASE_LEVEL 0x813C + GL_TEXTURE_MAX_LEVEL 0x813D + GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 + GL_SINGLE_COLOR 0x81F9 + GL_SEPARATE_SPECULAR_COLOR 0x81FA + GL_SMOOTH_POINT_SIZE_RANGE 0x0B12 + GL_SMOOTH_POINT_SIZE_GRANULARITY 0x0B13 + GL_SMOOTH_LINE_WIDTH_RANGE 0x0B22 + GL_SMOOTH_LINE_WIDTH_GRANULARITY 0x0B23 + GL_ALIASED_POINT_SIZE_RANGE 0x846D + GL_ALIASED_LINE_WIDTH_RANGE 0x846E + GL_PACK_SKIP_IMAGES 0x806B + GL_PACK_IMAGE_HEIGHT 0x806C + GL_UNPACK_SKIP_IMAGES 0x806D + GL_UNPACK_IMAGE_HEIGHT 0x806E + GL_TEXTURE_3D 0x806F + GL_PROXY_TEXTURE_3D 0x8070 + GL_TEXTURE_DEPTH 0x8071 + GL_TEXTURE_WRAP_R 0x8072 + GL_MAX_3D_TEXTURE_SIZE 0x8073 + GL_TEXTURE_BINDING_3D 0x806A + void glDrawRangeElements (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices) + void glTexImage3D (GLenum target, GLint level, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels) + void glTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels) + void glCopyTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/core/GL_VERSION_1_3 b/Externals/GLew/auto/core/GL_VERSION_1_3 new file mode 100644 index 0000000000..737ad7c0d3 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_1_3 @@ -0,0 +1,146 @@ +GL_VERSION_1_3 +http://www.opengl.org/documentation/specs/version1.3/glspec13.pdf + + GL_TEXTURE0 0x84C0 + GL_TEXTURE1 0x84C1 + GL_TEXTURE2 0x84C2 + GL_TEXTURE3 0x84C3 + GL_TEXTURE4 0x84C4 + GL_TEXTURE5 0x84C5 + GL_TEXTURE6 0x84C6 + GL_TEXTURE7 0x84C7 + GL_TEXTURE8 0x84C8 + GL_TEXTURE9 0x84C9 + GL_TEXTURE10 0x84CA + GL_TEXTURE11 0x84CB + GL_TEXTURE12 0x84CC + GL_TEXTURE13 0x84CD + GL_TEXTURE14 0x84CE + GL_TEXTURE15 0x84CF + GL_TEXTURE16 0x84D0 + GL_TEXTURE17 0x84D1 + GL_TEXTURE18 0x84D2 + GL_TEXTURE19 0x84D3 + GL_TEXTURE20 0x84D4 + GL_TEXTURE21 0x84D5 + GL_TEXTURE22 0x84D6 + GL_TEXTURE23 0x84D7 + GL_TEXTURE24 0x84D8 + GL_TEXTURE25 0x84D9 + GL_TEXTURE26 0x84DA + GL_TEXTURE27 0x84DB + GL_TEXTURE28 0x84DC + GL_TEXTURE29 0x84DD + GL_TEXTURE30 0x84DE + GL_TEXTURE31 0x84DF + GL_ACTIVE_TEXTURE 0x84E0 + GL_CLIENT_ACTIVE_TEXTURE 0x84E1 + GL_MAX_TEXTURE_UNITS 0x84E2 + GL_NORMAL_MAP 0x8511 + GL_REFLECTION_MAP 0x8512 + GL_TEXTURE_CUBE_MAP 0x8513 + GL_TEXTURE_BINDING_CUBE_MAP 0x8514 + GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x8515 + GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x8516 + GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x8517 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x8518 + GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x8519 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x851A + GL_PROXY_TEXTURE_CUBE_MAP 0x851B + GL_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C + GL_COMPRESSED_ALPHA 0x84E9 + GL_COMPRESSED_LUMINANCE 0x84EA + GL_COMPRESSED_LUMINANCE_ALPHA 0x84EB + GL_COMPRESSED_INTENSITY 0x84EC + GL_COMPRESSED_RGB 0x84ED + GL_COMPRESSED_RGBA 0x84EE + GL_TEXTURE_COMPRESSION_HINT 0x84EF + GL_TEXTURE_COMPRESSED_IMAGE_SIZE 0x86A0 + GL_TEXTURE_COMPRESSED 0x86A1 + GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 + GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 + GL_MULTISAMPLE 0x809D + GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E + GL_SAMPLE_ALPHA_TO_ONE 0x809F + GL_SAMPLE_COVERAGE 0x80A0 + GL_SAMPLE_BUFFERS 0x80A8 + GL_SAMPLES 0x80A9 + GL_SAMPLE_COVERAGE_VALUE 0x80AA + GL_SAMPLE_COVERAGE_INVERT 0x80AB + GL_MULTISAMPLE_BIT 0x20000000 + GL_TRANSPOSE_MODELVIEW_MATRIX 0x84E3 + GL_TRANSPOSE_PROJECTION_MATRIX 0x84E4 + GL_TRANSPOSE_TEXTURE_MATRIX 0x84E5 + GL_TRANSPOSE_COLOR_MATRIX 0x84E6 + GL_COMBINE 0x8570 + GL_COMBINE_RGB 0x8571 + GL_COMBINE_ALPHA 0x8572 + GL_SOURCE0_RGB 0x8580 + GL_SOURCE1_RGB 0x8581 + GL_SOURCE2_RGB 0x8582 + GL_SOURCE0_ALPHA 0x8588 + GL_SOURCE1_ALPHA 0x8589 + GL_SOURCE2_ALPHA 0x858A + GL_OPERAND0_RGB 0x8590 + GL_OPERAND1_RGB 0x8591 + GL_OPERAND2_RGB 0x8592 + GL_OPERAND0_ALPHA 0x8598 + GL_OPERAND1_ALPHA 0x8599 + GL_OPERAND2_ALPHA 0x859A + GL_RGB_SCALE 0x8573 + GL_ADD_SIGNED 0x8574 + GL_INTERPOLATE 0x8575 + GL_SUBTRACT 0x84E7 + GL_CONSTANT 0x8576 + GL_PRIMARY_COLOR 0x8577 + GL_PREVIOUS 0x8578 + GL_DOT3_RGB 0x86AE + GL_DOT3_RGBA 0x86AF + GL_CLAMP_TO_BORDER 0x812D + + void glActiveTexture (GLenum texture) + void glClientActiveTexture (GLenum texture) + void glCompressedTexImage1D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data) + void glCompressedTexImage2D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data) + void glCompressedTexImage3D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data) + void glCompressedTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data) + void glCompressedTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data) + void glCompressedTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data) + void glGetCompressedTexImage (GLenum target, GLint lod, GLvoid *img) + void glLoadTransposeMatrixd (const GLdouble m[16]) + void glLoadTransposeMatrixf (const GLfloat m[16]) + void glMultTransposeMatrixd (const GLdouble m[16]) + void glMultTransposeMatrixf (const GLfloat m[16]) + void glMultiTexCoord1d (GLenum target, GLdouble s) + void glMultiTexCoord1dv (GLenum target, const GLdouble *v) + void glMultiTexCoord1f (GLenum target, GLfloat s) + void glMultiTexCoord1fv (GLenum target, const GLfloat *v) + void glMultiTexCoord1i (GLenum target, GLint s) + void glMultiTexCoord1iv (GLenum target, const GLint *v) + void glMultiTexCoord1s (GLenum target, GLshort s) + void glMultiTexCoord1sv (GLenum target, const GLshort *v) + void glMultiTexCoord2d (GLenum target, GLdouble s, GLdouble t) + void glMultiTexCoord2dv (GLenum target, const GLdouble *v) + void glMultiTexCoord2f (GLenum target, GLfloat s, GLfloat t) + void glMultiTexCoord2fv (GLenum target, const GLfloat *v) + void glMultiTexCoord2i (GLenum target, GLint s, GLint t) + void glMultiTexCoord2iv (GLenum target, const GLint *v) + void glMultiTexCoord2s (GLenum target, GLshort s, GLshort t) + void glMultiTexCoord2sv (GLenum target, const GLshort *v) + void glMultiTexCoord3d (GLenum target, GLdouble s, GLdouble t, GLdouble r) + void glMultiTexCoord3dv (GLenum target, const GLdouble *v) + void glMultiTexCoord3f (GLenum target, GLfloat s, GLfloat t, GLfloat r) + void glMultiTexCoord3fv (GLenum target, const GLfloat *v) + void glMultiTexCoord3i (GLenum target, GLint s, GLint t, GLint r) + void glMultiTexCoord3iv (GLenum target, const GLint *v) + void glMultiTexCoord3s (GLenum target, GLshort s, GLshort t, GLshort r) + void glMultiTexCoord3sv (GLenum target, const GLshort *v) + void glMultiTexCoord4d (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q) + void glMultiTexCoord4dv (GLenum target, const GLdouble *v) + void glMultiTexCoord4f (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q) + void glMultiTexCoord4fv (GLenum target, const GLfloat *v) + void glMultiTexCoord4i (GLenum target, GLint s, GLint t, GLint r, GLint q) + void glMultiTexCoord4iv (GLenum target, const GLint *v) + void glMultiTexCoord4s (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q) + void glMultiTexCoord4sv (GLenum target, const GLshort *v) + void glSampleCoverage (GLclampf value, GLboolean invert) diff --git a/Externals/GLew/auto/core/GL_VERSION_1_4 b/Externals/GLew/auto/core/GL_VERSION_1_4 new file mode 100644 index 0000000000..a48fc235b3 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_1_4 @@ -0,0 +1,89 @@ +GL_VERSION_1_4 +http://www.opengl.org/documentation/specs/version1.4/glspec14.pdf + + GL_GENERATE_MIPMAP 0x8191 + GL_GENERATE_MIPMAP_HINT 0x8192 + GL_DEPTH_COMPONENT16 0x81A5 + GL_DEPTH_COMPONENT24 0x81A6 + GL_DEPTH_COMPONENT32 0x81A7 + GL_TEXTURE_DEPTH_SIZE 0x884A + GL_DEPTH_TEXTURE_MODE 0x884B + GL_TEXTURE_COMPARE_MODE 0x884C + GL_TEXTURE_COMPARE_FUNC 0x884D + GL_COMPARE_R_TO_TEXTURE 0x884E + GL_FOG_COORDINATE_SOURCE 0x8450 + GL_FOG_COORDINATE 0x8451 + GL_FRAGMENT_DEPTH 0x8452 + GL_CURRENT_FOG_COORDINATE 0x8453 + GL_FOG_COORDINATE_ARRAY_TYPE 0x8454 + GL_FOG_COORDINATE_ARRAY_STRIDE 0x8455 + GL_FOG_COORDINATE_ARRAY_POINTER 0x8456 + GL_FOG_COORDINATE_ARRAY 0x8457 + GL_POINT_SIZE_MIN 0x8126 + GL_POINT_SIZE_MAX 0x8127 + GL_POINT_FADE_THRESHOLD_SIZE 0x8128 + GL_POINT_DISTANCE_ATTENUATION 0x8129 + GL_COLOR_SUM 0x8458 + GL_CURRENT_SECONDARY_COLOR 0x8459 + GL_SECONDARY_COLOR_ARRAY_SIZE 0x845A + GL_SECONDARY_COLOR_ARRAY_TYPE 0x845B + GL_SECONDARY_COLOR_ARRAY_STRIDE 0x845C + GL_SECONDARY_COLOR_ARRAY_POINTER 0x845D + GL_SECONDARY_COLOR_ARRAY 0x845E + GL_BLEND_DST_RGB 0x80C8 + GL_BLEND_SRC_RGB 0x80C9 + GL_BLEND_DST_ALPHA 0x80CA + GL_BLEND_SRC_ALPHA 0x80CB + GL_INCR_WRAP 0x8507 + GL_DECR_WRAP 0x8508 + GL_TEXTURE_FILTER_CONTROL 0x8500 + GL_TEXTURE_LOD_BIAS 0x8501 + GL_MAX_TEXTURE_LOD_BIAS 0x84FD + GL_MIRRORED_REPEAT 0x8370 + void glBlendEquation (GLenum mode) + void glBlendColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha) + void glFogCoordf (GLfloat coord) + void glFogCoordfv (const GLfloat *coord) + void glFogCoordd (GLdouble coord) + void glFogCoorddv (const GLdouble *coord) + void glFogCoordPointer (GLenum type, GLsizei stride, const GLvoid *pointer) + void glMultiDrawArrays (GLenum mode, GLint *first, GLsizei *count, GLsizei primcount) + void glMultiDrawElements (GLenum mode, GLsizei *count, GLenum type, const GLvoid **indices, GLsizei primcount) + void glPointParameteri (GLenum pname, GLint param) + void glPointParameteriv (GLenum pname, const GLint *params) + void glPointParameterf (GLenum pname, GLfloat param) + void glPointParameterfv (GLenum pname, const GLfloat *params) + void glSecondaryColor3b (GLbyte red, GLbyte green, GLbyte blue) + void glSecondaryColor3bv (const GLbyte *v) + void glSecondaryColor3d (GLdouble red, GLdouble green, GLdouble blue) + void glSecondaryColor3dv (const GLdouble *v) + void glSecondaryColor3f (GLfloat red, GLfloat green, GLfloat blue) + void glSecondaryColor3fv (const GLfloat *v) + void glSecondaryColor3i (GLint red, GLint green, GLint blue) + void glSecondaryColor3iv (const GLint *v) + void glSecondaryColor3s (GLshort red, GLshort green, GLshort blue) + void glSecondaryColor3sv (const GLshort *v) + void glSecondaryColor3ub (GLubyte red, GLubyte green, GLubyte blue) + void glSecondaryColor3ubv (const GLubyte *v) + void glSecondaryColor3ui (GLuint red, GLuint green, GLuint blue) + void glSecondaryColor3uiv (const GLuint *v) + void glSecondaryColor3us (GLushort red, GLushort green, GLushort blue) + void glSecondaryColor3usv (const GLushort *v) + void glSecondaryColorPointer (GLint size, GLenum type, GLsizei stride, GLvoid *pointer) + void glBlendFuncSeparate (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha) + void glWindowPos2d (GLdouble x, GLdouble y) + void glWindowPos2f (GLfloat x, GLfloat y) + void glWindowPos2i (GLint x, GLint y) + void glWindowPos2s (GLshort x, GLshort y) + void glWindowPos2dv (const GLdouble *p) + void glWindowPos2fv (const GLfloat *p) + void glWindowPos2iv (const GLint *p) + void glWindowPos2sv (const GLshort *p) + void glWindowPos3d (GLdouble x, GLdouble y, GLdouble z) + void glWindowPos3f (GLfloat x, GLfloat y, GLfloat z) + void glWindowPos3i (GLint x, GLint y, GLint z) + void glWindowPos3s (GLshort x, GLshort y, GLshort z) + void glWindowPos3dv (const GLdouble *p) + void glWindowPos3fv (const GLfloat *p) + void glWindowPos3iv (const GLint *p) + void glWindowPos3sv (const GLshort *p) diff --git a/Externals/GLew/auto/core/GL_VERSION_1_5 b/Externals/GLew/auto/core/GL_VERSION_1_5 new file mode 100644 index 0000000000..d1ec8d4b27 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_1_5 @@ -0,0 +1,74 @@ +GL_VERSION_1_5 +http://www.opengl.org/documentation/specs/version1.5/glspec15.pdf + + GL_BUFFER_SIZE 0x8764 + GL_BUFFER_USAGE 0x8765 + GL_QUERY_COUNTER_BITS 0x8864 + GL_CURRENT_QUERY 0x8865 + GL_QUERY_RESULT 0x8866 + GL_QUERY_RESULT_AVAILABLE 0x8867 + GL_ARRAY_BUFFER 0x8892 + GL_ELEMENT_ARRAY_BUFFER 0x8893 + GL_ARRAY_BUFFER_BINDING 0x8894 + GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895 + GL_VERTEX_ARRAY_BUFFER_BINDING 0x8896 + GL_NORMAL_ARRAY_BUFFER_BINDING 0x8897 + GL_COLOR_ARRAY_BUFFER_BINDING 0x8898 + GL_INDEX_ARRAY_BUFFER_BINDING 0x8899 + GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING 0x889A + GL_EDGE_FLAG_ARRAY_BUFFER_BINDING 0x889B + GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING 0x889C + GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING 0x889D + GL_WEIGHT_ARRAY_BUFFER_BINDING 0x889E + GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F + GL_READ_ONLY 0x88B8 + GL_WRITE_ONLY 0x88B9 + GL_READ_WRITE 0x88BA + GL_BUFFER_ACCESS 0x88BB + GL_BUFFER_MAPPED 0x88BC + GL_BUFFER_MAP_POINTER 0x88BD + GL_STREAM_DRAW 0x88E0 + GL_STREAM_READ 0x88E1 + GL_STREAM_COPY 0x88E2 + GL_STATIC_DRAW 0x88E4 + GL_STATIC_READ 0x88E5 + GL_STATIC_COPY 0x88E6 + GL_DYNAMIC_DRAW 0x88E8 + GL_DYNAMIC_READ 0x88E9 + GL_DYNAMIC_COPY 0x88EA + GL_SAMPLES_PASSED 0x8914 + GL_FOG_COORD_SRC GL_FOG_COORDINATE_SOURCE + GL_FOG_COORD GL_FOG_COORDINATE + GL_CURRENT_FOG_COORD GL_CURRENT_FOG_COORDINATE + GL_FOG_COORD_ARRAY_TYPE GL_FOG_COORDINATE_ARRAY_TYPE + GL_FOG_COORD_ARRAY_STRIDE GL_FOG_COORDINATE_ARRAY_STRIDE + GL_FOG_COORD_ARRAY_POINTER GL_FOG_COORDINATE_ARRAY_POINTER + GL_FOG_COORD_ARRAY GL_FOG_COORDINATE_ARRAY + GL_FOG_COORD_ARRAY_BUFFER_BINDING GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING + GL_SRC0_RGB GL_SOURCE0_RGB + GL_SRC1_RGB GL_SOURCE1_RGB + GL_SRC2_RGB GL_SOURCE2_RGB + GL_SRC0_ALPHA GL_SOURCE0_ALPHA + GL_SRC1_ALPHA GL_SOURCE1_ALPHA + GL_SRC2_ALPHA GL_SOURCE2_ALPHA + void glGenQueries (GLsizei n, GLuint* ids) + void glDeleteQueries (GLsizei n, const GLuint* ids) + GLboolean glIsQuery (GLuint id) + void glBeginQuery (GLenum target, GLuint id) + void glEndQuery (GLenum target) + void glGetQueryiv (GLenum target, GLenum pname, GLint* params) + void glGetQueryObjectiv (GLuint id, GLenum pname, GLint* params) + void glGetQueryObjectuiv (GLuint id, GLenum pname, GLuint* params) + void glBindBuffer (GLenum target, GLuint buffer) + void glDeleteBuffers (GLsizei n, const GLuint* buffers) + void glGenBuffers (GLsizei n, GLuint* buffers) + GLboolean glIsBuffer (GLuint buffer) + void glBufferData (GLenum target, GLsizeiptr size, const GLvoid* data, GLenum usage) + void glBufferSubData (GLenum target, GLintptr offset, GLsizeiptr size, const GLvoid* data) + void glGetBufferSubData (GLenum target, GLintptr offset, GLsizeiptr size, GLvoid* data) + GLvoid* glMapBuffer (GLenum target, GLenum access) + GLboolean glUnmapBuffer (GLenum target) + void glGetBufferParameteriv (GLenum target, GLenum pname, GLint* params) + void glGetBufferPointerv (GLenum target, GLenum pname, GLvoid** params) + typedef ptrdiff_t GLsizeiptr + typedef ptrdiff_t GLintptr diff --git a/Externals/GLew/auto/core/GL_VERSION_2_0 b/Externals/GLew/auto/core/GL_VERSION_2_0 new file mode 100644 index 0000000000..b1b5902565 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_2_0 @@ -0,0 +1,181 @@ +GL_VERSION_2_0 +http://www.opengl.org/documentation/specs/version2.0/glspec20.pdf + + GL_BLEND_EQUATION_RGB GL_BLEND_EQUATION + GL_VERTEX_ATTRIB_ARRAY_ENABLED 0x8622 + GL_VERTEX_ATTRIB_ARRAY_SIZE 0x8623 + GL_VERTEX_ATTRIB_ARRAY_STRIDE 0x8624 + GL_VERTEX_ATTRIB_ARRAY_TYPE 0x8625 + GL_CURRENT_VERTEX_ATTRIB 0x8626 + GL_VERTEX_PROGRAM_POINT_SIZE 0x8642 + GL_VERTEX_PROGRAM_TWO_SIDE 0x8643 + GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645 + GL_STENCIL_BACK_FUNC 0x8800 + GL_STENCIL_BACK_FAIL 0x8801 + GL_STENCIL_BACK_PASS_DEPTH_FAIL 0x8802 + GL_STENCIL_BACK_PASS_DEPTH_PASS 0x8803 + GL_MAX_DRAW_BUFFERS 0x8824 + GL_DRAW_BUFFER0 0x8825 + GL_DRAW_BUFFER1 0x8826 + GL_DRAW_BUFFER2 0x8827 + GL_DRAW_BUFFER3 0x8828 + GL_DRAW_BUFFER4 0x8829 + GL_DRAW_BUFFER5 0x882A + GL_DRAW_BUFFER6 0x882B + GL_DRAW_BUFFER7 0x882C + GL_DRAW_BUFFER8 0x882D + GL_DRAW_BUFFER9 0x882E + GL_DRAW_BUFFER10 0x882F + GL_DRAW_BUFFER11 0x8830 + GL_DRAW_BUFFER12 0x8831 + GL_DRAW_BUFFER13 0x8832 + GL_DRAW_BUFFER14 0x8833 + GL_DRAW_BUFFER15 0x8834 + GL_BLEND_EQUATION_ALPHA 0x883D + GL_POINT_SPRITE 0x8861 + GL_COORD_REPLACE 0x8862 + GL_MAX_VERTEX_ATTRIBS 0x8869 + GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A + GL_MAX_TEXTURE_COORDS 0x8871 + GL_MAX_TEXTURE_IMAGE_UNITS 0x8872 + GL_FRAGMENT_SHADER 0x8B30 + GL_VERTEX_SHADER 0x8B31 + GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49 + GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A + GL_MAX_VARYING_FLOATS 0x8B4B + GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C + GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D + GL_SHADER_TYPE 0x8B4F + GL_FLOAT_VEC2 0x8B50 + GL_FLOAT_VEC3 0x8B51 + GL_FLOAT_VEC4 0x8B52 + GL_INT_VEC2 0x8B53 + GL_INT_VEC3 0x8B54 + GL_INT_VEC4 0x8B55 + GL_BOOL 0x8B56 + GL_BOOL_VEC2 0x8B57 + GL_BOOL_VEC3 0x8B58 + GL_BOOL_VEC4 0x8B59 + GL_FLOAT_MAT2 0x8B5A + GL_FLOAT_MAT3 0x8B5B + GL_FLOAT_MAT4 0x8B5C + GL_SAMPLER_1D 0x8B5D + GL_SAMPLER_2D 0x8B5E + GL_SAMPLER_3D 0x8B5F + GL_SAMPLER_CUBE 0x8B60 + GL_SAMPLER_1D_SHADOW 0x8B61 + GL_SAMPLER_2D_SHADOW 0x8B62 + GL_DELETE_STATUS 0x8B80 + GL_COMPILE_STATUS 0x8B81 + GL_LINK_STATUS 0x8B82 + GL_VALIDATE_STATUS 0x8B83 + GL_INFO_LOG_LENGTH 0x8B84 + GL_ATTACHED_SHADERS 0x8B85 + GL_ACTIVE_UNIFORMS 0x8B86 + GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87 + GL_SHADER_SOURCE_LENGTH 0x8B88 + GL_ACTIVE_ATTRIBUTES 0x8B89 + GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A + GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B + GL_SHADING_LANGUAGE_VERSION 0x8B8C + GL_CURRENT_PROGRAM 0x8B8D + GL_POINT_SPRITE_COORD_ORIGIN 0x8CA0 + GL_LOWER_LEFT 0x8CA1 + GL_UPPER_LEFT 0x8CA2 + GL_STENCIL_BACK_REF 0x8CA3 + GL_STENCIL_BACK_VALUE_MASK 0x8CA4 + GL_STENCIL_BACK_WRITEMASK 0x8CA5 + typedef char GLchar + void glBlendEquationSeparate (GLenum, GLenum) + void glDrawBuffers (GLsizei n, const GLenum* bufs) + void glStencilOpSeparate (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass) + void glStencilFuncSeparate (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask) + void glStencilMaskSeparate (GLenum, GLuint) + void glAttachShader (GLuint program, GLuint shader) + void glBindAttribLocation (GLuint program, GLuint index, const GLchar* name) + void glCompileShader (GLuint shader) + GLuint glCreateProgram (void) + GLuint glCreateShader (GLenum type) + void glDeleteProgram (GLuint program) + void glDeleteShader (GLuint shader) + void glDetachShader (GLuint program, GLuint shader) + void glDisableVertexAttribArray (GLuint) + void glEnableVertexAttribArray (GLuint) + void glGetActiveAttrib (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name) + void glGetActiveUniform (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name) + void glGetAttachedShaders (GLuint program, GLsizei maxCount, GLsizei* count, GLuint* shaders) + GLint glGetAttribLocation (GLuint program, const GLchar* name) + void glGetProgramiv (GLuint program, GLenum pname, GLint* param) + void glGetProgramInfoLog (GLuint program, GLsizei bufSize, GLsizei* length, GLchar* infoLog) + void glGetShaderiv (GLuint shader, GLenum pname, GLint* param) + void glGetShaderInfoLog (GLuint shader, GLsizei bufSize, GLsizei* length, GLchar* infoLog) + void glShaderSource (GLuint shader, GLsizei count, const GLchar** strings, const GLint* lengths) + GLint glGetUniformLocation (GLuint program, const GLchar* name) + void glGetUniformfv (GLuint program, GLint location, GLfloat* params) + void glGetUniformiv (GLuint program, GLint location, GLint* params) + void glGetVertexAttribdv (GLuint, GLenum, GLdouble*) + void glGetVertexAttribfv (GLuint, GLenum, GLfloat*) + void glGetVertexAttribiv (GLuint, GLenum, GLint*) + void glGetVertexAttribPointerv (GLuint, GLenum, GLvoid*) + GLboolean glIsProgram (GLuint program) + GLboolean glIsShader (GLuint shader) + void glLinkProgram (GLuint program) + void glGetShaderSource (GLint obj, GLsizei maxLength, GLsizei* length, GLchar* source) + void glUseProgram (GLuint program) + void glUniform1f (GLint location, GLfloat v0) + void glUniform1fv (GLint location, GLsizei count, const GLfloat* value) + void glUniform1i (GLint location, GLint v0) + void glUniform1iv (GLint location, GLsizei count, const GLint* value) + void glUniform2f (GLint location, GLfloat v0, GLfloat v1) + void glUniform2fv (GLint location, GLsizei count, const GLfloat* value) + void glUniform2i (GLint location, GLint v0, GLint v1) + void glUniform2iv (GLint location, GLsizei count, const GLint* value) + void glUniform3f (GLint location, GLfloat v0, GLfloat v1, GLfloat v2) + void glUniform3fv (GLint location, GLsizei count, const GLfloat* value) + void glUniform3i (GLint location, GLint v0, GLint v1, GLint v2) + void glUniform3iv (GLint location, GLsizei count, const GLint* value) + void glUniform4f (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3) + void glUniform4fv (GLint location, GLsizei count, const GLfloat* value) + void glUniform4i (GLint location, GLint v0, GLint v1, GLint v2, GLint v3) + void glUniform4iv (GLint location, GLsizei count, const GLint* value) + void glUniformMatrix2fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glUniformMatrix3fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glUniformMatrix4fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glValidateProgram (GLuint program) + void glVertexAttrib1d (GLuint index, GLdouble x) + void glVertexAttrib1dv (GLuint index, const GLdouble* v) + void glVertexAttrib1f (GLuint index, GLfloat x) + void glVertexAttrib1fv (GLuint index, const GLfloat* v) + void glVertexAttrib1s (GLuint index, GLshort x) + void glVertexAttrib1sv (GLuint index, const GLshort* v) + void glVertexAttrib2d (GLuint index, GLdouble x, GLdouble y) + void glVertexAttrib2dv (GLuint index, const GLdouble* v) + void glVertexAttrib2f (GLuint index, GLfloat x, GLfloat y) + void glVertexAttrib2fv (GLuint index, const GLfloat* v) + void glVertexAttrib2s (GLuint index, GLshort x, GLshort y) + void glVertexAttrib2sv (GLuint index, const GLshort* v) + void glVertexAttrib3d (GLuint index, GLdouble x, GLdouble y, GLdouble z) + void glVertexAttrib3dv (GLuint index, const GLdouble* v) + void glVertexAttrib3f (GLuint index, GLfloat x, GLfloat y, GLfloat z) + void glVertexAttrib3fv (GLuint index, const GLfloat* v) + void glVertexAttrib3s (GLuint index, GLshort x, GLshort y, GLshort z) + void glVertexAttrib3sv (GLuint index, const GLshort* v) + void glVertexAttrib4Nbv (GLuint index, const GLbyte* v) + void glVertexAttrib4Niv (GLuint index, const GLint* v) + void glVertexAttrib4Nsv (GLuint index, const GLshort* v) + void glVertexAttrib4Nub (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w) + void glVertexAttrib4Nubv (GLuint index, const GLubyte* v) + void glVertexAttrib4Nuiv (GLuint index, const GLuint* v) + void glVertexAttrib4Nusv (GLuint index, const GLushort* v) + void glVertexAttrib4bv (GLuint index, const GLbyte* v) + void glVertexAttrib4d (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glVertexAttrib4dv (GLuint index, const GLdouble* v) + void glVertexAttrib4f (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glVertexAttrib4fv (GLuint index, const GLfloat* v) + void glVertexAttrib4iv (GLuint index, const GLint* v) + void glVertexAttrib4s (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w) + void glVertexAttrib4sv (GLuint index, const GLshort* v) + void glVertexAttrib4ubv (GLuint index, const GLubyte* v) + void glVertexAttrib4uiv (GLuint index, const GLuint* v) + void glVertexAttrib4usv (GLuint index, const GLushort* v) + void glVertexAttribPointer (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid* pointer) diff --git a/Externals/GLew/auto/core/GL_VERSION_2_1 b/Externals/GLew/auto/core/GL_VERSION_2_1 new file mode 100644 index 0000000000..51aa95b840 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_2_1 @@ -0,0 +1,32 @@ +GL_VERSION_2_1 +http://www.opengl.org/documentation/specs/version2.1/glspec21.pdf + + GL_CURRENT_RASTER_SECONDARY_COLOR 0x845F + GL_PIXEL_PACK_BUFFER 0x88EB + GL_PIXEL_UNPACK_BUFFER 0x88EC + GL_PIXEL_PACK_BUFFER_BINDING 0x88ED + GL_PIXEL_UNPACK_BUFFER_BINDING 0x88EF + GL_FLOAT_MAT2x3 0x8B65 + GL_FLOAT_MAT2x4 0x8B66 + GL_FLOAT_MAT3x2 0x8B67 + GL_FLOAT_MAT3x4 0x8B68 + GL_FLOAT_MAT4x2 0x8B69 + GL_FLOAT_MAT4x3 0x8B6A + GL_SRGB 0x8C40 + GL_SRGB8 0x8C41 + GL_SRGB_ALPHA 0x8C42 + GL_SRGB8_ALPHA8 0x8C43 + GL_SLUMINANCE_ALPHA 0x8C44 + GL_SLUMINANCE8_ALPHA8 0x8C45 + GL_SLUMINANCE 0x8C46 + GL_SLUMINANCE8 0x8C47 + GL_COMPRESSED_SRGB 0x8C48 + GL_COMPRESSED_SRGB_ALPHA 0x8C49 + GL_COMPRESSED_SLUMINANCE 0x8C4A + GL_COMPRESSED_SLUMINANCE_ALPHA 0x8C4B + void glUniformMatrix2x3fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value) + void glUniformMatrix3x2fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value) + void glUniformMatrix2x4fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value) + void glUniformMatrix4x2fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value) + void glUniformMatrix3x4fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value) + void glUniformMatrix4x3fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value) diff --git a/Externals/GLew/auto/core/GL_VERSION_3_0 b/Externals/GLew/auto/core/GL_VERSION_3_0 new file mode 100644 index 0000000000..1a362f0b59 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_3_0 @@ -0,0 +1,166 @@ +GL_VERSION_3_0 +http://www.opengl.org/registry/doc/glspec30.20080811.pdf + + GL_COMPARE_REF_TO_TEXTURE GL_COMPARE_R_TO_TEXTURE_ARB + GL_CLIP_DISTANCE0 GL_CLIP_PLANE0 + GL_CLIP_DISTANCE1 GL_CLIP_PLANE1 + GL_CLIP_DISTANCE2 GL_CLIP_PLANE2 + GL_CLIP_DISTANCE3 GL_CLIP_PLANE3 + GL_CLIP_DISTANCE4 GL_CLIP_PLANE4 + GL_CLIP_DISTANCE5 GL_CLIP_PLANE5 + GL_MAX_CLIP_DISTANCES GL_MAX_CLIP_PLANES + GL_MAJOR_VERSION 0x821B + GL_MINOR_VERSION 0x821C + GL_NUM_EXTENSIONS 0x821D + GL_CONTEXT_FLAGS 0x821E + GL_DEPTH_BUFFER 0x8223 + GL_STENCIL_BUFFER 0x8224 + GL_COMPRESSED_RED 0x8225 + GL_COMPRESSED_RG 0x8226 + GL_CONTEXT_FLAG_FORWARD_COMPATIBLE_BIT 0x0001 + GL_RGBA32F 0x8814 + GL_RGB32F 0x8815 + GL_RGBA16F 0x881A + GL_RGB16F 0x881B + GL_VERTEX_ATTRIB_ARRAY_INTEGER 0x88FD + GL_MAX_ARRAY_TEXTURE_LAYERS 0x88FF + GL_MIN_PROGRAM_TEXEL_OFFSET 0x8904 + GL_MAX_PROGRAM_TEXEL_OFFSET 0x8905 + GL_CLAMP_VERTEX_COLOR 0x891A + GL_CLAMP_FRAGMENT_COLOR 0x891B + GL_CLAMP_READ_COLOR 0x891C + GL_FIXED_ONLY 0x891D + GL_MAX_VARYING_COMPONENTS GL_MAX_VARYING_FLOATS + GL_TEXTURE_RED_TYPE 0x8C10 + GL_TEXTURE_GREEN_TYPE 0x8C11 + GL_TEXTURE_BLUE_TYPE 0x8C12 + GL_TEXTURE_ALPHA_TYPE 0x8C13 + GL_TEXTURE_LUMINANCE_TYPE 0x8C14 + GL_TEXTURE_INTENSITY_TYPE 0x8C15 + GL_TEXTURE_DEPTH_TYPE 0x8C16 + GL_UNSIGNED_NORMALIZED 0x8C17 + GL_TEXTURE_1D_ARRAY 0x8C18 + GL_PROXY_TEXTURE_1D_ARRAY 0x8C19 + GL_TEXTURE_2D_ARRAY 0x8C1A + GL_PROXY_TEXTURE_2D_ARRAY 0x8C1B + GL_TEXTURE_BINDING_1D_ARRAY 0x8C1C + GL_TEXTURE_BINDING_2D_ARRAY 0x8C1D + GL_R11F_G11F_B10F 0x8C3A + GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B + GL_RGB9_E5 0x8C3D + GL_UNSIGNED_INT_5_9_9_9_REV 0x8C3E + GL_TEXTURE_SHARED_SIZE 0x8C3F + GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH 0x8C76 + GL_TRANSFORM_FEEDBACK_BUFFER_MODE 0x8C7F + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS 0x8C80 + GL_TRANSFORM_FEEDBACK_VARYINGS 0x8C83 + GL_TRANSFORM_FEEDBACK_BUFFER_START 0x8C84 + GL_TRANSFORM_FEEDBACK_BUFFER_SIZE 0x8C85 + GL_PRIMITIVES_GENERATED 0x8C87 + GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN 0x8C88 + GL_RASTERIZER_DISCARD 0x8C89 + GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS 0x8C8A + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS 0x8C8B + GL_INTERLEAVED_ATTRIBS 0x8C8C + GL_SEPARATE_ATTRIBS 0x8C8D + GL_TRANSFORM_FEEDBACK_BUFFER 0x8C8E + GL_TRANSFORM_FEEDBACK_BUFFER_BINDING 0x8C8F + GL_RGBA32UI 0x8D70 + GL_RGB32UI 0x8D71 + GL_RGBA16UI 0x8D76 + GL_RGB16UI 0x8D77 + GL_RGBA8UI 0x8D7C + GL_RGB8UI 0x8D7D + GL_RGBA32I 0x8D82 + GL_RGB32I 0x8D83 + GL_RGBA16I 0x8D88 + GL_RGB16I 0x8D89 + GL_RGBA8I 0x8D8E + GL_RGB8I 0x8D8F + GL_RED_INTEGER 0x8D94 + GL_GREEN_INTEGER 0x8D95 + GL_BLUE_INTEGER 0x8D96 + GL_ALPHA_INTEGER 0x8D97 + GL_RGB_INTEGER 0x8D98 + GL_RGBA_INTEGER 0x8D99 + GL_BGR_INTEGER 0x8D9A + GL_BGRA_INTEGER 0x8D9B + GL_SAMPLER_1D_ARRAY 0x8DC0 + GL_SAMPLER_2D_ARRAY 0x8DC1 + GL_SAMPLER_1D_ARRAY_SHADOW 0x8DC3 + GL_SAMPLER_2D_ARRAY_SHADOW 0x8DC4 + GL_SAMPLER_CUBE_SHADOW 0x8DC5 + GL_UNSIGNED_INT_VEC2 0x8DC6 + GL_UNSIGNED_INT_VEC3 0x8DC7 + GL_UNSIGNED_INT_VEC4 0x8DC8 + GL_INT_SAMPLER_1D 0x8DC9 + GL_INT_SAMPLER_2D 0x8DCA + GL_INT_SAMPLER_3D 0x8DCB + GL_INT_SAMPLER_CUBE 0x8DCC + GL_INT_SAMPLER_1D_ARRAY 0x8DCE + GL_INT_SAMPLER_2D_ARRAY 0x8DCF + GL_UNSIGNED_INT_SAMPLER_1D 0x8DD1 + GL_UNSIGNED_INT_SAMPLER_2D 0x8DD2 + GL_UNSIGNED_INT_SAMPLER_3D 0x8DD3 + GL_UNSIGNED_INT_SAMPLER_CUBE 0x8DD4 + GL_UNSIGNED_INT_SAMPLER_1D_ARRAY 0x8DD6 + GL_UNSIGNED_INT_SAMPLER_2D_ARRAY 0x8DD7 + GL_QUERY_WAIT 0x8E13 + GL_QUERY_NO_WAIT 0x8E14 + GL_QUERY_BY_REGION_WAIT 0x8E15 + GL_QUERY_BY_REGION_NO_WAIT 0x8E16 + void glColorMaski (GLuint, GLboolean, GLboolean, GLboolean, GLboolean) + void glGetBooleani_v (GLenum, GLuint, GLboolean*) + void glEnablei (GLenum, GLuint) + void glDisablei (GLenum, GLuint) + GLboolean glIsEnabledi (GLenum, GLuint) + void glBeginTransformFeedback (GLenum) + void glEndTransformFeedback (void) + void glTransformFeedbackVaryings (GLuint, GLsizei, const GLchar **, GLenum) + void glGetTransformFeedbackVarying (GLuint, GLuint, GLint*) + void glClampColor (GLenum, GLenum) + void glBeginConditionalRender (GLuint, GLenum) + void glEndConditionalRender (void) + void glVertexAttribI1i (GLuint, GLint) + void glVertexAttribI2i (GLuint, GLint, GLint) + void glVertexAttribI3i (GLuint, GLint, GLint, GLint) + void glVertexAttribI4i (GLuint, GLint, GLint, GLint, GLint) + void glVertexAttribI1ui (GLuint, GLuint) + void glVertexAttribI2ui (GLuint, GLuint, GLuint) + void glVertexAttribI3ui (GLuint, GLuint, GLuint, GLuint) + void glVertexAttribI4ui (GLuint, GLuint, GLuint, GLuint, GLuint) + void glVertexAttribI1iv (GLuint, const GLint*) + void glVertexAttribI2iv (GLuint, const GLint*) + void glVertexAttribI3iv (GLuint, const GLint*) + void glVertexAttribI4iv (GLuint, const GLint*) + void glVertexAttribI1uiv (GLuint, const GLuint*) + void glVertexAttribI2uiv (GLuint, const GLuint*) + void glVertexAttribI3uiv (GLuint, const GLuint*) + void glVertexAttribI4uiv (GLuint, const GLuint*) + void glVertexAttribI4bv (GLuint, const GLbyte*) + void glVertexAttribI4sv (GLuint, const GLshort*) + void glVertexAttribI4ubv (GLuint, const GLubyte*) + void glVertexAttribI4usv (GLuint, const GLushort*) + void glVertexAttribIPointer (GLuint, GLint, GLenum, GLsizei, const GLvoid*) + void glGetVertexAttribIiv (GLuint, GLenum, GLint*) + void glGetVertexAttribIuiv (GLuint, GLenum, GLuint*) + void glGetUniformuiv (GLuint, GLint, GLuint*) + void glBindFragDataLocation (GLuint, GLuint, const GLchar*) + GLint glGetFragDataLocation (GLuint, const GLchar*) + void glUniform1ui (GLint, GLuint) + void glUniform2ui (GLint, GLuint, GLuint) + void glUniform3ui (GLint, GLuint, GLuint, GLuint) + void glUniform4ui (GLint, GLuint, GLuint, GLuint, GLuint) + void glUniform1uiv (GLint, GLsizei, const GLuint*) + void glUniform2uiv (GLint, GLsizei, const GLuint*) + void glUniform3uiv (GLint, GLsizei, const GLuint*) + void glUniform4uiv (GLint, GLsizei, const GLuint*) + void glTexParameterIiv (GLenum, GLenum, const GLint*) + void glTexParameterIuiv (GLenum, GLenum, const GLuint*) + void glGetTexParameterIiv (GLenum, GLenum, GLint*) + void glGetTexParameterIuiv (GLenum, GLenum, GLuint*) + void glClearBufferiv (GLenum, GLint, const GLint*) + void glClearBufferuiv (GLenum, GLint, const GLuint*) + void glClearBufferfv (GLenum, GLint, const GLfloat*) + void glClearBufferfi (GLenum, GLint, GLfloat, GLint) + const GLubyte* glGetStringi (GLenum, GLuint) diff --git a/Externals/GLew/auto/core/GL_VERSION_3_1 b/Externals/GLew/auto/core/GL_VERSION_3_1 new file mode 100644 index 0000000000..3e387a3c9c --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_3_1 @@ -0,0 +1,41 @@ +GL_VERSION_3_1 +http://www.opengl.org/registry/doc/glspec30.20080811.pdf + + GL_SAMPLER_2D_RECT 0x8B63 + GL_SAMPLER_2D_RECT_SHADOW 0x8B64 + GL_SAMPLER_BUFFER 0x8DC2 + GL_INT_SAMPLER_2D_RECT 0x8DCD + GL_INT_SAMPLER_BUFFER 0x8DD0 + GL_UNSIGNED_INT_SAMPLER_2D_RECT 0x8DD5 + GL_UNSIGNED_INT_SAMPLER_BUFFER 0x8DD8 + GL_TEXTURE_BUFFER 0x8C2A + GL_MAX_TEXTURE_BUFFER_SIZE 0x8C2B + GL_TEXTURE_BINDING_BUFFER 0x8C2C + GL_TEXTURE_BUFFER_DATA_STORE_BINDING 0x8C2D + GL_TEXTURE_BUFFER_FORMAT 0x8C2E + GL_TEXTURE_RECTANGLE 0x84F5 + GL_TEXTURE_BINDING_RECTANGLE 0x84F6 + GL_PROXY_TEXTURE_RECTANGLE 0x84F7 + GL_MAX_RECTANGLE_TEXTURE_SIZE 0x84F8 + GL_RED_SNORM 0x8F90 + GL_RG_SNORM 0x8F91 + GL_RGB_SNORM 0x8F92 + GL_RGBA_SNORM 0x8F93 + GL_R8_SNORM 0x8F94 + GL_RG8_SNORM 0x8F95 + GL_RGB8_SNORM 0x8F96 + GL_RGBA8_SNORM 0x8F97 + GL_R16_SNORM 0x8F98 + GL_RG16_SNORM 0x8F99 + GL_RGB16_SNORM 0x8F9A + GL_RGBA16_SNORM 0x8F9B + GL_SIGNED_NORMALIZED 0x8F9C + GL_PRIMITIVE_RESTART 0x8F9D + GL_PRIMITIVE_RESTART_INDEX 0x8F9E + GL_BUFFER_ACCESS_FLAGS 0x911F + GL_BUFFER_MAP_LENGTH 0x9120 + GL_BUFFER_MAP_OFFSET 0x9121 + void glDrawArraysInstanced (GLenum, GLint, GLsizei, GLsizei) + void glDrawElementsInstanced (GLenum, GLsizei, GLenum, const GLvoid*, GLsizei) + void glTexBuffer (GLenum, GLenum, GLuint) + void glPrimitiveRestartIndex (GLuint) diff --git a/Externals/GLew/auto/core/GL_VERSION_3_2 b/Externals/GLew/auto/core/GL_VERSION_3_2 new file mode 100644 index 0000000000..81ba55dcc2 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_3_2 @@ -0,0 +1,28 @@ +GL_VERSION_3_2 +http://www.opengl.org/registry/doc/glspec32.core.20090803.pdf + + GL_CONTEXT_CORE_PROFILE_BIT 0x00000001 + GL_CONTEXT_COMPATIBILITY_PROFILE_BIT 0x00000002 + GL_LINES_ADJACENCY 0x000A + GL_LINE_STRIP_ADJACENCY 0x000B + GL_TRIANGLES_ADJACENCY 0x000C + GL_TRIANGLE_STRIP_ADJACENCY 0x000D + GL_PROGRAM_POINT_SIZE 0x8642 + GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS 0x8C29 + GL_FRAMEBUFFER_ATTACHMENT_LAYERED 0x8DA7 + GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS 0x8DA8 + GL_GEOMETRY_SHADER 0x8DD9 + GL_GEOMETRY_VERTICES_OUT 0x8916 + GL_GEOMETRY_INPUT_TYPE 0x8917 + GL_GEOMETRY_OUTPUT_TYPE 0x8918 + GL_MAX_GEOMETRY_UNIFORM_COMPONENTS 0x8DDF + GL_MAX_GEOMETRY_OUTPUT_VERTICES 0x8DE0 + GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS 0x8DE1 + GL_MAX_VERTEX_OUTPUT_COMPONENTS 0x9122 + GL_MAX_GEOMETRY_INPUT_COMPONENTS 0x9123 + GL_MAX_GEOMETRY_OUTPUT_COMPONENTS 0x9124 + GL_MAX_FRAGMENT_INPUT_COMPONENTS 0x9125 + GL_CONTEXT_PROFILE_MASK 0x9126 + void glGetInteger64i_v (GLenum, GLuint, GLint64 *) + void glGetBufferParameteri64v (GLenum, GLenum, GLint64 *) + void glFramebufferTexture (GLenum, GLenum, GLuint, GLint) diff --git a/Externals/GLew/auto/core/GL_VERSION_3_3 b/Externals/GLew/auto/core/GL_VERSION_3_3 new file mode 100644 index 0000000000..799f5303e1 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_3_3 @@ -0,0 +1,11 @@ +GL_VERSION_3_3 +http://www.opengl.org/registry/doc/glspec32.core.20090803.pdf + + GL_TEXTURE_SWIZZLE_R 0x8E42 + GL_TEXTURE_SWIZZLE_G 0x8E43 + GL_TEXTURE_SWIZZLE_B 0x8E44 + GL_TEXTURE_SWIZZLE_A 0x8E45 + GL_TEXTURE_SWIZZLE_RGBA 0x8E46 + GL_RGB10_A2UI 0x906F + GL_ANY_SAMPLES_PASSED 0x8C2F + GL_VERTEX_ATTRIB_ARRAY_DIVISOR 0x88FE diff --git a/Externals/GLew/auto/core/GL_VERSION_4_0 b/Externals/GLew/auto/core/GL_VERSION_4_0 new file mode 100644 index 0000000000..9a118c9059 --- /dev/null +++ b/Externals/GLew/auto/core/GL_VERSION_4_0 @@ -0,0 +1,25 @@ +GL_VERSION_4_0 +http://www.opengl.org/registry/doc/glspec32.core.20090803.pdf + + GL_SAMPLE_SHADING 0x8C36 + GL_MIN_SAMPLE_SHADING_VALUE 0x8C37 + GL_GEOMETRY_SHADER_INVOCATIONS 0x887F + GL_MAX_GEOMETRY_SHADER_INVOCATIONS 0x8E5A + GL_MIN_FRAGMENT_INTERPOLATION_OFFSET 0x8E5B + GL_MAX_FRAGMENT_INTERPOLATION_OFFSET 0x8E5C + GL_FRAGMENT_INTERPOLATION_OFFSET_BITS 0x8E5D + GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5E + GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5F + GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS 0x8F9F + GL_TEXTURE_CUBE_MAP_ARRAY 0x9009 + GL_TEXTURE_BINDING_CUBE_MAP_ARRAY 0x900A + GL_PROXY_TEXTURE_CUBE_MAP_ARRAY 0x900B + GL_SAMPLER_CUBE_MAP_ARRAY 0x900C + GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW 0x900D + GL_INT_SAMPLER_CUBE_MAP_ARRAY 0x900E + GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY 0x900F + void glMinSampleShading (GLclampf value) + void glBlendEquationSeparatei (GLuint buf, GLenum modeRGB, GLenum modeAlpha) + void glBlendEquationi (GLuint buf, GLenum mode) + void glBlendFuncSeparatei (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha) + void glBlendFunci (GLuint buf, GLenum src, GLenum dst) diff --git a/Externals/GLew/auto/core/GL_WIN_swap_hint b/Externals/GLew/auto/core/GL_WIN_swap_hint new file mode 100644 index 0000000000..6916189eb2 --- /dev/null +++ b/Externals/GLew/auto/core/GL_WIN_swap_hint @@ -0,0 +1,4 @@ +GL_WIN_swap_hint +http://msdn.microsoft.com/library/default.asp?url=/library/en-us/opengl/glfunc01_16zy.asp +GL_WIN_swap_hint + void glAddSwapHintRectWIN (GLint x, GLint y, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/core/WGL_ATI_render_texture_rectangle b/Externals/GLew/auto/core/WGL_ATI_render_texture_rectangle new file mode 100644 index 0000000000..55df114d31 --- /dev/null +++ b/Externals/GLew/auto/core/WGL_ATI_render_texture_rectangle @@ -0,0 +1,4 @@ +WGL_ATI_render_texture_rectangle + +WGL_ATI_render_texture_rectangle + WGL_TEXTURE_RECTANGLE_ATI 0x21A5 diff --git a/Externals/GLew/auto/core/WGL_EXT_framebuffer_sRGB b/Externals/GLew/auto/core/WGL_EXT_framebuffer_sRGB new file mode 100644 index 0000000000..e4a40322fd --- /dev/null +++ b/Externals/GLew/auto/core/WGL_EXT_framebuffer_sRGB @@ -0,0 +1,4 @@ +WGL_EXT_framebuffer_sRGB +http://developer.download.nvidia.com/opengl/specs/GL_EXT_framebuffer_sRGB.txt +WGL_EXT_framebuffer_sRGB + WGL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20A9 diff --git a/Externals/GLew/auto/core/WGL_EXT_pixel_format_packed_float b/Externals/GLew/auto/core/WGL_EXT_pixel_format_packed_float new file mode 100644 index 0000000000..30925fc5da --- /dev/null +++ b/Externals/GLew/auto/core/WGL_EXT_pixel_format_packed_float @@ -0,0 +1,4 @@ +WGL_EXT_pixel_format_packed_float +http://developer.download.nvidia.com/opengl/specs/GL_EXT_packed_float.txt +WGL_EXT_pixel_format_packed_float + WGL_TYPE_RGBA_UNSIGNED_FLOAT_EXT 0x20A8 diff --git a/Externals/GLew/auto/core/WGL_NV_gpu_affinity b/Externals/GLew/auto/core/WGL_NV_gpu_affinity new file mode 100644 index 0000000000..f722204cd7 --- /dev/null +++ b/Externals/GLew/auto/core/WGL_NV_gpu_affinity @@ -0,0 +1,12 @@ +WGL_NV_gpu_affinity +http://developer.download.nvidia.com/opengl/specs/WGL_nv_gpu_affinity.txt +WGL_NV_gpu_affinity + WGL_ERROR_INCOMPATIBLE_AFFINITY_MASKS_NV 0x20D0 + WGL_ERROR_MISSING_AFFINITY_MASK_NV 0x20D1 + BOOL wglEnumGpusNV (UINT iGpuIndex, HGPUNV *phGpu) + BOOL wglEnumGpuDevicesNV (HGPUNV hGpu, UINT iDeviceIndex, PGPU_DEVICE lpGpuDevice) + HDC wglCreateAffinityDCNV (const HGPUNV *phGpuList) + BOOL wglEnumGpusFromAffinityDCNV (HDC hAffinityDC, UINT iGpuIndex, HGPUNV *hGpu) + BOOL wglDeleteDCNV (HDC hdc) + DECLARE_HANDLE(HGPUNV); + typedef struct _GPU_DEVICE { DWORD cb; CHAR DeviceName[32]; CHAR DeviceString[128]; DWORD Flags; RECT rcVirtualScreen; } GPU_DEVICE, *PGPU_DEVICE; diff --git a/Externals/GLew/auto/core/WGL_NV_vertex_array_range b/Externals/GLew/auto/core/WGL_NV_vertex_array_range new file mode 100644 index 0000000000..ca22d31a3e --- /dev/null +++ b/Externals/GLew/auto/core/WGL_NV_vertex_array_range @@ -0,0 +1,5 @@ +WGL_NV_vertex_array_range +http://oss.sgi.com/projects/ogl-sample/registry/NV/vertex_array_range.txt +WGL_NV_vertex_array_range + void * wglAllocateMemoryNV (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority) + void wglFreeMemoryNV (void *pointer) diff --git a/Externals/GLew/auto/custom.txt b/Externals/GLew/auto/custom.txt new file mode 100644 index 0000000000..b797b95887 --- /dev/null +++ b/Externals/GLew/auto/custom.txt @@ -0,0 +1,7 @@ +WGL_ARB_extensions_string +WGL_EXT_extensions_string +WGL_ARB_pixel_format +WGL_ARB_pbuffer +WGL_NV_float_buffer +WGL_ATI_pixel_format_float +WGL_ARB_multisample diff --git a/Externals/GLew/auto/doc/advanced.html b/Externals/GLew/auto/doc/advanced.html new file mode 100644 index 0000000000..45a3ada7c3 --- /dev/null +++ b/Externals/GLew/auto/doc/advanced.html @@ -0,0 +1,176 @@ +

Automatic Code Generation

+ +

+Starting from release 1.1.0, the source code and parts of the +documentation are automatically generated from the extension +specifications in a two-step process. In the first step, +specification files from the OpenGL registry are downloaded and +parsed. Skeleton descriptors are created for each extension. These +descriptors contain all necessary information for creating the source +code and documentation in a simple and compact format, including the +name of the extension, url link to the specification, tokens, function +declarations, typedefs and struct definitions. In the second step, +the header files as well as the library and glewinfo source are +generated from the descriptor files. The code generation scripts are +located in the auto subdirectory. +

+ +

+The code generation scripts require GNU make, wget, and perl. On +Windows, the simplest way to get access to these tools is to install +Cygwin, but make sure that the +root directory is mounted in binary mode. The makefile in the +auto directory provides the following build targets: +

+ +
+ + + + + + + + + + + + + + + + +
make    Create the source files from the descriptors. If the +descriptors do not exist, create them from the spec files. If the spec +files do not exist, download them from the OpenGL repository.
make clean    Delete the source files.
make clobber    Delete the source files and the descriptors.
make destroy    Delete the source files, the descriptors, and the spec files.
make custom    Create the source files for the extensions +listed in auto/custom.txt. See "Custom Code +Generation" below for more details.
+
+ +

Adding a New Extension

+ +

+To add a new extension, create a descriptor file for the extension in +auto/core and rerun the code generation scripts by typing +make clean; make in the auto directory. +

+ +

+The format of the descriptor file is given below. Items in +brackets are optional. +

+ +

+<Extension Name>
+[<URL of Specification File>]
+    [<Token Name> <Token Value>]
+    [<Token Name> <Token Value>]
+    ...
+    [<Typedef>]
+    [<Typedef>]
+    ...
+    [<Function Signature>]
+    [<Function Signature>]
+    ...
+ +

+ + + +

+Take a look at one of the files in auto/core for an +example. Note that typedefs and function signatures should not be +terminated with a semicolon. +

+ +

Custom Code Generation

+

+Starting from GLEW 1.3.0, it is possible to control which extensions +to include in the libarary by specifying a list in +auto/custom.txt. This is useful when you do not need all the +extensions and would like to reduce the size of the source files. +Type make clean; make custom in the auto directory +to rerun the scripts with the custom list of extensions. +

+ +

+For example, the following is the list of extensions needed to get GLEW and the +utilities to compile. +

+ +

+WGL_ARB_extensions_string
+WGL_ARB_multisample
+WGL_ARB_pixel_format
+WGL_ARB_pbuffer
+WGL_EXT_extensions_string
+WGL_ATI_pixel_format_float
+WGL_NV_float_buffer
+

+ +

Multiple Rendering Contexts (GLEW MX)

+ +

Starting with release 1.2.0, thread-safe support for multiple +rendering contexts, possibly with different capabilities, is +available. Since this is not required by most users, it is not added +to the binary releases to maintain compatibility between different +versions. To include multi-context support, you have to do the +following:

+
    +
  1. Compile and use GLEW with the GLEW_MX preprocessor token +defined.
  2. +
  3. For each rendering context, create a GLEWContext object +that will be available as long as the rendering context exists.
  4. +
  5. Define a macro or function called glewGetContext() that +returns a pointer to the GLEWContext object associated with +the rendering context from which OpenGL/WGL/GLX calls are issued. This +dispatch mechanism is primitive, but generic. +
  6. Make sure that you call glewInit() after creating the +GLEWContext object in each rendering context. Note, that the +GLEWContext pointer returned by glewGetContext() has +to reside in global or thread-local memory. +
+ +

Note that according to the MSDN +WGL documentation, you have to initialize the entry points for +every rendering context that use pixel formats with different +capabilities For example, the pixel formats provided by the generic +software OpenGL implementation by Microsoft vs. the hardware +accelerated pixel formats have different capabilities. GLEW by +default ignores this requirement, and does not define per-context +entry points (you can however do this using the steps described +above). Assuming a global namespace for the entry points works in +most situations, because typically all hardware accelerated pixel +formats provide the same entry points and capabilities. This means +that unless you use the multi-context version of GLEW, you need to +call glewInit() only once in your program, or more precisely, +once per process.

+ +

Separate Namespace

+ +

+To avoid name clashes when linking with libraries that include the +same symbols, extension entry points are declared in a separate +namespace (release 1.1.0 and up). This is achieved by aliasing OpenGL +function names to their GLEW equivalents. For instance, +glFancyFunction is simply an alias to +glewFancyFunction. The separate namespace does not effect +token and function pointer definitions. +

+ +

Known Issues

+ +

+GLEW requires GLX 1.2 for compatibility with GLUT. +

+ diff --git a/Externals/GLew/auto/doc/basic.html b/Externals/GLew/auto/doc/basic.html new file mode 100644 index 0000000000..693575ba5a --- /dev/null +++ b/Externals/GLew/auto/doc/basic.html @@ -0,0 +1,180 @@ +

Initializing GLEW

+

+First you need to create a valid OpenGL rendering context and call +glewInit() to initialize the extension entry points. If +glewInit() returns GLEW_OK, the initialization +succeeded and you can use the available extensions as well as core +OpenGL functionality. For example: +

+ +

+#include <GL/glew.h>
+#include <GL/glut.h>
+...
+glutInit(&argc, argv);
+glutCreateWindow("GLEW Test");
+GLenum err = glewInit();
+if (GLEW_OK != err)
+{
+  /* Problem: glewInit failed, something is seriously wrong. */
+  fprintf(stderr, "Error: %s\n", glewGetErrorString(err));
+  ...
+}
+fprintf(stdout, "Status: Using GLEW %s\n", glewGetString(GLEW_VERSION));
+

+ +

Checking for Extensions

+ +

+Starting from GLEW 1.1.0, you can find out if a particular extension +is available on your platform by querying globally defined variables +of the form GLEW_{extension_name}: +

+ +

+if (GLEW_ARB_vertex_program)
+{
+  /* It is safe to use the ARB_vertex_program extension here. */
+  glGenProgramsARB(...);
+}
+

+ +

+In GLEW 1.0.x, a global structure was used for this task. To ensure +binary compatibility between releases, the struct was replaced with a +set of variables. +

+ +

+You can also check for core OpenGL functionality. For example, to +see if OpenGL 1.3 is supported, do the following: +

+ +

+if (GLEW_VERSION_1_3)
+{
+  /* Yay! OpenGL 1.3 is supported! */
+}
+

+ +

+In general, you can check if GLEW_{extension_name} or +GLEW_VERSION_{version} is true or false. +

+ +

+It is also possible to perform extension checks from string +input. Starting from the 1.3.0 release, use glewIsSupported +to check if the required core or extension functionality is +available: +

+ +

+if (glewIsSupported("GL_VERSION_1_4  GL_ARB_point_sprite"))
+{
+  /* Great, we have OpenGL 1.4 + point sprites. */
+}
+

+ +

+For extensions only, glewGetExtension provides a slower alternative +(GLEW 1.0.x-1.2.x). Note that in the 1.3.0 release +glewGetExtension was replaced with +glewIsSupported. +

+ +

+if (glewGetExtension("GL_ARB_fragment_program"))
+{
+  /* Looks like ARB_fragment_program is supported. */
+}
+

+ +

Experimental Drivers

+ +

+GLEW obtains information on the supported extensions from the graphics +driver. Experimental or pre-release drivers, however, might not +report every available extension through the standard mechanism, in +which case GLEW will report it unsupported. To circumvent this +situation, the glewExperimental global switch can be turned +on by setting it to GL_TRUE before calling +glewInit(), which ensures that all extensions with valid +entry points will be exposed. +

+ +

Platform Specific Extensions

+ +

+Platform specific extensions are separated into two header files: +wglew.h and glxew.h, which define the available +WGL and GLX extensions. To determine if a certain +extension is supported, query WGLEW_{extension name} or +GLXEW_{extension_name}. For example: +

+ +

+#include <GL/wglew.h>
+
+if (WGLEW_ARB_pbuffer)
+{
+  /* OK, we can use pbuffers. */
+}
+else
+{
+  /* Sorry, pbuffers will not work on this platform. */
+}
+

+ +

+Alternatively, use wglewIsSupported or +glxewIsSupported to check for extensions from a string: +

+ +

+if (wglewIsSupported("WGL_ARB_pbuffer"))
+{
+  /* OK, we can use pbuffers. */
+}
+

+ +

Utilities

+ +

+GLEW provides two command-line utilities: one for creating a list of +available extensions and visuals; and another for verifying extension +entry points. +

+ +

visualinfo: extensions and visuals

+ +

+visualinfo is an extended version of glxinfo. The +Windows version creates a file called visualinfo.txt, which +contains a list of available OpenGL, WGL, and GLU extensions as well +as a table of visuals aka. pixel formats. Pbuffer and MRT capable +visuals are also included. For additional usage information, type +visualinfo -h. +

+ +

glewinfo: extension verification utility

+ +

+glewinfo allows you to verify the entry points for the +extensions supported on your platform. The Windows version +reports the results to a text file called glewinfo.txt. The +Unix version prints the results to stdout. +

+ +

Windows usage:

+
glewinfo [-pf <id>]
+ +

where <id> is the pixel format id for which the +capabilities are displayed.

+ +

Unix usage:

+
glewinfo [-display <dpy>] [-visual <id>]
+ +

where <dpy> is the X11 display and <id> is +the visual id for which the capabilities are displayed.

+ diff --git a/Externals/GLew/auto/doc/credits.html b/Externals/GLew/auto/doc/credits.html new file mode 100644 index 0000000000..7f1b8d9a87 --- /dev/null +++ b/Externals/GLew/auto/doc/credits.html @@ -0,0 +1,25 @@ +

Credits

+ +

+GLEW was developed by Milan +Ikits and Marcelo +Magallon. They also perform occasional maintainance to make sure +that GLEW stays in mint condition. Aaron Lefohn, Joe Kniss, and Chris +Wyman were the first users and also assisted with the design and +debugging process. The acronym GLEW originates from Aaron Lefohn. +Pasi Kärkkäinen identified and fixed several problems with +GLX and SDL. Nate Robins created the wglinfo utility, to +which modifications were made by Michael Wimmer. +

+ +

Copyright

+ +

+GLEW is originally derived from the EXTGL project by Lev Povalahev. +The source code is licensed under the Modified BSD +License, the Mesa 3-D License (MIT +License), and the Khronos License (MIT +License). The automatic code generation scripts are released under +the GNU GPL. +

diff --git a/Externals/GLew/auto/doc/index.html b/Externals/GLew/auto/doc/index.html new file mode 100644 index 0000000000..246d2353ca --- /dev/null +++ b/Externals/GLew/auto/doc/index.html @@ -0,0 +1,100 @@ +

+The OpenGL Extension Wrangler Library (GLEW) is a cross-platform +open-source C/C++ extension loading library. GLEW provides efficient +run-time mechanisms for determining which OpenGL extensions are +supported on the target platform. OpenGL core and extension +functionality is exposed in a single header file. GLEW has been +tested on a variety of operating systems, including Windows, Linux, +Mac OS X, FreeBSD, Irix, and Solaris. +

+ +

Download Center

+

+GLEW is distributed +as source and precompiled binaries. The latest release is +1.5.4 +[04-21-10]: +

+

+

+

+ + + +
+ + + + + + + + + + + + + + + +
Source +ZIP |  +TGZ
Binaries +Windows 32-bit |  +64-bit  +
+
+

+

+An up-to-date copy is also available from the project +repository: +

+

+svn co https://glew.svn.sourceforge.net/svnroot/glew/trunk/glew glew +

+ +

Supported Extensions

+

+The latest release contains support for OpenGL 3.3, OpenGL 4.0 and the following extensions: +

+ + +

News

+
    +
  • [04-21-10] GLEW 1.5.4 adds support for OpenGL 3.3, OpenGL 4.0 and new extensions, fixes bugs
  • +
  • [02-28-10] GLEW 1.5.3 fixes minor bugs and adds three new extensions
  • +
  • [12-31-09] GLEW 1.5.2 adds support for OpenGL 3.1, OpenGL 3.2 and new extensions
  • +
  • [11-03-08] GLEW 1.5.1 adds support for OpenGL 3.0 and 31 new extensions
  • +
  • [12-27-07] GLEW 1.5.0 is released under less restrictive licenses
  • +
  • [04-27-07] GLEW 1.4.0 is released
  • +
  • [03-08-07] GLEW is included in the NVIDIA OpenGL SDK
  • +
  • [03-04-07] GLEW 1.3.6 is released
  • +
  • [02-28-07] Repository is migrated to SVN
  • +
  • [02-25-07] GLEW is included in the OpenGL SDK
  • +
  • [11-21-06] GLEW 1.3.5 adds OpenGL 2.1 and NVIDIA G80 extensions
  • +
  • [03-04-06] GLEW 1.3.4 adds support for five new extensions
  • +
  • [05-16-05] GLEW 1.3.3 is released
  • +
  • [03-16-05] GLEW 1.3.2 adds support for GL_APPLE_pixel_buffer
  • +
  • [02-11-05] gljava and sdljava provide a Java binding to OpenGL via GLEW
  • +
  • [02-02-05] GLEW 1.3.1 adds support for GL_EXT_framebuffer_object
  • +
  • [01-04-05] GLEW 1.3.0 adds core OpenGL 2.0 support plus many enhancements
  • +
  • [12-22-04] GLEWpy Python wrapper announced
  • +
  • [12-12-04] Mailing lists created on sourceforge
  • +
  • [12-06-04] GLEW 1.2.5 adds new extensions and support for FreeBSD
  • +
+ +

Links

+ + diff --git a/Externals/GLew/auto/doc/install.html b/Externals/GLew/auto/doc/install.html new file mode 100644 index 0000000000..448aafd819 --- /dev/null +++ b/Externals/GLew/auto/doc/install.html @@ -0,0 +1,126 @@ +

Installation

+ +

+To use the shared library version of GLEW, you need to copy the +headers and libraries into their destination directories. On Windows +this typically boils down to copying: +

+ + + + + + + + + + +
bin/glew32.dll    to    %SystemRoot%/system32
lib/glew32.lib    to    {VC Root}/Lib
include/GL/glew.h    to    {VC Root}/Include/GL
include/GL/wglew.h    to    {VC Root}/Include/GL
+

+

+ +

+where {VC Root} is the Visual C++ root directory, typically +C:/Program Files/Microsoft Visual Studio/VC98 for Visual +Studio 6.0 or C:/Program Files/Microsoft Visual +Studio .NET 2003/Vc7/PlatformSDK for Visual Studio .NET. +

+ +

+On Unix, typing make install will attempt to install GLEW +into /usr/include/GL and /usr/lib. You can +customize the installation target via the GLEW_DEST +environment variable if you do not have write access to these +directories. +

+ +

Building Your Project with GLEW

+

+There are two ways to build your project with GLEW. +

+

Including the source files / project file

+

+The simpler but less flexible way is to include glew.h and +glew.c into your project. On Windows, you also need to +define the GLEW_STATIC preprocessor token when building a +static library or executable, and the GLEW_BUILD preprocessor +token when building a dll. You also need to replace +<GL/gl.h> and <GL/glu.h> with +<glew.h> in your code and set the appropriate include +flag (-I) to tell the compiler where to look for it. For +example: +

+

+#include <glew.h>
+#include <GL/glut.h>
+<gl, glu, and glut functionality is available here>
+

+

+Depending on where you put glew.h you may also need to change +the include directives in glew.c. Note that if you are using +GLEW together with GLUT, you have to include glew.h first. +In addition, glew.h includes glu.h, so you do not +need to include it separately. +

+

+On Windows, you also have the option of adding the supplied project +file glew_static.dsp to your workspace (solution) and compile +it together with your other projects. In this case you also need to +change the GLEW_BUILD preprocessor constant to +GLEW_STATIC when building a static library or executable, +otherwise you get build errors. +

+

+Note that GLEW does not use the C +runtime library, so it does not matter which version (single-threaded, +multi-threaded or multi-threaded DLL) it is linked with (without +debugging information). It is, however, always a good idea to compile all +your projects including GLEW with the same C runtime settings. +

+ +

Using GLEW as a shared library

+ +

+Alternatively, you can use the provided project files / makefile to +build a separate shared library you can link your projects with later. +In this case the best practice is to install glew.h, +glew32.lib, and glew32.dll / libGLEW.so to +where the OpenGL equivalents gl.h, opengl32.lib, and +opengl32.dll / libGL.so are located. Note that you +need administrative privileges to do this. If you do not have +administrator access and your system administrator will not do it for +you, you can install GLEW into your own lib and include subdirectories +and tell the compiler where to find it. Then you can just replace +<GL/gl.h> with <GL/glew.h> in your +program: +

+ +

+#include <GL/glew.h>
+#include <GL/glut.h>
+<gl, glu, and glut functionality is available here>
+

+ +

+or: +

+ +

+#include <GL/glew.h>
+<gl and glu functionality is available here>
+

+ +

+Remember to link your project with glew32.lib, +glu32.lib, and opengl32.lib on Windows and +libGLEW.so, libGLU.so, and libGL.so on +Unix (-lGLEW -lGLU -lGL). +

+ +

+It is important to keep in mind that glew.h includes neither +windows.h nor gl.h. Also, GLEW will warn you by +issuing a preprocessor error in case you have included gl.h, +glext.h, or glATI.h before glew.h. +

+ diff --git a/Externals/GLew/auto/doc/log.html b/Externals/GLew/auto/doc/log.html new file mode 100644 index 0000000000..44183ce97b --- /dev/null +++ b/Externals/GLew/auto/doc/log.html @@ -0,0 +1,602 @@ +

Change Log

+ +
+
    +
  • 1.5.4 [04-21-10] +
      +
    • New features: +
        +
      • Support for OpenGL 3.3 +
      • Support for OpenGL 4.0 +
      +
    • New extensions: +
        +
      • GL_AMD_conservative_depth +
      • GL_ARB_blend_func_extended +
      • GL_ARB_draw_indirect +
      • GL_ARB_explicit_attrib_location +
      • GL_ARB_gpu_shader5 +
      • GL_ARB_gpu_shader_fp64 +
      • GL_ARB_occlusion_query2 +
      • GL_ARB_sampler_objects +
      • GL_ARB_shader_bit_encoding +
      • GL_ARB_shader_subroutine +
      • GL_ARB_shading_language_include +
      • GL_ARB_tessellation_shader +
      • GL_ARB_texture_buffer_object_rgb32 +
      • GL_ARB_texture_compression_bptc +
      • GL_ARB_texture_rgb10_a2ui +
      • GL_ARB_texture_swizzle +
      • GL_ARB_timer_query +
      • GL_ARB_transform_feedback2 +
      • GL_ARB_transform_feedback3 +
      • GL_ARB_vertex_type_2_10_10_10_rev +
      • GL_EXT_shader_image_load_store +
      • GL_EXT_vertex_attrib_64bit +
      • GL_NV_gpu_program5 +
      • GL_NV_gpu_program_fp64 +
      • GL_NV_gpu_shader5 +
      • GL_NV_tessellation_program5 +
      • GL_NV_vertex_attrib_integer_64bit +
      • GLX_ARB_vertex_buffer_object +
      +
    • Bug fixes: +
        +
      • Parameter constness fix for glPointParameteriv and glPointParameterfv +
      +
    +
+ +
+
    +
  • 1.5.3 [02-28-10] +
      +
    • New extensions: +
        +
      • GLX_INTEL_swap_event +
      • GL_AMD_seamless_cubemap_per_texture +
      • GL_AMD_shader_stencil_export +
      +
    • Bug fixes: +
        +
      • Correct version detection for GL 3.1 and 3.2 +
      • Missing 3.1 enumerants +
      • Add glew.pc +
      +
    +
+ +
+
    +
  • 1.5.2 [12-31-09] +
      +
    • New features: +
        +
      • Support for OpenGL 3.1 +
      • Support for OpenGL 3.2 +
      +
    • New extensions: +
        +
      • GL_AMD_draw_buffers_blend +
      • GL_AMD_performance_monitor +
      • GL_AMD_texture_texture4 +
      • GL_AMD_vertex_shader_tessellator +
      • GL_APPLE_aux_depth_stencil +
      • GL_APPLE_object_purgeable +
      • GL_APPLE_rgb_422 +
      • GL_APPLE_row_bytes +
      • GL_APPLE_vertex_program_evaluators +
      • GL_ARB_compatibility +
      • GL_ARB_copy_buffer +
      • GL_ARB_depth_clamp +
      • GL_ARB_draw_buffers_blend +
      • GL_ARB_draw_elements_base_vertex +
      • GL_ARB_fragment_coord_conventions +
      • GL_ARB_provoking_vertex +
      • GL_ARB_sample_shading +
      • GL_ARB_seamless_cube_map +
      • GL_ARB_shader_texture_lod +
      • GL_ARB_sync +
      • GL_ARB_texture_cube_map_array +
      • GL_ARB_texture_gather +
      • GL_ARB_texture_multisample +
      • GL_ARB_texture_query_lod +
      • GL_ARB_uniform_buffer_object +
      • GL_ARB_vertex_array_bgra +
      • GL_ATI_meminfo +
      • GL_EXT_provoking_vertex +
      • GL_EXT_separate_shader_objects +
      • GL_EXT_texture_snorm +
      • GL_NV_copy_image +
      • GL_NV_parameter_buffer_object2 +
      • GL_NV_shader_buffer_load +
      • GL_NV_texture_barrier +
      • GL_NV_transform_feedback2 +
      • GL_NV_vertex_buffer_unified_memory +
      • WGL_AMD_gpu_association +
      • WGL_ARB_create_context_profile +
      • WGL_NV_copy_image +
      • GLX_ARB_create_context_profile +
      • GLX_EXT_swap_control +
      • GLX_NV_copy_image +
      +
    • Bug fixes: +
        +
      • DOS line endings for windows .zip archives only. +
      • glTransformFeedbackVaryings arguments. +
      • Resource leak in glewinfo and visualinfo tools. +
      • WIN32_LEAN_AND_MEAN preprocessor pollution. +
      • Fixed version detection for GLEW_VERSION_2_1 and GLEW_VERSION_3_0. +
      • MesaGLUT glut.h GLAPIENTRY dependency. +
      • glFramebufferTextureLayer correction. +
      • OSX compiler warnings resolved. +
      • Cygwin linking to opengl32 by default, rather than X11 OpenGL. +
      • SnowLeopard (OSX 10.6) gl.h detection. +
      • Use $(STRIP) consistently. +
      +
    +
+ +
+
    +
  • 1.5.1 [11-03-08] +
      +
    • New features: +
        +
      • Support for OpenGL 3.0 +
      +
    • New extensions: +
        +
      • GL_ARB_depth_buffer_float +
      • GL_ARB_draw_instance, +
      • GL_ARB_framebuffer_object +
      • GL_ARB_framebuffer_sRGB +
      • GL_ARB_geometry_shader4 +
      • GL_ARB_half_float_pixel +
      • GL_ARB_half_float_vertex +
      • GL_ARB_instanced_arrays +
      • GL_ARB_map_buffer_range +
      • GL_ARB_texture_buffer_object +
      • GL_ARB_texture_compression_rgtc +
      • GL_ARB_vertex_array_object +
      • GL_EXT_direct_state_access +
      • GL_EXT_texture_swizzle +
      • GL_EXT_transform_feedback +
      • GL_EXT_vertex_array_bgra +
      • GL_NV_conditional_render +
      • GL_NV_explicit_multisample +
      • GL_NV_present_video +
      • GL_SGIS_point_line_texgen +
      • GL_SGIX_convolution_accuracy +
      • WGL_ARB_create_context +
      • WGL_ARB_framebuffer_sRGB +
      • WGL_NV_present_video +
      • WGL_NV_swap_group +
      • WGL_NV_video_output +
      • GLX_ARB_create_context +
      • GLX_ARB_framebuffer_sRGB +
      • GLX_NV_present_video +
      • GLX_NV_swap_group +
      • GLX_NV_video_output +
      +
    • Bug fixes: +
        +
      • Licensing issues with documentation +
      • Problems with long long and _MSC_VER on MINGW +
      • Incorrect parameter for glGetUniformLocation +
      • glewGetExtension fails on last entry +
      • Incomplete GL_NV_texture_shader tokens +
      • Scripting problems on Cygwin +
      • Incorrect definition for GLint on OS X +
      +
    +
+ +
+
    +
  • 1.5.0 [12-27-07] +
      +
    • New features: +
        +
      • Licensing change (BSD, Mesa 3-D, Khronos) +
      • Switch to using registry on www.opengl.org +
      • Support for major and minor version strings +
      +
    • New extensions: +
        +
      • GL_APPLE_flush_buffer_range +
      • GL_GREMEDY_frame_terminator +
      • GLX_EXT_texture_from_pixmap +
      +
    • Bug fixes: +
        +
      • Incorrent 64-bit type definitions +
      • Do not strip static library on install +
      • Missing tokens in GL_ATI_fragment_shader and WGL_{ARB,EXT}_make_current_read +
      • Missing tokens in GL_VERSION_2_1 +
      • Missing functions in GL_VERSION_1_4 +
      • Incorrect parameter type for glXCopyContext +
      +
    +
+
+
    +
  • 1.4.0 [04-27-07] +
      +
    • New features: +
        +
      • Extension variables are declared const to avoid possible +corruption of their values +
      +
    • New extensions: +
        +
      • GL_NV_depth_range_unclamped +
      +
    • Bug fixes: +
        +
      • Incorrect tokens in GL_NV_transform_feedback and GL_NV_framebuffer_multisample_coverage +
      • Incorrect function names in GL_EXT_gpu_program_parameters +
      • Missing tokens in GL_EXT_framebuffer_multisample +
      • GLEW_MX initialization problem for WGL_{ARB,EXT}_extensions_string +
      +
    +
+
+
    +
  • 1.3.6 [03-04-07] +
      +
    • New extensions: +
        +
      • GL_ATI_shader_texture_lod +
      • GL_EXT_gpu_program_parameters +
      • GL_NV_geometry_shader4 +
      • WGL_NV_gpu_affinity +
      • GLX_SGIX_hyperpipe +
      +
    • Bug fixes: +
        +
      • Missing include guards in glxew.h +
      • Makefile and install problems for Cygwin builds +
      • Install problem for Linux AMD64 builds +
      • Incorrent token in GL_ATI_texture_compression_3dc +
      • Missing tokens from GL_ATIX_point_sprites +
      +
    +
+
+
    +
  • 1.3.5 [11-21-06] +
      +
    • New features: +
        +
      • Support for core OpenGL 2.1 +
      • Debug support for glewIsSupported +
      +
    • New extensions: +
        +
      • GL_EXT_bindable_uniform +
      • GL_EXT_draw_buffers2 +
      • GL_EXT_draw_instanced +
      • GL_EXT_framebuffer_sRGB +
      • GL_EXT_geometry_shader4 +
      • GL_EXT_gpu_shader4 +
      • GL_EXT_packed_float +
      • GL_EXT_texture_array +
      • GL_EXT_texture_buffer_object +
      • GL_EXT_texture_compression_latc +
      • GL_EXT_texture_compression_rgtc +
      • GL_EXT_texture_integer +
      • GL_EXT_texture_shared_exponent +
      • GL_EXT_timer_query +
      • GL_NV_depth_buffer_float +
      • GL_NV_fragment_program4 +
      • GL_NV_framebuffer_multisample_coverage +
      • GL_NV_geometry_program4 +
      • GL_NV_gpu_program4 +
      • GL_NV_parameter_buffer_object +
      • GL_NV_transform_feedback +
      • GL_NV_vertex_program4 +
      • GL_OES_byte_coordinates +
      • GL_OES_compressed_paletted_texture +
      • GL_OES_read_format +
      • GL_OES_single_precision +
      • WGL_EXT_pixel_format_packed_float +
      • WGL_EXT_framebuffer_sRGB +
      • GLX_EXT_fbconfig_packed_float +
      • GLX_EXT_framebuffer_sRGB +
      +
    • Bug fixes: +
        +
      • Wrong GLXContext definition on Solaris +
      • Makefile problem for parallel builds +
      +
    +
+
+
    +
  • 1.3.4 [03-04-06] +
      +
    • New extensions: +
        +
      • GL_EXT_framebuffer_blit +
      • GL_EXT_framebuffer_multisample +
      • GL_EXT_packed_depth_stencil +
      • GL_MESAX_texture_stack +
      • WGL_3DL_stereo_control +
      +
    +
      +
    • Bug fixes: +
        +
      • glBlendEquation missing from GL_ARB_imaging +
      • Wrong APIENTRY definition for Cygwin +
      • Incorrect OS X OpenGL types +
      • Unix 64-bit installation patch +
      +
    +
+
+
    +
  • 1.3.3 [05-16-05] +
      +
    • New feature: +
        +
      • Code generation option to split source into multiple files +
      +
    +
      +
    • Bug fixes: +
        +
      • OpenGL 2.0 core initialization problems +
      • Wrong value for token GL_SHADER_TYPE +
      • Missing tokens in GL_ATI_fragment_shader +
      • Missing entry points in GL_ARB_transpose_matrix +
      +
    +
+
+
    +
  • 1.3.2 [03-16-05] +
      +
    • New extension: +
        +
      • GL_APPLE_pixel_buffer +
      +
    • Bug fixes: +
        +
      • Missing OpenGL 2.0 entry points +
      • Missing tokens in GL_SGIX_shadow +
      • MinGW makefile problem +
      • Check for incorrect OpenGL version string on SiS hardware +
      • Documentation update to meet the HTML 4.01 Transitional specification +
      +
    +
+
+
    +
  • 1.3.1 [02-02-05] +
      +
    • New features: +
        +
      • Consistent Unix and Windows versioning +
      +
    • New extensions: +
        +
      • GL_EXT_framebuffer_object +
      • GL_ARB_pixel_buffer_object +
      +
    • Bug fixes: +
        +
      • Missing OpenGL 2.0 tokens +
      • Incorrect typedefs (GLhandleARB and GLhalf) +
      • Borland compiler problems +
      +
    +
+
+
    +
  • 1.3.0 [01-04-05] +
      +
    • New features: +
        +
      • Support for core OpenGL 2.0 +
      • glewIsSupported provides efficient string-based extension checks +
      • Custom code generation from a list of extensions +
      • Makefile changes +
      +
    • New extensions: +
        +
      • WGL_ATI_render_texture_rectangle +
      +
    • Bug fixes: +
        +
      • Incorrect function signature in OpenGL 1.5 core +
      +
    +
+
+
    +
  • 1.2.5 [12-06-04] +
      +
    • New extensions: +
        +
      • GL_ATI_texture_compression_3dc +
      • GL_EXT_Cg_shader +
      • GL_EXT_draw_range_elements +
      • GL_KTX_buffer_region +
      +
    • Bug fixes: +
        +
      • OpenGL version detection bug +
      • Problems with wxWindows and MinGW compilation +
      • visualinfo compilation problem with GLEW_MX specified +
      • Wrong token name in OpenGL 1.5 core +
      +
    • Support for FreeBSD +
    +
+
+
    +
  • 1.2.4 [09-06-04] +
      +
    • Added ARB_draw_buffers and ARB_texture_rectangle +
    • Fixed bug in ARB_shader_objects +
    • Replaced wglinfo with visualinfo +
    +
+
+
    +
  • 1.2.3 [06-10-04] +
      +
    • Added GL_NV_fragment_program2, GL_NV_fragment_program_option, GL_NV_vertex_program2_option, GL_NV_vertex_program3 +
    • Bug fix in GL_ARB_vertex_blend +
    +
+
+
    +
  • 1.2.2 [05-08-04] +
      +
    • Added GL_EXT_pixel_buffer_object, removed GL_NV_element_array +
    • Fixed GLEW_MX problems +
    • Bug fix in GL_EXT_texture_rectangle and wglinfo +
    +
+
+
    +
  • 1.2.1 [03-18-04] +
      +
    • Bug fix in OpenGL version query (early release of 1.2.0 contained this bug) +
    • Bug fix in GL_ARB_shader_objects and temporary bug fix in GL_ARB_vertex_shader +
    • Added flags on GDI support and multisampling to wglinfo +
    +
+
+
    +
  • 1.2.0 [02-19-04] +
      +
    • Added full OpenGL 1.5 support +
    • Added support for multiple rendering contexts with different capabilities +
    • Added command line flags to glewinfo for selecting displays and visuals +
    • Added GLX_SGIS_multisample, GLX_SUN_video_resize, and GL_SUN_read_video_pixels +
    • Added MinGW/MSYS support +
    • Bug fixes in GL_ARB_shader_objects and the OS X build +
    +
+
+
    +
  • 1.1.4 [12-15-03] +
      +
    • Added GL_APPLE_float_pixels, GL_APPLE_texture_range, +GL_EXT_texture_cube_map, GL_EXT_texture_edge_clamp, +GLX_ATI_pixel_format_float, and GLX_ATI_render_texture +
    • Bug fixes in GL_ATI_map_object_buffer and GL_ATI_fragment_shader +
    +
+
+
    +
  • 1.1.3 [10-28-03] +
      +
    • Added Solaris and Darwin support +
    • Added GL_ARB_fragment_shader, GL_ARB_shader_objects, and GL_ARB_vertex_shader +
    • Fixed bug in GL_WIN_swap_hint +
    • Removed glewinfo's dependency on GLUT +
    +
+
+
    +
  • 1.1.2 [09-15-03] +
      +
    • Removed dependency on WGL_{ARB,EXT}_extensions_string to make GLEW run on Matrox cards +
    • Added glewGetString for querying the GLEW version string +
    +
+
+
    +
  • 1.1.1 [08-11-03] +
      +
    • Added GLX_NV_float_buffer, GL_ARB_shading_language_100, and GL_ARB_texture_non_power_of_two +
    • Fixed bug in GL_ARB_vertex_buffer_object +
    • Minor updates in documentation +
    +
+
+
    +
  • 1.1.0 [07-08-03] +
      +
    • Added automatic code generation +
    • Added almost every extension in the registry +
    • Added separate namespace +
    • Added Irix support +
    • Updated documentation +
    +
+
+
    +
  • 1.0.7 [06-29-03] +
      +
    • Added GL_EXT_depth_bounds_test +
    • Fixed typos +
    +
+
+
    +
  • 1.0.6 [05-05-03] +
      +
    • Added ARB_vertex_buffer_object and NV_half_float +
    • Updated wglinfo +
    • Temporary Linux bug fixes (problems with SDL and MESA) +
    +
+
+
    +
  • 1.0.5 [02-17-03] +
      +
    • Bug fixes +
    • Added wglinfo +
    • Updated documentation +
    +
+
+
    +
  • 1.0.4 [02-02-03] +
      +
    • Added NV_texture_expand_normal +
    • Added mingw support +
    • Updated documentation +
    +
+
+
    +
  • 1.0.3 [01-09-03] +
      +
    • Cleaned up ATI extensions +
    • Changed function prototypes to match glext.h +
    • Added EXT_texture3D +
    • Fixed typos in ATI_vertex_attrib_array_object and ATI_draw_buffers +
    +
+
+
    +
  • 1.0.2 [12-21-02] +
      +
    • Added list of supported extensions to documentation +
    • Added NV_half_float and NV_texgen_emboss +
    +
+
+
    +
  • 1.0.1 [12-17-02] +
      +
    • Bug fixes +
    • Added glewGetExtension +
    +
+
+
    +
  • 1.0.0 [12-12-02] +
      +
    • Initial release +
    +
+
+ diff --git a/Externals/GLew/auto/extensions/.dummy b/Externals/GLew/auto/extensions/.dummy new file mode 100644 index 0000000000..e69de29bb2 diff --git a/Externals/GLew/auto/extensions/GLX_3DFX_multisample b/Externals/GLew/auto/extensions/GLX_3DFX_multisample new file mode 100644 index 0000000000..01b2150fe4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_3DFX_multisample @@ -0,0 +1,5 @@ +GLX_3DFX_multisample +http://www.opengl.org/registry/specs/3DFX/3dfx_multisample.txt +GLX_3DFX_multisample + GLX_SAMPLE_BUFFERS_3DFX 0x8050 + GLX_SAMPLES_3DFX 0x8051 diff --git a/Externals/GLew/auto/extensions/GLX_ARB_create_context b/Externals/GLew/auto/extensions/GLX_ARB_create_context new file mode 100644 index 0000000000..f7b7de60ec --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ARB_create_context @@ -0,0 +1,9 @@ +GLX_ARB_create_context +http://www.opengl.org/registry/specs/ARB/glx_create_context.txt +GLX_ARB_create_context + GLX_CONTEXT_DEBUG_BIT_ARB 0x0001 + GLX_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 + GLX_CONTEXT_MAJOR_VERSION_ARB 0x2091 + GLX_CONTEXT_MINOR_VERSION_ARB 0x2092 + GLX_CONTEXT_FLAGS_ARB 0x2094 + GLXContext glXCreateContextAttribsARB (Display* dpy, GLXFBConfig config, GLXContext share_context, Bool direct, const int *attrib_list) diff --git a/Externals/GLew/auto/extensions/GLX_ARB_create_context_profile b/Externals/GLew/auto/extensions/GLX_ARB_create_context_profile new file mode 100644 index 0000000000..15540ce0a1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ARB_create_context_profile @@ -0,0 +1,6 @@ +GLX_ARB_create_context_profile +http://www.opengl.org/registry/specs/ARB/glx_create_context.txt +GLX_ARB_create_context_profile + GLX_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 + GLX_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 + GLX_CONTEXT_PROFILE_MASK_ARB 0x9126 diff --git a/Externals/GLew/auto/extensions/GLX_ARB_fbconfig_float b/Externals/GLew/auto/extensions/GLX_ARB_fbconfig_float new file mode 100644 index 0000000000..0e93c1b28c --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ARB_fbconfig_float @@ -0,0 +1,5 @@ +GLX_ARB_fbconfig_float +http://www.opengl.org/registry/specs/ARB/color_buffer_float.txt +GLX_ARB_fbconfig_float + GLX_RGBA_FLOAT_BIT 0x00000004 + GLX_RGBA_FLOAT_TYPE 0x20B9 diff --git a/Externals/GLew/auto/extensions/GLX_ARB_framebuffer_sRGB b/Externals/GLew/auto/extensions/GLX_ARB_framebuffer_sRGB new file mode 100644 index 0000000000..b1b0ced03f --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ARB_framebuffer_sRGB @@ -0,0 +1,4 @@ +GLX_ARB_framebuffer_sRGB +http://www.opengl.org/registry/specs/ARB/framebuffer_sRGB.txt +GLX_ARB_framebuffer_sRGB + GLX_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20B2 diff --git a/Externals/GLew/auto/extensions/GLX_ARB_get_proc_address b/Externals/GLew/auto/extensions/GLX_ARB_get_proc_address new file mode 100644 index 0000000000..5c066d7d00 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ARB_get_proc_address @@ -0,0 +1,4 @@ +GLX_ARB_get_proc_address +http://oss.sgi.com/projects/ogl-sample/registry/ARB/get_proc_address.txt +GLX_ARB_get_proc_address + extern void ( * glXGetProcAddressARB (const GLubyte *procName)) (void); diff --git a/Externals/GLew/auto/extensions/GLX_ARB_multisample b/Externals/GLew/auto/extensions/GLX_ARB_multisample new file mode 100644 index 0000000000..abae704a9c --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ARB_multisample @@ -0,0 +1,5 @@ +GLX_ARB_multisample +http://www.opengl.org/registry/specs/ARB/multisample.txt +GLX_ARB_multisample + GLX_SAMPLE_BUFFERS_ARB 100000 + GLX_SAMPLES_ARB 100001 diff --git a/Externals/GLew/auto/extensions/GLX_ARB_vertex_buffer_object b/Externals/GLew/auto/extensions/GLX_ARB_vertex_buffer_object new file mode 100644 index 0000000000..cb570ce229 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ARB_vertex_buffer_object @@ -0,0 +1,4 @@ +GLX_ARB_vertex_buffer_object +http://www.opengl.org/registry/specs/ARB/vertex_buffer_object.txt +GLX_ARB_vertex_buffer_object + GLX_CONTEXT_ALLOW_BUFFER_BYTE_ORDER_MISMATCH_ARB 0x2095 diff --git a/Externals/GLew/auto/extensions/GLX_ATI_pixel_format_float b/Externals/GLew/auto/extensions/GLX_ATI_pixel_format_float new file mode 100644 index 0000000000..854ca716ba --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ATI_pixel_format_float @@ -0,0 +1,4 @@ +GLX_ATI_pixel_format_float + +GLX_ATI_pixel_format_float + GLX_RGBA_FLOAT_ATI_BIT 0x00000100 diff --git a/Externals/GLew/auto/extensions/GLX_ATI_render_texture b/Externals/GLew/auto/extensions/GLX_ATI_render_texture new file mode 100644 index 0000000000..254eb9f3bc --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_ATI_render_texture @@ -0,0 +1,41 @@ +GLX_ATI_render_texture + +GLX_ATI_render_texture + GLX_BIND_TO_TEXTURE_RGB_ATI 0x9800 + GLX_BIND_TO_TEXTURE_RGBA_ATI 0x9801 + GLX_TEXTURE_FORMAT_ATI 0x9802 + GLX_TEXTURE_TARGET_ATI 0x9803 + GLX_MIPMAP_TEXTURE_ATI 0x9804 + GLX_TEXTURE_RGB_ATI 0x9805 + GLX_TEXTURE_RGBA_ATI 0x9806 + GLX_NO_TEXTURE_ATI 0x9807 + GLX_TEXTURE_CUBE_MAP_ATI 0x9808 + GLX_TEXTURE_1D_ATI 0x9809 + GLX_TEXTURE_2D_ATI 0x980A + GLX_MIPMAP_LEVEL_ATI 0x980B + GLX_CUBE_MAP_FACE_ATI 0x980C + GLX_TEXTURE_CUBE_MAP_POSITIVE_X_ATI 0x980D + GLX_TEXTURE_CUBE_MAP_NEGATIVE_X_ATI 0x980E + GLX_TEXTURE_CUBE_MAP_POSITIVE_Y_ATI 0x980F + GLX_TEXTURE_CUBE_MAP_NEGATIVE_Y_ATI 0x9810 + GLX_TEXTURE_CUBE_MAP_POSITIVE_Z_ATI 0x9811 + GLX_TEXTURE_CUBE_MAP_NEGATIVE_Z_ATI 0x9812 + GLX_FRONT_LEFT_ATI 0x9813 + GLX_FRONT_RIGHT_ATI 0x9814 + GLX_BACK_LEFT_ATI 0x9815 + GLX_BACK_RIGHT_ATI 0x9816 + GLX_AUX0_ATI 0x9817 + GLX_AUX1_ATI 0x9818 + GLX_AUX2_ATI 0x9819 + GLX_AUX3_ATI 0x981A + GLX_AUX4_ATI 0x981B + GLX_AUX5_ATI 0x981C + GLX_AUX6_ATI 0x981D + GLX_AUX7_ATI 0x981E + GLX_AUX8_ATI 0x981F + GLX_AUX9_ATI 0x9820 + GLX_BIND_TO_TEXTURE_LUMINANCE_ATI 0x9821 + GLX_BIND_TO_TEXTURE_INTENSITY_ATI 0x9822 + void glXBindTexImageATI (Display *dpy, GLXPbuffer pbuf, int buffer) + void glXReleaseTexImageATI (Display *dpy, GLXPbuffer pbuf, int buffer) + void glXDrawableAttribATI (Display *dpy, GLXDrawable draw, const int *attrib_list) diff --git a/Externals/GLew/auto/extensions/GLX_EXT_fbconfig_packed_float b/Externals/GLew/auto/extensions/GLX_EXT_fbconfig_packed_float new file mode 100644 index 0000000000..7c7822d81a --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_fbconfig_packed_float @@ -0,0 +1,5 @@ +GLX_EXT_fbconfig_packed_float +http://developer.download.nvidia.com/opengl/specs/GL_EXT_packed_float.txt +GLX_EXT_fbconfig_packed_float + GLX_RGBA_UNSIGNED_FLOAT_TYPE_EXT 0x20B1 + GLX_RGBA_UNSIGNED_FLOAT_BIT_EXT 0x00000008 diff --git a/Externals/GLew/auto/extensions/GLX_EXT_framebuffer_sRGB b/Externals/GLew/auto/extensions/GLX_EXT_framebuffer_sRGB new file mode 100644 index 0000000000..f51c484afd --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_framebuffer_sRGB @@ -0,0 +1,4 @@ +GLX_EXT_framebuffer_sRGB +http://developer.download.nvidia.com/opengl/specs/GL_EXT_framebuffer_sRGB.txt +GLX_EXT_framebuffer_sRGB + GLX_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20B2 diff --git a/Externals/GLew/auto/extensions/GLX_EXT_import_context b/Externals/GLew/auto/extensions/GLX_EXT_import_context new file mode 100644 index 0000000000..ecca5fde00 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_import_context @@ -0,0 +1,11 @@ +GLX_EXT_import_context +http://www.opengl.org/registry/specs/EXT/import_context.txt +GLX_EXT_import_context + GLX_SHARE_CONTEXT_EXT 0x800A + GLX_VISUAL_ID_EXT 0x800B + GLX_SCREEN_EXT 0x800C + void glXFreeContextEXT (Display* dpy, GLXContext context) + GLXContextID glXGetContextIDEXT (const GLXContext context) + GLXContext glXImportContextEXT (Display* dpy, GLXContextID contextID) + int glXQueryContextInfoEXT (Display* dpy, GLXContext context, int attribute,int *value) + typedef XID GLXContextID diff --git a/Externals/GLew/auto/extensions/GLX_EXT_scene_marker b/Externals/GLew/auto/extensions/GLX_EXT_scene_marker new file mode 100644 index 0000000000..5c3fa86345 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_scene_marker @@ -0,0 +1,3 @@ +GLX_EXT_scene_marker +http://www.opengl.org/registry/specs/EXT/scene_marker.txt +GLX_EXT_scene_marker diff --git a/Externals/GLew/auto/extensions/GLX_EXT_swap_control b/Externals/GLew/auto/extensions/GLX_EXT_swap_control new file mode 100644 index 0000000000..56372c004f --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_swap_control @@ -0,0 +1,6 @@ +GLX_EXT_swap_control +http://www.opengl.org/registry/specs/EXT/swap_control.txt +GLX_EXT_swap_control + GLX_SWAP_INTERVAL_EXT 0x20F1 + GLX_MAX_SWAP_INTERVAL_EXT 0x20F2 + void glXSwapIntervalEXT (Display* dpy, GLXDrawable drawable, int interval) diff --git a/Externals/GLew/auto/extensions/GLX_EXT_texture_from_pixmap b/Externals/GLew/auto/extensions/GLX_EXT_texture_from_pixmap new file mode 100644 index 0000000000..f8352075e9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_texture_from_pixmap @@ -0,0 +1,36 @@ +GLX_EXT_texture_from_pixmap +http://www.opengl.org/registry/specs/EXT/texture_from_pixmap.txt +GLX_EXT_texture_from_pixmap + GLX_TEXTURE_1D_BIT_EXT 0x00000001 + GLX_TEXTURE_2D_BIT_EXT 0x00000002 + GLX_TEXTURE_RECTANGLE_BIT_EXT 0x00000004 + GLX_BIND_TO_TEXTURE_RGB_EXT 0x20D0 + GLX_BIND_TO_TEXTURE_RGBA_EXT 0x20D1 + GLX_BIND_TO_MIPMAP_TEXTURE_EXT 0x20D2 + GLX_BIND_TO_TEXTURE_TARGETS_EXT 0x20D3 + GLX_Y_INVERTED_EXT 0x20D4 + GLX_TEXTURE_FORMAT_EXT 0x20D5 + GLX_TEXTURE_TARGET_EXT 0x20D6 + GLX_MIPMAP_TEXTURE_EXT 0x20D7 + GLX_TEXTURE_FORMAT_NONE_EXT 0x20D8 + GLX_TEXTURE_FORMAT_RGB_EXT 0x20D9 + GLX_TEXTURE_FORMAT_RGBA_EXT 0x20DA + GLX_TEXTURE_1D_EXT 0x20DB + GLX_TEXTURE_2D_EXT 0x20DC + GLX_TEXTURE_RECTANGLE_EXT 0x20DD + GLX_FRONT_LEFT_EXT 0x20DE + GLX_FRONT_RIGHT_EXT 0x20DF + GLX_BACK_LEFT_EXT 0x20E0 + GLX_BACK_RIGHT_EXT 0x20E1 + GLX_AUX0_EXT 0x20E2 + GLX_AUX1_EXT 0x20E3 + GLX_AUX2_EXT 0x20E4 + GLX_AUX3_EXT 0x20E5 + GLX_AUX4_EXT 0x20E6 + GLX_AUX5_EXT 0x20E7 + GLX_AUX6_EXT 0x20E8 + GLX_AUX7_EXT 0x20E9 + GLX_AUX8_EXT 0x20EA + GLX_AUX9_EXT 0x20EB + void glXBindTexImageEXT (Display* display, GLXDrawable drawable, int buffer, const int *attrib_list) + void glXReleaseTexImageEXT (Display* display, GLXDrawable drawable, int buffer) diff --git a/Externals/GLew/auto/extensions/GLX_EXT_visual_info b/Externals/GLew/auto/extensions/GLX_EXT_visual_info new file mode 100644 index 0000000000..7db919cbb1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_visual_info @@ -0,0 +1,19 @@ +GLX_EXT_visual_info +http://www.opengl.org/registry/specs/EXT/visual_info.txt +GLX_EXT_visual_info + GLX_X_VISUAL_TYPE_EXT 0x22 + GLX_TRANSPARENT_TYPE_EXT 0x23 + GLX_TRANSPARENT_INDEX_VALUE_EXT 0x24 + GLX_TRANSPARENT_RED_VALUE_EXT 0x25 + GLX_TRANSPARENT_GREEN_VALUE_EXT 0x26 + GLX_TRANSPARENT_BLUE_VALUE_EXT 0x27 + GLX_TRANSPARENT_ALPHA_VALUE_EXT 0x28 + GLX_NONE_EXT 0x8000 + GLX_TRUE_COLOR_EXT 0x8002 + GLX_DIRECT_COLOR_EXT 0x8003 + GLX_PSEUDO_COLOR_EXT 0x8004 + GLX_STATIC_COLOR_EXT 0x8005 + GLX_GRAY_SCALE_EXT 0x8006 + GLX_STATIC_GRAY_EXT 0x8007 + GLX_TRANSPARENT_RGB_EXT 0x8008 + GLX_TRANSPARENT_INDEX_EXT 0x8009 diff --git a/Externals/GLew/auto/extensions/GLX_EXT_visual_rating b/Externals/GLew/auto/extensions/GLX_EXT_visual_rating new file mode 100644 index 0000000000..fc86674667 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_EXT_visual_rating @@ -0,0 +1,6 @@ +GLX_EXT_visual_rating +http://www.opengl.org/registry/specs/EXT/visual_rating.txt +GLX_EXT_visual_rating + GLX_VISUAL_CAVEAT_EXT 0x20 + GLX_SLOW_VISUAL_EXT 0x8001 + GLX_NON_CONFORMANT_VISUAL_EXT 0x800D diff --git a/Externals/GLew/auto/extensions/GLX_INTEL_swap_event b/Externals/GLew/auto/extensions/GLX_INTEL_swap_event new file mode 100644 index 0000000000..d9a7f7cf3a --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_INTEL_swap_event @@ -0,0 +1,7 @@ +GLX_INTEL_swap_event +http://www.opengl.org/registry/specs/INTEL/swap_event.txt +GLX_INTEL_swap_event + GLX_EXCHANGE_COMPLETE_INTEL 0x8180 + GLX_COPY_COMPLETE_INTEL 0x8181 + GLX_FLIP_COMPLETE_INTEL 0x8182 + GLX_BUFFER_SWAP_COMPLETE_INTEL_MASK 0x04000000 diff --git a/Externals/GLew/auto/extensions/GLX_MESA_agp_offset b/Externals/GLew/auto/extensions/GLX_MESA_agp_offset new file mode 100644 index 0000000000..5f307cd8cb --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_MESA_agp_offset @@ -0,0 +1,4 @@ +GLX_MESA_agp_offset +http://www.opengl.org/registry/specs/MESA/agp_offset.txt +GLX_MESA_agp_offset + unsigned int glXGetAGPOffsetMESA (const void* pointer) diff --git a/Externals/GLew/auto/extensions/GLX_MESA_copy_sub_buffer b/Externals/GLew/auto/extensions/GLX_MESA_copy_sub_buffer new file mode 100644 index 0000000000..b6557e76c1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_MESA_copy_sub_buffer @@ -0,0 +1,4 @@ +GLX_MESA_copy_sub_buffer +http://www.opengl.org/registry/specs/MESA/copy_sub_buffer.txt +GLX_MESA_copy_sub_buffer + void glXCopySubBufferMESA (Display* dpy, GLXDrawable drawable, int x, int y, int width, int height) diff --git a/Externals/GLew/auto/extensions/GLX_MESA_pixmap_colormap b/Externals/GLew/auto/extensions/GLX_MESA_pixmap_colormap new file mode 100644 index 0000000000..e59956c569 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_MESA_pixmap_colormap @@ -0,0 +1,4 @@ +GLX_MESA_pixmap_colormap +http://www.opengl.org/registry/specs/MESA/pixmap_colormap.txt +GLX_MESA_pixmap_colormap + GLXPixmap glXCreateGLXPixmapMESA (Display* dpy, XVisualInfo *visual, Pixmap pixmap, Colormap cmap) diff --git a/Externals/GLew/auto/extensions/GLX_MESA_release_buffers b/Externals/GLew/auto/extensions/GLX_MESA_release_buffers new file mode 100644 index 0000000000..cfd10914e1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_MESA_release_buffers @@ -0,0 +1,4 @@ +GLX_MESA_release_buffers +http://www.opengl.org/registry/specs/MESA/release_buffers.txt +GLX_MESA_release_buffers + Bool glXReleaseBuffersMESA (Display* dpy, GLXDrawable d) diff --git a/Externals/GLew/auto/extensions/GLX_MESA_set_3dfx_mode b/Externals/GLew/auto/extensions/GLX_MESA_set_3dfx_mode new file mode 100644 index 0000000000..03a263d52d --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_MESA_set_3dfx_mode @@ -0,0 +1,6 @@ +GLX_MESA_set_3dfx_mode +http://www.opengl.org/registry/specs/MESA/set_3dfx_mode.txt +GLX_MESA_set_3dfx_mode + GLX_3DFX_WINDOW_MODE_MESA 0x1 + GLX_3DFX_FULLSCREEN_MODE_MESA 0x2 + GLboolean glXSet3DfxModeMESA (GLint mode) diff --git a/Externals/GLew/auto/extensions/GLX_NV_copy_image b/Externals/GLew/auto/extensions/GLX_NV_copy_image new file mode 100644 index 0000000000..acaef8cc5f --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_NV_copy_image @@ -0,0 +1,4 @@ +GLX_NV_copy_image +http://www.opengl.org/registry/specs/NV/copy_image.txt +GLX_NV_copy_image + void glXCopyImageSubDataNV (Display *dpy, GLXContext srcCtx, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLXContext dstCtx, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth) diff --git a/Externals/GLew/auto/extensions/GLX_NV_float_buffer b/Externals/GLew/auto/extensions/GLX_NV_float_buffer new file mode 100644 index 0000000000..cc9185ee94 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_NV_float_buffer @@ -0,0 +1,4 @@ +GLX_NV_float_buffer +http://cvs1.nvidia.com/inc/GL/glxtokens.h +GLX_NV_float_buffer + GLX_FLOAT_COMPONENTS_NV 0x20B0 diff --git a/Externals/GLew/auto/extensions/GLX_NV_present_video b/Externals/GLew/auto/extensions/GLX_NV_present_video new file mode 100644 index 0000000000..0078079fa6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_NV_present_video @@ -0,0 +1,6 @@ +GLX_NV_present_video +http://www.opengl.org/registry/specs/NV/present_video.txt +GLX_NV_present_video + GLX_NUM_VIDEO_SLOTS_NV 0x20F0 + int glXBindVideoDeviceNV (Display* dpy, unsigned int video_slot, unsigned int video_device, const int *attrib_list) + unsigned int* glXEnumerateVideoDevicesNV (Display *dpy, int screen, int *nelements) diff --git a/Externals/GLew/auto/extensions/GLX_NV_swap_group b/Externals/GLew/auto/extensions/GLX_NV_swap_group new file mode 100644 index 0000000000..ec40bca3d4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_NV_swap_group @@ -0,0 +1,9 @@ +GLX_NV_swap_group +http://www.opengl.org/registry/specs/NV/glx_swap_group.txt +GLX_NV_swap_group + Bool glXBindSwapBarrierNV (Display* dpy, GLuint group, GLuint barrier) + Bool glXJoinSwapGroupNV (Display* dpy, GLXDrawable drawable, GLuint group) + Bool glXQueryFrameCountNV (Display* dpy, int screen, GLuint *count) + Bool glXQueryMaxSwapGroupsNV (Display* dpy, int screen, GLuint *maxGroups, GLuint *maxBarriers) + Bool glXQuerySwapGroupNV (Display* dpy, GLXDrawable drawable, GLuint *group, GLuint *barrier) + Bool glXResetFrameCountNV (Display* dpy, int screen) diff --git a/Externals/GLew/auto/extensions/GLX_NV_vertex_array_range b/Externals/GLew/auto/extensions/GLX_NV_vertex_array_range new file mode 100644 index 0000000000..11afe17406 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_NV_vertex_array_range @@ -0,0 +1,5 @@ +GLX_NV_vertex_array_range +http://oss.sgi.com/projects/ogl-sample/registry/NV/vertex_array_range.txt +GLX_NV_vertex_array_range + void * glXAllocateMemoryNV (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority) + void glXFreeMemoryNV (void *pointer) diff --git a/Externals/GLew/auto/extensions/GLX_NV_video_output b/Externals/GLew/auto/extensions/GLX_NV_video_output new file mode 100644 index 0000000000..1bd30fc4a6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_NV_video_output @@ -0,0 +1,19 @@ +GLX_NV_video_output +http://www.opengl.org/registry/specs/NV/glx_video_out.txt +GLX_NV_video_output + GLX_VIDEO_OUT_COLOR_NV 0x20C3 + GLX_VIDEO_OUT_ALPHA_NV 0x20C4 + GLX_VIDEO_OUT_DEPTH_NV 0x20C5 + GLX_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 + GLX_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 + GLX_VIDEO_OUT_FRAME_NV 0x20C8 + GLX_VIDEO_OUT_FIELD_1_NV 0x20C9 + GLX_VIDEO_OUT_FIELD_2_NV 0x20CA + GLX_VIDEO_OUT_STACKED_FIELDS_1_2_NV 0x20CB + GLX_VIDEO_OUT_STACKED_FIELDS_2_1_NV 0x20CC + int glXBindVideoImageNV (Display* dpy, GLXVideoDeviceNV VideoDevice, GLXPbuffer pbuf, int iVideoBuffer) + int glXGetVideoDeviceNV (Display* dpy, int screen, int numVideoDevices, GLXVideoDeviceNV *pVideoDevice) + int glXGetVideoInfoNV (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice, unsigned long *pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo) + int glXReleaseVideoDeviceNV (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice) + int glXReleaseVideoImageNV (Display* dpy, GLXPbuffer pbuf) + int glXSendPbufferToVideoNV (Display* dpy, GLXPbuffer pbuf, int iBufferType, unsigned long *pulCounterPbuffer, GLboolean bBlock) diff --git a/Externals/GLew/auto/extensions/GLX_OML_swap_method b/Externals/GLew/auto/extensions/GLX_OML_swap_method new file mode 100644 index 0000000000..1ad2d4f369 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_OML_swap_method @@ -0,0 +1,7 @@ +GLX_OML_swap_method +http://www.opengl.org/registry/specs/OML/glx_swap_method.txt +GLX_OML_swap_method + GLX_SWAP_METHOD_OML 0x8060 + GLX_SWAP_EXCHANGE_OML 0x8061 + GLX_SWAP_COPY_OML 0x8062 + GLX_SWAP_UNDEFINED_OML 0x8063 diff --git a/Externals/GLew/auto/extensions/GLX_OML_sync_control b/Externals/GLew/auto/extensions/GLX_OML_sync_control new file mode 100644 index 0000000000..5de293bc3a --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_OML_sync_control @@ -0,0 +1,8 @@ +GLX_OML_sync_control +http://www.opengl.org/registry/specs/OML/glx_sync_control.txt +GLX_OML_sync_control + Bool glXGetMscRateOML (Display* dpy, GLXDrawable drawable, int32_t* numerator, int32_t* denominator) + Bool glXGetSyncValuesOML (Display* dpy, GLXDrawable drawable, int64_t* ust, int64_t* msc, int64_t* sbc) + int64_t glXSwapBuffersMscOML (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder) + Bool glXWaitForMscOML (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder, int64_t* ust, int64_t* msc, int64_t* sbc) + Bool glXWaitForSbcOML (Display* dpy, GLXDrawable drawable, int64_t target_sbc, int64_t* ust, int64_t* msc, int64_t* sbc) diff --git a/Externals/GLew/auto/extensions/GLX_SGIS_blended_overlay b/Externals/GLew/auto/extensions/GLX_SGIS_blended_overlay new file mode 100644 index 0000000000..27cc982ff6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIS_blended_overlay @@ -0,0 +1,4 @@ +GLX_SGIS_blended_overlay +http://www.opengl.org/registry/specs/SGIS/blended_overlay.txt +GLX_SGIS_blended_overlay + GLX_BLENDED_RGBA_SGIS 0x8025 diff --git a/Externals/GLew/auto/extensions/GLX_SGIS_color_range b/Externals/GLew/auto/extensions/GLX_SGIS_color_range new file mode 100644 index 0000000000..5416dcb416 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIS_color_range @@ -0,0 +1,12 @@ +GLX_SGIS_color_range +http://www.opengl.org/registry/specs/SGIS/color_range.txt +GLX_SGIS_color_range + GLX_MAX_GREEN_SGIS 0 + GLX_MIN_RED_SGIS 0 + GLX_MIN_BLUE_SGIS 0 + GLX_MAX_RED_SGIS 0 + GLX_MAX_ALPHA_SGIS 0 + GLX_MIN_GREEN_SGIS 0 + GLX_MIN_ALPHA_SGIS 0 + GLX_EXTENDED_RANGE_SGIS 0 + GLX_MAX_BLUE_SGIS 0 diff --git a/Externals/GLew/auto/extensions/GLX_SGIS_multisample b/Externals/GLew/auto/extensions/GLX_SGIS_multisample new file mode 100644 index 0000000000..9d22b47b6e --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIS_multisample @@ -0,0 +1,5 @@ +GLX_SGIS_multisample +http://www.opengl.org/registry/specs/SGIS/multisample.txt +GLX_SGIS_multisample + GLX_SAMPLE_BUFFERS_SGIS 100000 + GLX_SAMPLES_SGIS 100001 diff --git a/Externals/GLew/auto/extensions/GLX_SGIS_shared_multisample b/Externals/GLew/auto/extensions/GLX_SGIS_shared_multisample new file mode 100644 index 0000000000..274e90f76e --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIS_shared_multisample @@ -0,0 +1,5 @@ +GLX_SGIS_shared_multisample + +GLX_SGIS_shared_multisample + GLX_MULTISAMPLE_SUB_RECT_WIDTH_SGIS 0x8026 + GLX_MULTISAMPLE_SUB_RECT_HEIGHT_SGIS 0x8027 diff --git a/Externals/GLew/auto/extensions/GLX_SGIX_fbconfig b/Externals/GLew/auto/extensions/GLX_SGIX_fbconfig new file mode 100644 index 0000000000..ac0d049248 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIX_fbconfig @@ -0,0 +1,22 @@ +GLX_SGIX_fbconfig +http://www.opengl.org/registry/specs/SGIX/fbconfig.txt +GLX_SGIX_fbconfig + GLX_WINDOW_BIT_SGIX 0x00000001 + GLX_RGBA_BIT_SGIX 0x00000001 + GLX_PIXMAP_BIT_SGIX 0x00000002 + GLX_COLOR_INDEX_BIT_SGIX 0x00000002 + GLX_SCREEN_EXT 0x800C + GLX_DRAWABLE_TYPE_SGIX 0x8010 + GLX_RENDER_TYPE_SGIX 0x8011 + GLX_X_RENDERABLE_SGIX 0x8012 + GLX_FBCONFIG_ID_SGIX 0x8013 + GLX_RGBA_TYPE_SGIX 0x8014 + GLX_COLOR_INDEX_TYPE_SGIX 0x8015 + GLXFBConfigSGIX* glXChooseFBConfigSGIX (Display *dpy, int screen, const int *attrib_list, int *nelements) + GLXContext glXCreateContextWithConfigSGIX (Display* dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct) + GLXPixmap glXCreateGLXPixmapWithConfigSGIX (Display* dpy, GLXFBConfig config, Pixmap pixmap) + int glXGetFBConfigAttribSGIX (Display* dpy, GLXFBConfigSGIX config, int attribute, int *value) + GLXFBConfigSGIX glXGetFBConfigFromVisualSGIX (Display* dpy, XVisualInfo *vis) + XVisualInfo* glXGetVisualFromFBConfigSGIX (Display *dpy, GLXFBConfig config) + typedef XID GLXFBConfigIDSGIX + typedef struct __GLXFBConfigRec *GLXFBConfigSGIX diff --git a/Externals/GLew/auto/extensions/GLX_SGIX_hyperpipe b/Externals/GLew/auto/extensions/GLX_SGIX_hyperpipe new file mode 100644 index 0000000000..79ec30295c --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIX_hyperpipe @@ -0,0 +1,25 @@ +GLX_SGIX_hyperpipe +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/hyperpipe_group.txt +GLX_SGIX_hyperpipe + GLX_HYPERPIPE_ID_SGIX 0x8030 + GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX 80 + GLX_HYPERPIPE_DISPLAY_PIPE_SGIX 0x00000001 + GLX_HYPERPIPE_RENDER_PIPE_SGIX 0x00000002 + GLX_PIPE_RECT_SGIX 0x00000001 + GLX_PIPE_RECT_LIMITS_SGIX 0x00000002 + GLX_HYPERPIPE_STEREO_SGIX 0x00000003 + GLX_HYPERPIPE_PIXEL_AVERAGE_SGIX 0x00000004 + GLX_BAD_HYPERPIPE_CONFIG_SGIX 91 + GLX_BAD_HYPERPIPE_SGIX 92 + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int networkId; } GLXHyperpipeNetworkSGIX; + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int channel; unsigned int participationType; int timeSlice; } GLXHyperpipeConfigSGIX; + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int srcXOrigin; int srcYOrigin; int srcWidth; int srcHeight; int destXOrigin; int destYOrigin; int destWidth; int destHeight; } GLXPipeRect; + typedef struct { char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; int XOrigin; int YOrigin; int maxHeight; int maxWidth; } GLXPipeRectLimits; + GLXHyperpipeNetworkSGIX * glXQueryHyperpipeNetworkSGIX (Display *dpy, int *npipes) + int glXHyperpipeConfigSGIX (Display *dpy, int networkId, int npipes, GLXHyperpipeConfigSGIX *cfg, int *hpId) + GLXHyperpipeConfigSGIX * glXQueryHyperpipeConfigSGIX (Display *dpy, int hpId, int *npipes) + int glXDestroyHyperpipeConfigSGIX (Display *dpy, int hpId) + int glXBindHyperpipeSGIX (Display *dpy, int hpId) + int glXQueryHyperpipeBestAttribSGIX (Display *dpy, int timeSlice, int attrib, int size, void *attribList, void *returnAttribList) + int glXHyperpipeAttribSGIX (Display *dpy, int timeSlice, int attrib, int size, void *attribList) + int glXQueryHyperpipeAttribSGIX (Display *dpy, int timeSlice, int attrib, int size, void *returnAttribList) diff --git a/Externals/GLew/auto/extensions/GLX_SGIX_pbuffer b/Externals/GLew/auto/extensions/GLX_SGIX_pbuffer new file mode 100644 index 0000000000..4acf71cc96 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIX_pbuffer @@ -0,0 +1,35 @@ +GLX_SGIX_pbuffer +http://www.opengl.org/registry/specs/SGIX/pbuffer.txt +GLX_SGIX_pbuffer + GLX_FRONT_LEFT_BUFFER_BIT_SGIX 0x00000001 + GLX_FRONT_RIGHT_BUFFER_BIT_SGIX 0x00000002 + GLX_PBUFFER_BIT_SGIX 0x00000004 + GLX_BACK_LEFT_BUFFER_BIT_SGIX 0x00000004 + GLX_BACK_RIGHT_BUFFER_BIT_SGIX 0x00000008 + GLX_AUX_BUFFERS_BIT_SGIX 0x00000010 + GLX_DEPTH_BUFFER_BIT_SGIX 0x00000020 + GLX_STENCIL_BUFFER_BIT_SGIX 0x00000040 + GLX_ACCUM_BUFFER_BIT_SGIX 0x00000080 + GLX_SAMPLE_BUFFERS_BIT_SGIX 0x00000100 + GLX_MAX_PBUFFER_WIDTH_SGIX 0x8016 + GLX_MAX_PBUFFER_HEIGHT_SGIX 0x8017 + GLX_MAX_PBUFFER_PIXELS_SGIX 0x8018 + GLX_OPTIMAL_PBUFFER_WIDTH_SGIX 0x8019 + GLX_OPTIMAL_PBUFFER_HEIGHT_SGIX 0x801A + GLX_PRESERVED_CONTENTS_SGIX 0x801B + GLX_LARGEST_PBUFFER_SGIX 0x801C + GLX_WIDTH_SGIX 0x801D + GLX_HEIGHT_SGIX 0x801E + GLX_EVENT_MASK_SGIX 0x801F + GLX_DAMAGED_SGIX 0x8020 + GLX_SAVED_SGIX 0x8021 + GLX_WINDOW_SGIX 0x8022 + GLX_PBUFFER_SGIX 0x8023 + GLX_BUFFER_CLOBBER_MASK_SGIX 0x08000000 + GLXPbuffer glXCreateGLXPbufferSGIX (Display* dpy, GLXFBConfig config, unsigned int width, unsigned int height, int *attrib_list) + void glXDestroyGLXPbufferSGIX (Display* dpy, GLXPbuffer pbuf) + void glXGetSelectedEventSGIX (Display* dpy, GLXDrawable drawable, unsigned long *mask) + void glXQueryGLXPbufferSGIX (Display* dpy, GLXPbuffer pbuf, int attribute, unsigned int *value) + void glXSelectEventSGIX (Display* dpy, GLXDrawable drawable, unsigned long mask) + typedef XID GLXPbufferSGIX + typedef struct { int type; unsigned long serial; Bool send_event; Display *display; GLXDrawable drawable; int event_type; int draw_type; unsigned int mask; int x, y; int width, height; int count; } GLXBufferClobberEventSGIX diff --git a/Externals/GLew/auto/extensions/GLX_SGIX_swap_barrier b/Externals/GLew/auto/extensions/GLX_SGIX_swap_barrier new file mode 100644 index 0000000000..57dd60dbb0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIX_swap_barrier @@ -0,0 +1,5 @@ +GLX_SGIX_swap_barrier +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/swap_barrier.txt +GLX_SGIX_swap_barrier + void glXBindSwapBarrierSGIX (Display *dpy, GLXDrawable drawable, int barrier) + Bool glXQueryMaxSwapBarriersSGIX (Display *dpy, int screen, int *max) diff --git a/Externals/GLew/auto/extensions/GLX_SGIX_swap_group b/Externals/GLew/auto/extensions/GLX_SGIX_swap_group new file mode 100644 index 0000000000..3530604605 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIX_swap_group @@ -0,0 +1,4 @@ +GLX_SGIX_swap_group +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/swap_group.txt +GLX_SGIX_swap_group + void glXJoinSwapGroupSGIX (Display *dpy, GLXDrawable drawable, GLXDrawable member) diff --git a/Externals/GLew/auto/extensions/GLX_SGIX_video_resize b/Externals/GLew/auto/extensions/GLX_SGIX_video_resize new file mode 100644 index 0000000000..cc919969ff --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIX_video_resize @@ -0,0 +1,10 @@ +GLX_SGIX_video_resize +http://www.opengl.org/registry/specs/SGIX/video_resize.txt +GLX_SGIX_video_resize + GLX_SYNC_FRAME_SGIX 0x00000000 + GLX_SYNC_SWAP_SGIX 0x00000001 + int glXBindChannelToWindowSGIX (Display* display, int screen, int channel, Window window) + int glXChannelRectSGIX (Display* display, int screen, int channel, int x, int y, int w, int h) + int glXChannelRectSyncSGIX (Display* display, int screen, int channel, GLenum synctype) + int glXQueryChannelDeltasSGIX (Display* display, int screen, int channel, int *x, int *y, int *w, int *h) + int glXQueryChannelRectSGIX (Display* display, int screen, int channel, int *dx, int *dy, int *dw, int *dh) diff --git a/Externals/GLew/auto/extensions/GLX_SGIX_visual_select_group b/Externals/GLew/auto/extensions/GLX_SGIX_visual_select_group new file mode 100644 index 0000000000..6c00691031 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGIX_visual_select_group @@ -0,0 +1,4 @@ +GLX_SGIX_visual_select_group +http://www.opengl.org/registry/specs/SGIX/visual_select_group.txt +GLX_SGIX_visual_select_group + GLX_VISUAL_SELECT_GROUP_SGIX 0x8028 diff --git a/Externals/GLew/auto/extensions/GLX_SGI_cushion b/Externals/GLew/auto/extensions/GLX_SGI_cushion new file mode 100644 index 0000000000..ce47e63a85 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGI_cushion @@ -0,0 +1,4 @@ +GLX_SGI_cushion +http://www.opengl.org/registry/specs/SGI/cushion.txt +GLX_SGI_cushion + void glXCushionSGI (Display* dpy, Window window, float cushion) diff --git a/Externals/GLew/auto/extensions/GLX_SGI_make_current_read b/Externals/GLew/auto/extensions/GLX_SGI_make_current_read new file mode 100644 index 0000000000..857611ecaa --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGI_make_current_read @@ -0,0 +1,5 @@ +GLX_SGI_make_current_read +http://www.opengl.org/registry/specs/SGI/make_current_read.txt +GLX_SGI_make_current_read + GLXDrawable glXGetCurrentReadDrawableSGI (void) + Bool glXMakeCurrentReadSGI (Display* dpy, GLXDrawable draw, GLXDrawable read, GLXContext ctx) diff --git a/Externals/GLew/auto/extensions/GLX_SGI_swap_control b/Externals/GLew/auto/extensions/GLX_SGI_swap_control new file mode 100644 index 0000000000..bab97bdbfe --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGI_swap_control @@ -0,0 +1,4 @@ +GLX_SGI_swap_control +http://www.opengl.org/registry/specs/SGI/swap_control.txt +GLX_SGI_swap_control + int glXSwapIntervalSGI (int interval) diff --git a/Externals/GLew/auto/extensions/GLX_SGI_video_sync b/Externals/GLew/auto/extensions/GLX_SGI_video_sync new file mode 100644 index 0000000000..f76b79ea3d --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SGI_video_sync @@ -0,0 +1,5 @@ +GLX_SGI_video_sync +http://www.opengl.org/registry/specs/SGI/video_sync.txt +GLX_SGI_video_sync + int glXGetVideoSyncSGI (uint* count) + int glXWaitVideoSyncSGI (int divisor, int remainder, unsigned int* count) diff --git a/Externals/GLew/auto/extensions/GLX_SUN_get_transparent_index b/Externals/GLew/auto/extensions/GLX_SUN_get_transparent_index new file mode 100644 index 0000000000..f3b3b64fa3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SUN_get_transparent_index @@ -0,0 +1,4 @@ +GLX_SUN_get_transparent_index +http://www.opengl.org/registry/specs/SUN/get_transparent_index.txt +GLX_SUN_get_transparent_index + Status glXGetTransparentIndexSUN (Display* dpy, Window overlay, Window underlay, unsigned long *pTransparentIndex) diff --git a/Externals/GLew/auto/extensions/GLX_SUN_video_resize b/Externals/GLew/auto/extensions/GLX_SUN_video_resize new file mode 100644 index 0000000000..0a0cefe3db --- /dev/null +++ b/Externals/GLew/auto/extensions/GLX_SUN_video_resize @@ -0,0 +1,7 @@ +GLX_SUN_video_resize +http://wwws.sun.com/software/graphics/opengl/extensions/glx_sun_video_resize.txt +GLX_SUN_video_resize + GL_VIDEO_RESIZE_COMPENSATION_SUN 0x85CD + GLX_VIDEO_RESIZE_SUN 0x8171 + int glXVideoResizeSUN (Display* display, GLXDrawable window, float factor) + int glXGetVideoResizeSUN (Display* display, GLXDrawable window, float* factor) diff --git a/Externals/GLew/auto/extensions/GL_3DFX_multisample b/Externals/GLew/auto/extensions/GL_3DFX_multisample new file mode 100644 index 0000000000..7a58d3a248 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_3DFX_multisample @@ -0,0 +1,7 @@ +GL_3DFX_multisample +http://www.opengl.org/registry/specs/3DFX/3dfx_multisample.txt +GL_3DFX_multisample + GL_MULTISAMPLE_3DFX 0x86B2 + GL_SAMPLE_BUFFERS_3DFX 0x86B3 + GL_SAMPLES_3DFX 0x86B4 + GL_MULTISAMPLE_BIT_3DFX 0x20000000 diff --git a/Externals/GLew/auto/extensions/GL_3DFX_tbuffer b/Externals/GLew/auto/extensions/GL_3DFX_tbuffer new file mode 100644 index 0000000000..d62d4c775f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_3DFX_tbuffer @@ -0,0 +1,4 @@ +GL_3DFX_tbuffer +http://www.opengl.org/registry/specs/3DFX/tbuffer.txt +GL_3DFX_tbuffer + void glTbufferMask3DFX (GLuint mask) diff --git a/Externals/GLew/auto/extensions/GL_3DFX_texture_compression_FXT1 b/Externals/GLew/auto/extensions/GL_3DFX_texture_compression_FXT1 new file mode 100644 index 0000000000..c0e4581285 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_3DFX_texture_compression_FXT1 @@ -0,0 +1,5 @@ +GL_3DFX_texture_compression_FXT1 +http://www.opengl.org/registry/specs/3DFX/texture_compression_FXT1.txt +GL_3DFX_texture_compression_FXT1 + GL_COMPRESSED_RGB_FXT1_3DFX 0x86B0 + GL_COMPRESSED_RGBA_FXT1_3DFX 0x86B1 diff --git a/Externals/GLew/auto/extensions/GL_AMD_conservative_depth b/Externals/GLew/auto/extensions/GL_AMD_conservative_depth new file mode 100644 index 0000000000..c4489eddfb --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_AMD_conservative_depth @@ -0,0 +1,3 @@ +GL_AMD_conservative_depth +http://www.opengl.org/registry/specs/AMD/conservative_depth.txt +GL_AMD_conservative_depth diff --git a/Externals/GLew/auto/extensions/GL_AMD_draw_buffers_blend b/Externals/GLew/auto/extensions/GL_AMD_draw_buffers_blend new file mode 100644 index 0000000000..74b33a1f3c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_AMD_draw_buffers_blend @@ -0,0 +1,7 @@ +GL_AMD_draw_buffers_blend +http://www.opengl.org/registry/specs/AMD/draw_buffers_blend.txt +GL_AMD_draw_buffers_blend + void glBlendEquationIndexedAMD (GLuint buf, GLenum mode) + void glBlendEquationSeparateIndexedAMD (GLuint buf, GLenum modeRGB, GLenum modeAlpha) + void glBlendFuncIndexedAMD (GLuint buf, GLenum src, GLenum dst) + void glBlendFuncSeparateIndexedAMD (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha) diff --git a/Externals/GLew/auto/extensions/GL_AMD_performance_monitor b/Externals/GLew/auto/extensions/GL_AMD_performance_monitor new file mode 100644 index 0000000000..9cc6191d5e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_AMD_performance_monitor @@ -0,0 +1,23 @@ +GL_AMD_performance_monitor +http://www.opengl.org/registry/specs/AMD/performance_monitor.txt +GL_AMD_performance_monitor + GL_UNSIGNED_INT 0x1405 + GL_FLOAT 0x1406 + GL_COUNTER_TYPE_AMD 0x8BC0 + GL_COUNTER_RANGE_AMD 0x8BC1 + GL_UNSIGNED_INT64_AMD 0x8BC2 + GL_PERCENTAGE_AMD 0x8BC3 + GL_PERFMON_RESULT_AVAILABLE_AMD 0x8BC4 + GL_PERFMON_RESULT_SIZE_AMD 0x8BC5 + GL_PERFMON_RESULT_AMD 0x8BC6 + void glBeginPerfMonitorAMD (GLuint monitor) + void glDeletePerfMonitorsAMD (GLsizei n, GLuint* monitors) + void glEndPerfMonitorAMD (GLuint monitor) + void glGenPerfMonitorsAMD (GLsizei n, GLuint* monitors) + void glGetPerfMonitorCounterDataAMD (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint* data, GLint *bytesWritten) + void glGetPerfMonitorCounterInfoAMD (GLuint group, GLuint counter, GLenum pname, void* data) + void glGetPerfMonitorCounterStringAMD (GLuint group, GLuint counter, GLsizei bufSize, GLsizei* length, char *counterString) + void glGetPerfMonitorCountersAMD (GLuint group, GLint* numCounters, GLint *maxActiveCounters, GLsizei countersSize, GLuint *counters) + void glGetPerfMonitorGroupStringAMD (GLuint group, GLsizei bufSize, GLsizei* length, char *groupString) + void glGetPerfMonitorGroupsAMD (GLint* numGroups, GLsizei groupsSize, GLuint *groups) + void glSelectPerfMonitorCountersAMD (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint* counterList) diff --git a/Externals/GLew/auto/extensions/GL_AMD_seamless_cubemap_per_texture b/Externals/GLew/auto/extensions/GL_AMD_seamless_cubemap_per_texture new file mode 100644 index 0000000000..3565655dde --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_AMD_seamless_cubemap_per_texture @@ -0,0 +1,4 @@ +GL_AMD_seamless_cubemap_per_texture +http://www.opengl.org/registry/specs/AMD/seamless_cubemap_per_texture.txt +GL_AMD_seamless_cubemap_per_texture + GL_TEXTURE_CUBE_MAP_SEAMLESS_ARB 0x884F diff --git a/Externals/GLew/auto/extensions/GL_AMD_shader_stencil_export b/Externals/GLew/auto/extensions/GL_AMD_shader_stencil_export new file mode 100644 index 0000000000..a7b91d7c23 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_AMD_shader_stencil_export @@ -0,0 +1,3 @@ +GL_AMD_shader_stencil_export +http://www.opengl.org/registry/specs/AMD/shader_stencil_export.txt +GL_AMD_shader_stencil_export diff --git a/Externals/GLew/auto/extensions/GL_AMD_texture_texture4 b/Externals/GLew/auto/extensions/GL_AMD_texture_texture4 new file mode 100644 index 0000000000..5736c5a558 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_AMD_texture_texture4 @@ -0,0 +1,3 @@ +GL_AMD_texture_texture4 +http://www.opengl.org/registry/specs/AMD/texture_texture4.txt +GL_AMD_texture_texture4 diff --git a/Externals/GLew/auto/extensions/GL_AMD_vertex_shader_tessellator b/Externals/GLew/auto/extensions/GL_AMD_vertex_shader_tessellator new file mode 100644 index 0000000000..db9e4b8883 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_AMD_vertex_shader_tessellator @@ -0,0 +1,12 @@ +GL_AMD_vertex_shader_tessellator +http://www.opengl.org/registry/specs/AMD/vertex_shader_tessellator.txt +GL_AMD_vertex_shader_tessellator + GL_SAMPLER_BUFFER_AMD 0x9001 + GL_INT_SAMPLER_BUFFER_AMD 0x9002 + GL_UNSIGNED_INT_SAMPLER_BUFFER_AMD 0x9003 + GL_TESSELLATION_MODE_AMD 0x9004 + GL_TESSELLATION_FACTOR_AMD 0x9005 + GL_DISCRETE_AMD 0x9006 + GL_CONTINUOUS_AMD 0x9007 + void glTessellationFactorAMD (GLfloat factor) + void glTessellationModeAMD (GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_aux_depth_stencil b/Externals/GLew/auto/extensions/GL_APPLE_aux_depth_stencil new file mode 100644 index 0000000000..34339d35a7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_aux_depth_stencil @@ -0,0 +1,4 @@ +GL_APPLE_aux_depth_stencil +http://www.opengl.org/registry/specs/APPLE/aux_depth_stencil.txt +GL_APPLE_aux_depth_stencil + GL_AUX_DEPTH_STENCIL_APPLE 0x8A14 diff --git a/Externals/GLew/auto/extensions/GL_APPLE_client_storage b/Externals/GLew/auto/extensions/GL_APPLE_client_storage new file mode 100644 index 0000000000..287b632a4f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_client_storage @@ -0,0 +1,4 @@ +GL_APPLE_client_storage +http://www.opengl.org/registry/specs/APPLE/client_storage.txt +GL_APPLE_client_storage + GL_UNPACK_CLIENT_STORAGE_APPLE 0x85B2 diff --git a/Externals/GLew/auto/extensions/GL_APPLE_element_array b/Externals/GLew/auto/extensions/GL_APPLE_element_array new file mode 100644 index 0000000000..c999f276d7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_element_array @@ -0,0 +1,11 @@ +GL_APPLE_element_array +http://www.opengl.org/registry/specs/APPLE/element_array.txt +GL_APPLE_element_array + GL_ELEMENT_ARRAY_APPLE 0x8A0C + GL_ELEMENT_ARRAY_TYPE_APPLE 0x8A0D + GL_ELEMENT_ARRAY_POINTER_APPLE 0x8A0E + void glDrawElementArrayAPPLE (GLenum mode, GLint first, GLsizei count) + void glDrawRangeElementArrayAPPLE (GLenum mode, GLuint start, GLuint end, GLint first, GLsizei count) + void glElementPointerAPPLE (GLenum type, const void* pointer) + void glMultiDrawElementArrayAPPLE (GLenum mode, const GLint* first, const GLsizei *count, GLsizei primcount) + void glMultiDrawRangeElementArrayAPPLE (GLenum mode, GLuint start, GLuint end, const GLint* first, const GLsizei *count, GLsizei primcount) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_fence b/Externals/GLew/auto/extensions/GL_APPLE_fence new file mode 100644 index 0000000000..1886b38958 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_fence @@ -0,0 +1,13 @@ +GL_APPLE_fence +http://www.opengl.org/registry/specs/APPLE/fence.txt +GL_APPLE_fence + GL_DRAW_PIXELS_APPLE 0x8A0A + GL_FENCE_APPLE 0x8A0B + void glDeleteFencesAPPLE (GLsizei n, const GLuint* fences) + void glFinishFenceAPPLE (GLuint fence) + void glFinishObjectAPPLE (GLenum object, GLint name) + void glGenFencesAPPLE (GLsizei n, GLuint* fences) + GLboolean glIsFenceAPPLE (GLuint fence) + void glSetFenceAPPLE (GLuint fence) + GLboolean glTestFenceAPPLE (GLuint fence) + GLboolean glTestObjectAPPLE (GLenum object, GLuint name) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_float_pixels b/Externals/GLew/auto/extensions/GL_APPLE_float_pixels new file mode 100644 index 0000000000..8a60870eec --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_float_pixels @@ -0,0 +1,17 @@ +GL_APPLE_float_pixels +http://developer.apple.com/opengl/extensions/apple_float_pixels.html +GL_APPLE_float_pixels + GL_HALF_APPLE 0x140B + GL_COLOR_FLOAT_APPLE 0x8A0F + GL_RGBA_FLOAT32_APPLE 0x8814 + GL_RGB_FLOAT32_APPLE 0x8815 + GL_ALPHA_FLOAT32_APPLE 0x8816 + GL_INTENSITY_FLOAT32_APPLE 0x8817 + GL_LUMINANCE_FLOAT32_APPLE 0x8818 + GL_LUMINANCE_ALPHA_FLOAT32_APPLE 0x8819 + GL_RGBA_FLOAT16_APPLE 0x881A + GL_RGB_FLOAT16_APPLE 0x881B + GL_ALPHA_FLOAT16_APPLE 0x881C + GL_INTENSITY_FLOAT16_APPLE 0x881D + GL_LUMINANCE_FLOAT16_APPLE 0x881E + GL_LUMINANCE_ALPHA_FLOAT16_APPLE 0x881F diff --git a/Externals/GLew/auto/extensions/GL_APPLE_flush_buffer_range b/Externals/GLew/auto/extensions/GL_APPLE_flush_buffer_range new file mode 100644 index 0000000000..243cff808d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_flush_buffer_range @@ -0,0 +1,7 @@ +GL_APPLE_flush_buffer_range +http://www.opengl.org/registry/specs/APPLE/flush_buffer_range.txt +GL_APPLE_flush_buffer_range + GL_BUFFER_SERIALIZED_MODIFY_APPLE 0x8A12 + GL_BUFFER_FLUSHING_UNMAP_APPLE 0x8A13 + void glBufferParameteriAPPLE (GLenum target, GLenum pname, GLint param) + void glFlushMappedBufferRangeAPPLE (GLenum target, GLintptr offset, GLsizeiptr size) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_object_purgeable b/Externals/GLew/auto/extensions/GL_APPLE_object_purgeable new file mode 100644 index 0000000000..a428e7724b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_object_purgeable @@ -0,0 +1,12 @@ +GL_APPLE_object_purgeable +http://www.opengl.org/registry/specs/APPLE/object_purgeable.txt +GL_APPLE_object_purgeable + GL_BUFFER_OBJECT_APPLE 0x85B3 + GL_RELEASED_APPLE 0x8A19 + GL_VOLATILE_APPLE 0x8A1A + GL_RETAINED_APPLE 0x8A1B + GL_UNDEFINED_APPLE 0x8A1C + GL_PURGEABLE_APPLE 0x8A1D + void glGetObjectParameterivAPPLE (GLenum objectType, GLuint name, GLenum pname, GLint* params) + GLenum glObjectPurgeableAPPLE (GLenum objectType, GLuint name, GLenum option) + GLenum glObjectUnpurgeableAPPLE (GLenum objectType, GLuint name, GLenum option) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_pixel_buffer b/Externals/GLew/auto/extensions/GL_APPLE_pixel_buffer new file mode 100644 index 0000000000..7449f2918e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_pixel_buffer @@ -0,0 +1,4 @@ +GL_APPLE_pixel_buffer + +GL_APPLE_pixel_buffer + GL_MIN_PBUFFER_VIEWPORT_DIMS_APPLE 0x8A10 diff --git a/Externals/GLew/auto/extensions/GL_APPLE_rgb_422 b/Externals/GLew/auto/extensions/GL_APPLE_rgb_422 new file mode 100644 index 0000000000..00e43559c2 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_rgb_422 @@ -0,0 +1,6 @@ +GL_APPLE_rgb_422 +http://www.opengl.org/registry/specs/APPLE/rgb_422.txt +GL_APPLE_rgb_422 + GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA + GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB + GL_RGB_422_APPLE 0x8A1F diff --git a/Externals/GLew/auto/extensions/GL_APPLE_row_bytes b/Externals/GLew/auto/extensions/GL_APPLE_row_bytes new file mode 100644 index 0000000000..0c60b923db --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_row_bytes @@ -0,0 +1,5 @@ +GL_APPLE_row_bytes +http://www.opengl.org/registry/specs/APPLE/row_bytes.txt +GL_APPLE_row_bytes + GL_PACK_ROW_BYTES_APPLE 0x8A15 + GL_UNPACK_ROW_BYTES_APPLE 0x8A16 diff --git a/Externals/GLew/auto/extensions/GL_APPLE_specular_vector b/Externals/GLew/auto/extensions/GL_APPLE_specular_vector new file mode 100644 index 0000000000..98a18fa5d5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_specular_vector @@ -0,0 +1,4 @@ +GL_APPLE_specular_vector +http://www.opengl.org/registry/specs/APPLE/specular_vector.txt +GL_APPLE_specular_vector + GL_LIGHT_MODEL_SPECULAR_VECTOR_APPLE 0x85B0 diff --git a/Externals/GLew/auto/extensions/GL_APPLE_texture_range b/Externals/GLew/auto/extensions/GL_APPLE_texture_range new file mode 100644 index 0000000000..8c5165d61d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_texture_range @@ -0,0 +1,12 @@ +GL_APPLE_texture_range +http://developer.apple.com/opengl/extensions/apple_texture_range.html +GL_APPLE_texture_range + GL_TEXTURE_STORAGE_HINT_APPLE 0x85BC + GL_STORAGE_PRIVATE_APPLE 0x85BD + GL_STORAGE_CACHED_APPLE 0x85BE + GL_STORAGE_SHARED_APPLE 0x85BF + GL_TEXTURE_RANGE_LENGTH_APPLE 0x85B7 + GL_TEXTURE_RANGE_POINTER_APPLE 0x85B8 + void glTextureRangeAPPLE (GLenum target, GLsizei length, GLvoid *pointer) + void glGetTexParameterPointervAPPLE (GLenum target, GLenum pname, GLvoid **params) + diff --git a/Externals/GLew/auto/extensions/GL_APPLE_transform_hint b/Externals/GLew/auto/extensions/GL_APPLE_transform_hint new file mode 100644 index 0000000000..ac713eb534 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_transform_hint @@ -0,0 +1,4 @@ +GL_APPLE_transform_hint +http://www.opengl.org/registry/specs/APPLE/transform_hint.txt +GL_APPLE_transform_hint + GL_TRANSFORM_HINT_APPLE 0x85B1 diff --git a/Externals/GLew/auto/extensions/GL_APPLE_vertex_array_object b/Externals/GLew/auto/extensions/GL_APPLE_vertex_array_object new file mode 100644 index 0000000000..95da66d2ac --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_vertex_array_object @@ -0,0 +1,8 @@ +GL_APPLE_vertex_array_object +http://www.opengl.org/registry/specs/APPLE/vertex_array_object.txt +GL_APPLE_vertex_array_object + GL_VERTEX_ARRAY_BINDING_APPLE 0x85B5 + void glBindVertexArrayAPPLE (GLuint array) + void glDeleteVertexArraysAPPLE (GLsizei n, const GLuint* arrays) + void glGenVertexArraysAPPLE (GLsizei n, const GLuint* arrays) + GLboolean glIsVertexArrayAPPLE (GLuint array) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_vertex_array_range b/Externals/GLew/auto/extensions/GL_APPLE_vertex_array_range new file mode 100644 index 0000000000..1536f076b4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_vertex_array_range @@ -0,0 +1,14 @@ +GL_APPLE_vertex_array_range +http://www.opengl.org/registry/specs/APPLE/vertex_array_range.txt +GL_APPLE_vertex_array_range + GL_VERTEX_ARRAY_RANGE_APPLE 0x851D + GL_VERTEX_ARRAY_RANGE_LENGTH_APPLE 0x851E + GL_VERTEX_ARRAY_STORAGE_HINT_APPLE 0x851F + GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_APPLE 0x8520 + GL_VERTEX_ARRAY_RANGE_POINTER_APPLE 0x8521 + GL_STORAGE_CLIENT_APPLE 0x85B4 + GL_STORAGE_CACHED_APPLE 0x85BE + GL_STORAGE_SHARED_APPLE 0x85BF + void glFlushVertexArrayRangeAPPLE (GLsizei length, void* pointer) + void glVertexArrayParameteriAPPLE (GLenum pname, GLint param) + void glVertexArrayRangeAPPLE (GLsizei length, void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_vertex_program_evaluators b/Externals/GLew/auto/extensions/GL_APPLE_vertex_program_evaluators new file mode 100644 index 0000000000..4bc8dea013 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_vertex_program_evaluators @@ -0,0 +1,20 @@ +GL_APPLE_vertex_program_evaluators +http://www.opengl.org/registry/specs/APPLE/vertex_program_evaluators.txt +GL_APPLE_vertex_program_evaluators + GL_VERTEX_ATTRIB_MAP1_APPLE 0x8A00 + GL_VERTEX_ATTRIB_MAP2_APPLE 0x8A01 + GL_VERTEX_ATTRIB_MAP1_SIZE_APPLE 0x8A02 + GL_VERTEX_ATTRIB_MAP1_COEFF_APPLE 0x8A03 + GL_VERTEX_ATTRIB_MAP1_ORDER_APPLE 0x8A04 + GL_VERTEX_ATTRIB_MAP1_DOMAIN_APPLE 0x8A05 + GL_VERTEX_ATTRIB_MAP2_SIZE_APPLE 0x8A06 + GL_VERTEX_ATTRIB_MAP2_COEFF_APPLE 0x8A07 + GL_VERTEX_ATTRIB_MAP2_ORDER_APPLE 0x8A08 + GL_VERTEX_ATTRIB_MAP2_DOMAIN_APPLE 0x8A09 + void glDisableVertexAttribAPPLE (GLuint index, GLenum pname) + void glEnableVertexAttribAPPLE (GLuint index, GLenum pname) + GLboolean glIsVertexAttribEnabledAPPLE (GLuint index, GLenum pname) + void glMapVertexAttrib1dAPPLE (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble* points) + void glMapVertexAttrib1fAPPLE (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat* points) + void glMapVertexAttrib2dAPPLE (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble* points) + void glMapVertexAttrib2fAPPLE (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat* points) diff --git a/Externals/GLew/auto/extensions/GL_APPLE_ycbcr_422 b/Externals/GLew/auto/extensions/GL_APPLE_ycbcr_422 new file mode 100644 index 0000000000..3b855494cc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_APPLE_ycbcr_422 @@ -0,0 +1,6 @@ +GL_APPLE_ycbcr_422 +http://www.opengl.org/registry/specs/APPLE/ycbcr_422.txt +GL_APPLE_ycbcr_422 + GL_YCBCR_422_APPLE 0x85B9 + GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA + GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB diff --git a/Externals/GLew/auto/extensions/GL_ARB_blend_func_extended b/Externals/GLew/auto/extensions/GL_ARB_blend_func_extended new file mode 100644 index 0000000000..c70d68dfdf --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_blend_func_extended @@ -0,0 +1,9 @@ +GL_ARB_blend_func_extended +http://www.opengl.org/registry/specs/ARB/blend_func_extended.txt +GL_ARB_blend_func_extended + GL_SRC1_COLOR 0x88F9 + GL_ONE_MINUS_SRC1_COLOR 0x88FA + GL_ONE_MINUS_SRC1_ALPHA 0x88FB + GL_MAX_DUAL_SOURCE_DRAW_BUFFERS 0x88FC + void glBindFragDataLocationIndexed (GLuint program, GLuint colorNumber, GLuint index, const char * name) + GLint glGetFragDataIndex (GLuint program, const char * name) diff --git a/Externals/GLew/auto/extensions/GL_ARB_color_buffer_float b/Externals/GLew/auto/extensions/GL_ARB_color_buffer_float new file mode 100644 index 0000000000..1d7ad0542e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_color_buffer_float @@ -0,0 +1,9 @@ +GL_ARB_color_buffer_float +http://www.opengl.org/registry/specs/ARB/color_buffer_float.txt +GL_ARB_color_buffer_float + GL_RGBA_FLOAT_MODE_ARB 0x8820 + GL_CLAMP_VERTEX_COLOR_ARB 0x891A + GL_CLAMP_FRAGMENT_COLOR_ARB 0x891B + GL_CLAMP_READ_COLOR_ARB 0x891C + GL_FIXED_ONLY_ARB 0x891D + void glClampColorARB (GLenum target, GLenum clamp) diff --git a/Externals/GLew/auto/extensions/GL_ARB_compatibility b/Externals/GLew/auto/extensions/GL_ARB_compatibility new file mode 100644 index 0000000000..60200c41fa --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_compatibility @@ -0,0 +1,3 @@ +GL_ARB_compatibility +http://www.opengl.org/registry/specs/ARB/compatibility.txt +GL_ARB_compatibility diff --git a/Externals/GLew/auto/extensions/GL_ARB_copy_buffer b/Externals/GLew/auto/extensions/GL_ARB_copy_buffer new file mode 100644 index 0000000000..64f58b0cb0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_copy_buffer @@ -0,0 +1,6 @@ +GL_ARB_copy_buffer +http://www.opengl.org/registry/specs/ARB/copy_buffer.txt +GL_ARB_copy_buffer + GL_COPY_READ_BUFFER 0x8F36 + GL_COPY_WRITE_BUFFER 0x8F37 + void glCopyBufferSubData (GLenum readtarget, GLenum writetarget, GLintptr readoffset, GLintptr writeoffset, GLsizeiptr size) diff --git a/Externals/GLew/auto/extensions/GL_ARB_depth_buffer_float b/Externals/GLew/auto/extensions/GL_ARB_depth_buffer_float new file mode 100644 index 0000000000..f18f1216c7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_depth_buffer_float @@ -0,0 +1,6 @@ +GL_ARB_depth_buffer_float +http://www.opengl.org/registry/specs/ARB/depth_buffer_float.txt +GL_ARB_depth_buffer_float + GL_DEPTH_COMPONENT32F 0x8CAC + GL_DEPTH32F_STENCIL8 0x8CAD + GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD diff --git a/Externals/GLew/auto/extensions/GL_ARB_depth_clamp b/Externals/GLew/auto/extensions/GL_ARB_depth_clamp new file mode 100644 index 0000000000..31cffa7707 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_depth_clamp @@ -0,0 +1,4 @@ +GL_ARB_depth_clamp +http://www.opengl.org/registry/specs/ARB/depth_clamp.txt +GL_ARB_depth_clamp + GL_DEPTH_CLAMP 0x864F diff --git a/Externals/GLew/auto/extensions/GL_ARB_depth_texture b/Externals/GLew/auto/extensions/GL_ARB_depth_texture new file mode 100644 index 0000000000..d1aa476c09 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_depth_texture @@ -0,0 +1,8 @@ +GL_ARB_depth_texture +http://www.opengl.org/registry/specs/ARB/depth_texture.txt +GL_ARB_depth_texture + GL_DEPTH_COMPONENT16_ARB 0x81A5 + GL_DEPTH_COMPONENT24_ARB 0x81A6 + GL_DEPTH_COMPONENT32_ARB 0x81A7 + GL_TEXTURE_DEPTH_SIZE_ARB 0x884A + GL_DEPTH_TEXTURE_MODE_ARB 0x884B diff --git a/Externals/GLew/auto/extensions/GL_ARB_draw_buffers b/Externals/GLew/auto/extensions/GL_ARB_draw_buffers new file mode 100644 index 0000000000..8c96b61b4b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_draw_buffers @@ -0,0 +1,21 @@ +GL_ARB_draw_buffers +http://www.opengl.org/registry/specs/ARB/draw_buffers.txt +GL_ARB_draw_buffers + GL_MAX_DRAW_BUFFERS_ARB 0x8824 + GL_DRAW_BUFFER0_ARB 0x8825 + GL_DRAW_BUFFER1_ARB 0x8826 + GL_DRAW_BUFFER2_ARB 0x8827 + GL_DRAW_BUFFER3_ARB 0x8828 + GL_DRAW_BUFFER4_ARB 0x8829 + GL_DRAW_BUFFER5_ARB 0x882A + GL_DRAW_BUFFER6_ARB 0x882B + GL_DRAW_BUFFER7_ARB 0x882C + GL_DRAW_BUFFER8_ARB 0x882D + GL_DRAW_BUFFER9_ARB 0x882E + GL_DRAW_BUFFER10_ARB 0x882F + GL_DRAW_BUFFER11_ARB 0x8830 + GL_DRAW_BUFFER12_ARB 0x8831 + GL_DRAW_BUFFER13_ARB 0x8832 + GL_DRAW_BUFFER14_ARB 0x8833 + GL_DRAW_BUFFER15_ARB 0x8834 + void glDrawBuffersARB (GLsizei n, const GLenum* bufs) diff --git a/Externals/GLew/auto/extensions/GL_ARB_draw_buffers_blend b/Externals/GLew/auto/extensions/GL_ARB_draw_buffers_blend new file mode 100644 index 0000000000..4f63320832 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_draw_buffers_blend @@ -0,0 +1,7 @@ +GL_ARB_draw_buffers_blend +http://www.opengl.org/registry/specs/ARB/draw_buffers_blend.txt +GL_ARB_draw_buffers_blend + void glBlendEquationSeparateiARB (GLuint buf, GLenum modeRGB, GLenum modeAlpha) + void glBlendEquationiARB (GLuint buf, GLenum mode) + void glBlendFuncSeparateiARB (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha) + void glBlendFunciARB (GLuint buf, GLenum src, GLenum dst) diff --git a/Externals/GLew/auto/extensions/GL_ARB_draw_elements_base_vertex b/Externals/GLew/auto/extensions/GL_ARB_draw_elements_base_vertex new file mode 100644 index 0000000000..85c5be7ac0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_draw_elements_base_vertex @@ -0,0 +1,7 @@ +GL_ARB_draw_elements_base_vertex +http://www.opengl.org/registry/specs/ARB/draw_elements_base_vertex.txt +GL_ARB_draw_elements_base_vertex + void glDrawElementsBaseVertex (GLenum mode, GLsizei count, GLenum type, void* indices, GLint basevertex) + void glDrawElementsInstancedBaseVertex (GLenum mode, GLsizei count, GLenum type, const void* indices, GLsizei primcount, GLint basevertex) + void glDrawRangeElementsBaseVertex (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, void* indices, GLint basevertex) + void glMultiDrawElementsBaseVertex (GLenum mode, GLsizei* count, GLenum type, GLvoid**indices, GLsizei primcount, GLint *basevertex) diff --git a/Externals/GLew/auto/extensions/GL_ARB_draw_indirect b/Externals/GLew/auto/extensions/GL_ARB_draw_indirect new file mode 100644 index 0000000000..1423bc6f50 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_draw_indirect @@ -0,0 +1,7 @@ +GL_ARB_draw_indirect +http://www.opengl.org/registry/specs/ARB/draw_indirect.txt +GL_ARB_draw_indirect + GL_DRAW_INDIRECT_BUFFER 0x8F3F + GL_DRAW_INDIRECT_BUFFER_BINDING 0x8F43 + void glDrawArraysIndirect (GLenum mode, const void* indirect) + void glDrawElementsIndirect (GLenum mode, GLenum type, const void* indirect) diff --git a/Externals/GLew/auto/extensions/GL_ARB_draw_instanced b/Externals/GLew/auto/extensions/GL_ARB_draw_instanced new file mode 100644 index 0000000000..a1a0f37d9f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_draw_instanced @@ -0,0 +1,5 @@ +GL_ARB_draw_instanced +http://www.opengl.org/registry/specs/ARB/draw_instanced.txt +GL_ARB_draw_instanced + void glDrawArraysInstancedARB (GLenum mode, GLint first, GLsizei count, GLsizei primcount) + void glDrawElementsInstancedARB (GLenum mode, GLsizei count, GLenum type, const void* indices, GLsizei primcount) diff --git a/Externals/GLew/auto/extensions/GL_ARB_explicit_attrib_location b/Externals/GLew/auto/extensions/GL_ARB_explicit_attrib_location new file mode 100644 index 0000000000..76fe9ca035 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_explicit_attrib_location @@ -0,0 +1,3 @@ +GL_ARB_explicit_attrib_location +http://www.opengl.org/registry/specs/ARB/explicit_attrib_location.txt +GL_ARB_explicit_attrib_location diff --git a/Externals/GLew/auto/extensions/GL_ARB_fragment_coord_conventions b/Externals/GLew/auto/extensions/GL_ARB_fragment_coord_conventions new file mode 100644 index 0000000000..f54b1fe06d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_fragment_coord_conventions @@ -0,0 +1,3 @@ +GL_ARB_fragment_coord_conventions +http://www.opengl.org/registry/specs/ARB/fragment_coord_conventions.txt +GL_ARB_fragment_coord_conventions diff --git a/Externals/GLew/auto/extensions/GL_ARB_fragment_program b/Externals/GLew/auto/extensions/GL_ARB_fragment_program new file mode 100644 index 0000000000..ce63a3472e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_fragment_program @@ -0,0 +1,18 @@ +GL_ARB_fragment_program +http://www.opengl.org/registry/specs/ARB/fragment_program.txt +GL_ARB_fragment_program + GL_FRAGMENT_PROGRAM_ARB 0x8804 + GL_PROGRAM_ALU_INSTRUCTIONS_ARB 0x8805 + GL_PROGRAM_TEX_INSTRUCTIONS_ARB 0x8806 + GL_PROGRAM_TEX_INDIRECTIONS_ARB 0x8807 + GL_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x8808 + GL_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x8809 + GL_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x880A + GL_MAX_PROGRAM_ALU_INSTRUCTIONS_ARB 0x880B + GL_MAX_PROGRAM_TEX_INSTRUCTIONS_ARB 0x880C + GL_MAX_PROGRAM_TEX_INDIRECTIONS_ARB 0x880D + GL_MAX_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x880E + GL_MAX_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x880F + GL_MAX_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x8810 + GL_MAX_TEXTURE_COORDS_ARB 0x8871 + GL_MAX_TEXTURE_IMAGE_UNITS_ARB 0x8872 diff --git a/Externals/GLew/auto/extensions/GL_ARB_fragment_program_shadow b/Externals/GLew/auto/extensions/GL_ARB_fragment_program_shadow new file mode 100644 index 0000000000..cce0d4883f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_fragment_program_shadow @@ -0,0 +1,3 @@ +GL_ARB_fragment_program_shadow +http://www.opengl.org/registry/specs/ARB/fragment_program_shadow.txt +GL_ARB_fragment_program_shadow diff --git a/Externals/GLew/auto/extensions/GL_ARB_fragment_shader b/Externals/GLew/auto/extensions/GL_ARB_fragment_shader new file mode 100644 index 0000000000..07f477393f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_fragment_shader @@ -0,0 +1,6 @@ +GL_ARB_fragment_shader +http://www.opengl.org/registry/specs/ARB/fragment_shader.txt +GL_ARB_fragment_shader + GL_FRAGMENT_SHADER_ARB 0x8B30 + GL_MAX_FRAGMENT_UNIFORM_COMPONENTS_ARB 0x8B49 + GL_FRAGMENT_SHADER_DERIVATIVE_HINT_ARB 0x8B8B diff --git a/Externals/GLew/auto/extensions/GL_ARB_framebuffer_object b/Externals/GLew/auto/extensions/GL_ARB_framebuffer_object new file mode 100644 index 0000000000..bb217e2fbc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_framebuffer_object @@ -0,0 +1,97 @@ +GL_ARB_framebuffer_object +http://www.opengl.org/registry/specs/ARB/framebuffer_object.txt +GL_ARB_framebuffer_object + GL_INVALID_FRAMEBUFFER_OPERATION 0x0506 + GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING 0x8210 + GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE 0x8211 + GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE 0x8212 + GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE 0x8213 + GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE 0x8214 + GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE 0x8215 + GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE 0x8216 + GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE 0x8217 + GL_FRAMEBUFFER_DEFAULT 0x8218 + GL_FRAMEBUFFER_UNDEFINED 0x8219 + GL_DEPTH_STENCIL_ATTACHMENT 0x821A + GL_INDEX 0x8222 + GL_MAX_RENDERBUFFER_SIZE 0x84E8 + GL_DEPTH_STENCIL 0x84F9 + GL_UNSIGNED_INT_24_8 0x84FA + GL_DEPTH24_STENCIL8 0x88F0 + GL_TEXTURE_STENCIL_SIZE 0x88F1 + GL_UNSIGNED_NORMALIZED 0x8C17 + GL_SRGB 0x8C40 + GL_DRAW_FRAMEBUFFER_BINDING 0x8CA6 + GL_FRAMEBUFFER_BINDING 0x8CA6 + GL_RENDERBUFFER_BINDING 0x8CA7 + GL_READ_FRAMEBUFFER 0x8CA8 + GL_DRAW_FRAMEBUFFER 0x8CA9 + GL_READ_FRAMEBUFFER_BINDING 0x8CAA + GL_RENDERBUFFER_SAMPLES 0x8CAB + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE 0x8CD0 + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME 0x8CD1 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL 0x8CD2 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE 0x8CD3 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 + GL_FRAMEBUFFER_COMPLETE 0x8CD5 + GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT 0x8CD6 + GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT 0x8CD7 + GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER 0x8CDB + GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER 0x8CDC + GL_FRAMEBUFFER_UNSUPPORTED 0x8CDD + GL_MAX_COLOR_ATTACHMENTS 0x8CDF + GL_COLOR_ATTACHMENT0 0x8CE0 + GL_COLOR_ATTACHMENT1 0x8CE1 + GL_COLOR_ATTACHMENT2 0x8CE2 + GL_COLOR_ATTACHMENT3 0x8CE3 + GL_COLOR_ATTACHMENT4 0x8CE4 + GL_COLOR_ATTACHMENT5 0x8CE5 + GL_COLOR_ATTACHMENT6 0x8CE6 + GL_COLOR_ATTACHMENT7 0x8CE7 + GL_COLOR_ATTACHMENT8 0x8CE8 + GL_COLOR_ATTACHMENT9 0x8CE9 + GL_COLOR_ATTACHMENT10 0x8CEA + GL_COLOR_ATTACHMENT11 0x8CEB + GL_COLOR_ATTACHMENT12 0x8CEC + GL_COLOR_ATTACHMENT13 0x8CED + GL_COLOR_ATTACHMENT14 0x8CEE + GL_COLOR_ATTACHMENT15 0x8CEF + GL_DEPTH_ATTACHMENT 0x8D00 + GL_STENCIL_ATTACHMENT 0x8D20 + GL_FRAMEBUFFER 0x8D40 + GL_RENDERBUFFER 0x8D41 + GL_RENDERBUFFER_WIDTH 0x8D42 + GL_RENDERBUFFER_HEIGHT 0x8D43 + GL_RENDERBUFFER_INTERNAL_FORMAT 0x8D44 + GL_STENCIL_INDEX1 0x8D46 + GL_STENCIL_INDEX4 0x8D47 + GL_STENCIL_INDEX8 0x8D48 + GL_STENCIL_INDEX16 0x8D49 + GL_RENDERBUFFER_RED_SIZE 0x8D50 + GL_RENDERBUFFER_GREEN_SIZE 0x8D51 + GL_RENDERBUFFER_BLUE_SIZE 0x8D52 + GL_RENDERBUFFER_ALPHA_SIZE 0x8D53 + GL_RENDERBUFFER_DEPTH_SIZE 0x8D54 + GL_RENDERBUFFER_STENCIL_SIZE 0x8D55 + GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE 0x8D56 + GL_MAX_SAMPLES 0x8D57 + void glBindFramebuffer (GLenum target, GLuint framebuffer) + void glBindRenderbuffer (GLenum target, GLuint renderbuffer) + void glBlitFramebuffer (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter) + GLenum glCheckFramebufferStatus (GLenum target) + void glDeleteFramebuffers (GLsizei n, const GLuint* framebuffers) + void glDeleteRenderbuffers (GLsizei n, const GLuint* renderbuffers) + void glFramebufferRenderbuffer (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer) + void glFramebufferTexture1D (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level) + void glFramebufferTexture2D (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level) + void glFramebufferTexture3D (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint layer) + void glFramebufferTextureLayer (GLenum target,GLenum attachment, GLuint texture,GLint level,GLint layer) + void glGenFramebuffers (GLsizei n, GLuint* framebuffers) + void glGenRenderbuffers (GLsizei n, GLuint* renderbuffers) + void glGenerateMipmap (GLenum target) + void glGetFramebufferAttachmentParameteriv (GLenum target, GLenum attachment, GLenum pname, GLint* params) + void glGetRenderbufferParameteriv (GLenum target, GLenum pname, GLint* params) + GLboolean glIsFramebuffer (GLuint framebuffer) + GLboolean glIsRenderbuffer (GLuint renderbuffer) + void glRenderbufferStorage (GLenum target, GLenum internalformat, GLsizei width, GLsizei height) + void glRenderbufferStorageMultisample (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/extensions/GL_ARB_framebuffer_sRGB b/Externals/GLew/auto/extensions/GL_ARB_framebuffer_sRGB new file mode 100644 index 0000000000..c9909bca48 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_framebuffer_sRGB @@ -0,0 +1,4 @@ +GL_ARB_framebuffer_sRGB +http://www.opengl.org/registry/specs/ARB/framebuffer_sRGB.txt +GL_ARB_framebuffer_sRGB + GL_FRAMEBUFFER_SRGB 0x8DB9 diff --git a/Externals/GLew/auto/extensions/GL_ARB_geometry_shader4 b/Externals/GLew/auto/extensions/GL_ARB_geometry_shader4 new file mode 100644 index 0000000000..76cfcbf66c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_geometry_shader4 @@ -0,0 +1,26 @@ +GL_ARB_geometry_shader4 +http://www.opengl.org/registry/specs/ARB/geometry_shader4.txt +GL_ARB_geometry_shader4 + GL_LINES_ADJACENCY_ARB 0xA + GL_LINE_STRIP_ADJACENCY_ARB 0xB + GL_TRIANGLES_ADJACENCY_ARB 0xC + GL_TRIANGLE_STRIP_ADJACENCY_ARB 0xD + GL_PROGRAM_POINT_SIZE_ARB 0x8642 + GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_ARB 0x8C29 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 + GL_FRAMEBUFFER_ATTACHMENT_LAYERED_ARB 0x8DA7 + GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_ARB 0x8DA8 + GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_ARB 0x8DA9 + GL_GEOMETRY_SHADER_ARB 0x8DD9 + GL_GEOMETRY_VERTICES_OUT_ARB 0x8DDA + GL_GEOMETRY_INPUT_TYPE_ARB 0x8DDB + GL_GEOMETRY_OUTPUT_TYPE_ARB 0x8DDC + GL_MAX_GEOMETRY_VARYING_COMPONENTS_ARB 0x8DDD + GL_MAX_VERTEX_VARYING_COMPONENTS_ARB 0x8DDE + GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_ARB 0x8DDF + GL_MAX_GEOMETRY_OUTPUT_VERTICES_ARB 0x8DE0 + GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_ARB 0x8DE1 + void glFramebufferTextureARB (GLenum target, GLenum attachment, GLuint texture, GLint level) + void glFramebufferTextureFaceARB (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face) + void glFramebufferTextureLayerARB (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer) + void glProgramParameteriARB (GLuint program, GLenum pname, GLint value) diff --git a/Externals/GLew/auto/extensions/GL_ARB_gpu_shader5 b/Externals/GLew/auto/extensions/GL_ARB_gpu_shader5 new file mode 100644 index 0000000000..816c894adc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_gpu_shader5 @@ -0,0 +1,9 @@ +GL_ARB_gpu_shader5 +http://www.opengl.org/registry/specs/ARB/gpu_shader5.txt +GL_ARB_gpu_shader5 + GL_GEOMETRY_SHADER_INVOCATIONS 0x887F + GL_MAX_GEOMETRY_SHADER_INVOCATIONS 0x8E5A + GL_MIN_FRAGMENT_INTERPOLATION_OFFSET 0x8E5B + GL_MAX_FRAGMENT_INTERPOLATION_OFFSET 0x8E5C + GL_FRAGMENT_INTERPOLATION_OFFSET_BITS 0x8E5D + GL_MAX_VERTEX_STREAMS 0x8E71 diff --git a/Externals/GLew/auto/extensions/GL_ARB_gpu_shader_fp64 b/Externals/GLew/auto/extensions/GL_ARB_gpu_shader_fp64 new file mode 100644 index 0000000000..f452eeb0ad --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_gpu_shader_fp64 @@ -0,0 +1,3 @@ +GL_ARB_gpu_shader_fp64 +http://www.opengl.org/registry/specs/ARB/gpu_shader_fp64.txt +GL_ARB_gpu_shader_fp64 diff --git a/Externals/GLew/auto/extensions/GL_ARB_half_float_pixel b/Externals/GLew/auto/extensions/GL_ARB_half_float_pixel new file mode 100644 index 0000000000..6cc72e83f7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_half_float_pixel @@ -0,0 +1,4 @@ +GL_ARB_half_float_pixel +http://www.opengl.org/registry/specs/ARB/half_float_pixel.txt +GL_ARB_half_float_pixel + GL_HALF_FLOAT_ARB 0x140B diff --git a/Externals/GLew/auto/extensions/GL_ARB_half_float_vertex b/Externals/GLew/auto/extensions/GL_ARB_half_float_vertex new file mode 100644 index 0000000000..2ecbbc358d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_half_float_vertex @@ -0,0 +1,4 @@ +GL_ARB_half_float_vertex +http://www.opengl.org/registry/specs/ARB/half_float_vertex.txt +GL_ARB_half_float_vertex + GL_HALF_FLOAT 0x140B diff --git a/Externals/GLew/auto/extensions/GL_ARB_imaging b/Externals/GLew/auto/extensions/GL_ARB_imaging new file mode 100644 index 0000000000..0efd0c1b8e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_imaging @@ -0,0 +1,112 @@ +GL_ARB_imaging + +GL_ARB_imaging + GL_CONSTANT_COLOR 0x8001 + GL_ONE_MINUS_CONSTANT_COLOR 0x8002 + GL_CONSTANT_ALPHA 0x8003 + GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 + GL_BLEND_COLOR 0x8005 + GL_FUNC_ADD 0x8006 + GL_MIN 0x8007 + GL_MAX 0x8008 + GL_BLEND_EQUATION 0x8009 + GL_FUNC_SUBTRACT 0x800A + GL_FUNC_REVERSE_SUBTRACT 0x800B + GL_CONVOLUTION_1D 0x8010 + GL_CONVOLUTION_2D 0x8011 + GL_SEPARABLE_2D 0x8012 + GL_CONVOLUTION_BORDER_MODE 0x8013 + GL_CONVOLUTION_FILTER_SCALE 0x8014 + GL_CONVOLUTION_FILTER_BIAS 0x8015 + GL_REDUCE 0x8016 + GL_CONVOLUTION_FORMAT 0x8017 + GL_CONVOLUTION_WIDTH 0x8018 + GL_CONVOLUTION_HEIGHT 0x8019 + GL_MAX_CONVOLUTION_WIDTH 0x801A + GL_MAX_CONVOLUTION_HEIGHT 0x801B + GL_POST_CONVOLUTION_RED_SCALE 0x801C + GL_POST_CONVOLUTION_GREEN_SCALE 0x801D + GL_POST_CONVOLUTION_BLUE_SCALE 0x801E + GL_POST_CONVOLUTION_ALPHA_SCALE 0x801F + GL_POST_CONVOLUTION_RED_BIAS 0x8020 + GL_POST_CONVOLUTION_GREEN_BIAS 0x8021 + GL_POST_CONVOLUTION_BLUE_BIAS 0x8022 + GL_POST_CONVOLUTION_ALPHA_BIAS 0x8023 + GL_HISTOGRAM 0x8024 + GL_PROXY_HISTOGRAM 0x8025 + GL_HISTOGRAM_WIDTH 0x8026 + GL_HISTOGRAM_FORMAT 0x8027 + GL_HISTOGRAM_RED_SIZE 0x8028 + GL_HISTOGRAM_GREEN_SIZE 0x8029 + GL_HISTOGRAM_BLUE_SIZE 0x802A + GL_HISTOGRAM_ALPHA_SIZE 0x802B + GL_HISTOGRAM_LUMINANCE_SIZE 0x802C + GL_HISTOGRAM_SINK 0x802D + GL_MINMAX 0x802E + GL_MINMAX_FORMAT 0x802F + GL_MINMAX_SINK 0x8030 + GL_TABLE_TOO_LARGE 0x8031 + GL_COLOR_MATRIX 0x80B1 + GL_COLOR_MATRIX_STACK_DEPTH 0x80B2 + GL_MAX_COLOR_MATRIX_STACK_DEPTH 0x80B3 + GL_POST_COLOR_MATRIX_RED_SCALE 0x80B4 + GL_POST_COLOR_MATRIX_GREEN_SCALE 0x80B5 + GL_POST_COLOR_MATRIX_BLUE_SCALE 0x80B6 + GL_POST_COLOR_MATRIX_ALPHA_SCALE 0x80B7 + GL_POST_COLOR_MATRIX_RED_BIAS 0x80B8 + GL_POST_COLOR_MATRIX_GREEN_BIAS 0x80B9 + GL_POST_COLOR_MATRIX_BLUE_BIAS 0x80BA + GL_POST_COLOR_MATRIX_ALPHA_BIAS 0x80BB + GL_COLOR_TABLE 0x80D0 + GL_POST_CONVOLUTION_COLOR_TABLE 0x80D1 + GL_POST_COLOR_MATRIX_COLOR_TABLE 0x80D2 + GL_PROXY_COLOR_TABLE 0x80D3 + GL_PROXY_POST_CONVOLUTION_COLOR_TABLE 0x80D4 + GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE 0x80D5 + GL_COLOR_TABLE_SCALE 0x80D6 + GL_COLOR_TABLE_BIAS 0x80D7 + GL_COLOR_TABLE_FORMAT 0x80D8 + GL_COLOR_TABLE_WIDTH 0x80D9 + GL_COLOR_TABLE_RED_SIZE 0x80DA + GL_COLOR_TABLE_GREEN_SIZE 0x80DB + GL_COLOR_TABLE_BLUE_SIZE 0x80DC + GL_COLOR_TABLE_ALPHA_SIZE 0x80DD + GL_COLOR_TABLE_LUMINANCE_SIZE 0x80DE + GL_COLOR_TABLE_INTENSITY_SIZE 0x80DF + GL_IGNORE_BORDER 0x8150 + GL_CONSTANT_BORDER 0x8151 + GL_WRAP_BORDER 0x8152 + GL_REPLICATE_BORDER 0x8153 + GL_CONVOLUTION_BORDER_COLOR 0x8154 + void glColorTable (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table) + void glColorSubTable (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data) + void glColorTableParameteriv (GLenum target, GLenum pname, const GLint *params) + void glColorTableParameterfv (GLenum target, GLenum pname, const GLfloat *params) + void glCopyColorSubTable (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width) + void glCopyColorTable (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width) + void glGetColorTable (GLenum target, GLenum format, GLenum type, GLvoid *table) + void glGetColorTableParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetColorTableParameteriv (GLenum target, GLenum pname, GLint *params) + void glHistogram (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink) + void glResetHistogram (GLenum target) + void glGetHistogram (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values) + void glGetHistogramParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetHistogramParameteriv (GLenum target, GLenum pname, GLint *params) + void glMinmax (GLenum target, GLenum internalformat, GLboolean sink) + void glResetMinmax (GLenum target) + void glGetMinmaxParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetMinmaxParameteriv (GLenum target, GLenum pname, GLint *params) + void glConvolutionFilter1D (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image) + void glConvolutionFilter2D (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image) + void glConvolutionParameterf (GLenum target, GLenum pname, GLfloat params) + void glConvolutionParameterfv (GLenum target, GLenum pname, const GLfloat *params) + void glConvolutionParameteri (GLenum target, GLenum pname, GLint params) + void glConvolutionParameteriv (GLenum target, GLenum pname, const GLint *params) + void glCopyConvolutionFilter1D (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width) + void glCopyConvolutionFilter2D (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height) + void glGetConvolutionFilter (GLenum target, GLenum format, GLenum type, GLvoid *image) + void glGetConvolutionParameterfv (GLenum target, GLenum pname, GLfloat *params) + void glGetConvolutionParameteriv (GLenum target, GLenum pname, GLint *params) + void glSeparableFilter2D (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column) + void glGetSeparableFilter (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span) + void glGetMinmax (GLenum target, GLboolean reset, GLenum format, GLenum types, GLvoid *values) diff --git a/Externals/GLew/auto/extensions/GL_ARB_instanced_arrays b/Externals/GLew/auto/extensions/GL_ARB_instanced_arrays new file mode 100644 index 0000000000..e3a5231205 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_instanced_arrays @@ -0,0 +1,5 @@ +GL_ARB_instanced_arrays +http://www.opengl.org/registry/specs/ARB/instanced_arrays.txt +GL_ARB_instanced_arrays + GL_VERTEX_ATTRIB_ARRAY_DIVISOR_ARB 0x88FE + void glVertexAttribDivisorARB (GLuint index, GLuint divisor) diff --git a/Externals/GLew/auto/extensions/GL_ARB_map_buffer_range b/Externals/GLew/auto/extensions/GL_ARB_map_buffer_range new file mode 100644 index 0000000000..6c55bf6174 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_map_buffer_range @@ -0,0 +1,11 @@ +GL_ARB_map_buffer_range +http://www.opengl.org/registry/specs/ARB/map_buffer_range.txt +GL_ARB_map_buffer_range + GL_MAP_READ_BIT 0x0001 + GL_MAP_WRITE_BIT 0x0002 + GL_MAP_INVALIDATE_RANGE_BIT 0x0004 + GL_MAP_INVALIDATE_BUFFER_BIT 0x0008 + GL_MAP_FLUSH_EXPLICIT_BIT 0x0010 + GL_MAP_UNSYNCHRONIZED_BIT 0x0020 + void glFlushMappedBufferRange (GLenum target, GLintptr offset, GLsizeiptr length) + GLvoid * glMapBufferRange (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access) diff --git a/Externals/GLew/auto/extensions/GL_ARB_matrix_palette b/Externals/GLew/auto/extensions/GL_ARB_matrix_palette new file mode 100644 index 0000000000..4b67c15cf4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_matrix_palette @@ -0,0 +1,18 @@ +GL_ARB_matrix_palette +http://oss.sgi.com/projects/ogl-sample/registry/ARB/matrix_palette.txt +GL_ARB_matrix_palette + GL_MATRIX_PALETTE_ARB 0x8840 + GL_MAX_MATRIX_PALETTE_STACK_DEPTH_ARB 0x8841 + GL_MAX_PALETTE_MATRICES_ARB 0x8842 + GL_CURRENT_PALETTE_MATRIX_ARB 0x8843 + GL_MATRIX_INDEX_ARRAY_ARB 0x8844 + GL_CURRENT_MATRIX_INDEX_ARB 0x8845 + GL_MATRIX_INDEX_ARRAY_SIZE_ARB 0x8846 + GL_MATRIX_INDEX_ARRAY_TYPE_ARB 0x8847 + GL_MATRIX_INDEX_ARRAY_STRIDE_ARB 0x8848 + GL_MATRIX_INDEX_ARRAY_POINTER_ARB 0x8849 + void glCurrentPaletteMatrixARB (GLint index) + void glMatrixIndexPointerARB (GLint size, GLenum type, GLsizei stride, GLvoid *pointer) + void glMatrixIndexubvARB (GLint size, GLubyte *indices) + void glMatrixIndexusvARB (GLint size, GLushort *indices) + void glMatrixIndexuivARB (GLint size, GLuint *indices) diff --git a/Externals/GLew/auto/extensions/GL_ARB_multisample b/Externals/GLew/auto/extensions/GL_ARB_multisample new file mode 100644 index 0000000000..6abf9e7f52 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_multisample @@ -0,0 +1,13 @@ +GL_ARB_multisample +http://www.opengl.org/registry/specs/ARB/multisample.txt +GL_ARB_multisample + GL_MULTISAMPLE_ARB 0x809D + GL_SAMPLE_ALPHA_TO_COVERAGE_ARB 0x809E + GL_SAMPLE_ALPHA_TO_ONE_ARB 0x809F + GL_SAMPLE_COVERAGE_ARB 0x80A0 + GL_SAMPLE_BUFFERS_ARB 0x80A8 + GL_SAMPLES_ARB 0x80A9 + GL_SAMPLE_COVERAGE_VALUE_ARB 0x80AA + GL_SAMPLE_COVERAGE_INVERT_ARB 0x80AB + GL_MULTISAMPLE_BIT_ARB 0x20000000 + void glSampleCoverageARB (GLclampf value, GLboolean invert) diff --git a/Externals/GLew/auto/extensions/GL_ARB_multitexture b/Externals/GLew/auto/extensions/GL_ARB_multitexture new file mode 100644 index 0000000000..ee80791831 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_multitexture @@ -0,0 +1,72 @@ +GL_ARB_multitexture +http://oss.sgi.com/projects/ogl-sample/registry/ARB/multitexture.txt +GL_ARB_multitexture + GL_TEXTURE0_ARB 0x84C0 + GL_TEXTURE1_ARB 0x84C1 + GL_TEXTURE2_ARB 0x84C2 + GL_TEXTURE3_ARB 0x84C3 + GL_TEXTURE4_ARB 0x84C4 + GL_TEXTURE5_ARB 0x84C5 + GL_TEXTURE6_ARB 0x84C6 + GL_TEXTURE7_ARB 0x84C7 + GL_TEXTURE8_ARB 0x84C8 + GL_TEXTURE9_ARB 0x84C9 + GL_TEXTURE10_ARB 0x84CA + GL_TEXTURE11_ARB 0x84CB + GL_TEXTURE12_ARB 0x84CC + GL_TEXTURE13_ARB 0x84CD + GL_TEXTURE14_ARB 0x84CE + GL_TEXTURE15_ARB 0x84CF + GL_TEXTURE16_ARB 0x84D0 + GL_TEXTURE17_ARB 0x84D1 + GL_TEXTURE18_ARB 0x84D2 + GL_TEXTURE19_ARB 0x84D3 + GL_TEXTURE20_ARB 0x84D4 + GL_TEXTURE21_ARB 0x84D5 + GL_TEXTURE22_ARB 0x84D6 + GL_TEXTURE23_ARB 0x84D7 + GL_TEXTURE24_ARB 0x84D8 + GL_TEXTURE25_ARB 0x84D9 + GL_TEXTURE26_ARB 0x84DA + GL_TEXTURE27_ARB 0x84DB + GL_TEXTURE28_ARB 0x84DC + GL_TEXTURE29_ARB 0x84DD + GL_TEXTURE30_ARB 0x84DE + GL_TEXTURE31_ARB 0x84DF + GL_ACTIVE_TEXTURE_ARB 0x84E0 + GL_CLIENT_ACTIVE_TEXTURE_ARB 0x84E1 + GL_MAX_TEXTURE_UNITS_ARB 0x84E2 + void glActiveTextureARB (GLenum texture) + void glClientActiveTextureARB (GLenum texture) + void glMultiTexCoord1dARB (GLenum target, GLdouble s) + void glMultiTexCoord1dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord1fARB (GLenum target, GLfloat s) + void glMultiTexCoord1fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord1iARB (GLenum target, GLint s) + void glMultiTexCoord1ivARB (GLenum target, const GLint *v) + void glMultiTexCoord1sARB (GLenum target, GLshort s) + void glMultiTexCoord1svARB (GLenum target, const GLshort *v) + void glMultiTexCoord2dARB (GLenum target, GLdouble s, GLdouble t) + void glMultiTexCoord2dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord2fARB (GLenum target, GLfloat s, GLfloat t) + void glMultiTexCoord2fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord2iARB (GLenum target, GLint s, GLint t) + void glMultiTexCoord2ivARB (GLenum target, const GLint *v) + void glMultiTexCoord2sARB (GLenum target, GLshort s, GLshort t) + void glMultiTexCoord2svARB (GLenum target, const GLshort *v) + void glMultiTexCoord3dARB (GLenum target, GLdouble s, GLdouble t, GLdouble r) + void glMultiTexCoord3dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord3fARB (GLenum target, GLfloat s, GLfloat t, GLfloat r) + void glMultiTexCoord3fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord3iARB (GLenum target, GLint s, GLint t, GLint r) + void glMultiTexCoord3ivARB (GLenum target, const GLint *v) + void glMultiTexCoord3sARB (GLenum target, GLshort s, GLshort t, GLshort r) + void glMultiTexCoord3svARB (GLenum target, const GLshort *v) + void glMultiTexCoord4dARB (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q) + void glMultiTexCoord4dvARB (GLenum target, const GLdouble *v) + void glMultiTexCoord4fARB (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q) + void glMultiTexCoord4fvARB (GLenum target, const GLfloat *v) + void glMultiTexCoord4iARB (GLenum target, GLint s, GLint t, GLint r, GLint q) + void glMultiTexCoord4ivARB (GLenum target, const GLint *v) + void glMultiTexCoord4sARB (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q) + void glMultiTexCoord4svARB (GLenum target, const GLshort *v) diff --git a/Externals/GLew/auto/extensions/GL_ARB_occlusion_query b/Externals/GLew/auto/extensions/GL_ARB_occlusion_query new file mode 100644 index 0000000000..18e10aa37a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_occlusion_query @@ -0,0 +1,16 @@ +GL_ARB_occlusion_query +http://www.opengl.org/registry/specs/ARB/occlusion_query.txt +GL_ARB_occlusion_query + GL_QUERY_COUNTER_BITS_ARB 0x8864 + GL_CURRENT_QUERY_ARB 0x8865 + GL_QUERY_RESULT_ARB 0x8866 + GL_QUERY_RESULT_AVAILABLE_ARB 0x8867 + GL_SAMPLES_PASSED_ARB 0x8914 + void glBeginQueryARB (GLenum target, GLuint id) + void glDeleteQueriesARB (GLsizei n, const GLuint* ids) + void glEndQueryARB (GLenum target) + void glGenQueriesARB (GLsizei n, GLuint* ids) + void glGetQueryObjectivARB (GLuint id, GLenum pname, GLint* params) + void glGetQueryObjectuivARB (GLuint id, GLenum pname, GLuint* params) + void glGetQueryivARB (GLenum target, GLenum pname, GLint* params) + GLboolean glIsQueryARB (GLuint id) diff --git a/Externals/GLew/auto/extensions/GL_ARB_occlusion_query2 b/Externals/GLew/auto/extensions/GL_ARB_occlusion_query2 new file mode 100644 index 0000000000..5dad0135f8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_occlusion_query2 @@ -0,0 +1,4 @@ +GL_ARB_occlusion_query2 +http://www.opengl.org/registry/specs/ARB/occlusion_query2.txt +GL_ARB_occlusion_query2 + GL_ANY_SAMPLES_PASSED 0x8C2F diff --git a/Externals/GLew/auto/extensions/GL_ARB_pixel_buffer_object b/Externals/GLew/auto/extensions/GL_ARB_pixel_buffer_object new file mode 100644 index 0000000000..ccec4ccde9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_pixel_buffer_object @@ -0,0 +1,7 @@ +GL_ARB_pixel_buffer_object +http://www.opengl.org/registry/specs/ARB/pixel_buffer_object.txt +GL_ARB_pixel_buffer_object + GL_PIXEL_PACK_BUFFER_ARB 0x88EB + GL_PIXEL_UNPACK_BUFFER_ARB 0x88EC + GL_PIXEL_PACK_BUFFER_BINDING_ARB 0x88ED + GL_PIXEL_UNPACK_BUFFER_BINDING_ARB 0x88EF diff --git a/Externals/GLew/auto/extensions/GL_ARB_point_parameters b/Externals/GLew/auto/extensions/GL_ARB_point_parameters new file mode 100644 index 0000000000..6c15a02171 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_point_parameters @@ -0,0 +1,9 @@ +GL_ARB_point_parameters +http://www.opengl.org/registry/specs/ARB/point_parameters.txt +GL_ARB_point_parameters + GL_POINT_SIZE_MIN_ARB 0x8126 + GL_POINT_SIZE_MAX_ARB 0x8127 + GL_POINT_FADE_THRESHOLD_SIZE_ARB 0x8128 + GL_POINT_DISTANCE_ATTENUATION_ARB 0x8129 + void glPointParameterfARB (GLenum pname, GLfloat param) + void glPointParameterfvARB (GLenum pname, GLfloat* params) diff --git a/Externals/GLew/auto/extensions/GL_ARB_point_sprite b/Externals/GLew/auto/extensions/GL_ARB_point_sprite new file mode 100644 index 0000000000..8f2c2e88ef --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_point_sprite @@ -0,0 +1,5 @@ +GL_ARB_point_sprite +http://www.opengl.org/registry/specs/ARB/point_sprite.txt +GL_ARB_point_sprite + GL_POINT_SPRITE_ARB 0x8861 + GL_COORD_REPLACE_ARB 0x8862 diff --git a/Externals/GLew/auto/extensions/GL_ARB_provoking_vertex b/Externals/GLew/auto/extensions/GL_ARB_provoking_vertex new file mode 100644 index 0000000000..3e2f16de43 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_provoking_vertex @@ -0,0 +1,8 @@ +GL_ARB_provoking_vertex +http://www.opengl.org/registry/specs/ARB/provoking_vertex.txt +GL_ARB_provoking_vertex + GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION 0x8E4C + GL_FIRST_VERTEX_CONVENTION 0x8E4D + GL_LAST_VERTEX_CONVENTION 0x8E4E + GL_PROVOKING_VERTEX 0x8E4F + void glProvokingVertex (GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_ARB_sample_shading b/Externals/GLew/auto/extensions/GL_ARB_sample_shading new file mode 100644 index 0000000000..0d8b105d80 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_sample_shading @@ -0,0 +1,6 @@ +GL_ARB_sample_shading +http://www.opengl.org/registry/specs/ARB/sample_shading.txt +GL_ARB_sample_shading + GL_SAMPLE_SHADING_ARB 0x8C36 + GL_MIN_SAMPLE_SHADING_VALUE_ARB 0x8C37 + void glMinSampleShadingARB (GLclampf value) diff --git a/Externals/GLew/auto/extensions/GL_ARB_sampler_objects b/Externals/GLew/auto/extensions/GL_ARB_sampler_objects new file mode 100644 index 0000000000..c9423909ea --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_sampler_objects @@ -0,0 +1,18 @@ +GL_ARB_sampler_objects +http://www.opengl.org/registry/specs/ARB/sampler_objects.txt +GL_ARB_sampler_objects + GL_SAMPLER_BINDING 0x8919 + void glBindSampler (GLuint unit, GLuint sampler) + void glDeleteSamplers (GLsizei count, const GLuint * samplers) + void glGenSamplers (GLsizei count, GLuint* samplers) + void glGetSamplerParameterIiv (GLuint sampler, GLenum pname, GLint* params) + void glGetSamplerParameterIuiv (GLuint sampler, GLenum pname, GLuint* params) + void glGetSamplerParameterfv (GLuint sampler, GLenum pname, GLfloat* params) + void glGetSamplerParameteriv (GLuint sampler, GLenum pname, GLint* params) + GLboolean glIsSampler (GLuint sampler) + void glSamplerParameterIiv (GLuint sampler, GLenum pname, const GLint* params) + void glSamplerParameterIuiv (GLuint sampler, GLenum pname, const GLuint* params) + void glSamplerParameterf (GLuint sampler, GLenum pname, GLfloat param) + void glSamplerParameterfv (GLuint sampler, GLenum pname, const GLfloat* params) + void glSamplerParameteri (GLuint sampler, GLenum pname, GLint param) + void glSamplerParameteriv (GLuint sampler, GLenum pname, const GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_ARB_seamless_cube_map b/Externals/GLew/auto/extensions/GL_ARB_seamless_cube_map new file mode 100644 index 0000000000..c6b5941b6e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_seamless_cube_map @@ -0,0 +1,4 @@ +GL_ARB_seamless_cube_map +http://www.opengl.org/registry/specs/ARB/seamless_cube_map.txt +GL_ARB_seamless_cube_map + GL_TEXTURE_CUBE_MAP_SEAMLESS 0x884F diff --git a/Externals/GLew/auto/extensions/GL_ARB_shader_bit_encoding b/Externals/GLew/auto/extensions/GL_ARB_shader_bit_encoding new file mode 100644 index 0000000000..9c00ed7e52 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shader_bit_encoding @@ -0,0 +1,3 @@ +GL_ARB_shader_bit_encoding +http://www.opengl.org/registry/specs/ARB/shader_bit_encoding.txt +GL_ARB_shader_bit_encoding diff --git a/Externals/GLew/auto/extensions/GL_ARB_shader_objects b/Externals/GLew/auto/extensions/GL_ARB_shader_objects new file mode 100644 index 0000000000..fc24d978a4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shader_objects @@ -0,0 +1,78 @@ +GL_ARB_shader_objects +http://www.opengl.org/registry/specs/ARB/shader_objects.txt +GL_ARB_shader_objects + GL_PROGRAM_OBJECT_ARB 0x8B40 + GL_SHADER_OBJECT_ARB 0x8B48 + GL_OBJECT_TYPE_ARB 0x8B4E + GL_OBJECT_SUBTYPE_ARB 0x8B4F + GL_FLOAT_VEC2_ARB 0x8B50 + GL_FLOAT_VEC3_ARB 0x8B51 + GL_FLOAT_VEC4_ARB 0x8B52 + GL_INT_VEC2_ARB 0x8B53 + GL_INT_VEC3_ARB 0x8B54 + GL_INT_VEC4_ARB 0x8B55 + GL_BOOL_ARB 0x8B56 + GL_BOOL_VEC2_ARB 0x8B57 + GL_BOOL_VEC3_ARB 0x8B58 + GL_BOOL_VEC4_ARB 0x8B59 + GL_FLOAT_MAT2_ARB 0x8B5A + GL_FLOAT_MAT3_ARB 0x8B5B + GL_FLOAT_MAT4_ARB 0x8B5C + GL_SAMPLER_1D_ARB 0x8B5D + GL_SAMPLER_2D_ARB 0x8B5E + GL_SAMPLER_3D_ARB 0x8B5F + GL_SAMPLER_CUBE_ARB 0x8B60 + GL_SAMPLER_1D_SHADOW_ARB 0x8B61 + GL_SAMPLER_2D_SHADOW_ARB 0x8B62 + GL_SAMPLER_2D_RECT_ARB 0x8B63 + GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 + GL_OBJECT_DELETE_STATUS_ARB 0x8B80 + GL_OBJECT_COMPILE_STATUS_ARB 0x8B81 + GL_OBJECT_LINK_STATUS_ARB 0x8B82 + GL_OBJECT_VALIDATE_STATUS_ARB 0x8B83 + GL_OBJECT_INFO_LOG_LENGTH_ARB 0x8B84 + GL_OBJECT_ATTACHED_OBJECTS_ARB 0x8B85 + GL_OBJECT_ACTIVE_UNIFORMS_ARB 0x8B86 + GL_OBJECT_ACTIVE_UNIFORM_MAX_LENGTH_ARB 0x8B87 + GL_OBJECT_SHADER_SOURCE_LENGTH_ARB 0x8B88 + void glAttachObjectARB (GLhandleARB containerObj, GLhandleARB obj) + void glCompileShaderARB (GLhandleARB shaderObj) + GLhandleARB glCreateProgramObjectARB (void) + GLhandleARB glCreateShaderObjectARB (GLenum shaderType) + void glDeleteObjectARB (GLhandleARB obj) + void glDetachObjectARB (GLhandleARB containerObj, GLhandleARB attachedObj) + void glGetActiveUniformARB (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name) + void glGetAttachedObjectsARB (GLhandleARB containerObj, GLsizei maxCount, GLsizei* count, GLhandleARB *obj) + GLhandleARB glGetHandleARB (GLenum pname) + void glGetInfoLogARB (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *infoLog) + void glGetObjectParameterfvARB (GLhandleARB obj, GLenum pname, GLfloat* params) + void glGetObjectParameterivARB (GLhandleARB obj, GLenum pname, GLint* params) + void glGetShaderSourceARB (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *source) + GLint glGetUniformLocationARB (GLhandleARB programObj, const GLcharARB* name) + void glGetUniformfvARB (GLhandleARB programObj, GLint location, GLfloat* params) + void glGetUniformivARB (GLhandleARB programObj, GLint location, GLint* params) + void glLinkProgramARB (GLhandleARB programObj) + void glShaderSourceARB (GLhandleARB shaderObj, GLsizei count, const GLcharARB ** string, const GLint *length) + void glUniform1fARB (GLint location, GLfloat v0) + void glUniform1fvARB (GLint location, GLsizei count, const GLfloat* value) + void glUniform1iARB (GLint location, GLint v0) + void glUniform1ivARB (GLint location, GLsizei count, const GLint* value) + void glUniform2fARB (GLint location, GLfloat v0, GLfloat v1) + void glUniform2fvARB (GLint location, GLsizei count, const GLfloat* value) + void glUniform2iARB (GLint location, GLint v0, GLint v1) + void glUniform2ivARB (GLint location, GLsizei count, const GLint* value) + void glUniform3fARB (GLint location, GLfloat v0, GLfloat v1, GLfloat v2) + void glUniform3fvARB (GLint location, GLsizei count, const GLfloat* value) + void glUniform3iARB (GLint location, GLint v0, GLint v1, GLint v2) + void glUniform3ivARB (GLint location, GLsizei count, const GLint* value) + void glUniform4fARB (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3) + void glUniform4fvARB (GLint location, GLsizei count, const GLfloat* value) + void glUniform4iARB (GLint location, GLint v0, GLint v1, GLint v2, GLint v3) + void glUniform4ivARB (GLint location, GLsizei count, const GLint* value) + void glUniformMatrix2fvARB (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glUniformMatrix3fvARB (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glUniformMatrix4fvARB (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glUseProgramObjectARB (GLhandleARB programObj) + void glValidateProgramARB (GLhandleARB programObj) + typedef char GLcharARB + typedef unsigned int GLhandleARB diff --git a/Externals/GLew/auto/extensions/GL_ARB_shader_subroutine b/Externals/GLew/auto/extensions/GL_ARB_shader_subroutine new file mode 100644 index 0000000000..a89f08f390 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shader_subroutine @@ -0,0 +1,20 @@ +GL_ARB_shader_subroutine +http://www.opengl.org/registry/specs/ARB/shader_subroutine.txt +GL_ARB_shader_subroutine + GL_ACTIVE_SUBROUTINES 0x8DE5 + GL_ACTIVE_SUBROUTINE_UNIFORMS 0x8DE6 + GL_MAX_SUBROUTINES 0x8DE7 + GL_MAX_SUBROUTINE_UNIFORM_LOCATIONS 0x8DE8 + GL_ACTIVE_SUBROUTINE_UNIFORM_LOCATIONS 0x8E47 + GL_ACTIVE_SUBROUTINE_MAX_LENGTH 0x8E48 + GL_ACTIVE_SUBROUTINE_UNIFORM_MAX_LENGTH 0x8E49 + GL_NUM_COMPATIBLE_SUBROUTINES 0x8E4A + GL_COMPATIBLE_SUBROUTINES 0x8E4B + void glGetActiveSubroutineName (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, char *name) + void glGetActiveSubroutineUniformName (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, char *name) + void glGetActiveSubroutineUniformiv (GLuint program, GLenum shadertype, GLuint index, GLenum pname, GLint* values) + void glGetProgramStageiv (GLuint program, GLenum shadertype, GLenum pname, GLint* values) + GLuint glGetSubroutineIndex (GLuint program, GLenum shadertype, const char* name) + GLint glGetSubroutineUniformLocation (GLuint program, GLenum shadertype, const char* name) + void glGetUniformSubroutineuiv (GLenum shadertype, GLint location, GLuint* params) + void glUniformSubroutinesuiv (GLenum shadertype, GLsizei count, const GLuint* indices) diff --git a/Externals/GLew/auto/extensions/GL_ARB_shader_texture_lod b/Externals/GLew/auto/extensions/GL_ARB_shader_texture_lod new file mode 100644 index 0000000000..1366c86e88 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shader_texture_lod @@ -0,0 +1,3 @@ +GL_ARB_shader_texture_lod +http://www.opengl.org/registry/specs/ARB/shader_texture_lod.txt +GL_ARB_shader_texture_lod diff --git a/Externals/GLew/auto/extensions/GL_ARB_shading_language_100 b/Externals/GLew/auto/extensions/GL_ARB_shading_language_100 new file mode 100644 index 0000000000..53cd0d46f0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shading_language_100 @@ -0,0 +1,4 @@ +GL_ARB_shading_language_100 +http://www.opengl.org/registry/specs/ARB/shading_language_100.txt +GL_ARB_shading_language_100 + GL_SHADING_LANGUAGE_VERSION_ARB 0x8B8C diff --git a/Externals/GLew/auto/extensions/GL_ARB_shading_language_include b/Externals/GLew/auto/extensions/GL_ARB_shading_language_include new file mode 100644 index 0000000000..d8dd5b2b69 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shading_language_include @@ -0,0 +1,12 @@ +GL_ARB_shading_language_include +http://www.opengl.org/registry/specs/ARB/shading_language_include.txt +GL_ARB_shading_language_include + GL_SHADER_INCLUDE_ARB 0x8DAE + GL_NAMED_STRING_LENGTH_ARB 0x8DE9 + GL_NAMED_STRING_TYPE_ARB 0x8DEA + void glCompileShaderIncludeARB (GLuint shader, GLsizei count, const char ** path, const GLint *length) + void glDeleteNamedStringARB (GLint namelen, const char* name) + void glGetNamedStringARB (GLint namelen, const char* name, GLsizei bufSize, GLint *stringlen, char *string) + void glGetNamedStringivARB (GLint namelen, const char* name, GLenum pname, GLint *params) + GLboolean glIsNamedStringARB (GLint namelen, const char* name) + void glNamedStringARB (GLenum type, GLint namelen, const char* name, GLint stringlen, const char *string) diff --git a/Externals/GLew/auto/extensions/GL_ARB_shadow b/Externals/GLew/auto/extensions/GL_ARB_shadow new file mode 100644 index 0000000000..eeaca307f7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shadow @@ -0,0 +1,6 @@ +GL_ARB_shadow +http://www.opengl.org/registry/specs/ARB/shadow.txt +GL_ARB_shadow + GL_TEXTURE_COMPARE_MODE_ARB 0x884C + GL_TEXTURE_COMPARE_FUNC_ARB 0x884D + GL_COMPARE_R_TO_TEXTURE_ARB 0x884E diff --git a/Externals/GLew/auto/extensions/GL_ARB_shadow_ambient b/Externals/GLew/auto/extensions/GL_ARB_shadow_ambient new file mode 100644 index 0000000000..d2e13a04b4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_shadow_ambient @@ -0,0 +1,4 @@ +GL_ARB_shadow_ambient +http://www.opengl.org/registry/specs/ARB/shadow_ambient.txt +GL_ARB_shadow_ambient + GL_TEXTURE_COMPARE_FAIL_VALUE_ARB 0x80BF diff --git a/Externals/GLew/auto/extensions/GL_ARB_sync b/Externals/GLew/auto/extensions/GL_ARB_sync new file mode 100644 index 0000000000..883dc897d7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_sync @@ -0,0 +1,25 @@ +GL_ARB_sync +http://www.opengl.org/registry/specs/ARB/sync.txt +GL_ARB_sync + GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001 + GL_MAX_SERVER_WAIT_TIMEOUT 0x9111 + GL_OBJECT_TYPE 0x9112 + GL_SYNC_CONDITION 0x9113 + GL_SYNC_STATUS 0x9114 + GL_SYNC_FLAGS 0x9115 + GL_SYNC_FENCE 0x9116 + GL_SYNC_GPU_COMMANDS_COMPLETE 0x9117 + GL_UNSIGNALED 0x9118 + GL_SIGNALED 0x9119 + GL_ALREADY_SIGNALED 0x911A + GL_TIMEOUT_EXPIRED 0x911B + GL_CONDITION_SATISFIED 0x911C + GL_WAIT_FAILED 0x911D + GL_TIMEOUT_IGNORED 0xFFFFFFFFFFFFFFFF + GLenum glClientWaitSync (GLsync GLsync,GLbitfield flags,GLuint64 timeout) + void glDeleteSync (GLsync GLsync) + GLsync glFenceSync (GLenum condition,GLbitfield flags) + void glGetInteger64v (GLenum pname, GLint64* params) + void glGetSynciv (GLsync GLsync,GLenum pname,GLsizei bufSize,GLsizei* length, GLint *values) + GLboolean glIsSync (GLsync GLsync) + void glWaitSync (GLsync GLsync,GLbitfield flags,GLuint64 timeout) diff --git a/Externals/GLew/auto/extensions/GL_ARB_tessellation_shader b/Externals/GLew/auto/extensions/GL_ARB_tessellation_shader new file mode 100644 index 0000000000..c7376507cc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_tessellation_shader @@ -0,0 +1,37 @@ +GL_ARB_tessellation_shader +http://www.opengl.org/registry/specs/ARB/tessellation_shader.txt +GL_ARB_tessellation_shader + GL_PATCHES 0xE + GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_CONTROL_SHADER 0x84F0 + GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_EVALUATION_SHADER 0x84F1 + GL_MAX_TESS_CONTROL_INPUT_COMPONENTS 0x886C + GL_MAX_TESS_EVALUATION_INPUT_COMPONENTS 0x886D + GL_MAX_COMBINED_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E1E + GL_MAX_COMBINED_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E1F + GL_PATCH_VERTICES 0x8E72 + GL_PATCH_DEFAULT_INNER_LEVEL 0x8E73 + GL_PATCH_DEFAULT_OUTER_LEVEL 0x8E74 + GL_TESS_CONTROL_OUTPUT_VERTICES 0x8E75 + GL_TESS_GEN_MODE 0x8E76 + GL_TESS_GEN_SPACING 0x8E77 + GL_TESS_GEN_VERTEX_ORDER 0x8E78 + GL_TESS_GEN_POINT_MODE 0x8E79 + GL_ISOLINES 0x8E7A + GL_FRACTIONAL_ODD 0x8E7B + GL_FRACTIONAL_EVEN 0x8E7C + GL_MAX_PATCH_VERTICES 0x8E7D + GL_MAX_TESS_GEN_LEVEL 0x8E7E + GL_MAX_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E7F + GL_MAX_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E80 + GL_MAX_TESS_CONTROL_TEXTURE_IMAGE_UNITS 0x8E81 + GL_MAX_TESS_EVALUATION_TEXTURE_IMAGE_UNITS 0x8E82 + GL_MAX_TESS_CONTROL_OUTPUT_COMPONENTS 0x8E83 + GL_MAX_TESS_PATCH_COMPONENTS 0x8E84 + GL_MAX_TESS_CONTROL_TOTAL_OUTPUT_COMPONENTS 0x8E85 + GL_MAX_TESS_EVALUATION_OUTPUT_COMPONENTS 0x8E86 + GL_TESS_EVALUATION_SHADER 0x8E87 + GL_TESS_CONTROL_SHADER 0x8E88 + GL_MAX_TESS_CONTROL_UNIFORM_BLOCKS 0x8E89 + GL_MAX_TESS_EVALUATION_UNIFORM_BLOCKS 0x8E8A + void glPatchParameterfv (GLenum pname, const GLfloat* values) + void glPatchParameteri (GLenum pname, GLint value) diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_border_clamp b/Externals/GLew/auto/extensions/GL_ARB_texture_border_clamp new file mode 100644 index 0000000000..14e74fbe03 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_border_clamp @@ -0,0 +1,4 @@ +GL_ARB_texture_border_clamp +http://www.opengl.org/registry/specs/ARB/texture_border_clamp.txt +GL_ARB_texture_border_clamp + GL_CLAMP_TO_BORDER_ARB 0x812D diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object b/Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object new file mode 100644 index 0000000000..bae7fc6e17 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object @@ -0,0 +1,9 @@ +GL_ARB_texture_buffer_object +http://www.opengl.org/registry/specs/ARB/texture_buffer_object.txt +GL_ARB_texture_buffer_object + GL_TEXTURE_BUFFER_ARB 0x8C2A + GL_MAX_TEXTURE_BUFFER_SIZE_ARB 0x8C2B + GL_TEXTURE_BINDING_BUFFER_ARB 0x8C2C + GL_TEXTURE_BUFFER_DATA_STORE_BINDING_ARB 0x8C2D + GL_TEXTURE_BUFFER_FORMAT_ARB 0x8C2E + void glTexBufferARB (GLenum target, GLenum internalformat, GLuint buffer) diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object_rgb32 b/Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object_rgb32 new file mode 100644 index 0000000000..ddac257ebe --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_buffer_object_rgb32 @@ -0,0 +1,3 @@ +GL_ARB_texture_buffer_object_rgb32 +http://www.opengl.org/registry/specs/ARB/texture_buffer_object_rgb32.txt +GL_ARB_texture_buffer_object_rgb32 diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_compression b/Externals/GLew/auto/extensions/GL_ARB_texture_compression new file mode 100644 index 0000000000..c32a6fba88 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_compression @@ -0,0 +1,21 @@ +GL_ARB_texture_compression +http://www.opengl.org/registry/specs/ARB/texture_compression.txt +GL_ARB_texture_compression + GL_COMPRESSED_ALPHA_ARB 0x84E9 + GL_COMPRESSED_LUMINANCE_ARB 0x84EA + GL_COMPRESSED_LUMINANCE_ALPHA_ARB 0x84EB + GL_COMPRESSED_INTENSITY_ARB 0x84EC + GL_COMPRESSED_RGB_ARB 0x84ED + GL_COMPRESSED_RGBA_ARB 0x84EE + GL_TEXTURE_COMPRESSION_HINT_ARB 0x84EF + GL_TEXTURE_COMPRESSED_IMAGE_SIZE_ARB 0x86A0 + GL_TEXTURE_COMPRESSED_ARB 0x86A1 + GL_NUM_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A2 + GL_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A3 + void glCompressedTexImage1DARB (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data) + void glCompressedTexImage2DARB (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data) + void glCompressedTexImage3DARB (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data) + void glCompressedTexSubImage1DARB (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data) + void glCompressedTexSubImage2DARB (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data) + void glCompressedTexSubImage3DARB (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data) + void glGetCompressedTexImageARB (GLenum target, GLint lod, void* img) diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_compression_bptc b/Externals/GLew/auto/extensions/GL_ARB_texture_compression_bptc new file mode 100644 index 0000000000..a476d78f4c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_compression_bptc @@ -0,0 +1,7 @@ +GL_ARB_texture_compression_bptc +http://www.opengl.org/registry/specs/ARB/texture_compression_bptc.txt +GL_ARB_texture_compression_bptc + GL_COMPRESSED_RGBA_BPTC_UNORM_ARB 0x8E8C + GL_COMPRESSED_SRGB_ALPHA_BPTC_UNORM_ARB 0x8E8D + GL_COMPRESSED_RGB_BPTC_SIGNED_FLOAT_ARB 0x8E8E + GL_COMPRESSED_RGB_BPTC_UNSIGNED_FLOAT_ARB 0x8E8F diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_compression_rgtc b/Externals/GLew/auto/extensions/GL_ARB_texture_compression_rgtc new file mode 100644 index 0000000000..233597e61d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_compression_rgtc @@ -0,0 +1,7 @@ +GL_ARB_texture_compression_rgtc +http://www.opengl.org/registry/specs/ARB/texture_compression_rgtc.txt +GL_ARB_texture_compression_rgtc + GL_COMPRESSED_RED_RGTC1 0x8DBB + GL_COMPRESSED_SIGNED_RED_RGTC1 0x8DBC + GL_COMPRESSED_RG_RGTC2 0x8DBD + GL_COMPRESSED_SIGNED_RG_RGTC2 0x8DBE diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_cube_map b/Externals/GLew/auto/extensions/GL_ARB_texture_cube_map new file mode 100644 index 0000000000..67f232e6a5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_cube_map @@ -0,0 +1,15 @@ +GL_ARB_texture_cube_map +http://www.opengl.org/registry/specs/ARB/texture_cube_map.txt +GL_ARB_texture_cube_map + GL_NORMAL_MAP_ARB 0x8511 + GL_REFLECTION_MAP_ARB 0x8512 + GL_TEXTURE_CUBE_MAP_ARB 0x8513 + GL_TEXTURE_BINDING_CUBE_MAP_ARB 0x8514 + GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x8515 + GL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x8516 + GL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x8517 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x8518 + GL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x8519 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x851A + GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B + GL_MAX_CUBE_MAP_TEXTURE_SIZE_ARB 0x851C diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_cube_map_array b/Externals/GLew/auto/extensions/GL_ARB_texture_cube_map_array new file mode 100644 index 0000000000..fcb7223ec9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_cube_map_array @@ -0,0 +1,10 @@ +GL_ARB_texture_cube_map_array +http://www.opengl.org/registry/specs/ARB/texture_cube_map_array.txt +GL_ARB_texture_cube_map_array + GL_TEXTURE_CUBE_MAP_ARRAY_ARB 0x9009 + GL_TEXTURE_BINDING_CUBE_MAP_ARRAY_ARB 0x900A + GL_PROXY_TEXTURE_CUBE_MAP_ARRAY_ARB 0x900B + GL_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900C + GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW_ARB 0x900D + GL_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900E + GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900F diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_env_add b/Externals/GLew/auto/extensions/GL_ARB_texture_env_add new file mode 100644 index 0000000000..9f6f889e4a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_env_add @@ -0,0 +1,3 @@ +GL_ARB_texture_env_add +http://www.opengl.org/registry/specs/ARB/texture_env_add.txt +GL_ARB_texture_env_add diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_env_combine b/Externals/GLew/auto/extensions/GL_ARB_texture_env_combine new file mode 100644 index 0000000000..94d689e000 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_env_combine @@ -0,0 +1,25 @@ +GL_ARB_texture_env_combine +http://www.opengl.org/registry/specs/ARB/texture_env_combine.txt +GL_ARB_texture_env_combine + GL_SUBTRACT_ARB 0x84E7 + GL_COMBINE_ARB 0x8570 + GL_COMBINE_RGB_ARB 0x8571 + GL_COMBINE_ALPHA_ARB 0x8572 + GL_RGB_SCALE_ARB 0x8573 + GL_ADD_SIGNED_ARB 0x8574 + GL_INTERPOLATE_ARB 0x8575 + GL_CONSTANT_ARB 0x8576 + GL_PRIMARY_COLOR_ARB 0x8577 + GL_PREVIOUS_ARB 0x8578 + GL_SOURCE0_RGB_ARB 0x8580 + GL_SOURCE1_RGB_ARB 0x8581 + GL_SOURCE2_RGB_ARB 0x8582 + GL_SOURCE0_ALPHA_ARB 0x8588 + GL_SOURCE1_ALPHA_ARB 0x8589 + GL_SOURCE2_ALPHA_ARB 0x858A + GL_OPERAND0_RGB_ARB 0x8590 + GL_OPERAND1_RGB_ARB 0x8591 + GL_OPERAND2_RGB_ARB 0x8592 + GL_OPERAND0_ALPHA_ARB 0x8598 + GL_OPERAND1_ALPHA_ARB 0x8599 + GL_OPERAND2_ALPHA_ARB 0x859A diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_env_crossbar b/Externals/GLew/auto/extensions/GL_ARB_texture_env_crossbar new file mode 100644 index 0000000000..93aa97f428 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_env_crossbar @@ -0,0 +1,3 @@ +GL_ARB_texture_env_crossbar +http://www.opengl.org/registry/specs/ARB/texture_env_crossbar.txt +GL_ARB_texture_env_crossbar diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_env_dot3 b/Externals/GLew/auto/extensions/GL_ARB_texture_env_dot3 new file mode 100644 index 0000000000..6e6587fab4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_env_dot3 @@ -0,0 +1,5 @@ +GL_ARB_texture_env_dot3 +http://www.opengl.org/registry/specs/ARB/texture_env_dot3.txt +GL_ARB_texture_env_dot3 + GL_DOT3_RGB_ARB 0x86AE + GL_DOT3_RGBA_ARB 0x86AF diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_float b/Externals/GLew/auto/extensions/GL_ARB_texture_float new file mode 100644 index 0000000000..14d0de6953 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_float @@ -0,0 +1,23 @@ +GL_ARB_texture_float +http://www.opengl.org/registry/specs/ARB/texture_float.txt +GL_ARB_texture_float + GL_RGBA32F_ARB 0x8814 + GL_RGB32F_ARB 0x8815 + GL_ALPHA32F_ARB 0x8816 + GL_INTENSITY32F_ARB 0x8817 + GL_LUMINANCE32F_ARB 0x8818 + GL_LUMINANCE_ALPHA32F_ARB 0x8819 + GL_RGBA16F_ARB 0x881A + GL_RGB16F_ARB 0x881B + GL_ALPHA16F_ARB 0x881C + GL_INTENSITY16F_ARB 0x881D + GL_LUMINANCE16F_ARB 0x881E + GL_LUMINANCE_ALPHA16F_ARB 0x881F + GL_TEXTURE_RED_TYPE_ARB 0x8C10 + GL_TEXTURE_GREEN_TYPE_ARB 0x8C11 + GL_TEXTURE_BLUE_TYPE_ARB 0x8C12 + GL_TEXTURE_ALPHA_TYPE_ARB 0x8C13 + GL_TEXTURE_LUMINANCE_TYPE_ARB 0x8C14 + GL_TEXTURE_INTENSITY_TYPE_ARB 0x8C15 + GL_TEXTURE_DEPTH_TYPE_ARB 0x8C16 + GL_UNSIGNED_NORMALIZED_ARB 0x8C17 diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_gather b/Externals/GLew/auto/extensions/GL_ARB_texture_gather new file mode 100644 index 0000000000..0f5fd182a4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_gather @@ -0,0 +1,6 @@ +GL_ARB_texture_gather +http://www.opengl.org/registry/specs/ARB/texture_gather.txt +GL_ARB_texture_gather + GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5E + GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5F + GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS_ARB 0x8F9F diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_mirrored_repeat b/Externals/GLew/auto/extensions/GL_ARB_texture_mirrored_repeat new file mode 100644 index 0000000000..6d664e9eab --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_mirrored_repeat @@ -0,0 +1,4 @@ +GL_ARB_texture_mirrored_repeat +http://www.opengl.org/registry/specs/ARB/texture_mirrored_repeat.txt +GL_ARB_texture_mirrored_repeat + GL_MIRRORED_REPEAT_ARB 0x8370 diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_multisample b/Externals/GLew/auto/extensions/GL_ARB_texture_multisample new file mode 100644 index 0000000000..9e0e89662b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_multisample @@ -0,0 +1,28 @@ +GL_ARB_texture_multisample +http://www.opengl.org/registry/specs/ARB/texture_multisample.txt +GL_ARB_texture_multisample + GL_SAMPLE_POSITION 0x8E50 + GL_SAMPLE_MASK 0x8E51 + GL_SAMPLE_MASK_VALUE 0x8E52 + GL_MAX_SAMPLE_MASK_WORDS 0x8E59 + GL_TEXTURE_2D_MULTISAMPLE 0x9100 + GL_PROXY_TEXTURE_2D_MULTISAMPLE 0x9101 + GL_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9102 + GL_PROXY_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9103 + GL_TEXTURE_BINDING_2D_MULTISAMPLE 0x9104 + GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY 0x9105 + GL_TEXTURE_SAMPLES 0x9106 + GL_TEXTURE_FIXED_SAMPLE_LOCATIONS 0x9107 + GL_SAMPLER_2D_MULTISAMPLE 0x9108 + GL_INT_SAMPLER_2D_MULTISAMPLE 0x9109 + GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE 0x910A + GL_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910B + GL_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910C + GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910D + GL_MAX_COLOR_TEXTURE_SAMPLES 0x910E + GL_MAX_DEPTH_TEXTURE_SAMPLES 0x910F + GL_MAX_INTEGER_SAMPLES 0x9110 + void glGetMultisamplefv (GLenum pname, GLuint index, GLfloat* val) + void glSampleMaski (GLuint index, GLbitfield mask) + void glTexImage2DMultisample (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations) + void glTexImage3DMultisample (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations) diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_non_power_of_two b/Externals/GLew/auto/extensions/GL_ARB_texture_non_power_of_two new file mode 100644 index 0000000000..c711111f51 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_non_power_of_two @@ -0,0 +1,3 @@ +GL_ARB_texture_non_power_of_two +http://www.opengl.org/registry/specs/ARB/texture_non_power_of_two.txt +GL_ARB_texture_non_power_of_two diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_query_lod b/Externals/GLew/auto/extensions/GL_ARB_texture_query_lod new file mode 100644 index 0000000000..981dc84c68 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_query_lod @@ -0,0 +1,3 @@ +GL_ARB_texture_query_lod +http://www.opengl.org/registry/specs/ARB/texture_query_lod.txt +GL_ARB_texture_query_lod diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_rectangle b/Externals/GLew/auto/extensions/GL_ARB_texture_rectangle new file mode 100644 index 0000000000..33915d165d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_rectangle @@ -0,0 +1,9 @@ +GL_ARB_texture_rectangle +http://www.opengl.org/registry/specs/ARB/texture_rectangle.txt +GL_ARB_texture_rectangle + GL_TEXTURE_RECTANGLE_ARB 0x84F5 + GL_TEXTURE_BINDING_RECTANGLE_ARB 0x84F6 + GL_PROXY_TEXTURE_RECTANGLE_ARB 0x84F7 + GL_MAX_RECTANGLE_TEXTURE_SIZE_ARB 0x84F8 + GL_SAMPLER_2D_RECT_ARB 0x8B63 + GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_rg b/Externals/GLew/auto/extensions/GL_ARB_texture_rg new file mode 100644 index 0000000000..1f55eff6d1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_rg @@ -0,0 +1,28 @@ +GL_ARB_texture_rg +http://www.opengl.org/registry/specs/ARB/texture_rg.txt +GL_ARB_texture_rg + GL_RED 0x1903 + GL_COMPRESSED_RED 0x8225 + GL_COMPRESSED_RG 0x8226 + GL_RG 0x8227 + GL_RG_INTEGER 0x8228 + GL_R8 0x8229 + GL_R16 0x822A + GL_RG8 0x822B + GL_RG16 0x822C + GL_R16F 0x822D + GL_R32F 0x822E + GL_RG16F 0x822F + GL_RG32F 0x8230 + GL_R8I 0x8231 + GL_R8UI 0x8232 + GL_R16I 0x8233 + GL_R16UI 0x8234 + GL_R32I 0x8235 + GL_R32UI 0x8236 + GL_RG8I 0x8237 + GL_RG8UI 0x8238 + GL_RG16I 0x8239 + GL_RG16UI 0x823A + GL_RG32I 0x823B + GL_RG32UI 0x823C diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_rgb10_a2ui b/Externals/GLew/auto/extensions/GL_ARB_texture_rgb10_a2ui new file mode 100644 index 0000000000..7e5d4db08b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_rgb10_a2ui @@ -0,0 +1,4 @@ +GL_ARB_texture_rgb10_a2ui +http://www.opengl.org/registry/specs/ARB/texture_rgb10_a2ui.txt +GL_ARB_texture_rgb10_a2ui + GL_RGB10_A2UI 0x906F diff --git a/Externals/GLew/auto/extensions/GL_ARB_texture_swizzle b/Externals/GLew/auto/extensions/GL_ARB_texture_swizzle new file mode 100644 index 0000000000..4553324605 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_texture_swizzle @@ -0,0 +1,8 @@ +GL_ARB_texture_swizzle +http://www.opengl.org/registry/specs/ARB/texture_swizzle.txt +GL_ARB_texture_swizzle + GL_TEXTURE_SWIZZLE_R 0x8E42 + GL_TEXTURE_SWIZZLE_G 0x8E43 + GL_TEXTURE_SWIZZLE_B 0x8E44 + GL_TEXTURE_SWIZZLE_A 0x8E45 + GL_TEXTURE_SWIZZLE_RGBA 0x8E46 diff --git a/Externals/GLew/auto/extensions/GL_ARB_timer_query b/Externals/GLew/auto/extensions/GL_ARB_timer_query new file mode 100644 index 0000000000..6f64ace39a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_timer_query @@ -0,0 +1,8 @@ +GL_ARB_timer_query +http://www.opengl.org/registry/specs/ARB/timer_query.txt +GL_ARB_timer_query + GL_TIME_ELAPSED 0x88BF + GL_TIMESTAMP 0x8E28 + void glGetQueryObjecti64v (GLuint id, GLenum pname, GLint64* params) + void glGetQueryObjectui64v (GLuint id, GLenum pname, GLuint64* params) + void glQueryCounter (GLuint id, GLenum target) diff --git a/Externals/GLew/auto/extensions/GL_ARB_transform_feedback2 b/Externals/GLew/auto/extensions/GL_ARB_transform_feedback2 new file mode 100644 index 0000000000..06c362677f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_transform_feedback2 @@ -0,0 +1,14 @@ +GL_ARB_transform_feedback2 +http://www.opengl.org/registry/specs/ARB/transform_feedback2.txt +GL_ARB_transform_feedback2 + GL_TRANSFORM_FEEDBACK 0x8E22 + GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED 0x8E23 + GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE 0x8E24 + GL_TRANSFORM_FEEDBACK_BINDING 0x8E25 + void glBindTransformFeedback (GLenum target, GLuint id) + void glDeleteTransformFeedbacks (GLsizei n, const GLuint* ids) + void glDrawTransformFeedback (GLenum mode, GLuint id) + void glGenTransformFeedbacks (GLsizei n, GLuint* ids) + GLboolean glIsTransformFeedback (GLuint id) + void glPauseTransformFeedback (void) + void glResumeTransformFeedback (void) diff --git a/Externals/GLew/auto/extensions/GL_ARB_transform_feedback3 b/Externals/GLew/auto/extensions/GL_ARB_transform_feedback3 new file mode 100644 index 0000000000..37e8f3543a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_transform_feedback3 @@ -0,0 +1,9 @@ +GL_ARB_transform_feedback3 +http://www.opengl.org/registry/specs/ARB/transform_feedback3.txt +GL_ARB_transform_feedback3 + GL_MAX_TRANSFORM_FEEDBACK_BUFFERS 0x8E70 + GL_MAX_VERTEX_STREAMS 0x8E71 + void glBeginQueryIndexed (GLenum target, GLuint index, GLuint id) + void glDrawTransformFeedbackStream (GLenum mode, GLuint id, GLuint stream) + void glEndQueryIndexed (GLenum target, GLuint index) + void glGetQueryIndexediv (GLenum target, GLuint index, GLenum pname, GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_ARB_transpose_matrix b/Externals/GLew/auto/extensions/GL_ARB_transpose_matrix new file mode 100644 index 0000000000..e869bd5aa8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_transpose_matrix @@ -0,0 +1,11 @@ +GL_ARB_transpose_matrix +http://www.opengl.org/registry/specs/ARB/transpose_matrix.txt +GL_ARB_transpose_matrix + GL_TRANSPOSE_MODELVIEW_MATRIX_ARB 0x84E3 + GL_TRANSPOSE_PROJECTION_MATRIX_ARB 0x84E4 + GL_TRANSPOSE_TEXTURE_MATRIX_ARB 0x84E5 + GL_TRANSPOSE_COLOR_MATRIX_ARB 0x84E6 + void glLoadTransposeMatrixfARB (GLfloat m[16]) + void glLoadTransposeMatrixdARB (GLdouble m[16]) + void glMultTransposeMatrixfARB (GLfloat m[16]) + void glMultTransposeMatrixdARB (GLdouble m[16]) diff --git a/Externals/GLew/auto/extensions/GL_ARB_uniform_buffer_object b/Externals/GLew/auto/extensions/GL_ARB_uniform_buffer_object new file mode 100644 index 0000000000..c4992d1876 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_uniform_buffer_object @@ -0,0 +1,46 @@ +GL_ARB_uniform_buffer_object +http://www.opengl.org/registry/specs/ARB/uniform_buffer_object.txt +GL_ARB_uniform_buffer_object + GL_UNIFORM_BUFFER 0x8A11 + GL_UNIFORM_BUFFER_BINDING 0x8A28 + GL_UNIFORM_BUFFER_START 0x8A29 + GL_UNIFORM_BUFFER_SIZE 0x8A2A + GL_MAX_VERTEX_UNIFORM_BLOCKS 0x8A2B + GL_MAX_GEOMETRY_UNIFORM_BLOCKS 0x8A2C + GL_MAX_FRAGMENT_UNIFORM_BLOCKS 0x8A2D + GL_MAX_COMBINED_UNIFORM_BLOCKS 0x8A2E + GL_MAX_UNIFORM_BUFFER_BINDINGS 0x8A2F + GL_MAX_UNIFORM_BLOCK_SIZE 0x8A30 + GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS 0x8A31 + GL_MAX_COMBINED_GEOMETRY_UNIFORM_COMPONENTS 0x8A32 + GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS 0x8A33 + GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT 0x8A34 + GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH 0x8A35 + GL_ACTIVE_UNIFORM_BLOCKS 0x8A36 + GL_UNIFORM_TYPE 0x8A37 + GL_UNIFORM_SIZE 0x8A38 + GL_UNIFORM_NAME_LENGTH 0x8A39 + GL_UNIFORM_BLOCK_INDEX 0x8A3A + GL_UNIFORM_OFFSET 0x8A3B + GL_UNIFORM_ARRAY_STRIDE 0x8A3C + GL_UNIFORM_MATRIX_STRIDE 0x8A3D + GL_UNIFORM_IS_ROW_MAJOR 0x8A3E + GL_UNIFORM_BLOCK_BINDING 0x8A3F + GL_UNIFORM_BLOCK_DATA_SIZE 0x8A40 + GL_UNIFORM_BLOCK_NAME_LENGTH 0x8A41 + GL_UNIFORM_BLOCK_ACTIVE_UNIFORMS 0x8A42 + GL_UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES 0x8A43 + GL_UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER 0x8A44 + GL_UNIFORM_BLOCK_REFERENCED_BY_GEOMETRY_SHADER 0x8A45 + GL_UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER 0x8A46 + GL_INVALID_INDEX 0xFFFFFFFF + void glBindBufferBase (GLenum target, GLuint index, GLuint buffer) + void glBindBufferRange (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size) + void glGetActiveUniformBlockName (GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei* length, char* uniformBlockName) + void glGetActiveUniformBlockiv (GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint* params) + void glGetActiveUniformName (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei* length, char* uniformName) + void glGetActiveUniformsiv (GLuint program, GLsizei uniformCount, const GLuint* uniformIndices, GLenum pname, GLint* params) + void glGetIntegeri_v (GLenum target, GLuint index, GLint* data) + GLuint glGetUniformBlockIndex (GLuint program, const char* uniformBlockName) + void glGetUniformIndices (GLuint program, GLsizei uniformCount, const char** uniformNames, GLuint* uniformIndices) + void glUniformBlockBinding (GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding) diff --git a/Externals/GLew/auto/extensions/GL_ARB_vertex_array_bgra b/Externals/GLew/auto/extensions/GL_ARB_vertex_array_bgra new file mode 100644 index 0000000000..cf4ef09e6e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_vertex_array_bgra @@ -0,0 +1,4 @@ +GL_ARB_vertex_array_bgra +http://www.opengl.org/registry/specs/ARB/vertex_array_bgra.txt +GL_ARB_vertex_array_bgra + GL_BGRA 0x80E1 diff --git a/Externals/GLew/auto/extensions/GL_ARB_vertex_array_object b/Externals/GLew/auto/extensions/GL_ARB_vertex_array_object new file mode 100644 index 0000000000..efe7d7c577 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_vertex_array_object @@ -0,0 +1,8 @@ +GL_ARB_vertex_array_object +http://www.opengl.org/registry/specs/ARB/vertex_array_object.txt +GL_ARB_vertex_array_object + GL_VERTEX_ARRAY_BINDING 0x85B5 + void glBindVertexArray (GLuint array) + void glDeleteVertexArrays (GLsizei n, const GLuint* arrays) + void glGenVertexArrays (GLsizei n, GLuint* arrays) + GLboolean glIsVertexArray (GLuint array) diff --git a/Externals/GLew/auto/extensions/GL_ARB_vertex_blend b/Externals/GLew/auto/extensions/GL_ARB_vertex_blend new file mode 100644 index 0000000000..8da2c785b9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_vertex_blend @@ -0,0 +1,55 @@ +GL_ARB_vertex_blend +http://oss.sgi.com/projects/ogl-sample/registry/ARB/vertex_blend.txt +GL_ARB_vertex_blend + GL_MAX_VERTEX_UNITS_ARB 0x86A4 + GL_ACTIVE_VERTEX_UNITS_ARB 0x86A5 + GL_WEIGHT_SUM_UNITY_ARB 0x86A6 + GL_VERTEX_BLEND_ARB 0x86A7 + GL_CURRENT_WEIGHT_ARB 0x86A8 + GL_WEIGHT_ARRAY_TYPE_ARB 0x86A9 + GL_WEIGHT_ARRAY_STRIDE_ARB 0x86AA + GL_WEIGHT_ARRAY_SIZE_ARB 0x86AB + GL_WEIGHT_ARRAY_POINTER_ARB 0x86AC + GL_WEIGHT_ARRAY_ARB 0x86AD + GL_MODELVIEW0_ARB 0x1700 + GL_MODELVIEW1_ARB 0x850A + GL_MODELVIEW2_ARB 0x8722 + GL_MODELVIEW3_ARB 0x8723 + GL_MODELVIEW4_ARB 0x8724 + GL_MODELVIEW5_ARB 0x8725 + GL_MODELVIEW6_ARB 0x8726 + GL_MODELVIEW7_ARB 0x8727 + GL_MODELVIEW8_ARB 0x8728 + GL_MODELVIEW9_ARB 0x8729 + GL_MODELVIEW10_ARB 0x872A + GL_MODELVIEW11_ARB 0x872B + GL_MODELVIEW12_ARB 0x872C + GL_MODELVIEW13_ARB 0x872D + GL_MODELVIEW14_ARB 0x872E + GL_MODELVIEW15_ARB 0x872F + GL_MODELVIEW16_ARB 0x8730 + GL_MODELVIEW17_ARB 0x8731 + GL_MODELVIEW18_ARB 0x8732 + GL_MODELVIEW19_ARB 0x8733 + GL_MODELVIEW20_ARB 0x8734 + GL_MODELVIEW21_ARB 0x8735 + GL_MODELVIEW22_ARB 0x8736 + GL_MODELVIEW23_ARB 0x8737 + GL_MODELVIEW24_ARB 0x8738 + GL_MODELVIEW25_ARB 0x8739 + GL_MODELVIEW26_ARB 0x873A + GL_MODELVIEW27_ARB 0x873B + GL_MODELVIEW28_ARB 0x873C + GL_MODELVIEW29_ARB 0x873D + GL_MODELVIEW30_ARB 0x873E + GL_MODELVIEW31_ARB 0x873F + void glWeightbvARB (GLint size, GLbyte *weights) + void glWeightsvARB (GLint size, GLshort *weights) + void glWeightivARB (GLint size, GLint *weights) + void glWeightfvARB (GLint size, GLfloat *weights) + void glWeightdvARB (GLint size, GLdouble *weights) + void glWeightubvARB (GLint size, GLubyte *weights) + void glWeightusvARB (GLint size, GLushort *weights) + void glWeightuivARB (GLint size, GLuint *weights) + void glWeightPointerARB (GLint size, GLenum type, GLsizei stride, GLvoid *pointer) + void glVertexBlendARB (GLint count) diff --git a/Externals/GLew/auto/extensions/GL_ARB_vertex_buffer_object b/Externals/GLew/auto/extensions/GL_ARB_vertex_buffer_object new file mode 100644 index 0000000000..bd2ddfae47 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_vertex_buffer_object @@ -0,0 +1,47 @@ +GL_ARB_vertex_buffer_object +http://www.opengl.org/registry/specs/ARB/vertex_buffer_object.txt +GL_ARB_vertex_buffer_object + GL_BUFFER_SIZE_ARB 0x8764 + GL_BUFFER_USAGE_ARB 0x8765 + GL_ARRAY_BUFFER_ARB 0x8892 + GL_ELEMENT_ARRAY_BUFFER_ARB 0x8893 + GL_ARRAY_BUFFER_BINDING_ARB 0x8894 + GL_ELEMENT_ARRAY_BUFFER_BINDING_ARB 0x8895 + GL_VERTEX_ARRAY_BUFFER_BINDING_ARB 0x8896 + GL_NORMAL_ARRAY_BUFFER_BINDING_ARB 0x8897 + GL_COLOR_ARRAY_BUFFER_BINDING_ARB 0x8898 + GL_INDEX_ARRAY_BUFFER_BINDING_ARB 0x8899 + GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING_ARB 0x889A + GL_EDGE_FLAG_ARRAY_BUFFER_BINDING_ARB 0x889B + GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING_ARB 0x889C + GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING_ARB 0x889D + GL_WEIGHT_ARRAY_BUFFER_BINDING_ARB 0x889E + GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING_ARB 0x889F + GL_READ_ONLY_ARB 0x88B8 + GL_WRITE_ONLY_ARB 0x88B9 + GL_READ_WRITE_ARB 0x88BA + GL_BUFFER_ACCESS_ARB 0x88BB + GL_BUFFER_MAPPED_ARB 0x88BC + GL_BUFFER_MAP_POINTER_ARB 0x88BD + GL_STREAM_DRAW_ARB 0x88E0 + GL_STREAM_READ_ARB 0x88E1 + GL_STREAM_COPY_ARB 0x88E2 + GL_STATIC_DRAW_ARB 0x88E4 + GL_STATIC_READ_ARB 0x88E5 + GL_STATIC_COPY_ARB 0x88E6 + GL_DYNAMIC_DRAW_ARB 0x88E8 + GL_DYNAMIC_READ_ARB 0x88E9 + GL_DYNAMIC_COPY_ARB 0x88EA + void glBindBufferARB (GLenum target, GLuint buffer) + void glBufferDataARB (GLenum target, GLsizeiptrARB size, const GLvoid* data, GLenum usage) + void glBufferSubDataARB (GLenum target, GLintptrARB offset, GLsizeiptrARB size, const GLvoid* data) + void glDeleteBuffersARB (GLsizei n, const GLuint* buffers) + void glGenBuffersARB (GLsizei n, GLuint* buffers) + void glGetBufferParameterivARB (GLenum target, GLenum pname, GLint* params) + void glGetBufferPointervARB (GLenum target, GLenum pname, GLvoid** params) + void glGetBufferSubDataARB (GLenum target, GLintptrARB offset, GLsizeiptrARB size, GLvoid* data) + GLboolean glIsBufferARB (GLuint buffer) + GLvoid * glMapBufferARB (GLenum target, GLenum access) + GLboolean glUnmapBufferARB (GLenum target) + typedef ptrdiff_t GLsizeiptrARB + typedef ptrdiff_t GLintptrARB diff --git a/Externals/GLew/auto/extensions/GL_ARB_vertex_program b/Externals/GLew/auto/extensions/GL_ARB_vertex_program new file mode 100644 index 0000000000..81fd69d7b5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_vertex_program @@ -0,0 +1,144 @@ +GL_ARB_vertex_program +http://www.opengl.org/registry/specs/ARB/vertex_program.txt +GL_ARB_vertex_program + GL_COLOR_SUM_ARB 0x8458 + GL_VERTEX_PROGRAM_ARB 0x8620 + GL_VERTEX_ATTRIB_ARRAY_ENABLED_ARB 0x8622 + GL_VERTEX_ATTRIB_ARRAY_SIZE_ARB 0x8623 + GL_VERTEX_ATTRIB_ARRAY_STRIDE_ARB 0x8624 + GL_VERTEX_ATTRIB_ARRAY_TYPE_ARB 0x8625 + GL_CURRENT_VERTEX_ATTRIB_ARB 0x8626 + GL_PROGRAM_LENGTH_ARB 0x8627 + GL_PROGRAM_STRING_ARB 0x8628 + GL_MAX_PROGRAM_MATRIX_STACK_DEPTH_ARB 0x862E + GL_MAX_PROGRAM_MATRICES_ARB 0x862F + GL_CURRENT_MATRIX_STACK_DEPTH_ARB 0x8640 + GL_CURRENT_MATRIX_ARB 0x8641 + GL_VERTEX_PROGRAM_POINT_SIZE_ARB 0x8642 + GL_VERTEX_PROGRAM_TWO_SIDE_ARB 0x8643 + GL_VERTEX_ATTRIB_ARRAY_POINTER_ARB 0x8645 + GL_PROGRAM_ERROR_POSITION_ARB 0x864B + GL_PROGRAM_BINDING_ARB 0x8677 + GL_MAX_VERTEX_ATTRIBS_ARB 0x8869 + GL_VERTEX_ATTRIB_ARRAY_NORMALIZED_ARB 0x886A + GL_PROGRAM_ERROR_STRING_ARB 0x8874 + GL_PROGRAM_FORMAT_ASCII_ARB 0x8875 + GL_PROGRAM_FORMAT_ARB 0x8876 + GL_PROGRAM_INSTRUCTIONS_ARB 0x88A0 + GL_MAX_PROGRAM_INSTRUCTIONS_ARB 0x88A1 + GL_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A2 + GL_MAX_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A3 + GL_PROGRAM_TEMPORARIES_ARB 0x88A4 + GL_MAX_PROGRAM_TEMPORARIES_ARB 0x88A5 + GL_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A6 + GL_MAX_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A7 + GL_PROGRAM_PARAMETERS_ARB 0x88A8 + GL_MAX_PROGRAM_PARAMETERS_ARB 0x88A9 + GL_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AA + GL_MAX_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AB + GL_PROGRAM_ATTRIBS_ARB 0x88AC + GL_MAX_PROGRAM_ATTRIBS_ARB 0x88AD + GL_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AE + GL_MAX_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AF + GL_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B0 + GL_MAX_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B1 + GL_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B2 + GL_MAX_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B3 + GL_MAX_PROGRAM_LOCAL_PARAMETERS_ARB 0x88B4 + GL_MAX_PROGRAM_ENV_PARAMETERS_ARB 0x88B5 + GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB 0x88B6 + GL_TRANSPOSE_CURRENT_MATRIX_ARB 0x88B7 + GL_MATRIX0_ARB 0x88C0 + GL_MATRIX1_ARB 0x88C1 + GL_MATRIX2_ARB 0x88C2 + GL_MATRIX3_ARB 0x88C3 + GL_MATRIX4_ARB 0x88C4 + GL_MATRIX5_ARB 0x88C5 + GL_MATRIX6_ARB 0x88C6 + GL_MATRIX7_ARB 0x88C7 + GL_MATRIX8_ARB 0x88C8 + GL_MATRIX9_ARB 0x88C9 + GL_MATRIX10_ARB 0x88CA + GL_MATRIX11_ARB 0x88CB + GL_MATRIX12_ARB 0x88CC + GL_MATRIX13_ARB 0x88CD + GL_MATRIX14_ARB 0x88CE + GL_MATRIX15_ARB 0x88CF + GL_MATRIX16_ARB 0x88D0 + GL_MATRIX17_ARB 0x88D1 + GL_MATRIX18_ARB 0x88D2 + GL_MATRIX19_ARB 0x88D3 + GL_MATRIX20_ARB 0x88D4 + GL_MATRIX21_ARB 0x88D5 + GL_MATRIX22_ARB 0x88D6 + GL_MATRIX23_ARB 0x88D7 + GL_MATRIX24_ARB 0x88D8 + GL_MATRIX25_ARB 0x88D9 + GL_MATRIX26_ARB 0x88DA + GL_MATRIX27_ARB 0x88DB + GL_MATRIX28_ARB 0x88DC + GL_MATRIX29_ARB 0x88DD + GL_MATRIX30_ARB 0x88DE + GL_MATRIX31_ARB 0x88DF + void glBindProgramARB (GLenum target, GLuint program) + void glDeleteProgramsARB (GLsizei n, const GLuint* programs) + void glDisableVertexAttribArrayARB (GLuint index) + void glEnableVertexAttribArrayARB (GLuint index) + void glGenProgramsARB (GLsizei n, GLuint* programs) + void glGetProgramEnvParameterdvARB (GLenum target, GLuint index, GLdouble* params) + void glGetProgramEnvParameterfvARB (GLenum target, GLuint index, GLfloat* params) + void glGetProgramLocalParameterdvARB (GLenum target, GLuint index, GLdouble* params) + void glGetProgramLocalParameterfvARB (GLenum target, GLuint index, GLfloat* params) + void glGetProgramStringARB (GLenum target, GLenum pname, void* string) + void glGetProgramivARB (GLenum target, GLenum pname, GLint* params) + void glGetVertexAttribPointervARB (GLuint index, GLenum pname, GLvoid** pointer) + void glGetVertexAttribdvARB (GLuint index, GLenum pname, GLdouble* params) + void glGetVertexAttribfvARB (GLuint index, GLenum pname, GLfloat* params) + void glGetVertexAttribivARB (GLuint index, GLenum pname, GLint* params) + GLboolean glIsProgramARB (GLuint program) + void glProgramEnvParameter4dARB (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glProgramEnvParameter4dvARB (GLenum target, GLuint index, const GLdouble* params) + void glProgramEnvParameter4fARB (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glProgramEnvParameter4fvARB (GLenum target, GLuint index, const GLfloat* params) + void glProgramLocalParameter4dARB (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glProgramLocalParameter4dvARB (GLenum target, GLuint index, const GLdouble* params) + void glProgramLocalParameter4fARB (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glProgramLocalParameter4fvARB (GLenum target, GLuint index, const GLfloat* params) + void glProgramStringARB (GLenum target, GLenum format, GLsizei len, const void* string) + void glVertexAttrib1dARB (GLuint index, GLdouble x) + void glVertexAttrib1dvARB (GLuint index, const GLdouble* v) + void glVertexAttrib1fARB (GLuint index, GLfloat x) + void glVertexAttrib1fvARB (GLuint index, const GLfloat* v) + void glVertexAttrib1sARB (GLuint index, GLshort x) + void glVertexAttrib1svARB (GLuint index, const GLshort* v) + void glVertexAttrib2dARB (GLuint index, GLdouble x, GLdouble y) + void glVertexAttrib2dvARB (GLuint index, const GLdouble* v) + void glVertexAttrib2fARB (GLuint index, GLfloat x, GLfloat y) + void glVertexAttrib2fvARB (GLuint index, const GLfloat* v) + void glVertexAttrib2sARB (GLuint index, GLshort x, GLshort y) + void glVertexAttrib2svARB (GLuint index, const GLshort* v) + void glVertexAttrib3dARB (GLuint index, GLdouble x, GLdouble y, GLdouble z) + void glVertexAttrib3dvARB (GLuint index, const GLdouble* v) + void glVertexAttrib3fARB (GLuint index, GLfloat x, GLfloat y, GLfloat z) + void glVertexAttrib3fvARB (GLuint index, const GLfloat* v) + void glVertexAttrib3sARB (GLuint index, GLshort x, GLshort y, GLshort z) + void glVertexAttrib3svARB (GLuint index, const GLshort* v) + void glVertexAttrib4NbvARB (GLuint index, const GLbyte* v) + void glVertexAttrib4NivARB (GLuint index, const GLint* v) + void glVertexAttrib4NsvARB (GLuint index, const GLshort* v) + void glVertexAttrib4NubARB (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w) + void glVertexAttrib4NubvARB (GLuint index, const GLubyte* v) + void glVertexAttrib4NuivARB (GLuint index, const GLuint* v) + void glVertexAttrib4NusvARB (GLuint index, const GLushort* v) + void glVertexAttrib4bvARB (GLuint index, const GLbyte* v) + void glVertexAttrib4dARB (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glVertexAttrib4dvARB (GLuint index, const GLdouble* v) + void glVertexAttrib4fARB (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glVertexAttrib4fvARB (GLuint index, const GLfloat* v) + void glVertexAttrib4ivARB (GLuint index, const GLint* v) + void glVertexAttrib4sARB (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w) + void glVertexAttrib4svARB (GLuint index, const GLshort* v) + void glVertexAttrib4ubvARB (GLuint index, const GLubyte* v) + void glVertexAttrib4uivARB (GLuint index, const GLuint* v) + void glVertexAttrib4usvARB (GLuint index, const GLushort* v) + void glVertexAttribPointerARB (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_ARB_vertex_shader b/Externals/GLew/auto/extensions/GL_ARB_vertex_shader new file mode 100644 index 0000000000..08f5fe152e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_vertex_shader @@ -0,0 +1,13 @@ +GL_ARB_vertex_shader +http://www.opengl.org/registry/specs/ARB/vertex_shader.txt +GL_ARB_vertex_shader + GL_VERTEX_SHADER_ARB 0x8B31 + GL_MAX_VERTEX_UNIFORM_COMPONENTS_ARB 0x8B4A + GL_MAX_VARYING_FLOATS_ARB 0x8B4B + GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C + GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS_ARB 0x8B4D + GL_OBJECT_ACTIVE_ATTRIBUTES_ARB 0x8B89 + GL_OBJECT_ACTIVE_ATTRIBUTE_MAX_LENGTH_ARB 0x8B8A + void glBindAttribLocationARB (GLhandleARB programObj, GLuint index, const GLcharARB* name) + void glGetActiveAttribARB (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name) + GLint glGetAttribLocationARB (GLhandleARB programObj, const GLcharARB* name) diff --git a/Externals/GLew/auto/extensions/GL_ARB_vertex_type_2_10_10_10_rev b/Externals/GLew/auto/extensions/GL_ARB_vertex_type_2_10_10_10_rev new file mode 100644 index 0000000000..5259063f5c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_vertex_type_2_10_10_10_rev @@ -0,0 +1,43 @@ +GL_ARB_vertex_type_2_10_10_10_rev +http://www.opengl.org/registry/specs/ARB/vertex_type_2_10_10_10_rev.txt +GL_ARB_vertex_type_2_10_10_10_rev + GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 + GL_INT_2_10_10_10_REV 0x8D9F + void glColorP3ui (GLenum type, GLuint color) + void glColorP3uiv (GLenum type, const GLuint* color) + void glColorP4ui (GLenum type, GLuint color) + void glColorP4uiv (GLenum type, const GLuint* color) + void glMultiTexCoordP1ui (GLenum texture, GLenum type, GLuint coords) + void glMultiTexCoordP1uiv (GLenum texture, GLenum type, const GLuint* coords) + void glMultiTexCoordP2ui (GLenum texture, GLenum type, GLuint coords) + void glMultiTexCoordP2uiv (GLenum texture, GLenum type, const GLuint* coords) + void glMultiTexCoordP3ui (GLenum texture, GLenum type, GLuint coords) + void glMultiTexCoordP3uiv (GLenum texture, GLenum type, const GLuint* coords) + void glMultiTexCoordP4ui (GLenum texture, GLenum type, GLuint coords) + void glMultiTexCoordP4uiv (GLenum texture, GLenum type, const GLuint* coords) + void glNormalP3ui (GLenum type, GLuint coords) + void glNormalP3uiv (GLenum type, const GLuint* coords) + void glSecondaryColorP3ui (GLenum type, GLuint color) + void glSecondaryColorP3uiv (GLenum type, const GLuint* color) + void glTexCoordP1ui (GLenum type, GLuint coords) + void glTexCoordP1uiv (GLenum type, const GLuint* coords) + void glTexCoordP2ui (GLenum type, GLuint coords) + void glTexCoordP2uiv (GLenum type, const GLuint* coords) + void glTexCoordP3ui (GLenum type, GLuint coords) + void glTexCoordP3uiv (GLenum type, const GLuint* coords) + void glTexCoordP4ui (GLenum type, GLuint coords) + void glTexCoordP4uiv (GLenum type, const GLuint* coords) + void glVertexAttribP1ui (GLuint index, GLenum type, GLboolean normalized, GLuint value) + void glVertexAttribP1uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint* value) + void glVertexAttribP2ui (GLuint index, GLenum type, GLboolean normalized, GLuint value) + void glVertexAttribP2uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint* value) + void glVertexAttribP3ui (GLuint index, GLenum type, GLboolean normalized, GLuint value) + void glVertexAttribP3uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint* value) + void glVertexAttribP4ui (GLuint index, GLenum type, GLboolean normalized, GLuint value) + void glVertexAttribP4uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint* value) + void glVertexP2ui (GLenum type, GLuint value) + void glVertexP2uiv (GLenum type, const GLuint* value) + void glVertexP3ui (GLenum type, GLuint value) + void glVertexP3uiv (GLenum type, const GLuint* value) + void glVertexP4ui (GLenum type, GLuint value) + void glVertexP4uiv (GLenum type, const GLuint* value) diff --git a/Externals/GLew/auto/extensions/GL_ARB_window_pos b/Externals/GLew/auto/extensions/GL_ARB_window_pos new file mode 100644 index 0000000000..15e5bf586a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ARB_window_pos @@ -0,0 +1,19 @@ +GL_ARB_window_pos +http://www.opengl.org/registry/specs/ARB/window_pos.txt +GL_ARB_window_pos + void glWindowPos2dARB (GLdouble x, GLdouble y) + void glWindowPos2dvARB (const GLdouble* p) + void glWindowPos2fARB (GLfloat x, GLfloat y) + void glWindowPos2fvARB (const GLfloat* p) + void glWindowPos2iARB (GLint x, GLint y) + void glWindowPos2ivARB (const GLint* p) + void glWindowPos2sARB (GLshort x, GLshort y) + void glWindowPos2svARB (const GLshort* p) + void glWindowPos3dARB (GLdouble x, GLdouble y, GLdouble z) + void glWindowPos3dvARB (const GLdouble* p) + void glWindowPos3fARB (GLfloat x, GLfloat y, GLfloat z) + void glWindowPos3fvARB (const GLfloat* p) + void glWindowPos3iARB (GLint x, GLint y, GLint z) + void glWindowPos3ivARB (const GLint* p) + void glWindowPos3sARB (GLshort x, GLshort y, GLshort z) + void glWindowPos3svARB (const GLshort* p) diff --git a/Externals/GLew/auto/extensions/GL_ATIX_point_sprites b/Externals/GLew/auto/extensions/GL_ATIX_point_sprites new file mode 100644 index 0000000000..0f4f574131 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATIX_point_sprites @@ -0,0 +1,9 @@ +GL_ATIX_point_sprites +http://www.ati.com/developer/atiopengl.pdf +GL_ATIX_point_sprites + GL_TEXTURE_POINT_MODE_ATIX 0x60B0 + GL_TEXTURE_POINT_ONE_COORD_ATIX 0x60B1 + GL_TEXTURE_POINT_SPRITE_ATIX 0x60B2 + GL_POINT_SPRITE_CULL_MODE_ATIX 0x60B3 + GL_POINT_SPRITE_CULL_CENTER_ATIX 0x60B4 + GL_POINT_SPRITE_CULL_CLIP_ATIX 0x60B5 diff --git a/Externals/GLew/auto/extensions/GL_ATIX_texture_env_combine3 b/Externals/GLew/auto/extensions/GL_ATIX_texture_env_combine3 new file mode 100644 index 0000000000..537426b95d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATIX_texture_env_combine3 @@ -0,0 +1,6 @@ +GL_ATIX_texture_env_combine3 +http://www.ati.com/developer/atiopengl.pdf +GL_ATIX_texture_env_combine3 + GL_MODULATE_ADD_ATIX 0x8744 + GL_MODULATE_SIGNED_ADD_ATIX 0x8745 + GL_MODULATE_SUBTRACT_ATIX 0x8746 diff --git a/Externals/GLew/auto/extensions/GL_ATIX_texture_env_route b/Externals/GLew/auto/extensions/GL_ATIX_texture_env_route new file mode 100644 index 0000000000..939ae09b95 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATIX_texture_env_route @@ -0,0 +1,6 @@ +GL_ATIX_texture_env_route +http://www.ati.com/developer/sdk/RadeonSDK/Html/Info/ATIX_texture_env_route.txt +GL_ATIX_texture_env_route + GL_SECONDARY_COLOR_ATIX 0x8747 + GL_TEXTURE_OUTPUT_RGB_ATIX 0x8748 + GL_TEXTURE_OUTPUT_ALPHA_ATIX 0x8749 diff --git a/Externals/GLew/auto/extensions/GL_ATIX_vertex_shader_output_point_size b/Externals/GLew/auto/extensions/GL_ATIX_vertex_shader_output_point_size new file mode 100644 index 0000000000..277a3136cb --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATIX_vertex_shader_output_point_size @@ -0,0 +1,4 @@ +GL_ATIX_vertex_shader_output_point_size +http://www.ati.com/developer/atiopengl.pdf +GL_ATIX_vertex_shader_output_point_size + GL_OUTPUT_POINT_SIZE_ATIX 0x610E diff --git a/Externals/GLew/auto/extensions/GL_ATI_draw_buffers b/Externals/GLew/auto/extensions/GL_ATI_draw_buffers new file mode 100644 index 0000000000..34966371a0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_draw_buffers @@ -0,0 +1,21 @@ +GL_ATI_draw_buffers +http://www.opengl.org/registry/specs/ATI/draw_buffers.txt +GL_ATI_draw_buffers + GL_MAX_DRAW_BUFFERS_ATI 0x8824 + GL_DRAW_BUFFER0_ATI 0x8825 + GL_DRAW_BUFFER1_ATI 0x8826 + GL_DRAW_BUFFER2_ATI 0x8827 + GL_DRAW_BUFFER3_ATI 0x8828 + GL_DRAW_BUFFER4_ATI 0x8829 + GL_DRAW_BUFFER5_ATI 0x882A + GL_DRAW_BUFFER6_ATI 0x882B + GL_DRAW_BUFFER7_ATI 0x882C + GL_DRAW_BUFFER8_ATI 0x882D + GL_DRAW_BUFFER9_ATI 0x882E + GL_DRAW_BUFFER10_ATI 0x882F + GL_DRAW_BUFFER11_ATI 0x8830 + GL_DRAW_BUFFER12_ATI 0x8831 + GL_DRAW_BUFFER13_ATI 0x8832 + GL_DRAW_BUFFER14_ATI 0x8833 + GL_DRAW_BUFFER15_ATI 0x8834 + void glDrawBuffersATI (GLsizei n, const GLenum* bufs) diff --git a/Externals/GLew/auto/extensions/GL_ATI_element_array b/Externals/GLew/auto/extensions/GL_ATI_element_array new file mode 100644 index 0000000000..8ad72cebb4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_element_array @@ -0,0 +1,9 @@ +GL_ATI_element_array +http://www.opengl.org/registry/specs/ATI/element_array.txt +GL_ATI_element_array + GL_ELEMENT_ARRAY_ATI 0x8768 + GL_ELEMENT_ARRAY_TYPE_ATI 0x8769 + GL_ELEMENT_ARRAY_POINTER_ATI 0x876A + void glDrawElementArrayATI (GLenum mode, GLsizei count) + void glDrawRangeElementArrayATI (GLenum mode, GLuint start, GLuint end, GLsizei count) + void glElementPointerATI (GLenum type, const void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_ATI_envmap_bumpmap b/Externals/GLew/auto/extensions/GL_ATI_envmap_bumpmap new file mode 100644 index 0000000000..fbd992551e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_envmap_bumpmap @@ -0,0 +1,15 @@ +GL_ATI_envmap_bumpmap +http://oss.sgi.com/projects/ogl-sample/registry/ATI/envmap_bumpmap.txt +GL_ATI_envmap_bumpmap + GL_BUMP_ROT_MATRIX_ATI 0x8775 + GL_BUMP_ROT_MATRIX_SIZE_ATI 0x8776 + GL_BUMP_NUM_TEX_UNITS_ATI 0x8777 + GL_BUMP_TEX_UNITS_ATI 0x8778 + GL_DUDV_ATI 0x8779 + GL_DU8DV8_ATI 0x877A + GL_BUMP_ENVMAP_ATI 0x877B + GL_BUMP_TARGET_ATI 0x877C + void glTexBumpParameterivATI (GLenum pname, GLint *param) + void glTexBumpParameterfvATI (GLenum pname, GLfloat *param) + void glGetTexBumpParameterivATI (GLenum pname, GLint *param) + void glGetTexBumpParameterfvATI (GLenum pname, GLfloat *param) diff --git a/Externals/GLew/auto/extensions/GL_ATI_fragment_shader b/Externals/GLew/auto/extensions/GL_ATI_fragment_shader new file mode 100644 index 0000000000..2154d27fac --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_fragment_shader @@ -0,0 +1,71 @@ +GL_ATI_fragment_shader +http://www.opengl.org/registry/specs/ATI/fragment_shader.txt +GL_ATI_fragment_shader + GL_RED_BIT_ATI 0x00000001 + GL_2X_BIT_ATI 0x00000001 + GL_4X_BIT_ATI 0x00000002 + GL_GREEN_BIT_ATI 0x00000002 + GL_COMP_BIT_ATI 0x00000002 + GL_BLUE_BIT_ATI 0x00000004 + GL_8X_BIT_ATI 0x00000004 + GL_NEGATE_BIT_ATI 0x00000004 + GL_BIAS_BIT_ATI 0x00000008 + GL_HALF_BIT_ATI 0x00000008 + GL_QUARTER_BIT_ATI 0x00000010 + GL_EIGHTH_BIT_ATI 0x00000020 + GL_SATURATE_BIT_ATI 0x00000040 + GL_FRAGMENT_SHADER_ATI 0x8920 + GL_REG_0_ATI 0x8921 + GL_REG_1_ATI 0x8922 + GL_REG_2_ATI 0x8923 + GL_REG_3_ATI 0x8924 + GL_REG_4_ATI 0x8925 + GL_REG_5_ATI 0x8926 + GL_CON_0_ATI 0x8941 + GL_CON_1_ATI 0x8942 + GL_CON_2_ATI 0x8943 + GL_CON_3_ATI 0x8944 + GL_CON_4_ATI 0x8945 + GL_CON_5_ATI 0x8946 + GL_CON_6_ATI 0x8947 + GL_CON_7_ATI 0x8948 + GL_MOV_ATI 0x8961 + GL_ADD_ATI 0x8963 + GL_MUL_ATI 0x8964 + GL_SUB_ATI 0x8965 + GL_DOT3_ATI 0x8966 + GL_DOT4_ATI 0x8967 + GL_MAD_ATI 0x8968 + GL_LERP_ATI 0x8969 + GL_CND_ATI 0x896A + GL_CND0_ATI 0x896B + GL_DOT2_ADD_ATI 0x896C + GL_SECONDARY_INTERPOLATOR_ATI 0x896D + GL_SWIZZLE_STR_ATI 0x8976 + GL_SWIZZLE_STQ_ATI 0x8977 + GL_SWIZZLE_STR_DR_ATI 0x8978 + GL_SWIZZLE_STQ_DQ_ATI 0x8979 + void glAlphaFragmentOp1ATI (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod) + void glAlphaFragmentOp2ATI (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod) + void glAlphaFragmentOp3ATI (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod) + void glBeginFragmentShaderATI (void) + void glBindFragmentShaderATI (GLuint id) + void glColorFragmentOp1ATI (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod) + void glColorFragmentOp2ATI (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod) + void glColorFragmentOp3ATI (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod) + void glDeleteFragmentShaderATI (GLuint id) + void glEndFragmentShaderATI (void) + GLuint glGenFragmentShadersATI (GLuint range) + void glPassTexCoordATI (GLuint dst, GLuint coord, GLenum swizzle) + void glSampleMapATI (GLuint dst, GLuint interp, GLenum swizzle) + void glSetFragmentShaderConstantATI (GLuint dst, const GLfloat* value) + GL_NUM_FRAGMENT_REGISTERS_ATI 0x896E + GL_NUM_FRAGMENT_CONSTANTS_ATI 0x896F + GL_NUM_PASSES_ATI 0x8970 + GL_NUM_INSTRUCTIONS_PER_PASS_ATI 0x8971 + GL_NUM_INSTRUCTIONS_TOTAL_ATI 0x8972 + GL_NUM_INPUT_INTERPOLATOR_COMPONENTS_ATI 0x8973 + GL_NUM_LOOPBACK_COMPONENTS_ATI 0x8974 + GL_COLOR_ALPHA_PAIRING_ATI 0x8975 + GL_SWIZZLE_STRQ_ATI 0x897A + GL_SWIZZLE_STRQ_DQ_ATI 0x897B diff --git a/Externals/GLew/auto/extensions/GL_ATI_map_object_buffer b/Externals/GLew/auto/extensions/GL_ATI_map_object_buffer new file mode 100644 index 0000000000..f360fa2adc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_map_object_buffer @@ -0,0 +1,5 @@ +GL_ATI_map_object_buffer +http://www.ati.com/developer/sdk/RADEONSDK/Html/Info/ATI_map_object_buffer.txt +GL_ATI_map_object_buffer + void* glMapObjectBufferATI (GLuint buffer) + void glUnmapObjectBufferATI (GLuint buffer) diff --git a/Externals/GLew/auto/extensions/GL_ATI_meminfo b/Externals/GLew/auto/extensions/GL_ATI_meminfo new file mode 100644 index 0000000000..5a5719bec0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_meminfo @@ -0,0 +1,6 @@ +GL_ATI_meminfo +http://www.opengl.org/registry/specs/ATI/meminfo.txt +GL_ATI_meminfo + GL_VBO_FREE_MEMORY_ATI 0x87FB + GL_TEXTURE_FREE_MEMORY_ATI 0x87FC + GL_RENDERBUFFER_FREE_MEMORY_ATI 0x87FD diff --git a/Externals/GLew/auto/extensions/GL_ATI_pn_triangles b/Externals/GLew/auto/extensions/GL_ATI_pn_triangles new file mode 100644 index 0000000000..7b353b5352 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_pn_triangles @@ -0,0 +1,14 @@ +GL_ATI_pn_triangles +http://www.ati.com/developer/sdk/RADEONSDK/Html/Info/ati_pn_triangles.txt +GL_ATI_pn_triangles + GL_PN_TRIANGLES_ATI 0x87F0 + GL_MAX_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F1 + GL_PN_TRIANGLES_POINT_MODE_ATI 0x87F2 + GL_PN_TRIANGLES_NORMAL_MODE_ATI 0x87F3 + GL_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F4 + GL_PN_TRIANGLES_POINT_MODE_LINEAR_ATI 0x87F5 + GL_PN_TRIANGLES_POINT_MODE_CUBIC_ATI 0x87F6 + GL_PN_TRIANGLES_NORMAL_MODE_LINEAR_ATI 0x87F7 + GL_PN_TRIANGLES_NORMAL_MODE_QUADRATIC_ATI 0x87F8 + void glPNTrianglesiATI (GLenum pname, GLint param) + void glPNTrianglesfATI (GLenum pname, GLfloat param) diff --git a/Externals/GLew/auto/extensions/GL_ATI_separate_stencil b/Externals/GLew/auto/extensions/GL_ATI_separate_stencil new file mode 100644 index 0000000000..c4d82abba9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_separate_stencil @@ -0,0 +1,9 @@ +GL_ATI_separate_stencil +http://www.ati.com/developer/sdk/RadeonSDK/Html/Info/ATI_separate_stencil.txt +GL_ATI_separate_stencil + GL_STENCIL_BACK_FUNC_ATI 0x8800 + GL_STENCIL_BACK_FAIL_ATI 0x8801 + GL_STENCIL_BACK_PASS_DEPTH_FAIL_ATI 0x8802 + GL_STENCIL_BACK_PASS_DEPTH_PASS_ATI 0x8803 + void glStencilOpSeparateATI (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass) + void glStencilFuncSeparateATI (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask) diff --git a/Externals/GLew/auto/extensions/GL_ATI_shader_texture_lod b/Externals/GLew/auto/extensions/GL_ATI_shader_texture_lod new file mode 100644 index 0000000000..5fbc624a6b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_shader_texture_lod @@ -0,0 +1,3 @@ +GL_ATI_shader_texture_lod + +GL_ATI_shader_texture_lod diff --git a/Externals/GLew/auto/extensions/GL_ATI_text_fragment_shader b/Externals/GLew/auto/extensions/GL_ATI_text_fragment_shader new file mode 100644 index 0000000000..926c30019a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_text_fragment_shader @@ -0,0 +1,4 @@ +GL_ATI_text_fragment_shader +http://www.opengl.org/registry/specs/ATI/text_fragment_shader.txt +GL_ATI_text_fragment_shader + GL_TEXT_FRAGMENT_SHADER_ATI 0x8200 diff --git a/Externals/GLew/auto/extensions/GL_ATI_texture_compression_3dc b/Externals/GLew/auto/extensions/GL_ATI_texture_compression_3dc new file mode 100644 index 0000000000..2548b30ead --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_texture_compression_3dc @@ -0,0 +1,4 @@ +GL_ATI_texture_compression_3dc + +GL_ATI_texture_compression_3dc + GL_COMPRESSED_LUMINANCE_ALPHA_3DC_ATI 0x8837 diff --git a/Externals/GLew/auto/extensions/GL_ATI_texture_env_combine3 b/Externals/GLew/auto/extensions/GL_ATI_texture_env_combine3 new file mode 100644 index 0000000000..e65c170921 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_texture_env_combine3 @@ -0,0 +1,6 @@ +GL_ATI_texture_env_combine3 +http://www.opengl.org/registry/specs/ATI/texture_env_combine3.txt +GL_ATI_texture_env_combine3 + GL_MODULATE_ADD_ATI 0x8744 + GL_MODULATE_SIGNED_ADD_ATI 0x8745 + GL_MODULATE_SUBTRACT_ATI 0x8746 diff --git a/Externals/GLew/auto/extensions/GL_ATI_texture_float b/Externals/GLew/auto/extensions/GL_ATI_texture_float new file mode 100644 index 0000000000..d8c9b8987b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_texture_float @@ -0,0 +1,15 @@ +GL_ATI_texture_float +http://www.opengl.org/registry/specs/ATI/texture_float.txt +GL_ATI_texture_float + GL_RGBA_FLOAT32_ATI 0x8814 + GL_RGB_FLOAT32_ATI 0x8815 + GL_ALPHA_FLOAT32_ATI 0x8816 + GL_INTENSITY_FLOAT32_ATI 0x8817 + GL_LUMINANCE_FLOAT32_ATI 0x8818 + GL_LUMINANCE_ALPHA_FLOAT32_ATI 0x8819 + GL_RGBA_FLOAT16_ATI 0x881A + GL_RGB_FLOAT16_ATI 0x881B + GL_ALPHA_FLOAT16_ATI 0x881C + GL_INTENSITY_FLOAT16_ATI 0x881D + GL_LUMINANCE_FLOAT16_ATI 0x881E + GL_LUMINANCE_ALPHA_FLOAT16_ATI 0x881F diff --git a/Externals/GLew/auto/extensions/GL_ATI_texture_mirror_once b/Externals/GLew/auto/extensions/GL_ATI_texture_mirror_once new file mode 100644 index 0000000000..a1dabaff55 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_texture_mirror_once @@ -0,0 +1,5 @@ +GL_ATI_texture_mirror_once +http://www.opengl.org/registry/specs/ATI/texture_mirror_once.txt +GL_ATI_texture_mirror_once + GL_MIRROR_CLAMP_ATI 0x8742 + GL_MIRROR_CLAMP_TO_EDGE_ATI 0x8743 diff --git a/Externals/GLew/auto/extensions/GL_ATI_vertex_array_object b/Externals/GLew/auto/extensions/GL_ATI_vertex_array_object new file mode 100644 index 0000000000..5e1a06a921 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_vertex_array_object @@ -0,0 +1,23 @@ +GL_ATI_vertex_array_object +http://www.opengl.org/registry/specs/ATI/vertex_array_object.txt +GL_ATI_vertex_array_object + GL_STATIC_ATI 0x8760 + GL_DYNAMIC_ATI 0x8761 + GL_PRESERVE_ATI 0x8762 + GL_DISCARD_ATI 0x8763 + GL_OBJECT_BUFFER_SIZE_ATI 0x8764 + GL_OBJECT_BUFFER_USAGE_ATI 0x8765 + GL_ARRAY_OBJECT_BUFFER_ATI 0x8766 + GL_ARRAY_OBJECT_OFFSET_ATI 0x8767 + void glArrayObjectATI (GLenum array, GLint size, GLenum type, GLsizei stride, GLuint buffer, GLuint offset) + void glFreeObjectBufferATI (GLuint buffer) + void glGetArrayObjectfvATI (GLenum array, GLenum pname, GLfloat* params) + void glGetArrayObjectivATI (GLenum array, GLenum pname, GLint* params) + void glGetObjectBufferfvATI (GLuint buffer, GLenum pname, GLfloat* params) + void glGetObjectBufferivATI (GLuint buffer, GLenum pname, GLint* params) + void glGetVariantArrayObjectfvATI (GLuint id, GLenum pname, GLfloat* params) + void glGetVariantArrayObjectivATI (GLuint id, GLenum pname, GLint* params) + GLboolean glIsObjectBufferATI (GLuint buffer) + GLuint glNewObjectBufferATI (GLsizei size, const void* pointer, GLenum usage) + void glUpdateObjectBufferATI (GLuint buffer, GLuint offset, GLsizei size, const void* pointer, GLenum preserve) + void glVariantArrayObjectATI (GLuint id, GLenum type, GLsizei stride, GLuint buffer, GLuint offset) diff --git a/Externals/GLew/auto/extensions/GL_ATI_vertex_attrib_array_object b/Externals/GLew/auto/extensions/GL_ATI_vertex_attrib_array_object new file mode 100644 index 0000000000..c8ce9946e3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_vertex_attrib_array_object @@ -0,0 +1,6 @@ +GL_ATI_vertex_attrib_array_object +http://www.opengl.org/registry/specs/ATI/vertex_attrib_array_object.txt +GL_ATI_vertex_attrib_array_object + void glGetVertexAttribArrayObjectfvATI (GLuint index, GLenum pname, GLfloat* params) + void glGetVertexAttribArrayObjectivATI (GLuint index, GLenum pname, GLint* params) + void glVertexAttribArrayObjectATI (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLuint buffer, GLuint offset) diff --git a/Externals/GLew/auto/extensions/GL_ATI_vertex_streams b/Externals/GLew/auto/extensions/GL_ATI_vertex_streams new file mode 100644 index 0000000000..56005f9c50 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_ATI_vertex_streams @@ -0,0 +1,50 @@ +GL_ATI_vertex_streams +http://www.ati.com/developer/sdk/RADEONSDK/Html/Info/ATI_vertex_streams.txt +GL_ATI_vertex_streams + GL_MAX_VERTEX_STREAMS_ATI 0x876B + GL_VERTEX_SOURCE_ATI 0x876C + GL_VERTEX_STREAM0_ATI 0x876D + GL_VERTEX_STREAM1_ATI 0x876E + GL_VERTEX_STREAM2_ATI 0x876F + GL_VERTEX_STREAM3_ATI 0x8770 + GL_VERTEX_STREAM4_ATI 0x8771 + GL_VERTEX_STREAM5_ATI 0x8772 + GL_VERTEX_STREAM6_ATI 0x8773 + GL_VERTEX_STREAM7_ATI 0x8774 + void glClientActiveVertexStreamATI (GLenum stream) + void glVertexBlendEnviATI (GLenum pname, GLint param) + void glVertexBlendEnvfATI (GLenum pname, GLfloat param) + void glVertexStream2sATI (GLenum stream, GLshort x, GLshort y) + void glVertexStream2svATI (GLenum stream, const GLshort *v) + void glVertexStream2iATI (GLenum stream, GLint x, GLint y) + void glVertexStream2ivATI (GLenum stream, const GLint *v) + void glVertexStream2fATI (GLenum stream, GLfloat x, GLfloat y) + void glVertexStream2fvATI (GLenum stream, const GLfloat *v) + void glVertexStream2dATI (GLenum stream, GLdouble x, GLdouble y) + void glVertexStream2dvATI (GLenum stream, const GLdouble *v) + void glVertexStream3sATI (GLenum stream, GLshort x, GLshort y, GLshort z) + void glVertexStream3svATI (GLenum stream, const GLshort *v) + void glVertexStream3iATI (GLenum stream, GLint x, GLint y, GLint z) + void glVertexStream3ivATI (GLenum stream, const GLint *v) + void glVertexStream3fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z) + void glVertexStream3fvATI (GLenum stream, const GLfloat *v) + void glVertexStream3dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z) + void glVertexStream3dvATI (GLenum stream, const GLdouble *v) + void glVertexStream4sATI (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w) + void glVertexStream4svATI (GLenum stream, const GLshort *v) + void glVertexStream4iATI (GLenum stream, GLint x, GLint y, GLint z, GLint w) + void glVertexStream4ivATI (GLenum stream, const GLint *v) + void glVertexStream4fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glVertexStream4fvATI (GLenum stream, const GLfloat *v) + void glVertexStream4dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glVertexStream4dvATI (GLenum stream, const GLdouble *v) + void glNormalStream3bATI (GLenum stream, GLbyte x, GLbyte y, GLbyte z) + void glNormalStream3bvATI (GLenum stream, const GLbyte *v) + void glNormalStream3sATI (GLenum stream, GLshort x, GLshort y, GLshort z) + void glNormalStream3svATI (GLenum stream, const GLshort *v) + void glNormalStream3iATI (GLenum stream, GLint x, GLint y, GLint z) + void glNormalStream3ivATI (GLenum stream, const GLint *v) + void glNormalStream3fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z) + void glNormalStream3fvATI (GLenum stream, const GLfloat *v) + void glNormalStream3dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z) + void glNormalStream3dvATI (GLenum stream, const GLdouble *v) diff --git a/Externals/GLew/auto/extensions/GL_EXT_422_pixels b/Externals/GLew/auto/extensions/GL_EXT_422_pixels new file mode 100644 index 0000000000..70d3d574f1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_422_pixels @@ -0,0 +1,7 @@ +GL_EXT_422_pixels +http://www.opengl.org/registry/specs/EXT/422_pixels.txt +GL_EXT_422_pixels + GL_422_EXT 0x80CC + GL_422_REV_EXT 0x80CD + GL_422_AVERAGE_EXT 0x80CE + GL_422_REV_AVERAGE_EXT 0x80CF diff --git a/Externals/GLew/auto/extensions/GL_EXT_Cg_shader b/Externals/GLew/auto/extensions/GL_EXT_Cg_shader new file mode 100644 index 0000000000..34d3152931 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_Cg_shader @@ -0,0 +1,5 @@ +GL_EXT_Cg_shader +http://download.nvidia.com/developer/GLSL/GLSL%20Release%20Notes%20for%20Release%2060.pdf +GL_EXT_Cg_shader + GL_CG_VERTEX_SHADER_EXT 0x890E + GL_CG_FRAGMENT_SHADER_EXT 0x890F diff --git a/Externals/GLew/auto/extensions/GL_EXT_abgr b/Externals/GLew/auto/extensions/GL_EXT_abgr new file mode 100644 index 0000000000..9c86889779 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_abgr @@ -0,0 +1,4 @@ +GL_EXT_abgr +http://www.opengl.org/registry/specs/EXT/abgr.txt +GL_EXT_abgr + GL_ABGR_EXT 0x8000 diff --git a/Externals/GLew/auto/extensions/GL_EXT_bgra b/Externals/GLew/auto/extensions/GL_EXT_bgra new file mode 100644 index 0000000000..afe1c019ef --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_bgra @@ -0,0 +1,5 @@ +GL_EXT_bgra +http://www.opengl.org/registry/specs/EXT/bgra.txt +GL_EXT_bgra + GL_BGR_EXT 0x80E0 + GL_BGRA_EXT 0x80E1 diff --git a/Externals/GLew/auto/extensions/GL_EXT_bindable_uniform b/Externals/GLew/auto/extensions/GL_EXT_bindable_uniform new file mode 100644 index 0000000000..809123b659 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_bindable_uniform @@ -0,0 +1,12 @@ +GL_EXT_bindable_uniform +http://developer.download.nvidia.com/opengl/specs/GL_EXT_bindable_uniform.txt +GL_EXT_bindable_uniform + GL_MAX_VERTEX_BINDABLE_UNIFORMS_EXT 0x8DE2 + GL_MAX_FRAGMENT_BINDABLE_UNIFORMS_EXT 0x8DE3 + GL_MAX_GEOMETRY_BINDABLE_UNIFORMS_EXT 0x8DE4 + GL_MAX_BINDABLE_UNIFORM_SIZE_EXT 0x8DED + GL_UNIFORM_BUFFER_BINDING_EXT 0x8DEF + GL_UNIFORM_BUFFER_EXT 0x8DEE + void glUniformBufferEXT (GLuint program, GLint location, GLuint buffer) + GLint glGetUniformBufferSizeEXT (GLuint program, GLint location) + GLintptr glGetUniformOffsetEXT (GLuint program, GLint location) diff --git a/Externals/GLew/auto/extensions/GL_EXT_blend_color b/Externals/GLew/auto/extensions/GL_EXT_blend_color new file mode 100644 index 0000000000..706181e82f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_blend_color @@ -0,0 +1,9 @@ +GL_EXT_blend_color +http://www.opengl.org/registry/specs/EXT/blend_color.txt +GL_EXT_blend_color + GL_CONSTANT_COLOR_EXT 0x8001 + GL_ONE_MINUS_CONSTANT_COLOR_EXT 0x8002 + GL_CONSTANT_ALPHA_EXT 0x8003 + GL_ONE_MINUS_CONSTANT_ALPHA_EXT 0x8004 + GL_BLEND_COLOR_EXT 0x8005 + void glBlendColorEXT (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha) diff --git a/Externals/GLew/auto/extensions/GL_EXT_blend_equation_separate b/Externals/GLew/auto/extensions/GL_EXT_blend_equation_separate new file mode 100644 index 0000000000..7ac5975a3e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_blend_equation_separate @@ -0,0 +1,6 @@ +GL_EXT_blend_equation_separate +http://www.opengl.org/registry/specs/EXT/blend_equation_separate.txt +GL_EXT_blend_equation_separate + GL_BLEND_EQUATION_RGB_EXT 0x8009 + GL_BLEND_EQUATION_ALPHA_EXT 0x883D + void glBlendEquationSeparateEXT (GLenum modeRGB, GLenum modeAlpha) diff --git a/Externals/GLew/auto/extensions/GL_EXT_blend_func_separate b/Externals/GLew/auto/extensions/GL_EXT_blend_func_separate new file mode 100644 index 0000000000..9517afc5c0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_blend_func_separate @@ -0,0 +1,8 @@ +GL_EXT_blend_func_separate +http://www.opengl.org/registry/specs/EXT/blend_func_separate.txt +GL_EXT_blend_func_separate + GL_BLEND_DST_RGB_EXT 0x80C8 + GL_BLEND_SRC_RGB_EXT 0x80C9 + GL_BLEND_DST_ALPHA_EXT 0x80CA + GL_BLEND_SRC_ALPHA_EXT 0x80CB + void glBlendFuncSeparateEXT (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha) diff --git a/Externals/GLew/auto/extensions/GL_EXT_blend_logic_op b/Externals/GLew/auto/extensions/GL_EXT_blend_logic_op new file mode 100644 index 0000000000..7e3027d145 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_blend_logic_op @@ -0,0 +1,3 @@ +GL_EXT_blend_logic_op +http://www.opengl.org/registry/specs/EXT/blend_logic_op.txt +GL_EXT_blend_logic_op diff --git a/Externals/GLew/auto/extensions/GL_EXT_blend_minmax b/Externals/GLew/auto/extensions/GL_EXT_blend_minmax new file mode 100644 index 0000000000..fee5af635f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_blend_minmax @@ -0,0 +1,8 @@ +GL_EXT_blend_minmax +http://www.opengl.org/registry/specs/EXT/blend_minmax.txt +GL_EXT_blend_minmax + GL_FUNC_ADD_EXT 0x8006 + GL_MIN_EXT 0x8007 + GL_MAX_EXT 0x8008 + GL_BLEND_EQUATION_EXT 0x8009 + void glBlendEquationEXT (GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_EXT_blend_subtract b/Externals/GLew/auto/extensions/GL_EXT_blend_subtract new file mode 100644 index 0000000000..8b9348b923 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_blend_subtract @@ -0,0 +1,5 @@ +GL_EXT_blend_subtract +http://www.opengl.org/registry/specs/EXT/blend_subtract.txt +GL_EXT_blend_subtract + GL_FUNC_SUBTRACT_EXT 0x800A + GL_FUNC_REVERSE_SUBTRACT_EXT 0x800B diff --git a/Externals/GLew/auto/extensions/GL_EXT_clip_volume_hint b/Externals/GLew/auto/extensions/GL_EXT_clip_volume_hint new file mode 100644 index 0000000000..8959276cb7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_clip_volume_hint @@ -0,0 +1,4 @@ +GL_EXT_clip_volume_hint +http://www.opengl.org/registry/specs/EXT/clip_volume_hint.txt +GL_EXT_clip_volume_hint + GL_CLIP_VOLUME_CLIPPING_HINT_EXT 0x80F0 diff --git a/Externals/GLew/auto/extensions/GL_EXT_cmyka b/Externals/GLew/auto/extensions/GL_EXT_cmyka new file mode 100644 index 0000000000..824654f6b9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_cmyka @@ -0,0 +1,7 @@ +GL_EXT_cmyka +http://www.opengl.org/registry/specs/EXT/cmyka.txt +GL_EXT_cmyka + GL_CMYK_EXT 0x800C + GL_CMYKA_EXT 0x800D + GL_PACK_CMYK_HINT_EXT 0x800E + GL_UNPACK_CMYK_HINT_EXT 0x800F diff --git a/Externals/GLew/auto/extensions/GL_EXT_color_subtable b/Externals/GLew/auto/extensions/GL_EXT_color_subtable new file mode 100644 index 0000000000..398c31327e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_color_subtable @@ -0,0 +1,5 @@ +GL_EXT_color_subtable +http://www.opengl.org/registry/specs/EXT/color_subtable.txt +GL_EXT_color_subtable + void glColorSubTableEXT (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const void* data) + void glCopyColorSubTableEXT (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width) diff --git a/Externals/GLew/auto/extensions/GL_EXT_compiled_vertex_array b/Externals/GLew/auto/extensions/GL_EXT_compiled_vertex_array new file mode 100644 index 0000000000..0f8c5dc499 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_compiled_vertex_array @@ -0,0 +1,7 @@ +GL_EXT_compiled_vertex_array +http://www.opengl.org/registry/specs/EXT/compiled_vertex_array.txt +GL_EXT_compiled_vertex_array + GL_ARRAY_ELEMENT_LOCK_FIRST_EXT 0x81A8 + GL_ARRAY_ELEMENT_LOCK_COUNT_EXT 0x81A9 + void glLockArraysEXT (GLint first, GLsizei count) + void glUnlockArraysEXT (void) diff --git a/Externals/GLew/auto/extensions/GL_EXT_convolution b/Externals/GLew/auto/extensions/GL_EXT_convolution new file mode 100644 index 0000000000..7fda5a6543 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_convolution @@ -0,0 +1,36 @@ +GL_EXT_convolution +http://www.opengl.org/registry/specs/EXT/convolution.txt +GL_EXT_convolution + GL_CONVOLUTION_1D_EXT 0x8010 + GL_CONVOLUTION_2D_EXT 0x8011 + GL_SEPARABLE_2D_EXT 0x8012 + GL_CONVOLUTION_BORDER_MODE_EXT 0x8013 + GL_CONVOLUTION_FILTER_SCALE_EXT 0x8014 + GL_CONVOLUTION_FILTER_BIAS_EXT 0x8015 + GL_REDUCE_EXT 0x8016 + GL_CONVOLUTION_FORMAT_EXT 0x8017 + GL_CONVOLUTION_WIDTH_EXT 0x8018 + GL_CONVOLUTION_HEIGHT_EXT 0x8019 + GL_MAX_CONVOLUTION_WIDTH_EXT 0x801A + GL_MAX_CONVOLUTION_HEIGHT_EXT 0x801B + GL_POST_CONVOLUTION_RED_SCALE_EXT 0x801C + GL_POST_CONVOLUTION_GREEN_SCALE_EXT 0x801D + GL_POST_CONVOLUTION_BLUE_SCALE_EXT 0x801E + GL_POST_CONVOLUTION_ALPHA_SCALE_EXT 0x801F + GL_POST_CONVOLUTION_RED_BIAS_EXT 0x8020 + GL_POST_CONVOLUTION_GREEN_BIAS_EXT 0x8021 + GL_POST_CONVOLUTION_BLUE_BIAS_EXT 0x8022 + GL_POST_CONVOLUTION_ALPHA_BIAS_EXT 0x8023 + void glConvolutionFilter1DEXT (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void* image) + void glConvolutionFilter2DEXT (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* image) + void glConvolutionParameterfEXT (GLenum target, GLenum pname, GLfloat param) + void glConvolutionParameterfvEXT (GLenum target, GLenum pname, const GLfloat* params) + void glConvolutionParameteriEXT (GLenum target, GLenum pname, GLint param) + void glConvolutionParameterivEXT (GLenum target, GLenum pname, const GLint* params) + void glCopyConvolutionFilter1DEXT (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width) + void glCopyConvolutionFilter2DEXT (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height) + void glGetConvolutionFilterEXT (GLenum target, GLenum format, GLenum type, void* image) + void glGetConvolutionParameterfvEXT (GLenum target, GLenum pname, GLfloat* params) + void glGetConvolutionParameterivEXT (GLenum target, GLenum pname, GLint* params) + void glGetSeparableFilterEXT (GLenum target, GLenum format, GLenum type, void* row, void* column, void* span) + void glSeparableFilter2DEXT (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* row, const void* column) diff --git a/Externals/GLew/auto/extensions/GL_EXT_coordinate_frame b/Externals/GLew/auto/extensions/GL_EXT_coordinate_frame new file mode 100644 index 0000000000..c85f2352ff --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_coordinate_frame @@ -0,0 +1,19 @@ +GL_EXT_coordinate_frame +http://www.opengl.org/registry/specs/EXT/coordinate_frame.txt +GL_EXT_coordinate_frame + GL_TANGENT_ARRAY_EXT 0x8439 + GL_BINORMAL_ARRAY_EXT 0x843A + GL_CURRENT_TANGENT_EXT 0x843B + GL_CURRENT_BINORMAL_EXT 0x843C + GL_TANGENT_ARRAY_TYPE_EXT 0x843E + GL_TANGENT_ARRAY_STRIDE_EXT 0x843F + GL_BINORMAL_ARRAY_TYPE_EXT 0x8440 + GL_BINORMAL_ARRAY_STRIDE_EXT 0x8441 + GL_TANGENT_ARRAY_POINTER_EXT 0x8442 + GL_BINORMAL_ARRAY_POINTER_EXT 0x8443 + GL_MAP1_TANGENT_EXT 0x8444 + GL_MAP2_TANGENT_EXT 0x8445 + GL_MAP1_BINORMAL_EXT 0x8446 + GL_MAP2_BINORMAL_EXT 0x8447 + void glBinormalPointerEXT (GLenum type, GLsizei stride, void* pointer) + void glTangentPointerEXT (GLenum type, GLsizei stride, void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_EXT_copy_texture b/Externals/GLew/auto/extensions/GL_EXT_copy_texture new file mode 100644 index 0000000000..4fff03e73f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_copy_texture @@ -0,0 +1,8 @@ +GL_EXT_copy_texture +http://www.opengl.org/registry/specs/EXT/copy_texture.txt +GL_EXT_copy_texture + void glCopyTexImage1DEXT (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border) + void glCopyTexImage2DEXT (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border) + void glCopyTexSubImage1DEXT (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width) + void glCopyTexSubImage2DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height) + void glCopyTexSubImage3DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/extensions/GL_EXT_cull_vertex b/Externals/GLew/auto/extensions/GL_EXT_cull_vertex new file mode 100644 index 0000000000..0808ea244e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_cull_vertex @@ -0,0 +1,8 @@ +GL_EXT_cull_vertex +http://www.opengl.org/registry/specs/EXT/cull_vertex.txt +GL_EXT_cull_vertex + GL_CULL_VERTEX_EXT 0x81AA + GL_CULL_VERTEX_EYE_POSITION_EXT 0x81AB + GL_CULL_VERTEX_OBJECT_POSITION_EXT 0x81AC + void glCullParameterdvEXT (GLenum pname, GLdouble* params) + void glCullParameterfvEXT (GLenum pname, GLfloat* params) diff --git a/Externals/GLew/auto/extensions/GL_EXT_depth_bounds_test b/Externals/GLew/auto/extensions/GL_EXT_depth_bounds_test new file mode 100644 index 0000000000..62528b7b0c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_depth_bounds_test @@ -0,0 +1,6 @@ +GL_EXT_depth_bounds_test +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_depth_bounds_test.txt +GL_EXT_depth_bounds_test + GL_DEPTH_BOUNDS_TEST_EXT 0x8890 + GL_DEPTH_BOUNDS_EXT 0x8891 + void glDepthBoundsEXT (GLclampd zmin, GLclampd zmax) diff --git a/Externals/GLew/auto/extensions/GL_EXT_direct_state_access b/Externals/GLew/auto/extensions/GL_EXT_direct_state_access new file mode 100644 index 0000000000..712683b6de --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_direct_state_access @@ -0,0 +1,219 @@ +GL_EXT_direct_state_access +http://www.opengl.org/registry/specs/EXT/direct_state_access.txt +GL_EXT_direct_state_access + GL_PROGRAM_MATRIX_EXT 0x8E2D + GL_TRANSPOSE_PROGRAM_MATRIX_EXT 0x8E2E + GL_PROGRAM_MATRIX_STACK_DEPTH_EXT 0x8E2F + void glBindMultiTextureEXT (GLenum texunit, GLenum target, GLuint texture) + GLenum glCheckNamedFramebufferStatusEXT (GLuint framebuffer, GLenum target) + void glClientAttribDefaultEXT (GLbitfield mask) + void glCompressedMultiTexImage1DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data) + void glCompressedMultiTexImage2DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data) + void glCompressedMultiTexImage3DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data) + void glCompressedMultiTexSubImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data) + void glCompressedMultiTexSubImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data) + void glCompressedMultiTexSubImage3DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data) + void glCompressedTextureImage1DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data) + void glCompressedTextureImage2DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data) + void glCompressedTextureImage3DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data) + void glCompressedTextureSubImage1DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data) + void glCompressedTextureSubImage2DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data) + void glCompressedTextureSubImage3DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data) + void glCopyMultiTexImage1DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border) + void glCopyMultiTexImage2DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border) + void glCopyMultiTexSubImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width) + void glCopyMultiTexSubImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height) + void glCopyMultiTexSubImage3DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height) + void glCopyTextureImage1DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border) + void glCopyTextureImage2DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border) + void glCopyTextureSubImage1DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width) + void glCopyTextureSubImage2DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height) + void glCopyTextureSubImage3DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height) + void glDisableClientStateIndexedEXT (GLenum array, GLuint index) + void glDisableClientStateiEXT (GLenum array, GLuint index) + void glDisableVertexArrayAttribEXT (GLuint vaobj, GLuint index) + void glDisableVertexArrayEXT (GLuint vaobj, GLenum array) + void glEnableClientStateIndexedEXT (GLenum array, GLuint index) + void glEnableClientStateiEXT (GLenum array, GLuint index) + void glEnableVertexArrayAttribEXT (GLuint vaobj, GLuint index) + void glEnableVertexArrayEXT (GLuint vaobj, GLenum array) + void glFlushMappedNamedBufferRangeEXT (GLuint buffer, GLintptr offset, GLsizeiptr length) + void glFramebufferDrawBufferEXT (GLuint framebuffer, GLenum mode) + void glFramebufferDrawBuffersEXT (GLuint framebuffer, GLsizei n, const GLenum* bufs) + void glFramebufferReadBufferEXT (GLuint framebuffer, GLenum mode) + void glGenerateMultiTexMipmapEXT (GLenum texunit, GLenum target) + void glGenerateTextureMipmapEXT (GLuint texture, GLenum target) + void glGetCompressedMultiTexImageEXT (GLenum texunit, GLenum target, GLint level, void* img) + void glGetCompressedTextureImageEXT (GLuint texture, GLenum target, GLint level, void* img) + void glGetDoubleIndexedvEXT (GLenum target, GLuint index, GLdouble* params) + void glGetDoublei_vEXT (GLenum pname, GLuint index, GLdouble* params) + void glGetFloatIndexedvEXT (GLenum target, GLuint index, GLfloat* params) + void glGetFloati_vEXT (GLenum pname, GLuint index, GLfloat* params) + void glGetFramebufferParameterivEXT (GLuint framebuffer, GLenum pname, GLint* param) + void glGetMultiTexEnvfvEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat* params) + void glGetMultiTexEnvivEXT (GLenum texunit, GLenum target, GLenum pname, GLint* params) + void glGetMultiTexGendvEXT (GLenum texunit, GLenum coord, GLenum pname, GLdouble* params) + void glGetMultiTexGenfvEXT (GLenum texunit, GLenum coord, GLenum pname, GLfloat* params) + void glGetMultiTexGenivEXT (GLenum texunit, GLenum coord, GLenum pname, GLint* params) + void glGetMultiTexImageEXT (GLenum texunit, GLenum target, GLint level, GLenum format, GLenum type, void* pixels) + void glGetMultiTexLevelParameterfvEXT (GLenum texunit, GLenum target, GLint level, GLenum pname, GLfloat* params) + void glGetMultiTexLevelParameterivEXT (GLenum texunit, GLenum target, GLint level, GLenum pname, GLint* params) + void glGetMultiTexParameterIivEXT (GLenum texunit, GLenum target, GLenum pname, GLint* params) + void glGetMultiTexParameterIuivEXT (GLenum texunit, GLenum target, GLenum pname, GLuint* params) + void glGetMultiTexParameterfvEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat* params) + void glGetMultiTexParameterivEXT (GLenum texunit, GLenum target, GLenum pname, GLint* params) + void glGetNamedBufferParameterivEXT (GLuint buffer, GLenum pname, GLint* params) + void glGetNamedBufferPointervEXT (GLuint buffer, GLenum pname, void** params) + void glGetNamedBufferSubDataEXT (GLuint buffer, GLintptr offset, GLsizeiptr size, void* data) + void glGetNamedFramebufferAttachmentParameterivEXT (GLuint framebuffer, GLenum attachment, GLenum pname, GLint* params) + void glGetNamedProgramLocalParameterIivEXT (GLuint program, GLenum target, GLuint index, GLint* params) + void glGetNamedProgramLocalParameterIuivEXT (GLuint program, GLenum target, GLuint index, GLuint* params) + void glGetNamedProgramLocalParameterdvEXT (GLuint program, GLenum target, GLuint index, GLdouble* params) + void glGetNamedProgramLocalParameterfvEXT (GLuint program, GLenum target, GLuint index, GLfloat* params) + void glGetNamedProgramStringEXT (GLuint program, GLenum target, GLenum pname, void* string) + void glGetNamedProgramivEXT (GLuint program, GLenum target, GLenum pname, GLint* params) + void glGetNamedRenderbufferParameterivEXT (GLuint renderbuffer, GLenum pname, GLint* params) + void glGetPointerIndexedvEXT (GLenum target, GLuint index, GLvoid** params) + void glGetPointeri_vEXT (GLenum pname, GLuint index, GLvoid** params) + void glGetTextureImageEXT (GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, void* pixels) + void glGetTextureLevelParameterfvEXT (GLuint texture, GLenum target, GLint level, GLenum pname, GLfloat* params) + void glGetTextureLevelParameterivEXT (GLuint texture, GLenum target, GLint level, GLenum pname, GLint* params) + void glGetTextureParameterIivEXT (GLuint texture, GLenum target, GLenum pname, GLint* params) + void glGetTextureParameterIuivEXT (GLuint texture, GLenum target, GLenum pname, GLuint* params) + void glGetTextureParameterfvEXT (GLuint texture, GLenum target, GLenum pname, GLfloat* params) + void glGetTextureParameterivEXT (GLuint texture, GLenum target, GLenum pname, GLint* params) + void glGetVertexArrayIntegeri_vEXT (GLuint vaobj, GLuint index, GLenum pname, GLint* param) + void glGetVertexArrayIntegervEXT (GLuint vaobj, GLenum pname, GLint* param) + void glGetVertexArrayPointeri_vEXT (GLuint vaobj, GLuint index, GLenum pname, GLvoid** param) + void glGetVertexArrayPointervEXT (GLuint vaobj, GLenum pname, GLvoid** param) + GLvoid * glMapNamedBufferEXT (GLuint buffer, GLenum access) + GLvoid * glMapNamedBufferRangeEXT (GLuint buffer, GLintptr offset, GLsizeiptr length, GLbitfield access) + void glMatrixFrustumEXT (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f) + void glMatrixLoadIdentityEXT (GLenum matrixMode) + void glMatrixLoadTransposedEXT (GLenum matrixMode, const GLdouble* m) + void glMatrixLoadTransposefEXT (GLenum matrixMode, const GLfloat* m) + void glMatrixLoaddEXT (GLenum matrixMode, const GLdouble* m) + void glMatrixLoadfEXT (GLenum matrixMode, const GLfloat* m) + void glMatrixMultTransposedEXT (GLenum matrixMode, const GLdouble* m) + void glMatrixMultTransposefEXT (GLenum matrixMode, const GLfloat* m) + void glMatrixMultdEXT (GLenum matrixMode, const GLdouble* m) + void glMatrixMultfEXT (GLenum matrixMode, const GLfloat* m) + void glMatrixOrthoEXT (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f) + void glMatrixPopEXT (GLenum matrixMode) + void glMatrixPushEXT (GLenum matrixMode) + void glMatrixRotatedEXT (GLenum matrixMode, GLdouble angle, GLdouble x, GLdouble y, GLdouble z) + void glMatrixRotatefEXT (GLenum matrixMode, GLfloat angle, GLfloat x, GLfloat y, GLfloat z) + void glMatrixScaledEXT (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z) + void glMatrixScalefEXT (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z) + void glMatrixTranslatedEXT (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z) + void glMatrixTranslatefEXT (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z) + void glMultiTexBufferEXT (GLenum texunit, GLenum target, GLenum internalformat, GLuint buffer) + void glMultiTexCoordPointerEXT (GLenum texunit, GLint size, GLenum type, GLsizei stride, const void* pointer) + void glMultiTexEnvfEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat param) + void glMultiTexEnvfvEXT (GLenum texunit, GLenum target, GLenum pname, const GLfloat* params) + void glMultiTexEnviEXT (GLenum texunit, GLenum target, GLenum pname, GLint param) + void glMultiTexEnvivEXT (GLenum texunit, GLenum target, GLenum pname, const GLint* params) + void glMultiTexGendEXT (GLenum texunit, GLenum coord, GLenum pname, GLdouble param) + void glMultiTexGendvEXT (GLenum texunit, GLenum coord, GLenum pname, const GLdouble* params) + void glMultiTexGenfEXT (GLenum texunit, GLenum coord, GLenum pname, GLfloat param) + void glMultiTexGenfvEXT (GLenum texunit, GLenum coord, GLenum pname, const GLfloat* params) + void glMultiTexGeniEXT (GLenum texunit, GLenum coord, GLenum pname, GLint param) + void glMultiTexGenivEXT (GLenum texunit, GLenum coord, GLenum pname, const GLint* params) + void glMultiTexImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void* pixels) + void glMultiTexImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void* pixels) + void glMultiTexImage3DEXT (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels) + void glMultiTexParameterIivEXT (GLenum texunit, GLenum target, GLenum pname, const GLint* params) + void glMultiTexParameterIuivEXT (GLenum texunit, GLenum target, GLenum pname, const GLuint* params) + void glMultiTexParameterfEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat param) + void glMultiTexParameterfvEXT (GLenum texunit, GLenum target, GLenum pname, const GLfloat* param) + void glMultiTexParameteriEXT (GLenum texunit, GLenum target, GLenum pname, GLint param) + void glMultiTexParameterivEXT (GLenum texunit, GLenum target, GLenum pname, const GLint* param) + void glMultiTexRenderbufferEXT (GLenum texunit, GLenum target, GLuint renderbuffer) + void glMultiTexSubImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels) + void glMultiTexSubImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels) + void glMultiTexSubImage3DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels) + void glNamedBufferDataEXT (GLuint buffer, GLsizeiptr size, const void* data, GLenum usage) + void glNamedBufferSubDataEXT (GLuint buffer, GLintptr offset, GLsizeiptr size, const void* data) + void glNamedCopyBufferSubDataEXT (GLuint readBuffer, GLuint writeBuffer, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size) + void glNamedFramebufferRenderbufferEXT (GLuint framebuffer, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer) + void glNamedFramebufferTexture1DEXT (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level) + void glNamedFramebufferTexture2DEXT (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level) + void glNamedFramebufferTexture3DEXT (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset) + void glNamedFramebufferTextureEXT (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level) + void glNamedFramebufferTextureFaceEXT (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLenum face) + void glNamedFramebufferTextureLayerEXT (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLint layer) + void glNamedProgramLocalParameter4dEXT (GLuint program, GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glNamedProgramLocalParameter4dvEXT (GLuint program, GLenum target, GLuint index, const GLdouble* params) + void glNamedProgramLocalParameter4fEXT (GLuint program, GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glNamedProgramLocalParameter4fvEXT (GLuint program, GLenum target, GLuint index, const GLfloat* params) + void glNamedProgramLocalParameterI4iEXT (GLuint program, GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w) + void glNamedProgramLocalParameterI4ivEXT (GLuint program, GLenum target, GLuint index, const GLint* params) + void glNamedProgramLocalParameterI4uiEXT (GLuint program, GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w) + void glNamedProgramLocalParameterI4uivEXT (GLuint program, GLenum target, GLuint index, const GLuint* params) + void glNamedProgramLocalParameters4fvEXT (GLuint program, GLenum target, GLuint index, GLsizei count, const GLfloat* params) + void glNamedProgramLocalParametersI4ivEXT (GLuint program, GLenum target, GLuint index, GLsizei count, const GLint* params) + void glNamedProgramLocalParametersI4uivEXT (GLuint program, GLenum target, GLuint index, GLsizei count, const GLuint* params) + void glNamedProgramStringEXT (GLuint program, GLenum target, GLenum format, GLsizei len, const void* string) + void glNamedRenderbufferStorageEXT (GLuint renderbuffer, GLenum internalformat, GLsizei width, GLsizei height) + void glNamedRenderbufferStorageMultisampleCoverageEXT (GLuint renderbuffer, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height) + void glNamedRenderbufferStorageMultisampleEXT (GLuint renderbuffer, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height) + void glProgramUniform1fEXT (GLuint program, GLint location, GLfloat v0) + void glProgramUniform1fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat* value) + void glProgramUniform1iEXT (GLuint program, GLint location, GLint v0) + void glProgramUniform1ivEXT (GLuint program, GLint location, GLsizei count, const GLint* value) + void glProgramUniform1uiEXT (GLuint program, GLint location, GLuint v0) + void glProgramUniform1uivEXT (GLuint program, GLint location, GLsizei count, const GLuint* value) + void glProgramUniform2fEXT (GLuint program, GLint location, GLfloat v0, GLfloat v1) + void glProgramUniform2fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat* value) + void glProgramUniform2iEXT (GLuint program, GLint location, GLint v0, GLint v1) + void glProgramUniform2ivEXT (GLuint program, GLint location, GLsizei count, const GLint* value) + void glProgramUniform2uiEXT (GLuint program, GLint location, GLuint v0, GLuint v1) + void glProgramUniform2uivEXT (GLuint program, GLint location, GLsizei count, const GLuint* value) + void glProgramUniform3fEXT (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2) + void glProgramUniform3fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat* value) + void glProgramUniform3iEXT (GLuint program, GLint location, GLint v0, GLint v1, GLint v2) + void glProgramUniform3ivEXT (GLuint program, GLint location, GLsizei count, const GLint* value) + void glProgramUniform3uiEXT (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2) + void glProgramUniform3uivEXT (GLuint program, GLint location, GLsizei count, const GLuint* value) + void glProgramUniform4fEXT (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3) + void glProgramUniform4fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat* value) + void glProgramUniform4iEXT (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3) + void glProgramUniform4ivEXT (GLuint program, GLint location, GLsizei count, const GLint* value) + void glProgramUniform4uiEXT (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3) + void glProgramUniform4uivEXT (GLuint program, GLint location, GLsizei count, const GLuint* value) + void glProgramUniformMatrix2fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix2x3fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix2x4fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix3fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix3x2fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix3x4fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix4fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix4x2fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glProgramUniformMatrix4x3fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) + void glPushClientAttribDefaultEXT (GLbitfield mask) + void glTextureBufferEXT (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer) + void glTextureImage1DEXT (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void* pixels) + void glTextureImage2DEXT (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void* pixels) + void glTextureImage3DEXT (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels) + void glTextureParameterIivEXT (GLuint texture, GLenum target, GLenum pname, const GLint* params) + void glTextureParameterIuivEXT (GLuint texture, GLenum target, GLenum pname, const GLuint* params) + void glTextureParameterfEXT (GLuint texture, GLenum target, GLenum pname, GLfloat param) + void glTextureParameterfvEXT (GLuint texture, GLenum target, GLenum pname, const GLfloat* param) + void glTextureParameteriEXT (GLuint texture, GLenum target, GLenum pname, GLint param) + void glTextureParameterivEXT (GLuint texture, GLenum target, GLenum pname, const GLint* param) + void glTextureRenderbufferEXT (GLuint texture, GLenum target, GLuint renderbuffer) + void glTextureSubImage1DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels) + void glTextureSubImage2DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels) + void glTextureSubImage3DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels) + GLboolean glUnmapNamedBufferEXT (GLuint buffer) + void glVertexArrayColorOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArrayEdgeFlagOffsetEXT (GLuint vaobj, GLuint buffer, GLsizei stride, GLintptr offset) + void glVertexArrayFogCoordOffsetEXT (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArrayIndexOffsetEXT (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArrayMultiTexCoordOffsetEXT (GLuint vaobj, GLuint buffer, GLenum texunit, GLint size, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArrayNormalOffsetEXT (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArraySecondaryColorOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArrayTexCoordOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArrayVertexAttribIOffsetEXT (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset) + void glVertexArrayVertexAttribOffsetEXT (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLintptr offset) + void glVertexArrayVertexOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset) diff --git a/Externals/GLew/auto/extensions/GL_EXT_draw_buffers2 b/Externals/GLew/auto/extensions/GL_EXT_draw_buffers2 new file mode 100644 index 0000000000..3917eb81ee --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_draw_buffers2 @@ -0,0 +1,9 @@ +GL_EXT_draw_buffers2 +http://www.opengl.org/registry/specs/EXT/draw_buffers2.txt +GL_EXT_draw_buffers2 + void glColorMaskIndexedEXT (GLuint buf, GLboolean r, GLboolean g, GLboolean b, GLboolean a) + void glDisableIndexedEXT (GLenum target, GLuint index) + void glEnableIndexedEXT (GLenum target, GLuint index) + void glGetBooleanIndexedvEXT (GLenum value, GLuint index, GLboolean* data) + void glGetIntegerIndexedvEXT (GLenum value, GLuint index, GLint* data) + GLboolean glIsEnabledIndexedEXT (GLenum target, GLuint index) diff --git a/Externals/GLew/auto/extensions/GL_EXT_draw_instanced b/Externals/GLew/auto/extensions/GL_EXT_draw_instanced new file mode 100644 index 0000000000..afafa27f3e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_draw_instanced @@ -0,0 +1,5 @@ +GL_EXT_draw_instanced +http://developer.download.nvidia.com/opengl/specs/GL_EXT_draw_instanced.txt +GL_EXT_draw_instanced + void glDrawArraysInstancedEXT (GLenum mode, GLint start, GLsizei count, GLsizei primcount) + void glDrawElementsInstancedEXT (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount) diff --git a/Externals/GLew/auto/extensions/GL_EXT_draw_range_elements b/Externals/GLew/auto/extensions/GL_EXT_draw_range_elements new file mode 100644 index 0000000000..2abc870ba2 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_draw_range_elements @@ -0,0 +1,6 @@ +GL_EXT_draw_range_elements +http://oss.sgi.com/projects/ogl-sample/registry/EXT/draw_range_elements.txt +GL_EXT_draw_range_elements + GL_MAX_ELEMENTS_VERTICES 0x80E8 + GL_MAX_ELEMENTS_INDICES 0x80E9 + void glDrawRangeElementsEXT (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices) diff --git a/Externals/GLew/auto/extensions/GL_EXT_fog_coord b/Externals/GLew/auto/extensions/GL_EXT_fog_coord new file mode 100644 index 0000000000..ac7868aa32 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_fog_coord @@ -0,0 +1,16 @@ +GL_EXT_fog_coord +http://oss.sgi.com/projects/ogl-sample/registry/EXT/fog_coord.txt +GL_EXT_fog_coord + GL_FOG_COORDINATE_SOURCE_EXT 0x8450 + GL_FOG_COORDINATE_EXT 0x8451 + GL_FRAGMENT_DEPTH_EXT 0x8452 + GL_CURRENT_FOG_COORDINATE_EXT 0x8453 + GL_FOG_COORDINATE_ARRAY_TYPE_EXT 0x8454 + GL_FOG_COORDINATE_ARRAY_STRIDE_EXT 0x8455 + GL_FOG_COORDINATE_ARRAY_POINTER_EXT 0x8456 + GL_FOG_COORDINATE_ARRAY_EXT 0x8457 + void glFogCoordfEXT (GLfloat coord) + void glFogCoordfvEXT (const GLfloat *coord) + void glFogCoorddEXT (GLdouble coord) + void glFogCoorddvEXT (const GLdouble *coord) + void glFogCoordPointerEXT (GLenum type, GLsizei stride, const GLvoid *pointer) diff --git a/Externals/GLew/auto/extensions/GL_EXT_fragment_lighting b/Externals/GLew/auto/extensions/GL_EXT_fragment_lighting new file mode 100644 index 0000000000..ab6888d8e5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_fragment_lighting @@ -0,0 +1,35 @@ +GL_EXT_fragment_lighting +http://www.opengl.org/registry/specs/EXT/fragment_lighting.txt +GL_EXT_fragment_lighting + GL_FRAGMENT_LIGHTING_EXT 0x8400 + GL_FRAGMENT_COLOR_MATERIAL_EXT 0x8401 + GL_FRAGMENT_COLOR_MATERIAL_FACE_EXT 0x8402 + GL_FRAGMENT_COLOR_MATERIAL_PARAMETER_EXT 0x8403 + GL_MAX_FRAGMENT_LIGHTS_EXT 0x8404 + GL_MAX_ACTIVE_LIGHTS_EXT 0x8405 + GL_CURRENT_RASTER_NORMAL_EXT 0x8406 + GL_LIGHT_ENV_MODE_EXT 0x8407 + GL_FRAGMENT_LIGHT_MODEL_LOCAL_VIEWER_EXT 0x8408 + GL_FRAGMENT_LIGHT_MODEL_TWO_SIDE_EXT 0x8409 + GL_FRAGMENT_LIGHT_MODEL_AMBIENT_EXT 0x840A + GL_FRAGMENT_LIGHT_MODEL_NORMAL_INTERPOLATION_EXT 0x840B + GL_FRAGMENT_LIGHT0_EXT 0x840C + GL_FRAGMENT_LIGHT7_EXT 0x8413 + void glFragmentColorMaterialEXT (GLenum face, GLenum mode) + void glFragmentLightModelfEXT (GLenum pname, GLfloat param) + void glFragmentLightModelfvEXT (GLenum pname, GLfloat* params) + void glFragmentLightModeliEXT (GLenum pname, GLint param) + void glFragmentLightModelivEXT (GLenum pname, GLint* params) + void glFragmentLightfEXT (GLenum light, GLenum pname, GLfloat param) + void glFragmentLightfvEXT (GLenum light, GLenum pname, GLfloat* params) + void glFragmentLightiEXT (GLenum light, GLenum pname, GLint param) + void glFragmentLightivEXT (GLenum light, GLenum pname, GLint* params) + void glFragmentMaterialfEXT (GLenum face, GLenum pname, const GLfloat param) + void glFragmentMaterialfvEXT (GLenum face, GLenum pname, const GLfloat* params) + void glFragmentMaterialiEXT (GLenum face, GLenum pname, const GLint param) + void glFragmentMaterialivEXT (GLenum face, GLenum pname, const GLint* params) + void glGetFragmentLightfvEXT (GLenum light, GLenum pname, GLfloat* params) + void glGetFragmentLightivEXT (GLenum light, GLenum pname, GLint* params) + void glGetFragmentMaterialfvEXT (GLenum face, GLenum pname, const GLfloat* params) + void glGetFragmentMaterialivEXT (GLenum face, GLenum pname, const GLint* params) + void glLightEnviEXT (GLenum pname, GLint param) diff --git a/Externals/GLew/auto/extensions/GL_EXT_framebuffer_blit b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_blit new file mode 100644 index 0000000000..22110c2990 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_blit @@ -0,0 +1,8 @@ +GL_EXT_framebuffer_blit +http://www.opengl.org/registry/specs/EXT/framebuffer_blit.txt +GL_EXT_framebuffer_blit + GL_DRAW_FRAMEBUFFER_BINDING_EXT 0x8CA6 + GL_READ_FRAMEBUFFER_EXT 0x8CA8 + GL_DRAW_FRAMEBUFFER_EXT 0x8CA9 + GL_READ_FRAMEBUFFER_BINDING_EXT 0x8CAA + void glBlitFramebufferEXT (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter) diff --git a/Externals/GLew/auto/extensions/GL_EXT_framebuffer_multisample b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_multisample new file mode 100644 index 0000000000..c512933f00 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_multisample @@ -0,0 +1,9 @@ +GL_EXT_framebuffer_multisample +http://www.opengl.org/registry/specs/EXT/framebuffer_multisample.txt +GL_EXT_framebuffer_multisample + GL_RENDERBUFFER_SAMPLES_EXT 0x8CAB + GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_EXT 0x8D56 + GL_MAX_SAMPLES_EXT 0x8D57 + void glRenderbufferStorageMultisampleEXT (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height) + GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_EXT 0x8D56 + GL_MAX_SAMPLES_EXT 0x8D57 diff --git a/Externals/GLew/auto/extensions/GL_EXT_framebuffer_object b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_object new file mode 100644 index 0000000000..1fb4998956 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_object @@ -0,0 +1,71 @@ +GL_EXT_framebuffer_object +http://www.opengl.org/registry/specs/EXT/framebuffer_object.txt +GL_EXT_framebuffer_object + GL_INVALID_FRAMEBUFFER_OPERATION_EXT 0x0506 + GL_MAX_RENDERBUFFER_SIZE_EXT 0x84E8 + GL_FRAMEBUFFER_BINDING_EXT 0x8CA6 + GL_RENDERBUFFER_BINDING_EXT 0x8CA7 + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE_EXT 0x8CD0 + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME_EXT 0x8CD1 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL_EXT 0x8CD2 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE_EXT 0x8CD3 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET_EXT 0x8CD4 + GL_FRAMEBUFFER_COMPLETE_EXT 0x8CD5 + GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT_EXT 0x8CD6 + GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT_EXT 0x8CD7 + GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS_EXT 0x8CD9 + GL_FRAMEBUFFER_INCOMPLETE_FORMATS_EXT 0x8CDA + GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER_EXT 0x8CDB + GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER_EXT 0x8CDC + GL_FRAMEBUFFER_UNSUPPORTED_EXT 0x8CDD + GL_MAX_COLOR_ATTACHMENTS_EXT 0x8CDF + GL_COLOR_ATTACHMENT0_EXT 0x8CE0 + GL_COLOR_ATTACHMENT1_EXT 0x8CE1 + GL_COLOR_ATTACHMENT2_EXT 0x8CE2 + GL_COLOR_ATTACHMENT3_EXT 0x8CE3 + GL_COLOR_ATTACHMENT4_EXT 0x8CE4 + GL_COLOR_ATTACHMENT5_EXT 0x8CE5 + GL_COLOR_ATTACHMENT6_EXT 0x8CE6 + GL_COLOR_ATTACHMENT7_EXT 0x8CE7 + GL_COLOR_ATTACHMENT8_EXT 0x8CE8 + GL_COLOR_ATTACHMENT9_EXT 0x8CE9 + GL_COLOR_ATTACHMENT10_EXT 0x8CEA + GL_COLOR_ATTACHMENT11_EXT 0x8CEB + GL_COLOR_ATTACHMENT12_EXT 0x8CEC + GL_COLOR_ATTACHMENT13_EXT 0x8CED + GL_COLOR_ATTACHMENT14_EXT 0x8CEE + GL_COLOR_ATTACHMENT15_EXT 0x8CEF + GL_DEPTH_ATTACHMENT_EXT 0x8D00 + GL_STENCIL_ATTACHMENT_EXT 0x8D20 + GL_FRAMEBUFFER_EXT 0x8D40 + GL_RENDERBUFFER_EXT 0x8D41 + GL_RENDERBUFFER_WIDTH_EXT 0x8D42 + GL_RENDERBUFFER_HEIGHT_EXT 0x8D43 + GL_RENDERBUFFER_INTERNAL_FORMAT_EXT 0x8D44 + GL_STENCIL_INDEX1_EXT 0x8D46 + GL_STENCIL_INDEX4_EXT 0x8D47 + GL_STENCIL_INDEX8_EXT 0x8D48 + GL_STENCIL_INDEX16_EXT 0x8D49 + GL_RENDERBUFFER_RED_SIZE_EXT 0x8D50 + GL_RENDERBUFFER_GREEN_SIZE_EXT 0x8D51 + GL_RENDERBUFFER_BLUE_SIZE_EXT 0x8D52 + GL_RENDERBUFFER_ALPHA_SIZE_EXT 0x8D53 + GL_RENDERBUFFER_DEPTH_SIZE_EXT 0x8D54 + GL_RENDERBUFFER_STENCIL_SIZE_EXT 0x8D55 + void glBindFramebufferEXT (GLenum target, GLuint framebuffer) + void glBindRenderbufferEXT (GLenum target, GLuint renderbuffer) + GLenum glCheckFramebufferStatusEXT (GLenum target) + void glDeleteFramebuffersEXT (GLsizei n, const GLuint* framebuffers) + void glDeleteRenderbuffersEXT (GLsizei n, const GLuint* renderbuffers) + void glFramebufferRenderbufferEXT (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer) + void glFramebufferTexture1DEXT (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level) + void glFramebufferTexture2DEXT (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level) + void glFramebufferTexture3DEXT (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset) + void glGenFramebuffersEXT (GLsizei n, GLuint* framebuffers) + void glGenRenderbuffersEXT (GLsizei n, GLuint* renderbuffers) + void glGenerateMipmapEXT (GLenum target) + void glGetFramebufferAttachmentParameterivEXT (GLenum target, GLenum attachment, GLenum pname, GLint* params) + void glGetRenderbufferParameterivEXT (GLenum target, GLenum pname, GLint* params) + GLboolean glIsFramebufferEXT (GLuint framebuffer) + GLboolean glIsRenderbufferEXT (GLuint renderbuffer) + void glRenderbufferStorageEXT (GLenum target, GLenum internalformat, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/extensions/GL_EXT_framebuffer_sRGB b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_sRGB new file mode 100644 index 0000000000..4ca897b1fd --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_framebuffer_sRGB @@ -0,0 +1,5 @@ +GL_EXT_framebuffer_sRGB +http://developer.download.nvidia.com/opengl/specs/GL_EXT_framebuffer_sRGB.txt +GL_EXT_framebuffer_sRGB + GL_FRAMEBUFFER_SRGB_EXT 0x8DB9 + GL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x8DBA diff --git a/Externals/GLew/auto/extensions/GL_EXT_geometry_shader4 b/Externals/GLew/auto/extensions/GL_EXT_geometry_shader4 new file mode 100644 index 0000000000..888e500ae0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_geometry_shader4 @@ -0,0 +1,27 @@ +GL_EXT_geometry_shader4 +http://developer.download.nvidia.com/opengl/specs/GL_EXT_geometry_shader4.txt +GL_EXT_geometry_shader4 + GL_GEOMETRY_SHADER_EXT 0x8DD9 + GL_MAX_GEOMETRY_VARYING_COMPONENTS_EXT 0x8DDD + GL_MAX_VERTEX_VARYING_COMPONENTS_EXT 0x8DDE + GL_MAX_VARYING_COMPONENTS_EXT 0x8B4B + GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_EXT 0x8DDF + GL_MAX_GEOMETRY_OUTPUT_VERTICES_EXT 0x8DE0 + GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_EXT 0x8DE1 + GL_GEOMETRY_VERTICES_OUT_EXT 0x8DDA + GL_GEOMETRY_INPUT_TYPE_EXT 0x8DDB + GL_GEOMETRY_OUTPUT_TYPE_EXT 0x8DDC + GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_EXT 0x8C29 + GL_LINES_ADJACENCY_EXT 0xA + GL_LINE_STRIP_ADJACENCY_EXT 0xB + GL_TRIANGLES_ADJACENCY_EXT 0xC + GL_TRIANGLE_STRIP_ADJACENCY_EXT 0xD + GL_FRAMEBUFFER_ATTACHMENT_LAYERED_EXT 0x8DA7 + GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_EXT 0x8DA8 + GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_EXT 0x8DA9 + GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER_EXT 0x8CD4 + GL_PROGRAM_POINT_SIZE_EXT 0x8642 + void glProgramParameteriEXT (GLuint program, GLenum pname, GLint value) + void glFramebufferTextureEXT (GLenum target, GLenum attachment, GLuint texture, GLint level) + void glFramebufferTextureLayerEXT (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer) + void glFramebufferTextureFaceEXT (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face) diff --git a/Externals/GLew/auto/extensions/GL_EXT_gpu_program_parameters b/Externals/GLew/auto/extensions/GL_EXT_gpu_program_parameters new file mode 100644 index 0000000000..9048c98d96 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_gpu_program_parameters @@ -0,0 +1,5 @@ +GL_EXT_gpu_program_parameters +http://developer.download.nvidia.com/opengl/specs/GL_EXT_gpu_program_parameters.txt +GL_EXT_gpu_program_parameters + void glProgramEnvParameters4fvEXT (GLenum target, GLuint index, GLsizei count, const GLfloat* params) + void glProgramLocalParameters4fvEXT (GLenum target, GLuint index, GLsizei count, const GLfloat* params) diff --git a/Externals/GLew/auto/extensions/GL_EXT_gpu_shader4 b/Externals/GLew/auto/extensions/GL_EXT_gpu_shader4 new file mode 100644 index 0000000000..0e89f0db06 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_gpu_shader4 @@ -0,0 +1,63 @@ +GL_EXT_gpu_shader4 +http://developer.download.nvidia.com/opengl/specs/GL_EXT_gpu_shader4.txt +GL_EXT_gpu_shader4 + GL_SAMPLER_1D_ARRAY_EXT 0x8DC0 + GL_SAMPLER_2D_ARRAY_EXT 0x8DC1 + GL_SAMPLER_BUFFER_EXT 0x8DC2 + GL_SAMPLER_1D_ARRAY_SHADOW_EXT 0x8DC3 + GL_SAMPLER_2D_ARRAY_SHADOW_EXT 0x8DC4 + GL_SAMPLER_CUBE_SHADOW_EXT 0x8DC5 + GL_UNSIGNED_INT_VEC2_EXT 0x8DC6 + GL_UNSIGNED_INT_VEC3_EXT 0x8DC7 + GL_UNSIGNED_INT_VEC4_EXT 0x8DC8 + GL_INT_SAMPLER_1D_EXT 0x8DC9 + GL_INT_SAMPLER_2D_EXT 0x8DCA + GL_INT_SAMPLER_3D_EXT 0x8DCB + GL_INT_SAMPLER_CUBE_EXT 0x8DCC + GL_INT_SAMPLER_2D_RECT_EXT 0x8DCD + GL_INT_SAMPLER_1D_ARRAY_EXT 0x8DCE + GL_INT_SAMPLER_2D_ARRAY_EXT 0x8DCF + GL_INT_SAMPLER_BUFFER_EXT 0x8DD0 + GL_UNSIGNED_INT_SAMPLER_1D_EXT 0x8DD1 + GL_UNSIGNED_INT_SAMPLER_2D_EXT 0x8DD2 + GL_UNSIGNED_INT_SAMPLER_3D_EXT 0x8DD3 + GL_UNSIGNED_INT_SAMPLER_CUBE_EXT 0x8DD4 + GL_UNSIGNED_INT_SAMPLER_2D_RECT_EXT 0x8DD5 + GL_UNSIGNED_INT_SAMPLER_1D_ARRAY_EXT 0x8DD6 + GL_UNSIGNED_INT_SAMPLER_2D_ARRAY_EXT 0x8DD7 + GL_UNSIGNED_INT_SAMPLER_BUFFER_EXT 0x8DD8 + GL_VERTEX_ATTRIB_ARRAY_INTEGER_EXT 0x88FD + void glGetUniformuivEXT (GLuint program, GLint location, GLuint *params) + void glBindFragDataLocationEXT (GLuint program, GLuint color, const GLchar *name) + GLint glGetFragDataLocationEXT (GLuint program, const GLchar *name) + void glUniform1uiEXT (GLint location, GLuint v0) + void glUniform2uiEXT (GLint location, GLuint v0, GLuint v1) + void glUniform3uiEXT (GLint location, GLuint v0, GLuint v1, GLuint v2) + void glUniform4uiEXT (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3) + void glUniform1uivEXT (GLint location, GLsizei count, const GLuint *value) + void glUniform2uivEXT (GLint location, GLsizei count, const GLuint *value) + void glUniform3uivEXT (GLint location, GLsizei count, const GLuint *value) + void glUniform4uivEXT (GLint location, GLsizei count, const GLuint *value) + void glVertexAttribI1iEXT (GLuint index, GLint x) + void glVertexAttribI2iEXT (GLuint index, GLint x, GLint y) + void glVertexAttribI3iEXT (GLuint index, GLint x, GLint y, GLint z) + void glVertexAttribI4iEXT (GLuint index, GLint x, GLint y, GLint z, GLint w) + void glVertexAttribI1uiEXT (GLuint index, GLuint x) + void glVertexAttribI2uiEXT (GLuint index, GLuint x, GLuint y) + void glVertexAttribI3uiEXT (GLuint index, GLuint x, GLuint y, GLuint z) + void glVertexAttribI4uiEXT (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w) + void glVertexAttribI1ivEXT (GLuint index, const GLint *v) + void glVertexAttribI2ivEXT (GLuint index, const GLint *v) + void glVertexAttribI3ivEXT (GLuint index, const GLint *v) + void glVertexAttribI4ivEXT (GLuint index, const GLint *v) + void glVertexAttribI1uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI2uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI3uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI4uivEXT (GLuint index, const GLuint *v) + void glVertexAttribI4bvEXT (GLuint index, const GLbyte *v) + void glVertexAttribI4svEXT (GLuint index, const GLshort *v) + void glVertexAttribI4ubvEXT (GLuint index, const GLubyte *v) + void glVertexAttribI4usvEXT (GLuint index, const GLushort *v) + void glVertexAttribIPointerEXT (GLuint index, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer) + void glGetVertexAttribIivEXT (GLuint index, GLenum pname, GLint *params) + void glGetVertexAttribIuivEXT (GLuint index, GLenum pname, GLuint *params) diff --git a/Externals/GLew/auto/extensions/GL_EXT_histogram b/Externals/GLew/auto/extensions/GL_EXT_histogram new file mode 100644 index 0000000000..14dfb527b1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_histogram @@ -0,0 +1,26 @@ +GL_EXT_histogram +http://www.opengl.org/registry/specs/EXT/histogram.txt +GL_EXT_histogram + GL_HISTOGRAM_EXT 0x8024 + GL_PROXY_HISTOGRAM_EXT 0x8025 + GL_HISTOGRAM_WIDTH_EXT 0x8026 + GL_HISTOGRAM_FORMAT_EXT 0x8027 + GL_HISTOGRAM_RED_SIZE_EXT 0x8028 + GL_HISTOGRAM_GREEN_SIZE_EXT 0x8029 + GL_HISTOGRAM_BLUE_SIZE_EXT 0x802A + GL_HISTOGRAM_ALPHA_SIZE_EXT 0x802B + GL_HISTOGRAM_LUMINANCE_SIZE_EXT 0x802C + GL_HISTOGRAM_SINK_EXT 0x802D + GL_MINMAX_EXT 0x802E + GL_MINMAX_FORMAT_EXT 0x802F + GL_MINMAX_SINK_EXT 0x8030 + void glGetHistogramEXT (GLenum target, GLboolean reset, GLenum format, GLenum type, void* values) + void glGetHistogramParameterfvEXT (GLenum target, GLenum pname, GLfloat* params) + void glGetHistogramParameterivEXT (GLenum target, GLenum pname, GLint* params) + void glGetMinmaxEXT (GLenum target, GLboolean reset, GLenum format, GLenum type, void* values) + void glGetMinmaxParameterfvEXT (GLenum target, GLenum pname, GLfloat* params) + void glGetMinmaxParameterivEXT (GLenum target, GLenum pname, GLint* params) + void glHistogramEXT (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink) + void glMinmaxEXT (GLenum target, GLenum internalformat, GLboolean sink) + void glResetHistogramEXT (GLenum target) + void glResetMinmaxEXT (GLenum target) diff --git a/Externals/GLew/auto/extensions/GL_EXT_index_array_formats b/Externals/GLew/auto/extensions/GL_EXT_index_array_formats new file mode 100644 index 0000000000..cc11b98828 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_index_array_formats @@ -0,0 +1,3 @@ +GL_EXT_index_array_formats +http://www.opengl.org/registry/specs/EXT/index_array_formats.txt +GL_EXT_index_array_formats diff --git a/Externals/GLew/auto/extensions/GL_EXT_index_func b/Externals/GLew/auto/extensions/GL_EXT_index_func new file mode 100644 index 0000000000..8431c5a849 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_index_func @@ -0,0 +1,4 @@ +GL_EXT_index_func +http://www.opengl.org/registry/specs/EXT/index_func.txt +GL_EXT_index_func + void glIndexFuncEXT (GLenum func, GLfloat ref) diff --git a/Externals/GLew/auto/extensions/GL_EXT_index_material b/Externals/GLew/auto/extensions/GL_EXT_index_material new file mode 100644 index 0000000000..7bb43d6d14 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_index_material @@ -0,0 +1,4 @@ +GL_EXT_index_material +http://www.opengl.org/registry/specs/EXT/index_material.txt +GL_EXT_index_material + void glIndexMaterialEXT (GLenum face, GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_EXT_index_texture b/Externals/GLew/auto/extensions/GL_EXT_index_texture new file mode 100644 index 0000000000..c4ee051842 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_index_texture @@ -0,0 +1,3 @@ +GL_EXT_index_texture +http://www.opengl.org/registry/specs/EXT/index_texture.txt +GL_EXT_index_texture diff --git a/Externals/GLew/auto/extensions/GL_EXT_light_texture b/Externals/GLew/auto/extensions/GL_EXT_light_texture new file mode 100644 index 0000000000..d18049c5af --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_light_texture @@ -0,0 +1,16 @@ +GL_EXT_light_texture +http://www.opengl.org/registry/specs/EXT/light_texture.txt +GL_EXT_light_texture + GL_FRAGMENT_MATERIAL_EXT 0x8349 + GL_FRAGMENT_NORMAL_EXT 0x834A + GL_FRAGMENT_COLOR_EXT 0x834C + GL_ATTENUATION_EXT 0x834D + GL_SHADOW_ATTENUATION_EXT 0x834E + GL_TEXTURE_APPLICATION_MODE_EXT 0x834F + GL_TEXTURE_LIGHT_EXT 0x8350 + GL_TEXTURE_MATERIAL_FACE_EXT 0x8351 + GL_TEXTURE_MATERIAL_PARAMETER_EXT 0x8352 + GL_FRAGMENT_DEPTH_EXT 0x8452 + void glApplyTextureEXT (GLenum mode) + void glTextureLightEXT (GLenum pname) + void glTextureMaterialEXT (GLenum face, GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_EXT_misc_attribute b/Externals/GLew/auto/extensions/GL_EXT_misc_attribute new file mode 100644 index 0000000000..ad4cee0223 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_misc_attribute @@ -0,0 +1,3 @@ +GL_EXT_misc_attribute +http://www.opengl.org/registry/specs/EXT/misc_attribute.txt +GL_EXT_misc_attribute diff --git a/Externals/GLew/auto/extensions/GL_EXT_multi_draw_arrays b/Externals/GLew/auto/extensions/GL_EXT_multi_draw_arrays new file mode 100644 index 0000000000..cf03e22217 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_multi_draw_arrays @@ -0,0 +1,5 @@ +GL_EXT_multi_draw_arrays +http://www.opengl.org/registry/specs/EXT/multi_draw_arrays.txt +GL_EXT_multi_draw_arrays + void glMultiDrawArraysEXT (GLenum mode, GLint* first, GLsizei *count, GLsizei primcount) + void glMultiDrawElementsEXT (GLenum mode, GLsizei* count, GLenum type, const GLvoid **indices, GLsizei primcount) diff --git a/Externals/GLew/auto/extensions/GL_EXT_multisample b/Externals/GLew/auto/extensions/GL_EXT_multisample new file mode 100644 index 0000000000..bdb1e164e2 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_multisample @@ -0,0 +1,22 @@ +GL_EXT_multisample +http://www.opengl.org/registry/specs/EXT/wgl_multisample.txt +GL_EXT_multisample + GL_MULTISAMPLE_EXT 0x809D + GL_SAMPLE_ALPHA_TO_MASK_EXT 0x809E + GL_SAMPLE_ALPHA_TO_ONE_EXT 0x809F + GL_SAMPLE_MASK_EXT 0x80A0 + GL_1PASS_EXT 0x80A1 + GL_2PASS_0_EXT 0x80A2 + GL_2PASS_1_EXT 0x80A3 + GL_4PASS_0_EXT 0x80A4 + GL_4PASS_1_EXT 0x80A5 + GL_4PASS_2_EXT 0x80A6 + GL_4PASS_3_EXT 0x80A7 + GL_SAMPLE_BUFFERS_EXT 0x80A8 + GL_SAMPLES_EXT 0x80A9 + GL_SAMPLE_MASK_VALUE_EXT 0x80AA + GL_SAMPLE_MASK_INVERT_EXT 0x80AB + GL_SAMPLE_PATTERN_EXT 0x80AC + GL_MULTISAMPLE_BIT_EXT 0x20000000 + void glSampleMaskEXT (GLclampf value, GLboolean invert) + void glSamplePatternEXT (GLenum pattern) diff --git a/Externals/GLew/auto/extensions/GL_EXT_packed_depth_stencil b/Externals/GLew/auto/extensions/GL_EXT_packed_depth_stencil new file mode 100644 index 0000000000..44a711cc99 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_packed_depth_stencil @@ -0,0 +1,7 @@ +GL_EXT_packed_depth_stencil +http://www.opengl.org/registry/specs/EXT/packed_depth_stencil.txt +GL_EXT_packed_depth_stencil + GL_DEPTH_STENCIL_EXT 0x84F9 + GL_UNSIGNED_INT_24_8_EXT 0x84FA + GL_DEPTH24_STENCIL8_EXT 0x88F0 + GL_TEXTURE_STENCIL_SIZE_EXT 0x88F1 diff --git a/Externals/GLew/auto/extensions/GL_EXT_packed_float b/Externals/GLew/auto/extensions/GL_EXT_packed_float new file mode 100644 index 0000000000..bcb22557d6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_packed_float @@ -0,0 +1,6 @@ +GL_EXT_packed_float +http://developer.download.nvidia.com/opengl/specs/GL_EXT_packed_float.txt +GL_EXT_packed_float + GL_R11F_G11F_B10F_EXT 0x8C3A + GL_UNSIGNED_INT_10F_11F_11F_REV_EXT 0x8C3B + GL_RGBA_SIGNED_COMPONENTS_EXT 0x8C3C diff --git a/Externals/GLew/auto/extensions/GL_EXT_packed_pixels b/Externals/GLew/auto/extensions/GL_EXT_packed_pixels new file mode 100644 index 0000000000..ba47d59846 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_packed_pixels @@ -0,0 +1,8 @@ +GL_EXT_packed_pixels +http://www.opengl.org/registry/specs/EXT/packed_pixels.txt +GL_EXT_packed_pixels + GL_UNSIGNED_BYTE_3_3_2_EXT 0x8032 + GL_UNSIGNED_SHORT_4_4_4_4_EXT 0x8033 + GL_UNSIGNED_SHORT_5_5_5_1_EXT 0x8034 + GL_UNSIGNED_INT_8_8_8_8_EXT 0x8035 + GL_UNSIGNED_INT_10_10_10_2_EXT 0x8036 diff --git a/Externals/GLew/auto/extensions/GL_EXT_paletted_texture b/Externals/GLew/auto/extensions/GL_EXT_paletted_texture new file mode 100644 index 0000000000..6830acc449 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_paletted_texture @@ -0,0 +1,30 @@ +GL_EXT_paletted_texture +http://www.opengl.org/registry/specs/EXT/paletted_texture.txt +GL_EXT_paletted_texture + GL_TEXTURE_1D 0x0DE0 + GL_TEXTURE_2D 0x0DE1 + GL_PROXY_TEXTURE_1D 0x8063 + GL_PROXY_TEXTURE_2D 0x8064 + GL_TEXTURE_3D_EXT 0x806F + GL_PROXY_TEXTURE_3D_EXT 0x8070 + GL_COLOR_TABLE_FORMAT_EXT 0x80D8 + GL_COLOR_TABLE_WIDTH_EXT 0x80D9 + GL_COLOR_TABLE_RED_SIZE_EXT 0x80DA + GL_COLOR_TABLE_GREEN_SIZE_EXT 0x80DB + GL_COLOR_TABLE_BLUE_SIZE_EXT 0x80DC + GL_COLOR_TABLE_ALPHA_SIZE_EXT 0x80DD + GL_COLOR_TABLE_LUMINANCE_SIZE_EXT 0x80DE + GL_COLOR_TABLE_INTENSITY_SIZE_EXT 0x80DF + GL_COLOR_INDEX1_EXT 0x80E2 + GL_COLOR_INDEX2_EXT 0x80E3 + GL_COLOR_INDEX4_EXT 0x80E4 + GL_COLOR_INDEX8_EXT 0x80E5 + GL_COLOR_INDEX12_EXT 0x80E6 + GL_COLOR_INDEX16_EXT 0x80E7 + GL_TEXTURE_INDEX_SIZE_EXT 0x80ED + GL_TEXTURE_CUBE_MAP_ARB 0x8513 + GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B + void glColorTableEXT (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const void* data) + void glGetColorTableEXT (GLenum target, GLenum format, GLenum type, void* data) + void glGetColorTableParameterfvEXT (GLenum target, GLenum pname, GLfloat* params) + void glGetColorTableParameterivEXT (GLenum target, GLenum pname, GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_EXT_pixel_buffer_object b/Externals/GLew/auto/extensions/GL_EXT_pixel_buffer_object new file mode 100644 index 0000000000..a7f8f2c80e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_pixel_buffer_object @@ -0,0 +1,7 @@ +GL_EXT_pixel_buffer_object +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_pixel_buffer_object.txt +GL_EXT_pixel_buffer_object + GL_PIXEL_PACK_BUFFER_EXT 0x88EB + GL_PIXEL_UNPACK_BUFFER_EXT 0x88EC + GL_PIXEL_PACK_BUFFER_BINDING_EXT 0x88ED + GL_PIXEL_UNPACK_BUFFER_BINDING_EXT 0x88EF diff --git a/Externals/GLew/auto/extensions/GL_EXT_pixel_transform b/Externals/GLew/auto/extensions/GL_EXT_pixel_transform new file mode 100644 index 0000000000..30fdbfbbd0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_pixel_transform @@ -0,0 +1,18 @@ +GL_EXT_pixel_transform +http://www.opengl.org/registry/specs/EXT/pixel_transform.txt +GL_EXT_pixel_transform + GL_PIXEL_TRANSFORM_2D_EXT 0x8330 + GL_PIXEL_MAG_FILTER_EXT 0x8331 + GL_PIXEL_MIN_FILTER_EXT 0x8332 + GL_PIXEL_CUBIC_WEIGHT_EXT 0x8333 + GL_CUBIC_EXT 0x8334 + GL_AVERAGE_EXT 0x8335 + GL_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8336 + GL_MAX_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8337 + GL_PIXEL_TRANSFORM_2D_MATRIX_EXT 0x8338 + void glGetPixelTransformParameterfvEXT (GLenum target, GLenum pname, const GLfloat* params) + void glGetPixelTransformParameterivEXT (GLenum target, GLenum pname, const GLint* params) + void glPixelTransformParameterfEXT (GLenum target, GLenum pname, const GLfloat param) + void glPixelTransformParameterfvEXT (GLenum target, GLenum pname, const GLfloat* params) + void glPixelTransformParameteriEXT (GLenum target, GLenum pname, const GLint param) + void glPixelTransformParameterivEXT (GLenum target, GLenum pname, const GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_EXT_pixel_transform_color_table b/Externals/GLew/auto/extensions/GL_EXT_pixel_transform_color_table new file mode 100644 index 0000000000..c53b731f92 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_pixel_transform_color_table @@ -0,0 +1,3 @@ +GL_EXT_pixel_transform_color_table +http://www.opengl.org/registry/specs/EXT/pixel_transform_color_table.txt +GL_EXT_pixel_transform_color_table diff --git a/Externals/GLew/auto/extensions/GL_EXT_point_parameters b/Externals/GLew/auto/extensions/GL_EXT_point_parameters new file mode 100644 index 0000000000..31285984de --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_point_parameters @@ -0,0 +1,9 @@ +GL_EXT_point_parameters +http://www.opengl.org/registry/specs/EXT/point_parameters.txt +GL_EXT_point_parameters + GL_POINT_SIZE_MIN_EXT 0x8126 + GL_POINT_SIZE_MAX_EXT 0x8127 + GL_POINT_FADE_THRESHOLD_SIZE_EXT 0x8128 + GL_DISTANCE_ATTENUATION_EXT 0x8129 + void glPointParameterfEXT (GLenum pname, GLfloat param) + void glPointParameterfvEXT (GLenum pname, GLfloat* params) diff --git a/Externals/GLew/auto/extensions/GL_EXT_polygon_offset b/Externals/GLew/auto/extensions/GL_EXT_polygon_offset new file mode 100644 index 0000000000..66d81eba77 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_polygon_offset @@ -0,0 +1,7 @@ +GL_EXT_polygon_offset +http://www.opengl.org/registry/specs/EXT/polygon_offset.txt +GL_EXT_polygon_offset + GL_POLYGON_OFFSET_EXT 0x8037 + GL_POLYGON_OFFSET_FACTOR_EXT 0x8038 + GL_POLYGON_OFFSET_BIAS_EXT 0x8039 + void glPolygonOffsetEXT (GLfloat factor, GLfloat bias) diff --git a/Externals/GLew/auto/extensions/GL_EXT_provoking_vertex b/Externals/GLew/auto/extensions/GL_EXT_provoking_vertex new file mode 100644 index 0000000000..8512a050e1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_provoking_vertex @@ -0,0 +1,8 @@ +GL_EXT_provoking_vertex +http://www.opengl.org/registry/specs/EXT/provoking_vertex.txt +GL_EXT_provoking_vertex + GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION_EXT 0x8E4C + GL_FIRST_VERTEX_CONVENTION_EXT 0x8E4D + GL_LAST_VERTEX_CONVENTION_EXT 0x8E4E + GL_PROVOKING_VERTEX_EXT 0x8E4F + void glProvokingVertexEXT (GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_EXT_rescale_normal b/Externals/GLew/auto/extensions/GL_EXT_rescale_normal new file mode 100644 index 0000000000..d87b45dead --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_rescale_normal @@ -0,0 +1,4 @@ +GL_EXT_rescale_normal +http://www.opengl.org/registry/specs/EXT/rescale_normal.txt +GL_EXT_rescale_normal + GL_RESCALE_NORMAL_EXT 0x803A diff --git a/Externals/GLew/auto/extensions/GL_EXT_scene_marker b/Externals/GLew/auto/extensions/GL_EXT_scene_marker new file mode 100644 index 0000000000..0ac00930f2 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_scene_marker @@ -0,0 +1,5 @@ +GL_EXT_scene_marker +http://www.opengl.org/registry/specs/EXT/scene_marker.txt +GL_EXT_scene_marker + void glBeginSceneEXT (void) + void glEndSceneEXT (void) diff --git a/Externals/GLew/auto/extensions/GL_EXT_secondary_color b/Externals/GLew/auto/extensions/GL_EXT_secondary_color new file mode 100644 index 0000000000..490dc64320 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_secondary_color @@ -0,0 +1,27 @@ +GL_EXT_secondary_color +http://oss.sgi.com/projects/ogl-sample/registry/EXT/secondary_color.txt +GL_EXT_secondary_color + GL_COLOR_SUM_EXT 0x8458 + GL_CURRENT_SECONDARY_COLOR_EXT 0x8459 + GL_SECONDARY_COLOR_ARRAY_SIZE_EXT 0x845A + GL_SECONDARY_COLOR_ARRAY_TYPE_EXT 0x845B + GL_SECONDARY_COLOR_ARRAY_STRIDE_EXT 0x845C + GL_SECONDARY_COLOR_ARRAY_POINTER_EXT 0x845D + GL_SECONDARY_COLOR_ARRAY_EXT 0x845E + void glSecondaryColor3bEXT (GLbyte red, GLbyte green, GLbyte blue) + void glSecondaryColor3bvEXT (const GLbyte *v) + void glSecondaryColor3dEXT (GLdouble red, GLdouble green, GLdouble blue) + void glSecondaryColor3dvEXT (const GLdouble *v) + void glSecondaryColor3fEXT (GLfloat red, GLfloat green, GLfloat blue) + void glSecondaryColor3fvEXT (const GLfloat *v) + void glSecondaryColor3iEXT (GLint red, GLint green, GLint blue) + void glSecondaryColor3ivEXT (const GLint *v) + void glSecondaryColor3sEXT (GLshort red, GLshort green, GLshort blue) + void glSecondaryColor3svEXT (const GLshort *v) + void glSecondaryColor3ubEXT (GLubyte red, GLubyte green, GLubyte blue) + void glSecondaryColor3ubvEXT (const GLubyte *v) + void glSecondaryColor3uiEXT (GLuint red, GLuint green, GLuint blue) + void glSecondaryColor3uivEXT (const GLuint *v) + void glSecondaryColor3usEXT (GLushort red, GLushort green, GLushort blue) + void glSecondaryColor3usvEXT (const GLushort *v) + void glSecondaryColorPointerEXT (GLint size, GLenum type, GLsizei stride, GLvoid *pointer) diff --git a/Externals/GLew/auto/extensions/GL_EXT_separate_shader_objects b/Externals/GLew/auto/extensions/GL_EXT_separate_shader_objects new file mode 100644 index 0000000000..f0bc8d151c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_separate_shader_objects @@ -0,0 +1,7 @@ +GL_EXT_separate_shader_objects +http://www.opengl.org/registry/specs/EXT/separate_shader_objects.txt +GL_EXT_separate_shader_objects + GL_ACTIVE_PROGRAM_EXT 0x8B8D + void glActiveProgramEXT (GLuint program) + GLuint glCreateShaderProgramEXT (GLenum type, const char* string) + void glUseShaderProgramEXT (GLenum type, GLuint program) diff --git a/Externals/GLew/auto/extensions/GL_EXT_separate_specular_color b/Externals/GLew/auto/extensions/GL_EXT_separate_specular_color new file mode 100644 index 0000000000..4b717689a4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_separate_specular_color @@ -0,0 +1,6 @@ +GL_EXT_separate_specular_color +http://www.opengl.org/registry/specs/EXT/separate_specular_color.txt +GL_EXT_separate_specular_color + GL_LIGHT_MODEL_COLOR_CONTROL_EXT 0x81F8 + GL_SINGLE_COLOR_EXT 0x81F9 + GL_SEPARATE_SPECULAR_COLOR_EXT 0x81FA diff --git a/Externals/GLew/auto/extensions/GL_EXT_shader_image_load_store b/Externals/GLew/auto/extensions/GL_EXT_shader_image_load_store new file mode 100644 index 0000000000..a6845b49de --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_shader_image_load_store @@ -0,0 +1,60 @@ +GL_EXT_shader_image_load_store +http://www.opengl.org/registry/specs/EXT/shader_image_load_store.txt +GL_EXT_shader_image_load_store + GL_VERTEX_ATTRIB_ARRAY_BARRIER_BIT_EXT 0x00000001 + GL_ELEMENT_ARRAY_BARRIER_BIT_EXT 0x00000002 + GL_UNIFORM_BARRIER_BIT_EXT 0x00000004 + GL_TEXTURE_FETCH_BARRIER_BIT_EXT 0x00000008 + GL_SHADER_IMAGE_ACCESS_BARRIER_BIT_EXT 0x00000020 + GL_COMMAND_BARRIER_BIT_EXT 0x00000040 + GL_PIXEL_BUFFER_BARRIER_BIT_EXT 0x00000080 + GL_TEXTURE_UPDATE_BARRIER_BIT_EXT 0x00000100 + GL_BUFFER_UPDATE_BARRIER_BIT_EXT 0x00000200 + GL_FRAMEBUFFER_BARRIER_BIT_EXT 0x00000400 + GL_TRANSFORM_FEEDBACK_BARRIER_BIT_EXT 0x00000800 + GL_ATOMIC_COUNTER_BARRIER_BIT_EXT 0x00001000 + GL_MAX_IMAGE_UNITS_EXT 0x8F38 + GL_MAX_COMBINED_IMAGE_UNITS_AND_FRAGMENT_OUTPUTS_EXT 0x8F39 + GL_IMAGE_BINDING_NAME_EXT 0x8F3A + GL_IMAGE_BINDING_LEVEL_EXT 0x8F3B + GL_IMAGE_BINDING_LAYERED_EXT 0x8F3C + GL_IMAGE_BINDING_LAYER_EXT 0x8F3D + GL_IMAGE_BINDING_ACCESS_EXT 0x8F3E + GL_IMAGE_1D_EXT 0x904C + GL_IMAGE_2D_EXT 0x904D + GL_IMAGE_3D_EXT 0x904E + GL_IMAGE_2D_RECT_EXT 0x904F + GL_IMAGE_CUBE_EXT 0x9050 + GL_IMAGE_BUFFER_EXT 0x9051 + GL_IMAGE_1D_ARRAY_EXT 0x9052 + GL_IMAGE_2D_ARRAY_EXT 0x9053 + GL_IMAGE_CUBE_MAP_ARRAY_EXT 0x9054 + GL_IMAGE_2D_MULTISAMPLE_EXT 0x9055 + GL_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9056 + GL_INT_IMAGE_1D_EXT 0x9057 + GL_INT_IMAGE_2D_EXT 0x9058 + GL_INT_IMAGE_3D_EXT 0x9059 + GL_INT_IMAGE_2D_RECT_EXT 0x905A + GL_INT_IMAGE_CUBE_EXT 0x905B + GL_INT_IMAGE_BUFFER_EXT 0x905C + GL_INT_IMAGE_1D_ARRAY_EXT 0x905D + GL_INT_IMAGE_2D_ARRAY_EXT 0x905E + GL_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x905F + GL_INT_IMAGE_2D_MULTISAMPLE_EXT 0x9060 + GL_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9061 + GL_UNSIGNED_INT_IMAGE_1D_EXT 0x9062 + GL_UNSIGNED_INT_IMAGE_2D_EXT 0x9063 + GL_UNSIGNED_INT_IMAGE_3D_EXT 0x9064 + GL_UNSIGNED_INT_IMAGE_2D_RECT_EXT 0x9065 + GL_UNSIGNED_INT_IMAGE_CUBE_EXT 0x9066 + GL_UNSIGNED_INT_IMAGE_BUFFER_EXT 0x9067 + GL_UNSIGNED_INT_IMAGE_1D_ARRAY_EXT 0x9068 + GL_UNSIGNED_INT_IMAGE_2D_ARRAY_EXT 0x9069 + GL_UNSIGNED_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x906A + GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_EXT 0x906B + GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x906C + GL_MAX_IMAGE_SAMPLES_EXT 0x906D + GL_IMAGE_BINDING_FORMAT_EXT 0x906E + GL_ALL_BARRIER_BITS_EXT 0xFFFFFFFF + void glBindImageTextureEXT (GLuint index, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLint format) + void glMemoryBarrierEXT (GLbitfield barriers) diff --git a/Externals/GLew/auto/extensions/GL_EXT_shadow_funcs b/Externals/GLew/auto/extensions/GL_EXT_shadow_funcs new file mode 100644 index 0000000000..d92a7c4be1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_shadow_funcs @@ -0,0 +1,3 @@ +GL_EXT_shadow_funcs +http://www.opengl.org/registry/specs/EXT/shadow_funcs.txt +GL_EXT_shadow_funcs diff --git a/Externals/GLew/auto/extensions/GL_EXT_shared_texture_palette b/Externals/GLew/auto/extensions/GL_EXT_shared_texture_palette new file mode 100644 index 0000000000..7ca0875aa6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_shared_texture_palette @@ -0,0 +1,4 @@ +GL_EXT_shared_texture_palette +http://www.opengl.org/registry/specs/EXT/shared_texture_palette.txt +GL_EXT_shared_texture_palette + GL_SHARED_TEXTURE_PALETTE_EXT 0x81FB diff --git a/Externals/GLew/auto/extensions/GL_EXT_stencil_clear_tag b/Externals/GLew/auto/extensions/GL_EXT_stencil_clear_tag new file mode 100644 index 0000000000..a117d0e220 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_stencil_clear_tag @@ -0,0 +1,5 @@ +GL_EXT_stencil_clear_tag +http://www.opengl.org/registry/specs/EXT/stencil_clear_tag.txt +GL_EXT_stencil_clear_tag + GL_STENCIL_TAG_BITS_EXT 0x88F2 + GL_STENCIL_CLEAR_TAG_VALUE_EXT 0x88F3 diff --git a/Externals/GLew/auto/extensions/GL_EXT_stencil_two_side b/Externals/GLew/auto/extensions/GL_EXT_stencil_two_side new file mode 100644 index 0000000000..4145dc81df --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_stencil_two_side @@ -0,0 +1,6 @@ +GL_EXT_stencil_two_side +http://www.opengl.org/registry/specs/EXT/stencil_two_side.txt +GL_EXT_stencil_two_side + GL_STENCIL_TEST_TWO_SIDE_EXT 0x8910 + GL_ACTIVE_STENCIL_FACE_EXT 0x8911 + void glActiveStencilFaceEXT (GLenum face) diff --git a/Externals/GLew/auto/extensions/GL_EXT_stencil_wrap b/Externals/GLew/auto/extensions/GL_EXT_stencil_wrap new file mode 100644 index 0000000000..b9ee8ebb12 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_stencil_wrap @@ -0,0 +1,5 @@ +GL_EXT_stencil_wrap +http://www.opengl.org/registry/specs/EXT/stencil_wrap.txt +GL_EXT_stencil_wrap + GL_INCR_WRAP_EXT 0x8507 + GL_DECR_WRAP_EXT 0x8508 diff --git a/Externals/GLew/auto/extensions/GL_EXT_subtexture b/Externals/GLew/auto/extensions/GL_EXT_subtexture new file mode 100644 index 0000000000..1592146387 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_subtexture @@ -0,0 +1,6 @@ +GL_EXT_subtexture +http://www.opengl.org/registry/specs/EXT/subtexture.txt +GL_EXT_subtexture + void glTexSubImage1DEXT (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels) + void glTexSubImage2DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels) + void glTexSubImage3DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels) diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture b/Externals/GLew/auto/extensions/GL_EXT_texture new file mode 100644 index 0000000000..5e78f29d06 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture @@ -0,0 +1,45 @@ +GL_EXT_texture +http://www.opengl.org/registry/specs/EXT/texture.txt +GL_EXT_texture + GL_ALPHA4_EXT 0x803B + GL_ALPHA8_EXT 0x803C + GL_ALPHA12_EXT 0x803D + GL_ALPHA16_EXT 0x803E + GL_LUMINANCE4_EXT 0x803F + GL_LUMINANCE8_EXT 0x8040 + GL_LUMINANCE12_EXT 0x8041 + GL_LUMINANCE16_EXT 0x8042 + GL_LUMINANCE4_ALPHA4_EXT 0x8043 + GL_LUMINANCE6_ALPHA2_EXT 0x8044 + GL_LUMINANCE8_ALPHA8_EXT 0x8045 + GL_LUMINANCE12_ALPHA4_EXT 0x8046 + GL_LUMINANCE12_ALPHA12_EXT 0x8047 + GL_LUMINANCE16_ALPHA16_EXT 0x8048 + GL_INTENSITY_EXT 0x8049 + GL_INTENSITY4_EXT 0x804A + GL_INTENSITY8_EXT 0x804B + GL_INTENSITY12_EXT 0x804C + GL_INTENSITY16_EXT 0x804D + GL_RGB2_EXT 0x804E + GL_RGB4_EXT 0x804F + GL_RGB5_EXT 0x8050 + GL_RGB8_EXT 0x8051 + GL_RGB10_EXT 0x8052 + GL_RGB12_EXT 0x8053 + GL_RGB16_EXT 0x8054 + GL_RGBA2_EXT 0x8055 + GL_RGBA4_EXT 0x8056 + GL_RGB5_A1_EXT 0x8057 + GL_RGBA8_EXT 0x8058 + GL_RGB10_A2_EXT 0x8059 + GL_RGBA12_EXT 0x805A + GL_RGBA16_EXT 0x805B + GL_TEXTURE_RED_SIZE_EXT 0x805C + GL_TEXTURE_GREEN_SIZE_EXT 0x805D + GL_TEXTURE_BLUE_SIZE_EXT 0x805E + GL_TEXTURE_ALPHA_SIZE_EXT 0x805F + GL_TEXTURE_LUMINANCE_SIZE_EXT 0x8060 + GL_TEXTURE_INTENSITY_SIZE_EXT 0x8061 + GL_REPLACE_EXT 0x8062 + GL_PROXY_TEXTURE_1D_EXT 0x8063 + GL_PROXY_TEXTURE_2D_EXT 0x8064 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture3D b/Externals/GLew/auto/extensions/GL_EXT_texture3D new file mode 100644 index 0000000000..5f248babb7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture3D @@ -0,0 +1,13 @@ +GL_EXT_texture3D +http://www.opengl.org/registry/specs/EXT/texture3D.txt +GL_EXT_texture3D + GL_PACK_SKIP_IMAGES_EXT 0x806B + GL_PACK_IMAGE_HEIGHT_EXT 0x806C + GL_UNPACK_SKIP_IMAGES_EXT 0x806D + GL_UNPACK_IMAGE_HEIGHT_EXT 0x806E + GL_TEXTURE_3D_EXT 0x806F + GL_PROXY_TEXTURE_3D_EXT 0x8070 + GL_TEXTURE_DEPTH_EXT 0x8071 + GL_TEXTURE_WRAP_R_EXT 0x8072 + GL_MAX_3D_TEXTURE_SIZE_EXT 0x8073 + void glTexImage3DEXT (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels) diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_array b/Externals/GLew/auto/extensions/GL_EXT_texture_array new file mode 100644 index 0000000000..f61e72ebc3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_array @@ -0,0 +1,11 @@ +GL_EXT_texture_array +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_array.txt +GL_EXT_texture_array + GL_TEXTURE_1D_ARRAY_EXT 0x8C18 + GL_PROXY_TEXTURE_1D_ARRAY_EXT 0x8C19 + GL_TEXTURE_2D_ARRAY_EXT 0x8C1A + GL_PROXY_TEXTURE_2D_ARRAY_EXT 0x8C1B + GL_TEXTURE_BINDING_1D_ARRAY_EXT 0x8C1C + GL_TEXTURE_BINDING_2D_ARRAY_EXT 0x8C1D + GL_MAX_ARRAY_TEXTURE_LAYERS_EXT 0x88FF + GL_COMPARE_REF_DEPTH_TO_TEXTURE_EXT 0x884E diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_buffer_object b/Externals/GLew/auto/extensions/GL_EXT_texture_buffer_object new file mode 100644 index 0000000000..c00e1f3367 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_buffer_object @@ -0,0 +1,9 @@ +GL_EXT_texture_buffer_object +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_buffer_object.txt +GL_EXT_texture_buffer_object + GL_TEXTURE_BUFFER_EXT 0x8C2A + GL_MAX_TEXTURE_BUFFER_SIZE_EXT 0x8C2B + GL_TEXTURE_BINDING_BUFFER_EXT 0x8C2C + GL_TEXTURE_BUFFER_DATA_STORE_BINDING_EXT 0x8C2D + GL_TEXTURE_BUFFER_FORMAT_EXT 0x8C2E + void glTexBufferEXT (GLenum target, GLenum internalformat, GLuint buffer) diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_compression_dxt1 b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_dxt1 new file mode 100644 index 0000000000..4e31f3d2b4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_dxt1 @@ -0,0 +1,5 @@ +GL_EXT_texture_compression_dxt1 +http://www.opengl.org/registry/specs/EXT/texture_compression_dxt1.txt +GL_EXT_texture_compression_dxt1 + GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 + GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_compression_latc b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_latc new file mode 100644 index 0000000000..ddf8d26449 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_latc @@ -0,0 +1,7 @@ +GL_EXT_texture_compression_latc +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_compression_latc.txt +GL_EXT_texture_compression_latc + GL_COMPRESSED_LUMINANCE_LATC1_EXT 0x8C70 + GL_COMPRESSED_SIGNED_LUMINANCE_LATC1_EXT 0x8C71 + GL_COMPRESSED_LUMINANCE_ALPHA_LATC2_EXT 0x8C72 + GL_COMPRESSED_SIGNED_LUMINANCE_ALPHA_LATC2_EXT 0x8C73 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_compression_rgtc b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_rgtc new file mode 100644 index 0000000000..7c5c57ff83 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_rgtc @@ -0,0 +1,7 @@ +GL_EXT_texture_compression_rgtc +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_compression_rgtc.txt +GL_EXT_texture_compression_rgtc + GL_COMPRESSED_RED_RGTC1_EXT 0x8DBB + GL_COMPRESSED_SIGNED_RED_RGTC1_EXT 0x8DBC + GL_COMPRESSED_RED_GREEN_RGTC2_EXT 0x8DBD + GL_COMPRESSED_SIGNED_RED_GREEN_RGTC2_EXT 0x8DBE diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_compression_s3tc b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_s3tc new file mode 100644 index 0000000000..6369ded31a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_compression_s3tc @@ -0,0 +1,7 @@ +GL_EXT_texture_compression_s3tc +http://www.opengl.org/registry/specs/EXT/texture_compression_s3tc.txt +GL_EXT_texture_compression_s3tc + GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 + GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 + GL_COMPRESSED_RGBA_S3TC_DXT3_EXT 0x83F2 + GL_COMPRESSED_RGBA_S3TC_DXT5_EXT 0x83F3 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_cube_map b/Externals/GLew/auto/extensions/GL_EXT_texture_cube_map new file mode 100644 index 0000000000..5909f4803c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_cube_map @@ -0,0 +1,15 @@ +GL_EXT_texture_cube_map +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_texture_cube_map.txt +GL_EXT_texture_cube_map + GL_NORMAL_MAP_EXT 0x8511 + GL_REFLECTION_MAP_EXT 0x8512 + GL_TEXTURE_CUBE_MAP_EXT 0x8513 + GL_TEXTURE_BINDING_CUBE_MAP_EXT 0x8514 + GL_TEXTURE_CUBE_MAP_POSITIVE_X_EXT 0x8515 + GL_TEXTURE_CUBE_MAP_NEGATIVE_X_EXT 0x8516 + GL_TEXTURE_CUBE_MAP_POSITIVE_Y_EXT 0x8517 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_EXT 0x8518 + GL_TEXTURE_CUBE_MAP_POSITIVE_Z_EXT 0x8519 + GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_EXT 0x851A + GL_PROXY_TEXTURE_CUBE_MAP_EXT 0x851B + GL_MAX_CUBE_MAP_TEXTURE_SIZE_EXT 0x851C diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_edge_clamp b/Externals/GLew/auto/extensions/GL_EXT_texture_edge_clamp new file mode 100644 index 0000000000..4df0997d74 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_edge_clamp @@ -0,0 +1,4 @@ +GL_EXT_texture_edge_clamp +http://www.opengl.org/developers/documentation/Version1.2/1.2specs/texture_edge_clamp.txt +GL_EXT_texture_edge_clamp + GL_CLAMP_TO_EDGE_EXT 0x812F diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_env b/Externals/GLew/auto/extensions/GL_EXT_texture_env new file mode 100644 index 0000000000..73017c252f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_env @@ -0,0 +1,14 @@ +GL_EXT_texture_env +http://www.opengl.org/registry/specs/EXT/texture_env.txt +GL_EXT_texture_env + GL_TEXTURE_ENV0_EXT 0 + GL_TEXTURE_ENV_SHIFT_EXT 0 + GL_ENV_BLEND_EXT 0 + GL_ENV_ADD_EXT 0 + GL_ENV_REPLACE_EXT 0 + GL_ENV_SUBTRACT_EXT 0 + GL_TEXTURE_ENV_MODE_ALPHA_EXT 0 + GL_ENV_REVERSE_BLEND_EXT 0 + GL_ENV_REVERSE_SUBTRACT_EXT 0 + GL_ENV_COPY_EXT 0 + GL_ENV_MODULATE_EXT 0 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_env_add b/Externals/GLew/auto/extensions/GL_EXT_texture_env_add new file mode 100644 index 0000000000..11eead636f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_env_add @@ -0,0 +1,3 @@ +GL_EXT_texture_env_add +http://www.opengl.org/registry/specs/EXT/texture_env_add.txt +GL_EXT_texture_env_add diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_env_combine b/Externals/GLew/auto/extensions/GL_EXT_texture_env_combine new file mode 100644 index 0000000000..dda88914cc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_env_combine @@ -0,0 +1,24 @@ +GL_EXT_texture_env_combine +http://www.opengl.org/registry/specs/EXT/texture_env_combine.txt +GL_EXT_texture_env_combine + GL_COMBINE_EXT 0x8570 + GL_COMBINE_RGB_EXT 0x8571 + GL_COMBINE_ALPHA_EXT 0x8572 + GL_RGB_SCALE_EXT 0x8573 + GL_ADD_SIGNED_EXT 0x8574 + GL_INTERPOLATE_EXT 0x8575 + GL_CONSTANT_EXT 0x8576 + GL_PRIMARY_COLOR_EXT 0x8577 + GL_PREVIOUS_EXT 0x8578 + GL_SOURCE0_RGB_EXT 0x8580 + GL_SOURCE1_RGB_EXT 0x8581 + GL_SOURCE2_RGB_EXT 0x8582 + GL_SOURCE0_ALPHA_EXT 0x8588 + GL_SOURCE1_ALPHA_EXT 0x8589 + GL_SOURCE2_ALPHA_EXT 0x858A + GL_OPERAND0_RGB_EXT 0x8590 + GL_OPERAND1_RGB_EXT 0x8591 + GL_OPERAND2_RGB_EXT 0x8592 + GL_OPERAND0_ALPHA_EXT 0x8598 + GL_OPERAND1_ALPHA_EXT 0x8599 + GL_OPERAND2_ALPHA_EXT 0x859A diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_env_dot3 b/Externals/GLew/auto/extensions/GL_EXT_texture_env_dot3 new file mode 100644 index 0000000000..3b740d607d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_env_dot3 @@ -0,0 +1,5 @@ +GL_EXT_texture_env_dot3 +http://www.opengl.org/registry/specs/EXT/texture_env_dot3.txt +GL_EXT_texture_env_dot3 + GL_DOT3_RGB_EXT 0x8740 + GL_DOT3_RGBA_EXT 0x8741 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_filter_anisotropic b/Externals/GLew/auto/extensions/GL_EXT_texture_filter_anisotropic new file mode 100644 index 0000000000..1e4d780c2b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_filter_anisotropic @@ -0,0 +1,5 @@ +GL_EXT_texture_filter_anisotropic +http://www.opengl.org/registry/specs/EXT/texture_filter_anisotropic.txt +GL_EXT_texture_filter_anisotropic + GL_TEXTURE_MAX_ANISOTROPY_EXT 0x84FE + GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT 0x84FF diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_integer b/Externals/GLew/auto/extensions/GL_EXT_texture_integer new file mode 100644 index 0000000000..1c57e40d87 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_integer @@ -0,0 +1,56 @@ +GL_EXT_texture_integer +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_integer.txt +GL_EXT_texture_integer + GL_RGBA32UI_EXT 0x8D70 + GL_RGB32UI_EXT 0x8D71 + GL_ALPHA32UI_EXT 0x8D72 + GL_INTENSITY32UI_EXT 0x8D73 + GL_LUMINANCE32UI_EXT 0x8D74 + GL_LUMINANCE_ALPHA32UI_EXT 0x8D75 + GL_RGBA16UI_EXT 0x8D76 + GL_RGB16UI_EXT 0x8D77 + GL_ALPHA16UI_EXT 0x8D78 + GL_INTENSITY16UI_EXT 0x8D79 + GL_LUMINANCE16UI_EXT 0x8D7A + GL_LUMINANCE_ALPHA16UI_EXT 0x8D7B + GL_RGBA8UI_EXT 0x8D7C + GL_RGB8UI_EXT 0x8D7D + GL_ALPHA8UI_EXT 0x8D7E + GL_INTENSITY8UI_EXT 0x8D7F + GL_LUMINANCE8UI_EXT 0x8D80 + GL_LUMINANCE_ALPHA8UI_EXT 0x8D81 + GL_RGBA32I_EXT 0x8D82 + GL_RGB32I_EXT 0x8D83 + GL_ALPHA32I_EXT 0x8D84 + GL_INTENSITY32I_EXT 0x8D85 + GL_LUMINANCE32I_EXT 0x8D86 + GL_LUMINANCE_ALPHA32I_EXT 0x8D87 + GL_RGBA16I_EXT 0x8D88 + GL_RGB16I_EXT 0x8D89 + GL_ALPHA16I_EXT 0x8D8A + GL_INTENSITY16I_EXT 0x8D8B + GL_LUMINANCE16I_EXT 0x8D8C + GL_LUMINANCE_ALPHA16I_EXT 0x8D8D + GL_RGBA8I_EXT 0x8D8E + GL_RGB8I_EXT 0x8D8F + GL_ALPHA8I_EXT 0x8D90 + GL_INTENSITY8I_EXT 0x8D91 + GL_LUMINANCE8I_EXT 0x8D92 + GL_LUMINANCE_ALPHA8I_EXT 0x8D93 + GL_RED_INTEGER_EXT 0x8D94 + GL_GREEN_INTEGER_EXT 0x8D95 + GL_BLUE_INTEGER_EXT 0x8D96 + GL_ALPHA_INTEGER_EXT 0x8D97 + GL_RGB_INTEGER_EXT 0x8D98 + GL_RGBA_INTEGER_EXT 0x8D99 + GL_BGR_INTEGER_EXT 0x8D9A + GL_BGRA_INTEGER_EXT 0x8D9B + GL_LUMINANCE_INTEGER_EXT 0x8D9C + GL_LUMINANCE_ALPHA_INTEGER_EXT 0x8D9D + GL_RGBA_INTEGER_MODE_EXT 0x8D9E + void glTexParameterIivEXT (GLenum target, GLenum pname, const GLint *params) + void glTexParameterIuivEXT (GLenum target, GLenum pname, const GLuint *params) + void glGetTexParameterIivEXT (GLenum target, GLenum pname, GLint *params) + void glGetTexParameterIuivEXT (GLenum target, GLenum pname, GLuint *params) + void glClearColorIiEXT (GLint red, GLint green, GLint blue, GLint alpha) + void glClearColorIuiEXT (GLuint red, GLuint green, GLuint blue, GLuint alpha) diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_lod_bias b/Externals/GLew/auto/extensions/GL_EXT_texture_lod_bias new file mode 100644 index 0000000000..216612688f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_lod_bias @@ -0,0 +1,6 @@ +GL_EXT_texture_lod_bias +http://www.opengl.org/registry/specs/EXT/texture_lod_bias.txt +GL_EXT_texture_lod_bias + GL_MAX_TEXTURE_LOD_BIAS_EXT 0x84FD + GL_TEXTURE_FILTER_CONTROL_EXT 0x8500 + GL_TEXTURE_LOD_BIAS_EXT 0x8501 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_mirror_clamp b/Externals/GLew/auto/extensions/GL_EXT_texture_mirror_clamp new file mode 100644 index 0000000000..6e3471c745 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_mirror_clamp @@ -0,0 +1,6 @@ +GL_EXT_texture_mirror_clamp +http://www.opengl.org/registry/specs/EXT/texture_mirror_clamp.txt +GL_EXT_texture_mirror_clamp + GL_MIRROR_CLAMP_EXT 0x8742 + GL_MIRROR_CLAMP_TO_EDGE_EXT 0x8743 + GL_MIRROR_CLAMP_TO_BORDER_EXT 0x8912 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_object b/Externals/GLew/auto/extensions/GL_EXT_texture_object new file mode 100644 index 0000000000..13d4cde7f8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_object @@ -0,0 +1,14 @@ +GL_EXT_texture_object +http://www.opengl.org/registry/specs/EXT/texture_object.txt +GL_EXT_texture_object + GL_TEXTURE_PRIORITY_EXT 0x8066 + GL_TEXTURE_RESIDENT_EXT 0x8067 + GL_TEXTURE_1D_BINDING_EXT 0x8068 + GL_TEXTURE_2D_BINDING_EXT 0x8069 + GL_TEXTURE_3D_BINDING_EXT 0x806A + GLboolean glAreTexturesResidentEXT (GLsizei n, const GLuint* textures, GLboolean* residences) + void glBindTextureEXT (GLenum target, GLuint texture) + void glDeleteTexturesEXT (GLsizei n, const GLuint* textures) + void glGenTexturesEXT (GLsizei n, GLuint* textures) + GLboolean glIsTextureEXT (GLuint texture) + void glPrioritizeTexturesEXT (GLsizei n, const GLuint* textures, const GLclampf* priorities) diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_perturb_normal b/Externals/GLew/auto/extensions/GL_EXT_texture_perturb_normal new file mode 100644 index 0000000000..b852190472 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_perturb_normal @@ -0,0 +1,6 @@ +GL_EXT_texture_perturb_normal +http://www.opengl.org/registry/specs/EXT/texture_perturb_normal.txt +GL_EXT_texture_perturb_normal + GL_PERTURB_EXT 0x85AE + GL_TEXTURE_NORMAL_EXT 0x85AF + void glTextureNormalEXT (GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_rectangle b/Externals/GLew/auto/extensions/GL_EXT_texture_rectangle new file mode 100644 index 0000000000..4028a9e671 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_rectangle @@ -0,0 +1,7 @@ +GL_EXT_texture_rectangle +http://developer.apple.com/opengl/extensions/ext_texture_rectangle.html +GL_EXT_texture_rectangle + GL_TEXTURE_RECTANGLE_EXT 0x84F5 + GL_TEXTURE_BINDING_RECTANGLE_EXT 0x84F6 + GL_PROXY_TEXTURE_RECTANGLE_EXT 0x84F7 + GL_MAX_RECTANGLE_TEXTURE_SIZE_EXT 0x84F8 diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_sRGB b/Externals/GLew/auto/extensions/GL_EXT_texture_sRGB new file mode 100644 index 0000000000..e38d9a955e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_sRGB @@ -0,0 +1,19 @@ +GL_EXT_texture_sRGB +http://www.opengl.org/registry/specs/EXT/texture_sRGB.txt +GL_EXT_texture_sRGB + GL_SRGB_EXT 0x8C40 + GL_SRGB8_EXT 0x8C41 + GL_SRGB_ALPHA_EXT 0x8C42 + GL_SRGB8_ALPHA8_EXT 0x8C43 + GL_SLUMINANCE_ALPHA_EXT 0x8C44 + GL_SLUMINANCE8_ALPHA8_EXT 0x8C45 + GL_SLUMINANCE_EXT 0x8C46 + GL_SLUMINANCE8_EXT 0x8C47 + GL_COMPRESSED_SRGB_EXT 0x8C48 + GL_COMPRESSED_SRGB_ALPHA_EXT 0x8C49 + GL_COMPRESSED_SLUMINANCE_EXT 0x8C4A + GL_COMPRESSED_SLUMINANCE_ALPHA_EXT 0x8C4B + GL_COMPRESSED_SRGB_S3TC_DXT1_EXT 0x8C4C + GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT 0x8C4D + GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT 0x8C4E + GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT 0x8C4F diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_shared_exponent b/Externals/GLew/auto/extensions/GL_EXT_texture_shared_exponent new file mode 100644 index 0000000000..4ff7efcd35 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_shared_exponent @@ -0,0 +1,6 @@ +GL_EXT_texture_shared_exponent +http://developer.download.nvidia.com/opengl/specs/GL_EXT_texture_shared_exponent.txt +GL_EXT_texture_shared_exponent + GL_RGB9_E5_EXT 0x8C3D + GL_UNSIGNED_INT_5_9_9_9_REV_EXT 0x8C3E + GL_TEXTURE_SHARED_SIZE_EXT 0x8C3F diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_snorm b/Externals/GLew/auto/extensions/GL_EXT_texture_snorm new file mode 100644 index 0000000000..493a8be621 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_snorm @@ -0,0 +1,28 @@ +GL_EXT_texture_snorm +http://www.opengl.org/registry/specs/EXT/texture_snorm.txt +GL_EXT_texture_snorm + GL_RED_SNORM 0x8F90 + GL_RG_SNORM 0x8F91 + GL_RGB_SNORM 0x8F92 + GL_RGBA_SNORM 0x8F93 + GL_R8_SNORM 0x8F94 + GL_RG8_SNORM 0x8F95 + GL_RGB8_SNORM 0x8F96 + GL_RGBA8_SNORM 0x8F97 + GL_R16_SNORM 0x8F98 + GL_RG16_SNORM 0x8F99 + GL_RGB16_SNORM 0x8F9A + GL_RGBA16_SNORM 0x8F9B + GL_SIGNED_NORMALIZED 0x8F9C + GL_ALPHA_SNORM 0x9010 + GL_LUMINANCE_SNORM 0x9011 + GL_LUMINANCE_ALPHA_SNORM 0x9012 + GL_INTENSITY_SNORM 0x9013 + GL_ALPHA8_SNORM 0x9014 + GL_LUMINANCE8_SNORM 0x9015 + GL_LUMINANCE8_ALPHA8_SNORM 0x9016 + GL_INTENSITY8_SNORM 0x9017 + GL_ALPHA16_SNORM 0x9018 + GL_LUMINANCE16_SNORM 0x9019 + GL_LUMINANCE16_ALPHA16_SNORM 0x901A + GL_INTENSITY16_SNORM 0x901B diff --git a/Externals/GLew/auto/extensions/GL_EXT_texture_swizzle b/Externals/GLew/auto/extensions/GL_EXT_texture_swizzle new file mode 100644 index 0000000000..2d2884b0ed --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_texture_swizzle @@ -0,0 +1,8 @@ +GL_EXT_texture_swizzle +http://www.opengl.org/registry/specs/EXT/texture_swizzle.txt +GL_EXT_texture_swizzle + GL_TEXTURE_SWIZZLE_R_EXT 0x8E42 + GL_TEXTURE_SWIZZLE_G_EXT 0x8E43 + GL_TEXTURE_SWIZZLE_B_EXT 0x8E44 + GL_TEXTURE_SWIZZLE_A_EXT 0x8E45 + GL_TEXTURE_SWIZZLE_RGBA_EXT 0x8E46 diff --git a/Externals/GLew/auto/extensions/GL_EXT_timer_query b/Externals/GLew/auto/extensions/GL_EXT_timer_query new file mode 100644 index 0000000000..390e6fc0cd --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_timer_query @@ -0,0 +1,6 @@ +GL_EXT_timer_query +http://www.nvidia.com/dev_content/nvopenglspecs/GL_EXT_timer_query.txt +GL_EXT_timer_query + GL_TIME_ELAPSED_EXT 0x88BF + void glGetQueryObjecti64vEXT (GLuint id, GLenum pname, GLint64EXT *params) + void glGetQueryObjectui64vEXT (GLuint id, GLenum pname, GLuint64EXT *params) diff --git a/Externals/GLew/auto/extensions/GL_EXT_transform_feedback b/Externals/GLew/auto/extensions/GL_EXT_transform_feedback new file mode 100644 index 0000000000..72ae6fd4a3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_transform_feedback @@ -0,0 +1,25 @@ +GL_EXT_transform_feedback +http://www.opengl.org/registry/specs/EXT/transform_feedback.txt +GL_EXT_transform_feedback + GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH_EXT 0x8C76 + GL_TRANSFORM_FEEDBACK_BUFFER_MODE_EXT 0x8C7F + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_EXT 0x8C80 + GL_TRANSFORM_FEEDBACK_VARYINGS_EXT 0x8C83 + GL_TRANSFORM_FEEDBACK_BUFFER_START_EXT 0x8C84 + GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_EXT 0x8C85 + GL_PRIMITIVES_GENERATED_EXT 0x8C87 + GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_EXT 0x8C88 + GL_RASTERIZER_DISCARD_EXT 0x8C89 + GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_EXT 0x8C8A + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_EXT 0x8C8B + GL_INTERLEAVED_ATTRIBS_EXT 0x8C8C + GL_SEPARATE_ATTRIBS_EXT 0x8C8D + GL_TRANSFORM_FEEDBACK_BUFFER_EXT 0x8C8E + GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_EXT 0x8C8F + void glBeginTransformFeedbackEXT (GLenum primitiveMode) + void glBindBufferBaseEXT (GLenum target, GLuint index, GLuint buffer) + void glBindBufferOffsetEXT (GLenum target, GLuint index, GLuint buffer, GLintptr offset) + void glBindBufferRangeEXT (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size) + void glEndTransformFeedbackEXT (void) + void glGetTransformFeedbackVaryingEXT (GLuint program, GLuint index, GLsizei bufSize, GLsizei* length, GLsizei *size, GLenum *type, char *name) + void glTransformFeedbackVaryingsEXT (GLuint program, GLsizei count, const char ** varyings, GLenum bufferMode) diff --git a/Externals/GLew/auto/extensions/GL_EXT_vertex_array b/Externals/GLew/auto/extensions/GL_EXT_vertex_array new file mode 100644 index 0000000000..43bbe30a6c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_vertex_array @@ -0,0 +1,45 @@ +GL_EXT_vertex_array +http://www.opengl.org/registry/specs/EXT/vertex_array.txt +GL_EXT_vertex_array + GL_DOUBLE_EXT 0x140A + GL_VERTEX_ARRAY_EXT 0x8074 + GL_NORMAL_ARRAY_EXT 0x8075 + GL_COLOR_ARRAY_EXT 0x8076 + GL_INDEX_ARRAY_EXT 0x8077 + GL_TEXTURE_COORD_ARRAY_EXT 0x8078 + GL_EDGE_FLAG_ARRAY_EXT 0x8079 + GL_VERTEX_ARRAY_SIZE_EXT 0x807A + GL_VERTEX_ARRAY_TYPE_EXT 0x807B + GL_VERTEX_ARRAY_STRIDE_EXT 0x807C + GL_VERTEX_ARRAY_COUNT_EXT 0x807D + GL_NORMAL_ARRAY_TYPE_EXT 0x807E + GL_NORMAL_ARRAY_STRIDE_EXT 0x807F + GL_NORMAL_ARRAY_COUNT_EXT 0x8080 + GL_COLOR_ARRAY_SIZE_EXT 0x8081 + GL_COLOR_ARRAY_TYPE_EXT 0x8082 + GL_COLOR_ARRAY_STRIDE_EXT 0x8083 + GL_COLOR_ARRAY_COUNT_EXT 0x8084 + GL_INDEX_ARRAY_TYPE_EXT 0x8085 + GL_INDEX_ARRAY_STRIDE_EXT 0x8086 + GL_INDEX_ARRAY_COUNT_EXT 0x8087 + GL_TEXTURE_COORD_ARRAY_SIZE_EXT 0x8088 + GL_TEXTURE_COORD_ARRAY_TYPE_EXT 0x8089 + GL_TEXTURE_COORD_ARRAY_STRIDE_EXT 0x808A + GL_TEXTURE_COORD_ARRAY_COUNT_EXT 0x808B + GL_EDGE_FLAG_ARRAY_STRIDE_EXT 0x808C + GL_EDGE_FLAG_ARRAY_COUNT_EXT 0x808D + GL_VERTEX_ARRAY_POINTER_EXT 0x808E + GL_NORMAL_ARRAY_POINTER_EXT 0x808F + GL_COLOR_ARRAY_POINTER_EXT 0x8090 + GL_INDEX_ARRAY_POINTER_EXT 0x8091 + GL_TEXTURE_COORD_ARRAY_POINTER_EXT 0x8092 + GL_EDGE_FLAG_ARRAY_POINTER_EXT 0x8093 + void glArrayElementEXT (GLint i) + void glColorPointerEXT (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer) + void glDrawArraysEXT (GLenum mode, GLint first, GLsizei count) + void glEdgeFlagPointerEXT (GLsizei stride, GLsizei count, const GLboolean* pointer) + void glGetPointervEXT (GLenum pname, void** params) + void glIndexPointerEXT (GLenum type, GLsizei stride, GLsizei count, const void* pointer) + void glNormalPointerEXT (GLenum type, GLsizei stride, GLsizei count, const void* pointer) + void glTexCoordPointerEXT (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer) + void glVertexPointerEXT (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_EXT_vertex_array_bgra b/Externals/GLew/auto/extensions/GL_EXT_vertex_array_bgra new file mode 100644 index 0000000000..ea2f99bb7e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_vertex_array_bgra @@ -0,0 +1,4 @@ +GL_EXT_vertex_array_bgra +http://www.opengl.org/registry/specs/EXT/vertex_array_bgra.txt +GL_EXT_vertex_array_bgra + GL_BGRA 0x80E1 diff --git a/Externals/GLew/auto/extensions/GL_EXT_vertex_attrib_64bit b/Externals/GLew/auto/extensions/GL_EXT_vertex_attrib_64bit new file mode 100644 index 0000000000..4773342bad --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_vertex_attrib_64bit @@ -0,0 +1,20 @@ +GL_EXT_vertex_attrib_64bit +http://www.opengl.org/registry/specs/EXT/vertex_attrib_64bit.txt +GL_EXT_vertex_attrib_64bit + GL_DOUBLE_MAT2_EXT 0x8F46 + GL_DOUBLE_MAT3_EXT 0x8F47 + GL_DOUBLE_MAT4_EXT 0x8F48 + GL_DOUBLE_VEC2_EXT 0x8FFC + GL_DOUBLE_VEC3_EXT 0x8FFD + GL_DOUBLE_VEC4_EXT 0x8FFE + void glGetVertexAttribLdvEXT (GLuint index, GLenum pname, GLdouble* params) + void glVertexArrayVertexAttribLOffsetEXT (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset) + void glVertexAttribL1dEXT (GLuint index, GLdouble x) + void glVertexAttribL1dvEXT (GLuint index, const GLdouble* v) + void glVertexAttribL2dEXT (GLuint index, GLdouble x, GLdouble y) + void glVertexAttribL2dvEXT (GLuint index, const GLdouble* v) + void glVertexAttribL3dEXT (GLuint index, GLdouble x, GLdouble y, GLdouble z) + void glVertexAttribL3dvEXT (GLuint index, const GLdouble* v) + void glVertexAttribL4dEXT (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glVertexAttribL4dvEXT (GLuint index, const GLdouble* v) + void glVertexAttribLPointerEXT (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_EXT_vertex_shader b/Externals/GLew/auto/extensions/GL_EXT_vertex_shader new file mode 100644 index 0000000000..eb125b6083 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_vertex_shader @@ -0,0 +1,156 @@ +GL_EXT_vertex_shader +http://oss.sgi.com/projects/ogl-sample/registry/EXT/vertex_shader.txt +GL_EXT_vertex_shader + GL_VERTEX_SHADER_EXT 0x8780 + GL_VERTEX_SHADER_BINDING_EXT 0x8781 + GL_OP_INDEX_EXT 0x8782 + GL_OP_NEGATE_EXT 0x8783 + GL_OP_DOT3_EXT 0x8784 + GL_OP_DOT4_EXT 0x8785 + GL_OP_MUL_EXT 0x8786 + GL_OP_ADD_EXT 0x8787 + GL_OP_MADD_EXT 0x8788 + GL_OP_FRAC_EXT 0x8789 + GL_OP_MAX_EXT 0x878A + GL_OP_MIN_EXT 0x878B + GL_OP_SET_GE_EXT 0x878C + GL_OP_SET_LT_EXT 0x878D + GL_OP_CLAMP_EXT 0x878E + GL_OP_FLOOR_EXT 0x878F + GL_OP_ROUND_EXT 0x8790 + GL_OP_EXP_BASE_2_EXT 0x8791 + GL_OP_LOG_BASE_2_EXT 0x8792 + GL_OP_POWER_EXT 0x8793 + GL_OP_RECIP_EXT 0x8794 + GL_OP_RECIP_SQRT_EXT 0x8795 + GL_OP_SUB_EXT 0x8796 + GL_OP_CROSS_PRODUCT_EXT 0x8797 + GL_OP_MULTIPLY_MATRIX_EXT 0x8798 + GL_OP_MOV_EXT 0x8799 + GL_OUTPUT_VERTEX_EXT 0x879A + GL_OUTPUT_COLOR0_EXT 0x879B + GL_OUTPUT_COLOR1_EXT 0x879C + GL_OUTPUT_TEXTURE_COORD0_EXT 0x879D + GL_OUTPUT_TEXTURE_COORD1_EXT 0x879E + GL_OUTPUT_TEXTURE_COORD2_EXT 0x879F + GL_OUTPUT_TEXTURE_COORD3_EXT 0x87A0 + GL_OUTPUT_TEXTURE_COORD4_EXT 0x87A1 + GL_OUTPUT_TEXTURE_COORD5_EXT 0x87A2 + GL_OUTPUT_TEXTURE_COORD6_EXT 0x87A3 + GL_OUTPUT_TEXTURE_COORD7_EXT 0x87A4 + GL_OUTPUT_TEXTURE_COORD8_EXT 0x87A5 + GL_OUTPUT_TEXTURE_COORD9_EXT 0x87A6 + GL_OUTPUT_TEXTURE_COORD10_EXT 0x87A7 + GL_OUTPUT_TEXTURE_COORD11_EXT 0x87A8 + GL_OUTPUT_TEXTURE_COORD12_EXT 0x87A9 + GL_OUTPUT_TEXTURE_COORD13_EXT 0x87AA + GL_OUTPUT_TEXTURE_COORD14_EXT 0x87AB + GL_OUTPUT_TEXTURE_COORD15_EXT 0x87AC + GL_OUTPUT_TEXTURE_COORD16_EXT 0x87AD + GL_OUTPUT_TEXTURE_COORD17_EXT 0x87AE + GL_OUTPUT_TEXTURE_COORD18_EXT 0x87AF + GL_OUTPUT_TEXTURE_COORD19_EXT 0x87B0 + GL_OUTPUT_TEXTURE_COORD20_EXT 0x87B1 + GL_OUTPUT_TEXTURE_COORD21_EXT 0x87B2 + GL_OUTPUT_TEXTURE_COORD22_EXT 0x87B3 + GL_OUTPUT_TEXTURE_COORD23_EXT 0x87B4 + GL_OUTPUT_TEXTURE_COORD24_EXT 0x87B5 + GL_OUTPUT_TEXTURE_COORD25_EXT 0x87B6 + GL_OUTPUT_TEXTURE_COORD26_EXT 0x87B7 + GL_OUTPUT_TEXTURE_COORD27_EXT 0x87B8 + GL_OUTPUT_TEXTURE_COORD28_EXT 0x87B9 + GL_OUTPUT_TEXTURE_COORD29_EXT 0x87BA + GL_OUTPUT_TEXTURE_COORD30_EXT 0x87BB + GL_OUTPUT_TEXTURE_COORD31_EXT 0x87BC + GL_OUTPUT_FOG_EXT 0x87BD + GL_SCALAR_EXT 0x87BE + GL_VECTOR_EXT 0x87BF + GL_MATRIX_EXT 0x87C0 + GL_VARIANT_EXT 0x87C1 + GL_INVARIANT_EXT 0x87C2 + GL_LOCAL_CONSTANT_EXT 0x87C3 + GL_LOCAL_EXT 0x87C4 + GL_MAX_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87C5 + GL_MAX_VERTEX_SHADER_VARIANTS_EXT 0x87C6 + GL_MAX_VERTEX_SHADER_INVARIANTS_EXT 0x87C7 + GL_MAX_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87C8 + GL_MAX_VERTEX_SHADER_LOCALS_EXT 0x87C9 + GL_MAX_OPTIMIZED_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CA + GL_MAX_OPTIMIZED_VERTEX_SHADER_VARIANTS_EXT 0x87CB + GL_MAX_OPTIMIZED_VERTEX_SHADER_INVARIANTS_EXT 0x87CC + GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87CD + GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCALS_EXT 0x87CE + GL_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CF + GL_VERTEX_SHADER_VARIANTS_EXT 0x87D0 + GL_VERTEX_SHADER_INVARIANTS_EXT 0x87D1 + GL_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87D2 + GL_VERTEX_SHADER_LOCALS_EXT 0x87D3 + GL_VERTEX_SHADER_OPTIMIZED_EXT 0x87D4 + GL_X_EXT 0x87D5 + GL_Y_EXT 0x87D6 + GL_Z_EXT 0x87D7 + GL_W_EXT 0x87D8 + GL_NEGATIVE_X_EXT 0x87D9 + GL_NEGATIVE_Y_EXT 0x87DA + GL_NEGATIVE_Z_EXT 0x87DB + GL_NEGATIVE_W_EXT 0x87DC + GL_ZERO_EXT 0x87DD + GL_ONE_EXT 0x87DE + GL_NEGATIVE_ONE_EXT 0x87DF + GL_NORMALIZED_RANGE_EXT 0x87E0 + GL_FULL_RANGE_EXT 0x87E1 + GL_CURRENT_VERTEX_EXT 0x87E2 + GL_MVP_MATRIX_EXT 0x87E3 + GL_VARIANT_VALUE_EXT 0x87E4 + GL_VARIANT_DATATYPE_EXT 0x87E5 + GL_VARIANT_ARRAY_STRIDE_EXT 0x87E6 + GL_VARIANT_ARRAY_TYPE_EXT 0x87E7 + GL_VARIANT_ARRAY_EXT 0x87E8 + GL_VARIANT_ARRAY_POINTER_EXT 0x87E9 + GL_INVARIANT_VALUE_EXT 0x87EA + GL_INVARIANT_DATATYPE_EXT 0x87EB + GL_LOCAL_CONSTANT_VALUE_EXT 0x87EC + GL_LOCAL_CONSTANT_DATATYPE_EXT 0x87ED + + void glBeginVertexShaderEXT (void) + void glEndVertexShaderEXT (void) + void glBindVertexShaderEXT (GLuint id) + GLuint glGenVertexShadersEXT (GLuint range) + void glDeleteVertexShaderEXT (GLuint id) + void glShaderOp1EXT (GLenum op, GLuint res, GLuint arg1) + void glShaderOp2EXT (GLenum op, GLuint res, GLuint arg1, GLuint arg2) + void glShaderOp3EXT (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3) + void glSwizzleEXT (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW) + void glWriteMaskEXT (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW) + void glInsertComponentEXT (GLuint res, GLuint src, GLuint num) + void glExtractComponentEXT (GLuint res, GLuint src, GLuint num) + GLuint glGenSymbolsEXT (GLenum dataType, GLenum storageType, GLenum range, GLuint components) + void glSetInvariantEXT (GLuint id, GLenum type, GLvoid *addr) + void glSetLocalConstantEXT (GLuint id, GLenum type, GLvoid *addr) + void glVariantbvEXT (GLuint id, GLbyte *addr) + void glVariantsvEXT (GLuint id, GLshort *addr) + void glVariantivEXT (GLuint id, GLint *addr) + void glVariantfvEXT (GLuint id, GLfloat *addr) + void glVariantdvEXT (GLuint id, GLdouble *addr) + void glVariantubvEXT (GLuint id, GLubyte *addr) + void glVariantusvEXT (GLuint id, GLushort *addr) + void glVariantuivEXT (GLuint id, GLuint *addr) + void glVariantPointerEXT (GLuint id, GLenum type, GLuint stride, GLvoid *addr) + void glEnableVariantClientStateEXT (GLuint id) + void glDisableVariantClientStateEXT (GLuint id) + GLuint glBindLightParameterEXT (GLenum light, GLenum value) + GLuint glBindMaterialParameterEXT (GLenum face, GLenum value) + GLuint glBindTexGenParameterEXT (GLenum unit, GLenum coord, GLenum value) + GLuint glBindTextureUnitParameterEXT (GLenum unit, GLenum value) + GLuint glBindParameterEXT (GLenum value) + GLboolean glIsVariantEnabledEXT (GLuint id, GLenum cap) + void glGetVariantBooleanvEXT (GLuint id, GLenum value, GLboolean *data) + void glGetVariantIntegervEXT (GLuint id, GLenum value, GLint *data) + void glGetVariantFloatvEXT (GLuint id, GLenum value, GLfloat *data) + void glGetVariantPointervEXT (GLuint id, GLenum value, GLvoid **data) + void glGetInvariantBooleanvEXT (GLuint id, GLenum value, GLboolean *data) + void glGetInvariantIntegervEXT (GLuint id, GLenum value, GLint *data) + void glGetInvariantFloatvEXT (GLuint id, GLenum value, GLfloat *data) + void glGetLocalConstantBooleanvEXT (GLuint id, GLenum value, GLboolean *data) + void glGetLocalConstantIntegervEXT (GLuint id, GLenum value, GLint *data) + void glGetLocalConstantFloatvEXT (GLuint id, GLenum value, GLfloat *data) diff --git a/Externals/GLew/auto/extensions/GL_EXT_vertex_weighting b/Externals/GLew/auto/extensions/GL_EXT_vertex_weighting new file mode 100644 index 0000000000..7a5a0f043e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_EXT_vertex_weighting @@ -0,0 +1,19 @@ +GL_EXT_vertex_weighting +http://www.opengl.org/registry/specs/EXT/vertex_weighting.txt +GL_EXT_vertex_weighting + GL_MODELVIEW0_STACK_DEPTH_EXT 0x0BA3 + GL_MODELVIEW0_MATRIX_EXT 0x0BA6 + GL_MODELVIEW0_EXT 0x1700 + GL_MODELVIEW1_STACK_DEPTH_EXT 0x8502 + GL_MODELVIEW1_MATRIX_EXT 0x8506 + GL_VERTEX_WEIGHTING_EXT 0x8509 + GL_MODELVIEW1_EXT 0x850A + GL_CURRENT_VERTEX_WEIGHT_EXT 0x850B + GL_VERTEX_WEIGHT_ARRAY_EXT 0x850C + GL_VERTEX_WEIGHT_ARRAY_SIZE_EXT 0x850D + GL_VERTEX_WEIGHT_ARRAY_TYPE_EXT 0x850E + GL_VERTEX_WEIGHT_ARRAY_STRIDE_EXT 0x850F + GL_VERTEX_WEIGHT_ARRAY_POINTER_EXT 0x8510 + void glVertexWeightPointerEXT (GLint size, GLenum type, GLsizei stride, void* pointer) + void glVertexWeightfEXT (GLfloat weight) + void glVertexWeightfvEXT (GLfloat* weight) diff --git a/Externals/GLew/auto/extensions/GL_GREMEDY_frame_terminator b/Externals/GLew/auto/extensions/GL_GREMEDY_frame_terminator new file mode 100644 index 0000000000..2832f551ab --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_GREMEDY_frame_terminator @@ -0,0 +1,4 @@ +GL_GREMEDY_frame_terminator +http://www.opengl.org/registry/specs/GREMEDY/frame_terminator.txt +GL_GREMEDY_frame_terminator + void glFrameTerminatorGREMEDY (void) diff --git a/Externals/GLew/auto/extensions/GL_GREMEDY_string_marker b/Externals/GLew/auto/extensions/GL_GREMEDY_string_marker new file mode 100644 index 0000000000..34f07f942d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_GREMEDY_string_marker @@ -0,0 +1,4 @@ +GL_GREMEDY_string_marker +http://www.opengl.org/registry/specs/GREMEDY/string_marker.txt +GL_GREMEDY_string_marker + void glStringMarkerGREMEDY (GLsizei len, const void* string) diff --git a/Externals/GLew/auto/extensions/GL_HP_convolution_border_modes b/Externals/GLew/auto/extensions/GL_HP_convolution_border_modes new file mode 100644 index 0000000000..cfcdca05ad --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_HP_convolution_border_modes @@ -0,0 +1,3 @@ +GL_HP_convolution_border_modes +http://www.opengl.org/registry/specs/HP/convolution_border_modes.txt +GL_HP_convolution_border_modes diff --git a/Externals/GLew/auto/extensions/GL_HP_image_transform b/Externals/GLew/auto/extensions/GL_HP_image_transform new file mode 100644 index 0000000000..c1842393e8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_HP_image_transform @@ -0,0 +1,9 @@ +GL_HP_image_transform +http://www.opengl.org/registry/specs/HP/image_transform.txt +GL_HP_image_transform + void glGetImageTransformParameterfvHP (GLenum target, GLenum pname, const GLfloat* params) + void glGetImageTransformParameterivHP (GLenum target, GLenum pname, const GLint* params) + void glImageTransformParameterfHP (GLenum target, GLenum pname, const GLfloat param) + void glImageTransformParameterfvHP (GLenum target, GLenum pname, const GLfloat* params) + void glImageTransformParameteriHP (GLenum target, GLenum pname, const GLint param) + void glImageTransformParameterivHP (GLenum target, GLenum pname, const GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_HP_occlusion_test b/Externals/GLew/auto/extensions/GL_HP_occlusion_test new file mode 100644 index 0000000000..f3e091eb47 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_HP_occlusion_test @@ -0,0 +1,5 @@ +GL_HP_occlusion_test +http://www.opengl.org/registry/specs/HP/occlusion_test.txt +GL_HP_occlusion_test + GL_OCCLUSION_TEST_RESULT_HP 0x8166 + GL_OCCLUSION_TEST_HP 0x8165 diff --git a/Externals/GLew/auto/extensions/GL_HP_texture_lighting b/Externals/GLew/auto/extensions/GL_HP_texture_lighting new file mode 100644 index 0000000000..d5d3f7333e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_HP_texture_lighting @@ -0,0 +1,3 @@ +GL_HP_texture_lighting +http://www.opengl.org/registry/specs/HP/texture_lighting.txt +GL_HP_texture_lighting diff --git a/Externals/GLew/auto/extensions/GL_IBM_cull_vertex b/Externals/GLew/auto/extensions/GL_IBM_cull_vertex new file mode 100644 index 0000000000..1b9c4d2bf0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_IBM_cull_vertex @@ -0,0 +1,4 @@ +GL_IBM_cull_vertex +http://www.opengl.org/registry/specs/IBM/cull_vertex.txt +GL_IBM_cull_vertex + GL_CULL_VERTEX_IBM 103050 diff --git a/Externals/GLew/auto/extensions/GL_IBM_multimode_draw_arrays b/Externals/GLew/auto/extensions/GL_IBM_multimode_draw_arrays new file mode 100644 index 0000000000..be45e8c647 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_IBM_multimode_draw_arrays @@ -0,0 +1,5 @@ +GL_IBM_multimode_draw_arrays +http://www.opengl.org/registry/specs/IBM/multimode_draw_arrays.txt +GL_IBM_multimode_draw_arrays + void glMultiModeDrawArraysIBM (const GLenum* mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride) + void glMultiModeDrawElementsIBM (const GLenum* mode, const GLsizei *count, GLenum type, const GLvoid * const *indices, GLsizei primcount, GLint modestride) diff --git a/Externals/GLew/auto/extensions/GL_IBM_rasterpos_clip b/Externals/GLew/auto/extensions/GL_IBM_rasterpos_clip new file mode 100644 index 0000000000..b219297208 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_IBM_rasterpos_clip @@ -0,0 +1,4 @@ +GL_IBM_rasterpos_clip +http://www.opengl.org/registry/specs/IBM/rasterpos_clip.txt +GL_IBM_rasterpos_clip + GL_RASTER_POSITION_UNCLIPPED_IBM 103010 diff --git a/Externals/GLew/auto/extensions/GL_IBM_static_data b/Externals/GLew/auto/extensions/GL_IBM_static_data new file mode 100644 index 0000000000..b31f7f9a2e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_IBM_static_data @@ -0,0 +1,5 @@ +GL_IBM_static_data +http://www.opengl.org/registry/specs/IBM/static_data.txt +GL_IBM_static_data + GL_ALL_STATIC_DATA_IBM 103060 + GL_STATIC_VERTEX_ARRAY_IBM 103061 diff --git a/Externals/GLew/auto/extensions/GL_IBM_texture_mirrored_repeat b/Externals/GLew/auto/extensions/GL_IBM_texture_mirrored_repeat new file mode 100644 index 0000000000..bf41e8eaf4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_IBM_texture_mirrored_repeat @@ -0,0 +1,4 @@ +GL_IBM_texture_mirrored_repeat +http://www.opengl.org/registry/specs/IBM/texture_mirrored_repeat.txt +GL_IBM_texture_mirrored_repeat + GL_MIRRORED_REPEAT_IBM 0x8370 diff --git a/Externals/GLew/auto/extensions/GL_IBM_vertex_array_lists b/Externals/GLew/auto/extensions/GL_IBM_vertex_array_lists new file mode 100644 index 0000000000..a03313cef7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_IBM_vertex_array_lists @@ -0,0 +1,27 @@ +GL_IBM_vertex_array_lists +http://www.opengl.org/registry/specs/IBM/vertex_array_lists.txt +GL_IBM_vertex_array_lists + GL_VERTEX_ARRAY_LIST_IBM 103070 + GL_NORMAL_ARRAY_LIST_IBM 103071 + GL_COLOR_ARRAY_LIST_IBM 103072 + GL_INDEX_ARRAY_LIST_IBM 103073 + GL_TEXTURE_COORD_ARRAY_LIST_IBM 103074 + GL_EDGE_FLAG_ARRAY_LIST_IBM 103075 + GL_FOG_COORDINATE_ARRAY_LIST_IBM 103076 + GL_SECONDARY_COLOR_ARRAY_LIST_IBM 103077 + GL_VERTEX_ARRAY_LIST_STRIDE_IBM 103080 + GL_NORMAL_ARRAY_LIST_STRIDE_IBM 103081 + GL_COLOR_ARRAY_LIST_STRIDE_IBM 103082 + GL_INDEX_ARRAY_LIST_STRIDE_IBM 103083 + GL_TEXTURE_COORD_ARRAY_LIST_STRIDE_IBM 103084 + GL_EDGE_FLAG_ARRAY_LIST_STRIDE_IBM 103085 + GL_FOG_COORDINATE_ARRAY_LIST_STRIDE_IBM 103086 + GL_SECONDARY_COLOR_ARRAY_LIST_STRIDE_IBM 103087 + void glColorPointerListIBM (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride) + void glEdgeFlagPointerListIBM (GLint stride, const GLboolean ** pointer, GLint ptrstride) + void glFogCoordPointerListIBM (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride) + void glIndexPointerListIBM (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride) + void glNormalPointerListIBM (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride) + void glSecondaryColorPointerListIBM (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride) + void glTexCoordPointerListIBM (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride) + void glVertexPointerListIBM (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride) diff --git a/Externals/GLew/auto/extensions/GL_INGR_color_clamp b/Externals/GLew/auto/extensions/GL_INGR_color_clamp new file mode 100644 index 0000000000..15d27efbfd --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_INGR_color_clamp @@ -0,0 +1,11 @@ +GL_INGR_color_clamp +http://www.opengl.org/registry/specs/INGR/color_clamp.txt +GL_INGR_color_clamp + GL_RED_MIN_CLAMP_INGR 0x8560 + GL_GREEN_MIN_CLAMP_INGR 0x8561 + GL_BLUE_MIN_CLAMP_INGR 0x8562 + GL_ALPHA_MIN_CLAMP_INGR 0x8563 + GL_RED_MAX_CLAMP_INGR 0x8564 + GL_GREEN_MAX_CLAMP_INGR 0x8565 + GL_BLUE_MAX_CLAMP_INGR 0x8566 + GL_ALPHA_MAX_CLAMP_INGR 0x8567 diff --git a/Externals/GLew/auto/extensions/GL_INGR_interlace_read b/Externals/GLew/auto/extensions/GL_INGR_interlace_read new file mode 100644 index 0000000000..052356430c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_INGR_interlace_read @@ -0,0 +1,4 @@ +GL_INGR_interlace_read +http://www.opengl.org/registry/specs/INGR/interlace_read.txt +GL_INGR_interlace_read + GL_INTERLACE_READ_INGR 0x8568 diff --git a/Externals/GLew/auto/extensions/GL_INTEL_parallel_arrays b/Externals/GLew/auto/extensions/GL_INTEL_parallel_arrays new file mode 100644 index 0000000000..925a6198b6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_INTEL_parallel_arrays @@ -0,0 +1,12 @@ +GL_INTEL_parallel_arrays +http://www.opengl.org/registry/specs/INTEL/parallel_arrays.txt +GL_INTEL_parallel_arrays + GL_PARALLEL_ARRAYS_INTEL 0x83F4 + GL_VERTEX_ARRAY_PARALLEL_POINTERS_INTEL 0x83F5 + GL_NORMAL_ARRAY_PARALLEL_POINTERS_INTEL 0x83F6 + GL_COLOR_ARRAY_PARALLEL_POINTERS_INTEL 0x83F7 + GL_TEXTURE_COORD_ARRAY_PARALLEL_POINTERS_INTEL 0x83F8 + void glColorPointervINTEL (GLint size, GLenum type, const void** pointer) + void glNormalPointervINTEL (GLenum type, const void** pointer) + void glTexCoordPointervINTEL (GLint size, GLenum type, const void** pointer) + void glVertexPointervINTEL (GLint size, GLenum type, const void** pointer) diff --git a/Externals/GLew/auto/extensions/GL_INTEL_texture_scissor b/Externals/GLew/auto/extensions/GL_INTEL_texture_scissor new file mode 100644 index 0000000000..732944b295 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_INTEL_texture_scissor @@ -0,0 +1,5 @@ +GL_INTEL_texture_scissor +http://www.opengl.org/registry/specs/INTEL/texture_scissor.txt +GL_INTEL_texture_scissor + void glTexScissorFuncINTEL (GLenum target, GLenum lfunc, GLenum hfunc) + void glTexScissorINTEL (GLenum target, GLclampf tlow, GLclampf thigh) diff --git a/Externals/GLew/auto/extensions/GL_KTX_buffer_region b/Externals/GLew/auto/extensions/GL_KTX_buffer_region new file mode 100644 index 0000000000..22a59d3be3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_KTX_buffer_region @@ -0,0 +1,12 @@ +GL_KTX_buffer_region + +GL_KTX_buffer_region + GL_KTX_FRONT_REGION 0x0 + GL_KTX_BACK_REGION 0x1 + GL_KTX_Z_REGION 0x2 + GL_KTX_STENCIL_REGION 0x3 + GLuint glBufferRegionEnabledEXT (void) + GLuint glNewBufferRegionEXT (GLenum region) + void glDeleteBufferRegionEXT (GLenum region) + void glReadBufferRegionEXT (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height) + void glDrawBufferRegionEXT (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height, GLint xDest, GLint yDest) diff --git a/Externals/GLew/auto/extensions/GL_MESAX_texture_stack b/Externals/GLew/auto/extensions/GL_MESAX_texture_stack new file mode 100644 index 0000000000..1e7c58db96 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_MESAX_texture_stack @@ -0,0 +1,9 @@ +GL_MESAX_texture_stack +http://www.opengl.org/registry/specs/MESAX/texture_stack.txt +GL_MESAX_texture_stack + GL_TEXTURE_1D_STACK_MESAX 0x8759 + GL_TEXTURE_2D_STACK_MESAX 0x875A + GL_PROXY_TEXTURE_1D_STACK_MESAX 0x875B + GL_PROXY_TEXTURE_2D_STACK_MESAX 0x875C + GL_TEXTURE_1D_STACK_BINDING_MESAX 0x875D + GL_TEXTURE_2D_STACK_BINDING_MESAX 0x875E diff --git a/Externals/GLew/auto/extensions/GL_MESA_pack_invert b/Externals/GLew/auto/extensions/GL_MESA_pack_invert new file mode 100644 index 0000000000..dca9c64e66 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_MESA_pack_invert @@ -0,0 +1,4 @@ +GL_MESA_pack_invert +http://www.opengl.org/registry/specs/MESA/pack_invert.txt +GL_MESA_pack_invert + GL_PACK_INVERT_MESA 0x8758 diff --git a/Externals/GLew/auto/extensions/GL_MESA_resize_buffers b/Externals/GLew/auto/extensions/GL_MESA_resize_buffers new file mode 100644 index 0000000000..39649bdb97 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_MESA_resize_buffers @@ -0,0 +1,4 @@ +GL_MESA_resize_buffers +http://www.opengl.org/registry/specs/MESA/resize_buffers.txt +GL_MESA_resize_buffers + void glResizeBuffersMESA (void) diff --git a/Externals/GLew/auto/extensions/GL_MESA_window_pos b/Externals/GLew/auto/extensions/GL_MESA_window_pos new file mode 100644 index 0000000000..290c52cb8d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_MESA_window_pos @@ -0,0 +1,27 @@ +GL_MESA_window_pos +http://www.opengl.org/registry/specs/MESA/window_pos.txt +GL_MESA_window_pos + void glWindowPos2dMESA (GLdouble x, GLdouble y) + void glWindowPos2dvMESA (const GLdouble* p) + void glWindowPos2fMESA (GLfloat x, GLfloat y) + void glWindowPos2fvMESA (const GLfloat* p) + void glWindowPos2iMESA (GLint x, GLint y) + void glWindowPos2ivMESA (const GLint* p) + void glWindowPos2sMESA (GLshort x, GLshort y) + void glWindowPos2svMESA (const GLshort* p) + void glWindowPos3dMESA (GLdouble x, GLdouble y, GLdouble z) + void glWindowPos3dvMESA (const GLdouble* p) + void glWindowPos3fMESA (GLfloat x, GLfloat y, GLfloat z) + void glWindowPos3fvMESA (const GLfloat* p) + void glWindowPos3iMESA (GLint x, GLint y, GLint z) + void glWindowPos3ivMESA (const GLint* p) + void glWindowPos3sMESA (GLshort x, GLshort y, GLshort z) + void glWindowPos3svMESA (const GLshort* p) + void glWindowPos4dMESA (GLdouble x, GLdouble y, GLdouble z, GLdouble) + void glWindowPos4dvMESA (const GLdouble* p) + void glWindowPos4fMESA (GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glWindowPos4fvMESA (const GLfloat* p) + void glWindowPos4iMESA (GLint x, GLint y, GLint z, GLint w) + void glWindowPos4ivMESA (const GLint* p) + void glWindowPos4sMESA (GLshort x, GLshort y, GLshort z, GLshort w) + void glWindowPos4svMESA (const GLshort* p) diff --git a/Externals/GLew/auto/extensions/GL_MESA_ycbcr_texture b/Externals/GLew/auto/extensions/GL_MESA_ycbcr_texture new file mode 100644 index 0000000000..f26d38761a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_MESA_ycbcr_texture @@ -0,0 +1,6 @@ +GL_MESA_ycbcr_texture +http://www.opengl.org/registry/specs/MESA/ycbcr_texture.txt +GL_MESA_ycbcr_texture + GL_UNSIGNED_SHORT_8_8_MESA 0x85BA + GL_UNSIGNED_SHORT_8_8_REV_MESA 0x85BB + GL_YCBCR_MESA 0x8757 diff --git a/Externals/GLew/auto/extensions/GL_NV_blend_square b/Externals/GLew/auto/extensions/GL_NV_blend_square new file mode 100644 index 0000000000..8aafdcc2bc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_blend_square @@ -0,0 +1,3 @@ +GL_NV_blend_square +http://www.opengl.org/registry/specs/NV/blend_square.txt +GL_NV_blend_square diff --git a/Externals/GLew/auto/extensions/GL_NV_conditional_render b/Externals/GLew/auto/extensions/GL_NV_conditional_render new file mode 100644 index 0000000000..f22d1afbd2 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_conditional_render @@ -0,0 +1,9 @@ +GL_NV_conditional_render +http://www.opengl.org/registry/specs/NV/conditional_render.txt +GL_NV_conditional_render + GL_QUERY_WAIT_NV 0x8E13 + GL_QUERY_NO_WAIT_NV 0x8E14 + GL_QUERY_BY_REGION_WAIT_NV 0x8E15 + GL_QUERY_BY_REGION_NO_WAIT_NV 0x8E16 + void glBeginConditionalRenderNV (GLuint id, GLenum mode) + void glEndConditionalRenderNV (void) diff --git a/Externals/GLew/auto/extensions/GL_NV_copy_depth_to_color b/Externals/GLew/auto/extensions/GL_NV_copy_depth_to_color new file mode 100644 index 0000000000..7d48642d51 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_copy_depth_to_color @@ -0,0 +1,5 @@ +GL_NV_copy_depth_to_color +http://www.opengl.org/registry/specs/NV/copy_depth_to_color.txt +GL_NV_copy_depth_to_color + GL_DEPTH_STENCIL_TO_RGBA_NV 0x886E + GL_DEPTH_STENCIL_TO_BGRA_NV 0x886F diff --git a/Externals/GLew/auto/extensions/GL_NV_copy_image b/Externals/GLew/auto/extensions/GL_NV_copy_image new file mode 100644 index 0000000000..0cf53fd927 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_copy_image @@ -0,0 +1,4 @@ +GL_NV_copy_image +http://www.opengl.org/registry/specs/NV/copy_image.txt +GL_NV_copy_image + void glCopyImageSubDataNV (GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth) diff --git a/Externals/GLew/auto/extensions/GL_NV_depth_buffer_float b/Externals/GLew/auto/extensions/GL_NV_depth_buffer_float new file mode 100644 index 0000000000..493b245589 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_depth_buffer_float @@ -0,0 +1,10 @@ +GL_NV_depth_buffer_float +http://developer.download.nvidia.com/opengl/specs/GL_NV_depth_buffer_float.txt +GL_NV_depth_buffer_float + GL_DEPTH_COMPONENT32F_NV 0x8DAB + GL_DEPTH32F_STENCIL8_NV 0x8DAC + GL_FLOAT_32_UNSIGNED_INT_24_8_REV_NV 0x8DAD + GL_DEPTH_BUFFER_FLOAT_MODE_NV 0x8DAF + void glDepthRangedNV (GLdouble zNear, GLdouble zFar) + void glClearDepthdNV (GLdouble depth) + void glDepthBoundsdNV (GLdouble zmin, GLdouble zmax) diff --git a/Externals/GLew/auto/extensions/GL_NV_depth_clamp b/Externals/GLew/auto/extensions/GL_NV_depth_clamp new file mode 100644 index 0000000000..561a0c59a0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_depth_clamp @@ -0,0 +1,4 @@ +GL_NV_depth_clamp +http://www.opengl.org/registry/specs/NV/depth_clamp.txt +GL_NV_depth_clamp + GL_DEPTH_CLAMP_NV 0x864F diff --git a/Externals/GLew/auto/extensions/GL_NV_depth_range_unclamped b/Externals/GLew/auto/extensions/GL_NV_depth_range_unclamped new file mode 100644 index 0000000000..62b4e59fa7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_depth_range_unclamped @@ -0,0 +1,8 @@ +GL_NV_depth_range_unclamped + +GL_NV_depth_range_unclamped + GL_SAMPLE_COUNT_BITS_NV 0x8864 + GL_CURRENT_SAMPLE_COUNT_QUERY_NV 0x8865 + GL_QUERY_RESULT_NV 0x8866 + GL_QUERY_RESULT_AVAILABLE_NV 0x8867 + GL_SAMPLE_COUNT_NV 0x8914 diff --git a/Externals/GLew/auto/extensions/GL_NV_evaluators b/Externals/GLew/auto/extensions/GL_NV_evaluators new file mode 100644 index 0000000000..531ea7fea0 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_evaluators @@ -0,0 +1,36 @@ +GL_NV_evaluators +http://www.opengl.org/registry/specs/NV/evaluators.txt +GL_NV_evaluators + GL_EVAL_2D_NV 0x86C0 + GL_EVAL_TRIANGULAR_2D_NV 0x86C1 + GL_MAP_TESSELLATION_NV 0x86C2 + GL_MAP_ATTRIB_U_ORDER_NV 0x86C3 + GL_MAP_ATTRIB_V_ORDER_NV 0x86C4 + GL_EVAL_FRACTIONAL_TESSELLATION_NV 0x86C5 + GL_EVAL_VERTEX_ATTRIB0_NV 0x86C6 + GL_EVAL_VERTEX_ATTRIB1_NV 0x86C7 + GL_EVAL_VERTEX_ATTRIB2_NV 0x86C8 + GL_EVAL_VERTEX_ATTRIB3_NV 0x86C9 + GL_EVAL_VERTEX_ATTRIB4_NV 0x86CA + GL_EVAL_VERTEX_ATTRIB5_NV 0x86CB + GL_EVAL_VERTEX_ATTRIB6_NV 0x86CC + GL_EVAL_VERTEX_ATTRIB7_NV 0x86CD + GL_EVAL_VERTEX_ATTRIB8_NV 0x86CE + GL_EVAL_VERTEX_ATTRIB9_NV 0x86CF + GL_EVAL_VERTEX_ATTRIB10_NV 0x86D0 + GL_EVAL_VERTEX_ATTRIB11_NV 0x86D1 + GL_EVAL_VERTEX_ATTRIB12_NV 0x86D2 + GL_EVAL_VERTEX_ATTRIB13_NV 0x86D3 + GL_EVAL_VERTEX_ATTRIB14_NV 0x86D4 + GL_EVAL_VERTEX_ATTRIB15_NV 0x86D5 + GL_MAX_MAP_TESSELLATION_NV 0x86D6 + GL_MAX_RATIONAL_EVAL_ORDER_NV 0x86D7 + void glEvalMapsNV (GLenum target, GLenum mode) + void glGetMapAttribParameterfvNV (GLenum target, GLuint index, GLenum pname, GLfloat* params) + void glGetMapAttribParameterivNV (GLenum target, GLuint index, GLenum pname, GLint* params) + void glGetMapControlPointsNV (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, void* points) + void glGetMapParameterfvNV (GLenum target, GLenum pname, GLfloat* params) + void glGetMapParameterivNV (GLenum target, GLenum pname, GLint* params) + void glMapControlPointsNV (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const void* points) + void glMapParameterfvNV (GLenum target, GLenum pname, const GLfloat* params) + void glMapParameterivNV (GLenum target, GLenum pname, const GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_NV_explicit_multisample b/Externals/GLew/auto/extensions/GL_NV_explicit_multisample new file mode 100644 index 0000000000..0b87a174a6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_explicit_multisample @@ -0,0 +1,16 @@ +GL_NV_explicit_multisample +http://www.opengl.org/registry/specs/NV/explicit_multisample.txt +GL_NV_explicit_multisample + GL_SAMPLE_POSITION_NV 0x8E50 + GL_SAMPLE_MASK_NV 0x8E51 + GL_SAMPLE_MASK_VALUE_NV 0x8E52 + GL_TEXTURE_BINDING_RENDERBUFFER_NV 0x8E53 + GL_TEXTURE_RENDERBUFFER_DATA_STORE_BINDING_NV 0x8E54 + GL_TEXTURE_RENDERBUFFER_NV 0x8E55 + GL_SAMPLER_RENDERBUFFER_NV 0x8E56 + GL_INT_SAMPLER_RENDERBUFFER_NV 0x8E57 + GL_UNSIGNED_INT_SAMPLER_RENDERBUFFER_NV 0x8E58 + GL_MAX_SAMPLE_MASK_WORDS_NV 0x8E59 + void glGetMultisamplefvNV (GLenum pname, GLuint index, GLfloat* val) + void glSampleMaskIndexedNV (GLuint index, GLbitfield mask) + void glTexRenderbufferNV (GLenum target, GLuint renderbuffer) diff --git a/Externals/GLew/auto/extensions/GL_NV_fence b/Externals/GLew/auto/extensions/GL_NV_fence new file mode 100644 index 0000000000..e59833fe7a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_fence @@ -0,0 +1,13 @@ +GL_NV_fence +http://www.opengl.org/registry/specs/NV/fence.txt +GL_NV_fence + GL_ALL_COMPLETED_NV 0x84F2 + GL_FENCE_STATUS_NV 0x84F3 + GL_FENCE_CONDITION_NV 0x84F4 + void glDeleteFencesNV (GLsizei n, const GLuint* fences) + void glFinishFenceNV (GLuint fence) + void glGenFencesNV (GLsizei n, GLuint* fences) + void glGetFenceivNV (GLuint fence, GLenum pname, GLint* params) + GLboolean glIsFenceNV (GLuint fence) + void glSetFenceNV (GLuint fence, GLenum condition) + GLboolean glTestFenceNV (GLuint fence) diff --git a/Externals/GLew/auto/extensions/GL_NV_float_buffer b/Externals/GLew/auto/extensions/GL_NV_float_buffer new file mode 100644 index 0000000000..f44ae430f8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_float_buffer @@ -0,0 +1,18 @@ +GL_NV_float_buffer +http://www.opengl.org/registry/specs/NV/float_buffer.txt +GL_NV_float_buffer + GL_FLOAT_R_NV 0x8880 + GL_FLOAT_RG_NV 0x8881 + GL_FLOAT_RGB_NV 0x8882 + GL_FLOAT_RGBA_NV 0x8883 + GL_FLOAT_R16_NV 0x8884 + GL_FLOAT_R32_NV 0x8885 + GL_FLOAT_RG16_NV 0x8886 + GL_FLOAT_RG32_NV 0x8887 + GL_FLOAT_RGB16_NV 0x8888 + GL_FLOAT_RGB32_NV 0x8889 + GL_FLOAT_RGBA16_NV 0x888A + GL_FLOAT_RGBA32_NV 0x888B + GL_TEXTURE_FLOAT_COMPONENTS_NV 0x888C + GL_FLOAT_CLEAR_COLOR_VALUE_NV 0x888D + GL_FLOAT_RGBA_MODE_NV 0x888E diff --git a/Externals/GLew/auto/extensions/GL_NV_fog_distance b/Externals/GLew/auto/extensions/GL_NV_fog_distance new file mode 100644 index 0000000000..9cee59b36a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_fog_distance @@ -0,0 +1,6 @@ +GL_NV_fog_distance +http://www.opengl.org/registry/specs/NV/fog_distance.txt +GL_NV_fog_distance + GL_FOG_DISTANCE_MODE_NV 0x855A + GL_EYE_RADIAL_NV 0x855B + GL_EYE_PLANE_ABSOLUTE_NV 0x855C diff --git a/Externals/GLew/auto/extensions/GL_NV_fragment_program b/Externals/GLew/auto/extensions/GL_NV_fragment_program new file mode 100644 index 0000000000..298808c6f8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_fragment_program @@ -0,0 +1,15 @@ +GL_NV_fragment_program +http://www.opengl.org/registry/specs/NV/fragment_program.txt +GL_NV_fragment_program + GL_MAX_FRAGMENT_PROGRAM_LOCAL_PARAMETERS_NV 0x8868 + GL_FRAGMENT_PROGRAM_NV 0x8870 + GL_MAX_TEXTURE_COORDS_NV 0x8871 + GL_MAX_TEXTURE_IMAGE_UNITS_NV 0x8872 + GL_FRAGMENT_PROGRAM_BINDING_NV 0x8873 + GL_PROGRAM_ERROR_STRING_NV 0x8874 + void glGetProgramNamedParameterdvNV (GLuint id, GLsizei len, const GLubyte* name, GLdouble *params) + void glGetProgramNamedParameterfvNV (GLuint id, GLsizei len, const GLubyte* name, GLfloat *params) + void glProgramNamedParameter4dNV (GLuint id, GLsizei len, const GLubyte* name, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glProgramNamedParameter4dvNV (GLuint id, GLsizei len, const GLubyte* name, const GLdouble v[]) + void glProgramNamedParameter4fNV (GLuint id, GLsizei len, const GLubyte* name, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glProgramNamedParameter4fvNV (GLuint id, GLsizei len, const GLubyte* name, const GLfloat v[]) diff --git a/Externals/GLew/auto/extensions/GL_NV_fragment_program2 b/Externals/GLew/auto/extensions/GL_NV_fragment_program2 new file mode 100644 index 0000000000..7fb59eea1b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_fragment_program2 @@ -0,0 +1,8 @@ +GL_NV_fragment_program2 +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_fragment_program2.txt +GL_NV_fragment_program2 + GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 + GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 + GL_MAX_PROGRAM_IF_DEPTH_NV 0x88F6 + GL_MAX_PROGRAM_LOOP_DEPTH_NV 0x88F7 + GL_MAX_PROGRAM_LOOP_COUNT_NV 0x88F8 diff --git a/Externals/GLew/auto/extensions/GL_NV_fragment_program4 b/Externals/GLew/auto/extensions/GL_NV_fragment_program4 new file mode 100644 index 0000000000..0ae2598795 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_fragment_program4 @@ -0,0 +1,3 @@ +GL_NV_fragment_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_fragment_program4.txt +GL_NV_gpu_program4 diff --git a/Externals/GLew/auto/extensions/GL_NV_fragment_program_option b/Externals/GLew/auto/extensions/GL_NV_fragment_program_option new file mode 100644 index 0000000000..7af9731bd8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_fragment_program_option @@ -0,0 +1,3 @@ +GL_NV_fragment_program_option +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_fragment_program_option.txt +GL_NV_fragment_program_option diff --git a/Externals/GLew/auto/extensions/GL_NV_framebuffer_multisample_coverage b/Externals/GLew/auto/extensions/GL_NV_framebuffer_multisample_coverage new file mode 100644 index 0000000000..d1d066056c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_framebuffer_multisample_coverage @@ -0,0 +1,8 @@ +GL_NV_framebuffer_multisample_coverage +http://developer.download.nvidia.com/opengl/specs/GL_NV_framebuffer_multisample_coverage.txt +GL_NV_framebuffer_multisample_coverage + GL_RENDERBUFFER_COVERAGE_SAMPLES_NV 0x8CAB + GL_RENDERBUFFER_COLOR_SAMPLES_NV 0x8E10 + GL_MAX_MULTISAMPLE_COVERAGE_MODES_NV 0x8E11 + GL_MULTISAMPLE_COVERAGE_MODES_NV 0x8E12 + void glRenderbufferStorageMultisampleCoverageNV (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/extensions/GL_NV_geometry_program4 b/Externals/GLew/auto/extensions/GL_NV_geometry_program4 new file mode 100644 index 0000000000..3f82b195d3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_geometry_program4 @@ -0,0 +1,7 @@ +GL_NV_geometry_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_geometry_program4.txt +GL_NV_gpu_program4 + GL_GEOMETRY_PROGRAM_NV 0x8C26 + GL_MAX_PROGRAM_OUTPUT_VERTICES_NV 0x8C27 + GL_MAX_PROGRAM_TOTAL_OUTPUT_COMPONENTS_NV 0x8C28 + void glProgramVertexLimitNV (GLenum target, GLint limit) diff --git a/Externals/GLew/auto/extensions/GL_NV_geometry_shader4 b/Externals/GLew/auto/extensions/GL_NV_geometry_shader4 new file mode 100644 index 0000000000..2040c0dbb3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_geometry_shader4 @@ -0,0 +1,3 @@ +GL_NV_geometry_shader4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_geometry_shader4.txt +GL_NV_geometry_shader4 diff --git a/Externals/GLew/auto/extensions/GL_NV_gpu_program4 b/Externals/GLew/auto/extensions/GL_NV_gpu_program4 new file mode 100644 index 0000000000..030f68e1cc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_gpu_program4 @@ -0,0 +1,23 @@ +GL_NV_gpu_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_gpu_program4.txt +GL_NV_gpu_program4 + GL_MIN_PROGRAM_TEXEL_OFFSET_NV 0x8904 + GL_MAX_PROGRAM_TEXEL_OFFSET_NV 0x8905 + GL_PROGRAM_ATTRIB_COMPONENTS_NV 0x8906 + GL_PROGRAM_RESULT_COMPONENTS_NV 0x8907 + GL_MAX_PROGRAM_ATTRIB_COMPONENTS_NV 0x8908 + GL_MAX_PROGRAM_RESULT_COMPONENTS_NV 0x8909 + GL_MAX_PROGRAM_GENERIC_ATTRIBS_NV 0x8DA5 + GL_MAX_PROGRAM_GENERIC_RESULTS_NV 0x8DA6 + void glProgramLocalParameterI4iNV (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w) + void glProgramLocalParameterI4ivNV (GLenum target, GLuint index, const GLint *params) + void glProgramLocalParametersI4ivNV (GLenum target, GLuint index, GLsizei count, const GLint *params) + void glProgramLocalParameterI4uiNV (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w) + void glProgramLocalParameterI4uivNV (GLenum target, GLuint index, const GLuint *params) + void glProgramLocalParametersI4uivNV (GLenum target, GLuint index, GLsizei count, const GLuint *params) + void glProgramEnvParameterI4iNV (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w) + void glProgramEnvParameterI4ivNV (GLenum target, GLuint index, const GLint *params) + void glProgramEnvParametersI4ivNV (GLenum target, GLuint index, GLsizei count, const GLint *params) + void glProgramEnvParameterI4uiNV (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w) + void glProgramEnvParameterI4uivNV (GLenum target, GLuint index, const GLuint *params) + void glProgramEnvParametersI4uivNV (GLenum target, GLuint index, GLsizei count, const GLuint *params) diff --git a/Externals/GLew/auto/extensions/GL_NV_gpu_program5 b/Externals/GLew/auto/extensions/GL_NV_gpu_program5 new file mode 100644 index 0000000000..b9e387bcc6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_gpu_program5 @@ -0,0 +1,7 @@ +GL_NV_gpu_program5 +http://www.opengl.org/registry/specs/NV/gpu_program5.txt +GL_NV_gpu_program5 + GL_MAX_GEOMETRY_PROGRAM_INVOCATIONS_NV 0x8E5A + GL_MIN_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5B + GL_MAX_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5C + GL_FRAGMENT_PROGRAM_INTERPOLATION_OFFSET_BITS_NV 0x8E5D diff --git a/Externals/GLew/auto/extensions/GL_NV_gpu_program_fp64 b/Externals/GLew/auto/extensions/GL_NV_gpu_program_fp64 new file mode 100644 index 0000000000..b710ca5915 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_gpu_program_fp64 @@ -0,0 +1,3 @@ +GL_NV_gpu_program_fp64 +http://www.opengl.org/registry/specs/NV/gpu_program5.txt +GL_NV_gpu_program_fp64 diff --git a/Externals/GLew/auto/extensions/GL_NV_gpu_shader5 b/Externals/GLew/auto/extensions/GL_NV_gpu_shader5 new file mode 100644 index 0000000000..705286ed92 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_gpu_shader5 @@ -0,0 +1,65 @@ +GL_NV_gpu_shader5 +http://www.opengl.org/registry/specs/NV/gpu_shader5.txt +GL_NV_gpu_shader5 + GL_INT64_NV 0x140E + GL_UNSIGNED_INT64_NV 0x140F + GL_INT8_NV 0x8FE0 + GL_INT8_VEC2_NV 0x8FE1 + GL_INT8_VEC3_NV 0x8FE2 + GL_INT8_VEC4_NV 0x8FE3 + GL_INT16_NV 0x8FE4 + GL_INT16_VEC2_NV 0x8FE5 + GL_INT16_VEC3_NV 0x8FE6 + GL_INT16_VEC4_NV 0x8FE7 + GL_INT64_VEC2_NV 0x8FE9 + GL_INT64_VEC3_NV 0x8FEA + GL_INT64_VEC4_NV 0x8FEB + GL_UNSIGNED_INT8_NV 0x8FEC + GL_UNSIGNED_INT8_VEC2_NV 0x8FED + GL_UNSIGNED_INT8_VEC3_NV 0x8FEE + GL_UNSIGNED_INT8_VEC4_NV 0x8FEF + GL_UNSIGNED_INT16_NV 0x8FF0 + GL_UNSIGNED_INT16_VEC2_NV 0x8FF1 + GL_UNSIGNED_INT16_VEC3_NV 0x8FF2 + GL_UNSIGNED_INT16_VEC4_NV 0x8FF3 + GL_UNSIGNED_INT64_VEC2_NV 0x8FF5 + GL_UNSIGNED_INT64_VEC3_NV 0x8FF6 + GL_UNSIGNED_INT64_VEC4_NV 0x8FF7 + GL_FLOAT16_NV 0x8FF8 + GL_FLOAT16_VEC2_NV 0x8FF9 + GL_FLOAT16_VEC3_NV 0x8FFA + GL_FLOAT16_VEC4_NV 0x8FFB + void glGetUniformi64vNV (GLuint program, GLint location, GLint64EXT* params) + void glGetUniformui64vNV (GLuint program, GLint location, GLuint64EXT* params) + void glProgramUniform1i64NV (GLuint program, GLint location, GLint64EXT x) + void glProgramUniform1i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT* value) + void glProgramUniform1ui64NV (GLuint program, GLint location, GLuint64EXT x) + void glProgramUniform1ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value) + void glProgramUniform2i64NV (GLuint program, GLint location, GLint64EXT x, GLint64EXT y) + void glProgramUniform2i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT* value) + void glProgramUniform2ui64NV (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y) + void glProgramUniform2ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value) + void glProgramUniform3i64NV (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z) + void glProgramUniform3i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT* value) + void glProgramUniform3ui64NV (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z) + void glProgramUniform3ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value) + void glProgramUniform4i64NV (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w) + void glProgramUniform4i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT* value) + void glProgramUniform4ui64NV (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w) + void glProgramUniform4ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value) + void glUniform1i64NV (GLint location, GLint64EXT x) + void glUniform1i64vNV (GLint location, GLsizei count, const GLint64EXT* value) + void glUniform1ui64NV (GLint location, GLuint64EXT x) + void glUniform1ui64vNV (GLint location, GLsizei count, const GLuint64EXT* value) + void glUniform2i64NV (GLint location, GLint64EXT x, GLint64EXT y) + void glUniform2i64vNV (GLint location, GLsizei count, const GLint64EXT* value) + void glUniform2ui64NV (GLint location, GLuint64EXT x, GLuint64EXT y) + void glUniform2ui64vNV (GLint location, GLsizei count, const GLuint64EXT* value) + void glUniform3i64NV (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z) + void glUniform3i64vNV (GLint location, GLsizei count, const GLint64EXT* value) + void glUniform3ui64NV (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z) + void glUniform3ui64vNV (GLint location, GLsizei count, const GLuint64EXT* value) + void glUniform4i64NV (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w) + void glUniform4i64vNV (GLint location, GLsizei count, const GLint64EXT* value) + void glUniform4ui64NV (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w) + void glUniform4ui64vNV (GLint location, GLsizei count, const GLuint64EXT* value) diff --git a/Externals/GLew/auto/extensions/GL_NV_half_float b/Externals/GLew/auto/extensions/GL_NV_half_float new file mode 100644 index 0000000000..ca309e98e5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_half_float @@ -0,0 +1,51 @@ +GL_NV_half_float +http://www.opengl.org/registry/specs/NV/half_float.txt +GL_NV_half_float + GL_HALF_FLOAT_NV 0x140B + void glColor3hNV (GLhalf red, GLhalf green, GLhalf blue) + void glColor3hvNV (const GLhalf* v) + void glColor4hNV (GLhalf red, GLhalf green, GLhalf blue, GLhalf alpha) + void glColor4hvNV (const GLhalf* v) + void glFogCoordhNV (GLhalf fog) + void glFogCoordhvNV (const GLhalf* fog) + void glMultiTexCoord1hNV (GLenum target, GLhalf s) + void glMultiTexCoord1hvNV (GLenum target, const GLhalf* v) + void glMultiTexCoord2hNV (GLenum target, GLhalf s, GLhalf t) + void glMultiTexCoord2hvNV (GLenum target, const GLhalf* v) + void glMultiTexCoord3hNV (GLenum target, GLhalf s, GLhalf t, GLhalf r) + void glMultiTexCoord3hvNV (GLenum target, const GLhalf* v) + void glMultiTexCoord4hNV (GLenum target, GLhalf s, GLhalf t, GLhalf r, GLhalf q) + void glMultiTexCoord4hvNV (GLenum target, const GLhalf* v) + void glNormal3hNV (GLhalf nx, GLhalf ny, GLhalf nz) + void glNormal3hvNV (const GLhalf* v) + void glSecondaryColor3hNV (GLhalf red, GLhalf green, GLhalf blue) + void glSecondaryColor3hvNV (const GLhalf* v) + void glTexCoord1hNV (GLhalf s) + void glTexCoord1hvNV (const GLhalf* v) + void glTexCoord2hNV (GLhalf s, GLhalf t) + void glTexCoord2hvNV (const GLhalf* v) + void glTexCoord3hNV (GLhalf s, GLhalf t, GLhalf r) + void glTexCoord3hvNV (const GLhalf* v) + void glTexCoord4hNV (GLhalf s, GLhalf t, GLhalf r, GLhalf q) + void glTexCoord4hvNV (const GLhalf* v) + void glVertex2hNV (GLhalf x, GLhalf y) + void glVertex2hvNV (const GLhalf* v) + void glVertex3hNV (GLhalf x, GLhalf y, GLhalf z) + void glVertex3hvNV (const GLhalf* v) + void glVertex4hNV (GLhalf x, GLhalf y, GLhalf z, GLhalf w) + void glVertex4hvNV (const GLhalf* v) + void glVertexAttrib1hNV (GLuint index, GLhalf x) + void glVertexAttrib1hvNV (GLuint index, const GLhalf* v) + void glVertexAttrib2hNV (GLuint index, GLhalf x, GLhalf y) + void glVertexAttrib2hvNV (GLuint index, const GLhalf* v) + void glVertexAttrib3hNV (GLuint index, GLhalf x, GLhalf y, GLhalf z) + void glVertexAttrib3hvNV (GLuint index, const GLhalf* v) + void glVertexAttrib4hNV (GLuint index, GLhalf x, GLhalf y, GLhalf z, GLhalf w) + void glVertexAttrib4hvNV (GLuint index, const GLhalf* v) + void glVertexAttribs1hvNV (GLuint index, GLsizei n, const GLhalf* v) + void glVertexAttribs2hvNV (GLuint index, GLsizei n, const GLhalf* v) + void glVertexAttribs3hvNV (GLuint index, GLsizei n, const GLhalf* v) + void glVertexAttribs4hvNV (GLuint index, GLsizei n, const GLhalf* v) + void glVertexWeighthNV (GLhalf weight) + void glVertexWeighthvNV (const GLhalf* weight) + typedef unsigned short GLhalf diff --git a/Externals/GLew/auto/extensions/GL_NV_light_max_exponent b/Externals/GLew/auto/extensions/GL_NV_light_max_exponent new file mode 100644 index 0000000000..cacd6a2322 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_light_max_exponent @@ -0,0 +1,5 @@ +GL_NV_light_max_exponent +http://www.opengl.org/registry/specs/NV/light_max_exponent.txt +GL_NV_light_max_exponent + GL_MAX_SHININESS_NV 0x8504 + GL_MAX_SPOT_EXPONENT_NV 0x8505 diff --git a/Externals/GLew/auto/extensions/GL_NV_multisample_filter_hint b/Externals/GLew/auto/extensions/GL_NV_multisample_filter_hint new file mode 100644 index 0000000000..cad0240663 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_multisample_filter_hint @@ -0,0 +1,4 @@ +GL_NV_multisample_filter_hint +http://www.opengl.org/registry/specs/NV/multisample_filter_hint.txt +GL_NV_multisample_filter_hint + GL_MULTISAMPLE_FILTER_HINT_NV 0x8534 diff --git a/Externals/GLew/auto/extensions/GL_NV_occlusion_query b/Externals/GLew/auto/extensions/GL_NV_occlusion_query new file mode 100644 index 0000000000..b3b1a14611 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_occlusion_query @@ -0,0 +1,14 @@ +GL_NV_occlusion_query +http://www.opengl.org/registry/specs/NV/occlusion_query.txt +GL_NV_occlusion_query + GL_PIXEL_COUNTER_BITS_NV 0x8864 + GL_CURRENT_OCCLUSION_QUERY_ID_NV 0x8865 + GL_PIXEL_COUNT_NV 0x8866 + GL_PIXEL_COUNT_AVAILABLE_NV 0x8867 + void glBeginOcclusionQueryNV (GLuint id) + void glDeleteOcclusionQueriesNV (GLsizei n, const GLuint* ids) + void glEndOcclusionQueryNV (void) + void glGenOcclusionQueriesNV (GLsizei n, GLuint* ids) + void glGetOcclusionQueryivNV (GLuint id, GLenum pname, GLint* params) + void glGetOcclusionQueryuivNV (GLuint id, GLenum pname, GLuint* params) + GLboolean glIsOcclusionQueryNV (GLuint id) diff --git a/Externals/GLew/auto/extensions/GL_NV_packed_depth_stencil b/Externals/GLew/auto/extensions/GL_NV_packed_depth_stencil new file mode 100644 index 0000000000..e0de7abe55 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_packed_depth_stencil @@ -0,0 +1,5 @@ +GL_NV_packed_depth_stencil +http://www.opengl.org/registry/specs/NV/packed_depth_stencil.txt +GL_NV_packed_depth_stencil + GL_DEPTH_STENCIL_NV 0x84F9 + GL_UNSIGNED_INT_24_8_NV 0x84FA diff --git a/Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object b/Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object new file mode 100644 index 0000000000..d2525a1766 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object @@ -0,0 +1,11 @@ +GL_NV_parameter_buffer_object +http://developer.download.nvidia.com/opengl/specs/GL_NV_parameter_buffer_object.txt +GL_NV_parameter_buffer_object + GL_VERTEX_PROGRAM_PARAMETER_BUFFER_NV 0x8DA2 + GL_GEOMETRY_PROGRAM_PARAMETER_BUFFER_NV 0x8DA3 + GL_FRAGMENT_PROGRAM_PARAMETER_BUFFER_NV 0x8DA4 + GL_MAX_PROGRAM_PARAMETER_BUFFER_BINDINGS_NV 0x8DA0 + GL_MAX_PROGRAM_PARAMETER_BUFFER_SIZE_NV 0x8DA1 + void glProgramBufferParametersfvNV (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLfloat *params) + void glProgramBufferParametersIivNV (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLint *params) + void glProgramBufferParametersIuivNV (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLuint *params) diff --git a/Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object2 b/Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object2 new file mode 100644 index 0000000000..d281d02f7e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_parameter_buffer_object2 @@ -0,0 +1,3 @@ +GL_NV_parameter_buffer_object2 +http://www.opengl.org/registry/specs/NV/parameter_buffer_object2.txt +GL_NV_parameter_buffer_object2 diff --git a/Externals/GLew/auto/extensions/GL_NV_pixel_data_range b/Externals/GLew/auto/extensions/GL_NV_pixel_data_range new file mode 100644 index 0000000000..dd18c9c61e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_pixel_data_range @@ -0,0 +1,11 @@ +GL_NV_pixel_data_range +http://www.opengl.org/registry/specs/NV/pixel_data_range.txt +GL_NV_pixel_data_range + GL_WRITE_PIXEL_DATA_RANGE_NV 0x8878 + GL_READ_PIXEL_DATA_RANGE_NV 0x8879 + GL_WRITE_PIXEL_DATA_RANGE_LENGTH_NV 0x887A + GL_READ_PIXEL_DATA_RANGE_LENGTH_NV 0x887B + GL_WRITE_PIXEL_DATA_RANGE_POINTER_NV 0x887C + GL_READ_PIXEL_DATA_RANGE_POINTER_NV 0x887D + void glFlushPixelDataRangeNV (GLenum target) + void glPixelDataRangeNV (GLenum target, GLsizei length, void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_NV_point_sprite b/Externals/GLew/auto/extensions/GL_NV_point_sprite new file mode 100644 index 0000000000..cb79d31eae --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_point_sprite @@ -0,0 +1,8 @@ +GL_NV_point_sprite +http://www.opengl.org/registry/specs/NV/point_sprite.txt +GL_NV_point_sprite + GL_POINT_SPRITE_NV 0x8861 + GL_COORD_REPLACE_NV 0x8862 + GL_POINT_SPRITE_R_MODE_NV 0x8863 + void glPointParameteriNV (GLenum pname, GLint param) + void glPointParameterivNV (GLenum pname, const GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_NV_present_video b/Externals/GLew/auto/extensions/GL_NV_present_video new file mode 100644 index 0000000000..893c74c8e9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_present_video @@ -0,0 +1,15 @@ +GL_NV_present_video +http://www.opengl.org/registry/specs/NV/present_video.txt +GL_NV_present_video + GL_FRAME_NV 0x8E26 + GL_FIELDS_NV 0x8E27 + GL_CURRENT_TIME_NV 0x8E28 + GL_NUM_FILL_STREAMS_NV 0x8E29 + GL_PRESENT_TIME_NV 0x8E2A + GL_PRESENT_DURATION_NV 0x8E2B + void glGetVideoi64vNV (GLuint video_slot, GLenum pname, GLint64EXT* params) + void glGetVideoivNV (GLuint video_slot, GLenum pname, GLint* params) + void glGetVideoui64vNV (GLuint video_slot, GLenum pname, GLuint64EXT* params) + void glGetVideouivNV (GLuint video_slot, GLenum pname, GLuint* params) + void glPresentFrameDualFillNV (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLenum target1, GLuint fill1, GLenum target2, GLuint fill2, GLenum target3, GLuint fill3) + void glPresentFrameKeyedNV (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLuint key0, GLenum target1, GLuint fill1, GLuint key1) diff --git a/Externals/GLew/auto/extensions/GL_NV_primitive_restart b/Externals/GLew/auto/extensions/GL_NV_primitive_restart new file mode 100644 index 0000000000..ebd1f7af1b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_primitive_restart @@ -0,0 +1,7 @@ +GL_NV_primitive_restart +http://www.opengl.org/registry/specs/NV/primitive_restart.txt +GL_NV_primitive_restart + GL_PRIMITIVE_RESTART_NV 0x8558 + GL_PRIMITIVE_RESTART_INDEX_NV 0x8559 + void glPrimitiveRestartIndexNV (GLuint index) + void glPrimitiveRestartNV (void) diff --git a/Externals/GLew/auto/extensions/GL_NV_register_combiners b/Externals/GLew/auto/extensions/GL_NV_register_combiners new file mode 100644 index 0000000000..e9255ab6f7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_register_combiners @@ -0,0 +1,67 @@ +GL_NV_register_combiners +http://www.opengl.org/registry/specs/NV/register_combiners.txt +GL_NV_register_combiners + GL_REGISTER_COMBINERS_NV 0x8522 + GL_VARIABLE_A_NV 0x8523 + GL_VARIABLE_B_NV 0x8524 + GL_VARIABLE_C_NV 0x8525 + GL_VARIABLE_D_NV 0x8526 + GL_VARIABLE_E_NV 0x8527 + GL_VARIABLE_F_NV 0x8528 + GL_VARIABLE_G_NV 0x8529 + GL_CONSTANT_COLOR0_NV 0x852A + GL_CONSTANT_COLOR1_NV 0x852B + GL_PRIMARY_COLOR_NV 0x852C + GL_SECONDARY_COLOR_NV 0x852D + GL_SPARE0_NV 0x852E + GL_SPARE1_NV 0x852F + GL_DISCARD_NV 0x8530 + GL_E_TIMES_F_NV 0x8531 + GL_SPARE0_PLUS_SECONDARY_COLOR_NV 0x8532 + GL_UNSIGNED_IDENTITY_NV 0x8536 + GL_UNSIGNED_INVERT_NV 0x8537 + GL_EXPAND_NORMAL_NV 0x8538 + GL_EXPAND_NEGATE_NV 0x8539 + GL_HALF_BIAS_NORMAL_NV 0x853A + GL_HALF_BIAS_NEGATE_NV 0x853B + GL_SIGNED_IDENTITY_NV 0x853C + GL_SIGNED_NEGATE_NV 0x853D + GL_SCALE_BY_TWO_NV 0x853E + GL_SCALE_BY_FOUR_NV 0x853F + GL_SCALE_BY_ONE_HALF_NV 0x8540 + GL_BIAS_BY_NEGATIVE_ONE_HALF_NV 0x8541 + GL_COMBINER_INPUT_NV 0x8542 + GL_COMBINER_MAPPING_NV 0x8543 + GL_COMBINER_COMPONENT_USAGE_NV 0x8544 + GL_COMBINER_AB_DOT_PRODUCT_NV 0x8545 + GL_COMBINER_CD_DOT_PRODUCT_NV 0x8546 + GL_COMBINER_MUX_SUM_NV 0x8547 + GL_COMBINER_SCALE_NV 0x8548 + GL_COMBINER_BIAS_NV 0x8549 + GL_COMBINER_AB_OUTPUT_NV 0x854A + GL_COMBINER_CD_OUTPUT_NV 0x854B + GL_COMBINER_SUM_OUTPUT_NV 0x854C + GL_MAX_GENERAL_COMBINERS_NV 0x854D + GL_NUM_GENERAL_COMBINERS_NV 0x854E + GL_COLOR_SUM_CLAMP_NV 0x854F + GL_COMBINER0_NV 0x8550 + GL_COMBINER1_NV 0x8551 + GL_COMBINER2_NV 0x8552 + GL_COMBINER3_NV 0x8553 + GL_COMBINER4_NV 0x8554 + GL_COMBINER5_NV 0x8555 + GL_COMBINER6_NV 0x8556 + GL_COMBINER7_NV 0x8557 + void glCombinerInputNV (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage) + void glCombinerOutputNV (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum) + void glCombinerParameterfNV (GLenum pname, GLfloat param) + void glCombinerParameterfvNV (GLenum pname, const GLfloat* params) + void glCombinerParameteriNV (GLenum pname, GLint param) + void glCombinerParameterivNV (GLenum pname, const GLint* params) + void glFinalCombinerInputNV (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage) + void glGetCombinerInputParameterfvNV (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat* params) + void glGetCombinerInputParameterivNV (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint* params) + void glGetCombinerOutputParameterfvNV (GLenum stage, GLenum portion, GLenum pname, GLfloat* params) + void glGetCombinerOutputParameterivNV (GLenum stage, GLenum portion, GLenum pname, GLint* params) + void glGetFinalCombinerInputParameterfvNV (GLenum variable, GLenum pname, GLfloat* params) + void glGetFinalCombinerInputParameterivNV (GLenum variable, GLenum pname, GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_NV_register_combiners2 b/Externals/GLew/auto/extensions/GL_NV_register_combiners2 new file mode 100644 index 0000000000..166db2547d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_register_combiners2 @@ -0,0 +1,6 @@ +GL_NV_register_combiners2 +http://www.opengl.org/registry/specs/NV/register_combiners2.txt +GL_NV_register_combiners2 + GL_PER_STAGE_CONSTANTS_NV 0x8535 + void glCombinerStageParameterfvNV (GLenum stage, GLenum pname, const GLfloat* params) + void glGetCombinerStageParameterfvNV (GLenum stage, GLenum pname, GLfloat* params) diff --git a/Externals/GLew/auto/extensions/GL_NV_shader_buffer_load b/Externals/GLew/auto/extensions/GL_NV_shader_buffer_load new file mode 100644 index 0000000000..e58a6b14a8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_shader_buffer_load @@ -0,0 +1,19 @@ +GL_NV_shader_buffer_load +http://www.opengl.org/registry/specs/NV/shader_buffer_load.txt +GL_NV_shader_buffer_load + GL_BUFFER_GPU_ADDRESS_NV 0x8F1D + GL_GPU_ADDRESS_NV 0x8F34 + GL_MAX_SHADER_BUFFER_ADDRESS_NV 0x8F35 + void glGetBufferParameterui64vNV (GLenum target, GLenum pname, GLuint64EXT* params) + void glGetIntegerui64vNV (GLenum value, GLuint64EXT* result) + void glGetNamedBufferParameterui64vNV (GLuint buffer, GLenum pname, GLuint64EXT* params) + GLboolean glIsBufferResidentNV (GLenum target) + GLboolean glIsNamedBufferResidentNV (GLuint buffer) + void glMakeBufferNonResidentNV (GLenum target) + void glMakeBufferResidentNV (GLenum target, GLenum access) + void glMakeNamedBufferNonResidentNV (GLuint buffer) + void glMakeNamedBufferResidentNV (GLuint buffer, GLenum access) + void glProgramUniformui64NV (GLuint program, GLint location, GLuint64EXT value) + void glProgramUniformui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value) + void glUniformui64NV (GLint location, GLuint64EXT value) + void glUniformui64vNV (GLint location, GLsizei count, const GLuint64EXT* value) diff --git a/Externals/GLew/auto/extensions/GL_NV_tessellation_program5 b/Externals/GLew/auto/extensions/GL_NV_tessellation_program5 new file mode 100644 index 0000000000..b663c974dc --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_tessellation_program5 @@ -0,0 +1,8 @@ +GL_NV_tessellation_program5 +http://www.opengl.org/registry/specs/NV/tessellation_program5.txt +GL_NV_gpu_program5 + GL_MAX_PROGRAM_PATCH_ATTRIBS_NV 0x86D8 + GL_TESS_CONTROL_PROGRAM_NV 0x891E + GL_TESS_EVALUATION_PROGRAM_NV 0x891F + GL_TESS_CONTROL_PROGRAM_PARAMETER_BUFFER_NV 0x8C74 + GL_TESS_EVALUATION_PROGRAM_PARAMETER_BUFFER_NV 0x8C75 diff --git a/Externals/GLew/auto/extensions/GL_NV_texgen_emboss b/Externals/GLew/auto/extensions/GL_NV_texgen_emboss new file mode 100644 index 0000000000..0b7492e171 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texgen_emboss @@ -0,0 +1,6 @@ +GL_NV_texgen_emboss +http://www.opengl.org/registry/specs/NV/texgen_emboss.txt +GL_NV_texgen_emboss + GL_EMBOSS_LIGHT_NV 0x855D + GL_EMBOSS_CONSTANT_NV 0x855E + GL_EMBOSS_MAP_NV 0x855F diff --git a/Externals/GLew/auto/extensions/GL_NV_texgen_reflection b/Externals/GLew/auto/extensions/GL_NV_texgen_reflection new file mode 100644 index 0000000000..252b3d1ab1 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texgen_reflection @@ -0,0 +1,5 @@ +GL_NV_texgen_reflection +http://www.opengl.org/registry/specs/NV/texgen_reflection.txt +GL_NV_texgen_reflection + GL_NORMAL_MAP_NV 0x8511 + GL_REFLECTION_MAP_NV 0x8512 diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_barrier b/Externals/GLew/auto/extensions/GL_NV_texture_barrier new file mode 100644 index 0000000000..ec6ce68483 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_barrier @@ -0,0 +1,4 @@ +GL_NV_texture_barrier +http://www.opengl.org/registry/specs/NV/texture_barrier.txt +GL_NV_texture_barrier + void glTextureBarrierNV (void) diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_compression_vtc b/Externals/GLew/auto/extensions/GL_NV_texture_compression_vtc new file mode 100644 index 0000000000..86cfb6e90b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_compression_vtc @@ -0,0 +1,3 @@ +GL_NV_texture_compression_vtc +http://www.opengl.org/registry/specs/NV/texture_compression_vtc.txt +GL_NV_texture_compression_vtc diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_env_combine4 b/Externals/GLew/auto/extensions/GL_NV_texture_env_combine4 new file mode 100644 index 0000000000..1e1adab484 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_env_combine4 @@ -0,0 +1,8 @@ +GL_NV_texture_env_combine4 +http://www.opengl.org/registry/specs/NV/texture_env_combine4.txt +GL_NV_texture_env_combine4 + GL_COMBINE4_NV 0x8503 + GL_SOURCE3_RGB_NV 0x8583 + GL_SOURCE3_ALPHA_NV 0x858B + GL_OPERAND3_RGB_NV 0x8593 + GL_OPERAND3_ALPHA_NV 0x859B diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_expand_normal b/Externals/GLew/auto/extensions/GL_NV_texture_expand_normal new file mode 100644 index 0000000000..9d9b39b0d6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_expand_normal @@ -0,0 +1,4 @@ +GL_NV_texture_expand_normal +http://www.opengl.org/registry/specs/NV/texture_expand_normal.txt +GL_NV_texture_expand_normal + GL_TEXTURE_UNSIGNED_REMAP_MODE_NV 0x888F diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_rectangle b/Externals/GLew/auto/extensions/GL_NV_texture_rectangle new file mode 100644 index 0000000000..4da2762c44 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_rectangle @@ -0,0 +1,7 @@ +GL_NV_texture_rectangle +http://www.opengl.org/registry/specs/NV/texture_rectangle.txt +GL_NV_texture_rectangle + GL_TEXTURE_RECTANGLE_NV 0x84F5 + GL_TEXTURE_BINDING_RECTANGLE_NV 0x84F6 + GL_PROXY_TEXTURE_RECTANGLE_NV 0x84F7 + GL_MAX_RECTANGLE_TEXTURE_SIZE_NV 0x84F8 diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_shader b/Externals/GLew/auto/extensions/GL_NV_texture_shader new file mode 100644 index 0000000000..826db8f6a7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_shader @@ -0,0 +1,76 @@ +GL_NV_texture_shader +http://www.opengl.org/registry/specs/NV/texture_shader.txt +GL_NV_texture_shader + GL_OFFSET_TEXTURE_RECTANGLE_NV 0x864C + GL_OFFSET_TEXTURE_RECTANGLE_SCALE_NV 0x864D + GL_DOT_PRODUCT_TEXTURE_RECTANGLE_NV 0x864E + GL_RGBA_UNSIGNED_DOT_PRODUCT_MAPPING_NV 0x86D9 + GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA + GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB + GL_DSDT_MAG_INTENSITY_NV 0x86DC + GL_SHADER_CONSISTENT_NV 0x86DD + GL_TEXTURE_SHADER_NV 0x86DE + GL_SHADER_OPERATION_NV 0x86DF + GL_CULL_MODES_NV 0x86E0 + GL_OFFSET_TEXTURE_MATRIX_NV 0x86E1 + GL_OFFSET_TEXTURE_SCALE_NV 0x86E2 + GL_OFFSET_TEXTURE_BIAS_NV 0x86E3 + GL_PREVIOUS_TEXTURE_INPUT_NV 0x86E4 + GL_CONST_EYE_NV 0x86E5 + GL_PASS_THROUGH_NV 0x86E6 + GL_CULL_FRAGMENT_NV 0x86E7 + GL_OFFSET_TEXTURE_2D_NV 0x86E8 + GL_DEPENDENT_AR_TEXTURE_2D_NV 0x86E9 + GL_DEPENDENT_GB_TEXTURE_2D_NV 0x86EA + GL_DOT_PRODUCT_NV 0x86EC + GL_DOT_PRODUCT_DEPTH_REPLACE_NV 0x86ED + GL_DOT_PRODUCT_TEXTURE_2D_NV 0x86EE + GL_DOT_PRODUCT_TEXTURE_CUBE_MAP_NV 0x86F0 + GL_DOT_PRODUCT_DIFFUSE_CUBE_MAP_NV 0x86F1 + GL_DOT_PRODUCT_REFLECT_CUBE_MAP_NV 0x86F2 + GL_DOT_PRODUCT_CONST_EYE_REFLECT_CUBE_MAP_NV 0x86F3 + GL_HILO_NV 0x86F4 + GL_DSDT_NV 0x86F5 + GL_DSDT_MAG_NV 0x86F6 + GL_DSDT_MAG_VIB_NV 0x86F7 + GL_HILO16_NV 0x86F8 + GL_SIGNED_HILO_NV 0x86F9 + GL_SIGNED_HILO16_NV 0x86FA + GL_SIGNED_RGBA_NV 0x86FB + GL_SIGNED_RGBA8_NV 0x86FC + GL_SIGNED_RGB_NV 0x86FE + GL_SIGNED_RGB8_NV 0x86FF + GL_SIGNED_LUMINANCE_NV 0x8701 + GL_SIGNED_LUMINANCE8_NV 0x8702 + GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 + GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 + GL_SIGNED_ALPHA_NV 0x8705 + GL_SIGNED_ALPHA8_NV 0x8706 + GL_SIGNED_INTENSITY_NV 0x8707 + GL_SIGNED_INTENSITY8_NV 0x8708 + GL_DSDT8_NV 0x8709 + GL_DSDT8_MAG8_NV 0x870A + GL_DSDT8_MAG8_INTENSITY8_NV 0x870B + GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C + GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D + GL_HI_SCALE_NV 0x870E + GL_LO_SCALE_NV 0x870F + GL_DS_SCALE_NV 0x8710 + GL_DT_SCALE_NV 0x8711 + GL_MAGNITUDE_SCALE_NV 0x8712 + GL_VIBRANCE_SCALE_NV 0x8713 + GL_HI_BIAS_NV 0x8714 + GL_LO_BIAS_NV 0x8715 + GL_DS_BIAS_NV 0x8716 + GL_DT_BIAS_NV 0x8717 + GL_MAGNITUDE_BIAS_NV 0x8718 + GL_VIBRANCE_BIAS_NV 0x8719 + GL_TEXTURE_BORDER_VALUES_NV 0x871A + GL_TEXTURE_HI_SIZE_NV 0x871B + GL_TEXTURE_LO_SIZE_NV 0x871C + GL_TEXTURE_DS_SIZE_NV 0x871D + GL_TEXTURE_DT_SIZE_NV 0x871E + GL_TEXTURE_MAG_SIZE_NV 0x871F + GL_OFFSET_TEXTURE_2D_MATRIX_NV 0x86E1 + GL_OFFSET_TEXTURE_2D_BIAS_NV 0x86E3 + GL_OFFSET_TEXTURE_2D_SCALE_NV 0x86E2 diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_shader2 b/Externals/GLew/auto/extensions/GL_NV_texture_shader2 new file mode 100644 index 0000000000..c5cc92d0f6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_shader2 @@ -0,0 +1,31 @@ +GL_NV_texture_shader2 +http://www.opengl.org/registry/specs/NV/texture_shader2.txt +GL_NV_texture_shader2 + GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA + GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB + GL_DSDT_MAG_INTENSITY_NV 0x86DC + GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF + GL_HILO_NV 0x86F4 + GL_DSDT_NV 0x86F5 + GL_DSDT_MAG_NV 0x86F6 + GL_DSDT_MAG_VIB_NV 0x86F7 + GL_HILO16_NV 0x86F8 + GL_SIGNED_HILO_NV 0x86F9 + GL_SIGNED_HILO16_NV 0x86FA + GL_SIGNED_RGBA_NV 0x86FB + GL_SIGNED_RGBA8_NV 0x86FC + GL_SIGNED_RGB_NV 0x86FE + GL_SIGNED_RGB8_NV 0x86FF + GL_SIGNED_LUMINANCE_NV 0x8701 + GL_SIGNED_LUMINANCE8_NV 0x8702 + GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 + GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 + GL_SIGNED_ALPHA_NV 0x8705 + GL_SIGNED_ALPHA8_NV 0x8706 + GL_SIGNED_INTENSITY_NV 0x8707 + GL_SIGNED_INTENSITY8_NV 0x8708 + GL_DSDT8_NV 0x8709 + GL_DSDT8_MAG8_NV 0x870A + GL_DSDT8_MAG8_INTENSITY8_NV 0x870B + GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C + GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D diff --git a/Externals/GLew/auto/extensions/GL_NV_texture_shader3 b/Externals/GLew/auto/extensions/GL_NV_texture_shader3 new file mode 100644 index 0000000000..5cc042b0da --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_texture_shader3 @@ -0,0 +1,20 @@ +GL_NV_texture_shader3 +http://www.opengl.org/registry/specs/NV/texture_shader3.txt +GL_NV_texture_shader3 + GL_OFFSET_PROJECTIVE_TEXTURE_2D_NV 0x8850 + GL_OFFSET_PROJECTIVE_TEXTURE_2D_SCALE_NV 0x8851 + GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8852 + GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_SCALE_NV 0x8853 + GL_OFFSET_HILO_TEXTURE_2D_NV 0x8854 + GL_OFFSET_HILO_TEXTURE_RECTANGLE_NV 0x8855 + GL_OFFSET_HILO_PROJECTIVE_TEXTURE_2D_NV 0x8856 + GL_OFFSET_HILO_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8857 + GL_DEPENDENT_HILO_TEXTURE_2D_NV 0x8858 + GL_DEPENDENT_RGB_TEXTURE_3D_NV 0x8859 + GL_DEPENDENT_RGB_TEXTURE_CUBE_MAP_NV 0x885A + GL_DOT_PRODUCT_PASS_THROUGH_NV 0x885B + GL_DOT_PRODUCT_TEXTURE_1D_NV 0x885C + GL_DOT_PRODUCT_AFFINE_DEPTH_REPLACE_NV 0x885D + GL_HILO8_NV 0x885E + GL_SIGNED_HILO8_NV 0x885F + GL_FORCE_BLUE_TO_ONE_NV 0x8860 diff --git a/Externals/GLew/auto/extensions/GL_NV_transform_feedback b/Externals/GLew/auto/extensions/GL_NV_transform_feedback new file mode 100644 index 0000000000..fce47571e8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_transform_feedback @@ -0,0 +1,39 @@ +GL_NV_transform_feedback +http://developer.download.nvidia.com/opengl/specs/GL_NV_transform_feedback.txt +GL_NV_transform_feedback + GL_BACK_PRIMARY_COLOR_NV 0x8C77 + GL_BACK_SECONDARY_COLOR_NV 0x8C78 + GL_TEXTURE_COORD_NV 0x8C79 + GL_CLIP_DISTANCE_NV 0x8C7A + GL_VERTEX_ID_NV 0x8C7B + GL_PRIMITIVE_ID_NV 0x8C7C + GL_GENERIC_ATTRIB_NV 0x8C7D + GL_TRANSFORM_FEEDBACK_ATTRIBS_NV 0x8C7E + GL_TRANSFORM_FEEDBACK_BUFFER_MODE_NV 0x8C7F + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_NV 0x8C80 + GL_ACTIVE_VARYINGS_NV 0x8C81 + GL_ACTIVE_VARYING_MAX_LENGTH_NV 0x8C82 + GL_TRANSFORM_FEEDBACK_VARYINGS_NV 0x8C83 + GL_TRANSFORM_FEEDBACK_BUFFER_START_NV 0x8C84 + GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_NV 0x8C85 + GL_TRANSFORM_FEEDBACK_RECORD_NV 0x8C86 + GL_PRIMITIVES_GENERATED_NV 0x8C87 + GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_NV 0x8C88 + GL_RASTERIZER_DISCARD_NV 0x8C89 + GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_NV 0x8C8A + GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_NV 0x8C8B + GL_INTERLEAVED_ATTRIBS_NV 0x8C8C + GL_SEPARATE_ATTRIBS_NV 0x8C8D + GL_TRANSFORM_FEEDBACK_BUFFER_NV 0x8C8E + GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_NV 0x8C8F + void glBeginTransformFeedbackNV (GLenum primitiveMode) + void glEndTransformFeedbackNV (void) + void glTransformFeedbackAttribsNV (GLuint count, const GLint *attribs, GLenum bufferMode) + void glBindBufferRangeNV (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size) + void glBindBufferOffsetNV (GLenum target, GLuint index, GLuint buffer, GLintptr offset) + void glBindBufferBaseNV (GLenum target, GLuint index, GLuint buffer) + void glTransformFeedbackVaryingsNV (GLuint program, GLsizei count, const GLint *locations, GLenum bufferMode) + void glActiveVaryingNV (GLuint program, const GLchar *name) + GLint glGetVaryingLocationNV (GLuint program, const GLchar *name) + void glGetActiveVaryingNV (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name) + void glGetTransformFeedbackVaryingNV (GLuint program, GLuint index, GLint *location) diff --git a/Externals/GLew/auto/extensions/GL_NV_transform_feedback2 b/Externals/GLew/auto/extensions/GL_NV_transform_feedback2 new file mode 100644 index 0000000000..5513687281 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_transform_feedback2 @@ -0,0 +1,14 @@ +GL_NV_transform_feedback2 +http://www.opengl.org/registry/specs/NV/transform_feedback2.txt +GL_NV_transform_feedback2 + GL_TRANSFORM_FEEDBACK_NV 0x8E22 + GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED_NV 0x8E23 + GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE_NV 0x8E24 + GL_TRANSFORM_FEEDBACK_BINDING_NV 0x8E25 + void glBindTransformFeedbackNV (GLenum target, GLuint id) + void glDeleteTransformFeedbacksNV (GLsizei n, const GLuint* ids) + void glDrawTransformFeedbackNV (GLenum mode, GLuint id) + void glGenTransformFeedbacksNV (GLsizei n, GLuint* ids) + GLboolean glIsTransformFeedbackNV (GLuint id) + void glPauseTransformFeedbackNV (void) + void glResumeTransformFeedbackNV (void) diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_array_range b/Externals/GLew/auto/extensions/GL_NV_vertex_array_range new file mode 100644 index 0000000000..32396aa53e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_array_range @@ -0,0 +1,10 @@ +GL_NV_vertex_array_range +http://www.opengl.org/registry/specs/NV/vertex_array_range.txt +GL_NV_vertex_array_range + GL_VERTEX_ARRAY_RANGE_NV 0x851D + GL_VERTEX_ARRAY_RANGE_LENGTH_NV 0x851E + GL_VERTEX_ARRAY_RANGE_VALID_NV 0x851F + GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_NV 0x8520 + GL_VERTEX_ARRAY_RANGE_POINTER_NV 0x8521 + void glFlushVertexArrayRangeNV (void) + void glVertexArrayRangeNV (GLsizei length, void* pointer) diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_array_range2 b/Externals/GLew/auto/extensions/GL_NV_vertex_array_range2 new file mode 100644 index 0000000000..00fa72c899 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_array_range2 @@ -0,0 +1,4 @@ +GL_NV_vertex_array_range2 +http://www.opengl.org/registry/specs/NV/vertex_array_range2.txt +GL_NV_vertex_array_range2 + GL_VERTEX_ARRAY_RANGE_WITHOUT_FLUSH_NV 0x8533 diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_attrib_integer_64bit b/Externals/GLew/auto/extensions/GL_NV_vertex_attrib_integer_64bit new file mode 100644 index 0000000000..a34bb362a3 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_attrib_integer_64bit @@ -0,0 +1,24 @@ +GL_NV_vertex_attrib_integer_64bit +http://www.opengl.org/registry/specs/NV/vertex_attrib_integer_64bit.txt +GL_NV_vertex_attrib_integer_64bit + GL_INT64_NV 0x140E + GL_UNSIGNED_INT64_NV 0x140F + void glGetVertexAttribLi64vNV (GLuint index, GLenum pname, GLint64EXT* params) + void glGetVertexAttribLui64vNV (GLuint index, GLenum pname, GLuint64EXT* params) + void glVertexAttribL1i64NV (GLuint index, GLint64EXT x) + void glVertexAttribL1i64vNV (GLuint index, const GLint64EXT* v) + void glVertexAttribL1ui64NV (GLuint index, GLuint64EXT x) + void glVertexAttribL1ui64vNV (GLuint index, const GLuint64EXT* v) + void glVertexAttribL2i64NV (GLuint index, GLint64EXT x, GLint64EXT y) + void glVertexAttribL2i64vNV (GLuint index, const GLint64EXT* v) + void glVertexAttribL2ui64NV (GLuint index, GLuint64EXT x, GLuint64EXT y) + void glVertexAttribL2ui64vNV (GLuint index, const GLuint64EXT* v) + void glVertexAttribL3i64NV (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z) + void glVertexAttribL3i64vNV (GLuint index, const GLint64EXT* v) + void glVertexAttribL3ui64NV (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z) + void glVertexAttribL3ui64vNV (GLuint index, const GLuint64EXT* v) + void glVertexAttribL4i64NV (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w) + void glVertexAttribL4i64vNV (GLuint index, const GLint64EXT* v) + void glVertexAttribL4ui64NV (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w) + void glVertexAttribL4ui64vNV (GLuint index, const GLuint64EXT* v) + void glVertexAttribLFormatNV (GLuint index, GLint size, GLenum type, GLsizei stride) diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_buffer_unified_memory b/Externals/GLew/auto/extensions/GL_NV_vertex_buffer_unified_memory new file mode 100644 index 0000000000..474d4f32dd --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_buffer_unified_memory @@ -0,0 +1,37 @@ +GL_NV_vertex_buffer_unified_memory +http://www.opengl.org/registry/specs/NV/vertex_buffer_unified_memory.txt +GL_NV_vertex_buffer_unified_memory + GL_VERTEX_ATTRIB_ARRAY_UNIFIED_NV 0x8F1E + GL_ELEMENT_ARRAY_UNIFIED_NV 0x8F1F + GL_VERTEX_ATTRIB_ARRAY_ADDRESS_NV 0x8F20 + GL_VERTEX_ARRAY_ADDRESS_NV 0x8F21 + GL_NORMAL_ARRAY_ADDRESS_NV 0x8F22 + GL_COLOR_ARRAY_ADDRESS_NV 0x8F23 + GL_INDEX_ARRAY_ADDRESS_NV 0x8F24 + GL_TEXTURE_COORD_ARRAY_ADDRESS_NV 0x8F25 + GL_EDGE_FLAG_ARRAY_ADDRESS_NV 0x8F26 + GL_SECONDARY_COLOR_ARRAY_ADDRESS_NV 0x8F27 + GL_FOG_COORD_ARRAY_ADDRESS_NV 0x8F28 + GL_ELEMENT_ARRAY_ADDRESS_NV 0x8F29 + GL_VERTEX_ATTRIB_ARRAY_LENGTH_NV 0x8F2A + GL_VERTEX_ARRAY_LENGTH_NV 0x8F2B + GL_NORMAL_ARRAY_LENGTH_NV 0x8F2C + GL_COLOR_ARRAY_LENGTH_NV 0x8F2D + GL_INDEX_ARRAY_LENGTH_NV 0x8F2E + GL_TEXTURE_COORD_ARRAY_LENGTH_NV 0x8F2F + GL_EDGE_FLAG_ARRAY_LENGTH_NV 0x8F30 + GL_SECONDARY_COLOR_ARRAY_LENGTH_NV 0x8F31 + GL_FOG_COORD_ARRAY_LENGTH_NV 0x8F32 + GL_ELEMENT_ARRAY_LENGTH_NV 0x8F33 + void glBufferAddressRangeNV (GLenum pname, GLuint index, GLuint64EXT address, GLsizeiptr length) + void glColorFormatNV (GLint size, GLenum type, GLsizei stride) + void glEdgeFlagFormatNV (GLsizei stride) + void glFogCoordFormatNV (GLenum type, GLsizei stride) + void glGetIntegerui64i_vNV (GLenum value, GLuint index, GLuint64EXT result[]) + void glIndexFormatNV (GLenum type, GLsizei stride) + void glNormalFormatNV (GLenum type, GLsizei stride) + void glSecondaryColorFormatNV (GLint size, GLenum type, GLsizei stride) + void glTexCoordFormatNV (GLint size, GLenum type, GLsizei stride) + void glVertexAttribFormatNV (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride) + void glVertexAttribIFormatNV (GLuint index, GLint size, GLenum type, GLsizei stride) + void glVertexFormatNV (GLint size, GLenum type, GLsizei stride) diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_program b/Externals/GLew/auto/extensions/GL_NV_vertex_program new file mode 100644 index 0000000000..cb4cc8a972 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_program @@ -0,0 +1,150 @@ +GL_NV_vertex_program +http://www.opengl.org/registry/specs/NV/vertex_program.txt +GL_NV_vertex_program + GL_VERTEX_PROGRAM_NV 0x8620 + GL_VERTEX_STATE_PROGRAM_NV 0x8621 + GL_ATTRIB_ARRAY_SIZE_NV 0x8623 + GL_ATTRIB_ARRAY_STRIDE_NV 0x8624 + GL_ATTRIB_ARRAY_TYPE_NV 0x8625 + GL_CURRENT_ATTRIB_NV 0x8626 + GL_PROGRAM_LENGTH_NV 0x8627 + GL_PROGRAM_STRING_NV 0x8628 + GL_MODELVIEW_PROJECTION_NV 0x8629 + GL_IDENTITY_NV 0x862A + GL_INVERSE_NV 0x862B + GL_TRANSPOSE_NV 0x862C + GL_INVERSE_TRANSPOSE_NV 0x862D + GL_MAX_TRACK_MATRIX_STACK_DEPTH_NV 0x862E + GL_MAX_TRACK_MATRICES_NV 0x862F + GL_MATRIX0_NV 0x8630 + GL_MATRIX1_NV 0x8631 + GL_MATRIX2_NV 0x8632 + GL_MATRIX3_NV 0x8633 + GL_MATRIX4_NV 0x8634 + GL_MATRIX5_NV 0x8635 + GL_MATRIX6_NV 0x8636 + GL_MATRIX7_NV 0x8637 + GL_CURRENT_MATRIX_STACK_DEPTH_NV 0x8640 + GL_CURRENT_MATRIX_NV 0x8641 + GL_VERTEX_PROGRAM_POINT_SIZE_NV 0x8642 + GL_VERTEX_PROGRAM_TWO_SIDE_NV 0x8643 + GL_PROGRAM_PARAMETER_NV 0x8644 + GL_ATTRIB_ARRAY_POINTER_NV 0x8645 + GL_PROGRAM_TARGET_NV 0x8646 + GL_PROGRAM_RESIDENT_NV 0x8647 + GL_TRACK_MATRIX_NV 0x8648 + GL_TRACK_MATRIX_TRANSFORM_NV 0x8649 + GL_VERTEX_PROGRAM_BINDING_NV 0x864A + GL_PROGRAM_ERROR_POSITION_NV 0x864B + GL_VERTEX_ATTRIB_ARRAY0_NV 0x8650 + GL_VERTEX_ATTRIB_ARRAY1_NV 0x8651 + GL_VERTEX_ATTRIB_ARRAY2_NV 0x8652 + GL_VERTEX_ATTRIB_ARRAY3_NV 0x8653 + GL_VERTEX_ATTRIB_ARRAY4_NV 0x8654 + GL_VERTEX_ATTRIB_ARRAY5_NV 0x8655 + GL_VERTEX_ATTRIB_ARRAY6_NV 0x8656 + GL_VERTEX_ATTRIB_ARRAY7_NV 0x8657 + GL_VERTEX_ATTRIB_ARRAY8_NV 0x8658 + GL_VERTEX_ATTRIB_ARRAY9_NV 0x8659 + GL_VERTEX_ATTRIB_ARRAY10_NV 0x865A + GL_VERTEX_ATTRIB_ARRAY11_NV 0x865B + GL_VERTEX_ATTRIB_ARRAY12_NV 0x865C + GL_VERTEX_ATTRIB_ARRAY13_NV 0x865D + GL_VERTEX_ATTRIB_ARRAY14_NV 0x865E + GL_VERTEX_ATTRIB_ARRAY15_NV 0x865F + GL_MAP1_VERTEX_ATTRIB0_4_NV 0x8660 + GL_MAP1_VERTEX_ATTRIB1_4_NV 0x8661 + GL_MAP1_VERTEX_ATTRIB2_4_NV 0x8662 + GL_MAP1_VERTEX_ATTRIB3_4_NV 0x8663 + GL_MAP1_VERTEX_ATTRIB4_4_NV 0x8664 + GL_MAP1_VERTEX_ATTRIB5_4_NV 0x8665 + GL_MAP1_VERTEX_ATTRIB6_4_NV 0x8666 + GL_MAP1_VERTEX_ATTRIB7_4_NV 0x8667 + GL_MAP1_VERTEX_ATTRIB8_4_NV 0x8668 + GL_MAP1_VERTEX_ATTRIB9_4_NV 0x8669 + GL_MAP1_VERTEX_ATTRIB10_4_NV 0x866A + GL_MAP1_VERTEX_ATTRIB11_4_NV 0x866B + GL_MAP1_VERTEX_ATTRIB12_4_NV 0x866C + GL_MAP1_VERTEX_ATTRIB13_4_NV 0x866D + GL_MAP1_VERTEX_ATTRIB14_4_NV 0x866E + GL_MAP1_VERTEX_ATTRIB15_4_NV 0x866F + GL_MAP2_VERTEX_ATTRIB0_4_NV 0x8670 + GL_MAP2_VERTEX_ATTRIB1_4_NV 0x8671 + GL_MAP2_VERTEX_ATTRIB2_4_NV 0x8672 + GL_MAP2_VERTEX_ATTRIB3_4_NV 0x8673 + GL_MAP2_VERTEX_ATTRIB4_4_NV 0x8674 + GL_MAP2_VERTEX_ATTRIB5_4_NV 0x8675 + GL_MAP2_VERTEX_ATTRIB6_4_NV 0x8676 + GL_MAP2_VERTEX_ATTRIB7_4_NV 0x8677 + GL_MAP2_VERTEX_ATTRIB8_4_NV 0x8678 + GL_MAP2_VERTEX_ATTRIB9_4_NV 0x8679 + GL_MAP2_VERTEX_ATTRIB10_4_NV 0x867A + GL_MAP2_VERTEX_ATTRIB11_4_NV 0x867B + GL_MAP2_VERTEX_ATTRIB12_4_NV 0x867C + GL_MAP2_VERTEX_ATTRIB13_4_NV 0x867D + GL_MAP2_VERTEX_ATTRIB14_4_NV 0x867E + GL_MAP2_VERTEX_ATTRIB15_4_NV 0x867F + GLboolean glAreProgramsResidentNV (GLsizei n, const GLuint* ids, GLboolean *residences) + void glBindProgramNV (GLenum target, GLuint id) + void glDeleteProgramsNV (GLsizei n, const GLuint* ids) + void glExecuteProgramNV (GLenum target, GLuint id, const GLfloat* params) + void glGenProgramsNV (GLsizei n, GLuint* ids) + void glGetProgramParameterdvNV (GLenum target, GLuint index, GLenum pname, GLdouble* params) + void glGetProgramParameterfvNV (GLenum target, GLuint index, GLenum pname, GLfloat* params) + void glGetProgramStringNV (GLuint id, GLenum pname, GLubyte* program) + void glGetProgramivNV (GLuint id, GLenum pname, GLint* params) + void glGetTrackMatrixivNV (GLenum target, GLuint address, GLenum pname, GLint* params) + void glGetVertexAttribPointervNV (GLuint index, GLenum pname, GLvoid** pointer) + void glGetVertexAttribdvNV (GLuint index, GLenum pname, GLdouble* params) + void glGetVertexAttribfvNV (GLuint index, GLenum pname, GLfloat* params) + void glGetVertexAttribivNV (GLuint index, GLenum pname, GLint* params) + GLboolean glIsProgramNV (GLuint id) + void glLoadProgramNV (GLenum target, GLuint id, GLsizei len, const GLubyte* program) + void glProgramParameter4dNV (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glProgramParameter4dvNV (GLenum target, GLuint index, const GLdouble* params) + void glProgramParameter4fNV (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glProgramParameter4fvNV (GLenum target, GLuint index, const GLfloat* params) + void glProgramParameters4dvNV (GLenum target, GLuint index, GLuint num, const GLdouble* params) + void glProgramParameters4fvNV (GLenum target, GLuint index, GLuint num, const GLfloat* params) + void glRequestResidentProgramsNV (GLsizei n, GLuint* ids) + void glTrackMatrixNV (GLenum target, GLuint address, GLenum matrix, GLenum transform) + void glVertexAttrib1dNV (GLuint index, GLdouble x) + void glVertexAttrib1dvNV (GLuint index, const GLdouble* v) + void glVertexAttrib1fNV (GLuint index, GLfloat x) + void glVertexAttrib1fvNV (GLuint index, const GLfloat* v) + void glVertexAttrib1sNV (GLuint index, GLshort x) + void glVertexAttrib1svNV (GLuint index, const GLshort* v) + void glVertexAttrib2dNV (GLuint index, GLdouble x, GLdouble y) + void glVertexAttrib2dvNV (GLuint index, const GLdouble* v) + void glVertexAttrib2fNV (GLuint index, GLfloat x, GLfloat y) + void glVertexAttrib2fvNV (GLuint index, const GLfloat* v) + void glVertexAttrib2sNV (GLuint index, GLshort x, GLshort y) + void glVertexAttrib2svNV (GLuint index, const GLshort* v) + void glVertexAttrib3dNV (GLuint index, GLdouble x, GLdouble y, GLdouble z) + void glVertexAttrib3dvNV (GLuint index, const GLdouble* v) + void glVertexAttrib3fNV (GLuint index, GLfloat x, GLfloat y, GLfloat z) + void glVertexAttrib3fvNV (GLuint index, const GLfloat* v) + void glVertexAttrib3sNV (GLuint index, GLshort x, GLshort y, GLshort z) + void glVertexAttrib3svNV (GLuint index, const GLshort* v) + void glVertexAttrib4dNV (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w) + void glVertexAttrib4dvNV (GLuint index, const GLdouble* v) + void glVertexAttrib4fNV (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glVertexAttrib4fvNV (GLuint index, const GLfloat* v) + void glVertexAttrib4sNV (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w) + void glVertexAttrib4svNV (GLuint index, const GLshort* v) + void glVertexAttrib4ubNV (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w) + void glVertexAttrib4ubvNV (GLuint index, const GLubyte* v) + void glVertexAttribPointerNV (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer) + void glVertexAttribs1dvNV (GLuint index, GLsizei n, const GLdouble* v) + void glVertexAttribs1fvNV (GLuint index, GLsizei n, const GLfloat* v) + void glVertexAttribs1svNV (GLuint index, GLsizei n, const GLshort* v) + void glVertexAttribs2dvNV (GLuint index, GLsizei n, const GLdouble* v) + void glVertexAttribs2fvNV (GLuint index, GLsizei n, const GLfloat* v) + void glVertexAttribs2svNV (GLuint index, GLsizei n, const GLshort* v) + void glVertexAttribs3dvNV (GLuint index, GLsizei n, const GLdouble* v) + void glVertexAttribs3fvNV (GLuint index, GLsizei n, const GLfloat* v) + void glVertexAttribs3svNV (GLuint index, GLsizei n, const GLshort* v) + void glVertexAttribs4dvNV (GLuint index, GLsizei n, const GLdouble* v) + void glVertexAttribs4fvNV (GLuint index, GLsizei n, const GLfloat* v) + void glVertexAttribs4svNV (GLuint index, GLsizei n, const GLshort* v) + void glVertexAttribs4ubvNV (GLuint index, GLsizei n, const GLubyte* v) diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_program1_1 b/Externals/GLew/auto/extensions/GL_NV_vertex_program1_1 new file mode 100644 index 0000000000..929248ac02 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_program1_1 @@ -0,0 +1,3 @@ +GL_NV_vertex_program1_1 +http://www.opengl.org/registry/specs/NV/vertex_program1_1.txt +GL_NV_vertex_program1_1 diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_program2 b/Externals/GLew/auto/extensions/GL_NV_vertex_program2 new file mode 100644 index 0000000000..e80c7a4022 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_program2 @@ -0,0 +1,3 @@ +GL_NV_vertex_program2 +http://www.opengl.org/registry/specs/NV/vertex_program2.txt +GL_NV_vertex_program2 diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_program2_option b/Externals/GLew/auto/extensions/GL_NV_vertex_program2_option new file mode 100644 index 0000000000..1fecc4c040 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_program2_option @@ -0,0 +1,5 @@ +GL_NV_vertex_program2_option +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_vertex_program2_option.txt +GL_NV_vertex_program2_option + GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 + GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_program3 b/Externals/GLew/auto/extensions/GL_NV_vertex_program3 new file mode 100644 index 0000000000..6510e0649c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_program3 @@ -0,0 +1,4 @@ +GL_NV_vertex_program3 +http://www.nvidia.com/dev_content/nvopenglspecs/GL_NV_vertex_program3.txt +GL_NV_vertex_program3 + MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C diff --git a/Externals/GLew/auto/extensions/GL_NV_vertex_program4 b/Externals/GLew/auto/extensions/GL_NV_vertex_program4 new file mode 100644 index 0000000000..7e61b3a95d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_NV_vertex_program4 @@ -0,0 +1,3 @@ +GL_NV_vertex_program4 +http://developer.download.nvidia.com/opengl/specs/GL_NV_vertex_program4.txt +GL_NV_gpu_program4 diff --git a/Externals/GLew/auto/extensions/GL_OES_byte_coordinates b/Externals/GLew/auto/extensions/GL_OES_byte_coordinates new file mode 100644 index 0000000000..cf9d509dec --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_OES_byte_coordinates @@ -0,0 +1,4 @@ +GL_OES_byte_coordinates +http://www.opengl.org/registry/specs/OES/OES_byte_coordinates.txt +GL_OES_byte_coordinates + GL_BYTE 0x1400 diff --git a/Externals/GLew/auto/extensions/GL_OES_compressed_paletted_texture b/Externals/GLew/auto/extensions/GL_OES_compressed_paletted_texture new file mode 100644 index 0000000000..d8838389d5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_OES_compressed_paletted_texture @@ -0,0 +1,13 @@ +GL_OES_compressed_paletted_texture +http://www.opengl.org/registry/specs/OES/OES_compressed_paletted_texture.txt +GL_OES_compressed_paletted_texture + GL_PALETTE4_RGB8_OES 0x8B90 + GL_PALETTE4_RGBA8_OES 0x8B91 + GL_PALETTE4_R5_G6_B5_OES 0x8B92 + GL_PALETTE4_RGBA4_OES 0x8B93 + GL_PALETTE4_RGB5_A1_OES 0x8B94 + GL_PALETTE8_RGB8_OES 0x8B95 + GL_PALETTE8_RGBA8_OES 0x8B96 + GL_PALETTE8_R5_G6_B5_OES 0x8B97 + GL_PALETTE8_RGBA4_OES 0x8B98 + GL_PALETTE8_RGB5_A1_OES 0x8B99 diff --git a/Externals/GLew/auto/extensions/GL_OES_read_format b/Externals/GLew/auto/extensions/GL_OES_read_format new file mode 100644 index 0000000000..08e91a4018 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_OES_read_format @@ -0,0 +1,5 @@ +GL_OES_read_format +http://www.opengl.org/registry/specs/OES/OES_read_format.txt +GL_OES_read_format + GL_IMPLEMENTATION_COLOR_READ_TYPE_OES 0x8B9A + GL_IMPLEMENTATION_COLOR_READ_FORMAT_OES 0x8B9B diff --git a/Externals/GLew/auto/extensions/GL_OES_single_precision b/Externals/GLew/auto/extensions/GL_OES_single_precision new file mode 100644 index 0000000000..8702c6dd58 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_OES_single_precision @@ -0,0 +1,9 @@ +GL_OES_single_precision +http://www.opengl.org/registry/specs/OES/OES_single_precision.txt +GL_OES_single_precision + void glClearDepthfOES (GLclampd depth) + void glClipPlanefOES (GLenum plane, const GLfloat* equation) + void glDepthRangefOES (GLclampf n, GLclampf f) + void glFrustumfOES (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f) + void glGetClipPlanefOES (GLenum plane, GLfloat* equation) + void glOrthofOES (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f) diff --git a/Externals/GLew/auto/extensions/GL_OML_interlace b/Externals/GLew/auto/extensions/GL_OML_interlace new file mode 100644 index 0000000000..384a43b977 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_OML_interlace @@ -0,0 +1,5 @@ +GL_OML_interlace +http://www.opengl.org/registry/specs/OML/interlace.txt +GL_OML_interlace + GL_INTERLACE_OML 0x8980 + GL_INTERLACE_READ_OML 0x8981 diff --git a/Externals/GLew/auto/extensions/GL_OML_resample b/Externals/GLew/auto/extensions/GL_OML_resample new file mode 100644 index 0000000000..6e702bfad6 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_OML_resample @@ -0,0 +1,9 @@ +GL_OML_resample +http://www.opengl.org/registry/specs/OML/resample.txt +GL_OML_resample + GL_PACK_RESAMPLE_OML 0x8984 + GL_UNPACK_RESAMPLE_OML 0x8985 + GL_RESAMPLE_REPLICATE_OML 0x8986 + GL_RESAMPLE_ZERO_FILL_OML 0x8987 + GL_RESAMPLE_AVERAGE_OML 0x8988 + GL_RESAMPLE_DECIMATE_OML 0x8989 diff --git a/Externals/GLew/auto/extensions/GL_OML_subsample b/Externals/GLew/auto/extensions/GL_OML_subsample new file mode 100644 index 0000000000..3406ae777b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_OML_subsample @@ -0,0 +1,5 @@ +GL_OML_subsample +http://www.opengl.org/registry/specs/OML/subsample.txt +GL_OML_subsample + GL_FORMAT_SUBSAMPLE_24_24_OML 0x8982 + GL_FORMAT_SUBSAMPLE_244_244_OML 0x8983 diff --git a/Externals/GLew/auto/extensions/GL_PGI_misc_hints b/Externals/GLew/auto/extensions/GL_PGI_misc_hints new file mode 100644 index 0000000000..b8e88bd70a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_PGI_misc_hints @@ -0,0 +1,23 @@ +GL_PGI_misc_hints +http://www.opengl.org/registry/specs/PGI/misc_hints.txt +GL_PGI_misc_hints + GL_PREFER_DOUBLEBUFFER_HINT_PGI 107000 + GL_CONSERVE_MEMORY_HINT_PGI 107005 + GL_RECLAIM_MEMORY_HINT_PGI 107006 + GL_NATIVE_GRAPHICS_HANDLE_PGI 107010 + GL_NATIVE_GRAPHICS_BEGIN_HINT_PGI 107011 + GL_NATIVE_GRAPHICS_END_HINT_PGI 107012 + GL_ALWAYS_FAST_HINT_PGI 107020 + GL_ALWAYS_SOFT_HINT_PGI 107021 + GL_ALLOW_DRAW_OBJ_HINT_PGI 107022 + GL_ALLOW_DRAW_WIN_HINT_PGI 107023 + GL_ALLOW_DRAW_FRG_HINT_PGI 107024 + GL_ALLOW_DRAW_MEM_HINT_PGI 107025 + GL_STRICT_DEPTHFUNC_HINT_PGI 107030 + GL_STRICT_LIGHTING_HINT_PGI 107031 + GL_STRICT_SCISSOR_HINT_PGI 107032 + GL_FULL_STIPPLE_HINT_PGI 107033 + GL_CLIP_NEAR_HINT_PGI 107040 + GL_CLIP_FAR_HINT_PGI 107041 + GL_WIDE_LINE_HINT_PGI 107042 + GL_BACK_NORMALS_HINT_PGI 107043 diff --git a/Externals/GLew/auto/extensions/GL_PGI_vertex_hints b/Externals/GLew/auto/extensions/GL_PGI_vertex_hints new file mode 100644 index 0000000000..3550952c71 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_PGI_vertex_hints @@ -0,0 +1,25 @@ +GL_PGI_vertex_hints +http://www.opengl.org/registry/specs/PGI/vertex_hints.txt +GL_PGI_vertex_hints + GL_VERTEX23_BIT_PGI 0x00000004 + GL_VERTEX4_BIT_PGI 0x00000008 + GL_COLOR3_BIT_PGI 0x00010000 + GL_COLOR4_BIT_PGI 0x00020000 + GL_EDGEFLAG_BIT_PGI 0x00040000 + GL_INDEX_BIT_PGI 0x00080000 + GL_MAT_AMBIENT_BIT_PGI 0x00100000 + GL_VERTEX_DATA_HINT_PGI 107050 + GL_VERTEX_CONSISTENT_HINT_PGI 107051 + GL_MATERIAL_SIDE_HINT_PGI 107052 + GL_MAX_VERTEX_HINT_PGI 107053 + GL_MAT_AMBIENT_AND_DIFFUSE_BIT_PGI 0x00200000 + GL_MAT_DIFFUSE_BIT_PGI 0x00400000 + GL_MAT_EMISSION_BIT_PGI 0x00800000 + GL_MAT_COLOR_INDEXES_BIT_PGI 0x01000000 + GL_MAT_SHININESS_BIT_PGI 0x02000000 + GL_MAT_SPECULAR_BIT_PGI 0x04000000 + GL_NORMAL_BIT_PGI 0x08000000 + GL_TEXCOORD1_BIT_PGI 0x10000000 + GL_TEXCOORD2_BIT_PGI 0x20000000 + GL_TEXCOORD3_BIT_PGI 0x40000000 + GL_TEXCOORD4_BIT_PGI 0x80000000 diff --git a/Externals/GLew/auto/extensions/GL_REND_screen_coordinates b/Externals/GLew/auto/extensions/GL_REND_screen_coordinates new file mode 100644 index 0000000000..d4447ea868 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_REND_screen_coordinates @@ -0,0 +1,5 @@ +GL_REND_screen_coordinates +http://www.opengl.org/registry/specs/REND/screen_coordinates.txt +GL_REND_screen_coordinates + GL_SCREEN_COORDINATES_REND 0x8490 + GL_INVERTED_SCREEN_W_REND 0x8491 diff --git a/Externals/GLew/auto/extensions/GL_S3_s3tc b/Externals/GLew/auto/extensions/GL_S3_s3tc new file mode 100644 index 0000000000..1d9d71c5ac --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_S3_s3tc @@ -0,0 +1,9 @@ +GL_S3_s3tc +http://www.opengl.org/registry/specs/S3/s3tc.txt +GL_S3_s3tc + GL_RGB_S3TC 0x83A0 + GL_RGB4_S3TC 0x83A1 + GL_RGBA_S3TC 0x83A2 + GL_RGBA4_S3TC 0x83A3 + GL_RGBA_DXT5_S3TC 0x83A4 + GL_RGBA4_DXT5_S3TC 0x83A5 diff --git a/Externals/GLew/auto/extensions/GL_SGIS_color_range b/Externals/GLew/auto/extensions/GL_SGIS_color_range new file mode 100644 index 0000000000..71d39c5655 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_color_range @@ -0,0 +1,12 @@ +GL_SGIS_color_range +http://www.opengl.org/registry/specs/SGIS/color_range.txt +GL_SGIS_color_range + GL_EXTENDED_RANGE_SGIS 0x85A5 + GL_MIN_RED_SGIS 0x85A6 + GL_MAX_RED_SGIS 0x85A7 + GL_MIN_GREEN_SGIS 0x85A8 + GL_MAX_GREEN_SGIS 0x85A9 + GL_MIN_BLUE_SGIS 0x85AA + GL_MAX_BLUE_SGIS 0x85AB + GL_MIN_ALPHA_SGIS 0x85AC + GL_MAX_ALPHA_SGIS 0x85AD diff --git a/Externals/GLew/auto/extensions/GL_SGIS_detail_texture b/Externals/GLew/auto/extensions/GL_SGIS_detail_texture new file mode 100644 index 0000000000..178f7b2a84 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_detail_texture @@ -0,0 +1,5 @@ +GL_SGIS_detail_texture +http://www.opengl.org/registry/specs/SGIS/detail_texture.txt +GL_SGIS_detail_texture + void glDetailTexFuncSGIS (GLenum target, GLsizei n, const GLfloat* points) + void glGetDetailTexFuncSGIS (GLenum target, GLfloat* points) diff --git a/Externals/GLew/auto/extensions/GL_SGIS_fog_function b/Externals/GLew/auto/extensions/GL_SGIS_fog_function new file mode 100644 index 0000000000..3716d97a11 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_fog_function @@ -0,0 +1,5 @@ +GL_SGIS_fog_function +http://www.opengl.org/registry/specs/SGIS/fog_func.txt +GL_SGIS_fog_function + void glFogFuncSGIS (GLsizei n, const GLfloat* points) + void glGetFogFuncSGIS (GLfloat* points) diff --git a/Externals/GLew/auto/extensions/GL_SGIS_generate_mipmap b/Externals/GLew/auto/extensions/GL_SGIS_generate_mipmap new file mode 100644 index 0000000000..cc7b27be97 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_generate_mipmap @@ -0,0 +1,5 @@ +GL_SGIS_generate_mipmap +http://www.opengl.org/registry/specs/SGIS/generate_mipmap.txt +GL_SGIS_generate_mipmap + GL_GENERATE_MIPMAP_SGIS 0x8191 + GL_GENERATE_MIPMAP_HINT_SGIS 0x8192 diff --git a/Externals/GLew/auto/extensions/GL_SGIS_multisample b/Externals/GLew/auto/extensions/GL_SGIS_multisample new file mode 100644 index 0000000000..255de640f5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_multisample @@ -0,0 +1,22 @@ +GL_SGIS_multisample +http://www.opengl.org/registry/specs/SGIS/multisample.txt +GL_SGIS_multisample + GL_MULTISAMPLE_SGIS 0x809D + GL_SAMPLE_ALPHA_TO_MASK_SGIS 0x809E + GL_SAMPLE_ALPHA_TO_ONE_SGIS 0x809F + GL_SAMPLE_MASK_SGIS 0x80A0 + GL_1PASS_SGIS 0x80A1 + GL_2PASS_0_SGIS 0x80A2 + GL_2PASS_1_SGIS 0x80A3 + GL_4PASS_0_SGIS 0x80A4 + GL_4PASS_1_SGIS 0x80A5 + GL_4PASS_2_SGIS 0x80A6 + GL_4PASS_3_SGIS 0x80A7 + GL_SAMPLE_BUFFERS_SGIS 0x80A8 + GL_SAMPLES_SGIS 0x80A9 + GL_SAMPLE_MASK_VALUE_SGIS 0x80AA + GL_SAMPLE_MASK_INVERT_SGIS 0x80AB + GL_SAMPLE_PATTERN_SGIS 0x80AC + GL_MULTISAMPLE_BIT_EXT 0x20000000 + void glSampleMaskSGIS (GLclampf value, GLboolean invert) + void glSamplePatternSGIS (GLenum pattern) diff --git a/Externals/GLew/auto/extensions/GL_SGIS_pixel_texture b/Externals/GLew/auto/extensions/GL_SGIS_pixel_texture new file mode 100644 index 0000000000..5939eb2438 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_pixel_texture @@ -0,0 +1,3 @@ +GL_SGIS_pixel_texture +http://www.opengl.org/registry/specs/SGIS/pixel_texture.txt +GL_SGIS_pixel_texture diff --git a/Externals/GLew/auto/extensions/GL_SGIS_point_line_texgen b/Externals/GLew/auto/extensions/GL_SGIS_point_line_texgen new file mode 100644 index 0000000000..ccf383d0ca --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_point_line_texgen @@ -0,0 +1,11 @@ +GL_SGIS_point_line_texgen +http://www.opengl.org/registry/specs/SGIS/point_line_texgen.txt +GL_SGIS_point_line_texgen + GL_EYE_DISTANCE_TO_POINT_SGIS 0x81F0 + GL_OBJECT_DISTANCE_TO_POINT_SGIS 0x81F1 + GL_EYE_DISTANCE_TO_LINE_SGIS 0x81F2 + GL_OBJECT_DISTANCE_TO_LINE_SGIS 0x81F3 + GL_EYE_POINT_SGIS 0x81F4 + GL_OBJECT_POINT_SGIS 0x81F5 + GL_EYE_LINE_SGIS 0x81F6 + GL_OBJECT_LINE_SGIS 0x81F7 diff --git a/Externals/GLew/auto/extensions/GL_SGIS_sharpen_texture b/Externals/GLew/auto/extensions/GL_SGIS_sharpen_texture new file mode 100644 index 0000000000..3ac1f6aa04 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_sharpen_texture @@ -0,0 +1,5 @@ +GL_SGIS_sharpen_texture +http://www.opengl.org/registry/specs/SGIS/sharpen_texture.txt +GL_SGIS_sharpen_texture + void glGetSharpenTexFuncSGIS (GLenum target, GLfloat* points) + void glSharpenTexFuncSGIS (GLenum target, GLsizei n, const GLfloat* points) diff --git a/Externals/GLew/auto/extensions/GL_SGIS_texture4D b/Externals/GLew/auto/extensions/GL_SGIS_texture4D new file mode 100644 index 0000000000..00bf6a7836 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_texture4D @@ -0,0 +1,5 @@ +GL_SGIS_texture4D +http://www.opengl.org/registry/specs/SGIS/texture4D.txt +GL_SGIS_texture4D + void glTexImage4DSGIS (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLint border, GLenum format, GLenum type, const void* pixels) + void glTexSubImage4DSGIS (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint woffset, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLenum format, GLenum type, const void* pixels) diff --git a/Externals/GLew/auto/extensions/GL_SGIS_texture_border_clamp b/Externals/GLew/auto/extensions/GL_SGIS_texture_border_clamp new file mode 100644 index 0000000000..d397e7d892 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_texture_border_clamp @@ -0,0 +1,4 @@ +GL_SGIS_texture_border_clamp +http://www.opengl.org/registry/specs/SGIS/texture_border_clamp.txt +GL_SGIS_texture_border_clamp + GL_CLAMP_TO_BORDER_SGIS 0x812D diff --git a/Externals/GLew/auto/extensions/GL_SGIS_texture_edge_clamp b/Externals/GLew/auto/extensions/GL_SGIS_texture_edge_clamp new file mode 100644 index 0000000000..6b0fe033d7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_texture_edge_clamp @@ -0,0 +1,4 @@ +GL_SGIS_texture_edge_clamp +http://www.opengl.org/registry/specs/SGIS/texture_edge_clamp.txt +GL_SGIS_texture_edge_clamp + GL_CLAMP_TO_EDGE_SGIS 0x812F diff --git a/Externals/GLew/auto/extensions/GL_SGIS_texture_filter4 b/Externals/GLew/auto/extensions/GL_SGIS_texture_filter4 new file mode 100644 index 0000000000..49fda19f52 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_texture_filter4 @@ -0,0 +1,5 @@ +GL_SGIS_texture_filter4 +http://www.opengl.org/registry/specs/SGIS/texture_filter4.txt +GL_SGIS_texture_filter4 + void glGetTexFilterFuncSGIS (GLenum target, GLenum filter, GLfloat* weights) + void glTexFilterFuncSGIS (GLenum target, GLenum filter, GLsizei n, const GLfloat* weights) diff --git a/Externals/GLew/auto/extensions/GL_SGIS_texture_lod b/Externals/GLew/auto/extensions/GL_SGIS_texture_lod new file mode 100644 index 0000000000..c731a5fcb8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_texture_lod @@ -0,0 +1,7 @@ +GL_SGIS_texture_lod +http://www.opengl.org/registry/specs/SGIS/texture_lod.txt +GL_SGIS_texture_lod + GL_TEXTURE_MIN_LOD_SGIS 0x813A + GL_TEXTURE_MAX_LOD_SGIS 0x813B + GL_TEXTURE_BASE_LEVEL_SGIS 0x813C + GL_TEXTURE_MAX_LEVEL_SGIS 0x813D diff --git a/Externals/GLew/auto/extensions/GL_SGIS_texture_select b/Externals/GLew/auto/extensions/GL_SGIS_texture_select new file mode 100644 index 0000000000..ba51bc8191 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIS_texture_select @@ -0,0 +1,3 @@ +GL_SGIS_texture_select +http://www.opengl.org/registry/specs/SGIS/texture_select.txt +GL_SGIS_texture_select diff --git a/Externals/GLew/auto/extensions/GL_SGIX_async b/Externals/GLew/auto/extensions/GL_SGIX_async new file mode 100644 index 0000000000..05f04549af --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_async @@ -0,0 +1,10 @@ +GL_SGIX_async +http://www.opengl.org/registry/specs/SGIX/async.txt +GL_SGIX_async + GL_ASYNC_MARKER_SGIX 0x8329 + void glAsyncMarkerSGIX (GLuint marker) + void glDeleteAsyncMarkersSGIX (GLuint marker, GLsizei range) + GLint glFinishAsyncSGIX (GLuint* markerp) + GLuint glGenAsyncMarkersSGIX (GLsizei range) + GLboolean glIsAsyncMarkerSGIX (GLuint marker) + GLint glPollAsyncSGIX (GLuint* markerp) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_async_histogram b/Externals/GLew/auto/extensions/GL_SGIX_async_histogram new file mode 100644 index 0000000000..ff5b40b937 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_async_histogram @@ -0,0 +1,5 @@ +GL_SGIX_async_histogram +http://www.opengl.org/registry/specs/SGIX/async_histogram.txt +GL_SGIX_async_histogram + GL_ASYNC_HISTOGRAM_SGIX 0x832C + GL_MAX_ASYNC_HISTOGRAM_SGIX 0x832D diff --git a/Externals/GLew/auto/extensions/GL_SGIX_async_pixel b/Externals/GLew/auto/extensions/GL_SGIX_async_pixel new file mode 100644 index 0000000000..7afb9dfc4d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_async_pixel @@ -0,0 +1,9 @@ +GL_SGIX_async_pixel +http://www.opengl.org/registry/specs/SGIX/async_pixel.txt +GL_SGIX_async_pixel + GL_ASYNC_TEX_IMAGE_SGIX 0x835C + GL_ASYNC_DRAW_PIXELS_SGIX 0x835D + GL_ASYNC_READ_PIXELS_SGIX 0x835E + GL_MAX_ASYNC_TEX_IMAGE_SGIX 0x835F + GL_MAX_ASYNC_DRAW_PIXELS_SGIX 0x8360 + GL_MAX_ASYNC_READ_PIXELS_SGIX 0x8361 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_blend_alpha_minmax b/Externals/GLew/auto/extensions/GL_SGIX_blend_alpha_minmax new file mode 100644 index 0000000000..445112492e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_blend_alpha_minmax @@ -0,0 +1,5 @@ +GL_SGIX_blend_alpha_minmax +http://www.opengl.org/registry/specs/SGIX/blend_alpha_minmax.txt +GL_SGIX_blend_alpha_minmax + GL_ALPHA_MIN_SGIX 0x8320 + GL_ALPHA_MAX_SGIX 0x8321 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_clipmap b/Externals/GLew/auto/extensions/GL_SGIX_clipmap new file mode 100644 index 0000000000..d46748677b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_clipmap @@ -0,0 +1,3 @@ +GL_SGIX_clipmap +http://www.opengl.org/registry/specs/SGIX/clipmap.txt +GL_SGIX_clipmap diff --git a/Externals/GLew/auto/extensions/GL_SGIX_convolution_accuracy b/Externals/GLew/auto/extensions/GL_SGIX_convolution_accuracy new file mode 100644 index 0000000000..064ff2c2a4 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_convolution_accuracy @@ -0,0 +1,4 @@ +GL_SGIX_convolution_accuracy +http://www.opengl.org/registry/specs/SGIX/convolution_accuracy.txt +GL_SGIX_convolution_accuracy + GL_CONVOLUTION_HINT_SGIX 0x8316 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_depth_texture b/Externals/GLew/auto/extensions/GL_SGIX_depth_texture new file mode 100644 index 0000000000..5c5914e688 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_depth_texture @@ -0,0 +1,6 @@ +GL_SGIX_depth_texture +http://www.opengl.org/registry/specs/SGIX/depth_texture.txt +GL_SGIX_depth_texture + GL_DEPTH_COMPONENT16_SGIX 0x81A5 + GL_DEPTH_COMPONENT24_SGIX 0x81A6 + GL_DEPTH_COMPONENT32_SGIX 0x81A7 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_flush_raster b/Externals/GLew/auto/extensions/GL_SGIX_flush_raster new file mode 100644 index 0000000000..9e62248ad7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_flush_raster @@ -0,0 +1,4 @@ +GL_SGIX_flush_raster +http://www.opengl.org/registry/specs/SGIX/flush_raster.txt +GL_SGIX_flush_raster + void glFlushRasterSGIX (void) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_fog_offset b/Externals/GLew/auto/extensions/GL_SGIX_fog_offset new file mode 100644 index 0000000000..da1009ad88 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_fog_offset @@ -0,0 +1,5 @@ +GL_SGIX_fog_offset +http://www.opengl.org/registry/specs/SGIX/fog_offset.txt +GL_SGIX_fog_offset + GL_FOG_OFFSET_SGIX 0x8198 + GL_FOG_OFFSET_VALUE_SGIX 0x8199 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_fog_texture b/Externals/GLew/auto/extensions/GL_SGIX_fog_texture new file mode 100644 index 0000000000..3da0eda166 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_fog_texture @@ -0,0 +1,7 @@ +GL_SGIX_fog_texture +http://www.opengl.org/registry/specs/SGIX/fog_texture.txt +GL_SGIX_fog_texture + GL_TEXTURE_FOG_SGIX 0 + GL_FOG_PATCHY_FACTOR_SGIX 0 + GL_FRAGMENT_FOG_SGIX 0 + void glTextureFogSGIX (GLenum pname) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_fragment_specular_lighting b/Externals/GLew/auto/extensions/GL_SGIX_fragment_specular_lighting new file mode 100644 index 0000000000..35937c9c25 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_fragment_specular_lighting @@ -0,0 +1,20 @@ +GL_SGIX_fragment_specular_lighting +http://www.opengl.org/registry/specs/SGIX/fragment_specular_lighting.txt +GL_SGIX_fragment_specular_lighting + void glFragmentColorMaterialSGIX (GLenum face, GLenum mode) + void glFragmentLightModelfSGIX (GLenum pname, GLfloat param) + void glFragmentLightModelfvSGIX (GLenum pname, GLfloat* params) + void glFragmentLightModeliSGIX (GLenum pname, GLint param) + void glFragmentLightModelivSGIX (GLenum pname, GLint* params) + void glFragmentLightfSGIX (GLenum light, GLenum pname, GLfloat param) + void glFragmentLightfvSGIX (GLenum light, GLenum pname, GLfloat* params) + void glFragmentLightiSGIX (GLenum light, GLenum pname, GLint param) + void glFragmentLightivSGIX (GLenum light, GLenum pname, GLint* params) + void glFragmentMaterialfSGIX (GLenum face, GLenum pname, const GLfloat param) + void glFragmentMaterialfvSGIX (GLenum face, GLenum pname, const GLfloat* params) + void glFragmentMaterialiSGIX (GLenum face, GLenum pname, const GLint param) + void glFragmentMaterialivSGIX (GLenum face, GLenum pname, const GLint* params) + void glGetFragmentLightfvSGIX (GLenum light, GLenum value, GLfloat* data) + void glGetFragmentLightivSGIX (GLenum light, GLenum value, GLint* data) + void glGetFragmentMaterialfvSGIX (GLenum face, GLenum pname, const GLfloat* data) + void glGetFragmentMaterialivSGIX (GLenum face, GLenum pname, const GLint* data) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_framezoom b/Externals/GLew/auto/extensions/GL_SGIX_framezoom new file mode 100644 index 0000000000..a1569accac --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_framezoom @@ -0,0 +1,4 @@ +GL_SGIX_framezoom +http://www.opengl.org/registry/specs/SGIX/framezoom.txt +GL_SGIX_framezoom + void glFrameZoomSGIX (GLint factor) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_interlace b/Externals/GLew/auto/extensions/GL_SGIX_interlace new file mode 100644 index 0000000000..54d351e45b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_interlace @@ -0,0 +1,4 @@ +GL_SGIX_interlace +http://www.opengl.org/registry/specs/SGIX/interlace.txt +GL_SGIX_interlace + GL_INTERLACE_SGIX 0x8094 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_ir_instrument1 b/Externals/GLew/auto/extensions/GL_SGIX_ir_instrument1 new file mode 100644 index 0000000000..a6c586e82e --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_ir_instrument1 @@ -0,0 +1,3 @@ +GL_SGIX_ir_instrument1 +http://www.opengl.org/registry/specs/SGIX/ir_instrument1.txt +GL_SGIX_ir_instrument1 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_list_priority b/Externals/GLew/auto/extensions/GL_SGIX_list_priority new file mode 100644 index 0000000000..187219b7a7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_list_priority @@ -0,0 +1,3 @@ +GL_SGIX_list_priority +http://www.opengl.org/registry/specs/SGIX/list_priority.txt +GL_SGIX_list_priority diff --git a/Externals/GLew/auto/extensions/GL_SGIX_pixel_texture b/Externals/GLew/auto/extensions/GL_SGIX_pixel_texture new file mode 100644 index 0000000000..20bab95808 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_pixel_texture @@ -0,0 +1,4 @@ +GL_SGIX_pixel_texture +http://www.opengl.org/registry/specs/SGIX/sgix_pixel_texture.txt +GL_SGIX_pixel_texture + void glPixelTexGenSGIX (GLenum mode) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_pixel_texture_bits b/Externals/GLew/auto/extensions/GL_SGIX_pixel_texture_bits new file mode 100644 index 0000000000..e550316d42 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_pixel_texture_bits @@ -0,0 +1,3 @@ +GL_SGIX_pixel_texture_bits +http://www.opengl.org/registry/specs/SGIX/pixel_texture_bits.txt +GL_SGIX_pixel_texture_bits diff --git a/Externals/GLew/auto/extensions/GL_SGIX_reference_plane b/Externals/GLew/auto/extensions/GL_SGIX_reference_plane new file mode 100644 index 0000000000..acce07647c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_reference_plane @@ -0,0 +1,4 @@ +GL_SGIX_reference_plane +http://www.opengl.org/registry/specs/SGIX/reference_plane.txt +GL_SGIX_reference_plane + void glReferencePlaneSGIX (const GLdouble* equation) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_resample b/Externals/GLew/auto/extensions/GL_SGIX_resample new file mode 100644 index 0000000000..526e38033d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_resample @@ -0,0 +1,8 @@ +GL_SGIX_resample +http://www.opengl.org/registry/specs/SGIX/resample.txt +GL_SGIX_resample + GL_PACK_RESAMPLE_SGIX 0x842E + GL_UNPACK_RESAMPLE_SGIX 0x842F + GL_RESAMPLE_DECIMATE_SGIX 0x8430 + GL_RESAMPLE_REPLICATE_SGIX 0x8433 + GL_RESAMPLE_ZERO_FILL_SGIX 0x8434 diff --git a/Externals/GLew/auto/extensions/GL_SGIX_shadow b/Externals/GLew/auto/extensions/GL_SGIX_shadow new file mode 100644 index 0000000000..2b34cc83a9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_shadow @@ -0,0 +1,7 @@ +GL_SGIX_shadow +http://oss.sgi.com/projects/ogl-sample/registry/SGIX/shadow.txt +GL_SGIX_shadow + GL_TEXTURE_COMPARE_SGIX 0x819A + GL_TEXTURE_COMPARE_OPERATOR_SGIX 0x819B + GL_TEXTURE_LEQUAL_R_SGIX 0x819C + GL_TEXTURE_GEQUAL_R_SGIX 0x819D diff --git a/Externals/GLew/auto/extensions/GL_SGIX_shadow_ambient b/Externals/GLew/auto/extensions/GL_SGIX_shadow_ambient new file mode 100644 index 0000000000..b3476b1e74 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_shadow_ambient @@ -0,0 +1,4 @@ +GL_SGIX_shadow_ambient +http://www.opengl.org/registry/specs/SGIX/shadow_ambient.txt +GL_SGIX_shadow_ambient + GL_SHADOW_AMBIENT_SGIX 0x80BF diff --git a/Externals/GLew/auto/extensions/GL_SGIX_sprite b/Externals/GLew/auto/extensions/GL_SGIX_sprite new file mode 100644 index 0000000000..427a779e23 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_sprite @@ -0,0 +1,7 @@ +GL_SGIX_sprite +http://www.opengl.org/registry/specs/SGIX/sprite.txt +GL_SGIX_sprite + void glSpriteParameterfSGIX (GLenum pname, GLfloat param) + void glSpriteParameterfvSGIX (GLenum pname, GLfloat* params) + void glSpriteParameteriSGIX (GLenum pname, GLint param) + void glSpriteParameterivSGIX (GLenum pname, GLint* params) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_tag_sample_buffer b/Externals/GLew/auto/extensions/GL_SGIX_tag_sample_buffer new file mode 100644 index 0000000000..e17f53e5c9 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_tag_sample_buffer @@ -0,0 +1,4 @@ +GL_SGIX_tag_sample_buffer +http://www.opengl.org/registry/specs/SGIX/tag_sample_buffer.txt +GL_SGIX_tag_sample_buffer + void glTagSampleBufferSGIX (void) diff --git a/Externals/GLew/auto/extensions/GL_SGIX_texture_add_env b/Externals/GLew/auto/extensions/GL_SGIX_texture_add_env new file mode 100644 index 0000000000..19db14cdea --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_texture_add_env @@ -0,0 +1,3 @@ +GL_SGIX_texture_add_env +http://www.opengl.org/registry/specs/SGIX/texture_env_add.txt +GL_SGIX_texture_add_env diff --git a/Externals/GLew/auto/extensions/GL_SGIX_texture_coordinate_clamp b/Externals/GLew/auto/extensions/GL_SGIX_texture_coordinate_clamp new file mode 100644 index 0000000000..cd6862d4b5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_texture_coordinate_clamp @@ -0,0 +1,6 @@ +GL_SGIX_texture_coordinate_clamp +http://www.opengl.org/registry/specs/SGIX/texture_coordinate_clamp.txt +GL_SGIX_texture_coordinate_clamp + GL_TEXTURE_MAX_CLAMP_S_SGIX 0x8369 + GL_TEXTURE_MAX_CLAMP_T_SGIX 0x836A + GL_TEXTURE_MAX_CLAMP_R_SGIX 0x836B diff --git a/Externals/GLew/auto/extensions/GL_SGIX_texture_lod_bias b/Externals/GLew/auto/extensions/GL_SGIX_texture_lod_bias new file mode 100644 index 0000000000..2f8dfb608a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_texture_lod_bias @@ -0,0 +1,3 @@ +GL_SGIX_texture_lod_bias +http://www.opengl.org/registry/specs/SGIX/texture_lod_bias.txt +GL_SGIX_texture_lod_bias diff --git a/Externals/GLew/auto/extensions/GL_SGIX_texture_multi_buffer b/Externals/GLew/auto/extensions/GL_SGIX_texture_multi_buffer new file mode 100644 index 0000000000..0990319aff --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_texture_multi_buffer @@ -0,0 +1,4 @@ +GL_SGIX_texture_multi_buffer +http://www.opengl.org/registry/specs/SGIX/texture_multi_buffer.txt +GL_SGIX_texture_multi_buffer + GL_TEXTURE_MULTI_BUFFER_HINT_SGIX 0x812E diff --git a/Externals/GLew/auto/extensions/GL_SGIX_texture_range b/Externals/GLew/auto/extensions/GL_SGIX_texture_range new file mode 100644 index 0000000000..2299caf3d8 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_texture_range @@ -0,0 +1,31 @@ +GL_SGIX_texture_range +http://www.opengl.org/registry/specs/SGIX/texture_range.txt +GL_SGIX_texture_range + GL_RGB_SIGNED_SGIX 0x85E0 + GL_RGBA_SIGNED_SGIX 0x85E1 + GL_ALPHA_SIGNED_SGIX 0x85E2 + GL_LUMINANCE_SIGNED_SGIX 0x85E3 + GL_INTENSITY_SIGNED_SGIX 0x85E4 + GL_LUMINANCE_ALPHA_SIGNED_SGIX 0x85E5 + GL_RGB16_SIGNED_SGIX 0x85E6 + GL_RGBA16_SIGNED_SGIX 0x85E7 + GL_ALPHA16_SIGNED_SGIX 0x85E8 + GL_LUMINANCE16_SIGNED_SGIX 0x85E9 + GL_INTENSITY16_SIGNED_SGIX 0x85EA + GL_LUMINANCE16_ALPHA16_SIGNED_SGIX 0x85EB + GL_RGB_EXTENDED_RANGE_SGIX 0x85EC + GL_RGBA_EXTENDED_RANGE_SGIX 0x85ED + GL_ALPHA_EXTENDED_RANGE_SGIX 0x85EE + GL_LUMINANCE_EXTENDED_RANGE_SGIX 0x85EF + GL_INTENSITY_EXTENDED_RANGE_SGIX 0x85F0 + GL_LUMINANCE_ALPHA_EXTENDED_RANGE_SGIX 0x85F1 + GL_RGB16_EXTENDED_RANGE_SGIX 0x85F2 + GL_RGBA16_EXTENDED_RANGE_SGIX 0x85F3 + GL_ALPHA16_EXTENDED_RANGE_SGIX 0x85F4 + GL_LUMINANCE16_EXTENDED_RANGE_SGIX 0x85F5 + GL_INTENSITY16_EXTENDED_RANGE_SGIX 0x85F6 + GL_LUMINANCE16_ALPHA16_EXTENDED_RANGE_SGIX 0x85F7 + GL_MIN_LUMINANCE_SGIS 0x85F8 + GL_MAX_LUMINANCE_SGIS 0x85F9 + GL_MIN_INTENSITY_SGIS 0x85FA + GL_MAX_INTENSITY_SGIS 0x85FB diff --git a/Externals/GLew/auto/extensions/GL_SGIX_texture_scale_bias b/Externals/GLew/auto/extensions/GL_SGIX_texture_scale_bias new file mode 100644 index 0000000000..83ff2ffb02 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_texture_scale_bias @@ -0,0 +1,7 @@ +GL_SGIX_texture_scale_bias +http://www.opengl.org/registry/specs/SGIX/texture_scale_bias.txt +GL_SGIX_texture_scale_bias + GL_POST_TEXTURE_FILTER_BIAS_SGIX 0x8179 + GL_POST_TEXTURE_FILTER_SCALE_SGIX 0x817A + GL_POST_TEXTURE_FILTER_BIAS_RANGE_SGIX 0x817B + GL_POST_TEXTURE_FILTER_SCALE_RANGE_SGIX 0x817C diff --git a/Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip b/Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip new file mode 100644 index 0000000000..98772553fb --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip @@ -0,0 +1,5 @@ +GL_SGIX_vertex_preclip +http://www.opengl.org/registry/specs/SGIX/vertex_preclip.txt +GL_SGIX_vertex_preclip + GL_VERTEX_PRECLIP_SGIX 0x83EE + GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF diff --git a/Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip_hint b/Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip_hint new file mode 100644 index 0000000000..285bded5a2 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_vertex_preclip_hint @@ -0,0 +1,5 @@ +GL_SGIX_vertex_preclip_hint +http://www.opengl.org/registry/specs/SGIX/vertex_preclip.txt +GL_SGIX_vertex_preclip_hint + GL_VERTEX_PRECLIP_SGIX 0x83EE + GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF diff --git a/Externals/GLew/auto/extensions/GL_SGIX_ycrcb b/Externals/GLew/auto/extensions/GL_SGIX_ycrcb new file mode 100644 index 0000000000..19e60345bf --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGIX_ycrcb @@ -0,0 +1,3 @@ +GL_SGIX_ycrcb +http://www.opengl.org/registry/specs/SGIX/ycrcb.txt +GL_SGIX_ycrcb diff --git a/Externals/GLew/auto/extensions/GL_SGI_color_matrix b/Externals/GLew/auto/extensions/GL_SGI_color_matrix new file mode 100644 index 0000000000..7db7e20eea --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGI_color_matrix @@ -0,0 +1,14 @@ +GL_SGI_color_matrix +http://www.opengl.org/registry/specs/SGI/color_matrix.txt +GL_SGI_color_matrix + GL_COLOR_MATRIX_SGI 0x80B1 + GL_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B2 + GL_MAX_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B3 + GL_POST_COLOR_MATRIX_RED_SCALE_SGI 0x80B4 + GL_POST_COLOR_MATRIX_GREEN_SCALE_SGI 0x80B5 + GL_POST_COLOR_MATRIX_BLUE_SCALE_SGI 0x80B6 + GL_POST_COLOR_MATRIX_ALPHA_SCALE_SGI 0x80B7 + GL_POST_COLOR_MATRIX_RED_BIAS_SGI 0x80B8 + GL_POST_COLOR_MATRIX_GREEN_BIAS_SGI 0x80B9 + GL_POST_COLOR_MATRIX_BLUE_BIAS_SGI 0x80BA + GL_POST_COLOR_MATRIX_ALPHA_BIAS_SGI 0x80BB diff --git a/Externals/GLew/auto/extensions/GL_SGI_color_table b/Externals/GLew/auto/extensions/GL_SGI_color_table new file mode 100644 index 0000000000..756ba491c7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGI_color_table @@ -0,0 +1,26 @@ +GL_SGI_color_table +http://www.opengl.org/registry/specs/SGI/color_table.txt +GL_SGI_color_table + GL_COLOR_TABLE_SGI 0x80D0 + GL_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D1 + GL_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D2 + GL_PROXY_COLOR_TABLE_SGI 0x80D3 + GL_PROXY_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D4 + GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D5 + GL_COLOR_TABLE_SCALE_SGI 0x80D6 + GL_COLOR_TABLE_BIAS_SGI 0x80D7 + GL_COLOR_TABLE_FORMAT_SGI 0x80D8 + GL_COLOR_TABLE_WIDTH_SGI 0x80D9 + GL_COLOR_TABLE_RED_SIZE_SGI 0x80DA + GL_COLOR_TABLE_GREEN_SIZE_SGI 0x80DB + GL_COLOR_TABLE_BLUE_SIZE_SGI 0x80DC + GL_COLOR_TABLE_ALPHA_SIZE_SGI 0x80DD + GL_COLOR_TABLE_LUMINANCE_SIZE_SGI 0x80DE + GL_COLOR_TABLE_INTENSITY_SIZE_SGI 0x80DF + void glColorTableParameterfvSGI (GLenum target, GLenum pname, const GLfloat* params) + void glColorTableParameterivSGI (GLenum target, GLenum pname, const GLint* params) + void glColorTableSGI (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void* table) + void glCopyColorTableSGI (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width) + void glGetColorTableParameterfvSGI (GLenum target, GLenum pname, GLfloat* params) + void glGetColorTableParameterivSGI (GLenum target, GLenum pname, GLint* params) + void glGetColorTableSGI (GLenum target, GLenum format, GLenum type, void* table) diff --git a/Externals/GLew/auto/extensions/GL_SGI_texture_color_table b/Externals/GLew/auto/extensions/GL_SGI_texture_color_table new file mode 100644 index 0000000000..29931705be --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SGI_texture_color_table @@ -0,0 +1,5 @@ +GL_SGI_texture_color_table +http://www.opengl.org/registry/specs/SGI/texture_color_table.txt +GL_SGI_texture_color_table + GL_TEXTURE_COLOR_TABLE_SGI 0x80BC + GL_PROXY_TEXTURE_COLOR_TABLE_SGI 0x80BD diff --git a/Externals/GLew/auto/extensions/GL_SUNX_constant_data b/Externals/GLew/auto/extensions/GL_SUNX_constant_data new file mode 100644 index 0000000000..5fe63c585f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUNX_constant_data @@ -0,0 +1,6 @@ +GL_SUNX_constant_data +http://www.opengl.org/registry/specs/SUNX/constant_data.txt +GL_SUNX_constant_data + GL_UNPACK_CONSTANT_DATA_SUNX 0x81D5 + GL_TEXTURE_CONSTANT_DATA_SUNX 0x81D6 + void glFinishTextureSUNX (void) diff --git a/Externals/GLew/auto/extensions/GL_SUN_convolution_border_modes b/Externals/GLew/auto/extensions/GL_SUN_convolution_border_modes new file mode 100644 index 0000000000..0c6fda8f23 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUN_convolution_border_modes @@ -0,0 +1,4 @@ +GL_SUN_convolution_border_modes +http://www.opengl.org/registry/specs/SUN/convolution_border_modes.txt +GL_SUN_convolution_border_modes + GL_WRAP_BORDER_SUN 0x81D4 diff --git a/Externals/GLew/auto/extensions/GL_SUN_global_alpha b/Externals/GLew/auto/extensions/GL_SUN_global_alpha new file mode 100644 index 0000000000..d7c527436a --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUN_global_alpha @@ -0,0 +1,13 @@ +GL_SUN_global_alpha +http://www.opengl.org/registry/specs/SUN/global_alpha.txt +GL_SUN_global_alpha + GL_GLOBAL_ALPHA_SUN 0x81D9 + GL_GLOBAL_ALPHA_FACTOR_SUN 0x81DA + void glGlobalAlphaFactorbSUN (GLbyte factor) + void glGlobalAlphaFactordSUN (GLdouble factor) + void glGlobalAlphaFactorfSUN (GLfloat factor) + void glGlobalAlphaFactoriSUN (GLint factor) + void glGlobalAlphaFactorsSUN (GLshort factor) + void glGlobalAlphaFactorubSUN (GLubyte factor) + void glGlobalAlphaFactoruiSUN (GLuint factor) + void glGlobalAlphaFactorusSUN (GLushort factor) diff --git a/Externals/GLew/auto/extensions/GL_SUN_mesh_array b/Externals/GLew/auto/extensions/GL_SUN_mesh_array new file mode 100644 index 0000000000..28229bf32d --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUN_mesh_array @@ -0,0 +1,5 @@ +GL_SUN_mesh_array +http://www.opengl.org/registry/specs/SUN/mesh_array.txt +GL_SUN_mesh_array + GL_QUAD_MESH_SUN 0x8614 + GL_TRIANGLE_MESH_SUN 0x8615 diff --git a/Externals/GLew/auto/extensions/GL_SUN_read_video_pixels b/Externals/GLew/auto/extensions/GL_SUN_read_video_pixels new file mode 100644 index 0000000000..faa55f972c --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUN_read_video_pixels @@ -0,0 +1,4 @@ +GL_SUN_read_video_pixels +http://wwws.sun.com/software/graphics/opengl/extensions/gl_sun_read_video_pixels.txt +GL_SUN_read_video_pixels + void glReadVideoPixelsSUN (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid* pixels) diff --git a/Externals/GLew/auto/extensions/GL_SUN_slice_accum b/Externals/GLew/auto/extensions/GL_SUN_slice_accum new file mode 100644 index 0000000000..404237d70f --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUN_slice_accum @@ -0,0 +1,4 @@ +GL_SUN_slice_accum +http://www.opengl.org/registry/specs/SUN/slice_accum.txt +GL_SUN_slice_accum + GL_SLICE_ACCUM_SUN 0x85CC diff --git a/Externals/GLew/auto/extensions/GL_SUN_triangle_list b/Externals/GLew/auto/extensions/GL_SUN_triangle_list new file mode 100644 index 0000000000..a42af1ff79 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUN_triangle_list @@ -0,0 +1,27 @@ +GL_SUN_triangle_list +http://www.opengl.org/registry/specs/SUN/triangle_list.txt +GL_SUN_triangle_list + GL_RESTART_SUN 0x01 + GL_REPLACE_MIDDLE_SUN 0x02 + GL_REPLACE_OLDEST_SUN 0x03 + GL_TRIANGLE_LIST_SUN 0x81D7 + GL_REPLACEMENT_CODE_SUN 0x81D8 + GL_REPLACEMENT_CODE_ARRAY_SUN 0x85C0 + GL_REPLACEMENT_CODE_ARRAY_TYPE_SUN 0x85C1 + GL_REPLACEMENT_CODE_ARRAY_STRIDE_SUN 0x85C2 + GL_REPLACEMENT_CODE_ARRAY_POINTER_SUN 0x85C3 + GL_R1UI_V3F_SUN 0x85C4 + GL_R1UI_C4UB_V3F_SUN 0x85C5 + GL_R1UI_C3F_V3F_SUN 0x85C6 + GL_R1UI_N3F_V3F_SUN 0x85C7 + GL_R1UI_C4F_N3F_V3F_SUN 0x85C8 + GL_R1UI_T2F_V3F_SUN 0x85C9 + GL_R1UI_T2F_N3F_V3F_SUN 0x85CA + GL_R1UI_T2F_C4F_N3F_V3F_SUN 0x85CB + void glReplacementCodePointerSUN (GLenum type, GLsizei stride, const void* pointer) + void glReplacementCodeubSUN (GLubyte code) + void glReplacementCodeubvSUN (const GLubyte* code) + void glReplacementCodeuiSUN (GLuint code) + void glReplacementCodeuivSUN (const GLuint* code) + void glReplacementCodeusSUN (GLushort code) + void glReplacementCodeusvSUN (const GLushort* code) diff --git a/Externals/GLew/auto/extensions/GL_SUN_vertex b/Externals/GLew/auto/extensions/GL_SUN_vertex new file mode 100644 index 0000000000..0111c011a5 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_SUN_vertex @@ -0,0 +1,43 @@ +GL_SUN_vertex +http://www.opengl.org/registry/specs/SUN/vertex.txt +GL_SUN_vertex + void glColor3fVertex3fSUN (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z) + void glColor3fVertex3fvSUN (const GLfloat* c, const GLfloat *v) + void glColor4fNormal3fVertex3fSUN (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glColor4fNormal3fVertex3fvSUN (const GLfloat* c, const GLfloat *n, const GLfloat *v) + void glColor4ubVertex2fSUN (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y) + void glColor4ubVertex2fvSUN (const GLubyte* c, const GLfloat *v) + void glColor4ubVertex3fSUN (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z) + void glColor4ubVertex3fvSUN (const GLubyte* c, const GLfloat *v) + void glNormal3fVertex3fSUN (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glNormal3fVertex3fvSUN (const GLfloat* n, const GLfloat *v) + void glReplacementCodeuiColor3fVertex3fSUN (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiColor3fVertex3fvSUN (const GLuint* rc, const GLfloat *c, const GLfloat *v) + void glReplacementCodeuiColor4fNormal3fVertex3fSUN (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiColor4fNormal3fVertex3fvSUN (const GLuint* rc, const GLfloat *c, const GLfloat *n, const GLfloat *v) + void glReplacementCodeuiColor4ubVertex3fSUN (GLuint rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiColor4ubVertex3fvSUN (const GLuint* rc, const GLubyte *c, const GLfloat *v) + void glReplacementCodeuiNormal3fVertex3fSUN (GLuint rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiNormal3fVertex3fvSUN (const GLuint* rc, const GLfloat *n, const GLfloat *v) + void glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN (GLuint rc, GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN (const GLuint* rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v) + void glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN (GLuint rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN (const GLuint* rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v) + void glReplacementCodeuiTexCoord2fVertex3fSUN (GLuint rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiTexCoord2fVertex3fvSUN (const GLuint* rc, const GLfloat *tc, const GLfloat *v) + void glReplacementCodeuiVertex3fSUN (GLuint rc, GLfloat x, GLfloat y, GLfloat z) + void glReplacementCodeuiVertex3fvSUN (const GLuint* rc, const GLfloat *v) + void glTexCoord2fColor3fVertex3fSUN (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z) + void glTexCoord2fColor3fVertex3fvSUN (const GLfloat* tc, const GLfloat *c, const GLfloat *v) + void glTexCoord2fColor4fNormal3fVertex3fSUN (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glTexCoord2fColor4fNormal3fVertex3fvSUN (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v) + void glTexCoord2fColor4ubVertex3fSUN (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z) + void glTexCoord2fColor4ubVertex3fvSUN (const GLfloat* tc, const GLubyte *c, const GLfloat *v) + void glTexCoord2fNormal3fVertex3fSUN (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z) + void glTexCoord2fNormal3fVertex3fvSUN (const GLfloat* tc, const GLfloat *n, const GLfloat *v) + void glTexCoord2fVertex3fSUN (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z) + void glTexCoord2fVertex3fvSUN (const GLfloat* tc, const GLfloat *v) + void glTexCoord4fColor4fNormal3fVertex4fSUN (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glTexCoord4fColor4fNormal3fVertex4fvSUN (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v) + void glTexCoord4fVertex4fSUN (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w) + void glTexCoord4fVertex4fvSUN (const GLfloat* tc, const GLfloat *v) diff --git a/Externals/GLew/auto/extensions/GL_WIN_phong_shading b/Externals/GLew/auto/extensions/GL_WIN_phong_shading new file mode 100644 index 0000000000..9faadb86b7 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_WIN_phong_shading @@ -0,0 +1,5 @@ +GL_WIN_phong_shading +http://www.opengl.org/registry/specs/WIN/phong_shading.txt +GL_WIN_phong_shading + GL_PHONG_WIN 0x80EA + GL_PHONG_HINT_WIN 0x80EB diff --git a/Externals/GLew/auto/extensions/GL_WIN_specular_fog b/Externals/GLew/auto/extensions/GL_WIN_specular_fog new file mode 100644 index 0000000000..2cfcd0191b --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_WIN_specular_fog @@ -0,0 +1,4 @@ +GL_WIN_specular_fog +http://www.opengl.org/registry/specs/WIN/specular_fog.txt +GL_WIN_specular_fog + GL_FOG_SPECULAR_TEXTURE_WIN 0x80EC diff --git a/Externals/GLew/auto/extensions/GL_WIN_swap_hint b/Externals/GLew/auto/extensions/GL_WIN_swap_hint new file mode 100644 index 0000000000..6916189eb2 --- /dev/null +++ b/Externals/GLew/auto/extensions/GL_WIN_swap_hint @@ -0,0 +1,4 @@ +GL_WIN_swap_hint +http://msdn.microsoft.com/library/default.asp?url=/library/en-us/opengl/glfunc01_16zy.asp +GL_WIN_swap_hint + void glAddSwapHintRectWIN (GLint x, GLint y, GLsizei width, GLsizei height) diff --git a/Externals/GLew/auto/extensions/WGL_3DFX_multisample b/Externals/GLew/auto/extensions/WGL_3DFX_multisample new file mode 100644 index 0000000000..f0d91e9986 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_3DFX_multisample @@ -0,0 +1,5 @@ +WGL_3DFX_multisample +http://www.opengl.org/registry/specs/3DFX/3dfx_multisample.txt +WGL_3DFX_multisample + WGL_SAMPLE_BUFFERS_3DFX 0x2060 + WGL_SAMPLES_3DFX 0x2061 diff --git a/Externals/GLew/auto/extensions/WGL_3DL_stereo_control b/Externals/GLew/auto/extensions/WGL_3DL_stereo_control new file mode 100644 index 0000000000..88fb1bb4b7 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_3DL_stereo_control @@ -0,0 +1,8 @@ +WGL_3DL_stereo_control +http://www.opengl.org/registry/specs/3DL/stereo_control.txt +WGL_3DL_stereo_control + WGL_STEREO_EMITTER_ENABLE_3DL 0x2055 + WGL_STEREO_EMITTER_DISABLE_3DL 0x2056 + WGL_STEREO_POLARITY_NORMAL_3DL 0x2057 + WGL_STEREO_POLARITY_INVERT_3DL 0x2058 + BOOL wglSetStereoEmitterState3DL (HDC hDC, UINT uState) diff --git a/Externals/GLew/auto/extensions/WGL_AMD_gpu_association b/Externals/GLew/auto/extensions/WGL_AMD_gpu_association new file mode 100644 index 0000000000..359b9ba3dc --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_AMD_gpu_association @@ -0,0 +1,22 @@ +WGL_AMD_gpu_association +http://www.opengl.org/registry/specs/AMD/wgl_gpu_association.txt +WGL_AMD_gpu_association + WGL_GPU_VENDOR_AMD 0x1F00 + WGL_GPU_RENDERER_STRING_AMD 0x1F01 + WGL_GPU_OPENGL_VERSION_STRING_AMD 0x1F02 + WGL_GPU_FASTEST_TARGET_GPUS_AMD 0x21A2 + WGL_GPU_RAM_AMD 0x21A3 + WGL_GPU_CLOCK_AMD 0x21A4 + WGL_GPU_NUM_PIPES_AMD 0x21A5 + WGL_GPU_NUM_SIMD_AMD 0x21A6 + WGL_GPU_NUM_RB_AMD 0x21A7 + WGL_GPU_NUM_SPI_AMD 0x21A8 + VOID wglBlitContextFramebufferAMD (HGLRC dstCtx, GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter) + HGLRC wglCreateAssociatedContextAMD (UINT id) + HGLRC wglCreateAssociatedContextAttribsAMD (UINT id, HGLRC hShareContext, const int* attribList) + BOOL wglDeleteAssociatedContextAMD (HGLRC hglrc) + UINT wglGetContextGPUIDAMD (HGLRC hglrc) + HGLRC wglGetCurrentAssociatedContextAMD (void) + UINT wglGetGPUIDsAMD (UINT maxCount, UINT* ids) + INT wglGetGPUInfoAMD (UINT id, INT property, GLenum dataType, UINT size, void* data) + BOOL wglMakeAssociatedContextCurrentAMD (HGLRC hglrc) diff --git a/Externals/GLew/auto/extensions/WGL_ARB_buffer_region b/Externals/GLew/auto/extensions/WGL_ARB_buffer_region new file mode 100644 index 0000000000..719f648727 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_buffer_region @@ -0,0 +1,11 @@ +WGL_ARB_buffer_region +http://www.opengl.org/registry/specs/ARB/wgl_buffer_region.txt +WGL_ARB_buffer_region + WGL_FRONT_COLOR_BUFFER_BIT_ARB 0x00000001 + WGL_BACK_COLOR_BUFFER_BIT_ARB 0x00000002 + WGL_DEPTH_BUFFER_BIT_ARB 0x00000004 + WGL_STENCIL_BUFFER_BIT_ARB 0x00000008 + HANDLE wglCreateBufferRegionARB (HDC hDC, int iLayerPlane, UINT uType) + VOID wglDeleteBufferRegionARB (HANDLE hRegion) + BOOL wglRestoreBufferRegionARB (HANDLE hRegion, int x, int y, int width, int height, int xSrc, int ySrc) + BOOL wglSaveBufferRegionARB (HANDLE hRegion, int x, int y, int width, int height) diff --git a/Externals/GLew/auto/extensions/WGL_ARB_create_context b/Externals/GLew/auto/extensions/WGL_ARB_create_context new file mode 100644 index 0000000000..d864772094 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_create_context @@ -0,0 +1,10 @@ +WGL_ARB_create_context +http://www.opengl.org/registry/specs/ARB/wgl_create_context.txt +WGL_ARB_create_context + WGL_CONTEXT_DEBUG_BIT_ARB 0x0001 + WGL_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 + WGL_CONTEXT_MAJOR_VERSION_ARB 0x2091 + WGL_CONTEXT_MINOR_VERSION_ARB 0x2092 + WGL_CONTEXT_LAYER_PLANE_ARB 0x2093 + WGL_CONTEXT_FLAGS_ARB 0x2094 + HGLRC wglCreateContextAttribsARB (HDC hDC, HGLRC hShareContext, const int* attribList) diff --git a/Externals/GLew/auto/extensions/WGL_ARB_create_context_profile b/Externals/GLew/auto/extensions/WGL_ARB_create_context_profile new file mode 100644 index 0000000000..1b3c10427e --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_create_context_profile @@ -0,0 +1,6 @@ +WGL_ARB_create_context_profile +http://www.opengl.org/registry/specs/ARB/wgl_create_context.txt +WGL_ARB_create_context_profile + WGL_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 + WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 + WGL_CONTEXT_PROFILE_MASK_ARB 0x9126 diff --git a/Externals/GLew/auto/extensions/WGL_ARB_extensions_string b/Externals/GLew/auto/extensions/WGL_ARB_extensions_string new file mode 100644 index 0000000000..1c13879c81 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_extensions_string @@ -0,0 +1,4 @@ +WGL_ARB_extensions_string +http://www.opengl.org/registry/specs/ARB/wgl_extensions_string.txt +WGL_ARB_extensions_string + const char* wglGetExtensionsStringARB (HDC hdc) diff --git a/Externals/GLew/auto/extensions/WGL_ARB_framebuffer_sRGB b/Externals/GLew/auto/extensions/WGL_ARB_framebuffer_sRGB new file mode 100644 index 0000000000..b166c5b74c --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_framebuffer_sRGB @@ -0,0 +1,4 @@ +WGL_ARB_framebuffer_sRGB +http://www.opengl.org/registry/specs/ARB/framebuffer_sRGB.txt +WGL_ARB_framebuffer_sRGB + WGL_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20A9 diff --git a/Externals/GLew/auto/extensions/WGL_ARB_make_current_read b/Externals/GLew/auto/extensions/WGL_ARB_make_current_read new file mode 100644 index 0000000000..352f9cf676 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_make_current_read @@ -0,0 +1,7 @@ +WGL_ARB_make_current_read +http://www.opengl.org/registry/specs/ARB/wgl_make_current_read.txt +WGL_ARB_make_current_read + HDC wglGetCurrentReadDCARB (VOID) + BOOL wglMakeContextCurrentARB (HDC hDrawDC, HDC hReadDC, HGLRC hglrc) + ERROR_INVALID_PIXEL_TYPE_ARB 0x2043 + ERROR_INCOMPATIBLE_DEVICE_CONTEXTS_ARB 0x2054 diff --git a/Externals/GLew/auto/extensions/WGL_ARB_multisample b/Externals/GLew/auto/extensions/WGL_ARB_multisample new file mode 100644 index 0000000000..8f9f5c3790 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_multisample @@ -0,0 +1,5 @@ +WGL_ARB_multisample +http://www.opengl.org/registry/specs/ARB/multisample.txt +WGL_ARB_multisample + WGL_SAMPLE_BUFFERS_ARB 0x2041 + WGL_SAMPLES_ARB 0x2042 diff --git a/Externals/GLew/auto/extensions/WGL_ARB_pbuffer b/Externals/GLew/auto/extensions/WGL_ARB_pbuffer new file mode 100644 index 0000000000..fa9f7c9f2f --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_pbuffer @@ -0,0 +1,17 @@ +WGL_ARB_pbuffer +http://www.opengl.org/registry/specs/ARB/wgl_pbuffer.txt +WGL_ARB_pbuffer + WGL_DRAW_TO_PBUFFER_ARB 0x202D + WGL_MAX_PBUFFER_PIXELS_ARB 0x202E + WGL_MAX_PBUFFER_WIDTH_ARB 0x202F + WGL_MAX_PBUFFER_HEIGHT_ARB 0x2030 + WGL_PBUFFER_LARGEST_ARB 0x2033 + WGL_PBUFFER_WIDTH_ARB 0x2034 + WGL_PBUFFER_HEIGHT_ARB 0x2035 + WGL_PBUFFER_LOST_ARB 0x2036 + HPBUFFERARB wglCreatePbufferARB (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList) + BOOL wglDestroyPbufferARB (HPBUFFERARB hPbuffer) + HDC wglGetPbufferDCARB (HPBUFFERARB hPbuffer) + BOOL wglQueryPbufferARB (HPBUFFERARB hPbuffer, int iAttribute, int* piValue) + int wglReleasePbufferDCARB (HPBUFFERARB hPbuffer, HDC hDC) + DECLARE_HANDLE(HPBUFFERARB); diff --git a/Externals/GLew/auto/extensions/WGL_ARB_pixel_format b/Externals/GLew/auto/extensions/WGL_ARB_pixel_format new file mode 100644 index 0000000000..553353f127 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_pixel_format @@ -0,0 +1,55 @@ +WGL_ARB_pixel_format +http://www.opengl.org/registry/specs/ARB/wgl_pixel_format.txt +WGL_ARB_pixel_format + WGL_NUMBER_PIXEL_FORMATS_ARB 0x2000 + WGL_DRAW_TO_WINDOW_ARB 0x2001 + WGL_DRAW_TO_BITMAP_ARB 0x2002 + WGL_ACCELERATION_ARB 0x2003 + WGL_NEED_PALETTE_ARB 0x2004 + WGL_NEED_SYSTEM_PALETTE_ARB 0x2005 + WGL_SWAP_LAYER_BUFFERS_ARB 0x2006 + WGL_SWAP_METHOD_ARB 0x2007 + WGL_NUMBER_OVERLAYS_ARB 0x2008 + WGL_NUMBER_UNDERLAYS_ARB 0x2009 + WGL_TRANSPARENT_ARB 0x200A + WGL_SHARE_DEPTH_ARB 0x200C + WGL_SHARE_STENCIL_ARB 0x200D + WGL_SHARE_ACCUM_ARB 0x200E + WGL_SUPPORT_GDI_ARB 0x200F + WGL_SUPPORT_OPENGL_ARB 0x2010 + WGL_DOUBLE_BUFFER_ARB 0x2011 + WGL_STEREO_ARB 0x2012 + WGL_PIXEL_TYPE_ARB 0x2013 + WGL_COLOR_BITS_ARB 0x2014 + WGL_RED_BITS_ARB 0x2015 + WGL_RED_SHIFT_ARB 0x2016 + WGL_GREEN_BITS_ARB 0x2017 + WGL_GREEN_SHIFT_ARB 0x2018 + WGL_BLUE_BITS_ARB 0x2019 + WGL_BLUE_SHIFT_ARB 0x201A + WGL_ALPHA_BITS_ARB 0x201B + WGL_ALPHA_SHIFT_ARB 0x201C + WGL_ACCUM_BITS_ARB 0x201D + WGL_ACCUM_RED_BITS_ARB 0x201E + WGL_ACCUM_GREEN_BITS_ARB 0x201F + WGL_ACCUM_BLUE_BITS_ARB 0x2020 + WGL_ACCUM_ALPHA_BITS_ARB 0x2021 + WGL_DEPTH_BITS_ARB 0x2022 + WGL_STENCIL_BITS_ARB 0x2023 + WGL_AUX_BUFFERS_ARB 0x2024 + WGL_NO_ACCELERATION_ARB 0x2025 + WGL_GENERIC_ACCELERATION_ARB 0x2026 + WGL_FULL_ACCELERATION_ARB 0x2027 + WGL_SWAP_EXCHANGE_ARB 0x2028 + WGL_SWAP_COPY_ARB 0x2029 + WGL_SWAP_UNDEFINED_ARB 0x202A + WGL_TYPE_RGBA_ARB 0x202B + WGL_TYPE_COLORINDEX_ARB 0x202C + WGL_TRANSPARENT_RED_VALUE_ARB 0x2037 + WGL_TRANSPARENT_GREEN_VALUE_ARB 0x2038 + WGL_TRANSPARENT_BLUE_VALUE_ARB 0x2039 + WGL_TRANSPARENT_ALPHA_VALUE_ARB 0x203A + WGL_TRANSPARENT_INDEX_VALUE_ARB 0x203B + BOOL wglChoosePixelFormatARB (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats) + BOOL wglGetPixelFormatAttribfvARB (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, FLOAT *pfValues) + BOOL wglGetPixelFormatAttribivARB (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, int *piValues) diff --git a/Externals/GLew/auto/extensions/WGL_ARB_pixel_format_float b/Externals/GLew/auto/extensions/WGL_ARB_pixel_format_float new file mode 100644 index 0000000000..f45294cafb --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_pixel_format_float @@ -0,0 +1,4 @@ +WGL_ARB_pixel_format_float +http://www.opengl.org/registry/specs/ARB/color_buffer_float.txt +WGL_ARB_pixel_format_float + WGL_TYPE_RGBA_FLOAT_ARB 0x21A0 diff --git a/Externals/GLew/auto/extensions/WGL_ARB_render_texture b/Externals/GLew/auto/extensions/WGL_ARB_render_texture new file mode 100644 index 0000000000..7821263ad1 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ARB_render_texture @@ -0,0 +1,39 @@ +WGL_ARB_render_texture +http://www.opengl.org/registry/specs/ARB/wgl_render_texture.txt +WGL_ARB_render_texture + WGL_BIND_TO_TEXTURE_RGB_ARB 0x2070 + WGL_BIND_TO_TEXTURE_RGBA_ARB 0x2071 + WGL_TEXTURE_FORMAT_ARB 0x2072 + WGL_TEXTURE_TARGET_ARB 0x2073 + WGL_MIPMAP_TEXTURE_ARB 0x2074 + WGL_TEXTURE_RGB_ARB 0x2075 + WGL_TEXTURE_RGBA_ARB 0x2076 + WGL_NO_TEXTURE_ARB 0x2077 + WGL_TEXTURE_CUBE_MAP_ARB 0x2078 + WGL_TEXTURE_1D_ARB 0x2079 + WGL_TEXTURE_2D_ARB 0x207A + WGL_MIPMAP_LEVEL_ARB 0x207B + WGL_CUBE_MAP_FACE_ARB 0x207C + WGL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x207D + WGL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x207E + WGL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x207F + WGL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x2080 + WGL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x2081 + WGL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x2082 + WGL_FRONT_LEFT_ARB 0x2083 + WGL_FRONT_RIGHT_ARB 0x2084 + WGL_BACK_LEFT_ARB 0x2085 + WGL_BACK_RIGHT_ARB 0x2086 + WGL_AUX0_ARB 0x2087 + WGL_AUX1_ARB 0x2088 + WGL_AUX2_ARB 0x2089 + WGL_AUX3_ARB 0x208A + WGL_AUX4_ARB 0x208B + WGL_AUX5_ARB 0x208C + WGL_AUX6_ARB 0x208D + WGL_AUX7_ARB 0x208E + WGL_AUX8_ARB 0x208F + WGL_AUX9_ARB 0x2090 + BOOL wglBindTexImageARB (HPBUFFERARB hPbuffer, int iBuffer) + BOOL wglReleaseTexImageARB (HPBUFFERARB hPbuffer, int iBuffer) + BOOL wglSetPbufferAttribARB (HPBUFFERARB hPbuffer, const int* piAttribList) diff --git a/Externals/GLew/auto/extensions/WGL_ATI_pixel_format_float b/Externals/GLew/auto/extensions/WGL_ATI_pixel_format_float new file mode 100644 index 0000000000..ba6f51a32a --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ATI_pixel_format_float @@ -0,0 +1,6 @@ +WGL_ATI_pixel_format_float +http://www.opengl.org/registry/specs/ATI/pixel_format_float.txt +WGL_ATI_pixel_format_float + WGL_TYPE_RGBA_FLOAT_ATI 0x21A0 + GL_RGBA_FLOAT_MODE_ATI 0x8820 + GL_COLOR_CLEAR_UNCLAMPED_VALUE_ATI 0x8835 diff --git a/Externals/GLew/auto/extensions/WGL_ATI_render_texture_rectangle b/Externals/GLew/auto/extensions/WGL_ATI_render_texture_rectangle new file mode 100644 index 0000000000..55df114d31 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_ATI_render_texture_rectangle @@ -0,0 +1,4 @@ +WGL_ATI_render_texture_rectangle + +WGL_ATI_render_texture_rectangle + WGL_TEXTURE_RECTANGLE_ATI 0x21A5 diff --git a/Externals/GLew/auto/extensions/WGL_EXT_depth_float b/Externals/GLew/auto/extensions/WGL_EXT_depth_float new file mode 100644 index 0000000000..f8f3efed67 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_depth_float @@ -0,0 +1,4 @@ +WGL_EXT_depth_float +http://www.opengl.org/registry/specs/EXT/wgl_depth_float.txt +WGL_EXT_depth_float + WGL_DEPTH_FLOAT_EXT 0x2040 diff --git a/Externals/GLew/auto/extensions/WGL_EXT_display_color_table b/Externals/GLew/auto/extensions/WGL_EXT_display_color_table new file mode 100644 index 0000000000..4de4a3d690 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_display_color_table @@ -0,0 +1,7 @@ +WGL_EXT_display_color_table +http://www.opengl.org/registry/specs/EXT/wgl_display_color_table.txt +WGL_EXT_display_color_table + GLboolean wglBindDisplayColorTableEXT (GLushort id) + GLboolean wglCreateDisplayColorTableEXT (GLushort id) + void wglDestroyDisplayColorTableEXT (GLushort id) + GLboolean wglLoadDisplayColorTableEXT (GLushort* table, GLuint length) diff --git a/Externals/GLew/auto/extensions/WGL_EXT_extensions_string b/Externals/GLew/auto/extensions/WGL_EXT_extensions_string new file mode 100644 index 0000000000..1f0cda0f1f --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_extensions_string @@ -0,0 +1,4 @@ +WGL_EXT_extensions_string +http://www.opengl.org/registry/specs/EXT/wgl_extensions_string.txt +WGL_EXT_extensions_string + const char* wglGetExtensionsStringEXT (void) diff --git a/Externals/GLew/auto/extensions/WGL_EXT_framebuffer_sRGB b/Externals/GLew/auto/extensions/WGL_EXT_framebuffer_sRGB new file mode 100644 index 0000000000..e4a40322fd --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_framebuffer_sRGB @@ -0,0 +1,4 @@ +WGL_EXT_framebuffer_sRGB +http://developer.download.nvidia.com/opengl/specs/GL_EXT_framebuffer_sRGB.txt +WGL_EXT_framebuffer_sRGB + WGL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20A9 diff --git a/Externals/GLew/auto/extensions/WGL_EXT_make_current_read b/Externals/GLew/auto/extensions/WGL_EXT_make_current_read new file mode 100644 index 0000000000..d92c307cfd --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_make_current_read @@ -0,0 +1,6 @@ +WGL_EXT_make_current_read +http://www.opengl.org/registry/specs/EXT/wgl_make_current_read.txt +WGL_EXT_make_current_read + HDC wglGetCurrentReadDCEXT (VOID) + BOOL wglMakeContextCurrentEXT (HDC hDrawDC, HDC hReadDC, HGLRC hglrc) + ERROR_INVALID_PIXEL_TYPE_EXT 0x2043 diff --git a/Externals/GLew/auto/extensions/WGL_EXT_multisample b/Externals/GLew/auto/extensions/WGL_EXT_multisample new file mode 100644 index 0000000000..e419a3312f --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_multisample @@ -0,0 +1,5 @@ +WGL_EXT_multisample +http://www.opengl.org/registry/specs/EXT/wgl_multisample.txt +WGL_EXT_multisample + WGL_SAMPLE_BUFFERS_EXT 0x2041 + WGL_SAMPLES_EXT 0x2042 diff --git a/Externals/GLew/auto/extensions/WGL_EXT_pbuffer b/Externals/GLew/auto/extensions/WGL_EXT_pbuffer new file mode 100644 index 0000000000..d32a950382 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_pbuffer @@ -0,0 +1,18 @@ +WGL_EXT_pbuffer +http://www.opengl.org/registry/specs/EXT/wgl_pbuffer.txt +WGL_EXT_pbuffer + WGL_DRAW_TO_PBUFFER_EXT 0x202D + WGL_MAX_PBUFFER_PIXELS_EXT 0x202E + WGL_MAX_PBUFFER_WIDTH_EXT 0x202F + WGL_MAX_PBUFFER_HEIGHT_EXT 0x2030 + WGL_OPTIMAL_PBUFFER_WIDTH_EXT 0x2031 + WGL_OPTIMAL_PBUFFER_HEIGHT_EXT 0x2032 + WGL_PBUFFER_LARGEST_EXT 0x2033 + WGL_PBUFFER_WIDTH_EXT 0x2034 + WGL_PBUFFER_HEIGHT_EXT 0x2035 + HPBUFFEREXT wglCreatePbufferEXT (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList) + BOOL wglDestroyPbufferEXT (HPBUFFEREXT hPbuffer) + HDC wglGetPbufferDCEXT (HPBUFFEREXT hPbuffer) + BOOL wglQueryPbufferEXT (HPBUFFEREXT hPbuffer, int iAttribute, int* piValue) + int wglReleasePbufferDCEXT (HPBUFFEREXT hPbuffer, HDC hDC) + DECLARE_HANDLE(HPBUFFEREXT); diff --git a/Externals/GLew/auto/extensions/WGL_EXT_pixel_format b/Externals/GLew/auto/extensions/WGL_EXT_pixel_format new file mode 100644 index 0000000000..6b189332fa --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_pixel_format @@ -0,0 +1,51 @@ +WGL_EXT_pixel_format +http://www.opengl.org/registry/specs/EXT/wgl_pixel_format.txt +WGL_EXT_pixel_format + WGL_NUMBER_PIXEL_FORMATS_EXT 0x2000 + WGL_DRAW_TO_WINDOW_EXT 0x2001 + WGL_DRAW_TO_BITMAP_EXT 0x2002 + WGL_ACCELERATION_EXT 0x2003 + WGL_NEED_PALETTE_EXT 0x2004 + WGL_NEED_SYSTEM_PALETTE_EXT 0x2005 + WGL_SWAP_LAYER_BUFFERS_EXT 0x2006 + WGL_SWAP_METHOD_EXT 0x2007 + WGL_NUMBER_OVERLAYS_EXT 0x2008 + WGL_NUMBER_UNDERLAYS_EXT 0x2009 + WGL_TRANSPARENT_EXT 0x200A + WGL_TRANSPARENT_VALUE_EXT 0x200B + WGL_SHARE_DEPTH_EXT 0x200C + WGL_SHARE_STENCIL_EXT 0x200D + WGL_SHARE_ACCUM_EXT 0x200E + WGL_SUPPORT_GDI_EXT 0x200F + WGL_SUPPORT_OPENGL_EXT 0x2010 + WGL_DOUBLE_BUFFER_EXT 0x2011 + WGL_STEREO_EXT 0x2012 + WGL_PIXEL_TYPE_EXT 0x2013 + WGL_COLOR_BITS_EXT 0x2014 + WGL_RED_BITS_EXT 0x2015 + WGL_RED_SHIFT_EXT 0x2016 + WGL_GREEN_BITS_EXT 0x2017 + WGL_GREEN_SHIFT_EXT 0x2018 + WGL_BLUE_BITS_EXT 0x2019 + WGL_BLUE_SHIFT_EXT 0x201A + WGL_ALPHA_BITS_EXT 0x201B + WGL_ALPHA_SHIFT_EXT 0x201C + WGL_ACCUM_BITS_EXT 0x201D + WGL_ACCUM_RED_BITS_EXT 0x201E + WGL_ACCUM_GREEN_BITS_EXT 0x201F + WGL_ACCUM_BLUE_BITS_EXT 0x2020 + WGL_ACCUM_ALPHA_BITS_EXT 0x2021 + WGL_DEPTH_BITS_EXT 0x2022 + WGL_STENCIL_BITS_EXT 0x2023 + WGL_AUX_BUFFERS_EXT 0x2024 + WGL_NO_ACCELERATION_EXT 0x2025 + WGL_GENERIC_ACCELERATION_EXT 0x2026 + WGL_FULL_ACCELERATION_EXT 0x2027 + WGL_SWAP_EXCHANGE_EXT 0x2028 + WGL_SWAP_COPY_EXT 0x2029 + WGL_SWAP_UNDEFINED_EXT 0x202A + WGL_TYPE_RGBA_EXT 0x202B + WGL_TYPE_COLORINDEX_EXT 0x202C + BOOL wglChoosePixelFormatEXT (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats) + BOOL wglGetPixelFormatAttribfvEXT (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, FLOAT *pfValues) + BOOL wglGetPixelFormatAttribivEXT (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, int *piValues) diff --git a/Externals/GLew/auto/extensions/WGL_EXT_pixel_format_packed_float b/Externals/GLew/auto/extensions/WGL_EXT_pixel_format_packed_float new file mode 100644 index 0000000000..30925fc5da --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_pixel_format_packed_float @@ -0,0 +1,4 @@ +WGL_EXT_pixel_format_packed_float +http://developer.download.nvidia.com/opengl/specs/GL_EXT_packed_float.txt +WGL_EXT_pixel_format_packed_float + WGL_TYPE_RGBA_UNSIGNED_FLOAT_EXT 0x20A8 diff --git a/Externals/GLew/auto/extensions/WGL_EXT_swap_control b/Externals/GLew/auto/extensions/WGL_EXT_swap_control new file mode 100644 index 0000000000..c3d63f5181 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_EXT_swap_control @@ -0,0 +1,5 @@ +WGL_EXT_swap_control +http://www.opengl.org/registry/specs/EXT/wgl_swap_control.txt +WGL_EXT_swap_control + int wglGetSwapIntervalEXT (void) + BOOL wglSwapIntervalEXT (int interval) diff --git a/Externals/GLew/auto/extensions/WGL_I3D_digital_video_control b/Externals/GLew/auto/extensions/WGL_I3D_digital_video_control new file mode 100644 index 0000000000..6dff1d3f62 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_I3D_digital_video_control @@ -0,0 +1,9 @@ +WGL_I3D_digital_video_control +http://www.opengl.org/registry/specs/I3D/wgl_digital_video_control.txt +WGL_I3D_digital_video_control + WGL_DIGITAL_VIDEO_CURSOR_ALPHA_FRAMEBUFFER_I3D 0x2050 + WGL_DIGITAL_VIDEO_CURSOR_ALPHA_VALUE_I3D 0x2051 + WGL_DIGITAL_VIDEO_CURSOR_INCLUDED_I3D 0x2052 + WGL_DIGITAL_VIDEO_GAMMA_CORRECTED_I3D 0x2053 + BOOL wglGetDigitalVideoParametersI3D (HDC hDC, int iAttribute, int* piValue) + BOOL wglSetDigitalVideoParametersI3D (HDC hDC, int iAttribute, const int* piValue) diff --git a/Externals/GLew/auto/extensions/WGL_I3D_gamma b/Externals/GLew/auto/extensions/WGL_I3D_gamma new file mode 100644 index 0000000000..6df2a59ca3 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_I3D_gamma @@ -0,0 +1,9 @@ +WGL_I3D_gamma +http://www.opengl.org/registry/specs/I3D/wgl_gamma.txt +WGL_I3D_gamma + WGL_GAMMA_TABLE_SIZE_I3D 0x204E + WGL_GAMMA_EXCLUDE_DESKTOP_I3D 0x204F + BOOL wglGetGammaTableI3D (HDC hDC, int iEntries, USHORT* puRed, USHORT *puGreen, USHORT *puBlue) + BOOL wglGetGammaTableParametersI3D (HDC hDC, int iAttribute, int* piValue) + BOOL wglSetGammaTableI3D (HDC hDC, int iEntries, const USHORT* puRed, const USHORT *puGreen, const USHORT *puBlue) + BOOL wglSetGammaTableParametersI3D (HDC hDC, int iAttribute, const int* piValue) diff --git a/Externals/GLew/auto/extensions/WGL_I3D_genlock b/Externals/GLew/auto/extensions/WGL_I3D_genlock new file mode 100644 index 0000000000..ef6a7aa28f --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_I3D_genlock @@ -0,0 +1,24 @@ +WGL_I3D_genlock +http://www.opengl.org/registry/specs/I3D/wgl_genlock.txt +WGL_I3D_genlock + WGL_GENLOCK_SOURCE_MULTIVIEW_I3D 0x2044 + WGL_GENLOCK_SOURCE_EXTERNAL_SYNC_I3D 0x2045 + WGL_GENLOCK_SOURCE_EXTERNAL_FIELD_I3D 0x2046 + WGL_GENLOCK_SOURCE_EXTERNAL_TTL_I3D 0x2047 + WGL_GENLOCK_SOURCE_DIGITAL_SYNC_I3D 0x2048 + WGL_GENLOCK_SOURCE_DIGITAL_FIELD_I3D 0x2049 + WGL_GENLOCK_SOURCE_EDGE_FALLING_I3D 0x204A + WGL_GENLOCK_SOURCE_EDGE_RISING_I3D 0x204B + WGL_GENLOCK_SOURCE_EDGE_BOTH_I3D 0x204C + BOOL wglDisableGenlockI3D (HDC hDC) + BOOL wglEnableGenlockI3D (HDC hDC) + BOOL wglGenlockSampleRateI3D (HDC hDC, UINT uRate) + BOOL wglGenlockSourceDelayI3D (HDC hDC, UINT uDelay) + BOOL wglGenlockSourceEdgeI3D (HDC hDC, UINT uEdge) + BOOL wglGenlockSourceI3D (HDC hDC, UINT uSource) + BOOL wglGetGenlockSampleRateI3D (HDC hDC, UINT* uRate) + BOOL wglGetGenlockSourceDelayI3D (HDC hDC, UINT* uDelay) + BOOL wglGetGenlockSourceEdgeI3D (HDC hDC, UINT* uEdge) + BOOL wglGetGenlockSourceI3D (HDC hDC, UINT* uSource) + BOOL wglIsEnabledGenlockI3D (HDC hDC, BOOL* pFlag) + BOOL wglQueryGenlockMaxSourceDelayI3D (HDC hDC, UINT* uMaxLineDelay, UINT *uMaxPixelDelay) diff --git a/Externals/GLew/auto/extensions/WGL_I3D_image_buffer b/Externals/GLew/auto/extensions/WGL_I3D_image_buffer new file mode 100644 index 0000000000..fa4a66db9c --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_I3D_image_buffer @@ -0,0 +1,9 @@ +WGL_I3D_image_buffer +http://www.opengl.org/registry/specs/I3D/wgl_image_buffer.txt +WGL_I3D_image_buffer + WGL_IMAGE_BUFFER_MIN_ACCESS_I3D 0x00000001 + WGL_IMAGE_BUFFER_LOCK_I3D 0x00000002 + BOOL wglAssociateImageBufferEventsI3D (HDC hdc, HANDLE* pEvent, LPVOID *pAddress, DWORD *pSize, UINT count) + LPVOID wglCreateImageBufferI3D (HDC hDC, DWORD dwSize, UINT uFlags) + BOOL wglDestroyImageBufferI3D (HDC hDC, LPVOID pAddress) + BOOL wglReleaseImageBufferEventsI3D (HDC hdc, LPVOID* pAddress, UINT count) diff --git a/Externals/GLew/auto/extensions/WGL_I3D_swap_frame_lock b/Externals/GLew/auto/extensions/WGL_I3D_swap_frame_lock new file mode 100644 index 0000000000..76cf91f9c3 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_I3D_swap_frame_lock @@ -0,0 +1,7 @@ +WGL_I3D_swap_frame_lock +http://www.opengl.org/registry/specs/I3D/wgl_swap_frame_lock.txt +WGL_I3D_swap_frame_lock + BOOL wglDisableFrameLockI3D (VOID) + BOOL wglEnableFrameLockI3D (VOID) + BOOL wglIsEnabledFrameLockI3D (BOOL* pFlag) + BOOL wglQueryFrameLockMasterI3D (BOOL* pFlag) diff --git a/Externals/GLew/auto/extensions/WGL_I3D_swap_frame_usage b/Externals/GLew/auto/extensions/WGL_I3D_swap_frame_usage new file mode 100644 index 0000000000..59546a55e5 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_I3D_swap_frame_usage @@ -0,0 +1,7 @@ +WGL_I3D_swap_frame_usage +http://www.opengl.org/registry/specs/I3D/wgl_swap_frame_usage.txt +WGL_I3D_swap_frame_usage + BOOL wglBeginFrameTrackingI3D (void) + BOOL wglEndFrameTrackingI3D (void) + BOOL wglGetFrameUsageI3D (float* pUsage) + BOOL wglQueryFrameTrackingI3D (DWORD* pFrameCount, DWORD *pMissedFrames, float *pLastMissedUsage) diff --git a/Externals/GLew/auto/extensions/WGL_NV_copy_image b/Externals/GLew/auto/extensions/WGL_NV_copy_image new file mode 100644 index 0000000000..8b2a91910b --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_copy_image @@ -0,0 +1,4 @@ +WGL_NV_copy_image +http://www.opengl.org/registry/specs/NV/copy_image.txt +WGL_NV_copy_image + BOOL wglCopyImageSubDataNV (HGLRC hSrcRC, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, HGLRC hDstRC, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth) diff --git a/Externals/GLew/auto/extensions/WGL_NV_float_buffer b/Externals/GLew/auto/extensions/WGL_NV_float_buffer new file mode 100644 index 0000000000..508e82ee85 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_float_buffer @@ -0,0 +1,12 @@ +WGL_NV_float_buffer +http://www.opengl.org/registry/specs/NV/float_buffer.txt +WGL_NV_float_buffer + WGL_FLOAT_COMPONENTS_NV 0x20B0 + WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_R_NV 0x20B1 + WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RG_NV 0x20B2 + WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGB_NV 0x20B3 + WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGBA_NV 0x20B4 + WGL_TEXTURE_FLOAT_R_NV 0x20B5 + WGL_TEXTURE_FLOAT_RG_NV 0x20B6 + WGL_TEXTURE_FLOAT_RGB_NV 0x20B7 + WGL_TEXTURE_FLOAT_RGBA_NV 0x20B8 diff --git a/Externals/GLew/auto/extensions/WGL_NV_gpu_affinity b/Externals/GLew/auto/extensions/WGL_NV_gpu_affinity new file mode 100644 index 0000000000..f722204cd7 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_gpu_affinity @@ -0,0 +1,12 @@ +WGL_NV_gpu_affinity +http://developer.download.nvidia.com/opengl/specs/WGL_nv_gpu_affinity.txt +WGL_NV_gpu_affinity + WGL_ERROR_INCOMPATIBLE_AFFINITY_MASKS_NV 0x20D0 + WGL_ERROR_MISSING_AFFINITY_MASK_NV 0x20D1 + BOOL wglEnumGpusNV (UINT iGpuIndex, HGPUNV *phGpu) + BOOL wglEnumGpuDevicesNV (HGPUNV hGpu, UINT iDeviceIndex, PGPU_DEVICE lpGpuDevice) + HDC wglCreateAffinityDCNV (const HGPUNV *phGpuList) + BOOL wglEnumGpusFromAffinityDCNV (HDC hAffinityDC, UINT iGpuIndex, HGPUNV *hGpu) + BOOL wglDeleteDCNV (HDC hdc) + DECLARE_HANDLE(HGPUNV); + typedef struct _GPU_DEVICE { DWORD cb; CHAR DeviceName[32]; CHAR DeviceString[128]; DWORD Flags; RECT rcVirtualScreen; } GPU_DEVICE, *PGPU_DEVICE; diff --git a/Externals/GLew/auto/extensions/WGL_NV_present_video b/Externals/GLew/auto/extensions/WGL_NV_present_video new file mode 100644 index 0000000000..4e62467984 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_present_video @@ -0,0 +1,8 @@ +WGL_NV_present_video +http://www.opengl.org/registry/specs/NV/present_video.txt +WGL_NV_present_video + WGL_NUM_VIDEO_SLOTS_NV 0x20F0 + BOOL wglBindVideoDeviceNV (HDC hDc, unsigned int uVideoSlot, HVIDEOOUTPUTDEVICENV hVideoDevice, const int* piAttribList) + int wglEnumerateVideoDevicesNV (HDC hDc, HVIDEOOUTPUTDEVICENV* phDeviceList) + BOOL wglQueryCurrentContextNV (int iAttribute, int* piValue) + DECLARE_HANDLE(HVIDEOOUTPUTDEVICENV); diff --git a/Externals/GLew/auto/extensions/WGL_NV_render_depth_texture b/Externals/GLew/auto/extensions/WGL_NV_render_depth_texture new file mode 100644 index 0000000000..c2e359af44 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_render_depth_texture @@ -0,0 +1,9 @@ +WGL_NV_render_depth_texture +http://www.opengl.org/registry/specs/NV/render_depth_texture.txt +WGL_NV_render_depth_texture + WGL_NO_TEXTURE_ARB 0x2077 + WGL_BIND_TO_TEXTURE_DEPTH_NV 0x20A3 + WGL_BIND_TO_TEXTURE_RECTANGLE_DEPTH_NV 0x20A4 + WGL_DEPTH_TEXTURE_FORMAT_NV 0x20A5 + WGL_TEXTURE_DEPTH_COMPONENT_NV 0x20A6 + WGL_DEPTH_COMPONENT_NV 0x20A7 diff --git a/Externals/GLew/auto/extensions/WGL_NV_render_texture_rectangle b/Externals/GLew/auto/extensions/WGL_NV_render_texture_rectangle new file mode 100644 index 0000000000..ada7e7ef5f --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_render_texture_rectangle @@ -0,0 +1,6 @@ +WGL_NV_render_texture_rectangle +http://www.opengl.org/registry/specs/NV/render_texture_rectangle.txt +WGL_NV_render_texture_rectangle + WGL_BIND_TO_TEXTURE_RECTANGLE_RGB_NV 0x20A0 + WGL_BIND_TO_TEXTURE_RECTANGLE_RGBA_NV 0x20A1 + WGL_TEXTURE_RECTANGLE_NV 0x20A2 diff --git a/Externals/GLew/auto/extensions/WGL_NV_swap_group b/Externals/GLew/auto/extensions/WGL_NV_swap_group new file mode 100644 index 0000000000..c114a4954c --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_swap_group @@ -0,0 +1,9 @@ +WGL_NV_swap_group +http://www.opengl.org/registry/specs/NV/wgl_swap_group.txt +WGL_NV_swap_group + BOOL wglBindSwapBarrierNV (GLuint group, GLuint barrier) + BOOL wglJoinSwapGroupNV (HDC hDC, GLuint group) + BOOL wglQueryFrameCountNV (HDC hDC, GLuint* count) + BOOL wglQueryMaxSwapGroupsNV (HDC hDC, GLuint* maxGroups, GLuint *maxBarriers) + BOOL wglQuerySwapGroupNV (HDC hDC, GLuint* group, GLuint *barrier) + BOOL wglResetFrameCountNV (HDC hDC) diff --git a/Externals/GLew/auto/extensions/WGL_NV_vertex_array_range b/Externals/GLew/auto/extensions/WGL_NV_vertex_array_range new file mode 100644 index 0000000000..ca22d31a3e --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_vertex_array_range @@ -0,0 +1,5 @@ +WGL_NV_vertex_array_range +http://oss.sgi.com/projects/ogl-sample/registry/NV/vertex_array_range.txt +WGL_NV_vertex_array_range + void * wglAllocateMemoryNV (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority) + void wglFreeMemoryNV (void *pointer) diff --git a/Externals/GLew/auto/extensions/WGL_NV_video_output b/Externals/GLew/auto/extensions/WGL_NV_video_output new file mode 100644 index 0000000000..87f243f649 --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_NV_video_output @@ -0,0 +1,23 @@ +WGL_NV_video_output +http://www.opengl.org/registry/specs/NV/wgl_video_out.txt +WGL_NV_video_output + WGL_BIND_TO_VIDEO_RGB_NV 0x20C0 + WGL_BIND_TO_VIDEO_RGBA_NV 0x20C1 + WGL_BIND_TO_VIDEO_RGB_AND_DEPTH_NV 0x20C2 + WGL_VIDEO_OUT_COLOR_NV 0x20C3 + WGL_VIDEO_OUT_ALPHA_NV 0x20C4 + WGL_VIDEO_OUT_DEPTH_NV 0x20C5 + WGL_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 + WGL_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 + WGL_VIDEO_OUT_FRAME 0x20C8 + WGL_VIDEO_OUT_FIELD_1 0x20C9 + WGL_VIDEO_OUT_FIELD_2 0x20CA + WGL_VIDEO_OUT_STACKED_FIELDS_1_2 0x20CB + WGL_VIDEO_OUT_STACKED_FIELDS_2_1 0x20CC + BOOL wglBindVideoImageNV (HPVIDEODEV hVideoDevice, HPBUFFERARB hPbuffer, int iVideoBuffer) + BOOL wglGetVideoDeviceNV (HDC hDC, int numDevices, HPVIDEODEV* hVideoDevice) + BOOL wglGetVideoInfoNV (HPVIDEODEV hpVideoDevice, unsigned long* pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo) + BOOL wglReleaseVideoDeviceNV (HPVIDEODEV hVideoDevice) + BOOL wglReleaseVideoImageNV (HPBUFFERARB hPbuffer, int iVideoBuffer) + BOOL wglSendPbufferToVideoNV (HPBUFFERARB hPbuffer, int iBufferType, unsigned long* pulCounterPbuffer, BOOL bBlock) + DECLARE_HANDLE(HPVIDEODEV); diff --git a/Externals/GLew/auto/extensions/WGL_OML_sync_control b/Externals/GLew/auto/extensions/WGL_OML_sync_control new file mode 100644 index 0000000000..d3265c8c7d --- /dev/null +++ b/Externals/GLew/auto/extensions/WGL_OML_sync_control @@ -0,0 +1,9 @@ +WGL_OML_sync_control +http://www.opengl.org/registry/specs/OML/wgl_sync_control.txt +WGL_OML_sync_control + BOOL wglGetMscRateOML (HDC hdc, INT32* numerator, INT32 *denominator) + BOOL wglGetSyncValuesOML (HDC hdc, INT64* ust, INT64 *msc, INT64 *sbc) + INT64 wglSwapBuffersMscOML (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder) + INT64 wglSwapLayerBuffersMscOML (HDC hdc, INT fuPlanes, INT64 target_msc, INT64 divisor, INT64 remainder) + BOOL wglWaitForMscOML (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder, INT64* ust, INT64 *msc, INT64 *sbc) + BOOL wglWaitForSbcOML (HDC hdc, INT64 target_sbc, INT64* ust, INT64 *msc, INT64 *sbc) diff --git a/Externals/GLew/auto/lib/OpenGL/Spec.pm b/Externals/GLew/auto/lib/OpenGL/Spec.pm new file mode 100644 index 0000000000..1311b394dd --- /dev/null +++ b/Externals/GLew/auto/lib/OpenGL/Spec.pm @@ -0,0 +1,202 @@ +package OpenGL::Spec; + +# A very simple task further complicated by the fact that some people +# can't read, others use legacy Operating Systems, and others don't give +# a damn about using a halfway decent text editor. +# +# The code to parse the _template_ is so simple and straightforward... +# yet the code to parse the real spec files is this mess. + +my %typemap = ( + bitfield => "GLbitfield", + boolean => "GLboolean", + # fsck up in EXT_vertex_array + Boolean => "GLboolean", + byte => "GLbyte", + clampd => "GLclampd", + clampf => "GLclampf", + double => "GLdouble", + enum => "GLenum", + # Intel fsck up + Glenum => "GLenum", + float => "GLfloat", + half => "GLuint", + int => "GLint", + short => "GLshort", + sizei => "GLsizei", + ubyte => "GLubyte", + uint => "GLuint", + ushort => "GLushort", + DMbuffer => "void *", + + # ARB VBO introduces these + sizeiptrARB => "GLsizeiptrARB", + intptrARB => "GLintptrARB", + + # ARB shader objects introduces these, charARB is at least 8 bits, + # handleARB is at least 32 bits + charARB => "GLcharARB", + handleARB => "GLhandleARB", + + # GLX 1.3 defines new types which might not be available at compile time + #GLXFBConfig => "void*", + #GLXFBConfigID => "XID", + #GLXContextID => "XID", + #GLXWindow => "XID", + #GLXPbuffer => "XID", + + # Weird stuff for some SGIX extension + #GLXFBConfigSGIX => "void*", + #GLXFBConfigIDSGIX => "XID", +); + +my %void_typemap = ( + void => "GLvoid", +); + +my $section_re = qr{^[A-Z]}; +my $function_re = qr{^(.+) ([a-z][a-z0-9_]*) \((.+)\)$}i; +my $token_re = qr{^([A-Z0-9][A-Z0-9_]*):?\s+((?:0x)?[0-9A-F]+)(.*)$}; +my $prefix_re = qr{^(?:AGL | GLX | WGL)_}x; +my $eofnc_re = qr{ \);?$ | ^$ }x; +my $function_re = qr{^(.+) ([a-z][a-z0-9_]*) \((.+)\)$}i; +my $prefix_re = qr{^(?:gl | agl | wgl | glX)}x; +my $types_re = __compile_wordlist_cap(keys %typemap); +my $voidtype_re = __compile_wordlist_cap(keys %void_typemap); + +sub new($) +{ + my $class = shift; + my $self = { section => {} }; + $self->{filename} = shift; + local $/; + open(my $fh, "<$self->{filename}") or die "Can't open $self->{filename}"; + my $content = <$fh>; + my $section; + my $s = $self->{section}; + + $content =~ s{[ \t]+$}{}mg; + # Join lines that end with a word-character and ones that *begin* + # with one + $content =~ s{(\w)\n(\w)}{$1 $2}sg; + + foreach (split /\n/, $content) + { + if (/$section_re/) + { + chomp; + s/^Name String$/Name Strings/; # Fix common mistake + $section = $_; + $s->{$section} = ""; + } + elsif (defined $section and exists $s->{$section}) + { + s{^\s+}{}mg; # Remove leading whitespace + $s->{$section} .= $_ . "\n"; + } + } + + $s->{$_} =~ s{(?:^\n+|\n+$)}{}s foreach keys %$s; + + bless $self, $class; +} + +sub sections() +{ + my $self = shift; + keys %{$self->{section}}; +} + +sub name() +{ + my $self = shift; + $self->{section}->{Name}; +} + +sub name_strings() +{ + my $self = shift; + split("\n", $self->{section}->{"Name Strings"}); +} + +sub tokens() +{ + my $self = shift; + my %tokens = (); + foreach (split /\n/, $self->{section}->{"New Tokens"}) + { + next unless /$token_re/; + my ($name, $value) = ($1, $2); + $name =~ s{^}{GL_} unless $name =~ /$prefix_re/; + $tokens{$name} = $value; + } + + return %tokens; +} + +sub functions() +{ + my $self = shift; + my %functions = (); + my @fnc = (); + + foreach (split /\n/, $self->{section}->{"New Procedures and Functions"}) + { + push @fnc, $_ unless ($_ eq "" or $_ eq "None"); + + next unless /$eofnc_re/; + + if (__normalize_proto(@fnc) =~ /$function_re/) + { + my ($return, $name, $parms) = ($1, $2, $3); + if (!__ignore_function($name, $extname)) + { + $name =~ s/^/gl/ unless $name =~ /$prefix_re/; + if ($name =~ /^gl/ && $name !~ /^glX/) + { + $return =~ s/$types_re/$typemap{$1}/g; + $return =~ s/$voidtype_re/$void_typemap{$1}/g; + $parms =~ s/$types_re/$typemap{$1}/g; + $parms =~ s/$voidtype_re/$void_typemap{$1}/g; + } + $functions{$name} = { + rtype => $return, + parms => $parms, + }; + } + } + @fnc = (); + } + + return %functions; +} + +sub __normalize_proto +{ + local $_ = join(" ", @_); + s/\s+/ /g; # multiple whitespace -> single space + s/\s*\(\s*/ \(/; # exactly one space before ( and none after + s/\s*\)\s*/\)/; # no after before or after ) + s/\s*\*([a-zA-Z])/\* $1/; # "* identifier" XXX: g missing? + s/\*wgl/\* wgl/; # "* wgl" XXX: why doesn't the + s/\*glX/\* glX/; # "* glX" previous re catch this? + s/\.\.\./void/; # ... -> void + s/;$//; # remove ; at the end of the line + return $_; +} + +sub __ignore_function +{ + return 0; +} + +sub __compile_regex +{ + my $regex = join('', @_); + return qr/$regex/ +} + +sub __compile_wordlist_cap +{ + __compile_regex('\b(', join('|', @_), ')\b'); +} diff --git a/Externals/GLew/auto/src/footer.html b/Externals/GLew/auto/src/footer.html new file mode 100644 index 0000000000..3adb9c14cb --- /dev/null +++ b/Externals/GLew/auto/src/footer.html @@ -0,0 +1,4 @@ + + + + diff --git a/Externals/GLew/auto/src/glew.rc b/Externals/GLew/auto/src/glew.rc new file mode 100644 index 0000000000..5674cc9cd5 --- /dev/null +++ b/Externals/GLew/auto/src/glew.rc @@ -0,0 +1,77 @@ + +#include + +#ifdef GLEW_MX +# ifdef GLEW_STATIC +# ifdef _DEBUG +# define FILENAME "glew32mxsd.dll" +# else +# define FILENAME "glew32mxs.dll" +# endif +# else +# ifdef _DEBUG +# define FILENAME "glew32mxd.dll" +# else +# define FILENAME "glew32mx.dll" +# endif +# endif +#else +# ifdef GLEW_STATIC +# ifdef _DEBUG +# define FILENAME "glew32sd.dll" +# else +# define FILENAME "glew32s.dll" +# endif +# else +# ifdef _DEBUG +# define FILENAME "glew32d.dll" +# else +# define FILENAME "glew32.dll" +# endif +# endif +#endif + +///////////////////////////////////////////////////////////////////////////// +// +// Version +// +VS_VERSION_INFO VERSIONINFO +FILEVERSION GLEW_MAJOR, GLEW_MINOR, GLEW_MICRO, 0 +PRODUCTVERSION GLEW_MAJOR, GLEW_MINOR, GLEW_MICRO, 0 +FILEFLAGSMASK VS_FFI_FILEFLAGSMASK +#ifdef _DEBUG +FILEFLAGS VS_FF_DEBUG +#else +FILEFLAGS 0x0L +#endif +FILEOS VOS__WINDOWS32 +#ifdef GLEW_STATIC +FILETYPE VFT_STATIC_LIB +#else +FILETYPE VFT_DLL +#endif +FILESUBTYPE VFT2_UNKNOWN +BEGIN + BLOCK "StringFileInfo" + BEGIN + BLOCK "040904b0" + BEGIN + VALUE "Comments", "The OpenGL Extension Wrangler Library\r\nCopyright (C) 2002-2008, Milan Ikits \r\nCopyright (C) 2002-2008, Marcelo E. Magallon \r\nCopyright (C) 2002, Lev Povalahev\r\nAll rights reserved.\r\n\r\nRedistribution and use in source and binary forms, with or without \r\nmodification, are permitted provided that the following conditions are met:\r\n\r\n* Redistributions of source code must retain the above copyright notice, \r\n this list of conditions and the following disclaimer.\r\n* Redistributions in binary form must reproduce the above copyright notice, \r\n this list of conditions and the following disclaimer in the documentation \r\n and/or other materials provided with the distribution.\r\n* The name of the author may be used to endorse or promote products \r\n derived from this software without specific prior written permission.\r\n\r\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ''AS IS'' \r\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \r\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r\nARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \r\nLIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \r\nCONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \r\nSUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\r\nINTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\r\nCONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r\nARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\r\nTHE POSSIBILITY OF SUCH DAMAGE.\r\n\r\n\r\nMesa 3-D graphics library\r\n\r\nVersion: 7.0\r\n\r\nCopyright (C) 1999-2007 Brian Paul All Rights Reserved.\r\n\r\nPermission is hereby granted, free of charge, to any person obtaining a\r\ncopy of this software and associated documentation files (the ''Software''),\r\nto deal in the Software without restriction, including without limitation\r\nthe rights to use, copy, modify, merge, publish, distribute, sublicense,\r\nand/or sell copies of the Software, and to permit persons to whom the\r\nSoftware is furnished to do so, subject to the following conditions:\r\n\r\nThe above copyright notice and this permission notice shall be included\r\nin all copies or substantial portions of the Software.\r\n\r\nTHE SOFTWARE IS PROVIDED ''AS IS'', WITHOUT WARRANTY OF ANY KIND, EXPRESS\r\nOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL\r\nBRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN\r\nAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r\nCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r\n\r\n\r\nCopyright (c) 2007 The Khronos Group Inc.\r\n\r\nPermission is hereby granted, free of charge, to any person obtaining a\r\ncopy of this software and/or associated documentation files (the\r\n''Materials''), to deal in the Materials without restriction, including\r\nwithout limitation the rights to use, copy, modify, merge, publish,\r\ndistribute, sublicense, and/or sell copies of the Materials, and to\r\npermit persons to whom the Materials are furnished to do so, subject to\r\nthe following conditions:\r\n\r\nThe above copyright notice and this permission notice shall be included\r\nin all copies or substantial portions of the Materials.\r\n\r\nTHE MATERIALS ARE PROVIDED ''AS IS'', WITHOUT WARRANTY OF ANY KIND,\r\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\r\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\r\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\r\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\r\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\r\nMATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.\0" + VALUE "CompanyName", "\0" + VALUE "FileDescription", "The OpenGL Extension Wrangler Library\0" + VALUE "FileVersion", "GLEW_MAJOR,GLEW_MINOR,GLEW_MICRO,0\0" + VALUE "InternalName", "GLEW\0" + VALUE "LegalCopyright", " 2002-2008 Milan Ikits & Marcelo Magallon\0" + VALUE "LegalTrademarks", "\0" + VALUE "OriginalFilename", FILENAME "\0" + VALUE "PrivateBuild", "\0" + VALUE "ProductName", "The OpenGL Extension Wrangler Library\0" + VALUE "ProductVersion", "GLEW_MAJOR,GLEW_MINOR,GLEW_MICRO,0\0" + VALUE "SpecialBuild", "\0" + END + END + BLOCK "VarFileInfo" + BEGIN + VALUE "Translation", 0x409, 1200 + END +END diff --git a/Externals/GLew/auto/src/glew_head.c b/Externals/GLew/auto/src/glew_head.c new file mode 100644 index 0000000000..19afd9386e --- /dev/null +++ b/Externals/GLew/auto/src/glew_head.c @@ -0,0 +1,207 @@ +#include +#if defined(_WIN32) +# include +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +# include +#endif + +/* + * Define glewGetContext and related helper macros. + */ +#ifdef GLEW_MX +# define glewGetContext() ctx +# ifdef _WIN32 +# define GLEW_CONTEXT_ARG_DEF_INIT GLEWContext* ctx +# define GLEW_CONTEXT_ARG_VAR_INIT ctx +# define wglewGetContext() ctx +# define WGLEW_CONTEXT_ARG_DEF_INIT WGLEWContext* ctx +# define WGLEW_CONTEXT_ARG_DEF_LIST WGLEWContext* ctx +# else /* _WIN32 */ +# define GLEW_CONTEXT_ARG_DEF_INIT void +# define GLEW_CONTEXT_ARG_VAR_INIT +# define glxewGetContext() ctx +# define GLXEW_CONTEXT_ARG_DEF_INIT void +# define GLXEW_CONTEXT_ARG_DEF_LIST GLXEWContext* ctx +# endif /* _WIN32 */ +# define GLEW_CONTEXT_ARG_DEF_LIST GLEWContext* ctx +#else /* GLEW_MX */ +# define GLEW_CONTEXT_ARG_DEF_INIT void +# define GLEW_CONTEXT_ARG_VAR_INIT +# define GLEW_CONTEXT_ARG_DEF_LIST void +# define WGLEW_CONTEXT_ARG_DEF_INIT void +# define WGLEW_CONTEXT_ARG_DEF_LIST void +# define GLXEW_CONTEXT_ARG_DEF_INIT void +# define GLXEW_CONTEXT_ARG_DEF_LIST void +#endif /* GLEW_MX */ + +#if defined(__APPLE__) +#include +#include +#include + +#ifdef MAC_OS_X_VERSION_10_3 + +#include + +void* NSGLGetProcAddress (const GLubyte *name) +{ + static void* image = NULL; + if (NULL == image) + { + image = dlopen("/System/Library/Frameworks/OpenGL.framework/Versions/Current/OpenGL", RTLD_LAZY); + } + return image ? dlsym(image, (const char*)name) : NULL; +} +#else + +#include + +void* NSGLGetProcAddress (const GLubyte *name) +{ + static const struct mach_header* image = NULL; + NSSymbol symbol; + char* symbolName; + if (NULL == image) + { + image = NSAddImage("/System/Library/Frameworks/OpenGL.framework/Versions/Current/OpenGL", NSADDIMAGE_OPTION_RETURN_ON_ERROR); + } + /* prepend a '_' for the Unix C symbol mangling convention */ + symbolName = malloc(strlen((const char*)name) + 2); + strcpy(symbolName+1, (const char*)name); + symbolName[0] = '_'; + symbol = NULL; + /* if (NSIsSymbolNameDefined(symbolName)) + symbol = NSLookupAndBindSymbol(symbolName); */ + symbol = image ? NSLookupSymbolInImage(image, symbolName, NSLOOKUPSYMBOLINIMAGE_OPTION_BIND | NSLOOKUPSYMBOLINIMAGE_OPTION_RETURN_ON_ERROR) : NULL; + free(symbolName); + return symbol ? NSAddressOfSymbol(symbol) : NULL; +} +#endif /* MAC_OS_X_VERSION_10_3 */ +#endif /* __APPLE__ */ + +#if defined(__sgi) || defined (__sun) +#include +#include +#include + +void* dlGetProcAddress (const GLubyte* name) +{ + static void* h = NULL; + static void* gpa; + + if (h == NULL) + { + if ((h = dlopen(NULL, RTLD_LAZY | RTLD_LOCAL)) == NULL) return NULL; + gpa = dlsym(h, "glXGetProcAddress"); + } + + if (gpa != NULL) + return ((void*(*)(const GLubyte*))gpa)(name); + else + return dlsym(h, (const char*)name); +} +#endif /* __sgi || __sun */ + +/* + * Define glewGetProcAddress. + */ +#if defined(_WIN32) +# define glewGetProcAddress(name) wglGetProcAddress((LPCSTR)name) +#else +# if defined(__APPLE__) +# define glewGetProcAddress(name) NSGLGetProcAddress(name) +# else +# if defined(__sgi) || defined(__sun) +# define glewGetProcAddress(name) dlGetProcAddress(name) +# else /* __linux */ +# define glewGetProcAddress(name) (*glXGetProcAddressARB)(name) +# endif +# endif +#endif + +/* + * Define GLboolean const cast. + */ +#define CONST_CAST(x) (*(GLboolean*)&x) + +/* + * GLEW, just like OpenGL or GLU, does not rely on the standard C library. + * These functions implement the functionality required in this file. + */ +static GLuint _glewStrLen (const GLubyte* s) +{ + GLuint i=0; + if (s == NULL) return 0; + while (s[i] != '\0') i++; + return i; +} + +static GLuint _glewStrCLen (const GLubyte* s, GLubyte c) +{ + GLuint i=0; + if (s == NULL) return 0; + while (s[i] != '\0' && s[i] != c) i++; + return (s[i] == '\0' || s[i] == c) ? i : 0; +} + +static GLboolean _glewStrSame (const GLubyte* a, const GLubyte* b, GLuint n) +{ + GLuint i=0; + if(a == NULL || b == NULL) + return (a == NULL && b == NULL && n == 0) ? GL_TRUE : GL_FALSE; + while (i < n && a[i] != '\0' && b[i] != '\0' && a[i] == b[i]) i++; + return i == n ? GL_TRUE : GL_FALSE; +} + +static GLboolean _glewStrSame1 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + while (*na > 0 && (**a == ' ' || **a == '\n' || **a == '\r' || **a == '\t')) + { + (*a)++; + (*na)--; + } + if(*na >= nb) + { + GLuint i=0; + while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; + if(i == nb) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} + +static GLboolean _glewStrSame2 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + if(*na >= nb) + { + GLuint i=0; + while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; + if(i == nb) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} + +static GLboolean _glewStrSame3 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + if(*na >= nb) + { + GLuint i=0; + while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; + if (i == nb && (*na == nb || (*a)[i] == ' ' || (*a)[i] == '\n' || (*a)[i] == '\r' || (*a)[i] == '\t')) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} diff --git a/Externals/GLew/auto/src/glew_head.h b/Externals/GLew/auto/src/glew_head.h new file mode 100644 index 0000000000..ed49f50c38 --- /dev/null +++ b/Externals/GLew/auto/src/glew_head.h @@ -0,0 +1,1073 @@ +#ifndef __glew_h__ +#define __glew_h__ +#define __GLEW_H__ + +#if defined(__gl_h_) || defined(__GL_H__) || defined(__X_GL_H) +#error gl.h included before glew.h +#endif +#if defined(__glext_h_) || defined(__GLEXT_H_) +#error glext.h included before glew.h +#endif +#if defined(__gl_ATI_h_) +#error glATI.h included before glew.h +#endif + +#define __gl_h_ +#define __GL_H__ +#define __X_GL_H +#define __glext_h_ +#define __GLEXT_H_ +#define __gl_ATI_h_ + +#if defined(_WIN32) + +/* + * GLEW does not include to avoid name space pollution. + * GL needs GLAPI and GLAPIENTRY, GLU needs APIENTRY, CALLBACK, and wchar_t + * defined properly. + */ +/* */ +#ifndef APIENTRY +#define GLEW_APIENTRY_DEFINED +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define APIENTRY __stdcall +# elif (_MSC_VER >= 800) || defined(_STDCALL_SUPPORTED) || defined(__BORLANDC__) +# define APIENTRY __stdcall +# else +# define APIENTRY +# endif +#endif +#ifndef GLAPI +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define GLAPI extern +# endif +#endif +/* */ +#ifndef CALLBACK +#define GLEW_CALLBACK_DEFINED +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define CALLBACK __attribute__ ((__stdcall__)) +# elif (defined(_M_MRX000) || defined(_M_IX86) || defined(_M_ALPHA) || defined(_M_PPC)) && !defined(MIDL_PASS) +# define CALLBACK __stdcall +# else +# define CALLBACK +# endif +#endif +/* and */ +#ifndef WINGDIAPI +#define GLEW_WINGDIAPI_DEFINED +#define WINGDIAPI __declspec(dllimport) +#endif +/* */ +#if (defined(_MSC_VER) || defined(__BORLANDC__)) && !defined(_WCHAR_T_DEFINED) +typedef unsigned short wchar_t; +# define _WCHAR_T_DEFINED +#endif +/* */ +#if !defined(_W64) +# if !defined(__midl) && (defined(_X86_) || defined(_M_IX86)) && defined(_MSC_VER) && _MSC_VER >= 1300 +# define _W64 __w64 +# else +# define _W64 +# endif +#endif +#if !defined(_PTRDIFF_T_DEFINED) && !defined(_PTRDIFF_T_) +# ifdef _WIN64 +typedef __int64 ptrdiff_t; +# else +typedef _W64 int ptrdiff_t; +# endif +# define _PTRDIFF_T_DEFINED +# define _PTRDIFF_T_ +#endif + +#ifndef GLAPI +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define GLAPI extern +# else +# define GLAPI WINGDIAPI +# endif +#endif + +#ifndef GLAPIENTRY +#define GLAPIENTRY APIENTRY +#endif + +/* + * GLEW_STATIC needs to be set when using the static version. + * GLEW_BUILD is set when building the DLL version. + */ +#ifdef GLEW_STATIC +# define GLEWAPI extern +#else +# ifdef GLEW_BUILD +# define GLEWAPI extern __declspec(dllexport) +# else +# define GLEWAPI extern __declspec(dllimport) +# endif +#endif + +#else /* _UNIX */ + +/* + * Needed for ptrdiff_t in turn needed by VBO. This is defined by ISO + * C. On my system, this amounts to _3 lines_ of included code, all of + * them pretty much harmless. If you know of a way of detecting 32 vs + * 64 _targets_ at compile time you are free to replace this with + * something that's portable. For now, _this_ is the portable solution. + * (mem, 2004-01-04) + */ + +#include + +/* SGI MIPSPro doesn't like stdint.h in C++ mode */ + +#if defined(__sgi) && !defined(__GNUC__) +#include +#else +#include +#endif + +#define GLEW_APIENTRY_DEFINED +#define APIENTRY +#define GLEWAPI extern + +/* */ +#ifndef GLAPI +#define GLAPI extern +#endif +#ifndef GLAPIENTRY +#define GLAPIENTRY +#endif + +#endif /* _WIN32 */ + +#ifdef __cplusplus +extern "C" { +#endif + +/* ----------------------------- GL_VERSION_1_1 ---------------------------- */ + +#ifndef GL_VERSION_1_1 +#define GL_VERSION_1_1 1 + +typedef unsigned int GLenum; +typedef unsigned int GLbitfield; +typedef unsigned int GLuint; +typedef int GLint; +typedef int GLsizei; +typedef unsigned char GLboolean; +typedef signed char GLbyte; +typedef short GLshort; +typedef unsigned char GLubyte; +typedef unsigned short GLushort; +typedef unsigned long GLulong; +typedef float GLfloat; +typedef float GLclampf; +typedef double GLdouble; +typedef double GLclampd; +typedef void GLvoid; +#if defined(_MSC_VER) +# if _MSC_VER < 1400 +typedef __int64 GLint64EXT; +typedef unsigned __int64 GLuint64EXT; +# else +typedef signed long long GLint64EXT; +typedef unsigned long long GLuint64EXT; +# endif +#else +# if defined(__MINGW32__) || defined(__CYGWIN__) +#include +# endif +typedef int64_t GLint64EXT; +typedef uint64_t GLuint64EXT; +#endif +typedef GLint64EXT GLint64; +typedef GLuint64EXT GLuint64; +typedef struct __GLsync *GLsync; + +#define GL_ACCUM 0x0100 +#define GL_LOAD 0x0101 +#define GL_RETURN 0x0102 +#define GL_MULT 0x0103 +#define GL_ADD 0x0104 +#define GL_NEVER 0x0200 +#define GL_LESS 0x0201 +#define GL_EQUAL 0x0202 +#define GL_LEQUAL 0x0203 +#define GL_GREATER 0x0204 +#define GL_NOTEQUAL 0x0205 +#define GL_GEQUAL 0x0206 +#define GL_ALWAYS 0x0207 +#define GL_CURRENT_BIT 0x00000001 +#define GL_POINT_BIT 0x00000002 +#define GL_LINE_BIT 0x00000004 +#define GL_POLYGON_BIT 0x00000008 +#define GL_POLYGON_STIPPLE_BIT 0x00000010 +#define GL_PIXEL_MODE_BIT 0x00000020 +#define GL_LIGHTING_BIT 0x00000040 +#define GL_FOG_BIT 0x00000080 +#define GL_DEPTH_BUFFER_BIT 0x00000100 +#define GL_ACCUM_BUFFER_BIT 0x00000200 +#define GL_STENCIL_BUFFER_BIT 0x00000400 +#define GL_VIEWPORT_BIT 0x00000800 +#define GL_TRANSFORM_BIT 0x00001000 +#define GL_ENABLE_BIT 0x00002000 +#define GL_COLOR_BUFFER_BIT 0x00004000 +#define GL_HINT_BIT 0x00008000 +#define GL_EVAL_BIT 0x00010000 +#define GL_LIST_BIT 0x00020000 +#define GL_TEXTURE_BIT 0x00040000 +#define GL_SCISSOR_BIT 0x00080000 +#define GL_ALL_ATTRIB_BITS 0x000fffff +#define GL_POINTS 0x0000 +#define GL_LINES 0x0001 +#define GL_LINE_LOOP 0x0002 +#define GL_LINE_STRIP 0x0003 +#define GL_TRIANGLES 0x0004 +#define GL_TRIANGLE_STRIP 0x0005 +#define GL_TRIANGLE_FAN 0x0006 +#define GL_QUADS 0x0007 +#define GL_QUAD_STRIP 0x0008 +#define GL_POLYGON 0x0009 +#define GL_ZERO 0 +#define GL_ONE 1 +#define GL_SRC_COLOR 0x0300 +#define GL_ONE_MINUS_SRC_COLOR 0x0301 +#define GL_SRC_ALPHA 0x0302 +#define GL_ONE_MINUS_SRC_ALPHA 0x0303 +#define GL_DST_ALPHA 0x0304 +#define GL_ONE_MINUS_DST_ALPHA 0x0305 +#define GL_DST_COLOR 0x0306 +#define GL_ONE_MINUS_DST_COLOR 0x0307 +#define GL_SRC_ALPHA_SATURATE 0x0308 +#define GL_TRUE 1 +#define GL_FALSE 0 +#define GL_CLIP_PLANE0 0x3000 +#define GL_CLIP_PLANE1 0x3001 +#define GL_CLIP_PLANE2 0x3002 +#define GL_CLIP_PLANE3 0x3003 +#define GL_CLIP_PLANE4 0x3004 +#define GL_CLIP_PLANE5 0x3005 +#define GL_BYTE 0x1400 +#define GL_UNSIGNED_BYTE 0x1401 +#define GL_SHORT 0x1402 +#define GL_UNSIGNED_SHORT 0x1403 +#define GL_INT 0x1404 +#define GL_UNSIGNED_INT 0x1405 +#define GL_FLOAT 0x1406 +#define GL_2_BYTES 0x1407 +#define GL_3_BYTES 0x1408 +#define GL_4_BYTES 0x1409 +#define GL_DOUBLE 0x140A +#define GL_NONE 0 +#define GL_FRONT_LEFT 0x0400 +#define GL_FRONT_RIGHT 0x0401 +#define GL_BACK_LEFT 0x0402 +#define GL_BACK_RIGHT 0x0403 +#define GL_FRONT 0x0404 +#define GL_BACK 0x0405 +#define GL_LEFT 0x0406 +#define GL_RIGHT 0x0407 +#define GL_FRONT_AND_BACK 0x0408 +#define GL_AUX0 0x0409 +#define GL_AUX1 0x040A +#define GL_AUX2 0x040B +#define GL_AUX3 0x040C +#define GL_NO_ERROR 0 +#define GL_INVALID_ENUM 0x0500 +#define GL_INVALID_VALUE 0x0501 +#define GL_INVALID_OPERATION 0x0502 +#define GL_STACK_OVERFLOW 0x0503 +#define GL_STACK_UNDERFLOW 0x0504 +#define GL_OUT_OF_MEMORY 0x0505 +#define GL_2D 0x0600 +#define GL_3D 0x0601 +#define GL_3D_COLOR 0x0602 +#define GL_3D_COLOR_TEXTURE 0x0603 +#define GL_4D_COLOR_TEXTURE 0x0604 +#define GL_PASS_THROUGH_TOKEN 0x0700 +#define GL_POINT_TOKEN 0x0701 +#define GL_LINE_TOKEN 0x0702 +#define GL_POLYGON_TOKEN 0x0703 +#define GL_BITMAP_TOKEN 0x0704 +#define GL_DRAW_PIXEL_TOKEN 0x0705 +#define GL_COPY_PIXEL_TOKEN 0x0706 +#define GL_LINE_RESET_TOKEN 0x0707 +#define GL_EXP 0x0800 +#define GL_EXP2 0x0801 +#define GL_CW 0x0900 +#define GL_CCW 0x0901 +#define GL_COEFF 0x0A00 +#define GL_ORDER 0x0A01 +#define GL_DOMAIN 0x0A02 +#define GL_CURRENT_COLOR 0x0B00 +#define GL_CURRENT_INDEX 0x0B01 +#define GL_CURRENT_NORMAL 0x0B02 +#define GL_CURRENT_TEXTURE_COORDS 0x0B03 +#define GL_CURRENT_RASTER_COLOR 0x0B04 +#define GL_CURRENT_RASTER_INDEX 0x0B05 +#define GL_CURRENT_RASTER_TEXTURE_COORDS 0x0B06 +#define GL_CURRENT_RASTER_POSITION 0x0B07 +#define GL_CURRENT_RASTER_POSITION_VALID 0x0B08 +#define GL_CURRENT_RASTER_DISTANCE 0x0B09 +#define GL_POINT_SMOOTH 0x0B10 +#define GL_POINT_SIZE 0x0B11 +#define GL_POINT_SIZE_RANGE 0x0B12 +#define GL_POINT_SIZE_GRANULARITY 0x0B13 +#define GL_LINE_SMOOTH 0x0B20 +#define GL_LINE_WIDTH 0x0B21 +#define GL_LINE_WIDTH_RANGE 0x0B22 +#define GL_LINE_WIDTH_GRANULARITY 0x0B23 +#define GL_LINE_STIPPLE 0x0B24 +#define GL_LINE_STIPPLE_PATTERN 0x0B25 +#define GL_LINE_STIPPLE_REPEAT 0x0B26 +#define GL_LIST_MODE 0x0B30 +#define GL_MAX_LIST_NESTING 0x0B31 +#define GL_LIST_BASE 0x0B32 +#define GL_LIST_INDEX 0x0B33 +#define GL_POLYGON_MODE 0x0B40 +#define GL_POLYGON_SMOOTH 0x0B41 +#define GL_POLYGON_STIPPLE 0x0B42 +#define GL_EDGE_FLAG 0x0B43 +#define GL_CULL_FACE 0x0B44 +#define GL_CULL_FACE_MODE 0x0B45 +#define GL_FRONT_FACE 0x0B46 +#define GL_LIGHTING 0x0B50 +#define GL_LIGHT_MODEL_LOCAL_VIEWER 0x0B51 +#define GL_LIGHT_MODEL_TWO_SIDE 0x0B52 +#define GL_LIGHT_MODEL_AMBIENT 0x0B53 +#define GL_SHADE_MODEL 0x0B54 +#define GL_COLOR_MATERIAL_FACE 0x0B55 +#define GL_COLOR_MATERIAL_PARAMETER 0x0B56 +#define GL_COLOR_MATERIAL 0x0B57 +#define GL_FOG 0x0B60 +#define GL_FOG_INDEX 0x0B61 +#define GL_FOG_DENSITY 0x0B62 +#define GL_FOG_START 0x0B63 +#define GL_FOG_END 0x0B64 +#define GL_FOG_MODE 0x0B65 +#define GL_FOG_COLOR 0x0B66 +#define GL_DEPTH_RANGE 0x0B70 +#define GL_DEPTH_TEST 0x0B71 +#define GL_DEPTH_WRITEMASK 0x0B72 +#define GL_DEPTH_CLEAR_VALUE 0x0B73 +#define GL_DEPTH_FUNC 0x0B74 +#define GL_ACCUM_CLEAR_VALUE 0x0B80 +#define GL_STENCIL_TEST 0x0B90 +#define GL_STENCIL_CLEAR_VALUE 0x0B91 +#define GL_STENCIL_FUNC 0x0B92 +#define GL_STENCIL_VALUE_MASK 0x0B93 +#define GL_STENCIL_FAIL 0x0B94 +#define GL_STENCIL_PASS_DEPTH_FAIL 0x0B95 +#define GL_STENCIL_PASS_DEPTH_PASS 0x0B96 +#define GL_STENCIL_REF 0x0B97 +#define GL_STENCIL_WRITEMASK 0x0B98 +#define GL_MATRIX_MODE 0x0BA0 +#define GL_NORMALIZE 0x0BA1 +#define GL_VIEWPORT 0x0BA2 +#define GL_MODELVIEW_STACK_DEPTH 0x0BA3 +#define GL_PROJECTION_STACK_DEPTH 0x0BA4 +#define GL_TEXTURE_STACK_DEPTH 0x0BA5 +#define GL_MODELVIEW_MATRIX 0x0BA6 +#define GL_PROJECTION_MATRIX 0x0BA7 +#define GL_TEXTURE_MATRIX 0x0BA8 +#define GL_ATTRIB_STACK_DEPTH 0x0BB0 +#define GL_CLIENT_ATTRIB_STACK_DEPTH 0x0BB1 +#define GL_ALPHA_TEST 0x0BC0 +#define GL_ALPHA_TEST_FUNC 0x0BC1 +#define GL_ALPHA_TEST_REF 0x0BC2 +#define GL_DITHER 0x0BD0 +#define GL_BLEND_DST 0x0BE0 +#define GL_BLEND_SRC 0x0BE1 +#define GL_BLEND 0x0BE2 +#define GL_LOGIC_OP_MODE 0x0BF0 +#define GL_INDEX_LOGIC_OP 0x0BF1 +#define GL_COLOR_LOGIC_OP 0x0BF2 +#define GL_AUX_BUFFERS 0x0C00 +#define GL_DRAW_BUFFER 0x0C01 +#define GL_READ_BUFFER 0x0C02 +#define GL_SCISSOR_BOX 0x0C10 +#define GL_SCISSOR_TEST 0x0C11 +#define GL_INDEX_CLEAR_VALUE 0x0C20 +#define GL_INDEX_WRITEMASK 0x0C21 +#define GL_COLOR_CLEAR_VALUE 0x0C22 +#define GL_COLOR_WRITEMASK 0x0C23 +#define GL_INDEX_MODE 0x0C30 +#define GL_RGBA_MODE 0x0C31 +#define GL_DOUBLEBUFFER 0x0C32 +#define GL_STEREO 0x0C33 +#define GL_RENDER_MODE 0x0C40 +#define GL_PERSPECTIVE_CORRECTION_HINT 0x0C50 +#define GL_POINT_SMOOTH_HINT 0x0C51 +#define GL_LINE_SMOOTH_HINT 0x0C52 +#define GL_POLYGON_SMOOTH_HINT 0x0C53 +#define GL_FOG_HINT 0x0C54 +#define GL_TEXTURE_GEN_S 0x0C60 +#define GL_TEXTURE_GEN_T 0x0C61 +#define GL_TEXTURE_GEN_R 0x0C62 +#define GL_TEXTURE_GEN_Q 0x0C63 +#define GL_PIXEL_MAP_I_TO_I 0x0C70 +#define GL_PIXEL_MAP_S_TO_S 0x0C71 +#define GL_PIXEL_MAP_I_TO_R 0x0C72 +#define GL_PIXEL_MAP_I_TO_G 0x0C73 +#define GL_PIXEL_MAP_I_TO_B 0x0C74 +#define GL_PIXEL_MAP_I_TO_A 0x0C75 +#define GL_PIXEL_MAP_R_TO_R 0x0C76 +#define GL_PIXEL_MAP_G_TO_G 0x0C77 +#define GL_PIXEL_MAP_B_TO_B 0x0C78 +#define GL_PIXEL_MAP_A_TO_A 0x0C79 +#define GL_PIXEL_MAP_I_TO_I_SIZE 0x0CB0 +#define GL_PIXEL_MAP_S_TO_S_SIZE 0x0CB1 +#define GL_PIXEL_MAP_I_TO_R_SIZE 0x0CB2 +#define GL_PIXEL_MAP_I_TO_G_SIZE 0x0CB3 +#define GL_PIXEL_MAP_I_TO_B_SIZE 0x0CB4 +#define GL_PIXEL_MAP_I_TO_A_SIZE 0x0CB5 +#define GL_PIXEL_MAP_R_TO_R_SIZE 0x0CB6 +#define GL_PIXEL_MAP_G_TO_G_SIZE 0x0CB7 +#define GL_PIXEL_MAP_B_TO_B_SIZE 0x0CB8 +#define GL_PIXEL_MAP_A_TO_A_SIZE 0x0CB9 +#define GL_UNPACK_SWAP_BYTES 0x0CF0 +#define GL_UNPACK_LSB_FIRST 0x0CF1 +#define GL_UNPACK_ROW_LENGTH 0x0CF2 +#define GL_UNPACK_SKIP_ROWS 0x0CF3 +#define GL_UNPACK_SKIP_PIXELS 0x0CF4 +#define GL_UNPACK_ALIGNMENT 0x0CF5 +#define GL_PACK_SWAP_BYTES 0x0D00 +#define GL_PACK_LSB_FIRST 0x0D01 +#define GL_PACK_ROW_LENGTH 0x0D02 +#define GL_PACK_SKIP_ROWS 0x0D03 +#define GL_PACK_SKIP_PIXELS 0x0D04 +#define GL_PACK_ALIGNMENT 0x0D05 +#define GL_MAP_COLOR 0x0D10 +#define GL_MAP_STENCIL 0x0D11 +#define GL_INDEX_SHIFT 0x0D12 +#define GL_INDEX_OFFSET 0x0D13 +#define GL_RED_SCALE 0x0D14 +#define GL_RED_BIAS 0x0D15 +#define GL_ZOOM_X 0x0D16 +#define GL_ZOOM_Y 0x0D17 +#define GL_GREEN_SCALE 0x0D18 +#define GL_GREEN_BIAS 0x0D19 +#define GL_BLUE_SCALE 0x0D1A +#define GL_BLUE_BIAS 0x0D1B +#define GL_ALPHA_SCALE 0x0D1C +#define GL_ALPHA_BIAS 0x0D1D +#define GL_DEPTH_SCALE 0x0D1E +#define GL_DEPTH_BIAS 0x0D1F +#define GL_MAX_EVAL_ORDER 0x0D30 +#define GL_MAX_LIGHTS 0x0D31 +#define GL_MAX_CLIP_PLANES 0x0D32 +#define GL_MAX_TEXTURE_SIZE 0x0D33 +#define GL_MAX_PIXEL_MAP_TABLE 0x0D34 +#define GL_MAX_ATTRIB_STACK_DEPTH 0x0D35 +#define GL_MAX_MODELVIEW_STACK_DEPTH 0x0D36 +#define GL_MAX_NAME_STACK_DEPTH 0x0D37 +#define GL_MAX_PROJECTION_STACK_DEPTH 0x0D38 +#define GL_MAX_TEXTURE_STACK_DEPTH 0x0D39 +#define GL_MAX_VIEWPORT_DIMS 0x0D3A +#define GL_MAX_CLIENT_ATTRIB_STACK_DEPTH 0x0D3B +#define GL_SUBPIXEL_BITS 0x0D50 +#define GL_INDEX_BITS 0x0D51 +#define GL_RED_BITS 0x0D52 +#define GL_GREEN_BITS 0x0D53 +#define GL_BLUE_BITS 0x0D54 +#define GL_ALPHA_BITS 0x0D55 +#define GL_DEPTH_BITS 0x0D56 +#define GL_STENCIL_BITS 0x0D57 +#define GL_ACCUM_RED_BITS 0x0D58 +#define GL_ACCUM_GREEN_BITS 0x0D59 +#define GL_ACCUM_BLUE_BITS 0x0D5A +#define GL_ACCUM_ALPHA_BITS 0x0D5B +#define GL_NAME_STACK_DEPTH 0x0D70 +#define GL_AUTO_NORMAL 0x0D80 +#define GL_MAP1_COLOR_4 0x0D90 +#define GL_MAP1_INDEX 0x0D91 +#define GL_MAP1_NORMAL 0x0D92 +#define GL_MAP1_TEXTURE_COORD_1 0x0D93 +#define GL_MAP1_TEXTURE_COORD_2 0x0D94 +#define GL_MAP1_TEXTURE_COORD_3 0x0D95 +#define GL_MAP1_TEXTURE_COORD_4 0x0D96 +#define GL_MAP1_VERTEX_3 0x0D97 +#define GL_MAP1_VERTEX_4 0x0D98 +#define GL_MAP2_COLOR_4 0x0DB0 +#define GL_MAP2_INDEX 0x0DB1 +#define GL_MAP2_NORMAL 0x0DB2 +#define GL_MAP2_TEXTURE_COORD_1 0x0DB3 +#define GL_MAP2_TEXTURE_COORD_2 0x0DB4 +#define GL_MAP2_TEXTURE_COORD_3 0x0DB5 +#define GL_MAP2_TEXTURE_COORD_4 0x0DB6 +#define GL_MAP2_VERTEX_3 0x0DB7 +#define GL_MAP2_VERTEX_4 0x0DB8 +#define GL_MAP1_GRID_DOMAIN 0x0DD0 +#define GL_MAP1_GRID_SEGMENTS 0x0DD1 +#define GL_MAP2_GRID_DOMAIN 0x0DD2 +#define GL_MAP2_GRID_SEGMENTS 0x0DD3 +#define GL_TEXTURE_1D 0x0DE0 +#define GL_TEXTURE_2D 0x0DE1 +#define GL_FEEDBACK_BUFFER_POINTER 0x0DF0 +#define GL_FEEDBACK_BUFFER_SIZE 0x0DF1 +#define GL_FEEDBACK_BUFFER_TYPE 0x0DF2 +#define GL_SELECTION_BUFFER_POINTER 0x0DF3 +#define GL_SELECTION_BUFFER_SIZE 0x0DF4 +#define GL_TEXTURE_WIDTH 0x1000 +#define GL_TEXTURE_HEIGHT 0x1001 +#define GL_TEXTURE_INTERNAL_FORMAT 0x1003 +#define GL_TEXTURE_BORDER_COLOR 0x1004 +#define GL_TEXTURE_BORDER 0x1005 +#define GL_DONT_CARE 0x1100 +#define GL_FASTEST 0x1101 +#define GL_NICEST 0x1102 +#define GL_LIGHT0 0x4000 +#define GL_LIGHT1 0x4001 +#define GL_LIGHT2 0x4002 +#define GL_LIGHT3 0x4003 +#define GL_LIGHT4 0x4004 +#define GL_LIGHT5 0x4005 +#define GL_LIGHT6 0x4006 +#define GL_LIGHT7 0x4007 +#define GL_AMBIENT 0x1200 +#define GL_DIFFUSE 0x1201 +#define GL_SPECULAR 0x1202 +#define GL_POSITION 0x1203 +#define GL_SPOT_DIRECTION 0x1204 +#define GL_SPOT_EXPONENT 0x1205 +#define GL_SPOT_CUTOFF 0x1206 +#define GL_CONSTANT_ATTENUATION 0x1207 +#define GL_LINEAR_ATTENUATION 0x1208 +#define GL_QUADRATIC_ATTENUATION 0x1209 +#define GL_COMPILE 0x1300 +#define GL_COMPILE_AND_EXECUTE 0x1301 +#define GL_CLEAR 0x1500 +#define GL_AND 0x1501 +#define GL_AND_REVERSE 0x1502 +#define GL_COPY 0x1503 +#define GL_AND_INVERTED 0x1504 +#define GL_NOOP 0x1505 +#define GL_XOR 0x1506 +#define GL_OR 0x1507 +#define GL_NOR 0x1508 +#define GL_EQUIV 0x1509 +#define GL_INVERT 0x150A +#define GL_OR_REVERSE 0x150B +#define GL_COPY_INVERTED 0x150C +#define GL_OR_INVERTED 0x150D +#define GL_NAND 0x150E +#define GL_SET 0x150F +#define GL_EMISSION 0x1600 +#define GL_SHININESS 0x1601 +#define GL_AMBIENT_AND_DIFFUSE 0x1602 +#define GL_COLOR_INDEXES 0x1603 +#define GL_MODELVIEW 0x1700 +#define GL_PROJECTION 0x1701 +#define GL_TEXTURE 0x1702 +#define GL_COLOR 0x1800 +#define GL_DEPTH 0x1801 +#define GL_STENCIL 0x1802 +#define GL_COLOR_INDEX 0x1900 +#define GL_STENCIL_INDEX 0x1901 +#define GL_DEPTH_COMPONENT 0x1902 +#define GL_RED 0x1903 +#define GL_GREEN 0x1904 +#define GL_BLUE 0x1905 +#define GL_ALPHA 0x1906 +#define GL_RGB 0x1907 +#define GL_RGBA 0x1908 +#define GL_LUMINANCE 0x1909 +#define GL_LUMINANCE_ALPHA 0x190A +#define GL_BITMAP 0x1A00 +#define GL_POINT 0x1B00 +#define GL_LINE 0x1B01 +#define GL_FILL 0x1B02 +#define GL_RENDER 0x1C00 +#define GL_FEEDBACK 0x1C01 +#define GL_SELECT 0x1C02 +#define GL_FLAT 0x1D00 +#define GL_SMOOTH 0x1D01 +#define GL_KEEP 0x1E00 +#define GL_REPLACE 0x1E01 +#define GL_INCR 0x1E02 +#define GL_DECR 0x1E03 +#define GL_VENDOR 0x1F00 +#define GL_RENDERER 0x1F01 +#define GL_VERSION 0x1F02 +#define GL_EXTENSIONS 0x1F03 +#define GL_S 0x2000 +#define GL_T 0x2001 +#define GL_R 0x2002 +#define GL_Q 0x2003 +#define GL_MODULATE 0x2100 +#define GL_DECAL 0x2101 +#define GL_TEXTURE_ENV_MODE 0x2200 +#define GL_TEXTURE_ENV_COLOR 0x2201 +#define GL_TEXTURE_ENV 0x2300 +#define GL_EYE_LINEAR 0x2400 +#define GL_OBJECT_LINEAR 0x2401 +#define GL_SPHERE_MAP 0x2402 +#define GL_TEXTURE_GEN_MODE 0x2500 +#define GL_OBJECT_PLANE 0x2501 +#define GL_EYE_PLANE 0x2502 +#define GL_NEAREST 0x2600 +#define GL_LINEAR 0x2601 +#define GL_NEAREST_MIPMAP_NEAREST 0x2700 +#define GL_LINEAR_MIPMAP_NEAREST 0x2701 +#define GL_NEAREST_MIPMAP_LINEAR 0x2702 +#define GL_LINEAR_MIPMAP_LINEAR 0x2703 +#define GL_TEXTURE_MAG_FILTER 0x2800 +#define GL_TEXTURE_MIN_FILTER 0x2801 +#define GL_TEXTURE_WRAP_S 0x2802 +#define GL_TEXTURE_WRAP_T 0x2803 +#define GL_CLAMP 0x2900 +#define GL_REPEAT 0x2901 +#define GL_CLIENT_PIXEL_STORE_BIT 0x00000001 +#define GL_CLIENT_VERTEX_ARRAY_BIT 0x00000002 +#define GL_CLIENT_ALL_ATTRIB_BITS 0xffffffff +#define GL_POLYGON_OFFSET_FACTOR 0x8038 +#define GL_POLYGON_OFFSET_UNITS 0x2A00 +#define GL_POLYGON_OFFSET_POINT 0x2A01 +#define GL_POLYGON_OFFSET_LINE 0x2A02 +#define GL_POLYGON_OFFSET_FILL 0x8037 +#define GL_ALPHA4 0x803B +#define GL_ALPHA8 0x803C +#define GL_ALPHA12 0x803D +#define GL_ALPHA16 0x803E +#define GL_LUMINANCE4 0x803F +#define GL_LUMINANCE8 0x8040 +#define GL_LUMINANCE12 0x8041 +#define GL_LUMINANCE16 0x8042 +#define GL_LUMINANCE4_ALPHA4 0x8043 +#define GL_LUMINANCE6_ALPHA2 0x8044 +#define GL_LUMINANCE8_ALPHA8 0x8045 +#define GL_LUMINANCE12_ALPHA4 0x8046 +#define GL_LUMINANCE12_ALPHA12 0x8047 +#define GL_LUMINANCE16_ALPHA16 0x8048 +#define GL_INTENSITY 0x8049 +#define GL_INTENSITY4 0x804A +#define GL_INTENSITY8 0x804B +#define GL_INTENSITY12 0x804C +#define GL_INTENSITY16 0x804D +#define GL_R3_G3_B2 0x2A10 +#define GL_RGB4 0x804F +#define GL_RGB5 0x8050 +#define GL_RGB8 0x8051 +#define GL_RGB10 0x8052 +#define GL_RGB12 0x8053 +#define GL_RGB16 0x8054 +#define GL_RGBA2 0x8055 +#define GL_RGBA4 0x8056 +#define GL_RGB5_A1 0x8057 +#define GL_RGBA8 0x8058 +#define GL_RGB10_A2 0x8059 +#define GL_RGBA12 0x805A +#define GL_RGBA16 0x805B +#define GL_TEXTURE_RED_SIZE 0x805C +#define GL_TEXTURE_GREEN_SIZE 0x805D +#define GL_TEXTURE_BLUE_SIZE 0x805E +#define GL_TEXTURE_ALPHA_SIZE 0x805F +#define GL_TEXTURE_LUMINANCE_SIZE 0x8060 +#define GL_TEXTURE_INTENSITY_SIZE 0x8061 +#define GL_PROXY_TEXTURE_1D 0x8063 +#define GL_PROXY_TEXTURE_2D 0x8064 +#define GL_TEXTURE_PRIORITY 0x8066 +#define GL_TEXTURE_RESIDENT 0x8067 +#define GL_TEXTURE_BINDING_1D 0x8068 +#define GL_TEXTURE_BINDING_2D 0x8069 +#define GL_VERTEX_ARRAY 0x8074 +#define GL_NORMAL_ARRAY 0x8075 +#define GL_COLOR_ARRAY 0x8076 +#define GL_INDEX_ARRAY 0x8077 +#define GL_TEXTURE_COORD_ARRAY 0x8078 +#define GL_EDGE_FLAG_ARRAY 0x8079 +#define GL_VERTEX_ARRAY_SIZE 0x807A +#define GL_VERTEX_ARRAY_TYPE 0x807B +#define GL_VERTEX_ARRAY_STRIDE 0x807C +#define GL_NORMAL_ARRAY_TYPE 0x807E +#define GL_NORMAL_ARRAY_STRIDE 0x807F +#define GL_COLOR_ARRAY_SIZE 0x8081 +#define GL_COLOR_ARRAY_TYPE 0x8082 +#define GL_COLOR_ARRAY_STRIDE 0x8083 +#define GL_INDEX_ARRAY_TYPE 0x8085 +#define GL_INDEX_ARRAY_STRIDE 0x8086 +#define GL_TEXTURE_COORD_ARRAY_SIZE 0x8088 +#define GL_TEXTURE_COORD_ARRAY_TYPE 0x8089 +#define GL_TEXTURE_COORD_ARRAY_STRIDE 0x808A +#define GL_EDGE_FLAG_ARRAY_STRIDE 0x808C +#define GL_VERTEX_ARRAY_POINTER 0x808E +#define GL_NORMAL_ARRAY_POINTER 0x808F +#define GL_COLOR_ARRAY_POINTER 0x8090 +#define GL_INDEX_ARRAY_POINTER 0x8091 +#define GL_TEXTURE_COORD_ARRAY_POINTER 0x8092 +#define GL_EDGE_FLAG_ARRAY_POINTER 0x8093 +#define GL_V2F 0x2A20 +#define GL_V3F 0x2A21 +#define GL_C4UB_V2F 0x2A22 +#define GL_C4UB_V3F 0x2A23 +#define GL_C3F_V3F 0x2A24 +#define GL_N3F_V3F 0x2A25 +#define GL_C4F_N3F_V3F 0x2A26 +#define GL_T2F_V3F 0x2A27 +#define GL_T4F_V4F 0x2A28 +#define GL_T2F_C4UB_V3F 0x2A29 +#define GL_T2F_C3F_V3F 0x2A2A +#define GL_T2F_N3F_V3F 0x2A2B +#define GL_T2F_C4F_N3F_V3F 0x2A2C +#define GL_T4F_C4F_N3F_V4F 0x2A2D +#define GL_LOGIC_OP GL_INDEX_LOGIC_OP +#define GL_TEXTURE_COMPONENTS GL_TEXTURE_INTERNAL_FORMAT +#define GL_COLOR_INDEX1_EXT 0x80E2 +#define GL_COLOR_INDEX2_EXT 0x80E3 +#define GL_COLOR_INDEX4_EXT 0x80E4 +#define GL_COLOR_INDEX8_EXT 0x80E5 +#define GL_COLOR_INDEX12_EXT 0x80E6 +#define GL_COLOR_INDEX16_EXT 0x80E7 + +GLAPI void GLAPIENTRY glAccum (GLenum op, GLfloat value); +GLAPI void GLAPIENTRY glAlphaFunc (GLenum func, GLclampf ref); +GLAPI GLboolean GLAPIENTRY glAreTexturesResident (GLsizei n, const GLuint *textures, GLboolean *residences); +GLAPI void GLAPIENTRY glArrayElement (GLint i); +GLAPI void GLAPIENTRY glBegin (GLenum mode); +GLAPI void GLAPIENTRY glBindTexture (GLenum target, GLuint texture); +GLAPI void GLAPIENTRY glBitmap (GLsizei width, GLsizei height, GLfloat xorig, GLfloat yorig, GLfloat xmove, GLfloat ymove, const GLubyte *bitmap); +GLAPI void GLAPIENTRY glBlendFunc (GLenum sfactor, GLenum dfactor); +GLAPI void GLAPIENTRY glCallList (GLuint list); +GLAPI void GLAPIENTRY glCallLists (GLsizei n, GLenum type, const GLvoid *lists); +GLAPI void GLAPIENTRY glClear (GLbitfield mask); +GLAPI void GLAPIENTRY glClearAccum (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI void GLAPIENTRY glClearColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +GLAPI void GLAPIENTRY glClearDepth (GLclampd depth); +GLAPI void GLAPIENTRY glClearIndex (GLfloat c); +GLAPI void GLAPIENTRY glClearStencil (GLint s); +GLAPI void GLAPIENTRY glClipPlane (GLenum plane, const GLdouble *equation); +GLAPI void GLAPIENTRY glColor3b (GLbyte red, GLbyte green, GLbyte blue); +GLAPI void GLAPIENTRY glColor3bv (const GLbyte *v); +GLAPI void GLAPIENTRY glColor3d (GLdouble red, GLdouble green, GLdouble blue); +GLAPI void GLAPIENTRY glColor3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glColor3f (GLfloat red, GLfloat green, GLfloat blue); +GLAPI void GLAPIENTRY glColor3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glColor3i (GLint red, GLint green, GLint blue); +GLAPI void GLAPIENTRY glColor3iv (const GLint *v); +GLAPI void GLAPIENTRY glColor3s (GLshort red, GLshort green, GLshort blue); +GLAPI void GLAPIENTRY glColor3sv (const GLshort *v); +GLAPI void GLAPIENTRY glColor3ub (GLubyte red, GLubyte green, GLubyte blue); +GLAPI void GLAPIENTRY glColor3ubv (const GLubyte *v); +GLAPI void GLAPIENTRY glColor3ui (GLuint red, GLuint green, GLuint blue); +GLAPI void GLAPIENTRY glColor3uiv (const GLuint *v); +GLAPI void GLAPIENTRY glColor3us (GLushort red, GLushort green, GLushort blue); +GLAPI void GLAPIENTRY glColor3usv (const GLushort *v); +GLAPI void GLAPIENTRY glColor4b (GLbyte red, GLbyte green, GLbyte blue, GLbyte alpha); +GLAPI void GLAPIENTRY glColor4bv (const GLbyte *v); +GLAPI void GLAPIENTRY glColor4d (GLdouble red, GLdouble green, GLdouble blue, GLdouble alpha); +GLAPI void GLAPIENTRY glColor4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glColor4f (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI void GLAPIENTRY glColor4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glColor4i (GLint red, GLint green, GLint blue, GLint alpha); +GLAPI void GLAPIENTRY glColor4iv (const GLint *v); +GLAPI void GLAPIENTRY glColor4s (GLshort red, GLshort green, GLshort blue, GLshort alpha); +GLAPI void GLAPIENTRY glColor4sv (const GLshort *v); +GLAPI void GLAPIENTRY glColor4ub (GLubyte red, GLubyte green, GLubyte blue, GLubyte alpha); +GLAPI void GLAPIENTRY glColor4ubv (const GLubyte *v); +GLAPI void GLAPIENTRY glColor4ui (GLuint red, GLuint green, GLuint blue, GLuint alpha); +GLAPI void GLAPIENTRY glColor4uiv (const GLuint *v); +GLAPI void GLAPIENTRY glColor4us (GLushort red, GLushort green, GLushort blue, GLushort alpha); +GLAPI void GLAPIENTRY glColor4usv (const GLushort *v); +GLAPI void GLAPIENTRY glColorMask (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); +GLAPI void GLAPIENTRY glColorMaterial (GLenum face, GLenum mode); +GLAPI void GLAPIENTRY glColorPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glCopyPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum type); +GLAPI void GLAPIENTRY glCopyTexImage1D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLint border); +GLAPI void GLAPIENTRY glCopyTexImage2D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +GLAPI void GLAPIENTRY glCopyTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +GLAPI void GLAPIENTRY glCopyTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void GLAPIENTRY glCullFace (GLenum mode); +GLAPI void GLAPIENTRY glDeleteLists (GLuint list, GLsizei range); +GLAPI void GLAPIENTRY glDeleteTextures (GLsizei n, const GLuint *textures); +GLAPI void GLAPIENTRY glDepthFunc (GLenum func); +GLAPI void GLAPIENTRY glDepthMask (GLboolean flag); +GLAPI void GLAPIENTRY glDepthRange (GLclampd zNear, GLclampd zFar); +GLAPI void GLAPIENTRY glDisable (GLenum cap); +GLAPI void GLAPIENTRY glDisableClientState (GLenum array); +GLAPI void GLAPIENTRY glDrawArrays (GLenum mode, GLint first, GLsizei count); +GLAPI void GLAPIENTRY glDrawBuffer (GLenum mode); +GLAPI void GLAPIENTRY glDrawElements (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices); +GLAPI void GLAPIENTRY glDrawPixels (GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glEdgeFlag (GLboolean flag); +GLAPI void GLAPIENTRY glEdgeFlagPointer (GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glEdgeFlagv (const GLboolean *flag); +GLAPI void GLAPIENTRY glEnable (GLenum cap); +GLAPI void GLAPIENTRY glEnableClientState (GLenum array); +GLAPI void GLAPIENTRY glEnd (void); +GLAPI void GLAPIENTRY glEndList (void); +GLAPI void GLAPIENTRY glEvalCoord1d (GLdouble u); +GLAPI void GLAPIENTRY glEvalCoord1dv (const GLdouble *u); +GLAPI void GLAPIENTRY glEvalCoord1f (GLfloat u); +GLAPI void GLAPIENTRY glEvalCoord1fv (const GLfloat *u); +GLAPI void GLAPIENTRY glEvalCoord2d (GLdouble u, GLdouble v); +GLAPI void GLAPIENTRY glEvalCoord2dv (const GLdouble *u); +GLAPI void GLAPIENTRY glEvalCoord2f (GLfloat u, GLfloat v); +GLAPI void GLAPIENTRY glEvalCoord2fv (const GLfloat *u); +GLAPI void GLAPIENTRY glEvalMesh1 (GLenum mode, GLint i1, GLint i2); +GLAPI void GLAPIENTRY glEvalMesh2 (GLenum mode, GLint i1, GLint i2, GLint j1, GLint j2); +GLAPI void GLAPIENTRY glEvalPoint1 (GLint i); +GLAPI void GLAPIENTRY glEvalPoint2 (GLint i, GLint j); +GLAPI void GLAPIENTRY glFeedbackBuffer (GLsizei size, GLenum type, GLfloat *buffer); +GLAPI void GLAPIENTRY glFinish (void); +GLAPI void GLAPIENTRY glFlush (void); +GLAPI void GLAPIENTRY glFogf (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glFogfv (GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glFogi (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glFogiv (GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glFrontFace (GLenum mode); +GLAPI void GLAPIENTRY glFrustum (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI GLuint GLAPIENTRY glGenLists (GLsizei range); +GLAPI void GLAPIENTRY glGenTextures (GLsizei n, GLuint *textures); +GLAPI void GLAPIENTRY glGetBooleanv (GLenum pname, GLboolean *params); +GLAPI void GLAPIENTRY glGetClipPlane (GLenum plane, GLdouble *equation); +GLAPI void GLAPIENTRY glGetDoublev (GLenum pname, GLdouble *params); +GLAPI GLenum GLAPIENTRY glGetError (void); +GLAPI void GLAPIENTRY glGetFloatv (GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetIntegerv (GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetLightfv (GLenum light, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetLightiv (GLenum light, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetMapdv (GLenum target, GLenum query, GLdouble *v); +GLAPI void GLAPIENTRY glGetMapfv (GLenum target, GLenum query, GLfloat *v); +GLAPI void GLAPIENTRY glGetMapiv (GLenum target, GLenum query, GLint *v); +GLAPI void GLAPIENTRY glGetMaterialfv (GLenum face, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetMaterialiv (GLenum face, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetPixelMapfv (GLenum map, GLfloat *values); +GLAPI void GLAPIENTRY glGetPixelMapuiv (GLenum map, GLuint *values); +GLAPI void GLAPIENTRY glGetPixelMapusv (GLenum map, GLushort *values); +GLAPI void GLAPIENTRY glGetPointerv (GLenum pname, GLvoid* *params); +GLAPI void GLAPIENTRY glGetPolygonStipple (GLubyte *mask); +GLAPI const GLubyte * GLAPIENTRY glGetString (GLenum name); +GLAPI void GLAPIENTRY glGetTexEnvfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexEnviv (GLenum target, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetTexGendv (GLenum coord, GLenum pname, GLdouble *params); +GLAPI void GLAPIENTRY glGetTexGenfv (GLenum coord, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexGeniv (GLenum coord, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetTexImage (GLenum target, GLint level, GLenum format, GLenum type, GLvoid *pixels); +GLAPI void GLAPIENTRY glGetTexLevelParameterfv (GLenum target, GLint level, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexLevelParameteriv (GLenum target, GLint level, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetTexParameterfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glHint (GLenum target, GLenum mode); +GLAPI void GLAPIENTRY glIndexMask (GLuint mask); +GLAPI void GLAPIENTRY glIndexPointer (GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glIndexd (GLdouble c); +GLAPI void GLAPIENTRY glIndexdv (const GLdouble *c); +GLAPI void GLAPIENTRY glIndexf (GLfloat c); +GLAPI void GLAPIENTRY glIndexfv (const GLfloat *c); +GLAPI void GLAPIENTRY glIndexi (GLint c); +GLAPI void GLAPIENTRY glIndexiv (const GLint *c); +GLAPI void GLAPIENTRY glIndexs (GLshort c); +GLAPI void GLAPIENTRY glIndexsv (const GLshort *c); +GLAPI void GLAPIENTRY glIndexub (GLubyte c); +GLAPI void GLAPIENTRY glIndexubv (const GLubyte *c); +GLAPI void GLAPIENTRY glInitNames (void); +GLAPI void GLAPIENTRY glInterleavedArrays (GLenum format, GLsizei stride, const GLvoid *pointer); +GLAPI GLboolean GLAPIENTRY glIsEnabled (GLenum cap); +GLAPI GLboolean GLAPIENTRY glIsList (GLuint list); +GLAPI GLboolean GLAPIENTRY glIsTexture (GLuint texture); +GLAPI void GLAPIENTRY glLightModelf (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glLightModelfv (GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glLightModeli (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glLightModeliv (GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glLightf (GLenum light, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glLightfv (GLenum light, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glLighti (GLenum light, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glLightiv (GLenum light, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glLineStipple (GLint factor, GLushort pattern); +GLAPI void GLAPIENTRY glLineWidth (GLfloat width); +GLAPI void GLAPIENTRY glListBase (GLuint base); +GLAPI void GLAPIENTRY glLoadIdentity (void); +GLAPI void GLAPIENTRY glLoadMatrixd (const GLdouble *m); +GLAPI void GLAPIENTRY glLoadMatrixf (const GLfloat *m); +GLAPI void GLAPIENTRY glLoadName (GLuint name); +GLAPI void GLAPIENTRY glLogicOp (GLenum opcode); +GLAPI void GLAPIENTRY glMap1d (GLenum target, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); +GLAPI void GLAPIENTRY glMap1f (GLenum target, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); +GLAPI void GLAPIENTRY glMap2d (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble *points); +GLAPI void GLAPIENTRY glMap2f (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); +GLAPI void GLAPIENTRY glMapGrid1d (GLint un, GLdouble u1, GLdouble u2); +GLAPI void GLAPIENTRY glMapGrid1f (GLint un, GLfloat u1, GLfloat u2); +GLAPI void GLAPIENTRY glMapGrid2d (GLint un, GLdouble u1, GLdouble u2, GLint vn, GLdouble v1, GLdouble v2); +GLAPI void GLAPIENTRY glMapGrid2f (GLint un, GLfloat u1, GLfloat u2, GLint vn, GLfloat v1, GLfloat v2); +GLAPI void GLAPIENTRY glMaterialf (GLenum face, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glMaterialfv (GLenum face, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glMateriali (GLenum face, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glMaterialiv (GLenum face, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glMatrixMode (GLenum mode); +GLAPI void GLAPIENTRY glMultMatrixd (const GLdouble *m); +GLAPI void GLAPIENTRY glMultMatrixf (const GLfloat *m); +GLAPI void GLAPIENTRY glNewList (GLuint list, GLenum mode); +GLAPI void GLAPIENTRY glNormal3b (GLbyte nx, GLbyte ny, GLbyte nz); +GLAPI void GLAPIENTRY glNormal3bv (const GLbyte *v); +GLAPI void GLAPIENTRY glNormal3d (GLdouble nx, GLdouble ny, GLdouble nz); +GLAPI void GLAPIENTRY glNormal3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glNormal3f (GLfloat nx, GLfloat ny, GLfloat nz); +GLAPI void GLAPIENTRY glNormal3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glNormal3i (GLint nx, GLint ny, GLint nz); +GLAPI void GLAPIENTRY glNormal3iv (const GLint *v); +GLAPI void GLAPIENTRY glNormal3s (GLshort nx, GLshort ny, GLshort nz); +GLAPI void GLAPIENTRY glNormal3sv (const GLshort *v); +GLAPI void GLAPIENTRY glNormalPointer (GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glOrtho (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI void GLAPIENTRY glPassThrough (GLfloat token); +GLAPI void GLAPIENTRY glPixelMapfv (GLenum map, GLsizei mapsize, const GLfloat *values); +GLAPI void GLAPIENTRY glPixelMapuiv (GLenum map, GLsizei mapsize, const GLuint *values); +GLAPI void GLAPIENTRY glPixelMapusv (GLenum map, GLsizei mapsize, const GLushort *values); +GLAPI void GLAPIENTRY glPixelStoref (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glPixelStorei (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glPixelTransferf (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glPixelTransferi (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glPixelZoom (GLfloat xfactor, GLfloat yfactor); +GLAPI void GLAPIENTRY glPointSize (GLfloat size); +GLAPI void GLAPIENTRY glPolygonMode (GLenum face, GLenum mode); +GLAPI void GLAPIENTRY glPolygonOffset (GLfloat factor, GLfloat units); +GLAPI void GLAPIENTRY glPolygonStipple (const GLubyte *mask); +GLAPI void GLAPIENTRY glPopAttrib (void); +GLAPI void GLAPIENTRY glPopClientAttrib (void); +GLAPI void GLAPIENTRY glPopMatrix (void); +GLAPI void GLAPIENTRY glPopName (void); +GLAPI void GLAPIENTRY glPrioritizeTextures (GLsizei n, const GLuint *textures, const GLclampf *priorities); +GLAPI void GLAPIENTRY glPushAttrib (GLbitfield mask); +GLAPI void GLAPIENTRY glPushClientAttrib (GLbitfield mask); +GLAPI void GLAPIENTRY glPushMatrix (void); +GLAPI void GLAPIENTRY glPushName (GLuint name); +GLAPI void GLAPIENTRY glRasterPos2d (GLdouble x, GLdouble y); +GLAPI void GLAPIENTRY glRasterPos2dv (const GLdouble *v); +GLAPI void GLAPIENTRY glRasterPos2f (GLfloat x, GLfloat y); +GLAPI void GLAPIENTRY glRasterPos2fv (const GLfloat *v); +GLAPI void GLAPIENTRY glRasterPos2i (GLint x, GLint y); +GLAPI void GLAPIENTRY glRasterPos2iv (const GLint *v); +GLAPI void GLAPIENTRY glRasterPos2s (GLshort x, GLshort y); +GLAPI void GLAPIENTRY glRasterPos2sv (const GLshort *v); +GLAPI void GLAPIENTRY glRasterPos3d (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glRasterPos3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glRasterPos3f (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glRasterPos3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glRasterPos3i (GLint x, GLint y, GLint z); +GLAPI void GLAPIENTRY glRasterPos3iv (const GLint *v); +GLAPI void GLAPIENTRY glRasterPos3s (GLshort x, GLshort y, GLshort z); +GLAPI void GLAPIENTRY glRasterPos3sv (const GLshort *v); +GLAPI void GLAPIENTRY glRasterPos4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void GLAPIENTRY glRasterPos4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glRasterPos4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void GLAPIENTRY glRasterPos4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glRasterPos4i (GLint x, GLint y, GLint z, GLint w); +GLAPI void GLAPIENTRY glRasterPos4iv (const GLint *v); +GLAPI void GLAPIENTRY glRasterPos4s (GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void GLAPIENTRY glRasterPos4sv (const GLshort *v); +GLAPI void GLAPIENTRY glReadBuffer (GLenum mode); +GLAPI void GLAPIENTRY glReadPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid *pixels); +GLAPI void GLAPIENTRY glRectd (GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2); +GLAPI void GLAPIENTRY glRectdv (const GLdouble *v1, const GLdouble *v2); +GLAPI void GLAPIENTRY glRectf (GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2); +GLAPI void GLAPIENTRY glRectfv (const GLfloat *v1, const GLfloat *v2); +GLAPI void GLAPIENTRY glRecti (GLint x1, GLint y1, GLint x2, GLint y2); +GLAPI void GLAPIENTRY glRectiv (const GLint *v1, const GLint *v2); +GLAPI void GLAPIENTRY glRects (GLshort x1, GLshort y1, GLshort x2, GLshort y2); +GLAPI void GLAPIENTRY glRectsv (const GLshort *v1, const GLshort *v2); +GLAPI GLint GLAPIENTRY glRenderMode (GLenum mode); +GLAPI void GLAPIENTRY glRotated (GLdouble angle, GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glRotatef (GLfloat angle, GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glScaled (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glScalef (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glScissor (GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void GLAPIENTRY glSelectBuffer (GLsizei size, GLuint *buffer); +GLAPI void GLAPIENTRY glShadeModel (GLenum mode); +GLAPI void GLAPIENTRY glStencilFunc (GLenum func, GLint ref, GLuint mask); +GLAPI void GLAPIENTRY glStencilMask (GLuint mask); +GLAPI void GLAPIENTRY glStencilOp (GLenum fail, GLenum zfail, GLenum zpass); +GLAPI void GLAPIENTRY glTexCoord1d (GLdouble s); +GLAPI void GLAPIENTRY glTexCoord1dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord1f (GLfloat s); +GLAPI void GLAPIENTRY glTexCoord1fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord1i (GLint s); +GLAPI void GLAPIENTRY glTexCoord1iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord1s (GLshort s); +GLAPI void GLAPIENTRY glTexCoord1sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoord2d (GLdouble s, GLdouble t); +GLAPI void GLAPIENTRY glTexCoord2dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord2f (GLfloat s, GLfloat t); +GLAPI void GLAPIENTRY glTexCoord2fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord2i (GLint s, GLint t); +GLAPI void GLAPIENTRY glTexCoord2iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord2s (GLshort s, GLshort t); +GLAPI void GLAPIENTRY glTexCoord2sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoord3d (GLdouble s, GLdouble t, GLdouble r); +GLAPI void GLAPIENTRY glTexCoord3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord3f (GLfloat s, GLfloat t, GLfloat r); +GLAPI void GLAPIENTRY glTexCoord3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord3i (GLint s, GLint t, GLint r); +GLAPI void GLAPIENTRY glTexCoord3iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord3s (GLshort s, GLshort t, GLshort r); +GLAPI void GLAPIENTRY glTexCoord3sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoord4d (GLdouble s, GLdouble t, GLdouble r, GLdouble q); +GLAPI void GLAPIENTRY glTexCoord4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord4f (GLfloat s, GLfloat t, GLfloat r, GLfloat q); +GLAPI void GLAPIENTRY glTexCoord4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord4i (GLint s, GLint t, GLint r, GLint q); +GLAPI void GLAPIENTRY glTexCoord4iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord4s (GLshort s, GLshort t, GLshort r, GLshort q); +GLAPI void GLAPIENTRY glTexCoord4sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoordPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glTexEnvf (GLenum target, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glTexEnvfv (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glTexEnvi (GLenum target, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glTexEnviv (GLenum target, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glTexGend (GLenum coord, GLenum pname, GLdouble param); +GLAPI void GLAPIENTRY glTexGendv (GLenum coord, GLenum pname, const GLdouble *params); +GLAPI void GLAPIENTRY glTexGenf (GLenum coord, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glTexGenfv (GLenum coord, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glTexGeni (GLenum coord, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glTexGeniv (GLenum coord, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glTexImage1D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTexImage2D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTexParameterf (GLenum target, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glTexParameterfv (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glTexParameteri (GLenum target, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glTexParameteriv (GLenum target, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTranslated (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glTranslatef (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glVertex2d (GLdouble x, GLdouble y); +GLAPI void GLAPIENTRY glVertex2dv (const GLdouble *v); +GLAPI void GLAPIENTRY glVertex2f (GLfloat x, GLfloat y); +GLAPI void GLAPIENTRY glVertex2fv (const GLfloat *v); +GLAPI void GLAPIENTRY glVertex2i (GLint x, GLint y); +GLAPI void GLAPIENTRY glVertex2iv (const GLint *v); +GLAPI void GLAPIENTRY glVertex2s (GLshort x, GLshort y); +GLAPI void GLAPIENTRY glVertex2sv (const GLshort *v); +GLAPI void GLAPIENTRY glVertex3d (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glVertex3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glVertex3f (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glVertex3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glVertex3i (GLint x, GLint y, GLint z); +GLAPI void GLAPIENTRY glVertex3iv (const GLint *v); +GLAPI void GLAPIENTRY glVertex3s (GLshort x, GLshort y, GLshort z); +GLAPI void GLAPIENTRY glVertex3sv (const GLshort *v); +GLAPI void GLAPIENTRY glVertex4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void GLAPIENTRY glVertex4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glVertex4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void GLAPIENTRY glVertex4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glVertex4i (GLint x, GLint y, GLint z, GLint w); +GLAPI void GLAPIENTRY glVertex4iv (const GLint *v); +GLAPI void GLAPIENTRY glVertex4s (GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void GLAPIENTRY glVertex4sv (const GLshort *v); +GLAPI void GLAPIENTRY glVertexPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glViewport (GLint x, GLint y, GLsizei width, GLsizei height); + +#define GLEW_VERSION_1_1 GLEW_GET_VAR(__GLEW_VERSION_1_1) + +#endif /* GL_VERSION_1_1 */ + +/* ---------------------------------- GLU ---------------------------------- */ + +/* this is where we can safely include GLU */ +#if defined(__APPLE__) && defined(__MACH__) +#include +#else +#include +#endif + diff --git a/Externals/GLew/auto/src/glew_init_gl.c b/Externals/GLew/auto/src/glew_init_gl.c new file mode 100644 index 0000000000..ff7d5a8efe --- /dev/null +++ b/Externals/GLew/auto/src/glew_init_gl.c @@ -0,0 +1,70 @@ +/* ------------------------------------------------------------------------- */ + +/* + * Search for name in the extensions string. Use of strstr() + * is not sufficient because extension names can be prefixes of + * other extension names. Could use strtok() but the constant + * string returned by glGetString might be in read-only memory. + */ +GLboolean glewGetExtension (const char* name) +{ + GLubyte* p; + GLubyte* end; + GLuint len = _glewStrLen((const GLubyte*)name); + p = (GLubyte*)glGetString(GL_EXTENSIONS); + if (0 == p) return GL_FALSE; + end = p + _glewStrLen(p); + while (p < end) + { + GLuint n = _glewStrCLen(p, ' '); + if (len == n && _glewStrSame((const GLubyte*)name, p, n)) return GL_TRUE; + p += n+1; + } + return GL_FALSE; +} + +/* ------------------------------------------------------------------------- */ + +#ifndef GLEW_MX +static +#endif +GLenum glewContextInit (GLEW_CONTEXT_ARG_DEF_LIST) +{ + const GLubyte* s; + GLuint dot; + GLint major, minor; + /* query opengl version */ + s = glGetString(GL_VERSION); + dot = _glewStrCLen(s, '.'); + if (dot == 0) + return GLEW_ERROR_NO_GL_VERSION; + + major = s[dot-1]-'0'; + minor = s[dot+1]-'0'; + + if (minor < 0 || minor > 9) + minor = 0; + if (major<0 || major>9) + return GLEW_ERROR_NO_GL_VERSION; + + + if (major == 1 && minor == 0) + { + return GLEW_ERROR_GL_VERSION_10_ONLY; + } + else + { + CONST_CAST(GLEW_VERSION_4_0) = ( major > 4 ) || ( major == 4 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_3) = GLEW_VERSION_4_0 == GL_TRUE || ( major == 3 && minor >= 3 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_2) = GLEW_VERSION_3_3 == GL_TRUE || ( major == 3 && minor >= 2 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_1) = GLEW_VERSION_3_2 == GL_TRUE || ( major == 3 && minor >= 1 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_0) = GLEW_VERSION_3_1 == GL_TRUE || ( major == 3 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_2_1) = GLEW_VERSION_3_0 == GL_TRUE || ( major == 2 && minor >= 1 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_2_0) = GLEW_VERSION_2_1 == GL_TRUE || ( major == 2 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_5) = GLEW_VERSION_2_0 == GL_TRUE || ( major == 1 && minor >= 5 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_4) = GLEW_VERSION_1_5 == GL_TRUE || ( major == 1 && minor >= 4 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_3) = GLEW_VERSION_1_4 == GL_TRUE || ( major == 1 && minor >= 3 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_2) = GLEW_VERSION_1_3 == GL_TRUE || ( major == 1 && minor >= 2 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_1) = GLEW_VERSION_1_2 == GL_TRUE || ( major == 1 && minor >= 1 ) ? GL_TRUE : GL_FALSE; + } + /* initialize extensions */ diff --git a/Externals/GLew/auto/src/glew_init_glx.c b/Externals/GLew/auto/src/glew_init_glx.c new file mode 100644 index 0000000000..c66e24c632 --- /dev/null +++ b/Externals/GLew/auto/src/glew_init_glx.c @@ -0,0 +1,52 @@ +/* ------------------------------------------------------------------------ */ + +GLboolean glxewGetExtension (const char* name) +{ + GLubyte* p; + GLubyte* end; + GLuint len; + + if (glXGetCurrentDisplay == NULL) return GL_FALSE; + len = _glewStrLen((const GLubyte*)name); + p = (GLubyte*)glXGetClientString(glXGetCurrentDisplay(), GLX_EXTENSIONS); + if (0 == p) return GL_FALSE; + end = p + _glewStrLen(p); + while (p < end) + { + GLuint n = _glewStrCLen(p, ' '); + if (len == n && _glewStrSame((const GLubyte*)name, p, n)) return GL_TRUE; + p += n+1; + } + return GL_FALSE; +} + +GLenum glxewContextInit (GLXEW_CONTEXT_ARG_DEF_LIST) +{ + int major, minor; + /* initialize core GLX 1.2 */ + if (_glewInit_GLX_VERSION_1_2(GLEW_CONTEXT_ARG_VAR_INIT)) return GLEW_ERROR_GLX_VERSION_11_ONLY; + /* initialize flags */ + CONST_CAST(GLXEW_VERSION_1_0) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_1) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_2) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_3) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_4) = GL_TRUE; + /* query GLX version */ + glXQueryVersion(glXGetCurrentDisplay(), &major, &minor); + if (major == 1 && minor <= 3) + { + switch (minor) + { + case 3: + CONST_CAST(GLXEW_VERSION_1_4) = GL_FALSE; + break; + case 2: + CONST_CAST(GLXEW_VERSION_1_4) = GL_FALSE; + CONST_CAST(GLXEW_VERSION_1_3) = GL_FALSE; + break; + default: + return GLEW_ERROR_GLX_VERSION_11_ONLY; + break; + } + } + /* initialize extensions */ diff --git a/Externals/GLew/auto/src/glew_init_tail.c b/Externals/GLew/auto/src/glew_init_tail.c new file mode 100644 index 0000000000..678b91cd8e --- /dev/null +++ b/Externals/GLew/auto/src/glew_init_tail.c @@ -0,0 +1,56 @@ +/* ------------------------------------------------------------------------ */ + +const GLubyte* glewGetErrorString (GLenum error) +{ + static const GLubyte* _glewErrorString[] = + { + (const GLubyte*)"No error", + (const GLubyte*)"Missing GL version", + (const GLubyte*)"GL 1.1 and up are not supported", + (const GLubyte*)"GLX 1.2 and up are not supported", + (const GLubyte*)"Unknown error" + }; + const int max_error = sizeof(_glewErrorString)/sizeof(*_glewErrorString) - 1; + return _glewErrorString[(int)error > max_error ? max_error : (int)error]; +} + +const GLubyte* glewGetString (GLenum name) +{ + static const GLubyte* _glewString[] = + { + (const GLubyte*)NULL, + (const GLubyte*)"GLEW_VERSION_STRING", + (const GLubyte*)"GLEW_VERSION_MAJOR_STRING", + (const GLubyte*)"GLEW_VERSION_MINOR_STRING", + (const GLubyte*)"GLEW_VERSION_MICRO_STRING" + }; + const int max_string = sizeof(_glewString)/sizeof(*_glewString) - 1; + return _glewString[(int)name > max_string ? 0 : (int)name]; +} + +/* ------------------------------------------------------------------------ */ + +GLboolean glewExperimental = GL_FALSE; + +#if !defined(GLEW_MX) + +#if defined(_WIN32) +extern GLenum wglewContextInit (void); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) /* _UNIX */ +extern GLenum glxewContextInit (void); +#endif /* _WIN32 */ + +GLenum glewInit () +{ + GLenum r; + if ( (r = glewContextInit()) ) return r; +#if defined(_WIN32) + return wglewContextInit(); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) /* _UNIX */ + return glxewContextInit(); +#else + return r; +#endif /* _WIN32 */ +} + +#endif /* !GLEW_MX */ diff --git a/Externals/GLew/auto/src/glew_init_wgl.c b/Externals/GLew/auto/src/glew_init_wgl.c new file mode 100644 index 0000000000..e66de427b1 --- /dev/null +++ b/Externals/GLew/auto/src/glew_init_wgl.c @@ -0,0 +1,36 @@ +/* ------------------------------------------------------------------------- */ + +static PFNWGLGETEXTENSIONSSTRINGARBPROC _wglewGetExtensionsStringARB = NULL; +static PFNWGLGETEXTENSIONSSTRINGEXTPROC _wglewGetExtensionsStringEXT = NULL; + +GLboolean wglewGetExtension (const char* name) +{ + GLubyte* p; + GLubyte* end; + GLuint len = _glewStrLen((const GLubyte*)name); + if (_wglewGetExtensionsStringARB == NULL) + if (_wglewGetExtensionsStringEXT == NULL) + return GL_FALSE; + else + p = (GLubyte*)_wglewGetExtensionsStringEXT(); + else + p = (GLubyte*)_wglewGetExtensionsStringARB(wglGetCurrentDC()); + if (0 == p) return GL_FALSE; + end = p + _glewStrLen(p); + while (p < end) + { + GLuint n = _glewStrCLen(p, ' '); + if (len == n && _glewStrSame((const GLubyte*)name, p, n)) return GL_TRUE; + p += n+1; + } + return GL_FALSE; +} + +GLenum wglewContextInit (WGLEW_CONTEXT_ARG_DEF_LIST) +{ + GLboolean crippled; + /* find wgl extension string query functions */ + _wglewGetExtensionsStringARB = (PFNWGLGETEXTENSIONSSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringARB"); + _wglewGetExtensionsStringEXT = (PFNWGLGETEXTENSIONSSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringEXT"); + /* initialize extensions */ + crippled = _wglewGetExtensionsStringARB == NULL && _wglewGetExtensionsStringEXT == NULL; diff --git a/Externals/GLew/auto/src/glew_license.h b/Externals/GLew/auto/src/glew_license.h new file mode 100644 index 0000000000..5c3e781f71 --- /dev/null +++ b/Externals/GLew/auto/src/glew_license.h @@ -0,0 +1,31 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + diff --git a/Externals/GLew/auto/src/glew_str_glx.c b/Externals/GLew/auto/src/glew_str_glx.c new file mode 100644 index 0000000000..7c31405754 --- /dev/null +++ b/Externals/GLew/auto/src/glew_str_glx.c @@ -0,0 +1,21 @@ + } + ret = (len == 0); + } + return ret; +} + +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + +#if defined(GLEW_MX) +GLboolean glxewContextIsSupported (GLXEWContext* ctx, const char* name) +#else +GLboolean glxewIsSupported (const char* name) +#endif +{ + GLubyte* pos = (GLubyte*)name; + GLuint len = _glewStrLen(pos); + GLboolean ret = GL_TRUE; + while (ret && len > 0) + { + if(_glewStrSame1(&pos, &len, (const GLubyte*)"GLX_", 4)) + { diff --git a/Externals/GLew/auto/src/glew_str_head.c b/Externals/GLew/auto/src/glew_str_head.c new file mode 100644 index 0000000000..1f3ddf20c4 --- /dev/null +++ b/Externals/GLew/auto/src/glew_str_head.c @@ -0,0 +1,13 @@ +#ifdef GLEW_MX +GLboolean glewContextIsSupported (GLEWContext* ctx, const char* name) +#else +GLboolean glewIsSupported (const char* name) +#endif +{ + GLubyte* pos = (GLubyte*)name; + GLuint len = _glewStrLen(pos); + GLboolean ret = GL_TRUE; + while (ret && len > 0) + { + if (_glewStrSame1(&pos, &len, (const GLubyte*)"GL_", 3)) + { diff --git a/Externals/GLew/auto/src/glew_str_tail.c b/Externals/GLew/auto/src/glew_str_tail.c new file mode 100644 index 0000000000..caa95727d3 --- /dev/null +++ b/Externals/GLew/auto/src/glew_str_tail.c @@ -0,0 +1,7 @@ + } + ret = (len == 0); + } + return ret; +} + +#endif /* _WIN32 */ diff --git a/Externals/GLew/auto/src/glew_str_wgl.c b/Externals/GLew/auto/src/glew_str_wgl.c new file mode 100644 index 0000000000..2398075bda --- /dev/null +++ b/Externals/GLew/auto/src/glew_str_wgl.c @@ -0,0 +1,21 @@ + } + ret = (len == 0); + } + return ret; +} + +#if defined(_WIN32) + +#if defined(GLEW_MX) +GLboolean wglewContextIsSupported (WGLEWContext* ctx, const char* name) +#else +GLboolean wglewIsSupported (const char* name) +#endif +{ + GLubyte* pos = (GLubyte*)name; + GLuint len = _glewStrLen(pos); + GLboolean ret = GL_TRUE; + while (ret && len > 0) + { + if (_glewStrSame1(&pos, &len, (const GLubyte*)"WGL_", 4)) + { diff --git a/Externals/GLew/auto/src/glew_tail.h b/Externals/GLew/auto/src/glew_tail.h new file mode 100644 index 0000000000..647c4cfe52 --- /dev/null +++ b/Externals/GLew/auto/src/glew_tail.h @@ -0,0 +1,74 @@ +/* ------------------------------------------------------------------------- */ + +/* error codes */ +#define GLEW_OK 0 +#define GLEW_NO_ERROR 0 +#define GLEW_ERROR_NO_GL_VERSION 1 /* missing GL version */ +#define GLEW_ERROR_GL_VERSION_10_ONLY 2 /* GL 1.1 and up are not supported */ +#define GLEW_ERROR_GLX_VERSION_11_ONLY 3 /* GLX 1.2 and up are not supported */ + +/* string codes */ +#define GLEW_VERSION 1 +#define GLEW_VERSION_MAJOR 2 +#define GLEW_VERSION_MINOR 3 +#define GLEW_VERSION_MICRO 4 + +/* API */ +#ifdef GLEW_MX + +typedef struct GLEWContextStruct GLEWContext; +GLEWAPI GLenum glewContextInit (GLEWContext* ctx); +GLEWAPI GLboolean glewContextIsSupported (GLEWContext* ctx, const char* name); + +#define glewInit() glewContextInit(glewGetContext()) +#define glewIsSupported(x) glewContextIsSupported(glewGetContext(), x) +#define glewIsExtensionSupported(x) glewIsSupported(x) + +#define GLEW_GET_VAR(x) (*(const GLboolean*)&(glewGetContext()->x)) +#ifdef _WIN32 +# define GLEW_GET_FUN(x) glewGetContext()->x +#else +# define GLEW_GET_FUN(x) x +#endif + +#else /* GLEW_MX */ + +GLEWAPI GLenum glewInit (); +GLEWAPI GLboolean glewIsSupported (const char* name); +#define glewIsExtensionSupported(x) glewIsSupported(x) + +#define GLEW_GET_VAR(x) (*(const GLboolean*)&x) +#define GLEW_GET_FUN(x) x + +#endif /* GLEW_MX */ + +GLEWAPI GLboolean glewExperimental; +GLEWAPI GLboolean glewGetExtension (const char* name); +GLEWAPI const GLubyte* glewGetErrorString (GLenum error); +GLEWAPI const GLubyte* glewGetString (GLenum name); + +#ifdef __cplusplus +} +#endif + +#ifdef GLEW_APIENTRY_DEFINED +#undef GLEW_APIENTRY_DEFINED +#undef APIENTRY +#undef GLAPIENTRY +#define GLAPIENTRY +#endif + +#ifdef GLEW_CALLBACK_DEFINED +#undef GLEW_CALLBACK_DEFINED +#undef CALLBACK +#endif + +#ifdef GLEW_WINGDIAPI_DEFINED +#undef GLEW_WINGDIAPI_DEFINED +#undef WINGDIAPI +#endif + +#undef GLAPI +/* #undef GLEWAPI */ + +#endif /* __glew_h__ */ diff --git a/Externals/GLew/auto/src/glew_utils.c b/Externals/GLew/auto/src/glew_utils.c new file mode 100644 index 0000000000..85fb57f758 --- /dev/null +++ b/Externals/GLew/auto/src/glew_utils.c @@ -0,0 +1,162 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#include +#if defined(_WIN32) +# include +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +# include +#endif + +#include "glew_utils.h" + +#if defined(__APPLE__) +#include +#include +#include + +void* NSGLGetProcAddress (const GLubyte *name) +{ + NSSymbol symbol; + char* symbolName; + /* prepend a '_' for the Unix C symbol mangling convention */ + symbolName = malloc(strlen((const char*)name) + 2); + strcpy(symbolName+1, (const char*)name); + symbolName[0] = '_'; + symbol = NULL; + if (NSIsSymbolNameDefined(symbolName)) + symbol = NSLookupAndBindSymbol(symbolName); + free(symbolName); + return symbol ? NSAddressOfSymbol(symbol) : NULL; +} +#endif /* __APPLE__ */ + +#if defined(__sgi) || defined (__sun) +#include +#include +#include + +void* dlGetProcAddress (const GLubyte* name) +{ + static void* h = NULL; + static void* gpa; + + if (h == NULL) + { + if ((h = dlopen(NULL, RTLD_LAZY | RTLD_LOCAL)) == NULL) return NULL; + gpa = dlsym(h, "glXGetProcAddress"); + } + + if (gpa != NULL) + return ((void*(*)(const GLubyte*))gpa)(name); + else + return dlsym(h, (const char*)name); +} +#endif /* __sgi || __sun */ + +/* + * GLEW, just like OpenGL or GLU, does not rely on the standard C library. + * These functions implement the functionality required in this file. + */ + +GLuint _glewStrLen (const GLubyte* s) +{ + GLuint i=0; + while (s+i != NULL && s[i] != '\0') i++; + return i; +} + +GLuint _glewStrCLen (const GLubyte* s, GLubyte c) +{ + GLuint i=0; + while (s+i != NULL && s[i] != '\0' && s[i] != c) i++; + return i; +} + +GLboolean _glewStrSame (const GLubyte* a, const GLubyte* b, GLuint n) +{ + GLuint i=0; + while (i < n && a+i != NULL && b+i != NULL && a[i] == b[i]) i++; + return i == n ? GL_TRUE : GL_FALSE; +} + +GLboolean _glewStrSame1 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + while (*na > 0 && (**a == ' ' || **a == '\n' || **a == '\r' || **a == '\t')) + { + *a++; + *na--; + } + if(*na >= nb) + { + GLuint i=0; + while (i < nb && *a+i != NULL && b+i != NULL && *a[i] == b[i]) i++; + if(i == nb) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} + +GLboolean _glewStrSame2 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + if(*na >= nb) + { + GLuint i=0; + while (i < nb && *a+i != NULL && b+i != NULL && *a[i] == b[i]) i++; + if(i == nb) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} + +GLboolean _glewStrSame3 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + if(*na >= nb) + { + GLuint i=0; + while (i < nb && *a+i != NULL && b+i != NULL && *a[i] == b[i]) i++; + if (i == nb && (*na == nb || *a[i] == ' ' || *a[i] == '\n' || *a[i] == '\r' || *a[i] == '\t')) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} diff --git a/Externals/GLew/auto/src/glew_utils.h b/Externals/GLew/auto/src/glew_utils.h new file mode 100644 index 0000000000..006023050c --- /dev/null +++ b/Externals/GLew/auto/src/glew_utils.h @@ -0,0 +1,101 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#ifndef __glew_utils_h__ +#define __glew_utils_h__ + +#include +#if defined(_WIN32) +# include +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +# include +#endif + +/* + * Define glewGetContext and related helper macros. + */ +#ifdef GLEW_MX +# define glewGetContext() ctx +# ifdef _WIN32 +# define GLEW_CONTEXT_ARG_DEF_INIT GLEWContext* ctx +# define GLEW_CONTEXT_ARG_VAR_INIT ctx +# define wglewGetContext() ctx +# define WGLEW_CONTEXT_ARG_DEF_INIT WGLEWContext* ctx +# define WGLEW_CONTEXT_ARG_DEF_LIST WGLEWContext* ctx +# else /* _WIN32 */ +# define GLEW_CONTEXT_ARG_DEF_INIT void +# define GLEW_CONTEXT_ARG_VAR_INIT +# define glxewGetContext() ctx +# define GLXEW_CONTEXT_ARG_DEF_INIT void +# define GLXEW_CONTEXT_ARG_DEF_LIST GLXEWContext* ctx +# endif /* _WIN32 */ +# define GLEW_CONTEXT_ARG_DEF_LIST GLEWContext* ctx +#else /* GLEW_MX */ +# define GLEW_CONTEXT_ARG_DEF_INIT void +# define GLEW_CONTEXT_ARG_VAR_INIT +# define GLEW_CONTEXT_ARG_DEF_LIST void +# define WGLEW_CONTEXT_ARG_DEF_INIT void +# define WGLEW_CONTEXT_ARG_DEF_LIST void +# define GLXEW_CONTEXT_ARG_DEF_INIT void +# define GLXEW_CONTEXT_ARG_DEF_LIST void +#endif /* GLEW_MX */ + +/* + * Define glewGetProcAddress. + */ +#if defined(_WIN32) +# define glewGetProcAddress(name) wglGetProcAddress((LPCSTR)name) +#else +# if defined(__APPLE__) + extern void* NSGLGetProcAddress (const GLubyte* name); +# define glewGetProcAddress(name) NSGLGetProcAddress(name) +# else +# if defined(__sgi) || defined(__sun) + extern void* dlGetProcAddress (const GLubyte* name); +# define glewGetProcAddress(name) dlGetProcAddress(name) +# else /* __linux */ +# define glewGetProcAddress(name) (*glXGetProcAddressARB)(name) +# endif +# endif +#endif + +/* + * GLEW, just like OpenGL or GLU, does not rely on the standard C library. + * These functions implement the string processing functionality required in the library. + */ +extern GLuint _glewStrLen (const GLubyte* s); +extern GLuint _glewStrCLen (const GLubyte* s, GLubyte c); +extern GLboolean _glewStrSame (const GLubyte* a, const GLubyte* b, GLuint n); +extern GLboolean _glewStrSame1 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb); +extern GLboolean _glewStrSame2 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb); +extern GLboolean _glewStrSame3 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) + +#endif /* __glew_utils_h__ */ diff --git a/Externals/GLew/auto/src/glewinfo.rc b/Externals/GLew/auto/src/glewinfo.rc new file mode 100644 index 0000000000..60b001dfdb --- /dev/null +++ b/Externals/GLew/auto/src/glewinfo.rc @@ -0,0 +1,57 @@ + +#include + +#ifdef GLEW_MX +# ifdef _DEBUG +# define FILENAME "glewinfo-mxd.exe" +# else +# define FILENAME "glewinfo-mx.exe" +# endif +#else +# ifdef _DEBUG +# define FILENAME "glewinfod.exe" +# else +# define FILENAME "glewinfo.exe" +# endif +#endif + +///////////////////////////////////////////////////////////////////////////// +// +// Version +// +VS_VERSION_INFO VERSIONINFO +FILEVERSION GLEW_MAJOR, GLEW_MINOR, GLEW_MICRO, 0 +PRODUCTVERSION GLEW_MAJOR, GLEW_MINOR, GLEW_MICRO, 0 +FILEFLAGSMASK VS_FFI_FILEFLAGSMASK +#ifdef _DEBUG +FILEFLAGS VS_FF_DEBUG +#else +FILEFLAGS 0x0L +#endif +FILEOS VOS__WINDOWS32 +FILETYPE VFT_APP +FILESUBTYPE VFT2_UNKNOWN +BEGIN + BLOCK "StringFileInfo" + BEGIN + BLOCK "040904b0" + BEGIN + VALUE "Comments", "The OpenGL Extension Wrangler Library\r\nCopyright (C) 2002-2008, Milan Ikits \r\nCopyright (C) 2002-2008, Marcelo E. Magallon \r\nCopyright (C) 2002, Lev Povalahev\r\nAll rights reserved.\r\n \r\nRedistribution and use in source and binary forms, with or without \r\nmodification, are permitted provided that the following conditions are met:\r\n\r\n* Redistributions of source code must retain the above copyright notice, \r\n this list of conditions and the following disclaimer.\r\n* Redistributions in binary form must reproduce the above copyright notice, \r\n this list of conditions and the following disclaimer in the documentation \r\n and/or other materials provided with the distribution.\r\n* The name of the author may be used to endorse or promote products \r\n derived from this software without specific prior written permission.\r\n\r\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' \r\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \r\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r\nARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \r\nLIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \r\nCONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \r\nSUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\r\nINTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\r\nCONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r\nARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\r\nTHE POSSIBILITY OF SUCH DAMAGE.\r\n\r\nLicense Applicability. Except to the extent portions of this file are\r\nmade subject to an alternative license as permitted in the SGI Free\r\nSoftware License B, Version 1.1 (the 'License'), the contents of this\r\nfile are subject only to the provisions of the License. You may not use\r\nthis file except in compliance with the License. You may obtain a copy\r\nof the License at Silicon Graphics, Inc., attn: Legal Services, 1600\r\nAmphitheatre Parkway, Mountain View, CA 94043-1351, or at:\r\n\r\nhttp://oss.sgi.com/projects/FreeB\r\n\r\nNote that, as provided in the License, the Software is distributed on an\r\n'AS IS' basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS\r\nDISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND\r\nCONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A\r\nPARTICULAR PURPOSE, AND NON-INFRINGEMENT.\r\n\r\nOriginal Code. The Original Code is: OpenGL Sample Implementation,\r\nVersion 1.2.1, released January 26, 2000, developed by Silicon Graphics,\r\nInc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.\r\nCopyright in any portions created by third parties is as indicated\r\nelsewhere herein. All Rights Reserved.\r\n\r\nAdditional Notice Provisions: This software was created using the\r\nOpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has\r\nnot been independently verified as being compliant with the OpenGL(R)\r\nversion 1.2.1 Specification.\0" + VALUE "CompanyName", "\0" + VALUE "FileDescription", "Utility for verifying extension entry points\0" + VALUE "FileVersion", "GLEW_MAJOR,GLEW_MINOR,GLEW_MICRO,0\0" + VALUE "InternalName", "glewinfo\0" + VALUE "LegalCopyright", " 2002-2008 Milan Ikits & Marcelo Magallon\0" + VALUE "LegalTrademarks", "\0" + VALUE "OriginalFilename", FILENAME "\0" + VALUE "PrivateBuild", "\0" + VALUE "ProductName", "The OpenGL Extension Wrangler Library\0" + VALUE "ProductVersion", "GLEW_MAJOR,GLEW_MINOR,GLEW_MICRO,0\0" + VALUE "SpecialBuild", "\0" + END + END + BLOCK "VarFileInfo" + BEGIN + VALUE "Translation", 0x409, 1200 + END +END diff --git a/Externals/GLew/auto/src/glewinfo_gl.c b/Externals/GLew/auto/src/glewinfo_gl.c new file mode 100644 index 0000000000..9d7835d0b8 --- /dev/null +++ b/Externals/GLew/auto/src/glewinfo_gl.c @@ -0,0 +1,7 @@ +/* ------------------------------------------------------------------------ */ + +static void glewInfo (void) +{ +#ifdef GL_VERSION_1_1 + _glewInfo_GL_VERSION_1_1(); +#endif /* GL_VERSION_1_1 */ diff --git a/Externals/GLew/auto/src/glewinfo_glx.c b/Externals/GLew/auto/src/glewinfo_glx.c new file mode 100644 index 0000000000..287d7e1fd1 --- /dev/null +++ b/Externals/GLew/auto/src/glewinfo_glx.c @@ -0,0 +1,6 @@ +} + +#else /* _UNIX */ + +static void glxewInfo () +{ diff --git a/Externals/GLew/auto/src/glewinfo_head.c b/Externals/GLew/auto/src/glewinfo_head.c new file mode 100644 index 0000000000..e1070c5b32 --- /dev/null +++ b/Externals/GLew/auto/src/glewinfo_head.c @@ -0,0 +1,77 @@ +#include +#include +#include +#include +#if defined(_WIN32) +#include +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +#include +#endif + +static FILE* f; + +#ifdef GLEW_MX +GLEWContext _glewctx; +#define glewGetContext() (&_glewctx) +#ifdef _WIN32 +WGLEWContext _wglewctx; +#define wglewGetContext() (&_wglewctx) +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLXEWContext _glxewctx; +#define glxewGetContext() (&_glxewctx) +#endif +#endif + +#if defined(_WIN32) +GLboolean glewCreateContext (int* pixelformat); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLboolean glewCreateContext (const char* display, int* visual); +#else +GLboolean glewCreateContext (); +#endif + +#if defined(_WIN32) || !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLboolean glewParseArgs (int argc, char** argv, char** display, int* visual); +#endif + +void glewDestroyContext (); + +/* ------------------------------------------------------------------------- */ + +static void glewPrintExt (const char* name, GLboolean def1, GLboolean def2, GLboolean def3) +{ + unsigned int i; + fprintf(f, "\n%s:", name); + for (i=0; i<62-strlen(name); i++) fprintf(f, " "); + fprintf(f, "%s ", def1 ? "OK" : "MISSING"); + if (def1 != def2) + fprintf(f, "[%s] ", def2 ? "OK" : "MISSING"); + if (def1 != def3) + fprintf(f, "[%s]\n", def3 ? "OK" : "MISSING"); + else + fprintf(f, "\n"); + for (i=0; i]\n"); +#else + fprintf(stderr, "Usage: glewinfo [-display ] [-visual ]\n"); +#endif + return 1; + } +#endif + +#if defined(_WIN32) + if (GL_TRUE == glewCreateContext(&visual)) +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + if (GL_TRUE == glewCreateContext()) +#else + if (GL_TRUE == glewCreateContext(display, &visual)) +#endif + { + fprintf(stderr, "Error: glewCreateContext failed\n"); + glewDestroyContext(); + return 1; + } + glewExperimental = GL_TRUE; +#ifdef GLEW_MX + err = glewContextInit(glewGetContext()); +#ifdef _WIN32 + err = err || wglewContextInit(wglewGetContext()); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + err = err || glxewContextInit(glxewGetContext()); +#endif + +#else + err = glewInit(); +#endif + if (GLEW_OK != err) + { + fprintf(stderr, "Error [main]: glewInit failed: %s\n", glewGetErrorString(err)); + glewDestroyContext(); + return 1; + } +#if defined(_WIN32) + f = fopen("glewinfo.txt", "w"); + if (f == NULL) f = stdout; +#else + f = stdout; +#endif + fprintf(f, "---------------------------\n"); + fprintf(f, " GLEW Extension Info\n"); + fprintf(f, "---------------------------\n\n"); + fprintf(f, "GLEW version %s\n", glewGetString(GLEW_VERSION)); +#if defined(_WIN32) + fprintf(f, "Reporting capabilities of pixelformat %d\n", visual); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + fprintf(f, "Reporting capabilities of display %s, visual 0x%x\n", + display == NULL ? getenv("DISPLAY") : display, visual); +#endif + fprintf(f, "Running on a %s from %s\n", + glGetString(GL_RENDERER), glGetString(GL_VENDOR)); + fprintf(f, "OpenGL version %s is supported\n", glGetString(GL_VERSION)); + glewInfo(); +#if defined(_WIN32) + wglewInfo(); +#else + glxewInfo(); +#endif + if (f != stdout) fclose(f); + glewDestroyContext(); + return 0; +} + +/* ------------------------------------------------------------------------ */ + +#if defined(_WIN32) || !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLboolean glewParseArgs (int argc, char** argv, char** display, int* visual) +{ + int p = 0; + while (p < argc) + { +#if defined(_WIN32) + if (!strcmp(argv[p], "-pf") || !strcmp(argv[p], "-pixelformat")) + { + if (++p >= argc) return GL_TRUE; + *display = 0; + *visual = strtol(argv[p++], NULL, 0); + } + else + return GL_TRUE; +#else + if (!strcmp(argv[p], "-display")) + { + if (++p >= argc) return GL_TRUE; + *display = argv[p++]; + } + else if (!strcmp(argv[p], "-visual")) + { + if (++p >= argc) return GL_TRUE; + *visual = (int)strtol(argv[p++], NULL, 0); + } + else + return GL_TRUE; +#endif + } + return GL_FALSE; +} +#endif + +/* ------------------------------------------------------------------------ */ + +#if defined(_WIN32) + +HWND wnd = NULL; +HDC dc = NULL; +HGLRC rc = NULL; + +GLboolean glewCreateContext (int* pixelformat) +{ + WNDCLASS wc; + PIXELFORMATDESCRIPTOR pfd; + /* register window class */ + ZeroMemory(&wc, sizeof(WNDCLASS)); + wc.hInstance = GetModuleHandle(NULL); + wc.lpfnWndProc = DefWindowProc; + wc.lpszClassName = "GLEW"; + if (0 == RegisterClass(&wc)) return GL_TRUE; + /* create window */ + wnd = CreateWindow("GLEW", "GLEW", 0, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, + CW_USEDEFAULT, NULL, NULL, GetModuleHandle(NULL), NULL); + if (NULL == wnd) return GL_TRUE; + /* get the device context */ + dc = GetDC(wnd); + if (NULL == dc) return GL_TRUE; + /* find pixel format */ + ZeroMemory(&pfd, sizeof(PIXELFORMATDESCRIPTOR)); + if (*pixelformat == -1) /* find default */ + { + pfd.nSize = sizeof(PIXELFORMATDESCRIPTOR); + pfd.nVersion = 1; + pfd.dwFlags = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL; + *pixelformat = ChoosePixelFormat(dc, &pfd); + if (*pixelformat == 0) return GL_TRUE; + } + /* set the pixel format for the dc */ + if (FALSE == SetPixelFormat(dc, *pixelformat, &pfd)) return GL_TRUE; + /* create rendering context */ + rc = wglCreateContext(dc); + if (NULL == rc) return GL_TRUE; + if (FALSE == wglMakeCurrent(dc, rc)) return GL_TRUE; + return GL_FALSE; +} + +void glewDestroyContext () +{ + if (NULL != rc) wglMakeCurrent(NULL, NULL); + if (NULL != rc) wglDeleteContext(rc); + if (NULL != wnd && NULL != dc) ReleaseDC(wnd, dc); + if (NULL != wnd) DestroyWindow(wnd); + UnregisterClass("GLEW", GetModuleHandle(NULL)); +} + +/* ------------------------------------------------------------------------ */ + +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + +#include + +AGLContext ctx, octx; + +GLboolean glewCreateContext () +{ + int attrib[] = { AGL_RGBA, AGL_NONE }; + AGLPixelFormat pf; + /*int major, minor; + SetPortWindowPort(wnd); + aglGetVersion(&major, &minor); + fprintf(stderr, "GL %d.%d\n", major, minor);*/ + pf = aglChoosePixelFormat(NULL, 0, attrib); + if (NULL == pf) return GL_TRUE; + ctx = aglCreateContext(pf, NULL); + if (NULL == ctx || AGL_NO_ERROR != aglGetError()) return GL_TRUE; + aglDestroyPixelFormat(pf); + /*aglSetDrawable(ctx, GetWindowPort(wnd));*/ + octx = aglGetCurrentContext(); + if (GL_FALSE == aglSetCurrentContext(ctx)) return GL_TRUE; + return GL_FALSE; +} + +void glewDestroyContext () +{ + aglSetCurrentContext(octx); + if (NULL != ctx) aglDestroyContext(ctx); +} + +/* ------------------------------------------------------------------------ */ + +#else /* __UNIX || (__APPLE__ && GLEW_APPLE_GLX) */ + +Display* dpy = NULL; +XVisualInfo* vi = NULL; +XVisualInfo* vis = NULL; +GLXContext ctx = NULL; +Window wnd = 0; +Colormap cmap = 0; + +GLboolean glewCreateContext (const char* display, int* visual) +{ + int attrib[] = { GLX_RGBA, GLX_DOUBLEBUFFER, None }; + int erb, evb; + XSetWindowAttributes swa; + /* open display */ + dpy = XOpenDisplay(display); + if (NULL == dpy) return GL_TRUE; + /* query for glx */ + if (!glXQueryExtension(dpy, &erb, &evb)) return GL_TRUE; + /* choose visual */ + if (*visual == -1) + { + vi = glXChooseVisual(dpy, DefaultScreen(dpy), attrib); + if (NULL == vi) return GL_TRUE; + *visual = (int)XVisualIDFromVisual(vi->visual); + } + else + { + int n_vis, i; + vis = XGetVisualInfo(dpy, 0, NULL, &n_vis); + for (i=0; iscreen), 0, 0, 1, 1, 1, 0, 0);*/ + cmap = XCreateColormap(dpy, RootWindow(dpy, vi->screen), vi->visual, AllocNone); + swa.border_pixel = 0; + swa.colormap = cmap; + wnd = XCreateWindow(dpy, RootWindow(dpy, vi->screen), + 0, 0, 1, 1, 0, vi->depth, InputOutput, vi->visual, + CWBorderPixel | CWColormap, &swa); + /* make context current */ + if (!glXMakeCurrent(dpy, wnd, ctx)) return GL_TRUE; + return GL_FALSE; +} + +void glewDestroyContext () +{ + if (NULL != dpy && NULL != ctx) glXDestroyContext(dpy, ctx); + if (NULL != dpy && 0 != wnd) XDestroyWindow(dpy, wnd); + if (NULL != dpy && 0 != cmap) XFreeColormap(dpy, cmap); + if (NULL != vis) + XFree(vis); + else if (NULL != vi) + XFree(vi); + if (NULL != dpy) XCloseDisplay(dpy); +} + +#endif /* __UNIX || (__APPLE__ && GLEW_APPLE_GLX) */ diff --git a/Externals/GLew/auto/src/glewinfo_wgl.c b/Externals/GLew/auto/src/glewinfo_wgl.c new file mode 100644 index 0000000000..61f101a090 --- /dev/null +++ b/Externals/GLew/auto/src/glewinfo_wgl.c @@ -0,0 +1,8 @@ +} + +/* ------------------------------------------------------------------------ */ + +#ifdef _WIN32 + +static void wglewInfo () +{ diff --git a/Externals/GLew/auto/src/glxew_head.h b/Externals/GLew/auto/src/glxew_head.h new file mode 100644 index 0000000000..16fdfa4126 --- /dev/null +++ b/Externals/GLew/auto/src/glxew_head.h @@ -0,0 +1,106 @@ +#ifndef __glxew_h__ +#define __glxew_h__ +#define __GLXEW_H__ + +#ifdef __glxext_h_ +#error glxext.h included before glxew.h +#endif + +#if defined(GLX_H) || defined(__GLX_glx_h__) || defined(__glx_h__) +#error glx.h included before glxew.h +#endif + +#define __glxext_h_ + +#define GLX_H +#define __GLX_glx_h__ +#define __glx_h__ + +#include +#include +#include +#include + +#ifdef __cplusplus +extern "C" { +#endif + +/* ---------------------------- GLX_VERSION_1_0 --------------------------- */ + +#ifndef GLX_VERSION_1_0 +#define GLX_VERSION_1_0 1 + +#define GLX_USE_GL 1 +#define GLX_BUFFER_SIZE 2 +#define GLX_LEVEL 3 +#define GLX_RGBA 4 +#define GLX_DOUBLEBUFFER 5 +#define GLX_STEREO 6 +#define GLX_AUX_BUFFERS 7 +#define GLX_RED_SIZE 8 +#define GLX_GREEN_SIZE 9 +#define GLX_BLUE_SIZE 10 +#define GLX_ALPHA_SIZE 11 +#define GLX_DEPTH_SIZE 12 +#define GLX_STENCIL_SIZE 13 +#define GLX_ACCUM_RED_SIZE 14 +#define GLX_ACCUM_GREEN_SIZE 15 +#define GLX_ACCUM_BLUE_SIZE 16 +#define GLX_ACCUM_ALPHA_SIZE 17 +#define GLX_BAD_SCREEN 1 +#define GLX_BAD_ATTRIBUTE 2 +#define GLX_NO_EXTENSION 3 +#define GLX_BAD_VISUAL 4 +#define GLX_BAD_CONTEXT 5 +#define GLX_BAD_VALUE 6 +#define GLX_BAD_ENUM 7 + +typedef XID GLXDrawable; +typedef XID GLXPixmap; +#ifdef __sun +typedef struct __glXContextRec *GLXContext; +#else +typedef struct __GLXcontextRec *GLXContext; +#endif + +typedef unsigned int GLXVideoDeviceNV; + +extern Bool glXQueryExtension (Display *dpy, int *errorBase, int *eventBase); +extern Bool glXQueryVersion (Display *dpy, int *major, int *minor); +extern int glXGetConfig (Display *dpy, XVisualInfo *vis, int attrib, int *value); +extern XVisualInfo* glXChooseVisual (Display *dpy, int screen, int *attribList); +extern GLXPixmap glXCreateGLXPixmap (Display *dpy, XVisualInfo *vis, Pixmap pixmap); +extern void glXDestroyGLXPixmap (Display *dpy, GLXPixmap pix); +extern GLXContext glXCreateContext (Display *dpy, XVisualInfo *vis, GLXContext shareList, Bool direct); +extern void glXDestroyContext (Display *dpy, GLXContext ctx); +extern Bool glXIsDirect (Display *dpy, GLXContext ctx); +extern void glXCopyContext (Display *dpy, GLXContext src, GLXContext dst, GLulong mask); +extern Bool glXMakeCurrent (Display *dpy, GLXDrawable drawable, GLXContext ctx); +extern GLXContext glXGetCurrentContext (void); +extern GLXDrawable glXGetCurrentDrawable (void); +extern void glXWaitGL (void); +extern void glXWaitX (void); +extern void glXSwapBuffers (Display *dpy, GLXDrawable drawable); +extern void glXUseXFont (Font font, int first, int count, int listBase); + +#define GLXEW_VERSION_1_0 GLXEW_GET_VAR(__GLXEW_VERSION_1_0) + +#endif /* GLX_VERSION_1_0 */ + +/* ---------------------------- GLX_VERSION_1_1 --------------------------- */ + +#ifndef GLX_VERSION_1_1 +#define GLX_VERSION_1_1 + +#define GLX_VENDOR 0x1 +#define GLX_VERSION 0x2 +#define GLX_EXTENSIONS 0x3 + +extern const char* glXQueryExtensionsString (Display *dpy, int screen); +extern const char* glXGetClientString (Display *dpy, int name); +extern const char* glXQueryServerString (Display *dpy, int screen, int name); + +#define GLXEW_VERSION_1_1 GLXEW_GET_VAR(__GLXEW_VERSION_1_1) + +#endif /* GLX_VERSION_1_1 */ + diff --git a/Externals/GLew/auto/src/glxew_tail.h b/Externals/GLew/auto/src/glxew_tail.h new file mode 100644 index 0000000000..702eb94447 --- /dev/null +++ b/Externals/GLew/auto/src/glxew_tail.h @@ -0,0 +1,30 @@ +/* ------------------------------------------------------------------------ */ + +#ifdef GLEW_MX + +typedef struct GLXEWContextStruct GLXEWContext; +extern GLenum glxewContextInit (GLXEWContext* ctx); +extern GLboolean glxewContextIsSupported (GLXEWContext* ctx, const char* name); + +#define glxewInit() glxewContextInit(glxewGetContext()) +#define glxewIsSupported(x) glxewContextIsSupported(glxewGetContext(), x) + +#define GLXEW_GET_VAR(x) (*(const GLboolean*)&(glxewGetContext()->x)) +#define GLXEW_GET_FUN(x) x + +#else /* GLEW_MX */ + +#define GLXEW_GET_VAR(x) (*(const GLboolean*)&x) +#define GLXEW_GET_FUN(x) x + +extern GLboolean glxewIsSupported (const char* name); + +#endif /* GLEW_MX */ + +extern GLboolean glxewGetExtension (const char* name); + +#ifdef __cplusplus +} +#endif + +#endif /* __glxew_h__ */ diff --git a/Externals/GLew/auto/src/header.html b/Externals/GLew/auto/src/header.html new file mode 100644 index 0000000000..c33dd3888c --- /dev/null +++ b/Externals/GLew/auto/src/header.html @@ -0,0 +1,98 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + diff --git a/Externals/GLew/auto/src/khronos_license.h b/Externals/GLew/auto/src/khronos_license.h new file mode 100644 index 0000000000..420cd72273 --- /dev/null +++ b/Externals/GLew/auto/src/khronos_license.h @@ -0,0 +1,23 @@ +/* +** Copyright (c) 2007 The Khronos Group Inc. +** +** Permission is hereby granted, free of charge, to any person obtaining a +** copy of this software and/or associated documentation files (the +** "Materials"), to deal in the Materials without restriction, including +** without limitation the rights to use, copy, modify, merge, publish, +** distribute, sublicense, and/or sell copies of the Materials, and to +** permit persons to whom the Materials are furnished to do so, subject to +** the following conditions: +** +** The above copyright notice and this permission notice shall be included +** in all copies or substantial portions of the Materials. +** +** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. +*/ + diff --git a/Externals/GLew/auto/src/mesa_license.h b/Externals/GLew/auto/src/mesa_license.h new file mode 100644 index 0000000000..3350cca3f0 --- /dev/null +++ b/Externals/GLew/auto/src/mesa_license.h @@ -0,0 +1,24 @@ +/* + * Mesa 3-D graphics library + * Version: 7.0 + * + * Copyright (C) 1999-2007 Brian Paul All Rights Reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included + * in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN + * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + diff --git a/Externals/GLew/auto/src/visualinfo.rc b/Externals/GLew/auto/src/visualinfo.rc new file mode 100644 index 0000000000..2373944577 --- /dev/null +++ b/Externals/GLew/auto/src/visualinfo.rc @@ -0,0 +1,57 @@ + +#include + +#ifdef GLEW_MX +# ifdef _DEBUG +# define FILENAME "visualinfo-mxd.exe" +# else +# define FILENAME "visualinfo-mx.exe" +# endif +#else +# ifdef _DEBUG +# define FILENAME "visualinfod.exe" +# else +# define FILENAME "visualinfo.exe" +# endif +#endif + +///////////////////////////////////////////////////////////////////////////// +// +// Version +// +VS_VERSION_INFO VERSIONINFO +FILEVERSION GLEW_MAJOR, GLEW_MINOR, GLEW_MICRO, 0 +PRODUCTVERSION GLEW_MAJOR, GLEW_MINOR, GLEW_MICRO, 0 +FILEFLAGSMASK VS_FFI_FILEFLAGSMASK +#ifdef _DEBUG +FILEFLAGS VS_FF_DEBUG +#else +FILEFLAGS 0x0L +#endif +FILEOS VOS__WINDOWS32 +FILETYPE VFT_APP +FILESUBTYPE VFT2_UNKNOWN +BEGIN + BLOCK "StringFileInfo" + BEGIN + BLOCK "040904b0" + BEGIN + VALUE "Comments", "The OpenGL Extension Wrangler Library\r\nCopyright (C) 2002-2008, Milan Ikits \r\nCopyright (C) 2002-2008, Marcelo E. Magallon \r\nCopyright (C) 2002, Lev Povalahev\r\nAll rights reserved.\r\n \r\nRedistribution and use in source and binary forms, with or without \r\nmodification, are permitted provided that the following conditions are met:\r\n\r\n* Redistributions of source code must retain the above copyright notice, \r\n this list of conditions and the following disclaimer.\r\n* Redistributions in binary form must reproduce the above copyright notice, \r\n this list of conditions and the following disclaimer in the documentation \r\n and/or other materials provided with the distribution.\r\n* The name of the author may be used to endorse or promote products \r\n derived from this software without specific prior written permission.\r\n\r\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' \r\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \r\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r\nARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \r\nLIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \r\nCONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \r\nSUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\r\nINTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\r\nCONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r\nARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\r\nTHE POSSIBILITY OF SUCH DAMAGE.\r\n\r\nLicense Applicability. Except to the extent portions of this file are\r\nmade subject to an alternative license as permitted in the SGI Free\r\nSoftware License B, Version 1.1 (the 'License'), the contents of this\r\nfile are subject only to the provisions of the License. You may not use\r\nthis file except in compliance with the License. You may obtain a copy\r\nof the License at Silicon Graphics, Inc., attn: Legal Services, 1600\r\nAmphitheatre Parkway, Mountain View, CA 94043-1351, or at:\r\n\r\nhttp://oss.sgi.com/projects/FreeB\r\n\r\nNote that, as provided in the License, the Software is distributed on an\r\n'AS IS' basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS\r\nDISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND\r\nCONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A\r\nPARTICULAR PURPOSE, AND NON-INFRINGEMENT.\r\n\r\nOriginal Code. The Original Code is: OpenGL Sample Implementation,\r\nVersion 1.2.1, released January 26, 2000, developed by Silicon Graphics,\r\nInc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.\r\nCopyright in any portions created by third parties is as indicated\r\nelsewhere herein. All Rights Reserved.\r\n\r\nAdditional Notice Provisions: This software was created using the\r\nOpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has\r\nnot been independently verified as being compliant with the OpenGL(R)\r\nversion 1.2.1 Specification.\0" + VALUE "CompanyName", "\0" + VALUE "FileDescription", "Utility for listing pixelformat capabilities\0" + VALUE "FileVersion", "GLEW_MAJOR,GLEW_MINOR,GLEW_MICRO,0\0" + VALUE "InternalName", "visualinfo\0" + VALUE "LegalCopyright", " 2002-2008 Milan Ikits & Marcelo Magallon\0" + VALUE "LegalTrademarks", "\0" + VALUE "OriginalFilename", FILENAME "\0" + VALUE "PrivateBuild", "\0" + VALUE "ProductName", "The OpenGL Extension Wrangler Library\0" + VALUE "ProductVersion", "GLEW_MAJOR,GLEW_MINOR,GLEW_MICRO,0\0" + VALUE "SpecialBuild", "\0" + END + END + BLOCK "VarFileInfo" + BEGIN + VALUE "Translation", 0x409, 1200 + END +END diff --git a/Externals/GLew/auto/src/wglew_head.h b/Externals/GLew/auto/src/wglew_head.h new file mode 100644 index 0000000000..df8850392f --- /dev/null +++ b/Externals/GLew/auto/src/wglew_head.h @@ -0,0 +1,36 @@ +#ifndef __wglew_h__ +#define __wglew_h__ +#define __WGLEW_H__ + +#ifdef __wglext_h_ +#error wglext.h included before wglew.h +#endif + +#define __wglext_h_ + +#if !defined(WINAPI) +# ifndef WIN32_LEAN_AND_MEAN +# define WIN32_LEAN_AND_MEAN 1 +# endif +#include +# undef WIN32_LEAN_AND_MEAN +#endif + +/* + * GLEW_STATIC needs to be set when using the static version. + * GLEW_BUILD is set when building the DLL version. + */ +#ifdef GLEW_STATIC +# define GLEWAPI extern +#else +# ifdef GLEW_BUILD +# define GLEWAPI extern __declspec(dllexport) +# else +# define GLEWAPI extern __declspec(dllimport) +# endif +#endif + +#ifdef __cplusplus +extern "C" { +#endif + diff --git a/Externals/GLew/auto/src/wglew_tail.h b/Externals/GLew/auto/src/wglew_tail.h new file mode 100644 index 0000000000..7bb9bf8a95 --- /dev/null +++ b/Externals/GLew/auto/src/wglew_tail.h @@ -0,0 +1,32 @@ +/* ------------------------------------------------------------------------- */ + +#ifdef GLEW_MX + +typedef struct WGLEWContextStruct WGLEWContext; +GLEWAPI GLenum wglewContextInit (WGLEWContext* ctx); +GLEWAPI GLboolean wglewContextIsSupported (WGLEWContext* ctx, const char* name); + +#define wglewInit() wglewContextInit(wglewGetContext()) +#define wglewIsSupported(x) wglewContextIsSupported(wglewGetContext(), x) + +#define WGLEW_GET_VAR(x) (*(const GLboolean*)&(wglewGetContext()->x)) +#define WGLEW_GET_FUN(x) wglewGetContext()->x + +#else /* GLEW_MX */ + +#define WGLEW_GET_VAR(x) (*(const GLboolean*)&x) +#define WGLEW_GET_FUN(x) x + +GLEWAPI GLboolean wglewIsSupported (const char* name); + +#endif /* GLEW_MX */ + +GLEWAPI GLboolean wglewGetExtension (const char* name); + +#ifdef __cplusplus +} +#endif + +#undef GLEWAPI + +#endif /* __wglew_h__ */ diff --git a/Externals/GLew/build/vc6/Makefile b/Externals/GLew/build/vc6/Makefile new file mode 100644 index 0000000000..9f0ab41c83 --- /dev/null +++ b/Externals/GLew/build/vc6/Makefile @@ -0,0 +1,28 @@ +MSDEV := msdev +RM := rm -rf + +default: + $(MSDEV) glew.dsw /make \ + "glew_static - Win32 Release" \ + "glew_shared - Win32 Release" \ + "glewinfo - Win32 Release" \ + "visualinfo - Win32 Release" /build + +mx: + $(MSDEV) glew.dsw /make \ + "glew_static - Win32 Release MX" \ + "glew_shared - Win32 Release MX" \ + "glewinfo - Win32 Release MX" \ + "visualinfo - Win32 Release MX" /build + +debug: + $(MSDEV) glew.dsw /make \ + "glew_static - Win32 Debug" \ + "glew_shared - Win32 Debug" \ + "glewinfo - Win32 Debug" \ + "visualinfo - Win32 Debug" /build + + +clean: + $(MSDEV) glew.dsw /make all /clean + $(RM) static shared *.plg *.ncb *.opt diff --git a/Externals/GLew/build/vc6/glew.dsw b/Externals/GLew/build/vc6/glew.dsw new file mode 100644 index 0000000000..c201779eb7 --- /dev/null +++ b/Externals/GLew/build/vc6/glew.dsw @@ -0,0 +1,71 @@ +Microsoft Developer Studio Workspace File, Format Version 6.00 +# WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE! + +############################################################################### + +Project: "glew_shared"=.\glew_shared.dsp - Package Owner=<4> + +Package=<5> +{{{ +}}} + +Package=<4> +{{{ +}}} + +############################################################################### + +Project: "glew_static"=.\glew_static.dsp - Package Owner=<4> + +Package=<5> +{{{ +}}} + +Package=<4> +{{{ +}}} + +############################################################################### + +Project: "glewinfo"=.\glewinfo.dsp - Package Owner=<4> + +Package=<5> +{{{ +}}} + +Package=<4> +{{{ + Begin Project Dependency + Project_Dep_Name glew_static + End Project Dependency +}}} + +############################################################################### + +Project: "visualinfo"=.\visualinfo.dsp - Package Owner=<4> + +Package=<5> +{{{ +}}} + +Package=<4> +{{{ + Begin Project Dependency + Project_Dep_Name glew_static + End Project Dependency +}}} + +############################################################################### + +Global: + +Package=<5> +{{{ +}}} + +Package=<3> +{{{ +}}} + +############################################################################### + diff --git a/Externals/GLew/build/vc6/glew.rc b/Externals/GLew/build/vc6/glew.rc new file mode 100644 index 0000000000..a806f717ae --- /dev/null +++ b/Externals/GLew/build/vc6/glew.rc @@ -0,0 +1,77 @@ + +#include + +#ifdef GLEW_MX +# ifdef GLEW_STATIC +# ifdef _DEBUG +# define FILENAME "glew32mxsd.dll" +# else +# define FILENAME "glew32mxs.dll" +# endif +# else +# ifdef _DEBUG +# define FILENAME "glew32mxd.dll" +# else +# define FILENAME "glew32mx.dll" +# endif +# endif +#else +# ifdef GLEW_STATIC +# ifdef _DEBUG +# define FILENAME "glew32sd.dll" +# else +# define FILENAME "glew32s.dll" +# endif +# else +# ifdef _DEBUG +# define FILENAME "glew32d.dll" +# else +# define FILENAME "glew32.dll" +# endif +# endif +#endif + +///////////////////////////////////////////////////////////////////////////// +// +// Version +// +VS_VERSION_INFO VERSIONINFO +FILEVERSION 1, 5, 4, 0 +PRODUCTVERSION 1, 5, 4, 0 +FILEFLAGSMASK VS_FFI_FILEFLAGSMASK +#ifdef _DEBUG +FILEFLAGS VS_FF_DEBUG +#else +FILEFLAGS 0x0L +#endif +FILEOS VOS__WINDOWS32 +#ifdef GLEW_STATIC +FILETYPE VFT_STATIC_LIB +#else +FILETYPE VFT_DLL +#endif +FILESUBTYPE VFT2_UNKNOWN +BEGIN + BLOCK "StringFileInfo" + BEGIN + BLOCK "040904b0" + BEGIN + VALUE "Comments", "The OpenGL Extension Wrangler Library\r\nCopyright (C) 2002-2008, Milan Ikits \r\nCopyright (C) 2002-2008, Marcelo E. Magallon \r\nCopyright (C) 2002, Lev Povalahev\r\nAll rights reserved.\r\n\r\nRedistribution and use in source and binary forms, with or without \r\nmodification, are permitted provided that the following conditions are met:\r\n\r\n* Redistributions of source code must retain the above copyright notice, \r\n this list of conditions and the following disclaimer.\r\n* Redistributions in binary form must reproduce the above copyright notice, \r\n this list of conditions and the following disclaimer in the documentation \r\n and/or other materials provided with the distribution.\r\n* The name of the author may be used to endorse or promote products \r\n derived from this software without specific prior written permission.\r\n\r\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ''AS IS'' \r\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \r\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r\nARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \r\nLIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \r\nCONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \r\nSUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\r\nINTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\r\nCONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r\nARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\r\nTHE POSSIBILITY OF SUCH DAMAGE.\r\n\r\n\r\nMesa 3-D graphics library\r\n\r\nVersion: 7.0\r\n\r\nCopyright (C) 1999-2007 Brian Paul All Rights Reserved.\r\n\r\nPermission is hereby granted, free of charge, to any person obtaining a\r\ncopy of this software and associated documentation files (the ''Software''),\r\nto deal in the Software without restriction, including without limitation\r\nthe rights to use, copy, modify, merge, publish, distribute, sublicense,\r\nand/or sell copies of the Software, and to permit persons to whom the\r\nSoftware is furnished to do so, subject to the following conditions:\r\n\r\nThe above copyright notice and this permission notice shall be included\r\nin all copies or substantial portions of the Software.\r\n\r\nTHE SOFTWARE IS PROVIDED ''AS IS'', WITHOUT WARRANTY OF ANY KIND, EXPRESS\r\nOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL\r\nBRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN\r\nAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r\nCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r\n\r\n\r\nCopyright (c) 2007 The Khronos Group Inc.\r\n\r\nPermission is hereby granted, free of charge, to any person obtaining a\r\ncopy of this software and/or associated documentation files (the\r\n''Materials''), to deal in the Materials without restriction, including\r\nwithout limitation the rights to use, copy, modify, merge, publish,\r\ndistribute, sublicense, and/or sell copies of the Materials, and to\r\npermit persons to whom the Materials are furnished to do so, subject to\r\nthe following conditions:\r\n\r\nThe above copyright notice and this permission notice shall be included\r\nin all copies or substantial portions of the Materials.\r\n\r\nTHE MATERIALS ARE PROVIDED ''AS IS'', WITHOUT WARRANTY OF ANY KIND,\r\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\r\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\r\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\r\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\r\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\r\nMATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.\0" + VALUE "CompanyName", "\0" + VALUE "FileDescription", "The OpenGL Extension Wrangler Library\0" + VALUE "FileVersion", "1,5,4,0\0" + VALUE "InternalName", "GLEW\0" + VALUE "LegalCopyright", " 2002-2008 Milan Ikits & Marcelo Magallon\0" + VALUE "LegalTrademarks", "\0" + VALUE "OriginalFilename", FILENAME "\0" + VALUE "PrivateBuild", "\0" + VALUE "ProductName", "The OpenGL Extension Wrangler Library\0" + VALUE "ProductVersion", "1,5,4,0\0" + VALUE "SpecialBuild", "\0" + END + END + BLOCK "VarFileInfo" + BEGIN + VALUE "Translation", 0x409, 1200 + END +END diff --git a/Externals/GLew/build/vc6/glew_shared.dsp b/Externals/GLew/build/vc6/glew_shared.dsp new file mode 100644 index 0000000000..25278e0731 --- /dev/null +++ b/Externals/GLew/build/vc6/glew_shared.dsp @@ -0,0 +1,184 @@ +# Microsoft Developer Studio Project File - Name="glew_shared" - Package Owner=<4> +# Microsoft Developer Studio Generated Build File, Format Version 6.00 +# ** DO NOT EDIT ** + +# TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102 + +CFG=glew_shared - Win32 Debug MX +!MESSAGE This is not a valid makefile. To build this project using NMAKE, +!MESSAGE use the Export Makefile command and run +!MESSAGE +!MESSAGE NMAKE /f "glew_shared.mak". +!MESSAGE +!MESSAGE You can specify a configuration when running NMAKE +!MESSAGE by defining the macro CFG on the command line. For example: +!MESSAGE +!MESSAGE NMAKE /f "glew_shared.mak" CFG="glew_shared - Win32 Debug MX" +!MESSAGE +!MESSAGE Possible choices for configuration are: +!MESSAGE +!MESSAGE "glew_shared - Win32 Release" (based on "Win32 (x86) Dynamic-Link Library") +!MESSAGE "glew_shared - Win32 Debug" (based on "Win32 (x86) Dynamic-Link Library") +!MESSAGE "glew_shared - Win32 Debug MX" (based on "Win32 (x86) Dynamic-Link Library") +!MESSAGE "glew_shared - Win32 Release MX" (based on "Win32 (x86) Dynamic-Link Library") +!MESSAGE + +# Begin Project +# PROP AllowPerConfigDependencies 0 +# PROP Scc_ProjName "" +# PROP Scc_LocalPath "" +CPP=cl.exe +MTL=midl.exe +RSC=rc.exe + +!IF "$(CFG)" == "glew_shared - Win32 Release" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "Release" +# PROP BASE Intermediate_Dir "Release" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "shared/release" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "GLEW_EXPORTS" /YX /FD /c +# ADD CPP /nologo /W3 /O2 /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_BUILD" /YX /FD /c +# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32 +# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32 +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386 +# ADD LINK32 opengl32.lib /nologo /dll /pdb:none /machine:I386 /out:"../../bin/glew32.dll" /ignore:4089 +# ADD LINK32 /base:0x62AA0000 + +!ELSEIF "$(CFG)" == "glew_shared - Win32 Debug" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "Debug" +# PROP BASE Intermediate_Dir "Debug" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "shared/debug" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "GLEW_EXPORTS" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_BUILD" /YX /FD /GZ /c +# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32 +# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32 +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept +# ADD LINK32 opengl32.lib /nologo /dll /incremental:no /debug /machine:I386 /out:"../../bin/glew32d.dll" /pdbtype:sept +# SUBTRACT LINK32 /pdb:none +# ADD LINK32 /base:0x62AA0000 + +!ELSEIF "$(CFG)" == "glew_shared - Win32 Debug MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "glew_shared___Win32_Debug_MX" +# PROP BASE Intermediate_Dir "glew_shared___Win32_Debug_MX" +# PROP BASE Ignore_Export_Lib 0 +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "shared/debug-mx" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /MDd /W3 /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_BUILD" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_MX" /D "GLEW_BUILD" /YX /FD /GZ /c +# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32 +# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32 +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" /d "GLEW_MX" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 opengl32.lib /nologo /dll /incremental:no /pdb:"../../lib/glew32d.pdb" /debug /machine:I386 /out:"../../lib/glew32d.dll" /implib:"../../lib/glew32d.lib" /pdbtype:sept +# SUBTRACT BASE LINK32 /pdb:none +# ADD LINK32 opengl32.lib /nologo /dll /incremental:no /debug /machine:I386 /out:"../../bin/glew32mxd.dll" /pdbtype:sept +# SUBTRACT LINK32 /pdb:none +# ADD LINK32 /base:0x62AA0000 + +!ELSEIF "$(CFG)" == "glew_shared - Win32 Release MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "glew_shared___Win32_Release_MX" +# PROP BASE Intermediate_Dir "glew_shared___Win32_Release_MX" +# PROP BASE Ignore_Export_Lib 0 +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "shared/release-mx" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /O2 /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_BUILD" /YX /FD /c +# ADD CPP /nologo /W3 /O2 /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_MX" /D "GLEW_BUILD" /YX /FD /c +# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32 +# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32 +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" /d "GLEW_MX" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 opengl32.lib /nologo /dll /pdb:none /machine:I386 /out:"../../lib/glew32.dll" /implib:"../../lib/glew32.lib" /ignore:4089 +# ADD LINK32 opengl32.lib /nologo /dll /pdb:none /machine:I386 /out:"../../bin/glew32mx.dll" /ignore:4089 +# ADD LINK32 /base:0x62AA0000 + +!ENDIF + +# Begin Target + +# Name "glew_shared - Win32 Release" +# Name "glew_shared - Win32 Debug" +# Name "glew_shared - Win32 Debug MX" +# Name "glew_shared - Win32 Release MX" +# Begin Group "Source Files" + +# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat" +# Begin Source File + +SOURCE=..\..\src\glew.c +# End Source File +# End Group +# Begin Group "Header Files" + +# PROP Default_Filter "h;hpp;hxx;hm;inl" +# Begin Source File + +SOURCE=..\..\include\GL\glew.h +# End Source File +# Begin Source File + +SOURCE=..\..\include\GL\wglew.h +# End Source File +# End Group +# Begin Group "Resource Files" + +# PROP Default_Filter "" +# Begin Source File + +SOURCE=.\glew.rc +# End Source File +# End Group +# End Target +# End Project diff --git a/Externals/GLew/build/vc6/glew_static.dsp b/Externals/GLew/build/vc6/glew_static.dsp new file mode 100644 index 0000000000..5bc2851ef0 --- /dev/null +++ b/Externals/GLew/build/vc6/glew_static.dsp @@ -0,0 +1,162 @@ +# Microsoft Developer Studio Project File - Name="glew_static" - Package Owner=<4> +# Microsoft Developer Studio Generated Build File, Format Version 6.00 +# ** DO NOT EDIT ** + +# TARGTYPE "Win32 (x86) Static Library" 0x0104 + +CFG=glew_static - Win32 Debug MX +!MESSAGE This is not a valid makefile. To build this project using NMAKE, +!MESSAGE use the Export Makefile command and run +!MESSAGE +!MESSAGE NMAKE /f "glew_static.mak". +!MESSAGE +!MESSAGE You can specify a configuration when running NMAKE +!MESSAGE by defining the macro CFG on the command line. For example: +!MESSAGE +!MESSAGE NMAKE /f "glew_static.mak" CFG="glew_static - Win32 Debug MX" +!MESSAGE +!MESSAGE Possible choices for configuration are: +!MESSAGE +!MESSAGE "glew_static - Win32 Release" (based on "Win32 (x86) Static Library") +!MESSAGE "glew_static - Win32 Debug" (based on "Win32 (x86) Static Library") +!MESSAGE "glew_static - Win32 Debug MX" (based on "Win32 (x86) Static Library") +!MESSAGE "glew_static - Win32 Release MX" (based on "Win32 (x86) Static Library") +!MESSAGE + +# Begin Project +# PROP AllowPerConfigDependencies 0 +# PROP Scc_ProjName "" +# PROP Scc_LocalPath "" +CPP=cl.exe +RSC=rc.exe + +!IF "$(CFG)" == "glew_static - Win32 Release" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "Release" +# PROP BASE Intermediate_Dir "Release" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "static/release" +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /YX /FD /c +# ADD CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /YX /FD /c +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" /d "GLEW_STATIC" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LIB32=link.exe -lib +# ADD BASE LIB32 /nologo +# ADD LIB32 /nologo /out:"../../lib/glew32s.lib" + +!ELSEIF "$(CFG)" == "glew_static - Win32 Debug" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "Debug" +# PROP BASE Intermediate_Dir "Debug" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "static/debug" +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /YX /FD /GZ /c +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" /d "GLEW_STATIC" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LIB32=link.exe -lib +# ADD BASE LIB32 /nologo +# ADD LIB32 /nologo /out:"../../lib/glew32sd.lib" + +!ELSEIF "$(CFG)" == "glew_static - Win32 Debug MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "glew_static___Win32_Debug_MX" +# PROP BASE Intermediate_Dir "glew_static___Win32_Debug_MX" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "static/debug-mx" +# PROP Target_Dir "" +# ADD BASE CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_MX" /D "GLEW_STATIC" /YX /FD /GZ /c +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" /d "GLEW_MX" /d "GLEW_STATIC" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LIB32=link.exe -lib +# ADD BASE LIB32 /nologo /out:"../../lib/glew32sd.lib" +# ADD LIB32 /nologo /out:"../../lib/glew32mxsd.lib" + +!ELSEIF "$(CFG)" == "glew_static - Win32 Release MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "glew_static___Win32_Release_MX" +# PROP BASE Intermediate_Dir "glew_static___Win32_Release_MX" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../lib" +# PROP Intermediate_Dir "static/release-mx" +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /YX /FD /c +# ADD CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRALEAN" /D "GLEW_MX" /D "GLEW_STATIC" /YX /FD /c +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" /d "GLEW_MX" /d "GLEW_STATIC" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LIB32=link.exe -lib +# ADD BASE LIB32 /nologo /out:"../../lib/glew32s.lib" +# ADD LIB32 /nologo /out:"../../lib/glew32mxs.lib" + +!ENDIF + +# Begin Target + +# Name "glew_static - Win32 Release" +# Name "glew_static - Win32 Debug" +# Name "glew_static - Win32 Debug MX" +# Name "glew_static - Win32 Release MX" +# Begin Group "Source Files" + +# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat" +# Begin Source File + +SOURCE=..\..\src\glew.c +# End Source File +# End Group +# Begin Group "Header Files" + +# PROP Default_Filter "h;hpp;hxx;hm;inl" +# Begin Source File + +SOURCE=..\..\include\GL\glew.h +# End Source File +# Begin Source File + +SOURCE=..\..\include\GL\wglew.h +# End Source File +# End Group +# Begin Group "Resources" + +# PROP Default_Filter "" +# Begin Source File + +SOURCE=.\glew.rc +# End Source File +# End Group +# End Target +# End Project diff --git a/Externals/GLew/build/vc6/glewinfo.dsp b/Externals/GLew/build/vc6/glewinfo.dsp new file mode 100644 index 0000000000..f75c1fc395 --- /dev/null +++ b/Externals/GLew/build/vc6/glewinfo.dsp @@ -0,0 +1,159 @@ +# Microsoft Developer Studio Project File - Name="glewinfo" - Package Owner=<4> +# Microsoft Developer Studio Generated Build File, Format Version 6.00 +# ** DO NOT EDIT ** + +# TARGTYPE "Win32 (x86) Console Application" 0x0103 + +CFG=glewinfo - Win32 Debug MX +!MESSAGE This is not a valid makefile. To build this project using NMAKE, +!MESSAGE use the Export Makefile command and run +!MESSAGE +!MESSAGE NMAKE /f "glewinfo.mak". +!MESSAGE +!MESSAGE You can specify a configuration when running NMAKE +!MESSAGE by defining the macro CFG on the command line. For example: +!MESSAGE +!MESSAGE NMAKE /f "glewinfo.mak" CFG="glewinfo - Win32 Debug MX" +!MESSAGE +!MESSAGE Possible choices for configuration are: +!MESSAGE +!MESSAGE "glewinfo - Win32 Release" (based on "Win32 (x86) Console Application") +!MESSAGE "glewinfo - Win32 Debug" (based on "Win32 (x86) Console Application") +!MESSAGE "glewinfo - Win32 Debug MX" (based on "Win32 (x86) Console Application") +!MESSAGE "glewinfo - Win32 Release MX" (based on "Win32 (x86) Console Application") +!MESSAGE + +# Begin Project +# PROP AllowPerConfigDependencies 0 +# PROP Scc_ProjName "" +# PROP Scc_LocalPath "" +CPP=cl.exe +RSC=rc.exe + +!IF "$(CFG)" == "glewinfo - Win32 Release" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "Release" +# PROP BASE Intermediate_Dir "Release" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/release" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /YX /FD /c +# ADD CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /c +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /machine:I386 +# ADD LINK32 ../../lib/glew32s.lib opengl32.lib gdi32.lib user32.lib /nologo /subsystem:console /machine:I386 + +!ELSEIF "$(CFG)" == "glewinfo - Win32 Debug" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "Debug" +# PROP BASE Intermediate_Dir "Debug" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/debug" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRA_LEAN" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /GZ /c +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept +# ADD LINK32 ../../lib/glew32sd.lib opengl32.lib gdi32.lib user32.lib /nologo /subsystem:console /incremental:no /pdb:"static/debug/glewinfod.pdb" /debug /machine:I386 /out:"../../bin/glewinfod.exe" /pdbtype:sept +# SUBTRACT LINK32 /pdb:none + +!ELSEIF "$(CFG)" == "glewinfo - Win32 Debug MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "glewinfo___Win32_Debug_MX" +# PROP BASE Intermediate_Dir "glewinfo___Win32_Debug_MX" +# PROP BASE Ignore_Export_Lib 0 +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/debug-mx" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRA_LEAN" /D "GLEW_STATIC" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRA_LEAN" /D "GLEW_MX" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /GZ /c +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" /d "GLEW_MX" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 ../../lib/glew32sd.lib opengl32.lib gdi32.lib user32.lib /nologo /subsystem:console /incremental:no /pdb:"static/debug/glewinfod.pdb" /debug /machine:I386 /out:"../../bin/glewinfod.exe" /pdbtype:sept +# SUBTRACT BASE LINK32 /pdb:none +# ADD LINK32 ../../lib/glew32mxsd.lib opengl32.lib gdi32.lib user32.lib /nologo /subsystem:console /incremental:no /pdb:"static/debug/glewinfod.pdb" /debug /machine:I386 /out:"../../bin/glewinfo-mxd.exe" /pdbtype:sept +# SUBTRACT LINK32 /pdb:none + +!ELSEIF "$(CFG)" == "glewinfo - Win32 Release MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "glewinfo___Win32_Release_MX" +# PROP BASE Intermediate_Dir "glewinfo___Win32_Release_MX" +# PROP BASE Ignore_Export_Lib 0 +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/release-mx" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /YX /FD /c +# ADD CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_MX" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /c +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" /d "GLEW_MX" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 ../../lib/glew32s.lib opengl32.lib gdi32.lib user32.lib /nologo /subsystem:console /machine:I386 +# ADD LINK32 ../../lib/glew32mxs.lib opengl32.lib gdi32.lib user32.lib /nologo /subsystem:console /machine:I386 /out:"../../bin/glewinfo-mx.exe" + +!ENDIF + +# Begin Target + +# Name "glewinfo - Win32 Release" +# Name "glewinfo - Win32 Debug" +# Name "glewinfo - Win32 Debug MX" +# Name "glewinfo - Win32 Release MX" +# Begin Group "Source Files" + +# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat" +# Begin Source File + +SOURCE=..\..\src\glewinfo.c +# End Source File +# End Group +# Begin Group "Resource Files" + +# PROP Default_Filter "" +# Begin Source File + +SOURCE=.\glewinfo.rc +# End Source File +# End Group +# End Target +# End Project diff --git a/Externals/GLew/build/vc6/glewinfo.rc b/Externals/GLew/build/vc6/glewinfo.rc new file mode 100644 index 0000000000..e3d3956c92 --- /dev/null +++ b/Externals/GLew/build/vc6/glewinfo.rc @@ -0,0 +1,57 @@ + +#include + +#ifdef GLEW_MX +# ifdef _DEBUG +# define FILENAME "glewinfo-mxd.exe" +# else +# define FILENAME "glewinfo-mx.exe" +# endif +#else +# ifdef _DEBUG +# define FILENAME "glewinfod.exe" +# else +# define FILENAME "glewinfo.exe" +# endif +#endif + +///////////////////////////////////////////////////////////////////////////// +// +// Version +// +VS_VERSION_INFO VERSIONINFO +FILEVERSION 1, 5, 4, 0 +PRODUCTVERSION 1, 5, 4, 0 +FILEFLAGSMASK VS_FFI_FILEFLAGSMASK +#ifdef _DEBUG +FILEFLAGS VS_FF_DEBUG +#else +FILEFLAGS 0x0L +#endif +FILEOS VOS__WINDOWS32 +FILETYPE VFT_APP +FILESUBTYPE VFT2_UNKNOWN +BEGIN + BLOCK "StringFileInfo" + BEGIN + BLOCK "040904b0" + BEGIN + VALUE "Comments", "The OpenGL Extension Wrangler Library\r\nCopyright (C) 2002-2008, Milan Ikits \r\nCopyright (C) 2002-2008, Marcelo E. Magallon \r\nCopyright (C) 2002, Lev Povalahev\r\nAll rights reserved.\r\n \r\nRedistribution and use in source and binary forms, with or without \r\nmodification, are permitted provided that the following conditions are met:\r\n\r\n* Redistributions of source code must retain the above copyright notice, \r\n this list of conditions and the following disclaimer.\r\n* Redistributions in binary form must reproduce the above copyright notice, \r\n this list of conditions and the following disclaimer in the documentation \r\n and/or other materials provided with the distribution.\r\n* The name of the author may be used to endorse or promote products \r\n derived from this software without specific prior written permission.\r\n\r\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' \r\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \r\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r\nARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \r\nLIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \r\nCONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \r\nSUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\r\nINTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\r\nCONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r\nARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\r\nTHE POSSIBILITY OF SUCH DAMAGE.\r\n\r\nLicense Applicability. Except to the extent portions of this file are\r\nmade subject to an alternative license as permitted in the SGI Free\r\nSoftware License B, Version 1.1 (the 'License'), the contents of this\r\nfile are subject only to the provisions of the License. You may not use\r\nthis file except in compliance with the License. You may obtain a copy\r\nof the License at Silicon Graphics, Inc., attn: Legal Services, 1600\r\nAmphitheatre Parkway, Mountain View, CA 94043-1351, or at:\r\n\r\nhttp://oss.sgi.com/projects/FreeB\r\n\r\nNote that, as provided in the License, the Software is distributed on an\r\n'AS IS' basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS\r\nDISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND\r\nCONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A\r\nPARTICULAR PURPOSE, AND NON-INFRINGEMENT.\r\n\r\nOriginal Code. The Original Code is: OpenGL Sample Implementation,\r\nVersion 1.2.1, released January 26, 2000, developed by Silicon Graphics,\r\nInc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.\r\nCopyright in any portions created by third parties is as indicated\r\nelsewhere herein. All Rights Reserved.\r\n\r\nAdditional Notice Provisions: This software was created using the\r\nOpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has\r\nnot been independently verified as being compliant with the OpenGL(R)\r\nversion 1.2.1 Specification.\0" + VALUE "CompanyName", "\0" + VALUE "FileDescription", "Utility for verifying extension entry points\0" + VALUE "FileVersion", "1,5,4,0\0" + VALUE "InternalName", "glewinfo\0" + VALUE "LegalCopyright", " 2002-2008 Milan Ikits & Marcelo Magallon\0" + VALUE "LegalTrademarks", "\0" + VALUE "OriginalFilename", FILENAME "\0" + VALUE "PrivateBuild", "\0" + VALUE "ProductName", "The OpenGL Extension Wrangler Library\0" + VALUE "ProductVersion", "1,5,4,0\0" + VALUE "SpecialBuild", "\0" + END + END + BLOCK "VarFileInfo" + BEGIN + VALUE "Translation", 0x409, 1200 + END +END diff --git a/Externals/GLew/build/vc6/visualinfo.dsp b/Externals/GLew/build/vc6/visualinfo.dsp new file mode 100644 index 0000000000..7a61ee9f88 --- /dev/null +++ b/Externals/GLew/build/vc6/visualinfo.dsp @@ -0,0 +1,159 @@ +# Microsoft Developer Studio Project File - Name="visualinfo" - Package Owner=<4> +# Microsoft Developer Studio Generated Build File, Format Version 6.00 +# ** DO NOT EDIT ** + +# TARGTYPE "Win32 (x86) Console Application" 0x0103 + +CFG=visualinfo - Win32 Debug MX +!MESSAGE This is not a valid makefile. To build this project using NMAKE, +!MESSAGE use the Export Makefile command and run +!MESSAGE +!MESSAGE NMAKE /f "visualinfo.mak". +!MESSAGE +!MESSAGE You can specify a configuration when running NMAKE +!MESSAGE by defining the macro CFG on the command line. For example: +!MESSAGE +!MESSAGE NMAKE /f "visualinfo.mak" CFG="visualinfo - Win32 Debug MX" +!MESSAGE +!MESSAGE Possible choices for configuration are: +!MESSAGE +!MESSAGE "visualinfo - Win32 Release" (based on "Win32 (x86) Console Application") +!MESSAGE "visualinfo - Win32 Debug" (based on "Win32 (x86) Console Application") +!MESSAGE "visualinfo - Win32 Debug MX" (based on "Win32 (x86) Console Application") +!MESSAGE "visualinfo - Win32 Release MX" (based on "Win32 (x86) Console Application") +!MESSAGE + +# Begin Project +# PROP AllowPerConfigDependencies 0 +# PROP Scc_ProjName "" +# PROP Scc_LocalPath "" +CPP=cl.exe +RSC=rc.exe + +!IF "$(CFG)" == "visualinfo - Win32 Release" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "Release" +# PROP BASE Intermediate_Dir "Release" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/release" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /YX /FD /c +# ADD CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /c +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /machine:I386 +# ADD LINK32 ../../lib/glew32s.lib glu32.lib opengl32.lib gdi32.lib user32.lib kernel32.lib /nologo /subsystem:console /machine:I386 + +!ELSEIF "$(CFG)" == "visualinfo - Win32 Debug" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "Debug" +# PROP BASE Intermediate_Dir "Debug" +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/debug" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRA_LEAN" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /GZ /c +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept +# ADD LINK32 ../../lib/glew32sd.lib glu32.lib opengl32.lib gdi32.lib user32.lib kernel32.lib /nologo /subsystem:console /incremental:no /pdb:"static/debug/visualinfod.pdb" /debug /machine:I386 /out:"../../bin/visualinfod.exe" /pdbtype:sept +# SUBTRACT LINK32 /pdb:none + +!ELSEIF "$(CFG)" == "visualinfo - Win32 Debug MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 1 +# PROP BASE Output_Dir "visualinfo___Win32_Debug_MX" +# PROP BASE Intermediate_Dir "visualinfo___Win32_Debug_MX" +# PROP BASE Ignore_Export_Lib 0 +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 1 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/debug-mx" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRA_LEAN" /D "GLEW_STATIC" /YX /FD /GZ /c +# ADD CPP /nologo /MDd /W3 /GX /Zi /Od /I "../../include" /D "WIN32" /D "WIN32_LEAN_AND_MEAN" /D "VC_EXTRA_LEAN" /D "GLEW_MX" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /GZ /c +# ADD BASE RSC /l 0x409 /d "_DEBUG" +# ADD RSC /l 0x409 /d "_DEBUG" /d "GLEW_MX" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 ../../lib/glew32sd.lib glu32.lib opengl32.lib gdi32.lib user32.lib kernel32.lib /nologo /subsystem:console /incremental:no /pdb:"static/debug/visualinfod.pdb" /debug /machine:I386 /out:"../../bin/visualinfod.exe" /pdbtype:sept +# SUBTRACT BASE LINK32 /pdb:none +# ADD LINK32 ../../lib/glew32mxsd.lib glu32.lib opengl32.lib gdi32.lib user32.lib kernel32.lib /nologo /subsystem:console /incremental:no /pdb:"static/debug/visualinfod.pdb" /debug /machine:I386 /out:"../../bin/visualinfo-mxd.exe" /pdbtype:sept +# SUBTRACT LINK32 /pdb:none + +!ELSEIF "$(CFG)" == "visualinfo - Win32 Release MX" + +# PROP BASE Use_MFC 0 +# PROP BASE Use_Debug_Libraries 0 +# PROP BASE Output_Dir "visualinfo___Win32_Release_MX" +# PROP BASE Intermediate_Dir "visualinfo___Win32_Release_MX" +# PROP BASE Ignore_Export_Lib 0 +# PROP BASE Target_Dir "" +# PROP Use_MFC 0 +# PROP Use_Debug_Libraries 0 +# PROP Output_Dir "../../bin" +# PROP Intermediate_Dir "static/release-mx" +# PROP Ignore_Export_Lib 0 +# PROP Target_Dir "" +# ADD BASE CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_STATIC" /YX /FD /c +# ADD CPP /nologo /W3 /GX /O2 /I "../../include" /D "WIN32" /D "WIN32_MEAN_AND_LEAN" /D "VC_EXTRALEAN" /D "GLEW_MX" /D "GLEW_STATIC" /D "_CRT_SECURE_NO_WARNINGS" /YX /FD /c +# ADD BASE RSC /l 0x409 /d "NDEBUG" +# ADD RSC /l 0x409 /d "NDEBUG" /d "GLEW_MX" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LINK32=link.exe +# ADD BASE LINK32 ../../lib/glew32s.lib glu32.lib opengl32.lib gdi32.lib user32.lib kernel32.lib /nologo /subsystem:console /machine:I386 +# ADD LINK32 ../../lib/glew32mxs.lib glu32.lib opengl32.lib gdi32.lib user32.lib kernel32.lib /nologo /subsystem:console /machine:I386 /out:"../../bin/visualinfo-mx.exe" + +!ENDIF + +# Begin Target + +# Name "visualinfo - Win32 Release" +# Name "visualinfo - Win32 Debug" +# Name "visualinfo - Win32 Debug MX" +# Name "visualinfo - Win32 Release MX" +# Begin Group "Source Files" + +# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat" +# Begin Source File + +SOURCE=..\..\src\visualinfo.c +# End Source File +# End Group +# Begin Group "Resource Files" + +# PROP Default_Filter "" +# Begin Source File + +SOURCE=.\visualinfo.rc +# End Source File +# End Group +# End Target +# End Project diff --git a/Externals/GLew/build/vc6/visualinfo.rc b/Externals/GLew/build/vc6/visualinfo.rc new file mode 100644 index 0000000000..873ce78859 --- /dev/null +++ b/Externals/GLew/build/vc6/visualinfo.rc @@ -0,0 +1,57 @@ + +#include + +#ifdef GLEW_MX +# ifdef _DEBUG +# define FILENAME "visualinfo-mxd.exe" +# else +# define FILENAME "visualinfo-mx.exe" +# endif +#else +# ifdef _DEBUG +# define FILENAME "visualinfod.exe" +# else +# define FILENAME "visualinfo.exe" +# endif +#endif + +///////////////////////////////////////////////////////////////////////////// +// +// Version +// +VS_VERSION_INFO VERSIONINFO +FILEVERSION 1, 5, 4, 0 +PRODUCTVERSION 1, 5, 4, 0 +FILEFLAGSMASK VS_FFI_FILEFLAGSMASK +#ifdef _DEBUG +FILEFLAGS VS_FF_DEBUG +#else +FILEFLAGS 0x0L +#endif +FILEOS VOS__WINDOWS32 +FILETYPE VFT_APP +FILESUBTYPE VFT2_UNKNOWN +BEGIN + BLOCK "StringFileInfo" + BEGIN + BLOCK "040904b0" + BEGIN + VALUE "Comments", "The OpenGL Extension Wrangler Library\r\nCopyright (C) 2002-2008, Milan Ikits \r\nCopyright (C) 2002-2008, Marcelo E. Magallon \r\nCopyright (C) 2002, Lev Povalahev\r\nAll rights reserved.\r\n \r\nRedistribution and use in source and binary forms, with or without \r\nmodification, are permitted provided that the following conditions are met:\r\n\r\n* Redistributions of source code must retain the above copyright notice, \r\n this list of conditions and the following disclaimer.\r\n* Redistributions in binary form must reproduce the above copyright notice, \r\n this list of conditions and the following disclaimer in the documentation \r\n and/or other materials provided with the distribution.\r\n* The name of the author may be used to endorse or promote products \r\n derived from this software without specific prior written permission.\r\n\r\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' \r\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \r\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r\nARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \r\nLIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \r\nCONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \r\nSUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\r\nINTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\r\nCONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r\nARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\r\nTHE POSSIBILITY OF SUCH DAMAGE.\r\n\r\nLicense Applicability. Except to the extent portions of this file are\r\nmade subject to an alternative license as permitted in the SGI Free\r\nSoftware License B, Version 1.1 (the 'License'), the contents of this\r\nfile are subject only to the provisions of the License. You may not use\r\nthis file except in compliance with the License. You may obtain a copy\r\nof the License at Silicon Graphics, Inc., attn: Legal Services, 1600\r\nAmphitheatre Parkway, Mountain View, CA 94043-1351, or at:\r\n\r\nhttp://oss.sgi.com/projects/FreeB\r\n\r\nNote that, as provided in the License, the Software is distributed on an\r\n'AS IS' basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS\r\nDISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND\r\nCONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A\r\nPARTICULAR PURPOSE, AND NON-INFRINGEMENT.\r\n\r\nOriginal Code. The Original Code is: OpenGL Sample Implementation,\r\nVersion 1.2.1, released January 26, 2000, developed by Silicon Graphics,\r\nInc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.\r\nCopyright in any portions created by third parties is as indicated\r\nelsewhere herein. All Rights Reserved.\r\n\r\nAdditional Notice Provisions: This software was created using the\r\nOpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has\r\nnot been independently verified as being compliant with the OpenGL(R)\r\nversion 1.2.1 Specification.\0" + VALUE "CompanyName", "\0" + VALUE "FileDescription", "Utility for listing pixelformat capabilities\0" + VALUE "FileVersion", "1,5,4,0\0" + VALUE "InternalName", "visualinfo\0" + VALUE "LegalCopyright", " 2002-2008 Milan Ikits & Marcelo Magallon\0" + VALUE "LegalTrademarks", "\0" + VALUE "OriginalFilename", FILENAME "\0" + VALUE "PrivateBuild", "\0" + VALUE "ProductName", "The OpenGL Extension Wrangler Library\0" + VALUE "ProductVersion", "1,5,4,0\0" + VALUE "SpecialBuild", "\0" + END + END + BLOCK "VarFileInfo" + BEGIN + VALUE "Translation", 0x409, 1200 + END +END diff --git a/Externals/GLew/config/Makefile.cygming b/Externals/GLew/config/Makefile.cygming new file mode 100644 index 0000000000..d1d6062dbf --- /dev/null +++ b/Externals/GLew/config/Makefile.cygming @@ -0,0 +1,22 @@ +NAME = glew32 +GLEW_DEST = /usr +BINDIR = /usr/bin +LIBDIR = /usr/lib/mingw +INCDIR = /usr/include/mingw/GL +CC = gcc -mno-cygwin +# use gcc for linking, with ld it does not work +LD = gcc -mno-cygwin +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +CFLAGS.SO = -DGLEW_BUILD +LDFLAGS.SO = -shared -Wl,-soname,$(LIB.SONAME) -Wl,--out-implib,lib/$(LIB.DEVLNK) +LDFLAGS.GL = -lglu32 -lopengl32 -lgdi32 -luser32 -lkernel32 +LDFLAGS.EXTRA = -L$(LIBDIR) +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = .exe +LIB.SONAME = lib$(NAME).dll +LIB.DEVLNK = lib$(NAME).dll.a # for mingw this is the dll import lib +LIB.SHARED = $(NAME).dll +LIB.STATIC = lib$(NAME).a # the static lib will be broken (see CFLAGS.SO) diff --git a/Externals/GLew/config/Makefile.cygwin b/Externals/GLew/config/Makefile.cygwin new file mode 100644 index 0000000000..c724e42270 --- /dev/null +++ b/Externals/GLew/config/Makefile.cygwin @@ -0,0 +1,21 @@ +NAME = GLEW +GLEW_DEST ?= /usr/X11R6 +CC = cc +# use gcc for linking, with ld it does not work +LD = cc +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +LDFLAGS.SO = -shared -Wl,-soname=$(LIB.SONAME) +LDFLAGS.EXTRA = -L/usr/X11R6/lib +LIBDIR = $(GLEW_DEST)/lib +LDFLAGS.GL = -lXmu -lXi -lGLU -lGL -lXext -lX11 +LDFLAGS.STATIC = -Wl,-Bstatic +LDFLAGS.DYNAMIC = -Wl,-Bdynamic +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = +LIB.SONAME = lib$(NAME).so.$(SO_MAJOR) +LIB.DEVLNK = lib$(NAME).so +LIB.SHARED = lib$(NAME).so.$(SO_VERSION) +LIB.STATIC = lib$(NAME).a diff --git a/Externals/GLew/config/Makefile.darwin b/Externals/GLew/config/Makefile.darwin new file mode 100644 index 0000000000..a80acac70d --- /dev/null +++ b/Externals/GLew/config/Makefile.darwin @@ -0,0 +1,26 @@ +NAME = $(GLEW_NAME) +CC = cc +LD = cc +CFLAGS.EXTRA = -no-cpp-precomp -dynamic -fno-common +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA += -DGLEW_MX +endif +PICFLAG = -fPIC +LDFLAGS.SO = -dynamiclib -install_name $(GLEW_DEST)/lib/$(LIB.SHARED) +LDFLAGS.EXTRA = +ifneq (undefined, $(origin GLEW_APPLE_GLX)) +CFLAGS.EXTRA += -I/usr/X11R6/include -D'GLEW_APPLE_GLX' +LDFLAGS.GL = -L/usr/X11R6/lib -lXmu -lXi -lGLU -lGL -lXext -lX11 +else +LDFLAGS.GL = -framework AGL -framework OpenGL +endif +LDFLAGS.STATIC = +LDFLAGS.DYNAMIC = +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = +LIB.SONAME = lib$(NAME).$(SO_MAJOR).dylib +LIB.DEVLNK = lib$(NAME).dylib +LIB.SHARED = lib$(NAME).$(SO_VERSION).dylib +LIB.STATIC = lib$(NAME).a +SHARED_OBJ_EXT = pic_o diff --git a/Externals/GLew/config/Makefile.freebsd b/Externals/GLew/config/Makefile.freebsd new file mode 100644 index 0000000000..3bbc545882 --- /dev/null +++ b/Externals/GLew/config/Makefile.freebsd @@ -0,0 +1,20 @@ +NAME = $(GLEW_NAME) +CC = cc +LD = ld +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +LDFLAGS.SO = -shared -soname $(LIB.SONAME) +LDFLAGS.EXTRA = -L/usr/X11R6/lib +LDFLAGS.GL = -lXmu -lXi -lGLU -lGL -lXext -lX11 +LDFLAGS.STATIC = -Wl,-Bstatic +LDFLAGS.DYNAMIC = -Wl,-Bdynamic +CFLAGS.EXTRA += -I/usr/X11R6/include +NAME = GLEW +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = +LIB.SONAME = lib$(NAME).so.$(SO_MAJOR) +LIB.DEVLNK = lib$(NAME).so +LIB.SHARED = lib$(NAME).so.$(SO_VERSION) +LIB.STATIC = lib$(NAME).a diff --git a/Externals/GLew/config/Makefile.gnu b/Externals/GLew/config/Makefile.gnu new file mode 100644 index 0000000000..69846ab710 --- /dev/null +++ b/Externals/GLew/config/Makefile.gnu @@ -0,0 +1,21 @@ +NAME = $(GLEW_NAME) +CC = cc +LD = cc +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +PICFLAG = -fPIC +LDFLAGS.SO = -shared -Wl,-soname=$(LIB.SONAME) +LDFLAGS.EXTRA = -L/usr/X11R6/lib +LDFLAGS.GL = -lXmu -lXi -lGLU -lGL -lXext -lX11 +LDFLAGS.STATIC = -Wl,-Bstatic +LDFLAGS.DYNAMIC = -Wl,-Bdynamic +NAME = GLEW +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = +LIB.SONAME = lib$(NAME).so.$(SO_MAJOR) +LIB.DEVLNK = lib$(NAME).so +LIB.SHARED = lib$(NAME).so.$(SO_VERSION) +LIB.STATIC = lib$(NAME).a +SHARED_OBJ_EXT = pic_o diff --git a/Externals/GLew/config/Makefile.irix b/Externals/GLew/config/Makefile.irix new file mode 100644 index 0000000000..c618224011 --- /dev/null +++ b/Externals/GLew/config/Makefile.irix @@ -0,0 +1,20 @@ +NAME = $(GLEW_NAME) +CC = cc +LD = ld +ABI = -64# -n32 +CC += $(ABI) +LD += $(ABI) +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +LDFLAGS.SO = -shared -soname $(LIB.SONAME) +LDFLAGS.EXTRA = +LDFLAGS.GL = -lGLU -lGL -lXext -lX11 +NAME = GLEW +WARN = -fullwarn -woff 1110,1498 +POPT = -O2 -OPT:Olimit=0 +BIN.SUFFIX = +LIB.SONAME = lib$(NAME).so.$(SO_MAJOR) +LIB.DEVLNK = lib$(NAME).so +LIB.SHARED = lib$(NAME).so.$(SO_VERSION) +LIB.STATIC = lib$(NAME).a diff --git a/Externals/GLew/config/Makefile.kfreebsd b/Externals/GLew/config/Makefile.kfreebsd new file mode 100644 index 0000000000..ace80ff814 --- /dev/null +++ b/Externals/GLew/config/Makefile.kfreebsd @@ -0,0 +1,21 @@ +NAME = $(GLEW_NAME) +CC = cc +LD = cc +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +PICFLAG = -fPIC +LDFLAGS.SO = -shared -Wl,-soname $(LIB.SONAME) +LDFLAGS.EXTRA = -L/usr/X11R6/lib +LDFLAGS.GL = -lXmu -lXi -lGLU -lGL -lXext -lX11 +LDFLAGS.STATIC = -Wl,-Bstatic +LDFLAGS.DYNAMIC = -Wl,-Bdynamic +NAME = GLEW +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = +LIB.SONAME = lib$(NAME).so.$(SO_MAJOR) +LIB.DEVLNK = lib$(NAME).so +LIB.SHARED = lib$(NAME).so.$(SO_VERSION) +LIB.STATIC = lib$(NAME).a +SHARED_OBJ_EXT = pic_o diff --git a/Externals/GLew/config/Makefile.linux b/Externals/GLew/config/Makefile.linux new file mode 100644 index 0000000000..fd8a2d1cb0 --- /dev/null +++ b/Externals/GLew/config/Makefile.linux @@ -0,0 +1,28 @@ +NAME = $(GLEW_NAME) +CC = cc +LD = cc +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +PICFLAG = -fPIC +LDFLAGS.SO = -shared -Wl,-soname=$(LIB.SONAME) +M_ARCH ?= $(shell uname -m) +ifeq (x86_64,${M_ARCH}) +LDFLAGS.EXTRA = -L/usr/X11R6/lib64 +LIBDIR = $(GLEW_DEST)/lib64 +else +LDFLAGS.EXTRA = -L/usr/X11R6/lib +LIBDIR = $(GLEW_DEST)/lib +endif +LDFLAGS.GL = -lXmu -lXi -lGLU -lGL -lXext -lX11 +LDFLAGS.STATIC = -Wl,-Bstatic +LDFLAGS.DYNAMIC = -Wl,-Bdynamic +NAME = GLEW +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = +LIB.SONAME = lib$(NAME).so.$(SO_MAJOR) +LIB.DEVLNK = lib$(NAME).so +LIB.SHARED = lib$(NAME).so.$(SO_VERSION) +LIB.STATIC = lib$(NAME).a +SHARED_OBJ_EXT = pic_o diff --git a/Externals/GLew/config/Makefile.mingw b/Externals/GLew/config/Makefile.mingw new file mode 100644 index 0000000000..6b98a44f95 --- /dev/null +++ b/Externals/GLew/config/Makefile.mingw @@ -0,0 +1,19 @@ +NAME = glew32 +CC = gcc +# use gcc for linking, with ld it does not work +LD = gcc +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA = -DGLEW_MX +endif +CFLAGS.SO = -DGLEW_BUILD +#LDFLAGS.SO = -shared -soname $(LIB.SONAME) --out-implib lib/$(LIB.DEVLNK) +LDFLAGS.SO = -shared -Wl,-soname,$(LIB.SONAME) -Wl,--out-implib,lib/$(LIB.DEVLNK) +LDFLAGS.GL = -lglu32 -lopengl32 -lgdi32 -luser32 -lkernel32 +LDFLAGS.EXTRA = -L/mingw/lib +WARN = -Wall -W +POPT = -O2 +BIN.SUFFIX = .exe +LIB.SONAME = lib$(NAME).dll +LIB.DEVLNK = lib$(NAME).dll.a # for mingw this is the dll import lib +LIB.SHARED = $(NAME).dll +LIB.STATIC = lib$(NAME).a # the static lib will be broken (see CFLAGS.SO) diff --git a/Externals/GLew/config/Makefile.solaris b/Externals/GLew/config/Makefile.solaris new file mode 100644 index 0000000000..d7dfa9c752 --- /dev/null +++ b/Externals/GLew/config/Makefile.solaris @@ -0,0 +1,17 @@ +NAME = $(GLEW_NAME) +CC = cc +LD = ld +CFLAGS.EXTRA = -I/usr/openwin/include +ifneq (undefined, $(origin GLEW_MX)) +CFLAGS.EXTRA += -DGLEW_MX +endif +LDFLAGS.SO = -G +LDFLAGS.EXTRA = -L/usr/openwin/lib +LDFLAGS.GL = -lXmu -lXi -lGLU -lGL -lXext -lX11 +NAME = GLEW +BIN.SUFFIX = +POPT = -xO2 +LIB.SONAME = lib$(NAME).so.$(SO_MAJOR) +LIB.DEVLNK = lib$(NAME).so +LIB.SHARED = lib$(NAME).so.$(SO_VERSION) +LIB.STATIC = lib$(NAME).a diff --git a/Externals/GLew/config/config.guess b/Externals/GLew/config/config.guess new file mode 100755 index 0000000000..da83314608 --- /dev/null +++ b/Externals/GLew/config/config.guess @@ -0,0 +1,1561 @@ +#! /bin/sh +# Attempt to guess a canonical system name. +# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, +# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 +# Free Software Foundation, Inc. + +timestamp='2009-04-27' + +# This file is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA +# 02110-1301, USA. +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + + +# Originally written by Per Bothner . +# Please send patches to . Submit a context +# diff and a properly formatted ChangeLog entry. +# +# This script attempts to guess a canonical system name similar to +# config.sub. If it succeeds, it prints the system name on stdout, and +# exits with 0. Otherwise, it exits with 1. +# +# The plan is that this can be called by configure scripts if you +# don't specify an explicit build system type. + +me=`echo "$0" | sed -e 's,.*/,,'` + +usage="\ +Usage: $0 [OPTION] + +Output the configuration name of the system \`$me' is run on. + +Operation modes: + -h, --help print this help, then exit + -t, --time-stamp print date of last modification, then exit + -v, --version print version number, then exit + +Report bugs and patches to ." + +version="\ +GNU config.guess ($timestamp) + +Originally written by Per Bothner. +Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, +2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. + +This is free software; see the source for copying conditions. There is NO +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + +help=" +Try \`$me --help' for more information." + +# Parse command line +while test $# -gt 0 ; do + case $1 in + --time-stamp | --time* | -t ) + echo "$timestamp" ; exit ;; + --version | -v ) + echo "$version" ; exit ;; + --help | --h* | -h ) + echo "$usage"; exit ;; + -- ) # Stop option processing + shift; break ;; + - ) # Use stdin as input. + break ;; + -* ) + echo "$me: invalid option $1$help" >&2 + exit 1 ;; + * ) + break ;; + esac +done + +if test $# != 0; then + echo "$me: too many arguments$help" >&2 + exit 1 +fi + +trap 'exit 1' 1 2 15 + +# CC_FOR_BUILD -- compiler used by this script. Note that the use of a +# compiler to aid in system detection is discouraged as it requires +# temporary files to be created and, as you can see below, it is a +# headache to deal with in a portable fashion. + +# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still +# use `HOST_CC' if defined, but it is deprecated. + +# Portable tmp directory creation inspired by the Autoconf team. + +set_cc_for_build=' +trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; +trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; +: ${TMPDIR=/tmp} ; + { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || + { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || + { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || + { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; +dummy=$tmp/dummy ; +tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; +case $CC_FOR_BUILD,$HOST_CC,$CC in + ,,) echo "int x;" > $dummy.c ; + for c in cc gcc c89 c99 ; do + if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then + CC_FOR_BUILD="$c"; break ; + fi ; + done ; + if test x"$CC_FOR_BUILD" = x ; then + CC_FOR_BUILD=no_compiler_found ; + fi + ;; + ,,*) CC_FOR_BUILD=$CC ;; + ,*,*) CC_FOR_BUILD=$HOST_CC ;; +esac ; set_cc_for_build= ;' + +# This is needed to find uname on a Pyramid OSx when run in the BSD universe. +# (ghazi@noc.rutgers.edu 1994-08-24) +if (test -f /.attbin/uname) >/dev/null 2>&1 ; then + PATH=$PATH:/.attbin ; export PATH +fi + +UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown +UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown +UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown +UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown + +# Note: order is significant - the case branches are not exclusive. + +case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in + *:NetBSD:*:*) + # NetBSD (nbsd) targets should (where applicable) match one or + # more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*, + # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently + # switched to ELF, *-*-netbsd* would select the old + # object file format. This provides both forward + # compatibility and a consistent mechanism for selecting the + # object file format. + # + # Note: NetBSD doesn't particularly care about the vendor + # portion of the name. We always set it to "unknown". + sysctl="sysctl -n hw.machine_arch" + UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \ + /usr/sbin/$sysctl 2>/dev/null || echo unknown)` + case "${UNAME_MACHINE_ARCH}" in + armeb) machine=armeb-unknown ;; + arm*) machine=arm-unknown ;; + sh3el) machine=shl-unknown ;; + sh3eb) machine=sh-unknown ;; + sh5el) machine=sh5le-unknown ;; + *) machine=${UNAME_MACHINE_ARCH}-unknown ;; + esac + # The Operating System including object format, if it has switched + # to ELF recently, or will in the future. + case "${UNAME_MACHINE_ARCH}" in + arm*|i386|m68k|ns32k|sh3*|sparc|vax) + eval $set_cc_for_build + if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep __ELF__ >/dev/null + then + # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). + # Return netbsd for either. FIX? + os=netbsd + else + os=netbsdelf + fi + ;; + *) + os=netbsd + ;; + esac + # The OS release + # Debian GNU/NetBSD machines have a different userland, and + # thus, need a distinct triplet. However, they do not need + # kernel version information, so it can be replaced with a + # suitable tag, in the style of linux-gnu. + case "${UNAME_VERSION}" in + Debian*) + release='-gnu' + ;; + *) + release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` + ;; + esac + # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: + # contains redundant information, the shorter form: + # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. + echo "${machine}-${os}${release}" + exit ;; + *:OpenBSD:*:*) + UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` + echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} + exit ;; + *:ekkoBSD:*:*) + echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} + exit ;; + *:SolidBSD:*:*) + echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} + exit ;; + macppc:MirBSD:*:*) + echo powerpc-unknown-mirbsd${UNAME_RELEASE} + exit ;; + *:MirBSD:*:*) + echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} + exit ;; + alpha:OSF1:*:*) + case $UNAME_RELEASE in + *4.0) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` + ;; + *5.*) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` + ;; + esac + # According to Compaq, /usr/sbin/psrinfo has been available on + # OSF/1 and Tru64 systems produced since 1995. I hope that + # covers most systems running today. This code pipes the CPU + # types through head -n 1, so we only detect the type of CPU 0. + ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` + case "$ALPHA_CPU_TYPE" in + "EV4 (21064)") + UNAME_MACHINE="alpha" ;; + "EV4.5 (21064)") + UNAME_MACHINE="alpha" ;; + "LCA4 (21066/21068)") + UNAME_MACHINE="alpha" ;; + "EV5 (21164)") + UNAME_MACHINE="alphaev5" ;; + "EV5.6 (21164A)") + UNAME_MACHINE="alphaev56" ;; + "EV5.6 (21164PC)") + UNAME_MACHINE="alphapca56" ;; + "EV5.7 (21164PC)") + UNAME_MACHINE="alphapca57" ;; + "EV6 (21264)") + UNAME_MACHINE="alphaev6" ;; + "EV6.7 (21264A)") + UNAME_MACHINE="alphaev67" ;; + "EV6.8CB (21264C)") + UNAME_MACHINE="alphaev68" ;; + "EV6.8AL (21264B)") + UNAME_MACHINE="alphaev68" ;; + "EV6.8CX (21264D)") + UNAME_MACHINE="alphaev68" ;; + "EV6.9A (21264/EV69A)") + UNAME_MACHINE="alphaev69" ;; + "EV7 (21364)") + UNAME_MACHINE="alphaev7" ;; + "EV7.9 (21364A)") + UNAME_MACHINE="alphaev79" ;; + esac + # A Pn.n version is a patched version. + # A Vn.n version is a released version. + # A Tn.n version is a released field test version. + # A Xn.n version is an unreleased experimental baselevel. + # 1.2 uses "1.2" for uname -r. + echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` + exit ;; + Alpha\ *:Windows_NT*:*) + # How do we know it's Interix rather than the generic POSIX subsystem? + # Should we change UNAME_MACHINE based on the output of uname instead + # of the specific Alpha model? + echo alpha-pc-interix + exit ;; + 21064:Windows_NT:50:3) + echo alpha-dec-winnt3.5 + exit ;; + Amiga*:UNIX_System_V:4.0:*) + echo m68k-unknown-sysv4 + exit ;; + *:[Aa]miga[Oo][Ss]:*:*) + echo ${UNAME_MACHINE}-unknown-amigaos + exit ;; + *:[Mm]orph[Oo][Ss]:*:*) + echo ${UNAME_MACHINE}-unknown-morphos + exit ;; + *:OS/390:*:*) + echo i370-ibm-openedition + exit ;; + *:z/VM:*:*) + echo s390-ibm-zvmoe + exit ;; + *:OS400:*:*) + echo powerpc-ibm-os400 + exit ;; + arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) + echo arm-acorn-riscix${UNAME_RELEASE} + exit ;; + arm:riscos:*:*|arm:RISCOS:*:*) + echo arm-unknown-riscos + exit ;; + SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) + echo hppa1.1-hitachi-hiuxmpp + exit ;; + Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) + # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. + if test "`(/bin/universe) 2>/dev/null`" = att ; then + echo pyramid-pyramid-sysv3 + else + echo pyramid-pyramid-bsd + fi + exit ;; + NILE*:*:*:dcosx) + echo pyramid-pyramid-svr4 + exit ;; + DRS?6000:unix:4.0:6*) + echo sparc-icl-nx6 + exit ;; + DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) + case `/usr/bin/uname -p` in + sparc) echo sparc-icl-nx7; exit ;; + esac ;; + s390x:SunOS:*:*) + echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4H:SunOS:5.*:*) + echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) + echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) + eval $set_cc_for_build + SUN_ARCH="i386" + # If there is a compiler, see if it is configured for 64-bit objects. + # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. + # This test works for both compilers. + if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then + if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ + (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ + grep IS_64BIT_ARCH >/dev/null + then + SUN_ARCH="x86_64" + fi + fi + echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:6*:*) + # According to config.sub, this is the proper way to canonicalize + # SunOS6. Hard to guess exactly what SunOS6 will be like, but + # it's likely to be more like Solaris than SunOS4. + echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:*:*) + case "`/usr/bin/arch -k`" in + Series*|S4*) + UNAME_RELEASE=`uname -v` + ;; + esac + # Japanese Language versions have a version number like `4.1.3-JL'. + echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` + exit ;; + sun3*:SunOS:*:*) + echo m68k-sun-sunos${UNAME_RELEASE} + exit ;; + sun*:*:4.2BSD:*) + UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` + test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 + case "`/bin/arch`" in + sun3) + echo m68k-sun-sunos${UNAME_RELEASE} + ;; + sun4) + echo sparc-sun-sunos${UNAME_RELEASE} + ;; + esac + exit ;; + aushp:SunOS:*:*) + echo sparc-auspex-sunos${UNAME_RELEASE} + exit ;; + # The situation for MiNT is a little confusing. The machine name + # can be virtually everything (everything which is not + # "atarist" or "atariste" at least should have a processor + # > m68000). The system name ranges from "MiNT" over "FreeMiNT" + # to the lowercase version "mint" (or "freemint"). Finally + # the system name "TOS" denotes a system which is actually not + # MiNT. But MiNT is downward compatible to TOS, so this should + # be no problem. + atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) + echo m68k-milan-mint${UNAME_RELEASE} + exit ;; + hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) + echo m68k-hades-mint${UNAME_RELEASE} + exit ;; + *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) + echo m68k-unknown-mint${UNAME_RELEASE} + exit ;; + m68k:machten:*:*) + echo m68k-apple-machten${UNAME_RELEASE} + exit ;; + powerpc:machten:*:*) + echo powerpc-apple-machten${UNAME_RELEASE} + exit ;; + RISC*:Mach:*:*) + echo mips-dec-mach_bsd4.3 + exit ;; + RISC*:ULTRIX:*:*) + echo mips-dec-ultrix${UNAME_RELEASE} + exit ;; + VAX*:ULTRIX*:*:*) + echo vax-dec-ultrix${UNAME_RELEASE} + exit ;; + 2020:CLIX:*:* | 2430:CLIX:*:*) + echo clipper-intergraph-clix${UNAME_RELEASE} + exit ;; + mips:*:*:UMIPS | mips:*:*:RISCos) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c +#ifdef __cplusplus +#include /* for printf() prototype */ + int main (int argc, char *argv[]) { +#else + int main (argc, argv) int argc; char *argv[]; { +#endif + #if defined (host_mips) && defined (MIPSEB) + #if defined (SYSTYPE_SYSV) + printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_SVR4) + printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) + printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); + #endif + #endif + exit (-1); + } +EOF + $CC_FOR_BUILD -o $dummy $dummy.c && + dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && + SYSTEM_NAME=`$dummy $dummyarg` && + { echo "$SYSTEM_NAME"; exit; } + echo mips-mips-riscos${UNAME_RELEASE} + exit ;; + Motorola:PowerMAX_OS:*:*) + echo powerpc-motorola-powermax + exit ;; + Motorola:*:4.3:PL8-*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:Power_UNIX:*:*) + echo powerpc-harris-powerunix + exit ;; + m88k:CX/UX:7*:*) + echo m88k-harris-cxux7 + exit ;; + m88k:*:4*:R4*) + echo m88k-motorola-sysv4 + exit ;; + m88k:*:3*:R3*) + echo m88k-motorola-sysv3 + exit ;; + AViiON:dgux:*:*) + # DG/UX returns AViiON for all architectures + UNAME_PROCESSOR=`/usr/bin/uname -p` + if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] + then + if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ + [ ${TARGET_BINARY_INTERFACE}x = x ] + then + echo m88k-dg-dgux${UNAME_RELEASE} + else + echo m88k-dg-dguxbcs${UNAME_RELEASE} + fi + else + echo i586-dg-dgux${UNAME_RELEASE} + fi + exit ;; + M88*:DolphinOS:*:*) # DolphinOS (SVR3) + echo m88k-dolphin-sysv3 + exit ;; + M88*:*:R3*:*) + # Delta 88k system running SVR3 + echo m88k-motorola-sysv3 + exit ;; + XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) + echo m88k-tektronix-sysv3 + exit ;; + Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) + echo m68k-tektronix-bsd + exit ;; + *:IRIX*:*:*) + echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` + exit ;; + ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. + echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id + exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' + i*86:AIX:*:*) + echo i386-ibm-aix + exit ;; + ia64:AIX:*:*) + if [ -x /usr/bin/oslevel ] ; then + IBM_REV=`/usr/bin/oslevel` + else + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} + fi + echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} + exit ;; + *:AIX:2:3) + if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + + main() + { + if (!__power_pc()) + exit(1); + puts("powerpc-ibm-aix3.2.5"); + exit(0); + } +EOF + if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` + then + echo "$SYSTEM_NAME" + else + echo rs6000-ibm-aix3.2.5 + fi + elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then + echo rs6000-ibm-aix3.2.4 + else + echo rs6000-ibm-aix3.2 + fi + exit ;; + *:AIX:*:[456]) + IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` + if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then + IBM_ARCH=rs6000 + else + IBM_ARCH=powerpc + fi + if [ -x /usr/bin/oslevel ] ; then + IBM_REV=`/usr/bin/oslevel` + else + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} + fi + echo ${IBM_ARCH}-ibm-aix${IBM_REV} + exit ;; + *:AIX:*:*) + echo rs6000-ibm-aix + exit ;; + ibmrt:4.4BSD:*|romp-ibm:BSD:*) + echo romp-ibm-bsd4.4 + exit ;; + ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and + echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to + exit ;; # report: romp-ibm BSD 4.3 + *:BOSX:*:*) + echo rs6000-bull-bosx + exit ;; + DPX/2?00:B.O.S.:*:*) + echo m68k-bull-sysv3 + exit ;; + 9000/[34]??:4.3bsd:1.*:*) + echo m68k-hp-bsd + exit ;; + hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) + echo m68k-hp-bsd4.4 + exit ;; + 9000/[34678]??:HP-UX:*:*) + HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` + case "${UNAME_MACHINE}" in + 9000/31? ) HP_ARCH=m68000 ;; + 9000/[34]?? ) HP_ARCH=m68k ;; + 9000/[678][0-9][0-9]) + if [ -x /usr/bin/getconf ]; then + sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` + sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` + case "${sc_cpu_version}" in + 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 + 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 + 532) # CPU_PA_RISC2_0 + case "${sc_kernel_bits}" in + 32) HP_ARCH="hppa2.0n" ;; + 64) HP_ARCH="hppa2.0w" ;; + '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 + esac ;; + esac + fi + if [ "${HP_ARCH}" = "" ]; then + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + + #define _HPUX_SOURCE + #include + #include + + int main () + { + #if defined(_SC_KERNEL_BITS) + long bits = sysconf(_SC_KERNEL_BITS); + #endif + long cpu = sysconf (_SC_CPU_VERSION); + + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1"); break; + case CPU_PA_RISC2_0: + #if defined(_SC_KERNEL_BITS) + switch (bits) + { + case 64: puts ("hppa2.0w"); break; + case 32: puts ("hppa2.0n"); break; + default: puts ("hppa2.0"); break; + } break; + #else /* !defined(_SC_KERNEL_BITS) */ + puts ("hppa2.0"); break; + #endif + default: puts ("hppa1.0"); break; + } + exit (0); + } +EOF + (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` + test -z "$HP_ARCH" && HP_ARCH=hppa + fi ;; + esac + if [ ${HP_ARCH} = "hppa2.0w" ] + then + eval $set_cc_for_build + + # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating + # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler + # generating 64-bit code. GNU and HP use different nomenclature: + # + # $ CC_FOR_BUILD=cc ./config.guess + # => hppa2.0w-hp-hpux11.23 + # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess + # => hppa64-hp-hpux11.23 + + if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | + grep __LP64__ >/dev/null + then + HP_ARCH="hppa2.0w" + else + HP_ARCH="hppa64" + fi + fi + echo ${HP_ARCH}-hp-hpux${HPUX_REV} + exit ;; + ia64:HP-UX:*:*) + HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` + echo ia64-hp-hpux${HPUX_REV} + exit ;; + 3050*:HI-UX:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + int + main () + { + long cpu = sysconf (_SC_CPU_VERSION); + /* The order matters, because CPU_IS_HP_MC68K erroneously returns + true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct + results, however. */ + if (CPU_IS_PA_RISC (cpu)) + { + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; + case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; + default: puts ("hppa-hitachi-hiuxwe2"); break; + } + } + else if (CPU_IS_HP_MC68K (cpu)) + puts ("m68k-hitachi-hiuxwe2"); + else puts ("unknown-hitachi-hiuxwe2"); + exit (0); + } +EOF + $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && + { echo "$SYSTEM_NAME"; exit; } + echo unknown-hitachi-hiuxwe2 + exit ;; + 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) + echo hppa1.1-hp-bsd + exit ;; + 9000/8??:4.3bsd:*:*) + echo hppa1.0-hp-bsd + exit ;; + *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) + echo hppa1.0-hp-mpeix + exit ;; + hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) + echo hppa1.1-hp-osf + exit ;; + hp8??:OSF1:*:*) + echo hppa1.0-hp-osf + exit ;; + i*86:OSF1:*:*) + if [ -x /usr/sbin/sysversion ] ; then + echo ${UNAME_MACHINE}-unknown-osf1mk + else + echo ${UNAME_MACHINE}-unknown-osf1 + fi + exit ;; + parisc*:Lites*:*:*) + echo hppa1.1-hp-lites + exit ;; + C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) + echo c1-convex-bsd + exit ;; + C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) + if getsysinfo -f scalar_acc + then echo c32-convex-bsd + else echo c2-convex-bsd + fi + exit ;; + C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) + echo c34-convex-bsd + exit ;; + C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) + echo c38-convex-bsd + exit ;; + C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) + echo c4-convex-bsd + exit ;; + CRAY*Y-MP:*:*:*) + echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*[A-Z]90:*:*:*) + echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ + | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ + -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ + -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*TS:*:*:*) + echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*T3E:*:*:*) + echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*SV1:*:*:*) + echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + *:UNICOS/mp:*:*) + echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) + FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` + FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` + FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` + echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + 5000:UNIX_System_V:4.*:*) + FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` + FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` + echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) + echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} + exit ;; + sparc*:BSD/OS:*:*) + echo sparc-unknown-bsdi${UNAME_RELEASE} + exit ;; + *:BSD/OS:*:*) + echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} + exit ;; + *:FreeBSD:*:*) + case ${UNAME_MACHINE} in + pc98) + echo i386-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + amd64) + echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + *) + echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + esac + exit ;; + i*:CYGWIN*:*) + echo ${UNAME_MACHINE}-pc-cygwin + exit ;; + *:MINGW*:*) + echo ${UNAME_MACHINE}-pc-mingw32 + exit ;; + i*:windows32*:*) + # uname -m includes "-pc" on this system. + echo ${UNAME_MACHINE}-mingw32 + exit ;; + i*:PW*:*) + echo ${UNAME_MACHINE}-pc-pw32 + exit ;; + *:Interix*:[3456]*) + case ${UNAME_MACHINE} in + x86) + echo i586-pc-interix${UNAME_RELEASE} + exit ;; + EM64T | authenticamd | genuineintel) + echo x86_64-unknown-interix${UNAME_RELEASE} + exit ;; + IA64) + echo ia64-unknown-interix${UNAME_RELEASE} + exit ;; + esac ;; + [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) + echo i${UNAME_MACHINE}-pc-mks + exit ;; + i*:Windows_NT*:* | Pentium*:Windows_NT*:*) + # How do we know it's Interix rather than the generic POSIX subsystem? + # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we + # UNAME_MACHINE based on the output of uname instead of i386? + echo i586-pc-interix + exit ;; + i*:UWIN*:*) + echo ${UNAME_MACHINE}-pc-uwin + exit ;; + amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) + echo x86_64-unknown-cygwin + exit ;; + p*:CYGWIN*:*) + echo powerpcle-unknown-cygwin + exit ;; + prep*:SunOS:5.*:*) + echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + *:GNU:*:*) + # the GNU system + echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` + exit ;; + *:GNU/*:*:*) + # other systems with GNU libc and userland + echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu + exit ;; + i*86:Minix:*:*) + echo ${UNAME_MACHINE}-pc-minix + exit ;; + arm*:Linux:*:*) + eval $set_cc_for_build + if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep -q __ARM_EABI__ + then + echo ${UNAME_MACHINE}-unknown-linux-gnu + else + echo ${UNAME_MACHINE}-unknown-linux-gnueabi + fi + exit ;; + avr32*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + cris:Linux:*:*) + echo cris-axis-linux-gnu + exit ;; + crisv32:Linux:*:*) + echo crisv32-axis-linux-gnu + exit ;; + frv:Linux:*:*) + echo frv-unknown-linux-gnu + exit ;; + ia64:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + m32r*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + m68*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + mips:Linux:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #undef CPU + #undef mips + #undef mipsel + #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) + CPU=mipsel + #else + #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) + CPU=mips + #else + CPU= + #endif + #endif +EOF + eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' + /^CPU/{ + s: ::g + p + }'`" + test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } + ;; + mips64:Linux:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #undef CPU + #undef mips64 + #undef mips64el + #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) + CPU=mips64el + #else + #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) + CPU=mips64 + #else + CPU= + #endif + #endif +EOF + eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' + /^CPU/{ + s: ::g + p + }'`" + test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } + ;; + or32:Linux:*:*) + echo or32-unknown-linux-gnu + exit ;; + ppc:Linux:*:*) + echo powerpc-unknown-linux-gnu + exit ;; + ppc64:Linux:*:*) + echo powerpc64-unknown-linux-gnu + exit ;; + alpha:Linux:*:*) + case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in + EV5) UNAME_MACHINE=alphaev5 ;; + EV56) UNAME_MACHINE=alphaev56 ;; + PCA56) UNAME_MACHINE=alphapca56 ;; + PCA57) UNAME_MACHINE=alphapca56 ;; + EV6) UNAME_MACHINE=alphaev6 ;; + EV67) UNAME_MACHINE=alphaev67 ;; + EV68*) UNAME_MACHINE=alphaev68 ;; + esac + objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null + if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi + echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC} + exit ;; + padre:Linux:*:*) + echo sparc-unknown-linux-gnu + exit ;; + parisc:Linux:*:* | hppa:Linux:*:*) + # Look for CPU level + case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in + PA7*) echo hppa1.1-unknown-linux-gnu ;; + PA8*) echo hppa2.0-unknown-linux-gnu ;; + *) echo hppa-unknown-linux-gnu ;; + esac + exit ;; + parisc64:Linux:*:* | hppa64:Linux:*:*) + echo hppa64-unknown-linux-gnu + exit ;; + s390:Linux:*:* | s390x:Linux:*:*) + echo ${UNAME_MACHINE}-ibm-linux + exit ;; + sh64*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + sh*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + sparc:Linux:*:* | sparc64:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + vax:Linux:*:*) + echo ${UNAME_MACHINE}-dec-linux-gnu + exit ;; + x86_64:Linux:*:*) + echo x86_64-unknown-linux-gnu + exit ;; + xtensa*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + i*86:Linux:*:*) + # The BFD linker knows what the default object file format is, so + # first see if it will tell us. cd to the root directory to prevent + # problems with other programs or directories called `ld' in the path. + # Set LC_ALL=C to ensure ld outputs messages in English. + ld_supported_targets=`cd /; LC_ALL=C ld --help 2>&1 \ + | sed -ne '/supported targets:/!d + s/[ ][ ]*/ /g + s/.*supported targets: *// + s/ .*// + p'` + case "$ld_supported_targets" in + elf32-i386) + TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu" + ;; + a.out-i386-linux) + echo "${UNAME_MACHINE}-pc-linux-gnuaout" + exit ;; + "") + # Either a pre-BFD a.out linker (linux-gnuoldld) or + # one that does not give us useful --help. + echo "${UNAME_MACHINE}-pc-linux-gnuoldld" + exit ;; + esac + # Determine whether the default compiler is a.out or elf + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + #ifdef __ELF__ + # ifdef __GLIBC__ + # if __GLIBC__ >= 2 + LIBC=gnu + # else + LIBC=gnulibc1 + # endif + # else + LIBC=gnulibc1 + # endif + #else + #if defined(__INTEL_COMPILER) || defined(__PGI) || defined(__SUNPRO_C) || defined(__SUNPRO_CC) + LIBC=gnu + #else + LIBC=gnuaout + #endif + #endif + #ifdef __dietlibc__ + LIBC=dietlibc + #endif +EOF + eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' + /^LIBC/{ + s: ::g + p + }'`" + test x"${LIBC}" != x && { + echo "${UNAME_MACHINE}-pc-linux-${LIBC}" + exit + } + test x"${TENTATIVE}" != x && { echo "${TENTATIVE}"; exit; } + ;; + i*86:DYNIX/ptx:4*:*) + # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. + # earlier versions are messed up and put the nodename in both + # sysname and nodename. + echo i386-sequent-sysv4 + exit ;; + i*86:UNIX_SV:4.2MP:2.*) + # Unixware is an offshoot of SVR4, but it has its own version + # number series starting with 2... + # I am not positive that other SVR4 systems won't match this, + # I just have to hope. -- rms. + # Use sysv4.2uw... so that sysv4* matches it. + echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} + exit ;; + i*86:OS/2:*:*) + # If we were able to find `uname', then EMX Unix compatibility + # is probably installed. + echo ${UNAME_MACHINE}-pc-os2-emx + exit ;; + i*86:XTS-300:*:STOP) + echo ${UNAME_MACHINE}-unknown-stop + exit ;; + i*86:atheos:*:*) + echo ${UNAME_MACHINE}-unknown-atheos + exit ;; + i*86:syllable:*:*) + echo ${UNAME_MACHINE}-pc-syllable + exit ;; + i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.0*:*) + echo i386-unknown-lynxos${UNAME_RELEASE} + exit ;; + i*86:*DOS:*:*) + echo ${UNAME_MACHINE}-pc-msdosdjgpp + exit ;; + i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) + UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` + if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then + echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} + else + echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} + fi + exit ;; + i*86:*:5:[678]*) + # UnixWare 7.x, OpenUNIX and OpenServer 6. + case `/bin/uname -X | grep "^Machine"` in + *486*) UNAME_MACHINE=i486 ;; + *Pentium) UNAME_MACHINE=i586 ;; + *Pent*|*Celeron) UNAME_MACHINE=i686 ;; + esac + echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} + exit ;; + i*86:*:3.2:*) + if test -f /usr/options/cb.name; then + UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then + UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` + (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 + (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ + && UNAME_MACHINE=i586 + (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ + && UNAME_MACHINE=i686 + (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ + && UNAME_MACHINE=i686 + echo ${UNAME_MACHINE}-pc-sco$UNAME_REL + else + echo ${UNAME_MACHINE}-pc-sysv32 + fi + exit ;; + pc:*:*:*) + # Left here for compatibility: + # uname -m prints for DJGPP always 'pc', but it prints nothing about + # the processor, so we play safe by assuming i586. + # Note: whatever this is, it MUST be the same as what config.sub + # prints for the "djgpp" host, or else GDB configury will decide that + # this is a cross-build. + echo i586-pc-msdosdjgpp + exit ;; + Intel:Mach:3*:*) + echo i386-pc-mach3 + exit ;; + paragon:*:*:*) + echo i860-intel-osf1 + exit ;; + i860:*:4.*:*) # i860-SVR4 + if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then + echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 + else # Add other i860-SVR4 vendors below as they are discovered. + echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 + fi + exit ;; + mini*:CTIX:SYS*5:*) + # "miniframe" + echo m68010-convergent-sysv + exit ;; + mc68k:UNIX:SYSTEM5:3.51m) + echo m68k-convergent-sysv + exit ;; + M680?0:D-NIX:5.3:*) + echo m68k-diab-dnix + exit ;; + M68*:*:R3V[5678]*:*) + test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; + 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) + OS_REL='' + test -r /etc/.relid \ + && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4.3${OS_REL}; exit; } + /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; + 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4; exit; } ;; + NCR*:*:4.2:* | MPRAS*:*:4.2:*) + OS_REL='.3' + test -r /etc/.relid \ + && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4.3${OS_REL}; exit; } + /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } + /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; + m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) + echo m68k-unknown-lynxos${UNAME_RELEASE} + exit ;; + mc68030:UNIX_System_V:4.*:*) + echo m68k-atari-sysv4 + exit ;; + TSUNAMI:LynxOS:2.*:*) + echo sparc-unknown-lynxos${UNAME_RELEASE} + exit ;; + rs6000:LynxOS:2.*:*) + echo rs6000-unknown-lynxos${UNAME_RELEASE} + exit ;; + PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.0*:*) + echo powerpc-unknown-lynxos${UNAME_RELEASE} + exit ;; + SM[BE]S:UNIX_SV:*:*) + echo mips-dde-sysv${UNAME_RELEASE} + exit ;; + RM*:ReliantUNIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + RM*:SINIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + *:SINIX-*:*:*) + if uname -p 2>/dev/null >/dev/null ; then + UNAME_MACHINE=`(uname -p) 2>/dev/null` + echo ${UNAME_MACHINE}-sni-sysv4 + else + echo ns32k-sni-sysv + fi + exit ;; + PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort + # says + echo i586-unisys-sysv4 + exit ;; + *:UNIX_System_V:4*:FTX*) + # From Gerald Hewes . + # How about differentiating between stratus architectures? -djm + echo hppa1.1-stratus-sysv4 + exit ;; + *:*:*:FTX*) + # From seanf@swdc.stratus.com. + echo i860-stratus-sysv4 + exit ;; + i*86:VOS:*:*) + # From Paul.Green@stratus.com. + echo ${UNAME_MACHINE}-stratus-vos + exit ;; + *:VOS:*:*) + # From Paul.Green@stratus.com. + echo hppa1.1-stratus-vos + exit ;; + mc68*:A/UX:*:*) + echo m68k-apple-aux${UNAME_RELEASE} + exit ;; + news*:NEWS-OS:6*:*) + echo mips-sony-newsos6 + exit ;; + R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) + if [ -d /usr/nec ]; then + echo mips-nec-sysv${UNAME_RELEASE} + else + echo mips-unknown-sysv${UNAME_RELEASE} + fi + exit ;; + BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. + echo powerpc-be-beos + exit ;; + BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. + echo powerpc-apple-beos + exit ;; + BePC:BeOS:*:*) # BeOS running on Intel PC compatible. + echo i586-pc-beos + exit ;; + BePC:Haiku:*:*) # Haiku running on Intel PC compatible. + echo i586-pc-haiku + exit ;; + SX-4:SUPER-UX:*:*) + echo sx4-nec-superux${UNAME_RELEASE} + exit ;; + SX-5:SUPER-UX:*:*) + echo sx5-nec-superux${UNAME_RELEASE} + exit ;; + SX-6:SUPER-UX:*:*) + echo sx6-nec-superux${UNAME_RELEASE} + exit ;; + SX-7:SUPER-UX:*:*) + echo sx7-nec-superux${UNAME_RELEASE} + exit ;; + SX-8:SUPER-UX:*:*) + echo sx8-nec-superux${UNAME_RELEASE} + exit ;; + SX-8R:SUPER-UX:*:*) + echo sx8r-nec-superux${UNAME_RELEASE} + exit ;; + Power*:Rhapsody:*:*) + echo powerpc-apple-rhapsody${UNAME_RELEASE} + exit ;; + *:Rhapsody:*:*) + echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} + exit ;; + *:Darwin:*:*) + UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown + case $UNAME_PROCESSOR in + unknown) UNAME_PROCESSOR=powerpc ;; + esac + echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} + exit ;; + *:procnto*:*:* | *:QNX:[0123456789]*:*) + UNAME_PROCESSOR=`uname -p` + if test "$UNAME_PROCESSOR" = "x86"; then + UNAME_PROCESSOR=i386 + UNAME_MACHINE=pc + fi + echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} + exit ;; + *:QNX:*:4*) + echo i386-pc-qnx + exit ;; + NSE-?:NONSTOP_KERNEL:*:*) + echo nse-tandem-nsk${UNAME_RELEASE} + exit ;; + NSR-?:NONSTOP_KERNEL:*:*) + echo nsr-tandem-nsk${UNAME_RELEASE} + exit ;; + *:NonStop-UX:*:*) + echo mips-compaq-nonstopux + exit ;; + BS2000:POSIX*:*:*) + echo bs2000-siemens-sysv + exit ;; + DS/*:UNIX_System_V:*:*) + echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} + exit ;; + *:Plan9:*:*) + # "uname -m" is not consistent, so use $cputype instead. 386 + # is converted to i386 for consistency with other x86 + # operating systems. + if test "$cputype" = "386"; then + UNAME_MACHINE=i386 + else + UNAME_MACHINE="$cputype" + fi + echo ${UNAME_MACHINE}-unknown-plan9 + exit ;; + *:TOPS-10:*:*) + echo pdp10-unknown-tops10 + exit ;; + *:TENEX:*:*) + echo pdp10-unknown-tenex + exit ;; + KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) + echo pdp10-dec-tops20 + exit ;; + XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) + echo pdp10-xkl-tops20 + exit ;; + *:TOPS-20:*:*) + echo pdp10-unknown-tops20 + exit ;; + *:ITS:*:*) + echo pdp10-unknown-its + exit ;; + SEI:*:*:SEIUX) + echo mips-sei-seiux${UNAME_RELEASE} + exit ;; + *:DragonFly:*:*) + echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` + exit ;; + *:*VMS:*:*) + UNAME_MACHINE=`(uname -p) 2>/dev/null` + case "${UNAME_MACHINE}" in + A*) echo alpha-dec-vms ; exit ;; + I*) echo ia64-dec-vms ; exit ;; + V*) echo vax-dec-vms ; exit ;; + esac ;; + *:XENIX:*:SysV) + echo i386-pc-xenix + exit ;; + i*86:skyos:*:*) + echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' + exit ;; + i*86:rdos:*:*) + echo ${UNAME_MACHINE}-pc-rdos + exit ;; + i*86:AROS:*:*) + echo ${UNAME_MACHINE}-pc-aros + exit ;; +esac + +#echo '(No uname command or uname output not recognized.)' 1>&2 +#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2 + +eval $set_cc_for_build +cat >$dummy.c < +# include +#endif +main () +{ +#if defined (sony) +#if defined (MIPSEB) + /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed, + I don't know.... */ + printf ("mips-sony-bsd\n"); exit (0); +#else +#include + printf ("m68k-sony-newsos%s\n", +#ifdef NEWSOS4 + "4" +#else + "" +#endif + ); exit (0); +#endif +#endif + +#if defined (__arm) && defined (__acorn) && defined (__unix) + printf ("arm-acorn-riscix\n"); exit (0); +#endif + +#if defined (hp300) && !defined (hpux) + printf ("m68k-hp-bsd\n"); exit (0); +#endif + +#if defined (NeXT) +#if !defined (__ARCHITECTURE__) +#define __ARCHITECTURE__ "m68k" +#endif + int version; + version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`; + if (version < 4) + printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version); + else + printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version); + exit (0); +#endif + +#if defined (MULTIMAX) || defined (n16) +#if defined (UMAXV) + printf ("ns32k-encore-sysv\n"); exit (0); +#else +#if defined (CMU) + printf ("ns32k-encore-mach\n"); exit (0); +#else + printf ("ns32k-encore-bsd\n"); exit (0); +#endif +#endif +#endif + +#if defined (__386BSD__) + printf ("i386-pc-bsd\n"); exit (0); +#endif + +#if defined (sequent) +#if defined (i386) + printf ("i386-sequent-dynix\n"); exit (0); +#endif +#if defined (ns32000) + printf ("ns32k-sequent-dynix\n"); exit (0); +#endif +#endif + +#if defined (_SEQUENT_) + struct utsname un; + + uname(&un); + + if (strncmp(un.version, "V2", 2) == 0) { + printf ("i386-sequent-ptx2\n"); exit (0); + } + if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */ + printf ("i386-sequent-ptx1\n"); exit (0); + } + printf ("i386-sequent-ptx\n"); exit (0); + +#endif + +#if defined (vax) +# if !defined (ultrix) +# include +# if defined (BSD) +# if BSD == 43 + printf ("vax-dec-bsd4.3\n"); exit (0); +# else +# if BSD == 199006 + printf ("vax-dec-bsd4.3reno\n"); exit (0); +# else + printf ("vax-dec-bsd\n"); exit (0); +# endif +# endif +# else + printf ("vax-dec-bsd\n"); exit (0); +# endif +# else + printf ("vax-dec-ultrix\n"); exit (0); +# endif +#endif + +#if defined (alliant) && defined (i860) + printf ("i860-alliant-bsd\n"); exit (0); +#endif + + exit (1); +} +EOF + +$CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null && SYSTEM_NAME=`$dummy` && + { echo "$SYSTEM_NAME"; exit; } + +# Apollos put the system type in the environment. + +test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit; } + +# Convex versions that predate uname can use getsysinfo(1) + +if [ -x /usr/convex/getsysinfo ] +then + case `getsysinfo -f cpu_type` in + c1*) + echo c1-convex-bsd + exit ;; + c2*) + if getsysinfo -f scalar_acc + then echo c32-convex-bsd + else echo c2-convex-bsd + fi + exit ;; + c34*) + echo c34-convex-bsd + exit ;; + c38*) + echo c38-convex-bsd + exit ;; + c4*) + echo c4-convex-bsd + exit ;; + esac +fi + +cat >&2 < in order to provide the needed +information to handle your system. + +config.guess timestamp = $timestamp + +uname -m = `(uname -m) 2>/dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null` + +hostinfo = `(hostinfo) 2>/dev/null` +/bin/universe = `(/bin/universe) 2>/dev/null` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` +/bin/arch = `(/bin/arch) 2>/dev/null` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` + +UNAME_MACHINE = ${UNAME_MACHINE} +UNAME_RELEASE = ${UNAME_RELEASE} +UNAME_SYSTEM = ${UNAME_SYSTEM} +UNAME_VERSION = ${UNAME_VERSION} +EOF + +exit 1 + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "timestamp='" +# time-stamp-format: "%:y-%02m-%02d" +# time-stamp-end: "'" +# End: diff --git a/Externals/GLew/config/version b/Externals/GLew/config/version new file mode 100644 index 0000000000..42b850fc1f --- /dev/null +++ b/Externals/GLew/config/version @@ -0,0 +1,7 @@ +GLEW_MAJOR = 1 +GLEW_MINOR = 5 +GLEW_MICRO = 4 +GLEW_VERSION = $(GLEW_MAJOR).$(GLEW_MINOR).$(GLEW_MICRO) +GLEW_NAME = GLEW +SO_MAJOR = $(GLEW_MAJOR).$(GLEW_MINOR) +SO_VERSION = $(GLEW_VERSION) diff --git a/Externals/GLew/doc/advanced.html b/Externals/GLew/doc/advanced.html new file mode 100644 index 0000000000..4f722d429e --- /dev/null +++ b/Externals/GLew/doc/advanced.html @@ -0,0 +1,278 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Automatic Code Generation

+ +

+Starting from release 1.1.0, the source code and parts of the +documentation are automatically generated from the extension +specifications in a two-step process. In the first step, +specification files from the OpenGL registry are downloaded and +parsed. Skeleton descriptors are created for each extension. These +descriptors contain all necessary information for creating the source +code and documentation in a simple and compact format, including the +name of the extension, url link to the specification, tokens, function +declarations, typedefs and struct definitions. In the second step, +the header files as well as the library and glewinfo source are +generated from the descriptor files. The code generation scripts are +located in the auto subdirectory. +

+ +

+The code generation scripts require GNU make, wget, and perl. On +Windows, the simplest way to get access to these tools is to install +Cygwin, but make sure that the +root directory is mounted in binary mode. The makefile in the +auto directory provides the following build targets: +

+ +
+ + + + + + + + + + + + + + + + +
make    Create the source files from the descriptors. If the +descriptors do not exist, create them from the spec files. If the spec +files do not exist, download them from the OpenGL repository.
make clean    Delete the source files.
make clobber    Delete the source files and the descriptors.
make destroy    Delete the source files, the descriptors, and the spec files.
make custom    Create the source files for the extensions +listed in auto/custom.txt. See "Custom Code +Generation" below for more details.
+
+ +

Adding a New Extension

+ +

+To add a new extension, create a descriptor file for the extension in +auto/core and rerun the code generation scripts by typing +make clean; make in the auto directory. +

+ +

+The format of the descriptor file is given below. Items in +brackets are optional. +

+ +

+<Extension Name>
+[<URL of Specification File>]
+    [<Token Name> <Token Value>]
+    [<Token Name> <Token Value>]
+    ...
+    [<Typedef>]
+    [<Typedef>]
+    ...
+    [<Function Signature>]
+    [<Function Signature>]
+    ...
+ +

+ + + +

+Take a look at one of the files in auto/core for an +example. Note that typedefs and function signatures should not be +terminated with a semicolon. +

+ +

Custom Code Generation

+

+Starting from GLEW 1.3.0, it is possible to control which extensions +to include in the libarary by specifying a list in +auto/custom.txt. This is useful when you do not need all the +extensions and would like to reduce the size of the source files. +Type make clean; make custom in the auto directory +to rerun the scripts with the custom list of extensions. +

+ +

+For example, the following is the list of extensions needed to get GLEW and the +utilities to compile. +

+ +

+WGL_ARB_extensions_string
+WGL_ARB_multisample
+WGL_ARB_pixel_format
+WGL_ARB_pbuffer
+WGL_EXT_extensions_string
+WGL_ATI_pixel_format_float
+WGL_NV_float_buffer
+

+ +

Multiple Rendering Contexts (GLEW MX)

+ +

Starting with release 1.2.0, thread-safe support for multiple +rendering contexts, possibly with different capabilities, is +available. Since this is not required by most users, it is not added +to the binary releases to maintain compatibility between different +versions. To include multi-context support, you have to do the +following:

+
    +
  1. Compile and use GLEW with the GLEW_MX preprocessor token +defined.
  2. +
  3. For each rendering context, create a GLEWContext object +that will be available as long as the rendering context exists.
  4. +
  5. Define a macro or function called glewGetContext() that +returns a pointer to the GLEWContext object associated with +the rendering context from which OpenGL/WGL/GLX calls are issued. This +dispatch mechanism is primitive, but generic. +
  6. Make sure that you call glewInit() after creating the +GLEWContext object in each rendering context. Note, that the +GLEWContext pointer returned by glewGetContext() has +to reside in global or thread-local memory. +
+ +

Note that according to the MSDN +WGL documentation, you have to initialize the entry points for +every rendering context that use pixel formats with different +capabilities For example, the pixel formats provided by the generic +software OpenGL implementation by Microsoft vs. the hardware +accelerated pixel formats have different capabilities. GLEW by +default ignores this requirement, and does not define per-context +entry points (you can however do this using the steps described +above). Assuming a global namespace for the entry points works in +most situations, because typically all hardware accelerated pixel +formats provide the same entry points and capabilities. This means +that unless you use the multi-context version of GLEW, you need to +call glewInit() only once in your program, or more precisely, +once per process.

+ +

Separate Namespace

+ +

+To avoid name clashes when linking with libraries that include the +same symbols, extension entry points are declared in a separate +namespace (release 1.1.0 and up). This is achieved by aliasing OpenGL +function names to their GLEW equivalents. For instance, +glFancyFunction is simply an alias to +glewFancyFunction. The separate namespace does not effect +token and function pointer definitions. +

+ +

Known Issues

+ +

+GLEW requires GLX 1.2 for compatibility with GLUT. +

+ + +
+ + diff --git a/Externals/GLew/doc/basic.html b/Externals/GLew/doc/basic.html new file mode 100644 index 0000000000..0627831070 --- /dev/null +++ b/Externals/GLew/doc/basic.html @@ -0,0 +1,282 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Initializing GLEW

+

+First you need to create a valid OpenGL rendering context and call +glewInit() to initialize the extension entry points. If +glewInit() returns GLEW_OK, the initialization +succeeded and you can use the available extensions as well as core +OpenGL functionality. For example: +

+ +

+#include <GL/glew.h>
+#include <GL/glut.h>
+...
+glutInit(&argc, argv);
+glutCreateWindow("GLEW Test");
+GLenum err = glewInit();
+if (GLEW_OK != err)
+{
+  /* Problem: glewInit failed, something is seriously wrong. */
+  fprintf(stderr, "Error: %s\n", glewGetErrorString(err));
+  ...
+}
+fprintf(stdout, "Status: Using GLEW %s\n", glewGetString(GLEW_VERSION));
+

+ +

Checking for Extensions

+ +

+Starting from GLEW 1.1.0, you can find out if a particular extension +is available on your platform by querying globally defined variables +of the form GLEW_{extension_name}: +

+ +

+if (GLEW_ARB_vertex_program)
+{
+  /* It is safe to use the ARB_vertex_program extension here. */
+  glGenProgramsARB(...);
+}
+

+ +

+In GLEW 1.0.x, a global structure was used for this task. To ensure +binary compatibility between releases, the struct was replaced with a +set of variables. +

+ +

+You can also check for core OpenGL functionality. For example, to +see if OpenGL 1.3 is supported, do the following: +

+ +

+if (GLEW_VERSION_1_3)
+{
+  /* Yay! OpenGL 1.3 is supported! */
+}
+

+ +

+In general, you can check if GLEW_{extension_name} or +GLEW_VERSION_{version} is true or false. +

+ +

+It is also possible to perform extension checks from string +input. Starting from the 1.3.0 release, use glewIsSupported +to check if the required core or extension functionality is +available: +

+ +

+if (glewIsSupported("GL_VERSION_1_4  GL_ARB_point_sprite"))
+{
+  /* Great, we have OpenGL 1.4 + point sprites. */
+}
+

+ +

+For extensions only, glewGetExtension provides a slower alternative +(GLEW 1.0.x-1.2.x). Note that in the 1.3.0 release +glewGetExtension was replaced with +glewIsSupported. +

+ +

+if (glewGetExtension("GL_ARB_fragment_program"))
+{
+  /* Looks like ARB_fragment_program is supported. */
+}
+

+ +

Experimental Drivers

+ +

+GLEW obtains information on the supported extensions from the graphics +driver. Experimental or pre-release drivers, however, might not +report every available extension through the standard mechanism, in +which case GLEW will report it unsupported. To circumvent this +situation, the glewExperimental global switch can be turned +on by setting it to GL_TRUE before calling +glewInit(), which ensures that all extensions with valid +entry points will be exposed. +

+ +

Platform Specific Extensions

+ +

+Platform specific extensions are separated into two header files: +wglew.h and glxew.h, which define the available +WGL and GLX extensions. To determine if a certain +extension is supported, query WGLEW_{extension name} or +GLXEW_{extension_name}. For example: +

+ +

+#include <GL/wglew.h>
+
+if (WGLEW_ARB_pbuffer)
+{
+  /* OK, we can use pbuffers. */
+}
+else
+{
+  /* Sorry, pbuffers will not work on this platform. */
+}
+

+ +

+Alternatively, use wglewIsSupported or +glxewIsSupported to check for extensions from a string: +

+ +

+if (wglewIsSupported("WGL_ARB_pbuffer"))
+{
+  /* OK, we can use pbuffers. */
+}
+

+ +

Utilities

+ +

+GLEW provides two command-line utilities: one for creating a list of +available extensions and visuals; and another for verifying extension +entry points. +

+ +

visualinfo: extensions and visuals

+ +

+visualinfo is an extended version of glxinfo. The +Windows version creates a file called visualinfo.txt, which +contains a list of available OpenGL, WGL, and GLU extensions as well +as a table of visuals aka. pixel formats. Pbuffer and MRT capable +visuals are also included. For additional usage information, type +visualinfo -h. +

+ +

glewinfo: extension verification utility

+ +

+glewinfo allows you to verify the entry points for the +extensions supported on your platform. The Windows version +reports the results to a text file called glewinfo.txt. The +Unix version prints the results to stdout. +

+ +

Windows usage:

+
glewinfo [-pf <id>]
+ +

where <id> is the pixel format id for which the +capabilities are displayed.

+ +

Unix usage:

+
glewinfo [-display <dpy>] [-visual <id>]
+ +

where <dpy> is the X11 display and <id> is +the visual id for which the capabilities are displayed.

+ + +
+ + diff --git a/Externals/GLew/doc/credits.html b/Externals/GLew/doc/credits.html new file mode 100644 index 0000000000..9fb3959f5a --- /dev/null +++ b/Externals/GLew/doc/credits.html @@ -0,0 +1,127 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Credits

+ +

+GLEW was developed by Milan +Ikits and Marcelo +Magallon. They also perform occasional maintainance to make sure +that GLEW stays in mint condition. Aaron Lefohn, Joe Kniss, and Chris +Wyman were the first users and also assisted with the design and +debugging process. The acronym GLEW originates from Aaron Lefohn. +Pasi Kärkkäinen identified and fixed several problems with +GLX and SDL. Nate Robins created the wglinfo utility, to +which modifications were made by Michael Wimmer. +

+ +

Copyright

+ +

+GLEW is originally derived from the EXTGL project by Lev Povalahev. +The source code is licensed under the Modified BSD +License, the Mesa 3-D License (MIT +License), and the Khronos License (MIT +License). The automatic code generation scripts are released under +the GNU GPL. +

+ +
+ + diff --git a/Externals/GLew/doc/glew.css b/Externals/GLew/doc/glew.css new file mode 100644 index 0000000000..1bb7dd178a --- /dev/null +++ b/Externals/GLew/doc/glew.css @@ -0,0 +1,187 @@ +h1 +{ + color: black; + font: 23px "Verdana", "Arial", "Helvetica", sans-serif; + font-weight: bold; + text-align: center; + margin-top: 12px; + margin-bottom: 18px; +} + +h2 +{ + color: black; + font: 18px "Verdana", "Arial", "Helvetica", sans-serif; + font-weight: bold; + text-align: left; + padding-top: 0px; + padding-bottom: 0px; + margin-top: 18px; + margin-bottom: 12px; +} + +h3 +{ + color: black; + font: 17px "Verdana", "Arial", "Helvetica", sans-serif; + text-align: left; + padding-top: 0px; + padding-bottom: 0px; + margin-top: 12px; + margin-bottom: 12px; +} + +small +{ + font: 8pt "Verdana", "Arial", "Helvetica", sans-serif; +} + +body +{ + color: black; + font: 10pt "Verdana", "Arial", "Helvetica", sans-serif; + text-align: left; +} + +td +{ + color: black; + font: 10pt "Verdana", "Arial", "Helvetica", sans-serif; +} + +tt +{ + color: rgb(0,120,0); +} +/* color: maroon; */ + +td.num +{ + color: lightgrey; + font: 10pt "Verdana", "Arial", "Helvetica", sans-serif; + text-align: right; +} + +blockquote +{ + color: rgb(0,120,0); + background: #f0f0f0; + text-align: left; + margin-left: 40px; + margin-right: 40px; + margin-bottom: 6px; + padding-bottom: 0px; + margin-top: 0px; + padding-top: 0px; + border-top: 0px; + border-width: 0px; +} + +pre +{ + color: rgb(0,120,0); + background: #f0f0f0; + text-align: left; + margin-left: 40px; + margin-right: 40px; + margin-bottom: 6px; + padding-bottom: 0px; + margin-top: 0px; + padding-top: 0px; + border-top: 0px; + border-width: 0px; +} + +p +{ + color: black; + font: 10pt "Verdana", "Arial", "Helvetica", sans-serif; + text-align: left; + margin-bottom: 0px; + padding-bottom: 6px; + margin-top: 0px; + padding-top: 0px; +} + +p.right +{ + color: black; + font: 10pt "Verdana", "Arial", "Helvetica", sans-serif; + text-align: right; + margin-bottom: 0px; + padding-bottom: 6px; + margin-top: 0px; + padding-top: 0px; +} + +p.pre +{ + color: rgb(0,120,0); + font: 10pt "Courier New", "Courier", monospace; + background: #f0f0f0; + text-align: left; + margin-top: 0px; + margin-bottom: 6px; + margin-left: 40px; + margin-right: 40px; + padding-top: 0px; + padding-bottom: 6px; + padding-left: 6px; + padding-right: 6px; + border-top: 0px; + border-width: 0px; +} + +a:link +{ + color: rgb(0,0,139); + text-decoration: none; +} + +a:visited +{ + color: rgb(220,20,60); + text-decoration: none; +} + +a:hover +{ + color: rgb(220,20,60); + text-decoration: underline; + background: "#e8e8e8"; +} + +ul +{ + list-style-type: disc; + text-align: left; + margin-left: 40px; + margin-top: 0px; + padding-top: 0px; + margin-bottom: 0px; + padding-bottom: 3px; +} + +ul.none +{ + list-style-type: none; +} + +ol +{ + text-align: left; + margin-left: 40px; + margin-top: 0px; + padding-top: 0px; + margin-bottom: 0px; + padding-bottom: 12px; +} + +hr +{ + color: maroon; + background-color: maroon; + height: 1px; + border: 0px; + width: 80%; +} diff --git a/Externals/GLew/doc/glew.html b/Externals/GLew/doc/glew.html new file mode 100644 index 0000000000..70002b7de2 --- /dev/null +++ b/Externals/GLew/doc/glew.html @@ -0,0 +1,513 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Supported OpenGL Extensions

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
1 3DFX_multisample
2 3DFX_tbuffer
3 3DFX_texture_compression_FXT1

4 AMD_conservative_depth
5 AMD_draw_buffers_blend
6 AMD_performance_monitor
7 AMD_seamless_cubemap_per_texture
8 AMD_shader_stencil_export
9 AMD_texture_texture4
10 AMD_vertex_shader_tessellator

11 APPLE_aux_depth_stencil
12 APPLE_client_storage
13 APPLE_element_array
14 APPLE_fence
15 APPLE_float_pixels
16 APPLE_flush_buffer_range
17 APPLE_object_purgeable
18 APPLE_pixel_buffer
19 APPLE_rgb_422
20 APPLE_row_bytes
21 APPLE_specular_vector
22 APPLE_texture_range
23 APPLE_transform_hint
24 APPLE_vertex_array_object
25 APPLE_vertex_array_range
26 APPLE_vertex_program_evaluators
27 APPLE_ycbcr_422

28 ARB_blend_func_extended
29 ARB_color_buffer_float
30 ARB_compatibility
31 ARB_copy_buffer
32 ARB_depth_buffer_float
33 ARB_depth_clamp
34 ARB_depth_texture
35 ARB_draw_buffers
36 ARB_draw_buffers_blend
37 ARB_draw_elements_base_vertex
38 ARB_draw_indirect
39 ARB_draw_instanced
40 ARB_explicit_attrib_location
41 ARB_fragment_coord_conventions
42 ARB_fragment_program
43 ARB_fragment_program_shadow
44 ARB_fragment_shader
45 ARB_framebuffer_object
46 ARB_framebuffer_sRGB
47 ARB_geometry_shader4
48 ARB_gpu_shader5
49 ARB_gpu_shader_fp64
50 ARB_half_float_pixel
51 ARB_half_float_vertex
52 ARB_imaging
53 ARB_instanced_arrays
54 ARB_map_buffer_range
55 ARB_matrix_palette
56 ARB_multisample
57 ARB_multitexture
58 ARB_occlusion_query
59 ARB_occlusion_query2
60 ARB_pixel_buffer_object
61 ARB_point_parameters
62 ARB_point_sprite
63 ARB_provoking_vertex
64 ARB_sample_shading
65 ARB_sampler_objects
66 ARB_seamless_cube_map
67 ARB_shader_bit_encoding
68 ARB_shader_objects
69 ARB_shader_subroutine
70 ARB_shader_texture_lod
71 ARB_shading_language_100
72 ARB_shading_language_include
73 ARB_shadow
74 ARB_shadow_ambient
75 ARB_sync
76 ARB_tessellation_shader
77 ARB_texture_border_clamp
78 ARB_texture_buffer_object
79 ARB_texture_buffer_object_rgb32
80 ARB_texture_compression
81 ARB_texture_compression_bptc
82 ARB_texture_compression_rgtc
83 ARB_texture_cube_map
84 ARB_texture_cube_map_array
85 ARB_texture_env_add
86 ARB_texture_env_combine
87 ARB_texture_env_crossbar
88 ARB_texture_env_dot3
89 ARB_texture_float
90 ARB_texture_gather
91 ARB_texture_mirrored_repeat
92 ARB_texture_multisample
93 ARB_texture_non_power_of_two
94 ARB_texture_query_lod
95 ARB_texture_rectangle
96 ARB_texture_rg
97 ARB_texture_rgb10_a2ui
98 ARB_texture_swizzle
99 ARB_timer_query
100 ARB_transform_feedback2
101 ARB_transform_feedback3
102 ARB_transpose_matrix
103 ARB_uniform_buffer_object
104 ARB_vertex_array_bgra
105 ARB_vertex_array_object
106 ARB_vertex_blend
107 ARB_vertex_buffer_object
108 ARB_vertex_program
109 ARB_vertex_shader
110 ARB_vertex_type_2_10_10_10_rev
111 ARB_window_pos

112 ATIX_point_sprites
113 ATIX_texture_env_combine3
114 ATIX_texture_env_route
115 ATIX_vertex_shader_output_point_size

116 ATI_draw_buffers
117 ATI_element_array
118 ATI_envmap_bumpmap
119 ATI_fragment_shader
120 ATI_map_object_buffer
121 ATI_meminfo
122 ATI_pn_triangles
123 ATI_separate_stencil
124 ATI_shader_texture_lod
125 ATI_text_fragment_shader
126 ATI_texture_compression_3dc
127 ATI_texture_env_combine3
128 ATI_texture_float
129 ATI_texture_mirror_once
130 ATI_vertex_array_object
131 ATI_vertex_attrib_array_object
132 ATI_vertex_streams

133 EXT_422_pixels
134 EXT_Cg_shader
135 EXT_abgr
136 EXT_bgra
137 EXT_bindable_uniform
138 EXT_blend_color
139 EXT_blend_equation_separate
140 EXT_blend_func_separate
141 EXT_blend_logic_op
142 EXT_blend_minmax
143 EXT_blend_subtract
144 EXT_clip_volume_hint
145 EXT_cmyka
146 EXT_color_subtable
147 EXT_compiled_vertex_array
148 EXT_convolution
149 EXT_coordinate_frame
150 EXT_copy_texture
151 EXT_cull_vertex
152 EXT_depth_bounds_test
153 EXT_direct_state_access
154 EXT_draw_buffers2
155 EXT_draw_instanced
156 EXT_draw_range_elements
157 EXT_fog_coord
158 EXT_fragment_lighting
159 EXT_framebuffer_blit
160 EXT_framebuffer_multisample
161 EXT_framebuffer_object
162 EXT_framebuffer_sRGB
163 EXT_geometry_shader4
164 EXT_gpu_program_parameters
165 EXT_gpu_shader4
166 EXT_histogram
167 EXT_index_array_formats
168 EXT_index_func
169 EXT_index_material
170 EXT_index_texture
171 EXT_light_texture
172 EXT_misc_attribute
173 EXT_multi_draw_arrays
174 EXT_multisample
175 EXT_packed_depth_stencil
176 EXT_packed_float
177 EXT_packed_pixels
178 EXT_paletted_texture
179 EXT_pixel_buffer_object
180 EXT_pixel_transform
181 EXT_pixel_transform_color_table
182 EXT_point_parameters
183 EXT_polygon_offset
184 EXT_provoking_vertex
185 EXT_rescale_normal
186 EXT_scene_marker
187 EXT_secondary_color
188 EXT_separate_shader_objects
189 EXT_separate_specular_color
190 EXT_shader_image_load_store
191 EXT_shadow_funcs
192 EXT_shared_texture_palette
193 EXT_stencil_clear_tag
194 EXT_stencil_two_side
195 EXT_stencil_wrap
196 EXT_subtexture
197 EXT_texture
198 EXT_texture3D
199 EXT_texture_array
200 EXT_texture_buffer_object
201 EXT_texture_compression_dxt1
202 EXT_texture_compression_latc
203 EXT_texture_compression_rgtc
204 EXT_texture_compression_s3tc
205 EXT_texture_cube_map
206 EXT_texture_edge_clamp
207 EXT_texture_env
208 EXT_texture_env_add
209 EXT_texture_env_combine
210 EXT_texture_env_dot3
211 EXT_texture_filter_anisotropic
212 EXT_texture_integer
213 EXT_texture_lod_bias
214 EXT_texture_mirror_clamp
215 EXT_texture_object
216 EXT_texture_perturb_normal
217 EXT_texture_rectangle
218 EXT_texture_sRGB
219 EXT_texture_shared_exponent
220 EXT_texture_snorm
221 EXT_texture_swizzle
222 EXT_timer_query
223 EXT_transform_feedback
224 EXT_vertex_array
225 EXT_vertex_array_bgra
226 EXT_vertex_attrib_64bit
227 EXT_vertex_shader
228 EXT_vertex_weighting

229 GREMEDY_frame_terminator
230 GREMEDY_string_marker

231 HP_convolution_border_modes
232 HP_image_transform
233 HP_occlusion_test
234 HP_texture_lighting

235 IBM_cull_vertex
236 IBM_multimode_draw_arrays
237 IBM_rasterpos_clip
238 IBM_static_data
239 IBM_texture_mirrored_repeat
240 IBM_vertex_array_lists

241 INGR_color_clamp
242 INGR_interlace_read

243 INTEL_parallel_arrays
244 INTEL_texture_scissor

245 KTX_buffer_region

246 MESAX_texture_stack

247 MESA_pack_invert
248 MESA_resize_buffers
249 MESA_window_pos
250 MESA_ycbcr_texture

251 NV_blend_square
252 NV_conditional_render
253 NV_copy_depth_to_color
254 NV_copy_image
255 NV_depth_buffer_float
256 NV_depth_clamp
257 NV_depth_range_unclamped
258 NV_evaluators
259 NV_explicit_multisample
260 NV_fence
261 NV_float_buffer
262 NV_fog_distance
263 NV_fragment_program
264 NV_fragment_program2
265 NV_fragment_program4
266 NV_fragment_program_option
267 NV_framebuffer_multisample_coverage
268 NV_geometry_program4
269 NV_geometry_shader4
270 NV_gpu_program4
271 NV_gpu_program5
272 NV_gpu_program_fp64
273 NV_gpu_shader5
274 NV_half_float
275 NV_light_max_exponent
276 NV_multisample_filter_hint
277 NV_occlusion_query
278 NV_packed_depth_stencil
279 NV_parameter_buffer_object
280 NV_parameter_buffer_object2
281 NV_pixel_data_range
282 NV_point_sprite
283 NV_present_video
284 NV_primitive_restart
285 NV_register_combiners
286 NV_register_combiners2
287 NV_shader_buffer_load
288 NV_tessellation_program5
289 NV_texgen_emboss
290 NV_texgen_reflection
291 NV_texture_barrier
292 NV_texture_compression_vtc
293 NV_texture_env_combine4
294 NV_texture_expand_normal
295 NV_texture_rectangle
296 NV_texture_shader
297 NV_texture_shader2
298 NV_texture_shader3
299 NV_transform_feedback
300 NV_transform_feedback2
301 NV_vertex_array_range
302 NV_vertex_array_range2
303 NV_vertex_attrib_integer_64bit
304 NV_vertex_buffer_unified_memory
305 NV_vertex_program
306 NV_vertex_program1_1
307 NV_vertex_program2
308 NV_vertex_program2_option
309 NV_vertex_program3
310 NV_vertex_program4

311 OES_byte_coordinates
312 OES_compressed_paletted_texture
313 OES_read_format
314 OES_single_precision

315 OML_interlace
316 OML_resample
317 OML_subsample

318 PGI_misc_hints
319 PGI_vertex_hints

320 REND_screen_coordinates

321 S3_s3tc

322 SGIS_color_range
323 SGIS_detail_texture
324 SGIS_fog_function
325 SGIS_generate_mipmap
326 SGIS_multisample
327 SGIS_pixel_texture
328 SGIS_point_line_texgen
329 SGIS_sharpen_texture
330 SGIS_texture4D
331 SGIS_texture_border_clamp
332 SGIS_texture_edge_clamp
333 SGIS_texture_filter4
334 SGIS_texture_lod
335 SGIS_texture_select

336 SGIX_async
337 SGIX_async_histogram
338 SGIX_async_pixel
339 SGIX_blend_alpha_minmax
340 SGIX_clipmap
341 SGIX_convolution_accuracy
342 SGIX_depth_texture
343 SGIX_flush_raster
344 SGIX_fog_offset
345 SGIX_fog_texture
346 SGIX_fragment_specular_lighting
347 SGIX_framezoom
348 SGIX_interlace
349 SGIX_ir_instrument1
350 SGIX_list_priority
351 SGIX_pixel_texture
352 SGIX_pixel_texture_bits
353 SGIX_reference_plane
354 SGIX_resample
355 SGIX_shadow
356 SGIX_shadow_ambient
357 SGIX_sprite
358 SGIX_tag_sample_buffer
359 SGIX_texture_add_env
360 SGIX_texture_coordinate_clamp
361 SGIX_texture_lod_bias
362 SGIX_texture_multi_buffer
363 SGIX_texture_range
364 SGIX_texture_scale_bias
365 SGIX_vertex_preclip
366 SGIX_vertex_preclip_hint
367 SGIX_ycrcb

368 SGI_color_matrix
369 SGI_color_table
370 SGI_texture_color_table

371 SUNX_constant_data

372 SUN_convolution_border_modes
373 SUN_global_alpha
374 SUN_mesh_array
375 SUN_read_video_pixels
376 SUN_slice_accum
377 SUN_triangle_list
378 SUN_vertex

379 WIN_phong_shading
380 WIN_specular_fog
381 WIN_swap_hint
+ +
+ + diff --git a/Externals/GLew/doc/glew.png b/Externals/GLew/doc/glew.png new file mode 100644 index 0000000000000000000000000000000000000000..d46550f194988fe99362932b29f48aeded97111e GIT binary patch literal 9298 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 SQv}cd07nix*}k?RB>f+9$xcWB literal 0 HcmV?d00001 diff --git a/Externals/GLew/doc/glew.txt b/Externals/GLew/doc/glew.txt new file mode 100644 index 0000000000..31a31d3dbe --- /dev/null +++ b/Externals/GLew/doc/glew.txt @@ -0,0 +1,28 @@ +The OpenGL Extension Wrangler Library +Copyright (C) 2002-2008, Milan Ikits +Copyright (C) 2002-2008, Marcelo E. Magallon +Copyright (C) 2002, Lev Povalahev +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +* Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. +* The name of the author may be used to endorse or promote products + derived from this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +THE POSSIBILITY OF SUCH DAMAGE. diff --git a/Externals/GLew/doc/glxew.html b/Externals/GLew/doc/glxew.html new file mode 100644 index 0000000000..9818b603a6 --- /dev/null +++ b/Externals/GLew/doc/glxew.html @@ -0,0 +1,166 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Supported GLX Extensions

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
1 3DFX_multisample

2 ARB_create_context
3 ARB_create_context_profile
4 ARB_fbconfig_float
5 ARB_framebuffer_sRGB
6 ARB_get_proc_address
7 ARB_multisample
8 ARB_vertex_buffer_object

9 ATI_pixel_format_float
10 ATI_render_texture

11 EXT_fbconfig_packed_float
12 EXT_framebuffer_sRGB
13 EXT_import_context
14 EXT_scene_marker
15 EXT_swap_control
16 EXT_texture_from_pixmap
17 EXT_visual_info
18 EXT_visual_rating

19 INTEL_swap_event

20 MESA_agp_offset
21 MESA_copy_sub_buffer
22 MESA_pixmap_colormap
23 MESA_release_buffers
24 MESA_set_3dfx_mode

25 NV_copy_image
26 NV_float_buffer
27 NV_present_video
28 NV_swap_group
29 NV_vertex_array_range
30 NV_video_output

31 OML_swap_method
32 OML_sync_control

33 SGIS_blended_overlay
34 SGIS_color_range
35 SGIS_multisample
36 SGIS_shared_multisample

37 SGIX_fbconfig
38 SGIX_hyperpipe
39 SGIX_pbuffer
40 SGIX_swap_barrier
41 SGIX_swap_group
42 SGIX_video_resize
43 SGIX_visual_select_group

44 SGI_cushion
45 SGI_make_current_read
46 SGI_swap_control
47 SGI_video_sync

48 SUN_get_transparent_index
49 SUN_video_resize
+ +
+ + diff --git a/Externals/GLew/doc/gpl.txt b/Externals/GLew/doc/gpl.txt new file mode 100644 index 0000000000..b7b5f53df1 --- /dev/null +++ b/Externals/GLew/doc/gpl.txt @@ -0,0 +1,340 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc. + 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Library General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + , 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Library General +Public License instead of this License. diff --git a/Externals/GLew/doc/index.html b/Externals/GLew/doc/index.html new file mode 100644 index 0000000000..f95035b231 --- /dev/null +++ b/Externals/GLew/doc/index.html @@ -0,0 +1,202 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

+The OpenGL Extension Wrangler Library (GLEW) is a cross-platform +open-source C/C++ extension loading library. GLEW provides efficient +run-time mechanisms for determining which OpenGL extensions are +supported on the target platform. OpenGL core and extension +functionality is exposed in a single header file. GLEW has been +tested on a variety of operating systems, including Windows, Linux, +Mac OS X, FreeBSD, Irix, and Solaris. +

+ +

Download Center

+

+GLEW is distributed +as source and precompiled binaries. The latest release is +1.5.4 +[04-21-10]: +

+

+

+

+ + + +
+ + + + + + + + + + + + + + + +
Source +ZIP |  +TGZ
Binaries +Windows 32-bit |  +64-bit  +
+
+

+

+An up-to-date copy is also available from the project +repository: +

+

+svn co https://glew.svn.sourceforge.net/svnroot/glew/trunk/glew glew +

+ +

Supported Extensions

+

+The latest release contains support for OpenGL 3.3, OpenGL 4.0 and the following extensions: +

+ + +

News

+
    +
  • [04-21-10] GLEW 1.5.4 adds support for OpenGL 3.3, OpenGL 4.0 and new extensions, fixes bugs
  • +
  • [02-28-10] GLEW 1.5.3 fixes minor bugs and adds three new extensions
  • +
  • [12-31-09] GLEW 1.5.2 adds support for OpenGL 3.1, OpenGL 3.2 and new extensions
  • +
  • [11-03-08] GLEW 1.5.1 adds support for OpenGL 3.0 and 31 new extensions
  • +
  • [12-27-07] GLEW 1.5.0 is released under less restrictive licenses
  • +
  • [04-27-07] GLEW 1.4.0 is released
  • +
  • [03-08-07] GLEW is included in the NVIDIA OpenGL SDK
  • +
  • [03-04-07] GLEW 1.3.6 is released
  • +
  • [02-28-07] Repository is migrated to SVN
  • +
  • [02-25-07] GLEW is included in the OpenGL SDK
  • +
  • [11-21-06] GLEW 1.3.5 adds OpenGL 2.1 and NVIDIA G80 extensions
  • +
  • [03-04-06] GLEW 1.3.4 adds support for five new extensions
  • +
  • [05-16-05] GLEW 1.3.3 is released
  • +
  • [03-16-05] GLEW 1.3.2 adds support for GL_APPLE_pixel_buffer
  • +
  • [02-11-05] gljava and sdljava provide a Java binding to OpenGL via GLEW
  • +
  • [02-02-05] GLEW 1.3.1 adds support for GL_EXT_framebuffer_object
  • +
  • [01-04-05] GLEW 1.3.0 adds core OpenGL 2.0 support plus many enhancements
  • +
  • [12-22-04] GLEWpy Python wrapper announced
  • +
  • [12-12-04] Mailing lists created on sourceforge
  • +
  • [12-06-04] GLEW 1.2.5 adds new extensions and support for FreeBSD
  • +
+ +

Links

+ + + +
+ + diff --git a/Externals/GLew/doc/install.html b/Externals/GLew/doc/install.html new file mode 100644 index 0000000000..45d45249b2 --- /dev/null +++ b/Externals/GLew/doc/install.html @@ -0,0 +1,228 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Installation

+ +

+To use the shared library version of GLEW, you need to copy the +headers and libraries into their destination directories. On Windows +this typically boils down to copying: +

+ + + + + + + + + + +
bin/glew32.dll    to    %SystemRoot%/system32
lib/glew32.lib    to    {VC Root}/Lib
include/GL/glew.h    to    {VC Root}/Include/GL
include/GL/wglew.h    to    {VC Root}/Include/GL
+

+

+ +

+where {VC Root} is the Visual C++ root directory, typically +C:/Program Files/Microsoft Visual Studio/VC98 for Visual +Studio 6.0 or C:/Program Files/Microsoft Visual +Studio .NET 2003/Vc7/PlatformSDK for Visual Studio .NET. +

+ +

+On Unix, typing make install will attempt to install GLEW +into /usr/include/GL and /usr/lib. You can +customize the installation target via the GLEW_DEST +environment variable if you do not have write access to these +directories. +

+ +

Building Your Project with GLEW

+

+There are two ways to build your project with GLEW. +

+

Including the source files / project file

+

+The simpler but less flexible way is to include glew.h and +glew.c into your project. On Windows, you also need to +define the GLEW_STATIC preprocessor token when building a +static library or executable, and the GLEW_BUILD preprocessor +token when building a dll. You also need to replace +<GL/gl.h> and <GL/glu.h> with +<glew.h> in your code and set the appropriate include +flag (-I) to tell the compiler where to look for it. For +example: +

+

+#include <glew.h>
+#include <GL/glut.h>
+<gl, glu, and glut functionality is available here>
+

+

+Depending on where you put glew.h you may also need to change +the include directives in glew.c. Note that if you are using +GLEW together with GLUT, you have to include glew.h first. +In addition, glew.h includes glu.h, so you do not +need to include it separately. +

+

+On Windows, you also have the option of adding the supplied project +file glew_static.dsp to your workspace (solution) and compile +it together with your other projects. In this case you also need to +change the GLEW_BUILD preprocessor constant to +GLEW_STATIC when building a static library or executable, +otherwise you get build errors. +

+

+Note that GLEW does not use the C +runtime library, so it does not matter which version (single-threaded, +multi-threaded or multi-threaded DLL) it is linked with (without +debugging information). It is, however, always a good idea to compile all +your projects including GLEW with the same C runtime settings. +

+ +

Using GLEW as a shared library

+ +

+Alternatively, you can use the provided project files / makefile to +build a separate shared library you can link your projects with later. +In this case the best practice is to install glew.h, +glew32.lib, and glew32.dll / libGLEW.so to +where the OpenGL equivalents gl.h, opengl32.lib, and +opengl32.dll / libGL.so are located. Note that you +need administrative privileges to do this. If you do not have +administrator access and your system administrator will not do it for +you, you can install GLEW into your own lib and include subdirectories +and tell the compiler where to find it. Then you can just replace +<GL/gl.h> with <GL/glew.h> in your +program: +

+ +

+#include <GL/glew.h>
+#include <GL/glut.h>
+<gl, glu, and glut functionality is available here>
+

+ +

+or: +

+ +

+#include <GL/glew.h>
+<gl and glu functionality is available here>
+

+ +

+Remember to link your project with glew32.lib, +glu32.lib, and opengl32.lib on Windows and +libGLEW.so, libGLU.so, and libGL.so on +Unix (-lGLEW -lGLU -lGL). +

+ +

+It is important to keep in mind that glew.h includes neither +windows.h nor gl.h. Also, GLEW will warn you by +issuing a preprocessor error in case you have included gl.h, +glext.h, or glATI.h before glew.h. +

+ + +
+ + diff --git a/Externals/GLew/doc/khronos.txt b/Externals/GLew/doc/khronos.txt new file mode 100644 index 0000000000..ffc271c915 --- /dev/null +++ b/Externals/GLew/doc/khronos.txt @@ -0,0 +1,20 @@ +Copyright (c) 2007 The Khronos Group Inc. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and/or associated documentation files (the +"Materials"), to deal in the Materials without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Materials, and to +permit persons to whom the Materials are furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be included +in all copies or substantial portions of the Materials. + +THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. diff --git a/Externals/GLew/doc/log.html b/Externals/GLew/doc/log.html new file mode 100644 index 0000000000..610a7696d8 --- /dev/null +++ b/Externals/GLew/doc/log.html @@ -0,0 +1,704 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Change Log

+ +
+
    +
  • 1.5.4 [04-21-10] +
      +
    • New features: +
        +
      • Support for OpenGL 3.3 +
      • Support for OpenGL 4.0 +
      +
    • New extensions: +
        +
      • GL_AMD_conservative_depth +
      • GL_ARB_blend_func_extended +
      • GL_ARB_draw_indirect +
      • GL_ARB_explicit_attrib_location +
      • GL_ARB_gpu_shader5 +
      • GL_ARB_gpu_shader_fp64 +
      • GL_ARB_occlusion_query2 +
      • GL_ARB_sampler_objects +
      • GL_ARB_shader_bit_encoding +
      • GL_ARB_shader_subroutine +
      • GL_ARB_shading_language_include +
      • GL_ARB_tessellation_shader +
      • GL_ARB_texture_buffer_object_rgb32 +
      • GL_ARB_texture_compression_bptc +
      • GL_ARB_texture_rgb10_a2ui +
      • GL_ARB_texture_swizzle +
      • GL_ARB_timer_query +
      • GL_ARB_transform_feedback2 +
      • GL_ARB_transform_feedback3 +
      • GL_ARB_vertex_type_2_10_10_10_rev +
      • GL_EXT_shader_image_load_store +
      • GL_EXT_vertex_attrib_64bit +
      • GL_NV_gpu_program5 +
      • GL_NV_gpu_program_fp64 +
      • GL_NV_gpu_shader5 +
      • GL_NV_tessellation_program5 +
      • GL_NV_vertex_attrib_integer_64bit +
      • GLX_ARB_vertex_buffer_object +
      +
    • Bug fixes: +
        +
      • Parameter constness fix for glPointParameteriv and glPointParameterfv +
      +
    +
+ +
+
    +
  • 1.5.3 [02-28-10] +
      +
    • New extensions: +
        +
      • GLX_INTEL_swap_event +
      • GL_AMD_seamless_cubemap_per_texture +
      • GL_AMD_shader_stencil_export +
      +
    • Bug fixes: +
        +
      • Correct version detection for GL 3.1 and 3.2 +
      • Missing 3.1 enumerants +
      • Add glew.pc +
      +
    +
+ +
+
    +
  • 1.5.2 [12-31-09] +
      +
    • New features: +
        +
      • Support for OpenGL 3.1 +
      • Support for OpenGL 3.2 +
      +
    • New extensions: +
        +
      • GL_AMD_draw_buffers_blend +
      • GL_AMD_performance_monitor +
      • GL_AMD_texture_texture4 +
      • GL_AMD_vertex_shader_tessellator +
      • GL_APPLE_aux_depth_stencil +
      • GL_APPLE_object_purgeable +
      • GL_APPLE_rgb_422 +
      • GL_APPLE_row_bytes +
      • GL_APPLE_vertex_program_evaluators +
      • GL_ARB_compatibility +
      • GL_ARB_copy_buffer +
      • GL_ARB_depth_clamp +
      • GL_ARB_draw_buffers_blend +
      • GL_ARB_draw_elements_base_vertex +
      • GL_ARB_fragment_coord_conventions +
      • GL_ARB_provoking_vertex +
      • GL_ARB_sample_shading +
      • GL_ARB_seamless_cube_map +
      • GL_ARB_shader_texture_lod +
      • GL_ARB_sync +
      • GL_ARB_texture_cube_map_array +
      • GL_ARB_texture_gather +
      • GL_ARB_texture_multisample +
      • GL_ARB_texture_query_lod +
      • GL_ARB_uniform_buffer_object +
      • GL_ARB_vertex_array_bgra +
      • GL_ATI_meminfo +
      • GL_EXT_provoking_vertex +
      • GL_EXT_separate_shader_objects +
      • GL_EXT_texture_snorm +
      • GL_NV_copy_image +
      • GL_NV_parameter_buffer_object2 +
      • GL_NV_shader_buffer_load +
      • GL_NV_texture_barrier +
      • GL_NV_transform_feedback2 +
      • GL_NV_vertex_buffer_unified_memory +
      • WGL_AMD_gpu_association +
      • WGL_ARB_create_context_profile +
      • WGL_NV_copy_image +
      • GLX_ARB_create_context_profile +
      • GLX_EXT_swap_control +
      • GLX_NV_copy_image +
      +
    • Bug fixes: +
        +
      • DOS line endings for windows .zip archives only. +
      • glTransformFeedbackVaryings arguments. +
      • Resource leak in glewinfo and visualinfo tools. +
      • WIN32_LEAN_AND_MEAN preprocessor pollution. +
      • Fixed version detection for GLEW_VERSION_2_1 and GLEW_VERSION_3_0. +
      • MesaGLUT glut.h GLAPIENTRY dependency. +
      • glFramebufferTextureLayer correction. +
      • OSX compiler warnings resolved. +
      • Cygwin linking to opengl32 by default, rather than X11 OpenGL. +
      • SnowLeopard (OSX 10.6) gl.h detection. +
      • Use $(STRIP) consistently. +
      +
    +
+ +
+
    +
  • 1.5.1 [11-03-08] +
      +
    • New features: +
        +
      • Support for OpenGL 3.0 +
      +
    • New extensions: +
        +
      • GL_ARB_depth_buffer_float +
      • GL_ARB_draw_instance, +
      • GL_ARB_framebuffer_object +
      • GL_ARB_framebuffer_sRGB +
      • GL_ARB_geometry_shader4 +
      • GL_ARB_half_float_pixel +
      • GL_ARB_half_float_vertex +
      • GL_ARB_instanced_arrays +
      • GL_ARB_map_buffer_range +
      • GL_ARB_texture_buffer_object +
      • GL_ARB_texture_compression_rgtc +
      • GL_ARB_vertex_array_object +
      • GL_EXT_direct_state_access +
      • GL_EXT_texture_swizzle +
      • GL_EXT_transform_feedback +
      • GL_EXT_vertex_array_bgra +
      • GL_NV_conditional_render +
      • GL_NV_explicit_multisample +
      • GL_NV_present_video +
      • GL_SGIS_point_line_texgen +
      • GL_SGIX_convolution_accuracy +
      • WGL_ARB_create_context +
      • WGL_ARB_framebuffer_sRGB +
      • WGL_NV_present_video +
      • WGL_NV_swap_group +
      • WGL_NV_video_output +
      • GLX_ARB_create_context +
      • GLX_ARB_framebuffer_sRGB +
      • GLX_NV_present_video +
      • GLX_NV_swap_group +
      • GLX_NV_video_output +
      +
    • Bug fixes: +
        +
      • Licensing issues with documentation +
      • Problems with long long and _MSC_VER on MINGW +
      • Incorrect parameter for glGetUniformLocation +
      • glewGetExtension fails on last entry +
      • Incomplete GL_NV_texture_shader tokens +
      • Scripting problems on Cygwin +
      • Incorrect definition for GLint on OS X +
      +
    +
+ +
+
    +
  • 1.5.0 [12-27-07] +
      +
    • New features: +
        +
      • Licensing change (BSD, Mesa 3-D, Khronos) +
      • Switch to using registry on www.opengl.org +
      • Support for major and minor version strings +
      +
    • New extensions: +
        +
      • GL_APPLE_flush_buffer_range +
      • GL_GREMEDY_frame_terminator +
      • GLX_EXT_texture_from_pixmap +
      +
    • Bug fixes: +
        +
      • Incorrent 64-bit type definitions +
      • Do not strip static library on install +
      • Missing tokens in GL_ATI_fragment_shader and WGL_{ARB,EXT}_make_current_read +
      • Missing tokens in GL_VERSION_2_1 +
      • Missing functions in GL_VERSION_1_4 +
      • Incorrect parameter type for glXCopyContext +
      +
    +
+
+
    +
  • 1.4.0 [04-27-07] +
      +
    • New features: +
        +
      • Extension variables are declared const to avoid possible +corruption of their values +
      +
    • New extensions: +
        +
      • GL_NV_depth_range_unclamped +
      +
    • Bug fixes: +
        +
      • Incorrect tokens in GL_NV_transform_feedback and GL_NV_framebuffer_multisample_coverage +
      • Incorrect function names in GL_EXT_gpu_program_parameters +
      • Missing tokens in GL_EXT_framebuffer_multisample +
      • GLEW_MX initialization problem for WGL_{ARB,EXT}_extensions_string +
      +
    +
+
+
    +
  • 1.3.6 [03-04-07] +
      +
    • New extensions: +
        +
      • GL_ATI_shader_texture_lod +
      • GL_EXT_gpu_program_parameters +
      • GL_NV_geometry_shader4 +
      • WGL_NV_gpu_affinity +
      • GLX_SGIX_hyperpipe +
      +
    • Bug fixes: +
        +
      • Missing include guards in glxew.h +
      • Makefile and install problems for Cygwin builds +
      • Install problem for Linux AMD64 builds +
      • Incorrent token in GL_ATI_texture_compression_3dc +
      • Missing tokens from GL_ATIX_point_sprites +
      +
    +
+
+
    +
  • 1.3.5 [11-21-06] +
      +
    • New features: +
        +
      • Support for core OpenGL 2.1 +
      • Debug support for glewIsSupported +
      +
    • New extensions: +
        +
      • GL_EXT_bindable_uniform +
      • GL_EXT_draw_buffers2 +
      • GL_EXT_draw_instanced +
      • GL_EXT_framebuffer_sRGB +
      • GL_EXT_geometry_shader4 +
      • GL_EXT_gpu_shader4 +
      • GL_EXT_packed_float +
      • GL_EXT_texture_array +
      • GL_EXT_texture_buffer_object +
      • GL_EXT_texture_compression_latc +
      • GL_EXT_texture_compression_rgtc +
      • GL_EXT_texture_integer +
      • GL_EXT_texture_shared_exponent +
      • GL_EXT_timer_query +
      • GL_NV_depth_buffer_float +
      • GL_NV_fragment_program4 +
      • GL_NV_framebuffer_multisample_coverage +
      • GL_NV_geometry_program4 +
      • GL_NV_gpu_program4 +
      • GL_NV_parameter_buffer_object +
      • GL_NV_transform_feedback +
      • GL_NV_vertex_program4 +
      • GL_OES_byte_coordinates +
      • GL_OES_compressed_paletted_texture +
      • GL_OES_read_format +
      • GL_OES_single_precision +
      • WGL_EXT_pixel_format_packed_float +
      • WGL_EXT_framebuffer_sRGB +
      • GLX_EXT_fbconfig_packed_float +
      • GLX_EXT_framebuffer_sRGB +
      +
    • Bug fixes: +
        +
      • Wrong GLXContext definition on Solaris +
      • Makefile problem for parallel builds +
      +
    +
+
+
    +
  • 1.3.4 [03-04-06] +
      +
    • New extensions: +
        +
      • GL_EXT_framebuffer_blit +
      • GL_EXT_framebuffer_multisample +
      • GL_EXT_packed_depth_stencil +
      • GL_MESAX_texture_stack +
      • WGL_3DL_stereo_control +
      +
    +
      +
    • Bug fixes: +
        +
      • glBlendEquation missing from GL_ARB_imaging +
      • Wrong APIENTRY definition for Cygwin +
      • Incorrect OS X OpenGL types +
      • Unix 64-bit installation patch +
      +
    +
+
+
    +
  • 1.3.3 [05-16-05] +
      +
    • New feature: +
        +
      • Code generation option to split source into multiple files +
      +
    +
      +
    • Bug fixes: +
        +
      • OpenGL 2.0 core initialization problems +
      • Wrong value for token GL_SHADER_TYPE +
      • Missing tokens in GL_ATI_fragment_shader +
      • Missing entry points in GL_ARB_transpose_matrix +
      +
    +
+
+
    +
  • 1.3.2 [03-16-05] +
      +
    • New extension: +
        +
      • GL_APPLE_pixel_buffer +
      +
    • Bug fixes: +
        +
      • Missing OpenGL 2.0 entry points +
      • Missing tokens in GL_SGIX_shadow +
      • MinGW makefile problem +
      • Check for incorrect OpenGL version string on SiS hardware +
      • Documentation update to meet the HTML 4.01 Transitional specification +
      +
    +
+
+
    +
  • 1.3.1 [02-02-05] +
      +
    • New features: +
        +
      • Consistent Unix and Windows versioning +
      +
    • New extensions: +
        +
      • GL_EXT_framebuffer_object +
      • GL_ARB_pixel_buffer_object +
      +
    • Bug fixes: +
        +
      • Missing OpenGL 2.0 tokens +
      • Incorrect typedefs (GLhandleARB and GLhalf) +
      • Borland compiler problems +
      +
    +
+
+
    +
  • 1.3.0 [01-04-05] +
      +
    • New features: +
        +
      • Support for core OpenGL 2.0 +
      • glewIsSupported provides efficient string-based extension checks +
      • Custom code generation from a list of extensions +
      • Makefile changes +
      +
    • New extensions: +
        +
      • WGL_ATI_render_texture_rectangle +
      +
    • Bug fixes: +
        +
      • Incorrect function signature in OpenGL 1.5 core +
      +
    +
+
+
    +
  • 1.2.5 [12-06-04] +
      +
    • New extensions: +
        +
      • GL_ATI_texture_compression_3dc +
      • GL_EXT_Cg_shader +
      • GL_EXT_draw_range_elements +
      • GL_KTX_buffer_region +
      +
    • Bug fixes: +
        +
      • OpenGL version detection bug +
      • Problems with wxWindows and MinGW compilation +
      • visualinfo compilation problem with GLEW_MX specified +
      • Wrong token name in OpenGL 1.5 core +
      +
    • Support for FreeBSD +
    +
+
+
    +
  • 1.2.4 [09-06-04] +
      +
    • Added ARB_draw_buffers and ARB_texture_rectangle +
    • Fixed bug in ARB_shader_objects +
    • Replaced wglinfo with visualinfo +
    +
+
+
    +
  • 1.2.3 [06-10-04] +
      +
    • Added GL_NV_fragment_program2, GL_NV_fragment_program_option, GL_NV_vertex_program2_option, GL_NV_vertex_program3 +
    • Bug fix in GL_ARB_vertex_blend +
    +
+
+
    +
  • 1.2.2 [05-08-04] +
      +
    • Added GL_EXT_pixel_buffer_object, removed GL_NV_element_array +
    • Fixed GLEW_MX problems +
    • Bug fix in GL_EXT_texture_rectangle and wglinfo +
    +
+
+
    +
  • 1.2.1 [03-18-04] +
      +
    • Bug fix in OpenGL version query (early release of 1.2.0 contained this bug) +
    • Bug fix in GL_ARB_shader_objects and temporary bug fix in GL_ARB_vertex_shader +
    • Added flags on GDI support and multisampling to wglinfo +
    +
+
+
    +
  • 1.2.0 [02-19-04] +
      +
    • Added full OpenGL 1.5 support +
    • Added support for multiple rendering contexts with different capabilities +
    • Added command line flags to glewinfo for selecting displays and visuals +
    • Added GLX_SGIS_multisample, GLX_SUN_video_resize, and GL_SUN_read_video_pixels +
    • Added MinGW/MSYS support +
    • Bug fixes in GL_ARB_shader_objects and the OS X build +
    +
+
+
    +
  • 1.1.4 [12-15-03] +
      +
    • Added GL_APPLE_float_pixels, GL_APPLE_texture_range, +GL_EXT_texture_cube_map, GL_EXT_texture_edge_clamp, +GLX_ATI_pixel_format_float, and GLX_ATI_render_texture +
    • Bug fixes in GL_ATI_map_object_buffer and GL_ATI_fragment_shader +
    +
+
+
    +
  • 1.1.3 [10-28-03] +
      +
    • Added Solaris and Darwin support +
    • Added GL_ARB_fragment_shader, GL_ARB_shader_objects, and GL_ARB_vertex_shader +
    • Fixed bug in GL_WIN_swap_hint +
    • Removed glewinfo's dependency on GLUT +
    +
+
+
    +
  • 1.1.2 [09-15-03] +
      +
    • Removed dependency on WGL_{ARB,EXT}_extensions_string to make GLEW run on Matrox cards +
    • Added glewGetString for querying the GLEW version string +
    +
+
+
    +
  • 1.1.1 [08-11-03] +
      +
    • Added GLX_NV_float_buffer, GL_ARB_shading_language_100, and GL_ARB_texture_non_power_of_two +
    • Fixed bug in GL_ARB_vertex_buffer_object +
    • Minor updates in documentation +
    +
+
+
    +
  • 1.1.0 [07-08-03] +
      +
    • Added automatic code generation +
    • Added almost every extension in the registry +
    • Added separate namespace +
    • Added Irix support +
    • Updated documentation +
    +
+
+
    +
  • 1.0.7 [06-29-03] +
      +
    • Added GL_EXT_depth_bounds_test +
    • Fixed typos +
    +
+
+
    +
  • 1.0.6 [05-05-03] +
      +
    • Added ARB_vertex_buffer_object and NV_half_float +
    • Updated wglinfo +
    • Temporary Linux bug fixes (problems with SDL and MESA) +
    +
+
+
    +
  • 1.0.5 [02-17-03] +
      +
    • Bug fixes +
    • Added wglinfo +
    • Updated documentation +
    +
+
+
    +
  • 1.0.4 [02-02-03] +
      +
    • Added NV_texture_expand_normal +
    • Added mingw support +
    • Updated documentation +
    +
+
+
    +
  • 1.0.3 [01-09-03] +
      +
    • Cleaned up ATI extensions +
    • Changed function prototypes to match glext.h +
    • Added EXT_texture3D +
    • Fixed typos in ATI_vertex_attrib_array_object and ATI_draw_buffers +
    +
+
+
    +
  • 1.0.2 [12-21-02] +
      +
    • Added list of supported extensions to documentation +
    • Added NV_half_float and NV_texgen_emboss +
    +
+
+
    +
  • 1.0.1 [12-17-02] +
      +
    • Bug fixes +
    • Added glewGetExtension +
    +
+
+
    +
  • 1.0.0 [12-12-02] +
      +
    • Initial release +
    +
+
+ + +
+ + diff --git a/Externals/GLew/doc/mesa.txt b/Externals/GLew/doc/mesa.txt new file mode 100644 index 0000000000..a82dd4bd44 --- /dev/null +++ b/Externals/GLew/doc/mesa.txt @@ -0,0 +1,21 @@ +Mesa 3-D graphics library +Version: 7.0 + +Copyright (C) 1999-2007 Brian Paul All Rights Reserved. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the "Software"), +to deal in the Software without restriction, including without limitation +the rights to use, copy, modify, merge, publish, distribute, sublicense, +and/or sell copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included +in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN +AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Externals/GLew/doc/new.png b/Externals/GLew/doc/new.png new file mode 100644 index 0000000000000000000000000000000000000000..7ce2b47960a7085d7e599044ae16187cdd79153a GIT binary patch literal 1180 zcmeAS@N?(olHy`uVBq!ia0vp^l0eME!3-o9=sc?gQk(@Ik;M!Q+`=Ht$S`Y;1W=GA z-O<;Pfnj4`&F{d;K)yn~JGFCa<74&D@oYeyX$c9*zYc!<&#ugD zEX;h`K5fE3d!7AtAbrBj%8&UMxaGCg^YE;B^S_bhGyeiTHjt*I2Wij#@s`{#4`Wk1 zcAm$Fr+$BdfkAy*0t1JF+Jam2V}O}iVy5K2zYp1VP2u#YVZOw`c!VS5Vy&Rj?)<-SyMXD!>frJ-_3sASzYj7t}CiK1p=3en~oMXMs0 zp<*ct%eofjl3TJ-(qdI^m2LK5SM7iMo##By?|HxX{oe2Ue&+~!1;YTbG`BDZ5C#BG z^Z|kiKrsvUV21$+U;zMzC^Q9>j6DP0y?|#8ia;VF-fI{{IaegvG-cAr$-% zyi7#UDPi1KI0RrU1%pFmWT|v@8d?~_U@-(7?w?{11_l&a4J!7qoUyIjV@;Yo9g$Iw zwoA&XHPNDe?Ybnep+RT?ECyP2fR@y#5;=^jl5$F?YX$v)1fw(xOhH%vF~{!Kxt)s! z?%_keW6F^I80R_JiZSj!yu+@s%A>_gC*>(!?^49Er%`#T7;Q9&4Uw z-EIlfky)}8LTeJxnIIg-y2UN(Ramxv8>^DkK%xQ=`xS0V{X=6p_H^~XW^`TSKPWN)tgl3YJ<~ubbI;-Vdj4CXCJwVady>xra zWO-bIaf9DJezwZYvKeN{Y>%_OxVSEq)8$u&oGBaVJCs-P>Ev=6UP{|LCtKbuuCsYb zwrcIZCe7;iKX5a-ePBh8!80*>E8H(f2trZ5ZBbvR1FLx?Cep3^o7pM8W1yVqJ;&VP zxuC_&2d{_Lf9$Aww>3yM182byPn0$qh<80wNYD-;>8IAc9ez4u`zii@+Gve>{khq$ z>G5AK9Q|WqyYh4~xi2D*^_k(Ly&s9lqx9v<^(L{2#--+t@6xRN%su9{9W+|Ks91BC z39Sda0z3w;C)+Y^&QP_oJ9s_D{_I%W_<-~mi7|fKMaSdGY~RNL0TNdU75ZmY%lw#( zllY9a?gx1#8^gF2ao%d>e(KHl3ZC>`R^_^cDE>6vm^%2E%kr=g3^8R>YMt0FKHaB1 zW>hs}f-J|pg_)d6Id<;xb&HZ8bqCVG0~J-*Zs(j<#}uTJWY3u*XPYPbpx#jvR$LA4Pc<>()X8nt`|KPF>{P;;dAT~9_is`OE)U>Od*|$Lt~cMlxqRfd zOjS~u*^y%P{tKGi zxAIr+b%`2l7=CRb>V&wl&l$rfPWVM(Q%zny9}ZOaeLHr>CTsVC<=7hmK>1((2_$yc zC?{l=;wf!lLZw(C7DIg`$M^!SzkT$|cdU_yaEySHfAJ9MAl{-{U?PU|tUl?g>!nO-738Ql%gH zTo<-ge()QhXCy`ef zqflsIxci3Yjr@#CFDbs(hM{>8iHSsr9!1Kqd>DF^R2HtmQ+;tPa^*XN(d8o?14x#X&d7--kaK%y3_cy2dRU7~S literal 0 HcmV?d00001 diff --git a/Externals/GLew/doc/wglew.html b/Externals/GLew/doc/wglew.html new file mode 100644 index 0000000000..a8ebe0f93e --- /dev/null +++ b/Externals/GLew/doc/wglew.html @@ -0,0 +1,156 @@ + + + + + + +GLEW: The OpenGL Extension Wrangler Library + + + + + + + + +
+ + + + + + + + +
+ + + + + + + +
Latest Release: 1.5.4

GLEW Logo

+ + + + + + + + + + +
Download
Installation
Basic Usage
Advanced Usage
Credits & Copyright
Change Log
Project Page
Mailing Lists
Bug Tracker
+

+
+ + + + + +
Last Update: 04-21-10
+ OpenGL Logo + SourceForge Logo +
+
+
+ +

The OpenGL Extension Wrangler Library

+ + + + +

Supported WGL Extensions

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
1 3DFX_multisample

2 3DL_stereo_control

3 AMD_gpu_association

4 ARB_buffer_region
5 ARB_create_context
6 ARB_create_context_profile
7 ARB_extensions_string
8 ARB_framebuffer_sRGB
9 ARB_make_current_read
10 ARB_multisample
11 ARB_pbuffer
12 ARB_pixel_format
13 ARB_pixel_format_float
14 ARB_render_texture

15 ATI_pixel_format_float
16 ATI_render_texture_rectangle

17 EXT_depth_float
18 EXT_display_color_table
19 EXT_extensions_string
20 EXT_framebuffer_sRGB
21 EXT_make_current_read
22 EXT_multisample
23 EXT_pbuffer
24 EXT_pixel_format
25 EXT_pixel_format_packed_float
26 EXT_swap_control

27 I3D_digital_video_control
28 I3D_gamma
29 I3D_genlock
30 I3D_image_buffer
31 I3D_swap_frame_lock
32 I3D_swap_frame_usage

33 NV_copy_image
34 NV_float_buffer
35 NV_gpu_affinity
36 NV_present_video
37 NV_render_depth_texture
38 NV_render_texture_rectangle
39 NV_swap_group
40 NV_vertex_array_range
41 NV_video_output

42 OML_sync_control
+ +
+ + diff --git a/Externals/GLew/glew.pc.in b/Externals/GLew/glew.pc.in new file mode 100644 index 0000000000..4979fb0504 --- /dev/null +++ b/Externals/GLew/glew.pc.in @@ -0,0 +1,10 @@ +prefix=@prefix@ +exec_prefix=@exec_prefix@ +libdir=@libdir@ +includedir=@includedir@ + +Name: glew +Description: The OpenGL Extension Wrangler library +Version: @version@ +Cflags: -I${includedir} +Libs: -L${libdir} -lGLEW diff --git a/Externals/GLew/include/GL/glew.h b/Externals/GLew/include/GL/glew.h new file mode 100644 index 0000000000..189270e64d --- /dev/null +++ b/Externals/GLew/include/GL/glew.h @@ -0,0 +1,14435 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + +/* + * Mesa 3-D graphics library + * Version: 7.0 + * + * Copyright (C) 1999-2007 Brian Paul All Rights Reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included + * in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN + * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + +/* +** Copyright (c) 2007 The Khronos Group Inc. +** +** Permission is hereby granted, free of charge, to any person obtaining a +** copy of this software and/or associated documentation files (the +** "Materials"), to deal in the Materials without restriction, including +** without limitation the rights to use, copy, modify, merge, publish, +** distribute, sublicense, and/or sell copies of the Materials, and to +** permit persons to whom the Materials are furnished to do so, subject to +** the following conditions: +** +** The above copyright notice and this permission notice shall be included +** in all copies or substantial portions of the Materials. +** +** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. +*/ + +#ifndef __glew_h__ +#define __glew_h__ +#define __GLEW_H__ + +#if defined(__gl_h_) || defined(__GL_H__) || defined(__X_GL_H) +#error gl.h included before glew.h +#endif +#if defined(__glext_h_) || defined(__GLEXT_H_) +#error glext.h included before glew.h +#endif +#if defined(__gl_ATI_h_) +#error glATI.h included before glew.h +#endif + +#define __gl_h_ +#define __GL_H__ +#define __X_GL_H +#define __glext_h_ +#define __GLEXT_H_ +#define __gl_ATI_h_ + +#if defined(_WIN32) + +/* + * GLEW does not include to avoid name space pollution. + * GL needs GLAPI and GLAPIENTRY, GLU needs APIENTRY, CALLBACK, and wchar_t + * defined properly. + */ +/* */ +#ifndef APIENTRY +#define GLEW_APIENTRY_DEFINED +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define APIENTRY __stdcall +# elif (_MSC_VER >= 800) || defined(_STDCALL_SUPPORTED) || defined(__BORLANDC__) +# define APIENTRY __stdcall +# else +# define APIENTRY +# endif +#endif +#ifndef GLAPI +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define GLAPI extern +# endif +#endif +/* */ +#ifndef CALLBACK +#define GLEW_CALLBACK_DEFINED +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define CALLBACK __attribute__ ((__stdcall__)) +# elif (defined(_M_MRX000) || defined(_M_IX86) || defined(_M_ALPHA) || defined(_M_PPC)) && !defined(MIDL_PASS) +# define CALLBACK __stdcall +# else +# define CALLBACK +# endif +#endif +/* and */ +#ifndef WINGDIAPI +#define GLEW_WINGDIAPI_DEFINED +#define WINGDIAPI __declspec(dllimport) +#endif +/* */ +#if (defined(_MSC_VER) || defined(__BORLANDC__)) && !defined(_WCHAR_T_DEFINED) +typedef unsigned short wchar_t; +# define _WCHAR_T_DEFINED +#endif +/* */ +#if !defined(_W64) +# if !defined(__midl) && (defined(_X86_) || defined(_M_IX86)) && defined(_MSC_VER) && _MSC_VER >= 1300 +# define _W64 __w64 +# else +# define _W64 +# endif +#endif +#if !defined(_PTRDIFF_T_DEFINED) && !defined(_PTRDIFF_T_) +# ifdef _WIN64 +typedef __int64 ptrdiff_t; +# else +typedef _W64 int ptrdiff_t; +# endif +# define _PTRDIFF_T_DEFINED +# define _PTRDIFF_T_ +#endif + +#ifndef GLAPI +# if defined(__MINGW32__) || defined(__CYGWIN__) +# define GLAPI extern +# else +# define GLAPI WINGDIAPI +# endif +#endif + +#ifndef GLAPIENTRY +#define GLAPIENTRY APIENTRY +#endif + +/* + * GLEW_STATIC needs to be set when using the static version. + * GLEW_BUILD is set when building the DLL version. + */ +#ifdef GLEW_STATIC +# define GLEWAPI extern +#else +# ifdef GLEW_BUILD +# define GLEWAPI extern __declspec(dllexport) +# else +# define GLEWAPI extern __declspec(dllimport) +# endif +#endif + +#else /* _UNIX */ + +/* + * Needed for ptrdiff_t in turn needed by VBO. This is defined by ISO + * C. On my system, this amounts to _3 lines_ of included code, all of + * them pretty much harmless. If you know of a way of detecting 32 vs + * 64 _targets_ at compile time you are free to replace this with + * something that's portable. For now, _this_ is the portable solution. + * (mem, 2004-01-04) + */ + +#include + +/* SGI MIPSPro doesn't like stdint.h in C++ mode */ + +#if defined(__sgi) && !defined(__GNUC__) +#include +#else +#include +#endif + +#define GLEW_APIENTRY_DEFINED +#define APIENTRY +#define GLEWAPI extern + +/* */ +#ifndef GLAPI +#define GLAPI extern +#endif +#ifndef GLAPIENTRY +#define GLAPIENTRY +#endif + +#endif /* _WIN32 */ + +#ifdef __cplusplus +extern "C" { +#endif + +/* ----------------------------- GL_VERSION_1_1 ---------------------------- */ + +#ifndef GL_VERSION_1_1 +#define GL_VERSION_1_1 1 + +typedef unsigned int GLenum; +typedef unsigned int GLbitfield; +typedef unsigned int GLuint; +typedef int GLint; +typedef int GLsizei; +typedef unsigned char GLboolean; +typedef signed char GLbyte; +typedef short GLshort; +typedef unsigned char GLubyte; +typedef unsigned short GLushort; +typedef unsigned long GLulong; +typedef float GLfloat; +typedef float GLclampf; +typedef double GLdouble; +typedef double GLclampd; +typedef void GLvoid; +#if defined(_MSC_VER) +# if _MSC_VER < 1400 +typedef __int64 GLint64EXT; +typedef unsigned __int64 GLuint64EXT; +# else +typedef signed long long GLint64EXT; +typedef unsigned long long GLuint64EXT; +# endif +#else +# if defined(__MINGW32__) || defined(__CYGWIN__) +#include +# endif +typedef int64_t GLint64EXT; +typedef uint64_t GLuint64EXT; +#endif +typedef GLint64EXT GLint64; +typedef GLuint64EXT GLuint64; +typedef struct __GLsync *GLsync; + +#define GL_ACCUM 0x0100 +#define GL_LOAD 0x0101 +#define GL_RETURN 0x0102 +#define GL_MULT 0x0103 +#define GL_ADD 0x0104 +#define GL_NEVER 0x0200 +#define GL_LESS 0x0201 +#define GL_EQUAL 0x0202 +#define GL_LEQUAL 0x0203 +#define GL_GREATER 0x0204 +#define GL_NOTEQUAL 0x0205 +#define GL_GEQUAL 0x0206 +#define GL_ALWAYS 0x0207 +#define GL_CURRENT_BIT 0x00000001 +#define GL_POINT_BIT 0x00000002 +#define GL_LINE_BIT 0x00000004 +#define GL_POLYGON_BIT 0x00000008 +#define GL_POLYGON_STIPPLE_BIT 0x00000010 +#define GL_PIXEL_MODE_BIT 0x00000020 +#define GL_LIGHTING_BIT 0x00000040 +#define GL_FOG_BIT 0x00000080 +#define GL_DEPTH_BUFFER_BIT 0x00000100 +#define GL_ACCUM_BUFFER_BIT 0x00000200 +#define GL_STENCIL_BUFFER_BIT 0x00000400 +#define GL_VIEWPORT_BIT 0x00000800 +#define GL_TRANSFORM_BIT 0x00001000 +#define GL_ENABLE_BIT 0x00002000 +#define GL_COLOR_BUFFER_BIT 0x00004000 +#define GL_HINT_BIT 0x00008000 +#define GL_EVAL_BIT 0x00010000 +#define GL_LIST_BIT 0x00020000 +#define GL_TEXTURE_BIT 0x00040000 +#define GL_SCISSOR_BIT 0x00080000 +#define GL_ALL_ATTRIB_BITS 0x000fffff +#define GL_POINTS 0x0000 +#define GL_LINES 0x0001 +#define GL_LINE_LOOP 0x0002 +#define GL_LINE_STRIP 0x0003 +#define GL_TRIANGLES 0x0004 +#define GL_TRIANGLE_STRIP 0x0005 +#define GL_TRIANGLE_FAN 0x0006 +#define GL_QUADS 0x0007 +#define GL_QUAD_STRIP 0x0008 +#define GL_POLYGON 0x0009 +#define GL_ZERO 0 +#define GL_ONE 1 +#define GL_SRC_COLOR 0x0300 +#define GL_ONE_MINUS_SRC_COLOR 0x0301 +#define GL_SRC_ALPHA 0x0302 +#define GL_ONE_MINUS_SRC_ALPHA 0x0303 +#define GL_DST_ALPHA 0x0304 +#define GL_ONE_MINUS_DST_ALPHA 0x0305 +#define GL_DST_COLOR 0x0306 +#define GL_ONE_MINUS_DST_COLOR 0x0307 +#define GL_SRC_ALPHA_SATURATE 0x0308 +#define GL_TRUE 1 +#define GL_FALSE 0 +#define GL_CLIP_PLANE0 0x3000 +#define GL_CLIP_PLANE1 0x3001 +#define GL_CLIP_PLANE2 0x3002 +#define GL_CLIP_PLANE3 0x3003 +#define GL_CLIP_PLANE4 0x3004 +#define GL_CLIP_PLANE5 0x3005 +#define GL_BYTE 0x1400 +#define GL_UNSIGNED_BYTE 0x1401 +#define GL_SHORT 0x1402 +#define GL_UNSIGNED_SHORT 0x1403 +#define GL_INT 0x1404 +#define GL_UNSIGNED_INT 0x1405 +#define GL_FLOAT 0x1406 +#define GL_2_BYTES 0x1407 +#define GL_3_BYTES 0x1408 +#define GL_4_BYTES 0x1409 +#define GL_DOUBLE 0x140A +#define GL_NONE 0 +#define GL_FRONT_LEFT 0x0400 +#define GL_FRONT_RIGHT 0x0401 +#define GL_BACK_LEFT 0x0402 +#define GL_BACK_RIGHT 0x0403 +#define GL_FRONT 0x0404 +#define GL_BACK 0x0405 +#define GL_LEFT 0x0406 +#define GL_RIGHT 0x0407 +#define GL_FRONT_AND_BACK 0x0408 +#define GL_AUX0 0x0409 +#define GL_AUX1 0x040A +#define GL_AUX2 0x040B +#define GL_AUX3 0x040C +#define GL_NO_ERROR 0 +#define GL_INVALID_ENUM 0x0500 +#define GL_INVALID_VALUE 0x0501 +#define GL_INVALID_OPERATION 0x0502 +#define GL_STACK_OVERFLOW 0x0503 +#define GL_STACK_UNDERFLOW 0x0504 +#define GL_OUT_OF_MEMORY 0x0505 +#define GL_2D 0x0600 +#define GL_3D 0x0601 +#define GL_3D_COLOR 0x0602 +#define GL_3D_COLOR_TEXTURE 0x0603 +#define GL_4D_COLOR_TEXTURE 0x0604 +#define GL_PASS_THROUGH_TOKEN 0x0700 +#define GL_POINT_TOKEN 0x0701 +#define GL_LINE_TOKEN 0x0702 +#define GL_POLYGON_TOKEN 0x0703 +#define GL_BITMAP_TOKEN 0x0704 +#define GL_DRAW_PIXEL_TOKEN 0x0705 +#define GL_COPY_PIXEL_TOKEN 0x0706 +#define GL_LINE_RESET_TOKEN 0x0707 +#define GL_EXP 0x0800 +#define GL_EXP2 0x0801 +#define GL_CW 0x0900 +#define GL_CCW 0x0901 +#define GL_COEFF 0x0A00 +#define GL_ORDER 0x0A01 +#define GL_DOMAIN 0x0A02 +#define GL_CURRENT_COLOR 0x0B00 +#define GL_CURRENT_INDEX 0x0B01 +#define GL_CURRENT_NORMAL 0x0B02 +#define GL_CURRENT_TEXTURE_COORDS 0x0B03 +#define GL_CURRENT_RASTER_COLOR 0x0B04 +#define GL_CURRENT_RASTER_INDEX 0x0B05 +#define GL_CURRENT_RASTER_TEXTURE_COORDS 0x0B06 +#define GL_CURRENT_RASTER_POSITION 0x0B07 +#define GL_CURRENT_RASTER_POSITION_VALID 0x0B08 +#define GL_CURRENT_RASTER_DISTANCE 0x0B09 +#define GL_POINT_SMOOTH 0x0B10 +#define GL_POINT_SIZE 0x0B11 +#define GL_POINT_SIZE_RANGE 0x0B12 +#define GL_POINT_SIZE_GRANULARITY 0x0B13 +#define GL_LINE_SMOOTH 0x0B20 +#define GL_LINE_WIDTH 0x0B21 +#define GL_LINE_WIDTH_RANGE 0x0B22 +#define GL_LINE_WIDTH_GRANULARITY 0x0B23 +#define GL_LINE_STIPPLE 0x0B24 +#define GL_LINE_STIPPLE_PATTERN 0x0B25 +#define GL_LINE_STIPPLE_REPEAT 0x0B26 +#define GL_LIST_MODE 0x0B30 +#define GL_MAX_LIST_NESTING 0x0B31 +#define GL_LIST_BASE 0x0B32 +#define GL_LIST_INDEX 0x0B33 +#define GL_POLYGON_MODE 0x0B40 +#define GL_POLYGON_SMOOTH 0x0B41 +#define GL_POLYGON_STIPPLE 0x0B42 +#define GL_EDGE_FLAG 0x0B43 +#define GL_CULL_FACE 0x0B44 +#define GL_CULL_FACE_MODE 0x0B45 +#define GL_FRONT_FACE 0x0B46 +#define GL_LIGHTING 0x0B50 +#define GL_LIGHT_MODEL_LOCAL_VIEWER 0x0B51 +#define GL_LIGHT_MODEL_TWO_SIDE 0x0B52 +#define GL_LIGHT_MODEL_AMBIENT 0x0B53 +#define GL_SHADE_MODEL 0x0B54 +#define GL_COLOR_MATERIAL_FACE 0x0B55 +#define GL_COLOR_MATERIAL_PARAMETER 0x0B56 +#define GL_COLOR_MATERIAL 0x0B57 +#define GL_FOG 0x0B60 +#define GL_FOG_INDEX 0x0B61 +#define GL_FOG_DENSITY 0x0B62 +#define GL_FOG_START 0x0B63 +#define GL_FOG_END 0x0B64 +#define GL_FOG_MODE 0x0B65 +#define GL_FOG_COLOR 0x0B66 +#define GL_DEPTH_RANGE 0x0B70 +#define GL_DEPTH_TEST 0x0B71 +#define GL_DEPTH_WRITEMASK 0x0B72 +#define GL_DEPTH_CLEAR_VALUE 0x0B73 +#define GL_DEPTH_FUNC 0x0B74 +#define GL_ACCUM_CLEAR_VALUE 0x0B80 +#define GL_STENCIL_TEST 0x0B90 +#define GL_STENCIL_CLEAR_VALUE 0x0B91 +#define GL_STENCIL_FUNC 0x0B92 +#define GL_STENCIL_VALUE_MASK 0x0B93 +#define GL_STENCIL_FAIL 0x0B94 +#define GL_STENCIL_PASS_DEPTH_FAIL 0x0B95 +#define GL_STENCIL_PASS_DEPTH_PASS 0x0B96 +#define GL_STENCIL_REF 0x0B97 +#define GL_STENCIL_WRITEMASK 0x0B98 +#define GL_MATRIX_MODE 0x0BA0 +#define GL_NORMALIZE 0x0BA1 +#define GL_VIEWPORT 0x0BA2 +#define GL_MODELVIEW_STACK_DEPTH 0x0BA3 +#define GL_PROJECTION_STACK_DEPTH 0x0BA4 +#define GL_TEXTURE_STACK_DEPTH 0x0BA5 +#define GL_MODELVIEW_MATRIX 0x0BA6 +#define GL_PROJECTION_MATRIX 0x0BA7 +#define GL_TEXTURE_MATRIX 0x0BA8 +#define GL_ATTRIB_STACK_DEPTH 0x0BB0 +#define GL_CLIENT_ATTRIB_STACK_DEPTH 0x0BB1 +#define GL_ALPHA_TEST 0x0BC0 +#define GL_ALPHA_TEST_FUNC 0x0BC1 +#define GL_ALPHA_TEST_REF 0x0BC2 +#define GL_DITHER 0x0BD0 +#define GL_BLEND_DST 0x0BE0 +#define GL_BLEND_SRC 0x0BE1 +#define GL_BLEND 0x0BE2 +#define GL_LOGIC_OP_MODE 0x0BF0 +#define GL_INDEX_LOGIC_OP 0x0BF1 +#define GL_COLOR_LOGIC_OP 0x0BF2 +#define GL_AUX_BUFFERS 0x0C00 +#define GL_DRAW_BUFFER 0x0C01 +#define GL_READ_BUFFER 0x0C02 +#define GL_SCISSOR_BOX 0x0C10 +#define GL_SCISSOR_TEST 0x0C11 +#define GL_INDEX_CLEAR_VALUE 0x0C20 +#define GL_INDEX_WRITEMASK 0x0C21 +#define GL_COLOR_CLEAR_VALUE 0x0C22 +#define GL_COLOR_WRITEMASK 0x0C23 +#define GL_INDEX_MODE 0x0C30 +#define GL_RGBA_MODE 0x0C31 +#define GL_DOUBLEBUFFER 0x0C32 +#define GL_STEREO 0x0C33 +#define GL_RENDER_MODE 0x0C40 +#define GL_PERSPECTIVE_CORRECTION_HINT 0x0C50 +#define GL_POINT_SMOOTH_HINT 0x0C51 +#define GL_LINE_SMOOTH_HINT 0x0C52 +#define GL_POLYGON_SMOOTH_HINT 0x0C53 +#define GL_FOG_HINT 0x0C54 +#define GL_TEXTURE_GEN_S 0x0C60 +#define GL_TEXTURE_GEN_T 0x0C61 +#define GL_TEXTURE_GEN_R 0x0C62 +#define GL_TEXTURE_GEN_Q 0x0C63 +#define GL_PIXEL_MAP_I_TO_I 0x0C70 +#define GL_PIXEL_MAP_S_TO_S 0x0C71 +#define GL_PIXEL_MAP_I_TO_R 0x0C72 +#define GL_PIXEL_MAP_I_TO_G 0x0C73 +#define GL_PIXEL_MAP_I_TO_B 0x0C74 +#define GL_PIXEL_MAP_I_TO_A 0x0C75 +#define GL_PIXEL_MAP_R_TO_R 0x0C76 +#define GL_PIXEL_MAP_G_TO_G 0x0C77 +#define GL_PIXEL_MAP_B_TO_B 0x0C78 +#define GL_PIXEL_MAP_A_TO_A 0x0C79 +#define GL_PIXEL_MAP_I_TO_I_SIZE 0x0CB0 +#define GL_PIXEL_MAP_S_TO_S_SIZE 0x0CB1 +#define GL_PIXEL_MAP_I_TO_R_SIZE 0x0CB2 +#define GL_PIXEL_MAP_I_TO_G_SIZE 0x0CB3 +#define GL_PIXEL_MAP_I_TO_B_SIZE 0x0CB4 +#define GL_PIXEL_MAP_I_TO_A_SIZE 0x0CB5 +#define GL_PIXEL_MAP_R_TO_R_SIZE 0x0CB6 +#define GL_PIXEL_MAP_G_TO_G_SIZE 0x0CB7 +#define GL_PIXEL_MAP_B_TO_B_SIZE 0x0CB8 +#define GL_PIXEL_MAP_A_TO_A_SIZE 0x0CB9 +#define GL_UNPACK_SWAP_BYTES 0x0CF0 +#define GL_UNPACK_LSB_FIRST 0x0CF1 +#define GL_UNPACK_ROW_LENGTH 0x0CF2 +#define GL_UNPACK_SKIP_ROWS 0x0CF3 +#define GL_UNPACK_SKIP_PIXELS 0x0CF4 +#define GL_UNPACK_ALIGNMENT 0x0CF5 +#define GL_PACK_SWAP_BYTES 0x0D00 +#define GL_PACK_LSB_FIRST 0x0D01 +#define GL_PACK_ROW_LENGTH 0x0D02 +#define GL_PACK_SKIP_ROWS 0x0D03 +#define GL_PACK_SKIP_PIXELS 0x0D04 +#define GL_PACK_ALIGNMENT 0x0D05 +#define GL_MAP_COLOR 0x0D10 +#define GL_MAP_STENCIL 0x0D11 +#define GL_INDEX_SHIFT 0x0D12 +#define GL_INDEX_OFFSET 0x0D13 +#define GL_RED_SCALE 0x0D14 +#define GL_RED_BIAS 0x0D15 +#define GL_ZOOM_X 0x0D16 +#define GL_ZOOM_Y 0x0D17 +#define GL_GREEN_SCALE 0x0D18 +#define GL_GREEN_BIAS 0x0D19 +#define GL_BLUE_SCALE 0x0D1A +#define GL_BLUE_BIAS 0x0D1B +#define GL_ALPHA_SCALE 0x0D1C +#define GL_ALPHA_BIAS 0x0D1D +#define GL_DEPTH_SCALE 0x0D1E +#define GL_DEPTH_BIAS 0x0D1F +#define GL_MAX_EVAL_ORDER 0x0D30 +#define GL_MAX_LIGHTS 0x0D31 +#define GL_MAX_CLIP_PLANES 0x0D32 +#define GL_MAX_TEXTURE_SIZE 0x0D33 +#define GL_MAX_PIXEL_MAP_TABLE 0x0D34 +#define GL_MAX_ATTRIB_STACK_DEPTH 0x0D35 +#define GL_MAX_MODELVIEW_STACK_DEPTH 0x0D36 +#define GL_MAX_NAME_STACK_DEPTH 0x0D37 +#define GL_MAX_PROJECTION_STACK_DEPTH 0x0D38 +#define GL_MAX_TEXTURE_STACK_DEPTH 0x0D39 +#define GL_MAX_VIEWPORT_DIMS 0x0D3A +#define GL_MAX_CLIENT_ATTRIB_STACK_DEPTH 0x0D3B +#define GL_SUBPIXEL_BITS 0x0D50 +#define GL_INDEX_BITS 0x0D51 +#define GL_RED_BITS 0x0D52 +#define GL_GREEN_BITS 0x0D53 +#define GL_BLUE_BITS 0x0D54 +#define GL_ALPHA_BITS 0x0D55 +#define GL_DEPTH_BITS 0x0D56 +#define GL_STENCIL_BITS 0x0D57 +#define GL_ACCUM_RED_BITS 0x0D58 +#define GL_ACCUM_GREEN_BITS 0x0D59 +#define GL_ACCUM_BLUE_BITS 0x0D5A +#define GL_ACCUM_ALPHA_BITS 0x0D5B +#define GL_NAME_STACK_DEPTH 0x0D70 +#define GL_AUTO_NORMAL 0x0D80 +#define GL_MAP1_COLOR_4 0x0D90 +#define GL_MAP1_INDEX 0x0D91 +#define GL_MAP1_NORMAL 0x0D92 +#define GL_MAP1_TEXTURE_COORD_1 0x0D93 +#define GL_MAP1_TEXTURE_COORD_2 0x0D94 +#define GL_MAP1_TEXTURE_COORD_3 0x0D95 +#define GL_MAP1_TEXTURE_COORD_4 0x0D96 +#define GL_MAP1_VERTEX_3 0x0D97 +#define GL_MAP1_VERTEX_4 0x0D98 +#define GL_MAP2_COLOR_4 0x0DB0 +#define GL_MAP2_INDEX 0x0DB1 +#define GL_MAP2_NORMAL 0x0DB2 +#define GL_MAP2_TEXTURE_COORD_1 0x0DB3 +#define GL_MAP2_TEXTURE_COORD_2 0x0DB4 +#define GL_MAP2_TEXTURE_COORD_3 0x0DB5 +#define GL_MAP2_TEXTURE_COORD_4 0x0DB6 +#define GL_MAP2_VERTEX_3 0x0DB7 +#define GL_MAP2_VERTEX_4 0x0DB8 +#define GL_MAP1_GRID_DOMAIN 0x0DD0 +#define GL_MAP1_GRID_SEGMENTS 0x0DD1 +#define GL_MAP2_GRID_DOMAIN 0x0DD2 +#define GL_MAP2_GRID_SEGMENTS 0x0DD3 +#define GL_TEXTURE_1D 0x0DE0 +#define GL_TEXTURE_2D 0x0DE1 +#define GL_FEEDBACK_BUFFER_POINTER 0x0DF0 +#define GL_FEEDBACK_BUFFER_SIZE 0x0DF1 +#define GL_FEEDBACK_BUFFER_TYPE 0x0DF2 +#define GL_SELECTION_BUFFER_POINTER 0x0DF3 +#define GL_SELECTION_BUFFER_SIZE 0x0DF4 +#define GL_TEXTURE_WIDTH 0x1000 +#define GL_TEXTURE_HEIGHT 0x1001 +#define GL_TEXTURE_INTERNAL_FORMAT 0x1003 +#define GL_TEXTURE_BORDER_COLOR 0x1004 +#define GL_TEXTURE_BORDER 0x1005 +#define GL_DONT_CARE 0x1100 +#define GL_FASTEST 0x1101 +#define GL_NICEST 0x1102 +#define GL_LIGHT0 0x4000 +#define GL_LIGHT1 0x4001 +#define GL_LIGHT2 0x4002 +#define GL_LIGHT3 0x4003 +#define GL_LIGHT4 0x4004 +#define GL_LIGHT5 0x4005 +#define GL_LIGHT6 0x4006 +#define GL_LIGHT7 0x4007 +#define GL_AMBIENT 0x1200 +#define GL_DIFFUSE 0x1201 +#define GL_SPECULAR 0x1202 +#define GL_POSITION 0x1203 +#define GL_SPOT_DIRECTION 0x1204 +#define GL_SPOT_EXPONENT 0x1205 +#define GL_SPOT_CUTOFF 0x1206 +#define GL_CONSTANT_ATTENUATION 0x1207 +#define GL_LINEAR_ATTENUATION 0x1208 +#define GL_QUADRATIC_ATTENUATION 0x1209 +#define GL_COMPILE 0x1300 +#define GL_COMPILE_AND_EXECUTE 0x1301 +#define GL_CLEAR 0x1500 +#define GL_AND 0x1501 +#define GL_AND_REVERSE 0x1502 +#define GL_COPY 0x1503 +#define GL_AND_INVERTED 0x1504 +#define GL_NOOP 0x1505 +#define GL_XOR 0x1506 +#define GL_OR 0x1507 +#define GL_NOR 0x1508 +#define GL_EQUIV 0x1509 +#define GL_INVERT 0x150A +#define GL_OR_REVERSE 0x150B +#define GL_COPY_INVERTED 0x150C +#define GL_OR_INVERTED 0x150D +#define GL_NAND 0x150E +#define GL_SET 0x150F +#define GL_EMISSION 0x1600 +#define GL_SHININESS 0x1601 +#define GL_AMBIENT_AND_DIFFUSE 0x1602 +#define GL_COLOR_INDEXES 0x1603 +#define GL_MODELVIEW 0x1700 +#define GL_PROJECTION 0x1701 +#define GL_TEXTURE 0x1702 +#define GL_COLOR 0x1800 +#define GL_DEPTH 0x1801 +#define GL_STENCIL 0x1802 +#define GL_COLOR_INDEX 0x1900 +#define GL_STENCIL_INDEX 0x1901 +#define GL_DEPTH_COMPONENT 0x1902 +#define GL_RED 0x1903 +#define GL_GREEN 0x1904 +#define GL_BLUE 0x1905 +#define GL_ALPHA 0x1906 +#define GL_RGB 0x1907 +#define GL_RGBA 0x1908 +#define GL_LUMINANCE 0x1909 +#define GL_LUMINANCE_ALPHA 0x190A +#define GL_BITMAP 0x1A00 +#define GL_POINT 0x1B00 +#define GL_LINE 0x1B01 +#define GL_FILL 0x1B02 +#define GL_RENDER 0x1C00 +#define GL_FEEDBACK 0x1C01 +#define GL_SELECT 0x1C02 +#define GL_FLAT 0x1D00 +#define GL_SMOOTH 0x1D01 +#define GL_KEEP 0x1E00 +#define GL_REPLACE 0x1E01 +#define GL_INCR 0x1E02 +#define GL_DECR 0x1E03 +#define GL_VENDOR 0x1F00 +#define GL_RENDERER 0x1F01 +#define GL_VERSION 0x1F02 +#define GL_EXTENSIONS 0x1F03 +#define GL_S 0x2000 +#define GL_T 0x2001 +#define GL_R 0x2002 +#define GL_Q 0x2003 +#define GL_MODULATE 0x2100 +#define GL_DECAL 0x2101 +#define GL_TEXTURE_ENV_MODE 0x2200 +#define GL_TEXTURE_ENV_COLOR 0x2201 +#define GL_TEXTURE_ENV 0x2300 +#define GL_EYE_LINEAR 0x2400 +#define GL_OBJECT_LINEAR 0x2401 +#define GL_SPHERE_MAP 0x2402 +#define GL_TEXTURE_GEN_MODE 0x2500 +#define GL_OBJECT_PLANE 0x2501 +#define GL_EYE_PLANE 0x2502 +#define GL_NEAREST 0x2600 +#define GL_LINEAR 0x2601 +#define GL_NEAREST_MIPMAP_NEAREST 0x2700 +#define GL_LINEAR_MIPMAP_NEAREST 0x2701 +#define GL_NEAREST_MIPMAP_LINEAR 0x2702 +#define GL_LINEAR_MIPMAP_LINEAR 0x2703 +#define GL_TEXTURE_MAG_FILTER 0x2800 +#define GL_TEXTURE_MIN_FILTER 0x2801 +#define GL_TEXTURE_WRAP_S 0x2802 +#define GL_TEXTURE_WRAP_T 0x2803 +#define GL_CLAMP 0x2900 +#define GL_REPEAT 0x2901 +#define GL_CLIENT_PIXEL_STORE_BIT 0x00000001 +#define GL_CLIENT_VERTEX_ARRAY_BIT 0x00000002 +#define GL_CLIENT_ALL_ATTRIB_BITS 0xffffffff +#define GL_POLYGON_OFFSET_FACTOR 0x8038 +#define GL_POLYGON_OFFSET_UNITS 0x2A00 +#define GL_POLYGON_OFFSET_POINT 0x2A01 +#define GL_POLYGON_OFFSET_LINE 0x2A02 +#define GL_POLYGON_OFFSET_FILL 0x8037 +#define GL_ALPHA4 0x803B +#define GL_ALPHA8 0x803C +#define GL_ALPHA12 0x803D +#define GL_ALPHA16 0x803E +#define GL_LUMINANCE4 0x803F +#define GL_LUMINANCE8 0x8040 +#define GL_LUMINANCE12 0x8041 +#define GL_LUMINANCE16 0x8042 +#define GL_LUMINANCE4_ALPHA4 0x8043 +#define GL_LUMINANCE6_ALPHA2 0x8044 +#define GL_LUMINANCE8_ALPHA8 0x8045 +#define GL_LUMINANCE12_ALPHA4 0x8046 +#define GL_LUMINANCE12_ALPHA12 0x8047 +#define GL_LUMINANCE16_ALPHA16 0x8048 +#define GL_INTENSITY 0x8049 +#define GL_INTENSITY4 0x804A +#define GL_INTENSITY8 0x804B +#define GL_INTENSITY12 0x804C +#define GL_INTENSITY16 0x804D +#define GL_R3_G3_B2 0x2A10 +#define GL_RGB4 0x804F +#define GL_RGB5 0x8050 +#define GL_RGB8 0x8051 +#define GL_RGB10 0x8052 +#define GL_RGB12 0x8053 +#define GL_RGB16 0x8054 +#define GL_RGBA2 0x8055 +#define GL_RGBA4 0x8056 +#define GL_RGB5_A1 0x8057 +#define GL_RGBA8 0x8058 +#define GL_RGB10_A2 0x8059 +#define GL_RGBA12 0x805A +#define GL_RGBA16 0x805B +#define GL_TEXTURE_RED_SIZE 0x805C +#define GL_TEXTURE_GREEN_SIZE 0x805D +#define GL_TEXTURE_BLUE_SIZE 0x805E +#define GL_TEXTURE_ALPHA_SIZE 0x805F +#define GL_TEXTURE_LUMINANCE_SIZE 0x8060 +#define GL_TEXTURE_INTENSITY_SIZE 0x8061 +#define GL_PROXY_TEXTURE_1D 0x8063 +#define GL_PROXY_TEXTURE_2D 0x8064 +#define GL_TEXTURE_PRIORITY 0x8066 +#define GL_TEXTURE_RESIDENT 0x8067 +#define GL_TEXTURE_BINDING_1D 0x8068 +#define GL_TEXTURE_BINDING_2D 0x8069 +#define GL_VERTEX_ARRAY 0x8074 +#define GL_NORMAL_ARRAY 0x8075 +#define GL_COLOR_ARRAY 0x8076 +#define GL_INDEX_ARRAY 0x8077 +#define GL_TEXTURE_COORD_ARRAY 0x8078 +#define GL_EDGE_FLAG_ARRAY 0x8079 +#define GL_VERTEX_ARRAY_SIZE 0x807A +#define GL_VERTEX_ARRAY_TYPE 0x807B +#define GL_VERTEX_ARRAY_STRIDE 0x807C +#define GL_NORMAL_ARRAY_TYPE 0x807E +#define GL_NORMAL_ARRAY_STRIDE 0x807F +#define GL_COLOR_ARRAY_SIZE 0x8081 +#define GL_COLOR_ARRAY_TYPE 0x8082 +#define GL_COLOR_ARRAY_STRIDE 0x8083 +#define GL_INDEX_ARRAY_TYPE 0x8085 +#define GL_INDEX_ARRAY_STRIDE 0x8086 +#define GL_TEXTURE_COORD_ARRAY_SIZE 0x8088 +#define GL_TEXTURE_COORD_ARRAY_TYPE 0x8089 +#define GL_TEXTURE_COORD_ARRAY_STRIDE 0x808A +#define GL_EDGE_FLAG_ARRAY_STRIDE 0x808C +#define GL_VERTEX_ARRAY_POINTER 0x808E +#define GL_NORMAL_ARRAY_POINTER 0x808F +#define GL_COLOR_ARRAY_POINTER 0x8090 +#define GL_INDEX_ARRAY_POINTER 0x8091 +#define GL_TEXTURE_COORD_ARRAY_POINTER 0x8092 +#define GL_EDGE_FLAG_ARRAY_POINTER 0x8093 +#define GL_V2F 0x2A20 +#define GL_V3F 0x2A21 +#define GL_C4UB_V2F 0x2A22 +#define GL_C4UB_V3F 0x2A23 +#define GL_C3F_V3F 0x2A24 +#define GL_N3F_V3F 0x2A25 +#define GL_C4F_N3F_V3F 0x2A26 +#define GL_T2F_V3F 0x2A27 +#define GL_T4F_V4F 0x2A28 +#define GL_T2F_C4UB_V3F 0x2A29 +#define GL_T2F_C3F_V3F 0x2A2A +#define GL_T2F_N3F_V3F 0x2A2B +#define GL_T2F_C4F_N3F_V3F 0x2A2C +#define GL_T4F_C4F_N3F_V4F 0x2A2D +#define GL_LOGIC_OP GL_INDEX_LOGIC_OP +#define GL_TEXTURE_COMPONENTS GL_TEXTURE_INTERNAL_FORMAT +#define GL_COLOR_INDEX1_EXT 0x80E2 +#define GL_COLOR_INDEX2_EXT 0x80E3 +#define GL_COLOR_INDEX4_EXT 0x80E4 +#define GL_COLOR_INDEX8_EXT 0x80E5 +#define GL_COLOR_INDEX12_EXT 0x80E6 +#define GL_COLOR_INDEX16_EXT 0x80E7 + +GLAPI void GLAPIENTRY glAccum (GLenum op, GLfloat value); +GLAPI void GLAPIENTRY glAlphaFunc (GLenum func, GLclampf ref); +GLAPI GLboolean GLAPIENTRY glAreTexturesResident (GLsizei n, const GLuint *textures, GLboolean *residences); +GLAPI void GLAPIENTRY glArrayElement (GLint i); +GLAPI void GLAPIENTRY glBegin (GLenum mode); +GLAPI void GLAPIENTRY glBindTexture (GLenum target, GLuint texture); +GLAPI void GLAPIENTRY glBitmap (GLsizei width, GLsizei height, GLfloat xorig, GLfloat yorig, GLfloat xmove, GLfloat ymove, const GLubyte *bitmap); +GLAPI void GLAPIENTRY glBlendFunc (GLenum sfactor, GLenum dfactor); +GLAPI void GLAPIENTRY glCallList (GLuint list); +GLAPI void GLAPIENTRY glCallLists (GLsizei n, GLenum type, const GLvoid *lists); +GLAPI void GLAPIENTRY glClear (GLbitfield mask); +GLAPI void GLAPIENTRY glClearAccum (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI void GLAPIENTRY glClearColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +GLAPI void GLAPIENTRY glClearDepth (GLclampd depth); +GLAPI void GLAPIENTRY glClearIndex (GLfloat c); +GLAPI void GLAPIENTRY glClearStencil (GLint s); +GLAPI void GLAPIENTRY glClipPlane (GLenum plane, const GLdouble *equation); +GLAPI void GLAPIENTRY glColor3b (GLbyte red, GLbyte green, GLbyte blue); +GLAPI void GLAPIENTRY glColor3bv (const GLbyte *v); +GLAPI void GLAPIENTRY glColor3d (GLdouble red, GLdouble green, GLdouble blue); +GLAPI void GLAPIENTRY glColor3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glColor3f (GLfloat red, GLfloat green, GLfloat blue); +GLAPI void GLAPIENTRY glColor3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glColor3i (GLint red, GLint green, GLint blue); +GLAPI void GLAPIENTRY glColor3iv (const GLint *v); +GLAPI void GLAPIENTRY glColor3s (GLshort red, GLshort green, GLshort blue); +GLAPI void GLAPIENTRY glColor3sv (const GLshort *v); +GLAPI void GLAPIENTRY glColor3ub (GLubyte red, GLubyte green, GLubyte blue); +GLAPI void GLAPIENTRY glColor3ubv (const GLubyte *v); +GLAPI void GLAPIENTRY glColor3ui (GLuint red, GLuint green, GLuint blue); +GLAPI void GLAPIENTRY glColor3uiv (const GLuint *v); +GLAPI void GLAPIENTRY glColor3us (GLushort red, GLushort green, GLushort blue); +GLAPI void GLAPIENTRY glColor3usv (const GLushort *v); +GLAPI void GLAPIENTRY glColor4b (GLbyte red, GLbyte green, GLbyte blue, GLbyte alpha); +GLAPI void GLAPIENTRY glColor4bv (const GLbyte *v); +GLAPI void GLAPIENTRY glColor4d (GLdouble red, GLdouble green, GLdouble blue, GLdouble alpha); +GLAPI void GLAPIENTRY glColor4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glColor4f (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI void GLAPIENTRY glColor4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glColor4i (GLint red, GLint green, GLint blue, GLint alpha); +GLAPI void GLAPIENTRY glColor4iv (const GLint *v); +GLAPI void GLAPIENTRY glColor4s (GLshort red, GLshort green, GLshort blue, GLshort alpha); +GLAPI void GLAPIENTRY glColor4sv (const GLshort *v); +GLAPI void GLAPIENTRY glColor4ub (GLubyte red, GLubyte green, GLubyte blue, GLubyte alpha); +GLAPI void GLAPIENTRY glColor4ubv (const GLubyte *v); +GLAPI void GLAPIENTRY glColor4ui (GLuint red, GLuint green, GLuint blue, GLuint alpha); +GLAPI void GLAPIENTRY glColor4uiv (const GLuint *v); +GLAPI void GLAPIENTRY glColor4us (GLushort red, GLushort green, GLushort blue, GLushort alpha); +GLAPI void GLAPIENTRY glColor4usv (const GLushort *v); +GLAPI void GLAPIENTRY glColorMask (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); +GLAPI void GLAPIENTRY glColorMaterial (GLenum face, GLenum mode); +GLAPI void GLAPIENTRY glColorPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glCopyPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum type); +GLAPI void GLAPIENTRY glCopyTexImage1D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLint border); +GLAPI void GLAPIENTRY glCopyTexImage2D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +GLAPI void GLAPIENTRY glCopyTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +GLAPI void GLAPIENTRY glCopyTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void GLAPIENTRY glCullFace (GLenum mode); +GLAPI void GLAPIENTRY glDeleteLists (GLuint list, GLsizei range); +GLAPI void GLAPIENTRY glDeleteTextures (GLsizei n, const GLuint *textures); +GLAPI void GLAPIENTRY glDepthFunc (GLenum func); +GLAPI void GLAPIENTRY glDepthMask (GLboolean flag); +GLAPI void GLAPIENTRY glDepthRange (GLclampd zNear, GLclampd zFar); +GLAPI void GLAPIENTRY glDisable (GLenum cap); +GLAPI void GLAPIENTRY glDisableClientState (GLenum array); +GLAPI void GLAPIENTRY glDrawArrays (GLenum mode, GLint first, GLsizei count); +GLAPI void GLAPIENTRY glDrawBuffer (GLenum mode); +GLAPI void GLAPIENTRY glDrawElements (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices); +GLAPI void GLAPIENTRY glDrawPixels (GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glEdgeFlag (GLboolean flag); +GLAPI void GLAPIENTRY glEdgeFlagPointer (GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glEdgeFlagv (const GLboolean *flag); +GLAPI void GLAPIENTRY glEnable (GLenum cap); +GLAPI void GLAPIENTRY glEnableClientState (GLenum array); +GLAPI void GLAPIENTRY glEnd (void); +GLAPI void GLAPIENTRY glEndList (void); +GLAPI void GLAPIENTRY glEvalCoord1d (GLdouble u); +GLAPI void GLAPIENTRY glEvalCoord1dv (const GLdouble *u); +GLAPI void GLAPIENTRY glEvalCoord1f (GLfloat u); +GLAPI void GLAPIENTRY glEvalCoord1fv (const GLfloat *u); +GLAPI void GLAPIENTRY glEvalCoord2d (GLdouble u, GLdouble v); +GLAPI void GLAPIENTRY glEvalCoord2dv (const GLdouble *u); +GLAPI void GLAPIENTRY glEvalCoord2f (GLfloat u, GLfloat v); +GLAPI void GLAPIENTRY glEvalCoord2fv (const GLfloat *u); +GLAPI void GLAPIENTRY glEvalMesh1 (GLenum mode, GLint i1, GLint i2); +GLAPI void GLAPIENTRY glEvalMesh2 (GLenum mode, GLint i1, GLint i2, GLint j1, GLint j2); +GLAPI void GLAPIENTRY glEvalPoint1 (GLint i); +GLAPI void GLAPIENTRY glEvalPoint2 (GLint i, GLint j); +GLAPI void GLAPIENTRY glFeedbackBuffer (GLsizei size, GLenum type, GLfloat *buffer); +GLAPI void GLAPIENTRY glFinish (void); +GLAPI void GLAPIENTRY glFlush (void); +GLAPI void GLAPIENTRY glFogf (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glFogfv (GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glFogi (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glFogiv (GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glFrontFace (GLenum mode); +GLAPI void GLAPIENTRY glFrustum (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI GLuint GLAPIENTRY glGenLists (GLsizei range); +GLAPI void GLAPIENTRY glGenTextures (GLsizei n, GLuint *textures); +GLAPI void GLAPIENTRY glGetBooleanv (GLenum pname, GLboolean *params); +GLAPI void GLAPIENTRY glGetClipPlane (GLenum plane, GLdouble *equation); +GLAPI void GLAPIENTRY glGetDoublev (GLenum pname, GLdouble *params); +GLAPI GLenum GLAPIENTRY glGetError (void); +GLAPI void GLAPIENTRY glGetFloatv (GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetIntegerv (GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetLightfv (GLenum light, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetLightiv (GLenum light, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetMapdv (GLenum target, GLenum query, GLdouble *v); +GLAPI void GLAPIENTRY glGetMapfv (GLenum target, GLenum query, GLfloat *v); +GLAPI void GLAPIENTRY glGetMapiv (GLenum target, GLenum query, GLint *v); +GLAPI void GLAPIENTRY glGetMaterialfv (GLenum face, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetMaterialiv (GLenum face, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetPixelMapfv (GLenum map, GLfloat *values); +GLAPI void GLAPIENTRY glGetPixelMapuiv (GLenum map, GLuint *values); +GLAPI void GLAPIENTRY glGetPixelMapusv (GLenum map, GLushort *values); +GLAPI void GLAPIENTRY glGetPointerv (GLenum pname, GLvoid* *params); +GLAPI void GLAPIENTRY glGetPolygonStipple (GLubyte *mask); +GLAPI const GLubyte * GLAPIENTRY glGetString (GLenum name); +GLAPI void GLAPIENTRY glGetTexEnvfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexEnviv (GLenum target, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetTexGendv (GLenum coord, GLenum pname, GLdouble *params); +GLAPI void GLAPIENTRY glGetTexGenfv (GLenum coord, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexGeniv (GLenum coord, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetTexImage (GLenum target, GLint level, GLenum format, GLenum type, GLvoid *pixels); +GLAPI void GLAPIENTRY glGetTexLevelParameterfv (GLenum target, GLint level, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexLevelParameteriv (GLenum target, GLint level, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glGetTexParameterfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void GLAPIENTRY glGetTexParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void GLAPIENTRY glHint (GLenum target, GLenum mode); +GLAPI void GLAPIENTRY glIndexMask (GLuint mask); +GLAPI void GLAPIENTRY glIndexPointer (GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glIndexd (GLdouble c); +GLAPI void GLAPIENTRY glIndexdv (const GLdouble *c); +GLAPI void GLAPIENTRY glIndexf (GLfloat c); +GLAPI void GLAPIENTRY glIndexfv (const GLfloat *c); +GLAPI void GLAPIENTRY glIndexi (GLint c); +GLAPI void GLAPIENTRY glIndexiv (const GLint *c); +GLAPI void GLAPIENTRY glIndexs (GLshort c); +GLAPI void GLAPIENTRY glIndexsv (const GLshort *c); +GLAPI void GLAPIENTRY glIndexub (GLubyte c); +GLAPI void GLAPIENTRY glIndexubv (const GLubyte *c); +GLAPI void GLAPIENTRY glInitNames (void); +GLAPI void GLAPIENTRY glInterleavedArrays (GLenum format, GLsizei stride, const GLvoid *pointer); +GLAPI GLboolean GLAPIENTRY glIsEnabled (GLenum cap); +GLAPI GLboolean GLAPIENTRY glIsList (GLuint list); +GLAPI GLboolean GLAPIENTRY glIsTexture (GLuint texture); +GLAPI void GLAPIENTRY glLightModelf (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glLightModelfv (GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glLightModeli (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glLightModeliv (GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glLightf (GLenum light, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glLightfv (GLenum light, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glLighti (GLenum light, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glLightiv (GLenum light, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glLineStipple (GLint factor, GLushort pattern); +GLAPI void GLAPIENTRY glLineWidth (GLfloat width); +GLAPI void GLAPIENTRY glListBase (GLuint base); +GLAPI void GLAPIENTRY glLoadIdentity (void); +GLAPI void GLAPIENTRY glLoadMatrixd (const GLdouble *m); +GLAPI void GLAPIENTRY glLoadMatrixf (const GLfloat *m); +GLAPI void GLAPIENTRY glLoadName (GLuint name); +GLAPI void GLAPIENTRY glLogicOp (GLenum opcode); +GLAPI void GLAPIENTRY glMap1d (GLenum target, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); +GLAPI void GLAPIENTRY glMap1f (GLenum target, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); +GLAPI void GLAPIENTRY glMap2d (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble *points); +GLAPI void GLAPIENTRY glMap2f (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); +GLAPI void GLAPIENTRY glMapGrid1d (GLint un, GLdouble u1, GLdouble u2); +GLAPI void GLAPIENTRY glMapGrid1f (GLint un, GLfloat u1, GLfloat u2); +GLAPI void GLAPIENTRY glMapGrid2d (GLint un, GLdouble u1, GLdouble u2, GLint vn, GLdouble v1, GLdouble v2); +GLAPI void GLAPIENTRY glMapGrid2f (GLint un, GLfloat u1, GLfloat u2, GLint vn, GLfloat v1, GLfloat v2); +GLAPI void GLAPIENTRY glMaterialf (GLenum face, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glMaterialfv (GLenum face, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glMateriali (GLenum face, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glMaterialiv (GLenum face, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glMatrixMode (GLenum mode); +GLAPI void GLAPIENTRY glMultMatrixd (const GLdouble *m); +GLAPI void GLAPIENTRY glMultMatrixf (const GLfloat *m); +GLAPI void GLAPIENTRY glNewList (GLuint list, GLenum mode); +GLAPI void GLAPIENTRY glNormal3b (GLbyte nx, GLbyte ny, GLbyte nz); +GLAPI void GLAPIENTRY glNormal3bv (const GLbyte *v); +GLAPI void GLAPIENTRY glNormal3d (GLdouble nx, GLdouble ny, GLdouble nz); +GLAPI void GLAPIENTRY glNormal3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glNormal3f (GLfloat nx, GLfloat ny, GLfloat nz); +GLAPI void GLAPIENTRY glNormal3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glNormal3i (GLint nx, GLint ny, GLint nz); +GLAPI void GLAPIENTRY glNormal3iv (const GLint *v); +GLAPI void GLAPIENTRY glNormal3s (GLshort nx, GLshort ny, GLshort nz); +GLAPI void GLAPIENTRY glNormal3sv (const GLshort *v); +GLAPI void GLAPIENTRY glNormalPointer (GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glOrtho (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI void GLAPIENTRY glPassThrough (GLfloat token); +GLAPI void GLAPIENTRY glPixelMapfv (GLenum map, GLsizei mapsize, const GLfloat *values); +GLAPI void GLAPIENTRY glPixelMapuiv (GLenum map, GLsizei mapsize, const GLuint *values); +GLAPI void GLAPIENTRY glPixelMapusv (GLenum map, GLsizei mapsize, const GLushort *values); +GLAPI void GLAPIENTRY glPixelStoref (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glPixelStorei (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glPixelTransferf (GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glPixelTransferi (GLenum pname, GLint param); +GLAPI void GLAPIENTRY glPixelZoom (GLfloat xfactor, GLfloat yfactor); +GLAPI void GLAPIENTRY glPointSize (GLfloat size); +GLAPI void GLAPIENTRY glPolygonMode (GLenum face, GLenum mode); +GLAPI void GLAPIENTRY glPolygonOffset (GLfloat factor, GLfloat units); +GLAPI void GLAPIENTRY glPolygonStipple (const GLubyte *mask); +GLAPI void GLAPIENTRY glPopAttrib (void); +GLAPI void GLAPIENTRY glPopClientAttrib (void); +GLAPI void GLAPIENTRY glPopMatrix (void); +GLAPI void GLAPIENTRY glPopName (void); +GLAPI void GLAPIENTRY glPrioritizeTextures (GLsizei n, const GLuint *textures, const GLclampf *priorities); +GLAPI void GLAPIENTRY glPushAttrib (GLbitfield mask); +GLAPI void GLAPIENTRY glPushClientAttrib (GLbitfield mask); +GLAPI void GLAPIENTRY glPushMatrix (void); +GLAPI void GLAPIENTRY glPushName (GLuint name); +GLAPI void GLAPIENTRY glRasterPos2d (GLdouble x, GLdouble y); +GLAPI void GLAPIENTRY glRasterPos2dv (const GLdouble *v); +GLAPI void GLAPIENTRY glRasterPos2f (GLfloat x, GLfloat y); +GLAPI void GLAPIENTRY glRasterPos2fv (const GLfloat *v); +GLAPI void GLAPIENTRY glRasterPos2i (GLint x, GLint y); +GLAPI void GLAPIENTRY glRasterPos2iv (const GLint *v); +GLAPI void GLAPIENTRY glRasterPos2s (GLshort x, GLshort y); +GLAPI void GLAPIENTRY glRasterPos2sv (const GLshort *v); +GLAPI void GLAPIENTRY glRasterPos3d (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glRasterPos3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glRasterPos3f (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glRasterPos3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glRasterPos3i (GLint x, GLint y, GLint z); +GLAPI void GLAPIENTRY glRasterPos3iv (const GLint *v); +GLAPI void GLAPIENTRY glRasterPos3s (GLshort x, GLshort y, GLshort z); +GLAPI void GLAPIENTRY glRasterPos3sv (const GLshort *v); +GLAPI void GLAPIENTRY glRasterPos4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void GLAPIENTRY glRasterPos4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glRasterPos4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void GLAPIENTRY glRasterPos4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glRasterPos4i (GLint x, GLint y, GLint z, GLint w); +GLAPI void GLAPIENTRY glRasterPos4iv (const GLint *v); +GLAPI void GLAPIENTRY glRasterPos4s (GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void GLAPIENTRY glRasterPos4sv (const GLshort *v); +GLAPI void GLAPIENTRY glReadBuffer (GLenum mode); +GLAPI void GLAPIENTRY glReadPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid *pixels); +GLAPI void GLAPIENTRY glRectd (GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2); +GLAPI void GLAPIENTRY glRectdv (const GLdouble *v1, const GLdouble *v2); +GLAPI void GLAPIENTRY glRectf (GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2); +GLAPI void GLAPIENTRY glRectfv (const GLfloat *v1, const GLfloat *v2); +GLAPI void GLAPIENTRY glRecti (GLint x1, GLint y1, GLint x2, GLint y2); +GLAPI void GLAPIENTRY glRectiv (const GLint *v1, const GLint *v2); +GLAPI void GLAPIENTRY glRects (GLshort x1, GLshort y1, GLshort x2, GLshort y2); +GLAPI void GLAPIENTRY glRectsv (const GLshort *v1, const GLshort *v2); +GLAPI GLint GLAPIENTRY glRenderMode (GLenum mode); +GLAPI void GLAPIENTRY glRotated (GLdouble angle, GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glRotatef (GLfloat angle, GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glScaled (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glScalef (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glScissor (GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void GLAPIENTRY glSelectBuffer (GLsizei size, GLuint *buffer); +GLAPI void GLAPIENTRY glShadeModel (GLenum mode); +GLAPI void GLAPIENTRY glStencilFunc (GLenum func, GLint ref, GLuint mask); +GLAPI void GLAPIENTRY glStencilMask (GLuint mask); +GLAPI void GLAPIENTRY glStencilOp (GLenum fail, GLenum zfail, GLenum zpass); +GLAPI void GLAPIENTRY glTexCoord1d (GLdouble s); +GLAPI void GLAPIENTRY glTexCoord1dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord1f (GLfloat s); +GLAPI void GLAPIENTRY glTexCoord1fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord1i (GLint s); +GLAPI void GLAPIENTRY glTexCoord1iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord1s (GLshort s); +GLAPI void GLAPIENTRY glTexCoord1sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoord2d (GLdouble s, GLdouble t); +GLAPI void GLAPIENTRY glTexCoord2dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord2f (GLfloat s, GLfloat t); +GLAPI void GLAPIENTRY glTexCoord2fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord2i (GLint s, GLint t); +GLAPI void GLAPIENTRY glTexCoord2iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord2s (GLshort s, GLshort t); +GLAPI void GLAPIENTRY glTexCoord2sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoord3d (GLdouble s, GLdouble t, GLdouble r); +GLAPI void GLAPIENTRY glTexCoord3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord3f (GLfloat s, GLfloat t, GLfloat r); +GLAPI void GLAPIENTRY glTexCoord3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord3i (GLint s, GLint t, GLint r); +GLAPI void GLAPIENTRY glTexCoord3iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord3s (GLshort s, GLshort t, GLshort r); +GLAPI void GLAPIENTRY glTexCoord3sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoord4d (GLdouble s, GLdouble t, GLdouble r, GLdouble q); +GLAPI void GLAPIENTRY glTexCoord4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glTexCoord4f (GLfloat s, GLfloat t, GLfloat r, GLfloat q); +GLAPI void GLAPIENTRY glTexCoord4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glTexCoord4i (GLint s, GLint t, GLint r, GLint q); +GLAPI void GLAPIENTRY glTexCoord4iv (const GLint *v); +GLAPI void GLAPIENTRY glTexCoord4s (GLshort s, GLshort t, GLshort r, GLshort q); +GLAPI void GLAPIENTRY glTexCoord4sv (const GLshort *v); +GLAPI void GLAPIENTRY glTexCoordPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glTexEnvf (GLenum target, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glTexEnvfv (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glTexEnvi (GLenum target, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glTexEnviv (GLenum target, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glTexGend (GLenum coord, GLenum pname, GLdouble param); +GLAPI void GLAPIENTRY glTexGendv (GLenum coord, GLenum pname, const GLdouble *params); +GLAPI void GLAPIENTRY glTexGenf (GLenum coord, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glTexGenfv (GLenum coord, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glTexGeni (GLenum coord, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glTexGeniv (GLenum coord, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glTexImage1D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTexImage2D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTexParameterf (GLenum target, GLenum pname, GLfloat param); +GLAPI void GLAPIENTRY glTexParameterfv (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void GLAPIENTRY glTexParameteri (GLenum target, GLenum pname, GLint param); +GLAPI void GLAPIENTRY glTexParameteriv (GLenum target, GLenum pname, const GLint *params); +GLAPI void GLAPIENTRY glTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); +GLAPI void GLAPIENTRY glTranslated (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glTranslatef (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glVertex2d (GLdouble x, GLdouble y); +GLAPI void GLAPIENTRY glVertex2dv (const GLdouble *v); +GLAPI void GLAPIENTRY glVertex2f (GLfloat x, GLfloat y); +GLAPI void GLAPIENTRY glVertex2fv (const GLfloat *v); +GLAPI void GLAPIENTRY glVertex2i (GLint x, GLint y); +GLAPI void GLAPIENTRY glVertex2iv (const GLint *v); +GLAPI void GLAPIENTRY glVertex2s (GLshort x, GLshort y); +GLAPI void GLAPIENTRY glVertex2sv (const GLshort *v); +GLAPI void GLAPIENTRY glVertex3d (GLdouble x, GLdouble y, GLdouble z); +GLAPI void GLAPIENTRY glVertex3dv (const GLdouble *v); +GLAPI void GLAPIENTRY glVertex3f (GLfloat x, GLfloat y, GLfloat z); +GLAPI void GLAPIENTRY glVertex3fv (const GLfloat *v); +GLAPI void GLAPIENTRY glVertex3i (GLint x, GLint y, GLint z); +GLAPI void GLAPIENTRY glVertex3iv (const GLint *v); +GLAPI void GLAPIENTRY glVertex3s (GLshort x, GLshort y, GLshort z); +GLAPI void GLAPIENTRY glVertex3sv (const GLshort *v); +GLAPI void GLAPIENTRY glVertex4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void GLAPIENTRY glVertex4dv (const GLdouble *v); +GLAPI void GLAPIENTRY glVertex4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void GLAPIENTRY glVertex4fv (const GLfloat *v); +GLAPI void GLAPIENTRY glVertex4i (GLint x, GLint y, GLint z, GLint w); +GLAPI void GLAPIENTRY glVertex4iv (const GLint *v); +GLAPI void GLAPIENTRY glVertex4s (GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void GLAPIENTRY glVertex4sv (const GLshort *v); +GLAPI void GLAPIENTRY glVertexPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +GLAPI void GLAPIENTRY glViewport (GLint x, GLint y, GLsizei width, GLsizei height); + +#define GLEW_VERSION_1_1 GLEW_GET_VAR(__GLEW_VERSION_1_1) + +#endif /* GL_VERSION_1_1 */ + +/* ---------------------------------- GLU ---------------------------------- */ + +/* this is where we can safely include GLU */ +#if defined(__APPLE__) && defined(__MACH__) +#include +#else +#include +#endif + +/* ----------------------------- GL_VERSION_1_2 ---------------------------- */ + +#ifndef GL_VERSION_1_2 +#define GL_VERSION_1_2 1 + +#define GL_SMOOTH_POINT_SIZE_RANGE 0x0B12 +#define GL_SMOOTH_POINT_SIZE_GRANULARITY 0x0B13 +#define GL_SMOOTH_LINE_WIDTH_RANGE 0x0B22 +#define GL_SMOOTH_LINE_WIDTH_GRANULARITY 0x0B23 +#define GL_UNSIGNED_BYTE_3_3_2 0x8032 +#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033 +#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 +#define GL_UNSIGNED_INT_8_8_8_8 0x8035 +#define GL_UNSIGNED_INT_10_10_10_2 0x8036 +#define GL_RESCALE_NORMAL 0x803A +#define GL_TEXTURE_BINDING_3D 0x806A +#define GL_PACK_SKIP_IMAGES 0x806B +#define GL_PACK_IMAGE_HEIGHT 0x806C +#define GL_UNPACK_SKIP_IMAGES 0x806D +#define GL_UNPACK_IMAGE_HEIGHT 0x806E +#define GL_TEXTURE_3D 0x806F +#define GL_PROXY_TEXTURE_3D 0x8070 +#define GL_TEXTURE_DEPTH 0x8071 +#define GL_TEXTURE_WRAP_R 0x8072 +#define GL_MAX_3D_TEXTURE_SIZE 0x8073 +#define GL_BGR 0x80E0 +#define GL_BGRA 0x80E1 +#define GL_MAX_ELEMENTS_VERTICES 0x80E8 +#define GL_MAX_ELEMENTS_INDICES 0x80E9 +#define GL_CLAMP_TO_EDGE 0x812F +#define GL_TEXTURE_MIN_LOD 0x813A +#define GL_TEXTURE_MAX_LOD 0x813B +#define GL_TEXTURE_BASE_LEVEL 0x813C +#define GL_TEXTURE_MAX_LEVEL 0x813D +#define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 +#define GL_SINGLE_COLOR 0x81F9 +#define GL_SEPARATE_SPECULAR_COLOR 0x81FA +#define GL_UNSIGNED_BYTE_2_3_3_REV 0x8362 +#define GL_UNSIGNED_SHORT_5_6_5 0x8363 +#define GL_UNSIGNED_SHORT_5_6_5_REV 0x8364 +#define GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 +#define GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 +#define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 +#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 +#define GL_ALIASED_POINT_SIZE_RANGE 0x846D +#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E + +typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); +typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); + +#define glCopyTexSubImage3D GLEW_GET_FUN(__glewCopyTexSubImage3D) +#define glDrawRangeElements GLEW_GET_FUN(__glewDrawRangeElements) +#define glTexImage3D GLEW_GET_FUN(__glewTexImage3D) +#define glTexSubImage3D GLEW_GET_FUN(__glewTexSubImage3D) + +#define GLEW_VERSION_1_2 GLEW_GET_VAR(__GLEW_VERSION_1_2) + +#endif /* GL_VERSION_1_2 */ + +/* ----------------------------- GL_VERSION_1_3 ---------------------------- */ + +#ifndef GL_VERSION_1_3 +#define GL_VERSION_1_3 1 + +#define GL_MULTISAMPLE 0x809D +#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE 0x809F +#define GL_SAMPLE_COVERAGE 0x80A0 +#define GL_SAMPLE_BUFFERS 0x80A8 +#define GL_SAMPLES 0x80A9 +#define GL_SAMPLE_COVERAGE_VALUE 0x80AA +#define GL_SAMPLE_COVERAGE_INVERT 0x80AB +#define GL_CLAMP_TO_BORDER 0x812D +#define GL_TEXTURE0 0x84C0 +#define GL_TEXTURE1 0x84C1 +#define GL_TEXTURE2 0x84C2 +#define GL_TEXTURE3 0x84C3 +#define GL_TEXTURE4 0x84C4 +#define GL_TEXTURE5 0x84C5 +#define GL_TEXTURE6 0x84C6 +#define GL_TEXTURE7 0x84C7 +#define GL_TEXTURE8 0x84C8 +#define GL_TEXTURE9 0x84C9 +#define GL_TEXTURE10 0x84CA +#define GL_TEXTURE11 0x84CB +#define GL_TEXTURE12 0x84CC +#define GL_TEXTURE13 0x84CD +#define GL_TEXTURE14 0x84CE +#define GL_TEXTURE15 0x84CF +#define GL_TEXTURE16 0x84D0 +#define GL_TEXTURE17 0x84D1 +#define GL_TEXTURE18 0x84D2 +#define GL_TEXTURE19 0x84D3 +#define GL_TEXTURE20 0x84D4 +#define GL_TEXTURE21 0x84D5 +#define GL_TEXTURE22 0x84D6 +#define GL_TEXTURE23 0x84D7 +#define GL_TEXTURE24 0x84D8 +#define GL_TEXTURE25 0x84D9 +#define GL_TEXTURE26 0x84DA +#define GL_TEXTURE27 0x84DB +#define GL_TEXTURE28 0x84DC +#define GL_TEXTURE29 0x84DD +#define GL_TEXTURE30 0x84DE +#define GL_TEXTURE31 0x84DF +#define GL_ACTIVE_TEXTURE 0x84E0 +#define GL_CLIENT_ACTIVE_TEXTURE 0x84E1 +#define GL_MAX_TEXTURE_UNITS 0x84E2 +#define GL_TRANSPOSE_MODELVIEW_MATRIX 0x84E3 +#define GL_TRANSPOSE_PROJECTION_MATRIX 0x84E4 +#define GL_TRANSPOSE_TEXTURE_MATRIX 0x84E5 +#define GL_TRANSPOSE_COLOR_MATRIX 0x84E6 +#define GL_SUBTRACT 0x84E7 +#define GL_COMPRESSED_ALPHA 0x84E9 +#define GL_COMPRESSED_LUMINANCE 0x84EA +#define GL_COMPRESSED_LUMINANCE_ALPHA 0x84EB +#define GL_COMPRESSED_INTENSITY 0x84EC +#define GL_COMPRESSED_RGB 0x84ED +#define GL_COMPRESSED_RGBA 0x84EE +#define GL_TEXTURE_COMPRESSION_HINT 0x84EF +#define GL_NORMAL_MAP 0x8511 +#define GL_REFLECTION_MAP 0x8512 +#define GL_TEXTURE_CUBE_MAP 0x8513 +#define GL_TEXTURE_BINDING_CUBE_MAP 0x8514 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x8515 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x8516 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x8517 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x8518 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x8519 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x851A +#define GL_PROXY_TEXTURE_CUBE_MAP 0x851B +#define GL_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C +#define GL_COMBINE 0x8570 +#define GL_COMBINE_RGB 0x8571 +#define GL_COMBINE_ALPHA 0x8572 +#define GL_RGB_SCALE 0x8573 +#define GL_ADD_SIGNED 0x8574 +#define GL_INTERPOLATE 0x8575 +#define GL_CONSTANT 0x8576 +#define GL_PRIMARY_COLOR 0x8577 +#define GL_PREVIOUS 0x8578 +#define GL_SOURCE0_RGB 0x8580 +#define GL_SOURCE1_RGB 0x8581 +#define GL_SOURCE2_RGB 0x8582 +#define GL_SOURCE0_ALPHA 0x8588 +#define GL_SOURCE1_ALPHA 0x8589 +#define GL_SOURCE2_ALPHA 0x858A +#define GL_OPERAND0_RGB 0x8590 +#define GL_OPERAND1_RGB 0x8591 +#define GL_OPERAND2_RGB 0x8592 +#define GL_OPERAND0_ALPHA 0x8598 +#define GL_OPERAND1_ALPHA 0x8599 +#define GL_OPERAND2_ALPHA 0x859A +#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE 0x86A0 +#define GL_TEXTURE_COMPRESSED 0x86A1 +#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 +#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 +#define GL_DOT3_RGB 0x86AE +#define GL_DOT3_RGBA 0x86AF +#define GL_MULTISAMPLE_BIT 0x20000000 + +typedef void (GLAPIENTRY * PFNGLACTIVETEXTUREPROC) (GLenum texture); +typedef void (GLAPIENTRY * PFNGLCLIENTACTIVETEXTUREPROC) (GLenum texture); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE3DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXIMAGEPROC) (GLenum target, GLint lod, GLvoid *img); +typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXDPROC) (const GLdouble m[16]); +typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXFPROC) (const GLfloat m[16]); +typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXDPROC) (const GLdouble m[16]); +typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXFPROC) (const GLfloat m[16]); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DPROC) (GLenum target, GLdouble s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DVPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FPROC) (GLenum target, GLfloat s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FVPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IPROC) (GLenum target, GLint s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IVPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SPROC) (GLenum target, GLshort s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SVPROC) (GLenum target, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DPROC) (GLenum target, GLdouble s, GLdouble t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DVPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FPROC) (GLenum target, GLfloat s, GLfloat t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FVPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IPROC) (GLenum target, GLint s, GLint t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IVPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SPROC) (GLenum target, GLshort s, GLshort t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SVPROC) (GLenum target, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DVPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FVPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IPROC) (GLenum target, GLint s, GLint t, GLint r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IVPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SPROC) (GLenum target, GLshort s, GLshort t, GLshort r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SVPROC) (GLenum target, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DVPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FVPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IVPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SVPROC) (GLenum target, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLSAMPLECOVERAGEPROC) (GLclampf value, GLboolean invert); + +#define glActiveTexture GLEW_GET_FUN(__glewActiveTexture) +#define glClientActiveTexture GLEW_GET_FUN(__glewClientActiveTexture) +#define glCompressedTexImage1D GLEW_GET_FUN(__glewCompressedTexImage1D) +#define glCompressedTexImage2D GLEW_GET_FUN(__glewCompressedTexImage2D) +#define glCompressedTexImage3D GLEW_GET_FUN(__glewCompressedTexImage3D) +#define glCompressedTexSubImage1D GLEW_GET_FUN(__glewCompressedTexSubImage1D) +#define glCompressedTexSubImage2D GLEW_GET_FUN(__glewCompressedTexSubImage2D) +#define glCompressedTexSubImage3D GLEW_GET_FUN(__glewCompressedTexSubImage3D) +#define glGetCompressedTexImage GLEW_GET_FUN(__glewGetCompressedTexImage) +#define glLoadTransposeMatrixd GLEW_GET_FUN(__glewLoadTransposeMatrixd) +#define glLoadTransposeMatrixf GLEW_GET_FUN(__glewLoadTransposeMatrixf) +#define glMultTransposeMatrixd GLEW_GET_FUN(__glewMultTransposeMatrixd) +#define glMultTransposeMatrixf GLEW_GET_FUN(__glewMultTransposeMatrixf) +#define glMultiTexCoord1d GLEW_GET_FUN(__glewMultiTexCoord1d) +#define glMultiTexCoord1dv GLEW_GET_FUN(__glewMultiTexCoord1dv) +#define glMultiTexCoord1f GLEW_GET_FUN(__glewMultiTexCoord1f) +#define glMultiTexCoord1fv GLEW_GET_FUN(__glewMultiTexCoord1fv) +#define glMultiTexCoord1i GLEW_GET_FUN(__glewMultiTexCoord1i) +#define glMultiTexCoord1iv GLEW_GET_FUN(__glewMultiTexCoord1iv) +#define glMultiTexCoord1s GLEW_GET_FUN(__glewMultiTexCoord1s) +#define glMultiTexCoord1sv GLEW_GET_FUN(__glewMultiTexCoord1sv) +#define glMultiTexCoord2d GLEW_GET_FUN(__glewMultiTexCoord2d) +#define glMultiTexCoord2dv GLEW_GET_FUN(__glewMultiTexCoord2dv) +#define glMultiTexCoord2f GLEW_GET_FUN(__glewMultiTexCoord2f) +#define glMultiTexCoord2fv GLEW_GET_FUN(__glewMultiTexCoord2fv) +#define glMultiTexCoord2i GLEW_GET_FUN(__glewMultiTexCoord2i) +#define glMultiTexCoord2iv GLEW_GET_FUN(__glewMultiTexCoord2iv) +#define glMultiTexCoord2s GLEW_GET_FUN(__glewMultiTexCoord2s) +#define glMultiTexCoord2sv GLEW_GET_FUN(__glewMultiTexCoord2sv) +#define glMultiTexCoord3d GLEW_GET_FUN(__glewMultiTexCoord3d) +#define glMultiTexCoord3dv GLEW_GET_FUN(__glewMultiTexCoord3dv) +#define glMultiTexCoord3f GLEW_GET_FUN(__glewMultiTexCoord3f) +#define glMultiTexCoord3fv GLEW_GET_FUN(__glewMultiTexCoord3fv) +#define glMultiTexCoord3i GLEW_GET_FUN(__glewMultiTexCoord3i) +#define glMultiTexCoord3iv GLEW_GET_FUN(__glewMultiTexCoord3iv) +#define glMultiTexCoord3s GLEW_GET_FUN(__glewMultiTexCoord3s) +#define glMultiTexCoord3sv GLEW_GET_FUN(__glewMultiTexCoord3sv) +#define glMultiTexCoord4d GLEW_GET_FUN(__glewMultiTexCoord4d) +#define glMultiTexCoord4dv GLEW_GET_FUN(__glewMultiTexCoord4dv) +#define glMultiTexCoord4f GLEW_GET_FUN(__glewMultiTexCoord4f) +#define glMultiTexCoord4fv GLEW_GET_FUN(__glewMultiTexCoord4fv) +#define glMultiTexCoord4i GLEW_GET_FUN(__glewMultiTexCoord4i) +#define glMultiTexCoord4iv GLEW_GET_FUN(__glewMultiTexCoord4iv) +#define glMultiTexCoord4s GLEW_GET_FUN(__glewMultiTexCoord4s) +#define glMultiTexCoord4sv GLEW_GET_FUN(__glewMultiTexCoord4sv) +#define glSampleCoverage GLEW_GET_FUN(__glewSampleCoverage) + +#define GLEW_VERSION_1_3 GLEW_GET_VAR(__GLEW_VERSION_1_3) + +#endif /* GL_VERSION_1_3 */ + +/* ----------------------------- GL_VERSION_1_4 ---------------------------- */ + +#ifndef GL_VERSION_1_4 +#define GL_VERSION_1_4 1 + +#define GL_BLEND_DST_RGB 0x80C8 +#define GL_BLEND_SRC_RGB 0x80C9 +#define GL_BLEND_DST_ALPHA 0x80CA +#define GL_BLEND_SRC_ALPHA 0x80CB +#define GL_POINT_SIZE_MIN 0x8126 +#define GL_POINT_SIZE_MAX 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE 0x8128 +#define GL_POINT_DISTANCE_ATTENUATION 0x8129 +#define GL_GENERATE_MIPMAP 0x8191 +#define GL_GENERATE_MIPMAP_HINT 0x8192 +#define GL_DEPTH_COMPONENT16 0x81A5 +#define GL_DEPTH_COMPONENT24 0x81A6 +#define GL_DEPTH_COMPONENT32 0x81A7 +#define GL_MIRRORED_REPEAT 0x8370 +#define GL_FOG_COORDINATE_SOURCE 0x8450 +#define GL_FOG_COORDINATE 0x8451 +#define GL_FRAGMENT_DEPTH 0x8452 +#define GL_CURRENT_FOG_COORDINATE 0x8453 +#define GL_FOG_COORDINATE_ARRAY_TYPE 0x8454 +#define GL_FOG_COORDINATE_ARRAY_STRIDE 0x8455 +#define GL_FOG_COORDINATE_ARRAY_POINTER 0x8456 +#define GL_FOG_COORDINATE_ARRAY 0x8457 +#define GL_COLOR_SUM 0x8458 +#define GL_CURRENT_SECONDARY_COLOR 0x8459 +#define GL_SECONDARY_COLOR_ARRAY_SIZE 0x845A +#define GL_SECONDARY_COLOR_ARRAY_TYPE 0x845B +#define GL_SECONDARY_COLOR_ARRAY_STRIDE 0x845C +#define GL_SECONDARY_COLOR_ARRAY_POINTER 0x845D +#define GL_SECONDARY_COLOR_ARRAY 0x845E +#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD +#define GL_TEXTURE_FILTER_CONTROL 0x8500 +#define GL_TEXTURE_LOD_BIAS 0x8501 +#define GL_INCR_WRAP 0x8507 +#define GL_DECR_WRAP 0x8508 +#define GL_TEXTURE_DEPTH_SIZE 0x884A +#define GL_DEPTH_TEXTURE_MODE 0x884B +#define GL_TEXTURE_COMPARE_MODE 0x884C +#define GL_TEXTURE_COMPARE_FUNC 0x884D +#define GL_COMPARE_R_TO_TEXTURE 0x884E + +typedef void (GLAPIENTRY * PFNGLBLENDCOLORPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONPROC) (GLenum mode); +typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTERPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); +typedef void (GLAPIENTRY * PFNGLFOGCOORDDPROC) (GLdouble coord); +typedef void (GLAPIENTRY * PFNGLFOGCOORDDVPROC) (const GLdouble *coord); +typedef void (GLAPIENTRY * PFNGLFOGCOORDFPROC) (GLfloat coord); +typedef void (GLAPIENTRY * PFNGLFOGCOORDFVPROC) (const GLfloat *coord); +typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSPROC) (GLenum mode, GLint *first, GLsizei *count, GLsizei primcount); +typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSPROC) (GLenum mode, GLsizei *count, GLenum type, const GLvoid **indices, GLsizei primcount); +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVPROC) (GLenum pname, const GLfloat *params); +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIVPROC) (GLenum pname, const GLint *params); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BPROC) (GLbyte red, GLbyte green, GLbyte blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BVPROC) (const GLbyte *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DPROC) (GLdouble red, GLdouble green, GLdouble blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DVPROC) (const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FPROC) (GLfloat red, GLfloat green, GLfloat blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FVPROC) (const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IPROC) (GLint red, GLint green, GLint blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IVPROC) (const GLint *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SPROC) (GLshort red, GLshort green, GLshort blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SVPROC) (const GLshort *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBPROC) (GLubyte red, GLubyte green, GLubyte blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBVPROC) (const GLubyte *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIPROC) (GLuint red, GLuint green, GLuint blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIVPROC) (const GLuint *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USPROC) (GLushort red, GLushort green, GLushort blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USVPROC) (const GLushort *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTERPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DPROC) (GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVPROC) (const GLdouble *p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FPROC) (GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVPROC) (const GLfloat *p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IPROC) (GLint x, GLint y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVPROC) (const GLint *p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SPROC) (GLshort x, GLshort y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVPROC) (const GLshort *p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVPROC) (const GLdouble *p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVPROC) (const GLfloat *p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IPROC) (GLint x, GLint y, GLint z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVPROC) (const GLint *p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SPROC) (GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVPROC) (const GLshort *p); + +#define glBlendColor GLEW_GET_FUN(__glewBlendColor) +#define glBlendEquation GLEW_GET_FUN(__glewBlendEquation) +#define glBlendFuncSeparate GLEW_GET_FUN(__glewBlendFuncSeparate) +#define glFogCoordPointer GLEW_GET_FUN(__glewFogCoordPointer) +#define glFogCoordd GLEW_GET_FUN(__glewFogCoordd) +#define glFogCoorddv GLEW_GET_FUN(__glewFogCoorddv) +#define glFogCoordf GLEW_GET_FUN(__glewFogCoordf) +#define glFogCoordfv GLEW_GET_FUN(__glewFogCoordfv) +#define glMultiDrawArrays GLEW_GET_FUN(__glewMultiDrawArrays) +#define glMultiDrawElements GLEW_GET_FUN(__glewMultiDrawElements) +#define glPointParameterf GLEW_GET_FUN(__glewPointParameterf) +#define glPointParameterfv GLEW_GET_FUN(__glewPointParameterfv) +#define glPointParameteri GLEW_GET_FUN(__glewPointParameteri) +#define glPointParameteriv GLEW_GET_FUN(__glewPointParameteriv) +#define glSecondaryColor3b GLEW_GET_FUN(__glewSecondaryColor3b) +#define glSecondaryColor3bv GLEW_GET_FUN(__glewSecondaryColor3bv) +#define glSecondaryColor3d GLEW_GET_FUN(__glewSecondaryColor3d) +#define glSecondaryColor3dv GLEW_GET_FUN(__glewSecondaryColor3dv) +#define glSecondaryColor3f GLEW_GET_FUN(__glewSecondaryColor3f) +#define glSecondaryColor3fv GLEW_GET_FUN(__glewSecondaryColor3fv) +#define glSecondaryColor3i GLEW_GET_FUN(__glewSecondaryColor3i) +#define glSecondaryColor3iv GLEW_GET_FUN(__glewSecondaryColor3iv) +#define glSecondaryColor3s GLEW_GET_FUN(__glewSecondaryColor3s) +#define glSecondaryColor3sv GLEW_GET_FUN(__glewSecondaryColor3sv) +#define glSecondaryColor3ub GLEW_GET_FUN(__glewSecondaryColor3ub) +#define glSecondaryColor3ubv GLEW_GET_FUN(__glewSecondaryColor3ubv) +#define glSecondaryColor3ui GLEW_GET_FUN(__glewSecondaryColor3ui) +#define glSecondaryColor3uiv GLEW_GET_FUN(__glewSecondaryColor3uiv) +#define glSecondaryColor3us GLEW_GET_FUN(__glewSecondaryColor3us) +#define glSecondaryColor3usv GLEW_GET_FUN(__glewSecondaryColor3usv) +#define glSecondaryColorPointer GLEW_GET_FUN(__glewSecondaryColorPointer) +#define glWindowPos2d GLEW_GET_FUN(__glewWindowPos2d) +#define glWindowPos2dv GLEW_GET_FUN(__glewWindowPos2dv) +#define glWindowPos2f GLEW_GET_FUN(__glewWindowPos2f) +#define glWindowPos2fv GLEW_GET_FUN(__glewWindowPos2fv) +#define glWindowPos2i GLEW_GET_FUN(__glewWindowPos2i) +#define glWindowPos2iv GLEW_GET_FUN(__glewWindowPos2iv) +#define glWindowPos2s GLEW_GET_FUN(__glewWindowPos2s) +#define glWindowPos2sv GLEW_GET_FUN(__glewWindowPos2sv) +#define glWindowPos3d GLEW_GET_FUN(__glewWindowPos3d) +#define glWindowPos3dv GLEW_GET_FUN(__glewWindowPos3dv) +#define glWindowPos3f GLEW_GET_FUN(__glewWindowPos3f) +#define glWindowPos3fv GLEW_GET_FUN(__glewWindowPos3fv) +#define glWindowPos3i GLEW_GET_FUN(__glewWindowPos3i) +#define glWindowPos3iv GLEW_GET_FUN(__glewWindowPos3iv) +#define glWindowPos3s GLEW_GET_FUN(__glewWindowPos3s) +#define glWindowPos3sv GLEW_GET_FUN(__glewWindowPos3sv) + +#define GLEW_VERSION_1_4 GLEW_GET_VAR(__GLEW_VERSION_1_4) + +#endif /* GL_VERSION_1_4 */ + +/* ----------------------------- GL_VERSION_1_5 ---------------------------- */ + +#ifndef GL_VERSION_1_5 +#define GL_VERSION_1_5 1 + +#define GL_FOG_COORD_SRC GL_FOG_COORDINATE_SOURCE +#define GL_FOG_COORD GL_FOG_COORDINATE +#define GL_FOG_COORD_ARRAY GL_FOG_COORDINATE_ARRAY +#define GL_SRC0_RGB GL_SOURCE0_RGB +#define GL_FOG_COORD_ARRAY_POINTER GL_FOG_COORDINATE_ARRAY_POINTER +#define GL_FOG_COORD_ARRAY_TYPE GL_FOG_COORDINATE_ARRAY_TYPE +#define GL_SRC1_ALPHA GL_SOURCE1_ALPHA +#define GL_CURRENT_FOG_COORD GL_CURRENT_FOG_COORDINATE +#define GL_FOG_COORD_ARRAY_STRIDE GL_FOG_COORDINATE_ARRAY_STRIDE +#define GL_SRC0_ALPHA GL_SOURCE0_ALPHA +#define GL_SRC1_RGB GL_SOURCE1_RGB +#define GL_FOG_COORD_ARRAY_BUFFER_BINDING GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING +#define GL_SRC2_ALPHA GL_SOURCE2_ALPHA +#define GL_SRC2_RGB GL_SOURCE2_RGB +#define GL_BUFFER_SIZE 0x8764 +#define GL_BUFFER_USAGE 0x8765 +#define GL_QUERY_COUNTER_BITS 0x8864 +#define GL_CURRENT_QUERY 0x8865 +#define GL_QUERY_RESULT 0x8866 +#define GL_QUERY_RESULT_AVAILABLE 0x8867 +#define GL_ARRAY_BUFFER 0x8892 +#define GL_ELEMENT_ARRAY_BUFFER 0x8893 +#define GL_ARRAY_BUFFER_BINDING 0x8894 +#define GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895 +#define GL_VERTEX_ARRAY_BUFFER_BINDING 0x8896 +#define GL_NORMAL_ARRAY_BUFFER_BINDING 0x8897 +#define GL_COLOR_ARRAY_BUFFER_BINDING 0x8898 +#define GL_INDEX_ARRAY_BUFFER_BINDING 0x8899 +#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING 0x889A +#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING 0x889B +#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING 0x889C +#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING 0x889D +#define GL_WEIGHT_ARRAY_BUFFER_BINDING 0x889E +#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F +#define GL_READ_ONLY 0x88B8 +#define GL_WRITE_ONLY 0x88B9 +#define GL_READ_WRITE 0x88BA +#define GL_BUFFER_ACCESS 0x88BB +#define GL_BUFFER_MAPPED 0x88BC +#define GL_BUFFER_MAP_POINTER 0x88BD +#define GL_STREAM_DRAW 0x88E0 +#define GL_STREAM_READ 0x88E1 +#define GL_STREAM_COPY 0x88E2 +#define GL_STATIC_DRAW 0x88E4 +#define GL_STATIC_READ 0x88E5 +#define GL_STATIC_COPY 0x88E6 +#define GL_DYNAMIC_DRAW 0x88E8 +#define GL_DYNAMIC_READ 0x88E9 +#define GL_DYNAMIC_COPY 0x88EA +#define GL_SAMPLES_PASSED 0x8914 + +typedef ptrdiff_t GLsizeiptr; +typedef ptrdiff_t GLintptr; + +typedef void (GLAPIENTRY * PFNGLBEGINQUERYPROC) (GLenum target, GLuint id); +typedef void (GLAPIENTRY * PFNGLBINDBUFFERPROC) (GLenum target, GLuint buffer); +typedef void (GLAPIENTRY * PFNGLBUFFERDATAPROC) (GLenum target, GLsizeiptr size, const GLvoid* data, GLenum usage); +typedef void (GLAPIENTRY * PFNGLBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, const GLvoid* data); +typedef void (GLAPIENTRY * PFNGLDELETEBUFFERSPROC) (GLsizei n, const GLuint* buffers); +typedef void (GLAPIENTRY * PFNGLDELETEQUERIESPROC) (GLsizei n, const GLuint* ids); +typedef void (GLAPIENTRY * PFNGLENDQUERYPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLGENBUFFERSPROC) (GLsizei n, GLuint* buffers); +typedef void (GLAPIENTRY * PFNGLGENQUERIESPROC) (GLsizei n, GLuint* ids); +typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETBUFFERPOINTERVPROC) (GLenum target, GLenum pname, GLvoid** params); +typedef void (GLAPIENTRY * PFNGLGETBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, GLvoid* data); +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTIVPROC) (GLuint id, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUIVPROC) (GLuint id, GLenum pname, GLuint* params); +typedef void (GLAPIENTRY * PFNGLGETQUERYIVPROC) (GLenum target, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERPROC) (GLuint buffer); +typedef GLboolean (GLAPIENTRY * PFNGLISQUERYPROC) (GLuint id); +typedef GLvoid* (GLAPIENTRY * PFNGLMAPBUFFERPROC) (GLenum target, GLenum access); +typedef GLboolean (GLAPIENTRY * PFNGLUNMAPBUFFERPROC) (GLenum target); + +#define glBeginQuery GLEW_GET_FUN(__glewBeginQuery) +#define glBindBuffer GLEW_GET_FUN(__glewBindBuffer) +#define glBufferData GLEW_GET_FUN(__glewBufferData) +#define glBufferSubData GLEW_GET_FUN(__glewBufferSubData) +#define glDeleteBuffers GLEW_GET_FUN(__glewDeleteBuffers) +#define glDeleteQueries GLEW_GET_FUN(__glewDeleteQueries) +#define glEndQuery GLEW_GET_FUN(__glewEndQuery) +#define glGenBuffers GLEW_GET_FUN(__glewGenBuffers) +#define glGenQueries GLEW_GET_FUN(__glewGenQueries) +#define glGetBufferParameteriv GLEW_GET_FUN(__glewGetBufferParameteriv) +#define glGetBufferPointerv GLEW_GET_FUN(__glewGetBufferPointerv) +#define glGetBufferSubData GLEW_GET_FUN(__glewGetBufferSubData) +#define glGetQueryObjectiv GLEW_GET_FUN(__glewGetQueryObjectiv) +#define glGetQueryObjectuiv GLEW_GET_FUN(__glewGetQueryObjectuiv) +#define glGetQueryiv GLEW_GET_FUN(__glewGetQueryiv) +#define glIsBuffer GLEW_GET_FUN(__glewIsBuffer) +#define glIsQuery GLEW_GET_FUN(__glewIsQuery) +#define glMapBuffer GLEW_GET_FUN(__glewMapBuffer) +#define glUnmapBuffer GLEW_GET_FUN(__glewUnmapBuffer) + +#define GLEW_VERSION_1_5 GLEW_GET_VAR(__GLEW_VERSION_1_5) + +#endif /* GL_VERSION_1_5 */ + +/* ----------------------------- GL_VERSION_2_0 ---------------------------- */ + +#ifndef GL_VERSION_2_0 +#define GL_VERSION_2_0 1 + +#define GL_BLEND_EQUATION_RGB GL_BLEND_EQUATION +#define GL_VERTEX_ATTRIB_ARRAY_ENABLED 0x8622 +#define GL_VERTEX_ATTRIB_ARRAY_SIZE 0x8623 +#define GL_VERTEX_ATTRIB_ARRAY_STRIDE 0x8624 +#define GL_VERTEX_ATTRIB_ARRAY_TYPE 0x8625 +#define GL_CURRENT_VERTEX_ATTRIB 0x8626 +#define GL_VERTEX_PROGRAM_POINT_SIZE 0x8642 +#define GL_VERTEX_PROGRAM_TWO_SIDE 0x8643 +#define GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645 +#define GL_STENCIL_BACK_FUNC 0x8800 +#define GL_STENCIL_BACK_FAIL 0x8801 +#define GL_STENCIL_BACK_PASS_DEPTH_FAIL 0x8802 +#define GL_STENCIL_BACK_PASS_DEPTH_PASS 0x8803 +#define GL_MAX_DRAW_BUFFERS 0x8824 +#define GL_DRAW_BUFFER0 0x8825 +#define GL_DRAW_BUFFER1 0x8826 +#define GL_DRAW_BUFFER2 0x8827 +#define GL_DRAW_BUFFER3 0x8828 +#define GL_DRAW_BUFFER4 0x8829 +#define GL_DRAW_BUFFER5 0x882A +#define GL_DRAW_BUFFER6 0x882B +#define GL_DRAW_BUFFER7 0x882C +#define GL_DRAW_BUFFER8 0x882D +#define GL_DRAW_BUFFER9 0x882E +#define GL_DRAW_BUFFER10 0x882F +#define GL_DRAW_BUFFER11 0x8830 +#define GL_DRAW_BUFFER12 0x8831 +#define GL_DRAW_BUFFER13 0x8832 +#define GL_DRAW_BUFFER14 0x8833 +#define GL_DRAW_BUFFER15 0x8834 +#define GL_BLEND_EQUATION_ALPHA 0x883D +#define GL_POINT_SPRITE 0x8861 +#define GL_COORD_REPLACE 0x8862 +#define GL_MAX_VERTEX_ATTRIBS 0x8869 +#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A +#define GL_MAX_TEXTURE_COORDS 0x8871 +#define GL_MAX_TEXTURE_IMAGE_UNITS 0x8872 +#define GL_FRAGMENT_SHADER 0x8B30 +#define GL_VERTEX_SHADER 0x8B31 +#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49 +#define GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A +#define GL_MAX_VARYING_FLOATS 0x8B4B +#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C +#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D +#define GL_SHADER_TYPE 0x8B4F +#define GL_FLOAT_VEC2 0x8B50 +#define GL_FLOAT_VEC3 0x8B51 +#define GL_FLOAT_VEC4 0x8B52 +#define GL_INT_VEC2 0x8B53 +#define GL_INT_VEC3 0x8B54 +#define GL_INT_VEC4 0x8B55 +#define GL_BOOL 0x8B56 +#define GL_BOOL_VEC2 0x8B57 +#define GL_BOOL_VEC3 0x8B58 +#define GL_BOOL_VEC4 0x8B59 +#define GL_FLOAT_MAT2 0x8B5A +#define GL_FLOAT_MAT3 0x8B5B +#define GL_FLOAT_MAT4 0x8B5C +#define GL_SAMPLER_1D 0x8B5D +#define GL_SAMPLER_2D 0x8B5E +#define GL_SAMPLER_3D 0x8B5F +#define GL_SAMPLER_CUBE 0x8B60 +#define GL_SAMPLER_1D_SHADOW 0x8B61 +#define GL_SAMPLER_2D_SHADOW 0x8B62 +#define GL_DELETE_STATUS 0x8B80 +#define GL_COMPILE_STATUS 0x8B81 +#define GL_LINK_STATUS 0x8B82 +#define GL_VALIDATE_STATUS 0x8B83 +#define GL_INFO_LOG_LENGTH 0x8B84 +#define GL_ATTACHED_SHADERS 0x8B85 +#define GL_ACTIVE_UNIFORMS 0x8B86 +#define GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87 +#define GL_SHADER_SOURCE_LENGTH 0x8B88 +#define GL_ACTIVE_ATTRIBUTES 0x8B89 +#define GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A +#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B +#define GL_SHADING_LANGUAGE_VERSION 0x8B8C +#define GL_CURRENT_PROGRAM 0x8B8D +#define GL_POINT_SPRITE_COORD_ORIGIN 0x8CA0 +#define GL_LOWER_LEFT 0x8CA1 +#define GL_UPPER_LEFT 0x8CA2 +#define GL_STENCIL_BACK_REF 0x8CA3 +#define GL_STENCIL_BACK_VALUE_MASK 0x8CA4 +#define GL_STENCIL_BACK_WRITEMASK 0x8CA5 + +typedef char GLchar; + +typedef void (GLAPIENTRY * PFNGLATTACHSHADERPROC) (GLuint program, GLuint shader); +typedef void (GLAPIENTRY * PFNGLBINDATTRIBLOCATIONPROC) (GLuint program, GLuint index, const GLchar* name); +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEPROC) (GLenum, GLenum); +typedef void (GLAPIENTRY * PFNGLCOMPILESHADERPROC) (GLuint shader); +typedef GLuint (GLAPIENTRY * PFNGLCREATEPROGRAMPROC) (void); +typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROC) (GLenum type); +typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMPROC) (GLuint program); +typedef void (GLAPIENTRY * PFNGLDELETESHADERPROC) (GLuint shader); +typedef void (GLAPIENTRY * PFNGLDETACHSHADERPROC) (GLuint program, GLuint shader); +typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBARRAYPROC) (GLuint); +typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSPROC) (GLsizei n, const GLenum* bufs); +typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBARRAYPROC) (GLuint); +typedef void (GLAPIENTRY * PFNGLGETACTIVEATTRIBPROC) (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name); +typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMPROC) (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name); +typedef void (GLAPIENTRY * PFNGLGETATTACHEDSHADERSPROC) (GLuint program, GLsizei maxCount, GLsizei* count, GLuint* shaders); +typedef GLint (GLAPIENTRY * PFNGLGETATTRIBLOCATIONPROC) (GLuint program, const GLchar* name); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMINFOLOGPROC) (GLuint program, GLsizei bufSize, GLsizei* length, GLchar* infoLog); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVPROC) (GLuint program, GLenum pname, GLint* param); +typedef void (GLAPIENTRY * PFNGLGETSHADERINFOLOGPROC) (GLuint shader, GLsizei bufSize, GLsizei* length, GLchar* infoLog); +typedef void (GLAPIENTRY * PFNGLGETSHADERSOURCEPROC) (GLint obj, GLsizei maxLength, GLsizei* length, GLchar* source); +typedef void (GLAPIENTRY * PFNGLGETSHADERIVPROC) (GLuint shader, GLenum pname, GLint* param); +typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMLOCATIONPROC) (GLuint program, const GLchar* name); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMFVPROC) (GLuint program, GLint location, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMIVPROC) (GLuint program, GLint location, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVPROC) (GLuint, GLenum, GLvoid*); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVPROC) (GLuint, GLenum, GLdouble*); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVPROC) (GLuint, GLenum, GLfloat*); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVPROC) (GLuint, GLenum, GLint*); +typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMPROC) (GLuint program); +typedef GLboolean (GLAPIENTRY * PFNGLISSHADERPROC) (GLuint shader); +typedef void (GLAPIENTRY * PFNGLLINKPROGRAMPROC) (GLuint program); +typedef void (GLAPIENTRY * PFNGLSHADERSOURCEPROC) (GLuint shader, GLsizei count, const GLchar** strings, const GLint* lengths); +typedef void (GLAPIENTRY * PFNGLSTENCILFUNCSEPARATEPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); +typedef void (GLAPIENTRY * PFNGLSTENCILMASKSEPARATEPROC) (GLenum, GLuint); +typedef void (GLAPIENTRY * PFNGLSTENCILOPSEPARATEPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +typedef void (GLAPIENTRY * PFNGLUNIFORM1FPROC) (GLint location, GLfloat v0); +typedef void (GLAPIENTRY * PFNGLUNIFORM1FVPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM1IPROC) (GLint location, GLint v0); +typedef void (GLAPIENTRY * PFNGLUNIFORM1IVPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM2FPROC) (GLint location, GLfloat v0, GLfloat v1); +typedef void (GLAPIENTRY * PFNGLUNIFORM2FVPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM2IPROC) (GLint location, GLint v0, GLint v1); +typedef void (GLAPIENTRY * PFNGLUNIFORM2IVPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM3FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (GLAPIENTRY * PFNGLUNIFORM3FVPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM3IPROC) (GLint location, GLint v0, GLint v1, GLint v2); +typedef void (GLAPIENTRY * PFNGLUNIFORM3IVPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM4FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (GLAPIENTRY * PFNGLUNIFORM4FVPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM4IPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (GLAPIENTRY * PFNGLUNIFORM4IVPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUSEPROGRAMPROC) (GLuint program); +typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMPROC) (GLuint program); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DPROC) (GLuint index, GLdouble x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FPROC) (GLuint index, GLfloat x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SPROC) (GLuint index, GLshort x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SPROC) (GLuint index, GLshort x, GLshort y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NBVPROC) (GLuint index, const GLbyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NIVPROC) (GLuint index, const GLint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NSVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBVPROC) (GLuint index, const GLubyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUIVPROC) (GLuint index, const GLuint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUSVPROC) (GLuint index, const GLushort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4BVPROC) (GLuint index, const GLbyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4IVPROC) (GLuint index, const GLint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVPROC) (GLuint index, const GLubyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UIVPROC) (GLuint index, const GLuint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4USVPROC) (GLuint index, const GLushort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid* pointer); + +#define glAttachShader GLEW_GET_FUN(__glewAttachShader) +#define glBindAttribLocation GLEW_GET_FUN(__glewBindAttribLocation) +#define glBlendEquationSeparate GLEW_GET_FUN(__glewBlendEquationSeparate) +#define glCompileShader GLEW_GET_FUN(__glewCompileShader) +#define glCreateProgram GLEW_GET_FUN(__glewCreateProgram) +#define glCreateShader GLEW_GET_FUN(__glewCreateShader) +#define glDeleteProgram GLEW_GET_FUN(__glewDeleteProgram) +#define glDeleteShader GLEW_GET_FUN(__glewDeleteShader) +#define glDetachShader GLEW_GET_FUN(__glewDetachShader) +#define glDisableVertexAttribArray GLEW_GET_FUN(__glewDisableVertexAttribArray) +#define glDrawBuffers GLEW_GET_FUN(__glewDrawBuffers) +#define glEnableVertexAttribArray GLEW_GET_FUN(__glewEnableVertexAttribArray) +#define glGetActiveAttrib GLEW_GET_FUN(__glewGetActiveAttrib) +#define glGetActiveUniform GLEW_GET_FUN(__glewGetActiveUniform) +#define glGetAttachedShaders GLEW_GET_FUN(__glewGetAttachedShaders) +#define glGetAttribLocation GLEW_GET_FUN(__glewGetAttribLocation) +#define glGetProgramInfoLog GLEW_GET_FUN(__glewGetProgramInfoLog) +#define glGetProgramiv GLEW_GET_FUN(__glewGetProgramiv) +#define glGetShaderInfoLog GLEW_GET_FUN(__glewGetShaderInfoLog) +#define glGetShaderSource GLEW_GET_FUN(__glewGetShaderSource) +#define glGetShaderiv GLEW_GET_FUN(__glewGetShaderiv) +#define glGetUniformLocation GLEW_GET_FUN(__glewGetUniformLocation) +#define glGetUniformfv GLEW_GET_FUN(__glewGetUniformfv) +#define glGetUniformiv GLEW_GET_FUN(__glewGetUniformiv) +#define glGetVertexAttribPointerv GLEW_GET_FUN(__glewGetVertexAttribPointerv) +#define glGetVertexAttribdv GLEW_GET_FUN(__glewGetVertexAttribdv) +#define glGetVertexAttribfv GLEW_GET_FUN(__glewGetVertexAttribfv) +#define glGetVertexAttribiv GLEW_GET_FUN(__glewGetVertexAttribiv) +#define glIsProgram GLEW_GET_FUN(__glewIsProgram) +#define glIsShader GLEW_GET_FUN(__glewIsShader) +#define glLinkProgram GLEW_GET_FUN(__glewLinkProgram) +#define glShaderSource GLEW_GET_FUN(__glewShaderSource) +#define glStencilFuncSeparate GLEW_GET_FUN(__glewStencilFuncSeparate) +#define glStencilMaskSeparate GLEW_GET_FUN(__glewStencilMaskSeparate) +#define glStencilOpSeparate GLEW_GET_FUN(__glewStencilOpSeparate) +#define glUniform1f GLEW_GET_FUN(__glewUniform1f) +#define glUniform1fv GLEW_GET_FUN(__glewUniform1fv) +#define glUniform1i GLEW_GET_FUN(__glewUniform1i) +#define glUniform1iv GLEW_GET_FUN(__glewUniform1iv) +#define glUniform2f GLEW_GET_FUN(__glewUniform2f) +#define glUniform2fv GLEW_GET_FUN(__glewUniform2fv) +#define glUniform2i GLEW_GET_FUN(__glewUniform2i) +#define glUniform2iv GLEW_GET_FUN(__glewUniform2iv) +#define glUniform3f GLEW_GET_FUN(__glewUniform3f) +#define glUniform3fv GLEW_GET_FUN(__glewUniform3fv) +#define glUniform3i GLEW_GET_FUN(__glewUniform3i) +#define glUniform3iv GLEW_GET_FUN(__glewUniform3iv) +#define glUniform4f GLEW_GET_FUN(__glewUniform4f) +#define glUniform4fv GLEW_GET_FUN(__glewUniform4fv) +#define glUniform4i GLEW_GET_FUN(__glewUniform4i) +#define glUniform4iv GLEW_GET_FUN(__glewUniform4iv) +#define glUniformMatrix2fv GLEW_GET_FUN(__glewUniformMatrix2fv) +#define glUniformMatrix3fv GLEW_GET_FUN(__glewUniformMatrix3fv) +#define glUniformMatrix4fv GLEW_GET_FUN(__glewUniformMatrix4fv) +#define glUseProgram GLEW_GET_FUN(__glewUseProgram) +#define glValidateProgram GLEW_GET_FUN(__glewValidateProgram) +#define glVertexAttrib1d GLEW_GET_FUN(__glewVertexAttrib1d) +#define glVertexAttrib1dv GLEW_GET_FUN(__glewVertexAttrib1dv) +#define glVertexAttrib1f GLEW_GET_FUN(__glewVertexAttrib1f) +#define glVertexAttrib1fv GLEW_GET_FUN(__glewVertexAttrib1fv) +#define glVertexAttrib1s GLEW_GET_FUN(__glewVertexAttrib1s) +#define glVertexAttrib1sv GLEW_GET_FUN(__glewVertexAttrib1sv) +#define glVertexAttrib2d GLEW_GET_FUN(__glewVertexAttrib2d) +#define glVertexAttrib2dv GLEW_GET_FUN(__glewVertexAttrib2dv) +#define glVertexAttrib2f GLEW_GET_FUN(__glewVertexAttrib2f) +#define glVertexAttrib2fv GLEW_GET_FUN(__glewVertexAttrib2fv) +#define glVertexAttrib2s GLEW_GET_FUN(__glewVertexAttrib2s) +#define glVertexAttrib2sv GLEW_GET_FUN(__glewVertexAttrib2sv) +#define glVertexAttrib3d GLEW_GET_FUN(__glewVertexAttrib3d) +#define glVertexAttrib3dv GLEW_GET_FUN(__glewVertexAttrib3dv) +#define glVertexAttrib3f GLEW_GET_FUN(__glewVertexAttrib3f) +#define glVertexAttrib3fv GLEW_GET_FUN(__glewVertexAttrib3fv) +#define glVertexAttrib3s GLEW_GET_FUN(__glewVertexAttrib3s) +#define glVertexAttrib3sv GLEW_GET_FUN(__glewVertexAttrib3sv) +#define glVertexAttrib4Nbv GLEW_GET_FUN(__glewVertexAttrib4Nbv) +#define glVertexAttrib4Niv GLEW_GET_FUN(__glewVertexAttrib4Niv) +#define glVertexAttrib4Nsv GLEW_GET_FUN(__glewVertexAttrib4Nsv) +#define glVertexAttrib4Nub GLEW_GET_FUN(__glewVertexAttrib4Nub) +#define glVertexAttrib4Nubv GLEW_GET_FUN(__glewVertexAttrib4Nubv) +#define glVertexAttrib4Nuiv GLEW_GET_FUN(__glewVertexAttrib4Nuiv) +#define glVertexAttrib4Nusv GLEW_GET_FUN(__glewVertexAttrib4Nusv) +#define glVertexAttrib4bv GLEW_GET_FUN(__glewVertexAttrib4bv) +#define glVertexAttrib4d GLEW_GET_FUN(__glewVertexAttrib4d) +#define glVertexAttrib4dv GLEW_GET_FUN(__glewVertexAttrib4dv) +#define glVertexAttrib4f GLEW_GET_FUN(__glewVertexAttrib4f) +#define glVertexAttrib4fv GLEW_GET_FUN(__glewVertexAttrib4fv) +#define glVertexAttrib4iv GLEW_GET_FUN(__glewVertexAttrib4iv) +#define glVertexAttrib4s GLEW_GET_FUN(__glewVertexAttrib4s) +#define glVertexAttrib4sv GLEW_GET_FUN(__glewVertexAttrib4sv) +#define glVertexAttrib4ubv GLEW_GET_FUN(__glewVertexAttrib4ubv) +#define glVertexAttrib4uiv GLEW_GET_FUN(__glewVertexAttrib4uiv) +#define glVertexAttrib4usv GLEW_GET_FUN(__glewVertexAttrib4usv) +#define glVertexAttribPointer GLEW_GET_FUN(__glewVertexAttribPointer) + +#define GLEW_VERSION_2_0 GLEW_GET_VAR(__GLEW_VERSION_2_0) + +#endif /* GL_VERSION_2_0 */ + +/* ----------------------------- GL_VERSION_2_1 ---------------------------- */ + +#ifndef GL_VERSION_2_1 +#define GL_VERSION_2_1 1 + +#define GL_CURRENT_RASTER_SECONDARY_COLOR 0x845F +#define GL_PIXEL_PACK_BUFFER 0x88EB +#define GL_PIXEL_UNPACK_BUFFER 0x88EC +#define GL_PIXEL_PACK_BUFFER_BINDING 0x88ED +#define GL_PIXEL_UNPACK_BUFFER_BINDING 0x88EF +#define GL_FLOAT_MAT2x3 0x8B65 +#define GL_FLOAT_MAT2x4 0x8B66 +#define GL_FLOAT_MAT3x2 0x8B67 +#define GL_FLOAT_MAT3x4 0x8B68 +#define GL_FLOAT_MAT4x2 0x8B69 +#define GL_FLOAT_MAT4x3 0x8B6A +#define GL_SRGB 0x8C40 +#define GL_SRGB8 0x8C41 +#define GL_SRGB_ALPHA 0x8C42 +#define GL_SRGB8_ALPHA8 0x8C43 +#define GL_SLUMINANCE_ALPHA 0x8C44 +#define GL_SLUMINANCE8_ALPHA8 0x8C45 +#define GL_SLUMINANCE 0x8C46 +#define GL_SLUMINANCE8 0x8C47 +#define GL_COMPRESSED_SRGB 0x8C48 +#define GL_COMPRESSED_SRGB_ALPHA 0x8C49 +#define GL_COMPRESSED_SLUMINANCE 0x8C4A +#define GL_COMPRESSED_SLUMINANCE_ALPHA 0x8C4B + +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); + +#define glUniformMatrix2x3fv GLEW_GET_FUN(__glewUniformMatrix2x3fv) +#define glUniformMatrix2x4fv GLEW_GET_FUN(__glewUniformMatrix2x4fv) +#define glUniformMatrix3x2fv GLEW_GET_FUN(__glewUniformMatrix3x2fv) +#define glUniformMatrix3x4fv GLEW_GET_FUN(__glewUniformMatrix3x4fv) +#define glUniformMatrix4x2fv GLEW_GET_FUN(__glewUniformMatrix4x2fv) +#define glUniformMatrix4x3fv GLEW_GET_FUN(__glewUniformMatrix4x3fv) + +#define GLEW_VERSION_2_1 GLEW_GET_VAR(__GLEW_VERSION_2_1) + +#endif /* GL_VERSION_2_1 */ + +/* ----------------------------- GL_VERSION_3_0 ---------------------------- */ + +#ifndef GL_VERSION_3_0 +#define GL_VERSION_3_0 1 + +#define GL_MAX_CLIP_DISTANCES GL_MAX_CLIP_PLANES +#define GL_CLIP_DISTANCE5 GL_CLIP_PLANE5 +#define GL_CLIP_DISTANCE1 GL_CLIP_PLANE1 +#define GL_CLIP_DISTANCE3 GL_CLIP_PLANE3 +#define GL_COMPARE_REF_TO_TEXTURE GL_COMPARE_R_TO_TEXTURE_ARB +#define GL_CLIP_DISTANCE0 GL_CLIP_PLANE0 +#define GL_CLIP_DISTANCE4 GL_CLIP_PLANE4 +#define GL_CLIP_DISTANCE2 GL_CLIP_PLANE2 +#define GL_MAX_VARYING_COMPONENTS GL_MAX_VARYING_FLOATS +#define GL_CONTEXT_FLAG_FORWARD_COMPATIBLE_BIT 0x0001 +#define GL_MAJOR_VERSION 0x821B +#define GL_MINOR_VERSION 0x821C +#define GL_NUM_EXTENSIONS 0x821D +#define GL_CONTEXT_FLAGS 0x821E +#define GL_DEPTH_BUFFER 0x8223 +#define GL_STENCIL_BUFFER 0x8224 +#define GL_COMPRESSED_RED 0x8225 +#define GL_COMPRESSED_RG 0x8226 +#define GL_RGBA32F 0x8814 +#define GL_RGB32F 0x8815 +#define GL_RGBA16F 0x881A +#define GL_RGB16F 0x881B +#define GL_VERTEX_ATTRIB_ARRAY_INTEGER 0x88FD +#define GL_MAX_ARRAY_TEXTURE_LAYERS 0x88FF +#define GL_MIN_PROGRAM_TEXEL_OFFSET 0x8904 +#define GL_MAX_PROGRAM_TEXEL_OFFSET 0x8905 +#define GL_CLAMP_VERTEX_COLOR 0x891A +#define GL_CLAMP_FRAGMENT_COLOR 0x891B +#define GL_CLAMP_READ_COLOR 0x891C +#define GL_FIXED_ONLY 0x891D +#define GL_TEXTURE_RED_TYPE 0x8C10 +#define GL_TEXTURE_GREEN_TYPE 0x8C11 +#define GL_TEXTURE_BLUE_TYPE 0x8C12 +#define GL_TEXTURE_ALPHA_TYPE 0x8C13 +#define GL_TEXTURE_LUMINANCE_TYPE 0x8C14 +#define GL_TEXTURE_INTENSITY_TYPE 0x8C15 +#define GL_TEXTURE_DEPTH_TYPE 0x8C16 +#define GL_UNSIGNED_NORMALIZED 0x8C17 +#define GL_TEXTURE_1D_ARRAY 0x8C18 +#define GL_PROXY_TEXTURE_1D_ARRAY 0x8C19 +#define GL_TEXTURE_2D_ARRAY 0x8C1A +#define GL_PROXY_TEXTURE_2D_ARRAY 0x8C1B +#define GL_TEXTURE_BINDING_1D_ARRAY 0x8C1C +#define GL_TEXTURE_BINDING_2D_ARRAY 0x8C1D +#define GL_R11F_G11F_B10F 0x8C3A +#define GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B +#define GL_RGB9_E5 0x8C3D +#define GL_UNSIGNED_INT_5_9_9_9_REV 0x8C3E +#define GL_TEXTURE_SHARED_SIZE 0x8C3F +#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH 0x8C76 +#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE 0x8C7F +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS 0x8C80 +#define GL_TRANSFORM_FEEDBACK_VARYINGS 0x8C83 +#define GL_TRANSFORM_FEEDBACK_BUFFER_START 0x8C84 +#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE 0x8C85 +#define GL_PRIMITIVES_GENERATED 0x8C87 +#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN 0x8C88 +#define GL_RASTERIZER_DISCARD 0x8C89 +#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS 0x8C8A +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS 0x8C8B +#define GL_INTERLEAVED_ATTRIBS 0x8C8C +#define GL_SEPARATE_ATTRIBS 0x8C8D +#define GL_TRANSFORM_FEEDBACK_BUFFER 0x8C8E +#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING 0x8C8F +#define GL_RGBA32UI 0x8D70 +#define GL_RGB32UI 0x8D71 +#define GL_RGBA16UI 0x8D76 +#define GL_RGB16UI 0x8D77 +#define GL_RGBA8UI 0x8D7C +#define GL_RGB8UI 0x8D7D +#define GL_RGBA32I 0x8D82 +#define GL_RGB32I 0x8D83 +#define GL_RGBA16I 0x8D88 +#define GL_RGB16I 0x8D89 +#define GL_RGBA8I 0x8D8E +#define GL_RGB8I 0x8D8F +#define GL_RED_INTEGER 0x8D94 +#define GL_GREEN_INTEGER 0x8D95 +#define GL_BLUE_INTEGER 0x8D96 +#define GL_ALPHA_INTEGER 0x8D97 +#define GL_RGB_INTEGER 0x8D98 +#define GL_RGBA_INTEGER 0x8D99 +#define GL_BGR_INTEGER 0x8D9A +#define GL_BGRA_INTEGER 0x8D9B +#define GL_SAMPLER_1D_ARRAY 0x8DC0 +#define GL_SAMPLER_2D_ARRAY 0x8DC1 +#define GL_SAMPLER_1D_ARRAY_SHADOW 0x8DC3 +#define GL_SAMPLER_2D_ARRAY_SHADOW 0x8DC4 +#define GL_SAMPLER_CUBE_SHADOW 0x8DC5 +#define GL_UNSIGNED_INT_VEC2 0x8DC6 +#define GL_UNSIGNED_INT_VEC3 0x8DC7 +#define GL_UNSIGNED_INT_VEC4 0x8DC8 +#define GL_INT_SAMPLER_1D 0x8DC9 +#define GL_INT_SAMPLER_2D 0x8DCA +#define GL_INT_SAMPLER_3D 0x8DCB +#define GL_INT_SAMPLER_CUBE 0x8DCC +#define GL_INT_SAMPLER_1D_ARRAY 0x8DCE +#define GL_INT_SAMPLER_2D_ARRAY 0x8DCF +#define GL_UNSIGNED_INT_SAMPLER_1D 0x8DD1 +#define GL_UNSIGNED_INT_SAMPLER_2D 0x8DD2 +#define GL_UNSIGNED_INT_SAMPLER_3D 0x8DD3 +#define GL_UNSIGNED_INT_SAMPLER_CUBE 0x8DD4 +#define GL_UNSIGNED_INT_SAMPLER_1D_ARRAY 0x8DD6 +#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY 0x8DD7 +#define GL_QUERY_WAIT 0x8E13 +#define GL_QUERY_NO_WAIT 0x8E14 +#define GL_QUERY_BY_REGION_WAIT 0x8E15 +#define GL_QUERY_BY_REGION_NO_WAIT 0x8E16 + +typedef void (GLAPIENTRY * PFNGLBEGINCONDITIONALRENDERPROC) (GLuint, GLenum); +typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKPROC) (GLenum); +typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONPROC) (GLuint, GLuint, const GLchar*); +typedef void (GLAPIENTRY * PFNGLCLAMPCOLORPROC) (GLenum, GLenum); +typedef void (GLAPIENTRY * PFNGLCLEARBUFFERFIPROC) (GLenum, GLint, GLfloat, GLint); +typedef void (GLAPIENTRY * PFNGLCLEARBUFFERFVPROC) (GLenum, GLint, const GLfloat*); +typedef void (GLAPIENTRY * PFNGLCLEARBUFFERIVPROC) (GLenum, GLint, const GLint*); +typedef void (GLAPIENTRY * PFNGLCLEARBUFFERUIVPROC) (GLenum, GLint, const GLuint*); +typedef void (GLAPIENTRY * PFNGLCOLORMASKIPROC) (GLuint, GLboolean, GLboolean, GLboolean, GLboolean); +typedef void (GLAPIENTRY * PFNGLDISABLEIPROC) (GLenum, GLuint); +typedef void (GLAPIENTRY * PFNGLENABLEIPROC) (GLenum, GLuint); +typedef void (GLAPIENTRY * PFNGLENDCONDITIONALRENDERPROC) (void); +typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKPROC) (void); +typedef void (GLAPIENTRY * PFNGLGETBOOLEANI_VPROC) (GLenum, GLuint, GLboolean*); +typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATALOCATIONPROC) (GLuint, const GLchar*); +typedef const GLubyte* (GLAPIENTRY * PFNGLGETSTRINGIPROC) (GLenum, GLuint); +typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIIVPROC) (GLenum, GLenum, GLint*); +typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIUIVPROC) (GLenum, GLenum, GLuint*); +typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGPROC) (GLuint, GLuint, GLint*); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMUIVPROC) (GLuint, GLint, GLuint*); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIIVPROC) (GLuint, GLenum, GLint*); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIUIVPROC) (GLuint, GLenum, GLuint*); +typedef GLboolean (GLAPIENTRY * PFNGLISENABLEDIPROC) (GLenum, GLuint); +typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIIVPROC) (GLenum, GLenum, const GLint*); +typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIUIVPROC) (GLenum, GLenum, const GLuint*); +typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSPROC) (GLuint, GLsizei, const GLchar **, GLenum); +typedef void (GLAPIENTRY * PFNGLUNIFORM1UIPROC) (GLint, GLuint); +typedef void (GLAPIENTRY * PFNGLUNIFORM1UIVPROC) (GLint, GLsizei, const GLuint*); +typedef void (GLAPIENTRY * PFNGLUNIFORM2UIPROC) (GLint, GLuint, GLuint); +typedef void (GLAPIENTRY * PFNGLUNIFORM2UIVPROC) (GLint, GLsizei, const GLuint*); +typedef void (GLAPIENTRY * PFNGLUNIFORM3UIPROC) (GLint, GLuint, GLuint, GLuint); +typedef void (GLAPIENTRY * PFNGLUNIFORM3UIVPROC) (GLint, GLsizei, const GLuint*); +typedef void (GLAPIENTRY * PFNGLUNIFORM4UIPROC) (GLint, GLuint, GLuint, GLuint, GLuint); +typedef void (GLAPIENTRY * PFNGLUNIFORM4UIVPROC) (GLint, GLsizei, const GLuint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IPROC) (GLuint, GLint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IVPROC) (GLuint, const GLint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIPROC) (GLuint, GLuint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIVPROC) (GLuint, const GLuint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IPROC) (GLuint, GLint, GLint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IVPROC) (GLuint, const GLint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIPROC) (GLuint, GLuint, GLuint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIVPROC) (GLuint, const GLuint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IPROC) (GLuint, GLint, GLint, GLint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IVPROC) (GLuint, const GLint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIPROC) (GLuint, GLuint, GLuint, GLuint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIVPROC) (GLuint, const GLuint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4BVPROC) (GLuint, const GLbyte*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IPROC) (GLuint, GLint, GLint, GLint, GLint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IVPROC) (GLuint, const GLint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4SVPROC) (GLuint, const GLshort*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UBVPROC) (GLuint, const GLubyte*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIPROC) (GLuint, GLuint, GLuint, GLuint, GLuint); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIVPROC) (GLuint, const GLuint*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4USVPROC) (GLuint, const GLushort*); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIPOINTERPROC) (GLuint, GLint, GLenum, GLsizei, const GLvoid*); + +#define glBeginConditionalRender GLEW_GET_FUN(__glewBeginConditionalRender) +#define glBeginTransformFeedback GLEW_GET_FUN(__glewBeginTransformFeedback) +#define glBindFragDataLocation GLEW_GET_FUN(__glewBindFragDataLocation) +#define glClampColor GLEW_GET_FUN(__glewClampColor) +#define glClearBufferfi GLEW_GET_FUN(__glewClearBufferfi) +#define glClearBufferfv GLEW_GET_FUN(__glewClearBufferfv) +#define glClearBufferiv GLEW_GET_FUN(__glewClearBufferiv) +#define glClearBufferuiv GLEW_GET_FUN(__glewClearBufferuiv) +#define glColorMaski GLEW_GET_FUN(__glewColorMaski) +#define glDisablei GLEW_GET_FUN(__glewDisablei) +#define glEnablei GLEW_GET_FUN(__glewEnablei) +#define glEndConditionalRender GLEW_GET_FUN(__glewEndConditionalRender) +#define glEndTransformFeedback GLEW_GET_FUN(__glewEndTransformFeedback) +#define glGetBooleani_v GLEW_GET_FUN(__glewGetBooleani_v) +#define glGetFragDataLocation GLEW_GET_FUN(__glewGetFragDataLocation) +#define glGetStringi GLEW_GET_FUN(__glewGetStringi) +#define glGetTexParameterIiv GLEW_GET_FUN(__glewGetTexParameterIiv) +#define glGetTexParameterIuiv GLEW_GET_FUN(__glewGetTexParameterIuiv) +#define glGetTransformFeedbackVarying GLEW_GET_FUN(__glewGetTransformFeedbackVarying) +#define glGetUniformuiv GLEW_GET_FUN(__glewGetUniformuiv) +#define glGetVertexAttribIiv GLEW_GET_FUN(__glewGetVertexAttribIiv) +#define glGetVertexAttribIuiv GLEW_GET_FUN(__glewGetVertexAttribIuiv) +#define glIsEnabledi GLEW_GET_FUN(__glewIsEnabledi) +#define glTexParameterIiv GLEW_GET_FUN(__glewTexParameterIiv) +#define glTexParameterIuiv GLEW_GET_FUN(__glewTexParameterIuiv) +#define glTransformFeedbackVaryings GLEW_GET_FUN(__glewTransformFeedbackVaryings) +#define glUniform1ui GLEW_GET_FUN(__glewUniform1ui) +#define glUniform1uiv GLEW_GET_FUN(__glewUniform1uiv) +#define glUniform2ui GLEW_GET_FUN(__glewUniform2ui) +#define glUniform2uiv GLEW_GET_FUN(__glewUniform2uiv) +#define glUniform3ui GLEW_GET_FUN(__glewUniform3ui) +#define glUniform3uiv GLEW_GET_FUN(__glewUniform3uiv) +#define glUniform4ui GLEW_GET_FUN(__glewUniform4ui) +#define glUniform4uiv GLEW_GET_FUN(__glewUniform4uiv) +#define glVertexAttribI1i GLEW_GET_FUN(__glewVertexAttribI1i) +#define glVertexAttribI1iv GLEW_GET_FUN(__glewVertexAttribI1iv) +#define glVertexAttribI1ui GLEW_GET_FUN(__glewVertexAttribI1ui) +#define glVertexAttribI1uiv GLEW_GET_FUN(__glewVertexAttribI1uiv) +#define glVertexAttribI2i GLEW_GET_FUN(__glewVertexAttribI2i) +#define glVertexAttribI2iv GLEW_GET_FUN(__glewVertexAttribI2iv) +#define glVertexAttribI2ui GLEW_GET_FUN(__glewVertexAttribI2ui) +#define glVertexAttribI2uiv GLEW_GET_FUN(__glewVertexAttribI2uiv) +#define glVertexAttribI3i GLEW_GET_FUN(__glewVertexAttribI3i) +#define glVertexAttribI3iv GLEW_GET_FUN(__glewVertexAttribI3iv) +#define glVertexAttribI3ui GLEW_GET_FUN(__glewVertexAttribI3ui) +#define glVertexAttribI3uiv GLEW_GET_FUN(__glewVertexAttribI3uiv) +#define glVertexAttribI4bv GLEW_GET_FUN(__glewVertexAttribI4bv) +#define glVertexAttribI4i GLEW_GET_FUN(__glewVertexAttribI4i) +#define glVertexAttribI4iv GLEW_GET_FUN(__glewVertexAttribI4iv) +#define glVertexAttribI4sv GLEW_GET_FUN(__glewVertexAttribI4sv) +#define glVertexAttribI4ubv GLEW_GET_FUN(__glewVertexAttribI4ubv) +#define glVertexAttribI4ui GLEW_GET_FUN(__glewVertexAttribI4ui) +#define glVertexAttribI4uiv GLEW_GET_FUN(__glewVertexAttribI4uiv) +#define glVertexAttribI4usv GLEW_GET_FUN(__glewVertexAttribI4usv) +#define glVertexAttribIPointer GLEW_GET_FUN(__glewVertexAttribIPointer) + +#define GLEW_VERSION_3_0 GLEW_GET_VAR(__GLEW_VERSION_3_0) + +#endif /* GL_VERSION_3_0 */ + +/* ----------------------------- GL_VERSION_3_1 ---------------------------- */ + +#ifndef GL_VERSION_3_1 +#define GL_VERSION_3_1 1 + +#define GL_TEXTURE_RECTANGLE 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE 0x84F8 +#define GL_SAMPLER_2D_RECT 0x8B63 +#define GL_SAMPLER_2D_RECT_SHADOW 0x8B64 +#define GL_TEXTURE_BUFFER 0x8C2A +#define GL_MAX_TEXTURE_BUFFER_SIZE 0x8C2B +#define GL_TEXTURE_BINDING_BUFFER 0x8C2C +#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING 0x8C2D +#define GL_TEXTURE_BUFFER_FORMAT 0x8C2E +#define GL_SAMPLER_BUFFER 0x8DC2 +#define GL_INT_SAMPLER_2D_RECT 0x8DCD +#define GL_INT_SAMPLER_BUFFER 0x8DD0 +#define GL_UNSIGNED_INT_SAMPLER_2D_RECT 0x8DD5 +#define GL_UNSIGNED_INT_SAMPLER_BUFFER 0x8DD8 +#define GL_RED_SNORM 0x8F90 +#define GL_RG_SNORM 0x8F91 +#define GL_RGB_SNORM 0x8F92 +#define GL_RGBA_SNORM 0x8F93 +#define GL_R8_SNORM 0x8F94 +#define GL_RG8_SNORM 0x8F95 +#define GL_RGB8_SNORM 0x8F96 +#define GL_RGBA8_SNORM 0x8F97 +#define GL_R16_SNORM 0x8F98 +#define GL_RG16_SNORM 0x8F99 +#define GL_RGB16_SNORM 0x8F9A +#define GL_RGBA16_SNORM 0x8F9B +#define GL_SIGNED_NORMALIZED 0x8F9C +#define GL_PRIMITIVE_RESTART 0x8F9D +#define GL_PRIMITIVE_RESTART_INDEX 0x8F9E +#define GL_BUFFER_ACCESS_FLAGS 0x911F +#define GL_BUFFER_MAP_LENGTH 0x9120 +#define GL_BUFFER_MAP_OFFSET 0x9121 + +typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDPROC) (GLenum, GLint, GLsizei, GLsizei); +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDPROC) (GLenum, GLsizei, GLenum, const GLvoid*, GLsizei); +typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTINDEXPROC) (GLuint); +typedef void (GLAPIENTRY * PFNGLTEXBUFFERPROC) (GLenum, GLenum, GLuint); + +#define glDrawArraysInstanced GLEW_GET_FUN(__glewDrawArraysInstanced) +#define glDrawElementsInstanced GLEW_GET_FUN(__glewDrawElementsInstanced) +#define glPrimitiveRestartIndex GLEW_GET_FUN(__glewPrimitiveRestartIndex) +#define glTexBuffer GLEW_GET_FUN(__glewTexBuffer) + +#define GLEW_VERSION_3_1 GLEW_GET_VAR(__GLEW_VERSION_3_1) + +#endif /* GL_VERSION_3_1 */ + +/* ----------------------------- GL_VERSION_3_2 ---------------------------- */ + +#ifndef GL_VERSION_3_2 +#define GL_VERSION_3_2 1 + +#define GL_CONTEXT_CORE_PROFILE_BIT 0x00000001 +#define GL_CONTEXT_COMPATIBILITY_PROFILE_BIT 0x00000002 +#define GL_LINES_ADJACENCY 0x000A +#define GL_LINE_STRIP_ADJACENCY 0x000B +#define GL_TRIANGLES_ADJACENCY 0x000C +#define GL_TRIANGLE_STRIP_ADJACENCY 0x000D +#define GL_PROGRAM_POINT_SIZE 0x8642 +#define GL_GEOMETRY_VERTICES_OUT 0x8916 +#define GL_GEOMETRY_INPUT_TYPE 0x8917 +#define GL_GEOMETRY_OUTPUT_TYPE 0x8918 +#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS 0x8C29 +#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED 0x8DA7 +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS 0x8DA8 +#define GL_GEOMETRY_SHADER 0x8DD9 +#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS 0x8DDF +#define GL_MAX_GEOMETRY_OUTPUT_VERTICES 0x8DE0 +#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS 0x8DE1 +#define GL_MAX_VERTEX_OUTPUT_COMPONENTS 0x9122 +#define GL_MAX_GEOMETRY_INPUT_COMPONENTS 0x9123 +#define GL_MAX_GEOMETRY_OUTPUT_COMPONENTS 0x9124 +#define GL_MAX_FRAGMENT_INPUT_COMPONENTS 0x9125 +#define GL_CONTEXT_PROFILE_MASK 0x9126 + +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREPROC) (GLenum, GLenum, GLuint, GLint); +typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERI64VPROC) (GLenum, GLenum, GLint64 *); +typedef void (GLAPIENTRY * PFNGLGETINTEGER64I_VPROC) (GLenum, GLuint, GLint64 *); + +#define glFramebufferTexture GLEW_GET_FUN(__glewFramebufferTexture) +#define glGetBufferParameteri64v GLEW_GET_FUN(__glewGetBufferParameteri64v) +#define glGetInteger64i_v GLEW_GET_FUN(__glewGetInteger64i_v) + +#define GLEW_VERSION_3_2 GLEW_GET_VAR(__GLEW_VERSION_3_2) + +#endif /* GL_VERSION_3_2 */ + +/* ----------------------------- GL_VERSION_3_3 ---------------------------- */ + +#ifndef GL_VERSION_3_3 +#define GL_VERSION_3_3 1 + +#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR 0x88FE +#define GL_ANY_SAMPLES_PASSED 0x8C2F +#define GL_TEXTURE_SWIZZLE_R 0x8E42 +#define GL_TEXTURE_SWIZZLE_G 0x8E43 +#define GL_TEXTURE_SWIZZLE_B 0x8E44 +#define GL_TEXTURE_SWIZZLE_A 0x8E45 +#define GL_TEXTURE_SWIZZLE_RGBA 0x8E46 +#define GL_RGB10_A2UI 0x906F + +#define GLEW_VERSION_3_3 GLEW_GET_VAR(__GLEW_VERSION_3_3) + +#endif /* GL_VERSION_3_3 */ + +/* ----------------------------- GL_VERSION_4_0 ---------------------------- */ + +#ifndef GL_VERSION_4_0 +#define GL_VERSION_4_0 1 + +#define GL_GEOMETRY_SHADER_INVOCATIONS 0x887F +#define GL_SAMPLE_SHADING 0x8C36 +#define GL_MIN_SAMPLE_SHADING_VALUE 0x8C37 +#define GL_MAX_GEOMETRY_SHADER_INVOCATIONS 0x8E5A +#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET 0x8E5B +#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET 0x8E5C +#define GL_FRAGMENT_INTERPOLATION_OFFSET_BITS 0x8E5D +#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5E +#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5F +#define GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS 0x8F9F +#define GL_TEXTURE_CUBE_MAP_ARRAY 0x9009 +#define GL_TEXTURE_BINDING_CUBE_MAP_ARRAY 0x900A +#define GL_PROXY_TEXTURE_CUBE_MAP_ARRAY 0x900B +#define GL_SAMPLER_CUBE_MAP_ARRAY 0x900C +#define GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW 0x900D +#define GL_INT_SAMPLER_CUBE_MAP_ARRAY 0x900E +#define GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY 0x900F + +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEIPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONIPROC) (GLuint buf, GLenum mode); +typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEIPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +typedef void (GLAPIENTRY * PFNGLBLENDFUNCIPROC) (GLuint buf, GLenum src, GLenum dst); +typedef void (GLAPIENTRY * PFNGLMINSAMPLESHADINGPROC) (GLclampf value); + +#define glBlendEquationSeparatei GLEW_GET_FUN(__glewBlendEquationSeparatei) +#define glBlendEquationi GLEW_GET_FUN(__glewBlendEquationi) +#define glBlendFuncSeparatei GLEW_GET_FUN(__glewBlendFuncSeparatei) +#define glBlendFunci GLEW_GET_FUN(__glewBlendFunci) +#define glMinSampleShading GLEW_GET_FUN(__glewMinSampleShading) + +#define GLEW_VERSION_4_0 GLEW_GET_VAR(__GLEW_VERSION_4_0) + +#endif /* GL_VERSION_4_0 */ + +/* -------------------------- GL_3DFX_multisample -------------------------- */ + +#ifndef GL_3DFX_multisample +#define GL_3DFX_multisample 1 + +#define GL_MULTISAMPLE_3DFX 0x86B2 +#define GL_SAMPLE_BUFFERS_3DFX 0x86B3 +#define GL_SAMPLES_3DFX 0x86B4 +#define GL_MULTISAMPLE_BIT_3DFX 0x20000000 + +#define GLEW_3DFX_multisample GLEW_GET_VAR(__GLEW_3DFX_multisample) + +#endif /* GL_3DFX_multisample */ + +/* ---------------------------- GL_3DFX_tbuffer ---------------------------- */ + +#ifndef GL_3DFX_tbuffer +#define GL_3DFX_tbuffer 1 + +typedef void (GLAPIENTRY * PFNGLTBUFFERMASK3DFXPROC) (GLuint mask); + +#define glTbufferMask3DFX GLEW_GET_FUN(__glewTbufferMask3DFX) + +#define GLEW_3DFX_tbuffer GLEW_GET_VAR(__GLEW_3DFX_tbuffer) + +#endif /* GL_3DFX_tbuffer */ + +/* -------------------- GL_3DFX_texture_compression_FXT1 ------------------- */ + +#ifndef GL_3DFX_texture_compression_FXT1 +#define GL_3DFX_texture_compression_FXT1 1 + +#define GL_COMPRESSED_RGB_FXT1_3DFX 0x86B0 +#define GL_COMPRESSED_RGBA_FXT1_3DFX 0x86B1 + +#define GLEW_3DFX_texture_compression_FXT1 GLEW_GET_VAR(__GLEW_3DFX_texture_compression_FXT1) + +#endif /* GL_3DFX_texture_compression_FXT1 */ + +/* ----------------------- GL_AMD_conservative_depth ----------------------- */ + +#ifndef GL_AMD_conservative_depth +#define GL_AMD_conservative_depth 1 + +#define GLEW_AMD_conservative_depth GLEW_GET_VAR(__GLEW_AMD_conservative_depth) + +#endif /* GL_AMD_conservative_depth */ + +/* ----------------------- GL_AMD_draw_buffers_blend ----------------------- */ + +#ifndef GL_AMD_draw_buffers_blend +#define GL_AMD_draw_buffers_blend 1 + +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONINDEXEDAMDPROC) (GLuint buf, GLenum mode); +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +typedef void (GLAPIENTRY * PFNGLBLENDFUNCINDEXEDAMDPROC) (GLuint buf, GLenum src, GLenum dst); +typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); + +#define glBlendEquationIndexedAMD GLEW_GET_FUN(__glewBlendEquationIndexedAMD) +#define glBlendEquationSeparateIndexedAMD GLEW_GET_FUN(__glewBlendEquationSeparateIndexedAMD) +#define glBlendFuncIndexedAMD GLEW_GET_FUN(__glewBlendFuncIndexedAMD) +#define glBlendFuncSeparateIndexedAMD GLEW_GET_FUN(__glewBlendFuncSeparateIndexedAMD) + +#define GLEW_AMD_draw_buffers_blend GLEW_GET_VAR(__GLEW_AMD_draw_buffers_blend) + +#endif /* GL_AMD_draw_buffers_blend */ + +/* ----------------------- GL_AMD_performance_monitor ---------------------- */ + +#ifndef GL_AMD_performance_monitor +#define GL_AMD_performance_monitor 1 + +#define GL_UNSIGNED_INT 0x1405 +#define GL_FLOAT 0x1406 +#define GL_COUNTER_TYPE_AMD 0x8BC0 +#define GL_COUNTER_RANGE_AMD 0x8BC1 +#define GL_UNSIGNED_INT64_AMD 0x8BC2 +#define GL_PERCENTAGE_AMD 0x8BC3 +#define GL_PERFMON_RESULT_AVAILABLE_AMD 0x8BC4 +#define GL_PERFMON_RESULT_SIZE_AMD 0x8BC5 +#define GL_PERFMON_RESULT_AMD 0x8BC6 + +typedef void (GLAPIENTRY * PFNGLBEGINPERFMONITORAMDPROC) (GLuint monitor); +typedef void (GLAPIENTRY * PFNGLDELETEPERFMONITORSAMDPROC) (GLsizei n, GLuint* monitors); +typedef void (GLAPIENTRY * PFNGLENDPERFMONITORAMDPROC) (GLuint monitor); +typedef void (GLAPIENTRY * PFNGLGENPERFMONITORSAMDPROC) (GLsizei n, GLuint* monitors); +typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERDATAAMDPROC) (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint* data, GLint *bytesWritten); +typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERINFOAMDPROC) (GLuint group, GLuint counter, GLenum pname, void* data); +typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC) (GLuint group, GLuint counter, GLsizei bufSize, GLsizei* length, char *counterString); +typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERSAMDPROC) (GLuint group, GLint* numCounters, GLint *maxActiveCounters, GLsizei countersSize, GLuint *counters); +typedef void (GLAPIENTRY * PFNGLGETPERFMONITORGROUPSTRINGAMDPROC) (GLuint group, GLsizei bufSize, GLsizei* length, char *groupString); +typedef void (GLAPIENTRY * PFNGLGETPERFMONITORGROUPSAMDPROC) (GLint* numGroups, GLsizei groupsSize, GLuint *groups); +typedef void (GLAPIENTRY * PFNGLSELECTPERFMONITORCOUNTERSAMDPROC) (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint* counterList); + +#define glBeginPerfMonitorAMD GLEW_GET_FUN(__glewBeginPerfMonitorAMD) +#define glDeletePerfMonitorsAMD GLEW_GET_FUN(__glewDeletePerfMonitorsAMD) +#define glEndPerfMonitorAMD GLEW_GET_FUN(__glewEndPerfMonitorAMD) +#define glGenPerfMonitorsAMD GLEW_GET_FUN(__glewGenPerfMonitorsAMD) +#define glGetPerfMonitorCounterDataAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterDataAMD) +#define glGetPerfMonitorCounterInfoAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterInfoAMD) +#define glGetPerfMonitorCounterStringAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterStringAMD) +#define glGetPerfMonitorCountersAMD GLEW_GET_FUN(__glewGetPerfMonitorCountersAMD) +#define glGetPerfMonitorGroupStringAMD GLEW_GET_FUN(__glewGetPerfMonitorGroupStringAMD) +#define glGetPerfMonitorGroupsAMD GLEW_GET_FUN(__glewGetPerfMonitorGroupsAMD) +#define glSelectPerfMonitorCountersAMD GLEW_GET_FUN(__glewSelectPerfMonitorCountersAMD) + +#define GLEW_AMD_performance_monitor GLEW_GET_VAR(__GLEW_AMD_performance_monitor) + +#endif /* GL_AMD_performance_monitor */ + +/* ------------------ GL_AMD_seamless_cubemap_per_texture ------------------ */ + +#ifndef GL_AMD_seamless_cubemap_per_texture +#define GL_AMD_seamless_cubemap_per_texture 1 + +#define GL_TEXTURE_CUBE_MAP_SEAMLESS_ARB 0x884F + +#define GLEW_AMD_seamless_cubemap_per_texture GLEW_GET_VAR(__GLEW_AMD_seamless_cubemap_per_texture) + +#endif /* GL_AMD_seamless_cubemap_per_texture */ + +/* ---------------------- GL_AMD_shader_stencil_export --------------------- */ + +#ifndef GL_AMD_shader_stencil_export +#define GL_AMD_shader_stencil_export 1 + +#define GLEW_AMD_shader_stencil_export GLEW_GET_VAR(__GLEW_AMD_shader_stencil_export) + +#endif /* GL_AMD_shader_stencil_export */ + +/* ------------------------ GL_AMD_texture_texture4 ------------------------ */ + +#ifndef GL_AMD_texture_texture4 +#define GL_AMD_texture_texture4 1 + +#define GLEW_AMD_texture_texture4 GLEW_GET_VAR(__GLEW_AMD_texture_texture4) + +#endif /* GL_AMD_texture_texture4 */ + +/* -------------------- GL_AMD_vertex_shader_tessellator ------------------- */ + +#ifndef GL_AMD_vertex_shader_tessellator +#define GL_AMD_vertex_shader_tessellator 1 + +#define GL_SAMPLER_BUFFER_AMD 0x9001 +#define GL_INT_SAMPLER_BUFFER_AMD 0x9002 +#define GL_UNSIGNED_INT_SAMPLER_BUFFER_AMD 0x9003 +#define GL_TESSELLATION_MODE_AMD 0x9004 +#define GL_TESSELLATION_FACTOR_AMD 0x9005 +#define GL_DISCRETE_AMD 0x9006 +#define GL_CONTINUOUS_AMD 0x9007 + +typedef void (GLAPIENTRY * PFNGLTESSELLATIONFACTORAMDPROC) (GLfloat factor); +typedef void (GLAPIENTRY * PFNGLTESSELLATIONMODEAMDPROC) (GLenum mode); + +#define glTessellationFactorAMD GLEW_GET_FUN(__glewTessellationFactorAMD) +#define glTessellationModeAMD GLEW_GET_FUN(__glewTessellationModeAMD) + +#define GLEW_AMD_vertex_shader_tessellator GLEW_GET_VAR(__GLEW_AMD_vertex_shader_tessellator) + +#endif /* GL_AMD_vertex_shader_tessellator */ + +/* ----------------------- GL_APPLE_aux_depth_stencil ---------------------- */ + +#ifndef GL_APPLE_aux_depth_stencil +#define GL_APPLE_aux_depth_stencil 1 + +#define GL_AUX_DEPTH_STENCIL_APPLE 0x8A14 + +#define GLEW_APPLE_aux_depth_stencil GLEW_GET_VAR(__GLEW_APPLE_aux_depth_stencil) + +#endif /* GL_APPLE_aux_depth_stencil */ + +/* ------------------------ GL_APPLE_client_storage ------------------------ */ + +#ifndef GL_APPLE_client_storage +#define GL_APPLE_client_storage 1 + +#define GL_UNPACK_CLIENT_STORAGE_APPLE 0x85B2 + +#define GLEW_APPLE_client_storage GLEW_GET_VAR(__GLEW_APPLE_client_storage) + +#endif /* GL_APPLE_client_storage */ + +/* ------------------------- GL_APPLE_element_array ------------------------ */ + +#ifndef GL_APPLE_element_array +#define GL_APPLE_element_array 1 + +#define GL_ELEMENT_ARRAY_APPLE 0x8A0C +#define GL_ELEMENT_ARRAY_TYPE_APPLE 0x8A0D +#define GL_ELEMENT_ARRAY_POINTER_APPLE 0x8A0E + +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, GLint first, GLsizei count); +typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, GLint first, GLsizei count); +typedef void (GLAPIENTRY * PFNGLELEMENTPOINTERAPPLEPROC) (GLenum type, const void* pointer); +typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, const GLint* first, const GLsizei *count, GLsizei primcount); +typedef void (GLAPIENTRY * PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, const GLint* first, const GLsizei *count, GLsizei primcount); + +#define glDrawElementArrayAPPLE GLEW_GET_FUN(__glewDrawElementArrayAPPLE) +#define glDrawRangeElementArrayAPPLE GLEW_GET_FUN(__glewDrawRangeElementArrayAPPLE) +#define glElementPointerAPPLE GLEW_GET_FUN(__glewElementPointerAPPLE) +#define glMultiDrawElementArrayAPPLE GLEW_GET_FUN(__glewMultiDrawElementArrayAPPLE) +#define glMultiDrawRangeElementArrayAPPLE GLEW_GET_FUN(__glewMultiDrawRangeElementArrayAPPLE) + +#define GLEW_APPLE_element_array GLEW_GET_VAR(__GLEW_APPLE_element_array) + +#endif /* GL_APPLE_element_array */ + +/* ----------------------------- GL_APPLE_fence ---------------------------- */ + +#ifndef GL_APPLE_fence +#define GL_APPLE_fence 1 + +#define GL_DRAW_PIXELS_APPLE 0x8A0A +#define GL_FENCE_APPLE 0x8A0B + +typedef void (GLAPIENTRY * PFNGLDELETEFENCESAPPLEPROC) (GLsizei n, const GLuint* fences); +typedef void (GLAPIENTRY * PFNGLFINISHFENCEAPPLEPROC) (GLuint fence); +typedef void (GLAPIENTRY * PFNGLFINISHOBJECTAPPLEPROC) (GLenum object, GLint name); +typedef void (GLAPIENTRY * PFNGLGENFENCESAPPLEPROC) (GLsizei n, GLuint* fences); +typedef GLboolean (GLAPIENTRY * PFNGLISFENCEAPPLEPROC) (GLuint fence); +typedef void (GLAPIENTRY * PFNGLSETFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (GLAPIENTRY * PFNGLTESTFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (GLAPIENTRY * PFNGLTESTOBJECTAPPLEPROC) (GLenum object, GLuint name); + +#define glDeleteFencesAPPLE GLEW_GET_FUN(__glewDeleteFencesAPPLE) +#define glFinishFenceAPPLE GLEW_GET_FUN(__glewFinishFenceAPPLE) +#define glFinishObjectAPPLE GLEW_GET_FUN(__glewFinishObjectAPPLE) +#define glGenFencesAPPLE GLEW_GET_FUN(__glewGenFencesAPPLE) +#define glIsFenceAPPLE GLEW_GET_FUN(__glewIsFenceAPPLE) +#define glSetFenceAPPLE GLEW_GET_FUN(__glewSetFenceAPPLE) +#define glTestFenceAPPLE GLEW_GET_FUN(__glewTestFenceAPPLE) +#define glTestObjectAPPLE GLEW_GET_FUN(__glewTestObjectAPPLE) + +#define GLEW_APPLE_fence GLEW_GET_VAR(__GLEW_APPLE_fence) + +#endif /* GL_APPLE_fence */ + +/* ------------------------- GL_APPLE_float_pixels ------------------------- */ + +#ifndef GL_APPLE_float_pixels +#define GL_APPLE_float_pixels 1 + +#define GL_HALF_APPLE 0x140B +#define GL_RGBA_FLOAT32_APPLE 0x8814 +#define GL_RGB_FLOAT32_APPLE 0x8815 +#define GL_ALPHA_FLOAT32_APPLE 0x8816 +#define GL_INTENSITY_FLOAT32_APPLE 0x8817 +#define GL_LUMINANCE_FLOAT32_APPLE 0x8818 +#define GL_LUMINANCE_ALPHA_FLOAT32_APPLE 0x8819 +#define GL_RGBA_FLOAT16_APPLE 0x881A +#define GL_RGB_FLOAT16_APPLE 0x881B +#define GL_ALPHA_FLOAT16_APPLE 0x881C +#define GL_INTENSITY_FLOAT16_APPLE 0x881D +#define GL_LUMINANCE_FLOAT16_APPLE 0x881E +#define GL_LUMINANCE_ALPHA_FLOAT16_APPLE 0x881F +#define GL_COLOR_FLOAT_APPLE 0x8A0F + +#define GLEW_APPLE_float_pixels GLEW_GET_VAR(__GLEW_APPLE_float_pixels) + +#endif /* GL_APPLE_float_pixels */ + +/* ---------------------- GL_APPLE_flush_buffer_range ---------------------- */ + +#ifndef GL_APPLE_flush_buffer_range +#define GL_APPLE_flush_buffer_range 1 + +#define GL_BUFFER_SERIALIZED_MODIFY_APPLE 0x8A12 +#define GL_BUFFER_FLUSHING_UNMAP_APPLE 0x8A13 + +typedef void (GLAPIENTRY * PFNGLBUFFERPARAMETERIAPPLEPROC) (GLenum target, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC) (GLenum target, GLintptr offset, GLsizeiptr size); + +#define glBufferParameteriAPPLE GLEW_GET_FUN(__glewBufferParameteriAPPLE) +#define glFlushMappedBufferRangeAPPLE GLEW_GET_FUN(__glewFlushMappedBufferRangeAPPLE) + +#define GLEW_APPLE_flush_buffer_range GLEW_GET_VAR(__GLEW_APPLE_flush_buffer_range) + +#endif /* GL_APPLE_flush_buffer_range */ + +/* ----------------------- GL_APPLE_object_purgeable ----------------------- */ + +#ifndef GL_APPLE_object_purgeable +#define GL_APPLE_object_purgeable 1 + +#define GL_BUFFER_OBJECT_APPLE 0x85B3 +#define GL_RELEASED_APPLE 0x8A19 +#define GL_VOLATILE_APPLE 0x8A1A +#define GL_RETAINED_APPLE 0x8A1B +#define GL_UNDEFINED_APPLE 0x8A1C +#define GL_PURGEABLE_APPLE 0x8A1D + +typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERIVAPPLEPROC) (GLenum objectType, GLuint name, GLenum pname, GLint* params); +typedef GLenum (GLAPIENTRY * PFNGLOBJECTPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); +typedef GLenum (GLAPIENTRY * PFNGLOBJECTUNPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); + +#define glGetObjectParameterivAPPLE GLEW_GET_FUN(__glewGetObjectParameterivAPPLE) +#define glObjectPurgeableAPPLE GLEW_GET_FUN(__glewObjectPurgeableAPPLE) +#define glObjectUnpurgeableAPPLE GLEW_GET_FUN(__glewObjectUnpurgeableAPPLE) + +#define GLEW_APPLE_object_purgeable GLEW_GET_VAR(__GLEW_APPLE_object_purgeable) + +#endif /* GL_APPLE_object_purgeable */ + +/* ------------------------- GL_APPLE_pixel_buffer ------------------------- */ + +#ifndef GL_APPLE_pixel_buffer +#define GL_APPLE_pixel_buffer 1 + +#define GL_MIN_PBUFFER_VIEWPORT_DIMS_APPLE 0x8A10 + +#define GLEW_APPLE_pixel_buffer GLEW_GET_VAR(__GLEW_APPLE_pixel_buffer) + +#endif /* GL_APPLE_pixel_buffer */ + +/* ---------------------------- GL_APPLE_rgb_422 --------------------------- */ + +#ifndef GL_APPLE_rgb_422 +#define GL_APPLE_rgb_422 1 + +#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA +#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB +#define GL_RGB_422_APPLE 0x8A1F + +#define GLEW_APPLE_rgb_422 GLEW_GET_VAR(__GLEW_APPLE_rgb_422) + +#endif /* GL_APPLE_rgb_422 */ + +/* --------------------------- GL_APPLE_row_bytes -------------------------- */ + +#ifndef GL_APPLE_row_bytes +#define GL_APPLE_row_bytes 1 + +#define GL_PACK_ROW_BYTES_APPLE 0x8A15 +#define GL_UNPACK_ROW_BYTES_APPLE 0x8A16 + +#define GLEW_APPLE_row_bytes GLEW_GET_VAR(__GLEW_APPLE_row_bytes) + +#endif /* GL_APPLE_row_bytes */ + +/* ------------------------ GL_APPLE_specular_vector ----------------------- */ + +#ifndef GL_APPLE_specular_vector +#define GL_APPLE_specular_vector 1 + +#define GL_LIGHT_MODEL_SPECULAR_VECTOR_APPLE 0x85B0 + +#define GLEW_APPLE_specular_vector GLEW_GET_VAR(__GLEW_APPLE_specular_vector) + +#endif /* GL_APPLE_specular_vector */ + +/* ------------------------- GL_APPLE_texture_range ------------------------ */ + +#ifndef GL_APPLE_texture_range +#define GL_APPLE_texture_range 1 + +#define GL_TEXTURE_RANGE_LENGTH_APPLE 0x85B7 +#define GL_TEXTURE_RANGE_POINTER_APPLE 0x85B8 +#define GL_TEXTURE_STORAGE_HINT_APPLE 0x85BC +#define GL_STORAGE_PRIVATE_APPLE 0x85BD +#define GL_STORAGE_CACHED_APPLE 0x85BE +#define GL_STORAGE_SHARED_APPLE 0x85BF + +typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC) (GLenum target, GLenum pname, GLvoid **params); +typedef void (GLAPIENTRY * PFNGLTEXTURERANGEAPPLEPROC) (GLenum target, GLsizei length, GLvoid *pointer); + +#define glGetTexParameterPointervAPPLE GLEW_GET_FUN(__glewGetTexParameterPointervAPPLE) +#define glTextureRangeAPPLE GLEW_GET_FUN(__glewTextureRangeAPPLE) + +#define GLEW_APPLE_texture_range GLEW_GET_VAR(__GLEW_APPLE_texture_range) + +#endif /* GL_APPLE_texture_range */ + +/* ------------------------ GL_APPLE_transform_hint ------------------------ */ + +#ifndef GL_APPLE_transform_hint +#define GL_APPLE_transform_hint 1 + +#define GL_TRANSFORM_HINT_APPLE 0x85B1 + +#define GLEW_APPLE_transform_hint GLEW_GET_VAR(__GLEW_APPLE_transform_hint) + +#endif /* GL_APPLE_transform_hint */ + +/* ---------------------- GL_APPLE_vertex_array_object --------------------- */ + +#ifndef GL_APPLE_vertex_array_object +#define GL_APPLE_vertex_array_object 1 + +#define GL_VERTEX_ARRAY_BINDING_APPLE 0x85B5 + +typedef void (GLAPIENTRY * PFNGLBINDVERTEXARRAYAPPLEPROC) (GLuint array); +typedef void (GLAPIENTRY * PFNGLDELETEVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint* arrays); +typedef void (GLAPIENTRY * PFNGLGENVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint* arrays); +typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXARRAYAPPLEPROC) (GLuint array); + +#define glBindVertexArrayAPPLE GLEW_GET_FUN(__glewBindVertexArrayAPPLE) +#define glDeleteVertexArraysAPPLE GLEW_GET_FUN(__glewDeleteVertexArraysAPPLE) +#define glGenVertexArraysAPPLE GLEW_GET_FUN(__glewGenVertexArraysAPPLE) +#define glIsVertexArrayAPPLE GLEW_GET_FUN(__glewIsVertexArrayAPPLE) + +#define GLEW_APPLE_vertex_array_object GLEW_GET_VAR(__GLEW_APPLE_vertex_array_object) + +#endif /* GL_APPLE_vertex_array_object */ + +/* ---------------------- GL_APPLE_vertex_array_range ---------------------- */ + +#ifndef GL_APPLE_vertex_array_range +#define GL_APPLE_vertex_array_range 1 + +#define GL_VERTEX_ARRAY_RANGE_APPLE 0x851D +#define GL_VERTEX_ARRAY_RANGE_LENGTH_APPLE 0x851E +#define GL_VERTEX_ARRAY_STORAGE_HINT_APPLE 0x851F +#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_APPLE 0x8520 +#define GL_VERTEX_ARRAY_RANGE_POINTER_APPLE 0x8521 +#define GL_STORAGE_CLIENT_APPLE 0x85B4 +#define GL_STORAGE_CACHED_APPLE 0x85BE +#define GL_STORAGE_SHARED_APPLE 0x85BF + +typedef void (GLAPIENTRY * PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, void* pointer); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYPARAMETERIAPPLEPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, void* pointer); + +#define glFlushVertexArrayRangeAPPLE GLEW_GET_FUN(__glewFlushVertexArrayRangeAPPLE) +#define glVertexArrayParameteriAPPLE GLEW_GET_FUN(__glewVertexArrayParameteriAPPLE) +#define glVertexArrayRangeAPPLE GLEW_GET_FUN(__glewVertexArrayRangeAPPLE) + +#define GLEW_APPLE_vertex_array_range GLEW_GET_VAR(__GLEW_APPLE_vertex_array_range) + +#endif /* GL_APPLE_vertex_array_range */ + +/* ------------------- GL_APPLE_vertex_program_evaluators ------------------ */ + +#ifndef GL_APPLE_vertex_program_evaluators +#define GL_APPLE_vertex_program_evaluators 1 + +#define GL_VERTEX_ATTRIB_MAP1_APPLE 0x8A00 +#define GL_VERTEX_ATTRIB_MAP2_APPLE 0x8A01 +#define GL_VERTEX_ATTRIB_MAP1_SIZE_APPLE 0x8A02 +#define GL_VERTEX_ATTRIB_MAP1_COEFF_APPLE 0x8A03 +#define GL_VERTEX_ATTRIB_MAP1_ORDER_APPLE 0x8A04 +#define GL_VERTEX_ATTRIB_MAP1_DOMAIN_APPLE 0x8A05 +#define GL_VERTEX_ATTRIB_MAP2_SIZE_APPLE 0x8A06 +#define GL_VERTEX_ATTRIB_MAP2_COEFF_APPLE 0x8A07 +#define GL_VERTEX_ATTRIB_MAP2_ORDER_APPLE 0x8A08 +#define GL_VERTEX_ATTRIB_MAP2_DOMAIN_APPLE 0x8A09 + +typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); +typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); +typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXATTRIBENABLEDAPPLEPROC) (GLuint index, GLenum pname); +typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB1DAPPLEPROC) (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble* points); +typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB1FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat* points); +typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB2DAPPLEPROC) (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble* points); +typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB2FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat* points); + +#define glDisableVertexAttribAPPLE GLEW_GET_FUN(__glewDisableVertexAttribAPPLE) +#define glEnableVertexAttribAPPLE GLEW_GET_FUN(__glewEnableVertexAttribAPPLE) +#define glIsVertexAttribEnabledAPPLE GLEW_GET_FUN(__glewIsVertexAttribEnabledAPPLE) +#define glMapVertexAttrib1dAPPLE GLEW_GET_FUN(__glewMapVertexAttrib1dAPPLE) +#define glMapVertexAttrib1fAPPLE GLEW_GET_FUN(__glewMapVertexAttrib1fAPPLE) +#define glMapVertexAttrib2dAPPLE GLEW_GET_FUN(__glewMapVertexAttrib2dAPPLE) +#define glMapVertexAttrib2fAPPLE GLEW_GET_FUN(__glewMapVertexAttrib2fAPPLE) + +#define GLEW_APPLE_vertex_program_evaluators GLEW_GET_VAR(__GLEW_APPLE_vertex_program_evaluators) + +#endif /* GL_APPLE_vertex_program_evaluators */ + +/* --------------------------- GL_APPLE_ycbcr_422 -------------------------- */ + +#ifndef GL_APPLE_ycbcr_422 +#define GL_APPLE_ycbcr_422 1 + +#define GL_YCBCR_422_APPLE 0x85B9 +#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA +#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB + +#define GLEW_APPLE_ycbcr_422 GLEW_GET_VAR(__GLEW_APPLE_ycbcr_422) + +#endif /* GL_APPLE_ycbcr_422 */ + +/* ----------------------- GL_ARB_blend_func_extended ---------------------- */ + +#ifndef GL_ARB_blend_func_extended +#define GL_ARB_blend_func_extended 1 + +#define GL_SRC1_COLOR 0x88F9 +#define GL_ONE_MINUS_SRC1_COLOR 0x88FA +#define GL_ONE_MINUS_SRC1_ALPHA 0x88FB +#define GL_MAX_DUAL_SOURCE_DRAW_BUFFERS 0x88FC + +typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONINDEXEDPROC) (GLuint program, GLuint colorNumber, GLuint index, const char * name); +typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATAINDEXPROC) (GLuint program, const char * name); + +#define glBindFragDataLocationIndexed GLEW_GET_FUN(__glewBindFragDataLocationIndexed) +#define glGetFragDataIndex GLEW_GET_FUN(__glewGetFragDataIndex) + +#define GLEW_ARB_blend_func_extended GLEW_GET_VAR(__GLEW_ARB_blend_func_extended) + +#endif /* GL_ARB_blend_func_extended */ + +/* ----------------------- GL_ARB_color_buffer_float ----------------------- */ + +#ifndef GL_ARB_color_buffer_float +#define GL_ARB_color_buffer_float 1 + +#define GL_RGBA_FLOAT_MODE_ARB 0x8820 +#define GL_CLAMP_VERTEX_COLOR_ARB 0x891A +#define GL_CLAMP_FRAGMENT_COLOR_ARB 0x891B +#define GL_CLAMP_READ_COLOR_ARB 0x891C +#define GL_FIXED_ONLY_ARB 0x891D + +typedef void (GLAPIENTRY * PFNGLCLAMPCOLORARBPROC) (GLenum target, GLenum clamp); + +#define glClampColorARB GLEW_GET_FUN(__glewClampColorARB) + +#define GLEW_ARB_color_buffer_float GLEW_GET_VAR(__GLEW_ARB_color_buffer_float) + +#endif /* GL_ARB_color_buffer_float */ + +/* -------------------------- GL_ARB_compatibility ------------------------- */ + +#ifndef GL_ARB_compatibility +#define GL_ARB_compatibility 1 + +#define GLEW_ARB_compatibility GLEW_GET_VAR(__GLEW_ARB_compatibility) + +#endif /* GL_ARB_compatibility */ + +/* --------------------------- GL_ARB_copy_buffer -------------------------- */ + +#ifndef GL_ARB_copy_buffer +#define GL_ARB_copy_buffer 1 + +#define GL_COPY_READ_BUFFER 0x8F36 +#define GL_COPY_WRITE_BUFFER 0x8F37 + +typedef void (GLAPIENTRY * PFNGLCOPYBUFFERSUBDATAPROC) (GLenum readtarget, GLenum writetarget, GLintptr readoffset, GLintptr writeoffset, GLsizeiptr size); + +#define glCopyBufferSubData GLEW_GET_FUN(__glewCopyBufferSubData) + +#define GLEW_ARB_copy_buffer GLEW_GET_VAR(__GLEW_ARB_copy_buffer) + +#endif /* GL_ARB_copy_buffer */ + +/* ----------------------- GL_ARB_depth_buffer_float ----------------------- */ + +#ifndef GL_ARB_depth_buffer_float +#define GL_ARB_depth_buffer_float 1 + +#define GL_DEPTH_COMPONENT32F 0x8CAC +#define GL_DEPTH32F_STENCIL8 0x8CAD +#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD + +#define GLEW_ARB_depth_buffer_float GLEW_GET_VAR(__GLEW_ARB_depth_buffer_float) + +#endif /* GL_ARB_depth_buffer_float */ + +/* --------------------------- GL_ARB_depth_clamp -------------------------- */ + +#ifndef GL_ARB_depth_clamp +#define GL_ARB_depth_clamp 1 + +#define GL_DEPTH_CLAMP 0x864F + +#define GLEW_ARB_depth_clamp GLEW_GET_VAR(__GLEW_ARB_depth_clamp) + +#endif /* GL_ARB_depth_clamp */ + +/* -------------------------- GL_ARB_depth_texture ------------------------- */ + +#ifndef GL_ARB_depth_texture +#define GL_ARB_depth_texture 1 + +#define GL_DEPTH_COMPONENT16_ARB 0x81A5 +#define GL_DEPTH_COMPONENT24_ARB 0x81A6 +#define GL_DEPTH_COMPONENT32_ARB 0x81A7 +#define GL_TEXTURE_DEPTH_SIZE_ARB 0x884A +#define GL_DEPTH_TEXTURE_MODE_ARB 0x884B + +#define GLEW_ARB_depth_texture GLEW_GET_VAR(__GLEW_ARB_depth_texture) + +#endif /* GL_ARB_depth_texture */ + +/* -------------------------- GL_ARB_draw_buffers -------------------------- */ + +#ifndef GL_ARB_draw_buffers +#define GL_ARB_draw_buffers 1 + +#define GL_MAX_DRAW_BUFFERS_ARB 0x8824 +#define GL_DRAW_BUFFER0_ARB 0x8825 +#define GL_DRAW_BUFFER1_ARB 0x8826 +#define GL_DRAW_BUFFER2_ARB 0x8827 +#define GL_DRAW_BUFFER3_ARB 0x8828 +#define GL_DRAW_BUFFER4_ARB 0x8829 +#define GL_DRAW_BUFFER5_ARB 0x882A +#define GL_DRAW_BUFFER6_ARB 0x882B +#define GL_DRAW_BUFFER7_ARB 0x882C +#define GL_DRAW_BUFFER8_ARB 0x882D +#define GL_DRAW_BUFFER9_ARB 0x882E +#define GL_DRAW_BUFFER10_ARB 0x882F +#define GL_DRAW_BUFFER11_ARB 0x8830 +#define GL_DRAW_BUFFER12_ARB 0x8831 +#define GL_DRAW_BUFFER13_ARB 0x8832 +#define GL_DRAW_BUFFER14_ARB 0x8833 +#define GL_DRAW_BUFFER15_ARB 0x8834 + +typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSARBPROC) (GLsizei n, const GLenum* bufs); + +#define glDrawBuffersARB GLEW_GET_FUN(__glewDrawBuffersARB) + +#define GLEW_ARB_draw_buffers GLEW_GET_VAR(__GLEW_ARB_draw_buffers) + +#endif /* GL_ARB_draw_buffers */ + +/* ----------------------- GL_ARB_draw_buffers_blend ----------------------- */ + +#ifndef GL_ARB_draw_buffers_blend +#define GL_ARB_draw_buffers_blend 1 + +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEIARBPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONIARBPROC) (GLuint buf, GLenum mode); +typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEIARBPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +typedef void (GLAPIENTRY * PFNGLBLENDFUNCIARBPROC) (GLuint buf, GLenum src, GLenum dst); + +#define glBlendEquationSeparateiARB GLEW_GET_FUN(__glewBlendEquationSeparateiARB) +#define glBlendEquationiARB GLEW_GET_FUN(__glewBlendEquationiARB) +#define glBlendFuncSeparateiARB GLEW_GET_FUN(__glewBlendFuncSeparateiARB) +#define glBlendFunciARB GLEW_GET_FUN(__glewBlendFunciARB) + +#define GLEW_ARB_draw_buffers_blend GLEW_GET_VAR(__GLEW_ARB_draw_buffers_blend) + +#endif /* GL_ARB_draw_buffers_blend */ + +/* -------------------- GL_ARB_draw_elements_base_vertex ------------------- */ + +#ifndef GL_ARB_draw_elements_base_vertex +#define GL_ARB_draw_elements_base_vertex 1 + +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, void* indices, GLint basevertex); +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const void* indices, GLsizei primcount, GLint basevertex); +typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, void* indices, GLint basevertex); +typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, GLsizei* count, GLenum type, GLvoid**indices, GLsizei primcount, GLint *basevertex); + +#define glDrawElementsBaseVertex GLEW_GET_FUN(__glewDrawElementsBaseVertex) +#define glDrawElementsInstancedBaseVertex GLEW_GET_FUN(__glewDrawElementsInstancedBaseVertex) +#define glDrawRangeElementsBaseVertex GLEW_GET_FUN(__glewDrawRangeElementsBaseVertex) +#define glMultiDrawElementsBaseVertex GLEW_GET_FUN(__glewMultiDrawElementsBaseVertex) + +#define GLEW_ARB_draw_elements_base_vertex GLEW_GET_VAR(__GLEW_ARB_draw_elements_base_vertex) + +#endif /* GL_ARB_draw_elements_base_vertex */ + +/* -------------------------- GL_ARB_draw_indirect ------------------------- */ + +#ifndef GL_ARB_draw_indirect +#define GL_ARB_draw_indirect 1 + +#define GL_DRAW_INDIRECT_BUFFER 0x8F3F +#define GL_DRAW_INDIRECT_BUFFER_BINDING 0x8F43 + +typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINDIRECTPROC) (GLenum mode, const void* indirect); +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINDIRECTPROC) (GLenum mode, GLenum type, const void* indirect); + +#define glDrawArraysIndirect GLEW_GET_FUN(__glewDrawArraysIndirect) +#define glDrawElementsIndirect GLEW_GET_FUN(__glewDrawElementsIndirect) + +#define GLEW_ARB_draw_indirect GLEW_GET_VAR(__GLEW_ARB_draw_indirect) + +#endif /* GL_ARB_draw_indirect */ + +/* ------------------------- GL_ARB_draw_instanced ------------------------- */ + +#ifndef GL_ARB_draw_instanced +#define GL_ARB_draw_instanced 1 + +typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDARBPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount); +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDARBPROC) (GLenum mode, GLsizei count, GLenum type, const void* indices, GLsizei primcount); + +#define glDrawArraysInstancedARB GLEW_GET_FUN(__glewDrawArraysInstancedARB) +#define glDrawElementsInstancedARB GLEW_GET_FUN(__glewDrawElementsInstancedARB) + +#define GLEW_ARB_draw_instanced GLEW_GET_VAR(__GLEW_ARB_draw_instanced) + +#endif /* GL_ARB_draw_instanced */ + +/* -------------------- GL_ARB_explicit_attrib_location -------------------- */ + +#ifndef GL_ARB_explicit_attrib_location +#define GL_ARB_explicit_attrib_location 1 + +#define GLEW_ARB_explicit_attrib_location GLEW_GET_VAR(__GLEW_ARB_explicit_attrib_location) + +#endif /* GL_ARB_explicit_attrib_location */ + +/* ------------------- GL_ARB_fragment_coord_conventions ------------------- */ + +#ifndef GL_ARB_fragment_coord_conventions +#define GL_ARB_fragment_coord_conventions 1 + +#define GLEW_ARB_fragment_coord_conventions GLEW_GET_VAR(__GLEW_ARB_fragment_coord_conventions) + +#endif /* GL_ARB_fragment_coord_conventions */ + +/* ------------------------ GL_ARB_fragment_program ------------------------ */ + +#ifndef GL_ARB_fragment_program +#define GL_ARB_fragment_program 1 + +#define GL_FRAGMENT_PROGRAM_ARB 0x8804 +#define GL_PROGRAM_ALU_INSTRUCTIONS_ARB 0x8805 +#define GL_PROGRAM_TEX_INSTRUCTIONS_ARB 0x8806 +#define GL_PROGRAM_TEX_INDIRECTIONS_ARB 0x8807 +#define GL_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x8808 +#define GL_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x8809 +#define GL_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x880A +#define GL_MAX_PROGRAM_ALU_INSTRUCTIONS_ARB 0x880B +#define GL_MAX_PROGRAM_TEX_INSTRUCTIONS_ARB 0x880C +#define GL_MAX_PROGRAM_TEX_INDIRECTIONS_ARB 0x880D +#define GL_MAX_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x880E +#define GL_MAX_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x880F +#define GL_MAX_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x8810 +#define GL_MAX_TEXTURE_COORDS_ARB 0x8871 +#define GL_MAX_TEXTURE_IMAGE_UNITS_ARB 0x8872 + +#define GLEW_ARB_fragment_program GLEW_GET_VAR(__GLEW_ARB_fragment_program) + +#endif /* GL_ARB_fragment_program */ + +/* --------------------- GL_ARB_fragment_program_shadow -------------------- */ + +#ifndef GL_ARB_fragment_program_shadow +#define GL_ARB_fragment_program_shadow 1 + +#define GLEW_ARB_fragment_program_shadow GLEW_GET_VAR(__GLEW_ARB_fragment_program_shadow) + +#endif /* GL_ARB_fragment_program_shadow */ + +/* ------------------------- GL_ARB_fragment_shader ------------------------ */ + +#ifndef GL_ARB_fragment_shader +#define GL_ARB_fragment_shader 1 + +#define GL_FRAGMENT_SHADER_ARB 0x8B30 +#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS_ARB 0x8B49 +#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT_ARB 0x8B8B + +#define GLEW_ARB_fragment_shader GLEW_GET_VAR(__GLEW_ARB_fragment_shader) + +#endif /* GL_ARB_fragment_shader */ + +/* ----------------------- GL_ARB_framebuffer_object ----------------------- */ + +#ifndef GL_ARB_framebuffer_object +#define GL_ARB_framebuffer_object 1 + +#define GL_INVALID_FRAMEBUFFER_OPERATION 0x0506 +#define GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING 0x8210 +#define GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE 0x8211 +#define GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE 0x8212 +#define GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE 0x8213 +#define GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE 0x8214 +#define GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE 0x8215 +#define GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE 0x8216 +#define GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE 0x8217 +#define GL_FRAMEBUFFER_DEFAULT 0x8218 +#define GL_FRAMEBUFFER_UNDEFINED 0x8219 +#define GL_DEPTH_STENCIL_ATTACHMENT 0x821A +#define GL_INDEX 0x8222 +#define GL_MAX_RENDERBUFFER_SIZE 0x84E8 +#define GL_DEPTH_STENCIL 0x84F9 +#define GL_UNSIGNED_INT_24_8 0x84FA +#define GL_DEPTH24_STENCIL8 0x88F0 +#define GL_TEXTURE_STENCIL_SIZE 0x88F1 +#define GL_UNSIGNED_NORMALIZED 0x8C17 +#define GL_SRGB 0x8C40 +#define GL_DRAW_FRAMEBUFFER_BINDING 0x8CA6 +#define GL_FRAMEBUFFER_BINDING 0x8CA6 +#define GL_RENDERBUFFER_BINDING 0x8CA7 +#define GL_READ_FRAMEBUFFER 0x8CA8 +#define GL_DRAW_FRAMEBUFFER 0x8CA9 +#define GL_READ_FRAMEBUFFER_BINDING 0x8CAA +#define GL_RENDERBUFFER_SAMPLES 0x8CAB +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE 0x8CD0 +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME 0x8CD1 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL 0x8CD2 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE 0x8CD3 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 +#define GL_FRAMEBUFFER_COMPLETE 0x8CD5 +#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT 0x8CD6 +#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT 0x8CD7 +#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER 0x8CDB +#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER 0x8CDC +#define GL_FRAMEBUFFER_UNSUPPORTED 0x8CDD +#define GL_MAX_COLOR_ATTACHMENTS 0x8CDF +#define GL_COLOR_ATTACHMENT0 0x8CE0 +#define GL_COLOR_ATTACHMENT1 0x8CE1 +#define GL_COLOR_ATTACHMENT2 0x8CE2 +#define GL_COLOR_ATTACHMENT3 0x8CE3 +#define GL_COLOR_ATTACHMENT4 0x8CE4 +#define GL_COLOR_ATTACHMENT5 0x8CE5 +#define GL_COLOR_ATTACHMENT6 0x8CE6 +#define GL_COLOR_ATTACHMENT7 0x8CE7 +#define GL_COLOR_ATTACHMENT8 0x8CE8 +#define GL_COLOR_ATTACHMENT9 0x8CE9 +#define GL_COLOR_ATTACHMENT10 0x8CEA +#define GL_COLOR_ATTACHMENT11 0x8CEB +#define GL_COLOR_ATTACHMENT12 0x8CEC +#define GL_COLOR_ATTACHMENT13 0x8CED +#define GL_COLOR_ATTACHMENT14 0x8CEE +#define GL_COLOR_ATTACHMENT15 0x8CEF +#define GL_DEPTH_ATTACHMENT 0x8D00 +#define GL_STENCIL_ATTACHMENT 0x8D20 +#define GL_FRAMEBUFFER 0x8D40 +#define GL_RENDERBUFFER 0x8D41 +#define GL_RENDERBUFFER_WIDTH 0x8D42 +#define GL_RENDERBUFFER_HEIGHT 0x8D43 +#define GL_RENDERBUFFER_INTERNAL_FORMAT 0x8D44 +#define GL_STENCIL_INDEX1 0x8D46 +#define GL_STENCIL_INDEX4 0x8D47 +#define GL_STENCIL_INDEX8 0x8D48 +#define GL_STENCIL_INDEX16 0x8D49 +#define GL_RENDERBUFFER_RED_SIZE 0x8D50 +#define GL_RENDERBUFFER_GREEN_SIZE 0x8D51 +#define GL_RENDERBUFFER_BLUE_SIZE 0x8D52 +#define GL_RENDERBUFFER_ALPHA_SIZE 0x8D53 +#define GL_RENDERBUFFER_DEPTH_SIZE 0x8D54 +#define GL_RENDERBUFFER_STENCIL_SIZE 0x8D55 +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE 0x8D56 +#define GL_MAX_SAMPLES 0x8D57 + +typedef void (GLAPIENTRY * PFNGLBINDFRAMEBUFFERPROC) (GLenum target, GLuint framebuffer); +typedef void (GLAPIENTRY * PFNGLBINDRENDERBUFFERPROC) (GLenum target, GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLBLITFRAMEBUFFERPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +typedef GLenum (GLAPIENTRY * PFNGLCHECKFRAMEBUFFERSTATUSPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLDELETEFRAMEBUFFERSPROC) (GLsizei n, const GLuint* framebuffers); +typedef void (GLAPIENTRY * PFNGLDELETERENDERBUFFERSPROC) (GLsizei n, const GLuint* renderbuffers); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERRENDERBUFFERPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE1DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE2DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE3DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint layer); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYERPROC) (GLenum target,GLenum attachment, GLuint texture,GLint level,GLint layer); +typedef void (GLAPIENTRY * PFNGLGENFRAMEBUFFERSPROC) (GLsizei n, GLuint* framebuffers); +typedef void (GLAPIENTRY * PFNGLGENRENDERBUFFERSPROC) (GLsizei n, GLuint* renderbuffers); +typedef void (GLAPIENTRY * PFNGLGENERATEMIPMAPPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC) (GLenum target, GLenum attachment, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETRENDERBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISFRAMEBUFFERPROC) (GLuint framebuffer); +typedef GLboolean (GLAPIENTRY * PFNGLISRENDERBUFFERPROC) (GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); + +#define glBindFramebuffer GLEW_GET_FUN(__glewBindFramebuffer) +#define glBindRenderbuffer GLEW_GET_FUN(__glewBindRenderbuffer) +#define glBlitFramebuffer GLEW_GET_FUN(__glewBlitFramebuffer) +#define glCheckFramebufferStatus GLEW_GET_FUN(__glewCheckFramebufferStatus) +#define glDeleteFramebuffers GLEW_GET_FUN(__glewDeleteFramebuffers) +#define glDeleteRenderbuffers GLEW_GET_FUN(__glewDeleteRenderbuffers) +#define glFramebufferRenderbuffer GLEW_GET_FUN(__glewFramebufferRenderbuffer) +#define glFramebufferTexture1D GLEW_GET_FUN(__glewFramebufferTexture1D) +#define glFramebufferTexture2D GLEW_GET_FUN(__glewFramebufferTexture2D) +#define glFramebufferTexture3D GLEW_GET_FUN(__glewFramebufferTexture3D) +#define glFramebufferTextureLayer GLEW_GET_FUN(__glewFramebufferTextureLayer) +#define glGenFramebuffers GLEW_GET_FUN(__glewGenFramebuffers) +#define glGenRenderbuffers GLEW_GET_FUN(__glewGenRenderbuffers) +#define glGenerateMipmap GLEW_GET_FUN(__glewGenerateMipmap) +#define glGetFramebufferAttachmentParameteriv GLEW_GET_FUN(__glewGetFramebufferAttachmentParameteriv) +#define glGetRenderbufferParameteriv GLEW_GET_FUN(__glewGetRenderbufferParameteriv) +#define glIsFramebuffer GLEW_GET_FUN(__glewIsFramebuffer) +#define glIsRenderbuffer GLEW_GET_FUN(__glewIsRenderbuffer) +#define glRenderbufferStorage GLEW_GET_FUN(__glewRenderbufferStorage) +#define glRenderbufferStorageMultisample GLEW_GET_FUN(__glewRenderbufferStorageMultisample) + +#define GLEW_ARB_framebuffer_object GLEW_GET_VAR(__GLEW_ARB_framebuffer_object) + +#endif /* GL_ARB_framebuffer_object */ + +/* ------------------------ GL_ARB_framebuffer_sRGB ------------------------ */ + +#ifndef GL_ARB_framebuffer_sRGB +#define GL_ARB_framebuffer_sRGB 1 + +#define GL_FRAMEBUFFER_SRGB 0x8DB9 + +#define GLEW_ARB_framebuffer_sRGB GLEW_GET_VAR(__GLEW_ARB_framebuffer_sRGB) + +#endif /* GL_ARB_framebuffer_sRGB */ + +/* ------------------------ GL_ARB_geometry_shader4 ------------------------ */ + +#ifndef GL_ARB_geometry_shader4 +#define GL_ARB_geometry_shader4 1 + +#define GL_LINES_ADJACENCY_ARB 0xA +#define GL_LINE_STRIP_ADJACENCY_ARB 0xB +#define GL_TRIANGLES_ADJACENCY_ARB 0xC +#define GL_TRIANGLE_STRIP_ADJACENCY_ARB 0xD +#define GL_PROGRAM_POINT_SIZE_ARB 0x8642 +#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_ARB 0x8C29 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 +#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED_ARB 0x8DA7 +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_ARB 0x8DA8 +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_ARB 0x8DA9 +#define GL_GEOMETRY_SHADER_ARB 0x8DD9 +#define GL_GEOMETRY_VERTICES_OUT_ARB 0x8DDA +#define GL_GEOMETRY_INPUT_TYPE_ARB 0x8DDB +#define GL_GEOMETRY_OUTPUT_TYPE_ARB 0x8DDC +#define GL_MAX_GEOMETRY_VARYING_COMPONENTS_ARB 0x8DDD +#define GL_MAX_VERTEX_VARYING_COMPONENTS_ARB 0x8DDE +#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_ARB 0x8DDF +#define GL_MAX_GEOMETRY_OUTPUT_VERTICES_ARB 0x8DE0 +#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_ARB 0x8DE1 + +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREFACEARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYERARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIARBPROC) (GLuint program, GLenum pname, GLint value); + +#define glFramebufferTextureARB GLEW_GET_FUN(__glewFramebufferTextureARB) +#define glFramebufferTextureFaceARB GLEW_GET_FUN(__glewFramebufferTextureFaceARB) +#define glFramebufferTextureLayerARB GLEW_GET_FUN(__glewFramebufferTextureLayerARB) +#define glProgramParameteriARB GLEW_GET_FUN(__glewProgramParameteriARB) + +#define GLEW_ARB_geometry_shader4 GLEW_GET_VAR(__GLEW_ARB_geometry_shader4) + +#endif /* GL_ARB_geometry_shader4 */ + +/* --------------------------- GL_ARB_gpu_shader5 -------------------------- */ + +#ifndef GL_ARB_gpu_shader5 +#define GL_ARB_gpu_shader5 1 + +#define GL_GEOMETRY_SHADER_INVOCATIONS 0x887F +#define GL_MAX_GEOMETRY_SHADER_INVOCATIONS 0x8E5A +#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET 0x8E5B +#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET 0x8E5C +#define GL_FRAGMENT_INTERPOLATION_OFFSET_BITS 0x8E5D +#define GL_MAX_VERTEX_STREAMS 0x8E71 + +#define GLEW_ARB_gpu_shader5 GLEW_GET_VAR(__GLEW_ARB_gpu_shader5) + +#endif /* GL_ARB_gpu_shader5 */ + +/* ------------------------- GL_ARB_gpu_shader_fp64 ------------------------ */ + +#ifndef GL_ARB_gpu_shader_fp64 +#define GL_ARB_gpu_shader_fp64 1 + +#define GLEW_ARB_gpu_shader_fp64 GLEW_GET_VAR(__GLEW_ARB_gpu_shader_fp64) + +#endif /* GL_ARB_gpu_shader_fp64 */ + +/* ------------------------ GL_ARB_half_float_pixel ------------------------ */ + +#ifndef GL_ARB_half_float_pixel +#define GL_ARB_half_float_pixel 1 + +#define GL_HALF_FLOAT_ARB 0x140B + +#define GLEW_ARB_half_float_pixel GLEW_GET_VAR(__GLEW_ARB_half_float_pixel) + +#endif /* GL_ARB_half_float_pixel */ + +/* ------------------------ GL_ARB_half_float_vertex ----------------------- */ + +#ifndef GL_ARB_half_float_vertex +#define GL_ARB_half_float_vertex 1 + +#define GL_HALF_FLOAT 0x140B + +#define GLEW_ARB_half_float_vertex GLEW_GET_VAR(__GLEW_ARB_half_float_vertex) + +#endif /* GL_ARB_half_float_vertex */ + +/* ----------------------------- GL_ARB_imaging ---------------------------- */ + +#ifndef GL_ARB_imaging +#define GL_ARB_imaging 1 + +#define GL_CONSTANT_COLOR 0x8001 +#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002 +#define GL_CONSTANT_ALPHA 0x8003 +#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 +#define GL_BLEND_COLOR 0x8005 +#define GL_FUNC_ADD 0x8006 +#define GL_MIN 0x8007 +#define GL_MAX 0x8008 +#define GL_BLEND_EQUATION 0x8009 +#define GL_FUNC_SUBTRACT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT 0x800B +#define GL_CONVOLUTION_1D 0x8010 +#define GL_CONVOLUTION_2D 0x8011 +#define GL_SEPARABLE_2D 0x8012 +#define GL_CONVOLUTION_BORDER_MODE 0x8013 +#define GL_CONVOLUTION_FILTER_SCALE 0x8014 +#define GL_CONVOLUTION_FILTER_BIAS 0x8015 +#define GL_REDUCE 0x8016 +#define GL_CONVOLUTION_FORMAT 0x8017 +#define GL_CONVOLUTION_WIDTH 0x8018 +#define GL_CONVOLUTION_HEIGHT 0x8019 +#define GL_MAX_CONVOLUTION_WIDTH 0x801A +#define GL_MAX_CONVOLUTION_HEIGHT 0x801B +#define GL_POST_CONVOLUTION_RED_SCALE 0x801C +#define GL_POST_CONVOLUTION_GREEN_SCALE 0x801D +#define GL_POST_CONVOLUTION_BLUE_SCALE 0x801E +#define GL_POST_CONVOLUTION_ALPHA_SCALE 0x801F +#define GL_POST_CONVOLUTION_RED_BIAS 0x8020 +#define GL_POST_CONVOLUTION_GREEN_BIAS 0x8021 +#define GL_POST_CONVOLUTION_BLUE_BIAS 0x8022 +#define GL_POST_CONVOLUTION_ALPHA_BIAS 0x8023 +#define GL_HISTOGRAM 0x8024 +#define GL_PROXY_HISTOGRAM 0x8025 +#define GL_HISTOGRAM_WIDTH 0x8026 +#define GL_HISTOGRAM_FORMAT 0x8027 +#define GL_HISTOGRAM_RED_SIZE 0x8028 +#define GL_HISTOGRAM_GREEN_SIZE 0x8029 +#define GL_HISTOGRAM_BLUE_SIZE 0x802A +#define GL_HISTOGRAM_ALPHA_SIZE 0x802B +#define GL_HISTOGRAM_LUMINANCE_SIZE 0x802C +#define GL_HISTOGRAM_SINK 0x802D +#define GL_MINMAX 0x802E +#define GL_MINMAX_FORMAT 0x802F +#define GL_MINMAX_SINK 0x8030 +#define GL_TABLE_TOO_LARGE 0x8031 +#define GL_COLOR_MATRIX 0x80B1 +#define GL_COLOR_MATRIX_STACK_DEPTH 0x80B2 +#define GL_MAX_COLOR_MATRIX_STACK_DEPTH 0x80B3 +#define GL_POST_COLOR_MATRIX_RED_SCALE 0x80B4 +#define GL_POST_COLOR_MATRIX_GREEN_SCALE 0x80B5 +#define GL_POST_COLOR_MATRIX_BLUE_SCALE 0x80B6 +#define GL_POST_COLOR_MATRIX_ALPHA_SCALE 0x80B7 +#define GL_POST_COLOR_MATRIX_RED_BIAS 0x80B8 +#define GL_POST_COLOR_MATRIX_GREEN_BIAS 0x80B9 +#define GL_POST_COLOR_MATRIX_BLUE_BIAS 0x80BA +#define GL_POST_COLOR_MATRIX_ALPHA_BIAS 0x80BB +#define GL_COLOR_TABLE 0x80D0 +#define GL_POST_CONVOLUTION_COLOR_TABLE 0x80D1 +#define GL_POST_COLOR_MATRIX_COLOR_TABLE 0x80D2 +#define GL_PROXY_COLOR_TABLE 0x80D3 +#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE 0x80D4 +#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE 0x80D5 +#define GL_COLOR_TABLE_SCALE 0x80D6 +#define GL_COLOR_TABLE_BIAS 0x80D7 +#define GL_COLOR_TABLE_FORMAT 0x80D8 +#define GL_COLOR_TABLE_WIDTH 0x80D9 +#define GL_COLOR_TABLE_RED_SIZE 0x80DA +#define GL_COLOR_TABLE_GREEN_SIZE 0x80DB +#define GL_COLOR_TABLE_BLUE_SIZE 0x80DC +#define GL_COLOR_TABLE_ALPHA_SIZE 0x80DD +#define GL_COLOR_TABLE_LUMINANCE_SIZE 0x80DE +#define GL_COLOR_TABLE_INTENSITY_SIZE 0x80DF +#define GL_IGNORE_BORDER 0x8150 +#define GL_CONSTANT_BORDER 0x8151 +#define GL_WRAP_BORDER 0x8152 +#define GL_REPLICATE_BORDER 0x8153 +#define GL_CONVOLUTION_BORDER_COLOR 0x8154 + +typedef void (GLAPIENTRY * PFNGLCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); +typedef void (GLAPIENTRY * PFNGLCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); +typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFPROC) (GLenum target, GLenum pname, GLfloat params); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIPROC) (GLenum target, GLenum pname, GLint params); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (GLAPIENTRY * PFNGLCOPYCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLCOPYCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); +typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); +typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (GLAPIENTRY * PFNGLGETMINMAXPROC) (GLenum target, GLboolean reset, GLenum format, GLenum types, GLvoid *values); +typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (GLAPIENTRY * PFNGLGETSEPARABLEFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); +typedef void (GLAPIENTRY * PFNGLHISTOGRAMPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +typedef void (GLAPIENTRY * PFNGLMINMAXPROC) (GLenum target, GLenum internalformat, GLboolean sink); +typedef void (GLAPIENTRY * PFNGLRESETHISTOGRAMPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLRESETMINMAXPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLSEPARABLEFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); + +#define glColorSubTable GLEW_GET_FUN(__glewColorSubTable) +#define glColorTable GLEW_GET_FUN(__glewColorTable) +#define glColorTableParameterfv GLEW_GET_FUN(__glewColorTableParameterfv) +#define glColorTableParameteriv GLEW_GET_FUN(__glewColorTableParameteriv) +#define glConvolutionFilter1D GLEW_GET_FUN(__glewConvolutionFilter1D) +#define glConvolutionFilter2D GLEW_GET_FUN(__glewConvolutionFilter2D) +#define glConvolutionParameterf GLEW_GET_FUN(__glewConvolutionParameterf) +#define glConvolutionParameterfv GLEW_GET_FUN(__glewConvolutionParameterfv) +#define glConvolutionParameteri GLEW_GET_FUN(__glewConvolutionParameteri) +#define glConvolutionParameteriv GLEW_GET_FUN(__glewConvolutionParameteriv) +#define glCopyColorSubTable GLEW_GET_FUN(__glewCopyColorSubTable) +#define glCopyColorTable GLEW_GET_FUN(__glewCopyColorTable) +#define glCopyConvolutionFilter1D GLEW_GET_FUN(__glewCopyConvolutionFilter1D) +#define glCopyConvolutionFilter2D GLEW_GET_FUN(__glewCopyConvolutionFilter2D) +#define glGetColorTable GLEW_GET_FUN(__glewGetColorTable) +#define glGetColorTableParameterfv GLEW_GET_FUN(__glewGetColorTableParameterfv) +#define glGetColorTableParameteriv GLEW_GET_FUN(__glewGetColorTableParameteriv) +#define glGetConvolutionFilter GLEW_GET_FUN(__glewGetConvolutionFilter) +#define glGetConvolutionParameterfv GLEW_GET_FUN(__glewGetConvolutionParameterfv) +#define glGetConvolutionParameteriv GLEW_GET_FUN(__glewGetConvolutionParameteriv) +#define glGetHistogram GLEW_GET_FUN(__glewGetHistogram) +#define glGetHistogramParameterfv GLEW_GET_FUN(__glewGetHistogramParameterfv) +#define glGetHistogramParameteriv GLEW_GET_FUN(__glewGetHistogramParameteriv) +#define glGetMinmax GLEW_GET_FUN(__glewGetMinmax) +#define glGetMinmaxParameterfv GLEW_GET_FUN(__glewGetMinmaxParameterfv) +#define glGetMinmaxParameteriv GLEW_GET_FUN(__glewGetMinmaxParameteriv) +#define glGetSeparableFilter GLEW_GET_FUN(__glewGetSeparableFilter) +#define glHistogram GLEW_GET_FUN(__glewHistogram) +#define glMinmax GLEW_GET_FUN(__glewMinmax) +#define glResetHistogram GLEW_GET_FUN(__glewResetHistogram) +#define glResetMinmax GLEW_GET_FUN(__glewResetMinmax) +#define glSeparableFilter2D GLEW_GET_FUN(__glewSeparableFilter2D) + +#define GLEW_ARB_imaging GLEW_GET_VAR(__GLEW_ARB_imaging) + +#endif /* GL_ARB_imaging */ + +/* ------------------------ GL_ARB_instanced_arrays ------------------------ */ + +#ifndef GL_ARB_instanced_arrays +#define GL_ARB_instanced_arrays 1 + +#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR_ARB 0x88FE + +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBDIVISORARBPROC) (GLuint index, GLuint divisor); + +#define glVertexAttribDivisorARB GLEW_GET_FUN(__glewVertexAttribDivisorARB) + +#define GLEW_ARB_instanced_arrays GLEW_GET_VAR(__GLEW_ARB_instanced_arrays) + +#endif /* GL_ARB_instanced_arrays */ + +/* ------------------------ GL_ARB_map_buffer_range ------------------------ */ + +#ifndef GL_ARB_map_buffer_range +#define GL_ARB_map_buffer_range 1 + +#define GL_MAP_READ_BIT 0x0001 +#define GL_MAP_WRITE_BIT 0x0002 +#define GL_MAP_INVALIDATE_RANGE_BIT 0x0004 +#define GL_MAP_INVALIDATE_BUFFER_BIT 0x0008 +#define GL_MAP_FLUSH_EXPLICIT_BIT 0x0010 +#define GL_MAP_UNSYNCHRONIZED_BIT 0x0020 + +typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length); +typedef GLvoid * (GLAPIENTRY * PFNGLMAPBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); + +#define glFlushMappedBufferRange GLEW_GET_FUN(__glewFlushMappedBufferRange) +#define glMapBufferRange GLEW_GET_FUN(__glewMapBufferRange) + +#define GLEW_ARB_map_buffer_range GLEW_GET_VAR(__GLEW_ARB_map_buffer_range) + +#endif /* GL_ARB_map_buffer_range */ + +/* ------------------------- GL_ARB_matrix_palette ------------------------- */ + +#ifndef GL_ARB_matrix_palette +#define GL_ARB_matrix_palette 1 + +#define GL_MATRIX_PALETTE_ARB 0x8840 +#define GL_MAX_MATRIX_PALETTE_STACK_DEPTH_ARB 0x8841 +#define GL_MAX_PALETTE_MATRICES_ARB 0x8842 +#define GL_CURRENT_PALETTE_MATRIX_ARB 0x8843 +#define GL_MATRIX_INDEX_ARRAY_ARB 0x8844 +#define GL_CURRENT_MATRIX_INDEX_ARB 0x8845 +#define GL_MATRIX_INDEX_ARRAY_SIZE_ARB 0x8846 +#define GL_MATRIX_INDEX_ARRAY_TYPE_ARB 0x8847 +#define GL_MATRIX_INDEX_ARRAY_STRIDE_ARB 0x8848 +#define GL_MATRIX_INDEX_ARRAY_POINTER_ARB 0x8849 + +typedef void (GLAPIENTRY * PFNGLCURRENTPALETTEMATRIXARBPROC) (GLint index); +typedef void (GLAPIENTRY * PFNGLMATRIXINDEXPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); +typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUBVARBPROC) (GLint size, GLubyte *indices); +typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUIVARBPROC) (GLint size, GLuint *indices); +typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUSVARBPROC) (GLint size, GLushort *indices); + +#define glCurrentPaletteMatrixARB GLEW_GET_FUN(__glewCurrentPaletteMatrixARB) +#define glMatrixIndexPointerARB GLEW_GET_FUN(__glewMatrixIndexPointerARB) +#define glMatrixIndexubvARB GLEW_GET_FUN(__glewMatrixIndexubvARB) +#define glMatrixIndexuivARB GLEW_GET_FUN(__glewMatrixIndexuivARB) +#define glMatrixIndexusvARB GLEW_GET_FUN(__glewMatrixIndexusvARB) + +#define GLEW_ARB_matrix_palette GLEW_GET_VAR(__GLEW_ARB_matrix_palette) + +#endif /* GL_ARB_matrix_palette */ + +/* --------------------------- GL_ARB_multisample -------------------------- */ + +#ifndef GL_ARB_multisample +#define GL_ARB_multisample 1 + +#define GL_MULTISAMPLE_ARB 0x809D +#define GL_SAMPLE_ALPHA_TO_COVERAGE_ARB 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE_ARB 0x809F +#define GL_SAMPLE_COVERAGE_ARB 0x80A0 +#define GL_SAMPLE_BUFFERS_ARB 0x80A8 +#define GL_SAMPLES_ARB 0x80A9 +#define GL_SAMPLE_COVERAGE_VALUE_ARB 0x80AA +#define GL_SAMPLE_COVERAGE_INVERT_ARB 0x80AB +#define GL_MULTISAMPLE_BIT_ARB 0x20000000 + +typedef void (GLAPIENTRY * PFNGLSAMPLECOVERAGEARBPROC) (GLclampf value, GLboolean invert); + +#define glSampleCoverageARB GLEW_GET_FUN(__glewSampleCoverageARB) + +#define GLEW_ARB_multisample GLEW_GET_VAR(__GLEW_ARB_multisample) + +#endif /* GL_ARB_multisample */ + +/* -------------------------- GL_ARB_multitexture -------------------------- */ + +#ifndef GL_ARB_multitexture +#define GL_ARB_multitexture 1 + +#define GL_TEXTURE0_ARB 0x84C0 +#define GL_TEXTURE1_ARB 0x84C1 +#define GL_TEXTURE2_ARB 0x84C2 +#define GL_TEXTURE3_ARB 0x84C3 +#define GL_TEXTURE4_ARB 0x84C4 +#define GL_TEXTURE5_ARB 0x84C5 +#define GL_TEXTURE6_ARB 0x84C6 +#define GL_TEXTURE7_ARB 0x84C7 +#define GL_TEXTURE8_ARB 0x84C8 +#define GL_TEXTURE9_ARB 0x84C9 +#define GL_TEXTURE10_ARB 0x84CA +#define GL_TEXTURE11_ARB 0x84CB +#define GL_TEXTURE12_ARB 0x84CC +#define GL_TEXTURE13_ARB 0x84CD +#define GL_TEXTURE14_ARB 0x84CE +#define GL_TEXTURE15_ARB 0x84CF +#define GL_TEXTURE16_ARB 0x84D0 +#define GL_TEXTURE17_ARB 0x84D1 +#define GL_TEXTURE18_ARB 0x84D2 +#define GL_TEXTURE19_ARB 0x84D3 +#define GL_TEXTURE20_ARB 0x84D4 +#define GL_TEXTURE21_ARB 0x84D5 +#define GL_TEXTURE22_ARB 0x84D6 +#define GL_TEXTURE23_ARB 0x84D7 +#define GL_TEXTURE24_ARB 0x84D8 +#define GL_TEXTURE25_ARB 0x84D9 +#define GL_TEXTURE26_ARB 0x84DA +#define GL_TEXTURE27_ARB 0x84DB +#define GL_TEXTURE28_ARB 0x84DC +#define GL_TEXTURE29_ARB 0x84DD +#define GL_TEXTURE30_ARB 0x84DE +#define GL_TEXTURE31_ARB 0x84DF +#define GL_ACTIVE_TEXTURE_ARB 0x84E0 +#define GL_CLIENT_ACTIVE_TEXTURE_ARB 0x84E1 +#define GL_MAX_TEXTURE_UNITS_ARB 0x84E2 + +typedef void (GLAPIENTRY * PFNGLACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (GLAPIENTRY * PFNGLCLIENTACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DARBPROC) (GLenum target, GLdouble s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FARBPROC) (GLenum target, GLfloat s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IARBPROC) (GLenum target, GLint s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IVARBPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SARBPROC) (GLenum target, GLshort s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SVARBPROC) (GLenum target, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DARBPROC) (GLenum target, GLdouble s, GLdouble t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FARBPROC) (GLenum target, GLfloat s, GLfloat t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IARBPROC) (GLenum target, GLint s, GLint t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IVARBPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SARBPROC) (GLenum target, GLshort s, GLshort t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SVARBPROC) (GLenum target, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IARBPROC) (GLenum target, GLint s, GLint t, GLint r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IVARBPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SVARBPROC) (GLenum target, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IARBPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IVARBPROC) (GLenum target, const GLint *v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SVARBPROC) (GLenum target, const GLshort *v); + +#define glActiveTextureARB GLEW_GET_FUN(__glewActiveTextureARB) +#define glClientActiveTextureARB GLEW_GET_FUN(__glewClientActiveTextureARB) +#define glMultiTexCoord1dARB GLEW_GET_FUN(__glewMultiTexCoord1dARB) +#define glMultiTexCoord1dvARB GLEW_GET_FUN(__glewMultiTexCoord1dvARB) +#define glMultiTexCoord1fARB GLEW_GET_FUN(__glewMultiTexCoord1fARB) +#define glMultiTexCoord1fvARB GLEW_GET_FUN(__glewMultiTexCoord1fvARB) +#define glMultiTexCoord1iARB GLEW_GET_FUN(__glewMultiTexCoord1iARB) +#define glMultiTexCoord1ivARB GLEW_GET_FUN(__glewMultiTexCoord1ivARB) +#define glMultiTexCoord1sARB GLEW_GET_FUN(__glewMultiTexCoord1sARB) +#define glMultiTexCoord1svARB GLEW_GET_FUN(__glewMultiTexCoord1svARB) +#define glMultiTexCoord2dARB GLEW_GET_FUN(__glewMultiTexCoord2dARB) +#define glMultiTexCoord2dvARB GLEW_GET_FUN(__glewMultiTexCoord2dvARB) +#define glMultiTexCoord2fARB GLEW_GET_FUN(__glewMultiTexCoord2fARB) +#define glMultiTexCoord2fvARB GLEW_GET_FUN(__glewMultiTexCoord2fvARB) +#define glMultiTexCoord2iARB GLEW_GET_FUN(__glewMultiTexCoord2iARB) +#define glMultiTexCoord2ivARB GLEW_GET_FUN(__glewMultiTexCoord2ivARB) +#define glMultiTexCoord2sARB GLEW_GET_FUN(__glewMultiTexCoord2sARB) +#define glMultiTexCoord2svARB GLEW_GET_FUN(__glewMultiTexCoord2svARB) +#define glMultiTexCoord3dARB GLEW_GET_FUN(__glewMultiTexCoord3dARB) +#define glMultiTexCoord3dvARB GLEW_GET_FUN(__glewMultiTexCoord3dvARB) +#define glMultiTexCoord3fARB GLEW_GET_FUN(__glewMultiTexCoord3fARB) +#define glMultiTexCoord3fvARB GLEW_GET_FUN(__glewMultiTexCoord3fvARB) +#define glMultiTexCoord3iARB GLEW_GET_FUN(__glewMultiTexCoord3iARB) +#define glMultiTexCoord3ivARB GLEW_GET_FUN(__glewMultiTexCoord3ivARB) +#define glMultiTexCoord3sARB GLEW_GET_FUN(__glewMultiTexCoord3sARB) +#define glMultiTexCoord3svARB GLEW_GET_FUN(__glewMultiTexCoord3svARB) +#define glMultiTexCoord4dARB GLEW_GET_FUN(__glewMultiTexCoord4dARB) +#define glMultiTexCoord4dvARB GLEW_GET_FUN(__glewMultiTexCoord4dvARB) +#define glMultiTexCoord4fARB GLEW_GET_FUN(__glewMultiTexCoord4fARB) +#define glMultiTexCoord4fvARB GLEW_GET_FUN(__glewMultiTexCoord4fvARB) +#define glMultiTexCoord4iARB GLEW_GET_FUN(__glewMultiTexCoord4iARB) +#define glMultiTexCoord4ivARB GLEW_GET_FUN(__glewMultiTexCoord4ivARB) +#define glMultiTexCoord4sARB GLEW_GET_FUN(__glewMultiTexCoord4sARB) +#define glMultiTexCoord4svARB GLEW_GET_FUN(__glewMultiTexCoord4svARB) + +#define GLEW_ARB_multitexture GLEW_GET_VAR(__GLEW_ARB_multitexture) + +#endif /* GL_ARB_multitexture */ + +/* ------------------------- GL_ARB_occlusion_query ------------------------ */ + +#ifndef GL_ARB_occlusion_query +#define GL_ARB_occlusion_query 1 + +#define GL_QUERY_COUNTER_BITS_ARB 0x8864 +#define GL_CURRENT_QUERY_ARB 0x8865 +#define GL_QUERY_RESULT_ARB 0x8866 +#define GL_QUERY_RESULT_AVAILABLE_ARB 0x8867 +#define GL_SAMPLES_PASSED_ARB 0x8914 + +typedef void (GLAPIENTRY * PFNGLBEGINQUERYARBPROC) (GLenum target, GLuint id); +typedef void (GLAPIENTRY * PFNGLDELETEQUERIESARBPROC) (GLsizei n, const GLuint* ids); +typedef void (GLAPIENTRY * PFNGLENDQUERYARBPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLGENQUERIESARBPROC) (GLsizei n, GLuint* ids); +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTIVARBPROC) (GLuint id, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUIVARBPROC) (GLuint id, GLenum pname, GLuint* params); +typedef void (GLAPIENTRY * PFNGLGETQUERYIVARBPROC) (GLenum target, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISQUERYARBPROC) (GLuint id); + +#define glBeginQueryARB GLEW_GET_FUN(__glewBeginQueryARB) +#define glDeleteQueriesARB GLEW_GET_FUN(__glewDeleteQueriesARB) +#define glEndQueryARB GLEW_GET_FUN(__glewEndQueryARB) +#define glGenQueriesARB GLEW_GET_FUN(__glewGenQueriesARB) +#define glGetQueryObjectivARB GLEW_GET_FUN(__glewGetQueryObjectivARB) +#define glGetQueryObjectuivARB GLEW_GET_FUN(__glewGetQueryObjectuivARB) +#define glGetQueryivARB GLEW_GET_FUN(__glewGetQueryivARB) +#define glIsQueryARB GLEW_GET_FUN(__glewIsQueryARB) + +#define GLEW_ARB_occlusion_query GLEW_GET_VAR(__GLEW_ARB_occlusion_query) + +#endif /* GL_ARB_occlusion_query */ + +/* ------------------------ GL_ARB_occlusion_query2 ------------------------ */ + +#ifndef GL_ARB_occlusion_query2 +#define GL_ARB_occlusion_query2 1 + +#define GL_ANY_SAMPLES_PASSED 0x8C2F + +#define GLEW_ARB_occlusion_query2 GLEW_GET_VAR(__GLEW_ARB_occlusion_query2) + +#endif /* GL_ARB_occlusion_query2 */ + +/* ----------------------- GL_ARB_pixel_buffer_object ---------------------- */ + +#ifndef GL_ARB_pixel_buffer_object +#define GL_ARB_pixel_buffer_object 1 + +#define GL_PIXEL_PACK_BUFFER_ARB 0x88EB +#define GL_PIXEL_UNPACK_BUFFER_ARB 0x88EC +#define GL_PIXEL_PACK_BUFFER_BINDING_ARB 0x88ED +#define GL_PIXEL_UNPACK_BUFFER_BINDING_ARB 0x88EF + +#define GLEW_ARB_pixel_buffer_object GLEW_GET_VAR(__GLEW_ARB_pixel_buffer_object) + +#endif /* GL_ARB_pixel_buffer_object */ + +/* ------------------------ GL_ARB_point_parameters ------------------------ */ + +#ifndef GL_ARB_point_parameters +#define GL_ARB_point_parameters 1 + +#define GL_POINT_SIZE_MIN_ARB 0x8126 +#define GL_POINT_SIZE_MAX_ARB 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE_ARB 0x8128 +#define GL_POINT_DISTANCE_ATTENUATION_ARB 0x8129 + +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFARBPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVARBPROC) (GLenum pname, GLfloat* params); + +#define glPointParameterfARB GLEW_GET_FUN(__glewPointParameterfARB) +#define glPointParameterfvARB GLEW_GET_FUN(__glewPointParameterfvARB) + +#define GLEW_ARB_point_parameters GLEW_GET_VAR(__GLEW_ARB_point_parameters) + +#endif /* GL_ARB_point_parameters */ + +/* -------------------------- GL_ARB_point_sprite -------------------------- */ + +#ifndef GL_ARB_point_sprite +#define GL_ARB_point_sprite 1 + +#define GL_POINT_SPRITE_ARB 0x8861 +#define GL_COORD_REPLACE_ARB 0x8862 + +#define GLEW_ARB_point_sprite GLEW_GET_VAR(__GLEW_ARB_point_sprite) + +#endif /* GL_ARB_point_sprite */ + +/* ------------------------ GL_ARB_provoking_vertex ------------------------ */ + +#ifndef GL_ARB_provoking_vertex +#define GL_ARB_provoking_vertex 1 + +#define GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION 0x8E4C +#define GL_FIRST_VERTEX_CONVENTION 0x8E4D +#define GL_LAST_VERTEX_CONVENTION 0x8E4E +#define GL_PROVOKING_VERTEX 0x8E4F + +typedef void (GLAPIENTRY * PFNGLPROVOKINGVERTEXPROC) (GLenum mode); + +#define glProvokingVertex GLEW_GET_FUN(__glewProvokingVertex) + +#define GLEW_ARB_provoking_vertex GLEW_GET_VAR(__GLEW_ARB_provoking_vertex) + +#endif /* GL_ARB_provoking_vertex */ + +/* ------------------------- GL_ARB_sample_shading ------------------------- */ + +#ifndef GL_ARB_sample_shading +#define GL_ARB_sample_shading 1 + +#define GL_SAMPLE_SHADING_ARB 0x8C36 +#define GL_MIN_SAMPLE_SHADING_VALUE_ARB 0x8C37 + +typedef void (GLAPIENTRY * PFNGLMINSAMPLESHADINGARBPROC) (GLclampf value); + +#define glMinSampleShadingARB GLEW_GET_FUN(__glewMinSampleShadingARB) + +#define GLEW_ARB_sample_shading GLEW_GET_VAR(__GLEW_ARB_sample_shading) + +#endif /* GL_ARB_sample_shading */ + +/* ------------------------- GL_ARB_sampler_objects ------------------------ */ + +#ifndef GL_ARB_sampler_objects +#define GL_ARB_sampler_objects 1 + +#define GL_SAMPLER_BINDING 0x8919 + +typedef void (GLAPIENTRY * PFNGLBINDSAMPLERPROC) (GLuint unit, GLuint sampler); +typedef void (GLAPIENTRY * PFNGLDELETESAMPLERSPROC) (GLsizei count, const GLuint * samplers); +typedef void (GLAPIENTRY * PFNGLGENSAMPLERSPROC) (GLsizei count, GLuint* samplers); +typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, GLuint* params); +typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISSAMPLERPROC) (GLuint sampler); +typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, const GLuint* params); +typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERFPROC) (GLuint sampler, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIPROC) (GLuint sampler, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, const GLint* params); + +#define glBindSampler GLEW_GET_FUN(__glewBindSampler) +#define glDeleteSamplers GLEW_GET_FUN(__glewDeleteSamplers) +#define glGenSamplers GLEW_GET_FUN(__glewGenSamplers) +#define glGetSamplerParameterIiv GLEW_GET_FUN(__glewGetSamplerParameterIiv) +#define glGetSamplerParameterIuiv GLEW_GET_FUN(__glewGetSamplerParameterIuiv) +#define glGetSamplerParameterfv GLEW_GET_FUN(__glewGetSamplerParameterfv) +#define glGetSamplerParameteriv GLEW_GET_FUN(__glewGetSamplerParameteriv) +#define glIsSampler GLEW_GET_FUN(__glewIsSampler) +#define glSamplerParameterIiv GLEW_GET_FUN(__glewSamplerParameterIiv) +#define glSamplerParameterIuiv GLEW_GET_FUN(__glewSamplerParameterIuiv) +#define glSamplerParameterf GLEW_GET_FUN(__glewSamplerParameterf) +#define glSamplerParameterfv GLEW_GET_FUN(__glewSamplerParameterfv) +#define glSamplerParameteri GLEW_GET_FUN(__glewSamplerParameteri) +#define glSamplerParameteriv GLEW_GET_FUN(__glewSamplerParameteriv) + +#define GLEW_ARB_sampler_objects GLEW_GET_VAR(__GLEW_ARB_sampler_objects) + +#endif /* GL_ARB_sampler_objects */ + +/* ------------------------ GL_ARB_seamless_cube_map ----------------------- */ + +#ifndef GL_ARB_seamless_cube_map +#define GL_ARB_seamless_cube_map 1 + +#define GL_TEXTURE_CUBE_MAP_SEAMLESS 0x884F + +#define GLEW_ARB_seamless_cube_map GLEW_GET_VAR(__GLEW_ARB_seamless_cube_map) + +#endif /* GL_ARB_seamless_cube_map */ + +/* ----------------------- GL_ARB_shader_bit_encoding ---------------------- */ + +#ifndef GL_ARB_shader_bit_encoding +#define GL_ARB_shader_bit_encoding 1 + +#define GLEW_ARB_shader_bit_encoding GLEW_GET_VAR(__GLEW_ARB_shader_bit_encoding) + +#endif /* GL_ARB_shader_bit_encoding */ + +/* ------------------------- GL_ARB_shader_objects ------------------------- */ + +#ifndef GL_ARB_shader_objects +#define GL_ARB_shader_objects 1 + +#define GL_PROGRAM_OBJECT_ARB 0x8B40 +#define GL_SHADER_OBJECT_ARB 0x8B48 +#define GL_OBJECT_TYPE_ARB 0x8B4E +#define GL_OBJECT_SUBTYPE_ARB 0x8B4F +#define GL_FLOAT_VEC2_ARB 0x8B50 +#define GL_FLOAT_VEC3_ARB 0x8B51 +#define GL_FLOAT_VEC4_ARB 0x8B52 +#define GL_INT_VEC2_ARB 0x8B53 +#define GL_INT_VEC3_ARB 0x8B54 +#define GL_INT_VEC4_ARB 0x8B55 +#define GL_BOOL_ARB 0x8B56 +#define GL_BOOL_VEC2_ARB 0x8B57 +#define GL_BOOL_VEC3_ARB 0x8B58 +#define GL_BOOL_VEC4_ARB 0x8B59 +#define GL_FLOAT_MAT2_ARB 0x8B5A +#define GL_FLOAT_MAT3_ARB 0x8B5B +#define GL_FLOAT_MAT4_ARB 0x8B5C +#define GL_SAMPLER_1D_ARB 0x8B5D +#define GL_SAMPLER_2D_ARB 0x8B5E +#define GL_SAMPLER_3D_ARB 0x8B5F +#define GL_SAMPLER_CUBE_ARB 0x8B60 +#define GL_SAMPLER_1D_SHADOW_ARB 0x8B61 +#define GL_SAMPLER_2D_SHADOW_ARB 0x8B62 +#define GL_SAMPLER_2D_RECT_ARB 0x8B63 +#define GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 +#define GL_OBJECT_DELETE_STATUS_ARB 0x8B80 +#define GL_OBJECT_COMPILE_STATUS_ARB 0x8B81 +#define GL_OBJECT_LINK_STATUS_ARB 0x8B82 +#define GL_OBJECT_VALIDATE_STATUS_ARB 0x8B83 +#define GL_OBJECT_INFO_LOG_LENGTH_ARB 0x8B84 +#define GL_OBJECT_ATTACHED_OBJECTS_ARB 0x8B85 +#define GL_OBJECT_ACTIVE_UNIFORMS_ARB 0x8B86 +#define GL_OBJECT_ACTIVE_UNIFORM_MAX_LENGTH_ARB 0x8B87 +#define GL_OBJECT_SHADER_SOURCE_LENGTH_ARB 0x8B88 + +typedef char GLcharARB; +typedef unsigned int GLhandleARB; + +typedef void (GLAPIENTRY * PFNGLATTACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB obj); +typedef void (GLAPIENTRY * PFNGLCOMPILESHADERARBPROC) (GLhandleARB shaderObj); +typedef GLhandleARB (GLAPIENTRY * PFNGLCREATEPROGRAMOBJECTARBPROC) (void); +typedef GLhandleARB (GLAPIENTRY * PFNGLCREATESHADEROBJECTARBPROC) (GLenum shaderType); +typedef void (GLAPIENTRY * PFNGLDELETEOBJECTARBPROC) (GLhandleARB obj); +typedef void (GLAPIENTRY * PFNGLDETACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB attachedObj); +typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name); +typedef void (GLAPIENTRY * PFNGLGETATTACHEDOBJECTSARBPROC) (GLhandleARB containerObj, GLsizei maxCount, GLsizei* count, GLhandleARB *obj); +typedef GLhandleARB (GLAPIENTRY * PFNGLGETHANDLEARBPROC) (GLenum pname); +typedef void (GLAPIENTRY * PFNGLGETINFOLOGARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *infoLog); +typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERFVARBPROC) (GLhandleARB obj, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERIVARBPROC) (GLhandleARB obj, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETSHADERSOURCEARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *source); +typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB* name); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMFVARBPROC) (GLhandleARB programObj, GLint location, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMIVARBPROC) (GLhandleARB programObj, GLint location, GLint* params); +typedef void (GLAPIENTRY * PFNGLLINKPROGRAMARBPROC) (GLhandleARB programObj); +typedef void (GLAPIENTRY * PFNGLSHADERSOURCEARBPROC) (GLhandleARB shaderObj, GLsizei count, const GLcharARB ** string, const GLint *length); +typedef void (GLAPIENTRY * PFNGLUNIFORM1FARBPROC) (GLint location, GLfloat v0); +typedef void (GLAPIENTRY * PFNGLUNIFORM1FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM1IARBPROC) (GLint location, GLint v0); +typedef void (GLAPIENTRY * PFNGLUNIFORM1IVARBPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM2FARBPROC) (GLint location, GLfloat v0, GLfloat v1); +typedef void (GLAPIENTRY * PFNGLUNIFORM2FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM2IARBPROC) (GLint location, GLint v0, GLint v1); +typedef void (GLAPIENTRY * PFNGLUNIFORM2IVARBPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM3FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (GLAPIENTRY * PFNGLUNIFORM3FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM3IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2); +typedef void (GLAPIENTRY * PFNGLUNIFORM3IVARBPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM4FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (GLAPIENTRY * PFNGLUNIFORM4FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM4IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (GLAPIENTRY * PFNGLUNIFORM4IVARBPROC) (GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLUSEPROGRAMOBJECTARBPROC) (GLhandleARB programObj); +typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMARBPROC) (GLhandleARB programObj); + +#define glAttachObjectARB GLEW_GET_FUN(__glewAttachObjectARB) +#define glCompileShaderARB GLEW_GET_FUN(__glewCompileShaderARB) +#define glCreateProgramObjectARB GLEW_GET_FUN(__glewCreateProgramObjectARB) +#define glCreateShaderObjectARB GLEW_GET_FUN(__glewCreateShaderObjectARB) +#define glDeleteObjectARB GLEW_GET_FUN(__glewDeleteObjectARB) +#define glDetachObjectARB GLEW_GET_FUN(__glewDetachObjectARB) +#define glGetActiveUniformARB GLEW_GET_FUN(__glewGetActiveUniformARB) +#define glGetAttachedObjectsARB GLEW_GET_FUN(__glewGetAttachedObjectsARB) +#define glGetHandleARB GLEW_GET_FUN(__glewGetHandleARB) +#define glGetInfoLogARB GLEW_GET_FUN(__glewGetInfoLogARB) +#define glGetObjectParameterfvARB GLEW_GET_FUN(__glewGetObjectParameterfvARB) +#define glGetObjectParameterivARB GLEW_GET_FUN(__glewGetObjectParameterivARB) +#define glGetShaderSourceARB GLEW_GET_FUN(__glewGetShaderSourceARB) +#define glGetUniformLocationARB GLEW_GET_FUN(__glewGetUniformLocationARB) +#define glGetUniformfvARB GLEW_GET_FUN(__glewGetUniformfvARB) +#define glGetUniformivARB GLEW_GET_FUN(__glewGetUniformivARB) +#define glLinkProgramARB GLEW_GET_FUN(__glewLinkProgramARB) +#define glShaderSourceARB GLEW_GET_FUN(__glewShaderSourceARB) +#define glUniform1fARB GLEW_GET_FUN(__glewUniform1fARB) +#define glUniform1fvARB GLEW_GET_FUN(__glewUniform1fvARB) +#define glUniform1iARB GLEW_GET_FUN(__glewUniform1iARB) +#define glUniform1ivARB GLEW_GET_FUN(__glewUniform1ivARB) +#define glUniform2fARB GLEW_GET_FUN(__glewUniform2fARB) +#define glUniform2fvARB GLEW_GET_FUN(__glewUniform2fvARB) +#define glUniform2iARB GLEW_GET_FUN(__glewUniform2iARB) +#define glUniform2ivARB GLEW_GET_FUN(__glewUniform2ivARB) +#define glUniform3fARB GLEW_GET_FUN(__glewUniform3fARB) +#define glUniform3fvARB GLEW_GET_FUN(__glewUniform3fvARB) +#define glUniform3iARB GLEW_GET_FUN(__glewUniform3iARB) +#define glUniform3ivARB GLEW_GET_FUN(__glewUniform3ivARB) +#define glUniform4fARB GLEW_GET_FUN(__glewUniform4fARB) +#define glUniform4fvARB GLEW_GET_FUN(__glewUniform4fvARB) +#define glUniform4iARB GLEW_GET_FUN(__glewUniform4iARB) +#define glUniform4ivARB GLEW_GET_FUN(__glewUniform4ivARB) +#define glUniformMatrix2fvARB GLEW_GET_FUN(__glewUniformMatrix2fvARB) +#define glUniformMatrix3fvARB GLEW_GET_FUN(__glewUniformMatrix3fvARB) +#define glUniformMatrix4fvARB GLEW_GET_FUN(__glewUniformMatrix4fvARB) +#define glUseProgramObjectARB GLEW_GET_FUN(__glewUseProgramObjectARB) +#define glValidateProgramARB GLEW_GET_FUN(__glewValidateProgramARB) + +#define GLEW_ARB_shader_objects GLEW_GET_VAR(__GLEW_ARB_shader_objects) + +#endif /* GL_ARB_shader_objects */ + +/* ------------------------ GL_ARB_shader_subroutine ----------------------- */ + +#ifndef GL_ARB_shader_subroutine +#define GL_ARB_shader_subroutine 1 + +#define GL_ACTIVE_SUBROUTINES 0x8DE5 +#define GL_ACTIVE_SUBROUTINE_UNIFORMS 0x8DE6 +#define GL_MAX_SUBROUTINES 0x8DE7 +#define GL_MAX_SUBROUTINE_UNIFORM_LOCATIONS 0x8DE8 +#define GL_ACTIVE_SUBROUTINE_UNIFORM_LOCATIONS 0x8E47 +#define GL_ACTIVE_SUBROUTINE_MAX_LENGTH 0x8E48 +#define GL_ACTIVE_SUBROUTINE_UNIFORM_MAX_LENGTH 0x8E49 +#define GL_NUM_COMPATIBLE_SUBROUTINES 0x8E4A +#define GL_COMPATIBLE_SUBROUTINES 0x8E4B + +typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINENAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, char *name); +typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, char *name); +typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC) (GLuint program, GLenum shadertype, GLuint index, GLenum pname, GLint* values); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTAGEIVPROC) (GLuint program, GLenum shadertype, GLenum pname, GLint* values); +typedef GLuint (GLAPIENTRY * PFNGLGETSUBROUTINEINDEXPROC) (GLuint program, GLenum shadertype, const char* name); +typedef GLint (GLAPIENTRY * PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC) (GLuint program, GLenum shadertype, const char* name); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMSUBROUTINEUIVPROC) (GLenum shadertype, GLint location, GLuint* params); +typedef void (GLAPIENTRY * PFNGLUNIFORMSUBROUTINESUIVPROC) (GLenum shadertype, GLsizei count, const GLuint* indices); + +#define glGetActiveSubroutineName GLEW_GET_FUN(__glewGetActiveSubroutineName) +#define glGetActiveSubroutineUniformName GLEW_GET_FUN(__glewGetActiveSubroutineUniformName) +#define glGetActiveSubroutineUniformiv GLEW_GET_FUN(__glewGetActiveSubroutineUniformiv) +#define glGetProgramStageiv GLEW_GET_FUN(__glewGetProgramStageiv) +#define glGetSubroutineIndex GLEW_GET_FUN(__glewGetSubroutineIndex) +#define glGetSubroutineUniformLocation GLEW_GET_FUN(__glewGetSubroutineUniformLocation) +#define glGetUniformSubroutineuiv GLEW_GET_FUN(__glewGetUniformSubroutineuiv) +#define glUniformSubroutinesuiv GLEW_GET_FUN(__glewUniformSubroutinesuiv) + +#define GLEW_ARB_shader_subroutine GLEW_GET_VAR(__GLEW_ARB_shader_subroutine) + +#endif /* GL_ARB_shader_subroutine */ + +/* ----------------------- GL_ARB_shader_texture_lod ----------------------- */ + +#ifndef GL_ARB_shader_texture_lod +#define GL_ARB_shader_texture_lod 1 + +#define GLEW_ARB_shader_texture_lod GLEW_GET_VAR(__GLEW_ARB_shader_texture_lod) + +#endif /* GL_ARB_shader_texture_lod */ + +/* ---------------------- GL_ARB_shading_language_100 ---------------------- */ + +#ifndef GL_ARB_shading_language_100 +#define GL_ARB_shading_language_100 1 + +#define GL_SHADING_LANGUAGE_VERSION_ARB 0x8B8C + +#define GLEW_ARB_shading_language_100 GLEW_GET_VAR(__GLEW_ARB_shading_language_100) + +#endif /* GL_ARB_shading_language_100 */ + +/* -------------------- GL_ARB_shading_language_include -------------------- */ + +#ifndef GL_ARB_shading_language_include +#define GL_ARB_shading_language_include 1 + +#define GL_SHADER_INCLUDE_ARB 0x8DAE +#define GL_NAMED_STRING_LENGTH_ARB 0x8DE9 +#define GL_NAMED_STRING_TYPE_ARB 0x8DEA + +typedef void (GLAPIENTRY * PFNGLCOMPILESHADERINCLUDEARBPROC) (GLuint shader, GLsizei count, const char ** path, const GLint *length); +typedef void (GLAPIENTRY * PFNGLDELETENAMEDSTRINGARBPROC) (GLint namelen, const char* name); +typedef void (GLAPIENTRY * PFNGLGETNAMEDSTRINGARBPROC) (GLint namelen, const char* name, GLsizei bufSize, GLint *stringlen, char *string); +typedef void (GLAPIENTRY * PFNGLGETNAMEDSTRINGIVARBPROC) (GLint namelen, const char* name, GLenum pname, GLint *params); +typedef GLboolean (GLAPIENTRY * PFNGLISNAMEDSTRINGARBPROC) (GLint namelen, const char* name); +typedef void (GLAPIENTRY * PFNGLNAMEDSTRINGARBPROC) (GLenum type, GLint namelen, const char* name, GLint stringlen, const char *string); + +#define glCompileShaderIncludeARB GLEW_GET_FUN(__glewCompileShaderIncludeARB) +#define glDeleteNamedStringARB GLEW_GET_FUN(__glewDeleteNamedStringARB) +#define glGetNamedStringARB GLEW_GET_FUN(__glewGetNamedStringARB) +#define glGetNamedStringivARB GLEW_GET_FUN(__glewGetNamedStringivARB) +#define glIsNamedStringARB GLEW_GET_FUN(__glewIsNamedStringARB) +#define glNamedStringARB GLEW_GET_FUN(__glewNamedStringARB) + +#define GLEW_ARB_shading_language_include GLEW_GET_VAR(__GLEW_ARB_shading_language_include) + +#endif /* GL_ARB_shading_language_include */ + +/* ----------------------------- GL_ARB_shadow ----------------------------- */ + +#ifndef GL_ARB_shadow +#define GL_ARB_shadow 1 + +#define GL_TEXTURE_COMPARE_MODE_ARB 0x884C +#define GL_TEXTURE_COMPARE_FUNC_ARB 0x884D +#define GL_COMPARE_R_TO_TEXTURE_ARB 0x884E + +#define GLEW_ARB_shadow GLEW_GET_VAR(__GLEW_ARB_shadow) + +#endif /* GL_ARB_shadow */ + +/* ------------------------- GL_ARB_shadow_ambient ------------------------- */ + +#ifndef GL_ARB_shadow_ambient +#define GL_ARB_shadow_ambient 1 + +#define GL_TEXTURE_COMPARE_FAIL_VALUE_ARB 0x80BF + +#define GLEW_ARB_shadow_ambient GLEW_GET_VAR(__GLEW_ARB_shadow_ambient) + +#endif /* GL_ARB_shadow_ambient */ + +/* ------------------------------ GL_ARB_sync ------------------------------ */ + +#ifndef GL_ARB_sync +#define GL_ARB_sync 1 + +#define GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001 +#define GL_MAX_SERVER_WAIT_TIMEOUT 0x9111 +#define GL_OBJECT_TYPE 0x9112 +#define GL_SYNC_CONDITION 0x9113 +#define GL_SYNC_STATUS 0x9114 +#define GL_SYNC_FLAGS 0x9115 +#define GL_SYNC_FENCE 0x9116 +#define GL_SYNC_GPU_COMMANDS_COMPLETE 0x9117 +#define GL_UNSIGNALED 0x9118 +#define GL_SIGNALED 0x9119 +#define GL_ALREADY_SIGNALED 0x911A +#define GL_TIMEOUT_EXPIRED 0x911B +#define GL_CONDITION_SATISFIED 0x911C +#define GL_WAIT_FAILED 0x911D +#define GL_TIMEOUT_IGNORED 0xFFFFFFFFFFFFFFFF + +typedef GLenum (GLAPIENTRY * PFNGLCLIENTWAITSYNCPROC) (GLsync GLsync,GLbitfield flags,GLuint64 timeout); +typedef void (GLAPIENTRY * PFNGLDELETESYNCPROC) (GLsync GLsync); +typedef GLsync (GLAPIENTRY * PFNGLFENCESYNCPROC) (GLenum condition,GLbitfield flags); +typedef void (GLAPIENTRY * PFNGLGETINTEGER64VPROC) (GLenum pname, GLint64* params); +typedef void (GLAPIENTRY * PFNGLGETSYNCIVPROC) (GLsync GLsync,GLenum pname,GLsizei bufSize,GLsizei* length, GLint *values); +typedef GLboolean (GLAPIENTRY * PFNGLISSYNCPROC) (GLsync GLsync); +typedef void (GLAPIENTRY * PFNGLWAITSYNCPROC) (GLsync GLsync,GLbitfield flags,GLuint64 timeout); + +#define glClientWaitSync GLEW_GET_FUN(__glewClientWaitSync) +#define glDeleteSync GLEW_GET_FUN(__glewDeleteSync) +#define glFenceSync GLEW_GET_FUN(__glewFenceSync) +#define glGetInteger64v GLEW_GET_FUN(__glewGetInteger64v) +#define glGetSynciv GLEW_GET_FUN(__glewGetSynciv) +#define glIsSync GLEW_GET_FUN(__glewIsSync) +#define glWaitSync GLEW_GET_FUN(__glewWaitSync) + +#define GLEW_ARB_sync GLEW_GET_VAR(__GLEW_ARB_sync) + +#endif /* GL_ARB_sync */ + +/* ----------------------- GL_ARB_tessellation_shader ---------------------- */ + +#ifndef GL_ARB_tessellation_shader +#define GL_ARB_tessellation_shader 1 + +#define GL_PATCHES 0xE +#define GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_CONTROL_SHADER 0x84F0 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_EVALUATION_SHADER 0x84F1 +#define GL_MAX_TESS_CONTROL_INPUT_COMPONENTS 0x886C +#define GL_MAX_TESS_EVALUATION_INPUT_COMPONENTS 0x886D +#define GL_MAX_COMBINED_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E1E +#define GL_MAX_COMBINED_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E1F +#define GL_PATCH_VERTICES 0x8E72 +#define GL_PATCH_DEFAULT_INNER_LEVEL 0x8E73 +#define GL_PATCH_DEFAULT_OUTER_LEVEL 0x8E74 +#define GL_TESS_CONTROL_OUTPUT_VERTICES 0x8E75 +#define GL_TESS_GEN_MODE 0x8E76 +#define GL_TESS_GEN_SPACING 0x8E77 +#define GL_TESS_GEN_VERTEX_ORDER 0x8E78 +#define GL_TESS_GEN_POINT_MODE 0x8E79 +#define GL_ISOLINES 0x8E7A +#define GL_FRACTIONAL_ODD 0x8E7B +#define GL_FRACTIONAL_EVEN 0x8E7C +#define GL_MAX_PATCH_VERTICES 0x8E7D +#define GL_MAX_TESS_GEN_LEVEL 0x8E7E +#define GL_MAX_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E7F +#define GL_MAX_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E80 +#define GL_MAX_TESS_CONTROL_TEXTURE_IMAGE_UNITS 0x8E81 +#define GL_MAX_TESS_EVALUATION_TEXTURE_IMAGE_UNITS 0x8E82 +#define GL_MAX_TESS_CONTROL_OUTPUT_COMPONENTS 0x8E83 +#define GL_MAX_TESS_PATCH_COMPONENTS 0x8E84 +#define GL_MAX_TESS_CONTROL_TOTAL_OUTPUT_COMPONENTS 0x8E85 +#define GL_MAX_TESS_EVALUATION_OUTPUT_COMPONENTS 0x8E86 +#define GL_TESS_EVALUATION_SHADER 0x8E87 +#define GL_TESS_CONTROL_SHADER 0x8E88 +#define GL_MAX_TESS_CONTROL_UNIFORM_BLOCKS 0x8E89 +#define GL_MAX_TESS_EVALUATION_UNIFORM_BLOCKS 0x8E8A + +typedef void (GLAPIENTRY * PFNGLPATCHPARAMETERFVPROC) (GLenum pname, const GLfloat* values); +typedef void (GLAPIENTRY * PFNGLPATCHPARAMETERIPROC) (GLenum pname, GLint value); + +#define glPatchParameterfv GLEW_GET_FUN(__glewPatchParameterfv) +#define glPatchParameteri GLEW_GET_FUN(__glewPatchParameteri) + +#define GLEW_ARB_tessellation_shader GLEW_GET_VAR(__GLEW_ARB_tessellation_shader) + +#endif /* GL_ARB_tessellation_shader */ + +/* ---------------------- GL_ARB_texture_border_clamp ---------------------- */ + +#ifndef GL_ARB_texture_border_clamp +#define GL_ARB_texture_border_clamp 1 + +#define GL_CLAMP_TO_BORDER_ARB 0x812D + +#define GLEW_ARB_texture_border_clamp GLEW_GET_VAR(__GLEW_ARB_texture_border_clamp) + +#endif /* GL_ARB_texture_border_clamp */ + +/* ---------------------- GL_ARB_texture_buffer_object --------------------- */ + +#ifndef GL_ARB_texture_buffer_object +#define GL_ARB_texture_buffer_object 1 + +#define GL_TEXTURE_BUFFER_ARB 0x8C2A +#define GL_MAX_TEXTURE_BUFFER_SIZE_ARB 0x8C2B +#define GL_TEXTURE_BINDING_BUFFER_ARB 0x8C2C +#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING_ARB 0x8C2D +#define GL_TEXTURE_BUFFER_FORMAT_ARB 0x8C2E + +typedef void (GLAPIENTRY * PFNGLTEXBUFFERARBPROC) (GLenum target, GLenum internalformat, GLuint buffer); + +#define glTexBufferARB GLEW_GET_FUN(__glewTexBufferARB) + +#define GLEW_ARB_texture_buffer_object GLEW_GET_VAR(__GLEW_ARB_texture_buffer_object) + +#endif /* GL_ARB_texture_buffer_object */ + +/* ------------------- GL_ARB_texture_buffer_object_rgb32 ------------------ */ + +#ifndef GL_ARB_texture_buffer_object_rgb32 +#define GL_ARB_texture_buffer_object_rgb32 1 + +#define GLEW_ARB_texture_buffer_object_rgb32 GLEW_GET_VAR(__GLEW_ARB_texture_buffer_object_rgb32) + +#endif /* GL_ARB_texture_buffer_object_rgb32 */ + +/* ----------------------- GL_ARB_texture_compression ---------------------- */ + +#ifndef GL_ARB_texture_compression +#define GL_ARB_texture_compression 1 + +#define GL_COMPRESSED_ALPHA_ARB 0x84E9 +#define GL_COMPRESSED_LUMINANCE_ARB 0x84EA +#define GL_COMPRESSED_LUMINANCE_ALPHA_ARB 0x84EB +#define GL_COMPRESSED_INTENSITY_ARB 0x84EC +#define GL_COMPRESSED_RGB_ARB 0x84ED +#define GL_COMPRESSED_RGBA_ARB 0x84EE +#define GL_TEXTURE_COMPRESSION_HINT_ARB 0x84EF +#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE_ARB 0x86A0 +#define GL_TEXTURE_COMPRESSED_ARB 0x86A1 +#define GL_NUM_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A2 +#define GL_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A3 + +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE1DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE2DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE3DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint lod, void* img); + +#define glCompressedTexImage1DARB GLEW_GET_FUN(__glewCompressedTexImage1DARB) +#define glCompressedTexImage2DARB GLEW_GET_FUN(__glewCompressedTexImage2DARB) +#define glCompressedTexImage3DARB GLEW_GET_FUN(__glewCompressedTexImage3DARB) +#define glCompressedTexSubImage1DARB GLEW_GET_FUN(__glewCompressedTexSubImage1DARB) +#define glCompressedTexSubImage2DARB GLEW_GET_FUN(__glewCompressedTexSubImage2DARB) +#define glCompressedTexSubImage3DARB GLEW_GET_FUN(__glewCompressedTexSubImage3DARB) +#define glGetCompressedTexImageARB GLEW_GET_FUN(__glewGetCompressedTexImageARB) + +#define GLEW_ARB_texture_compression GLEW_GET_VAR(__GLEW_ARB_texture_compression) + +#endif /* GL_ARB_texture_compression */ + +/* -------------------- GL_ARB_texture_compression_bptc -------------------- */ + +#ifndef GL_ARB_texture_compression_bptc +#define GL_ARB_texture_compression_bptc 1 + +#define GL_COMPRESSED_RGBA_BPTC_UNORM_ARB 0x8E8C +#define GL_COMPRESSED_SRGB_ALPHA_BPTC_UNORM_ARB 0x8E8D +#define GL_COMPRESSED_RGB_BPTC_SIGNED_FLOAT_ARB 0x8E8E +#define GL_COMPRESSED_RGB_BPTC_UNSIGNED_FLOAT_ARB 0x8E8F + +#define GLEW_ARB_texture_compression_bptc GLEW_GET_VAR(__GLEW_ARB_texture_compression_bptc) + +#endif /* GL_ARB_texture_compression_bptc */ + +/* -------------------- GL_ARB_texture_compression_rgtc -------------------- */ + +#ifndef GL_ARB_texture_compression_rgtc +#define GL_ARB_texture_compression_rgtc 1 + +#define GL_COMPRESSED_RED_RGTC1 0x8DBB +#define GL_COMPRESSED_SIGNED_RED_RGTC1 0x8DBC +#define GL_COMPRESSED_RG_RGTC2 0x8DBD +#define GL_COMPRESSED_SIGNED_RG_RGTC2 0x8DBE + +#define GLEW_ARB_texture_compression_rgtc GLEW_GET_VAR(__GLEW_ARB_texture_compression_rgtc) + +#endif /* GL_ARB_texture_compression_rgtc */ + +/* ------------------------ GL_ARB_texture_cube_map ------------------------ */ + +#ifndef GL_ARB_texture_cube_map +#define GL_ARB_texture_cube_map 1 + +#define GL_NORMAL_MAP_ARB 0x8511 +#define GL_REFLECTION_MAP_ARB 0x8512 +#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 +#define GL_TEXTURE_BINDING_CUBE_MAP_ARB 0x8514 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x8515 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x8516 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x8517 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x8518 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x8519 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x851A +#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B +#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_ARB 0x851C + +#define GLEW_ARB_texture_cube_map GLEW_GET_VAR(__GLEW_ARB_texture_cube_map) + +#endif /* GL_ARB_texture_cube_map */ + +/* --------------------- GL_ARB_texture_cube_map_array --------------------- */ + +#ifndef GL_ARB_texture_cube_map_array +#define GL_ARB_texture_cube_map_array 1 + +#define GL_TEXTURE_CUBE_MAP_ARRAY_ARB 0x9009 +#define GL_TEXTURE_BINDING_CUBE_MAP_ARRAY_ARB 0x900A +#define GL_PROXY_TEXTURE_CUBE_MAP_ARRAY_ARB 0x900B +#define GL_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900C +#define GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW_ARB 0x900D +#define GL_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900E +#define GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900F + +#define GLEW_ARB_texture_cube_map_array GLEW_GET_VAR(__GLEW_ARB_texture_cube_map_array) + +#endif /* GL_ARB_texture_cube_map_array */ + +/* ------------------------- GL_ARB_texture_env_add ------------------------ */ + +#ifndef GL_ARB_texture_env_add +#define GL_ARB_texture_env_add 1 + +#define GLEW_ARB_texture_env_add GLEW_GET_VAR(__GLEW_ARB_texture_env_add) + +#endif /* GL_ARB_texture_env_add */ + +/* ----------------------- GL_ARB_texture_env_combine ---------------------- */ + +#ifndef GL_ARB_texture_env_combine +#define GL_ARB_texture_env_combine 1 + +#define GL_SUBTRACT_ARB 0x84E7 +#define GL_COMBINE_ARB 0x8570 +#define GL_COMBINE_RGB_ARB 0x8571 +#define GL_COMBINE_ALPHA_ARB 0x8572 +#define GL_RGB_SCALE_ARB 0x8573 +#define GL_ADD_SIGNED_ARB 0x8574 +#define GL_INTERPOLATE_ARB 0x8575 +#define GL_CONSTANT_ARB 0x8576 +#define GL_PRIMARY_COLOR_ARB 0x8577 +#define GL_PREVIOUS_ARB 0x8578 +#define GL_SOURCE0_RGB_ARB 0x8580 +#define GL_SOURCE1_RGB_ARB 0x8581 +#define GL_SOURCE2_RGB_ARB 0x8582 +#define GL_SOURCE0_ALPHA_ARB 0x8588 +#define GL_SOURCE1_ALPHA_ARB 0x8589 +#define GL_SOURCE2_ALPHA_ARB 0x858A +#define GL_OPERAND0_RGB_ARB 0x8590 +#define GL_OPERAND1_RGB_ARB 0x8591 +#define GL_OPERAND2_RGB_ARB 0x8592 +#define GL_OPERAND0_ALPHA_ARB 0x8598 +#define GL_OPERAND1_ALPHA_ARB 0x8599 +#define GL_OPERAND2_ALPHA_ARB 0x859A + +#define GLEW_ARB_texture_env_combine GLEW_GET_VAR(__GLEW_ARB_texture_env_combine) + +#endif /* GL_ARB_texture_env_combine */ + +/* ---------------------- GL_ARB_texture_env_crossbar ---------------------- */ + +#ifndef GL_ARB_texture_env_crossbar +#define GL_ARB_texture_env_crossbar 1 + +#define GLEW_ARB_texture_env_crossbar GLEW_GET_VAR(__GLEW_ARB_texture_env_crossbar) + +#endif /* GL_ARB_texture_env_crossbar */ + +/* ------------------------ GL_ARB_texture_env_dot3 ------------------------ */ + +#ifndef GL_ARB_texture_env_dot3 +#define GL_ARB_texture_env_dot3 1 + +#define GL_DOT3_RGB_ARB 0x86AE +#define GL_DOT3_RGBA_ARB 0x86AF + +#define GLEW_ARB_texture_env_dot3 GLEW_GET_VAR(__GLEW_ARB_texture_env_dot3) + +#endif /* GL_ARB_texture_env_dot3 */ + +/* -------------------------- GL_ARB_texture_float ------------------------- */ + +#ifndef GL_ARB_texture_float +#define GL_ARB_texture_float 1 + +#define GL_RGBA32F_ARB 0x8814 +#define GL_RGB32F_ARB 0x8815 +#define GL_ALPHA32F_ARB 0x8816 +#define GL_INTENSITY32F_ARB 0x8817 +#define GL_LUMINANCE32F_ARB 0x8818 +#define GL_LUMINANCE_ALPHA32F_ARB 0x8819 +#define GL_RGBA16F_ARB 0x881A +#define GL_RGB16F_ARB 0x881B +#define GL_ALPHA16F_ARB 0x881C +#define GL_INTENSITY16F_ARB 0x881D +#define GL_LUMINANCE16F_ARB 0x881E +#define GL_LUMINANCE_ALPHA16F_ARB 0x881F +#define GL_TEXTURE_RED_TYPE_ARB 0x8C10 +#define GL_TEXTURE_GREEN_TYPE_ARB 0x8C11 +#define GL_TEXTURE_BLUE_TYPE_ARB 0x8C12 +#define GL_TEXTURE_ALPHA_TYPE_ARB 0x8C13 +#define GL_TEXTURE_LUMINANCE_TYPE_ARB 0x8C14 +#define GL_TEXTURE_INTENSITY_TYPE_ARB 0x8C15 +#define GL_TEXTURE_DEPTH_TYPE_ARB 0x8C16 +#define GL_UNSIGNED_NORMALIZED_ARB 0x8C17 + +#define GLEW_ARB_texture_float GLEW_GET_VAR(__GLEW_ARB_texture_float) + +#endif /* GL_ARB_texture_float */ + +/* ------------------------- GL_ARB_texture_gather ------------------------- */ + +#ifndef GL_ARB_texture_gather +#define GL_ARB_texture_gather 1 + +#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5E +#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5F +#define GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS_ARB 0x8F9F + +#define GLEW_ARB_texture_gather GLEW_GET_VAR(__GLEW_ARB_texture_gather) + +#endif /* GL_ARB_texture_gather */ + +/* --------------------- GL_ARB_texture_mirrored_repeat -------------------- */ + +#ifndef GL_ARB_texture_mirrored_repeat +#define GL_ARB_texture_mirrored_repeat 1 + +#define GL_MIRRORED_REPEAT_ARB 0x8370 + +#define GLEW_ARB_texture_mirrored_repeat GLEW_GET_VAR(__GLEW_ARB_texture_mirrored_repeat) + +#endif /* GL_ARB_texture_mirrored_repeat */ + +/* ----------------------- GL_ARB_texture_multisample ---------------------- */ + +#ifndef GL_ARB_texture_multisample +#define GL_ARB_texture_multisample 1 + +#define GL_SAMPLE_POSITION 0x8E50 +#define GL_SAMPLE_MASK 0x8E51 +#define GL_SAMPLE_MASK_VALUE 0x8E52 +#define GL_MAX_SAMPLE_MASK_WORDS 0x8E59 +#define GL_TEXTURE_2D_MULTISAMPLE 0x9100 +#define GL_PROXY_TEXTURE_2D_MULTISAMPLE 0x9101 +#define GL_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9102 +#define GL_PROXY_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9103 +#define GL_TEXTURE_BINDING_2D_MULTISAMPLE 0x9104 +#define GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY 0x9105 +#define GL_TEXTURE_SAMPLES 0x9106 +#define GL_TEXTURE_FIXED_SAMPLE_LOCATIONS 0x9107 +#define GL_SAMPLER_2D_MULTISAMPLE 0x9108 +#define GL_INT_SAMPLER_2D_MULTISAMPLE 0x9109 +#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE 0x910A +#define GL_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910B +#define GL_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910C +#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910D +#define GL_MAX_COLOR_TEXTURE_SAMPLES 0x910E +#define GL_MAX_DEPTH_TEXTURE_SAMPLES 0x910F +#define GL_MAX_INTEGER_SAMPLES 0x9110 + +typedef void (GLAPIENTRY * PFNGLGETMULTISAMPLEFVPROC) (GLenum pname, GLuint index, GLfloat* val); +typedef void (GLAPIENTRY * PFNGLSAMPLEMASKIPROC) (GLuint index, GLbitfield mask); +typedef void (GLAPIENTRY * PFNGLTEXIMAGE2DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); + +#define glGetMultisamplefv GLEW_GET_FUN(__glewGetMultisamplefv) +#define glSampleMaski GLEW_GET_FUN(__glewSampleMaski) +#define glTexImage2DMultisample GLEW_GET_FUN(__glewTexImage2DMultisample) +#define glTexImage3DMultisample GLEW_GET_FUN(__glewTexImage3DMultisample) + +#define GLEW_ARB_texture_multisample GLEW_GET_VAR(__GLEW_ARB_texture_multisample) + +#endif /* GL_ARB_texture_multisample */ + +/* -------------------- GL_ARB_texture_non_power_of_two -------------------- */ + +#ifndef GL_ARB_texture_non_power_of_two +#define GL_ARB_texture_non_power_of_two 1 + +#define GLEW_ARB_texture_non_power_of_two GLEW_GET_VAR(__GLEW_ARB_texture_non_power_of_two) + +#endif /* GL_ARB_texture_non_power_of_two */ + +/* ------------------------ GL_ARB_texture_query_lod ----------------------- */ + +#ifndef GL_ARB_texture_query_lod +#define GL_ARB_texture_query_lod 1 + +#define GLEW_ARB_texture_query_lod GLEW_GET_VAR(__GLEW_ARB_texture_query_lod) + +#endif /* GL_ARB_texture_query_lod */ + +/* ------------------------ GL_ARB_texture_rectangle ----------------------- */ + +#ifndef GL_ARB_texture_rectangle +#define GL_ARB_texture_rectangle 1 + +#define GL_TEXTURE_RECTANGLE_ARB 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE_ARB 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE_ARB 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE_ARB 0x84F8 +#define GL_SAMPLER_2D_RECT_ARB 0x8B63 +#define GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 + +#define GLEW_ARB_texture_rectangle GLEW_GET_VAR(__GLEW_ARB_texture_rectangle) + +#endif /* GL_ARB_texture_rectangle */ + +/* --------------------------- GL_ARB_texture_rg --------------------------- */ + +#ifndef GL_ARB_texture_rg +#define GL_ARB_texture_rg 1 + +#define GL_RED 0x1903 +#define GL_COMPRESSED_RED 0x8225 +#define GL_COMPRESSED_RG 0x8226 +#define GL_RG 0x8227 +#define GL_RG_INTEGER 0x8228 +#define GL_R8 0x8229 +#define GL_R16 0x822A +#define GL_RG8 0x822B +#define GL_RG16 0x822C +#define GL_R16F 0x822D +#define GL_R32F 0x822E +#define GL_RG16F 0x822F +#define GL_RG32F 0x8230 +#define GL_R8I 0x8231 +#define GL_R8UI 0x8232 +#define GL_R16I 0x8233 +#define GL_R16UI 0x8234 +#define GL_R32I 0x8235 +#define GL_R32UI 0x8236 +#define GL_RG8I 0x8237 +#define GL_RG8UI 0x8238 +#define GL_RG16I 0x8239 +#define GL_RG16UI 0x823A +#define GL_RG32I 0x823B +#define GL_RG32UI 0x823C + +#define GLEW_ARB_texture_rg GLEW_GET_VAR(__GLEW_ARB_texture_rg) + +#endif /* GL_ARB_texture_rg */ + +/* ----------------------- GL_ARB_texture_rgb10_a2ui ----------------------- */ + +#ifndef GL_ARB_texture_rgb10_a2ui +#define GL_ARB_texture_rgb10_a2ui 1 + +#define GL_RGB10_A2UI 0x906F + +#define GLEW_ARB_texture_rgb10_a2ui GLEW_GET_VAR(__GLEW_ARB_texture_rgb10_a2ui) + +#endif /* GL_ARB_texture_rgb10_a2ui */ + +/* ------------------------- GL_ARB_texture_swizzle ------------------------ */ + +#ifndef GL_ARB_texture_swizzle +#define GL_ARB_texture_swizzle 1 + +#define GL_TEXTURE_SWIZZLE_R 0x8E42 +#define GL_TEXTURE_SWIZZLE_G 0x8E43 +#define GL_TEXTURE_SWIZZLE_B 0x8E44 +#define GL_TEXTURE_SWIZZLE_A 0x8E45 +#define GL_TEXTURE_SWIZZLE_RGBA 0x8E46 + +#define GLEW_ARB_texture_swizzle GLEW_GET_VAR(__GLEW_ARB_texture_swizzle) + +#endif /* GL_ARB_texture_swizzle */ + +/* --------------------------- GL_ARB_timer_query -------------------------- */ + +#ifndef GL_ARB_timer_query +#define GL_ARB_timer_query 1 + +#define GL_TIME_ELAPSED 0x88BF +#define GL_TIMESTAMP 0x8E28 + +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTI64VPROC) (GLuint id, GLenum pname, GLint64* params); +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUI64VPROC) (GLuint id, GLenum pname, GLuint64* params); +typedef void (GLAPIENTRY * PFNGLQUERYCOUNTERPROC) (GLuint id, GLenum target); + +#define glGetQueryObjecti64v GLEW_GET_FUN(__glewGetQueryObjecti64v) +#define glGetQueryObjectui64v GLEW_GET_FUN(__glewGetQueryObjectui64v) +#define glQueryCounter GLEW_GET_FUN(__glewQueryCounter) + +#define GLEW_ARB_timer_query GLEW_GET_VAR(__GLEW_ARB_timer_query) + +#endif /* GL_ARB_timer_query */ + +/* ----------------------- GL_ARB_transform_feedback2 ---------------------- */ + +#ifndef GL_ARB_transform_feedback2 +#define GL_ARB_transform_feedback2 1 + +#define GL_TRANSFORM_FEEDBACK 0x8E22 +#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED 0x8E23 +#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE 0x8E24 +#define GL_TRANSFORM_FEEDBACK_BINDING 0x8E25 + +typedef void (GLAPIENTRY * PFNGLBINDTRANSFORMFEEDBACKPROC) (GLenum target, GLuint id); +typedef void (GLAPIENTRY * PFNGLDELETETRANSFORMFEEDBACKSPROC) (GLsizei n, const GLuint* ids); +typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKPROC) (GLenum mode, GLuint id); +typedef void (GLAPIENTRY * PFNGLGENTRANSFORMFEEDBACKSPROC) (GLsizei n, GLuint* ids); +typedef GLboolean (GLAPIENTRY * PFNGLISTRANSFORMFEEDBACKPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLPAUSETRANSFORMFEEDBACKPROC) (void); +typedef void (GLAPIENTRY * PFNGLRESUMETRANSFORMFEEDBACKPROC) (void); + +#define glBindTransformFeedback GLEW_GET_FUN(__glewBindTransformFeedback) +#define glDeleteTransformFeedbacks GLEW_GET_FUN(__glewDeleteTransformFeedbacks) +#define glDrawTransformFeedback GLEW_GET_FUN(__glewDrawTransformFeedback) +#define glGenTransformFeedbacks GLEW_GET_FUN(__glewGenTransformFeedbacks) +#define glIsTransformFeedback GLEW_GET_FUN(__glewIsTransformFeedback) +#define glPauseTransformFeedback GLEW_GET_FUN(__glewPauseTransformFeedback) +#define glResumeTransformFeedback GLEW_GET_FUN(__glewResumeTransformFeedback) + +#define GLEW_ARB_transform_feedback2 GLEW_GET_VAR(__GLEW_ARB_transform_feedback2) + +#endif /* GL_ARB_transform_feedback2 */ + +/* ----------------------- GL_ARB_transform_feedback3 ---------------------- */ + +#ifndef GL_ARB_transform_feedback3 +#define GL_ARB_transform_feedback3 1 + +#define GL_MAX_TRANSFORM_FEEDBACK_BUFFERS 0x8E70 +#define GL_MAX_VERTEX_STREAMS 0x8E71 + +typedef void (GLAPIENTRY * PFNGLBEGINQUERYINDEXEDPROC) (GLenum target, GLuint index, GLuint id); +typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC) (GLenum mode, GLuint id, GLuint stream); +typedef void (GLAPIENTRY * PFNGLENDQUERYINDEXEDPROC) (GLenum target, GLuint index); +typedef void (GLAPIENTRY * PFNGLGETQUERYINDEXEDIVPROC) (GLenum target, GLuint index, GLenum pname, GLint* params); + +#define glBeginQueryIndexed GLEW_GET_FUN(__glewBeginQueryIndexed) +#define glDrawTransformFeedbackStream GLEW_GET_FUN(__glewDrawTransformFeedbackStream) +#define glEndQueryIndexed GLEW_GET_FUN(__glewEndQueryIndexed) +#define glGetQueryIndexediv GLEW_GET_FUN(__glewGetQueryIndexediv) + +#define GLEW_ARB_transform_feedback3 GLEW_GET_VAR(__GLEW_ARB_transform_feedback3) + +#endif /* GL_ARB_transform_feedback3 */ + +/* ------------------------ GL_ARB_transpose_matrix ------------------------ */ + +#ifndef GL_ARB_transpose_matrix +#define GL_ARB_transpose_matrix 1 + +#define GL_TRANSPOSE_MODELVIEW_MATRIX_ARB 0x84E3 +#define GL_TRANSPOSE_PROJECTION_MATRIX_ARB 0x84E4 +#define GL_TRANSPOSE_TEXTURE_MATRIX_ARB 0x84E5 +#define GL_TRANSPOSE_COLOR_MATRIX_ARB 0x84E6 + +typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXDARBPROC) (GLdouble m[16]); +typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXFARBPROC) (GLfloat m[16]); +typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXDARBPROC) (GLdouble m[16]); +typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXFARBPROC) (GLfloat m[16]); + +#define glLoadTransposeMatrixdARB GLEW_GET_FUN(__glewLoadTransposeMatrixdARB) +#define glLoadTransposeMatrixfARB GLEW_GET_FUN(__glewLoadTransposeMatrixfARB) +#define glMultTransposeMatrixdARB GLEW_GET_FUN(__glewMultTransposeMatrixdARB) +#define glMultTransposeMatrixfARB GLEW_GET_FUN(__glewMultTransposeMatrixfARB) + +#define GLEW_ARB_transpose_matrix GLEW_GET_VAR(__GLEW_ARB_transpose_matrix) + +#endif /* GL_ARB_transpose_matrix */ + +/* ---------------------- GL_ARB_uniform_buffer_object --------------------- */ + +#ifndef GL_ARB_uniform_buffer_object +#define GL_ARB_uniform_buffer_object 1 + +#define GL_UNIFORM_BUFFER 0x8A11 +#define GL_UNIFORM_BUFFER_BINDING 0x8A28 +#define GL_UNIFORM_BUFFER_START 0x8A29 +#define GL_UNIFORM_BUFFER_SIZE 0x8A2A +#define GL_MAX_VERTEX_UNIFORM_BLOCKS 0x8A2B +#define GL_MAX_GEOMETRY_UNIFORM_BLOCKS 0x8A2C +#define GL_MAX_FRAGMENT_UNIFORM_BLOCKS 0x8A2D +#define GL_MAX_COMBINED_UNIFORM_BLOCKS 0x8A2E +#define GL_MAX_UNIFORM_BUFFER_BINDINGS 0x8A2F +#define GL_MAX_UNIFORM_BLOCK_SIZE 0x8A30 +#define GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS 0x8A31 +#define GL_MAX_COMBINED_GEOMETRY_UNIFORM_COMPONENTS 0x8A32 +#define GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS 0x8A33 +#define GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT 0x8A34 +#define GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH 0x8A35 +#define GL_ACTIVE_UNIFORM_BLOCKS 0x8A36 +#define GL_UNIFORM_TYPE 0x8A37 +#define GL_UNIFORM_SIZE 0x8A38 +#define GL_UNIFORM_NAME_LENGTH 0x8A39 +#define GL_UNIFORM_BLOCK_INDEX 0x8A3A +#define GL_UNIFORM_OFFSET 0x8A3B +#define GL_UNIFORM_ARRAY_STRIDE 0x8A3C +#define GL_UNIFORM_MATRIX_STRIDE 0x8A3D +#define GL_UNIFORM_IS_ROW_MAJOR 0x8A3E +#define GL_UNIFORM_BLOCK_BINDING 0x8A3F +#define GL_UNIFORM_BLOCK_DATA_SIZE 0x8A40 +#define GL_UNIFORM_BLOCK_NAME_LENGTH 0x8A41 +#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORMS 0x8A42 +#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES 0x8A43 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER 0x8A44 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_GEOMETRY_SHADER 0x8A45 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER 0x8A46 +#define GL_INVALID_INDEX 0xFFFFFFFF + +typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASEPROC) (GLenum target, GLuint index, GLuint buffer); +typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGEPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC) (GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei* length, char* uniformBlockName); +typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMBLOCKIVPROC) (GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMNAMEPROC) (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei* length, char* uniformName); +typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMSIVPROC) (GLuint program, GLsizei uniformCount, const GLuint* uniformIndices, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETINTEGERI_VPROC) (GLenum target, GLuint index, GLint* data); +typedef GLuint (GLAPIENTRY * PFNGLGETUNIFORMBLOCKINDEXPROC) (GLuint program, const char* uniformBlockName); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMINDICESPROC) (GLuint program, GLsizei uniformCount, const char** uniformNames, GLuint* uniformIndices); +typedef void (GLAPIENTRY * PFNGLUNIFORMBLOCKBINDINGPROC) (GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding); + +#define glBindBufferBase GLEW_GET_FUN(__glewBindBufferBase) +#define glBindBufferRange GLEW_GET_FUN(__glewBindBufferRange) +#define glGetActiveUniformBlockName GLEW_GET_FUN(__glewGetActiveUniformBlockName) +#define glGetActiveUniformBlockiv GLEW_GET_FUN(__glewGetActiveUniformBlockiv) +#define glGetActiveUniformName GLEW_GET_FUN(__glewGetActiveUniformName) +#define glGetActiveUniformsiv GLEW_GET_FUN(__glewGetActiveUniformsiv) +#define glGetIntegeri_v GLEW_GET_FUN(__glewGetIntegeri_v) +#define glGetUniformBlockIndex GLEW_GET_FUN(__glewGetUniformBlockIndex) +#define glGetUniformIndices GLEW_GET_FUN(__glewGetUniformIndices) +#define glUniformBlockBinding GLEW_GET_FUN(__glewUniformBlockBinding) + +#define GLEW_ARB_uniform_buffer_object GLEW_GET_VAR(__GLEW_ARB_uniform_buffer_object) + +#endif /* GL_ARB_uniform_buffer_object */ + +/* ------------------------ GL_ARB_vertex_array_bgra ----------------------- */ + +#ifndef GL_ARB_vertex_array_bgra +#define GL_ARB_vertex_array_bgra 1 + +#define GL_BGRA 0x80E1 + +#define GLEW_ARB_vertex_array_bgra GLEW_GET_VAR(__GLEW_ARB_vertex_array_bgra) + +#endif /* GL_ARB_vertex_array_bgra */ + +/* ----------------------- GL_ARB_vertex_array_object ---------------------- */ + +#ifndef GL_ARB_vertex_array_object +#define GL_ARB_vertex_array_object 1 + +#define GL_VERTEX_ARRAY_BINDING 0x85B5 + +typedef void (GLAPIENTRY * PFNGLBINDVERTEXARRAYPROC) (GLuint array); +typedef void (GLAPIENTRY * PFNGLDELETEVERTEXARRAYSPROC) (GLsizei n, const GLuint* arrays); +typedef void (GLAPIENTRY * PFNGLGENVERTEXARRAYSPROC) (GLsizei n, GLuint* arrays); +typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXARRAYPROC) (GLuint array); + +#define glBindVertexArray GLEW_GET_FUN(__glewBindVertexArray) +#define glDeleteVertexArrays GLEW_GET_FUN(__glewDeleteVertexArrays) +#define glGenVertexArrays GLEW_GET_FUN(__glewGenVertexArrays) +#define glIsVertexArray GLEW_GET_FUN(__glewIsVertexArray) + +#define GLEW_ARB_vertex_array_object GLEW_GET_VAR(__GLEW_ARB_vertex_array_object) + +#endif /* GL_ARB_vertex_array_object */ + +/* -------------------------- GL_ARB_vertex_blend -------------------------- */ + +#ifndef GL_ARB_vertex_blend +#define GL_ARB_vertex_blend 1 + +#define GL_MODELVIEW0_ARB 0x1700 +#define GL_MODELVIEW1_ARB 0x850A +#define GL_MAX_VERTEX_UNITS_ARB 0x86A4 +#define GL_ACTIVE_VERTEX_UNITS_ARB 0x86A5 +#define GL_WEIGHT_SUM_UNITY_ARB 0x86A6 +#define GL_VERTEX_BLEND_ARB 0x86A7 +#define GL_CURRENT_WEIGHT_ARB 0x86A8 +#define GL_WEIGHT_ARRAY_TYPE_ARB 0x86A9 +#define GL_WEIGHT_ARRAY_STRIDE_ARB 0x86AA +#define GL_WEIGHT_ARRAY_SIZE_ARB 0x86AB +#define GL_WEIGHT_ARRAY_POINTER_ARB 0x86AC +#define GL_WEIGHT_ARRAY_ARB 0x86AD +#define GL_MODELVIEW2_ARB 0x8722 +#define GL_MODELVIEW3_ARB 0x8723 +#define GL_MODELVIEW4_ARB 0x8724 +#define GL_MODELVIEW5_ARB 0x8725 +#define GL_MODELVIEW6_ARB 0x8726 +#define GL_MODELVIEW7_ARB 0x8727 +#define GL_MODELVIEW8_ARB 0x8728 +#define GL_MODELVIEW9_ARB 0x8729 +#define GL_MODELVIEW10_ARB 0x872A +#define GL_MODELVIEW11_ARB 0x872B +#define GL_MODELVIEW12_ARB 0x872C +#define GL_MODELVIEW13_ARB 0x872D +#define GL_MODELVIEW14_ARB 0x872E +#define GL_MODELVIEW15_ARB 0x872F +#define GL_MODELVIEW16_ARB 0x8730 +#define GL_MODELVIEW17_ARB 0x8731 +#define GL_MODELVIEW18_ARB 0x8732 +#define GL_MODELVIEW19_ARB 0x8733 +#define GL_MODELVIEW20_ARB 0x8734 +#define GL_MODELVIEW21_ARB 0x8735 +#define GL_MODELVIEW22_ARB 0x8736 +#define GL_MODELVIEW23_ARB 0x8737 +#define GL_MODELVIEW24_ARB 0x8738 +#define GL_MODELVIEW25_ARB 0x8739 +#define GL_MODELVIEW26_ARB 0x873A +#define GL_MODELVIEW27_ARB 0x873B +#define GL_MODELVIEW28_ARB 0x873C +#define GL_MODELVIEW29_ARB 0x873D +#define GL_MODELVIEW30_ARB 0x873E +#define GL_MODELVIEW31_ARB 0x873F + +typedef void (GLAPIENTRY * PFNGLVERTEXBLENDARBPROC) (GLint count); +typedef void (GLAPIENTRY * PFNGLWEIGHTPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); +typedef void (GLAPIENTRY * PFNGLWEIGHTBVARBPROC) (GLint size, GLbyte *weights); +typedef void (GLAPIENTRY * PFNGLWEIGHTDVARBPROC) (GLint size, GLdouble *weights); +typedef void (GLAPIENTRY * PFNGLWEIGHTFVARBPROC) (GLint size, GLfloat *weights); +typedef void (GLAPIENTRY * PFNGLWEIGHTIVARBPROC) (GLint size, GLint *weights); +typedef void (GLAPIENTRY * PFNGLWEIGHTSVARBPROC) (GLint size, GLshort *weights); +typedef void (GLAPIENTRY * PFNGLWEIGHTUBVARBPROC) (GLint size, GLubyte *weights); +typedef void (GLAPIENTRY * PFNGLWEIGHTUIVARBPROC) (GLint size, GLuint *weights); +typedef void (GLAPIENTRY * PFNGLWEIGHTUSVARBPROC) (GLint size, GLushort *weights); + +#define glVertexBlendARB GLEW_GET_FUN(__glewVertexBlendARB) +#define glWeightPointerARB GLEW_GET_FUN(__glewWeightPointerARB) +#define glWeightbvARB GLEW_GET_FUN(__glewWeightbvARB) +#define glWeightdvARB GLEW_GET_FUN(__glewWeightdvARB) +#define glWeightfvARB GLEW_GET_FUN(__glewWeightfvARB) +#define glWeightivARB GLEW_GET_FUN(__glewWeightivARB) +#define glWeightsvARB GLEW_GET_FUN(__glewWeightsvARB) +#define glWeightubvARB GLEW_GET_FUN(__glewWeightubvARB) +#define glWeightuivARB GLEW_GET_FUN(__glewWeightuivARB) +#define glWeightusvARB GLEW_GET_FUN(__glewWeightusvARB) + +#define GLEW_ARB_vertex_blend GLEW_GET_VAR(__GLEW_ARB_vertex_blend) + +#endif /* GL_ARB_vertex_blend */ + +/* ---------------------- GL_ARB_vertex_buffer_object ---------------------- */ + +#ifndef GL_ARB_vertex_buffer_object +#define GL_ARB_vertex_buffer_object 1 + +#define GL_BUFFER_SIZE_ARB 0x8764 +#define GL_BUFFER_USAGE_ARB 0x8765 +#define GL_ARRAY_BUFFER_ARB 0x8892 +#define GL_ELEMENT_ARRAY_BUFFER_ARB 0x8893 +#define GL_ARRAY_BUFFER_BINDING_ARB 0x8894 +#define GL_ELEMENT_ARRAY_BUFFER_BINDING_ARB 0x8895 +#define GL_VERTEX_ARRAY_BUFFER_BINDING_ARB 0x8896 +#define GL_NORMAL_ARRAY_BUFFER_BINDING_ARB 0x8897 +#define GL_COLOR_ARRAY_BUFFER_BINDING_ARB 0x8898 +#define GL_INDEX_ARRAY_BUFFER_BINDING_ARB 0x8899 +#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING_ARB 0x889A +#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING_ARB 0x889B +#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING_ARB 0x889C +#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING_ARB 0x889D +#define GL_WEIGHT_ARRAY_BUFFER_BINDING_ARB 0x889E +#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING_ARB 0x889F +#define GL_READ_ONLY_ARB 0x88B8 +#define GL_WRITE_ONLY_ARB 0x88B9 +#define GL_READ_WRITE_ARB 0x88BA +#define GL_BUFFER_ACCESS_ARB 0x88BB +#define GL_BUFFER_MAPPED_ARB 0x88BC +#define GL_BUFFER_MAP_POINTER_ARB 0x88BD +#define GL_STREAM_DRAW_ARB 0x88E0 +#define GL_STREAM_READ_ARB 0x88E1 +#define GL_STREAM_COPY_ARB 0x88E2 +#define GL_STATIC_DRAW_ARB 0x88E4 +#define GL_STATIC_READ_ARB 0x88E5 +#define GL_STATIC_COPY_ARB 0x88E6 +#define GL_DYNAMIC_DRAW_ARB 0x88E8 +#define GL_DYNAMIC_READ_ARB 0x88E9 +#define GL_DYNAMIC_COPY_ARB 0x88EA + +typedef ptrdiff_t GLsizeiptrARB; +typedef ptrdiff_t GLintptrARB; + +typedef void (GLAPIENTRY * PFNGLBINDBUFFERARBPROC) (GLenum target, GLuint buffer); +typedef void (GLAPIENTRY * PFNGLBUFFERDATAARBPROC) (GLenum target, GLsizeiptrARB size, const GLvoid* data, GLenum usage); +typedef void (GLAPIENTRY * PFNGLBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, const GLvoid* data); +typedef void (GLAPIENTRY * PFNGLDELETEBUFFERSARBPROC) (GLsizei n, const GLuint* buffers); +typedef void (GLAPIENTRY * PFNGLGENBUFFERSARBPROC) (GLsizei n, GLuint* buffers); +typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERIVARBPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETBUFFERPOINTERVARBPROC) (GLenum target, GLenum pname, GLvoid** params); +typedef void (GLAPIENTRY * PFNGLGETBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, GLvoid* data); +typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERARBPROC) (GLuint buffer); +typedef GLvoid * (GLAPIENTRY * PFNGLMAPBUFFERARBPROC) (GLenum target, GLenum access); +typedef GLboolean (GLAPIENTRY * PFNGLUNMAPBUFFERARBPROC) (GLenum target); + +#define glBindBufferARB GLEW_GET_FUN(__glewBindBufferARB) +#define glBufferDataARB GLEW_GET_FUN(__glewBufferDataARB) +#define glBufferSubDataARB GLEW_GET_FUN(__glewBufferSubDataARB) +#define glDeleteBuffersARB GLEW_GET_FUN(__glewDeleteBuffersARB) +#define glGenBuffersARB GLEW_GET_FUN(__glewGenBuffersARB) +#define glGetBufferParameterivARB GLEW_GET_FUN(__glewGetBufferParameterivARB) +#define glGetBufferPointervARB GLEW_GET_FUN(__glewGetBufferPointervARB) +#define glGetBufferSubDataARB GLEW_GET_FUN(__glewGetBufferSubDataARB) +#define glIsBufferARB GLEW_GET_FUN(__glewIsBufferARB) +#define glMapBufferARB GLEW_GET_FUN(__glewMapBufferARB) +#define glUnmapBufferARB GLEW_GET_FUN(__glewUnmapBufferARB) + +#define GLEW_ARB_vertex_buffer_object GLEW_GET_VAR(__GLEW_ARB_vertex_buffer_object) + +#endif /* GL_ARB_vertex_buffer_object */ + +/* ------------------------- GL_ARB_vertex_program ------------------------- */ + +#ifndef GL_ARB_vertex_program +#define GL_ARB_vertex_program 1 + +#define GL_COLOR_SUM_ARB 0x8458 +#define GL_VERTEX_PROGRAM_ARB 0x8620 +#define GL_VERTEX_ATTRIB_ARRAY_ENABLED_ARB 0x8622 +#define GL_VERTEX_ATTRIB_ARRAY_SIZE_ARB 0x8623 +#define GL_VERTEX_ATTRIB_ARRAY_STRIDE_ARB 0x8624 +#define GL_VERTEX_ATTRIB_ARRAY_TYPE_ARB 0x8625 +#define GL_CURRENT_VERTEX_ATTRIB_ARB 0x8626 +#define GL_PROGRAM_LENGTH_ARB 0x8627 +#define GL_PROGRAM_STRING_ARB 0x8628 +#define GL_MAX_PROGRAM_MATRIX_STACK_DEPTH_ARB 0x862E +#define GL_MAX_PROGRAM_MATRICES_ARB 0x862F +#define GL_CURRENT_MATRIX_STACK_DEPTH_ARB 0x8640 +#define GL_CURRENT_MATRIX_ARB 0x8641 +#define GL_VERTEX_PROGRAM_POINT_SIZE_ARB 0x8642 +#define GL_VERTEX_PROGRAM_TWO_SIDE_ARB 0x8643 +#define GL_VERTEX_ATTRIB_ARRAY_POINTER_ARB 0x8645 +#define GL_PROGRAM_ERROR_POSITION_ARB 0x864B +#define GL_PROGRAM_BINDING_ARB 0x8677 +#define GL_MAX_VERTEX_ATTRIBS_ARB 0x8869 +#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED_ARB 0x886A +#define GL_PROGRAM_ERROR_STRING_ARB 0x8874 +#define GL_PROGRAM_FORMAT_ASCII_ARB 0x8875 +#define GL_PROGRAM_FORMAT_ARB 0x8876 +#define GL_PROGRAM_INSTRUCTIONS_ARB 0x88A0 +#define GL_MAX_PROGRAM_INSTRUCTIONS_ARB 0x88A1 +#define GL_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A2 +#define GL_MAX_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A3 +#define GL_PROGRAM_TEMPORARIES_ARB 0x88A4 +#define GL_MAX_PROGRAM_TEMPORARIES_ARB 0x88A5 +#define GL_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A6 +#define GL_MAX_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A7 +#define GL_PROGRAM_PARAMETERS_ARB 0x88A8 +#define GL_MAX_PROGRAM_PARAMETERS_ARB 0x88A9 +#define GL_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AA +#define GL_MAX_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AB +#define GL_PROGRAM_ATTRIBS_ARB 0x88AC +#define GL_MAX_PROGRAM_ATTRIBS_ARB 0x88AD +#define GL_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AE +#define GL_MAX_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AF +#define GL_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B0 +#define GL_MAX_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B1 +#define GL_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B2 +#define GL_MAX_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B3 +#define GL_MAX_PROGRAM_LOCAL_PARAMETERS_ARB 0x88B4 +#define GL_MAX_PROGRAM_ENV_PARAMETERS_ARB 0x88B5 +#define GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB 0x88B6 +#define GL_TRANSPOSE_CURRENT_MATRIX_ARB 0x88B7 +#define GL_MATRIX0_ARB 0x88C0 +#define GL_MATRIX1_ARB 0x88C1 +#define GL_MATRIX2_ARB 0x88C2 +#define GL_MATRIX3_ARB 0x88C3 +#define GL_MATRIX4_ARB 0x88C4 +#define GL_MATRIX5_ARB 0x88C5 +#define GL_MATRIX6_ARB 0x88C6 +#define GL_MATRIX7_ARB 0x88C7 +#define GL_MATRIX8_ARB 0x88C8 +#define GL_MATRIX9_ARB 0x88C9 +#define GL_MATRIX10_ARB 0x88CA +#define GL_MATRIX11_ARB 0x88CB +#define GL_MATRIX12_ARB 0x88CC +#define GL_MATRIX13_ARB 0x88CD +#define GL_MATRIX14_ARB 0x88CE +#define GL_MATRIX15_ARB 0x88CF +#define GL_MATRIX16_ARB 0x88D0 +#define GL_MATRIX17_ARB 0x88D1 +#define GL_MATRIX18_ARB 0x88D2 +#define GL_MATRIX19_ARB 0x88D3 +#define GL_MATRIX20_ARB 0x88D4 +#define GL_MATRIX21_ARB 0x88D5 +#define GL_MATRIX22_ARB 0x88D6 +#define GL_MATRIX23_ARB 0x88D7 +#define GL_MATRIX24_ARB 0x88D8 +#define GL_MATRIX25_ARB 0x88D9 +#define GL_MATRIX26_ARB 0x88DA +#define GL_MATRIX27_ARB 0x88DB +#define GL_MATRIX28_ARB 0x88DC +#define GL_MATRIX29_ARB 0x88DD +#define GL_MATRIX30_ARB 0x88DE +#define GL_MATRIX31_ARB 0x88DF + +typedef void (GLAPIENTRY * PFNGLBINDPROGRAMARBPROC) (GLenum target, GLuint program); +typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMSARBPROC) (GLsizei n, const GLuint* programs); +typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); +typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); +typedef void (GLAPIENTRY * PFNGLGENPROGRAMSARBPROC) (GLsizei n, GLuint* programs); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMENVPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMENVPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTRINGARBPROC) (GLenum target, GLenum pname, void* string); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVARBPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVARBPROC) (GLuint index, GLenum pname, GLvoid** pointer); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVARBPROC) (GLuint index, GLenum pname, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVARBPROC) (GLuint index, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVARBPROC) (GLuint index, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMARBPROC) (GLuint program); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMSTRINGARBPROC) (GLenum target, GLenum format, GLsizei len, const void* string); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DARBPROC) (GLuint index, GLdouble x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVARBPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FARBPROC) (GLuint index, GLfloat x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVARBPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SARBPROC) (GLuint index, GLshort x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVARBPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DARBPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVARBPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FARBPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVARBPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SARBPROC) (GLuint index, GLshort x, GLshort y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVARBPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVARBPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVARBPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVARBPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NBVARBPROC) (GLuint index, const GLbyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NIVARBPROC) (GLuint index, const GLint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NSVARBPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBARBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBVARBPROC) (GLuint index, const GLubyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUIVARBPROC) (GLuint index, const GLuint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUSVARBPROC) (GLuint index, const GLushort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4BVARBPROC) (GLuint index, const GLbyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVARBPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVARBPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4IVARBPROC) (GLuint index, const GLint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVARBPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVARBPROC) (GLuint index, const GLubyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UIVARBPROC) (GLuint index, const GLuint* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4USVARBPROC) (GLuint index, const GLushort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERARBPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void* pointer); + +#define glBindProgramARB GLEW_GET_FUN(__glewBindProgramARB) +#define glDeleteProgramsARB GLEW_GET_FUN(__glewDeleteProgramsARB) +#define glDisableVertexAttribArrayARB GLEW_GET_FUN(__glewDisableVertexAttribArrayARB) +#define glEnableVertexAttribArrayARB GLEW_GET_FUN(__glewEnableVertexAttribArrayARB) +#define glGenProgramsARB GLEW_GET_FUN(__glewGenProgramsARB) +#define glGetProgramEnvParameterdvARB GLEW_GET_FUN(__glewGetProgramEnvParameterdvARB) +#define glGetProgramEnvParameterfvARB GLEW_GET_FUN(__glewGetProgramEnvParameterfvARB) +#define glGetProgramLocalParameterdvARB GLEW_GET_FUN(__glewGetProgramLocalParameterdvARB) +#define glGetProgramLocalParameterfvARB GLEW_GET_FUN(__glewGetProgramLocalParameterfvARB) +#define glGetProgramStringARB GLEW_GET_FUN(__glewGetProgramStringARB) +#define glGetProgramivARB GLEW_GET_FUN(__glewGetProgramivARB) +#define glGetVertexAttribPointervARB GLEW_GET_FUN(__glewGetVertexAttribPointervARB) +#define glGetVertexAttribdvARB GLEW_GET_FUN(__glewGetVertexAttribdvARB) +#define glGetVertexAttribfvARB GLEW_GET_FUN(__glewGetVertexAttribfvARB) +#define glGetVertexAttribivARB GLEW_GET_FUN(__glewGetVertexAttribivARB) +#define glIsProgramARB GLEW_GET_FUN(__glewIsProgramARB) +#define glProgramEnvParameter4dARB GLEW_GET_FUN(__glewProgramEnvParameter4dARB) +#define glProgramEnvParameter4dvARB GLEW_GET_FUN(__glewProgramEnvParameter4dvARB) +#define glProgramEnvParameter4fARB GLEW_GET_FUN(__glewProgramEnvParameter4fARB) +#define glProgramEnvParameter4fvARB GLEW_GET_FUN(__glewProgramEnvParameter4fvARB) +#define glProgramLocalParameter4dARB GLEW_GET_FUN(__glewProgramLocalParameter4dARB) +#define glProgramLocalParameter4dvARB GLEW_GET_FUN(__glewProgramLocalParameter4dvARB) +#define glProgramLocalParameter4fARB GLEW_GET_FUN(__glewProgramLocalParameter4fARB) +#define glProgramLocalParameter4fvARB GLEW_GET_FUN(__glewProgramLocalParameter4fvARB) +#define glProgramStringARB GLEW_GET_FUN(__glewProgramStringARB) +#define glVertexAttrib1dARB GLEW_GET_FUN(__glewVertexAttrib1dARB) +#define glVertexAttrib1dvARB GLEW_GET_FUN(__glewVertexAttrib1dvARB) +#define glVertexAttrib1fARB GLEW_GET_FUN(__glewVertexAttrib1fARB) +#define glVertexAttrib1fvARB GLEW_GET_FUN(__glewVertexAttrib1fvARB) +#define glVertexAttrib1sARB GLEW_GET_FUN(__glewVertexAttrib1sARB) +#define glVertexAttrib1svARB GLEW_GET_FUN(__glewVertexAttrib1svARB) +#define glVertexAttrib2dARB GLEW_GET_FUN(__glewVertexAttrib2dARB) +#define glVertexAttrib2dvARB GLEW_GET_FUN(__glewVertexAttrib2dvARB) +#define glVertexAttrib2fARB GLEW_GET_FUN(__glewVertexAttrib2fARB) +#define glVertexAttrib2fvARB GLEW_GET_FUN(__glewVertexAttrib2fvARB) +#define glVertexAttrib2sARB GLEW_GET_FUN(__glewVertexAttrib2sARB) +#define glVertexAttrib2svARB GLEW_GET_FUN(__glewVertexAttrib2svARB) +#define glVertexAttrib3dARB GLEW_GET_FUN(__glewVertexAttrib3dARB) +#define glVertexAttrib3dvARB GLEW_GET_FUN(__glewVertexAttrib3dvARB) +#define glVertexAttrib3fARB GLEW_GET_FUN(__glewVertexAttrib3fARB) +#define glVertexAttrib3fvARB GLEW_GET_FUN(__glewVertexAttrib3fvARB) +#define glVertexAttrib3sARB GLEW_GET_FUN(__glewVertexAttrib3sARB) +#define glVertexAttrib3svARB GLEW_GET_FUN(__glewVertexAttrib3svARB) +#define glVertexAttrib4NbvARB GLEW_GET_FUN(__glewVertexAttrib4NbvARB) +#define glVertexAttrib4NivARB GLEW_GET_FUN(__glewVertexAttrib4NivARB) +#define glVertexAttrib4NsvARB GLEW_GET_FUN(__glewVertexAttrib4NsvARB) +#define glVertexAttrib4NubARB GLEW_GET_FUN(__glewVertexAttrib4NubARB) +#define glVertexAttrib4NubvARB GLEW_GET_FUN(__glewVertexAttrib4NubvARB) +#define glVertexAttrib4NuivARB GLEW_GET_FUN(__glewVertexAttrib4NuivARB) +#define glVertexAttrib4NusvARB GLEW_GET_FUN(__glewVertexAttrib4NusvARB) +#define glVertexAttrib4bvARB GLEW_GET_FUN(__glewVertexAttrib4bvARB) +#define glVertexAttrib4dARB GLEW_GET_FUN(__glewVertexAttrib4dARB) +#define glVertexAttrib4dvARB GLEW_GET_FUN(__glewVertexAttrib4dvARB) +#define glVertexAttrib4fARB GLEW_GET_FUN(__glewVertexAttrib4fARB) +#define glVertexAttrib4fvARB GLEW_GET_FUN(__glewVertexAttrib4fvARB) +#define glVertexAttrib4ivARB GLEW_GET_FUN(__glewVertexAttrib4ivARB) +#define glVertexAttrib4sARB GLEW_GET_FUN(__glewVertexAttrib4sARB) +#define glVertexAttrib4svARB GLEW_GET_FUN(__glewVertexAttrib4svARB) +#define glVertexAttrib4ubvARB GLEW_GET_FUN(__glewVertexAttrib4ubvARB) +#define glVertexAttrib4uivARB GLEW_GET_FUN(__glewVertexAttrib4uivARB) +#define glVertexAttrib4usvARB GLEW_GET_FUN(__glewVertexAttrib4usvARB) +#define glVertexAttribPointerARB GLEW_GET_FUN(__glewVertexAttribPointerARB) + +#define GLEW_ARB_vertex_program GLEW_GET_VAR(__GLEW_ARB_vertex_program) + +#endif /* GL_ARB_vertex_program */ + +/* -------------------------- GL_ARB_vertex_shader ------------------------- */ + +#ifndef GL_ARB_vertex_shader +#define GL_ARB_vertex_shader 1 + +#define GL_VERTEX_SHADER_ARB 0x8B31 +#define GL_MAX_VERTEX_UNIFORM_COMPONENTS_ARB 0x8B4A +#define GL_MAX_VARYING_FLOATS_ARB 0x8B4B +#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C +#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS_ARB 0x8B4D +#define GL_OBJECT_ACTIVE_ATTRIBUTES_ARB 0x8B89 +#define GL_OBJECT_ACTIVE_ATTRIBUTE_MAX_LENGTH_ARB 0x8B8A + +typedef void (GLAPIENTRY * PFNGLBINDATTRIBLOCATIONARBPROC) (GLhandleARB programObj, GLuint index, const GLcharARB* name); +typedef void (GLAPIENTRY * PFNGLGETACTIVEATTRIBARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name); +typedef GLint (GLAPIENTRY * PFNGLGETATTRIBLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB* name); + +#define glBindAttribLocationARB GLEW_GET_FUN(__glewBindAttribLocationARB) +#define glGetActiveAttribARB GLEW_GET_FUN(__glewGetActiveAttribARB) +#define glGetAttribLocationARB GLEW_GET_FUN(__glewGetAttribLocationARB) + +#define GLEW_ARB_vertex_shader GLEW_GET_VAR(__GLEW_ARB_vertex_shader) + +#endif /* GL_ARB_vertex_shader */ + +/* ------------------- GL_ARB_vertex_type_2_10_10_10_rev ------------------- */ + +#ifndef GL_ARB_vertex_type_2_10_10_10_rev +#define GL_ARB_vertex_type_2_10_10_10_rev 1 + +#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 +#define GL_INT_2_10_10_10_REV 0x8D9F + +typedef void (GLAPIENTRY * PFNGLCOLORP3UIPROC) (GLenum type, GLuint color); +typedef void (GLAPIENTRY * PFNGLCOLORP3UIVPROC) (GLenum type, const GLuint* color); +typedef void (GLAPIENTRY * PFNGLCOLORP4UIPROC) (GLenum type, GLuint color); +typedef void (GLAPIENTRY * PFNGLCOLORP4UIVPROC) (GLenum type, const GLuint* color); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP1UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP1UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP2UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP2UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP3UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP3UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP4UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP4UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLNORMALP3UIPROC) (GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLNORMALP3UIVPROC) (GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORP3UIPROC) (GLenum type, GLuint color); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORP3UIVPROC) (GLenum type, const GLuint* color); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP1UIPROC) (GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP1UIVPROC) (GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP2UIPROC) (GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP2UIVPROC) (GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP3UIPROC) (GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP3UIVPROC) (GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP4UIPROC) (GLenum type, GLuint coords); +typedef void (GLAPIENTRY * PFNGLTEXCOORDP4UIVPROC) (GLenum type, const GLuint* coords); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP1UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP1UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP2UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP2UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP3UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP3UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP4UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP4UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLVERTEXP2UIPROC) (GLenum type, GLuint value); +typedef void (GLAPIENTRY * PFNGLVERTEXP2UIVPROC) (GLenum type, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLVERTEXP3UIPROC) (GLenum type, GLuint value); +typedef void (GLAPIENTRY * PFNGLVERTEXP3UIVPROC) (GLenum type, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLVERTEXP4UIPROC) (GLenum type, GLuint value); +typedef void (GLAPIENTRY * PFNGLVERTEXP4UIVPROC) (GLenum type, const GLuint* value); + +#define glColorP3ui GLEW_GET_FUN(__glewColorP3ui) +#define glColorP3uiv GLEW_GET_FUN(__glewColorP3uiv) +#define glColorP4ui GLEW_GET_FUN(__glewColorP4ui) +#define glColorP4uiv GLEW_GET_FUN(__glewColorP4uiv) +#define glMultiTexCoordP1ui GLEW_GET_FUN(__glewMultiTexCoordP1ui) +#define glMultiTexCoordP1uiv GLEW_GET_FUN(__glewMultiTexCoordP1uiv) +#define glMultiTexCoordP2ui GLEW_GET_FUN(__glewMultiTexCoordP2ui) +#define glMultiTexCoordP2uiv GLEW_GET_FUN(__glewMultiTexCoordP2uiv) +#define glMultiTexCoordP3ui GLEW_GET_FUN(__glewMultiTexCoordP3ui) +#define glMultiTexCoordP3uiv GLEW_GET_FUN(__glewMultiTexCoordP3uiv) +#define glMultiTexCoordP4ui GLEW_GET_FUN(__glewMultiTexCoordP4ui) +#define glMultiTexCoordP4uiv GLEW_GET_FUN(__glewMultiTexCoordP4uiv) +#define glNormalP3ui GLEW_GET_FUN(__glewNormalP3ui) +#define glNormalP3uiv GLEW_GET_FUN(__glewNormalP3uiv) +#define glSecondaryColorP3ui GLEW_GET_FUN(__glewSecondaryColorP3ui) +#define glSecondaryColorP3uiv GLEW_GET_FUN(__glewSecondaryColorP3uiv) +#define glTexCoordP1ui GLEW_GET_FUN(__glewTexCoordP1ui) +#define glTexCoordP1uiv GLEW_GET_FUN(__glewTexCoordP1uiv) +#define glTexCoordP2ui GLEW_GET_FUN(__glewTexCoordP2ui) +#define glTexCoordP2uiv GLEW_GET_FUN(__glewTexCoordP2uiv) +#define glTexCoordP3ui GLEW_GET_FUN(__glewTexCoordP3ui) +#define glTexCoordP3uiv GLEW_GET_FUN(__glewTexCoordP3uiv) +#define glTexCoordP4ui GLEW_GET_FUN(__glewTexCoordP4ui) +#define glTexCoordP4uiv GLEW_GET_FUN(__glewTexCoordP4uiv) +#define glVertexAttribP1ui GLEW_GET_FUN(__glewVertexAttribP1ui) +#define glVertexAttribP1uiv GLEW_GET_FUN(__glewVertexAttribP1uiv) +#define glVertexAttribP2ui GLEW_GET_FUN(__glewVertexAttribP2ui) +#define glVertexAttribP2uiv GLEW_GET_FUN(__glewVertexAttribP2uiv) +#define glVertexAttribP3ui GLEW_GET_FUN(__glewVertexAttribP3ui) +#define glVertexAttribP3uiv GLEW_GET_FUN(__glewVertexAttribP3uiv) +#define glVertexAttribP4ui GLEW_GET_FUN(__glewVertexAttribP4ui) +#define glVertexAttribP4uiv GLEW_GET_FUN(__glewVertexAttribP4uiv) +#define glVertexP2ui GLEW_GET_FUN(__glewVertexP2ui) +#define glVertexP2uiv GLEW_GET_FUN(__glewVertexP2uiv) +#define glVertexP3ui GLEW_GET_FUN(__glewVertexP3ui) +#define glVertexP3uiv GLEW_GET_FUN(__glewVertexP3uiv) +#define glVertexP4ui GLEW_GET_FUN(__glewVertexP4ui) +#define glVertexP4uiv GLEW_GET_FUN(__glewVertexP4uiv) + +#define GLEW_ARB_vertex_type_2_10_10_10_rev GLEW_GET_VAR(__GLEW_ARB_vertex_type_2_10_10_10_rev) + +#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ + +/* --------------------------- GL_ARB_window_pos --------------------------- */ + +#ifndef GL_ARB_window_pos +#define GL_ARB_window_pos 1 + +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DARBPROC) (GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVARBPROC) (const GLdouble* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FARBPROC) (GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVARBPROC) (const GLfloat* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IARBPROC) (GLint x, GLint y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVARBPROC) (const GLint* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SARBPROC) (GLshort x, GLshort y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVARBPROC) (const GLshort* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DARBPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVARBPROC) (const GLdouble* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FARBPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVARBPROC) (const GLfloat* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IARBPROC) (GLint x, GLint y, GLint z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVARBPROC) (const GLint* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SARBPROC) (GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVARBPROC) (const GLshort* p); + +#define glWindowPos2dARB GLEW_GET_FUN(__glewWindowPos2dARB) +#define glWindowPos2dvARB GLEW_GET_FUN(__glewWindowPos2dvARB) +#define glWindowPos2fARB GLEW_GET_FUN(__glewWindowPos2fARB) +#define glWindowPos2fvARB GLEW_GET_FUN(__glewWindowPos2fvARB) +#define glWindowPos2iARB GLEW_GET_FUN(__glewWindowPos2iARB) +#define glWindowPos2ivARB GLEW_GET_FUN(__glewWindowPos2ivARB) +#define glWindowPos2sARB GLEW_GET_FUN(__glewWindowPos2sARB) +#define glWindowPos2svARB GLEW_GET_FUN(__glewWindowPos2svARB) +#define glWindowPos3dARB GLEW_GET_FUN(__glewWindowPos3dARB) +#define glWindowPos3dvARB GLEW_GET_FUN(__glewWindowPos3dvARB) +#define glWindowPos3fARB GLEW_GET_FUN(__glewWindowPos3fARB) +#define glWindowPos3fvARB GLEW_GET_FUN(__glewWindowPos3fvARB) +#define glWindowPos3iARB GLEW_GET_FUN(__glewWindowPos3iARB) +#define glWindowPos3ivARB GLEW_GET_FUN(__glewWindowPos3ivARB) +#define glWindowPos3sARB GLEW_GET_FUN(__glewWindowPos3sARB) +#define glWindowPos3svARB GLEW_GET_FUN(__glewWindowPos3svARB) + +#define GLEW_ARB_window_pos GLEW_GET_VAR(__GLEW_ARB_window_pos) + +#endif /* GL_ARB_window_pos */ + +/* ------------------------- GL_ATIX_point_sprites ------------------------- */ + +#ifndef GL_ATIX_point_sprites +#define GL_ATIX_point_sprites 1 + +#define GL_TEXTURE_POINT_MODE_ATIX 0x60B0 +#define GL_TEXTURE_POINT_ONE_COORD_ATIX 0x60B1 +#define GL_TEXTURE_POINT_SPRITE_ATIX 0x60B2 +#define GL_POINT_SPRITE_CULL_MODE_ATIX 0x60B3 +#define GL_POINT_SPRITE_CULL_CENTER_ATIX 0x60B4 +#define GL_POINT_SPRITE_CULL_CLIP_ATIX 0x60B5 + +#define GLEW_ATIX_point_sprites GLEW_GET_VAR(__GLEW_ATIX_point_sprites) + +#endif /* GL_ATIX_point_sprites */ + +/* ---------------------- GL_ATIX_texture_env_combine3 --------------------- */ + +#ifndef GL_ATIX_texture_env_combine3 +#define GL_ATIX_texture_env_combine3 1 + +#define GL_MODULATE_ADD_ATIX 0x8744 +#define GL_MODULATE_SIGNED_ADD_ATIX 0x8745 +#define GL_MODULATE_SUBTRACT_ATIX 0x8746 + +#define GLEW_ATIX_texture_env_combine3 GLEW_GET_VAR(__GLEW_ATIX_texture_env_combine3) + +#endif /* GL_ATIX_texture_env_combine3 */ + +/* ----------------------- GL_ATIX_texture_env_route ----------------------- */ + +#ifndef GL_ATIX_texture_env_route +#define GL_ATIX_texture_env_route 1 + +#define GL_SECONDARY_COLOR_ATIX 0x8747 +#define GL_TEXTURE_OUTPUT_RGB_ATIX 0x8748 +#define GL_TEXTURE_OUTPUT_ALPHA_ATIX 0x8749 + +#define GLEW_ATIX_texture_env_route GLEW_GET_VAR(__GLEW_ATIX_texture_env_route) + +#endif /* GL_ATIX_texture_env_route */ + +/* ---------------- GL_ATIX_vertex_shader_output_point_size ---------------- */ + +#ifndef GL_ATIX_vertex_shader_output_point_size +#define GL_ATIX_vertex_shader_output_point_size 1 + +#define GL_OUTPUT_POINT_SIZE_ATIX 0x610E + +#define GLEW_ATIX_vertex_shader_output_point_size GLEW_GET_VAR(__GLEW_ATIX_vertex_shader_output_point_size) + +#endif /* GL_ATIX_vertex_shader_output_point_size */ + +/* -------------------------- GL_ATI_draw_buffers -------------------------- */ + +#ifndef GL_ATI_draw_buffers +#define GL_ATI_draw_buffers 1 + +#define GL_MAX_DRAW_BUFFERS_ATI 0x8824 +#define GL_DRAW_BUFFER0_ATI 0x8825 +#define GL_DRAW_BUFFER1_ATI 0x8826 +#define GL_DRAW_BUFFER2_ATI 0x8827 +#define GL_DRAW_BUFFER3_ATI 0x8828 +#define GL_DRAW_BUFFER4_ATI 0x8829 +#define GL_DRAW_BUFFER5_ATI 0x882A +#define GL_DRAW_BUFFER6_ATI 0x882B +#define GL_DRAW_BUFFER7_ATI 0x882C +#define GL_DRAW_BUFFER8_ATI 0x882D +#define GL_DRAW_BUFFER9_ATI 0x882E +#define GL_DRAW_BUFFER10_ATI 0x882F +#define GL_DRAW_BUFFER11_ATI 0x8830 +#define GL_DRAW_BUFFER12_ATI 0x8831 +#define GL_DRAW_BUFFER13_ATI 0x8832 +#define GL_DRAW_BUFFER14_ATI 0x8833 +#define GL_DRAW_BUFFER15_ATI 0x8834 + +typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSATIPROC) (GLsizei n, const GLenum* bufs); + +#define glDrawBuffersATI GLEW_GET_FUN(__glewDrawBuffersATI) + +#define GLEW_ATI_draw_buffers GLEW_GET_VAR(__GLEW_ATI_draw_buffers) + +#endif /* GL_ATI_draw_buffers */ + +/* -------------------------- GL_ATI_element_array ------------------------- */ + +#ifndef GL_ATI_element_array +#define GL_ATI_element_array 1 + +#define GL_ELEMENT_ARRAY_ATI 0x8768 +#define GL_ELEMENT_ARRAY_TYPE_ATI 0x8769 +#define GL_ELEMENT_ARRAY_POINTER_ATI 0x876A + +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTARRAYATIPROC) (GLenum mode, GLsizei count); +typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTARRAYATIPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count); +typedef void (GLAPIENTRY * PFNGLELEMENTPOINTERATIPROC) (GLenum type, const void* pointer); + +#define glDrawElementArrayATI GLEW_GET_FUN(__glewDrawElementArrayATI) +#define glDrawRangeElementArrayATI GLEW_GET_FUN(__glewDrawRangeElementArrayATI) +#define glElementPointerATI GLEW_GET_FUN(__glewElementPointerATI) + +#define GLEW_ATI_element_array GLEW_GET_VAR(__GLEW_ATI_element_array) + +#endif /* GL_ATI_element_array */ + +/* ------------------------- GL_ATI_envmap_bumpmap ------------------------- */ + +#ifndef GL_ATI_envmap_bumpmap +#define GL_ATI_envmap_bumpmap 1 + +#define GL_BUMP_ROT_MATRIX_ATI 0x8775 +#define GL_BUMP_ROT_MATRIX_SIZE_ATI 0x8776 +#define GL_BUMP_NUM_TEX_UNITS_ATI 0x8777 +#define GL_BUMP_TEX_UNITS_ATI 0x8778 +#define GL_DUDV_ATI 0x8779 +#define GL_DU8DV8_ATI 0x877A +#define GL_BUMP_ENVMAP_ATI 0x877B +#define GL_BUMP_TARGET_ATI 0x877C + +typedef void (GLAPIENTRY * PFNGLGETTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); +typedef void (GLAPIENTRY * PFNGLGETTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); +typedef void (GLAPIENTRY * PFNGLTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); +typedef void (GLAPIENTRY * PFNGLTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); + +#define glGetTexBumpParameterfvATI GLEW_GET_FUN(__glewGetTexBumpParameterfvATI) +#define glGetTexBumpParameterivATI GLEW_GET_FUN(__glewGetTexBumpParameterivATI) +#define glTexBumpParameterfvATI GLEW_GET_FUN(__glewTexBumpParameterfvATI) +#define glTexBumpParameterivATI GLEW_GET_FUN(__glewTexBumpParameterivATI) + +#define GLEW_ATI_envmap_bumpmap GLEW_GET_VAR(__GLEW_ATI_envmap_bumpmap) + +#endif /* GL_ATI_envmap_bumpmap */ + +/* ------------------------- GL_ATI_fragment_shader ------------------------ */ + +#ifndef GL_ATI_fragment_shader +#define GL_ATI_fragment_shader 1 + +#define GL_RED_BIT_ATI 0x00000001 +#define GL_2X_BIT_ATI 0x00000001 +#define GL_4X_BIT_ATI 0x00000002 +#define GL_GREEN_BIT_ATI 0x00000002 +#define GL_COMP_BIT_ATI 0x00000002 +#define GL_BLUE_BIT_ATI 0x00000004 +#define GL_8X_BIT_ATI 0x00000004 +#define GL_NEGATE_BIT_ATI 0x00000004 +#define GL_BIAS_BIT_ATI 0x00000008 +#define GL_HALF_BIT_ATI 0x00000008 +#define GL_QUARTER_BIT_ATI 0x00000010 +#define GL_EIGHTH_BIT_ATI 0x00000020 +#define GL_SATURATE_BIT_ATI 0x00000040 +#define GL_FRAGMENT_SHADER_ATI 0x8920 +#define GL_REG_0_ATI 0x8921 +#define GL_REG_1_ATI 0x8922 +#define GL_REG_2_ATI 0x8923 +#define GL_REG_3_ATI 0x8924 +#define GL_REG_4_ATI 0x8925 +#define GL_REG_5_ATI 0x8926 +#define GL_CON_0_ATI 0x8941 +#define GL_CON_1_ATI 0x8942 +#define GL_CON_2_ATI 0x8943 +#define GL_CON_3_ATI 0x8944 +#define GL_CON_4_ATI 0x8945 +#define GL_CON_5_ATI 0x8946 +#define GL_CON_6_ATI 0x8947 +#define GL_CON_7_ATI 0x8948 +#define GL_MOV_ATI 0x8961 +#define GL_ADD_ATI 0x8963 +#define GL_MUL_ATI 0x8964 +#define GL_SUB_ATI 0x8965 +#define GL_DOT3_ATI 0x8966 +#define GL_DOT4_ATI 0x8967 +#define GL_MAD_ATI 0x8968 +#define GL_LERP_ATI 0x8969 +#define GL_CND_ATI 0x896A +#define GL_CND0_ATI 0x896B +#define GL_DOT2_ADD_ATI 0x896C +#define GL_SECONDARY_INTERPOLATOR_ATI 0x896D +#define GL_NUM_FRAGMENT_REGISTERS_ATI 0x896E +#define GL_NUM_FRAGMENT_CONSTANTS_ATI 0x896F +#define GL_NUM_PASSES_ATI 0x8970 +#define GL_NUM_INSTRUCTIONS_PER_PASS_ATI 0x8971 +#define GL_NUM_INSTRUCTIONS_TOTAL_ATI 0x8972 +#define GL_NUM_INPUT_INTERPOLATOR_COMPONENTS_ATI 0x8973 +#define GL_NUM_LOOPBACK_COMPONENTS_ATI 0x8974 +#define GL_COLOR_ALPHA_PAIRING_ATI 0x8975 +#define GL_SWIZZLE_STR_ATI 0x8976 +#define GL_SWIZZLE_STQ_ATI 0x8977 +#define GL_SWIZZLE_STR_DR_ATI 0x8978 +#define GL_SWIZZLE_STQ_DQ_ATI 0x8979 +#define GL_SWIZZLE_STRQ_ATI 0x897A +#define GL_SWIZZLE_STRQ_DQ_ATI 0x897B + +typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); +typedef void (GLAPIENTRY * PFNGLBEGINFRAGMENTSHADERATIPROC) (void); +typedef void (GLAPIENTRY * PFNGLBINDFRAGMENTSHADERATIPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); +typedef void (GLAPIENTRY * PFNGLDELETEFRAGMENTSHADERATIPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLENDFRAGMENTSHADERATIPROC) (void); +typedef GLuint (GLAPIENTRY * PFNGLGENFRAGMENTSHADERSATIPROC) (GLuint range); +typedef void (GLAPIENTRY * PFNGLPASSTEXCOORDATIPROC) (GLuint dst, GLuint coord, GLenum swizzle); +typedef void (GLAPIENTRY * PFNGLSAMPLEMAPATIPROC) (GLuint dst, GLuint interp, GLenum swizzle); +typedef void (GLAPIENTRY * PFNGLSETFRAGMENTSHADERCONSTANTATIPROC) (GLuint dst, const GLfloat* value); + +#define glAlphaFragmentOp1ATI GLEW_GET_FUN(__glewAlphaFragmentOp1ATI) +#define glAlphaFragmentOp2ATI GLEW_GET_FUN(__glewAlphaFragmentOp2ATI) +#define glAlphaFragmentOp3ATI GLEW_GET_FUN(__glewAlphaFragmentOp3ATI) +#define glBeginFragmentShaderATI GLEW_GET_FUN(__glewBeginFragmentShaderATI) +#define glBindFragmentShaderATI GLEW_GET_FUN(__glewBindFragmentShaderATI) +#define glColorFragmentOp1ATI GLEW_GET_FUN(__glewColorFragmentOp1ATI) +#define glColorFragmentOp2ATI GLEW_GET_FUN(__glewColorFragmentOp2ATI) +#define glColorFragmentOp3ATI GLEW_GET_FUN(__glewColorFragmentOp3ATI) +#define glDeleteFragmentShaderATI GLEW_GET_FUN(__glewDeleteFragmentShaderATI) +#define glEndFragmentShaderATI GLEW_GET_FUN(__glewEndFragmentShaderATI) +#define glGenFragmentShadersATI GLEW_GET_FUN(__glewGenFragmentShadersATI) +#define glPassTexCoordATI GLEW_GET_FUN(__glewPassTexCoordATI) +#define glSampleMapATI GLEW_GET_FUN(__glewSampleMapATI) +#define glSetFragmentShaderConstantATI GLEW_GET_FUN(__glewSetFragmentShaderConstantATI) + +#define GLEW_ATI_fragment_shader GLEW_GET_VAR(__GLEW_ATI_fragment_shader) + +#endif /* GL_ATI_fragment_shader */ + +/* ------------------------ GL_ATI_map_object_buffer ----------------------- */ + +#ifndef GL_ATI_map_object_buffer +#define GL_ATI_map_object_buffer 1 + +typedef void* (GLAPIENTRY * PFNGLMAPOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (GLAPIENTRY * PFNGLUNMAPOBJECTBUFFERATIPROC) (GLuint buffer); + +#define glMapObjectBufferATI GLEW_GET_FUN(__glewMapObjectBufferATI) +#define glUnmapObjectBufferATI GLEW_GET_FUN(__glewUnmapObjectBufferATI) + +#define GLEW_ATI_map_object_buffer GLEW_GET_VAR(__GLEW_ATI_map_object_buffer) + +#endif /* GL_ATI_map_object_buffer */ + +/* ----------------------------- GL_ATI_meminfo ---------------------------- */ + +#ifndef GL_ATI_meminfo +#define GL_ATI_meminfo 1 + +#define GL_VBO_FREE_MEMORY_ATI 0x87FB +#define GL_TEXTURE_FREE_MEMORY_ATI 0x87FC +#define GL_RENDERBUFFER_FREE_MEMORY_ATI 0x87FD + +#define GLEW_ATI_meminfo GLEW_GET_VAR(__GLEW_ATI_meminfo) + +#endif /* GL_ATI_meminfo */ + +/* -------------------------- GL_ATI_pn_triangles -------------------------- */ + +#ifndef GL_ATI_pn_triangles +#define GL_ATI_pn_triangles 1 + +#define GL_PN_TRIANGLES_ATI 0x87F0 +#define GL_MAX_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F1 +#define GL_PN_TRIANGLES_POINT_MODE_ATI 0x87F2 +#define GL_PN_TRIANGLES_NORMAL_MODE_ATI 0x87F3 +#define GL_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F4 +#define GL_PN_TRIANGLES_POINT_MODE_LINEAR_ATI 0x87F5 +#define GL_PN_TRIANGLES_POINT_MODE_CUBIC_ATI 0x87F6 +#define GL_PN_TRIANGLES_NORMAL_MODE_LINEAR_ATI 0x87F7 +#define GL_PN_TRIANGLES_NORMAL_MODE_QUADRATIC_ATI 0x87F8 + +typedef void (GLAPIENTRY * PFNGLPNTRIANGLESFATIPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLPNTRIANGLESIATIPROC) (GLenum pname, GLint param); + +#define glPNTrianglesfATI GLEW_GET_FUN(__glPNTrianglewesfATI) +#define glPNTrianglesiATI GLEW_GET_FUN(__glPNTrianglewesiATI) + +#define GLEW_ATI_pn_triangles GLEW_GET_VAR(__GLEW_ATI_pn_triangles) + +#endif /* GL_ATI_pn_triangles */ + +/* ------------------------ GL_ATI_separate_stencil ------------------------ */ + +#ifndef GL_ATI_separate_stencil +#define GL_ATI_separate_stencil 1 + +#define GL_STENCIL_BACK_FUNC_ATI 0x8800 +#define GL_STENCIL_BACK_FAIL_ATI 0x8801 +#define GL_STENCIL_BACK_PASS_DEPTH_FAIL_ATI 0x8802 +#define GL_STENCIL_BACK_PASS_DEPTH_PASS_ATI 0x8803 + +typedef void (GLAPIENTRY * PFNGLSTENCILFUNCSEPARATEATIPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); +typedef void (GLAPIENTRY * PFNGLSTENCILOPSEPARATEATIPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); + +#define glStencilFuncSeparateATI GLEW_GET_FUN(__glewStencilFuncSeparateATI) +#define glStencilOpSeparateATI GLEW_GET_FUN(__glewStencilOpSeparateATI) + +#define GLEW_ATI_separate_stencil GLEW_GET_VAR(__GLEW_ATI_separate_stencil) + +#endif /* GL_ATI_separate_stencil */ + +/* ----------------------- GL_ATI_shader_texture_lod ----------------------- */ + +#ifndef GL_ATI_shader_texture_lod +#define GL_ATI_shader_texture_lod 1 + +#define GLEW_ATI_shader_texture_lod GLEW_GET_VAR(__GLEW_ATI_shader_texture_lod) + +#endif /* GL_ATI_shader_texture_lod */ + +/* ---------------------- GL_ATI_text_fragment_shader ---------------------- */ + +#ifndef GL_ATI_text_fragment_shader +#define GL_ATI_text_fragment_shader 1 + +#define GL_TEXT_FRAGMENT_SHADER_ATI 0x8200 + +#define GLEW_ATI_text_fragment_shader GLEW_GET_VAR(__GLEW_ATI_text_fragment_shader) + +#endif /* GL_ATI_text_fragment_shader */ + +/* --------------------- GL_ATI_texture_compression_3dc -------------------- */ + +#ifndef GL_ATI_texture_compression_3dc +#define GL_ATI_texture_compression_3dc 1 + +#define GL_COMPRESSED_LUMINANCE_ALPHA_3DC_ATI 0x8837 + +#define GLEW_ATI_texture_compression_3dc GLEW_GET_VAR(__GLEW_ATI_texture_compression_3dc) + +#endif /* GL_ATI_texture_compression_3dc */ + +/* ---------------------- GL_ATI_texture_env_combine3 ---------------------- */ + +#ifndef GL_ATI_texture_env_combine3 +#define GL_ATI_texture_env_combine3 1 + +#define GL_MODULATE_ADD_ATI 0x8744 +#define GL_MODULATE_SIGNED_ADD_ATI 0x8745 +#define GL_MODULATE_SUBTRACT_ATI 0x8746 + +#define GLEW_ATI_texture_env_combine3 GLEW_GET_VAR(__GLEW_ATI_texture_env_combine3) + +#endif /* GL_ATI_texture_env_combine3 */ + +/* -------------------------- GL_ATI_texture_float ------------------------- */ + +#ifndef GL_ATI_texture_float +#define GL_ATI_texture_float 1 + +#define GL_RGBA_FLOAT32_ATI 0x8814 +#define GL_RGB_FLOAT32_ATI 0x8815 +#define GL_ALPHA_FLOAT32_ATI 0x8816 +#define GL_INTENSITY_FLOAT32_ATI 0x8817 +#define GL_LUMINANCE_FLOAT32_ATI 0x8818 +#define GL_LUMINANCE_ALPHA_FLOAT32_ATI 0x8819 +#define GL_RGBA_FLOAT16_ATI 0x881A +#define GL_RGB_FLOAT16_ATI 0x881B +#define GL_ALPHA_FLOAT16_ATI 0x881C +#define GL_INTENSITY_FLOAT16_ATI 0x881D +#define GL_LUMINANCE_FLOAT16_ATI 0x881E +#define GL_LUMINANCE_ALPHA_FLOAT16_ATI 0x881F + +#define GLEW_ATI_texture_float GLEW_GET_VAR(__GLEW_ATI_texture_float) + +#endif /* GL_ATI_texture_float */ + +/* ----------------------- GL_ATI_texture_mirror_once ---------------------- */ + +#ifndef GL_ATI_texture_mirror_once +#define GL_ATI_texture_mirror_once 1 + +#define GL_MIRROR_CLAMP_ATI 0x8742 +#define GL_MIRROR_CLAMP_TO_EDGE_ATI 0x8743 + +#define GLEW_ATI_texture_mirror_once GLEW_GET_VAR(__GLEW_ATI_texture_mirror_once) + +#endif /* GL_ATI_texture_mirror_once */ + +/* ----------------------- GL_ATI_vertex_array_object ---------------------- */ + +#ifndef GL_ATI_vertex_array_object +#define GL_ATI_vertex_array_object 1 + +#define GL_STATIC_ATI 0x8760 +#define GL_DYNAMIC_ATI 0x8761 +#define GL_PRESERVE_ATI 0x8762 +#define GL_DISCARD_ATI 0x8763 +#define GL_OBJECT_BUFFER_SIZE_ATI 0x8764 +#define GL_OBJECT_BUFFER_USAGE_ATI 0x8765 +#define GL_ARRAY_OBJECT_BUFFER_ATI 0x8766 +#define GL_ARRAY_OBJECT_OFFSET_ATI 0x8767 + +typedef void (GLAPIENTRY * PFNGLARRAYOBJECTATIPROC) (GLenum array, GLint size, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); +typedef void (GLAPIENTRY * PFNGLFREEOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (GLAPIENTRY * PFNGLGETARRAYOBJECTFVATIPROC) (GLenum array, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETARRAYOBJECTIVATIPROC) (GLenum array, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETOBJECTBUFFERFVATIPROC) (GLuint buffer, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETOBJECTBUFFERIVATIPROC) (GLuint buffer, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETVARIANTARRAYOBJECTFVATIPROC) (GLuint id, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETVARIANTARRAYOBJECTIVATIPROC) (GLuint id, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISOBJECTBUFFERATIPROC) (GLuint buffer); +typedef GLuint (GLAPIENTRY * PFNGLNEWOBJECTBUFFERATIPROC) (GLsizei size, const void* pointer, GLenum usage); +typedef void (GLAPIENTRY * PFNGLUPDATEOBJECTBUFFERATIPROC) (GLuint buffer, GLuint offset, GLsizei size, const void* pointer, GLenum preserve); +typedef void (GLAPIENTRY * PFNGLVARIANTARRAYOBJECTATIPROC) (GLuint id, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); + +#define glArrayObjectATI GLEW_GET_FUN(__glewArrayObjectATI) +#define glFreeObjectBufferATI GLEW_GET_FUN(__glewFreeObjectBufferATI) +#define glGetArrayObjectfvATI GLEW_GET_FUN(__glewGetArrayObjectfvATI) +#define glGetArrayObjectivATI GLEW_GET_FUN(__glewGetArrayObjectivATI) +#define glGetObjectBufferfvATI GLEW_GET_FUN(__glewGetObjectBufferfvATI) +#define glGetObjectBufferivATI GLEW_GET_FUN(__glewGetObjectBufferivATI) +#define glGetVariantArrayObjectfvATI GLEW_GET_FUN(__glewGetVariantArrayObjectfvATI) +#define glGetVariantArrayObjectivATI GLEW_GET_FUN(__glewGetVariantArrayObjectivATI) +#define glIsObjectBufferATI GLEW_GET_FUN(__glewIsObjectBufferATI) +#define glNewObjectBufferATI GLEW_GET_FUN(__glewNewObjectBufferATI) +#define glUpdateObjectBufferATI GLEW_GET_FUN(__glewUpdateObjectBufferATI) +#define glVariantArrayObjectATI GLEW_GET_FUN(__glewVariantArrayObjectATI) + +#define GLEW_ATI_vertex_array_object GLEW_GET_VAR(__GLEW_ATI_vertex_array_object) + +#endif /* GL_ATI_vertex_array_object */ + +/* ------------------- GL_ATI_vertex_attrib_array_object ------------------- */ + +#ifndef GL_ATI_vertex_attrib_array_object +#define GL_ATI_vertex_attrib_array_object 1 + +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC) (GLuint index, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC) (GLuint index, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBARRAYOBJECTATIPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLuint buffer, GLuint offset); + +#define glGetVertexAttribArrayObjectfvATI GLEW_GET_FUN(__glewGetVertexAttribArrayObjectfvATI) +#define glGetVertexAttribArrayObjectivATI GLEW_GET_FUN(__glewGetVertexAttribArrayObjectivATI) +#define glVertexAttribArrayObjectATI GLEW_GET_FUN(__glewVertexAttribArrayObjectATI) + +#define GLEW_ATI_vertex_attrib_array_object GLEW_GET_VAR(__GLEW_ATI_vertex_attrib_array_object) + +#endif /* GL_ATI_vertex_attrib_array_object */ + +/* ------------------------- GL_ATI_vertex_streams ------------------------- */ + +#ifndef GL_ATI_vertex_streams +#define GL_ATI_vertex_streams 1 + +#define GL_MAX_VERTEX_STREAMS_ATI 0x876B +#define GL_VERTEX_SOURCE_ATI 0x876C +#define GL_VERTEX_STREAM0_ATI 0x876D +#define GL_VERTEX_STREAM1_ATI 0x876E +#define GL_VERTEX_STREAM2_ATI 0x876F +#define GL_VERTEX_STREAM3_ATI 0x8770 +#define GL_VERTEX_STREAM4_ATI 0x8771 +#define GL_VERTEX_STREAM5_ATI 0x8772 +#define GL_VERTEX_STREAM6_ATI 0x8773 +#define GL_VERTEX_STREAM7_ATI 0x8774 + +typedef void (GLAPIENTRY * PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC) (GLenum stream); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3BATIPROC) (GLenum stream, GLbyte x, GLbyte y, GLbyte z); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3BVATIPROC) (GLenum stream, const GLbyte *v); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3DVATIPROC) (GLenum stream, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3FVATIPROC) (GLenum stream, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3IVATIPROC) (GLenum stream, const GLint *v); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3SVATIPROC) (GLenum stream, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLVERTEXBLENDENVFATIPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLVERTEXBLENDENVIATIPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2DATIPROC) (GLenum stream, GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2DVATIPROC) (GLenum stream, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2FATIPROC) (GLenum stream, GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2FVATIPROC) (GLenum stream, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2IATIPROC) (GLenum stream, GLint x, GLint y); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2IVATIPROC) (GLenum stream, const GLint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2SATIPROC) (GLenum stream, GLshort x, GLshort y); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2SVATIPROC) (GLenum stream, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3DVATIPROC) (GLenum stream, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3FVATIPROC) (GLenum stream, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3IVATIPROC) (GLenum stream, const GLint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3SVATIPROC) (GLenum stream, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4DVATIPROC) (GLenum stream, const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4FVATIPROC) (GLenum stream, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4IATIPROC) (GLenum stream, GLint x, GLint y, GLint z, GLint w); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4IVATIPROC) (GLenum stream, const GLint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4SVATIPROC) (GLenum stream, const GLshort *v); + +#define glClientActiveVertexStreamATI GLEW_GET_FUN(__glewClientActiveVertexStreamATI) +#define glNormalStream3bATI GLEW_GET_FUN(__glewNormalStream3bATI) +#define glNormalStream3bvATI GLEW_GET_FUN(__glewNormalStream3bvATI) +#define glNormalStream3dATI GLEW_GET_FUN(__glewNormalStream3dATI) +#define glNormalStream3dvATI GLEW_GET_FUN(__glewNormalStream3dvATI) +#define glNormalStream3fATI GLEW_GET_FUN(__glewNormalStream3fATI) +#define glNormalStream3fvATI GLEW_GET_FUN(__glewNormalStream3fvATI) +#define glNormalStream3iATI GLEW_GET_FUN(__glewNormalStream3iATI) +#define glNormalStream3ivATI GLEW_GET_FUN(__glewNormalStream3ivATI) +#define glNormalStream3sATI GLEW_GET_FUN(__glewNormalStream3sATI) +#define glNormalStream3svATI GLEW_GET_FUN(__glewNormalStream3svATI) +#define glVertexBlendEnvfATI GLEW_GET_FUN(__glewVertexBlendEnvfATI) +#define glVertexBlendEnviATI GLEW_GET_FUN(__glewVertexBlendEnviATI) +#define glVertexStream2dATI GLEW_GET_FUN(__glewVertexStream2dATI) +#define glVertexStream2dvATI GLEW_GET_FUN(__glewVertexStream2dvATI) +#define glVertexStream2fATI GLEW_GET_FUN(__glewVertexStream2fATI) +#define glVertexStream2fvATI GLEW_GET_FUN(__glewVertexStream2fvATI) +#define glVertexStream2iATI GLEW_GET_FUN(__glewVertexStream2iATI) +#define glVertexStream2ivATI GLEW_GET_FUN(__glewVertexStream2ivATI) +#define glVertexStream2sATI GLEW_GET_FUN(__glewVertexStream2sATI) +#define glVertexStream2svATI GLEW_GET_FUN(__glewVertexStream2svATI) +#define glVertexStream3dATI GLEW_GET_FUN(__glewVertexStream3dATI) +#define glVertexStream3dvATI GLEW_GET_FUN(__glewVertexStream3dvATI) +#define glVertexStream3fATI GLEW_GET_FUN(__glewVertexStream3fATI) +#define glVertexStream3fvATI GLEW_GET_FUN(__glewVertexStream3fvATI) +#define glVertexStream3iATI GLEW_GET_FUN(__glewVertexStream3iATI) +#define glVertexStream3ivATI GLEW_GET_FUN(__glewVertexStream3ivATI) +#define glVertexStream3sATI GLEW_GET_FUN(__glewVertexStream3sATI) +#define glVertexStream3svATI GLEW_GET_FUN(__glewVertexStream3svATI) +#define glVertexStream4dATI GLEW_GET_FUN(__glewVertexStream4dATI) +#define glVertexStream4dvATI GLEW_GET_FUN(__glewVertexStream4dvATI) +#define glVertexStream4fATI GLEW_GET_FUN(__glewVertexStream4fATI) +#define glVertexStream4fvATI GLEW_GET_FUN(__glewVertexStream4fvATI) +#define glVertexStream4iATI GLEW_GET_FUN(__glewVertexStream4iATI) +#define glVertexStream4ivATI GLEW_GET_FUN(__glewVertexStream4ivATI) +#define glVertexStream4sATI GLEW_GET_FUN(__glewVertexStream4sATI) +#define glVertexStream4svATI GLEW_GET_FUN(__glewVertexStream4svATI) + +#define GLEW_ATI_vertex_streams GLEW_GET_VAR(__GLEW_ATI_vertex_streams) + +#endif /* GL_ATI_vertex_streams */ + +/* --------------------------- GL_EXT_422_pixels --------------------------- */ + +#ifndef GL_EXT_422_pixels +#define GL_EXT_422_pixels 1 + +#define GL_422_EXT 0x80CC +#define GL_422_REV_EXT 0x80CD +#define GL_422_AVERAGE_EXT 0x80CE +#define GL_422_REV_AVERAGE_EXT 0x80CF + +#define GLEW_EXT_422_pixels GLEW_GET_VAR(__GLEW_EXT_422_pixels) + +#endif /* GL_EXT_422_pixels */ + +/* ---------------------------- GL_EXT_Cg_shader --------------------------- */ + +#ifndef GL_EXT_Cg_shader +#define GL_EXT_Cg_shader 1 + +#define GL_CG_VERTEX_SHADER_EXT 0x890E +#define GL_CG_FRAGMENT_SHADER_EXT 0x890F + +#define GLEW_EXT_Cg_shader GLEW_GET_VAR(__GLEW_EXT_Cg_shader) + +#endif /* GL_EXT_Cg_shader */ + +/* ------------------------------ GL_EXT_abgr ------------------------------ */ + +#ifndef GL_EXT_abgr +#define GL_EXT_abgr 1 + +#define GL_ABGR_EXT 0x8000 + +#define GLEW_EXT_abgr GLEW_GET_VAR(__GLEW_EXT_abgr) + +#endif /* GL_EXT_abgr */ + +/* ------------------------------ GL_EXT_bgra ------------------------------ */ + +#ifndef GL_EXT_bgra +#define GL_EXT_bgra 1 + +#define GL_BGR_EXT 0x80E0 +#define GL_BGRA_EXT 0x80E1 + +#define GLEW_EXT_bgra GLEW_GET_VAR(__GLEW_EXT_bgra) + +#endif /* GL_EXT_bgra */ + +/* ------------------------ GL_EXT_bindable_uniform ------------------------ */ + +#ifndef GL_EXT_bindable_uniform +#define GL_EXT_bindable_uniform 1 + +#define GL_MAX_VERTEX_BINDABLE_UNIFORMS_EXT 0x8DE2 +#define GL_MAX_FRAGMENT_BINDABLE_UNIFORMS_EXT 0x8DE3 +#define GL_MAX_GEOMETRY_BINDABLE_UNIFORMS_EXT 0x8DE4 +#define GL_MAX_BINDABLE_UNIFORM_SIZE_EXT 0x8DED +#define GL_UNIFORM_BUFFER_EXT 0x8DEE +#define GL_UNIFORM_BUFFER_BINDING_EXT 0x8DEF + +typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMBUFFERSIZEEXTPROC) (GLuint program, GLint location); +typedef GLintptr (GLAPIENTRY * PFNGLGETUNIFORMOFFSETEXTPROC) (GLuint program, GLint location); +typedef void (GLAPIENTRY * PFNGLUNIFORMBUFFEREXTPROC) (GLuint program, GLint location, GLuint buffer); + +#define glGetUniformBufferSizeEXT GLEW_GET_FUN(__glewGetUniformBufferSizeEXT) +#define glGetUniformOffsetEXT GLEW_GET_FUN(__glewGetUniformOffsetEXT) +#define glUniformBufferEXT GLEW_GET_FUN(__glewUniformBufferEXT) + +#define GLEW_EXT_bindable_uniform GLEW_GET_VAR(__GLEW_EXT_bindable_uniform) + +#endif /* GL_EXT_bindable_uniform */ + +/* --------------------------- GL_EXT_blend_color -------------------------- */ + +#ifndef GL_EXT_blend_color +#define GL_EXT_blend_color 1 + +#define GL_CONSTANT_COLOR_EXT 0x8001 +#define GL_ONE_MINUS_CONSTANT_COLOR_EXT 0x8002 +#define GL_CONSTANT_ALPHA_EXT 0x8003 +#define GL_ONE_MINUS_CONSTANT_ALPHA_EXT 0x8004 +#define GL_BLEND_COLOR_EXT 0x8005 + +typedef void (GLAPIENTRY * PFNGLBLENDCOLOREXTPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); + +#define glBlendColorEXT GLEW_GET_FUN(__glewBlendColorEXT) + +#define GLEW_EXT_blend_color GLEW_GET_VAR(__GLEW_EXT_blend_color) + +#endif /* GL_EXT_blend_color */ + +/* --------------------- GL_EXT_blend_equation_separate -------------------- */ + +#ifndef GL_EXT_blend_equation_separate +#define GL_EXT_blend_equation_separate 1 + +#define GL_BLEND_EQUATION_RGB_EXT 0x8009 +#define GL_BLEND_EQUATION_ALPHA_EXT 0x883D + +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEEXTPROC) (GLenum modeRGB, GLenum modeAlpha); + +#define glBlendEquationSeparateEXT GLEW_GET_FUN(__glewBlendEquationSeparateEXT) + +#define GLEW_EXT_blend_equation_separate GLEW_GET_VAR(__GLEW_EXT_blend_equation_separate) + +#endif /* GL_EXT_blend_equation_separate */ + +/* ----------------------- GL_EXT_blend_func_separate ---------------------- */ + +#ifndef GL_EXT_blend_func_separate +#define GL_EXT_blend_func_separate 1 + +#define GL_BLEND_DST_RGB_EXT 0x80C8 +#define GL_BLEND_SRC_RGB_EXT 0x80C9 +#define GL_BLEND_DST_ALPHA_EXT 0x80CA +#define GL_BLEND_SRC_ALPHA_EXT 0x80CB + +typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEEXTPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); + +#define glBlendFuncSeparateEXT GLEW_GET_FUN(__glewBlendFuncSeparateEXT) + +#define GLEW_EXT_blend_func_separate GLEW_GET_VAR(__GLEW_EXT_blend_func_separate) + +#endif /* GL_EXT_blend_func_separate */ + +/* ------------------------- GL_EXT_blend_logic_op ------------------------- */ + +#ifndef GL_EXT_blend_logic_op +#define GL_EXT_blend_logic_op 1 + +#define GLEW_EXT_blend_logic_op GLEW_GET_VAR(__GLEW_EXT_blend_logic_op) + +#endif /* GL_EXT_blend_logic_op */ + +/* -------------------------- GL_EXT_blend_minmax -------------------------- */ + +#ifndef GL_EXT_blend_minmax +#define GL_EXT_blend_minmax 1 + +#define GL_FUNC_ADD_EXT 0x8006 +#define GL_MIN_EXT 0x8007 +#define GL_MAX_EXT 0x8008 +#define GL_BLEND_EQUATION_EXT 0x8009 + +typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONEXTPROC) (GLenum mode); + +#define glBlendEquationEXT GLEW_GET_FUN(__glewBlendEquationEXT) + +#define GLEW_EXT_blend_minmax GLEW_GET_VAR(__GLEW_EXT_blend_minmax) + +#endif /* GL_EXT_blend_minmax */ + +/* ------------------------- GL_EXT_blend_subtract ------------------------- */ + +#ifndef GL_EXT_blend_subtract +#define GL_EXT_blend_subtract 1 + +#define GL_FUNC_SUBTRACT_EXT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT_EXT 0x800B + +#define GLEW_EXT_blend_subtract GLEW_GET_VAR(__GLEW_EXT_blend_subtract) + +#endif /* GL_EXT_blend_subtract */ + +/* ------------------------ GL_EXT_clip_volume_hint ------------------------ */ + +#ifndef GL_EXT_clip_volume_hint +#define GL_EXT_clip_volume_hint 1 + +#define GL_CLIP_VOLUME_CLIPPING_HINT_EXT 0x80F0 + +#define GLEW_EXT_clip_volume_hint GLEW_GET_VAR(__GLEW_EXT_clip_volume_hint) + +#endif /* GL_EXT_clip_volume_hint */ + +/* ------------------------------ GL_EXT_cmyka ----------------------------- */ + +#ifndef GL_EXT_cmyka +#define GL_EXT_cmyka 1 + +#define GL_CMYK_EXT 0x800C +#define GL_CMYKA_EXT 0x800D +#define GL_PACK_CMYK_HINT_EXT 0x800E +#define GL_UNPACK_CMYK_HINT_EXT 0x800F + +#define GLEW_EXT_cmyka GLEW_GET_VAR(__GLEW_EXT_cmyka) + +#endif /* GL_EXT_cmyka */ + +/* ------------------------- GL_EXT_color_subtable ------------------------- */ + +#ifndef GL_EXT_color_subtable +#define GL_EXT_color_subtable 1 + +typedef void (GLAPIENTRY * PFNGLCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const void* data); +typedef void (GLAPIENTRY * PFNGLCOPYCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); + +#define glColorSubTableEXT GLEW_GET_FUN(__glewColorSubTableEXT) +#define glCopyColorSubTableEXT GLEW_GET_FUN(__glewCopyColorSubTableEXT) + +#define GLEW_EXT_color_subtable GLEW_GET_VAR(__GLEW_EXT_color_subtable) + +#endif /* GL_EXT_color_subtable */ + +/* ---------------------- GL_EXT_compiled_vertex_array --------------------- */ + +#ifndef GL_EXT_compiled_vertex_array +#define GL_EXT_compiled_vertex_array 1 + +#define GL_ARRAY_ELEMENT_LOCK_FIRST_EXT 0x81A8 +#define GL_ARRAY_ELEMENT_LOCK_COUNT_EXT 0x81A9 + +typedef void (GLAPIENTRY * PFNGLLOCKARRAYSEXTPROC) (GLint first, GLsizei count); +typedef void (GLAPIENTRY * PFNGLUNLOCKARRAYSEXTPROC) (void); + +#define glLockArraysEXT GLEW_GET_FUN(__glewLockArraysEXT) +#define glUnlockArraysEXT GLEW_GET_FUN(__glewUnlockArraysEXT) + +#define GLEW_EXT_compiled_vertex_array GLEW_GET_VAR(__GLEW_EXT_compiled_vertex_array) + +#endif /* GL_EXT_compiled_vertex_array */ + +/* --------------------------- GL_EXT_convolution -------------------------- */ + +#ifndef GL_EXT_convolution +#define GL_EXT_convolution 1 + +#define GL_CONVOLUTION_1D_EXT 0x8010 +#define GL_CONVOLUTION_2D_EXT 0x8011 +#define GL_SEPARABLE_2D_EXT 0x8012 +#define GL_CONVOLUTION_BORDER_MODE_EXT 0x8013 +#define GL_CONVOLUTION_FILTER_SCALE_EXT 0x8014 +#define GL_CONVOLUTION_FILTER_BIAS_EXT 0x8015 +#define GL_REDUCE_EXT 0x8016 +#define GL_CONVOLUTION_FORMAT_EXT 0x8017 +#define GL_CONVOLUTION_WIDTH_EXT 0x8018 +#define GL_CONVOLUTION_HEIGHT_EXT 0x8019 +#define GL_MAX_CONVOLUTION_WIDTH_EXT 0x801A +#define GL_MAX_CONVOLUTION_HEIGHT_EXT 0x801B +#define GL_POST_CONVOLUTION_RED_SCALE_EXT 0x801C +#define GL_POST_CONVOLUTION_GREEN_SCALE_EXT 0x801D +#define GL_POST_CONVOLUTION_BLUE_SCALE_EXT 0x801E +#define GL_POST_CONVOLUTION_ALPHA_SCALE_EXT 0x801F +#define GL_POST_CONVOLUTION_RED_BIAS_EXT 0x8020 +#define GL_POST_CONVOLUTION_GREEN_BIAS_EXT 0x8021 +#define GL_POST_CONVOLUTION_BLUE_BIAS_EXT 0x8022 +#define GL_POST_CONVOLUTION_ALPHA_BIAS_EXT 0x8023 + +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void* image); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* image); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, void* image); +typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETSEPARABLEFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, void* row, void* column, void* span); +typedef void (GLAPIENTRY * PFNGLSEPARABLEFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* row, const void* column); + +#define glConvolutionFilter1DEXT GLEW_GET_FUN(__glewConvolutionFilter1DEXT) +#define glConvolutionFilter2DEXT GLEW_GET_FUN(__glewConvolutionFilter2DEXT) +#define glConvolutionParameterfEXT GLEW_GET_FUN(__glewConvolutionParameterfEXT) +#define glConvolutionParameterfvEXT GLEW_GET_FUN(__glewConvolutionParameterfvEXT) +#define glConvolutionParameteriEXT GLEW_GET_FUN(__glewConvolutionParameteriEXT) +#define glConvolutionParameterivEXT GLEW_GET_FUN(__glewConvolutionParameterivEXT) +#define glCopyConvolutionFilter1DEXT GLEW_GET_FUN(__glewCopyConvolutionFilter1DEXT) +#define glCopyConvolutionFilter2DEXT GLEW_GET_FUN(__glewCopyConvolutionFilter2DEXT) +#define glGetConvolutionFilterEXT GLEW_GET_FUN(__glewGetConvolutionFilterEXT) +#define glGetConvolutionParameterfvEXT GLEW_GET_FUN(__glewGetConvolutionParameterfvEXT) +#define glGetConvolutionParameterivEXT GLEW_GET_FUN(__glewGetConvolutionParameterivEXT) +#define glGetSeparableFilterEXT GLEW_GET_FUN(__glewGetSeparableFilterEXT) +#define glSeparableFilter2DEXT GLEW_GET_FUN(__glewSeparableFilter2DEXT) + +#define GLEW_EXT_convolution GLEW_GET_VAR(__GLEW_EXT_convolution) + +#endif /* GL_EXT_convolution */ + +/* ------------------------ GL_EXT_coordinate_frame ------------------------ */ + +#ifndef GL_EXT_coordinate_frame +#define GL_EXT_coordinate_frame 1 + +#define GL_TANGENT_ARRAY_EXT 0x8439 +#define GL_BINORMAL_ARRAY_EXT 0x843A +#define GL_CURRENT_TANGENT_EXT 0x843B +#define GL_CURRENT_BINORMAL_EXT 0x843C +#define GL_TANGENT_ARRAY_TYPE_EXT 0x843E +#define GL_TANGENT_ARRAY_STRIDE_EXT 0x843F +#define GL_BINORMAL_ARRAY_TYPE_EXT 0x8440 +#define GL_BINORMAL_ARRAY_STRIDE_EXT 0x8441 +#define GL_TANGENT_ARRAY_POINTER_EXT 0x8442 +#define GL_BINORMAL_ARRAY_POINTER_EXT 0x8443 +#define GL_MAP1_TANGENT_EXT 0x8444 +#define GL_MAP2_TANGENT_EXT 0x8445 +#define GL_MAP1_BINORMAL_EXT 0x8446 +#define GL_MAP2_BINORMAL_EXT 0x8447 + +typedef void (GLAPIENTRY * PFNGLBINORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, void* pointer); +typedef void (GLAPIENTRY * PFNGLTANGENTPOINTEREXTPROC) (GLenum type, GLsizei stride, void* pointer); + +#define glBinormalPointerEXT GLEW_GET_FUN(__glewBinormalPointerEXT) +#define glTangentPointerEXT GLEW_GET_FUN(__glewTangentPointerEXT) + +#define GLEW_EXT_coordinate_frame GLEW_GET_VAR(__GLEW_EXT_coordinate_frame) + +#endif /* GL_EXT_coordinate_frame */ + +/* -------------------------- GL_EXT_copy_texture -------------------------- */ + +#ifndef GL_EXT_copy_texture +#define GL_EXT_copy_texture 1 + +typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE1DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE2DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); + +#define glCopyTexImage1DEXT GLEW_GET_FUN(__glewCopyTexImage1DEXT) +#define glCopyTexImage2DEXT GLEW_GET_FUN(__glewCopyTexImage2DEXT) +#define glCopyTexSubImage1DEXT GLEW_GET_FUN(__glewCopyTexSubImage1DEXT) +#define glCopyTexSubImage2DEXT GLEW_GET_FUN(__glewCopyTexSubImage2DEXT) +#define glCopyTexSubImage3DEXT GLEW_GET_FUN(__glewCopyTexSubImage3DEXT) + +#define GLEW_EXT_copy_texture GLEW_GET_VAR(__GLEW_EXT_copy_texture) + +#endif /* GL_EXT_copy_texture */ + +/* --------------------------- GL_EXT_cull_vertex -------------------------- */ + +#ifndef GL_EXT_cull_vertex +#define GL_EXT_cull_vertex 1 + +#define GL_CULL_VERTEX_EXT 0x81AA +#define GL_CULL_VERTEX_EYE_POSITION_EXT 0x81AB +#define GL_CULL_VERTEX_OBJECT_POSITION_EXT 0x81AC + +typedef void (GLAPIENTRY * PFNGLCULLPARAMETERDVEXTPROC) (GLenum pname, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLCULLPARAMETERFVEXTPROC) (GLenum pname, GLfloat* params); + +#define glCullParameterdvEXT GLEW_GET_FUN(__glewCullParameterdvEXT) +#define glCullParameterfvEXT GLEW_GET_FUN(__glewCullParameterfvEXT) + +#define GLEW_EXT_cull_vertex GLEW_GET_VAR(__GLEW_EXT_cull_vertex) + +#endif /* GL_EXT_cull_vertex */ + +/* ------------------------ GL_EXT_depth_bounds_test ----------------------- */ + +#ifndef GL_EXT_depth_bounds_test +#define GL_EXT_depth_bounds_test 1 + +#define GL_DEPTH_BOUNDS_TEST_EXT 0x8890 +#define GL_DEPTH_BOUNDS_EXT 0x8891 + +typedef void (GLAPIENTRY * PFNGLDEPTHBOUNDSEXTPROC) (GLclampd zmin, GLclampd zmax); + +#define glDepthBoundsEXT GLEW_GET_FUN(__glewDepthBoundsEXT) + +#define GLEW_EXT_depth_bounds_test GLEW_GET_VAR(__GLEW_EXT_depth_bounds_test) + +#endif /* GL_EXT_depth_bounds_test */ + +/* ----------------------- GL_EXT_direct_state_access ---------------------- */ + +#ifndef GL_EXT_direct_state_access +#define GL_EXT_direct_state_access 1 + +#define GL_PROGRAM_MATRIX_EXT 0x8E2D +#define GL_TRANSPOSE_PROGRAM_MATRIX_EXT 0x8E2E +#define GL_PROGRAM_MATRIX_STACK_DEPTH_EXT 0x8E2F + +typedef void (GLAPIENTRY * PFNGLBINDMULTITEXTUREEXTPROC) (GLenum texunit, GLenum target, GLuint texture); +typedef GLenum (GLAPIENTRY * PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC) (GLuint framebuffer, GLenum target); +typedef void (GLAPIENTRY * PFNGLCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data); +typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLCOPYTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +typedef void (GLAPIENTRY * PFNGLCOPYTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); +typedef void (GLAPIENTRY * PFNGLDISABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); +typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); +typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); +typedef void (GLAPIENTRY * PFNGLENABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); +typedef void (GLAPIENTRY * PFNGLENABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); +typedef void (GLAPIENTRY * PFNGLENABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); +typedef void (GLAPIENTRY * PFNGLENABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); +typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC) (GLuint framebuffer, GLsizei n, const GLenum* bufs); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERREADBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); +typedef void (GLAPIENTRY * PFNGLGENERATEMULTITEXMIPMAPEXTPROC) (GLenum texunit, GLenum target); +typedef void (GLAPIENTRY * PFNGLGENERATETEXTUREMIPMAPEXTPROC) (GLuint texture, GLenum target); +typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint level, void* img); +typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint level, void* img); +typedef void (GLAPIENTRY * PFNGLGETDOUBLEINDEXEDVEXTPROC) (GLenum target, GLuint index, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETDOUBLEI_VEXTPROC) (GLenum pname, GLuint index, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETFLOATINDEXEDVEXTPROC) (GLenum target, GLuint index, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETFLOATI_VEXTPROC) (GLenum pname, GLuint index, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum pname, GLint* param); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum format, GLenum type, void* pixels); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLuint* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC) (GLuint buffer, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPOINTERVEXTPROC) (GLuint buffer, GLenum pname, void** params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, void* data); +typedef void (GLAPIENTRY * PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum pname, void* string); +typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMIVEXTPROC) (GLuint program, GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC) (GLuint renderbuffer, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETPOINTERINDEXEDVEXTPROC) (GLenum target, GLuint index, GLvoid** params); +typedef void (GLAPIENTRY * PFNGLGETPOINTERI_VEXTPROC) (GLenum pname, GLuint index, GLvoid** params); +typedef void (GLAPIENTRY * PFNGLGETTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, void* pixels); +typedef void (GLAPIENTRY * PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLuint* params); +typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, GLint* param); +typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYINTEGERVEXTPROC) (GLuint vaobj, GLenum pname, GLint* param); +typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, GLvoid** param); +typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYPOINTERVEXTPROC) (GLuint vaobj, GLenum pname, GLvoid** param); +typedef GLvoid * (GLAPIENTRY * PFNGLMAPNAMEDBUFFEREXTPROC) (GLuint buffer, GLenum access); +typedef GLvoid * (GLAPIENTRY * PFNGLMAPNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length, GLbitfield access); +typedef void (GLAPIENTRY * PFNGLMATRIXFRUSTUMEXTPROC) (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f); +typedef void (GLAPIENTRY * PFNGLMATRIXLOADIDENTITYEXTPROC) (GLenum matrixMode); +typedef void (GLAPIENTRY * PFNGLMATRIXLOADTRANSPOSEDEXTPROC) (GLenum matrixMode, const GLdouble* m); +typedef void (GLAPIENTRY * PFNGLMATRIXLOADTRANSPOSEFEXTPROC) (GLenum matrixMode, const GLfloat* m); +typedef void (GLAPIENTRY * PFNGLMATRIXLOADDEXTPROC) (GLenum matrixMode, const GLdouble* m); +typedef void (GLAPIENTRY * PFNGLMATRIXLOADFEXTPROC) (GLenum matrixMode, const GLfloat* m); +typedef void (GLAPIENTRY * PFNGLMATRIXMULTTRANSPOSEDEXTPROC) (GLenum matrixMode, const GLdouble* m); +typedef void (GLAPIENTRY * PFNGLMATRIXMULTTRANSPOSEFEXTPROC) (GLenum matrixMode, const GLfloat* m); +typedef void (GLAPIENTRY * PFNGLMATRIXMULTDEXTPROC) (GLenum matrixMode, const GLdouble* m); +typedef void (GLAPIENTRY * PFNGLMATRIXMULTFEXTPROC) (GLenum matrixMode, const GLfloat* m); +typedef void (GLAPIENTRY * PFNGLMATRIXORTHOEXTPROC) (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f); +typedef void (GLAPIENTRY * PFNGLMATRIXPOPEXTPROC) (GLenum matrixMode); +typedef void (GLAPIENTRY * PFNGLMATRIXPUSHEXTPROC) (GLenum matrixMode); +typedef void (GLAPIENTRY * PFNGLMATRIXROTATEDEXTPROC) (GLenum matrixMode, GLdouble angle, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLMATRIXROTATEFEXTPROC) (GLenum matrixMode, GLfloat angle, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLMATRIXSCALEDEXTPROC) (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLMATRIXSCALEFEXTPROC) (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLMATRIXTRANSLATEDEXTPROC) (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLMATRIXTRANSLATEFEXTPROC) (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLMULTITEXBUFFEREXTPROC) (GLenum texunit, GLenum target, GLenum internalformat, GLuint buffer); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDPOINTEREXTPROC) (GLenum texunit, GLint size, GLenum type, GLsizei stride, const void* pointer); +typedef void (GLAPIENTRY * PFNGLMULTITEXENVFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLMULTITEXENVIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLMULTITEXGENDEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble param); +typedef void (GLAPIENTRY * PFNGLMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLdouble* params); +typedef void (GLAPIENTRY * PFNGLMULTITEXGENFEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLMULTITEXGENIEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLuint* params); +typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat* param); +typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* param); +typedef void (GLAPIENTRY * PFNGLMULTITEXRENDERBUFFEREXTPROC) (GLenum texunit, GLenum target, GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLNAMEDBUFFERDATAEXTPROC) (GLuint buffer, GLsizeiptr size, const void* data, GLenum usage); +typedef void (GLAPIENTRY * PFNGLNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, const void* data); +typedef void (GLAPIENTRY * PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC) (GLuint readBuffer, GLuint writeBuffer, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); +typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC) (GLuint framebuffer, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLenum face); +typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLint layer); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLdouble* params); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC) (GLuint program, GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLint* params); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLuint* params); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLint* params); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLuint* params); +typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum format, GLsizei len, const void* string); +typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC) (GLuint renderbuffer, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC) (GLuint renderbuffer, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLuint renderbuffer, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FEXTPROC) (GLuint program, GLint location, GLfloat v0); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IEXTPROC) (GLuint program, GLint location, GLint v0); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIEXTPROC) (GLuint program, GLint location, GLuint v0); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +typedef void (GLAPIENTRY * PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); +typedef void (GLAPIENTRY * PFNGLTEXTUREBUFFEREXTPROC) (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer); +typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLuint* params); +typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERFEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLfloat* param); +typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint* param); +typedef void (GLAPIENTRY * PFNGLTEXTURERENDERBUFFEREXTPROC) (GLuint texture, GLenum target, GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels); +typedef GLboolean (GLAPIENTRY * PFNGLUNMAPNAMEDBUFFEREXTPROC) (GLuint buffer); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYINDEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum texunit, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYNORMALOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); + +#define glBindMultiTextureEXT GLEW_GET_FUN(__glewBindMultiTextureEXT) +#define glCheckNamedFramebufferStatusEXT GLEW_GET_FUN(__glewCheckNamedFramebufferStatusEXT) +#define glClientAttribDefaultEXT GLEW_GET_FUN(__glewClientAttribDefaultEXT) +#define glCompressedMultiTexImage1DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage1DEXT) +#define glCompressedMultiTexImage2DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage2DEXT) +#define glCompressedMultiTexImage3DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage3DEXT) +#define glCompressedMultiTexSubImage1DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage1DEXT) +#define glCompressedMultiTexSubImage2DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage2DEXT) +#define glCompressedMultiTexSubImage3DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage3DEXT) +#define glCompressedTextureImage1DEXT GLEW_GET_FUN(__glewCompressedTextureImage1DEXT) +#define glCompressedTextureImage2DEXT GLEW_GET_FUN(__glewCompressedTextureImage2DEXT) +#define glCompressedTextureImage3DEXT GLEW_GET_FUN(__glewCompressedTextureImage3DEXT) +#define glCompressedTextureSubImage1DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage1DEXT) +#define glCompressedTextureSubImage2DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage2DEXT) +#define glCompressedTextureSubImage3DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage3DEXT) +#define glCopyMultiTexImage1DEXT GLEW_GET_FUN(__glewCopyMultiTexImage1DEXT) +#define glCopyMultiTexImage2DEXT GLEW_GET_FUN(__glewCopyMultiTexImage2DEXT) +#define glCopyMultiTexSubImage1DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage1DEXT) +#define glCopyMultiTexSubImage2DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage2DEXT) +#define glCopyMultiTexSubImage3DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage3DEXT) +#define glCopyTextureImage1DEXT GLEW_GET_FUN(__glewCopyTextureImage1DEXT) +#define glCopyTextureImage2DEXT GLEW_GET_FUN(__glewCopyTextureImage2DEXT) +#define glCopyTextureSubImage1DEXT GLEW_GET_FUN(__glewCopyTextureSubImage1DEXT) +#define glCopyTextureSubImage2DEXT GLEW_GET_FUN(__glewCopyTextureSubImage2DEXT) +#define glCopyTextureSubImage3DEXT GLEW_GET_FUN(__glewCopyTextureSubImage3DEXT) +#define glDisableClientStateIndexedEXT GLEW_GET_FUN(__glewDisableClientStateIndexedEXT) +#define glDisableClientStateiEXT GLEW_GET_FUN(__glewDisableClientStateiEXT) +#define glDisableVertexArrayAttribEXT GLEW_GET_FUN(__glewDisableVertexArrayAttribEXT) +#define glDisableVertexArrayEXT GLEW_GET_FUN(__glewDisableVertexArrayEXT) +#define glEnableClientStateIndexedEXT GLEW_GET_FUN(__glewEnableClientStateIndexedEXT) +#define glEnableClientStateiEXT GLEW_GET_FUN(__glewEnableClientStateiEXT) +#define glEnableVertexArrayAttribEXT GLEW_GET_FUN(__glewEnableVertexArrayAttribEXT) +#define glEnableVertexArrayEXT GLEW_GET_FUN(__glewEnableVertexArrayEXT) +#define glFlushMappedNamedBufferRangeEXT GLEW_GET_FUN(__glewFlushMappedNamedBufferRangeEXT) +#define glFramebufferDrawBufferEXT GLEW_GET_FUN(__glewFramebufferDrawBufferEXT) +#define glFramebufferDrawBuffersEXT GLEW_GET_FUN(__glewFramebufferDrawBuffersEXT) +#define glFramebufferReadBufferEXT GLEW_GET_FUN(__glewFramebufferReadBufferEXT) +#define glGenerateMultiTexMipmapEXT GLEW_GET_FUN(__glewGenerateMultiTexMipmapEXT) +#define glGenerateTextureMipmapEXT GLEW_GET_FUN(__glewGenerateTextureMipmapEXT) +#define glGetCompressedMultiTexImageEXT GLEW_GET_FUN(__glewGetCompressedMultiTexImageEXT) +#define glGetCompressedTextureImageEXT GLEW_GET_FUN(__glewGetCompressedTextureImageEXT) +#define glGetDoubleIndexedvEXT GLEW_GET_FUN(__glewGetDoubleIndexedvEXT) +#define glGetDoublei_vEXT GLEW_GET_FUN(__glewGetDoublei_vEXT) +#define glGetFloatIndexedvEXT GLEW_GET_FUN(__glewGetFloatIndexedvEXT) +#define glGetFloati_vEXT GLEW_GET_FUN(__glewGetFloati_vEXT) +#define glGetFramebufferParameterivEXT GLEW_GET_FUN(__glewGetFramebufferParameterivEXT) +#define glGetMultiTexEnvfvEXT GLEW_GET_FUN(__glewGetMultiTexEnvfvEXT) +#define glGetMultiTexEnvivEXT GLEW_GET_FUN(__glewGetMultiTexEnvivEXT) +#define glGetMultiTexGendvEXT GLEW_GET_FUN(__glewGetMultiTexGendvEXT) +#define glGetMultiTexGenfvEXT GLEW_GET_FUN(__glewGetMultiTexGenfvEXT) +#define glGetMultiTexGenivEXT GLEW_GET_FUN(__glewGetMultiTexGenivEXT) +#define glGetMultiTexImageEXT GLEW_GET_FUN(__glewGetMultiTexImageEXT) +#define glGetMultiTexLevelParameterfvEXT GLEW_GET_FUN(__glewGetMultiTexLevelParameterfvEXT) +#define glGetMultiTexLevelParameterivEXT GLEW_GET_FUN(__glewGetMultiTexLevelParameterivEXT) +#define glGetMultiTexParameterIivEXT GLEW_GET_FUN(__glewGetMultiTexParameterIivEXT) +#define glGetMultiTexParameterIuivEXT GLEW_GET_FUN(__glewGetMultiTexParameterIuivEXT) +#define glGetMultiTexParameterfvEXT GLEW_GET_FUN(__glewGetMultiTexParameterfvEXT) +#define glGetMultiTexParameterivEXT GLEW_GET_FUN(__glewGetMultiTexParameterivEXT) +#define glGetNamedBufferParameterivEXT GLEW_GET_FUN(__glewGetNamedBufferParameterivEXT) +#define glGetNamedBufferPointervEXT GLEW_GET_FUN(__glewGetNamedBufferPointervEXT) +#define glGetNamedBufferSubDataEXT GLEW_GET_FUN(__glewGetNamedBufferSubDataEXT) +#define glGetNamedFramebufferAttachmentParameterivEXT GLEW_GET_FUN(__glewGetNamedFramebufferAttachmentParameterivEXT) +#define glGetNamedProgramLocalParameterIivEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterIivEXT) +#define glGetNamedProgramLocalParameterIuivEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterIuivEXT) +#define glGetNamedProgramLocalParameterdvEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterdvEXT) +#define glGetNamedProgramLocalParameterfvEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterfvEXT) +#define glGetNamedProgramStringEXT GLEW_GET_FUN(__glewGetNamedProgramStringEXT) +#define glGetNamedProgramivEXT GLEW_GET_FUN(__glewGetNamedProgramivEXT) +#define glGetNamedRenderbufferParameterivEXT GLEW_GET_FUN(__glewGetNamedRenderbufferParameterivEXT) +#define glGetPointerIndexedvEXT GLEW_GET_FUN(__glewGetPointerIndexedvEXT) +#define glGetPointeri_vEXT GLEW_GET_FUN(__glewGetPointeri_vEXT) +#define glGetTextureImageEXT GLEW_GET_FUN(__glewGetTextureImageEXT) +#define glGetTextureLevelParameterfvEXT GLEW_GET_FUN(__glewGetTextureLevelParameterfvEXT) +#define glGetTextureLevelParameterivEXT GLEW_GET_FUN(__glewGetTextureLevelParameterivEXT) +#define glGetTextureParameterIivEXT GLEW_GET_FUN(__glewGetTextureParameterIivEXT) +#define glGetTextureParameterIuivEXT GLEW_GET_FUN(__glewGetTextureParameterIuivEXT) +#define glGetTextureParameterfvEXT GLEW_GET_FUN(__glewGetTextureParameterfvEXT) +#define glGetTextureParameterivEXT GLEW_GET_FUN(__glewGetTextureParameterivEXT) +#define glGetVertexArrayIntegeri_vEXT GLEW_GET_FUN(__glewGetVertexArrayIntegeri_vEXT) +#define glGetVertexArrayIntegervEXT GLEW_GET_FUN(__glewGetVertexArrayIntegervEXT) +#define glGetVertexArrayPointeri_vEXT GLEW_GET_FUN(__glewGetVertexArrayPointeri_vEXT) +#define glGetVertexArrayPointervEXT GLEW_GET_FUN(__glewGetVertexArrayPointervEXT) +#define glMapNamedBufferEXT GLEW_GET_FUN(__glewMapNamedBufferEXT) +#define glMapNamedBufferRangeEXT GLEW_GET_FUN(__glewMapNamedBufferRangeEXT) +#define glMatrixFrustumEXT GLEW_GET_FUN(__glewMatrixFrustumEXT) +#define glMatrixLoadIdentityEXT GLEW_GET_FUN(__glewMatrixLoadIdentityEXT) +#define glMatrixLoadTransposedEXT GLEW_GET_FUN(__glewMatrixLoadTransposedEXT) +#define glMatrixLoadTransposefEXT GLEW_GET_FUN(__glewMatrixLoadTransposefEXT) +#define glMatrixLoaddEXT GLEW_GET_FUN(__glewMatrixLoaddEXT) +#define glMatrixLoadfEXT GLEW_GET_FUN(__glewMatrixLoadfEXT) +#define glMatrixMultTransposedEXT GLEW_GET_FUN(__glewMatrixMultTransposedEXT) +#define glMatrixMultTransposefEXT GLEW_GET_FUN(__glewMatrixMultTransposefEXT) +#define glMatrixMultdEXT GLEW_GET_FUN(__glewMatrixMultdEXT) +#define glMatrixMultfEXT GLEW_GET_FUN(__glewMatrixMultfEXT) +#define glMatrixOrthoEXT GLEW_GET_FUN(__glewMatrixOrthoEXT) +#define glMatrixPopEXT GLEW_GET_FUN(__glewMatrixPopEXT) +#define glMatrixPushEXT GLEW_GET_FUN(__glewMatrixPushEXT) +#define glMatrixRotatedEXT GLEW_GET_FUN(__glewMatrixRotatedEXT) +#define glMatrixRotatefEXT GLEW_GET_FUN(__glewMatrixRotatefEXT) +#define glMatrixScaledEXT GLEW_GET_FUN(__glewMatrixScaledEXT) +#define glMatrixScalefEXT GLEW_GET_FUN(__glewMatrixScalefEXT) +#define glMatrixTranslatedEXT GLEW_GET_FUN(__glewMatrixTranslatedEXT) +#define glMatrixTranslatefEXT GLEW_GET_FUN(__glewMatrixTranslatefEXT) +#define glMultiTexBufferEXT GLEW_GET_FUN(__glewMultiTexBufferEXT) +#define glMultiTexCoordPointerEXT GLEW_GET_FUN(__glewMultiTexCoordPointerEXT) +#define glMultiTexEnvfEXT GLEW_GET_FUN(__glewMultiTexEnvfEXT) +#define glMultiTexEnvfvEXT GLEW_GET_FUN(__glewMultiTexEnvfvEXT) +#define glMultiTexEnviEXT GLEW_GET_FUN(__glewMultiTexEnviEXT) +#define glMultiTexEnvivEXT GLEW_GET_FUN(__glewMultiTexEnvivEXT) +#define glMultiTexGendEXT GLEW_GET_FUN(__glewMultiTexGendEXT) +#define glMultiTexGendvEXT GLEW_GET_FUN(__glewMultiTexGendvEXT) +#define glMultiTexGenfEXT GLEW_GET_FUN(__glewMultiTexGenfEXT) +#define glMultiTexGenfvEXT GLEW_GET_FUN(__glewMultiTexGenfvEXT) +#define glMultiTexGeniEXT GLEW_GET_FUN(__glewMultiTexGeniEXT) +#define glMultiTexGenivEXT GLEW_GET_FUN(__glewMultiTexGenivEXT) +#define glMultiTexImage1DEXT GLEW_GET_FUN(__glewMultiTexImage1DEXT) +#define glMultiTexImage2DEXT GLEW_GET_FUN(__glewMultiTexImage2DEXT) +#define glMultiTexImage3DEXT GLEW_GET_FUN(__glewMultiTexImage3DEXT) +#define glMultiTexParameterIivEXT GLEW_GET_FUN(__glewMultiTexParameterIivEXT) +#define glMultiTexParameterIuivEXT GLEW_GET_FUN(__glewMultiTexParameterIuivEXT) +#define glMultiTexParameterfEXT GLEW_GET_FUN(__glewMultiTexParameterfEXT) +#define glMultiTexParameterfvEXT GLEW_GET_FUN(__glewMultiTexParameterfvEXT) +#define glMultiTexParameteriEXT GLEW_GET_FUN(__glewMultiTexParameteriEXT) +#define glMultiTexParameterivEXT GLEW_GET_FUN(__glewMultiTexParameterivEXT) +#define glMultiTexRenderbufferEXT GLEW_GET_FUN(__glewMultiTexRenderbufferEXT) +#define glMultiTexSubImage1DEXT GLEW_GET_FUN(__glewMultiTexSubImage1DEXT) +#define glMultiTexSubImage2DEXT GLEW_GET_FUN(__glewMultiTexSubImage2DEXT) +#define glMultiTexSubImage3DEXT GLEW_GET_FUN(__glewMultiTexSubImage3DEXT) +#define glNamedBufferDataEXT GLEW_GET_FUN(__glewNamedBufferDataEXT) +#define glNamedBufferSubDataEXT GLEW_GET_FUN(__glewNamedBufferSubDataEXT) +#define glNamedCopyBufferSubDataEXT GLEW_GET_FUN(__glewNamedCopyBufferSubDataEXT) +#define glNamedFramebufferRenderbufferEXT GLEW_GET_FUN(__glewNamedFramebufferRenderbufferEXT) +#define glNamedFramebufferTexture1DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture1DEXT) +#define glNamedFramebufferTexture2DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture2DEXT) +#define glNamedFramebufferTexture3DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture3DEXT) +#define glNamedFramebufferTextureEXT GLEW_GET_FUN(__glewNamedFramebufferTextureEXT) +#define glNamedFramebufferTextureFaceEXT GLEW_GET_FUN(__glewNamedFramebufferTextureFaceEXT) +#define glNamedFramebufferTextureLayerEXT GLEW_GET_FUN(__glewNamedFramebufferTextureLayerEXT) +#define glNamedProgramLocalParameter4dEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4dEXT) +#define glNamedProgramLocalParameter4dvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4dvEXT) +#define glNamedProgramLocalParameter4fEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4fEXT) +#define glNamedProgramLocalParameter4fvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4fvEXT) +#define glNamedProgramLocalParameterI4iEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4iEXT) +#define glNamedProgramLocalParameterI4ivEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4ivEXT) +#define glNamedProgramLocalParameterI4uiEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4uiEXT) +#define glNamedProgramLocalParameterI4uivEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4uivEXT) +#define glNamedProgramLocalParameters4fvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameters4fvEXT) +#define glNamedProgramLocalParametersI4ivEXT GLEW_GET_FUN(__glewNamedProgramLocalParametersI4ivEXT) +#define glNamedProgramLocalParametersI4uivEXT GLEW_GET_FUN(__glewNamedProgramLocalParametersI4uivEXT) +#define glNamedProgramStringEXT GLEW_GET_FUN(__glewNamedProgramStringEXT) +#define glNamedRenderbufferStorageEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageEXT) +#define glNamedRenderbufferStorageMultisampleCoverageEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageMultisampleCoverageEXT) +#define glNamedRenderbufferStorageMultisampleEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageMultisampleEXT) +#define glProgramUniform1fEXT GLEW_GET_FUN(__glewProgramUniform1fEXT) +#define glProgramUniform1fvEXT GLEW_GET_FUN(__glewProgramUniform1fvEXT) +#define glProgramUniform1iEXT GLEW_GET_FUN(__glewProgramUniform1iEXT) +#define glProgramUniform1ivEXT GLEW_GET_FUN(__glewProgramUniform1ivEXT) +#define glProgramUniform1uiEXT GLEW_GET_FUN(__glewProgramUniform1uiEXT) +#define glProgramUniform1uivEXT GLEW_GET_FUN(__glewProgramUniform1uivEXT) +#define glProgramUniform2fEXT GLEW_GET_FUN(__glewProgramUniform2fEXT) +#define glProgramUniform2fvEXT GLEW_GET_FUN(__glewProgramUniform2fvEXT) +#define glProgramUniform2iEXT GLEW_GET_FUN(__glewProgramUniform2iEXT) +#define glProgramUniform2ivEXT GLEW_GET_FUN(__glewProgramUniform2ivEXT) +#define glProgramUniform2uiEXT GLEW_GET_FUN(__glewProgramUniform2uiEXT) +#define glProgramUniform2uivEXT GLEW_GET_FUN(__glewProgramUniform2uivEXT) +#define glProgramUniform3fEXT GLEW_GET_FUN(__glewProgramUniform3fEXT) +#define glProgramUniform3fvEXT GLEW_GET_FUN(__glewProgramUniform3fvEXT) +#define glProgramUniform3iEXT GLEW_GET_FUN(__glewProgramUniform3iEXT) +#define glProgramUniform3ivEXT GLEW_GET_FUN(__glewProgramUniform3ivEXT) +#define glProgramUniform3uiEXT GLEW_GET_FUN(__glewProgramUniform3uiEXT) +#define glProgramUniform3uivEXT GLEW_GET_FUN(__glewProgramUniform3uivEXT) +#define glProgramUniform4fEXT GLEW_GET_FUN(__glewProgramUniform4fEXT) +#define glProgramUniform4fvEXT GLEW_GET_FUN(__glewProgramUniform4fvEXT) +#define glProgramUniform4iEXT GLEW_GET_FUN(__glewProgramUniform4iEXT) +#define glProgramUniform4ivEXT GLEW_GET_FUN(__glewProgramUniform4ivEXT) +#define glProgramUniform4uiEXT GLEW_GET_FUN(__glewProgramUniform4uiEXT) +#define glProgramUniform4uivEXT GLEW_GET_FUN(__glewProgramUniform4uivEXT) +#define glProgramUniformMatrix2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2fvEXT) +#define glProgramUniformMatrix2x3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x3fvEXT) +#define glProgramUniformMatrix2x4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x4fvEXT) +#define glProgramUniformMatrix3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3fvEXT) +#define glProgramUniformMatrix3x2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x2fvEXT) +#define glProgramUniformMatrix3x4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x4fvEXT) +#define glProgramUniformMatrix4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4fvEXT) +#define glProgramUniformMatrix4x2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x2fvEXT) +#define glProgramUniformMatrix4x3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x3fvEXT) +#define glPushClientAttribDefaultEXT GLEW_GET_FUN(__glewPushClientAttribDefaultEXT) +#define glTextureBufferEXT GLEW_GET_FUN(__glewTextureBufferEXT) +#define glTextureImage1DEXT GLEW_GET_FUN(__glewTextureImage1DEXT) +#define glTextureImage2DEXT GLEW_GET_FUN(__glewTextureImage2DEXT) +#define glTextureImage3DEXT GLEW_GET_FUN(__glewTextureImage3DEXT) +#define glTextureParameterIivEXT GLEW_GET_FUN(__glewTextureParameterIivEXT) +#define glTextureParameterIuivEXT GLEW_GET_FUN(__glewTextureParameterIuivEXT) +#define glTextureParameterfEXT GLEW_GET_FUN(__glewTextureParameterfEXT) +#define glTextureParameterfvEXT GLEW_GET_FUN(__glewTextureParameterfvEXT) +#define glTextureParameteriEXT GLEW_GET_FUN(__glewTextureParameteriEXT) +#define glTextureParameterivEXT GLEW_GET_FUN(__glewTextureParameterivEXT) +#define glTextureRenderbufferEXT GLEW_GET_FUN(__glewTextureRenderbufferEXT) +#define glTextureSubImage1DEXT GLEW_GET_FUN(__glewTextureSubImage1DEXT) +#define glTextureSubImage2DEXT GLEW_GET_FUN(__glewTextureSubImage2DEXT) +#define glTextureSubImage3DEXT GLEW_GET_FUN(__glewTextureSubImage3DEXT) +#define glUnmapNamedBufferEXT GLEW_GET_FUN(__glewUnmapNamedBufferEXT) +#define glVertexArrayColorOffsetEXT GLEW_GET_FUN(__glewVertexArrayColorOffsetEXT) +#define glVertexArrayEdgeFlagOffsetEXT GLEW_GET_FUN(__glewVertexArrayEdgeFlagOffsetEXT) +#define glVertexArrayFogCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayFogCoordOffsetEXT) +#define glVertexArrayIndexOffsetEXT GLEW_GET_FUN(__glewVertexArrayIndexOffsetEXT) +#define glVertexArrayMultiTexCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayMultiTexCoordOffsetEXT) +#define glVertexArrayNormalOffsetEXT GLEW_GET_FUN(__glewVertexArrayNormalOffsetEXT) +#define glVertexArraySecondaryColorOffsetEXT GLEW_GET_FUN(__glewVertexArraySecondaryColorOffsetEXT) +#define glVertexArrayTexCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayTexCoordOffsetEXT) +#define glVertexArrayVertexAttribIOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribIOffsetEXT) +#define glVertexArrayVertexAttribOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribOffsetEXT) +#define glVertexArrayVertexOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexOffsetEXT) + +#define GLEW_EXT_direct_state_access GLEW_GET_VAR(__GLEW_EXT_direct_state_access) + +#endif /* GL_EXT_direct_state_access */ + +/* -------------------------- GL_EXT_draw_buffers2 ------------------------- */ + +#ifndef GL_EXT_draw_buffers2 +#define GL_EXT_draw_buffers2 1 + +typedef void (GLAPIENTRY * PFNGLCOLORMASKINDEXEDEXTPROC) (GLuint buf, GLboolean r, GLboolean g, GLboolean b, GLboolean a); +typedef void (GLAPIENTRY * PFNGLDISABLEINDEXEDEXTPROC) (GLenum target, GLuint index); +typedef void (GLAPIENTRY * PFNGLENABLEINDEXEDEXTPROC) (GLenum target, GLuint index); +typedef void (GLAPIENTRY * PFNGLGETBOOLEANINDEXEDVEXTPROC) (GLenum value, GLuint index, GLboolean* data); +typedef void (GLAPIENTRY * PFNGLGETINTEGERINDEXEDVEXTPROC) (GLenum value, GLuint index, GLint* data); +typedef GLboolean (GLAPIENTRY * PFNGLISENABLEDINDEXEDEXTPROC) (GLenum target, GLuint index); + +#define glColorMaskIndexedEXT GLEW_GET_FUN(__glewColorMaskIndexedEXT) +#define glDisableIndexedEXT GLEW_GET_FUN(__glewDisableIndexedEXT) +#define glEnableIndexedEXT GLEW_GET_FUN(__glewEnableIndexedEXT) +#define glGetBooleanIndexedvEXT GLEW_GET_FUN(__glewGetBooleanIndexedvEXT) +#define glGetIntegerIndexedvEXT GLEW_GET_FUN(__glewGetIntegerIndexedvEXT) +#define glIsEnabledIndexedEXT GLEW_GET_FUN(__glewIsEnabledIndexedEXT) + +#define GLEW_EXT_draw_buffers2 GLEW_GET_VAR(__GLEW_EXT_draw_buffers2) + +#endif /* GL_EXT_draw_buffers2 */ + +/* ------------------------- GL_EXT_draw_instanced ------------------------- */ + +#ifndef GL_EXT_draw_instanced +#define GL_EXT_draw_instanced 1 + +typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDEXTPROC) (GLenum mode, GLint start, GLsizei count, GLsizei primcount); +typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDEXTPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount); + +#define glDrawArraysInstancedEXT GLEW_GET_FUN(__glewDrawArraysInstancedEXT) +#define glDrawElementsInstancedEXT GLEW_GET_FUN(__glewDrawElementsInstancedEXT) + +#define GLEW_EXT_draw_instanced GLEW_GET_VAR(__GLEW_EXT_draw_instanced) + +#endif /* GL_EXT_draw_instanced */ + +/* ----------------------- GL_EXT_draw_range_elements ---------------------- */ + +#ifndef GL_EXT_draw_range_elements +#define GL_EXT_draw_range_elements 1 + +#define GL_MAX_ELEMENTS_VERTICES 0x80E8 +#define GL_MAX_ELEMENTS_INDICES 0x80E9 + +typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSEXTPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); + +#define glDrawRangeElementsEXT GLEW_GET_FUN(__glewDrawRangeElementsEXT) + +#define GLEW_EXT_draw_range_elements GLEW_GET_VAR(__GLEW_EXT_draw_range_elements) + +#endif /* GL_EXT_draw_range_elements */ + +/* ---------------------------- GL_EXT_fog_coord --------------------------- */ + +#ifndef GL_EXT_fog_coord +#define GL_EXT_fog_coord 1 + +#define GL_FOG_COORDINATE_SOURCE_EXT 0x8450 +#define GL_FOG_COORDINATE_EXT 0x8451 +#define GL_FRAGMENT_DEPTH_EXT 0x8452 +#define GL_CURRENT_FOG_COORDINATE_EXT 0x8453 +#define GL_FOG_COORDINATE_ARRAY_TYPE_EXT 0x8454 +#define GL_FOG_COORDINATE_ARRAY_STRIDE_EXT 0x8455 +#define GL_FOG_COORDINATE_ARRAY_POINTER_EXT 0x8456 +#define GL_FOG_COORDINATE_ARRAY_EXT 0x8457 + +typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); +typedef void (GLAPIENTRY * PFNGLFOGCOORDDEXTPROC) (GLdouble coord); +typedef void (GLAPIENTRY * PFNGLFOGCOORDDVEXTPROC) (const GLdouble *coord); +typedef void (GLAPIENTRY * PFNGLFOGCOORDFEXTPROC) (GLfloat coord); +typedef void (GLAPIENTRY * PFNGLFOGCOORDFVEXTPROC) (const GLfloat *coord); + +#define glFogCoordPointerEXT GLEW_GET_FUN(__glewFogCoordPointerEXT) +#define glFogCoorddEXT GLEW_GET_FUN(__glewFogCoorddEXT) +#define glFogCoorddvEXT GLEW_GET_FUN(__glewFogCoorddvEXT) +#define glFogCoordfEXT GLEW_GET_FUN(__glewFogCoordfEXT) +#define glFogCoordfvEXT GLEW_GET_FUN(__glewFogCoordfvEXT) + +#define GLEW_EXT_fog_coord GLEW_GET_VAR(__GLEW_EXT_fog_coord) + +#endif /* GL_EXT_fog_coord */ + +/* ------------------------ GL_EXT_fragment_lighting ----------------------- */ + +#ifndef GL_EXT_fragment_lighting +#define GL_EXT_fragment_lighting 1 + +#define GL_FRAGMENT_LIGHTING_EXT 0x8400 +#define GL_FRAGMENT_COLOR_MATERIAL_EXT 0x8401 +#define GL_FRAGMENT_COLOR_MATERIAL_FACE_EXT 0x8402 +#define GL_FRAGMENT_COLOR_MATERIAL_PARAMETER_EXT 0x8403 +#define GL_MAX_FRAGMENT_LIGHTS_EXT 0x8404 +#define GL_MAX_ACTIVE_LIGHTS_EXT 0x8405 +#define GL_CURRENT_RASTER_NORMAL_EXT 0x8406 +#define GL_LIGHT_ENV_MODE_EXT 0x8407 +#define GL_FRAGMENT_LIGHT_MODEL_LOCAL_VIEWER_EXT 0x8408 +#define GL_FRAGMENT_LIGHT_MODEL_TWO_SIDE_EXT 0x8409 +#define GL_FRAGMENT_LIGHT_MODEL_AMBIENT_EXT 0x840A +#define GL_FRAGMENT_LIGHT_MODEL_NORMAL_INTERPOLATION_EXT 0x840B +#define GL_FRAGMENT_LIGHT0_EXT 0x840C +#define GL_FRAGMENT_LIGHT7_EXT 0x8413 + +typedef void (GLAPIENTRY * PFNGLFRAGMENTCOLORMATERIALEXTPROC) (GLenum face, GLenum mode); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFEXTPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFVEXTPROC) (GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIEXTPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIVEXTPROC) (GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFEXTPROC) (GLenum light, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFVEXTPROC) (GLenum light, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIEXTPROC) (GLenum light, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIVEXTPROC) (GLenum light, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFEXTPROC) (GLenum face, GLenum pname, const GLfloat param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFVEXTPROC) (GLenum face, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIEXTPROC) (GLenum face, GLenum pname, const GLint param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIVEXTPROC) (GLenum face, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTFVEXTPROC) (GLenum light, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTIVEXTPROC) (GLenum light, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALFVEXTPROC) (GLenum face, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALIVEXTPROC) (GLenum face, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLLIGHTENVIEXTPROC) (GLenum pname, GLint param); + +#define glFragmentColorMaterialEXT GLEW_GET_FUN(__glewFragmentColorMaterialEXT) +#define glFragmentLightModelfEXT GLEW_GET_FUN(__glewFragmentLightModelfEXT) +#define glFragmentLightModelfvEXT GLEW_GET_FUN(__glewFragmentLightModelfvEXT) +#define glFragmentLightModeliEXT GLEW_GET_FUN(__glewFragmentLightModeliEXT) +#define glFragmentLightModelivEXT GLEW_GET_FUN(__glewFragmentLightModelivEXT) +#define glFragmentLightfEXT GLEW_GET_FUN(__glewFragmentLightfEXT) +#define glFragmentLightfvEXT GLEW_GET_FUN(__glewFragmentLightfvEXT) +#define glFragmentLightiEXT GLEW_GET_FUN(__glewFragmentLightiEXT) +#define glFragmentLightivEXT GLEW_GET_FUN(__glewFragmentLightivEXT) +#define glFragmentMaterialfEXT GLEW_GET_FUN(__glewFragmentMaterialfEXT) +#define glFragmentMaterialfvEXT GLEW_GET_FUN(__glewFragmentMaterialfvEXT) +#define glFragmentMaterialiEXT GLEW_GET_FUN(__glewFragmentMaterialiEXT) +#define glFragmentMaterialivEXT GLEW_GET_FUN(__glewFragmentMaterialivEXT) +#define glGetFragmentLightfvEXT GLEW_GET_FUN(__glewGetFragmentLightfvEXT) +#define glGetFragmentLightivEXT GLEW_GET_FUN(__glewGetFragmentLightivEXT) +#define glGetFragmentMaterialfvEXT GLEW_GET_FUN(__glewGetFragmentMaterialfvEXT) +#define glGetFragmentMaterialivEXT GLEW_GET_FUN(__glewGetFragmentMaterialivEXT) +#define glLightEnviEXT GLEW_GET_FUN(__glewLightEnviEXT) + +#define GLEW_EXT_fragment_lighting GLEW_GET_VAR(__GLEW_EXT_fragment_lighting) + +#endif /* GL_EXT_fragment_lighting */ + +/* ------------------------ GL_EXT_framebuffer_blit ------------------------ */ + +#ifndef GL_EXT_framebuffer_blit +#define GL_EXT_framebuffer_blit 1 + +#define GL_DRAW_FRAMEBUFFER_BINDING_EXT 0x8CA6 +#define GL_READ_FRAMEBUFFER_EXT 0x8CA8 +#define GL_DRAW_FRAMEBUFFER_EXT 0x8CA9 +#define GL_READ_FRAMEBUFFER_BINDING_EXT 0x8CAA + +typedef void (GLAPIENTRY * PFNGLBLITFRAMEBUFFEREXTPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); + +#define glBlitFramebufferEXT GLEW_GET_FUN(__glewBlitFramebufferEXT) + +#define GLEW_EXT_framebuffer_blit GLEW_GET_VAR(__GLEW_EXT_framebuffer_blit) + +#endif /* GL_EXT_framebuffer_blit */ + +/* --------------------- GL_EXT_framebuffer_multisample -------------------- */ + +#ifndef GL_EXT_framebuffer_multisample +#define GL_EXT_framebuffer_multisample 1 + +#define GL_RENDERBUFFER_SAMPLES_EXT 0x8CAB +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_EXT 0x8D56 +#define GL_MAX_SAMPLES_EXT 0x8D57 + +typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); + +#define glRenderbufferStorageMultisampleEXT GLEW_GET_FUN(__glewRenderbufferStorageMultisampleEXT) + +#define GLEW_EXT_framebuffer_multisample GLEW_GET_VAR(__GLEW_EXT_framebuffer_multisample) + +#endif /* GL_EXT_framebuffer_multisample */ + +/* ----------------------- GL_EXT_framebuffer_object ----------------------- */ + +#ifndef GL_EXT_framebuffer_object +#define GL_EXT_framebuffer_object 1 + +#define GL_INVALID_FRAMEBUFFER_OPERATION_EXT 0x0506 +#define GL_MAX_RENDERBUFFER_SIZE_EXT 0x84E8 +#define GL_FRAMEBUFFER_BINDING_EXT 0x8CA6 +#define GL_RENDERBUFFER_BINDING_EXT 0x8CA7 +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE_EXT 0x8CD0 +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME_EXT 0x8CD1 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL_EXT 0x8CD2 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE_EXT 0x8CD3 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET_EXT 0x8CD4 +#define GL_FRAMEBUFFER_COMPLETE_EXT 0x8CD5 +#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT_EXT 0x8CD6 +#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT_EXT 0x8CD7 +#define GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS_EXT 0x8CD9 +#define GL_FRAMEBUFFER_INCOMPLETE_FORMATS_EXT 0x8CDA +#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER_EXT 0x8CDB +#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER_EXT 0x8CDC +#define GL_FRAMEBUFFER_UNSUPPORTED_EXT 0x8CDD +#define GL_MAX_COLOR_ATTACHMENTS_EXT 0x8CDF +#define GL_COLOR_ATTACHMENT0_EXT 0x8CE0 +#define GL_COLOR_ATTACHMENT1_EXT 0x8CE1 +#define GL_COLOR_ATTACHMENT2_EXT 0x8CE2 +#define GL_COLOR_ATTACHMENT3_EXT 0x8CE3 +#define GL_COLOR_ATTACHMENT4_EXT 0x8CE4 +#define GL_COLOR_ATTACHMENT5_EXT 0x8CE5 +#define GL_COLOR_ATTACHMENT6_EXT 0x8CE6 +#define GL_COLOR_ATTACHMENT7_EXT 0x8CE7 +#define GL_COLOR_ATTACHMENT8_EXT 0x8CE8 +#define GL_COLOR_ATTACHMENT9_EXT 0x8CE9 +#define GL_COLOR_ATTACHMENT10_EXT 0x8CEA +#define GL_COLOR_ATTACHMENT11_EXT 0x8CEB +#define GL_COLOR_ATTACHMENT12_EXT 0x8CEC +#define GL_COLOR_ATTACHMENT13_EXT 0x8CED +#define GL_COLOR_ATTACHMENT14_EXT 0x8CEE +#define GL_COLOR_ATTACHMENT15_EXT 0x8CEF +#define GL_DEPTH_ATTACHMENT_EXT 0x8D00 +#define GL_STENCIL_ATTACHMENT_EXT 0x8D20 +#define GL_FRAMEBUFFER_EXT 0x8D40 +#define GL_RENDERBUFFER_EXT 0x8D41 +#define GL_RENDERBUFFER_WIDTH_EXT 0x8D42 +#define GL_RENDERBUFFER_HEIGHT_EXT 0x8D43 +#define GL_RENDERBUFFER_INTERNAL_FORMAT_EXT 0x8D44 +#define GL_STENCIL_INDEX1_EXT 0x8D46 +#define GL_STENCIL_INDEX4_EXT 0x8D47 +#define GL_STENCIL_INDEX8_EXT 0x8D48 +#define GL_STENCIL_INDEX16_EXT 0x8D49 +#define GL_RENDERBUFFER_RED_SIZE_EXT 0x8D50 +#define GL_RENDERBUFFER_GREEN_SIZE_EXT 0x8D51 +#define GL_RENDERBUFFER_BLUE_SIZE_EXT 0x8D52 +#define GL_RENDERBUFFER_ALPHA_SIZE_EXT 0x8D53 +#define GL_RENDERBUFFER_DEPTH_SIZE_EXT 0x8D54 +#define GL_RENDERBUFFER_STENCIL_SIZE_EXT 0x8D55 + +typedef void (GLAPIENTRY * PFNGLBINDFRAMEBUFFEREXTPROC) (GLenum target, GLuint framebuffer); +typedef void (GLAPIENTRY * PFNGLBINDRENDERBUFFEREXTPROC) (GLenum target, GLuint renderbuffer); +typedef GLenum (GLAPIENTRY * PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLDELETEFRAMEBUFFERSEXTPROC) (GLsizei n, const GLuint* framebuffers); +typedef void (GLAPIENTRY * PFNGLDELETERENDERBUFFERSEXTPROC) (GLsizei n, const GLuint* renderbuffers); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE1DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE2DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE3DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +typedef void (GLAPIENTRY * PFNGLGENFRAMEBUFFERSEXTPROC) (GLsizei n, GLuint* framebuffers); +typedef void (GLAPIENTRY * PFNGLGENRENDERBUFFERSEXTPROC) (GLsizei n, GLuint* renderbuffers); +typedef void (GLAPIENTRY * PFNGLGENERATEMIPMAPEXTPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLenum target, GLenum attachment, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISFRAMEBUFFEREXTPROC) (GLuint framebuffer); +typedef GLboolean (GLAPIENTRY * PFNGLISRENDERBUFFEREXTPROC) (GLuint renderbuffer); +typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); + +#define glBindFramebufferEXT GLEW_GET_FUN(__glewBindFramebufferEXT) +#define glBindRenderbufferEXT GLEW_GET_FUN(__glewBindRenderbufferEXT) +#define glCheckFramebufferStatusEXT GLEW_GET_FUN(__glewCheckFramebufferStatusEXT) +#define glDeleteFramebuffersEXT GLEW_GET_FUN(__glewDeleteFramebuffersEXT) +#define glDeleteRenderbuffersEXT GLEW_GET_FUN(__glewDeleteRenderbuffersEXT) +#define glFramebufferRenderbufferEXT GLEW_GET_FUN(__glewFramebufferRenderbufferEXT) +#define glFramebufferTexture1DEXT GLEW_GET_FUN(__glewFramebufferTexture1DEXT) +#define glFramebufferTexture2DEXT GLEW_GET_FUN(__glewFramebufferTexture2DEXT) +#define glFramebufferTexture3DEXT GLEW_GET_FUN(__glewFramebufferTexture3DEXT) +#define glGenFramebuffersEXT GLEW_GET_FUN(__glewGenFramebuffersEXT) +#define glGenRenderbuffersEXT GLEW_GET_FUN(__glewGenRenderbuffersEXT) +#define glGenerateMipmapEXT GLEW_GET_FUN(__glewGenerateMipmapEXT) +#define glGetFramebufferAttachmentParameterivEXT GLEW_GET_FUN(__glewGetFramebufferAttachmentParameterivEXT) +#define glGetRenderbufferParameterivEXT GLEW_GET_FUN(__glewGetRenderbufferParameterivEXT) +#define glIsFramebufferEXT GLEW_GET_FUN(__glewIsFramebufferEXT) +#define glIsRenderbufferEXT GLEW_GET_FUN(__glewIsRenderbufferEXT) +#define glRenderbufferStorageEXT GLEW_GET_FUN(__glewRenderbufferStorageEXT) + +#define GLEW_EXT_framebuffer_object GLEW_GET_VAR(__GLEW_EXT_framebuffer_object) + +#endif /* GL_EXT_framebuffer_object */ + +/* ------------------------ GL_EXT_framebuffer_sRGB ------------------------ */ + +#ifndef GL_EXT_framebuffer_sRGB +#define GL_EXT_framebuffer_sRGB 1 + +#define GL_FRAMEBUFFER_SRGB_EXT 0x8DB9 +#define GL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x8DBA + +#define GLEW_EXT_framebuffer_sRGB GLEW_GET_VAR(__GLEW_EXT_framebuffer_sRGB) + +#endif /* GL_EXT_framebuffer_sRGB */ + +/* ------------------------ GL_EXT_geometry_shader4 ------------------------ */ + +#ifndef GL_EXT_geometry_shader4 +#define GL_EXT_geometry_shader4 1 + +#define GL_LINES_ADJACENCY_EXT 0xA +#define GL_LINE_STRIP_ADJACENCY_EXT 0xB +#define GL_TRIANGLES_ADJACENCY_EXT 0xC +#define GL_TRIANGLE_STRIP_ADJACENCY_EXT 0xD +#define GL_PROGRAM_POINT_SIZE_EXT 0x8642 +#define GL_MAX_VARYING_COMPONENTS_EXT 0x8B4B +#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_EXT 0x8C29 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER_EXT 0x8CD4 +#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED_EXT 0x8DA7 +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_EXT 0x8DA8 +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_EXT 0x8DA9 +#define GL_GEOMETRY_SHADER_EXT 0x8DD9 +#define GL_GEOMETRY_VERTICES_OUT_EXT 0x8DDA +#define GL_GEOMETRY_INPUT_TYPE_EXT 0x8DDB +#define GL_GEOMETRY_OUTPUT_TYPE_EXT 0x8DDC +#define GL_MAX_GEOMETRY_VARYING_COMPONENTS_EXT 0x8DDD +#define GL_MAX_VERTEX_VARYING_COMPONENTS_EXT 0x8DDE +#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_EXT 0x8DDF +#define GL_MAX_GEOMETRY_OUTPUT_VERTICES_EXT 0x8DE0 +#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_EXT 0x8DE1 + +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); +typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIEXTPROC) (GLuint program, GLenum pname, GLint value); + +#define glFramebufferTextureEXT GLEW_GET_FUN(__glewFramebufferTextureEXT) +#define glFramebufferTextureFaceEXT GLEW_GET_FUN(__glewFramebufferTextureFaceEXT) +#define glFramebufferTextureLayerEXT GLEW_GET_FUN(__glewFramebufferTextureLayerEXT) +#define glProgramParameteriEXT GLEW_GET_FUN(__glewProgramParameteriEXT) + +#define GLEW_EXT_geometry_shader4 GLEW_GET_VAR(__GLEW_EXT_geometry_shader4) + +#endif /* GL_EXT_geometry_shader4 */ + +/* --------------------- GL_EXT_gpu_program_parameters --------------------- */ + +#ifndef GL_EXT_gpu_program_parameters +#define GL_EXT_gpu_program_parameters 1 + +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat* params); + +#define glProgramEnvParameters4fvEXT GLEW_GET_FUN(__glewProgramEnvParameters4fvEXT) +#define glProgramLocalParameters4fvEXT GLEW_GET_FUN(__glewProgramLocalParameters4fvEXT) + +#define GLEW_EXT_gpu_program_parameters GLEW_GET_VAR(__GLEW_EXT_gpu_program_parameters) + +#endif /* GL_EXT_gpu_program_parameters */ + +/* --------------------------- GL_EXT_gpu_shader4 -------------------------- */ + +#ifndef GL_EXT_gpu_shader4 +#define GL_EXT_gpu_shader4 1 + +#define GL_VERTEX_ATTRIB_ARRAY_INTEGER_EXT 0x88FD +#define GL_SAMPLER_1D_ARRAY_EXT 0x8DC0 +#define GL_SAMPLER_2D_ARRAY_EXT 0x8DC1 +#define GL_SAMPLER_BUFFER_EXT 0x8DC2 +#define GL_SAMPLER_1D_ARRAY_SHADOW_EXT 0x8DC3 +#define GL_SAMPLER_2D_ARRAY_SHADOW_EXT 0x8DC4 +#define GL_SAMPLER_CUBE_SHADOW_EXT 0x8DC5 +#define GL_UNSIGNED_INT_VEC2_EXT 0x8DC6 +#define GL_UNSIGNED_INT_VEC3_EXT 0x8DC7 +#define GL_UNSIGNED_INT_VEC4_EXT 0x8DC8 +#define GL_INT_SAMPLER_1D_EXT 0x8DC9 +#define GL_INT_SAMPLER_2D_EXT 0x8DCA +#define GL_INT_SAMPLER_3D_EXT 0x8DCB +#define GL_INT_SAMPLER_CUBE_EXT 0x8DCC +#define GL_INT_SAMPLER_2D_RECT_EXT 0x8DCD +#define GL_INT_SAMPLER_1D_ARRAY_EXT 0x8DCE +#define GL_INT_SAMPLER_2D_ARRAY_EXT 0x8DCF +#define GL_INT_SAMPLER_BUFFER_EXT 0x8DD0 +#define GL_UNSIGNED_INT_SAMPLER_1D_EXT 0x8DD1 +#define GL_UNSIGNED_INT_SAMPLER_2D_EXT 0x8DD2 +#define GL_UNSIGNED_INT_SAMPLER_3D_EXT 0x8DD3 +#define GL_UNSIGNED_INT_SAMPLER_CUBE_EXT 0x8DD4 +#define GL_UNSIGNED_INT_SAMPLER_2D_RECT_EXT 0x8DD5 +#define GL_UNSIGNED_INT_SAMPLER_1D_ARRAY_EXT 0x8DD6 +#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY_EXT 0x8DD7 +#define GL_UNSIGNED_INT_SAMPLER_BUFFER_EXT 0x8DD8 + +typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONEXTPROC) (GLuint program, GLuint color, const GLchar *name); +typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATALOCATIONEXTPROC) (GLuint program, const GLchar *name); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMUIVEXTPROC) (GLuint program, GLint location, GLuint *params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIIVEXTPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIUIVEXTPROC) (GLuint index, GLenum pname, GLuint *params); +typedef void (GLAPIENTRY * PFNGLUNIFORM1UIEXTPROC) (GLint location, GLuint v0); +typedef void (GLAPIENTRY * PFNGLUNIFORM1UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (GLAPIENTRY * PFNGLUNIFORM2UIEXTPROC) (GLint location, GLuint v0, GLuint v1); +typedef void (GLAPIENTRY * PFNGLUNIFORM2UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (GLAPIENTRY * PFNGLUNIFORM3UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2); +typedef void (GLAPIENTRY * PFNGLUNIFORM3UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (GLAPIENTRY * PFNGLUNIFORM4UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +typedef void (GLAPIENTRY * PFNGLUNIFORM4UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IEXTPROC) (GLuint index, GLint x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IVEXTPROC) (GLuint index, const GLint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIEXTPROC) (GLuint index, GLuint x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IEXTPROC) (GLuint index, GLint x, GLint y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IVEXTPROC) (GLuint index, const GLint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIEXTPROC) (GLuint index, GLuint x, GLuint y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IEXTPROC) (GLuint index, GLint x, GLint y, GLint z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IVEXTPROC) (GLuint index, const GLint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4BVEXTPROC) (GLuint index, const GLbyte *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IEXTPROC) (GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IVEXTPROC) (GLuint index, const GLint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4SVEXTPROC) (GLuint index, const GLshort *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UBVEXTPROC) (GLuint index, const GLubyte *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4USVEXTPROC) (GLuint index, const GLushort *v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); + +#define glBindFragDataLocationEXT GLEW_GET_FUN(__glewBindFragDataLocationEXT) +#define glGetFragDataLocationEXT GLEW_GET_FUN(__glewGetFragDataLocationEXT) +#define glGetUniformuivEXT GLEW_GET_FUN(__glewGetUniformuivEXT) +#define glGetVertexAttribIivEXT GLEW_GET_FUN(__glewGetVertexAttribIivEXT) +#define glGetVertexAttribIuivEXT GLEW_GET_FUN(__glewGetVertexAttribIuivEXT) +#define glUniform1uiEXT GLEW_GET_FUN(__glewUniform1uiEXT) +#define glUniform1uivEXT GLEW_GET_FUN(__glewUniform1uivEXT) +#define glUniform2uiEXT GLEW_GET_FUN(__glewUniform2uiEXT) +#define glUniform2uivEXT GLEW_GET_FUN(__glewUniform2uivEXT) +#define glUniform3uiEXT GLEW_GET_FUN(__glewUniform3uiEXT) +#define glUniform3uivEXT GLEW_GET_FUN(__glewUniform3uivEXT) +#define glUniform4uiEXT GLEW_GET_FUN(__glewUniform4uiEXT) +#define glUniform4uivEXT GLEW_GET_FUN(__glewUniform4uivEXT) +#define glVertexAttribI1iEXT GLEW_GET_FUN(__glewVertexAttribI1iEXT) +#define glVertexAttribI1ivEXT GLEW_GET_FUN(__glewVertexAttribI1ivEXT) +#define glVertexAttribI1uiEXT GLEW_GET_FUN(__glewVertexAttribI1uiEXT) +#define glVertexAttribI1uivEXT GLEW_GET_FUN(__glewVertexAttribI1uivEXT) +#define glVertexAttribI2iEXT GLEW_GET_FUN(__glewVertexAttribI2iEXT) +#define glVertexAttribI2ivEXT GLEW_GET_FUN(__glewVertexAttribI2ivEXT) +#define glVertexAttribI2uiEXT GLEW_GET_FUN(__glewVertexAttribI2uiEXT) +#define glVertexAttribI2uivEXT GLEW_GET_FUN(__glewVertexAttribI2uivEXT) +#define glVertexAttribI3iEXT GLEW_GET_FUN(__glewVertexAttribI3iEXT) +#define glVertexAttribI3ivEXT GLEW_GET_FUN(__glewVertexAttribI3ivEXT) +#define glVertexAttribI3uiEXT GLEW_GET_FUN(__glewVertexAttribI3uiEXT) +#define glVertexAttribI3uivEXT GLEW_GET_FUN(__glewVertexAttribI3uivEXT) +#define glVertexAttribI4bvEXT GLEW_GET_FUN(__glewVertexAttribI4bvEXT) +#define glVertexAttribI4iEXT GLEW_GET_FUN(__glewVertexAttribI4iEXT) +#define glVertexAttribI4ivEXT GLEW_GET_FUN(__glewVertexAttribI4ivEXT) +#define glVertexAttribI4svEXT GLEW_GET_FUN(__glewVertexAttribI4svEXT) +#define glVertexAttribI4ubvEXT GLEW_GET_FUN(__glewVertexAttribI4ubvEXT) +#define glVertexAttribI4uiEXT GLEW_GET_FUN(__glewVertexAttribI4uiEXT) +#define glVertexAttribI4uivEXT GLEW_GET_FUN(__glewVertexAttribI4uivEXT) +#define glVertexAttribI4usvEXT GLEW_GET_FUN(__glewVertexAttribI4usvEXT) +#define glVertexAttribIPointerEXT GLEW_GET_FUN(__glewVertexAttribIPointerEXT) + +#define GLEW_EXT_gpu_shader4 GLEW_GET_VAR(__GLEW_EXT_gpu_shader4) + +#endif /* GL_EXT_gpu_shader4 */ + +/* ---------------------------- GL_EXT_histogram --------------------------- */ + +#ifndef GL_EXT_histogram +#define GL_EXT_histogram 1 + +#define GL_HISTOGRAM_EXT 0x8024 +#define GL_PROXY_HISTOGRAM_EXT 0x8025 +#define GL_HISTOGRAM_WIDTH_EXT 0x8026 +#define GL_HISTOGRAM_FORMAT_EXT 0x8027 +#define GL_HISTOGRAM_RED_SIZE_EXT 0x8028 +#define GL_HISTOGRAM_GREEN_SIZE_EXT 0x8029 +#define GL_HISTOGRAM_BLUE_SIZE_EXT 0x802A +#define GL_HISTOGRAM_ALPHA_SIZE_EXT 0x802B +#define GL_HISTOGRAM_LUMINANCE_SIZE_EXT 0x802C +#define GL_HISTOGRAM_SINK_EXT 0x802D +#define GL_MINMAX_EXT 0x802E +#define GL_MINMAX_FORMAT_EXT 0x802F +#define GL_MINMAX_SINK_EXT 0x8030 + +typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void* values); +typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETMINMAXEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void* values); +typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLHISTOGRAMEXTPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +typedef void (GLAPIENTRY * PFNGLMINMAXEXTPROC) (GLenum target, GLenum internalformat, GLboolean sink); +typedef void (GLAPIENTRY * PFNGLRESETHISTOGRAMEXTPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLRESETMINMAXEXTPROC) (GLenum target); + +#define glGetHistogramEXT GLEW_GET_FUN(__glewGetHistogramEXT) +#define glGetHistogramParameterfvEXT GLEW_GET_FUN(__glewGetHistogramParameterfvEXT) +#define glGetHistogramParameterivEXT GLEW_GET_FUN(__glewGetHistogramParameterivEXT) +#define glGetMinmaxEXT GLEW_GET_FUN(__glewGetMinmaxEXT) +#define glGetMinmaxParameterfvEXT GLEW_GET_FUN(__glewGetMinmaxParameterfvEXT) +#define glGetMinmaxParameterivEXT GLEW_GET_FUN(__glewGetMinmaxParameterivEXT) +#define glHistogramEXT GLEW_GET_FUN(__glewHistogramEXT) +#define glMinmaxEXT GLEW_GET_FUN(__glewMinmaxEXT) +#define glResetHistogramEXT GLEW_GET_FUN(__glewResetHistogramEXT) +#define glResetMinmaxEXT GLEW_GET_FUN(__glewResetMinmaxEXT) + +#define GLEW_EXT_histogram GLEW_GET_VAR(__GLEW_EXT_histogram) + +#endif /* GL_EXT_histogram */ + +/* ----------------------- GL_EXT_index_array_formats ---------------------- */ + +#ifndef GL_EXT_index_array_formats +#define GL_EXT_index_array_formats 1 + +#define GLEW_EXT_index_array_formats GLEW_GET_VAR(__GLEW_EXT_index_array_formats) + +#endif /* GL_EXT_index_array_formats */ + +/* --------------------------- GL_EXT_index_func --------------------------- */ + +#ifndef GL_EXT_index_func +#define GL_EXT_index_func 1 + +typedef void (GLAPIENTRY * PFNGLINDEXFUNCEXTPROC) (GLenum func, GLfloat ref); + +#define glIndexFuncEXT GLEW_GET_FUN(__glewIndexFuncEXT) + +#define GLEW_EXT_index_func GLEW_GET_VAR(__GLEW_EXT_index_func) + +#endif /* GL_EXT_index_func */ + +/* ------------------------- GL_EXT_index_material ------------------------- */ + +#ifndef GL_EXT_index_material +#define GL_EXT_index_material 1 + +typedef void (GLAPIENTRY * PFNGLINDEXMATERIALEXTPROC) (GLenum face, GLenum mode); + +#define glIndexMaterialEXT GLEW_GET_FUN(__glewIndexMaterialEXT) + +#define GLEW_EXT_index_material GLEW_GET_VAR(__GLEW_EXT_index_material) + +#endif /* GL_EXT_index_material */ + +/* -------------------------- GL_EXT_index_texture ------------------------- */ + +#ifndef GL_EXT_index_texture +#define GL_EXT_index_texture 1 + +#define GLEW_EXT_index_texture GLEW_GET_VAR(__GLEW_EXT_index_texture) + +#endif /* GL_EXT_index_texture */ + +/* -------------------------- GL_EXT_light_texture ------------------------- */ + +#ifndef GL_EXT_light_texture +#define GL_EXT_light_texture 1 + +#define GL_FRAGMENT_MATERIAL_EXT 0x8349 +#define GL_FRAGMENT_NORMAL_EXT 0x834A +#define GL_FRAGMENT_COLOR_EXT 0x834C +#define GL_ATTENUATION_EXT 0x834D +#define GL_SHADOW_ATTENUATION_EXT 0x834E +#define GL_TEXTURE_APPLICATION_MODE_EXT 0x834F +#define GL_TEXTURE_LIGHT_EXT 0x8350 +#define GL_TEXTURE_MATERIAL_FACE_EXT 0x8351 +#define GL_TEXTURE_MATERIAL_PARAMETER_EXT 0x8352 +#define GL_FRAGMENT_DEPTH_EXT 0x8452 + +typedef void (GLAPIENTRY * PFNGLAPPLYTEXTUREEXTPROC) (GLenum mode); +typedef void (GLAPIENTRY * PFNGLTEXTURELIGHTEXTPROC) (GLenum pname); +typedef void (GLAPIENTRY * PFNGLTEXTUREMATERIALEXTPROC) (GLenum face, GLenum mode); + +#define glApplyTextureEXT GLEW_GET_FUN(__glewApplyTextureEXT) +#define glTextureLightEXT GLEW_GET_FUN(__glewTextureLightEXT) +#define glTextureMaterialEXT GLEW_GET_FUN(__glewTextureMaterialEXT) + +#define GLEW_EXT_light_texture GLEW_GET_VAR(__GLEW_EXT_light_texture) + +#endif /* GL_EXT_light_texture */ + +/* ------------------------- GL_EXT_misc_attribute ------------------------- */ + +#ifndef GL_EXT_misc_attribute +#define GL_EXT_misc_attribute 1 + +#define GLEW_EXT_misc_attribute GLEW_GET_VAR(__GLEW_EXT_misc_attribute) + +#endif /* GL_EXT_misc_attribute */ + +/* ------------------------ GL_EXT_multi_draw_arrays ----------------------- */ + +#ifndef GL_EXT_multi_draw_arrays +#define GL_EXT_multi_draw_arrays 1 + +typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSEXTPROC) (GLenum mode, GLint* first, GLsizei *count, GLsizei primcount); +typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSEXTPROC) (GLenum mode, GLsizei* count, GLenum type, const GLvoid **indices, GLsizei primcount); + +#define glMultiDrawArraysEXT GLEW_GET_FUN(__glewMultiDrawArraysEXT) +#define glMultiDrawElementsEXT GLEW_GET_FUN(__glewMultiDrawElementsEXT) + +#define GLEW_EXT_multi_draw_arrays GLEW_GET_VAR(__GLEW_EXT_multi_draw_arrays) + +#endif /* GL_EXT_multi_draw_arrays */ + +/* --------------------------- GL_EXT_multisample -------------------------- */ + +#ifndef GL_EXT_multisample +#define GL_EXT_multisample 1 + +#define GL_MULTISAMPLE_EXT 0x809D +#define GL_SAMPLE_ALPHA_TO_MASK_EXT 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE_EXT 0x809F +#define GL_SAMPLE_MASK_EXT 0x80A0 +#define GL_1PASS_EXT 0x80A1 +#define GL_2PASS_0_EXT 0x80A2 +#define GL_2PASS_1_EXT 0x80A3 +#define GL_4PASS_0_EXT 0x80A4 +#define GL_4PASS_1_EXT 0x80A5 +#define GL_4PASS_2_EXT 0x80A6 +#define GL_4PASS_3_EXT 0x80A7 +#define GL_SAMPLE_BUFFERS_EXT 0x80A8 +#define GL_SAMPLES_EXT 0x80A9 +#define GL_SAMPLE_MASK_VALUE_EXT 0x80AA +#define GL_SAMPLE_MASK_INVERT_EXT 0x80AB +#define GL_SAMPLE_PATTERN_EXT 0x80AC +#define GL_MULTISAMPLE_BIT_EXT 0x20000000 + +typedef void (GLAPIENTRY * PFNGLSAMPLEMASKEXTPROC) (GLclampf value, GLboolean invert); +typedef void (GLAPIENTRY * PFNGLSAMPLEPATTERNEXTPROC) (GLenum pattern); + +#define glSampleMaskEXT GLEW_GET_FUN(__glewSampleMaskEXT) +#define glSamplePatternEXT GLEW_GET_FUN(__glewSamplePatternEXT) + +#define GLEW_EXT_multisample GLEW_GET_VAR(__GLEW_EXT_multisample) + +#endif /* GL_EXT_multisample */ + +/* ---------------------- GL_EXT_packed_depth_stencil ---------------------- */ + +#ifndef GL_EXT_packed_depth_stencil +#define GL_EXT_packed_depth_stencil 1 + +#define GL_DEPTH_STENCIL_EXT 0x84F9 +#define GL_UNSIGNED_INT_24_8_EXT 0x84FA +#define GL_DEPTH24_STENCIL8_EXT 0x88F0 +#define GL_TEXTURE_STENCIL_SIZE_EXT 0x88F1 + +#define GLEW_EXT_packed_depth_stencil GLEW_GET_VAR(__GLEW_EXT_packed_depth_stencil) + +#endif /* GL_EXT_packed_depth_stencil */ + +/* -------------------------- GL_EXT_packed_float -------------------------- */ + +#ifndef GL_EXT_packed_float +#define GL_EXT_packed_float 1 + +#define GL_R11F_G11F_B10F_EXT 0x8C3A +#define GL_UNSIGNED_INT_10F_11F_11F_REV_EXT 0x8C3B +#define GL_RGBA_SIGNED_COMPONENTS_EXT 0x8C3C + +#define GLEW_EXT_packed_float GLEW_GET_VAR(__GLEW_EXT_packed_float) + +#endif /* GL_EXT_packed_float */ + +/* -------------------------- GL_EXT_packed_pixels ------------------------- */ + +#ifndef GL_EXT_packed_pixels +#define GL_EXT_packed_pixels 1 + +#define GL_UNSIGNED_BYTE_3_3_2_EXT 0x8032 +#define GL_UNSIGNED_SHORT_4_4_4_4_EXT 0x8033 +#define GL_UNSIGNED_SHORT_5_5_5_1_EXT 0x8034 +#define GL_UNSIGNED_INT_8_8_8_8_EXT 0x8035 +#define GL_UNSIGNED_INT_10_10_10_2_EXT 0x8036 + +#define GLEW_EXT_packed_pixels GLEW_GET_VAR(__GLEW_EXT_packed_pixels) + +#endif /* GL_EXT_packed_pixels */ + +/* ------------------------ GL_EXT_paletted_texture ------------------------ */ + +#ifndef GL_EXT_paletted_texture +#define GL_EXT_paletted_texture 1 + +#define GL_TEXTURE_1D 0x0DE0 +#define GL_TEXTURE_2D 0x0DE1 +#define GL_PROXY_TEXTURE_1D 0x8063 +#define GL_PROXY_TEXTURE_2D 0x8064 +#define GL_TEXTURE_3D_EXT 0x806F +#define GL_PROXY_TEXTURE_3D_EXT 0x8070 +#define GL_COLOR_TABLE_FORMAT_EXT 0x80D8 +#define GL_COLOR_TABLE_WIDTH_EXT 0x80D9 +#define GL_COLOR_TABLE_RED_SIZE_EXT 0x80DA +#define GL_COLOR_TABLE_GREEN_SIZE_EXT 0x80DB +#define GL_COLOR_TABLE_BLUE_SIZE_EXT 0x80DC +#define GL_COLOR_TABLE_ALPHA_SIZE_EXT 0x80DD +#define GL_COLOR_TABLE_LUMINANCE_SIZE_EXT 0x80DE +#define GL_COLOR_TABLE_INTENSITY_SIZE_EXT 0x80DF +#define GL_COLOR_INDEX1_EXT 0x80E2 +#define GL_COLOR_INDEX2_EXT 0x80E3 +#define GL_COLOR_INDEX4_EXT 0x80E4 +#define GL_COLOR_INDEX8_EXT 0x80E5 +#define GL_COLOR_INDEX12_EXT 0x80E6 +#define GL_COLOR_INDEX16_EXT 0x80E7 +#define GL_TEXTURE_INDEX_SIZE_EXT 0x80ED +#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 +#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B + +typedef void (GLAPIENTRY * PFNGLCOLORTABLEEXTPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const void* data); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEEXTPROC) (GLenum target, GLenum format, GLenum type, void* data); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); + +#define glColorTableEXT GLEW_GET_FUN(__glewColorTableEXT) +#define glGetColorTableEXT GLEW_GET_FUN(__glewGetColorTableEXT) +#define glGetColorTableParameterfvEXT GLEW_GET_FUN(__glewGetColorTableParameterfvEXT) +#define glGetColorTableParameterivEXT GLEW_GET_FUN(__glewGetColorTableParameterivEXT) + +#define GLEW_EXT_paletted_texture GLEW_GET_VAR(__GLEW_EXT_paletted_texture) + +#endif /* GL_EXT_paletted_texture */ + +/* ----------------------- GL_EXT_pixel_buffer_object ---------------------- */ + +#ifndef GL_EXT_pixel_buffer_object +#define GL_EXT_pixel_buffer_object 1 + +#define GL_PIXEL_PACK_BUFFER_EXT 0x88EB +#define GL_PIXEL_UNPACK_BUFFER_EXT 0x88EC +#define GL_PIXEL_PACK_BUFFER_BINDING_EXT 0x88ED +#define GL_PIXEL_UNPACK_BUFFER_BINDING_EXT 0x88EF + +#define GLEW_EXT_pixel_buffer_object GLEW_GET_VAR(__GLEW_EXT_pixel_buffer_object) + +#endif /* GL_EXT_pixel_buffer_object */ + +/* ------------------------- GL_EXT_pixel_transform ------------------------ */ + +#ifndef GL_EXT_pixel_transform +#define GL_EXT_pixel_transform 1 + +#define GL_PIXEL_TRANSFORM_2D_EXT 0x8330 +#define GL_PIXEL_MAG_FILTER_EXT 0x8331 +#define GL_PIXEL_MIN_FILTER_EXT 0x8332 +#define GL_PIXEL_CUBIC_WEIGHT_EXT 0x8333 +#define GL_CUBIC_EXT 0x8334 +#define GL_AVERAGE_EXT 0x8335 +#define GL_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8336 +#define GL_MAX_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8337 +#define GL_PIXEL_TRANSFORM_2D_MATRIX_EXT 0x8338 + +typedef void (GLAPIENTRY * PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERFEXTPROC) (GLenum target, GLenum pname, const GLfloat param); +typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERIEXTPROC) (GLenum target, GLenum pname, const GLint param); +typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); + +#define glGetPixelTransformParameterfvEXT GLEW_GET_FUN(__glewGetPixelTransformParameterfvEXT) +#define glGetPixelTransformParameterivEXT GLEW_GET_FUN(__glewGetPixelTransformParameterivEXT) +#define glPixelTransformParameterfEXT GLEW_GET_FUN(__glewPixelTransformParameterfEXT) +#define glPixelTransformParameterfvEXT GLEW_GET_FUN(__glewPixelTransformParameterfvEXT) +#define glPixelTransformParameteriEXT GLEW_GET_FUN(__glewPixelTransformParameteriEXT) +#define glPixelTransformParameterivEXT GLEW_GET_FUN(__glewPixelTransformParameterivEXT) + +#define GLEW_EXT_pixel_transform GLEW_GET_VAR(__GLEW_EXT_pixel_transform) + +#endif /* GL_EXT_pixel_transform */ + +/* ------------------- GL_EXT_pixel_transform_color_table ------------------ */ + +#ifndef GL_EXT_pixel_transform_color_table +#define GL_EXT_pixel_transform_color_table 1 + +#define GLEW_EXT_pixel_transform_color_table GLEW_GET_VAR(__GLEW_EXT_pixel_transform_color_table) + +#endif /* GL_EXT_pixel_transform_color_table */ + +/* ------------------------ GL_EXT_point_parameters ------------------------ */ + +#ifndef GL_EXT_point_parameters +#define GL_EXT_point_parameters 1 + +#define GL_POINT_SIZE_MIN_EXT 0x8126 +#define GL_POINT_SIZE_MAX_EXT 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE_EXT 0x8128 +#define GL_DISTANCE_ATTENUATION_EXT 0x8129 + +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFEXTPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVEXTPROC) (GLenum pname, GLfloat* params); + +#define glPointParameterfEXT GLEW_GET_FUN(__glewPointParameterfEXT) +#define glPointParameterfvEXT GLEW_GET_FUN(__glewPointParameterfvEXT) + +#define GLEW_EXT_point_parameters GLEW_GET_VAR(__GLEW_EXT_point_parameters) + +#endif /* GL_EXT_point_parameters */ + +/* ------------------------- GL_EXT_polygon_offset ------------------------- */ + +#ifndef GL_EXT_polygon_offset +#define GL_EXT_polygon_offset 1 + +#define GL_POLYGON_OFFSET_EXT 0x8037 +#define GL_POLYGON_OFFSET_FACTOR_EXT 0x8038 +#define GL_POLYGON_OFFSET_BIAS_EXT 0x8039 + +typedef void (GLAPIENTRY * PFNGLPOLYGONOFFSETEXTPROC) (GLfloat factor, GLfloat bias); + +#define glPolygonOffsetEXT GLEW_GET_FUN(__glewPolygonOffsetEXT) + +#define GLEW_EXT_polygon_offset GLEW_GET_VAR(__GLEW_EXT_polygon_offset) + +#endif /* GL_EXT_polygon_offset */ + +/* ------------------------ GL_EXT_provoking_vertex ------------------------ */ + +#ifndef GL_EXT_provoking_vertex +#define GL_EXT_provoking_vertex 1 + +#define GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION_EXT 0x8E4C +#define GL_FIRST_VERTEX_CONVENTION_EXT 0x8E4D +#define GL_LAST_VERTEX_CONVENTION_EXT 0x8E4E +#define GL_PROVOKING_VERTEX_EXT 0x8E4F + +typedef void (GLAPIENTRY * PFNGLPROVOKINGVERTEXEXTPROC) (GLenum mode); + +#define glProvokingVertexEXT GLEW_GET_FUN(__glewProvokingVertexEXT) + +#define GLEW_EXT_provoking_vertex GLEW_GET_VAR(__GLEW_EXT_provoking_vertex) + +#endif /* GL_EXT_provoking_vertex */ + +/* ------------------------- GL_EXT_rescale_normal ------------------------- */ + +#ifndef GL_EXT_rescale_normal +#define GL_EXT_rescale_normal 1 + +#define GL_RESCALE_NORMAL_EXT 0x803A + +#define GLEW_EXT_rescale_normal GLEW_GET_VAR(__GLEW_EXT_rescale_normal) + +#endif /* GL_EXT_rescale_normal */ + +/* -------------------------- GL_EXT_scene_marker -------------------------- */ + +#ifndef GL_EXT_scene_marker +#define GL_EXT_scene_marker 1 + +typedef void (GLAPIENTRY * PFNGLBEGINSCENEEXTPROC) (void); +typedef void (GLAPIENTRY * PFNGLENDSCENEEXTPROC) (void); + +#define glBeginSceneEXT GLEW_GET_FUN(__glewBeginSceneEXT) +#define glEndSceneEXT GLEW_GET_FUN(__glewEndSceneEXT) + +#define GLEW_EXT_scene_marker GLEW_GET_VAR(__GLEW_EXT_scene_marker) + +#endif /* GL_EXT_scene_marker */ + +/* ------------------------- GL_EXT_secondary_color ------------------------ */ + +#ifndef GL_EXT_secondary_color +#define GL_EXT_secondary_color 1 + +#define GL_COLOR_SUM_EXT 0x8458 +#define GL_CURRENT_SECONDARY_COLOR_EXT 0x8459 +#define GL_SECONDARY_COLOR_ARRAY_SIZE_EXT 0x845A +#define GL_SECONDARY_COLOR_ARRAY_TYPE_EXT 0x845B +#define GL_SECONDARY_COLOR_ARRAY_STRIDE_EXT 0x845C +#define GL_SECONDARY_COLOR_ARRAY_POINTER_EXT 0x845D +#define GL_SECONDARY_COLOR_ARRAY_EXT 0x845E + +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BEXTPROC) (GLbyte red, GLbyte green, GLbyte blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BVEXTPROC) (const GLbyte *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DEXTPROC) (GLdouble red, GLdouble green, GLdouble blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DVEXTPROC) (const GLdouble *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FEXTPROC) (GLfloat red, GLfloat green, GLfloat blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FVEXTPROC) (const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IEXTPROC) (GLint red, GLint green, GLint blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IVEXTPROC) (const GLint *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SEXTPROC) (GLshort red, GLshort green, GLshort blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SVEXTPROC) (const GLshort *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBEXTPROC) (GLubyte red, GLubyte green, GLubyte blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBVEXTPROC) (const GLubyte *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIEXTPROC) (GLuint red, GLuint green, GLuint blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIVEXTPROC) (const GLuint *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USEXTPROC) (GLushort red, GLushort green, GLushort blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USVEXTPROC) (const GLushort *v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); + +#define glSecondaryColor3bEXT GLEW_GET_FUN(__glewSecondaryColor3bEXT) +#define glSecondaryColor3bvEXT GLEW_GET_FUN(__glewSecondaryColor3bvEXT) +#define glSecondaryColor3dEXT GLEW_GET_FUN(__glewSecondaryColor3dEXT) +#define glSecondaryColor3dvEXT GLEW_GET_FUN(__glewSecondaryColor3dvEXT) +#define glSecondaryColor3fEXT GLEW_GET_FUN(__glewSecondaryColor3fEXT) +#define glSecondaryColor3fvEXT GLEW_GET_FUN(__glewSecondaryColor3fvEXT) +#define glSecondaryColor3iEXT GLEW_GET_FUN(__glewSecondaryColor3iEXT) +#define glSecondaryColor3ivEXT GLEW_GET_FUN(__glewSecondaryColor3ivEXT) +#define glSecondaryColor3sEXT GLEW_GET_FUN(__glewSecondaryColor3sEXT) +#define glSecondaryColor3svEXT GLEW_GET_FUN(__glewSecondaryColor3svEXT) +#define glSecondaryColor3ubEXT GLEW_GET_FUN(__glewSecondaryColor3ubEXT) +#define glSecondaryColor3ubvEXT GLEW_GET_FUN(__glewSecondaryColor3ubvEXT) +#define glSecondaryColor3uiEXT GLEW_GET_FUN(__glewSecondaryColor3uiEXT) +#define glSecondaryColor3uivEXT GLEW_GET_FUN(__glewSecondaryColor3uivEXT) +#define glSecondaryColor3usEXT GLEW_GET_FUN(__glewSecondaryColor3usEXT) +#define glSecondaryColor3usvEXT GLEW_GET_FUN(__glewSecondaryColor3usvEXT) +#define glSecondaryColorPointerEXT GLEW_GET_FUN(__glewSecondaryColorPointerEXT) + +#define GLEW_EXT_secondary_color GLEW_GET_VAR(__GLEW_EXT_secondary_color) + +#endif /* GL_EXT_secondary_color */ + +/* --------------------- GL_EXT_separate_shader_objects -------------------- */ + +#ifndef GL_EXT_separate_shader_objects +#define GL_EXT_separate_shader_objects 1 + +#define GL_ACTIVE_PROGRAM_EXT 0x8B8D + +typedef void (GLAPIENTRY * PFNGLACTIVEPROGRAMEXTPROC) (GLuint program); +typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROGRAMEXTPROC) (GLenum type, const char* string); +typedef void (GLAPIENTRY * PFNGLUSESHADERPROGRAMEXTPROC) (GLenum type, GLuint program); + +#define glActiveProgramEXT GLEW_GET_FUN(__glewActiveProgramEXT) +#define glCreateShaderProgramEXT GLEW_GET_FUN(__glewCreateShaderProgramEXT) +#define glUseShaderProgramEXT GLEW_GET_FUN(__glewUseShaderProgramEXT) + +#define GLEW_EXT_separate_shader_objects GLEW_GET_VAR(__GLEW_EXT_separate_shader_objects) + +#endif /* GL_EXT_separate_shader_objects */ + +/* --------------------- GL_EXT_separate_specular_color -------------------- */ + +#ifndef GL_EXT_separate_specular_color +#define GL_EXT_separate_specular_color 1 + +#define GL_LIGHT_MODEL_COLOR_CONTROL_EXT 0x81F8 +#define GL_SINGLE_COLOR_EXT 0x81F9 +#define GL_SEPARATE_SPECULAR_COLOR_EXT 0x81FA + +#define GLEW_EXT_separate_specular_color GLEW_GET_VAR(__GLEW_EXT_separate_specular_color) + +#endif /* GL_EXT_separate_specular_color */ + +/* --------------------- GL_EXT_shader_image_load_store -------------------- */ + +#ifndef GL_EXT_shader_image_load_store +#define GL_EXT_shader_image_load_store 1 + +#define GL_VERTEX_ATTRIB_ARRAY_BARRIER_BIT_EXT 0x00000001 +#define GL_ELEMENT_ARRAY_BARRIER_BIT_EXT 0x00000002 +#define GL_UNIFORM_BARRIER_BIT_EXT 0x00000004 +#define GL_TEXTURE_FETCH_BARRIER_BIT_EXT 0x00000008 +#define GL_SHADER_IMAGE_ACCESS_BARRIER_BIT_EXT 0x00000020 +#define GL_COMMAND_BARRIER_BIT_EXT 0x00000040 +#define GL_PIXEL_BUFFER_BARRIER_BIT_EXT 0x00000080 +#define GL_TEXTURE_UPDATE_BARRIER_BIT_EXT 0x00000100 +#define GL_BUFFER_UPDATE_BARRIER_BIT_EXT 0x00000200 +#define GL_FRAMEBUFFER_BARRIER_BIT_EXT 0x00000400 +#define GL_TRANSFORM_FEEDBACK_BARRIER_BIT_EXT 0x00000800 +#define GL_ATOMIC_COUNTER_BARRIER_BIT_EXT 0x00001000 +#define GL_MAX_IMAGE_UNITS_EXT 0x8F38 +#define GL_MAX_COMBINED_IMAGE_UNITS_AND_FRAGMENT_OUTPUTS_EXT 0x8F39 +#define GL_IMAGE_BINDING_NAME_EXT 0x8F3A +#define GL_IMAGE_BINDING_LEVEL_EXT 0x8F3B +#define GL_IMAGE_BINDING_LAYERED_EXT 0x8F3C +#define GL_IMAGE_BINDING_LAYER_EXT 0x8F3D +#define GL_IMAGE_BINDING_ACCESS_EXT 0x8F3E +#define GL_IMAGE_1D_EXT 0x904C +#define GL_IMAGE_2D_EXT 0x904D +#define GL_IMAGE_3D_EXT 0x904E +#define GL_IMAGE_2D_RECT_EXT 0x904F +#define GL_IMAGE_CUBE_EXT 0x9050 +#define GL_IMAGE_BUFFER_EXT 0x9051 +#define GL_IMAGE_1D_ARRAY_EXT 0x9052 +#define GL_IMAGE_2D_ARRAY_EXT 0x9053 +#define GL_IMAGE_CUBE_MAP_ARRAY_EXT 0x9054 +#define GL_IMAGE_2D_MULTISAMPLE_EXT 0x9055 +#define GL_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9056 +#define GL_INT_IMAGE_1D_EXT 0x9057 +#define GL_INT_IMAGE_2D_EXT 0x9058 +#define GL_INT_IMAGE_3D_EXT 0x9059 +#define GL_INT_IMAGE_2D_RECT_EXT 0x905A +#define GL_INT_IMAGE_CUBE_EXT 0x905B +#define GL_INT_IMAGE_BUFFER_EXT 0x905C +#define GL_INT_IMAGE_1D_ARRAY_EXT 0x905D +#define GL_INT_IMAGE_2D_ARRAY_EXT 0x905E +#define GL_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x905F +#define GL_INT_IMAGE_2D_MULTISAMPLE_EXT 0x9060 +#define GL_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9061 +#define GL_UNSIGNED_INT_IMAGE_1D_EXT 0x9062 +#define GL_UNSIGNED_INT_IMAGE_2D_EXT 0x9063 +#define GL_UNSIGNED_INT_IMAGE_3D_EXT 0x9064 +#define GL_UNSIGNED_INT_IMAGE_2D_RECT_EXT 0x9065 +#define GL_UNSIGNED_INT_IMAGE_CUBE_EXT 0x9066 +#define GL_UNSIGNED_INT_IMAGE_BUFFER_EXT 0x9067 +#define GL_UNSIGNED_INT_IMAGE_1D_ARRAY_EXT 0x9068 +#define GL_UNSIGNED_INT_IMAGE_2D_ARRAY_EXT 0x9069 +#define GL_UNSIGNED_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x906A +#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_EXT 0x906B +#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x906C +#define GL_MAX_IMAGE_SAMPLES_EXT 0x906D +#define GL_IMAGE_BINDING_FORMAT_EXT 0x906E +#define GL_ALL_BARRIER_BITS_EXT 0xFFFFFFFF + +typedef void (GLAPIENTRY * PFNGLBINDIMAGETEXTUREEXTPROC) (GLuint index, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLint format); +typedef void (GLAPIENTRY * PFNGLMEMORYBARRIEREXTPROC) (GLbitfield barriers); + +#define glBindImageTextureEXT GLEW_GET_FUN(__glewBindImageTextureEXT) +#define glMemoryBarrierEXT GLEW_GET_FUN(__glewMemoryBarrierEXT) + +#define GLEW_EXT_shader_image_load_store GLEW_GET_VAR(__GLEW_EXT_shader_image_load_store) + +#endif /* GL_EXT_shader_image_load_store */ + +/* -------------------------- GL_EXT_shadow_funcs -------------------------- */ + +#ifndef GL_EXT_shadow_funcs +#define GL_EXT_shadow_funcs 1 + +#define GLEW_EXT_shadow_funcs GLEW_GET_VAR(__GLEW_EXT_shadow_funcs) + +#endif /* GL_EXT_shadow_funcs */ + +/* --------------------- GL_EXT_shared_texture_palette --------------------- */ + +#ifndef GL_EXT_shared_texture_palette +#define GL_EXT_shared_texture_palette 1 + +#define GL_SHARED_TEXTURE_PALETTE_EXT 0x81FB + +#define GLEW_EXT_shared_texture_palette GLEW_GET_VAR(__GLEW_EXT_shared_texture_palette) + +#endif /* GL_EXT_shared_texture_palette */ + +/* ------------------------ GL_EXT_stencil_clear_tag ----------------------- */ + +#ifndef GL_EXT_stencil_clear_tag +#define GL_EXT_stencil_clear_tag 1 + +#define GL_STENCIL_TAG_BITS_EXT 0x88F2 +#define GL_STENCIL_CLEAR_TAG_VALUE_EXT 0x88F3 + +#define GLEW_EXT_stencil_clear_tag GLEW_GET_VAR(__GLEW_EXT_stencil_clear_tag) + +#endif /* GL_EXT_stencil_clear_tag */ + +/* ------------------------ GL_EXT_stencil_two_side ------------------------ */ + +#ifndef GL_EXT_stencil_two_side +#define GL_EXT_stencil_two_side 1 + +#define GL_STENCIL_TEST_TWO_SIDE_EXT 0x8910 +#define GL_ACTIVE_STENCIL_FACE_EXT 0x8911 + +typedef void (GLAPIENTRY * PFNGLACTIVESTENCILFACEEXTPROC) (GLenum face); + +#define glActiveStencilFaceEXT GLEW_GET_FUN(__glewActiveStencilFaceEXT) + +#define GLEW_EXT_stencil_two_side GLEW_GET_VAR(__GLEW_EXT_stencil_two_side) + +#endif /* GL_EXT_stencil_two_side */ + +/* -------------------------- GL_EXT_stencil_wrap -------------------------- */ + +#ifndef GL_EXT_stencil_wrap +#define GL_EXT_stencil_wrap 1 + +#define GL_INCR_WRAP_EXT 0x8507 +#define GL_DECR_WRAP_EXT 0x8508 + +#define GLEW_EXT_stencil_wrap GLEW_GET_VAR(__GLEW_EXT_stencil_wrap) + +#endif /* GL_EXT_stencil_wrap */ + +/* --------------------------- GL_EXT_subtexture --------------------------- */ + +#ifndef GL_EXT_subtexture +#define GL_EXT_subtexture 1 + +typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels); + +#define glTexSubImage1DEXT GLEW_GET_FUN(__glewTexSubImage1DEXT) +#define glTexSubImage2DEXT GLEW_GET_FUN(__glewTexSubImage2DEXT) +#define glTexSubImage3DEXT GLEW_GET_FUN(__glewTexSubImage3DEXT) + +#define GLEW_EXT_subtexture GLEW_GET_VAR(__GLEW_EXT_subtexture) + +#endif /* GL_EXT_subtexture */ + +/* ----------------------------- GL_EXT_texture ---------------------------- */ + +#ifndef GL_EXT_texture +#define GL_EXT_texture 1 + +#define GL_ALPHA4_EXT 0x803B +#define GL_ALPHA8_EXT 0x803C +#define GL_ALPHA12_EXT 0x803D +#define GL_ALPHA16_EXT 0x803E +#define GL_LUMINANCE4_EXT 0x803F +#define GL_LUMINANCE8_EXT 0x8040 +#define GL_LUMINANCE12_EXT 0x8041 +#define GL_LUMINANCE16_EXT 0x8042 +#define GL_LUMINANCE4_ALPHA4_EXT 0x8043 +#define GL_LUMINANCE6_ALPHA2_EXT 0x8044 +#define GL_LUMINANCE8_ALPHA8_EXT 0x8045 +#define GL_LUMINANCE12_ALPHA4_EXT 0x8046 +#define GL_LUMINANCE12_ALPHA12_EXT 0x8047 +#define GL_LUMINANCE16_ALPHA16_EXT 0x8048 +#define GL_INTENSITY_EXT 0x8049 +#define GL_INTENSITY4_EXT 0x804A +#define GL_INTENSITY8_EXT 0x804B +#define GL_INTENSITY12_EXT 0x804C +#define GL_INTENSITY16_EXT 0x804D +#define GL_RGB2_EXT 0x804E +#define GL_RGB4_EXT 0x804F +#define GL_RGB5_EXT 0x8050 +#define GL_RGB8_EXT 0x8051 +#define GL_RGB10_EXT 0x8052 +#define GL_RGB12_EXT 0x8053 +#define GL_RGB16_EXT 0x8054 +#define GL_RGBA2_EXT 0x8055 +#define GL_RGBA4_EXT 0x8056 +#define GL_RGB5_A1_EXT 0x8057 +#define GL_RGBA8_EXT 0x8058 +#define GL_RGB10_A2_EXT 0x8059 +#define GL_RGBA12_EXT 0x805A +#define GL_RGBA16_EXT 0x805B +#define GL_TEXTURE_RED_SIZE_EXT 0x805C +#define GL_TEXTURE_GREEN_SIZE_EXT 0x805D +#define GL_TEXTURE_BLUE_SIZE_EXT 0x805E +#define GL_TEXTURE_ALPHA_SIZE_EXT 0x805F +#define GL_TEXTURE_LUMINANCE_SIZE_EXT 0x8060 +#define GL_TEXTURE_INTENSITY_SIZE_EXT 0x8061 +#define GL_REPLACE_EXT 0x8062 +#define GL_PROXY_TEXTURE_1D_EXT 0x8063 +#define GL_PROXY_TEXTURE_2D_EXT 0x8064 + +#define GLEW_EXT_texture GLEW_GET_VAR(__GLEW_EXT_texture) + +#endif /* GL_EXT_texture */ + +/* ---------------------------- GL_EXT_texture3D --------------------------- */ + +#ifndef GL_EXT_texture3D +#define GL_EXT_texture3D 1 + +#define GL_PACK_SKIP_IMAGES_EXT 0x806B +#define GL_PACK_IMAGE_HEIGHT_EXT 0x806C +#define GL_UNPACK_SKIP_IMAGES_EXT 0x806D +#define GL_UNPACK_IMAGE_HEIGHT_EXT 0x806E +#define GL_TEXTURE_3D_EXT 0x806F +#define GL_PROXY_TEXTURE_3D_EXT 0x8070 +#define GL_TEXTURE_DEPTH_EXT 0x8071 +#define GL_TEXTURE_WRAP_R_EXT 0x8072 +#define GL_MAX_3D_TEXTURE_SIZE_EXT 0x8073 + +typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels); + +#define glTexImage3DEXT GLEW_GET_FUN(__glewTexImage3DEXT) + +#define GLEW_EXT_texture3D GLEW_GET_VAR(__GLEW_EXT_texture3D) + +#endif /* GL_EXT_texture3D */ + +/* -------------------------- GL_EXT_texture_array ------------------------- */ + +#ifndef GL_EXT_texture_array +#define GL_EXT_texture_array 1 + +#define GL_COMPARE_REF_DEPTH_TO_TEXTURE_EXT 0x884E +#define GL_MAX_ARRAY_TEXTURE_LAYERS_EXT 0x88FF +#define GL_TEXTURE_1D_ARRAY_EXT 0x8C18 +#define GL_PROXY_TEXTURE_1D_ARRAY_EXT 0x8C19 +#define GL_TEXTURE_2D_ARRAY_EXT 0x8C1A +#define GL_PROXY_TEXTURE_2D_ARRAY_EXT 0x8C1B +#define GL_TEXTURE_BINDING_1D_ARRAY_EXT 0x8C1C +#define GL_TEXTURE_BINDING_2D_ARRAY_EXT 0x8C1D + +#define GLEW_EXT_texture_array GLEW_GET_VAR(__GLEW_EXT_texture_array) + +#endif /* GL_EXT_texture_array */ + +/* ---------------------- GL_EXT_texture_buffer_object --------------------- */ + +#ifndef GL_EXT_texture_buffer_object +#define GL_EXT_texture_buffer_object 1 + +#define GL_TEXTURE_BUFFER_EXT 0x8C2A +#define GL_MAX_TEXTURE_BUFFER_SIZE_EXT 0x8C2B +#define GL_TEXTURE_BINDING_BUFFER_EXT 0x8C2C +#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING_EXT 0x8C2D +#define GL_TEXTURE_BUFFER_FORMAT_EXT 0x8C2E + +typedef void (GLAPIENTRY * PFNGLTEXBUFFEREXTPROC) (GLenum target, GLenum internalformat, GLuint buffer); + +#define glTexBufferEXT GLEW_GET_FUN(__glewTexBufferEXT) + +#define GLEW_EXT_texture_buffer_object GLEW_GET_VAR(__GLEW_EXT_texture_buffer_object) + +#endif /* GL_EXT_texture_buffer_object */ + +/* -------------------- GL_EXT_texture_compression_dxt1 -------------------- */ + +#ifndef GL_EXT_texture_compression_dxt1 +#define GL_EXT_texture_compression_dxt1 1 + +#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 +#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 + +#define GLEW_EXT_texture_compression_dxt1 GLEW_GET_VAR(__GLEW_EXT_texture_compression_dxt1) + +#endif /* GL_EXT_texture_compression_dxt1 */ + +/* -------------------- GL_EXT_texture_compression_latc -------------------- */ + +#ifndef GL_EXT_texture_compression_latc +#define GL_EXT_texture_compression_latc 1 + +#define GL_COMPRESSED_LUMINANCE_LATC1_EXT 0x8C70 +#define GL_COMPRESSED_SIGNED_LUMINANCE_LATC1_EXT 0x8C71 +#define GL_COMPRESSED_LUMINANCE_ALPHA_LATC2_EXT 0x8C72 +#define GL_COMPRESSED_SIGNED_LUMINANCE_ALPHA_LATC2_EXT 0x8C73 + +#define GLEW_EXT_texture_compression_latc GLEW_GET_VAR(__GLEW_EXT_texture_compression_latc) + +#endif /* GL_EXT_texture_compression_latc */ + +/* -------------------- GL_EXT_texture_compression_rgtc -------------------- */ + +#ifndef GL_EXT_texture_compression_rgtc +#define GL_EXT_texture_compression_rgtc 1 + +#define GL_COMPRESSED_RED_RGTC1_EXT 0x8DBB +#define GL_COMPRESSED_SIGNED_RED_RGTC1_EXT 0x8DBC +#define GL_COMPRESSED_RED_GREEN_RGTC2_EXT 0x8DBD +#define GL_COMPRESSED_SIGNED_RED_GREEN_RGTC2_EXT 0x8DBE + +#define GLEW_EXT_texture_compression_rgtc GLEW_GET_VAR(__GLEW_EXT_texture_compression_rgtc) + +#endif /* GL_EXT_texture_compression_rgtc */ + +/* -------------------- GL_EXT_texture_compression_s3tc -------------------- */ + +#ifndef GL_EXT_texture_compression_s3tc +#define GL_EXT_texture_compression_s3tc 1 + +#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 +#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 +#define GL_COMPRESSED_RGBA_S3TC_DXT3_EXT 0x83F2 +#define GL_COMPRESSED_RGBA_S3TC_DXT5_EXT 0x83F3 + +#define GLEW_EXT_texture_compression_s3tc GLEW_GET_VAR(__GLEW_EXT_texture_compression_s3tc) + +#endif /* GL_EXT_texture_compression_s3tc */ + +/* ------------------------ GL_EXT_texture_cube_map ------------------------ */ + +#ifndef GL_EXT_texture_cube_map +#define GL_EXT_texture_cube_map 1 + +#define GL_NORMAL_MAP_EXT 0x8511 +#define GL_REFLECTION_MAP_EXT 0x8512 +#define GL_TEXTURE_CUBE_MAP_EXT 0x8513 +#define GL_TEXTURE_BINDING_CUBE_MAP_EXT 0x8514 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_EXT 0x8515 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_EXT 0x8516 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_EXT 0x8517 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_EXT 0x8518 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_EXT 0x8519 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_EXT 0x851A +#define GL_PROXY_TEXTURE_CUBE_MAP_EXT 0x851B +#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_EXT 0x851C + +#define GLEW_EXT_texture_cube_map GLEW_GET_VAR(__GLEW_EXT_texture_cube_map) + +#endif /* GL_EXT_texture_cube_map */ + +/* ----------------------- GL_EXT_texture_edge_clamp ----------------------- */ + +#ifndef GL_EXT_texture_edge_clamp +#define GL_EXT_texture_edge_clamp 1 + +#define GL_CLAMP_TO_EDGE_EXT 0x812F + +#define GLEW_EXT_texture_edge_clamp GLEW_GET_VAR(__GLEW_EXT_texture_edge_clamp) + +#endif /* GL_EXT_texture_edge_clamp */ + +/* --------------------------- GL_EXT_texture_env -------------------------- */ + +#ifndef GL_EXT_texture_env +#define GL_EXT_texture_env 1 + +#define GL_TEXTURE_ENV0_EXT 0 +#define GL_ENV_BLEND_EXT 0 +#define GL_TEXTURE_ENV_SHIFT_EXT 0 +#define GL_ENV_REPLACE_EXT 0 +#define GL_ENV_ADD_EXT 0 +#define GL_ENV_SUBTRACT_EXT 0 +#define GL_TEXTURE_ENV_MODE_ALPHA_EXT 0 +#define GL_ENV_REVERSE_SUBTRACT_EXT 0 +#define GL_ENV_REVERSE_BLEND_EXT 0 +#define GL_ENV_COPY_EXT 0 +#define GL_ENV_MODULATE_EXT 0 + +#define GLEW_EXT_texture_env GLEW_GET_VAR(__GLEW_EXT_texture_env) + +#endif /* GL_EXT_texture_env */ + +/* ------------------------- GL_EXT_texture_env_add ------------------------ */ + +#ifndef GL_EXT_texture_env_add +#define GL_EXT_texture_env_add 1 + +#define GLEW_EXT_texture_env_add GLEW_GET_VAR(__GLEW_EXT_texture_env_add) + +#endif /* GL_EXT_texture_env_add */ + +/* ----------------------- GL_EXT_texture_env_combine ---------------------- */ + +#ifndef GL_EXT_texture_env_combine +#define GL_EXT_texture_env_combine 1 + +#define GL_COMBINE_EXT 0x8570 +#define GL_COMBINE_RGB_EXT 0x8571 +#define GL_COMBINE_ALPHA_EXT 0x8572 +#define GL_RGB_SCALE_EXT 0x8573 +#define GL_ADD_SIGNED_EXT 0x8574 +#define GL_INTERPOLATE_EXT 0x8575 +#define GL_CONSTANT_EXT 0x8576 +#define GL_PRIMARY_COLOR_EXT 0x8577 +#define GL_PREVIOUS_EXT 0x8578 +#define GL_SOURCE0_RGB_EXT 0x8580 +#define GL_SOURCE1_RGB_EXT 0x8581 +#define GL_SOURCE2_RGB_EXT 0x8582 +#define GL_SOURCE0_ALPHA_EXT 0x8588 +#define GL_SOURCE1_ALPHA_EXT 0x8589 +#define GL_SOURCE2_ALPHA_EXT 0x858A +#define GL_OPERAND0_RGB_EXT 0x8590 +#define GL_OPERAND1_RGB_EXT 0x8591 +#define GL_OPERAND2_RGB_EXT 0x8592 +#define GL_OPERAND0_ALPHA_EXT 0x8598 +#define GL_OPERAND1_ALPHA_EXT 0x8599 +#define GL_OPERAND2_ALPHA_EXT 0x859A + +#define GLEW_EXT_texture_env_combine GLEW_GET_VAR(__GLEW_EXT_texture_env_combine) + +#endif /* GL_EXT_texture_env_combine */ + +/* ------------------------ GL_EXT_texture_env_dot3 ------------------------ */ + +#ifndef GL_EXT_texture_env_dot3 +#define GL_EXT_texture_env_dot3 1 + +#define GL_DOT3_RGB_EXT 0x8740 +#define GL_DOT3_RGBA_EXT 0x8741 + +#define GLEW_EXT_texture_env_dot3 GLEW_GET_VAR(__GLEW_EXT_texture_env_dot3) + +#endif /* GL_EXT_texture_env_dot3 */ + +/* ------------------- GL_EXT_texture_filter_anisotropic ------------------- */ + +#ifndef GL_EXT_texture_filter_anisotropic +#define GL_EXT_texture_filter_anisotropic 1 + +#define GL_TEXTURE_MAX_ANISOTROPY_EXT 0x84FE +#define GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT 0x84FF + +#define GLEW_EXT_texture_filter_anisotropic GLEW_GET_VAR(__GLEW_EXT_texture_filter_anisotropic) + +#endif /* GL_EXT_texture_filter_anisotropic */ + +/* ------------------------- GL_EXT_texture_integer ------------------------ */ + +#ifndef GL_EXT_texture_integer +#define GL_EXT_texture_integer 1 + +#define GL_RGBA32UI_EXT 0x8D70 +#define GL_RGB32UI_EXT 0x8D71 +#define GL_ALPHA32UI_EXT 0x8D72 +#define GL_INTENSITY32UI_EXT 0x8D73 +#define GL_LUMINANCE32UI_EXT 0x8D74 +#define GL_LUMINANCE_ALPHA32UI_EXT 0x8D75 +#define GL_RGBA16UI_EXT 0x8D76 +#define GL_RGB16UI_EXT 0x8D77 +#define GL_ALPHA16UI_EXT 0x8D78 +#define GL_INTENSITY16UI_EXT 0x8D79 +#define GL_LUMINANCE16UI_EXT 0x8D7A +#define GL_LUMINANCE_ALPHA16UI_EXT 0x8D7B +#define GL_RGBA8UI_EXT 0x8D7C +#define GL_RGB8UI_EXT 0x8D7D +#define GL_ALPHA8UI_EXT 0x8D7E +#define GL_INTENSITY8UI_EXT 0x8D7F +#define GL_LUMINANCE8UI_EXT 0x8D80 +#define GL_LUMINANCE_ALPHA8UI_EXT 0x8D81 +#define GL_RGBA32I_EXT 0x8D82 +#define GL_RGB32I_EXT 0x8D83 +#define GL_ALPHA32I_EXT 0x8D84 +#define GL_INTENSITY32I_EXT 0x8D85 +#define GL_LUMINANCE32I_EXT 0x8D86 +#define GL_LUMINANCE_ALPHA32I_EXT 0x8D87 +#define GL_RGBA16I_EXT 0x8D88 +#define GL_RGB16I_EXT 0x8D89 +#define GL_ALPHA16I_EXT 0x8D8A +#define GL_INTENSITY16I_EXT 0x8D8B +#define GL_LUMINANCE16I_EXT 0x8D8C +#define GL_LUMINANCE_ALPHA16I_EXT 0x8D8D +#define GL_RGBA8I_EXT 0x8D8E +#define GL_RGB8I_EXT 0x8D8F +#define GL_ALPHA8I_EXT 0x8D90 +#define GL_INTENSITY8I_EXT 0x8D91 +#define GL_LUMINANCE8I_EXT 0x8D92 +#define GL_LUMINANCE_ALPHA8I_EXT 0x8D93 +#define GL_RED_INTEGER_EXT 0x8D94 +#define GL_GREEN_INTEGER_EXT 0x8D95 +#define GL_BLUE_INTEGER_EXT 0x8D96 +#define GL_ALPHA_INTEGER_EXT 0x8D97 +#define GL_RGB_INTEGER_EXT 0x8D98 +#define GL_RGBA_INTEGER_EXT 0x8D99 +#define GL_BGR_INTEGER_EXT 0x8D9A +#define GL_BGRA_INTEGER_EXT 0x8D9B +#define GL_LUMINANCE_INTEGER_EXT 0x8D9C +#define GL_LUMINANCE_ALPHA_INTEGER_EXT 0x8D9D +#define GL_RGBA_INTEGER_MODE_EXT 0x8D9E + +typedef void (GLAPIENTRY * PFNGLCLEARCOLORIIEXTPROC) (GLint red, GLint green, GLint blue, GLint alpha); +typedef void (GLAPIENTRY * PFNGLCLEARCOLORIUIEXTPROC) (GLuint red, GLuint green, GLuint blue, GLuint alpha); +typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, GLuint *params); +typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, const GLuint *params); + +#define glClearColorIiEXT GLEW_GET_FUN(__glewClearColorIiEXT) +#define glClearColorIuiEXT GLEW_GET_FUN(__glewClearColorIuiEXT) +#define glGetTexParameterIivEXT GLEW_GET_FUN(__glewGetTexParameterIivEXT) +#define glGetTexParameterIuivEXT GLEW_GET_FUN(__glewGetTexParameterIuivEXT) +#define glTexParameterIivEXT GLEW_GET_FUN(__glewTexParameterIivEXT) +#define glTexParameterIuivEXT GLEW_GET_FUN(__glewTexParameterIuivEXT) + +#define GLEW_EXT_texture_integer GLEW_GET_VAR(__GLEW_EXT_texture_integer) + +#endif /* GL_EXT_texture_integer */ + +/* ------------------------ GL_EXT_texture_lod_bias ------------------------ */ + +#ifndef GL_EXT_texture_lod_bias +#define GL_EXT_texture_lod_bias 1 + +#define GL_MAX_TEXTURE_LOD_BIAS_EXT 0x84FD +#define GL_TEXTURE_FILTER_CONTROL_EXT 0x8500 +#define GL_TEXTURE_LOD_BIAS_EXT 0x8501 + +#define GLEW_EXT_texture_lod_bias GLEW_GET_VAR(__GLEW_EXT_texture_lod_bias) + +#endif /* GL_EXT_texture_lod_bias */ + +/* ---------------------- GL_EXT_texture_mirror_clamp ---------------------- */ + +#ifndef GL_EXT_texture_mirror_clamp +#define GL_EXT_texture_mirror_clamp 1 + +#define GL_MIRROR_CLAMP_EXT 0x8742 +#define GL_MIRROR_CLAMP_TO_EDGE_EXT 0x8743 +#define GL_MIRROR_CLAMP_TO_BORDER_EXT 0x8912 + +#define GLEW_EXT_texture_mirror_clamp GLEW_GET_VAR(__GLEW_EXT_texture_mirror_clamp) + +#endif /* GL_EXT_texture_mirror_clamp */ + +/* ------------------------- GL_EXT_texture_object ------------------------- */ + +#ifndef GL_EXT_texture_object +#define GL_EXT_texture_object 1 + +#define GL_TEXTURE_PRIORITY_EXT 0x8066 +#define GL_TEXTURE_RESIDENT_EXT 0x8067 +#define GL_TEXTURE_1D_BINDING_EXT 0x8068 +#define GL_TEXTURE_2D_BINDING_EXT 0x8069 +#define GL_TEXTURE_3D_BINDING_EXT 0x806A + +typedef GLboolean (GLAPIENTRY * PFNGLARETEXTURESRESIDENTEXTPROC) (GLsizei n, const GLuint* textures, GLboolean* residences); +typedef void (GLAPIENTRY * PFNGLBINDTEXTUREEXTPROC) (GLenum target, GLuint texture); +typedef void (GLAPIENTRY * PFNGLDELETETEXTURESEXTPROC) (GLsizei n, const GLuint* textures); +typedef void (GLAPIENTRY * PFNGLGENTEXTURESEXTPROC) (GLsizei n, GLuint* textures); +typedef GLboolean (GLAPIENTRY * PFNGLISTEXTUREEXTPROC) (GLuint texture); +typedef void (GLAPIENTRY * PFNGLPRIORITIZETEXTURESEXTPROC) (GLsizei n, const GLuint* textures, const GLclampf* priorities); + +#define glAreTexturesResidentEXT GLEW_GET_FUN(__glewAreTexturesResidentEXT) +#define glBindTextureEXT GLEW_GET_FUN(__glewBindTextureEXT) +#define glDeleteTexturesEXT GLEW_GET_FUN(__glewDeleteTexturesEXT) +#define glGenTexturesEXT GLEW_GET_FUN(__glewGenTexturesEXT) +#define glIsTextureEXT GLEW_GET_FUN(__glewIsTextureEXT) +#define glPrioritizeTexturesEXT GLEW_GET_FUN(__glewPrioritizeTexturesEXT) + +#define GLEW_EXT_texture_object GLEW_GET_VAR(__GLEW_EXT_texture_object) + +#endif /* GL_EXT_texture_object */ + +/* --------------------- GL_EXT_texture_perturb_normal --------------------- */ + +#ifndef GL_EXT_texture_perturb_normal +#define GL_EXT_texture_perturb_normal 1 + +#define GL_PERTURB_EXT 0x85AE +#define GL_TEXTURE_NORMAL_EXT 0x85AF + +typedef void (GLAPIENTRY * PFNGLTEXTURENORMALEXTPROC) (GLenum mode); + +#define glTextureNormalEXT GLEW_GET_FUN(__glewTextureNormalEXT) + +#define GLEW_EXT_texture_perturb_normal GLEW_GET_VAR(__GLEW_EXT_texture_perturb_normal) + +#endif /* GL_EXT_texture_perturb_normal */ + +/* ------------------------ GL_EXT_texture_rectangle ----------------------- */ + +#ifndef GL_EXT_texture_rectangle +#define GL_EXT_texture_rectangle 1 + +#define GL_TEXTURE_RECTANGLE_EXT 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE_EXT 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE_EXT 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE_EXT 0x84F8 + +#define GLEW_EXT_texture_rectangle GLEW_GET_VAR(__GLEW_EXT_texture_rectangle) + +#endif /* GL_EXT_texture_rectangle */ + +/* -------------------------- GL_EXT_texture_sRGB -------------------------- */ + +#ifndef GL_EXT_texture_sRGB +#define GL_EXT_texture_sRGB 1 + +#define GL_SRGB_EXT 0x8C40 +#define GL_SRGB8_EXT 0x8C41 +#define GL_SRGB_ALPHA_EXT 0x8C42 +#define GL_SRGB8_ALPHA8_EXT 0x8C43 +#define GL_SLUMINANCE_ALPHA_EXT 0x8C44 +#define GL_SLUMINANCE8_ALPHA8_EXT 0x8C45 +#define GL_SLUMINANCE_EXT 0x8C46 +#define GL_SLUMINANCE8_EXT 0x8C47 +#define GL_COMPRESSED_SRGB_EXT 0x8C48 +#define GL_COMPRESSED_SRGB_ALPHA_EXT 0x8C49 +#define GL_COMPRESSED_SLUMINANCE_EXT 0x8C4A +#define GL_COMPRESSED_SLUMINANCE_ALPHA_EXT 0x8C4B +#define GL_COMPRESSED_SRGB_S3TC_DXT1_EXT 0x8C4C +#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT 0x8C4D +#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT 0x8C4E +#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT 0x8C4F + +#define GLEW_EXT_texture_sRGB GLEW_GET_VAR(__GLEW_EXT_texture_sRGB) + +#endif /* GL_EXT_texture_sRGB */ + +/* --------------------- GL_EXT_texture_shared_exponent -------------------- */ + +#ifndef GL_EXT_texture_shared_exponent +#define GL_EXT_texture_shared_exponent 1 + +#define GL_RGB9_E5_EXT 0x8C3D +#define GL_UNSIGNED_INT_5_9_9_9_REV_EXT 0x8C3E +#define GL_TEXTURE_SHARED_SIZE_EXT 0x8C3F + +#define GLEW_EXT_texture_shared_exponent GLEW_GET_VAR(__GLEW_EXT_texture_shared_exponent) + +#endif /* GL_EXT_texture_shared_exponent */ + +/* -------------------------- GL_EXT_texture_snorm ------------------------- */ + +#ifndef GL_EXT_texture_snorm +#define GL_EXT_texture_snorm 1 + +#define GL_RED_SNORM 0x8F90 +#define GL_RG_SNORM 0x8F91 +#define GL_RGB_SNORM 0x8F92 +#define GL_RGBA_SNORM 0x8F93 +#define GL_R8_SNORM 0x8F94 +#define GL_RG8_SNORM 0x8F95 +#define GL_RGB8_SNORM 0x8F96 +#define GL_RGBA8_SNORM 0x8F97 +#define GL_R16_SNORM 0x8F98 +#define GL_RG16_SNORM 0x8F99 +#define GL_RGB16_SNORM 0x8F9A +#define GL_RGBA16_SNORM 0x8F9B +#define GL_SIGNED_NORMALIZED 0x8F9C +#define GL_ALPHA_SNORM 0x9010 +#define GL_LUMINANCE_SNORM 0x9011 +#define GL_LUMINANCE_ALPHA_SNORM 0x9012 +#define GL_INTENSITY_SNORM 0x9013 +#define GL_ALPHA8_SNORM 0x9014 +#define GL_LUMINANCE8_SNORM 0x9015 +#define GL_LUMINANCE8_ALPHA8_SNORM 0x9016 +#define GL_INTENSITY8_SNORM 0x9017 +#define GL_ALPHA16_SNORM 0x9018 +#define GL_LUMINANCE16_SNORM 0x9019 +#define GL_LUMINANCE16_ALPHA16_SNORM 0x901A +#define GL_INTENSITY16_SNORM 0x901B + +#define GLEW_EXT_texture_snorm GLEW_GET_VAR(__GLEW_EXT_texture_snorm) + +#endif /* GL_EXT_texture_snorm */ + +/* ------------------------- GL_EXT_texture_swizzle ------------------------ */ + +#ifndef GL_EXT_texture_swizzle +#define GL_EXT_texture_swizzle 1 + +#define GL_TEXTURE_SWIZZLE_R_EXT 0x8E42 +#define GL_TEXTURE_SWIZZLE_G_EXT 0x8E43 +#define GL_TEXTURE_SWIZZLE_B_EXT 0x8E44 +#define GL_TEXTURE_SWIZZLE_A_EXT 0x8E45 +#define GL_TEXTURE_SWIZZLE_RGBA_EXT 0x8E46 + +#define GLEW_EXT_texture_swizzle GLEW_GET_VAR(__GLEW_EXT_texture_swizzle) + +#endif /* GL_EXT_texture_swizzle */ + +/* --------------------------- GL_EXT_timer_query -------------------------- */ + +#ifndef GL_EXT_timer_query +#define GL_EXT_timer_query 1 + +#define GL_TIME_ELAPSED_EXT 0x88BF + +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTI64VEXTPROC) (GLuint id, GLenum pname, GLint64EXT *params); +typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUI64VEXTPROC) (GLuint id, GLenum pname, GLuint64EXT *params); + +#define glGetQueryObjecti64vEXT GLEW_GET_FUN(__glewGetQueryObjecti64vEXT) +#define glGetQueryObjectui64vEXT GLEW_GET_FUN(__glewGetQueryObjectui64vEXT) + +#define GLEW_EXT_timer_query GLEW_GET_VAR(__GLEW_EXT_timer_query) + +#endif /* GL_EXT_timer_query */ + +/* ----------------------- GL_EXT_transform_feedback ----------------------- */ + +#ifndef GL_EXT_transform_feedback +#define GL_EXT_transform_feedback 1 + +#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH_EXT 0x8C76 +#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE_EXT 0x8C7F +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_EXT 0x8C80 +#define GL_TRANSFORM_FEEDBACK_VARYINGS_EXT 0x8C83 +#define GL_TRANSFORM_FEEDBACK_BUFFER_START_EXT 0x8C84 +#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_EXT 0x8C85 +#define GL_PRIMITIVES_GENERATED_EXT 0x8C87 +#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_EXT 0x8C88 +#define GL_RASTERIZER_DISCARD_EXT 0x8C89 +#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_EXT 0x8C8A +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_EXT 0x8C8B +#define GL_INTERLEAVED_ATTRIBS_EXT 0x8C8C +#define GL_SEPARATE_ATTRIBS_EXT 0x8C8D +#define GL_TRANSFORM_FEEDBACK_BUFFER_EXT 0x8C8E +#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_EXT 0x8C8F + +typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKEXTPROC) (GLenum primitiveMode); +typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASEEXTPROC) (GLenum target, GLuint index, GLuint buffer); +typedef void (GLAPIENTRY * PFNGLBINDBUFFEROFFSETEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGEEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKEXTPROC) (void); +typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei* length, GLsizei *size, GLenum *type, char *name); +typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC) (GLuint program, GLsizei count, const char ** varyings, GLenum bufferMode); + +#define glBeginTransformFeedbackEXT GLEW_GET_FUN(__glewBeginTransformFeedbackEXT) +#define glBindBufferBaseEXT GLEW_GET_FUN(__glewBindBufferBaseEXT) +#define glBindBufferOffsetEXT GLEW_GET_FUN(__glewBindBufferOffsetEXT) +#define glBindBufferRangeEXT GLEW_GET_FUN(__glewBindBufferRangeEXT) +#define glEndTransformFeedbackEXT GLEW_GET_FUN(__glewEndTransformFeedbackEXT) +#define glGetTransformFeedbackVaryingEXT GLEW_GET_FUN(__glewGetTransformFeedbackVaryingEXT) +#define glTransformFeedbackVaryingsEXT GLEW_GET_FUN(__glewTransformFeedbackVaryingsEXT) + +#define GLEW_EXT_transform_feedback GLEW_GET_VAR(__GLEW_EXT_transform_feedback) + +#endif /* GL_EXT_transform_feedback */ + +/* -------------------------- GL_EXT_vertex_array -------------------------- */ + +#ifndef GL_EXT_vertex_array +#define GL_EXT_vertex_array 1 + +#define GL_DOUBLE_EXT 0x140A +#define GL_VERTEX_ARRAY_EXT 0x8074 +#define GL_NORMAL_ARRAY_EXT 0x8075 +#define GL_COLOR_ARRAY_EXT 0x8076 +#define GL_INDEX_ARRAY_EXT 0x8077 +#define GL_TEXTURE_COORD_ARRAY_EXT 0x8078 +#define GL_EDGE_FLAG_ARRAY_EXT 0x8079 +#define GL_VERTEX_ARRAY_SIZE_EXT 0x807A +#define GL_VERTEX_ARRAY_TYPE_EXT 0x807B +#define GL_VERTEX_ARRAY_STRIDE_EXT 0x807C +#define GL_VERTEX_ARRAY_COUNT_EXT 0x807D +#define GL_NORMAL_ARRAY_TYPE_EXT 0x807E +#define GL_NORMAL_ARRAY_STRIDE_EXT 0x807F +#define GL_NORMAL_ARRAY_COUNT_EXT 0x8080 +#define GL_COLOR_ARRAY_SIZE_EXT 0x8081 +#define GL_COLOR_ARRAY_TYPE_EXT 0x8082 +#define GL_COLOR_ARRAY_STRIDE_EXT 0x8083 +#define GL_COLOR_ARRAY_COUNT_EXT 0x8084 +#define GL_INDEX_ARRAY_TYPE_EXT 0x8085 +#define GL_INDEX_ARRAY_STRIDE_EXT 0x8086 +#define GL_INDEX_ARRAY_COUNT_EXT 0x8087 +#define GL_TEXTURE_COORD_ARRAY_SIZE_EXT 0x8088 +#define GL_TEXTURE_COORD_ARRAY_TYPE_EXT 0x8089 +#define GL_TEXTURE_COORD_ARRAY_STRIDE_EXT 0x808A +#define GL_TEXTURE_COORD_ARRAY_COUNT_EXT 0x808B +#define GL_EDGE_FLAG_ARRAY_STRIDE_EXT 0x808C +#define GL_EDGE_FLAG_ARRAY_COUNT_EXT 0x808D +#define GL_VERTEX_ARRAY_POINTER_EXT 0x808E +#define GL_NORMAL_ARRAY_POINTER_EXT 0x808F +#define GL_COLOR_ARRAY_POINTER_EXT 0x8090 +#define GL_INDEX_ARRAY_POINTER_EXT 0x8091 +#define GL_TEXTURE_COORD_ARRAY_POINTER_EXT 0x8092 +#define GL_EDGE_FLAG_ARRAY_POINTER_EXT 0x8093 + +typedef void (GLAPIENTRY * PFNGLARRAYELEMENTEXTPROC) (GLint i); +typedef void (GLAPIENTRY * PFNGLCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer); +typedef void (GLAPIENTRY * PFNGLDRAWARRAYSEXTPROC) (GLenum mode, GLint first, GLsizei count); +typedef void (GLAPIENTRY * PFNGLEDGEFLAGPOINTEREXTPROC) (GLsizei stride, GLsizei count, const GLboolean* pointer); +typedef void (GLAPIENTRY * PFNGLGETPOINTERVEXTPROC) (GLenum pname, void** params); +typedef void (GLAPIENTRY * PFNGLINDEXPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const void* pointer); +typedef void (GLAPIENTRY * PFNGLNORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const void* pointer); +typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer); +typedef void (GLAPIENTRY * PFNGLVERTEXPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer); + +#define glArrayElementEXT GLEW_GET_FUN(__glewArrayElementEXT) +#define glColorPointerEXT GLEW_GET_FUN(__glewColorPointerEXT) +#define glDrawArraysEXT GLEW_GET_FUN(__glewDrawArraysEXT) +#define glEdgeFlagPointerEXT GLEW_GET_FUN(__glewEdgeFlagPointerEXT) +#define glGetPointervEXT GLEW_GET_FUN(__glewGetPointervEXT) +#define glIndexPointerEXT GLEW_GET_FUN(__glewIndexPointerEXT) +#define glNormalPointerEXT GLEW_GET_FUN(__glewNormalPointerEXT) +#define glTexCoordPointerEXT GLEW_GET_FUN(__glewTexCoordPointerEXT) +#define glVertexPointerEXT GLEW_GET_FUN(__glewVertexPointerEXT) + +#define GLEW_EXT_vertex_array GLEW_GET_VAR(__GLEW_EXT_vertex_array) + +#endif /* GL_EXT_vertex_array */ + +/* ------------------------ GL_EXT_vertex_array_bgra ----------------------- */ + +#ifndef GL_EXT_vertex_array_bgra +#define GL_EXT_vertex_array_bgra 1 + +#define GL_BGRA 0x80E1 + +#define GLEW_EXT_vertex_array_bgra GLEW_GET_VAR(__GLEW_EXT_vertex_array_bgra) + +#endif /* GL_EXT_vertex_array_bgra */ + +/* ----------------------- GL_EXT_vertex_attrib_64bit ---------------------- */ + +#ifndef GL_EXT_vertex_attrib_64bit +#define GL_EXT_vertex_attrib_64bit 1 + +#define GL_DOUBLE_MAT2_EXT 0x8F46 +#define GL_DOUBLE_MAT3_EXT 0x8F47 +#define GL_DOUBLE_MAT4_EXT 0x8F48 +#define GL_DOUBLE_VEC2_EXT 0x8FFC +#define GL_DOUBLE_VEC3_EXT 0x8FFD +#define GL_DOUBLE_VEC4_EXT 0x8FFE + +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLDVEXTPROC) (GLuint index, GLenum pname, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DEXTPROC) (GLuint index, GLdouble x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DVEXTPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DEXTPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DVEXTPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DVEXTPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DVEXTPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer); + +#define glGetVertexAttribLdvEXT GLEW_GET_FUN(__glewGetVertexAttribLdvEXT) +#define glVertexArrayVertexAttribLOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribLOffsetEXT) +#define glVertexAttribL1dEXT GLEW_GET_FUN(__glewVertexAttribL1dEXT) +#define glVertexAttribL1dvEXT GLEW_GET_FUN(__glewVertexAttribL1dvEXT) +#define glVertexAttribL2dEXT GLEW_GET_FUN(__glewVertexAttribL2dEXT) +#define glVertexAttribL2dvEXT GLEW_GET_FUN(__glewVertexAttribL2dvEXT) +#define glVertexAttribL3dEXT GLEW_GET_FUN(__glewVertexAttribL3dEXT) +#define glVertexAttribL3dvEXT GLEW_GET_FUN(__glewVertexAttribL3dvEXT) +#define glVertexAttribL4dEXT GLEW_GET_FUN(__glewVertexAttribL4dEXT) +#define glVertexAttribL4dvEXT GLEW_GET_FUN(__glewVertexAttribL4dvEXT) +#define glVertexAttribLPointerEXT GLEW_GET_FUN(__glewVertexAttribLPointerEXT) + +#define GLEW_EXT_vertex_attrib_64bit GLEW_GET_VAR(__GLEW_EXT_vertex_attrib_64bit) + +#endif /* GL_EXT_vertex_attrib_64bit */ + +/* -------------------------- GL_EXT_vertex_shader ------------------------- */ + +#ifndef GL_EXT_vertex_shader +#define GL_EXT_vertex_shader 1 + +#define GL_VERTEX_SHADER_EXT 0x8780 +#define GL_VERTEX_SHADER_BINDING_EXT 0x8781 +#define GL_OP_INDEX_EXT 0x8782 +#define GL_OP_NEGATE_EXT 0x8783 +#define GL_OP_DOT3_EXT 0x8784 +#define GL_OP_DOT4_EXT 0x8785 +#define GL_OP_MUL_EXT 0x8786 +#define GL_OP_ADD_EXT 0x8787 +#define GL_OP_MADD_EXT 0x8788 +#define GL_OP_FRAC_EXT 0x8789 +#define GL_OP_MAX_EXT 0x878A +#define GL_OP_MIN_EXT 0x878B +#define GL_OP_SET_GE_EXT 0x878C +#define GL_OP_SET_LT_EXT 0x878D +#define GL_OP_CLAMP_EXT 0x878E +#define GL_OP_FLOOR_EXT 0x878F +#define GL_OP_ROUND_EXT 0x8790 +#define GL_OP_EXP_BASE_2_EXT 0x8791 +#define GL_OP_LOG_BASE_2_EXT 0x8792 +#define GL_OP_POWER_EXT 0x8793 +#define GL_OP_RECIP_EXT 0x8794 +#define GL_OP_RECIP_SQRT_EXT 0x8795 +#define GL_OP_SUB_EXT 0x8796 +#define GL_OP_CROSS_PRODUCT_EXT 0x8797 +#define GL_OP_MULTIPLY_MATRIX_EXT 0x8798 +#define GL_OP_MOV_EXT 0x8799 +#define GL_OUTPUT_VERTEX_EXT 0x879A +#define GL_OUTPUT_COLOR0_EXT 0x879B +#define GL_OUTPUT_COLOR1_EXT 0x879C +#define GL_OUTPUT_TEXTURE_COORD0_EXT 0x879D +#define GL_OUTPUT_TEXTURE_COORD1_EXT 0x879E +#define GL_OUTPUT_TEXTURE_COORD2_EXT 0x879F +#define GL_OUTPUT_TEXTURE_COORD3_EXT 0x87A0 +#define GL_OUTPUT_TEXTURE_COORD4_EXT 0x87A1 +#define GL_OUTPUT_TEXTURE_COORD5_EXT 0x87A2 +#define GL_OUTPUT_TEXTURE_COORD6_EXT 0x87A3 +#define GL_OUTPUT_TEXTURE_COORD7_EXT 0x87A4 +#define GL_OUTPUT_TEXTURE_COORD8_EXT 0x87A5 +#define GL_OUTPUT_TEXTURE_COORD9_EXT 0x87A6 +#define GL_OUTPUT_TEXTURE_COORD10_EXT 0x87A7 +#define GL_OUTPUT_TEXTURE_COORD11_EXT 0x87A8 +#define GL_OUTPUT_TEXTURE_COORD12_EXT 0x87A9 +#define GL_OUTPUT_TEXTURE_COORD13_EXT 0x87AA +#define GL_OUTPUT_TEXTURE_COORD14_EXT 0x87AB +#define GL_OUTPUT_TEXTURE_COORD15_EXT 0x87AC +#define GL_OUTPUT_TEXTURE_COORD16_EXT 0x87AD +#define GL_OUTPUT_TEXTURE_COORD17_EXT 0x87AE +#define GL_OUTPUT_TEXTURE_COORD18_EXT 0x87AF +#define GL_OUTPUT_TEXTURE_COORD19_EXT 0x87B0 +#define GL_OUTPUT_TEXTURE_COORD20_EXT 0x87B1 +#define GL_OUTPUT_TEXTURE_COORD21_EXT 0x87B2 +#define GL_OUTPUT_TEXTURE_COORD22_EXT 0x87B3 +#define GL_OUTPUT_TEXTURE_COORD23_EXT 0x87B4 +#define GL_OUTPUT_TEXTURE_COORD24_EXT 0x87B5 +#define GL_OUTPUT_TEXTURE_COORD25_EXT 0x87B6 +#define GL_OUTPUT_TEXTURE_COORD26_EXT 0x87B7 +#define GL_OUTPUT_TEXTURE_COORD27_EXT 0x87B8 +#define GL_OUTPUT_TEXTURE_COORD28_EXT 0x87B9 +#define GL_OUTPUT_TEXTURE_COORD29_EXT 0x87BA +#define GL_OUTPUT_TEXTURE_COORD30_EXT 0x87BB +#define GL_OUTPUT_TEXTURE_COORD31_EXT 0x87BC +#define GL_OUTPUT_FOG_EXT 0x87BD +#define GL_SCALAR_EXT 0x87BE +#define GL_VECTOR_EXT 0x87BF +#define GL_MATRIX_EXT 0x87C0 +#define GL_VARIANT_EXT 0x87C1 +#define GL_INVARIANT_EXT 0x87C2 +#define GL_LOCAL_CONSTANT_EXT 0x87C3 +#define GL_LOCAL_EXT 0x87C4 +#define GL_MAX_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87C5 +#define GL_MAX_VERTEX_SHADER_VARIANTS_EXT 0x87C6 +#define GL_MAX_VERTEX_SHADER_INVARIANTS_EXT 0x87C7 +#define GL_MAX_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87C8 +#define GL_MAX_VERTEX_SHADER_LOCALS_EXT 0x87C9 +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CA +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_VARIANTS_EXT 0x87CB +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INVARIANTS_EXT 0x87CC +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87CD +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCALS_EXT 0x87CE +#define GL_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CF +#define GL_VERTEX_SHADER_VARIANTS_EXT 0x87D0 +#define GL_VERTEX_SHADER_INVARIANTS_EXT 0x87D1 +#define GL_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87D2 +#define GL_VERTEX_SHADER_LOCALS_EXT 0x87D3 +#define GL_VERTEX_SHADER_OPTIMIZED_EXT 0x87D4 +#define GL_X_EXT 0x87D5 +#define GL_Y_EXT 0x87D6 +#define GL_Z_EXT 0x87D7 +#define GL_W_EXT 0x87D8 +#define GL_NEGATIVE_X_EXT 0x87D9 +#define GL_NEGATIVE_Y_EXT 0x87DA +#define GL_NEGATIVE_Z_EXT 0x87DB +#define GL_NEGATIVE_W_EXT 0x87DC +#define GL_ZERO_EXT 0x87DD +#define GL_ONE_EXT 0x87DE +#define GL_NEGATIVE_ONE_EXT 0x87DF +#define GL_NORMALIZED_RANGE_EXT 0x87E0 +#define GL_FULL_RANGE_EXT 0x87E1 +#define GL_CURRENT_VERTEX_EXT 0x87E2 +#define GL_MVP_MATRIX_EXT 0x87E3 +#define GL_VARIANT_VALUE_EXT 0x87E4 +#define GL_VARIANT_DATATYPE_EXT 0x87E5 +#define GL_VARIANT_ARRAY_STRIDE_EXT 0x87E6 +#define GL_VARIANT_ARRAY_TYPE_EXT 0x87E7 +#define GL_VARIANT_ARRAY_EXT 0x87E8 +#define GL_VARIANT_ARRAY_POINTER_EXT 0x87E9 +#define GL_INVARIANT_VALUE_EXT 0x87EA +#define GL_INVARIANT_DATATYPE_EXT 0x87EB +#define GL_LOCAL_CONSTANT_VALUE_EXT 0x87EC +#define GL_LOCAL_CONSTANT_DATATYPE_EXT 0x87ED + +typedef void (GLAPIENTRY * PFNGLBEGINVERTEXSHADEREXTPROC) (void); +typedef GLuint (GLAPIENTRY * PFNGLBINDLIGHTPARAMETEREXTPROC) (GLenum light, GLenum value); +typedef GLuint (GLAPIENTRY * PFNGLBINDMATERIALPARAMETEREXTPROC) (GLenum face, GLenum value); +typedef GLuint (GLAPIENTRY * PFNGLBINDPARAMETEREXTPROC) (GLenum value); +typedef GLuint (GLAPIENTRY * PFNGLBINDTEXGENPARAMETEREXTPROC) (GLenum unit, GLenum coord, GLenum value); +typedef GLuint (GLAPIENTRY * PFNGLBINDTEXTUREUNITPARAMETEREXTPROC) (GLenum unit, GLenum value); +typedef void (GLAPIENTRY * PFNGLBINDVERTEXSHADEREXTPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLDELETEVERTEXSHADEREXTPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLENABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLENDVERTEXSHADEREXTPROC) (void); +typedef void (GLAPIENTRY * PFNGLEXTRACTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); +typedef GLuint (GLAPIENTRY * PFNGLGENSYMBOLSEXTPROC) (GLenum dataType, GLenum storageType, GLenum range, GLuint components); +typedef GLuint (GLAPIENTRY * PFNGLGENVERTEXSHADERSEXTPROC) (GLuint range); +typedef void (GLAPIENTRY * PFNGLGETINVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (GLAPIENTRY * PFNGLGETINVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +typedef void (GLAPIENTRY * PFNGLGETINVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (GLAPIENTRY * PFNGLGETVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (GLAPIENTRY * PFNGLGETVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +typedef void (GLAPIENTRY * PFNGLGETVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (GLAPIENTRY * PFNGLGETVARIANTPOINTERVEXTPROC) (GLuint id, GLenum value, GLvoid **data); +typedef void (GLAPIENTRY * PFNGLINSERTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); +typedef GLboolean (GLAPIENTRY * PFNGLISVARIANTENABLEDEXTPROC) (GLuint id, GLenum cap); +typedef void (GLAPIENTRY * PFNGLSETINVARIANTEXTPROC) (GLuint id, GLenum type, GLvoid *addr); +typedef void (GLAPIENTRY * PFNGLSETLOCALCONSTANTEXTPROC) (GLuint id, GLenum type, GLvoid *addr); +typedef void (GLAPIENTRY * PFNGLSHADEROP1EXTPROC) (GLenum op, GLuint res, GLuint arg1); +typedef void (GLAPIENTRY * PFNGLSHADEROP2EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2); +typedef void (GLAPIENTRY * PFNGLSHADEROP3EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3); +typedef void (GLAPIENTRY * PFNGLSWIZZLEEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); +typedef void (GLAPIENTRY * PFNGLVARIANTPOINTEREXTPROC) (GLuint id, GLenum type, GLuint stride, GLvoid *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTBVEXTPROC) (GLuint id, GLbyte *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTDVEXTPROC) (GLuint id, GLdouble *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTFVEXTPROC) (GLuint id, GLfloat *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTIVEXTPROC) (GLuint id, GLint *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTSVEXTPROC) (GLuint id, GLshort *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTUBVEXTPROC) (GLuint id, GLubyte *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTUIVEXTPROC) (GLuint id, GLuint *addr); +typedef void (GLAPIENTRY * PFNGLVARIANTUSVEXTPROC) (GLuint id, GLushort *addr); +typedef void (GLAPIENTRY * PFNGLWRITEMASKEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); + +#define glBeginVertexShaderEXT GLEW_GET_FUN(__glewBeginVertexShaderEXT) +#define glBindLightParameterEXT GLEW_GET_FUN(__glewBindLightParameterEXT) +#define glBindMaterialParameterEXT GLEW_GET_FUN(__glewBindMaterialParameterEXT) +#define glBindParameterEXT GLEW_GET_FUN(__glewBindParameterEXT) +#define glBindTexGenParameterEXT GLEW_GET_FUN(__glewBindTexGenParameterEXT) +#define glBindTextureUnitParameterEXT GLEW_GET_FUN(__glewBindTextureUnitParameterEXT) +#define glBindVertexShaderEXT GLEW_GET_FUN(__glewBindVertexShaderEXT) +#define glDeleteVertexShaderEXT GLEW_GET_FUN(__glewDeleteVertexShaderEXT) +#define glDisableVariantClientStateEXT GLEW_GET_FUN(__glewDisableVariantClientStateEXT) +#define glEnableVariantClientStateEXT GLEW_GET_FUN(__glewEnableVariantClientStateEXT) +#define glEndVertexShaderEXT GLEW_GET_FUN(__glewEndVertexShaderEXT) +#define glExtractComponentEXT GLEW_GET_FUN(__glewExtractComponentEXT) +#define glGenSymbolsEXT GLEW_GET_FUN(__glewGenSymbolsEXT) +#define glGenVertexShadersEXT GLEW_GET_FUN(__glewGenVertexShadersEXT) +#define glGetInvariantBooleanvEXT GLEW_GET_FUN(__glewGetInvariantBooleanvEXT) +#define glGetInvariantFloatvEXT GLEW_GET_FUN(__glewGetInvariantFloatvEXT) +#define glGetInvariantIntegervEXT GLEW_GET_FUN(__glewGetInvariantIntegervEXT) +#define glGetLocalConstantBooleanvEXT GLEW_GET_FUN(__glewGetLocalConstantBooleanvEXT) +#define glGetLocalConstantFloatvEXT GLEW_GET_FUN(__glewGetLocalConstantFloatvEXT) +#define glGetLocalConstantIntegervEXT GLEW_GET_FUN(__glewGetLocalConstantIntegervEXT) +#define glGetVariantBooleanvEXT GLEW_GET_FUN(__glewGetVariantBooleanvEXT) +#define glGetVariantFloatvEXT GLEW_GET_FUN(__glewGetVariantFloatvEXT) +#define glGetVariantIntegervEXT GLEW_GET_FUN(__glewGetVariantIntegervEXT) +#define glGetVariantPointervEXT GLEW_GET_FUN(__glewGetVariantPointervEXT) +#define glInsertComponentEXT GLEW_GET_FUN(__glewInsertComponentEXT) +#define glIsVariantEnabledEXT GLEW_GET_FUN(__glewIsVariantEnabledEXT) +#define glSetInvariantEXT GLEW_GET_FUN(__glewSetInvariantEXT) +#define glSetLocalConstantEXT GLEW_GET_FUN(__glewSetLocalConstantEXT) +#define glShaderOp1EXT GLEW_GET_FUN(__glewShaderOp1EXT) +#define glShaderOp2EXT GLEW_GET_FUN(__glewShaderOp2EXT) +#define glShaderOp3EXT GLEW_GET_FUN(__glewShaderOp3EXT) +#define glSwizzleEXT GLEW_GET_FUN(__glewSwizzleEXT) +#define glVariantPointerEXT GLEW_GET_FUN(__glewVariantPointerEXT) +#define glVariantbvEXT GLEW_GET_FUN(__glewVariantbvEXT) +#define glVariantdvEXT GLEW_GET_FUN(__glewVariantdvEXT) +#define glVariantfvEXT GLEW_GET_FUN(__glewVariantfvEXT) +#define glVariantivEXT GLEW_GET_FUN(__glewVariantivEXT) +#define glVariantsvEXT GLEW_GET_FUN(__glewVariantsvEXT) +#define glVariantubvEXT GLEW_GET_FUN(__glewVariantubvEXT) +#define glVariantuivEXT GLEW_GET_FUN(__glewVariantuivEXT) +#define glVariantusvEXT GLEW_GET_FUN(__glewVariantusvEXT) +#define glWriteMaskEXT GLEW_GET_FUN(__glewWriteMaskEXT) + +#define GLEW_EXT_vertex_shader GLEW_GET_VAR(__GLEW_EXT_vertex_shader) + +#endif /* GL_EXT_vertex_shader */ + +/* ------------------------ GL_EXT_vertex_weighting ------------------------ */ + +#ifndef GL_EXT_vertex_weighting +#define GL_EXT_vertex_weighting 1 + +#define GL_MODELVIEW0_STACK_DEPTH_EXT 0x0BA3 +#define GL_MODELVIEW0_MATRIX_EXT 0x0BA6 +#define GL_MODELVIEW0_EXT 0x1700 +#define GL_MODELVIEW1_STACK_DEPTH_EXT 0x8502 +#define GL_MODELVIEW1_MATRIX_EXT 0x8506 +#define GL_VERTEX_WEIGHTING_EXT 0x8509 +#define GL_MODELVIEW1_EXT 0x850A +#define GL_CURRENT_VERTEX_WEIGHT_EXT 0x850B +#define GL_VERTEX_WEIGHT_ARRAY_EXT 0x850C +#define GL_VERTEX_WEIGHT_ARRAY_SIZE_EXT 0x850D +#define GL_VERTEX_WEIGHT_ARRAY_TYPE_EXT 0x850E +#define GL_VERTEX_WEIGHT_ARRAY_STRIDE_EXT 0x850F +#define GL_VERTEX_WEIGHT_ARRAY_POINTER_EXT 0x8510 + +typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, void* pointer); +typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTFEXTPROC) (GLfloat weight); +typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTFVEXTPROC) (GLfloat* weight); + +#define glVertexWeightPointerEXT GLEW_GET_FUN(__glewVertexWeightPointerEXT) +#define glVertexWeightfEXT GLEW_GET_FUN(__glewVertexWeightfEXT) +#define glVertexWeightfvEXT GLEW_GET_FUN(__glewVertexWeightfvEXT) + +#define GLEW_EXT_vertex_weighting GLEW_GET_VAR(__GLEW_EXT_vertex_weighting) + +#endif /* GL_EXT_vertex_weighting */ + +/* ---------------------- GL_GREMEDY_frame_terminator ---------------------- */ + +#ifndef GL_GREMEDY_frame_terminator +#define GL_GREMEDY_frame_terminator 1 + +typedef void (GLAPIENTRY * PFNGLFRAMETERMINATORGREMEDYPROC) (void); + +#define glFrameTerminatorGREMEDY GLEW_GET_FUN(__glewFrameTerminatorGREMEDY) + +#define GLEW_GREMEDY_frame_terminator GLEW_GET_VAR(__GLEW_GREMEDY_frame_terminator) + +#endif /* GL_GREMEDY_frame_terminator */ + +/* ------------------------ GL_GREMEDY_string_marker ----------------------- */ + +#ifndef GL_GREMEDY_string_marker +#define GL_GREMEDY_string_marker 1 + +typedef void (GLAPIENTRY * PFNGLSTRINGMARKERGREMEDYPROC) (GLsizei len, const void* string); + +#define glStringMarkerGREMEDY GLEW_GET_FUN(__glewStringMarkerGREMEDY) + +#define GLEW_GREMEDY_string_marker GLEW_GET_VAR(__GLEW_GREMEDY_string_marker) + +#endif /* GL_GREMEDY_string_marker */ + +/* --------------------- GL_HP_convolution_border_modes -------------------- */ + +#ifndef GL_HP_convolution_border_modes +#define GL_HP_convolution_border_modes 1 + +#define GLEW_HP_convolution_border_modes GLEW_GET_VAR(__GLEW_HP_convolution_border_modes) + +#endif /* GL_HP_convolution_border_modes */ + +/* ------------------------- GL_HP_image_transform ------------------------- */ + +#ifndef GL_HP_image_transform +#define GL_HP_image_transform 1 + +typedef void (GLAPIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERFHPPROC) (GLenum target, GLenum pname, const GLfloat param); +typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERIHPPROC) (GLenum target, GLenum pname, const GLint param); +typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint* params); + +#define glGetImageTransformParameterfvHP GLEW_GET_FUN(__glewGetImageTransformParameterfvHP) +#define glGetImageTransformParameterivHP GLEW_GET_FUN(__glewGetImageTransformParameterivHP) +#define glImageTransformParameterfHP GLEW_GET_FUN(__glewImageTransformParameterfHP) +#define glImageTransformParameterfvHP GLEW_GET_FUN(__glewImageTransformParameterfvHP) +#define glImageTransformParameteriHP GLEW_GET_FUN(__glewImageTransformParameteriHP) +#define glImageTransformParameterivHP GLEW_GET_FUN(__glewImageTransformParameterivHP) + +#define GLEW_HP_image_transform GLEW_GET_VAR(__GLEW_HP_image_transform) + +#endif /* GL_HP_image_transform */ + +/* -------------------------- GL_HP_occlusion_test ------------------------- */ + +#ifndef GL_HP_occlusion_test +#define GL_HP_occlusion_test 1 + +#define GL_OCCLUSION_TEST_HP 0x8165 +#define GL_OCCLUSION_TEST_RESULT_HP 0x8166 + +#define GLEW_HP_occlusion_test GLEW_GET_VAR(__GLEW_HP_occlusion_test) + +#endif /* GL_HP_occlusion_test */ + +/* ------------------------- GL_HP_texture_lighting ------------------------ */ + +#ifndef GL_HP_texture_lighting +#define GL_HP_texture_lighting 1 + +#define GLEW_HP_texture_lighting GLEW_GET_VAR(__GLEW_HP_texture_lighting) + +#endif /* GL_HP_texture_lighting */ + +/* --------------------------- GL_IBM_cull_vertex -------------------------- */ + +#ifndef GL_IBM_cull_vertex +#define GL_IBM_cull_vertex 1 + +#define GL_CULL_VERTEX_IBM 103050 + +#define GLEW_IBM_cull_vertex GLEW_GET_VAR(__GLEW_IBM_cull_vertex) + +#endif /* GL_IBM_cull_vertex */ + +/* ---------------------- GL_IBM_multimode_draw_arrays --------------------- */ + +#ifndef GL_IBM_multimode_draw_arrays +#define GL_IBM_multimode_draw_arrays 1 + +typedef void (GLAPIENTRY * PFNGLMULTIMODEDRAWARRAYSIBMPROC) (const GLenum* mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride); +typedef void (GLAPIENTRY * PFNGLMULTIMODEDRAWELEMENTSIBMPROC) (const GLenum* mode, const GLsizei *count, GLenum type, const GLvoid * const *indices, GLsizei primcount, GLint modestride); + +#define glMultiModeDrawArraysIBM GLEW_GET_FUN(__glewMultiModeDrawArraysIBM) +#define glMultiModeDrawElementsIBM GLEW_GET_FUN(__glewMultiModeDrawElementsIBM) + +#define GLEW_IBM_multimode_draw_arrays GLEW_GET_VAR(__GLEW_IBM_multimode_draw_arrays) + +#endif /* GL_IBM_multimode_draw_arrays */ + +/* ------------------------- GL_IBM_rasterpos_clip ------------------------- */ + +#ifndef GL_IBM_rasterpos_clip +#define GL_IBM_rasterpos_clip 1 + +#define GL_RASTER_POSITION_UNCLIPPED_IBM 103010 + +#define GLEW_IBM_rasterpos_clip GLEW_GET_VAR(__GLEW_IBM_rasterpos_clip) + +#endif /* GL_IBM_rasterpos_clip */ + +/* --------------------------- GL_IBM_static_data -------------------------- */ + +#ifndef GL_IBM_static_data +#define GL_IBM_static_data 1 + +#define GL_ALL_STATIC_DATA_IBM 103060 +#define GL_STATIC_VERTEX_ARRAY_IBM 103061 + +#define GLEW_IBM_static_data GLEW_GET_VAR(__GLEW_IBM_static_data) + +#endif /* GL_IBM_static_data */ + +/* --------------------- GL_IBM_texture_mirrored_repeat -------------------- */ + +#ifndef GL_IBM_texture_mirrored_repeat +#define GL_IBM_texture_mirrored_repeat 1 + +#define GL_MIRRORED_REPEAT_IBM 0x8370 + +#define GLEW_IBM_texture_mirrored_repeat GLEW_GET_VAR(__GLEW_IBM_texture_mirrored_repeat) + +#endif /* GL_IBM_texture_mirrored_repeat */ + +/* ----------------------- GL_IBM_vertex_array_lists ----------------------- */ + +#ifndef GL_IBM_vertex_array_lists +#define GL_IBM_vertex_array_lists 1 + +#define GL_VERTEX_ARRAY_LIST_IBM 103070 +#define GL_NORMAL_ARRAY_LIST_IBM 103071 +#define GL_COLOR_ARRAY_LIST_IBM 103072 +#define GL_INDEX_ARRAY_LIST_IBM 103073 +#define GL_TEXTURE_COORD_ARRAY_LIST_IBM 103074 +#define GL_EDGE_FLAG_ARRAY_LIST_IBM 103075 +#define GL_FOG_COORDINATE_ARRAY_LIST_IBM 103076 +#define GL_SECONDARY_COLOR_ARRAY_LIST_IBM 103077 +#define GL_VERTEX_ARRAY_LIST_STRIDE_IBM 103080 +#define GL_NORMAL_ARRAY_LIST_STRIDE_IBM 103081 +#define GL_COLOR_ARRAY_LIST_STRIDE_IBM 103082 +#define GL_INDEX_ARRAY_LIST_STRIDE_IBM 103083 +#define GL_TEXTURE_COORD_ARRAY_LIST_STRIDE_IBM 103084 +#define GL_EDGE_FLAG_ARRAY_LIST_STRIDE_IBM 103085 +#define GL_FOG_COORDINATE_ARRAY_LIST_STRIDE_IBM 103086 +#define GL_SECONDARY_COLOR_ARRAY_LIST_STRIDE_IBM 103087 + +typedef void (GLAPIENTRY * PFNGLCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); +typedef void (GLAPIENTRY * PFNGLEDGEFLAGPOINTERLISTIBMPROC) (GLint stride, const GLboolean ** pointer, GLint ptrstride); +typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); +typedef void (GLAPIENTRY * PFNGLINDEXPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); +typedef void (GLAPIENTRY * PFNGLNORMALPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); +typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); +typedef void (GLAPIENTRY * PFNGLVERTEXPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); + +#define glColorPointerListIBM GLEW_GET_FUN(__glewColorPointerListIBM) +#define glEdgeFlagPointerListIBM GLEW_GET_FUN(__glewEdgeFlagPointerListIBM) +#define glFogCoordPointerListIBM GLEW_GET_FUN(__glewFogCoordPointerListIBM) +#define glIndexPointerListIBM GLEW_GET_FUN(__glewIndexPointerListIBM) +#define glNormalPointerListIBM GLEW_GET_FUN(__glewNormalPointerListIBM) +#define glSecondaryColorPointerListIBM GLEW_GET_FUN(__glewSecondaryColorPointerListIBM) +#define glTexCoordPointerListIBM GLEW_GET_FUN(__glewTexCoordPointerListIBM) +#define glVertexPointerListIBM GLEW_GET_FUN(__glewVertexPointerListIBM) + +#define GLEW_IBM_vertex_array_lists GLEW_GET_VAR(__GLEW_IBM_vertex_array_lists) + +#endif /* GL_IBM_vertex_array_lists */ + +/* -------------------------- GL_INGR_color_clamp -------------------------- */ + +#ifndef GL_INGR_color_clamp +#define GL_INGR_color_clamp 1 + +#define GL_RED_MIN_CLAMP_INGR 0x8560 +#define GL_GREEN_MIN_CLAMP_INGR 0x8561 +#define GL_BLUE_MIN_CLAMP_INGR 0x8562 +#define GL_ALPHA_MIN_CLAMP_INGR 0x8563 +#define GL_RED_MAX_CLAMP_INGR 0x8564 +#define GL_GREEN_MAX_CLAMP_INGR 0x8565 +#define GL_BLUE_MAX_CLAMP_INGR 0x8566 +#define GL_ALPHA_MAX_CLAMP_INGR 0x8567 + +#define GLEW_INGR_color_clamp GLEW_GET_VAR(__GLEW_INGR_color_clamp) + +#endif /* GL_INGR_color_clamp */ + +/* ------------------------- GL_INGR_interlace_read ------------------------ */ + +#ifndef GL_INGR_interlace_read +#define GL_INGR_interlace_read 1 + +#define GL_INTERLACE_READ_INGR 0x8568 + +#define GLEW_INGR_interlace_read GLEW_GET_VAR(__GLEW_INGR_interlace_read) + +#endif /* GL_INGR_interlace_read */ + +/* ------------------------ GL_INTEL_parallel_arrays ----------------------- */ + +#ifndef GL_INTEL_parallel_arrays +#define GL_INTEL_parallel_arrays 1 + +#define GL_PARALLEL_ARRAYS_INTEL 0x83F4 +#define GL_VERTEX_ARRAY_PARALLEL_POINTERS_INTEL 0x83F5 +#define GL_NORMAL_ARRAY_PARALLEL_POINTERS_INTEL 0x83F6 +#define GL_COLOR_ARRAY_PARALLEL_POINTERS_INTEL 0x83F7 +#define GL_TEXTURE_COORD_ARRAY_PARALLEL_POINTERS_INTEL 0x83F8 + +typedef void (GLAPIENTRY * PFNGLCOLORPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); +typedef void (GLAPIENTRY * PFNGLNORMALPOINTERVINTELPROC) (GLenum type, const void** pointer); +typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); +typedef void (GLAPIENTRY * PFNGLVERTEXPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); + +#define glColorPointervINTEL GLEW_GET_FUN(__glewColorPointervINTEL) +#define glNormalPointervINTEL GLEW_GET_FUN(__glewNormalPointervINTEL) +#define glTexCoordPointervINTEL GLEW_GET_FUN(__glewTexCoordPointervINTEL) +#define glVertexPointervINTEL GLEW_GET_FUN(__glewVertexPointervINTEL) + +#define GLEW_INTEL_parallel_arrays GLEW_GET_VAR(__GLEW_INTEL_parallel_arrays) + +#endif /* GL_INTEL_parallel_arrays */ + +/* ------------------------ GL_INTEL_texture_scissor ----------------------- */ + +#ifndef GL_INTEL_texture_scissor +#define GL_INTEL_texture_scissor 1 + +typedef void (GLAPIENTRY * PFNGLTEXSCISSORFUNCINTELPROC) (GLenum target, GLenum lfunc, GLenum hfunc); +typedef void (GLAPIENTRY * PFNGLTEXSCISSORINTELPROC) (GLenum target, GLclampf tlow, GLclampf thigh); + +#define glTexScissorFuncINTEL GLEW_GET_FUN(__glewTexScissorFuncINTEL) +#define glTexScissorINTEL GLEW_GET_FUN(__glewTexScissorINTEL) + +#define GLEW_INTEL_texture_scissor GLEW_GET_VAR(__GLEW_INTEL_texture_scissor) + +#endif /* GL_INTEL_texture_scissor */ + +/* -------------------------- GL_KTX_buffer_region ------------------------- */ + +#ifndef GL_KTX_buffer_region +#define GL_KTX_buffer_region 1 + +#define GL_KTX_FRONT_REGION 0x0 +#define GL_KTX_BACK_REGION 0x1 +#define GL_KTX_Z_REGION 0x2 +#define GL_KTX_STENCIL_REGION 0x3 + +typedef GLuint (GLAPIENTRY * PFNGLBUFFERREGIONENABLEDEXTPROC) (void); +typedef void (GLAPIENTRY * PFNGLDELETEBUFFERREGIONEXTPROC) (GLenum region); +typedef void (GLAPIENTRY * PFNGLDRAWBUFFERREGIONEXTPROC) (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height, GLint xDest, GLint yDest); +typedef GLuint (GLAPIENTRY * PFNGLNEWBUFFERREGIONEXTPROC) (GLenum region); +typedef void (GLAPIENTRY * PFNGLREADBUFFERREGIONEXTPROC) (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height); + +#define glBufferRegionEnabledEXT GLEW_GET_FUN(__glewBufferRegionEnabledEXT) +#define glDeleteBufferRegionEXT GLEW_GET_FUN(__glewDeleteBufferRegionEXT) +#define glDrawBufferRegionEXT GLEW_GET_FUN(__glewDrawBufferRegionEXT) +#define glNewBufferRegionEXT GLEW_GET_FUN(__glewNewBufferRegionEXT) +#define glReadBufferRegionEXT GLEW_GET_FUN(__glewReadBufferRegionEXT) + +#define GLEW_KTX_buffer_region GLEW_GET_VAR(__GLEW_KTX_buffer_region) + +#endif /* GL_KTX_buffer_region */ + +/* ------------------------- GL_MESAX_texture_stack ------------------------ */ + +#ifndef GL_MESAX_texture_stack +#define GL_MESAX_texture_stack 1 + +#define GL_TEXTURE_1D_STACK_MESAX 0x8759 +#define GL_TEXTURE_2D_STACK_MESAX 0x875A +#define GL_PROXY_TEXTURE_1D_STACK_MESAX 0x875B +#define GL_PROXY_TEXTURE_2D_STACK_MESAX 0x875C +#define GL_TEXTURE_1D_STACK_BINDING_MESAX 0x875D +#define GL_TEXTURE_2D_STACK_BINDING_MESAX 0x875E + +#define GLEW_MESAX_texture_stack GLEW_GET_VAR(__GLEW_MESAX_texture_stack) + +#endif /* GL_MESAX_texture_stack */ + +/* -------------------------- GL_MESA_pack_invert -------------------------- */ + +#ifndef GL_MESA_pack_invert +#define GL_MESA_pack_invert 1 + +#define GL_PACK_INVERT_MESA 0x8758 + +#define GLEW_MESA_pack_invert GLEW_GET_VAR(__GLEW_MESA_pack_invert) + +#endif /* GL_MESA_pack_invert */ + +/* ------------------------- GL_MESA_resize_buffers ------------------------ */ + +#ifndef GL_MESA_resize_buffers +#define GL_MESA_resize_buffers 1 + +typedef void (GLAPIENTRY * PFNGLRESIZEBUFFERSMESAPROC) (void); + +#define glResizeBuffersMESA GLEW_GET_FUN(__glewResizeBuffersMESA) + +#define GLEW_MESA_resize_buffers GLEW_GET_VAR(__GLEW_MESA_resize_buffers) + +#endif /* GL_MESA_resize_buffers */ + +/* --------------------------- GL_MESA_window_pos -------------------------- */ + +#ifndef GL_MESA_window_pos +#define GL_MESA_window_pos 1 + +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DMESAPROC) (GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVMESAPROC) (const GLdouble* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FMESAPROC) (GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVMESAPROC) (const GLfloat* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IMESAPROC) (GLint x, GLint y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVMESAPROC) (const GLint* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SMESAPROC) (GLshort x, GLshort y); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVMESAPROC) (const GLshort* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DMESAPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVMESAPROC) (const GLdouble* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FMESAPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVMESAPROC) (const GLfloat* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IMESAPROC) (GLint x, GLint y, GLint z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVMESAPROC) (const GLint* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SMESAPROC) (GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVMESAPROC) (const GLshort* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4DMESAPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4DVMESAPROC) (const GLdouble* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4FMESAPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4FVMESAPROC) (const GLfloat* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4IMESAPROC) (GLint x, GLint y, GLint z, GLint w); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4IVMESAPROC) (const GLint* p); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4SMESAPROC) (GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (GLAPIENTRY * PFNGLWINDOWPOS4SVMESAPROC) (const GLshort* p); + +#define glWindowPos2dMESA GLEW_GET_FUN(__glewWindowPos2dMESA) +#define glWindowPos2dvMESA GLEW_GET_FUN(__glewWindowPos2dvMESA) +#define glWindowPos2fMESA GLEW_GET_FUN(__glewWindowPos2fMESA) +#define glWindowPos2fvMESA GLEW_GET_FUN(__glewWindowPos2fvMESA) +#define glWindowPos2iMESA GLEW_GET_FUN(__glewWindowPos2iMESA) +#define glWindowPos2ivMESA GLEW_GET_FUN(__glewWindowPos2ivMESA) +#define glWindowPos2sMESA GLEW_GET_FUN(__glewWindowPos2sMESA) +#define glWindowPos2svMESA GLEW_GET_FUN(__glewWindowPos2svMESA) +#define glWindowPos3dMESA GLEW_GET_FUN(__glewWindowPos3dMESA) +#define glWindowPos3dvMESA GLEW_GET_FUN(__glewWindowPos3dvMESA) +#define glWindowPos3fMESA GLEW_GET_FUN(__glewWindowPos3fMESA) +#define glWindowPos3fvMESA GLEW_GET_FUN(__glewWindowPos3fvMESA) +#define glWindowPos3iMESA GLEW_GET_FUN(__glewWindowPos3iMESA) +#define glWindowPos3ivMESA GLEW_GET_FUN(__glewWindowPos3ivMESA) +#define glWindowPos3sMESA GLEW_GET_FUN(__glewWindowPos3sMESA) +#define glWindowPos3svMESA GLEW_GET_FUN(__glewWindowPos3svMESA) +#define glWindowPos4dMESA GLEW_GET_FUN(__glewWindowPos4dMESA) +#define glWindowPos4dvMESA GLEW_GET_FUN(__glewWindowPos4dvMESA) +#define glWindowPos4fMESA GLEW_GET_FUN(__glewWindowPos4fMESA) +#define glWindowPos4fvMESA GLEW_GET_FUN(__glewWindowPos4fvMESA) +#define glWindowPos4iMESA GLEW_GET_FUN(__glewWindowPos4iMESA) +#define glWindowPos4ivMESA GLEW_GET_FUN(__glewWindowPos4ivMESA) +#define glWindowPos4sMESA GLEW_GET_FUN(__glewWindowPos4sMESA) +#define glWindowPos4svMESA GLEW_GET_FUN(__glewWindowPos4svMESA) + +#define GLEW_MESA_window_pos GLEW_GET_VAR(__GLEW_MESA_window_pos) + +#endif /* GL_MESA_window_pos */ + +/* ------------------------- GL_MESA_ycbcr_texture ------------------------- */ + +#ifndef GL_MESA_ycbcr_texture +#define GL_MESA_ycbcr_texture 1 + +#define GL_UNSIGNED_SHORT_8_8_MESA 0x85BA +#define GL_UNSIGNED_SHORT_8_8_REV_MESA 0x85BB +#define GL_YCBCR_MESA 0x8757 + +#define GLEW_MESA_ycbcr_texture GLEW_GET_VAR(__GLEW_MESA_ycbcr_texture) + +#endif /* GL_MESA_ycbcr_texture */ + +/* --------------------------- GL_NV_blend_square -------------------------- */ + +#ifndef GL_NV_blend_square +#define GL_NV_blend_square 1 + +#define GLEW_NV_blend_square GLEW_GET_VAR(__GLEW_NV_blend_square) + +#endif /* GL_NV_blend_square */ + +/* ------------------------ GL_NV_conditional_render ----------------------- */ + +#ifndef GL_NV_conditional_render +#define GL_NV_conditional_render 1 + +#define GL_QUERY_WAIT_NV 0x8E13 +#define GL_QUERY_NO_WAIT_NV 0x8E14 +#define GL_QUERY_BY_REGION_WAIT_NV 0x8E15 +#define GL_QUERY_BY_REGION_NO_WAIT_NV 0x8E16 + +typedef void (GLAPIENTRY * PFNGLBEGINCONDITIONALRENDERNVPROC) (GLuint id, GLenum mode); +typedef void (GLAPIENTRY * PFNGLENDCONDITIONALRENDERNVPROC) (void); + +#define glBeginConditionalRenderNV GLEW_GET_FUN(__glewBeginConditionalRenderNV) +#define glEndConditionalRenderNV GLEW_GET_FUN(__glewEndConditionalRenderNV) + +#define GLEW_NV_conditional_render GLEW_GET_VAR(__GLEW_NV_conditional_render) + +#endif /* GL_NV_conditional_render */ + +/* ----------------------- GL_NV_copy_depth_to_color ----------------------- */ + +#ifndef GL_NV_copy_depth_to_color +#define GL_NV_copy_depth_to_color 1 + +#define GL_DEPTH_STENCIL_TO_RGBA_NV 0x886E +#define GL_DEPTH_STENCIL_TO_BGRA_NV 0x886F + +#define GLEW_NV_copy_depth_to_color GLEW_GET_VAR(__GLEW_NV_copy_depth_to_color) + +#endif /* GL_NV_copy_depth_to_color */ + +/* ---------------------------- GL_NV_copy_image --------------------------- */ + +#ifndef GL_NV_copy_image +#define GL_NV_copy_image 1 + +typedef void (GLAPIENTRY * PFNGLCOPYIMAGESUBDATANVPROC) (GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); + +#define glCopyImageSubDataNV GLEW_GET_FUN(__glewCopyImageSubDataNV) + +#define GLEW_NV_copy_image GLEW_GET_VAR(__GLEW_NV_copy_image) + +#endif /* GL_NV_copy_image */ + +/* ------------------------ GL_NV_depth_buffer_float ----------------------- */ + +#ifndef GL_NV_depth_buffer_float +#define GL_NV_depth_buffer_float 1 + +#define GL_DEPTH_COMPONENT32F_NV 0x8DAB +#define GL_DEPTH32F_STENCIL8_NV 0x8DAC +#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV_NV 0x8DAD +#define GL_DEPTH_BUFFER_FLOAT_MODE_NV 0x8DAF + +typedef void (GLAPIENTRY * PFNGLCLEARDEPTHDNVPROC) (GLdouble depth); +typedef void (GLAPIENTRY * PFNGLDEPTHBOUNDSDNVPROC) (GLdouble zmin, GLdouble zmax); +typedef void (GLAPIENTRY * PFNGLDEPTHRANGEDNVPROC) (GLdouble zNear, GLdouble zFar); + +#define glClearDepthdNV GLEW_GET_FUN(__glewClearDepthdNV) +#define glDepthBoundsdNV GLEW_GET_FUN(__glewDepthBoundsdNV) +#define glDepthRangedNV GLEW_GET_FUN(__glewDepthRangedNV) + +#define GLEW_NV_depth_buffer_float GLEW_GET_VAR(__GLEW_NV_depth_buffer_float) + +#endif /* GL_NV_depth_buffer_float */ + +/* --------------------------- GL_NV_depth_clamp --------------------------- */ + +#ifndef GL_NV_depth_clamp +#define GL_NV_depth_clamp 1 + +#define GL_DEPTH_CLAMP_NV 0x864F + +#define GLEW_NV_depth_clamp GLEW_GET_VAR(__GLEW_NV_depth_clamp) + +#endif /* GL_NV_depth_clamp */ + +/* ---------------------- GL_NV_depth_range_unclamped ---------------------- */ + +#ifndef GL_NV_depth_range_unclamped +#define GL_NV_depth_range_unclamped 1 + +#define GL_SAMPLE_COUNT_BITS_NV 0x8864 +#define GL_CURRENT_SAMPLE_COUNT_QUERY_NV 0x8865 +#define GL_QUERY_RESULT_NV 0x8866 +#define GL_QUERY_RESULT_AVAILABLE_NV 0x8867 +#define GL_SAMPLE_COUNT_NV 0x8914 + +#define GLEW_NV_depth_range_unclamped GLEW_GET_VAR(__GLEW_NV_depth_range_unclamped) + +#endif /* GL_NV_depth_range_unclamped */ + +/* ---------------------------- GL_NV_evaluators --------------------------- */ + +#ifndef GL_NV_evaluators +#define GL_NV_evaluators 1 + +#define GL_EVAL_2D_NV 0x86C0 +#define GL_EVAL_TRIANGULAR_2D_NV 0x86C1 +#define GL_MAP_TESSELLATION_NV 0x86C2 +#define GL_MAP_ATTRIB_U_ORDER_NV 0x86C3 +#define GL_MAP_ATTRIB_V_ORDER_NV 0x86C4 +#define GL_EVAL_FRACTIONAL_TESSELLATION_NV 0x86C5 +#define GL_EVAL_VERTEX_ATTRIB0_NV 0x86C6 +#define GL_EVAL_VERTEX_ATTRIB1_NV 0x86C7 +#define GL_EVAL_VERTEX_ATTRIB2_NV 0x86C8 +#define GL_EVAL_VERTEX_ATTRIB3_NV 0x86C9 +#define GL_EVAL_VERTEX_ATTRIB4_NV 0x86CA +#define GL_EVAL_VERTEX_ATTRIB5_NV 0x86CB +#define GL_EVAL_VERTEX_ATTRIB6_NV 0x86CC +#define GL_EVAL_VERTEX_ATTRIB7_NV 0x86CD +#define GL_EVAL_VERTEX_ATTRIB8_NV 0x86CE +#define GL_EVAL_VERTEX_ATTRIB9_NV 0x86CF +#define GL_EVAL_VERTEX_ATTRIB10_NV 0x86D0 +#define GL_EVAL_VERTEX_ATTRIB11_NV 0x86D1 +#define GL_EVAL_VERTEX_ATTRIB12_NV 0x86D2 +#define GL_EVAL_VERTEX_ATTRIB13_NV 0x86D3 +#define GL_EVAL_VERTEX_ATTRIB14_NV 0x86D4 +#define GL_EVAL_VERTEX_ATTRIB15_NV 0x86D5 +#define GL_MAX_MAP_TESSELLATION_NV 0x86D6 +#define GL_MAX_RATIONAL_EVAL_ORDER_NV 0x86D7 + +typedef void (GLAPIENTRY * PFNGLEVALMAPSNVPROC) (GLenum target, GLenum mode); +typedef void (GLAPIENTRY * PFNGLGETMAPATTRIBPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETMAPATTRIBPARAMETERIVNVPROC) (GLenum target, GLuint index, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, void* points); +typedef void (GLAPIENTRY * PFNGLGETMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const void* points); +typedef void (GLAPIENTRY * PFNGLMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, const GLint* params); + +#define glEvalMapsNV GLEW_GET_FUN(__glewEvalMapsNV) +#define glGetMapAttribParameterfvNV GLEW_GET_FUN(__glewGetMapAttribParameterfvNV) +#define glGetMapAttribParameterivNV GLEW_GET_FUN(__glewGetMapAttribParameterivNV) +#define glGetMapControlPointsNV GLEW_GET_FUN(__glewGetMapControlPointsNV) +#define glGetMapParameterfvNV GLEW_GET_FUN(__glewGetMapParameterfvNV) +#define glGetMapParameterivNV GLEW_GET_FUN(__glewGetMapParameterivNV) +#define glMapControlPointsNV GLEW_GET_FUN(__glewMapControlPointsNV) +#define glMapParameterfvNV GLEW_GET_FUN(__glewMapParameterfvNV) +#define glMapParameterivNV GLEW_GET_FUN(__glewMapParameterivNV) + +#define GLEW_NV_evaluators GLEW_GET_VAR(__GLEW_NV_evaluators) + +#endif /* GL_NV_evaluators */ + +/* ----------------------- GL_NV_explicit_multisample ---------------------- */ + +#ifndef GL_NV_explicit_multisample +#define GL_NV_explicit_multisample 1 + +#define GL_SAMPLE_POSITION_NV 0x8E50 +#define GL_SAMPLE_MASK_NV 0x8E51 +#define GL_SAMPLE_MASK_VALUE_NV 0x8E52 +#define GL_TEXTURE_BINDING_RENDERBUFFER_NV 0x8E53 +#define GL_TEXTURE_RENDERBUFFER_DATA_STORE_BINDING_NV 0x8E54 +#define GL_TEXTURE_RENDERBUFFER_NV 0x8E55 +#define GL_SAMPLER_RENDERBUFFER_NV 0x8E56 +#define GL_INT_SAMPLER_RENDERBUFFER_NV 0x8E57 +#define GL_UNSIGNED_INT_SAMPLER_RENDERBUFFER_NV 0x8E58 +#define GL_MAX_SAMPLE_MASK_WORDS_NV 0x8E59 + +typedef void (GLAPIENTRY * PFNGLGETMULTISAMPLEFVNVPROC) (GLenum pname, GLuint index, GLfloat* val); +typedef void (GLAPIENTRY * PFNGLSAMPLEMASKINDEXEDNVPROC) (GLuint index, GLbitfield mask); +typedef void (GLAPIENTRY * PFNGLTEXRENDERBUFFERNVPROC) (GLenum target, GLuint renderbuffer); + +#define glGetMultisamplefvNV GLEW_GET_FUN(__glewGetMultisamplefvNV) +#define glSampleMaskIndexedNV GLEW_GET_FUN(__glewSampleMaskIndexedNV) +#define glTexRenderbufferNV GLEW_GET_FUN(__glewTexRenderbufferNV) + +#define GLEW_NV_explicit_multisample GLEW_GET_VAR(__GLEW_NV_explicit_multisample) + +#endif /* GL_NV_explicit_multisample */ + +/* ------------------------------ GL_NV_fence ------------------------------ */ + +#ifndef GL_NV_fence +#define GL_NV_fence 1 + +#define GL_ALL_COMPLETED_NV 0x84F2 +#define GL_FENCE_STATUS_NV 0x84F3 +#define GL_FENCE_CONDITION_NV 0x84F4 + +typedef void (GLAPIENTRY * PFNGLDELETEFENCESNVPROC) (GLsizei n, const GLuint* fences); +typedef void (GLAPIENTRY * PFNGLFINISHFENCENVPROC) (GLuint fence); +typedef void (GLAPIENTRY * PFNGLGENFENCESNVPROC) (GLsizei n, GLuint* fences); +typedef void (GLAPIENTRY * PFNGLGETFENCEIVNVPROC) (GLuint fence, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISFENCENVPROC) (GLuint fence); +typedef void (GLAPIENTRY * PFNGLSETFENCENVPROC) (GLuint fence, GLenum condition); +typedef GLboolean (GLAPIENTRY * PFNGLTESTFENCENVPROC) (GLuint fence); + +#define glDeleteFencesNV GLEW_GET_FUN(__glewDeleteFencesNV) +#define glFinishFenceNV GLEW_GET_FUN(__glewFinishFenceNV) +#define glGenFencesNV GLEW_GET_FUN(__glewGenFencesNV) +#define glGetFenceivNV GLEW_GET_FUN(__glewGetFenceivNV) +#define glIsFenceNV GLEW_GET_FUN(__glewIsFenceNV) +#define glSetFenceNV GLEW_GET_FUN(__glewSetFenceNV) +#define glTestFenceNV GLEW_GET_FUN(__glewTestFenceNV) + +#define GLEW_NV_fence GLEW_GET_VAR(__GLEW_NV_fence) + +#endif /* GL_NV_fence */ + +/* --------------------------- GL_NV_float_buffer -------------------------- */ + +#ifndef GL_NV_float_buffer +#define GL_NV_float_buffer 1 + +#define GL_FLOAT_R_NV 0x8880 +#define GL_FLOAT_RG_NV 0x8881 +#define GL_FLOAT_RGB_NV 0x8882 +#define GL_FLOAT_RGBA_NV 0x8883 +#define GL_FLOAT_R16_NV 0x8884 +#define GL_FLOAT_R32_NV 0x8885 +#define GL_FLOAT_RG16_NV 0x8886 +#define GL_FLOAT_RG32_NV 0x8887 +#define GL_FLOAT_RGB16_NV 0x8888 +#define GL_FLOAT_RGB32_NV 0x8889 +#define GL_FLOAT_RGBA16_NV 0x888A +#define GL_FLOAT_RGBA32_NV 0x888B +#define GL_TEXTURE_FLOAT_COMPONENTS_NV 0x888C +#define GL_FLOAT_CLEAR_COLOR_VALUE_NV 0x888D +#define GL_FLOAT_RGBA_MODE_NV 0x888E + +#define GLEW_NV_float_buffer GLEW_GET_VAR(__GLEW_NV_float_buffer) + +#endif /* GL_NV_float_buffer */ + +/* --------------------------- GL_NV_fog_distance -------------------------- */ + +#ifndef GL_NV_fog_distance +#define GL_NV_fog_distance 1 + +#define GL_FOG_DISTANCE_MODE_NV 0x855A +#define GL_EYE_RADIAL_NV 0x855B +#define GL_EYE_PLANE_ABSOLUTE_NV 0x855C + +#define GLEW_NV_fog_distance GLEW_GET_VAR(__GLEW_NV_fog_distance) + +#endif /* GL_NV_fog_distance */ + +/* ------------------------- GL_NV_fragment_program ------------------------ */ + +#ifndef GL_NV_fragment_program +#define GL_NV_fragment_program 1 + +#define GL_MAX_FRAGMENT_PROGRAM_LOCAL_PARAMETERS_NV 0x8868 +#define GL_FRAGMENT_PROGRAM_NV 0x8870 +#define GL_MAX_TEXTURE_COORDS_NV 0x8871 +#define GL_MAX_TEXTURE_IMAGE_UNITS_NV 0x8872 +#define GL_FRAGMENT_PROGRAM_BINDING_NV 0x8873 +#define GL_PROGRAM_ERROR_STRING_NV 0x8874 + +typedef void (GLAPIENTRY * PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLdouble *params); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLfloat *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4DNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, const GLdouble v[]); +typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4FNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, const GLfloat v[]); + +#define glGetProgramNamedParameterdvNV GLEW_GET_FUN(__glewGetProgramNamedParameterdvNV) +#define glGetProgramNamedParameterfvNV GLEW_GET_FUN(__glewGetProgramNamedParameterfvNV) +#define glProgramNamedParameter4dNV GLEW_GET_FUN(__glewProgramNamedParameter4dNV) +#define glProgramNamedParameter4dvNV GLEW_GET_FUN(__glewProgramNamedParameter4dvNV) +#define glProgramNamedParameter4fNV GLEW_GET_FUN(__glewProgramNamedParameter4fNV) +#define glProgramNamedParameter4fvNV GLEW_GET_FUN(__glewProgramNamedParameter4fvNV) + +#define GLEW_NV_fragment_program GLEW_GET_VAR(__GLEW_NV_fragment_program) + +#endif /* GL_NV_fragment_program */ + +/* ------------------------ GL_NV_fragment_program2 ------------------------ */ + +#ifndef GL_NV_fragment_program2 +#define GL_NV_fragment_program2 1 + +#define GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 +#define GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 +#define GL_MAX_PROGRAM_IF_DEPTH_NV 0x88F6 +#define GL_MAX_PROGRAM_LOOP_DEPTH_NV 0x88F7 +#define GL_MAX_PROGRAM_LOOP_COUNT_NV 0x88F8 + +#define GLEW_NV_fragment_program2 GLEW_GET_VAR(__GLEW_NV_fragment_program2) + +#endif /* GL_NV_fragment_program2 */ + +/* ------------------------ GL_NV_fragment_program4 ------------------------ */ + +#ifndef GL_NV_fragment_program4 +#define GL_NV_fragment_program4 1 + +#define GLEW_NV_fragment_program4 GLEW_GET_VAR(__GLEW_NV_fragment_program4) + +#endif /* GL_NV_fragment_program4 */ + +/* --------------------- GL_NV_fragment_program_option --------------------- */ + +#ifndef GL_NV_fragment_program_option +#define GL_NV_fragment_program_option 1 + +#define GLEW_NV_fragment_program_option GLEW_GET_VAR(__GLEW_NV_fragment_program_option) + +#endif /* GL_NV_fragment_program_option */ + +/* ----------------- GL_NV_framebuffer_multisample_coverage ---------------- */ + +#ifndef GL_NV_framebuffer_multisample_coverage +#define GL_NV_framebuffer_multisample_coverage 1 + +#define GL_RENDERBUFFER_COVERAGE_SAMPLES_NV 0x8CAB +#define GL_RENDERBUFFER_COLOR_SAMPLES_NV 0x8E10 +#define GL_MAX_MULTISAMPLE_COVERAGE_MODES_NV 0x8E11 +#define GL_MULTISAMPLE_COVERAGE_MODES_NV 0x8E12 + +typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); + +#define glRenderbufferStorageMultisampleCoverageNV GLEW_GET_FUN(__glewRenderbufferStorageMultisampleCoverageNV) + +#define GLEW_NV_framebuffer_multisample_coverage GLEW_GET_VAR(__GLEW_NV_framebuffer_multisample_coverage) + +#endif /* GL_NV_framebuffer_multisample_coverage */ + +/* ------------------------ GL_NV_geometry_program4 ------------------------ */ + +#ifndef GL_NV_geometry_program4 +#define GL_NV_geometry_program4 1 + +#define GL_GEOMETRY_PROGRAM_NV 0x8C26 +#define GL_MAX_PROGRAM_OUTPUT_VERTICES_NV 0x8C27 +#define GL_MAX_PROGRAM_TOTAL_OUTPUT_COMPONENTS_NV 0x8C28 + +typedef void (GLAPIENTRY * PFNGLPROGRAMVERTEXLIMITNVPROC) (GLenum target, GLint limit); + +#define glProgramVertexLimitNV GLEW_GET_FUN(__glewProgramVertexLimitNV) + +#define GLEW_NV_geometry_program4 GLEW_GET_VAR(__GLEW_NV_geometry_program4) + +#endif /* GL_NV_geometry_program4 */ + +/* ------------------------- GL_NV_geometry_shader4 ------------------------ */ + +#ifndef GL_NV_geometry_shader4 +#define GL_NV_geometry_shader4 1 + +#define GLEW_NV_geometry_shader4 GLEW_GET_VAR(__GLEW_NV_geometry_shader4) + +#endif /* GL_NV_geometry_shader4 */ + +/* --------------------------- GL_NV_gpu_program4 -------------------------- */ + +#ifndef GL_NV_gpu_program4 +#define GL_NV_gpu_program4 1 + +#define GL_MIN_PROGRAM_TEXEL_OFFSET_NV 0x8904 +#define GL_MAX_PROGRAM_TEXEL_OFFSET_NV 0x8905 +#define GL_PROGRAM_ATTRIB_COMPONENTS_NV 0x8906 +#define GL_PROGRAM_RESULT_COMPONENTS_NV 0x8907 +#define GL_MAX_PROGRAM_ATTRIB_COMPONENTS_NV 0x8908 +#define GL_MAX_PROGRAM_RESULT_COMPONENTS_NV 0x8909 +#define GL_MAX_PROGRAM_GENERIC_ATTRIBS_NV 0x8DA5 +#define GL_MAX_PROGRAM_GENERIC_RESULTS_NV 0x8DA6 + +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); + +#define glProgramEnvParameterI4iNV GLEW_GET_FUN(__glewProgramEnvParameterI4iNV) +#define glProgramEnvParameterI4ivNV GLEW_GET_FUN(__glewProgramEnvParameterI4ivNV) +#define glProgramEnvParameterI4uiNV GLEW_GET_FUN(__glewProgramEnvParameterI4uiNV) +#define glProgramEnvParameterI4uivNV GLEW_GET_FUN(__glewProgramEnvParameterI4uivNV) +#define glProgramEnvParametersI4ivNV GLEW_GET_FUN(__glewProgramEnvParametersI4ivNV) +#define glProgramEnvParametersI4uivNV GLEW_GET_FUN(__glewProgramEnvParametersI4uivNV) +#define glProgramLocalParameterI4iNV GLEW_GET_FUN(__glewProgramLocalParameterI4iNV) +#define glProgramLocalParameterI4ivNV GLEW_GET_FUN(__glewProgramLocalParameterI4ivNV) +#define glProgramLocalParameterI4uiNV GLEW_GET_FUN(__glewProgramLocalParameterI4uiNV) +#define glProgramLocalParameterI4uivNV GLEW_GET_FUN(__glewProgramLocalParameterI4uivNV) +#define glProgramLocalParametersI4ivNV GLEW_GET_FUN(__glewProgramLocalParametersI4ivNV) +#define glProgramLocalParametersI4uivNV GLEW_GET_FUN(__glewProgramLocalParametersI4uivNV) + +#define GLEW_NV_gpu_program4 GLEW_GET_VAR(__GLEW_NV_gpu_program4) + +#endif /* GL_NV_gpu_program4 */ + +/* --------------------------- GL_NV_gpu_program5 -------------------------- */ + +#ifndef GL_NV_gpu_program5 +#define GL_NV_gpu_program5 1 + +#define GL_MAX_GEOMETRY_PROGRAM_INVOCATIONS_NV 0x8E5A +#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5B +#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5C +#define GL_FRAGMENT_PROGRAM_INTERPOLATION_OFFSET_BITS_NV 0x8E5D + +#define GLEW_NV_gpu_program5 GLEW_GET_VAR(__GLEW_NV_gpu_program5) + +#endif /* GL_NV_gpu_program5 */ + +/* ------------------------- GL_NV_gpu_program_fp64 ------------------------ */ + +#ifndef GL_NV_gpu_program_fp64 +#define GL_NV_gpu_program_fp64 1 + +#define GLEW_NV_gpu_program_fp64 GLEW_GET_VAR(__GLEW_NV_gpu_program_fp64) + +#endif /* GL_NV_gpu_program_fp64 */ + +/* --------------------------- GL_NV_gpu_shader5 --------------------------- */ + +#ifndef GL_NV_gpu_shader5 +#define GL_NV_gpu_shader5 1 + +#define GL_INT64_NV 0x140E +#define GL_UNSIGNED_INT64_NV 0x140F +#define GL_INT8_NV 0x8FE0 +#define GL_INT8_VEC2_NV 0x8FE1 +#define GL_INT8_VEC3_NV 0x8FE2 +#define GL_INT8_VEC4_NV 0x8FE3 +#define GL_INT16_NV 0x8FE4 +#define GL_INT16_VEC2_NV 0x8FE5 +#define GL_INT16_VEC3_NV 0x8FE6 +#define GL_INT16_VEC4_NV 0x8FE7 +#define GL_INT64_VEC2_NV 0x8FE9 +#define GL_INT64_VEC3_NV 0x8FEA +#define GL_INT64_VEC4_NV 0x8FEB +#define GL_UNSIGNED_INT8_NV 0x8FEC +#define GL_UNSIGNED_INT8_VEC2_NV 0x8FED +#define GL_UNSIGNED_INT8_VEC3_NV 0x8FEE +#define GL_UNSIGNED_INT8_VEC4_NV 0x8FEF +#define GL_UNSIGNED_INT16_NV 0x8FF0 +#define GL_UNSIGNED_INT16_VEC2_NV 0x8FF1 +#define GL_UNSIGNED_INT16_VEC3_NV 0x8FF2 +#define GL_UNSIGNED_INT16_VEC4_NV 0x8FF3 +#define GL_UNSIGNED_INT64_VEC2_NV 0x8FF5 +#define GL_UNSIGNED_INT64_VEC3_NV 0x8FF6 +#define GL_UNSIGNED_INT64_VEC4_NV 0x8FF7 +#define GL_FLOAT16_NV 0x8FF8 +#define GL_FLOAT16_VEC2_NV 0x8FF9 +#define GL_FLOAT16_VEC3_NV 0x8FFA +#define GL_FLOAT16_VEC4_NV 0x8FFB + +typedef void (GLAPIENTRY * PFNGLGETUNIFORMI64VNVPROC) (GLuint program, GLint location, GLint64EXT* params); +typedef void (GLAPIENTRY * PFNGLGETUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLuint64EXT* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1I64NVPROC) (GLuint program, GLint location, GLint64EXT x); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM1I64NVPROC) (GLint location, GLint64EXT x); +typedef void (GLAPIENTRY * PFNGLUNIFORM1I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM1UI64NVPROC) (GLint location, GLuint64EXT x); +typedef void (GLAPIENTRY * PFNGLUNIFORM1UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM2I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y); +typedef void (GLAPIENTRY * PFNGLUNIFORM2I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM2UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y); +typedef void (GLAPIENTRY * PFNGLUNIFORM2UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM3I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); +typedef void (GLAPIENTRY * PFNGLUNIFORM3I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM3UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +typedef void (GLAPIENTRY * PFNGLUNIFORM3UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM4I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +typedef void (GLAPIENTRY * PFNGLUNIFORM4I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORM4UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +typedef void (GLAPIENTRY * PFNGLUNIFORM4UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); + +#define glGetUniformi64vNV GLEW_GET_FUN(__glewGetUniformi64vNV) +#define glGetUniformui64vNV GLEW_GET_FUN(__glewGetUniformui64vNV) +#define glProgramUniform1i64NV GLEW_GET_FUN(__glewProgramUniform1i64NV) +#define glProgramUniform1i64vNV GLEW_GET_FUN(__glewProgramUniform1i64vNV) +#define glProgramUniform1ui64NV GLEW_GET_FUN(__glewProgramUniform1ui64NV) +#define glProgramUniform1ui64vNV GLEW_GET_FUN(__glewProgramUniform1ui64vNV) +#define glProgramUniform2i64NV GLEW_GET_FUN(__glewProgramUniform2i64NV) +#define glProgramUniform2i64vNV GLEW_GET_FUN(__glewProgramUniform2i64vNV) +#define glProgramUniform2ui64NV GLEW_GET_FUN(__glewProgramUniform2ui64NV) +#define glProgramUniform2ui64vNV GLEW_GET_FUN(__glewProgramUniform2ui64vNV) +#define glProgramUniform3i64NV GLEW_GET_FUN(__glewProgramUniform3i64NV) +#define glProgramUniform3i64vNV GLEW_GET_FUN(__glewProgramUniform3i64vNV) +#define glProgramUniform3ui64NV GLEW_GET_FUN(__glewProgramUniform3ui64NV) +#define glProgramUniform3ui64vNV GLEW_GET_FUN(__glewProgramUniform3ui64vNV) +#define glProgramUniform4i64NV GLEW_GET_FUN(__glewProgramUniform4i64NV) +#define glProgramUniform4i64vNV GLEW_GET_FUN(__glewProgramUniform4i64vNV) +#define glProgramUniform4ui64NV GLEW_GET_FUN(__glewProgramUniform4ui64NV) +#define glProgramUniform4ui64vNV GLEW_GET_FUN(__glewProgramUniform4ui64vNV) +#define glUniform1i64NV GLEW_GET_FUN(__glewUniform1i64NV) +#define glUniform1i64vNV GLEW_GET_FUN(__glewUniform1i64vNV) +#define glUniform1ui64NV GLEW_GET_FUN(__glewUniform1ui64NV) +#define glUniform1ui64vNV GLEW_GET_FUN(__glewUniform1ui64vNV) +#define glUniform2i64NV GLEW_GET_FUN(__glewUniform2i64NV) +#define glUniform2i64vNV GLEW_GET_FUN(__glewUniform2i64vNV) +#define glUniform2ui64NV GLEW_GET_FUN(__glewUniform2ui64NV) +#define glUniform2ui64vNV GLEW_GET_FUN(__glewUniform2ui64vNV) +#define glUniform3i64NV GLEW_GET_FUN(__glewUniform3i64NV) +#define glUniform3i64vNV GLEW_GET_FUN(__glewUniform3i64vNV) +#define glUniform3ui64NV GLEW_GET_FUN(__glewUniform3ui64NV) +#define glUniform3ui64vNV GLEW_GET_FUN(__glewUniform3ui64vNV) +#define glUniform4i64NV GLEW_GET_FUN(__glewUniform4i64NV) +#define glUniform4i64vNV GLEW_GET_FUN(__glewUniform4i64vNV) +#define glUniform4ui64NV GLEW_GET_FUN(__glewUniform4ui64NV) +#define glUniform4ui64vNV GLEW_GET_FUN(__glewUniform4ui64vNV) + +#define GLEW_NV_gpu_shader5 GLEW_GET_VAR(__GLEW_NV_gpu_shader5) + +#endif /* GL_NV_gpu_shader5 */ + +/* ---------------------------- GL_NV_half_float --------------------------- */ + +#ifndef GL_NV_half_float +#define GL_NV_half_float 1 + +#define GL_HALF_FLOAT_NV 0x140B + +typedef unsigned short GLhalf; + +typedef void (GLAPIENTRY * PFNGLCOLOR3HNVPROC) (GLhalf red, GLhalf green, GLhalf blue); +typedef void (GLAPIENTRY * PFNGLCOLOR3HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLCOLOR4HNVPROC) (GLhalf red, GLhalf green, GLhalf blue, GLhalf alpha); +typedef void (GLAPIENTRY * PFNGLCOLOR4HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLFOGCOORDHNVPROC) (GLhalf fog); +typedef void (GLAPIENTRY * PFNGLFOGCOORDHVNVPROC) (const GLhalf* fog); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1HNVPROC) (GLenum target, GLhalf s); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1HVNVPROC) (GLenum target, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2HNVPROC) (GLenum target, GLhalf s, GLhalf t); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2HVNVPROC) (GLenum target, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3HNVPROC) (GLenum target, GLhalf s, GLhalf t, GLhalf r); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3HVNVPROC) (GLenum target, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4HNVPROC) (GLenum target, GLhalf s, GLhalf t, GLhalf r, GLhalf q); +typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4HVNVPROC) (GLenum target, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLNORMAL3HNVPROC) (GLhalf nx, GLhalf ny, GLhalf nz); +typedef void (GLAPIENTRY * PFNGLNORMAL3HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3HNVPROC) (GLhalf red, GLhalf green, GLhalf blue); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD1HNVPROC) (GLhalf s); +typedef void (GLAPIENTRY * PFNGLTEXCOORD1HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2HNVPROC) (GLhalf s, GLhalf t); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD3HNVPROC) (GLhalf s, GLhalf t, GLhalf r); +typedef void (GLAPIENTRY * PFNGLTEXCOORD3HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD4HNVPROC) (GLhalf s, GLhalf t, GLhalf r, GLhalf q); +typedef void (GLAPIENTRY * PFNGLTEXCOORD4HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEX2HNVPROC) (GLhalf x, GLhalf y); +typedef void (GLAPIENTRY * PFNGLVERTEX2HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEX3HNVPROC) (GLhalf x, GLhalf y, GLhalf z); +typedef void (GLAPIENTRY * PFNGLVERTEX3HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEX4HNVPROC) (GLhalf x, GLhalf y, GLhalf z, GLhalf w); +typedef void (GLAPIENTRY * PFNGLVERTEX4HVNVPROC) (const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1HNVPROC) (GLuint index, GLhalf x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1HVNVPROC) (GLuint index, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2HNVPROC) (GLuint index, GLhalf x, GLhalf y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2HVNVPROC) (GLuint index, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3HNVPROC) (GLuint index, GLhalf x, GLhalf y, GLhalf z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3HVNVPROC) (GLuint index, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4HNVPROC) (GLuint index, GLhalf x, GLhalf y, GLhalf z, GLhalf w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4HVNVPROC) (GLuint index, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); +typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTHNVPROC) (GLhalf weight); +typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTHVNVPROC) (const GLhalf* weight); + +#define glColor3hNV GLEW_GET_FUN(__glewColor3hNV) +#define glColor3hvNV GLEW_GET_FUN(__glewColor3hvNV) +#define glColor4hNV GLEW_GET_FUN(__glewColor4hNV) +#define glColor4hvNV GLEW_GET_FUN(__glewColor4hvNV) +#define glFogCoordhNV GLEW_GET_FUN(__glewFogCoordhNV) +#define glFogCoordhvNV GLEW_GET_FUN(__glewFogCoordhvNV) +#define glMultiTexCoord1hNV GLEW_GET_FUN(__glewMultiTexCoord1hNV) +#define glMultiTexCoord1hvNV GLEW_GET_FUN(__glewMultiTexCoord1hvNV) +#define glMultiTexCoord2hNV GLEW_GET_FUN(__glewMultiTexCoord2hNV) +#define glMultiTexCoord2hvNV GLEW_GET_FUN(__glewMultiTexCoord2hvNV) +#define glMultiTexCoord3hNV GLEW_GET_FUN(__glewMultiTexCoord3hNV) +#define glMultiTexCoord3hvNV GLEW_GET_FUN(__glewMultiTexCoord3hvNV) +#define glMultiTexCoord4hNV GLEW_GET_FUN(__glewMultiTexCoord4hNV) +#define glMultiTexCoord4hvNV GLEW_GET_FUN(__glewMultiTexCoord4hvNV) +#define glNormal3hNV GLEW_GET_FUN(__glewNormal3hNV) +#define glNormal3hvNV GLEW_GET_FUN(__glewNormal3hvNV) +#define glSecondaryColor3hNV GLEW_GET_FUN(__glewSecondaryColor3hNV) +#define glSecondaryColor3hvNV GLEW_GET_FUN(__glewSecondaryColor3hvNV) +#define glTexCoord1hNV GLEW_GET_FUN(__glewTexCoord1hNV) +#define glTexCoord1hvNV GLEW_GET_FUN(__glewTexCoord1hvNV) +#define glTexCoord2hNV GLEW_GET_FUN(__glewTexCoord2hNV) +#define glTexCoord2hvNV GLEW_GET_FUN(__glewTexCoord2hvNV) +#define glTexCoord3hNV GLEW_GET_FUN(__glewTexCoord3hNV) +#define glTexCoord3hvNV GLEW_GET_FUN(__glewTexCoord3hvNV) +#define glTexCoord4hNV GLEW_GET_FUN(__glewTexCoord4hNV) +#define glTexCoord4hvNV GLEW_GET_FUN(__glewTexCoord4hvNV) +#define glVertex2hNV GLEW_GET_FUN(__glewVertex2hNV) +#define glVertex2hvNV GLEW_GET_FUN(__glewVertex2hvNV) +#define glVertex3hNV GLEW_GET_FUN(__glewVertex3hNV) +#define glVertex3hvNV GLEW_GET_FUN(__glewVertex3hvNV) +#define glVertex4hNV GLEW_GET_FUN(__glewVertex4hNV) +#define glVertex4hvNV GLEW_GET_FUN(__glewVertex4hvNV) +#define glVertexAttrib1hNV GLEW_GET_FUN(__glewVertexAttrib1hNV) +#define glVertexAttrib1hvNV GLEW_GET_FUN(__glewVertexAttrib1hvNV) +#define glVertexAttrib2hNV GLEW_GET_FUN(__glewVertexAttrib2hNV) +#define glVertexAttrib2hvNV GLEW_GET_FUN(__glewVertexAttrib2hvNV) +#define glVertexAttrib3hNV GLEW_GET_FUN(__glewVertexAttrib3hNV) +#define glVertexAttrib3hvNV GLEW_GET_FUN(__glewVertexAttrib3hvNV) +#define glVertexAttrib4hNV GLEW_GET_FUN(__glewVertexAttrib4hNV) +#define glVertexAttrib4hvNV GLEW_GET_FUN(__glewVertexAttrib4hvNV) +#define glVertexAttribs1hvNV GLEW_GET_FUN(__glewVertexAttribs1hvNV) +#define glVertexAttribs2hvNV GLEW_GET_FUN(__glewVertexAttribs2hvNV) +#define glVertexAttribs3hvNV GLEW_GET_FUN(__glewVertexAttribs3hvNV) +#define glVertexAttribs4hvNV GLEW_GET_FUN(__glewVertexAttribs4hvNV) +#define glVertexWeighthNV GLEW_GET_FUN(__glewVertexWeighthNV) +#define glVertexWeighthvNV GLEW_GET_FUN(__glewVertexWeighthvNV) + +#define GLEW_NV_half_float GLEW_GET_VAR(__GLEW_NV_half_float) + +#endif /* GL_NV_half_float */ + +/* ------------------------ GL_NV_light_max_exponent ----------------------- */ + +#ifndef GL_NV_light_max_exponent +#define GL_NV_light_max_exponent 1 + +#define GL_MAX_SHININESS_NV 0x8504 +#define GL_MAX_SPOT_EXPONENT_NV 0x8505 + +#define GLEW_NV_light_max_exponent GLEW_GET_VAR(__GLEW_NV_light_max_exponent) + +#endif /* GL_NV_light_max_exponent */ + +/* --------------------- GL_NV_multisample_filter_hint --------------------- */ + +#ifndef GL_NV_multisample_filter_hint +#define GL_NV_multisample_filter_hint 1 + +#define GL_MULTISAMPLE_FILTER_HINT_NV 0x8534 + +#define GLEW_NV_multisample_filter_hint GLEW_GET_VAR(__GLEW_NV_multisample_filter_hint) + +#endif /* GL_NV_multisample_filter_hint */ + +/* ------------------------- GL_NV_occlusion_query ------------------------- */ + +#ifndef GL_NV_occlusion_query +#define GL_NV_occlusion_query 1 + +#define GL_PIXEL_COUNTER_BITS_NV 0x8864 +#define GL_CURRENT_OCCLUSION_QUERY_ID_NV 0x8865 +#define GL_PIXEL_COUNT_NV 0x8866 +#define GL_PIXEL_COUNT_AVAILABLE_NV 0x8867 + +typedef void (GLAPIENTRY * PFNGLBEGINOCCLUSIONQUERYNVPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLDELETEOCCLUSIONQUERIESNVPROC) (GLsizei n, const GLuint* ids); +typedef void (GLAPIENTRY * PFNGLENDOCCLUSIONQUERYNVPROC) (void); +typedef void (GLAPIENTRY * PFNGLGENOCCLUSIONQUERIESNVPROC) (GLsizei n, GLuint* ids); +typedef void (GLAPIENTRY * PFNGLGETOCCLUSIONQUERYIVNVPROC) (GLuint id, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETOCCLUSIONQUERYUIVNVPROC) (GLuint id, GLenum pname, GLuint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISOCCLUSIONQUERYNVPROC) (GLuint id); + +#define glBeginOcclusionQueryNV GLEW_GET_FUN(__glewBeginOcclusionQueryNV) +#define glDeleteOcclusionQueriesNV GLEW_GET_FUN(__glewDeleteOcclusionQueriesNV) +#define glEndOcclusionQueryNV GLEW_GET_FUN(__glewEndOcclusionQueryNV) +#define glGenOcclusionQueriesNV GLEW_GET_FUN(__glewGenOcclusionQueriesNV) +#define glGetOcclusionQueryivNV GLEW_GET_FUN(__glewGetOcclusionQueryivNV) +#define glGetOcclusionQueryuivNV GLEW_GET_FUN(__glewGetOcclusionQueryuivNV) +#define glIsOcclusionQueryNV GLEW_GET_FUN(__glewIsOcclusionQueryNV) + +#define GLEW_NV_occlusion_query GLEW_GET_VAR(__GLEW_NV_occlusion_query) + +#endif /* GL_NV_occlusion_query */ + +/* ----------------------- GL_NV_packed_depth_stencil ---------------------- */ + +#ifndef GL_NV_packed_depth_stencil +#define GL_NV_packed_depth_stencil 1 + +#define GL_DEPTH_STENCIL_NV 0x84F9 +#define GL_UNSIGNED_INT_24_8_NV 0x84FA + +#define GLEW_NV_packed_depth_stencil GLEW_GET_VAR(__GLEW_NV_packed_depth_stencil) + +#endif /* GL_NV_packed_depth_stencil */ + +/* --------------------- GL_NV_parameter_buffer_object --------------------- */ + +#ifndef GL_NV_parameter_buffer_object +#define GL_NV_parameter_buffer_object 1 + +#define GL_MAX_PROGRAM_PARAMETER_BUFFER_BINDINGS_NV 0x8DA0 +#define GL_MAX_PROGRAM_PARAMETER_BUFFER_SIZE_NV 0x8DA1 +#define GL_VERTEX_PROGRAM_PARAMETER_BUFFER_NV 0x8DA2 +#define GL_GEOMETRY_PROGRAM_PARAMETER_BUFFER_NV 0x8DA3 +#define GL_FRAGMENT_PROGRAM_PARAMETER_BUFFER_NV 0x8DA4 + +typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLuint *params); +typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLfloat *params); + +#define glProgramBufferParametersIivNV GLEW_GET_FUN(__glewProgramBufferParametersIivNV) +#define glProgramBufferParametersIuivNV GLEW_GET_FUN(__glewProgramBufferParametersIuivNV) +#define glProgramBufferParametersfvNV GLEW_GET_FUN(__glewProgramBufferParametersfvNV) + +#define GLEW_NV_parameter_buffer_object GLEW_GET_VAR(__GLEW_NV_parameter_buffer_object) + +#endif /* GL_NV_parameter_buffer_object */ + +/* --------------------- GL_NV_parameter_buffer_object2 -------------------- */ + +#ifndef GL_NV_parameter_buffer_object2 +#define GL_NV_parameter_buffer_object2 1 + +#define GLEW_NV_parameter_buffer_object2 GLEW_GET_VAR(__GLEW_NV_parameter_buffer_object2) + +#endif /* GL_NV_parameter_buffer_object2 */ + +/* ------------------------- GL_NV_pixel_data_range ------------------------ */ + +#ifndef GL_NV_pixel_data_range +#define GL_NV_pixel_data_range 1 + +#define GL_WRITE_PIXEL_DATA_RANGE_NV 0x8878 +#define GL_READ_PIXEL_DATA_RANGE_NV 0x8879 +#define GL_WRITE_PIXEL_DATA_RANGE_LENGTH_NV 0x887A +#define GL_READ_PIXEL_DATA_RANGE_LENGTH_NV 0x887B +#define GL_WRITE_PIXEL_DATA_RANGE_POINTER_NV 0x887C +#define GL_READ_PIXEL_DATA_RANGE_POINTER_NV 0x887D + +typedef void (GLAPIENTRY * PFNGLFLUSHPIXELDATARANGENVPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLPIXELDATARANGENVPROC) (GLenum target, GLsizei length, void* pointer); + +#define glFlushPixelDataRangeNV GLEW_GET_FUN(__glewFlushPixelDataRangeNV) +#define glPixelDataRangeNV GLEW_GET_FUN(__glewPixelDataRangeNV) + +#define GLEW_NV_pixel_data_range GLEW_GET_VAR(__GLEW_NV_pixel_data_range) + +#endif /* GL_NV_pixel_data_range */ + +/* --------------------------- GL_NV_point_sprite -------------------------- */ + +#ifndef GL_NV_point_sprite +#define GL_NV_point_sprite 1 + +#define GL_POINT_SPRITE_NV 0x8861 +#define GL_COORD_REPLACE_NV 0x8862 +#define GL_POINT_SPRITE_R_MODE_NV 0x8863 + +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERINVPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIVNVPROC) (GLenum pname, const GLint* params); + +#define glPointParameteriNV GLEW_GET_FUN(__glewPointParameteriNV) +#define glPointParameterivNV GLEW_GET_FUN(__glewPointParameterivNV) + +#define GLEW_NV_point_sprite GLEW_GET_VAR(__GLEW_NV_point_sprite) + +#endif /* GL_NV_point_sprite */ + +/* -------------------------- GL_NV_present_video -------------------------- */ + +#ifndef GL_NV_present_video +#define GL_NV_present_video 1 + +#define GL_FRAME_NV 0x8E26 +#define GL_FIELDS_NV 0x8E27 +#define GL_CURRENT_TIME_NV 0x8E28 +#define GL_NUM_FILL_STREAMS_NV 0x8E29 +#define GL_PRESENT_TIME_NV 0x8E2A +#define GL_PRESENT_DURATION_NV 0x8E2B + +typedef void (GLAPIENTRY * PFNGLGETVIDEOI64VNVPROC) (GLuint video_slot, GLenum pname, GLint64EXT* params); +typedef void (GLAPIENTRY * PFNGLGETVIDEOIVNVPROC) (GLuint video_slot, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETVIDEOUI64VNVPROC) (GLuint video_slot, GLenum pname, GLuint64EXT* params); +typedef void (GLAPIENTRY * PFNGLGETVIDEOUIVNVPROC) (GLuint video_slot, GLenum pname, GLuint* params); +typedef void (GLAPIENTRY * PFNGLPRESENTFRAMEDUALFILLNVPROC) (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLenum target1, GLuint fill1, GLenum target2, GLuint fill2, GLenum target3, GLuint fill3); +typedef void (GLAPIENTRY * PFNGLPRESENTFRAMEKEYEDNVPROC) (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLuint key0, GLenum target1, GLuint fill1, GLuint key1); + +#define glGetVideoi64vNV GLEW_GET_FUN(__glewGetVideoi64vNV) +#define glGetVideoivNV GLEW_GET_FUN(__glewGetVideoivNV) +#define glGetVideoui64vNV GLEW_GET_FUN(__glewGetVideoui64vNV) +#define glGetVideouivNV GLEW_GET_FUN(__glewGetVideouivNV) +#define glPresentFrameDualFillNV GLEW_GET_FUN(__glewPresentFrameDualFillNV) +#define glPresentFrameKeyedNV GLEW_GET_FUN(__glewPresentFrameKeyedNV) + +#define GLEW_NV_present_video GLEW_GET_VAR(__GLEW_NV_present_video) + +#endif /* GL_NV_present_video */ + +/* ------------------------ GL_NV_primitive_restart ------------------------ */ + +#ifndef GL_NV_primitive_restart +#define GL_NV_primitive_restart 1 + +#define GL_PRIMITIVE_RESTART_NV 0x8558 +#define GL_PRIMITIVE_RESTART_INDEX_NV 0x8559 + +typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTINDEXNVPROC) (GLuint index); +typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTNVPROC) (void); + +#define glPrimitiveRestartIndexNV GLEW_GET_FUN(__glewPrimitiveRestartIndexNV) +#define glPrimitiveRestartNV GLEW_GET_FUN(__glewPrimitiveRestartNV) + +#define GLEW_NV_primitive_restart GLEW_GET_VAR(__GLEW_NV_primitive_restart) + +#endif /* GL_NV_primitive_restart */ + +/* ------------------------ GL_NV_register_combiners ----------------------- */ + +#ifndef GL_NV_register_combiners +#define GL_NV_register_combiners 1 + +#define GL_REGISTER_COMBINERS_NV 0x8522 +#define GL_VARIABLE_A_NV 0x8523 +#define GL_VARIABLE_B_NV 0x8524 +#define GL_VARIABLE_C_NV 0x8525 +#define GL_VARIABLE_D_NV 0x8526 +#define GL_VARIABLE_E_NV 0x8527 +#define GL_VARIABLE_F_NV 0x8528 +#define GL_VARIABLE_G_NV 0x8529 +#define GL_CONSTANT_COLOR0_NV 0x852A +#define GL_CONSTANT_COLOR1_NV 0x852B +#define GL_PRIMARY_COLOR_NV 0x852C +#define GL_SECONDARY_COLOR_NV 0x852D +#define GL_SPARE0_NV 0x852E +#define GL_SPARE1_NV 0x852F +#define GL_DISCARD_NV 0x8530 +#define GL_E_TIMES_F_NV 0x8531 +#define GL_SPARE0_PLUS_SECONDARY_COLOR_NV 0x8532 +#define GL_UNSIGNED_IDENTITY_NV 0x8536 +#define GL_UNSIGNED_INVERT_NV 0x8537 +#define GL_EXPAND_NORMAL_NV 0x8538 +#define GL_EXPAND_NEGATE_NV 0x8539 +#define GL_HALF_BIAS_NORMAL_NV 0x853A +#define GL_HALF_BIAS_NEGATE_NV 0x853B +#define GL_SIGNED_IDENTITY_NV 0x853C +#define GL_SIGNED_NEGATE_NV 0x853D +#define GL_SCALE_BY_TWO_NV 0x853E +#define GL_SCALE_BY_FOUR_NV 0x853F +#define GL_SCALE_BY_ONE_HALF_NV 0x8540 +#define GL_BIAS_BY_NEGATIVE_ONE_HALF_NV 0x8541 +#define GL_COMBINER_INPUT_NV 0x8542 +#define GL_COMBINER_MAPPING_NV 0x8543 +#define GL_COMBINER_COMPONENT_USAGE_NV 0x8544 +#define GL_COMBINER_AB_DOT_PRODUCT_NV 0x8545 +#define GL_COMBINER_CD_DOT_PRODUCT_NV 0x8546 +#define GL_COMBINER_MUX_SUM_NV 0x8547 +#define GL_COMBINER_SCALE_NV 0x8548 +#define GL_COMBINER_BIAS_NV 0x8549 +#define GL_COMBINER_AB_OUTPUT_NV 0x854A +#define GL_COMBINER_CD_OUTPUT_NV 0x854B +#define GL_COMBINER_SUM_OUTPUT_NV 0x854C +#define GL_MAX_GENERAL_COMBINERS_NV 0x854D +#define GL_NUM_GENERAL_COMBINERS_NV 0x854E +#define GL_COLOR_SUM_CLAMP_NV 0x854F +#define GL_COMBINER0_NV 0x8550 +#define GL_COMBINER1_NV 0x8551 +#define GL_COMBINER2_NV 0x8552 +#define GL_COMBINER3_NV 0x8553 +#define GL_COMBINER4_NV 0x8554 +#define GL_COMBINER5_NV 0x8555 +#define GL_COMBINER6_NV 0x8556 +#define GL_COMBINER7_NV 0x8557 + +typedef void (GLAPIENTRY * PFNGLCOMBINERINPUTNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +typedef void (GLAPIENTRY * PFNGLCOMBINEROUTPUTNVPROC) (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum); +typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERFNVPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERFVNVPROC) (GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERINVPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERIVNVPROC) (GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLFINALCOMBINERINPUTNVPROC) (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +typedef void (GLAPIENTRY * PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC) (GLenum variable, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC) (GLenum variable, GLenum pname, GLint* params); + +#define glCombinerInputNV GLEW_GET_FUN(__glewCombinerInputNV) +#define glCombinerOutputNV GLEW_GET_FUN(__glewCombinerOutputNV) +#define glCombinerParameterfNV GLEW_GET_FUN(__glewCombinerParameterfNV) +#define glCombinerParameterfvNV GLEW_GET_FUN(__glewCombinerParameterfvNV) +#define glCombinerParameteriNV GLEW_GET_FUN(__glewCombinerParameteriNV) +#define glCombinerParameterivNV GLEW_GET_FUN(__glewCombinerParameterivNV) +#define glFinalCombinerInputNV GLEW_GET_FUN(__glewFinalCombinerInputNV) +#define glGetCombinerInputParameterfvNV GLEW_GET_FUN(__glewGetCombinerInputParameterfvNV) +#define glGetCombinerInputParameterivNV GLEW_GET_FUN(__glewGetCombinerInputParameterivNV) +#define glGetCombinerOutputParameterfvNV GLEW_GET_FUN(__glewGetCombinerOutputParameterfvNV) +#define glGetCombinerOutputParameterivNV GLEW_GET_FUN(__glewGetCombinerOutputParameterivNV) +#define glGetFinalCombinerInputParameterfvNV GLEW_GET_FUN(__glewGetFinalCombinerInputParameterfvNV) +#define glGetFinalCombinerInputParameterivNV GLEW_GET_FUN(__glewGetFinalCombinerInputParameterivNV) + +#define GLEW_NV_register_combiners GLEW_GET_VAR(__GLEW_NV_register_combiners) + +#endif /* GL_NV_register_combiners */ + +/* ----------------------- GL_NV_register_combiners2 ----------------------- */ + +#ifndef GL_NV_register_combiners2 +#define GL_NV_register_combiners2 1 + +#define GL_PER_STAGE_CONSTANTS_NV 0x8535 + +typedef void (GLAPIENTRY * PFNGLCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, GLfloat* params); + +#define glCombinerStageParameterfvNV GLEW_GET_FUN(__glewCombinerStageParameterfvNV) +#define glGetCombinerStageParameterfvNV GLEW_GET_FUN(__glewGetCombinerStageParameterfvNV) + +#define GLEW_NV_register_combiners2 GLEW_GET_VAR(__GLEW_NV_register_combiners2) + +#endif /* GL_NV_register_combiners2 */ + +/* ------------------------ GL_NV_shader_buffer_load ----------------------- */ + +#ifndef GL_NV_shader_buffer_load +#define GL_NV_shader_buffer_load 1 + +#define GL_BUFFER_GPU_ADDRESS_NV 0x8F1D +#define GL_GPU_ADDRESS_NV 0x8F34 +#define GL_MAX_SHADER_BUFFER_ADDRESS_NV 0x8F35 + +typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERUI64VNVPROC) (GLenum target, GLenum pname, GLuint64EXT* params); +typedef void (GLAPIENTRY * PFNGLGETINTEGERUI64VNVPROC) (GLenum value, GLuint64EXT* result); +typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC) (GLuint buffer, GLenum pname, GLuint64EXT* params); +typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERRESIDENTNVPROC) (GLenum target); +typedef GLboolean (GLAPIENTRY * PFNGLISNAMEDBUFFERRESIDENTNVPROC) (GLuint buffer); +typedef void (GLAPIENTRY * PFNGLMAKEBUFFERNONRESIDENTNVPROC) (GLenum target); +typedef void (GLAPIENTRY * PFNGLMAKEBUFFERRESIDENTNVPROC) (GLenum target, GLenum access); +typedef void (GLAPIENTRY * PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC) (GLuint buffer); +typedef void (GLAPIENTRY * PFNGLMAKENAMEDBUFFERRESIDENTNVPROC) (GLuint buffer, GLenum access); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMUI64NVPROC) (GLuint program, GLint location, GLuint64EXT value); +typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); +typedef void (GLAPIENTRY * PFNGLUNIFORMUI64NVPROC) (GLint location, GLuint64EXT value); +typedef void (GLAPIENTRY * PFNGLUNIFORMUI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); + +#define glGetBufferParameterui64vNV GLEW_GET_FUN(__glewGetBufferParameterui64vNV) +#define glGetIntegerui64vNV GLEW_GET_FUN(__glewGetIntegerui64vNV) +#define glGetNamedBufferParameterui64vNV GLEW_GET_FUN(__glewGetNamedBufferParameterui64vNV) +#define glIsBufferResidentNV GLEW_GET_FUN(__glewIsBufferResidentNV) +#define glIsNamedBufferResidentNV GLEW_GET_FUN(__glewIsNamedBufferResidentNV) +#define glMakeBufferNonResidentNV GLEW_GET_FUN(__glewMakeBufferNonResidentNV) +#define glMakeBufferResidentNV GLEW_GET_FUN(__glewMakeBufferResidentNV) +#define glMakeNamedBufferNonResidentNV GLEW_GET_FUN(__glewMakeNamedBufferNonResidentNV) +#define glMakeNamedBufferResidentNV GLEW_GET_FUN(__glewMakeNamedBufferResidentNV) +#define glProgramUniformui64NV GLEW_GET_FUN(__glewProgramUniformui64NV) +#define glProgramUniformui64vNV GLEW_GET_FUN(__glewProgramUniformui64vNV) +#define glUniformui64NV GLEW_GET_FUN(__glewUniformui64NV) +#define glUniformui64vNV GLEW_GET_FUN(__glewUniformui64vNV) + +#define GLEW_NV_shader_buffer_load GLEW_GET_VAR(__GLEW_NV_shader_buffer_load) + +#endif /* GL_NV_shader_buffer_load */ + +/* ---------------------- GL_NV_tessellation_program5 ---------------------- */ + +#ifndef GL_NV_tessellation_program5 +#define GL_NV_tessellation_program5 1 + +#define GL_MAX_PROGRAM_PATCH_ATTRIBS_NV 0x86D8 +#define GL_TESS_CONTROL_PROGRAM_NV 0x891E +#define GL_TESS_EVALUATION_PROGRAM_NV 0x891F +#define GL_TESS_CONTROL_PROGRAM_PARAMETER_BUFFER_NV 0x8C74 +#define GL_TESS_EVALUATION_PROGRAM_PARAMETER_BUFFER_NV 0x8C75 + +#define GLEW_NV_tessellation_program5 GLEW_GET_VAR(__GLEW_NV_tessellation_program5) + +#endif /* GL_NV_tessellation_program5 */ + +/* -------------------------- GL_NV_texgen_emboss -------------------------- */ + +#ifndef GL_NV_texgen_emboss +#define GL_NV_texgen_emboss 1 + +#define GL_EMBOSS_LIGHT_NV 0x855D +#define GL_EMBOSS_CONSTANT_NV 0x855E +#define GL_EMBOSS_MAP_NV 0x855F + +#define GLEW_NV_texgen_emboss GLEW_GET_VAR(__GLEW_NV_texgen_emboss) + +#endif /* GL_NV_texgen_emboss */ + +/* ------------------------ GL_NV_texgen_reflection ------------------------ */ + +#ifndef GL_NV_texgen_reflection +#define GL_NV_texgen_reflection 1 + +#define GL_NORMAL_MAP_NV 0x8511 +#define GL_REFLECTION_MAP_NV 0x8512 + +#define GLEW_NV_texgen_reflection GLEW_GET_VAR(__GLEW_NV_texgen_reflection) + +#endif /* GL_NV_texgen_reflection */ + +/* ------------------------- GL_NV_texture_barrier ------------------------- */ + +#ifndef GL_NV_texture_barrier +#define GL_NV_texture_barrier 1 + +typedef void (GLAPIENTRY * PFNGLTEXTUREBARRIERNVPROC) (void); + +#define glTextureBarrierNV GLEW_GET_FUN(__glewTextureBarrierNV) + +#define GLEW_NV_texture_barrier GLEW_GET_VAR(__GLEW_NV_texture_barrier) + +#endif /* GL_NV_texture_barrier */ + +/* --------------------- GL_NV_texture_compression_vtc --------------------- */ + +#ifndef GL_NV_texture_compression_vtc +#define GL_NV_texture_compression_vtc 1 + +#define GLEW_NV_texture_compression_vtc GLEW_GET_VAR(__GLEW_NV_texture_compression_vtc) + +#endif /* GL_NV_texture_compression_vtc */ + +/* ----------------------- GL_NV_texture_env_combine4 ---------------------- */ + +#ifndef GL_NV_texture_env_combine4 +#define GL_NV_texture_env_combine4 1 + +#define GL_COMBINE4_NV 0x8503 +#define GL_SOURCE3_RGB_NV 0x8583 +#define GL_SOURCE3_ALPHA_NV 0x858B +#define GL_OPERAND3_RGB_NV 0x8593 +#define GL_OPERAND3_ALPHA_NV 0x859B + +#define GLEW_NV_texture_env_combine4 GLEW_GET_VAR(__GLEW_NV_texture_env_combine4) + +#endif /* GL_NV_texture_env_combine4 */ + +/* ---------------------- GL_NV_texture_expand_normal ---------------------- */ + +#ifndef GL_NV_texture_expand_normal +#define GL_NV_texture_expand_normal 1 + +#define GL_TEXTURE_UNSIGNED_REMAP_MODE_NV 0x888F + +#define GLEW_NV_texture_expand_normal GLEW_GET_VAR(__GLEW_NV_texture_expand_normal) + +#endif /* GL_NV_texture_expand_normal */ + +/* ------------------------ GL_NV_texture_rectangle ------------------------ */ + +#ifndef GL_NV_texture_rectangle +#define GL_NV_texture_rectangle 1 + +#define GL_TEXTURE_RECTANGLE_NV 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE_NV 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE_NV 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE_NV 0x84F8 + +#define GLEW_NV_texture_rectangle GLEW_GET_VAR(__GLEW_NV_texture_rectangle) + +#endif /* GL_NV_texture_rectangle */ + +/* -------------------------- GL_NV_texture_shader ------------------------- */ + +#ifndef GL_NV_texture_shader +#define GL_NV_texture_shader 1 + +#define GL_OFFSET_TEXTURE_RECTANGLE_NV 0x864C +#define GL_OFFSET_TEXTURE_RECTANGLE_SCALE_NV 0x864D +#define GL_DOT_PRODUCT_TEXTURE_RECTANGLE_NV 0x864E +#define GL_RGBA_UNSIGNED_DOT_PRODUCT_MAPPING_NV 0x86D9 +#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA +#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB +#define GL_DSDT_MAG_INTENSITY_NV 0x86DC +#define GL_SHADER_CONSISTENT_NV 0x86DD +#define GL_TEXTURE_SHADER_NV 0x86DE +#define GL_SHADER_OPERATION_NV 0x86DF +#define GL_CULL_MODES_NV 0x86E0 +#define GL_OFFSET_TEXTURE_2D_MATRIX_NV 0x86E1 +#define GL_OFFSET_TEXTURE_MATRIX_NV 0x86E1 +#define GL_OFFSET_TEXTURE_2D_SCALE_NV 0x86E2 +#define GL_OFFSET_TEXTURE_SCALE_NV 0x86E2 +#define GL_OFFSET_TEXTURE_BIAS_NV 0x86E3 +#define GL_OFFSET_TEXTURE_2D_BIAS_NV 0x86E3 +#define GL_PREVIOUS_TEXTURE_INPUT_NV 0x86E4 +#define GL_CONST_EYE_NV 0x86E5 +#define GL_PASS_THROUGH_NV 0x86E6 +#define GL_CULL_FRAGMENT_NV 0x86E7 +#define GL_OFFSET_TEXTURE_2D_NV 0x86E8 +#define GL_DEPENDENT_AR_TEXTURE_2D_NV 0x86E9 +#define GL_DEPENDENT_GB_TEXTURE_2D_NV 0x86EA +#define GL_DOT_PRODUCT_NV 0x86EC +#define GL_DOT_PRODUCT_DEPTH_REPLACE_NV 0x86ED +#define GL_DOT_PRODUCT_TEXTURE_2D_NV 0x86EE +#define GL_DOT_PRODUCT_TEXTURE_CUBE_MAP_NV 0x86F0 +#define GL_DOT_PRODUCT_DIFFUSE_CUBE_MAP_NV 0x86F1 +#define GL_DOT_PRODUCT_REFLECT_CUBE_MAP_NV 0x86F2 +#define GL_DOT_PRODUCT_CONST_EYE_REFLECT_CUBE_MAP_NV 0x86F3 +#define GL_HILO_NV 0x86F4 +#define GL_DSDT_NV 0x86F5 +#define GL_DSDT_MAG_NV 0x86F6 +#define GL_DSDT_MAG_VIB_NV 0x86F7 +#define GL_HILO16_NV 0x86F8 +#define GL_SIGNED_HILO_NV 0x86F9 +#define GL_SIGNED_HILO16_NV 0x86FA +#define GL_SIGNED_RGBA_NV 0x86FB +#define GL_SIGNED_RGBA8_NV 0x86FC +#define GL_SIGNED_RGB_NV 0x86FE +#define GL_SIGNED_RGB8_NV 0x86FF +#define GL_SIGNED_LUMINANCE_NV 0x8701 +#define GL_SIGNED_LUMINANCE8_NV 0x8702 +#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 +#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 +#define GL_SIGNED_ALPHA_NV 0x8705 +#define GL_SIGNED_ALPHA8_NV 0x8706 +#define GL_SIGNED_INTENSITY_NV 0x8707 +#define GL_SIGNED_INTENSITY8_NV 0x8708 +#define GL_DSDT8_NV 0x8709 +#define GL_DSDT8_MAG8_NV 0x870A +#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B +#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C +#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D +#define GL_HI_SCALE_NV 0x870E +#define GL_LO_SCALE_NV 0x870F +#define GL_DS_SCALE_NV 0x8710 +#define GL_DT_SCALE_NV 0x8711 +#define GL_MAGNITUDE_SCALE_NV 0x8712 +#define GL_VIBRANCE_SCALE_NV 0x8713 +#define GL_HI_BIAS_NV 0x8714 +#define GL_LO_BIAS_NV 0x8715 +#define GL_DS_BIAS_NV 0x8716 +#define GL_DT_BIAS_NV 0x8717 +#define GL_MAGNITUDE_BIAS_NV 0x8718 +#define GL_VIBRANCE_BIAS_NV 0x8719 +#define GL_TEXTURE_BORDER_VALUES_NV 0x871A +#define GL_TEXTURE_HI_SIZE_NV 0x871B +#define GL_TEXTURE_LO_SIZE_NV 0x871C +#define GL_TEXTURE_DS_SIZE_NV 0x871D +#define GL_TEXTURE_DT_SIZE_NV 0x871E +#define GL_TEXTURE_MAG_SIZE_NV 0x871F + +#define GLEW_NV_texture_shader GLEW_GET_VAR(__GLEW_NV_texture_shader) + +#endif /* GL_NV_texture_shader */ + +/* ------------------------- GL_NV_texture_shader2 ------------------------- */ + +#ifndef GL_NV_texture_shader2 +#define GL_NV_texture_shader2 1 + +#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA +#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB +#define GL_DSDT_MAG_INTENSITY_NV 0x86DC +#define GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF +#define GL_HILO_NV 0x86F4 +#define GL_DSDT_NV 0x86F5 +#define GL_DSDT_MAG_NV 0x86F6 +#define GL_DSDT_MAG_VIB_NV 0x86F7 +#define GL_HILO16_NV 0x86F8 +#define GL_SIGNED_HILO_NV 0x86F9 +#define GL_SIGNED_HILO16_NV 0x86FA +#define GL_SIGNED_RGBA_NV 0x86FB +#define GL_SIGNED_RGBA8_NV 0x86FC +#define GL_SIGNED_RGB_NV 0x86FE +#define GL_SIGNED_RGB8_NV 0x86FF +#define GL_SIGNED_LUMINANCE_NV 0x8701 +#define GL_SIGNED_LUMINANCE8_NV 0x8702 +#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 +#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 +#define GL_SIGNED_ALPHA_NV 0x8705 +#define GL_SIGNED_ALPHA8_NV 0x8706 +#define GL_SIGNED_INTENSITY_NV 0x8707 +#define GL_SIGNED_INTENSITY8_NV 0x8708 +#define GL_DSDT8_NV 0x8709 +#define GL_DSDT8_MAG8_NV 0x870A +#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B +#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C +#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D + +#define GLEW_NV_texture_shader2 GLEW_GET_VAR(__GLEW_NV_texture_shader2) + +#endif /* GL_NV_texture_shader2 */ + +/* ------------------------- GL_NV_texture_shader3 ------------------------- */ + +#ifndef GL_NV_texture_shader3 +#define GL_NV_texture_shader3 1 + +#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_NV 0x8850 +#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_SCALE_NV 0x8851 +#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8852 +#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_SCALE_NV 0x8853 +#define GL_OFFSET_HILO_TEXTURE_2D_NV 0x8854 +#define GL_OFFSET_HILO_TEXTURE_RECTANGLE_NV 0x8855 +#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_2D_NV 0x8856 +#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8857 +#define GL_DEPENDENT_HILO_TEXTURE_2D_NV 0x8858 +#define GL_DEPENDENT_RGB_TEXTURE_3D_NV 0x8859 +#define GL_DEPENDENT_RGB_TEXTURE_CUBE_MAP_NV 0x885A +#define GL_DOT_PRODUCT_PASS_THROUGH_NV 0x885B +#define GL_DOT_PRODUCT_TEXTURE_1D_NV 0x885C +#define GL_DOT_PRODUCT_AFFINE_DEPTH_REPLACE_NV 0x885D +#define GL_HILO8_NV 0x885E +#define GL_SIGNED_HILO8_NV 0x885F +#define GL_FORCE_BLUE_TO_ONE_NV 0x8860 + +#define GLEW_NV_texture_shader3 GLEW_GET_VAR(__GLEW_NV_texture_shader3) + +#endif /* GL_NV_texture_shader3 */ + +/* ------------------------ GL_NV_transform_feedback ----------------------- */ + +#ifndef GL_NV_transform_feedback +#define GL_NV_transform_feedback 1 + +#define GL_BACK_PRIMARY_COLOR_NV 0x8C77 +#define GL_BACK_SECONDARY_COLOR_NV 0x8C78 +#define GL_TEXTURE_COORD_NV 0x8C79 +#define GL_CLIP_DISTANCE_NV 0x8C7A +#define GL_VERTEX_ID_NV 0x8C7B +#define GL_PRIMITIVE_ID_NV 0x8C7C +#define GL_GENERIC_ATTRIB_NV 0x8C7D +#define GL_TRANSFORM_FEEDBACK_ATTRIBS_NV 0x8C7E +#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE_NV 0x8C7F +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_NV 0x8C80 +#define GL_ACTIVE_VARYINGS_NV 0x8C81 +#define GL_ACTIVE_VARYING_MAX_LENGTH_NV 0x8C82 +#define GL_TRANSFORM_FEEDBACK_VARYINGS_NV 0x8C83 +#define GL_TRANSFORM_FEEDBACK_BUFFER_START_NV 0x8C84 +#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_NV 0x8C85 +#define GL_TRANSFORM_FEEDBACK_RECORD_NV 0x8C86 +#define GL_PRIMITIVES_GENERATED_NV 0x8C87 +#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_NV 0x8C88 +#define GL_RASTERIZER_DISCARD_NV 0x8C89 +#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_NV 0x8C8A +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_NV 0x8C8B +#define GL_INTERLEAVED_ATTRIBS_NV 0x8C8C +#define GL_SEPARATE_ATTRIBS_NV 0x8C8D +#define GL_TRANSFORM_FEEDBACK_BUFFER_NV 0x8C8E +#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_NV 0x8C8F + +typedef void (GLAPIENTRY * PFNGLACTIVEVARYINGNVPROC) (GLuint program, const GLchar *name); +typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKNVPROC) (GLenum primitiveMode); +typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASENVPROC) (GLenum target, GLuint index, GLuint buffer); +typedef void (GLAPIENTRY * PFNGLBINDBUFFEROFFSETNVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); +typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGENVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKNVPROC) (void); +typedef void (GLAPIENTRY * PFNGLGETACTIVEVARYINGNVPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC) (GLuint program, GLuint index, GLint *location); +typedef GLint (GLAPIENTRY * PFNGLGETVARYINGLOCATIONNVPROC) (GLuint program, const GLchar *name); +typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC) (GLuint count, const GLint *attribs, GLenum bufferMode); +typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC) (GLuint program, GLsizei count, const GLint *locations, GLenum bufferMode); + +#define glActiveVaryingNV GLEW_GET_FUN(__glewActiveVaryingNV) +#define glBeginTransformFeedbackNV GLEW_GET_FUN(__glewBeginTransformFeedbackNV) +#define glBindBufferBaseNV GLEW_GET_FUN(__glewBindBufferBaseNV) +#define glBindBufferOffsetNV GLEW_GET_FUN(__glewBindBufferOffsetNV) +#define glBindBufferRangeNV GLEW_GET_FUN(__glewBindBufferRangeNV) +#define glEndTransformFeedbackNV GLEW_GET_FUN(__glewEndTransformFeedbackNV) +#define glGetActiveVaryingNV GLEW_GET_FUN(__glewGetActiveVaryingNV) +#define glGetTransformFeedbackVaryingNV GLEW_GET_FUN(__glewGetTransformFeedbackVaryingNV) +#define glGetVaryingLocationNV GLEW_GET_FUN(__glewGetVaryingLocationNV) +#define glTransformFeedbackAttribsNV GLEW_GET_FUN(__glewTransformFeedbackAttribsNV) +#define glTransformFeedbackVaryingsNV GLEW_GET_FUN(__glewTransformFeedbackVaryingsNV) + +#define GLEW_NV_transform_feedback GLEW_GET_VAR(__GLEW_NV_transform_feedback) + +#endif /* GL_NV_transform_feedback */ + +/* ----------------------- GL_NV_transform_feedback2 ----------------------- */ + +#ifndef GL_NV_transform_feedback2 +#define GL_NV_transform_feedback2 1 + +#define GL_TRANSFORM_FEEDBACK_NV 0x8E22 +#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED_NV 0x8E23 +#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE_NV 0x8E24 +#define GL_TRANSFORM_FEEDBACK_BINDING_NV 0x8E25 + +typedef void (GLAPIENTRY * PFNGLBINDTRANSFORMFEEDBACKNVPROC) (GLenum target, GLuint id); +typedef void (GLAPIENTRY * PFNGLDELETETRANSFORMFEEDBACKSNVPROC) (GLsizei n, const GLuint* ids); +typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKNVPROC) (GLenum mode, GLuint id); +typedef void (GLAPIENTRY * PFNGLGENTRANSFORMFEEDBACKSNVPROC) (GLsizei n, GLuint* ids); +typedef GLboolean (GLAPIENTRY * PFNGLISTRANSFORMFEEDBACKNVPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLPAUSETRANSFORMFEEDBACKNVPROC) (void); +typedef void (GLAPIENTRY * PFNGLRESUMETRANSFORMFEEDBACKNVPROC) (void); + +#define glBindTransformFeedbackNV GLEW_GET_FUN(__glewBindTransformFeedbackNV) +#define glDeleteTransformFeedbacksNV GLEW_GET_FUN(__glewDeleteTransformFeedbacksNV) +#define glDrawTransformFeedbackNV GLEW_GET_FUN(__glewDrawTransformFeedbackNV) +#define glGenTransformFeedbacksNV GLEW_GET_FUN(__glewGenTransformFeedbacksNV) +#define glIsTransformFeedbackNV GLEW_GET_FUN(__glewIsTransformFeedbackNV) +#define glPauseTransformFeedbackNV GLEW_GET_FUN(__glewPauseTransformFeedbackNV) +#define glResumeTransformFeedbackNV GLEW_GET_FUN(__glewResumeTransformFeedbackNV) + +#define GLEW_NV_transform_feedback2 GLEW_GET_VAR(__GLEW_NV_transform_feedback2) + +#endif /* GL_NV_transform_feedback2 */ + +/* ------------------------ GL_NV_vertex_array_range ----------------------- */ + +#ifndef GL_NV_vertex_array_range +#define GL_NV_vertex_array_range 1 + +#define GL_VERTEX_ARRAY_RANGE_NV 0x851D +#define GL_VERTEX_ARRAY_RANGE_LENGTH_NV 0x851E +#define GL_VERTEX_ARRAY_RANGE_VALID_NV 0x851F +#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_NV 0x8520 +#define GL_VERTEX_ARRAY_RANGE_POINTER_NV 0x8521 + +typedef void (GLAPIENTRY * PFNGLFLUSHVERTEXARRAYRANGENVPROC) (void); +typedef void (GLAPIENTRY * PFNGLVERTEXARRAYRANGENVPROC) (GLsizei length, void* pointer); + +#define glFlushVertexArrayRangeNV GLEW_GET_FUN(__glewFlushVertexArrayRangeNV) +#define glVertexArrayRangeNV GLEW_GET_FUN(__glewVertexArrayRangeNV) + +#define GLEW_NV_vertex_array_range GLEW_GET_VAR(__GLEW_NV_vertex_array_range) + +#endif /* GL_NV_vertex_array_range */ + +/* ----------------------- GL_NV_vertex_array_range2 ----------------------- */ + +#ifndef GL_NV_vertex_array_range2 +#define GL_NV_vertex_array_range2 1 + +#define GL_VERTEX_ARRAY_RANGE_WITHOUT_FLUSH_NV 0x8533 + +#define GLEW_NV_vertex_array_range2 GLEW_GET_VAR(__GLEW_NV_vertex_array_range2) + +#endif /* GL_NV_vertex_array_range2 */ + +/* ------------------- GL_NV_vertex_attrib_integer_64bit ------------------- */ + +#ifndef GL_NV_vertex_attrib_integer_64bit +#define GL_NV_vertex_attrib_integer_64bit 1 + +#define GL_INT64_NV 0x140E +#define GL_UNSIGNED_INT64_NV 0x140F + +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLI64VNVPROC) (GLuint index, GLenum pname, GLint64EXT* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLUI64VNVPROC) (GLuint index, GLenum pname, GLuint64EXT* params); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1I64NVPROC) (GLuint index, GLint64EXT x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1I64VNVPROC) (GLuint index, const GLint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64NVPROC) (GLuint index, GLuint64EXT x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64VNVPROC) (GLuint index, const GLuint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2I64VNVPROC) (GLuint index, const GLint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2UI64VNVPROC) (GLuint index, const GLuint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3I64VNVPROC) (GLuint index, const GLint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3UI64VNVPROC) (GLuint index, const GLuint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4I64VNVPROC) (GLuint index, const GLint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4UI64VNVPROC) (GLuint index, const GLuint64EXT* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); + +#define glGetVertexAttribLi64vNV GLEW_GET_FUN(__glewGetVertexAttribLi64vNV) +#define glGetVertexAttribLui64vNV GLEW_GET_FUN(__glewGetVertexAttribLui64vNV) +#define glVertexAttribL1i64NV GLEW_GET_FUN(__glewVertexAttribL1i64NV) +#define glVertexAttribL1i64vNV GLEW_GET_FUN(__glewVertexAttribL1i64vNV) +#define glVertexAttribL1ui64NV GLEW_GET_FUN(__glewVertexAttribL1ui64NV) +#define glVertexAttribL1ui64vNV GLEW_GET_FUN(__glewVertexAttribL1ui64vNV) +#define glVertexAttribL2i64NV GLEW_GET_FUN(__glewVertexAttribL2i64NV) +#define glVertexAttribL2i64vNV GLEW_GET_FUN(__glewVertexAttribL2i64vNV) +#define glVertexAttribL2ui64NV GLEW_GET_FUN(__glewVertexAttribL2ui64NV) +#define glVertexAttribL2ui64vNV GLEW_GET_FUN(__glewVertexAttribL2ui64vNV) +#define glVertexAttribL3i64NV GLEW_GET_FUN(__glewVertexAttribL3i64NV) +#define glVertexAttribL3i64vNV GLEW_GET_FUN(__glewVertexAttribL3i64vNV) +#define glVertexAttribL3ui64NV GLEW_GET_FUN(__glewVertexAttribL3ui64NV) +#define glVertexAttribL3ui64vNV GLEW_GET_FUN(__glewVertexAttribL3ui64vNV) +#define glVertexAttribL4i64NV GLEW_GET_FUN(__glewVertexAttribL4i64NV) +#define glVertexAttribL4i64vNV GLEW_GET_FUN(__glewVertexAttribL4i64vNV) +#define glVertexAttribL4ui64NV GLEW_GET_FUN(__glewVertexAttribL4ui64NV) +#define glVertexAttribL4ui64vNV GLEW_GET_FUN(__glewVertexAttribL4ui64vNV) +#define glVertexAttribLFormatNV GLEW_GET_FUN(__glewVertexAttribLFormatNV) + +#define GLEW_NV_vertex_attrib_integer_64bit GLEW_GET_VAR(__GLEW_NV_vertex_attrib_integer_64bit) + +#endif /* GL_NV_vertex_attrib_integer_64bit */ + +/* ------------------- GL_NV_vertex_buffer_unified_memory ------------------ */ + +#ifndef GL_NV_vertex_buffer_unified_memory +#define GL_NV_vertex_buffer_unified_memory 1 + +#define GL_VERTEX_ATTRIB_ARRAY_UNIFIED_NV 0x8F1E +#define GL_ELEMENT_ARRAY_UNIFIED_NV 0x8F1F +#define GL_VERTEX_ATTRIB_ARRAY_ADDRESS_NV 0x8F20 +#define GL_VERTEX_ARRAY_ADDRESS_NV 0x8F21 +#define GL_NORMAL_ARRAY_ADDRESS_NV 0x8F22 +#define GL_COLOR_ARRAY_ADDRESS_NV 0x8F23 +#define GL_INDEX_ARRAY_ADDRESS_NV 0x8F24 +#define GL_TEXTURE_COORD_ARRAY_ADDRESS_NV 0x8F25 +#define GL_EDGE_FLAG_ARRAY_ADDRESS_NV 0x8F26 +#define GL_SECONDARY_COLOR_ARRAY_ADDRESS_NV 0x8F27 +#define GL_FOG_COORD_ARRAY_ADDRESS_NV 0x8F28 +#define GL_ELEMENT_ARRAY_ADDRESS_NV 0x8F29 +#define GL_VERTEX_ATTRIB_ARRAY_LENGTH_NV 0x8F2A +#define GL_VERTEX_ARRAY_LENGTH_NV 0x8F2B +#define GL_NORMAL_ARRAY_LENGTH_NV 0x8F2C +#define GL_COLOR_ARRAY_LENGTH_NV 0x8F2D +#define GL_INDEX_ARRAY_LENGTH_NV 0x8F2E +#define GL_TEXTURE_COORD_ARRAY_LENGTH_NV 0x8F2F +#define GL_EDGE_FLAG_ARRAY_LENGTH_NV 0x8F30 +#define GL_SECONDARY_COLOR_ARRAY_LENGTH_NV 0x8F31 +#define GL_FOG_COORD_ARRAY_LENGTH_NV 0x8F32 +#define GL_ELEMENT_ARRAY_LENGTH_NV 0x8F33 + +typedef void (GLAPIENTRY * PFNGLBUFFERADDRESSRANGENVPROC) (GLenum pname, GLuint index, GLuint64EXT address, GLsizeiptr length); +typedef void (GLAPIENTRY * PFNGLCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLEDGEFLAGFORMATNVPROC) (GLsizei stride); +typedef void (GLAPIENTRY * PFNGLFOGCOORDFORMATNVPROC) (GLenum type, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLGETINTEGERUI64I_VNVPROC) (GLenum value, GLuint index, GLuint64EXT result[]); +typedef void (GLAPIENTRY * PFNGLINDEXFORMATNVPROC) (GLenum type, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLNORMALFORMATNVPROC) (GLenum type, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLTEXCOORDFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); +typedef void (GLAPIENTRY * PFNGLVERTEXFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); + +#define glBufferAddressRangeNV GLEW_GET_FUN(__glewBufferAddressRangeNV) +#define glColorFormatNV GLEW_GET_FUN(__glewColorFormatNV) +#define glEdgeFlagFormatNV GLEW_GET_FUN(__glewEdgeFlagFormatNV) +#define glFogCoordFormatNV GLEW_GET_FUN(__glewFogCoordFormatNV) +#define glGetIntegerui64i_vNV GLEW_GET_FUN(__glewGetIntegerui64i_vNV) +#define glIndexFormatNV GLEW_GET_FUN(__glewIndexFormatNV) +#define glNormalFormatNV GLEW_GET_FUN(__glewNormalFormatNV) +#define glSecondaryColorFormatNV GLEW_GET_FUN(__glewSecondaryColorFormatNV) +#define glTexCoordFormatNV GLEW_GET_FUN(__glewTexCoordFormatNV) +#define glVertexAttribFormatNV GLEW_GET_FUN(__glewVertexAttribFormatNV) +#define glVertexAttribIFormatNV GLEW_GET_FUN(__glewVertexAttribIFormatNV) +#define glVertexFormatNV GLEW_GET_FUN(__glewVertexFormatNV) + +#define GLEW_NV_vertex_buffer_unified_memory GLEW_GET_VAR(__GLEW_NV_vertex_buffer_unified_memory) + +#endif /* GL_NV_vertex_buffer_unified_memory */ + +/* -------------------------- GL_NV_vertex_program ------------------------- */ + +#ifndef GL_NV_vertex_program +#define GL_NV_vertex_program 1 + +#define GL_VERTEX_PROGRAM_NV 0x8620 +#define GL_VERTEX_STATE_PROGRAM_NV 0x8621 +#define GL_ATTRIB_ARRAY_SIZE_NV 0x8623 +#define GL_ATTRIB_ARRAY_STRIDE_NV 0x8624 +#define GL_ATTRIB_ARRAY_TYPE_NV 0x8625 +#define GL_CURRENT_ATTRIB_NV 0x8626 +#define GL_PROGRAM_LENGTH_NV 0x8627 +#define GL_PROGRAM_STRING_NV 0x8628 +#define GL_MODELVIEW_PROJECTION_NV 0x8629 +#define GL_IDENTITY_NV 0x862A +#define GL_INVERSE_NV 0x862B +#define GL_TRANSPOSE_NV 0x862C +#define GL_INVERSE_TRANSPOSE_NV 0x862D +#define GL_MAX_TRACK_MATRIX_STACK_DEPTH_NV 0x862E +#define GL_MAX_TRACK_MATRICES_NV 0x862F +#define GL_MATRIX0_NV 0x8630 +#define GL_MATRIX1_NV 0x8631 +#define GL_MATRIX2_NV 0x8632 +#define GL_MATRIX3_NV 0x8633 +#define GL_MATRIX4_NV 0x8634 +#define GL_MATRIX5_NV 0x8635 +#define GL_MATRIX6_NV 0x8636 +#define GL_MATRIX7_NV 0x8637 +#define GL_CURRENT_MATRIX_STACK_DEPTH_NV 0x8640 +#define GL_CURRENT_MATRIX_NV 0x8641 +#define GL_VERTEX_PROGRAM_POINT_SIZE_NV 0x8642 +#define GL_VERTEX_PROGRAM_TWO_SIDE_NV 0x8643 +#define GL_PROGRAM_PARAMETER_NV 0x8644 +#define GL_ATTRIB_ARRAY_POINTER_NV 0x8645 +#define GL_PROGRAM_TARGET_NV 0x8646 +#define GL_PROGRAM_RESIDENT_NV 0x8647 +#define GL_TRACK_MATRIX_NV 0x8648 +#define GL_TRACK_MATRIX_TRANSFORM_NV 0x8649 +#define GL_VERTEX_PROGRAM_BINDING_NV 0x864A +#define GL_PROGRAM_ERROR_POSITION_NV 0x864B +#define GL_VERTEX_ATTRIB_ARRAY0_NV 0x8650 +#define GL_VERTEX_ATTRIB_ARRAY1_NV 0x8651 +#define GL_VERTEX_ATTRIB_ARRAY2_NV 0x8652 +#define GL_VERTEX_ATTRIB_ARRAY3_NV 0x8653 +#define GL_VERTEX_ATTRIB_ARRAY4_NV 0x8654 +#define GL_VERTEX_ATTRIB_ARRAY5_NV 0x8655 +#define GL_VERTEX_ATTRIB_ARRAY6_NV 0x8656 +#define GL_VERTEX_ATTRIB_ARRAY7_NV 0x8657 +#define GL_VERTEX_ATTRIB_ARRAY8_NV 0x8658 +#define GL_VERTEX_ATTRIB_ARRAY9_NV 0x8659 +#define GL_VERTEX_ATTRIB_ARRAY10_NV 0x865A +#define GL_VERTEX_ATTRIB_ARRAY11_NV 0x865B +#define GL_VERTEX_ATTRIB_ARRAY12_NV 0x865C +#define GL_VERTEX_ATTRIB_ARRAY13_NV 0x865D +#define GL_VERTEX_ATTRIB_ARRAY14_NV 0x865E +#define GL_VERTEX_ATTRIB_ARRAY15_NV 0x865F +#define GL_MAP1_VERTEX_ATTRIB0_4_NV 0x8660 +#define GL_MAP1_VERTEX_ATTRIB1_4_NV 0x8661 +#define GL_MAP1_VERTEX_ATTRIB2_4_NV 0x8662 +#define GL_MAP1_VERTEX_ATTRIB3_4_NV 0x8663 +#define GL_MAP1_VERTEX_ATTRIB4_4_NV 0x8664 +#define GL_MAP1_VERTEX_ATTRIB5_4_NV 0x8665 +#define GL_MAP1_VERTEX_ATTRIB6_4_NV 0x8666 +#define GL_MAP1_VERTEX_ATTRIB7_4_NV 0x8667 +#define GL_MAP1_VERTEX_ATTRIB8_4_NV 0x8668 +#define GL_MAP1_VERTEX_ATTRIB9_4_NV 0x8669 +#define GL_MAP1_VERTEX_ATTRIB10_4_NV 0x866A +#define GL_MAP1_VERTEX_ATTRIB11_4_NV 0x866B +#define GL_MAP1_VERTEX_ATTRIB12_4_NV 0x866C +#define GL_MAP1_VERTEX_ATTRIB13_4_NV 0x866D +#define GL_MAP1_VERTEX_ATTRIB14_4_NV 0x866E +#define GL_MAP1_VERTEX_ATTRIB15_4_NV 0x866F +#define GL_MAP2_VERTEX_ATTRIB0_4_NV 0x8670 +#define GL_MAP2_VERTEX_ATTRIB1_4_NV 0x8671 +#define GL_MAP2_VERTEX_ATTRIB2_4_NV 0x8672 +#define GL_MAP2_VERTEX_ATTRIB3_4_NV 0x8673 +#define GL_MAP2_VERTEX_ATTRIB4_4_NV 0x8674 +#define GL_MAP2_VERTEX_ATTRIB5_4_NV 0x8675 +#define GL_MAP2_VERTEX_ATTRIB6_4_NV 0x8676 +#define GL_MAP2_VERTEX_ATTRIB7_4_NV 0x8677 +#define GL_MAP2_VERTEX_ATTRIB8_4_NV 0x8678 +#define GL_MAP2_VERTEX_ATTRIB9_4_NV 0x8679 +#define GL_MAP2_VERTEX_ATTRIB10_4_NV 0x867A +#define GL_MAP2_VERTEX_ATTRIB11_4_NV 0x867B +#define GL_MAP2_VERTEX_ATTRIB12_4_NV 0x867C +#define GL_MAP2_VERTEX_ATTRIB13_4_NV 0x867D +#define GL_MAP2_VERTEX_ATTRIB14_4_NV 0x867E +#define GL_MAP2_VERTEX_ATTRIB15_4_NV 0x867F + +typedef GLboolean (GLAPIENTRY * PFNGLAREPROGRAMSRESIDENTNVPROC) (GLsizei n, const GLuint* ids, GLboolean *residences); +typedef void (GLAPIENTRY * PFNGLBINDPROGRAMNVPROC) (GLenum target, GLuint id); +typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMSNVPROC) (GLsizei n, const GLuint* ids); +typedef void (GLAPIENTRY * PFNGLEXECUTEPROGRAMNVPROC) (GLenum target, GLuint id, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGENPROGRAMSNVPROC) (GLsizei n, GLuint* ids); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMPARAMETERDVNVPROC) (GLenum target, GLuint index, GLenum pname, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTRINGNVPROC) (GLuint id, GLenum pname, GLubyte* program); +typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVNVPROC) (GLuint id, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETTRACKMATRIXIVNVPROC) (GLenum target, GLuint address, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVNVPROC) (GLuint index, GLenum pname, GLvoid** pointer); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVNVPROC) (GLuint index, GLenum pname, GLdouble* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVNVPROC) (GLuint index, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVNVPROC) (GLuint index, GLenum pname, GLint* params); +typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMNVPROC) (GLuint id); +typedef void (GLAPIENTRY * PFNGLLOADPROGRAMNVPROC) (GLenum target, GLuint id, GLsizei len, const GLubyte* program); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4DNVPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4DVNVPROC) (GLenum target, GLuint index, const GLdouble* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4FNVPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4FVNVPROC) (GLenum target, GLuint index, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERS4DVNVPROC) (GLenum target, GLuint index, GLuint num, const GLdouble* params); +typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERS4FVNVPROC) (GLenum target, GLuint index, GLuint num, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLREQUESTRESIDENTPROGRAMSNVPROC) (GLsizei n, GLuint* ids); +typedef void (GLAPIENTRY * PFNGLTRACKMATRIXNVPROC) (GLenum target, GLuint address, GLenum matrix, GLenum transform); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DNVPROC) (GLuint index, GLdouble x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVNVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FNVPROC) (GLuint index, GLfloat x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVNVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SNVPROC) (GLuint index, GLshort x); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVNVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DNVPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVNVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FNVPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVNVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SNVPROC) (GLuint index, GLshort x, GLshort y); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVNVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVNVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVNVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVNVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVNVPROC) (GLuint index, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVNVPROC) (GLuint index, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVNVPROC) (GLuint index, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBNVPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVNVPROC) (GLuint index, const GLubyte* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); +typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4UBVNVPROC) (GLuint index, GLsizei n, const GLubyte* v); + +#define glAreProgramsResidentNV GLEW_GET_FUN(__glewAreProgramsResidentNV) +#define glBindProgramNV GLEW_GET_FUN(__glewBindProgramNV) +#define glDeleteProgramsNV GLEW_GET_FUN(__glewDeleteProgramsNV) +#define glExecuteProgramNV GLEW_GET_FUN(__glewExecuteProgramNV) +#define glGenProgramsNV GLEW_GET_FUN(__glewGenProgramsNV) +#define glGetProgramParameterdvNV GLEW_GET_FUN(__glewGetProgramParameterdvNV) +#define glGetProgramParameterfvNV GLEW_GET_FUN(__glewGetProgramParameterfvNV) +#define glGetProgramStringNV GLEW_GET_FUN(__glewGetProgramStringNV) +#define glGetProgramivNV GLEW_GET_FUN(__glewGetProgramivNV) +#define glGetTrackMatrixivNV GLEW_GET_FUN(__glewGetTrackMatrixivNV) +#define glGetVertexAttribPointervNV GLEW_GET_FUN(__glewGetVertexAttribPointervNV) +#define glGetVertexAttribdvNV GLEW_GET_FUN(__glewGetVertexAttribdvNV) +#define glGetVertexAttribfvNV GLEW_GET_FUN(__glewGetVertexAttribfvNV) +#define glGetVertexAttribivNV GLEW_GET_FUN(__glewGetVertexAttribivNV) +#define glIsProgramNV GLEW_GET_FUN(__glewIsProgramNV) +#define glLoadProgramNV GLEW_GET_FUN(__glewLoadProgramNV) +#define glProgramParameter4dNV GLEW_GET_FUN(__glewProgramParameter4dNV) +#define glProgramParameter4dvNV GLEW_GET_FUN(__glewProgramParameter4dvNV) +#define glProgramParameter4fNV GLEW_GET_FUN(__glewProgramParameter4fNV) +#define glProgramParameter4fvNV GLEW_GET_FUN(__glewProgramParameter4fvNV) +#define glProgramParameters4dvNV GLEW_GET_FUN(__glewProgramParameters4dvNV) +#define glProgramParameters4fvNV GLEW_GET_FUN(__glewProgramParameters4fvNV) +#define glRequestResidentProgramsNV GLEW_GET_FUN(__glewRequestResidentProgramsNV) +#define glTrackMatrixNV GLEW_GET_FUN(__glewTrackMatrixNV) +#define glVertexAttrib1dNV GLEW_GET_FUN(__glewVertexAttrib1dNV) +#define glVertexAttrib1dvNV GLEW_GET_FUN(__glewVertexAttrib1dvNV) +#define glVertexAttrib1fNV GLEW_GET_FUN(__glewVertexAttrib1fNV) +#define glVertexAttrib1fvNV GLEW_GET_FUN(__glewVertexAttrib1fvNV) +#define glVertexAttrib1sNV GLEW_GET_FUN(__glewVertexAttrib1sNV) +#define glVertexAttrib1svNV GLEW_GET_FUN(__glewVertexAttrib1svNV) +#define glVertexAttrib2dNV GLEW_GET_FUN(__glewVertexAttrib2dNV) +#define glVertexAttrib2dvNV GLEW_GET_FUN(__glewVertexAttrib2dvNV) +#define glVertexAttrib2fNV GLEW_GET_FUN(__glewVertexAttrib2fNV) +#define glVertexAttrib2fvNV GLEW_GET_FUN(__glewVertexAttrib2fvNV) +#define glVertexAttrib2sNV GLEW_GET_FUN(__glewVertexAttrib2sNV) +#define glVertexAttrib2svNV GLEW_GET_FUN(__glewVertexAttrib2svNV) +#define glVertexAttrib3dNV GLEW_GET_FUN(__glewVertexAttrib3dNV) +#define glVertexAttrib3dvNV GLEW_GET_FUN(__glewVertexAttrib3dvNV) +#define glVertexAttrib3fNV GLEW_GET_FUN(__glewVertexAttrib3fNV) +#define glVertexAttrib3fvNV GLEW_GET_FUN(__glewVertexAttrib3fvNV) +#define glVertexAttrib3sNV GLEW_GET_FUN(__glewVertexAttrib3sNV) +#define glVertexAttrib3svNV GLEW_GET_FUN(__glewVertexAttrib3svNV) +#define glVertexAttrib4dNV GLEW_GET_FUN(__glewVertexAttrib4dNV) +#define glVertexAttrib4dvNV GLEW_GET_FUN(__glewVertexAttrib4dvNV) +#define glVertexAttrib4fNV GLEW_GET_FUN(__glewVertexAttrib4fNV) +#define glVertexAttrib4fvNV GLEW_GET_FUN(__glewVertexAttrib4fvNV) +#define glVertexAttrib4sNV GLEW_GET_FUN(__glewVertexAttrib4sNV) +#define glVertexAttrib4svNV GLEW_GET_FUN(__glewVertexAttrib4svNV) +#define glVertexAttrib4ubNV GLEW_GET_FUN(__glewVertexAttrib4ubNV) +#define glVertexAttrib4ubvNV GLEW_GET_FUN(__glewVertexAttrib4ubvNV) +#define glVertexAttribPointerNV GLEW_GET_FUN(__glewVertexAttribPointerNV) +#define glVertexAttribs1dvNV GLEW_GET_FUN(__glewVertexAttribs1dvNV) +#define glVertexAttribs1fvNV GLEW_GET_FUN(__glewVertexAttribs1fvNV) +#define glVertexAttribs1svNV GLEW_GET_FUN(__glewVertexAttribs1svNV) +#define glVertexAttribs2dvNV GLEW_GET_FUN(__glewVertexAttribs2dvNV) +#define glVertexAttribs2fvNV GLEW_GET_FUN(__glewVertexAttribs2fvNV) +#define glVertexAttribs2svNV GLEW_GET_FUN(__glewVertexAttribs2svNV) +#define glVertexAttribs3dvNV GLEW_GET_FUN(__glewVertexAttribs3dvNV) +#define glVertexAttribs3fvNV GLEW_GET_FUN(__glewVertexAttribs3fvNV) +#define glVertexAttribs3svNV GLEW_GET_FUN(__glewVertexAttribs3svNV) +#define glVertexAttribs4dvNV GLEW_GET_FUN(__glewVertexAttribs4dvNV) +#define glVertexAttribs4fvNV GLEW_GET_FUN(__glewVertexAttribs4fvNV) +#define glVertexAttribs4svNV GLEW_GET_FUN(__glewVertexAttribs4svNV) +#define glVertexAttribs4ubvNV GLEW_GET_FUN(__glewVertexAttribs4ubvNV) + +#define GLEW_NV_vertex_program GLEW_GET_VAR(__GLEW_NV_vertex_program) + +#endif /* GL_NV_vertex_program */ + +/* ------------------------ GL_NV_vertex_program1_1 ------------------------ */ + +#ifndef GL_NV_vertex_program1_1 +#define GL_NV_vertex_program1_1 1 + +#define GLEW_NV_vertex_program1_1 GLEW_GET_VAR(__GLEW_NV_vertex_program1_1) + +#endif /* GL_NV_vertex_program1_1 */ + +/* ------------------------- GL_NV_vertex_program2 ------------------------- */ + +#ifndef GL_NV_vertex_program2 +#define GL_NV_vertex_program2 1 + +#define GLEW_NV_vertex_program2 GLEW_GET_VAR(__GLEW_NV_vertex_program2) + +#endif /* GL_NV_vertex_program2 */ + +/* ---------------------- GL_NV_vertex_program2_option --------------------- */ + +#ifndef GL_NV_vertex_program2_option +#define GL_NV_vertex_program2_option 1 + +#define GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 +#define GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 + +#define GLEW_NV_vertex_program2_option GLEW_GET_VAR(__GLEW_NV_vertex_program2_option) + +#endif /* GL_NV_vertex_program2_option */ + +/* ------------------------- GL_NV_vertex_program3 ------------------------- */ + +#ifndef GL_NV_vertex_program3 +#define GL_NV_vertex_program3 1 + +#define MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C + +#define GLEW_NV_vertex_program3 GLEW_GET_VAR(__GLEW_NV_vertex_program3) + +#endif /* GL_NV_vertex_program3 */ + +/* ------------------------- GL_NV_vertex_program4 ------------------------- */ + +#ifndef GL_NV_vertex_program4 +#define GL_NV_vertex_program4 1 + +#define GLEW_NV_vertex_program4 GLEW_GET_VAR(__GLEW_NV_vertex_program4) + +#endif /* GL_NV_vertex_program4 */ + +/* ------------------------ GL_OES_byte_coordinates ------------------------ */ + +#ifndef GL_OES_byte_coordinates +#define GL_OES_byte_coordinates 1 + +#define GL_BYTE 0x1400 + +#define GLEW_OES_byte_coordinates GLEW_GET_VAR(__GLEW_OES_byte_coordinates) + +#endif /* GL_OES_byte_coordinates */ + +/* ------------------- GL_OES_compressed_paletted_texture ------------------ */ + +#ifndef GL_OES_compressed_paletted_texture +#define GL_OES_compressed_paletted_texture 1 + +#define GL_PALETTE4_RGB8_OES 0x8B90 +#define GL_PALETTE4_RGBA8_OES 0x8B91 +#define GL_PALETTE4_R5_G6_B5_OES 0x8B92 +#define GL_PALETTE4_RGBA4_OES 0x8B93 +#define GL_PALETTE4_RGB5_A1_OES 0x8B94 +#define GL_PALETTE8_RGB8_OES 0x8B95 +#define GL_PALETTE8_RGBA8_OES 0x8B96 +#define GL_PALETTE8_R5_G6_B5_OES 0x8B97 +#define GL_PALETTE8_RGBA4_OES 0x8B98 +#define GL_PALETTE8_RGB5_A1_OES 0x8B99 + +#define GLEW_OES_compressed_paletted_texture GLEW_GET_VAR(__GLEW_OES_compressed_paletted_texture) + +#endif /* GL_OES_compressed_paletted_texture */ + +/* --------------------------- GL_OES_read_format -------------------------- */ + +#ifndef GL_OES_read_format +#define GL_OES_read_format 1 + +#define GL_IMPLEMENTATION_COLOR_READ_TYPE_OES 0x8B9A +#define GL_IMPLEMENTATION_COLOR_READ_FORMAT_OES 0x8B9B + +#define GLEW_OES_read_format GLEW_GET_VAR(__GLEW_OES_read_format) + +#endif /* GL_OES_read_format */ + +/* ------------------------ GL_OES_single_precision ------------------------ */ + +#ifndef GL_OES_single_precision +#define GL_OES_single_precision 1 + +typedef void (GLAPIENTRY * PFNGLCLEARDEPTHFOESPROC) (GLclampd depth); +typedef void (GLAPIENTRY * PFNGLCLIPPLANEFOESPROC) (GLenum plane, const GLfloat* equation); +typedef void (GLAPIENTRY * PFNGLDEPTHRANGEFOESPROC) (GLclampf n, GLclampf f); +typedef void (GLAPIENTRY * PFNGLFRUSTUMFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); +typedef void (GLAPIENTRY * PFNGLGETCLIPPLANEFOESPROC) (GLenum plane, GLfloat* equation); +typedef void (GLAPIENTRY * PFNGLORTHOFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); + +#define glClearDepthfOES GLEW_GET_FUN(__glewClearDepthfOES) +#define glClipPlanefOES GLEW_GET_FUN(__glewClipPlanefOES) +#define glDepthRangefOES GLEW_GET_FUN(__glewDepthRangefOES) +#define glFrustumfOES GLEW_GET_FUN(__glewFrustumfOES) +#define glGetClipPlanefOES GLEW_GET_FUN(__glewGetClipPlanefOES) +#define glOrthofOES GLEW_GET_FUN(__glewOrthofOES) + +#define GLEW_OES_single_precision GLEW_GET_VAR(__GLEW_OES_single_precision) + +#endif /* GL_OES_single_precision */ + +/* ---------------------------- GL_OML_interlace --------------------------- */ + +#ifndef GL_OML_interlace +#define GL_OML_interlace 1 + +#define GL_INTERLACE_OML 0x8980 +#define GL_INTERLACE_READ_OML 0x8981 + +#define GLEW_OML_interlace GLEW_GET_VAR(__GLEW_OML_interlace) + +#endif /* GL_OML_interlace */ + +/* ---------------------------- GL_OML_resample ---------------------------- */ + +#ifndef GL_OML_resample +#define GL_OML_resample 1 + +#define GL_PACK_RESAMPLE_OML 0x8984 +#define GL_UNPACK_RESAMPLE_OML 0x8985 +#define GL_RESAMPLE_REPLICATE_OML 0x8986 +#define GL_RESAMPLE_ZERO_FILL_OML 0x8987 +#define GL_RESAMPLE_AVERAGE_OML 0x8988 +#define GL_RESAMPLE_DECIMATE_OML 0x8989 + +#define GLEW_OML_resample GLEW_GET_VAR(__GLEW_OML_resample) + +#endif /* GL_OML_resample */ + +/* ---------------------------- GL_OML_subsample --------------------------- */ + +#ifndef GL_OML_subsample +#define GL_OML_subsample 1 + +#define GL_FORMAT_SUBSAMPLE_24_24_OML 0x8982 +#define GL_FORMAT_SUBSAMPLE_244_244_OML 0x8983 + +#define GLEW_OML_subsample GLEW_GET_VAR(__GLEW_OML_subsample) + +#endif /* GL_OML_subsample */ + +/* --------------------------- GL_PGI_misc_hints --------------------------- */ + +#ifndef GL_PGI_misc_hints +#define GL_PGI_misc_hints 1 + +#define GL_PREFER_DOUBLEBUFFER_HINT_PGI 107000 +#define GL_CONSERVE_MEMORY_HINT_PGI 107005 +#define GL_RECLAIM_MEMORY_HINT_PGI 107006 +#define GL_NATIVE_GRAPHICS_HANDLE_PGI 107010 +#define GL_NATIVE_GRAPHICS_BEGIN_HINT_PGI 107011 +#define GL_NATIVE_GRAPHICS_END_HINT_PGI 107012 +#define GL_ALWAYS_FAST_HINT_PGI 107020 +#define GL_ALWAYS_SOFT_HINT_PGI 107021 +#define GL_ALLOW_DRAW_OBJ_HINT_PGI 107022 +#define GL_ALLOW_DRAW_WIN_HINT_PGI 107023 +#define GL_ALLOW_DRAW_FRG_HINT_PGI 107024 +#define GL_ALLOW_DRAW_MEM_HINT_PGI 107025 +#define GL_STRICT_DEPTHFUNC_HINT_PGI 107030 +#define GL_STRICT_LIGHTING_HINT_PGI 107031 +#define GL_STRICT_SCISSOR_HINT_PGI 107032 +#define GL_FULL_STIPPLE_HINT_PGI 107033 +#define GL_CLIP_NEAR_HINT_PGI 107040 +#define GL_CLIP_FAR_HINT_PGI 107041 +#define GL_WIDE_LINE_HINT_PGI 107042 +#define GL_BACK_NORMALS_HINT_PGI 107043 + +#define GLEW_PGI_misc_hints GLEW_GET_VAR(__GLEW_PGI_misc_hints) + +#endif /* GL_PGI_misc_hints */ + +/* -------------------------- GL_PGI_vertex_hints -------------------------- */ + +#ifndef GL_PGI_vertex_hints +#define GL_PGI_vertex_hints 1 + +#define GL_VERTEX23_BIT_PGI 0x00000004 +#define GL_VERTEX4_BIT_PGI 0x00000008 +#define GL_COLOR3_BIT_PGI 0x00010000 +#define GL_COLOR4_BIT_PGI 0x00020000 +#define GL_EDGEFLAG_BIT_PGI 0x00040000 +#define GL_INDEX_BIT_PGI 0x00080000 +#define GL_MAT_AMBIENT_BIT_PGI 0x00100000 +#define GL_VERTEX_DATA_HINT_PGI 107050 +#define GL_VERTEX_CONSISTENT_HINT_PGI 107051 +#define GL_MATERIAL_SIDE_HINT_PGI 107052 +#define GL_MAX_VERTEX_HINT_PGI 107053 +#define GL_MAT_AMBIENT_AND_DIFFUSE_BIT_PGI 0x00200000 +#define GL_MAT_DIFFUSE_BIT_PGI 0x00400000 +#define GL_MAT_EMISSION_BIT_PGI 0x00800000 +#define GL_MAT_COLOR_INDEXES_BIT_PGI 0x01000000 +#define GL_MAT_SHININESS_BIT_PGI 0x02000000 +#define GL_MAT_SPECULAR_BIT_PGI 0x04000000 +#define GL_NORMAL_BIT_PGI 0x08000000 +#define GL_TEXCOORD1_BIT_PGI 0x10000000 +#define GL_TEXCOORD2_BIT_PGI 0x20000000 +#define GL_TEXCOORD3_BIT_PGI 0x40000000 +#define GL_TEXCOORD4_BIT_PGI 0x80000000 + +#define GLEW_PGI_vertex_hints GLEW_GET_VAR(__GLEW_PGI_vertex_hints) + +#endif /* GL_PGI_vertex_hints */ + +/* ----------------------- GL_REND_screen_coordinates ---------------------- */ + +#ifndef GL_REND_screen_coordinates +#define GL_REND_screen_coordinates 1 + +#define GL_SCREEN_COORDINATES_REND 0x8490 +#define GL_INVERTED_SCREEN_W_REND 0x8491 + +#define GLEW_REND_screen_coordinates GLEW_GET_VAR(__GLEW_REND_screen_coordinates) + +#endif /* GL_REND_screen_coordinates */ + +/* ------------------------------- GL_S3_s3tc ------------------------------ */ + +#ifndef GL_S3_s3tc +#define GL_S3_s3tc 1 + +#define GL_RGB_S3TC 0x83A0 +#define GL_RGB4_S3TC 0x83A1 +#define GL_RGBA_S3TC 0x83A2 +#define GL_RGBA4_S3TC 0x83A3 +#define GL_RGBA_DXT5_S3TC 0x83A4 +#define GL_RGBA4_DXT5_S3TC 0x83A5 + +#define GLEW_S3_s3tc GLEW_GET_VAR(__GLEW_S3_s3tc) + +#endif /* GL_S3_s3tc */ + +/* -------------------------- GL_SGIS_color_range -------------------------- */ + +#ifndef GL_SGIS_color_range +#define GL_SGIS_color_range 1 + +#define GL_EXTENDED_RANGE_SGIS 0x85A5 +#define GL_MIN_RED_SGIS 0x85A6 +#define GL_MAX_RED_SGIS 0x85A7 +#define GL_MIN_GREEN_SGIS 0x85A8 +#define GL_MAX_GREEN_SGIS 0x85A9 +#define GL_MIN_BLUE_SGIS 0x85AA +#define GL_MAX_BLUE_SGIS 0x85AB +#define GL_MIN_ALPHA_SGIS 0x85AC +#define GL_MAX_ALPHA_SGIS 0x85AD + +#define GLEW_SGIS_color_range GLEW_GET_VAR(__GLEW_SGIS_color_range) + +#endif /* GL_SGIS_color_range */ + +/* ------------------------- GL_SGIS_detail_texture ------------------------ */ + +#ifndef GL_SGIS_detail_texture +#define GL_SGIS_detail_texture 1 + +typedef void (GLAPIENTRY * PFNGLDETAILTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat* points); +typedef void (GLAPIENTRY * PFNGLGETDETAILTEXFUNCSGISPROC) (GLenum target, GLfloat* points); + +#define glDetailTexFuncSGIS GLEW_GET_FUN(__glewDetailTexFuncSGIS) +#define glGetDetailTexFuncSGIS GLEW_GET_FUN(__glewGetDetailTexFuncSGIS) + +#define GLEW_SGIS_detail_texture GLEW_GET_VAR(__GLEW_SGIS_detail_texture) + +#endif /* GL_SGIS_detail_texture */ + +/* -------------------------- GL_SGIS_fog_function ------------------------- */ + +#ifndef GL_SGIS_fog_function +#define GL_SGIS_fog_function 1 + +typedef void (GLAPIENTRY * PFNGLFOGFUNCSGISPROC) (GLsizei n, const GLfloat* points); +typedef void (GLAPIENTRY * PFNGLGETFOGFUNCSGISPROC) (GLfloat* points); + +#define glFogFuncSGIS GLEW_GET_FUN(__glewFogFuncSGIS) +#define glGetFogFuncSGIS GLEW_GET_FUN(__glewGetFogFuncSGIS) + +#define GLEW_SGIS_fog_function GLEW_GET_VAR(__GLEW_SGIS_fog_function) + +#endif /* GL_SGIS_fog_function */ + +/* ------------------------ GL_SGIS_generate_mipmap ------------------------ */ + +#ifndef GL_SGIS_generate_mipmap +#define GL_SGIS_generate_mipmap 1 + +#define GL_GENERATE_MIPMAP_SGIS 0x8191 +#define GL_GENERATE_MIPMAP_HINT_SGIS 0x8192 + +#define GLEW_SGIS_generate_mipmap GLEW_GET_VAR(__GLEW_SGIS_generate_mipmap) + +#endif /* GL_SGIS_generate_mipmap */ + +/* -------------------------- GL_SGIS_multisample -------------------------- */ + +#ifndef GL_SGIS_multisample +#define GL_SGIS_multisample 1 + +#define GL_MULTISAMPLE_SGIS 0x809D +#define GL_SAMPLE_ALPHA_TO_MASK_SGIS 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE_SGIS 0x809F +#define GL_SAMPLE_MASK_SGIS 0x80A0 +#define GL_1PASS_SGIS 0x80A1 +#define GL_2PASS_0_SGIS 0x80A2 +#define GL_2PASS_1_SGIS 0x80A3 +#define GL_4PASS_0_SGIS 0x80A4 +#define GL_4PASS_1_SGIS 0x80A5 +#define GL_4PASS_2_SGIS 0x80A6 +#define GL_4PASS_3_SGIS 0x80A7 +#define GL_SAMPLE_BUFFERS_SGIS 0x80A8 +#define GL_SAMPLES_SGIS 0x80A9 +#define GL_SAMPLE_MASK_VALUE_SGIS 0x80AA +#define GL_SAMPLE_MASK_INVERT_SGIS 0x80AB +#define GL_SAMPLE_PATTERN_SGIS 0x80AC +#define GL_MULTISAMPLE_BIT_EXT 0x20000000 + +typedef void (GLAPIENTRY * PFNGLSAMPLEMASKSGISPROC) (GLclampf value, GLboolean invert); +typedef void (GLAPIENTRY * PFNGLSAMPLEPATTERNSGISPROC) (GLenum pattern); + +#define glSampleMaskSGIS GLEW_GET_FUN(__glewSampleMaskSGIS) +#define glSamplePatternSGIS GLEW_GET_FUN(__glewSamplePatternSGIS) + +#define GLEW_SGIS_multisample GLEW_GET_VAR(__GLEW_SGIS_multisample) + +#endif /* GL_SGIS_multisample */ + +/* ------------------------- GL_SGIS_pixel_texture ------------------------- */ + +#ifndef GL_SGIS_pixel_texture +#define GL_SGIS_pixel_texture 1 + +#define GLEW_SGIS_pixel_texture GLEW_GET_VAR(__GLEW_SGIS_pixel_texture) + +#endif /* GL_SGIS_pixel_texture */ + +/* ----------------------- GL_SGIS_point_line_texgen ----------------------- */ + +#ifndef GL_SGIS_point_line_texgen +#define GL_SGIS_point_line_texgen 1 + +#define GL_EYE_DISTANCE_TO_POINT_SGIS 0x81F0 +#define GL_OBJECT_DISTANCE_TO_POINT_SGIS 0x81F1 +#define GL_EYE_DISTANCE_TO_LINE_SGIS 0x81F2 +#define GL_OBJECT_DISTANCE_TO_LINE_SGIS 0x81F3 +#define GL_EYE_POINT_SGIS 0x81F4 +#define GL_OBJECT_POINT_SGIS 0x81F5 +#define GL_EYE_LINE_SGIS 0x81F6 +#define GL_OBJECT_LINE_SGIS 0x81F7 + +#define GLEW_SGIS_point_line_texgen GLEW_GET_VAR(__GLEW_SGIS_point_line_texgen) + +#endif /* GL_SGIS_point_line_texgen */ + +/* ------------------------ GL_SGIS_sharpen_texture ------------------------ */ + +#ifndef GL_SGIS_sharpen_texture +#define GL_SGIS_sharpen_texture 1 + +typedef void (GLAPIENTRY * PFNGLGETSHARPENTEXFUNCSGISPROC) (GLenum target, GLfloat* points); +typedef void (GLAPIENTRY * PFNGLSHARPENTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat* points); + +#define glGetSharpenTexFuncSGIS GLEW_GET_FUN(__glewGetSharpenTexFuncSGIS) +#define glSharpenTexFuncSGIS GLEW_GET_FUN(__glewSharpenTexFuncSGIS) + +#define GLEW_SGIS_sharpen_texture GLEW_GET_VAR(__GLEW_SGIS_sharpen_texture) + +#endif /* GL_SGIS_sharpen_texture */ + +/* --------------------------- GL_SGIS_texture4D --------------------------- */ + +#ifndef GL_SGIS_texture4D +#define GL_SGIS_texture4D 1 + +typedef void (GLAPIENTRY * PFNGLTEXIMAGE4DSGISPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLint border, GLenum format, GLenum type, const void* pixels); +typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE4DSGISPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint woffset, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLenum format, GLenum type, const void* pixels); + +#define glTexImage4DSGIS GLEW_GET_FUN(__glewTexImage4DSGIS) +#define glTexSubImage4DSGIS GLEW_GET_FUN(__glewTexSubImage4DSGIS) + +#define GLEW_SGIS_texture4D GLEW_GET_VAR(__GLEW_SGIS_texture4D) + +#endif /* GL_SGIS_texture4D */ + +/* ---------------------- GL_SGIS_texture_border_clamp --------------------- */ + +#ifndef GL_SGIS_texture_border_clamp +#define GL_SGIS_texture_border_clamp 1 + +#define GL_CLAMP_TO_BORDER_SGIS 0x812D + +#define GLEW_SGIS_texture_border_clamp GLEW_GET_VAR(__GLEW_SGIS_texture_border_clamp) + +#endif /* GL_SGIS_texture_border_clamp */ + +/* ----------------------- GL_SGIS_texture_edge_clamp ---------------------- */ + +#ifndef GL_SGIS_texture_edge_clamp +#define GL_SGIS_texture_edge_clamp 1 + +#define GL_CLAMP_TO_EDGE_SGIS 0x812F + +#define GLEW_SGIS_texture_edge_clamp GLEW_GET_VAR(__GLEW_SGIS_texture_edge_clamp) + +#endif /* GL_SGIS_texture_edge_clamp */ + +/* ------------------------ GL_SGIS_texture_filter4 ------------------------ */ + +#ifndef GL_SGIS_texture_filter4 +#define GL_SGIS_texture_filter4 1 + +typedef void (GLAPIENTRY * PFNGLGETTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLfloat* weights); +typedef void (GLAPIENTRY * PFNGLTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLsizei n, const GLfloat* weights); + +#define glGetTexFilterFuncSGIS GLEW_GET_FUN(__glewGetTexFilterFuncSGIS) +#define glTexFilterFuncSGIS GLEW_GET_FUN(__glewTexFilterFuncSGIS) + +#define GLEW_SGIS_texture_filter4 GLEW_GET_VAR(__GLEW_SGIS_texture_filter4) + +#endif /* GL_SGIS_texture_filter4 */ + +/* -------------------------- GL_SGIS_texture_lod -------------------------- */ + +#ifndef GL_SGIS_texture_lod +#define GL_SGIS_texture_lod 1 + +#define GL_TEXTURE_MIN_LOD_SGIS 0x813A +#define GL_TEXTURE_MAX_LOD_SGIS 0x813B +#define GL_TEXTURE_BASE_LEVEL_SGIS 0x813C +#define GL_TEXTURE_MAX_LEVEL_SGIS 0x813D + +#define GLEW_SGIS_texture_lod GLEW_GET_VAR(__GLEW_SGIS_texture_lod) + +#endif /* GL_SGIS_texture_lod */ + +/* ------------------------- GL_SGIS_texture_select ------------------------ */ + +#ifndef GL_SGIS_texture_select +#define GL_SGIS_texture_select 1 + +#define GLEW_SGIS_texture_select GLEW_GET_VAR(__GLEW_SGIS_texture_select) + +#endif /* GL_SGIS_texture_select */ + +/* ----------------------------- GL_SGIX_async ----------------------------- */ + +#ifndef GL_SGIX_async +#define GL_SGIX_async 1 + +#define GL_ASYNC_MARKER_SGIX 0x8329 + +typedef void (GLAPIENTRY * PFNGLASYNCMARKERSGIXPROC) (GLuint marker); +typedef void (GLAPIENTRY * PFNGLDELETEASYNCMARKERSSGIXPROC) (GLuint marker, GLsizei range); +typedef GLint (GLAPIENTRY * PFNGLFINISHASYNCSGIXPROC) (GLuint* markerp); +typedef GLuint (GLAPIENTRY * PFNGLGENASYNCMARKERSSGIXPROC) (GLsizei range); +typedef GLboolean (GLAPIENTRY * PFNGLISASYNCMARKERSGIXPROC) (GLuint marker); +typedef GLint (GLAPIENTRY * PFNGLPOLLASYNCSGIXPROC) (GLuint* markerp); + +#define glAsyncMarkerSGIX GLEW_GET_FUN(__glewAsyncMarkerSGIX) +#define glDeleteAsyncMarkersSGIX GLEW_GET_FUN(__glewDeleteAsyncMarkersSGIX) +#define glFinishAsyncSGIX GLEW_GET_FUN(__glewFinishAsyncSGIX) +#define glGenAsyncMarkersSGIX GLEW_GET_FUN(__glewGenAsyncMarkersSGIX) +#define glIsAsyncMarkerSGIX GLEW_GET_FUN(__glewIsAsyncMarkerSGIX) +#define glPollAsyncSGIX GLEW_GET_FUN(__glewPollAsyncSGIX) + +#define GLEW_SGIX_async GLEW_GET_VAR(__GLEW_SGIX_async) + +#endif /* GL_SGIX_async */ + +/* ------------------------ GL_SGIX_async_histogram ------------------------ */ + +#ifndef GL_SGIX_async_histogram +#define GL_SGIX_async_histogram 1 + +#define GL_ASYNC_HISTOGRAM_SGIX 0x832C +#define GL_MAX_ASYNC_HISTOGRAM_SGIX 0x832D + +#define GLEW_SGIX_async_histogram GLEW_GET_VAR(__GLEW_SGIX_async_histogram) + +#endif /* GL_SGIX_async_histogram */ + +/* -------------------------- GL_SGIX_async_pixel -------------------------- */ + +#ifndef GL_SGIX_async_pixel +#define GL_SGIX_async_pixel 1 + +#define GL_ASYNC_TEX_IMAGE_SGIX 0x835C +#define GL_ASYNC_DRAW_PIXELS_SGIX 0x835D +#define GL_ASYNC_READ_PIXELS_SGIX 0x835E +#define GL_MAX_ASYNC_TEX_IMAGE_SGIX 0x835F +#define GL_MAX_ASYNC_DRAW_PIXELS_SGIX 0x8360 +#define GL_MAX_ASYNC_READ_PIXELS_SGIX 0x8361 + +#define GLEW_SGIX_async_pixel GLEW_GET_VAR(__GLEW_SGIX_async_pixel) + +#endif /* GL_SGIX_async_pixel */ + +/* ----------------------- GL_SGIX_blend_alpha_minmax ---------------------- */ + +#ifndef GL_SGIX_blend_alpha_minmax +#define GL_SGIX_blend_alpha_minmax 1 + +#define GL_ALPHA_MIN_SGIX 0x8320 +#define GL_ALPHA_MAX_SGIX 0x8321 + +#define GLEW_SGIX_blend_alpha_minmax GLEW_GET_VAR(__GLEW_SGIX_blend_alpha_minmax) + +#endif /* GL_SGIX_blend_alpha_minmax */ + +/* ---------------------------- GL_SGIX_clipmap ---------------------------- */ + +#ifndef GL_SGIX_clipmap +#define GL_SGIX_clipmap 1 + +#define GLEW_SGIX_clipmap GLEW_GET_VAR(__GLEW_SGIX_clipmap) + +#endif /* GL_SGIX_clipmap */ + +/* ---------------------- GL_SGIX_convolution_accuracy --------------------- */ + +#ifndef GL_SGIX_convolution_accuracy +#define GL_SGIX_convolution_accuracy 1 + +#define GL_CONVOLUTION_HINT_SGIX 0x8316 + +#define GLEW_SGIX_convolution_accuracy GLEW_GET_VAR(__GLEW_SGIX_convolution_accuracy) + +#endif /* GL_SGIX_convolution_accuracy */ + +/* ------------------------- GL_SGIX_depth_texture ------------------------- */ + +#ifndef GL_SGIX_depth_texture +#define GL_SGIX_depth_texture 1 + +#define GL_DEPTH_COMPONENT16_SGIX 0x81A5 +#define GL_DEPTH_COMPONENT24_SGIX 0x81A6 +#define GL_DEPTH_COMPONENT32_SGIX 0x81A7 + +#define GLEW_SGIX_depth_texture GLEW_GET_VAR(__GLEW_SGIX_depth_texture) + +#endif /* GL_SGIX_depth_texture */ + +/* -------------------------- GL_SGIX_flush_raster ------------------------- */ + +#ifndef GL_SGIX_flush_raster +#define GL_SGIX_flush_raster 1 + +typedef void (GLAPIENTRY * PFNGLFLUSHRASTERSGIXPROC) (void); + +#define glFlushRasterSGIX GLEW_GET_FUN(__glewFlushRasterSGIX) + +#define GLEW_SGIX_flush_raster GLEW_GET_VAR(__GLEW_SGIX_flush_raster) + +#endif /* GL_SGIX_flush_raster */ + +/* --------------------------- GL_SGIX_fog_offset -------------------------- */ + +#ifndef GL_SGIX_fog_offset +#define GL_SGIX_fog_offset 1 + +#define GL_FOG_OFFSET_SGIX 0x8198 +#define GL_FOG_OFFSET_VALUE_SGIX 0x8199 + +#define GLEW_SGIX_fog_offset GLEW_GET_VAR(__GLEW_SGIX_fog_offset) + +#endif /* GL_SGIX_fog_offset */ + +/* -------------------------- GL_SGIX_fog_texture -------------------------- */ + +#ifndef GL_SGIX_fog_texture +#define GL_SGIX_fog_texture 1 + +#define GL_TEXTURE_FOG_SGIX 0 +#define GL_FOG_PATCHY_FACTOR_SGIX 0 +#define GL_FRAGMENT_FOG_SGIX 0 + +typedef void (GLAPIENTRY * PFNGLTEXTUREFOGSGIXPROC) (GLenum pname); + +#define glTextureFogSGIX GLEW_GET_FUN(__glewTextureFogSGIX) + +#define GLEW_SGIX_fog_texture GLEW_GET_VAR(__GLEW_SGIX_fog_texture) + +#endif /* GL_SGIX_fog_texture */ + +/* ------------------- GL_SGIX_fragment_specular_lighting ------------------ */ + +#ifndef GL_SGIX_fragment_specular_lighting +#define GL_SGIX_fragment_specular_lighting 1 + +typedef void (GLAPIENTRY * PFNGLFRAGMENTCOLORMATERIALSGIXPROC) (GLenum face, GLenum mode); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFSGIXPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFVSGIXPROC) (GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELISGIXPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIVSGIXPROC) (GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFSGIXPROC) (GLenum light, GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTISGIXPROC) (GLenum light, GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFSGIXPROC) (GLenum face, GLenum pname, const GLfloat param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALISGIXPROC) (GLenum face, GLenum pname, const GLint param); +typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum value, GLfloat* data); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum value, GLint* data); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat* data); +typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint* data); + +#define glFragmentColorMaterialSGIX GLEW_GET_FUN(__glewFragmentColorMaterialSGIX) +#define glFragmentLightModelfSGIX GLEW_GET_FUN(__glewFragmentLightModelfSGIX) +#define glFragmentLightModelfvSGIX GLEW_GET_FUN(__glewFragmentLightModelfvSGIX) +#define glFragmentLightModeliSGIX GLEW_GET_FUN(__glewFragmentLightModeliSGIX) +#define glFragmentLightModelivSGIX GLEW_GET_FUN(__glewFragmentLightModelivSGIX) +#define glFragmentLightfSGIX GLEW_GET_FUN(__glewFragmentLightfSGIX) +#define glFragmentLightfvSGIX GLEW_GET_FUN(__glewFragmentLightfvSGIX) +#define glFragmentLightiSGIX GLEW_GET_FUN(__glewFragmentLightiSGIX) +#define glFragmentLightivSGIX GLEW_GET_FUN(__glewFragmentLightivSGIX) +#define glFragmentMaterialfSGIX GLEW_GET_FUN(__glewFragmentMaterialfSGIX) +#define glFragmentMaterialfvSGIX GLEW_GET_FUN(__glewFragmentMaterialfvSGIX) +#define glFragmentMaterialiSGIX GLEW_GET_FUN(__glewFragmentMaterialiSGIX) +#define glFragmentMaterialivSGIX GLEW_GET_FUN(__glewFragmentMaterialivSGIX) +#define glGetFragmentLightfvSGIX GLEW_GET_FUN(__glewGetFragmentLightfvSGIX) +#define glGetFragmentLightivSGIX GLEW_GET_FUN(__glewGetFragmentLightivSGIX) +#define glGetFragmentMaterialfvSGIX GLEW_GET_FUN(__glewGetFragmentMaterialfvSGIX) +#define glGetFragmentMaterialivSGIX GLEW_GET_FUN(__glewGetFragmentMaterialivSGIX) + +#define GLEW_SGIX_fragment_specular_lighting GLEW_GET_VAR(__GLEW_SGIX_fragment_specular_lighting) + +#endif /* GL_SGIX_fragment_specular_lighting */ + +/* --------------------------- GL_SGIX_framezoom --------------------------- */ + +#ifndef GL_SGIX_framezoom +#define GL_SGIX_framezoom 1 + +typedef void (GLAPIENTRY * PFNGLFRAMEZOOMSGIXPROC) (GLint factor); + +#define glFrameZoomSGIX GLEW_GET_FUN(__glewFrameZoomSGIX) + +#define GLEW_SGIX_framezoom GLEW_GET_VAR(__GLEW_SGIX_framezoom) + +#endif /* GL_SGIX_framezoom */ + +/* --------------------------- GL_SGIX_interlace --------------------------- */ + +#ifndef GL_SGIX_interlace +#define GL_SGIX_interlace 1 + +#define GL_INTERLACE_SGIX 0x8094 + +#define GLEW_SGIX_interlace GLEW_GET_VAR(__GLEW_SGIX_interlace) + +#endif /* GL_SGIX_interlace */ + +/* ------------------------- GL_SGIX_ir_instrument1 ------------------------ */ + +#ifndef GL_SGIX_ir_instrument1 +#define GL_SGIX_ir_instrument1 1 + +#define GLEW_SGIX_ir_instrument1 GLEW_GET_VAR(__GLEW_SGIX_ir_instrument1) + +#endif /* GL_SGIX_ir_instrument1 */ + +/* ------------------------- GL_SGIX_list_priority ------------------------- */ + +#ifndef GL_SGIX_list_priority +#define GL_SGIX_list_priority 1 + +#define GLEW_SGIX_list_priority GLEW_GET_VAR(__GLEW_SGIX_list_priority) + +#endif /* GL_SGIX_list_priority */ + +/* ------------------------- GL_SGIX_pixel_texture ------------------------- */ + +#ifndef GL_SGIX_pixel_texture +#define GL_SGIX_pixel_texture 1 + +typedef void (GLAPIENTRY * PFNGLPIXELTEXGENSGIXPROC) (GLenum mode); + +#define glPixelTexGenSGIX GLEW_GET_FUN(__glewPixelTexGenSGIX) + +#define GLEW_SGIX_pixel_texture GLEW_GET_VAR(__GLEW_SGIX_pixel_texture) + +#endif /* GL_SGIX_pixel_texture */ + +/* ----------------------- GL_SGIX_pixel_texture_bits ---------------------- */ + +#ifndef GL_SGIX_pixel_texture_bits +#define GL_SGIX_pixel_texture_bits 1 + +#define GLEW_SGIX_pixel_texture_bits GLEW_GET_VAR(__GLEW_SGIX_pixel_texture_bits) + +#endif /* GL_SGIX_pixel_texture_bits */ + +/* ------------------------ GL_SGIX_reference_plane ------------------------ */ + +#ifndef GL_SGIX_reference_plane +#define GL_SGIX_reference_plane 1 + +typedef void (GLAPIENTRY * PFNGLREFERENCEPLANESGIXPROC) (const GLdouble* equation); + +#define glReferencePlaneSGIX GLEW_GET_FUN(__glewReferencePlaneSGIX) + +#define GLEW_SGIX_reference_plane GLEW_GET_VAR(__GLEW_SGIX_reference_plane) + +#endif /* GL_SGIX_reference_plane */ + +/* ---------------------------- GL_SGIX_resample --------------------------- */ + +#ifndef GL_SGIX_resample +#define GL_SGIX_resample 1 + +#define GL_PACK_RESAMPLE_SGIX 0x842E +#define GL_UNPACK_RESAMPLE_SGIX 0x842F +#define GL_RESAMPLE_DECIMATE_SGIX 0x8430 +#define GL_RESAMPLE_REPLICATE_SGIX 0x8433 +#define GL_RESAMPLE_ZERO_FILL_SGIX 0x8434 + +#define GLEW_SGIX_resample GLEW_GET_VAR(__GLEW_SGIX_resample) + +#endif /* GL_SGIX_resample */ + +/* ----------------------------- GL_SGIX_shadow ---------------------------- */ + +#ifndef GL_SGIX_shadow +#define GL_SGIX_shadow 1 + +#define GL_TEXTURE_COMPARE_SGIX 0x819A +#define GL_TEXTURE_COMPARE_OPERATOR_SGIX 0x819B +#define GL_TEXTURE_LEQUAL_R_SGIX 0x819C +#define GL_TEXTURE_GEQUAL_R_SGIX 0x819D + +#define GLEW_SGIX_shadow GLEW_GET_VAR(__GLEW_SGIX_shadow) + +#endif /* GL_SGIX_shadow */ + +/* ------------------------- GL_SGIX_shadow_ambient ------------------------ */ + +#ifndef GL_SGIX_shadow_ambient +#define GL_SGIX_shadow_ambient 1 + +#define GL_SHADOW_AMBIENT_SGIX 0x80BF + +#define GLEW_SGIX_shadow_ambient GLEW_GET_VAR(__GLEW_SGIX_shadow_ambient) + +#endif /* GL_SGIX_shadow_ambient */ + +/* ----------------------------- GL_SGIX_sprite ---------------------------- */ + +#ifndef GL_SGIX_sprite +#define GL_SGIX_sprite 1 + +typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERFSGIXPROC) (GLenum pname, GLfloat param); +typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERFVSGIXPROC) (GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERISGIXPROC) (GLenum pname, GLint param); +typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERIVSGIXPROC) (GLenum pname, GLint* params); + +#define glSpriteParameterfSGIX GLEW_GET_FUN(__glewSpriteParameterfSGIX) +#define glSpriteParameterfvSGIX GLEW_GET_FUN(__glewSpriteParameterfvSGIX) +#define glSpriteParameteriSGIX GLEW_GET_FUN(__glewSpriteParameteriSGIX) +#define glSpriteParameterivSGIX GLEW_GET_FUN(__glewSpriteParameterivSGIX) + +#define GLEW_SGIX_sprite GLEW_GET_VAR(__GLEW_SGIX_sprite) + +#endif /* GL_SGIX_sprite */ + +/* ----------------------- GL_SGIX_tag_sample_buffer ----------------------- */ + +#ifndef GL_SGIX_tag_sample_buffer +#define GL_SGIX_tag_sample_buffer 1 + +typedef void (GLAPIENTRY * PFNGLTAGSAMPLEBUFFERSGIXPROC) (void); + +#define glTagSampleBufferSGIX GLEW_GET_FUN(__glewTagSampleBufferSGIX) + +#define GLEW_SGIX_tag_sample_buffer GLEW_GET_VAR(__GLEW_SGIX_tag_sample_buffer) + +#endif /* GL_SGIX_tag_sample_buffer */ + +/* ------------------------ GL_SGIX_texture_add_env ------------------------ */ + +#ifndef GL_SGIX_texture_add_env +#define GL_SGIX_texture_add_env 1 + +#define GLEW_SGIX_texture_add_env GLEW_GET_VAR(__GLEW_SGIX_texture_add_env) + +#endif /* GL_SGIX_texture_add_env */ + +/* -------------------- GL_SGIX_texture_coordinate_clamp ------------------- */ + +#ifndef GL_SGIX_texture_coordinate_clamp +#define GL_SGIX_texture_coordinate_clamp 1 + +#define GL_TEXTURE_MAX_CLAMP_S_SGIX 0x8369 +#define GL_TEXTURE_MAX_CLAMP_T_SGIX 0x836A +#define GL_TEXTURE_MAX_CLAMP_R_SGIX 0x836B + +#define GLEW_SGIX_texture_coordinate_clamp GLEW_GET_VAR(__GLEW_SGIX_texture_coordinate_clamp) + +#endif /* GL_SGIX_texture_coordinate_clamp */ + +/* ------------------------ GL_SGIX_texture_lod_bias ----------------------- */ + +#ifndef GL_SGIX_texture_lod_bias +#define GL_SGIX_texture_lod_bias 1 + +#define GLEW_SGIX_texture_lod_bias GLEW_GET_VAR(__GLEW_SGIX_texture_lod_bias) + +#endif /* GL_SGIX_texture_lod_bias */ + +/* ---------------------- GL_SGIX_texture_multi_buffer --------------------- */ + +#ifndef GL_SGIX_texture_multi_buffer +#define GL_SGIX_texture_multi_buffer 1 + +#define GL_TEXTURE_MULTI_BUFFER_HINT_SGIX 0x812E + +#define GLEW_SGIX_texture_multi_buffer GLEW_GET_VAR(__GLEW_SGIX_texture_multi_buffer) + +#endif /* GL_SGIX_texture_multi_buffer */ + +/* ------------------------- GL_SGIX_texture_range ------------------------- */ + +#ifndef GL_SGIX_texture_range +#define GL_SGIX_texture_range 1 + +#define GL_RGB_SIGNED_SGIX 0x85E0 +#define GL_RGBA_SIGNED_SGIX 0x85E1 +#define GL_ALPHA_SIGNED_SGIX 0x85E2 +#define GL_LUMINANCE_SIGNED_SGIX 0x85E3 +#define GL_INTENSITY_SIGNED_SGIX 0x85E4 +#define GL_LUMINANCE_ALPHA_SIGNED_SGIX 0x85E5 +#define GL_RGB16_SIGNED_SGIX 0x85E6 +#define GL_RGBA16_SIGNED_SGIX 0x85E7 +#define GL_ALPHA16_SIGNED_SGIX 0x85E8 +#define GL_LUMINANCE16_SIGNED_SGIX 0x85E9 +#define GL_INTENSITY16_SIGNED_SGIX 0x85EA +#define GL_LUMINANCE16_ALPHA16_SIGNED_SGIX 0x85EB +#define GL_RGB_EXTENDED_RANGE_SGIX 0x85EC +#define GL_RGBA_EXTENDED_RANGE_SGIX 0x85ED +#define GL_ALPHA_EXTENDED_RANGE_SGIX 0x85EE +#define GL_LUMINANCE_EXTENDED_RANGE_SGIX 0x85EF +#define GL_INTENSITY_EXTENDED_RANGE_SGIX 0x85F0 +#define GL_LUMINANCE_ALPHA_EXTENDED_RANGE_SGIX 0x85F1 +#define GL_RGB16_EXTENDED_RANGE_SGIX 0x85F2 +#define GL_RGBA16_EXTENDED_RANGE_SGIX 0x85F3 +#define GL_ALPHA16_EXTENDED_RANGE_SGIX 0x85F4 +#define GL_LUMINANCE16_EXTENDED_RANGE_SGIX 0x85F5 +#define GL_INTENSITY16_EXTENDED_RANGE_SGIX 0x85F6 +#define GL_LUMINANCE16_ALPHA16_EXTENDED_RANGE_SGIX 0x85F7 +#define GL_MIN_LUMINANCE_SGIS 0x85F8 +#define GL_MAX_LUMINANCE_SGIS 0x85F9 +#define GL_MIN_INTENSITY_SGIS 0x85FA +#define GL_MAX_INTENSITY_SGIS 0x85FB + +#define GLEW_SGIX_texture_range GLEW_GET_VAR(__GLEW_SGIX_texture_range) + +#endif /* GL_SGIX_texture_range */ + +/* ----------------------- GL_SGIX_texture_scale_bias ---------------------- */ + +#ifndef GL_SGIX_texture_scale_bias +#define GL_SGIX_texture_scale_bias 1 + +#define GL_POST_TEXTURE_FILTER_BIAS_SGIX 0x8179 +#define GL_POST_TEXTURE_FILTER_SCALE_SGIX 0x817A +#define GL_POST_TEXTURE_FILTER_BIAS_RANGE_SGIX 0x817B +#define GL_POST_TEXTURE_FILTER_SCALE_RANGE_SGIX 0x817C + +#define GLEW_SGIX_texture_scale_bias GLEW_GET_VAR(__GLEW_SGIX_texture_scale_bias) + +#endif /* GL_SGIX_texture_scale_bias */ + +/* ------------------------- GL_SGIX_vertex_preclip ------------------------ */ + +#ifndef GL_SGIX_vertex_preclip +#define GL_SGIX_vertex_preclip 1 + +#define GL_VERTEX_PRECLIP_SGIX 0x83EE +#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF + +#define GLEW_SGIX_vertex_preclip GLEW_GET_VAR(__GLEW_SGIX_vertex_preclip) + +#endif /* GL_SGIX_vertex_preclip */ + +/* ---------------------- GL_SGIX_vertex_preclip_hint ---------------------- */ + +#ifndef GL_SGIX_vertex_preclip_hint +#define GL_SGIX_vertex_preclip_hint 1 + +#define GL_VERTEX_PRECLIP_SGIX 0x83EE +#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF + +#define GLEW_SGIX_vertex_preclip_hint GLEW_GET_VAR(__GLEW_SGIX_vertex_preclip_hint) + +#endif /* GL_SGIX_vertex_preclip_hint */ + +/* ----------------------------- GL_SGIX_ycrcb ----------------------------- */ + +#ifndef GL_SGIX_ycrcb +#define GL_SGIX_ycrcb 1 + +#define GLEW_SGIX_ycrcb GLEW_GET_VAR(__GLEW_SGIX_ycrcb) + +#endif /* GL_SGIX_ycrcb */ + +/* -------------------------- GL_SGI_color_matrix -------------------------- */ + +#ifndef GL_SGI_color_matrix +#define GL_SGI_color_matrix 1 + +#define GL_COLOR_MATRIX_SGI 0x80B1 +#define GL_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B2 +#define GL_MAX_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B3 +#define GL_POST_COLOR_MATRIX_RED_SCALE_SGI 0x80B4 +#define GL_POST_COLOR_MATRIX_GREEN_SCALE_SGI 0x80B5 +#define GL_POST_COLOR_MATRIX_BLUE_SCALE_SGI 0x80B6 +#define GL_POST_COLOR_MATRIX_ALPHA_SCALE_SGI 0x80B7 +#define GL_POST_COLOR_MATRIX_RED_BIAS_SGI 0x80B8 +#define GL_POST_COLOR_MATRIX_GREEN_BIAS_SGI 0x80B9 +#define GL_POST_COLOR_MATRIX_BLUE_BIAS_SGI 0x80BA +#define GL_POST_COLOR_MATRIX_ALPHA_BIAS_SGI 0x80BB + +#define GLEW_SGI_color_matrix GLEW_GET_VAR(__GLEW_SGI_color_matrix) + +#endif /* GL_SGI_color_matrix */ + +/* --------------------------- GL_SGI_color_table -------------------------- */ + +#ifndef GL_SGI_color_table +#define GL_SGI_color_table 1 + +#define GL_COLOR_TABLE_SGI 0x80D0 +#define GL_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D1 +#define GL_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D2 +#define GL_PROXY_COLOR_TABLE_SGI 0x80D3 +#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D4 +#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D5 +#define GL_COLOR_TABLE_SCALE_SGI 0x80D6 +#define GL_COLOR_TABLE_BIAS_SGI 0x80D7 +#define GL_COLOR_TABLE_FORMAT_SGI 0x80D8 +#define GL_COLOR_TABLE_WIDTH_SGI 0x80D9 +#define GL_COLOR_TABLE_RED_SIZE_SGI 0x80DA +#define GL_COLOR_TABLE_GREEN_SIZE_SGI 0x80DB +#define GL_COLOR_TABLE_BLUE_SIZE_SGI 0x80DC +#define GL_COLOR_TABLE_ALPHA_SIZE_SGI 0x80DD +#define GL_COLOR_TABLE_LUMINANCE_SIZE_SGI 0x80DE +#define GL_COLOR_TABLE_INTENSITY_SIZE_SGI 0x80DF + +typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, const GLfloat* params); +typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, const GLint* params); +typedef void (GLAPIENTRY * PFNGLCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void* table); +typedef void (GLAPIENTRY * PFNGLCOPYCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, GLfloat* params); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, GLint* params); +typedef void (GLAPIENTRY * PFNGLGETCOLORTABLESGIPROC) (GLenum target, GLenum format, GLenum type, void* table); + +#define glColorTableParameterfvSGI GLEW_GET_FUN(__glewColorTableParameterfvSGI) +#define glColorTableParameterivSGI GLEW_GET_FUN(__glewColorTableParameterivSGI) +#define glColorTableSGI GLEW_GET_FUN(__glewColorTableSGI) +#define glCopyColorTableSGI GLEW_GET_FUN(__glewCopyColorTableSGI) +#define glGetColorTableParameterfvSGI GLEW_GET_FUN(__glewGetColorTableParameterfvSGI) +#define glGetColorTableParameterivSGI GLEW_GET_FUN(__glewGetColorTableParameterivSGI) +#define glGetColorTableSGI GLEW_GET_FUN(__glewGetColorTableSGI) + +#define GLEW_SGI_color_table GLEW_GET_VAR(__GLEW_SGI_color_table) + +#endif /* GL_SGI_color_table */ + +/* ----------------------- GL_SGI_texture_color_table ---------------------- */ + +#ifndef GL_SGI_texture_color_table +#define GL_SGI_texture_color_table 1 + +#define GL_TEXTURE_COLOR_TABLE_SGI 0x80BC +#define GL_PROXY_TEXTURE_COLOR_TABLE_SGI 0x80BD + +#define GLEW_SGI_texture_color_table GLEW_GET_VAR(__GLEW_SGI_texture_color_table) + +#endif /* GL_SGI_texture_color_table */ + +/* ------------------------- GL_SUNX_constant_data ------------------------- */ + +#ifndef GL_SUNX_constant_data +#define GL_SUNX_constant_data 1 + +#define GL_UNPACK_CONSTANT_DATA_SUNX 0x81D5 +#define GL_TEXTURE_CONSTANT_DATA_SUNX 0x81D6 + +typedef void (GLAPIENTRY * PFNGLFINISHTEXTURESUNXPROC) (void); + +#define glFinishTextureSUNX GLEW_GET_FUN(__glewFinishTextureSUNX) + +#define GLEW_SUNX_constant_data GLEW_GET_VAR(__GLEW_SUNX_constant_data) + +#endif /* GL_SUNX_constant_data */ + +/* -------------------- GL_SUN_convolution_border_modes -------------------- */ + +#ifndef GL_SUN_convolution_border_modes +#define GL_SUN_convolution_border_modes 1 + +#define GL_WRAP_BORDER_SUN 0x81D4 + +#define GLEW_SUN_convolution_border_modes GLEW_GET_VAR(__GLEW_SUN_convolution_border_modes) + +#endif /* GL_SUN_convolution_border_modes */ + +/* -------------------------- GL_SUN_global_alpha -------------------------- */ + +#ifndef GL_SUN_global_alpha +#define GL_SUN_global_alpha 1 + +#define GL_GLOBAL_ALPHA_SUN 0x81D9 +#define GL_GLOBAL_ALPHA_FACTOR_SUN 0x81DA + +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORBSUNPROC) (GLbyte factor); +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORDSUNPROC) (GLdouble factor); +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORFSUNPROC) (GLfloat factor); +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORISUNPROC) (GLint factor); +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORSSUNPROC) (GLshort factor); +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUBSUNPROC) (GLubyte factor); +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUISUNPROC) (GLuint factor); +typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUSSUNPROC) (GLushort factor); + +#define glGlobalAlphaFactorbSUN GLEW_GET_FUN(__glewGlobalAlphaFactorbSUN) +#define glGlobalAlphaFactordSUN GLEW_GET_FUN(__glewGlobalAlphaFactordSUN) +#define glGlobalAlphaFactorfSUN GLEW_GET_FUN(__glewGlobalAlphaFactorfSUN) +#define glGlobalAlphaFactoriSUN GLEW_GET_FUN(__glewGlobalAlphaFactoriSUN) +#define glGlobalAlphaFactorsSUN GLEW_GET_FUN(__glewGlobalAlphaFactorsSUN) +#define glGlobalAlphaFactorubSUN GLEW_GET_FUN(__glewGlobalAlphaFactorubSUN) +#define glGlobalAlphaFactoruiSUN GLEW_GET_FUN(__glewGlobalAlphaFactoruiSUN) +#define glGlobalAlphaFactorusSUN GLEW_GET_FUN(__glewGlobalAlphaFactorusSUN) + +#define GLEW_SUN_global_alpha GLEW_GET_VAR(__GLEW_SUN_global_alpha) + +#endif /* GL_SUN_global_alpha */ + +/* --------------------------- GL_SUN_mesh_array --------------------------- */ + +#ifndef GL_SUN_mesh_array +#define GL_SUN_mesh_array 1 + +#define GL_QUAD_MESH_SUN 0x8614 +#define GL_TRIANGLE_MESH_SUN 0x8615 + +#define GLEW_SUN_mesh_array GLEW_GET_VAR(__GLEW_SUN_mesh_array) + +#endif /* GL_SUN_mesh_array */ + +/* ------------------------ GL_SUN_read_video_pixels ----------------------- */ + +#ifndef GL_SUN_read_video_pixels +#define GL_SUN_read_video_pixels 1 + +typedef void (GLAPIENTRY * PFNGLREADVIDEOPIXELSSUNPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid* pixels); + +#define glReadVideoPixelsSUN GLEW_GET_FUN(__glewReadVideoPixelsSUN) + +#define GLEW_SUN_read_video_pixels GLEW_GET_VAR(__GLEW_SUN_read_video_pixels) + +#endif /* GL_SUN_read_video_pixels */ + +/* --------------------------- GL_SUN_slice_accum -------------------------- */ + +#ifndef GL_SUN_slice_accum +#define GL_SUN_slice_accum 1 + +#define GL_SLICE_ACCUM_SUN 0x85CC + +#define GLEW_SUN_slice_accum GLEW_GET_VAR(__GLEW_SUN_slice_accum) + +#endif /* GL_SUN_slice_accum */ + +/* -------------------------- GL_SUN_triangle_list ------------------------- */ + +#ifndef GL_SUN_triangle_list +#define GL_SUN_triangle_list 1 + +#define GL_RESTART_SUN 0x01 +#define GL_REPLACE_MIDDLE_SUN 0x02 +#define GL_REPLACE_OLDEST_SUN 0x03 +#define GL_TRIANGLE_LIST_SUN 0x81D7 +#define GL_REPLACEMENT_CODE_SUN 0x81D8 +#define GL_REPLACEMENT_CODE_ARRAY_SUN 0x85C0 +#define GL_REPLACEMENT_CODE_ARRAY_TYPE_SUN 0x85C1 +#define GL_REPLACEMENT_CODE_ARRAY_STRIDE_SUN 0x85C2 +#define GL_REPLACEMENT_CODE_ARRAY_POINTER_SUN 0x85C3 +#define GL_R1UI_V3F_SUN 0x85C4 +#define GL_R1UI_C4UB_V3F_SUN 0x85C5 +#define GL_R1UI_C3F_V3F_SUN 0x85C6 +#define GL_R1UI_N3F_V3F_SUN 0x85C7 +#define GL_R1UI_C4F_N3F_V3F_SUN 0x85C8 +#define GL_R1UI_T2F_V3F_SUN 0x85C9 +#define GL_R1UI_T2F_N3F_V3F_SUN 0x85CA +#define GL_R1UI_T2F_C4F_N3F_V3F_SUN 0x85CB + +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEPOINTERSUNPROC) (GLenum type, GLsizei stride, const void* pointer); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUBSUNPROC) (GLubyte code); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUBVSUNPROC) (const GLubyte* code); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUISUNPROC) (GLuint code); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVSUNPROC) (const GLuint* code); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUSSUNPROC) (GLushort code); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUSVSUNPROC) (const GLushort* code); + +#define glReplacementCodePointerSUN GLEW_GET_FUN(__glewReplacementCodePointerSUN) +#define glReplacementCodeubSUN GLEW_GET_FUN(__glewReplacementCodeubSUN) +#define glReplacementCodeubvSUN GLEW_GET_FUN(__glewReplacementCodeubvSUN) +#define glReplacementCodeuiSUN GLEW_GET_FUN(__glewReplacementCodeuiSUN) +#define glReplacementCodeuivSUN GLEW_GET_FUN(__glewReplacementCodeuivSUN) +#define glReplacementCodeusSUN GLEW_GET_FUN(__glewReplacementCodeusSUN) +#define glReplacementCodeusvSUN GLEW_GET_FUN(__glewReplacementCodeusvSUN) + +#define GLEW_SUN_triangle_list GLEW_GET_VAR(__GLEW_SUN_triangle_list) + +#endif /* GL_SUN_triangle_list */ + +/* ----------------------------- GL_SUN_vertex ----------------------------- */ + +#ifndef GL_SUN_vertex +#define GL_SUN_vertex 1 + +typedef void (GLAPIENTRY * PFNGLCOLOR3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLCOLOR3FVERTEX3FVSUNPROC) (const GLfloat* c, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* c, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX2FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y); +typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX2FVSUNPROC) (const GLubyte* c, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX3FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX3FVSUNPROC) (const GLubyte* c, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLNORMAL3FVERTEX3FSUNPROC) (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *c, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC) (GLuint rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC) (const GLuint* rc, const GLubyte *c, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC) (GLuint rc, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC) (const GLfloat* tc, const GLubyte *c, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +typedef void (GLAPIENTRY * PFNGLTEXCOORD2FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (GLAPIENTRY * PFNGLTEXCOORD4FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GLAPIENTRY * PFNGLTEXCOORD4FVERTEX4FVSUNPROC) (const GLfloat* tc, const GLfloat *v); + +#define glColor3fVertex3fSUN GLEW_GET_FUN(__glewColor3fVertex3fSUN) +#define glColor3fVertex3fvSUN GLEW_GET_FUN(__glewColor3fVertex3fvSUN) +#define glColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewColor4fNormal3fVertex3fSUN) +#define glColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewColor4fNormal3fVertex3fvSUN) +#define glColor4ubVertex2fSUN GLEW_GET_FUN(__glewColor4ubVertex2fSUN) +#define glColor4ubVertex2fvSUN GLEW_GET_FUN(__glewColor4ubVertex2fvSUN) +#define glColor4ubVertex3fSUN GLEW_GET_FUN(__glewColor4ubVertex3fSUN) +#define glColor4ubVertex3fvSUN GLEW_GET_FUN(__glewColor4ubVertex3fvSUN) +#define glNormal3fVertex3fSUN GLEW_GET_FUN(__glewNormal3fVertex3fSUN) +#define glNormal3fVertex3fvSUN GLEW_GET_FUN(__glewNormal3fVertex3fvSUN) +#define glReplacementCodeuiColor3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor3fVertex3fSUN) +#define glReplacementCodeuiColor3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor3fVertex3fvSUN) +#define glReplacementCodeuiColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4fNormal3fVertex3fSUN) +#define glReplacementCodeuiColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4fNormal3fVertex3fvSUN) +#define glReplacementCodeuiColor4ubVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4ubVertex3fSUN) +#define glReplacementCodeuiColor4ubVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4ubVertex3fvSUN) +#define glReplacementCodeuiNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiNormal3fVertex3fSUN) +#define glReplacementCodeuiNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiNormal3fVertex3fvSUN) +#define glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN) +#define glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN) +#define glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN) +#define glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN) +#define glReplacementCodeuiTexCoord2fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fVertex3fSUN) +#define glReplacementCodeuiTexCoord2fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fVertex3fvSUN) +#define glReplacementCodeuiVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiVertex3fSUN) +#define glReplacementCodeuiVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiVertex3fvSUN) +#define glTexCoord2fColor3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor3fVertex3fSUN) +#define glTexCoord2fColor3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor3fVertex3fvSUN) +#define glTexCoord2fColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor4fNormal3fVertex3fSUN) +#define glTexCoord2fColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor4fNormal3fVertex3fvSUN) +#define glTexCoord2fColor4ubVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor4ubVertex3fSUN) +#define glTexCoord2fColor4ubVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor4ubVertex3fvSUN) +#define glTexCoord2fNormal3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fNormal3fVertex3fSUN) +#define glTexCoord2fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fNormal3fVertex3fvSUN) +#define glTexCoord2fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fVertex3fSUN) +#define glTexCoord2fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fVertex3fvSUN) +#define glTexCoord4fColor4fNormal3fVertex4fSUN GLEW_GET_FUN(__glewTexCoord4fColor4fNormal3fVertex4fSUN) +#define glTexCoord4fColor4fNormal3fVertex4fvSUN GLEW_GET_FUN(__glewTexCoord4fColor4fNormal3fVertex4fvSUN) +#define glTexCoord4fVertex4fSUN GLEW_GET_FUN(__glewTexCoord4fVertex4fSUN) +#define glTexCoord4fVertex4fvSUN GLEW_GET_FUN(__glewTexCoord4fVertex4fvSUN) + +#define GLEW_SUN_vertex GLEW_GET_VAR(__GLEW_SUN_vertex) + +#endif /* GL_SUN_vertex */ + +/* -------------------------- GL_WIN_phong_shading ------------------------- */ + +#ifndef GL_WIN_phong_shading +#define GL_WIN_phong_shading 1 + +#define GL_PHONG_WIN 0x80EA +#define GL_PHONG_HINT_WIN 0x80EB + +#define GLEW_WIN_phong_shading GLEW_GET_VAR(__GLEW_WIN_phong_shading) + +#endif /* GL_WIN_phong_shading */ + +/* -------------------------- GL_WIN_specular_fog -------------------------- */ + +#ifndef GL_WIN_specular_fog +#define GL_WIN_specular_fog 1 + +#define GL_FOG_SPECULAR_TEXTURE_WIN 0x80EC + +#define GLEW_WIN_specular_fog GLEW_GET_VAR(__GLEW_WIN_specular_fog) + +#endif /* GL_WIN_specular_fog */ + +/* ---------------------------- GL_WIN_swap_hint --------------------------- */ + +#ifndef GL_WIN_swap_hint +#define GL_WIN_swap_hint 1 + +typedef void (GLAPIENTRY * PFNGLADDSWAPHINTRECTWINPROC) (GLint x, GLint y, GLsizei width, GLsizei height); + +#define glAddSwapHintRectWIN GLEW_GET_FUN(__glewAddSwapHintRectWIN) + +#define GLEW_WIN_swap_hint GLEW_GET_VAR(__GLEW_WIN_swap_hint) + +#endif /* GL_WIN_swap_hint */ + +/* ------------------------------------------------------------------------- */ + +#if defined(GLEW_MX) && defined(_WIN32) +#define GLEW_FUN_EXPORT +#else +#define GLEW_FUN_EXPORT GLEWAPI +#endif /* GLEW_MX */ + +#if defined(GLEW_MX) +#define GLEW_VAR_EXPORT +#else +#define GLEW_VAR_EXPORT GLEWAPI +#endif /* GLEW_MX */ + +#if defined(GLEW_MX) && defined(_WIN32) +struct GLEWContextStruct +{ +#endif /* GLEW_MX */ + +GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE3DPROC __glewCopyTexSubImage3D; +GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSPROC __glewDrawRangeElements; +GLEW_FUN_EXPORT PFNGLTEXIMAGE3DPROC __glewTexImage3D; +GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE3DPROC __glewTexSubImage3D; + +GLEW_FUN_EXPORT PFNGLACTIVETEXTUREPROC __glewActiveTexture; +GLEW_FUN_EXPORT PFNGLCLIENTACTIVETEXTUREPROC __glewClientActiveTexture; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE1DPROC __glewCompressedTexImage1D; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE2DPROC __glewCompressedTexImage2D; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE3DPROC __glewCompressedTexImage3D; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC __glewCompressedTexSubImage1D; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC __glewCompressedTexSubImage2D; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC __glewCompressedTexSubImage3D; +GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXIMAGEPROC __glewGetCompressedTexImage; +GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXDPROC __glewLoadTransposeMatrixd; +GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXFPROC __glewLoadTransposeMatrixf; +GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXDPROC __glewMultTransposeMatrixd; +GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXFPROC __glewMultTransposeMatrixf; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DPROC __glewMultiTexCoord1d; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DVPROC __glewMultiTexCoord1dv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FPROC __glewMultiTexCoord1f; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FVPROC __glewMultiTexCoord1fv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IPROC __glewMultiTexCoord1i; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IVPROC __glewMultiTexCoord1iv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SPROC __glewMultiTexCoord1s; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SVPROC __glewMultiTexCoord1sv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DPROC __glewMultiTexCoord2d; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DVPROC __glewMultiTexCoord2dv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FPROC __glewMultiTexCoord2f; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FVPROC __glewMultiTexCoord2fv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IPROC __glewMultiTexCoord2i; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IVPROC __glewMultiTexCoord2iv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SPROC __glewMultiTexCoord2s; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SVPROC __glewMultiTexCoord2sv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DPROC __glewMultiTexCoord3d; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DVPROC __glewMultiTexCoord3dv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FPROC __glewMultiTexCoord3f; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FVPROC __glewMultiTexCoord3fv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IPROC __glewMultiTexCoord3i; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IVPROC __glewMultiTexCoord3iv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SPROC __glewMultiTexCoord3s; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SVPROC __glewMultiTexCoord3sv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DPROC __glewMultiTexCoord4d; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DVPROC __glewMultiTexCoord4dv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FPROC __glewMultiTexCoord4f; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FVPROC __glewMultiTexCoord4fv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IPROC __glewMultiTexCoord4i; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IVPROC __glewMultiTexCoord4iv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SPROC __glewMultiTexCoord4s; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SVPROC __glewMultiTexCoord4sv; +GLEW_FUN_EXPORT PFNGLSAMPLECOVERAGEPROC __glewSampleCoverage; + +GLEW_FUN_EXPORT PFNGLBLENDCOLORPROC __glewBlendColor; +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONPROC __glewBlendEquation; +GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEPROC __glewBlendFuncSeparate; +GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTERPROC __glewFogCoordPointer; +GLEW_FUN_EXPORT PFNGLFOGCOORDDPROC __glewFogCoordd; +GLEW_FUN_EXPORT PFNGLFOGCOORDDVPROC __glewFogCoorddv; +GLEW_FUN_EXPORT PFNGLFOGCOORDFPROC __glewFogCoordf; +GLEW_FUN_EXPORT PFNGLFOGCOORDFVPROC __glewFogCoordfv; +GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSPROC __glewMultiDrawArrays; +GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSPROC __glewMultiDrawElements; +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFPROC __glewPointParameterf; +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVPROC __glewPointParameterfv; +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIPROC __glewPointParameteri; +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIVPROC __glewPointParameteriv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BPROC __glewSecondaryColor3b; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BVPROC __glewSecondaryColor3bv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DPROC __glewSecondaryColor3d; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DVPROC __glewSecondaryColor3dv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FPROC __glewSecondaryColor3f; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FVPROC __glewSecondaryColor3fv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IPROC __glewSecondaryColor3i; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IVPROC __glewSecondaryColor3iv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SPROC __glewSecondaryColor3s; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SVPROC __glewSecondaryColor3sv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBPROC __glewSecondaryColor3ub; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBVPROC __glewSecondaryColor3ubv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIPROC __glewSecondaryColor3ui; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIVPROC __glewSecondaryColor3uiv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USPROC __glewSecondaryColor3us; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USVPROC __glewSecondaryColor3usv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTERPROC __glewSecondaryColorPointer; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2DPROC __glewWindowPos2d; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVPROC __glewWindowPos2dv; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2FPROC __glewWindowPos2f; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVPROC __glewWindowPos2fv; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2IPROC __glewWindowPos2i; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVPROC __glewWindowPos2iv; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2SPROC __glewWindowPos2s; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVPROC __glewWindowPos2sv; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3DPROC __glewWindowPos3d; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVPROC __glewWindowPos3dv; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3FPROC __glewWindowPos3f; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVPROC __glewWindowPos3fv; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3IPROC __glewWindowPos3i; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVPROC __glewWindowPos3iv; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3SPROC __glewWindowPos3s; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVPROC __glewWindowPos3sv; + +GLEW_FUN_EXPORT PFNGLBEGINQUERYPROC __glewBeginQuery; +GLEW_FUN_EXPORT PFNGLBINDBUFFERPROC __glewBindBuffer; +GLEW_FUN_EXPORT PFNGLBUFFERDATAPROC __glewBufferData; +GLEW_FUN_EXPORT PFNGLBUFFERSUBDATAPROC __glewBufferSubData; +GLEW_FUN_EXPORT PFNGLDELETEBUFFERSPROC __glewDeleteBuffers; +GLEW_FUN_EXPORT PFNGLDELETEQUERIESPROC __glewDeleteQueries; +GLEW_FUN_EXPORT PFNGLENDQUERYPROC __glewEndQuery; +GLEW_FUN_EXPORT PFNGLGENBUFFERSPROC __glewGenBuffers; +GLEW_FUN_EXPORT PFNGLGENQUERIESPROC __glewGenQueries; +GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERIVPROC __glewGetBufferParameteriv; +GLEW_FUN_EXPORT PFNGLGETBUFFERPOINTERVPROC __glewGetBufferPointerv; +GLEW_FUN_EXPORT PFNGLGETBUFFERSUBDATAPROC __glewGetBufferSubData; +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTIVPROC __glewGetQueryObjectiv; +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUIVPROC __glewGetQueryObjectuiv; +GLEW_FUN_EXPORT PFNGLGETQUERYIVPROC __glewGetQueryiv; +GLEW_FUN_EXPORT PFNGLISBUFFERPROC __glewIsBuffer; +GLEW_FUN_EXPORT PFNGLISQUERYPROC __glewIsQuery; +GLEW_FUN_EXPORT PFNGLMAPBUFFERPROC __glewMapBuffer; +GLEW_FUN_EXPORT PFNGLUNMAPBUFFERPROC __glewUnmapBuffer; + +GLEW_FUN_EXPORT PFNGLATTACHSHADERPROC __glewAttachShader; +GLEW_FUN_EXPORT PFNGLBINDATTRIBLOCATIONPROC __glewBindAttribLocation; +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEPROC __glewBlendEquationSeparate; +GLEW_FUN_EXPORT PFNGLCOMPILESHADERPROC __glewCompileShader; +GLEW_FUN_EXPORT PFNGLCREATEPROGRAMPROC __glewCreateProgram; +GLEW_FUN_EXPORT PFNGLCREATESHADERPROC __glewCreateShader; +GLEW_FUN_EXPORT PFNGLDELETEPROGRAMPROC __glewDeleteProgram; +GLEW_FUN_EXPORT PFNGLDELETESHADERPROC __glewDeleteShader; +GLEW_FUN_EXPORT PFNGLDETACHSHADERPROC __glewDetachShader; +GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBARRAYPROC __glewDisableVertexAttribArray; +GLEW_FUN_EXPORT PFNGLDRAWBUFFERSPROC __glewDrawBuffers; +GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBARRAYPROC __glewEnableVertexAttribArray; +GLEW_FUN_EXPORT PFNGLGETACTIVEATTRIBPROC __glewGetActiveAttrib; +GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMPROC __glewGetActiveUniform; +GLEW_FUN_EXPORT PFNGLGETATTACHEDSHADERSPROC __glewGetAttachedShaders; +GLEW_FUN_EXPORT PFNGLGETATTRIBLOCATIONPROC __glewGetAttribLocation; +GLEW_FUN_EXPORT PFNGLGETPROGRAMINFOLOGPROC __glewGetProgramInfoLog; +GLEW_FUN_EXPORT PFNGLGETPROGRAMIVPROC __glewGetProgramiv; +GLEW_FUN_EXPORT PFNGLGETSHADERINFOLOGPROC __glewGetShaderInfoLog; +GLEW_FUN_EXPORT PFNGLGETSHADERSOURCEPROC __glewGetShaderSource; +GLEW_FUN_EXPORT PFNGLGETSHADERIVPROC __glewGetShaderiv; +GLEW_FUN_EXPORT PFNGLGETUNIFORMLOCATIONPROC __glewGetUniformLocation; +GLEW_FUN_EXPORT PFNGLGETUNIFORMFVPROC __glewGetUniformfv; +GLEW_FUN_EXPORT PFNGLGETUNIFORMIVPROC __glewGetUniformiv; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVPROC __glewGetVertexAttribPointerv; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVPROC __glewGetVertexAttribdv; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVPROC __glewGetVertexAttribfv; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVPROC __glewGetVertexAttribiv; +GLEW_FUN_EXPORT PFNGLISPROGRAMPROC __glewIsProgram; +GLEW_FUN_EXPORT PFNGLISSHADERPROC __glewIsShader; +GLEW_FUN_EXPORT PFNGLLINKPROGRAMPROC __glewLinkProgram; +GLEW_FUN_EXPORT PFNGLSHADERSOURCEPROC __glewShaderSource; +GLEW_FUN_EXPORT PFNGLSTENCILFUNCSEPARATEPROC __glewStencilFuncSeparate; +GLEW_FUN_EXPORT PFNGLSTENCILMASKSEPARATEPROC __glewStencilMaskSeparate; +GLEW_FUN_EXPORT PFNGLSTENCILOPSEPARATEPROC __glewStencilOpSeparate; +GLEW_FUN_EXPORT PFNGLUNIFORM1FPROC __glewUniform1f; +GLEW_FUN_EXPORT PFNGLUNIFORM1FVPROC __glewUniform1fv; +GLEW_FUN_EXPORT PFNGLUNIFORM1IPROC __glewUniform1i; +GLEW_FUN_EXPORT PFNGLUNIFORM1IVPROC __glewUniform1iv; +GLEW_FUN_EXPORT PFNGLUNIFORM2FPROC __glewUniform2f; +GLEW_FUN_EXPORT PFNGLUNIFORM2FVPROC __glewUniform2fv; +GLEW_FUN_EXPORT PFNGLUNIFORM2IPROC __glewUniform2i; +GLEW_FUN_EXPORT PFNGLUNIFORM2IVPROC __glewUniform2iv; +GLEW_FUN_EXPORT PFNGLUNIFORM3FPROC __glewUniform3f; +GLEW_FUN_EXPORT PFNGLUNIFORM3FVPROC __glewUniform3fv; +GLEW_FUN_EXPORT PFNGLUNIFORM3IPROC __glewUniform3i; +GLEW_FUN_EXPORT PFNGLUNIFORM3IVPROC __glewUniform3iv; +GLEW_FUN_EXPORT PFNGLUNIFORM4FPROC __glewUniform4f; +GLEW_FUN_EXPORT PFNGLUNIFORM4FVPROC __glewUniform4fv; +GLEW_FUN_EXPORT PFNGLUNIFORM4IPROC __glewUniform4i; +GLEW_FUN_EXPORT PFNGLUNIFORM4IVPROC __glewUniform4iv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2FVPROC __glewUniformMatrix2fv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3FVPROC __glewUniformMatrix3fv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4FVPROC __glewUniformMatrix4fv; +GLEW_FUN_EXPORT PFNGLUSEPROGRAMPROC __glewUseProgram; +GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMPROC __glewValidateProgram; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DPROC __glewVertexAttrib1d; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVPROC __glewVertexAttrib1dv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FPROC __glewVertexAttrib1f; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVPROC __glewVertexAttrib1fv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SPROC __glewVertexAttrib1s; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVPROC __glewVertexAttrib1sv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DPROC __glewVertexAttrib2d; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVPROC __glewVertexAttrib2dv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FPROC __glewVertexAttrib2f; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVPROC __glewVertexAttrib2fv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SPROC __glewVertexAttrib2s; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVPROC __glewVertexAttrib2sv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DPROC __glewVertexAttrib3d; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVPROC __glewVertexAttrib3dv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FPROC __glewVertexAttrib3f; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVPROC __glewVertexAttrib3fv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SPROC __glewVertexAttrib3s; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVPROC __glewVertexAttrib3sv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NBVPROC __glewVertexAttrib4Nbv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NIVPROC __glewVertexAttrib4Niv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NSVPROC __glewVertexAttrib4Nsv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBPROC __glewVertexAttrib4Nub; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBVPROC __glewVertexAttrib4Nubv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUIVPROC __glewVertexAttrib4Nuiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUSVPROC __glewVertexAttrib4Nusv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4BVPROC __glewVertexAttrib4bv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DPROC __glewVertexAttrib4d; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVPROC __glewVertexAttrib4dv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FPROC __glewVertexAttrib4f; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVPROC __glewVertexAttrib4fv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4IVPROC __glewVertexAttrib4iv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SPROC __glewVertexAttrib4s; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVPROC __glewVertexAttrib4sv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVPROC __glewVertexAttrib4ubv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UIVPROC __glewVertexAttrib4uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4USVPROC __glewVertexAttrib4usv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERPROC __glewVertexAttribPointer; + +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X3FVPROC __glewUniformMatrix2x3fv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X4FVPROC __glewUniformMatrix2x4fv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X2FVPROC __glewUniformMatrix3x2fv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X4FVPROC __glewUniformMatrix3x4fv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X2FVPROC __glewUniformMatrix4x2fv; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X3FVPROC __glewUniformMatrix4x3fv; + +GLEW_FUN_EXPORT PFNGLBEGINCONDITIONALRENDERPROC __glewBeginConditionalRender; +GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKPROC __glewBeginTransformFeedback; +GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONPROC __glewBindFragDataLocation; +GLEW_FUN_EXPORT PFNGLCLAMPCOLORPROC __glewClampColor; +GLEW_FUN_EXPORT PFNGLCLEARBUFFERFIPROC __glewClearBufferfi; +GLEW_FUN_EXPORT PFNGLCLEARBUFFERFVPROC __glewClearBufferfv; +GLEW_FUN_EXPORT PFNGLCLEARBUFFERIVPROC __glewClearBufferiv; +GLEW_FUN_EXPORT PFNGLCLEARBUFFERUIVPROC __glewClearBufferuiv; +GLEW_FUN_EXPORT PFNGLCOLORMASKIPROC __glewColorMaski; +GLEW_FUN_EXPORT PFNGLDISABLEIPROC __glewDisablei; +GLEW_FUN_EXPORT PFNGLENABLEIPROC __glewEnablei; +GLEW_FUN_EXPORT PFNGLENDCONDITIONALRENDERPROC __glewEndConditionalRender; +GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKPROC __glewEndTransformFeedback; +GLEW_FUN_EXPORT PFNGLGETBOOLEANI_VPROC __glewGetBooleani_v; +GLEW_FUN_EXPORT PFNGLGETFRAGDATALOCATIONPROC __glewGetFragDataLocation; +GLEW_FUN_EXPORT PFNGLGETSTRINGIPROC __glewGetStringi; +GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIIVPROC __glewGetTexParameterIiv; +GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIUIVPROC __glewGetTexParameterIuiv; +GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGPROC __glewGetTransformFeedbackVarying; +GLEW_FUN_EXPORT PFNGLGETUNIFORMUIVPROC __glewGetUniformuiv; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIIVPROC __glewGetVertexAttribIiv; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIUIVPROC __glewGetVertexAttribIuiv; +GLEW_FUN_EXPORT PFNGLISENABLEDIPROC __glewIsEnabledi; +GLEW_FUN_EXPORT PFNGLTEXPARAMETERIIVPROC __glewTexParameterIiv; +GLEW_FUN_EXPORT PFNGLTEXPARAMETERIUIVPROC __glewTexParameterIuiv; +GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSPROC __glewTransformFeedbackVaryings; +GLEW_FUN_EXPORT PFNGLUNIFORM1UIPROC __glewUniform1ui; +GLEW_FUN_EXPORT PFNGLUNIFORM1UIVPROC __glewUniform1uiv; +GLEW_FUN_EXPORT PFNGLUNIFORM2UIPROC __glewUniform2ui; +GLEW_FUN_EXPORT PFNGLUNIFORM2UIVPROC __glewUniform2uiv; +GLEW_FUN_EXPORT PFNGLUNIFORM3UIPROC __glewUniform3ui; +GLEW_FUN_EXPORT PFNGLUNIFORM3UIVPROC __glewUniform3uiv; +GLEW_FUN_EXPORT PFNGLUNIFORM4UIPROC __glewUniform4ui; +GLEW_FUN_EXPORT PFNGLUNIFORM4UIVPROC __glewUniform4uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IPROC __glewVertexAttribI1i; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IVPROC __glewVertexAttribI1iv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIPROC __glewVertexAttribI1ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIVPROC __glewVertexAttribI1uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IPROC __glewVertexAttribI2i; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IVPROC __glewVertexAttribI2iv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIPROC __glewVertexAttribI2ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIVPROC __glewVertexAttribI2uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IPROC __glewVertexAttribI3i; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IVPROC __glewVertexAttribI3iv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIPROC __glewVertexAttribI3ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIVPROC __glewVertexAttribI3uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4BVPROC __glewVertexAttribI4bv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IPROC __glewVertexAttribI4i; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IVPROC __glewVertexAttribI4iv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4SVPROC __glewVertexAttribI4sv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UBVPROC __glewVertexAttribI4ubv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIPROC __glewVertexAttribI4ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIVPROC __glewVertexAttribI4uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4USVPROC __glewVertexAttribI4usv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIPOINTERPROC __glewVertexAttribIPointer; + +GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDPROC __glewDrawArraysInstanced; +GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDPROC __glewDrawElementsInstanced; +GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTINDEXPROC __glewPrimitiveRestartIndex; +GLEW_FUN_EXPORT PFNGLTEXBUFFERPROC __glewTexBuffer; + +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREPROC __glewFramebufferTexture; +GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERI64VPROC __glewGetBufferParameteri64v; +GLEW_FUN_EXPORT PFNGLGETINTEGER64I_VPROC __glewGetInteger64i_v; + +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEIPROC __glewBlendEquationSeparatei; +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONIPROC __glewBlendEquationi; +GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEIPROC __glewBlendFuncSeparatei; +GLEW_FUN_EXPORT PFNGLBLENDFUNCIPROC __glewBlendFunci; +GLEW_FUN_EXPORT PFNGLMINSAMPLESHADINGPROC __glewMinSampleShading; + +GLEW_FUN_EXPORT PFNGLTBUFFERMASK3DFXPROC __glewTbufferMask3DFX; + +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONINDEXEDAMDPROC __glewBlendEquationIndexedAMD; +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC __glewBlendEquationSeparateIndexedAMD; +GLEW_FUN_EXPORT PFNGLBLENDFUNCINDEXEDAMDPROC __glewBlendFuncIndexedAMD; +GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC __glewBlendFuncSeparateIndexedAMD; + +GLEW_FUN_EXPORT PFNGLBEGINPERFMONITORAMDPROC __glewBeginPerfMonitorAMD; +GLEW_FUN_EXPORT PFNGLDELETEPERFMONITORSAMDPROC __glewDeletePerfMonitorsAMD; +GLEW_FUN_EXPORT PFNGLENDPERFMONITORAMDPROC __glewEndPerfMonitorAMD; +GLEW_FUN_EXPORT PFNGLGENPERFMONITORSAMDPROC __glewGenPerfMonitorsAMD; +GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERDATAAMDPROC __glewGetPerfMonitorCounterDataAMD; +GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERINFOAMDPROC __glewGetPerfMonitorCounterInfoAMD; +GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC __glewGetPerfMonitorCounterStringAMD; +GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERSAMDPROC __glewGetPerfMonitorCountersAMD; +GLEW_FUN_EXPORT PFNGLGETPERFMONITORGROUPSTRINGAMDPROC __glewGetPerfMonitorGroupStringAMD; +GLEW_FUN_EXPORT PFNGLGETPERFMONITORGROUPSAMDPROC __glewGetPerfMonitorGroupsAMD; +GLEW_FUN_EXPORT PFNGLSELECTPERFMONITORCOUNTERSAMDPROC __glewSelectPerfMonitorCountersAMD; + +GLEW_FUN_EXPORT PFNGLTESSELLATIONFACTORAMDPROC __glewTessellationFactorAMD; +GLEW_FUN_EXPORT PFNGLTESSELLATIONMODEAMDPROC __glewTessellationModeAMD; + +GLEW_FUN_EXPORT PFNGLDRAWELEMENTARRAYAPPLEPROC __glewDrawElementArrayAPPLE; +GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC __glewDrawRangeElementArrayAPPLE; +GLEW_FUN_EXPORT PFNGLELEMENTPOINTERAPPLEPROC __glewElementPointerAPPLE; +GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC __glewMultiDrawElementArrayAPPLE; +GLEW_FUN_EXPORT PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC __glewMultiDrawRangeElementArrayAPPLE; + +GLEW_FUN_EXPORT PFNGLDELETEFENCESAPPLEPROC __glewDeleteFencesAPPLE; +GLEW_FUN_EXPORT PFNGLFINISHFENCEAPPLEPROC __glewFinishFenceAPPLE; +GLEW_FUN_EXPORT PFNGLFINISHOBJECTAPPLEPROC __glewFinishObjectAPPLE; +GLEW_FUN_EXPORT PFNGLGENFENCESAPPLEPROC __glewGenFencesAPPLE; +GLEW_FUN_EXPORT PFNGLISFENCEAPPLEPROC __glewIsFenceAPPLE; +GLEW_FUN_EXPORT PFNGLSETFENCEAPPLEPROC __glewSetFenceAPPLE; +GLEW_FUN_EXPORT PFNGLTESTFENCEAPPLEPROC __glewTestFenceAPPLE; +GLEW_FUN_EXPORT PFNGLTESTOBJECTAPPLEPROC __glewTestObjectAPPLE; + +GLEW_FUN_EXPORT PFNGLBUFFERPARAMETERIAPPLEPROC __glewBufferParameteriAPPLE; +GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC __glewFlushMappedBufferRangeAPPLE; + +GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERIVAPPLEPROC __glewGetObjectParameterivAPPLE; +GLEW_FUN_EXPORT PFNGLOBJECTPURGEABLEAPPLEPROC __glewObjectPurgeableAPPLE; +GLEW_FUN_EXPORT PFNGLOBJECTUNPURGEABLEAPPLEPROC __glewObjectUnpurgeableAPPLE; + +GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC __glewGetTexParameterPointervAPPLE; +GLEW_FUN_EXPORT PFNGLTEXTURERANGEAPPLEPROC __glewTextureRangeAPPLE; + +GLEW_FUN_EXPORT PFNGLBINDVERTEXARRAYAPPLEPROC __glewBindVertexArrayAPPLE; +GLEW_FUN_EXPORT PFNGLDELETEVERTEXARRAYSAPPLEPROC __glewDeleteVertexArraysAPPLE; +GLEW_FUN_EXPORT PFNGLGENVERTEXARRAYSAPPLEPROC __glewGenVertexArraysAPPLE; +GLEW_FUN_EXPORT PFNGLISVERTEXARRAYAPPLEPROC __glewIsVertexArrayAPPLE; + +GLEW_FUN_EXPORT PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC __glewFlushVertexArrayRangeAPPLE; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYPARAMETERIAPPLEPROC __glewVertexArrayParameteriAPPLE; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYRANGEAPPLEPROC __glewVertexArrayRangeAPPLE; + +GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBAPPLEPROC __glewDisableVertexAttribAPPLE; +GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBAPPLEPROC __glewEnableVertexAttribAPPLE; +GLEW_FUN_EXPORT PFNGLISVERTEXATTRIBENABLEDAPPLEPROC __glewIsVertexAttribEnabledAPPLE; +GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB1DAPPLEPROC __glewMapVertexAttrib1dAPPLE; +GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB1FAPPLEPROC __glewMapVertexAttrib1fAPPLE; +GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB2DAPPLEPROC __glewMapVertexAttrib2dAPPLE; +GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB2FAPPLEPROC __glewMapVertexAttrib2fAPPLE; + +GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONINDEXEDPROC __glewBindFragDataLocationIndexed; +GLEW_FUN_EXPORT PFNGLGETFRAGDATAINDEXPROC __glewGetFragDataIndex; + +GLEW_FUN_EXPORT PFNGLCLAMPCOLORARBPROC __glewClampColorARB; + +GLEW_FUN_EXPORT PFNGLCOPYBUFFERSUBDATAPROC __glewCopyBufferSubData; + +GLEW_FUN_EXPORT PFNGLDRAWBUFFERSARBPROC __glewDrawBuffersARB; + +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEIARBPROC __glewBlendEquationSeparateiARB; +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONIARBPROC __glewBlendEquationiARB; +GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEIARBPROC __glewBlendFuncSeparateiARB; +GLEW_FUN_EXPORT PFNGLBLENDFUNCIARBPROC __glewBlendFunciARB; + +GLEW_FUN_EXPORT PFNGLDRAWELEMENTSBASEVERTEXPROC __glewDrawElementsBaseVertex; +GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC __glewDrawElementsInstancedBaseVertex; +GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC __glewDrawRangeElementsBaseVertex; +GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC __glewMultiDrawElementsBaseVertex; + +GLEW_FUN_EXPORT PFNGLDRAWARRAYSINDIRECTPROC __glewDrawArraysIndirect; +GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINDIRECTPROC __glewDrawElementsIndirect; + +GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDARBPROC __glewDrawArraysInstancedARB; +GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDARBPROC __glewDrawElementsInstancedARB; + +GLEW_FUN_EXPORT PFNGLBINDFRAMEBUFFERPROC __glewBindFramebuffer; +GLEW_FUN_EXPORT PFNGLBINDRENDERBUFFERPROC __glewBindRenderbuffer; +GLEW_FUN_EXPORT PFNGLBLITFRAMEBUFFERPROC __glewBlitFramebuffer; +GLEW_FUN_EXPORT PFNGLCHECKFRAMEBUFFERSTATUSPROC __glewCheckFramebufferStatus; +GLEW_FUN_EXPORT PFNGLDELETEFRAMEBUFFERSPROC __glewDeleteFramebuffers; +GLEW_FUN_EXPORT PFNGLDELETERENDERBUFFERSPROC __glewDeleteRenderbuffers; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERRENDERBUFFERPROC __glewFramebufferRenderbuffer; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE1DPROC __glewFramebufferTexture1D; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE2DPROC __glewFramebufferTexture2D; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE3DPROC __glewFramebufferTexture3D; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYERPROC __glewFramebufferTextureLayer; +GLEW_FUN_EXPORT PFNGLGENFRAMEBUFFERSPROC __glewGenFramebuffers; +GLEW_FUN_EXPORT PFNGLGENRENDERBUFFERSPROC __glewGenRenderbuffers; +GLEW_FUN_EXPORT PFNGLGENERATEMIPMAPPROC __glewGenerateMipmap; +GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC __glewGetFramebufferAttachmentParameteriv; +GLEW_FUN_EXPORT PFNGLGETRENDERBUFFERPARAMETERIVPROC __glewGetRenderbufferParameteriv; +GLEW_FUN_EXPORT PFNGLISFRAMEBUFFERPROC __glewIsFramebuffer; +GLEW_FUN_EXPORT PFNGLISRENDERBUFFERPROC __glewIsRenderbuffer; +GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEPROC __glewRenderbufferStorage; +GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC __glewRenderbufferStorageMultisample; + +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREARBPROC __glewFramebufferTextureARB; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREFACEARBPROC __glewFramebufferTextureFaceARB; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYERARBPROC __glewFramebufferTextureLayerARB; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIARBPROC __glewProgramParameteriARB; + +GLEW_FUN_EXPORT PFNGLCOLORSUBTABLEPROC __glewColorSubTable; +GLEW_FUN_EXPORT PFNGLCOLORTABLEPROC __glewColorTable; +GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERFVPROC __glewColorTableParameterfv; +GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERIVPROC __glewColorTableParameteriv; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER1DPROC __glewConvolutionFilter1D; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER2DPROC __glewConvolutionFilter2D; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFPROC __glewConvolutionParameterf; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFVPROC __glewConvolutionParameterfv; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIPROC __glewConvolutionParameteri; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIVPROC __glewConvolutionParameteriv; +GLEW_FUN_EXPORT PFNGLCOPYCOLORSUBTABLEPROC __glewCopyColorSubTable; +GLEW_FUN_EXPORT PFNGLCOPYCOLORTABLEPROC __glewCopyColorTable; +GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER1DPROC __glewCopyConvolutionFilter1D; +GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER2DPROC __glewCopyConvolutionFilter2D; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPROC __glewGetColorTable; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVPROC __glewGetColorTableParameterfv; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVPROC __glewGetColorTableParameteriv; +GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONFILTERPROC __glewGetConvolutionFilter; +GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERFVPROC __glewGetConvolutionParameterfv; +GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERIVPROC __glewGetConvolutionParameteriv; +GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPROC __glewGetHistogram; +GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERFVPROC __glewGetHistogramParameterfv; +GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERIVPROC __glewGetHistogramParameteriv; +GLEW_FUN_EXPORT PFNGLGETMINMAXPROC __glewGetMinmax; +GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERFVPROC __glewGetMinmaxParameterfv; +GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERIVPROC __glewGetMinmaxParameteriv; +GLEW_FUN_EXPORT PFNGLGETSEPARABLEFILTERPROC __glewGetSeparableFilter; +GLEW_FUN_EXPORT PFNGLHISTOGRAMPROC __glewHistogram; +GLEW_FUN_EXPORT PFNGLMINMAXPROC __glewMinmax; +GLEW_FUN_EXPORT PFNGLRESETHISTOGRAMPROC __glewResetHistogram; +GLEW_FUN_EXPORT PFNGLRESETMINMAXPROC __glewResetMinmax; +GLEW_FUN_EXPORT PFNGLSEPARABLEFILTER2DPROC __glewSeparableFilter2D; + +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBDIVISORARBPROC __glewVertexAttribDivisorARB; + +GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDBUFFERRANGEPROC __glewFlushMappedBufferRange; +GLEW_FUN_EXPORT PFNGLMAPBUFFERRANGEPROC __glewMapBufferRange; + +GLEW_FUN_EXPORT PFNGLCURRENTPALETTEMATRIXARBPROC __glewCurrentPaletteMatrixARB; +GLEW_FUN_EXPORT PFNGLMATRIXINDEXPOINTERARBPROC __glewMatrixIndexPointerARB; +GLEW_FUN_EXPORT PFNGLMATRIXINDEXUBVARBPROC __glewMatrixIndexubvARB; +GLEW_FUN_EXPORT PFNGLMATRIXINDEXUIVARBPROC __glewMatrixIndexuivARB; +GLEW_FUN_EXPORT PFNGLMATRIXINDEXUSVARBPROC __glewMatrixIndexusvARB; + +GLEW_FUN_EXPORT PFNGLSAMPLECOVERAGEARBPROC __glewSampleCoverageARB; + +GLEW_FUN_EXPORT PFNGLACTIVETEXTUREARBPROC __glewActiveTextureARB; +GLEW_FUN_EXPORT PFNGLCLIENTACTIVETEXTUREARBPROC __glewClientActiveTextureARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DARBPROC __glewMultiTexCoord1dARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DVARBPROC __glewMultiTexCoord1dvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FARBPROC __glewMultiTexCoord1fARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FVARBPROC __glewMultiTexCoord1fvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IARBPROC __glewMultiTexCoord1iARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IVARBPROC __glewMultiTexCoord1ivARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SARBPROC __glewMultiTexCoord1sARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SVARBPROC __glewMultiTexCoord1svARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DARBPROC __glewMultiTexCoord2dARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DVARBPROC __glewMultiTexCoord2dvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FARBPROC __glewMultiTexCoord2fARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FVARBPROC __glewMultiTexCoord2fvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IARBPROC __glewMultiTexCoord2iARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IVARBPROC __glewMultiTexCoord2ivARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SARBPROC __glewMultiTexCoord2sARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SVARBPROC __glewMultiTexCoord2svARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DARBPROC __glewMultiTexCoord3dARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DVARBPROC __glewMultiTexCoord3dvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FARBPROC __glewMultiTexCoord3fARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FVARBPROC __glewMultiTexCoord3fvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IARBPROC __glewMultiTexCoord3iARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IVARBPROC __glewMultiTexCoord3ivARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SARBPROC __glewMultiTexCoord3sARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SVARBPROC __glewMultiTexCoord3svARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DARBPROC __glewMultiTexCoord4dARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DVARBPROC __glewMultiTexCoord4dvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FARBPROC __glewMultiTexCoord4fARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FVARBPROC __glewMultiTexCoord4fvARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IARBPROC __glewMultiTexCoord4iARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IVARBPROC __glewMultiTexCoord4ivARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SARBPROC __glewMultiTexCoord4sARB; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SVARBPROC __glewMultiTexCoord4svARB; + +GLEW_FUN_EXPORT PFNGLBEGINQUERYARBPROC __glewBeginQueryARB; +GLEW_FUN_EXPORT PFNGLDELETEQUERIESARBPROC __glewDeleteQueriesARB; +GLEW_FUN_EXPORT PFNGLENDQUERYARBPROC __glewEndQueryARB; +GLEW_FUN_EXPORT PFNGLGENQUERIESARBPROC __glewGenQueriesARB; +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTIVARBPROC __glewGetQueryObjectivARB; +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUIVARBPROC __glewGetQueryObjectuivARB; +GLEW_FUN_EXPORT PFNGLGETQUERYIVARBPROC __glewGetQueryivARB; +GLEW_FUN_EXPORT PFNGLISQUERYARBPROC __glewIsQueryARB; + +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFARBPROC __glewPointParameterfARB; +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVARBPROC __glewPointParameterfvARB; + +GLEW_FUN_EXPORT PFNGLPROVOKINGVERTEXPROC __glewProvokingVertex; + +GLEW_FUN_EXPORT PFNGLMINSAMPLESHADINGARBPROC __glewMinSampleShadingARB; + +GLEW_FUN_EXPORT PFNGLBINDSAMPLERPROC __glewBindSampler; +GLEW_FUN_EXPORT PFNGLDELETESAMPLERSPROC __glewDeleteSamplers; +GLEW_FUN_EXPORT PFNGLGENSAMPLERSPROC __glewGenSamplers; +GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIIVPROC __glewGetSamplerParameterIiv; +GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIUIVPROC __glewGetSamplerParameterIuiv; +GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERFVPROC __glewGetSamplerParameterfv; +GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIVPROC __glewGetSamplerParameteriv; +GLEW_FUN_EXPORT PFNGLISSAMPLERPROC __glewIsSampler; +GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIIVPROC __glewSamplerParameterIiv; +GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIUIVPROC __glewSamplerParameterIuiv; +GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERFPROC __glewSamplerParameterf; +GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERFVPROC __glewSamplerParameterfv; +GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIPROC __glewSamplerParameteri; +GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIVPROC __glewSamplerParameteriv; + +GLEW_FUN_EXPORT PFNGLATTACHOBJECTARBPROC __glewAttachObjectARB; +GLEW_FUN_EXPORT PFNGLCOMPILESHADERARBPROC __glewCompileShaderARB; +GLEW_FUN_EXPORT PFNGLCREATEPROGRAMOBJECTARBPROC __glewCreateProgramObjectARB; +GLEW_FUN_EXPORT PFNGLCREATESHADEROBJECTARBPROC __glewCreateShaderObjectARB; +GLEW_FUN_EXPORT PFNGLDELETEOBJECTARBPROC __glewDeleteObjectARB; +GLEW_FUN_EXPORT PFNGLDETACHOBJECTARBPROC __glewDetachObjectARB; +GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMARBPROC __glewGetActiveUniformARB; +GLEW_FUN_EXPORT PFNGLGETATTACHEDOBJECTSARBPROC __glewGetAttachedObjectsARB; +GLEW_FUN_EXPORT PFNGLGETHANDLEARBPROC __glewGetHandleARB; +GLEW_FUN_EXPORT PFNGLGETINFOLOGARBPROC __glewGetInfoLogARB; +GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERFVARBPROC __glewGetObjectParameterfvARB; +GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERIVARBPROC __glewGetObjectParameterivARB; +GLEW_FUN_EXPORT PFNGLGETSHADERSOURCEARBPROC __glewGetShaderSourceARB; +GLEW_FUN_EXPORT PFNGLGETUNIFORMLOCATIONARBPROC __glewGetUniformLocationARB; +GLEW_FUN_EXPORT PFNGLGETUNIFORMFVARBPROC __glewGetUniformfvARB; +GLEW_FUN_EXPORT PFNGLGETUNIFORMIVARBPROC __glewGetUniformivARB; +GLEW_FUN_EXPORT PFNGLLINKPROGRAMARBPROC __glewLinkProgramARB; +GLEW_FUN_EXPORT PFNGLSHADERSOURCEARBPROC __glewShaderSourceARB; +GLEW_FUN_EXPORT PFNGLUNIFORM1FARBPROC __glewUniform1fARB; +GLEW_FUN_EXPORT PFNGLUNIFORM1FVARBPROC __glewUniform1fvARB; +GLEW_FUN_EXPORT PFNGLUNIFORM1IARBPROC __glewUniform1iARB; +GLEW_FUN_EXPORT PFNGLUNIFORM1IVARBPROC __glewUniform1ivARB; +GLEW_FUN_EXPORT PFNGLUNIFORM2FARBPROC __glewUniform2fARB; +GLEW_FUN_EXPORT PFNGLUNIFORM2FVARBPROC __glewUniform2fvARB; +GLEW_FUN_EXPORT PFNGLUNIFORM2IARBPROC __glewUniform2iARB; +GLEW_FUN_EXPORT PFNGLUNIFORM2IVARBPROC __glewUniform2ivARB; +GLEW_FUN_EXPORT PFNGLUNIFORM3FARBPROC __glewUniform3fARB; +GLEW_FUN_EXPORT PFNGLUNIFORM3FVARBPROC __glewUniform3fvARB; +GLEW_FUN_EXPORT PFNGLUNIFORM3IARBPROC __glewUniform3iARB; +GLEW_FUN_EXPORT PFNGLUNIFORM3IVARBPROC __glewUniform3ivARB; +GLEW_FUN_EXPORT PFNGLUNIFORM4FARBPROC __glewUniform4fARB; +GLEW_FUN_EXPORT PFNGLUNIFORM4FVARBPROC __glewUniform4fvARB; +GLEW_FUN_EXPORT PFNGLUNIFORM4IARBPROC __glewUniform4iARB; +GLEW_FUN_EXPORT PFNGLUNIFORM4IVARBPROC __glewUniform4ivARB; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2FVARBPROC __glewUniformMatrix2fvARB; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3FVARBPROC __glewUniformMatrix3fvARB; +GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4FVARBPROC __glewUniformMatrix4fvARB; +GLEW_FUN_EXPORT PFNGLUSEPROGRAMOBJECTARBPROC __glewUseProgramObjectARB; +GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMARBPROC __glewValidateProgramARB; + +GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINENAMEPROC __glewGetActiveSubroutineName; +GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC __glewGetActiveSubroutineUniformName; +GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC __glewGetActiveSubroutineUniformiv; +GLEW_FUN_EXPORT PFNGLGETPROGRAMSTAGEIVPROC __glewGetProgramStageiv; +GLEW_FUN_EXPORT PFNGLGETSUBROUTINEINDEXPROC __glewGetSubroutineIndex; +GLEW_FUN_EXPORT PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC __glewGetSubroutineUniformLocation; +GLEW_FUN_EXPORT PFNGLGETUNIFORMSUBROUTINEUIVPROC __glewGetUniformSubroutineuiv; +GLEW_FUN_EXPORT PFNGLUNIFORMSUBROUTINESUIVPROC __glewUniformSubroutinesuiv; + +GLEW_FUN_EXPORT PFNGLCOMPILESHADERINCLUDEARBPROC __glewCompileShaderIncludeARB; +GLEW_FUN_EXPORT PFNGLDELETENAMEDSTRINGARBPROC __glewDeleteNamedStringARB; +GLEW_FUN_EXPORT PFNGLGETNAMEDSTRINGARBPROC __glewGetNamedStringARB; +GLEW_FUN_EXPORT PFNGLGETNAMEDSTRINGIVARBPROC __glewGetNamedStringivARB; +GLEW_FUN_EXPORT PFNGLISNAMEDSTRINGARBPROC __glewIsNamedStringARB; +GLEW_FUN_EXPORT PFNGLNAMEDSTRINGARBPROC __glewNamedStringARB; + +GLEW_FUN_EXPORT PFNGLCLIENTWAITSYNCPROC __glewClientWaitSync; +GLEW_FUN_EXPORT PFNGLDELETESYNCPROC __glewDeleteSync; +GLEW_FUN_EXPORT PFNGLFENCESYNCPROC __glewFenceSync; +GLEW_FUN_EXPORT PFNGLGETINTEGER64VPROC __glewGetInteger64v; +GLEW_FUN_EXPORT PFNGLGETSYNCIVPROC __glewGetSynciv; +GLEW_FUN_EXPORT PFNGLISSYNCPROC __glewIsSync; +GLEW_FUN_EXPORT PFNGLWAITSYNCPROC __glewWaitSync; + +GLEW_FUN_EXPORT PFNGLPATCHPARAMETERFVPROC __glewPatchParameterfv; +GLEW_FUN_EXPORT PFNGLPATCHPARAMETERIPROC __glewPatchParameteri; + +GLEW_FUN_EXPORT PFNGLTEXBUFFERARBPROC __glewTexBufferARB; + +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE1DARBPROC __glewCompressedTexImage1DARB; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE2DARBPROC __glewCompressedTexImage2DARB; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE3DARBPROC __glewCompressedTexImage3DARB; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC __glewCompressedTexSubImage1DARB; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC __glewCompressedTexSubImage2DARB; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC __glewCompressedTexSubImage3DARB; +GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXIMAGEARBPROC __glewGetCompressedTexImageARB; + +GLEW_FUN_EXPORT PFNGLGETMULTISAMPLEFVPROC __glewGetMultisamplefv; +GLEW_FUN_EXPORT PFNGLSAMPLEMASKIPROC __glewSampleMaski; +GLEW_FUN_EXPORT PFNGLTEXIMAGE2DMULTISAMPLEPROC __glewTexImage2DMultisample; +GLEW_FUN_EXPORT PFNGLTEXIMAGE3DMULTISAMPLEPROC __glewTexImage3DMultisample; + +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTI64VPROC __glewGetQueryObjecti64v; +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUI64VPROC __glewGetQueryObjectui64v; +GLEW_FUN_EXPORT PFNGLQUERYCOUNTERPROC __glewQueryCounter; + +GLEW_FUN_EXPORT PFNGLBINDTRANSFORMFEEDBACKPROC __glewBindTransformFeedback; +GLEW_FUN_EXPORT PFNGLDELETETRANSFORMFEEDBACKSPROC __glewDeleteTransformFeedbacks; +GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKPROC __glewDrawTransformFeedback; +GLEW_FUN_EXPORT PFNGLGENTRANSFORMFEEDBACKSPROC __glewGenTransformFeedbacks; +GLEW_FUN_EXPORT PFNGLISTRANSFORMFEEDBACKPROC __glewIsTransformFeedback; +GLEW_FUN_EXPORT PFNGLPAUSETRANSFORMFEEDBACKPROC __glewPauseTransformFeedback; +GLEW_FUN_EXPORT PFNGLRESUMETRANSFORMFEEDBACKPROC __glewResumeTransformFeedback; + +GLEW_FUN_EXPORT PFNGLBEGINQUERYINDEXEDPROC __glewBeginQueryIndexed; +GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC __glewDrawTransformFeedbackStream; +GLEW_FUN_EXPORT PFNGLENDQUERYINDEXEDPROC __glewEndQueryIndexed; +GLEW_FUN_EXPORT PFNGLGETQUERYINDEXEDIVPROC __glewGetQueryIndexediv; + +GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXDARBPROC __glewLoadTransposeMatrixdARB; +GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXFARBPROC __glewLoadTransposeMatrixfARB; +GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXDARBPROC __glewMultTransposeMatrixdARB; +GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXFARBPROC __glewMultTransposeMatrixfARB; + +GLEW_FUN_EXPORT PFNGLBINDBUFFERBASEPROC __glewBindBufferBase; +GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGEPROC __glewBindBufferRange; +GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC __glewGetActiveUniformBlockName; +GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMBLOCKIVPROC __glewGetActiveUniformBlockiv; +GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMNAMEPROC __glewGetActiveUniformName; +GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMSIVPROC __glewGetActiveUniformsiv; +GLEW_FUN_EXPORT PFNGLGETINTEGERI_VPROC __glewGetIntegeri_v; +GLEW_FUN_EXPORT PFNGLGETUNIFORMBLOCKINDEXPROC __glewGetUniformBlockIndex; +GLEW_FUN_EXPORT PFNGLGETUNIFORMINDICESPROC __glewGetUniformIndices; +GLEW_FUN_EXPORT PFNGLUNIFORMBLOCKBINDINGPROC __glewUniformBlockBinding; + +GLEW_FUN_EXPORT PFNGLBINDVERTEXARRAYPROC __glewBindVertexArray; +GLEW_FUN_EXPORT PFNGLDELETEVERTEXARRAYSPROC __glewDeleteVertexArrays; +GLEW_FUN_EXPORT PFNGLGENVERTEXARRAYSPROC __glewGenVertexArrays; +GLEW_FUN_EXPORT PFNGLISVERTEXARRAYPROC __glewIsVertexArray; + +GLEW_FUN_EXPORT PFNGLVERTEXBLENDARBPROC __glewVertexBlendARB; +GLEW_FUN_EXPORT PFNGLWEIGHTPOINTERARBPROC __glewWeightPointerARB; +GLEW_FUN_EXPORT PFNGLWEIGHTBVARBPROC __glewWeightbvARB; +GLEW_FUN_EXPORT PFNGLWEIGHTDVARBPROC __glewWeightdvARB; +GLEW_FUN_EXPORT PFNGLWEIGHTFVARBPROC __glewWeightfvARB; +GLEW_FUN_EXPORT PFNGLWEIGHTIVARBPROC __glewWeightivARB; +GLEW_FUN_EXPORT PFNGLWEIGHTSVARBPROC __glewWeightsvARB; +GLEW_FUN_EXPORT PFNGLWEIGHTUBVARBPROC __glewWeightubvARB; +GLEW_FUN_EXPORT PFNGLWEIGHTUIVARBPROC __glewWeightuivARB; +GLEW_FUN_EXPORT PFNGLWEIGHTUSVARBPROC __glewWeightusvARB; + +GLEW_FUN_EXPORT PFNGLBINDBUFFERARBPROC __glewBindBufferARB; +GLEW_FUN_EXPORT PFNGLBUFFERDATAARBPROC __glewBufferDataARB; +GLEW_FUN_EXPORT PFNGLBUFFERSUBDATAARBPROC __glewBufferSubDataARB; +GLEW_FUN_EXPORT PFNGLDELETEBUFFERSARBPROC __glewDeleteBuffersARB; +GLEW_FUN_EXPORT PFNGLGENBUFFERSARBPROC __glewGenBuffersARB; +GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERIVARBPROC __glewGetBufferParameterivARB; +GLEW_FUN_EXPORT PFNGLGETBUFFERPOINTERVARBPROC __glewGetBufferPointervARB; +GLEW_FUN_EXPORT PFNGLGETBUFFERSUBDATAARBPROC __glewGetBufferSubDataARB; +GLEW_FUN_EXPORT PFNGLISBUFFERARBPROC __glewIsBufferARB; +GLEW_FUN_EXPORT PFNGLMAPBUFFERARBPROC __glewMapBufferARB; +GLEW_FUN_EXPORT PFNGLUNMAPBUFFERARBPROC __glewUnmapBufferARB; + +GLEW_FUN_EXPORT PFNGLBINDPROGRAMARBPROC __glewBindProgramARB; +GLEW_FUN_EXPORT PFNGLDELETEPROGRAMSARBPROC __glewDeleteProgramsARB; +GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBARRAYARBPROC __glewDisableVertexAttribArrayARB; +GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBARRAYARBPROC __glewEnableVertexAttribArrayARB; +GLEW_FUN_EXPORT PFNGLGENPROGRAMSARBPROC __glewGenProgramsARB; +GLEW_FUN_EXPORT PFNGLGETPROGRAMENVPARAMETERDVARBPROC __glewGetProgramEnvParameterdvARB; +GLEW_FUN_EXPORT PFNGLGETPROGRAMENVPARAMETERFVARBPROC __glewGetProgramEnvParameterfvARB; +GLEW_FUN_EXPORT PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC __glewGetProgramLocalParameterdvARB; +GLEW_FUN_EXPORT PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC __glewGetProgramLocalParameterfvARB; +GLEW_FUN_EXPORT PFNGLGETPROGRAMSTRINGARBPROC __glewGetProgramStringARB; +GLEW_FUN_EXPORT PFNGLGETPROGRAMIVARBPROC __glewGetProgramivARB; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVARBPROC __glewGetVertexAttribPointervARB; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVARBPROC __glewGetVertexAttribdvARB; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVARBPROC __glewGetVertexAttribfvARB; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVARBPROC __glewGetVertexAttribivARB; +GLEW_FUN_EXPORT PFNGLISPROGRAMARBPROC __glewIsProgramARB; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4DARBPROC __glewProgramEnvParameter4dARB; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4DVARBPROC __glewProgramEnvParameter4dvARB; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4FARBPROC __glewProgramEnvParameter4fARB; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4FVARBPROC __glewProgramEnvParameter4fvARB; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4DARBPROC __glewProgramLocalParameter4dARB; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4DVARBPROC __glewProgramLocalParameter4dvARB; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4FARBPROC __glewProgramLocalParameter4fARB; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4FVARBPROC __glewProgramLocalParameter4fvARB; +GLEW_FUN_EXPORT PFNGLPROGRAMSTRINGARBPROC __glewProgramStringARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DARBPROC __glewVertexAttrib1dARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVARBPROC __glewVertexAttrib1dvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FARBPROC __glewVertexAttrib1fARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVARBPROC __glewVertexAttrib1fvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SARBPROC __glewVertexAttrib1sARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVARBPROC __glewVertexAttrib1svARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DARBPROC __glewVertexAttrib2dARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVARBPROC __glewVertexAttrib2dvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FARBPROC __glewVertexAttrib2fARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVARBPROC __glewVertexAttrib2fvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SARBPROC __glewVertexAttrib2sARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVARBPROC __glewVertexAttrib2svARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DARBPROC __glewVertexAttrib3dARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVARBPROC __glewVertexAttrib3dvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FARBPROC __glewVertexAttrib3fARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVARBPROC __glewVertexAttrib3fvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SARBPROC __glewVertexAttrib3sARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVARBPROC __glewVertexAttrib3svARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NBVARBPROC __glewVertexAttrib4NbvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NIVARBPROC __glewVertexAttrib4NivARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NSVARBPROC __glewVertexAttrib4NsvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBARBPROC __glewVertexAttrib4NubARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBVARBPROC __glewVertexAttrib4NubvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUIVARBPROC __glewVertexAttrib4NuivARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUSVARBPROC __glewVertexAttrib4NusvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4BVARBPROC __glewVertexAttrib4bvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DARBPROC __glewVertexAttrib4dARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVARBPROC __glewVertexAttrib4dvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FARBPROC __glewVertexAttrib4fARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVARBPROC __glewVertexAttrib4fvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4IVARBPROC __glewVertexAttrib4ivARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SARBPROC __glewVertexAttrib4sARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVARBPROC __glewVertexAttrib4svARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVARBPROC __glewVertexAttrib4ubvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UIVARBPROC __glewVertexAttrib4uivARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4USVARBPROC __glewVertexAttrib4usvARB; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERARBPROC __glewVertexAttribPointerARB; + +GLEW_FUN_EXPORT PFNGLBINDATTRIBLOCATIONARBPROC __glewBindAttribLocationARB; +GLEW_FUN_EXPORT PFNGLGETACTIVEATTRIBARBPROC __glewGetActiveAttribARB; +GLEW_FUN_EXPORT PFNGLGETATTRIBLOCATIONARBPROC __glewGetAttribLocationARB; + +GLEW_FUN_EXPORT PFNGLCOLORP3UIPROC __glewColorP3ui; +GLEW_FUN_EXPORT PFNGLCOLORP3UIVPROC __glewColorP3uiv; +GLEW_FUN_EXPORT PFNGLCOLORP4UIPROC __glewColorP4ui; +GLEW_FUN_EXPORT PFNGLCOLORP4UIVPROC __glewColorP4uiv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP1UIPROC __glewMultiTexCoordP1ui; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP1UIVPROC __glewMultiTexCoordP1uiv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP2UIPROC __glewMultiTexCoordP2ui; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP2UIVPROC __glewMultiTexCoordP2uiv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP3UIPROC __glewMultiTexCoordP3ui; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP3UIVPROC __glewMultiTexCoordP3uiv; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP4UIPROC __glewMultiTexCoordP4ui; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP4UIVPROC __glewMultiTexCoordP4uiv; +GLEW_FUN_EXPORT PFNGLNORMALP3UIPROC __glewNormalP3ui; +GLEW_FUN_EXPORT PFNGLNORMALP3UIVPROC __glewNormalP3uiv; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLORP3UIPROC __glewSecondaryColorP3ui; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLORP3UIVPROC __glewSecondaryColorP3uiv; +GLEW_FUN_EXPORT PFNGLTEXCOORDP1UIPROC __glewTexCoordP1ui; +GLEW_FUN_EXPORT PFNGLTEXCOORDP1UIVPROC __glewTexCoordP1uiv; +GLEW_FUN_EXPORT PFNGLTEXCOORDP2UIPROC __glewTexCoordP2ui; +GLEW_FUN_EXPORT PFNGLTEXCOORDP2UIVPROC __glewTexCoordP2uiv; +GLEW_FUN_EXPORT PFNGLTEXCOORDP3UIPROC __glewTexCoordP3ui; +GLEW_FUN_EXPORT PFNGLTEXCOORDP3UIVPROC __glewTexCoordP3uiv; +GLEW_FUN_EXPORT PFNGLTEXCOORDP4UIPROC __glewTexCoordP4ui; +GLEW_FUN_EXPORT PFNGLTEXCOORDP4UIVPROC __glewTexCoordP4uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP1UIPROC __glewVertexAttribP1ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP1UIVPROC __glewVertexAttribP1uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP2UIPROC __glewVertexAttribP2ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP2UIVPROC __glewVertexAttribP2uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP3UIPROC __glewVertexAttribP3ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP3UIVPROC __glewVertexAttribP3uiv; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP4UIPROC __glewVertexAttribP4ui; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP4UIVPROC __glewVertexAttribP4uiv; +GLEW_FUN_EXPORT PFNGLVERTEXP2UIPROC __glewVertexP2ui; +GLEW_FUN_EXPORT PFNGLVERTEXP2UIVPROC __glewVertexP2uiv; +GLEW_FUN_EXPORT PFNGLVERTEXP3UIPROC __glewVertexP3ui; +GLEW_FUN_EXPORT PFNGLVERTEXP3UIVPROC __glewVertexP3uiv; +GLEW_FUN_EXPORT PFNGLVERTEXP4UIPROC __glewVertexP4ui; +GLEW_FUN_EXPORT PFNGLVERTEXP4UIVPROC __glewVertexP4uiv; + +GLEW_FUN_EXPORT PFNGLWINDOWPOS2DARBPROC __glewWindowPos2dARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVARBPROC __glewWindowPos2dvARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2FARBPROC __glewWindowPos2fARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVARBPROC __glewWindowPos2fvARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2IARBPROC __glewWindowPos2iARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVARBPROC __glewWindowPos2ivARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2SARBPROC __glewWindowPos2sARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVARBPROC __glewWindowPos2svARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3DARBPROC __glewWindowPos3dARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVARBPROC __glewWindowPos3dvARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3FARBPROC __glewWindowPos3fARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVARBPROC __glewWindowPos3fvARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3IARBPROC __glewWindowPos3iARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVARBPROC __glewWindowPos3ivARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3SARBPROC __glewWindowPos3sARB; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVARBPROC __glewWindowPos3svARB; + +GLEW_FUN_EXPORT PFNGLDRAWBUFFERSATIPROC __glewDrawBuffersATI; + +GLEW_FUN_EXPORT PFNGLDRAWELEMENTARRAYATIPROC __glewDrawElementArrayATI; +GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTARRAYATIPROC __glewDrawRangeElementArrayATI; +GLEW_FUN_EXPORT PFNGLELEMENTPOINTERATIPROC __glewElementPointerATI; + +GLEW_FUN_EXPORT PFNGLGETTEXBUMPPARAMETERFVATIPROC __glewGetTexBumpParameterfvATI; +GLEW_FUN_EXPORT PFNGLGETTEXBUMPPARAMETERIVATIPROC __glewGetTexBumpParameterivATI; +GLEW_FUN_EXPORT PFNGLTEXBUMPPARAMETERFVATIPROC __glewTexBumpParameterfvATI; +GLEW_FUN_EXPORT PFNGLTEXBUMPPARAMETERIVATIPROC __glewTexBumpParameterivATI; + +GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP1ATIPROC __glewAlphaFragmentOp1ATI; +GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP2ATIPROC __glewAlphaFragmentOp2ATI; +GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP3ATIPROC __glewAlphaFragmentOp3ATI; +GLEW_FUN_EXPORT PFNGLBEGINFRAGMENTSHADERATIPROC __glewBeginFragmentShaderATI; +GLEW_FUN_EXPORT PFNGLBINDFRAGMENTSHADERATIPROC __glewBindFragmentShaderATI; +GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP1ATIPROC __glewColorFragmentOp1ATI; +GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP2ATIPROC __glewColorFragmentOp2ATI; +GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP3ATIPROC __glewColorFragmentOp3ATI; +GLEW_FUN_EXPORT PFNGLDELETEFRAGMENTSHADERATIPROC __glewDeleteFragmentShaderATI; +GLEW_FUN_EXPORT PFNGLENDFRAGMENTSHADERATIPROC __glewEndFragmentShaderATI; +GLEW_FUN_EXPORT PFNGLGENFRAGMENTSHADERSATIPROC __glewGenFragmentShadersATI; +GLEW_FUN_EXPORT PFNGLPASSTEXCOORDATIPROC __glewPassTexCoordATI; +GLEW_FUN_EXPORT PFNGLSAMPLEMAPATIPROC __glewSampleMapATI; +GLEW_FUN_EXPORT PFNGLSETFRAGMENTSHADERCONSTANTATIPROC __glewSetFragmentShaderConstantATI; + +GLEW_FUN_EXPORT PFNGLMAPOBJECTBUFFERATIPROC __glewMapObjectBufferATI; +GLEW_FUN_EXPORT PFNGLUNMAPOBJECTBUFFERATIPROC __glewUnmapObjectBufferATI; + +GLEW_FUN_EXPORT PFNGLPNTRIANGLESFATIPROC __glPNTrianglewesfATI; +GLEW_FUN_EXPORT PFNGLPNTRIANGLESIATIPROC __glPNTrianglewesiATI; + +GLEW_FUN_EXPORT PFNGLSTENCILFUNCSEPARATEATIPROC __glewStencilFuncSeparateATI; +GLEW_FUN_EXPORT PFNGLSTENCILOPSEPARATEATIPROC __glewStencilOpSeparateATI; + +GLEW_FUN_EXPORT PFNGLARRAYOBJECTATIPROC __glewArrayObjectATI; +GLEW_FUN_EXPORT PFNGLFREEOBJECTBUFFERATIPROC __glewFreeObjectBufferATI; +GLEW_FUN_EXPORT PFNGLGETARRAYOBJECTFVATIPROC __glewGetArrayObjectfvATI; +GLEW_FUN_EXPORT PFNGLGETARRAYOBJECTIVATIPROC __glewGetArrayObjectivATI; +GLEW_FUN_EXPORT PFNGLGETOBJECTBUFFERFVATIPROC __glewGetObjectBufferfvATI; +GLEW_FUN_EXPORT PFNGLGETOBJECTBUFFERIVATIPROC __glewGetObjectBufferivATI; +GLEW_FUN_EXPORT PFNGLGETVARIANTARRAYOBJECTFVATIPROC __glewGetVariantArrayObjectfvATI; +GLEW_FUN_EXPORT PFNGLGETVARIANTARRAYOBJECTIVATIPROC __glewGetVariantArrayObjectivATI; +GLEW_FUN_EXPORT PFNGLISOBJECTBUFFERATIPROC __glewIsObjectBufferATI; +GLEW_FUN_EXPORT PFNGLNEWOBJECTBUFFERATIPROC __glewNewObjectBufferATI; +GLEW_FUN_EXPORT PFNGLUPDATEOBJECTBUFFERATIPROC __glewUpdateObjectBufferATI; +GLEW_FUN_EXPORT PFNGLVARIANTARRAYOBJECTATIPROC __glewVariantArrayObjectATI; + +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC __glewGetVertexAttribArrayObjectfvATI; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC __glewGetVertexAttribArrayObjectivATI; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBARRAYOBJECTATIPROC __glewVertexAttribArrayObjectATI; + +GLEW_FUN_EXPORT PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC __glewClientActiveVertexStreamATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3BATIPROC __glewNormalStream3bATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3BVATIPROC __glewNormalStream3bvATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3DATIPROC __glewNormalStream3dATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3DVATIPROC __glewNormalStream3dvATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3FATIPROC __glewNormalStream3fATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3FVATIPROC __glewNormalStream3fvATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3IATIPROC __glewNormalStream3iATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3IVATIPROC __glewNormalStream3ivATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3SATIPROC __glewNormalStream3sATI; +GLEW_FUN_EXPORT PFNGLNORMALSTREAM3SVATIPROC __glewNormalStream3svATI; +GLEW_FUN_EXPORT PFNGLVERTEXBLENDENVFATIPROC __glewVertexBlendEnvfATI; +GLEW_FUN_EXPORT PFNGLVERTEXBLENDENVIATIPROC __glewVertexBlendEnviATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2DATIPROC __glewVertexStream2dATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2DVATIPROC __glewVertexStream2dvATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2FATIPROC __glewVertexStream2fATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2FVATIPROC __glewVertexStream2fvATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2IATIPROC __glewVertexStream2iATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2IVATIPROC __glewVertexStream2ivATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2SATIPROC __glewVertexStream2sATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2SVATIPROC __glewVertexStream2svATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3DATIPROC __glewVertexStream3dATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3DVATIPROC __glewVertexStream3dvATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3FATIPROC __glewVertexStream3fATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3FVATIPROC __glewVertexStream3fvATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3IATIPROC __glewVertexStream3iATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3IVATIPROC __glewVertexStream3ivATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3SATIPROC __glewVertexStream3sATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3SVATIPROC __glewVertexStream3svATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4DATIPROC __glewVertexStream4dATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4DVATIPROC __glewVertexStream4dvATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4FATIPROC __glewVertexStream4fATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4FVATIPROC __glewVertexStream4fvATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4IATIPROC __glewVertexStream4iATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4IVATIPROC __glewVertexStream4ivATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4SATIPROC __glewVertexStream4sATI; +GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4SVATIPROC __glewVertexStream4svATI; + +GLEW_FUN_EXPORT PFNGLGETUNIFORMBUFFERSIZEEXTPROC __glewGetUniformBufferSizeEXT; +GLEW_FUN_EXPORT PFNGLGETUNIFORMOFFSETEXTPROC __glewGetUniformOffsetEXT; +GLEW_FUN_EXPORT PFNGLUNIFORMBUFFEREXTPROC __glewUniformBufferEXT; + +GLEW_FUN_EXPORT PFNGLBLENDCOLOREXTPROC __glewBlendColorEXT; + +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEEXTPROC __glewBlendEquationSeparateEXT; + +GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEEXTPROC __glewBlendFuncSeparateEXT; + +GLEW_FUN_EXPORT PFNGLBLENDEQUATIONEXTPROC __glewBlendEquationEXT; + +GLEW_FUN_EXPORT PFNGLCOLORSUBTABLEEXTPROC __glewColorSubTableEXT; +GLEW_FUN_EXPORT PFNGLCOPYCOLORSUBTABLEEXTPROC __glewCopyColorSubTableEXT; + +GLEW_FUN_EXPORT PFNGLLOCKARRAYSEXTPROC __glewLockArraysEXT; +GLEW_FUN_EXPORT PFNGLUNLOCKARRAYSEXTPROC __glewUnlockArraysEXT; + +GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER1DEXTPROC __glewConvolutionFilter1DEXT; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER2DEXTPROC __glewConvolutionFilter2DEXT; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFEXTPROC __glewConvolutionParameterfEXT; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFVEXTPROC __glewConvolutionParameterfvEXT; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIEXTPROC __glewConvolutionParameteriEXT; +GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIVEXTPROC __glewConvolutionParameterivEXT; +GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC __glewCopyConvolutionFilter1DEXT; +GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC __glewCopyConvolutionFilter2DEXT; +GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONFILTEREXTPROC __glewGetConvolutionFilterEXT; +GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC __glewGetConvolutionParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC __glewGetConvolutionParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETSEPARABLEFILTEREXTPROC __glewGetSeparableFilterEXT; +GLEW_FUN_EXPORT PFNGLSEPARABLEFILTER2DEXTPROC __glewSeparableFilter2DEXT; + +GLEW_FUN_EXPORT PFNGLBINORMALPOINTEREXTPROC __glewBinormalPointerEXT; +GLEW_FUN_EXPORT PFNGLTANGENTPOINTEREXTPROC __glewTangentPointerEXT; + +GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE1DEXTPROC __glewCopyTexImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE2DEXTPROC __glewCopyTexImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE1DEXTPROC __glewCopyTexSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE2DEXTPROC __glewCopyTexSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE3DEXTPROC __glewCopyTexSubImage3DEXT; + +GLEW_FUN_EXPORT PFNGLCULLPARAMETERDVEXTPROC __glewCullParameterdvEXT; +GLEW_FUN_EXPORT PFNGLCULLPARAMETERFVEXTPROC __glewCullParameterfvEXT; + +GLEW_FUN_EXPORT PFNGLDEPTHBOUNDSEXTPROC __glewDepthBoundsEXT; + +GLEW_FUN_EXPORT PFNGLBINDMULTITEXTUREEXTPROC __glewBindMultiTextureEXT; +GLEW_FUN_EXPORT PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC __glewCheckNamedFramebufferStatusEXT; +GLEW_FUN_EXPORT PFNGLCLIENTATTRIBDEFAULTEXTPROC __glewClientAttribDefaultEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC __glewCompressedMultiTexImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC __glewCompressedMultiTexImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC __glewCompressedMultiTexImage3DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC __glewCompressedMultiTexSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC __glewCompressedMultiTexSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC __glewCompressedMultiTexSubImage3DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC __glewCompressedTextureImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC __glewCompressedTextureImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC __glewCompressedTextureImage3DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC __glewCompressedTextureSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC __glewCompressedTextureSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC __glewCompressedTextureSubImage3DEXT; +GLEW_FUN_EXPORT PFNGLCOPYMULTITEXIMAGE1DEXTPROC __glewCopyMultiTexImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOPYMULTITEXIMAGE2DEXTPROC __glewCopyMultiTexImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC __glewCopyMultiTexSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC __glewCopyMultiTexSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC __glewCopyMultiTexSubImage3DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXTUREIMAGE1DEXTPROC __glewCopyTextureImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXTUREIMAGE2DEXTPROC __glewCopyTextureImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC __glewCopyTextureSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC __glewCopyTextureSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC __glewCopyTextureSubImage3DEXT; +GLEW_FUN_EXPORT PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC __glewDisableClientStateIndexedEXT; +GLEW_FUN_EXPORT PFNGLDISABLECLIENTSTATEIEXTPROC __glewDisableClientStateiEXT; +GLEW_FUN_EXPORT PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC __glewDisableVertexArrayAttribEXT; +GLEW_FUN_EXPORT PFNGLDISABLEVERTEXARRAYEXTPROC __glewDisableVertexArrayEXT; +GLEW_FUN_EXPORT PFNGLENABLECLIENTSTATEINDEXEDEXTPROC __glewEnableClientStateIndexedEXT; +GLEW_FUN_EXPORT PFNGLENABLECLIENTSTATEIEXTPROC __glewEnableClientStateiEXT; +GLEW_FUN_EXPORT PFNGLENABLEVERTEXARRAYATTRIBEXTPROC __glewEnableVertexArrayAttribEXT; +GLEW_FUN_EXPORT PFNGLENABLEVERTEXARRAYEXTPROC __glewEnableVertexArrayEXT; +GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC __glewFlushMappedNamedBufferRangeEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC __glewFramebufferDrawBufferEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC __glewFramebufferDrawBuffersEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERREADBUFFEREXTPROC __glewFramebufferReadBufferEXT; +GLEW_FUN_EXPORT PFNGLGENERATEMULTITEXMIPMAPEXTPROC __glewGenerateMultiTexMipmapEXT; +GLEW_FUN_EXPORT PFNGLGENERATETEXTUREMIPMAPEXTPROC __glewGenerateTextureMipmapEXT; +GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC __glewGetCompressedMultiTexImageEXT; +GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC __glewGetCompressedTextureImageEXT; +GLEW_FUN_EXPORT PFNGLGETDOUBLEINDEXEDVEXTPROC __glewGetDoubleIndexedvEXT; +GLEW_FUN_EXPORT PFNGLGETDOUBLEI_VEXTPROC __glewGetDoublei_vEXT; +GLEW_FUN_EXPORT PFNGLGETFLOATINDEXEDVEXTPROC __glewGetFloatIndexedvEXT; +GLEW_FUN_EXPORT PFNGLGETFLOATI_VEXTPROC __glewGetFloati_vEXT; +GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC __glewGetFramebufferParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXENVFVEXTPROC __glewGetMultiTexEnvfvEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXENVIVEXTPROC __glewGetMultiTexEnvivEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXGENDVEXTPROC __glewGetMultiTexGendvEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXGENFVEXTPROC __glewGetMultiTexGenfvEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXGENIVEXTPROC __glewGetMultiTexGenivEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXIMAGEEXTPROC __glewGetMultiTexImageEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC __glewGetMultiTexLevelParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC __glewGetMultiTexLevelParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIIVEXTPROC __glewGetMultiTexParameterIivEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIUIVEXTPROC __glewGetMultiTexParameterIuivEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERFVEXTPROC __glewGetMultiTexParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIVEXTPROC __glewGetMultiTexParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC __glewGetNamedBufferParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPOINTERVEXTPROC __glewGetNamedBufferPointervEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERSUBDATAEXTPROC __glewGetNamedBufferSubDataEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetNamedFramebufferAttachmentParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC __glewGetNamedProgramLocalParameterIivEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC __glewGetNamedProgramLocalParameterIuivEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC __glewGetNamedProgramLocalParameterdvEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC __glewGetNamedProgramLocalParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMSTRINGEXTPROC __glewGetNamedProgramStringEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMIVEXTPROC __glewGetNamedProgramivEXT; +GLEW_FUN_EXPORT PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC __glewGetNamedRenderbufferParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETPOINTERINDEXEDVEXTPROC __glewGetPointerIndexedvEXT; +GLEW_FUN_EXPORT PFNGLGETPOINTERI_VEXTPROC __glewGetPointeri_vEXT; +GLEW_FUN_EXPORT PFNGLGETTEXTUREIMAGEEXTPROC __glewGetTextureImageEXT; +GLEW_FUN_EXPORT PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC __glewGetTextureLevelParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC __glewGetTextureLevelParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIIVEXTPROC __glewGetTextureParameterIivEXT; +GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIUIVEXTPROC __glewGetTextureParameterIuivEXT; +GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERFVEXTPROC __glewGetTextureParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIVEXTPROC __glewGetTextureParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC __glewGetVertexArrayIntegeri_vEXT; +GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYINTEGERVEXTPROC __glewGetVertexArrayIntegervEXT; +GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC __glewGetVertexArrayPointeri_vEXT; +GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYPOINTERVEXTPROC __glewGetVertexArrayPointervEXT; +GLEW_FUN_EXPORT PFNGLMAPNAMEDBUFFEREXTPROC __glewMapNamedBufferEXT; +GLEW_FUN_EXPORT PFNGLMAPNAMEDBUFFERRANGEEXTPROC __glewMapNamedBufferRangeEXT; +GLEW_FUN_EXPORT PFNGLMATRIXFRUSTUMEXTPROC __glewMatrixFrustumEXT; +GLEW_FUN_EXPORT PFNGLMATRIXLOADIDENTITYEXTPROC __glewMatrixLoadIdentityEXT; +GLEW_FUN_EXPORT PFNGLMATRIXLOADTRANSPOSEDEXTPROC __glewMatrixLoadTransposedEXT; +GLEW_FUN_EXPORT PFNGLMATRIXLOADTRANSPOSEFEXTPROC __glewMatrixLoadTransposefEXT; +GLEW_FUN_EXPORT PFNGLMATRIXLOADDEXTPROC __glewMatrixLoaddEXT; +GLEW_FUN_EXPORT PFNGLMATRIXLOADFEXTPROC __glewMatrixLoadfEXT; +GLEW_FUN_EXPORT PFNGLMATRIXMULTTRANSPOSEDEXTPROC __glewMatrixMultTransposedEXT; +GLEW_FUN_EXPORT PFNGLMATRIXMULTTRANSPOSEFEXTPROC __glewMatrixMultTransposefEXT; +GLEW_FUN_EXPORT PFNGLMATRIXMULTDEXTPROC __glewMatrixMultdEXT; +GLEW_FUN_EXPORT PFNGLMATRIXMULTFEXTPROC __glewMatrixMultfEXT; +GLEW_FUN_EXPORT PFNGLMATRIXORTHOEXTPROC __glewMatrixOrthoEXT; +GLEW_FUN_EXPORT PFNGLMATRIXPOPEXTPROC __glewMatrixPopEXT; +GLEW_FUN_EXPORT PFNGLMATRIXPUSHEXTPROC __glewMatrixPushEXT; +GLEW_FUN_EXPORT PFNGLMATRIXROTATEDEXTPROC __glewMatrixRotatedEXT; +GLEW_FUN_EXPORT PFNGLMATRIXROTATEFEXTPROC __glewMatrixRotatefEXT; +GLEW_FUN_EXPORT PFNGLMATRIXSCALEDEXTPROC __glewMatrixScaledEXT; +GLEW_FUN_EXPORT PFNGLMATRIXSCALEFEXTPROC __glewMatrixScalefEXT; +GLEW_FUN_EXPORT PFNGLMATRIXTRANSLATEDEXTPROC __glewMatrixTranslatedEXT; +GLEW_FUN_EXPORT PFNGLMATRIXTRANSLATEFEXTPROC __glewMatrixTranslatefEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXBUFFEREXTPROC __glewMultiTexBufferEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORDPOINTEREXTPROC __glewMultiTexCoordPointerEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXENVFEXTPROC __glewMultiTexEnvfEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXENVFVEXTPROC __glewMultiTexEnvfvEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXENVIEXTPROC __glewMultiTexEnviEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXENVIVEXTPROC __glewMultiTexEnvivEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXGENDEXTPROC __glewMultiTexGendEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXGENDVEXTPROC __glewMultiTexGendvEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXGENFEXTPROC __glewMultiTexGenfEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXGENFVEXTPROC __glewMultiTexGenfvEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXGENIEXTPROC __glewMultiTexGeniEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXGENIVEXTPROC __glewMultiTexGenivEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE1DEXTPROC __glewMultiTexImage1DEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE2DEXTPROC __glewMultiTexImage2DEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE3DEXTPROC __glewMultiTexImage3DEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIIVEXTPROC __glewMultiTexParameterIivEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIUIVEXTPROC __glewMultiTexParameterIuivEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERFEXTPROC __glewMultiTexParameterfEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERFVEXTPROC __glewMultiTexParameterfvEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIEXTPROC __glewMultiTexParameteriEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIVEXTPROC __glewMultiTexParameterivEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXRENDERBUFFEREXTPROC __glewMultiTexRenderbufferEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE1DEXTPROC __glewMultiTexSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE2DEXTPROC __glewMultiTexSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE3DEXTPROC __glewMultiTexSubImage3DEXT; +GLEW_FUN_EXPORT PFNGLNAMEDBUFFERDATAEXTPROC __glewNamedBufferDataEXT; +GLEW_FUN_EXPORT PFNGLNAMEDBUFFERSUBDATAEXTPROC __glewNamedBufferSubDataEXT; +GLEW_FUN_EXPORT PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC __glewNamedCopyBufferSubDataEXT; +GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC __glewNamedFramebufferRenderbufferEXT; +GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC __glewNamedFramebufferTexture1DEXT; +GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC __glewNamedFramebufferTexture2DEXT; +GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC __glewNamedFramebufferTexture3DEXT; +GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC __glewNamedFramebufferTextureEXT; +GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC __glewNamedFramebufferTextureFaceEXT; +GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC __glewNamedFramebufferTextureLayerEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC __glewNamedProgramLocalParameter4dEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC __glewNamedProgramLocalParameter4dvEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC __glewNamedProgramLocalParameter4fEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC __glewNamedProgramLocalParameter4fvEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC __glewNamedProgramLocalParameterI4iEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC __glewNamedProgramLocalParameterI4ivEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC __glewNamedProgramLocalParameterI4uiEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC __glewNamedProgramLocalParameterI4uivEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC __glewNamedProgramLocalParameters4fvEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC __glewNamedProgramLocalParametersI4ivEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC __glewNamedProgramLocalParametersI4uivEXT; +GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMSTRINGEXTPROC __glewNamedProgramStringEXT; +GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC __glewNamedRenderbufferStorageEXT; +GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC __glewNamedRenderbufferStorageMultisampleCoverageEXT; +GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewNamedRenderbufferStorageMultisampleEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FEXTPROC __glewProgramUniform1fEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FVEXTPROC __glewProgramUniform1fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IEXTPROC __glewProgramUniform1iEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IVEXTPROC __glewProgramUniform1ivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIEXTPROC __glewProgramUniform1uiEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIVEXTPROC __glewProgramUniform1uivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FEXTPROC __glewProgramUniform2fEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FVEXTPROC __glewProgramUniform2fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IEXTPROC __glewProgramUniform2iEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IVEXTPROC __glewProgramUniform2ivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIEXTPROC __glewProgramUniform2uiEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIVEXTPROC __glewProgramUniform2uivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FEXTPROC __glewProgramUniform3fEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FVEXTPROC __glewProgramUniform3fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IEXTPROC __glewProgramUniform3iEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IVEXTPROC __glewProgramUniform3ivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIEXTPROC __glewProgramUniform3uiEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIVEXTPROC __glewProgramUniform3uivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FEXTPROC __glewProgramUniform4fEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FVEXTPROC __glewProgramUniform4fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IEXTPROC __glewProgramUniform4iEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IVEXTPROC __glewProgramUniform4ivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIEXTPROC __glewProgramUniform4uiEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIVEXTPROC __glewProgramUniform4uivEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC __glewProgramUniformMatrix2fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC __glewProgramUniformMatrix2x3fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC __glewProgramUniformMatrix2x4fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC __glewProgramUniformMatrix3fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC __glewProgramUniformMatrix3x2fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC __glewProgramUniformMatrix3x4fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC __glewProgramUniformMatrix4fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC __glewProgramUniformMatrix4x2fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC __glewProgramUniformMatrix4x3fvEXT; +GLEW_FUN_EXPORT PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC __glewPushClientAttribDefaultEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREBUFFEREXTPROC __glewTextureBufferEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE1DEXTPROC __glewTextureImage1DEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE2DEXTPROC __glewTextureImage2DEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE3DEXTPROC __glewTextureImage3DEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIIVEXTPROC __glewTextureParameterIivEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIUIVEXTPROC __glewTextureParameterIuivEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERFEXTPROC __glewTextureParameterfEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERFVEXTPROC __glewTextureParameterfvEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIEXTPROC __glewTextureParameteriEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIVEXTPROC __glewTextureParameterivEXT; +GLEW_FUN_EXPORT PFNGLTEXTURERENDERBUFFEREXTPROC __glewTextureRenderbufferEXT; +GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE1DEXTPROC __glewTextureSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE2DEXTPROC __glewTextureSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE3DEXTPROC __glewTextureSubImage3DEXT; +GLEW_FUN_EXPORT PFNGLUNMAPNAMEDBUFFEREXTPROC __glewUnmapNamedBufferEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYCOLOROFFSETEXTPROC __glewVertexArrayColorOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC __glewVertexArrayEdgeFlagOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC __glewVertexArrayFogCoordOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYINDEXOFFSETEXTPROC __glewVertexArrayIndexOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC __glewVertexArrayMultiTexCoordOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYNORMALOFFSETEXTPROC __glewVertexArrayNormalOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC __glewVertexArraySecondaryColorOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC __glewVertexArrayTexCoordOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC __glewVertexArrayVertexAttribIOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC __glewVertexArrayVertexAttribOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC __glewVertexArrayVertexOffsetEXT; + +GLEW_FUN_EXPORT PFNGLCOLORMASKINDEXEDEXTPROC __glewColorMaskIndexedEXT; +GLEW_FUN_EXPORT PFNGLDISABLEINDEXEDEXTPROC __glewDisableIndexedEXT; +GLEW_FUN_EXPORT PFNGLENABLEINDEXEDEXTPROC __glewEnableIndexedEXT; +GLEW_FUN_EXPORT PFNGLGETBOOLEANINDEXEDVEXTPROC __glewGetBooleanIndexedvEXT; +GLEW_FUN_EXPORT PFNGLGETINTEGERINDEXEDVEXTPROC __glewGetIntegerIndexedvEXT; +GLEW_FUN_EXPORT PFNGLISENABLEDINDEXEDEXTPROC __glewIsEnabledIndexedEXT; + +GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDEXTPROC __glewDrawArraysInstancedEXT; +GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDEXTPROC __glewDrawElementsInstancedEXT; + +GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSEXTPROC __glewDrawRangeElementsEXT; + +GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTEREXTPROC __glewFogCoordPointerEXT; +GLEW_FUN_EXPORT PFNGLFOGCOORDDEXTPROC __glewFogCoorddEXT; +GLEW_FUN_EXPORT PFNGLFOGCOORDDVEXTPROC __glewFogCoorddvEXT; +GLEW_FUN_EXPORT PFNGLFOGCOORDFEXTPROC __glewFogCoordfEXT; +GLEW_FUN_EXPORT PFNGLFOGCOORDFVEXTPROC __glewFogCoordfvEXT; + +GLEW_FUN_EXPORT PFNGLFRAGMENTCOLORMATERIALEXTPROC __glewFragmentColorMaterialEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFEXTPROC __glewFragmentLightModelfEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFVEXTPROC __glewFragmentLightModelfvEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIEXTPROC __glewFragmentLightModeliEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIVEXTPROC __glewFragmentLightModelivEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFEXTPROC __glewFragmentLightfEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFVEXTPROC __glewFragmentLightfvEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIEXTPROC __glewFragmentLightiEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIVEXTPROC __glewFragmentLightivEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFEXTPROC __glewFragmentMaterialfEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFVEXTPROC __glewFragmentMaterialfvEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIEXTPROC __glewFragmentMaterialiEXT; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIVEXTPROC __glewFragmentMaterialivEXT; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTFVEXTPROC __glewGetFragmentLightfvEXT; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTIVEXTPROC __glewGetFragmentLightivEXT; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALFVEXTPROC __glewGetFragmentMaterialfvEXT; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALIVEXTPROC __glewGetFragmentMaterialivEXT; +GLEW_FUN_EXPORT PFNGLLIGHTENVIEXTPROC __glewLightEnviEXT; + +GLEW_FUN_EXPORT PFNGLBLITFRAMEBUFFEREXTPROC __glewBlitFramebufferEXT; + +GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewRenderbufferStorageMultisampleEXT; + +GLEW_FUN_EXPORT PFNGLBINDFRAMEBUFFEREXTPROC __glewBindFramebufferEXT; +GLEW_FUN_EXPORT PFNGLBINDRENDERBUFFEREXTPROC __glewBindRenderbufferEXT; +GLEW_FUN_EXPORT PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC __glewCheckFramebufferStatusEXT; +GLEW_FUN_EXPORT PFNGLDELETEFRAMEBUFFERSEXTPROC __glewDeleteFramebuffersEXT; +GLEW_FUN_EXPORT PFNGLDELETERENDERBUFFERSEXTPROC __glewDeleteRenderbuffersEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC __glewFramebufferRenderbufferEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE1DEXTPROC __glewFramebufferTexture1DEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE2DEXTPROC __glewFramebufferTexture2DEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE3DEXTPROC __glewFramebufferTexture3DEXT; +GLEW_FUN_EXPORT PFNGLGENFRAMEBUFFERSEXTPROC __glewGenFramebuffersEXT; +GLEW_FUN_EXPORT PFNGLGENRENDERBUFFERSEXTPROC __glewGenRenderbuffersEXT; +GLEW_FUN_EXPORT PFNGLGENERATEMIPMAPEXTPROC __glewGenerateMipmapEXT; +GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetFramebufferAttachmentParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC __glewGetRenderbufferParameterivEXT; +GLEW_FUN_EXPORT PFNGLISFRAMEBUFFEREXTPROC __glewIsFramebufferEXT; +GLEW_FUN_EXPORT PFNGLISRENDERBUFFEREXTPROC __glewIsRenderbufferEXT; +GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEEXTPROC __glewRenderbufferStorageEXT; + +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREEXTPROC __glewFramebufferTextureEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC __glewFramebufferTextureFaceEXT; +GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC __glewFramebufferTextureLayerEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIEXTPROC __glewProgramParameteriEXT; + +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERS4FVEXTPROC __glewProgramEnvParameters4fvEXT; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC __glewProgramLocalParameters4fvEXT; + +GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONEXTPROC __glewBindFragDataLocationEXT; +GLEW_FUN_EXPORT PFNGLGETFRAGDATALOCATIONEXTPROC __glewGetFragDataLocationEXT; +GLEW_FUN_EXPORT PFNGLGETUNIFORMUIVEXTPROC __glewGetUniformuivEXT; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIIVEXTPROC __glewGetVertexAttribIivEXT; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIUIVEXTPROC __glewGetVertexAttribIuivEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM1UIEXTPROC __glewUniform1uiEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM1UIVEXTPROC __glewUniform1uivEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM2UIEXTPROC __glewUniform2uiEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM2UIVEXTPROC __glewUniform2uivEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM3UIEXTPROC __glewUniform3uiEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM3UIVEXTPROC __glewUniform3uivEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM4UIEXTPROC __glewUniform4uiEXT; +GLEW_FUN_EXPORT PFNGLUNIFORM4UIVEXTPROC __glewUniform4uivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IEXTPROC __glewVertexAttribI1iEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IVEXTPROC __glewVertexAttribI1ivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIEXTPROC __glewVertexAttribI1uiEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIVEXTPROC __glewVertexAttribI1uivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IEXTPROC __glewVertexAttribI2iEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IVEXTPROC __glewVertexAttribI2ivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIEXTPROC __glewVertexAttribI2uiEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIVEXTPROC __glewVertexAttribI2uivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IEXTPROC __glewVertexAttribI3iEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IVEXTPROC __glewVertexAttribI3ivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIEXTPROC __glewVertexAttribI3uiEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIVEXTPROC __glewVertexAttribI3uivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4BVEXTPROC __glewVertexAttribI4bvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IEXTPROC __glewVertexAttribI4iEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IVEXTPROC __glewVertexAttribI4ivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4SVEXTPROC __glewVertexAttribI4svEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UBVEXTPROC __glewVertexAttribI4ubvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIEXTPROC __glewVertexAttribI4uiEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIVEXTPROC __glewVertexAttribI4uivEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4USVEXTPROC __glewVertexAttribI4usvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIPOINTEREXTPROC __glewVertexAttribIPointerEXT; + +GLEW_FUN_EXPORT PFNGLGETHISTOGRAMEXTPROC __glewGetHistogramEXT; +GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERFVEXTPROC __glewGetHistogramParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERIVEXTPROC __glewGetHistogramParameterivEXT; +GLEW_FUN_EXPORT PFNGLGETMINMAXEXTPROC __glewGetMinmaxEXT; +GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERFVEXTPROC __glewGetMinmaxParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERIVEXTPROC __glewGetMinmaxParameterivEXT; +GLEW_FUN_EXPORT PFNGLHISTOGRAMEXTPROC __glewHistogramEXT; +GLEW_FUN_EXPORT PFNGLMINMAXEXTPROC __glewMinmaxEXT; +GLEW_FUN_EXPORT PFNGLRESETHISTOGRAMEXTPROC __glewResetHistogramEXT; +GLEW_FUN_EXPORT PFNGLRESETMINMAXEXTPROC __glewResetMinmaxEXT; + +GLEW_FUN_EXPORT PFNGLINDEXFUNCEXTPROC __glewIndexFuncEXT; + +GLEW_FUN_EXPORT PFNGLINDEXMATERIALEXTPROC __glewIndexMaterialEXT; + +GLEW_FUN_EXPORT PFNGLAPPLYTEXTUREEXTPROC __glewApplyTextureEXT; +GLEW_FUN_EXPORT PFNGLTEXTURELIGHTEXTPROC __glewTextureLightEXT; +GLEW_FUN_EXPORT PFNGLTEXTUREMATERIALEXTPROC __glewTextureMaterialEXT; + +GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSEXTPROC __glewMultiDrawArraysEXT; +GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSEXTPROC __glewMultiDrawElementsEXT; + +GLEW_FUN_EXPORT PFNGLSAMPLEMASKEXTPROC __glewSampleMaskEXT; +GLEW_FUN_EXPORT PFNGLSAMPLEPATTERNEXTPROC __glewSamplePatternEXT; + +GLEW_FUN_EXPORT PFNGLCOLORTABLEEXTPROC __glewColorTableEXT; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEEXTPROC __glewGetColorTableEXT; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVEXTPROC __glewGetColorTableParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVEXTPROC __glewGetColorTableParameterivEXT; + +GLEW_FUN_EXPORT PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC __glewGetPixelTransformParameterfvEXT; +GLEW_FUN_EXPORT PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC __glewGetPixelTransformParameterivEXT; +GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERFEXTPROC __glewPixelTransformParameterfEXT; +GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC __glewPixelTransformParameterfvEXT; +GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERIEXTPROC __glewPixelTransformParameteriEXT; +GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC __glewPixelTransformParameterivEXT; + +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFEXTPROC __glewPointParameterfEXT; +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVEXTPROC __glewPointParameterfvEXT; + +GLEW_FUN_EXPORT PFNGLPOLYGONOFFSETEXTPROC __glewPolygonOffsetEXT; + +GLEW_FUN_EXPORT PFNGLPROVOKINGVERTEXEXTPROC __glewProvokingVertexEXT; + +GLEW_FUN_EXPORT PFNGLBEGINSCENEEXTPROC __glewBeginSceneEXT; +GLEW_FUN_EXPORT PFNGLENDSCENEEXTPROC __glewEndSceneEXT; + +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BEXTPROC __glewSecondaryColor3bEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BVEXTPROC __glewSecondaryColor3bvEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DEXTPROC __glewSecondaryColor3dEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DVEXTPROC __glewSecondaryColor3dvEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FEXTPROC __glewSecondaryColor3fEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FVEXTPROC __glewSecondaryColor3fvEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IEXTPROC __glewSecondaryColor3iEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IVEXTPROC __glewSecondaryColor3ivEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SEXTPROC __glewSecondaryColor3sEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SVEXTPROC __glewSecondaryColor3svEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBEXTPROC __glewSecondaryColor3ubEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBVEXTPROC __glewSecondaryColor3ubvEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIEXTPROC __glewSecondaryColor3uiEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIVEXTPROC __glewSecondaryColor3uivEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USEXTPROC __glewSecondaryColor3usEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USVEXTPROC __glewSecondaryColor3usvEXT; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTEREXTPROC __glewSecondaryColorPointerEXT; + +GLEW_FUN_EXPORT PFNGLACTIVEPROGRAMEXTPROC __glewActiveProgramEXT; +GLEW_FUN_EXPORT PFNGLCREATESHADERPROGRAMEXTPROC __glewCreateShaderProgramEXT; +GLEW_FUN_EXPORT PFNGLUSESHADERPROGRAMEXTPROC __glewUseShaderProgramEXT; + +GLEW_FUN_EXPORT PFNGLBINDIMAGETEXTUREEXTPROC __glewBindImageTextureEXT; +GLEW_FUN_EXPORT PFNGLMEMORYBARRIEREXTPROC __glewMemoryBarrierEXT; + +GLEW_FUN_EXPORT PFNGLACTIVESTENCILFACEEXTPROC __glewActiveStencilFaceEXT; + +GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE1DEXTPROC __glewTexSubImage1DEXT; +GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE2DEXTPROC __glewTexSubImage2DEXT; +GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE3DEXTPROC __glewTexSubImage3DEXT; + +GLEW_FUN_EXPORT PFNGLTEXIMAGE3DEXTPROC __glewTexImage3DEXT; + +GLEW_FUN_EXPORT PFNGLTEXBUFFEREXTPROC __glewTexBufferEXT; + +GLEW_FUN_EXPORT PFNGLCLEARCOLORIIEXTPROC __glewClearColorIiEXT; +GLEW_FUN_EXPORT PFNGLCLEARCOLORIUIEXTPROC __glewClearColorIuiEXT; +GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIIVEXTPROC __glewGetTexParameterIivEXT; +GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIUIVEXTPROC __glewGetTexParameterIuivEXT; +GLEW_FUN_EXPORT PFNGLTEXPARAMETERIIVEXTPROC __glewTexParameterIivEXT; +GLEW_FUN_EXPORT PFNGLTEXPARAMETERIUIVEXTPROC __glewTexParameterIuivEXT; + +GLEW_FUN_EXPORT PFNGLARETEXTURESRESIDENTEXTPROC __glewAreTexturesResidentEXT; +GLEW_FUN_EXPORT PFNGLBINDTEXTUREEXTPROC __glewBindTextureEXT; +GLEW_FUN_EXPORT PFNGLDELETETEXTURESEXTPROC __glewDeleteTexturesEXT; +GLEW_FUN_EXPORT PFNGLGENTEXTURESEXTPROC __glewGenTexturesEXT; +GLEW_FUN_EXPORT PFNGLISTEXTUREEXTPROC __glewIsTextureEXT; +GLEW_FUN_EXPORT PFNGLPRIORITIZETEXTURESEXTPROC __glewPrioritizeTexturesEXT; + +GLEW_FUN_EXPORT PFNGLTEXTURENORMALEXTPROC __glewTextureNormalEXT; + +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTI64VEXTPROC __glewGetQueryObjecti64vEXT; +GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUI64VEXTPROC __glewGetQueryObjectui64vEXT; + +GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKEXTPROC __glewBeginTransformFeedbackEXT; +GLEW_FUN_EXPORT PFNGLBINDBUFFERBASEEXTPROC __glewBindBufferBaseEXT; +GLEW_FUN_EXPORT PFNGLBINDBUFFEROFFSETEXTPROC __glewBindBufferOffsetEXT; +GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGEEXTPROC __glewBindBufferRangeEXT; +GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKEXTPROC __glewEndTransformFeedbackEXT; +GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC __glewGetTransformFeedbackVaryingEXT; +GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC __glewTransformFeedbackVaryingsEXT; + +GLEW_FUN_EXPORT PFNGLARRAYELEMENTEXTPROC __glewArrayElementEXT; +GLEW_FUN_EXPORT PFNGLCOLORPOINTEREXTPROC __glewColorPointerEXT; +GLEW_FUN_EXPORT PFNGLDRAWARRAYSEXTPROC __glewDrawArraysEXT; +GLEW_FUN_EXPORT PFNGLEDGEFLAGPOINTEREXTPROC __glewEdgeFlagPointerEXT; +GLEW_FUN_EXPORT PFNGLGETPOINTERVEXTPROC __glewGetPointervEXT; +GLEW_FUN_EXPORT PFNGLINDEXPOINTEREXTPROC __glewIndexPointerEXT; +GLEW_FUN_EXPORT PFNGLNORMALPOINTEREXTPROC __glewNormalPointerEXT; +GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTEREXTPROC __glewTexCoordPointerEXT; +GLEW_FUN_EXPORT PFNGLVERTEXPOINTEREXTPROC __glewVertexPointerEXT; + +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLDVEXTPROC __glewGetVertexAttribLdvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC __glewVertexArrayVertexAttribLOffsetEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DEXTPROC __glewVertexAttribL1dEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DVEXTPROC __glewVertexAttribL1dvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DEXTPROC __glewVertexAttribL2dEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DVEXTPROC __glewVertexAttribL2dvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DEXTPROC __glewVertexAttribL3dEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DVEXTPROC __glewVertexAttribL3dvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DEXTPROC __glewVertexAttribL4dEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DVEXTPROC __glewVertexAttribL4dvEXT; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLPOINTEREXTPROC __glewVertexAttribLPointerEXT; + +GLEW_FUN_EXPORT PFNGLBEGINVERTEXSHADEREXTPROC __glewBeginVertexShaderEXT; +GLEW_FUN_EXPORT PFNGLBINDLIGHTPARAMETEREXTPROC __glewBindLightParameterEXT; +GLEW_FUN_EXPORT PFNGLBINDMATERIALPARAMETEREXTPROC __glewBindMaterialParameterEXT; +GLEW_FUN_EXPORT PFNGLBINDPARAMETEREXTPROC __glewBindParameterEXT; +GLEW_FUN_EXPORT PFNGLBINDTEXGENPARAMETEREXTPROC __glewBindTexGenParameterEXT; +GLEW_FUN_EXPORT PFNGLBINDTEXTUREUNITPARAMETEREXTPROC __glewBindTextureUnitParameterEXT; +GLEW_FUN_EXPORT PFNGLBINDVERTEXSHADEREXTPROC __glewBindVertexShaderEXT; +GLEW_FUN_EXPORT PFNGLDELETEVERTEXSHADEREXTPROC __glewDeleteVertexShaderEXT; +GLEW_FUN_EXPORT PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC __glewDisableVariantClientStateEXT; +GLEW_FUN_EXPORT PFNGLENABLEVARIANTCLIENTSTATEEXTPROC __glewEnableVariantClientStateEXT; +GLEW_FUN_EXPORT PFNGLENDVERTEXSHADEREXTPROC __glewEndVertexShaderEXT; +GLEW_FUN_EXPORT PFNGLEXTRACTCOMPONENTEXTPROC __glewExtractComponentEXT; +GLEW_FUN_EXPORT PFNGLGENSYMBOLSEXTPROC __glewGenSymbolsEXT; +GLEW_FUN_EXPORT PFNGLGENVERTEXSHADERSEXTPROC __glewGenVertexShadersEXT; +GLEW_FUN_EXPORT PFNGLGETINVARIANTBOOLEANVEXTPROC __glewGetInvariantBooleanvEXT; +GLEW_FUN_EXPORT PFNGLGETINVARIANTFLOATVEXTPROC __glewGetInvariantFloatvEXT; +GLEW_FUN_EXPORT PFNGLGETINVARIANTINTEGERVEXTPROC __glewGetInvariantIntegervEXT; +GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC __glewGetLocalConstantBooleanvEXT; +GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTFLOATVEXTPROC __glewGetLocalConstantFloatvEXT; +GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTINTEGERVEXTPROC __glewGetLocalConstantIntegervEXT; +GLEW_FUN_EXPORT PFNGLGETVARIANTBOOLEANVEXTPROC __glewGetVariantBooleanvEXT; +GLEW_FUN_EXPORT PFNGLGETVARIANTFLOATVEXTPROC __glewGetVariantFloatvEXT; +GLEW_FUN_EXPORT PFNGLGETVARIANTINTEGERVEXTPROC __glewGetVariantIntegervEXT; +GLEW_FUN_EXPORT PFNGLGETVARIANTPOINTERVEXTPROC __glewGetVariantPointervEXT; +GLEW_FUN_EXPORT PFNGLINSERTCOMPONENTEXTPROC __glewInsertComponentEXT; +GLEW_FUN_EXPORT PFNGLISVARIANTENABLEDEXTPROC __glewIsVariantEnabledEXT; +GLEW_FUN_EXPORT PFNGLSETINVARIANTEXTPROC __glewSetInvariantEXT; +GLEW_FUN_EXPORT PFNGLSETLOCALCONSTANTEXTPROC __glewSetLocalConstantEXT; +GLEW_FUN_EXPORT PFNGLSHADEROP1EXTPROC __glewShaderOp1EXT; +GLEW_FUN_EXPORT PFNGLSHADEROP2EXTPROC __glewShaderOp2EXT; +GLEW_FUN_EXPORT PFNGLSHADEROP3EXTPROC __glewShaderOp3EXT; +GLEW_FUN_EXPORT PFNGLSWIZZLEEXTPROC __glewSwizzleEXT; +GLEW_FUN_EXPORT PFNGLVARIANTPOINTEREXTPROC __glewVariantPointerEXT; +GLEW_FUN_EXPORT PFNGLVARIANTBVEXTPROC __glewVariantbvEXT; +GLEW_FUN_EXPORT PFNGLVARIANTDVEXTPROC __glewVariantdvEXT; +GLEW_FUN_EXPORT PFNGLVARIANTFVEXTPROC __glewVariantfvEXT; +GLEW_FUN_EXPORT PFNGLVARIANTIVEXTPROC __glewVariantivEXT; +GLEW_FUN_EXPORT PFNGLVARIANTSVEXTPROC __glewVariantsvEXT; +GLEW_FUN_EXPORT PFNGLVARIANTUBVEXTPROC __glewVariantubvEXT; +GLEW_FUN_EXPORT PFNGLVARIANTUIVEXTPROC __glewVariantuivEXT; +GLEW_FUN_EXPORT PFNGLVARIANTUSVEXTPROC __glewVariantusvEXT; +GLEW_FUN_EXPORT PFNGLWRITEMASKEXTPROC __glewWriteMaskEXT; + +GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTPOINTEREXTPROC __glewVertexWeightPointerEXT; +GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTFEXTPROC __glewVertexWeightfEXT; +GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTFVEXTPROC __glewVertexWeightfvEXT; + +GLEW_FUN_EXPORT PFNGLFRAMETERMINATORGREMEDYPROC __glewFrameTerminatorGREMEDY; + +GLEW_FUN_EXPORT PFNGLSTRINGMARKERGREMEDYPROC __glewStringMarkerGREMEDY; + +GLEW_FUN_EXPORT PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC __glewGetImageTransformParameterfvHP; +GLEW_FUN_EXPORT PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC __glewGetImageTransformParameterivHP; +GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERFHPPROC __glewImageTransformParameterfHP; +GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERFVHPPROC __glewImageTransformParameterfvHP; +GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERIHPPROC __glewImageTransformParameteriHP; +GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERIVHPPROC __glewImageTransformParameterivHP; + +GLEW_FUN_EXPORT PFNGLMULTIMODEDRAWARRAYSIBMPROC __glewMultiModeDrawArraysIBM; +GLEW_FUN_EXPORT PFNGLMULTIMODEDRAWELEMENTSIBMPROC __glewMultiModeDrawElementsIBM; + +GLEW_FUN_EXPORT PFNGLCOLORPOINTERLISTIBMPROC __glewColorPointerListIBM; +GLEW_FUN_EXPORT PFNGLEDGEFLAGPOINTERLISTIBMPROC __glewEdgeFlagPointerListIBM; +GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTERLISTIBMPROC __glewFogCoordPointerListIBM; +GLEW_FUN_EXPORT PFNGLINDEXPOINTERLISTIBMPROC __glewIndexPointerListIBM; +GLEW_FUN_EXPORT PFNGLNORMALPOINTERLISTIBMPROC __glewNormalPointerListIBM; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTERLISTIBMPROC __glewSecondaryColorPointerListIBM; +GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTERLISTIBMPROC __glewTexCoordPointerListIBM; +GLEW_FUN_EXPORT PFNGLVERTEXPOINTERLISTIBMPROC __glewVertexPointerListIBM; + +GLEW_FUN_EXPORT PFNGLCOLORPOINTERVINTELPROC __glewColorPointervINTEL; +GLEW_FUN_EXPORT PFNGLNORMALPOINTERVINTELPROC __glewNormalPointervINTEL; +GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTERVINTELPROC __glewTexCoordPointervINTEL; +GLEW_FUN_EXPORT PFNGLVERTEXPOINTERVINTELPROC __glewVertexPointervINTEL; + +GLEW_FUN_EXPORT PFNGLTEXSCISSORFUNCINTELPROC __glewTexScissorFuncINTEL; +GLEW_FUN_EXPORT PFNGLTEXSCISSORINTELPROC __glewTexScissorINTEL; + +GLEW_FUN_EXPORT PFNGLBUFFERREGIONENABLEDEXTPROC __glewBufferRegionEnabledEXT; +GLEW_FUN_EXPORT PFNGLDELETEBUFFERREGIONEXTPROC __glewDeleteBufferRegionEXT; +GLEW_FUN_EXPORT PFNGLDRAWBUFFERREGIONEXTPROC __glewDrawBufferRegionEXT; +GLEW_FUN_EXPORT PFNGLNEWBUFFERREGIONEXTPROC __glewNewBufferRegionEXT; +GLEW_FUN_EXPORT PFNGLREADBUFFERREGIONEXTPROC __glewReadBufferRegionEXT; + +GLEW_FUN_EXPORT PFNGLRESIZEBUFFERSMESAPROC __glewResizeBuffersMESA; + +GLEW_FUN_EXPORT PFNGLWINDOWPOS2DMESAPROC __glewWindowPos2dMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVMESAPROC __glewWindowPos2dvMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2FMESAPROC __glewWindowPos2fMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVMESAPROC __glewWindowPos2fvMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2IMESAPROC __glewWindowPos2iMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVMESAPROC __glewWindowPos2ivMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2SMESAPROC __glewWindowPos2sMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVMESAPROC __glewWindowPos2svMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3DMESAPROC __glewWindowPos3dMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVMESAPROC __glewWindowPos3dvMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3FMESAPROC __glewWindowPos3fMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVMESAPROC __glewWindowPos3fvMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3IMESAPROC __glewWindowPos3iMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVMESAPROC __glewWindowPos3ivMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3SMESAPROC __glewWindowPos3sMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVMESAPROC __glewWindowPos3svMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4DMESAPROC __glewWindowPos4dMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4DVMESAPROC __glewWindowPos4dvMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4FMESAPROC __glewWindowPos4fMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4FVMESAPROC __glewWindowPos4fvMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4IMESAPROC __glewWindowPos4iMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4IVMESAPROC __glewWindowPos4ivMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4SMESAPROC __glewWindowPos4sMESA; +GLEW_FUN_EXPORT PFNGLWINDOWPOS4SVMESAPROC __glewWindowPos4svMESA; + +GLEW_FUN_EXPORT PFNGLBEGINCONDITIONALRENDERNVPROC __glewBeginConditionalRenderNV; +GLEW_FUN_EXPORT PFNGLENDCONDITIONALRENDERNVPROC __glewEndConditionalRenderNV; + +GLEW_FUN_EXPORT PFNGLCOPYIMAGESUBDATANVPROC __glewCopyImageSubDataNV; + +GLEW_FUN_EXPORT PFNGLCLEARDEPTHDNVPROC __glewClearDepthdNV; +GLEW_FUN_EXPORT PFNGLDEPTHBOUNDSDNVPROC __glewDepthBoundsdNV; +GLEW_FUN_EXPORT PFNGLDEPTHRANGEDNVPROC __glewDepthRangedNV; + +GLEW_FUN_EXPORT PFNGLEVALMAPSNVPROC __glewEvalMapsNV; +GLEW_FUN_EXPORT PFNGLGETMAPATTRIBPARAMETERFVNVPROC __glewGetMapAttribParameterfvNV; +GLEW_FUN_EXPORT PFNGLGETMAPATTRIBPARAMETERIVNVPROC __glewGetMapAttribParameterivNV; +GLEW_FUN_EXPORT PFNGLGETMAPCONTROLPOINTSNVPROC __glewGetMapControlPointsNV; +GLEW_FUN_EXPORT PFNGLGETMAPPARAMETERFVNVPROC __glewGetMapParameterfvNV; +GLEW_FUN_EXPORT PFNGLGETMAPPARAMETERIVNVPROC __glewGetMapParameterivNV; +GLEW_FUN_EXPORT PFNGLMAPCONTROLPOINTSNVPROC __glewMapControlPointsNV; +GLEW_FUN_EXPORT PFNGLMAPPARAMETERFVNVPROC __glewMapParameterfvNV; +GLEW_FUN_EXPORT PFNGLMAPPARAMETERIVNVPROC __glewMapParameterivNV; + +GLEW_FUN_EXPORT PFNGLGETMULTISAMPLEFVNVPROC __glewGetMultisamplefvNV; +GLEW_FUN_EXPORT PFNGLSAMPLEMASKINDEXEDNVPROC __glewSampleMaskIndexedNV; +GLEW_FUN_EXPORT PFNGLTEXRENDERBUFFERNVPROC __glewTexRenderbufferNV; + +GLEW_FUN_EXPORT PFNGLDELETEFENCESNVPROC __glewDeleteFencesNV; +GLEW_FUN_EXPORT PFNGLFINISHFENCENVPROC __glewFinishFenceNV; +GLEW_FUN_EXPORT PFNGLGENFENCESNVPROC __glewGenFencesNV; +GLEW_FUN_EXPORT PFNGLGETFENCEIVNVPROC __glewGetFenceivNV; +GLEW_FUN_EXPORT PFNGLISFENCENVPROC __glewIsFenceNV; +GLEW_FUN_EXPORT PFNGLSETFENCENVPROC __glewSetFenceNV; +GLEW_FUN_EXPORT PFNGLTESTFENCENVPROC __glewTestFenceNV; + +GLEW_FUN_EXPORT PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC __glewGetProgramNamedParameterdvNV; +GLEW_FUN_EXPORT PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC __glewGetProgramNamedParameterfvNV; +GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4DNVPROC __glewProgramNamedParameter4dNV; +GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC __glewProgramNamedParameter4dvNV; +GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4FNVPROC __glewProgramNamedParameter4fNV; +GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC __glewProgramNamedParameter4fvNV; + +GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC __glewRenderbufferStorageMultisampleCoverageNV; + +GLEW_FUN_EXPORT PFNGLPROGRAMVERTEXLIMITNVPROC __glewProgramVertexLimitNV; + +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4INVPROC __glewProgramEnvParameterI4iNV; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4IVNVPROC __glewProgramEnvParameterI4ivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4UINVPROC __glewProgramEnvParameterI4uiNV; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4UIVNVPROC __glewProgramEnvParameterI4uivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERSI4IVNVPROC __glewProgramEnvParametersI4ivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC __glewProgramEnvParametersI4uivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4INVPROC __glewProgramLocalParameterI4iNV; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC __glewProgramLocalParameterI4ivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4UINVPROC __glewProgramLocalParameterI4uiNV; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC __glewProgramLocalParameterI4uivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC __glewProgramLocalParametersI4ivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC __glewProgramLocalParametersI4uivNV; + +GLEW_FUN_EXPORT PFNGLGETUNIFORMI64VNVPROC __glewGetUniformi64vNV; +GLEW_FUN_EXPORT PFNGLGETUNIFORMUI64VNVPROC __glewGetUniformui64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1I64NVPROC __glewProgramUniform1i64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1I64VNVPROC __glewProgramUniform1i64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UI64NVPROC __glewProgramUniform1ui64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UI64VNVPROC __glewProgramUniform1ui64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2I64NVPROC __glewProgramUniform2i64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2I64VNVPROC __glewProgramUniform2i64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UI64NVPROC __glewProgramUniform2ui64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UI64VNVPROC __glewProgramUniform2ui64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3I64NVPROC __glewProgramUniform3i64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3I64VNVPROC __glewProgramUniform3i64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UI64NVPROC __glewProgramUniform3ui64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UI64VNVPROC __glewProgramUniform3ui64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4I64NVPROC __glewProgramUniform4i64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4I64VNVPROC __glewProgramUniform4i64vNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UI64NVPROC __glewProgramUniform4ui64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UI64VNVPROC __glewProgramUniform4ui64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM1I64NVPROC __glewUniform1i64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM1I64VNVPROC __glewUniform1i64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM1UI64NVPROC __glewUniform1ui64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM1UI64VNVPROC __glewUniform1ui64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM2I64NVPROC __glewUniform2i64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM2I64VNVPROC __glewUniform2i64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM2UI64NVPROC __glewUniform2ui64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM2UI64VNVPROC __glewUniform2ui64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM3I64NVPROC __glewUniform3i64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM3I64VNVPROC __glewUniform3i64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM3UI64NVPROC __glewUniform3ui64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM3UI64VNVPROC __glewUniform3ui64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM4I64NVPROC __glewUniform4i64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM4I64VNVPROC __glewUniform4i64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORM4UI64NVPROC __glewUniform4ui64NV; +GLEW_FUN_EXPORT PFNGLUNIFORM4UI64VNVPROC __glewUniform4ui64vNV; + +GLEW_FUN_EXPORT PFNGLCOLOR3HNVPROC __glewColor3hNV; +GLEW_FUN_EXPORT PFNGLCOLOR3HVNVPROC __glewColor3hvNV; +GLEW_FUN_EXPORT PFNGLCOLOR4HNVPROC __glewColor4hNV; +GLEW_FUN_EXPORT PFNGLCOLOR4HVNVPROC __glewColor4hvNV; +GLEW_FUN_EXPORT PFNGLFOGCOORDHNVPROC __glewFogCoordhNV; +GLEW_FUN_EXPORT PFNGLFOGCOORDHVNVPROC __glewFogCoordhvNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1HNVPROC __glewMultiTexCoord1hNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1HVNVPROC __glewMultiTexCoord1hvNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2HNVPROC __glewMultiTexCoord2hNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2HVNVPROC __glewMultiTexCoord2hvNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3HNVPROC __glewMultiTexCoord3hNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3HVNVPROC __glewMultiTexCoord3hvNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4HNVPROC __glewMultiTexCoord4hNV; +GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4HVNVPROC __glewMultiTexCoord4hvNV; +GLEW_FUN_EXPORT PFNGLNORMAL3HNVPROC __glewNormal3hNV; +GLEW_FUN_EXPORT PFNGLNORMAL3HVNVPROC __glewNormal3hvNV; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3HNVPROC __glewSecondaryColor3hNV; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3HVNVPROC __glewSecondaryColor3hvNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD1HNVPROC __glewTexCoord1hNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD1HVNVPROC __glewTexCoord1hvNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD2HNVPROC __glewTexCoord2hNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD2HVNVPROC __glewTexCoord2hvNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD3HNVPROC __glewTexCoord3hNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD3HVNVPROC __glewTexCoord3hvNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD4HNVPROC __glewTexCoord4hNV; +GLEW_FUN_EXPORT PFNGLTEXCOORD4HVNVPROC __glewTexCoord4hvNV; +GLEW_FUN_EXPORT PFNGLVERTEX2HNVPROC __glewVertex2hNV; +GLEW_FUN_EXPORT PFNGLVERTEX2HVNVPROC __glewVertex2hvNV; +GLEW_FUN_EXPORT PFNGLVERTEX3HNVPROC __glewVertex3hNV; +GLEW_FUN_EXPORT PFNGLVERTEX3HVNVPROC __glewVertex3hvNV; +GLEW_FUN_EXPORT PFNGLVERTEX4HNVPROC __glewVertex4hNV; +GLEW_FUN_EXPORT PFNGLVERTEX4HVNVPROC __glewVertex4hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1HNVPROC __glewVertexAttrib1hNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1HVNVPROC __glewVertexAttrib1hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2HNVPROC __glewVertexAttrib2hNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2HVNVPROC __glewVertexAttrib2hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3HNVPROC __glewVertexAttrib3hNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3HVNVPROC __glewVertexAttrib3hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4HNVPROC __glewVertexAttrib4hNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4HVNVPROC __glewVertexAttrib4hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1HVNVPROC __glewVertexAttribs1hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2HVNVPROC __glewVertexAttribs2hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3HVNVPROC __glewVertexAttribs3hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4HVNVPROC __glewVertexAttribs4hvNV; +GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTHNVPROC __glewVertexWeighthNV; +GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTHVNVPROC __glewVertexWeighthvNV; + +GLEW_FUN_EXPORT PFNGLBEGINOCCLUSIONQUERYNVPROC __glewBeginOcclusionQueryNV; +GLEW_FUN_EXPORT PFNGLDELETEOCCLUSIONQUERIESNVPROC __glewDeleteOcclusionQueriesNV; +GLEW_FUN_EXPORT PFNGLENDOCCLUSIONQUERYNVPROC __glewEndOcclusionQueryNV; +GLEW_FUN_EXPORT PFNGLGENOCCLUSIONQUERIESNVPROC __glewGenOcclusionQueriesNV; +GLEW_FUN_EXPORT PFNGLGETOCCLUSIONQUERYIVNVPROC __glewGetOcclusionQueryivNV; +GLEW_FUN_EXPORT PFNGLGETOCCLUSIONQUERYUIVNVPROC __glewGetOcclusionQueryuivNV; +GLEW_FUN_EXPORT PFNGLISOCCLUSIONQUERYNVPROC __glewIsOcclusionQueryNV; + +GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC __glewProgramBufferParametersIivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC __glewProgramBufferParametersIuivNV; +GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC __glewProgramBufferParametersfvNV; + +GLEW_FUN_EXPORT PFNGLFLUSHPIXELDATARANGENVPROC __glewFlushPixelDataRangeNV; +GLEW_FUN_EXPORT PFNGLPIXELDATARANGENVPROC __glewPixelDataRangeNV; + +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERINVPROC __glewPointParameteriNV; +GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIVNVPROC __glewPointParameterivNV; + +GLEW_FUN_EXPORT PFNGLGETVIDEOI64VNVPROC __glewGetVideoi64vNV; +GLEW_FUN_EXPORT PFNGLGETVIDEOIVNVPROC __glewGetVideoivNV; +GLEW_FUN_EXPORT PFNGLGETVIDEOUI64VNVPROC __glewGetVideoui64vNV; +GLEW_FUN_EXPORT PFNGLGETVIDEOUIVNVPROC __glewGetVideouivNV; +GLEW_FUN_EXPORT PFNGLPRESENTFRAMEDUALFILLNVPROC __glewPresentFrameDualFillNV; +GLEW_FUN_EXPORT PFNGLPRESENTFRAMEKEYEDNVPROC __glewPresentFrameKeyedNV; + +GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTINDEXNVPROC __glewPrimitiveRestartIndexNV; +GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTNVPROC __glewPrimitiveRestartNV; + +GLEW_FUN_EXPORT PFNGLCOMBINERINPUTNVPROC __glewCombinerInputNV; +GLEW_FUN_EXPORT PFNGLCOMBINEROUTPUTNVPROC __glewCombinerOutputNV; +GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERFNVPROC __glewCombinerParameterfNV; +GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERFVNVPROC __glewCombinerParameterfvNV; +GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERINVPROC __glewCombinerParameteriNV; +GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERIVNVPROC __glewCombinerParameterivNV; +GLEW_FUN_EXPORT PFNGLFINALCOMBINERINPUTNVPROC __glewFinalCombinerInputNV; +GLEW_FUN_EXPORT PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC __glewGetCombinerInputParameterfvNV; +GLEW_FUN_EXPORT PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC __glewGetCombinerInputParameterivNV; +GLEW_FUN_EXPORT PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC __glewGetCombinerOutputParameterfvNV; +GLEW_FUN_EXPORT PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC __glewGetCombinerOutputParameterivNV; +GLEW_FUN_EXPORT PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC __glewGetFinalCombinerInputParameterfvNV; +GLEW_FUN_EXPORT PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC __glewGetFinalCombinerInputParameterivNV; + +GLEW_FUN_EXPORT PFNGLCOMBINERSTAGEPARAMETERFVNVPROC __glewCombinerStageParameterfvNV; +GLEW_FUN_EXPORT PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC __glewGetCombinerStageParameterfvNV; + +GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERUI64VNVPROC __glewGetBufferParameterui64vNV; +GLEW_FUN_EXPORT PFNGLGETINTEGERUI64VNVPROC __glewGetIntegerui64vNV; +GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC __glewGetNamedBufferParameterui64vNV; +GLEW_FUN_EXPORT PFNGLISBUFFERRESIDENTNVPROC __glewIsBufferResidentNV; +GLEW_FUN_EXPORT PFNGLISNAMEDBUFFERRESIDENTNVPROC __glewIsNamedBufferResidentNV; +GLEW_FUN_EXPORT PFNGLMAKEBUFFERNONRESIDENTNVPROC __glewMakeBufferNonResidentNV; +GLEW_FUN_EXPORT PFNGLMAKEBUFFERRESIDENTNVPROC __glewMakeBufferResidentNV; +GLEW_FUN_EXPORT PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC __glewMakeNamedBufferNonResidentNV; +GLEW_FUN_EXPORT PFNGLMAKENAMEDBUFFERRESIDENTNVPROC __glewMakeNamedBufferResidentNV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMUI64NVPROC __glewProgramUniformui64NV; +GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMUI64VNVPROC __glewProgramUniformui64vNV; +GLEW_FUN_EXPORT PFNGLUNIFORMUI64NVPROC __glewUniformui64NV; +GLEW_FUN_EXPORT PFNGLUNIFORMUI64VNVPROC __glewUniformui64vNV; + +GLEW_FUN_EXPORT PFNGLTEXTUREBARRIERNVPROC __glewTextureBarrierNV; + +GLEW_FUN_EXPORT PFNGLACTIVEVARYINGNVPROC __glewActiveVaryingNV; +GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKNVPROC __glewBeginTransformFeedbackNV; +GLEW_FUN_EXPORT PFNGLBINDBUFFERBASENVPROC __glewBindBufferBaseNV; +GLEW_FUN_EXPORT PFNGLBINDBUFFEROFFSETNVPROC __glewBindBufferOffsetNV; +GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGENVPROC __glewBindBufferRangeNV; +GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKNVPROC __glewEndTransformFeedbackNV; +GLEW_FUN_EXPORT PFNGLGETACTIVEVARYINGNVPROC __glewGetActiveVaryingNV; +GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC __glewGetTransformFeedbackVaryingNV; +GLEW_FUN_EXPORT PFNGLGETVARYINGLOCATIONNVPROC __glewGetVaryingLocationNV; +GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC __glewTransformFeedbackAttribsNV; +GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC __glewTransformFeedbackVaryingsNV; + +GLEW_FUN_EXPORT PFNGLBINDTRANSFORMFEEDBACKNVPROC __glewBindTransformFeedbackNV; +GLEW_FUN_EXPORT PFNGLDELETETRANSFORMFEEDBACKSNVPROC __glewDeleteTransformFeedbacksNV; +GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKNVPROC __glewDrawTransformFeedbackNV; +GLEW_FUN_EXPORT PFNGLGENTRANSFORMFEEDBACKSNVPROC __glewGenTransformFeedbacksNV; +GLEW_FUN_EXPORT PFNGLISTRANSFORMFEEDBACKNVPROC __glewIsTransformFeedbackNV; +GLEW_FUN_EXPORT PFNGLPAUSETRANSFORMFEEDBACKNVPROC __glewPauseTransformFeedbackNV; +GLEW_FUN_EXPORT PFNGLRESUMETRANSFORMFEEDBACKNVPROC __glewResumeTransformFeedbackNV; + +GLEW_FUN_EXPORT PFNGLFLUSHVERTEXARRAYRANGENVPROC __glewFlushVertexArrayRangeNV; +GLEW_FUN_EXPORT PFNGLVERTEXARRAYRANGENVPROC __glewVertexArrayRangeNV; + +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLI64VNVPROC __glewGetVertexAttribLi64vNV; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLUI64VNVPROC __glewGetVertexAttribLui64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1I64NVPROC __glewVertexAttribL1i64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1I64VNVPROC __glewVertexAttribL1i64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64NVPROC __glewVertexAttribL1ui64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64VNVPROC __glewVertexAttribL1ui64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2I64NVPROC __glewVertexAttribL2i64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2I64VNVPROC __glewVertexAttribL2i64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2UI64NVPROC __glewVertexAttribL2ui64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2UI64VNVPROC __glewVertexAttribL2ui64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3I64NVPROC __glewVertexAttribL3i64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3I64VNVPROC __glewVertexAttribL3i64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3UI64NVPROC __glewVertexAttribL3ui64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3UI64VNVPROC __glewVertexAttribL3ui64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4I64NVPROC __glewVertexAttribL4i64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4I64VNVPROC __glewVertexAttribL4i64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4UI64NVPROC __glewVertexAttribL4ui64NV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4UI64VNVPROC __glewVertexAttribL4ui64vNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLFORMATNVPROC __glewVertexAttribLFormatNV; + +GLEW_FUN_EXPORT PFNGLBUFFERADDRESSRANGENVPROC __glewBufferAddressRangeNV; +GLEW_FUN_EXPORT PFNGLCOLORFORMATNVPROC __glewColorFormatNV; +GLEW_FUN_EXPORT PFNGLEDGEFLAGFORMATNVPROC __glewEdgeFlagFormatNV; +GLEW_FUN_EXPORT PFNGLFOGCOORDFORMATNVPROC __glewFogCoordFormatNV; +GLEW_FUN_EXPORT PFNGLGETINTEGERUI64I_VNVPROC __glewGetIntegerui64i_vNV; +GLEW_FUN_EXPORT PFNGLINDEXFORMATNVPROC __glewIndexFormatNV; +GLEW_FUN_EXPORT PFNGLNORMALFORMATNVPROC __glewNormalFormatNV; +GLEW_FUN_EXPORT PFNGLSECONDARYCOLORFORMATNVPROC __glewSecondaryColorFormatNV; +GLEW_FUN_EXPORT PFNGLTEXCOORDFORMATNVPROC __glewTexCoordFormatNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBFORMATNVPROC __glewVertexAttribFormatNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIFORMATNVPROC __glewVertexAttribIFormatNV; +GLEW_FUN_EXPORT PFNGLVERTEXFORMATNVPROC __glewVertexFormatNV; + +GLEW_FUN_EXPORT PFNGLAREPROGRAMSRESIDENTNVPROC __glewAreProgramsResidentNV; +GLEW_FUN_EXPORT PFNGLBINDPROGRAMNVPROC __glewBindProgramNV; +GLEW_FUN_EXPORT PFNGLDELETEPROGRAMSNVPROC __glewDeleteProgramsNV; +GLEW_FUN_EXPORT PFNGLEXECUTEPROGRAMNVPROC __glewExecuteProgramNV; +GLEW_FUN_EXPORT PFNGLGENPROGRAMSNVPROC __glewGenProgramsNV; +GLEW_FUN_EXPORT PFNGLGETPROGRAMPARAMETERDVNVPROC __glewGetProgramParameterdvNV; +GLEW_FUN_EXPORT PFNGLGETPROGRAMPARAMETERFVNVPROC __glewGetProgramParameterfvNV; +GLEW_FUN_EXPORT PFNGLGETPROGRAMSTRINGNVPROC __glewGetProgramStringNV; +GLEW_FUN_EXPORT PFNGLGETPROGRAMIVNVPROC __glewGetProgramivNV; +GLEW_FUN_EXPORT PFNGLGETTRACKMATRIXIVNVPROC __glewGetTrackMatrixivNV; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVNVPROC __glewGetVertexAttribPointervNV; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVNVPROC __glewGetVertexAttribdvNV; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVNVPROC __glewGetVertexAttribfvNV; +GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVNVPROC __glewGetVertexAttribivNV; +GLEW_FUN_EXPORT PFNGLISPROGRAMNVPROC __glewIsProgramNV; +GLEW_FUN_EXPORT PFNGLLOADPROGRAMNVPROC __glewLoadProgramNV; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4DNVPROC __glewProgramParameter4dNV; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4DVNVPROC __glewProgramParameter4dvNV; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4FNVPROC __glewProgramParameter4fNV; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4FVNVPROC __glewProgramParameter4fvNV; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERS4DVNVPROC __glewProgramParameters4dvNV; +GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERS4FVNVPROC __glewProgramParameters4fvNV; +GLEW_FUN_EXPORT PFNGLREQUESTRESIDENTPROGRAMSNVPROC __glewRequestResidentProgramsNV; +GLEW_FUN_EXPORT PFNGLTRACKMATRIXNVPROC __glewTrackMatrixNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DNVPROC __glewVertexAttrib1dNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVNVPROC __glewVertexAttrib1dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FNVPROC __glewVertexAttrib1fNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVNVPROC __glewVertexAttrib1fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SNVPROC __glewVertexAttrib1sNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVNVPROC __glewVertexAttrib1svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DNVPROC __glewVertexAttrib2dNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVNVPROC __glewVertexAttrib2dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FNVPROC __glewVertexAttrib2fNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVNVPROC __glewVertexAttrib2fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SNVPROC __glewVertexAttrib2sNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVNVPROC __glewVertexAttrib2svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DNVPROC __glewVertexAttrib3dNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVNVPROC __glewVertexAttrib3dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FNVPROC __glewVertexAttrib3fNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVNVPROC __glewVertexAttrib3fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SNVPROC __glewVertexAttrib3sNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVNVPROC __glewVertexAttrib3svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DNVPROC __glewVertexAttrib4dNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVNVPROC __glewVertexAttrib4dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FNVPROC __glewVertexAttrib4fNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVNVPROC __glewVertexAttrib4fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SNVPROC __glewVertexAttrib4sNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVNVPROC __glewVertexAttrib4svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBNVPROC __glewVertexAttrib4ubNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVNVPROC __glewVertexAttrib4ubvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERNVPROC __glewVertexAttribPointerNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1DVNVPROC __glewVertexAttribs1dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1FVNVPROC __glewVertexAttribs1fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1SVNVPROC __glewVertexAttribs1svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2DVNVPROC __glewVertexAttribs2dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2FVNVPROC __glewVertexAttribs2fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2SVNVPROC __glewVertexAttribs2svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3DVNVPROC __glewVertexAttribs3dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3FVNVPROC __glewVertexAttribs3fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3SVNVPROC __glewVertexAttribs3svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4DVNVPROC __glewVertexAttribs4dvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4FVNVPROC __glewVertexAttribs4fvNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4SVNVPROC __glewVertexAttribs4svNV; +GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4UBVNVPROC __glewVertexAttribs4ubvNV; + +GLEW_FUN_EXPORT PFNGLCLEARDEPTHFOESPROC __glewClearDepthfOES; +GLEW_FUN_EXPORT PFNGLCLIPPLANEFOESPROC __glewClipPlanefOES; +GLEW_FUN_EXPORT PFNGLDEPTHRANGEFOESPROC __glewDepthRangefOES; +GLEW_FUN_EXPORT PFNGLFRUSTUMFOESPROC __glewFrustumfOES; +GLEW_FUN_EXPORT PFNGLGETCLIPPLANEFOESPROC __glewGetClipPlanefOES; +GLEW_FUN_EXPORT PFNGLORTHOFOESPROC __glewOrthofOES; + +GLEW_FUN_EXPORT PFNGLDETAILTEXFUNCSGISPROC __glewDetailTexFuncSGIS; +GLEW_FUN_EXPORT PFNGLGETDETAILTEXFUNCSGISPROC __glewGetDetailTexFuncSGIS; + +GLEW_FUN_EXPORT PFNGLFOGFUNCSGISPROC __glewFogFuncSGIS; +GLEW_FUN_EXPORT PFNGLGETFOGFUNCSGISPROC __glewGetFogFuncSGIS; + +GLEW_FUN_EXPORT PFNGLSAMPLEMASKSGISPROC __glewSampleMaskSGIS; +GLEW_FUN_EXPORT PFNGLSAMPLEPATTERNSGISPROC __glewSamplePatternSGIS; + +GLEW_FUN_EXPORT PFNGLGETSHARPENTEXFUNCSGISPROC __glewGetSharpenTexFuncSGIS; +GLEW_FUN_EXPORT PFNGLSHARPENTEXFUNCSGISPROC __glewSharpenTexFuncSGIS; + +GLEW_FUN_EXPORT PFNGLTEXIMAGE4DSGISPROC __glewTexImage4DSGIS; +GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE4DSGISPROC __glewTexSubImage4DSGIS; + +GLEW_FUN_EXPORT PFNGLGETTEXFILTERFUNCSGISPROC __glewGetTexFilterFuncSGIS; +GLEW_FUN_EXPORT PFNGLTEXFILTERFUNCSGISPROC __glewTexFilterFuncSGIS; + +GLEW_FUN_EXPORT PFNGLASYNCMARKERSGIXPROC __glewAsyncMarkerSGIX; +GLEW_FUN_EXPORT PFNGLDELETEASYNCMARKERSSGIXPROC __glewDeleteAsyncMarkersSGIX; +GLEW_FUN_EXPORT PFNGLFINISHASYNCSGIXPROC __glewFinishAsyncSGIX; +GLEW_FUN_EXPORT PFNGLGENASYNCMARKERSSGIXPROC __glewGenAsyncMarkersSGIX; +GLEW_FUN_EXPORT PFNGLISASYNCMARKERSGIXPROC __glewIsAsyncMarkerSGIX; +GLEW_FUN_EXPORT PFNGLPOLLASYNCSGIXPROC __glewPollAsyncSGIX; + +GLEW_FUN_EXPORT PFNGLFLUSHRASTERSGIXPROC __glewFlushRasterSGIX; + +GLEW_FUN_EXPORT PFNGLTEXTUREFOGSGIXPROC __glewTextureFogSGIX; + +GLEW_FUN_EXPORT PFNGLFRAGMENTCOLORMATERIALSGIXPROC __glewFragmentColorMaterialSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFSGIXPROC __glewFragmentLightModelfSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFVSGIXPROC __glewFragmentLightModelfvSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELISGIXPROC __glewFragmentLightModeliSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIVSGIXPROC __glewFragmentLightModelivSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFSGIXPROC __glewFragmentLightfSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFVSGIXPROC __glewFragmentLightfvSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTISGIXPROC __glewFragmentLightiSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIVSGIXPROC __glewFragmentLightivSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFSGIXPROC __glewFragmentMaterialfSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFVSGIXPROC __glewFragmentMaterialfvSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALISGIXPROC __glewFragmentMaterialiSGIX; +GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIVSGIXPROC __glewFragmentMaterialivSGIX; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTFVSGIXPROC __glewGetFragmentLightfvSGIX; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTIVSGIXPROC __glewGetFragmentLightivSGIX; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALFVSGIXPROC __glewGetFragmentMaterialfvSGIX; +GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALIVSGIXPROC __glewGetFragmentMaterialivSGIX; + +GLEW_FUN_EXPORT PFNGLFRAMEZOOMSGIXPROC __glewFrameZoomSGIX; + +GLEW_FUN_EXPORT PFNGLPIXELTEXGENSGIXPROC __glewPixelTexGenSGIX; + +GLEW_FUN_EXPORT PFNGLREFERENCEPLANESGIXPROC __glewReferencePlaneSGIX; + +GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERFSGIXPROC __glewSpriteParameterfSGIX; +GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERFVSGIXPROC __glewSpriteParameterfvSGIX; +GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERISGIXPROC __glewSpriteParameteriSGIX; +GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERIVSGIXPROC __glewSpriteParameterivSGIX; + +GLEW_FUN_EXPORT PFNGLTAGSAMPLEBUFFERSGIXPROC __glewTagSampleBufferSGIX; + +GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERFVSGIPROC __glewColorTableParameterfvSGI; +GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERIVSGIPROC __glewColorTableParameterivSGI; +GLEW_FUN_EXPORT PFNGLCOLORTABLESGIPROC __glewColorTableSGI; +GLEW_FUN_EXPORT PFNGLCOPYCOLORTABLESGIPROC __glewCopyColorTableSGI; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVSGIPROC __glewGetColorTableParameterfvSGI; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVSGIPROC __glewGetColorTableParameterivSGI; +GLEW_FUN_EXPORT PFNGLGETCOLORTABLESGIPROC __glewGetColorTableSGI; + +GLEW_FUN_EXPORT PFNGLFINISHTEXTURESUNXPROC __glewFinishTextureSUNX; + +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORBSUNPROC __glewGlobalAlphaFactorbSUN; +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORDSUNPROC __glewGlobalAlphaFactordSUN; +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORFSUNPROC __glewGlobalAlphaFactorfSUN; +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORISUNPROC __glewGlobalAlphaFactoriSUN; +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORSSUNPROC __glewGlobalAlphaFactorsSUN; +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUBSUNPROC __glewGlobalAlphaFactorubSUN; +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUISUNPROC __glewGlobalAlphaFactoruiSUN; +GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUSSUNPROC __glewGlobalAlphaFactorusSUN; + +GLEW_FUN_EXPORT PFNGLREADVIDEOPIXELSSUNPROC __glewReadVideoPixelsSUN; + +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEPOINTERSUNPROC __glewReplacementCodePointerSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUBSUNPROC __glewReplacementCodeubSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUBVSUNPROC __glewReplacementCodeubvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUISUNPROC __glewReplacementCodeuiSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVSUNPROC __glewReplacementCodeuivSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUSSUNPROC __glewReplacementCodeusSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUSVSUNPROC __glewReplacementCodeusvSUN; + +GLEW_FUN_EXPORT PFNGLCOLOR3FVERTEX3FSUNPROC __glewColor3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLCOLOR3FVERTEX3FVSUNPROC __glewColor3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewColor4fNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewColor4fNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX2FSUNPROC __glewColor4ubVertex2fSUN; +GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX2FVSUNPROC __glewColor4ubVertex2fvSUN; +GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX3FSUNPROC __glewColor4ubVertex3fSUN; +GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX3FVSUNPROC __glewColor4ubVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLNORMAL3FVERTEX3FSUNPROC __glewNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLNORMAL3FVERTEX3FVSUNPROC __glewNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC __glewReplacementCodeuiColor3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC __glewReplacementCodeuiColor4ubVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC __glewReplacementCodeuiColor4ubVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC __glewReplacementCodeuiVertex3fSUN; +GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC __glewReplacementCodeuiVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC __glewTexCoord2fColor3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC __glewTexCoord2fColor3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC __glewTexCoord2fColor4ubVertex3fSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC __glewTexCoord2fColor4ubVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fNormal3fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fNormal3fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FVERTEX3FSUNPROC __glewTexCoord2fVertex3fSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD2FVERTEX3FVSUNPROC __glewTexCoord2fVertex3fvSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fvSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD4FVERTEX4FSUNPROC __glewTexCoord4fVertex4fSUN; +GLEW_FUN_EXPORT PFNGLTEXCOORD4FVERTEX4FVSUNPROC __glewTexCoord4fVertex4fvSUN; + +GLEW_FUN_EXPORT PFNGLADDSWAPHINTRECTWINPROC __glewAddSwapHintRectWIN; + +#if defined(GLEW_MX) && !defined(_WIN32) +struct GLEWContextStruct +{ +#endif /* GLEW_MX */ + +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_1; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_2; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_3; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_4; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_5; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_2_0; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_2_1; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_0; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_1; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_2; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_3; +GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_0; +GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_multisample; +GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_tbuffer; +GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_texture_compression_FXT1; +GLEW_VAR_EXPORT GLboolean __GLEW_AMD_conservative_depth; +GLEW_VAR_EXPORT GLboolean __GLEW_AMD_draw_buffers_blend; +GLEW_VAR_EXPORT GLboolean __GLEW_AMD_performance_monitor; +GLEW_VAR_EXPORT GLboolean __GLEW_AMD_seamless_cubemap_per_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_AMD_shader_stencil_export; +GLEW_VAR_EXPORT GLboolean __GLEW_AMD_texture_texture4; +GLEW_VAR_EXPORT GLboolean __GLEW_AMD_vertex_shader_tessellator; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_aux_depth_stencil; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_client_storage; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_element_array; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_fence; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_float_pixels; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_flush_buffer_range; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_object_purgeable; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_pixel_buffer; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_rgb_422; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_row_bytes; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_specular_vector; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_texture_range; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_transform_hint; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_array_object; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_array_range; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_program_evaluators; +GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_ycbcr_422; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_blend_func_extended; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_color_buffer_float; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_compatibility; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_copy_buffer; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_buffer_float; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_buffers; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_buffers_blend; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_elements_base_vertex; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_indirect; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_instanced; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_explicit_attrib_location; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_coord_conventions; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_program; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_program_shadow; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_framebuffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_framebuffer_sRGB; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_geometry_shader4; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_gpu_shader5; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_gpu_shader_fp64; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_half_float_pixel; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_half_float_vertex; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_imaging; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_instanced_arrays; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_map_buffer_range; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_matrix_palette; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multisample; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multitexture; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_occlusion_query; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_occlusion_query2; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_pixel_buffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_point_parameters; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_point_sprite; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_provoking_vertex; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sample_shading; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sampler_objects; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_seamless_cube_map; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_bit_encoding; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_objects; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_subroutine; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_texture_lod; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_100; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_include; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shadow; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shadow_ambient; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sync; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_tessellation_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_border_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_buffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_buffer_object_rgb32; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression_bptc; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression_rgtc; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_cube_map; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_cube_map_array; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_add; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_combine; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_crossbar; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_dot3; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_float; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_gather; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_mirrored_repeat; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_multisample; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_non_power_of_two; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_query_lod; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rectangle; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rg; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rgb10_a2ui; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_swizzle; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_timer_query; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transform_feedback2; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transform_feedback3; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transpose_matrix; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_uniform_buffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_array_bgra; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_array_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_blend; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_buffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_program; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_type_2_10_10_10_rev; +GLEW_VAR_EXPORT GLboolean __GLEW_ARB_window_pos; +GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_point_sprites; +GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_texture_env_combine3; +GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_texture_env_route; +GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_vertex_shader_output_point_size; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_draw_buffers; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_element_array; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_envmap_bumpmap; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_fragment_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_map_object_buffer; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_meminfo; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_pn_triangles; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_separate_stencil; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_shader_texture_lod; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_text_fragment_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_compression_3dc; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_env_combine3; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_float; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_mirror_once; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_array_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_attrib_array_object; +GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_streams; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_422_pixels; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_Cg_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_abgr; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_bgra; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_bindable_uniform; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_color; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_equation_separate; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_func_separate; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_logic_op; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_minmax; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_subtract; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_clip_volume_hint; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_cmyka; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_color_subtable; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_compiled_vertex_array; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_convolution; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_coordinate_frame; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_copy_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_cull_vertex; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_depth_bounds_test; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_direct_state_access; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_buffers2; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_instanced; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_range_elements; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_fog_coord; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_fragment_lighting; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_blit; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_multisample; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_sRGB; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_geometry_shader4; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_gpu_program_parameters; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_gpu_shader4; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_histogram; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_array_formats; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_func; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_material; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_light_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_misc_attribute; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_multi_draw_arrays; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_multisample; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_depth_stencil; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_float; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_pixels; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_paletted_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_buffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_transform; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_transform_color_table; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_point_parameters; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_polygon_offset; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_provoking_vertex; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_rescale_normal; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_scene_marker; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_secondary_color; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_separate_shader_objects; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_separate_specular_color; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shader_image_load_store; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shadow_funcs; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shared_texture_palette; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_clear_tag; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_two_side; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_wrap; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_subtexture; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture3D; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_array; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_buffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_dxt1; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_latc; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_rgtc; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_s3tc; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_cube_map; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_edge_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_add; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_combine; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_dot3; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_filter_anisotropic; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_integer; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_lod_bias; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_mirror_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_object; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_perturb_normal; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_rectangle; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_sRGB; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_shared_exponent; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_snorm; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_swizzle; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_timer_query; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_transform_feedback; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_array; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_array_bgra; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_attrib_64bit; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_weighting; +GLEW_VAR_EXPORT GLboolean __GLEW_GREMEDY_frame_terminator; +GLEW_VAR_EXPORT GLboolean __GLEW_GREMEDY_string_marker; +GLEW_VAR_EXPORT GLboolean __GLEW_HP_convolution_border_modes; +GLEW_VAR_EXPORT GLboolean __GLEW_HP_image_transform; +GLEW_VAR_EXPORT GLboolean __GLEW_HP_occlusion_test; +GLEW_VAR_EXPORT GLboolean __GLEW_HP_texture_lighting; +GLEW_VAR_EXPORT GLboolean __GLEW_IBM_cull_vertex; +GLEW_VAR_EXPORT GLboolean __GLEW_IBM_multimode_draw_arrays; +GLEW_VAR_EXPORT GLboolean __GLEW_IBM_rasterpos_clip; +GLEW_VAR_EXPORT GLboolean __GLEW_IBM_static_data; +GLEW_VAR_EXPORT GLboolean __GLEW_IBM_texture_mirrored_repeat; +GLEW_VAR_EXPORT GLboolean __GLEW_IBM_vertex_array_lists; +GLEW_VAR_EXPORT GLboolean __GLEW_INGR_color_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_INGR_interlace_read; +GLEW_VAR_EXPORT GLboolean __GLEW_INTEL_parallel_arrays; +GLEW_VAR_EXPORT GLboolean __GLEW_INTEL_texture_scissor; +GLEW_VAR_EXPORT GLboolean __GLEW_KTX_buffer_region; +GLEW_VAR_EXPORT GLboolean __GLEW_MESAX_texture_stack; +GLEW_VAR_EXPORT GLboolean __GLEW_MESA_pack_invert; +GLEW_VAR_EXPORT GLboolean __GLEW_MESA_resize_buffers; +GLEW_VAR_EXPORT GLboolean __GLEW_MESA_window_pos; +GLEW_VAR_EXPORT GLboolean __GLEW_MESA_ycbcr_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_blend_square; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_conditional_render; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_copy_depth_to_color; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_copy_image; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_buffer_float; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_range_unclamped; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_evaluators; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_explicit_multisample; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_fence; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_float_buffer; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_fog_distance; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program2; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program4; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program_option; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_framebuffer_multisample_coverage; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_geometry_program4; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_geometry_shader4; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program4; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program5; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program_fp64; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_shader5; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_half_float; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_light_max_exponent; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_multisample_filter_hint; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_occlusion_query; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_packed_depth_stencil; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_parameter_buffer_object; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_parameter_buffer_object2; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_pixel_data_range; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_point_sprite; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_present_video; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_primitive_restart; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_register_combiners; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_register_combiners2; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_shader_buffer_load; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_tessellation_program5; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texgen_emboss; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texgen_reflection; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_barrier; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_compression_vtc; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_env_combine4; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_expand_normal; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_rectangle; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader2; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader3; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_transform_feedback; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_transform_feedback2; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_array_range; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_array_range2; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_attrib_integer_64bit; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_buffer_unified_memory; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program1_1; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program2; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program2_option; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program3; +GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program4; +GLEW_VAR_EXPORT GLboolean __GLEW_OES_byte_coordinates; +GLEW_VAR_EXPORT GLboolean __GLEW_OES_compressed_paletted_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_OES_read_format; +GLEW_VAR_EXPORT GLboolean __GLEW_OES_single_precision; +GLEW_VAR_EXPORT GLboolean __GLEW_OML_interlace; +GLEW_VAR_EXPORT GLboolean __GLEW_OML_resample; +GLEW_VAR_EXPORT GLboolean __GLEW_OML_subsample; +GLEW_VAR_EXPORT GLboolean __GLEW_PGI_misc_hints; +GLEW_VAR_EXPORT GLboolean __GLEW_PGI_vertex_hints; +GLEW_VAR_EXPORT GLboolean __GLEW_REND_screen_coordinates; +GLEW_VAR_EXPORT GLboolean __GLEW_S3_s3tc; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_color_range; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_detail_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_fog_function; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_generate_mipmap; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_multisample; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_pixel_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_point_line_texgen; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_sharpen_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture4D; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_border_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_edge_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_filter4; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_lod; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_select; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async_histogram; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async_pixel; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_blend_alpha_minmax; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_clipmap; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_convolution_accuracy; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_depth_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_flush_raster; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fog_offset; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fog_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fragment_specular_lighting; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_framezoom; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_interlace; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_ir_instrument1; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_list_priority; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_pixel_texture; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_pixel_texture_bits; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_reference_plane; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_resample; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_shadow; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_shadow_ambient; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_sprite; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_tag_sample_buffer; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_add_env; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_coordinate_clamp; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_lod_bias; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_multi_buffer; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_range; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_scale_bias; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_vertex_preclip; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_vertex_preclip_hint; +GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_ycrcb; +GLEW_VAR_EXPORT GLboolean __GLEW_SGI_color_matrix; +GLEW_VAR_EXPORT GLboolean __GLEW_SGI_color_table; +GLEW_VAR_EXPORT GLboolean __GLEW_SGI_texture_color_table; +GLEW_VAR_EXPORT GLboolean __GLEW_SUNX_constant_data; +GLEW_VAR_EXPORT GLboolean __GLEW_SUN_convolution_border_modes; +GLEW_VAR_EXPORT GLboolean __GLEW_SUN_global_alpha; +GLEW_VAR_EXPORT GLboolean __GLEW_SUN_mesh_array; +GLEW_VAR_EXPORT GLboolean __GLEW_SUN_read_video_pixels; +GLEW_VAR_EXPORT GLboolean __GLEW_SUN_slice_accum; +GLEW_VAR_EXPORT GLboolean __GLEW_SUN_triangle_list; +GLEW_VAR_EXPORT GLboolean __GLEW_SUN_vertex; +GLEW_VAR_EXPORT GLboolean __GLEW_WIN_phong_shading; +GLEW_VAR_EXPORT GLboolean __GLEW_WIN_specular_fog; +GLEW_VAR_EXPORT GLboolean __GLEW_WIN_swap_hint; + +#ifdef GLEW_MX +}; /* GLEWContextStruct */ +#endif /* GLEW_MX */ + +/* ------------------------------------------------------------------------- */ + +/* error codes */ +#define GLEW_OK 0 +#define GLEW_NO_ERROR 0 +#define GLEW_ERROR_NO_GL_VERSION 1 /* missing GL version */ +#define GLEW_ERROR_GL_VERSION_10_ONLY 2 /* GL 1.1 and up are not supported */ +#define GLEW_ERROR_GLX_VERSION_11_ONLY 3 /* GLX 1.2 and up are not supported */ + +/* string codes */ +#define GLEW_VERSION 1 +#define GLEW_VERSION_MAJOR 2 +#define GLEW_VERSION_MINOR 3 +#define GLEW_VERSION_MICRO 4 + +/* API */ +#ifdef GLEW_MX + +typedef struct GLEWContextStruct GLEWContext; +GLEWAPI GLenum glewContextInit (GLEWContext* ctx); +GLEWAPI GLboolean glewContextIsSupported (GLEWContext* ctx, const char* name); + +#define glewInit() glewContextInit(glewGetContext()) +#define glewIsSupported(x) glewContextIsSupported(glewGetContext(), x) +#define glewIsExtensionSupported(x) glewIsSupported(x) + +#define GLEW_GET_VAR(x) (*(const GLboolean*)&(glewGetContext()->x)) +#ifdef _WIN32 +# define GLEW_GET_FUN(x) glewGetContext()->x +#else +# define GLEW_GET_FUN(x) x +#endif + +#else /* GLEW_MX */ + +GLEWAPI GLenum glewInit (); +GLEWAPI GLboolean glewIsSupported (const char* name); +#define glewIsExtensionSupported(x) glewIsSupported(x) + +#define GLEW_GET_VAR(x) (*(const GLboolean*)&x) +#define GLEW_GET_FUN(x) x + +#endif /* GLEW_MX */ + +GLEWAPI GLboolean glewExperimental; +GLEWAPI GLboolean glewGetExtension (const char* name); +GLEWAPI const GLubyte* glewGetErrorString (GLenum error); +GLEWAPI const GLubyte* glewGetString (GLenum name); + +#ifdef __cplusplus +} +#endif + +#ifdef GLEW_APIENTRY_DEFINED +#undef GLEW_APIENTRY_DEFINED +#undef APIENTRY +#undef GLAPIENTRY +#define GLAPIENTRY +#endif + +#ifdef GLEW_CALLBACK_DEFINED +#undef GLEW_CALLBACK_DEFINED +#undef CALLBACK +#endif + +#ifdef GLEW_WINGDIAPI_DEFINED +#undef GLEW_WINGDIAPI_DEFINED +#undef WINGDIAPI +#endif + +#undef GLAPI +/* #undef GLEWAPI */ + +#endif /* __glew_h__ */ diff --git a/Externals/GLew/include/GL/glxew.h b/Externals/GLew/include/GL/glxew.h new file mode 100644 index 0000000000..637ef1eaab --- /dev/null +++ b/Externals/GLew/include/GL/glxew.h @@ -0,0 +1,1476 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + +/* + * Mesa 3-D graphics library + * Version: 7.0 + * + * Copyright (C) 1999-2007 Brian Paul All Rights Reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included + * in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN + * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + +/* +** Copyright (c) 2007 The Khronos Group Inc. +** +** Permission is hereby granted, free of charge, to any person obtaining a +** copy of this software and/or associated documentation files (the +** "Materials"), to deal in the Materials without restriction, including +** without limitation the rights to use, copy, modify, merge, publish, +** distribute, sublicense, and/or sell copies of the Materials, and to +** permit persons to whom the Materials are furnished to do so, subject to +** the following conditions: +** +** The above copyright notice and this permission notice shall be included +** in all copies or substantial portions of the Materials. +** +** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. +*/ + +#ifndef __glxew_h__ +#define __glxew_h__ +#define __GLXEW_H__ + +#ifdef __glxext_h_ +#error glxext.h included before glxew.h +#endif + +#if defined(GLX_H) || defined(__GLX_glx_h__) || defined(__glx_h__) +#error glx.h included before glxew.h +#endif + +#define __glxext_h_ + +#define GLX_H +#define __GLX_glx_h__ +#define __glx_h__ + +#include +#include +#include +#include + +#ifdef __cplusplus +extern "C" { +#endif + +/* ---------------------------- GLX_VERSION_1_0 --------------------------- */ + +#ifndef GLX_VERSION_1_0 +#define GLX_VERSION_1_0 1 + +#define GLX_USE_GL 1 +#define GLX_BUFFER_SIZE 2 +#define GLX_LEVEL 3 +#define GLX_RGBA 4 +#define GLX_DOUBLEBUFFER 5 +#define GLX_STEREO 6 +#define GLX_AUX_BUFFERS 7 +#define GLX_RED_SIZE 8 +#define GLX_GREEN_SIZE 9 +#define GLX_BLUE_SIZE 10 +#define GLX_ALPHA_SIZE 11 +#define GLX_DEPTH_SIZE 12 +#define GLX_STENCIL_SIZE 13 +#define GLX_ACCUM_RED_SIZE 14 +#define GLX_ACCUM_GREEN_SIZE 15 +#define GLX_ACCUM_BLUE_SIZE 16 +#define GLX_ACCUM_ALPHA_SIZE 17 +#define GLX_BAD_SCREEN 1 +#define GLX_BAD_ATTRIBUTE 2 +#define GLX_NO_EXTENSION 3 +#define GLX_BAD_VISUAL 4 +#define GLX_BAD_CONTEXT 5 +#define GLX_BAD_VALUE 6 +#define GLX_BAD_ENUM 7 + +typedef XID GLXDrawable; +typedef XID GLXPixmap; +#ifdef __sun +typedef struct __glXContextRec *GLXContext; +#else +typedef struct __GLXcontextRec *GLXContext; +#endif + +typedef unsigned int GLXVideoDeviceNV; + +extern Bool glXQueryExtension (Display *dpy, int *errorBase, int *eventBase); +extern Bool glXQueryVersion (Display *dpy, int *major, int *minor); +extern int glXGetConfig (Display *dpy, XVisualInfo *vis, int attrib, int *value); +extern XVisualInfo* glXChooseVisual (Display *dpy, int screen, int *attribList); +extern GLXPixmap glXCreateGLXPixmap (Display *dpy, XVisualInfo *vis, Pixmap pixmap); +extern void glXDestroyGLXPixmap (Display *dpy, GLXPixmap pix); +extern GLXContext glXCreateContext (Display *dpy, XVisualInfo *vis, GLXContext shareList, Bool direct); +extern void glXDestroyContext (Display *dpy, GLXContext ctx); +extern Bool glXIsDirect (Display *dpy, GLXContext ctx); +extern void glXCopyContext (Display *dpy, GLXContext src, GLXContext dst, GLulong mask); +extern Bool glXMakeCurrent (Display *dpy, GLXDrawable drawable, GLXContext ctx); +extern GLXContext glXGetCurrentContext (void); +extern GLXDrawable glXGetCurrentDrawable (void); +extern void glXWaitGL (void); +extern void glXWaitX (void); +extern void glXSwapBuffers (Display *dpy, GLXDrawable drawable); +extern void glXUseXFont (Font font, int first, int count, int listBase); + +#define GLXEW_VERSION_1_0 GLXEW_GET_VAR(__GLXEW_VERSION_1_0) + +#endif /* GLX_VERSION_1_0 */ + +/* ---------------------------- GLX_VERSION_1_1 --------------------------- */ + +#ifndef GLX_VERSION_1_1 +#define GLX_VERSION_1_1 + +#define GLX_VENDOR 0x1 +#define GLX_VERSION 0x2 +#define GLX_EXTENSIONS 0x3 + +extern const char* glXQueryExtensionsString (Display *dpy, int screen); +extern const char* glXGetClientString (Display *dpy, int name); +extern const char* glXQueryServerString (Display *dpy, int screen, int name); + +#define GLXEW_VERSION_1_1 GLXEW_GET_VAR(__GLXEW_VERSION_1_1) + +#endif /* GLX_VERSION_1_1 */ + +/* ---------------------------- GLX_VERSION_1_2 ---------------------------- */ + +#ifndef GLX_VERSION_1_2 +#define GLX_VERSION_1_2 1 + +typedef Display* ( * PFNGLXGETCURRENTDISPLAYPROC) (void); + +#define glXGetCurrentDisplay GLXEW_GET_FUN(__glewXGetCurrentDisplay) + +#define GLXEW_VERSION_1_2 GLXEW_GET_VAR(__GLXEW_VERSION_1_2) + +#endif /* GLX_VERSION_1_2 */ + +/* ---------------------------- GLX_VERSION_1_3 ---------------------------- */ + +#ifndef GLX_VERSION_1_3 +#define GLX_VERSION_1_3 1 + +#define GLX_RGBA_BIT 0x00000001 +#define GLX_FRONT_LEFT_BUFFER_BIT 0x00000001 +#define GLX_WINDOW_BIT 0x00000001 +#define GLX_COLOR_INDEX_BIT 0x00000002 +#define GLX_PIXMAP_BIT 0x00000002 +#define GLX_FRONT_RIGHT_BUFFER_BIT 0x00000002 +#define GLX_BACK_LEFT_BUFFER_BIT 0x00000004 +#define GLX_PBUFFER_BIT 0x00000004 +#define GLX_BACK_RIGHT_BUFFER_BIT 0x00000008 +#define GLX_AUX_BUFFERS_BIT 0x00000010 +#define GLX_CONFIG_CAVEAT 0x20 +#define GLX_DEPTH_BUFFER_BIT 0x00000020 +#define GLX_X_VISUAL_TYPE 0x22 +#define GLX_TRANSPARENT_TYPE 0x23 +#define GLX_TRANSPARENT_INDEX_VALUE 0x24 +#define GLX_TRANSPARENT_RED_VALUE 0x25 +#define GLX_TRANSPARENT_GREEN_VALUE 0x26 +#define GLX_TRANSPARENT_BLUE_VALUE 0x27 +#define GLX_TRANSPARENT_ALPHA_VALUE 0x28 +#define GLX_STENCIL_BUFFER_BIT 0x00000040 +#define GLX_ACCUM_BUFFER_BIT 0x00000080 +#define GLX_NONE 0x8000 +#define GLX_SLOW_CONFIG 0x8001 +#define GLX_TRUE_COLOR 0x8002 +#define GLX_DIRECT_COLOR 0x8003 +#define GLX_PSEUDO_COLOR 0x8004 +#define GLX_STATIC_COLOR 0x8005 +#define GLX_GRAY_SCALE 0x8006 +#define GLX_STATIC_GRAY 0x8007 +#define GLX_TRANSPARENT_RGB 0x8008 +#define GLX_TRANSPARENT_INDEX 0x8009 +#define GLX_VISUAL_ID 0x800B +#define GLX_SCREEN 0x800C +#define GLX_NON_CONFORMANT_CONFIG 0x800D +#define GLX_DRAWABLE_TYPE 0x8010 +#define GLX_RENDER_TYPE 0x8011 +#define GLX_X_RENDERABLE 0x8012 +#define GLX_FBCONFIG_ID 0x8013 +#define GLX_RGBA_TYPE 0x8014 +#define GLX_COLOR_INDEX_TYPE 0x8015 +#define GLX_MAX_PBUFFER_WIDTH 0x8016 +#define GLX_MAX_PBUFFER_HEIGHT 0x8017 +#define GLX_MAX_PBUFFER_PIXELS 0x8018 +#define GLX_PRESERVED_CONTENTS 0x801B +#define GLX_LARGEST_PBUFFER 0x801C +#define GLX_WIDTH 0x801D +#define GLX_HEIGHT 0x801E +#define GLX_EVENT_MASK 0x801F +#define GLX_DAMAGED 0x8020 +#define GLX_SAVED 0x8021 +#define GLX_WINDOW 0x8022 +#define GLX_PBUFFER 0x8023 +#define GLX_PBUFFER_HEIGHT 0x8040 +#define GLX_PBUFFER_WIDTH 0x8041 +#define GLX_PBUFFER_CLOBBER_MASK 0x08000000 +#define GLX_DONT_CARE 0xFFFFFFFF + +typedef XID GLXFBConfigID; +typedef XID GLXWindow; +typedef XID GLXPbuffer; +typedef struct __GLXFBConfigRec *GLXFBConfig; + +typedef struct { + int event_type; + int draw_type; + unsigned long serial; + Bool send_event; + Display *display; + GLXDrawable drawable; + unsigned int buffer_mask; + unsigned int aux_buffer; + int x, y; + int width, height; + int count; +} GLXPbufferClobberEvent; +typedef union __GLXEvent { + GLXPbufferClobberEvent glxpbufferclobber; + long pad[24]; +} GLXEvent; + +typedef GLXFBConfig* ( * PFNGLXCHOOSEFBCONFIGPROC) (Display *dpy, int screen, const int *attrib_list, int *nelements); +typedef GLXContext ( * PFNGLXCREATENEWCONTEXTPROC) (Display *dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct); +typedef GLXPbuffer ( * PFNGLXCREATEPBUFFERPROC) (Display *dpy, GLXFBConfig config, const int *attrib_list); +typedef GLXPixmap ( * PFNGLXCREATEPIXMAPPROC) (Display *dpy, GLXFBConfig config, Pixmap pixmap, const int *attrib_list); +typedef GLXWindow ( * PFNGLXCREATEWINDOWPROC) (Display *dpy, GLXFBConfig config, Window win, const int *attrib_list); +typedef void ( * PFNGLXDESTROYPBUFFERPROC) (Display *dpy, GLXPbuffer pbuf); +typedef void ( * PFNGLXDESTROYPIXMAPPROC) (Display *dpy, GLXPixmap pixmap); +typedef void ( * PFNGLXDESTROYWINDOWPROC) (Display *dpy, GLXWindow win); +typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLEPROC) (void); +typedef int ( * PFNGLXGETFBCONFIGATTRIBPROC) (Display *dpy, GLXFBConfig config, int attribute, int *value); +typedef GLXFBConfig* ( * PFNGLXGETFBCONFIGSPROC) (Display *dpy, int screen, int *nelements); +typedef void ( * PFNGLXGETSELECTEDEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long *event_mask); +typedef XVisualInfo* ( * PFNGLXGETVISUALFROMFBCONFIGPROC) (Display *dpy, GLXFBConfig config); +typedef Bool ( * PFNGLXMAKECONTEXTCURRENTPROC) (Display *display, GLXDrawable draw, GLXDrawable read, GLXContext ctx); +typedef int ( * PFNGLXQUERYCONTEXTPROC) (Display *dpy, GLXContext ctx, int attribute, int *value); +typedef void ( * PFNGLXQUERYDRAWABLEPROC) (Display *dpy, GLXDrawable draw, int attribute, unsigned int *value); +typedef void ( * PFNGLXSELECTEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long event_mask); + +#define glXChooseFBConfig GLXEW_GET_FUN(__glewXChooseFBConfig) +#define glXCreateNewContext GLXEW_GET_FUN(__glewXCreateNewContext) +#define glXCreatePbuffer GLXEW_GET_FUN(__glewXCreatePbuffer) +#define glXCreatePixmap GLXEW_GET_FUN(__glewXCreatePixmap) +#define glXCreateWindow GLXEW_GET_FUN(__glewXCreateWindow) +#define glXDestroyPbuffer GLXEW_GET_FUN(__glewXDestroyPbuffer) +#define glXDestroyPixmap GLXEW_GET_FUN(__glewXDestroyPixmap) +#define glXDestroyWindow GLXEW_GET_FUN(__glewXDestroyWindow) +#define glXGetCurrentReadDrawable GLXEW_GET_FUN(__glewXGetCurrentReadDrawable) +#define glXGetFBConfigAttrib GLXEW_GET_FUN(__glewXGetFBConfigAttrib) +#define glXGetFBConfigs GLXEW_GET_FUN(__glewXGetFBConfigs) +#define glXGetSelectedEvent GLXEW_GET_FUN(__glewXGetSelectedEvent) +#define glXGetVisualFromFBConfig GLXEW_GET_FUN(__glewXGetVisualFromFBConfig) +#define glXMakeContextCurrent GLXEW_GET_FUN(__glewXMakeContextCurrent) +#define glXQueryContext GLXEW_GET_FUN(__glewXQueryContext) +#define glXQueryDrawable GLXEW_GET_FUN(__glewXQueryDrawable) +#define glXSelectEvent GLXEW_GET_FUN(__glewXSelectEvent) + +#define GLXEW_VERSION_1_3 GLXEW_GET_VAR(__GLXEW_VERSION_1_3) + +#endif /* GLX_VERSION_1_3 */ + +/* ---------------------------- GLX_VERSION_1_4 ---------------------------- */ + +#ifndef GLX_VERSION_1_4 +#define GLX_VERSION_1_4 1 + +#define GLX_SAMPLE_BUFFERS 100000 +#define GLX_SAMPLES 100001 + +extern void ( * glXGetProcAddress (const GLubyte *procName)) (void); + +#define GLXEW_VERSION_1_4 GLXEW_GET_VAR(__GLXEW_VERSION_1_4) + +#endif /* GLX_VERSION_1_4 */ + +/* -------------------------- GLX_3DFX_multisample ------------------------- */ + +#ifndef GLX_3DFX_multisample +#define GLX_3DFX_multisample 1 + +#define GLX_SAMPLE_BUFFERS_3DFX 0x8050 +#define GLX_SAMPLES_3DFX 0x8051 + +#define GLXEW_3DFX_multisample GLXEW_GET_VAR(__GLXEW_3DFX_multisample) + +#endif /* GLX_3DFX_multisample */ + +/* ------------------------- GLX_ARB_create_context ------------------------ */ + +#ifndef GLX_ARB_create_context +#define GLX_ARB_create_context 1 + +#define GLX_CONTEXT_DEBUG_BIT_ARB 0x0001 +#define GLX_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 +#define GLX_CONTEXT_MAJOR_VERSION_ARB 0x2091 +#define GLX_CONTEXT_MINOR_VERSION_ARB 0x2092 +#define GLX_CONTEXT_FLAGS_ARB 0x2094 + +typedef GLXContext ( * PFNGLXCREATECONTEXTATTRIBSARBPROC) (Display* dpy, GLXFBConfig config, GLXContext share_context, Bool direct, const int *attrib_list); + +#define glXCreateContextAttribsARB GLXEW_GET_FUN(__glewXCreateContextAttribsARB) + +#define GLXEW_ARB_create_context GLXEW_GET_VAR(__GLXEW_ARB_create_context) + +#endif /* GLX_ARB_create_context */ + +/* --------------------- GLX_ARB_create_context_profile -------------------- */ + +#ifndef GLX_ARB_create_context_profile +#define GLX_ARB_create_context_profile 1 + +#define GLX_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 +#define GLX_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 +#define GLX_CONTEXT_PROFILE_MASK_ARB 0x9126 + +#define GLXEW_ARB_create_context_profile GLXEW_GET_VAR(__GLXEW_ARB_create_context_profile) + +#endif /* GLX_ARB_create_context_profile */ + +/* ------------------------- GLX_ARB_fbconfig_float ------------------------ */ + +#ifndef GLX_ARB_fbconfig_float +#define GLX_ARB_fbconfig_float 1 + +#define GLX_RGBA_FLOAT_BIT 0x00000004 +#define GLX_RGBA_FLOAT_TYPE 0x20B9 + +#define GLXEW_ARB_fbconfig_float GLXEW_GET_VAR(__GLXEW_ARB_fbconfig_float) + +#endif /* GLX_ARB_fbconfig_float */ + +/* ------------------------ GLX_ARB_framebuffer_sRGB ----------------------- */ + +#ifndef GLX_ARB_framebuffer_sRGB +#define GLX_ARB_framebuffer_sRGB 1 + +#define GLX_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20B2 + +#define GLXEW_ARB_framebuffer_sRGB GLXEW_GET_VAR(__GLXEW_ARB_framebuffer_sRGB) + +#endif /* GLX_ARB_framebuffer_sRGB */ + +/* ------------------------ GLX_ARB_get_proc_address ----------------------- */ + +#ifndef GLX_ARB_get_proc_address +#define GLX_ARB_get_proc_address 1 + +extern void ( * glXGetProcAddressARB (const GLubyte *procName)) (void); + +#define GLXEW_ARB_get_proc_address GLXEW_GET_VAR(__GLXEW_ARB_get_proc_address) + +#endif /* GLX_ARB_get_proc_address */ + +/* -------------------------- GLX_ARB_multisample -------------------------- */ + +#ifndef GLX_ARB_multisample +#define GLX_ARB_multisample 1 + +#define GLX_SAMPLE_BUFFERS_ARB 100000 +#define GLX_SAMPLES_ARB 100001 + +#define GLXEW_ARB_multisample GLXEW_GET_VAR(__GLXEW_ARB_multisample) + +#endif /* GLX_ARB_multisample */ + +/* ---------------------- GLX_ARB_vertex_buffer_object --------------------- */ + +#ifndef GLX_ARB_vertex_buffer_object +#define GLX_ARB_vertex_buffer_object 1 + +#define GLX_CONTEXT_ALLOW_BUFFER_BYTE_ORDER_MISMATCH_ARB 0x2095 + +#define GLXEW_ARB_vertex_buffer_object GLXEW_GET_VAR(__GLXEW_ARB_vertex_buffer_object) + +#endif /* GLX_ARB_vertex_buffer_object */ + +/* ----------------------- GLX_ATI_pixel_format_float ---------------------- */ + +#ifndef GLX_ATI_pixel_format_float +#define GLX_ATI_pixel_format_float 1 + +#define GLX_RGBA_FLOAT_ATI_BIT 0x00000100 + +#define GLXEW_ATI_pixel_format_float GLXEW_GET_VAR(__GLXEW_ATI_pixel_format_float) + +#endif /* GLX_ATI_pixel_format_float */ + +/* ------------------------- GLX_ATI_render_texture ------------------------ */ + +#ifndef GLX_ATI_render_texture +#define GLX_ATI_render_texture 1 + +#define GLX_BIND_TO_TEXTURE_RGB_ATI 0x9800 +#define GLX_BIND_TO_TEXTURE_RGBA_ATI 0x9801 +#define GLX_TEXTURE_FORMAT_ATI 0x9802 +#define GLX_TEXTURE_TARGET_ATI 0x9803 +#define GLX_MIPMAP_TEXTURE_ATI 0x9804 +#define GLX_TEXTURE_RGB_ATI 0x9805 +#define GLX_TEXTURE_RGBA_ATI 0x9806 +#define GLX_NO_TEXTURE_ATI 0x9807 +#define GLX_TEXTURE_CUBE_MAP_ATI 0x9808 +#define GLX_TEXTURE_1D_ATI 0x9809 +#define GLX_TEXTURE_2D_ATI 0x980A +#define GLX_MIPMAP_LEVEL_ATI 0x980B +#define GLX_CUBE_MAP_FACE_ATI 0x980C +#define GLX_TEXTURE_CUBE_MAP_POSITIVE_X_ATI 0x980D +#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_X_ATI 0x980E +#define GLX_TEXTURE_CUBE_MAP_POSITIVE_Y_ATI 0x980F +#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_Y_ATI 0x9810 +#define GLX_TEXTURE_CUBE_MAP_POSITIVE_Z_ATI 0x9811 +#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_Z_ATI 0x9812 +#define GLX_FRONT_LEFT_ATI 0x9813 +#define GLX_FRONT_RIGHT_ATI 0x9814 +#define GLX_BACK_LEFT_ATI 0x9815 +#define GLX_BACK_RIGHT_ATI 0x9816 +#define GLX_AUX0_ATI 0x9817 +#define GLX_AUX1_ATI 0x9818 +#define GLX_AUX2_ATI 0x9819 +#define GLX_AUX3_ATI 0x981A +#define GLX_AUX4_ATI 0x981B +#define GLX_AUX5_ATI 0x981C +#define GLX_AUX6_ATI 0x981D +#define GLX_AUX7_ATI 0x981E +#define GLX_AUX8_ATI 0x981F +#define GLX_AUX9_ATI 0x9820 +#define GLX_BIND_TO_TEXTURE_LUMINANCE_ATI 0x9821 +#define GLX_BIND_TO_TEXTURE_INTENSITY_ATI 0x9822 + +typedef void ( * PFNGLXBINDTEXIMAGEATIPROC) (Display *dpy, GLXPbuffer pbuf, int buffer); +typedef void ( * PFNGLXDRAWABLEATTRIBATIPROC) (Display *dpy, GLXDrawable draw, const int *attrib_list); +typedef void ( * PFNGLXRELEASETEXIMAGEATIPROC) (Display *dpy, GLXPbuffer pbuf, int buffer); + +#define glXBindTexImageATI GLXEW_GET_FUN(__glewXBindTexImageATI) +#define glXDrawableAttribATI GLXEW_GET_FUN(__glewXDrawableAttribATI) +#define glXReleaseTexImageATI GLXEW_GET_FUN(__glewXReleaseTexImageATI) + +#define GLXEW_ATI_render_texture GLXEW_GET_VAR(__GLXEW_ATI_render_texture) + +#endif /* GLX_ATI_render_texture */ + +/* --------------------- GLX_EXT_fbconfig_packed_float --------------------- */ + +#ifndef GLX_EXT_fbconfig_packed_float +#define GLX_EXT_fbconfig_packed_float 1 + +#define GLX_RGBA_UNSIGNED_FLOAT_BIT_EXT 0x00000008 +#define GLX_RGBA_UNSIGNED_FLOAT_TYPE_EXT 0x20B1 + +#define GLXEW_EXT_fbconfig_packed_float GLXEW_GET_VAR(__GLXEW_EXT_fbconfig_packed_float) + +#endif /* GLX_EXT_fbconfig_packed_float */ + +/* ------------------------ GLX_EXT_framebuffer_sRGB ----------------------- */ + +#ifndef GLX_EXT_framebuffer_sRGB +#define GLX_EXT_framebuffer_sRGB 1 + +#define GLX_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20B2 + +#define GLXEW_EXT_framebuffer_sRGB GLXEW_GET_VAR(__GLXEW_EXT_framebuffer_sRGB) + +#endif /* GLX_EXT_framebuffer_sRGB */ + +/* ------------------------- GLX_EXT_import_context ------------------------ */ + +#ifndef GLX_EXT_import_context +#define GLX_EXT_import_context 1 + +#define GLX_SHARE_CONTEXT_EXT 0x800A +#define GLX_VISUAL_ID_EXT 0x800B +#define GLX_SCREEN_EXT 0x800C + +typedef XID GLXContextID; + +typedef void ( * PFNGLXFREECONTEXTEXTPROC) (Display* dpy, GLXContext context); +typedef GLXContextID ( * PFNGLXGETCONTEXTIDEXTPROC) (const GLXContext context); +typedef GLXContext ( * PFNGLXIMPORTCONTEXTEXTPROC) (Display* dpy, GLXContextID contextID); +typedef int ( * PFNGLXQUERYCONTEXTINFOEXTPROC) (Display* dpy, GLXContext context, int attribute,int *value); + +#define glXFreeContextEXT GLXEW_GET_FUN(__glewXFreeContextEXT) +#define glXGetContextIDEXT GLXEW_GET_FUN(__glewXGetContextIDEXT) +#define glXImportContextEXT GLXEW_GET_FUN(__glewXImportContextEXT) +#define glXQueryContextInfoEXT GLXEW_GET_FUN(__glewXQueryContextInfoEXT) + +#define GLXEW_EXT_import_context GLXEW_GET_VAR(__GLXEW_EXT_import_context) + +#endif /* GLX_EXT_import_context */ + +/* -------------------------- GLX_EXT_scene_marker ------------------------- */ + +#ifndef GLX_EXT_scene_marker +#define GLX_EXT_scene_marker 1 + +#define GLXEW_EXT_scene_marker GLXEW_GET_VAR(__GLXEW_EXT_scene_marker) + +#endif /* GLX_EXT_scene_marker */ + +/* -------------------------- GLX_EXT_swap_control ------------------------- */ + +#ifndef GLX_EXT_swap_control +#define GLX_EXT_swap_control 1 + +#define GLX_SWAP_INTERVAL_EXT 0x20F1 +#define GLX_MAX_SWAP_INTERVAL_EXT 0x20F2 + +typedef void ( * PFNGLXSWAPINTERVALEXTPROC) (Display* dpy, GLXDrawable drawable, int interval); + +#define glXSwapIntervalEXT GLXEW_GET_FUN(__glewXSwapIntervalEXT) + +#define GLXEW_EXT_swap_control GLXEW_GET_VAR(__GLXEW_EXT_swap_control) + +#endif /* GLX_EXT_swap_control */ + +/* ---------------------- GLX_EXT_texture_from_pixmap ---------------------- */ + +#ifndef GLX_EXT_texture_from_pixmap +#define GLX_EXT_texture_from_pixmap 1 + +#define GLX_TEXTURE_1D_BIT_EXT 0x00000001 +#define GLX_TEXTURE_2D_BIT_EXT 0x00000002 +#define GLX_TEXTURE_RECTANGLE_BIT_EXT 0x00000004 +#define GLX_BIND_TO_TEXTURE_RGB_EXT 0x20D0 +#define GLX_BIND_TO_TEXTURE_RGBA_EXT 0x20D1 +#define GLX_BIND_TO_MIPMAP_TEXTURE_EXT 0x20D2 +#define GLX_BIND_TO_TEXTURE_TARGETS_EXT 0x20D3 +#define GLX_Y_INVERTED_EXT 0x20D4 +#define GLX_TEXTURE_FORMAT_EXT 0x20D5 +#define GLX_TEXTURE_TARGET_EXT 0x20D6 +#define GLX_MIPMAP_TEXTURE_EXT 0x20D7 +#define GLX_TEXTURE_FORMAT_NONE_EXT 0x20D8 +#define GLX_TEXTURE_FORMAT_RGB_EXT 0x20D9 +#define GLX_TEXTURE_FORMAT_RGBA_EXT 0x20DA +#define GLX_TEXTURE_1D_EXT 0x20DB +#define GLX_TEXTURE_2D_EXT 0x20DC +#define GLX_TEXTURE_RECTANGLE_EXT 0x20DD +#define GLX_FRONT_LEFT_EXT 0x20DE +#define GLX_FRONT_RIGHT_EXT 0x20DF +#define GLX_BACK_LEFT_EXT 0x20E0 +#define GLX_BACK_RIGHT_EXT 0x20E1 +#define GLX_AUX0_EXT 0x20E2 +#define GLX_AUX1_EXT 0x20E3 +#define GLX_AUX2_EXT 0x20E4 +#define GLX_AUX3_EXT 0x20E5 +#define GLX_AUX4_EXT 0x20E6 +#define GLX_AUX5_EXT 0x20E7 +#define GLX_AUX6_EXT 0x20E8 +#define GLX_AUX7_EXT 0x20E9 +#define GLX_AUX8_EXT 0x20EA +#define GLX_AUX9_EXT 0x20EB + +typedef void ( * PFNGLXBINDTEXIMAGEEXTPROC) (Display* display, GLXDrawable drawable, int buffer, const int *attrib_list); +typedef void ( * PFNGLXRELEASETEXIMAGEEXTPROC) (Display* display, GLXDrawable drawable, int buffer); + +#define glXBindTexImageEXT GLXEW_GET_FUN(__glewXBindTexImageEXT) +#define glXReleaseTexImageEXT GLXEW_GET_FUN(__glewXReleaseTexImageEXT) + +#define GLXEW_EXT_texture_from_pixmap GLXEW_GET_VAR(__GLXEW_EXT_texture_from_pixmap) + +#endif /* GLX_EXT_texture_from_pixmap */ + +/* -------------------------- GLX_EXT_visual_info -------------------------- */ + +#ifndef GLX_EXT_visual_info +#define GLX_EXT_visual_info 1 + +#define GLX_X_VISUAL_TYPE_EXT 0x22 +#define GLX_TRANSPARENT_TYPE_EXT 0x23 +#define GLX_TRANSPARENT_INDEX_VALUE_EXT 0x24 +#define GLX_TRANSPARENT_RED_VALUE_EXT 0x25 +#define GLX_TRANSPARENT_GREEN_VALUE_EXT 0x26 +#define GLX_TRANSPARENT_BLUE_VALUE_EXT 0x27 +#define GLX_TRANSPARENT_ALPHA_VALUE_EXT 0x28 +#define GLX_NONE_EXT 0x8000 +#define GLX_TRUE_COLOR_EXT 0x8002 +#define GLX_DIRECT_COLOR_EXT 0x8003 +#define GLX_PSEUDO_COLOR_EXT 0x8004 +#define GLX_STATIC_COLOR_EXT 0x8005 +#define GLX_GRAY_SCALE_EXT 0x8006 +#define GLX_STATIC_GRAY_EXT 0x8007 +#define GLX_TRANSPARENT_RGB_EXT 0x8008 +#define GLX_TRANSPARENT_INDEX_EXT 0x8009 + +#define GLXEW_EXT_visual_info GLXEW_GET_VAR(__GLXEW_EXT_visual_info) + +#endif /* GLX_EXT_visual_info */ + +/* ------------------------- GLX_EXT_visual_rating ------------------------- */ + +#ifndef GLX_EXT_visual_rating +#define GLX_EXT_visual_rating 1 + +#define GLX_VISUAL_CAVEAT_EXT 0x20 +#define GLX_SLOW_VISUAL_EXT 0x8001 +#define GLX_NON_CONFORMANT_VISUAL_EXT 0x800D + +#define GLXEW_EXT_visual_rating GLXEW_GET_VAR(__GLXEW_EXT_visual_rating) + +#endif /* GLX_EXT_visual_rating */ + +/* -------------------------- GLX_INTEL_swap_event ------------------------- */ + +#ifndef GLX_INTEL_swap_event +#define GLX_INTEL_swap_event 1 + +#define GLX_EXCHANGE_COMPLETE_INTEL 0x8180 +#define GLX_COPY_COMPLETE_INTEL 0x8181 +#define GLX_FLIP_COMPLETE_INTEL 0x8182 +#define GLX_BUFFER_SWAP_COMPLETE_INTEL_MASK 0x04000000 + +#define GLXEW_INTEL_swap_event GLXEW_GET_VAR(__GLXEW_INTEL_swap_event) + +#endif /* GLX_INTEL_swap_event */ + +/* -------------------------- GLX_MESA_agp_offset -------------------------- */ + +#ifndef GLX_MESA_agp_offset +#define GLX_MESA_agp_offset 1 + +typedef unsigned int ( * PFNGLXGETAGPOFFSETMESAPROC) (const void* pointer); + +#define glXGetAGPOffsetMESA GLXEW_GET_FUN(__glewXGetAGPOffsetMESA) + +#define GLXEW_MESA_agp_offset GLXEW_GET_VAR(__GLXEW_MESA_agp_offset) + +#endif /* GLX_MESA_agp_offset */ + +/* ------------------------ GLX_MESA_copy_sub_buffer ----------------------- */ + +#ifndef GLX_MESA_copy_sub_buffer +#define GLX_MESA_copy_sub_buffer 1 + +typedef void ( * PFNGLXCOPYSUBBUFFERMESAPROC) (Display* dpy, GLXDrawable drawable, int x, int y, int width, int height); + +#define glXCopySubBufferMESA GLXEW_GET_FUN(__glewXCopySubBufferMESA) + +#define GLXEW_MESA_copy_sub_buffer GLXEW_GET_VAR(__GLXEW_MESA_copy_sub_buffer) + +#endif /* GLX_MESA_copy_sub_buffer */ + +/* ------------------------ GLX_MESA_pixmap_colormap ----------------------- */ + +#ifndef GLX_MESA_pixmap_colormap +#define GLX_MESA_pixmap_colormap 1 + +typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPMESAPROC) (Display* dpy, XVisualInfo *visual, Pixmap pixmap, Colormap cmap); + +#define glXCreateGLXPixmapMESA GLXEW_GET_FUN(__glewXCreateGLXPixmapMESA) + +#define GLXEW_MESA_pixmap_colormap GLXEW_GET_VAR(__GLXEW_MESA_pixmap_colormap) + +#endif /* GLX_MESA_pixmap_colormap */ + +/* ------------------------ GLX_MESA_release_buffers ----------------------- */ + +#ifndef GLX_MESA_release_buffers +#define GLX_MESA_release_buffers 1 + +typedef Bool ( * PFNGLXRELEASEBUFFERSMESAPROC) (Display* dpy, GLXDrawable d); + +#define glXReleaseBuffersMESA GLXEW_GET_FUN(__glewXReleaseBuffersMESA) + +#define GLXEW_MESA_release_buffers GLXEW_GET_VAR(__GLXEW_MESA_release_buffers) + +#endif /* GLX_MESA_release_buffers */ + +/* ------------------------- GLX_MESA_set_3dfx_mode ------------------------ */ + +#ifndef GLX_MESA_set_3dfx_mode +#define GLX_MESA_set_3dfx_mode 1 + +#define GLX_3DFX_WINDOW_MODE_MESA 0x1 +#define GLX_3DFX_FULLSCREEN_MODE_MESA 0x2 + +typedef GLboolean ( * PFNGLXSET3DFXMODEMESAPROC) (GLint mode); + +#define glXSet3DfxModeMESA GLXEW_GET_FUN(__glewXSet3DfxModeMESA) + +#define GLXEW_MESA_set_3dfx_mode GLXEW_GET_VAR(__GLXEW_MESA_set_3dfx_mode) + +#endif /* GLX_MESA_set_3dfx_mode */ + +/* --------------------------- GLX_NV_copy_image --------------------------- */ + +#ifndef GLX_NV_copy_image +#define GLX_NV_copy_image 1 + +typedef void ( * PFNGLXCOPYIMAGESUBDATANVPROC) (Display *dpy, GLXContext srcCtx, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLXContext dstCtx, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); + +#define glXCopyImageSubDataNV GLXEW_GET_FUN(__glewXCopyImageSubDataNV) + +#define GLXEW_NV_copy_image GLXEW_GET_VAR(__GLXEW_NV_copy_image) + +#endif /* GLX_NV_copy_image */ + +/* -------------------------- GLX_NV_float_buffer -------------------------- */ + +#ifndef GLX_NV_float_buffer +#define GLX_NV_float_buffer 1 + +#define GLX_FLOAT_COMPONENTS_NV 0x20B0 + +#define GLXEW_NV_float_buffer GLXEW_GET_VAR(__GLXEW_NV_float_buffer) + +#endif /* GLX_NV_float_buffer */ + +/* -------------------------- GLX_NV_present_video ------------------------- */ + +#ifndef GLX_NV_present_video +#define GLX_NV_present_video 1 + +#define GLX_NUM_VIDEO_SLOTS_NV 0x20F0 + +typedef int ( * PFNGLXBINDVIDEODEVICENVPROC) (Display* dpy, unsigned int video_slot, unsigned int video_device, const int *attrib_list); +typedef unsigned int* ( * PFNGLXENUMERATEVIDEODEVICESNVPROC) (Display *dpy, int screen, int *nelements); + +#define glXBindVideoDeviceNV GLXEW_GET_FUN(__glewXBindVideoDeviceNV) +#define glXEnumerateVideoDevicesNV GLXEW_GET_FUN(__glewXEnumerateVideoDevicesNV) + +#define GLXEW_NV_present_video GLXEW_GET_VAR(__GLXEW_NV_present_video) + +#endif /* GLX_NV_present_video */ + +/* --------------------------- GLX_NV_swap_group --------------------------- */ + +#ifndef GLX_NV_swap_group +#define GLX_NV_swap_group 1 + +typedef Bool ( * PFNGLXBINDSWAPBARRIERNVPROC) (Display* dpy, GLuint group, GLuint barrier); +typedef Bool ( * PFNGLXJOINSWAPGROUPNVPROC) (Display* dpy, GLXDrawable drawable, GLuint group); +typedef Bool ( * PFNGLXQUERYFRAMECOUNTNVPROC) (Display* dpy, int screen, GLuint *count); +typedef Bool ( * PFNGLXQUERYMAXSWAPGROUPSNVPROC) (Display* dpy, int screen, GLuint *maxGroups, GLuint *maxBarriers); +typedef Bool ( * PFNGLXQUERYSWAPGROUPNVPROC) (Display* dpy, GLXDrawable drawable, GLuint *group, GLuint *barrier); +typedef Bool ( * PFNGLXRESETFRAMECOUNTNVPROC) (Display* dpy, int screen); + +#define glXBindSwapBarrierNV GLXEW_GET_FUN(__glewXBindSwapBarrierNV) +#define glXJoinSwapGroupNV GLXEW_GET_FUN(__glewXJoinSwapGroupNV) +#define glXQueryFrameCountNV GLXEW_GET_FUN(__glewXQueryFrameCountNV) +#define glXQueryMaxSwapGroupsNV GLXEW_GET_FUN(__glewXQueryMaxSwapGroupsNV) +#define glXQuerySwapGroupNV GLXEW_GET_FUN(__glewXQuerySwapGroupNV) +#define glXResetFrameCountNV GLXEW_GET_FUN(__glewXResetFrameCountNV) + +#define GLXEW_NV_swap_group GLXEW_GET_VAR(__GLXEW_NV_swap_group) + +#endif /* GLX_NV_swap_group */ + +/* ----------------------- GLX_NV_vertex_array_range ----------------------- */ + +#ifndef GLX_NV_vertex_array_range +#define GLX_NV_vertex_array_range 1 + +typedef void * ( * PFNGLXALLOCATEMEMORYNVPROC) (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority); +typedef void ( * PFNGLXFREEMEMORYNVPROC) (void *pointer); + +#define glXAllocateMemoryNV GLXEW_GET_FUN(__glewXAllocateMemoryNV) +#define glXFreeMemoryNV GLXEW_GET_FUN(__glewXFreeMemoryNV) + +#define GLXEW_NV_vertex_array_range GLXEW_GET_VAR(__GLXEW_NV_vertex_array_range) + +#endif /* GLX_NV_vertex_array_range */ + +/* -------------------------- GLX_NV_video_output -------------------------- */ + +#ifndef GLX_NV_video_output +#define GLX_NV_video_output 1 + +#define GLX_VIDEO_OUT_COLOR_NV 0x20C3 +#define GLX_VIDEO_OUT_ALPHA_NV 0x20C4 +#define GLX_VIDEO_OUT_DEPTH_NV 0x20C5 +#define GLX_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 +#define GLX_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 +#define GLX_VIDEO_OUT_FRAME_NV 0x20C8 +#define GLX_VIDEO_OUT_FIELD_1_NV 0x20C9 +#define GLX_VIDEO_OUT_FIELD_2_NV 0x20CA +#define GLX_VIDEO_OUT_STACKED_FIELDS_1_2_NV 0x20CB +#define GLX_VIDEO_OUT_STACKED_FIELDS_2_1_NV 0x20CC + +typedef int ( * PFNGLXBINDVIDEOIMAGENVPROC) (Display* dpy, GLXVideoDeviceNV VideoDevice, GLXPbuffer pbuf, int iVideoBuffer); +typedef int ( * PFNGLXGETVIDEODEVICENVPROC) (Display* dpy, int screen, int numVideoDevices, GLXVideoDeviceNV *pVideoDevice); +typedef int ( * PFNGLXGETVIDEOINFONVPROC) (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice, unsigned long *pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo); +typedef int ( * PFNGLXRELEASEVIDEODEVICENVPROC) (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice); +typedef int ( * PFNGLXRELEASEVIDEOIMAGENVPROC) (Display* dpy, GLXPbuffer pbuf); +typedef int ( * PFNGLXSENDPBUFFERTOVIDEONVPROC) (Display* dpy, GLXPbuffer pbuf, int iBufferType, unsigned long *pulCounterPbuffer, GLboolean bBlock); + +#define glXBindVideoImageNV GLXEW_GET_FUN(__glewXBindVideoImageNV) +#define glXGetVideoDeviceNV GLXEW_GET_FUN(__glewXGetVideoDeviceNV) +#define glXGetVideoInfoNV GLXEW_GET_FUN(__glewXGetVideoInfoNV) +#define glXReleaseVideoDeviceNV GLXEW_GET_FUN(__glewXReleaseVideoDeviceNV) +#define glXReleaseVideoImageNV GLXEW_GET_FUN(__glewXReleaseVideoImageNV) +#define glXSendPbufferToVideoNV GLXEW_GET_FUN(__glewXSendPbufferToVideoNV) + +#define GLXEW_NV_video_output GLXEW_GET_VAR(__GLXEW_NV_video_output) + +#endif /* GLX_NV_video_output */ + +/* -------------------------- GLX_OML_swap_method -------------------------- */ + +#ifndef GLX_OML_swap_method +#define GLX_OML_swap_method 1 + +#define GLX_SWAP_METHOD_OML 0x8060 +#define GLX_SWAP_EXCHANGE_OML 0x8061 +#define GLX_SWAP_COPY_OML 0x8062 +#define GLX_SWAP_UNDEFINED_OML 0x8063 + +#define GLXEW_OML_swap_method GLXEW_GET_VAR(__GLXEW_OML_swap_method) + +#endif /* GLX_OML_swap_method */ + +/* -------------------------- GLX_OML_sync_control ------------------------- */ + +#if !defined(GLX_OML_sync_control) && defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) +#include +#define GLX_OML_sync_control 1 + +typedef Bool ( * PFNGLXGETMSCRATEOMLPROC) (Display* dpy, GLXDrawable drawable, int32_t* numerator, int32_t* denominator); +typedef Bool ( * PFNGLXGETSYNCVALUESOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t* ust, int64_t* msc, int64_t* sbc); +typedef int64_t ( * PFNGLXSWAPBUFFERSMSCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder); +typedef Bool ( * PFNGLXWAITFORMSCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder, int64_t* ust, int64_t* msc, int64_t* sbc); +typedef Bool ( * PFNGLXWAITFORSBCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_sbc, int64_t* ust, int64_t* msc, int64_t* sbc); + +#define glXGetMscRateOML GLXEW_GET_FUN(__glewXGetMscRateOML) +#define glXGetSyncValuesOML GLXEW_GET_FUN(__glewXGetSyncValuesOML) +#define glXSwapBuffersMscOML GLXEW_GET_FUN(__glewXSwapBuffersMscOML) +#define glXWaitForMscOML GLXEW_GET_FUN(__glewXWaitForMscOML) +#define glXWaitForSbcOML GLXEW_GET_FUN(__glewXWaitForSbcOML) + +#define GLXEW_OML_sync_control GLXEW_GET_VAR(__GLXEW_OML_sync_control) + +#endif /* GLX_OML_sync_control */ + +/* ------------------------ GLX_SGIS_blended_overlay ----------------------- */ + +#ifndef GLX_SGIS_blended_overlay +#define GLX_SGIS_blended_overlay 1 + +#define GLX_BLENDED_RGBA_SGIS 0x8025 + +#define GLXEW_SGIS_blended_overlay GLXEW_GET_VAR(__GLXEW_SGIS_blended_overlay) + +#endif /* GLX_SGIS_blended_overlay */ + +/* -------------------------- GLX_SGIS_color_range ------------------------- */ + +#ifndef GLX_SGIS_color_range +#define GLX_SGIS_color_range 1 + +#define GLX_MIN_RED_SGIS 0 +#define GLX_MAX_GREEN_SGIS 0 +#define GLX_MIN_BLUE_SGIS 0 +#define GLX_MAX_ALPHA_SGIS 0 +#define GLX_MIN_GREEN_SGIS 0 +#define GLX_MIN_ALPHA_SGIS 0 +#define GLX_MAX_RED_SGIS 0 +#define GLX_EXTENDED_RANGE_SGIS 0 +#define GLX_MAX_BLUE_SGIS 0 + +#define GLXEW_SGIS_color_range GLXEW_GET_VAR(__GLXEW_SGIS_color_range) + +#endif /* GLX_SGIS_color_range */ + +/* -------------------------- GLX_SGIS_multisample ------------------------- */ + +#ifndef GLX_SGIS_multisample +#define GLX_SGIS_multisample 1 + +#define GLX_SAMPLE_BUFFERS_SGIS 100000 +#define GLX_SAMPLES_SGIS 100001 + +#define GLXEW_SGIS_multisample GLXEW_GET_VAR(__GLXEW_SGIS_multisample) + +#endif /* GLX_SGIS_multisample */ + +/* ---------------------- GLX_SGIS_shared_multisample ---------------------- */ + +#ifndef GLX_SGIS_shared_multisample +#define GLX_SGIS_shared_multisample 1 + +#define GLX_MULTISAMPLE_SUB_RECT_WIDTH_SGIS 0x8026 +#define GLX_MULTISAMPLE_SUB_RECT_HEIGHT_SGIS 0x8027 + +#define GLXEW_SGIS_shared_multisample GLXEW_GET_VAR(__GLXEW_SGIS_shared_multisample) + +#endif /* GLX_SGIS_shared_multisample */ + +/* --------------------------- GLX_SGIX_fbconfig --------------------------- */ + +#ifndef GLX_SGIX_fbconfig +#define GLX_SGIX_fbconfig 1 + +#define GLX_WINDOW_BIT_SGIX 0x00000001 +#define GLX_RGBA_BIT_SGIX 0x00000001 +#define GLX_PIXMAP_BIT_SGIX 0x00000002 +#define GLX_COLOR_INDEX_BIT_SGIX 0x00000002 +#define GLX_SCREEN_EXT 0x800C +#define GLX_DRAWABLE_TYPE_SGIX 0x8010 +#define GLX_RENDER_TYPE_SGIX 0x8011 +#define GLX_X_RENDERABLE_SGIX 0x8012 +#define GLX_FBCONFIG_ID_SGIX 0x8013 +#define GLX_RGBA_TYPE_SGIX 0x8014 +#define GLX_COLOR_INDEX_TYPE_SGIX 0x8015 + +typedef XID GLXFBConfigIDSGIX; +typedef struct __GLXFBConfigRec *GLXFBConfigSGIX; + +typedef GLXFBConfigSGIX* ( * PFNGLXCHOOSEFBCONFIGSGIXPROC) (Display *dpy, int screen, const int *attrib_list, int *nelements); +typedef GLXContext ( * PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC) (Display* dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct); +typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC) (Display* dpy, GLXFBConfig config, Pixmap pixmap); +typedef int ( * PFNGLXGETFBCONFIGATTRIBSGIXPROC) (Display* dpy, GLXFBConfigSGIX config, int attribute, int *value); +typedef GLXFBConfigSGIX ( * PFNGLXGETFBCONFIGFROMVISUALSGIXPROC) (Display* dpy, XVisualInfo *vis); +typedef XVisualInfo* ( * PFNGLXGETVISUALFROMFBCONFIGSGIXPROC) (Display *dpy, GLXFBConfig config); + +#define glXChooseFBConfigSGIX GLXEW_GET_FUN(__glewXChooseFBConfigSGIX) +#define glXCreateContextWithConfigSGIX GLXEW_GET_FUN(__glewXCreateContextWithConfigSGIX) +#define glXCreateGLXPixmapWithConfigSGIX GLXEW_GET_FUN(__glewXCreateGLXPixmapWithConfigSGIX) +#define glXGetFBConfigAttribSGIX GLXEW_GET_FUN(__glewXGetFBConfigAttribSGIX) +#define glXGetFBConfigFromVisualSGIX GLXEW_GET_FUN(__glewXGetFBConfigFromVisualSGIX) +#define glXGetVisualFromFBConfigSGIX GLXEW_GET_FUN(__glewXGetVisualFromFBConfigSGIX) + +#define GLXEW_SGIX_fbconfig GLXEW_GET_VAR(__GLXEW_SGIX_fbconfig) + +#endif /* GLX_SGIX_fbconfig */ + +/* --------------------------- GLX_SGIX_hyperpipe -------------------------- */ + +#ifndef GLX_SGIX_hyperpipe +#define GLX_SGIX_hyperpipe 1 + +#define GLX_HYPERPIPE_DISPLAY_PIPE_SGIX 0x00000001 +#define GLX_PIPE_RECT_SGIX 0x00000001 +#define GLX_PIPE_RECT_LIMITS_SGIX 0x00000002 +#define GLX_HYPERPIPE_RENDER_PIPE_SGIX 0x00000002 +#define GLX_HYPERPIPE_STEREO_SGIX 0x00000003 +#define GLX_HYPERPIPE_PIXEL_AVERAGE_SGIX 0x00000004 +#define GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX 80 +#define GLX_BAD_HYPERPIPE_CONFIG_SGIX 91 +#define GLX_BAD_HYPERPIPE_SGIX 92 +#define GLX_HYPERPIPE_ID_SGIX 0x8030 + +typedef struct { + char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; + int networkId; +} GLXHyperpipeNetworkSGIX; +typedef struct { + char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; + int XOrigin; + int YOrigin; + int maxHeight; + int maxWidth; +} GLXPipeRectLimits; +typedef struct { + char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; + int channel; + unsigned int participationType; + int timeSlice; +} GLXHyperpipeConfigSGIX; +typedef struct { + char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; + int srcXOrigin; + int srcYOrigin; + int srcWidth; + int srcHeight; + int destXOrigin; + int destYOrigin; + int destWidth; + int destHeight; +} GLXPipeRect; + +typedef int ( * PFNGLXBINDHYPERPIPESGIXPROC) (Display *dpy, int hpId); +typedef int ( * PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC) (Display *dpy, int hpId); +typedef int ( * PFNGLXHYPERPIPEATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *attribList); +typedef int ( * PFNGLXHYPERPIPECONFIGSGIXPROC) (Display *dpy, int networkId, int npipes, GLXHyperpipeConfigSGIX *cfg, int *hpId); +typedef int ( * PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *returnAttribList); +typedef int ( * PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *attribList, void *returnAttribList); +typedef GLXHyperpipeConfigSGIX * ( * PFNGLXQUERYHYPERPIPECONFIGSGIXPROC) (Display *dpy, int hpId, int *npipes); +typedef GLXHyperpipeNetworkSGIX * ( * PFNGLXQUERYHYPERPIPENETWORKSGIXPROC) (Display *dpy, int *npipes); + +#define glXBindHyperpipeSGIX GLXEW_GET_FUN(__glewXBindHyperpipeSGIX) +#define glXDestroyHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXDestroyHyperpipeConfigSGIX) +#define glXHyperpipeAttribSGIX GLXEW_GET_FUN(__glewXHyperpipeAttribSGIX) +#define glXHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXHyperpipeConfigSGIX) +#define glXQueryHyperpipeAttribSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeAttribSGIX) +#define glXQueryHyperpipeBestAttribSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeBestAttribSGIX) +#define glXQueryHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeConfigSGIX) +#define glXQueryHyperpipeNetworkSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeNetworkSGIX) + +#define GLXEW_SGIX_hyperpipe GLXEW_GET_VAR(__GLXEW_SGIX_hyperpipe) + +#endif /* GLX_SGIX_hyperpipe */ + +/* ---------------------------- GLX_SGIX_pbuffer --------------------------- */ + +#ifndef GLX_SGIX_pbuffer +#define GLX_SGIX_pbuffer 1 + +#define GLX_FRONT_LEFT_BUFFER_BIT_SGIX 0x00000001 +#define GLX_FRONT_RIGHT_BUFFER_BIT_SGIX 0x00000002 +#define GLX_PBUFFER_BIT_SGIX 0x00000004 +#define GLX_BACK_LEFT_BUFFER_BIT_SGIX 0x00000004 +#define GLX_BACK_RIGHT_BUFFER_BIT_SGIX 0x00000008 +#define GLX_AUX_BUFFERS_BIT_SGIX 0x00000010 +#define GLX_DEPTH_BUFFER_BIT_SGIX 0x00000020 +#define GLX_STENCIL_BUFFER_BIT_SGIX 0x00000040 +#define GLX_ACCUM_BUFFER_BIT_SGIX 0x00000080 +#define GLX_SAMPLE_BUFFERS_BIT_SGIX 0x00000100 +#define GLX_MAX_PBUFFER_WIDTH_SGIX 0x8016 +#define GLX_MAX_PBUFFER_HEIGHT_SGIX 0x8017 +#define GLX_MAX_PBUFFER_PIXELS_SGIX 0x8018 +#define GLX_OPTIMAL_PBUFFER_WIDTH_SGIX 0x8019 +#define GLX_OPTIMAL_PBUFFER_HEIGHT_SGIX 0x801A +#define GLX_PRESERVED_CONTENTS_SGIX 0x801B +#define GLX_LARGEST_PBUFFER_SGIX 0x801C +#define GLX_WIDTH_SGIX 0x801D +#define GLX_HEIGHT_SGIX 0x801E +#define GLX_EVENT_MASK_SGIX 0x801F +#define GLX_DAMAGED_SGIX 0x8020 +#define GLX_SAVED_SGIX 0x8021 +#define GLX_WINDOW_SGIX 0x8022 +#define GLX_PBUFFER_SGIX 0x8023 +#define GLX_BUFFER_CLOBBER_MASK_SGIX 0x08000000 + +typedef XID GLXPbufferSGIX; +typedef struct { int type; unsigned long serial; Bool send_event; Display *display; GLXDrawable drawable; int event_type; int draw_type; unsigned int mask; int x, y; int width, height; int count; } GLXBufferClobberEventSGIX; + +typedef GLXPbuffer ( * PFNGLXCREATEGLXPBUFFERSGIXPROC) (Display* dpy, GLXFBConfig config, unsigned int width, unsigned int height, int *attrib_list); +typedef void ( * PFNGLXDESTROYGLXPBUFFERSGIXPROC) (Display* dpy, GLXPbuffer pbuf); +typedef void ( * PFNGLXGETSELECTEDEVENTSGIXPROC) (Display* dpy, GLXDrawable drawable, unsigned long *mask); +typedef void ( * PFNGLXQUERYGLXPBUFFERSGIXPROC) (Display* dpy, GLXPbuffer pbuf, int attribute, unsigned int *value); +typedef void ( * PFNGLXSELECTEVENTSGIXPROC) (Display* dpy, GLXDrawable drawable, unsigned long mask); + +#define glXCreateGLXPbufferSGIX GLXEW_GET_FUN(__glewXCreateGLXPbufferSGIX) +#define glXDestroyGLXPbufferSGIX GLXEW_GET_FUN(__glewXDestroyGLXPbufferSGIX) +#define glXGetSelectedEventSGIX GLXEW_GET_FUN(__glewXGetSelectedEventSGIX) +#define glXQueryGLXPbufferSGIX GLXEW_GET_FUN(__glewXQueryGLXPbufferSGIX) +#define glXSelectEventSGIX GLXEW_GET_FUN(__glewXSelectEventSGIX) + +#define GLXEW_SGIX_pbuffer GLXEW_GET_VAR(__GLXEW_SGIX_pbuffer) + +#endif /* GLX_SGIX_pbuffer */ + +/* ------------------------- GLX_SGIX_swap_barrier ------------------------- */ + +#ifndef GLX_SGIX_swap_barrier +#define GLX_SGIX_swap_barrier 1 + +typedef void ( * PFNGLXBINDSWAPBARRIERSGIXPROC) (Display *dpy, GLXDrawable drawable, int barrier); +typedef Bool ( * PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC) (Display *dpy, int screen, int *max); + +#define glXBindSwapBarrierSGIX GLXEW_GET_FUN(__glewXBindSwapBarrierSGIX) +#define glXQueryMaxSwapBarriersSGIX GLXEW_GET_FUN(__glewXQueryMaxSwapBarriersSGIX) + +#define GLXEW_SGIX_swap_barrier GLXEW_GET_VAR(__GLXEW_SGIX_swap_barrier) + +#endif /* GLX_SGIX_swap_barrier */ + +/* -------------------------- GLX_SGIX_swap_group -------------------------- */ + +#ifndef GLX_SGIX_swap_group +#define GLX_SGIX_swap_group 1 + +typedef void ( * PFNGLXJOINSWAPGROUPSGIXPROC) (Display *dpy, GLXDrawable drawable, GLXDrawable member); + +#define glXJoinSwapGroupSGIX GLXEW_GET_FUN(__glewXJoinSwapGroupSGIX) + +#define GLXEW_SGIX_swap_group GLXEW_GET_VAR(__GLXEW_SGIX_swap_group) + +#endif /* GLX_SGIX_swap_group */ + +/* ------------------------- GLX_SGIX_video_resize ------------------------- */ + +#ifndef GLX_SGIX_video_resize +#define GLX_SGIX_video_resize 1 + +#define GLX_SYNC_FRAME_SGIX 0x00000000 +#define GLX_SYNC_SWAP_SGIX 0x00000001 + +typedef int ( * PFNGLXBINDCHANNELTOWINDOWSGIXPROC) (Display* display, int screen, int channel, Window window); +typedef int ( * PFNGLXCHANNELRECTSGIXPROC) (Display* display, int screen, int channel, int x, int y, int w, int h); +typedef int ( * PFNGLXCHANNELRECTSYNCSGIXPROC) (Display* display, int screen, int channel, GLenum synctype); +typedef int ( * PFNGLXQUERYCHANNELDELTASSGIXPROC) (Display* display, int screen, int channel, int *x, int *y, int *w, int *h); +typedef int ( * PFNGLXQUERYCHANNELRECTSGIXPROC) (Display* display, int screen, int channel, int *dx, int *dy, int *dw, int *dh); + +#define glXBindChannelToWindowSGIX GLXEW_GET_FUN(__glewXBindChannelToWindowSGIX) +#define glXChannelRectSGIX GLXEW_GET_FUN(__glewXChannelRectSGIX) +#define glXChannelRectSyncSGIX GLXEW_GET_FUN(__glewXChannelRectSyncSGIX) +#define glXQueryChannelDeltasSGIX GLXEW_GET_FUN(__glewXQueryChannelDeltasSGIX) +#define glXQueryChannelRectSGIX GLXEW_GET_FUN(__glewXQueryChannelRectSGIX) + +#define GLXEW_SGIX_video_resize GLXEW_GET_VAR(__GLXEW_SGIX_video_resize) + +#endif /* GLX_SGIX_video_resize */ + +/* ---------------------- GLX_SGIX_visual_select_group --------------------- */ + +#ifndef GLX_SGIX_visual_select_group +#define GLX_SGIX_visual_select_group 1 + +#define GLX_VISUAL_SELECT_GROUP_SGIX 0x8028 + +#define GLXEW_SGIX_visual_select_group GLXEW_GET_VAR(__GLXEW_SGIX_visual_select_group) + +#endif /* GLX_SGIX_visual_select_group */ + +/* ---------------------------- GLX_SGI_cushion ---------------------------- */ + +#ifndef GLX_SGI_cushion +#define GLX_SGI_cushion 1 + +typedef void ( * PFNGLXCUSHIONSGIPROC) (Display* dpy, Window window, float cushion); + +#define glXCushionSGI GLXEW_GET_FUN(__glewXCushionSGI) + +#define GLXEW_SGI_cushion GLXEW_GET_VAR(__GLXEW_SGI_cushion) + +#endif /* GLX_SGI_cushion */ + +/* ----------------------- GLX_SGI_make_current_read ----------------------- */ + +#ifndef GLX_SGI_make_current_read +#define GLX_SGI_make_current_read 1 + +typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLESGIPROC) (void); +typedef Bool ( * PFNGLXMAKECURRENTREADSGIPROC) (Display* dpy, GLXDrawable draw, GLXDrawable read, GLXContext ctx); + +#define glXGetCurrentReadDrawableSGI GLXEW_GET_FUN(__glewXGetCurrentReadDrawableSGI) +#define glXMakeCurrentReadSGI GLXEW_GET_FUN(__glewXMakeCurrentReadSGI) + +#define GLXEW_SGI_make_current_read GLXEW_GET_VAR(__GLXEW_SGI_make_current_read) + +#endif /* GLX_SGI_make_current_read */ + +/* -------------------------- GLX_SGI_swap_control ------------------------- */ + +#ifndef GLX_SGI_swap_control +#define GLX_SGI_swap_control 1 + +typedef int ( * PFNGLXSWAPINTERVALSGIPROC) (int interval); + +#define glXSwapIntervalSGI GLXEW_GET_FUN(__glewXSwapIntervalSGI) + +#define GLXEW_SGI_swap_control GLXEW_GET_VAR(__GLXEW_SGI_swap_control) + +#endif /* GLX_SGI_swap_control */ + +/* --------------------------- GLX_SGI_video_sync -------------------------- */ + +#ifndef GLX_SGI_video_sync +#define GLX_SGI_video_sync 1 + +typedef int ( * PFNGLXGETVIDEOSYNCSGIPROC) (uint* count); +typedef int ( * PFNGLXWAITVIDEOSYNCSGIPROC) (int divisor, int remainder, unsigned int* count); + +#define glXGetVideoSyncSGI GLXEW_GET_FUN(__glewXGetVideoSyncSGI) +#define glXWaitVideoSyncSGI GLXEW_GET_FUN(__glewXWaitVideoSyncSGI) + +#define GLXEW_SGI_video_sync GLXEW_GET_VAR(__GLXEW_SGI_video_sync) + +#endif /* GLX_SGI_video_sync */ + +/* --------------------- GLX_SUN_get_transparent_index --------------------- */ + +#ifndef GLX_SUN_get_transparent_index +#define GLX_SUN_get_transparent_index 1 + +typedef Status ( * PFNGLXGETTRANSPARENTINDEXSUNPROC) (Display* dpy, Window overlay, Window underlay, unsigned long *pTransparentIndex); + +#define glXGetTransparentIndexSUN GLXEW_GET_FUN(__glewXGetTransparentIndexSUN) + +#define GLXEW_SUN_get_transparent_index GLXEW_GET_VAR(__GLXEW_SUN_get_transparent_index) + +#endif /* GLX_SUN_get_transparent_index */ + +/* -------------------------- GLX_SUN_video_resize ------------------------- */ + +#ifndef GLX_SUN_video_resize +#define GLX_SUN_video_resize 1 + +#define GLX_VIDEO_RESIZE_SUN 0x8171 +#define GL_VIDEO_RESIZE_COMPENSATION_SUN 0x85CD + +typedef int ( * PFNGLXGETVIDEORESIZESUNPROC) (Display* display, GLXDrawable window, float* factor); +typedef int ( * PFNGLXVIDEORESIZESUNPROC) (Display* display, GLXDrawable window, float factor); + +#define glXGetVideoResizeSUN GLXEW_GET_FUN(__glewXGetVideoResizeSUN) +#define glXVideoResizeSUN GLXEW_GET_FUN(__glewXVideoResizeSUN) + +#define GLXEW_SUN_video_resize GLXEW_GET_VAR(__GLXEW_SUN_video_resize) + +#endif /* GLX_SUN_video_resize */ + +/* ------------------------------------------------------------------------- */ + +#ifdef GLEW_MX +#define GLXEW_EXPORT +#else +#define GLXEW_EXPORT extern +#endif /* GLEW_MX */ + +extern PFNGLXGETCURRENTDISPLAYPROC __glewXGetCurrentDisplay; + +extern PFNGLXCHOOSEFBCONFIGPROC __glewXChooseFBConfig; +extern PFNGLXCREATENEWCONTEXTPROC __glewXCreateNewContext; +extern PFNGLXCREATEPBUFFERPROC __glewXCreatePbuffer; +extern PFNGLXCREATEPIXMAPPROC __glewXCreatePixmap; +extern PFNGLXCREATEWINDOWPROC __glewXCreateWindow; +extern PFNGLXDESTROYPBUFFERPROC __glewXDestroyPbuffer; +extern PFNGLXDESTROYPIXMAPPROC __glewXDestroyPixmap; +extern PFNGLXDESTROYWINDOWPROC __glewXDestroyWindow; +extern PFNGLXGETCURRENTREADDRAWABLEPROC __glewXGetCurrentReadDrawable; +extern PFNGLXGETFBCONFIGATTRIBPROC __glewXGetFBConfigAttrib; +extern PFNGLXGETFBCONFIGSPROC __glewXGetFBConfigs; +extern PFNGLXGETSELECTEDEVENTPROC __glewXGetSelectedEvent; +extern PFNGLXGETVISUALFROMFBCONFIGPROC __glewXGetVisualFromFBConfig; +extern PFNGLXMAKECONTEXTCURRENTPROC __glewXMakeContextCurrent; +extern PFNGLXQUERYCONTEXTPROC __glewXQueryContext; +extern PFNGLXQUERYDRAWABLEPROC __glewXQueryDrawable; +extern PFNGLXSELECTEVENTPROC __glewXSelectEvent; + +extern PFNGLXCREATECONTEXTATTRIBSARBPROC __glewXCreateContextAttribsARB; + +extern PFNGLXBINDTEXIMAGEATIPROC __glewXBindTexImageATI; +extern PFNGLXDRAWABLEATTRIBATIPROC __glewXDrawableAttribATI; +extern PFNGLXRELEASETEXIMAGEATIPROC __glewXReleaseTexImageATI; + +extern PFNGLXFREECONTEXTEXTPROC __glewXFreeContextEXT; +extern PFNGLXGETCONTEXTIDEXTPROC __glewXGetContextIDEXT; +extern PFNGLXIMPORTCONTEXTEXTPROC __glewXImportContextEXT; +extern PFNGLXQUERYCONTEXTINFOEXTPROC __glewXQueryContextInfoEXT; + +extern PFNGLXSWAPINTERVALEXTPROC __glewXSwapIntervalEXT; + +extern PFNGLXBINDTEXIMAGEEXTPROC __glewXBindTexImageEXT; +extern PFNGLXRELEASETEXIMAGEEXTPROC __glewXReleaseTexImageEXT; + +extern PFNGLXGETAGPOFFSETMESAPROC __glewXGetAGPOffsetMESA; + +extern PFNGLXCOPYSUBBUFFERMESAPROC __glewXCopySubBufferMESA; + +extern PFNGLXCREATEGLXPIXMAPMESAPROC __glewXCreateGLXPixmapMESA; + +extern PFNGLXRELEASEBUFFERSMESAPROC __glewXReleaseBuffersMESA; + +extern PFNGLXSET3DFXMODEMESAPROC __glewXSet3DfxModeMESA; + +extern PFNGLXCOPYIMAGESUBDATANVPROC __glewXCopyImageSubDataNV; + +extern PFNGLXBINDVIDEODEVICENVPROC __glewXBindVideoDeviceNV; +extern PFNGLXENUMERATEVIDEODEVICESNVPROC __glewXEnumerateVideoDevicesNV; + +extern PFNGLXBINDSWAPBARRIERNVPROC __glewXBindSwapBarrierNV; +extern PFNGLXJOINSWAPGROUPNVPROC __glewXJoinSwapGroupNV; +extern PFNGLXQUERYFRAMECOUNTNVPROC __glewXQueryFrameCountNV; +extern PFNGLXQUERYMAXSWAPGROUPSNVPROC __glewXQueryMaxSwapGroupsNV; +extern PFNGLXQUERYSWAPGROUPNVPROC __glewXQuerySwapGroupNV; +extern PFNGLXRESETFRAMECOUNTNVPROC __glewXResetFrameCountNV; + +extern PFNGLXALLOCATEMEMORYNVPROC __glewXAllocateMemoryNV; +extern PFNGLXFREEMEMORYNVPROC __glewXFreeMemoryNV; + +extern PFNGLXBINDVIDEOIMAGENVPROC __glewXBindVideoImageNV; +extern PFNGLXGETVIDEODEVICENVPROC __glewXGetVideoDeviceNV; +extern PFNGLXGETVIDEOINFONVPROC __glewXGetVideoInfoNV; +extern PFNGLXRELEASEVIDEODEVICENVPROC __glewXReleaseVideoDeviceNV; +extern PFNGLXRELEASEVIDEOIMAGENVPROC __glewXReleaseVideoImageNV; +extern PFNGLXSENDPBUFFERTOVIDEONVPROC __glewXSendPbufferToVideoNV; + +#ifdef GLX_OML_sync_control +extern PFNGLXGETMSCRATEOMLPROC __glewXGetMscRateOML; +extern PFNGLXGETSYNCVALUESOMLPROC __glewXGetSyncValuesOML; +extern PFNGLXSWAPBUFFERSMSCOMLPROC __glewXSwapBuffersMscOML; +extern PFNGLXWAITFORMSCOMLPROC __glewXWaitForMscOML; +extern PFNGLXWAITFORSBCOMLPROC __glewXWaitForSbcOML; +#endif + +extern PFNGLXCHOOSEFBCONFIGSGIXPROC __glewXChooseFBConfigSGIX; +extern PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC __glewXCreateContextWithConfigSGIX; +extern PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC __glewXCreateGLXPixmapWithConfigSGIX; +extern PFNGLXGETFBCONFIGATTRIBSGIXPROC __glewXGetFBConfigAttribSGIX; +extern PFNGLXGETFBCONFIGFROMVISUALSGIXPROC __glewXGetFBConfigFromVisualSGIX; +extern PFNGLXGETVISUALFROMFBCONFIGSGIXPROC __glewXGetVisualFromFBConfigSGIX; + +extern PFNGLXBINDHYPERPIPESGIXPROC __glewXBindHyperpipeSGIX; +extern PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC __glewXDestroyHyperpipeConfigSGIX; +extern PFNGLXHYPERPIPEATTRIBSGIXPROC __glewXHyperpipeAttribSGIX; +extern PFNGLXHYPERPIPECONFIGSGIXPROC __glewXHyperpipeConfigSGIX; +extern PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC __glewXQueryHyperpipeAttribSGIX; +extern PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC __glewXQueryHyperpipeBestAttribSGIX; +extern PFNGLXQUERYHYPERPIPECONFIGSGIXPROC __glewXQueryHyperpipeConfigSGIX; +extern PFNGLXQUERYHYPERPIPENETWORKSGIXPROC __glewXQueryHyperpipeNetworkSGIX; + +extern PFNGLXCREATEGLXPBUFFERSGIXPROC __glewXCreateGLXPbufferSGIX; +extern PFNGLXDESTROYGLXPBUFFERSGIXPROC __glewXDestroyGLXPbufferSGIX; +extern PFNGLXGETSELECTEDEVENTSGIXPROC __glewXGetSelectedEventSGIX; +extern PFNGLXQUERYGLXPBUFFERSGIXPROC __glewXQueryGLXPbufferSGIX; +extern PFNGLXSELECTEVENTSGIXPROC __glewXSelectEventSGIX; + +extern PFNGLXBINDSWAPBARRIERSGIXPROC __glewXBindSwapBarrierSGIX; +extern PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC __glewXQueryMaxSwapBarriersSGIX; + +extern PFNGLXJOINSWAPGROUPSGIXPROC __glewXJoinSwapGroupSGIX; + +extern PFNGLXBINDCHANNELTOWINDOWSGIXPROC __glewXBindChannelToWindowSGIX; +extern PFNGLXCHANNELRECTSGIXPROC __glewXChannelRectSGIX; +extern PFNGLXCHANNELRECTSYNCSGIXPROC __glewXChannelRectSyncSGIX; +extern PFNGLXQUERYCHANNELDELTASSGIXPROC __glewXQueryChannelDeltasSGIX; +extern PFNGLXQUERYCHANNELRECTSGIXPROC __glewXQueryChannelRectSGIX; + +extern PFNGLXCUSHIONSGIPROC __glewXCushionSGI; + +extern PFNGLXGETCURRENTREADDRAWABLESGIPROC __glewXGetCurrentReadDrawableSGI; +extern PFNGLXMAKECURRENTREADSGIPROC __glewXMakeCurrentReadSGI; + +extern PFNGLXSWAPINTERVALSGIPROC __glewXSwapIntervalSGI; + +extern PFNGLXGETVIDEOSYNCSGIPROC __glewXGetVideoSyncSGI; +extern PFNGLXWAITVIDEOSYNCSGIPROC __glewXWaitVideoSyncSGI; + +extern PFNGLXGETTRANSPARENTINDEXSUNPROC __glewXGetTransparentIndexSUN; + +extern PFNGLXGETVIDEORESIZESUNPROC __glewXGetVideoResizeSUN; +extern PFNGLXVIDEORESIZESUNPROC __glewXVideoResizeSUN; + +#if defined(GLEW_MX) +struct GLXEWContextStruct +{ +#endif /* GLEW_MX */ + +GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_0; +GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_1; +GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_2; +GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_3; +GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_4; +GLXEW_EXPORT GLboolean __GLXEW_3DFX_multisample; +GLXEW_EXPORT GLboolean __GLXEW_ARB_create_context; +GLXEW_EXPORT GLboolean __GLXEW_ARB_create_context_profile; +GLXEW_EXPORT GLboolean __GLXEW_ARB_fbconfig_float; +GLXEW_EXPORT GLboolean __GLXEW_ARB_framebuffer_sRGB; +GLXEW_EXPORT GLboolean __GLXEW_ARB_get_proc_address; +GLXEW_EXPORT GLboolean __GLXEW_ARB_multisample; +GLXEW_EXPORT GLboolean __GLXEW_ARB_vertex_buffer_object; +GLXEW_EXPORT GLboolean __GLXEW_ATI_pixel_format_float; +GLXEW_EXPORT GLboolean __GLXEW_ATI_render_texture; +GLXEW_EXPORT GLboolean __GLXEW_EXT_fbconfig_packed_float; +GLXEW_EXPORT GLboolean __GLXEW_EXT_framebuffer_sRGB; +GLXEW_EXPORT GLboolean __GLXEW_EXT_import_context; +GLXEW_EXPORT GLboolean __GLXEW_EXT_scene_marker; +GLXEW_EXPORT GLboolean __GLXEW_EXT_swap_control; +GLXEW_EXPORT GLboolean __GLXEW_EXT_texture_from_pixmap; +GLXEW_EXPORT GLboolean __GLXEW_EXT_visual_info; +GLXEW_EXPORT GLboolean __GLXEW_EXT_visual_rating; +GLXEW_EXPORT GLboolean __GLXEW_INTEL_swap_event; +GLXEW_EXPORT GLboolean __GLXEW_MESA_agp_offset; +GLXEW_EXPORT GLboolean __GLXEW_MESA_copy_sub_buffer; +GLXEW_EXPORT GLboolean __GLXEW_MESA_pixmap_colormap; +GLXEW_EXPORT GLboolean __GLXEW_MESA_release_buffers; +GLXEW_EXPORT GLboolean __GLXEW_MESA_set_3dfx_mode; +GLXEW_EXPORT GLboolean __GLXEW_NV_copy_image; +GLXEW_EXPORT GLboolean __GLXEW_NV_float_buffer; +GLXEW_EXPORT GLboolean __GLXEW_NV_present_video; +GLXEW_EXPORT GLboolean __GLXEW_NV_swap_group; +GLXEW_EXPORT GLboolean __GLXEW_NV_vertex_array_range; +GLXEW_EXPORT GLboolean __GLXEW_NV_video_output; +GLXEW_EXPORT GLboolean __GLXEW_OML_swap_method; +GLXEW_EXPORT GLboolean __GLXEW_OML_sync_control; +GLXEW_EXPORT GLboolean __GLXEW_SGIS_blended_overlay; +GLXEW_EXPORT GLboolean __GLXEW_SGIS_color_range; +GLXEW_EXPORT GLboolean __GLXEW_SGIS_multisample; +GLXEW_EXPORT GLboolean __GLXEW_SGIS_shared_multisample; +GLXEW_EXPORT GLboolean __GLXEW_SGIX_fbconfig; +GLXEW_EXPORT GLboolean __GLXEW_SGIX_hyperpipe; +GLXEW_EXPORT GLboolean __GLXEW_SGIX_pbuffer; +GLXEW_EXPORT GLboolean __GLXEW_SGIX_swap_barrier; +GLXEW_EXPORT GLboolean __GLXEW_SGIX_swap_group; +GLXEW_EXPORT GLboolean __GLXEW_SGIX_video_resize; +GLXEW_EXPORT GLboolean __GLXEW_SGIX_visual_select_group; +GLXEW_EXPORT GLboolean __GLXEW_SGI_cushion; +GLXEW_EXPORT GLboolean __GLXEW_SGI_make_current_read; +GLXEW_EXPORT GLboolean __GLXEW_SGI_swap_control; +GLXEW_EXPORT GLboolean __GLXEW_SGI_video_sync; +GLXEW_EXPORT GLboolean __GLXEW_SUN_get_transparent_index; +GLXEW_EXPORT GLboolean __GLXEW_SUN_video_resize; + +#ifdef GLEW_MX +}; /* GLXEWContextStruct */ +#endif /* GLEW_MX */ + +/* ------------------------------------------------------------------------ */ + +#ifdef GLEW_MX + +typedef struct GLXEWContextStruct GLXEWContext; +extern GLenum glxewContextInit (GLXEWContext* ctx); +extern GLboolean glxewContextIsSupported (GLXEWContext* ctx, const char* name); + +#define glxewInit() glxewContextInit(glxewGetContext()) +#define glxewIsSupported(x) glxewContextIsSupported(glxewGetContext(), x) + +#define GLXEW_GET_VAR(x) (*(const GLboolean*)&(glxewGetContext()->x)) +#define GLXEW_GET_FUN(x) x + +#else /* GLEW_MX */ + +#define GLXEW_GET_VAR(x) (*(const GLboolean*)&x) +#define GLXEW_GET_FUN(x) x + +extern GLboolean glxewIsSupported (const char* name); + +#endif /* GLEW_MX */ + +extern GLboolean glxewGetExtension (const char* name); + +#ifdef __cplusplus +} +#endif + +#endif /* __glxew_h__ */ diff --git a/Externals/GLew/include/GL/wglew.h b/Externals/GLew/include/GL/wglew.h new file mode 100644 index 0000000000..7c7a380479 --- /dev/null +++ b/Externals/GLew/include/GL/wglew.h @@ -0,0 +1,1247 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + +/* +** Copyright (c) 2007 The Khronos Group Inc. +** +** Permission is hereby granted, free of charge, to any person obtaining a +** copy of this software and/or associated documentation files (the +** "Materials"), to deal in the Materials without restriction, including +** without limitation the rights to use, copy, modify, merge, publish, +** distribute, sublicense, and/or sell copies of the Materials, and to +** permit persons to whom the Materials are furnished to do so, subject to +** the following conditions: +** +** The above copyright notice and this permission notice shall be included +** in all copies or substantial portions of the Materials. +** +** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. +*/ + +#ifndef __wglew_h__ +#define __wglew_h__ +#define __WGLEW_H__ + +#ifdef __wglext_h_ +#error wglext.h included before wglew.h +#endif + +#define __wglext_h_ + +#if !defined(WINAPI) +# ifndef WIN32_LEAN_AND_MEAN +# define WIN32_LEAN_AND_MEAN 1 +# endif +#include +# undef WIN32_LEAN_AND_MEAN +#endif + +/* + * GLEW_STATIC needs to be set when using the static version. + * GLEW_BUILD is set when building the DLL version. + */ +#ifdef GLEW_STATIC +# define GLEWAPI extern +#else +# ifdef GLEW_BUILD +# define GLEWAPI extern __declspec(dllexport) +# else +# define GLEWAPI extern __declspec(dllimport) +# endif +#endif + +#ifdef __cplusplus +extern "C" { +#endif + +/* -------------------------- WGL_3DFX_multisample ------------------------- */ + +#ifndef WGL_3DFX_multisample +#define WGL_3DFX_multisample 1 + +#define WGL_SAMPLE_BUFFERS_3DFX 0x2060 +#define WGL_SAMPLES_3DFX 0x2061 + +#define WGLEW_3DFX_multisample WGLEW_GET_VAR(__WGLEW_3DFX_multisample) + +#endif /* WGL_3DFX_multisample */ + +/* ------------------------- WGL_3DL_stereo_control ------------------------ */ + +#ifndef WGL_3DL_stereo_control +#define WGL_3DL_stereo_control 1 + +#define WGL_STEREO_EMITTER_ENABLE_3DL 0x2055 +#define WGL_STEREO_EMITTER_DISABLE_3DL 0x2056 +#define WGL_STEREO_POLARITY_NORMAL_3DL 0x2057 +#define WGL_STEREO_POLARITY_INVERT_3DL 0x2058 + +typedef BOOL (WINAPI * PFNWGLSETSTEREOEMITTERSTATE3DLPROC) (HDC hDC, UINT uState); + +#define wglSetStereoEmitterState3DL WGLEW_GET_FUN(__wglewSetStereoEmitterState3DL) + +#define WGLEW_3DL_stereo_control WGLEW_GET_VAR(__WGLEW_3DL_stereo_control) + +#endif /* WGL_3DL_stereo_control */ + +/* ------------------------ WGL_AMD_gpu_association ------------------------ */ + +#ifndef WGL_AMD_gpu_association +#define WGL_AMD_gpu_association 1 + +#define WGL_GPU_VENDOR_AMD 0x1F00 +#define WGL_GPU_RENDERER_STRING_AMD 0x1F01 +#define WGL_GPU_OPENGL_VERSION_STRING_AMD 0x1F02 +#define WGL_GPU_FASTEST_TARGET_GPUS_AMD 0x21A2 +#define WGL_GPU_RAM_AMD 0x21A3 +#define WGL_GPU_CLOCK_AMD 0x21A4 +#define WGL_GPU_NUM_PIPES_AMD 0x21A5 +#define WGL_GPU_NUM_SIMD_AMD 0x21A6 +#define WGL_GPU_NUM_RB_AMD 0x21A7 +#define WGL_GPU_NUM_SPI_AMD 0x21A8 + +typedef VOID (WINAPI * PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC) (HGLRC dstCtx, GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +typedef HGLRC (WINAPI * PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC) (UINT id); +typedef HGLRC (WINAPI * PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC) (UINT id, HGLRC hShareContext, const int* attribList); +typedef BOOL (WINAPI * PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC) (HGLRC hglrc); +typedef UINT (WINAPI * PFNWGLGETCONTEXTGPUIDAMDPROC) (HGLRC hglrc); +typedef HGLRC (WINAPI * PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC) (void); +typedef UINT (WINAPI * PFNWGLGETGPUIDSAMDPROC) (UINT maxCount, UINT* ids); +typedef INT (WINAPI * PFNWGLGETGPUINFOAMDPROC) (UINT id, INT property, GLenum dataType, UINT size, void* data); +typedef BOOL (WINAPI * PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC) (HGLRC hglrc); + +#define wglBlitContextFramebufferAMD WGLEW_GET_FUN(__wglewBlitContextFramebufferAMD) +#define wglCreateAssociatedContextAMD WGLEW_GET_FUN(__wglewCreateAssociatedContextAMD) +#define wglCreateAssociatedContextAttribsAMD WGLEW_GET_FUN(__wglewCreateAssociatedContextAttribsAMD) +#define wglDeleteAssociatedContextAMD WGLEW_GET_FUN(__wglewDeleteAssociatedContextAMD) +#define wglGetContextGPUIDAMD WGLEW_GET_FUN(__wglewGetContextGPUIDAMD) +#define wglGetCurrentAssociatedContextAMD WGLEW_GET_FUN(__wglewGetCurrentAssociatedContextAMD) +#define wglGetGPUIDsAMD WGLEW_GET_FUN(__wglewGetGPUIDsAMD) +#define wglGetGPUInfoAMD WGLEW_GET_FUN(__wglewGetGPUInfoAMD) +#define wglMakeAssociatedContextCurrentAMD WGLEW_GET_FUN(__wglewMakeAssociatedContextCurrentAMD) + +#define WGLEW_AMD_gpu_association WGLEW_GET_VAR(__WGLEW_AMD_gpu_association) + +#endif /* WGL_AMD_gpu_association */ + +/* ------------------------- WGL_ARB_buffer_region ------------------------- */ + +#ifndef WGL_ARB_buffer_region +#define WGL_ARB_buffer_region 1 + +#define WGL_FRONT_COLOR_BUFFER_BIT_ARB 0x00000001 +#define WGL_BACK_COLOR_BUFFER_BIT_ARB 0x00000002 +#define WGL_DEPTH_BUFFER_BIT_ARB 0x00000004 +#define WGL_STENCIL_BUFFER_BIT_ARB 0x00000008 + +typedef HANDLE (WINAPI * PFNWGLCREATEBUFFERREGIONARBPROC) (HDC hDC, int iLayerPlane, UINT uType); +typedef VOID (WINAPI * PFNWGLDELETEBUFFERREGIONARBPROC) (HANDLE hRegion); +typedef BOOL (WINAPI * PFNWGLRESTOREBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height, int xSrc, int ySrc); +typedef BOOL (WINAPI * PFNWGLSAVEBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height); + +#define wglCreateBufferRegionARB WGLEW_GET_FUN(__wglewCreateBufferRegionARB) +#define wglDeleteBufferRegionARB WGLEW_GET_FUN(__wglewDeleteBufferRegionARB) +#define wglRestoreBufferRegionARB WGLEW_GET_FUN(__wglewRestoreBufferRegionARB) +#define wglSaveBufferRegionARB WGLEW_GET_FUN(__wglewSaveBufferRegionARB) + +#define WGLEW_ARB_buffer_region WGLEW_GET_VAR(__WGLEW_ARB_buffer_region) + +#endif /* WGL_ARB_buffer_region */ + +/* ------------------------- WGL_ARB_create_context ------------------------ */ + +#ifndef WGL_ARB_create_context +#define WGL_ARB_create_context 1 + +#define WGL_CONTEXT_DEBUG_BIT_ARB 0x0001 +#define WGL_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 +#define WGL_CONTEXT_MAJOR_VERSION_ARB 0x2091 +#define WGL_CONTEXT_MINOR_VERSION_ARB 0x2092 +#define WGL_CONTEXT_LAYER_PLANE_ARB 0x2093 +#define WGL_CONTEXT_FLAGS_ARB 0x2094 + +typedef HGLRC (WINAPI * PFNWGLCREATECONTEXTATTRIBSARBPROC) (HDC hDC, HGLRC hShareContext, const int* attribList); + +#define wglCreateContextAttribsARB WGLEW_GET_FUN(__wglewCreateContextAttribsARB) + +#define WGLEW_ARB_create_context WGLEW_GET_VAR(__WGLEW_ARB_create_context) + +#endif /* WGL_ARB_create_context */ + +/* --------------------- WGL_ARB_create_context_profile -------------------- */ + +#ifndef WGL_ARB_create_context_profile +#define WGL_ARB_create_context_profile 1 + +#define WGL_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 +#define WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 +#define WGL_CONTEXT_PROFILE_MASK_ARB 0x9126 + +#define WGLEW_ARB_create_context_profile WGLEW_GET_VAR(__WGLEW_ARB_create_context_profile) + +#endif /* WGL_ARB_create_context_profile */ + +/* ----------------------- WGL_ARB_extensions_string ----------------------- */ + +#ifndef WGL_ARB_extensions_string +#define WGL_ARB_extensions_string 1 + +typedef const char* (WINAPI * PFNWGLGETEXTENSIONSSTRINGARBPROC) (HDC hdc); + +#define wglGetExtensionsStringARB WGLEW_GET_FUN(__wglewGetExtensionsStringARB) + +#define WGLEW_ARB_extensions_string WGLEW_GET_VAR(__WGLEW_ARB_extensions_string) + +#endif /* WGL_ARB_extensions_string */ + +/* ------------------------ WGL_ARB_framebuffer_sRGB ----------------------- */ + +#ifndef WGL_ARB_framebuffer_sRGB +#define WGL_ARB_framebuffer_sRGB 1 + +#define WGL_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20A9 + +#define WGLEW_ARB_framebuffer_sRGB WGLEW_GET_VAR(__WGLEW_ARB_framebuffer_sRGB) + +#endif /* WGL_ARB_framebuffer_sRGB */ + +/* ----------------------- WGL_ARB_make_current_read ----------------------- */ + +#ifndef WGL_ARB_make_current_read +#define WGL_ARB_make_current_read 1 + +#define ERROR_INVALID_PIXEL_TYPE_ARB 0x2043 +#define ERROR_INCOMPATIBLE_DEVICE_CONTEXTS_ARB 0x2054 + +typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCARBPROC) (VOID); +typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTARBPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); + +#define wglGetCurrentReadDCARB WGLEW_GET_FUN(__wglewGetCurrentReadDCARB) +#define wglMakeContextCurrentARB WGLEW_GET_FUN(__wglewMakeContextCurrentARB) + +#define WGLEW_ARB_make_current_read WGLEW_GET_VAR(__WGLEW_ARB_make_current_read) + +#endif /* WGL_ARB_make_current_read */ + +/* -------------------------- WGL_ARB_multisample -------------------------- */ + +#ifndef WGL_ARB_multisample +#define WGL_ARB_multisample 1 + +#define WGL_SAMPLE_BUFFERS_ARB 0x2041 +#define WGL_SAMPLES_ARB 0x2042 + +#define WGLEW_ARB_multisample WGLEW_GET_VAR(__WGLEW_ARB_multisample) + +#endif /* WGL_ARB_multisample */ + +/* ---------------------------- WGL_ARB_pbuffer ---------------------------- */ + +#ifndef WGL_ARB_pbuffer +#define WGL_ARB_pbuffer 1 + +#define WGL_DRAW_TO_PBUFFER_ARB 0x202D +#define WGL_MAX_PBUFFER_PIXELS_ARB 0x202E +#define WGL_MAX_PBUFFER_WIDTH_ARB 0x202F +#define WGL_MAX_PBUFFER_HEIGHT_ARB 0x2030 +#define WGL_PBUFFER_LARGEST_ARB 0x2033 +#define WGL_PBUFFER_WIDTH_ARB 0x2034 +#define WGL_PBUFFER_HEIGHT_ARB 0x2035 +#define WGL_PBUFFER_LOST_ARB 0x2036 + +DECLARE_HANDLE(HPBUFFERARB); + +typedef HPBUFFERARB (WINAPI * PFNWGLCREATEPBUFFERARBPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList); +typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFERARBPROC) (HPBUFFERARB hPbuffer); +typedef HDC (WINAPI * PFNWGLGETPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer); +typedef BOOL (WINAPI * PFNWGLQUERYPBUFFERARBPROC) (HPBUFFERARB hPbuffer, int iAttribute, int* piValue); +typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer, HDC hDC); + +#define wglCreatePbufferARB WGLEW_GET_FUN(__wglewCreatePbufferARB) +#define wglDestroyPbufferARB WGLEW_GET_FUN(__wglewDestroyPbufferARB) +#define wglGetPbufferDCARB WGLEW_GET_FUN(__wglewGetPbufferDCARB) +#define wglQueryPbufferARB WGLEW_GET_FUN(__wglewQueryPbufferARB) +#define wglReleasePbufferDCARB WGLEW_GET_FUN(__wglewReleasePbufferDCARB) + +#define WGLEW_ARB_pbuffer WGLEW_GET_VAR(__WGLEW_ARB_pbuffer) + +#endif /* WGL_ARB_pbuffer */ + +/* -------------------------- WGL_ARB_pixel_format ------------------------- */ + +#ifndef WGL_ARB_pixel_format +#define WGL_ARB_pixel_format 1 + +#define WGL_NUMBER_PIXEL_FORMATS_ARB 0x2000 +#define WGL_DRAW_TO_WINDOW_ARB 0x2001 +#define WGL_DRAW_TO_BITMAP_ARB 0x2002 +#define WGL_ACCELERATION_ARB 0x2003 +#define WGL_NEED_PALETTE_ARB 0x2004 +#define WGL_NEED_SYSTEM_PALETTE_ARB 0x2005 +#define WGL_SWAP_LAYER_BUFFERS_ARB 0x2006 +#define WGL_SWAP_METHOD_ARB 0x2007 +#define WGL_NUMBER_OVERLAYS_ARB 0x2008 +#define WGL_NUMBER_UNDERLAYS_ARB 0x2009 +#define WGL_TRANSPARENT_ARB 0x200A +#define WGL_SHARE_DEPTH_ARB 0x200C +#define WGL_SHARE_STENCIL_ARB 0x200D +#define WGL_SHARE_ACCUM_ARB 0x200E +#define WGL_SUPPORT_GDI_ARB 0x200F +#define WGL_SUPPORT_OPENGL_ARB 0x2010 +#define WGL_DOUBLE_BUFFER_ARB 0x2011 +#define WGL_STEREO_ARB 0x2012 +#define WGL_PIXEL_TYPE_ARB 0x2013 +#define WGL_COLOR_BITS_ARB 0x2014 +#define WGL_RED_BITS_ARB 0x2015 +#define WGL_RED_SHIFT_ARB 0x2016 +#define WGL_GREEN_BITS_ARB 0x2017 +#define WGL_GREEN_SHIFT_ARB 0x2018 +#define WGL_BLUE_BITS_ARB 0x2019 +#define WGL_BLUE_SHIFT_ARB 0x201A +#define WGL_ALPHA_BITS_ARB 0x201B +#define WGL_ALPHA_SHIFT_ARB 0x201C +#define WGL_ACCUM_BITS_ARB 0x201D +#define WGL_ACCUM_RED_BITS_ARB 0x201E +#define WGL_ACCUM_GREEN_BITS_ARB 0x201F +#define WGL_ACCUM_BLUE_BITS_ARB 0x2020 +#define WGL_ACCUM_ALPHA_BITS_ARB 0x2021 +#define WGL_DEPTH_BITS_ARB 0x2022 +#define WGL_STENCIL_BITS_ARB 0x2023 +#define WGL_AUX_BUFFERS_ARB 0x2024 +#define WGL_NO_ACCELERATION_ARB 0x2025 +#define WGL_GENERIC_ACCELERATION_ARB 0x2026 +#define WGL_FULL_ACCELERATION_ARB 0x2027 +#define WGL_SWAP_EXCHANGE_ARB 0x2028 +#define WGL_SWAP_COPY_ARB 0x2029 +#define WGL_SWAP_UNDEFINED_ARB 0x202A +#define WGL_TYPE_RGBA_ARB 0x202B +#define WGL_TYPE_COLORINDEX_ARB 0x202C +#define WGL_TRANSPARENT_RED_VALUE_ARB 0x2037 +#define WGL_TRANSPARENT_GREEN_VALUE_ARB 0x2038 +#define WGL_TRANSPARENT_BLUE_VALUE_ARB 0x2039 +#define WGL_TRANSPARENT_ALPHA_VALUE_ARB 0x203A +#define WGL_TRANSPARENT_INDEX_VALUE_ARB 0x203B + +typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATARBPROC) (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); +typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, FLOAT *pfValues); +typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, int *piValues); + +#define wglChoosePixelFormatARB WGLEW_GET_FUN(__wglewChoosePixelFormatARB) +#define wglGetPixelFormatAttribfvARB WGLEW_GET_FUN(__wglewGetPixelFormatAttribfvARB) +#define wglGetPixelFormatAttribivARB WGLEW_GET_FUN(__wglewGetPixelFormatAttribivARB) + +#define WGLEW_ARB_pixel_format WGLEW_GET_VAR(__WGLEW_ARB_pixel_format) + +#endif /* WGL_ARB_pixel_format */ + +/* ----------------------- WGL_ARB_pixel_format_float ---------------------- */ + +#ifndef WGL_ARB_pixel_format_float +#define WGL_ARB_pixel_format_float 1 + +#define WGL_TYPE_RGBA_FLOAT_ARB 0x21A0 + +#define WGLEW_ARB_pixel_format_float WGLEW_GET_VAR(__WGLEW_ARB_pixel_format_float) + +#endif /* WGL_ARB_pixel_format_float */ + +/* ------------------------- WGL_ARB_render_texture ------------------------ */ + +#ifndef WGL_ARB_render_texture +#define WGL_ARB_render_texture 1 + +#define WGL_BIND_TO_TEXTURE_RGB_ARB 0x2070 +#define WGL_BIND_TO_TEXTURE_RGBA_ARB 0x2071 +#define WGL_TEXTURE_FORMAT_ARB 0x2072 +#define WGL_TEXTURE_TARGET_ARB 0x2073 +#define WGL_MIPMAP_TEXTURE_ARB 0x2074 +#define WGL_TEXTURE_RGB_ARB 0x2075 +#define WGL_TEXTURE_RGBA_ARB 0x2076 +#define WGL_NO_TEXTURE_ARB 0x2077 +#define WGL_TEXTURE_CUBE_MAP_ARB 0x2078 +#define WGL_TEXTURE_1D_ARB 0x2079 +#define WGL_TEXTURE_2D_ARB 0x207A +#define WGL_MIPMAP_LEVEL_ARB 0x207B +#define WGL_CUBE_MAP_FACE_ARB 0x207C +#define WGL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x207D +#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x207E +#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x207F +#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x2080 +#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x2081 +#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x2082 +#define WGL_FRONT_LEFT_ARB 0x2083 +#define WGL_FRONT_RIGHT_ARB 0x2084 +#define WGL_BACK_LEFT_ARB 0x2085 +#define WGL_BACK_RIGHT_ARB 0x2086 +#define WGL_AUX0_ARB 0x2087 +#define WGL_AUX1_ARB 0x2088 +#define WGL_AUX2_ARB 0x2089 +#define WGL_AUX3_ARB 0x208A +#define WGL_AUX4_ARB 0x208B +#define WGL_AUX5_ARB 0x208C +#define WGL_AUX6_ARB 0x208D +#define WGL_AUX7_ARB 0x208E +#define WGL_AUX8_ARB 0x208F +#define WGL_AUX9_ARB 0x2090 + +typedef BOOL (WINAPI * PFNWGLBINDTEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); +typedef BOOL (WINAPI * PFNWGLRELEASETEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); +typedef BOOL (WINAPI * PFNWGLSETPBUFFERATTRIBARBPROC) (HPBUFFERARB hPbuffer, const int* piAttribList); + +#define wglBindTexImageARB WGLEW_GET_FUN(__wglewBindTexImageARB) +#define wglReleaseTexImageARB WGLEW_GET_FUN(__wglewReleaseTexImageARB) +#define wglSetPbufferAttribARB WGLEW_GET_FUN(__wglewSetPbufferAttribARB) + +#define WGLEW_ARB_render_texture WGLEW_GET_VAR(__WGLEW_ARB_render_texture) + +#endif /* WGL_ARB_render_texture */ + +/* ----------------------- WGL_ATI_pixel_format_float ---------------------- */ + +#ifndef WGL_ATI_pixel_format_float +#define WGL_ATI_pixel_format_float 1 + +#define WGL_TYPE_RGBA_FLOAT_ATI 0x21A0 +#define GL_RGBA_FLOAT_MODE_ATI 0x8820 +#define GL_COLOR_CLEAR_UNCLAMPED_VALUE_ATI 0x8835 + +#define WGLEW_ATI_pixel_format_float WGLEW_GET_VAR(__WGLEW_ATI_pixel_format_float) + +#endif /* WGL_ATI_pixel_format_float */ + +/* -------------------- WGL_ATI_render_texture_rectangle ------------------- */ + +#ifndef WGL_ATI_render_texture_rectangle +#define WGL_ATI_render_texture_rectangle 1 + +#define WGL_TEXTURE_RECTANGLE_ATI 0x21A5 + +#define WGLEW_ATI_render_texture_rectangle WGLEW_GET_VAR(__WGLEW_ATI_render_texture_rectangle) + +#endif /* WGL_ATI_render_texture_rectangle */ + +/* -------------------------- WGL_EXT_depth_float -------------------------- */ + +#ifndef WGL_EXT_depth_float +#define WGL_EXT_depth_float 1 + +#define WGL_DEPTH_FLOAT_EXT 0x2040 + +#define WGLEW_EXT_depth_float WGLEW_GET_VAR(__WGLEW_EXT_depth_float) + +#endif /* WGL_EXT_depth_float */ + +/* ---------------------- WGL_EXT_display_color_table ---------------------- */ + +#ifndef WGL_EXT_display_color_table +#define WGL_EXT_display_color_table 1 + +typedef GLboolean (WINAPI * PFNWGLBINDDISPLAYCOLORTABLEEXTPROC) (GLushort id); +typedef GLboolean (WINAPI * PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC) (GLushort id); +typedef void (WINAPI * PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC) (GLushort id); +typedef GLboolean (WINAPI * PFNWGLLOADDISPLAYCOLORTABLEEXTPROC) (GLushort* table, GLuint length); + +#define wglBindDisplayColorTableEXT WGLEW_GET_FUN(__wglewBindDisplayColorTableEXT) +#define wglCreateDisplayColorTableEXT WGLEW_GET_FUN(__wglewCreateDisplayColorTableEXT) +#define wglDestroyDisplayColorTableEXT WGLEW_GET_FUN(__wglewDestroyDisplayColorTableEXT) +#define wglLoadDisplayColorTableEXT WGLEW_GET_FUN(__wglewLoadDisplayColorTableEXT) + +#define WGLEW_EXT_display_color_table WGLEW_GET_VAR(__WGLEW_EXT_display_color_table) + +#endif /* WGL_EXT_display_color_table */ + +/* ----------------------- WGL_EXT_extensions_string ----------------------- */ + +#ifndef WGL_EXT_extensions_string +#define WGL_EXT_extensions_string 1 + +typedef const char* (WINAPI * PFNWGLGETEXTENSIONSSTRINGEXTPROC) (void); + +#define wglGetExtensionsStringEXT WGLEW_GET_FUN(__wglewGetExtensionsStringEXT) + +#define WGLEW_EXT_extensions_string WGLEW_GET_VAR(__WGLEW_EXT_extensions_string) + +#endif /* WGL_EXT_extensions_string */ + +/* ------------------------ WGL_EXT_framebuffer_sRGB ----------------------- */ + +#ifndef WGL_EXT_framebuffer_sRGB +#define WGL_EXT_framebuffer_sRGB 1 + +#define WGL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20A9 + +#define WGLEW_EXT_framebuffer_sRGB WGLEW_GET_VAR(__WGLEW_EXT_framebuffer_sRGB) + +#endif /* WGL_EXT_framebuffer_sRGB */ + +/* ----------------------- WGL_EXT_make_current_read ----------------------- */ + +#ifndef WGL_EXT_make_current_read +#define WGL_EXT_make_current_read 1 + +#define ERROR_INVALID_PIXEL_TYPE_EXT 0x2043 + +typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCEXTPROC) (VOID); +typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTEXTPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); + +#define wglGetCurrentReadDCEXT WGLEW_GET_FUN(__wglewGetCurrentReadDCEXT) +#define wglMakeContextCurrentEXT WGLEW_GET_FUN(__wglewMakeContextCurrentEXT) + +#define WGLEW_EXT_make_current_read WGLEW_GET_VAR(__WGLEW_EXT_make_current_read) + +#endif /* WGL_EXT_make_current_read */ + +/* -------------------------- WGL_EXT_multisample -------------------------- */ + +#ifndef WGL_EXT_multisample +#define WGL_EXT_multisample 1 + +#define WGL_SAMPLE_BUFFERS_EXT 0x2041 +#define WGL_SAMPLES_EXT 0x2042 + +#define WGLEW_EXT_multisample WGLEW_GET_VAR(__WGLEW_EXT_multisample) + +#endif /* WGL_EXT_multisample */ + +/* ---------------------------- WGL_EXT_pbuffer ---------------------------- */ + +#ifndef WGL_EXT_pbuffer +#define WGL_EXT_pbuffer 1 + +#define WGL_DRAW_TO_PBUFFER_EXT 0x202D +#define WGL_MAX_PBUFFER_PIXELS_EXT 0x202E +#define WGL_MAX_PBUFFER_WIDTH_EXT 0x202F +#define WGL_MAX_PBUFFER_HEIGHT_EXT 0x2030 +#define WGL_OPTIMAL_PBUFFER_WIDTH_EXT 0x2031 +#define WGL_OPTIMAL_PBUFFER_HEIGHT_EXT 0x2032 +#define WGL_PBUFFER_LARGEST_EXT 0x2033 +#define WGL_PBUFFER_WIDTH_EXT 0x2034 +#define WGL_PBUFFER_HEIGHT_EXT 0x2035 + +DECLARE_HANDLE(HPBUFFEREXT); + +typedef HPBUFFEREXT (WINAPI * PFNWGLCREATEPBUFFEREXTPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList); +typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer); +typedef HDC (WINAPI * PFNWGLGETPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer); +typedef BOOL (WINAPI * PFNWGLQUERYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer, int iAttribute, int* piValue); +typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer, HDC hDC); + +#define wglCreatePbufferEXT WGLEW_GET_FUN(__wglewCreatePbufferEXT) +#define wglDestroyPbufferEXT WGLEW_GET_FUN(__wglewDestroyPbufferEXT) +#define wglGetPbufferDCEXT WGLEW_GET_FUN(__wglewGetPbufferDCEXT) +#define wglQueryPbufferEXT WGLEW_GET_FUN(__wglewQueryPbufferEXT) +#define wglReleasePbufferDCEXT WGLEW_GET_FUN(__wglewReleasePbufferDCEXT) + +#define WGLEW_EXT_pbuffer WGLEW_GET_VAR(__WGLEW_EXT_pbuffer) + +#endif /* WGL_EXT_pbuffer */ + +/* -------------------------- WGL_EXT_pixel_format ------------------------- */ + +#ifndef WGL_EXT_pixel_format +#define WGL_EXT_pixel_format 1 + +#define WGL_NUMBER_PIXEL_FORMATS_EXT 0x2000 +#define WGL_DRAW_TO_WINDOW_EXT 0x2001 +#define WGL_DRAW_TO_BITMAP_EXT 0x2002 +#define WGL_ACCELERATION_EXT 0x2003 +#define WGL_NEED_PALETTE_EXT 0x2004 +#define WGL_NEED_SYSTEM_PALETTE_EXT 0x2005 +#define WGL_SWAP_LAYER_BUFFERS_EXT 0x2006 +#define WGL_SWAP_METHOD_EXT 0x2007 +#define WGL_NUMBER_OVERLAYS_EXT 0x2008 +#define WGL_NUMBER_UNDERLAYS_EXT 0x2009 +#define WGL_TRANSPARENT_EXT 0x200A +#define WGL_TRANSPARENT_VALUE_EXT 0x200B +#define WGL_SHARE_DEPTH_EXT 0x200C +#define WGL_SHARE_STENCIL_EXT 0x200D +#define WGL_SHARE_ACCUM_EXT 0x200E +#define WGL_SUPPORT_GDI_EXT 0x200F +#define WGL_SUPPORT_OPENGL_EXT 0x2010 +#define WGL_DOUBLE_BUFFER_EXT 0x2011 +#define WGL_STEREO_EXT 0x2012 +#define WGL_PIXEL_TYPE_EXT 0x2013 +#define WGL_COLOR_BITS_EXT 0x2014 +#define WGL_RED_BITS_EXT 0x2015 +#define WGL_RED_SHIFT_EXT 0x2016 +#define WGL_GREEN_BITS_EXT 0x2017 +#define WGL_GREEN_SHIFT_EXT 0x2018 +#define WGL_BLUE_BITS_EXT 0x2019 +#define WGL_BLUE_SHIFT_EXT 0x201A +#define WGL_ALPHA_BITS_EXT 0x201B +#define WGL_ALPHA_SHIFT_EXT 0x201C +#define WGL_ACCUM_BITS_EXT 0x201D +#define WGL_ACCUM_RED_BITS_EXT 0x201E +#define WGL_ACCUM_GREEN_BITS_EXT 0x201F +#define WGL_ACCUM_BLUE_BITS_EXT 0x2020 +#define WGL_ACCUM_ALPHA_BITS_EXT 0x2021 +#define WGL_DEPTH_BITS_EXT 0x2022 +#define WGL_STENCIL_BITS_EXT 0x2023 +#define WGL_AUX_BUFFERS_EXT 0x2024 +#define WGL_NO_ACCELERATION_EXT 0x2025 +#define WGL_GENERIC_ACCELERATION_EXT 0x2026 +#define WGL_FULL_ACCELERATION_EXT 0x2027 +#define WGL_SWAP_EXCHANGE_EXT 0x2028 +#define WGL_SWAP_COPY_EXT 0x2029 +#define WGL_SWAP_UNDEFINED_EXT 0x202A +#define WGL_TYPE_RGBA_EXT 0x202B +#define WGL_TYPE_COLORINDEX_EXT 0x202C + +typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATEXTPROC) (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); +typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, FLOAT *pfValues); +typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, int *piValues); + +#define wglChoosePixelFormatEXT WGLEW_GET_FUN(__wglewChoosePixelFormatEXT) +#define wglGetPixelFormatAttribfvEXT WGLEW_GET_FUN(__wglewGetPixelFormatAttribfvEXT) +#define wglGetPixelFormatAttribivEXT WGLEW_GET_FUN(__wglewGetPixelFormatAttribivEXT) + +#define WGLEW_EXT_pixel_format WGLEW_GET_VAR(__WGLEW_EXT_pixel_format) + +#endif /* WGL_EXT_pixel_format */ + +/* ------------------- WGL_EXT_pixel_format_packed_float ------------------- */ + +#ifndef WGL_EXT_pixel_format_packed_float +#define WGL_EXT_pixel_format_packed_float 1 + +#define WGL_TYPE_RGBA_UNSIGNED_FLOAT_EXT 0x20A8 + +#define WGLEW_EXT_pixel_format_packed_float WGLEW_GET_VAR(__WGLEW_EXT_pixel_format_packed_float) + +#endif /* WGL_EXT_pixel_format_packed_float */ + +/* -------------------------- WGL_EXT_swap_control ------------------------- */ + +#ifndef WGL_EXT_swap_control +#define WGL_EXT_swap_control 1 + +typedef int (WINAPI * PFNWGLGETSWAPINTERVALEXTPROC) (void); +typedef BOOL (WINAPI * PFNWGLSWAPINTERVALEXTPROC) (int interval); + +#define wglGetSwapIntervalEXT WGLEW_GET_FUN(__wglewGetSwapIntervalEXT) +#define wglSwapIntervalEXT WGLEW_GET_FUN(__wglewSwapIntervalEXT) + +#define WGLEW_EXT_swap_control WGLEW_GET_VAR(__WGLEW_EXT_swap_control) + +#endif /* WGL_EXT_swap_control */ + +/* --------------------- WGL_I3D_digital_video_control --------------------- */ + +#ifndef WGL_I3D_digital_video_control +#define WGL_I3D_digital_video_control 1 + +#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_FRAMEBUFFER_I3D 0x2050 +#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_VALUE_I3D 0x2051 +#define WGL_DIGITAL_VIDEO_CURSOR_INCLUDED_I3D 0x2052 +#define WGL_DIGITAL_VIDEO_GAMMA_CORRECTED_I3D 0x2053 + +typedef BOOL (WINAPI * PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC) (HDC hDC, int iAttribute, int* piValue); +typedef BOOL (WINAPI * PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC) (HDC hDC, int iAttribute, const int* piValue); + +#define wglGetDigitalVideoParametersI3D WGLEW_GET_FUN(__wglewGetDigitalVideoParametersI3D) +#define wglSetDigitalVideoParametersI3D WGLEW_GET_FUN(__wglewSetDigitalVideoParametersI3D) + +#define WGLEW_I3D_digital_video_control WGLEW_GET_VAR(__WGLEW_I3D_digital_video_control) + +#endif /* WGL_I3D_digital_video_control */ + +/* ----------------------------- WGL_I3D_gamma ----------------------------- */ + +#ifndef WGL_I3D_gamma +#define WGL_I3D_gamma 1 + +#define WGL_GAMMA_TABLE_SIZE_I3D 0x204E +#define WGL_GAMMA_EXCLUDE_DESKTOP_I3D 0x204F + +typedef BOOL (WINAPI * PFNWGLGETGAMMATABLEI3DPROC) (HDC hDC, int iEntries, USHORT* puRed, USHORT *puGreen, USHORT *puBlue); +typedef BOOL (WINAPI * PFNWGLGETGAMMATABLEPARAMETERSI3DPROC) (HDC hDC, int iAttribute, int* piValue); +typedef BOOL (WINAPI * PFNWGLSETGAMMATABLEI3DPROC) (HDC hDC, int iEntries, const USHORT* puRed, const USHORT *puGreen, const USHORT *puBlue); +typedef BOOL (WINAPI * PFNWGLSETGAMMATABLEPARAMETERSI3DPROC) (HDC hDC, int iAttribute, const int* piValue); + +#define wglGetGammaTableI3D WGLEW_GET_FUN(__wglewGetGammaTableI3D) +#define wglGetGammaTableParametersI3D WGLEW_GET_FUN(__wglewGetGammaTableParametersI3D) +#define wglSetGammaTableI3D WGLEW_GET_FUN(__wglewSetGammaTableI3D) +#define wglSetGammaTableParametersI3D WGLEW_GET_FUN(__wglewSetGammaTableParametersI3D) + +#define WGLEW_I3D_gamma WGLEW_GET_VAR(__WGLEW_I3D_gamma) + +#endif /* WGL_I3D_gamma */ + +/* ---------------------------- WGL_I3D_genlock ---------------------------- */ + +#ifndef WGL_I3D_genlock +#define WGL_I3D_genlock 1 + +#define WGL_GENLOCK_SOURCE_MULTIVIEW_I3D 0x2044 +#define WGL_GENLOCK_SOURCE_EXTERNAL_SYNC_I3D 0x2045 +#define WGL_GENLOCK_SOURCE_EXTERNAL_FIELD_I3D 0x2046 +#define WGL_GENLOCK_SOURCE_EXTERNAL_TTL_I3D 0x2047 +#define WGL_GENLOCK_SOURCE_DIGITAL_SYNC_I3D 0x2048 +#define WGL_GENLOCK_SOURCE_DIGITAL_FIELD_I3D 0x2049 +#define WGL_GENLOCK_SOURCE_EDGE_FALLING_I3D 0x204A +#define WGL_GENLOCK_SOURCE_EDGE_RISING_I3D 0x204B +#define WGL_GENLOCK_SOURCE_EDGE_BOTH_I3D 0x204C + +typedef BOOL (WINAPI * PFNWGLDISABLEGENLOCKI3DPROC) (HDC hDC); +typedef BOOL (WINAPI * PFNWGLENABLEGENLOCKI3DPROC) (HDC hDC); +typedef BOOL (WINAPI * PFNWGLGENLOCKSAMPLERATEI3DPROC) (HDC hDC, UINT uRate); +typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEDELAYI3DPROC) (HDC hDC, UINT uDelay); +typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEEDGEI3DPROC) (HDC hDC, UINT uEdge); +typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEI3DPROC) (HDC hDC, UINT uSource); +typedef BOOL (WINAPI * PFNWGLGETGENLOCKSAMPLERATEI3DPROC) (HDC hDC, UINT* uRate); +typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEDELAYI3DPROC) (HDC hDC, UINT* uDelay); +typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEEDGEI3DPROC) (HDC hDC, UINT* uEdge); +typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEI3DPROC) (HDC hDC, UINT* uSource); +typedef BOOL (WINAPI * PFNWGLISENABLEDGENLOCKI3DPROC) (HDC hDC, BOOL* pFlag); +typedef BOOL (WINAPI * PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC) (HDC hDC, UINT* uMaxLineDelay, UINT *uMaxPixelDelay); + +#define wglDisableGenlockI3D WGLEW_GET_FUN(__wglewDisableGenlockI3D) +#define wglEnableGenlockI3D WGLEW_GET_FUN(__wglewEnableGenlockI3D) +#define wglGenlockSampleRateI3D WGLEW_GET_FUN(__wglewGenlockSampleRateI3D) +#define wglGenlockSourceDelayI3D WGLEW_GET_FUN(__wglewGenlockSourceDelayI3D) +#define wglGenlockSourceEdgeI3D WGLEW_GET_FUN(__wglewGenlockSourceEdgeI3D) +#define wglGenlockSourceI3D WGLEW_GET_FUN(__wglewGenlockSourceI3D) +#define wglGetGenlockSampleRateI3D WGLEW_GET_FUN(__wglewGetGenlockSampleRateI3D) +#define wglGetGenlockSourceDelayI3D WGLEW_GET_FUN(__wglewGetGenlockSourceDelayI3D) +#define wglGetGenlockSourceEdgeI3D WGLEW_GET_FUN(__wglewGetGenlockSourceEdgeI3D) +#define wglGetGenlockSourceI3D WGLEW_GET_FUN(__wglewGetGenlockSourceI3D) +#define wglIsEnabledGenlockI3D WGLEW_GET_FUN(__wglewIsEnabledGenlockI3D) +#define wglQueryGenlockMaxSourceDelayI3D WGLEW_GET_FUN(__wglewQueryGenlockMaxSourceDelayI3D) + +#define WGLEW_I3D_genlock WGLEW_GET_VAR(__WGLEW_I3D_genlock) + +#endif /* WGL_I3D_genlock */ + +/* -------------------------- WGL_I3D_image_buffer ------------------------- */ + +#ifndef WGL_I3D_image_buffer +#define WGL_I3D_image_buffer 1 + +#define WGL_IMAGE_BUFFER_MIN_ACCESS_I3D 0x00000001 +#define WGL_IMAGE_BUFFER_LOCK_I3D 0x00000002 + +typedef BOOL (WINAPI * PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC) (HDC hdc, HANDLE* pEvent, LPVOID *pAddress, DWORD *pSize, UINT count); +typedef LPVOID (WINAPI * PFNWGLCREATEIMAGEBUFFERI3DPROC) (HDC hDC, DWORD dwSize, UINT uFlags); +typedef BOOL (WINAPI * PFNWGLDESTROYIMAGEBUFFERI3DPROC) (HDC hDC, LPVOID pAddress); +typedef BOOL (WINAPI * PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC) (HDC hdc, LPVOID* pAddress, UINT count); + +#define wglAssociateImageBufferEventsI3D WGLEW_GET_FUN(__wglewAssociateImageBufferEventsI3D) +#define wglCreateImageBufferI3D WGLEW_GET_FUN(__wglewCreateImageBufferI3D) +#define wglDestroyImageBufferI3D WGLEW_GET_FUN(__wglewDestroyImageBufferI3D) +#define wglReleaseImageBufferEventsI3D WGLEW_GET_FUN(__wglewReleaseImageBufferEventsI3D) + +#define WGLEW_I3D_image_buffer WGLEW_GET_VAR(__WGLEW_I3D_image_buffer) + +#endif /* WGL_I3D_image_buffer */ + +/* ------------------------ WGL_I3D_swap_frame_lock ------------------------ */ + +#ifndef WGL_I3D_swap_frame_lock +#define WGL_I3D_swap_frame_lock 1 + +typedef BOOL (WINAPI * PFNWGLDISABLEFRAMELOCKI3DPROC) (VOID); +typedef BOOL (WINAPI * PFNWGLENABLEFRAMELOCKI3DPROC) (VOID); +typedef BOOL (WINAPI * PFNWGLISENABLEDFRAMELOCKI3DPROC) (BOOL* pFlag); +typedef BOOL (WINAPI * PFNWGLQUERYFRAMELOCKMASTERI3DPROC) (BOOL* pFlag); + +#define wglDisableFrameLockI3D WGLEW_GET_FUN(__wglewDisableFrameLockI3D) +#define wglEnableFrameLockI3D WGLEW_GET_FUN(__wglewEnableFrameLockI3D) +#define wglIsEnabledFrameLockI3D WGLEW_GET_FUN(__wglewIsEnabledFrameLockI3D) +#define wglQueryFrameLockMasterI3D WGLEW_GET_FUN(__wglewQueryFrameLockMasterI3D) + +#define WGLEW_I3D_swap_frame_lock WGLEW_GET_VAR(__WGLEW_I3D_swap_frame_lock) + +#endif /* WGL_I3D_swap_frame_lock */ + +/* ------------------------ WGL_I3D_swap_frame_usage ----------------------- */ + +#ifndef WGL_I3D_swap_frame_usage +#define WGL_I3D_swap_frame_usage 1 + +typedef BOOL (WINAPI * PFNWGLBEGINFRAMETRACKINGI3DPROC) (void); +typedef BOOL (WINAPI * PFNWGLENDFRAMETRACKINGI3DPROC) (void); +typedef BOOL (WINAPI * PFNWGLGETFRAMEUSAGEI3DPROC) (float* pUsage); +typedef BOOL (WINAPI * PFNWGLQUERYFRAMETRACKINGI3DPROC) (DWORD* pFrameCount, DWORD *pMissedFrames, float *pLastMissedUsage); + +#define wglBeginFrameTrackingI3D WGLEW_GET_FUN(__wglewBeginFrameTrackingI3D) +#define wglEndFrameTrackingI3D WGLEW_GET_FUN(__wglewEndFrameTrackingI3D) +#define wglGetFrameUsageI3D WGLEW_GET_FUN(__wglewGetFrameUsageI3D) +#define wglQueryFrameTrackingI3D WGLEW_GET_FUN(__wglewQueryFrameTrackingI3D) + +#define WGLEW_I3D_swap_frame_usage WGLEW_GET_VAR(__WGLEW_I3D_swap_frame_usage) + +#endif /* WGL_I3D_swap_frame_usage */ + +/* --------------------------- WGL_NV_copy_image --------------------------- */ + +#ifndef WGL_NV_copy_image +#define WGL_NV_copy_image 1 + +typedef BOOL (WINAPI * PFNWGLCOPYIMAGESUBDATANVPROC) (HGLRC hSrcRC, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, HGLRC hDstRC, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); + +#define wglCopyImageSubDataNV WGLEW_GET_FUN(__wglewCopyImageSubDataNV) + +#define WGLEW_NV_copy_image WGLEW_GET_VAR(__WGLEW_NV_copy_image) + +#endif /* WGL_NV_copy_image */ + +/* -------------------------- WGL_NV_float_buffer -------------------------- */ + +#ifndef WGL_NV_float_buffer +#define WGL_NV_float_buffer 1 + +#define WGL_FLOAT_COMPONENTS_NV 0x20B0 +#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_R_NV 0x20B1 +#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RG_NV 0x20B2 +#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGB_NV 0x20B3 +#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGBA_NV 0x20B4 +#define WGL_TEXTURE_FLOAT_R_NV 0x20B5 +#define WGL_TEXTURE_FLOAT_RG_NV 0x20B6 +#define WGL_TEXTURE_FLOAT_RGB_NV 0x20B7 +#define WGL_TEXTURE_FLOAT_RGBA_NV 0x20B8 + +#define WGLEW_NV_float_buffer WGLEW_GET_VAR(__WGLEW_NV_float_buffer) + +#endif /* WGL_NV_float_buffer */ + +/* -------------------------- WGL_NV_gpu_affinity -------------------------- */ + +#ifndef WGL_NV_gpu_affinity +#define WGL_NV_gpu_affinity 1 + +#define WGL_ERROR_INCOMPATIBLE_AFFINITY_MASKS_NV 0x20D0 +#define WGL_ERROR_MISSING_AFFINITY_MASK_NV 0x20D1 + +DECLARE_HANDLE(HGPUNV); +typedef struct _GPU_DEVICE { + DWORD cb; + CHAR DeviceName[32]; + CHAR DeviceString[128]; + DWORD Flags; + RECT rcVirtualScreen; +} GPU_DEVICE, *PGPU_DEVICE; + +typedef HDC (WINAPI * PFNWGLCREATEAFFINITYDCNVPROC) (const HGPUNV *phGpuList); +typedef BOOL (WINAPI * PFNWGLDELETEDCNVPROC) (HDC hdc); +typedef BOOL (WINAPI * PFNWGLENUMGPUDEVICESNVPROC) (HGPUNV hGpu, UINT iDeviceIndex, PGPU_DEVICE lpGpuDevice); +typedef BOOL (WINAPI * PFNWGLENUMGPUSFROMAFFINITYDCNVPROC) (HDC hAffinityDC, UINT iGpuIndex, HGPUNV *hGpu); +typedef BOOL (WINAPI * PFNWGLENUMGPUSNVPROC) (UINT iGpuIndex, HGPUNV *phGpu); + +#define wglCreateAffinityDCNV WGLEW_GET_FUN(__wglewCreateAffinityDCNV) +#define wglDeleteDCNV WGLEW_GET_FUN(__wglewDeleteDCNV) +#define wglEnumGpuDevicesNV WGLEW_GET_FUN(__wglewEnumGpuDevicesNV) +#define wglEnumGpusFromAffinityDCNV WGLEW_GET_FUN(__wglewEnumGpusFromAffinityDCNV) +#define wglEnumGpusNV WGLEW_GET_FUN(__wglewEnumGpusNV) + +#define WGLEW_NV_gpu_affinity WGLEW_GET_VAR(__WGLEW_NV_gpu_affinity) + +#endif /* WGL_NV_gpu_affinity */ + +/* -------------------------- WGL_NV_present_video ------------------------- */ + +#ifndef WGL_NV_present_video +#define WGL_NV_present_video 1 + +#define WGL_NUM_VIDEO_SLOTS_NV 0x20F0 + +DECLARE_HANDLE(HVIDEOOUTPUTDEVICENV); + +typedef BOOL (WINAPI * PFNWGLBINDVIDEODEVICENVPROC) (HDC hDc, unsigned int uVideoSlot, HVIDEOOUTPUTDEVICENV hVideoDevice, const int* piAttribList); +typedef int (WINAPI * PFNWGLENUMERATEVIDEODEVICESNVPROC) (HDC hDc, HVIDEOOUTPUTDEVICENV* phDeviceList); +typedef BOOL (WINAPI * PFNWGLQUERYCURRENTCONTEXTNVPROC) (int iAttribute, int* piValue); + +#define wglBindVideoDeviceNV WGLEW_GET_FUN(__wglewBindVideoDeviceNV) +#define wglEnumerateVideoDevicesNV WGLEW_GET_FUN(__wglewEnumerateVideoDevicesNV) +#define wglQueryCurrentContextNV WGLEW_GET_FUN(__wglewQueryCurrentContextNV) + +#define WGLEW_NV_present_video WGLEW_GET_VAR(__WGLEW_NV_present_video) + +#endif /* WGL_NV_present_video */ + +/* ---------------------- WGL_NV_render_depth_texture ---------------------- */ + +#ifndef WGL_NV_render_depth_texture +#define WGL_NV_render_depth_texture 1 + +#define WGL_NO_TEXTURE_ARB 0x2077 +#define WGL_BIND_TO_TEXTURE_DEPTH_NV 0x20A3 +#define WGL_BIND_TO_TEXTURE_RECTANGLE_DEPTH_NV 0x20A4 +#define WGL_DEPTH_TEXTURE_FORMAT_NV 0x20A5 +#define WGL_TEXTURE_DEPTH_COMPONENT_NV 0x20A6 +#define WGL_DEPTH_COMPONENT_NV 0x20A7 + +#define WGLEW_NV_render_depth_texture WGLEW_GET_VAR(__WGLEW_NV_render_depth_texture) + +#endif /* WGL_NV_render_depth_texture */ + +/* -------------------- WGL_NV_render_texture_rectangle -------------------- */ + +#ifndef WGL_NV_render_texture_rectangle +#define WGL_NV_render_texture_rectangle 1 + +#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGB_NV 0x20A0 +#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGBA_NV 0x20A1 +#define WGL_TEXTURE_RECTANGLE_NV 0x20A2 + +#define WGLEW_NV_render_texture_rectangle WGLEW_GET_VAR(__WGLEW_NV_render_texture_rectangle) + +#endif /* WGL_NV_render_texture_rectangle */ + +/* --------------------------- WGL_NV_swap_group --------------------------- */ + +#ifndef WGL_NV_swap_group +#define WGL_NV_swap_group 1 + +typedef BOOL (WINAPI * PFNWGLBINDSWAPBARRIERNVPROC) (GLuint group, GLuint barrier); +typedef BOOL (WINAPI * PFNWGLJOINSWAPGROUPNVPROC) (HDC hDC, GLuint group); +typedef BOOL (WINAPI * PFNWGLQUERYFRAMECOUNTNVPROC) (HDC hDC, GLuint* count); +typedef BOOL (WINAPI * PFNWGLQUERYMAXSWAPGROUPSNVPROC) (HDC hDC, GLuint* maxGroups, GLuint *maxBarriers); +typedef BOOL (WINAPI * PFNWGLQUERYSWAPGROUPNVPROC) (HDC hDC, GLuint* group, GLuint *barrier); +typedef BOOL (WINAPI * PFNWGLRESETFRAMECOUNTNVPROC) (HDC hDC); + +#define wglBindSwapBarrierNV WGLEW_GET_FUN(__wglewBindSwapBarrierNV) +#define wglJoinSwapGroupNV WGLEW_GET_FUN(__wglewJoinSwapGroupNV) +#define wglQueryFrameCountNV WGLEW_GET_FUN(__wglewQueryFrameCountNV) +#define wglQueryMaxSwapGroupsNV WGLEW_GET_FUN(__wglewQueryMaxSwapGroupsNV) +#define wglQuerySwapGroupNV WGLEW_GET_FUN(__wglewQuerySwapGroupNV) +#define wglResetFrameCountNV WGLEW_GET_FUN(__wglewResetFrameCountNV) + +#define WGLEW_NV_swap_group WGLEW_GET_VAR(__WGLEW_NV_swap_group) + +#endif /* WGL_NV_swap_group */ + +/* ----------------------- WGL_NV_vertex_array_range ----------------------- */ + +#ifndef WGL_NV_vertex_array_range +#define WGL_NV_vertex_array_range 1 + +typedef void * (WINAPI * PFNWGLALLOCATEMEMORYNVPROC) (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority); +typedef void (WINAPI * PFNWGLFREEMEMORYNVPROC) (void *pointer); + +#define wglAllocateMemoryNV WGLEW_GET_FUN(__wglewAllocateMemoryNV) +#define wglFreeMemoryNV WGLEW_GET_FUN(__wglewFreeMemoryNV) + +#define WGLEW_NV_vertex_array_range WGLEW_GET_VAR(__WGLEW_NV_vertex_array_range) + +#endif /* WGL_NV_vertex_array_range */ + +/* -------------------------- WGL_NV_video_output -------------------------- */ + +#ifndef WGL_NV_video_output +#define WGL_NV_video_output 1 + +#define WGL_BIND_TO_VIDEO_RGB_NV 0x20C0 +#define WGL_BIND_TO_VIDEO_RGBA_NV 0x20C1 +#define WGL_BIND_TO_VIDEO_RGB_AND_DEPTH_NV 0x20C2 +#define WGL_VIDEO_OUT_COLOR_NV 0x20C3 +#define WGL_VIDEO_OUT_ALPHA_NV 0x20C4 +#define WGL_VIDEO_OUT_DEPTH_NV 0x20C5 +#define WGL_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 +#define WGL_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 +#define WGL_VIDEO_OUT_FRAME 0x20C8 +#define WGL_VIDEO_OUT_FIELD_1 0x20C9 +#define WGL_VIDEO_OUT_FIELD_2 0x20CA +#define WGL_VIDEO_OUT_STACKED_FIELDS_1_2 0x20CB +#define WGL_VIDEO_OUT_STACKED_FIELDS_2_1 0x20CC + +DECLARE_HANDLE(HPVIDEODEV); + +typedef BOOL (WINAPI * PFNWGLBINDVIDEOIMAGENVPROC) (HPVIDEODEV hVideoDevice, HPBUFFERARB hPbuffer, int iVideoBuffer); +typedef BOOL (WINAPI * PFNWGLGETVIDEODEVICENVPROC) (HDC hDC, int numDevices, HPVIDEODEV* hVideoDevice); +typedef BOOL (WINAPI * PFNWGLGETVIDEOINFONVPROC) (HPVIDEODEV hpVideoDevice, unsigned long* pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo); +typedef BOOL (WINAPI * PFNWGLRELEASEVIDEODEVICENVPROC) (HPVIDEODEV hVideoDevice); +typedef BOOL (WINAPI * PFNWGLRELEASEVIDEOIMAGENVPROC) (HPBUFFERARB hPbuffer, int iVideoBuffer); +typedef BOOL (WINAPI * PFNWGLSENDPBUFFERTOVIDEONVPROC) (HPBUFFERARB hPbuffer, int iBufferType, unsigned long* pulCounterPbuffer, BOOL bBlock); + +#define wglBindVideoImageNV WGLEW_GET_FUN(__wglewBindVideoImageNV) +#define wglGetVideoDeviceNV WGLEW_GET_FUN(__wglewGetVideoDeviceNV) +#define wglGetVideoInfoNV WGLEW_GET_FUN(__wglewGetVideoInfoNV) +#define wglReleaseVideoDeviceNV WGLEW_GET_FUN(__wglewReleaseVideoDeviceNV) +#define wglReleaseVideoImageNV WGLEW_GET_FUN(__wglewReleaseVideoImageNV) +#define wglSendPbufferToVideoNV WGLEW_GET_FUN(__wglewSendPbufferToVideoNV) + +#define WGLEW_NV_video_output WGLEW_GET_VAR(__WGLEW_NV_video_output) + +#endif /* WGL_NV_video_output */ + +/* -------------------------- WGL_OML_sync_control ------------------------- */ + +#ifndef WGL_OML_sync_control +#define WGL_OML_sync_control 1 + +typedef BOOL (WINAPI * PFNWGLGETMSCRATEOMLPROC) (HDC hdc, INT32* numerator, INT32 *denominator); +typedef BOOL (WINAPI * PFNWGLGETSYNCVALUESOMLPROC) (HDC hdc, INT64* ust, INT64 *msc, INT64 *sbc); +typedef INT64 (WINAPI * PFNWGLSWAPBUFFERSMSCOMLPROC) (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder); +typedef INT64 (WINAPI * PFNWGLSWAPLAYERBUFFERSMSCOMLPROC) (HDC hdc, INT fuPlanes, INT64 target_msc, INT64 divisor, INT64 remainder); +typedef BOOL (WINAPI * PFNWGLWAITFORMSCOMLPROC) (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder, INT64* ust, INT64 *msc, INT64 *sbc); +typedef BOOL (WINAPI * PFNWGLWAITFORSBCOMLPROC) (HDC hdc, INT64 target_sbc, INT64* ust, INT64 *msc, INT64 *sbc); + +#define wglGetMscRateOML WGLEW_GET_FUN(__wglewGetMscRateOML) +#define wglGetSyncValuesOML WGLEW_GET_FUN(__wglewGetSyncValuesOML) +#define wglSwapBuffersMscOML WGLEW_GET_FUN(__wglewSwapBuffersMscOML) +#define wglSwapLayerBuffersMscOML WGLEW_GET_FUN(__wglewSwapLayerBuffersMscOML) +#define wglWaitForMscOML WGLEW_GET_FUN(__wglewWaitForMscOML) +#define wglWaitForSbcOML WGLEW_GET_FUN(__wglewWaitForSbcOML) + +#define WGLEW_OML_sync_control WGLEW_GET_VAR(__WGLEW_OML_sync_control) + +#endif /* WGL_OML_sync_control */ + +/* ------------------------------------------------------------------------- */ + +#ifdef GLEW_MX +#define WGLEW_EXPORT +#else +#define WGLEW_EXPORT GLEWAPI +#endif /* GLEW_MX */ + +#ifdef GLEW_MX +struct WGLEWContextStruct +{ +#endif /* GLEW_MX */ + +WGLEW_EXPORT PFNWGLSETSTEREOEMITTERSTATE3DLPROC __wglewSetStereoEmitterState3DL; + +WGLEW_EXPORT PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC __wglewBlitContextFramebufferAMD; +WGLEW_EXPORT PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC __wglewCreateAssociatedContextAMD; +WGLEW_EXPORT PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC __wglewCreateAssociatedContextAttribsAMD; +WGLEW_EXPORT PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC __wglewDeleteAssociatedContextAMD; +WGLEW_EXPORT PFNWGLGETCONTEXTGPUIDAMDPROC __wglewGetContextGPUIDAMD; +WGLEW_EXPORT PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC __wglewGetCurrentAssociatedContextAMD; +WGLEW_EXPORT PFNWGLGETGPUIDSAMDPROC __wglewGetGPUIDsAMD; +WGLEW_EXPORT PFNWGLGETGPUINFOAMDPROC __wglewGetGPUInfoAMD; +WGLEW_EXPORT PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC __wglewMakeAssociatedContextCurrentAMD; + +WGLEW_EXPORT PFNWGLCREATEBUFFERREGIONARBPROC __wglewCreateBufferRegionARB; +WGLEW_EXPORT PFNWGLDELETEBUFFERREGIONARBPROC __wglewDeleteBufferRegionARB; +WGLEW_EXPORT PFNWGLRESTOREBUFFERREGIONARBPROC __wglewRestoreBufferRegionARB; +WGLEW_EXPORT PFNWGLSAVEBUFFERREGIONARBPROC __wglewSaveBufferRegionARB; + +WGLEW_EXPORT PFNWGLCREATECONTEXTATTRIBSARBPROC __wglewCreateContextAttribsARB; + +WGLEW_EXPORT PFNWGLGETEXTENSIONSSTRINGARBPROC __wglewGetExtensionsStringARB; + +WGLEW_EXPORT PFNWGLGETCURRENTREADDCARBPROC __wglewGetCurrentReadDCARB; +WGLEW_EXPORT PFNWGLMAKECONTEXTCURRENTARBPROC __wglewMakeContextCurrentARB; + +WGLEW_EXPORT PFNWGLCREATEPBUFFERARBPROC __wglewCreatePbufferARB; +WGLEW_EXPORT PFNWGLDESTROYPBUFFERARBPROC __wglewDestroyPbufferARB; +WGLEW_EXPORT PFNWGLGETPBUFFERDCARBPROC __wglewGetPbufferDCARB; +WGLEW_EXPORT PFNWGLQUERYPBUFFERARBPROC __wglewQueryPbufferARB; +WGLEW_EXPORT PFNWGLRELEASEPBUFFERDCARBPROC __wglewReleasePbufferDCARB; + +WGLEW_EXPORT PFNWGLCHOOSEPIXELFORMATARBPROC __wglewChoosePixelFormatARB; +WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBFVARBPROC __wglewGetPixelFormatAttribfvARB; +WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBIVARBPROC __wglewGetPixelFormatAttribivARB; + +WGLEW_EXPORT PFNWGLBINDTEXIMAGEARBPROC __wglewBindTexImageARB; +WGLEW_EXPORT PFNWGLRELEASETEXIMAGEARBPROC __wglewReleaseTexImageARB; +WGLEW_EXPORT PFNWGLSETPBUFFERATTRIBARBPROC __wglewSetPbufferAttribARB; + +WGLEW_EXPORT PFNWGLBINDDISPLAYCOLORTABLEEXTPROC __wglewBindDisplayColorTableEXT; +WGLEW_EXPORT PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC __wglewCreateDisplayColorTableEXT; +WGLEW_EXPORT PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC __wglewDestroyDisplayColorTableEXT; +WGLEW_EXPORT PFNWGLLOADDISPLAYCOLORTABLEEXTPROC __wglewLoadDisplayColorTableEXT; + +WGLEW_EXPORT PFNWGLGETEXTENSIONSSTRINGEXTPROC __wglewGetExtensionsStringEXT; + +WGLEW_EXPORT PFNWGLGETCURRENTREADDCEXTPROC __wglewGetCurrentReadDCEXT; +WGLEW_EXPORT PFNWGLMAKECONTEXTCURRENTEXTPROC __wglewMakeContextCurrentEXT; + +WGLEW_EXPORT PFNWGLCREATEPBUFFEREXTPROC __wglewCreatePbufferEXT; +WGLEW_EXPORT PFNWGLDESTROYPBUFFEREXTPROC __wglewDestroyPbufferEXT; +WGLEW_EXPORT PFNWGLGETPBUFFERDCEXTPROC __wglewGetPbufferDCEXT; +WGLEW_EXPORT PFNWGLQUERYPBUFFEREXTPROC __wglewQueryPbufferEXT; +WGLEW_EXPORT PFNWGLRELEASEPBUFFERDCEXTPROC __wglewReleasePbufferDCEXT; + +WGLEW_EXPORT PFNWGLCHOOSEPIXELFORMATEXTPROC __wglewChoosePixelFormatEXT; +WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBFVEXTPROC __wglewGetPixelFormatAttribfvEXT; +WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBIVEXTPROC __wglewGetPixelFormatAttribivEXT; + +WGLEW_EXPORT PFNWGLGETSWAPINTERVALEXTPROC __wglewGetSwapIntervalEXT; +WGLEW_EXPORT PFNWGLSWAPINTERVALEXTPROC __wglewSwapIntervalEXT; + +WGLEW_EXPORT PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC __wglewGetDigitalVideoParametersI3D; +WGLEW_EXPORT PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC __wglewSetDigitalVideoParametersI3D; + +WGLEW_EXPORT PFNWGLGETGAMMATABLEI3DPROC __wglewGetGammaTableI3D; +WGLEW_EXPORT PFNWGLGETGAMMATABLEPARAMETERSI3DPROC __wglewGetGammaTableParametersI3D; +WGLEW_EXPORT PFNWGLSETGAMMATABLEI3DPROC __wglewSetGammaTableI3D; +WGLEW_EXPORT PFNWGLSETGAMMATABLEPARAMETERSI3DPROC __wglewSetGammaTableParametersI3D; + +WGLEW_EXPORT PFNWGLDISABLEGENLOCKI3DPROC __wglewDisableGenlockI3D; +WGLEW_EXPORT PFNWGLENABLEGENLOCKI3DPROC __wglewEnableGenlockI3D; +WGLEW_EXPORT PFNWGLGENLOCKSAMPLERATEI3DPROC __wglewGenlockSampleRateI3D; +WGLEW_EXPORT PFNWGLGENLOCKSOURCEDELAYI3DPROC __wglewGenlockSourceDelayI3D; +WGLEW_EXPORT PFNWGLGENLOCKSOURCEEDGEI3DPROC __wglewGenlockSourceEdgeI3D; +WGLEW_EXPORT PFNWGLGENLOCKSOURCEI3DPROC __wglewGenlockSourceI3D; +WGLEW_EXPORT PFNWGLGETGENLOCKSAMPLERATEI3DPROC __wglewGetGenlockSampleRateI3D; +WGLEW_EXPORT PFNWGLGETGENLOCKSOURCEDELAYI3DPROC __wglewGetGenlockSourceDelayI3D; +WGLEW_EXPORT PFNWGLGETGENLOCKSOURCEEDGEI3DPROC __wglewGetGenlockSourceEdgeI3D; +WGLEW_EXPORT PFNWGLGETGENLOCKSOURCEI3DPROC __wglewGetGenlockSourceI3D; +WGLEW_EXPORT PFNWGLISENABLEDGENLOCKI3DPROC __wglewIsEnabledGenlockI3D; +WGLEW_EXPORT PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC __wglewQueryGenlockMaxSourceDelayI3D; + +WGLEW_EXPORT PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC __wglewAssociateImageBufferEventsI3D; +WGLEW_EXPORT PFNWGLCREATEIMAGEBUFFERI3DPROC __wglewCreateImageBufferI3D; +WGLEW_EXPORT PFNWGLDESTROYIMAGEBUFFERI3DPROC __wglewDestroyImageBufferI3D; +WGLEW_EXPORT PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC __wglewReleaseImageBufferEventsI3D; + +WGLEW_EXPORT PFNWGLDISABLEFRAMELOCKI3DPROC __wglewDisableFrameLockI3D; +WGLEW_EXPORT PFNWGLENABLEFRAMELOCKI3DPROC __wglewEnableFrameLockI3D; +WGLEW_EXPORT PFNWGLISENABLEDFRAMELOCKI3DPROC __wglewIsEnabledFrameLockI3D; +WGLEW_EXPORT PFNWGLQUERYFRAMELOCKMASTERI3DPROC __wglewQueryFrameLockMasterI3D; + +WGLEW_EXPORT PFNWGLBEGINFRAMETRACKINGI3DPROC __wglewBeginFrameTrackingI3D; +WGLEW_EXPORT PFNWGLENDFRAMETRACKINGI3DPROC __wglewEndFrameTrackingI3D; +WGLEW_EXPORT PFNWGLGETFRAMEUSAGEI3DPROC __wglewGetFrameUsageI3D; +WGLEW_EXPORT PFNWGLQUERYFRAMETRACKINGI3DPROC __wglewQueryFrameTrackingI3D; + +WGLEW_EXPORT PFNWGLCOPYIMAGESUBDATANVPROC __wglewCopyImageSubDataNV; + +WGLEW_EXPORT PFNWGLCREATEAFFINITYDCNVPROC __wglewCreateAffinityDCNV; +WGLEW_EXPORT PFNWGLDELETEDCNVPROC __wglewDeleteDCNV; +WGLEW_EXPORT PFNWGLENUMGPUDEVICESNVPROC __wglewEnumGpuDevicesNV; +WGLEW_EXPORT PFNWGLENUMGPUSFROMAFFINITYDCNVPROC __wglewEnumGpusFromAffinityDCNV; +WGLEW_EXPORT PFNWGLENUMGPUSNVPROC __wglewEnumGpusNV; + +WGLEW_EXPORT PFNWGLBINDVIDEODEVICENVPROC __wglewBindVideoDeviceNV; +WGLEW_EXPORT PFNWGLENUMERATEVIDEODEVICESNVPROC __wglewEnumerateVideoDevicesNV; +WGLEW_EXPORT PFNWGLQUERYCURRENTCONTEXTNVPROC __wglewQueryCurrentContextNV; + +WGLEW_EXPORT PFNWGLBINDSWAPBARRIERNVPROC __wglewBindSwapBarrierNV; +WGLEW_EXPORT PFNWGLJOINSWAPGROUPNVPROC __wglewJoinSwapGroupNV; +WGLEW_EXPORT PFNWGLQUERYFRAMECOUNTNVPROC __wglewQueryFrameCountNV; +WGLEW_EXPORT PFNWGLQUERYMAXSWAPGROUPSNVPROC __wglewQueryMaxSwapGroupsNV; +WGLEW_EXPORT PFNWGLQUERYSWAPGROUPNVPROC __wglewQuerySwapGroupNV; +WGLEW_EXPORT PFNWGLRESETFRAMECOUNTNVPROC __wglewResetFrameCountNV; + +WGLEW_EXPORT PFNWGLALLOCATEMEMORYNVPROC __wglewAllocateMemoryNV; +WGLEW_EXPORT PFNWGLFREEMEMORYNVPROC __wglewFreeMemoryNV; + +WGLEW_EXPORT PFNWGLBINDVIDEOIMAGENVPROC __wglewBindVideoImageNV; +WGLEW_EXPORT PFNWGLGETVIDEODEVICENVPROC __wglewGetVideoDeviceNV; +WGLEW_EXPORT PFNWGLGETVIDEOINFONVPROC __wglewGetVideoInfoNV; +WGLEW_EXPORT PFNWGLRELEASEVIDEODEVICENVPROC __wglewReleaseVideoDeviceNV; +WGLEW_EXPORT PFNWGLRELEASEVIDEOIMAGENVPROC __wglewReleaseVideoImageNV; +WGLEW_EXPORT PFNWGLSENDPBUFFERTOVIDEONVPROC __wglewSendPbufferToVideoNV; + +WGLEW_EXPORT PFNWGLGETMSCRATEOMLPROC __wglewGetMscRateOML; +WGLEW_EXPORT PFNWGLGETSYNCVALUESOMLPROC __wglewGetSyncValuesOML; +WGLEW_EXPORT PFNWGLSWAPBUFFERSMSCOMLPROC __wglewSwapBuffersMscOML; +WGLEW_EXPORT PFNWGLSWAPLAYERBUFFERSMSCOMLPROC __wglewSwapLayerBuffersMscOML; +WGLEW_EXPORT PFNWGLWAITFORMSCOMLPROC __wglewWaitForMscOML; +WGLEW_EXPORT PFNWGLWAITFORSBCOMLPROC __wglewWaitForSbcOML; +WGLEW_EXPORT GLboolean __WGLEW_3DFX_multisample; +WGLEW_EXPORT GLboolean __WGLEW_3DL_stereo_control; +WGLEW_EXPORT GLboolean __WGLEW_AMD_gpu_association; +WGLEW_EXPORT GLboolean __WGLEW_ARB_buffer_region; +WGLEW_EXPORT GLboolean __WGLEW_ARB_create_context; +WGLEW_EXPORT GLboolean __WGLEW_ARB_create_context_profile; +WGLEW_EXPORT GLboolean __WGLEW_ARB_extensions_string; +WGLEW_EXPORT GLboolean __WGLEW_ARB_framebuffer_sRGB; +WGLEW_EXPORT GLboolean __WGLEW_ARB_make_current_read; +WGLEW_EXPORT GLboolean __WGLEW_ARB_multisample; +WGLEW_EXPORT GLboolean __WGLEW_ARB_pbuffer; +WGLEW_EXPORT GLboolean __WGLEW_ARB_pixel_format; +WGLEW_EXPORT GLboolean __WGLEW_ARB_pixel_format_float; +WGLEW_EXPORT GLboolean __WGLEW_ARB_render_texture; +WGLEW_EXPORT GLboolean __WGLEW_ATI_pixel_format_float; +WGLEW_EXPORT GLboolean __WGLEW_ATI_render_texture_rectangle; +WGLEW_EXPORT GLboolean __WGLEW_EXT_depth_float; +WGLEW_EXPORT GLboolean __WGLEW_EXT_display_color_table; +WGLEW_EXPORT GLboolean __WGLEW_EXT_extensions_string; +WGLEW_EXPORT GLboolean __WGLEW_EXT_framebuffer_sRGB; +WGLEW_EXPORT GLboolean __WGLEW_EXT_make_current_read; +WGLEW_EXPORT GLboolean __WGLEW_EXT_multisample; +WGLEW_EXPORT GLboolean __WGLEW_EXT_pbuffer; +WGLEW_EXPORT GLboolean __WGLEW_EXT_pixel_format; +WGLEW_EXPORT GLboolean __WGLEW_EXT_pixel_format_packed_float; +WGLEW_EXPORT GLboolean __WGLEW_EXT_swap_control; +WGLEW_EXPORT GLboolean __WGLEW_I3D_digital_video_control; +WGLEW_EXPORT GLboolean __WGLEW_I3D_gamma; +WGLEW_EXPORT GLboolean __WGLEW_I3D_genlock; +WGLEW_EXPORT GLboolean __WGLEW_I3D_image_buffer; +WGLEW_EXPORT GLboolean __WGLEW_I3D_swap_frame_lock; +WGLEW_EXPORT GLboolean __WGLEW_I3D_swap_frame_usage; +WGLEW_EXPORT GLboolean __WGLEW_NV_copy_image; +WGLEW_EXPORT GLboolean __WGLEW_NV_float_buffer; +WGLEW_EXPORT GLboolean __WGLEW_NV_gpu_affinity; +WGLEW_EXPORT GLboolean __WGLEW_NV_present_video; +WGLEW_EXPORT GLboolean __WGLEW_NV_render_depth_texture; +WGLEW_EXPORT GLboolean __WGLEW_NV_render_texture_rectangle; +WGLEW_EXPORT GLboolean __WGLEW_NV_swap_group; +WGLEW_EXPORT GLboolean __WGLEW_NV_vertex_array_range; +WGLEW_EXPORT GLboolean __WGLEW_NV_video_output; +WGLEW_EXPORT GLboolean __WGLEW_OML_sync_control; + +#ifdef GLEW_MX +}; /* WGLEWContextStruct */ +#endif /* GLEW_MX */ + +/* ------------------------------------------------------------------------- */ + +#ifdef GLEW_MX + +typedef struct WGLEWContextStruct WGLEWContext; +GLEWAPI GLenum wglewContextInit (WGLEWContext* ctx); +GLEWAPI GLboolean wglewContextIsSupported (WGLEWContext* ctx, const char* name); + +#define wglewInit() wglewContextInit(wglewGetContext()) +#define wglewIsSupported(x) wglewContextIsSupported(wglewGetContext(), x) + +#define WGLEW_GET_VAR(x) (*(const GLboolean*)&(wglewGetContext()->x)) +#define WGLEW_GET_FUN(x) wglewGetContext()->x + +#else /* GLEW_MX */ + +#define WGLEW_GET_VAR(x) (*(const GLboolean*)&x) +#define WGLEW_GET_FUN(x) x + +GLEWAPI GLboolean wglewIsSupported (const char* name); + +#endif /* GLEW_MX */ + +GLEWAPI GLboolean wglewGetExtension (const char* name); + +#ifdef __cplusplus +} +#endif + +#undef GLEWAPI + +#endif /* __wglew_h__ */ diff --git a/Externals/GLew/src/glew.c b/Externals/GLew/src/glew.c new file mode 100644 index 0000000000..987236b7d3 --- /dev/null +++ b/Externals/GLew/src/glew.c @@ -0,0 +1,14320 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#include +#if defined(_WIN32) +# include +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +# include +#endif + +/* + * Define glewGetContext and related helper macros. + */ +#ifdef GLEW_MX +# define glewGetContext() ctx +# ifdef _WIN32 +# define GLEW_CONTEXT_ARG_DEF_INIT GLEWContext* ctx +# define GLEW_CONTEXT_ARG_VAR_INIT ctx +# define wglewGetContext() ctx +# define WGLEW_CONTEXT_ARG_DEF_INIT WGLEWContext* ctx +# define WGLEW_CONTEXT_ARG_DEF_LIST WGLEWContext* ctx +# else /* _WIN32 */ +# define GLEW_CONTEXT_ARG_DEF_INIT void +# define GLEW_CONTEXT_ARG_VAR_INIT +# define glxewGetContext() ctx +# define GLXEW_CONTEXT_ARG_DEF_INIT void +# define GLXEW_CONTEXT_ARG_DEF_LIST GLXEWContext* ctx +# endif /* _WIN32 */ +# define GLEW_CONTEXT_ARG_DEF_LIST GLEWContext* ctx +#else /* GLEW_MX */ +# define GLEW_CONTEXT_ARG_DEF_INIT void +# define GLEW_CONTEXT_ARG_VAR_INIT +# define GLEW_CONTEXT_ARG_DEF_LIST void +# define WGLEW_CONTEXT_ARG_DEF_INIT void +# define WGLEW_CONTEXT_ARG_DEF_LIST void +# define GLXEW_CONTEXT_ARG_DEF_INIT void +# define GLXEW_CONTEXT_ARG_DEF_LIST void +#endif /* GLEW_MX */ + +#if defined(__APPLE__) +#include +#include +#include + +#ifdef MAC_OS_X_VERSION_10_3 + +#include + +void* NSGLGetProcAddress (const GLubyte *name) +{ + static void* image = NULL; + if (NULL == image) + { + image = dlopen("/System/Library/Frameworks/OpenGL.framework/Versions/Current/OpenGL", RTLD_LAZY); + } + return image ? dlsym(image, (const char*)name) : NULL; +} +#else + +#include + +void* NSGLGetProcAddress (const GLubyte *name) +{ + static const struct mach_header* image = NULL; + NSSymbol symbol; + char* symbolName; + if (NULL == image) + { + image = NSAddImage("/System/Library/Frameworks/OpenGL.framework/Versions/Current/OpenGL", NSADDIMAGE_OPTION_RETURN_ON_ERROR); + } + /* prepend a '_' for the Unix C symbol mangling convention */ + symbolName = malloc(strlen((const char*)name) + 2); + strcpy(symbolName+1, (const char*)name); + symbolName[0] = '_'; + symbol = NULL; + /* if (NSIsSymbolNameDefined(symbolName)) + symbol = NSLookupAndBindSymbol(symbolName); */ + symbol = image ? NSLookupSymbolInImage(image, symbolName, NSLOOKUPSYMBOLINIMAGE_OPTION_BIND | NSLOOKUPSYMBOLINIMAGE_OPTION_RETURN_ON_ERROR) : NULL; + free(symbolName); + return symbol ? NSAddressOfSymbol(symbol) : NULL; +} +#endif /* MAC_OS_X_VERSION_10_3 */ +#endif /* __APPLE__ */ + +#if defined(__sgi) || defined (__sun) +#include +#include +#include + +void* dlGetProcAddress (const GLubyte* name) +{ + static void* h = NULL; + static void* gpa; + + if (h == NULL) + { + if ((h = dlopen(NULL, RTLD_LAZY | RTLD_LOCAL)) == NULL) return NULL; + gpa = dlsym(h, "glXGetProcAddress"); + } + + if (gpa != NULL) + return ((void*(*)(const GLubyte*))gpa)(name); + else + return dlsym(h, (const char*)name); +} +#endif /* __sgi || __sun */ + +/* + * Define glewGetProcAddress. + */ +#if defined(_WIN32) +# define glewGetProcAddress(name) wglGetProcAddress((LPCSTR)name) +#else +# if defined(__APPLE__) +# define glewGetProcAddress(name) NSGLGetProcAddress(name) +# else +# if defined(__sgi) || defined(__sun) +# define glewGetProcAddress(name) dlGetProcAddress(name) +# else /* __linux */ +# define glewGetProcAddress(name) (*glXGetProcAddressARB)(name) +# endif +# endif +#endif + +/* + * Define GLboolean const cast. + */ +#define CONST_CAST(x) (*(GLboolean*)&x) + +/* + * GLEW, just like OpenGL or GLU, does not rely on the standard C library. + * These functions implement the functionality required in this file. + */ +static GLuint _glewStrLen (const GLubyte* s) +{ + GLuint i=0; + if (s == NULL) return 0; + while (s[i] != '\0') i++; + return i; +} + +static GLuint _glewStrCLen (const GLubyte* s, GLubyte c) +{ + GLuint i=0; + if (s == NULL) return 0; + while (s[i] != '\0' && s[i] != c) i++; + return (s[i] == '\0' || s[i] == c) ? i : 0; +} + +static GLboolean _glewStrSame (const GLubyte* a, const GLubyte* b, GLuint n) +{ + GLuint i=0; + if(a == NULL || b == NULL) + return (a == NULL && b == NULL && n == 0) ? GL_TRUE : GL_FALSE; + while (i < n && a[i] != '\0' && b[i] != '\0' && a[i] == b[i]) i++; + return i == n ? GL_TRUE : GL_FALSE; +} + +static GLboolean _glewStrSame1 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + while (*na > 0 && (**a == ' ' || **a == '\n' || **a == '\r' || **a == '\t')) + { + (*a)++; + (*na)--; + } + if(*na >= nb) + { + GLuint i=0; + while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; + if(i == nb) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} + +static GLboolean _glewStrSame2 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + if(*na >= nb) + { + GLuint i=0; + while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; + if(i == nb) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} + +static GLboolean _glewStrSame3 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) +{ + if(*na >= nb) + { + GLuint i=0; + while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; + if (i == nb && (*na == nb || (*a)[i] == ' ' || (*a)[i] == '\n' || (*a)[i] == '\r' || (*a)[i] == '\t')) + { + *a = *a + nb; + *na = *na - nb; + return GL_TRUE; + } + } + return GL_FALSE; +} + +#if !defined(_WIN32) || !defined(GLEW_MX) + +PFNGLCOPYTEXSUBIMAGE3DPROC __glewCopyTexSubImage3D = NULL; +PFNGLDRAWRANGEELEMENTSPROC __glewDrawRangeElements = NULL; +PFNGLTEXIMAGE3DPROC __glewTexImage3D = NULL; +PFNGLTEXSUBIMAGE3DPROC __glewTexSubImage3D = NULL; + +PFNGLACTIVETEXTUREPROC __glewActiveTexture = NULL; +PFNGLCLIENTACTIVETEXTUREPROC __glewClientActiveTexture = NULL; +PFNGLCOMPRESSEDTEXIMAGE1DPROC __glewCompressedTexImage1D = NULL; +PFNGLCOMPRESSEDTEXIMAGE2DPROC __glewCompressedTexImage2D = NULL; +PFNGLCOMPRESSEDTEXIMAGE3DPROC __glewCompressedTexImage3D = NULL; +PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC __glewCompressedTexSubImage1D = NULL; +PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC __glewCompressedTexSubImage2D = NULL; +PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC __glewCompressedTexSubImage3D = NULL; +PFNGLGETCOMPRESSEDTEXIMAGEPROC __glewGetCompressedTexImage = NULL; +PFNGLLOADTRANSPOSEMATRIXDPROC __glewLoadTransposeMatrixd = NULL; +PFNGLLOADTRANSPOSEMATRIXFPROC __glewLoadTransposeMatrixf = NULL; +PFNGLMULTTRANSPOSEMATRIXDPROC __glewMultTransposeMatrixd = NULL; +PFNGLMULTTRANSPOSEMATRIXFPROC __glewMultTransposeMatrixf = NULL; +PFNGLMULTITEXCOORD1DPROC __glewMultiTexCoord1d = NULL; +PFNGLMULTITEXCOORD1DVPROC __glewMultiTexCoord1dv = NULL; +PFNGLMULTITEXCOORD1FPROC __glewMultiTexCoord1f = NULL; +PFNGLMULTITEXCOORD1FVPROC __glewMultiTexCoord1fv = NULL; +PFNGLMULTITEXCOORD1IPROC __glewMultiTexCoord1i = NULL; +PFNGLMULTITEXCOORD1IVPROC __glewMultiTexCoord1iv = NULL; +PFNGLMULTITEXCOORD1SPROC __glewMultiTexCoord1s = NULL; +PFNGLMULTITEXCOORD1SVPROC __glewMultiTexCoord1sv = NULL; +PFNGLMULTITEXCOORD2DPROC __glewMultiTexCoord2d = NULL; +PFNGLMULTITEXCOORD2DVPROC __glewMultiTexCoord2dv = NULL; +PFNGLMULTITEXCOORD2FPROC __glewMultiTexCoord2f = NULL; +PFNGLMULTITEXCOORD2FVPROC __glewMultiTexCoord2fv = NULL; +PFNGLMULTITEXCOORD2IPROC __glewMultiTexCoord2i = NULL; +PFNGLMULTITEXCOORD2IVPROC __glewMultiTexCoord2iv = NULL; +PFNGLMULTITEXCOORD2SPROC __glewMultiTexCoord2s = NULL; +PFNGLMULTITEXCOORD2SVPROC __glewMultiTexCoord2sv = NULL; +PFNGLMULTITEXCOORD3DPROC __glewMultiTexCoord3d = NULL; +PFNGLMULTITEXCOORD3DVPROC __glewMultiTexCoord3dv = NULL; +PFNGLMULTITEXCOORD3FPROC __glewMultiTexCoord3f = NULL; +PFNGLMULTITEXCOORD3FVPROC __glewMultiTexCoord3fv = NULL; +PFNGLMULTITEXCOORD3IPROC __glewMultiTexCoord3i = NULL; +PFNGLMULTITEXCOORD3IVPROC __glewMultiTexCoord3iv = NULL; +PFNGLMULTITEXCOORD3SPROC __glewMultiTexCoord3s = NULL; +PFNGLMULTITEXCOORD3SVPROC __glewMultiTexCoord3sv = NULL; +PFNGLMULTITEXCOORD4DPROC __glewMultiTexCoord4d = NULL; +PFNGLMULTITEXCOORD4DVPROC __glewMultiTexCoord4dv = NULL; +PFNGLMULTITEXCOORD4FPROC __glewMultiTexCoord4f = NULL; +PFNGLMULTITEXCOORD4FVPROC __glewMultiTexCoord4fv = NULL; +PFNGLMULTITEXCOORD4IPROC __glewMultiTexCoord4i = NULL; +PFNGLMULTITEXCOORD4IVPROC __glewMultiTexCoord4iv = NULL; +PFNGLMULTITEXCOORD4SPROC __glewMultiTexCoord4s = NULL; +PFNGLMULTITEXCOORD4SVPROC __glewMultiTexCoord4sv = NULL; +PFNGLSAMPLECOVERAGEPROC __glewSampleCoverage = NULL; + +PFNGLBLENDCOLORPROC __glewBlendColor = NULL; +PFNGLBLENDEQUATIONPROC __glewBlendEquation = NULL; +PFNGLBLENDFUNCSEPARATEPROC __glewBlendFuncSeparate = NULL; +PFNGLFOGCOORDPOINTERPROC __glewFogCoordPointer = NULL; +PFNGLFOGCOORDDPROC __glewFogCoordd = NULL; +PFNGLFOGCOORDDVPROC __glewFogCoorddv = NULL; +PFNGLFOGCOORDFPROC __glewFogCoordf = NULL; +PFNGLFOGCOORDFVPROC __glewFogCoordfv = NULL; +PFNGLMULTIDRAWARRAYSPROC __glewMultiDrawArrays = NULL; +PFNGLMULTIDRAWELEMENTSPROC __glewMultiDrawElements = NULL; +PFNGLPOINTPARAMETERFPROC __glewPointParameterf = NULL; +PFNGLPOINTPARAMETERFVPROC __glewPointParameterfv = NULL; +PFNGLPOINTPARAMETERIPROC __glewPointParameteri = NULL; +PFNGLPOINTPARAMETERIVPROC __glewPointParameteriv = NULL; +PFNGLSECONDARYCOLOR3BPROC __glewSecondaryColor3b = NULL; +PFNGLSECONDARYCOLOR3BVPROC __glewSecondaryColor3bv = NULL; +PFNGLSECONDARYCOLOR3DPROC __glewSecondaryColor3d = NULL; +PFNGLSECONDARYCOLOR3DVPROC __glewSecondaryColor3dv = NULL; +PFNGLSECONDARYCOLOR3FPROC __glewSecondaryColor3f = NULL; +PFNGLSECONDARYCOLOR3FVPROC __glewSecondaryColor3fv = NULL; +PFNGLSECONDARYCOLOR3IPROC __glewSecondaryColor3i = NULL; +PFNGLSECONDARYCOLOR3IVPROC __glewSecondaryColor3iv = NULL; +PFNGLSECONDARYCOLOR3SPROC __glewSecondaryColor3s = NULL; +PFNGLSECONDARYCOLOR3SVPROC __glewSecondaryColor3sv = NULL; +PFNGLSECONDARYCOLOR3UBPROC __glewSecondaryColor3ub = NULL; +PFNGLSECONDARYCOLOR3UBVPROC __glewSecondaryColor3ubv = NULL; +PFNGLSECONDARYCOLOR3UIPROC __glewSecondaryColor3ui = NULL; +PFNGLSECONDARYCOLOR3UIVPROC __glewSecondaryColor3uiv = NULL; +PFNGLSECONDARYCOLOR3USPROC __glewSecondaryColor3us = NULL; +PFNGLSECONDARYCOLOR3USVPROC __glewSecondaryColor3usv = NULL; +PFNGLSECONDARYCOLORPOINTERPROC __glewSecondaryColorPointer = NULL; +PFNGLWINDOWPOS2DPROC __glewWindowPos2d = NULL; +PFNGLWINDOWPOS2DVPROC __glewWindowPos2dv = NULL; +PFNGLWINDOWPOS2FPROC __glewWindowPos2f = NULL; +PFNGLWINDOWPOS2FVPROC __glewWindowPos2fv = NULL; +PFNGLWINDOWPOS2IPROC __glewWindowPos2i = NULL; +PFNGLWINDOWPOS2IVPROC __glewWindowPos2iv = NULL; +PFNGLWINDOWPOS2SPROC __glewWindowPos2s = NULL; +PFNGLWINDOWPOS2SVPROC __glewWindowPos2sv = NULL; +PFNGLWINDOWPOS3DPROC __glewWindowPos3d = NULL; +PFNGLWINDOWPOS3DVPROC __glewWindowPos3dv = NULL; +PFNGLWINDOWPOS3FPROC __glewWindowPos3f = NULL; +PFNGLWINDOWPOS3FVPROC __glewWindowPos3fv = NULL; +PFNGLWINDOWPOS3IPROC __glewWindowPos3i = NULL; +PFNGLWINDOWPOS3IVPROC __glewWindowPos3iv = NULL; +PFNGLWINDOWPOS3SPROC __glewWindowPos3s = NULL; +PFNGLWINDOWPOS3SVPROC __glewWindowPos3sv = NULL; + +PFNGLBEGINQUERYPROC __glewBeginQuery = NULL; +PFNGLBINDBUFFERPROC __glewBindBuffer = NULL; +PFNGLBUFFERDATAPROC __glewBufferData = NULL; +PFNGLBUFFERSUBDATAPROC __glewBufferSubData = NULL; +PFNGLDELETEBUFFERSPROC __glewDeleteBuffers = NULL; +PFNGLDELETEQUERIESPROC __glewDeleteQueries = NULL; +PFNGLENDQUERYPROC __glewEndQuery = NULL; +PFNGLGENBUFFERSPROC __glewGenBuffers = NULL; +PFNGLGENQUERIESPROC __glewGenQueries = NULL; +PFNGLGETBUFFERPARAMETERIVPROC __glewGetBufferParameteriv = NULL; +PFNGLGETBUFFERPOINTERVPROC __glewGetBufferPointerv = NULL; +PFNGLGETBUFFERSUBDATAPROC __glewGetBufferSubData = NULL; +PFNGLGETQUERYOBJECTIVPROC __glewGetQueryObjectiv = NULL; +PFNGLGETQUERYOBJECTUIVPROC __glewGetQueryObjectuiv = NULL; +PFNGLGETQUERYIVPROC __glewGetQueryiv = NULL; +PFNGLISBUFFERPROC __glewIsBuffer = NULL; +PFNGLISQUERYPROC __glewIsQuery = NULL; +PFNGLMAPBUFFERPROC __glewMapBuffer = NULL; +PFNGLUNMAPBUFFERPROC __glewUnmapBuffer = NULL; + +PFNGLATTACHSHADERPROC __glewAttachShader = NULL; +PFNGLBINDATTRIBLOCATIONPROC __glewBindAttribLocation = NULL; +PFNGLBLENDEQUATIONSEPARATEPROC __glewBlendEquationSeparate = NULL; +PFNGLCOMPILESHADERPROC __glewCompileShader = NULL; +PFNGLCREATEPROGRAMPROC __glewCreateProgram = NULL; +PFNGLCREATESHADERPROC __glewCreateShader = NULL; +PFNGLDELETEPROGRAMPROC __glewDeleteProgram = NULL; +PFNGLDELETESHADERPROC __glewDeleteShader = NULL; +PFNGLDETACHSHADERPROC __glewDetachShader = NULL; +PFNGLDISABLEVERTEXATTRIBARRAYPROC __glewDisableVertexAttribArray = NULL; +PFNGLDRAWBUFFERSPROC __glewDrawBuffers = NULL; +PFNGLENABLEVERTEXATTRIBARRAYPROC __glewEnableVertexAttribArray = NULL; +PFNGLGETACTIVEATTRIBPROC __glewGetActiveAttrib = NULL; +PFNGLGETACTIVEUNIFORMPROC __glewGetActiveUniform = NULL; +PFNGLGETATTACHEDSHADERSPROC __glewGetAttachedShaders = NULL; +PFNGLGETATTRIBLOCATIONPROC __glewGetAttribLocation = NULL; +PFNGLGETPROGRAMINFOLOGPROC __glewGetProgramInfoLog = NULL; +PFNGLGETPROGRAMIVPROC __glewGetProgramiv = NULL; +PFNGLGETSHADERINFOLOGPROC __glewGetShaderInfoLog = NULL; +PFNGLGETSHADERSOURCEPROC __glewGetShaderSource = NULL; +PFNGLGETSHADERIVPROC __glewGetShaderiv = NULL; +PFNGLGETUNIFORMLOCATIONPROC __glewGetUniformLocation = NULL; +PFNGLGETUNIFORMFVPROC __glewGetUniformfv = NULL; +PFNGLGETUNIFORMIVPROC __glewGetUniformiv = NULL; +PFNGLGETVERTEXATTRIBPOINTERVPROC __glewGetVertexAttribPointerv = NULL; +PFNGLGETVERTEXATTRIBDVPROC __glewGetVertexAttribdv = NULL; +PFNGLGETVERTEXATTRIBFVPROC __glewGetVertexAttribfv = NULL; +PFNGLGETVERTEXATTRIBIVPROC __glewGetVertexAttribiv = NULL; +PFNGLISPROGRAMPROC __glewIsProgram = NULL; +PFNGLISSHADERPROC __glewIsShader = NULL; +PFNGLLINKPROGRAMPROC __glewLinkProgram = NULL; +PFNGLSHADERSOURCEPROC __glewShaderSource = NULL; +PFNGLSTENCILFUNCSEPARATEPROC __glewStencilFuncSeparate = NULL; +PFNGLSTENCILMASKSEPARATEPROC __glewStencilMaskSeparate = NULL; +PFNGLSTENCILOPSEPARATEPROC __glewStencilOpSeparate = NULL; +PFNGLUNIFORM1FPROC __glewUniform1f = NULL; +PFNGLUNIFORM1FVPROC __glewUniform1fv = NULL; +PFNGLUNIFORM1IPROC __glewUniform1i = NULL; +PFNGLUNIFORM1IVPROC __glewUniform1iv = NULL; +PFNGLUNIFORM2FPROC __glewUniform2f = NULL; +PFNGLUNIFORM2FVPROC __glewUniform2fv = NULL; +PFNGLUNIFORM2IPROC __glewUniform2i = NULL; +PFNGLUNIFORM2IVPROC __glewUniform2iv = NULL; +PFNGLUNIFORM3FPROC __glewUniform3f = NULL; +PFNGLUNIFORM3FVPROC __glewUniform3fv = NULL; +PFNGLUNIFORM3IPROC __glewUniform3i = NULL; +PFNGLUNIFORM3IVPROC __glewUniform3iv = NULL; +PFNGLUNIFORM4FPROC __glewUniform4f = NULL; +PFNGLUNIFORM4FVPROC __glewUniform4fv = NULL; +PFNGLUNIFORM4IPROC __glewUniform4i = NULL; +PFNGLUNIFORM4IVPROC __glewUniform4iv = NULL; +PFNGLUNIFORMMATRIX2FVPROC __glewUniformMatrix2fv = NULL; +PFNGLUNIFORMMATRIX3FVPROC __glewUniformMatrix3fv = NULL; +PFNGLUNIFORMMATRIX4FVPROC __glewUniformMatrix4fv = NULL; +PFNGLUSEPROGRAMPROC __glewUseProgram = NULL; +PFNGLVALIDATEPROGRAMPROC __glewValidateProgram = NULL; +PFNGLVERTEXATTRIB1DPROC __glewVertexAttrib1d = NULL; +PFNGLVERTEXATTRIB1DVPROC __glewVertexAttrib1dv = NULL; +PFNGLVERTEXATTRIB1FPROC __glewVertexAttrib1f = NULL; +PFNGLVERTEXATTRIB1FVPROC __glewVertexAttrib1fv = NULL; +PFNGLVERTEXATTRIB1SPROC __glewVertexAttrib1s = NULL; +PFNGLVERTEXATTRIB1SVPROC __glewVertexAttrib1sv = NULL; +PFNGLVERTEXATTRIB2DPROC __glewVertexAttrib2d = NULL; +PFNGLVERTEXATTRIB2DVPROC __glewVertexAttrib2dv = NULL; +PFNGLVERTEXATTRIB2FPROC __glewVertexAttrib2f = NULL; +PFNGLVERTEXATTRIB2FVPROC __glewVertexAttrib2fv = NULL; +PFNGLVERTEXATTRIB2SPROC __glewVertexAttrib2s = NULL; +PFNGLVERTEXATTRIB2SVPROC __glewVertexAttrib2sv = NULL; +PFNGLVERTEXATTRIB3DPROC __glewVertexAttrib3d = NULL; +PFNGLVERTEXATTRIB3DVPROC __glewVertexAttrib3dv = NULL; +PFNGLVERTEXATTRIB3FPROC __glewVertexAttrib3f = NULL; +PFNGLVERTEXATTRIB3FVPROC __glewVertexAttrib3fv = NULL; +PFNGLVERTEXATTRIB3SPROC __glewVertexAttrib3s = NULL; +PFNGLVERTEXATTRIB3SVPROC __glewVertexAttrib3sv = NULL; +PFNGLVERTEXATTRIB4NBVPROC __glewVertexAttrib4Nbv = NULL; +PFNGLVERTEXATTRIB4NIVPROC __glewVertexAttrib4Niv = NULL; +PFNGLVERTEXATTRIB4NSVPROC __glewVertexAttrib4Nsv = NULL; +PFNGLVERTEXATTRIB4NUBPROC __glewVertexAttrib4Nub = NULL; +PFNGLVERTEXATTRIB4NUBVPROC __glewVertexAttrib4Nubv = NULL; +PFNGLVERTEXATTRIB4NUIVPROC __glewVertexAttrib4Nuiv = NULL; +PFNGLVERTEXATTRIB4NUSVPROC __glewVertexAttrib4Nusv = NULL; +PFNGLVERTEXATTRIB4BVPROC __glewVertexAttrib4bv = NULL; +PFNGLVERTEXATTRIB4DPROC __glewVertexAttrib4d = NULL; +PFNGLVERTEXATTRIB4DVPROC __glewVertexAttrib4dv = NULL; +PFNGLVERTEXATTRIB4FPROC __glewVertexAttrib4f = NULL; +PFNGLVERTEXATTRIB4FVPROC __glewVertexAttrib4fv = NULL; +PFNGLVERTEXATTRIB4IVPROC __glewVertexAttrib4iv = NULL; +PFNGLVERTEXATTRIB4SPROC __glewVertexAttrib4s = NULL; +PFNGLVERTEXATTRIB4SVPROC __glewVertexAttrib4sv = NULL; +PFNGLVERTEXATTRIB4UBVPROC __glewVertexAttrib4ubv = NULL; +PFNGLVERTEXATTRIB4UIVPROC __glewVertexAttrib4uiv = NULL; +PFNGLVERTEXATTRIB4USVPROC __glewVertexAttrib4usv = NULL; +PFNGLVERTEXATTRIBPOINTERPROC __glewVertexAttribPointer = NULL; + +PFNGLUNIFORMMATRIX2X3FVPROC __glewUniformMatrix2x3fv = NULL; +PFNGLUNIFORMMATRIX2X4FVPROC __glewUniformMatrix2x4fv = NULL; +PFNGLUNIFORMMATRIX3X2FVPROC __glewUniformMatrix3x2fv = NULL; +PFNGLUNIFORMMATRIX3X4FVPROC __glewUniformMatrix3x4fv = NULL; +PFNGLUNIFORMMATRIX4X2FVPROC __glewUniformMatrix4x2fv = NULL; +PFNGLUNIFORMMATRIX4X3FVPROC __glewUniformMatrix4x3fv = NULL; + +PFNGLBEGINCONDITIONALRENDERPROC __glewBeginConditionalRender = NULL; +PFNGLBEGINTRANSFORMFEEDBACKPROC __glewBeginTransformFeedback = NULL; +PFNGLBINDFRAGDATALOCATIONPROC __glewBindFragDataLocation = NULL; +PFNGLCLAMPCOLORPROC __glewClampColor = NULL; +PFNGLCLEARBUFFERFIPROC __glewClearBufferfi = NULL; +PFNGLCLEARBUFFERFVPROC __glewClearBufferfv = NULL; +PFNGLCLEARBUFFERIVPROC __glewClearBufferiv = NULL; +PFNGLCLEARBUFFERUIVPROC __glewClearBufferuiv = NULL; +PFNGLCOLORMASKIPROC __glewColorMaski = NULL; +PFNGLDISABLEIPROC __glewDisablei = NULL; +PFNGLENABLEIPROC __glewEnablei = NULL; +PFNGLENDCONDITIONALRENDERPROC __glewEndConditionalRender = NULL; +PFNGLENDTRANSFORMFEEDBACKPROC __glewEndTransformFeedback = NULL; +PFNGLGETBOOLEANI_VPROC __glewGetBooleani_v = NULL; +PFNGLGETFRAGDATALOCATIONPROC __glewGetFragDataLocation = NULL; +PFNGLGETSTRINGIPROC __glewGetStringi = NULL; +PFNGLGETTEXPARAMETERIIVPROC __glewGetTexParameterIiv = NULL; +PFNGLGETTEXPARAMETERIUIVPROC __glewGetTexParameterIuiv = NULL; +PFNGLGETTRANSFORMFEEDBACKVARYINGPROC __glewGetTransformFeedbackVarying = NULL; +PFNGLGETUNIFORMUIVPROC __glewGetUniformuiv = NULL; +PFNGLGETVERTEXATTRIBIIVPROC __glewGetVertexAttribIiv = NULL; +PFNGLGETVERTEXATTRIBIUIVPROC __glewGetVertexAttribIuiv = NULL; +PFNGLISENABLEDIPROC __glewIsEnabledi = NULL; +PFNGLTEXPARAMETERIIVPROC __glewTexParameterIiv = NULL; +PFNGLTEXPARAMETERIUIVPROC __glewTexParameterIuiv = NULL; +PFNGLTRANSFORMFEEDBACKVARYINGSPROC __glewTransformFeedbackVaryings = NULL; +PFNGLUNIFORM1UIPROC __glewUniform1ui = NULL; +PFNGLUNIFORM1UIVPROC __glewUniform1uiv = NULL; +PFNGLUNIFORM2UIPROC __glewUniform2ui = NULL; +PFNGLUNIFORM2UIVPROC __glewUniform2uiv = NULL; +PFNGLUNIFORM3UIPROC __glewUniform3ui = NULL; +PFNGLUNIFORM3UIVPROC __glewUniform3uiv = NULL; +PFNGLUNIFORM4UIPROC __glewUniform4ui = NULL; +PFNGLUNIFORM4UIVPROC __glewUniform4uiv = NULL; +PFNGLVERTEXATTRIBI1IPROC __glewVertexAttribI1i = NULL; +PFNGLVERTEXATTRIBI1IVPROC __glewVertexAttribI1iv = NULL; +PFNGLVERTEXATTRIBI1UIPROC __glewVertexAttribI1ui = NULL; +PFNGLVERTEXATTRIBI1UIVPROC __glewVertexAttribI1uiv = NULL; +PFNGLVERTEXATTRIBI2IPROC __glewVertexAttribI2i = NULL; +PFNGLVERTEXATTRIBI2IVPROC __glewVertexAttribI2iv = NULL; +PFNGLVERTEXATTRIBI2UIPROC __glewVertexAttribI2ui = NULL; +PFNGLVERTEXATTRIBI2UIVPROC __glewVertexAttribI2uiv = NULL; +PFNGLVERTEXATTRIBI3IPROC __glewVertexAttribI3i = NULL; +PFNGLVERTEXATTRIBI3IVPROC __glewVertexAttribI3iv = NULL; +PFNGLVERTEXATTRIBI3UIPROC __glewVertexAttribI3ui = NULL; +PFNGLVERTEXATTRIBI3UIVPROC __glewVertexAttribI3uiv = NULL; +PFNGLVERTEXATTRIBI4BVPROC __glewVertexAttribI4bv = NULL; +PFNGLVERTEXATTRIBI4IPROC __glewVertexAttribI4i = NULL; +PFNGLVERTEXATTRIBI4IVPROC __glewVertexAttribI4iv = NULL; +PFNGLVERTEXATTRIBI4SVPROC __glewVertexAttribI4sv = NULL; +PFNGLVERTEXATTRIBI4UBVPROC __glewVertexAttribI4ubv = NULL; +PFNGLVERTEXATTRIBI4UIPROC __glewVertexAttribI4ui = NULL; +PFNGLVERTEXATTRIBI4UIVPROC __glewVertexAttribI4uiv = NULL; +PFNGLVERTEXATTRIBI4USVPROC __glewVertexAttribI4usv = NULL; +PFNGLVERTEXATTRIBIPOINTERPROC __glewVertexAttribIPointer = NULL; + +PFNGLDRAWARRAYSINSTANCEDPROC __glewDrawArraysInstanced = NULL; +PFNGLDRAWELEMENTSINSTANCEDPROC __glewDrawElementsInstanced = NULL; +PFNGLPRIMITIVERESTARTINDEXPROC __glewPrimitiveRestartIndex = NULL; +PFNGLTEXBUFFERPROC __glewTexBuffer = NULL; + +PFNGLFRAMEBUFFERTEXTUREPROC __glewFramebufferTexture = NULL; +PFNGLGETBUFFERPARAMETERI64VPROC __glewGetBufferParameteri64v = NULL; +PFNGLGETINTEGER64I_VPROC __glewGetInteger64i_v = NULL; + +PFNGLBLENDEQUATIONSEPARATEIPROC __glewBlendEquationSeparatei = NULL; +PFNGLBLENDEQUATIONIPROC __glewBlendEquationi = NULL; +PFNGLBLENDFUNCSEPARATEIPROC __glewBlendFuncSeparatei = NULL; +PFNGLBLENDFUNCIPROC __glewBlendFunci = NULL; +PFNGLMINSAMPLESHADINGPROC __glewMinSampleShading = NULL; + +PFNGLTBUFFERMASK3DFXPROC __glewTbufferMask3DFX = NULL; + +PFNGLBLENDEQUATIONINDEXEDAMDPROC __glewBlendEquationIndexedAMD = NULL; +PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC __glewBlendEquationSeparateIndexedAMD = NULL; +PFNGLBLENDFUNCINDEXEDAMDPROC __glewBlendFuncIndexedAMD = NULL; +PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC __glewBlendFuncSeparateIndexedAMD = NULL; + +PFNGLBEGINPERFMONITORAMDPROC __glewBeginPerfMonitorAMD = NULL; +PFNGLDELETEPERFMONITORSAMDPROC __glewDeletePerfMonitorsAMD = NULL; +PFNGLENDPERFMONITORAMDPROC __glewEndPerfMonitorAMD = NULL; +PFNGLGENPERFMONITORSAMDPROC __glewGenPerfMonitorsAMD = NULL; +PFNGLGETPERFMONITORCOUNTERDATAAMDPROC __glewGetPerfMonitorCounterDataAMD = NULL; +PFNGLGETPERFMONITORCOUNTERINFOAMDPROC __glewGetPerfMonitorCounterInfoAMD = NULL; +PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC __glewGetPerfMonitorCounterStringAMD = NULL; +PFNGLGETPERFMONITORCOUNTERSAMDPROC __glewGetPerfMonitorCountersAMD = NULL; +PFNGLGETPERFMONITORGROUPSTRINGAMDPROC __glewGetPerfMonitorGroupStringAMD = NULL; +PFNGLGETPERFMONITORGROUPSAMDPROC __glewGetPerfMonitorGroupsAMD = NULL; +PFNGLSELECTPERFMONITORCOUNTERSAMDPROC __glewSelectPerfMonitorCountersAMD = NULL; + +PFNGLTESSELLATIONFACTORAMDPROC __glewTessellationFactorAMD = NULL; +PFNGLTESSELLATIONMODEAMDPROC __glewTessellationModeAMD = NULL; + +PFNGLDRAWELEMENTARRAYAPPLEPROC __glewDrawElementArrayAPPLE = NULL; +PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC __glewDrawRangeElementArrayAPPLE = NULL; +PFNGLELEMENTPOINTERAPPLEPROC __glewElementPointerAPPLE = NULL; +PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC __glewMultiDrawElementArrayAPPLE = NULL; +PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC __glewMultiDrawRangeElementArrayAPPLE = NULL; + +PFNGLDELETEFENCESAPPLEPROC __glewDeleteFencesAPPLE = NULL; +PFNGLFINISHFENCEAPPLEPROC __glewFinishFenceAPPLE = NULL; +PFNGLFINISHOBJECTAPPLEPROC __glewFinishObjectAPPLE = NULL; +PFNGLGENFENCESAPPLEPROC __glewGenFencesAPPLE = NULL; +PFNGLISFENCEAPPLEPROC __glewIsFenceAPPLE = NULL; +PFNGLSETFENCEAPPLEPROC __glewSetFenceAPPLE = NULL; +PFNGLTESTFENCEAPPLEPROC __glewTestFenceAPPLE = NULL; +PFNGLTESTOBJECTAPPLEPROC __glewTestObjectAPPLE = NULL; + +PFNGLBUFFERPARAMETERIAPPLEPROC __glewBufferParameteriAPPLE = NULL; +PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC __glewFlushMappedBufferRangeAPPLE = NULL; + +PFNGLGETOBJECTPARAMETERIVAPPLEPROC __glewGetObjectParameterivAPPLE = NULL; +PFNGLOBJECTPURGEABLEAPPLEPROC __glewObjectPurgeableAPPLE = NULL; +PFNGLOBJECTUNPURGEABLEAPPLEPROC __glewObjectUnpurgeableAPPLE = NULL; + +PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC __glewGetTexParameterPointervAPPLE = NULL; +PFNGLTEXTURERANGEAPPLEPROC __glewTextureRangeAPPLE = NULL; + +PFNGLBINDVERTEXARRAYAPPLEPROC __glewBindVertexArrayAPPLE = NULL; +PFNGLDELETEVERTEXARRAYSAPPLEPROC __glewDeleteVertexArraysAPPLE = NULL; +PFNGLGENVERTEXARRAYSAPPLEPROC __glewGenVertexArraysAPPLE = NULL; +PFNGLISVERTEXARRAYAPPLEPROC __glewIsVertexArrayAPPLE = NULL; + +PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC __glewFlushVertexArrayRangeAPPLE = NULL; +PFNGLVERTEXARRAYPARAMETERIAPPLEPROC __glewVertexArrayParameteriAPPLE = NULL; +PFNGLVERTEXARRAYRANGEAPPLEPROC __glewVertexArrayRangeAPPLE = NULL; + +PFNGLDISABLEVERTEXATTRIBAPPLEPROC __glewDisableVertexAttribAPPLE = NULL; +PFNGLENABLEVERTEXATTRIBAPPLEPROC __glewEnableVertexAttribAPPLE = NULL; +PFNGLISVERTEXATTRIBENABLEDAPPLEPROC __glewIsVertexAttribEnabledAPPLE = NULL; +PFNGLMAPVERTEXATTRIB1DAPPLEPROC __glewMapVertexAttrib1dAPPLE = NULL; +PFNGLMAPVERTEXATTRIB1FAPPLEPROC __glewMapVertexAttrib1fAPPLE = NULL; +PFNGLMAPVERTEXATTRIB2DAPPLEPROC __glewMapVertexAttrib2dAPPLE = NULL; +PFNGLMAPVERTEXATTRIB2FAPPLEPROC __glewMapVertexAttrib2fAPPLE = NULL; + +PFNGLBINDFRAGDATALOCATIONINDEXEDPROC __glewBindFragDataLocationIndexed = NULL; +PFNGLGETFRAGDATAINDEXPROC __glewGetFragDataIndex = NULL; + +PFNGLCLAMPCOLORARBPROC __glewClampColorARB = NULL; + +PFNGLCOPYBUFFERSUBDATAPROC __glewCopyBufferSubData = NULL; + +PFNGLDRAWBUFFERSARBPROC __glewDrawBuffersARB = NULL; + +PFNGLBLENDEQUATIONSEPARATEIARBPROC __glewBlendEquationSeparateiARB = NULL; +PFNGLBLENDEQUATIONIARBPROC __glewBlendEquationiARB = NULL; +PFNGLBLENDFUNCSEPARATEIARBPROC __glewBlendFuncSeparateiARB = NULL; +PFNGLBLENDFUNCIARBPROC __glewBlendFunciARB = NULL; + +PFNGLDRAWELEMENTSBASEVERTEXPROC __glewDrawElementsBaseVertex = NULL; +PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC __glewDrawElementsInstancedBaseVertex = NULL; +PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC __glewDrawRangeElementsBaseVertex = NULL; +PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC __glewMultiDrawElementsBaseVertex = NULL; + +PFNGLDRAWARRAYSINDIRECTPROC __glewDrawArraysIndirect = NULL; +PFNGLDRAWELEMENTSINDIRECTPROC __glewDrawElementsIndirect = NULL; + +PFNGLDRAWARRAYSINSTANCEDARBPROC __glewDrawArraysInstancedARB = NULL; +PFNGLDRAWELEMENTSINSTANCEDARBPROC __glewDrawElementsInstancedARB = NULL; + +PFNGLBINDFRAMEBUFFERPROC __glewBindFramebuffer = NULL; +PFNGLBINDRENDERBUFFERPROC __glewBindRenderbuffer = NULL; +PFNGLBLITFRAMEBUFFERPROC __glewBlitFramebuffer = NULL; +PFNGLCHECKFRAMEBUFFERSTATUSPROC __glewCheckFramebufferStatus = NULL; +PFNGLDELETEFRAMEBUFFERSPROC __glewDeleteFramebuffers = NULL; +PFNGLDELETERENDERBUFFERSPROC __glewDeleteRenderbuffers = NULL; +PFNGLFRAMEBUFFERRENDERBUFFERPROC __glewFramebufferRenderbuffer = NULL; +PFNGLFRAMEBUFFERTEXTURE1DPROC __glewFramebufferTexture1D = NULL; +PFNGLFRAMEBUFFERTEXTURE2DPROC __glewFramebufferTexture2D = NULL; +PFNGLFRAMEBUFFERTEXTURE3DPROC __glewFramebufferTexture3D = NULL; +PFNGLFRAMEBUFFERTEXTURELAYERPROC __glewFramebufferTextureLayer = NULL; +PFNGLGENFRAMEBUFFERSPROC __glewGenFramebuffers = NULL; +PFNGLGENRENDERBUFFERSPROC __glewGenRenderbuffers = NULL; +PFNGLGENERATEMIPMAPPROC __glewGenerateMipmap = NULL; +PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC __glewGetFramebufferAttachmentParameteriv = NULL; +PFNGLGETRENDERBUFFERPARAMETERIVPROC __glewGetRenderbufferParameteriv = NULL; +PFNGLISFRAMEBUFFERPROC __glewIsFramebuffer = NULL; +PFNGLISRENDERBUFFERPROC __glewIsRenderbuffer = NULL; +PFNGLRENDERBUFFERSTORAGEPROC __glewRenderbufferStorage = NULL; +PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC __glewRenderbufferStorageMultisample = NULL; + +PFNGLFRAMEBUFFERTEXTUREARBPROC __glewFramebufferTextureARB = NULL; +PFNGLFRAMEBUFFERTEXTUREFACEARBPROC __glewFramebufferTextureFaceARB = NULL; +PFNGLFRAMEBUFFERTEXTURELAYERARBPROC __glewFramebufferTextureLayerARB = NULL; +PFNGLPROGRAMPARAMETERIARBPROC __glewProgramParameteriARB = NULL; + +PFNGLCOLORSUBTABLEPROC __glewColorSubTable = NULL; +PFNGLCOLORTABLEPROC __glewColorTable = NULL; +PFNGLCOLORTABLEPARAMETERFVPROC __glewColorTableParameterfv = NULL; +PFNGLCOLORTABLEPARAMETERIVPROC __glewColorTableParameteriv = NULL; +PFNGLCONVOLUTIONFILTER1DPROC __glewConvolutionFilter1D = NULL; +PFNGLCONVOLUTIONFILTER2DPROC __glewConvolutionFilter2D = NULL; +PFNGLCONVOLUTIONPARAMETERFPROC __glewConvolutionParameterf = NULL; +PFNGLCONVOLUTIONPARAMETERFVPROC __glewConvolutionParameterfv = NULL; +PFNGLCONVOLUTIONPARAMETERIPROC __glewConvolutionParameteri = NULL; +PFNGLCONVOLUTIONPARAMETERIVPROC __glewConvolutionParameteriv = NULL; +PFNGLCOPYCOLORSUBTABLEPROC __glewCopyColorSubTable = NULL; +PFNGLCOPYCOLORTABLEPROC __glewCopyColorTable = NULL; +PFNGLCOPYCONVOLUTIONFILTER1DPROC __glewCopyConvolutionFilter1D = NULL; +PFNGLCOPYCONVOLUTIONFILTER2DPROC __glewCopyConvolutionFilter2D = NULL; +PFNGLGETCOLORTABLEPROC __glewGetColorTable = NULL; +PFNGLGETCOLORTABLEPARAMETERFVPROC __glewGetColorTableParameterfv = NULL; +PFNGLGETCOLORTABLEPARAMETERIVPROC __glewGetColorTableParameteriv = NULL; +PFNGLGETCONVOLUTIONFILTERPROC __glewGetConvolutionFilter = NULL; +PFNGLGETCONVOLUTIONPARAMETERFVPROC __glewGetConvolutionParameterfv = NULL; +PFNGLGETCONVOLUTIONPARAMETERIVPROC __glewGetConvolutionParameteriv = NULL; +PFNGLGETHISTOGRAMPROC __glewGetHistogram = NULL; +PFNGLGETHISTOGRAMPARAMETERFVPROC __glewGetHistogramParameterfv = NULL; +PFNGLGETHISTOGRAMPARAMETERIVPROC __glewGetHistogramParameteriv = NULL; +PFNGLGETMINMAXPROC __glewGetMinmax = NULL; +PFNGLGETMINMAXPARAMETERFVPROC __glewGetMinmaxParameterfv = NULL; +PFNGLGETMINMAXPARAMETERIVPROC __glewGetMinmaxParameteriv = NULL; +PFNGLGETSEPARABLEFILTERPROC __glewGetSeparableFilter = NULL; +PFNGLHISTOGRAMPROC __glewHistogram = NULL; +PFNGLMINMAXPROC __glewMinmax = NULL; +PFNGLRESETHISTOGRAMPROC __glewResetHistogram = NULL; +PFNGLRESETMINMAXPROC __glewResetMinmax = NULL; +PFNGLSEPARABLEFILTER2DPROC __glewSeparableFilter2D = NULL; + +PFNGLVERTEXATTRIBDIVISORARBPROC __glewVertexAttribDivisorARB = NULL; + +PFNGLFLUSHMAPPEDBUFFERRANGEPROC __glewFlushMappedBufferRange = NULL; +PFNGLMAPBUFFERRANGEPROC __glewMapBufferRange = NULL; + +PFNGLCURRENTPALETTEMATRIXARBPROC __glewCurrentPaletteMatrixARB = NULL; +PFNGLMATRIXINDEXPOINTERARBPROC __glewMatrixIndexPointerARB = NULL; +PFNGLMATRIXINDEXUBVARBPROC __glewMatrixIndexubvARB = NULL; +PFNGLMATRIXINDEXUIVARBPROC __glewMatrixIndexuivARB = NULL; +PFNGLMATRIXINDEXUSVARBPROC __glewMatrixIndexusvARB = NULL; + +PFNGLSAMPLECOVERAGEARBPROC __glewSampleCoverageARB = NULL; + +PFNGLACTIVETEXTUREARBPROC __glewActiveTextureARB = NULL; +PFNGLCLIENTACTIVETEXTUREARBPROC __glewClientActiveTextureARB = NULL; +PFNGLMULTITEXCOORD1DARBPROC __glewMultiTexCoord1dARB = NULL; +PFNGLMULTITEXCOORD1DVARBPROC __glewMultiTexCoord1dvARB = NULL; +PFNGLMULTITEXCOORD1FARBPROC __glewMultiTexCoord1fARB = NULL; +PFNGLMULTITEXCOORD1FVARBPROC __glewMultiTexCoord1fvARB = NULL; +PFNGLMULTITEXCOORD1IARBPROC __glewMultiTexCoord1iARB = NULL; +PFNGLMULTITEXCOORD1IVARBPROC __glewMultiTexCoord1ivARB = NULL; +PFNGLMULTITEXCOORD1SARBPROC __glewMultiTexCoord1sARB = NULL; +PFNGLMULTITEXCOORD1SVARBPROC __glewMultiTexCoord1svARB = NULL; +PFNGLMULTITEXCOORD2DARBPROC __glewMultiTexCoord2dARB = NULL; +PFNGLMULTITEXCOORD2DVARBPROC __glewMultiTexCoord2dvARB = NULL; +PFNGLMULTITEXCOORD2FARBPROC __glewMultiTexCoord2fARB = NULL; +PFNGLMULTITEXCOORD2FVARBPROC __glewMultiTexCoord2fvARB = NULL; +PFNGLMULTITEXCOORD2IARBPROC __glewMultiTexCoord2iARB = NULL; +PFNGLMULTITEXCOORD2IVARBPROC __glewMultiTexCoord2ivARB = NULL; +PFNGLMULTITEXCOORD2SARBPROC __glewMultiTexCoord2sARB = NULL; +PFNGLMULTITEXCOORD2SVARBPROC __glewMultiTexCoord2svARB = NULL; +PFNGLMULTITEXCOORD3DARBPROC __glewMultiTexCoord3dARB = NULL; +PFNGLMULTITEXCOORD3DVARBPROC __glewMultiTexCoord3dvARB = NULL; +PFNGLMULTITEXCOORD3FARBPROC __glewMultiTexCoord3fARB = NULL; +PFNGLMULTITEXCOORD3FVARBPROC __glewMultiTexCoord3fvARB = NULL; +PFNGLMULTITEXCOORD3IARBPROC __glewMultiTexCoord3iARB = NULL; +PFNGLMULTITEXCOORD3IVARBPROC __glewMultiTexCoord3ivARB = NULL; +PFNGLMULTITEXCOORD3SARBPROC __glewMultiTexCoord3sARB = NULL; +PFNGLMULTITEXCOORD3SVARBPROC __glewMultiTexCoord3svARB = NULL; +PFNGLMULTITEXCOORD4DARBPROC __glewMultiTexCoord4dARB = NULL; +PFNGLMULTITEXCOORD4DVARBPROC __glewMultiTexCoord4dvARB = NULL; +PFNGLMULTITEXCOORD4FARBPROC __glewMultiTexCoord4fARB = NULL; +PFNGLMULTITEXCOORD4FVARBPROC __glewMultiTexCoord4fvARB = NULL; +PFNGLMULTITEXCOORD4IARBPROC __glewMultiTexCoord4iARB = NULL; +PFNGLMULTITEXCOORD4IVARBPROC __glewMultiTexCoord4ivARB = NULL; +PFNGLMULTITEXCOORD4SARBPROC __glewMultiTexCoord4sARB = NULL; +PFNGLMULTITEXCOORD4SVARBPROC __glewMultiTexCoord4svARB = NULL; + +PFNGLBEGINQUERYARBPROC __glewBeginQueryARB = NULL; +PFNGLDELETEQUERIESARBPROC __glewDeleteQueriesARB = NULL; +PFNGLENDQUERYARBPROC __glewEndQueryARB = NULL; +PFNGLGENQUERIESARBPROC __glewGenQueriesARB = NULL; +PFNGLGETQUERYOBJECTIVARBPROC __glewGetQueryObjectivARB = NULL; +PFNGLGETQUERYOBJECTUIVARBPROC __glewGetQueryObjectuivARB = NULL; +PFNGLGETQUERYIVARBPROC __glewGetQueryivARB = NULL; +PFNGLISQUERYARBPROC __glewIsQueryARB = NULL; + +PFNGLPOINTPARAMETERFARBPROC __glewPointParameterfARB = NULL; +PFNGLPOINTPARAMETERFVARBPROC __glewPointParameterfvARB = NULL; + +PFNGLPROVOKINGVERTEXPROC __glewProvokingVertex = NULL; + +PFNGLMINSAMPLESHADINGARBPROC __glewMinSampleShadingARB = NULL; + +PFNGLBINDSAMPLERPROC __glewBindSampler = NULL; +PFNGLDELETESAMPLERSPROC __glewDeleteSamplers = NULL; +PFNGLGENSAMPLERSPROC __glewGenSamplers = NULL; +PFNGLGETSAMPLERPARAMETERIIVPROC __glewGetSamplerParameterIiv = NULL; +PFNGLGETSAMPLERPARAMETERIUIVPROC __glewGetSamplerParameterIuiv = NULL; +PFNGLGETSAMPLERPARAMETERFVPROC __glewGetSamplerParameterfv = NULL; +PFNGLGETSAMPLERPARAMETERIVPROC __glewGetSamplerParameteriv = NULL; +PFNGLISSAMPLERPROC __glewIsSampler = NULL; +PFNGLSAMPLERPARAMETERIIVPROC __glewSamplerParameterIiv = NULL; +PFNGLSAMPLERPARAMETERIUIVPROC __glewSamplerParameterIuiv = NULL; +PFNGLSAMPLERPARAMETERFPROC __glewSamplerParameterf = NULL; +PFNGLSAMPLERPARAMETERFVPROC __glewSamplerParameterfv = NULL; +PFNGLSAMPLERPARAMETERIPROC __glewSamplerParameteri = NULL; +PFNGLSAMPLERPARAMETERIVPROC __glewSamplerParameteriv = NULL; + +PFNGLATTACHOBJECTARBPROC __glewAttachObjectARB = NULL; +PFNGLCOMPILESHADERARBPROC __glewCompileShaderARB = NULL; +PFNGLCREATEPROGRAMOBJECTARBPROC __glewCreateProgramObjectARB = NULL; +PFNGLCREATESHADEROBJECTARBPROC __glewCreateShaderObjectARB = NULL; +PFNGLDELETEOBJECTARBPROC __glewDeleteObjectARB = NULL; +PFNGLDETACHOBJECTARBPROC __glewDetachObjectARB = NULL; +PFNGLGETACTIVEUNIFORMARBPROC __glewGetActiveUniformARB = NULL; +PFNGLGETATTACHEDOBJECTSARBPROC __glewGetAttachedObjectsARB = NULL; +PFNGLGETHANDLEARBPROC __glewGetHandleARB = NULL; +PFNGLGETINFOLOGARBPROC __glewGetInfoLogARB = NULL; +PFNGLGETOBJECTPARAMETERFVARBPROC __glewGetObjectParameterfvARB = NULL; +PFNGLGETOBJECTPARAMETERIVARBPROC __glewGetObjectParameterivARB = NULL; +PFNGLGETSHADERSOURCEARBPROC __glewGetShaderSourceARB = NULL; +PFNGLGETUNIFORMLOCATIONARBPROC __glewGetUniformLocationARB = NULL; +PFNGLGETUNIFORMFVARBPROC __glewGetUniformfvARB = NULL; +PFNGLGETUNIFORMIVARBPROC __glewGetUniformivARB = NULL; +PFNGLLINKPROGRAMARBPROC __glewLinkProgramARB = NULL; +PFNGLSHADERSOURCEARBPROC __glewShaderSourceARB = NULL; +PFNGLUNIFORM1FARBPROC __glewUniform1fARB = NULL; +PFNGLUNIFORM1FVARBPROC __glewUniform1fvARB = NULL; +PFNGLUNIFORM1IARBPROC __glewUniform1iARB = NULL; +PFNGLUNIFORM1IVARBPROC __glewUniform1ivARB = NULL; +PFNGLUNIFORM2FARBPROC __glewUniform2fARB = NULL; +PFNGLUNIFORM2FVARBPROC __glewUniform2fvARB = NULL; +PFNGLUNIFORM2IARBPROC __glewUniform2iARB = NULL; +PFNGLUNIFORM2IVARBPROC __glewUniform2ivARB = NULL; +PFNGLUNIFORM3FARBPROC __glewUniform3fARB = NULL; +PFNGLUNIFORM3FVARBPROC __glewUniform3fvARB = NULL; +PFNGLUNIFORM3IARBPROC __glewUniform3iARB = NULL; +PFNGLUNIFORM3IVARBPROC __glewUniform3ivARB = NULL; +PFNGLUNIFORM4FARBPROC __glewUniform4fARB = NULL; +PFNGLUNIFORM4FVARBPROC __glewUniform4fvARB = NULL; +PFNGLUNIFORM4IARBPROC __glewUniform4iARB = NULL; +PFNGLUNIFORM4IVARBPROC __glewUniform4ivARB = NULL; +PFNGLUNIFORMMATRIX2FVARBPROC __glewUniformMatrix2fvARB = NULL; +PFNGLUNIFORMMATRIX3FVARBPROC __glewUniformMatrix3fvARB = NULL; +PFNGLUNIFORMMATRIX4FVARBPROC __glewUniformMatrix4fvARB = NULL; +PFNGLUSEPROGRAMOBJECTARBPROC __glewUseProgramObjectARB = NULL; +PFNGLVALIDATEPROGRAMARBPROC __glewValidateProgramARB = NULL; + +PFNGLGETACTIVESUBROUTINENAMEPROC __glewGetActiveSubroutineName = NULL; +PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC __glewGetActiveSubroutineUniformName = NULL; +PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC __glewGetActiveSubroutineUniformiv = NULL; +PFNGLGETPROGRAMSTAGEIVPROC __glewGetProgramStageiv = NULL; +PFNGLGETSUBROUTINEINDEXPROC __glewGetSubroutineIndex = NULL; +PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC __glewGetSubroutineUniformLocation = NULL; +PFNGLGETUNIFORMSUBROUTINEUIVPROC __glewGetUniformSubroutineuiv = NULL; +PFNGLUNIFORMSUBROUTINESUIVPROC __glewUniformSubroutinesuiv = NULL; + +PFNGLCOMPILESHADERINCLUDEARBPROC __glewCompileShaderIncludeARB = NULL; +PFNGLDELETENAMEDSTRINGARBPROC __glewDeleteNamedStringARB = NULL; +PFNGLGETNAMEDSTRINGARBPROC __glewGetNamedStringARB = NULL; +PFNGLGETNAMEDSTRINGIVARBPROC __glewGetNamedStringivARB = NULL; +PFNGLISNAMEDSTRINGARBPROC __glewIsNamedStringARB = NULL; +PFNGLNAMEDSTRINGARBPROC __glewNamedStringARB = NULL; + +PFNGLCLIENTWAITSYNCPROC __glewClientWaitSync = NULL; +PFNGLDELETESYNCPROC __glewDeleteSync = NULL; +PFNGLFENCESYNCPROC __glewFenceSync = NULL; +PFNGLGETINTEGER64VPROC __glewGetInteger64v = NULL; +PFNGLGETSYNCIVPROC __glewGetSynciv = NULL; +PFNGLISSYNCPROC __glewIsSync = NULL; +PFNGLWAITSYNCPROC __glewWaitSync = NULL; + +PFNGLPATCHPARAMETERFVPROC __glewPatchParameterfv = NULL; +PFNGLPATCHPARAMETERIPROC __glewPatchParameteri = NULL; + +PFNGLTEXBUFFERARBPROC __glewTexBufferARB = NULL; + +PFNGLCOMPRESSEDTEXIMAGE1DARBPROC __glewCompressedTexImage1DARB = NULL; +PFNGLCOMPRESSEDTEXIMAGE2DARBPROC __glewCompressedTexImage2DARB = NULL; +PFNGLCOMPRESSEDTEXIMAGE3DARBPROC __glewCompressedTexImage3DARB = NULL; +PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC __glewCompressedTexSubImage1DARB = NULL; +PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC __glewCompressedTexSubImage2DARB = NULL; +PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC __glewCompressedTexSubImage3DARB = NULL; +PFNGLGETCOMPRESSEDTEXIMAGEARBPROC __glewGetCompressedTexImageARB = NULL; + +PFNGLGETMULTISAMPLEFVPROC __glewGetMultisamplefv = NULL; +PFNGLSAMPLEMASKIPROC __glewSampleMaski = NULL; +PFNGLTEXIMAGE2DMULTISAMPLEPROC __glewTexImage2DMultisample = NULL; +PFNGLTEXIMAGE3DMULTISAMPLEPROC __glewTexImage3DMultisample = NULL; + +PFNGLGETQUERYOBJECTI64VPROC __glewGetQueryObjecti64v = NULL; +PFNGLGETQUERYOBJECTUI64VPROC __glewGetQueryObjectui64v = NULL; +PFNGLQUERYCOUNTERPROC __glewQueryCounter = NULL; + +PFNGLBINDTRANSFORMFEEDBACKPROC __glewBindTransformFeedback = NULL; +PFNGLDELETETRANSFORMFEEDBACKSPROC __glewDeleteTransformFeedbacks = NULL; +PFNGLDRAWTRANSFORMFEEDBACKPROC __glewDrawTransformFeedback = NULL; +PFNGLGENTRANSFORMFEEDBACKSPROC __glewGenTransformFeedbacks = NULL; +PFNGLISTRANSFORMFEEDBACKPROC __glewIsTransformFeedback = NULL; +PFNGLPAUSETRANSFORMFEEDBACKPROC __glewPauseTransformFeedback = NULL; +PFNGLRESUMETRANSFORMFEEDBACKPROC __glewResumeTransformFeedback = NULL; + +PFNGLBEGINQUERYINDEXEDPROC __glewBeginQueryIndexed = NULL; +PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC __glewDrawTransformFeedbackStream = NULL; +PFNGLENDQUERYINDEXEDPROC __glewEndQueryIndexed = NULL; +PFNGLGETQUERYINDEXEDIVPROC __glewGetQueryIndexediv = NULL; + +PFNGLLOADTRANSPOSEMATRIXDARBPROC __glewLoadTransposeMatrixdARB = NULL; +PFNGLLOADTRANSPOSEMATRIXFARBPROC __glewLoadTransposeMatrixfARB = NULL; +PFNGLMULTTRANSPOSEMATRIXDARBPROC __glewMultTransposeMatrixdARB = NULL; +PFNGLMULTTRANSPOSEMATRIXFARBPROC __glewMultTransposeMatrixfARB = NULL; + +PFNGLBINDBUFFERBASEPROC __glewBindBufferBase = NULL; +PFNGLBINDBUFFERRANGEPROC __glewBindBufferRange = NULL; +PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC __glewGetActiveUniformBlockName = NULL; +PFNGLGETACTIVEUNIFORMBLOCKIVPROC __glewGetActiveUniformBlockiv = NULL; +PFNGLGETACTIVEUNIFORMNAMEPROC __glewGetActiveUniformName = NULL; +PFNGLGETACTIVEUNIFORMSIVPROC __glewGetActiveUniformsiv = NULL; +PFNGLGETINTEGERI_VPROC __glewGetIntegeri_v = NULL; +PFNGLGETUNIFORMBLOCKINDEXPROC __glewGetUniformBlockIndex = NULL; +PFNGLGETUNIFORMINDICESPROC __glewGetUniformIndices = NULL; +PFNGLUNIFORMBLOCKBINDINGPROC __glewUniformBlockBinding = NULL; + +PFNGLBINDVERTEXARRAYPROC __glewBindVertexArray = NULL; +PFNGLDELETEVERTEXARRAYSPROC __glewDeleteVertexArrays = NULL; +PFNGLGENVERTEXARRAYSPROC __glewGenVertexArrays = NULL; +PFNGLISVERTEXARRAYPROC __glewIsVertexArray = NULL; + +PFNGLVERTEXBLENDARBPROC __glewVertexBlendARB = NULL; +PFNGLWEIGHTPOINTERARBPROC __glewWeightPointerARB = NULL; +PFNGLWEIGHTBVARBPROC __glewWeightbvARB = NULL; +PFNGLWEIGHTDVARBPROC __glewWeightdvARB = NULL; +PFNGLWEIGHTFVARBPROC __glewWeightfvARB = NULL; +PFNGLWEIGHTIVARBPROC __glewWeightivARB = NULL; +PFNGLWEIGHTSVARBPROC __glewWeightsvARB = NULL; +PFNGLWEIGHTUBVARBPROC __glewWeightubvARB = NULL; +PFNGLWEIGHTUIVARBPROC __glewWeightuivARB = NULL; +PFNGLWEIGHTUSVARBPROC __glewWeightusvARB = NULL; + +PFNGLBINDBUFFERARBPROC __glewBindBufferARB = NULL; +PFNGLBUFFERDATAARBPROC __glewBufferDataARB = NULL; +PFNGLBUFFERSUBDATAARBPROC __glewBufferSubDataARB = NULL; +PFNGLDELETEBUFFERSARBPROC __glewDeleteBuffersARB = NULL; +PFNGLGENBUFFERSARBPROC __glewGenBuffersARB = NULL; +PFNGLGETBUFFERPARAMETERIVARBPROC __glewGetBufferParameterivARB = NULL; +PFNGLGETBUFFERPOINTERVARBPROC __glewGetBufferPointervARB = NULL; +PFNGLGETBUFFERSUBDATAARBPROC __glewGetBufferSubDataARB = NULL; +PFNGLISBUFFERARBPROC __glewIsBufferARB = NULL; +PFNGLMAPBUFFERARBPROC __glewMapBufferARB = NULL; +PFNGLUNMAPBUFFERARBPROC __glewUnmapBufferARB = NULL; + +PFNGLBINDPROGRAMARBPROC __glewBindProgramARB = NULL; +PFNGLDELETEPROGRAMSARBPROC __glewDeleteProgramsARB = NULL; +PFNGLDISABLEVERTEXATTRIBARRAYARBPROC __glewDisableVertexAttribArrayARB = NULL; +PFNGLENABLEVERTEXATTRIBARRAYARBPROC __glewEnableVertexAttribArrayARB = NULL; +PFNGLGENPROGRAMSARBPROC __glewGenProgramsARB = NULL; +PFNGLGETPROGRAMENVPARAMETERDVARBPROC __glewGetProgramEnvParameterdvARB = NULL; +PFNGLGETPROGRAMENVPARAMETERFVARBPROC __glewGetProgramEnvParameterfvARB = NULL; +PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC __glewGetProgramLocalParameterdvARB = NULL; +PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC __glewGetProgramLocalParameterfvARB = NULL; +PFNGLGETPROGRAMSTRINGARBPROC __glewGetProgramStringARB = NULL; +PFNGLGETPROGRAMIVARBPROC __glewGetProgramivARB = NULL; +PFNGLGETVERTEXATTRIBPOINTERVARBPROC __glewGetVertexAttribPointervARB = NULL; +PFNGLGETVERTEXATTRIBDVARBPROC __glewGetVertexAttribdvARB = NULL; +PFNGLGETVERTEXATTRIBFVARBPROC __glewGetVertexAttribfvARB = NULL; +PFNGLGETVERTEXATTRIBIVARBPROC __glewGetVertexAttribivARB = NULL; +PFNGLISPROGRAMARBPROC __glewIsProgramARB = NULL; +PFNGLPROGRAMENVPARAMETER4DARBPROC __glewProgramEnvParameter4dARB = NULL; +PFNGLPROGRAMENVPARAMETER4DVARBPROC __glewProgramEnvParameter4dvARB = NULL; +PFNGLPROGRAMENVPARAMETER4FARBPROC __glewProgramEnvParameter4fARB = NULL; +PFNGLPROGRAMENVPARAMETER4FVARBPROC __glewProgramEnvParameter4fvARB = NULL; +PFNGLPROGRAMLOCALPARAMETER4DARBPROC __glewProgramLocalParameter4dARB = NULL; +PFNGLPROGRAMLOCALPARAMETER4DVARBPROC __glewProgramLocalParameter4dvARB = NULL; +PFNGLPROGRAMLOCALPARAMETER4FARBPROC __glewProgramLocalParameter4fARB = NULL; +PFNGLPROGRAMLOCALPARAMETER4FVARBPROC __glewProgramLocalParameter4fvARB = NULL; +PFNGLPROGRAMSTRINGARBPROC __glewProgramStringARB = NULL; +PFNGLVERTEXATTRIB1DARBPROC __glewVertexAttrib1dARB = NULL; +PFNGLVERTEXATTRIB1DVARBPROC __glewVertexAttrib1dvARB = NULL; +PFNGLVERTEXATTRIB1FARBPROC __glewVertexAttrib1fARB = NULL; +PFNGLVERTEXATTRIB1FVARBPROC __glewVertexAttrib1fvARB = NULL; +PFNGLVERTEXATTRIB1SARBPROC __glewVertexAttrib1sARB = NULL; +PFNGLVERTEXATTRIB1SVARBPROC __glewVertexAttrib1svARB = NULL; +PFNGLVERTEXATTRIB2DARBPROC __glewVertexAttrib2dARB = NULL; +PFNGLVERTEXATTRIB2DVARBPROC __glewVertexAttrib2dvARB = NULL; +PFNGLVERTEXATTRIB2FARBPROC __glewVertexAttrib2fARB = NULL; +PFNGLVERTEXATTRIB2FVARBPROC __glewVertexAttrib2fvARB = NULL; +PFNGLVERTEXATTRIB2SARBPROC __glewVertexAttrib2sARB = NULL; +PFNGLVERTEXATTRIB2SVARBPROC __glewVertexAttrib2svARB = NULL; +PFNGLVERTEXATTRIB3DARBPROC __glewVertexAttrib3dARB = NULL; +PFNGLVERTEXATTRIB3DVARBPROC __glewVertexAttrib3dvARB = NULL; +PFNGLVERTEXATTRIB3FARBPROC __glewVertexAttrib3fARB = NULL; +PFNGLVERTEXATTRIB3FVARBPROC __glewVertexAttrib3fvARB = NULL; +PFNGLVERTEXATTRIB3SARBPROC __glewVertexAttrib3sARB = NULL; +PFNGLVERTEXATTRIB3SVARBPROC __glewVertexAttrib3svARB = NULL; +PFNGLVERTEXATTRIB4NBVARBPROC __glewVertexAttrib4NbvARB = NULL; +PFNGLVERTEXATTRIB4NIVARBPROC __glewVertexAttrib4NivARB = NULL; +PFNGLVERTEXATTRIB4NSVARBPROC __glewVertexAttrib4NsvARB = NULL; +PFNGLVERTEXATTRIB4NUBARBPROC __glewVertexAttrib4NubARB = NULL; +PFNGLVERTEXATTRIB4NUBVARBPROC __glewVertexAttrib4NubvARB = NULL; +PFNGLVERTEXATTRIB4NUIVARBPROC __glewVertexAttrib4NuivARB = NULL; +PFNGLVERTEXATTRIB4NUSVARBPROC __glewVertexAttrib4NusvARB = NULL; +PFNGLVERTEXATTRIB4BVARBPROC __glewVertexAttrib4bvARB = NULL; +PFNGLVERTEXATTRIB4DARBPROC __glewVertexAttrib4dARB = NULL; +PFNGLVERTEXATTRIB4DVARBPROC __glewVertexAttrib4dvARB = NULL; +PFNGLVERTEXATTRIB4FARBPROC __glewVertexAttrib4fARB = NULL; +PFNGLVERTEXATTRIB4FVARBPROC __glewVertexAttrib4fvARB = NULL; +PFNGLVERTEXATTRIB4IVARBPROC __glewVertexAttrib4ivARB = NULL; +PFNGLVERTEXATTRIB4SARBPROC __glewVertexAttrib4sARB = NULL; +PFNGLVERTEXATTRIB4SVARBPROC __glewVertexAttrib4svARB = NULL; +PFNGLVERTEXATTRIB4UBVARBPROC __glewVertexAttrib4ubvARB = NULL; +PFNGLVERTEXATTRIB4UIVARBPROC __glewVertexAttrib4uivARB = NULL; +PFNGLVERTEXATTRIB4USVARBPROC __glewVertexAttrib4usvARB = NULL; +PFNGLVERTEXATTRIBPOINTERARBPROC __glewVertexAttribPointerARB = NULL; + +PFNGLBINDATTRIBLOCATIONARBPROC __glewBindAttribLocationARB = NULL; +PFNGLGETACTIVEATTRIBARBPROC __glewGetActiveAttribARB = NULL; +PFNGLGETATTRIBLOCATIONARBPROC __glewGetAttribLocationARB = NULL; + +PFNGLCOLORP3UIPROC __glewColorP3ui = NULL; +PFNGLCOLORP3UIVPROC __glewColorP3uiv = NULL; +PFNGLCOLORP4UIPROC __glewColorP4ui = NULL; +PFNGLCOLORP4UIVPROC __glewColorP4uiv = NULL; +PFNGLMULTITEXCOORDP1UIPROC __glewMultiTexCoordP1ui = NULL; +PFNGLMULTITEXCOORDP1UIVPROC __glewMultiTexCoordP1uiv = NULL; +PFNGLMULTITEXCOORDP2UIPROC __glewMultiTexCoordP2ui = NULL; +PFNGLMULTITEXCOORDP2UIVPROC __glewMultiTexCoordP2uiv = NULL; +PFNGLMULTITEXCOORDP3UIPROC __glewMultiTexCoordP3ui = NULL; +PFNGLMULTITEXCOORDP3UIVPROC __glewMultiTexCoordP3uiv = NULL; +PFNGLMULTITEXCOORDP4UIPROC __glewMultiTexCoordP4ui = NULL; +PFNGLMULTITEXCOORDP4UIVPROC __glewMultiTexCoordP4uiv = NULL; +PFNGLNORMALP3UIPROC __glewNormalP3ui = NULL; +PFNGLNORMALP3UIVPROC __glewNormalP3uiv = NULL; +PFNGLSECONDARYCOLORP3UIPROC __glewSecondaryColorP3ui = NULL; +PFNGLSECONDARYCOLORP3UIVPROC __glewSecondaryColorP3uiv = NULL; +PFNGLTEXCOORDP1UIPROC __glewTexCoordP1ui = NULL; +PFNGLTEXCOORDP1UIVPROC __glewTexCoordP1uiv = NULL; +PFNGLTEXCOORDP2UIPROC __glewTexCoordP2ui = NULL; +PFNGLTEXCOORDP2UIVPROC __glewTexCoordP2uiv = NULL; +PFNGLTEXCOORDP3UIPROC __glewTexCoordP3ui = NULL; +PFNGLTEXCOORDP3UIVPROC __glewTexCoordP3uiv = NULL; +PFNGLTEXCOORDP4UIPROC __glewTexCoordP4ui = NULL; +PFNGLTEXCOORDP4UIVPROC __glewTexCoordP4uiv = NULL; +PFNGLVERTEXATTRIBP1UIPROC __glewVertexAttribP1ui = NULL; +PFNGLVERTEXATTRIBP1UIVPROC __glewVertexAttribP1uiv = NULL; +PFNGLVERTEXATTRIBP2UIPROC __glewVertexAttribP2ui = NULL; +PFNGLVERTEXATTRIBP2UIVPROC __glewVertexAttribP2uiv = NULL; +PFNGLVERTEXATTRIBP3UIPROC __glewVertexAttribP3ui = NULL; +PFNGLVERTEXATTRIBP3UIVPROC __glewVertexAttribP3uiv = NULL; +PFNGLVERTEXATTRIBP4UIPROC __glewVertexAttribP4ui = NULL; +PFNGLVERTEXATTRIBP4UIVPROC __glewVertexAttribP4uiv = NULL; +PFNGLVERTEXP2UIPROC __glewVertexP2ui = NULL; +PFNGLVERTEXP2UIVPROC __glewVertexP2uiv = NULL; +PFNGLVERTEXP3UIPROC __glewVertexP3ui = NULL; +PFNGLVERTEXP3UIVPROC __glewVertexP3uiv = NULL; +PFNGLVERTEXP4UIPROC __glewVertexP4ui = NULL; +PFNGLVERTEXP4UIVPROC __glewVertexP4uiv = NULL; + +PFNGLWINDOWPOS2DARBPROC __glewWindowPos2dARB = NULL; +PFNGLWINDOWPOS2DVARBPROC __glewWindowPos2dvARB = NULL; +PFNGLWINDOWPOS2FARBPROC __glewWindowPos2fARB = NULL; +PFNGLWINDOWPOS2FVARBPROC __glewWindowPos2fvARB = NULL; +PFNGLWINDOWPOS2IARBPROC __glewWindowPos2iARB = NULL; +PFNGLWINDOWPOS2IVARBPROC __glewWindowPos2ivARB = NULL; +PFNGLWINDOWPOS2SARBPROC __glewWindowPos2sARB = NULL; +PFNGLWINDOWPOS2SVARBPROC __glewWindowPos2svARB = NULL; +PFNGLWINDOWPOS3DARBPROC __glewWindowPos3dARB = NULL; +PFNGLWINDOWPOS3DVARBPROC __glewWindowPos3dvARB = NULL; +PFNGLWINDOWPOS3FARBPROC __glewWindowPos3fARB = NULL; +PFNGLWINDOWPOS3FVARBPROC __glewWindowPos3fvARB = NULL; +PFNGLWINDOWPOS3IARBPROC __glewWindowPos3iARB = NULL; +PFNGLWINDOWPOS3IVARBPROC __glewWindowPos3ivARB = NULL; +PFNGLWINDOWPOS3SARBPROC __glewWindowPos3sARB = NULL; +PFNGLWINDOWPOS3SVARBPROC __glewWindowPos3svARB = NULL; + +PFNGLDRAWBUFFERSATIPROC __glewDrawBuffersATI = NULL; + +PFNGLDRAWELEMENTARRAYATIPROC __glewDrawElementArrayATI = NULL; +PFNGLDRAWRANGEELEMENTARRAYATIPROC __glewDrawRangeElementArrayATI = NULL; +PFNGLELEMENTPOINTERATIPROC __glewElementPointerATI = NULL; + +PFNGLGETTEXBUMPPARAMETERFVATIPROC __glewGetTexBumpParameterfvATI = NULL; +PFNGLGETTEXBUMPPARAMETERIVATIPROC __glewGetTexBumpParameterivATI = NULL; +PFNGLTEXBUMPPARAMETERFVATIPROC __glewTexBumpParameterfvATI = NULL; +PFNGLTEXBUMPPARAMETERIVATIPROC __glewTexBumpParameterivATI = NULL; + +PFNGLALPHAFRAGMENTOP1ATIPROC __glewAlphaFragmentOp1ATI = NULL; +PFNGLALPHAFRAGMENTOP2ATIPROC __glewAlphaFragmentOp2ATI = NULL; +PFNGLALPHAFRAGMENTOP3ATIPROC __glewAlphaFragmentOp3ATI = NULL; +PFNGLBEGINFRAGMENTSHADERATIPROC __glewBeginFragmentShaderATI = NULL; +PFNGLBINDFRAGMENTSHADERATIPROC __glewBindFragmentShaderATI = NULL; +PFNGLCOLORFRAGMENTOP1ATIPROC __glewColorFragmentOp1ATI = NULL; +PFNGLCOLORFRAGMENTOP2ATIPROC __glewColorFragmentOp2ATI = NULL; +PFNGLCOLORFRAGMENTOP3ATIPROC __glewColorFragmentOp3ATI = NULL; +PFNGLDELETEFRAGMENTSHADERATIPROC __glewDeleteFragmentShaderATI = NULL; +PFNGLENDFRAGMENTSHADERATIPROC __glewEndFragmentShaderATI = NULL; +PFNGLGENFRAGMENTSHADERSATIPROC __glewGenFragmentShadersATI = NULL; +PFNGLPASSTEXCOORDATIPROC __glewPassTexCoordATI = NULL; +PFNGLSAMPLEMAPATIPROC __glewSampleMapATI = NULL; +PFNGLSETFRAGMENTSHADERCONSTANTATIPROC __glewSetFragmentShaderConstantATI = NULL; + +PFNGLMAPOBJECTBUFFERATIPROC __glewMapObjectBufferATI = NULL; +PFNGLUNMAPOBJECTBUFFERATIPROC __glewUnmapObjectBufferATI = NULL; + +PFNGLPNTRIANGLESFATIPROC __glPNTrianglewesfATI = NULL; +PFNGLPNTRIANGLESIATIPROC __glPNTrianglewesiATI = NULL; + +PFNGLSTENCILFUNCSEPARATEATIPROC __glewStencilFuncSeparateATI = NULL; +PFNGLSTENCILOPSEPARATEATIPROC __glewStencilOpSeparateATI = NULL; + +PFNGLARRAYOBJECTATIPROC __glewArrayObjectATI = NULL; +PFNGLFREEOBJECTBUFFERATIPROC __glewFreeObjectBufferATI = NULL; +PFNGLGETARRAYOBJECTFVATIPROC __glewGetArrayObjectfvATI = NULL; +PFNGLGETARRAYOBJECTIVATIPROC __glewGetArrayObjectivATI = NULL; +PFNGLGETOBJECTBUFFERFVATIPROC __glewGetObjectBufferfvATI = NULL; +PFNGLGETOBJECTBUFFERIVATIPROC __glewGetObjectBufferivATI = NULL; +PFNGLGETVARIANTARRAYOBJECTFVATIPROC __glewGetVariantArrayObjectfvATI = NULL; +PFNGLGETVARIANTARRAYOBJECTIVATIPROC __glewGetVariantArrayObjectivATI = NULL; +PFNGLISOBJECTBUFFERATIPROC __glewIsObjectBufferATI = NULL; +PFNGLNEWOBJECTBUFFERATIPROC __glewNewObjectBufferATI = NULL; +PFNGLUPDATEOBJECTBUFFERATIPROC __glewUpdateObjectBufferATI = NULL; +PFNGLVARIANTARRAYOBJECTATIPROC __glewVariantArrayObjectATI = NULL; + +PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC __glewGetVertexAttribArrayObjectfvATI = NULL; +PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC __glewGetVertexAttribArrayObjectivATI = NULL; +PFNGLVERTEXATTRIBARRAYOBJECTATIPROC __glewVertexAttribArrayObjectATI = NULL; + +PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC __glewClientActiveVertexStreamATI = NULL; +PFNGLNORMALSTREAM3BATIPROC __glewNormalStream3bATI = NULL; +PFNGLNORMALSTREAM3BVATIPROC __glewNormalStream3bvATI = NULL; +PFNGLNORMALSTREAM3DATIPROC __glewNormalStream3dATI = NULL; +PFNGLNORMALSTREAM3DVATIPROC __glewNormalStream3dvATI = NULL; +PFNGLNORMALSTREAM3FATIPROC __glewNormalStream3fATI = NULL; +PFNGLNORMALSTREAM3FVATIPROC __glewNormalStream3fvATI = NULL; +PFNGLNORMALSTREAM3IATIPROC __glewNormalStream3iATI = NULL; +PFNGLNORMALSTREAM3IVATIPROC __glewNormalStream3ivATI = NULL; +PFNGLNORMALSTREAM3SATIPROC __glewNormalStream3sATI = NULL; +PFNGLNORMALSTREAM3SVATIPROC __glewNormalStream3svATI = NULL; +PFNGLVERTEXBLENDENVFATIPROC __glewVertexBlendEnvfATI = NULL; +PFNGLVERTEXBLENDENVIATIPROC __glewVertexBlendEnviATI = NULL; +PFNGLVERTEXSTREAM2DATIPROC __glewVertexStream2dATI = NULL; +PFNGLVERTEXSTREAM2DVATIPROC __glewVertexStream2dvATI = NULL; +PFNGLVERTEXSTREAM2FATIPROC __glewVertexStream2fATI = NULL; +PFNGLVERTEXSTREAM2FVATIPROC __glewVertexStream2fvATI = NULL; +PFNGLVERTEXSTREAM2IATIPROC __glewVertexStream2iATI = NULL; +PFNGLVERTEXSTREAM2IVATIPROC __glewVertexStream2ivATI = NULL; +PFNGLVERTEXSTREAM2SATIPROC __glewVertexStream2sATI = NULL; +PFNGLVERTEXSTREAM2SVATIPROC __glewVertexStream2svATI = NULL; +PFNGLVERTEXSTREAM3DATIPROC __glewVertexStream3dATI = NULL; +PFNGLVERTEXSTREAM3DVATIPROC __glewVertexStream3dvATI = NULL; +PFNGLVERTEXSTREAM3FATIPROC __glewVertexStream3fATI = NULL; +PFNGLVERTEXSTREAM3FVATIPROC __glewVertexStream3fvATI = NULL; +PFNGLVERTEXSTREAM3IATIPROC __glewVertexStream3iATI = NULL; +PFNGLVERTEXSTREAM3IVATIPROC __glewVertexStream3ivATI = NULL; +PFNGLVERTEXSTREAM3SATIPROC __glewVertexStream3sATI = NULL; +PFNGLVERTEXSTREAM3SVATIPROC __glewVertexStream3svATI = NULL; +PFNGLVERTEXSTREAM4DATIPROC __glewVertexStream4dATI = NULL; +PFNGLVERTEXSTREAM4DVATIPROC __glewVertexStream4dvATI = NULL; +PFNGLVERTEXSTREAM4FATIPROC __glewVertexStream4fATI = NULL; +PFNGLVERTEXSTREAM4FVATIPROC __glewVertexStream4fvATI = NULL; +PFNGLVERTEXSTREAM4IATIPROC __glewVertexStream4iATI = NULL; +PFNGLVERTEXSTREAM4IVATIPROC __glewVertexStream4ivATI = NULL; +PFNGLVERTEXSTREAM4SATIPROC __glewVertexStream4sATI = NULL; +PFNGLVERTEXSTREAM4SVATIPROC __glewVertexStream4svATI = NULL; + +PFNGLGETUNIFORMBUFFERSIZEEXTPROC __glewGetUniformBufferSizeEXT = NULL; +PFNGLGETUNIFORMOFFSETEXTPROC __glewGetUniformOffsetEXT = NULL; +PFNGLUNIFORMBUFFEREXTPROC __glewUniformBufferEXT = NULL; + +PFNGLBLENDCOLOREXTPROC __glewBlendColorEXT = NULL; + +PFNGLBLENDEQUATIONSEPARATEEXTPROC __glewBlendEquationSeparateEXT = NULL; + +PFNGLBLENDFUNCSEPARATEEXTPROC __glewBlendFuncSeparateEXT = NULL; + +PFNGLBLENDEQUATIONEXTPROC __glewBlendEquationEXT = NULL; + +PFNGLCOLORSUBTABLEEXTPROC __glewColorSubTableEXT = NULL; +PFNGLCOPYCOLORSUBTABLEEXTPROC __glewCopyColorSubTableEXT = NULL; + +PFNGLLOCKARRAYSEXTPROC __glewLockArraysEXT = NULL; +PFNGLUNLOCKARRAYSEXTPROC __glewUnlockArraysEXT = NULL; + +PFNGLCONVOLUTIONFILTER1DEXTPROC __glewConvolutionFilter1DEXT = NULL; +PFNGLCONVOLUTIONFILTER2DEXTPROC __glewConvolutionFilter2DEXT = NULL; +PFNGLCONVOLUTIONPARAMETERFEXTPROC __glewConvolutionParameterfEXT = NULL; +PFNGLCONVOLUTIONPARAMETERFVEXTPROC __glewConvolutionParameterfvEXT = NULL; +PFNGLCONVOLUTIONPARAMETERIEXTPROC __glewConvolutionParameteriEXT = NULL; +PFNGLCONVOLUTIONPARAMETERIVEXTPROC __glewConvolutionParameterivEXT = NULL; +PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC __glewCopyConvolutionFilter1DEXT = NULL; +PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC __glewCopyConvolutionFilter2DEXT = NULL; +PFNGLGETCONVOLUTIONFILTEREXTPROC __glewGetConvolutionFilterEXT = NULL; +PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC __glewGetConvolutionParameterfvEXT = NULL; +PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC __glewGetConvolutionParameterivEXT = NULL; +PFNGLGETSEPARABLEFILTEREXTPROC __glewGetSeparableFilterEXT = NULL; +PFNGLSEPARABLEFILTER2DEXTPROC __glewSeparableFilter2DEXT = NULL; + +PFNGLBINORMALPOINTEREXTPROC __glewBinormalPointerEXT = NULL; +PFNGLTANGENTPOINTEREXTPROC __glewTangentPointerEXT = NULL; + +PFNGLCOPYTEXIMAGE1DEXTPROC __glewCopyTexImage1DEXT = NULL; +PFNGLCOPYTEXIMAGE2DEXTPROC __glewCopyTexImage2DEXT = NULL; +PFNGLCOPYTEXSUBIMAGE1DEXTPROC __glewCopyTexSubImage1DEXT = NULL; +PFNGLCOPYTEXSUBIMAGE2DEXTPROC __glewCopyTexSubImage2DEXT = NULL; +PFNGLCOPYTEXSUBIMAGE3DEXTPROC __glewCopyTexSubImage3DEXT = NULL; + +PFNGLCULLPARAMETERDVEXTPROC __glewCullParameterdvEXT = NULL; +PFNGLCULLPARAMETERFVEXTPROC __glewCullParameterfvEXT = NULL; + +PFNGLDEPTHBOUNDSEXTPROC __glewDepthBoundsEXT = NULL; + +PFNGLBINDMULTITEXTUREEXTPROC __glewBindMultiTextureEXT = NULL; +PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC __glewCheckNamedFramebufferStatusEXT = NULL; +PFNGLCLIENTATTRIBDEFAULTEXTPROC __glewClientAttribDefaultEXT = NULL; +PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC __glewCompressedMultiTexImage1DEXT = NULL; +PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC __glewCompressedMultiTexImage2DEXT = NULL; +PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC __glewCompressedMultiTexImage3DEXT = NULL; +PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC __glewCompressedMultiTexSubImage1DEXT = NULL; +PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC __glewCompressedMultiTexSubImage2DEXT = NULL; +PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC __glewCompressedMultiTexSubImage3DEXT = NULL; +PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC __glewCompressedTextureImage1DEXT = NULL; +PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC __glewCompressedTextureImage2DEXT = NULL; +PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC __glewCompressedTextureImage3DEXT = NULL; +PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC __glewCompressedTextureSubImage1DEXT = NULL; +PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC __glewCompressedTextureSubImage2DEXT = NULL; +PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC __glewCompressedTextureSubImage3DEXT = NULL; +PFNGLCOPYMULTITEXIMAGE1DEXTPROC __glewCopyMultiTexImage1DEXT = NULL; +PFNGLCOPYMULTITEXIMAGE2DEXTPROC __glewCopyMultiTexImage2DEXT = NULL; +PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC __glewCopyMultiTexSubImage1DEXT = NULL; +PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC __glewCopyMultiTexSubImage2DEXT = NULL; +PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC __glewCopyMultiTexSubImage3DEXT = NULL; +PFNGLCOPYTEXTUREIMAGE1DEXTPROC __glewCopyTextureImage1DEXT = NULL; +PFNGLCOPYTEXTUREIMAGE2DEXTPROC __glewCopyTextureImage2DEXT = NULL; +PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC __glewCopyTextureSubImage1DEXT = NULL; +PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC __glewCopyTextureSubImage2DEXT = NULL; +PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC __glewCopyTextureSubImage3DEXT = NULL; +PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC __glewDisableClientStateIndexedEXT = NULL; +PFNGLDISABLECLIENTSTATEIEXTPROC __glewDisableClientStateiEXT = NULL; +PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC __glewDisableVertexArrayAttribEXT = NULL; +PFNGLDISABLEVERTEXARRAYEXTPROC __glewDisableVertexArrayEXT = NULL; +PFNGLENABLECLIENTSTATEINDEXEDEXTPROC __glewEnableClientStateIndexedEXT = NULL; +PFNGLENABLECLIENTSTATEIEXTPROC __glewEnableClientStateiEXT = NULL; +PFNGLENABLEVERTEXARRAYATTRIBEXTPROC __glewEnableVertexArrayAttribEXT = NULL; +PFNGLENABLEVERTEXARRAYEXTPROC __glewEnableVertexArrayEXT = NULL; +PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC __glewFlushMappedNamedBufferRangeEXT = NULL; +PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC __glewFramebufferDrawBufferEXT = NULL; +PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC __glewFramebufferDrawBuffersEXT = NULL; +PFNGLFRAMEBUFFERREADBUFFEREXTPROC __glewFramebufferReadBufferEXT = NULL; +PFNGLGENERATEMULTITEXMIPMAPEXTPROC __glewGenerateMultiTexMipmapEXT = NULL; +PFNGLGENERATETEXTUREMIPMAPEXTPROC __glewGenerateTextureMipmapEXT = NULL; +PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC __glewGetCompressedMultiTexImageEXT = NULL; +PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC __glewGetCompressedTextureImageEXT = NULL; +PFNGLGETDOUBLEINDEXEDVEXTPROC __glewGetDoubleIndexedvEXT = NULL; +PFNGLGETDOUBLEI_VEXTPROC __glewGetDoublei_vEXT = NULL; +PFNGLGETFLOATINDEXEDVEXTPROC __glewGetFloatIndexedvEXT = NULL; +PFNGLGETFLOATI_VEXTPROC __glewGetFloati_vEXT = NULL; +PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC __glewGetFramebufferParameterivEXT = NULL; +PFNGLGETMULTITEXENVFVEXTPROC __glewGetMultiTexEnvfvEXT = NULL; +PFNGLGETMULTITEXENVIVEXTPROC __glewGetMultiTexEnvivEXT = NULL; +PFNGLGETMULTITEXGENDVEXTPROC __glewGetMultiTexGendvEXT = NULL; +PFNGLGETMULTITEXGENFVEXTPROC __glewGetMultiTexGenfvEXT = NULL; +PFNGLGETMULTITEXGENIVEXTPROC __glewGetMultiTexGenivEXT = NULL; +PFNGLGETMULTITEXIMAGEEXTPROC __glewGetMultiTexImageEXT = NULL; +PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC __glewGetMultiTexLevelParameterfvEXT = NULL; +PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC __glewGetMultiTexLevelParameterivEXT = NULL; +PFNGLGETMULTITEXPARAMETERIIVEXTPROC __glewGetMultiTexParameterIivEXT = NULL; +PFNGLGETMULTITEXPARAMETERIUIVEXTPROC __glewGetMultiTexParameterIuivEXT = NULL; +PFNGLGETMULTITEXPARAMETERFVEXTPROC __glewGetMultiTexParameterfvEXT = NULL; +PFNGLGETMULTITEXPARAMETERIVEXTPROC __glewGetMultiTexParameterivEXT = NULL; +PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC __glewGetNamedBufferParameterivEXT = NULL; +PFNGLGETNAMEDBUFFERPOINTERVEXTPROC __glewGetNamedBufferPointervEXT = NULL; +PFNGLGETNAMEDBUFFERSUBDATAEXTPROC __glewGetNamedBufferSubDataEXT = NULL; +PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetNamedFramebufferAttachmentParameterivEXT = NULL; +PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC __glewGetNamedProgramLocalParameterIivEXT = NULL; +PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC __glewGetNamedProgramLocalParameterIuivEXT = NULL; +PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC __glewGetNamedProgramLocalParameterdvEXT = NULL; +PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC __glewGetNamedProgramLocalParameterfvEXT = NULL; +PFNGLGETNAMEDPROGRAMSTRINGEXTPROC __glewGetNamedProgramStringEXT = NULL; +PFNGLGETNAMEDPROGRAMIVEXTPROC __glewGetNamedProgramivEXT = NULL; +PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC __glewGetNamedRenderbufferParameterivEXT = NULL; +PFNGLGETPOINTERINDEXEDVEXTPROC __glewGetPointerIndexedvEXT = NULL; +PFNGLGETPOINTERI_VEXTPROC __glewGetPointeri_vEXT = NULL; +PFNGLGETTEXTUREIMAGEEXTPROC __glewGetTextureImageEXT = NULL; +PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC __glewGetTextureLevelParameterfvEXT = NULL; +PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC __glewGetTextureLevelParameterivEXT = NULL; +PFNGLGETTEXTUREPARAMETERIIVEXTPROC __glewGetTextureParameterIivEXT = NULL; +PFNGLGETTEXTUREPARAMETERIUIVEXTPROC __glewGetTextureParameterIuivEXT = NULL; +PFNGLGETTEXTUREPARAMETERFVEXTPROC __glewGetTextureParameterfvEXT = NULL; +PFNGLGETTEXTUREPARAMETERIVEXTPROC __glewGetTextureParameterivEXT = NULL; +PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC __glewGetVertexArrayIntegeri_vEXT = NULL; +PFNGLGETVERTEXARRAYINTEGERVEXTPROC __glewGetVertexArrayIntegervEXT = NULL; +PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC __glewGetVertexArrayPointeri_vEXT = NULL; +PFNGLGETVERTEXARRAYPOINTERVEXTPROC __glewGetVertexArrayPointervEXT = NULL; +PFNGLMAPNAMEDBUFFEREXTPROC __glewMapNamedBufferEXT = NULL; +PFNGLMAPNAMEDBUFFERRANGEEXTPROC __glewMapNamedBufferRangeEXT = NULL; +PFNGLMATRIXFRUSTUMEXTPROC __glewMatrixFrustumEXT = NULL; +PFNGLMATRIXLOADIDENTITYEXTPROC __glewMatrixLoadIdentityEXT = NULL; +PFNGLMATRIXLOADTRANSPOSEDEXTPROC __glewMatrixLoadTransposedEXT = NULL; +PFNGLMATRIXLOADTRANSPOSEFEXTPROC __glewMatrixLoadTransposefEXT = NULL; +PFNGLMATRIXLOADDEXTPROC __glewMatrixLoaddEXT = NULL; +PFNGLMATRIXLOADFEXTPROC __glewMatrixLoadfEXT = NULL; +PFNGLMATRIXMULTTRANSPOSEDEXTPROC __glewMatrixMultTransposedEXT = NULL; +PFNGLMATRIXMULTTRANSPOSEFEXTPROC __glewMatrixMultTransposefEXT = NULL; +PFNGLMATRIXMULTDEXTPROC __glewMatrixMultdEXT = NULL; +PFNGLMATRIXMULTFEXTPROC __glewMatrixMultfEXT = NULL; +PFNGLMATRIXORTHOEXTPROC __glewMatrixOrthoEXT = NULL; +PFNGLMATRIXPOPEXTPROC __glewMatrixPopEXT = NULL; +PFNGLMATRIXPUSHEXTPROC __glewMatrixPushEXT = NULL; +PFNGLMATRIXROTATEDEXTPROC __glewMatrixRotatedEXT = NULL; +PFNGLMATRIXROTATEFEXTPROC __glewMatrixRotatefEXT = NULL; +PFNGLMATRIXSCALEDEXTPROC __glewMatrixScaledEXT = NULL; +PFNGLMATRIXSCALEFEXTPROC __glewMatrixScalefEXT = NULL; +PFNGLMATRIXTRANSLATEDEXTPROC __glewMatrixTranslatedEXT = NULL; +PFNGLMATRIXTRANSLATEFEXTPROC __glewMatrixTranslatefEXT = NULL; +PFNGLMULTITEXBUFFEREXTPROC __glewMultiTexBufferEXT = NULL; +PFNGLMULTITEXCOORDPOINTEREXTPROC __glewMultiTexCoordPointerEXT = NULL; +PFNGLMULTITEXENVFEXTPROC __glewMultiTexEnvfEXT = NULL; +PFNGLMULTITEXENVFVEXTPROC __glewMultiTexEnvfvEXT = NULL; +PFNGLMULTITEXENVIEXTPROC __glewMultiTexEnviEXT = NULL; +PFNGLMULTITEXENVIVEXTPROC __glewMultiTexEnvivEXT = NULL; +PFNGLMULTITEXGENDEXTPROC __glewMultiTexGendEXT = NULL; +PFNGLMULTITEXGENDVEXTPROC __glewMultiTexGendvEXT = NULL; +PFNGLMULTITEXGENFEXTPROC __glewMultiTexGenfEXT = NULL; +PFNGLMULTITEXGENFVEXTPROC __glewMultiTexGenfvEXT = NULL; +PFNGLMULTITEXGENIEXTPROC __glewMultiTexGeniEXT = NULL; +PFNGLMULTITEXGENIVEXTPROC __glewMultiTexGenivEXT = NULL; +PFNGLMULTITEXIMAGE1DEXTPROC __glewMultiTexImage1DEXT = NULL; +PFNGLMULTITEXIMAGE2DEXTPROC __glewMultiTexImage2DEXT = NULL; +PFNGLMULTITEXIMAGE3DEXTPROC __glewMultiTexImage3DEXT = NULL; +PFNGLMULTITEXPARAMETERIIVEXTPROC __glewMultiTexParameterIivEXT = NULL; +PFNGLMULTITEXPARAMETERIUIVEXTPROC __glewMultiTexParameterIuivEXT = NULL; +PFNGLMULTITEXPARAMETERFEXTPROC __glewMultiTexParameterfEXT = NULL; +PFNGLMULTITEXPARAMETERFVEXTPROC __glewMultiTexParameterfvEXT = NULL; +PFNGLMULTITEXPARAMETERIEXTPROC __glewMultiTexParameteriEXT = NULL; +PFNGLMULTITEXPARAMETERIVEXTPROC __glewMultiTexParameterivEXT = NULL; +PFNGLMULTITEXRENDERBUFFEREXTPROC __glewMultiTexRenderbufferEXT = NULL; +PFNGLMULTITEXSUBIMAGE1DEXTPROC __glewMultiTexSubImage1DEXT = NULL; +PFNGLMULTITEXSUBIMAGE2DEXTPROC __glewMultiTexSubImage2DEXT = NULL; +PFNGLMULTITEXSUBIMAGE3DEXTPROC __glewMultiTexSubImage3DEXT = NULL; +PFNGLNAMEDBUFFERDATAEXTPROC __glewNamedBufferDataEXT = NULL; +PFNGLNAMEDBUFFERSUBDATAEXTPROC __glewNamedBufferSubDataEXT = NULL; +PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC __glewNamedCopyBufferSubDataEXT = NULL; +PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC __glewNamedFramebufferRenderbufferEXT = NULL; +PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC __glewNamedFramebufferTexture1DEXT = NULL; +PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC __glewNamedFramebufferTexture2DEXT = NULL; +PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC __glewNamedFramebufferTexture3DEXT = NULL; +PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC __glewNamedFramebufferTextureEXT = NULL; +PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC __glewNamedFramebufferTextureFaceEXT = NULL; +PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC __glewNamedFramebufferTextureLayerEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC __glewNamedProgramLocalParameter4dEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC __glewNamedProgramLocalParameter4dvEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC __glewNamedProgramLocalParameter4fEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC __glewNamedProgramLocalParameter4fvEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC __glewNamedProgramLocalParameterI4iEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC __glewNamedProgramLocalParameterI4ivEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC __glewNamedProgramLocalParameterI4uiEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC __glewNamedProgramLocalParameterI4uivEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC __glewNamedProgramLocalParameters4fvEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC __glewNamedProgramLocalParametersI4ivEXT = NULL; +PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC __glewNamedProgramLocalParametersI4uivEXT = NULL; +PFNGLNAMEDPROGRAMSTRINGEXTPROC __glewNamedProgramStringEXT = NULL; +PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC __glewNamedRenderbufferStorageEXT = NULL; +PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC __glewNamedRenderbufferStorageMultisampleCoverageEXT = NULL; +PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewNamedRenderbufferStorageMultisampleEXT = NULL; +PFNGLPROGRAMUNIFORM1FEXTPROC __glewProgramUniform1fEXT = NULL; +PFNGLPROGRAMUNIFORM1FVEXTPROC __glewProgramUniform1fvEXT = NULL; +PFNGLPROGRAMUNIFORM1IEXTPROC __glewProgramUniform1iEXT = NULL; +PFNGLPROGRAMUNIFORM1IVEXTPROC __glewProgramUniform1ivEXT = NULL; +PFNGLPROGRAMUNIFORM1UIEXTPROC __glewProgramUniform1uiEXT = NULL; +PFNGLPROGRAMUNIFORM1UIVEXTPROC __glewProgramUniform1uivEXT = NULL; +PFNGLPROGRAMUNIFORM2FEXTPROC __glewProgramUniform2fEXT = NULL; +PFNGLPROGRAMUNIFORM2FVEXTPROC __glewProgramUniform2fvEXT = NULL; +PFNGLPROGRAMUNIFORM2IEXTPROC __glewProgramUniform2iEXT = NULL; +PFNGLPROGRAMUNIFORM2IVEXTPROC __glewProgramUniform2ivEXT = NULL; +PFNGLPROGRAMUNIFORM2UIEXTPROC __glewProgramUniform2uiEXT = NULL; +PFNGLPROGRAMUNIFORM2UIVEXTPROC __glewProgramUniform2uivEXT = NULL; +PFNGLPROGRAMUNIFORM3FEXTPROC __glewProgramUniform3fEXT = NULL; +PFNGLPROGRAMUNIFORM3FVEXTPROC __glewProgramUniform3fvEXT = NULL; +PFNGLPROGRAMUNIFORM3IEXTPROC __glewProgramUniform3iEXT = NULL; +PFNGLPROGRAMUNIFORM3IVEXTPROC __glewProgramUniform3ivEXT = NULL; +PFNGLPROGRAMUNIFORM3UIEXTPROC __glewProgramUniform3uiEXT = NULL; +PFNGLPROGRAMUNIFORM3UIVEXTPROC __glewProgramUniform3uivEXT = NULL; +PFNGLPROGRAMUNIFORM4FEXTPROC __glewProgramUniform4fEXT = NULL; +PFNGLPROGRAMUNIFORM4FVEXTPROC __glewProgramUniform4fvEXT = NULL; +PFNGLPROGRAMUNIFORM4IEXTPROC __glewProgramUniform4iEXT = NULL; +PFNGLPROGRAMUNIFORM4IVEXTPROC __glewProgramUniform4ivEXT = NULL; +PFNGLPROGRAMUNIFORM4UIEXTPROC __glewProgramUniform4uiEXT = NULL; +PFNGLPROGRAMUNIFORM4UIVEXTPROC __glewProgramUniform4uivEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC __glewProgramUniformMatrix2fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC __glewProgramUniformMatrix2x3fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC __glewProgramUniformMatrix2x4fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC __glewProgramUniformMatrix3fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC __glewProgramUniformMatrix3x2fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC __glewProgramUniformMatrix3x4fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC __glewProgramUniformMatrix4fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC __glewProgramUniformMatrix4x2fvEXT = NULL; +PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC __glewProgramUniformMatrix4x3fvEXT = NULL; +PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC __glewPushClientAttribDefaultEXT = NULL; +PFNGLTEXTUREBUFFEREXTPROC __glewTextureBufferEXT = NULL; +PFNGLTEXTUREIMAGE1DEXTPROC __glewTextureImage1DEXT = NULL; +PFNGLTEXTUREIMAGE2DEXTPROC __glewTextureImage2DEXT = NULL; +PFNGLTEXTUREIMAGE3DEXTPROC __glewTextureImage3DEXT = NULL; +PFNGLTEXTUREPARAMETERIIVEXTPROC __glewTextureParameterIivEXT = NULL; +PFNGLTEXTUREPARAMETERIUIVEXTPROC __glewTextureParameterIuivEXT = NULL; +PFNGLTEXTUREPARAMETERFEXTPROC __glewTextureParameterfEXT = NULL; +PFNGLTEXTUREPARAMETERFVEXTPROC __glewTextureParameterfvEXT = NULL; +PFNGLTEXTUREPARAMETERIEXTPROC __glewTextureParameteriEXT = NULL; +PFNGLTEXTUREPARAMETERIVEXTPROC __glewTextureParameterivEXT = NULL; +PFNGLTEXTURERENDERBUFFEREXTPROC __glewTextureRenderbufferEXT = NULL; +PFNGLTEXTURESUBIMAGE1DEXTPROC __glewTextureSubImage1DEXT = NULL; +PFNGLTEXTURESUBIMAGE2DEXTPROC __glewTextureSubImage2DEXT = NULL; +PFNGLTEXTURESUBIMAGE3DEXTPROC __glewTextureSubImage3DEXT = NULL; +PFNGLUNMAPNAMEDBUFFEREXTPROC __glewUnmapNamedBufferEXT = NULL; +PFNGLVERTEXARRAYCOLOROFFSETEXTPROC __glewVertexArrayColorOffsetEXT = NULL; +PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC __glewVertexArrayEdgeFlagOffsetEXT = NULL; +PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC __glewVertexArrayFogCoordOffsetEXT = NULL; +PFNGLVERTEXARRAYINDEXOFFSETEXTPROC __glewVertexArrayIndexOffsetEXT = NULL; +PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC __glewVertexArrayMultiTexCoordOffsetEXT = NULL; +PFNGLVERTEXARRAYNORMALOFFSETEXTPROC __glewVertexArrayNormalOffsetEXT = NULL; +PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC __glewVertexArraySecondaryColorOffsetEXT = NULL; +PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC __glewVertexArrayTexCoordOffsetEXT = NULL; +PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC __glewVertexArrayVertexAttribIOffsetEXT = NULL; +PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC __glewVertexArrayVertexAttribOffsetEXT = NULL; +PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC __glewVertexArrayVertexOffsetEXT = NULL; + +PFNGLCOLORMASKINDEXEDEXTPROC __glewColorMaskIndexedEXT = NULL; +PFNGLDISABLEINDEXEDEXTPROC __glewDisableIndexedEXT = NULL; +PFNGLENABLEINDEXEDEXTPROC __glewEnableIndexedEXT = NULL; +PFNGLGETBOOLEANINDEXEDVEXTPROC __glewGetBooleanIndexedvEXT = NULL; +PFNGLGETINTEGERINDEXEDVEXTPROC __glewGetIntegerIndexedvEXT = NULL; +PFNGLISENABLEDINDEXEDEXTPROC __glewIsEnabledIndexedEXT = NULL; + +PFNGLDRAWARRAYSINSTANCEDEXTPROC __glewDrawArraysInstancedEXT = NULL; +PFNGLDRAWELEMENTSINSTANCEDEXTPROC __glewDrawElementsInstancedEXT = NULL; + +PFNGLDRAWRANGEELEMENTSEXTPROC __glewDrawRangeElementsEXT = NULL; + +PFNGLFOGCOORDPOINTEREXTPROC __glewFogCoordPointerEXT = NULL; +PFNGLFOGCOORDDEXTPROC __glewFogCoorddEXT = NULL; +PFNGLFOGCOORDDVEXTPROC __glewFogCoorddvEXT = NULL; +PFNGLFOGCOORDFEXTPROC __glewFogCoordfEXT = NULL; +PFNGLFOGCOORDFVEXTPROC __glewFogCoordfvEXT = NULL; + +PFNGLFRAGMENTCOLORMATERIALEXTPROC __glewFragmentColorMaterialEXT = NULL; +PFNGLFRAGMENTLIGHTMODELFEXTPROC __glewFragmentLightModelfEXT = NULL; +PFNGLFRAGMENTLIGHTMODELFVEXTPROC __glewFragmentLightModelfvEXT = NULL; +PFNGLFRAGMENTLIGHTMODELIEXTPROC __glewFragmentLightModeliEXT = NULL; +PFNGLFRAGMENTLIGHTMODELIVEXTPROC __glewFragmentLightModelivEXT = NULL; +PFNGLFRAGMENTLIGHTFEXTPROC __glewFragmentLightfEXT = NULL; +PFNGLFRAGMENTLIGHTFVEXTPROC __glewFragmentLightfvEXT = NULL; +PFNGLFRAGMENTLIGHTIEXTPROC __glewFragmentLightiEXT = NULL; +PFNGLFRAGMENTLIGHTIVEXTPROC __glewFragmentLightivEXT = NULL; +PFNGLFRAGMENTMATERIALFEXTPROC __glewFragmentMaterialfEXT = NULL; +PFNGLFRAGMENTMATERIALFVEXTPROC __glewFragmentMaterialfvEXT = NULL; +PFNGLFRAGMENTMATERIALIEXTPROC __glewFragmentMaterialiEXT = NULL; +PFNGLFRAGMENTMATERIALIVEXTPROC __glewFragmentMaterialivEXT = NULL; +PFNGLGETFRAGMENTLIGHTFVEXTPROC __glewGetFragmentLightfvEXT = NULL; +PFNGLGETFRAGMENTLIGHTIVEXTPROC __glewGetFragmentLightivEXT = NULL; +PFNGLGETFRAGMENTMATERIALFVEXTPROC __glewGetFragmentMaterialfvEXT = NULL; +PFNGLGETFRAGMENTMATERIALIVEXTPROC __glewGetFragmentMaterialivEXT = NULL; +PFNGLLIGHTENVIEXTPROC __glewLightEnviEXT = NULL; + +PFNGLBLITFRAMEBUFFEREXTPROC __glewBlitFramebufferEXT = NULL; + +PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewRenderbufferStorageMultisampleEXT = NULL; + +PFNGLBINDFRAMEBUFFEREXTPROC __glewBindFramebufferEXT = NULL; +PFNGLBINDRENDERBUFFEREXTPROC __glewBindRenderbufferEXT = NULL; +PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC __glewCheckFramebufferStatusEXT = NULL; +PFNGLDELETEFRAMEBUFFERSEXTPROC __glewDeleteFramebuffersEXT = NULL; +PFNGLDELETERENDERBUFFERSEXTPROC __glewDeleteRenderbuffersEXT = NULL; +PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC __glewFramebufferRenderbufferEXT = NULL; +PFNGLFRAMEBUFFERTEXTURE1DEXTPROC __glewFramebufferTexture1DEXT = NULL; +PFNGLFRAMEBUFFERTEXTURE2DEXTPROC __glewFramebufferTexture2DEXT = NULL; +PFNGLFRAMEBUFFERTEXTURE3DEXTPROC __glewFramebufferTexture3DEXT = NULL; +PFNGLGENFRAMEBUFFERSEXTPROC __glewGenFramebuffersEXT = NULL; +PFNGLGENRENDERBUFFERSEXTPROC __glewGenRenderbuffersEXT = NULL; +PFNGLGENERATEMIPMAPEXTPROC __glewGenerateMipmapEXT = NULL; +PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetFramebufferAttachmentParameterivEXT = NULL; +PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC __glewGetRenderbufferParameterivEXT = NULL; +PFNGLISFRAMEBUFFEREXTPROC __glewIsFramebufferEXT = NULL; +PFNGLISRENDERBUFFEREXTPROC __glewIsRenderbufferEXT = NULL; +PFNGLRENDERBUFFERSTORAGEEXTPROC __glewRenderbufferStorageEXT = NULL; + +PFNGLFRAMEBUFFERTEXTUREEXTPROC __glewFramebufferTextureEXT = NULL; +PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC __glewFramebufferTextureFaceEXT = NULL; +PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC __glewFramebufferTextureLayerEXT = NULL; +PFNGLPROGRAMPARAMETERIEXTPROC __glewProgramParameteriEXT = NULL; + +PFNGLPROGRAMENVPARAMETERS4FVEXTPROC __glewProgramEnvParameters4fvEXT = NULL; +PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC __glewProgramLocalParameters4fvEXT = NULL; + +PFNGLBINDFRAGDATALOCATIONEXTPROC __glewBindFragDataLocationEXT = NULL; +PFNGLGETFRAGDATALOCATIONEXTPROC __glewGetFragDataLocationEXT = NULL; +PFNGLGETUNIFORMUIVEXTPROC __glewGetUniformuivEXT = NULL; +PFNGLGETVERTEXATTRIBIIVEXTPROC __glewGetVertexAttribIivEXT = NULL; +PFNGLGETVERTEXATTRIBIUIVEXTPROC __glewGetVertexAttribIuivEXT = NULL; +PFNGLUNIFORM1UIEXTPROC __glewUniform1uiEXT = NULL; +PFNGLUNIFORM1UIVEXTPROC __glewUniform1uivEXT = NULL; +PFNGLUNIFORM2UIEXTPROC __glewUniform2uiEXT = NULL; +PFNGLUNIFORM2UIVEXTPROC __glewUniform2uivEXT = NULL; +PFNGLUNIFORM3UIEXTPROC __glewUniform3uiEXT = NULL; +PFNGLUNIFORM3UIVEXTPROC __glewUniform3uivEXT = NULL; +PFNGLUNIFORM4UIEXTPROC __glewUniform4uiEXT = NULL; +PFNGLUNIFORM4UIVEXTPROC __glewUniform4uivEXT = NULL; +PFNGLVERTEXATTRIBI1IEXTPROC __glewVertexAttribI1iEXT = NULL; +PFNGLVERTEXATTRIBI1IVEXTPROC __glewVertexAttribI1ivEXT = NULL; +PFNGLVERTEXATTRIBI1UIEXTPROC __glewVertexAttribI1uiEXT = NULL; +PFNGLVERTEXATTRIBI1UIVEXTPROC __glewVertexAttribI1uivEXT = NULL; +PFNGLVERTEXATTRIBI2IEXTPROC __glewVertexAttribI2iEXT = NULL; +PFNGLVERTEXATTRIBI2IVEXTPROC __glewVertexAttribI2ivEXT = NULL; +PFNGLVERTEXATTRIBI2UIEXTPROC __glewVertexAttribI2uiEXT = NULL; +PFNGLVERTEXATTRIBI2UIVEXTPROC __glewVertexAttribI2uivEXT = NULL; +PFNGLVERTEXATTRIBI3IEXTPROC __glewVertexAttribI3iEXT = NULL; +PFNGLVERTEXATTRIBI3IVEXTPROC __glewVertexAttribI3ivEXT = NULL; +PFNGLVERTEXATTRIBI3UIEXTPROC __glewVertexAttribI3uiEXT = NULL; +PFNGLVERTEXATTRIBI3UIVEXTPROC __glewVertexAttribI3uivEXT = NULL; +PFNGLVERTEXATTRIBI4BVEXTPROC __glewVertexAttribI4bvEXT = NULL; +PFNGLVERTEXATTRIBI4IEXTPROC __glewVertexAttribI4iEXT = NULL; +PFNGLVERTEXATTRIBI4IVEXTPROC __glewVertexAttribI4ivEXT = NULL; +PFNGLVERTEXATTRIBI4SVEXTPROC __glewVertexAttribI4svEXT = NULL; +PFNGLVERTEXATTRIBI4UBVEXTPROC __glewVertexAttribI4ubvEXT = NULL; +PFNGLVERTEXATTRIBI4UIEXTPROC __glewVertexAttribI4uiEXT = NULL; +PFNGLVERTEXATTRIBI4UIVEXTPROC __glewVertexAttribI4uivEXT = NULL; +PFNGLVERTEXATTRIBI4USVEXTPROC __glewVertexAttribI4usvEXT = NULL; +PFNGLVERTEXATTRIBIPOINTEREXTPROC __glewVertexAttribIPointerEXT = NULL; + +PFNGLGETHISTOGRAMEXTPROC __glewGetHistogramEXT = NULL; +PFNGLGETHISTOGRAMPARAMETERFVEXTPROC __glewGetHistogramParameterfvEXT = NULL; +PFNGLGETHISTOGRAMPARAMETERIVEXTPROC __glewGetHistogramParameterivEXT = NULL; +PFNGLGETMINMAXEXTPROC __glewGetMinmaxEXT = NULL; +PFNGLGETMINMAXPARAMETERFVEXTPROC __glewGetMinmaxParameterfvEXT = NULL; +PFNGLGETMINMAXPARAMETERIVEXTPROC __glewGetMinmaxParameterivEXT = NULL; +PFNGLHISTOGRAMEXTPROC __glewHistogramEXT = NULL; +PFNGLMINMAXEXTPROC __glewMinmaxEXT = NULL; +PFNGLRESETHISTOGRAMEXTPROC __glewResetHistogramEXT = NULL; +PFNGLRESETMINMAXEXTPROC __glewResetMinmaxEXT = NULL; + +PFNGLINDEXFUNCEXTPROC __glewIndexFuncEXT = NULL; + +PFNGLINDEXMATERIALEXTPROC __glewIndexMaterialEXT = NULL; + +PFNGLAPPLYTEXTUREEXTPROC __glewApplyTextureEXT = NULL; +PFNGLTEXTURELIGHTEXTPROC __glewTextureLightEXT = NULL; +PFNGLTEXTUREMATERIALEXTPROC __glewTextureMaterialEXT = NULL; + +PFNGLMULTIDRAWARRAYSEXTPROC __glewMultiDrawArraysEXT = NULL; +PFNGLMULTIDRAWELEMENTSEXTPROC __glewMultiDrawElementsEXT = NULL; + +PFNGLSAMPLEMASKEXTPROC __glewSampleMaskEXT = NULL; +PFNGLSAMPLEPATTERNEXTPROC __glewSamplePatternEXT = NULL; + +PFNGLCOLORTABLEEXTPROC __glewColorTableEXT = NULL; +PFNGLGETCOLORTABLEEXTPROC __glewGetColorTableEXT = NULL; +PFNGLGETCOLORTABLEPARAMETERFVEXTPROC __glewGetColorTableParameterfvEXT = NULL; +PFNGLGETCOLORTABLEPARAMETERIVEXTPROC __glewGetColorTableParameterivEXT = NULL; + +PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC __glewGetPixelTransformParameterfvEXT = NULL; +PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC __glewGetPixelTransformParameterivEXT = NULL; +PFNGLPIXELTRANSFORMPARAMETERFEXTPROC __glewPixelTransformParameterfEXT = NULL; +PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC __glewPixelTransformParameterfvEXT = NULL; +PFNGLPIXELTRANSFORMPARAMETERIEXTPROC __glewPixelTransformParameteriEXT = NULL; +PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC __glewPixelTransformParameterivEXT = NULL; + +PFNGLPOINTPARAMETERFEXTPROC __glewPointParameterfEXT = NULL; +PFNGLPOINTPARAMETERFVEXTPROC __glewPointParameterfvEXT = NULL; + +PFNGLPOLYGONOFFSETEXTPROC __glewPolygonOffsetEXT = NULL; + +PFNGLPROVOKINGVERTEXEXTPROC __glewProvokingVertexEXT = NULL; + +PFNGLBEGINSCENEEXTPROC __glewBeginSceneEXT = NULL; +PFNGLENDSCENEEXTPROC __glewEndSceneEXT = NULL; + +PFNGLSECONDARYCOLOR3BEXTPROC __glewSecondaryColor3bEXT = NULL; +PFNGLSECONDARYCOLOR3BVEXTPROC __glewSecondaryColor3bvEXT = NULL; +PFNGLSECONDARYCOLOR3DEXTPROC __glewSecondaryColor3dEXT = NULL; +PFNGLSECONDARYCOLOR3DVEXTPROC __glewSecondaryColor3dvEXT = NULL; +PFNGLSECONDARYCOLOR3FEXTPROC __glewSecondaryColor3fEXT = NULL; +PFNGLSECONDARYCOLOR3FVEXTPROC __glewSecondaryColor3fvEXT = NULL; +PFNGLSECONDARYCOLOR3IEXTPROC __glewSecondaryColor3iEXT = NULL; +PFNGLSECONDARYCOLOR3IVEXTPROC __glewSecondaryColor3ivEXT = NULL; +PFNGLSECONDARYCOLOR3SEXTPROC __glewSecondaryColor3sEXT = NULL; +PFNGLSECONDARYCOLOR3SVEXTPROC __glewSecondaryColor3svEXT = NULL; +PFNGLSECONDARYCOLOR3UBEXTPROC __glewSecondaryColor3ubEXT = NULL; +PFNGLSECONDARYCOLOR3UBVEXTPROC __glewSecondaryColor3ubvEXT = NULL; +PFNGLSECONDARYCOLOR3UIEXTPROC __glewSecondaryColor3uiEXT = NULL; +PFNGLSECONDARYCOLOR3UIVEXTPROC __glewSecondaryColor3uivEXT = NULL; +PFNGLSECONDARYCOLOR3USEXTPROC __glewSecondaryColor3usEXT = NULL; +PFNGLSECONDARYCOLOR3USVEXTPROC __glewSecondaryColor3usvEXT = NULL; +PFNGLSECONDARYCOLORPOINTEREXTPROC __glewSecondaryColorPointerEXT = NULL; + +PFNGLACTIVEPROGRAMEXTPROC __glewActiveProgramEXT = NULL; +PFNGLCREATESHADERPROGRAMEXTPROC __glewCreateShaderProgramEXT = NULL; +PFNGLUSESHADERPROGRAMEXTPROC __glewUseShaderProgramEXT = NULL; + +PFNGLBINDIMAGETEXTUREEXTPROC __glewBindImageTextureEXT = NULL; +PFNGLMEMORYBARRIEREXTPROC __glewMemoryBarrierEXT = NULL; + +PFNGLACTIVESTENCILFACEEXTPROC __glewActiveStencilFaceEXT = NULL; + +PFNGLTEXSUBIMAGE1DEXTPROC __glewTexSubImage1DEXT = NULL; +PFNGLTEXSUBIMAGE2DEXTPROC __glewTexSubImage2DEXT = NULL; +PFNGLTEXSUBIMAGE3DEXTPROC __glewTexSubImage3DEXT = NULL; + +PFNGLTEXIMAGE3DEXTPROC __glewTexImage3DEXT = NULL; + +PFNGLTEXBUFFEREXTPROC __glewTexBufferEXT = NULL; + +PFNGLCLEARCOLORIIEXTPROC __glewClearColorIiEXT = NULL; +PFNGLCLEARCOLORIUIEXTPROC __glewClearColorIuiEXT = NULL; +PFNGLGETTEXPARAMETERIIVEXTPROC __glewGetTexParameterIivEXT = NULL; +PFNGLGETTEXPARAMETERIUIVEXTPROC __glewGetTexParameterIuivEXT = NULL; +PFNGLTEXPARAMETERIIVEXTPROC __glewTexParameterIivEXT = NULL; +PFNGLTEXPARAMETERIUIVEXTPROC __glewTexParameterIuivEXT = NULL; + +PFNGLARETEXTURESRESIDENTEXTPROC __glewAreTexturesResidentEXT = NULL; +PFNGLBINDTEXTUREEXTPROC __glewBindTextureEXT = NULL; +PFNGLDELETETEXTURESEXTPROC __glewDeleteTexturesEXT = NULL; +PFNGLGENTEXTURESEXTPROC __glewGenTexturesEXT = NULL; +PFNGLISTEXTUREEXTPROC __glewIsTextureEXT = NULL; +PFNGLPRIORITIZETEXTURESEXTPROC __glewPrioritizeTexturesEXT = NULL; + +PFNGLTEXTURENORMALEXTPROC __glewTextureNormalEXT = NULL; + +PFNGLGETQUERYOBJECTI64VEXTPROC __glewGetQueryObjecti64vEXT = NULL; +PFNGLGETQUERYOBJECTUI64VEXTPROC __glewGetQueryObjectui64vEXT = NULL; + +PFNGLBEGINTRANSFORMFEEDBACKEXTPROC __glewBeginTransformFeedbackEXT = NULL; +PFNGLBINDBUFFERBASEEXTPROC __glewBindBufferBaseEXT = NULL; +PFNGLBINDBUFFEROFFSETEXTPROC __glewBindBufferOffsetEXT = NULL; +PFNGLBINDBUFFERRANGEEXTPROC __glewBindBufferRangeEXT = NULL; +PFNGLENDTRANSFORMFEEDBACKEXTPROC __glewEndTransformFeedbackEXT = NULL; +PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC __glewGetTransformFeedbackVaryingEXT = NULL; +PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC __glewTransformFeedbackVaryingsEXT = NULL; + +PFNGLARRAYELEMENTEXTPROC __glewArrayElementEXT = NULL; +PFNGLCOLORPOINTEREXTPROC __glewColorPointerEXT = NULL; +PFNGLDRAWARRAYSEXTPROC __glewDrawArraysEXT = NULL; +PFNGLEDGEFLAGPOINTEREXTPROC __glewEdgeFlagPointerEXT = NULL; +PFNGLGETPOINTERVEXTPROC __glewGetPointervEXT = NULL; +PFNGLINDEXPOINTEREXTPROC __glewIndexPointerEXT = NULL; +PFNGLNORMALPOINTEREXTPROC __glewNormalPointerEXT = NULL; +PFNGLTEXCOORDPOINTEREXTPROC __glewTexCoordPointerEXT = NULL; +PFNGLVERTEXPOINTEREXTPROC __glewVertexPointerEXT = NULL; + +PFNGLGETVERTEXATTRIBLDVEXTPROC __glewGetVertexAttribLdvEXT = NULL; +PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC __glewVertexArrayVertexAttribLOffsetEXT = NULL; +PFNGLVERTEXATTRIBL1DEXTPROC __glewVertexAttribL1dEXT = NULL; +PFNGLVERTEXATTRIBL1DVEXTPROC __glewVertexAttribL1dvEXT = NULL; +PFNGLVERTEXATTRIBL2DEXTPROC __glewVertexAttribL2dEXT = NULL; +PFNGLVERTEXATTRIBL2DVEXTPROC __glewVertexAttribL2dvEXT = NULL; +PFNGLVERTEXATTRIBL3DEXTPROC __glewVertexAttribL3dEXT = NULL; +PFNGLVERTEXATTRIBL3DVEXTPROC __glewVertexAttribL3dvEXT = NULL; +PFNGLVERTEXATTRIBL4DEXTPROC __glewVertexAttribL4dEXT = NULL; +PFNGLVERTEXATTRIBL4DVEXTPROC __glewVertexAttribL4dvEXT = NULL; +PFNGLVERTEXATTRIBLPOINTEREXTPROC __glewVertexAttribLPointerEXT = NULL; + +PFNGLBEGINVERTEXSHADEREXTPROC __glewBeginVertexShaderEXT = NULL; +PFNGLBINDLIGHTPARAMETEREXTPROC __glewBindLightParameterEXT = NULL; +PFNGLBINDMATERIALPARAMETEREXTPROC __glewBindMaterialParameterEXT = NULL; +PFNGLBINDPARAMETEREXTPROC __glewBindParameterEXT = NULL; +PFNGLBINDTEXGENPARAMETEREXTPROC __glewBindTexGenParameterEXT = NULL; +PFNGLBINDTEXTUREUNITPARAMETEREXTPROC __glewBindTextureUnitParameterEXT = NULL; +PFNGLBINDVERTEXSHADEREXTPROC __glewBindVertexShaderEXT = NULL; +PFNGLDELETEVERTEXSHADEREXTPROC __glewDeleteVertexShaderEXT = NULL; +PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC __glewDisableVariantClientStateEXT = NULL; +PFNGLENABLEVARIANTCLIENTSTATEEXTPROC __glewEnableVariantClientStateEXT = NULL; +PFNGLENDVERTEXSHADEREXTPROC __glewEndVertexShaderEXT = NULL; +PFNGLEXTRACTCOMPONENTEXTPROC __glewExtractComponentEXT = NULL; +PFNGLGENSYMBOLSEXTPROC __glewGenSymbolsEXT = NULL; +PFNGLGENVERTEXSHADERSEXTPROC __glewGenVertexShadersEXT = NULL; +PFNGLGETINVARIANTBOOLEANVEXTPROC __glewGetInvariantBooleanvEXT = NULL; +PFNGLGETINVARIANTFLOATVEXTPROC __glewGetInvariantFloatvEXT = NULL; +PFNGLGETINVARIANTINTEGERVEXTPROC __glewGetInvariantIntegervEXT = NULL; +PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC __glewGetLocalConstantBooleanvEXT = NULL; +PFNGLGETLOCALCONSTANTFLOATVEXTPROC __glewGetLocalConstantFloatvEXT = NULL; +PFNGLGETLOCALCONSTANTINTEGERVEXTPROC __glewGetLocalConstantIntegervEXT = NULL; +PFNGLGETVARIANTBOOLEANVEXTPROC __glewGetVariantBooleanvEXT = NULL; +PFNGLGETVARIANTFLOATVEXTPROC __glewGetVariantFloatvEXT = NULL; +PFNGLGETVARIANTINTEGERVEXTPROC __glewGetVariantIntegervEXT = NULL; +PFNGLGETVARIANTPOINTERVEXTPROC __glewGetVariantPointervEXT = NULL; +PFNGLINSERTCOMPONENTEXTPROC __glewInsertComponentEXT = NULL; +PFNGLISVARIANTENABLEDEXTPROC __glewIsVariantEnabledEXT = NULL; +PFNGLSETINVARIANTEXTPROC __glewSetInvariantEXT = NULL; +PFNGLSETLOCALCONSTANTEXTPROC __glewSetLocalConstantEXT = NULL; +PFNGLSHADEROP1EXTPROC __glewShaderOp1EXT = NULL; +PFNGLSHADEROP2EXTPROC __glewShaderOp2EXT = NULL; +PFNGLSHADEROP3EXTPROC __glewShaderOp3EXT = NULL; +PFNGLSWIZZLEEXTPROC __glewSwizzleEXT = NULL; +PFNGLVARIANTPOINTEREXTPROC __glewVariantPointerEXT = NULL; +PFNGLVARIANTBVEXTPROC __glewVariantbvEXT = NULL; +PFNGLVARIANTDVEXTPROC __glewVariantdvEXT = NULL; +PFNGLVARIANTFVEXTPROC __glewVariantfvEXT = NULL; +PFNGLVARIANTIVEXTPROC __glewVariantivEXT = NULL; +PFNGLVARIANTSVEXTPROC __glewVariantsvEXT = NULL; +PFNGLVARIANTUBVEXTPROC __glewVariantubvEXT = NULL; +PFNGLVARIANTUIVEXTPROC __glewVariantuivEXT = NULL; +PFNGLVARIANTUSVEXTPROC __glewVariantusvEXT = NULL; +PFNGLWRITEMASKEXTPROC __glewWriteMaskEXT = NULL; + +PFNGLVERTEXWEIGHTPOINTEREXTPROC __glewVertexWeightPointerEXT = NULL; +PFNGLVERTEXWEIGHTFEXTPROC __glewVertexWeightfEXT = NULL; +PFNGLVERTEXWEIGHTFVEXTPROC __glewVertexWeightfvEXT = NULL; + +PFNGLFRAMETERMINATORGREMEDYPROC __glewFrameTerminatorGREMEDY = NULL; + +PFNGLSTRINGMARKERGREMEDYPROC __glewStringMarkerGREMEDY = NULL; + +PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC __glewGetImageTransformParameterfvHP = NULL; +PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC __glewGetImageTransformParameterivHP = NULL; +PFNGLIMAGETRANSFORMPARAMETERFHPPROC __glewImageTransformParameterfHP = NULL; +PFNGLIMAGETRANSFORMPARAMETERFVHPPROC __glewImageTransformParameterfvHP = NULL; +PFNGLIMAGETRANSFORMPARAMETERIHPPROC __glewImageTransformParameteriHP = NULL; +PFNGLIMAGETRANSFORMPARAMETERIVHPPROC __glewImageTransformParameterivHP = NULL; + +PFNGLMULTIMODEDRAWARRAYSIBMPROC __glewMultiModeDrawArraysIBM = NULL; +PFNGLMULTIMODEDRAWELEMENTSIBMPROC __glewMultiModeDrawElementsIBM = NULL; + +PFNGLCOLORPOINTERLISTIBMPROC __glewColorPointerListIBM = NULL; +PFNGLEDGEFLAGPOINTERLISTIBMPROC __glewEdgeFlagPointerListIBM = NULL; +PFNGLFOGCOORDPOINTERLISTIBMPROC __glewFogCoordPointerListIBM = NULL; +PFNGLINDEXPOINTERLISTIBMPROC __glewIndexPointerListIBM = NULL; +PFNGLNORMALPOINTERLISTIBMPROC __glewNormalPointerListIBM = NULL; +PFNGLSECONDARYCOLORPOINTERLISTIBMPROC __glewSecondaryColorPointerListIBM = NULL; +PFNGLTEXCOORDPOINTERLISTIBMPROC __glewTexCoordPointerListIBM = NULL; +PFNGLVERTEXPOINTERLISTIBMPROC __glewVertexPointerListIBM = NULL; + +PFNGLCOLORPOINTERVINTELPROC __glewColorPointervINTEL = NULL; +PFNGLNORMALPOINTERVINTELPROC __glewNormalPointervINTEL = NULL; +PFNGLTEXCOORDPOINTERVINTELPROC __glewTexCoordPointervINTEL = NULL; +PFNGLVERTEXPOINTERVINTELPROC __glewVertexPointervINTEL = NULL; + +PFNGLTEXSCISSORFUNCINTELPROC __glewTexScissorFuncINTEL = NULL; +PFNGLTEXSCISSORINTELPROC __glewTexScissorINTEL = NULL; + +PFNGLBUFFERREGIONENABLEDEXTPROC __glewBufferRegionEnabledEXT = NULL; +PFNGLDELETEBUFFERREGIONEXTPROC __glewDeleteBufferRegionEXT = NULL; +PFNGLDRAWBUFFERREGIONEXTPROC __glewDrawBufferRegionEXT = NULL; +PFNGLNEWBUFFERREGIONEXTPROC __glewNewBufferRegionEXT = NULL; +PFNGLREADBUFFERREGIONEXTPROC __glewReadBufferRegionEXT = NULL; + +PFNGLRESIZEBUFFERSMESAPROC __glewResizeBuffersMESA = NULL; + +PFNGLWINDOWPOS2DMESAPROC __glewWindowPos2dMESA = NULL; +PFNGLWINDOWPOS2DVMESAPROC __glewWindowPos2dvMESA = NULL; +PFNGLWINDOWPOS2FMESAPROC __glewWindowPos2fMESA = NULL; +PFNGLWINDOWPOS2FVMESAPROC __glewWindowPos2fvMESA = NULL; +PFNGLWINDOWPOS2IMESAPROC __glewWindowPos2iMESA = NULL; +PFNGLWINDOWPOS2IVMESAPROC __glewWindowPos2ivMESA = NULL; +PFNGLWINDOWPOS2SMESAPROC __glewWindowPos2sMESA = NULL; +PFNGLWINDOWPOS2SVMESAPROC __glewWindowPos2svMESA = NULL; +PFNGLWINDOWPOS3DMESAPROC __glewWindowPos3dMESA = NULL; +PFNGLWINDOWPOS3DVMESAPROC __glewWindowPos3dvMESA = NULL; +PFNGLWINDOWPOS3FMESAPROC __glewWindowPos3fMESA = NULL; +PFNGLWINDOWPOS3FVMESAPROC __glewWindowPos3fvMESA = NULL; +PFNGLWINDOWPOS3IMESAPROC __glewWindowPos3iMESA = NULL; +PFNGLWINDOWPOS3IVMESAPROC __glewWindowPos3ivMESA = NULL; +PFNGLWINDOWPOS3SMESAPROC __glewWindowPos3sMESA = NULL; +PFNGLWINDOWPOS3SVMESAPROC __glewWindowPos3svMESA = NULL; +PFNGLWINDOWPOS4DMESAPROC __glewWindowPos4dMESA = NULL; +PFNGLWINDOWPOS4DVMESAPROC __glewWindowPos4dvMESA = NULL; +PFNGLWINDOWPOS4FMESAPROC __glewWindowPos4fMESA = NULL; +PFNGLWINDOWPOS4FVMESAPROC __glewWindowPos4fvMESA = NULL; +PFNGLWINDOWPOS4IMESAPROC __glewWindowPos4iMESA = NULL; +PFNGLWINDOWPOS4IVMESAPROC __glewWindowPos4ivMESA = NULL; +PFNGLWINDOWPOS4SMESAPROC __glewWindowPos4sMESA = NULL; +PFNGLWINDOWPOS4SVMESAPROC __glewWindowPos4svMESA = NULL; + +PFNGLBEGINCONDITIONALRENDERNVPROC __glewBeginConditionalRenderNV = NULL; +PFNGLENDCONDITIONALRENDERNVPROC __glewEndConditionalRenderNV = NULL; + +PFNGLCOPYIMAGESUBDATANVPROC __glewCopyImageSubDataNV = NULL; + +PFNGLCLEARDEPTHDNVPROC __glewClearDepthdNV = NULL; +PFNGLDEPTHBOUNDSDNVPROC __glewDepthBoundsdNV = NULL; +PFNGLDEPTHRANGEDNVPROC __glewDepthRangedNV = NULL; + +PFNGLEVALMAPSNVPROC __glewEvalMapsNV = NULL; +PFNGLGETMAPATTRIBPARAMETERFVNVPROC __glewGetMapAttribParameterfvNV = NULL; +PFNGLGETMAPATTRIBPARAMETERIVNVPROC __glewGetMapAttribParameterivNV = NULL; +PFNGLGETMAPCONTROLPOINTSNVPROC __glewGetMapControlPointsNV = NULL; +PFNGLGETMAPPARAMETERFVNVPROC __glewGetMapParameterfvNV = NULL; +PFNGLGETMAPPARAMETERIVNVPROC __glewGetMapParameterivNV = NULL; +PFNGLMAPCONTROLPOINTSNVPROC __glewMapControlPointsNV = NULL; +PFNGLMAPPARAMETERFVNVPROC __glewMapParameterfvNV = NULL; +PFNGLMAPPARAMETERIVNVPROC __glewMapParameterivNV = NULL; + +PFNGLGETMULTISAMPLEFVNVPROC __glewGetMultisamplefvNV = NULL; +PFNGLSAMPLEMASKINDEXEDNVPROC __glewSampleMaskIndexedNV = NULL; +PFNGLTEXRENDERBUFFERNVPROC __glewTexRenderbufferNV = NULL; + +PFNGLDELETEFENCESNVPROC __glewDeleteFencesNV = NULL; +PFNGLFINISHFENCENVPROC __glewFinishFenceNV = NULL; +PFNGLGENFENCESNVPROC __glewGenFencesNV = NULL; +PFNGLGETFENCEIVNVPROC __glewGetFenceivNV = NULL; +PFNGLISFENCENVPROC __glewIsFenceNV = NULL; +PFNGLSETFENCENVPROC __glewSetFenceNV = NULL; +PFNGLTESTFENCENVPROC __glewTestFenceNV = NULL; + +PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC __glewGetProgramNamedParameterdvNV = NULL; +PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC __glewGetProgramNamedParameterfvNV = NULL; +PFNGLPROGRAMNAMEDPARAMETER4DNVPROC __glewProgramNamedParameter4dNV = NULL; +PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC __glewProgramNamedParameter4dvNV = NULL; +PFNGLPROGRAMNAMEDPARAMETER4FNVPROC __glewProgramNamedParameter4fNV = NULL; +PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC __glewProgramNamedParameter4fvNV = NULL; + +PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC __glewRenderbufferStorageMultisampleCoverageNV = NULL; + +PFNGLPROGRAMVERTEXLIMITNVPROC __glewProgramVertexLimitNV = NULL; + +PFNGLPROGRAMENVPARAMETERI4INVPROC __glewProgramEnvParameterI4iNV = NULL; +PFNGLPROGRAMENVPARAMETERI4IVNVPROC __glewProgramEnvParameterI4ivNV = NULL; +PFNGLPROGRAMENVPARAMETERI4UINVPROC __glewProgramEnvParameterI4uiNV = NULL; +PFNGLPROGRAMENVPARAMETERI4UIVNVPROC __glewProgramEnvParameterI4uivNV = NULL; +PFNGLPROGRAMENVPARAMETERSI4IVNVPROC __glewProgramEnvParametersI4ivNV = NULL; +PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC __glewProgramEnvParametersI4uivNV = NULL; +PFNGLPROGRAMLOCALPARAMETERI4INVPROC __glewProgramLocalParameterI4iNV = NULL; +PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC __glewProgramLocalParameterI4ivNV = NULL; +PFNGLPROGRAMLOCALPARAMETERI4UINVPROC __glewProgramLocalParameterI4uiNV = NULL; +PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC __glewProgramLocalParameterI4uivNV = NULL; +PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC __glewProgramLocalParametersI4ivNV = NULL; +PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC __glewProgramLocalParametersI4uivNV = NULL; + +PFNGLGETUNIFORMI64VNVPROC __glewGetUniformi64vNV = NULL; +PFNGLGETUNIFORMUI64VNVPROC __glewGetUniformui64vNV = NULL; +PFNGLPROGRAMUNIFORM1I64NVPROC __glewProgramUniform1i64NV = NULL; +PFNGLPROGRAMUNIFORM1I64VNVPROC __glewProgramUniform1i64vNV = NULL; +PFNGLPROGRAMUNIFORM1UI64NVPROC __glewProgramUniform1ui64NV = NULL; +PFNGLPROGRAMUNIFORM1UI64VNVPROC __glewProgramUniform1ui64vNV = NULL; +PFNGLPROGRAMUNIFORM2I64NVPROC __glewProgramUniform2i64NV = NULL; +PFNGLPROGRAMUNIFORM2I64VNVPROC __glewProgramUniform2i64vNV = NULL; +PFNGLPROGRAMUNIFORM2UI64NVPROC __glewProgramUniform2ui64NV = NULL; +PFNGLPROGRAMUNIFORM2UI64VNVPROC __glewProgramUniform2ui64vNV = NULL; +PFNGLPROGRAMUNIFORM3I64NVPROC __glewProgramUniform3i64NV = NULL; +PFNGLPROGRAMUNIFORM3I64VNVPROC __glewProgramUniform3i64vNV = NULL; +PFNGLPROGRAMUNIFORM3UI64NVPROC __glewProgramUniform3ui64NV = NULL; +PFNGLPROGRAMUNIFORM3UI64VNVPROC __glewProgramUniform3ui64vNV = NULL; +PFNGLPROGRAMUNIFORM4I64NVPROC __glewProgramUniform4i64NV = NULL; +PFNGLPROGRAMUNIFORM4I64VNVPROC __glewProgramUniform4i64vNV = NULL; +PFNGLPROGRAMUNIFORM4UI64NVPROC __glewProgramUniform4ui64NV = NULL; +PFNGLPROGRAMUNIFORM4UI64VNVPROC __glewProgramUniform4ui64vNV = NULL; +PFNGLUNIFORM1I64NVPROC __glewUniform1i64NV = NULL; +PFNGLUNIFORM1I64VNVPROC __glewUniform1i64vNV = NULL; +PFNGLUNIFORM1UI64NVPROC __glewUniform1ui64NV = NULL; +PFNGLUNIFORM1UI64VNVPROC __glewUniform1ui64vNV = NULL; +PFNGLUNIFORM2I64NVPROC __glewUniform2i64NV = NULL; +PFNGLUNIFORM2I64VNVPROC __glewUniform2i64vNV = NULL; +PFNGLUNIFORM2UI64NVPROC __glewUniform2ui64NV = NULL; +PFNGLUNIFORM2UI64VNVPROC __glewUniform2ui64vNV = NULL; +PFNGLUNIFORM3I64NVPROC __glewUniform3i64NV = NULL; +PFNGLUNIFORM3I64VNVPROC __glewUniform3i64vNV = NULL; +PFNGLUNIFORM3UI64NVPROC __glewUniform3ui64NV = NULL; +PFNGLUNIFORM3UI64VNVPROC __glewUniform3ui64vNV = NULL; +PFNGLUNIFORM4I64NVPROC __glewUniform4i64NV = NULL; +PFNGLUNIFORM4I64VNVPROC __glewUniform4i64vNV = NULL; +PFNGLUNIFORM4UI64NVPROC __glewUniform4ui64NV = NULL; +PFNGLUNIFORM4UI64VNVPROC __glewUniform4ui64vNV = NULL; + +PFNGLCOLOR3HNVPROC __glewColor3hNV = NULL; +PFNGLCOLOR3HVNVPROC __glewColor3hvNV = NULL; +PFNGLCOLOR4HNVPROC __glewColor4hNV = NULL; +PFNGLCOLOR4HVNVPROC __glewColor4hvNV = NULL; +PFNGLFOGCOORDHNVPROC __glewFogCoordhNV = NULL; +PFNGLFOGCOORDHVNVPROC __glewFogCoordhvNV = NULL; +PFNGLMULTITEXCOORD1HNVPROC __glewMultiTexCoord1hNV = NULL; +PFNGLMULTITEXCOORD1HVNVPROC __glewMultiTexCoord1hvNV = NULL; +PFNGLMULTITEXCOORD2HNVPROC __glewMultiTexCoord2hNV = NULL; +PFNGLMULTITEXCOORD2HVNVPROC __glewMultiTexCoord2hvNV = NULL; +PFNGLMULTITEXCOORD3HNVPROC __glewMultiTexCoord3hNV = NULL; +PFNGLMULTITEXCOORD3HVNVPROC __glewMultiTexCoord3hvNV = NULL; +PFNGLMULTITEXCOORD4HNVPROC __glewMultiTexCoord4hNV = NULL; +PFNGLMULTITEXCOORD4HVNVPROC __glewMultiTexCoord4hvNV = NULL; +PFNGLNORMAL3HNVPROC __glewNormal3hNV = NULL; +PFNGLNORMAL3HVNVPROC __glewNormal3hvNV = NULL; +PFNGLSECONDARYCOLOR3HNVPROC __glewSecondaryColor3hNV = NULL; +PFNGLSECONDARYCOLOR3HVNVPROC __glewSecondaryColor3hvNV = NULL; +PFNGLTEXCOORD1HNVPROC __glewTexCoord1hNV = NULL; +PFNGLTEXCOORD1HVNVPROC __glewTexCoord1hvNV = NULL; +PFNGLTEXCOORD2HNVPROC __glewTexCoord2hNV = NULL; +PFNGLTEXCOORD2HVNVPROC __glewTexCoord2hvNV = NULL; +PFNGLTEXCOORD3HNVPROC __glewTexCoord3hNV = NULL; +PFNGLTEXCOORD3HVNVPROC __glewTexCoord3hvNV = NULL; +PFNGLTEXCOORD4HNVPROC __glewTexCoord4hNV = NULL; +PFNGLTEXCOORD4HVNVPROC __glewTexCoord4hvNV = NULL; +PFNGLVERTEX2HNVPROC __glewVertex2hNV = NULL; +PFNGLVERTEX2HVNVPROC __glewVertex2hvNV = NULL; +PFNGLVERTEX3HNVPROC __glewVertex3hNV = NULL; +PFNGLVERTEX3HVNVPROC __glewVertex3hvNV = NULL; +PFNGLVERTEX4HNVPROC __glewVertex4hNV = NULL; +PFNGLVERTEX4HVNVPROC __glewVertex4hvNV = NULL; +PFNGLVERTEXATTRIB1HNVPROC __glewVertexAttrib1hNV = NULL; +PFNGLVERTEXATTRIB1HVNVPROC __glewVertexAttrib1hvNV = NULL; +PFNGLVERTEXATTRIB2HNVPROC __glewVertexAttrib2hNV = NULL; +PFNGLVERTEXATTRIB2HVNVPROC __glewVertexAttrib2hvNV = NULL; +PFNGLVERTEXATTRIB3HNVPROC __glewVertexAttrib3hNV = NULL; +PFNGLVERTEXATTRIB3HVNVPROC __glewVertexAttrib3hvNV = NULL; +PFNGLVERTEXATTRIB4HNVPROC __glewVertexAttrib4hNV = NULL; +PFNGLVERTEXATTRIB4HVNVPROC __glewVertexAttrib4hvNV = NULL; +PFNGLVERTEXATTRIBS1HVNVPROC __glewVertexAttribs1hvNV = NULL; +PFNGLVERTEXATTRIBS2HVNVPROC __glewVertexAttribs2hvNV = NULL; +PFNGLVERTEXATTRIBS3HVNVPROC __glewVertexAttribs3hvNV = NULL; +PFNGLVERTEXATTRIBS4HVNVPROC __glewVertexAttribs4hvNV = NULL; +PFNGLVERTEXWEIGHTHNVPROC __glewVertexWeighthNV = NULL; +PFNGLVERTEXWEIGHTHVNVPROC __glewVertexWeighthvNV = NULL; + +PFNGLBEGINOCCLUSIONQUERYNVPROC __glewBeginOcclusionQueryNV = NULL; +PFNGLDELETEOCCLUSIONQUERIESNVPROC __glewDeleteOcclusionQueriesNV = NULL; +PFNGLENDOCCLUSIONQUERYNVPROC __glewEndOcclusionQueryNV = NULL; +PFNGLGENOCCLUSIONQUERIESNVPROC __glewGenOcclusionQueriesNV = NULL; +PFNGLGETOCCLUSIONQUERYIVNVPROC __glewGetOcclusionQueryivNV = NULL; +PFNGLGETOCCLUSIONQUERYUIVNVPROC __glewGetOcclusionQueryuivNV = NULL; +PFNGLISOCCLUSIONQUERYNVPROC __glewIsOcclusionQueryNV = NULL; + +PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC __glewProgramBufferParametersIivNV = NULL; +PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC __glewProgramBufferParametersIuivNV = NULL; +PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC __glewProgramBufferParametersfvNV = NULL; + +PFNGLFLUSHPIXELDATARANGENVPROC __glewFlushPixelDataRangeNV = NULL; +PFNGLPIXELDATARANGENVPROC __glewPixelDataRangeNV = NULL; + +PFNGLPOINTPARAMETERINVPROC __glewPointParameteriNV = NULL; +PFNGLPOINTPARAMETERIVNVPROC __glewPointParameterivNV = NULL; + +PFNGLGETVIDEOI64VNVPROC __glewGetVideoi64vNV = NULL; +PFNGLGETVIDEOIVNVPROC __glewGetVideoivNV = NULL; +PFNGLGETVIDEOUI64VNVPROC __glewGetVideoui64vNV = NULL; +PFNGLGETVIDEOUIVNVPROC __glewGetVideouivNV = NULL; +PFNGLPRESENTFRAMEDUALFILLNVPROC __glewPresentFrameDualFillNV = NULL; +PFNGLPRESENTFRAMEKEYEDNVPROC __glewPresentFrameKeyedNV = NULL; + +PFNGLPRIMITIVERESTARTINDEXNVPROC __glewPrimitiveRestartIndexNV = NULL; +PFNGLPRIMITIVERESTARTNVPROC __glewPrimitiveRestartNV = NULL; + +PFNGLCOMBINERINPUTNVPROC __glewCombinerInputNV = NULL; +PFNGLCOMBINEROUTPUTNVPROC __glewCombinerOutputNV = NULL; +PFNGLCOMBINERPARAMETERFNVPROC __glewCombinerParameterfNV = NULL; +PFNGLCOMBINERPARAMETERFVNVPROC __glewCombinerParameterfvNV = NULL; +PFNGLCOMBINERPARAMETERINVPROC __glewCombinerParameteriNV = NULL; +PFNGLCOMBINERPARAMETERIVNVPROC __glewCombinerParameterivNV = NULL; +PFNGLFINALCOMBINERINPUTNVPROC __glewFinalCombinerInputNV = NULL; +PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC __glewGetCombinerInputParameterfvNV = NULL; +PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC __glewGetCombinerInputParameterivNV = NULL; +PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC __glewGetCombinerOutputParameterfvNV = NULL; +PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC __glewGetCombinerOutputParameterivNV = NULL; +PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC __glewGetFinalCombinerInputParameterfvNV = NULL; +PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC __glewGetFinalCombinerInputParameterivNV = NULL; + +PFNGLCOMBINERSTAGEPARAMETERFVNVPROC __glewCombinerStageParameterfvNV = NULL; +PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC __glewGetCombinerStageParameterfvNV = NULL; + +PFNGLGETBUFFERPARAMETERUI64VNVPROC __glewGetBufferParameterui64vNV = NULL; +PFNGLGETINTEGERUI64VNVPROC __glewGetIntegerui64vNV = NULL; +PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC __glewGetNamedBufferParameterui64vNV = NULL; +PFNGLISBUFFERRESIDENTNVPROC __glewIsBufferResidentNV = NULL; +PFNGLISNAMEDBUFFERRESIDENTNVPROC __glewIsNamedBufferResidentNV = NULL; +PFNGLMAKEBUFFERNONRESIDENTNVPROC __glewMakeBufferNonResidentNV = NULL; +PFNGLMAKEBUFFERRESIDENTNVPROC __glewMakeBufferResidentNV = NULL; +PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC __glewMakeNamedBufferNonResidentNV = NULL; +PFNGLMAKENAMEDBUFFERRESIDENTNVPROC __glewMakeNamedBufferResidentNV = NULL; +PFNGLPROGRAMUNIFORMUI64NVPROC __glewProgramUniformui64NV = NULL; +PFNGLPROGRAMUNIFORMUI64VNVPROC __glewProgramUniformui64vNV = NULL; +PFNGLUNIFORMUI64NVPROC __glewUniformui64NV = NULL; +PFNGLUNIFORMUI64VNVPROC __glewUniformui64vNV = NULL; + +PFNGLTEXTUREBARRIERNVPROC __glewTextureBarrierNV = NULL; + +PFNGLACTIVEVARYINGNVPROC __glewActiveVaryingNV = NULL; +PFNGLBEGINTRANSFORMFEEDBACKNVPROC __glewBeginTransformFeedbackNV = NULL; +PFNGLBINDBUFFERBASENVPROC __glewBindBufferBaseNV = NULL; +PFNGLBINDBUFFEROFFSETNVPROC __glewBindBufferOffsetNV = NULL; +PFNGLBINDBUFFERRANGENVPROC __glewBindBufferRangeNV = NULL; +PFNGLENDTRANSFORMFEEDBACKNVPROC __glewEndTransformFeedbackNV = NULL; +PFNGLGETACTIVEVARYINGNVPROC __glewGetActiveVaryingNV = NULL; +PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC __glewGetTransformFeedbackVaryingNV = NULL; +PFNGLGETVARYINGLOCATIONNVPROC __glewGetVaryingLocationNV = NULL; +PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC __glewTransformFeedbackAttribsNV = NULL; +PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC __glewTransformFeedbackVaryingsNV = NULL; + +PFNGLBINDTRANSFORMFEEDBACKNVPROC __glewBindTransformFeedbackNV = NULL; +PFNGLDELETETRANSFORMFEEDBACKSNVPROC __glewDeleteTransformFeedbacksNV = NULL; +PFNGLDRAWTRANSFORMFEEDBACKNVPROC __glewDrawTransformFeedbackNV = NULL; +PFNGLGENTRANSFORMFEEDBACKSNVPROC __glewGenTransformFeedbacksNV = NULL; +PFNGLISTRANSFORMFEEDBACKNVPROC __glewIsTransformFeedbackNV = NULL; +PFNGLPAUSETRANSFORMFEEDBACKNVPROC __glewPauseTransformFeedbackNV = NULL; +PFNGLRESUMETRANSFORMFEEDBACKNVPROC __glewResumeTransformFeedbackNV = NULL; + +PFNGLFLUSHVERTEXARRAYRANGENVPROC __glewFlushVertexArrayRangeNV = NULL; +PFNGLVERTEXARRAYRANGENVPROC __glewVertexArrayRangeNV = NULL; + +PFNGLGETVERTEXATTRIBLI64VNVPROC __glewGetVertexAttribLi64vNV = NULL; +PFNGLGETVERTEXATTRIBLUI64VNVPROC __glewGetVertexAttribLui64vNV = NULL; +PFNGLVERTEXATTRIBL1I64NVPROC __glewVertexAttribL1i64NV = NULL; +PFNGLVERTEXATTRIBL1I64VNVPROC __glewVertexAttribL1i64vNV = NULL; +PFNGLVERTEXATTRIBL1UI64NVPROC __glewVertexAttribL1ui64NV = NULL; +PFNGLVERTEXATTRIBL1UI64VNVPROC __glewVertexAttribL1ui64vNV = NULL; +PFNGLVERTEXATTRIBL2I64NVPROC __glewVertexAttribL2i64NV = NULL; +PFNGLVERTEXATTRIBL2I64VNVPROC __glewVertexAttribL2i64vNV = NULL; +PFNGLVERTEXATTRIBL2UI64NVPROC __glewVertexAttribL2ui64NV = NULL; +PFNGLVERTEXATTRIBL2UI64VNVPROC __glewVertexAttribL2ui64vNV = NULL; +PFNGLVERTEXATTRIBL3I64NVPROC __glewVertexAttribL3i64NV = NULL; +PFNGLVERTEXATTRIBL3I64VNVPROC __glewVertexAttribL3i64vNV = NULL; +PFNGLVERTEXATTRIBL3UI64NVPROC __glewVertexAttribL3ui64NV = NULL; +PFNGLVERTEXATTRIBL3UI64VNVPROC __glewVertexAttribL3ui64vNV = NULL; +PFNGLVERTEXATTRIBL4I64NVPROC __glewVertexAttribL4i64NV = NULL; +PFNGLVERTEXATTRIBL4I64VNVPROC __glewVertexAttribL4i64vNV = NULL; +PFNGLVERTEXATTRIBL4UI64NVPROC __glewVertexAttribL4ui64NV = NULL; +PFNGLVERTEXATTRIBL4UI64VNVPROC __glewVertexAttribL4ui64vNV = NULL; +PFNGLVERTEXATTRIBLFORMATNVPROC __glewVertexAttribLFormatNV = NULL; + +PFNGLBUFFERADDRESSRANGENVPROC __glewBufferAddressRangeNV = NULL; +PFNGLCOLORFORMATNVPROC __glewColorFormatNV = NULL; +PFNGLEDGEFLAGFORMATNVPROC __glewEdgeFlagFormatNV = NULL; +PFNGLFOGCOORDFORMATNVPROC __glewFogCoordFormatNV = NULL; +PFNGLGETINTEGERUI64I_VNVPROC __glewGetIntegerui64i_vNV = NULL; +PFNGLINDEXFORMATNVPROC __glewIndexFormatNV = NULL; +PFNGLNORMALFORMATNVPROC __glewNormalFormatNV = NULL; +PFNGLSECONDARYCOLORFORMATNVPROC __glewSecondaryColorFormatNV = NULL; +PFNGLTEXCOORDFORMATNVPROC __glewTexCoordFormatNV = NULL; +PFNGLVERTEXATTRIBFORMATNVPROC __glewVertexAttribFormatNV = NULL; +PFNGLVERTEXATTRIBIFORMATNVPROC __glewVertexAttribIFormatNV = NULL; +PFNGLVERTEXFORMATNVPROC __glewVertexFormatNV = NULL; + +PFNGLAREPROGRAMSRESIDENTNVPROC __glewAreProgramsResidentNV = NULL; +PFNGLBINDPROGRAMNVPROC __glewBindProgramNV = NULL; +PFNGLDELETEPROGRAMSNVPROC __glewDeleteProgramsNV = NULL; +PFNGLEXECUTEPROGRAMNVPROC __glewExecuteProgramNV = NULL; +PFNGLGENPROGRAMSNVPROC __glewGenProgramsNV = NULL; +PFNGLGETPROGRAMPARAMETERDVNVPROC __glewGetProgramParameterdvNV = NULL; +PFNGLGETPROGRAMPARAMETERFVNVPROC __glewGetProgramParameterfvNV = NULL; +PFNGLGETPROGRAMSTRINGNVPROC __glewGetProgramStringNV = NULL; +PFNGLGETPROGRAMIVNVPROC __glewGetProgramivNV = NULL; +PFNGLGETTRACKMATRIXIVNVPROC __glewGetTrackMatrixivNV = NULL; +PFNGLGETVERTEXATTRIBPOINTERVNVPROC __glewGetVertexAttribPointervNV = NULL; +PFNGLGETVERTEXATTRIBDVNVPROC __glewGetVertexAttribdvNV = NULL; +PFNGLGETVERTEXATTRIBFVNVPROC __glewGetVertexAttribfvNV = NULL; +PFNGLGETVERTEXATTRIBIVNVPROC __glewGetVertexAttribivNV = NULL; +PFNGLISPROGRAMNVPROC __glewIsProgramNV = NULL; +PFNGLLOADPROGRAMNVPROC __glewLoadProgramNV = NULL; +PFNGLPROGRAMPARAMETER4DNVPROC __glewProgramParameter4dNV = NULL; +PFNGLPROGRAMPARAMETER4DVNVPROC __glewProgramParameter4dvNV = NULL; +PFNGLPROGRAMPARAMETER4FNVPROC __glewProgramParameter4fNV = NULL; +PFNGLPROGRAMPARAMETER4FVNVPROC __glewProgramParameter4fvNV = NULL; +PFNGLPROGRAMPARAMETERS4DVNVPROC __glewProgramParameters4dvNV = NULL; +PFNGLPROGRAMPARAMETERS4FVNVPROC __glewProgramParameters4fvNV = NULL; +PFNGLREQUESTRESIDENTPROGRAMSNVPROC __glewRequestResidentProgramsNV = NULL; +PFNGLTRACKMATRIXNVPROC __glewTrackMatrixNV = NULL; +PFNGLVERTEXATTRIB1DNVPROC __glewVertexAttrib1dNV = NULL; +PFNGLVERTEXATTRIB1DVNVPROC __glewVertexAttrib1dvNV = NULL; +PFNGLVERTEXATTRIB1FNVPROC __glewVertexAttrib1fNV = NULL; +PFNGLVERTEXATTRIB1FVNVPROC __glewVertexAttrib1fvNV = NULL; +PFNGLVERTEXATTRIB1SNVPROC __glewVertexAttrib1sNV = NULL; +PFNGLVERTEXATTRIB1SVNVPROC __glewVertexAttrib1svNV = NULL; +PFNGLVERTEXATTRIB2DNVPROC __glewVertexAttrib2dNV = NULL; +PFNGLVERTEXATTRIB2DVNVPROC __glewVertexAttrib2dvNV = NULL; +PFNGLVERTEXATTRIB2FNVPROC __glewVertexAttrib2fNV = NULL; +PFNGLVERTEXATTRIB2FVNVPROC __glewVertexAttrib2fvNV = NULL; +PFNGLVERTEXATTRIB2SNVPROC __glewVertexAttrib2sNV = NULL; +PFNGLVERTEXATTRIB2SVNVPROC __glewVertexAttrib2svNV = NULL; +PFNGLVERTEXATTRIB3DNVPROC __glewVertexAttrib3dNV = NULL; +PFNGLVERTEXATTRIB3DVNVPROC __glewVertexAttrib3dvNV = NULL; +PFNGLVERTEXATTRIB3FNVPROC __glewVertexAttrib3fNV = NULL; +PFNGLVERTEXATTRIB3FVNVPROC __glewVertexAttrib3fvNV = NULL; +PFNGLVERTEXATTRIB3SNVPROC __glewVertexAttrib3sNV = NULL; +PFNGLVERTEXATTRIB3SVNVPROC __glewVertexAttrib3svNV = NULL; +PFNGLVERTEXATTRIB4DNVPROC __glewVertexAttrib4dNV = NULL; +PFNGLVERTEXATTRIB4DVNVPROC __glewVertexAttrib4dvNV = NULL; +PFNGLVERTEXATTRIB4FNVPROC __glewVertexAttrib4fNV = NULL; +PFNGLVERTEXATTRIB4FVNVPROC __glewVertexAttrib4fvNV = NULL; +PFNGLVERTEXATTRIB4SNVPROC __glewVertexAttrib4sNV = NULL; +PFNGLVERTEXATTRIB4SVNVPROC __glewVertexAttrib4svNV = NULL; +PFNGLVERTEXATTRIB4UBNVPROC __glewVertexAttrib4ubNV = NULL; +PFNGLVERTEXATTRIB4UBVNVPROC __glewVertexAttrib4ubvNV = NULL; +PFNGLVERTEXATTRIBPOINTERNVPROC __glewVertexAttribPointerNV = NULL; +PFNGLVERTEXATTRIBS1DVNVPROC __glewVertexAttribs1dvNV = NULL; +PFNGLVERTEXATTRIBS1FVNVPROC __glewVertexAttribs1fvNV = NULL; +PFNGLVERTEXATTRIBS1SVNVPROC __glewVertexAttribs1svNV = NULL; +PFNGLVERTEXATTRIBS2DVNVPROC __glewVertexAttribs2dvNV = NULL; +PFNGLVERTEXATTRIBS2FVNVPROC __glewVertexAttribs2fvNV = NULL; +PFNGLVERTEXATTRIBS2SVNVPROC __glewVertexAttribs2svNV = NULL; +PFNGLVERTEXATTRIBS3DVNVPROC __glewVertexAttribs3dvNV = NULL; +PFNGLVERTEXATTRIBS3FVNVPROC __glewVertexAttribs3fvNV = NULL; +PFNGLVERTEXATTRIBS3SVNVPROC __glewVertexAttribs3svNV = NULL; +PFNGLVERTEXATTRIBS4DVNVPROC __glewVertexAttribs4dvNV = NULL; +PFNGLVERTEXATTRIBS4FVNVPROC __glewVertexAttribs4fvNV = NULL; +PFNGLVERTEXATTRIBS4SVNVPROC __glewVertexAttribs4svNV = NULL; +PFNGLVERTEXATTRIBS4UBVNVPROC __glewVertexAttribs4ubvNV = NULL; + +PFNGLCLEARDEPTHFOESPROC __glewClearDepthfOES = NULL; +PFNGLCLIPPLANEFOESPROC __glewClipPlanefOES = NULL; +PFNGLDEPTHRANGEFOESPROC __glewDepthRangefOES = NULL; +PFNGLFRUSTUMFOESPROC __glewFrustumfOES = NULL; +PFNGLGETCLIPPLANEFOESPROC __glewGetClipPlanefOES = NULL; +PFNGLORTHOFOESPROC __glewOrthofOES = NULL; + +PFNGLDETAILTEXFUNCSGISPROC __glewDetailTexFuncSGIS = NULL; +PFNGLGETDETAILTEXFUNCSGISPROC __glewGetDetailTexFuncSGIS = NULL; + +PFNGLFOGFUNCSGISPROC __glewFogFuncSGIS = NULL; +PFNGLGETFOGFUNCSGISPROC __glewGetFogFuncSGIS = NULL; + +PFNGLSAMPLEMASKSGISPROC __glewSampleMaskSGIS = NULL; +PFNGLSAMPLEPATTERNSGISPROC __glewSamplePatternSGIS = NULL; + +PFNGLGETSHARPENTEXFUNCSGISPROC __glewGetSharpenTexFuncSGIS = NULL; +PFNGLSHARPENTEXFUNCSGISPROC __glewSharpenTexFuncSGIS = NULL; + +PFNGLTEXIMAGE4DSGISPROC __glewTexImage4DSGIS = NULL; +PFNGLTEXSUBIMAGE4DSGISPROC __glewTexSubImage4DSGIS = NULL; + +PFNGLGETTEXFILTERFUNCSGISPROC __glewGetTexFilterFuncSGIS = NULL; +PFNGLTEXFILTERFUNCSGISPROC __glewTexFilterFuncSGIS = NULL; + +PFNGLASYNCMARKERSGIXPROC __glewAsyncMarkerSGIX = NULL; +PFNGLDELETEASYNCMARKERSSGIXPROC __glewDeleteAsyncMarkersSGIX = NULL; +PFNGLFINISHASYNCSGIXPROC __glewFinishAsyncSGIX = NULL; +PFNGLGENASYNCMARKERSSGIXPROC __glewGenAsyncMarkersSGIX = NULL; +PFNGLISASYNCMARKERSGIXPROC __glewIsAsyncMarkerSGIX = NULL; +PFNGLPOLLASYNCSGIXPROC __glewPollAsyncSGIX = NULL; + +PFNGLFLUSHRASTERSGIXPROC __glewFlushRasterSGIX = NULL; + +PFNGLTEXTUREFOGSGIXPROC __glewTextureFogSGIX = NULL; + +PFNGLFRAGMENTCOLORMATERIALSGIXPROC __glewFragmentColorMaterialSGIX = NULL; +PFNGLFRAGMENTLIGHTMODELFSGIXPROC __glewFragmentLightModelfSGIX = NULL; +PFNGLFRAGMENTLIGHTMODELFVSGIXPROC __glewFragmentLightModelfvSGIX = NULL; +PFNGLFRAGMENTLIGHTMODELISGIXPROC __glewFragmentLightModeliSGIX = NULL; +PFNGLFRAGMENTLIGHTMODELIVSGIXPROC __glewFragmentLightModelivSGIX = NULL; +PFNGLFRAGMENTLIGHTFSGIXPROC __glewFragmentLightfSGIX = NULL; +PFNGLFRAGMENTLIGHTFVSGIXPROC __glewFragmentLightfvSGIX = NULL; +PFNGLFRAGMENTLIGHTISGIXPROC __glewFragmentLightiSGIX = NULL; +PFNGLFRAGMENTLIGHTIVSGIXPROC __glewFragmentLightivSGIX = NULL; +PFNGLFRAGMENTMATERIALFSGIXPROC __glewFragmentMaterialfSGIX = NULL; +PFNGLFRAGMENTMATERIALFVSGIXPROC __glewFragmentMaterialfvSGIX = NULL; +PFNGLFRAGMENTMATERIALISGIXPROC __glewFragmentMaterialiSGIX = NULL; +PFNGLFRAGMENTMATERIALIVSGIXPROC __glewFragmentMaterialivSGIX = NULL; +PFNGLGETFRAGMENTLIGHTFVSGIXPROC __glewGetFragmentLightfvSGIX = NULL; +PFNGLGETFRAGMENTLIGHTIVSGIXPROC __glewGetFragmentLightivSGIX = NULL; +PFNGLGETFRAGMENTMATERIALFVSGIXPROC __glewGetFragmentMaterialfvSGIX = NULL; +PFNGLGETFRAGMENTMATERIALIVSGIXPROC __glewGetFragmentMaterialivSGIX = NULL; + +PFNGLFRAMEZOOMSGIXPROC __glewFrameZoomSGIX = NULL; + +PFNGLPIXELTEXGENSGIXPROC __glewPixelTexGenSGIX = NULL; + +PFNGLREFERENCEPLANESGIXPROC __glewReferencePlaneSGIX = NULL; + +PFNGLSPRITEPARAMETERFSGIXPROC __glewSpriteParameterfSGIX = NULL; +PFNGLSPRITEPARAMETERFVSGIXPROC __glewSpriteParameterfvSGIX = NULL; +PFNGLSPRITEPARAMETERISGIXPROC __glewSpriteParameteriSGIX = NULL; +PFNGLSPRITEPARAMETERIVSGIXPROC __glewSpriteParameterivSGIX = NULL; + +PFNGLTAGSAMPLEBUFFERSGIXPROC __glewTagSampleBufferSGIX = NULL; + +PFNGLCOLORTABLEPARAMETERFVSGIPROC __glewColorTableParameterfvSGI = NULL; +PFNGLCOLORTABLEPARAMETERIVSGIPROC __glewColorTableParameterivSGI = NULL; +PFNGLCOLORTABLESGIPROC __glewColorTableSGI = NULL; +PFNGLCOPYCOLORTABLESGIPROC __glewCopyColorTableSGI = NULL; +PFNGLGETCOLORTABLEPARAMETERFVSGIPROC __glewGetColorTableParameterfvSGI = NULL; +PFNGLGETCOLORTABLEPARAMETERIVSGIPROC __glewGetColorTableParameterivSGI = NULL; +PFNGLGETCOLORTABLESGIPROC __glewGetColorTableSGI = NULL; + +PFNGLFINISHTEXTURESUNXPROC __glewFinishTextureSUNX = NULL; + +PFNGLGLOBALALPHAFACTORBSUNPROC __glewGlobalAlphaFactorbSUN = NULL; +PFNGLGLOBALALPHAFACTORDSUNPROC __glewGlobalAlphaFactordSUN = NULL; +PFNGLGLOBALALPHAFACTORFSUNPROC __glewGlobalAlphaFactorfSUN = NULL; +PFNGLGLOBALALPHAFACTORISUNPROC __glewGlobalAlphaFactoriSUN = NULL; +PFNGLGLOBALALPHAFACTORSSUNPROC __glewGlobalAlphaFactorsSUN = NULL; +PFNGLGLOBALALPHAFACTORUBSUNPROC __glewGlobalAlphaFactorubSUN = NULL; +PFNGLGLOBALALPHAFACTORUISUNPROC __glewGlobalAlphaFactoruiSUN = NULL; +PFNGLGLOBALALPHAFACTORUSSUNPROC __glewGlobalAlphaFactorusSUN = NULL; + +PFNGLREADVIDEOPIXELSSUNPROC __glewReadVideoPixelsSUN = NULL; + +PFNGLREPLACEMENTCODEPOINTERSUNPROC __glewReplacementCodePointerSUN = NULL; +PFNGLREPLACEMENTCODEUBSUNPROC __glewReplacementCodeubSUN = NULL; +PFNGLREPLACEMENTCODEUBVSUNPROC __glewReplacementCodeubvSUN = NULL; +PFNGLREPLACEMENTCODEUISUNPROC __glewReplacementCodeuiSUN = NULL; +PFNGLREPLACEMENTCODEUIVSUNPROC __glewReplacementCodeuivSUN = NULL; +PFNGLREPLACEMENTCODEUSSUNPROC __glewReplacementCodeusSUN = NULL; +PFNGLREPLACEMENTCODEUSVSUNPROC __glewReplacementCodeusvSUN = NULL; + +PFNGLCOLOR3FVERTEX3FSUNPROC __glewColor3fVertex3fSUN = NULL; +PFNGLCOLOR3FVERTEX3FVSUNPROC __glewColor3fVertex3fvSUN = NULL; +PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewColor4fNormal3fVertex3fSUN = NULL; +PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewColor4fNormal3fVertex3fvSUN = NULL; +PFNGLCOLOR4UBVERTEX2FSUNPROC __glewColor4ubVertex2fSUN = NULL; +PFNGLCOLOR4UBVERTEX2FVSUNPROC __glewColor4ubVertex2fvSUN = NULL; +PFNGLCOLOR4UBVERTEX3FSUNPROC __glewColor4ubVertex3fSUN = NULL; +PFNGLCOLOR4UBVERTEX3FVSUNPROC __glewColor4ubVertex3fvSUN = NULL; +PFNGLNORMAL3FVERTEX3FSUNPROC __glewNormal3fVertex3fSUN = NULL; +PFNGLNORMAL3FVERTEX3FVSUNPROC __glewNormal3fVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC __glewReplacementCodeuiColor3fVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor3fVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC __glewReplacementCodeuiColor4ubVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC __glewReplacementCodeuiColor4ubVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiNormal3fVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiNormal3fVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fvSUN = NULL; +PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC __glewReplacementCodeuiVertex3fSUN = NULL; +PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC __glewReplacementCodeuiVertex3fvSUN = NULL; +PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC __glewTexCoord2fColor3fVertex3fSUN = NULL; +PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC __glewTexCoord2fColor3fVertex3fvSUN = NULL; +PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fSUN = NULL; +PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fvSUN = NULL; +PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC __glewTexCoord2fColor4ubVertex3fSUN = NULL; +PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC __glewTexCoord2fColor4ubVertex3fvSUN = NULL; +PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fNormal3fVertex3fSUN = NULL; +PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fNormal3fVertex3fvSUN = NULL; +PFNGLTEXCOORD2FVERTEX3FSUNPROC __glewTexCoord2fVertex3fSUN = NULL; +PFNGLTEXCOORD2FVERTEX3FVSUNPROC __glewTexCoord2fVertex3fvSUN = NULL; +PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fSUN = NULL; +PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fvSUN = NULL; +PFNGLTEXCOORD4FVERTEX4FSUNPROC __glewTexCoord4fVertex4fSUN = NULL; +PFNGLTEXCOORD4FVERTEX4FVSUNPROC __glewTexCoord4fVertex4fvSUN = NULL; + +PFNGLADDSWAPHINTRECTWINPROC __glewAddSwapHintRectWIN = NULL; + +#endif /* !WIN32 || !GLEW_MX */ + +#if !defined(GLEW_MX) + +GLboolean __GLEW_VERSION_1_1 = GL_FALSE; +GLboolean __GLEW_VERSION_1_2 = GL_FALSE; +GLboolean __GLEW_VERSION_1_3 = GL_FALSE; +GLboolean __GLEW_VERSION_1_4 = GL_FALSE; +GLboolean __GLEW_VERSION_1_5 = GL_FALSE; +GLboolean __GLEW_VERSION_2_0 = GL_FALSE; +GLboolean __GLEW_VERSION_2_1 = GL_FALSE; +GLboolean __GLEW_VERSION_3_0 = GL_FALSE; +GLboolean __GLEW_VERSION_3_1 = GL_FALSE; +GLboolean __GLEW_VERSION_3_2 = GL_FALSE; +GLboolean __GLEW_VERSION_3_3 = GL_FALSE; +GLboolean __GLEW_VERSION_4_0 = GL_FALSE; +GLboolean __GLEW_3DFX_multisample = GL_FALSE; +GLboolean __GLEW_3DFX_tbuffer = GL_FALSE; +GLboolean __GLEW_3DFX_texture_compression_FXT1 = GL_FALSE; +GLboolean __GLEW_AMD_conservative_depth = GL_FALSE; +GLboolean __GLEW_AMD_draw_buffers_blend = GL_FALSE; +GLboolean __GLEW_AMD_performance_monitor = GL_FALSE; +GLboolean __GLEW_AMD_seamless_cubemap_per_texture = GL_FALSE; +GLboolean __GLEW_AMD_shader_stencil_export = GL_FALSE; +GLboolean __GLEW_AMD_texture_texture4 = GL_FALSE; +GLboolean __GLEW_AMD_vertex_shader_tessellator = GL_FALSE; +GLboolean __GLEW_APPLE_aux_depth_stencil = GL_FALSE; +GLboolean __GLEW_APPLE_client_storage = GL_FALSE; +GLboolean __GLEW_APPLE_element_array = GL_FALSE; +GLboolean __GLEW_APPLE_fence = GL_FALSE; +GLboolean __GLEW_APPLE_float_pixels = GL_FALSE; +GLboolean __GLEW_APPLE_flush_buffer_range = GL_FALSE; +GLboolean __GLEW_APPLE_object_purgeable = GL_FALSE; +GLboolean __GLEW_APPLE_pixel_buffer = GL_FALSE; +GLboolean __GLEW_APPLE_rgb_422 = GL_FALSE; +GLboolean __GLEW_APPLE_row_bytes = GL_FALSE; +GLboolean __GLEW_APPLE_specular_vector = GL_FALSE; +GLboolean __GLEW_APPLE_texture_range = GL_FALSE; +GLboolean __GLEW_APPLE_transform_hint = GL_FALSE; +GLboolean __GLEW_APPLE_vertex_array_object = GL_FALSE; +GLboolean __GLEW_APPLE_vertex_array_range = GL_FALSE; +GLboolean __GLEW_APPLE_vertex_program_evaluators = GL_FALSE; +GLboolean __GLEW_APPLE_ycbcr_422 = GL_FALSE; +GLboolean __GLEW_ARB_blend_func_extended = GL_FALSE; +GLboolean __GLEW_ARB_color_buffer_float = GL_FALSE; +GLboolean __GLEW_ARB_compatibility = GL_FALSE; +GLboolean __GLEW_ARB_copy_buffer = GL_FALSE; +GLboolean __GLEW_ARB_depth_buffer_float = GL_FALSE; +GLboolean __GLEW_ARB_depth_clamp = GL_FALSE; +GLboolean __GLEW_ARB_depth_texture = GL_FALSE; +GLboolean __GLEW_ARB_draw_buffers = GL_FALSE; +GLboolean __GLEW_ARB_draw_buffers_blend = GL_FALSE; +GLboolean __GLEW_ARB_draw_elements_base_vertex = GL_FALSE; +GLboolean __GLEW_ARB_draw_indirect = GL_FALSE; +GLboolean __GLEW_ARB_draw_instanced = GL_FALSE; +GLboolean __GLEW_ARB_explicit_attrib_location = GL_FALSE; +GLboolean __GLEW_ARB_fragment_coord_conventions = GL_FALSE; +GLboolean __GLEW_ARB_fragment_program = GL_FALSE; +GLboolean __GLEW_ARB_fragment_program_shadow = GL_FALSE; +GLboolean __GLEW_ARB_fragment_shader = GL_FALSE; +GLboolean __GLEW_ARB_framebuffer_object = GL_FALSE; +GLboolean __GLEW_ARB_framebuffer_sRGB = GL_FALSE; +GLboolean __GLEW_ARB_geometry_shader4 = GL_FALSE; +GLboolean __GLEW_ARB_gpu_shader5 = GL_FALSE; +GLboolean __GLEW_ARB_gpu_shader_fp64 = GL_FALSE; +GLboolean __GLEW_ARB_half_float_pixel = GL_FALSE; +GLboolean __GLEW_ARB_half_float_vertex = GL_FALSE; +GLboolean __GLEW_ARB_imaging = GL_FALSE; +GLboolean __GLEW_ARB_instanced_arrays = GL_FALSE; +GLboolean __GLEW_ARB_map_buffer_range = GL_FALSE; +GLboolean __GLEW_ARB_matrix_palette = GL_FALSE; +GLboolean __GLEW_ARB_multisample = GL_FALSE; +GLboolean __GLEW_ARB_multitexture = GL_FALSE; +GLboolean __GLEW_ARB_occlusion_query = GL_FALSE; +GLboolean __GLEW_ARB_occlusion_query2 = GL_FALSE; +GLboolean __GLEW_ARB_pixel_buffer_object = GL_FALSE; +GLboolean __GLEW_ARB_point_parameters = GL_FALSE; +GLboolean __GLEW_ARB_point_sprite = GL_FALSE; +GLboolean __GLEW_ARB_provoking_vertex = GL_FALSE; +GLboolean __GLEW_ARB_sample_shading = GL_FALSE; +GLboolean __GLEW_ARB_sampler_objects = GL_FALSE; +GLboolean __GLEW_ARB_seamless_cube_map = GL_FALSE; +GLboolean __GLEW_ARB_shader_bit_encoding = GL_FALSE; +GLboolean __GLEW_ARB_shader_objects = GL_FALSE; +GLboolean __GLEW_ARB_shader_subroutine = GL_FALSE; +GLboolean __GLEW_ARB_shader_texture_lod = GL_FALSE; +GLboolean __GLEW_ARB_shading_language_100 = GL_FALSE; +GLboolean __GLEW_ARB_shading_language_include = GL_FALSE; +GLboolean __GLEW_ARB_shadow = GL_FALSE; +GLboolean __GLEW_ARB_shadow_ambient = GL_FALSE; +GLboolean __GLEW_ARB_sync = GL_FALSE; +GLboolean __GLEW_ARB_tessellation_shader = GL_FALSE; +GLboolean __GLEW_ARB_texture_border_clamp = GL_FALSE; +GLboolean __GLEW_ARB_texture_buffer_object = GL_FALSE; +GLboolean __GLEW_ARB_texture_buffer_object_rgb32 = GL_FALSE; +GLboolean __GLEW_ARB_texture_compression = GL_FALSE; +GLboolean __GLEW_ARB_texture_compression_bptc = GL_FALSE; +GLboolean __GLEW_ARB_texture_compression_rgtc = GL_FALSE; +GLboolean __GLEW_ARB_texture_cube_map = GL_FALSE; +GLboolean __GLEW_ARB_texture_cube_map_array = GL_FALSE; +GLboolean __GLEW_ARB_texture_env_add = GL_FALSE; +GLboolean __GLEW_ARB_texture_env_combine = GL_FALSE; +GLboolean __GLEW_ARB_texture_env_crossbar = GL_FALSE; +GLboolean __GLEW_ARB_texture_env_dot3 = GL_FALSE; +GLboolean __GLEW_ARB_texture_float = GL_FALSE; +GLboolean __GLEW_ARB_texture_gather = GL_FALSE; +GLboolean __GLEW_ARB_texture_mirrored_repeat = GL_FALSE; +GLboolean __GLEW_ARB_texture_multisample = GL_FALSE; +GLboolean __GLEW_ARB_texture_non_power_of_two = GL_FALSE; +GLboolean __GLEW_ARB_texture_query_lod = GL_FALSE; +GLboolean __GLEW_ARB_texture_rectangle = GL_FALSE; +GLboolean __GLEW_ARB_texture_rg = GL_FALSE; +GLboolean __GLEW_ARB_texture_rgb10_a2ui = GL_FALSE; +GLboolean __GLEW_ARB_texture_swizzle = GL_FALSE; +GLboolean __GLEW_ARB_timer_query = GL_FALSE; +GLboolean __GLEW_ARB_transform_feedback2 = GL_FALSE; +GLboolean __GLEW_ARB_transform_feedback3 = GL_FALSE; +GLboolean __GLEW_ARB_transpose_matrix = GL_FALSE; +GLboolean __GLEW_ARB_uniform_buffer_object = GL_FALSE; +GLboolean __GLEW_ARB_vertex_array_bgra = GL_FALSE; +GLboolean __GLEW_ARB_vertex_array_object = GL_FALSE; +GLboolean __GLEW_ARB_vertex_blend = GL_FALSE; +GLboolean __GLEW_ARB_vertex_buffer_object = GL_FALSE; +GLboolean __GLEW_ARB_vertex_program = GL_FALSE; +GLboolean __GLEW_ARB_vertex_shader = GL_FALSE; +GLboolean __GLEW_ARB_vertex_type_2_10_10_10_rev = GL_FALSE; +GLboolean __GLEW_ARB_window_pos = GL_FALSE; +GLboolean __GLEW_ATIX_point_sprites = GL_FALSE; +GLboolean __GLEW_ATIX_texture_env_combine3 = GL_FALSE; +GLboolean __GLEW_ATIX_texture_env_route = GL_FALSE; +GLboolean __GLEW_ATIX_vertex_shader_output_point_size = GL_FALSE; +GLboolean __GLEW_ATI_draw_buffers = GL_FALSE; +GLboolean __GLEW_ATI_element_array = GL_FALSE; +GLboolean __GLEW_ATI_envmap_bumpmap = GL_FALSE; +GLboolean __GLEW_ATI_fragment_shader = GL_FALSE; +GLboolean __GLEW_ATI_map_object_buffer = GL_FALSE; +GLboolean __GLEW_ATI_meminfo = GL_FALSE; +GLboolean __GLEW_ATI_pn_triangles = GL_FALSE; +GLboolean __GLEW_ATI_separate_stencil = GL_FALSE; +GLboolean __GLEW_ATI_shader_texture_lod = GL_FALSE; +GLboolean __GLEW_ATI_text_fragment_shader = GL_FALSE; +GLboolean __GLEW_ATI_texture_compression_3dc = GL_FALSE; +GLboolean __GLEW_ATI_texture_env_combine3 = GL_FALSE; +GLboolean __GLEW_ATI_texture_float = GL_FALSE; +GLboolean __GLEW_ATI_texture_mirror_once = GL_FALSE; +GLboolean __GLEW_ATI_vertex_array_object = GL_FALSE; +GLboolean __GLEW_ATI_vertex_attrib_array_object = GL_FALSE; +GLboolean __GLEW_ATI_vertex_streams = GL_FALSE; +GLboolean __GLEW_EXT_422_pixels = GL_FALSE; +GLboolean __GLEW_EXT_Cg_shader = GL_FALSE; +GLboolean __GLEW_EXT_abgr = GL_FALSE; +GLboolean __GLEW_EXT_bgra = GL_FALSE; +GLboolean __GLEW_EXT_bindable_uniform = GL_FALSE; +GLboolean __GLEW_EXT_blend_color = GL_FALSE; +GLboolean __GLEW_EXT_blend_equation_separate = GL_FALSE; +GLboolean __GLEW_EXT_blend_func_separate = GL_FALSE; +GLboolean __GLEW_EXT_blend_logic_op = GL_FALSE; +GLboolean __GLEW_EXT_blend_minmax = GL_FALSE; +GLboolean __GLEW_EXT_blend_subtract = GL_FALSE; +GLboolean __GLEW_EXT_clip_volume_hint = GL_FALSE; +GLboolean __GLEW_EXT_cmyka = GL_FALSE; +GLboolean __GLEW_EXT_color_subtable = GL_FALSE; +GLboolean __GLEW_EXT_compiled_vertex_array = GL_FALSE; +GLboolean __GLEW_EXT_convolution = GL_FALSE; +GLboolean __GLEW_EXT_coordinate_frame = GL_FALSE; +GLboolean __GLEW_EXT_copy_texture = GL_FALSE; +GLboolean __GLEW_EXT_cull_vertex = GL_FALSE; +GLboolean __GLEW_EXT_depth_bounds_test = GL_FALSE; +GLboolean __GLEW_EXT_direct_state_access = GL_FALSE; +GLboolean __GLEW_EXT_draw_buffers2 = GL_FALSE; +GLboolean __GLEW_EXT_draw_instanced = GL_FALSE; +GLboolean __GLEW_EXT_draw_range_elements = GL_FALSE; +GLboolean __GLEW_EXT_fog_coord = GL_FALSE; +GLboolean __GLEW_EXT_fragment_lighting = GL_FALSE; +GLboolean __GLEW_EXT_framebuffer_blit = GL_FALSE; +GLboolean __GLEW_EXT_framebuffer_multisample = GL_FALSE; +GLboolean __GLEW_EXT_framebuffer_object = GL_FALSE; +GLboolean __GLEW_EXT_framebuffer_sRGB = GL_FALSE; +GLboolean __GLEW_EXT_geometry_shader4 = GL_FALSE; +GLboolean __GLEW_EXT_gpu_program_parameters = GL_FALSE; +GLboolean __GLEW_EXT_gpu_shader4 = GL_FALSE; +GLboolean __GLEW_EXT_histogram = GL_FALSE; +GLboolean __GLEW_EXT_index_array_formats = GL_FALSE; +GLboolean __GLEW_EXT_index_func = GL_FALSE; +GLboolean __GLEW_EXT_index_material = GL_FALSE; +GLboolean __GLEW_EXT_index_texture = GL_FALSE; +GLboolean __GLEW_EXT_light_texture = GL_FALSE; +GLboolean __GLEW_EXT_misc_attribute = GL_FALSE; +GLboolean __GLEW_EXT_multi_draw_arrays = GL_FALSE; +GLboolean __GLEW_EXT_multisample = GL_FALSE; +GLboolean __GLEW_EXT_packed_depth_stencil = GL_FALSE; +GLboolean __GLEW_EXT_packed_float = GL_FALSE; +GLboolean __GLEW_EXT_packed_pixels = GL_FALSE; +GLboolean __GLEW_EXT_paletted_texture = GL_FALSE; +GLboolean __GLEW_EXT_pixel_buffer_object = GL_FALSE; +GLboolean __GLEW_EXT_pixel_transform = GL_FALSE; +GLboolean __GLEW_EXT_pixel_transform_color_table = GL_FALSE; +GLboolean __GLEW_EXT_point_parameters = GL_FALSE; +GLboolean __GLEW_EXT_polygon_offset = GL_FALSE; +GLboolean __GLEW_EXT_provoking_vertex = GL_FALSE; +GLboolean __GLEW_EXT_rescale_normal = GL_FALSE; +GLboolean __GLEW_EXT_scene_marker = GL_FALSE; +GLboolean __GLEW_EXT_secondary_color = GL_FALSE; +GLboolean __GLEW_EXT_separate_shader_objects = GL_FALSE; +GLboolean __GLEW_EXT_separate_specular_color = GL_FALSE; +GLboolean __GLEW_EXT_shader_image_load_store = GL_FALSE; +GLboolean __GLEW_EXT_shadow_funcs = GL_FALSE; +GLboolean __GLEW_EXT_shared_texture_palette = GL_FALSE; +GLboolean __GLEW_EXT_stencil_clear_tag = GL_FALSE; +GLboolean __GLEW_EXT_stencil_two_side = GL_FALSE; +GLboolean __GLEW_EXT_stencil_wrap = GL_FALSE; +GLboolean __GLEW_EXT_subtexture = GL_FALSE; +GLboolean __GLEW_EXT_texture = GL_FALSE; +GLboolean __GLEW_EXT_texture3D = GL_FALSE; +GLboolean __GLEW_EXT_texture_array = GL_FALSE; +GLboolean __GLEW_EXT_texture_buffer_object = GL_FALSE; +GLboolean __GLEW_EXT_texture_compression_dxt1 = GL_FALSE; +GLboolean __GLEW_EXT_texture_compression_latc = GL_FALSE; +GLboolean __GLEW_EXT_texture_compression_rgtc = GL_FALSE; +GLboolean __GLEW_EXT_texture_compression_s3tc = GL_FALSE; +GLboolean __GLEW_EXT_texture_cube_map = GL_FALSE; +GLboolean __GLEW_EXT_texture_edge_clamp = GL_FALSE; +GLboolean __GLEW_EXT_texture_env = GL_FALSE; +GLboolean __GLEW_EXT_texture_env_add = GL_FALSE; +GLboolean __GLEW_EXT_texture_env_combine = GL_FALSE; +GLboolean __GLEW_EXT_texture_env_dot3 = GL_FALSE; +GLboolean __GLEW_EXT_texture_filter_anisotropic = GL_FALSE; +GLboolean __GLEW_EXT_texture_integer = GL_FALSE; +GLboolean __GLEW_EXT_texture_lod_bias = GL_FALSE; +GLboolean __GLEW_EXT_texture_mirror_clamp = GL_FALSE; +GLboolean __GLEW_EXT_texture_object = GL_FALSE; +GLboolean __GLEW_EXT_texture_perturb_normal = GL_FALSE; +GLboolean __GLEW_EXT_texture_rectangle = GL_FALSE; +GLboolean __GLEW_EXT_texture_sRGB = GL_FALSE; +GLboolean __GLEW_EXT_texture_shared_exponent = GL_FALSE; +GLboolean __GLEW_EXT_texture_snorm = GL_FALSE; +GLboolean __GLEW_EXT_texture_swizzle = GL_FALSE; +GLboolean __GLEW_EXT_timer_query = GL_FALSE; +GLboolean __GLEW_EXT_transform_feedback = GL_FALSE; +GLboolean __GLEW_EXT_vertex_array = GL_FALSE; +GLboolean __GLEW_EXT_vertex_array_bgra = GL_FALSE; +GLboolean __GLEW_EXT_vertex_attrib_64bit = GL_FALSE; +GLboolean __GLEW_EXT_vertex_shader = GL_FALSE; +GLboolean __GLEW_EXT_vertex_weighting = GL_FALSE; +GLboolean __GLEW_GREMEDY_frame_terminator = GL_FALSE; +GLboolean __GLEW_GREMEDY_string_marker = GL_FALSE; +GLboolean __GLEW_HP_convolution_border_modes = GL_FALSE; +GLboolean __GLEW_HP_image_transform = GL_FALSE; +GLboolean __GLEW_HP_occlusion_test = GL_FALSE; +GLboolean __GLEW_HP_texture_lighting = GL_FALSE; +GLboolean __GLEW_IBM_cull_vertex = GL_FALSE; +GLboolean __GLEW_IBM_multimode_draw_arrays = GL_FALSE; +GLboolean __GLEW_IBM_rasterpos_clip = GL_FALSE; +GLboolean __GLEW_IBM_static_data = GL_FALSE; +GLboolean __GLEW_IBM_texture_mirrored_repeat = GL_FALSE; +GLboolean __GLEW_IBM_vertex_array_lists = GL_FALSE; +GLboolean __GLEW_INGR_color_clamp = GL_FALSE; +GLboolean __GLEW_INGR_interlace_read = GL_FALSE; +GLboolean __GLEW_INTEL_parallel_arrays = GL_FALSE; +GLboolean __GLEW_INTEL_texture_scissor = GL_FALSE; +GLboolean __GLEW_KTX_buffer_region = GL_FALSE; +GLboolean __GLEW_MESAX_texture_stack = GL_FALSE; +GLboolean __GLEW_MESA_pack_invert = GL_FALSE; +GLboolean __GLEW_MESA_resize_buffers = GL_FALSE; +GLboolean __GLEW_MESA_window_pos = GL_FALSE; +GLboolean __GLEW_MESA_ycbcr_texture = GL_FALSE; +GLboolean __GLEW_NV_blend_square = GL_FALSE; +GLboolean __GLEW_NV_conditional_render = GL_FALSE; +GLboolean __GLEW_NV_copy_depth_to_color = GL_FALSE; +GLboolean __GLEW_NV_copy_image = GL_FALSE; +GLboolean __GLEW_NV_depth_buffer_float = GL_FALSE; +GLboolean __GLEW_NV_depth_clamp = GL_FALSE; +GLboolean __GLEW_NV_depth_range_unclamped = GL_FALSE; +GLboolean __GLEW_NV_evaluators = GL_FALSE; +GLboolean __GLEW_NV_explicit_multisample = GL_FALSE; +GLboolean __GLEW_NV_fence = GL_FALSE; +GLboolean __GLEW_NV_float_buffer = GL_FALSE; +GLboolean __GLEW_NV_fog_distance = GL_FALSE; +GLboolean __GLEW_NV_fragment_program = GL_FALSE; +GLboolean __GLEW_NV_fragment_program2 = GL_FALSE; +GLboolean __GLEW_NV_fragment_program4 = GL_FALSE; +GLboolean __GLEW_NV_fragment_program_option = GL_FALSE; +GLboolean __GLEW_NV_framebuffer_multisample_coverage = GL_FALSE; +GLboolean __GLEW_NV_geometry_program4 = GL_FALSE; +GLboolean __GLEW_NV_geometry_shader4 = GL_FALSE; +GLboolean __GLEW_NV_gpu_program4 = GL_FALSE; +GLboolean __GLEW_NV_gpu_program5 = GL_FALSE; +GLboolean __GLEW_NV_gpu_program_fp64 = GL_FALSE; +GLboolean __GLEW_NV_gpu_shader5 = GL_FALSE; +GLboolean __GLEW_NV_half_float = GL_FALSE; +GLboolean __GLEW_NV_light_max_exponent = GL_FALSE; +GLboolean __GLEW_NV_multisample_filter_hint = GL_FALSE; +GLboolean __GLEW_NV_occlusion_query = GL_FALSE; +GLboolean __GLEW_NV_packed_depth_stencil = GL_FALSE; +GLboolean __GLEW_NV_parameter_buffer_object = GL_FALSE; +GLboolean __GLEW_NV_parameter_buffer_object2 = GL_FALSE; +GLboolean __GLEW_NV_pixel_data_range = GL_FALSE; +GLboolean __GLEW_NV_point_sprite = GL_FALSE; +GLboolean __GLEW_NV_present_video = GL_FALSE; +GLboolean __GLEW_NV_primitive_restart = GL_FALSE; +GLboolean __GLEW_NV_register_combiners = GL_FALSE; +GLboolean __GLEW_NV_register_combiners2 = GL_FALSE; +GLboolean __GLEW_NV_shader_buffer_load = GL_FALSE; +GLboolean __GLEW_NV_tessellation_program5 = GL_FALSE; +GLboolean __GLEW_NV_texgen_emboss = GL_FALSE; +GLboolean __GLEW_NV_texgen_reflection = GL_FALSE; +GLboolean __GLEW_NV_texture_barrier = GL_FALSE; +GLboolean __GLEW_NV_texture_compression_vtc = GL_FALSE; +GLboolean __GLEW_NV_texture_env_combine4 = GL_FALSE; +GLboolean __GLEW_NV_texture_expand_normal = GL_FALSE; +GLboolean __GLEW_NV_texture_rectangle = GL_FALSE; +GLboolean __GLEW_NV_texture_shader = GL_FALSE; +GLboolean __GLEW_NV_texture_shader2 = GL_FALSE; +GLboolean __GLEW_NV_texture_shader3 = GL_FALSE; +GLboolean __GLEW_NV_transform_feedback = GL_FALSE; +GLboolean __GLEW_NV_transform_feedback2 = GL_FALSE; +GLboolean __GLEW_NV_vertex_array_range = GL_FALSE; +GLboolean __GLEW_NV_vertex_array_range2 = GL_FALSE; +GLboolean __GLEW_NV_vertex_attrib_integer_64bit = GL_FALSE; +GLboolean __GLEW_NV_vertex_buffer_unified_memory = GL_FALSE; +GLboolean __GLEW_NV_vertex_program = GL_FALSE; +GLboolean __GLEW_NV_vertex_program1_1 = GL_FALSE; +GLboolean __GLEW_NV_vertex_program2 = GL_FALSE; +GLboolean __GLEW_NV_vertex_program2_option = GL_FALSE; +GLboolean __GLEW_NV_vertex_program3 = GL_FALSE; +GLboolean __GLEW_NV_vertex_program4 = GL_FALSE; +GLboolean __GLEW_OES_byte_coordinates = GL_FALSE; +GLboolean __GLEW_OES_compressed_paletted_texture = GL_FALSE; +GLboolean __GLEW_OES_read_format = GL_FALSE; +GLboolean __GLEW_OES_single_precision = GL_FALSE; +GLboolean __GLEW_OML_interlace = GL_FALSE; +GLboolean __GLEW_OML_resample = GL_FALSE; +GLboolean __GLEW_OML_subsample = GL_FALSE; +GLboolean __GLEW_PGI_misc_hints = GL_FALSE; +GLboolean __GLEW_PGI_vertex_hints = GL_FALSE; +GLboolean __GLEW_REND_screen_coordinates = GL_FALSE; +GLboolean __GLEW_S3_s3tc = GL_FALSE; +GLboolean __GLEW_SGIS_color_range = GL_FALSE; +GLboolean __GLEW_SGIS_detail_texture = GL_FALSE; +GLboolean __GLEW_SGIS_fog_function = GL_FALSE; +GLboolean __GLEW_SGIS_generate_mipmap = GL_FALSE; +GLboolean __GLEW_SGIS_multisample = GL_FALSE; +GLboolean __GLEW_SGIS_pixel_texture = GL_FALSE; +GLboolean __GLEW_SGIS_point_line_texgen = GL_FALSE; +GLboolean __GLEW_SGIS_sharpen_texture = GL_FALSE; +GLboolean __GLEW_SGIS_texture4D = GL_FALSE; +GLboolean __GLEW_SGIS_texture_border_clamp = GL_FALSE; +GLboolean __GLEW_SGIS_texture_edge_clamp = GL_FALSE; +GLboolean __GLEW_SGIS_texture_filter4 = GL_FALSE; +GLboolean __GLEW_SGIS_texture_lod = GL_FALSE; +GLboolean __GLEW_SGIS_texture_select = GL_FALSE; +GLboolean __GLEW_SGIX_async = GL_FALSE; +GLboolean __GLEW_SGIX_async_histogram = GL_FALSE; +GLboolean __GLEW_SGIX_async_pixel = GL_FALSE; +GLboolean __GLEW_SGIX_blend_alpha_minmax = GL_FALSE; +GLboolean __GLEW_SGIX_clipmap = GL_FALSE; +GLboolean __GLEW_SGIX_convolution_accuracy = GL_FALSE; +GLboolean __GLEW_SGIX_depth_texture = GL_FALSE; +GLboolean __GLEW_SGIX_flush_raster = GL_FALSE; +GLboolean __GLEW_SGIX_fog_offset = GL_FALSE; +GLboolean __GLEW_SGIX_fog_texture = GL_FALSE; +GLboolean __GLEW_SGIX_fragment_specular_lighting = GL_FALSE; +GLboolean __GLEW_SGIX_framezoom = GL_FALSE; +GLboolean __GLEW_SGIX_interlace = GL_FALSE; +GLboolean __GLEW_SGIX_ir_instrument1 = GL_FALSE; +GLboolean __GLEW_SGIX_list_priority = GL_FALSE; +GLboolean __GLEW_SGIX_pixel_texture = GL_FALSE; +GLboolean __GLEW_SGIX_pixel_texture_bits = GL_FALSE; +GLboolean __GLEW_SGIX_reference_plane = GL_FALSE; +GLboolean __GLEW_SGIX_resample = GL_FALSE; +GLboolean __GLEW_SGIX_shadow = GL_FALSE; +GLboolean __GLEW_SGIX_shadow_ambient = GL_FALSE; +GLboolean __GLEW_SGIX_sprite = GL_FALSE; +GLboolean __GLEW_SGIX_tag_sample_buffer = GL_FALSE; +GLboolean __GLEW_SGIX_texture_add_env = GL_FALSE; +GLboolean __GLEW_SGIX_texture_coordinate_clamp = GL_FALSE; +GLboolean __GLEW_SGIX_texture_lod_bias = GL_FALSE; +GLboolean __GLEW_SGIX_texture_multi_buffer = GL_FALSE; +GLboolean __GLEW_SGIX_texture_range = GL_FALSE; +GLboolean __GLEW_SGIX_texture_scale_bias = GL_FALSE; +GLboolean __GLEW_SGIX_vertex_preclip = GL_FALSE; +GLboolean __GLEW_SGIX_vertex_preclip_hint = GL_FALSE; +GLboolean __GLEW_SGIX_ycrcb = GL_FALSE; +GLboolean __GLEW_SGI_color_matrix = GL_FALSE; +GLboolean __GLEW_SGI_color_table = GL_FALSE; +GLboolean __GLEW_SGI_texture_color_table = GL_FALSE; +GLboolean __GLEW_SUNX_constant_data = GL_FALSE; +GLboolean __GLEW_SUN_convolution_border_modes = GL_FALSE; +GLboolean __GLEW_SUN_global_alpha = GL_FALSE; +GLboolean __GLEW_SUN_mesh_array = GL_FALSE; +GLboolean __GLEW_SUN_read_video_pixels = GL_FALSE; +GLboolean __GLEW_SUN_slice_accum = GL_FALSE; +GLboolean __GLEW_SUN_triangle_list = GL_FALSE; +GLboolean __GLEW_SUN_vertex = GL_FALSE; +GLboolean __GLEW_WIN_phong_shading = GL_FALSE; +GLboolean __GLEW_WIN_specular_fog = GL_FALSE; +GLboolean __GLEW_WIN_swap_hint = GL_FALSE; + +#endif /* !GLEW_MX */ + +#ifdef GL_VERSION_1_2 + +static GLboolean _glewInit_GL_VERSION_1_2 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCopyTexSubImage3D = (PFNGLCOPYTEXSUBIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage3D")) == NULL) || r; + r = ((glDrawRangeElements = (PFNGLDRAWRANGEELEMENTSPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElements")) == NULL) || r; + r = ((glTexImage3D = (PFNGLTEXIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glTexImage3D")) == NULL) || r; + r = ((glTexSubImage3D = (PFNGLTEXSUBIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage3D")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_1_2 */ + +#ifdef GL_VERSION_1_3 + +static GLboolean _glewInit_GL_VERSION_1_3 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glActiveTexture = (PFNGLACTIVETEXTUREPROC)glewGetProcAddress((const GLubyte*)"glActiveTexture")) == NULL) || r; + r = ((glClientActiveTexture = (PFNGLCLIENTACTIVETEXTUREPROC)glewGetProcAddress((const GLubyte*)"glClientActiveTexture")) == NULL) || r; + r = ((glCompressedTexImage1D = (PFNGLCOMPRESSEDTEXIMAGE1DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage1D")) == NULL) || r; + r = ((glCompressedTexImage2D = (PFNGLCOMPRESSEDTEXIMAGE2DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage2D")) == NULL) || r; + r = ((glCompressedTexImage3D = (PFNGLCOMPRESSEDTEXIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage3D")) == NULL) || r; + r = ((glCompressedTexSubImage1D = (PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage1D")) == NULL) || r; + r = ((glCompressedTexSubImage2D = (PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage2D")) == NULL) || r; + r = ((glCompressedTexSubImage3D = (PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage3D")) == NULL) || r; + r = ((glGetCompressedTexImage = (PFNGLGETCOMPRESSEDTEXIMAGEPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedTexImage")) == NULL) || r; + r = ((glLoadTransposeMatrixd = (PFNGLLOADTRANSPOSEMATRIXDPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixd")) == NULL) || r; + r = ((glLoadTransposeMatrixf = (PFNGLLOADTRANSPOSEMATRIXFPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixf")) == NULL) || r; + r = ((glMultTransposeMatrixd = (PFNGLMULTTRANSPOSEMATRIXDPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixd")) == NULL) || r; + r = ((glMultTransposeMatrixf = (PFNGLMULTTRANSPOSEMATRIXFPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixf")) == NULL) || r; + r = ((glMultiTexCoord1d = (PFNGLMULTITEXCOORD1DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1d")) == NULL) || r; + r = ((glMultiTexCoord1dv = (PFNGLMULTITEXCOORD1DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1dv")) == NULL) || r; + r = ((glMultiTexCoord1f = (PFNGLMULTITEXCOORD1FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1f")) == NULL) || r; + r = ((glMultiTexCoord1fv = (PFNGLMULTITEXCOORD1FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1fv")) == NULL) || r; + r = ((glMultiTexCoord1i = (PFNGLMULTITEXCOORD1IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1i")) == NULL) || r; + r = ((glMultiTexCoord1iv = (PFNGLMULTITEXCOORD1IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1iv")) == NULL) || r; + r = ((glMultiTexCoord1s = (PFNGLMULTITEXCOORD1SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1s")) == NULL) || r; + r = ((glMultiTexCoord1sv = (PFNGLMULTITEXCOORD1SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1sv")) == NULL) || r; + r = ((glMultiTexCoord2d = (PFNGLMULTITEXCOORD2DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2d")) == NULL) || r; + r = ((glMultiTexCoord2dv = (PFNGLMULTITEXCOORD2DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2dv")) == NULL) || r; + r = ((glMultiTexCoord2f = (PFNGLMULTITEXCOORD2FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2f")) == NULL) || r; + r = ((glMultiTexCoord2fv = (PFNGLMULTITEXCOORD2FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2fv")) == NULL) || r; + r = ((glMultiTexCoord2i = (PFNGLMULTITEXCOORD2IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2i")) == NULL) || r; + r = ((glMultiTexCoord2iv = (PFNGLMULTITEXCOORD2IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2iv")) == NULL) || r; + r = ((glMultiTexCoord2s = (PFNGLMULTITEXCOORD2SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2s")) == NULL) || r; + r = ((glMultiTexCoord2sv = (PFNGLMULTITEXCOORD2SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2sv")) == NULL) || r; + r = ((glMultiTexCoord3d = (PFNGLMULTITEXCOORD3DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3d")) == NULL) || r; + r = ((glMultiTexCoord3dv = (PFNGLMULTITEXCOORD3DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3dv")) == NULL) || r; + r = ((glMultiTexCoord3f = (PFNGLMULTITEXCOORD3FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3f")) == NULL) || r; + r = ((glMultiTexCoord3fv = (PFNGLMULTITEXCOORD3FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3fv")) == NULL) || r; + r = ((glMultiTexCoord3i = (PFNGLMULTITEXCOORD3IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3i")) == NULL) || r; + r = ((glMultiTexCoord3iv = (PFNGLMULTITEXCOORD3IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3iv")) == NULL) || r; + r = ((glMultiTexCoord3s = (PFNGLMULTITEXCOORD3SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3s")) == NULL) || r; + r = ((glMultiTexCoord3sv = (PFNGLMULTITEXCOORD3SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3sv")) == NULL) || r; + r = ((glMultiTexCoord4d = (PFNGLMULTITEXCOORD4DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4d")) == NULL) || r; + r = ((glMultiTexCoord4dv = (PFNGLMULTITEXCOORD4DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4dv")) == NULL) || r; + r = ((glMultiTexCoord4f = (PFNGLMULTITEXCOORD4FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4f")) == NULL) || r; + r = ((glMultiTexCoord4fv = (PFNGLMULTITEXCOORD4FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4fv")) == NULL) || r; + r = ((glMultiTexCoord4i = (PFNGLMULTITEXCOORD4IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4i")) == NULL) || r; + r = ((glMultiTexCoord4iv = (PFNGLMULTITEXCOORD4IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4iv")) == NULL) || r; + r = ((glMultiTexCoord4s = (PFNGLMULTITEXCOORD4SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4s")) == NULL) || r; + r = ((glMultiTexCoord4sv = (PFNGLMULTITEXCOORD4SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4sv")) == NULL) || r; + r = ((glSampleCoverage = (PFNGLSAMPLECOVERAGEPROC)glewGetProcAddress((const GLubyte*)"glSampleCoverage")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_1_3 */ + +#ifdef GL_VERSION_1_4 + +static GLboolean _glewInit_GL_VERSION_1_4 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendColor = (PFNGLBLENDCOLORPROC)glewGetProcAddress((const GLubyte*)"glBlendColor")) == NULL) || r; + r = ((glBlendEquation = (PFNGLBLENDEQUATIONPROC)glewGetProcAddress((const GLubyte*)"glBlendEquation")) == NULL) || r; + r = ((glBlendFuncSeparate = (PFNGLBLENDFUNCSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparate")) == NULL) || r; + r = ((glFogCoordPointer = (PFNGLFOGCOORDPOINTERPROC)glewGetProcAddress((const GLubyte*)"glFogCoordPointer")) == NULL) || r; + r = ((glFogCoordd = (PFNGLFOGCOORDDPROC)glewGetProcAddress((const GLubyte*)"glFogCoordd")) == NULL) || r; + r = ((glFogCoorddv = (PFNGLFOGCOORDDVPROC)glewGetProcAddress((const GLubyte*)"glFogCoorddv")) == NULL) || r; + r = ((glFogCoordf = (PFNGLFOGCOORDFPROC)glewGetProcAddress((const GLubyte*)"glFogCoordf")) == NULL) || r; + r = ((glFogCoordfv = (PFNGLFOGCOORDFVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordfv")) == NULL) || r; + r = ((glMultiDrawArrays = (PFNGLMULTIDRAWARRAYSPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArrays")) == NULL) || r; + r = ((glMultiDrawElements = (PFNGLMULTIDRAWELEMENTSPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElements")) == NULL) || r; + r = ((glPointParameterf = (PFNGLPOINTPARAMETERFPROC)glewGetProcAddress((const GLubyte*)"glPointParameterf")) == NULL) || r; + r = ((glPointParameterfv = (PFNGLPOINTPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfv")) == NULL) || r; + r = ((glPointParameteri = (PFNGLPOINTPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glPointParameteri")) == NULL) || r; + r = ((glPointParameteriv = (PFNGLPOINTPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glPointParameteriv")) == NULL) || r; + r = ((glSecondaryColor3b = (PFNGLSECONDARYCOLOR3BPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3b")) == NULL) || r; + r = ((glSecondaryColor3bv = (PFNGLSECONDARYCOLOR3BVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3bv")) == NULL) || r; + r = ((glSecondaryColor3d = (PFNGLSECONDARYCOLOR3DPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3d")) == NULL) || r; + r = ((glSecondaryColor3dv = (PFNGLSECONDARYCOLOR3DVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3dv")) == NULL) || r; + r = ((glSecondaryColor3f = (PFNGLSECONDARYCOLOR3FPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3f")) == NULL) || r; + r = ((glSecondaryColor3fv = (PFNGLSECONDARYCOLOR3FVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3fv")) == NULL) || r; + r = ((glSecondaryColor3i = (PFNGLSECONDARYCOLOR3IPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3i")) == NULL) || r; + r = ((glSecondaryColor3iv = (PFNGLSECONDARYCOLOR3IVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3iv")) == NULL) || r; + r = ((glSecondaryColor3s = (PFNGLSECONDARYCOLOR3SPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3s")) == NULL) || r; + r = ((glSecondaryColor3sv = (PFNGLSECONDARYCOLOR3SVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3sv")) == NULL) || r; + r = ((glSecondaryColor3ub = (PFNGLSECONDARYCOLOR3UBPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ub")) == NULL) || r; + r = ((glSecondaryColor3ubv = (PFNGLSECONDARYCOLOR3UBVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ubv")) == NULL) || r; + r = ((glSecondaryColor3ui = (PFNGLSECONDARYCOLOR3UIPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ui")) == NULL) || r; + r = ((glSecondaryColor3uiv = (PFNGLSECONDARYCOLOR3UIVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3uiv")) == NULL) || r; + r = ((glSecondaryColor3us = (PFNGLSECONDARYCOLOR3USPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3us")) == NULL) || r; + r = ((glSecondaryColor3usv = (PFNGLSECONDARYCOLOR3USVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3usv")) == NULL) || r; + r = ((glSecondaryColorPointer = (PFNGLSECONDARYCOLORPOINTERPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorPointer")) == NULL) || r; + r = ((glWindowPos2d = (PFNGLWINDOWPOS2DPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2d")) == NULL) || r; + r = ((glWindowPos2dv = (PFNGLWINDOWPOS2DVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dv")) == NULL) || r; + r = ((glWindowPos2f = (PFNGLWINDOWPOS2FPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2f")) == NULL) || r; + r = ((glWindowPos2fv = (PFNGLWINDOWPOS2FVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fv")) == NULL) || r; + r = ((glWindowPos2i = (PFNGLWINDOWPOS2IPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2i")) == NULL) || r; + r = ((glWindowPos2iv = (PFNGLWINDOWPOS2IVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2iv")) == NULL) || r; + r = ((glWindowPos2s = (PFNGLWINDOWPOS2SPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2s")) == NULL) || r; + r = ((glWindowPos2sv = (PFNGLWINDOWPOS2SVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2sv")) == NULL) || r; + r = ((glWindowPos3d = (PFNGLWINDOWPOS3DPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3d")) == NULL) || r; + r = ((glWindowPos3dv = (PFNGLWINDOWPOS3DVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dv")) == NULL) || r; + r = ((glWindowPos3f = (PFNGLWINDOWPOS3FPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3f")) == NULL) || r; + r = ((glWindowPos3fv = (PFNGLWINDOWPOS3FVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fv")) == NULL) || r; + r = ((glWindowPos3i = (PFNGLWINDOWPOS3IPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3i")) == NULL) || r; + r = ((glWindowPos3iv = (PFNGLWINDOWPOS3IVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3iv")) == NULL) || r; + r = ((glWindowPos3s = (PFNGLWINDOWPOS3SPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3s")) == NULL) || r; + r = ((glWindowPos3sv = (PFNGLWINDOWPOS3SVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3sv")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_1_4 */ + +#ifdef GL_VERSION_1_5 + +static GLboolean _glewInit_GL_VERSION_1_5 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginQuery = (PFNGLBEGINQUERYPROC)glewGetProcAddress((const GLubyte*)"glBeginQuery")) == NULL) || r; + r = ((glBindBuffer = (PFNGLBINDBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBindBuffer")) == NULL) || r; + r = ((glBufferData = (PFNGLBUFFERDATAPROC)glewGetProcAddress((const GLubyte*)"glBufferData")) == NULL) || r; + r = ((glBufferSubData = (PFNGLBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glBufferSubData")) == NULL) || r; + r = ((glDeleteBuffers = (PFNGLDELETEBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteBuffers")) == NULL) || r; + r = ((glDeleteQueries = (PFNGLDELETEQUERIESPROC)glewGetProcAddress((const GLubyte*)"glDeleteQueries")) == NULL) || r; + r = ((glEndQuery = (PFNGLENDQUERYPROC)glewGetProcAddress((const GLubyte*)"glEndQuery")) == NULL) || r; + r = ((glGenBuffers = (PFNGLGENBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glGenBuffers")) == NULL) || r; + r = ((glGenQueries = (PFNGLGENQUERIESPROC)glewGetProcAddress((const GLubyte*)"glGenQueries")) == NULL) || r; + r = ((glGetBufferParameteriv = (PFNGLGETBUFFERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameteriv")) == NULL) || r; + r = ((glGetBufferPointerv = (PFNGLGETBUFFERPOINTERVPROC)glewGetProcAddress((const GLubyte*)"glGetBufferPointerv")) == NULL) || r; + r = ((glGetBufferSubData = (PFNGLGETBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glGetBufferSubData")) == NULL) || r; + r = ((glGetQueryObjectiv = (PFNGLGETQUERYOBJECTIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectiv")) == NULL) || r; + r = ((glGetQueryObjectuiv = (PFNGLGETQUERYOBJECTUIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectuiv")) == NULL) || r; + r = ((glGetQueryiv = (PFNGLGETQUERYIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryiv")) == NULL) || r; + r = ((glIsBuffer = (PFNGLISBUFFERPROC)glewGetProcAddress((const GLubyte*)"glIsBuffer")) == NULL) || r; + r = ((glIsQuery = (PFNGLISQUERYPROC)glewGetProcAddress((const GLubyte*)"glIsQuery")) == NULL) || r; + r = ((glMapBuffer = (PFNGLMAPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glMapBuffer")) == NULL) || r; + r = ((glUnmapBuffer = (PFNGLUNMAPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glUnmapBuffer")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_1_5 */ + +#ifdef GL_VERSION_2_0 + +static GLboolean _glewInit_GL_VERSION_2_0 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glAttachShader = (PFNGLATTACHSHADERPROC)glewGetProcAddress((const GLubyte*)"glAttachShader")) == NULL) || r; + r = ((glBindAttribLocation = (PFNGLBINDATTRIBLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glBindAttribLocation")) == NULL) || r; + r = ((glBlendEquationSeparate = (PFNGLBLENDEQUATIONSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparate")) == NULL) || r; + r = ((glCompileShader = (PFNGLCOMPILESHADERPROC)glewGetProcAddress((const GLubyte*)"glCompileShader")) == NULL) || r; + r = ((glCreateProgram = (PFNGLCREATEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glCreateProgram")) == NULL) || r; + r = ((glCreateShader = (PFNGLCREATESHADERPROC)glewGetProcAddress((const GLubyte*)"glCreateShader")) == NULL) || r; + r = ((glDeleteProgram = (PFNGLDELETEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glDeleteProgram")) == NULL) || r; + r = ((glDeleteShader = (PFNGLDELETESHADERPROC)glewGetProcAddress((const GLubyte*)"glDeleteShader")) == NULL) || r; + r = ((glDetachShader = (PFNGLDETACHSHADERPROC)glewGetProcAddress((const GLubyte*)"glDetachShader")) == NULL) || r; + r = ((glDisableVertexAttribArray = (PFNGLDISABLEVERTEXATTRIBARRAYPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexAttribArray")) == NULL) || r; + r = ((glDrawBuffers = (PFNGLDRAWBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDrawBuffers")) == NULL) || r; + r = ((glEnableVertexAttribArray = (PFNGLENABLEVERTEXATTRIBARRAYPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexAttribArray")) == NULL) || r; + r = ((glGetActiveAttrib = (PFNGLGETACTIVEATTRIBPROC)glewGetProcAddress((const GLubyte*)"glGetActiveAttrib")) == NULL) || r; + r = ((glGetActiveUniform = (PFNGLGETACTIVEUNIFORMPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniform")) == NULL) || r; + r = ((glGetAttachedShaders = (PFNGLGETATTACHEDSHADERSPROC)glewGetProcAddress((const GLubyte*)"glGetAttachedShaders")) == NULL) || r; + r = ((glGetAttribLocation = (PFNGLGETATTRIBLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetAttribLocation")) == NULL) || r; + r = ((glGetProgramInfoLog = (PFNGLGETPROGRAMINFOLOGPROC)glewGetProcAddress((const GLubyte*)"glGetProgramInfoLog")) == NULL) || r; + r = ((glGetProgramiv = (PFNGLGETPROGRAMIVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramiv")) == NULL) || r; + r = ((glGetShaderInfoLog = (PFNGLGETSHADERINFOLOGPROC)glewGetProcAddress((const GLubyte*)"glGetShaderInfoLog")) == NULL) || r; + r = ((glGetShaderSource = (PFNGLGETSHADERSOURCEPROC)glewGetProcAddress((const GLubyte*)"glGetShaderSource")) == NULL) || r; + r = ((glGetShaderiv = (PFNGLGETSHADERIVPROC)glewGetProcAddress((const GLubyte*)"glGetShaderiv")) == NULL) || r; + r = ((glGetUniformLocation = (PFNGLGETUNIFORMLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetUniformLocation")) == NULL) || r; + r = ((glGetUniformfv = (PFNGLGETUNIFORMFVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformfv")) == NULL) || r; + r = ((glGetUniformiv = (PFNGLGETUNIFORMIVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformiv")) == NULL) || r; + r = ((glGetVertexAttribPointerv = (PFNGLGETVERTEXATTRIBPOINTERVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribPointerv")) == NULL) || r; + r = ((glGetVertexAttribdv = (PFNGLGETVERTEXATTRIBDVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribdv")) == NULL) || r; + r = ((glGetVertexAttribfv = (PFNGLGETVERTEXATTRIBFVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribfv")) == NULL) || r; + r = ((glGetVertexAttribiv = (PFNGLGETVERTEXATTRIBIVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribiv")) == NULL) || r; + r = ((glIsProgram = (PFNGLISPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glIsProgram")) == NULL) || r; + r = ((glIsShader = (PFNGLISSHADERPROC)glewGetProcAddress((const GLubyte*)"glIsShader")) == NULL) || r; + r = ((glLinkProgram = (PFNGLLINKPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glLinkProgram")) == NULL) || r; + r = ((glShaderSource = (PFNGLSHADERSOURCEPROC)glewGetProcAddress((const GLubyte*)"glShaderSource")) == NULL) || r; + r = ((glStencilFuncSeparate = (PFNGLSTENCILFUNCSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glStencilFuncSeparate")) == NULL) || r; + r = ((glStencilMaskSeparate = (PFNGLSTENCILMASKSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glStencilMaskSeparate")) == NULL) || r; + r = ((glStencilOpSeparate = (PFNGLSTENCILOPSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glStencilOpSeparate")) == NULL) || r; + r = ((glUniform1f = (PFNGLUNIFORM1FPROC)glewGetProcAddress((const GLubyte*)"glUniform1f")) == NULL) || r; + r = ((glUniform1fv = (PFNGLUNIFORM1FVPROC)glewGetProcAddress((const GLubyte*)"glUniform1fv")) == NULL) || r; + r = ((glUniform1i = (PFNGLUNIFORM1IPROC)glewGetProcAddress((const GLubyte*)"glUniform1i")) == NULL) || r; + r = ((glUniform1iv = (PFNGLUNIFORM1IVPROC)glewGetProcAddress((const GLubyte*)"glUniform1iv")) == NULL) || r; + r = ((glUniform2f = (PFNGLUNIFORM2FPROC)glewGetProcAddress((const GLubyte*)"glUniform2f")) == NULL) || r; + r = ((glUniform2fv = (PFNGLUNIFORM2FVPROC)glewGetProcAddress((const GLubyte*)"glUniform2fv")) == NULL) || r; + r = ((glUniform2i = (PFNGLUNIFORM2IPROC)glewGetProcAddress((const GLubyte*)"glUniform2i")) == NULL) || r; + r = ((glUniform2iv = (PFNGLUNIFORM2IVPROC)glewGetProcAddress((const GLubyte*)"glUniform2iv")) == NULL) || r; + r = ((glUniform3f = (PFNGLUNIFORM3FPROC)glewGetProcAddress((const GLubyte*)"glUniform3f")) == NULL) || r; + r = ((glUniform3fv = (PFNGLUNIFORM3FVPROC)glewGetProcAddress((const GLubyte*)"glUniform3fv")) == NULL) || r; + r = ((glUniform3i = (PFNGLUNIFORM3IPROC)glewGetProcAddress((const GLubyte*)"glUniform3i")) == NULL) || r; + r = ((glUniform3iv = (PFNGLUNIFORM3IVPROC)glewGetProcAddress((const GLubyte*)"glUniform3iv")) == NULL) || r; + r = ((glUniform4f = (PFNGLUNIFORM4FPROC)glewGetProcAddress((const GLubyte*)"glUniform4f")) == NULL) || r; + r = ((glUniform4fv = (PFNGLUNIFORM4FVPROC)glewGetProcAddress((const GLubyte*)"glUniform4fv")) == NULL) || r; + r = ((glUniform4i = (PFNGLUNIFORM4IPROC)glewGetProcAddress((const GLubyte*)"glUniform4i")) == NULL) || r; + r = ((glUniform4iv = (PFNGLUNIFORM4IVPROC)glewGetProcAddress((const GLubyte*)"glUniform4iv")) == NULL) || r; + r = ((glUniformMatrix2fv = (PFNGLUNIFORMMATRIX2FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2fv")) == NULL) || r; + r = ((glUniformMatrix3fv = (PFNGLUNIFORMMATRIX3FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3fv")) == NULL) || r; + r = ((glUniformMatrix4fv = (PFNGLUNIFORMMATRIX4FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4fv")) == NULL) || r; + r = ((glUseProgram = (PFNGLUSEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glUseProgram")) == NULL) || r; + r = ((glValidateProgram = (PFNGLVALIDATEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glValidateProgram")) == NULL) || r; + r = ((glVertexAttrib1d = (PFNGLVERTEXATTRIB1DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1d")) == NULL) || r; + r = ((glVertexAttrib1dv = (PFNGLVERTEXATTRIB1DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dv")) == NULL) || r; + r = ((glVertexAttrib1f = (PFNGLVERTEXATTRIB1FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1f")) == NULL) || r; + r = ((glVertexAttrib1fv = (PFNGLVERTEXATTRIB1FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fv")) == NULL) || r; + r = ((glVertexAttrib1s = (PFNGLVERTEXATTRIB1SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1s")) == NULL) || r; + r = ((glVertexAttrib1sv = (PFNGLVERTEXATTRIB1SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1sv")) == NULL) || r; + r = ((glVertexAttrib2d = (PFNGLVERTEXATTRIB2DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2d")) == NULL) || r; + r = ((glVertexAttrib2dv = (PFNGLVERTEXATTRIB2DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dv")) == NULL) || r; + r = ((glVertexAttrib2f = (PFNGLVERTEXATTRIB2FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2f")) == NULL) || r; + r = ((glVertexAttrib2fv = (PFNGLVERTEXATTRIB2FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fv")) == NULL) || r; + r = ((glVertexAttrib2s = (PFNGLVERTEXATTRIB2SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2s")) == NULL) || r; + r = ((glVertexAttrib2sv = (PFNGLVERTEXATTRIB2SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2sv")) == NULL) || r; + r = ((glVertexAttrib3d = (PFNGLVERTEXATTRIB3DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3d")) == NULL) || r; + r = ((glVertexAttrib3dv = (PFNGLVERTEXATTRIB3DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dv")) == NULL) || r; + r = ((glVertexAttrib3f = (PFNGLVERTEXATTRIB3FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3f")) == NULL) || r; + r = ((glVertexAttrib3fv = (PFNGLVERTEXATTRIB3FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fv")) == NULL) || r; + r = ((glVertexAttrib3s = (PFNGLVERTEXATTRIB3SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3s")) == NULL) || r; + r = ((glVertexAttrib3sv = (PFNGLVERTEXATTRIB3SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3sv")) == NULL) || r; + r = ((glVertexAttrib4Nbv = (PFNGLVERTEXATTRIB4NBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nbv")) == NULL) || r; + r = ((glVertexAttrib4Niv = (PFNGLVERTEXATTRIB4NIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Niv")) == NULL) || r; + r = ((glVertexAttrib4Nsv = (PFNGLVERTEXATTRIB4NSVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nsv")) == NULL) || r; + r = ((glVertexAttrib4Nub = (PFNGLVERTEXATTRIB4NUBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nub")) == NULL) || r; + r = ((glVertexAttrib4Nubv = (PFNGLVERTEXATTRIB4NUBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nubv")) == NULL) || r; + r = ((glVertexAttrib4Nuiv = (PFNGLVERTEXATTRIB4NUIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nuiv")) == NULL) || r; + r = ((glVertexAttrib4Nusv = (PFNGLVERTEXATTRIB4NUSVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nusv")) == NULL) || r; + r = ((glVertexAttrib4bv = (PFNGLVERTEXATTRIB4BVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4bv")) == NULL) || r; + r = ((glVertexAttrib4d = (PFNGLVERTEXATTRIB4DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4d")) == NULL) || r; + r = ((glVertexAttrib4dv = (PFNGLVERTEXATTRIB4DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dv")) == NULL) || r; + r = ((glVertexAttrib4f = (PFNGLVERTEXATTRIB4FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4f")) == NULL) || r; + r = ((glVertexAttrib4fv = (PFNGLVERTEXATTRIB4FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fv")) == NULL) || r; + r = ((glVertexAttrib4iv = (PFNGLVERTEXATTRIB4IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4iv")) == NULL) || r; + r = ((glVertexAttrib4s = (PFNGLVERTEXATTRIB4SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4s")) == NULL) || r; + r = ((glVertexAttrib4sv = (PFNGLVERTEXATTRIB4SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4sv")) == NULL) || r; + r = ((glVertexAttrib4ubv = (PFNGLVERTEXATTRIB4UBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubv")) == NULL) || r; + r = ((glVertexAttrib4uiv = (PFNGLVERTEXATTRIB4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4uiv")) == NULL) || r; + r = ((glVertexAttrib4usv = (PFNGLVERTEXATTRIB4USVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4usv")) == NULL) || r; + r = ((glVertexAttribPointer = (PFNGLVERTEXATTRIBPOINTERPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribPointer")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_2_0 */ + +#ifdef GL_VERSION_2_1 + +static GLboolean _glewInit_GL_VERSION_2_1 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glUniformMatrix2x3fv = (PFNGLUNIFORMMATRIX2X3FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2x3fv")) == NULL) || r; + r = ((glUniformMatrix2x4fv = (PFNGLUNIFORMMATRIX2X4FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2x4fv")) == NULL) || r; + r = ((glUniformMatrix3x2fv = (PFNGLUNIFORMMATRIX3X2FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3x2fv")) == NULL) || r; + r = ((glUniformMatrix3x4fv = (PFNGLUNIFORMMATRIX3X4FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3x4fv")) == NULL) || r; + r = ((glUniformMatrix4x2fv = (PFNGLUNIFORMMATRIX4X2FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4x2fv")) == NULL) || r; + r = ((glUniformMatrix4x3fv = (PFNGLUNIFORMMATRIX4X3FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4x3fv")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_2_1 */ + +#ifdef GL_VERSION_3_0 + +static GLboolean _glewInit_GL_VERSION_3_0 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginConditionalRender = (PFNGLBEGINCONDITIONALRENDERPROC)glewGetProcAddress((const GLubyte*)"glBeginConditionalRender")) == NULL) || r; + r = ((glBeginTransformFeedback = (PFNGLBEGINTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glBeginTransformFeedback")) == NULL) || r; + r = ((glBindFragDataLocation = (PFNGLBINDFRAGDATALOCATIONPROC)glewGetProcAddress((const GLubyte*)"glBindFragDataLocation")) == NULL) || r; + r = ((glClampColor = (PFNGLCLAMPCOLORPROC)glewGetProcAddress((const GLubyte*)"glClampColor")) == NULL) || r; + r = ((glClearBufferfi = (PFNGLCLEARBUFFERFIPROC)glewGetProcAddress((const GLubyte*)"glClearBufferfi")) == NULL) || r; + r = ((glClearBufferfv = (PFNGLCLEARBUFFERFVPROC)glewGetProcAddress((const GLubyte*)"glClearBufferfv")) == NULL) || r; + r = ((glClearBufferiv = (PFNGLCLEARBUFFERIVPROC)glewGetProcAddress((const GLubyte*)"glClearBufferiv")) == NULL) || r; + r = ((glClearBufferuiv = (PFNGLCLEARBUFFERUIVPROC)glewGetProcAddress((const GLubyte*)"glClearBufferuiv")) == NULL) || r; + r = ((glColorMaski = (PFNGLCOLORMASKIPROC)glewGetProcAddress((const GLubyte*)"glColorMaski")) == NULL) || r; + r = ((glDisablei = (PFNGLDISABLEIPROC)glewGetProcAddress((const GLubyte*)"glDisablei")) == NULL) || r; + r = ((glEnablei = (PFNGLENABLEIPROC)glewGetProcAddress((const GLubyte*)"glEnablei")) == NULL) || r; + r = ((glEndConditionalRender = (PFNGLENDCONDITIONALRENDERPROC)glewGetProcAddress((const GLubyte*)"glEndConditionalRender")) == NULL) || r; + r = ((glEndTransformFeedback = (PFNGLENDTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glEndTransformFeedback")) == NULL) || r; + r = ((glGetBooleani_v = (PFNGLGETBOOLEANI_VPROC)glewGetProcAddress((const GLubyte*)"glGetBooleani_v")) == NULL) || r; + r = ((glGetFragDataLocation = (PFNGLGETFRAGDATALOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetFragDataLocation")) == NULL) || r; + r = ((glGetStringi = (PFNGLGETSTRINGIPROC)glewGetProcAddress((const GLubyte*)"glGetStringi")) == NULL) || r; + r = ((glGetTexParameterIiv = (PFNGLGETTEXPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIiv")) == NULL) || r; + r = ((glGetTexParameterIuiv = (PFNGLGETTEXPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIuiv")) == NULL) || r; + r = ((glGetTransformFeedbackVarying = (PFNGLGETTRANSFORMFEEDBACKVARYINGPROC)glewGetProcAddress((const GLubyte*)"glGetTransformFeedbackVarying")) == NULL) || r; + r = ((glGetUniformuiv = (PFNGLGETUNIFORMUIVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformuiv")) == NULL) || r; + r = ((glGetVertexAttribIiv = (PFNGLGETVERTEXATTRIBIIVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIiv")) == NULL) || r; + r = ((glGetVertexAttribIuiv = (PFNGLGETVERTEXATTRIBIUIVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIuiv")) == NULL) || r; + r = ((glIsEnabledi = (PFNGLISENABLEDIPROC)glewGetProcAddress((const GLubyte*)"glIsEnabledi")) == NULL) || r; + r = ((glTexParameterIiv = (PFNGLTEXPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIiv")) == NULL) || r; + r = ((glTexParameterIuiv = (PFNGLTEXPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIuiv")) == NULL) || r; + r = ((glTransformFeedbackVaryings = (PFNGLTRANSFORMFEEDBACKVARYINGSPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackVaryings")) == NULL) || r; + r = ((glUniform1ui = (PFNGLUNIFORM1UIPROC)glewGetProcAddress((const GLubyte*)"glUniform1ui")) == NULL) || r; + r = ((glUniform1uiv = (PFNGLUNIFORM1UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform1uiv")) == NULL) || r; + r = ((glUniform2ui = (PFNGLUNIFORM2UIPROC)glewGetProcAddress((const GLubyte*)"glUniform2ui")) == NULL) || r; + r = ((glUniform2uiv = (PFNGLUNIFORM2UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform2uiv")) == NULL) || r; + r = ((glUniform3ui = (PFNGLUNIFORM3UIPROC)glewGetProcAddress((const GLubyte*)"glUniform3ui")) == NULL) || r; + r = ((glUniform3uiv = (PFNGLUNIFORM3UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform3uiv")) == NULL) || r; + r = ((glUniform4ui = (PFNGLUNIFORM4UIPROC)glewGetProcAddress((const GLubyte*)"glUniform4ui")) == NULL) || r; + r = ((glUniform4uiv = (PFNGLUNIFORM4UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform4uiv")) == NULL) || r; + r = ((glVertexAttribI1i = (PFNGLVERTEXATTRIBI1IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1i")) == NULL) || r; + r = ((glVertexAttribI1iv = (PFNGLVERTEXATTRIBI1IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1iv")) == NULL) || r; + r = ((glVertexAttribI1ui = (PFNGLVERTEXATTRIBI1UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1ui")) == NULL) || r; + r = ((glVertexAttribI1uiv = (PFNGLVERTEXATTRIBI1UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1uiv")) == NULL) || r; + r = ((glVertexAttribI2i = (PFNGLVERTEXATTRIBI2IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2i")) == NULL) || r; + r = ((glVertexAttribI2iv = (PFNGLVERTEXATTRIBI2IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2iv")) == NULL) || r; + r = ((glVertexAttribI2ui = (PFNGLVERTEXATTRIBI2UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2ui")) == NULL) || r; + r = ((glVertexAttribI2uiv = (PFNGLVERTEXATTRIBI2UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2uiv")) == NULL) || r; + r = ((glVertexAttribI3i = (PFNGLVERTEXATTRIBI3IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3i")) == NULL) || r; + r = ((glVertexAttribI3iv = (PFNGLVERTEXATTRIBI3IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3iv")) == NULL) || r; + r = ((glVertexAttribI3ui = (PFNGLVERTEXATTRIBI3UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3ui")) == NULL) || r; + r = ((glVertexAttribI3uiv = (PFNGLVERTEXATTRIBI3UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3uiv")) == NULL) || r; + r = ((glVertexAttribI4bv = (PFNGLVERTEXATTRIBI4BVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4bv")) == NULL) || r; + r = ((glVertexAttribI4i = (PFNGLVERTEXATTRIBI4IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4i")) == NULL) || r; + r = ((glVertexAttribI4iv = (PFNGLVERTEXATTRIBI4IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4iv")) == NULL) || r; + r = ((glVertexAttribI4sv = (PFNGLVERTEXATTRIBI4SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4sv")) == NULL) || r; + r = ((glVertexAttribI4ubv = (PFNGLVERTEXATTRIBI4UBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ubv")) == NULL) || r; + r = ((glVertexAttribI4ui = (PFNGLVERTEXATTRIBI4UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ui")) == NULL) || r; + r = ((glVertexAttribI4uiv = (PFNGLVERTEXATTRIBI4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4uiv")) == NULL) || r; + r = ((glVertexAttribI4usv = (PFNGLVERTEXATTRIBI4USVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4usv")) == NULL) || r; + r = ((glVertexAttribIPointer = (PFNGLVERTEXATTRIBIPOINTERPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribIPointer")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_3_0 */ + +#ifdef GL_VERSION_3_1 + +static GLboolean _glewInit_GL_VERSION_3_1 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawArraysInstanced = (PFNGLDRAWARRAYSINSTANCEDPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstanced")) == NULL) || r; + r = ((glDrawElementsInstanced = (PFNGLDRAWELEMENTSINSTANCEDPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstanced")) == NULL) || r; + r = ((glPrimitiveRestartIndex = (PFNGLPRIMITIVERESTARTINDEXPROC)glewGetProcAddress((const GLubyte*)"glPrimitiveRestartIndex")) == NULL) || r; + r = ((glTexBuffer = (PFNGLTEXBUFFERPROC)glewGetProcAddress((const GLubyte*)"glTexBuffer")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_3_1 */ + +#ifdef GL_VERSION_3_2 + +static GLboolean _glewInit_GL_VERSION_3_2 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFramebufferTexture = (PFNGLFRAMEBUFFERTEXTUREPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture")) == NULL) || r; + r = ((glGetBufferParameteri64v = (PFNGLGETBUFFERPARAMETERI64VPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameteri64v")) == NULL) || r; + r = ((glGetInteger64i_v = (PFNGLGETINTEGER64I_VPROC)glewGetProcAddress((const GLubyte*)"glGetInteger64i_v")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_3_2 */ + +#ifdef GL_VERSION_3_3 + +#endif /* GL_VERSION_3_3 */ + +#ifdef GL_VERSION_4_0 + +static GLboolean _glewInit_GL_VERSION_4_0 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendEquationSeparatei = (PFNGLBLENDEQUATIONSEPARATEIPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparatei")) == NULL) || r; + r = ((glBlendEquationi = (PFNGLBLENDEQUATIONIPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationi")) == NULL) || r; + r = ((glBlendFuncSeparatei = (PFNGLBLENDFUNCSEPARATEIPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparatei")) == NULL) || r; + r = ((glBlendFunci = (PFNGLBLENDFUNCIPROC)glewGetProcAddress((const GLubyte*)"glBlendFunci")) == NULL) || r; + r = ((glMinSampleShading = (PFNGLMINSAMPLESHADINGPROC)glewGetProcAddress((const GLubyte*)"glMinSampleShading")) == NULL) || r; + + return r; +} + +#endif /* GL_VERSION_4_0 */ + +#ifdef GL_3DFX_multisample + +#endif /* GL_3DFX_multisample */ + +#ifdef GL_3DFX_tbuffer + +static GLboolean _glewInit_GL_3DFX_tbuffer (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTbufferMask3DFX = (PFNGLTBUFFERMASK3DFXPROC)glewGetProcAddress((const GLubyte*)"glTbufferMask3DFX")) == NULL) || r; + + return r; +} + +#endif /* GL_3DFX_tbuffer */ + +#ifdef GL_3DFX_texture_compression_FXT1 + +#endif /* GL_3DFX_texture_compression_FXT1 */ + +#ifdef GL_AMD_conservative_depth + +#endif /* GL_AMD_conservative_depth */ + +#ifdef GL_AMD_draw_buffers_blend + +static GLboolean _glewInit_GL_AMD_draw_buffers_blend (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendEquationIndexedAMD = (PFNGLBLENDEQUATIONINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationIndexedAMD")) == NULL) || r; + r = ((glBlendEquationSeparateIndexedAMD = (PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparateIndexedAMD")) == NULL) || r; + r = ((glBlendFuncIndexedAMD = (PFNGLBLENDFUNCINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncIndexedAMD")) == NULL) || r; + r = ((glBlendFuncSeparateIndexedAMD = (PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparateIndexedAMD")) == NULL) || r; + + return r; +} + +#endif /* GL_AMD_draw_buffers_blend */ + +#ifdef GL_AMD_performance_monitor + +static GLboolean _glewInit_GL_AMD_performance_monitor (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginPerfMonitorAMD = (PFNGLBEGINPERFMONITORAMDPROC)glewGetProcAddress((const GLubyte*)"glBeginPerfMonitorAMD")) == NULL) || r; + r = ((glDeletePerfMonitorsAMD = (PFNGLDELETEPERFMONITORSAMDPROC)glewGetProcAddress((const GLubyte*)"glDeletePerfMonitorsAMD")) == NULL) || r; + r = ((glEndPerfMonitorAMD = (PFNGLENDPERFMONITORAMDPROC)glewGetProcAddress((const GLubyte*)"glEndPerfMonitorAMD")) == NULL) || r; + r = ((glGenPerfMonitorsAMD = (PFNGLGENPERFMONITORSAMDPROC)glewGetProcAddress((const GLubyte*)"glGenPerfMonitorsAMD")) == NULL) || r; + r = ((glGetPerfMonitorCounterDataAMD = (PFNGLGETPERFMONITORCOUNTERDATAAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCounterDataAMD")) == NULL) || r; + r = ((glGetPerfMonitorCounterInfoAMD = (PFNGLGETPERFMONITORCOUNTERINFOAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCounterInfoAMD")) == NULL) || r; + r = ((glGetPerfMonitorCounterStringAMD = (PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCounterStringAMD")) == NULL) || r; + r = ((glGetPerfMonitorCountersAMD = (PFNGLGETPERFMONITORCOUNTERSAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCountersAMD")) == NULL) || r; + r = ((glGetPerfMonitorGroupStringAMD = (PFNGLGETPERFMONITORGROUPSTRINGAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorGroupStringAMD")) == NULL) || r; + r = ((glGetPerfMonitorGroupsAMD = (PFNGLGETPERFMONITORGROUPSAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorGroupsAMD")) == NULL) || r; + r = ((glSelectPerfMonitorCountersAMD = (PFNGLSELECTPERFMONITORCOUNTERSAMDPROC)glewGetProcAddress((const GLubyte*)"glSelectPerfMonitorCountersAMD")) == NULL) || r; + + return r; +} + +#endif /* GL_AMD_performance_monitor */ + +#ifdef GL_AMD_seamless_cubemap_per_texture + +#endif /* GL_AMD_seamless_cubemap_per_texture */ + +#ifdef GL_AMD_shader_stencil_export + +#endif /* GL_AMD_shader_stencil_export */ + +#ifdef GL_AMD_texture_texture4 + +#endif /* GL_AMD_texture_texture4 */ + +#ifdef GL_AMD_vertex_shader_tessellator + +static GLboolean _glewInit_GL_AMD_vertex_shader_tessellator (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTessellationFactorAMD = (PFNGLTESSELLATIONFACTORAMDPROC)glewGetProcAddress((const GLubyte*)"glTessellationFactorAMD")) == NULL) || r; + r = ((glTessellationModeAMD = (PFNGLTESSELLATIONMODEAMDPROC)glewGetProcAddress((const GLubyte*)"glTessellationModeAMD")) == NULL) || r; + + return r; +} + +#endif /* GL_AMD_vertex_shader_tessellator */ + +#ifdef GL_APPLE_aux_depth_stencil + +#endif /* GL_APPLE_aux_depth_stencil */ + +#ifdef GL_APPLE_client_storage + +#endif /* GL_APPLE_client_storage */ + +#ifdef GL_APPLE_element_array + +static GLboolean _glewInit_GL_APPLE_element_array (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawElementArrayAPPLE = (PFNGLDRAWELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDrawElementArrayAPPLE")) == NULL) || r; + r = ((glDrawRangeElementArrayAPPLE = (PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementArrayAPPLE")) == NULL) || r; + r = ((glElementPointerAPPLE = (PFNGLELEMENTPOINTERAPPLEPROC)glewGetProcAddress((const GLubyte*)"glElementPointerAPPLE")) == NULL) || r; + r = ((glMultiDrawElementArrayAPPLE = (PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementArrayAPPLE")) == NULL) || r; + r = ((glMultiDrawRangeElementArrayAPPLE = (PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawRangeElementArrayAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_element_array */ + +#ifdef GL_APPLE_fence + +static GLboolean _glewInit_GL_APPLE_fence (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDeleteFencesAPPLE = (PFNGLDELETEFENCESAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDeleteFencesAPPLE")) == NULL) || r; + r = ((glFinishFenceAPPLE = (PFNGLFINISHFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFinishFenceAPPLE")) == NULL) || r; + r = ((glFinishObjectAPPLE = (PFNGLFINISHOBJECTAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFinishObjectAPPLE")) == NULL) || r; + r = ((glGenFencesAPPLE = (PFNGLGENFENCESAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGenFencesAPPLE")) == NULL) || r; + r = ((glIsFenceAPPLE = (PFNGLISFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glIsFenceAPPLE")) == NULL) || r; + r = ((glSetFenceAPPLE = (PFNGLSETFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glSetFenceAPPLE")) == NULL) || r; + r = ((glTestFenceAPPLE = (PFNGLTESTFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glTestFenceAPPLE")) == NULL) || r; + r = ((glTestObjectAPPLE = (PFNGLTESTOBJECTAPPLEPROC)glewGetProcAddress((const GLubyte*)"glTestObjectAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_fence */ + +#ifdef GL_APPLE_float_pixels + +#endif /* GL_APPLE_float_pixels */ + +#ifdef GL_APPLE_flush_buffer_range + +static GLboolean _glewInit_GL_APPLE_flush_buffer_range (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBufferParameteriAPPLE = (PFNGLBUFFERPARAMETERIAPPLEPROC)glewGetProcAddress((const GLubyte*)"glBufferParameteriAPPLE")) == NULL) || r; + r = ((glFlushMappedBufferRangeAPPLE = (PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFlushMappedBufferRangeAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_flush_buffer_range */ + +#ifdef GL_APPLE_object_purgeable + +static GLboolean _glewInit_GL_APPLE_object_purgeable (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetObjectParameterivAPPLE = (PFNGLGETOBJECTPARAMETERIVAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGetObjectParameterivAPPLE")) == NULL) || r; + r = ((glObjectPurgeableAPPLE = (PFNGLOBJECTPURGEABLEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glObjectPurgeableAPPLE")) == NULL) || r; + r = ((glObjectUnpurgeableAPPLE = (PFNGLOBJECTUNPURGEABLEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glObjectUnpurgeableAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_object_purgeable */ + +#ifdef GL_APPLE_pixel_buffer + +#endif /* GL_APPLE_pixel_buffer */ + +#ifdef GL_APPLE_rgb_422 + +#endif /* GL_APPLE_rgb_422 */ + +#ifdef GL_APPLE_row_bytes + +#endif /* GL_APPLE_row_bytes */ + +#ifdef GL_APPLE_specular_vector + +#endif /* GL_APPLE_specular_vector */ + +#ifdef GL_APPLE_texture_range + +static GLboolean _glewInit_GL_APPLE_texture_range (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetTexParameterPointervAPPLE = (PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterPointervAPPLE")) == NULL) || r; + r = ((glTextureRangeAPPLE = (PFNGLTEXTURERANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glTextureRangeAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_texture_range */ + +#ifdef GL_APPLE_transform_hint + +#endif /* GL_APPLE_transform_hint */ + +#ifdef GL_APPLE_vertex_array_object + +static GLboolean _glewInit_GL_APPLE_vertex_array_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindVertexArrayAPPLE = (PFNGLBINDVERTEXARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glBindVertexArrayAPPLE")) == NULL) || r; + r = ((glDeleteVertexArraysAPPLE = (PFNGLDELETEVERTEXARRAYSAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDeleteVertexArraysAPPLE")) == NULL) || r; + r = ((glGenVertexArraysAPPLE = (PFNGLGENVERTEXARRAYSAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGenVertexArraysAPPLE")) == NULL) || r; + r = ((glIsVertexArrayAPPLE = (PFNGLISVERTEXARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glIsVertexArrayAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_vertex_array_object */ + +#ifdef GL_APPLE_vertex_array_range + +static GLboolean _glewInit_GL_APPLE_vertex_array_range (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFlushVertexArrayRangeAPPLE = (PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFlushVertexArrayRangeAPPLE")) == NULL) || r; + r = ((glVertexArrayParameteriAPPLE = (PFNGLVERTEXARRAYPARAMETERIAPPLEPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayParameteriAPPLE")) == NULL) || r; + r = ((glVertexArrayRangeAPPLE = (PFNGLVERTEXARRAYRANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayRangeAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_vertex_array_range */ + +#ifdef GL_APPLE_vertex_program_evaluators + +static GLboolean _glewInit_GL_APPLE_vertex_program_evaluators (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDisableVertexAttribAPPLE = (PFNGLDISABLEVERTEXATTRIBAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexAttribAPPLE")) == NULL) || r; + r = ((glEnableVertexAttribAPPLE = (PFNGLENABLEVERTEXATTRIBAPPLEPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexAttribAPPLE")) == NULL) || r; + r = ((glIsVertexAttribEnabledAPPLE = (PFNGLISVERTEXATTRIBENABLEDAPPLEPROC)glewGetProcAddress((const GLubyte*)"glIsVertexAttribEnabledAPPLE")) == NULL) || r; + r = ((glMapVertexAttrib1dAPPLE = (PFNGLMAPVERTEXATTRIB1DAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib1dAPPLE")) == NULL) || r; + r = ((glMapVertexAttrib1fAPPLE = (PFNGLMAPVERTEXATTRIB1FAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib1fAPPLE")) == NULL) || r; + r = ((glMapVertexAttrib2dAPPLE = (PFNGLMAPVERTEXATTRIB2DAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib2dAPPLE")) == NULL) || r; + r = ((glMapVertexAttrib2fAPPLE = (PFNGLMAPVERTEXATTRIB2FAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib2fAPPLE")) == NULL) || r; + + return r; +} + +#endif /* GL_APPLE_vertex_program_evaluators */ + +#ifdef GL_APPLE_ycbcr_422 + +#endif /* GL_APPLE_ycbcr_422 */ + +#ifdef GL_ARB_blend_func_extended + +static GLboolean _glewInit_GL_ARB_blend_func_extended (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindFragDataLocationIndexed = (PFNGLBINDFRAGDATALOCATIONINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glBindFragDataLocationIndexed")) == NULL) || r; + r = ((glGetFragDataIndex = (PFNGLGETFRAGDATAINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetFragDataIndex")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_blend_func_extended */ + +#ifdef GL_ARB_color_buffer_float + +static GLboolean _glewInit_GL_ARB_color_buffer_float (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glClampColorARB = (PFNGLCLAMPCOLORARBPROC)glewGetProcAddress((const GLubyte*)"glClampColorARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_color_buffer_float */ + +#ifdef GL_ARB_compatibility + +#endif /* GL_ARB_compatibility */ + +#ifdef GL_ARB_copy_buffer + +static GLboolean _glewInit_GL_ARB_copy_buffer (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCopyBufferSubData = (PFNGLCOPYBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glCopyBufferSubData")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_copy_buffer */ + +#ifdef GL_ARB_depth_buffer_float + +#endif /* GL_ARB_depth_buffer_float */ + +#ifdef GL_ARB_depth_clamp + +#endif /* GL_ARB_depth_clamp */ + +#ifdef GL_ARB_depth_texture + +#endif /* GL_ARB_depth_texture */ + +#ifdef GL_ARB_draw_buffers + +static GLboolean _glewInit_GL_ARB_draw_buffers (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawBuffersARB = (PFNGLDRAWBUFFERSARBPROC)glewGetProcAddress((const GLubyte*)"glDrawBuffersARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_draw_buffers */ + +#ifdef GL_ARB_draw_buffers_blend + +static GLboolean _glewInit_GL_ARB_draw_buffers_blend (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendEquationSeparateiARB = (PFNGLBLENDEQUATIONSEPARATEIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparateiARB")) == NULL) || r; + r = ((glBlendEquationiARB = (PFNGLBLENDEQUATIONIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationiARB")) == NULL) || r; + r = ((glBlendFuncSeparateiARB = (PFNGLBLENDFUNCSEPARATEIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparateiARB")) == NULL) || r; + r = ((glBlendFunciARB = (PFNGLBLENDFUNCIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendFunciARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_draw_buffers_blend */ + +#ifdef GL_ARB_draw_elements_base_vertex + +static GLboolean _glewInit_GL_ARB_draw_elements_base_vertex (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawElementsBaseVertex = (PFNGLDRAWELEMENTSBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsBaseVertex")) == NULL) || r; + r = ((glDrawElementsInstancedBaseVertex = (PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedBaseVertex")) == NULL) || r; + r = ((glDrawRangeElementsBaseVertex = (PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementsBaseVertex")) == NULL) || r; + r = ((glMultiDrawElementsBaseVertex = (PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsBaseVertex")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_draw_elements_base_vertex */ + +#ifdef GL_ARB_draw_indirect + +static GLboolean _glewInit_GL_ARB_draw_indirect (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawArraysIndirect = (PFNGLDRAWARRAYSINDIRECTPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysIndirect")) == NULL) || r; + r = ((glDrawElementsIndirect = (PFNGLDRAWELEMENTSINDIRECTPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsIndirect")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_draw_indirect */ + +#ifdef GL_ARB_draw_instanced + +static GLboolean _glewInit_GL_ARB_draw_instanced (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawArraysInstancedARB = (PFNGLDRAWARRAYSINSTANCEDARBPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstancedARB")) == NULL) || r; + r = ((glDrawElementsInstancedARB = (PFNGLDRAWELEMENTSINSTANCEDARBPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_draw_instanced */ + +#ifdef GL_ARB_explicit_attrib_location + +#endif /* GL_ARB_explicit_attrib_location */ + +#ifdef GL_ARB_fragment_coord_conventions + +#endif /* GL_ARB_fragment_coord_conventions */ + +#ifdef GL_ARB_fragment_program + +#endif /* GL_ARB_fragment_program */ + +#ifdef GL_ARB_fragment_program_shadow + +#endif /* GL_ARB_fragment_program_shadow */ + +#ifdef GL_ARB_fragment_shader + +#endif /* GL_ARB_fragment_shader */ + +#ifdef GL_ARB_framebuffer_object + +static GLboolean _glewInit_GL_ARB_framebuffer_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindFramebuffer = (PFNGLBINDFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBindFramebuffer")) == NULL) || r; + r = ((glBindRenderbuffer = (PFNGLBINDRENDERBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBindRenderbuffer")) == NULL) || r; + r = ((glBlitFramebuffer = (PFNGLBLITFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBlitFramebuffer")) == NULL) || r; + r = ((glCheckFramebufferStatus = (PFNGLCHECKFRAMEBUFFERSTATUSPROC)glewGetProcAddress((const GLubyte*)"glCheckFramebufferStatus")) == NULL) || r; + r = ((glDeleteFramebuffers = (PFNGLDELETEFRAMEBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteFramebuffers")) == NULL) || r; + r = ((glDeleteRenderbuffers = (PFNGLDELETERENDERBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteRenderbuffers")) == NULL) || r; + r = ((glFramebufferRenderbuffer = (PFNGLFRAMEBUFFERRENDERBUFFERPROC)glewGetProcAddress((const GLubyte*)"glFramebufferRenderbuffer")) == NULL) || r; + r = ((glFramebufferTexture1D = (PFNGLFRAMEBUFFERTEXTURE1DPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture1D")) == NULL) || r; + r = ((glFramebufferTexture2D = (PFNGLFRAMEBUFFERTEXTURE2DPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture2D")) == NULL) || r; + r = ((glFramebufferTexture3D = (PFNGLFRAMEBUFFERTEXTURE3DPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture3D")) == NULL) || r; + r = ((glFramebufferTextureLayer = (PFNGLFRAMEBUFFERTEXTURELAYERPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureLayer")) == NULL) || r; + r = ((glGenFramebuffers = (PFNGLGENFRAMEBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glGenFramebuffers")) == NULL) || r; + r = ((glGenRenderbuffers = (PFNGLGENRENDERBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glGenRenderbuffers")) == NULL) || r; + r = ((glGenerateMipmap = (PFNGLGENERATEMIPMAPPROC)glewGetProcAddress((const GLubyte*)"glGenerateMipmap")) == NULL) || r; + r = ((glGetFramebufferAttachmentParameteriv = (PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetFramebufferAttachmentParameteriv")) == NULL) || r; + r = ((glGetRenderbufferParameteriv = (PFNGLGETRENDERBUFFERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetRenderbufferParameteriv")) == NULL) || r; + r = ((glIsFramebuffer = (PFNGLISFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glIsFramebuffer")) == NULL) || r; + r = ((glIsRenderbuffer = (PFNGLISRENDERBUFFERPROC)glewGetProcAddress((const GLubyte*)"glIsRenderbuffer")) == NULL) || r; + r = ((glRenderbufferStorage = (PFNGLRENDERBUFFERSTORAGEPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorage")) == NULL) || r; + r = ((glRenderbufferStorageMultisample = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageMultisample")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_framebuffer_object */ + +#ifdef GL_ARB_framebuffer_sRGB + +#endif /* GL_ARB_framebuffer_sRGB */ + +#ifdef GL_ARB_geometry_shader4 + +static GLboolean _glewInit_GL_ARB_geometry_shader4 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFramebufferTextureARB = (PFNGLFRAMEBUFFERTEXTUREARBPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureARB")) == NULL) || r; + r = ((glFramebufferTextureFaceARB = (PFNGLFRAMEBUFFERTEXTUREFACEARBPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureFaceARB")) == NULL) || r; + r = ((glFramebufferTextureLayerARB = (PFNGLFRAMEBUFFERTEXTURELAYERARBPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureLayerARB")) == NULL) || r; + r = ((glProgramParameteriARB = (PFNGLPROGRAMPARAMETERIARBPROC)glewGetProcAddress((const GLubyte*)"glProgramParameteriARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_geometry_shader4 */ + +#ifdef GL_ARB_gpu_shader5 + +#endif /* GL_ARB_gpu_shader5 */ + +#ifdef GL_ARB_gpu_shader_fp64 + +#endif /* GL_ARB_gpu_shader_fp64 */ + +#ifdef GL_ARB_half_float_pixel + +#endif /* GL_ARB_half_float_pixel */ + +#ifdef GL_ARB_half_float_vertex + +#endif /* GL_ARB_half_float_vertex */ + +#ifdef GL_ARB_imaging + +static GLboolean _glewInit_GL_ARB_imaging (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendEquation = (PFNGLBLENDEQUATIONPROC)glewGetProcAddress((const GLubyte*)"glBlendEquation")) == NULL) || r; + r = ((glColorSubTable = (PFNGLCOLORSUBTABLEPROC)glewGetProcAddress((const GLubyte*)"glColorSubTable")) == NULL) || r; + r = ((glColorTable = (PFNGLCOLORTABLEPROC)glewGetProcAddress((const GLubyte*)"glColorTable")) == NULL) || r; + r = ((glColorTableParameterfv = (PFNGLCOLORTABLEPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameterfv")) == NULL) || r; + r = ((glColorTableParameteriv = (PFNGLCOLORTABLEPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameteriv")) == NULL) || r; + r = ((glConvolutionFilter1D = (PFNGLCONVOLUTIONFILTER1DPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter1D")) == NULL) || r; + r = ((glConvolutionFilter2D = (PFNGLCONVOLUTIONFILTER2DPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter2D")) == NULL) || r; + r = ((glConvolutionParameterf = (PFNGLCONVOLUTIONPARAMETERFPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterf")) == NULL) || r; + r = ((glConvolutionParameterfv = (PFNGLCONVOLUTIONPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterfv")) == NULL) || r; + r = ((glConvolutionParameteri = (PFNGLCONVOLUTIONPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameteri")) == NULL) || r; + r = ((glConvolutionParameteriv = (PFNGLCONVOLUTIONPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameteriv")) == NULL) || r; + r = ((glCopyColorSubTable = (PFNGLCOPYCOLORSUBTABLEPROC)glewGetProcAddress((const GLubyte*)"glCopyColorSubTable")) == NULL) || r; + r = ((glCopyColorTable = (PFNGLCOPYCOLORTABLEPROC)glewGetProcAddress((const GLubyte*)"glCopyColorTable")) == NULL) || r; + r = ((glCopyConvolutionFilter1D = (PFNGLCOPYCONVOLUTIONFILTER1DPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter1D")) == NULL) || r; + r = ((glCopyConvolutionFilter2D = (PFNGLCOPYCONVOLUTIONFILTER2DPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter2D")) == NULL) || r; + r = ((glGetColorTable = (PFNGLGETCOLORTABLEPROC)glewGetProcAddress((const GLubyte*)"glGetColorTable")) == NULL) || r; + r = ((glGetColorTableParameterfv = (PFNGLGETCOLORTABLEPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterfv")) == NULL) || r; + r = ((glGetColorTableParameteriv = (PFNGLGETCOLORTABLEPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameteriv")) == NULL) || r; + r = ((glGetConvolutionFilter = (PFNGLGETCONVOLUTIONFILTERPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionFilter")) == NULL) || r; + r = ((glGetConvolutionParameterfv = (PFNGLGETCONVOLUTIONPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameterfv")) == NULL) || r; + r = ((glGetConvolutionParameteriv = (PFNGLGETCONVOLUTIONPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameteriv")) == NULL) || r; + r = ((glGetHistogram = (PFNGLGETHISTOGRAMPROC)glewGetProcAddress((const GLubyte*)"glGetHistogram")) == NULL) || r; + r = ((glGetHistogramParameterfv = (PFNGLGETHISTOGRAMPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameterfv")) == NULL) || r; + r = ((glGetHistogramParameteriv = (PFNGLGETHISTOGRAMPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameteriv")) == NULL) || r; + r = ((glGetMinmax = (PFNGLGETMINMAXPROC)glewGetProcAddress((const GLubyte*)"glGetMinmax")) == NULL) || r; + r = ((glGetMinmaxParameterfv = (PFNGLGETMINMAXPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameterfv")) == NULL) || r; + r = ((glGetMinmaxParameteriv = (PFNGLGETMINMAXPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameteriv")) == NULL) || r; + r = ((glGetSeparableFilter = (PFNGLGETSEPARABLEFILTERPROC)glewGetProcAddress((const GLubyte*)"glGetSeparableFilter")) == NULL) || r; + r = ((glHistogram = (PFNGLHISTOGRAMPROC)glewGetProcAddress((const GLubyte*)"glHistogram")) == NULL) || r; + r = ((glMinmax = (PFNGLMINMAXPROC)glewGetProcAddress((const GLubyte*)"glMinmax")) == NULL) || r; + r = ((glResetHistogram = (PFNGLRESETHISTOGRAMPROC)glewGetProcAddress((const GLubyte*)"glResetHistogram")) == NULL) || r; + r = ((glResetMinmax = (PFNGLRESETMINMAXPROC)glewGetProcAddress((const GLubyte*)"glResetMinmax")) == NULL) || r; + r = ((glSeparableFilter2D = (PFNGLSEPARABLEFILTER2DPROC)glewGetProcAddress((const GLubyte*)"glSeparableFilter2D")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_imaging */ + +#ifdef GL_ARB_instanced_arrays + +static GLboolean _glewInit_GL_ARB_instanced_arrays (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glVertexAttribDivisorARB = (PFNGLVERTEXATTRIBDIVISORARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribDivisorARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_instanced_arrays */ + +#ifdef GL_ARB_map_buffer_range + +static GLboolean _glewInit_GL_ARB_map_buffer_range (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFlushMappedBufferRange = (PFNGLFLUSHMAPPEDBUFFERRANGEPROC)glewGetProcAddress((const GLubyte*)"glFlushMappedBufferRange")) == NULL) || r; + r = ((glMapBufferRange = (PFNGLMAPBUFFERRANGEPROC)glewGetProcAddress((const GLubyte*)"glMapBufferRange")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_map_buffer_range */ + +#ifdef GL_ARB_matrix_palette + +static GLboolean _glewInit_GL_ARB_matrix_palette (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCurrentPaletteMatrixARB = (PFNGLCURRENTPALETTEMATRIXARBPROC)glewGetProcAddress((const GLubyte*)"glCurrentPaletteMatrixARB")) == NULL) || r; + r = ((glMatrixIndexPointerARB = (PFNGLMATRIXINDEXPOINTERARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexPointerARB")) == NULL) || r; + r = ((glMatrixIndexubvARB = (PFNGLMATRIXINDEXUBVARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexubvARB")) == NULL) || r; + r = ((glMatrixIndexuivARB = (PFNGLMATRIXINDEXUIVARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexuivARB")) == NULL) || r; + r = ((glMatrixIndexusvARB = (PFNGLMATRIXINDEXUSVARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexusvARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_matrix_palette */ + +#ifdef GL_ARB_multisample + +static GLboolean _glewInit_GL_ARB_multisample (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glSampleCoverageARB = (PFNGLSAMPLECOVERAGEARBPROC)glewGetProcAddress((const GLubyte*)"glSampleCoverageARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_multisample */ + +#ifdef GL_ARB_multitexture + +static GLboolean _glewInit_GL_ARB_multitexture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glActiveTextureARB = (PFNGLACTIVETEXTUREARBPROC)glewGetProcAddress((const GLubyte*)"glActiveTextureARB")) == NULL) || r; + r = ((glClientActiveTextureARB = (PFNGLCLIENTACTIVETEXTUREARBPROC)glewGetProcAddress((const GLubyte*)"glClientActiveTextureARB")) == NULL) || r; + r = ((glMultiTexCoord1dARB = (PFNGLMULTITEXCOORD1DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1dARB")) == NULL) || r; + r = ((glMultiTexCoord1dvARB = (PFNGLMULTITEXCOORD1DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1dvARB")) == NULL) || r; + r = ((glMultiTexCoord1fARB = (PFNGLMULTITEXCOORD1FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1fARB")) == NULL) || r; + r = ((glMultiTexCoord1fvARB = (PFNGLMULTITEXCOORD1FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1fvARB")) == NULL) || r; + r = ((glMultiTexCoord1iARB = (PFNGLMULTITEXCOORD1IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1iARB")) == NULL) || r; + r = ((glMultiTexCoord1ivARB = (PFNGLMULTITEXCOORD1IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1ivARB")) == NULL) || r; + r = ((glMultiTexCoord1sARB = (PFNGLMULTITEXCOORD1SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1sARB")) == NULL) || r; + r = ((glMultiTexCoord1svARB = (PFNGLMULTITEXCOORD1SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1svARB")) == NULL) || r; + r = ((glMultiTexCoord2dARB = (PFNGLMULTITEXCOORD2DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2dARB")) == NULL) || r; + r = ((glMultiTexCoord2dvARB = (PFNGLMULTITEXCOORD2DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2dvARB")) == NULL) || r; + r = ((glMultiTexCoord2fARB = (PFNGLMULTITEXCOORD2FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2fARB")) == NULL) || r; + r = ((glMultiTexCoord2fvARB = (PFNGLMULTITEXCOORD2FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2fvARB")) == NULL) || r; + r = ((glMultiTexCoord2iARB = (PFNGLMULTITEXCOORD2IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2iARB")) == NULL) || r; + r = ((glMultiTexCoord2ivARB = (PFNGLMULTITEXCOORD2IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2ivARB")) == NULL) || r; + r = ((glMultiTexCoord2sARB = (PFNGLMULTITEXCOORD2SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2sARB")) == NULL) || r; + r = ((glMultiTexCoord2svARB = (PFNGLMULTITEXCOORD2SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2svARB")) == NULL) || r; + r = ((glMultiTexCoord3dARB = (PFNGLMULTITEXCOORD3DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3dARB")) == NULL) || r; + r = ((glMultiTexCoord3dvARB = (PFNGLMULTITEXCOORD3DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3dvARB")) == NULL) || r; + r = ((glMultiTexCoord3fARB = (PFNGLMULTITEXCOORD3FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3fARB")) == NULL) || r; + r = ((glMultiTexCoord3fvARB = (PFNGLMULTITEXCOORD3FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3fvARB")) == NULL) || r; + r = ((glMultiTexCoord3iARB = (PFNGLMULTITEXCOORD3IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3iARB")) == NULL) || r; + r = ((glMultiTexCoord3ivARB = (PFNGLMULTITEXCOORD3IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3ivARB")) == NULL) || r; + r = ((glMultiTexCoord3sARB = (PFNGLMULTITEXCOORD3SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3sARB")) == NULL) || r; + r = ((glMultiTexCoord3svARB = (PFNGLMULTITEXCOORD3SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3svARB")) == NULL) || r; + r = ((glMultiTexCoord4dARB = (PFNGLMULTITEXCOORD4DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4dARB")) == NULL) || r; + r = ((glMultiTexCoord4dvARB = (PFNGLMULTITEXCOORD4DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4dvARB")) == NULL) || r; + r = ((glMultiTexCoord4fARB = (PFNGLMULTITEXCOORD4FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4fARB")) == NULL) || r; + r = ((glMultiTexCoord4fvARB = (PFNGLMULTITEXCOORD4FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4fvARB")) == NULL) || r; + r = ((glMultiTexCoord4iARB = (PFNGLMULTITEXCOORD4IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4iARB")) == NULL) || r; + r = ((glMultiTexCoord4ivARB = (PFNGLMULTITEXCOORD4IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4ivARB")) == NULL) || r; + r = ((glMultiTexCoord4sARB = (PFNGLMULTITEXCOORD4SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4sARB")) == NULL) || r; + r = ((glMultiTexCoord4svARB = (PFNGLMULTITEXCOORD4SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4svARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_multitexture */ + +#ifdef GL_ARB_occlusion_query + +static GLboolean _glewInit_GL_ARB_occlusion_query (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginQueryARB = (PFNGLBEGINQUERYARBPROC)glewGetProcAddress((const GLubyte*)"glBeginQueryARB")) == NULL) || r; + r = ((glDeleteQueriesARB = (PFNGLDELETEQUERIESARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteQueriesARB")) == NULL) || r; + r = ((glEndQueryARB = (PFNGLENDQUERYARBPROC)glewGetProcAddress((const GLubyte*)"glEndQueryARB")) == NULL) || r; + r = ((glGenQueriesARB = (PFNGLGENQUERIESARBPROC)glewGetProcAddress((const GLubyte*)"glGenQueriesARB")) == NULL) || r; + r = ((glGetQueryObjectivARB = (PFNGLGETQUERYOBJECTIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectivARB")) == NULL) || r; + r = ((glGetQueryObjectuivARB = (PFNGLGETQUERYOBJECTUIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectuivARB")) == NULL) || r; + r = ((glGetQueryivARB = (PFNGLGETQUERYIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetQueryivARB")) == NULL) || r; + r = ((glIsQueryARB = (PFNGLISQUERYARBPROC)glewGetProcAddress((const GLubyte*)"glIsQueryARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_occlusion_query */ + +#ifdef GL_ARB_occlusion_query2 + +#endif /* GL_ARB_occlusion_query2 */ + +#ifdef GL_ARB_pixel_buffer_object + +#endif /* GL_ARB_pixel_buffer_object */ + +#ifdef GL_ARB_point_parameters + +static GLboolean _glewInit_GL_ARB_point_parameters (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPointParameterfARB = (PFNGLPOINTPARAMETERFARBPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfARB")) == NULL) || r; + r = ((glPointParameterfvARB = (PFNGLPOINTPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfvARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_point_parameters */ + +#ifdef GL_ARB_point_sprite + +#endif /* GL_ARB_point_sprite */ + +#ifdef GL_ARB_provoking_vertex + +static GLboolean _glewInit_GL_ARB_provoking_vertex (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glProvokingVertex = (PFNGLPROVOKINGVERTEXPROC)glewGetProcAddress((const GLubyte*)"glProvokingVertex")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_provoking_vertex */ + +#ifdef GL_ARB_sample_shading + +static GLboolean _glewInit_GL_ARB_sample_shading (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glMinSampleShadingARB = (PFNGLMINSAMPLESHADINGARBPROC)glewGetProcAddress((const GLubyte*)"glMinSampleShadingARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_sample_shading */ + +#ifdef GL_ARB_sampler_objects + +static GLboolean _glewInit_GL_ARB_sampler_objects (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindSampler = (PFNGLBINDSAMPLERPROC)glewGetProcAddress((const GLubyte*)"glBindSampler")) == NULL) || r; + r = ((glDeleteSamplers = (PFNGLDELETESAMPLERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteSamplers")) == NULL) || r; + r = ((glGenSamplers = (PFNGLGENSAMPLERSPROC)glewGetProcAddress((const GLubyte*)"glGenSamplers")) == NULL) || r; + r = ((glGetSamplerParameterIiv = (PFNGLGETSAMPLERPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameterIiv")) == NULL) || r; + r = ((glGetSamplerParameterIuiv = (PFNGLGETSAMPLERPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameterIuiv")) == NULL) || r; + r = ((glGetSamplerParameterfv = (PFNGLGETSAMPLERPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameterfv")) == NULL) || r; + r = ((glGetSamplerParameteriv = (PFNGLGETSAMPLERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameteriv")) == NULL) || r; + r = ((glIsSampler = (PFNGLISSAMPLERPROC)glewGetProcAddress((const GLubyte*)"glIsSampler")) == NULL) || r; + r = ((glSamplerParameterIiv = (PFNGLSAMPLERPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterIiv")) == NULL) || r; + r = ((glSamplerParameterIuiv = (PFNGLSAMPLERPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterIuiv")) == NULL) || r; + r = ((glSamplerParameterf = (PFNGLSAMPLERPARAMETERFPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterf")) == NULL) || r; + r = ((glSamplerParameterfv = (PFNGLSAMPLERPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterfv")) == NULL) || r; + r = ((glSamplerParameteri = (PFNGLSAMPLERPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameteri")) == NULL) || r; + r = ((glSamplerParameteriv = (PFNGLSAMPLERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameteriv")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_sampler_objects */ + +#ifdef GL_ARB_seamless_cube_map + +#endif /* GL_ARB_seamless_cube_map */ + +#ifdef GL_ARB_shader_bit_encoding + +#endif /* GL_ARB_shader_bit_encoding */ + +#ifdef GL_ARB_shader_objects + +static GLboolean _glewInit_GL_ARB_shader_objects (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glAttachObjectARB = (PFNGLATTACHOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glAttachObjectARB")) == NULL) || r; + r = ((glCompileShaderARB = (PFNGLCOMPILESHADERARBPROC)glewGetProcAddress((const GLubyte*)"glCompileShaderARB")) == NULL) || r; + r = ((glCreateProgramObjectARB = (PFNGLCREATEPROGRAMOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glCreateProgramObjectARB")) == NULL) || r; + r = ((glCreateShaderObjectARB = (PFNGLCREATESHADEROBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glCreateShaderObjectARB")) == NULL) || r; + r = ((glDeleteObjectARB = (PFNGLDELETEOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteObjectARB")) == NULL) || r; + r = ((glDetachObjectARB = (PFNGLDETACHOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glDetachObjectARB")) == NULL) || r; + r = ((glGetActiveUniformARB = (PFNGLGETACTIVEUNIFORMARBPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformARB")) == NULL) || r; + r = ((glGetAttachedObjectsARB = (PFNGLGETATTACHEDOBJECTSARBPROC)glewGetProcAddress((const GLubyte*)"glGetAttachedObjectsARB")) == NULL) || r; + r = ((glGetHandleARB = (PFNGLGETHANDLEARBPROC)glewGetProcAddress((const GLubyte*)"glGetHandleARB")) == NULL) || r; + r = ((glGetInfoLogARB = (PFNGLGETINFOLOGARBPROC)glewGetProcAddress((const GLubyte*)"glGetInfoLogARB")) == NULL) || r; + r = ((glGetObjectParameterfvARB = (PFNGLGETOBJECTPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetObjectParameterfvARB")) == NULL) || r; + r = ((glGetObjectParameterivARB = (PFNGLGETOBJECTPARAMETERIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetObjectParameterivARB")) == NULL) || r; + r = ((glGetShaderSourceARB = (PFNGLGETSHADERSOURCEARBPROC)glewGetProcAddress((const GLubyte*)"glGetShaderSourceARB")) == NULL) || r; + r = ((glGetUniformLocationARB = (PFNGLGETUNIFORMLOCATIONARBPROC)glewGetProcAddress((const GLubyte*)"glGetUniformLocationARB")) == NULL) || r; + r = ((glGetUniformfvARB = (PFNGLGETUNIFORMFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetUniformfvARB")) == NULL) || r; + r = ((glGetUniformivARB = (PFNGLGETUNIFORMIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetUniformivARB")) == NULL) || r; + r = ((glLinkProgramARB = (PFNGLLINKPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glLinkProgramARB")) == NULL) || r; + r = ((glShaderSourceARB = (PFNGLSHADERSOURCEARBPROC)glewGetProcAddress((const GLubyte*)"glShaderSourceARB")) == NULL) || r; + r = ((glUniform1fARB = (PFNGLUNIFORM1FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1fARB")) == NULL) || r; + r = ((glUniform1fvARB = (PFNGLUNIFORM1FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1fvARB")) == NULL) || r; + r = ((glUniform1iARB = (PFNGLUNIFORM1IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1iARB")) == NULL) || r; + r = ((glUniform1ivARB = (PFNGLUNIFORM1IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1ivARB")) == NULL) || r; + r = ((glUniform2fARB = (PFNGLUNIFORM2FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2fARB")) == NULL) || r; + r = ((glUniform2fvARB = (PFNGLUNIFORM2FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2fvARB")) == NULL) || r; + r = ((glUniform2iARB = (PFNGLUNIFORM2IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2iARB")) == NULL) || r; + r = ((glUniform2ivARB = (PFNGLUNIFORM2IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2ivARB")) == NULL) || r; + r = ((glUniform3fARB = (PFNGLUNIFORM3FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3fARB")) == NULL) || r; + r = ((glUniform3fvARB = (PFNGLUNIFORM3FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3fvARB")) == NULL) || r; + r = ((glUniform3iARB = (PFNGLUNIFORM3IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3iARB")) == NULL) || r; + r = ((glUniform3ivARB = (PFNGLUNIFORM3IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3ivARB")) == NULL) || r; + r = ((glUniform4fARB = (PFNGLUNIFORM4FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4fARB")) == NULL) || r; + r = ((glUniform4fvARB = (PFNGLUNIFORM4FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4fvARB")) == NULL) || r; + r = ((glUniform4iARB = (PFNGLUNIFORM4IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4iARB")) == NULL) || r; + r = ((glUniform4ivARB = (PFNGLUNIFORM4IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4ivARB")) == NULL) || r; + r = ((glUniformMatrix2fvARB = (PFNGLUNIFORMMATRIX2FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2fvARB")) == NULL) || r; + r = ((glUniformMatrix3fvARB = (PFNGLUNIFORMMATRIX3FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3fvARB")) == NULL) || r; + r = ((glUniformMatrix4fvARB = (PFNGLUNIFORMMATRIX4FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4fvARB")) == NULL) || r; + r = ((glUseProgramObjectARB = (PFNGLUSEPROGRAMOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glUseProgramObjectARB")) == NULL) || r; + r = ((glValidateProgramARB = (PFNGLVALIDATEPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glValidateProgramARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_shader_objects */ + +#ifdef GL_ARB_shader_subroutine + +static GLboolean _glewInit_GL_ARB_shader_subroutine (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetActiveSubroutineName = (PFNGLGETACTIVESUBROUTINENAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveSubroutineName")) == NULL) || r; + r = ((glGetActiveSubroutineUniformName = (PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveSubroutineUniformName")) == NULL) || r; + r = ((glGetActiveSubroutineUniformiv = (PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveSubroutineUniformiv")) == NULL) || r; + r = ((glGetProgramStageiv = (PFNGLGETPROGRAMSTAGEIVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramStageiv")) == NULL) || r; + r = ((glGetSubroutineIndex = (PFNGLGETSUBROUTINEINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetSubroutineIndex")) == NULL) || r; + r = ((glGetSubroutineUniformLocation = (PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetSubroutineUniformLocation")) == NULL) || r; + r = ((glGetUniformSubroutineuiv = (PFNGLGETUNIFORMSUBROUTINEUIVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformSubroutineuiv")) == NULL) || r; + r = ((glUniformSubroutinesuiv = (PFNGLUNIFORMSUBROUTINESUIVPROC)glewGetProcAddress((const GLubyte*)"glUniformSubroutinesuiv")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_shader_subroutine */ + +#ifdef GL_ARB_shader_texture_lod + +#endif /* GL_ARB_shader_texture_lod */ + +#ifdef GL_ARB_shading_language_100 + +#endif /* GL_ARB_shading_language_100 */ + +#ifdef GL_ARB_shading_language_include + +static GLboolean _glewInit_GL_ARB_shading_language_include (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCompileShaderIncludeARB = (PFNGLCOMPILESHADERINCLUDEARBPROC)glewGetProcAddress((const GLubyte*)"glCompileShaderIncludeARB")) == NULL) || r; + r = ((glDeleteNamedStringARB = (PFNGLDELETENAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteNamedStringARB")) == NULL) || r; + r = ((glGetNamedStringARB = (PFNGLGETNAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glGetNamedStringARB")) == NULL) || r; + r = ((glGetNamedStringivARB = (PFNGLGETNAMEDSTRINGIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetNamedStringivARB")) == NULL) || r; + r = ((glIsNamedStringARB = (PFNGLISNAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glIsNamedStringARB")) == NULL) || r; + r = ((glNamedStringARB = (PFNGLNAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glNamedStringARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_shading_language_include */ + +#ifdef GL_ARB_shadow + +#endif /* GL_ARB_shadow */ + +#ifdef GL_ARB_shadow_ambient + +#endif /* GL_ARB_shadow_ambient */ + +#ifdef GL_ARB_sync + +static GLboolean _glewInit_GL_ARB_sync (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glClientWaitSync = (PFNGLCLIENTWAITSYNCPROC)glewGetProcAddress((const GLubyte*)"glClientWaitSync")) == NULL) || r; + r = ((glDeleteSync = (PFNGLDELETESYNCPROC)glewGetProcAddress((const GLubyte*)"glDeleteSync")) == NULL) || r; + r = ((glFenceSync = (PFNGLFENCESYNCPROC)glewGetProcAddress((const GLubyte*)"glFenceSync")) == NULL) || r; + r = ((glGetInteger64v = (PFNGLGETINTEGER64VPROC)glewGetProcAddress((const GLubyte*)"glGetInteger64v")) == NULL) || r; + r = ((glGetSynciv = (PFNGLGETSYNCIVPROC)glewGetProcAddress((const GLubyte*)"glGetSynciv")) == NULL) || r; + r = ((glIsSync = (PFNGLISSYNCPROC)glewGetProcAddress((const GLubyte*)"glIsSync")) == NULL) || r; + r = ((glWaitSync = (PFNGLWAITSYNCPROC)glewGetProcAddress((const GLubyte*)"glWaitSync")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_sync */ + +#ifdef GL_ARB_tessellation_shader + +static GLboolean _glewInit_GL_ARB_tessellation_shader (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPatchParameterfv = (PFNGLPATCHPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glPatchParameterfv")) == NULL) || r; + r = ((glPatchParameteri = (PFNGLPATCHPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glPatchParameteri")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_tessellation_shader */ + +#ifdef GL_ARB_texture_border_clamp + +#endif /* GL_ARB_texture_border_clamp */ + +#ifdef GL_ARB_texture_buffer_object + +static GLboolean _glewInit_GL_ARB_texture_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTexBufferARB = (PFNGLTEXBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glTexBufferARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_texture_buffer_object */ + +#ifdef GL_ARB_texture_buffer_object_rgb32 + +#endif /* GL_ARB_texture_buffer_object_rgb32 */ + +#ifdef GL_ARB_texture_compression + +static GLboolean _glewInit_GL_ARB_texture_compression (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCompressedTexImage1DARB = (PFNGLCOMPRESSEDTEXIMAGE1DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage1DARB")) == NULL) || r; + r = ((glCompressedTexImage2DARB = (PFNGLCOMPRESSEDTEXIMAGE2DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage2DARB")) == NULL) || r; + r = ((glCompressedTexImage3DARB = (PFNGLCOMPRESSEDTEXIMAGE3DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage3DARB")) == NULL) || r; + r = ((glCompressedTexSubImage1DARB = (PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage1DARB")) == NULL) || r; + r = ((glCompressedTexSubImage2DARB = (PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage2DARB")) == NULL) || r; + r = ((glCompressedTexSubImage3DARB = (PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage3DARB")) == NULL) || r; + r = ((glGetCompressedTexImageARB = (PFNGLGETCOMPRESSEDTEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedTexImageARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_texture_compression */ + +#ifdef GL_ARB_texture_compression_bptc + +#endif /* GL_ARB_texture_compression_bptc */ + +#ifdef GL_ARB_texture_compression_rgtc + +#endif /* GL_ARB_texture_compression_rgtc */ + +#ifdef GL_ARB_texture_cube_map + +#endif /* GL_ARB_texture_cube_map */ + +#ifdef GL_ARB_texture_cube_map_array + +#endif /* GL_ARB_texture_cube_map_array */ + +#ifdef GL_ARB_texture_env_add + +#endif /* GL_ARB_texture_env_add */ + +#ifdef GL_ARB_texture_env_combine + +#endif /* GL_ARB_texture_env_combine */ + +#ifdef GL_ARB_texture_env_crossbar + +#endif /* GL_ARB_texture_env_crossbar */ + +#ifdef GL_ARB_texture_env_dot3 + +#endif /* GL_ARB_texture_env_dot3 */ + +#ifdef GL_ARB_texture_float + +#endif /* GL_ARB_texture_float */ + +#ifdef GL_ARB_texture_gather + +#endif /* GL_ARB_texture_gather */ + +#ifdef GL_ARB_texture_mirrored_repeat + +#endif /* GL_ARB_texture_mirrored_repeat */ + +#ifdef GL_ARB_texture_multisample + +static GLboolean _glewInit_GL_ARB_texture_multisample (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetMultisamplefv = (PFNGLGETMULTISAMPLEFVPROC)glewGetProcAddress((const GLubyte*)"glGetMultisamplefv")) == NULL) || r; + r = ((glSampleMaski = (PFNGLSAMPLEMASKIPROC)glewGetProcAddress((const GLubyte*)"glSampleMaski")) == NULL) || r; + r = ((glTexImage2DMultisample = (PFNGLTEXIMAGE2DMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glTexImage2DMultisample")) == NULL) || r; + r = ((glTexImage3DMultisample = (PFNGLTEXIMAGE3DMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glTexImage3DMultisample")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_texture_multisample */ + +#ifdef GL_ARB_texture_non_power_of_two + +#endif /* GL_ARB_texture_non_power_of_two */ + +#ifdef GL_ARB_texture_query_lod + +#endif /* GL_ARB_texture_query_lod */ + +#ifdef GL_ARB_texture_rectangle + +#endif /* GL_ARB_texture_rectangle */ + +#ifdef GL_ARB_texture_rg + +#endif /* GL_ARB_texture_rg */ + +#ifdef GL_ARB_texture_rgb10_a2ui + +#endif /* GL_ARB_texture_rgb10_a2ui */ + +#ifdef GL_ARB_texture_swizzle + +#endif /* GL_ARB_texture_swizzle */ + +#ifdef GL_ARB_timer_query + +static GLboolean _glewInit_GL_ARB_timer_query (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetQueryObjecti64v = (PFNGLGETQUERYOBJECTI64VPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjecti64v")) == NULL) || r; + r = ((glGetQueryObjectui64v = (PFNGLGETQUERYOBJECTUI64VPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectui64v")) == NULL) || r; + r = ((glQueryCounter = (PFNGLQUERYCOUNTERPROC)glewGetProcAddress((const GLubyte*)"glQueryCounter")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_timer_query */ + +#ifdef GL_ARB_transform_feedback2 + +static GLboolean _glewInit_GL_ARB_transform_feedback2 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindTransformFeedback = (PFNGLBINDTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glBindTransformFeedback")) == NULL) || r; + r = ((glDeleteTransformFeedbacks = (PFNGLDELETETRANSFORMFEEDBACKSPROC)glewGetProcAddress((const GLubyte*)"glDeleteTransformFeedbacks")) == NULL) || r; + r = ((glDrawTransformFeedback = (PFNGLDRAWTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedback")) == NULL) || r; + r = ((glGenTransformFeedbacks = (PFNGLGENTRANSFORMFEEDBACKSPROC)glewGetProcAddress((const GLubyte*)"glGenTransformFeedbacks")) == NULL) || r; + r = ((glIsTransformFeedback = (PFNGLISTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glIsTransformFeedback")) == NULL) || r; + r = ((glPauseTransformFeedback = (PFNGLPAUSETRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glPauseTransformFeedback")) == NULL) || r; + r = ((glResumeTransformFeedback = (PFNGLRESUMETRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glResumeTransformFeedback")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_transform_feedback2 */ + +#ifdef GL_ARB_transform_feedback3 + +static GLboolean _glewInit_GL_ARB_transform_feedback3 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginQueryIndexed = (PFNGLBEGINQUERYINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glBeginQueryIndexed")) == NULL) || r; + r = ((glDrawTransformFeedbackStream = (PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedbackStream")) == NULL) || r; + r = ((glEndQueryIndexed = (PFNGLENDQUERYINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glEndQueryIndexed")) == NULL) || r; + r = ((glGetQueryIndexediv = (PFNGLGETQUERYINDEXEDIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryIndexediv")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_transform_feedback3 */ + +#ifdef GL_ARB_transpose_matrix + +static GLboolean _glewInit_GL_ARB_transpose_matrix (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glLoadTransposeMatrixdARB = (PFNGLLOADTRANSPOSEMATRIXDARBPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixdARB")) == NULL) || r; + r = ((glLoadTransposeMatrixfARB = (PFNGLLOADTRANSPOSEMATRIXFARBPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixfARB")) == NULL) || r; + r = ((glMultTransposeMatrixdARB = (PFNGLMULTTRANSPOSEMATRIXDARBPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixdARB")) == NULL) || r; + r = ((glMultTransposeMatrixfARB = (PFNGLMULTTRANSPOSEMATRIXFARBPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixfARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_transpose_matrix */ + +#ifdef GL_ARB_uniform_buffer_object + +static GLboolean _glewInit_GL_ARB_uniform_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindBufferBase = (PFNGLBINDBUFFERBASEPROC)glewGetProcAddress((const GLubyte*)"glBindBufferBase")) == NULL) || r; + r = ((glBindBufferRange = (PFNGLBINDBUFFERRANGEPROC)glewGetProcAddress((const GLubyte*)"glBindBufferRange")) == NULL) || r; + r = ((glGetActiveUniformBlockName = (PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformBlockName")) == NULL) || r; + r = ((glGetActiveUniformBlockiv = (PFNGLGETACTIVEUNIFORMBLOCKIVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformBlockiv")) == NULL) || r; + r = ((glGetActiveUniformName = (PFNGLGETACTIVEUNIFORMNAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformName")) == NULL) || r; + r = ((glGetActiveUniformsiv = (PFNGLGETACTIVEUNIFORMSIVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformsiv")) == NULL) || r; + r = ((glGetIntegeri_v = (PFNGLGETINTEGERI_VPROC)glewGetProcAddress((const GLubyte*)"glGetIntegeri_v")) == NULL) || r; + r = ((glGetUniformBlockIndex = (PFNGLGETUNIFORMBLOCKINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetUniformBlockIndex")) == NULL) || r; + r = ((glGetUniformIndices = (PFNGLGETUNIFORMINDICESPROC)glewGetProcAddress((const GLubyte*)"glGetUniformIndices")) == NULL) || r; + r = ((glUniformBlockBinding = (PFNGLUNIFORMBLOCKBINDINGPROC)glewGetProcAddress((const GLubyte*)"glUniformBlockBinding")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_uniform_buffer_object */ + +#ifdef GL_ARB_vertex_array_bgra + +#endif /* GL_ARB_vertex_array_bgra */ + +#ifdef GL_ARB_vertex_array_object + +static GLboolean _glewInit_GL_ARB_vertex_array_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindVertexArray = (PFNGLBINDVERTEXARRAYPROC)glewGetProcAddress((const GLubyte*)"glBindVertexArray")) == NULL) || r; + r = ((glDeleteVertexArrays = (PFNGLDELETEVERTEXARRAYSPROC)glewGetProcAddress((const GLubyte*)"glDeleteVertexArrays")) == NULL) || r; + r = ((glGenVertexArrays = (PFNGLGENVERTEXARRAYSPROC)glewGetProcAddress((const GLubyte*)"glGenVertexArrays")) == NULL) || r; + r = ((glIsVertexArray = (PFNGLISVERTEXARRAYPROC)glewGetProcAddress((const GLubyte*)"glIsVertexArray")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_vertex_array_object */ + +#ifdef GL_ARB_vertex_blend + +static GLboolean _glewInit_GL_ARB_vertex_blend (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glVertexBlendARB = (PFNGLVERTEXBLENDARBPROC)glewGetProcAddress((const GLubyte*)"glVertexBlendARB")) == NULL) || r; + r = ((glWeightPointerARB = (PFNGLWEIGHTPOINTERARBPROC)glewGetProcAddress((const GLubyte*)"glWeightPointerARB")) == NULL) || r; + r = ((glWeightbvARB = (PFNGLWEIGHTBVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightbvARB")) == NULL) || r; + r = ((glWeightdvARB = (PFNGLWEIGHTDVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightdvARB")) == NULL) || r; + r = ((glWeightfvARB = (PFNGLWEIGHTFVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightfvARB")) == NULL) || r; + r = ((glWeightivARB = (PFNGLWEIGHTIVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightivARB")) == NULL) || r; + r = ((glWeightsvARB = (PFNGLWEIGHTSVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightsvARB")) == NULL) || r; + r = ((glWeightubvARB = (PFNGLWEIGHTUBVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightubvARB")) == NULL) || r; + r = ((glWeightuivARB = (PFNGLWEIGHTUIVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightuivARB")) == NULL) || r; + r = ((glWeightusvARB = (PFNGLWEIGHTUSVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightusvARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_vertex_blend */ + +#ifdef GL_ARB_vertex_buffer_object + +static GLboolean _glewInit_GL_ARB_vertex_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindBufferARB = (PFNGLBINDBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glBindBufferARB")) == NULL) || r; + r = ((glBufferDataARB = (PFNGLBUFFERDATAARBPROC)glewGetProcAddress((const GLubyte*)"glBufferDataARB")) == NULL) || r; + r = ((glBufferSubDataARB = (PFNGLBUFFERSUBDATAARBPROC)glewGetProcAddress((const GLubyte*)"glBufferSubDataARB")) == NULL) || r; + r = ((glDeleteBuffersARB = (PFNGLDELETEBUFFERSARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteBuffersARB")) == NULL) || r; + r = ((glGenBuffersARB = (PFNGLGENBUFFERSARBPROC)glewGetProcAddress((const GLubyte*)"glGenBuffersARB")) == NULL) || r; + r = ((glGetBufferParameterivARB = (PFNGLGETBUFFERPARAMETERIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameterivARB")) == NULL) || r; + r = ((glGetBufferPointervARB = (PFNGLGETBUFFERPOINTERVARBPROC)glewGetProcAddress((const GLubyte*)"glGetBufferPointervARB")) == NULL) || r; + r = ((glGetBufferSubDataARB = (PFNGLGETBUFFERSUBDATAARBPROC)glewGetProcAddress((const GLubyte*)"glGetBufferSubDataARB")) == NULL) || r; + r = ((glIsBufferARB = (PFNGLISBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glIsBufferARB")) == NULL) || r; + r = ((glMapBufferARB = (PFNGLMAPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glMapBufferARB")) == NULL) || r; + r = ((glUnmapBufferARB = (PFNGLUNMAPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glUnmapBufferARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_vertex_buffer_object */ + +#ifdef GL_ARB_vertex_program + +static GLboolean _glewInit_GL_ARB_vertex_program (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindProgramARB = (PFNGLBINDPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glBindProgramARB")) == NULL) || r; + r = ((glDeleteProgramsARB = (PFNGLDELETEPROGRAMSARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteProgramsARB")) == NULL) || r; + r = ((glDisableVertexAttribArrayARB = (PFNGLDISABLEVERTEXATTRIBARRAYARBPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexAttribArrayARB")) == NULL) || r; + r = ((glEnableVertexAttribArrayARB = (PFNGLENABLEVERTEXATTRIBARRAYARBPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexAttribArrayARB")) == NULL) || r; + r = ((glGenProgramsARB = (PFNGLGENPROGRAMSARBPROC)glewGetProcAddress((const GLubyte*)"glGenProgramsARB")) == NULL) || r; + r = ((glGetProgramEnvParameterdvARB = (PFNGLGETPROGRAMENVPARAMETERDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramEnvParameterdvARB")) == NULL) || r; + r = ((glGetProgramEnvParameterfvARB = (PFNGLGETPROGRAMENVPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramEnvParameterfvARB")) == NULL) || r; + r = ((glGetProgramLocalParameterdvARB = (PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramLocalParameterdvARB")) == NULL) || r; + r = ((glGetProgramLocalParameterfvARB = (PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramLocalParameterfvARB")) == NULL) || r; + r = ((glGetProgramStringARB = (PFNGLGETPROGRAMSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramStringARB")) == NULL) || r; + r = ((glGetProgramivARB = (PFNGLGETPROGRAMIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramivARB")) == NULL) || r; + r = ((glGetVertexAttribPointervARB = (PFNGLGETVERTEXATTRIBPOINTERVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribPointervARB")) == NULL) || r; + r = ((glGetVertexAttribdvARB = (PFNGLGETVERTEXATTRIBDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribdvARB")) == NULL) || r; + r = ((glGetVertexAttribfvARB = (PFNGLGETVERTEXATTRIBFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribfvARB")) == NULL) || r; + r = ((glGetVertexAttribivARB = (PFNGLGETVERTEXATTRIBIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribivARB")) == NULL) || r; + r = ((glIsProgramARB = (PFNGLISPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glIsProgramARB")) == NULL) || r; + r = ((glProgramEnvParameter4dARB = (PFNGLPROGRAMENVPARAMETER4DARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4dARB")) == NULL) || r; + r = ((glProgramEnvParameter4dvARB = (PFNGLPROGRAMENVPARAMETER4DVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4dvARB")) == NULL) || r; + r = ((glProgramEnvParameter4fARB = (PFNGLPROGRAMENVPARAMETER4FARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4fARB")) == NULL) || r; + r = ((glProgramEnvParameter4fvARB = (PFNGLPROGRAMENVPARAMETER4FVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4fvARB")) == NULL) || r; + r = ((glProgramLocalParameter4dARB = (PFNGLPROGRAMLOCALPARAMETER4DARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4dARB")) == NULL) || r; + r = ((glProgramLocalParameter4dvARB = (PFNGLPROGRAMLOCALPARAMETER4DVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4dvARB")) == NULL) || r; + r = ((glProgramLocalParameter4fARB = (PFNGLPROGRAMLOCALPARAMETER4FARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4fARB")) == NULL) || r; + r = ((glProgramLocalParameter4fvARB = (PFNGLPROGRAMLOCALPARAMETER4FVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4fvARB")) == NULL) || r; + r = ((glProgramStringARB = (PFNGLPROGRAMSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glProgramStringARB")) == NULL) || r; + r = ((glVertexAttrib1dARB = (PFNGLVERTEXATTRIB1DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dARB")) == NULL) || r; + r = ((glVertexAttrib1dvARB = (PFNGLVERTEXATTRIB1DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dvARB")) == NULL) || r; + r = ((glVertexAttrib1fARB = (PFNGLVERTEXATTRIB1FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fARB")) == NULL) || r; + r = ((glVertexAttrib1fvARB = (PFNGLVERTEXATTRIB1FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fvARB")) == NULL) || r; + r = ((glVertexAttrib1sARB = (PFNGLVERTEXATTRIB1SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1sARB")) == NULL) || r; + r = ((glVertexAttrib1svARB = (PFNGLVERTEXATTRIB1SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1svARB")) == NULL) || r; + r = ((glVertexAttrib2dARB = (PFNGLVERTEXATTRIB2DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dARB")) == NULL) || r; + r = ((glVertexAttrib2dvARB = (PFNGLVERTEXATTRIB2DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dvARB")) == NULL) || r; + r = ((glVertexAttrib2fARB = (PFNGLVERTEXATTRIB2FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fARB")) == NULL) || r; + r = ((glVertexAttrib2fvARB = (PFNGLVERTEXATTRIB2FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fvARB")) == NULL) || r; + r = ((glVertexAttrib2sARB = (PFNGLVERTEXATTRIB2SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2sARB")) == NULL) || r; + r = ((glVertexAttrib2svARB = (PFNGLVERTEXATTRIB2SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2svARB")) == NULL) || r; + r = ((glVertexAttrib3dARB = (PFNGLVERTEXATTRIB3DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dARB")) == NULL) || r; + r = ((glVertexAttrib3dvARB = (PFNGLVERTEXATTRIB3DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dvARB")) == NULL) || r; + r = ((glVertexAttrib3fARB = (PFNGLVERTEXATTRIB3FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fARB")) == NULL) || r; + r = ((glVertexAttrib3fvARB = (PFNGLVERTEXATTRIB3FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fvARB")) == NULL) || r; + r = ((glVertexAttrib3sARB = (PFNGLVERTEXATTRIB3SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3sARB")) == NULL) || r; + r = ((glVertexAttrib3svARB = (PFNGLVERTEXATTRIB3SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3svARB")) == NULL) || r; + r = ((glVertexAttrib4NbvARB = (PFNGLVERTEXATTRIB4NBVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NbvARB")) == NULL) || r; + r = ((glVertexAttrib4NivARB = (PFNGLVERTEXATTRIB4NIVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NivARB")) == NULL) || r; + r = ((glVertexAttrib4NsvARB = (PFNGLVERTEXATTRIB4NSVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NsvARB")) == NULL) || r; + r = ((glVertexAttrib4NubARB = (PFNGLVERTEXATTRIB4NUBARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NubARB")) == NULL) || r; + r = ((glVertexAttrib4NubvARB = (PFNGLVERTEXATTRIB4NUBVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NubvARB")) == NULL) || r; + r = ((glVertexAttrib4NuivARB = (PFNGLVERTEXATTRIB4NUIVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NuivARB")) == NULL) || r; + r = ((glVertexAttrib4NusvARB = (PFNGLVERTEXATTRIB4NUSVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NusvARB")) == NULL) || r; + r = ((glVertexAttrib4bvARB = (PFNGLVERTEXATTRIB4BVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4bvARB")) == NULL) || r; + r = ((glVertexAttrib4dARB = (PFNGLVERTEXATTRIB4DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dARB")) == NULL) || r; + r = ((glVertexAttrib4dvARB = (PFNGLVERTEXATTRIB4DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dvARB")) == NULL) || r; + r = ((glVertexAttrib4fARB = (PFNGLVERTEXATTRIB4FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fARB")) == NULL) || r; + r = ((glVertexAttrib4fvARB = (PFNGLVERTEXATTRIB4FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fvARB")) == NULL) || r; + r = ((glVertexAttrib4ivARB = (PFNGLVERTEXATTRIB4IVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ivARB")) == NULL) || r; + r = ((glVertexAttrib4sARB = (PFNGLVERTEXATTRIB4SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4sARB")) == NULL) || r; + r = ((glVertexAttrib4svARB = (PFNGLVERTEXATTRIB4SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4svARB")) == NULL) || r; + r = ((glVertexAttrib4ubvARB = (PFNGLVERTEXATTRIB4UBVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubvARB")) == NULL) || r; + r = ((glVertexAttrib4uivARB = (PFNGLVERTEXATTRIB4UIVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4uivARB")) == NULL) || r; + r = ((glVertexAttrib4usvARB = (PFNGLVERTEXATTRIB4USVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4usvARB")) == NULL) || r; + r = ((glVertexAttribPointerARB = (PFNGLVERTEXATTRIBPOINTERARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribPointerARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_vertex_program */ + +#ifdef GL_ARB_vertex_shader + +static GLboolean _glewInit_GL_ARB_vertex_shader (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindAttribLocationARB = (PFNGLBINDATTRIBLOCATIONARBPROC)glewGetProcAddress((const GLubyte*)"glBindAttribLocationARB")) == NULL) || r; + r = ((glGetActiveAttribARB = (PFNGLGETACTIVEATTRIBARBPROC)glewGetProcAddress((const GLubyte*)"glGetActiveAttribARB")) == NULL) || r; + r = ((glGetAttribLocationARB = (PFNGLGETATTRIBLOCATIONARBPROC)glewGetProcAddress((const GLubyte*)"glGetAttribLocationARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_vertex_shader */ + +#ifdef GL_ARB_vertex_type_2_10_10_10_rev + +static GLboolean _glewInit_GL_ARB_vertex_type_2_10_10_10_rev (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColorP3ui = (PFNGLCOLORP3UIPROC)glewGetProcAddress((const GLubyte*)"glColorP3ui")) == NULL) || r; + r = ((glColorP3uiv = (PFNGLCOLORP3UIVPROC)glewGetProcAddress((const GLubyte*)"glColorP3uiv")) == NULL) || r; + r = ((glColorP4ui = (PFNGLCOLORP4UIPROC)glewGetProcAddress((const GLubyte*)"glColorP4ui")) == NULL) || r; + r = ((glColorP4uiv = (PFNGLCOLORP4UIVPROC)glewGetProcAddress((const GLubyte*)"glColorP4uiv")) == NULL) || r; + r = ((glMultiTexCoordP1ui = (PFNGLMULTITEXCOORDP1UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP1ui")) == NULL) || r; + r = ((glMultiTexCoordP1uiv = (PFNGLMULTITEXCOORDP1UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP1uiv")) == NULL) || r; + r = ((glMultiTexCoordP2ui = (PFNGLMULTITEXCOORDP2UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP2ui")) == NULL) || r; + r = ((glMultiTexCoordP2uiv = (PFNGLMULTITEXCOORDP2UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP2uiv")) == NULL) || r; + r = ((glMultiTexCoordP3ui = (PFNGLMULTITEXCOORDP3UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP3ui")) == NULL) || r; + r = ((glMultiTexCoordP3uiv = (PFNGLMULTITEXCOORDP3UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP3uiv")) == NULL) || r; + r = ((glMultiTexCoordP4ui = (PFNGLMULTITEXCOORDP4UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP4ui")) == NULL) || r; + r = ((glMultiTexCoordP4uiv = (PFNGLMULTITEXCOORDP4UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP4uiv")) == NULL) || r; + r = ((glNormalP3ui = (PFNGLNORMALP3UIPROC)glewGetProcAddress((const GLubyte*)"glNormalP3ui")) == NULL) || r; + r = ((glNormalP3uiv = (PFNGLNORMALP3UIVPROC)glewGetProcAddress((const GLubyte*)"glNormalP3uiv")) == NULL) || r; + r = ((glSecondaryColorP3ui = (PFNGLSECONDARYCOLORP3UIPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorP3ui")) == NULL) || r; + r = ((glSecondaryColorP3uiv = (PFNGLSECONDARYCOLORP3UIVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorP3uiv")) == NULL) || r; + r = ((glTexCoordP1ui = (PFNGLTEXCOORDP1UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP1ui")) == NULL) || r; + r = ((glTexCoordP1uiv = (PFNGLTEXCOORDP1UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP1uiv")) == NULL) || r; + r = ((glTexCoordP2ui = (PFNGLTEXCOORDP2UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP2ui")) == NULL) || r; + r = ((glTexCoordP2uiv = (PFNGLTEXCOORDP2UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP2uiv")) == NULL) || r; + r = ((glTexCoordP3ui = (PFNGLTEXCOORDP3UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP3ui")) == NULL) || r; + r = ((glTexCoordP3uiv = (PFNGLTEXCOORDP3UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP3uiv")) == NULL) || r; + r = ((glTexCoordP4ui = (PFNGLTEXCOORDP4UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP4ui")) == NULL) || r; + r = ((glTexCoordP4uiv = (PFNGLTEXCOORDP4UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP4uiv")) == NULL) || r; + r = ((glVertexAttribP1ui = (PFNGLVERTEXATTRIBP1UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP1ui")) == NULL) || r; + r = ((glVertexAttribP1uiv = (PFNGLVERTEXATTRIBP1UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP1uiv")) == NULL) || r; + r = ((glVertexAttribP2ui = (PFNGLVERTEXATTRIBP2UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP2ui")) == NULL) || r; + r = ((glVertexAttribP2uiv = (PFNGLVERTEXATTRIBP2UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP2uiv")) == NULL) || r; + r = ((glVertexAttribP3ui = (PFNGLVERTEXATTRIBP3UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP3ui")) == NULL) || r; + r = ((glVertexAttribP3uiv = (PFNGLVERTEXATTRIBP3UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP3uiv")) == NULL) || r; + r = ((glVertexAttribP4ui = (PFNGLVERTEXATTRIBP4UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP4ui")) == NULL) || r; + r = ((glVertexAttribP4uiv = (PFNGLVERTEXATTRIBP4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP4uiv")) == NULL) || r; + r = ((glVertexP2ui = (PFNGLVERTEXP2UIPROC)glewGetProcAddress((const GLubyte*)"glVertexP2ui")) == NULL) || r; + r = ((glVertexP2uiv = (PFNGLVERTEXP2UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexP2uiv")) == NULL) || r; + r = ((glVertexP3ui = (PFNGLVERTEXP3UIPROC)glewGetProcAddress((const GLubyte*)"glVertexP3ui")) == NULL) || r; + r = ((glVertexP3uiv = (PFNGLVERTEXP3UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexP3uiv")) == NULL) || r; + r = ((glVertexP4ui = (PFNGLVERTEXP4UIPROC)glewGetProcAddress((const GLubyte*)"glVertexP4ui")) == NULL) || r; + r = ((glVertexP4uiv = (PFNGLVERTEXP4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexP4uiv")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ + +#ifdef GL_ARB_window_pos + +static GLboolean _glewInit_GL_ARB_window_pos (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glWindowPos2dARB = (PFNGLWINDOWPOS2DARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dARB")) == NULL) || r; + r = ((glWindowPos2dvARB = (PFNGLWINDOWPOS2DVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dvARB")) == NULL) || r; + r = ((glWindowPos2fARB = (PFNGLWINDOWPOS2FARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fARB")) == NULL) || r; + r = ((glWindowPos2fvARB = (PFNGLWINDOWPOS2FVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fvARB")) == NULL) || r; + r = ((glWindowPos2iARB = (PFNGLWINDOWPOS2IARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2iARB")) == NULL) || r; + r = ((glWindowPos2ivARB = (PFNGLWINDOWPOS2IVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2ivARB")) == NULL) || r; + r = ((glWindowPos2sARB = (PFNGLWINDOWPOS2SARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2sARB")) == NULL) || r; + r = ((glWindowPos2svARB = (PFNGLWINDOWPOS2SVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2svARB")) == NULL) || r; + r = ((glWindowPos3dARB = (PFNGLWINDOWPOS3DARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dARB")) == NULL) || r; + r = ((glWindowPos3dvARB = (PFNGLWINDOWPOS3DVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dvARB")) == NULL) || r; + r = ((glWindowPos3fARB = (PFNGLWINDOWPOS3FARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fARB")) == NULL) || r; + r = ((glWindowPos3fvARB = (PFNGLWINDOWPOS3FVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fvARB")) == NULL) || r; + r = ((glWindowPos3iARB = (PFNGLWINDOWPOS3IARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3iARB")) == NULL) || r; + r = ((glWindowPos3ivARB = (PFNGLWINDOWPOS3IVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3ivARB")) == NULL) || r; + r = ((glWindowPos3sARB = (PFNGLWINDOWPOS3SARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3sARB")) == NULL) || r; + r = ((glWindowPos3svARB = (PFNGLWINDOWPOS3SVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3svARB")) == NULL) || r; + + return r; +} + +#endif /* GL_ARB_window_pos */ + +#ifdef GL_ATIX_point_sprites + +#endif /* GL_ATIX_point_sprites */ + +#ifdef GL_ATIX_texture_env_combine3 + +#endif /* GL_ATIX_texture_env_combine3 */ + +#ifdef GL_ATIX_texture_env_route + +#endif /* GL_ATIX_texture_env_route */ + +#ifdef GL_ATIX_vertex_shader_output_point_size + +#endif /* GL_ATIX_vertex_shader_output_point_size */ + +#ifdef GL_ATI_draw_buffers + +static GLboolean _glewInit_GL_ATI_draw_buffers (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawBuffersATI = (PFNGLDRAWBUFFERSATIPROC)glewGetProcAddress((const GLubyte*)"glDrawBuffersATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_draw_buffers */ + +#ifdef GL_ATI_element_array + +static GLboolean _glewInit_GL_ATI_element_array (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawElementArrayATI = (PFNGLDRAWELEMENTARRAYATIPROC)glewGetProcAddress((const GLubyte*)"glDrawElementArrayATI")) == NULL) || r; + r = ((glDrawRangeElementArrayATI = (PFNGLDRAWRANGEELEMENTARRAYATIPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementArrayATI")) == NULL) || r; + r = ((glElementPointerATI = (PFNGLELEMENTPOINTERATIPROC)glewGetProcAddress((const GLubyte*)"glElementPointerATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_element_array */ + +#ifdef GL_ATI_envmap_bumpmap + +static GLboolean _glewInit_GL_ATI_envmap_bumpmap (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetTexBumpParameterfvATI = (PFNGLGETTEXBUMPPARAMETERFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetTexBumpParameterfvATI")) == NULL) || r; + r = ((glGetTexBumpParameterivATI = (PFNGLGETTEXBUMPPARAMETERIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetTexBumpParameterivATI")) == NULL) || r; + r = ((glTexBumpParameterfvATI = (PFNGLTEXBUMPPARAMETERFVATIPROC)glewGetProcAddress((const GLubyte*)"glTexBumpParameterfvATI")) == NULL) || r; + r = ((glTexBumpParameterivATI = (PFNGLTEXBUMPPARAMETERIVATIPROC)glewGetProcAddress((const GLubyte*)"glTexBumpParameterivATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_envmap_bumpmap */ + +#ifdef GL_ATI_fragment_shader + +static GLboolean _glewInit_GL_ATI_fragment_shader (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glAlphaFragmentOp1ATI = (PFNGLALPHAFRAGMENTOP1ATIPROC)glewGetProcAddress((const GLubyte*)"glAlphaFragmentOp1ATI")) == NULL) || r; + r = ((glAlphaFragmentOp2ATI = (PFNGLALPHAFRAGMENTOP2ATIPROC)glewGetProcAddress((const GLubyte*)"glAlphaFragmentOp2ATI")) == NULL) || r; + r = ((glAlphaFragmentOp3ATI = (PFNGLALPHAFRAGMENTOP3ATIPROC)glewGetProcAddress((const GLubyte*)"glAlphaFragmentOp3ATI")) == NULL) || r; + r = ((glBeginFragmentShaderATI = (PFNGLBEGINFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glBeginFragmentShaderATI")) == NULL) || r; + r = ((glBindFragmentShaderATI = (PFNGLBINDFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glBindFragmentShaderATI")) == NULL) || r; + r = ((glColorFragmentOp1ATI = (PFNGLCOLORFRAGMENTOP1ATIPROC)glewGetProcAddress((const GLubyte*)"glColorFragmentOp1ATI")) == NULL) || r; + r = ((glColorFragmentOp2ATI = (PFNGLCOLORFRAGMENTOP2ATIPROC)glewGetProcAddress((const GLubyte*)"glColorFragmentOp2ATI")) == NULL) || r; + r = ((glColorFragmentOp3ATI = (PFNGLCOLORFRAGMENTOP3ATIPROC)glewGetProcAddress((const GLubyte*)"glColorFragmentOp3ATI")) == NULL) || r; + r = ((glDeleteFragmentShaderATI = (PFNGLDELETEFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glDeleteFragmentShaderATI")) == NULL) || r; + r = ((glEndFragmentShaderATI = (PFNGLENDFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glEndFragmentShaderATI")) == NULL) || r; + r = ((glGenFragmentShadersATI = (PFNGLGENFRAGMENTSHADERSATIPROC)glewGetProcAddress((const GLubyte*)"glGenFragmentShadersATI")) == NULL) || r; + r = ((glPassTexCoordATI = (PFNGLPASSTEXCOORDATIPROC)glewGetProcAddress((const GLubyte*)"glPassTexCoordATI")) == NULL) || r; + r = ((glSampleMapATI = (PFNGLSAMPLEMAPATIPROC)glewGetProcAddress((const GLubyte*)"glSampleMapATI")) == NULL) || r; + r = ((glSetFragmentShaderConstantATI = (PFNGLSETFRAGMENTSHADERCONSTANTATIPROC)glewGetProcAddress((const GLubyte*)"glSetFragmentShaderConstantATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_fragment_shader */ + +#ifdef GL_ATI_map_object_buffer + +static GLboolean _glewInit_GL_ATI_map_object_buffer (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glMapObjectBufferATI = (PFNGLMAPOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glMapObjectBufferATI")) == NULL) || r; + r = ((glUnmapObjectBufferATI = (PFNGLUNMAPOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glUnmapObjectBufferATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_map_object_buffer */ + +#ifdef GL_ATI_meminfo + +#endif /* GL_ATI_meminfo */ + +#ifdef GL_ATI_pn_triangles + +static GLboolean _glewInit_GL_ATI_pn_triangles (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPNTrianglesfATI = (PFNGLPNTRIANGLESFATIPROC)glewGetProcAddress((const GLubyte*)"glPNTrianglesfATI")) == NULL) || r; + r = ((glPNTrianglesiATI = (PFNGLPNTRIANGLESIATIPROC)glewGetProcAddress((const GLubyte*)"glPNTrianglesiATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_pn_triangles */ + +#ifdef GL_ATI_separate_stencil + +static GLboolean _glewInit_GL_ATI_separate_stencil (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glStencilFuncSeparateATI = (PFNGLSTENCILFUNCSEPARATEATIPROC)glewGetProcAddress((const GLubyte*)"glStencilFuncSeparateATI")) == NULL) || r; + r = ((glStencilOpSeparateATI = (PFNGLSTENCILOPSEPARATEATIPROC)glewGetProcAddress((const GLubyte*)"glStencilOpSeparateATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_separate_stencil */ + +#ifdef GL_ATI_shader_texture_lod + +#endif /* GL_ATI_shader_texture_lod */ + +#ifdef GL_ATI_text_fragment_shader + +#endif /* GL_ATI_text_fragment_shader */ + +#ifdef GL_ATI_texture_compression_3dc + +#endif /* GL_ATI_texture_compression_3dc */ + +#ifdef GL_ATI_texture_env_combine3 + +#endif /* GL_ATI_texture_env_combine3 */ + +#ifdef GL_ATI_texture_float + +#endif /* GL_ATI_texture_float */ + +#ifdef GL_ATI_texture_mirror_once + +#endif /* GL_ATI_texture_mirror_once */ + +#ifdef GL_ATI_vertex_array_object + +static GLboolean _glewInit_GL_ATI_vertex_array_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glArrayObjectATI = (PFNGLARRAYOBJECTATIPROC)glewGetProcAddress((const GLubyte*)"glArrayObjectATI")) == NULL) || r; + r = ((glFreeObjectBufferATI = (PFNGLFREEOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glFreeObjectBufferATI")) == NULL) || r; + r = ((glGetArrayObjectfvATI = (PFNGLGETARRAYOBJECTFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetArrayObjectfvATI")) == NULL) || r; + r = ((glGetArrayObjectivATI = (PFNGLGETARRAYOBJECTIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetArrayObjectivATI")) == NULL) || r; + r = ((glGetObjectBufferfvATI = (PFNGLGETOBJECTBUFFERFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetObjectBufferfvATI")) == NULL) || r; + r = ((glGetObjectBufferivATI = (PFNGLGETOBJECTBUFFERIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetObjectBufferivATI")) == NULL) || r; + r = ((glGetVariantArrayObjectfvATI = (PFNGLGETVARIANTARRAYOBJECTFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVariantArrayObjectfvATI")) == NULL) || r; + r = ((glGetVariantArrayObjectivATI = (PFNGLGETVARIANTARRAYOBJECTIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVariantArrayObjectivATI")) == NULL) || r; + r = ((glIsObjectBufferATI = (PFNGLISOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glIsObjectBufferATI")) == NULL) || r; + r = ((glNewObjectBufferATI = (PFNGLNEWOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glNewObjectBufferATI")) == NULL) || r; + r = ((glUpdateObjectBufferATI = (PFNGLUPDATEOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glUpdateObjectBufferATI")) == NULL) || r; + r = ((glVariantArrayObjectATI = (PFNGLVARIANTARRAYOBJECTATIPROC)glewGetProcAddress((const GLubyte*)"glVariantArrayObjectATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_vertex_array_object */ + +#ifdef GL_ATI_vertex_attrib_array_object + +static GLboolean _glewInit_GL_ATI_vertex_attrib_array_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetVertexAttribArrayObjectfvATI = (PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribArrayObjectfvATI")) == NULL) || r; + r = ((glGetVertexAttribArrayObjectivATI = (PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribArrayObjectivATI")) == NULL) || r; + r = ((glVertexAttribArrayObjectATI = (PFNGLVERTEXATTRIBARRAYOBJECTATIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribArrayObjectATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_vertex_attrib_array_object */ + +#ifdef GL_ATI_vertex_streams + +static GLboolean _glewInit_GL_ATI_vertex_streams (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glClientActiveVertexStreamATI = (PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC)glewGetProcAddress((const GLubyte*)"glClientActiveVertexStreamATI")) == NULL) || r; + r = ((glNormalStream3bATI = (PFNGLNORMALSTREAM3BATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3bATI")) == NULL) || r; + r = ((glNormalStream3bvATI = (PFNGLNORMALSTREAM3BVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3bvATI")) == NULL) || r; + r = ((glNormalStream3dATI = (PFNGLNORMALSTREAM3DATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3dATI")) == NULL) || r; + r = ((glNormalStream3dvATI = (PFNGLNORMALSTREAM3DVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3dvATI")) == NULL) || r; + r = ((glNormalStream3fATI = (PFNGLNORMALSTREAM3FATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3fATI")) == NULL) || r; + r = ((glNormalStream3fvATI = (PFNGLNORMALSTREAM3FVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3fvATI")) == NULL) || r; + r = ((glNormalStream3iATI = (PFNGLNORMALSTREAM3IATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3iATI")) == NULL) || r; + r = ((glNormalStream3ivATI = (PFNGLNORMALSTREAM3IVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3ivATI")) == NULL) || r; + r = ((glNormalStream3sATI = (PFNGLNORMALSTREAM3SATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3sATI")) == NULL) || r; + r = ((glNormalStream3svATI = (PFNGLNORMALSTREAM3SVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3svATI")) == NULL) || r; + r = ((glVertexBlendEnvfATI = (PFNGLVERTEXBLENDENVFATIPROC)glewGetProcAddress((const GLubyte*)"glVertexBlendEnvfATI")) == NULL) || r; + r = ((glVertexBlendEnviATI = (PFNGLVERTEXBLENDENVIATIPROC)glewGetProcAddress((const GLubyte*)"glVertexBlendEnviATI")) == NULL) || r; + r = ((glVertexStream2dATI = (PFNGLVERTEXSTREAM2DATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2dATI")) == NULL) || r; + r = ((glVertexStream2dvATI = (PFNGLVERTEXSTREAM2DVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2dvATI")) == NULL) || r; + r = ((glVertexStream2fATI = (PFNGLVERTEXSTREAM2FATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2fATI")) == NULL) || r; + r = ((glVertexStream2fvATI = (PFNGLVERTEXSTREAM2FVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2fvATI")) == NULL) || r; + r = ((glVertexStream2iATI = (PFNGLVERTEXSTREAM2IATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2iATI")) == NULL) || r; + r = ((glVertexStream2ivATI = (PFNGLVERTEXSTREAM2IVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2ivATI")) == NULL) || r; + r = ((glVertexStream2sATI = (PFNGLVERTEXSTREAM2SATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2sATI")) == NULL) || r; + r = ((glVertexStream2svATI = (PFNGLVERTEXSTREAM2SVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2svATI")) == NULL) || r; + r = ((glVertexStream3dATI = (PFNGLVERTEXSTREAM3DATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3dATI")) == NULL) || r; + r = ((glVertexStream3dvATI = (PFNGLVERTEXSTREAM3DVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3dvATI")) == NULL) || r; + r = ((glVertexStream3fATI = (PFNGLVERTEXSTREAM3FATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3fATI")) == NULL) || r; + r = ((glVertexStream3fvATI = (PFNGLVERTEXSTREAM3FVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3fvATI")) == NULL) || r; + r = ((glVertexStream3iATI = (PFNGLVERTEXSTREAM3IATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3iATI")) == NULL) || r; + r = ((glVertexStream3ivATI = (PFNGLVERTEXSTREAM3IVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3ivATI")) == NULL) || r; + r = ((glVertexStream3sATI = (PFNGLVERTEXSTREAM3SATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3sATI")) == NULL) || r; + r = ((glVertexStream3svATI = (PFNGLVERTEXSTREAM3SVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3svATI")) == NULL) || r; + r = ((glVertexStream4dATI = (PFNGLVERTEXSTREAM4DATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4dATI")) == NULL) || r; + r = ((glVertexStream4dvATI = (PFNGLVERTEXSTREAM4DVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4dvATI")) == NULL) || r; + r = ((glVertexStream4fATI = (PFNGLVERTEXSTREAM4FATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4fATI")) == NULL) || r; + r = ((glVertexStream4fvATI = (PFNGLVERTEXSTREAM4FVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4fvATI")) == NULL) || r; + r = ((glVertexStream4iATI = (PFNGLVERTEXSTREAM4IATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4iATI")) == NULL) || r; + r = ((glVertexStream4ivATI = (PFNGLVERTEXSTREAM4IVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4ivATI")) == NULL) || r; + r = ((glVertexStream4sATI = (PFNGLVERTEXSTREAM4SATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4sATI")) == NULL) || r; + r = ((glVertexStream4svATI = (PFNGLVERTEXSTREAM4SVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4svATI")) == NULL) || r; + + return r; +} + +#endif /* GL_ATI_vertex_streams */ + +#ifdef GL_EXT_422_pixels + +#endif /* GL_EXT_422_pixels */ + +#ifdef GL_EXT_Cg_shader + +#endif /* GL_EXT_Cg_shader */ + +#ifdef GL_EXT_abgr + +#endif /* GL_EXT_abgr */ + +#ifdef GL_EXT_bgra + +#endif /* GL_EXT_bgra */ + +#ifdef GL_EXT_bindable_uniform + +static GLboolean _glewInit_GL_EXT_bindable_uniform (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetUniformBufferSizeEXT = (PFNGLGETUNIFORMBUFFERSIZEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetUniformBufferSizeEXT")) == NULL) || r; + r = ((glGetUniformOffsetEXT = (PFNGLGETUNIFORMOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glGetUniformOffsetEXT")) == NULL) || r; + r = ((glUniformBufferEXT = (PFNGLUNIFORMBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glUniformBufferEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_bindable_uniform */ + +#ifdef GL_EXT_blend_color + +static GLboolean _glewInit_GL_EXT_blend_color (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendColorEXT = (PFNGLBLENDCOLOREXTPROC)glewGetProcAddress((const GLubyte*)"glBlendColorEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_blend_color */ + +#ifdef GL_EXT_blend_equation_separate + +static GLboolean _glewInit_GL_EXT_blend_equation_separate (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendEquationSeparateEXT = (PFNGLBLENDEQUATIONSEPARATEEXTPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparateEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_blend_equation_separate */ + +#ifdef GL_EXT_blend_func_separate + +static GLboolean _glewInit_GL_EXT_blend_func_separate (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendFuncSeparateEXT = (PFNGLBLENDFUNCSEPARATEEXTPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparateEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_blend_func_separate */ + +#ifdef GL_EXT_blend_logic_op + +#endif /* GL_EXT_blend_logic_op */ + +#ifdef GL_EXT_blend_minmax + +static GLboolean _glewInit_GL_EXT_blend_minmax (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlendEquationEXT = (PFNGLBLENDEQUATIONEXTPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_blend_minmax */ + +#ifdef GL_EXT_blend_subtract + +#endif /* GL_EXT_blend_subtract */ + +#ifdef GL_EXT_clip_volume_hint + +#endif /* GL_EXT_clip_volume_hint */ + +#ifdef GL_EXT_cmyka + +#endif /* GL_EXT_cmyka */ + +#ifdef GL_EXT_color_subtable + +static GLboolean _glewInit_GL_EXT_color_subtable (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColorSubTableEXT = (PFNGLCOLORSUBTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glColorSubTableEXT")) == NULL) || r; + r = ((glCopyColorSubTableEXT = (PFNGLCOPYCOLORSUBTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyColorSubTableEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_color_subtable */ + +#ifdef GL_EXT_compiled_vertex_array + +static GLboolean _glewInit_GL_EXT_compiled_vertex_array (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glLockArraysEXT = (PFNGLLOCKARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glLockArraysEXT")) == NULL) || r; + r = ((glUnlockArraysEXT = (PFNGLUNLOCKARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glUnlockArraysEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_compiled_vertex_array */ + +#ifdef GL_EXT_convolution + +static GLboolean _glewInit_GL_EXT_convolution (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glConvolutionFilter1DEXT = (PFNGLCONVOLUTIONFILTER1DEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter1DEXT")) == NULL) || r; + r = ((glConvolutionFilter2DEXT = (PFNGLCONVOLUTIONFILTER2DEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter2DEXT")) == NULL) || r; + r = ((glConvolutionParameterfEXT = (PFNGLCONVOLUTIONPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterfEXT")) == NULL) || r; + r = ((glConvolutionParameterfvEXT = (PFNGLCONVOLUTIONPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterfvEXT")) == NULL) || r; + r = ((glConvolutionParameteriEXT = (PFNGLCONVOLUTIONPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameteriEXT")) == NULL) || r; + r = ((glConvolutionParameterivEXT = (PFNGLCONVOLUTIONPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterivEXT")) == NULL) || r; + r = ((glCopyConvolutionFilter1DEXT = (PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter1DEXT")) == NULL) || r; + r = ((glCopyConvolutionFilter2DEXT = (PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter2DEXT")) == NULL) || r; + r = ((glGetConvolutionFilterEXT = (PFNGLGETCONVOLUTIONFILTEREXTPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionFilterEXT")) == NULL) || r; + r = ((glGetConvolutionParameterfvEXT = (PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameterfvEXT")) == NULL) || r; + r = ((glGetConvolutionParameterivEXT = (PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameterivEXT")) == NULL) || r; + r = ((glGetSeparableFilterEXT = (PFNGLGETSEPARABLEFILTEREXTPROC)glewGetProcAddress((const GLubyte*)"glGetSeparableFilterEXT")) == NULL) || r; + r = ((glSeparableFilter2DEXT = (PFNGLSEPARABLEFILTER2DEXTPROC)glewGetProcAddress((const GLubyte*)"glSeparableFilter2DEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_convolution */ + +#ifdef GL_EXT_coordinate_frame + +static GLboolean _glewInit_GL_EXT_coordinate_frame (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBinormalPointerEXT = (PFNGLBINORMALPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glBinormalPointerEXT")) == NULL) || r; + r = ((glTangentPointerEXT = (PFNGLTANGENTPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glTangentPointerEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_coordinate_frame */ + +#ifdef GL_EXT_copy_texture + +static GLboolean _glewInit_GL_EXT_copy_texture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCopyTexImage1DEXT = (PFNGLCOPYTEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexImage1DEXT")) == NULL) || r; + r = ((glCopyTexImage2DEXT = (PFNGLCOPYTEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexImage2DEXT")) == NULL) || r; + r = ((glCopyTexSubImage1DEXT = (PFNGLCOPYTEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage1DEXT")) == NULL) || r; + r = ((glCopyTexSubImage2DEXT = (PFNGLCOPYTEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage2DEXT")) == NULL) || r; + r = ((glCopyTexSubImage3DEXT = (PFNGLCOPYTEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage3DEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_copy_texture */ + +#ifdef GL_EXT_cull_vertex + +static GLboolean _glewInit_GL_EXT_cull_vertex (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCullParameterdvEXT = (PFNGLCULLPARAMETERDVEXTPROC)glewGetProcAddress((const GLubyte*)"glCullParameterdvEXT")) == NULL) || r; + r = ((glCullParameterfvEXT = (PFNGLCULLPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glCullParameterfvEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_cull_vertex */ + +#ifdef GL_EXT_depth_bounds_test + +static GLboolean _glewInit_GL_EXT_depth_bounds_test (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDepthBoundsEXT = (PFNGLDEPTHBOUNDSEXTPROC)glewGetProcAddress((const GLubyte*)"glDepthBoundsEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_depth_bounds_test */ + +#ifdef GL_EXT_direct_state_access + +static GLboolean _glewInit_GL_EXT_direct_state_access (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindMultiTextureEXT = (PFNGLBINDMULTITEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glBindMultiTextureEXT")) == NULL) || r; + r = ((glCheckNamedFramebufferStatusEXT = (PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC)glewGetProcAddress((const GLubyte*)"glCheckNamedFramebufferStatusEXT")) == NULL) || r; + r = ((glClientAttribDefaultEXT = (PFNGLCLIENTATTRIBDEFAULTEXTPROC)glewGetProcAddress((const GLubyte*)"glClientAttribDefaultEXT")) == NULL) || r; + r = ((glCompressedMultiTexImage1DEXT = (PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexImage1DEXT")) == NULL) || r; + r = ((glCompressedMultiTexImage2DEXT = (PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexImage2DEXT")) == NULL) || r; + r = ((glCompressedMultiTexImage3DEXT = (PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexImage3DEXT")) == NULL) || r; + r = ((glCompressedMultiTexSubImage1DEXT = (PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexSubImage1DEXT")) == NULL) || r; + r = ((glCompressedMultiTexSubImage2DEXT = (PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexSubImage2DEXT")) == NULL) || r; + r = ((glCompressedMultiTexSubImage3DEXT = (PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexSubImage3DEXT")) == NULL) || r; + r = ((glCompressedTextureImage1DEXT = (PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureImage1DEXT")) == NULL) || r; + r = ((glCompressedTextureImage2DEXT = (PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureImage2DEXT")) == NULL) || r; + r = ((glCompressedTextureImage3DEXT = (PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureImage3DEXT")) == NULL) || r; + r = ((glCompressedTextureSubImage1DEXT = (PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureSubImage1DEXT")) == NULL) || r; + r = ((glCompressedTextureSubImage2DEXT = (PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureSubImage2DEXT")) == NULL) || r; + r = ((glCompressedTextureSubImage3DEXT = (PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureSubImage3DEXT")) == NULL) || r; + r = ((glCopyMultiTexImage1DEXT = (PFNGLCOPYMULTITEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexImage1DEXT")) == NULL) || r; + r = ((glCopyMultiTexImage2DEXT = (PFNGLCOPYMULTITEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexImage2DEXT")) == NULL) || r; + r = ((glCopyMultiTexSubImage1DEXT = (PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexSubImage1DEXT")) == NULL) || r; + r = ((glCopyMultiTexSubImage2DEXT = (PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexSubImage2DEXT")) == NULL) || r; + r = ((glCopyMultiTexSubImage3DEXT = (PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexSubImage3DEXT")) == NULL) || r; + r = ((glCopyTextureImage1DEXT = (PFNGLCOPYTEXTUREIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureImage1DEXT")) == NULL) || r; + r = ((glCopyTextureImage2DEXT = (PFNGLCOPYTEXTUREIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureImage2DEXT")) == NULL) || r; + r = ((glCopyTextureSubImage1DEXT = (PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureSubImage1DEXT")) == NULL) || r; + r = ((glCopyTextureSubImage2DEXT = (PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureSubImage2DEXT")) == NULL) || r; + r = ((glCopyTextureSubImage3DEXT = (PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureSubImage3DEXT")) == NULL) || r; + r = ((glDisableClientStateIndexedEXT = (PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableClientStateIndexedEXT")) == NULL) || r; + r = ((glDisableClientStateiEXT = (PFNGLDISABLECLIENTSTATEIEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableClientStateiEXT")) == NULL) || r; + r = ((glDisableVertexArrayAttribEXT = (PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexArrayAttribEXT")) == NULL) || r; + r = ((glDisableVertexArrayEXT = (PFNGLDISABLEVERTEXARRAYEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexArrayEXT")) == NULL) || r; + r = ((glEnableClientStateIndexedEXT = (PFNGLENABLECLIENTSTATEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableClientStateIndexedEXT")) == NULL) || r; + r = ((glEnableClientStateiEXT = (PFNGLENABLECLIENTSTATEIEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableClientStateiEXT")) == NULL) || r; + r = ((glEnableVertexArrayAttribEXT = (PFNGLENABLEVERTEXARRAYATTRIBEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexArrayAttribEXT")) == NULL) || r; + r = ((glEnableVertexArrayEXT = (PFNGLENABLEVERTEXARRAYEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexArrayEXT")) == NULL) || r; + r = ((glFlushMappedNamedBufferRangeEXT = (PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC)glewGetProcAddress((const GLubyte*)"glFlushMappedNamedBufferRangeEXT")) == NULL) || r; + r = ((glFramebufferDrawBufferEXT = (PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferDrawBufferEXT")) == NULL) || r; + r = ((glFramebufferDrawBuffersEXT = (PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferDrawBuffersEXT")) == NULL) || r; + r = ((glFramebufferReadBufferEXT = (PFNGLFRAMEBUFFERREADBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferReadBufferEXT")) == NULL) || r; + r = ((glGenerateMultiTexMipmapEXT = (PFNGLGENERATEMULTITEXMIPMAPEXTPROC)glewGetProcAddress((const GLubyte*)"glGenerateMultiTexMipmapEXT")) == NULL) || r; + r = ((glGenerateTextureMipmapEXT = (PFNGLGENERATETEXTUREMIPMAPEXTPROC)glewGetProcAddress((const GLubyte*)"glGenerateTextureMipmapEXT")) == NULL) || r; + r = ((glGetCompressedMultiTexImageEXT = (PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedMultiTexImageEXT")) == NULL) || r; + r = ((glGetCompressedTextureImageEXT = (PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedTextureImageEXT")) == NULL) || r; + r = ((glGetDoubleIndexedvEXT = (PFNGLGETDOUBLEINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetDoubleIndexedvEXT")) == NULL) || r; + r = ((glGetDoublei_vEXT = (PFNGLGETDOUBLEI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetDoublei_vEXT")) == NULL) || r; + r = ((glGetFloatIndexedvEXT = (PFNGLGETFLOATINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFloatIndexedvEXT")) == NULL) || r; + r = ((glGetFloati_vEXT = (PFNGLGETFLOATI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFloati_vEXT")) == NULL) || r; + r = ((glGetFramebufferParameterivEXT = (PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFramebufferParameterivEXT")) == NULL) || r; + r = ((glGetMultiTexEnvfvEXT = (PFNGLGETMULTITEXENVFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexEnvfvEXT")) == NULL) || r; + r = ((glGetMultiTexEnvivEXT = (PFNGLGETMULTITEXENVIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexEnvivEXT")) == NULL) || r; + r = ((glGetMultiTexGendvEXT = (PFNGLGETMULTITEXGENDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexGendvEXT")) == NULL) || r; + r = ((glGetMultiTexGenfvEXT = (PFNGLGETMULTITEXGENFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexGenfvEXT")) == NULL) || r; + r = ((glGetMultiTexGenivEXT = (PFNGLGETMULTITEXGENIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexGenivEXT")) == NULL) || r; + r = ((glGetMultiTexImageEXT = (PFNGLGETMULTITEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexImageEXT")) == NULL) || r; + r = ((glGetMultiTexLevelParameterfvEXT = (PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexLevelParameterfvEXT")) == NULL) || r; + r = ((glGetMultiTexLevelParameterivEXT = (PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexLevelParameterivEXT")) == NULL) || r; + r = ((glGetMultiTexParameterIivEXT = (PFNGLGETMULTITEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterIivEXT")) == NULL) || r; + r = ((glGetMultiTexParameterIuivEXT = (PFNGLGETMULTITEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterIuivEXT")) == NULL) || r; + r = ((glGetMultiTexParameterfvEXT = (PFNGLGETMULTITEXPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterfvEXT")) == NULL) || r; + r = ((glGetMultiTexParameterivEXT = (PFNGLGETMULTITEXPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterivEXT")) == NULL) || r; + r = ((glGetNamedBufferParameterivEXT = (PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferParameterivEXT")) == NULL) || r; + r = ((glGetNamedBufferPointervEXT = (PFNGLGETNAMEDBUFFERPOINTERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferPointervEXT")) == NULL) || r; + r = ((glGetNamedBufferSubDataEXT = (PFNGLGETNAMEDBUFFERSUBDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferSubDataEXT")) == NULL) || r; + r = ((glGetNamedFramebufferAttachmentParameterivEXT = (PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedFramebufferAttachmentParameterivEXT")) == NULL) || r; + r = ((glGetNamedProgramLocalParameterIivEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterIivEXT")) == NULL) || r; + r = ((glGetNamedProgramLocalParameterIuivEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterIuivEXT")) == NULL) || r; + r = ((glGetNamedProgramLocalParameterdvEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterdvEXT")) == NULL) || r; + r = ((glGetNamedProgramLocalParameterfvEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterfvEXT")) == NULL) || r; + r = ((glGetNamedProgramStringEXT = (PFNGLGETNAMEDPROGRAMSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramStringEXT")) == NULL) || r; + r = ((glGetNamedProgramivEXT = (PFNGLGETNAMEDPROGRAMIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramivEXT")) == NULL) || r; + r = ((glGetNamedRenderbufferParameterivEXT = (PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedRenderbufferParameterivEXT")) == NULL) || r; + r = ((glGetPointerIndexedvEXT = (PFNGLGETPOINTERINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPointerIndexedvEXT")) == NULL) || r; + r = ((glGetPointeri_vEXT = (PFNGLGETPOINTERI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPointeri_vEXT")) == NULL) || r; + r = ((glGetTextureImageEXT = (PFNGLGETTEXTUREIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureImageEXT")) == NULL) || r; + r = ((glGetTextureLevelParameterfvEXT = (PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureLevelParameterfvEXT")) == NULL) || r; + r = ((glGetTextureLevelParameterivEXT = (PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureLevelParameterivEXT")) == NULL) || r; + r = ((glGetTextureParameterIivEXT = (PFNGLGETTEXTUREPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterIivEXT")) == NULL) || r; + r = ((glGetTextureParameterIuivEXT = (PFNGLGETTEXTUREPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterIuivEXT")) == NULL) || r; + r = ((glGetTextureParameterfvEXT = (PFNGLGETTEXTUREPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterfvEXT")) == NULL) || r; + r = ((glGetTextureParameterivEXT = (PFNGLGETTEXTUREPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterivEXT")) == NULL) || r; + r = ((glGetVertexArrayIntegeri_vEXT = (PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayIntegeri_vEXT")) == NULL) || r; + r = ((glGetVertexArrayIntegervEXT = (PFNGLGETVERTEXARRAYINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayIntegervEXT")) == NULL) || r; + r = ((glGetVertexArrayPointeri_vEXT = (PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayPointeri_vEXT")) == NULL) || r; + r = ((glGetVertexArrayPointervEXT = (PFNGLGETVERTEXARRAYPOINTERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayPointervEXT")) == NULL) || r; + r = ((glMapNamedBufferEXT = (PFNGLMAPNAMEDBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glMapNamedBufferEXT")) == NULL) || r; + r = ((glMapNamedBufferRangeEXT = (PFNGLMAPNAMEDBUFFERRANGEEXTPROC)glewGetProcAddress((const GLubyte*)"glMapNamedBufferRangeEXT")) == NULL) || r; + r = ((glMatrixFrustumEXT = (PFNGLMATRIXFRUSTUMEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixFrustumEXT")) == NULL) || r; + r = ((glMatrixLoadIdentityEXT = (PFNGLMATRIXLOADIDENTITYEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadIdentityEXT")) == NULL) || r; + r = ((glMatrixLoadTransposedEXT = (PFNGLMATRIXLOADTRANSPOSEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadTransposedEXT")) == NULL) || r; + r = ((glMatrixLoadTransposefEXT = (PFNGLMATRIXLOADTRANSPOSEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadTransposefEXT")) == NULL) || r; + r = ((glMatrixLoaddEXT = (PFNGLMATRIXLOADDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoaddEXT")) == NULL) || r; + r = ((glMatrixLoadfEXT = (PFNGLMATRIXLOADFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadfEXT")) == NULL) || r; + r = ((glMatrixMultTransposedEXT = (PFNGLMATRIXMULTTRANSPOSEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultTransposedEXT")) == NULL) || r; + r = ((glMatrixMultTransposefEXT = (PFNGLMATRIXMULTTRANSPOSEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultTransposefEXT")) == NULL) || r; + r = ((glMatrixMultdEXT = (PFNGLMATRIXMULTDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultdEXT")) == NULL) || r; + r = ((glMatrixMultfEXT = (PFNGLMATRIXMULTFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultfEXT")) == NULL) || r; + r = ((glMatrixOrthoEXT = (PFNGLMATRIXORTHOEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixOrthoEXT")) == NULL) || r; + r = ((glMatrixPopEXT = (PFNGLMATRIXPOPEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixPopEXT")) == NULL) || r; + r = ((glMatrixPushEXT = (PFNGLMATRIXPUSHEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixPushEXT")) == NULL) || r; + r = ((glMatrixRotatedEXT = (PFNGLMATRIXROTATEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixRotatedEXT")) == NULL) || r; + r = ((glMatrixRotatefEXT = (PFNGLMATRIXROTATEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixRotatefEXT")) == NULL) || r; + r = ((glMatrixScaledEXT = (PFNGLMATRIXSCALEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixScaledEXT")) == NULL) || r; + r = ((glMatrixScalefEXT = (PFNGLMATRIXSCALEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixScalefEXT")) == NULL) || r; + r = ((glMatrixTranslatedEXT = (PFNGLMATRIXTRANSLATEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixTranslatedEXT")) == NULL) || r; + r = ((glMatrixTranslatefEXT = (PFNGLMATRIXTRANSLATEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixTranslatefEXT")) == NULL) || r; + r = ((glMultiTexBufferEXT = (PFNGLMULTITEXBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexBufferEXT")) == NULL) || r; + r = ((glMultiTexCoordPointerEXT = (PFNGLMULTITEXCOORDPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordPointerEXT")) == NULL) || r; + r = ((glMultiTexEnvfEXT = (PFNGLMULTITEXENVFEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnvfEXT")) == NULL) || r; + r = ((glMultiTexEnvfvEXT = (PFNGLMULTITEXENVFVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnvfvEXT")) == NULL) || r; + r = ((glMultiTexEnviEXT = (PFNGLMULTITEXENVIEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnviEXT")) == NULL) || r; + r = ((glMultiTexEnvivEXT = (PFNGLMULTITEXENVIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnvivEXT")) == NULL) || r; + r = ((glMultiTexGendEXT = (PFNGLMULTITEXGENDEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGendEXT")) == NULL) || r; + r = ((glMultiTexGendvEXT = (PFNGLMULTITEXGENDVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGendvEXT")) == NULL) || r; + r = ((glMultiTexGenfEXT = (PFNGLMULTITEXGENFEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGenfEXT")) == NULL) || r; + r = ((glMultiTexGenfvEXT = (PFNGLMULTITEXGENFVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGenfvEXT")) == NULL) || r; + r = ((glMultiTexGeniEXT = (PFNGLMULTITEXGENIEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGeniEXT")) == NULL) || r; + r = ((glMultiTexGenivEXT = (PFNGLMULTITEXGENIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGenivEXT")) == NULL) || r; + r = ((glMultiTexImage1DEXT = (PFNGLMULTITEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexImage1DEXT")) == NULL) || r; + r = ((glMultiTexImage2DEXT = (PFNGLMULTITEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexImage2DEXT")) == NULL) || r; + r = ((glMultiTexImage3DEXT = (PFNGLMULTITEXIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexImage3DEXT")) == NULL) || r; + r = ((glMultiTexParameterIivEXT = (PFNGLMULTITEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterIivEXT")) == NULL) || r; + r = ((glMultiTexParameterIuivEXT = (PFNGLMULTITEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterIuivEXT")) == NULL) || r; + r = ((glMultiTexParameterfEXT = (PFNGLMULTITEXPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterfEXT")) == NULL) || r; + r = ((glMultiTexParameterfvEXT = (PFNGLMULTITEXPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterfvEXT")) == NULL) || r; + r = ((glMultiTexParameteriEXT = (PFNGLMULTITEXPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameteriEXT")) == NULL) || r; + r = ((glMultiTexParameterivEXT = (PFNGLMULTITEXPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterivEXT")) == NULL) || r; + r = ((glMultiTexRenderbufferEXT = (PFNGLMULTITEXRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexRenderbufferEXT")) == NULL) || r; + r = ((glMultiTexSubImage1DEXT = (PFNGLMULTITEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexSubImage1DEXT")) == NULL) || r; + r = ((glMultiTexSubImage2DEXT = (PFNGLMULTITEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexSubImage2DEXT")) == NULL) || r; + r = ((glMultiTexSubImage3DEXT = (PFNGLMULTITEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexSubImage3DEXT")) == NULL) || r; + r = ((glNamedBufferDataEXT = (PFNGLNAMEDBUFFERDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedBufferDataEXT")) == NULL) || r; + r = ((glNamedBufferSubDataEXT = (PFNGLNAMEDBUFFERSUBDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedBufferSubDataEXT")) == NULL) || r; + r = ((glNamedCopyBufferSubDataEXT = (PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedCopyBufferSubDataEXT")) == NULL) || r; + r = ((glNamedFramebufferRenderbufferEXT = (PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferRenderbufferEXT")) == NULL) || r; + r = ((glNamedFramebufferTexture1DEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTexture1DEXT")) == NULL) || r; + r = ((glNamedFramebufferTexture2DEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTexture2DEXT")) == NULL) || r; + r = ((glNamedFramebufferTexture3DEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTexture3DEXT")) == NULL) || r; + r = ((glNamedFramebufferTextureEXT = (PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTextureEXT")) == NULL) || r; + r = ((glNamedFramebufferTextureFaceEXT = (PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTextureFaceEXT")) == NULL) || r; + r = ((glNamedFramebufferTextureLayerEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTextureLayerEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameter4dEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4dEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameter4dvEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4dvEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameter4fEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4fEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameter4fvEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4fvEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameterI4iEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4iEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameterI4ivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4ivEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameterI4uiEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4uiEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameterI4uivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4uivEXT")) == NULL) || r; + r = ((glNamedProgramLocalParameters4fvEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameters4fvEXT")) == NULL) || r; + r = ((glNamedProgramLocalParametersI4ivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParametersI4ivEXT")) == NULL) || r; + r = ((glNamedProgramLocalParametersI4uivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParametersI4uivEXT")) == NULL) || r; + r = ((glNamedProgramStringEXT = (PFNGLNAMEDPROGRAMSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramStringEXT")) == NULL) || r; + r = ((glNamedRenderbufferStorageEXT = (PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedRenderbufferStorageEXT")) == NULL) || r; + r = ((glNamedRenderbufferStorageMultisampleCoverageEXT = (PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedRenderbufferStorageMultisampleCoverageEXT")) == NULL) || r; + r = ((glNamedRenderbufferStorageMultisampleEXT = (PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedRenderbufferStorageMultisampleEXT")) == NULL) || r; + r = ((glProgramUniform1fEXT = (PFNGLPROGRAMUNIFORM1FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1fEXT")) == NULL) || r; + r = ((glProgramUniform1fvEXT = (PFNGLPROGRAMUNIFORM1FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1fvEXT")) == NULL) || r; + r = ((glProgramUniform1iEXT = (PFNGLPROGRAMUNIFORM1IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1iEXT")) == NULL) || r; + r = ((glProgramUniform1ivEXT = (PFNGLPROGRAMUNIFORM1IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1ivEXT")) == NULL) || r; + r = ((glProgramUniform1uiEXT = (PFNGLPROGRAMUNIFORM1UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1uiEXT")) == NULL) || r; + r = ((glProgramUniform1uivEXT = (PFNGLPROGRAMUNIFORM1UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1uivEXT")) == NULL) || r; + r = ((glProgramUniform2fEXT = (PFNGLPROGRAMUNIFORM2FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2fEXT")) == NULL) || r; + r = ((glProgramUniform2fvEXT = (PFNGLPROGRAMUNIFORM2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2fvEXT")) == NULL) || r; + r = ((glProgramUniform2iEXT = (PFNGLPROGRAMUNIFORM2IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2iEXT")) == NULL) || r; + r = ((glProgramUniform2ivEXT = (PFNGLPROGRAMUNIFORM2IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2ivEXT")) == NULL) || r; + r = ((glProgramUniform2uiEXT = (PFNGLPROGRAMUNIFORM2UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2uiEXT")) == NULL) || r; + r = ((glProgramUniform2uivEXT = (PFNGLPROGRAMUNIFORM2UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2uivEXT")) == NULL) || r; + r = ((glProgramUniform3fEXT = (PFNGLPROGRAMUNIFORM3FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3fEXT")) == NULL) || r; + r = ((glProgramUniform3fvEXT = (PFNGLPROGRAMUNIFORM3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3fvEXT")) == NULL) || r; + r = ((glProgramUniform3iEXT = (PFNGLPROGRAMUNIFORM3IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3iEXT")) == NULL) || r; + r = ((glProgramUniform3ivEXT = (PFNGLPROGRAMUNIFORM3IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3ivEXT")) == NULL) || r; + r = ((glProgramUniform3uiEXT = (PFNGLPROGRAMUNIFORM3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3uiEXT")) == NULL) || r; + r = ((glProgramUniform3uivEXT = (PFNGLPROGRAMUNIFORM3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3uivEXT")) == NULL) || r; + r = ((glProgramUniform4fEXT = (PFNGLPROGRAMUNIFORM4FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4fEXT")) == NULL) || r; + r = ((glProgramUniform4fvEXT = (PFNGLPROGRAMUNIFORM4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4fvEXT")) == NULL) || r; + r = ((glProgramUniform4iEXT = (PFNGLPROGRAMUNIFORM4IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4iEXT")) == NULL) || r; + r = ((glProgramUniform4ivEXT = (PFNGLPROGRAMUNIFORM4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4ivEXT")) == NULL) || r; + r = ((glProgramUniform4uiEXT = (PFNGLPROGRAMUNIFORM4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4uiEXT")) == NULL) || r; + r = ((glProgramUniform4uivEXT = (PFNGLPROGRAMUNIFORM4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4uivEXT")) == NULL) || r; + r = ((glProgramUniformMatrix2fvEXT = (PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix2x3fvEXT = (PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x3fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix2x4fvEXT = (PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x4fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix3fvEXT = (PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix3x2fvEXT = (PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x2fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix3x4fvEXT = (PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x4fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix4fvEXT = (PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix4x2fvEXT = (PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x2fvEXT")) == NULL) || r; + r = ((glProgramUniformMatrix4x3fvEXT = (PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x3fvEXT")) == NULL) || r; + r = ((glPushClientAttribDefaultEXT = (PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC)glewGetProcAddress((const GLubyte*)"glPushClientAttribDefaultEXT")) == NULL) || r; + r = ((glTextureBufferEXT = (PFNGLTEXTUREBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glTextureBufferEXT")) == NULL) || r; + r = ((glTextureImage1DEXT = (PFNGLTEXTUREIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureImage1DEXT")) == NULL) || r; + r = ((glTextureImage2DEXT = (PFNGLTEXTUREIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureImage2DEXT")) == NULL) || r; + r = ((glTextureImage3DEXT = (PFNGLTEXTUREIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureImage3DEXT")) == NULL) || r; + r = ((glTextureParameterIivEXT = (PFNGLTEXTUREPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterIivEXT")) == NULL) || r; + r = ((glTextureParameterIuivEXT = (PFNGLTEXTUREPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterIuivEXT")) == NULL) || r; + r = ((glTextureParameterfEXT = (PFNGLTEXTUREPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterfEXT")) == NULL) || r; + r = ((glTextureParameterfvEXT = (PFNGLTEXTUREPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterfvEXT")) == NULL) || r; + r = ((glTextureParameteriEXT = (PFNGLTEXTUREPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameteriEXT")) == NULL) || r; + r = ((glTextureParameterivEXT = (PFNGLTEXTUREPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterivEXT")) == NULL) || r; + r = ((glTextureRenderbufferEXT = (PFNGLTEXTURERENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glTextureRenderbufferEXT")) == NULL) || r; + r = ((glTextureSubImage1DEXT = (PFNGLTEXTURESUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureSubImage1DEXT")) == NULL) || r; + r = ((glTextureSubImage2DEXT = (PFNGLTEXTURESUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureSubImage2DEXT")) == NULL) || r; + r = ((glTextureSubImage3DEXT = (PFNGLTEXTURESUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureSubImage3DEXT")) == NULL) || r; + r = ((glUnmapNamedBufferEXT = (PFNGLUNMAPNAMEDBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glUnmapNamedBufferEXT")) == NULL) || r; + r = ((glVertexArrayColorOffsetEXT = (PFNGLVERTEXARRAYCOLOROFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayColorOffsetEXT")) == NULL) || r; + r = ((glVertexArrayEdgeFlagOffsetEXT = (PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayEdgeFlagOffsetEXT")) == NULL) || r; + r = ((glVertexArrayFogCoordOffsetEXT = (PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayFogCoordOffsetEXT")) == NULL) || r; + r = ((glVertexArrayIndexOffsetEXT = (PFNGLVERTEXARRAYINDEXOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayIndexOffsetEXT")) == NULL) || r; + r = ((glVertexArrayMultiTexCoordOffsetEXT = (PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayMultiTexCoordOffsetEXT")) == NULL) || r; + r = ((glVertexArrayNormalOffsetEXT = (PFNGLVERTEXARRAYNORMALOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayNormalOffsetEXT")) == NULL) || r; + r = ((glVertexArraySecondaryColorOffsetEXT = (PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArraySecondaryColorOffsetEXT")) == NULL) || r; + r = ((glVertexArrayTexCoordOffsetEXT = (PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayTexCoordOffsetEXT")) == NULL) || r; + r = ((glVertexArrayVertexAttribIOffsetEXT = (PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexAttribIOffsetEXT")) == NULL) || r; + r = ((glVertexArrayVertexAttribOffsetEXT = (PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexAttribOffsetEXT")) == NULL) || r; + r = ((glVertexArrayVertexOffsetEXT = (PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexOffsetEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_direct_state_access */ + +#ifdef GL_EXT_draw_buffers2 + +static GLboolean _glewInit_GL_EXT_draw_buffers2 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColorMaskIndexedEXT = (PFNGLCOLORMASKINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glColorMaskIndexedEXT")) == NULL) || r; + r = ((glDisableIndexedEXT = (PFNGLDISABLEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableIndexedEXT")) == NULL) || r; + r = ((glEnableIndexedEXT = (PFNGLENABLEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableIndexedEXT")) == NULL) || r; + r = ((glGetBooleanIndexedvEXT = (PFNGLGETBOOLEANINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetBooleanIndexedvEXT")) == NULL) || r; + r = ((glGetIntegerIndexedvEXT = (PFNGLGETINTEGERINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetIntegerIndexedvEXT")) == NULL) || r; + r = ((glIsEnabledIndexedEXT = (PFNGLISENABLEDINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glIsEnabledIndexedEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_draw_buffers2 */ + +#ifdef GL_EXT_draw_instanced + +static GLboolean _glewInit_GL_EXT_draw_instanced (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawArraysInstancedEXT = (PFNGLDRAWARRAYSINSTANCEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstancedEXT")) == NULL) || r; + r = ((glDrawElementsInstancedEXT = (PFNGLDRAWELEMENTSINSTANCEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_draw_instanced */ + +#ifdef GL_EXT_draw_range_elements + +static GLboolean _glewInit_GL_EXT_draw_range_elements (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDrawRangeElementsEXT = (PFNGLDRAWRANGEELEMENTSEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementsEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_draw_range_elements */ + +#ifdef GL_EXT_fog_coord + +static GLboolean _glewInit_GL_EXT_fog_coord (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFogCoordPointerEXT = (PFNGLFOGCOORDPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoordPointerEXT")) == NULL) || r; + r = ((glFogCoorddEXT = (PFNGLFOGCOORDDEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoorddEXT")) == NULL) || r; + r = ((glFogCoorddvEXT = (PFNGLFOGCOORDDVEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoorddvEXT")) == NULL) || r; + r = ((glFogCoordfEXT = (PFNGLFOGCOORDFEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoordfEXT")) == NULL) || r; + r = ((glFogCoordfvEXT = (PFNGLFOGCOORDFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoordfvEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_fog_coord */ + +#ifdef GL_EXT_fragment_lighting + +static GLboolean _glewInit_GL_EXT_fragment_lighting (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFragmentColorMaterialEXT = (PFNGLFRAGMENTCOLORMATERIALEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentColorMaterialEXT")) == NULL) || r; + r = ((glFragmentLightModelfEXT = (PFNGLFRAGMENTLIGHTMODELFEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfEXT")) == NULL) || r; + r = ((glFragmentLightModelfvEXT = (PFNGLFRAGMENTLIGHTMODELFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfvEXT")) == NULL) || r; + r = ((glFragmentLightModeliEXT = (PFNGLFRAGMENTLIGHTMODELIEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModeliEXT")) == NULL) || r; + r = ((glFragmentLightModelivEXT = (PFNGLFRAGMENTLIGHTMODELIVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelivEXT")) == NULL) || r; + r = ((glFragmentLightfEXT = (PFNGLFRAGMENTLIGHTFEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfEXT")) == NULL) || r; + r = ((glFragmentLightfvEXT = (PFNGLFRAGMENTLIGHTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfvEXT")) == NULL) || r; + r = ((glFragmentLightiEXT = (PFNGLFRAGMENTLIGHTIEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightiEXT")) == NULL) || r; + r = ((glFragmentLightivEXT = (PFNGLFRAGMENTLIGHTIVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightivEXT")) == NULL) || r; + r = ((glFragmentMaterialfEXT = (PFNGLFRAGMENTMATERIALFEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfEXT")) == NULL) || r; + r = ((glFragmentMaterialfvEXT = (PFNGLFRAGMENTMATERIALFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfvEXT")) == NULL) || r; + r = ((glFragmentMaterialiEXT = (PFNGLFRAGMENTMATERIALIEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialiEXT")) == NULL) || r; + r = ((glFragmentMaterialivEXT = (PFNGLFRAGMENTMATERIALIVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialivEXT")) == NULL) || r; + r = ((glGetFragmentLightfvEXT = (PFNGLGETFRAGMENTLIGHTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightfvEXT")) == NULL) || r; + r = ((glGetFragmentLightivEXT = (PFNGLGETFRAGMENTLIGHTIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightivEXT")) == NULL) || r; + r = ((glGetFragmentMaterialfvEXT = (PFNGLGETFRAGMENTMATERIALFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialfvEXT")) == NULL) || r; + r = ((glGetFragmentMaterialivEXT = (PFNGLGETFRAGMENTMATERIALIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialivEXT")) == NULL) || r; + r = ((glLightEnviEXT = (PFNGLLIGHTENVIEXTPROC)glewGetProcAddress((const GLubyte*)"glLightEnviEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_fragment_lighting */ + +#ifdef GL_EXT_framebuffer_blit + +static GLboolean _glewInit_GL_EXT_framebuffer_blit (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBlitFramebufferEXT = (PFNGLBLITFRAMEBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glBlitFramebufferEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_framebuffer_blit */ + +#ifdef GL_EXT_framebuffer_multisample + +static GLboolean _glewInit_GL_EXT_framebuffer_multisample (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glRenderbufferStorageMultisampleEXT = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageMultisampleEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_framebuffer_multisample */ + +#ifdef GL_EXT_framebuffer_object + +static GLboolean _glewInit_GL_EXT_framebuffer_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindFramebufferEXT = (PFNGLBINDFRAMEBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindFramebufferEXT")) == NULL) || r; + r = ((glBindRenderbufferEXT = (PFNGLBINDRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindRenderbufferEXT")) == NULL) || r; + r = ((glCheckFramebufferStatusEXT = (PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC)glewGetProcAddress((const GLubyte*)"glCheckFramebufferStatusEXT")) == NULL) || r; + r = ((glDeleteFramebuffersEXT = (PFNGLDELETEFRAMEBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteFramebuffersEXT")) == NULL) || r; + r = ((glDeleteRenderbuffersEXT = (PFNGLDELETERENDERBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteRenderbuffersEXT")) == NULL) || r; + r = ((glFramebufferRenderbufferEXT = (PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferRenderbufferEXT")) == NULL) || r; + r = ((glFramebufferTexture1DEXT = (PFNGLFRAMEBUFFERTEXTURE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture1DEXT")) == NULL) || r; + r = ((glFramebufferTexture2DEXT = (PFNGLFRAMEBUFFERTEXTURE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture2DEXT")) == NULL) || r; + r = ((glFramebufferTexture3DEXT = (PFNGLFRAMEBUFFERTEXTURE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture3DEXT")) == NULL) || r; + r = ((glGenFramebuffersEXT = (PFNGLGENFRAMEBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenFramebuffersEXT")) == NULL) || r; + r = ((glGenRenderbuffersEXT = (PFNGLGENRENDERBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenRenderbuffersEXT")) == NULL) || r; + r = ((glGenerateMipmapEXT = (PFNGLGENERATEMIPMAPEXTPROC)glewGetProcAddress((const GLubyte*)"glGenerateMipmapEXT")) == NULL) || r; + r = ((glGetFramebufferAttachmentParameterivEXT = (PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFramebufferAttachmentParameterivEXT")) == NULL) || r; + r = ((glGetRenderbufferParameterivEXT = (PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetRenderbufferParameterivEXT")) == NULL) || r; + r = ((glIsFramebufferEXT = (PFNGLISFRAMEBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glIsFramebufferEXT")) == NULL) || r; + r = ((glIsRenderbufferEXT = (PFNGLISRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glIsRenderbufferEXT")) == NULL) || r; + r = ((glRenderbufferStorageEXT = (PFNGLRENDERBUFFERSTORAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_framebuffer_object */ + +#ifdef GL_EXT_framebuffer_sRGB + +#endif /* GL_EXT_framebuffer_sRGB */ + +#ifdef GL_EXT_geometry_shader4 + +static GLboolean _glewInit_GL_EXT_geometry_shader4 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFramebufferTextureEXT = (PFNGLFRAMEBUFFERTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureEXT")) == NULL) || r; + r = ((glFramebufferTextureFaceEXT = (PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureFaceEXT")) == NULL) || r; + r = ((glFramebufferTextureLayerEXT = (PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureLayerEXT")) == NULL) || r; + r = ((glProgramParameteriEXT = (PFNGLPROGRAMPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramParameteriEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_geometry_shader4 */ + +#ifdef GL_EXT_gpu_program_parameters + +static GLboolean _glewInit_GL_EXT_gpu_program_parameters (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glProgramEnvParameters4fvEXT = (PFNGLPROGRAMENVPARAMETERS4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameters4fvEXT")) == NULL) || r; + r = ((glProgramLocalParameters4fvEXT = (PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameters4fvEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_gpu_program_parameters */ + +#ifdef GL_EXT_gpu_shader4 + +static GLboolean _glewInit_GL_EXT_gpu_shader4 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindFragDataLocationEXT = (PFNGLBINDFRAGDATALOCATIONEXTPROC)glewGetProcAddress((const GLubyte*)"glBindFragDataLocationEXT")) == NULL) || r; + r = ((glGetFragDataLocationEXT = (PFNGLGETFRAGDATALOCATIONEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragDataLocationEXT")) == NULL) || r; + r = ((glGetUniformuivEXT = (PFNGLGETUNIFORMUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetUniformuivEXT")) == NULL) || r; + r = ((glGetVertexAttribIivEXT = (PFNGLGETVERTEXATTRIBIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIivEXT")) == NULL) || r; + r = ((glGetVertexAttribIuivEXT = (PFNGLGETVERTEXATTRIBIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIuivEXT")) == NULL) || r; + r = ((glUniform1uiEXT = (PFNGLUNIFORM1UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform1uiEXT")) == NULL) || r; + r = ((glUniform1uivEXT = (PFNGLUNIFORM1UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform1uivEXT")) == NULL) || r; + r = ((glUniform2uiEXT = (PFNGLUNIFORM2UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform2uiEXT")) == NULL) || r; + r = ((glUniform2uivEXT = (PFNGLUNIFORM2UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform2uivEXT")) == NULL) || r; + r = ((glUniform3uiEXT = (PFNGLUNIFORM3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform3uiEXT")) == NULL) || r; + r = ((glUniform3uivEXT = (PFNGLUNIFORM3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform3uivEXT")) == NULL) || r; + r = ((glUniform4uiEXT = (PFNGLUNIFORM4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform4uiEXT")) == NULL) || r; + r = ((glUniform4uivEXT = (PFNGLUNIFORM4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform4uivEXT")) == NULL) || r; + r = ((glVertexAttribI1iEXT = (PFNGLVERTEXATTRIBI1IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1iEXT")) == NULL) || r; + r = ((glVertexAttribI1ivEXT = (PFNGLVERTEXATTRIBI1IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1ivEXT")) == NULL) || r; + r = ((glVertexAttribI1uiEXT = (PFNGLVERTEXATTRIBI1UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1uiEXT")) == NULL) || r; + r = ((glVertexAttribI1uivEXT = (PFNGLVERTEXATTRIBI1UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1uivEXT")) == NULL) || r; + r = ((glVertexAttribI2iEXT = (PFNGLVERTEXATTRIBI2IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2iEXT")) == NULL) || r; + r = ((glVertexAttribI2ivEXT = (PFNGLVERTEXATTRIBI2IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2ivEXT")) == NULL) || r; + r = ((glVertexAttribI2uiEXT = (PFNGLVERTEXATTRIBI2UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2uiEXT")) == NULL) || r; + r = ((glVertexAttribI2uivEXT = (PFNGLVERTEXATTRIBI2UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2uivEXT")) == NULL) || r; + r = ((glVertexAttribI3iEXT = (PFNGLVERTEXATTRIBI3IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3iEXT")) == NULL) || r; + r = ((glVertexAttribI3ivEXT = (PFNGLVERTEXATTRIBI3IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3ivEXT")) == NULL) || r; + r = ((glVertexAttribI3uiEXT = (PFNGLVERTEXATTRIBI3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3uiEXT")) == NULL) || r; + r = ((glVertexAttribI3uivEXT = (PFNGLVERTEXATTRIBI3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3uivEXT")) == NULL) || r; + r = ((glVertexAttribI4bvEXT = (PFNGLVERTEXATTRIBI4BVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4bvEXT")) == NULL) || r; + r = ((glVertexAttribI4iEXT = (PFNGLVERTEXATTRIBI4IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4iEXT")) == NULL) || r; + r = ((glVertexAttribI4ivEXT = (PFNGLVERTEXATTRIBI4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ivEXT")) == NULL) || r; + r = ((glVertexAttribI4svEXT = (PFNGLVERTEXATTRIBI4SVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4svEXT")) == NULL) || r; + r = ((glVertexAttribI4ubvEXT = (PFNGLVERTEXATTRIBI4UBVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ubvEXT")) == NULL) || r; + r = ((glVertexAttribI4uiEXT = (PFNGLVERTEXATTRIBI4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4uiEXT")) == NULL) || r; + r = ((glVertexAttribI4uivEXT = (PFNGLVERTEXATTRIBI4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4uivEXT")) == NULL) || r; + r = ((glVertexAttribI4usvEXT = (PFNGLVERTEXATTRIBI4USVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4usvEXT")) == NULL) || r; + r = ((glVertexAttribIPointerEXT = (PFNGLVERTEXATTRIBIPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribIPointerEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_gpu_shader4 */ + +#ifdef GL_EXT_histogram + +static GLboolean _glewInit_GL_EXT_histogram (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetHistogramEXT = (PFNGLGETHISTOGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramEXT")) == NULL) || r; + r = ((glGetHistogramParameterfvEXT = (PFNGLGETHISTOGRAMPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameterfvEXT")) == NULL) || r; + r = ((glGetHistogramParameterivEXT = (PFNGLGETHISTOGRAMPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameterivEXT")) == NULL) || r; + r = ((glGetMinmaxEXT = (PFNGLGETMINMAXEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxEXT")) == NULL) || r; + r = ((glGetMinmaxParameterfvEXT = (PFNGLGETMINMAXPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameterfvEXT")) == NULL) || r; + r = ((glGetMinmaxParameterivEXT = (PFNGLGETMINMAXPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameterivEXT")) == NULL) || r; + r = ((glHistogramEXT = (PFNGLHISTOGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glHistogramEXT")) == NULL) || r; + r = ((glMinmaxEXT = (PFNGLMINMAXEXTPROC)glewGetProcAddress((const GLubyte*)"glMinmaxEXT")) == NULL) || r; + r = ((glResetHistogramEXT = (PFNGLRESETHISTOGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glResetHistogramEXT")) == NULL) || r; + r = ((glResetMinmaxEXT = (PFNGLRESETMINMAXEXTPROC)glewGetProcAddress((const GLubyte*)"glResetMinmaxEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_histogram */ + +#ifdef GL_EXT_index_array_formats + +#endif /* GL_EXT_index_array_formats */ + +#ifdef GL_EXT_index_func + +static GLboolean _glewInit_GL_EXT_index_func (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glIndexFuncEXT = (PFNGLINDEXFUNCEXTPROC)glewGetProcAddress((const GLubyte*)"glIndexFuncEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_index_func */ + +#ifdef GL_EXT_index_material + +static GLboolean _glewInit_GL_EXT_index_material (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glIndexMaterialEXT = (PFNGLINDEXMATERIALEXTPROC)glewGetProcAddress((const GLubyte*)"glIndexMaterialEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_index_material */ + +#ifdef GL_EXT_index_texture + +#endif /* GL_EXT_index_texture */ + +#ifdef GL_EXT_light_texture + +static GLboolean _glewInit_GL_EXT_light_texture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glApplyTextureEXT = (PFNGLAPPLYTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glApplyTextureEXT")) == NULL) || r; + r = ((glTextureLightEXT = (PFNGLTEXTURELIGHTEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureLightEXT")) == NULL) || r; + r = ((glTextureMaterialEXT = (PFNGLTEXTUREMATERIALEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureMaterialEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_light_texture */ + +#ifdef GL_EXT_misc_attribute + +#endif /* GL_EXT_misc_attribute */ + +#ifdef GL_EXT_multi_draw_arrays + +static GLboolean _glewInit_GL_EXT_multi_draw_arrays (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glMultiDrawArraysEXT = (PFNGLMULTIDRAWARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArraysEXT")) == NULL) || r; + r = ((glMultiDrawElementsEXT = (PFNGLMULTIDRAWELEMENTSEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_multi_draw_arrays */ + +#ifdef GL_EXT_multisample + +static GLboolean _glewInit_GL_EXT_multisample (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glSampleMaskEXT = (PFNGLSAMPLEMASKEXTPROC)glewGetProcAddress((const GLubyte*)"glSampleMaskEXT")) == NULL) || r; + r = ((glSamplePatternEXT = (PFNGLSAMPLEPATTERNEXTPROC)glewGetProcAddress((const GLubyte*)"glSamplePatternEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_multisample */ + +#ifdef GL_EXT_packed_depth_stencil + +#endif /* GL_EXT_packed_depth_stencil */ + +#ifdef GL_EXT_packed_float + +#endif /* GL_EXT_packed_float */ + +#ifdef GL_EXT_packed_pixels + +#endif /* GL_EXT_packed_pixels */ + +#ifdef GL_EXT_paletted_texture + +static GLboolean _glewInit_GL_EXT_paletted_texture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColorTableEXT = (PFNGLCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glColorTableEXT")) == NULL) || r; + r = ((glGetColorTableEXT = (PFNGLGETCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableEXT")) == NULL) || r; + r = ((glGetColorTableParameterfvEXT = (PFNGLGETCOLORTABLEPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterfvEXT")) == NULL) || r; + r = ((glGetColorTableParameterivEXT = (PFNGLGETCOLORTABLEPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterivEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_paletted_texture */ + +#ifdef GL_EXT_pixel_buffer_object + +#endif /* GL_EXT_pixel_buffer_object */ + +#ifdef GL_EXT_pixel_transform + +static GLboolean _glewInit_GL_EXT_pixel_transform (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetPixelTransformParameterfvEXT = (PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPixelTransformParameterfvEXT")) == NULL) || r; + r = ((glGetPixelTransformParameterivEXT = (PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPixelTransformParameterivEXT")) == NULL) || r; + r = ((glPixelTransformParameterfEXT = (PFNGLPIXELTRANSFORMPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameterfEXT")) == NULL) || r; + r = ((glPixelTransformParameterfvEXT = (PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameterfvEXT")) == NULL) || r; + r = ((glPixelTransformParameteriEXT = (PFNGLPIXELTRANSFORMPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameteriEXT")) == NULL) || r; + r = ((glPixelTransformParameterivEXT = (PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameterivEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_pixel_transform */ + +#ifdef GL_EXT_pixel_transform_color_table + +#endif /* GL_EXT_pixel_transform_color_table */ + +#ifdef GL_EXT_point_parameters + +static GLboolean _glewInit_GL_EXT_point_parameters (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPointParameterfEXT = (PFNGLPOINTPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfEXT")) == NULL) || r; + r = ((glPointParameterfvEXT = (PFNGLPOINTPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfvEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_point_parameters */ + +#ifdef GL_EXT_polygon_offset + +static GLboolean _glewInit_GL_EXT_polygon_offset (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPolygonOffsetEXT = (PFNGLPOLYGONOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glPolygonOffsetEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_polygon_offset */ + +#ifdef GL_EXT_provoking_vertex + +static GLboolean _glewInit_GL_EXT_provoking_vertex (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glProvokingVertexEXT = (PFNGLPROVOKINGVERTEXEXTPROC)glewGetProcAddress((const GLubyte*)"glProvokingVertexEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_provoking_vertex */ + +#ifdef GL_EXT_rescale_normal + +#endif /* GL_EXT_rescale_normal */ + +#ifdef GL_EXT_scene_marker + +static GLboolean _glewInit_GL_EXT_scene_marker (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginSceneEXT = (PFNGLBEGINSCENEEXTPROC)glewGetProcAddress((const GLubyte*)"glBeginSceneEXT")) == NULL) || r; + r = ((glEndSceneEXT = (PFNGLENDSCENEEXTPROC)glewGetProcAddress((const GLubyte*)"glEndSceneEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_scene_marker */ + +#ifdef GL_EXT_secondary_color + +static GLboolean _glewInit_GL_EXT_secondary_color (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glSecondaryColor3bEXT = (PFNGLSECONDARYCOLOR3BEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3bEXT")) == NULL) || r; + r = ((glSecondaryColor3bvEXT = (PFNGLSECONDARYCOLOR3BVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3bvEXT")) == NULL) || r; + r = ((glSecondaryColor3dEXT = (PFNGLSECONDARYCOLOR3DEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3dEXT")) == NULL) || r; + r = ((glSecondaryColor3dvEXT = (PFNGLSECONDARYCOLOR3DVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3dvEXT")) == NULL) || r; + r = ((glSecondaryColor3fEXT = (PFNGLSECONDARYCOLOR3FEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3fEXT")) == NULL) || r; + r = ((glSecondaryColor3fvEXT = (PFNGLSECONDARYCOLOR3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3fvEXT")) == NULL) || r; + r = ((glSecondaryColor3iEXT = (PFNGLSECONDARYCOLOR3IEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3iEXT")) == NULL) || r; + r = ((glSecondaryColor3ivEXT = (PFNGLSECONDARYCOLOR3IVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ivEXT")) == NULL) || r; + r = ((glSecondaryColor3sEXT = (PFNGLSECONDARYCOLOR3SEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3sEXT")) == NULL) || r; + r = ((glSecondaryColor3svEXT = (PFNGLSECONDARYCOLOR3SVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3svEXT")) == NULL) || r; + r = ((glSecondaryColor3ubEXT = (PFNGLSECONDARYCOLOR3UBEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ubEXT")) == NULL) || r; + r = ((glSecondaryColor3ubvEXT = (PFNGLSECONDARYCOLOR3UBVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ubvEXT")) == NULL) || r; + r = ((glSecondaryColor3uiEXT = (PFNGLSECONDARYCOLOR3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3uiEXT")) == NULL) || r; + r = ((glSecondaryColor3uivEXT = (PFNGLSECONDARYCOLOR3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3uivEXT")) == NULL) || r; + r = ((glSecondaryColor3usEXT = (PFNGLSECONDARYCOLOR3USEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3usEXT")) == NULL) || r; + r = ((glSecondaryColor3usvEXT = (PFNGLSECONDARYCOLOR3USVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3usvEXT")) == NULL) || r; + r = ((glSecondaryColorPointerEXT = (PFNGLSECONDARYCOLORPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorPointerEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_secondary_color */ + +#ifdef GL_EXT_separate_shader_objects + +static GLboolean _glewInit_GL_EXT_separate_shader_objects (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glActiveProgramEXT = (PFNGLACTIVEPROGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glActiveProgramEXT")) == NULL) || r; + r = ((glCreateShaderProgramEXT = (PFNGLCREATESHADERPROGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glCreateShaderProgramEXT")) == NULL) || r; + r = ((glUseShaderProgramEXT = (PFNGLUSESHADERPROGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glUseShaderProgramEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_separate_shader_objects */ + +#ifdef GL_EXT_separate_specular_color + +#endif /* GL_EXT_separate_specular_color */ + +#ifdef GL_EXT_shader_image_load_store + +static GLboolean _glewInit_GL_EXT_shader_image_load_store (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindImageTextureEXT = (PFNGLBINDIMAGETEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glBindImageTextureEXT")) == NULL) || r; + r = ((glMemoryBarrierEXT = (PFNGLMEMORYBARRIEREXTPROC)glewGetProcAddress((const GLubyte*)"glMemoryBarrierEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_shader_image_load_store */ + +#ifdef GL_EXT_shadow_funcs + +#endif /* GL_EXT_shadow_funcs */ + +#ifdef GL_EXT_shared_texture_palette + +#endif /* GL_EXT_shared_texture_palette */ + +#ifdef GL_EXT_stencil_clear_tag + +#endif /* GL_EXT_stencil_clear_tag */ + +#ifdef GL_EXT_stencil_two_side + +static GLboolean _glewInit_GL_EXT_stencil_two_side (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glActiveStencilFaceEXT = (PFNGLACTIVESTENCILFACEEXTPROC)glewGetProcAddress((const GLubyte*)"glActiveStencilFaceEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_stencil_two_side */ + +#ifdef GL_EXT_stencil_wrap + +#endif /* GL_EXT_stencil_wrap */ + +#ifdef GL_EXT_subtexture + +static GLboolean _glewInit_GL_EXT_subtexture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTexSubImage1DEXT = (PFNGLTEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage1DEXT")) == NULL) || r; + r = ((glTexSubImage2DEXT = (PFNGLTEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage2DEXT")) == NULL) || r; + r = ((glTexSubImage3DEXT = (PFNGLTEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage3DEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_subtexture */ + +#ifdef GL_EXT_texture + +#endif /* GL_EXT_texture */ + +#ifdef GL_EXT_texture3D + +static GLboolean _glewInit_GL_EXT_texture3D (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTexImage3DEXT = (PFNGLTEXIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexImage3DEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_texture3D */ + +#ifdef GL_EXT_texture_array + +#endif /* GL_EXT_texture_array */ + +#ifdef GL_EXT_texture_buffer_object + +static GLboolean _glewInit_GL_EXT_texture_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTexBufferEXT = (PFNGLTEXBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glTexBufferEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_texture_buffer_object */ + +#ifdef GL_EXT_texture_compression_dxt1 + +#endif /* GL_EXT_texture_compression_dxt1 */ + +#ifdef GL_EXT_texture_compression_latc + +#endif /* GL_EXT_texture_compression_latc */ + +#ifdef GL_EXT_texture_compression_rgtc + +#endif /* GL_EXT_texture_compression_rgtc */ + +#ifdef GL_EXT_texture_compression_s3tc + +#endif /* GL_EXT_texture_compression_s3tc */ + +#ifdef GL_EXT_texture_cube_map + +#endif /* GL_EXT_texture_cube_map */ + +#ifdef GL_EXT_texture_edge_clamp + +#endif /* GL_EXT_texture_edge_clamp */ + +#ifdef GL_EXT_texture_env + +#endif /* GL_EXT_texture_env */ + +#ifdef GL_EXT_texture_env_add + +#endif /* GL_EXT_texture_env_add */ + +#ifdef GL_EXT_texture_env_combine + +#endif /* GL_EXT_texture_env_combine */ + +#ifdef GL_EXT_texture_env_dot3 + +#endif /* GL_EXT_texture_env_dot3 */ + +#ifdef GL_EXT_texture_filter_anisotropic + +#endif /* GL_EXT_texture_filter_anisotropic */ + +#ifdef GL_EXT_texture_integer + +static GLboolean _glewInit_GL_EXT_texture_integer (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glClearColorIiEXT = (PFNGLCLEARCOLORIIEXTPROC)glewGetProcAddress((const GLubyte*)"glClearColorIiEXT")) == NULL) || r; + r = ((glClearColorIuiEXT = (PFNGLCLEARCOLORIUIEXTPROC)glewGetProcAddress((const GLubyte*)"glClearColorIuiEXT")) == NULL) || r; + r = ((glGetTexParameterIivEXT = (PFNGLGETTEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIivEXT")) == NULL) || r; + r = ((glGetTexParameterIuivEXT = (PFNGLGETTEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIuivEXT")) == NULL) || r; + r = ((glTexParameterIivEXT = (PFNGLTEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIivEXT")) == NULL) || r; + r = ((glTexParameterIuivEXT = (PFNGLTEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIuivEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_texture_integer */ + +#ifdef GL_EXT_texture_lod_bias + +#endif /* GL_EXT_texture_lod_bias */ + +#ifdef GL_EXT_texture_mirror_clamp + +#endif /* GL_EXT_texture_mirror_clamp */ + +#ifdef GL_EXT_texture_object + +static GLboolean _glewInit_GL_EXT_texture_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glAreTexturesResidentEXT = (PFNGLARETEXTURESRESIDENTEXTPROC)glewGetProcAddress((const GLubyte*)"glAreTexturesResidentEXT")) == NULL) || r; + r = ((glBindTextureEXT = (PFNGLBINDTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glBindTextureEXT")) == NULL) || r; + r = ((glDeleteTexturesEXT = (PFNGLDELETETEXTURESEXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteTexturesEXT")) == NULL) || r; + r = ((glGenTexturesEXT = (PFNGLGENTEXTURESEXTPROC)glewGetProcAddress((const GLubyte*)"glGenTexturesEXT")) == NULL) || r; + r = ((glIsTextureEXT = (PFNGLISTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glIsTextureEXT")) == NULL) || r; + r = ((glPrioritizeTexturesEXT = (PFNGLPRIORITIZETEXTURESEXTPROC)glewGetProcAddress((const GLubyte*)"glPrioritizeTexturesEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_texture_object */ + +#ifdef GL_EXT_texture_perturb_normal + +static GLboolean _glewInit_GL_EXT_texture_perturb_normal (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTextureNormalEXT = (PFNGLTEXTURENORMALEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureNormalEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_texture_perturb_normal */ + +#ifdef GL_EXT_texture_rectangle + +#endif /* GL_EXT_texture_rectangle */ + +#ifdef GL_EXT_texture_sRGB + +#endif /* GL_EXT_texture_sRGB */ + +#ifdef GL_EXT_texture_shared_exponent + +#endif /* GL_EXT_texture_shared_exponent */ + +#ifdef GL_EXT_texture_snorm + +#endif /* GL_EXT_texture_snorm */ + +#ifdef GL_EXT_texture_swizzle + +#endif /* GL_EXT_texture_swizzle */ + +#ifdef GL_EXT_timer_query + +static GLboolean _glewInit_GL_EXT_timer_query (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetQueryObjecti64vEXT = (PFNGLGETQUERYOBJECTI64VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjecti64vEXT")) == NULL) || r; + r = ((glGetQueryObjectui64vEXT = (PFNGLGETQUERYOBJECTUI64VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectui64vEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_timer_query */ + +#ifdef GL_EXT_transform_feedback + +static GLboolean _glewInit_GL_EXT_transform_feedback (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginTransformFeedbackEXT = (PFNGLBEGINTRANSFORMFEEDBACKEXTPROC)glewGetProcAddress((const GLubyte*)"glBeginTransformFeedbackEXT")) == NULL) || r; + r = ((glBindBufferBaseEXT = (PFNGLBINDBUFFERBASEEXTPROC)glewGetProcAddress((const GLubyte*)"glBindBufferBaseEXT")) == NULL) || r; + r = ((glBindBufferOffsetEXT = (PFNGLBINDBUFFEROFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glBindBufferOffsetEXT")) == NULL) || r; + r = ((glBindBufferRangeEXT = (PFNGLBINDBUFFERRANGEEXTPROC)glewGetProcAddress((const GLubyte*)"glBindBufferRangeEXT")) == NULL) || r; + r = ((glEndTransformFeedbackEXT = (PFNGLENDTRANSFORMFEEDBACKEXTPROC)glewGetProcAddress((const GLubyte*)"glEndTransformFeedbackEXT")) == NULL) || r; + r = ((glGetTransformFeedbackVaryingEXT = (PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTransformFeedbackVaryingEXT")) == NULL) || r; + r = ((glTransformFeedbackVaryingsEXT = (PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackVaryingsEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_transform_feedback */ + +#ifdef GL_EXT_vertex_array + +static GLboolean _glewInit_GL_EXT_vertex_array (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glArrayElementEXT = (PFNGLARRAYELEMENTEXTPROC)glewGetProcAddress((const GLubyte*)"glArrayElementEXT")) == NULL) || r; + r = ((glColorPointerEXT = (PFNGLCOLORPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glColorPointerEXT")) == NULL) || r; + r = ((glDrawArraysEXT = (PFNGLDRAWARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysEXT")) == NULL) || r; + r = ((glEdgeFlagPointerEXT = (PFNGLEDGEFLAGPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glEdgeFlagPointerEXT")) == NULL) || r; + r = ((glGetPointervEXT = (PFNGLGETPOINTERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPointervEXT")) == NULL) || r; + r = ((glIndexPointerEXT = (PFNGLINDEXPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glIndexPointerEXT")) == NULL) || r; + r = ((glNormalPointerEXT = (PFNGLNORMALPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glNormalPointerEXT")) == NULL) || r; + r = ((glTexCoordPointerEXT = (PFNGLTEXCOORDPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glTexCoordPointerEXT")) == NULL) || r; + r = ((glVertexPointerEXT = (PFNGLVERTEXPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexPointerEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_vertex_array */ + +#ifdef GL_EXT_vertex_array_bgra + +#endif /* GL_EXT_vertex_array_bgra */ + +#ifdef GL_EXT_vertex_attrib_64bit + +static GLboolean _glewInit_GL_EXT_vertex_attrib_64bit (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetVertexAttribLdvEXT = (PFNGLGETVERTEXATTRIBLDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLdvEXT")) == NULL) || r; + r = ((glVertexArrayVertexAttribLOffsetEXT = (PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexAttribLOffsetEXT")) == NULL) || r; + r = ((glVertexAttribL1dEXT = (PFNGLVERTEXATTRIBL1DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1dEXT")) == NULL) || r; + r = ((glVertexAttribL1dvEXT = (PFNGLVERTEXATTRIBL1DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1dvEXT")) == NULL) || r; + r = ((glVertexAttribL2dEXT = (PFNGLVERTEXATTRIBL2DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2dEXT")) == NULL) || r; + r = ((glVertexAttribL2dvEXT = (PFNGLVERTEXATTRIBL2DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2dvEXT")) == NULL) || r; + r = ((glVertexAttribL3dEXT = (PFNGLVERTEXATTRIBL3DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3dEXT")) == NULL) || r; + r = ((glVertexAttribL3dvEXT = (PFNGLVERTEXATTRIBL3DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3dvEXT")) == NULL) || r; + r = ((glVertexAttribL4dEXT = (PFNGLVERTEXATTRIBL4DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4dEXT")) == NULL) || r; + r = ((glVertexAttribL4dvEXT = (PFNGLVERTEXATTRIBL4DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4dvEXT")) == NULL) || r; + r = ((glVertexAttribLPointerEXT = (PFNGLVERTEXATTRIBLPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribLPointerEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_vertex_attrib_64bit */ + +#ifdef GL_EXT_vertex_shader + +static GLboolean _glewInit_GL_EXT_vertex_shader (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginVertexShaderEXT = (PFNGLBEGINVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glBeginVertexShaderEXT")) == NULL) || r; + r = ((glBindLightParameterEXT = (PFNGLBINDLIGHTPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindLightParameterEXT")) == NULL) || r; + r = ((glBindMaterialParameterEXT = (PFNGLBINDMATERIALPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindMaterialParameterEXT")) == NULL) || r; + r = ((glBindParameterEXT = (PFNGLBINDPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindParameterEXT")) == NULL) || r; + r = ((glBindTexGenParameterEXT = (PFNGLBINDTEXGENPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindTexGenParameterEXT")) == NULL) || r; + r = ((glBindTextureUnitParameterEXT = (PFNGLBINDTEXTUREUNITPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindTextureUnitParameterEXT")) == NULL) || r; + r = ((glBindVertexShaderEXT = (PFNGLBINDVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindVertexShaderEXT")) == NULL) || r; + r = ((glDeleteVertexShaderEXT = (PFNGLDELETEVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteVertexShaderEXT")) == NULL) || r; + r = ((glDisableVariantClientStateEXT = (PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableVariantClientStateEXT")) == NULL) || r; + r = ((glEnableVariantClientStateEXT = (PFNGLENABLEVARIANTCLIENTSTATEEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableVariantClientStateEXT")) == NULL) || r; + r = ((glEndVertexShaderEXT = (PFNGLENDVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glEndVertexShaderEXT")) == NULL) || r; + r = ((glExtractComponentEXT = (PFNGLEXTRACTCOMPONENTEXTPROC)glewGetProcAddress((const GLubyte*)"glExtractComponentEXT")) == NULL) || r; + r = ((glGenSymbolsEXT = (PFNGLGENSYMBOLSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenSymbolsEXT")) == NULL) || r; + r = ((glGenVertexShadersEXT = (PFNGLGENVERTEXSHADERSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenVertexShadersEXT")) == NULL) || r; + r = ((glGetInvariantBooleanvEXT = (PFNGLGETINVARIANTBOOLEANVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetInvariantBooleanvEXT")) == NULL) || r; + r = ((glGetInvariantFloatvEXT = (PFNGLGETINVARIANTFLOATVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetInvariantFloatvEXT")) == NULL) || r; + r = ((glGetInvariantIntegervEXT = (PFNGLGETINVARIANTINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetInvariantIntegervEXT")) == NULL) || r; + r = ((glGetLocalConstantBooleanvEXT = (PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetLocalConstantBooleanvEXT")) == NULL) || r; + r = ((glGetLocalConstantFloatvEXT = (PFNGLGETLOCALCONSTANTFLOATVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetLocalConstantFloatvEXT")) == NULL) || r; + r = ((glGetLocalConstantIntegervEXT = (PFNGLGETLOCALCONSTANTINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetLocalConstantIntegervEXT")) == NULL) || r; + r = ((glGetVariantBooleanvEXT = (PFNGLGETVARIANTBOOLEANVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantBooleanvEXT")) == NULL) || r; + r = ((glGetVariantFloatvEXT = (PFNGLGETVARIANTFLOATVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantFloatvEXT")) == NULL) || r; + r = ((glGetVariantIntegervEXT = (PFNGLGETVARIANTINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantIntegervEXT")) == NULL) || r; + r = ((glGetVariantPointervEXT = (PFNGLGETVARIANTPOINTERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantPointervEXT")) == NULL) || r; + r = ((glInsertComponentEXT = (PFNGLINSERTCOMPONENTEXTPROC)glewGetProcAddress((const GLubyte*)"glInsertComponentEXT")) == NULL) || r; + r = ((glIsVariantEnabledEXT = (PFNGLISVARIANTENABLEDEXTPROC)glewGetProcAddress((const GLubyte*)"glIsVariantEnabledEXT")) == NULL) || r; + r = ((glSetInvariantEXT = (PFNGLSETINVARIANTEXTPROC)glewGetProcAddress((const GLubyte*)"glSetInvariantEXT")) == NULL) || r; + r = ((glSetLocalConstantEXT = (PFNGLSETLOCALCONSTANTEXTPROC)glewGetProcAddress((const GLubyte*)"glSetLocalConstantEXT")) == NULL) || r; + r = ((glShaderOp1EXT = (PFNGLSHADEROP1EXTPROC)glewGetProcAddress((const GLubyte*)"glShaderOp1EXT")) == NULL) || r; + r = ((glShaderOp2EXT = (PFNGLSHADEROP2EXTPROC)glewGetProcAddress((const GLubyte*)"glShaderOp2EXT")) == NULL) || r; + r = ((glShaderOp3EXT = (PFNGLSHADEROP3EXTPROC)glewGetProcAddress((const GLubyte*)"glShaderOp3EXT")) == NULL) || r; + r = ((glSwizzleEXT = (PFNGLSWIZZLEEXTPROC)glewGetProcAddress((const GLubyte*)"glSwizzleEXT")) == NULL) || r; + r = ((glVariantPointerEXT = (PFNGLVARIANTPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVariantPointerEXT")) == NULL) || r; + r = ((glVariantbvEXT = (PFNGLVARIANTBVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantbvEXT")) == NULL) || r; + r = ((glVariantdvEXT = (PFNGLVARIANTDVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantdvEXT")) == NULL) || r; + r = ((glVariantfvEXT = (PFNGLVARIANTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantfvEXT")) == NULL) || r; + r = ((glVariantivEXT = (PFNGLVARIANTIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantivEXT")) == NULL) || r; + r = ((glVariantsvEXT = (PFNGLVARIANTSVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantsvEXT")) == NULL) || r; + r = ((glVariantubvEXT = (PFNGLVARIANTUBVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantubvEXT")) == NULL) || r; + r = ((glVariantuivEXT = (PFNGLVARIANTUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantuivEXT")) == NULL) || r; + r = ((glVariantusvEXT = (PFNGLVARIANTUSVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantusvEXT")) == NULL) || r; + r = ((glWriteMaskEXT = (PFNGLWRITEMASKEXTPROC)glewGetProcAddress((const GLubyte*)"glWriteMaskEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_vertex_shader */ + +#ifdef GL_EXT_vertex_weighting + +static GLboolean _glewInit_GL_EXT_vertex_weighting (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glVertexWeightPointerEXT = (PFNGLVERTEXWEIGHTPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexWeightPointerEXT")) == NULL) || r; + r = ((glVertexWeightfEXT = (PFNGLVERTEXWEIGHTFEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexWeightfEXT")) == NULL) || r; + r = ((glVertexWeightfvEXT = (PFNGLVERTEXWEIGHTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexWeightfvEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_EXT_vertex_weighting */ + +#ifdef GL_GREMEDY_frame_terminator + +static GLboolean _glewInit_GL_GREMEDY_frame_terminator (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFrameTerminatorGREMEDY = (PFNGLFRAMETERMINATORGREMEDYPROC)glewGetProcAddress((const GLubyte*)"glFrameTerminatorGREMEDY")) == NULL) || r; + + return r; +} + +#endif /* GL_GREMEDY_frame_terminator */ + +#ifdef GL_GREMEDY_string_marker + +static GLboolean _glewInit_GL_GREMEDY_string_marker (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glStringMarkerGREMEDY = (PFNGLSTRINGMARKERGREMEDYPROC)glewGetProcAddress((const GLubyte*)"glStringMarkerGREMEDY")) == NULL) || r; + + return r; +} + +#endif /* GL_GREMEDY_string_marker */ + +#ifdef GL_HP_convolution_border_modes + +#endif /* GL_HP_convolution_border_modes */ + +#ifdef GL_HP_image_transform + +static GLboolean _glewInit_GL_HP_image_transform (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetImageTransformParameterfvHP = (PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC)glewGetProcAddress((const GLubyte*)"glGetImageTransformParameterfvHP")) == NULL) || r; + r = ((glGetImageTransformParameterivHP = (PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC)glewGetProcAddress((const GLubyte*)"glGetImageTransformParameterivHP")) == NULL) || r; + r = ((glImageTransformParameterfHP = (PFNGLIMAGETRANSFORMPARAMETERFHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameterfHP")) == NULL) || r; + r = ((glImageTransformParameterfvHP = (PFNGLIMAGETRANSFORMPARAMETERFVHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameterfvHP")) == NULL) || r; + r = ((glImageTransformParameteriHP = (PFNGLIMAGETRANSFORMPARAMETERIHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameteriHP")) == NULL) || r; + r = ((glImageTransformParameterivHP = (PFNGLIMAGETRANSFORMPARAMETERIVHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameterivHP")) == NULL) || r; + + return r; +} + +#endif /* GL_HP_image_transform */ + +#ifdef GL_HP_occlusion_test + +#endif /* GL_HP_occlusion_test */ + +#ifdef GL_HP_texture_lighting + +#endif /* GL_HP_texture_lighting */ + +#ifdef GL_IBM_cull_vertex + +#endif /* GL_IBM_cull_vertex */ + +#ifdef GL_IBM_multimode_draw_arrays + +static GLboolean _glewInit_GL_IBM_multimode_draw_arrays (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glMultiModeDrawArraysIBM = (PFNGLMULTIMODEDRAWARRAYSIBMPROC)glewGetProcAddress((const GLubyte*)"glMultiModeDrawArraysIBM")) == NULL) || r; + r = ((glMultiModeDrawElementsIBM = (PFNGLMULTIMODEDRAWELEMENTSIBMPROC)glewGetProcAddress((const GLubyte*)"glMultiModeDrawElementsIBM")) == NULL) || r; + + return r; +} + +#endif /* GL_IBM_multimode_draw_arrays */ + +#ifdef GL_IBM_rasterpos_clip + +#endif /* GL_IBM_rasterpos_clip */ + +#ifdef GL_IBM_static_data + +#endif /* GL_IBM_static_data */ + +#ifdef GL_IBM_texture_mirrored_repeat + +#endif /* GL_IBM_texture_mirrored_repeat */ + +#ifdef GL_IBM_vertex_array_lists + +static GLboolean _glewInit_GL_IBM_vertex_array_lists (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColorPointerListIBM = (PFNGLCOLORPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glColorPointerListIBM")) == NULL) || r; + r = ((glEdgeFlagPointerListIBM = (PFNGLEDGEFLAGPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glEdgeFlagPointerListIBM")) == NULL) || r; + r = ((glFogCoordPointerListIBM = (PFNGLFOGCOORDPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glFogCoordPointerListIBM")) == NULL) || r; + r = ((glIndexPointerListIBM = (PFNGLINDEXPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glIndexPointerListIBM")) == NULL) || r; + r = ((glNormalPointerListIBM = (PFNGLNORMALPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glNormalPointerListIBM")) == NULL) || r; + r = ((glSecondaryColorPointerListIBM = (PFNGLSECONDARYCOLORPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorPointerListIBM")) == NULL) || r; + r = ((glTexCoordPointerListIBM = (PFNGLTEXCOORDPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glTexCoordPointerListIBM")) == NULL) || r; + r = ((glVertexPointerListIBM = (PFNGLVERTEXPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glVertexPointerListIBM")) == NULL) || r; + + return r; +} + +#endif /* GL_IBM_vertex_array_lists */ + +#ifdef GL_INGR_color_clamp + +#endif /* GL_INGR_color_clamp */ + +#ifdef GL_INGR_interlace_read + +#endif /* GL_INGR_interlace_read */ + +#ifdef GL_INTEL_parallel_arrays + +static GLboolean _glewInit_GL_INTEL_parallel_arrays (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColorPointervINTEL = (PFNGLCOLORPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glColorPointervINTEL")) == NULL) || r; + r = ((glNormalPointervINTEL = (PFNGLNORMALPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glNormalPointervINTEL")) == NULL) || r; + r = ((glTexCoordPointervINTEL = (PFNGLTEXCOORDPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glTexCoordPointervINTEL")) == NULL) || r; + r = ((glVertexPointervINTEL = (PFNGLVERTEXPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glVertexPointervINTEL")) == NULL) || r; + + return r; +} + +#endif /* GL_INTEL_parallel_arrays */ + +#ifdef GL_INTEL_texture_scissor + +static GLboolean _glewInit_GL_INTEL_texture_scissor (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTexScissorFuncINTEL = (PFNGLTEXSCISSORFUNCINTELPROC)glewGetProcAddress((const GLubyte*)"glTexScissorFuncINTEL")) == NULL) || r; + r = ((glTexScissorINTEL = (PFNGLTEXSCISSORINTELPROC)glewGetProcAddress((const GLubyte*)"glTexScissorINTEL")) == NULL) || r; + + return r; +} + +#endif /* GL_INTEL_texture_scissor */ + +#ifdef GL_KTX_buffer_region + +static GLboolean _glewInit_GL_KTX_buffer_region (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBufferRegionEnabledEXT = (PFNGLBUFFERREGIONENABLEDEXTPROC)glewGetProcAddress((const GLubyte*)"glBufferRegionEnabledEXT")) == NULL) || r; + r = ((glDeleteBufferRegionEXT = (PFNGLDELETEBUFFERREGIONEXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteBufferRegionEXT")) == NULL) || r; + r = ((glDrawBufferRegionEXT = (PFNGLDRAWBUFFERREGIONEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawBufferRegionEXT")) == NULL) || r; + r = ((glNewBufferRegionEXT = (PFNGLNEWBUFFERREGIONEXTPROC)glewGetProcAddress((const GLubyte*)"glNewBufferRegionEXT")) == NULL) || r; + r = ((glReadBufferRegionEXT = (PFNGLREADBUFFERREGIONEXTPROC)glewGetProcAddress((const GLubyte*)"glReadBufferRegionEXT")) == NULL) || r; + + return r; +} + +#endif /* GL_KTX_buffer_region */ + +#ifdef GL_MESAX_texture_stack + +#endif /* GL_MESAX_texture_stack */ + +#ifdef GL_MESA_pack_invert + +#endif /* GL_MESA_pack_invert */ + +#ifdef GL_MESA_resize_buffers + +static GLboolean _glewInit_GL_MESA_resize_buffers (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glResizeBuffersMESA = (PFNGLRESIZEBUFFERSMESAPROC)glewGetProcAddress((const GLubyte*)"glResizeBuffersMESA")) == NULL) || r; + + return r; +} + +#endif /* GL_MESA_resize_buffers */ + +#ifdef GL_MESA_window_pos + +static GLboolean _glewInit_GL_MESA_window_pos (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glWindowPos2dMESA = (PFNGLWINDOWPOS2DMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dMESA")) == NULL) || r; + r = ((glWindowPos2dvMESA = (PFNGLWINDOWPOS2DVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dvMESA")) == NULL) || r; + r = ((glWindowPos2fMESA = (PFNGLWINDOWPOS2FMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fMESA")) == NULL) || r; + r = ((glWindowPos2fvMESA = (PFNGLWINDOWPOS2FVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fvMESA")) == NULL) || r; + r = ((glWindowPos2iMESA = (PFNGLWINDOWPOS2IMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2iMESA")) == NULL) || r; + r = ((glWindowPos2ivMESA = (PFNGLWINDOWPOS2IVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2ivMESA")) == NULL) || r; + r = ((glWindowPos2sMESA = (PFNGLWINDOWPOS2SMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2sMESA")) == NULL) || r; + r = ((glWindowPos2svMESA = (PFNGLWINDOWPOS2SVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2svMESA")) == NULL) || r; + r = ((glWindowPos3dMESA = (PFNGLWINDOWPOS3DMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dMESA")) == NULL) || r; + r = ((glWindowPos3dvMESA = (PFNGLWINDOWPOS3DVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dvMESA")) == NULL) || r; + r = ((glWindowPos3fMESA = (PFNGLWINDOWPOS3FMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fMESA")) == NULL) || r; + r = ((glWindowPos3fvMESA = (PFNGLWINDOWPOS3FVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fvMESA")) == NULL) || r; + r = ((glWindowPos3iMESA = (PFNGLWINDOWPOS3IMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3iMESA")) == NULL) || r; + r = ((glWindowPos3ivMESA = (PFNGLWINDOWPOS3IVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3ivMESA")) == NULL) || r; + r = ((glWindowPos3sMESA = (PFNGLWINDOWPOS3SMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3sMESA")) == NULL) || r; + r = ((glWindowPos3svMESA = (PFNGLWINDOWPOS3SVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3svMESA")) == NULL) || r; + r = ((glWindowPos4dMESA = (PFNGLWINDOWPOS4DMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4dMESA")) == NULL) || r; + r = ((glWindowPos4dvMESA = (PFNGLWINDOWPOS4DVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4dvMESA")) == NULL) || r; + r = ((glWindowPos4fMESA = (PFNGLWINDOWPOS4FMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4fMESA")) == NULL) || r; + r = ((glWindowPos4fvMESA = (PFNGLWINDOWPOS4FVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4fvMESA")) == NULL) || r; + r = ((glWindowPos4iMESA = (PFNGLWINDOWPOS4IMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4iMESA")) == NULL) || r; + r = ((glWindowPos4ivMESA = (PFNGLWINDOWPOS4IVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4ivMESA")) == NULL) || r; + r = ((glWindowPos4sMESA = (PFNGLWINDOWPOS4SMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4sMESA")) == NULL) || r; + r = ((glWindowPos4svMESA = (PFNGLWINDOWPOS4SVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4svMESA")) == NULL) || r; + + return r; +} + +#endif /* GL_MESA_window_pos */ + +#ifdef GL_MESA_ycbcr_texture + +#endif /* GL_MESA_ycbcr_texture */ + +#ifdef GL_NV_blend_square + +#endif /* GL_NV_blend_square */ + +#ifdef GL_NV_conditional_render + +static GLboolean _glewInit_GL_NV_conditional_render (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginConditionalRenderNV = (PFNGLBEGINCONDITIONALRENDERNVPROC)glewGetProcAddress((const GLubyte*)"glBeginConditionalRenderNV")) == NULL) || r; + r = ((glEndConditionalRenderNV = (PFNGLENDCONDITIONALRENDERNVPROC)glewGetProcAddress((const GLubyte*)"glEndConditionalRenderNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_conditional_render */ + +#ifdef GL_NV_copy_depth_to_color + +#endif /* GL_NV_copy_depth_to_color */ + +#ifdef GL_NV_copy_image + +static GLboolean _glewInit_GL_NV_copy_image (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCopyImageSubDataNV = (PFNGLCOPYIMAGESUBDATANVPROC)glewGetProcAddress((const GLubyte*)"glCopyImageSubDataNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_copy_image */ + +#ifdef GL_NV_depth_buffer_float + +static GLboolean _glewInit_GL_NV_depth_buffer_float (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glClearDepthdNV = (PFNGLCLEARDEPTHDNVPROC)glewGetProcAddress((const GLubyte*)"glClearDepthdNV")) == NULL) || r; + r = ((glDepthBoundsdNV = (PFNGLDEPTHBOUNDSDNVPROC)glewGetProcAddress((const GLubyte*)"glDepthBoundsdNV")) == NULL) || r; + r = ((glDepthRangedNV = (PFNGLDEPTHRANGEDNVPROC)glewGetProcAddress((const GLubyte*)"glDepthRangedNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_depth_buffer_float */ + +#ifdef GL_NV_depth_clamp + +#endif /* GL_NV_depth_clamp */ + +#ifdef GL_NV_depth_range_unclamped + +#endif /* GL_NV_depth_range_unclamped */ + +#ifdef GL_NV_evaluators + +static GLboolean _glewInit_GL_NV_evaluators (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glEvalMapsNV = (PFNGLEVALMAPSNVPROC)glewGetProcAddress((const GLubyte*)"glEvalMapsNV")) == NULL) || r; + r = ((glGetMapAttribParameterfvNV = (PFNGLGETMAPATTRIBPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapAttribParameterfvNV")) == NULL) || r; + r = ((glGetMapAttribParameterivNV = (PFNGLGETMAPATTRIBPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapAttribParameterivNV")) == NULL) || r; + r = ((glGetMapControlPointsNV = (PFNGLGETMAPCONTROLPOINTSNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapControlPointsNV")) == NULL) || r; + r = ((glGetMapParameterfvNV = (PFNGLGETMAPPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapParameterfvNV")) == NULL) || r; + r = ((glGetMapParameterivNV = (PFNGLGETMAPPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapParameterivNV")) == NULL) || r; + r = ((glMapControlPointsNV = (PFNGLMAPCONTROLPOINTSNVPROC)glewGetProcAddress((const GLubyte*)"glMapControlPointsNV")) == NULL) || r; + r = ((glMapParameterfvNV = (PFNGLMAPPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glMapParameterfvNV")) == NULL) || r; + r = ((glMapParameterivNV = (PFNGLMAPPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glMapParameterivNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_evaluators */ + +#ifdef GL_NV_explicit_multisample + +static GLboolean _glewInit_GL_NV_explicit_multisample (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetMultisamplefvNV = (PFNGLGETMULTISAMPLEFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMultisamplefvNV")) == NULL) || r; + r = ((glSampleMaskIndexedNV = (PFNGLSAMPLEMASKINDEXEDNVPROC)glewGetProcAddress((const GLubyte*)"glSampleMaskIndexedNV")) == NULL) || r; + r = ((glTexRenderbufferNV = (PFNGLTEXRENDERBUFFERNVPROC)glewGetProcAddress((const GLubyte*)"glTexRenderbufferNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_explicit_multisample */ + +#ifdef GL_NV_fence + +static GLboolean _glewInit_GL_NV_fence (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDeleteFencesNV = (PFNGLDELETEFENCESNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteFencesNV")) == NULL) || r; + r = ((glFinishFenceNV = (PFNGLFINISHFENCENVPROC)glewGetProcAddress((const GLubyte*)"glFinishFenceNV")) == NULL) || r; + r = ((glGenFencesNV = (PFNGLGENFENCESNVPROC)glewGetProcAddress((const GLubyte*)"glGenFencesNV")) == NULL) || r; + r = ((glGetFenceivNV = (PFNGLGETFENCEIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetFenceivNV")) == NULL) || r; + r = ((glIsFenceNV = (PFNGLISFENCENVPROC)glewGetProcAddress((const GLubyte*)"glIsFenceNV")) == NULL) || r; + r = ((glSetFenceNV = (PFNGLSETFENCENVPROC)glewGetProcAddress((const GLubyte*)"glSetFenceNV")) == NULL) || r; + r = ((glTestFenceNV = (PFNGLTESTFENCENVPROC)glewGetProcAddress((const GLubyte*)"glTestFenceNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_fence */ + +#ifdef GL_NV_float_buffer + +#endif /* GL_NV_float_buffer */ + +#ifdef GL_NV_fog_distance + +#endif /* GL_NV_fog_distance */ + +#ifdef GL_NV_fragment_program + +static GLboolean _glewInit_GL_NV_fragment_program (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetProgramNamedParameterdvNV = (PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramNamedParameterdvNV")) == NULL) || r; + r = ((glGetProgramNamedParameterfvNV = (PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramNamedParameterfvNV")) == NULL) || r; + r = ((glProgramNamedParameter4dNV = (PFNGLPROGRAMNAMEDPARAMETER4DNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4dNV")) == NULL) || r; + r = ((glProgramNamedParameter4dvNV = (PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4dvNV")) == NULL) || r; + r = ((glProgramNamedParameter4fNV = (PFNGLPROGRAMNAMEDPARAMETER4FNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4fNV")) == NULL) || r; + r = ((glProgramNamedParameter4fvNV = (PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4fvNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_fragment_program */ + +#ifdef GL_NV_fragment_program2 + +#endif /* GL_NV_fragment_program2 */ + +#ifdef GL_NV_fragment_program4 + +#endif /* GL_NV_fragment_program4 */ + +#ifdef GL_NV_fragment_program_option + +#endif /* GL_NV_fragment_program_option */ + +#ifdef GL_NV_framebuffer_multisample_coverage + +static GLboolean _glewInit_GL_NV_framebuffer_multisample_coverage (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glRenderbufferStorageMultisampleCoverageNV = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageMultisampleCoverageNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_framebuffer_multisample_coverage */ + +#ifdef GL_NV_geometry_program4 + +static GLboolean _glewInit_GL_NV_geometry_program4 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glProgramVertexLimitNV = (PFNGLPROGRAMVERTEXLIMITNVPROC)glewGetProcAddress((const GLubyte*)"glProgramVertexLimitNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_geometry_program4 */ + +#ifdef GL_NV_geometry_shader4 + +#endif /* GL_NV_geometry_shader4 */ + +#ifdef GL_NV_gpu_program4 + +static GLboolean _glewInit_GL_NV_gpu_program4 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glProgramEnvParameterI4iNV = (PFNGLPROGRAMENVPARAMETERI4INVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4iNV")) == NULL) || r; + r = ((glProgramEnvParameterI4ivNV = (PFNGLPROGRAMENVPARAMETERI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4ivNV")) == NULL) || r; + r = ((glProgramEnvParameterI4uiNV = (PFNGLPROGRAMENVPARAMETERI4UINVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4uiNV")) == NULL) || r; + r = ((glProgramEnvParameterI4uivNV = (PFNGLPROGRAMENVPARAMETERI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4uivNV")) == NULL) || r; + r = ((glProgramEnvParametersI4ivNV = (PFNGLPROGRAMENVPARAMETERSI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParametersI4ivNV")) == NULL) || r; + r = ((glProgramEnvParametersI4uivNV = (PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParametersI4uivNV")) == NULL) || r; + r = ((glProgramLocalParameterI4iNV = (PFNGLPROGRAMLOCALPARAMETERI4INVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4iNV")) == NULL) || r; + r = ((glProgramLocalParameterI4ivNV = (PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4ivNV")) == NULL) || r; + r = ((glProgramLocalParameterI4uiNV = (PFNGLPROGRAMLOCALPARAMETERI4UINVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4uiNV")) == NULL) || r; + r = ((glProgramLocalParameterI4uivNV = (PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4uivNV")) == NULL) || r; + r = ((glProgramLocalParametersI4ivNV = (PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParametersI4ivNV")) == NULL) || r; + r = ((glProgramLocalParametersI4uivNV = (PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParametersI4uivNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_gpu_program4 */ + +#ifdef GL_NV_gpu_program5 + +#endif /* GL_NV_gpu_program5 */ + +#ifdef GL_NV_gpu_program_fp64 + +#endif /* GL_NV_gpu_program_fp64 */ + +#ifdef GL_NV_gpu_shader5 + +static GLboolean _glewInit_GL_NV_gpu_shader5 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetUniformi64vNV = (PFNGLGETUNIFORMI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformi64vNV")) == NULL) || r; + r = ((glGetUniformui64vNV = (PFNGLGETUNIFORMUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformui64vNV")) == NULL) || r; + r = ((glProgramUniform1i64NV = (PFNGLPROGRAMUNIFORM1I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1i64NV")) == NULL) || r; + r = ((glProgramUniform1i64vNV = (PFNGLPROGRAMUNIFORM1I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1i64vNV")) == NULL) || r; + r = ((glProgramUniform1ui64NV = (PFNGLPROGRAMUNIFORM1UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1ui64NV")) == NULL) || r; + r = ((glProgramUniform1ui64vNV = (PFNGLPROGRAMUNIFORM1UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1ui64vNV")) == NULL) || r; + r = ((glProgramUniform2i64NV = (PFNGLPROGRAMUNIFORM2I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2i64NV")) == NULL) || r; + r = ((glProgramUniform2i64vNV = (PFNGLPROGRAMUNIFORM2I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2i64vNV")) == NULL) || r; + r = ((glProgramUniform2ui64NV = (PFNGLPROGRAMUNIFORM2UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2ui64NV")) == NULL) || r; + r = ((glProgramUniform2ui64vNV = (PFNGLPROGRAMUNIFORM2UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2ui64vNV")) == NULL) || r; + r = ((glProgramUniform3i64NV = (PFNGLPROGRAMUNIFORM3I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3i64NV")) == NULL) || r; + r = ((glProgramUniform3i64vNV = (PFNGLPROGRAMUNIFORM3I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3i64vNV")) == NULL) || r; + r = ((glProgramUniform3ui64NV = (PFNGLPROGRAMUNIFORM3UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3ui64NV")) == NULL) || r; + r = ((glProgramUniform3ui64vNV = (PFNGLPROGRAMUNIFORM3UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3ui64vNV")) == NULL) || r; + r = ((glProgramUniform4i64NV = (PFNGLPROGRAMUNIFORM4I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4i64NV")) == NULL) || r; + r = ((glProgramUniform4i64vNV = (PFNGLPROGRAMUNIFORM4I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4i64vNV")) == NULL) || r; + r = ((glProgramUniform4ui64NV = (PFNGLPROGRAMUNIFORM4UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4ui64NV")) == NULL) || r; + r = ((glProgramUniform4ui64vNV = (PFNGLPROGRAMUNIFORM4UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4ui64vNV")) == NULL) || r; + r = ((glUniform1i64NV = (PFNGLUNIFORM1I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform1i64NV")) == NULL) || r; + r = ((glUniform1i64vNV = (PFNGLUNIFORM1I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform1i64vNV")) == NULL) || r; + r = ((glUniform1ui64NV = (PFNGLUNIFORM1UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform1ui64NV")) == NULL) || r; + r = ((glUniform1ui64vNV = (PFNGLUNIFORM1UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform1ui64vNV")) == NULL) || r; + r = ((glUniform2i64NV = (PFNGLUNIFORM2I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform2i64NV")) == NULL) || r; + r = ((glUniform2i64vNV = (PFNGLUNIFORM2I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform2i64vNV")) == NULL) || r; + r = ((glUniform2ui64NV = (PFNGLUNIFORM2UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform2ui64NV")) == NULL) || r; + r = ((glUniform2ui64vNV = (PFNGLUNIFORM2UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform2ui64vNV")) == NULL) || r; + r = ((glUniform3i64NV = (PFNGLUNIFORM3I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform3i64NV")) == NULL) || r; + r = ((glUniform3i64vNV = (PFNGLUNIFORM3I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform3i64vNV")) == NULL) || r; + r = ((glUniform3ui64NV = (PFNGLUNIFORM3UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform3ui64NV")) == NULL) || r; + r = ((glUniform3ui64vNV = (PFNGLUNIFORM3UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform3ui64vNV")) == NULL) || r; + r = ((glUniform4i64NV = (PFNGLUNIFORM4I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform4i64NV")) == NULL) || r; + r = ((glUniform4i64vNV = (PFNGLUNIFORM4I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform4i64vNV")) == NULL) || r; + r = ((glUniform4ui64NV = (PFNGLUNIFORM4UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform4ui64NV")) == NULL) || r; + r = ((glUniform4ui64vNV = (PFNGLUNIFORM4UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform4ui64vNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_gpu_shader5 */ + +#ifdef GL_NV_half_float + +static GLboolean _glewInit_GL_NV_half_float (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColor3hNV = (PFNGLCOLOR3HNVPROC)glewGetProcAddress((const GLubyte*)"glColor3hNV")) == NULL) || r; + r = ((glColor3hvNV = (PFNGLCOLOR3HVNVPROC)glewGetProcAddress((const GLubyte*)"glColor3hvNV")) == NULL) || r; + r = ((glColor4hNV = (PFNGLCOLOR4HNVPROC)glewGetProcAddress((const GLubyte*)"glColor4hNV")) == NULL) || r; + r = ((glColor4hvNV = (PFNGLCOLOR4HVNVPROC)glewGetProcAddress((const GLubyte*)"glColor4hvNV")) == NULL) || r; + r = ((glFogCoordhNV = (PFNGLFOGCOORDHNVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordhNV")) == NULL) || r; + r = ((glFogCoordhvNV = (PFNGLFOGCOORDHVNVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordhvNV")) == NULL) || r; + r = ((glMultiTexCoord1hNV = (PFNGLMULTITEXCOORD1HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1hNV")) == NULL) || r; + r = ((glMultiTexCoord1hvNV = (PFNGLMULTITEXCOORD1HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1hvNV")) == NULL) || r; + r = ((glMultiTexCoord2hNV = (PFNGLMULTITEXCOORD2HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2hNV")) == NULL) || r; + r = ((glMultiTexCoord2hvNV = (PFNGLMULTITEXCOORD2HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2hvNV")) == NULL) || r; + r = ((glMultiTexCoord3hNV = (PFNGLMULTITEXCOORD3HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3hNV")) == NULL) || r; + r = ((glMultiTexCoord3hvNV = (PFNGLMULTITEXCOORD3HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3hvNV")) == NULL) || r; + r = ((glMultiTexCoord4hNV = (PFNGLMULTITEXCOORD4HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4hNV")) == NULL) || r; + r = ((glMultiTexCoord4hvNV = (PFNGLMULTITEXCOORD4HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4hvNV")) == NULL) || r; + r = ((glNormal3hNV = (PFNGLNORMAL3HNVPROC)glewGetProcAddress((const GLubyte*)"glNormal3hNV")) == NULL) || r; + r = ((glNormal3hvNV = (PFNGLNORMAL3HVNVPROC)glewGetProcAddress((const GLubyte*)"glNormal3hvNV")) == NULL) || r; + r = ((glSecondaryColor3hNV = (PFNGLSECONDARYCOLOR3HNVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3hNV")) == NULL) || r; + r = ((glSecondaryColor3hvNV = (PFNGLSECONDARYCOLOR3HVNVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3hvNV")) == NULL) || r; + r = ((glTexCoord1hNV = (PFNGLTEXCOORD1HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord1hNV")) == NULL) || r; + r = ((glTexCoord1hvNV = (PFNGLTEXCOORD1HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord1hvNV")) == NULL) || r; + r = ((glTexCoord2hNV = (PFNGLTEXCOORD2HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2hNV")) == NULL) || r; + r = ((glTexCoord2hvNV = (PFNGLTEXCOORD2HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2hvNV")) == NULL) || r; + r = ((glTexCoord3hNV = (PFNGLTEXCOORD3HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord3hNV")) == NULL) || r; + r = ((glTexCoord3hvNV = (PFNGLTEXCOORD3HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord3hvNV")) == NULL) || r; + r = ((glTexCoord4hNV = (PFNGLTEXCOORD4HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4hNV")) == NULL) || r; + r = ((glTexCoord4hvNV = (PFNGLTEXCOORD4HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4hvNV")) == NULL) || r; + r = ((glVertex2hNV = (PFNGLVERTEX2HNVPROC)glewGetProcAddress((const GLubyte*)"glVertex2hNV")) == NULL) || r; + r = ((glVertex2hvNV = (PFNGLVERTEX2HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertex2hvNV")) == NULL) || r; + r = ((glVertex3hNV = (PFNGLVERTEX3HNVPROC)glewGetProcAddress((const GLubyte*)"glVertex3hNV")) == NULL) || r; + r = ((glVertex3hvNV = (PFNGLVERTEX3HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertex3hvNV")) == NULL) || r; + r = ((glVertex4hNV = (PFNGLVERTEX4HNVPROC)glewGetProcAddress((const GLubyte*)"glVertex4hNV")) == NULL) || r; + r = ((glVertex4hvNV = (PFNGLVERTEX4HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertex4hvNV")) == NULL) || r; + r = ((glVertexAttrib1hNV = (PFNGLVERTEXATTRIB1HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1hNV")) == NULL) || r; + r = ((glVertexAttrib1hvNV = (PFNGLVERTEXATTRIB1HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1hvNV")) == NULL) || r; + r = ((glVertexAttrib2hNV = (PFNGLVERTEXATTRIB2HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2hNV")) == NULL) || r; + r = ((glVertexAttrib2hvNV = (PFNGLVERTEXATTRIB2HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2hvNV")) == NULL) || r; + r = ((glVertexAttrib3hNV = (PFNGLVERTEXATTRIB3HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3hNV")) == NULL) || r; + r = ((glVertexAttrib3hvNV = (PFNGLVERTEXATTRIB3HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3hvNV")) == NULL) || r; + r = ((glVertexAttrib4hNV = (PFNGLVERTEXATTRIB4HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4hNV")) == NULL) || r; + r = ((glVertexAttrib4hvNV = (PFNGLVERTEXATTRIB4HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4hvNV")) == NULL) || r; + r = ((glVertexAttribs1hvNV = (PFNGLVERTEXATTRIBS1HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1hvNV")) == NULL) || r; + r = ((glVertexAttribs2hvNV = (PFNGLVERTEXATTRIBS2HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2hvNV")) == NULL) || r; + r = ((glVertexAttribs3hvNV = (PFNGLVERTEXATTRIBS3HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3hvNV")) == NULL) || r; + r = ((glVertexAttribs4hvNV = (PFNGLVERTEXATTRIBS4HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4hvNV")) == NULL) || r; + r = ((glVertexWeighthNV = (PFNGLVERTEXWEIGHTHNVPROC)glewGetProcAddress((const GLubyte*)"glVertexWeighthNV")) == NULL) || r; + r = ((glVertexWeighthvNV = (PFNGLVERTEXWEIGHTHVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexWeighthvNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_half_float */ + +#ifdef GL_NV_light_max_exponent + +#endif /* GL_NV_light_max_exponent */ + +#ifdef GL_NV_multisample_filter_hint + +#endif /* GL_NV_multisample_filter_hint */ + +#ifdef GL_NV_occlusion_query + +static GLboolean _glewInit_GL_NV_occlusion_query (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBeginOcclusionQueryNV = (PFNGLBEGINOCCLUSIONQUERYNVPROC)glewGetProcAddress((const GLubyte*)"glBeginOcclusionQueryNV")) == NULL) || r; + r = ((glDeleteOcclusionQueriesNV = (PFNGLDELETEOCCLUSIONQUERIESNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteOcclusionQueriesNV")) == NULL) || r; + r = ((glEndOcclusionQueryNV = (PFNGLENDOCCLUSIONQUERYNVPROC)glewGetProcAddress((const GLubyte*)"glEndOcclusionQueryNV")) == NULL) || r; + r = ((glGenOcclusionQueriesNV = (PFNGLGENOCCLUSIONQUERIESNVPROC)glewGetProcAddress((const GLubyte*)"glGenOcclusionQueriesNV")) == NULL) || r; + r = ((glGetOcclusionQueryivNV = (PFNGLGETOCCLUSIONQUERYIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetOcclusionQueryivNV")) == NULL) || r; + r = ((glGetOcclusionQueryuivNV = (PFNGLGETOCCLUSIONQUERYUIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetOcclusionQueryuivNV")) == NULL) || r; + r = ((glIsOcclusionQueryNV = (PFNGLISOCCLUSIONQUERYNVPROC)glewGetProcAddress((const GLubyte*)"glIsOcclusionQueryNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_occlusion_query */ + +#ifdef GL_NV_packed_depth_stencil + +#endif /* GL_NV_packed_depth_stencil */ + +#ifdef GL_NV_parameter_buffer_object + +static GLboolean _glewInit_GL_NV_parameter_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glProgramBufferParametersIivNV = (PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramBufferParametersIivNV")) == NULL) || r; + r = ((glProgramBufferParametersIuivNV = (PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramBufferParametersIuivNV")) == NULL) || r; + r = ((glProgramBufferParametersfvNV = (PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramBufferParametersfvNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_parameter_buffer_object */ + +#ifdef GL_NV_parameter_buffer_object2 + +#endif /* GL_NV_parameter_buffer_object2 */ + +#ifdef GL_NV_pixel_data_range + +static GLboolean _glewInit_GL_NV_pixel_data_range (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFlushPixelDataRangeNV = (PFNGLFLUSHPIXELDATARANGENVPROC)glewGetProcAddress((const GLubyte*)"glFlushPixelDataRangeNV")) == NULL) || r; + r = ((glPixelDataRangeNV = (PFNGLPIXELDATARANGENVPROC)glewGetProcAddress((const GLubyte*)"glPixelDataRangeNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_pixel_data_range */ + +#ifdef GL_NV_point_sprite + +static GLboolean _glewInit_GL_NV_point_sprite (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPointParameteriNV = (PFNGLPOINTPARAMETERINVPROC)glewGetProcAddress((const GLubyte*)"glPointParameteriNV")) == NULL) || r; + r = ((glPointParameterivNV = (PFNGLPOINTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glPointParameterivNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_point_sprite */ + +#ifdef GL_NV_present_video + +static GLboolean _glewInit_GL_NV_present_video (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetVideoi64vNV = (PFNGLGETVIDEOI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoi64vNV")) == NULL) || r; + r = ((glGetVideoivNV = (PFNGLGETVIDEOIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoivNV")) == NULL) || r; + r = ((glGetVideoui64vNV = (PFNGLGETVIDEOUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoui64vNV")) == NULL) || r; + r = ((glGetVideouivNV = (PFNGLGETVIDEOUIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideouivNV")) == NULL) || r; + r = ((glPresentFrameDualFillNV = (PFNGLPRESENTFRAMEDUALFILLNVPROC)glewGetProcAddress((const GLubyte*)"glPresentFrameDualFillNV")) == NULL) || r; + r = ((glPresentFrameKeyedNV = (PFNGLPRESENTFRAMEKEYEDNVPROC)glewGetProcAddress((const GLubyte*)"glPresentFrameKeyedNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_present_video */ + +#ifdef GL_NV_primitive_restart + +static GLboolean _glewInit_GL_NV_primitive_restart (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPrimitiveRestartIndexNV = (PFNGLPRIMITIVERESTARTINDEXNVPROC)glewGetProcAddress((const GLubyte*)"glPrimitiveRestartIndexNV")) == NULL) || r; + r = ((glPrimitiveRestartNV = (PFNGLPRIMITIVERESTARTNVPROC)glewGetProcAddress((const GLubyte*)"glPrimitiveRestartNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_primitive_restart */ + +#ifdef GL_NV_register_combiners + +static GLboolean _glewInit_GL_NV_register_combiners (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCombinerInputNV = (PFNGLCOMBINERINPUTNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerInputNV")) == NULL) || r; + r = ((glCombinerOutputNV = (PFNGLCOMBINEROUTPUTNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerOutputNV")) == NULL) || r; + r = ((glCombinerParameterfNV = (PFNGLCOMBINERPARAMETERFNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameterfNV")) == NULL) || r; + r = ((glCombinerParameterfvNV = (PFNGLCOMBINERPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameterfvNV")) == NULL) || r; + r = ((glCombinerParameteriNV = (PFNGLCOMBINERPARAMETERINVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameteriNV")) == NULL) || r; + r = ((glCombinerParameterivNV = (PFNGLCOMBINERPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameterivNV")) == NULL) || r; + r = ((glFinalCombinerInputNV = (PFNGLFINALCOMBINERINPUTNVPROC)glewGetProcAddress((const GLubyte*)"glFinalCombinerInputNV")) == NULL) || r; + r = ((glGetCombinerInputParameterfvNV = (PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerInputParameterfvNV")) == NULL) || r; + r = ((glGetCombinerInputParameterivNV = (PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerInputParameterivNV")) == NULL) || r; + r = ((glGetCombinerOutputParameterfvNV = (PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerOutputParameterfvNV")) == NULL) || r; + r = ((glGetCombinerOutputParameterivNV = (PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerOutputParameterivNV")) == NULL) || r; + r = ((glGetFinalCombinerInputParameterfvNV = (PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetFinalCombinerInputParameterfvNV")) == NULL) || r; + r = ((glGetFinalCombinerInputParameterivNV = (PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetFinalCombinerInputParameterivNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_register_combiners */ + +#ifdef GL_NV_register_combiners2 + +static GLboolean _glewInit_GL_NV_register_combiners2 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glCombinerStageParameterfvNV = (PFNGLCOMBINERSTAGEPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerStageParameterfvNV")) == NULL) || r; + r = ((glGetCombinerStageParameterfvNV = (PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerStageParameterfvNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_register_combiners2 */ + +#ifdef GL_NV_shader_buffer_load + +static GLboolean _glewInit_GL_NV_shader_buffer_load (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetBufferParameterui64vNV = (PFNGLGETBUFFERPARAMETERUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameterui64vNV")) == NULL) || r; + r = ((glGetIntegerui64vNV = (PFNGLGETINTEGERUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetIntegerui64vNV")) == NULL) || r; + r = ((glGetNamedBufferParameterui64vNV = (PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferParameterui64vNV")) == NULL) || r; + r = ((glIsBufferResidentNV = (PFNGLISBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glIsBufferResidentNV")) == NULL) || r; + r = ((glIsNamedBufferResidentNV = (PFNGLISNAMEDBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glIsNamedBufferResidentNV")) == NULL) || r; + r = ((glMakeBufferNonResidentNV = (PFNGLMAKEBUFFERNONRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeBufferNonResidentNV")) == NULL) || r; + r = ((glMakeBufferResidentNV = (PFNGLMAKEBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeBufferResidentNV")) == NULL) || r; + r = ((glMakeNamedBufferNonResidentNV = (PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeNamedBufferNonResidentNV")) == NULL) || r; + r = ((glMakeNamedBufferResidentNV = (PFNGLMAKENAMEDBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeNamedBufferResidentNV")) == NULL) || r; + r = ((glProgramUniformui64NV = (PFNGLPROGRAMUNIFORMUI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformui64NV")) == NULL) || r; + r = ((glProgramUniformui64vNV = (PFNGLPROGRAMUNIFORMUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformui64vNV")) == NULL) || r; + r = ((glUniformui64NV = (PFNGLUNIFORMUI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniformui64NV")) == NULL) || r; + r = ((glUniformui64vNV = (PFNGLUNIFORMUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniformui64vNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_shader_buffer_load */ + +#ifdef GL_NV_tessellation_program5 + +#endif /* GL_NV_tessellation_program5 */ + +#ifdef GL_NV_texgen_emboss + +#endif /* GL_NV_texgen_emboss */ + +#ifdef GL_NV_texgen_reflection + +#endif /* GL_NV_texgen_reflection */ + +#ifdef GL_NV_texture_barrier + +static GLboolean _glewInit_GL_NV_texture_barrier (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTextureBarrierNV = (PFNGLTEXTUREBARRIERNVPROC)glewGetProcAddress((const GLubyte*)"glTextureBarrierNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_texture_barrier */ + +#ifdef GL_NV_texture_compression_vtc + +#endif /* GL_NV_texture_compression_vtc */ + +#ifdef GL_NV_texture_env_combine4 + +#endif /* GL_NV_texture_env_combine4 */ + +#ifdef GL_NV_texture_expand_normal + +#endif /* GL_NV_texture_expand_normal */ + +#ifdef GL_NV_texture_rectangle + +#endif /* GL_NV_texture_rectangle */ + +#ifdef GL_NV_texture_shader + +#endif /* GL_NV_texture_shader */ + +#ifdef GL_NV_texture_shader2 + +#endif /* GL_NV_texture_shader2 */ + +#ifdef GL_NV_texture_shader3 + +#endif /* GL_NV_texture_shader3 */ + +#ifdef GL_NV_transform_feedback + +static GLboolean _glewInit_GL_NV_transform_feedback (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glActiveVaryingNV = (PFNGLACTIVEVARYINGNVPROC)glewGetProcAddress((const GLubyte*)"glActiveVaryingNV")) == NULL) || r; + r = ((glBeginTransformFeedbackNV = (PFNGLBEGINTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glBeginTransformFeedbackNV")) == NULL) || r; + r = ((glBindBufferBaseNV = (PFNGLBINDBUFFERBASENVPROC)glewGetProcAddress((const GLubyte*)"glBindBufferBaseNV")) == NULL) || r; + r = ((glBindBufferOffsetNV = (PFNGLBINDBUFFEROFFSETNVPROC)glewGetProcAddress((const GLubyte*)"glBindBufferOffsetNV")) == NULL) || r; + r = ((glBindBufferRangeNV = (PFNGLBINDBUFFERRANGENVPROC)glewGetProcAddress((const GLubyte*)"glBindBufferRangeNV")) == NULL) || r; + r = ((glEndTransformFeedbackNV = (PFNGLENDTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glEndTransformFeedbackNV")) == NULL) || r; + r = ((glGetActiveVaryingNV = (PFNGLGETACTIVEVARYINGNVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveVaryingNV")) == NULL) || r; + r = ((glGetTransformFeedbackVaryingNV = (PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC)glewGetProcAddress((const GLubyte*)"glGetTransformFeedbackVaryingNV")) == NULL) || r; + r = ((glGetVaryingLocationNV = (PFNGLGETVARYINGLOCATIONNVPROC)glewGetProcAddress((const GLubyte*)"glGetVaryingLocationNV")) == NULL) || r; + r = ((glTransformFeedbackAttribsNV = (PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackAttribsNV")) == NULL) || r; + r = ((glTransformFeedbackVaryingsNV = (PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackVaryingsNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_transform_feedback */ + +#ifdef GL_NV_transform_feedback2 + +static GLboolean _glewInit_GL_NV_transform_feedback2 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBindTransformFeedbackNV = (PFNGLBINDTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glBindTransformFeedbackNV")) == NULL) || r; + r = ((glDeleteTransformFeedbacksNV = (PFNGLDELETETRANSFORMFEEDBACKSNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteTransformFeedbacksNV")) == NULL) || r; + r = ((glDrawTransformFeedbackNV = (PFNGLDRAWTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedbackNV")) == NULL) || r; + r = ((glGenTransformFeedbacksNV = (PFNGLGENTRANSFORMFEEDBACKSNVPROC)glewGetProcAddress((const GLubyte*)"glGenTransformFeedbacksNV")) == NULL) || r; + r = ((glIsTransformFeedbackNV = (PFNGLISTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glIsTransformFeedbackNV")) == NULL) || r; + r = ((glPauseTransformFeedbackNV = (PFNGLPAUSETRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glPauseTransformFeedbackNV")) == NULL) || r; + r = ((glResumeTransformFeedbackNV = (PFNGLRESUMETRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glResumeTransformFeedbackNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_transform_feedback2 */ + +#ifdef GL_NV_vertex_array_range + +static GLboolean _glewInit_GL_NV_vertex_array_range (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFlushVertexArrayRangeNV = (PFNGLFLUSHVERTEXARRAYRANGENVPROC)glewGetProcAddress((const GLubyte*)"glFlushVertexArrayRangeNV")) == NULL) || r; + r = ((glVertexArrayRangeNV = (PFNGLVERTEXARRAYRANGENVPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayRangeNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_vertex_array_range */ + +#ifdef GL_NV_vertex_array_range2 + +#endif /* GL_NV_vertex_array_range2 */ + +#ifdef GL_NV_vertex_attrib_integer_64bit + +static GLboolean _glewInit_GL_NV_vertex_attrib_integer_64bit (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetVertexAttribLi64vNV = (PFNGLGETVERTEXATTRIBLI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLi64vNV")) == NULL) || r; + r = ((glGetVertexAttribLui64vNV = (PFNGLGETVERTEXATTRIBLUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLui64vNV")) == NULL) || r; + r = ((glVertexAttribL1i64NV = (PFNGLVERTEXATTRIBL1I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1i64NV")) == NULL) || r; + r = ((glVertexAttribL1i64vNV = (PFNGLVERTEXATTRIBL1I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1i64vNV")) == NULL) || r; + r = ((glVertexAttribL1ui64NV = (PFNGLVERTEXATTRIBL1UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1ui64NV")) == NULL) || r; + r = ((glVertexAttribL1ui64vNV = (PFNGLVERTEXATTRIBL1UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1ui64vNV")) == NULL) || r; + r = ((glVertexAttribL2i64NV = (PFNGLVERTEXATTRIBL2I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2i64NV")) == NULL) || r; + r = ((glVertexAttribL2i64vNV = (PFNGLVERTEXATTRIBL2I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2i64vNV")) == NULL) || r; + r = ((glVertexAttribL2ui64NV = (PFNGLVERTEXATTRIBL2UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2ui64NV")) == NULL) || r; + r = ((glVertexAttribL2ui64vNV = (PFNGLVERTEXATTRIBL2UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2ui64vNV")) == NULL) || r; + r = ((glVertexAttribL3i64NV = (PFNGLVERTEXATTRIBL3I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3i64NV")) == NULL) || r; + r = ((glVertexAttribL3i64vNV = (PFNGLVERTEXATTRIBL3I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3i64vNV")) == NULL) || r; + r = ((glVertexAttribL3ui64NV = (PFNGLVERTEXATTRIBL3UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3ui64NV")) == NULL) || r; + r = ((glVertexAttribL3ui64vNV = (PFNGLVERTEXATTRIBL3UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3ui64vNV")) == NULL) || r; + r = ((glVertexAttribL4i64NV = (PFNGLVERTEXATTRIBL4I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4i64NV")) == NULL) || r; + r = ((glVertexAttribL4i64vNV = (PFNGLVERTEXATTRIBL4I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4i64vNV")) == NULL) || r; + r = ((glVertexAttribL4ui64NV = (PFNGLVERTEXATTRIBL4UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4ui64NV")) == NULL) || r; + r = ((glVertexAttribL4ui64vNV = (PFNGLVERTEXATTRIBL4UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4ui64vNV")) == NULL) || r; + r = ((glVertexAttribLFormatNV = (PFNGLVERTEXATTRIBLFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribLFormatNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_vertex_attrib_integer_64bit */ + +#ifdef GL_NV_vertex_buffer_unified_memory + +static GLboolean _glewInit_GL_NV_vertex_buffer_unified_memory (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glBufferAddressRangeNV = (PFNGLBUFFERADDRESSRANGENVPROC)glewGetProcAddress((const GLubyte*)"glBufferAddressRangeNV")) == NULL) || r; + r = ((glColorFormatNV = (PFNGLCOLORFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glColorFormatNV")) == NULL) || r; + r = ((glEdgeFlagFormatNV = (PFNGLEDGEFLAGFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glEdgeFlagFormatNV")) == NULL) || r; + r = ((glFogCoordFormatNV = (PFNGLFOGCOORDFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordFormatNV")) == NULL) || r; + r = ((glGetIntegerui64i_vNV = (PFNGLGETINTEGERUI64I_VNVPROC)glewGetProcAddress((const GLubyte*)"glGetIntegerui64i_vNV")) == NULL) || r; + r = ((glIndexFormatNV = (PFNGLINDEXFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glIndexFormatNV")) == NULL) || r; + r = ((glNormalFormatNV = (PFNGLNORMALFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glNormalFormatNV")) == NULL) || r; + r = ((glSecondaryColorFormatNV = (PFNGLSECONDARYCOLORFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorFormatNV")) == NULL) || r; + r = ((glTexCoordFormatNV = (PFNGLTEXCOORDFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordFormatNV")) == NULL) || r; + r = ((glVertexAttribFormatNV = (PFNGLVERTEXATTRIBFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribFormatNV")) == NULL) || r; + r = ((glVertexAttribIFormatNV = (PFNGLVERTEXATTRIBIFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribIFormatNV")) == NULL) || r; + r = ((glVertexFormatNV = (PFNGLVERTEXFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexFormatNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_vertex_buffer_unified_memory */ + +#ifdef GL_NV_vertex_program + +static GLboolean _glewInit_GL_NV_vertex_program (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glAreProgramsResidentNV = (PFNGLAREPROGRAMSRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glAreProgramsResidentNV")) == NULL) || r; + r = ((glBindProgramNV = (PFNGLBINDPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glBindProgramNV")) == NULL) || r; + r = ((glDeleteProgramsNV = (PFNGLDELETEPROGRAMSNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteProgramsNV")) == NULL) || r; + r = ((glExecuteProgramNV = (PFNGLEXECUTEPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glExecuteProgramNV")) == NULL) || r; + r = ((glGenProgramsNV = (PFNGLGENPROGRAMSNVPROC)glewGetProcAddress((const GLubyte*)"glGenProgramsNV")) == NULL) || r; + r = ((glGetProgramParameterdvNV = (PFNGLGETPROGRAMPARAMETERDVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramParameterdvNV")) == NULL) || r; + r = ((glGetProgramParameterfvNV = (PFNGLGETPROGRAMPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramParameterfvNV")) == NULL) || r; + r = ((glGetProgramStringNV = (PFNGLGETPROGRAMSTRINGNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramStringNV")) == NULL) || r; + r = ((glGetProgramivNV = (PFNGLGETPROGRAMIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramivNV")) == NULL) || r; + r = ((glGetTrackMatrixivNV = (PFNGLGETTRACKMATRIXIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetTrackMatrixivNV")) == NULL) || r; + r = ((glGetVertexAttribPointervNV = (PFNGLGETVERTEXATTRIBPOINTERVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribPointervNV")) == NULL) || r; + r = ((glGetVertexAttribdvNV = (PFNGLGETVERTEXATTRIBDVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribdvNV")) == NULL) || r; + r = ((glGetVertexAttribfvNV = (PFNGLGETVERTEXATTRIBFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribfvNV")) == NULL) || r; + r = ((glGetVertexAttribivNV = (PFNGLGETVERTEXATTRIBIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribivNV")) == NULL) || r; + r = ((glIsProgramNV = (PFNGLISPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glIsProgramNV")) == NULL) || r; + r = ((glLoadProgramNV = (PFNGLLOADPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glLoadProgramNV")) == NULL) || r; + r = ((glProgramParameter4dNV = (PFNGLPROGRAMPARAMETER4DNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4dNV")) == NULL) || r; + r = ((glProgramParameter4dvNV = (PFNGLPROGRAMPARAMETER4DVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4dvNV")) == NULL) || r; + r = ((glProgramParameter4fNV = (PFNGLPROGRAMPARAMETER4FNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4fNV")) == NULL) || r; + r = ((glProgramParameter4fvNV = (PFNGLPROGRAMPARAMETER4FVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4fvNV")) == NULL) || r; + r = ((glProgramParameters4dvNV = (PFNGLPROGRAMPARAMETERS4DVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameters4dvNV")) == NULL) || r; + r = ((glProgramParameters4fvNV = (PFNGLPROGRAMPARAMETERS4FVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameters4fvNV")) == NULL) || r; + r = ((glRequestResidentProgramsNV = (PFNGLREQUESTRESIDENTPROGRAMSNVPROC)glewGetProcAddress((const GLubyte*)"glRequestResidentProgramsNV")) == NULL) || r; + r = ((glTrackMatrixNV = (PFNGLTRACKMATRIXNVPROC)glewGetProcAddress((const GLubyte*)"glTrackMatrixNV")) == NULL) || r; + r = ((glVertexAttrib1dNV = (PFNGLVERTEXATTRIB1DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dNV")) == NULL) || r; + r = ((glVertexAttrib1dvNV = (PFNGLVERTEXATTRIB1DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dvNV")) == NULL) || r; + r = ((glVertexAttrib1fNV = (PFNGLVERTEXATTRIB1FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fNV")) == NULL) || r; + r = ((glVertexAttrib1fvNV = (PFNGLVERTEXATTRIB1FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fvNV")) == NULL) || r; + r = ((glVertexAttrib1sNV = (PFNGLVERTEXATTRIB1SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1sNV")) == NULL) || r; + r = ((glVertexAttrib1svNV = (PFNGLVERTEXATTRIB1SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1svNV")) == NULL) || r; + r = ((glVertexAttrib2dNV = (PFNGLVERTEXATTRIB2DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dNV")) == NULL) || r; + r = ((glVertexAttrib2dvNV = (PFNGLVERTEXATTRIB2DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dvNV")) == NULL) || r; + r = ((glVertexAttrib2fNV = (PFNGLVERTEXATTRIB2FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fNV")) == NULL) || r; + r = ((glVertexAttrib2fvNV = (PFNGLVERTEXATTRIB2FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fvNV")) == NULL) || r; + r = ((glVertexAttrib2sNV = (PFNGLVERTEXATTRIB2SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2sNV")) == NULL) || r; + r = ((glVertexAttrib2svNV = (PFNGLVERTEXATTRIB2SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2svNV")) == NULL) || r; + r = ((glVertexAttrib3dNV = (PFNGLVERTEXATTRIB3DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dNV")) == NULL) || r; + r = ((glVertexAttrib3dvNV = (PFNGLVERTEXATTRIB3DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dvNV")) == NULL) || r; + r = ((glVertexAttrib3fNV = (PFNGLVERTEXATTRIB3FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fNV")) == NULL) || r; + r = ((glVertexAttrib3fvNV = (PFNGLVERTEXATTRIB3FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fvNV")) == NULL) || r; + r = ((glVertexAttrib3sNV = (PFNGLVERTEXATTRIB3SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3sNV")) == NULL) || r; + r = ((glVertexAttrib3svNV = (PFNGLVERTEXATTRIB3SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3svNV")) == NULL) || r; + r = ((glVertexAttrib4dNV = (PFNGLVERTEXATTRIB4DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dNV")) == NULL) || r; + r = ((glVertexAttrib4dvNV = (PFNGLVERTEXATTRIB4DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dvNV")) == NULL) || r; + r = ((glVertexAttrib4fNV = (PFNGLVERTEXATTRIB4FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fNV")) == NULL) || r; + r = ((glVertexAttrib4fvNV = (PFNGLVERTEXATTRIB4FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fvNV")) == NULL) || r; + r = ((glVertexAttrib4sNV = (PFNGLVERTEXATTRIB4SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4sNV")) == NULL) || r; + r = ((glVertexAttrib4svNV = (PFNGLVERTEXATTRIB4SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4svNV")) == NULL) || r; + r = ((glVertexAttrib4ubNV = (PFNGLVERTEXATTRIB4UBNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubNV")) == NULL) || r; + r = ((glVertexAttrib4ubvNV = (PFNGLVERTEXATTRIB4UBVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubvNV")) == NULL) || r; + r = ((glVertexAttribPointerNV = (PFNGLVERTEXATTRIBPOINTERNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribPointerNV")) == NULL) || r; + r = ((glVertexAttribs1dvNV = (PFNGLVERTEXATTRIBS1DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1dvNV")) == NULL) || r; + r = ((glVertexAttribs1fvNV = (PFNGLVERTEXATTRIBS1FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1fvNV")) == NULL) || r; + r = ((glVertexAttribs1svNV = (PFNGLVERTEXATTRIBS1SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1svNV")) == NULL) || r; + r = ((glVertexAttribs2dvNV = (PFNGLVERTEXATTRIBS2DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2dvNV")) == NULL) || r; + r = ((glVertexAttribs2fvNV = (PFNGLVERTEXATTRIBS2FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2fvNV")) == NULL) || r; + r = ((glVertexAttribs2svNV = (PFNGLVERTEXATTRIBS2SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2svNV")) == NULL) || r; + r = ((glVertexAttribs3dvNV = (PFNGLVERTEXATTRIBS3DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3dvNV")) == NULL) || r; + r = ((glVertexAttribs3fvNV = (PFNGLVERTEXATTRIBS3FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3fvNV")) == NULL) || r; + r = ((glVertexAttribs3svNV = (PFNGLVERTEXATTRIBS3SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3svNV")) == NULL) || r; + r = ((glVertexAttribs4dvNV = (PFNGLVERTEXATTRIBS4DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4dvNV")) == NULL) || r; + r = ((glVertexAttribs4fvNV = (PFNGLVERTEXATTRIBS4FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4fvNV")) == NULL) || r; + r = ((glVertexAttribs4svNV = (PFNGLVERTEXATTRIBS4SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4svNV")) == NULL) || r; + r = ((glVertexAttribs4ubvNV = (PFNGLVERTEXATTRIBS4UBVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4ubvNV")) == NULL) || r; + + return r; +} + +#endif /* GL_NV_vertex_program */ + +#ifdef GL_NV_vertex_program1_1 + +#endif /* GL_NV_vertex_program1_1 */ + +#ifdef GL_NV_vertex_program2 + +#endif /* GL_NV_vertex_program2 */ + +#ifdef GL_NV_vertex_program2_option + +#endif /* GL_NV_vertex_program2_option */ + +#ifdef GL_NV_vertex_program3 + +#endif /* GL_NV_vertex_program3 */ + +#ifdef GL_NV_vertex_program4 + +#endif /* GL_NV_vertex_program4 */ + +#ifdef GL_OES_byte_coordinates + +#endif /* GL_OES_byte_coordinates */ + +#ifdef GL_OES_compressed_paletted_texture + +#endif /* GL_OES_compressed_paletted_texture */ + +#ifdef GL_OES_read_format + +#endif /* GL_OES_read_format */ + +#ifdef GL_OES_single_precision + +static GLboolean _glewInit_GL_OES_single_precision (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glClearDepthfOES = (PFNGLCLEARDEPTHFOESPROC)glewGetProcAddress((const GLubyte*)"glClearDepthfOES")) == NULL) || r; + r = ((glClipPlanefOES = (PFNGLCLIPPLANEFOESPROC)glewGetProcAddress((const GLubyte*)"glClipPlanefOES")) == NULL) || r; + r = ((glDepthRangefOES = (PFNGLDEPTHRANGEFOESPROC)glewGetProcAddress((const GLubyte*)"glDepthRangefOES")) == NULL) || r; + r = ((glFrustumfOES = (PFNGLFRUSTUMFOESPROC)glewGetProcAddress((const GLubyte*)"glFrustumfOES")) == NULL) || r; + r = ((glGetClipPlanefOES = (PFNGLGETCLIPPLANEFOESPROC)glewGetProcAddress((const GLubyte*)"glGetClipPlanefOES")) == NULL) || r; + r = ((glOrthofOES = (PFNGLORTHOFOESPROC)glewGetProcAddress((const GLubyte*)"glOrthofOES")) == NULL) || r; + + return r; +} + +#endif /* GL_OES_single_precision */ + +#ifdef GL_OML_interlace + +#endif /* GL_OML_interlace */ + +#ifdef GL_OML_resample + +#endif /* GL_OML_resample */ + +#ifdef GL_OML_subsample + +#endif /* GL_OML_subsample */ + +#ifdef GL_PGI_misc_hints + +#endif /* GL_PGI_misc_hints */ + +#ifdef GL_PGI_vertex_hints + +#endif /* GL_PGI_vertex_hints */ + +#ifdef GL_REND_screen_coordinates + +#endif /* GL_REND_screen_coordinates */ + +#ifdef GL_S3_s3tc + +#endif /* GL_S3_s3tc */ + +#ifdef GL_SGIS_color_range + +#endif /* GL_SGIS_color_range */ + +#ifdef GL_SGIS_detail_texture + +static GLboolean _glewInit_GL_SGIS_detail_texture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glDetailTexFuncSGIS = (PFNGLDETAILTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glDetailTexFuncSGIS")) == NULL) || r; + r = ((glGetDetailTexFuncSGIS = (PFNGLGETDETAILTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetDetailTexFuncSGIS")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIS_detail_texture */ + +#ifdef GL_SGIS_fog_function + +static GLboolean _glewInit_GL_SGIS_fog_function (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFogFuncSGIS = (PFNGLFOGFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glFogFuncSGIS")) == NULL) || r; + r = ((glGetFogFuncSGIS = (PFNGLGETFOGFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetFogFuncSGIS")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIS_fog_function */ + +#ifdef GL_SGIS_generate_mipmap + +#endif /* GL_SGIS_generate_mipmap */ + +#ifdef GL_SGIS_multisample + +static GLboolean _glewInit_GL_SGIS_multisample (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glSampleMaskSGIS = (PFNGLSAMPLEMASKSGISPROC)glewGetProcAddress((const GLubyte*)"glSampleMaskSGIS")) == NULL) || r; + r = ((glSamplePatternSGIS = (PFNGLSAMPLEPATTERNSGISPROC)glewGetProcAddress((const GLubyte*)"glSamplePatternSGIS")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIS_multisample */ + +#ifdef GL_SGIS_pixel_texture + +#endif /* GL_SGIS_pixel_texture */ + +#ifdef GL_SGIS_point_line_texgen + +#endif /* GL_SGIS_point_line_texgen */ + +#ifdef GL_SGIS_sharpen_texture + +static GLboolean _glewInit_GL_SGIS_sharpen_texture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetSharpenTexFuncSGIS = (PFNGLGETSHARPENTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetSharpenTexFuncSGIS")) == NULL) || r; + r = ((glSharpenTexFuncSGIS = (PFNGLSHARPENTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glSharpenTexFuncSGIS")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIS_sharpen_texture */ + +#ifdef GL_SGIS_texture4D + +static GLboolean _glewInit_GL_SGIS_texture4D (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTexImage4DSGIS = (PFNGLTEXIMAGE4DSGISPROC)glewGetProcAddress((const GLubyte*)"glTexImage4DSGIS")) == NULL) || r; + r = ((glTexSubImage4DSGIS = (PFNGLTEXSUBIMAGE4DSGISPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage4DSGIS")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIS_texture4D */ + +#ifdef GL_SGIS_texture_border_clamp + +#endif /* GL_SGIS_texture_border_clamp */ + +#ifdef GL_SGIS_texture_edge_clamp + +#endif /* GL_SGIS_texture_edge_clamp */ + +#ifdef GL_SGIS_texture_filter4 + +static GLboolean _glewInit_GL_SGIS_texture_filter4 (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGetTexFilterFuncSGIS = (PFNGLGETTEXFILTERFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetTexFilterFuncSGIS")) == NULL) || r; + r = ((glTexFilterFuncSGIS = (PFNGLTEXFILTERFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glTexFilterFuncSGIS")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIS_texture_filter4 */ + +#ifdef GL_SGIS_texture_lod + +#endif /* GL_SGIS_texture_lod */ + +#ifdef GL_SGIS_texture_select + +#endif /* GL_SGIS_texture_select */ + +#ifdef GL_SGIX_async + +static GLboolean _glewInit_GL_SGIX_async (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glAsyncMarkerSGIX = (PFNGLASYNCMARKERSGIXPROC)glewGetProcAddress((const GLubyte*)"glAsyncMarkerSGIX")) == NULL) || r; + r = ((glDeleteAsyncMarkersSGIX = (PFNGLDELETEASYNCMARKERSSGIXPROC)glewGetProcAddress((const GLubyte*)"glDeleteAsyncMarkersSGIX")) == NULL) || r; + r = ((glFinishAsyncSGIX = (PFNGLFINISHASYNCSGIXPROC)glewGetProcAddress((const GLubyte*)"glFinishAsyncSGIX")) == NULL) || r; + r = ((glGenAsyncMarkersSGIX = (PFNGLGENASYNCMARKERSSGIXPROC)glewGetProcAddress((const GLubyte*)"glGenAsyncMarkersSGIX")) == NULL) || r; + r = ((glIsAsyncMarkerSGIX = (PFNGLISASYNCMARKERSGIXPROC)glewGetProcAddress((const GLubyte*)"glIsAsyncMarkerSGIX")) == NULL) || r; + r = ((glPollAsyncSGIX = (PFNGLPOLLASYNCSGIXPROC)glewGetProcAddress((const GLubyte*)"glPollAsyncSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_async */ + +#ifdef GL_SGIX_async_histogram + +#endif /* GL_SGIX_async_histogram */ + +#ifdef GL_SGIX_async_pixel + +#endif /* GL_SGIX_async_pixel */ + +#ifdef GL_SGIX_blend_alpha_minmax + +#endif /* GL_SGIX_blend_alpha_minmax */ + +#ifdef GL_SGIX_clipmap + +#endif /* GL_SGIX_clipmap */ + +#ifdef GL_SGIX_convolution_accuracy + +#endif /* GL_SGIX_convolution_accuracy */ + +#ifdef GL_SGIX_depth_texture + +#endif /* GL_SGIX_depth_texture */ + +#ifdef GL_SGIX_flush_raster + +static GLboolean _glewInit_GL_SGIX_flush_raster (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFlushRasterSGIX = (PFNGLFLUSHRASTERSGIXPROC)glewGetProcAddress((const GLubyte*)"glFlushRasterSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_flush_raster */ + +#ifdef GL_SGIX_fog_offset + +#endif /* GL_SGIX_fog_offset */ + +#ifdef GL_SGIX_fog_texture + +static GLboolean _glewInit_GL_SGIX_fog_texture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTextureFogSGIX = (PFNGLTEXTUREFOGSGIXPROC)glewGetProcAddress((const GLubyte*)"glTextureFogSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_fog_texture */ + +#ifdef GL_SGIX_fragment_specular_lighting + +static GLboolean _glewInit_GL_SGIX_fragment_specular_lighting (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFragmentColorMaterialSGIX = (PFNGLFRAGMENTCOLORMATERIALSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentColorMaterialSGIX")) == NULL) || r; + r = ((glFragmentLightModelfSGIX = (PFNGLFRAGMENTLIGHTMODELFSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfSGIX")) == NULL) || r; + r = ((glFragmentLightModelfvSGIX = (PFNGLFRAGMENTLIGHTMODELFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfvSGIX")) == NULL) || r; + r = ((glFragmentLightModeliSGIX = (PFNGLFRAGMENTLIGHTMODELISGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModeliSGIX")) == NULL) || r; + r = ((glFragmentLightModelivSGIX = (PFNGLFRAGMENTLIGHTMODELIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelivSGIX")) == NULL) || r; + r = ((glFragmentLightfSGIX = (PFNGLFRAGMENTLIGHTFSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfSGIX")) == NULL) || r; + r = ((glFragmentLightfvSGIX = (PFNGLFRAGMENTLIGHTFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfvSGIX")) == NULL) || r; + r = ((glFragmentLightiSGIX = (PFNGLFRAGMENTLIGHTISGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightiSGIX")) == NULL) || r; + r = ((glFragmentLightivSGIX = (PFNGLFRAGMENTLIGHTIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightivSGIX")) == NULL) || r; + r = ((glFragmentMaterialfSGIX = (PFNGLFRAGMENTMATERIALFSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfSGIX")) == NULL) || r; + r = ((glFragmentMaterialfvSGIX = (PFNGLFRAGMENTMATERIALFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfvSGIX")) == NULL) || r; + r = ((glFragmentMaterialiSGIX = (PFNGLFRAGMENTMATERIALISGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialiSGIX")) == NULL) || r; + r = ((glFragmentMaterialivSGIX = (PFNGLFRAGMENTMATERIALIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialivSGIX")) == NULL) || r; + r = ((glGetFragmentLightfvSGIX = (PFNGLGETFRAGMENTLIGHTFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightfvSGIX")) == NULL) || r; + r = ((glGetFragmentLightivSGIX = (PFNGLGETFRAGMENTLIGHTIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightivSGIX")) == NULL) || r; + r = ((glGetFragmentMaterialfvSGIX = (PFNGLGETFRAGMENTMATERIALFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialfvSGIX")) == NULL) || r; + r = ((glGetFragmentMaterialivSGIX = (PFNGLGETFRAGMENTMATERIALIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialivSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_fragment_specular_lighting */ + +#ifdef GL_SGIX_framezoom + +static GLboolean _glewInit_GL_SGIX_framezoom (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFrameZoomSGIX = (PFNGLFRAMEZOOMSGIXPROC)glewGetProcAddress((const GLubyte*)"glFrameZoomSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_framezoom */ + +#ifdef GL_SGIX_interlace + +#endif /* GL_SGIX_interlace */ + +#ifdef GL_SGIX_ir_instrument1 + +#endif /* GL_SGIX_ir_instrument1 */ + +#ifdef GL_SGIX_list_priority + +#endif /* GL_SGIX_list_priority */ + +#ifdef GL_SGIX_pixel_texture + +static GLboolean _glewInit_GL_SGIX_pixel_texture (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glPixelTexGenSGIX = (PFNGLPIXELTEXGENSGIXPROC)glewGetProcAddress((const GLubyte*)"glPixelTexGenSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_pixel_texture */ + +#ifdef GL_SGIX_pixel_texture_bits + +#endif /* GL_SGIX_pixel_texture_bits */ + +#ifdef GL_SGIX_reference_plane + +static GLboolean _glewInit_GL_SGIX_reference_plane (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glReferencePlaneSGIX = (PFNGLREFERENCEPLANESGIXPROC)glewGetProcAddress((const GLubyte*)"glReferencePlaneSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_reference_plane */ + +#ifdef GL_SGIX_resample + +#endif /* GL_SGIX_resample */ + +#ifdef GL_SGIX_shadow + +#endif /* GL_SGIX_shadow */ + +#ifdef GL_SGIX_shadow_ambient + +#endif /* GL_SGIX_shadow_ambient */ + +#ifdef GL_SGIX_sprite + +static GLboolean _glewInit_GL_SGIX_sprite (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glSpriteParameterfSGIX = (PFNGLSPRITEPARAMETERFSGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameterfSGIX")) == NULL) || r; + r = ((glSpriteParameterfvSGIX = (PFNGLSPRITEPARAMETERFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameterfvSGIX")) == NULL) || r; + r = ((glSpriteParameteriSGIX = (PFNGLSPRITEPARAMETERISGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameteriSGIX")) == NULL) || r; + r = ((glSpriteParameterivSGIX = (PFNGLSPRITEPARAMETERIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameterivSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_sprite */ + +#ifdef GL_SGIX_tag_sample_buffer + +static GLboolean _glewInit_GL_SGIX_tag_sample_buffer (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glTagSampleBufferSGIX = (PFNGLTAGSAMPLEBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glTagSampleBufferSGIX")) == NULL) || r; + + return r; +} + +#endif /* GL_SGIX_tag_sample_buffer */ + +#ifdef GL_SGIX_texture_add_env + +#endif /* GL_SGIX_texture_add_env */ + +#ifdef GL_SGIX_texture_coordinate_clamp + +#endif /* GL_SGIX_texture_coordinate_clamp */ + +#ifdef GL_SGIX_texture_lod_bias + +#endif /* GL_SGIX_texture_lod_bias */ + +#ifdef GL_SGIX_texture_multi_buffer + +#endif /* GL_SGIX_texture_multi_buffer */ + +#ifdef GL_SGIX_texture_range + +#endif /* GL_SGIX_texture_range */ + +#ifdef GL_SGIX_texture_scale_bias + +#endif /* GL_SGIX_texture_scale_bias */ + +#ifdef GL_SGIX_vertex_preclip + +#endif /* GL_SGIX_vertex_preclip */ + +#ifdef GL_SGIX_vertex_preclip_hint + +#endif /* GL_SGIX_vertex_preclip_hint */ + +#ifdef GL_SGIX_ycrcb + +#endif /* GL_SGIX_ycrcb */ + +#ifdef GL_SGI_color_matrix + +#endif /* GL_SGI_color_matrix */ + +#ifdef GL_SGI_color_table + +static GLboolean _glewInit_GL_SGI_color_table (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColorTableParameterfvSGI = (PFNGLCOLORTABLEPARAMETERFVSGIPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameterfvSGI")) == NULL) || r; + r = ((glColorTableParameterivSGI = (PFNGLCOLORTABLEPARAMETERIVSGIPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameterivSGI")) == NULL) || r; + r = ((glColorTableSGI = (PFNGLCOLORTABLESGIPROC)glewGetProcAddress((const GLubyte*)"glColorTableSGI")) == NULL) || r; + r = ((glCopyColorTableSGI = (PFNGLCOPYCOLORTABLESGIPROC)glewGetProcAddress((const GLubyte*)"glCopyColorTableSGI")) == NULL) || r; + r = ((glGetColorTableParameterfvSGI = (PFNGLGETCOLORTABLEPARAMETERFVSGIPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterfvSGI")) == NULL) || r; + r = ((glGetColorTableParameterivSGI = (PFNGLGETCOLORTABLEPARAMETERIVSGIPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterivSGI")) == NULL) || r; + r = ((glGetColorTableSGI = (PFNGLGETCOLORTABLESGIPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableSGI")) == NULL) || r; + + return r; +} + +#endif /* GL_SGI_color_table */ + +#ifdef GL_SGI_texture_color_table + +#endif /* GL_SGI_texture_color_table */ + +#ifdef GL_SUNX_constant_data + +static GLboolean _glewInit_GL_SUNX_constant_data (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glFinishTextureSUNX = (PFNGLFINISHTEXTURESUNXPROC)glewGetProcAddress((const GLubyte*)"glFinishTextureSUNX")) == NULL) || r; + + return r; +} + +#endif /* GL_SUNX_constant_data */ + +#ifdef GL_SUN_convolution_border_modes + +#endif /* GL_SUN_convolution_border_modes */ + +#ifdef GL_SUN_global_alpha + +static GLboolean _glewInit_GL_SUN_global_alpha (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glGlobalAlphaFactorbSUN = (PFNGLGLOBALALPHAFACTORBSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorbSUN")) == NULL) || r; + r = ((glGlobalAlphaFactordSUN = (PFNGLGLOBALALPHAFACTORDSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactordSUN")) == NULL) || r; + r = ((glGlobalAlphaFactorfSUN = (PFNGLGLOBALALPHAFACTORFSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorfSUN")) == NULL) || r; + r = ((glGlobalAlphaFactoriSUN = (PFNGLGLOBALALPHAFACTORISUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactoriSUN")) == NULL) || r; + r = ((glGlobalAlphaFactorsSUN = (PFNGLGLOBALALPHAFACTORSSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorsSUN")) == NULL) || r; + r = ((glGlobalAlphaFactorubSUN = (PFNGLGLOBALALPHAFACTORUBSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorubSUN")) == NULL) || r; + r = ((glGlobalAlphaFactoruiSUN = (PFNGLGLOBALALPHAFACTORUISUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactoruiSUN")) == NULL) || r; + r = ((glGlobalAlphaFactorusSUN = (PFNGLGLOBALALPHAFACTORUSSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorusSUN")) == NULL) || r; + + return r; +} + +#endif /* GL_SUN_global_alpha */ + +#ifdef GL_SUN_mesh_array + +#endif /* GL_SUN_mesh_array */ + +#ifdef GL_SUN_read_video_pixels + +static GLboolean _glewInit_GL_SUN_read_video_pixels (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glReadVideoPixelsSUN = (PFNGLREADVIDEOPIXELSSUNPROC)glewGetProcAddress((const GLubyte*)"glReadVideoPixelsSUN")) == NULL) || r; + + return r; +} + +#endif /* GL_SUN_read_video_pixels */ + +#ifdef GL_SUN_slice_accum + +#endif /* GL_SUN_slice_accum */ + +#ifdef GL_SUN_triangle_list + +static GLboolean _glewInit_GL_SUN_triangle_list (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glReplacementCodePointerSUN = (PFNGLREPLACEMENTCODEPOINTERSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodePointerSUN")) == NULL) || r; + r = ((glReplacementCodeubSUN = (PFNGLREPLACEMENTCODEUBSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeubSUN")) == NULL) || r; + r = ((glReplacementCodeubvSUN = (PFNGLREPLACEMENTCODEUBVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeubvSUN")) == NULL) || r; + r = ((glReplacementCodeuiSUN = (PFNGLREPLACEMENTCODEUISUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiSUN")) == NULL) || r; + r = ((glReplacementCodeuivSUN = (PFNGLREPLACEMENTCODEUIVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuivSUN")) == NULL) || r; + r = ((glReplacementCodeusSUN = (PFNGLREPLACEMENTCODEUSSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeusSUN")) == NULL) || r; + r = ((glReplacementCodeusvSUN = (PFNGLREPLACEMENTCODEUSVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeusvSUN")) == NULL) || r; + + return r; +} + +#endif /* GL_SUN_triangle_list */ + +#ifdef GL_SUN_vertex + +static GLboolean _glewInit_GL_SUN_vertex (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glColor3fVertex3fSUN = (PFNGLCOLOR3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor3fVertex3fSUN")) == NULL) || r; + r = ((glColor3fVertex3fvSUN = (PFNGLCOLOR3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor3fVertex3fvSUN")) == NULL) || r; + r = ((glColor4fNormal3fVertex3fSUN = (PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4fNormal3fVertex3fSUN")) == NULL) || r; + r = ((glColor4fNormal3fVertex3fvSUN = (PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4fNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glColor4ubVertex2fSUN = (PFNGLCOLOR4UBVERTEX2FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex2fSUN")) == NULL) || r; + r = ((glColor4ubVertex2fvSUN = (PFNGLCOLOR4UBVERTEX2FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex2fvSUN")) == NULL) || r; + r = ((glColor4ubVertex3fSUN = (PFNGLCOLOR4UBVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex3fSUN")) == NULL) || r; + r = ((glColor4ubVertex3fvSUN = (PFNGLCOLOR4UBVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex3fvSUN")) == NULL) || r; + r = ((glNormal3fVertex3fSUN = (PFNGLNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glNormal3fVertex3fSUN")) == NULL) || r; + r = ((glNormal3fVertex3fvSUN = (PFNGLNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiColor3fVertex3fSUN = (PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor3fVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiColor3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor3fVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiColor4fNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4fNormal3fVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiColor4fNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4fNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiColor4ubVertex3fSUN = (PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4ubVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiColor4ubVertex3fvSUN = (PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4ubVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiNormal3fVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiTexCoord2fVertex3fSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiTexCoord2fVertex3fvSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fVertex3fvSUN")) == NULL) || r; + r = ((glReplacementCodeuiVertex3fSUN = (PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiVertex3fSUN")) == NULL) || r; + r = ((glReplacementCodeuiVertex3fvSUN = (PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiVertex3fvSUN")) == NULL) || r; + r = ((glTexCoord2fColor3fVertex3fSUN = (PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor3fVertex3fSUN")) == NULL) || r; + r = ((glTexCoord2fColor3fVertex3fvSUN = (PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor3fVertex3fvSUN")) == NULL) || r; + r = ((glTexCoord2fColor4fNormal3fVertex3fSUN = (PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4fNormal3fVertex3fSUN")) == NULL) || r; + r = ((glTexCoord2fColor4fNormal3fVertex3fvSUN = (PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4fNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glTexCoord2fColor4ubVertex3fSUN = (PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4ubVertex3fSUN")) == NULL) || r; + r = ((glTexCoord2fColor4ubVertex3fvSUN = (PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4ubVertex3fvSUN")) == NULL) || r; + r = ((glTexCoord2fNormal3fVertex3fSUN = (PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fNormal3fVertex3fSUN")) == NULL) || r; + r = ((glTexCoord2fNormal3fVertex3fvSUN = (PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fNormal3fVertex3fvSUN")) == NULL) || r; + r = ((glTexCoord2fVertex3fSUN = (PFNGLTEXCOORD2FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fVertex3fSUN")) == NULL) || r; + r = ((glTexCoord2fVertex3fvSUN = (PFNGLTEXCOORD2FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fVertex3fvSUN")) == NULL) || r; + r = ((glTexCoord4fColor4fNormal3fVertex4fSUN = (PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fColor4fNormal3fVertex4fSUN")) == NULL) || r; + r = ((glTexCoord4fColor4fNormal3fVertex4fvSUN = (PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fColor4fNormal3fVertex4fvSUN")) == NULL) || r; + r = ((glTexCoord4fVertex4fSUN = (PFNGLTEXCOORD4FVERTEX4FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fVertex4fSUN")) == NULL) || r; + r = ((glTexCoord4fVertex4fvSUN = (PFNGLTEXCOORD4FVERTEX4FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fVertex4fvSUN")) == NULL) || r; + + return r; +} + +#endif /* GL_SUN_vertex */ + +#ifdef GL_WIN_phong_shading + +#endif /* GL_WIN_phong_shading */ + +#ifdef GL_WIN_specular_fog + +#endif /* GL_WIN_specular_fog */ + +#ifdef GL_WIN_swap_hint + +static GLboolean _glewInit_GL_WIN_swap_hint (GLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glAddSwapHintRectWIN = (PFNGLADDSWAPHINTRECTWINPROC)glewGetProcAddress((const GLubyte*)"glAddSwapHintRectWIN")) == NULL) || r; + + return r; +} + +#endif /* GL_WIN_swap_hint */ + +/* ------------------------------------------------------------------------- */ + +/* + * Search for name in the extensions string. Use of strstr() + * is not sufficient because extension names can be prefixes of + * other extension names. Could use strtok() but the constant + * string returned by glGetString might be in read-only memory. + */ +GLboolean glewGetExtension (const char* name) +{ + GLubyte* p; + GLubyte* end; + GLuint len = _glewStrLen((const GLubyte*)name); + p = (GLubyte*)glGetString(GL_EXTENSIONS); + if (0 == p) return GL_FALSE; + end = p + _glewStrLen(p); + while (p < end) + { + GLuint n = _glewStrCLen(p, ' '); + if (len == n && _glewStrSame((const GLubyte*)name, p, n)) return GL_TRUE; + p += n+1; + } + return GL_FALSE; +} + +/* ------------------------------------------------------------------------- */ + +#ifndef GLEW_MX +static +#endif +GLenum glewContextInit (GLEW_CONTEXT_ARG_DEF_LIST) +{ + const GLubyte* s; + GLuint dot; + GLint major, minor; + /* query opengl version */ + s = glGetString(GL_VERSION); + dot = _glewStrCLen(s, '.'); + if (dot == 0) + return GLEW_ERROR_NO_GL_VERSION; + + major = s[dot-1]-'0'; + minor = s[dot+1]-'0'; + + if (minor < 0 || minor > 9) + minor = 0; + if (major<0 || major>9) + return GLEW_ERROR_NO_GL_VERSION; + + + if (major == 1 && minor == 0) + { + return GLEW_ERROR_GL_VERSION_10_ONLY; + } + else + { + CONST_CAST(GLEW_VERSION_4_0) = ( major > 4 ) || ( major == 4 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_3) = GLEW_VERSION_4_0 == GL_TRUE || ( major == 3 && minor >= 3 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_2) = GLEW_VERSION_3_3 == GL_TRUE || ( major == 3 && minor >= 2 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_1) = GLEW_VERSION_3_2 == GL_TRUE || ( major == 3 && minor >= 1 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_3_0) = GLEW_VERSION_3_1 == GL_TRUE || ( major == 3 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_2_1) = GLEW_VERSION_3_0 == GL_TRUE || ( major == 2 && minor >= 1 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_2_0) = GLEW_VERSION_2_1 == GL_TRUE || ( major == 2 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_5) = GLEW_VERSION_2_0 == GL_TRUE || ( major == 1 && minor >= 5 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_4) = GLEW_VERSION_1_5 == GL_TRUE || ( major == 1 && minor >= 4 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_3) = GLEW_VERSION_1_4 == GL_TRUE || ( major == 1 && minor >= 3 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_2) = GLEW_VERSION_1_3 == GL_TRUE || ( major == 1 && minor >= 2 ) ? GL_TRUE : GL_FALSE; + CONST_CAST(GLEW_VERSION_1_1) = GLEW_VERSION_1_2 == GL_TRUE || ( major == 1 && minor >= 1 ) ? GL_TRUE : GL_FALSE; + } + /* initialize extensions */ +#ifdef GL_VERSION_1_2 + if (glewExperimental || GLEW_VERSION_1_2) CONST_CAST(GLEW_VERSION_1_2) = !_glewInit_GL_VERSION_1_2(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_1_2 */ +#ifdef GL_VERSION_1_3 + if (glewExperimental || GLEW_VERSION_1_3) CONST_CAST(GLEW_VERSION_1_3) = !_glewInit_GL_VERSION_1_3(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_1_3 */ +#ifdef GL_VERSION_1_4 + if (glewExperimental || GLEW_VERSION_1_4) CONST_CAST(GLEW_VERSION_1_4) = !_glewInit_GL_VERSION_1_4(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_1_4 */ +#ifdef GL_VERSION_1_5 + if (glewExperimental || GLEW_VERSION_1_5) CONST_CAST(GLEW_VERSION_1_5) = !_glewInit_GL_VERSION_1_5(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_1_5 */ +#ifdef GL_VERSION_2_0 + if (glewExperimental || GLEW_VERSION_2_0) CONST_CAST(GLEW_VERSION_2_0) = !_glewInit_GL_VERSION_2_0(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_2_0 */ +#ifdef GL_VERSION_2_1 + if (glewExperimental || GLEW_VERSION_2_1) CONST_CAST(GLEW_VERSION_2_1) = !_glewInit_GL_VERSION_2_1(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_2_1 */ +#ifdef GL_VERSION_3_0 + if (glewExperimental || GLEW_VERSION_3_0) CONST_CAST(GLEW_VERSION_3_0) = !_glewInit_GL_VERSION_3_0(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_3_0 */ +#ifdef GL_VERSION_3_1 + if (glewExperimental || GLEW_VERSION_3_1) CONST_CAST(GLEW_VERSION_3_1) = !_glewInit_GL_VERSION_3_1(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_3_1 */ +#ifdef GL_VERSION_3_2 + if (glewExperimental || GLEW_VERSION_3_2) CONST_CAST(GLEW_VERSION_3_2) = !_glewInit_GL_VERSION_3_2(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_3_2 */ +#ifdef GL_VERSION_3_3 +#endif /* GL_VERSION_3_3 */ +#ifdef GL_VERSION_4_0 + if (glewExperimental || GLEW_VERSION_4_0) CONST_CAST(GLEW_VERSION_4_0) = !_glewInit_GL_VERSION_4_0(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_VERSION_4_0 */ +#ifdef GL_3DFX_multisample + CONST_CAST(GLEW_3DFX_multisample) = glewGetExtension("GL_3DFX_multisample"); +#endif /* GL_3DFX_multisample */ +#ifdef GL_3DFX_tbuffer + CONST_CAST(GLEW_3DFX_tbuffer) = glewGetExtension("GL_3DFX_tbuffer"); + if (glewExperimental || GLEW_3DFX_tbuffer) CONST_CAST(GLEW_3DFX_tbuffer) = !_glewInit_GL_3DFX_tbuffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_3DFX_tbuffer */ +#ifdef GL_3DFX_texture_compression_FXT1 + CONST_CAST(GLEW_3DFX_texture_compression_FXT1) = glewGetExtension("GL_3DFX_texture_compression_FXT1"); +#endif /* GL_3DFX_texture_compression_FXT1 */ +#ifdef GL_AMD_conservative_depth + CONST_CAST(GLEW_AMD_conservative_depth) = glewGetExtension("GL_AMD_conservative_depth"); +#endif /* GL_AMD_conservative_depth */ +#ifdef GL_AMD_draw_buffers_blend + CONST_CAST(GLEW_AMD_draw_buffers_blend) = glewGetExtension("GL_AMD_draw_buffers_blend"); + if (glewExperimental || GLEW_AMD_draw_buffers_blend) CONST_CAST(GLEW_AMD_draw_buffers_blend) = !_glewInit_GL_AMD_draw_buffers_blend(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_AMD_draw_buffers_blend */ +#ifdef GL_AMD_performance_monitor + CONST_CAST(GLEW_AMD_performance_monitor) = glewGetExtension("GL_AMD_performance_monitor"); + if (glewExperimental || GLEW_AMD_performance_monitor) CONST_CAST(GLEW_AMD_performance_monitor) = !_glewInit_GL_AMD_performance_monitor(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_AMD_performance_monitor */ +#ifdef GL_AMD_seamless_cubemap_per_texture + CONST_CAST(GLEW_AMD_seamless_cubemap_per_texture) = glewGetExtension("GL_AMD_seamless_cubemap_per_texture"); +#endif /* GL_AMD_seamless_cubemap_per_texture */ +#ifdef GL_AMD_shader_stencil_export + CONST_CAST(GLEW_AMD_shader_stencil_export) = glewGetExtension("GL_AMD_shader_stencil_export"); +#endif /* GL_AMD_shader_stencil_export */ +#ifdef GL_AMD_texture_texture4 + CONST_CAST(GLEW_AMD_texture_texture4) = glewGetExtension("GL_AMD_texture_texture4"); +#endif /* GL_AMD_texture_texture4 */ +#ifdef GL_AMD_vertex_shader_tessellator + CONST_CAST(GLEW_AMD_vertex_shader_tessellator) = glewGetExtension("GL_AMD_vertex_shader_tessellator"); + if (glewExperimental || GLEW_AMD_vertex_shader_tessellator) CONST_CAST(GLEW_AMD_vertex_shader_tessellator) = !_glewInit_GL_AMD_vertex_shader_tessellator(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_AMD_vertex_shader_tessellator */ +#ifdef GL_APPLE_aux_depth_stencil + CONST_CAST(GLEW_APPLE_aux_depth_stencil) = glewGetExtension("GL_APPLE_aux_depth_stencil"); +#endif /* GL_APPLE_aux_depth_stencil */ +#ifdef GL_APPLE_client_storage + CONST_CAST(GLEW_APPLE_client_storage) = glewGetExtension("GL_APPLE_client_storage"); +#endif /* GL_APPLE_client_storage */ +#ifdef GL_APPLE_element_array + CONST_CAST(GLEW_APPLE_element_array) = glewGetExtension("GL_APPLE_element_array"); + if (glewExperimental || GLEW_APPLE_element_array) CONST_CAST(GLEW_APPLE_element_array) = !_glewInit_GL_APPLE_element_array(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_element_array */ +#ifdef GL_APPLE_fence + CONST_CAST(GLEW_APPLE_fence) = glewGetExtension("GL_APPLE_fence"); + if (glewExperimental || GLEW_APPLE_fence) CONST_CAST(GLEW_APPLE_fence) = !_glewInit_GL_APPLE_fence(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_fence */ +#ifdef GL_APPLE_float_pixels + CONST_CAST(GLEW_APPLE_float_pixels) = glewGetExtension("GL_APPLE_float_pixels"); +#endif /* GL_APPLE_float_pixels */ +#ifdef GL_APPLE_flush_buffer_range + CONST_CAST(GLEW_APPLE_flush_buffer_range) = glewGetExtension("GL_APPLE_flush_buffer_range"); + if (glewExperimental || GLEW_APPLE_flush_buffer_range) CONST_CAST(GLEW_APPLE_flush_buffer_range) = !_glewInit_GL_APPLE_flush_buffer_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_flush_buffer_range */ +#ifdef GL_APPLE_object_purgeable + CONST_CAST(GLEW_APPLE_object_purgeable) = glewGetExtension("GL_APPLE_object_purgeable"); + if (glewExperimental || GLEW_APPLE_object_purgeable) CONST_CAST(GLEW_APPLE_object_purgeable) = !_glewInit_GL_APPLE_object_purgeable(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_object_purgeable */ +#ifdef GL_APPLE_pixel_buffer + CONST_CAST(GLEW_APPLE_pixel_buffer) = glewGetExtension("GL_APPLE_pixel_buffer"); +#endif /* GL_APPLE_pixel_buffer */ +#ifdef GL_APPLE_rgb_422 + CONST_CAST(GLEW_APPLE_rgb_422) = glewGetExtension("GL_APPLE_rgb_422"); +#endif /* GL_APPLE_rgb_422 */ +#ifdef GL_APPLE_row_bytes + CONST_CAST(GLEW_APPLE_row_bytes) = glewGetExtension("GL_APPLE_row_bytes"); +#endif /* GL_APPLE_row_bytes */ +#ifdef GL_APPLE_specular_vector + CONST_CAST(GLEW_APPLE_specular_vector) = glewGetExtension("GL_APPLE_specular_vector"); +#endif /* GL_APPLE_specular_vector */ +#ifdef GL_APPLE_texture_range + CONST_CAST(GLEW_APPLE_texture_range) = glewGetExtension("GL_APPLE_texture_range"); + if (glewExperimental || GLEW_APPLE_texture_range) CONST_CAST(GLEW_APPLE_texture_range) = !_glewInit_GL_APPLE_texture_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_texture_range */ +#ifdef GL_APPLE_transform_hint + CONST_CAST(GLEW_APPLE_transform_hint) = glewGetExtension("GL_APPLE_transform_hint"); +#endif /* GL_APPLE_transform_hint */ +#ifdef GL_APPLE_vertex_array_object + CONST_CAST(GLEW_APPLE_vertex_array_object) = glewGetExtension("GL_APPLE_vertex_array_object"); + if (glewExperimental || GLEW_APPLE_vertex_array_object) CONST_CAST(GLEW_APPLE_vertex_array_object) = !_glewInit_GL_APPLE_vertex_array_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_vertex_array_object */ +#ifdef GL_APPLE_vertex_array_range + CONST_CAST(GLEW_APPLE_vertex_array_range) = glewGetExtension("GL_APPLE_vertex_array_range"); + if (glewExperimental || GLEW_APPLE_vertex_array_range) CONST_CAST(GLEW_APPLE_vertex_array_range) = !_glewInit_GL_APPLE_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_vertex_array_range */ +#ifdef GL_APPLE_vertex_program_evaluators + CONST_CAST(GLEW_APPLE_vertex_program_evaluators) = glewGetExtension("GL_APPLE_vertex_program_evaluators"); + if (glewExperimental || GLEW_APPLE_vertex_program_evaluators) CONST_CAST(GLEW_APPLE_vertex_program_evaluators) = !_glewInit_GL_APPLE_vertex_program_evaluators(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_APPLE_vertex_program_evaluators */ +#ifdef GL_APPLE_ycbcr_422 + CONST_CAST(GLEW_APPLE_ycbcr_422) = glewGetExtension("GL_APPLE_ycbcr_422"); +#endif /* GL_APPLE_ycbcr_422 */ +#ifdef GL_ARB_blend_func_extended + CONST_CAST(GLEW_ARB_blend_func_extended) = glewGetExtension("GL_ARB_blend_func_extended"); + if (glewExperimental || GLEW_ARB_blend_func_extended) CONST_CAST(GLEW_ARB_blend_func_extended) = !_glewInit_GL_ARB_blend_func_extended(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_blend_func_extended */ +#ifdef GL_ARB_color_buffer_float + CONST_CAST(GLEW_ARB_color_buffer_float) = glewGetExtension("GL_ARB_color_buffer_float"); + if (glewExperimental || GLEW_ARB_color_buffer_float) CONST_CAST(GLEW_ARB_color_buffer_float) = !_glewInit_GL_ARB_color_buffer_float(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_color_buffer_float */ +#ifdef GL_ARB_compatibility + CONST_CAST(GLEW_ARB_compatibility) = glewGetExtension("GL_ARB_compatibility"); +#endif /* GL_ARB_compatibility */ +#ifdef GL_ARB_copy_buffer + CONST_CAST(GLEW_ARB_copy_buffer) = glewGetExtension("GL_ARB_copy_buffer"); + if (glewExperimental || GLEW_ARB_copy_buffer) CONST_CAST(GLEW_ARB_copy_buffer) = !_glewInit_GL_ARB_copy_buffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_copy_buffer */ +#ifdef GL_ARB_depth_buffer_float + CONST_CAST(GLEW_ARB_depth_buffer_float) = glewGetExtension("GL_ARB_depth_buffer_float"); +#endif /* GL_ARB_depth_buffer_float */ +#ifdef GL_ARB_depth_clamp + CONST_CAST(GLEW_ARB_depth_clamp) = glewGetExtension("GL_ARB_depth_clamp"); +#endif /* GL_ARB_depth_clamp */ +#ifdef GL_ARB_depth_texture + CONST_CAST(GLEW_ARB_depth_texture) = glewGetExtension("GL_ARB_depth_texture"); +#endif /* GL_ARB_depth_texture */ +#ifdef GL_ARB_draw_buffers + CONST_CAST(GLEW_ARB_draw_buffers) = glewGetExtension("GL_ARB_draw_buffers"); + if (glewExperimental || GLEW_ARB_draw_buffers) CONST_CAST(GLEW_ARB_draw_buffers) = !_glewInit_GL_ARB_draw_buffers(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_draw_buffers */ +#ifdef GL_ARB_draw_buffers_blend + CONST_CAST(GLEW_ARB_draw_buffers_blend) = glewGetExtension("GL_ARB_draw_buffers_blend"); + if (glewExperimental || GLEW_ARB_draw_buffers_blend) CONST_CAST(GLEW_ARB_draw_buffers_blend) = !_glewInit_GL_ARB_draw_buffers_blend(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_draw_buffers_blend */ +#ifdef GL_ARB_draw_elements_base_vertex + CONST_CAST(GLEW_ARB_draw_elements_base_vertex) = glewGetExtension("GL_ARB_draw_elements_base_vertex"); + if (glewExperimental || GLEW_ARB_draw_elements_base_vertex) CONST_CAST(GLEW_ARB_draw_elements_base_vertex) = !_glewInit_GL_ARB_draw_elements_base_vertex(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_draw_elements_base_vertex */ +#ifdef GL_ARB_draw_indirect + CONST_CAST(GLEW_ARB_draw_indirect) = glewGetExtension("GL_ARB_draw_indirect"); + if (glewExperimental || GLEW_ARB_draw_indirect) CONST_CAST(GLEW_ARB_draw_indirect) = !_glewInit_GL_ARB_draw_indirect(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_draw_indirect */ +#ifdef GL_ARB_draw_instanced + CONST_CAST(GLEW_ARB_draw_instanced) = glewGetExtension("GL_ARB_draw_instanced"); + if (glewExperimental || GLEW_ARB_draw_instanced) CONST_CAST(GLEW_ARB_draw_instanced) = !_glewInit_GL_ARB_draw_instanced(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_draw_instanced */ +#ifdef GL_ARB_explicit_attrib_location + CONST_CAST(GLEW_ARB_explicit_attrib_location) = glewGetExtension("GL_ARB_explicit_attrib_location"); +#endif /* GL_ARB_explicit_attrib_location */ +#ifdef GL_ARB_fragment_coord_conventions + CONST_CAST(GLEW_ARB_fragment_coord_conventions) = glewGetExtension("GL_ARB_fragment_coord_conventions"); +#endif /* GL_ARB_fragment_coord_conventions */ +#ifdef GL_ARB_fragment_program + CONST_CAST(GLEW_ARB_fragment_program) = glewGetExtension("GL_ARB_fragment_program"); +#endif /* GL_ARB_fragment_program */ +#ifdef GL_ARB_fragment_program_shadow + CONST_CAST(GLEW_ARB_fragment_program_shadow) = glewGetExtension("GL_ARB_fragment_program_shadow"); +#endif /* GL_ARB_fragment_program_shadow */ +#ifdef GL_ARB_fragment_shader + CONST_CAST(GLEW_ARB_fragment_shader) = glewGetExtension("GL_ARB_fragment_shader"); +#endif /* GL_ARB_fragment_shader */ +#ifdef GL_ARB_framebuffer_object + CONST_CAST(GLEW_ARB_framebuffer_object) = glewGetExtension("GL_ARB_framebuffer_object"); + if (glewExperimental || GLEW_ARB_framebuffer_object) CONST_CAST(GLEW_ARB_framebuffer_object) = !_glewInit_GL_ARB_framebuffer_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_framebuffer_object */ +#ifdef GL_ARB_framebuffer_sRGB + CONST_CAST(GLEW_ARB_framebuffer_sRGB) = glewGetExtension("GL_ARB_framebuffer_sRGB"); +#endif /* GL_ARB_framebuffer_sRGB */ +#ifdef GL_ARB_geometry_shader4 + CONST_CAST(GLEW_ARB_geometry_shader4) = glewGetExtension("GL_ARB_geometry_shader4"); + if (glewExperimental || GLEW_ARB_geometry_shader4) CONST_CAST(GLEW_ARB_geometry_shader4) = !_glewInit_GL_ARB_geometry_shader4(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_geometry_shader4 */ +#ifdef GL_ARB_gpu_shader5 + CONST_CAST(GLEW_ARB_gpu_shader5) = glewGetExtension("GL_ARB_gpu_shader5"); +#endif /* GL_ARB_gpu_shader5 */ +#ifdef GL_ARB_gpu_shader_fp64 + CONST_CAST(GLEW_ARB_gpu_shader_fp64) = glewGetExtension("GL_ARB_gpu_shader_fp64"); +#endif /* GL_ARB_gpu_shader_fp64 */ +#ifdef GL_ARB_half_float_pixel + CONST_CAST(GLEW_ARB_half_float_pixel) = glewGetExtension("GL_ARB_half_float_pixel"); +#endif /* GL_ARB_half_float_pixel */ +#ifdef GL_ARB_half_float_vertex + CONST_CAST(GLEW_ARB_half_float_vertex) = glewGetExtension("GL_ARB_half_float_vertex"); +#endif /* GL_ARB_half_float_vertex */ +#ifdef GL_ARB_imaging + CONST_CAST(GLEW_ARB_imaging) = glewGetExtension("GL_ARB_imaging"); + if (glewExperimental || GLEW_ARB_imaging) CONST_CAST(GLEW_ARB_imaging) = !_glewInit_GL_ARB_imaging(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_imaging */ +#ifdef GL_ARB_instanced_arrays + CONST_CAST(GLEW_ARB_instanced_arrays) = glewGetExtension("GL_ARB_instanced_arrays"); + if (glewExperimental || GLEW_ARB_instanced_arrays) CONST_CAST(GLEW_ARB_instanced_arrays) = !_glewInit_GL_ARB_instanced_arrays(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_instanced_arrays */ +#ifdef GL_ARB_map_buffer_range + CONST_CAST(GLEW_ARB_map_buffer_range) = glewGetExtension("GL_ARB_map_buffer_range"); + if (glewExperimental || GLEW_ARB_map_buffer_range) CONST_CAST(GLEW_ARB_map_buffer_range) = !_glewInit_GL_ARB_map_buffer_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_map_buffer_range */ +#ifdef GL_ARB_matrix_palette + CONST_CAST(GLEW_ARB_matrix_palette) = glewGetExtension("GL_ARB_matrix_palette"); + if (glewExperimental || GLEW_ARB_matrix_palette) CONST_CAST(GLEW_ARB_matrix_palette) = !_glewInit_GL_ARB_matrix_palette(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_matrix_palette */ +#ifdef GL_ARB_multisample + CONST_CAST(GLEW_ARB_multisample) = glewGetExtension("GL_ARB_multisample"); + if (glewExperimental || GLEW_ARB_multisample) CONST_CAST(GLEW_ARB_multisample) = !_glewInit_GL_ARB_multisample(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_multisample */ +#ifdef GL_ARB_multitexture + CONST_CAST(GLEW_ARB_multitexture) = glewGetExtension("GL_ARB_multitexture"); + if (glewExperimental || GLEW_ARB_multitexture) CONST_CAST(GLEW_ARB_multitexture) = !_glewInit_GL_ARB_multitexture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_multitexture */ +#ifdef GL_ARB_occlusion_query + CONST_CAST(GLEW_ARB_occlusion_query) = glewGetExtension("GL_ARB_occlusion_query"); + if (glewExperimental || GLEW_ARB_occlusion_query) CONST_CAST(GLEW_ARB_occlusion_query) = !_glewInit_GL_ARB_occlusion_query(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_occlusion_query */ +#ifdef GL_ARB_occlusion_query2 + CONST_CAST(GLEW_ARB_occlusion_query2) = glewGetExtension("GL_ARB_occlusion_query2"); +#endif /* GL_ARB_occlusion_query2 */ +#ifdef GL_ARB_pixel_buffer_object + CONST_CAST(GLEW_ARB_pixel_buffer_object) = glewGetExtension("GL_ARB_pixel_buffer_object"); +#endif /* GL_ARB_pixel_buffer_object */ +#ifdef GL_ARB_point_parameters + CONST_CAST(GLEW_ARB_point_parameters) = glewGetExtension("GL_ARB_point_parameters"); + if (glewExperimental || GLEW_ARB_point_parameters) CONST_CAST(GLEW_ARB_point_parameters) = !_glewInit_GL_ARB_point_parameters(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_point_parameters */ +#ifdef GL_ARB_point_sprite + CONST_CAST(GLEW_ARB_point_sprite) = glewGetExtension("GL_ARB_point_sprite"); +#endif /* GL_ARB_point_sprite */ +#ifdef GL_ARB_provoking_vertex + CONST_CAST(GLEW_ARB_provoking_vertex) = glewGetExtension("GL_ARB_provoking_vertex"); + if (glewExperimental || GLEW_ARB_provoking_vertex) CONST_CAST(GLEW_ARB_provoking_vertex) = !_glewInit_GL_ARB_provoking_vertex(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_provoking_vertex */ +#ifdef GL_ARB_sample_shading + CONST_CAST(GLEW_ARB_sample_shading) = glewGetExtension("GL_ARB_sample_shading"); + if (glewExperimental || GLEW_ARB_sample_shading) CONST_CAST(GLEW_ARB_sample_shading) = !_glewInit_GL_ARB_sample_shading(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_sample_shading */ +#ifdef GL_ARB_sampler_objects + CONST_CAST(GLEW_ARB_sampler_objects) = glewGetExtension("GL_ARB_sampler_objects"); + if (glewExperimental || GLEW_ARB_sampler_objects) CONST_CAST(GLEW_ARB_sampler_objects) = !_glewInit_GL_ARB_sampler_objects(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_sampler_objects */ +#ifdef GL_ARB_seamless_cube_map + CONST_CAST(GLEW_ARB_seamless_cube_map) = glewGetExtension("GL_ARB_seamless_cube_map"); +#endif /* GL_ARB_seamless_cube_map */ +#ifdef GL_ARB_shader_bit_encoding + CONST_CAST(GLEW_ARB_shader_bit_encoding) = glewGetExtension("GL_ARB_shader_bit_encoding"); +#endif /* GL_ARB_shader_bit_encoding */ +#ifdef GL_ARB_shader_objects + CONST_CAST(GLEW_ARB_shader_objects) = glewGetExtension("GL_ARB_shader_objects"); + if (glewExperimental || GLEW_ARB_shader_objects) CONST_CAST(GLEW_ARB_shader_objects) = !_glewInit_GL_ARB_shader_objects(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_shader_objects */ +#ifdef GL_ARB_shader_subroutine + CONST_CAST(GLEW_ARB_shader_subroutine) = glewGetExtension("GL_ARB_shader_subroutine"); + if (glewExperimental || GLEW_ARB_shader_subroutine) CONST_CAST(GLEW_ARB_shader_subroutine) = !_glewInit_GL_ARB_shader_subroutine(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_shader_subroutine */ +#ifdef GL_ARB_shader_texture_lod + CONST_CAST(GLEW_ARB_shader_texture_lod) = glewGetExtension("GL_ARB_shader_texture_lod"); +#endif /* GL_ARB_shader_texture_lod */ +#ifdef GL_ARB_shading_language_100 + CONST_CAST(GLEW_ARB_shading_language_100) = glewGetExtension("GL_ARB_shading_language_100"); +#endif /* GL_ARB_shading_language_100 */ +#ifdef GL_ARB_shading_language_include + CONST_CAST(GLEW_ARB_shading_language_include) = glewGetExtension("GL_ARB_shading_language_include"); + if (glewExperimental || GLEW_ARB_shading_language_include) CONST_CAST(GLEW_ARB_shading_language_include) = !_glewInit_GL_ARB_shading_language_include(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_shading_language_include */ +#ifdef GL_ARB_shadow + CONST_CAST(GLEW_ARB_shadow) = glewGetExtension("GL_ARB_shadow"); +#endif /* GL_ARB_shadow */ +#ifdef GL_ARB_shadow_ambient + CONST_CAST(GLEW_ARB_shadow_ambient) = glewGetExtension("GL_ARB_shadow_ambient"); +#endif /* GL_ARB_shadow_ambient */ +#ifdef GL_ARB_sync + CONST_CAST(GLEW_ARB_sync) = glewGetExtension("GL_ARB_sync"); + if (glewExperimental || GLEW_ARB_sync) CONST_CAST(GLEW_ARB_sync) = !_glewInit_GL_ARB_sync(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_sync */ +#ifdef GL_ARB_tessellation_shader + CONST_CAST(GLEW_ARB_tessellation_shader) = glewGetExtension("GL_ARB_tessellation_shader"); + if (glewExperimental || GLEW_ARB_tessellation_shader) CONST_CAST(GLEW_ARB_tessellation_shader) = !_glewInit_GL_ARB_tessellation_shader(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_tessellation_shader */ +#ifdef GL_ARB_texture_border_clamp + CONST_CAST(GLEW_ARB_texture_border_clamp) = glewGetExtension("GL_ARB_texture_border_clamp"); +#endif /* GL_ARB_texture_border_clamp */ +#ifdef GL_ARB_texture_buffer_object + CONST_CAST(GLEW_ARB_texture_buffer_object) = glewGetExtension("GL_ARB_texture_buffer_object"); + if (glewExperimental || GLEW_ARB_texture_buffer_object) CONST_CAST(GLEW_ARB_texture_buffer_object) = !_glewInit_GL_ARB_texture_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_texture_buffer_object */ +#ifdef GL_ARB_texture_buffer_object_rgb32 + CONST_CAST(GLEW_ARB_texture_buffer_object_rgb32) = glewGetExtension("GL_ARB_texture_buffer_object_rgb32"); +#endif /* GL_ARB_texture_buffer_object_rgb32 */ +#ifdef GL_ARB_texture_compression + CONST_CAST(GLEW_ARB_texture_compression) = glewGetExtension("GL_ARB_texture_compression"); + if (glewExperimental || GLEW_ARB_texture_compression) CONST_CAST(GLEW_ARB_texture_compression) = !_glewInit_GL_ARB_texture_compression(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_texture_compression */ +#ifdef GL_ARB_texture_compression_bptc + CONST_CAST(GLEW_ARB_texture_compression_bptc) = glewGetExtension("GL_ARB_texture_compression_bptc"); +#endif /* GL_ARB_texture_compression_bptc */ +#ifdef GL_ARB_texture_compression_rgtc + CONST_CAST(GLEW_ARB_texture_compression_rgtc) = glewGetExtension("GL_ARB_texture_compression_rgtc"); +#endif /* GL_ARB_texture_compression_rgtc */ +#ifdef GL_ARB_texture_cube_map + CONST_CAST(GLEW_ARB_texture_cube_map) = glewGetExtension("GL_ARB_texture_cube_map"); +#endif /* GL_ARB_texture_cube_map */ +#ifdef GL_ARB_texture_cube_map_array + CONST_CAST(GLEW_ARB_texture_cube_map_array) = glewGetExtension("GL_ARB_texture_cube_map_array"); +#endif /* GL_ARB_texture_cube_map_array */ +#ifdef GL_ARB_texture_env_add + CONST_CAST(GLEW_ARB_texture_env_add) = glewGetExtension("GL_ARB_texture_env_add"); +#endif /* GL_ARB_texture_env_add */ +#ifdef GL_ARB_texture_env_combine + CONST_CAST(GLEW_ARB_texture_env_combine) = glewGetExtension("GL_ARB_texture_env_combine"); +#endif /* GL_ARB_texture_env_combine */ +#ifdef GL_ARB_texture_env_crossbar + CONST_CAST(GLEW_ARB_texture_env_crossbar) = glewGetExtension("GL_ARB_texture_env_crossbar"); +#endif /* GL_ARB_texture_env_crossbar */ +#ifdef GL_ARB_texture_env_dot3 + CONST_CAST(GLEW_ARB_texture_env_dot3) = glewGetExtension("GL_ARB_texture_env_dot3"); +#endif /* GL_ARB_texture_env_dot3 */ +#ifdef GL_ARB_texture_float + CONST_CAST(GLEW_ARB_texture_float) = glewGetExtension("GL_ARB_texture_float"); +#endif /* GL_ARB_texture_float */ +#ifdef GL_ARB_texture_gather + CONST_CAST(GLEW_ARB_texture_gather) = glewGetExtension("GL_ARB_texture_gather"); +#endif /* GL_ARB_texture_gather */ +#ifdef GL_ARB_texture_mirrored_repeat + CONST_CAST(GLEW_ARB_texture_mirrored_repeat) = glewGetExtension("GL_ARB_texture_mirrored_repeat"); +#endif /* GL_ARB_texture_mirrored_repeat */ +#ifdef GL_ARB_texture_multisample + CONST_CAST(GLEW_ARB_texture_multisample) = glewGetExtension("GL_ARB_texture_multisample"); + if (glewExperimental || GLEW_ARB_texture_multisample) CONST_CAST(GLEW_ARB_texture_multisample) = !_glewInit_GL_ARB_texture_multisample(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_texture_multisample */ +#ifdef GL_ARB_texture_non_power_of_two + CONST_CAST(GLEW_ARB_texture_non_power_of_two) = glewGetExtension("GL_ARB_texture_non_power_of_two"); +#endif /* GL_ARB_texture_non_power_of_two */ +#ifdef GL_ARB_texture_query_lod + CONST_CAST(GLEW_ARB_texture_query_lod) = glewGetExtension("GL_ARB_texture_query_lod"); +#endif /* GL_ARB_texture_query_lod */ +#ifdef GL_ARB_texture_rectangle + CONST_CAST(GLEW_ARB_texture_rectangle) = glewGetExtension("GL_ARB_texture_rectangle"); +#endif /* GL_ARB_texture_rectangle */ +#ifdef GL_ARB_texture_rg + CONST_CAST(GLEW_ARB_texture_rg) = glewGetExtension("GL_ARB_texture_rg"); +#endif /* GL_ARB_texture_rg */ +#ifdef GL_ARB_texture_rgb10_a2ui + CONST_CAST(GLEW_ARB_texture_rgb10_a2ui) = glewGetExtension("GL_ARB_texture_rgb10_a2ui"); +#endif /* GL_ARB_texture_rgb10_a2ui */ +#ifdef GL_ARB_texture_swizzle + CONST_CAST(GLEW_ARB_texture_swizzle) = glewGetExtension("GL_ARB_texture_swizzle"); +#endif /* GL_ARB_texture_swizzle */ +#ifdef GL_ARB_timer_query + CONST_CAST(GLEW_ARB_timer_query) = glewGetExtension("GL_ARB_timer_query"); + if (glewExperimental || GLEW_ARB_timer_query) CONST_CAST(GLEW_ARB_timer_query) = !_glewInit_GL_ARB_timer_query(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_timer_query */ +#ifdef GL_ARB_transform_feedback2 + CONST_CAST(GLEW_ARB_transform_feedback2) = glewGetExtension("GL_ARB_transform_feedback2"); + if (glewExperimental || GLEW_ARB_transform_feedback2) CONST_CAST(GLEW_ARB_transform_feedback2) = !_glewInit_GL_ARB_transform_feedback2(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_transform_feedback2 */ +#ifdef GL_ARB_transform_feedback3 + CONST_CAST(GLEW_ARB_transform_feedback3) = glewGetExtension("GL_ARB_transform_feedback3"); + if (glewExperimental || GLEW_ARB_transform_feedback3) CONST_CAST(GLEW_ARB_transform_feedback3) = !_glewInit_GL_ARB_transform_feedback3(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_transform_feedback3 */ +#ifdef GL_ARB_transpose_matrix + CONST_CAST(GLEW_ARB_transpose_matrix) = glewGetExtension("GL_ARB_transpose_matrix"); + if (glewExperimental || GLEW_ARB_transpose_matrix) CONST_CAST(GLEW_ARB_transpose_matrix) = !_glewInit_GL_ARB_transpose_matrix(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_transpose_matrix */ +#ifdef GL_ARB_uniform_buffer_object + CONST_CAST(GLEW_ARB_uniform_buffer_object) = glewGetExtension("GL_ARB_uniform_buffer_object"); + if (glewExperimental || GLEW_ARB_uniform_buffer_object) CONST_CAST(GLEW_ARB_uniform_buffer_object) = !_glewInit_GL_ARB_uniform_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_uniform_buffer_object */ +#ifdef GL_ARB_vertex_array_bgra + CONST_CAST(GLEW_ARB_vertex_array_bgra) = glewGetExtension("GL_ARB_vertex_array_bgra"); +#endif /* GL_ARB_vertex_array_bgra */ +#ifdef GL_ARB_vertex_array_object + CONST_CAST(GLEW_ARB_vertex_array_object) = glewGetExtension("GL_ARB_vertex_array_object"); + if (glewExperimental || GLEW_ARB_vertex_array_object) CONST_CAST(GLEW_ARB_vertex_array_object) = !_glewInit_GL_ARB_vertex_array_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_vertex_array_object */ +#ifdef GL_ARB_vertex_blend + CONST_CAST(GLEW_ARB_vertex_blend) = glewGetExtension("GL_ARB_vertex_blend"); + if (glewExperimental || GLEW_ARB_vertex_blend) CONST_CAST(GLEW_ARB_vertex_blend) = !_glewInit_GL_ARB_vertex_blend(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_vertex_blend */ +#ifdef GL_ARB_vertex_buffer_object + CONST_CAST(GLEW_ARB_vertex_buffer_object) = glewGetExtension("GL_ARB_vertex_buffer_object"); + if (glewExperimental || GLEW_ARB_vertex_buffer_object) CONST_CAST(GLEW_ARB_vertex_buffer_object) = !_glewInit_GL_ARB_vertex_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_vertex_buffer_object */ +#ifdef GL_ARB_vertex_program + CONST_CAST(GLEW_ARB_vertex_program) = glewGetExtension("GL_ARB_vertex_program"); + if (glewExperimental || GLEW_ARB_vertex_program) CONST_CAST(GLEW_ARB_vertex_program) = !_glewInit_GL_ARB_vertex_program(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_vertex_program */ +#ifdef GL_ARB_vertex_shader + CONST_CAST(GLEW_ARB_vertex_shader) = glewGetExtension("GL_ARB_vertex_shader"); + if (glewExperimental || GLEW_ARB_vertex_shader) CONST_CAST(GLEW_ARB_vertex_shader) = !_glewInit_GL_ARB_vertex_shader(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_vertex_shader */ +#ifdef GL_ARB_vertex_type_2_10_10_10_rev + CONST_CAST(GLEW_ARB_vertex_type_2_10_10_10_rev) = glewGetExtension("GL_ARB_vertex_type_2_10_10_10_rev"); + if (glewExperimental || GLEW_ARB_vertex_type_2_10_10_10_rev) CONST_CAST(GLEW_ARB_vertex_type_2_10_10_10_rev) = !_glewInit_GL_ARB_vertex_type_2_10_10_10_rev(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ +#ifdef GL_ARB_window_pos + CONST_CAST(GLEW_ARB_window_pos) = glewGetExtension("GL_ARB_window_pos"); + if (glewExperimental || GLEW_ARB_window_pos) CONST_CAST(GLEW_ARB_window_pos) = !_glewInit_GL_ARB_window_pos(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ARB_window_pos */ +#ifdef GL_ATIX_point_sprites + CONST_CAST(GLEW_ATIX_point_sprites) = glewGetExtension("GL_ATIX_point_sprites"); +#endif /* GL_ATIX_point_sprites */ +#ifdef GL_ATIX_texture_env_combine3 + CONST_CAST(GLEW_ATIX_texture_env_combine3) = glewGetExtension("GL_ATIX_texture_env_combine3"); +#endif /* GL_ATIX_texture_env_combine3 */ +#ifdef GL_ATIX_texture_env_route + CONST_CAST(GLEW_ATIX_texture_env_route) = glewGetExtension("GL_ATIX_texture_env_route"); +#endif /* GL_ATIX_texture_env_route */ +#ifdef GL_ATIX_vertex_shader_output_point_size + CONST_CAST(GLEW_ATIX_vertex_shader_output_point_size) = glewGetExtension("GL_ATIX_vertex_shader_output_point_size"); +#endif /* GL_ATIX_vertex_shader_output_point_size */ +#ifdef GL_ATI_draw_buffers + CONST_CAST(GLEW_ATI_draw_buffers) = glewGetExtension("GL_ATI_draw_buffers"); + if (glewExperimental || GLEW_ATI_draw_buffers) CONST_CAST(GLEW_ATI_draw_buffers) = !_glewInit_GL_ATI_draw_buffers(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_draw_buffers */ +#ifdef GL_ATI_element_array + CONST_CAST(GLEW_ATI_element_array) = glewGetExtension("GL_ATI_element_array"); + if (glewExperimental || GLEW_ATI_element_array) CONST_CAST(GLEW_ATI_element_array) = !_glewInit_GL_ATI_element_array(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_element_array */ +#ifdef GL_ATI_envmap_bumpmap + CONST_CAST(GLEW_ATI_envmap_bumpmap) = glewGetExtension("GL_ATI_envmap_bumpmap"); + if (glewExperimental || GLEW_ATI_envmap_bumpmap) CONST_CAST(GLEW_ATI_envmap_bumpmap) = !_glewInit_GL_ATI_envmap_bumpmap(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_envmap_bumpmap */ +#ifdef GL_ATI_fragment_shader + CONST_CAST(GLEW_ATI_fragment_shader) = glewGetExtension("GL_ATI_fragment_shader"); + if (glewExperimental || GLEW_ATI_fragment_shader) CONST_CAST(GLEW_ATI_fragment_shader) = !_glewInit_GL_ATI_fragment_shader(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_fragment_shader */ +#ifdef GL_ATI_map_object_buffer + CONST_CAST(GLEW_ATI_map_object_buffer) = glewGetExtension("GL_ATI_map_object_buffer"); + if (glewExperimental || GLEW_ATI_map_object_buffer) CONST_CAST(GLEW_ATI_map_object_buffer) = !_glewInit_GL_ATI_map_object_buffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_map_object_buffer */ +#ifdef GL_ATI_meminfo + CONST_CAST(GLEW_ATI_meminfo) = glewGetExtension("GL_ATI_meminfo"); +#endif /* GL_ATI_meminfo */ +#ifdef GL_ATI_pn_triangles + CONST_CAST(GLEW_ATI_pn_triangles) = glewGetExtension("GL_ATI_pn_triangles"); + if (glewExperimental || GLEW_ATI_pn_triangles) CONST_CAST(GLEW_ATI_pn_triangles) = !_glewInit_GL_ATI_pn_triangles(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_pn_triangles */ +#ifdef GL_ATI_separate_stencil + CONST_CAST(GLEW_ATI_separate_stencil) = glewGetExtension("GL_ATI_separate_stencil"); + if (glewExperimental || GLEW_ATI_separate_stencil) CONST_CAST(GLEW_ATI_separate_stencil) = !_glewInit_GL_ATI_separate_stencil(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_separate_stencil */ +#ifdef GL_ATI_shader_texture_lod + CONST_CAST(GLEW_ATI_shader_texture_lod) = glewGetExtension("GL_ATI_shader_texture_lod"); +#endif /* GL_ATI_shader_texture_lod */ +#ifdef GL_ATI_text_fragment_shader + CONST_CAST(GLEW_ATI_text_fragment_shader) = glewGetExtension("GL_ATI_text_fragment_shader"); +#endif /* GL_ATI_text_fragment_shader */ +#ifdef GL_ATI_texture_compression_3dc + CONST_CAST(GLEW_ATI_texture_compression_3dc) = glewGetExtension("GL_ATI_texture_compression_3dc"); +#endif /* GL_ATI_texture_compression_3dc */ +#ifdef GL_ATI_texture_env_combine3 + CONST_CAST(GLEW_ATI_texture_env_combine3) = glewGetExtension("GL_ATI_texture_env_combine3"); +#endif /* GL_ATI_texture_env_combine3 */ +#ifdef GL_ATI_texture_float + CONST_CAST(GLEW_ATI_texture_float) = glewGetExtension("GL_ATI_texture_float"); +#endif /* GL_ATI_texture_float */ +#ifdef GL_ATI_texture_mirror_once + CONST_CAST(GLEW_ATI_texture_mirror_once) = glewGetExtension("GL_ATI_texture_mirror_once"); +#endif /* GL_ATI_texture_mirror_once */ +#ifdef GL_ATI_vertex_array_object + CONST_CAST(GLEW_ATI_vertex_array_object) = glewGetExtension("GL_ATI_vertex_array_object"); + if (glewExperimental || GLEW_ATI_vertex_array_object) CONST_CAST(GLEW_ATI_vertex_array_object) = !_glewInit_GL_ATI_vertex_array_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_vertex_array_object */ +#ifdef GL_ATI_vertex_attrib_array_object + CONST_CAST(GLEW_ATI_vertex_attrib_array_object) = glewGetExtension("GL_ATI_vertex_attrib_array_object"); + if (glewExperimental || GLEW_ATI_vertex_attrib_array_object) CONST_CAST(GLEW_ATI_vertex_attrib_array_object) = !_glewInit_GL_ATI_vertex_attrib_array_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_vertex_attrib_array_object */ +#ifdef GL_ATI_vertex_streams + CONST_CAST(GLEW_ATI_vertex_streams) = glewGetExtension("GL_ATI_vertex_streams"); + if (glewExperimental || GLEW_ATI_vertex_streams) CONST_CAST(GLEW_ATI_vertex_streams) = !_glewInit_GL_ATI_vertex_streams(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_ATI_vertex_streams */ +#ifdef GL_EXT_422_pixels + CONST_CAST(GLEW_EXT_422_pixels) = glewGetExtension("GL_EXT_422_pixels"); +#endif /* GL_EXT_422_pixels */ +#ifdef GL_EXT_Cg_shader + CONST_CAST(GLEW_EXT_Cg_shader) = glewGetExtension("GL_EXT_Cg_shader"); +#endif /* GL_EXT_Cg_shader */ +#ifdef GL_EXT_abgr + CONST_CAST(GLEW_EXT_abgr) = glewGetExtension("GL_EXT_abgr"); +#endif /* GL_EXT_abgr */ +#ifdef GL_EXT_bgra + CONST_CAST(GLEW_EXT_bgra) = glewGetExtension("GL_EXT_bgra"); +#endif /* GL_EXT_bgra */ +#ifdef GL_EXT_bindable_uniform + CONST_CAST(GLEW_EXT_bindable_uniform) = glewGetExtension("GL_EXT_bindable_uniform"); + if (glewExperimental || GLEW_EXT_bindable_uniform) CONST_CAST(GLEW_EXT_bindable_uniform) = !_glewInit_GL_EXT_bindable_uniform(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_bindable_uniform */ +#ifdef GL_EXT_blend_color + CONST_CAST(GLEW_EXT_blend_color) = glewGetExtension("GL_EXT_blend_color"); + if (glewExperimental || GLEW_EXT_blend_color) CONST_CAST(GLEW_EXT_blend_color) = !_glewInit_GL_EXT_blend_color(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_blend_color */ +#ifdef GL_EXT_blend_equation_separate + CONST_CAST(GLEW_EXT_blend_equation_separate) = glewGetExtension("GL_EXT_blend_equation_separate"); + if (glewExperimental || GLEW_EXT_blend_equation_separate) CONST_CAST(GLEW_EXT_blend_equation_separate) = !_glewInit_GL_EXT_blend_equation_separate(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_blend_equation_separate */ +#ifdef GL_EXT_blend_func_separate + CONST_CAST(GLEW_EXT_blend_func_separate) = glewGetExtension("GL_EXT_blend_func_separate"); + if (glewExperimental || GLEW_EXT_blend_func_separate) CONST_CAST(GLEW_EXT_blend_func_separate) = !_glewInit_GL_EXT_blend_func_separate(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_blend_func_separate */ +#ifdef GL_EXT_blend_logic_op + CONST_CAST(GLEW_EXT_blend_logic_op) = glewGetExtension("GL_EXT_blend_logic_op"); +#endif /* GL_EXT_blend_logic_op */ +#ifdef GL_EXT_blend_minmax + CONST_CAST(GLEW_EXT_blend_minmax) = glewGetExtension("GL_EXT_blend_minmax"); + if (glewExperimental || GLEW_EXT_blend_minmax) CONST_CAST(GLEW_EXT_blend_minmax) = !_glewInit_GL_EXT_blend_minmax(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_blend_minmax */ +#ifdef GL_EXT_blend_subtract + CONST_CAST(GLEW_EXT_blend_subtract) = glewGetExtension("GL_EXT_blend_subtract"); +#endif /* GL_EXT_blend_subtract */ +#ifdef GL_EXT_clip_volume_hint + CONST_CAST(GLEW_EXT_clip_volume_hint) = glewGetExtension("GL_EXT_clip_volume_hint"); +#endif /* GL_EXT_clip_volume_hint */ +#ifdef GL_EXT_cmyka + CONST_CAST(GLEW_EXT_cmyka) = glewGetExtension("GL_EXT_cmyka"); +#endif /* GL_EXT_cmyka */ +#ifdef GL_EXT_color_subtable + CONST_CAST(GLEW_EXT_color_subtable) = glewGetExtension("GL_EXT_color_subtable"); + if (glewExperimental || GLEW_EXT_color_subtable) CONST_CAST(GLEW_EXT_color_subtable) = !_glewInit_GL_EXT_color_subtable(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_color_subtable */ +#ifdef GL_EXT_compiled_vertex_array + CONST_CAST(GLEW_EXT_compiled_vertex_array) = glewGetExtension("GL_EXT_compiled_vertex_array"); + if (glewExperimental || GLEW_EXT_compiled_vertex_array) CONST_CAST(GLEW_EXT_compiled_vertex_array) = !_glewInit_GL_EXT_compiled_vertex_array(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_compiled_vertex_array */ +#ifdef GL_EXT_convolution + CONST_CAST(GLEW_EXT_convolution) = glewGetExtension("GL_EXT_convolution"); + if (glewExperimental || GLEW_EXT_convolution) CONST_CAST(GLEW_EXT_convolution) = !_glewInit_GL_EXT_convolution(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_convolution */ +#ifdef GL_EXT_coordinate_frame + CONST_CAST(GLEW_EXT_coordinate_frame) = glewGetExtension("GL_EXT_coordinate_frame"); + if (glewExperimental || GLEW_EXT_coordinate_frame) CONST_CAST(GLEW_EXT_coordinate_frame) = !_glewInit_GL_EXT_coordinate_frame(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_coordinate_frame */ +#ifdef GL_EXT_copy_texture + CONST_CAST(GLEW_EXT_copy_texture) = glewGetExtension("GL_EXT_copy_texture"); + if (glewExperimental || GLEW_EXT_copy_texture) CONST_CAST(GLEW_EXT_copy_texture) = !_glewInit_GL_EXT_copy_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_copy_texture */ +#ifdef GL_EXT_cull_vertex + CONST_CAST(GLEW_EXT_cull_vertex) = glewGetExtension("GL_EXT_cull_vertex"); + if (glewExperimental || GLEW_EXT_cull_vertex) CONST_CAST(GLEW_EXT_cull_vertex) = !_glewInit_GL_EXT_cull_vertex(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_cull_vertex */ +#ifdef GL_EXT_depth_bounds_test + CONST_CAST(GLEW_EXT_depth_bounds_test) = glewGetExtension("GL_EXT_depth_bounds_test"); + if (glewExperimental || GLEW_EXT_depth_bounds_test) CONST_CAST(GLEW_EXT_depth_bounds_test) = !_glewInit_GL_EXT_depth_bounds_test(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_depth_bounds_test */ +#ifdef GL_EXT_direct_state_access + CONST_CAST(GLEW_EXT_direct_state_access) = glewGetExtension("GL_EXT_direct_state_access"); + if (glewExperimental || GLEW_EXT_direct_state_access) CONST_CAST(GLEW_EXT_direct_state_access) = !_glewInit_GL_EXT_direct_state_access(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_direct_state_access */ +#ifdef GL_EXT_draw_buffers2 + CONST_CAST(GLEW_EXT_draw_buffers2) = glewGetExtension("GL_EXT_draw_buffers2"); + if (glewExperimental || GLEW_EXT_draw_buffers2) CONST_CAST(GLEW_EXT_draw_buffers2) = !_glewInit_GL_EXT_draw_buffers2(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_draw_buffers2 */ +#ifdef GL_EXT_draw_instanced + CONST_CAST(GLEW_EXT_draw_instanced) = glewGetExtension("GL_EXT_draw_instanced"); + if (glewExperimental || GLEW_EXT_draw_instanced) CONST_CAST(GLEW_EXT_draw_instanced) = !_glewInit_GL_EXT_draw_instanced(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_draw_instanced */ +#ifdef GL_EXT_draw_range_elements + CONST_CAST(GLEW_EXT_draw_range_elements) = glewGetExtension("GL_EXT_draw_range_elements"); + if (glewExperimental || GLEW_EXT_draw_range_elements) CONST_CAST(GLEW_EXT_draw_range_elements) = !_glewInit_GL_EXT_draw_range_elements(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_draw_range_elements */ +#ifdef GL_EXT_fog_coord + CONST_CAST(GLEW_EXT_fog_coord) = glewGetExtension("GL_EXT_fog_coord"); + if (glewExperimental || GLEW_EXT_fog_coord) CONST_CAST(GLEW_EXT_fog_coord) = !_glewInit_GL_EXT_fog_coord(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_fog_coord */ +#ifdef GL_EXT_fragment_lighting + CONST_CAST(GLEW_EXT_fragment_lighting) = glewGetExtension("GL_EXT_fragment_lighting"); + if (glewExperimental || GLEW_EXT_fragment_lighting) CONST_CAST(GLEW_EXT_fragment_lighting) = !_glewInit_GL_EXT_fragment_lighting(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_fragment_lighting */ +#ifdef GL_EXT_framebuffer_blit + CONST_CAST(GLEW_EXT_framebuffer_blit) = glewGetExtension("GL_EXT_framebuffer_blit"); + if (glewExperimental || GLEW_EXT_framebuffer_blit) CONST_CAST(GLEW_EXT_framebuffer_blit) = !_glewInit_GL_EXT_framebuffer_blit(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_framebuffer_blit */ +#ifdef GL_EXT_framebuffer_multisample + CONST_CAST(GLEW_EXT_framebuffer_multisample) = glewGetExtension("GL_EXT_framebuffer_multisample"); + if (glewExperimental || GLEW_EXT_framebuffer_multisample) CONST_CAST(GLEW_EXT_framebuffer_multisample) = !_glewInit_GL_EXT_framebuffer_multisample(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_framebuffer_multisample */ +#ifdef GL_EXT_framebuffer_object + CONST_CAST(GLEW_EXT_framebuffer_object) = glewGetExtension("GL_EXT_framebuffer_object"); + if (glewExperimental || GLEW_EXT_framebuffer_object) CONST_CAST(GLEW_EXT_framebuffer_object) = !_glewInit_GL_EXT_framebuffer_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_framebuffer_object */ +#ifdef GL_EXT_framebuffer_sRGB + CONST_CAST(GLEW_EXT_framebuffer_sRGB) = glewGetExtension("GL_EXT_framebuffer_sRGB"); +#endif /* GL_EXT_framebuffer_sRGB */ +#ifdef GL_EXT_geometry_shader4 + CONST_CAST(GLEW_EXT_geometry_shader4) = glewGetExtension("GL_EXT_geometry_shader4"); + if (glewExperimental || GLEW_EXT_geometry_shader4) CONST_CAST(GLEW_EXT_geometry_shader4) = !_glewInit_GL_EXT_geometry_shader4(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_geometry_shader4 */ +#ifdef GL_EXT_gpu_program_parameters + CONST_CAST(GLEW_EXT_gpu_program_parameters) = glewGetExtension("GL_EXT_gpu_program_parameters"); + if (glewExperimental || GLEW_EXT_gpu_program_parameters) CONST_CAST(GLEW_EXT_gpu_program_parameters) = !_glewInit_GL_EXT_gpu_program_parameters(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_gpu_program_parameters */ +#ifdef GL_EXT_gpu_shader4 + CONST_CAST(GLEW_EXT_gpu_shader4) = glewGetExtension("GL_EXT_gpu_shader4"); + if (glewExperimental || GLEW_EXT_gpu_shader4) CONST_CAST(GLEW_EXT_gpu_shader4) = !_glewInit_GL_EXT_gpu_shader4(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_gpu_shader4 */ +#ifdef GL_EXT_histogram + CONST_CAST(GLEW_EXT_histogram) = glewGetExtension("GL_EXT_histogram"); + if (glewExperimental || GLEW_EXT_histogram) CONST_CAST(GLEW_EXT_histogram) = !_glewInit_GL_EXT_histogram(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_histogram */ +#ifdef GL_EXT_index_array_formats + CONST_CAST(GLEW_EXT_index_array_formats) = glewGetExtension("GL_EXT_index_array_formats"); +#endif /* GL_EXT_index_array_formats */ +#ifdef GL_EXT_index_func + CONST_CAST(GLEW_EXT_index_func) = glewGetExtension("GL_EXT_index_func"); + if (glewExperimental || GLEW_EXT_index_func) CONST_CAST(GLEW_EXT_index_func) = !_glewInit_GL_EXT_index_func(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_index_func */ +#ifdef GL_EXT_index_material + CONST_CAST(GLEW_EXT_index_material) = glewGetExtension("GL_EXT_index_material"); + if (glewExperimental || GLEW_EXT_index_material) CONST_CAST(GLEW_EXT_index_material) = !_glewInit_GL_EXT_index_material(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_index_material */ +#ifdef GL_EXT_index_texture + CONST_CAST(GLEW_EXT_index_texture) = glewGetExtension("GL_EXT_index_texture"); +#endif /* GL_EXT_index_texture */ +#ifdef GL_EXT_light_texture + CONST_CAST(GLEW_EXT_light_texture) = glewGetExtension("GL_EXT_light_texture"); + if (glewExperimental || GLEW_EXT_light_texture) CONST_CAST(GLEW_EXT_light_texture) = !_glewInit_GL_EXT_light_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_light_texture */ +#ifdef GL_EXT_misc_attribute + CONST_CAST(GLEW_EXT_misc_attribute) = glewGetExtension("GL_EXT_misc_attribute"); +#endif /* GL_EXT_misc_attribute */ +#ifdef GL_EXT_multi_draw_arrays + CONST_CAST(GLEW_EXT_multi_draw_arrays) = glewGetExtension("GL_EXT_multi_draw_arrays"); + if (glewExperimental || GLEW_EXT_multi_draw_arrays) CONST_CAST(GLEW_EXT_multi_draw_arrays) = !_glewInit_GL_EXT_multi_draw_arrays(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_multi_draw_arrays */ +#ifdef GL_EXT_multisample + CONST_CAST(GLEW_EXT_multisample) = glewGetExtension("GL_EXT_multisample"); + if (glewExperimental || GLEW_EXT_multisample) CONST_CAST(GLEW_EXT_multisample) = !_glewInit_GL_EXT_multisample(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_multisample */ +#ifdef GL_EXT_packed_depth_stencil + CONST_CAST(GLEW_EXT_packed_depth_stencil) = glewGetExtension("GL_EXT_packed_depth_stencil"); +#endif /* GL_EXT_packed_depth_stencil */ +#ifdef GL_EXT_packed_float + CONST_CAST(GLEW_EXT_packed_float) = glewGetExtension("GL_EXT_packed_float"); +#endif /* GL_EXT_packed_float */ +#ifdef GL_EXT_packed_pixels + CONST_CAST(GLEW_EXT_packed_pixels) = glewGetExtension("GL_EXT_packed_pixels"); +#endif /* GL_EXT_packed_pixels */ +#ifdef GL_EXT_paletted_texture + CONST_CAST(GLEW_EXT_paletted_texture) = glewGetExtension("GL_EXT_paletted_texture"); + if (glewExperimental || GLEW_EXT_paletted_texture) CONST_CAST(GLEW_EXT_paletted_texture) = !_glewInit_GL_EXT_paletted_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_paletted_texture */ +#ifdef GL_EXT_pixel_buffer_object + CONST_CAST(GLEW_EXT_pixel_buffer_object) = glewGetExtension("GL_EXT_pixel_buffer_object"); +#endif /* GL_EXT_pixel_buffer_object */ +#ifdef GL_EXT_pixel_transform + CONST_CAST(GLEW_EXT_pixel_transform) = glewGetExtension("GL_EXT_pixel_transform"); + if (glewExperimental || GLEW_EXT_pixel_transform) CONST_CAST(GLEW_EXT_pixel_transform) = !_glewInit_GL_EXT_pixel_transform(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_pixel_transform */ +#ifdef GL_EXT_pixel_transform_color_table + CONST_CAST(GLEW_EXT_pixel_transform_color_table) = glewGetExtension("GL_EXT_pixel_transform_color_table"); +#endif /* GL_EXT_pixel_transform_color_table */ +#ifdef GL_EXT_point_parameters + CONST_CAST(GLEW_EXT_point_parameters) = glewGetExtension("GL_EXT_point_parameters"); + if (glewExperimental || GLEW_EXT_point_parameters) CONST_CAST(GLEW_EXT_point_parameters) = !_glewInit_GL_EXT_point_parameters(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_point_parameters */ +#ifdef GL_EXT_polygon_offset + CONST_CAST(GLEW_EXT_polygon_offset) = glewGetExtension("GL_EXT_polygon_offset"); + if (glewExperimental || GLEW_EXT_polygon_offset) CONST_CAST(GLEW_EXT_polygon_offset) = !_glewInit_GL_EXT_polygon_offset(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_polygon_offset */ +#ifdef GL_EXT_provoking_vertex + CONST_CAST(GLEW_EXT_provoking_vertex) = glewGetExtension("GL_EXT_provoking_vertex"); + if (glewExperimental || GLEW_EXT_provoking_vertex) CONST_CAST(GLEW_EXT_provoking_vertex) = !_glewInit_GL_EXT_provoking_vertex(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_provoking_vertex */ +#ifdef GL_EXT_rescale_normal + CONST_CAST(GLEW_EXT_rescale_normal) = glewGetExtension("GL_EXT_rescale_normal"); +#endif /* GL_EXT_rescale_normal */ +#ifdef GL_EXT_scene_marker + CONST_CAST(GLEW_EXT_scene_marker) = glewGetExtension("GL_EXT_scene_marker"); + if (glewExperimental || GLEW_EXT_scene_marker) CONST_CAST(GLEW_EXT_scene_marker) = !_glewInit_GL_EXT_scene_marker(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_scene_marker */ +#ifdef GL_EXT_secondary_color + CONST_CAST(GLEW_EXT_secondary_color) = glewGetExtension("GL_EXT_secondary_color"); + if (glewExperimental || GLEW_EXT_secondary_color) CONST_CAST(GLEW_EXT_secondary_color) = !_glewInit_GL_EXT_secondary_color(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_secondary_color */ +#ifdef GL_EXT_separate_shader_objects + CONST_CAST(GLEW_EXT_separate_shader_objects) = glewGetExtension("GL_EXT_separate_shader_objects"); + if (glewExperimental || GLEW_EXT_separate_shader_objects) CONST_CAST(GLEW_EXT_separate_shader_objects) = !_glewInit_GL_EXT_separate_shader_objects(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_separate_shader_objects */ +#ifdef GL_EXT_separate_specular_color + CONST_CAST(GLEW_EXT_separate_specular_color) = glewGetExtension("GL_EXT_separate_specular_color"); +#endif /* GL_EXT_separate_specular_color */ +#ifdef GL_EXT_shader_image_load_store + CONST_CAST(GLEW_EXT_shader_image_load_store) = glewGetExtension("GL_EXT_shader_image_load_store"); + if (glewExperimental || GLEW_EXT_shader_image_load_store) CONST_CAST(GLEW_EXT_shader_image_load_store) = !_glewInit_GL_EXT_shader_image_load_store(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_shader_image_load_store */ +#ifdef GL_EXT_shadow_funcs + CONST_CAST(GLEW_EXT_shadow_funcs) = glewGetExtension("GL_EXT_shadow_funcs"); +#endif /* GL_EXT_shadow_funcs */ +#ifdef GL_EXT_shared_texture_palette + CONST_CAST(GLEW_EXT_shared_texture_palette) = glewGetExtension("GL_EXT_shared_texture_palette"); +#endif /* GL_EXT_shared_texture_palette */ +#ifdef GL_EXT_stencil_clear_tag + CONST_CAST(GLEW_EXT_stencil_clear_tag) = glewGetExtension("GL_EXT_stencil_clear_tag"); +#endif /* GL_EXT_stencil_clear_tag */ +#ifdef GL_EXT_stencil_two_side + CONST_CAST(GLEW_EXT_stencil_two_side) = glewGetExtension("GL_EXT_stencil_two_side"); + if (glewExperimental || GLEW_EXT_stencil_two_side) CONST_CAST(GLEW_EXT_stencil_two_side) = !_glewInit_GL_EXT_stencil_two_side(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_stencil_two_side */ +#ifdef GL_EXT_stencil_wrap + CONST_CAST(GLEW_EXT_stencil_wrap) = glewGetExtension("GL_EXT_stencil_wrap"); +#endif /* GL_EXT_stencil_wrap */ +#ifdef GL_EXT_subtexture + CONST_CAST(GLEW_EXT_subtexture) = glewGetExtension("GL_EXT_subtexture"); + if (glewExperimental || GLEW_EXT_subtexture) CONST_CAST(GLEW_EXT_subtexture) = !_glewInit_GL_EXT_subtexture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_subtexture */ +#ifdef GL_EXT_texture + CONST_CAST(GLEW_EXT_texture) = glewGetExtension("GL_EXT_texture"); +#endif /* GL_EXT_texture */ +#ifdef GL_EXT_texture3D + CONST_CAST(GLEW_EXT_texture3D) = glewGetExtension("GL_EXT_texture3D"); + if (glewExperimental || GLEW_EXT_texture3D) CONST_CAST(GLEW_EXT_texture3D) = !_glewInit_GL_EXT_texture3D(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_texture3D */ +#ifdef GL_EXT_texture_array + CONST_CAST(GLEW_EXT_texture_array) = glewGetExtension("GL_EXT_texture_array"); +#endif /* GL_EXT_texture_array */ +#ifdef GL_EXT_texture_buffer_object + CONST_CAST(GLEW_EXT_texture_buffer_object) = glewGetExtension("GL_EXT_texture_buffer_object"); + if (glewExperimental || GLEW_EXT_texture_buffer_object) CONST_CAST(GLEW_EXT_texture_buffer_object) = !_glewInit_GL_EXT_texture_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_texture_buffer_object */ +#ifdef GL_EXT_texture_compression_dxt1 + CONST_CAST(GLEW_EXT_texture_compression_dxt1) = glewGetExtension("GL_EXT_texture_compression_dxt1"); +#endif /* GL_EXT_texture_compression_dxt1 */ +#ifdef GL_EXT_texture_compression_latc + CONST_CAST(GLEW_EXT_texture_compression_latc) = glewGetExtension("GL_EXT_texture_compression_latc"); +#endif /* GL_EXT_texture_compression_latc */ +#ifdef GL_EXT_texture_compression_rgtc + CONST_CAST(GLEW_EXT_texture_compression_rgtc) = glewGetExtension("GL_EXT_texture_compression_rgtc"); +#endif /* GL_EXT_texture_compression_rgtc */ +#ifdef GL_EXT_texture_compression_s3tc + CONST_CAST(GLEW_EXT_texture_compression_s3tc) = glewGetExtension("GL_EXT_texture_compression_s3tc"); +#endif /* GL_EXT_texture_compression_s3tc */ +#ifdef GL_EXT_texture_cube_map + CONST_CAST(GLEW_EXT_texture_cube_map) = glewGetExtension("GL_EXT_texture_cube_map"); +#endif /* GL_EXT_texture_cube_map */ +#ifdef GL_EXT_texture_edge_clamp + CONST_CAST(GLEW_EXT_texture_edge_clamp) = glewGetExtension("GL_EXT_texture_edge_clamp"); +#endif /* GL_EXT_texture_edge_clamp */ +#ifdef GL_EXT_texture_env + CONST_CAST(GLEW_EXT_texture_env) = glewGetExtension("GL_EXT_texture_env"); +#endif /* GL_EXT_texture_env */ +#ifdef GL_EXT_texture_env_add + CONST_CAST(GLEW_EXT_texture_env_add) = glewGetExtension("GL_EXT_texture_env_add"); +#endif /* GL_EXT_texture_env_add */ +#ifdef GL_EXT_texture_env_combine + CONST_CAST(GLEW_EXT_texture_env_combine) = glewGetExtension("GL_EXT_texture_env_combine"); +#endif /* GL_EXT_texture_env_combine */ +#ifdef GL_EXT_texture_env_dot3 + CONST_CAST(GLEW_EXT_texture_env_dot3) = glewGetExtension("GL_EXT_texture_env_dot3"); +#endif /* GL_EXT_texture_env_dot3 */ +#ifdef GL_EXT_texture_filter_anisotropic + CONST_CAST(GLEW_EXT_texture_filter_anisotropic) = glewGetExtension("GL_EXT_texture_filter_anisotropic"); +#endif /* GL_EXT_texture_filter_anisotropic */ +#ifdef GL_EXT_texture_integer + CONST_CAST(GLEW_EXT_texture_integer) = glewGetExtension("GL_EXT_texture_integer"); + if (glewExperimental || GLEW_EXT_texture_integer) CONST_CAST(GLEW_EXT_texture_integer) = !_glewInit_GL_EXT_texture_integer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_texture_integer */ +#ifdef GL_EXT_texture_lod_bias + CONST_CAST(GLEW_EXT_texture_lod_bias) = glewGetExtension("GL_EXT_texture_lod_bias"); +#endif /* GL_EXT_texture_lod_bias */ +#ifdef GL_EXT_texture_mirror_clamp + CONST_CAST(GLEW_EXT_texture_mirror_clamp) = glewGetExtension("GL_EXT_texture_mirror_clamp"); +#endif /* GL_EXT_texture_mirror_clamp */ +#ifdef GL_EXT_texture_object + CONST_CAST(GLEW_EXT_texture_object) = glewGetExtension("GL_EXT_texture_object"); + if (glewExperimental || GLEW_EXT_texture_object) CONST_CAST(GLEW_EXT_texture_object) = !_glewInit_GL_EXT_texture_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_texture_object */ +#ifdef GL_EXT_texture_perturb_normal + CONST_CAST(GLEW_EXT_texture_perturb_normal) = glewGetExtension("GL_EXT_texture_perturb_normal"); + if (glewExperimental || GLEW_EXT_texture_perturb_normal) CONST_CAST(GLEW_EXT_texture_perturb_normal) = !_glewInit_GL_EXT_texture_perturb_normal(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_texture_perturb_normal */ +#ifdef GL_EXT_texture_rectangle + CONST_CAST(GLEW_EXT_texture_rectangle) = glewGetExtension("GL_EXT_texture_rectangle"); +#endif /* GL_EXT_texture_rectangle */ +#ifdef GL_EXT_texture_sRGB + CONST_CAST(GLEW_EXT_texture_sRGB) = glewGetExtension("GL_EXT_texture_sRGB"); +#endif /* GL_EXT_texture_sRGB */ +#ifdef GL_EXT_texture_shared_exponent + CONST_CAST(GLEW_EXT_texture_shared_exponent) = glewGetExtension("GL_EXT_texture_shared_exponent"); +#endif /* GL_EXT_texture_shared_exponent */ +#ifdef GL_EXT_texture_snorm + CONST_CAST(GLEW_EXT_texture_snorm) = glewGetExtension("GL_EXT_texture_snorm"); +#endif /* GL_EXT_texture_snorm */ +#ifdef GL_EXT_texture_swizzle + CONST_CAST(GLEW_EXT_texture_swizzle) = glewGetExtension("GL_EXT_texture_swizzle"); +#endif /* GL_EXT_texture_swizzle */ +#ifdef GL_EXT_timer_query + CONST_CAST(GLEW_EXT_timer_query) = glewGetExtension("GL_EXT_timer_query"); + if (glewExperimental || GLEW_EXT_timer_query) CONST_CAST(GLEW_EXT_timer_query) = !_glewInit_GL_EXT_timer_query(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_timer_query */ +#ifdef GL_EXT_transform_feedback + CONST_CAST(GLEW_EXT_transform_feedback) = glewGetExtension("GL_EXT_transform_feedback"); + if (glewExperimental || GLEW_EXT_transform_feedback) CONST_CAST(GLEW_EXT_transform_feedback) = !_glewInit_GL_EXT_transform_feedback(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_transform_feedback */ +#ifdef GL_EXT_vertex_array + CONST_CAST(GLEW_EXT_vertex_array) = glewGetExtension("GL_EXT_vertex_array"); + if (glewExperimental || GLEW_EXT_vertex_array) CONST_CAST(GLEW_EXT_vertex_array) = !_glewInit_GL_EXT_vertex_array(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_vertex_array */ +#ifdef GL_EXT_vertex_array_bgra + CONST_CAST(GLEW_EXT_vertex_array_bgra) = glewGetExtension("GL_EXT_vertex_array_bgra"); +#endif /* GL_EXT_vertex_array_bgra */ +#ifdef GL_EXT_vertex_attrib_64bit + CONST_CAST(GLEW_EXT_vertex_attrib_64bit) = glewGetExtension("GL_EXT_vertex_attrib_64bit"); + if (glewExperimental || GLEW_EXT_vertex_attrib_64bit) CONST_CAST(GLEW_EXT_vertex_attrib_64bit) = !_glewInit_GL_EXT_vertex_attrib_64bit(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_vertex_attrib_64bit */ +#ifdef GL_EXT_vertex_shader + CONST_CAST(GLEW_EXT_vertex_shader) = glewGetExtension("GL_EXT_vertex_shader"); + if (glewExperimental || GLEW_EXT_vertex_shader) CONST_CAST(GLEW_EXT_vertex_shader) = !_glewInit_GL_EXT_vertex_shader(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_vertex_shader */ +#ifdef GL_EXT_vertex_weighting + CONST_CAST(GLEW_EXT_vertex_weighting) = glewGetExtension("GL_EXT_vertex_weighting"); + if (glewExperimental || GLEW_EXT_vertex_weighting) CONST_CAST(GLEW_EXT_vertex_weighting) = !_glewInit_GL_EXT_vertex_weighting(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_EXT_vertex_weighting */ +#ifdef GL_GREMEDY_frame_terminator + CONST_CAST(GLEW_GREMEDY_frame_terminator) = glewGetExtension("GL_GREMEDY_frame_terminator"); + if (glewExperimental || GLEW_GREMEDY_frame_terminator) CONST_CAST(GLEW_GREMEDY_frame_terminator) = !_glewInit_GL_GREMEDY_frame_terminator(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_GREMEDY_frame_terminator */ +#ifdef GL_GREMEDY_string_marker + CONST_CAST(GLEW_GREMEDY_string_marker) = glewGetExtension("GL_GREMEDY_string_marker"); + if (glewExperimental || GLEW_GREMEDY_string_marker) CONST_CAST(GLEW_GREMEDY_string_marker) = !_glewInit_GL_GREMEDY_string_marker(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_GREMEDY_string_marker */ +#ifdef GL_HP_convolution_border_modes + CONST_CAST(GLEW_HP_convolution_border_modes) = glewGetExtension("GL_HP_convolution_border_modes"); +#endif /* GL_HP_convolution_border_modes */ +#ifdef GL_HP_image_transform + CONST_CAST(GLEW_HP_image_transform) = glewGetExtension("GL_HP_image_transform"); + if (glewExperimental || GLEW_HP_image_transform) CONST_CAST(GLEW_HP_image_transform) = !_glewInit_GL_HP_image_transform(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_HP_image_transform */ +#ifdef GL_HP_occlusion_test + CONST_CAST(GLEW_HP_occlusion_test) = glewGetExtension("GL_HP_occlusion_test"); +#endif /* GL_HP_occlusion_test */ +#ifdef GL_HP_texture_lighting + CONST_CAST(GLEW_HP_texture_lighting) = glewGetExtension("GL_HP_texture_lighting"); +#endif /* GL_HP_texture_lighting */ +#ifdef GL_IBM_cull_vertex + CONST_CAST(GLEW_IBM_cull_vertex) = glewGetExtension("GL_IBM_cull_vertex"); +#endif /* GL_IBM_cull_vertex */ +#ifdef GL_IBM_multimode_draw_arrays + CONST_CAST(GLEW_IBM_multimode_draw_arrays) = glewGetExtension("GL_IBM_multimode_draw_arrays"); + if (glewExperimental || GLEW_IBM_multimode_draw_arrays) CONST_CAST(GLEW_IBM_multimode_draw_arrays) = !_glewInit_GL_IBM_multimode_draw_arrays(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_IBM_multimode_draw_arrays */ +#ifdef GL_IBM_rasterpos_clip + CONST_CAST(GLEW_IBM_rasterpos_clip) = glewGetExtension("GL_IBM_rasterpos_clip"); +#endif /* GL_IBM_rasterpos_clip */ +#ifdef GL_IBM_static_data + CONST_CAST(GLEW_IBM_static_data) = glewGetExtension("GL_IBM_static_data"); +#endif /* GL_IBM_static_data */ +#ifdef GL_IBM_texture_mirrored_repeat + CONST_CAST(GLEW_IBM_texture_mirrored_repeat) = glewGetExtension("GL_IBM_texture_mirrored_repeat"); +#endif /* GL_IBM_texture_mirrored_repeat */ +#ifdef GL_IBM_vertex_array_lists + CONST_CAST(GLEW_IBM_vertex_array_lists) = glewGetExtension("GL_IBM_vertex_array_lists"); + if (glewExperimental || GLEW_IBM_vertex_array_lists) CONST_CAST(GLEW_IBM_vertex_array_lists) = !_glewInit_GL_IBM_vertex_array_lists(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_IBM_vertex_array_lists */ +#ifdef GL_INGR_color_clamp + CONST_CAST(GLEW_INGR_color_clamp) = glewGetExtension("GL_INGR_color_clamp"); +#endif /* GL_INGR_color_clamp */ +#ifdef GL_INGR_interlace_read + CONST_CAST(GLEW_INGR_interlace_read) = glewGetExtension("GL_INGR_interlace_read"); +#endif /* GL_INGR_interlace_read */ +#ifdef GL_INTEL_parallel_arrays + CONST_CAST(GLEW_INTEL_parallel_arrays) = glewGetExtension("GL_INTEL_parallel_arrays"); + if (glewExperimental || GLEW_INTEL_parallel_arrays) CONST_CAST(GLEW_INTEL_parallel_arrays) = !_glewInit_GL_INTEL_parallel_arrays(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_INTEL_parallel_arrays */ +#ifdef GL_INTEL_texture_scissor + CONST_CAST(GLEW_INTEL_texture_scissor) = glewGetExtension("GL_INTEL_texture_scissor"); + if (glewExperimental || GLEW_INTEL_texture_scissor) CONST_CAST(GLEW_INTEL_texture_scissor) = !_glewInit_GL_INTEL_texture_scissor(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_INTEL_texture_scissor */ +#ifdef GL_KTX_buffer_region + CONST_CAST(GLEW_KTX_buffer_region) = glewGetExtension("GL_KTX_buffer_region"); + if (glewExperimental || GLEW_KTX_buffer_region) CONST_CAST(GLEW_KTX_buffer_region) = !_glewInit_GL_KTX_buffer_region(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_KTX_buffer_region */ +#ifdef GL_MESAX_texture_stack + CONST_CAST(GLEW_MESAX_texture_stack) = glewGetExtension("GL_MESAX_texture_stack"); +#endif /* GL_MESAX_texture_stack */ +#ifdef GL_MESA_pack_invert + CONST_CAST(GLEW_MESA_pack_invert) = glewGetExtension("GL_MESA_pack_invert"); +#endif /* GL_MESA_pack_invert */ +#ifdef GL_MESA_resize_buffers + CONST_CAST(GLEW_MESA_resize_buffers) = glewGetExtension("GL_MESA_resize_buffers"); + if (glewExperimental || GLEW_MESA_resize_buffers) CONST_CAST(GLEW_MESA_resize_buffers) = !_glewInit_GL_MESA_resize_buffers(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_MESA_resize_buffers */ +#ifdef GL_MESA_window_pos + CONST_CAST(GLEW_MESA_window_pos) = glewGetExtension("GL_MESA_window_pos"); + if (glewExperimental || GLEW_MESA_window_pos) CONST_CAST(GLEW_MESA_window_pos) = !_glewInit_GL_MESA_window_pos(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_MESA_window_pos */ +#ifdef GL_MESA_ycbcr_texture + CONST_CAST(GLEW_MESA_ycbcr_texture) = glewGetExtension("GL_MESA_ycbcr_texture"); +#endif /* GL_MESA_ycbcr_texture */ +#ifdef GL_NV_blend_square + CONST_CAST(GLEW_NV_blend_square) = glewGetExtension("GL_NV_blend_square"); +#endif /* GL_NV_blend_square */ +#ifdef GL_NV_conditional_render + CONST_CAST(GLEW_NV_conditional_render) = glewGetExtension("GL_NV_conditional_render"); + if (glewExperimental || GLEW_NV_conditional_render) CONST_CAST(GLEW_NV_conditional_render) = !_glewInit_GL_NV_conditional_render(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_conditional_render */ +#ifdef GL_NV_copy_depth_to_color + CONST_CAST(GLEW_NV_copy_depth_to_color) = glewGetExtension("GL_NV_copy_depth_to_color"); +#endif /* GL_NV_copy_depth_to_color */ +#ifdef GL_NV_copy_image + CONST_CAST(GLEW_NV_copy_image) = glewGetExtension("GL_NV_copy_image"); + if (glewExperimental || GLEW_NV_copy_image) CONST_CAST(GLEW_NV_copy_image) = !_glewInit_GL_NV_copy_image(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_copy_image */ +#ifdef GL_NV_depth_buffer_float + CONST_CAST(GLEW_NV_depth_buffer_float) = glewGetExtension("GL_NV_depth_buffer_float"); + if (glewExperimental || GLEW_NV_depth_buffer_float) CONST_CAST(GLEW_NV_depth_buffer_float) = !_glewInit_GL_NV_depth_buffer_float(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_depth_buffer_float */ +#ifdef GL_NV_depth_clamp + CONST_CAST(GLEW_NV_depth_clamp) = glewGetExtension("GL_NV_depth_clamp"); +#endif /* GL_NV_depth_clamp */ +#ifdef GL_NV_depth_range_unclamped + CONST_CAST(GLEW_NV_depth_range_unclamped) = glewGetExtension("GL_NV_depth_range_unclamped"); +#endif /* GL_NV_depth_range_unclamped */ +#ifdef GL_NV_evaluators + CONST_CAST(GLEW_NV_evaluators) = glewGetExtension("GL_NV_evaluators"); + if (glewExperimental || GLEW_NV_evaluators) CONST_CAST(GLEW_NV_evaluators) = !_glewInit_GL_NV_evaluators(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_evaluators */ +#ifdef GL_NV_explicit_multisample + CONST_CAST(GLEW_NV_explicit_multisample) = glewGetExtension("GL_NV_explicit_multisample"); + if (glewExperimental || GLEW_NV_explicit_multisample) CONST_CAST(GLEW_NV_explicit_multisample) = !_glewInit_GL_NV_explicit_multisample(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_explicit_multisample */ +#ifdef GL_NV_fence + CONST_CAST(GLEW_NV_fence) = glewGetExtension("GL_NV_fence"); + if (glewExperimental || GLEW_NV_fence) CONST_CAST(GLEW_NV_fence) = !_glewInit_GL_NV_fence(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_fence */ +#ifdef GL_NV_float_buffer + CONST_CAST(GLEW_NV_float_buffer) = glewGetExtension("GL_NV_float_buffer"); +#endif /* GL_NV_float_buffer */ +#ifdef GL_NV_fog_distance + CONST_CAST(GLEW_NV_fog_distance) = glewGetExtension("GL_NV_fog_distance"); +#endif /* GL_NV_fog_distance */ +#ifdef GL_NV_fragment_program + CONST_CAST(GLEW_NV_fragment_program) = glewGetExtension("GL_NV_fragment_program"); + if (glewExperimental || GLEW_NV_fragment_program) CONST_CAST(GLEW_NV_fragment_program) = !_glewInit_GL_NV_fragment_program(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_fragment_program */ +#ifdef GL_NV_fragment_program2 + CONST_CAST(GLEW_NV_fragment_program2) = glewGetExtension("GL_NV_fragment_program2"); +#endif /* GL_NV_fragment_program2 */ +#ifdef GL_NV_fragment_program4 + CONST_CAST(GLEW_NV_fragment_program4) = glewGetExtension("GL_NV_gpu_program4"); +#endif /* GL_NV_fragment_program4 */ +#ifdef GL_NV_fragment_program_option + CONST_CAST(GLEW_NV_fragment_program_option) = glewGetExtension("GL_NV_fragment_program_option"); +#endif /* GL_NV_fragment_program_option */ +#ifdef GL_NV_framebuffer_multisample_coverage + CONST_CAST(GLEW_NV_framebuffer_multisample_coverage) = glewGetExtension("GL_NV_framebuffer_multisample_coverage"); + if (glewExperimental || GLEW_NV_framebuffer_multisample_coverage) CONST_CAST(GLEW_NV_framebuffer_multisample_coverage) = !_glewInit_GL_NV_framebuffer_multisample_coverage(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_framebuffer_multisample_coverage */ +#ifdef GL_NV_geometry_program4 + CONST_CAST(GLEW_NV_geometry_program4) = glewGetExtension("GL_NV_gpu_program4"); + if (glewExperimental || GLEW_NV_geometry_program4) CONST_CAST(GLEW_NV_geometry_program4) = !_glewInit_GL_NV_geometry_program4(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_geometry_program4 */ +#ifdef GL_NV_geometry_shader4 + CONST_CAST(GLEW_NV_geometry_shader4) = glewGetExtension("GL_NV_geometry_shader4"); +#endif /* GL_NV_geometry_shader4 */ +#ifdef GL_NV_gpu_program4 + CONST_CAST(GLEW_NV_gpu_program4) = glewGetExtension("GL_NV_gpu_program4"); + if (glewExperimental || GLEW_NV_gpu_program4) CONST_CAST(GLEW_NV_gpu_program4) = !_glewInit_GL_NV_gpu_program4(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_gpu_program4 */ +#ifdef GL_NV_gpu_program5 + CONST_CAST(GLEW_NV_gpu_program5) = glewGetExtension("GL_NV_gpu_program5"); +#endif /* GL_NV_gpu_program5 */ +#ifdef GL_NV_gpu_program_fp64 + CONST_CAST(GLEW_NV_gpu_program_fp64) = glewGetExtension("GL_NV_gpu_program_fp64"); +#endif /* GL_NV_gpu_program_fp64 */ +#ifdef GL_NV_gpu_shader5 + CONST_CAST(GLEW_NV_gpu_shader5) = glewGetExtension("GL_NV_gpu_shader5"); + if (glewExperimental || GLEW_NV_gpu_shader5) CONST_CAST(GLEW_NV_gpu_shader5) = !_glewInit_GL_NV_gpu_shader5(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_gpu_shader5 */ +#ifdef GL_NV_half_float + CONST_CAST(GLEW_NV_half_float) = glewGetExtension("GL_NV_half_float"); + if (glewExperimental || GLEW_NV_half_float) CONST_CAST(GLEW_NV_half_float) = !_glewInit_GL_NV_half_float(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_half_float */ +#ifdef GL_NV_light_max_exponent + CONST_CAST(GLEW_NV_light_max_exponent) = glewGetExtension("GL_NV_light_max_exponent"); +#endif /* GL_NV_light_max_exponent */ +#ifdef GL_NV_multisample_filter_hint + CONST_CAST(GLEW_NV_multisample_filter_hint) = glewGetExtension("GL_NV_multisample_filter_hint"); +#endif /* GL_NV_multisample_filter_hint */ +#ifdef GL_NV_occlusion_query + CONST_CAST(GLEW_NV_occlusion_query) = glewGetExtension("GL_NV_occlusion_query"); + if (glewExperimental || GLEW_NV_occlusion_query) CONST_CAST(GLEW_NV_occlusion_query) = !_glewInit_GL_NV_occlusion_query(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_occlusion_query */ +#ifdef GL_NV_packed_depth_stencil + CONST_CAST(GLEW_NV_packed_depth_stencil) = glewGetExtension("GL_NV_packed_depth_stencil"); +#endif /* GL_NV_packed_depth_stencil */ +#ifdef GL_NV_parameter_buffer_object + CONST_CAST(GLEW_NV_parameter_buffer_object) = glewGetExtension("GL_NV_parameter_buffer_object"); + if (glewExperimental || GLEW_NV_parameter_buffer_object) CONST_CAST(GLEW_NV_parameter_buffer_object) = !_glewInit_GL_NV_parameter_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_parameter_buffer_object */ +#ifdef GL_NV_parameter_buffer_object2 + CONST_CAST(GLEW_NV_parameter_buffer_object2) = glewGetExtension("GL_NV_parameter_buffer_object2"); +#endif /* GL_NV_parameter_buffer_object2 */ +#ifdef GL_NV_pixel_data_range + CONST_CAST(GLEW_NV_pixel_data_range) = glewGetExtension("GL_NV_pixel_data_range"); + if (glewExperimental || GLEW_NV_pixel_data_range) CONST_CAST(GLEW_NV_pixel_data_range) = !_glewInit_GL_NV_pixel_data_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_pixel_data_range */ +#ifdef GL_NV_point_sprite + CONST_CAST(GLEW_NV_point_sprite) = glewGetExtension("GL_NV_point_sprite"); + if (glewExperimental || GLEW_NV_point_sprite) CONST_CAST(GLEW_NV_point_sprite) = !_glewInit_GL_NV_point_sprite(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_point_sprite */ +#ifdef GL_NV_present_video + CONST_CAST(GLEW_NV_present_video) = glewGetExtension("GL_NV_present_video"); + if (glewExperimental || GLEW_NV_present_video) CONST_CAST(GLEW_NV_present_video) = !_glewInit_GL_NV_present_video(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_present_video */ +#ifdef GL_NV_primitive_restart + CONST_CAST(GLEW_NV_primitive_restart) = glewGetExtension("GL_NV_primitive_restart"); + if (glewExperimental || GLEW_NV_primitive_restart) CONST_CAST(GLEW_NV_primitive_restart) = !_glewInit_GL_NV_primitive_restart(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_primitive_restart */ +#ifdef GL_NV_register_combiners + CONST_CAST(GLEW_NV_register_combiners) = glewGetExtension("GL_NV_register_combiners"); + if (glewExperimental || GLEW_NV_register_combiners) CONST_CAST(GLEW_NV_register_combiners) = !_glewInit_GL_NV_register_combiners(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_register_combiners */ +#ifdef GL_NV_register_combiners2 + CONST_CAST(GLEW_NV_register_combiners2) = glewGetExtension("GL_NV_register_combiners2"); + if (glewExperimental || GLEW_NV_register_combiners2) CONST_CAST(GLEW_NV_register_combiners2) = !_glewInit_GL_NV_register_combiners2(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_register_combiners2 */ +#ifdef GL_NV_shader_buffer_load + CONST_CAST(GLEW_NV_shader_buffer_load) = glewGetExtension("GL_NV_shader_buffer_load"); + if (glewExperimental || GLEW_NV_shader_buffer_load) CONST_CAST(GLEW_NV_shader_buffer_load) = !_glewInit_GL_NV_shader_buffer_load(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_shader_buffer_load */ +#ifdef GL_NV_tessellation_program5 + CONST_CAST(GLEW_NV_tessellation_program5) = glewGetExtension("GL_NV_gpu_program5"); +#endif /* GL_NV_tessellation_program5 */ +#ifdef GL_NV_texgen_emboss + CONST_CAST(GLEW_NV_texgen_emboss) = glewGetExtension("GL_NV_texgen_emboss"); +#endif /* GL_NV_texgen_emboss */ +#ifdef GL_NV_texgen_reflection + CONST_CAST(GLEW_NV_texgen_reflection) = glewGetExtension("GL_NV_texgen_reflection"); +#endif /* GL_NV_texgen_reflection */ +#ifdef GL_NV_texture_barrier + CONST_CAST(GLEW_NV_texture_barrier) = glewGetExtension("GL_NV_texture_barrier"); + if (glewExperimental || GLEW_NV_texture_barrier) CONST_CAST(GLEW_NV_texture_barrier) = !_glewInit_GL_NV_texture_barrier(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_texture_barrier */ +#ifdef GL_NV_texture_compression_vtc + CONST_CAST(GLEW_NV_texture_compression_vtc) = glewGetExtension("GL_NV_texture_compression_vtc"); +#endif /* GL_NV_texture_compression_vtc */ +#ifdef GL_NV_texture_env_combine4 + CONST_CAST(GLEW_NV_texture_env_combine4) = glewGetExtension("GL_NV_texture_env_combine4"); +#endif /* GL_NV_texture_env_combine4 */ +#ifdef GL_NV_texture_expand_normal + CONST_CAST(GLEW_NV_texture_expand_normal) = glewGetExtension("GL_NV_texture_expand_normal"); +#endif /* GL_NV_texture_expand_normal */ +#ifdef GL_NV_texture_rectangle + CONST_CAST(GLEW_NV_texture_rectangle) = glewGetExtension("GL_NV_texture_rectangle"); +#endif /* GL_NV_texture_rectangle */ +#ifdef GL_NV_texture_shader + CONST_CAST(GLEW_NV_texture_shader) = glewGetExtension("GL_NV_texture_shader"); +#endif /* GL_NV_texture_shader */ +#ifdef GL_NV_texture_shader2 + CONST_CAST(GLEW_NV_texture_shader2) = glewGetExtension("GL_NV_texture_shader2"); +#endif /* GL_NV_texture_shader2 */ +#ifdef GL_NV_texture_shader3 + CONST_CAST(GLEW_NV_texture_shader3) = glewGetExtension("GL_NV_texture_shader3"); +#endif /* GL_NV_texture_shader3 */ +#ifdef GL_NV_transform_feedback + CONST_CAST(GLEW_NV_transform_feedback) = glewGetExtension("GL_NV_transform_feedback"); + if (glewExperimental || GLEW_NV_transform_feedback) CONST_CAST(GLEW_NV_transform_feedback) = !_glewInit_GL_NV_transform_feedback(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_transform_feedback */ +#ifdef GL_NV_transform_feedback2 + CONST_CAST(GLEW_NV_transform_feedback2) = glewGetExtension("GL_NV_transform_feedback2"); + if (glewExperimental || GLEW_NV_transform_feedback2) CONST_CAST(GLEW_NV_transform_feedback2) = !_glewInit_GL_NV_transform_feedback2(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_transform_feedback2 */ +#ifdef GL_NV_vertex_array_range + CONST_CAST(GLEW_NV_vertex_array_range) = glewGetExtension("GL_NV_vertex_array_range"); + if (glewExperimental || GLEW_NV_vertex_array_range) CONST_CAST(GLEW_NV_vertex_array_range) = !_glewInit_GL_NV_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_vertex_array_range */ +#ifdef GL_NV_vertex_array_range2 + CONST_CAST(GLEW_NV_vertex_array_range2) = glewGetExtension("GL_NV_vertex_array_range2"); +#endif /* GL_NV_vertex_array_range2 */ +#ifdef GL_NV_vertex_attrib_integer_64bit + CONST_CAST(GLEW_NV_vertex_attrib_integer_64bit) = glewGetExtension("GL_NV_vertex_attrib_integer_64bit"); + if (glewExperimental || GLEW_NV_vertex_attrib_integer_64bit) CONST_CAST(GLEW_NV_vertex_attrib_integer_64bit) = !_glewInit_GL_NV_vertex_attrib_integer_64bit(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_vertex_attrib_integer_64bit */ +#ifdef GL_NV_vertex_buffer_unified_memory + CONST_CAST(GLEW_NV_vertex_buffer_unified_memory) = glewGetExtension("GL_NV_vertex_buffer_unified_memory"); + if (glewExperimental || GLEW_NV_vertex_buffer_unified_memory) CONST_CAST(GLEW_NV_vertex_buffer_unified_memory) = !_glewInit_GL_NV_vertex_buffer_unified_memory(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_vertex_buffer_unified_memory */ +#ifdef GL_NV_vertex_program + CONST_CAST(GLEW_NV_vertex_program) = glewGetExtension("GL_NV_vertex_program"); + if (glewExperimental || GLEW_NV_vertex_program) CONST_CAST(GLEW_NV_vertex_program) = !_glewInit_GL_NV_vertex_program(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_NV_vertex_program */ +#ifdef GL_NV_vertex_program1_1 + CONST_CAST(GLEW_NV_vertex_program1_1) = glewGetExtension("GL_NV_vertex_program1_1"); +#endif /* GL_NV_vertex_program1_1 */ +#ifdef GL_NV_vertex_program2 + CONST_CAST(GLEW_NV_vertex_program2) = glewGetExtension("GL_NV_vertex_program2"); +#endif /* GL_NV_vertex_program2 */ +#ifdef GL_NV_vertex_program2_option + CONST_CAST(GLEW_NV_vertex_program2_option) = glewGetExtension("GL_NV_vertex_program2_option"); +#endif /* GL_NV_vertex_program2_option */ +#ifdef GL_NV_vertex_program3 + CONST_CAST(GLEW_NV_vertex_program3) = glewGetExtension("GL_NV_vertex_program3"); +#endif /* GL_NV_vertex_program3 */ +#ifdef GL_NV_vertex_program4 + CONST_CAST(GLEW_NV_vertex_program4) = glewGetExtension("GL_NV_gpu_program4"); +#endif /* GL_NV_vertex_program4 */ +#ifdef GL_OES_byte_coordinates + CONST_CAST(GLEW_OES_byte_coordinates) = glewGetExtension("GL_OES_byte_coordinates"); +#endif /* GL_OES_byte_coordinates */ +#ifdef GL_OES_compressed_paletted_texture + CONST_CAST(GLEW_OES_compressed_paletted_texture) = glewGetExtension("GL_OES_compressed_paletted_texture"); +#endif /* GL_OES_compressed_paletted_texture */ +#ifdef GL_OES_read_format + CONST_CAST(GLEW_OES_read_format) = glewGetExtension("GL_OES_read_format"); +#endif /* GL_OES_read_format */ +#ifdef GL_OES_single_precision + CONST_CAST(GLEW_OES_single_precision) = glewGetExtension("GL_OES_single_precision"); + if (glewExperimental || GLEW_OES_single_precision) CONST_CAST(GLEW_OES_single_precision) = !_glewInit_GL_OES_single_precision(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_OES_single_precision */ +#ifdef GL_OML_interlace + CONST_CAST(GLEW_OML_interlace) = glewGetExtension("GL_OML_interlace"); +#endif /* GL_OML_interlace */ +#ifdef GL_OML_resample + CONST_CAST(GLEW_OML_resample) = glewGetExtension("GL_OML_resample"); +#endif /* GL_OML_resample */ +#ifdef GL_OML_subsample + CONST_CAST(GLEW_OML_subsample) = glewGetExtension("GL_OML_subsample"); +#endif /* GL_OML_subsample */ +#ifdef GL_PGI_misc_hints + CONST_CAST(GLEW_PGI_misc_hints) = glewGetExtension("GL_PGI_misc_hints"); +#endif /* GL_PGI_misc_hints */ +#ifdef GL_PGI_vertex_hints + CONST_CAST(GLEW_PGI_vertex_hints) = glewGetExtension("GL_PGI_vertex_hints"); +#endif /* GL_PGI_vertex_hints */ +#ifdef GL_REND_screen_coordinates + CONST_CAST(GLEW_REND_screen_coordinates) = glewGetExtension("GL_REND_screen_coordinates"); +#endif /* GL_REND_screen_coordinates */ +#ifdef GL_S3_s3tc + CONST_CAST(GLEW_S3_s3tc) = glewGetExtension("GL_S3_s3tc"); +#endif /* GL_S3_s3tc */ +#ifdef GL_SGIS_color_range + CONST_CAST(GLEW_SGIS_color_range) = glewGetExtension("GL_SGIS_color_range"); +#endif /* GL_SGIS_color_range */ +#ifdef GL_SGIS_detail_texture + CONST_CAST(GLEW_SGIS_detail_texture) = glewGetExtension("GL_SGIS_detail_texture"); + if (glewExperimental || GLEW_SGIS_detail_texture) CONST_CAST(GLEW_SGIS_detail_texture) = !_glewInit_GL_SGIS_detail_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIS_detail_texture */ +#ifdef GL_SGIS_fog_function + CONST_CAST(GLEW_SGIS_fog_function) = glewGetExtension("GL_SGIS_fog_function"); + if (glewExperimental || GLEW_SGIS_fog_function) CONST_CAST(GLEW_SGIS_fog_function) = !_glewInit_GL_SGIS_fog_function(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIS_fog_function */ +#ifdef GL_SGIS_generate_mipmap + CONST_CAST(GLEW_SGIS_generate_mipmap) = glewGetExtension("GL_SGIS_generate_mipmap"); +#endif /* GL_SGIS_generate_mipmap */ +#ifdef GL_SGIS_multisample + CONST_CAST(GLEW_SGIS_multisample) = glewGetExtension("GL_SGIS_multisample"); + if (glewExperimental || GLEW_SGIS_multisample) CONST_CAST(GLEW_SGIS_multisample) = !_glewInit_GL_SGIS_multisample(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIS_multisample */ +#ifdef GL_SGIS_pixel_texture + CONST_CAST(GLEW_SGIS_pixel_texture) = glewGetExtension("GL_SGIS_pixel_texture"); +#endif /* GL_SGIS_pixel_texture */ +#ifdef GL_SGIS_point_line_texgen + CONST_CAST(GLEW_SGIS_point_line_texgen) = glewGetExtension("GL_SGIS_point_line_texgen"); +#endif /* GL_SGIS_point_line_texgen */ +#ifdef GL_SGIS_sharpen_texture + CONST_CAST(GLEW_SGIS_sharpen_texture) = glewGetExtension("GL_SGIS_sharpen_texture"); + if (glewExperimental || GLEW_SGIS_sharpen_texture) CONST_CAST(GLEW_SGIS_sharpen_texture) = !_glewInit_GL_SGIS_sharpen_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIS_sharpen_texture */ +#ifdef GL_SGIS_texture4D + CONST_CAST(GLEW_SGIS_texture4D) = glewGetExtension("GL_SGIS_texture4D"); + if (glewExperimental || GLEW_SGIS_texture4D) CONST_CAST(GLEW_SGIS_texture4D) = !_glewInit_GL_SGIS_texture4D(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIS_texture4D */ +#ifdef GL_SGIS_texture_border_clamp + CONST_CAST(GLEW_SGIS_texture_border_clamp) = glewGetExtension("GL_SGIS_texture_border_clamp"); +#endif /* GL_SGIS_texture_border_clamp */ +#ifdef GL_SGIS_texture_edge_clamp + CONST_CAST(GLEW_SGIS_texture_edge_clamp) = glewGetExtension("GL_SGIS_texture_edge_clamp"); +#endif /* GL_SGIS_texture_edge_clamp */ +#ifdef GL_SGIS_texture_filter4 + CONST_CAST(GLEW_SGIS_texture_filter4) = glewGetExtension("GL_SGIS_texture_filter4"); + if (glewExperimental || GLEW_SGIS_texture_filter4) CONST_CAST(GLEW_SGIS_texture_filter4) = !_glewInit_GL_SGIS_texture_filter4(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIS_texture_filter4 */ +#ifdef GL_SGIS_texture_lod + CONST_CAST(GLEW_SGIS_texture_lod) = glewGetExtension("GL_SGIS_texture_lod"); +#endif /* GL_SGIS_texture_lod */ +#ifdef GL_SGIS_texture_select + CONST_CAST(GLEW_SGIS_texture_select) = glewGetExtension("GL_SGIS_texture_select"); +#endif /* GL_SGIS_texture_select */ +#ifdef GL_SGIX_async + CONST_CAST(GLEW_SGIX_async) = glewGetExtension("GL_SGIX_async"); + if (glewExperimental || GLEW_SGIX_async) CONST_CAST(GLEW_SGIX_async) = !_glewInit_GL_SGIX_async(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_async */ +#ifdef GL_SGIX_async_histogram + CONST_CAST(GLEW_SGIX_async_histogram) = glewGetExtension("GL_SGIX_async_histogram"); +#endif /* GL_SGIX_async_histogram */ +#ifdef GL_SGIX_async_pixel + CONST_CAST(GLEW_SGIX_async_pixel) = glewGetExtension("GL_SGIX_async_pixel"); +#endif /* GL_SGIX_async_pixel */ +#ifdef GL_SGIX_blend_alpha_minmax + CONST_CAST(GLEW_SGIX_blend_alpha_minmax) = glewGetExtension("GL_SGIX_blend_alpha_minmax"); +#endif /* GL_SGIX_blend_alpha_minmax */ +#ifdef GL_SGIX_clipmap + CONST_CAST(GLEW_SGIX_clipmap) = glewGetExtension("GL_SGIX_clipmap"); +#endif /* GL_SGIX_clipmap */ +#ifdef GL_SGIX_convolution_accuracy + CONST_CAST(GLEW_SGIX_convolution_accuracy) = glewGetExtension("GL_SGIX_convolution_accuracy"); +#endif /* GL_SGIX_convolution_accuracy */ +#ifdef GL_SGIX_depth_texture + CONST_CAST(GLEW_SGIX_depth_texture) = glewGetExtension("GL_SGIX_depth_texture"); +#endif /* GL_SGIX_depth_texture */ +#ifdef GL_SGIX_flush_raster + CONST_CAST(GLEW_SGIX_flush_raster) = glewGetExtension("GL_SGIX_flush_raster"); + if (glewExperimental || GLEW_SGIX_flush_raster) CONST_CAST(GLEW_SGIX_flush_raster) = !_glewInit_GL_SGIX_flush_raster(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_flush_raster */ +#ifdef GL_SGIX_fog_offset + CONST_CAST(GLEW_SGIX_fog_offset) = glewGetExtension("GL_SGIX_fog_offset"); +#endif /* GL_SGIX_fog_offset */ +#ifdef GL_SGIX_fog_texture + CONST_CAST(GLEW_SGIX_fog_texture) = glewGetExtension("GL_SGIX_fog_texture"); + if (glewExperimental || GLEW_SGIX_fog_texture) CONST_CAST(GLEW_SGIX_fog_texture) = !_glewInit_GL_SGIX_fog_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_fog_texture */ +#ifdef GL_SGIX_fragment_specular_lighting + CONST_CAST(GLEW_SGIX_fragment_specular_lighting) = glewGetExtension("GL_SGIX_fragment_specular_lighting"); + if (glewExperimental || GLEW_SGIX_fragment_specular_lighting) CONST_CAST(GLEW_SGIX_fragment_specular_lighting) = !_glewInit_GL_SGIX_fragment_specular_lighting(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_fragment_specular_lighting */ +#ifdef GL_SGIX_framezoom + CONST_CAST(GLEW_SGIX_framezoom) = glewGetExtension("GL_SGIX_framezoom"); + if (glewExperimental || GLEW_SGIX_framezoom) CONST_CAST(GLEW_SGIX_framezoom) = !_glewInit_GL_SGIX_framezoom(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_framezoom */ +#ifdef GL_SGIX_interlace + CONST_CAST(GLEW_SGIX_interlace) = glewGetExtension("GL_SGIX_interlace"); +#endif /* GL_SGIX_interlace */ +#ifdef GL_SGIX_ir_instrument1 + CONST_CAST(GLEW_SGIX_ir_instrument1) = glewGetExtension("GL_SGIX_ir_instrument1"); +#endif /* GL_SGIX_ir_instrument1 */ +#ifdef GL_SGIX_list_priority + CONST_CAST(GLEW_SGIX_list_priority) = glewGetExtension("GL_SGIX_list_priority"); +#endif /* GL_SGIX_list_priority */ +#ifdef GL_SGIX_pixel_texture + CONST_CAST(GLEW_SGIX_pixel_texture) = glewGetExtension("GL_SGIX_pixel_texture"); + if (glewExperimental || GLEW_SGIX_pixel_texture) CONST_CAST(GLEW_SGIX_pixel_texture) = !_glewInit_GL_SGIX_pixel_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_pixel_texture */ +#ifdef GL_SGIX_pixel_texture_bits + CONST_CAST(GLEW_SGIX_pixel_texture_bits) = glewGetExtension("GL_SGIX_pixel_texture_bits"); +#endif /* GL_SGIX_pixel_texture_bits */ +#ifdef GL_SGIX_reference_plane + CONST_CAST(GLEW_SGIX_reference_plane) = glewGetExtension("GL_SGIX_reference_plane"); + if (glewExperimental || GLEW_SGIX_reference_plane) CONST_CAST(GLEW_SGIX_reference_plane) = !_glewInit_GL_SGIX_reference_plane(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_reference_plane */ +#ifdef GL_SGIX_resample + CONST_CAST(GLEW_SGIX_resample) = glewGetExtension("GL_SGIX_resample"); +#endif /* GL_SGIX_resample */ +#ifdef GL_SGIX_shadow + CONST_CAST(GLEW_SGIX_shadow) = glewGetExtension("GL_SGIX_shadow"); +#endif /* GL_SGIX_shadow */ +#ifdef GL_SGIX_shadow_ambient + CONST_CAST(GLEW_SGIX_shadow_ambient) = glewGetExtension("GL_SGIX_shadow_ambient"); +#endif /* GL_SGIX_shadow_ambient */ +#ifdef GL_SGIX_sprite + CONST_CAST(GLEW_SGIX_sprite) = glewGetExtension("GL_SGIX_sprite"); + if (glewExperimental || GLEW_SGIX_sprite) CONST_CAST(GLEW_SGIX_sprite) = !_glewInit_GL_SGIX_sprite(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_sprite */ +#ifdef GL_SGIX_tag_sample_buffer + CONST_CAST(GLEW_SGIX_tag_sample_buffer) = glewGetExtension("GL_SGIX_tag_sample_buffer"); + if (glewExperimental || GLEW_SGIX_tag_sample_buffer) CONST_CAST(GLEW_SGIX_tag_sample_buffer) = !_glewInit_GL_SGIX_tag_sample_buffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGIX_tag_sample_buffer */ +#ifdef GL_SGIX_texture_add_env + CONST_CAST(GLEW_SGIX_texture_add_env) = glewGetExtension("GL_SGIX_texture_add_env"); +#endif /* GL_SGIX_texture_add_env */ +#ifdef GL_SGIX_texture_coordinate_clamp + CONST_CAST(GLEW_SGIX_texture_coordinate_clamp) = glewGetExtension("GL_SGIX_texture_coordinate_clamp"); +#endif /* GL_SGIX_texture_coordinate_clamp */ +#ifdef GL_SGIX_texture_lod_bias + CONST_CAST(GLEW_SGIX_texture_lod_bias) = glewGetExtension("GL_SGIX_texture_lod_bias"); +#endif /* GL_SGIX_texture_lod_bias */ +#ifdef GL_SGIX_texture_multi_buffer + CONST_CAST(GLEW_SGIX_texture_multi_buffer) = glewGetExtension("GL_SGIX_texture_multi_buffer"); +#endif /* GL_SGIX_texture_multi_buffer */ +#ifdef GL_SGIX_texture_range + CONST_CAST(GLEW_SGIX_texture_range) = glewGetExtension("GL_SGIX_texture_range"); +#endif /* GL_SGIX_texture_range */ +#ifdef GL_SGIX_texture_scale_bias + CONST_CAST(GLEW_SGIX_texture_scale_bias) = glewGetExtension("GL_SGIX_texture_scale_bias"); +#endif /* GL_SGIX_texture_scale_bias */ +#ifdef GL_SGIX_vertex_preclip + CONST_CAST(GLEW_SGIX_vertex_preclip) = glewGetExtension("GL_SGIX_vertex_preclip"); +#endif /* GL_SGIX_vertex_preclip */ +#ifdef GL_SGIX_vertex_preclip_hint + CONST_CAST(GLEW_SGIX_vertex_preclip_hint) = glewGetExtension("GL_SGIX_vertex_preclip_hint"); +#endif /* GL_SGIX_vertex_preclip_hint */ +#ifdef GL_SGIX_ycrcb + CONST_CAST(GLEW_SGIX_ycrcb) = glewGetExtension("GL_SGIX_ycrcb"); +#endif /* GL_SGIX_ycrcb */ +#ifdef GL_SGI_color_matrix + CONST_CAST(GLEW_SGI_color_matrix) = glewGetExtension("GL_SGI_color_matrix"); +#endif /* GL_SGI_color_matrix */ +#ifdef GL_SGI_color_table + CONST_CAST(GLEW_SGI_color_table) = glewGetExtension("GL_SGI_color_table"); + if (glewExperimental || GLEW_SGI_color_table) CONST_CAST(GLEW_SGI_color_table) = !_glewInit_GL_SGI_color_table(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SGI_color_table */ +#ifdef GL_SGI_texture_color_table + CONST_CAST(GLEW_SGI_texture_color_table) = glewGetExtension("GL_SGI_texture_color_table"); +#endif /* GL_SGI_texture_color_table */ +#ifdef GL_SUNX_constant_data + CONST_CAST(GLEW_SUNX_constant_data) = glewGetExtension("GL_SUNX_constant_data"); + if (glewExperimental || GLEW_SUNX_constant_data) CONST_CAST(GLEW_SUNX_constant_data) = !_glewInit_GL_SUNX_constant_data(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SUNX_constant_data */ +#ifdef GL_SUN_convolution_border_modes + CONST_CAST(GLEW_SUN_convolution_border_modes) = glewGetExtension("GL_SUN_convolution_border_modes"); +#endif /* GL_SUN_convolution_border_modes */ +#ifdef GL_SUN_global_alpha + CONST_CAST(GLEW_SUN_global_alpha) = glewGetExtension("GL_SUN_global_alpha"); + if (glewExperimental || GLEW_SUN_global_alpha) CONST_CAST(GLEW_SUN_global_alpha) = !_glewInit_GL_SUN_global_alpha(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SUN_global_alpha */ +#ifdef GL_SUN_mesh_array + CONST_CAST(GLEW_SUN_mesh_array) = glewGetExtension("GL_SUN_mesh_array"); +#endif /* GL_SUN_mesh_array */ +#ifdef GL_SUN_read_video_pixels + CONST_CAST(GLEW_SUN_read_video_pixels) = glewGetExtension("GL_SUN_read_video_pixels"); + if (glewExperimental || GLEW_SUN_read_video_pixels) CONST_CAST(GLEW_SUN_read_video_pixels) = !_glewInit_GL_SUN_read_video_pixels(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SUN_read_video_pixels */ +#ifdef GL_SUN_slice_accum + CONST_CAST(GLEW_SUN_slice_accum) = glewGetExtension("GL_SUN_slice_accum"); +#endif /* GL_SUN_slice_accum */ +#ifdef GL_SUN_triangle_list + CONST_CAST(GLEW_SUN_triangle_list) = glewGetExtension("GL_SUN_triangle_list"); + if (glewExperimental || GLEW_SUN_triangle_list) CONST_CAST(GLEW_SUN_triangle_list) = !_glewInit_GL_SUN_triangle_list(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SUN_triangle_list */ +#ifdef GL_SUN_vertex + CONST_CAST(GLEW_SUN_vertex) = glewGetExtension("GL_SUN_vertex"); + if (glewExperimental || GLEW_SUN_vertex) CONST_CAST(GLEW_SUN_vertex) = !_glewInit_GL_SUN_vertex(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_SUN_vertex */ +#ifdef GL_WIN_phong_shading + CONST_CAST(GLEW_WIN_phong_shading) = glewGetExtension("GL_WIN_phong_shading"); +#endif /* GL_WIN_phong_shading */ +#ifdef GL_WIN_specular_fog + CONST_CAST(GLEW_WIN_specular_fog) = glewGetExtension("GL_WIN_specular_fog"); +#endif /* GL_WIN_specular_fog */ +#ifdef GL_WIN_swap_hint + CONST_CAST(GLEW_WIN_swap_hint) = glewGetExtension("GL_WIN_swap_hint"); + if (glewExperimental || GLEW_WIN_swap_hint) CONST_CAST(GLEW_WIN_swap_hint) = !_glewInit_GL_WIN_swap_hint(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GL_WIN_swap_hint */ + + return GLEW_OK; +} + + +#if defined(_WIN32) + +#if !defined(GLEW_MX) + +PFNWGLSETSTEREOEMITTERSTATE3DLPROC __wglewSetStereoEmitterState3DL = NULL; + +PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC __wglewBlitContextFramebufferAMD = NULL; +PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC __wglewCreateAssociatedContextAMD = NULL; +PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC __wglewCreateAssociatedContextAttribsAMD = NULL; +PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC __wglewDeleteAssociatedContextAMD = NULL; +PFNWGLGETCONTEXTGPUIDAMDPROC __wglewGetContextGPUIDAMD = NULL; +PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC __wglewGetCurrentAssociatedContextAMD = NULL; +PFNWGLGETGPUIDSAMDPROC __wglewGetGPUIDsAMD = NULL; +PFNWGLGETGPUINFOAMDPROC __wglewGetGPUInfoAMD = NULL; +PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC __wglewMakeAssociatedContextCurrentAMD = NULL; + +PFNWGLCREATEBUFFERREGIONARBPROC __wglewCreateBufferRegionARB = NULL; +PFNWGLDELETEBUFFERREGIONARBPROC __wglewDeleteBufferRegionARB = NULL; +PFNWGLRESTOREBUFFERREGIONARBPROC __wglewRestoreBufferRegionARB = NULL; +PFNWGLSAVEBUFFERREGIONARBPROC __wglewSaveBufferRegionARB = NULL; + +PFNWGLCREATECONTEXTATTRIBSARBPROC __wglewCreateContextAttribsARB = NULL; + +PFNWGLGETEXTENSIONSSTRINGARBPROC __wglewGetExtensionsStringARB = NULL; + +PFNWGLGETCURRENTREADDCARBPROC __wglewGetCurrentReadDCARB = NULL; +PFNWGLMAKECONTEXTCURRENTARBPROC __wglewMakeContextCurrentARB = NULL; + +PFNWGLCREATEPBUFFERARBPROC __wglewCreatePbufferARB = NULL; +PFNWGLDESTROYPBUFFERARBPROC __wglewDestroyPbufferARB = NULL; +PFNWGLGETPBUFFERDCARBPROC __wglewGetPbufferDCARB = NULL; +PFNWGLQUERYPBUFFERARBPROC __wglewQueryPbufferARB = NULL; +PFNWGLRELEASEPBUFFERDCARBPROC __wglewReleasePbufferDCARB = NULL; + +PFNWGLCHOOSEPIXELFORMATARBPROC __wglewChoosePixelFormatARB = NULL; +PFNWGLGETPIXELFORMATATTRIBFVARBPROC __wglewGetPixelFormatAttribfvARB = NULL; +PFNWGLGETPIXELFORMATATTRIBIVARBPROC __wglewGetPixelFormatAttribivARB = NULL; + +PFNWGLBINDTEXIMAGEARBPROC __wglewBindTexImageARB = NULL; +PFNWGLRELEASETEXIMAGEARBPROC __wglewReleaseTexImageARB = NULL; +PFNWGLSETPBUFFERATTRIBARBPROC __wglewSetPbufferAttribARB = NULL; + +PFNWGLBINDDISPLAYCOLORTABLEEXTPROC __wglewBindDisplayColorTableEXT = NULL; +PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC __wglewCreateDisplayColorTableEXT = NULL; +PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC __wglewDestroyDisplayColorTableEXT = NULL; +PFNWGLLOADDISPLAYCOLORTABLEEXTPROC __wglewLoadDisplayColorTableEXT = NULL; + +PFNWGLGETEXTENSIONSSTRINGEXTPROC __wglewGetExtensionsStringEXT = NULL; + +PFNWGLGETCURRENTREADDCEXTPROC __wglewGetCurrentReadDCEXT = NULL; +PFNWGLMAKECONTEXTCURRENTEXTPROC __wglewMakeContextCurrentEXT = NULL; + +PFNWGLCREATEPBUFFEREXTPROC __wglewCreatePbufferEXT = NULL; +PFNWGLDESTROYPBUFFEREXTPROC __wglewDestroyPbufferEXT = NULL; +PFNWGLGETPBUFFERDCEXTPROC __wglewGetPbufferDCEXT = NULL; +PFNWGLQUERYPBUFFEREXTPROC __wglewQueryPbufferEXT = NULL; +PFNWGLRELEASEPBUFFERDCEXTPROC __wglewReleasePbufferDCEXT = NULL; + +PFNWGLCHOOSEPIXELFORMATEXTPROC __wglewChoosePixelFormatEXT = NULL; +PFNWGLGETPIXELFORMATATTRIBFVEXTPROC __wglewGetPixelFormatAttribfvEXT = NULL; +PFNWGLGETPIXELFORMATATTRIBIVEXTPROC __wglewGetPixelFormatAttribivEXT = NULL; + +PFNWGLGETSWAPINTERVALEXTPROC __wglewGetSwapIntervalEXT = NULL; +PFNWGLSWAPINTERVALEXTPROC __wglewSwapIntervalEXT = NULL; + +PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC __wglewGetDigitalVideoParametersI3D = NULL; +PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC __wglewSetDigitalVideoParametersI3D = NULL; + +PFNWGLGETGAMMATABLEI3DPROC __wglewGetGammaTableI3D = NULL; +PFNWGLGETGAMMATABLEPARAMETERSI3DPROC __wglewGetGammaTableParametersI3D = NULL; +PFNWGLSETGAMMATABLEI3DPROC __wglewSetGammaTableI3D = NULL; +PFNWGLSETGAMMATABLEPARAMETERSI3DPROC __wglewSetGammaTableParametersI3D = NULL; + +PFNWGLDISABLEGENLOCKI3DPROC __wglewDisableGenlockI3D = NULL; +PFNWGLENABLEGENLOCKI3DPROC __wglewEnableGenlockI3D = NULL; +PFNWGLGENLOCKSAMPLERATEI3DPROC __wglewGenlockSampleRateI3D = NULL; +PFNWGLGENLOCKSOURCEDELAYI3DPROC __wglewGenlockSourceDelayI3D = NULL; +PFNWGLGENLOCKSOURCEEDGEI3DPROC __wglewGenlockSourceEdgeI3D = NULL; +PFNWGLGENLOCKSOURCEI3DPROC __wglewGenlockSourceI3D = NULL; +PFNWGLGETGENLOCKSAMPLERATEI3DPROC __wglewGetGenlockSampleRateI3D = NULL; +PFNWGLGETGENLOCKSOURCEDELAYI3DPROC __wglewGetGenlockSourceDelayI3D = NULL; +PFNWGLGETGENLOCKSOURCEEDGEI3DPROC __wglewGetGenlockSourceEdgeI3D = NULL; +PFNWGLGETGENLOCKSOURCEI3DPROC __wglewGetGenlockSourceI3D = NULL; +PFNWGLISENABLEDGENLOCKI3DPROC __wglewIsEnabledGenlockI3D = NULL; +PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC __wglewQueryGenlockMaxSourceDelayI3D = NULL; + +PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC __wglewAssociateImageBufferEventsI3D = NULL; +PFNWGLCREATEIMAGEBUFFERI3DPROC __wglewCreateImageBufferI3D = NULL; +PFNWGLDESTROYIMAGEBUFFERI3DPROC __wglewDestroyImageBufferI3D = NULL; +PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC __wglewReleaseImageBufferEventsI3D = NULL; + +PFNWGLDISABLEFRAMELOCKI3DPROC __wglewDisableFrameLockI3D = NULL; +PFNWGLENABLEFRAMELOCKI3DPROC __wglewEnableFrameLockI3D = NULL; +PFNWGLISENABLEDFRAMELOCKI3DPROC __wglewIsEnabledFrameLockI3D = NULL; +PFNWGLQUERYFRAMELOCKMASTERI3DPROC __wglewQueryFrameLockMasterI3D = NULL; + +PFNWGLBEGINFRAMETRACKINGI3DPROC __wglewBeginFrameTrackingI3D = NULL; +PFNWGLENDFRAMETRACKINGI3DPROC __wglewEndFrameTrackingI3D = NULL; +PFNWGLGETFRAMEUSAGEI3DPROC __wglewGetFrameUsageI3D = NULL; +PFNWGLQUERYFRAMETRACKINGI3DPROC __wglewQueryFrameTrackingI3D = NULL; + +PFNWGLCOPYIMAGESUBDATANVPROC __wglewCopyImageSubDataNV = NULL; + +PFNWGLCREATEAFFINITYDCNVPROC __wglewCreateAffinityDCNV = NULL; +PFNWGLDELETEDCNVPROC __wglewDeleteDCNV = NULL; +PFNWGLENUMGPUDEVICESNVPROC __wglewEnumGpuDevicesNV = NULL; +PFNWGLENUMGPUSFROMAFFINITYDCNVPROC __wglewEnumGpusFromAffinityDCNV = NULL; +PFNWGLENUMGPUSNVPROC __wglewEnumGpusNV = NULL; + +PFNWGLBINDVIDEODEVICENVPROC __wglewBindVideoDeviceNV = NULL; +PFNWGLENUMERATEVIDEODEVICESNVPROC __wglewEnumerateVideoDevicesNV = NULL; +PFNWGLQUERYCURRENTCONTEXTNVPROC __wglewQueryCurrentContextNV = NULL; + +PFNWGLBINDSWAPBARRIERNVPROC __wglewBindSwapBarrierNV = NULL; +PFNWGLJOINSWAPGROUPNVPROC __wglewJoinSwapGroupNV = NULL; +PFNWGLQUERYFRAMECOUNTNVPROC __wglewQueryFrameCountNV = NULL; +PFNWGLQUERYMAXSWAPGROUPSNVPROC __wglewQueryMaxSwapGroupsNV = NULL; +PFNWGLQUERYSWAPGROUPNVPROC __wglewQuerySwapGroupNV = NULL; +PFNWGLRESETFRAMECOUNTNVPROC __wglewResetFrameCountNV = NULL; + +PFNWGLALLOCATEMEMORYNVPROC __wglewAllocateMemoryNV = NULL; +PFNWGLFREEMEMORYNVPROC __wglewFreeMemoryNV = NULL; + +PFNWGLBINDVIDEOIMAGENVPROC __wglewBindVideoImageNV = NULL; +PFNWGLGETVIDEODEVICENVPROC __wglewGetVideoDeviceNV = NULL; +PFNWGLGETVIDEOINFONVPROC __wglewGetVideoInfoNV = NULL; +PFNWGLRELEASEVIDEODEVICENVPROC __wglewReleaseVideoDeviceNV = NULL; +PFNWGLRELEASEVIDEOIMAGENVPROC __wglewReleaseVideoImageNV = NULL; +PFNWGLSENDPBUFFERTOVIDEONVPROC __wglewSendPbufferToVideoNV = NULL; + +PFNWGLGETMSCRATEOMLPROC __wglewGetMscRateOML = NULL; +PFNWGLGETSYNCVALUESOMLPROC __wglewGetSyncValuesOML = NULL; +PFNWGLSWAPBUFFERSMSCOMLPROC __wglewSwapBuffersMscOML = NULL; +PFNWGLSWAPLAYERBUFFERSMSCOMLPROC __wglewSwapLayerBuffersMscOML = NULL; +PFNWGLWAITFORMSCOMLPROC __wglewWaitForMscOML = NULL; +PFNWGLWAITFORSBCOMLPROC __wglewWaitForSbcOML = NULL; +GLboolean __WGLEW_3DFX_multisample = GL_FALSE; +GLboolean __WGLEW_3DL_stereo_control = GL_FALSE; +GLboolean __WGLEW_AMD_gpu_association = GL_FALSE; +GLboolean __WGLEW_ARB_buffer_region = GL_FALSE; +GLboolean __WGLEW_ARB_create_context = GL_FALSE; +GLboolean __WGLEW_ARB_create_context_profile = GL_FALSE; +GLboolean __WGLEW_ARB_extensions_string = GL_FALSE; +GLboolean __WGLEW_ARB_framebuffer_sRGB = GL_FALSE; +GLboolean __WGLEW_ARB_make_current_read = GL_FALSE; +GLboolean __WGLEW_ARB_multisample = GL_FALSE; +GLboolean __WGLEW_ARB_pbuffer = GL_FALSE; +GLboolean __WGLEW_ARB_pixel_format = GL_FALSE; +GLboolean __WGLEW_ARB_pixel_format_float = GL_FALSE; +GLboolean __WGLEW_ARB_render_texture = GL_FALSE; +GLboolean __WGLEW_ATI_pixel_format_float = GL_FALSE; +GLboolean __WGLEW_ATI_render_texture_rectangle = GL_FALSE; +GLboolean __WGLEW_EXT_depth_float = GL_FALSE; +GLboolean __WGLEW_EXT_display_color_table = GL_FALSE; +GLboolean __WGLEW_EXT_extensions_string = GL_FALSE; +GLboolean __WGLEW_EXT_framebuffer_sRGB = GL_FALSE; +GLboolean __WGLEW_EXT_make_current_read = GL_FALSE; +GLboolean __WGLEW_EXT_multisample = GL_FALSE; +GLboolean __WGLEW_EXT_pbuffer = GL_FALSE; +GLboolean __WGLEW_EXT_pixel_format = GL_FALSE; +GLboolean __WGLEW_EXT_pixel_format_packed_float = GL_FALSE; +GLboolean __WGLEW_EXT_swap_control = GL_FALSE; +GLboolean __WGLEW_I3D_digital_video_control = GL_FALSE; +GLboolean __WGLEW_I3D_gamma = GL_FALSE; +GLboolean __WGLEW_I3D_genlock = GL_FALSE; +GLboolean __WGLEW_I3D_image_buffer = GL_FALSE; +GLboolean __WGLEW_I3D_swap_frame_lock = GL_FALSE; +GLboolean __WGLEW_I3D_swap_frame_usage = GL_FALSE; +GLboolean __WGLEW_NV_copy_image = GL_FALSE; +GLboolean __WGLEW_NV_float_buffer = GL_FALSE; +GLboolean __WGLEW_NV_gpu_affinity = GL_FALSE; +GLboolean __WGLEW_NV_present_video = GL_FALSE; +GLboolean __WGLEW_NV_render_depth_texture = GL_FALSE; +GLboolean __WGLEW_NV_render_texture_rectangle = GL_FALSE; +GLboolean __WGLEW_NV_swap_group = GL_FALSE; +GLboolean __WGLEW_NV_vertex_array_range = GL_FALSE; +GLboolean __WGLEW_NV_video_output = GL_FALSE; +GLboolean __WGLEW_OML_sync_control = GL_FALSE; + +#endif /* !GLEW_MX */ + +#ifdef WGL_3DFX_multisample + +#endif /* WGL_3DFX_multisample */ + +#ifdef WGL_3DL_stereo_control + +static GLboolean _glewInit_WGL_3DL_stereo_control (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglSetStereoEmitterState3DL = (PFNWGLSETSTEREOEMITTERSTATE3DLPROC)glewGetProcAddress((const GLubyte*)"wglSetStereoEmitterState3DL")) == NULL) || r; + + return r; +} + +#endif /* WGL_3DL_stereo_control */ + +#ifdef WGL_AMD_gpu_association + +static GLboolean _glewInit_WGL_AMD_gpu_association (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglBlitContextFramebufferAMD = (PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC)glewGetProcAddress((const GLubyte*)"wglBlitContextFramebufferAMD")) == NULL) || r; + r = ((wglCreateAssociatedContextAMD = (PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"wglCreateAssociatedContextAMD")) == NULL) || r; + r = ((wglCreateAssociatedContextAttribsAMD = (PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC)glewGetProcAddress((const GLubyte*)"wglCreateAssociatedContextAttribsAMD")) == NULL) || r; + r = ((wglDeleteAssociatedContextAMD = (PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"wglDeleteAssociatedContextAMD")) == NULL) || r; + r = ((wglGetContextGPUIDAMD = (PFNWGLGETCONTEXTGPUIDAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetContextGPUIDAMD")) == NULL) || r; + r = ((wglGetCurrentAssociatedContextAMD = (PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetCurrentAssociatedContextAMD")) == NULL) || r; + r = ((wglGetGPUIDsAMD = (PFNWGLGETGPUIDSAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetGPUIDsAMD")) == NULL) || r; + r = ((wglGetGPUInfoAMD = (PFNWGLGETGPUINFOAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetGPUInfoAMD")) == NULL) || r; + r = ((wglMakeAssociatedContextCurrentAMD = (PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC)glewGetProcAddress((const GLubyte*)"wglMakeAssociatedContextCurrentAMD")) == NULL) || r; + + return r; +} + +#endif /* WGL_AMD_gpu_association */ + +#ifdef WGL_ARB_buffer_region + +static GLboolean _glewInit_WGL_ARB_buffer_region (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglCreateBufferRegionARB = (PFNWGLCREATEBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglCreateBufferRegionARB")) == NULL) || r; + r = ((wglDeleteBufferRegionARB = (PFNWGLDELETEBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglDeleteBufferRegionARB")) == NULL) || r; + r = ((wglRestoreBufferRegionARB = (PFNWGLRESTOREBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglRestoreBufferRegionARB")) == NULL) || r; + r = ((wglSaveBufferRegionARB = (PFNWGLSAVEBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglSaveBufferRegionARB")) == NULL) || r; + + return r; +} + +#endif /* WGL_ARB_buffer_region */ + +#ifdef WGL_ARB_create_context + +static GLboolean _glewInit_WGL_ARB_create_context (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglCreateContextAttribsARB = (PFNWGLCREATECONTEXTATTRIBSARBPROC)glewGetProcAddress((const GLubyte*)"wglCreateContextAttribsARB")) == NULL) || r; + + return r; +} + +#endif /* WGL_ARB_create_context */ + +#ifdef WGL_ARB_create_context_profile + +#endif /* WGL_ARB_create_context_profile */ + +#ifdef WGL_ARB_extensions_string + +static GLboolean _glewInit_WGL_ARB_extensions_string (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetExtensionsStringARB = (PFNWGLGETEXTENSIONSSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringARB")) == NULL) || r; + + return r; +} + +#endif /* WGL_ARB_extensions_string */ + +#ifdef WGL_ARB_framebuffer_sRGB + +#endif /* WGL_ARB_framebuffer_sRGB */ + +#ifdef WGL_ARB_make_current_read + +static GLboolean _glewInit_WGL_ARB_make_current_read (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetCurrentReadDCARB = (PFNWGLGETCURRENTREADDCARBPROC)glewGetProcAddress((const GLubyte*)"wglGetCurrentReadDCARB")) == NULL) || r; + r = ((wglMakeContextCurrentARB = (PFNWGLMAKECONTEXTCURRENTARBPROC)glewGetProcAddress((const GLubyte*)"wglMakeContextCurrentARB")) == NULL) || r; + + return r; +} + +#endif /* WGL_ARB_make_current_read */ + +#ifdef WGL_ARB_multisample + +#endif /* WGL_ARB_multisample */ + +#ifdef WGL_ARB_pbuffer + +static GLboolean _glewInit_WGL_ARB_pbuffer (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglCreatePbufferARB = (PFNWGLCREATEPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"wglCreatePbufferARB")) == NULL) || r; + r = ((wglDestroyPbufferARB = (PFNWGLDESTROYPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"wglDestroyPbufferARB")) == NULL) || r; + r = ((wglGetPbufferDCARB = (PFNWGLGETPBUFFERDCARBPROC)glewGetProcAddress((const GLubyte*)"wglGetPbufferDCARB")) == NULL) || r; + r = ((wglQueryPbufferARB = (PFNWGLQUERYPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"wglQueryPbufferARB")) == NULL) || r; + r = ((wglReleasePbufferDCARB = (PFNWGLRELEASEPBUFFERDCARBPROC)glewGetProcAddress((const GLubyte*)"wglReleasePbufferDCARB")) == NULL) || r; + + return r; +} + +#endif /* WGL_ARB_pbuffer */ + +#ifdef WGL_ARB_pixel_format + +static GLboolean _glewInit_WGL_ARB_pixel_format (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglChoosePixelFormatARB = (PFNWGLCHOOSEPIXELFORMATARBPROC)glewGetProcAddress((const GLubyte*)"wglChoosePixelFormatARB")) == NULL) || r; + r = ((wglGetPixelFormatAttribfvARB = (PFNWGLGETPIXELFORMATATTRIBFVARBPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribfvARB")) == NULL) || r; + r = ((wglGetPixelFormatAttribivARB = (PFNWGLGETPIXELFORMATATTRIBIVARBPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribivARB")) == NULL) || r; + + return r; +} + +#endif /* WGL_ARB_pixel_format */ + +#ifdef WGL_ARB_pixel_format_float + +#endif /* WGL_ARB_pixel_format_float */ + +#ifdef WGL_ARB_render_texture + +static GLboolean _glewInit_WGL_ARB_render_texture (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglBindTexImageARB = (PFNWGLBINDTEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"wglBindTexImageARB")) == NULL) || r; + r = ((wglReleaseTexImageARB = (PFNWGLRELEASETEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"wglReleaseTexImageARB")) == NULL) || r; + r = ((wglSetPbufferAttribARB = (PFNWGLSETPBUFFERATTRIBARBPROC)glewGetProcAddress((const GLubyte*)"wglSetPbufferAttribARB")) == NULL) || r; + + return r; +} + +#endif /* WGL_ARB_render_texture */ + +#ifdef WGL_ATI_pixel_format_float + +#endif /* WGL_ATI_pixel_format_float */ + +#ifdef WGL_ATI_render_texture_rectangle + +#endif /* WGL_ATI_render_texture_rectangle */ + +#ifdef WGL_EXT_depth_float + +#endif /* WGL_EXT_depth_float */ + +#ifdef WGL_EXT_display_color_table + +static GLboolean _glewInit_WGL_EXT_display_color_table (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglBindDisplayColorTableEXT = (PFNWGLBINDDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglBindDisplayColorTableEXT")) == NULL) || r; + r = ((wglCreateDisplayColorTableEXT = (PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglCreateDisplayColorTableEXT")) == NULL) || r; + r = ((wglDestroyDisplayColorTableEXT = (PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglDestroyDisplayColorTableEXT")) == NULL) || r; + r = ((wglLoadDisplayColorTableEXT = (PFNWGLLOADDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglLoadDisplayColorTableEXT")) == NULL) || r; + + return r; +} + +#endif /* WGL_EXT_display_color_table */ + +#ifdef WGL_EXT_extensions_string + +static GLboolean _glewInit_WGL_EXT_extensions_string (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetExtensionsStringEXT = (PFNWGLGETEXTENSIONSSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringEXT")) == NULL) || r; + + return r; +} + +#endif /* WGL_EXT_extensions_string */ + +#ifdef WGL_EXT_framebuffer_sRGB + +#endif /* WGL_EXT_framebuffer_sRGB */ + +#ifdef WGL_EXT_make_current_read + +static GLboolean _glewInit_WGL_EXT_make_current_read (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetCurrentReadDCEXT = (PFNWGLGETCURRENTREADDCEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetCurrentReadDCEXT")) == NULL) || r; + r = ((wglMakeContextCurrentEXT = (PFNWGLMAKECONTEXTCURRENTEXTPROC)glewGetProcAddress((const GLubyte*)"wglMakeContextCurrentEXT")) == NULL) || r; + + return r; +} + +#endif /* WGL_EXT_make_current_read */ + +#ifdef WGL_EXT_multisample + +#endif /* WGL_EXT_multisample */ + +#ifdef WGL_EXT_pbuffer + +static GLboolean _glewInit_WGL_EXT_pbuffer (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglCreatePbufferEXT = (PFNWGLCREATEPBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"wglCreatePbufferEXT")) == NULL) || r; + r = ((wglDestroyPbufferEXT = (PFNWGLDESTROYPBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"wglDestroyPbufferEXT")) == NULL) || r; + r = ((wglGetPbufferDCEXT = (PFNWGLGETPBUFFERDCEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetPbufferDCEXT")) == NULL) || r; + r = ((wglQueryPbufferEXT = (PFNWGLQUERYPBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"wglQueryPbufferEXT")) == NULL) || r; + r = ((wglReleasePbufferDCEXT = (PFNWGLRELEASEPBUFFERDCEXTPROC)glewGetProcAddress((const GLubyte*)"wglReleasePbufferDCEXT")) == NULL) || r; + + return r; +} + +#endif /* WGL_EXT_pbuffer */ + +#ifdef WGL_EXT_pixel_format + +static GLboolean _glewInit_WGL_EXT_pixel_format (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglChoosePixelFormatEXT = (PFNWGLCHOOSEPIXELFORMATEXTPROC)glewGetProcAddress((const GLubyte*)"wglChoosePixelFormatEXT")) == NULL) || r; + r = ((wglGetPixelFormatAttribfvEXT = (PFNWGLGETPIXELFORMATATTRIBFVEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribfvEXT")) == NULL) || r; + r = ((wglGetPixelFormatAttribivEXT = (PFNWGLGETPIXELFORMATATTRIBIVEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribivEXT")) == NULL) || r; + + return r; +} + +#endif /* WGL_EXT_pixel_format */ + +#ifdef WGL_EXT_pixel_format_packed_float + +#endif /* WGL_EXT_pixel_format_packed_float */ + +#ifdef WGL_EXT_swap_control + +static GLboolean _glewInit_WGL_EXT_swap_control (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetSwapIntervalEXT = (PFNWGLGETSWAPINTERVALEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetSwapIntervalEXT")) == NULL) || r; + r = ((wglSwapIntervalEXT = (PFNWGLSWAPINTERVALEXTPROC)glewGetProcAddress((const GLubyte*)"wglSwapIntervalEXT")) == NULL) || r; + + return r; +} + +#endif /* WGL_EXT_swap_control */ + +#ifdef WGL_I3D_digital_video_control + +static GLboolean _glewInit_WGL_I3D_digital_video_control (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetDigitalVideoParametersI3D = (PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetDigitalVideoParametersI3D")) == NULL) || r; + r = ((wglSetDigitalVideoParametersI3D = (PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglSetDigitalVideoParametersI3D")) == NULL) || r; + + return r; +} + +#endif /* WGL_I3D_digital_video_control */ + +#ifdef WGL_I3D_gamma + +static GLboolean _glewInit_WGL_I3D_gamma (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetGammaTableI3D = (PFNWGLGETGAMMATABLEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGammaTableI3D")) == NULL) || r; + r = ((wglGetGammaTableParametersI3D = (PFNWGLGETGAMMATABLEPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGammaTableParametersI3D")) == NULL) || r; + r = ((wglSetGammaTableI3D = (PFNWGLSETGAMMATABLEI3DPROC)glewGetProcAddress((const GLubyte*)"wglSetGammaTableI3D")) == NULL) || r; + r = ((wglSetGammaTableParametersI3D = (PFNWGLSETGAMMATABLEPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglSetGammaTableParametersI3D")) == NULL) || r; + + return r; +} + +#endif /* WGL_I3D_gamma */ + +#ifdef WGL_I3D_genlock + +static GLboolean _glewInit_WGL_I3D_genlock (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglDisableGenlockI3D = (PFNWGLDISABLEGENLOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglDisableGenlockI3D")) == NULL) || r; + r = ((wglEnableGenlockI3D = (PFNWGLENABLEGENLOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglEnableGenlockI3D")) == NULL) || r; + r = ((wglGenlockSampleRateI3D = (PFNWGLGENLOCKSAMPLERATEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSampleRateI3D")) == NULL) || r; + r = ((wglGenlockSourceDelayI3D = (PFNWGLGENLOCKSOURCEDELAYI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSourceDelayI3D")) == NULL) || r; + r = ((wglGenlockSourceEdgeI3D = (PFNWGLGENLOCKSOURCEEDGEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSourceEdgeI3D")) == NULL) || r; + r = ((wglGenlockSourceI3D = (PFNWGLGENLOCKSOURCEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSourceI3D")) == NULL) || r; + r = ((wglGetGenlockSampleRateI3D = (PFNWGLGETGENLOCKSAMPLERATEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSampleRateI3D")) == NULL) || r; + r = ((wglGetGenlockSourceDelayI3D = (PFNWGLGETGENLOCKSOURCEDELAYI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSourceDelayI3D")) == NULL) || r; + r = ((wglGetGenlockSourceEdgeI3D = (PFNWGLGETGENLOCKSOURCEEDGEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSourceEdgeI3D")) == NULL) || r; + r = ((wglGetGenlockSourceI3D = (PFNWGLGETGENLOCKSOURCEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSourceI3D")) == NULL) || r; + r = ((wglIsEnabledGenlockI3D = (PFNWGLISENABLEDGENLOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglIsEnabledGenlockI3D")) == NULL) || r; + r = ((wglQueryGenlockMaxSourceDelayI3D = (PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC)glewGetProcAddress((const GLubyte*)"wglQueryGenlockMaxSourceDelayI3D")) == NULL) || r; + + return r; +} + +#endif /* WGL_I3D_genlock */ + +#ifdef WGL_I3D_image_buffer + +static GLboolean _glewInit_WGL_I3D_image_buffer (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglAssociateImageBufferEventsI3D = (PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC)glewGetProcAddress((const GLubyte*)"wglAssociateImageBufferEventsI3D")) == NULL) || r; + r = ((wglCreateImageBufferI3D = (PFNWGLCREATEIMAGEBUFFERI3DPROC)glewGetProcAddress((const GLubyte*)"wglCreateImageBufferI3D")) == NULL) || r; + r = ((wglDestroyImageBufferI3D = (PFNWGLDESTROYIMAGEBUFFERI3DPROC)glewGetProcAddress((const GLubyte*)"wglDestroyImageBufferI3D")) == NULL) || r; + r = ((wglReleaseImageBufferEventsI3D = (PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC)glewGetProcAddress((const GLubyte*)"wglReleaseImageBufferEventsI3D")) == NULL) || r; + + return r; +} + +#endif /* WGL_I3D_image_buffer */ + +#ifdef WGL_I3D_swap_frame_lock + +static GLboolean _glewInit_WGL_I3D_swap_frame_lock (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglDisableFrameLockI3D = (PFNWGLDISABLEFRAMELOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglDisableFrameLockI3D")) == NULL) || r; + r = ((wglEnableFrameLockI3D = (PFNWGLENABLEFRAMELOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglEnableFrameLockI3D")) == NULL) || r; + r = ((wglIsEnabledFrameLockI3D = (PFNWGLISENABLEDFRAMELOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglIsEnabledFrameLockI3D")) == NULL) || r; + r = ((wglQueryFrameLockMasterI3D = (PFNWGLQUERYFRAMELOCKMASTERI3DPROC)glewGetProcAddress((const GLubyte*)"wglQueryFrameLockMasterI3D")) == NULL) || r; + + return r; +} + +#endif /* WGL_I3D_swap_frame_lock */ + +#ifdef WGL_I3D_swap_frame_usage + +static GLboolean _glewInit_WGL_I3D_swap_frame_usage (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglBeginFrameTrackingI3D = (PFNWGLBEGINFRAMETRACKINGI3DPROC)glewGetProcAddress((const GLubyte*)"wglBeginFrameTrackingI3D")) == NULL) || r; + r = ((wglEndFrameTrackingI3D = (PFNWGLENDFRAMETRACKINGI3DPROC)glewGetProcAddress((const GLubyte*)"wglEndFrameTrackingI3D")) == NULL) || r; + r = ((wglGetFrameUsageI3D = (PFNWGLGETFRAMEUSAGEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetFrameUsageI3D")) == NULL) || r; + r = ((wglQueryFrameTrackingI3D = (PFNWGLQUERYFRAMETRACKINGI3DPROC)glewGetProcAddress((const GLubyte*)"wglQueryFrameTrackingI3D")) == NULL) || r; + + return r; +} + +#endif /* WGL_I3D_swap_frame_usage */ + +#ifdef WGL_NV_copy_image + +static GLboolean _glewInit_WGL_NV_copy_image (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglCopyImageSubDataNV = (PFNWGLCOPYIMAGESUBDATANVPROC)glewGetProcAddress((const GLubyte*)"wglCopyImageSubDataNV")) == NULL) || r; + + return r; +} + +#endif /* WGL_NV_copy_image */ + +#ifdef WGL_NV_float_buffer + +#endif /* WGL_NV_float_buffer */ + +#ifdef WGL_NV_gpu_affinity + +static GLboolean _glewInit_WGL_NV_gpu_affinity (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglCreateAffinityDCNV = (PFNWGLCREATEAFFINITYDCNVPROC)glewGetProcAddress((const GLubyte*)"wglCreateAffinityDCNV")) == NULL) || r; + r = ((wglDeleteDCNV = (PFNWGLDELETEDCNVPROC)glewGetProcAddress((const GLubyte*)"wglDeleteDCNV")) == NULL) || r; + r = ((wglEnumGpuDevicesNV = (PFNWGLENUMGPUDEVICESNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumGpuDevicesNV")) == NULL) || r; + r = ((wglEnumGpusFromAffinityDCNV = (PFNWGLENUMGPUSFROMAFFINITYDCNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumGpusFromAffinityDCNV")) == NULL) || r; + r = ((wglEnumGpusNV = (PFNWGLENUMGPUSNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumGpusNV")) == NULL) || r; + + return r; +} + +#endif /* WGL_NV_gpu_affinity */ + +#ifdef WGL_NV_present_video + +static GLboolean _glewInit_WGL_NV_present_video (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglBindVideoDeviceNV = (PFNWGLBINDVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglBindVideoDeviceNV")) == NULL) || r; + r = ((wglEnumerateVideoDevicesNV = (PFNWGLENUMERATEVIDEODEVICESNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumerateVideoDevicesNV")) == NULL) || r; + r = ((wglQueryCurrentContextNV = (PFNWGLQUERYCURRENTCONTEXTNVPROC)glewGetProcAddress((const GLubyte*)"wglQueryCurrentContextNV")) == NULL) || r; + + return r; +} + +#endif /* WGL_NV_present_video */ + +#ifdef WGL_NV_render_depth_texture + +#endif /* WGL_NV_render_depth_texture */ + +#ifdef WGL_NV_render_texture_rectangle + +#endif /* WGL_NV_render_texture_rectangle */ + +#ifdef WGL_NV_swap_group + +static GLboolean _glewInit_WGL_NV_swap_group (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglBindSwapBarrierNV = (PFNWGLBINDSWAPBARRIERNVPROC)glewGetProcAddress((const GLubyte*)"wglBindSwapBarrierNV")) == NULL) || r; + r = ((wglJoinSwapGroupNV = (PFNWGLJOINSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"wglJoinSwapGroupNV")) == NULL) || r; + r = ((wglQueryFrameCountNV = (PFNWGLQUERYFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"wglQueryFrameCountNV")) == NULL) || r; + r = ((wglQueryMaxSwapGroupsNV = (PFNWGLQUERYMAXSWAPGROUPSNVPROC)glewGetProcAddress((const GLubyte*)"wglQueryMaxSwapGroupsNV")) == NULL) || r; + r = ((wglQuerySwapGroupNV = (PFNWGLQUERYSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"wglQuerySwapGroupNV")) == NULL) || r; + r = ((wglResetFrameCountNV = (PFNWGLRESETFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"wglResetFrameCountNV")) == NULL) || r; + + return r; +} + +#endif /* WGL_NV_swap_group */ + +#ifdef WGL_NV_vertex_array_range + +static GLboolean _glewInit_WGL_NV_vertex_array_range (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglAllocateMemoryNV = (PFNWGLALLOCATEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"wglAllocateMemoryNV")) == NULL) || r; + r = ((wglFreeMemoryNV = (PFNWGLFREEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"wglFreeMemoryNV")) == NULL) || r; + + return r; +} + +#endif /* WGL_NV_vertex_array_range */ + +#ifdef WGL_NV_video_output + +static GLboolean _glewInit_WGL_NV_video_output (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglBindVideoImageNV = (PFNWGLBINDVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"wglBindVideoImageNV")) == NULL) || r; + r = ((wglGetVideoDeviceNV = (PFNWGLGETVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglGetVideoDeviceNV")) == NULL) || r; + r = ((wglGetVideoInfoNV = (PFNWGLGETVIDEOINFONVPROC)glewGetProcAddress((const GLubyte*)"wglGetVideoInfoNV")) == NULL) || r; + r = ((wglReleaseVideoDeviceNV = (PFNWGLRELEASEVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglReleaseVideoDeviceNV")) == NULL) || r; + r = ((wglReleaseVideoImageNV = (PFNWGLRELEASEVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"wglReleaseVideoImageNV")) == NULL) || r; + r = ((wglSendPbufferToVideoNV = (PFNWGLSENDPBUFFERTOVIDEONVPROC)glewGetProcAddress((const GLubyte*)"wglSendPbufferToVideoNV")) == NULL) || r; + + return r; +} + +#endif /* WGL_NV_video_output */ + +#ifdef WGL_OML_sync_control + +static GLboolean _glewInit_WGL_OML_sync_control (WGLEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((wglGetMscRateOML = (PFNWGLGETMSCRATEOMLPROC)glewGetProcAddress((const GLubyte*)"wglGetMscRateOML")) == NULL) || r; + r = ((wglGetSyncValuesOML = (PFNWGLGETSYNCVALUESOMLPROC)glewGetProcAddress((const GLubyte*)"wglGetSyncValuesOML")) == NULL) || r; + r = ((wglSwapBuffersMscOML = (PFNWGLSWAPBUFFERSMSCOMLPROC)glewGetProcAddress((const GLubyte*)"wglSwapBuffersMscOML")) == NULL) || r; + r = ((wglSwapLayerBuffersMscOML = (PFNWGLSWAPLAYERBUFFERSMSCOMLPROC)glewGetProcAddress((const GLubyte*)"wglSwapLayerBuffersMscOML")) == NULL) || r; + r = ((wglWaitForMscOML = (PFNWGLWAITFORMSCOMLPROC)glewGetProcAddress((const GLubyte*)"wglWaitForMscOML")) == NULL) || r; + r = ((wglWaitForSbcOML = (PFNWGLWAITFORSBCOMLPROC)glewGetProcAddress((const GLubyte*)"wglWaitForSbcOML")) == NULL) || r; + + return r; +} + +#endif /* WGL_OML_sync_control */ + +/* ------------------------------------------------------------------------- */ + +static PFNWGLGETEXTENSIONSSTRINGARBPROC _wglewGetExtensionsStringARB = NULL; +static PFNWGLGETEXTENSIONSSTRINGEXTPROC _wglewGetExtensionsStringEXT = NULL; + +GLboolean wglewGetExtension (const char* name) +{ + GLubyte* p; + GLubyte* end; + GLuint len = _glewStrLen((const GLubyte*)name); + if (_wglewGetExtensionsStringARB == NULL) + if (_wglewGetExtensionsStringEXT == NULL) + return GL_FALSE; + else + p = (GLubyte*)_wglewGetExtensionsStringEXT(); + else + p = (GLubyte*)_wglewGetExtensionsStringARB(wglGetCurrentDC()); + if (0 == p) return GL_FALSE; + end = p + _glewStrLen(p); + while (p < end) + { + GLuint n = _glewStrCLen(p, ' '); + if (len == n && _glewStrSame((const GLubyte*)name, p, n)) return GL_TRUE; + p += n+1; + } + return GL_FALSE; +} + +GLenum wglewContextInit (WGLEW_CONTEXT_ARG_DEF_LIST) +{ + GLboolean crippled; + /* find wgl extension string query functions */ + _wglewGetExtensionsStringARB = (PFNWGLGETEXTENSIONSSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringARB"); + _wglewGetExtensionsStringEXT = (PFNWGLGETEXTENSIONSSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringEXT"); + /* initialize extensions */ + crippled = _wglewGetExtensionsStringARB == NULL && _wglewGetExtensionsStringEXT == NULL; +#ifdef WGL_3DFX_multisample + CONST_CAST(WGLEW_3DFX_multisample) = wglewGetExtension("WGL_3DFX_multisample"); +#endif /* WGL_3DFX_multisample */ +#ifdef WGL_3DL_stereo_control + CONST_CAST(WGLEW_3DL_stereo_control) = wglewGetExtension("WGL_3DL_stereo_control"); + if (glewExperimental || WGLEW_3DL_stereo_control|| crippled) CONST_CAST(WGLEW_3DL_stereo_control)= !_glewInit_WGL_3DL_stereo_control(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_3DL_stereo_control */ +#ifdef WGL_AMD_gpu_association + CONST_CAST(WGLEW_AMD_gpu_association) = wglewGetExtension("WGL_AMD_gpu_association"); + if (glewExperimental || WGLEW_AMD_gpu_association|| crippled) CONST_CAST(WGLEW_AMD_gpu_association)= !_glewInit_WGL_AMD_gpu_association(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_AMD_gpu_association */ +#ifdef WGL_ARB_buffer_region + CONST_CAST(WGLEW_ARB_buffer_region) = wglewGetExtension("WGL_ARB_buffer_region"); + if (glewExperimental || WGLEW_ARB_buffer_region|| crippled) CONST_CAST(WGLEW_ARB_buffer_region)= !_glewInit_WGL_ARB_buffer_region(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_ARB_buffer_region */ +#ifdef WGL_ARB_create_context + CONST_CAST(WGLEW_ARB_create_context) = wglewGetExtension("WGL_ARB_create_context"); + if (glewExperimental || WGLEW_ARB_create_context|| crippled) CONST_CAST(WGLEW_ARB_create_context)= !_glewInit_WGL_ARB_create_context(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_ARB_create_context */ +#ifdef WGL_ARB_create_context_profile + CONST_CAST(WGLEW_ARB_create_context_profile) = wglewGetExtension("WGL_ARB_create_context_profile"); +#endif /* WGL_ARB_create_context_profile */ +#ifdef WGL_ARB_extensions_string + CONST_CAST(WGLEW_ARB_extensions_string) = wglewGetExtension("WGL_ARB_extensions_string"); + if (glewExperimental || WGLEW_ARB_extensions_string|| crippled) CONST_CAST(WGLEW_ARB_extensions_string)= !_glewInit_WGL_ARB_extensions_string(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_ARB_extensions_string */ +#ifdef WGL_ARB_framebuffer_sRGB + CONST_CAST(WGLEW_ARB_framebuffer_sRGB) = wglewGetExtension("WGL_ARB_framebuffer_sRGB"); +#endif /* WGL_ARB_framebuffer_sRGB */ +#ifdef WGL_ARB_make_current_read + CONST_CAST(WGLEW_ARB_make_current_read) = wglewGetExtension("WGL_ARB_make_current_read"); + if (glewExperimental || WGLEW_ARB_make_current_read|| crippled) CONST_CAST(WGLEW_ARB_make_current_read)= !_glewInit_WGL_ARB_make_current_read(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_ARB_make_current_read */ +#ifdef WGL_ARB_multisample + CONST_CAST(WGLEW_ARB_multisample) = wglewGetExtension("WGL_ARB_multisample"); +#endif /* WGL_ARB_multisample */ +#ifdef WGL_ARB_pbuffer + CONST_CAST(WGLEW_ARB_pbuffer) = wglewGetExtension("WGL_ARB_pbuffer"); + if (glewExperimental || WGLEW_ARB_pbuffer|| crippled) CONST_CAST(WGLEW_ARB_pbuffer)= !_glewInit_WGL_ARB_pbuffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_ARB_pbuffer */ +#ifdef WGL_ARB_pixel_format + CONST_CAST(WGLEW_ARB_pixel_format) = wglewGetExtension("WGL_ARB_pixel_format"); + if (glewExperimental || WGLEW_ARB_pixel_format|| crippled) CONST_CAST(WGLEW_ARB_pixel_format)= !_glewInit_WGL_ARB_pixel_format(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_ARB_pixel_format */ +#ifdef WGL_ARB_pixel_format_float + CONST_CAST(WGLEW_ARB_pixel_format_float) = wglewGetExtension("WGL_ARB_pixel_format_float"); +#endif /* WGL_ARB_pixel_format_float */ +#ifdef WGL_ARB_render_texture + CONST_CAST(WGLEW_ARB_render_texture) = wglewGetExtension("WGL_ARB_render_texture"); + if (glewExperimental || WGLEW_ARB_render_texture|| crippled) CONST_CAST(WGLEW_ARB_render_texture)= !_glewInit_WGL_ARB_render_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_ARB_render_texture */ +#ifdef WGL_ATI_pixel_format_float + CONST_CAST(WGLEW_ATI_pixel_format_float) = wglewGetExtension("WGL_ATI_pixel_format_float"); +#endif /* WGL_ATI_pixel_format_float */ +#ifdef WGL_ATI_render_texture_rectangle + CONST_CAST(WGLEW_ATI_render_texture_rectangle) = wglewGetExtension("WGL_ATI_render_texture_rectangle"); +#endif /* WGL_ATI_render_texture_rectangle */ +#ifdef WGL_EXT_depth_float + CONST_CAST(WGLEW_EXT_depth_float) = wglewGetExtension("WGL_EXT_depth_float"); +#endif /* WGL_EXT_depth_float */ +#ifdef WGL_EXT_display_color_table + CONST_CAST(WGLEW_EXT_display_color_table) = wglewGetExtension("WGL_EXT_display_color_table"); + if (glewExperimental || WGLEW_EXT_display_color_table|| crippled) CONST_CAST(WGLEW_EXT_display_color_table)= !_glewInit_WGL_EXT_display_color_table(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_EXT_display_color_table */ +#ifdef WGL_EXT_extensions_string + CONST_CAST(WGLEW_EXT_extensions_string) = wglewGetExtension("WGL_EXT_extensions_string"); + if (glewExperimental || WGLEW_EXT_extensions_string|| crippled) CONST_CAST(WGLEW_EXT_extensions_string)= !_glewInit_WGL_EXT_extensions_string(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_EXT_extensions_string */ +#ifdef WGL_EXT_framebuffer_sRGB + CONST_CAST(WGLEW_EXT_framebuffer_sRGB) = wglewGetExtension("WGL_EXT_framebuffer_sRGB"); +#endif /* WGL_EXT_framebuffer_sRGB */ +#ifdef WGL_EXT_make_current_read + CONST_CAST(WGLEW_EXT_make_current_read) = wglewGetExtension("WGL_EXT_make_current_read"); + if (glewExperimental || WGLEW_EXT_make_current_read|| crippled) CONST_CAST(WGLEW_EXT_make_current_read)= !_glewInit_WGL_EXT_make_current_read(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_EXT_make_current_read */ +#ifdef WGL_EXT_multisample + CONST_CAST(WGLEW_EXT_multisample) = wglewGetExtension("WGL_EXT_multisample"); +#endif /* WGL_EXT_multisample */ +#ifdef WGL_EXT_pbuffer + CONST_CAST(WGLEW_EXT_pbuffer) = wglewGetExtension("WGL_EXT_pbuffer"); + if (glewExperimental || WGLEW_EXT_pbuffer|| crippled) CONST_CAST(WGLEW_EXT_pbuffer)= !_glewInit_WGL_EXT_pbuffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_EXT_pbuffer */ +#ifdef WGL_EXT_pixel_format + CONST_CAST(WGLEW_EXT_pixel_format) = wglewGetExtension("WGL_EXT_pixel_format"); + if (glewExperimental || WGLEW_EXT_pixel_format|| crippled) CONST_CAST(WGLEW_EXT_pixel_format)= !_glewInit_WGL_EXT_pixel_format(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_EXT_pixel_format */ +#ifdef WGL_EXT_pixel_format_packed_float + CONST_CAST(WGLEW_EXT_pixel_format_packed_float) = wglewGetExtension("WGL_EXT_pixel_format_packed_float"); +#endif /* WGL_EXT_pixel_format_packed_float */ +#ifdef WGL_EXT_swap_control + CONST_CAST(WGLEW_EXT_swap_control) = wglewGetExtension("WGL_EXT_swap_control"); + if (glewExperimental || WGLEW_EXT_swap_control|| crippled) CONST_CAST(WGLEW_EXT_swap_control)= !_glewInit_WGL_EXT_swap_control(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_EXT_swap_control */ +#ifdef WGL_I3D_digital_video_control + CONST_CAST(WGLEW_I3D_digital_video_control) = wglewGetExtension("WGL_I3D_digital_video_control"); + if (glewExperimental || WGLEW_I3D_digital_video_control|| crippled) CONST_CAST(WGLEW_I3D_digital_video_control)= !_glewInit_WGL_I3D_digital_video_control(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_I3D_digital_video_control */ +#ifdef WGL_I3D_gamma + CONST_CAST(WGLEW_I3D_gamma) = wglewGetExtension("WGL_I3D_gamma"); + if (glewExperimental || WGLEW_I3D_gamma|| crippled) CONST_CAST(WGLEW_I3D_gamma)= !_glewInit_WGL_I3D_gamma(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_I3D_gamma */ +#ifdef WGL_I3D_genlock + CONST_CAST(WGLEW_I3D_genlock) = wglewGetExtension("WGL_I3D_genlock"); + if (glewExperimental || WGLEW_I3D_genlock|| crippled) CONST_CAST(WGLEW_I3D_genlock)= !_glewInit_WGL_I3D_genlock(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_I3D_genlock */ +#ifdef WGL_I3D_image_buffer + CONST_CAST(WGLEW_I3D_image_buffer) = wglewGetExtension("WGL_I3D_image_buffer"); + if (glewExperimental || WGLEW_I3D_image_buffer|| crippled) CONST_CAST(WGLEW_I3D_image_buffer)= !_glewInit_WGL_I3D_image_buffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_I3D_image_buffer */ +#ifdef WGL_I3D_swap_frame_lock + CONST_CAST(WGLEW_I3D_swap_frame_lock) = wglewGetExtension("WGL_I3D_swap_frame_lock"); + if (glewExperimental || WGLEW_I3D_swap_frame_lock|| crippled) CONST_CAST(WGLEW_I3D_swap_frame_lock)= !_glewInit_WGL_I3D_swap_frame_lock(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_I3D_swap_frame_lock */ +#ifdef WGL_I3D_swap_frame_usage + CONST_CAST(WGLEW_I3D_swap_frame_usage) = wglewGetExtension("WGL_I3D_swap_frame_usage"); + if (glewExperimental || WGLEW_I3D_swap_frame_usage|| crippled) CONST_CAST(WGLEW_I3D_swap_frame_usage)= !_glewInit_WGL_I3D_swap_frame_usage(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_I3D_swap_frame_usage */ +#ifdef WGL_NV_copy_image + CONST_CAST(WGLEW_NV_copy_image) = wglewGetExtension("WGL_NV_copy_image"); + if (glewExperimental || WGLEW_NV_copy_image|| crippled) CONST_CAST(WGLEW_NV_copy_image)= !_glewInit_WGL_NV_copy_image(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_NV_copy_image */ +#ifdef WGL_NV_float_buffer + CONST_CAST(WGLEW_NV_float_buffer) = wglewGetExtension("WGL_NV_float_buffer"); +#endif /* WGL_NV_float_buffer */ +#ifdef WGL_NV_gpu_affinity + CONST_CAST(WGLEW_NV_gpu_affinity) = wglewGetExtension("WGL_NV_gpu_affinity"); + if (glewExperimental || WGLEW_NV_gpu_affinity|| crippled) CONST_CAST(WGLEW_NV_gpu_affinity)= !_glewInit_WGL_NV_gpu_affinity(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_NV_gpu_affinity */ +#ifdef WGL_NV_present_video + CONST_CAST(WGLEW_NV_present_video) = wglewGetExtension("WGL_NV_present_video"); + if (glewExperimental || WGLEW_NV_present_video|| crippled) CONST_CAST(WGLEW_NV_present_video)= !_glewInit_WGL_NV_present_video(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_NV_present_video */ +#ifdef WGL_NV_render_depth_texture + CONST_CAST(WGLEW_NV_render_depth_texture) = wglewGetExtension("WGL_NV_render_depth_texture"); +#endif /* WGL_NV_render_depth_texture */ +#ifdef WGL_NV_render_texture_rectangle + CONST_CAST(WGLEW_NV_render_texture_rectangle) = wglewGetExtension("WGL_NV_render_texture_rectangle"); +#endif /* WGL_NV_render_texture_rectangle */ +#ifdef WGL_NV_swap_group + CONST_CAST(WGLEW_NV_swap_group) = wglewGetExtension("WGL_NV_swap_group"); + if (glewExperimental || WGLEW_NV_swap_group|| crippled) CONST_CAST(WGLEW_NV_swap_group)= !_glewInit_WGL_NV_swap_group(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_NV_swap_group */ +#ifdef WGL_NV_vertex_array_range + CONST_CAST(WGLEW_NV_vertex_array_range) = wglewGetExtension("WGL_NV_vertex_array_range"); + if (glewExperimental || WGLEW_NV_vertex_array_range|| crippled) CONST_CAST(WGLEW_NV_vertex_array_range)= !_glewInit_WGL_NV_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_NV_vertex_array_range */ +#ifdef WGL_NV_video_output + CONST_CAST(WGLEW_NV_video_output) = wglewGetExtension("WGL_NV_video_output"); + if (glewExperimental || WGLEW_NV_video_output|| crippled) CONST_CAST(WGLEW_NV_video_output)= !_glewInit_WGL_NV_video_output(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_NV_video_output */ +#ifdef WGL_OML_sync_control + CONST_CAST(WGLEW_OML_sync_control) = wglewGetExtension("WGL_OML_sync_control"); + if (glewExperimental || WGLEW_OML_sync_control|| crippled) CONST_CAST(WGLEW_OML_sync_control)= !_glewInit_WGL_OML_sync_control(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* WGL_OML_sync_control */ + + return GLEW_OK; +} + +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + +PFNGLXGETCURRENTDISPLAYPROC __glewXGetCurrentDisplay = NULL; + +PFNGLXCHOOSEFBCONFIGPROC __glewXChooseFBConfig = NULL; +PFNGLXCREATENEWCONTEXTPROC __glewXCreateNewContext = NULL; +PFNGLXCREATEPBUFFERPROC __glewXCreatePbuffer = NULL; +PFNGLXCREATEPIXMAPPROC __glewXCreatePixmap = NULL; +PFNGLXCREATEWINDOWPROC __glewXCreateWindow = NULL; +PFNGLXDESTROYPBUFFERPROC __glewXDestroyPbuffer = NULL; +PFNGLXDESTROYPIXMAPPROC __glewXDestroyPixmap = NULL; +PFNGLXDESTROYWINDOWPROC __glewXDestroyWindow = NULL; +PFNGLXGETCURRENTREADDRAWABLEPROC __glewXGetCurrentReadDrawable = NULL; +PFNGLXGETFBCONFIGATTRIBPROC __glewXGetFBConfigAttrib = NULL; +PFNGLXGETFBCONFIGSPROC __glewXGetFBConfigs = NULL; +PFNGLXGETSELECTEDEVENTPROC __glewXGetSelectedEvent = NULL; +PFNGLXGETVISUALFROMFBCONFIGPROC __glewXGetVisualFromFBConfig = NULL; +PFNGLXMAKECONTEXTCURRENTPROC __glewXMakeContextCurrent = NULL; +PFNGLXQUERYCONTEXTPROC __glewXQueryContext = NULL; +PFNGLXQUERYDRAWABLEPROC __glewXQueryDrawable = NULL; +PFNGLXSELECTEVENTPROC __glewXSelectEvent = NULL; + +PFNGLXCREATECONTEXTATTRIBSARBPROC __glewXCreateContextAttribsARB = NULL; + +PFNGLXBINDTEXIMAGEATIPROC __glewXBindTexImageATI = NULL; +PFNGLXDRAWABLEATTRIBATIPROC __glewXDrawableAttribATI = NULL; +PFNGLXRELEASETEXIMAGEATIPROC __glewXReleaseTexImageATI = NULL; + +PFNGLXFREECONTEXTEXTPROC __glewXFreeContextEXT = NULL; +PFNGLXGETCONTEXTIDEXTPROC __glewXGetContextIDEXT = NULL; +PFNGLXIMPORTCONTEXTEXTPROC __glewXImportContextEXT = NULL; +PFNGLXQUERYCONTEXTINFOEXTPROC __glewXQueryContextInfoEXT = NULL; + +PFNGLXSWAPINTERVALEXTPROC __glewXSwapIntervalEXT = NULL; + +PFNGLXBINDTEXIMAGEEXTPROC __glewXBindTexImageEXT = NULL; +PFNGLXRELEASETEXIMAGEEXTPROC __glewXReleaseTexImageEXT = NULL; + +PFNGLXGETAGPOFFSETMESAPROC __glewXGetAGPOffsetMESA = NULL; + +PFNGLXCOPYSUBBUFFERMESAPROC __glewXCopySubBufferMESA = NULL; + +PFNGLXCREATEGLXPIXMAPMESAPROC __glewXCreateGLXPixmapMESA = NULL; + +PFNGLXRELEASEBUFFERSMESAPROC __glewXReleaseBuffersMESA = NULL; + +PFNGLXSET3DFXMODEMESAPROC __glewXSet3DfxModeMESA = NULL; + +PFNGLXCOPYIMAGESUBDATANVPROC __glewXCopyImageSubDataNV = NULL; + +PFNGLXBINDVIDEODEVICENVPROC __glewXBindVideoDeviceNV = NULL; +PFNGLXENUMERATEVIDEODEVICESNVPROC __glewXEnumerateVideoDevicesNV = NULL; + +PFNGLXBINDSWAPBARRIERNVPROC __glewXBindSwapBarrierNV = NULL; +PFNGLXJOINSWAPGROUPNVPROC __glewXJoinSwapGroupNV = NULL; +PFNGLXQUERYFRAMECOUNTNVPROC __glewXQueryFrameCountNV = NULL; +PFNGLXQUERYMAXSWAPGROUPSNVPROC __glewXQueryMaxSwapGroupsNV = NULL; +PFNGLXQUERYSWAPGROUPNVPROC __glewXQuerySwapGroupNV = NULL; +PFNGLXRESETFRAMECOUNTNVPROC __glewXResetFrameCountNV = NULL; + +PFNGLXALLOCATEMEMORYNVPROC __glewXAllocateMemoryNV = NULL; +PFNGLXFREEMEMORYNVPROC __glewXFreeMemoryNV = NULL; + +PFNGLXBINDVIDEOIMAGENVPROC __glewXBindVideoImageNV = NULL; +PFNGLXGETVIDEODEVICENVPROC __glewXGetVideoDeviceNV = NULL; +PFNGLXGETVIDEOINFONVPROC __glewXGetVideoInfoNV = NULL; +PFNGLXRELEASEVIDEODEVICENVPROC __glewXReleaseVideoDeviceNV = NULL; +PFNGLXRELEASEVIDEOIMAGENVPROC __glewXReleaseVideoImageNV = NULL; +PFNGLXSENDPBUFFERTOVIDEONVPROC __glewXSendPbufferToVideoNV = NULL; + +#ifdef GLX_OML_sync_control +PFNGLXGETMSCRATEOMLPROC __glewXGetMscRateOML = NULL; +PFNGLXGETSYNCVALUESOMLPROC __glewXGetSyncValuesOML = NULL; +PFNGLXSWAPBUFFERSMSCOMLPROC __glewXSwapBuffersMscOML = NULL; +PFNGLXWAITFORMSCOMLPROC __glewXWaitForMscOML = NULL; +PFNGLXWAITFORSBCOMLPROC __glewXWaitForSbcOML = NULL; +#endif + +PFNGLXCHOOSEFBCONFIGSGIXPROC __glewXChooseFBConfigSGIX = NULL; +PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC __glewXCreateContextWithConfigSGIX = NULL; +PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC __glewXCreateGLXPixmapWithConfigSGIX = NULL; +PFNGLXGETFBCONFIGATTRIBSGIXPROC __glewXGetFBConfigAttribSGIX = NULL; +PFNGLXGETFBCONFIGFROMVISUALSGIXPROC __glewXGetFBConfigFromVisualSGIX = NULL; +PFNGLXGETVISUALFROMFBCONFIGSGIXPROC __glewXGetVisualFromFBConfigSGIX = NULL; + +PFNGLXBINDHYPERPIPESGIXPROC __glewXBindHyperpipeSGIX = NULL; +PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC __glewXDestroyHyperpipeConfigSGIX = NULL; +PFNGLXHYPERPIPEATTRIBSGIXPROC __glewXHyperpipeAttribSGIX = NULL; +PFNGLXHYPERPIPECONFIGSGIXPROC __glewXHyperpipeConfigSGIX = NULL; +PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC __glewXQueryHyperpipeAttribSGIX = NULL; +PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC __glewXQueryHyperpipeBestAttribSGIX = NULL; +PFNGLXQUERYHYPERPIPECONFIGSGIXPROC __glewXQueryHyperpipeConfigSGIX = NULL; +PFNGLXQUERYHYPERPIPENETWORKSGIXPROC __glewXQueryHyperpipeNetworkSGIX = NULL; + +PFNGLXCREATEGLXPBUFFERSGIXPROC __glewXCreateGLXPbufferSGIX = NULL; +PFNGLXDESTROYGLXPBUFFERSGIXPROC __glewXDestroyGLXPbufferSGIX = NULL; +PFNGLXGETSELECTEDEVENTSGIXPROC __glewXGetSelectedEventSGIX = NULL; +PFNGLXQUERYGLXPBUFFERSGIXPROC __glewXQueryGLXPbufferSGIX = NULL; +PFNGLXSELECTEVENTSGIXPROC __glewXSelectEventSGIX = NULL; + +PFNGLXBINDSWAPBARRIERSGIXPROC __glewXBindSwapBarrierSGIX = NULL; +PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC __glewXQueryMaxSwapBarriersSGIX = NULL; + +PFNGLXJOINSWAPGROUPSGIXPROC __glewXJoinSwapGroupSGIX = NULL; + +PFNGLXBINDCHANNELTOWINDOWSGIXPROC __glewXBindChannelToWindowSGIX = NULL; +PFNGLXCHANNELRECTSGIXPROC __glewXChannelRectSGIX = NULL; +PFNGLXCHANNELRECTSYNCSGIXPROC __glewXChannelRectSyncSGIX = NULL; +PFNGLXQUERYCHANNELDELTASSGIXPROC __glewXQueryChannelDeltasSGIX = NULL; +PFNGLXQUERYCHANNELRECTSGIXPROC __glewXQueryChannelRectSGIX = NULL; + +PFNGLXCUSHIONSGIPROC __glewXCushionSGI = NULL; + +PFNGLXGETCURRENTREADDRAWABLESGIPROC __glewXGetCurrentReadDrawableSGI = NULL; +PFNGLXMAKECURRENTREADSGIPROC __glewXMakeCurrentReadSGI = NULL; + +PFNGLXSWAPINTERVALSGIPROC __glewXSwapIntervalSGI = NULL; + +PFNGLXGETVIDEOSYNCSGIPROC __glewXGetVideoSyncSGI = NULL; +PFNGLXWAITVIDEOSYNCSGIPROC __glewXWaitVideoSyncSGI = NULL; + +PFNGLXGETTRANSPARENTINDEXSUNPROC __glewXGetTransparentIndexSUN = NULL; + +PFNGLXGETVIDEORESIZESUNPROC __glewXGetVideoResizeSUN = NULL; +PFNGLXVIDEORESIZESUNPROC __glewXVideoResizeSUN = NULL; + +#if !defined(GLEW_MX) + +GLboolean __GLXEW_VERSION_1_0 = GL_FALSE; +GLboolean __GLXEW_VERSION_1_1 = GL_FALSE; +GLboolean __GLXEW_VERSION_1_2 = GL_FALSE; +GLboolean __GLXEW_VERSION_1_3 = GL_FALSE; +GLboolean __GLXEW_VERSION_1_4 = GL_FALSE; +GLboolean __GLXEW_3DFX_multisample = GL_FALSE; +GLboolean __GLXEW_ARB_create_context = GL_FALSE; +GLboolean __GLXEW_ARB_create_context_profile = GL_FALSE; +GLboolean __GLXEW_ARB_fbconfig_float = GL_FALSE; +GLboolean __GLXEW_ARB_framebuffer_sRGB = GL_FALSE; +GLboolean __GLXEW_ARB_get_proc_address = GL_FALSE; +GLboolean __GLXEW_ARB_multisample = GL_FALSE; +GLboolean __GLXEW_ARB_vertex_buffer_object = GL_FALSE; +GLboolean __GLXEW_ATI_pixel_format_float = GL_FALSE; +GLboolean __GLXEW_ATI_render_texture = GL_FALSE; +GLboolean __GLXEW_EXT_fbconfig_packed_float = GL_FALSE; +GLboolean __GLXEW_EXT_framebuffer_sRGB = GL_FALSE; +GLboolean __GLXEW_EXT_import_context = GL_FALSE; +GLboolean __GLXEW_EXT_scene_marker = GL_FALSE; +GLboolean __GLXEW_EXT_swap_control = GL_FALSE; +GLboolean __GLXEW_EXT_texture_from_pixmap = GL_FALSE; +GLboolean __GLXEW_EXT_visual_info = GL_FALSE; +GLboolean __GLXEW_EXT_visual_rating = GL_FALSE; +GLboolean __GLXEW_INTEL_swap_event = GL_FALSE; +GLboolean __GLXEW_MESA_agp_offset = GL_FALSE; +GLboolean __GLXEW_MESA_copy_sub_buffer = GL_FALSE; +GLboolean __GLXEW_MESA_pixmap_colormap = GL_FALSE; +GLboolean __GLXEW_MESA_release_buffers = GL_FALSE; +GLboolean __GLXEW_MESA_set_3dfx_mode = GL_FALSE; +GLboolean __GLXEW_NV_copy_image = GL_FALSE; +GLboolean __GLXEW_NV_float_buffer = GL_FALSE; +GLboolean __GLXEW_NV_present_video = GL_FALSE; +GLboolean __GLXEW_NV_swap_group = GL_FALSE; +GLboolean __GLXEW_NV_vertex_array_range = GL_FALSE; +GLboolean __GLXEW_NV_video_output = GL_FALSE; +GLboolean __GLXEW_OML_swap_method = GL_FALSE; +#ifdef GLX_OML_sync_control +GLboolean __GLXEW_OML_sync_control = GL_FALSE; +#endif +GLboolean __GLXEW_SGIS_blended_overlay = GL_FALSE; +GLboolean __GLXEW_SGIS_color_range = GL_FALSE; +GLboolean __GLXEW_SGIS_multisample = GL_FALSE; +GLboolean __GLXEW_SGIS_shared_multisample = GL_FALSE; +GLboolean __GLXEW_SGIX_fbconfig = GL_FALSE; +GLboolean __GLXEW_SGIX_hyperpipe = GL_FALSE; +GLboolean __GLXEW_SGIX_pbuffer = GL_FALSE; +GLboolean __GLXEW_SGIX_swap_barrier = GL_FALSE; +GLboolean __GLXEW_SGIX_swap_group = GL_FALSE; +GLboolean __GLXEW_SGIX_video_resize = GL_FALSE; +GLboolean __GLXEW_SGIX_visual_select_group = GL_FALSE; +GLboolean __GLXEW_SGI_cushion = GL_FALSE; +GLboolean __GLXEW_SGI_make_current_read = GL_FALSE; +GLboolean __GLXEW_SGI_swap_control = GL_FALSE; +GLboolean __GLXEW_SGI_video_sync = GL_FALSE; +GLboolean __GLXEW_SUN_get_transparent_index = GL_FALSE; +GLboolean __GLXEW_SUN_video_resize = GL_FALSE; + +#endif /* !GLEW_MX */ + +#ifdef GLX_VERSION_1_2 + +static GLboolean _glewInit_GLX_VERSION_1_2 (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXGetCurrentDisplay = (PFNGLXGETCURRENTDISPLAYPROC)glewGetProcAddress((const GLubyte*)"glXGetCurrentDisplay")) == NULL) || r; + + return r; +} + +#endif /* GLX_VERSION_1_2 */ + +#ifdef GLX_VERSION_1_3 + +static GLboolean _glewInit_GLX_VERSION_1_3 (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXChooseFBConfig = (PFNGLXCHOOSEFBCONFIGPROC)glewGetProcAddress((const GLubyte*)"glXChooseFBConfig")) == NULL) || r; + r = ((glXCreateNewContext = (PFNGLXCREATENEWCONTEXTPROC)glewGetProcAddress((const GLubyte*)"glXCreateNewContext")) == NULL) || r; + r = ((glXCreatePbuffer = (PFNGLXCREATEPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glXCreatePbuffer")) == NULL) || r; + r = ((glXCreatePixmap = (PFNGLXCREATEPIXMAPPROC)glewGetProcAddress((const GLubyte*)"glXCreatePixmap")) == NULL) || r; + r = ((glXCreateWindow = (PFNGLXCREATEWINDOWPROC)glewGetProcAddress((const GLubyte*)"glXCreateWindow")) == NULL) || r; + r = ((glXDestroyPbuffer = (PFNGLXDESTROYPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glXDestroyPbuffer")) == NULL) || r; + r = ((glXDestroyPixmap = (PFNGLXDESTROYPIXMAPPROC)glewGetProcAddress((const GLubyte*)"glXDestroyPixmap")) == NULL) || r; + r = ((glXDestroyWindow = (PFNGLXDESTROYWINDOWPROC)glewGetProcAddress((const GLubyte*)"glXDestroyWindow")) == NULL) || r; + r = ((glXGetCurrentReadDrawable = (PFNGLXGETCURRENTREADDRAWABLEPROC)glewGetProcAddress((const GLubyte*)"glXGetCurrentReadDrawable")) == NULL) || r; + r = ((glXGetFBConfigAttrib = (PFNGLXGETFBCONFIGATTRIBPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigAttrib")) == NULL) || r; + r = ((glXGetFBConfigs = (PFNGLXGETFBCONFIGSPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigs")) == NULL) || r; + r = ((glXGetSelectedEvent = (PFNGLXGETSELECTEDEVENTPROC)glewGetProcAddress((const GLubyte*)"glXGetSelectedEvent")) == NULL) || r; + r = ((glXGetVisualFromFBConfig = (PFNGLXGETVISUALFROMFBCONFIGPROC)glewGetProcAddress((const GLubyte*)"glXGetVisualFromFBConfig")) == NULL) || r; + r = ((glXMakeContextCurrent = (PFNGLXMAKECONTEXTCURRENTPROC)glewGetProcAddress((const GLubyte*)"glXMakeContextCurrent")) == NULL) || r; + r = ((glXQueryContext = (PFNGLXQUERYCONTEXTPROC)glewGetProcAddress((const GLubyte*)"glXQueryContext")) == NULL) || r; + r = ((glXQueryDrawable = (PFNGLXQUERYDRAWABLEPROC)glewGetProcAddress((const GLubyte*)"glXQueryDrawable")) == NULL) || r; + r = ((glXSelectEvent = (PFNGLXSELECTEVENTPROC)glewGetProcAddress((const GLubyte*)"glXSelectEvent")) == NULL) || r; + + return r; +} + +#endif /* GLX_VERSION_1_3 */ + +#ifdef GLX_VERSION_1_4 + +#endif /* GLX_VERSION_1_4 */ + +#ifdef GLX_3DFX_multisample + +#endif /* GLX_3DFX_multisample */ + +#ifdef GLX_ARB_create_context + +static GLboolean _glewInit_GLX_ARB_create_context (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXCreateContextAttribsARB = (PFNGLXCREATECONTEXTATTRIBSARBPROC)glewGetProcAddress((const GLubyte*)"glXCreateContextAttribsARB")) == NULL) || r; + + return r; +} + +#endif /* GLX_ARB_create_context */ + +#ifdef GLX_ARB_create_context_profile + +#endif /* GLX_ARB_create_context_profile */ + +#ifdef GLX_ARB_fbconfig_float + +#endif /* GLX_ARB_fbconfig_float */ + +#ifdef GLX_ARB_framebuffer_sRGB + +#endif /* GLX_ARB_framebuffer_sRGB */ + +#ifdef GLX_ARB_get_proc_address + +#endif /* GLX_ARB_get_proc_address */ + +#ifdef GLX_ARB_multisample + +#endif /* GLX_ARB_multisample */ + +#ifdef GLX_ARB_vertex_buffer_object + +#endif /* GLX_ARB_vertex_buffer_object */ + +#ifdef GLX_ATI_pixel_format_float + +#endif /* GLX_ATI_pixel_format_float */ + +#ifdef GLX_ATI_render_texture + +static GLboolean _glewInit_GLX_ATI_render_texture (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindTexImageATI = (PFNGLXBINDTEXIMAGEATIPROC)glewGetProcAddress((const GLubyte*)"glXBindTexImageATI")) == NULL) || r; + r = ((glXDrawableAttribATI = (PFNGLXDRAWABLEATTRIBATIPROC)glewGetProcAddress((const GLubyte*)"glXDrawableAttribATI")) == NULL) || r; + r = ((glXReleaseTexImageATI = (PFNGLXRELEASETEXIMAGEATIPROC)glewGetProcAddress((const GLubyte*)"glXReleaseTexImageATI")) == NULL) || r; + + return r; +} + +#endif /* GLX_ATI_render_texture */ + +#ifdef GLX_EXT_fbconfig_packed_float + +#endif /* GLX_EXT_fbconfig_packed_float */ + +#ifdef GLX_EXT_framebuffer_sRGB + +#endif /* GLX_EXT_framebuffer_sRGB */ + +#ifdef GLX_EXT_import_context + +static GLboolean _glewInit_GLX_EXT_import_context (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXFreeContextEXT = (PFNGLXFREECONTEXTEXTPROC)glewGetProcAddress((const GLubyte*)"glXFreeContextEXT")) == NULL) || r; + r = ((glXGetContextIDEXT = (PFNGLXGETCONTEXTIDEXTPROC)glewGetProcAddress((const GLubyte*)"glXGetContextIDEXT")) == NULL) || r; + r = ((glXImportContextEXT = (PFNGLXIMPORTCONTEXTEXTPROC)glewGetProcAddress((const GLubyte*)"glXImportContextEXT")) == NULL) || r; + r = ((glXQueryContextInfoEXT = (PFNGLXQUERYCONTEXTINFOEXTPROC)glewGetProcAddress((const GLubyte*)"glXQueryContextInfoEXT")) == NULL) || r; + + return r; +} + +#endif /* GLX_EXT_import_context */ + +#ifdef GLX_EXT_scene_marker + +#endif /* GLX_EXT_scene_marker */ + +#ifdef GLX_EXT_swap_control + +static GLboolean _glewInit_GLX_EXT_swap_control (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXSwapIntervalEXT = (PFNGLXSWAPINTERVALEXTPROC)glewGetProcAddress((const GLubyte*)"glXSwapIntervalEXT")) == NULL) || r; + + return r; +} + +#endif /* GLX_EXT_swap_control */ + +#ifdef GLX_EXT_texture_from_pixmap + +static GLboolean _glewInit_GLX_EXT_texture_from_pixmap (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindTexImageEXT = (PFNGLXBINDTEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glXBindTexImageEXT")) == NULL) || r; + r = ((glXReleaseTexImageEXT = (PFNGLXRELEASETEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glXReleaseTexImageEXT")) == NULL) || r; + + return r; +} + +#endif /* GLX_EXT_texture_from_pixmap */ + +#ifdef GLX_EXT_visual_info + +#endif /* GLX_EXT_visual_info */ + +#ifdef GLX_EXT_visual_rating + +#endif /* GLX_EXT_visual_rating */ + +#ifdef GLX_INTEL_swap_event + +#endif /* GLX_INTEL_swap_event */ + +#ifdef GLX_MESA_agp_offset + +static GLboolean _glewInit_GLX_MESA_agp_offset (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXGetAGPOffsetMESA = (PFNGLXGETAGPOFFSETMESAPROC)glewGetProcAddress((const GLubyte*)"glXGetAGPOffsetMESA")) == NULL) || r; + + return r; +} + +#endif /* GLX_MESA_agp_offset */ + +#ifdef GLX_MESA_copy_sub_buffer + +static GLboolean _glewInit_GLX_MESA_copy_sub_buffer (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXCopySubBufferMESA = (PFNGLXCOPYSUBBUFFERMESAPROC)glewGetProcAddress((const GLubyte*)"glXCopySubBufferMESA")) == NULL) || r; + + return r; +} + +#endif /* GLX_MESA_copy_sub_buffer */ + +#ifdef GLX_MESA_pixmap_colormap + +static GLboolean _glewInit_GLX_MESA_pixmap_colormap (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXCreateGLXPixmapMESA = (PFNGLXCREATEGLXPIXMAPMESAPROC)glewGetProcAddress((const GLubyte*)"glXCreateGLXPixmapMESA")) == NULL) || r; + + return r; +} + +#endif /* GLX_MESA_pixmap_colormap */ + +#ifdef GLX_MESA_release_buffers + +static GLboolean _glewInit_GLX_MESA_release_buffers (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXReleaseBuffersMESA = (PFNGLXRELEASEBUFFERSMESAPROC)glewGetProcAddress((const GLubyte*)"glXReleaseBuffersMESA")) == NULL) || r; + + return r; +} + +#endif /* GLX_MESA_release_buffers */ + +#ifdef GLX_MESA_set_3dfx_mode + +static GLboolean _glewInit_GLX_MESA_set_3dfx_mode (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXSet3DfxModeMESA = (PFNGLXSET3DFXMODEMESAPROC)glewGetProcAddress((const GLubyte*)"glXSet3DfxModeMESA")) == NULL) || r; + + return r; +} + +#endif /* GLX_MESA_set_3dfx_mode */ + +#ifdef GLX_NV_copy_image + +static GLboolean _glewInit_GLX_NV_copy_image (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXCopyImageSubDataNV = (PFNGLXCOPYIMAGESUBDATANVPROC)glewGetProcAddress((const GLubyte*)"glXCopyImageSubDataNV")) == NULL) || r; + + return r; +} + +#endif /* GLX_NV_copy_image */ + +#ifdef GLX_NV_float_buffer + +#endif /* GLX_NV_float_buffer */ + +#ifdef GLX_NV_present_video + +static GLboolean _glewInit_GLX_NV_present_video (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindVideoDeviceNV = (PFNGLXBINDVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXBindVideoDeviceNV")) == NULL) || r; + r = ((glXEnumerateVideoDevicesNV = (PFNGLXENUMERATEVIDEODEVICESNVPROC)glewGetProcAddress((const GLubyte*)"glXEnumerateVideoDevicesNV")) == NULL) || r; + + return r; +} + +#endif /* GLX_NV_present_video */ + +#ifdef GLX_NV_swap_group + +static GLboolean _glewInit_GLX_NV_swap_group (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindSwapBarrierNV = (PFNGLXBINDSWAPBARRIERNVPROC)glewGetProcAddress((const GLubyte*)"glXBindSwapBarrierNV")) == NULL) || r; + r = ((glXJoinSwapGroupNV = (PFNGLXJOINSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"glXJoinSwapGroupNV")) == NULL) || r; + r = ((glXQueryFrameCountNV = (PFNGLXQUERYFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"glXQueryFrameCountNV")) == NULL) || r; + r = ((glXQueryMaxSwapGroupsNV = (PFNGLXQUERYMAXSWAPGROUPSNVPROC)glewGetProcAddress((const GLubyte*)"glXQueryMaxSwapGroupsNV")) == NULL) || r; + r = ((glXQuerySwapGroupNV = (PFNGLXQUERYSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"glXQuerySwapGroupNV")) == NULL) || r; + r = ((glXResetFrameCountNV = (PFNGLXRESETFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"glXResetFrameCountNV")) == NULL) || r; + + return r; +} + +#endif /* GLX_NV_swap_group */ + +#ifdef GLX_NV_vertex_array_range + +static GLboolean _glewInit_GLX_NV_vertex_array_range (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXAllocateMemoryNV = (PFNGLXALLOCATEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"glXAllocateMemoryNV")) == NULL) || r; + r = ((glXFreeMemoryNV = (PFNGLXFREEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"glXFreeMemoryNV")) == NULL) || r; + + return r; +} + +#endif /* GLX_NV_vertex_array_range */ + +#ifdef GLX_NV_video_output + +static GLboolean _glewInit_GLX_NV_video_output (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindVideoImageNV = (PFNGLXBINDVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"glXBindVideoImageNV")) == NULL) || r; + r = ((glXGetVideoDeviceNV = (PFNGLXGETVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoDeviceNV")) == NULL) || r; + r = ((glXGetVideoInfoNV = (PFNGLXGETVIDEOINFONVPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoInfoNV")) == NULL) || r; + r = ((glXReleaseVideoDeviceNV = (PFNGLXRELEASEVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXReleaseVideoDeviceNV")) == NULL) || r; + r = ((glXReleaseVideoImageNV = (PFNGLXRELEASEVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"glXReleaseVideoImageNV")) == NULL) || r; + r = ((glXSendPbufferToVideoNV = (PFNGLXSENDPBUFFERTOVIDEONVPROC)glewGetProcAddress((const GLubyte*)"glXSendPbufferToVideoNV")) == NULL) || r; + + return r; +} + +#endif /* GLX_NV_video_output */ + +#ifdef GLX_OML_swap_method + +#endif /* GLX_OML_swap_method */ + +#if defined(GLX_OML_sync_control) && defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) +#include + +static GLboolean _glewInit_GLX_OML_sync_control (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXGetMscRateOML = (PFNGLXGETMSCRATEOMLPROC)glewGetProcAddress((const GLubyte*)"glXGetMscRateOML")) == NULL) || r; + r = ((glXGetSyncValuesOML = (PFNGLXGETSYNCVALUESOMLPROC)glewGetProcAddress((const GLubyte*)"glXGetSyncValuesOML")) == NULL) || r; + r = ((glXSwapBuffersMscOML = (PFNGLXSWAPBUFFERSMSCOMLPROC)glewGetProcAddress((const GLubyte*)"glXSwapBuffersMscOML")) == NULL) || r; + r = ((glXWaitForMscOML = (PFNGLXWAITFORMSCOMLPROC)glewGetProcAddress((const GLubyte*)"glXWaitForMscOML")) == NULL) || r; + r = ((glXWaitForSbcOML = (PFNGLXWAITFORSBCOMLPROC)glewGetProcAddress((const GLubyte*)"glXWaitForSbcOML")) == NULL) || r; + + return r; +} + +#endif /* GLX_OML_sync_control */ + +#ifdef GLX_SGIS_blended_overlay + +#endif /* GLX_SGIS_blended_overlay */ + +#ifdef GLX_SGIS_color_range + +#endif /* GLX_SGIS_color_range */ + +#ifdef GLX_SGIS_multisample + +#endif /* GLX_SGIS_multisample */ + +#ifdef GLX_SGIS_shared_multisample + +#endif /* GLX_SGIS_shared_multisample */ + +#ifdef GLX_SGIX_fbconfig + +static GLboolean _glewInit_GLX_SGIX_fbconfig (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXChooseFBConfigSGIX = (PFNGLXCHOOSEFBCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXChooseFBConfigSGIX")) == NULL) || r; + r = ((glXCreateContextWithConfigSGIX = (PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXCreateContextWithConfigSGIX")) == NULL) || r; + r = ((glXCreateGLXPixmapWithConfigSGIX = (PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXCreateGLXPixmapWithConfigSGIX")) == NULL) || r; + r = ((glXGetFBConfigAttribSGIX = (PFNGLXGETFBCONFIGATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigAttribSGIX")) == NULL) || r; + r = ((glXGetFBConfigFromVisualSGIX = (PFNGLXGETFBCONFIGFROMVISUALSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigFromVisualSGIX")) == NULL) || r; + r = ((glXGetVisualFromFBConfigSGIX = (PFNGLXGETVISUALFROMFBCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetVisualFromFBConfigSGIX")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGIX_fbconfig */ + +#ifdef GLX_SGIX_hyperpipe + +static GLboolean _glewInit_GLX_SGIX_hyperpipe (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindHyperpipeSGIX = (PFNGLXBINDHYPERPIPESGIXPROC)glewGetProcAddress((const GLubyte*)"glXBindHyperpipeSGIX")) == NULL) || r; + r = ((glXDestroyHyperpipeConfigSGIX = (PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXDestroyHyperpipeConfigSGIX")) == NULL) || r; + r = ((glXHyperpipeAttribSGIX = (PFNGLXHYPERPIPEATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXHyperpipeAttribSGIX")) == NULL) || r; + r = ((glXHyperpipeConfigSGIX = (PFNGLXHYPERPIPECONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXHyperpipeConfigSGIX")) == NULL) || r; + r = ((glXQueryHyperpipeAttribSGIX = (PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeAttribSGIX")) == NULL) || r; + r = ((glXQueryHyperpipeBestAttribSGIX = (PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeBestAttribSGIX")) == NULL) || r; + r = ((glXQueryHyperpipeConfigSGIX = (PFNGLXQUERYHYPERPIPECONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeConfigSGIX")) == NULL) || r; + r = ((glXQueryHyperpipeNetworkSGIX = (PFNGLXQUERYHYPERPIPENETWORKSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeNetworkSGIX")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGIX_hyperpipe */ + +#ifdef GLX_SGIX_pbuffer + +static GLboolean _glewInit_GLX_SGIX_pbuffer (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXCreateGLXPbufferSGIX = (PFNGLXCREATEGLXPBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXCreateGLXPbufferSGIX")) == NULL) || r; + r = ((glXDestroyGLXPbufferSGIX = (PFNGLXDESTROYGLXPBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXDestroyGLXPbufferSGIX")) == NULL) || r; + r = ((glXGetSelectedEventSGIX = (PFNGLXGETSELECTEDEVENTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetSelectedEventSGIX")) == NULL) || r; + r = ((glXQueryGLXPbufferSGIX = (PFNGLXQUERYGLXPBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryGLXPbufferSGIX")) == NULL) || r; + r = ((glXSelectEventSGIX = (PFNGLXSELECTEVENTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXSelectEventSGIX")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGIX_pbuffer */ + +#ifdef GLX_SGIX_swap_barrier + +static GLboolean _glewInit_GLX_SGIX_swap_barrier (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindSwapBarrierSGIX = (PFNGLXBINDSWAPBARRIERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXBindSwapBarrierSGIX")) == NULL) || r; + r = ((glXQueryMaxSwapBarriersSGIX = (PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryMaxSwapBarriersSGIX")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGIX_swap_barrier */ + +#ifdef GLX_SGIX_swap_group + +static GLboolean _glewInit_GLX_SGIX_swap_group (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXJoinSwapGroupSGIX = (PFNGLXJOINSWAPGROUPSGIXPROC)glewGetProcAddress((const GLubyte*)"glXJoinSwapGroupSGIX")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGIX_swap_group */ + +#ifdef GLX_SGIX_video_resize + +static GLboolean _glewInit_GLX_SGIX_video_resize (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXBindChannelToWindowSGIX = (PFNGLXBINDCHANNELTOWINDOWSGIXPROC)glewGetProcAddress((const GLubyte*)"glXBindChannelToWindowSGIX")) == NULL) || r; + r = ((glXChannelRectSGIX = (PFNGLXCHANNELRECTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXChannelRectSGIX")) == NULL) || r; + r = ((glXChannelRectSyncSGIX = (PFNGLXCHANNELRECTSYNCSGIXPROC)glewGetProcAddress((const GLubyte*)"glXChannelRectSyncSGIX")) == NULL) || r; + r = ((glXQueryChannelDeltasSGIX = (PFNGLXQUERYCHANNELDELTASSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryChannelDeltasSGIX")) == NULL) || r; + r = ((glXQueryChannelRectSGIX = (PFNGLXQUERYCHANNELRECTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryChannelRectSGIX")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGIX_video_resize */ + +#ifdef GLX_SGIX_visual_select_group + +#endif /* GLX_SGIX_visual_select_group */ + +#ifdef GLX_SGI_cushion + +static GLboolean _glewInit_GLX_SGI_cushion (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXCushionSGI = (PFNGLXCUSHIONSGIPROC)glewGetProcAddress((const GLubyte*)"glXCushionSGI")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGI_cushion */ + +#ifdef GLX_SGI_make_current_read + +static GLboolean _glewInit_GLX_SGI_make_current_read (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXGetCurrentReadDrawableSGI = (PFNGLXGETCURRENTREADDRAWABLESGIPROC)glewGetProcAddress((const GLubyte*)"glXGetCurrentReadDrawableSGI")) == NULL) || r; + r = ((glXMakeCurrentReadSGI = (PFNGLXMAKECURRENTREADSGIPROC)glewGetProcAddress((const GLubyte*)"glXMakeCurrentReadSGI")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGI_make_current_read */ + +#ifdef GLX_SGI_swap_control + +static GLboolean _glewInit_GLX_SGI_swap_control (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXSwapIntervalSGI = (PFNGLXSWAPINTERVALSGIPROC)glewGetProcAddress((const GLubyte*)"glXSwapIntervalSGI")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGI_swap_control */ + +#ifdef GLX_SGI_video_sync + +static GLboolean _glewInit_GLX_SGI_video_sync (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXGetVideoSyncSGI = (PFNGLXGETVIDEOSYNCSGIPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoSyncSGI")) == NULL) || r; + r = ((glXWaitVideoSyncSGI = (PFNGLXWAITVIDEOSYNCSGIPROC)glewGetProcAddress((const GLubyte*)"glXWaitVideoSyncSGI")) == NULL) || r; + + return r; +} + +#endif /* GLX_SGI_video_sync */ + +#ifdef GLX_SUN_get_transparent_index + +static GLboolean _glewInit_GLX_SUN_get_transparent_index (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXGetTransparentIndexSUN = (PFNGLXGETTRANSPARENTINDEXSUNPROC)glewGetProcAddress((const GLubyte*)"glXGetTransparentIndexSUN")) == NULL) || r; + + return r; +} + +#endif /* GLX_SUN_get_transparent_index */ + +#ifdef GLX_SUN_video_resize + +static GLboolean _glewInit_GLX_SUN_video_resize (GLXEW_CONTEXT_ARG_DEF_INIT) +{ + GLboolean r = GL_FALSE; + + r = ((glXGetVideoResizeSUN = (PFNGLXGETVIDEORESIZESUNPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoResizeSUN")) == NULL) || r; + r = ((glXVideoResizeSUN = (PFNGLXVIDEORESIZESUNPROC)glewGetProcAddress((const GLubyte*)"glXVideoResizeSUN")) == NULL) || r; + + return r; +} + +#endif /* GLX_SUN_video_resize */ + +/* ------------------------------------------------------------------------ */ + +GLboolean glxewGetExtension (const char* name) +{ + GLubyte* p; + GLubyte* end; + GLuint len; + + if (glXGetCurrentDisplay == NULL) return GL_FALSE; + len = _glewStrLen((const GLubyte*)name); + p = (GLubyte*)glXGetClientString(glXGetCurrentDisplay(), GLX_EXTENSIONS); + if (0 == p) return GL_FALSE; + end = p + _glewStrLen(p); + while (p < end) + { + GLuint n = _glewStrCLen(p, ' '); + if (len == n && _glewStrSame((const GLubyte*)name, p, n)) return GL_TRUE; + p += n+1; + } + return GL_FALSE; +} + +GLenum glxewContextInit (GLXEW_CONTEXT_ARG_DEF_LIST) +{ + int major, minor; + /* initialize core GLX 1.2 */ + if (_glewInit_GLX_VERSION_1_2(GLEW_CONTEXT_ARG_VAR_INIT)) return GLEW_ERROR_GLX_VERSION_11_ONLY; + /* initialize flags */ + CONST_CAST(GLXEW_VERSION_1_0) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_1) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_2) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_3) = GL_TRUE; + CONST_CAST(GLXEW_VERSION_1_4) = GL_TRUE; + /* query GLX version */ + glXQueryVersion(glXGetCurrentDisplay(), &major, &minor); + if (major == 1 && minor <= 3) + { + switch (minor) + { + case 3: + CONST_CAST(GLXEW_VERSION_1_4) = GL_FALSE; + break; + case 2: + CONST_CAST(GLXEW_VERSION_1_4) = GL_FALSE; + CONST_CAST(GLXEW_VERSION_1_3) = GL_FALSE; + break; + default: + return GLEW_ERROR_GLX_VERSION_11_ONLY; + break; + } + } + /* initialize extensions */ +#ifdef GLX_VERSION_1_3 + if (glewExperimental || GLXEW_VERSION_1_3) CONST_CAST(GLXEW_VERSION_1_3) = !_glewInit_GLX_VERSION_1_3(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_VERSION_1_3 */ +#ifdef GLX_3DFX_multisample + CONST_CAST(GLXEW_3DFX_multisample) = glxewGetExtension("GLX_3DFX_multisample"); +#endif /* GLX_3DFX_multisample */ +#ifdef GLX_ARB_create_context + CONST_CAST(GLXEW_ARB_create_context) = glxewGetExtension("GLX_ARB_create_context"); + if (glewExperimental || GLXEW_ARB_create_context) CONST_CAST(GLXEW_ARB_create_context) = !_glewInit_GLX_ARB_create_context(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_ARB_create_context */ +#ifdef GLX_ARB_create_context_profile + CONST_CAST(GLXEW_ARB_create_context_profile) = glxewGetExtension("GLX_ARB_create_context_profile"); +#endif /* GLX_ARB_create_context_profile */ +#ifdef GLX_ARB_fbconfig_float + CONST_CAST(GLXEW_ARB_fbconfig_float) = glxewGetExtension("GLX_ARB_fbconfig_float"); +#endif /* GLX_ARB_fbconfig_float */ +#ifdef GLX_ARB_framebuffer_sRGB + CONST_CAST(GLXEW_ARB_framebuffer_sRGB) = glxewGetExtension("GLX_ARB_framebuffer_sRGB"); +#endif /* GLX_ARB_framebuffer_sRGB */ +#ifdef GLX_ARB_get_proc_address + CONST_CAST(GLXEW_ARB_get_proc_address) = glxewGetExtension("GLX_ARB_get_proc_address"); +#endif /* GLX_ARB_get_proc_address */ +#ifdef GLX_ARB_multisample + CONST_CAST(GLXEW_ARB_multisample) = glxewGetExtension("GLX_ARB_multisample"); +#endif /* GLX_ARB_multisample */ +#ifdef GLX_ARB_vertex_buffer_object + CONST_CAST(GLXEW_ARB_vertex_buffer_object) = glxewGetExtension("GLX_ARB_vertex_buffer_object"); +#endif /* GLX_ARB_vertex_buffer_object */ +#ifdef GLX_ATI_pixel_format_float + CONST_CAST(GLXEW_ATI_pixel_format_float) = glxewGetExtension("GLX_ATI_pixel_format_float"); +#endif /* GLX_ATI_pixel_format_float */ +#ifdef GLX_ATI_render_texture + CONST_CAST(GLXEW_ATI_render_texture) = glxewGetExtension("GLX_ATI_render_texture"); + if (glewExperimental || GLXEW_ATI_render_texture) CONST_CAST(GLXEW_ATI_render_texture) = !_glewInit_GLX_ATI_render_texture(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_ATI_render_texture */ +#ifdef GLX_EXT_fbconfig_packed_float + CONST_CAST(GLXEW_EXT_fbconfig_packed_float) = glxewGetExtension("GLX_EXT_fbconfig_packed_float"); +#endif /* GLX_EXT_fbconfig_packed_float */ +#ifdef GLX_EXT_framebuffer_sRGB + CONST_CAST(GLXEW_EXT_framebuffer_sRGB) = glxewGetExtension("GLX_EXT_framebuffer_sRGB"); +#endif /* GLX_EXT_framebuffer_sRGB */ +#ifdef GLX_EXT_import_context + CONST_CAST(GLXEW_EXT_import_context) = glxewGetExtension("GLX_EXT_import_context"); + if (glewExperimental || GLXEW_EXT_import_context) CONST_CAST(GLXEW_EXT_import_context) = !_glewInit_GLX_EXT_import_context(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_EXT_import_context */ +#ifdef GLX_EXT_scene_marker + CONST_CAST(GLXEW_EXT_scene_marker) = glxewGetExtension("GLX_EXT_scene_marker"); +#endif /* GLX_EXT_scene_marker */ +#ifdef GLX_EXT_swap_control + CONST_CAST(GLXEW_EXT_swap_control) = glxewGetExtension("GLX_EXT_swap_control"); + if (glewExperimental || GLXEW_EXT_swap_control) CONST_CAST(GLXEW_EXT_swap_control) = !_glewInit_GLX_EXT_swap_control(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_EXT_swap_control */ +#ifdef GLX_EXT_texture_from_pixmap + CONST_CAST(GLXEW_EXT_texture_from_pixmap) = glxewGetExtension("GLX_EXT_texture_from_pixmap"); + if (glewExperimental || GLXEW_EXT_texture_from_pixmap) CONST_CAST(GLXEW_EXT_texture_from_pixmap) = !_glewInit_GLX_EXT_texture_from_pixmap(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_EXT_texture_from_pixmap */ +#ifdef GLX_EXT_visual_info + CONST_CAST(GLXEW_EXT_visual_info) = glxewGetExtension("GLX_EXT_visual_info"); +#endif /* GLX_EXT_visual_info */ +#ifdef GLX_EXT_visual_rating + CONST_CAST(GLXEW_EXT_visual_rating) = glxewGetExtension("GLX_EXT_visual_rating"); +#endif /* GLX_EXT_visual_rating */ +#ifdef GLX_INTEL_swap_event + CONST_CAST(GLXEW_INTEL_swap_event) = glxewGetExtension("GLX_INTEL_swap_event"); +#endif /* GLX_INTEL_swap_event */ +#ifdef GLX_MESA_agp_offset + CONST_CAST(GLXEW_MESA_agp_offset) = glxewGetExtension("GLX_MESA_agp_offset"); + if (glewExperimental || GLXEW_MESA_agp_offset) CONST_CAST(GLXEW_MESA_agp_offset) = !_glewInit_GLX_MESA_agp_offset(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_MESA_agp_offset */ +#ifdef GLX_MESA_copy_sub_buffer + CONST_CAST(GLXEW_MESA_copy_sub_buffer) = glxewGetExtension("GLX_MESA_copy_sub_buffer"); + if (glewExperimental || GLXEW_MESA_copy_sub_buffer) CONST_CAST(GLXEW_MESA_copy_sub_buffer) = !_glewInit_GLX_MESA_copy_sub_buffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_MESA_copy_sub_buffer */ +#ifdef GLX_MESA_pixmap_colormap + CONST_CAST(GLXEW_MESA_pixmap_colormap) = glxewGetExtension("GLX_MESA_pixmap_colormap"); + if (glewExperimental || GLXEW_MESA_pixmap_colormap) CONST_CAST(GLXEW_MESA_pixmap_colormap) = !_glewInit_GLX_MESA_pixmap_colormap(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_MESA_pixmap_colormap */ +#ifdef GLX_MESA_release_buffers + CONST_CAST(GLXEW_MESA_release_buffers) = glxewGetExtension("GLX_MESA_release_buffers"); + if (glewExperimental || GLXEW_MESA_release_buffers) CONST_CAST(GLXEW_MESA_release_buffers) = !_glewInit_GLX_MESA_release_buffers(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_MESA_release_buffers */ +#ifdef GLX_MESA_set_3dfx_mode + CONST_CAST(GLXEW_MESA_set_3dfx_mode) = glxewGetExtension("GLX_MESA_set_3dfx_mode"); + if (glewExperimental || GLXEW_MESA_set_3dfx_mode) CONST_CAST(GLXEW_MESA_set_3dfx_mode) = !_glewInit_GLX_MESA_set_3dfx_mode(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_MESA_set_3dfx_mode */ +#ifdef GLX_NV_copy_image + CONST_CAST(GLXEW_NV_copy_image) = glxewGetExtension("GLX_NV_copy_image"); + if (glewExperimental || GLXEW_NV_copy_image) CONST_CAST(GLXEW_NV_copy_image) = !_glewInit_GLX_NV_copy_image(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_NV_copy_image */ +#ifdef GLX_NV_float_buffer + CONST_CAST(GLXEW_NV_float_buffer) = glxewGetExtension("GLX_NV_float_buffer"); +#endif /* GLX_NV_float_buffer */ +#ifdef GLX_NV_present_video + CONST_CAST(GLXEW_NV_present_video) = glxewGetExtension("GLX_NV_present_video"); + if (glewExperimental || GLXEW_NV_present_video) CONST_CAST(GLXEW_NV_present_video) = !_glewInit_GLX_NV_present_video(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_NV_present_video */ +#ifdef GLX_NV_swap_group + CONST_CAST(GLXEW_NV_swap_group) = glxewGetExtension("GLX_NV_swap_group"); + if (glewExperimental || GLXEW_NV_swap_group) CONST_CAST(GLXEW_NV_swap_group) = !_glewInit_GLX_NV_swap_group(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_NV_swap_group */ +#ifdef GLX_NV_vertex_array_range + CONST_CAST(GLXEW_NV_vertex_array_range) = glxewGetExtension("GLX_NV_vertex_array_range"); + if (glewExperimental || GLXEW_NV_vertex_array_range) CONST_CAST(GLXEW_NV_vertex_array_range) = !_glewInit_GLX_NV_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_NV_vertex_array_range */ +#ifdef GLX_NV_video_output + CONST_CAST(GLXEW_NV_video_output) = glxewGetExtension("GLX_NV_video_output"); + if (glewExperimental || GLXEW_NV_video_output) CONST_CAST(GLXEW_NV_video_output) = !_glewInit_GLX_NV_video_output(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_NV_video_output */ +#ifdef GLX_OML_swap_method + CONST_CAST(GLXEW_OML_swap_method) = glxewGetExtension("GLX_OML_swap_method"); +#endif /* GLX_OML_swap_method */ +#if defined(GLX_OML_sync_control) && defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) +#include + CONST_CAST(GLXEW_OML_sync_control) = glxewGetExtension("GLX_OML_sync_control"); + if (glewExperimental || GLXEW_OML_sync_control) CONST_CAST(GLXEW_OML_sync_control) = !_glewInit_GLX_OML_sync_control(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_OML_sync_control */ +#ifdef GLX_SGIS_blended_overlay + CONST_CAST(GLXEW_SGIS_blended_overlay) = glxewGetExtension("GLX_SGIS_blended_overlay"); +#endif /* GLX_SGIS_blended_overlay */ +#ifdef GLX_SGIS_color_range + CONST_CAST(GLXEW_SGIS_color_range) = glxewGetExtension("GLX_SGIS_color_range"); +#endif /* GLX_SGIS_color_range */ +#ifdef GLX_SGIS_multisample + CONST_CAST(GLXEW_SGIS_multisample) = glxewGetExtension("GLX_SGIS_multisample"); +#endif /* GLX_SGIS_multisample */ +#ifdef GLX_SGIS_shared_multisample + CONST_CAST(GLXEW_SGIS_shared_multisample) = glxewGetExtension("GLX_SGIS_shared_multisample"); +#endif /* GLX_SGIS_shared_multisample */ +#ifdef GLX_SGIX_fbconfig + CONST_CAST(GLXEW_SGIX_fbconfig) = glxewGetExtension("GLX_SGIX_fbconfig"); + if (glewExperimental || GLXEW_SGIX_fbconfig) CONST_CAST(GLXEW_SGIX_fbconfig) = !_glewInit_GLX_SGIX_fbconfig(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGIX_fbconfig */ +#ifdef GLX_SGIX_hyperpipe + CONST_CAST(GLXEW_SGIX_hyperpipe) = glxewGetExtension("GLX_SGIX_hyperpipe"); + if (glewExperimental || GLXEW_SGIX_hyperpipe) CONST_CAST(GLXEW_SGIX_hyperpipe) = !_glewInit_GLX_SGIX_hyperpipe(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGIX_hyperpipe */ +#ifdef GLX_SGIX_pbuffer + CONST_CAST(GLXEW_SGIX_pbuffer) = glxewGetExtension("GLX_SGIX_pbuffer"); + if (glewExperimental || GLXEW_SGIX_pbuffer) CONST_CAST(GLXEW_SGIX_pbuffer) = !_glewInit_GLX_SGIX_pbuffer(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGIX_pbuffer */ +#ifdef GLX_SGIX_swap_barrier + CONST_CAST(GLXEW_SGIX_swap_barrier) = glxewGetExtension("GLX_SGIX_swap_barrier"); + if (glewExperimental || GLXEW_SGIX_swap_barrier) CONST_CAST(GLXEW_SGIX_swap_barrier) = !_glewInit_GLX_SGIX_swap_barrier(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGIX_swap_barrier */ +#ifdef GLX_SGIX_swap_group + CONST_CAST(GLXEW_SGIX_swap_group) = glxewGetExtension("GLX_SGIX_swap_group"); + if (glewExperimental || GLXEW_SGIX_swap_group) CONST_CAST(GLXEW_SGIX_swap_group) = !_glewInit_GLX_SGIX_swap_group(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGIX_swap_group */ +#ifdef GLX_SGIX_video_resize + CONST_CAST(GLXEW_SGIX_video_resize) = glxewGetExtension("GLX_SGIX_video_resize"); + if (glewExperimental || GLXEW_SGIX_video_resize) CONST_CAST(GLXEW_SGIX_video_resize) = !_glewInit_GLX_SGIX_video_resize(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGIX_video_resize */ +#ifdef GLX_SGIX_visual_select_group + CONST_CAST(GLXEW_SGIX_visual_select_group) = glxewGetExtension("GLX_SGIX_visual_select_group"); +#endif /* GLX_SGIX_visual_select_group */ +#ifdef GLX_SGI_cushion + CONST_CAST(GLXEW_SGI_cushion) = glxewGetExtension("GLX_SGI_cushion"); + if (glewExperimental || GLXEW_SGI_cushion) CONST_CAST(GLXEW_SGI_cushion) = !_glewInit_GLX_SGI_cushion(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGI_cushion */ +#ifdef GLX_SGI_make_current_read + CONST_CAST(GLXEW_SGI_make_current_read) = glxewGetExtension("GLX_SGI_make_current_read"); + if (glewExperimental || GLXEW_SGI_make_current_read) CONST_CAST(GLXEW_SGI_make_current_read) = !_glewInit_GLX_SGI_make_current_read(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGI_make_current_read */ +#ifdef GLX_SGI_swap_control + CONST_CAST(GLXEW_SGI_swap_control) = glxewGetExtension("GLX_SGI_swap_control"); + if (glewExperimental || GLXEW_SGI_swap_control) CONST_CAST(GLXEW_SGI_swap_control) = !_glewInit_GLX_SGI_swap_control(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGI_swap_control */ +#ifdef GLX_SGI_video_sync + CONST_CAST(GLXEW_SGI_video_sync) = glxewGetExtension("GLX_SGI_video_sync"); + if (glewExperimental || GLXEW_SGI_video_sync) CONST_CAST(GLXEW_SGI_video_sync) = !_glewInit_GLX_SGI_video_sync(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SGI_video_sync */ +#ifdef GLX_SUN_get_transparent_index + CONST_CAST(GLXEW_SUN_get_transparent_index) = glxewGetExtension("GLX_SUN_get_transparent_index"); + if (glewExperimental || GLXEW_SUN_get_transparent_index) CONST_CAST(GLXEW_SUN_get_transparent_index) = !_glewInit_GLX_SUN_get_transparent_index(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SUN_get_transparent_index */ +#ifdef GLX_SUN_video_resize + CONST_CAST(GLXEW_SUN_video_resize) = glxewGetExtension("GLX_SUN_video_resize"); + if (glewExperimental || GLXEW_SUN_video_resize) CONST_CAST(GLXEW_SUN_video_resize) = !_glewInit_GLX_SUN_video_resize(GLEW_CONTEXT_ARG_VAR_INIT); +#endif /* GLX_SUN_video_resize */ + + return GLEW_OK; +} + +#endif /* !__APPLE__ || GLEW_APPLE_GLX */ + +/* ------------------------------------------------------------------------ */ + +const GLubyte* glewGetErrorString (GLenum error) +{ + static const GLubyte* _glewErrorString[] = + { + (const GLubyte*)"No error", + (const GLubyte*)"Missing GL version", + (const GLubyte*)"GL 1.1 and up are not supported", + (const GLubyte*)"GLX 1.2 and up are not supported", + (const GLubyte*)"Unknown error" + }; + const int max_error = sizeof(_glewErrorString)/sizeof(*_glewErrorString) - 1; + return _glewErrorString[(int)error > max_error ? max_error : (int)error]; +} + +const GLubyte* glewGetString (GLenum name) +{ + static const GLubyte* _glewString[] = + { + (const GLubyte*)NULL, + (const GLubyte*)"1.5.4", + (const GLubyte*)"1", + (const GLubyte*)"5", + (const GLubyte*)"4" + }; + const int max_string = sizeof(_glewString)/sizeof(*_glewString) - 1; + return _glewString[(int)name > max_string ? 0 : (int)name]; +} + +/* ------------------------------------------------------------------------ */ + +GLboolean glewExperimental = GL_FALSE; + +#if !defined(GLEW_MX) + +#if defined(_WIN32) +extern GLenum wglewContextInit (void); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) /* _UNIX */ +extern GLenum glxewContextInit (void); +#endif /* _WIN32 */ + +GLenum glewInit () +{ + GLenum r; + if ( (r = glewContextInit()) ) return r; +#if defined(_WIN32) + return wglewContextInit(); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) /* _UNIX */ + return glxewContextInit(); +#else + return r; +#endif /* _WIN32 */ +} + +#endif /* !GLEW_MX */ +#ifdef GLEW_MX +GLboolean glewContextIsSupported (GLEWContext* ctx, const char* name) +#else +GLboolean glewIsSupported (const char* name) +#endif +{ + GLubyte* pos = (GLubyte*)name; + GLuint len = _glewStrLen(pos); + GLboolean ret = GL_TRUE; + while (ret && len > 0) + { + if (_glewStrSame1(&pos, &len, (const GLubyte*)"GL_", 3)) + { + if (_glewStrSame2(&pos, &len, (const GLubyte*)"VERSION_", 8)) + { +#ifdef GL_VERSION_1_2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_2", 3)) + { + ret = GLEW_VERSION_1_2; + continue; + } +#endif +#ifdef GL_VERSION_1_3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_3", 3)) + { + ret = GLEW_VERSION_1_3; + continue; + } +#endif +#ifdef GL_VERSION_1_4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_4", 3)) + { + ret = GLEW_VERSION_1_4; + continue; + } +#endif +#ifdef GL_VERSION_1_5 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_5", 3)) + { + ret = GLEW_VERSION_1_5; + continue; + } +#endif +#ifdef GL_VERSION_2_0 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"2_0", 3)) + { + ret = GLEW_VERSION_2_0; + continue; + } +#endif +#ifdef GL_VERSION_2_1 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"2_1", 3)) + { + ret = GLEW_VERSION_2_1; + continue; + } +#endif +#ifdef GL_VERSION_3_0 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_0", 3)) + { + ret = GLEW_VERSION_3_0; + continue; + } +#endif +#ifdef GL_VERSION_3_1 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_1", 3)) + { + ret = GLEW_VERSION_3_1; + continue; + } +#endif +#ifdef GL_VERSION_3_2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_2", 3)) + { + ret = GLEW_VERSION_3_2; + continue; + } +#endif +#ifdef GL_VERSION_3_3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_3", 3)) + { + ret = GLEW_VERSION_3_3; + continue; + } +#endif +#ifdef GL_VERSION_4_0 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"4_0", 3)) + { + ret = GLEW_VERSION_4_0; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DFX_", 5)) + { +#ifdef GL_3DFX_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = GLEW_3DFX_multisample; + continue; + } +#endif +#ifdef GL_3DFX_tbuffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"tbuffer", 7)) + { + ret = GLEW_3DFX_tbuffer; + continue; + } +#endif +#ifdef GL_3DFX_texture_compression_FXT1 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_FXT1", 24)) + { + ret = GLEW_3DFX_texture_compression_FXT1; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"AMD_", 4)) + { +#ifdef GL_AMD_conservative_depth + if (_glewStrSame3(&pos, &len, (const GLubyte*)"conservative_depth", 18)) + { + ret = GLEW_AMD_conservative_depth; + continue; + } +#endif +#ifdef GL_AMD_draw_buffers_blend + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers_blend", 18)) + { + ret = GLEW_AMD_draw_buffers_blend; + continue; + } +#endif +#ifdef GL_AMD_performance_monitor + if (_glewStrSame3(&pos, &len, (const GLubyte*)"performance_monitor", 19)) + { + ret = GLEW_AMD_performance_monitor; + continue; + } +#endif +#ifdef GL_AMD_seamless_cubemap_per_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"seamless_cubemap_per_texture", 28)) + { + ret = GLEW_AMD_seamless_cubemap_per_texture; + continue; + } +#endif +#ifdef GL_AMD_shader_stencil_export + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_stencil_export", 21)) + { + ret = GLEW_AMD_shader_stencil_export; + continue; + } +#endif +#ifdef GL_AMD_texture_texture4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_texture4", 16)) + { + ret = GLEW_AMD_texture_texture4; + continue; + } +#endif +#ifdef GL_AMD_vertex_shader_tessellator + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader_tessellator", 25)) + { + ret = GLEW_AMD_vertex_shader_tessellator; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"APPLE_", 6)) + { +#ifdef GL_APPLE_aux_depth_stencil + if (_glewStrSame3(&pos, &len, (const GLubyte*)"aux_depth_stencil", 17)) + { + ret = GLEW_APPLE_aux_depth_stencil; + continue; + } +#endif +#ifdef GL_APPLE_client_storage + if (_glewStrSame3(&pos, &len, (const GLubyte*)"client_storage", 14)) + { + ret = GLEW_APPLE_client_storage; + continue; + } +#endif +#ifdef GL_APPLE_element_array + if (_glewStrSame3(&pos, &len, (const GLubyte*)"element_array", 13)) + { + ret = GLEW_APPLE_element_array; + continue; + } +#endif +#ifdef GL_APPLE_fence + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fence", 5)) + { + ret = GLEW_APPLE_fence; + continue; + } +#endif +#ifdef GL_APPLE_float_pixels + if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_pixels", 12)) + { + ret = GLEW_APPLE_float_pixels; + continue; + } +#endif +#ifdef GL_APPLE_flush_buffer_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"flush_buffer_range", 18)) + { + ret = GLEW_APPLE_flush_buffer_range; + continue; + } +#endif +#ifdef GL_APPLE_object_purgeable + if (_glewStrSame3(&pos, &len, (const GLubyte*)"object_purgeable", 16)) + { + ret = GLEW_APPLE_object_purgeable; + continue; + } +#endif +#ifdef GL_APPLE_pixel_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_buffer", 12)) + { + ret = GLEW_APPLE_pixel_buffer; + continue; + } +#endif +#ifdef GL_APPLE_rgb_422 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"rgb_422", 7)) + { + ret = GLEW_APPLE_rgb_422; + continue; + } +#endif +#ifdef GL_APPLE_row_bytes + if (_glewStrSame3(&pos, &len, (const GLubyte*)"row_bytes", 9)) + { + ret = GLEW_APPLE_row_bytes; + continue; + } +#endif +#ifdef GL_APPLE_specular_vector + if (_glewStrSame3(&pos, &len, (const GLubyte*)"specular_vector", 15)) + { + ret = GLEW_APPLE_specular_vector; + continue; + } +#endif +#ifdef GL_APPLE_texture_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_range", 13)) + { + ret = GLEW_APPLE_texture_range; + continue; + } +#endif +#ifdef GL_APPLE_transform_hint + if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_hint", 14)) + { + ret = GLEW_APPLE_transform_hint; + continue; + } +#endif +#ifdef GL_APPLE_vertex_array_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_object", 19)) + { + ret = GLEW_APPLE_vertex_array_object; + continue; + } +#endif +#ifdef GL_APPLE_vertex_array_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) + { + ret = GLEW_APPLE_vertex_array_range; + continue; + } +#endif +#ifdef GL_APPLE_vertex_program_evaluators + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program_evaluators", 25)) + { + ret = GLEW_APPLE_vertex_program_evaluators; + continue; + } +#endif +#ifdef GL_APPLE_ycbcr_422 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"ycbcr_422", 9)) + { + ret = GLEW_APPLE_ycbcr_422; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"ARB_", 4)) + { +#ifdef GL_ARB_blend_func_extended + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_func_extended", 19)) + { + ret = GLEW_ARB_blend_func_extended; + continue; + } +#endif +#ifdef GL_ARB_color_buffer_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_buffer_float", 18)) + { + ret = GLEW_ARB_color_buffer_float; + continue; + } +#endif +#ifdef GL_ARB_compatibility + if (_glewStrSame3(&pos, &len, (const GLubyte*)"compatibility", 13)) + { + ret = GLEW_ARB_compatibility; + continue; + } +#endif +#ifdef GL_ARB_copy_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_buffer", 11)) + { + ret = GLEW_ARB_copy_buffer; + continue; + } +#endif +#ifdef GL_ARB_depth_buffer_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_buffer_float", 18)) + { + ret = GLEW_ARB_depth_buffer_float; + continue; + } +#endif +#ifdef GL_ARB_depth_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_clamp", 11)) + { + ret = GLEW_ARB_depth_clamp; + continue; + } +#endif +#ifdef GL_ARB_depth_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_texture", 13)) + { + ret = GLEW_ARB_depth_texture; + continue; + } +#endif +#ifdef GL_ARB_draw_buffers + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers", 12)) + { + ret = GLEW_ARB_draw_buffers; + continue; + } +#endif +#ifdef GL_ARB_draw_buffers_blend + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers_blend", 18)) + { + ret = GLEW_ARB_draw_buffers_blend; + continue; + } +#endif +#ifdef GL_ARB_draw_elements_base_vertex + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_elements_base_vertex", 25)) + { + ret = GLEW_ARB_draw_elements_base_vertex; + continue; + } +#endif +#ifdef GL_ARB_draw_indirect + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_indirect", 13)) + { + ret = GLEW_ARB_draw_indirect; + continue; + } +#endif +#ifdef GL_ARB_draw_instanced + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_instanced", 14)) + { + ret = GLEW_ARB_draw_instanced; + continue; + } +#endif +#ifdef GL_ARB_explicit_attrib_location + if (_glewStrSame3(&pos, &len, (const GLubyte*)"explicit_attrib_location", 24)) + { + ret = GLEW_ARB_explicit_attrib_location; + continue; + } +#endif +#ifdef GL_ARB_fragment_coord_conventions + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_coord_conventions", 26)) + { + ret = GLEW_ARB_fragment_coord_conventions; + continue; + } +#endif +#ifdef GL_ARB_fragment_program + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program", 16)) + { + ret = GLEW_ARB_fragment_program; + continue; + } +#endif +#ifdef GL_ARB_fragment_program_shadow + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program_shadow", 23)) + { + ret = GLEW_ARB_fragment_program_shadow; + continue; + } +#endif +#ifdef GL_ARB_fragment_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_shader", 15)) + { + ret = GLEW_ARB_fragment_shader; + continue; + } +#endif +#ifdef GL_ARB_framebuffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_object", 18)) + { + ret = GLEW_ARB_framebuffer_object; + continue; + } +#endif +#ifdef GL_ARB_framebuffer_sRGB + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) + { + ret = GLEW_ARB_framebuffer_sRGB; + continue; + } +#endif +#ifdef GL_ARB_geometry_shader4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_shader4", 16)) + { + ret = GLEW_ARB_geometry_shader4; + continue; + } +#endif +#ifdef GL_ARB_gpu_shader5 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader5", 11)) + { + ret = GLEW_ARB_gpu_shader5; + continue; + } +#endif +#ifdef GL_ARB_gpu_shader_fp64 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader_fp64", 15)) + { + ret = GLEW_ARB_gpu_shader_fp64; + continue; + } +#endif +#ifdef GL_ARB_half_float_pixel + if (_glewStrSame3(&pos, &len, (const GLubyte*)"half_float_pixel", 16)) + { + ret = GLEW_ARB_half_float_pixel; + continue; + } +#endif +#ifdef GL_ARB_half_float_vertex + if (_glewStrSame3(&pos, &len, (const GLubyte*)"half_float_vertex", 17)) + { + ret = GLEW_ARB_half_float_vertex; + continue; + } +#endif +#ifdef GL_ARB_imaging + if (_glewStrSame3(&pos, &len, (const GLubyte*)"imaging", 7)) + { + ret = GLEW_ARB_imaging; + continue; + } +#endif +#ifdef GL_ARB_instanced_arrays + if (_glewStrSame3(&pos, &len, (const GLubyte*)"instanced_arrays", 16)) + { + ret = GLEW_ARB_instanced_arrays; + continue; + } +#endif +#ifdef GL_ARB_map_buffer_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"map_buffer_range", 16)) + { + ret = GLEW_ARB_map_buffer_range; + continue; + } +#endif +#ifdef GL_ARB_matrix_palette + if (_glewStrSame3(&pos, &len, (const GLubyte*)"matrix_palette", 14)) + { + ret = GLEW_ARB_matrix_palette; + continue; + } +#endif +#ifdef GL_ARB_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = GLEW_ARB_multisample; + continue; + } +#endif +#ifdef GL_ARB_multitexture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multitexture", 12)) + { + ret = GLEW_ARB_multitexture; + continue; + } +#endif +#ifdef GL_ARB_occlusion_query + if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_query", 15)) + { + ret = GLEW_ARB_occlusion_query; + continue; + } +#endif +#ifdef GL_ARB_occlusion_query2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_query2", 16)) + { + ret = GLEW_ARB_occlusion_query2; + continue; + } +#endif +#ifdef GL_ARB_pixel_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_buffer_object", 19)) + { + ret = GLEW_ARB_pixel_buffer_object; + continue; + } +#endif +#ifdef GL_ARB_point_parameters + if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_parameters", 16)) + { + ret = GLEW_ARB_point_parameters; + continue; + } +#endif +#ifdef GL_ARB_point_sprite + if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_sprite", 12)) + { + ret = GLEW_ARB_point_sprite; + continue; + } +#endif +#ifdef GL_ARB_provoking_vertex + if (_glewStrSame3(&pos, &len, (const GLubyte*)"provoking_vertex", 16)) + { + ret = GLEW_ARB_provoking_vertex; + continue; + } +#endif +#ifdef GL_ARB_sample_shading + if (_glewStrSame3(&pos, &len, (const GLubyte*)"sample_shading", 14)) + { + ret = GLEW_ARB_sample_shading; + continue; + } +#endif +#ifdef GL_ARB_sampler_objects + if (_glewStrSame3(&pos, &len, (const GLubyte*)"sampler_objects", 15)) + { + ret = GLEW_ARB_sampler_objects; + continue; + } +#endif +#ifdef GL_ARB_seamless_cube_map + if (_glewStrSame3(&pos, &len, (const GLubyte*)"seamless_cube_map", 17)) + { + ret = GLEW_ARB_seamless_cube_map; + continue; + } +#endif +#ifdef GL_ARB_shader_bit_encoding + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_bit_encoding", 19)) + { + ret = GLEW_ARB_shader_bit_encoding; + continue; + } +#endif +#ifdef GL_ARB_shader_objects + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_objects", 14)) + { + ret = GLEW_ARB_shader_objects; + continue; + } +#endif +#ifdef GL_ARB_shader_subroutine + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_subroutine", 17)) + { + ret = GLEW_ARB_shader_subroutine; + continue; + } +#endif +#ifdef GL_ARB_shader_texture_lod + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_texture_lod", 18)) + { + ret = GLEW_ARB_shader_texture_lod; + continue; + } +#endif +#ifdef GL_ARB_shading_language_100 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shading_language_100", 20)) + { + ret = GLEW_ARB_shading_language_100; + continue; + } +#endif +#ifdef GL_ARB_shading_language_include + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shading_language_include", 24)) + { + ret = GLEW_ARB_shading_language_include; + continue; + } +#endif +#ifdef GL_ARB_shadow + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow", 6)) + { + ret = GLEW_ARB_shadow; + continue; + } +#endif +#ifdef GL_ARB_shadow_ambient + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow_ambient", 14)) + { + ret = GLEW_ARB_shadow_ambient; + continue; + } +#endif +#ifdef GL_ARB_sync + if (_glewStrSame3(&pos, &len, (const GLubyte*)"sync", 4)) + { + ret = GLEW_ARB_sync; + continue; + } +#endif +#ifdef GL_ARB_tessellation_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"tessellation_shader", 19)) + { + ret = GLEW_ARB_tessellation_shader; + continue; + } +#endif +#ifdef GL_ARB_texture_border_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_border_clamp", 20)) + { + ret = GLEW_ARB_texture_border_clamp; + continue; + } +#endif +#ifdef GL_ARB_texture_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_buffer_object", 21)) + { + ret = GLEW_ARB_texture_buffer_object; + continue; + } +#endif +#ifdef GL_ARB_texture_buffer_object_rgb32 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_buffer_object_rgb32", 27)) + { + ret = GLEW_ARB_texture_buffer_object_rgb32; + continue; + } +#endif +#ifdef GL_ARB_texture_compression + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression", 19)) + { + ret = GLEW_ARB_texture_compression; + continue; + } +#endif +#ifdef GL_ARB_texture_compression_bptc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_bptc", 24)) + { + ret = GLEW_ARB_texture_compression_bptc; + continue; + } +#endif +#ifdef GL_ARB_texture_compression_rgtc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_rgtc", 24)) + { + ret = GLEW_ARB_texture_compression_rgtc; + continue; + } +#endif +#ifdef GL_ARB_texture_cube_map + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_cube_map", 16)) + { + ret = GLEW_ARB_texture_cube_map; + continue; + } +#endif +#ifdef GL_ARB_texture_cube_map_array + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_cube_map_array", 22)) + { + ret = GLEW_ARB_texture_cube_map_array; + continue; + } +#endif +#ifdef GL_ARB_texture_env_add + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_add", 15)) + { + ret = GLEW_ARB_texture_env_add; + continue; + } +#endif +#ifdef GL_ARB_texture_env_combine + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine", 19)) + { + ret = GLEW_ARB_texture_env_combine; + continue; + } +#endif +#ifdef GL_ARB_texture_env_crossbar + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_crossbar", 20)) + { + ret = GLEW_ARB_texture_env_crossbar; + continue; + } +#endif +#ifdef GL_ARB_texture_env_dot3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_dot3", 16)) + { + ret = GLEW_ARB_texture_env_dot3; + continue; + } +#endif +#ifdef GL_ARB_texture_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_float", 13)) + { + ret = GLEW_ARB_texture_float; + continue; + } +#endif +#ifdef GL_ARB_texture_gather + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_gather", 14)) + { + ret = GLEW_ARB_texture_gather; + continue; + } +#endif +#ifdef GL_ARB_texture_mirrored_repeat + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirrored_repeat", 23)) + { + ret = GLEW_ARB_texture_mirrored_repeat; + continue; + } +#endif +#ifdef GL_ARB_texture_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_multisample", 19)) + { + ret = GLEW_ARB_texture_multisample; + continue; + } +#endif +#ifdef GL_ARB_texture_non_power_of_two + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_non_power_of_two", 24)) + { + ret = GLEW_ARB_texture_non_power_of_two; + continue; + } +#endif +#ifdef GL_ARB_texture_query_lod + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_query_lod", 17)) + { + ret = GLEW_ARB_texture_query_lod; + continue; + } +#endif +#ifdef GL_ARB_texture_rectangle + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rectangle", 17)) + { + ret = GLEW_ARB_texture_rectangle; + continue; + } +#endif +#ifdef GL_ARB_texture_rg + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rg", 10)) + { + ret = GLEW_ARB_texture_rg; + continue; + } +#endif +#ifdef GL_ARB_texture_rgb10_a2ui + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rgb10_a2ui", 18)) + { + ret = GLEW_ARB_texture_rgb10_a2ui; + continue; + } +#endif +#ifdef GL_ARB_texture_swizzle + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_swizzle", 15)) + { + ret = GLEW_ARB_texture_swizzle; + continue; + } +#endif +#ifdef GL_ARB_timer_query + if (_glewStrSame3(&pos, &len, (const GLubyte*)"timer_query", 11)) + { + ret = GLEW_ARB_timer_query; + continue; + } +#endif +#ifdef GL_ARB_transform_feedback2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback2", 19)) + { + ret = GLEW_ARB_transform_feedback2; + continue; + } +#endif +#ifdef GL_ARB_transform_feedback3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback3", 19)) + { + ret = GLEW_ARB_transform_feedback3; + continue; + } +#endif +#ifdef GL_ARB_transpose_matrix + if (_glewStrSame3(&pos, &len, (const GLubyte*)"transpose_matrix", 16)) + { + ret = GLEW_ARB_transpose_matrix; + continue; + } +#endif +#ifdef GL_ARB_uniform_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"uniform_buffer_object", 21)) + { + ret = GLEW_ARB_uniform_buffer_object; + continue; + } +#endif +#ifdef GL_ARB_vertex_array_bgra + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_bgra", 17)) + { + ret = GLEW_ARB_vertex_array_bgra; + continue; + } +#endif +#ifdef GL_ARB_vertex_array_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_object", 19)) + { + ret = GLEW_ARB_vertex_array_object; + continue; + } +#endif +#ifdef GL_ARB_vertex_blend + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_blend", 12)) + { + ret = GLEW_ARB_vertex_blend; + continue; + } +#endif +#ifdef GL_ARB_vertex_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_buffer_object", 20)) + { + ret = GLEW_ARB_vertex_buffer_object; + continue; + } +#endif +#ifdef GL_ARB_vertex_program + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program", 14)) + { + ret = GLEW_ARB_vertex_program; + continue; + } +#endif +#ifdef GL_ARB_vertex_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader", 13)) + { + ret = GLEW_ARB_vertex_shader; + continue; + } +#endif +#ifdef GL_ARB_vertex_type_2_10_10_10_rev + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_type_2_10_10_10_rev", 26)) + { + ret = GLEW_ARB_vertex_type_2_10_10_10_rev; + continue; + } +#endif +#ifdef GL_ARB_window_pos + if (_glewStrSame3(&pos, &len, (const GLubyte*)"window_pos", 10)) + { + ret = GLEW_ARB_window_pos; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATIX_", 5)) + { +#ifdef GL_ATIX_point_sprites + if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_sprites", 13)) + { + ret = GLEW_ATIX_point_sprites; + continue; + } +#endif +#ifdef GL_ATIX_texture_env_combine3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine3", 20)) + { + ret = GLEW_ATIX_texture_env_combine3; + continue; + } +#endif +#ifdef GL_ATIX_texture_env_route + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_route", 17)) + { + ret = GLEW_ATIX_texture_env_route; + continue; + } +#endif +#ifdef GL_ATIX_vertex_shader_output_point_size + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader_output_point_size", 31)) + { + ret = GLEW_ATIX_vertex_shader_output_point_size; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATI_", 4)) + { +#ifdef GL_ATI_draw_buffers + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers", 12)) + { + ret = GLEW_ATI_draw_buffers; + continue; + } +#endif +#ifdef GL_ATI_element_array + if (_glewStrSame3(&pos, &len, (const GLubyte*)"element_array", 13)) + { + ret = GLEW_ATI_element_array; + continue; + } +#endif +#ifdef GL_ATI_envmap_bumpmap + if (_glewStrSame3(&pos, &len, (const GLubyte*)"envmap_bumpmap", 14)) + { + ret = GLEW_ATI_envmap_bumpmap; + continue; + } +#endif +#ifdef GL_ATI_fragment_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_shader", 15)) + { + ret = GLEW_ATI_fragment_shader; + continue; + } +#endif +#ifdef GL_ATI_map_object_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"map_object_buffer", 17)) + { + ret = GLEW_ATI_map_object_buffer; + continue; + } +#endif +#ifdef GL_ATI_meminfo + if (_glewStrSame3(&pos, &len, (const GLubyte*)"meminfo", 7)) + { + ret = GLEW_ATI_meminfo; + continue; + } +#endif +#ifdef GL_ATI_pn_triangles + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pn_triangles", 12)) + { + ret = GLEW_ATI_pn_triangles; + continue; + } +#endif +#ifdef GL_ATI_separate_stencil + if (_glewStrSame3(&pos, &len, (const GLubyte*)"separate_stencil", 16)) + { + ret = GLEW_ATI_separate_stencil; + continue; + } +#endif +#ifdef GL_ATI_shader_texture_lod + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_texture_lod", 18)) + { + ret = GLEW_ATI_shader_texture_lod; + continue; + } +#endif +#ifdef GL_ATI_text_fragment_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"text_fragment_shader", 20)) + { + ret = GLEW_ATI_text_fragment_shader; + continue; + } +#endif +#ifdef GL_ATI_texture_compression_3dc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_3dc", 23)) + { + ret = GLEW_ATI_texture_compression_3dc; + continue; + } +#endif +#ifdef GL_ATI_texture_env_combine3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine3", 20)) + { + ret = GLEW_ATI_texture_env_combine3; + continue; + } +#endif +#ifdef GL_ATI_texture_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_float", 13)) + { + ret = GLEW_ATI_texture_float; + continue; + } +#endif +#ifdef GL_ATI_texture_mirror_once + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirror_once", 19)) + { + ret = GLEW_ATI_texture_mirror_once; + continue; + } +#endif +#ifdef GL_ATI_vertex_array_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_object", 19)) + { + ret = GLEW_ATI_vertex_array_object; + continue; + } +#endif +#ifdef GL_ATI_vertex_attrib_array_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_array_object", 26)) + { + ret = GLEW_ATI_vertex_attrib_array_object; + continue; + } +#endif +#ifdef GL_ATI_vertex_streams + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_streams", 14)) + { + ret = GLEW_ATI_vertex_streams; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"EXT_", 4)) + { +#ifdef GL_EXT_422_pixels + if (_glewStrSame3(&pos, &len, (const GLubyte*)"422_pixels", 10)) + { + ret = GLEW_EXT_422_pixels; + continue; + } +#endif +#ifdef GL_EXT_Cg_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"Cg_shader", 9)) + { + ret = GLEW_EXT_Cg_shader; + continue; + } +#endif +#ifdef GL_EXT_abgr + if (_glewStrSame3(&pos, &len, (const GLubyte*)"abgr", 4)) + { + ret = GLEW_EXT_abgr; + continue; + } +#endif +#ifdef GL_EXT_bgra + if (_glewStrSame3(&pos, &len, (const GLubyte*)"bgra", 4)) + { + ret = GLEW_EXT_bgra; + continue; + } +#endif +#ifdef GL_EXT_bindable_uniform + if (_glewStrSame3(&pos, &len, (const GLubyte*)"bindable_uniform", 16)) + { + ret = GLEW_EXT_bindable_uniform; + continue; + } +#endif +#ifdef GL_EXT_blend_color + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_color", 11)) + { + ret = GLEW_EXT_blend_color; + continue; + } +#endif +#ifdef GL_EXT_blend_equation_separate + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_equation_separate", 23)) + { + ret = GLEW_EXT_blend_equation_separate; + continue; + } +#endif +#ifdef GL_EXT_blend_func_separate + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_func_separate", 19)) + { + ret = GLEW_EXT_blend_func_separate; + continue; + } +#endif +#ifdef GL_EXT_blend_logic_op + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_logic_op", 14)) + { + ret = GLEW_EXT_blend_logic_op; + continue; + } +#endif +#ifdef GL_EXT_blend_minmax + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_minmax", 12)) + { + ret = GLEW_EXT_blend_minmax; + continue; + } +#endif +#ifdef GL_EXT_blend_subtract + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_subtract", 14)) + { + ret = GLEW_EXT_blend_subtract; + continue; + } +#endif +#ifdef GL_EXT_clip_volume_hint + if (_glewStrSame3(&pos, &len, (const GLubyte*)"clip_volume_hint", 16)) + { + ret = GLEW_EXT_clip_volume_hint; + continue; + } +#endif +#ifdef GL_EXT_cmyka + if (_glewStrSame3(&pos, &len, (const GLubyte*)"cmyka", 5)) + { + ret = GLEW_EXT_cmyka; + continue; + } +#endif +#ifdef GL_EXT_color_subtable + if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_subtable", 14)) + { + ret = GLEW_EXT_color_subtable; + continue; + } +#endif +#ifdef GL_EXT_compiled_vertex_array + if (_glewStrSame3(&pos, &len, (const GLubyte*)"compiled_vertex_array", 21)) + { + ret = GLEW_EXT_compiled_vertex_array; + continue; + } +#endif +#ifdef GL_EXT_convolution + if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution", 11)) + { + ret = GLEW_EXT_convolution; + continue; + } +#endif +#ifdef GL_EXT_coordinate_frame + if (_glewStrSame3(&pos, &len, (const GLubyte*)"coordinate_frame", 16)) + { + ret = GLEW_EXT_coordinate_frame; + continue; + } +#endif +#ifdef GL_EXT_copy_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_texture", 12)) + { + ret = GLEW_EXT_copy_texture; + continue; + } +#endif +#ifdef GL_EXT_cull_vertex + if (_glewStrSame3(&pos, &len, (const GLubyte*)"cull_vertex", 11)) + { + ret = GLEW_EXT_cull_vertex; + continue; + } +#endif +#ifdef GL_EXT_depth_bounds_test + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_bounds_test", 17)) + { + ret = GLEW_EXT_depth_bounds_test; + continue; + } +#endif +#ifdef GL_EXT_direct_state_access + if (_glewStrSame3(&pos, &len, (const GLubyte*)"direct_state_access", 19)) + { + ret = GLEW_EXT_direct_state_access; + continue; + } +#endif +#ifdef GL_EXT_draw_buffers2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers2", 13)) + { + ret = GLEW_EXT_draw_buffers2; + continue; + } +#endif +#ifdef GL_EXT_draw_instanced + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_instanced", 14)) + { + ret = GLEW_EXT_draw_instanced; + continue; + } +#endif +#ifdef GL_EXT_draw_range_elements + if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_range_elements", 19)) + { + ret = GLEW_EXT_draw_range_elements; + continue; + } +#endif +#ifdef GL_EXT_fog_coord + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_coord", 9)) + { + ret = GLEW_EXT_fog_coord; + continue; + } +#endif +#ifdef GL_EXT_fragment_lighting + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_lighting", 17)) + { + ret = GLEW_EXT_fragment_lighting; + continue; + } +#endif +#ifdef GL_EXT_framebuffer_blit + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_blit", 16)) + { + ret = GLEW_EXT_framebuffer_blit; + continue; + } +#endif +#ifdef GL_EXT_framebuffer_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_multisample", 23)) + { + ret = GLEW_EXT_framebuffer_multisample; + continue; + } +#endif +#ifdef GL_EXT_framebuffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_object", 18)) + { + ret = GLEW_EXT_framebuffer_object; + continue; + } +#endif +#ifdef GL_EXT_framebuffer_sRGB + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) + { + ret = GLEW_EXT_framebuffer_sRGB; + continue; + } +#endif +#ifdef GL_EXT_geometry_shader4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_shader4", 16)) + { + ret = GLEW_EXT_geometry_shader4; + continue; + } +#endif +#ifdef GL_EXT_gpu_program_parameters + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program_parameters", 22)) + { + ret = GLEW_EXT_gpu_program_parameters; + continue; + } +#endif +#ifdef GL_EXT_gpu_shader4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader4", 11)) + { + ret = GLEW_EXT_gpu_shader4; + continue; + } +#endif +#ifdef GL_EXT_histogram + if (_glewStrSame3(&pos, &len, (const GLubyte*)"histogram", 9)) + { + ret = GLEW_EXT_histogram; + continue; + } +#endif +#ifdef GL_EXT_index_array_formats + if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_array_formats", 19)) + { + ret = GLEW_EXT_index_array_formats; + continue; + } +#endif +#ifdef GL_EXT_index_func + if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_func", 10)) + { + ret = GLEW_EXT_index_func; + continue; + } +#endif +#ifdef GL_EXT_index_material + if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_material", 14)) + { + ret = GLEW_EXT_index_material; + continue; + } +#endif +#ifdef GL_EXT_index_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_texture", 13)) + { + ret = GLEW_EXT_index_texture; + continue; + } +#endif +#ifdef GL_EXT_light_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"light_texture", 13)) + { + ret = GLEW_EXT_light_texture; + continue; + } +#endif +#ifdef GL_EXT_misc_attribute + if (_glewStrSame3(&pos, &len, (const GLubyte*)"misc_attribute", 14)) + { + ret = GLEW_EXT_misc_attribute; + continue; + } +#endif +#ifdef GL_EXT_multi_draw_arrays + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multi_draw_arrays", 17)) + { + ret = GLEW_EXT_multi_draw_arrays; + continue; + } +#endif +#ifdef GL_EXT_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = GLEW_EXT_multisample; + continue; + } +#endif +#ifdef GL_EXT_packed_depth_stencil + if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_depth_stencil", 20)) + { + ret = GLEW_EXT_packed_depth_stencil; + continue; + } +#endif +#ifdef GL_EXT_packed_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_float", 12)) + { + ret = GLEW_EXT_packed_float; + continue; + } +#endif +#ifdef GL_EXT_packed_pixels + if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_pixels", 13)) + { + ret = GLEW_EXT_packed_pixels; + continue; + } +#endif +#ifdef GL_EXT_paletted_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"paletted_texture", 16)) + { + ret = GLEW_EXT_paletted_texture; + continue; + } +#endif +#ifdef GL_EXT_pixel_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_buffer_object", 19)) + { + ret = GLEW_EXT_pixel_buffer_object; + continue; + } +#endif +#ifdef GL_EXT_pixel_transform + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_transform", 15)) + { + ret = GLEW_EXT_pixel_transform; + continue; + } +#endif +#ifdef GL_EXT_pixel_transform_color_table + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_transform_color_table", 27)) + { + ret = GLEW_EXT_pixel_transform_color_table; + continue; + } +#endif +#ifdef GL_EXT_point_parameters + if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_parameters", 16)) + { + ret = GLEW_EXT_point_parameters; + continue; + } +#endif +#ifdef GL_EXT_polygon_offset + if (_glewStrSame3(&pos, &len, (const GLubyte*)"polygon_offset", 14)) + { + ret = GLEW_EXT_polygon_offset; + continue; + } +#endif +#ifdef GL_EXT_provoking_vertex + if (_glewStrSame3(&pos, &len, (const GLubyte*)"provoking_vertex", 16)) + { + ret = GLEW_EXT_provoking_vertex; + continue; + } +#endif +#ifdef GL_EXT_rescale_normal + if (_glewStrSame3(&pos, &len, (const GLubyte*)"rescale_normal", 14)) + { + ret = GLEW_EXT_rescale_normal; + continue; + } +#endif +#ifdef GL_EXT_scene_marker + if (_glewStrSame3(&pos, &len, (const GLubyte*)"scene_marker", 12)) + { + ret = GLEW_EXT_scene_marker; + continue; + } +#endif +#ifdef GL_EXT_secondary_color + if (_glewStrSame3(&pos, &len, (const GLubyte*)"secondary_color", 15)) + { + ret = GLEW_EXT_secondary_color; + continue; + } +#endif +#ifdef GL_EXT_separate_shader_objects + if (_glewStrSame3(&pos, &len, (const GLubyte*)"separate_shader_objects", 23)) + { + ret = GLEW_EXT_separate_shader_objects; + continue; + } +#endif +#ifdef GL_EXT_separate_specular_color + if (_glewStrSame3(&pos, &len, (const GLubyte*)"separate_specular_color", 23)) + { + ret = GLEW_EXT_separate_specular_color; + continue; + } +#endif +#ifdef GL_EXT_shader_image_load_store + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_image_load_store", 23)) + { + ret = GLEW_EXT_shader_image_load_store; + continue; + } +#endif +#ifdef GL_EXT_shadow_funcs + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow_funcs", 12)) + { + ret = GLEW_EXT_shadow_funcs; + continue; + } +#endif +#ifdef GL_EXT_shared_texture_palette + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shared_texture_palette", 22)) + { + ret = GLEW_EXT_shared_texture_palette; + continue; + } +#endif +#ifdef GL_EXT_stencil_clear_tag + if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_clear_tag", 17)) + { + ret = GLEW_EXT_stencil_clear_tag; + continue; + } +#endif +#ifdef GL_EXT_stencil_two_side + if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_two_side", 16)) + { + ret = GLEW_EXT_stencil_two_side; + continue; + } +#endif +#ifdef GL_EXT_stencil_wrap + if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_wrap", 12)) + { + ret = GLEW_EXT_stencil_wrap; + continue; + } +#endif +#ifdef GL_EXT_subtexture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"subtexture", 10)) + { + ret = GLEW_EXT_subtexture; + continue; + } +#endif +#ifdef GL_EXT_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture", 7)) + { + ret = GLEW_EXT_texture; + continue; + } +#endif +#ifdef GL_EXT_texture3D + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture3D", 9)) + { + ret = GLEW_EXT_texture3D; + continue; + } +#endif +#ifdef GL_EXT_texture_array + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_array", 13)) + { + ret = GLEW_EXT_texture_array; + continue; + } +#endif +#ifdef GL_EXT_texture_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_buffer_object", 21)) + { + ret = GLEW_EXT_texture_buffer_object; + continue; + } +#endif +#ifdef GL_EXT_texture_compression_dxt1 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_dxt1", 24)) + { + ret = GLEW_EXT_texture_compression_dxt1; + continue; + } +#endif +#ifdef GL_EXT_texture_compression_latc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_latc", 24)) + { + ret = GLEW_EXT_texture_compression_latc; + continue; + } +#endif +#ifdef GL_EXT_texture_compression_rgtc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_rgtc", 24)) + { + ret = GLEW_EXT_texture_compression_rgtc; + continue; + } +#endif +#ifdef GL_EXT_texture_compression_s3tc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_s3tc", 24)) + { + ret = GLEW_EXT_texture_compression_s3tc; + continue; + } +#endif +#ifdef GL_EXT_texture_cube_map + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_cube_map", 16)) + { + ret = GLEW_EXT_texture_cube_map; + continue; + } +#endif +#ifdef GL_EXT_texture_edge_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_edge_clamp", 18)) + { + ret = GLEW_EXT_texture_edge_clamp; + continue; + } +#endif +#ifdef GL_EXT_texture_env + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env", 11)) + { + ret = GLEW_EXT_texture_env; + continue; + } +#endif +#ifdef GL_EXT_texture_env_add + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_add", 15)) + { + ret = GLEW_EXT_texture_env_add; + continue; + } +#endif +#ifdef GL_EXT_texture_env_combine + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine", 19)) + { + ret = GLEW_EXT_texture_env_combine; + continue; + } +#endif +#ifdef GL_EXT_texture_env_dot3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_dot3", 16)) + { + ret = GLEW_EXT_texture_env_dot3; + continue; + } +#endif +#ifdef GL_EXT_texture_filter_anisotropic + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_filter_anisotropic", 26)) + { + ret = GLEW_EXT_texture_filter_anisotropic; + continue; + } +#endif +#ifdef GL_EXT_texture_integer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_integer", 15)) + { + ret = GLEW_EXT_texture_integer; + continue; + } +#endif +#ifdef GL_EXT_texture_lod_bias + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lod_bias", 16)) + { + ret = GLEW_EXT_texture_lod_bias; + continue; + } +#endif +#ifdef GL_EXT_texture_mirror_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirror_clamp", 20)) + { + ret = GLEW_EXT_texture_mirror_clamp; + continue; + } +#endif +#ifdef GL_EXT_texture_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_object", 14)) + { + ret = GLEW_EXT_texture_object; + continue; + } +#endif +#ifdef GL_EXT_texture_perturb_normal + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_perturb_normal", 22)) + { + ret = GLEW_EXT_texture_perturb_normal; + continue; + } +#endif +#ifdef GL_EXT_texture_rectangle + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rectangle", 17)) + { + ret = GLEW_EXT_texture_rectangle; + continue; + } +#endif +#ifdef GL_EXT_texture_sRGB + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_sRGB", 12)) + { + ret = GLEW_EXT_texture_sRGB; + continue; + } +#endif +#ifdef GL_EXT_texture_shared_exponent + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shared_exponent", 23)) + { + ret = GLEW_EXT_texture_shared_exponent; + continue; + } +#endif +#ifdef GL_EXT_texture_snorm + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_snorm", 13)) + { + ret = GLEW_EXT_texture_snorm; + continue; + } +#endif +#ifdef GL_EXT_texture_swizzle + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_swizzle", 15)) + { + ret = GLEW_EXT_texture_swizzle; + continue; + } +#endif +#ifdef GL_EXT_timer_query + if (_glewStrSame3(&pos, &len, (const GLubyte*)"timer_query", 11)) + { + ret = GLEW_EXT_timer_query; + continue; + } +#endif +#ifdef GL_EXT_transform_feedback + if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback", 18)) + { + ret = GLEW_EXT_transform_feedback; + continue; + } +#endif +#ifdef GL_EXT_vertex_array + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array", 12)) + { + ret = GLEW_EXT_vertex_array; + continue; + } +#endif +#ifdef GL_EXT_vertex_array_bgra + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_bgra", 17)) + { + ret = GLEW_EXT_vertex_array_bgra; + continue; + } +#endif +#ifdef GL_EXT_vertex_attrib_64bit + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_64bit", 19)) + { + ret = GLEW_EXT_vertex_attrib_64bit; + continue; + } +#endif +#ifdef GL_EXT_vertex_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader", 13)) + { + ret = GLEW_EXT_vertex_shader; + continue; + } +#endif +#ifdef GL_EXT_vertex_weighting + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_weighting", 16)) + { + ret = GLEW_EXT_vertex_weighting; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"GREMEDY_", 8)) + { +#ifdef GL_GREMEDY_frame_terminator + if (_glewStrSame3(&pos, &len, (const GLubyte*)"frame_terminator", 16)) + { + ret = GLEW_GREMEDY_frame_terminator; + continue; + } +#endif +#ifdef GL_GREMEDY_string_marker + if (_glewStrSame3(&pos, &len, (const GLubyte*)"string_marker", 13)) + { + ret = GLEW_GREMEDY_string_marker; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"HP_", 3)) + { +#ifdef GL_HP_convolution_border_modes + if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution_border_modes", 24)) + { + ret = GLEW_HP_convolution_border_modes; + continue; + } +#endif +#ifdef GL_HP_image_transform + if (_glewStrSame3(&pos, &len, (const GLubyte*)"image_transform", 15)) + { + ret = GLEW_HP_image_transform; + continue; + } +#endif +#ifdef GL_HP_occlusion_test + if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_test", 14)) + { + ret = GLEW_HP_occlusion_test; + continue; + } +#endif +#ifdef GL_HP_texture_lighting + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lighting", 16)) + { + ret = GLEW_HP_texture_lighting; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"IBM_", 4)) + { +#ifdef GL_IBM_cull_vertex + if (_glewStrSame3(&pos, &len, (const GLubyte*)"cull_vertex", 11)) + { + ret = GLEW_IBM_cull_vertex; + continue; + } +#endif +#ifdef GL_IBM_multimode_draw_arrays + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multimode_draw_arrays", 21)) + { + ret = GLEW_IBM_multimode_draw_arrays; + continue; + } +#endif +#ifdef GL_IBM_rasterpos_clip + if (_glewStrSame3(&pos, &len, (const GLubyte*)"rasterpos_clip", 14)) + { + ret = GLEW_IBM_rasterpos_clip; + continue; + } +#endif +#ifdef GL_IBM_static_data + if (_glewStrSame3(&pos, &len, (const GLubyte*)"static_data", 11)) + { + ret = GLEW_IBM_static_data; + continue; + } +#endif +#ifdef GL_IBM_texture_mirrored_repeat + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirrored_repeat", 23)) + { + ret = GLEW_IBM_texture_mirrored_repeat; + continue; + } +#endif +#ifdef GL_IBM_vertex_array_lists + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_lists", 18)) + { + ret = GLEW_IBM_vertex_array_lists; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"INGR_", 5)) + { +#ifdef GL_INGR_color_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_clamp", 11)) + { + ret = GLEW_INGR_color_clamp; + continue; + } +#endif +#ifdef GL_INGR_interlace_read + if (_glewStrSame3(&pos, &len, (const GLubyte*)"interlace_read", 14)) + { + ret = GLEW_INGR_interlace_read; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"INTEL_", 6)) + { +#ifdef GL_INTEL_parallel_arrays + if (_glewStrSame3(&pos, &len, (const GLubyte*)"parallel_arrays", 15)) + { + ret = GLEW_INTEL_parallel_arrays; + continue; + } +#endif +#ifdef GL_INTEL_texture_scissor + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_scissor", 15)) + { + ret = GLEW_INTEL_texture_scissor; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"KTX_", 4)) + { +#ifdef GL_KTX_buffer_region + if (_glewStrSame3(&pos, &len, (const GLubyte*)"buffer_region", 13)) + { + ret = GLEW_KTX_buffer_region; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"MESAX_", 6)) + { +#ifdef GL_MESAX_texture_stack + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_stack", 13)) + { + ret = GLEW_MESAX_texture_stack; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"MESA_", 5)) + { +#ifdef GL_MESA_pack_invert + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pack_invert", 11)) + { + ret = GLEW_MESA_pack_invert; + continue; + } +#endif +#ifdef GL_MESA_resize_buffers + if (_glewStrSame3(&pos, &len, (const GLubyte*)"resize_buffers", 14)) + { + ret = GLEW_MESA_resize_buffers; + continue; + } +#endif +#ifdef GL_MESA_window_pos + if (_glewStrSame3(&pos, &len, (const GLubyte*)"window_pos", 10)) + { + ret = GLEW_MESA_window_pos; + continue; + } +#endif +#ifdef GL_MESA_ycbcr_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"ycbcr_texture", 13)) + { + ret = GLEW_MESA_ycbcr_texture; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"NV_", 3)) + { +#ifdef GL_NV_blend_square + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_square", 12)) + { + ret = GLEW_NV_blend_square; + continue; + } +#endif +#ifdef GL_NV_conditional_render + if (_glewStrSame3(&pos, &len, (const GLubyte*)"conditional_render", 18)) + { + ret = GLEW_NV_conditional_render; + continue; + } +#endif +#ifdef GL_NV_copy_depth_to_color + if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_depth_to_color", 19)) + { + ret = GLEW_NV_copy_depth_to_color; + continue; + } +#endif +#ifdef GL_NV_copy_image + if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_image", 10)) + { + ret = GLEW_NV_copy_image; + continue; + } +#endif +#ifdef GL_NV_depth_buffer_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_buffer_float", 18)) + { + ret = GLEW_NV_depth_buffer_float; + continue; + } +#endif +#ifdef GL_NV_depth_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_clamp", 11)) + { + ret = GLEW_NV_depth_clamp; + continue; + } +#endif +#ifdef GL_NV_depth_range_unclamped + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_range_unclamped", 21)) + { + ret = GLEW_NV_depth_range_unclamped; + continue; + } +#endif +#ifdef GL_NV_evaluators + if (_glewStrSame3(&pos, &len, (const GLubyte*)"evaluators", 10)) + { + ret = GLEW_NV_evaluators; + continue; + } +#endif +#ifdef GL_NV_explicit_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"explicit_multisample", 20)) + { + ret = GLEW_NV_explicit_multisample; + continue; + } +#endif +#ifdef GL_NV_fence + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fence", 5)) + { + ret = GLEW_NV_fence; + continue; + } +#endif +#ifdef GL_NV_float_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_buffer", 12)) + { + ret = GLEW_NV_float_buffer; + continue; + } +#endif +#ifdef GL_NV_fog_distance + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_distance", 12)) + { + ret = GLEW_NV_fog_distance; + continue; + } +#endif +#ifdef GL_NV_fragment_program + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program", 16)) + { + ret = GLEW_NV_fragment_program; + continue; + } +#endif +#ifdef GL_NV_fragment_program2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program2", 17)) + { + ret = GLEW_NV_fragment_program2; + continue; + } +#endif +#ifdef GL_NV_fragment_program4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program4", 17)) + { + ret = GLEW_NV_fragment_program4; + continue; + } +#endif +#ifdef GL_NV_fragment_program_option + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program_option", 23)) + { + ret = GLEW_NV_fragment_program_option; + continue; + } +#endif +#ifdef GL_NV_framebuffer_multisample_coverage + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_multisample_coverage", 32)) + { + ret = GLEW_NV_framebuffer_multisample_coverage; + continue; + } +#endif +#ifdef GL_NV_geometry_program4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_program4", 17)) + { + ret = GLEW_NV_geometry_program4; + continue; + } +#endif +#ifdef GL_NV_geometry_shader4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_shader4", 16)) + { + ret = GLEW_NV_geometry_shader4; + continue; + } +#endif +#ifdef GL_NV_gpu_program4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program4", 12)) + { + ret = GLEW_NV_gpu_program4; + continue; + } +#endif +#ifdef GL_NV_gpu_program5 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program5", 12)) + { + ret = GLEW_NV_gpu_program5; + continue; + } +#endif +#ifdef GL_NV_gpu_program_fp64 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program_fp64", 16)) + { + ret = GLEW_NV_gpu_program_fp64; + continue; + } +#endif +#ifdef GL_NV_gpu_shader5 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader5", 11)) + { + ret = GLEW_NV_gpu_shader5; + continue; + } +#endif +#ifdef GL_NV_half_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"half_float", 10)) + { + ret = GLEW_NV_half_float; + continue; + } +#endif +#ifdef GL_NV_light_max_exponent + if (_glewStrSame3(&pos, &len, (const GLubyte*)"light_max_exponent", 18)) + { + ret = GLEW_NV_light_max_exponent; + continue; + } +#endif +#ifdef GL_NV_multisample_filter_hint + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample_filter_hint", 23)) + { + ret = GLEW_NV_multisample_filter_hint; + continue; + } +#endif +#ifdef GL_NV_occlusion_query + if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_query", 15)) + { + ret = GLEW_NV_occlusion_query; + continue; + } +#endif +#ifdef GL_NV_packed_depth_stencil + if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_depth_stencil", 20)) + { + ret = GLEW_NV_packed_depth_stencil; + continue; + } +#endif +#ifdef GL_NV_parameter_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"parameter_buffer_object", 23)) + { + ret = GLEW_NV_parameter_buffer_object; + continue; + } +#endif +#ifdef GL_NV_parameter_buffer_object2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"parameter_buffer_object2", 24)) + { + ret = GLEW_NV_parameter_buffer_object2; + continue; + } +#endif +#ifdef GL_NV_pixel_data_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_data_range", 16)) + { + ret = GLEW_NV_pixel_data_range; + continue; + } +#endif +#ifdef GL_NV_point_sprite + if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_sprite", 12)) + { + ret = GLEW_NV_point_sprite; + continue; + } +#endif +#ifdef GL_NV_present_video + if (_glewStrSame3(&pos, &len, (const GLubyte*)"present_video", 13)) + { + ret = GLEW_NV_present_video; + continue; + } +#endif +#ifdef GL_NV_primitive_restart + if (_glewStrSame3(&pos, &len, (const GLubyte*)"primitive_restart", 17)) + { + ret = GLEW_NV_primitive_restart; + continue; + } +#endif +#ifdef GL_NV_register_combiners + if (_glewStrSame3(&pos, &len, (const GLubyte*)"register_combiners", 18)) + { + ret = GLEW_NV_register_combiners; + continue; + } +#endif +#ifdef GL_NV_register_combiners2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"register_combiners2", 19)) + { + ret = GLEW_NV_register_combiners2; + continue; + } +#endif +#ifdef GL_NV_shader_buffer_load + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_buffer_load", 18)) + { + ret = GLEW_NV_shader_buffer_load; + continue; + } +#endif +#ifdef GL_NV_tessellation_program5 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"tessellation_program5", 21)) + { + ret = GLEW_NV_tessellation_program5; + continue; + } +#endif +#ifdef GL_NV_texgen_emboss + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texgen_emboss", 13)) + { + ret = GLEW_NV_texgen_emboss; + continue; + } +#endif +#ifdef GL_NV_texgen_reflection + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texgen_reflection", 17)) + { + ret = GLEW_NV_texgen_reflection; + continue; + } +#endif +#ifdef GL_NV_texture_barrier + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_barrier", 15)) + { + ret = GLEW_NV_texture_barrier; + continue; + } +#endif +#ifdef GL_NV_texture_compression_vtc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_vtc", 23)) + { + ret = GLEW_NV_texture_compression_vtc; + continue; + } +#endif +#ifdef GL_NV_texture_env_combine4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine4", 20)) + { + ret = GLEW_NV_texture_env_combine4; + continue; + } +#endif +#ifdef GL_NV_texture_expand_normal + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_expand_normal", 21)) + { + ret = GLEW_NV_texture_expand_normal; + continue; + } +#endif +#ifdef GL_NV_texture_rectangle + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rectangle", 17)) + { + ret = GLEW_NV_texture_rectangle; + continue; + } +#endif +#ifdef GL_NV_texture_shader + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shader", 14)) + { + ret = GLEW_NV_texture_shader; + continue; + } +#endif +#ifdef GL_NV_texture_shader2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shader2", 15)) + { + ret = GLEW_NV_texture_shader2; + continue; + } +#endif +#ifdef GL_NV_texture_shader3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shader3", 15)) + { + ret = GLEW_NV_texture_shader3; + continue; + } +#endif +#ifdef GL_NV_transform_feedback + if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback", 18)) + { + ret = GLEW_NV_transform_feedback; + continue; + } +#endif +#ifdef GL_NV_transform_feedback2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback2", 19)) + { + ret = GLEW_NV_transform_feedback2; + continue; + } +#endif +#ifdef GL_NV_vertex_array_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) + { + ret = GLEW_NV_vertex_array_range; + continue; + } +#endif +#ifdef GL_NV_vertex_array_range2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range2", 19)) + { + ret = GLEW_NV_vertex_array_range2; + continue; + } +#endif +#ifdef GL_NV_vertex_attrib_integer_64bit + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_integer_64bit", 27)) + { + ret = GLEW_NV_vertex_attrib_integer_64bit; + continue; + } +#endif +#ifdef GL_NV_vertex_buffer_unified_memory + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_buffer_unified_memory", 28)) + { + ret = GLEW_NV_vertex_buffer_unified_memory; + continue; + } +#endif +#ifdef GL_NV_vertex_program + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program", 14)) + { + ret = GLEW_NV_vertex_program; + continue; + } +#endif +#ifdef GL_NV_vertex_program1_1 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program1_1", 17)) + { + ret = GLEW_NV_vertex_program1_1; + continue; + } +#endif +#ifdef GL_NV_vertex_program2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program2", 15)) + { + ret = GLEW_NV_vertex_program2; + continue; + } +#endif +#ifdef GL_NV_vertex_program2_option + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program2_option", 22)) + { + ret = GLEW_NV_vertex_program2_option; + continue; + } +#endif +#ifdef GL_NV_vertex_program3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program3", 15)) + { + ret = GLEW_NV_vertex_program3; + continue; + } +#endif +#ifdef GL_NV_vertex_program4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program4", 15)) + { + ret = GLEW_NV_vertex_program4; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"OES_", 4)) + { +#ifdef GL_OES_byte_coordinates + if (_glewStrSame3(&pos, &len, (const GLubyte*)"byte_coordinates", 16)) + { + ret = GLEW_OES_byte_coordinates; + continue; + } +#endif +#ifdef GL_OES_compressed_paletted_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"compressed_paletted_texture", 27)) + { + ret = GLEW_OES_compressed_paletted_texture; + continue; + } +#endif +#ifdef GL_OES_read_format + if (_glewStrSame3(&pos, &len, (const GLubyte*)"read_format", 11)) + { + ret = GLEW_OES_read_format; + continue; + } +#endif +#ifdef GL_OES_single_precision + if (_glewStrSame3(&pos, &len, (const GLubyte*)"single_precision", 16)) + { + ret = GLEW_OES_single_precision; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"OML_", 4)) + { +#ifdef GL_OML_interlace + if (_glewStrSame3(&pos, &len, (const GLubyte*)"interlace", 9)) + { + ret = GLEW_OML_interlace; + continue; + } +#endif +#ifdef GL_OML_resample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"resample", 8)) + { + ret = GLEW_OML_resample; + continue; + } +#endif +#ifdef GL_OML_subsample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"subsample", 9)) + { + ret = GLEW_OML_subsample; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"PGI_", 4)) + { +#ifdef GL_PGI_misc_hints + if (_glewStrSame3(&pos, &len, (const GLubyte*)"misc_hints", 10)) + { + ret = GLEW_PGI_misc_hints; + continue; + } +#endif +#ifdef GL_PGI_vertex_hints + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_hints", 12)) + { + ret = GLEW_PGI_vertex_hints; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"REND_", 5)) + { +#ifdef GL_REND_screen_coordinates + if (_glewStrSame3(&pos, &len, (const GLubyte*)"screen_coordinates", 18)) + { + ret = GLEW_REND_screen_coordinates; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"S3_", 3)) + { +#ifdef GL_S3_s3tc + if (_glewStrSame3(&pos, &len, (const GLubyte*)"s3tc", 4)) + { + ret = GLEW_S3_s3tc; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIS_", 5)) + { +#ifdef GL_SGIS_color_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_range", 11)) + { + ret = GLEW_SGIS_color_range; + continue; + } +#endif +#ifdef GL_SGIS_detail_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"detail_texture", 14)) + { + ret = GLEW_SGIS_detail_texture; + continue; + } +#endif +#ifdef GL_SGIS_fog_function + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_function", 12)) + { + ret = GLEW_SGIS_fog_function; + continue; + } +#endif +#ifdef GL_SGIS_generate_mipmap + if (_glewStrSame3(&pos, &len, (const GLubyte*)"generate_mipmap", 15)) + { + ret = GLEW_SGIS_generate_mipmap; + continue; + } +#endif +#ifdef GL_SGIS_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = GLEW_SGIS_multisample; + continue; + } +#endif +#ifdef GL_SGIS_pixel_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_texture", 13)) + { + ret = GLEW_SGIS_pixel_texture; + continue; + } +#endif +#ifdef GL_SGIS_point_line_texgen + if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_line_texgen", 17)) + { + ret = GLEW_SGIS_point_line_texgen; + continue; + } +#endif +#ifdef GL_SGIS_sharpen_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"sharpen_texture", 15)) + { + ret = GLEW_SGIS_sharpen_texture; + continue; + } +#endif +#ifdef GL_SGIS_texture4D + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture4D", 9)) + { + ret = GLEW_SGIS_texture4D; + continue; + } +#endif +#ifdef GL_SGIS_texture_border_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_border_clamp", 20)) + { + ret = GLEW_SGIS_texture_border_clamp; + continue; + } +#endif +#ifdef GL_SGIS_texture_edge_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_edge_clamp", 18)) + { + ret = GLEW_SGIS_texture_edge_clamp; + continue; + } +#endif +#ifdef GL_SGIS_texture_filter4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_filter4", 15)) + { + ret = GLEW_SGIS_texture_filter4; + continue; + } +#endif +#ifdef GL_SGIS_texture_lod + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lod", 11)) + { + ret = GLEW_SGIS_texture_lod; + continue; + } +#endif +#ifdef GL_SGIS_texture_select + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_select", 14)) + { + ret = GLEW_SGIS_texture_select; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIX_", 5)) + { +#ifdef GL_SGIX_async + if (_glewStrSame3(&pos, &len, (const GLubyte*)"async", 5)) + { + ret = GLEW_SGIX_async; + continue; + } +#endif +#ifdef GL_SGIX_async_histogram + if (_glewStrSame3(&pos, &len, (const GLubyte*)"async_histogram", 15)) + { + ret = GLEW_SGIX_async_histogram; + continue; + } +#endif +#ifdef GL_SGIX_async_pixel + if (_glewStrSame3(&pos, &len, (const GLubyte*)"async_pixel", 11)) + { + ret = GLEW_SGIX_async_pixel; + continue; + } +#endif +#ifdef GL_SGIX_blend_alpha_minmax + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_alpha_minmax", 18)) + { + ret = GLEW_SGIX_blend_alpha_minmax; + continue; + } +#endif +#ifdef GL_SGIX_clipmap + if (_glewStrSame3(&pos, &len, (const GLubyte*)"clipmap", 7)) + { + ret = GLEW_SGIX_clipmap; + continue; + } +#endif +#ifdef GL_SGIX_convolution_accuracy + if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution_accuracy", 20)) + { + ret = GLEW_SGIX_convolution_accuracy; + continue; + } +#endif +#ifdef GL_SGIX_depth_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_texture", 13)) + { + ret = GLEW_SGIX_depth_texture; + continue; + } +#endif +#ifdef GL_SGIX_flush_raster + if (_glewStrSame3(&pos, &len, (const GLubyte*)"flush_raster", 12)) + { + ret = GLEW_SGIX_flush_raster; + continue; + } +#endif +#ifdef GL_SGIX_fog_offset + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_offset", 10)) + { + ret = GLEW_SGIX_fog_offset; + continue; + } +#endif +#ifdef GL_SGIX_fog_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_texture", 11)) + { + ret = GLEW_SGIX_fog_texture; + continue; + } +#endif +#ifdef GL_SGIX_fragment_specular_lighting + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_specular_lighting", 26)) + { + ret = GLEW_SGIX_fragment_specular_lighting; + continue; + } +#endif +#ifdef GL_SGIX_framezoom + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framezoom", 9)) + { + ret = GLEW_SGIX_framezoom; + continue; + } +#endif +#ifdef GL_SGIX_interlace + if (_glewStrSame3(&pos, &len, (const GLubyte*)"interlace", 9)) + { + ret = GLEW_SGIX_interlace; + continue; + } +#endif +#ifdef GL_SGIX_ir_instrument1 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"ir_instrument1", 14)) + { + ret = GLEW_SGIX_ir_instrument1; + continue; + } +#endif +#ifdef GL_SGIX_list_priority + if (_glewStrSame3(&pos, &len, (const GLubyte*)"list_priority", 13)) + { + ret = GLEW_SGIX_list_priority; + continue; + } +#endif +#ifdef GL_SGIX_pixel_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_texture", 13)) + { + ret = GLEW_SGIX_pixel_texture; + continue; + } +#endif +#ifdef GL_SGIX_pixel_texture_bits + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_texture_bits", 18)) + { + ret = GLEW_SGIX_pixel_texture_bits; + continue; + } +#endif +#ifdef GL_SGIX_reference_plane + if (_glewStrSame3(&pos, &len, (const GLubyte*)"reference_plane", 15)) + { + ret = GLEW_SGIX_reference_plane; + continue; + } +#endif +#ifdef GL_SGIX_resample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"resample", 8)) + { + ret = GLEW_SGIX_resample; + continue; + } +#endif +#ifdef GL_SGIX_shadow + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow", 6)) + { + ret = GLEW_SGIX_shadow; + continue; + } +#endif +#ifdef GL_SGIX_shadow_ambient + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow_ambient", 14)) + { + ret = GLEW_SGIX_shadow_ambient; + continue; + } +#endif +#ifdef GL_SGIX_sprite + if (_glewStrSame3(&pos, &len, (const GLubyte*)"sprite", 6)) + { + ret = GLEW_SGIX_sprite; + continue; + } +#endif +#ifdef GL_SGIX_tag_sample_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"tag_sample_buffer", 17)) + { + ret = GLEW_SGIX_tag_sample_buffer; + continue; + } +#endif +#ifdef GL_SGIX_texture_add_env + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_add_env", 15)) + { + ret = GLEW_SGIX_texture_add_env; + continue; + } +#endif +#ifdef GL_SGIX_texture_coordinate_clamp + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_coordinate_clamp", 24)) + { + ret = GLEW_SGIX_texture_coordinate_clamp; + continue; + } +#endif +#ifdef GL_SGIX_texture_lod_bias + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lod_bias", 16)) + { + ret = GLEW_SGIX_texture_lod_bias; + continue; + } +#endif +#ifdef GL_SGIX_texture_multi_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_multi_buffer", 20)) + { + ret = GLEW_SGIX_texture_multi_buffer; + continue; + } +#endif +#ifdef GL_SGIX_texture_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_range", 13)) + { + ret = GLEW_SGIX_texture_range; + continue; + } +#endif +#ifdef GL_SGIX_texture_scale_bias + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_scale_bias", 18)) + { + ret = GLEW_SGIX_texture_scale_bias; + continue; + } +#endif +#ifdef GL_SGIX_vertex_preclip + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_preclip", 14)) + { + ret = GLEW_SGIX_vertex_preclip; + continue; + } +#endif +#ifdef GL_SGIX_vertex_preclip_hint + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_preclip_hint", 19)) + { + ret = GLEW_SGIX_vertex_preclip_hint; + continue; + } +#endif +#ifdef GL_SGIX_ycrcb + if (_glewStrSame3(&pos, &len, (const GLubyte*)"ycrcb", 5)) + { + ret = GLEW_SGIX_ycrcb; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGI_", 4)) + { +#ifdef GL_SGI_color_matrix + if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_matrix", 12)) + { + ret = GLEW_SGI_color_matrix; + continue; + } +#endif +#ifdef GL_SGI_color_table + if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_table", 11)) + { + ret = GLEW_SGI_color_table; + continue; + } +#endif +#ifdef GL_SGI_texture_color_table + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_color_table", 19)) + { + ret = GLEW_SGI_texture_color_table; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SUNX_", 5)) + { +#ifdef GL_SUNX_constant_data + if (_glewStrSame3(&pos, &len, (const GLubyte*)"constant_data", 13)) + { + ret = GLEW_SUNX_constant_data; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SUN_", 4)) + { +#ifdef GL_SUN_convolution_border_modes + if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution_border_modes", 24)) + { + ret = GLEW_SUN_convolution_border_modes; + continue; + } +#endif +#ifdef GL_SUN_global_alpha + if (_glewStrSame3(&pos, &len, (const GLubyte*)"global_alpha", 12)) + { + ret = GLEW_SUN_global_alpha; + continue; + } +#endif +#ifdef GL_SUN_mesh_array + if (_glewStrSame3(&pos, &len, (const GLubyte*)"mesh_array", 10)) + { + ret = GLEW_SUN_mesh_array; + continue; + } +#endif +#ifdef GL_SUN_read_video_pixels + if (_glewStrSame3(&pos, &len, (const GLubyte*)"read_video_pixels", 17)) + { + ret = GLEW_SUN_read_video_pixels; + continue; + } +#endif +#ifdef GL_SUN_slice_accum + if (_glewStrSame3(&pos, &len, (const GLubyte*)"slice_accum", 11)) + { + ret = GLEW_SUN_slice_accum; + continue; + } +#endif +#ifdef GL_SUN_triangle_list + if (_glewStrSame3(&pos, &len, (const GLubyte*)"triangle_list", 13)) + { + ret = GLEW_SUN_triangle_list; + continue; + } +#endif +#ifdef GL_SUN_vertex + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex", 6)) + { + ret = GLEW_SUN_vertex; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"WIN_", 4)) + { +#ifdef GL_WIN_phong_shading + if (_glewStrSame3(&pos, &len, (const GLubyte*)"phong_shading", 13)) + { + ret = GLEW_WIN_phong_shading; + continue; + } +#endif +#ifdef GL_WIN_specular_fog + if (_glewStrSame3(&pos, &len, (const GLubyte*)"specular_fog", 12)) + { + ret = GLEW_WIN_specular_fog; + continue; + } +#endif +#ifdef GL_WIN_swap_hint + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_hint", 9)) + { + ret = GLEW_WIN_swap_hint; + continue; + } +#endif + } + } + ret = (len == 0); + } + return ret; +} + +#if defined(_WIN32) + +#if defined(GLEW_MX) +GLboolean wglewContextIsSupported (WGLEWContext* ctx, const char* name) +#else +GLboolean wglewIsSupported (const char* name) +#endif +{ + GLubyte* pos = (GLubyte*)name; + GLuint len = _glewStrLen(pos); + GLboolean ret = GL_TRUE; + while (ret && len > 0) + { + if (_glewStrSame1(&pos, &len, (const GLubyte*)"WGL_", 4)) + { + if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DFX_", 5)) + { +#ifdef WGL_3DFX_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = WGLEW_3DFX_multisample; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DL_", 4)) + { +#ifdef WGL_3DL_stereo_control + if (_glewStrSame3(&pos, &len, (const GLubyte*)"stereo_control", 14)) + { + ret = WGLEW_3DL_stereo_control; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"AMD_", 4)) + { +#ifdef WGL_AMD_gpu_association + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_association", 15)) + { + ret = WGLEW_AMD_gpu_association; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"ARB_", 4)) + { +#ifdef WGL_ARB_buffer_region + if (_glewStrSame3(&pos, &len, (const GLubyte*)"buffer_region", 13)) + { + ret = WGLEW_ARB_buffer_region; + continue; + } +#endif +#ifdef WGL_ARB_create_context + if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context", 14)) + { + ret = WGLEW_ARB_create_context; + continue; + } +#endif +#ifdef WGL_ARB_create_context_profile + if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_profile", 22)) + { + ret = WGLEW_ARB_create_context_profile; + continue; + } +#endif +#ifdef WGL_ARB_extensions_string + if (_glewStrSame3(&pos, &len, (const GLubyte*)"extensions_string", 17)) + { + ret = WGLEW_ARB_extensions_string; + continue; + } +#endif +#ifdef WGL_ARB_framebuffer_sRGB + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) + { + ret = WGLEW_ARB_framebuffer_sRGB; + continue; + } +#endif +#ifdef WGL_ARB_make_current_read + if (_glewStrSame3(&pos, &len, (const GLubyte*)"make_current_read", 17)) + { + ret = WGLEW_ARB_make_current_read; + continue; + } +#endif +#ifdef WGL_ARB_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = WGLEW_ARB_multisample; + continue; + } +#endif +#ifdef WGL_ARB_pbuffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pbuffer", 7)) + { + ret = WGLEW_ARB_pbuffer; + continue; + } +#endif +#ifdef WGL_ARB_pixel_format + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format", 12)) + { + ret = WGLEW_ARB_pixel_format; + continue; + } +#endif +#ifdef WGL_ARB_pixel_format_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_float", 18)) + { + ret = WGLEW_ARB_pixel_format_float; + continue; + } +#endif +#ifdef WGL_ARB_render_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture", 14)) + { + ret = WGLEW_ARB_render_texture; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATI_", 4)) + { +#ifdef WGL_ATI_pixel_format_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_float", 18)) + { + ret = WGLEW_ATI_pixel_format_float; + continue; + } +#endif +#ifdef WGL_ATI_render_texture_rectangle + if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture_rectangle", 24)) + { + ret = WGLEW_ATI_render_texture_rectangle; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"EXT_", 4)) + { +#ifdef WGL_EXT_depth_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_float", 11)) + { + ret = WGLEW_EXT_depth_float; + continue; + } +#endif +#ifdef WGL_EXT_display_color_table + if (_glewStrSame3(&pos, &len, (const GLubyte*)"display_color_table", 19)) + { + ret = WGLEW_EXT_display_color_table; + continue; + } +#endif +#ifdef WGL_EXT_extensions_string + if (_glewStrSame3(&pos, &len, (const GLubyte*)"extensions_string", 17)) + { + ret = WGLEW_EXT_extensions_string; + continue; + } +#endif +#ifdef WGL_EXT_framebuffer_sRGB + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) + { + ret = WGLEW_EXT_framebuffer_sRGB; + continue; + } +#endif +#ifdef WGL_EXT_make_current_read + if (_glewStrSame3(&pos, &len, (const GLubyte*)"make_current_read", 17)) + { + ret = WGLEW_EXT_make_current_read; + continue; + } +#endif +#ifdef WGL_EXT_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = WGLEW_EXT_multisample; + continue; + } +#endif +#ifdef WGL_EXT_pbuffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pbuffer", 7)) + { + ret = WGLEW_EXT_pbuffer; + continue; + } +#endif +#ifdef WGL_EXT_pixel_format + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format", 12)) + { + ret = WGLEW_EXT_pixel_format; + continue; + } +#endif +#ifdef WGL_EXT_pixel_format_packed_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_packed_float", 25)) + { + ret = WGLEW_EXT_pixel_format_packed_float; + continue; + } +#endif +#ifdef WGL_EXT_swap_control + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control", 12)) + { + ret = WGLEW_EXT_swap_control; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"I3D_", 4)) + { +#ifdef WGL_I3D_digital_video_control + if (_glewStrSame3(&pos, &len, (const GLubyte*)"digital_video_control", 21)) + { + ret = WGLEW_I3D_digital_video_control; + continue; + } +#endif +#ifdef WGL_I3D_gamma + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gamma", 5)) + { + ret = WGLEW_I3D_gamma; + continue; + } +#endif +#ifdef WGL_I3D_genlock + if (_glewStrSame3(&pos, &len, (const GLubyte*)"genlock", 7)) + { + ret = WGLEW_I3D_genlock; + continue; + } +#endif +#ifdef WGL_I3D_image_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"image_buffer", 12)) + { + ret = WGLEW_I3D_image_buffer; + continue; + } +#endif +#ifdef WGL_I3D_swap_frame_lock + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_frame_lock", 15)) + { + ret = WGLEW_I3D_swap_frame_lock; + continue; + } +#endif +#ifdef WGL_I3D_swap_frame_usage + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_frame_usage", 16)) + { + ret = WGLEW_I3D_swap_frame_usage; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"NV_", 3)) + { +#ifdef WGL_NV_copy_image + if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_image", 10)) + { + ret = WGLEW_NV_copy_image; + continue; + } +#endif +#ifdef WGL_NV_float_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_buffer", 12)) + { + ret = WGLEW_NV_float_buffer; + continue; + } +#endif +#ifdef WGL_NV_gpu_affinity + if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_affinity", 12)) + { + ret = WGLEW_NV_gpu_affinity; + continue; + } +#endif +#ifdef WGL_NV_present_video + if (_glewStrSame3(&pos, &len, (const GLubyte*)"present_video", 13)) + { + ret = WGLEW_NV_present_video; + continue; + } +#endif +#ifdef WGL_NV_render_depth_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_depth_texture", 20)) + { + ret = WGLEW_NV_render_depth_texture; + continue; + } +#endif +#ifdef WGL_NV_render_texture_rectangle + if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture_rectangle", 24)) + { + ret = WGLEW_NV_render_texture_rectangle; + continue; + } +#endif +#ifdef WGL_NV_swap_group + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_group", 10)) + { + ret = WGLEW_NV_swap_group; + continue; + } +#endif +#ifdef WGL_NV_vertex_array_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) + { + ret = WGLEW_NV_vertex_array_range; + continue; + } +#endif +#ifdef WGL_NV_video_output + if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_output", 12)) + { + ret = WGLEW_NV_video_output; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"OML_", 4)) + { +#ifdef WGL_OML_sync_control + if (_glewStrSame3(&pos, &len, (const GLubyte*)"sync_control", 12)) + { + ret = WGLEW_OML_sync_control; + continue; + } +#endif + } + } + ret = (len == 0); + } + return ret; +} + +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + +#if defined(GLEW_MX) +GLboolean glxewContextIsSupported (GLXEWContext* ctx, const char* name) +#else +GLboolean glxewIsSupported (const char* name) +#endif +{ + GLubyte* pos = (GLubyte*)name; + GLuint len = _glewStrLen(pos); + GLboolean ret = GL_TRUE; + while (ret && len > 0) + { + if(_glewStrSame1(&pos, &len, (const GLubyte*)"GLX_", 4)) + { + if (_glewStrSame2(&pos, &len, (const GLubyte*)"VERSION_", 8)) + { +#ifdef GLX_VERSION_1_2 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_2", 3)) + { + ret = GLXEW_VERSION_1_2; + continue; + } +#endif +#ifdef GLX_VERSION_1_3 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_3", 3)) + { + ret = GLXEW_VERSION_1_3; + continue; + } +#endif +#ifdef GLX_VERSION_1_4 + if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_4", 3)) + { + ret = GLXEW_VERSION_1_4; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DFX_", 5)) + { +#ifdef GLX_3DFX_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = GLXEW_3DFX_multisample; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"ARB_", 4)) + { +#ifdef GLX_ARB_create_context + if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context", 14)) + { + ret = GLXEW_ARB_create_context; + continue; + } +#endif +#ifdef GLX_ARB_create_context_profile + if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_profile", 22)) + { + ret = GLXEW_ARB_create_context_profile; + continue; + } +#endif +#ifdef GLX_ARB_fbconfig_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fbconfig_float", 14)) + { + ret = GLXEW_ARB_fbconfig_float; + continue; + } +#endif +#ifdef GLX_ARB_framebuffer_sRGB + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) + { + ret = GLXEW_ARB_framebuffer_sRGB; + continue; + } +#endif +#ifdef GLX_ARB_get_proc_address + if (_glewStrSame3(&pos, &len, (const GLubyte*)"get_proc_address", 16)) + { + ret = GLXEW_ARB_get_proc_address; + continue; + } +#endif +#ifdef GLX_ARB_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = GLXEW_ARB_multisample; + continue; + } +#endif +#ifdef GLX_ARB_vertex_buffer_object + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_buffer_object", 20)) + { + ret = GLXEW_ARB_vertex_buffer_object; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATI_", 4)) + { +#ifdef GLX_ATI_pixel_format_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_float", 18)) + { + ret = GLXEW_ATI_pixel_format_float; + continue; + } +#endif +#ifdef GLX_ATI_render_texture + if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture", 14)) + { + ret = GLXEW_ATI_render_texture; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"EXT_", 4)) + { +#ifdef GLX_EXT_fbconfig_packed_float + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fbconfig_packed_float", 21)) + { + ret = GLXEW_EXT_fbconfig_packed_float; + continue; + } +#endif +#ifdef GLX_EXT_framebuffer_sRGB + if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) + { + ret = GLXEW_EXT_framebuffer_sRGB; + continue; + } +#endif +#ifdef GLX_EXT_import_context + if (_glewStrSame3(&pos, &len, (const GLubyte*)"import_context", 14)) + { + ret = GLXEW_EXT_import_context; + continue; + } +#endif +#ifdef GLX_EXT_scene_marker + if (_glewStrSame3(&pos, &len, (const GLubyte*)"scene_marker", 12)) + { + ret = GLXEW_EXT_scene_marker; + continue; + } +#endif +#ifdef GLX_EXT_swap_control + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control", 12)) + { + ret = GLXEW_EXT_swap_control; + continue; + } +#endif +#ifdef GLX_EXT_texture_from_pixmap + if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_from_pixmap", 19)) + { + ret = GLXEW_EXT_texture_from_pixmap; + continue; + } +#endif +#ifdef GLX_EXT_visual_info + if (_glewStrSame3(&pos, &len, (const GLubyte*)"visual_info", 11)) + { + ret = GLXEW_EXT_visual_info; + continue; + } +#endif +#ifdef GLX_EXT_visual_rating + if (_glewStrSame3(&pos, &len, (const GLubyte*)"visual_rating", 13)) + { + ret = GLXEW_EXT_visual_rating; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"INTEL_", 6)) + { +#ifdef GLX_INTEL_swap_event + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_event", 10)) + { + ret = GLXEW_INTEL_swap_event; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"MESA_", 5)) + { +#ifdef GLX_MESA_agp_offset + if (_glewStrSame3(&pos, &len, (const GLubyte*)"agp_offset", 10)) + { + ret = GLXEW_MESA_agp_offset; + continue; + } +#endif +#ifdef GLX_MESA_copy_sub_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_sub_buffer", 15)) + { + ret = GLXEW_MESA_copy_sub_buffer; + continue; + } +#endif +#ifdef GLX_MESA_pixmap_colormap + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixmap_colormap", 15)) + { + ret = GLXEW_MESA_pixmap_colormap; + continue; + } +#endif +#ifdef GLX_MESA_release_buffers + if (_glewStrSame3(&pos, &len, (const GLubyte*)"release_buffers", 15)) + { + ret = GLXEW_MESA_release_buffers; + continue; + } +#endif +#ifdef GLX_MESA_set_3dfx_mode + if (_glewStrSame3(&pos, &len, (const GLubyte*)"set_3dfx_mode", 13)) + { + ret = GLXEW_MESA_set_3dfx_mode; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"NV_", 3)) + { +#ifdef GLX_NV_copy_image + if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_image", 10)) + { + ret = GLXEW_NV_copy_image; + continue; + } +#endif +#ifdef GLX_NV_float_buffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_buffer", 12)) + { + ret = GLXEW_NV_float_buffer; + continue; + } +#endif +#ifdef GLX_NV_present_video + if (_glewStrSame3(&pos, &len, (const GLubyte*)"present_video", 13)) + { + ret = GLXEW_NV_present_video; + continue; + } +#endif +#ifdef GLX_NV_swap_group + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_group", 10)) + { + ret = GLXEW_NV_swap_group; + continue; + } +#endif +#ifdef GLX_NV_vertex_array_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) + { + ret = GLXEW_NV_vertex_array_range; + continue; + } +#endif +#ifdef GLX_NV_video_output + if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_output", 12)) + { + ret = GLXEW_NV_video_output; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"OML_", 4)) + { +#ifdef GLX_OML_swap_method + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_method", 11)) + { + ret = GLXEW_OML_swap_method; + continue; + } +#endif +#if defined(GLX_OML_sync_control) && defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) +#include + if (_glewStrSame3(&pos, &len, (const GLubyte*)"sync_control", 12)) + { + ret = GLXEW_OML_sync_control; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIS_", 5)) + { +#ifdef GLX_SGIS_blended_overlay + if (_glewStrSame3(&pos, &len, (const GLubyte*)"blended_overlay", 15)) + { + ret = GLXEW_SGIS_blended_overlay; + continue; + } +#endif +#ifdef GLX_SGIS_color_range + if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_range", 11)) + { + ret = GLXEW_SGIS_color_range; + continue; + } +#endif +#ifdef GLX_SGIS_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) + { + ret = GLXEW_SGIS_multisample; + continue; + } +#endif +#ifdef GLX_SGIS_shared_multisample + if (_glewStrSame3(&pos, &len, (const GLubyte*)"shared_multisample", 18)) + { + ret = GLXEW_SGIS_shared_multisample; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIX_", 5)) + { +#ifdef GLX_SGIX_fbconfig + if (_glewStrSame3(&pos, &len, (const GLubyte*)"fbconfig", 8)) + { + ret = GLXEW_SGIX_fbconfig; + continue; + } +#endif +#ifdef GLX_SGIX_hyperpipe + if (_glewStrSame3(&pos, &len, (const GLubyte*)"hyperpipe", 9)) + { + ret = GLXEW_SGIX_hyperpipe; + continue; + } +#endif +#ifdef GLX_SGIX_pbuffer + if (_glewStrSame3(&pos, &len, (const GLubyte*)"pbuffer", 7)) + { + ret = GLXEW_SGIX_pbuffer; + continue; + } +#endif +#ifdef GLX_SGIX_swap_barrier + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_barrier", 12)) + { + ret = GLXEW_SGIX_swap_barrier; + continue; + } +#endif +#ifdef GLX_SGIX_swap_group + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_group", 10)) + { + ret = GLXEW_SGIX_swap_group; + continue; + } +#endif +#ifdef GLX_SGIX_video_resize + if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_resize", 12)) + { + ret = GLXEW_SGIX_video_resize; + continue; + } +#endif +#ifdef GLX_SGIX_visual_select_group + if (_glewStrSame3(&pos, &len, (const GLubyte*)"visual_select_group", 19)) + { + ret = GLXEW_SGIX_visual_select_group; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGI_", 4)) + { +#ifdef GLX_SGI_cushion + if (_glewStrSame3(&pos, &len, (const GLubyte*)"cushion", 7)) + { + ret = GLXEW_SGI_cushion; + continue; + } +#endif +#ifdef GLX_SGI_make_current_read + if (_glewStrSame3(&pos, &len, (const GLubyte*)"make_current_read", 17)) + { + ret = GLXEW_SGI_make_current_read; + continue; + } +#endif +#ifdef GLX_SGI_swap_control + if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control", 12)) + { + ret = GLXEW_SGI_swap_control; + continue; + } +#endif +#ifdef GLX_SGI_video_sync + if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_sync", 10)) + { + ret = GLXEW_SGI_video_sync; + continue; + } +#endif + } + if (_glewStrSame2(&pos, &len, (const GLubyte*)"SUN_", 4)) + { +#ifdef GLX_SUN_get_transparent_index + if (_glewStrSame3(&pos, &len, (const GLubyte*)"get_transparent_index", 21)) + { + ret = GLXEW_SUN_get_transparent_index; + continue; + } +#endif +#ifdef GLX_SUN_video_resize + if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_resize", 12)) + { + ret = GLXEW_SUN_video_resize; + continue; + } +#endif + } + } + ret = (len == 0); + } + return ret; +} + +#endif /* _WIN32 */ diff --git a/Externals/GLew/src/glewinfo.c b/Externals/GLew/src/glewinfo.c new file mode 100644 index 0000000000..abfe1fa299 --- /dev/null +++ b/Externals/GLew/src/glewinfo.c @@ -0,0 +1,8441 @@ +/* +** The OpenGL Extension Wrangler Library +** Copyright (C) 2002-2008, Milan Ikits +** Copyright (C) 2002-2008, Marcelo E. Magallon +** Copyright (C) 2002, Lev Povalahev +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are met: +** +** * Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** * The name of the author may be used to endorse or promote products +** derived from this software without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +** THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#include +#include +#include +#include +#if defined(_WIN32) +#include +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +#include +#endif + +static FILE* f; + +#ifdef GLEW_MX +GLEWContext _glewctx; +#define glewGetContext() (&_glewctx) +#ifdef _WIN32 +WGLEWContext _wglewctx; +#define wglewGetContext() (&_wglewctx) +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLXEWContext _glxewctx; +#define glxewGetContext() (&_glxewctx) +#endif +#endif + +#if defined(_WIN32) +GLboolean glewCreateContext (int* pixelformat); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLboolean glewCreateContext (const char* display, int* visual); +#else +GLboolean glewCreateContext (); +#endif + +#if defined(_WIN32) || !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLboolean glewParseArgs (int argc, char** argv, char** display, int* visual); +#endif + +void glewDestroyContext (); + +/* ------------------------------------------------------------------------- */ + +static void glewPrintExt (const char* name, GLboolean def1, GLboolean def2, GLboolean def3) +{ + unsigned int i; + fprintf(f, "\n%s:", name); + for (i=0; i<62-strlen(name); i++) fprintf(f, " "); + fprintf(f, "%s ", def1 ? "OK" : "MISSING"); + if (def1 != def2) + fprintf(f, "[%s] ", def2 ? "OK" : "MISSING"); + if (def1 != def3) + fprintf(f, "[%s]\n", def3 ? "OK" : "MISSING"); + else + fprintf(f, "\n"); + for (i=0; i= 199901L) +#include + +static void _glewInfo_GLX_OML_sync_control (void) +{ + glewPrintExt("GLX_OML_sync_control", GLXEW_OML_sync_control, glxewIsSupported("GLX_OML_sync_control"), glxewGetExtension("GLX_OML_sync_control")); + + glewInfoFunc("glXGetMscRateOML", glXGetMscRateOML == NULL); + glewInfoFunc("glXGetSyncValuesOML", glXGetSyncValuesOML == NULL); + glewInfoFunc("glXSwapBuffersMscOML", glXSwapBuffersMscOML == NULL); + glewInfoFunc("glXWaitForMscOML", glXWaitForMscOML == NULL); + glewInfoFunc("glXWaitForSbcOML", glXWaitForSbcOML == NULL); +} + +#endif /* GLX_OML_sync_control */ + +#ifdef GLX_SGIS_blended_overlay + +static void _glewInfo_GLX_SGIS_blended_overlay (void) +{ + glewPrintExt("GLX_SGIS_blended_overlay", GLXEW_SGIS_blended_overlay, glxewIsSupported("GLX_SGIS_blended_overlay"), glxewGetExtension("GLX_SGIS_blended_overlay")); +} + +#endif /* GLX_SGIS_blended_overlay */ + +#ifdef GLX_SGIS_color_range + +static void _glewInfo_GLX_SGIS_color_range (void) +{ + glewPrintExt("GLX_SGIS_color_range", GLXEW_SGIS_color_range, glxewIsSupported("GLX_SGIS_color_range"), glxewGetExtension("GLX_SGIS_color_range")); +} + +#endif /* GLX_SGIS_color_range */ + +#ifdef GLX_SGIS_multisample + +static void _glewInfo_GLX_SGIS_multisample (void) +{ + glewPrintExt("GLX_SGIS_multisample", GLXEW_SGIS_multisample, glxewIsSupported("GLX_SGIS_multisample"), glxewGetExtension("GLX_SGIS_multisample")); +} + +#endif /* GLX_SGIS_multisample */ + +#ifdef GLX_SGIS_shared_multisample + +static void _glewInfo_GLX_SGIS_shared_multisample (void) +{ + glewPrintExt("GLX_SGIS_shared_multisample", GLXEW_SGIS_shared_multisample, glxewIsSupported("GLX_SGIS_shared_multisample"), glxewGetExtension("GLX_SGIS_shared_multisample")); +} + +#endif /* GLX_SGIS_shared_multisample */ + +#ifdef GLX_SGIX_fbconfig + +static void _glewInfo_GLX_SGIX_fbconfig (void) +{ + glewPrintExt("GLX_SGIX_fbconfig", GLXEW_SGIX_fbconfig, glxewIsSupported("GLX_SGIX_fbconfig"), glxewGetExtension("GLX_SGIX_fbconfig")); + + glewInfoFunc("glXChooseFBConfigSGIX", glXChooseFBConfigSGIX == NULL); + glewInfoFunc("glXCreateContextWithConfigSGIX", glXCreateContextWithConfigSGIX == NULL); + glewInfoFunc("glXCreateGLXPixmapWithConfigSGIX", glXCreateGLXPixmapWithConfigSGIX == NULL); + glewInfoFunc("glXGetFBConfigAttribSGIX", glXGetFBConfigAttribSGIX == NULL); + glewInfoFunc("glXGetFBConfigFromVisualSGIX", glXGetFBConfigFromVisualSGIX == NULL); + glewInfoFunc("glXGetVisualFromFBConfigSGIX", glXGetVisualFromFBConfigSGIX == NULL); +} + +#endif /* GLX_SGIX_fbconfig */ + +#ifdef GLX_SGIX_hyperpipe + +static void _glewInfo_GLX_SGIX_hyperpipe (void) +{ + glewPrintExt("GLX_SGIX_hyperpipe", GLXEW_SGIX_hyperpipe, glxewIsSupported("GLX_SGIX_hyperpipe"), glxewGetExtension("GLX_SGIX_hyperpipe")); + + glewInfoFunc("glXBindHyperpipeSGIX", glXBindHyperpipeSGIX == NULL); + glewInfoFunc("glXDestroyHyperpipeConfigSGIX", glXDestroyHyperpipeConfigSGIX == NULL); + glewInfoFunc("glXHyperpipeAttribSGIX", glXHyperpipeAttribSGIX == NULL); + glewInfoFunc("glXHyperpipeConfigSGIX", glXHyperpipeConfigSGIX == NULL); + glewInfoFunc("glXQueryHyperpipeAttribSGIX", glXQueryHyperpipeAttribSGIX == NULL); + glewInfoFunc("glXQueryHyperpipeBestAttribSGIX", glXQueryHyperpipeBestAttribSGIX == NULL); + glewInfoFunc("glXQueryHyperpipeConfigSGIX", glXQueryHyperpipeConfigSGIX == NULL); + glewInfoFunc("glXQueryHyperpipeNetworkSGIX", glXQueryHyperpipeNetworkSGIX == NULL); +} + +#endif /* GLX_SGIX_hyperpipe */ + +#ifdef GLX_SGIX_pbuffer + +static void _glewInfo_GLX_SGIX_pbuffer (void) +{ + glewPrintExt("GLX_SGIX_pbuffer", GLXEW_SGIX_pbuffer, glxewIsSupported("GLX_SGIX_pbuffer"), glxewGetExtension("GLX_SGIX_pbuffer")); + + glewInfoFunc("glXCreateGLXPbufferSGIX", glXCreateGLXPbufferSGIX == NULL); + glewInfoFunc("glXDestroyGLXPbufferSGIX", glXDestroyGLXPbufferSGIX == NULL); + glewInfoFunc("glXGetSelectedEventSGIX", glXGetSelectedEventSGIX == NULL); + glewInfoFunc("glXQueryGLXPbufferSGIX", glXQueryGLXPbufferSGIX == NULL); + glewInfoFunc("glXSelectEventSGIX", glXSelectEventSGIX == NULL); +} + +#endif /* GLX_SGIX_pbuffer */ + +#ifdef GLX_SGIX_swap_barrier + +static void _glewInfo_GLX_SGIX_swap_barrier (void) +{ + glewPrintExt("GLX_SGIX_swap_barrier", GLXEW_SGIX_swap_barrier, glxewIsSupported("GLX_SGIX_swap_barrier"), glxewGetExtension("GLX_SGIX_swap_barrier")); + + glewInfoFunc("glXBindSwapBarrierSGIX", glXBindSwapBarrierSGIX == NULL); + glewInfoFunc("glXQueryMaxSwapBarriersSGIX", glXQueryMaxSwapBarriersSGIX == NULL); +} + +#endif /* GLX_SGIX_swap_barrier */ + +#ifdef GLX_SGIX_swap_group + +static void _glewInfo_GLX_SGIX_swap_group (void) +{ + glewPrintExt("GLX_SGIX_swap_group", GLXEW_SGIX_swap_group, glxewIsSupported("GLX_SGIX_swap_group"), glxewGetExtension("GLX_SGIX_swap_group")); + + glewInfoFunc("glXJoinSwapGroupSGIX", glXJoinSwapGroupSGIX == NULL); +} + +#endif /* GLX_SGIX_swap_group */ + +#ifdef GLX_SGIX_video_resize + +static void _glewInfo_GLX_SGIX_video_resize (void) +{ + glewPrintExt("GLX_SGIX_video_resize", GLXEW_SGIX_video_resize, glxewIsSupported("GLX_SGIX_video_resize"), glxewGetExtension("GLX_SGIX_video_resize")); + + glewInfoFunc("glXBindChannelToWindowSGIX", glXBindChannelToWindowSGIX == NULL); + glewInfoFunc("glXChannelRectSGIX", glXChannelRectSGIX == NULL); + glewInfoFunc("glXChannelRectSyncSGIX", glXChannelRectSyncSGIX == NULL); + glewInfoFunc("glXQueryChannelDeltasSGIX", glXQueryChannelDeltasSGIX == NULL); + glewInfoFunc("glXQueryChannelRectSGIX", glXQueryChannelRectSGIX == NULL); +} + +#endif /* GLX_SGIX_video_resize */ + +#ifdef GLX_SGIX_visual_select_group + +static void _glewInfo_GLX_SGIX_visual_select_group (void) +{ + glewPrintExt("GLX_SGIX_visual_select_group", GLXEW_SGIX_visual_select_group, glxewIsSupported("GLX_SGIX_visual_select_group"), glxewGetExtension("GLX_SGIX_visual_select_group")); +} + +#endif /* GLX_SGIX_visual_select_group */ + +#ifdef GLX_SGI_cushion + +static void _glewInfo_GLX_SGI_cushion (void) +{ + glewPrintExt("GLX_SGI_cushion", GLXEW_SGI_cushion, glxewIsSupported("GLX_SGI_cushion"), glxewGetExtension("GLX_SGI_cushion")); + + glewInfoFunc("glXCushionSGI", glXCushionSGI == NULL); +} + +#endif /* GLX_SGI_cushion */ + +#ifdef GLX_SGI_make_current_read + +static void _glewInfo_GLX_SGI_make_current_read (void) +{ + glewPrintExt("GLX_SGI_make_current_read", GLXEW_SGI_make_current_read, glxewIsSupported("GLX_SGI_make_current_read"), glxewGetExtension("GLX_SGI_make_current_read")); + + glewInfoFunc("glXGetCurrentReadDrawableSGI", glXGetCurrentReadDrawableSGI == NULL); + glewInfoFunc("glXMakeCurrentReadSGI", glXMakeCurrentReadSGI == NULL); +} + +#endif /* GLX_SGI_make_current_read */ + +#ifdef GLX_SGI_swap_control + +static void _glewInfo_GLX_SGI_swap_control (void) +{ + glewPrintExt("GLX_SGI_swap_control", GLXEW_SGI_swap_control, glxewIsSupported("GLX_SGI_swap_control"), glxewGetExtension("GLX_SGI_swap_control")); + + glewInfoFunc("glXSwapIntervalSGI", glXSwapIntervalSGI == NULL); +} + +#endif /* GLX_SGI_swap_control */ + +#ifdef GLX_SGI_video_sync + +static void _glewInfo_GLX_SGI_video_sync (void) +{ + glewPrintExt("GLX_SGI_video_sync", GLXEW_SGI_video_sync, glxewIsSupported("GLX_SGI_video_sync"), glxewGetExtension("GLX_SGI_video_sync")); + + glewInfoFunc("glXGetVideoSyncSGI", glXGetVideoSyncSGI == NULL); + glewInfoFunc("glXWaitVideoSyncSGI", glXWaitVideoSyncSGI == NULL); +} + +#endif /* GLX_SGI_video_sync */ + +#ifdef GLX_SUN_get_transparent_index + +static void _glewInfo_GLX_SUN_get_transparent_index (void) +{ + glewPrintExt("GLX_SUN_get_transparent_index", GLXEW_SUN_get_transparent_index, glxewIsSupported("GLX_SUN_get_transparent_index"), glxewGetExtension("GLX_SUN_get_transparent_index")); + + glewInfoFunc("glXGetTransparentIndexSUN", glXGetTransparentIndexSUN == NULL); +} + +#endif /* GLX_SUN_get_transparent_index */ + +#ifdef GLX_SUN_video_resize + +static void _glewInfo_GLX_SUN_video_resize (void) +{ + glewPrintExt("GLX_SUN_video_resize", GLXEW_SUN_video_resize, glxewIsSupported("GLX_SUN_video_resize"), glxewGetExtension("GLX_SUN_video_resize")); + + glewInfoFunc("glXGetVideoResizeSUN", glXGetVideoResizeSUN == NULL); + glewInfoFunc("glXVideoResizeSUN", glXVideoResizeSUN == NULL); +} + +#endif /* GLX_SUN_video_resize */ + +#endif /* _WIN32 */ + +/* ------------------------------------------------------------------------ */ + +static void glewInfo (void) +{ +#ifdef GL_VERSION_1_1 + _glewInfo_GL_VERSION_1_1(); +#endif /* GL_VERSION_1_1 */ +#ifdef GL_VERSION_1_2 + _glewInfo_GL_VERSION_1_2(); +#endif /* GL_VERSION_1_2 */ +#ifdef GL_VERSION_1_3 + _glewInfo_GL_VERSION_1_3(); +#endif /* GL_VERSION_1_3 */ +#ifdef GL_VERSION_1_4 + _glewInfo_GL_VERSION_1_4(); +#endif /* GL_VERSION_1_4 */ +#ifdef GL_VERSION_1_5 + _glewInfo_GL_VERSION_1_5(); +#endif /* GL_VERSION_1_5 */ +#ifdef GL_VERSION_2_0 + _glewInfo_GL_VERSION_2_0(); +#endif /* GL_VERSION_2_0 */ +#ifdef GL_VERSION_2_1 + _glewInfo_GL_VERSION_2_1(); +#endif /* GL_VERSION_2_1 */ +#ifdef GL_VERSION_3_0 + _glewInfo_GL_VERSION_3_0(); +#endif /* GL_VERSION_3_0 */ +#ifdef GL_VERSION_3_1 + _glewInfo_GL_VERSION_3_1(); +#endif /* GL_VERSION_3_1 */ +#ifdef GL_VERSION_3_2 + _glewInfo_GL_VERSION_3_2(); +#endif /* GL_VERSION_3_2 */ +#ifdef GL_VERSION_3_3 + _glewInfo_GL_VERSION_3_3(); +#endif /* GL_VERSION_3_3 */ +#ifdef GL_VERSION_4_0 + _glewInfo_GL_VERSION_4_0(); +#endif /* GL_VERSION_4_0 */ +#ifdef GL_3DFX_multisample + _glewInfo_GL_3DFX_multisample(); +#endif /* GL_3DFX_multisample */ +#ifdef GL_3DFX_tbuffer + _glewInfo_GL_3DFX_tbuffer(); +#endif /* GL_3DFX_tbuffer */ +#ifdef GL_3DFX_texture_compression_FXT1 + _glewInfo_GL_3DFX_texture_compression_FXT1(); +#endif /* GL_3DFX_texture_compression_FXT1 */ +#ifdef GL_AMD_conservative_depth + _glewInfo_GL_AMD_conservative_depth(); +#endif /* GL_AMD_conservative_depth */ +#ifdef GL_AMD_draw_buffers_blend + _glewInfo_GL_AMD_draw_buffers_blend(); +#endif /* GL_AMD_draw_buffers_blend */ +#ifdef GL_AMD_performance_monitor + _glewInfo_GL_AMD_performance_monitor(); +#endif /* GL_AMD_performance_monitor */ +#ifdef GL_AMD_seamless_cubemap_per_texture + _glewInfo_GL_AMD_seamless_cubemap_per_texture(); +#endif /* GL_AMD_seamless_cubemap_per_texture */ +#ifdef GL_AMD_shader_stencil_export + _glewInfo_GL_AMD_shader_stencil_export(); +#endif /* GL_AMD_shader_stencil_export */ +#ifdef GL_AMD_texture_texture4 + _glewInfo_GL_AMD_texture_texture4(); +#endif /* GL_AMD_texture_texture4 */ +#ifdef GL_AMD_vertex_shader_tessellator + _glewInfo_GL_AMD_vertex_shader_tessellator(); +#endif /* GL_AMD_vertex_shader_tessellator */ +#ifdef GL_APPLE_aux_depth_stencil + _glewInfo_GL_APPLE_aux_depth_stencil(); +#endif /* GL_APPLE_aux_depth_stencil */ +#ifdef GL_APPLE_client_storage + _glewInfo_GL_APPLE_client_storage(); +#endif /* GL_APPLE_client_storage */ +#ifdef GL_APPLE_element_array + _glewInfo_GL_APPLE_element_array(); +#endif /* GL_APPLE_element_array */ +#ifdef GL_APPLE_fence + _glewInfo_GL_APPLE_fence(); +#endif /* GL_APPLE_fence */ +#ifdef GL_APPLE_float_pixels + _glewInfo_GL_APPLE_float_pixels(); +#endif /* GL_APPLE_float_pixels */ +#ifdef GL_APPLE_flush_buffer_range + _glewInfo_GL_APPLE_flush_buffer_range(); +#endif /* GL_APPLE_flush_buffer_range */ +#ifdef GL_APPLE_object_purgeable + _glewInfo_GL_APPLE_object_purgeable(); +#endif /* GL_APPLE_object_purgeable */ +#ifdef GL_APPLE_pixel_buffer + _glewInfo_GL_APPLE_pixel_buffer(); +#endif /* GL_APPLE_pixel_buffer */ +#ifdef GL_APPLE_rgb_422 + _glewInfo_GL_APPLE_rgb_422(); +#endif /* GL_APPLE_rgb_422 */ +#ifdef GL_APPLE_row_bytes + _glewInfo_GL_APPLE_row_bytes(); +#endif /* GL_APPLE_row_bytes */ +#ifdef GL_APPLE_specular_vector + _glewInfo_GL_APPLE_specular_vector(); +#endif /* GL_APPLE_specular_vector */ +#ifdef GL_APPLE_texture_range + _glewInfo_GL_APPLE_texture_range(); +#endif /* GL_APPLE_texture_range */ +#ifdef GL_APPLE_transform_hint + _glewInfo_GL_APPLE_transform_hint(); +#endif /* GL_APPLE_transform_hint */ +#ifdef GL_APPLE_vertex_array_object + _glewInfo_GL_APPLE_vertex_array_object(); +#endif /* GL_APPLE_vertex_array_object */ +#ifdef GL_APPLE_vertex_array_range + _glewInfo_GL_APPLE_vertex_array_range(); +#endif /* GL_APPLE_vertex_array_range */ +#ifdef GL_APPLE_vertex_program_evaluators + _glewInfo_GL_APPLE_vertex_program_evaluators(); +#endif /* GL_APPLE_vertex_program_evaluators */ +#ifdef GL_APPLE_ycbcr_422 + _glewInfo_GL_APPLE_ycbcr_422(); +#endif /* GL_APPLE_ycbcr_422 */ +#ifdef GL_ARB_blend_func_extended + _glewInfo_GL_ARB_blend_func_extended(); +#endif /* GL_ARB_blend_func_extended */ +#ifdef GL_ARB_color_buffer_float + _glewInfo_GL_ARB_color_buffer_float(); +#endif /* GL_ARB_color_buffer_float */ +#ifdef GL_ARB_compatibility + _glewInfo_GL_ARB_compatibility(); +#endif /* GL_ARB_compatibility */ +#ifdef GL_ARB_copy_buffer + _glewInfo_GL_ARB_copy_buffer(); +#endif /* GL_ARB_copy_buffer */ +#ifdef GL_ARB_depth_buffer_float + _glewInfo_GL_ARB_depth_buffer_float(); +#endif /* GL_ARB_depth_buffer_float */ +#ifdef GL_ARB_depth_clamp + _glewInfo_GL_ARB_depth_clamp(); +#endif /* GL_ARB_depth_clamp */ +#ifdef GL_ARB_depth_texture + _glewInfo_GL_ARB_depth_texture(); +#endif /* GL_ARB_depth_texture */ +#ifdef GL_ARB_draw_buffers + _glewInfo_GL_ARB_draw_buffers(); +#endif /* GL_ARB_draw_buffers */ +#ifdef GL_ARB_draw_buffers_blend + _glewInfo_GL_ARB_draw_buffers_blend(); +#endif /* GL_ARB_draw_buffers_blend */ +#ifdef GL_ARB_draw_elements_base_vertex + _glewInfo_GL_ARB_draw_elements_base_vertex(); +#endif /* GL_ARB_draw_elements_base_vertex */ +#ifdef GL_ARB_draw_indirect + _glewInfo_GL_ARB_draw_indirect(); +#endif /* GL_ARB_draw_indirect */ +#ifdef GL_ARB_draw_instanced + _glewInfo_GL_ARB_draw_instanced(); +#endif /* GL_ARB_draw_instanced */ +#ifdef GL_ARB_explicit_attrib_location + _glewInfo_GL_ARB_explicit_attrib_location(); +#endif /* GL_ARB_explicit_attrib_location */ +#ifdef GL_ARB_fragment_coord_conventions + _glewInfo_GL_ARB_fragment_coord_conventions(); +#endif /* GL_ARB_fragment_coord_conventions */ +#ifdef GL_ARB_fragment_program + _glewInfo_GL_ARB_fragment_program(); +#endif /* GL_ARB_fragment_program */ +#ifdef GL_ARB_fragment_program_shadow + _glewInfo_GL_ARB_fragment_program_shadow(); +#endif /* GL_ARB_fragment_program_shadow */ +#ifdef GL_ARB_fragment_shader + _glewInfo_GL_ARB_fragment_shader(); +#endif /* GL_ARB_fragment_shader */ +#ifdef GL_ARB_framebuffer_object + _glewInfo_GL_ARB_framebuffer_object(); +#endif /* GL_ARB_framebuffer_object */ +#ifdef GL_ARB_framebuffer_sRGB + _glewInfo_GL_ARB_framebuffer_sRGB(); +#endif /* GL_ARB_framebuffer_sRGB */ +#ifdef GL_ARB_geometry_shader4 + _glewInfo_GL_ARB_geometry_shader4(); +#endif /* GL_ARB_geometry_shader4 */ +#ifdef GL_ARB_gpu_shader5 + _glewInfo_GL_ARB_gpu_shader5(); +#endif /* GL_ARB_gpu_shader5 */ +#ifdef GL_ARB_gpu_shader_fp64 + _glewInfo_GL_ARB_gpu_shader_fp64(); +#endif /* GL_ARB_gpu_shader_fp64 */ +#ifdef GL_ARB_half_float_pixel + _glewInfo_GL_ARB_half_float_pixel(); +#endif /* GL_ARB_half_float_pixel */ +#ifdef GL_ARB_half_float_vertex + _glewInfo_GL_ARB_half_float_vertex(); +#endif /* GL_ARB_half_float_vertex */ +#ifdef GL_ARB_imaging + _glewInfo_GL_ARB_imaging(); +#endif /* GL_ARB_imaging */ +#ifdef GL_ARB_instanced_arrays + _glewInfo_GL_ARB_instanced_arrays(); +#endif /* GL_ARB_instanced_arrays */ +#ifdef GL_ARB_map_buffer_range + _glewInfo_GL_ARB_map_buffer_range(); +#endif /* GL_ARB_map_buffer_range */ +#ifdef GL_ARB_matrix_palette + _glewInfo_GL_ARB_matrix_palette(); +#endif /* GL_ARB_matrix_palette */ +#ifdef GL_ARB_multisample + _glewInfo_GL_ARB_multisample(); +#endif /* GL_ARB_multisample */ +#ifdef GL_ARB_multitexture + _glewInfo_GL_ARB_multitexture(); +#endif /* GL_ARB_multitexture */ +#ifdef GL_ARB_occlusion_query + _glewInfo_GL_ARB_occlusion_query(); +#endif /* GL_ARB_occlusion_query */ +#ifdef GL_ARB_occlusion_query2 + _glewInfo_GL_ARB_occlusion_query2(); +#endif /* GL_ARB_occlusion_query2 */ +#ifdef GL_ARB_pixel_buffer_object + _glewInfo_GL_ARB_pixel_buffer_object(); +#endif /* GL_ARB_pixel_buffer_object */ +#ifdef GL_ARB_point_parameters + _glewInfo_GL_ARB_point_parameters(); +#endif /* GL_ARB_point_parameters */ +#ifdef GL_ARB_point_sprite + _glewInfo_GL_ARB_point_sprite(); +#endif /* GL_ARB_point_sprite */ +#ifdef GL_ARB_provoking_vertex + _glewInfo_GL_ARB_provoking_vertex(); +#endif /* GL_ARB_provoking_vertex */ +#ifdef GL_ARB_sample_shading + _glewInfo_GL_ARB_sample_shading(); +#endif /* GL_ARB_sample_shading */ +#ifdef GL_ARB_sampler_objects + _glewInfo_GL_ARB_sampler_objects(); +#endif /* GL_ARB_sampler_objects */ +#ifdef GL_ARB_seamless_cube_map + _glewInfo_GL_ARB_seamless_cube_map(); +#endif /* GL_ARB_seamless_cube_map */ +#ifdef GL_ARB_shader_bit_encoding + _glewInfo_GL_ARB_shader_bit_encoding(); +#endif /* GL_ARB_shader_bit_encoding */ +#ifdef GL_ARB_shader_objects + _glewInfo_GL_ARB_shader_objects(); +#endif /* GL_ARB_shader_objects */ +#ifdef GL_ARB_shader_subroutine + _glewInfo_GL_ARB_shader_subroutine(); +#endif /* GL_ARB_shader_subroutine */ +#ifdef GL_ARB_shader_texture_lod + _glewInfo_GL_ARB_shader_texture_lod(); +#endif /* GL_ARB_shader_texture_lod */ +#ifdef GL_ARB_shading_language_100 + _glewInfo_GL_ARB_shading_language_100(); +#endif /* GL_ARB_shading_language_100 */ +#ifdef GL_ARB_shading_language_include + _glewInfo_GL_ARB_shading_language_include(); +#endif /* GL_ARB_shading_language_include */ +#ifdef GL_ARB_shadow + _glewInfo_GL_ARB_shadow(); +#endif /* GL_ARB_shadow */ +#ifdef GL_ARB_shadow_ambient + _glewInfo_GL_ARB_shadow_ambient(); +#endif /* GL_ARB_shadow_ambient */ +#ifdef GL_ARB_sync + _glewInfo_GL_ARB_sync(); +#endif /* GL_ARB_sync */ +#ifdef GL_ARB_tessellation_shader + _glewInfo_GL_ARB_tessellation_shader(); +#endif /* GL_ARB_tessellation_shader */ +#ifdef GL_ARB_texture_border_clamp + _glewInfo_GL_ARB_texture_border_clamp(); +#endif /* GL_ARB_texture_border_clamp */ +#ifdef GL_ARB_texture_buffer_object + _glewInfo_GL_ARB_texture_buffer_object(); +#endif /* GL_ARB_texture_buffer_object */ +#ifdef GL_ARB_texture_buffer_object_rgb32 + _glewInfo_GL_ARB_texture_buffer_object_rgb32(); +#endif /* GL_ARB_texture_buffer_object_rgb32 */ +#ifdef GL_ARB_texture_compression + _glewInfo_GL_ARB_texture_compression(); +#endif /* GL_ARB_texture_compression */ +#ifdef GL_ARB_texture_compression_bptc + _glewInfo_GL_ARB_texture_compression_bptc(); +#endif /* GL_ARB_texture_compression_bptc */ +#ifdef GL_ARB_texture_compression_rgtc + _glewInfo_GL_ARB_texture_compression_rgtc(); +#endif /* GL_ARB_texture_compression_rgtc */ +#ifdef GL_ARB_texture_cube_map + _glewInfo_GL_ARB_texture_cube_map(); +#endif /* GL_ARB_texture_cube_map */ +#ifdef GL_ARB_texture_cube_map_array + _glewInfo_GL_ARB_texture_cube_map_array(); +#endif /* GL_ARB_texture_cube_map_array */ +#ifdef GL_ARB_texture_env_add + _glewInfo_GL_ARB_texture_env_add(); +#endif /* GL_ARB_texture_env_add */ +#ifdef GL_ARB_texture_env_combine + _glewInfo_GL_ARB_texture_env_combine(); +#endif /* GL_ARB_texture_env_combine */ +#ifdef GL_ARB_texture_env_crossbar + _glewInfo_GL_ARB_texture_env_crossbar(); +#endif /* GL_ARB_texture_env_crossbar */ +#ifdef GL_ARB_texture_env_dot3 + _glewInfo_GL_ARB_texture_env_dot3(); +#endif /* GL_ARB_texture_env_dot3 */ +#ifdef GL_ARB_texture_float + _glewInfo_GL_ARB_texture_float(); +#endif /* GL_ARB_texture_float */ +#ifdef GL_ARB_texture_gather + _glewInfo_GL_ARB_texture_gather(); +#endif /* GL_ARB_texture_gather */ +#ifdef GL_ARB_texture_mirrored_repeat + _glewInfo_GL_ARB_texture_mirrored_repeat(); +#endif /* GL_ARB_texture_mirrored_repeat */ +#ifdef GL_ARB_texture_multisample + _glewInfo_GL_ARB_texture_multisample(); +#endif /* GL_ARB_texture_multisample */ +#ifdef GL_ARB_texture_non_power_of_two + _glewInfo_GL_ARB_texture_non_power_of_two(); +#endif /* GL_ARB_texture_non_power_of_two */ +#ifdef GL_ARB_texture_query_lod + _glewInfo_GL_ARB_texture_query_lod(); +#endif /* GL_ARB_texture_query_lod */ +#ifdef GL_ARB_texture_rectangle + _glewInfo_GL_ARB_texture_rectangle(); +#endif /* GL_ARB_texture_rectangle */ +#ifdef GL_ARB_texture_rg + _glewInfo_GL_ARB_texture_rg(); +#endif /* GL_ARB_texture_rg */ +#ifdef GL_ARB_texture_rgb10_a2ui + _glewInfo_GL_ARB_texture_rgb10_a2ui(); +#endif /* GL_ARB_texture_rgb10_a2ui */ +#ifdef GL_ARB_texture_swizzle + _glewInfo_GL_ARB_texture_swizzle(); +#endif /* GL_ARB_texture_swizzle */ +#ifdef GL_ARB_timer_query + _glewInfo_GL_ARB_timer_query(); +#endif /* GL_ARB_timer_query */ +#ifdef GL_ARB_transform_feedback2 + _glewInfo_GL_ARB_transform_feedback2(); +#endif /* GL_ARB_transform_feedback2 */ +#ifdef GL_ARB_transform_feedback3 + _glewInfo_GL_ARB_transform_feedback3(); +#endif /* GL_ARB_transform_feedback3 */ +#ifdef GL_ARB_transpose_matrix + _glewInfo_GL_ARB_transpose_matrix(); +#endif /* GL_ARB_transpose_matrix */ +#ifdef GL_ARB_uniform_buffer_object + _glewInfo_GL_ARB_uniform_buffer_object(); +#endif /* GL_ARB_uniform_buffer_object */ +#ifdef GL_ARB_vertex_array_bgra + _glewInfo_GL_ARB_vertex_array_bgra(); +#endif /* GL_ARB_vertex_array_bgra */ +#ifdef GL_ARB_vertex_array_object + _glewInfo_GL_ARB_vertex_array_object(); +#endif /* GL_ARB_vertex_array_object */ +#ifdef GL_ARB_vertex_blend + _glewInfo_GL_ARB_vertex_blend(); +#endif /* GL_ARB_vertex_blend */ +#ifdef GL_ARB_vertex_buffer_object + _glewInfo_GL_ARB_vertex_buffer_object(); +#endif /* GL_ARB_vertex_buffer_object */ +#ifdef GL_ARB_vertex_program + _glewInfo_GL_ARB_vertex_program(); +#endif /* GL_ARB_vertex_program */ +#ifdef GL_ARB_vertex_shader + _glewInfo_GL_ARB_vertex_shader(); +#endif /* GL_ARB_vertex_shader */ +#ifdef GL_ARB_vertex_type_2_10_10_10_rev + _glewInfo_GL_ARB_vertex_type_2_10_10_10_rev(); +#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ +#ifdef GL_ARB_window_pos + _glewInfo_GL_ARB_window_pos(); +#endif /* GL_ARB_window_pos */ +#ifdef GL_ATIX_point_sprites + _glewInfo_GL_ATIX_point_sprites(); +#endif /* GL_ATIX_point_sprites */ +#ifdef GL_ATIX_texture_env_combine3 + _glewInfo_GL_ATIX_texture_env_combine3(); +#endif /* GL_ATIX_texture_env_combine3 */ +#ifdef GL_ATIX_texture_env_route + _glewInfo_GL_ATIX_texture_env_route(); +#endif /* GL_ATIX_texture_env_route */ +#ifdef GL_ATIX_vertex_shader_output_point_size + _glewInfo_GL_ATIX_vertex_shader_output_point_size(); +#endif /* GL_ATIX_vertex_shader_output_point_size */ +#ifdef GL_ATI_draw_buffers + _glewInfo_GL_ATI_draw_buffers(); +#endif /* GL_ATI_draw_buffers */ +#ifdef GL_ATI_element_array + _glewInfo_GL_ATI_element_array(); +#endif /* GL_ATI_element_array */ +#ifdef GL_ATI_envmap_bumpmap + _glewInfo_GL_ATI_envmap_bumpmap(); +#endif /* GL_ATI_envmap_bumpmap */ +#ifdef GL_ATI_fragment_shader + _glewInfo_GL_ATI_fragment_shader(); +#endif /* GL_ATI_fragment_shader */ +#ifdef GL_ATI_map_object_buffer + _glewInfo_GL_ATI_map_object_buffer(); +#endif /* GL_ATI_map_object_buffer */ +#ifdef GL_ATI_meminfo + _glewInfo_GL_ATI_meminfo(); +#endif /* GL_ATI_meminfo */ +#ifdef GL_ATI_pn_triangles + _glewInfo_GL_ATI_pn_triangles(); +#endif /* GL_ATI_pn_triangles */ +#ifdef GL_ATI_separate_stencil + _glewInfo_GL_ATI_separate_stencil(); +#endif /* GL_ATI_separate_stencil */ +#ifdef GL_ATI_shader_texture_lod + _glewInfo_GL_ATI_shader_texture_lod(); +#endif /* GL_ATI_shader_texture_lod */ +#ifdef GL_ATI_text_fragment_shader + _glewInfo_GL_ATI_text_fragment_shader(); +#endif /* GL_ATI_text_fragment_shader */ +#ifdef GL_ATI_texture_compression_3dc + _glewInfo_GL_ATI_texture_compression_3dc(); +#endif /* GL_ATI_texture_compression_3dc */ +#ifdef GL_ATI_texture_env_combine3 + _glewInfo_GL_ATI_texture_env_combine3(); +#endif /* GL_ATI_texture_env_combine3 */ +#ifdef GL_ATI_texture_float + _glewInfo_GL_ATI_texture_float(); +#endif /* GL_ATI_texture_float */ +#ifdef GL_ATI_texture_mirror_once + _glewInfo_GL_ATI_texture_mirror_once(); +#endif /* GL_ATI_texture_mirror_once */ +#ifdef GL_ATI_vertex_array_object + _glewInfo_GL_ATI_vertex_array_object(); +#endif /* GL_ATI_vertex_array_object */ +#ifdef GL_ATI_vertex_attrib_array_object + _glewInfo_GL_ATI_vertex_attrib_array_object(); +#endif /* GL_ATI_vertex_attrib_array_object */ +#ifdef GL_ATI_vertex_streams + _glewInfo_GL_ATI_vertex_streams(); +#endif /* GL_ATI_vertex_streams */ +#ifdef GL_EXT_422_pixels + _glewInfo_GL_EXT_422_pixels(); +#endif /* GL_EXT_422_pixels */ +#ifdef GL_EXT_Cg_shader + _glewInfo_GL_EXT_Cg_shader(); +#endif /* GL_EXT_Cg_shader */ +#ifdef GL_EXT_abgr + _glewInfo_GL_EXT_abgr(); +#endif /* GL_EXT_abgr */ +#ifdef GL_EXT_bgra + _glewInfo_GL_EXT_bgra(); +#endif /* GL_EXT_bgra */ +#ifdef GL_EXT_bindable_uniform + _glewInfo_GL_EXT_bindable_uniform(); +#endif /* GL_EXT_bindable_uniform */ +#ifdef GL_EXT_blend_color + _glewInfo_GL_EXT_blend_color(); +#endif /* GL_EXT_blend_color */ +#ifdef GL_EXT_blend_equation_separate + _glewInfo_GL_EXT_blend_equation_separate(); +#endif /* GL_EXT_blend_equation_separate */ +#ifdef GL_EXT_blend_func_separate + _glewInfo_GL_EXT_blend_func_separate(); +#endif /* GL_EXT_blend_func_separate */ +#ifdef GL_EXT_blend_logic_op + _glewInfo_GL_EXT_blend_logic_op(); +#endif /* GL_EXT_blend_logic_op */ +#ifdef GL_EXT_blend_minmax + _glewInfo_GL_EXT_blend_minmax(); +#endif /* GL_EXT_blend_minmax */ +#ifdef GL_EXT_blend_subtract + _glewInfo_GL_EXT_blend_subtract(); +#endif /* GL_EXT_blend_subtract */ +#ifdef GL_EXT_clip_volume_hint + _glewInfo_GL_EXT_clip_volume_hint(); +#endif /* GL_EXT_clip_volume_hint */ +#ifdef GL_EXT_cmyka + _glewInfo_GL_EXT_cmyka(); +#endif /* GL_EXT_cmyka */ +#ifdef GL_EXT_color_subtable + _glewInfo_GL_EXT_color_subtable(); +#endif /* GL_EXT_color_subtable */ +#ifdef GL_EXT_compiled_vertex_array + _glewInfo_GL_EXT_compiled_vertex_array(); +#endif /* GL_EXT_compiled_vertex_array */ +#ifdef GL_EXT_convolution + _glewInfo_GL_EXT_convolution(); +#endif /* GL_EXT_convolution */ +#ifdef GL_EXT_coordinate_frame + _glewInfo_GL_EXT_coordinate_frame(); +#endif /* GL_EXT_coordinate_frame */ +#ifdef GL_EXT_copy_texture + _glewInfo_GL_EXT_copy_texture(); +#endif /* GL_EXT_copy_texture */ +#ifdef GL_EXT_cull_vertex + _glewInfo_GL_EXT_cull_vertex(); +#endif /* GL_EXT_cull_vertex */ +#ifdef GL_EXT_depth_bounds_test + _glewInfo_GL_EXT_depth_bounds_test(); +#endif /* GL_EXT_depth_bounds_test */ +#ifdef GL_EXT_direct_state_access + _glewInfo_GL_EXT_direct_state_access(); +#endif /* GL_EXT_direct_state_access */ +#ifdef GL_EXT_draw_buffers2 + _glewInfo_GL_EXT_draw_buffers2(); +#endif /* GL_EXT_draw_buffers2 */ +#ifdef GL_EXT_draw_instanced + _glewInfo_GL_EXT_draw_instanced(); +#endif /* GL_EXT_draw_instanced */ +#ifdef GL_EXT_draw_range_elements + _glewInfo_GL_EXT_draw_range_elements(); +#endif /* GL_EXT_draw_range_elements */ +#ifdef GL_EXT_fog_coord + _glewInfo_GL_EXT_fog_coord(); +#endif /* GL_EXT_fog_coord */ +#ifdef GL_EXT_fragment_lighting + _glewInfo_GL_EXT_fragment_lighting(); +#endif /* GL_EXT_fragment_lighting */ +#ifdef GL_EXT_framebuffer_blit + _glewInfo_GL_EXT_framebuffer_blit(); +#endif /* GL_EXT_framebuffer_blit */ +#ifdef GL_EXT_framebuffer_multisample + _glewInfo_GL_EXT_framebuffer_multisample(); +#endif /* GL_EXT_framebuffer_multisample */ +#ifdef GL_EXT_framebuffer_object + _glewInfo_GL_EXT_framebuffer_object(); +#endif /* GL_EXT_framebuffer_object */ +#ifdef GL_EXT_framebuffer_sRGB + _glewInfo_GL_EXT_framebuffer_sRGB(); +#endif /* GL_EXT_framebuffer_sRGB */ +#ifdef GL_EXT_geometry_shader4 + _glewInfo_GL_EXT_geometry_shader4(); +#endif /* GL_EXT_geometry_shader4 */ +#ifdef GL_EXT_gpu_program_parameters + _glewInfo_GL_EXT_gpu_program_parameters(); +#endif /* GL_EXT_gpu_program_parameters */ +#ifdef GL_EXT_gpu_shader4 + _glewInfo_GL_EXT_gpu_shader4(); +#endif /* GL_EXT_gpu_shader4 */ +#ifdef GL_EXT_histogram + _glewInfo_GL_EXT_histogram(); +#endif /* GL_EXT_histogram */ +#ifdef GL_EXT_index_array_formats + _glewInfo_GL_EXT_index_array_formats(); +#endif /* GL_EXT_index_array_formats */ +#ifdef GL_EXT_index_func + _glewInfo_GL_EXT_index_func(); +#endif /* GL_EXT_index_func */ +#ifdef GL_EXT_index_material + _glewInfo_GL_EXT_index_material(); +#endif /* GL_EXT_index_material */ +#ifdef GL_EXT_index_texture + _glewInfo_GL_EXT_index_texture(); +#endif /* GL_EXT_index_texture */ +#ifdef GL_EXT_light_texture + _glewInfo_GL_EXT_light_texture(); +#endif /* GL_EXT_light_texture */ +#ifdef GL_EXT_misc_attribute + _glewInfo_GL_EXT_misc_attribute(); +#endif /* GL_EXT_misc_attribute */ +#ifdef GL_EXT_multi_draw_arrays + _glewInfo_GL_EXT_multi_draw_arrays(); +#endif /* GL_EXT_multi_draw_arrays */ +#ifdef GL_EXT_multisample + _glewInfo_GL_EXT_multisample(); +#endif /* GL_EXT_multisample */ +#ifdef GL_EXT_packed_depth_stencil + _glewInfo_GL_EXT_packed_depth_stencil(); +#endif /* GL_EXT_packed_depth_stencil */ +#ifdef GL_EXT_packed_float + _glewInfo_GL_EXT_packed_float(); +#endif /* GL_EXT_packed_float */ +#ifdef GL_EXT_packed_pixels + _glewInfo_GL_EXT_packed_pixels(); +#endif /* GL_EXT_packed_pixels */ +#ifdef GL_EXT_paletted_texture + _glewInfo_GL_EXT_paletted_texture(); +#endif /* GL_EXT_paletted_texture */ +#ifdef GL_EXT_pixel_buffer_object + _glewInfo_GL_EXT_pixel_buffer_object(); +#endif /* GL_EXT_pixel_buffer_object */ +#ifdef GL_EXT_pixel_transform + _glewInfo_GL_EXT_pixel_transform(); +#endif /* GL_EXT_pixel_transform */ +#ifdef GL_EXT_pixel_transform_color_table + _glewInfo_GL_EXT_pixel_transform_color_table(); +#endif /* GL_EXT_pixel_transform_color_table */ +#ifdef GL_EXT_point_parameters + _glewInfo_GL_EXT_point_parameters(); +#endif /* GL_EXT_point_parameters */ +#ifdef GL_EXT_polygon_offset + _glewInfo_GL_EXT_polygon_offset(); +#endif /* GL_EXT_polygon_offset */ +#ifdef GL_EXT_provoking_vertex + _glewInfo_GL_EXT_provoking_vertex(); +#endif /* GL_EXT_provoking_vertex */ +#ifdef GL_EXT_rescale_normal + _glewInfo_GL_EXT_rescale_normal(); +#endif /* GL_EXT_rescale_normal */ +#ifdef GL_EXT_scene_marker + _glewInfo_GL_EXT_scene_marker(); +#endif /* GL_EXT_scene_marker */ +#ifdef GL_EXT_secondary_color + _glewInfo_GL_EXT_secondary_color(); +#endif /* GL_EXT_secondary_color */ +#ifdef GL_EXT_separate_shader_objects + _glewInfo_GL_EXT_separate_shader_objects(); +#endif /* GL_EXT_separate_shader_objects */ +#ifdef GL_EXT_separate_specular_color + _glewInfo_GL_EXT_separate_specular_color(); +#endif /* GL_EXT_separate_specular_color */ +#ifdef GL_EXT_shader_image_load_store + _glewInfo_GL_EXT_shader_image_load_store(); +#endif /* GL_EXT_shader_image_load_store */ +#ifdef GL_EXT_shadow_funcs + _glewInfo_GL_EXT_shadow_funcs(); +#endif /* GL_EXT_shadow_funcs */ +#ifdef GL_EXT_shared_texture_palette + _glewInfo_GL_EXT_shared_texture_palette(); +#endif /* GL_EXT_shared_texture_palette */ +#ifdef GL_EXT_stencil_clear_tag + _glewInfo_GL_EXT_stencil_clear_tag(); +#endif /* GL_EXT_stencil_clear_tag */ +#ifdef GL_EXT_stencil_two_side + _glewInfo_GL_EXT_stencil_two_side(); +#endif /* GL_EXT_stencil_two_side */ +#ifdef GL_EXT_stencil_wrap + _glewInfo_GL_EXT_stencil_wrap(); +#endif /* GL_EXT_stencil_wrap */ +#ifdef GL_EXT_subtexture + _glewInfo_GL_EXT_subtexture(); +#endif /* GL_EXT_subtexture */ +#ifdef GL_EXT_texture + _glewInfo_GL_EXT_texture(); +#endif /* GL_EXT_texture */ +#ifdef GL_EXT_texture3D + _glewInfo_GL_EXT_texture3D(); +#endif /* GL_EXT_texture3D */ +#ifdef GL_EXT_texture_array + _glewInfo_GL_EXT_texture_array(); +#endif /* GL_EXT_texture_array */ +#ifdef GL_EXT_texture_buffer_object + _glewInfo_GL_EXT_texture_buffer_object(); +#endif /* GL_EXT_texture_buffer_object */ +#ifdef GL_EXT_texture_compression_dxt1 + _glewInfo_GL_EXT_texture_compression_dxt1(); +#endif /* GL_EXT_texture_compression_dxt1 */ +#ifdef GL_EXT_texture_compression_latc + _glewInfo_GL_EXT_texture_compression_latc(); +#endif /* GL_EXT_texture_compression_latc */ +#ifdef GL_EXT_texture_compression_rgtc + _glewInfo_GL_EXT_texture_compression_rgtc(); +#endif /* GL_EXT_texture_compression_rgtc */ +#ifdef GL_EXT_texture_compression_s3tc + _glewInfo_GL_EXT_texture_compression_s3tc(); +#endif /* GL_EXT_texture_compression_s3tc */ +#ifdef GL_EXT_texture_cube_map + _glewInfo_GL_EXT_texture_cube_map(); +#endif /* GL_EXT_texture_cube_map */ +#ifdef GL_EXT_texture_edge_clamp + _glewInfo_GL_EXT_texture_edge_clamp(); +#endif /* GL_EXT_texture_edge_clamp */ +#ifdef GL_EXT_texture_env + _glewInfo_GL_EXT_texture_env(); +#endif /* GL_EXT_texture_env */ +#ifdef GL_EXT_texture_env_add + _glewInfo_GL_EXT_texture_env_add(); +#endif /* GL_EXT_texture_env_add */ +#ifdef GL_EXT_texture_env_combine + _glewInfo_GL_EXT_texture_env_combine(); +#endif /* GL_EXT_texture_env_combine */ +#ifdef GL_EXT_texture_env_dot3 + _glewInfo_GL_EXT_texture_env_dot3(); +#endif /* GL_EXT_texture_env_dot3 */ +#ifdef GL_EXT_texture_filter_anisotropic + _glewInfo_GL_EXT_texture_filter_anisotropic(); +#endif /* GL_EXT_texture_filter_anisotropic */ +#ifdef GL_EXT_texture_integer + _glewInfo_GL_EXT_texture_integer(); +#endif /* GL_EXT_texture_integer */ +#ifdef GL_EXT_texture_lod_bias + _glewInfo_GL_EXT_texture_lod_bias(); +#endif /* GL_EXT_texture_lod_bias */ +#ifdef GL_EXT_texture_mirror_clamp + _glewInfo_GL_EXT_texture_mirror_clamp(); +#endif /* GL_EXT_texture_mirror_clamp */ +#ifdef GL_EXT_texture_object + _glewInfo_GL_EXT_texture_object(); +#endif /* GL_EXT_texture_object */ +#ifdef GL_EXT_texture_perturb_normal + _glewInfo_GL_EXT_texture_perturb_normal(); +#endif /* GL_EXT_texture_perturb_normal */ +#ifdef GL_EXT_texture_rectangle + _glewInfo_GL_EXT_texture_rectangle(); +#endif /* GL_EXT_texture_rectangle */ +#ifdef GL_EXT_texture_sRGB + _glewInfo_GL_EXT_texture_sRGB(); +#endif /* GL_EXT_texture_sRGB */ +#ifdef GL_EXT_texture_shared_exponent + _glewInfo_GL_EXT_texture_shared_exponent(); +#endif /* GL_EXT_texture_shared_exponent */ +#ifdef GL_EXT_texture_snorm + _glewInfo_GL_EXT_texture_snorm(); +#endif /* GL_EXT_texture_snorm */ +#ifdef GL_EXT_texture_swizzle + _glewInfo_GL_EXT_texture_swizzle(); +#endif /* GL_EXT_texture_swizzle */ +#ifdef GL_EXT_timer_query + _glewInfo_GL_EXT_timer_query(); +#endif /* GL_EXT_timer_query */ +#ifdef GL_EXT_transform_feedback + _glewInfo_GL_EXT_transform_feedback(); +#endif /* GL_EXT_transform_feedback */ +#ifdef GL_EXT_vertex_array + _glewInfo_GL_EXT_vertex_array(); +#endif /* GL_EXT_vertex_array */ +#ifdef GL_EXT_vertex_array_bgra + _glewInfo_GL_EXT_vertex_array_bgra(); +#endif /* GL_EXT_vertex_array_bgra */ +#ifdef GL_EXT_vertex_attrib_64bit + _glewInfo_GL_EXT_vertex_attrib_64bit(); +#endif /* GL_EXT_vertex_attrib_64bit */ +#ifdef GL_EXT_vertex_shader + _glewInfo_GL_EXT_vertex_shader(); +#endif /* GL_EXT_vertex_shader */ +#ifdef GL_EXT_vertex_weighting + _glewInfo_GL_EXT_vertex_weighting(); +#endif /* GL_EXT_vertex_weighting */ +#ifdef GL_GREMEDY_frame_terminator + _glewInfo_GL_GREMEDY_frame_terminator(); +#endif /* GL_GREMEDY_frame_terminator */ +#ifdef GL_GREMEDY_string_marker + _glewInfo_GL_GREMEDY_string_marker(); +#endif /* GL_GREMEDY_string_marker */ +#ifdef GL_HP_convolution_border_modes + _glewInfo_GL_HP_convolution_border_modes(); +#endif /* GL_HP_convolution_border_modes */ +#ifdef GL_HP_image_transform + _glewInfo_GL_HP_image_transform(); +#endif /* GL_HP_image_transform */ +#ifdef GL_HP_occlusion_test + _glewInfo_GL_HP_occlusion_test(); +#endif /* GL_HP_occlusion_test */ +#ifdef GL_HP_texture_lighting + _glewInfo_GL_HP_texture_lighting(); +#endif /* GL_HP_texture_lighting */ +#ifdef GL_IBM_cull_vertex + _glewInfo_GL_IBM_cull_vertex(); +#endif /* GL_IBM_cull_vertex */ +#ifdef GL_IBM_multimode_draw_arrays + _glewInfo_GL_IBM_multimode_draw_arrays(); +#endif /* GL_IBM_multimode_draw_arrays */ +#ifdef GL_IBM_rasterpos_clip + _glewInfo_GL_IBM_rasterpos_clip(); +#endif /* GL_IBM_rasterpos_clip */ +#ifdef GL_IBM_static_data + _glewInfo_GL_IBM_static_data(); +#endif /* GL_IBM_static_data */ +#ifdef GL_IBM_texture_mirrored_repeat + _glewInfo_GL_IBM_texture_mirrored_repeat(); +#endif /* GL_IBM_texture_mirrored_repeat */ +#ifdef GL_IBM_vertex_array_lists + _glewInfo_GL_IBM_vertex_array_lists(); +#endif /* GL_IBM_vertex_array_lists */ +#ifdef GL_INGR_color_clamp + _glewInfo_GL_INGR_color_clamp(); +#endif /* GL_INGR_color_clamp */ +#ifdef GL_INGR_interlace_read + _glewInfo_GL_INGR_interlace_read(); +#endif /* GL_INGR_interlace_read */ +#ifdef GL_INTEL_parallel_arrays + _glewInfo_GL_INTEL_parallel_arrays(); +#endif /* GL_INTEL_parallel_arrays */ +#ifdef GL_INTEL_texture_scissor + _glewInfo_GL_INTEL_texture_scissor(); +#endif /* GL_INTEL_texture_scissor */ +#ifdef GL_KTX_buffer_region + _glewInfo_GL_KTX_buffer_region(); +#endif /* GL_KTX_buffer_region */ +#ifdef GL_MESAX_texture_stack + _glewInfo_GL_MESAX_texture_stack(); +#endif /* GL_MESAX_texture_stack */ +#ifdef GL_MESA_pack_invert + _glewInfo_GL_MESA_pack_invert(); +#endif /* GL_MESA_pack_invert */ +#ifdef GL_MESA_resize_buffers + _glewInfo_GL_MESA_resize_buffers(); +#endif /* GL_MESA_resize_buffers */ +#ifdef GL_MESA_window_pos + _glewInfo_GL_MESA_window_pos(); +#endif /* GL_MESA_window_pos */ +#ifdef GL_MESA_ycbcr_texture + _glewInfo_GL_MESA_ycbcr_texture(); +#endif /* GL_MESA_ycbcr_texture */ +#ifdef GL_NV_blend_square + _glewInfo_GL_NV_blend_square(); +#endif /* GL_NV_blend_square */ +#ifdef GL_NV_conditional_render + _glewInfo_GL_NV_conditional_render(); +#endif /* GL_NV_conditional_render */ +#ifdef GL_NV_copy_depth_to_color + _glewInfo_GL_NV_copy_depth_to_color(); +#endif /* GL_NV_copy_depth_to_color */ +#ifdef GL_NV_copy_image + _glewInfo_GL_NV_copy_image(); +#endif /* GL_NV_copy_image */ +#ifdef GL_NV_depth_buffer_float + _glewInfo_GL_NV_depth_buffer_float(); +#endif /* GL_NV_depth_buffer_float */ +#ifdef GL_NV_depth_clamp + _glewInfo_GL_NV_depth_clamp(); +#endif /* GL_NV_depth_clamp */ +#ifdef GL_NV_depth_range_unclamped + _glewInfo_GL_NV_depth_range_unclamped(); +#endif /* GL_NV_depth_range_unclamped */ +#ifdef GL_NV_evaluators + _glewInfo_GL_NV_evaluators(); +#endif /* GL_NV_evaluators */ +#ifdef GL_NV_explicit_multisample + _glewInfo_GL_NV_explicit_multisample(); +#endif /* GL_NV_explicit_multisample */ +#ifdef GL_NV_fence + _glewInfo_GL_NV_fence(); +#endif /* GL_NV_fence */ +#ifdef GL_NV_float_buffer + _glewInfo_GL_NV_float_buffer(); +#endif /* GL_NV_float_buffer */ +#ifdef GL_NV_fog_distance + _glewInfo_GL_NV_fog_distance(); +#endif /* GL_NV_fog_distance */ +#ifdef GL_NV_fragment_program + _glewInfo_GL_NV_fragment_program(); +#endif /* GL_NV_fragment_program */ +#ifdef GL_NV_fragment_program2 + _glewInfo_GL_NV_fragment_program2(); +#endif /* GL_NV_fragment_program2 */ +#ifdef GL_NV_fragment_program4 + _glewInfo_GL_NV_fragment_program4(); +#endif /* GL_NV_fragment_program4 */ +#ifdef GL_NV_fragment_program_option + _glewInfo_GL_NV_fragment_program_option(); +#endif /* GL_NV_fragment_program_option */ +#ifdef GL_NV_framebuffer_multisample_coverage + _glewInfo_GL_NV_framebuffer_multisample_coverage(); +#endif /* GL_NV_framebuffer_multisample_coverage */ +#ifdef GL_NV_geometry_program4 + _glewInfo_GL_NV_geometry_program4(); +#endif /* GL_NV_geometry_program4 */ +#ifdef GL_NV_geometry_shader4 + _glewInfo_GL_NV_geometry_shader4(); +#endif /* GL_NV_geometry_shader4 */ +#ifdef GL_NV_gpu_program4 + _glewInfo_GL_NV_gpu_program4(); +#endif /* GL_NV_gpu_program4 */ +#ifdef GL_NV_gpu_program5 + _glewInfo_GL_NV_gpu_program5(); +#endif /* GL_NV_gpu_program5 */ +#ifdef GL_NV_gpu_program_fp64 + _glewInfo_GL_NV_gpu_program_fp64(); +#endif /* GL_NV_gpu_program_fp64 */ +#ifdef GL_NV_gpu_shader5 + _glewInfo_GL_NV_gpu_shader5(); +#endif /* GL_NV_gpu_shader5 */ +#ifdef GL_NV_half_float + _glewInfo_GL_NV_half_float(); +#endif /* GL_NV_half_float */ +#ifdef GL_NV_light_max_exponent + _glewInfo_GL_NV_light_max_exponent(); +#endif /* GL_NV_light_max_exponent */ +#ifdef GL_NV_multisample_filter_hint + _glewInfo_GL_NV_multisample_filter_hint(); +#endif /* GL_NV_multisample_filter_hint */ +#ifdef GL_NV_occlusion_query + _glewInfo_GL_NV_occlusion_query(); +#endif /* GL_NV_occlusion_query */ +#ifdef GL_NV_packed_depth_stencil + _glewInfo_GL_NV_packed_depth_stencil(); +#endif /* GL_NV_packed_depth_stencil */ +#ifdef GL_NV_parameter_buffer_object + _glewInfo_GL_NV_parameter_buffer_object(); +#endif /* GL_NV_parameter_buffer_object */ +#ifdef GL_NV_parameter_buffer_object2 + _glewInfo_GL_NV_parameter_buffer_object2(); +#endif /* GL_NV_parameter_buffer_object2 */ +#ifdef GL_NV_pixel_data_range + _glewInfo_GL_NV_pixel_data_range(); +#endif /* GL_NV_pixel_data_range */ +#ifdef GL_NV_point_sprite + _glewInfo_GL_NV_point_sprite(); +#endif /* GL_NV_point_sprite */ +#ifdef GL_NV_present_video + _glewInfo_GL_NV_present_video(); +#endif /* GL_NV_present_video */ +#ifdef GL_NV_primitive_restart + _glewInfo_GL_NV_primitive_restart(); +#endif /* GL_NV_primitive_restart */ +#ifdef GL_NV_register_combiners + _glewInfo_GL_NV_register_combiners(); +#endif /* GL_NV_register_combiners */ +#ifdef GL_NV_register_combiners2 + _glewInfo_GL_NV_register_combiners2(); +#endif /* GL_NV_register_combiners2 */ +#ifdef GL_NV_shader_buffer_load + _glewInfo_GL_NV_shader_buffer_load(); +#endif /* GL_NV_shader_buffer_load */ +#ifdef GL_NV_tessellation_program5 + _glewInfo_GL_NV_tessellation_program5(); +#endif /* GL_NV_tessellation_program5 */ +#ifdef GL_NV_texgen_emboss + _glewInfo_GL_NV_texgen_emboss(); +#endif /* GL_NV_texgen_emboss */ +#ifdef GL_NV_texgen_reflection + _glewInfo_GL_NV_texgen_reflection(); +#endif /* GL_NV_texgen_reflection */ +#ifdef GL_NV_texture_barrier + _glewInfo_GL_NV_texture_barrier(); +#endif /* GL_NV_texture_barrier */ +#ifdef GL_NV_texture_compression_vtc + _glewInfo_GL_NV_texture_compression_vtc(); +#endif /* GL_NV_texture_compression_vtc */ +#ifdef GL_NV_texture_env_combine4 + _glewInfo_GL_NV_texture_env_combine4(); +#endif /* GL_NV_texture_env_combine4 */ +#ifdef GL_NV_texture_expand_normal + _glewInfo_GL_NV_texture_expand_normal(); +#endif /* GL_NV_texture_expand_normal */ +#ifdef GL_NV_texture_rectangle + _glewInfo_GL_NV_texture_rectangle(); +#endif /* GL_NV_texture_rectangle */ +#ifdef GL_NV_texture_shader + _glewInfo_GL_NV_texture_shader(); +#endif /* GL_NV_texture_shader */ +#ifdef GL_NV_texture_shader2 + _glewInfo_GL_NV_texture_shader2(); +#endif /* GL_NV_texture_shader2 */ +#ifdef GL_NV_texture_shader3 + _glewInfo_GL_NV_texture_shader3(); +#endif /* GL_NV_texture_shader3 */ +#ifdef GL_NV_transform_feedback + _glewInfo_GL_NV_transform_feedback(); +#endif /* GL_NV_transform_feedback */ +#ifdef GL_NV_transform_feedback2 + _glewInfo_GL_NV_transform_feedback2(); +#endif /* GL_NV_transform_feedback2 */ +#ifdef GL_NV_vertex_array_range + _glewInfo_GL_NV_vertex_array_range(); +#endif /* GL_NV_vertex_array_range */ +#ifdef GL_NV_vertex_array_range2 + _glewInfo_GL_NV_vertex_array_range2(); +#endif /* GL_NV_vertex_array_range2 */ +#ifdef GL_NV_vertex_attrib_integer_64bit + _glewInfo_GL_NV_vertex_attrib_integer_64bit(); +#endif /* GL_NV_vertex_attrib_integer_64bit */ +#ifdef GL_NV_vertex_buffer_unified_memory + _glewInfo_GL_NV_vertex_buffer_unified_memory(); +#endif /* GL_NV_vertex_buffer_unified_memory */ +#ifdef GL_NV_vertex_program + _glewInfo_GL_NV_vertex_program(); +#endif /* GL_NV_vertex_program */ +#ifdef GL_NV_vertex_program1_1 + _glewInfo_GL_NV_vertex_program1_1(); +#endif /* GL_NV_vertex_program1_1 */ +#ifdef GL_NV_vertex_program2 + _glewInfo_GL_NV_vertex_program2(); +#endif /* GL_NV_vertex_program2 */ +#ifdef GL_NV_vertex_program2_option + _glewInfo_GL_NV_vertex_program2_option(); +#endif /* GL_NV_vertex_program2_option */ +#ifdef GL_NV_vertex_program3 + _glewInfo_GL_NV_vertex_program3(); +#endif /* GL_NV_vertex_program3 */ +#ifdef GL_NV_vertex_program4 + _glewInfo_GL_NV_vertex_program4(); +#endif /* GL_NV_vertex_program4 */ +#ifdef GL_OES_byte_coordinates + _glewInfo_GL_OES_byte_coordinates(); +#endif /* GL_OES_byte_coordinates */ +#ifdef GL_OES_compressed_paletted_texture + _glewInfo_GL_OES_compressed_paletted_texture(); +#endif /* GL_OES_compressed_paletted_texture */ +#ifdef GL_OES_read_format + _glewInfo_GL_OES_read_format(); +#endif /* GL_OES_read_format */ +#ifdef GL_OES_single_precision + _glewInfo_GL_OES_single_precision(); +#endif /* GL_OES_single_precision */ +#ifdef GL_OML_interlace + _glewInfo_GL_OML_interlace(); +#endif /* GL_OML_interlace */ +#ifdef GL_OML_resample + _glewInfo_GL_OML_resample(); +#endif /* GL_OML_resample */ +#ifdef GL_OML_subsample + _glewInfo_GL_OML_subsample(); +#endif /* GL_OML_subsample */ +#ifdef GL_PGI_misc_hints + _glewInfo_GL_PGI_misc_hints(); +#endif /* GL_PGI_misc_hints */ +#ifdef GL_PGI_vertex_hints + _glewInfo_GL_PGI_vertex_hints(); +#endif /* GL_PGI_vertex_hints */ +#ifdef GL_REND_screen_coordinates + _glewInfo_GL_REND_screen_coordinates(); +#endif /* GL_REND_screen_coordinates */ +#ifdef GL_S3_s3tc + _glewInfo_GL_S3_s3tc(); +#endif /* GL_S3_s3tc */ +#ifdef GL_SGIS_color_range + _glewInfo_GL_SGIS_color_range(); +#endif /* GL_SGIS_color_range */ +#ifdef GL_SGIS_detail_texture + _glewInfo_GL_SGIS_detail_texture(); +#endif /* GL_SGIS_detail_texture */ +#ifdef GL_SGIS_fog_function + _glewInfo_GL_SGIS_fog_function(); +#endif /* GL_SGIS_fog_function */ +#ifdef GL_SGIS_generate_mipmap + _glewInfo_GL_SGIS_generate_mipmap(); +#endif /* GL_SGIS_generate_mipmap */ +#ifdef GL_SGIS_multisample + _glewInfo_GL_SGIS_multisample(); +#endif /* GL_SGIS_multisample */ +#ifdef GL_SGIS_pixel_texture + _glewInfo_GL_SGIS_pixel_texture(); +#endif /* GL_SGIS_pixel_texture */ +#ifdef GL_SGIS_point_line_texgen + _glewInfo_GL_SGIS_point_line_texgen(); +#endif /* GL_SGIS_point_line_texgen */ +#ifdef GL_SGIS_sharpen_texture + _glewInfo_GL_SGIS_sharpen_texture(); +#endif /* GL_SGIS_sharpen_texture */ +#ifdef GL_SGIS_texture4D + _glewInfo_GL_SGIS_texture4D(); +#endif /* GL_SGIS_texture4D */ +#ifdef GL_SGIS_texture_border_clamp + _glewInfo_GL_SGIS_texture_border_clamp(); +#endif /* GL_SGIS_texture_border_clamp */ +#ifdef GL_SGIS_texture_edge_clamp + _glewInfo_GL_SGIS_texture_edge_clamp(); +#endif /* GL_SGIS_texture_edge_clamp */ +#ifdef GL_SGIS_texture_filter4 + _glewInfo_GL_SGIS_texture_filter4(); +#endif /* GL_SGIS_texture_filter4 */ +#ifdef GL_SGIS_texture_lod + _glewInfo_GL_SGIS_texture_lod(); +#endif /* GL_SGIS_texture_lod */ +#ifdef GL_SGIS_texture_select + _glewInfo_GL_SGIS_texture_select(); +#endif /* GL_SGIS_texture_select */ +#ifdef GL_SGIX_async + _glewInfo_GL_SGIX_async(); +#endif /* GL_SGIX_async */ +#ifdef GL_SGIX_async_histogram + _glewInfo_GL_SGIX_async_histogram(); +#endif /* GL_SGIX_async_histogram */ +#ifdef GL_SGIX_async_pixel + _glewInfo_GL_SGIX_async_pixel(); +#endif /* GL_SGIX_async_pixel */ +#ifdef GL_SGIX_blend_alpha_minmax + _glewInfo_GL_SGIX_blend_alpha_minmax(); +#endif /* GL_SGIX_blend_alpha_minmax */ +#ifdef GL_SGIX_clipmap + _glewInfo_GL_SGIX_clipmap(); +#endif /* GL_SGIX_clipmap */ +#ifdef GL_SGIX_convolution_accuracy + _glewInfo_GL_SGIX_convolution_accuracy(); +#endif /* GL_SGIX_convolution_accuracy */ +#ifdef GL_SGIX_depth_texture + _glewInfo_GL_SGIX_depth_texture(); +#endif /* GL_SGIX_depth_texture */ +#ifdef GL_SGIX_flush_raster + _glewInfo_GL_SGIX_flush_raster(); +#endif /* GL_SGIX_flush_raster */ +#ifdef GL_SGIX_fog_offset + _glewInfo_GL_SGIX_fog_offset(); +#endif /* GL_SGIX_fog_offset */ +#ifdef GL_SGIX_fog_texture + _glewInfo_GL_SGIX_fog_texture(); +#endif /* GL_SGIX_fog_texture */ +#ifdef GL_SGIX_fragment_specular_lighting + _glewInfo_GL_SGIX_fragment_specular_lighting(); +#endif /* GL_SGIX_fragment_specular_lighting */ +#ifdef GL_SGIX_framezoom + _glewInfo_GL_SGIX_framezoom(); +#endif /* GL_SGIX_framezoom */ +#ifdef GL_SGIX_interlace + _glewInfo_GL_SGIX_interlace(); +#endif /* GL_SGIX_interlace */ +#ifdef GL_SGIX_ir_instrument1 + _glewInfo_GL_SGIX_ir_instrument1(); +#endif /* GL_SGIX_ir_instrument1 */ +#ifdef GL_SGIX_list_priority + _glewInfo_GL_SGIX_list_priority(); +#endif /* GL_SGIX_list_priority */ +#ifdef GL_SGIX_pixel_texture + _glewInfo_GL_SGIX_pixel_texture(); +#endif /* GL_SGIX_pixel_texture */ +#ifdef GL_SGIX_pixel_texture_bits + _glewInfo_GL_SGIX_pixel_texture_bits(); +#endif /* GL_SGIX_pixel_texture_bits */ +#ifdef GL_SGIX_reference_plane + _glewInfo_GL_SGIX_reference_plane(); +#endif /* GL_SGIX_reference_plane */ +#ifdef GL_SGIX_resample + _glewInfo_GL_SGIX_resample(); +#endif /* GL_SGIX_resample */ +#ifdef GL_SGIX_shadow + _glewInfo_GL_SGIX_shadow(); +#endif /* GL_SGIX_shadow */ +#ifdef GL_SGIX_shadow_ambient + _glewInfo_GL_SGIX_shadow_ambient(); +#endif /* GL_SGIX_shadow_ambient */ +#ifdef GL_SGIX_sprite + _glewInfo_GL_SGIX_sprite(); +#endif /* GL_SGIX_sprite */ +#ifdef GL_SGIX_tag_sample_buffer + _glewInfo_GL_SGIX_tag_sample_buffer(); +#endif /* GL_SGIX_tag_sample_buffer */ +#ifdef GL_SGIX_texture_add_env + _glewInfo_GL_SGIX_texture_add_env(); +#endif /* GL_SGIX_texture_add_env */ +#ifdef GL_SGIX_texture_coordinate_clamp + _glewInfo_GL_SGIX_texture_coordinate_clamp(); +#endif /* GL_SGIX_texture_coordinate_clamp */ +#ifdef GL_SGIX_texture_lod_bias + _glewInfo_GL_SGIX_texture_lod_bias(); +#endif /* GL_SGIX_texture_lod_bias */ +#ifdef GL_SGIX_texture_multi_buffer + _glewInfo_GL_SGIX_texture_multi_buffer(); +#endif /* GL_SGIX_texture_multi_buffer */ +#ifdef GL_SGIX_texture_range + _glewInfo_GL_SGIX_texture_range(); +#endif /* GL_SGIX_texture_range */ +#ifdef GL_SGIX_texture_scale_bias + _glewInfo_GL_SGIX_texture_scale_bias(); +#endif /* GL_SGIX_texture_scale_bias */ +#ifdef GL_SGIX_vertex_preclip + _glewInfo_GL_SGIX_vertex_preclip(); +#endif /* GL_SGIX_vertex_preclip */ +#ifdef GL_SGIX_vertex_preclip_hint + _glewInfo_GL_SGIX_vertex_preclip_hint(); +#endif /* GL_SGIX_vertex_preclip_hint */ +#ifdef GL_SGIX_ycrcb + _glewInfo_GL_SGIX_ycrcb(); +#endif /* GL_SGIX_ycrcb */ +#ifdef GL_SGI_color_matrix + _glewInfo_GL_SGI_color_matrix(); +#endif /* GL_SGI_color_matrix */ +#ifdef GL_SGI_color_table + _glewInfo_GL_SGI_color_table(); +#endif /* GL_SGI_color_table */ +#ifdef GL_SGI_texture_color_table + _glewInfo_GL_SGI_texture_color_table(); +#endif /* GL_SGI_texture_color_table */ +#ifdef GL_SUNX_constant_data + _glewInfo_GL_SUNX_constant_data(); +#endif /* GL_SUNX_constant_data */ +#ifdef GL_SUN_convolution_border_modes + _glewInfo_GL_SUN_convolution_border_modes(); +#endif /* GL_SUN_convolution_border_modes */ +#ifdef GL_SUN_global_alpha + _glewInfo_GL_SUN_global_alpha(); +#endif /* GL_SUN_global_alpha */ +#ifdef GL_SUN_mesh_array + _glewInfo_GL_SUN_mesh_array(); +#endif /* GL_SUN_mesh_array */ +#ifdef GL_SUN_read_video_pixels + _glewInfo_GL_SUN_read_video_pixels(); +#endif /* GL_SUN_read_video_pixels */ +#ifdef GL_SUN_slice_accum + _glewInfo_GL_SUN_slice_accum(); +#endif /* GL_SUN_slice_accum */ +#ifdef GL_SUN_triangle_list + _glewInfo_GL_SUN_triangle_list(); +#endif /* GL_SUN_triangle_list */ +#ifdef GL_SUN_vertex + _glewInfo_GL_SUN_vertex(); +#endif /* GL_SUN_vertex */ +#ifdef GL_WIN_phong_shading + _glewInfo_GL_WIN_phong_shading(); +#endif /* GL_WIN_phong_shading */ +#ifdef GL_WIN_specular_fog + _glewInfo_GL_WIN_specular_fog(); +#endif /* GL_WIN_specular_fog */ +#ifdef GL_WIN_swap_hint + _glewInfo_GL_WIN_swap_hint(); +#endif /* GL_WIN_swap_hint */ +} + +/* ------------------------------------------------------------------------ */ + +#ifdef _WIN32 + +static void wglewInfo () +{ +#ifdef WGL_3DFX_multisample + _glewInfo_WGL_3DFX_multisample(); +#endif /* WGL_3DFX_multisample */ +#ifdef WGL_3DL_stereo_control + _glewInfo_WGL_3DL_stereo_control(); +#endif /* WGL_3DL_stereo_control */ +#ifdef WGL_AMD_gpu_association + _glewInfo_WGL_AMD_gpu_association(); +#endif /* WGL_AMD_gpu_association */ +#ifdef WGL_ARB_buffer_region + _glewInfo_WGL_ARB_buffer_region(); +#endif /* WGL_ARB_buffer_region */ +#ifdef WGL_ARB_create_context + _glewInfo_WGL_ARB_create_context(); +#endif /* WGL_ARB_create_context */ +#ifdef WGL_ARB_create_context_profile + _glewInfo_WGL_ARB_create_context_profile(); +#endif /* WGL_ARB_create_context_profile */ +#ifdef WGL_ARB_extensions_string + _glewInfo_WGL_ARB_extensions_string(); +#endif /* WGL_ARB_extensions_string */ +#ifdef WGL_ARB_framebuffer_sRGB + _glewInfo_WGL_ARB_framebuffer_sRGB(); +#endif /* WGL_ARB_framebuffer_sRGB */ +#ifdef WGL_ARB_make_current_read + _glewInfo_WGL_ARB_make_current_read(); +#endif /* WGL_ARB_make_current_read */ +#ifdef WGL_ARB_multisample + _glewInfo_WGL_ARB_multisample(); +#endif /* WGL_ARB_multisample */ +#ifdef WGL_ARB_pbuffer + _glewInfo_WGL_ARB_pbuffer(); +#endif /* WGL_ARB_pbuffer */ +#ifdef WGL_ARB_pixel_format + _glewInfo_WGL_ARB_pixel_format(); +#endif /* WGL_ARB_pixel_format */ +#ifdef WGL_ARB_pixel_format_float + _glewInfo_WGL_ARB_pixel_format_float(); +#endif /* WGL_ARB_pixel_format_float */ +#ifdef WGL_ARB_render_texture + _glewInfo_WGL_ARB_render_texture(); +#endif /* WGL_ARB_render_texture */ +#ifdef WGL_ATI_pixel_format_float + _glewInfo_WGL_ATI_pixel_format_float(); +#endif /* WGL_ATI_pixel_format_float */ +#ifdef WGL_ATI_render_texture_rectangle + _glewInfo_WGL_ATI_render_texture_rectangle(); +#endif /* WGL_ATI_render_texture_rectangle */ +#ifdef WGL_EXT_depth_float + _glewInfo_WGL_EXT_depth_float(); +#endif /* WGL_EXT_depth_float */ +#ifdef WGL_EXT_display_color_table + _glewInfo_WGL_EXT_display_color_table(); +#endif /* WGL_EXT_display_color_table */ +#ifdef WGL_EXT_extensions_string + _glewInfo_WGL_EXT_extensions_string(); +#endif /* WGL_EXT_extensions_string */ +#ifdef WGL_EXT_framebuffer_sRGB + _glewInfo_WGL_EXT_framebuffer_sRGB(); +#endif /* WGL_EXT_framebuffer_sRGB */ +#ifdef WGL_EXT_make_current_read + _glewInfo_WGL_EXT_make_current_read(); +#endif /* WGL_EXT_make_current_read */ +#ifdef WGL_EXT_multisample + _glewInfo_WGL_EXT_multisample(); +#endif /* WGL_EXT_multisample */ +#ifdef WGL_EXT_pbuffer + _glewInfo_WGL_EXT_pbuffer(); +#endif /* WGL_EXT_pbuffer */ +#ifdef WGL_EXT_pixel_format + _glewInfo_WGL_EXT_pixel_format(); +#endif /* WGL_EXT_pixel_format */ +#ifdef WGL_EXT_pixel_format_packed_float + _glewInfo_WGL_EXT_pixel_format_packed_float(); +#endif /* WGL_EXT_pixel_format_packed_float */ +#ifdef WGL_EXT_swap_control + _glewInfo_WGL_EXT_swap_control(); +#endif /* WGL_EXT_swap_control */ +#ifdef WGL_I3D_digital_video_control + _glewInfo_WGL_I3D_digital_video_control(); +#endif /* WGL_I3D_digital_video_control */ +#ifdef WGL_I3D_gamma + _glewInfo_WGL_I3D_gamma(); +#endif /* WGL_I3D_gamma */ +#ifdef WGL_I3D_genlock + _glewInfo_WGL_I3D_genlock(); +#endif /* WGL_I3D_genlock */ +#ifdef WGL_I3D_image_buffer + _glewInfo_WGL_I3D_image_buffer(); +#endif /* WGL_I3D_image_buffer */ +#ifdef WGL_I3D_swap_frame_lock + _glewInfo_WGL_I3D_swap_frame_lock(); +#endif /* WGL_I3D_swap_frame_lock */ +#ifdef WGL_I3D_swap_frame_usage + _glewInfo_WGL_I3D_swap_frame_usage(); +#endif /* WGL_I3D_swap_frame_usage */ +#ifdef WGL_NV_copy_image + _glewInfo_WGL_NV_copy_image(); +#endif /* WGL_NV_copy_image */ +#ifdef WGL_NV_float_buffer + _glewInfo_WGL_NV_float_buffer(); +#endif /* WGL_NV_float_buffer */ +#ifdef WGL_NV_gpu_affinity + _glewInfo_WGL_NV_gpu_affinity(); +#endif /* WGL_NV_gpu_affinity */ +#ifdef WGL_NV_present_video + _glewInfo_WGL_NV_present_video(); +#endif /* WGL_NV_present_video */ +#ifdef WGL_NV_render_depth_texture + _glewInfo_WGL_NV_render_depth_texture(); +#endif /* WGL_NV_render_depth_texture */ +#ifdef WGL_NV_render_texture_rectangle + _glewInfo_WGL_NV_render_texture_rectangle(); +#endif /* WGL_NV_render_texture_rectangle */ +#ifdef WGL_NV_swap_group + _glewInfo_WGL_NV_swap_group(); +#endif /* WGL_NV_swap_group */ +#ifdef WGL_NV_vertex_array_range + _glewInfo_WGL_NV_vertex_array_range(); +#endif /* WGL_NV_vertex_array_range */ +#ifdef WGL_NV_video_output + _glewInfo_WGL_NV_video_output(); +#endif /* WGL_NV_video_output */ +#ifdef WGL_OML_sync_control + _glewInfo_WGL_OML_sync_control(); +#endif /* WGL_OML_sync_control */ +} + +#else /* _UNIX */ + +static void glxewInfo () +{ +#ifdef GLX_VERSION_1_2 + _glewInfo_GLX_VERSION_1_2(); +#endif /* GLX_VERSION_1_2 */ +#ifdef GLX_VERSION_1_3 + _glewInfo_GLX_VERSION_1_3(); +#endif /* GLX_VERSION_1_3 */ +#ifdef GLX_VERSION_1_4 + _glewInfo_GLX_VERSION_1_4(); +#endif /* GLX_VERSION_1_4 */ +#ifdef GLX_3DFX_multisample + _glewInfo_GLX_3DFX_multisample(); +#endif /* GLX_3DFX_multisample */ +#ifdef GLX_ARB_create_context + _glewInfo_GLX_ARB_create_context(); +#endif /* GLX_ARB_create_context */ +#ifdef GLX_ARB_create_context_profile + _glewInfo_GLX_ARB_create_context_profile(); +#endif /* GLX_ARB_create_context_profile */ +#ifdef GLX_ARB_fbconfig_float + _glewInfo_GLX_ARB_fbconfig_float(); +#endif /* GLX_ARB_fbconfig_float */ +#ifdef GLX_ARB_framebuffer_sRGB + _glewInfo_GLX_ARB_framebuffer_sRGB(); +#endif /* GLX_ARB_framebuffer_sRGB */ +#ifdef GLX_ARB_get_proc_address + _glewInfo_GLX_ARB_get_proc_address(); +#endif /* GLX_ARB_get_proc_address */ +#ifdef GLX_ARB_multisample + _glewInfo_GLX_ARB_multisample(); +#endif /* GLX_ARB_multisample */ +#ifdef GLX_ARB_vertex_buffer_object + _glewInfo_GLX_ARB_vertex_buffer_object(); +#endif /* GLX_ARB_vertex_buffer_object */ +#ifdef GLX_ATI_pixel_format_float + _glewInfo_GLX_ATI_pixel_format_float(); +#endif /* GLX_ATI_pixel_format_float */ +#ifdef GLX_ATI_render_texture + _glewInfo_GLX_ATI_render_texture(); +#endif /* GLX_ATI_render_texture */ +#ifdef GLX_EXT_fbconfig_packed_float + _glewInfo_GLX_EXT_fbconfig_packed_float(); +#endif /* GLX_EXT_fbconfig_packed_float */ +#ifdef GLX_EXT_framebuffer_sRGB + _glewInfo_GLX_EXT_framebuffer_sRGB(); +#endif /* GLX_EXT_framebuffer_sRGB */ +#ifdef GLX_EXT_import_context + _glewInfo_GLX_EXT_import_context(); +#endif /* GLX_EXT_import_context */ +#ifdef GLX_EXT_scene_marker + _glewInfo_GLX_EXT_scene_marker(); +#endif /* GLX_EXT_scene_marker */ +#ifdef GLX_EXT_swap_control + _glewInfo_GLX_EXT_swap_control(); +#endif /* GLX_EXT_swap_control */ +#ifdef GLX_EXT_texture_from_pixmap + _glewInfo_GLX_EXT_texture_from_pixmap(); +#endif /* GLX_EXT_texture_from_pixmap */ +#ifdef GLX_EXT_visual_info + _glewInfo_GLX_EXT_visual_info(); +#endif /* GLX_EXT_visual_info */ +#ifdef GLX_EXT_visual_rating + _glewInfo_GLX_EXT_visual_rating(); +#endif /* GLX_EXT_visual_rating */ +#ifdef GLX_INTEL_swap_event + _glewInfo_GLX_INTEL_swap_event(); +#endif /* GLX_INTEL_swap_event */ +#ifdef GLX_MESA_agp_offset + _glewInfo_GLX_MESA_agp_offset(); +#endif /* GLX_MESA_agp_offset */ +#ifdef GLX_MESA_copy_sub_buffer + _glewInfo_GLX_MESA_copy_sub_buffer(); +#endif /* GLX_MESA_copy_sub_buffer */ +#ifdef GLX_MESA_pixmap_colormap + _glewInfo_GLX_MESA_pixmap_colormap(); +#endif /* GLX_MESA_pixmap_colormap */ +#ifdef GLX_MESA_release_buffers + _glewInfo_GLX_MESA_release_buffers(); +#endif /* GLX_MESA_release_buffers */ +#ifdef GLX_MESA_set_3dfx_mode + _glewInfo_GLX_MESA_set_3dfx_mode(); +#endif /* GLX_MESA_set_3dfx_mode */ +#ifdef GLX_NV_copy_image + _glewInfo_GLX_NV_copy_image(); +#endif /* GLX_NV_copy_image */ +#ifdef GLX_NV_float_buffer + _glewInfo_GLX_NV_float_buffer(); +#endif /* GLX_NV_float_buffer */ +#ifdef GLX_NV_present_video + _glewInfo_GLX_NV_present_video(); +#endif /* GLX_NV_present_video */ +#ifdef GLX_NV_swap_group + _glewInfo_GLX_NV_swap_group(); +#endif /* GLX_NV_swap_group */ +#ifdef GLX_NV_vertex_array_range + _glewInfo_GLX_NV_vertex_array_range(); +#endif /* GLX_NV_vertex_array_range */ +#ifdef GLX_NV_video_output + _glewInfo_GLX_NV_video_output(); +#endif /* GLX_NV_video_output */ +#ifdef GLX_OML_swap_method + _glewInfo_GLX_OML_swap_method(); +#endif /* GLX_OML_swap_method */ +#if defined(GLX_OML_sync_control) && defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) +#include + _glewInfo_GLX_OML_sync_control(); +#endif /* GLX_OML_sync_control */ +#ifdef GLX_SGIS_blended_overlay + _glewInfo_GLX_SGIS_blended_overlay(); +#endif /* GLX_SGIS_blended_overlay */ +#ifdef GLX_SGIS_color_range + _glewInfo_GLX_SGIS_color_range(); +#endif /* GLX_SGIS_color_range */ +#ifdef GLX_SGIS_multisample + _glewInfo_GLX_SGIS_multisample(); +#endif /* GLX_SGIS_multisample */ +#ifdef GLX_SGIS_shared_multisample + _glewInfo_GLX_SGIS_shared_multisample(); +#endif /* GLX_SGIS_shared_multisample */ +#ifdef GLX_SGIX_fbconfig + _glewInfo_GLX_SGIX_fbconfig(); +#endif /* GLX_SGIX_fbconfig */ +#ifdef GLX_SGIX_hyperpipe + _glewInfo_GLX_SGIX_hyperpipe(); +#endif /* GLX_SGIX_hyperpipe */ +#ifdef GLX_SGIX_pbuffer + _glewInfo_GLX_SGIX_pbuffer(); +#endif /* GLX_SGIX_pbuffer */ +#ifdef GLX_SGIX_swap_barrier + _glewInfo_GLX_SGIX_swap_barrier(); +#endif /* GLX_SGIX_swap_barrier */ +#ifdef GLX_SGIX_swap_group + _glewInfo_GLX_SGIX_swap_group(); +#endif /* GLX_SGIX_swap_group */ +#ifdef GLX_SGIX_video_resize + _glewInfo_GLX_SGIX_video_resize(); +#endif /* GLX_SGIX_video_resize */ +#ifdef GLX_SGIX_visual_select_group + _glewInfo_GLX_SGIX_visual_select_group(); +#endif /* GLX_SGIX_visual_select_group */ +#ifdef GLX_SGI_cushion + _glewInfo_GLX_SGI_cushion(); +#endif /* GLX_SGI_cushion */ +#ifdef GLX_SGI_make_current_read + _glewInfo_GLX_SGI_make_current_read(); +#endif /* GLX_SGI_make_current_read */ +#ifdef GLX_SGI_swap_control + _glewInfo_GLX_SGI_swap_control(); +#endif /* GLX_SGI_swap_control */ +#ifdef GLX_SGI_video_sync + _glewInfo_GLX_SGI_video_sync(); +#endif /* GLX_SGI_video_sync */ +#ifdef GLX_SUN_get_transparent_index + _glewInfo_GLX_SUN_get_transparent_index(); +#endif /* GLX_SUN_get_transparent_index */ +#ifdef GLX_SUN_video_resize + _glewInfo_GLX_SUN_video_resize(); +#endif /* GLX_SUN_video_resize */ +} + +#endif /* _WIN32 */ + +/* ------------------------------------------------------------------------ */ + +#if defined(_WIN32) || !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +int main (int argc, char** argv) +#else +int main (void) +#endif +{ + GLuint err; + +#if defined(_WIN32) || !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + char* display = NULL; + int visual = -1; + + if (glewParseArgs(argc-1, argv+1, &display, &visual)) + { +#if defined(_WIN32) + fprintf(stderr, "Usage: glewinfo [-pf ]\n"); +#else + fprintf(stderr, "Usage: glewinfo [-display ] [-visual ]\n"); +#endif + return 1; + } +#endif + +#if defined(_WIN32) + if (GL_TRUE == glewCreateContext(&visual)) +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + if (GL_TRUE == glewCreateContext()) +#else + if (GL_TRUE == glewCreateContext(display, &visual)) +#endif + { + fprintf(stderr, "Error: glewCreateContext failed\n"); + glewDestroyContext(); + return 1; + } + glewExperimental = GL_TRUE; +#ifdef GLEW_MX + err = glewContextInit(glewGetContext()); +#ifdef _WIN32 + err = err || wglewContextInit(wglewGetContext()); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + err = err || glxewContextInit(glxewGetContext()); +#endif + +#else + err = glewInit(); +#endif + if (GLEW_OK != err) + { + fprintf(stderr, "Error [main]: glewInit failed: %s\n", glewGetErrorString(err)); + glewDestroyContext(); + return 1; + } +#if defined(_WIN32) + f = fopen("glewinfo.txt", "w"); + if (f == NULL) f = stdout; +#else + f = stdout; +#endif + fprintf(f, "---------------------------\n"); + fprintf(f, " GLEW Extension Info\n"); + fprintf(f, "---------------------------\n\n"); + fprintf(f, "GLEW version %s\n", glewGetString(GLEW_VERSION)); +#if defined(_WIN32) + fprintf(f, "Reporting capabilities of pixelformat %d\n", visual); +#elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + fprintf(f, "Reporting capabilities of display %s, visual 0x%x\n", + display == NULL ? getenv("DISPLAY") : display, visual); +#endif + fprintf(f, "Running on a %s from %s\n", + glGetString(GL_RENDERER), glGetString(GL_VENDOR)); + fprintf(f, "OpenGL version %s is supported\n", glGetString(GL_VERSION)); + glewInfo(); +#if defined(_WIN32) + wglewInfo(); +#else + glxewInfo(); +#endif + if (f != stdout) fclose(f); + glewDestroyContext(); + return 0; +} + +/* ------------------------------------------------------------------------ */ + +#if defined(_WIN32) || !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLboolean glewParseArgs (int argc, char** argv, char** display, int* visual) +{ + int p = 0; + while (p < argc) + { +#if defined(_WIN32) + if (!strcmp(argv[p], "-pf") || !strcmp(argv[p], "-pixelformat")) + { + if (++p >= argc) return GL_TRUE; + *display = 0; + *visual = strtol(argv[p++], NULL, 0); + } + else + return GL_TRUE; +#else + if (!strcmp(argv[p], "-display")) + { + if (++p >= argc) return GL_TRUE; + *display = argv[p++]; + } + else if (!strcmp(argv[p], "-visual")) + { + if (++p >= argc) return GL_TRUE; + *visual = (int)strtol(argv[p++], NULL, 0); + } + else + return GL_TRUE; +#endif + } + return GL_FALSE; +} +#endif + +/* ------------------------------------------------------------------------ */ + +#if defined(_WIN32) + +HWND wnd = NULL; +HDC dc = NULL; +HGLRC rc = NULL; + +GLboolean glewCreateContext (int* pixelformat) +{ + WNDCLASS wc; + PIXELFORMATDESCRIPTOR pfd; + /* register window class */ + ZeroMemory(&wc, sizeof(WNDCLASS)); + wc.hInstance = GetModuleHandle(NULL); + wc.lpfnWndProc = DefWindowProc; + wc.lpszClassName = "GLEW"; + if (0 == RegisterClass(&wc)) return GL_TRUE; + /* create window */ + wnd = CreateWindow("GLEW", "GLEW", 0, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, + CW_USEDEFAULT, NULL, NULL, GetModuleHandle(NULL), NULL); + if (NULL == wnd) return GL_TRUE; + /* get the device context */ + dc = GetDC(wnd); + if (NULL == dc) return GL_TRUE; + /* find pixel format */ + ZeroMemory(&pfd, sizeof(PIXELFORMATDESCRIPTOR)); + if (*pixelformat == -1) /* find default */ + { + pfd.nSize = sizeof(PIXELFORMATDESCRIPTOR); + pfd.nVersion = 1; + pfd.dwFlags = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL; + *pixelformat = ChoosePixelFormat(dc, &pfd); + if (*pixelformat == 0) return GL_TRUE; + } + /* set the pixel format for the dc */ + if (FALSE == SetPixelFormat(dc, *pixelformat, &pfd)) return GL_TRUE; + /* create rendering context */ + rc = wglCreateContext(dc); + if (NULL == rc) return GL_TRUE; + if (FALSE == wglMakeCurrent(dc, rc)) return GL_TRUE; + return GL_FALSE; +} + +void glewDestroyContext () +{ + if (NULL != rc) wglMakeCurrent(NULL, NULL); + if (NULL != rc) wglDeleteContext(rc); + if (NULL != wnd && NULL != dc) ReleaseDC(wnd, dc); + if (NULL != wnd) DestroyWindow(wnd); + UnregisterClass("GLEW", GetModuleHandle(NULL)); +} + +/* ------------------------------------------------------------------------ */ + +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + +#include + +AGLContext ctx, octx; + +GLboolean glewCreateContext () +{ + int attrib[] = { AGL_RGBA, AGL_NONE }; + AGLPixelFormat pf; + /*int major, minor; + SetPortWindowPort(wnd); + aglGetVersion(&major, &minor); + fprintf(stderr, "GL %d.%d\n", major, minor);*/ + pf = aglChoosePixelFormat(NULL, 0, attrib); + if (NULL == pf) return GL_TRUE; + ctx = aglCreateContext(pf, NULL); + if (NULL == ctx || AGL_NO_ERROR != aglGetError()) return GL_TRUE; + aglDestroyPixelFormat(pf); + /*aglSetDrawable(ctx, GetWindowPort(wnd));*/ + octx = aglGetCurrentContext(); + if (GL_FALSE == aglSetCurrentContext(ctx)) return GL_TRUE; + return GL_FALSE; +} + +void glewDestroyContext () +{ + aglSetCurrentContext(octx); + if (NULL != ctx) aglDestroyContext(ctx); +} + +/* ------------------------------------------------------------------------ */ + +#else /* __UNIX || (__APPLE__ && GLEW_APPLE_GLX) */ + +Display* dpy = NULL; +XVisualInfo* vi = NULL; +XVisualInfo* vis = NULL; +GLXContext ctx = NULL; +Window wnd = 0; +Colormap cmap = 0; + +GLboolean glewCreateContext (const char* display, int* visual) +{ + int attrib[] = { GLX_RGBA, GLX_DOUBLEBUFFER, None }; + int erb, evb; + XSetWindowAttributes swa; + /* open display */ + dpy = XOpenDisplay(display); + if (NULL == dpy) return GL_TRUE; + /* query for glx */ + if (!glXQueryExtension(dpy, &erb, &evb)) return GL_TRUE; + /* choose visual */ + if (*visual == -1) + { + vi = glXChooseVisual(dpy, DefaultScreen(dpy), attrib); + if (NULL == vi) return GL_TRUE; + *visual = (int)XVisualIDFromVisual(vi->visual); + } + else + { + int n_vis, i; + vis = XGetVisualInfo(dpy, 0, NULL, &n_vis); + for (i=0; iscreen), 0, 0, 1, 1, 1, 0, 0);*/ + cmap = XCreateColormap(dpy, RootWindow(dpy, vi->screen), vi->visual, AllocNone); + swa.border_pixel = 0; + swa.colormap = cmap; + wnd = XCreateWindow(dpy, RootWindow(dpy, vi->screen), + 0, 0, 1, 1, 0, vi->depth, InputOutput, vi->visual, + CWBorderPixel | CWColormap, &swa); + /* make context current */ + if (!glXMakeCurrent(dpy, wnd, ctx)) return GL_TRUE; + return GL_FALSE; +} + +void glewDestroyContext () +{ + if (NULL != dpy && NULL != ctx) glXDestroyContext(dpy, ctx); + if (NULL != dpy && 0 != wnd) XDestroyWindow(dpy, wnd); + if (NULL != dpy && 0 != cmap) XFreeColormap(dpy, cmap); + if (NULL != vis) + XFree(vis); + else if (NULL != vi) + XFree(vi); + if (NULL != dpy) XCloseDisplay(dpy); +} + +#endif /* __UNIX || (__APPLE__ && GLEW_APPLE_GLX) */ diff --git a/Externals/GLew/src/visualinfo.c b/Externals/GLew/src/visualinfo.c new file mode 100644 index 0000000000..f3ae91f2b4 --- /dev/null +++ b/Externals/GLew/src/visualinfo.c @@ -0,0 +1,1173 @@ +/* +** visualinfo.c +** +** Copyright (C) Nate Robins, 1997 +** Michael Wimmer, 1999 +** Milan Ikits, 2002-2008 +** +** visualinfo is a small utility that displays all available visuals, +** aka. pixelformats, in an OpenGL system along with renderer version +** information. It shows a table of all the visuals that support OpenGL +** along with their capabilities. The format of the table is similar to +** that of glxinfo on Unix systems: +** +** visual ~= pixel format descriptor +** id = visual id (integer from 1 - max visuals) +** tp = type (wn: window, pb: pbuffer, wp: window & pbuffer, bm: bitmap) +** ac = acceleration (ge: generic, fu: full, no: none) +** fm = format (i: integer, f: float, c: color index) +** db = double buffer (y = yes) +** sw = swap method (x: exchange, c: copy, u: undefined) +** st = stereo (y = yes) +** sz = total # bits +** r = # bits of red +** g = # bits of green +** b = # bits of blue +** a = # bits of alpha +** axbf = # aux buffers +** dpth = # bits of depth +** stcl = # bits of stencil +*/ + +#include +#include +#include +#include +#if defined(_WIN32) +#include +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) +#include +#else +#include +#endif + +#ifdef GLEW_MX +GLEWContext _glewctx; +# define glewGetContext() (&_glewctx) +# ifdef _WIN32 +WGLEWContext _wglewctx; +# define wglewGetContext() (&_wglewctx) +# elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) +GLXEWContext _glxewctx; +# define glxewGetContext() (&_glxewctx) +# endif +#endif /* GLEW_MX */ + +typedef struct GLContextStruct +{ +#ifdef _WIN32 + HWND wnd; + HDC dc; + HGLRC rc; +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + AGLContext ctx, octx; +#else + Display* dpy; + XVisualInfo* vi; + GLXContext ctx; + Window wnd; + Colormap cmap; +#endif +} GLContext; + +void InitContext (GLContext* ctx); +GLboolean CreateContext (GLContext* ctx); +void DestroyContext (GLContext* ctx); +void VisualInfo (GLContext* ctx); +void PrintExtensions (const char* s); +GLboolean ParseArgs (int argc, char** argv); + +int showall = 0; +int displaystdout = 0; +int verbose = 0; +int drawableonly = 0; + +char* display = NULL; +int visual = -1; + +FILE* file = 0; +GLContext ctx; + +int +main (int argc, char** argv) +{ + GLenum err; + + /* ---------------------------------------------------------------------- */ + /* parse arguments */ + if (GL_TRUE == ParseArgs(argc-1, argv+1)) + { +#if defined(_WIN32) + fprintf(stderr, "Usage: visualinfo [-a] [-s] [-h] [-pf ]\n"); + fprintf(stderr, " -a: show all visuals\n"); + fprintf(stderr, " -s: display to stdout instead of visualinfo.txt\n"); + fprintf(stderr, " -pf : use given pixelformat\n"); + fprintf(stderr, " -h: this screen\n"); +#else + fprintf(stderr, "Usage: visualinfo [-h] [-display ] [-visual ]\n"); + fprintf(stderr, " -h: this screen\n"); + fprintf(stderr, " -display : use given display\n"); + fprintf(stderr, " -visual : use given visual\n"); +#endif + return 1; + } + + /* ---------------------------------------------------------------------- */ + /* create OpenGL rendering context */ + InitContext(&ctx); + if (GL_TRUE == CreateContext(&ctx)) + { + fprintf(stderr, "Error: CreateContext failed\n"); + DestroyContext(&ctx); + return 1; + } + + /* ---------------------------------------------------------------------- */ + /* initialize GLEW */ + glewExperimental = GL_TRUE; +#ifdef GLEW_MX + err = glewContextInit(glewGetContext()); +# ifdef _WIN32 + err = err || wglewContextInit(wglewGetContext()); +# elif !defined(__APPLE__) || defined(GLEW_APPLE_GLX) + err = err || glxewContextInit(glxewGetContext()); +# endif +#else + err = glewInit(); +#endif + if (GLEW_OK != err) + { + fprintf(stderr, "Error [main]: glewInit failed: %s\n", glewGetErrorString(err)); + DestroyContext(&ctx); + return 1; + } + + /* ---------------------------------------------------------------------- */ + /* open file */ +#if defined(_WIN32) + if (!displaystdout) + file = fopen("visualinfo.txt", "w"); + if (file == NULL) + file = stdout; +#else + file = stdout; +#endif + + /* ---------------------------------------------------------------------- */ + /* output header information */ + /* OpenGL extensions */ + fprintf(file, "OpenGL vendor string: %s\n", glGetString(GL_VENDOR)); + fprintf(file, "OpenGL renderer string: %s\n", glGetString(GL_RENDERER)); + fprintf(file, "OpenGL version string: %s\n", glGetString(GL_VERSION)); + fprintf(file, "OpenGL extensions (GL_): \n"); + PrintExtensions((char*)glGetString(GL_EXTENSIONS)); + /* GLU extensions */ + fprintf(file, "GLU version string: %s\n", gluGetString(GLU_VERSION)); + fprintf(file, "GLU extensions (GLU_): \n"); + PrintExtensions((char*)gluGetString(GLU_EXTENSIONS)); + + /* ---------------------------------------------------------------------- */ + /* extensions string */ +#if defined(_WIN32) + /* WGL extensions */ + if (WGLEW_ARB_extensions_string || WGLEW_EXT_extensions_string) + { + fprintf(file, "WGL extensions (WGL_): \n"); + PrintExtensions(wglGetExtensionsStringARB ? + (char*)wglGetExtensionsStringARB(ctx.dc) : + (char*)wglGetExtensionsStringEXT()); + } +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + +#else + /* GLX extensions */ + fprintf(file, "GLX extensions (GLX_): \n"); + PrintExtensions(glXQueryExtensionsString(glXGetCurrentDisplay(), + DefaultScreen(glXGetCurrentDisplay()))); +#endif + + /* ---------------------------------------------------------------------- */ + /* enumerate all the formats */ + VisualInfo(&ctx); + + /* ---------------------------------------------------------------------- */ + /* release resources */ + DestroyContext(&ctx); + if (file != stdout) + fclose(file); + return 0; +} + +/* do the magic to separate all extensions with comma's, except + for the last one that _may_ terminate in a space. */ +void PrintExtensions (const char* s) +{ + char t[80]; + int i=0; + char* p=0; + + t[79] = '\0'; + while (*s) + { + t[i++] = *s; + if(*s == ' ') + { + if (*(s+1) != '\0') { + t[i-1] = ','; + t[i] = ' '; + p = &t[i++]; + } + else /* zoinks! last one terminated in a space! */ + { + t[i-1] = '\0'; + } + } + if(i > 80 - 5) + { + *p = t[i] = '\0'; + fprintf(file, " %s\n", t); + p++; + i = (int)strlen(p); + strcpy(t, p); + } + s++; + } + t[i] = '\0'; + fprintf(file, " %s.\n", t); +} + +/* ---------------------------------------------------------------------- */ + +#if defined(_WIN32) + +void +VisualInfoARB (GLContext* ctx) +{ + int attrib[32], value[32], n_attrib, n_pbuffer=0, n_float=0; + int i, pf, maxpf; + unsigned int c; + + /* to get pbuffer capable pixel formats */ + attrib[0] = WGL_DRAW_TO_PBUFFER_ARB; + attrib[1] = GL_TRUE; + attrib[2] = 0; + wglChoosePixelFormatARB(ctx->dc, attrib, 0, 1, &pf, &c); + /* query number of pixel formats */ + attrib[0] = WGL_NUMBER_PIXEL_FORMATS_ARB; + wglGetPixelFormatAttribivARB(ctx->dc, 0, 0, 1, attrib, value); + maxpf = value[0]; + for (i=0; i<32; i++) + value[i] = 0; + + attrib[0] = WGL_SUPPORT_OPENGL_ARB; + attrib[1] = WGL_DRAW_TO_WINDOW_ARB; + attrib[2] = WGL_DRAW_TO_BITMAP_ARB; + attrib[3] = WGL_ACCELERATION_ARB; + /* WGL_NO_ACCELERATION_ARB, WGL_GENERIC_ACCELERATION_ARB, WGL_FULL_ACCELERATION_ARB */ + attrib[4] = WGL_SWAP_METHOD_ARB; + /* WGL_SWAP_EXCHANGE_ARB, WGL_SWAP_COPY_ARB, WGL_SWAP_UNDEFINED_ARB */ + attrib[5] = WGL_DOUBLE_BUFFER_ARB; + attrib[6] = WGL_STEREO_ARB; + attrib[7] = WGL_PIXEL_TYPE_ARB; + /* WGL_TYPE_RGBA_ARB, WGL_TYPE_COLORINDEX_ARB, + WGL_TYPE_RGBA_FLOAT_ATI (WGL_ATI_pixel_format_float) */ + /* Color buffer information */ + attrib[8] = WGL_COLOR_BITS_ARB; + attrib[9] = WGL_RED_BITS_ARB; + attrib[10] = WGL_GREEN_BITS_ARB; + attrib[11] = WGL_BLUE_BITS_ARB; + attrib[12] = WGL_ALPHA_BITS_ARB; + /* Accumulation buffer information */ + attrib[13] = WGL_ACCUM_BITS_ARB; + attrib[14] = WGL_ACCUM_RED_BITS_ARB; + attrib[15] = WGL_ACCUM_GREEN_BITS_ARB; + attrib[16] = WGL_ACCUM_BLUE_BITS_ARB; + attrib[17] = WGL_ACCUM_ALPHA_BITS_ARB; + /* Depth, stencil, and aux buffer information */ + attrib[18] = WGL_DEPTH_BITS_ARB; + attrib[19] = WGL_STENCIL_BITS_ARB; + attrib[20] = WGL_AUX_BUFFERS_ARB; + /* Layer information */ + attrib[21] = WGL_NUMBER_OVERLAYS_ARB; + attrib[22] = WGL_NUMBER_UNDERLAYS_ARB; + attrib[23] = WGL_SWAP_LAYER_BUFFERS_ARB; + attrib[24] = WGL_SAMPLES_ARB; + attrib[25] = WGL_SUPPORT_GDI_ARB; + n_attrib = 26; + if (WGLEW_ARB_pbuffer) + { + attrib[n_attrib] = WGL_DRAW_TO_PBUFFER_ARB; + n_pbuffer = n_attrib; + n_attrib++; + } + if (WGLEW_NV_float_buffer) + { + attrib[n_attrib] = WGL_FLOAT_COMPONENTS_NV; + n_float = n_attrib; + n_attrib++; + } + + if (!verbose) + { + /* print table header */ + fprintf(file, " +-----+-------------------------+-----------------+----------+-----------------+----------+\n"); + fprintf(file, " | | visual | color | ax dp st | accum | layer |\n"); + fprintf(file, " | id | tp ac gd fm db sw st ms | sz r g b a | bf th cl | sz r g b a | ov un sw |\n"); + fprintf(file, " +-----+-------------------------+-----------------+----------+-----------------+----------+\n"); + /* loop through all the pixel formats */ + for(i = 1; i <= maxpf; i++) + { + wglGetPixelFormatAttribivARB(ctx->dc, i, 0, n_attrib, attrib, value); + /* only describe this format if it supports OpenGL */ + if (!value[0]) continue; + /* by default show only fully accelerated window or pbuffer capable visuals */ + if (!showall + && ((value[2] && !value[1]) + || (!WGLEW_ARB_pbuffer || !value[n_pbuffer]) + || (value[3] != WGL_FULL_ACCELERATION_ARB))) continue; + /* print out the information for this visual */ + /* visual id */ + fprintf(file, " |% 4d | ", i); + /* visual type */ + if (value[1]) + { + if (WGLEW_ARB_pbuffer && value[n_pbuffer]) fprintf(file, "wp "); + else fprintf(file, "wn "); + } + else + { + if (value[2]) fprintf(file, "bm "); + else if (WGLEW_ARB_pbuffer && value[n_pbuffer]) fprintf(file, "pb "); + } + /* acceleration */ + fprintf(file, "%s ", value[3] == WGL_FULL_ACCELERATION_ARB ? "fu" : + value[3] == WGL_GENERIC_ACCELERATION_ARB ? "ge" : + value[3] == WGL_NO_ACCELERATION_ARB ? "no" : ". "); + /* gdi support */ + fprintf(file, " %c ", value[25] ? 'y' : '.'); + /* format */ + if (WGLEW_NV_float_buffer && value[n_float]) fprintf(file, " f "); + else if (WGLEW_ATI_pixel_format_float && value[7] == WGL_TYPE_RGBA_FLOAT_ATI) fprintf(file, " f "); + else if (value[7] == WGL_TYPE_RGBA_ARB) fprintf(file, " i "); + else if (value[7] == WGL_TYPE_COLORINDEX_ARB) fprintf(file, " c "); + /* double buffer */ + fprintf(file, " %c ", value[5] ? 'y' : '.'); + /* swap method */ + if (value[4] == WGL_SWAP_EXCHANGE_ARB) fprintf(file, " x "); + else if (value[4] == WGL_SWAP_COPY_ARB) fprintf(file, " c "); + else if (value[4] == WGL_SWAP_UNDEFINED_ARB) fprintf(file, " . "); + else fprintf(file, " . "); + /* stereo */ + fprintf(file, " %c ", value[6] ? 'y' : '.'); + /* multisample */ + if (value[24] > 0) + fprintf(file, "%2d | ", value[24]); + else + fprintf(file, " . | "); + /* color size */ + if (value[8]) fprintf(file, "%3d ", value[8]); + else fprintf(file, " . "); + /* red */ + if (value[9]) fprintf(file, "%2d ", value[9]); + else fprintf(file, " . "); + /* green */ + if (value[10]) fprintf(file, "%2d ", value[10]); + else fprintf(file, " . "); + /* blue */ + if (value[11]) fprintf(file, "%2d ", value[11]); + else fprintf(file, " . "); + /* alpha */ + if (value[12]) fprintf(file, "%2d | ", value[12]); + else fprintf(file, " . | "); + /* aux buffers */ + if (value[20]) fprintf(file, "%2d ", value[20]); + else fprintf(file, " . "); + /* depth */ + if (value[18]) fprintf(file, "%2d ", value[18]); + else fprintf(file, " . "); + /* stencil */ + if (value[19]) fprintf(file, "%2d | ", value[19]); + else fprintf(file, " . | "); + /* accum size */ + if (value[13]) fprintf(file, "%3d ", value[13]); + else fprintf(file, " . "); + /* accum red */ + if (value[14]) fprintf(file, "%2d ", value[14]); + else fprintf(file, " . "); + /* accum green */ + if (value[15]) fprintf(file, "%2d ", value[15]); + else fprintf(file, " . "); + /* accum blue */ + if (value[16]) fprintf(file, "%2d ", value[16]); + else fprintf(file, " . "); + /* accum alpha */ + if (value[17]) fprintf(file, "%2d | ", value[17]); + else fprintf(file, " . | "); + /* overlay */ + if (value[21]) fprintf(file, "%2d ", value[21]); + else fprintf(file, " . "); + /* underlay */ + if (value[22]) fprintf(file, "%2d ", value[22]); + else fprintf(file, " . "); + /* layer swap */ + if (value[23]) fprintf(file, "y "); + else fprintf(file, " . "); + fprintf(file, "|\n"); + } + /* print table footer */ + fprintf(file, " +-----+-------------------------+-----------------+----------+-----------------+----------+\n"); + fprintf(file, " | | visual | color | ax dp st | accum | layer |\n"); + fprintf(file, " | id | tp ac gd fm db sw st ms | sz r g b a | bf th cl | sz r g b a | ov un sw |\n"); + fprintf(file, " +-----+-------------------------+-----------------+----------+-----------------+----------+\n"); + } + else /* verbose */ + { +#if 0 + fprintf(file, "\n"); + /* loop through all the pixel formats */ + for(i = 1; i <= maxpf; i++) + { + DescribePixelFormat(ctx->dc, i, sizeof(PIXELFORMATDESCRIPTOR), &pfd); + /* only describe this format if it supports OpenGL */ + if(!(pfd.dwFlags & PFD_SUPPORT_OPENGL) + || (drawableonly && !(pfd.dwFlags & PFD_DRAW_TO_WINDOW))) continue; + fprintf(file, "Visual ID: %2d depth=%d class=%s\n", i, pfd.cDepthBits, + pfd.cColorBits <= 8 ? "PseudoColor" : "TrueColor"); + fprintf(file, " bufferSize=%d level=%d renderType=%s doubleBuffer=%d stereo=%d\n", pfd.cColorBits, pfd.bReserved, pfd.iPixelType == PFD_TYPE_RGBA ? "rgba" : "ci", pfd.dwFlags & PFD_DOUBLEBUFFER, pfd.dwFlags & PFD_STEREO); + fprintf(file, " generic=%d generic accelerated=%d\n", (pfd.dwFlags & PFD_GENERIC_FORMAT) == PFD_GENERIC_FORMAT, (pfd.dwFlags & PFD_GENERIC_ACCELERATED) == PFD_GENERIC_ACCELERATED); + fprintf(file, " rgba: redSize=%d greenSize=%d blueSize=%d alphaSize=%d\n", pfd.cRedBits, pfd.cGreenBits, pfd.cBlueBits, pfd.cAlphaBits); + fprintf(file, " auxBuffers=%d depthSize=%d stencilSize=%d\n", pfd.cAuxBuffers, pfd.cDepthBits, pfd.cStencilBits); + fprintf(file, " accum: redSize=%d greenSize=%d blueSize=%d alphaSize=%d\n", pfd.cAccumRedBits, pfd.cAccumGreenBits, pfd.cAccumBlueBits, pfd.cAccumAlphaBits); + fprintf(file, " multiSample=%d multisampleBuffers=%d\n", 0, 0); + fprintf(file, " Opaque.\n"); + } +#endif + } +} + +void +VisualInfoGDI (GLContext* ctx) +{ + int i, maxpf; + PIXELFORMATDESCRIPTOR pfd; + + /* calling DescribePixelFormat() with NULL pfd (!!!) return maximum + number of pixel formats */ + maxpf = DescribePixelFormat(ctx->dc, 1, 0, NULL); + + if (!verbose) + { + fprintf(file, "-----------------------------------------------------------------------------\n"); + fprintf(file, " visual x bf lv rg d st ge ge r g b a ax dp st accum buffs ms \n"); + fprintf(file, " id dep tp sp sz l ci b ro ne ac sz sz sz sz bf th cl sz r g b a ns b\n"); + fprintf(file, "-----------------------------------------------------------------------------\n"); + + /* loop through all the pixel formats */ + for(i = 1; i <= maxpf; i++) + { + DescribePixelFormat(ctx->dc, i, sizeof(PIXELFORMATDESCRIPTOR), &pfd); + /* only describe this format if it supports OpenGL */ + if(!(pfd.dwFlags & PFD_SUPPORT_OPENGL) + || (drawableonly && (pfd.dwFlags & PFD_DRAW_TO_BITMAP))) continue; + /* other criteria could be tested here for actual pixel format + choosing in an application: + + for (...each pixel format...) { + if (pfd.dwFlags & PFD_SUPPORT_OPENGL && + pfd.dwFlags & PFD_DOUBLEBUFFER && + pfd.cDepthBits >= 24 && + pfd.cColorBits >= 24) + { + goto found; + } + } + ... not found so exit ... + found: + ... found so use it ... + */ + /* print out the information for this pixel format */ + fprintf(file, "0x%02x ", i); + fprintf(file, "%3d ", pfd.cColorBits); + if(pfd.dwFlags & PFD_DRAW_TO_WINDOW) fprintf(file, "wn "); + else if(pfd.dwFlags & PFD_DRAW_TO_BITMAP) fprintf(file, "bm "); + else fprintf(file, "pb "); + /* should find transparent pixel from LAYERPLANEDESCRIPTOR */ + fprintf(file, " . "); + fprintf(file, "%3d ", pfd.cColorBits); + /* bReserved field indicates number of over/underlays */ + if(pfd.bReserved) fprintf(file, " %d ", pfd.bReserved); + else fprintf(file, " . "); + fprintf(file, " %c ", pfd.iPixelType == PFD_TYPE_RGBA ? 'r' : 'c'); + fprintf(file, "%c ", pfd.dwFlags & PFD_DOUBLEBUFFER ? 'y' : '.'); + fprintf(file, " %c ", pfd.dwFlags & PFD_STEREO ? 'y' : '.'); + /* added: */ + fprintf(file, " %c ", pfd.dwFlags & PFD_GENERIC_FORMAT ? 'y' : '.'); + fprintf(file, " %c ", pfd.dwFlags & PFD_GENERIC_ACCELERATED ? 'y' : '.'); + if(pfd.cRedBits && pfd.iPixelType == PFD_TYPE_RGBA) + fprintf(file, "%2d ", pfd.cRedBits); + else fprintf(file, " . "); + if(pfd.cGreenBits && pfd.iPixelType == PFD_TYPE_RGBA) + fprintf(file, "%2d ", pfd.cGreenBits); + else fprintf(file, " . "); + if(pfd.cBlueBits && pfd.iPixelType == PFD_TYPE_RGBA) + fprintf(file, "%2d ", pfd.cBlueBits); + else fprintf(file, " . "); + if(pfd.cAlphaBits && pfd.iPixelType == PFD_TYPE_RGBA) + fprintf(file, "%2d ", pfd.cAlphaBits); + else fprintf(file, " . "); + if(pfd.cAuxBuffers) fprintf(file, "%2d ", pfd.cAuxBuffers); + else fprintf(file, " . "); + if(pfd.cDepthBits) fprintf(file, "%2d ", pfd.cDepthBits); + else fprintf(file, " . "); + if(pfd.cStencilBits) fprintf(file, "%2d ", pfd.cStencilBits); + else fprintf(file, " . "); + if(pfd.cAccumBits) fprintf(file, "%3d ", pfd.cAccumBits); + else fprintf(file, " . "); + if(pfd.cAccumRedBits) fprintf(file, "%2d ", pfd.cAccumRedBits); + else fprintf(file, " . "); + if(pfd.cAccumGreenBits) fprintf(file, "%2d ", pfd.cAccumGreenBits); + else fprintf(file, " . "); + if(pfd.cAccumBlueBits) fprintf(file, "%2d ", pfd.cAccumBlueBits); + else fprintf(file, " . "); + if(pfd.cAccumAlphaBits) fprintf(file, "%2d ", pfd.cAccumAlphaBits); + else fprintf(file, " . "); + /* no multisample in win32 */ + fprintf(file, " . .\n"); + } + /* print table footer */ + fprintf(file, "-----------------------------------------------------------------------------\n"); + fprintf(file, " visual x bf lv rg d st ge ge r g b a ax dp st accum buffs ms \n"); + fprintf(file, " id dep tp sp sz l ci b ro ne ac sz sz sz sz bf th cl sz r g b a ns b\n"); + fprintf(file, "-----------------------------------------------------------------------------\n"); + } + else /* verbose */ + { + fprintf(file, "\n"); + /* loop through all the pixel formats */ + for(i = 1; i <= maxpf; i++) + { + DescribePixelFormat(ctx->dc, i, sizeof(PIXELFORMATDESCRIPTOR), &pfd); + /* only describe this format if it supports OpenGL */ + if(!(pfd.dwFlags & PFD_SUPPORT_OPENGL) + || (drawableonly && !(pfd.dwFlags & PFD_DRAW_TO_WINDOW))) continue; + fprintf(file, "Visual ID: %2d depth=%d class=%s\n", i, pfd.cDepthBits, + pfd.cColorBits <= 8 ? "PseudoColor" : "TrueColor"); + fprintf(file, " bufferSize=%d level=%d renderType=%s doubleBuffer=%ld stereo=%ld\n", pfd.cColorBits, pfd.bReserved, pfd.iPixelType == PFD_TYPE_RGBA ? "rgba" : "ci", pfd.dwFlags & PFD_DOUBLEBUFFER, pfd.dwFlags & PFD_STEREO); + fprintf(file, " generic=%d generic accelerated=%d\n", (pfd.dwFlags & PFD_GENERIC_FORMAT) == PFD_GENERIC_FORMAT, (pfd.dwFlags & PFD_GENERIC_ACCELERATED) == PFD_GENERIC_ACCELERATED); + fprintf(file, " rgba: redSize=%d greenSize=%d blueSize=%d alphaSize=%d\n", pfd.cRedBits, pfd.cGreenBits, pfd.cBlueBits, pfd.cAlphaBits); + fprintf(file, " auxBuffers=%d depthSize=%d stencilSize=%d\n", pfd.cAuxBuffers, pfd.cDepthBits, pfd.cStencilBits); + fprintf(file, " accum: redSize=%d greenSize=%d blueSize=%d alphaSize=%d\n", pfd.cAccumRedBits, pfd.cAccumGreenBits, pfd.cAccumBlueBits, pfd.cAccumAlphaBits); + fprintf(file, " multiSample=%d multisampleBuffers=%d\n", 0, 0); + fprintf(file, " Opaque.\n"); + } + } +} + +void +VisualInfo (GLContext* ctx) +{ + if (WGLEW_ARB_pixel_format) + VisualInfoARB(ctx); + else + VisualInfoGDI(ctx); +} + +/* ---------------------------------------------------------------------- */ + +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + +void +VisualInfo (GLContext* ctx) +{ +/* + int attrib[] = { AGL_RGBA, AGL_NONE }; + AGLPixelFormat pf; + GLint value; + pf = aglChoosePixelFormat(NULL, 0, attrib); + while (pf != NULL) + { + aglDescribePixelFormat(pf, GL_RGBA, &value); + fprintf(stderr, "%d\n", value); + pf = aglNextPixelFormat(pf); + } +*/ +} + +#else /* GLX */ + +void +VisualInfo (GLContext* ctx) +{ + int n_fbc; + GLXFBConfig* fbc; + int value, ret, i; + + fbc = glXGetFBConfigs(ctx->dpy, DefaultScreen(ctx->dpy), &n_fbc); + + if (fbc) + { + if (!verbose) + { + /* print table header */ + fprintf(file, " +-----+-------------------------+-----------------+----------+-------------+-------+------+\n"); + fprintf(file, " | | visual | color | ax dp st | accum | ms | cav |\n"); + fprintf(file, " | id | tp xr cl fm db st lv xp | sz r g b a | bf th cl | r g b a | ns b | eat |\n"); + fprintf(file, " +-----+-------------------------+-----------------+----------+-------------+-------+------+\n"); + /* loop through all the fbcs */ + for (i=0; idpy, fbc[i], GLX_FBCONFIG_ID, &value); + if (ret != Success) + { + fprintf(file, "| ? |"); + } + else + { + fprintf(file, " |% 4d | ", value); + } + /* visual type */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_DRAWABLE_TYPE, &value); + if (ret != Success) + { + fprintf(file, " ? "); + } + else + { + if (value & GLX_WINDOW_BIT) + { + if (value & GLX_PBUFFER_BIT) + { + fprintf(file, "wp "); + } + else + { + fprintf(file, "wn "); + } + } + else + { + if (value & GLX_PBUFFER_BIT) + { + fprintf(file, "pb "); + } + else if (value & GLX_PIXMAP_BIT) + { + fprintf(file, "pm "); + } + else + { + fprintf(file, " ? "); + } + } + } + /* x renderable */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_X_RENDERABLE, &value); + if (ret != Success) + { + fprintf(file, " ? "); + } + else + { + fprintf(file, value ? " y " : " n "); + } + /* class */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_X_VISUAL_TYPE, &value); + if (ret != Success) + { + fprintf(file, " ? "); + } + else + { + if (GLX_TRUE_COLOR == value) + fprintf(file, "tc "); + else if (GLX_DIRECT_COLOR == value) + fprintf(file, "dc "); + else if (GLX_PSEUDO_COLOR == value) + fprintf(file, "pc "); + else if (GLX_STATIC_COLOR == value) + fprintf(file, "sc "); + else if (GLX_GRAY_SCALE == value) + fprintf(file, "gs "); + else if (GLX_STATIC_GRAY == value) + fprintf(file, "sg "); + else if (GLX_X_VISUAL_TYPE == value) + fprintf(file, " . "); + else + fprintf(file, " ? "); + } + /* format */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_RENDER_TYPE, &value); + if (ret != Success) + { + fprintf(file, " ? "); + } + else + { + if (GLXEW_NV_float_buffer) + { + int ret2, value2; + ret2 = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_FLOAT_COMPONENTS_NV, &value2); + if (Success == ret2 && GL_TRUE == value2) + { + fprintf(file, " f "); + } + else if (value & GLX_RGBA_BIT) + fprintf(file, " i "); + else if (value & GLX_COLOR_INDEX_BIT) + fprintf(file, " c "); + else + fprintf(file, " ? "); + } + else + { + if (value & GLX_RGBA_FLOAT_ATI_BIT) + fprintf(file, " f "); + else if (value & GLX_RGBA_BIT) + fprintf(file, " i "); + else if (value & GLX_COLOR_INDEX_BIT) + fprintf(file, " c "); + else + fprintf(file, " ? "); + } + } + /* double buffer */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_DOUBLEBUFFER, &value); + fprintf(file, " %c ", Success != ret ? '?' : (value ? 'y' : '.')); + /* stereo */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_STEREO, &value); + fprintf(file, " %c ", Success != ret ? '?' : (value ? 'y' : '.')); + /* level */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_LEVEL, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + fprintf(file, "%2d ", value); + } + /* transparency */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_TRANSPARENT_TYPE, &value); + if (Success != ret) + { + fprintf(file, " ? | "); + } + else + { + if (GLX_TRANSPARENT_RGB == value) + fprintf(file, " r | "); + else if (GLX_TRANSPARENT_INDEX == value) + fprintf(file, " i | "); + else if (GLX_NONE == value) + fprintf(file, " . | "); + else + fprintf(file, " ? | "); + } + /* color size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_BUFFER_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%3d ", value); + else + fprintf(file, " . "); + } + /* red size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_RED_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* green size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_GREEN_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* blue size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_BLUE_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* alpha size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_ALPHA_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? | "); + } + else + { + if (value) + fprintf(file, "%2d | ", value); + else + fprintf(file, " . | "); + } + /* aux buffers */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_AUX_BUFFERS, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* depth size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_DEPTH_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* stencil size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_STENCIL_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? | "); + } + else + { + if (value) + fprintf(file, "%2d | ", value); + else + fprintf(file, " . | "); + } + /* accum red size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_ACCUM_RED_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* accum green size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_ACCUM_GREEN_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* accum blue size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_ACCUM_BLUE_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + if (value) + fprintf(file, "%2d ", value); + else + fprintf(file, " . "); + } + /* accum alpha size */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_ACCUM_ALPHA_SIZE, &value); + if (Success != ret) + { + fprintf(file, " ? | "); + } + else + { + if (value) + fprintf(file, "%2d | ", value); + else + fprintf(file, " . | "); + } + /* multisample */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_SAMPLES, &value); + if (Success != ret) + { + fprintf(file, " ? "); + } + else + { + fprintf(file, "%2d ", value); + } + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_SAMPLE_BUFFERS, &value); + if (Success != ret) + { + fprintf(file, " ? | "); + } + else + { + fprintf(file, "%2d | ", value); + } + /* caveat */ + ret = glXGetFBConfigAttrib(ctx->dpy, fbc[i], GLX_CONFIG_CAVEAT, &value); + if (Success != ret) + { + fprintf(file, "???? |"); + } + else + { + if (GLX_NONE == value) + fprintf(file, "none |\n"); + else if (GLX_SLOW_CONFIG == value) + fprintf(file, "slow |\n"); + else if (GLX_NON_CONFORMANT_CONFIG == value) + fprintf(file, "ncft |\n"); + else + fprintf(file, "???? |\n"); + } + } + /* print table footer */ + fprintf(file, " +-----+-------------------------+-----------------+----------+-------------+-------+------+\n"); + fprintf(file, " | id | tp xr cl fm db st lv xp | sz r g b a | bf th cl | r g b a | ns b | eat |\n"); + fprintf(file, " | | visual | color | ax dp st | accum | ms | cav |\n"); + fprintf(file, " +-----+-------------------------+-----------------+----------+-------------+-------+------+\n"); + } + } +} + +#endif + +/* ------------------------------------------------------------------------ */ + +#if defined(_WIN32) + +void InitContext (GLContext* ctx) +{ + ctx->wnd = NULL; + ctx->dc = NULL; + ctx->rc = NULL; +} + +GLboolean CreateContext (GLContext* ctx) +{ + WNDCLASS wc; + PIXELFORMATDESCRIPTOR pfd; + /* check for input */ + if (NULL == ctx) return GL_TRUE; + /* register window class */ + ZeroMemory(&wc, sizeof(WNDCLASS)); + wc.hInstance = GetModuleHandle(NULL); + wc.lpfnWndProc = DefWindowProc; + wc.lpszClassName = "GLEW"; + if (0 == RegisterClass(&wc)) return GL_TRUE; + /* create window */ + ctx->wnd = CreateWindow("GLEW", "GLEW", 0, CW_USEDEFAULT, CW_USEDEFAULT, + CW_USEDEFAULT, CW_USEDEFAULT, NULL, NULL, + GetModuleHandle(NULL), NULL); + if (NULL == ctx->wnd) return GL_TRUE; + /* get the device context */ + ctx->dc = GetDC(ctx->wnd); + if (NULL == ctx->dc) return GL_TRUE; + /* find pixel format */ + ZeroMemory(&pfd, sizeof(PIXELFORMATDESCRIPTOR)); + if (visual == -1) /* find default */ + { + pfd.nSize = sizeof(PIXELFORMATDESCRIPTOR); + pfd.nVersion = 1; + pfd.dwFlags = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL; + visual = ChoosePixelFormat(ctx->dc, &pfd); + if (0 == visual) return GL_TRUE; + } + /* set the pixel format for the dc */ + if (FALSE == SetPixelFormat(ctx->dc, visual, &pfd)) return GL_TRUE; + /* create rendering context */ + ctx->rc = wglCreateContext(ctx->dc); + if (NULL == ctx->rc) return GL_TRUE; + if (FALSE == wglMakeCurrent(ctx->dc, ctx->rc)) return GL_TRUE; + return GL_FALSE; +} + +void DestroyContext (GLContext* ctx) +{ + if (NULL == ctx) return; + if (NULL != ctx->rc) wglMakeCurrent(NULL, NULL); + if (NULL != ctx->rc) wglDeleteContext(wglGetCurrentContext()); + if (NULL != ctx->wnd && NULL != ctx->dc) ReleaseDC(ctx->wnd, ctx->dc); + if (NULL != ctx->wnd) DestroyWindow(ctx->wnd); + UnregisterClass("GLEW", GetModuleHandle(NULL)); +} + +/* ------------------------------------------------------------------------ */ + +#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) + +void InitContext (GLContext* ctx) +{ + ctx->ctx = NULL; + ctx->octx = NULL; +} + +GLboolean CreateContext (GLContext* ctx) +{ + int attrib[] = { AGL_RGBA, AGL_NONE }; + AGLPixelFormat pf; + /* check input */ + if (NULL == ctx) return GL_TRUE; + /*int major, minor; + SetPortWindowPort(wnd); + aglGetVersion(&major, &minor); + fprintf(stderr, "GL %d.%d\n", major, minor);*/ + pf = aglChoosePixelFormat(NULL, 0, attrib); + if (NULL == pf) return GL_TRUE; + ctx->ctx = aglCreateContext(pf, NULL); + if (NULL == ctx->ctx || AGL_NO_ERROR != aglGetError()) return GL_TRUE; + aglDestroyPixelFormat(pf); + /*aglSetDrawable(ctx, GetWindowPort(wnd));*/ + ctx->octx = aglGetCurrentContext(); + if (GL_FALSE == aglSetCurrentContext(ctx->ctx)) return GL_TRUE; + return GL_FALSE; +} + +void DestroyContext (GLContext* ctx) +{ + if (NULL == ctx) return; + aglSetCurrentContext(ctx->octx); + if (NULL != ctx->ctx) aglDestroyContext(ctx->ctx); +} + +/* ------------------------------------------------------------------------ */ + +#else /* __UNIX || (__APPLE__ && GLEW_APPLE_GLX) */ + +void InitContext (GLContext* ctx) +{ + ctx->dpy = NULL; + ctx->vi = NULL; + ctx->ctx = NULL; + ctx->wnd = 0; + ctx->cmap = 0; +} + +GLboolean CreateContext (GLContext* ctx) +{ + int attrib[] = { GLX_RGBA, GLX_DOUBLEBUFFER, None }; + int erb, evb; + XSetWindowAttributes swa; + /* check input */ + if (NULL == ctx) return GL_TRUE; + /* open display */ + ctx->dpy = XOpenDisplay(display); + if (NULL == ctx->dpy) return GL_TRUE; + /* query for glx */ + if (!glXQueryExtension(ctx->dpy, &erb, &evb)) return GL_TRUE; + /* choose visual */ + ctx->vi = glXChooseVisual(ctx->dpy, DefaultScreen(ctx->dpy), attrib); + if (NULL == ctx->vi) return GL_TRUE; + /* create context */ + ctx->ctx = glXCreateContext(ctx->dpy, ctx->vi, None, True); + if (NULL == ctx->ctx) return GL_TRUE; + /* create window */ + /*wnd = XCreateSimpleWindow(dpy, RootWindow(dpy, vi->screen), 0, 0, 1, 1, 1, 0, 0);*/ + ctx->cmap = XCreateColormap(ctx->dpy, RootWindow(ctx->dpy, ctx->vi->screen), + ctx->vi->visual, AllocNone); + swa.border_pixel = 0; + swa.colormap = ctx->cmap; + ctx->wnd = XCreateWindow(ctx->dpy, RootWindow(ctx->dpy, ctx->vi->screen), + 0, 0, 1, 1, 0, ctx->vi->depth, InputOutput, ctx->vi->visual, + CWBorderPixel | CWColormap, &swa); + /* make context current */ + if (!glXMakeCurrent(ctx->dpy, ctx->wnd, ctx->ctx)) return GL_TRUE; + return GL_FALSE; +} + +void DestroyContext (GLContext* ctx) +{ + if (NULL != ctx->dpy && NULL != ctx->ctx) glXDestroyContext(ctx->dpy, ctx->ctx); + if (NULL != ctx->dpy && 0 != ctx->wnd) XDestroyWindow(ctx->dpy, ctx->wnd); + if (NULL != ctx->dpy && 0 != ctx->cmap) XFreeColormap(ctx->dpy, ctx->cmap); + if (NULL != ctx->vi) XFree(ctx->vi); + if (NULL != ctx->dpy) XCloseDisplay(ctx->dpy); +} + +#endif /* __UNIX || (__APPLE__ && GLEW_APPLE_GLX) */ + +GLboolean ParseArgs (int argc, char** argv) +{ + int p = 0; + while (p < argc) + { +#if defined(_WIN32) + if (!strcmp(argv[p], "-pf") || !strcmp(argv[p], "-pixelformat")) + { + if (++p >= argc) return GL_TRUE; + display = NULL; + visual = strtol(argv[p], NULL, 0); + } + else if (!strcmp(argv[p], "-a")) + { + showall = 1; + } + else if (!strcmp(argv[p], "-s")) + { + displaystdout = 1; + } + else if (!strcmp(argv[p], "-h")) + { + return GL_TRUE; + } + else + return GL_TRUE; +#else + if (!strcmp(argv[p], "-display")) + { + if (++p >= argc) return GL_TRUE; + display = argv[p]; + } + else if (!strcmp(argv[p], "-visual")) + { + if (++p >= argc) return GL_TRUE; + visual = (int)strtol(argv[p], NULL, 0); + } + else if (!strcmp(argv[p], "-h")) + { + return GL_TRUE; + } + else + return GL_TRUE; +#endif + p++; + } + return GL_FALSE; +} diff --git a/Externals/SDL/BUGS b/Externals/SDL/BUGS new file mode 100644 index 0000000000..218bf3d15b --- /dev/null +++ b/Externals/SDL/BUGS @@ -0,0 +1,18 @@ + +Bugs are now managed in the SDL bug tracker, here: + + http://bugzilla.libsdl.org/ + +You may report bugs there, and search to see if a given issue has already + been reported, discussed, and maybe even fixed. + + + +You may also find help at the SDL mailing list. Subscription information: + + http://lists.libsdl.org/listinfo.cgi/sdl-libsdl.org + +Bug reports are welcome here, but we really appreciate if you use Bugzilla, as + bugs discussed on the mailing list may be forgotten or missed. + + diff --git a/Externals/SDL/Borland.html b/Externals/SDL/Borland.html new file mode 100644 index 0000000000..eaf82099d6 --- /dev/null +++ b/Externals/SDL/Borland.html @@ -0,0 +1,139 @@ + + + + Building SDL with Borland's C++ compilers + + + + + +

Building SDL with Borland's C++ compilers.

+ by David Snopek + and updated by Dominique + Louis ( Last updated : 30th June 2003 ).
+
+ These instructions cover how to compile SDL and its included test +programs using either Borland C++ Builder 5, 6 for Windows, + C++ Builder for Linux ( AKA Kylix 3 ) or the free Borland C++ command-line compiler.
+ +

Extract the files

+ +

Unzip the Borland.zip archive into this directory. Do not unzip + it into any other directory because the makefiles ( *.mak ) and project + files ( *.bpr ) use relative paths to refer to the SDL sources. This should + create a directory named "Borland" inside of the top level SDL source directory. +

+ +

Using Borland C++ Builder 5, 6 for Windows +

+ +

Inside of the "Borland" directory there is a "bcb6" directory that contains + a number of Builder project files. Double-click on the "libSDL.bpg" file + icon. Once Builder has started click on the "Projects" menu on +the menu-bar and go down to "Build All Projects" option.
+ This will proceed to build SDL ( with Borland's calling convention ), +SDLmain, and all the test programs. Currently, all +the test programs are dynamically linked to Sam Lantinga's +SDL.dll.

+ +

NOTE : Borland's "lib" format and Microsoft's "lib" format are incompatible. + 
+ If you wish to dynamically link to the SDL library supplied by Sam Lantinga + in each release, I have created the correct *.libs for SDL 1.2.4 and they + exist in the "/lib" directory.
+ If you would like to create the *.lib files yourself, you will need to +make use of Borland's "implib.exe" utility.
+

+ +

IMPLIB works like this:

+ +
    IMPLIB (destination lib name) (source dll)
+ +

For example,

+ +
    IMPLIB SDL.lib SDL.dll
+ +

This assumes that SDL.dll was compiled with Visual C++ or similar.
+

+ +

To learn more about the difference between Borland's and Microsoft's *.lib + format please read the article here.
+

+ +


+ NOTE :
The C++ Builder for Windows project format, is not compatible + with the Kylix 3 project format, hence the reason why they are in separate + directories.

+ +

Using the free Borland C++ command-line compiler +

+ +

The free Borland compiler can be downloaded at no charge from the Borland website + . Make sure that it is installed and properly configured.

+ +

Open an MS-DOS Prompt. Change to the "Borland\freebcc" directory under + the SDL source directory. Type "make -f SDL.mak" to build SDL and "make + -f SDLmain.mak". There are also makefiles for all of the test programs, if you wish to build them. All .exes and +DLLs are created in the "test" SDL directory. Ify ou would like to create +the DLL and all the test applications, I have thrown together a basic batchfile +called "makeall.bat" which should create everything in the right order.

+ +

Output files

+ No matter which compiler you used, three important files should have + been produced: +
    +
  • SDL.dll ( Borland format )
  • +
  • SDL.lib ( Borland format )
  • +
  • SDLmain.lib ( Borland format )
  • + +
+ Both of the *.lib files will need to be added to all the projects +that use SDL and SDL.dll must be placed some where the Windows dynamic +linker can find it (either in your project directory or on the system +path, C:\WINDOWS\SYSTEM). +

Using Borland C++ Builder for Linux ( AKA Kylix + 3 )

+ +

Inside of the "Borland" directory there is a "k3" directory that contains + a number of Builder project files. Double-click on the "libSDL.bpg" file + icon. Once Builder has started click on the "Projects" menu on +the menu-bar and go down to "Build All Projects" option. This will +proceed to build all the test programs
+ Linux users do not need *.lib files as the Shared Object is linked right + into the project ( very neat actually, Windows should do this sort of thing + as it is a lot easier for the developer ).
+ NOTE : The C++ Builder for Windows project format, is not + compatible with the Kylix 3 project format, hence the reason why they are + in separate directories.

+ +

On Mandrake 8.1 the shared objects for SDL are located in the /usr/lib + directory as libSDL_*.so and the Mesa OpenGL shared objects are located +in /usr/X11R6/lib as libGL*.so
+
+ So if your setup is different you may need to change the project file + so that they re-link to the ones on your system.
+
+ On Mandrake 8.1 the headers files are located at /usr/include/SDL/. + So if you you have not installed the development RPMs ( usually named libSDL-devel* + ) for SDL ( not included ) you may have to change the include directory + within some of the projects.
+

+ +

Known Problems

+ The only known problem is that I ( Dominique Louis ), was unable to +create the projects that rebuilt the SDL shared objects under Linux, due +to time constraints and my lack of intimate knowledge of Linux. +

Test programs

+ Some of the test programs require included media files ( *.wav; *.bmp +etc ). All the test programs are now created in the "test" directory, where +the media files are ( usually ) so they should be ready to go.
+
+
+
+ + diff --git a/Externals/SDL/Borland.zip b/Externals/SDL/Borland.zip new file mode 100644 index 0000000000000000000000000000000000000000..ed8f45d27e7c83640a90aa121f4e35b0a2c23179 GIT binary patch literal 157899 zcmd43Wl$X4wzZ491cDRX-2()N5L|-0JHb7;yEX3a!QI{6-CcrvklVcZvhAF`@BOoH zeN;^fit4V}RM&dum}`udl>mo;19|(hmtLd)>xcjI4G{z#M9|9io35n+gPy+LM+QX& zSP<}3GZ4PFQgns@fdn%Ekp(^;4fqHc5J`j++PSTZa#`SS2EfAn*T?IAGc~ldqt~-G z`sd!MNhE*bY5h6f3p}uTBN2LVY#ZfELLJf7ShvrPvIkAfrEs!xmsqcE# zb`x(?J?xBH$4qrXs>(x~@`pF(WikC=T%-hOJejv;IE^u6zYlKvduR16i}b47ljESAQ&7247}D#rorcNdTv9KH=pXU@uH zRr2^zwH=Z8J>UH5yS?}Fn^L3+x;i!AYsEIcy!&`Q89+)E-gP)w!OkH-YEKdwaC|71 zz6y6HJ+XdKY3RNgWYeV6EEicNrK3QH&$<4>s?pxNQ2 zNgZE`^Jz(kk77C}iS-!q

c<#GU>tm0hsb8O{p}z-WGGT1(@64N2XN4Mg+--0 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 lXR7#JH$MNL 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 WSSbhU5l(^sgja) + diff --git a/Externals/SDL/CWprojects.sea.bin b/Externals/SDL/CWprojects.sea.bin new file mode 100644 index 0000000000000000000000000000000000000000..e8a6fdc29adb13e34bd0818d018486e47f614968 GIT binary patch literal 476160 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 y-o0yg5IXbcKoCWeB$Y5^L4!mGqUK^r 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Ⓢ?@oUv&qs?u~ zsY-3a+6qBI+OuKL<7e32@WSyC#y)zdCZiPC;-f{?1_jnx1fJQYz9%wRmiQhMP1&R1 zv&}pP1)Wc3O%V8Q>&4UlR%zsvj!n!)>o^}|Fmp=+&+fFxIMLO_A%7Fv^l%;sP2nk< z+%y*)=RB;(=g%)93B?&Y?S`?&c2^nT)0BfGqU$78)sVluQojHbb|>0$q7Q*z44-3v zAW>bOmQ^ihWWYyB`e5}z7+ zq;>`6zrcdIG19#4A^b`gt%>=UJ)Fcb8BbU#N31RK5PA4EGf2Ju|Bp(g39JVpMuXa8C9#y5_?f5cnWUos?g{3=4|woi&kWX%M1xN; z)61#z1aY$vJ3_-m0zgf!>E?lM$9ZPNu;T*!9s^j6_IMENxhHI?X_~eJ6m0C_!!F0U z>os_WEwm6VqitPU0L_TsXgQ^#RW(O+)>kqyVHO`C0BVi~tt5;-EMRTsgqRNW^Q0T? zv=R&T69Bj!eV;St@R0c7^4PphsBzUrbn5Em03^8pdE-QGm`&tcOzIzJo6X!>ZeXpG zhvtQ5U9YMMB;r|0vj9vY---C^-*@}`up}UxPHb;P88>~YGZx3K6MQsHM!bjKu~$)a z8}rdEva^c))RaBS9goKY&W9r`SgB`XSxT$S{iJ+ z4IenmiM481X{|Yyse)dhs-si^1oAJr=D9eT0kffLyGqz-of|sT<}>Ip7d&)!qLJlvP|m4$WW%l{}?x6*`<_~LC6 zkOWwXo7Ms`XQ5sVY;~ z3j~Tg20#Oc;7iwfCW5!1oK(}Z*)ZJeMu%{M3o2KGc57n5OpYm*A>m8^p?4t9A9GC! zq^coqP-zS&4p0H3o+$2Ee_>on1;6ki#Al%pR=Y833cq>Jq`f1D`pQcD*+6-M(4WrLvN{ z@&!DBp6~J2x5fzRZJH=j)4;{RJ+hm%&QbbqAFT`vi|0N$_C0>;9sqAHT@SF|7?OSt* z(fSiHl*pBywOpcHik5z*7p9Vu)O9IxwlYa(&#hxJZMh<0`145=_HnV_VvXQuEX!4h z3SDQntVE5Vq3jbV%`h%TtYYy9Z)%V$Wxk(yL&+<7ZTgyKU^hnHu4NHZ7N_)t1fh8PmQ>J7srS@HG1t70H0L? z?nv*cBe$2=hxqca9fq=_HSx^3c2S(Sc$Ol8*BeIP>H6V13!hrO5;I720}n605D4l=W=#DPBjrn^K8()rZqoy6XEdqF`b?IPRDri zyAr(Goo*kaf!>oI?@dxsgX4nMs(94}xD`FnJsR4w(QXKqzUMFxn(#&+(oJ9OmY9sm zHJ}}1tOxtce&fW>x1lt)r z4l)7+9aaIT!zqL6&unkkxCOAdTbK@XKv(tw3W#$`0&G@-1i}=YlesmT4M}-05^%oS zBdo491a3uXn1_BycEgFH8%k{M8+sgU*jT3G``7o~OA*TYY%C>0>f$Y_=sCm=-sqn~ zwyu;#dHWL!SHJ@9s4k0`5KB{$_MRFHJK*9w9kOn>ScOnqOMvco#oj$8&*_`pRbdVh zHd~^o$&#C^Ps%Nm%Y z7hHgNqg+-RDDY*EhMcgs1@6XBx*&aqIl81slO`bYy+@(CkPEifS$~|_WO*yni8@0Y z`wR1@0v@~L?u_bsr0o&X-%sU-j}e1J?A&BX`Qjy>kc*J3<*I0_6P{LazhYd+{ej&r zjueF&nH8dGH+vPEUB^GaH=1aaba5u^%Y%v&Y)UK7W%8;h<%9L02^^g5w(DrFJ-#;PFJ~Wj=`zZ%8LPLx! zPW~wesa3M{kCR7!GgKI<#CpE_@QN@|`^PInOwg}a1mhLv47WyLx4E{@QQ#^`tXVnZuxy_WK4^^JlL{{4p^YBNqA`+@l;~CkMy(O zM7w;HYho_fqx^lwPk3V997_0z`s`tMzeYm7uO1s{B?7L*25cML>N%lDzu+nJDXIPtY>+VS+{Rvxrp9lcG z==D2-l!;*+ti?Jx}wa6867!|nZl!0j+e?Xmw|;db~x;r6os z&v5(he-5|9{0XN~;)mPht6>Ro%k!zgMXQ*c$%1bx&?Sc`Ny1O@lWPxHPL%daq zYY9l2?!s}(liGKU_ygxct`*_BMz)=3*IMXbd%0ccOac9Dq10eXO;qX=2GA&ByCt6b zrEJ4@ug&Kvp8;4HkOf8SAoPhO6EPA`{EIKa#i`ir7Kw*1D<$F^j0}&Ffs&rt_rBEiO6%NRFPqbc-&k+y>1bnayL^Y$!|5`vT*#O97^A&zzIYrEIc=EV z&m)gil`(~ORD#KE3Owh%!9PGGEtP8u=+h>IaE1nc`69tOa#3j9u6{&nBQhtAH0JF+ z%k#`o{DaqhPGExUo+IcDc{#@c$c7EGR1PHveAr=D!Nd|I4L3`Awt|Xy$>3hZLpYT8 z2_sKicw|)Pu1@UL#tFyJ*(g(@cP`H4c_tF+ILAkGKD;pj^u<7qQ_|U}Jdox&z^TJB zjvxiyAvni8r&ylZMGITh8}MY4jB!)_rpqITpWeXTMtc|8u4_}(QY9W zOTzGAIqIf2J+4*F?#c{CBk#s1sHha~+iJdqF?h6dj%xe_Oj1M??#AI3hOZGc#VS~L zWpI`nv2v%*-)@~$Mil9=;PD;@D)VKGE9!vA1%1uhMOV%FR!%Rovd-(AarQiS)BGE_ zzyi#aN6N}NcFZGQ9VDV-Rt-`5Osd7bDNMG^M79}=jg4E@{*?}Hvz_zf{d6UA_&^;Jm`4uZm(oi)!2Jro@b6*2h?&IwM$0(Ybg zX{wh$sanS3Uo08$rFpsneor`90ewq=Q+;2jxyB))`gjBgcqLDKUVZfgOfsg&bu=Zc zS0D7nG5V`G2;vxsgwu(^cxO6viIRiUwFu7w#~QHYPuS!L5W8PQ!h3J7I^qV$mq zPxavV0sj1r3rrx6<@Htr@ghythIYIC7Mn2Ie_=*gE8qVJ9|(RKU!r)NZ`dLiHs&j_QdUWZ;P zn)zo{dGdeojF1GeV_X8wD6NlN`q|jwQ=LyP2_?rO>pq9R=tcP!6v-W%_C;y|K}xcd z#V^LQ9d$d{5%Z|f2O}ZZ2mMSg6C*!8{GHmXrWYIC%@u8wrqO=?tQryTRtW{bn$hR$ z7iEccGZm@tj1n(KF2D}~jDeP<`cmcU^SQEsF-Qs{sCn`;9L{@q9G&=Fk)nu6#8pfO z!fkm97%_hCP91EqlJLy86+XP)pBS*QcRRrPKE)}Aa+`CLt72GAPu>fHOf-}b@g{4PRkaPx8BU|Iwt%JKuzUswy79Th0a>x^2eUzXe}a2D@qKxgGv3s#@`Oa7I>mL0NP{G!fh=^(VQ_J5WDGzdEFbDd z?m$}Lf(vJs3rO4?_N|gnZ*55d6|JhUJ|GT@`ju-lGLva3eV8maNhIFt=BqvFiqBYb z9r{n>N#eYaKC|Ku4kBLKl#jLHYzVz7V8leFgV@3c($mat8fK{heJ6}!4Jci(hxC8~ z)MG`YVQgQ6l3XAFtk%A=nis}wp=J`tLm;KGEAARE#+d)uGUE83T1GHj|1T^fwY&J! zCyfL2`Uo@$vE04Z=Q&n)be;!vfImzlmA{)tsz3ZRjlB4GrV$$xS_HAyZF}`9C72%2 z&REClXJ&MS4)|HC(?U{Lm26C4v6rDA?4{4Hiw^(?qf^PYh!+K5z+#5ZdAwFgOM}Tx z#hhp2RnNX6;+SHk!K(F*7Kt4ApNK{XGbkFq9@;4a%>0$WJ!gaxzE1m48{l&=e=qZq zIKPUhmfVT^iB)-m@XMLAHv!6(G#=~0$QDJdpHm1!p&Te+2M>=6$Upx$^+r3OGV!=V)nk&b+9U3{p^MV^x}xEJP7 ze_QxDP{g!oJD8}?;Md61L6~v3cv<900k_-aq2_Tk)kxGb<4s_wY8BLK{RDzsPOEL` z({GIkFx{DXKi7>q+wlkzY^DhYO#on>!KF0SvN$;$X2m~nH8j*+0q$UiHK01f1Erz^|#+X}lNL_3Rg}p|wNe54`+U<7J@(xAb3)L9X`aoQnwDR^ijSK<1=BV9Ch z|1{bxpef8!LQS>MJD~OzTt8)i9Ly#6``P6IavaWCYS~dV`hJl05$iCAMj-=cS{G8n zVg@W%m8gn7cgi3GV{3RB4tVs;k(#Ek{!uL*9yS(q6 zOX|2&UB3r=p3WfEr(jP>;Y?E4eXlIT`*_2y4|sbdIESkVr17*~uCuBG5WI-0l@Pp$ z7dLEr{=^iA{!|K8sw=6qVO8gcUYE8O%i`3aQDlLH+1Ipe2(>&Sl)6oFq!a_9upQdg z8ypp$bX1yvI?NxWAI2o^8%EjI0(zWwW@5q1gxHS33Y@jhSDGE8CPa9YF!uVa9H#S> z9SA|s;=qho!I=0Bfi)xvJ{aJ6;2s370jvwMS6rdfi1fVL?v|++!xmf(J}`l=ikY7G z(YUF?b#5>UXf}C|PH~A06r-ERlXQmx5OUJvQx)M1%PsGKD${HGa=f1wi@tWOD7*n* zTa)#^Gg;H!diOC5*R-#-;#mYxswoY@NU9rQs z*pM$U(mTS#ukJAHiUSY*__mw#e0j>7gh3VwmeGP`*i=Onoaq+{VI0T787L;plo#}5 z44aSpC1CA3e*`g4CSVUEJbVx*Q&Frtgbt=Vt$!IzS)JvmK79Y^)|RaEz;&;}?wpQF zL_)dlnOCvseJM|Jdq^P5#Ms!wiOU;>N!F7hJdc;XiQQ zZ1sO~-3G%@uG>v%zUz0c8_nY<*X^dB&Nb6W8uAC%jaa|a6fw08<+^>pKXBc7zjNL3 z|B~x|8ICW?{nn71 z-Ua2l(b5h(gXmD;4?q6oy5U$OM8Y4qZm=hm>uxRhXRf^U!gVt}aNQ}&h5sj9_x4}7Zo|KD-30F*xbDaQTU_@**nf@d z9ti!D>$dz?Tz4c&#;QH3T0M0@yNC+1bg>9>!bOyMr22Hh!rYZl=I3O}dO@p?-=Z+; z*Lo};dFx0e9KN|y>b~%#D?Rqd8kwOD^Cf!0E9p2_K)Dg6kIV7sQcyL4&=;$SW}t;& z>16;O`-fY<$DjV68=DjPUc-J(;KD%1Iz7aFozt)&Z|G+JkX(5oEMQ;C-n8!39?vWlLAa61@Azo|-y=KRH7EPIChy2L;qm$i@Sm2eBB3c%A%spPYyT$ct5Twn-w@jjQfrfHD4)r<2 z+=8})2%(Y^xOtXZ#457tWj#Up#u#!eR)e>5L_Z}Zi%2A@ZyzKjX~j@U$#Np}bnpK_ zQo@S5*73WfBxGnY;XzV@D1Y)xQeys7QeqqZASt0u_(M|SCJ)He(PwijQk?4I;K=x1 zeI*B%(kZZh6cw@CMKl#_3)oxVg;R^Pl0A3VZ}l@2VKky@`zDPc#V(k|iJ9|Vgv*hR zXIkXK7I1enR>C1)<1$dP0t?^KK$45a#5!x;osB5god%{M&*H=G5DiAdcpvTd_Uk$z zdJ_l5q>L|3N^EUY!%XASk7AXpG_92%&@^r+EzMf+8U+s<*vz8$0++RL{JuNftiR!< z4^ZK*|9xK7`_c%(h>{~OZb4&VA+^sDC!EB=N}EH*LqRYeb2Cx(*#uO==;1`kG89CT;SMeZPNX^$N#W}K0 zgq~*xM>i@N{cXe@cXIeO;@~G-YONVQx3h}nC|x$s>&1ZTp5uf+IM9z{t_Z9B zp(afJ^5>R&{`;02^>fReJ^H6DH?DB1Vfb25&7J)?XuLWoRSg{v&(=FDXIAV@X_anA zp>2H0QdHHK9QeyYcmXQdFxVaEizwjr!Em+Ud;eMi?jVnzcWcTtG_8T$Oi+7yC~A=n zR+^*vV1U+htYjd02*bwr1_cU05y#t4I;Vgl({DWhw)Gm--fXYB|7gvPgZ4+#gIBC-m&BgXp<)-a|M7b77I|Ws@p8OZH#i zO2@^|lXJphHN8zh#G|Bu8C$TBr$hGV0L0Z9X+kRAb2%fHrz7Ri+dm~PvhvM<#YU*e zb9*p660hE4&lDle`fFsKTs`(kmDYClSY zk{l;KrV?NhPoj*T1EOp~tOm7yiNewz=?{DklluFJXYtn&PxX+L$C4!&oeS}Be#eXn znb5RpBBY+iCUuJx89*zP2kheLX&@4bLnJS&w1YGmOWJ-KxqUHpkU=;kG8xBb%RQCyTaWLX9yyWZU?RkQOc|qe9kfc5e3_YjpHE+Q#o|jJ&WZ_}b zL(w3cZ+V#XM4^*j$6qGBbU2M)lisx;ZdJ>73Qpt;@#lkpgs7Hdh?Xxp0S^AUPsb<; zJDRjZSm4n#5iELRQex^CdxjtOa{)L81>mxMGpD_s!Dy*XLFjv2i))7J4C@Sxz$Upa zM>VR@k~A=}J) zh<>?}B0yN7|5DiIm7?4OtEYC;j<;H@@@D$Jid0muFXHL91C|gj-E|yyi;+~rmNR(C z8?eg)S+IHgGsrI(AE+z12bv< zlod~IN-YDq20-42&TKkLJ~D8o?aC9_n2m)ql--RGu2T%~w|sx**HuUjWHZC1D|!iM zWD5L@+f00NLxibXiNid_hs=}$u?WEcGegiAL`HZ

=x)UQ4y(keajUVO>BRvZk1Q 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

&(4QFZA-&V842F>p^twF>+ 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 BMYaF{ literal 0 HcmV?d00001 diff --git a/Externals/SDL/INSTALL b/Externals/SDL/INSTALL new file mode 100644 index 0000000000..1a30fba008 --- /dev/null +++ b/Externals/SDL/INSTALL @@ -0,0 +1,23 @@ + +To compile and install SDL: + + 1. Run './configure; make; make install' + + If you are compiling for Windows using gcc, read the FAQ at: + http://www.libsdl.org/faq.php?action=listentries&category=4#42 + + If you are compiling using Visual C++ on Win32, you should read + the file VisualC.html + + 2. Look at the example programs in ./test, and check out the HTML + documentation in ./docs to see how to use the SDL library. + + 3. Join the SDL developer mailing list by sending E-mail to + sdl-request@libsdl.org + and put "subscribe" in the subject of the message. + + Or alternatively you can use the web interface: + http://www.libsdl.org/mailing-list.php + +That's it! +Sam Lantinga diff --git a/Externals/SDL/MPWmake.sea.bin b/Externals/SDL/MPWmake.sea.bin new file mode 100644 index 0000000000000000000000000000000000000000..b345e086651a4648752459f8ca4fb2009d817cbf GIT binary patch literal 22144 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 Ti1F@^C5*3O!V?ZhhKc?QZkous literal 0 HcmV?d00001 diff --git a/Externals/SDL/Makefile.dc b/Externals/SDL/Makefile.dc new file mode 100644 index 0000000000..58d6e712df --- /dev/null +++ b/Externals/SDL/Makefile.dc @@ -0,0 +1,111 @@ +#GL=1 + +CC = sh-elf-gcc +AR = sh-elf-ar + +ifdef GL +DEFS += -DSDL_VIDEO_OPENGL=1 +TARGET = libSDL_gl.a +else +TARGET = libSDL.a +endif + +CFLAGS=$(KOS_CFLAGS) $(DEFS) -Iinclude + +SRCS = \ + src/audio/dc/SDL_dcaudio.c \ + src/audio/dc/aica.c \ + src/audio/dummy/SDL_dummyaudio.c \ + src/audio/SDL_audio.c \ + src/audio/SDL_audiocvt.c \ + src/audio/SDL_audiodev.c \ + src/audio/SDL_mixer.c \ + src/audio/SDL_wave.c \ + src/cdrom/dc/SDL_syscdrom.c \ + src/cdrom/SDL_cdrom.c \ + src/events/SDL_active.c \ + src/events/SDL_events.c \ + src/events/SDL_expose.c \ + src/events/SDL_keyboard.c \ + src/events/SDL_mouse.c \ + src/events/SDL_quit.c \ + src/events/SDL_resize.c \ + src/file/SDL_rwops.c \ + src/joystick/dc/SDL_sysjoystick.c \ + src/joystick/SDL_joystick.c \ + src/loadso/dummy/SDL_sysloadso.c \ + src/SDL.c \ + src/SDL_error.c \ + src/SDL_fatal.c \ + src/stdlib/SDL_getenv.c \ + src/stdlib/SDL_iconv.c \ + src/stdlib/SDL_malloc.c \ + src/stdlib/SDL_qsort.c \ + src/stdlib/SDL_stdlib.c \ + src/stdlib/SDL_string.c \ + src/thread/dc/SDL_syscond.c \ + src/thread/dc/SDL_sysmutex.c \ + src/thread/dc/SDL_syssem.c \ + src/thread/dc/SDL_systhread.c \ + src/thread/SDL_thread.c \ + src/timer/dc/SDL_systimer.c \ + src/timer/SDL_timer.c \ + src/video/dc/SDL_dcevents.c \ + src/video/dc/SDL_dcvideo.c \ + src/video/dummy/SDL_nullevents.c \ + src/video/dummy/SDL_nullmouse.c \ + src/video/dummy/SDL_nullvideo.c \ + src/video/SDL_blit.c \ + src/video/SDL_blit_0.c \ + src/video/SDL_blit_1.c \ + src/video/SDL_blit_A.c \ + src/video/SDL_blit_N.c \ + src/video/SDL_bmp.c \ + src/video/SDL_cursor.c \ + src/video/SDL_gamma.c \ + src/video/SDL_pixels.c \ + src/video/SDL_RLEaccel.c \ + src/video/SDL_stretch.c \ + src/video/SDL_surface.c \ + src/video/SDL_video.c \ + src/video/SDL_yuv.c \ + src/video/SDL_yuv_sw.c \ + +OBJS = $(SRCS:.c=.o) + +TEST = \ + test/checkkeys.c \ + test/graywin.c \ + test/loopwave.c \ + test/testalpha.c \ + test/testbitmap.c \ + test/testcdrom.c \ + test/testerror.c \ + test/testgamma.c \ + test/testgl.c \ + test/testhread.c \ + test/testjoystick.c \ + test/testkeys.c \ + test/testlock.c \ + test/testoverlay.c \ + test/testpalette.c \ + test/testsem.c \ + test/testsprite.c \ + test/testtimer.c \ + test/testtypes.c \ + test/testver.c \ + test/testvidinfo.c \ + test/testwin.c \ + test/testwm.c \ + test/threadwin.c \ + test/torturethread.c \ + +$(TARGET): copy_config \ + $(OBJS) + $(AR) rcs $(TARGET) $(OBJS) + +copy_config: + @cp include/SDL_config.h.default include/SDL_config.h + +clean: + rm -f include/SDL_config.h $(OBJS) diff --git a/Externals/SDL/Makefile.in b/Externals/SDL/Makefile.in new file mode 100644 index 0000000000..e29dc6db48 --- /dev/null +++ b/Externals/SDL/Makefile.in @@ -0,0 +1,183 @@ +# Makefile to build and install the SDL library + +top_builddir = . +srcdir = @srcdir@ +objects = build +depend = build-deps +prefix = @prefix@ +exec_prefix = @exec_prefix@ +bindir = @bindir@ +libdir = @libdir@ +includedir = @includedir@ +datarootdir = @datarootdir@ +datadir = @datadir@ +mandir = @mandir@ +auxdir = @ac_aux_dir@ +distpath = $(srcdir)/.. +distdir = SDL-@SDL_VERSION@ +distfile = $(distdir).tar.gz + +@SET_MAKE@ +SHELL = @SHELL@ +CC = @CC@ +INCLUDE = @INCLUDE@ +CFLAGS = @BUILD_CFLAGS@ +EXTRA_CFLAGS = @EXTRA_CFLAGS@ +LDFLAGS = @BUILD_LDFLAGS@ +EXTRA_LDFLAGS = @EXTRA_LDFLAGS@ +LIBTOOL = @LIBTOOL@ +INSTALL = @INSTALL@ +NASM = @NASM@ @NASMFLAGS@ +AR = @AR@ +RANLIB = @RANLIB@ +WINDRES = @WINDRES@ + +TARGET = libSDL.la +SOURCES = @SOURCES@ +OBJECTS = @OBJECTS@ + +SDLMAIN_TARGET = libSDLmain.a +SDLMAIN_SOURCES = @SDLMAIN_SOURCES@ +SDLMAIN_OBJECTS = @SDLMAIN_OBJECTS@ + +DIST = acinclude autogen.sh Borland.html Borland.zip BUGS build-scripts configure configure.in COPYING CREDITS CWprojects.sea.bin docs docs.html include INSTALL Makefile.dc Makefile.minimal Makefile.in MPWmake.sea.bin README* sdl-config.in sdl.m4 sdl.pc.in SDL.qpg.in SDL.spec SDL.spec.in src test TODO VisualCE.zip VisualC.html VisualC.zip Watcom-OS2.zip Watcom-Win32.zip symbian.zip WhatsNew Xcode.tar.gz + +HDRS = SDL.h SDL_active.h SDL_audio.h SDL_byteorder.h SDL_cdrom.h SDL_cpuinfo.h SDL_endian.h SDL_error.h SDL_events.h SDL_getenv.h SDL_joystick.h SDL_keyboard.h SDL_keysym.h SDL_loadso.h SDL_main.h SDL_mouse.h SDL_mutex.h SDL_name.h SDL_opengl.h SDL_platform.h SDL_quit.h SDL_rwops.h SDL_stdinc.h SDL_syswm.h SDL_thread.h SDL_timer.h SDL_types.h SDL_version.h SDL_video.h begin_code.h close_code.h + +LT_AGE = @LT_AGE@ +LT_CURRENT = @LT_CURRENT@ +LT_RELEASE = @LT_RELEASE@ +LT_REVISION = @LT_REVISION@ +LT_LDFLAGS = -no-undefined -rpath $(DESTDIR)$(libdir) -release $(LT_RELEASE) -version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE) + +all: $(srcdir)/configure Makefile $(objects) $(objects)/$(TARGET) $(objects)/$(SDLMAIN_TARGET) + +$(srcdir)/configure: $(srcdir)/configure.in + @echo "Warning, configure.in is out of date" + #(cd $(srcdir) && sh autogen.sh && sh configure) + @sleep 3 + +Makefile: $(srcdir)/Makefile.in + $(SHELL) config.status $@ + +$(objects): + $(SHELL) $(auxdir)/mkinstalldirs $@ + +.PHONY: all depend install install-bin install-hdrs install-lib install-data install-man uninstall uninstall-bin uninstall-hdrs uninstall-lib uninstall-data uninstall-man clean distclean dist +depend: + @SOURCES="$(SOURCES)" INCLUDE="$(INCLUDE)" output="$(depend)" \ + $(SHELL) $(auxdir)/makedep.sh + @for src in $(SDLMAIN_SOURCES); do \ + obj=`echo $$src | sed -e 's|.*/||' -e 's|\.[^\.]*$$|.o|'`; \ + echo "\$$(objects)/$$obj: $$src" >>$(depend); \ + echo " \$$(CC) \$$(CFLAGS) \$$(EXTRA_CFLAGS) -c $$src -o \$$@" >>$(depend); \ + done + +include $(depend) + +$(objects)/$(TARGET): $(OBJECTS) + $(LIBTOOL) --mode=link $(CC) -o $@ $(OBJECTS) $(LDFLAGS) $(EXTRA_LDFLAGS) $(LT_LDFLAGS) + +$(objects)/$(SDLMAIN_TARGET): $(SDLMAIN_OBJECTS) + $(AR) cru $@ $(SDLMAIN_OBJECTS) + $(RANLIB) $@ + +install: all install-bin install-hdrs install-lib install-data install-man +install-bin: + $(SHELL) $(auxdir)/mkinstalldirs $(DESTDIR)$(bindir) + $(INSTALL) -m 755 sdl-config $(DESTDIR)$(bindir)/sdl-config +install-hdrs: + $(SHELL) $(auxdir)/mkinstalldirs $(DESTDIR)$(includedir)/SDL + for file in $(HDRS); do \ + $(INSTALL) -m 644 $(srcdir)/include/$$file $(DESTDIR)$(includedir)/SDL/$$file; \ + done + $(INSTALL) -m 644 include/SDL_config.h $(DESTDIR)$(includedir)/SDL/SDL_config.h +install-lib: $(objects) $(objects)/$(TARGET) $(objects)/$(SDLMAIN_TARGET) + $(SHELL) $(auxdir)/mkinstalldirs $(DESTDIR)$(libdir) + $(LIBTOOL) --mode=install $(INSTALL) $(objects)/$(TARGET) $(DESTDIR)$(libdir)/$(TARGET) + $(INSTALL) -m 644 $(objects)/$(SDLMAIN_TARGET) $(DESTDIR)$(libdir)/$(SDLMAIN_TARGET) + $(RANLIB) $(DESTDIR)$(libdir)/$(SDLMAIN_TARGET) +install-data: + $(SHELL) $(auxdir)/mkinstalldirs $(DESTDIR)$(datadir)/aclocal + $(INSTALL) -m 644 $(srcdir)/sdl.m4 $(DESTDIR)$(datadir)/aclocal/sdl.m4 + $(SHELL) $(auxdir)/mkinstalldirs $(DESTDIR)$(libdir)/pkgconfig + $(INSTALL) -m 644 sdl.pc $(DESTDIR)$(libdir)/pkgconfig +install-man: + $(SHELL) $(auxdir)/mkinstalldirs $(DESTDIR)$(mandir)/man3 + for src in $(srcdir)/docs/man3/*.3; do \ + file=`echo $$src | sed -e 's|^.*/||'`; \ + $(INSTALL) -m 644 $$src $(DESTDIR)$(mandir)/man3/$$file; \ + done + +uninstall: uninstall-bin uninstall-hdrs uninstall-lib uninstall-data uninstall-man +uninstall-bin: + rm -f $(DESTDIR)$(bindir)/sdl-config +uninstall-hdrs: + for file in $(HDRS); do \ + rm -f $(DESTDIR)$(includedir)/SDL/$$file; \ + done + rm -f $(DESTDIR)$(includedir)/SDL/SDL_config.h + -rmdir $(DESTDIR)$(includedir)/SDL +uninstall-lib: + $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$(TARGET) + rm -f $(DESTDIR)$(libdir)/$(SDLMAIN_TARGET) +uninstall-data: + rm -f $(DESTDIR)$(datadir)/aclocal/sdl.m4 + rm -f $(DESTDIR)$(libdir)/pkgconfig/sdl.pc +uninstall-man: + for src in $(srcdir)/docs/man3/*.3; do \ + file=`echo $$src | sed -e 's|^.*/||'`; \ + rm -f $(DESTDIR)$(mandir)/man3/$$file; \ + done + +clean: + rm -rf $(objects) + if test -f test/Makefile; then (cd test; $(MAKE) $@); fi + +distclean: clean + rm -f Makefile include/SDL_config.h sdl-config + rm -f SDL.qpg + rm -f config.status config.cache config.log libtool $(depend) + rm -rf $(srcdir)/autom4te* + rm -rf $(srcdir)/test/autom4te* + find $(srcdir) \( \ + -name '*~' -o \ + -name '*.bak' -o \ + -name '*.old' -o \ + -name '*.rej' -o \ + -name '*.orig' -o \ + -name '.#*' \) \ + -exec rm -f {} \; + cp $(srcdir)/include/SDL_config.h.default $(srcdir)/include/SDL_config.h + if test -f test/Makefile; then (cd test; $(MAKE) $@); fi + +dist $(distfile): + $(SHELL) $(auxdir)/mkinstalldirs $(distdir) + tar cf - $(DIST) | (cd $(distdir); tar xf -) + cp $(distdir)/include/SDL_config.h.default $(distdir)/include/SDL_config.h + rm -rf `find $(distdir) -name .svn` + rm -rf $(distdir)/test/autom4te* + find $(distdir) \( \ + -name '*~' -o \ + -name '*.bak' -o \ + -name '*.old' -o \ + -name '*.rej' -o \ + -name '*.orig' -o \ + -name '.#*' \) \ + -exec rm -f {} \; + if test -f $(distdir)/test/Makefile; then (cd $(distdir)/test && make distclean); fi + tar cvf - $(distdir) | gzip --best >$(distfile) + rm -rf $(distdir) + +rpm: $(distfile) + rpmbuild -ta $? + +# Create a SVN snapshot that people can run update on +snapshot: + svn co http://svn.libsdl.org/branches/SDL-1.2 + (cd SDL-1.2 && ./autogen.sh && rm -rf autom4te.cache) + cp SDL-1.2/include/SDL_config.h.default SDL-1.2/include/SDL_config.h + tar zcf $(HOME)/SDL-1.2.tar.gz SDL-1.2 + rm -f $(HOME)/SDL-1.2.zip + zip -r $(HOME)/SDL-1.2.zip SDL-1.2 + rm -rf SDL-1.2 diff --git a/Externals/SDL/Makefile.minimal b/Externals/SDL/Makefile.minimal new file mode 100644 index 0000000000..827621c3f3 --- /dev/null +++ b/Externals/SDL/Makefile.minimal @@ -0,0 +1,42 @@ +# Makefile to build the SDL library + +INCLUDE = -I./include +CFLAGS = -g -O2 $(INCLUDE) +AR = ar +RANLIB = ranlib + +CONFIG_H = include/SDL_config.h +TARGET = libSDL.a +SOURCES = \ + src/*.c \ + src/audio/*.c \ + src/cdrom/*.c \ + src/cpuinfo/*.c \ + src/events/*.c \ + src/file/*.c \ + src/joystick/*.c \ + src/stdlib/*.c \ + src/thread/*.c \ + src/timer/*.c \ + src/video/*.c \ + src/audio/dummy/*.c \ + src/video/dummy/*.c \ + src/joystick/dummy/*.c \ + src/cdrom/dummy/*.c \ + src/thread/generic/*.c \ + src/timer/dummy/*.c \ + src/loadso/dummy/*.c \ + +OBJECTS = $(shell echo $(SOURCES) | sed -e 's,\.c,\.o,g') + +all: $(TARGET) + +$(TARGET): $(CONFIG_H) $(OBJECTS) + $(AR) crv $@ $^ + $(RANLIB) $@ + +$(CONFIG_H): + cp $(CONFIG_H).default $(CONFIG_H) + +clean: + rm -f $(TARGET) $(OBJECTS) diff --git a/Externals/SDL/README b/Externals/SDL/README new file mode 100644 index 0000000000..7c0dd5890c --- /dev/null +++ b/Externals/SDL/README @@ -0,0 +1,49 @@ + + Simple DirectMedia Layer + + (SDL) + + Version 1.2 + +--- +http://www.libsdl.org/ + +This is the Simple DirectMedia Layer, a general API that provides low +level access to audio, keyboard, mouse, joystick, 3D hardware via OpenGL, +and 2D framebuffer across multiple platforms. + +The current version supports Linux, Windows CE/95/98/ME/XP/Vista, BeOS, +MacOS Classic, Mac OS X, FreeBSD, NetBSD, OpenBSD, BSD/OS, Solaris, IRIX, +and QNX. The code contains support for Dreamcast, Atari, AIX, OSF/Tru64, +RISC OS, SymbianOS, Nintendo DS, and OS/2, but these are not officially +supported. + +SDL is written in C, but works with C++ natively, and has bindings to +several other languages, including Ada, C#, Eiffel, Erlang, Euphoria, +Guile, Haskell, Java, Lisp, Lua, ML, Objective C, Pascal, Perl, PHP, +Pike, Pliant, Python, Ruby, and Smalltalk. + +This library is distributed under GNU LGPL version 2, which can be +found in the file "COPYING". This license allows you to use SDL +freely in commercial programs as long as you link with the dynamic +library. + +The best way to learn how to use SDL is to check out the header files in +the "include" subdirectory and the programs in the "test" subdirectory. +The header files and test programs are well commented and always up to date. +More documentation is available in HTML format in "docs/index.html", and +a documentation wiki is available online at: + http://www.libsdl.org/cgi/docwiki.cgi + +The test programs in the "test" subdirectory are in the public domain. + +Frequently asked questions are answered online: + http://www.libsdl.org/faq.php + +If you need help with the library, or just want to discuss SDL related +issues, you can join the developers mailing list: + http://www.libsdl.org/mailing-list.php + +Enjoy! + Sam Lantinga (slouken@libsdl.org) + diff --git a/Externals/SDL/README-SDL.txt b/Externals/SDL/README-SDL.txt new file mode 100644 index 0000000000..4d36ca9dce --- /dev/null +++ b/Externals/SDL/README-SDL.txt @@ -0,0 +1,13 @@ + +Please distribute this file with the SDL runtime environment: + +The Simple DirectMedia Layer (SDL for short) is a cross-platfrom library +designed to make it easy to write multi-media software, such as games and +emulators. + +The Simple DirectMedia Layer library source code is available from: +http://www.libsdl.org/ + +This library is distributed under the terms of the GNU LGPL license: +http://www.gnu.org/copyleft/lesser.html + diff --git a/Externals/SDL/README.AmigaOS b/Externals/SDL/README.AmigaOS new file mode 100644 index 0000000000..e0d890640d --- /dev/null +++ b/Externals/SDL/README.AmigaOS @@ -0,0 +1,12 @@ +The AmigaOS code has been removed from SDL, since it had been broken for a + long time and had a few bits of fairly invasive code #ifdef'd into the + SDL core. + +However, there is an OS4 version of SDL here: + http://www.rcdrummond.net/amiga/index.html + +And a MorphOS version here: + http://www.lehtoranta.net/powersdl/ + +--ryan. + diff --git a/Externals/SDL/README.BeOS b/Externals/SDL/README.BeOS new file mode 100644 index 0000000000..ccdccf598a --- /dev/null +++ b/Externals/SDL/README.BeOS @@ -0,0 +1,13 @@ + +SDL on BeOS R5 +============== + +You can build SDL on BeOS like any other GNU style package. +e.g. ./configure && make && make install +By default it is installed in /boot/develop/tools/gnupro/{bin,lib,etc.} + +Once you install SDL, you need to copy libSDL.so to /boot/home/config/lib, +so it can be found by the dynamic linker. + +Enjoy! + Sam Lantinga (slouken@libsdl.org) diff --git a/Externals/SDL/README.CVS b/Externals/SDL/README.CVS new file mode 100644 index 0000000000..7664e9181e --- /dev/null +++ b/Externals/SDL/README.CVS @@ -0,0 +1,4 @@ + +SDL is no longer hosted in a CVS repository. Please see README.SVN for +information on accessing our Subversion repository. + diff --git a/Externals/SDL/README.DC b/Externals/SDL/README.DC new file mode 100644 index 0000000000..e2fb1d6518 --- /dev/null +++ b/Externals/SDL/README.DC @@ -0,0 +1,32 @@ +SDL for Dreamcast (beta2) + + BERO + berobero@users.sourceforge.net + + http://www.geocities.co.jp/Playtown/2004/ + +this work with kos-newlib +http://sourceforge.net/projects/dcquake/ + +compile +- source environ.sh (from the KOS distribution) +- make -f Makefile.dc + +compile with gl support +- install latest libgl from http://sourceforge.net/projects/dcquake/ +- uncomment GL=1 in Makefile.dc +- make -f Makefile.dc clean +- make -f Makefile.dc + +install +- copy include/*.h and libSDL.a or libSDL_gl.a for your enviroment + +changelog: + +beta2 +- OpenGL support +- Hardware page flip support + +beta +- thread, timer don't tested so much. +- not support OpenGL diff --git a/Externals/SDL/README.MacOS b/Externals/SDL/README.MacOS new file mode 100644 index 0000000000..acfd93578b --- /dev/null +++ b/Externals/SDL/README.MacOS @@ -0,0 +1,63 @@ + +============================================================================== +Using the Simple DirectMedia Layer with MacOS 7,8,9 on PPC +============================================================================== + +These instructions are for people using the Apple MPW environment: +http://developer.apple.com/tools/mpw-tools/ + +CodeWarrior projects are available in the CWprojects directory. + +============================================================================== +I. Building the Simple DirectMedia Layer libraries: + (This step isn't necessary if you have the SDL binary distribution) + + First, unpack the MPWmake.sea.hqx archive and move SDL.make into the + SDL directory. + + Start MPW + + Set the current directory within MPW to the SDL toplevel directory. + + Build "SDL" (Type Command-B and enter "SDL" in the dialog) + + If everything compiles successfully, you now have the PPC libraries + "SDL" and "SDLmain.o" in the 'lib' subdirectory. + +============================================================================== +II. Building the Simple DirectMedia Layer test programs: + + First, unpack the MPWmake.sea.hqx archive, move the new rsrc directory to + the main SDL directory, and move the makefiles in the new test subdirectory + to the SDL 'test' subdirectory. + + Start MPW + + Set the current directory within MPW to the SDL 'test' subdirectory. + + Build the programs that have an associated MPW makefile (file ending + with .make), including "testwin", "testalpha", and "graywin". + + Copy the SDL library file into the test directory, and run! + +============================================================================== +III. Building the Simple DirectMedia Layer demo programs: + + Copy one of the test program Makefiles to the demo directory + and modify it to match the sources in the demo. + +============================================================================== +IV. Enjoy! :) + + If you have a project you'd like me to know about, or want to ask questions, + go ahead and join the SDL developer's mailing list by sending e-mail to: + + sdl-request@libsdl.org + + and put "subscribe" into the subject of the message. Or alternatively you + can use the web interface: + + http://www.libsdl.org/mailman/listinfo/sdl + +============================================================================== + diff --git a/Externals/SDL/README.MacOSX b/Externals/SDL/README.MacOSX new file mode 100644 index 0000000000..3bc421371f --- /dev/null +++ b/Externals/SDL/README.MacOSX @@ -0,0 +1,186 @@ +============================================================================== +Using the Simple DirectMedia Layer with Mac OS X +============================================================================== + +These instructions are for people using Apple's Mac OS X (pronounced +"ten"). + +From the developer's point of view, OS X is a sort of hybrid Mac and +Unix system, and you have the option of using either traditional +command line tools or Apple's IDE Xcode. + +To build SDL using the command line, use the standard configure and make +process: + + ./configure + make + sudo make install + +You can also build SDL as a Universal library (a single binary for both +PowerPC and Intel architectures), on Mac OS X 10.4 and newer, by using +the fatbuild.sh script in build-scripts: + sh build-scripts/fatbuild.sh + sudo build-scripts/fatbuild.sh install +This script builds SDL with 10.2 ABI compatibility on PowerPC and 10.4 +ABI compatibility on Intel architectures. For best compatibility you +should compile your application the same way. A script which wraps +gcc to make this easy is provided in test/gcc-fat.sh + +To use the library once it's built, you essential have two possibilities: +use the traditional autoconf/automake/make method, or use Xcode. + +============================================================================== +Using the Simple DirectMedia Layer with a traditional Makefile +============================================================================== + +An existing autoconf/automake build system for your SDL app has good chances +to work almost unchanged on OS X. However, to produce a "real" Mac OS X binary +that you can distribute to users, you need to put the generated binary into a +so called "bundle", which basically is a fancy folder with a name like +"MyCoolGame.app". + +To get this build automatically, add something like the following rule to +your Makefile.am: + +bundle_contents = APP_NAME.app/Contents +APP_NAME_bundle: EXE_NAME + mkdir -p $(bundle_contents)/MacOS + mkdir -p $(bundle_contents)/Resources + echo "APPL????" > $(bundle_contents)/PkgInfo + $(INSTALL_PROGRAM) $< $(bundle_contents)/MacOS/ + +You should replace EXE_NAME with the name of the executable. APP_NAME is what +will be visible to the user in the Finder. Usually it will be the same +as EXE_NAME but capitalized. E.g. if EXE_NAME is "testgame" then APP_NAME +usually is "TestGame". You might also want to use @PACKAGE@ to use the package +name as specified in your configure.in file. + +If your project builds more than one application, you will have to do a bit +more. For each of your target applications, you need a seperate rule. + +If you want the created bundles to be installed, you may want to add this +rule to your Makefile.am: + +install-exec-hook: APP_NAME_bundle + rm -rf $(DESTDIR)$(prefix)/Applications/APP_NAME.app + mkdir -p $(DESTDIR)$(prefix)/Applications/ + cp -r $< /$(DESTDIR)$(prefix)Applications/ + +This rule takes the Bundle created by the rule from step 3 and installs them +into $(DESTDIR)$(prefix)/Applications/. + +Again, if you want to install multiple applications, you will have to augment +the make rule accordingly. + + +But beware! That is only part of the story! With the above, you end up with +a bare bone .app bundle, which is double clickable from the Finder. But +there are some more things you should do before shipping yor product... + +1) The bundle right now probably is dynamically linked against SDL. That + means that when you copy it to another computer, *it will not run*, + unless you also install SDL on that other computer. A good solution + for this dilemma is to static link against SDL. On OS X, you can + achieve that by linkinag against the libraries listed by + sdl-config --static-libs + instead of those listed by + sdl-config --libs + Depending on how exactly SDL is integrated into your build systems, the + way to achieve that varies, so I won't describe it here in detail +2) Add an 'Info.plist' to your application. That is a special XML file which + contains some meta-information about your application (like some copyright + information, the version of your app, the name of an optional icon file, + and other things). Part of that information is displayed by the Finder + when you click on the .app, or if you look at the "Get Info" window. + More information about Info.plist files can be found on Apple's homepage. + + +As a final remark, let me add that I use some of the techniques (and some +variations of them) in Exult and ScummVM; both are available in source on +the net, so feel free to take a peek at them for inspiration! + + +============================================================================== +Using the Simple DirectMedia Layer with Xcode +============================================================================== + +These instructions are for using Apple's Xcode IDE to build SDL applications. + +- First steps + +The first thing to do is to unpack the Xcode.tar.gz archive in the +top level SDL directory (where the Xcode.tar.gz archive resides). +Because Stuffit Expander will unpack the archive into a subdirectory, +you should unpack the archive manually from the command line: + cd [path_to_SDL_source] + tar zxf Xcode.tar.gz +This will create a new folder called Xcode, which you can browse +normally from the Finder. + +- Building the Framework + +The SDL Library is packaged as a framework bundle, an organized +relocatable folder heirarchy of executible code, interface headers, +and additional resources. For practical purposes, you can think of a +framework as a more user and system-friendly shared library, whose library +file behaves more or less like a standard UNIX shared library. + +To build the framework, simply open the framework project and build it. +By default, the framework bundle "SDL.framework" is installed in +/Library/Frameworks. Therefore, the testers and project stationary expect +it to be located there. However, it will function the same in any of the +following locations: + + ~/Library/Frameworks + /Local/Library/Frameworks + /System/Library/Frameworks + +- Build Options + There are two "Build Styles" (See the "Targets" tab) for SDL. + "Deployment" should be used if you aren't tweaking the SDL library. + "Development" should be used to debug SDL apps or the library itself. + +- Building the Testers + Open the SDLTest project and build away! + +- Using the Project Stationary + Copy the stationary to the indicated folders to access it from + the "New Project" and "Add target" menus. What could be easier? + +- Setting up a new project by hand + Some of you won't want to use the Stationary so I'll give some tips: + * Create a new "Cocoa Application" + * Add src/main/macosx/SDLMain.m , .h and .nib to your project + * Remove "main.c" from your project + * Remove "MainMenu.nib" from your project + * Add "$(HOME)/Library/Frameworks/SDL.framework/Headers" to include path + * Add "$(HOME)/Library/Frameworks" to the frameworks search path + * Add "-framework SDL -framework Foundation -framework AppKit" to "OTHER_LDFLAGS" + * Set the "Main Nib File" under "Application Settings" to "SDLMain.nib" + * Add your files + * Clean and build + +- Building from command line + Use pbxbuild in the same directory as your .pbproj file + +- Running your app + You can send command line args to your app by either invoking it from + the command line (in *.app/Contents/MacOS) or by entering them in the + "Executibles" panel of the target settings. + +- Implementation Notes + Some things that may be of interest about how it all works... + * Working directory + As defined in the SDL_main.m file, the working directory of your SDL app + is by default set to its parent. You may wish to change this to better + suit your needs. + * You have a Cocoa App! + Your SDL app is essentially a Cocoa application. When your app + starts up and the libraries finish loading, a Cocoa procedure is called, + which sets up the working directory and calls your main() method. + You are free to modify your Cocoa app with generally no consequence + to SDL. You cannot, however, easily change the SDL window itself. + Functionality may be added in the future to help this. + + +Known bugs are listed in the file "BUGS" diff --git a/Externals/SDL/README.MiNT b/Externals/SDL/README.MiNT new file mode 100644 index 0000000000..eabe3eb1b7 --- /dev/null +++ b/Externals/SDL/README.MiNT @@ -0,0 +1,250 @@ +============================================================================== +Using the Simple DirectMedia Layer on Atari +============================================================================== + + + If you want to build SDL from sources to create SDL programs on Atari: + see sections I - II. + + If you want to create SDL programs on Atari using SDL binary build, + download it from my web site (URL at end of this file). + + If you want to configure a program using SDL on Atari, + see sections IV - VI. + + +============================================================================== +I. Building the Simple DirectMedia Layer libraries: + (This step isn't necessary if you have the SDL binary distribution) + + Do the classic configure, with --disable-shared --enable-static and: + + Tos version (should run everywhere): + --disable-threads + Tos does not support threads. + + MiNT version (maybe Magic, only for multitasking OS): + --disable-pthreads --enable-pth + Mint and Magic may supports threads, so audio can be used with current + devices, like Sun audio, or disk-writing support. Like Tos, interrupt + audio without threads is more suited for Atari machines. + + Then you can make ; make install it. + +============================================================================== +II. Building the Simple DirectMedia Layer test programs: + + Do the classic configure, then make. + + Run them ! + +============================================================================== +III. Enjoy! :) + + If you have a project you'd like me to know about, or want to ask questions, + go ahead and join the SDL developer's mailing list by sending e-mail to: + + sdl-request@libsdl.org + + and put "subscribe" into the subject of the message. Or alternatively you + can use the web interface: + + http://www.libsdl.org/mailman/listinfo/sdl + +============================================================================== +IV. What is supported: + +Keyboard (GEMDOS, BIOS, GEM, Ikbd) +Mouse (XBIOS, GEM, Ikbd, /dev/mouse (non working atm, disabled)) +Video (XBIOS (Fullscreen), GEM (Windowed and Fullscreen)) +Timer (VBL vector, GNU pth library) +Joysticks and joypads (Ikbd, Hardware) +Audio (Hardware, XBIOS, GSXB, MCSN, STFA, /dev/audio if threads enabled) +Threads (Multitasking OS only via GNU pth library) +Shared object loader (using LDG library from http://ldg.atari.org/) +Audio CD (MetaDOS) +OpenGL (using Mesa offscreen rendering driver) + +- Dependent driver combinations: +Video Kbd Mouse Timer Joysticks +xbios ikbd ikbd vbl(2) ikbd +xbios gemdos xbios vbl(2) xbios +xbios bios xbios vbl(2) xbios +gem gem gem(1) vbl(2) xbios + +Audio O/S Misc +dma8 All Uses MFP Timer A interrupt +xbios TOS Uses MFP Timer A interrupt +xbios MiNT Uses MFP Timer A interrupt +xbios Magic Uses MFP Timer A interrupt +stfa All Uses MFP interrupt +mcsn TOS Uses MFP Timer A interrupt +mcsn MiNT Uses MiNT thread +mcsn Magic Disabled +gsxb All Uses GSXB callback + +Joypad driver always uses hardware access. +OpenGL driver always uses OSMesa. + +(1) GEM does not report relative mouse motion, so xbios mouse driver is used +to report this type event. +A preliminary driver for /dev/mouse device driver is present, but is disabled +till it can be used with other applications simultaneously. + +(2) If you build SDL with threads using the GNU pth library, timers are +supported via the pth library. + +============================================================================== +V. Environment variables: + +SDL_VIDEODRIVER: + Set to 'xbios' to force xbios video driver + Set to 'gem' to force gem video driver + +SDL_VIDEO_GL_DRIVER: + Set to filename to load as OpenGL library, if you use SDL_GL_LoadLibrary() + +SDL_AUDIODRIVER: + Set to 'mint_gsxb' to force Atari GSXB audio driver + Set to 'mint_mcsn' to force Atari MCSN audio driver + Set to 'mint_stfa' to force Atari STFA audio driver + Set to 'mint_xbios' to force Atari Xbios audio driver + Set to 'mint_dma8' to force Atari 8 bits DMA audio driver + Set to 'audio' to force Sun /dev/audio audio driver + Set to 'disk' to force disk-writing audio driver + +SDL_ATARI_EVENTSDRIVER + Set to 'ikbd' to force IKBD 6301 keyboard driver + Set to 'gemdos' to force gemdos keyboard driver + Set to 'bios' to force bios keyboard driver + +SDL_JOYSTICK_ATARI: + Use any of these strings in the environment variable to enable or + disable a joystick: + + 'ikbd-joy1-[on|off]' for IKBD joystick on port 1 (hardware access) + 'xbios-joy1-[on|off]' for IKBD joystick on port 1 (xbios access) + 'porta-pad-[on|off]' for joypad and/or teamtap on port A + 'porta-joy0-[on|off]' for joystick 0 on port A + 'porta-joy1-[on|off]' for joystick 1 on port A + 'porta-lp-[on|off]' for lightpen on port A + 'porta-anpad-[on|off]' for analog paddle on port A + 'portb-pad-[on|off]' for joypad and/or teamtap on port B + 'portb-joy0-[on|off]' for joystick 0 on port B + 'portb-joy1-[on|off]' for joystick 1 on port B + 'portb-anpad-[on|off]' for analog paddle on port B + + Default configuration is: + 'ikbd-joy1-on' (if IKBD events driver enabled) + 'xbios-joy1-on' (if gemdos/bios/gem events driver enabled) + 'porta-pad-on portb-pad-on' (if available on the machine) + + port[a|b]-[pad|joy?|lp|anpad]-* strings are mutually exclusives. + On such a port, you can only use a joypad OR 1 or 2 joysticks OR + a lightpen OR an analog paddle. You must disable joypad before + setting another controller. + + The second joystick port on IKBD is used by the mouse, so not usable. + Another problem with the IKBD: mouse buttons and joystick fire buttons + are wired together at the hardware level, it means: + port 0 port 0 port 1 + mouse left button = joystick fire 0 = joystick fire 1 + mouse right button = joystick fire 1 = joystick fire 0 + + Descriptions of joysticks/joypads: + - Joypads: 1 hat, 17 buttons (Atari Jaguar console-like). + - Joysticks: 1 hat, 1 button. + - Lightpen, analog paddles: 2 axis, 2 buttons. The 2 buttons are those + affected to 1 button joysticks on the same port. + +============================================================================== +VI. More informations about drivers: + +OpenGL: + The default is to use the Mesa offscreen driver (osmesa.ldg). If you want + to use an older OpenGL implementation, like mesa_gl.ldg or tiny_gl.ldg, + your program must use SDL_GL_LoadLibrary() to do so, and retrieve the + needed function pointers with SDL_LoadFunction(). In all cases, the OpenGL + context is taken care of by SDL itself, you just have to use gl* functions. + + However, there is one OpenGL call that has a different prototype in the old + implementations: glOrtho(). In the old implementations, it has 6 float as + parameters, in the standard one, it has 6 double parameters. If you want + to compile testdyngl, or any other SDL program that loads its OpenGL + library, you must change the glOrtho() prototype used in this program. In + osmesa.ldg, you can retrieve a glOrtho() with double parameters, by + searching for the function "glOrtho6d". + +Xbios video: + Video chip is detected using the _VDO cookie. + Screen enhancers are not supported, but could be if you know how to + use them. + + ST, STE, Mega ST, Mega STE: + 320x200x4 bits, shades of grey, available only for the purpose + of testing SDL. + TT: + 320x480x8 and 320x240x8 (software double-lined mode). + Falcon: + All modes supported by the current monitor (RVB or VGA). + BlowUp and Centscreen extended modes, ScreenBlaster 3 current mode. + Milan: + Experimental support + Clones and any machine with monochrome monitor: + Not supported. + +Gem video: + Automatically used if xbios not available. + + All machines: + Only the current resolution, if 8 bits or higher depth. + +IKBD keyboard, mouse and joystick driver: + Available if _MCH cookie is ST, Mega ST, STE, Mega STE, TT or Falcon. + + Hades has an IKBD, but xbios is not available for video, so IKBD + driver is disabled. + +Gemdos and bios keyboard driver: + Available on all machines. + +Mouse and joystick xbios driver: + Available on all machines (I think). + +Joypad driver: + Available if _MCH cookie is STE or Falcon. Supports teamtap. + +PTH timer driver: + Available with multitasking OS. + +VBL timer driver: + Available on all machines (I think). + +Audio drivers: + Cookies _SND, MCSN, STFA and GSXB used to detect supported audio + capabilities. + + STE, Mega STE, TT: + 8 bits DMA (hardware access) + STFA, MCSN or GSXB driver if installed + Falcon: + 8 bits DMA (hardware access) + Xbios functions + STFA, MCSN or GSXB driver if installed + Other machines: + STFA, MCSN or GSXB driver if installed + + STFA driver: + http://removers.free.fr/softs/stfa.html + GSXB driver: + http://assemsoft.atari.org/gsxb/ + MacSound driver: + http://jf.omnis.ch/software/tos/ + MagicSound driver (MCSN,GSXB compatible): + http://perso.wanadoo.fr/didierm/ + X-Sound driver (GSXB compatible): + http://www.uni-ulm.de/~s_thuth/atari/xsound_e.html + +-- +Patrice Mandin +http://pmandin.atari.org/ diff --git a/Externals/SDL/README.NDS b/Externals/SDL/README.NDS new file mode 100644 index 0000000000..e96a9eeecb --- /dev/null +++ b/Externals/SDL/README.NDS @@ -0,0 +1,22 @@ +The SDL port to the Nintendo DS + +This port uses the devKitPro toolchain, available from: +http://www.devkitpro.org + +Precompiled tools for cross-compiling on Linux are available from: +http://www.libsdl.org/extras/nds/devkitPro-20070503-linux.tar.gz + +todo: +add ds console specific features/optimizations +mouse/keyboard support +dual screen support + +build with: +cp include/SDL_config_nds.h include/SDL_config.h +make -f Makefile.ds + +included is an arm9/arm7 template to allow for sound streaming support. + +Enjoy, fix the source and share :) +Troy Davis(GPF) +http://gpf.dcemu.co.uk/ diff --git a/Externals/SDL/README.NanoX b/Externals/SDL/README.NanoX new file mode 100644 index 0000000000..8418ff3320 --- /dev/null +++ b/Externals/SDL/README.NanoX @@ -0,0 +1,97 @@ + ================================================================= + Patch version 0.9 of SDL(Simple DirectMedia Layer) for Nano-X API + ================================================================= + + Authors: Hsieh-Fu Tsai, clare@setabox.com + Greg Haerr, greg@censoft.com + + This patch is against SDL version 1.2.4. + It enhances previous patch 0.8 by providing direct framebuffer + access as well as dynamic hardware pixel type support, not + requiring a compile-time option setting for different framebuffer + modes. + Tested against Microwindows version 0.89pre9. + + Older Microwindows versions + =========================== + If running on a version older than Microwindows 0.89pre9, + the following items might need to be patched in Microwindows. + + 1. Patch src/nanox/client.c::GrClose() + It fixes the client side GrClose(). In the original version, + GrOpen() can only be called once. When the GrOpen() is called at + the second time, the program will terminate. In order to prevent + this situation, we need to insert "nxSocket = -1" after + "close(nxSocket)" in GrClose(). If you do not have this problem, + you may skip this step. + + 2. Patch src/nanox/clientfb.c to return absolute x,y coordinates + when using GrGetWindowFBInfo(). Copy the version 0.89pre9 + of src/nanox/clientfb.c to your system, or configure + using --disable-nanox-direct-fb. + + ============= + Quick Install + ============= + + 1. ./configure --disable-video-x11 --disable-video-fbcon \ + --enable-video-nanox \ + --with-nanox-pixel-type=[rgb/0888/888/565/555/332/pal] + 2. make clean + 3. make + 4. make install (as root) + + ============ + Nitty-gritty + ============ + + --enable-nanox-direct-fb Use direct framebuffer access + --enable-nanox-debug Show debug messages + --enable-nanox-share-memory Use shared-memory to speed up + + When running multi-threaded applications using SDL, such + as SMPEG, set THREADSAFE=Y in Microwindows' config file, + to enable GrXXX() system call critical section support. + + ============================================= + Some programs can be used to test this patch. + ============================================= + + 1. http://www.cs.berkeley.edu/~weimer/atris (a tetris-like game) + 2. http://www.libsdl.org/projects/newvox/ + 3. http://www.libsdl.org/projects/xflame/ + 4. http://www.libsdl.org/projects/optimum/ + 5. http://www.gnugeneration.com/software/loop/ + 6: http://www.lokigames.com/development/smpeg.php3 (SMPEG version 0.4.4) + + ========= + Todo List + ========= + + 1. Create hardware surface + 2. Create YUVOverlay on hardware + 3. Use OpenGL + 4. Gamma correction + 5. Hide/Change mouse pointer + 6. Better window movement control with direct fb access + 7. Palette handling in 8bpp could be improved + + ===================== + Supporting Institutes + ===================== + + Many thanks to go to Setabox Co., Ltd. and CML (Communication and + Multimedia Laboratory, http://www.cmlab.csie.ntu.edu.tw/) in the + Department of Computer Science and Information Engineering of + National Taiwan University for supporting this porting project. + + Century Embedded Technologies (http://embedded.censoft.com) + for this patch. + + =================== + Contact Information + =================== + + Welcome to give me any suggestion and to report bugs. + My e-mail address : clare@setabox.com or niky@cmlab.csie.ntu.edu.tw + or greg@censoft.com diff --git a/Externals/SDL/README.OS2 b/Externals/SDL/README.OS2 new file mode 100644 index 0000000000..424b3739c3 --- /dev/null +++ b/Externals/SDL/README.OS2 @@ -0,0 +1,281 @@ + +=========== +SDL on OS/2 +=========== + +Last updated on May. 17, 2006. + + +1. How to compile? +------------------ + +To compile this, you'll need the followings installed: +- The OS/2 Developer's Toolkit +- The OpenWatcom compiler + (http://www.openwatcom.org) + +First of all, you have to unzip the Watcom-OS2.zip file. This will result in a +file called "makefile" and a file called "setvars.cmd" in this folder (and some +more files...). + +Please edit the second, fourth and fifth lines of setvars.cmd file +to set the folders where the toolkit, the OW compiler and the FSLib are. +You won't need NASM yet (The Netwide Assembler), you can leave that line. +Run setvars.cmd, and you should get a shell in which you can +compile SDL. + +Check the "makefile" file. There is a line in there which determines if the +resulting SDL.DLL will be a 'debug' or a 'release' build. The 'debug' version +is full of printf()'s, so if something goes wrong, its output can help a lot +for debugging. + +Then run "wmake". +This should create the SDL12.DLL and the corresponding SDL12.LIB file here. + +To test applications, it's a good idea to use the 'debug' build of SDL, and +redirect the standard output and standard error output to files, to see what +happens internally in SDL. +(like: testsprite >stdout.txt 2>stderr.txt) + +To rebuild SDL, use the following commands in this folder: +wmake clean +wmake + + + +2. How to compile the testapps? +------------------------------- + +Once you have SDL12.DLL compiled, navigate into the 'test' folder, copy in +there the newly built SDL12.DLL, and copy in there FSLib.DLL. + +Then run "wmake" in there to compile some of the testapps. + + + +3. What is missing? +------------------- + +The following things are missing from this SDL implementation: +- MMX, SSE and 3DNOW! optimized video blitters? +- HW Video surfaces +- OpenGL support + + + +4. Special Keys / Full-Screen support +------------------------------------- + +There are two special hot-keys implemented: +- Alt+Home switches between fullscreen and windowed mode +- Alt+End simulates closing the window (can be used as a Panic key) +Only the LEFT Alt key will work. + + + +5. Joysticks on SDL/2 +--------------------- + +The Joystick detection only works for standard joysticks (2 buttons, 2 axes +and the like). Therefore, if you use a non-standard joystick, you should +specify its features in the SDL_OS2_JOYSTICK environment variable in a batch +file or CONFIG.SYS, so SDL applications can provide full capability to your +device. The syntax is: + +SET SDL_OS2_JOYSTICK=[JOYSTICK_NAME] [AXES] [BUTTONS] [HATS] [BALLS] + +So, it you have a Gravis GamePad with 4 axes, 2 buttons, 2 hats and 0 balls, +the line should be: + +SET SDL_OS2_JOYSTICK=Gravis_GamePad 4 2 2 0 + +If you want to add spaces in your joystick name, just surround it with +quotes or double-quotes: + +SET SDL_OS2_JOYSTICK='Gravis GamePad' 4 2 2 0 + +or + +SET SDL_OS2_JOYSTICK="Gravis GamePad" 4 2 2 0 + + Notive However that Balls and Hats are not supported under OS/2, and the +value will be ignored... but it is wise to define these correctly because +in the future those can be supported. + Also the number of buttons is limited to 2 when using two joysticks, +4 when using one joystick with 4 axes, 6 when using a joystick with 3 axes +and 8 when using a joystick with 2 axes. Notice however these are limitations +of the Joystick Port hardware, not OS/2. + + + +6. Proportional windows +----------------------- + +For some SDL applications it can be handy to have proportional windows, so +the windows will keep their aspect ratio when resized. +This can be achieved in two ways: + +- Before starting the given SDL application, set the + SDL_USE_PROPORTIONAL_WINDOW environment variable to something, e.g.: + + SET SDL_USE_PROPORTIONAL_WINDOW=1 + dosbox.exe + +- If you have a HOME environment variable set, then SDL will look for a file + in there called ".sdl.proportionals". If that file contains the name of the + currently running SDL executable, then that process will have proportional + windows automatically. + + Please note that this file is created automatically with default values + at the first run. + + + +7. Audio in SDL applications +---------------------------- + +Audio effects are one of the most important features in games. Creating audio +effects in sync with the game and without hickups and pauses in the audio are +very important things. + +However there are multithreaded SDL applications that have tight loops as their +main logic loop. This kills performance in OS/2, and takes too much CPU from +other threads in the same process, for example from the thread to create the +sound effects. + +For this reason, the OS/2 port of SDL can be instructed to run the audio thread +in high priority, which makes sure that there will be enough time for the +processing of the audio data. + +At default, SDL/2 runs the audio thread at ForegroundServer+0 priority. Well +written and well behaving SDL applications should work well in this mode. +For other applications, you can tell SDL/2 to run the audio thread at +TimeCritical priority by setting an env.variable before starting the SDL app: + + SET SDL_USE_TIMECRITICAL_AUDIO=1 + +Please note that this is a bit risky, because if the SDL application runs a +tight infinite loop in this thread, this will make the whole system +unresponsive, so use it with care, and only for applications that need it! + + + +8. Next steps... +---------------- + +Things to do: +- Implement missing stuffs (look for 'TODO' string in source code!) +- Finish video driver (the 'wincommon' can be a good example for missing + things like application icon and so on...) +- Enable MMX/SSE/SSE2 acceleration functions +- Rewrite CDROM support using DOS Ioctl for better support. + + + +9. Contacts +----------- + + You can contact the developers for bugs: + + Area Developer email + General (Audio/Video/System) Doodle doodle@scenergy.dfmk.hu + CDROM and Joystick Caetano daniel@caetano.eng.br + + Notice however that SDL/2 is 'in development' stage so ... if you want to help, +please, be our guest and contact us! + + + +10. Changelog of the OS/2 port +------------------------------ + +Version 1.2.10 - 2006-05-17 - Doodle + - Small modifications for v1.2.10 release + - Changed DLL name to include version info (currently SDL12.dll) + +Version 1.2 - 2006-05-01 - Doodle + - Modified makefile system to have only one makefile + - Included FSLib headers, DLL and LIB file + +Version 1.2 - 2006-02-26 - Doodle + - Updated the official SDL version with the OS/2 specific changes. + - Added support for real unicode keycode conversion. + +Version 1.2.7 - 2006-01-20 - Doodle + - Added support for selectively using timecritical priority for + audio threads by SDL_USE_TIMECRITICAL_AUDIO environment variable. + (e.g.: + SET SDL_USE_TIMECRITICAL_AUDIO=1 + dosbox.exe + ) + +Version 1.2.7 - 2005-12-22 - Doodle + - Added support for proportional SDL windows. + There are two ways to have proportional (aspect-keeping) windows for + a given SDL application: Either set the SDL_USE_PROPORTIONAL_WINDOW + environment variable to something before starting the application + (e.g.: + SET SDL_USE_PROPORTIONAL_WINDOW=1 + dosbox.exe + ) + or, if you have the HOME environment variable set, then SDL12.DLL will + create a file in that directory called .sdl.proportionals, and you can + put there the name of executable files that will be automatically made + proportional. + +Version 1.2.7 - 2005-10-14 - Doodle + - Enabled Exception handler code in FSLib to be able to restore original + desktop video mode in case the application crashes. + - Added the missing FSLib_Uninitialize() call into SDL. + (The lack of it did not cause problems, but it's cleaner this way.) + - Fixed a mouse problem in Fullscreen mode where any mouse click + re-centered the mouse. + +Version 1.2.7 - 2005-10-09 - Doodle + - Implemented window icon support + +Version 1.2.7 - 2005-10-03 - Doodle + - Reworked semaphore support again + - Tuned thread priorities + +Version 1.2.7 - 2005-10-02 - Doodle + - Added support for custom mouse pointers + - Fixed WM_CLOSE processing: give a chance to SDL app to ask user... + - Added support for MMX-accelerated audio mixers + - Other small fixes + +Version 1.2.7 - 2005-09-12 - Doodle + - Small fixes for DosBox incorporated into public release + - Fixed semaphore support (SDL_syssem.c) + - Fixed FSLib to have good clipping in scaled window mode, + and to prevent occasional desktop freezes. + +Version 1.2.7 - 2004-09-08a - Caetano + - Improved joystick support (general verifications about hardware). + - Added support up to 8 buttons in 2 axes joysticks and 6 buttons in 3 axes joysticks. + - Added support to environment variable SDL_OS2_JOYSTICK to specify a joystick. + - Improved Joystick test to handle every type of joystick and display only relevant information. + - Merged with Doodle 2004-09-08 + - Little tid up in README.OS2 + - Added explanation about SDL_OS2_JOYSTICK environment variable on README.OS2 + +Version 1.2.7 - 2004-09-07 - Caetano + - Merged with changes in headers for GCC compiling. + - Added Joystick support using basic IBM GAME$ support, allowing it to work with all joystick drivers since OS/2 2.1. + - Improved joystick detection (hacked!). OS/2 do not allow real joystick detection, so... + - Modified makefile in test to compile "testjoystick". Anyway, it's useless, since it seems to cause a lot of trouble in OS/2 (because os video routines, not Joystick support). + - Created separated Joystick test program to test only joystick functions. + - Improved joystick auto-centering. + - Improved the coordinate correction routine to use two scale factors for each axis. + +Version 1.2.7 - 2004-07-05 - Caetano + - Corrected the time returned by status in CDROM support (it was incorrect) + - Added the testcdrom.c and corrected the linking directive (it was causing an error) + +Version 1.2.7 - 2004-07-02a - Caetano + - Corrected a little problem in a comment at SDL-1.2.7\test\torturethread.c, line 18 (missing */, nested comment) + - Added CDROM support to tree (SDL-1.2.7\src\cdrom\os2\SDL_syscdrom.c) + - Modified makefile (SDL-1.2.7\src\makefiles.wat and SDL-1.2.7\watcom.mif) to build with CDROM support + - Added the "extra" SDL_types.h forgotten in 2004-07-02 version. + + diff --git a/Externals/SDL/README.PS3 b/Externals/SDL/README.PS3 new file mode 100644 index 0000000000..c66467d392 --- /dev/null +++ b/Externals/SDL/README.PS3 @@ -0,0 +1,29 @@ + +SDL on Sony Playstation3 +------------------------ + +Installation: + First, you have to install the Cell SDK + - Download the Cell SDK installer RPM and ISO images to + a temporary directory such as /tmp/cellsdk. + - Mount the image: mount -o loop CellSDK-Devel-Fedora_3.1.0.0.0.iso /tmp/cellsdk + - Install the SDK installer: rpm -ivh cell-install-3.1.0-0.0.noarch.rpm + - Install the SDK: cd /opt/cell && ./cellsdk --iso /tmp/cellsdkiso install + + You need to install the SPU-libs before installing SDL + - Go to SDL-1.2/src/video/ps3/spulibs/ + - Run make && make install + + Finally, install SDL + - Go to SDL-1.2/ and build SDL like any other GNU style package. + e.g. + - Build the configure-script with ./autogen.sh + - Configure SDL for your needs: ./configure --enable-video-ps3 ... + - Build and install it: make && make install + + +Todo: + - mouse/keyboard/controller support + +Have fun! + Dirk Herrendoerfer diff --git a/Externals/SDL/README.PicoGUI b/Externals/SDL/README.PicoGUI new file mode 100644 index 0000000000..cdb6bedaec --- /dev/null +++ b/Externals/SDL/README.PicoGUI @@ -0,0 +1,50 @@ + ======================== + Using SDL with PicoGUI + ======================== + +- Originally contributed by Micah Dowty + +PicoGUI is a scalable GUI system with a unique architecture, primarily focused +on scalability to various embedded systems. You can find more information +including a FAQ at http://picogui.org + +To use the patch: + + 1. When compiling, add the "--enable-video-picogui" switch to ./configure + + 2. When running your program, ensure that the picogui driver for SDL + is in use by setting the SDL_VIDEODRIVER environment variable + to "picogui". + + 3. The program must also be linked to the C client library for PicoGUI + (libpgui.so). If the program is being compiled with a patched SDL + installed this should be done automatically. If you want to use an + existing binary with PicoGUI, you can set the LD_PRELOAD environment + variable to the path of your libpgui.so file. + +Capabilities: + + So far only basic functionality is provided on true color (linear16/24/32) + devices. Accessing a memory mapped bitmap, updating the display, and handling + mouse/keyboard input. This functionality has been tested with several + applications, including mplayer, Xine, sldroids, and Abuse. + +TODO list: + + - YUV overlays will be helpful for watching video on set top boxes or other + embedded devices that have some graphics acceleration hardware + + - Account for rotated bitmap storage in pgserver + + - Support for hiding or changing the cursor + + - The display should be centered when the SDL application is smaller + than the PicoGUI panel + + - Fullscreen or any other special modes + + - Support for indexed and grayscale modes + + - Probably much more... + +--- The End --- diff --git a/Externals/SDL/README.Porting b/Externals/SDL/README.Porting new file mode 100644 index 0000000000..df619934f0 --- /dev/null +++ b/Externals/SDL/README.Porting @@ -0,0 +1,56 @@ + +* Porting To A New Platform + + The first thing you have to do when porting to a new platform, is look at +include/SDL_platform.h and create an entry there for your operating system. +The standard format is __PLATFORM__, where PLATFORM is the name of the OS. +Ideally SDL_platform.h will be able to auto-detect the system it's building +on based on C preprocessor symbols. + +There are two basic ways of building SDL at the moment: + +1. The "UNIX" way: ./configure; make; make install + + If you have a GNUish system, then you might try this. Edit configure.in, + take a look at the large section labelled: + "Set up the configuration based on the target platform!" + Add a section for your platform, and then re-run autogen.sh and build! + +2. Using an IDE: + + If you're using an IDE or other non-configure build system, you'll probably + want to create a custom SDL_config.h for your platform. Edit SDL_config.h, + add a section for your platform, and create a custom SDL_config_{platform}.h, + based on SDL_config.h.minimal and SDL_config.h.in + + Add the top level include directory to the header search path, and then add + the following sources to the project: + src/*.c + src/audio/*.c + src/cdrom/*.c + src/cpuinfo/*.c + src/events/*.c + src/file/*.c + src/joystick/*.c + src/stdlib/*.c + src/thread/*.c + src/timer/*.c + src/video/*.c + src/audio/disk/*.c + src/video/dummy/*.c + src/joystick/dummy/*.c + src/cdrom/dummy/*.c + src/thread/generic/*.c + src/timer/dummy/*.c + src/loadso/dummy/*.c + + +Once you have a working library without any drivers, you can go back to each +of the major subsystems and start implementing drivers for your platform. + +If you have any questions, don't hesitate to ask on the SDL mailing list: + http://www.libsdl.org/mailing-list.php + +Enjoy! + Sam Lantinga (slouken@libsdl.org) + diff --git a/Externals/SDL/README.QNX b/Externals/SDL/README.QNX new file mode 100644 index 0000000000..995afbec0e --- /dev/null +++ b/Externals/SDL/README.QNX @@ -0,0 +1,155 @@ +README.QNX by Mike Gorchak , +Last changed at 24 Apr 2004. + +====================================================================== +Table of Contents: + +1. OpenGL. +2. Wheel and multi-button mouses. +3. CDROM handling issues. +4. Hardware video overlays. +5. Shared library building. +6. Some building issues. +7. Environment variables. + +====================================================================== +1. OpenGL: + + OpenGL works well and is stable, but fullscreen mode has not been +heavily tested yet. + If you have QNX RtP version 6.1.0 or above you must download the +Photon3D runtime from http://developers.qnx.com or install it from the +public repository or from the public CD, available with QNX. OS versi- +ons below 6.1.0 are not supported. + When creating an OpenGL context, software renderer mode is artifi- +cially selected (QSSL made acceleration only for Voodoo boards in +fullscreen mode, sorry but I don't have this board to test OpenGL - +maybe it works or maybe not :)). If you want acceleration - you can +remove one line in the source code: find the file SDL_ph_image.c and +remove the following + + OGLAttrib[OGLargc++]=PHOGL_ATTRIB_FORCE_SW; + +line in the ph_SetupOpenGLContext() function or change the argument to +PHOGL_ATTRIB_FORCE_HW or PHOGL_ATTRIB_FAVOR_HW. + +====================================================================== +2. Wheel and multi-button mouses: + + Photon emits keyboard events (key up and down) when the mouse +wheel is moved. The key_scan field appears valid, and it contains zero. +That is a basic method of detecting mouse wheel events under Photon. +It looks like a hack, but it works for me :) on various PC configura- +tions. + +I've tested it on: + +1. Genius Optical NetScroll/+ PS/2 (1 wheel) +2. A4Tech Optical GreatEye WheelMouse PS/2, model: WOP-35. (2 wheels + + 2 additional buttons). The wheel for vertical scrolling works as + usual, but the second wheel for horizontal scrolling emits two se- + quential events up or down, so it can provide faster scrolling than + the first wheel. Additional buttons don't emit any events, but it + looks like they're handled by photon in an unusual way - like click + to front, but works not with any window, looks like a fun bug-o-fe- + ature :). + +====================================================================== +3. CDROM handling issues: + + Access to CDROM can only be provided with 'root' privileges. I +can't do anything about that, /dev/cd0 has brw------- permissions and +root:root rights. + +====================================================================== +4. Hardware video overlays: + + Overlays can flicker during window movement, resizing, etc. It +happens because the photon driver updates the real window contents be- +hind the overlay, then draws the temporary chroma key color over the +window contents. It can be done without using the chroma key but that +causes the overlay to always be on top. So flickering during window +movement is preferred instead. + Double buffering code is temporarily disabled in the photon driver +code, because on my GF2-MX it can accidentally cause a buffer switch, +which causes the old frame to show. S3 Savage4 has the same problem, +but ATI Rage 128 doesn't. I think it can be fixed later. Current code +works very well, so maybe double buffering is not needed right now. + Something strange happens when you try to move the window with the +overlay beyond the left border of the screen. The overlay tries to +stay at position x=0, but when attempting to move it a bit more it +jumps to position x=-60 (on GF2-MX, on ATI Rage128 this value a bit +smaller). It's really strange, looks like the overlay doesn't like +negative coordinates. + +======================================================================= +5. Shared library building: + + A shared library can be built, but before running the autogen.sh +script you must manually delete the libtool.m4 stuff from the acinclu- +de.m4 file (it comes after the ESD detection code up to the end of the +file), because the libtool stuff in the acinclude.m4 file was very old +in SDL distribution before the version 1.2.7 and doesn't knew anything +about QNX. SDL 1.2.7 distribution contains the new libtool.m4 script, +but anyway it is broken :), Just remove it, then run "libtoolize +--force --copy", delete the file aclocal.m4 if it is exists and after +that run the autogen.sh script. SDL 1.2.8 contains fixed libtool.m4, +ltmain.sh and config.sub files, so you can just run the autogen.sh +script. + +====================================================================== +6. Some building issues: + + Feel free to not use the --disable-shared configure option if you' +ve read the above comment about 'Shared library building'. Otherwise +this option is strongly recommended, as without it the sdl-config +script will be broken. + + Run the configure script without x11 support, e.g.: + + a) for OpenGL support: + ./configure --prefix=/usr \ + --disable-video-x11 \ + --disable-shared + + b) without OpenGL support: + ./configure --prefix=/usr \ + --disable-video-x11 \ + --disable-shared \ + --disable-video-opengl + + And of course dont forget to specify --disable-debug, which is on +by default, to disable debug and enable the expensive optimizations. + + In the test directory also run the ./configure script without +x11 support, e.g.: + + ./configure --with-sdl-prefix=/usr \ + --with-sdl-exec-prefix=/usr \ + --prefix=/usr --without-x + +====================================================================== +7. Environment variables: + + Please note that the photon driver is sensible to the following +environmental variables: + + * SDL_PHOTON_FULLSCREEN_REFRESH - this environment variable controls +the refresh rate in all fullscreen modes. Be carefull !!! Photon +drivers usually do not checking the maximum refresh rate, which video +adapter or monitor supports. + + * SDL_VIDEO_WINDOW_POS - can be set in the "X,Y" format. If X and Y +coordinates are bigger than the current desktop resolution, then win- +dow positioning across virtual consoles is activated. If X and Y are +smaller than the desktop resolution then window positioning in the +current console is activated. The word "center" can be used instead of +coordinates, it produces the same behavior as SDL_VIDEO_CENTERED +environmental variable. + + * SDL_VIDEO_CENTERED - if this environmental variable exists then the +window centering is perfomed in the current virtual console. + +Notes: The SDL_VIDEO_CENTERED enviromental variable has greater pri- +ority than the SDL_VIDEO_WINDOW_POS in case if both variables are sup- +plied to the application. diff --git a/Externals/SDL/README.Qtopia b/Externals/SDL/README.Qtopia new file mode 100644 index 0000000000..01627d1fb3 --- /dev/null +++ b/Externals/SDL/README.Qtopia @@ -0,0 +1,84 @@ + +============================================================================== +Using the Simple DirectMedia Layer with Qtopia/OPIE +============================================================================== + +============================================================================== +I. Setting up the Qtopia development environment. + + This document will not explain how to setup the Qtopia development + environment. That is outside the scope of the document. You can read + more on this subject in this excellent howto: + + http://www.zauruszone.com/howtos/linux_compiler_setup_howto.html + +============================================================================== +II. Building the Simple DirectMedia Layer libraries using the arm + cross-compiler + + This is somewhat tricky since the name of the compiler binaries + differ from the standard. Also you should disable features not + needed. The command below works for me. Note that it's all one + line. You can also set the NM, LD etc environment variables + separately. + + NM=arm-linux-nm LD=arm-linux-ld CC=arm-linux-gcc CXX=arm-linux-g++ RANLIB=arm-linux-ranlib AR=arm-linux-ar ./configure --enable-video-qtopia --disable-video-dummy --disable-video-fbcon --disable-video-dga --disable-arts --disable-esd --disable-alsa --disable-cdrom --disable-video-x11 --disable-nasm --prefix=/opt/Qtopia/sharp/ arm-unknown-linux-gnu + + One thing to note is that the above configure will include joystick + support, even though you can't have joysticks on the Zaurus. The + reason for this is to avoid link / compile / runtime errors with + applications that have joystick support. + +============================================================================== +III. Building the Simple DirectMedia Layer test programs: + + After installing, making sure the correct sdl-config is in your + path, run configure like this: + + NM=arm-linux-nm LD=arm-linux-ld CC=arm-linux-gcc CXX=arm-linux-g++ AR=arm-linux-ar ./configure arm-unknown-linux-gnu + +============================================================================== +IV. Application porting notes + + One thing I have noticed is that applications sometimes don't exit + correctly. Their icon remains in the taskbar and they tend to + relaunch themselves automatically. I believe this problem doesn't + occur if you exit your application using the exit() method. However, + if you end main() with 'return 0;' or so, this seems to happen. + + Also note that when running in landscape mode - i.e requesting a + window that is HEIGHT pixels wide and WIDTH pixels high, where WIDTH + and HEIGHT normally is 240 and 320 - the image is blitted so that + the hardware buttons are on the left side of the display. This might + not always be desirable but such is the code today. + + +============================================================================== +V. Enjoy! :) + + If you have a project you'd like me to know about, or want to ask questions, + go ahead and join the SDL developer's mailing list by sending e-mail to: + + sdl-request@libsdl.org + + and put "subscribe" into the subject of the message. Or alternatively you + can use the web interface: + + http://www.libsdl.org/mailman/listinfo/sdl + +============================================================================== +VI. What is supported: + +Keyboard (Sharp Zaurus) +Hardware buttons +Stylus input (mouse) +Video. Allows fullscreen both in portrait mode (up to WIDTHxHEIGHT +size window) and in landscape mode (up to HEIGHTxWIDTH). + +All other SDL functionality works like a normal Linux system (threads, +audio etc). + +-- +David Hedbor +http://david.hedbor.org/ http://eongames.com/ + diff --git a/Externals/SDL/README.RISCOS b/Externals/SDL/README.RISCOS new file mode 100644 index 0000000000..1ab85984a6 --- /dev/null +++ b/Externals/SDL/README.RISCOS @@ -0,0 +1,130 @@ +Readme for RISC OS port of SDL +============================== + +This document last updated on 2nd Februrary 2006 + +This is a RISC OS port of the Simple Direct Media Layer (SDL) by Alan Buckley with contributions from Peter Naulls. + +Details of the SDL can be found at http://www.libsdl.org. + +The source code including the RISC OS version can be obtained from: + +http://www.libsdl.org. + +Pre built libraries and many games and applications compiled for RISC OS using this library can be downloaded from The Unix Porting Project at http://www.riscos.info/unix/. + +This is released under the LGPL see the file COPYING for details. + + +Compiling applications under RISC OS +==================================== + +Add -ISDL: for the C compiler flags if you include the files in the SDL directory. e.g. #include "SDL/SDL.h" +Add -ISDL:SDL for the C compiler flags if you include the files directly. e.g. #include "SDL/SDL.h" + +Add -LSDL: -lSDL to the link stage of compilation. + +For example, to compile the testbitmap.c sample you could use: + +gcc -ISDL:SDL -LSDL: -lSDL testbitmap.c -otestbitmap + + +RISC OS port of SDL runtime information +======================================= + +Runtime requirements +-------------------- + +This library currently needs a minimum of RISC OS 3.6. The source code for the library (and a lot of the programs built with it) also need long file names. + +To use the audio you also need 16 bit sound and to have installed the DigitalRender module by Andreas Dehmel version 0.51 available from his +web site: http://home.t-online.de/~zarquon +This is loaded when needed by UnixLib. + +Note: As most programs ported from other OSes use high resolution graphics and a memory back buffer a machine with a StrongARM processor and 1 or 2MB of VRAM (or a better machine) is recomended. + + +RISC OS runtime parameters +-------------------------- + +Several environmental variables have been defined to make porting programs easier (i.e. By setting these variable you do not need to have source code differences between OSes). + +They are all defined on an application basis. + +The used below is found as follows: +1. Use the name of the program unless it is !RunImage +2. Check the folder specification for the folder !RunImage is run from. If it is a folder name use that name, otherwise if it is an environmental variable of the form use the value of XXX. + +The variables are: + +SDL$$TaskName + +The name of the task for RISC OS. If omitted then is used for the task name, + +SDL$$BackBuffer + +Set to 1 to use a system memory back buffer for the screen in full screen mode. Some programs on other systems assume their is always a back buffer even though the SDL specification specifies this is not the case. The current RISC OS implementation uses direct writes to the screen if a hardware fullscreen is requested. + +Set to 2 to use an ARM code full word copy. This is faster than the standard back buffer, but uses aligned words only so it is possible (but unlikely) for it to corrupt the screen for 8bpp and 16bpp modes. + +Set to 3 to use a RISC OS sprite as the back buffer. This is usually the slowest for most SDL applications, however it may be useful in the future as Sprite acceleration is added to various hardware that runs RISC OS. + +SDL$$CloseAction - set the action for the close icon. Again as programs don't match the specification you can set this to 0 to remove the close icon from the main window for applications where this does not affect the program. + + +RISC OS SDL port API notes +========================== + +Current level of implementation +------------------------------- + +The following list is an overview of how much of the SDL is implemented. The areas match the main areas of the SDL. + +video - Mostly done. Doesn't cover gamma, YUV-overlay or OpenGL. +Window Manager - Mostly done. SetIcon/IconifyWindow not implemented. +Events - Mostly done. Resize and some joystick events missing. +Joystick - Currently assumes a single joystick with 4 buttons. +Audio - Done +CDROM - Not implemented. +Threads - Done +Timers - Done + +Thread support can be removed by defining DISABLE_THREADS and recompiling the library. + +SDL API notes +------------- + +This section contains additional notes on some specific commands. + +SDL_SetVideoMode + On RISC OS a fullscreen mode directly accesses the screen. This can be modified by the environmental variable (SDL$$BackBuffer) or by using the SDL_SWSURFACE flag to write to an offscreen buffer that is updated using SDL_UpdateRects. + Open GL is not supported so SDL_OPENGL and SDL_OPENGLBLIT flags fail. + SDL_RESIZEABLE and SDL_NOFRAME flags are not supported. + +SDL_SetColors + In a wimp mode the screen colours are not changed for a hardware palette instead the RISC OS sprite colour mapping is used to get the best matching colours. + +SDL_CreateCursor + Inverted colour is not supported. + +SDL_WM_ToggleFullScreen + Currently this won't work if the application starts up in Fullscreen mode. + Toggling to fullscreen will only work if the monitor is set up to support the exact screen size requested. + +SDL_EnableUNICODE + Unicode translation used here is only really accurate for 7 bit characters. + +SDL_NumJoysticks/JoystickName etc. + Hardcoded to expect only 1 joystick with 4 buttons if the Joystick module is loaded. + +SDL_GetTicks + Timer used has only a centisecond accuracy. This applies to other time related functions. + +SDL_Delay + Modified to poll keyboard/mouse during the delay on the event thread. + + +Notes on current implementation +------------------------------- + +Keyboard and mouse are polled so if too long a time is spent between a call to SDL_PumpEvents, functions that use it, or SDL_Delay events can be missed. diff --git a/Externals/SDL/README.SVN b/Externals/SDL/README.SVN new file mode 100644 index 0000000000..65c5c427e2 --- /dev/null +++ b/Externals/SDL/README.SVN @@ -0,0 +1,23 @@ + +The latest development version of SDL is available via Subversion. +Subversion allows you to get up-to-the-minute fixes and enhancements; +as a developer works on a source tree, you can use svn to mirror that +source tree instead of waiting for an official release. Please look +at the Subversion website ( http://subversion.tigris.org/ ) for more +information on using svn, where you can also download software for +MacOS, Windows, and Unix systems. + + svn checkout http://svn.libsdl.org/branches/SDL-1.2 + +If you are building SDL with an IDE, you will need to copy the file +include/SDL_config.h.default to include/SDL_config.h before building. + +If you are building SDL via configure, you will need to run autogen.sh +before running configure. + +There is a web interface to the subversion repository at: + http://www.libsdl.org/cgi/viewvc.cgi + +There is an RSS feed available at that URL, for those that want to +track commits in real time. + diff --git a/Externals/SDL/README.Symbian b/Externals/SDL/README.Symbian new file mode 100644 index 0000000000..32d925a00d --- /dev/null +++ b/Externals/SDL/README.Symbian @@ -0,0 +1,23 @@ +============================================================================== +Using the Simple DirectMedia Layer with S60 3.x / Symbian 9.x +============================================================================== + +These instuctions are for people developing for S60 3.x. S60 3.x +uses Symbian OS so you need S60 SDK. + +extract "symbian.zip" into this folder. + +go to symbian folder + +bldmake bldfiles +abld build + +That produces WINSCW and ARMV5 versions of sdl.dll runtime library +and sdl.lib for development. +The sdlexe.dll/sdlexe.lib and sdlmain.lib are for easy SDL S60 +integration, please see http://www.mbnet.fi/~mertama/sdl.html +for further info. + + + + diff --git a/Externals/SDL/README.Watcom b/Externals/SDL/README.Watcom new file mode 100644 index 0000000000..8ed391fc83 --- /dev/null +++ b/Externals/SDL/README.Watcom @@ -0,0 +1,133 @@ + +Using SDL under Windows with the OpenWatcom compiler +==================================================== + +Prerequisites +------------- + +I have done the port under Windows XP Home with SP2 installed. Windows +2000 should also be working. I'm not so sure about ancient Windows NT, +since only DirectX 3 is available there. Building should be possible, +but running the compiled applications will probalbly fail with +SDL_VIDEODRIVER=directx. The windib driver should work, though. + +To compile and use the SDL with Open Watcom you will need the following: +- Open Watcom compiler. I used version 1.5. The environment variables + PATH, WATCOM and INCLUDE need to be set appropriately - please consult + the OpenWatcom documentation and instructions given during the + installation of the compiler. + My setup looks like this in owvars.bat: + set WATCOM=C:\watcom + set INCLUDE=%WATCOM%\h;%WATCOM%\h\nt + set PATH=%PATH%;%WATCOM%\binnt;%WATCOM%\binw +- A fairly recent DirectX SDK. The original unmodified DX8 SDK works, as + well as the minimal DirectX 7 SDK from the Allegro download site + (). +- The SDL sources from Subversion +- The file Watcom-Win32.zip (now available in Subversion) + + +Building the Library +-------------------- + +1) In the SDL base directory extract the archive Watcom-Win32.zip. This + creates a subdirectory named 'watcom'. +2) The makefile expects the environment variable DXDIR to be set to the + base directory of a DirectX SDK. I have tried a stock DX8 SDK from + Microsoft as well as the minimal DirectX 7 SDK from the Allegro + download site. + You can also edit the makefile directly and hard code your path to + the SDK on your system. + I have this in my setup: + set DXDIR=D:\devel\DX8_SDK +3) Enter the watcom directory and run + wmake sdl +4) All tests from the test directory are working and can be built by + running + wmake tests + +Notes: + + The makefile offers some options to tweak the way the library is built. + You have at your disposal the option to build a static (default) + library, or a DLL (with tgt=dll). You can also choose whether to build + a Release (default) or a Debug version (with build=debug) of the tests + and library. Please consult the usage comment at the top of the + makefile for usage instructions. + + If you specify a test target (i.e. 'wmake tests' for all tests, or + selected targets like 'wmake testgl testvidinfo testoverlay2'), the + tests are always freshly compiled and linked. This is done to + minimise hassle when switching between library versions (static vs. + DLL), because they require subtly different options. + Also, the test executables are put directly into the test directory, + so they can find their data files. The clean target of the makefile + removes the test executables and the SDL.dll file from the test + directory. + + To use the library in your own projects with Open Watcom, you can use + the way the tests are built as base of your own build environment. + + The library can also be built with the stack calling convention of the + compiler (-6s instead of -6r). + + +Test applications +----------------- + +I've tried to make all tests work. The following table gives an overview +of the current status. + + Testname Status +~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +checkkeys + +graywin + +loopwave + +testalpha + +testbitmap + +testdyngl + +testerror + +testfile + +testgamma + +testgl + +testhread + +testiconv - (all failed) +testkeys + +testlock + +testoverlay + (needs 'set SDL_VIDEODRIVER=directx') +testoverlay2 + (needs 'set SDL_VIDEODRIVER=directx') +testpalette + +testplatform + +testsem + +testsprite + +testtimer + +testver + +testvidinfo + +testwin ? (fading doesn't seem right) +testwm + +torturethread + +testcdrom + +testjoystick not tested +threadwin + +testcursor + + + +TODO +---- + +There is room for further improvement: +- Test joystick functionality. +- Investigate fading issue in 'testwin' test. +- Fix the UTF-8 support. +- Adapt the makefile/object file list to support more target systems +- Use "#pragma aux" syntax for the CPU info functions. + + +Questions and Comments +---------------------- + +Please direct any questions or comments to me: + + Happy Coding! + + Marc Peter diff --git a/Externals/SDL/README.WinCE b/Externals/SDL/README.WinCE new file mode 100644 index 0000000000..6f8799ef80 --- /dev/null +++ b/Externals/SDL/README.WinCE @@ -0,0 +1,55 @@ + +Project files for embedded Visual C++ 3.0, 4.0 and +Visual Studio 2005 can be found in VisualCE.zip + +SDL supports GAPI and WinDib output for Windows CE. + +GAPI driver supports: + +- all possible WinCE devices (Pocket PC, Smartphones, HPC) + with different orientations of video memory and resolutions. +- 4, 8 and 16 bpp devices +- special handling of 8bpp on 8bpp devices +- VGA mode, you can even switch between VGA and GAPI in runtime + (between 240x320 and 480x640 for example). On VGA devices you can + use either GAPI or VGA. +- Landscape mode and automatic rotation of buttons and stylus coordinates. + To enable landscape mode make width of video screen bigger than height. + For example: + SDL_SetVideoMode(320,240,16,SDL_FULLSCREEN) +- WM2005 +- SDL_ListModes + +NOTE: +There are several SDL features not available in the WinCE port of SDL. + +- DirectX is not yet available +- Semaphores are not available +- Joystick support is not available +- CD-ROM control is not available + +In addition, there are several features that run in "degraded" mode: + +Preprocessor Symbol Effect +=================== ================================= + +SDL_systimer.c: +USE_GETTICKCOUNT Less accurate values for SDL time functions +USE_SETTIMER Use only a single marginally accurate timer + +SDL_syswm.c: +DISABLE_ICON_SUPPORT Can't set the runtime window icon + +SDL_sysmouse.c: +USE_STATIC_CURSOR Only the arrow cursor is available + +SDL_sysevents.c: +NO_GETKEYBOARDSTATE Can't get modifier state on keyboard focus + +SDL_dibevents.c: +NO_GETKEYBOARDSTATE Very limited keycode translation + +SDL_dibvideo.c: +NO_GETDIBITS Can't distinguish between 15 bpp and 16 bpp +NO_CHANGEDISPLAYSETTINGS No fullscreen support +NO_GAMMA_SUPPORT Gamma correction not available diff --git a/Externals/SDL/README.wscons b/Externals/SDL/README.wscons new file mode 100644 index 0000000000..349c89c999 --- /dev/null +++ b/Externals/SDL/README.wscons @@ -0,0 +1,107 @@ +============================================================================== +Using the Simple DirectMedia Layer with OpenBSD/wscons +============================================================================== + +The wscons SDL driver can be used to run SDL programs on OpenBSD +without running X. So far, the driver only runs on the Sharp Zaurus, +but the driver is written to be easily extended for other machines. +The main missing pieces are blitting routines for anything but 16 bit +displays, and keycode maps for other keyboards. Also, there is no +support for hardware palettes. + +There is currently no mouse support. + +To compile SDL with support for wscons, use the +"--enable-video-wscons" option when running configure. I used the +following command line: + +./configure --disable-oss --disable-ltdl --enable-pthread-sem \ + --disable-esd --disable-arts --disable-video-aalib \ + --enable-openbsdaudio --enable-video-wscons \ + --prefix=/usr/local --sysconfdir=/etc + + +Setting the console device to use +================================= + +When starting an SDL program on a wscons console, the driver uses the +current virtual terminal (usually /dev/ttyC0). To force the driver to +use a specific terminal device, set the environment variable +SDL_WSCONSDEV: + +bash$ SDL_WSCONSDEV=/dev/ttyC1 ./some-sdl-program + +This is especially useful when starting an SDL program from a remote +login prompt (which is great for development). If you do this, and +want to use keyboard input, you should avoid having some other program +reading from the used virtual console (i.e., do not have a getty +running). + + +Rotating the display +==================== + +The display can be rotated by the wscons SDL driver. This is useful +for the Sharp Zaurus, since the display hardware is wired so that it +is correctly rotated only when the display is folded into "PDA mode." +When using the Zaurus in "normal," or "keyboard" mode, the hardware +screen is rotated 90 degrees anti-clockwise. + +To let the wscons SDL driver rotate the screen, set the environment +variable SDL_VIDEO_WSCONS_ROTATION to "CW", "CCW", or "UD", for +clockwise, counter clockwise, and upside-down rotation respectively. +"CW" makes the screen appear correct on a Sharp Zaurus SL-C3100. + +When using rotation in the driver, a "shadow" frame buffer is used to +hold the intermediary display, before blitting it to the actual +hardware frame buffer. This slows down performance a bit. + +For completeness, the rotation "NONE" can be specified to use a shadow +frame buffer without actually rotating. Unsetting +SDL_VIDEO_WSCONS_ROTATION, or setting it to '' turns off the shadow +frame buffer for maximum performance. + + +Running MAME +============ + +Since my main motivation for writing the driver was playing MAME on +the Zaurus, I'll give a few hints: + +XMame compiles just fine under OpenBSD. + +I'm not sure this is strictly necessary, but set + +MY_CPU = arm + +in makefile.unix, and + +CFLAGS.arm = -DLSB_FIRST -DALIGN_INTS -DALIGN_SHORTS + +in src/unix/unix.max + +to be sure. + +The latest XMame (0.101 at this writing) is a very large program. +Either tinker with the make files to compile a version without support +for all drivers, or, get an older version of XMame. My recommendation +would be 0.37b16. + +When running MAME, DO NOT SET SDL_VIDEO_WSCONS_ROTATION! Performace +is MUCH better without this, and it is COMPLETELY UNNECESSARY, since +MAME can rotate the picture itself while drawing, and does so MUCH +FASTER. + +Use the Xmame command line option "-ror" to rotate the picture to the +right. + + +Acknowledgments +=============== + +I studied the wsfb driver for XFree86/Xorg quite a bit before writing +this, so there ought to be some similarities. + + +-- +Staffan Ulfberg diff --git a/Externals/SDL/SDL.qpg.in b/Externals/SDL/SDL.qpg.in new file mode 100644 index 0000000000..8e1ff8da87 --- /dev/null +++ b/Externals/SDL/SDL.qpg.in @@ -0,0 +1,140 @@ + + + + + + + + + + + + + + + + QNX.ORG.RU Community + + + QNX.ORG.RU Team + Mike Gorchak + mike@malva.ua + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Library + SDL + 1 + http://qnx.org.ru/repository + 2.6 + + + + Simple DirectMedia Layer (SDL) + SDL + slouken@libsdl.org + Public + public + http://www.libsdl.org + + slouken@libsdl.org + Sam Lantinga + http://www.libsdl.org + + slouken@libsdl.org + + + This is the Simple DirectMedia Layer (SDL), a generic API that provides low level access to audio, keyboard, mouse, and display framebuffer across multiple platforms. + This is the Simple DirectMedia Layer (SDL), a generic API that provides low level access to audio, keyboard, mouse, and display framebuffer across multiple platforms. This is the libraries, include files and other resources you can use to develop and run SDL applications. + http://www.libsdl.org + + + + + @VERSION@ + Medium + Stable + + + 1 + + GNU Lesser General Public License + + + + Software Development/Libraries and Extensions/C Libraries + SDL,audio,graphics,demos,games,emulators,direct,media,layer + qnx6 + none + Photon + Console + Developer + User + + repdata://LicenseUrl/COPYING + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Externals/SDL/SDL.spec b/Externals/SDL/SDL.spec new file mode 100644 index 0000000000..fb505310be --- /dev/null +++ b/Externals/SDL/SDL.spec @@ -0,0 +1,113 @@ +Summary: Simple DirectMedia Layer +Name: SDL +Version: 1.2.14 +Release: 1 +Source: http://www.libsdl.org/release/%{name}-%{version}.tar.gz +URL: http://www.libsdl.org/ +License: LGPL +Group: System Environment/Libraries +BuildRoot: %{_tmppath}/%{name}-%{version}-buildroot +Prefix: %{_prefix} +%ifos linux +Provides: libSDL-1.2.so.0 +%endif + +%define __defattr %defattr(-,root,root) +%define __soext so + +%description +This is the Simple DirectMedia Layer, a generic API that provides low +level access to audio, keyboard, mouse, and display framebuffer across +multiple platforms. + +%package devel +Summary: Libraries, includes and more to develop SDL applications. +Group: Development/Libraries +Requires: %{name} = %{version} + +%description devel +This is the Simple DirectMedia Layer, a generic API that provides low +level access to audio, keyboard, mouse, and display framebuffer across +multiple platforms. + +This is the libraries, include files and other resources you can use +to develop SDL applications. + + +%prep +%setup -q + +%build +%ifos linux +CFLAGS="$RPM_OPT_FLAGS" ./configure --prefix=%{prefix} --disable-video-aalib --disable-video-directfb --disable-video-ggi --disable-video-svga +%else +%configure +%endif +make + +%install +rm -rf $RPM_BUILD_ROOT +%ifos linux +make install prefix=$RPM_BUILD_ROOT%{prefix} \ + bindir=$RPM_BUILD_ROOT%{_bindir} \ + libdir=$RPM_BUILD_ROOT%{_libdir} \ + includedir=$RPM_BUILD_ROOT%{_includedir} \ + datadir=$RPM_BUILD_ROOT%{_datadir} \ + mandir=$RPM_BUILD_ROOT%{_mandir} +ln -s libSDL-1.2.so.0 $RPM_BUILD_ROOT%{_libdir}/libSDL-1.1.so.0 +%else +%makeinstall +%endif + +%clean +rm -rf $RPM_BUILD_ROOT + +%files +%{__defattr} +%doc README-SDL.txt COPYING CREDITS BUGS +%{_libdir}/lib*.%{__soext}.* + +%files devel +%{__defattr} +%doc README README-SDL.txt COPYING CREDITS BUGS WhatsNew docs.html +%doc docs/index.html docs/html +%{_bindir}/*-config +%{_libdir}/lib*.a +%{_libdir}/lib*.la +%{_libdir}/lib*.%{__soext} +%dir %{_includedir}/SDL +%{_includedir}/SDL/*.h +%{_libdir}/pkgconfig/sdl.pc +%{_datadir}/aclocal/* +%{_mandir}/man3/* + +%changelog +* Tue May 16 2006 Sam Lantinga +- Removed support for Darwin, due to build problems on ps2linux + +* Mon Jan 03 2004 Anders Bjorklund +- Added support for Darwin, updated spec file + +* Wed Jan 19 2000 Sam Lantinga +- Re-integrated spec file into SDL distribution +- 'name' and 'version' come from configure +- Some of the documentation is devel specific +- Removed SMP support from %build - it doesn't work with libtool anyway + +* Tue Jan 18 2000 Hakan Tandogan +- Hacked Mandrake sdl spec to build 1.1 + +* Sun Dec 19 1999 John Buswell +- Build Release + +* Sat Dec 18 1999 John Buswell +- Add symlink for libSDL-1.0.so.0 required by sdlbomber +- Added docs + +* Thu Dec 09 1999 Lenny Cartier +- v 1.0.0 + +* Mon Nov 1 1999 Chmouel Boudjnah +- First spec file for Mandrake distribution. + +# end of file diff --git a/Externals/SDL/SDL.spec.in b/Externals/SDL/SDL.spec.in new file mode 100644 index 0000000000..dbda11210a --- /dev/null +++ b/Externals/SDL/SDL.spec.in @@ -0,0 +1,113 @@ +Summary: Simple DirectMedia Layer +Name: SDL +Version: @SDL_VERSION@ +Release: 1 +Source: http://www.libsdl.org/release/%{name}-%{version}.tar.gz +URL: http://www.libsdl.org/ +License: LGPL +Group: System Environment/Libraries +BuildRoot: %{_tmppath}/%{name}-%{version}-buildroot +Prefix: %{_prefix} +%ifos linux +Provides: libSDL-1.2.so.0 +%endif + +%define __defattr %defattr(-,root,root) +%define __soext so + +%description +This is the Simple DirectMedia Layer, a generic API that provides low +level access to audio, keyboard, mouse, and display framebuffer across +multiple platforms. + +%package devel +Summary: Libraries, includes and more to develop SDL applications. +Group: Development/Libraries +Requires: %{name} = %{version} + +%description devel +This is the Simple DirectMedia Layer, a generic API that provides low +level access to audio, keyboard, mouse, and display framebuffer across +multiple platforms. + +This is the libraries, include files and other resources you can use +to develop SDL applications. + + +%prep +%setup -q + +%build +%ifos linux +CFLAGS="$RPM_OPT_FLAGS" ./configure --prefix=%{prefix} --disable-video-aalib --disable-video-directfb --disable-video-ggi --disable-video-svga +%else +%configure +%endif +make + +%install +rm -rf $RPM_BUILD_ROOT +%ifos linux +make install prefix=$RPM_BUILD_ROOT%{prefix} \ + bindir=$RPM_BUILD_ROOT%{_bindir} \ + libdir=$RPM_BUILD_ROOT%{_libdir} \ + includedir=$RPM_BUILD_ROOT%{_includedir} \ + datadir=$RPM_BUILD_ROOT%{_datadir} \ + mandir=$RPM_BUILD_ROOT%{_mandir} +ln -s libSDL-1.2.so.0 $RPM_BUILD_ROOT%{_libdir}/libSDL-1.1.so.0 +%else +%makeinstall +%endif + +%clean +rm -rf $RPM_BUILD_ROOT + +%files +%{__defattr} +%doc README-SDL.txt COPYING CREDITS BUGS +%{_libdir}/lib*.%{__soext}.* + +%files devel +%{__defattr} +%doc README README-SDL.txt COPYING CREDITS BUGS WhatsNew docs.html +%doc docs/index.html docs/html +%{_bindir}/*-config +%{_libdir}/lib*.a +%{_libdir}/lib*.la +%{_libdir}/lib*.%{__soext} +%dir %{_includedir}/SDL +%{_includedir}/SDL/*.h +%{_libdir}/pkgconfig/sdl.pc +%{_datadir}/aclocal/* +%{_mandir}/man3/* + +%changelog +* Tue May 16 2006 Sam Lantinga +- Removed support for Darwin, due to build problems on ps2linux + +* Mon Jan 03 2004 Anders Bjorklund +- Added support for Darwin, updated spec file + +* Wed Jan 19 2000 Sam Lantinga +- Re-integrated spec file into SDL distribution +- 'name' and 'version' come from configure +- Some of the documentation is devel specific +- Removed SMP support from %build - it doesn't work with libtool anyway + +* Tue Jan 18 2000 Hakan Tandogan +- Hacked Mandrake sdl spec to build 1.1 + +* Sun Dec 19 1999 John Buswell +- Build Release + +* Sat Dec 18 1999 John Buswell +- Add symlink for libSDL-1.0.so.0 required by sdlbomber +- Added docs + +* Thu Dec 09 1999 Lenny Cartier +- v 1.0.0 + +* Mon Nov 1 1999 Chmouel Boudjnah +- First spec file for Mandrake distribution. + +# end of file diff --git a/Externals/SDL/TODO b/Externals/SDL/TODO new file mode 100644 index 0000000000..65bb01c17a --- /dev/null +++ b/Externals/SDL/TODO @@ -0,0 +1,25 @@ + +Wish list for the 1.3 development branch: +http://bugzilla.libsdl.org/ + + * Add mousewheel events (new unified event architecture?) + * DirectInput joystick support needs to be implemented + * Be able to enumerate and select available audio and video drivers + * Fullscreen video mode support for Mac OS X + * Explicit vertical retrace wait (maybe separate from SDL_Flip?) + * Shaped windows, windows without borders + * Multiple windows, multiple display support + * SDL_INIT_EVENTTHREAD on Windows and MacOS? + * Add a timestamp to events + * Add audio input API + * Add hardware accelerated scaled blit + * Add hardware accelerated alpha blits + * Redesign blitting architecture to allow blit plugins + +In the jump from 1.2 to 1.3, we should change the SDL_Rect members to +int and evaluate all the rest of the datatypes. This is the only place +we should do it though, since the 1.2 series should not break binary +compatibility in this way. + +Requests: + * PCM and CDROM volume control (deprecated, but possible) diff --git a/Externals/SDL/VisualC.html b/Externals/SDL/VisualC.html new file mode 100644 index 0000000000..ad2ed97a60 --- /dev/null +++ b/Externals/SDL/VisualC.html @@ -0,0 +1,171 @@ + + + Using SDL with Microsoft Visual C++ + + +

+ Using SDL with Microsoft Visual C++ 5,6 and 7 +

+

+ by Lion Kimbro and additions by + James Turk +

+

+ You can either use the precompiled libraries from + the SDL Download web site , or you can build SDL yourself. +

+

+ Building SDL +

+

+ Unzip the VisualC.zip file into the directory that contains this + file (VisualC.html). +

+

+ Be certain that you unzip the zip file for your compiler into this + directory and not any other directory. If you are using WinZip, be careful to + make sure that it extracts to this folder, because it's + convenient feature of unzipping to a folder with the name of the file currently + being unzipped will get you in trouble if you use it right now. And that's all + I have to say about that. +

+

+ Now that it's unzipped, go into the VisualC + directory that is created, and double-click on the VC++ file "SDL.dsw" + ("SDL.sln"). This should open up the IDE. +

+

+ You may be prompted at this point to upgrade the workspace, should you be using + a more recent version of Visual C++. If so, allow the workspace to be upgraded. +

+

+ Build the .dll and .lib files. +

+

+ This is done by right clicking on each project in turn (Projects are listed in + the Workspace panel in the FileView tab), and selecting "Build". +

+

+ If you get an error about SDL_config.h being missing, you should + copy include/SDL_config.h.default to include/SDL_config.h and try again. +

+

+ You may get a few warnings, but you should not get any errors. You do have to + have at least the DirectX 5 SDK installed, however. The latest + version of DirectX can be downloaded or purchased on a cheap CD (my + recommendation) from Microsoft . +

+

+ Later, we will refer to the following .lib and .dll files that have just been + generated: +

+
    +
  • SDL.dll
  • +
  • SDL.lib
  • +
  • SDLmain.lib
  • +
+

+ Search for these using the Windows Find (Windows-F) utility, if you don't + already know where they should be. For those of you with a clue, look inside + the Debug or Release directories of the subdirectories of the Project folder. + (It might be easier to just use Windows Find if this sounds confusing. And + don't worry about needing a clue; we all need visits from the clue fairy + frequently.) +

+

+ Creating a Project with SDL +

+

+ Create a project as a Win32 Application. +

+

+ Create a C++ file for your project. +

+

+ Set the C runtime to "Multi-threaded DLL" in the menu: Project|Settings|C/C++ + tab|Code Generation|Runtime Library . +

+

+ Add the SDL include directory to your list of includes in the + menu: Project|Settings|C/C++ tab|Preprocessor|Additional include directories + . +
+ VC7 Specific: Instead of doing this I find it easier to + add the include and library directories to the list that VC7 keeps. Do this by + selecting Tools|Options|Projects|VC++ Directories and under the "Show + Directories For:" dropbox select "Include Files", and click the "New Directory + Icon" and add the [SDLROOT]\include directory (ex. If you installed to + c:\SDL-1.2.5\ add c:\SDL-1.2.5\include). Proceed to change the + dropbox selection to "Library Files" and add [SDLROOT]\lib. +

+

+ The "include directory" I am referring to is the include folder + within the main SDL directory (the one that this HTML file located within). +

+

+ Now we're going to use the files that we had created earlier in the Build SDL + step. +

+

+ Copy the following files into your Project directory: +

+
    +
  • SDL.dll
  • +
+

+ Add the following files to your project (It is not necessary to copy them to + your project directory): +

+
    +
  • SDL.lib
  • +
  • SDLmain.lib
  • +
+

+ (To add them to your project, right click on your project, and select "Add + files to project") +

+

Instead of adding the files to your project it is more + desireable to add them to the linker options: Project|Properties|Linker|Command + Line and type the names of the libraries to link with in the "Additional + Options:" box.  Note: This must be done for each build + configuration (eg. Release,Debug).

+

+ SDL 101, First Day of Class +

+

+ Now create the basic body of your project. The body of your program should take + the following form: +

+#include "SDL.h"
+
+int main( int argc, char* argv[] )
+{
+  // Body of the program goes here.
+  return 0;
+}
+
+ +

+

+ That's it! +

+

+ I hope that this document has helped you get through the most difficult part of + using the SDL: installing it. Suggestions for improvements to this document + should be sent to the writers of this document. +

+

+ Thanks to Paulus Esterhazy (pesterhazy@gmx.net), for the work on VC++ port. +

+

+ This document was originally called "VisualC.txt", and was written by + Sam Lantinga. +

+

+ Later, it was converted to HTML and expanded into the document that you see + today by Lion Kimbro. +

+

Minor Fixes and Visual C++ 7 Information (In Green) was added by James Turk +

+ + diff --git a/Externals/SDL/VisualC.zip b/Externals/SDL/VisualC.zip new file mode 100644 index 0000000000000000000000000000000000000000..5ee0c63d06893ab948e5523cecb0016d412a8933 GIT binary patch literal 43373 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
sp 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

  • %#Qc=hNaAZTBI8^^2t554-k8PI|3pggL) z&rU}?n@*n8->myW(ocH!Z^zt8YXn>;@&a z^LD)V^f${-)ouX!6dyeNu%mhlMx?qVv>9RAN4SmRcts;6_220Jv;)JX+YFQZKJYTgp5!&nP zIO!PGpy>X(M*UrLJyZko%asP$-3Xj%()E=2TPkw%lIgULWY;^W?}{QflCTcwU!}bb z)FnhsB&&Oezp7XGjy=9%V_X|#pQF;1Rkv5Y$^Xr?x;BZ9Mcf`ZBKs05T{nT_V(})Q zTR?{DNyJy2CK2>*BXDK)NzePX3u{ZhBbeHZ`ZqmJ~?sfW-$9Pk9FJKY@ldOAF zs>`RA;$}km zXz3 zGG>m&))}=%1`Ia-5QAJ|fX?eFBX-TU_T8C>Z^rcA%rmaIryG*|X&&8?f$ntUthx1A zC^Rm9K2*WwE^NW(kV(`MmrZCl=~_ec31ssYU`vKUzLa49%gcq0woMQqBDV~qB6HTH zr{npaT0o=8%)q$NirsC<v;y2w`_YI2n*IXW3&@~PrBxwZWTImSi+d=3=OUY z{lW0N^otFDqMl&*llA_+&QyeHoO*vCEQaxfKd~~QSa0b?2keZ8T*lNy_MkUKyVoSV z2m|S@xUaxssJ*hY2Z4qJ#$2^(s}=Zh<|EfsRUFI{YmBnOsD6ap}UwM1&u3PjYLer zen>%>T|t7~OFi`*&r zHi=Q722M%*n0er=O?&(i0pAOIVdGPHIUo#{XVjUhw?u^&YJNngXL;~TF^M8@Ai?%9 zLFjyfSS0up6Yzd`oYsms$D#AX?2IlY$?V=FE8WR6BP8)iGNu?*FBIHC9i2e1b$;hfTl!~y)(@?4z!K#Bdskq7%N)XJ8_|GiaUAQO!G8PZ1;XKs8lc= zLezadd>_6UwDDGdpR6}EfW1&+yT1c0bju4`K5mHImq1T?SGZdNY{tuUt5>>9s`*)P zV|dMPC1LwE_;~i?Ae3mIaKDeK{^nUT%@H|s-b^R6^i}lg9Y}Y6wzZ1+WVC3j{)Oss zOZg{|h7e_&rxUVD-$c&_I(8ZSUTmQC5+JdMLUpZi#uM%qa=Wj-#8^cU^n}DFeH(=j zQKm=GE65gTwS&Jd^rt#@!C3msQlaikbtYHV4w^Z3;eFs^4E8?BViO3dE4NzD!e;9X z1E*58Rd`4>#BZe1lTBMo1ip-LJLwTOG=xz;5G{+`3SR4>r?@?bq0w`&AR|B~m`gcu zkP?B@S^gt|ZIlv$AG?5jYT;BM5;GD{n9^z2m9%x+Ul{h_yBeZNNmkrOY(~>k7-#Co z!%w;QzCUmi^Ib!(d4Yx!oiRFNA|-?rRHsec>VO-gumN|Aot78XltT6ap#o_7vZlzWI zp!SsQtS#29>VJNn^mI~HMOVnsW1RF8T+?ZHO0B`gRmqLzzQz)R+Y1a%E5c=c?7SLV z#pLCm$dK2BJ?Hol zYp#BHE07ivPH!+jk0#m9BpId_yaL2h$r)-E-$rUjg-ePO%U0WnmcfTn2Cw-M8N4kl zgQ+5u4DN)gyy-v6U@ib{K$5>^jaL-0 ze-o~uEVayDHB@g6*H65G>7mywnTIoPAitr0s!&sV)le(`E57NDKUB{gGnW?=NT|D( z?CBQjt2jSexRSP7m9)&Nq#)MuIK}@d680$h+scjHwOMs0nHf~NR9yc|?*SFYM;w&ELclwe7^(BzR_P<(_ z|4!NmQ*1l{gbyY7kAP6m9r)ZMxUJ+JP_F4}-;X@C-~82Q8&Df)!3|lj_3(--5YF%} z#DYNPwj|t%EX~FnH=NUWWAL?f-HbZBp$@|$mTKiU+;Q#5JA8uzyImRQmVC9YmT3HU@J2X1vG$#3Pt~oCx+D1X z+rjk1p8YUzaq1maW3sY^(;0hLc2*qr*BLXEb;!Q_GYnU3UXOgtX^@`c^*g~B=4-e3 z(n4qV2U?xmn{$(yODA^|p%Z@0x)IX}yfD+Mp$dE*qAH4aeIz6)cq@(WjL}}Ol^@5QRpsaKsJRxv+do$Sdr#BCo;v;)p3bP2r!)TxPk*x>g8f#)x8X-B zbeC+t14k?CF@wxyv;{?3kD1@L0tD2w5+jnA8B?jPw*8Clo_0%^mAE*vbZGgxwmdAksXDGzCP1*E*D+Yam|Vl9?W(4So&Z?VFMAYNC6X z+)fM3i#9_B-$a^?7-Kup+)p$L#q=fOSWFljam3f(w||M$2hSoky)kmGWNC8X+=8Xv zz&VE&dG>vrh{lYi>9~GbOpwF z7n-g|6K*`-J{e6fqG>jo{)VOsH2n!pe?Zf3(6kFpI+_lm=@B%=V5#}hbP1a7BhF~L z6HN=yG!sp~Leo?v$8dzF^`r6P&tX|aS3#of1-I*A^s(}2)q^j zm@XQ0?>yz@k021AF|Z z&LE-|Z?S#{k1=Be%xN~>jEcf>2<}L&J1Wrvzpp=U2f3cM4ETy@ivaesziz<}M0pY; zp2ll?b**-5dCxoot&wL)emy<$N9b_MzbymllD_>he!oIGe5u(eqx4W53RnS}1KBX% zNNVC<`xYbqKoUKSIDv9bZ}#jrub3nVq)M)zJQ8=)PQmZs1Ki7vUx!G8k$86!Uq+8h zZbSkZbrA2Xho2XI6Y=tWoCh!jyiE8?hrs1N(OqPY{Uu#=I>xi#v&U0w3J|Pq?PDT3 zrU&+;o-JstKN}j2D%n#0qbQX+>%xh zd0OZ`pF3p%URi}#=HOxNQ2U!T>3+zg#e6bNp*UeQ%m?$J&{N!=JtA#(#@ko>?Bys= zcMpTinUzPo)>Vrl3n&u1DTV^Y7@%N=d&FIR_Uc`D?Ka?3*(dVu=(879FJq;9SlU6r zO~Gl~0q4?8+|rIubqx3nOcN=D$(Wmc-ov}9b#M{i0PTKapN?$2q!wQhpsl}nY99EE zDKP)1nl*V7-{=5TIs`PzEXbv>r|93Cjy&3iKVBF4dar4UKAOt54?duggr&P43pY}( z5NekGot4kPwJ6QZXx0KdaWIWp?e3Y?sSEga!rLc?GkXuW*YJLCdfkF5;0~OVf?Ajs z$ZRI9G<63>DJcsp7va`rQB=ZPg~NoVd3F^@C#$wNQA_u9LTvCjOLR2>5#Tv|pShr< z>;}-s{*eR2Er?V3Y3wOienuYD9vB5+K>;$i<9*xv{?N!(e!*) z*Q%WCT;DU1EZ^uofu?Sq&s>&e-Ir&6IRUTc3!irhyU&QYzXk62TAC6~VqO<<|Ci-1 z^>FW>#k$VqY(khZ5&B1%zD$UwcfTkJt!jP9GVGjI;Y?6ez@bklO75v_P znazI7+}j>D<9%(1&0pQf(}pILviahTxVxyh{J7AeHxsrIz`RES&jDc6{S#pw+_$+Iw$4(Hm_R0Y-1c2P7`qikl(LpYc5ygg!zAZWA8NJo=vm)JTz{gFgKrv#+h;R>E39_!&J;eyoa;=W6H$Swxub7(~9rL zt#}a7{Aq75%kl!JWBfDaL?M(p11#UPDGN+#Jrb2kQ=g;(<@8$rvH_5#Nk+@^`?jKBHa{ERJ9_^dPbbwOJLo~oJ-rFI3~+R0zR=rkD-My&-=6Qq4qmVx znGc-r=I|Y($eZ(eyFnrakXYA30>M8Hnar{01&O04^YZi1xWHvP&r4mOv82EzgZx`K zmW6Q6=}@Tbtul+?GA6iW+~C)tL-5;4&b9B?$!gN+hx${{a!}5-ZxzD*ZQz7r7XB6R z4cy)lTY8y!=SRF!aXExH8q8bJxe~e?rwh*`G}Pd|^d>%5wbkt5acGpsGarISbas|S zdAbrl#Ljb=5LGE|v!B2_RC{fSoHj#yS|QSY7fQ~<0MMNm1QmtFTdeA4h0ogbuM|N6)t7t#JWf8q+h@cyJ8 zUVfN=(*^mL)ZmoCbwYRvlu z4Mo=l8f%MrPO!{9;u{Vd;<_c{N8*Zqz1O30zBBU~@~&W`ENLDYxiVTQp=jW2s;TgV zt2w2UjxG*224m!m(MSP^N;uWpFi!2?rPE!#RxG2ldH0xJ44huGb&SQpb%FiMxch33+hw|;1?nGF2gU<5 zm&2zzXT155jSffUjPsV@6d=lnLzE3U<})$a8N{yqu2d-5iGGf1`C>6Hh<0pDwd zBy+&CENh>V18BX4ttIcEP4#q@85=^ZN%ApMS7z?U3C`X|UqG3Qba1Dl!VI;J*n=1kASeHPV> z174%>?B?mDm9^$TG5QWrEI+)7It+8*y>4PEwwEko zt7HRV;?Y>R@0GlcH1}J`N#m*~jW>UVb>(rYppRikjOY8$+n+QoKV0ReMFn8GnUnh? ztK@#p>JyUlNZ6<+vj^z5&p0QX7ZtA4QQFzz+P;b38l62U!(I5}+f>^Gl6gcKp7 zvZ??(UDZ!kXaY+S5z~#>jAIIOu5|wLUXLX>>wbz9z0sWTD?Gswj%|TtMHC;=Q5kom zWW|AA{9@eI5?hnQ9tTDfxj42l;n>o%QiS?OwBn0oPQvjx@sP;4#4tm=_^)@q1;z98 z?Pp@Ie8c^Lz4Hy<>h6(mpraG`pK(=8OUlU8v=#)pWdh1$UgfPPUvp6llTeutc12#3x&$ z-IKfB=}b7d1(OAu3QXn~_3)SnDv$sVwc|-mbeZnPH(*`++V>sY_u0M{$6+nl0i#2p z*$wea(d%%Z-^t_RUhPp_s~-pS+T)lk?NNNsXdGUFfihUQ)w5skxQ*}YKY8e6OW=?& zd)^&AGYvDW3Nz+~dd#Ks9o|0mcFTobv}Z5i#Y!^fH9JI?H|v8n{poSskCs59lF-r+ z?T$#L#=88~a=Dk8bL3 zJp|n&GFU&ckn`y|PSnE+LP=dTj=)>)tV@i0ROo^kSnBz-=`wr(J9$PZ>D!Ukt3_d7 zR>x?)!qLHllWymT{HD9dy2Pbv!CL>dSTXWR;q?OZM2O9a-h5{_EVtM2KsC@Mwf{SE zled-rqywmVng{+!?Xh9TE=iaJzq{a90>As==Y!t^@GFDgWAIxAKRyOz><9gPGkaZ+ zjA*8^qyFN%PzMrkdmHG<+6I1+i>@zg zsL7&l8GUh955DxoEWNE-gXi%Zdfo_DFvGf?oNxEfH&zjxW~?DtU~D2d!^{zAXcE}Q zmq+*=eAP4#DQcn2OD=VUANcux1nKCg!H@V2B{f1y`W)X!ZM|1iy~b??PZva2@Dexeyse9?D~|al2Qq6f;%m@SAiNrMHE)vn6qkt)sCy3UgOOy*#S!;3)Pi?I zPA=q2p=oYHF+!mo#QaBJR(uGR5(X~Cs@sn4Z=Dhc17Shhz76{oETFF>bFQMZOo5WP0M z?W`)sDZYk?%9u6}+OH@(c8(EOwBZ4_^Uf3Q*5AT5U3RDQjB&5iQ|tJkvRS{^X*NTS zk6)q%aS_i`+u0!bZ1lWcXG50HU-r7>*`H4W!8^nJF_#w@3W&{yDl?TuNri6J#?!)8vF!$*n=|_R& zA9xjS1Me78c)OLk9HUSVZKR*qQ$JJhsOp2)A(^%3=t-Yui;(YQ1C?(B1QtHFS-=MZ zC*l=1sn?LeO5EZGgCPOGo5oF6d>*~N{VTeK&VO-dwo~>w`6kXL^AcR+NScfn1~t)Q z61LO2_P32>eV~zq?AGH)ceNiRiDs$;!XEgRG^5r^Un8UsQ}@OhjB-@!jHNC-CO;m- zXfd%e(WUWjqsZwk{}^Z8O9j0MDuw=bm58Z^1b3OcDU;A+7J0Oo33MM`&*b{zFpY_H zANhA2H#(9GgBrGl6N~eivu^KwKio9E&ctd0!8VycMG?>(p~)AF!*rgrPJfSg_EGbl zAMfex-09MSKB`?VPMvYP5z)t%3Kd-$L`JvPSuwLRTA$2 zt}P9PqH5=ac-5!sO`)VSIJ1L%De-*pb32_JWi!O|$#j&N?d3vPJV6CBa$Ne?9GR-S zoyLRCvSV)rK25K@+j&!P&m+U3`G@>D8DINiI&++?*}wnH?G*>)YJ^(r!s;-x=in}XkInx^Tkx+XcQ22aoe%XBImxfn0@*!VI zKrGV2f6Sz3vHL|Q?tGd(KxiiMM5OUw;&kCFt{qog6Q@DUE38RZ3x!U!wu@vL+ zF;Co3et)>^v%(dQvaQKHJ%W0>*Mo=s9|b!fI?NLLtt3!b-U9YZCxJsdvichG*O;d0 zC)1iC4SS*1O{Su;EIn9ap zU5ez_ia6i!y;turey*77&k^&@M38pM%whKab?2udx;$p^YkY}r{S7)I7Ow74kwvZI z8=%nsbtrgPtDq-{Ca8fGs=yXcXH_9Cp(~yBSy}~-TXnp(tx$m;aXKo`bj#>oTI1el z`1u@b?=h?0x*JZZ9(9p1myVGb4=Li?Y0ct39CxR^rvnz>G{r#ks8R|5;f)BQjg{LESQW-8=L<eaSrdKk5{xH z_8x#e!Zqc0bg%>rms2z#WAK7Ku|BO%Y{1u+^(nMrL}{zT=Y^&^U2XWJ5kDI%zWrjz z^WM0J6yME;U%A!D6?DH+y;#)!LY0u(#C=#-y#Hb(8S^6~1N~PMYdc3RZv?NGcj29I z&jMn!h4>T^uU1N!9a*?pM9Da$RqO+-wXHw$-uwFNss5n7t#M3u`wpCNZ}AG&WC>L{ z+L4o}<2Vb-2w(Q50-fkig?8<9n+LD8&iZ&?3x(3^=?((iQG}0cxqDA2hadL?g%x)w zf_m)4qg_ApBCGXQpZ@NTkg(dzliX2nh+0FE$>B%r8m#a|4p{v0fTO0+d-4*6?hS8& z6KeNOE~E`bJwe9EU;6%>uAXNLW=dS-)uT>q$7CQvqW_ViBVf0aMIa$*xjA?o>LpNj~i zJcgsR&5DxP2svz7K05DE#)UJEpM!DX48Ra*?nm>z-E#m@VGjsjGZPv8AHZE7Z?wPB zy%fvx2Im_tP>sU`*dCI(J-Givdnio~Uo2EAMqg%(#gW*_FUU#0WH8~-So9@W`IF4; z1&@p*M>idoe;5I5iPrOcosA-&0_kj&eEuysSAgS>3S6P32f(ZW{*Oi!R|SO9@Q@vk zpr%^lDsuUIDnxo-XQRtM-@5sze5cbI<90TxKKm9_kJ~G@;G#wwK7WPSSehVi!$Y2= zMbmCl9H+%@z7(zV!MYh2lKu>;ajH2mn(8x{)I}<>dz((?`gmOs-E`0rA3!_p|QxFNYiBI zt;=~EC5`{|7JlvFD;Pa}(Yv`6nvzA^(nHFeH-Grx;GXk`RR51J+ErrDtRo5LQ*f%1jY zW6gIODd)|1wzXXu$JO2?m|7?e8COSM0N0nQp&aL2TBIQMb>>Td2KJ!h3&H)%62?tX z{Rzg;oVV&fbNVhrx&~^VHIp5{?lXK)%5t=kqmfpq|4a=hfl!eVZjErQBD7r>nYJN& zyB={5v}$#&iY*nXT$q+9J2wBCR7gS_KH_5eCwpEuKNnKId#k#I%Hh!G9$|kE;Cqt*M9bDs1@d5a9Eg3qG5(4oX7#QA+Dznh_dJgQU!fba6G!L&ZOZ z&w+TIHD%yo%WC*+T?@Xp3kUI1ZR9i`Ibqb+&p{7K^Xb0pHRx^hT6#-l3bFGNJ4{E7 z7kMp4FVo3O5qzy=P0OE2RelTB=ui?esIH>%Ky#qp#fXf({;xcH%}Wu>uZZALHLB@M zK$Y4uV*TCG(ISQIm}Q$=BX%o+@f6?qsQ6}5d^0J6nHa%4Xj$Gm3xd-s@(31WB&e?LxuwRTKqhXOlbF9gpGOV8bNsaLKHpa zEzxa35xE|#T$XvLKNztd%xbXYq4ju;FNf-gb&u3A^24=WeA|$5<_-m;&t}%lgbF+w zsU`&K)r_x}9i)0?t_3{Jr%*|8JQ{8IYy@$&Bx`r@l6Nc2L>Zc%FA zY3JSbzz^6pRKB~t6B)KJ!$Un8E{`zmv=}1vC64`>xYUN+8j&?_%WnV5KCkBjaU1Ub zjgn7oTYK66(bI0-|K~LptKC|z|Eh6=&%{GJj}3PEhUlZwJZ|u!A%IamAw3gKIBSGS zvR?SH-V|Anq2I$(WEKpk*%TQC<{^-hppt~F{RLG+ zjzAz~$GR$yRh7#WUR59sK_84%#_d-G>IMc6`?q>J_0c#1&$&$;UoEia{Qt@Q^dju1@iD&kKY41Y z|8JW(0LOl*LJe*JX^V*zI_+=316X(-OA?#6V_d~raW}<{9)-EgNH($*;@p`PpXHB% zuj=b(UfLE4P0(8)P9N$`6q}5WC0}NK0SuNN_3Ur|kos51zGkD3IdK@MT@zgA&yUjr zPGq{&$Wx8U&cOGgPs1mxk;+oMs)}*G*|^_XS?nY#HSkF~=s|Y9!(0wJYSpdro=|6< z;!CW2qwJGYm1gDr@lKIemMZh&Hw#B4Tzz|C7(=e-Awm&;>0dTMz+C2SA(fB2rv z9RfbbfStfH+ZLKUdGtFFI(1#i^zaKWFEr3Kw)_m0GOK}&jaf=OGK<&}de|Ic-_f4c zS<_`1cg!7-!zXpQm$FaWR{}?PGwAASx zx0v6JqczpT%eTVM#y*?O8<|_Yr`EH-O04RiW^ufdIhsV*L)`QFQfHm)znl(O;ANiB zZsTc3JznSu76(7~jSp>x`n*;9=iI_`pdJk3$$)DQPW%oo-(2tbUYk zjIAcAqgCJ$#2UQy)41Iw9u`~ZP?_g*BU#%qMjyskQ7m$+y3g%2Cb;TOyQ~Lj67^QV zr!*#|ow(Ef#PQcawxV0>+Hp4?DtZ8x1_Mf4)4$48%P#-qhg!l}=m_ObMU< z8a#av-AjGgujz|Zas4Ljv?X;Q^q@72@)aGahthoPF5i>EtIt;;8ya*aCOsHW_GEF<29!UiHjT|67=G4^qaR+R>dQA>-%H zwD-{MK5&ak`|P!Dx3joJ-#OLDai+Z!=(71Q!>qz=YJ4P?B1%`WW$e;^i7z$Mohg%} zb10+nA&c%drmLQWbT?t<+?Q%Rn1YWdq((Al&1uSVmwlhUWI)-N zjOB^Ri#&xmy;>P7U{G^1<6(Rk_0W^d-vpjAbKr zGyE)4Zu^?DQ^R~~fzbEIvQt<4ep_}beW{$={&?A`jAeRzC*b_M+UxYAp2NC{ciG^Q zlb+%>@lmQOm%gj))L8!|cS! z>P`C6RPzzuAW;We?>Gos&q?7Ot(|lz-^V9-%QCL<&81*vtjhS7Fbt0L990LY?xG{+ zihHu2<0>0F!hbc?VEw3h1xx8VV(KirVT8Z0ezZDIG~>_FD|LuYZp=x+YS3ZR_w3(Fw?`+ToZm7L zWTUx-{8pvHkS>LZDu?VEh@)RL2O`&q(*oNTbXi9%sH+%GH+6rE_ZBpni}8)wQEnri z-0Rc6s!G=1)Z>v&+38{a_$?@qv&?%bm#fBdU}d3U{wE-psDCl1;t6rWZzj%P>m776 zyOB8*oHx@A;9sXTT3GAycw@L59Mj&3P_IK?I(bQJ*2#5!>IIU7`ICD+)ew$y@jLLZKT1=z)XCCw@pw&pT za31F;=TOy))`!Z*3ckKo11pouPRIJN;IvUm>=zqkIR*mkoyYxys)((iu#g8 zI9&p}(!aciz3< z6U1QcvgGPSLHxSfnS4`vDDat7HDGeFJ}_9jyu;c%#5YiT_803P7YB}=SyQCfjm9@u zynk9#)fxPBhRV{%6JlGZuR>_S9-m<0|(mysyzyTRqwjjXL9EEr^mhV}_yy@mOfa zt*RD`B{tC5+ty%9A6;%y4hU1a!jv3fDg@}S9$oz($g+U!*6Pu}{|{tfZNIX5^t1ng z4Byofyq?-D?dc(chOc_6fmSWhrD;Jr4fAEZnO zQv&}VB#I9ch0DG-jijx@n~!LhruKC8=mn5Ih_fD}&y)3A?fQ&3EEL4Y&_vsU3I+eF#}tyT0VTQ2Q|)+%slo_CuTe2KOu^^6i$k}~b- zOcB9j7hClaFemHDr6Mj|MZ0}!9;!)3p-R5>x3z6ew`f6pk979j2F-(8jd)YPbu;`_ zry&|s)vHCl9?cUJundClT$kPtREeIA1l)jnnxZ{ZpIFzLc+&6OjHgOr(0oLDzPZN( ztVXVS@+Z!d54jk*Ci1Fl13flw5AN~HCqHiR=AS&G*A<=oSftP12K`{!ksCYfQvEU7 z3(aqT27OeZE!DICZL^olDR3!kONH+B?XGC2XY1c?ZP4q%$y59G(FVb>f5pX)Ju70& z$&eonCl8)H95^VLG-T{slH%{1(Xc!rtwnE0+mp7R3JFbzfAjd>hQb*$(>nE&`gh{t zK6{q*%LV%Hmg6%$Uv~BB>=T;0;<9}Q_Z?1a8L;=eC0~eyaqer|cUWxcvv=v2?F97( zeIE>lPTeuD*LC%SjfSi=Wj|H#4}S=Ns5W^?6@ zIE!pPnT2aW?Ix&DE#^>UY>~itWS`-xo+awZm9e2LSMT{4d@pEo^LLV9W`j`Lt;7gD zr+gxp>8PYbf26+=z2#5RDsWjz``0PdOYmi!$dyW#{4Ic{>MM(wt=+`BjR{Xgw}3s_Xw)#y1h0}MDgs9=auJSL+7 zjfU}&h>vyv2M`5EKt+Q_lo`Pw5I9HC7&B&=WcC~<_3xMdO`ATnroCyJ+uAlw)ub(t z1i{o6wK1q|f+jaPI5E+fARsz-t-a5{3~GA+$M@au-v2+}w`b1TkF{TG@4eREYpva@ z`Vd9=Axuz|@kc@fr6UIS`fzW!8*k~ASH#Pb4*9s0FVgzAYDhm;0eb1lJBd76(Ilw% z$ygqR9Ic%5uW=+#=Xo+#w(6j{#26|?*nsy9K?!6ib~lRUdDq68+k0Ack`3h^frFE4 z4C>yjxshD-YL)dcw?hA9_B5x8=@5z37~Ji~h7L?D#X3Lk_gwWzbhlOUtc_L72>G`V z==s3;Nx!ETN?_nAFYU3$`oE8jXTc4Xw4>6G{0CM1arLI})Vq4uJf(Ft3N37(H4Ohy zDLh{0Y@4|uMIwdW3W)~{%)SJg+9Kzn65}xv8>I0{95-n4VQ|FZX#u-=`h9ZDn|K(d z@txNNDcW1lTbuzwyoQR1JuQNl#Ua6b2UV@B^CDcS_)0=h=sb703`LMmU!OZF%Bn=-A{EP;*_HKFj{D8SY0owNn2F?VU|Xw$2QRQ8|Z=1?mn!q z(IsKCryI0V89U6mn8q%OGd5tzpRhOIpa!o|rz8*fBC_2;@^$R&=y5%nLti3;dKT)& zZN5(4Zjd8)f1(96qZM+v{;Ku=&eb%IWn3#Cnn&SV&`6h>rx@YO5&U~u|2**tPB%GY zhR*g7C-Ly?{PMzrP-!(i6OvoqLXS<9L`X>DO+nA_^^WS(vc%>dcDfixI-zPOr=Wfm z%||)?G2I_Q?>C0LgXv)bYzh&uk2PPS>Js%s%Y``8S!(#aCp}h>l7Xgzij5-8s@4R` zzN0(}3Sy7&u7=(h$lKWe;WGK|OHv|u^;qI~(THgZl9}+fhP*vARVym%-j5 zgJ*l}%Np@DdAnYIRPR0~z9K&kiyUy!`vKk$$yJz~0o47I)n!K-8&UxNy_C~ZXSc}q z2(BE$8D8o6Uod%=8k~O?{(x=kDP_@qO=a)Z_E-V5_0dLX9`;^2laj@^`M2HD0|%l^oHy`o>Ao&RjzrO#`D) zt$!PnA{z8yr@t5FT3tS=)wz3i8f1;d-0sZ@5RL!4KwltfN1FV5;B^#xeQDTv4xW%r z;pl-;w5n+X8RY8Zaf>rau8xfJW-_zs=uhQI5F1#xmjE{Oyd{W6)VYYEOqX(Y3KOIM z_&TaFJkHb@bNB4Z1q5PuE4C>kp)vh0 z%De|vASiQs0gy~5PNKMlwg}^tBUmk<;A!I6U}AZ7y#E8q084*d(965spkkZzuYza0 zA?P1AUf6k^@}2vTY~L04vJ+tZ*-5pDCQYUrVr@$KKp+sLvgqjfSYK`;$PW7O6qTo97s3>EF#{sz!k7d*+kq)N$tYTHe3)~3->*&P-=fsJJUWNc0&;ZH{Cb~;QK3z+X{3+gjap=`x@b<7^F8pERX)7B~v95*d zQF2C#9hB5q!^r*>0K-?z`*imxn`fz_WhSNC#HPIIfMj*EVYNmsU)gwGUAHL^x>VRg zy&&?+$*N@I;Q1mRjp01J0I!#e_1Spb=ZtX9TPT_FZL)I*&l#U@G`_Cv$BRvo1c3sV zxi5+LFl+HcvL&B;bNP&hcB$F_HdB5&G?N}aLIUw02Qam(QBTTyN%_EmVw4{PQpTtI zpV%6F2fd#sZa@0B>XK2LW*^(HtQ!xt z2%cu>mA)&%>Pg1n#lOMxS%XPVKyZ8$@k6^mhf_iJWAeWMU%(6PZ}H0 z3ZM6W(%0~jm}qYFYLwS8T?@SO$}iwGt%Y3>djk5$=%zR1B+!aoOL?y;pg|SjO7t8{ zt^gt%(E=+kuhs$S3$y4I)=aSGWs=Lz1yP(B1qe19+De{If&3-qGgj!Pn;Ozat}30T zV5!rtJvq{+Gg`cH*&bUU?b^<-n1}_CVA(u-$?&e`(;Lni-I)P;Nl7LowuYmhCxI^F`iPUm-a8H4w`}y>~ z1A4i^h~0h9b6lhG>2wsQ@B2Q!KRX8n%6C@=0^dX9%) zhiCdrFdHcrm2Z3)d6tFf1$^{W9&ZxNqSv24b8ayz<5ooVWe2$ysp@ zIq?Xd)H`-xKhrNo9r0kmi}-Z~zMjJ`AAa>pF-N|IIJ*U&a)gx$wg=&=bWJPO$`#?nPzJ|N%sPWx>3E%Kyn(hzbZTEaF z$2W?zD1%951=VX#XUECf`B^2>2v?s@y4UqYJTHz%IYC#SVb|Z;eG{33XAe66pIm)W zQY1vvNoQPrk@Qt7{lyoLgGzQxr45!fv}3|*~esFU1y zBP$Kx3$tfrcxiEJ@$D-1{pL+PyK2_|^rx==a;ZzjPfO8JZm1ymY0;$uf<(cDp~_Ff zVx)!^7XgVn*)^XN1=3~P96W2lnI;lNEw*(B&qQ=8U%Z#yWU`VEZb}s#nY2g4DL=*O zie9?C<`(%J)w%)Q0e%^w^%{)d`Z0&HmbgrJL}@wKO${^`hTQ~4^m`!<*;&GgtC6)e z9Kj^!M#VcRq;@EsIYIrh6|r-U!(9mREggwvmw;p7ZUBV+FU4X-`CvuWltrDzs(fqbT^~q5QRyQu1M=?2 zAM-gBfuEnFGrITTI#CR)kkS1!B+ojPvmKPTYoVIRNXIVLFk+uvRz^Mmcz-oOWv)@} zn{=*Ya$m|z9dxb5R39tZQ>jqLL|9k;J`GZwVq%Z4A$_&vG>T5KGf5pClX5JTgpcRF z1qG^fcoC1v^zCXqSZAsAQru1JMlo8~Jk-U<35xCsV3kPR0sM15Q3yegAO($^Af$y# zp$wOwUBMbeDcLgEPAJCnEZ#cAB$UzieGApws0q~$_^g}l+Db-Nqcd2e?e7AVS>$v1 zIaCw4J!zpTe2{6a)&hP%RV=U;a>PAAhtm2`R+VKXYnA=M%-TaTGeBnkL-GWyEZ+M* zKT{`Fq4-xw6Dw$C>InlUtqm>v%-fay4-i$Z)Bm%=Qzn%>rte;ejeZa0_pINm7Bo|@ zTvKiXdINyQBr!uBP;@WSJ7}wbbpR7lh+}y7ZACR5G17caZIVva+QGH^nd$@qHl-VtGWh{kPAsCl#vsQ4ELy;)lTnCTc>@2Ax!a`+bp9`31NwBtz5jwx=cNv)`!_gW7|I&A^RQ02G?~I7=}3p zZNCled1%y|z*N2y>CmM>OuvCAfv&z7X_hy`@CFyjaW7k>`<=P5ak8eBiNro=%vNQq`x-L;1nZ}}d^zyuHd9#kpgSZCVF=>$^=5LOd9)zgHG^%I{-xX2i zJLw*b0JsaRtKk3pU>tL!r)@a#%HerQy*pZxVO%E+dk!%GxAKQLk49Av4f zEHwb+6Dcv_N3nMvdESJyT0=mbB{$Gl`BnPoO}093OcoyiUK1f)B+NVTo*E5!GwC?+ z9L2le!W`E|;obHnrW`ra_q+*_kTkGAMR^Ui-tn$F{I-%vuQi}T^DHv0ZD#=<9Fijae^G_YSfWP*@hSS784B>Uy^6I z-qw*B@`|A6a=O_ZC)yC)I62AHq9;kuWe&)N6r2O#bx&6}q{qr5aXWsbyqu`-3l^{Y{hJJ2!Yzft+a$0EI+7$820iiKB;Ov| zJA;kaz#5PKbtw-=s*Q)=&ox7x@nXahQzdYxH9Xpi6M<7LG1c>J;IotZEaf{=n!H7{ zkC*l|>!pd#ou+kyl<3-NTFUJjbwuE(>_|@Fy#U1UD+rUE2W~czb+>m^0I%aH&rK)r z>puCE0x2soWol^3O1}aDo zJ8voQPQQZX)EgTfx&iAFwubS!Y4AF{MLweR)yh@mG&$RvIaW~c+7(qP(>ZslIMEyD z>`$$o>g-S3Huf9%HF0dTU)Kd|{xih3fRei%- z&Rd)}rix|;Yykp$_^~DWFkpKBdGen3v7~DsIFIYe6FSdhN&er2g4YB13BU#Wa(HKd ze%(FJ{>63co&8zH2E-VYWmL2FpEW*%=Qhs%%DQ+b@Btrs>yn&*i6d>Ex+ILZZLG7N zuapwJg%h2}cvqvwQ#cX*o&DRS-$N0c#{~;yPos{9s1Hf|o%Nd8(u>|D6P@jlKSEdIaXsoEItj-;NWI_ZR`kDlg$|Le}{sZyk8%~*^77fk*= zlG?gzHaDU@r01H*=_%f%j0T`pENQ*cm8cLIcWRF(68Vq!VU#tQ&$(^}q^XW6vf1J8 z5dqCemxFxaYSJj*NnplsKIB{cA5eQxQFzJW6jvH2PDs1@)ZH}h6nPXzE>|OWLFB)u zUETFpYS#!8PUedc{yy*=}d3>%MO5kph)It%@V>v*m$CJ-|hGhQYV(*$jZjNU) zpZ0}x)fb=aZrmA_)2d0$^?#*(z@***w05`v|K4DJO|U$~qs;ssWVcDYGC9ox2@9d(@ia?bhgd+#0Z`|UCI8f*Pg&!|~7YtH%1RjX!_3RC}4e|ps`yi1{O zv7(2;svA?3BSt#=4d|T7)d0XU&6|DlP<4tLZcys0d-vApp4De-&SVitD~o=b&4a*! z$#)#oo@E>NO}V5f?I+cbp`}Ss+!p6K5UB?V^2JnOm39LggW9am+|wOInQ@KBcNfF3 zWaybW{-jzZX7?h?t39AIn_A}~_h<>C`j*SRdGyicHr7Usz@FbejlGo#IW7P}JEjw}t!RcEcPRIZO_W3Z- zh!%e9as8~kFBJn0UtTC?j?QbaJ{O-Vxq>H7*BUuscxiq0H*+6s;SZBVCKOOVf6&Wbz1!aWP5M z0}8N>J!+zG*MQ9qR%v~{={bB0TcM|^jibcP^GneV$v2EaNOqa!iyj{6V2U904a*+@ z9Yv_BA721{01~W~Bf%z*!kp}mjbqU@mt@{H_n$8o)Hk(oC9F=amM0}{SHeKaKxQ|R z6J%6!SHZXkWPuJff^MN{i&%_(dJ>wbt9$!wsm)8P&?qcRD`pGV_?cNsp-5KMl$m^t zarZ(W0CWRQm1{58*x4O99Z%Km2=#3GtZ=;?^z!kf#7NxOXiA`vq2|XzAJ7duw>x+9 zWI5_k)KcwgmU(|Bv4T9#u!aUHJsR;bc(HR#sRGkLr!n^-e={Ekw+*%3fS2w`QY@)Q|nj6Vv`OCarM9S^!nk7J19 z>lsUR@jV8_`Xl3#;=6w_ArnU5xL*aSl#WfaeU32{(@`}z9uUwa!#_S&c`nt^IU8<< z^=njr19!mdHc5%N5abF;%}IUo+zpT&KE#Q*{ljs-2SEug_OiaOS$n)e8N{xJ9&GxC z@f^&fx3vUp^-I;#qb}Ym^Lh&Y=H2&et4@NMM|jD)y3J#M`v6i>CV_D!LixzyJ$dJ1 zX-Ov2R`6GC%Ophq$K68522FBL(c0A$m71tHLmE9I}Xg7_ug z8T7j$+d?u#y)NH9>{W`qUfRsdW6<%{aoB-BL<23A7?%@}?nO@g3*+QWej|wlU4DA@ z0%I+ohk;D=2}4z2*FJm`T-8^792n?Ey8JZvw@9G#?j>G~3k;k#}0WP$BSSUVDo z8l$!pHYofe9Eg*YVNG+$+8wCr9DU%mSQ}>dASX~-@Dic0WXTJ=Q;v@xfs1p#wsj`Q zRscC}%6b!VI~Y42;hx9PP%Op?`%*N$%?QnhT5z>%zk2Q5W9069lpuli-~?3$Rn znSom6p%$8V$hkW8>&c| zcrb^vK*p^OS-b_xuVC<-6;fc+OM{tQOc4A*um=y155*-nIp!ur8~gdmL= zUxhBLc4IG@5@d$w=b~rX+?Z>&Pq$W}3jDzDdg9eITl7yWS7t z=t-d|y{vDP);Oo7L#oH}jq2RHu6hmj{AdJ;Nk)`Xd8tuKH1amRt4NdCOEe~6d{UZo z@`W>eZxyx#qWG#Upe)oRn`?a2y+EA>p8$s^U=B15naV4k2#}05MQ@Dm+n4&{BkLol zvbJ|Aq)rMOzRdKXS*)0WV>xB z9VEkeqB&F!PAh0<5t8I&dv`D zDg9~B!z7xk(j@!2a9n-m&1|HvB(;@ub%s#Pqd?z)=fyj?!Us0V`3A>-;@VmhT%(q8iV^Tq|9zP@e@~%%*c!uM((; z9~&pz%WkbMP7j|3=h{IKen3u~MymS^JYm5_E`8_ZRV*Y4BxosDd?PZy(>?BPboW5v@Rq?d!sej4gap zo;NZpJ6 z9s$jwqx}lE!wu+Wo zL~7&&6_CEghYhnLDCokl5UPwgdB76P355AF8l@ZU8dd9zW z+2v<08^bLY$cSX;G1V^%@sLz1J(+4uJS!9gh!aXPf*sYBYnm?e-W3u}M-fx;pg*~}Vj0Y?(u+X=F#?e^8Ov8%wo&wG z0k7k6E`yLrX^>N^<`eCqB9kOWNsk0YfHWcR?RGRhAD_G7KrWzy4rla|<-AFo$P z+%0gL_NVLduUoCnyIx~O^}KxLXVjIP{ifgt5_&2s-6fNNjZZ#Q^_n*E#<0Yz!!gH} z+;wVU`3=1m&6>b8kNw>~&6z6`DO0LJV{V!nmxx-=@j=}#>?4YCqww0G@Ro={KwmUh zG%g8AW$H<+wAZt;m$XxOV_o2z9K(Xw@A6l;d2@JVr|9}lCgYT0mMPxt;9@kTvb~kf zN}+D5Om$c$Q;)7D*NbTdVk!wCOZ7*0lS1-M>riQB36V(OAuU>NZaH$`; zEljDy$&)hsTCx55O9Z&sQzq}R7kGoWpnhid=kH$qwNGD$GjQ+-hep6S1k5`yF~5#1 zL2EQjew5Lcc+nn|%N-zQR@-F3T}tRU`4j|}l*AN#=yAkiiw?l043R`kEUb998_VbY z`YE>wYYsQ6I-A{+Uv`iAj`+xy64;KFwvT=FKn-?J;$Z)f6}Uo$$??$z!I#G^6A}NX zA3>H#j(>A(h7#HaiRC*Y%pe-#=o#}<1!dZ>zi(*jmkdJ3S~JMyE`ib{Ry=k2gP~Se zcaVn1no?}!nnDfx{aJmbMuT1vC+ux6w65Dj{U5Wz6zLI*QejJEgF54%Z;{%r^0M#{ zXB4!BrdS54f4b(WDt5HZxD3u^&Z3Km7Sn2@h9{r?{Kz>qQ zoE0%C{Z1kW*;4z(Ki+D&9*xhdDC_)?NgI&tn6e|- z%Nmk4Ni1;Lh6WUAh#&35 z&j)zu&V_qpBbV{dFyB+DydsY5*lW5EdKvWJ9l8q%iU|~EmQ6<}Z_bqQBmPnkcN2ZZ z#CsEh6(2J(x`!<1CY2gJ@WX&Ebq3HI~E{*{1X2`jvP`^pW-C&dqyMuoxdBR%E>rC(@l!W3hXiQ^L7 z>?|ULhVIN~Wls(x>I7v{PO5miGy@$YB5qH$8#toyn|$)P8)>FPQYJ(_bK<(=ZI zwDvt%7UF&G{P!>HU!I=Yfis-J@Ld_0V&n7;V*7~@*-jO;(r9SQJum~e;hg^+)A;QM zS;kPI!C$&E7j(?Z))PS)6oEiU54fGo%FhCHYC*jB_nOU|m8b-}t;)5}7AoPOIQ$Xd z;)z{B|5`i>-&~063CDBjvPZ!OMkPh7)(ZHl0(Bt>z1tHp!7DWfv0%Zp8@Qf)d7 z>BYHe@)m4Vm)LMNe-*zi0E=h3od!c(!B{_mC{+zyHM$-kFBJgpI|lN zwnq|Fp=^U&OM{T$0<>ZNc7`bBPIR_@Qd6GoGvA(Ke^v<@f0?97bru)Us5SXnMS^RX zZV^PrE=m<4ntI7U(2#2{UuY)LxW5O*dljcJu96@SV!iTCQu+Es%$W!J3B}xeh99#D zgDMR##oz-p7DxIC#A;|Xz*YUJE9X1Q^tcBu+^uKSnp!K5Lxih9TQnL%rI>rbfg(>m z$Vx0Hg#&oXNDIQ4;ep`9HhgwoyzMXA*msCxX0HGYSkrkyh#NjIk+p+II`rX8md5P? zu4BfAz-Cm>k7TcsEkg^*05sPhy80cWPwxoF+y1s)zG9vS7*Xk((0gZe?oX9;7;nWw zy%KB0r%DvPx03kffr4xK-s7GwC?UpPvL?q}zm@b?v@6g-HCMEY>GMCHM(H0*BJNSe zE33M5ccHbuyuODYRLmE1h^a?3^7C@TU@|^rWnfVaf+FFVSXp8f9#Y6?ltu87=f*$I&M!wj5JnzE!MUFN#}wouI3+J$tZ zdwo3IKxVc8rO+EQeb0{1yDJe3b)48ag$k)jCM*d}{zolXXx`D~c1hVHkM#AaO zmRJ!BSoiYE8M=DmP++iOrZH1j%%0OW;HME9EbYk{9i$Yf_XwSLq=Y`o5Vur8sPRD3 zS*al!UA(dq{lc#G%#$D(?6}AnhF#sTNuayrSWC47U;v)I2tRTUZ`f8qw9Pe`w(WZ2 z-F^kPrvnFpH-S5^9i3o&b^>yHOEF2o@ag`>@_@UFQz#u;8u-B|lSJE72>EB4tUd*e z{@q@tj;)`LSg)wfR?xno7~F~YE`Rqs(Y897sSo|Z`K5mry$xBM*v%dG)0FZ&xg%U0 z@xd*%TQn!?%L%sjx4?J-;DJuVw2}LMc%Ap!EBp|?hNI;P3GKa@us>Mi(&}2bG~UL&mt+(1>#wo>okzFNs|HO_ljn~8CBk|U z>5S3d^P|mMwg?*=3-Fc9Mq9TFDM~{-EVl)Bcx|5i=*x75CR{K~Ez^<@lWQO85x^BN znlrxEi??A?yQG*j)pM9yqXR#5Jv2j%Aj1qgrWUJL$J3NeXsxf518%J-+(zfDoIWp# zFd6g0hYZC2zGHXgWqpSRLAriab|UMU?IUh2tS%kJTh5l^IL-}I)D26v5DluF{0rQB zD^^ZTUsKh9FkS;@k;L9rx9Fhk;#ML85%&%SGJil9aPbs{Y5QQ& z7o>OgD=1OnfX&zHx<#i8H=YBamSu6lS&&*dxnJk}UJ_W;B=TA9GI8%cHx2Iqg7Wn; zbdnnpf8Dcp;HArhBMY4>f8G?-y&CJNV@5sNf`Rn6XAe=pWbLz{F=*a!J;zzt%y0eo zv&+GGQL58fwpWWVz34XHWFqmW8BesQA)@S7T|)jKb=>a5_IB4ozRi6er%}bp)=516 zEAE$q7RG^WB8|DR8Y*mLcFpVSUPPum{TyjNYQ>DRdrKMh>@-J)2bg1K}=T= zS5xX&NS~+o_&=$k!NQF?WF#!68nEr;guQl_p}aiMo^Z6#eF%+#b9q|9@e9bj4c~r; zQA`Z9Lba<1i$f`H+9XX{o~uk*d|-#0C95D7;n~Cte@Lj-)@n`1o4>|GQZGZ;fv0NF^06n0O4*3b+M9RO?#m zv*7S0zc&Um%O{~XoY~7uOzWmhoma~pW?^vhwu~&Nj+T=KpySL#SYoUXu@fBQbjiOl z=Qh+K#C=ji1ZN+Bu606mak5Wj+mN61dS1CSAglheB>jF2;trK(2D4oj2nw#8QSHMD ztCwdcN*iu;2?B6%Ze5}fDKnHQo@lKl;M(z*LNKllAvM}tQQyt{%CL{b?LLqm;TaIc zAnc2hH_O3_n?zaK3_=tv$uPZ}B09+V;U3Hgn0c9>MEZ>)rGa^vA7_!tHCX8J$7z?^ zf$_?E5s-9dJs%K$=fv`bNn*_OGc!ZF`s1s|QO;vfx;}K`6ibr1VH^&TU{;l4UPFNK z4ox;T2CYcQ(ZQjM<<*YvwCY7O^z2A;Th1vW_-uv^lf_SVFe|sz2_nnfkgQPe0)8w$ z$N`hSkyeGqDp4OD>>YHaEW4;)Ax78SwG2%9L)X1C^DDM|AFv1RmfNf}=<7Y=FN6n# zIiVr4Qb`}N@E;hRqQtraVmYD@${E8xRs?SGkF21zRYm2NTnHwB7JjOCq*CiQ<%{Axa$XLxb=l7fsM}5?ff4EV5;&{adgYwooy_4 zzFGQ?ogAPZU+1P#2OAs5bgqy@F{Q+>%6tDHc@$iH2FxSFAgre;}_izaNXsC#l*>FXeWM)td< zxLPQ**JA3T{Sl|S1`jQ#(@u9#VIycmWMF-=eQ6_{ag&mkp7x;7kChg6+eSFECJdd6 zrX=p_>dMM>eJzt+SS*J61BRSB%ad7>9(q_9koi<~p~wN}j%@%_erIEO<*YuHs=93% zGF7Ols-8&=DnK>Pt!#pv7~SWhmM?Vw#r)^%+V|-osV4W;APlw4cdfhczq0N?ZE`qj z`cr>&xoSx~&*A_YB6<0qZ@_ks|?>LY-uqrL>qg!o}M zfz<3MW%3nba)+qF9CMlI$GMxalz--Vfun4zVGU~jm`yodc^(m=nIlotoS0_FT`b-O zI-O{~W;nzap_G>R#*&B@J0Bmu+;!)7v(V{fx`sKdVyxmRK*D$WS|?DGiYx_-jh{JS->NLE2F_1`PB?t*Qt$a1YBHPJ+m&a7)9n`VT=uQ zj~6)#zO!BHu~7(cWzLZ0TBwx<2sm)T!QZ~O$b;!#gyok(<~cTHflC=641gUH`~pmm`~pprIy&4%tYH2iWuUBfrpBd4pf zfc+)zUB^C&BAR(WH>X8PY72Gq=eUEy8$*ulA^bxt#h~b%#pWr-rhcF2oIRe?svT@> z{_iNNRE;nSU`9_hutRuoo2r(NW-<6KrF2)*<8Jm&nYw?%8lVqTO^@ zB@LX2HEiBGV}?x)n5*_+V8P+O4Hw)zW>}dHdmbIAwY55L;l9VN6#EAlR9HohNYD+K z2O18U{hM%bRl!Vb*Rd6Ank1`SsZ*tuoBeisG9^yw2kvQ$%SEh;%Thg;xw;-b+ogl| zSeWB7S?I7AwT!76zqKbQ<9M}mTCq+okTP}D0>rKl@CjL)?CR~B>>BeM zi9MWnW$lh)(gxF&-Yg$@(nUdLsBMPDa7&P^>iR5339$JxZqH_H%xsG@OH?5vt|@jr z&orLF<0l$QJukzY+OixtXmo3(#evL65*?~U8&!-q<}|oPsuqR8krF(CgiH&ovgj6%%rM!iB}X3%8+!=Mn{9pYDcEa8q8Ohq zABI}U{h0|HeG9k>wN|a%jz;EZH@nLJ86Eqlws z42!D~Ykoh2Vr)7~K`|ogmNW3h0j%&egr8FqG)O{%&jMUyw;3(0xv6^3hZh}RdaIy* zz+MuET!3j5{!$!pp#Es-F5Kxxy0qB#hqy#=wA(Ur3L!;Uf~d_(FrdXy>BqYhH-5&-c+26|gyuJ(Q% z4)I4b&GxjVJzJ|m@NXZl>+V)QM`}kbFhmIUwch-|p>Gi3tZSArM6oF#9lsbret;l4 zoc*pycQl~XuNqp4g~~ens1RH}I@m^Z|CIqX2{Q?*Ahg2msCU)p4Lu1t30i%qrwR1| zc}B-g#l1!o;R3q2oRmQLZnw?LYq$Yn0rmsd>Q8ow1S}8+MLBWiAr3~GnJ|yI66Vz}422igSVn}MD4W@Av{V@ejS7*~ z&1BwyK_VXDQIo0&EjG;uVz_S#3)~Fgq(zR1TSW8$UA44hM<*i*Aj+Q#VL_uLul*JB z1h$-z3ez0@CwCiXlvjLag;Mwya=O!9!xjUrR09l8Hg~N5AvB^hR1v3pJX)Oz~=#N?Co}g_GSf<35&o`4dlm zOVF*KW5_nwA4dQ9qgIJmNwWS&B9?Q!kEaCJ{15E+0^AQM;K%$iuzj$?DY!8-^(B4| zyY$}At30)RJDAx9)4FUgWS(m0i#gLfte)PT2k0|VOqhZEkRbECu}JPc(ss=)-?QVf zU>zBZ?`Kss={=^ck^?y{6*IGqLG6w%nbI|N5_|fRO!2kjKyybhXy=bDC0Q_VbN~PV z4e+#MV86jtg6#+S`w@TyzyL^mm9sKt`uoagYh|pa3IhN`CmI$N3A7PY^8^P#fSLj> zlE)N&389A}LF)%ni-Xq~vez5#iC|uqLW%~#KqeNKxe}wv+N`3csQrjl+#x%~(>xS9 zF>7}#Y{)Zxf9lD}8S^a$K?OLaG0?$f#wtV$@N=qJt4Qagf&L-swV=mD{ccMJ39JJi z5l4R>26T@s6VscRfRf8r3A%qhjle=wD%YqZPsw1NW|+$?5fYO{;Xogw5kkPu?kWP> z`xP=~HZcu|R>e=<4x)>;w=%D3&Pm zi%D2M=DbAgturfWNW|i!Df|$1^j5tU$@%L_dAesb`a>TN5o7k)kkt3uhl0E^bgu^w z?aj~rp=+x!&u8P-zr}#J|NPj`i4PljL)u4hnn@T(8ZX~}1=48o5YlH7PQ{!#C#*;{ zfql=6IFv9kqhObPgAweBGcn;1rIK%d9m#TztAL%|kDMpVWN;^Hcns*db)po(@JHt) zkk^k;>h=u|fD&@jBW-z;oqjaIDuz(=c^)dum?Lg&zYT3k)=pTdSV|A*|2yGgFZ4vQYX3p$G^SYBr`wB-RU z!d-D2fEC%i%0gg11ALck84|9EPFux?jztKPWT)aV*%>`A$9Q@3q{YaUG#1 z4MJu)9q!lLefE!lgLB$~luOTJb`$j!v=AeN z-o8%OPt)c9R#bI6`cwW3999k>r;&?;y0Fl!{Om_g;R%b`y~ur_IeJ)O9X5m-O|3E)M=&gVo@1LkB}KrA&`TESm~$`@;s=wzBsy zA0Aq6y=l{xqQT2U&FW7WsGhB!{>Az3ukhE1X3~R685|EP6=gNE{&-uB($*kh#-vkM zn9xJoQ{B8UIM(GK@(}_0wW}GlAaQG7l#dThZUZPzr-zqBF2GGE^nNNB@7!7wk(#{e zTQK2q)~fzFYfg$n*o73Nk`+^>crb+u)N^K0O=QC5yOM0b;2y7`Or@lEOU1~g$hlxw z%gXYy>X=xhwd+eQzus*lkt1)<0X`K76PS1RXoyjlYe343x_AX-|zZsS1n`Up0cEUDbiW z<^y-}pX&*%*?PG)Xax+|zHBQ^@a|-qGG51z>0{niw{t+CB2L4E?nV+va)zZlquI zt8JtkNvd$6f)^ezKj2a2TU-Qx|t5o#$%*+AuPW0?Wp27F+MM?kOnuc== zD1blsh4i^!Bz1csd{qk?G)4N_|Gr2t!M{<3^qTxe1ggj%*7ZM7W2XW zta~c3?8&iXvT1nWU_(7>50v@Qbw>%{@kGBL@)7;jxph3Ev)RN&@wIC~roh7~bZsb7uoEzQKU z9NqE;%*LC92rPHBwJZa9W8kky>!n5n|Lq)HB=Xt2Q--ekKO+R^&oBY*(>b`9xw;!U zyD*yAnf~n`q8Qc1{xdwVOZbBHix@rB!#{LPj{sMXT)v2}2qm8e8!J@+(_~&4?W0>L zwy6wm-~VCV1<95t#oQ=FD79lClG_^5tLM7raAl(g#@ZOIog*FuJG0G?{6X?hXXPRc zY{e+4!LwtoPO_4C*0>Q6+#tFASI+{BC@Wwq#{qj6w--5_IQB$oAT+Liunf{jjFS-9y_J5C@=4ZQ>nww=_Pym1o z5&%H>SG)i6t(Kqd9seV=s#4W+m}5rwo2qG5fzzh@UROZUSY}*{X{92Ws0|(=J?vzU z%M_PAaJhPY*5>q`(dOyIRA|C|S$u zWyZzg+xiN3K{>j_{tl6gGRPRX@Xn&hB&<%{_%S>eOhc_mC`6LOI=!bB)dav5elGVb zb+~De$&bBj&H9u;mODk=7yB;&!SUm!y(eSv_s^|mjJ;fRz@`C)uiFmI+l9bRVzF|} zE)_7yGNOS4-d|21`zf4cnTVI)W$VxO`pl5C7CE10(UsC~3Yh+I3gLwag+CxWPMN6u zf*4>r=rhe>hWc^Vv~*n4FJi=&%C#*pSSVrv^{P%khB(lj)1aMJ=kbt+eqaT7!0*c9^rT ziEV>i&0&zka@RAg7_x|=8lE#>Cda!>7N&i=^W({t>yhtK!1wt5)PZ!>_wk~1^01za z>y}{_Yx&X>PJSw_nS5@d`c z@&W6Lh-4F(DnJ{V94Er)zu})VWnb-4r5lOuNO$aDe>^KeO;?em+^oeid}^AoX#=U1 z9Rn&qL0pkUa?)a)aPS7EBntwH1@?dIEaa#5{qsWxj0pdA_fMFwrV0T7`$v5NfPVn~ zVFq37imY3CR@afAF<}qdU&{Lrz+XfmAdu&O0RG_#mVe_&z@Un#dHy%fUkn3!@kIb- z7XXMV1^Hwc|LVwJIG~@);-8NEgJWuI`!~{GeB=K@`fslCpGa!Q|BduFbNQ6*|3doT z@$P@hrgIATkLdRk;-AR(zs36BR`EX}Jb{4!wvnGGf7!@?i}Zib62$)u&R?_SeGT}R uo%#Qnr2lPU{<9bL|7!nld-I9&m%aI?9}u5||5vaN4PgAVQ1o|yJ^eqAUU{Ve literal 0 HcmV?d00001 diff --git a/Externals/SDL/Watcom-Win32.zip b/Externals/SDL/Watcom-Win32.zip new file mode 100644 index 0000000000000000000000000000000000000000..c60af6df43d2ab91ec59bc16d372ee056fcca958 GIT binary patch literal 3709 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 literal 0 HcmV?d00001 diff --git a/Externals/SDL/WhatsNew b/Externals/SDL/WhatsNew new file mode 100644 index 0000000000..927fdd264f --- /dev/null +++ b/Externals/SDL/WhatsNew @@ -0,0 +1,727 @@ + +This is a list of API changes in SDL's version history. + +Version 1.0: + +1.2.14: + Added cast macros for correct usage with C++: + SDL_reinterpret_cast(type, expression) + SDL_static_cast(type, expression) + + Added SDL_VIDEO_FULLSCREEN_DISPLAY as a preferred synonym for + SDL_VIDEO_FULLSCREEN_HEAD on X11. + + Added SDL_DISABLE_LOCK_KEYS environment variable to enable normal + up/down events for Caps-Lock and Num-Lock keys. + +1.2.13: + Added SDL_BUTTON_X1 and SDL_BUTTON_X2 constants. + +1.2.12: + Added SDL_VIDEO_ALLOW_SCREENSAVER to override SDL's disabling + of the screensaver on Mac OS X and X11. + +1.2.10: + If SDL_OpenAudio() is passed zero for the desired format + fields, the following environment variables will be used + to fill them in: + SDL_AUDIO_FREQUENCY + SDL_AUDIO_FORMAT + SDL_AUDIO_CHANNELS + SDL_AUDIO_SAMPLES + If an environment variable is not specified, it will be set + to a reasonable default value. + + Added support for the SDL_VIDEO_FULLSCREEN_HEAD environment + variable, currently supported on X11 Xinerama configurations. + + Added SDL_GL_SWAP_CONTROL to wait for vsync in OpenGL applications. + + Added SDL_GL_ACCELERATED_VISUAL to guarantee hardware acceleration. + + Added current_w and current_h to the SDL_VideoInfo structure, + which is set to the desktop resolution during video intialization, + and then set to the current resolution when a video mode is set. + + SDL_SetVideoMode() now accepts 0 for width or height and will use + the current video mode (or the desktop mode if no mode has been set.) + + Added SDL_GetKeyRepeat() + + Added SDL_config.h, with defaults for various build environments. + +1.2.7: + Added CPU feature detection functions to SDL_cpuinfo.h: + SDL_HasRDTSC(), SDL_HasMMX(), SDL_Has3DNow(), SDL_HasSSE(), + SDL_HasAltiVec() + Added function to create RWops from const memory: SDL_RWFromConstMem() + +1.2.6: + Added SDL_LoadObject(), SDL_LoadFunction(), and SDL_UnloadObject() + + Added SDL_GL_MULTISAMPLEBUFFERS and SDL_GL_MULTISAMPLESAMPLES for FSAA + +1.2.5: + Added SDL_BUTTON_WHEELUP (4) and SDL_BUTTON_WHEELDOWN (5) + + Added SDL_GL_STEREO for stereoscopic OpenGL contexts + +1.2.0: + Added SDL_VIDEOEXPOSE event to signal that the screen needs to + be redrawn. This is currently only delivered to OpenGL windows + on X11, though it may be delivered in the future when the video + memory is lost under DirectX. + +1.1.8: + You can pass SDL_NOFRAME to SDL_VideoMode() to create a window + that has no title bar or frame decoration. Fullscreen video + modes automatically have this flag set. + + Added a function to query the clipping rectangle for a surface: + void SDL_GetClipRect(SDL_Surface *surface, SDL_Rect *rect) + + Added a function to query the current event filter: + SDL_EventFilter SDL_GetEventFilter(void) + + If you pass -1 to SDL_ShowCursor(), it won't change the current + cursor visibility state, but will still return it. + + SDL_LockSurface() and SDL_UnlockSurface() are recursive, meaning + you can nest them as deep as you want, as long as each lock call + has a matching unlock call. The surface remains locked until the + last matching unlock call. + + Note that you may not blit to or from a locked surface. + +1.1.7: + The SDL_SetGammaRamp() and SDL_GetGammaRamp() functions now take + arrays of Uint16 values instead of Uint8 values. For the most part, + you can just take your old values and shift them up 8 bits to get + new correct values for your gamma ramps. + + You can pass SDL_RLEACCEL in flags passed to SDL_ConvertSurface() + and SDL will try to RLE accelerate colorkey and alpha blits in the + resulting surface. + +1.1.6: + Added a function to return the thread ID of a specific thread: + Uint32 SDL_GetThreadID(SDL_Thread *thread) + If 'thread' is NULL, this function returns the id for this thread. + +1.1.5: + The YUV overlay structure has been changed to use an array of + pitches and pixels representing the planes of a YUV image, to + better enable hardware acceleration. The YV12 and IYUV formats + each have three planes, corresponding to the Y, U, and V portions + of the image, while packed pixel YUV formats just have one plane. + + For palettized mode (8bpp), the screen colormap is now split in + a physical and a logical palette. The physical palette determines + what colours the screen pixels will get when displayed, and the + logical palette controls the mapping from blits to/from the screen. + A new function, SDL_SetPalette() has been added to change + logical and physical palettes separately. SDL_SetColors() works + just as before, and is equivalent to calling SDL_SetPalette() with + a flag argument of (SDL_LOGPAL|SDL_PHYSPAL). + + SDL_BlitSurface() no longer modifies the source rectangle, only the + destination rectangle. The width/height members of the destination + rectangle are ignored, only the position is used. + + The old source clipping function SDL_SetClipping() has been replaced + with a more useful function to set the destination clipping rectangle: + SDL_bool SDL_SetClipRect(SDL_Surface *surface, SDL_Rect *rect) + + Added a function to see what subsystems have been initialized: + Uint32 SDL_WasInit(Uint32 flags) + + The Big Alpha Flip: SDL now treats alpha as opacity like everybody + else, and not as transparency: + + A new cpp symbol: SDL_ALPHA_OPAQUE is defined as 255 + A new cpp symbol: SDL_ALPHA_TRANSPARENT is defined as 0 + Values between 0 and 255 vary from fully transparent to fully opaque. + + New functions: + SDL_DisplayFormatAlpha() + Returns a surface converted to a format with alpha-channel + that can be blit efficiently to the screen. (In other words, + like SDL_DisplayFormat() but the resulting surface has + an alpha channel.) This is useful for surfaces with alpha. + SDL_MapRGBA() + Works as SDL_MapRGB() but takes an additional alpha parameter. + SDL_GetRGBA() + Works as SDL_GetRGB() but also returns the alpha value + (SDL_ALPHA_OPAQUE for formats without an alpha channel) + + Both SDL_GetRGB() and SDL_GetRGBA() now always return values in + the [0..255] interval. Previously, SDL_GetRGB() would return + (0xf8, 0xfc, 0xf8) for a completely white pixel in RGB565 format. + (N.B.: This is broken for bit fields < 3 bits.) + + SDL_MapRGB() returns pixels in which the alpha channel is set opaque. + + SDL_SetAlpha() can now be used for both setting the per-surface + alpha, using the new way of thinking of alpha, and also to enable + and disable per-pixel alpha blending for surfaces with an alpha + channel: + To disable alpha blending: + SDL_SetAlpha(surface, 0, 0); + To re-enable alpha blending: + SDL_SetAlpha(surface, SDL_SRCALPHA, 0); + Surfaces with an alpha channel have blending enabled by default. + + SDL_SetAlpha() now accepts SDL_RLEACCEL as a flag, which requests + RLE acceleration of blits, just as like with SDL_SetColorKey(). + This flag can be set for both surfaces with an alpha channel + and surfaces with an alpha value set by SDL_SetAlpha(). + As always, RLE surfaces must be locked before pixel access is + allowed, and unlocked before any other SDL operations are done + on it. + + The blit semantics for surfaces with and without alpha and colorkey + have now been defined: + + RGBA->RGB: + SDL_SRCALPHA set: + alpha-blend (using alpha-channel). + SDL_SRCCOLORKEY ignored. + SDL_SRCALPHA not set: + copy RGB. + if SDL_SRCCOLORKEY set, only copy the pixels matching the + RGB values of the source colour key, ignoring alpha in the + comparison. + + RGB->RGBA: + SDL_SRCALPHA set: + alpha-blend (using the source per-surface alpha value); + set destination alpha to opaque. + SDL_SRCALPHA not set: + copy RGB, set destination alpha to opaque. + both: + if SDL_SRCCOLORKEY set, only copy the pixels matching the + source colour key. + + RGBA->RGBA: + SDL_SRCALPHA set: + alpha-blend (using the source alpha channel) the RGB values; + leave destination alpha untouched. [Note: is this correct?] + SDL_SRCCOLORKEY ignored. + SDL_SRCALPHA not set: + copy all of RGBA to the destination. + if SDL_SRCCOLORKEY set, only copy the pixels matching the + RGB values of the source colour key, ignoring alpha in the + comparison. + + RGB->RGB: + SDL_SRCALPHA set: + alpha-blend (using the source per-surface alpha value). + SDL_SRCALPHA not set: + copy RGB. + both: + if SDL_SRCCOLORKEY set, only copy the pixels matching the + source colour key. + + As a special case, blits from surfaces with per-surface alpha + value of 128 (50% transparency) are optimised and much faster + than other alpha values. This does not apply to surfaces with + alpha channels (per-pixel alpha). + + New functions for manipulating the gamma of the display have + been added: + int SDL_SetGamma(float red, float green, float blue); + int SDL_SetGammaRamp(Uint8 *red, Uint8 *green, Uint8 *blue); + int SDL_GetGammaRamp(Uint8 *red, Uint8 *green, Uint8 *blue); + Gamma ramps are tables with 256 entries which map the screen color + components into actually displayed colors. For an example of + implementing gamma correction and gamma fades, see test/testgamma.c + Gamma control is not supported on all hardware. + +1.1.4: + The size of the SDL_CDtrack structure changed from 8 to 12 bytes + as the size of the length member was extended to 32 bits. + + You can now use SDL for 2D blitting with a GL mode by passing the + SDL_OPENGLBLIT flag to SDL_SetVideoMode(). You can specify 16 or + 32 bpp, and the data in the framebuffer is put into the GL scene + when you call SDL_UpdateRects(), and the scene will be visible + when you call SDL_GL_SwapBuffers(). + + Run the "testgl" test program with the -logo command line option + to see an example of this blending of 2D and 3D in SDL. + +1.1.3: + Added SDL_FreeRW() to the API, to complement SDL_AllocRW() + + Added resizable window support - just add SDL_RESIZABLE to the + SDL_SetVideoMode() flags, and then wait for SDL_VIDEORESIZE events. + See SDL_events.h for details on the new SDL_ResizeEvent structure. + + Added condition variable support, based on mutexes and semaphores. + SDL_CreateCond() + SDL_DestroyCond() + SDL_CondSignal() + SDL_CondBroadcast() + SDL_CondWait() + SDL_CondTimedWait() + The new function prototypes are in SDL_mutex.h + + Added counting semaphore support, based on the mutex primitive. + SDL_CreateSemaphore() + SDL_DestroySemaphore() + SDL_SemWait() + SDL_SemTryWait() + SDL_SemWaitTimeout() + SDL_SemPost() + SDL_SemValue() + The new function prototypes are in SDL_mutex.h + + Added support for asynchronous blitting. To take advantage of this, + you must set the SDL_ASYNCBLIT flag when setting the video mode and + creating surfaces that you want accelerated in this way. You must + lock surfaces that have this flag set, and the lock will block until + any queued blits have completed. + + Added YUV video overlay support. + The supported YUV formats are: YV12, IYUV, YUY2, UYVY, and YVYU. + This function creates an overlay surface: + SDL_CreateYUVOverlay() + You must lock and unlock the overlay to get access to the data: + SDL_LockYUVOverlay() SDL_UnlockYUVOverlay() + You can then display the overlay: + SDL_DisplayYUVOverlay() + You must free the overlay when you are done using it: + SDL_FreeYUVOverlay() + See SDL_video.h for the full function prototypes. + + The joystick hat position constants have been changed: + Old constant New constant + ------------ ------------ + 0 SDL_HAT_CENTERED + 1 SDL_HAT_UP + 2 SDL_HAT_RIGHTUP + 3 SDL_HAT_RIGHT + 4 SDL_HAT_RIGHTDOWN + 5 SDL_HAT_DOWN + 6 SDL_HAT_LEFTDOWN + 7 SDL_HAT_LEFT + 8 SDL_HAT_LEFTUP + The new constants are bitmasks, so you can check for the + individual axes like this: + if ( hat_position & SDL_HAT_UP ) { + } + and you'll catch left-up, up, and right-up. + +1.1.2: + Added multiple timer support: + SDL_AddTimer() and SDL_RemoveTimer() + + SDL_WM_SetIcon() now respects the icon colorkey if mask is NULL. + +1.1.0: + Added initial OpenGL support. + First set GL attributes (such as RGB depth, alpha depth, etc.) + SDL_GL_SetAttribute() + Then call SDL_SetVideoMode() with the SDL_OPENGL flag. + Perform all of your normal GL drawing. + Finally swap the buffers with the new SDL function: + SDL_GL_SwapBuffers() + See the new 'testgl' test program for an example of using GL with SDL. + + You can load GL extension functions by using the function: + SDL_GL_LoadProcAddress() + + Added functions to initialize and cleanup specific SDL subsystems: + SDL_InitSubSystem() and SDL_QuitSubSystem() + + Added user-defined event type: + typedef struct { + Uint8 type; + int code; + void *data1; + void *data2; + } SDL_UserEvent; + This structure is in the "user" member of an SDL_Event. + + Added a function to push events into the event queue: + SDL_PushEvent() + + Example of using the new SDL user-defined events: + { + SDL_Event event; + + event.type = SDL_USEREVENT; + event.user.code = my_event_code; + event.user.data1 = significant_data; + event.user.data2 = 0; + SDL_PushEvent(&event); + } + + Added a function to get mouse deltas since last query: + SDL_GetRelativeMouseState() + + Added a boolean datatype to SDL_types.h: + SDL_bool = { SDL_TRUE, SDL_FALSE } + + Added a function to get the current audio status: + SDL_GetAudioState(); + It returns one of: + SDL_AUDIO_STOPPED, + SDL_AUDIO_PLAYING, + SDL_AUDIO_PAUSED + + Added an AAlib driver (ASCII Art) - by Stephane Peter. + +1.0.6: + The input grab state is reset after each call to SDL_SetVideoMode(). + The input is grabbed by default in fullscreen mode, and ungrabbed in + windowed mode. If you want to set input grab to a particular value, + you should set it after each call to SDL_SetVideoMode(). + +1.0.5: + Exposed SDL_AudioInit(), SDL_VideoInit() + Added SDL_AudioDriverName() and SDL_VideoDriverName() + + Added new window manager function: + SDL_WM_ToggleFullScreen() + This is currently implemented only on Linux + + The ALT-ENTER code has been removed - it's not appropriate for a + lib to bind keys when they aren't even emergency escape sequences. + + ALT-ENTER functionality can be implemented with the following code: + + int Handle_AltEnter(const SDL_Event *event) + { + if ( event->type == SDL_KEYDOWN ) { + if ( (event->key.keysym.sym == SDLK_RETURN) && + (event->key.keysym.mod & KMOD_ALT) ) { + SDL_WM_ToggleFullScreen(SDL_GetVideoSurface()); + return(0); + } + } + return(1); + } + SDL_SetEventFilter(Handle_AltEnter); + +1.0.3: + Under X11, if you grab the input and hide the mouse cursor, + the mouse will go into a "relative motion" mode where you + will always get relative motion events no matter how far in + each direction you move the mouse - relative motion is not + bounded by the edges of the window (though the absolute values + of the mouse positions are clamped by the size of the window). + The SVGAlib, framebuffer console, and DirectInput drivers all + have this behavior naturally, and the GDI and BWindow drivers + never go into "relative motion" mode. + +1.0.2: + Added a function to enable keyboard repeat: + SDL_EnableKeyRepeat() + + Added a function to grab the mouse and keyboard input + SDL_WM_GrabInput() + + Added a function to iconify the window. + SDL_WM_IconifyWindow() + If this function succeeds, the application will receive an event + signaling SDL_APPACTIVE event + +1.0.1: + Added constants to SDL_audio.h for 16-bit native byte ordering: + AUDIO_U16SYS, AUDIO_S16SYS + +1.0.0: + New public release + +Version 0.11: + +0.11.5: + A new function SDL_GetVideoSurface() has been added, and returns + a pointer to the current display surface. + + SDL_AllocSurface() has been renamed SDL_CreateRGBSurface(), and + a new function SDL_CreateRGBSurfaceFrom() has been added to allow + creating an SDL surface from an existing pixel data buffer. + + Added SDL_GetRGB() to the headers and documentation. + +0.11.4: + SDL_SetLibraryPath() is no longer meaningful, and has been removed. + +0.11.3: + A new flag for SDL_Init(), SDL_INIT_NOPARACHUTE, prevents SDL from + installing fatal signal handlers on operating systems that support + them. + +Version 0.9: + +0.9.15: + SDL_CreateColorCursor() has been removed. Color cursors should + be implemented as sprites, blitted by the application when the + cursor moves. To get smooth color cursor updates when the app + is busy, pass the SDL_INIT_EVENTTHREAD flag to SDL_Init(). This + allows you to handle the mouse motion in another thread from an + event filter function, but is currently only supported by Linux + and BeOS. Note that you'll have to protect the display surface + from multi-threaded access by using mutexes if you do this. + + Thread-safe surface support has been removed from SDL. + This makes blitting somewhat faster, by removing SDL_MiddleBlit(). + Code that used SDL_MiddleBlit() should use SDL_LowerBlit() instead. + You can make your surfaces thread-safe by allocating your own + mutex and making lock/unlock calls around accesses to your surface. + +0.9.14: + SDL_GetMouseState() now takes pointers to int rather than Uint16. + + If you set the SDL_WINDOWID environment variable under UNIX X11, + SDL will use that as the main window instead of creating it's own. + This is an unsupported extension to SDL, and not portable at all. + +0.9.13: + Added a function SDL_SetLibraryPath() which can be used to specify + the directory containing the SDL dynamic libraries. This is useful + for commercial applications which ship with particular versions + of the libraries, and for security on multi-user systems. + If this function is not used, the default system directories are + searched using the native dynamic object loading mechanism. + + In order to support C linkage under Visual C++, you must declare + main() without any return type: + main(int argc, char *argv[]) { + /* Do the program... */ + return(0); + } + C++ programs should also return a value if compiled under VC++. + + The blit_endian member of the SDL_VideoInfo struct has been removed. + + SDL_SymToASCII() has been replaced with SDL_GetKeyName(), so there + is now no longer any function to translate a keysym to a character. + + The SDL_keysym structure has been extended with a 'scancode' and + 'unicode' member. The 'scancode' is a hardware specific scancode + for the key that was pressed, and may be 0. The 'unicode' member + is a 16-bit UNICODE translation of the key that was pressed along + with any modifiers or compose keys that have been pressed. + If no UNICODE translation exists for the key, 'unicode' will be 0. + + Added a function SDL_EnableUNICODE() to enable/disable UNICODE + translation of character keypresses. Translation defaults off. + + To convert existing code to use the new API, change code which + uses SDL_SymToASCII() to get the keyname to use SDL_GetKeyName(), + and change code which uses it to get the ASCII value of a sym to + use the 'unicode' member of the event keysym. + +0.9.12: + There is partial support for 64-bit datatypes. I don't recommend + you use this if you have a choice, because 64-bit datatypes are not + supported on many platforms. On platforms for which it is supported, + the SDL_HAS_64BIT_TYPE C preprocessor define will be enabled, and + you can use the Uint64 and Sint64 datatypes. + + Added functions to SDL_endian.h to support 64-bit datatypes: + SDL_SwapLE64(), SDL_SwapBE64(), + SDL_ReadLE64(), SDL_ReadBE64(), SDL_WriteLE64(), SDL_WriteBE64() + + A new member "len_ratio" has been added to the SDL_AudioCVT structure, + and allows you to determine either the original buffer length or the + converted buffer length, given the other. + + A new function SDL_FreeWAV() has been added to the API to free data + allocated by SDL_LoadWAV_RW(). This is necessary under Win32 since + the gcc compiled DLL uses a different heap than VC++ compiled apps. + + SDL now has initial support for international keyboards using the + Latin character set. + If a particular mapping is desired, you can set the DEFAULT_KEYBOARD + compile-time variable, or you can set the environment variable + "SDL_KEYBOARD" to a string identifying the keyboard mapping you desire. + The valid values for these variables can be found in SDL_keyboard.c + + Full support for German and French keyboards under X11 is implemented. + +0.9.11: + The THREADED_EVENTS compile-time define has been replaced with the + SDL_INIT_EVENTTHREAD flag. If this flag is passed to SDL_Init(), + SDL will create a separate thread to perform input event handling. + If this flag is passed to SDL_Init(), and the OS doesn't support + event handling in a separate thread, SDL_Init() will fail. + Be sure to add calls to SDL_Delay() in your main thread to allow + the OS to schedule your event thread, or it may starve, leading + to slow event delivery and/or dropped events. + Currently MacOS and Win32 do not support this flag, while BeOS + and Linux do support it. I recommend that your application only + use this flag if absolutely necessary. + + The SDL thread function passed to SDL_CreateThread() now returns a + status. This status can be retrieved by passing a non-NULL pointer + as the 'status' argument to SDL_WaitThread(). + + The volume parameter to SDL_MixAudio() has been increased in range + from (0-8) to (0-128) + + SDL now has a data source abstraction which can encompass a file, + an area of memory, or any custom object you can envision. It uses + these abstractions, SDL_RWops, in the endian read/write functions, + and the built-in WAV and BMP file loaders. This means you can load + WAV chunks from memory mapped files, compressed archives, network + pipes, or anything else that has a data read abstraction. + + There are three built-in data source abstractions: + SDL_RWFromFile(), SDL_RWFromFP(), SDL_RWFromMem() + along with a generic data source allocation function: + SDL_AllocRW() + These data sources can be used like stdio file pointers with the + following convenience functions: + SDL_RWseek(), SDL_RWread(), SDL_RWwrite(), SDL_RWclose() + These functions are defined in the new header file "SDL_rwops.h" + + The endian swapping functions have been turned into macros for speed + and SDL_CalculateEndian() has been removed. SDL_endian.h now defines + SDL_BYTEORDER as either SDL_BIG_ENDIAN or SDL_LIL_ENDIAN depending on + the endianness of the host system. + + The endian read/write functions now take an SDL_RWops pointer + instead of a stdio FILE pointer, to support the new data source + abstraction. + + The SDL_*LoadWAV() functions have been replaced with a single + SDL_LoadWAV_RW() function that takes a SDL_RWops pointer as it's + first parameter, and a flag whether or not to automatically + free it as the second parameter. SDL_LoadWAV() is a macro for + backward compatibility and convenience: + SDL_LoadWAV_RW(SDL_RWFromFile("sample.wav", "rb"), 1, ...); + + The SDL_*LoadBMP()/SDL_*SaveBMP() functions have each been replaced + with a single function that takes a SDL_RWops pointer as it's + first parameter, and a flag whether or not to automatically + free it as the second parameter. SDL_LoadBMP() and SDL_SaveBMP() + are macros for backward compatibility and convenience: + SDL_LoadBMP_RW(SDL_RWFromFile("sample.bmp", "rb"), 1, ...); + SDL_SaveBMP_RW(SDL_RWFromFile("sample.bmp", "wb"), 1, ...); + Note that these functions use SDL_RWseek() extensively, and should + not be used on pipes or other non-seekable data sources. + +0.9.10: + The Linux SDL_SysWMInfo and SDL_SysWMMsg structures have been + extended to support multiple types of display drivers, as well as + safe access to the X11 display when THREADED_EVENTS is enabled. + The new structures are documented in the SDL_syswm.h header file. + + Thanks to John Elliott , the UK keyboard + should now work properly, as well as the "Windows" keys on US + keyboards. + + The Linux CD-ROM code now reads the CD-ROM devices from /etc/fstab + instead of trying to open each block device on the system. + The CD must be listed in /etc/fstab as using the iso9660 filesystem. + + On Linux, if you define THREADED_EVENTS at compile time, a separate + thread will be spawned to gather X events asynchronously from the + graphics updates. This hasn't been extensively tested, but it does + provide a means of handling keyboard and mouse input in a separate + thread from the graphics thread. (This is now enabled by default.) + + A special access function SDL_PeepEvents() allows you to manipulate + the event queue in a thread-safe manner, including peeking at events, + removing events of a specified type, and adding new events of arbitrary + type to the queue (use the new 'user' member of the SDL_Event type). + + If you use SDL_PeepEvents() to gather events, then the main graphics + thread needs to call SDL_PumpEvents() periodically to drive the event + loop and generate input events. This is not necessary if SDL has been + compiled with THREADED_EVENTS defined, but doesn't hurt. + + A new function SDL_ThreadID() returns the identifier associated with + the current thread. + +0.9.9: + The AUDIO_STEREO format flag has been replaced with a new 'channels' + member of the SDL_AudioSpec structure. The channels are 1 for mono + audio, and 2 for stereo audio. In the future more channels may be + supported for 3D surround sound. + + The SDL_MixAudio() function now takes an additional volume parameter, + which should be set to SDL_MIX_MAXVOLUME for compatibility with the + original function. + + The CD-ROM functions which take a 'cdrom' parameter can now be + passed NULL, and will act on the last successfully opened CD-ROM. + +0.9.8: + No changes, bugfixes only. + +0.9.7: + No changes, bugfixes only. + +0.9.6: + Added a fast rectangle fill function: SDL_FillRect() + + Addition of a useful function for getting info on the video hardware: + const SDL_VideoInfo *SDL_GetVideoInfo(void) + This function replaces SDL_GetDisplayFormat(). + + Initial support for double-buffering: + Use the SDL_DOUBLEBUF flag in SDL_SetVideoMode() + Update the screen with a new function: SDL_Flip() + + SDL_AllocSurface() takes two new flags: + SDL_SRCCOLORKEY means that the surface will be used for colorkey blits + and if the hardware supports hardware acceleration of colorkey blits + between two surfaces in video memory, to place the surface in video + memory if possible, otherwise it will be placed in system memory. + SDL_SRCALPHA means that the surface will be used for alpha blits and + if the hardware supports hardware acceleration of alpha blits between + two surfaces in video memory, to place the surface in video memory + if possible, otherwise it will be placed in system memory. + SDL_HWSURFACE now means that the surface will be created with the + same format as the display surface, since having surfaces in video + memory is only useful for fast blitting to the screen, and you can't + blit surfaces with different surface formats in video memory. + +0.9.5: + You can now pass a NULL mask to SDL_WM_SetIcon(), and it will assume + that the icon consists of the entire image. + + SDL_LowerBlit() is back -- but don't use it on the display surface. + It is exactly the same as SDL_MiddleBlit(), but doesn't check for + thread safety. + + Added SDL_FPLoadBMP(), SDL_FPSaveBMP(), SDL_FPLoadWAV(), which take + a FILE pointer instead of a file name. + + Added CD-ROM audio control API: + SDL_CDNumDrives() + SDL_CDName() + SDL_CDOpen() + SDL_CDStatus() + SDL_CDPlayTracks() + SDL_CDPlay() + SDL_CDPause() + SDL_CDResume() + SDL_CDStop() + SDL_CDEject() + SDL_CDClose() + +0.9.4: + No changes, bugfixes only. + +0.9.3: + Mouse motion event now includes relative motion information: + Sint16 event->motion.xrel, Sint16 event->motion.yrel + + X11 keyrepeat handling can be disabled by defining IGNORE_X_KEYREPEAT + (Add -DIGNORE_X_KEYREPEAT to CFLAGS line in obj/x11Makefile) + +0.9.2: + No changes, bugfixes only. + +0.9.1: + Removed SDL_MapSurface() and SDL_UnmapSurface() -- surfaces are now + automatically mapped on blit. + +0.8.0: + SDL stable release diff --git a/Externals/SDL/Xcode.tar.gz b/Externals/SDL/Xcode.tar.gz new file mode 100644 index 0000000000000000000000000000000000000000..b18e74ef6f11a7ce182682ad10fbc77aee21fa6c GIT binary patch literal 918433 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≫myEwR00%rfur%4s(EVz|tX9}Ob`N;#ew)smU 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 z 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%0DG1V9yEjH@Sf%9GF`UG1_)M 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

    @u_oosm~^=(W%la6Yd?_*T4YguNkihS*>k5R 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

    qVM=ec?p&f(d)RgYm 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 z zIvfU>4u}rHJ~H6C>v=H6AMRMwMf>ua9umtEJ&!)Nu6bV$NG2K@IcmOC5+N<0Y@jXCi zmX*BmHgZ5>#8oQf`joqxmWVxGzftWjRq%9UH8l23p!iPDQjv+Snh>ZF|7-YYW=Fq7 z#X+e^bJ(Py#)u5Z8IPS={5z#sY{~W#H#&c6UlPTVyd%vuVGO#SHfDUgT;-z2wt|Q{ zjUJQyQ$GJ(A+@>Uig$oX-=JsnM9adahM24`O;{%IDUumh9qqN!G8MwS`VdbwZ5ifK z0Fs?odyMx3dt!`U_5jd~*iKCrkq1DDd^u4#KDW-62&l@j*~9ZB$3L|U>>Zw)aXgfi z%414yvx@gZ;Ur$jzeaAKmwJi~fkYcqO8VNUXfEXyBpbvessh7Vn;RnPc=t8&P7nAjE8d3s?c?Gyt&B0kBTKr5AkMFT4Hj zWUJrj%fDcmzQMwMesy+-t!?w2+vGgVpMN}1`T$3D`}J)LZQJBsvCceUk-tB*@pP7L z^Ud4joUqQ`rE#x?kS`W)ZHb6`N0E!64s#fIk7zGhtsZfs0Km9Q zH1dk9QOF9@oLsIS+^FNR|6*WGO6i6IqR~;E6Sh)H@>L`rhSH_g&8X6*241D16u*?u zYZDaKq_pn<7ra_Eq@4(=ly9^Eert&FJag!YB3 zLkD*Pl#r8af+GR`%R#Z6LBCesliGx9e^lpEK;sAF26I>9M{o+q*lQ>m(?d1(B}F=$)N#Ujz$U9kpe>qfJWFGiX+nv z1Wrt~p{8c-eo)H%DOjS>pBP)N|Fe?VVqudr%$Y`!v$pPpL%jo;curGKxuHhu?O zYrT5!@@kRjEk9@nZNkN?eU@dOIp~s%ee-qS%3h@}TB!8>A>|~sEtV=x5=tqHOF6yA z0b_E{FIoe5fCkfF-G8IB8VJh{rqIH5B}wKzYXlvkt0KX5&5<*GSy!Ia2-8~uB>ei( zgSaLp*f9F#$kIp3{2OZrY11I2b^3N=If5j%RGdFf<$d16>1o4O1$j^mmP!8Z2Es9R z!XHrjOpY`kZ9#U@nEk*Zt&Ny-3_p9uvqafXdo846b)d>~i7(qCRW{Ip|j zLZmR=BzBB=+1@Ci!erK4Z9w=8*+l3p$`IY z1+MY8Ut%*xts4qAZGh8|++n?vJGf~}2JCa&839nP?s!r}p6FfVqOf*Q%=k&k?f}{f z5=eC2xTY4G0T;_ESn@4gpS6c9X(G_EK2cZ>M$(}wZ2n=jNw&md{*wW)Rf z@pXR5kP-j)i1=pkVm;*d%_*gyA4RPPh$|KJm2J~@W+vR$VuP!t>-?n1qIX2|?IYNS zZn3J9-)<6IyQnW~A^FS2N4xt(H}%&~o5M#>qB=HI?00l9TZ-ilmyf6lo`X@y*;)a| zyy0NYzbL+AgIe4tzfac4wAfu@Xj2sQlAAS}Uqe(UD0Um^Dm%1n zxxjb}0$oT32`exCX}=NplaaLBeNvj=L&{C|XLq&4YaLfsK^@G9dNZOEN)aelAa!c! z0{p!&ka3Ao=Mi}pf0M6JsMIJ}Gt;p2&~DaAlL$dOkD;JWJV>Z>HAzUC=ptVvP*JCx zCN``9v^!D~E>dcB#{D#wH}T>Qe4$*{Flkncxg}=d;aYqXYpckiEomZwdZDSKS|g!y zcWaQ|b!zPXXjzaSq=lHo`X`VAO`391xuM>2cB)R8^KUr3-fBVwDGCh_Z$~*nXrz_N zO`qV$U_y}$<-8vAvn7BH2gJpPoMsPvHqMsg(75>pi!Un)KwFJaZug*GeVqHZg8nfWqr{VvhJ}h*w218QjDK--okG{_qQ*pN(sdz{_oYmAk zLm89i^dttk%U|_~F7!q8jDF?USfe#MweOX$lQmjrFSOzOeG@FAAOSh8@qlri=hs!? zbZTEKU0*G;HYpeFrN!yMb7PsC?dvivOQ%kATymAz9;q6QaF*6?__@>*z+^zFK}hm% zXjBBD4Nc>(`hEPez&8Jo&OgIhL=aM6Z?wK8*v)iYWBDIcN~NT;lbU<1QS%(nDt7zg zjfna>io_{_x4wid^Z!*-Lz6|-oZucdMWbF@%Y?*cD`3azgB_)-r1PelyO<^e$>5yb zG*QpblmqW+r~Mv^>{}xh(HkpFl$c4p3{ALY9*Ttcxh>f{`0oO7N8Iu7XDBcR}d%&AD>AE?=zWCDtR|#t$ z5N|Qa|7xFB_>@4#nuC$}XE1nMiT}pe+WCM$##*?ZMj3j8eojLI;(V&2p0mxv*+J22 zLc;qqFE+_5Z1jm``iE5YB~1Y`}!-u!viM0MHLBs{&&!XHZj`Mcyypza+iFI~DculKyVs|Cwn z(5Q8pfQQ5`Q~EOZ|4?sq7tl3HNYkq1h3cRh-oV}}%Y-b4|HDZ^VH}cU ztOFJUczwpe8q#d7gY_6PK&fzN)3*4E{*fMy$J6ckGD7t=yR1PO{Q(^dkLNaM)3Bu< zPS^c+um0VZ`MpVavMS!f`MtpW8Mh2R46Ps_$GF+p+}YyjXBFT+0^Vu#fL{!GsXxUp zStTf0{Y)PAb$Lul@7JiG*1F{XNQd)xtiMISslvXmPV<=`t)HIm_OZHSO>|bn+Dh45 zFQHT)lhZ7tcN(m^rgHYusjas>B+$!Dz(S+~ZvD~hllURQ7oWsiRUrPR<&ObUUa4{S z|LD}B;|{?GpX6sQyI$1TjPV(i)m-P#u%dLFo}|~uWO~GUih*96LlCa4cGiyx_Qg@0 zwj=ou!zmO)A1GhkHR~sLvvYQ|%7XvU;Brc3TIc`9>4?eOmhVlM>8|XA#bQinDJxBu zPb~Z$c=l9#{@?VY(ehzWfDUIA&F1o*woUvp-T`OXV&}QZ2ZIR_2}X{^JT-0?te$iz ze@B5+h8^kQZi-#4(Mzm_Zb_5ig1x8Voo&aPq6BU{aUSZFG0+=Y*Tp-G=+ew6O0c4a z*o!48YXu8qV0qeh@j;=jKs3-O=f4v87$hlHDfe`a?7~vJMS;e5s^<|8!U6 z<}upnSqD{RSlnOgAxhmi|J>hOxa^e0`I3G>-DN=cVC{hMky@M$`leQpP4cEzl#TMH z=4JMf@lt<aeaYKegxRy3W7KsxFLC=ls z*n$kcTIz|0Z(F~qt;}Y1sTsmca&;}dD=4qh2J%fg6io7c$*uZFY#BhcUaN1$5sj}MjRhcBGuKj>9Y>THWP6z0vl zvi2g4T64FGQRNCXT#GuC^U+}v=_dK9e|!ne|M*b;wI?BbU+eiJe9m#a^eWA|uBXWnV78ke3gXInfzmi(P1U&Wb@TK z)%iko2E6fPiyeE+mNNHN?~G=yD$_Ql9}$@K65OvXWenv<)G?3k9=As+J%Yr%50>$sMFY0!z{j~Ja} z%1H0E;n&iG4LWcOKBir^YNJ1vUA7)&yOZ2$qIaR)+uEK@6@7(dYCRqr(L0!E`-rBL zzEY>Ovfm0epGj@nu@wZfFXknU3uBJv-Z5{IW}}yFf@-vPD-3|&g?O)FwzKMn2LR7@ zaIm-Xm@{eI<+hcoqsyLsO`U8Hu51^sY#**{C$4NSu5351Y(JiCziM7wqkF#o|0$e7 zEyTMemW#f-S4j5SMnksC^UKN8`vQ#Hrh7k%v_+slUsqz=@k7I=ZJUS7Zi;N{oOqi%KDgKV}|S$bY%ZTYE_OF0u2UYn zY?$m9*{_cQkGX*Bt^V$LG6K(ETp0b`a3AX-*~2#~c;3@IsdDc(qcB}w;FZ^g5`cc6j%u7N`_6u)esP3sYxi%P+tRV6$dkc7A#tz)YL@*Ry2mEkHh+FDtv1zjr%aO4Jw0DvUDeUD zOgjf4vcNpk74;6JPhH9CE^wd3UQW8N-|%=#gV4S-9lMxpTXTONWx9M@-Jj_4T)}n< zUU#y>kP_K&wLe(rKC-^QpsUw%-&NA9bgiQK48Jw=xNg3}Xyv;OZ+{D(4=dl7&9kwY zX=O9ZXmrzH?zdn?#(W$=K(9XosCQp`%)7$lOFi+V$nI{3adu6Ajq_@0W_??gul7E( zuJLANeT?(cVWTV^639WA?#Ntso2(7$$c-MMKJq$+E9nVd2zr6>QtH^ z8oY(ZHqsGu(CreeXRX`gi9|C7ub;I&f8}A>atDKUV!L*Oqn^sbGX&oj>Bf9xy}h<= z6zRrltq1hZ?_LW|HUeMQ(AWZ>F*N{he#;z!F=e>#Ki_AN1I#yEDo)mBvn9j5?BwKQ z{4l90u`{@ciT#Ne#rYuke*j@Xp1)X^_tao3L{fB-T-WXSwC{F3=lN~BJN3M=eoFm) z0I@LxTyH=nhtON3Bkb=xZErT8IIezp=fS*=d0ufg#CivXHUp5T8*lSMoA>T;?!DCC z!FY$k_$$nCm_d&r3~>X*3H?9gTM^LLC)by)!|V3(-?cK1H|y@oe(*VUyUuyr`4RYQ zICR|MoqHbwTX;@wkN)R0E?*xIT*bm3jZ3(Ojyvud!<6^ne~xULub53Epk8{v&OITA8wR#c2j&Ro9^rInVrc?N0N8k6SY(RC1D7!I z;8AyG4hN0IjB|H^Ca#hwrfVR24n|??;Ogk8b*WMPEy|h`7wUU6M{c#g$_m?xp(Ee;H+38tfovjYR~Aey4fB`R%23Jds-gs_1#o3%df|?Ms+PTuv{X|JcK|75+Tl&N$l#I4PFz zUnAEiA6Vb$Y&V9JfomJ4$xE3RM)LWB;SS|8v2;STsT)le;D!x?{tnK~uCp)y#Dpbd z`fx$-_?T?+((#>d#7sN>*I&yV69r04JQ-8;I>M{O4E`?}=MUyu#1C<1-`OGZV+*sv zZ%&+%nG2;LCUM`N4~HyxBvW6(*TsUPmFXLV;~70xBo}( zaCCKY(rzM)My0V(+${Lp*j8m%NCR>Kb-_d3cBM++SHz6C|Cejg--R&VOwS;sdO zc;tbpxMPE%^?VWp6FnT_*?JGAj^p7^Ey{Yq*wbu7EH*)&DU^T;)WE}+fOG~kdLN$Y zh9EP?9l!eyoA2fI_v7G>zBc&gZUEkqv*Y}ZUWXG6)CRM#IqGd4ve_(SV|4%1)p1Ak6?D(P zOuVe;_1*b!mVn~7E&MMck`-ie8POm^&dk+js8dfRsS!sEuUt+77(V83cFEFaR^&LlkhJy%75BF6ic@Q|7vA=a9sfPHG+%3c% z$P@n4M2>K#7k~ZA*^w&;(`9AvJ@t;=SU+=BMOTsuB9HzJfR_++_63Wd-_&p35T^4V z7QS~OV!v%gCh(A6#lR@3i6Q_65a}x*b2lT54*323Prsl@qDrs)tU5k3LYOgmN|P`$0qR~_!|DazL+AD_zinP$6SqF|N0VSWbG~T?-N4=di-zj-)XGL-{|lEC*1PlUBO@H z?iBr}vG?THedLUnrFyTMcdIuq+iu^T`Y+4%X1H)deN21jKke?0pe~Q(=di|FxmH7IH_FvZjr}%)IOzr|r=m@+ZG%+2p zIj8sFD*9q$01N?#RPi1d>pk)eV1Y>!|CsG~M{LZ#a1Pz+)B^+J2QcnKbn3q8-O;c4 zKThV;-rUQ2z4^DY`&lsFJ3BtuYhqC94^Dugcl1iew_fb!Y5(y%0B#(DWFS?IBRV z9$ardgD*hzM84ZvWRGn95oqJFmmu0ZFPyXX`3)I7e*`eMgwf&vjg2ue@bI~3U4I^? z|3_=RV*~wP%zerK`81!$)BpeLlP~)JFaGlo{lDJoU$y=V70UmQ>;K%B_5Ue8|7!Jr zEEo~_g00(aGjZfT+@FAO8iDRdeU3yqZTxuA=)5^;ouNwCZRcY@ob|{^fR?bLoG=)9 z&eU^*amL|v$*DIA-s9e`H={33z409I2u2h};W$i)QI&iyTgq%XHS5Glvf3b7cCLEscj^Lk{!TRZigUU*(&3h@Kw8Y4Xko~bbQi!noBu;^P=tS^n&g? zz-D*Z8=&FSr+FEkGQP$4U4S(Rq@jQqe3c#G5V*mGZNu4g-kst17t^5Yg<;#9p3O%X zRlhpMt>C9mhrvtz$H0HN^;@F(OO<(a-fm5&PvQA%Z`Pc{q8iUc%bi3o=lLWY>qH{z z>R?|!772Xl-A;q~xCat_%F}BfBjYf5&b2$mVkO33#mHZ!$Y15yyYba+Z+0{d)&SZt zl?{3$Y31H2rE)mVZDV@deJQ`By$k30bNu$b`u5=b`~;gG`C#KuPu%&qJ4ifiy2GK@ z0|rK(8~U{2chop(w{$MmS-Va7V$SnhW_7VFFi$p8K&T7+FoWhg`PO-k>7X2=*TaC! z#J;?x%c1+{&Y|L0u{kMUf9M*ZUy=qrx#sZf_bAWe@Cx|Eiv9oLJ^W(sJ zpGrgc6TLAYcLsRpJMaF5^T%y7Re1XsGt&l!`rS{m`_LQT&IZ3&$NlL{vH-%0A!7Oa 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 b%je7I%je7I%je5y)#v{Q|FC)D0C*z+lbU&4 literal 0 HcmV?d00001 diff --git a/Externals/SDL/acinclude/alsa.m4 b/Externals/SDL/acinclude/alsa.m4 new file mode 100644 index 0000000000..d818e70dbb --- /dev/null +++ b/Externals/SDL/acinclude/alsa.m4 @@ -0,0 +1,145 @@ +############################################################################## +dnl Configure Paths for Alsa +dnl Some modifications by Richard Boulton +dnl Christopher Lansdown +dnl Jaroslav Kysela +dnl Last modification: alsa.m4,v 1.23 2004/01/16 18:14:22 tiwai Exp +dnl AM_PATH_ALSA([MINIMUM-VERSION [, ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]]) +dnl Test for libasound, and define ALSA_CFLAGS and ALSA_LIBS as appropriate. +dnl enables arguments --with-alsa-prefix= +dnl --with-alsa-enc-prefix= +dnl --disable-alsatest +dnl +dnl For backwards compatibility, if ACTION_IF_NOT_FOUND is not specified, +dnl and the alsa libraries are not found, a fatal AC_MSG_ERROR() will result. +dnl +AC_DEFUN([AM_PATH_ALSA], +[dnl Save the original CFLAGS, LDFLAGS, and LIBS +alsa_save_CFLAGS="$CFLAGS" +alsa_save_LDFLAGS="$LDFLAGS" +alsa_save_LIBS="$LIBS" +alsa_found=yes + +dnl +dnl Get the cflags and libraries for alsa +dnl +AC_ARG_WITH(alsa-prefix, +[ --with-alsa-prefix=PFX Prefix where Alsa library is installed(optional)], +[alsa_prefix="$withval"], [alsa_prefix=""]) + +AC_ARG_WITH(alsa-inc-prefix, +[ --with-alsa-inc-prefix=PFX Prefix where include libraries are (optional)], +[alsa_inc_prefix="$withval"], [alsa_inc_prefix=""]) + +dnl FIXME: this is not yet implemented +AC_ARG_ENABLE(alsatest, +[ --disable-alsatest Do not try to compile and run a test Alsa program], +[enable_alsatest="$enableval"], +[enable_alsatest=yes]) + +dnl Add any special include directories +AC_MSG_CHECKING(for ALSA CFLAGS) +if test "$alsa_inc_prefix" != "" ; then + ALSA_CFLAGS="$ALSA_CFLAGS -I$alsa_inc_prefix" + CFLAGS="$CFLAGS -I$alsa_inc_prefix" +fi +AC_MSG_RESULT($ALSA_CFLAGS) + +dnl add any special lib dirs +AC_MSG_CHECKING(for ALSA LDFLAGS) +if test "$alsa_prefix" != "" ; then + ALSA_LIBS="$ALSA_LIBS -L$alsa_prefix" + LDFLAGS="$LDFLAGS $ALSA_LIBS" +fi + +dnl add the alsa library +ALSA_LIBS="$ALSA_LIBS -lasound -lm -ldl -lpthread" +LIBS=`echo $LIBS | sed 's/-lm//'` +LIBS=`echo $LIBS | sed 's/-ldl//'` +LIBS=`echo $LIBS | sed 's/-lpthread//'` +LIBS=`echo $LIBS | sed 's/ //'` +LIBS="$ALSA_LIBS $LIBS" +AC_MSG_RESULT($ALSA_LIBS) + +dnl Check for a working version of libasound that is of the right version. +min_alsa_version=ifelse([$1], ,0.1.1,$1) +AC_MSG_CHECKING(for libasound headers version >= $min_alsa_version) +no_alsa="" + alsa_min_major_version=`echo $min_alsa_version | \ + sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'` + alsa_min_minor_version=`echo $min_alsa_version | \ + sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'` + alsa_min_micro_version=`echo $min_alsa_version | \ + sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'` + +AC_LANG_SAVE +AC_LANG_C +AC_TRY_COMPILE([ +#include +], [ +/* ensure backward compatibility */ +#if !defined(SND_LIB_MAJOR) && defined(SOUNDLIB_VERSION_MAJOR) +#define SND_LIB_MAJOR SOUNDLIB_VERSION_MAJOR +#endif +#if !defined(SND_LIB_MINOR) && defined(SOUNDLIB_VERSION_MINOR) +#define SND_LIB_MINOR SOUNDLIB_VERSION_MINOR +#endif +#if !defined(SND_LIB_SUBMINOR) && defined(SOUNDLIB_VERSION_SUBMINOR) +#define SND_LIB_SUBMINOR SOUNDLIB_VERSION_SUBMINOR +#endif + +# if(SND_LIB_MAJOR > $alsa_min_major_version) + exit(0); +# else +# if(SND_LIB_MAJOR < $alsa_min_major_version) +# error not present +# endif + +# if(SND_LIB_MINOR > $alsa_min_minor_version) + exit(0); +# else +# if(SND_LIB_MINOR < $alsa_min_minor_version) +# error not present +# endif + +# if(SND_LIB_SUBMINOR < $alsa_min_micro_version) +# error not present +# endif +# endif +# endif +exit(0); +], + [AC_MSG_RESULT(found.)], + [AC_MSG_RESULT(not present.) + ifelse([$3], , [AC_MSG_ERROR(Sufficiently new version of libasound not found.)]) + alsa_found=no] +) +AC_LANG_RESTORE + +dnl Now that we know that we have the right version, let's see if we have the library and not just the headers. +if test "x$enable_alsatest" = "xyes"; then +AC_CHECK_LIB([asound], [snd_ctl_open],, + [ifelse([$3], , [AC_MSG_ERROR(No linkable libasound was found.)]) + alsa_found=no] +) +fi + +if test "x$alsa_found" = "xyes" ; then + ifelse([$2], , :, [$2]) + LIBS=`echo $LIBS | sed 's/-lasound//g'` + LIBS=`echo $LIBS | sed 's/ //'` + LIBS="-lasound $LIBS" +fi +if test "x$alsa_found" = "xno" ; then + ifelse([$3], , :, [$3]) + CFLAGS="$alsa_save_CFLAGS" + LDFLAGS="$alsa_save_LDFLAGS" + LIBS="$alsa_save_LIBS" + ALSA_CFLAGS="" + ALSA_LIBS="" +fi + +dnl That should be it. Now just export out symbols: +AC_SUBST(ALSA_CFLAGS) +AC_SUBST(ALSA_LIBS) +]) diff --git a/Externals/SDL/acinclude/esd.m4 b/Externals/SDL/acinclude/esd.m4 new file mode 100644 index 0000000000..58d64a9048 --- /dev/null +++ b/Externals/SDL/acinclude/esd.m4 @@ -0,0 +1,168 @@ +############################################################################## +# +# --- esd.m4 --- +# +# Configure paths for ESD +# Manish Singh 98-9-30 +# stolen back from Frank Belew +# stolen from Manish Singh +# Shamelessly stolen from Owen Taylor + +dnl AM_PATH_ESD([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]]) +dnl Test for ESD, and define ESD_CFLAGS and ESD_LIBS +dnl +AC_DEFUN([AM_PATH_ESD], +[dnl +dnl Get the cflags and libraries from the esd-config script +dnl +AC_ARG_WITH(esd-prefix,[ --with-esd-prefix=PFX Prefix where ESD is installed (optional)], + esd_prefix="$withval", esd_prefix="") +AC_ARG_WITH(esd-exec-prefix,[ --with-esd-exec-prefix=PFX Exec prefix where ESD is installed (optional)], + esd_exec_prefix="$withval", esd_exec_prefix="") +AC_ARG_ENABLE(esdtest, [ --disable-esdtest Do not try to compile and run a test ESD program], + , enable_esdtest=yes) + + if test x$esd_exec_prefix != x ; then + esd_args="$esd_args --exec-prefix=$esd_exec_prefix" + if test x${ESD_CONFIG+set} != xset ; then + ESD_CONFIG=$esd_exec_prefix/bin/esd-config + fi + fi + if test x$esd_prefix != x ; then + esd_args="$esd_args --prefix=$esd_prefix" + if test x${ESD_CONFIG+set} != xset ; then + ESD_CONFIG=$esd_prefix/bin/esd-config + fi + fi + + AC_PATH_PROG(ESD_CONFIG, esd-config, no) + min_esd_version=ifelse([$1], ,0.2.7,$1) + AC_MSG_CHECKING(for ESD - version >= $min_esd_version) + no_esd="" + if test "$ESD_CONFIG" = "no" ; then + no_esd=yes + else + ESD_CFLAGS=`$ESD_CONFIG $esdconf_args --cflags` + ESD_LIBS=`$ESD_CONFIG $esdconf_args --libs` + + esd_major_version=`$ESD_CONFIG $esd_args --version | \ + sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'` + esd_minor_version=`$ESD_CONFIG $esd_args --version | \ + sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'` + esd_micro_version=`$ESD_CONFIG $esd_config_args --version | \ + sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'` + if test "x$enable_esdtest" = "xyes" ; then + ac_save_CFLAGS="$CFLAGS" + ac_save_LIBS="$LIBS" + CFLAGS="$CFLAGS $ESD_CFLAGS" + LIBS="$LIBS $ESD_LIBS" +dnl +dnl Now check if the installed ESD is sufficiently new. (Also sanity +dnl checks the results of esd-config to some extent +dnl + rm -f conf.esdtest + AC_TRY_RUN([ +#include +#include +#include +#include + +char* +my_strdup (char *str) +{ + char *new_str; + + if (str) + { + new_str = malloc ((strlen (str) + 1) * sizeof(char)); + strcpy (new_str, str); + } + else + new_str = NULL; + + return new_str; +} + +int main () +{ + int major, minor, micro; + char *tmp_version; + + system ("touch conf.esdtest"); + + /* HP/UX 9 (%@#!) writes to sscanf strings */ + tmp_version = my_strdup("$min_esd_version"); + if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, µ) != 3) { + printf("%s, bad version string\n", "$min_esd_version"); + exit(1); + } + + if (($esd_major_version > major) || + (($esd_major_version == major) && ($esd_minor_version > minor)) || + (($esd_major_version == major) && ($esd_minor_version == minor) && ($esd_micro_version >= micro))) + { + return 0; + } + else + { + printf("\n*** 'esd-config --version' returned %d.%d.%d, but the minimum version\n", $esd_major_version, $esd_minor_version, $esd_micro_version); + printf("*** of ESD required is %d.%d.%d. If esd-config is correct, then it is\n", major, minor, micro); + printf("*** best to upgrade to the required version.\n"); + printf("*** If esd-config was wrong, set the environment variable ESD_CONFIG\n"); + printf("*** to point to the correct copy of esd-config, and remove the file\n"); + printf("*** config.cache before re-running configure\n"); + return 1; + } +} + +],, no_esd=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"]) + CFLAGS="$ac_save_CFLAGS" + LIBS="$ac_save_LIBS" + fi + fi + if test "x$no_esd" = x ; then + AC_MSG_RESULT(yes) + ifelse([$2], , :, [$2]) + else + AC_MSG_RESULT(no) + if test "$ESD_CONFIG" = "no" ; then + echo "*** The esd-config script installed by ESD could not be found" + echo "*** If ESD was installed in PREFIX, make sure PREFIX/bin is in" + echo "*** your path, or set the ESD_CONFIG environment variable to the" + echo "*** full path to esd-config." + else + if test -f conf.esdtest ; then + : + else + echo "*** Could not run ESD test program, checking why..." + CFLAGS="$CFLAGS $ESD_CFLAGS" + LIBS="$LIBS $ESD_LIBS" + AC_TRY_LINK([ +#include +#include +], [ return 0; ], + [ echo "*** The test program compiled, but did not run. This usually means" + echo "*** that the run-time linker is not finding ESD or finding the wrong" + echo "*** version of ESD. If it is not finding ESD, you'll need to set your" + echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point" + echo "*** to the installed location Also, make sure you have run ldconfig if that" + echo "*** is required on your system" + echo "***" + echo "*** If you have an old version installed, it is best to remove it, although" + echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"], + [ echo "*** The test program failed to compile or link. See the file config.log for the" + echo "*** exact error that occured. This usually means ESD was incorrectly installed" + echo "*** or that you have moved ESD since it was installed. In the latter case, you" + echo "*** may want to edit the esd-config script: $ESD_CONFIG" ]) + CFLAGS="$ac_save_CFLAGS" + LIBS="$ac_save_LIBS" + fi + fi + ESD_CFLAGS="" + ESD_LIBS="" + ifelse([$3], , :, [$3]) + fi + AC_SUBST(ESD_CFLAGS) + AC_SUBST(ESD_LIBS) + rm -f conf.esdtest +]) diff --git a/Externals/SDL/acinclude/libtool.m4 b/Externals/SDL/acinclude/libtool.m4 new file mode 100644 index 0000000000..6894db826b --- /dev/null +++ b/Externals/SDL/acinclude/libtool.m4 @@ -0,0 +1,7370 @@ +############################################################################## +# Based on libtool-2.2.6a +# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- +# +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, +# 2006, 2007, 2008 Free Software Foundation, Inc. +# Written by Gordon Matzigkeit, 1996 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +m4_define([_LT_COPYING], [dnl +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, +# 2006, 2007, 2008 Free Software Foundation, Inc. +# Written by Gordon Matzigkeit, 1996 +# +# This file is part of GNU Libtool. +# +# GNU Libtool is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License as +# published by the Free Software Foundation; either version 2 of +# the License, or (at your option) any later version. +# +# As a special exception to the GNU General Public License, +# if you distribute this file as part of a program or library that +# is built using GNU Libtool, you may include this file under the +# same distribution terms that you use for the rest of that program. +# +# GNU Libtool is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Libtool; see the file COPYING. If not, a copy +# can be downloaded from http://www.gnu.org/licenses/gpl.html, or +# obtained by writing to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +]) + +# serial 56 LT_INIT + + +# LT_PREREQ(VERSION) +# ------------------ +# Complain and exit if this libtool version is less that VERSION. +m4_defun([LT_PREREQ], +[m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1, + [m4_default([$3], + [m4_fatal([Libtool version $1 or higher is required], + 63)])], + [$2])]) + + +# _LT_CHECK_BUILDDIR +# ------------------ +# Complain if the absolute build directory name contains unusual characters +m4_defun([_LT_CHECK_BUILDDIR], +[case `pwd` in + *\ * | *\ *) + AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;; +esac +]) + + +# LT_INIT([OPTIONS]) +# ------------------ +AC_DEFUN([LT_INIT], +[AC_PREREQ([2.58])dnl We use AC_INCLUDES_DEFAULT +AC_BEFORE([$0], [LT_LANG])dnl +AC_BEFORE([$0], [LT_OUTPUT])dnl +AC_BEFORE([$0], [LTDL_INIT])dnl +m4_require([_LT_CHECK_BUILDDIR])dnl + +dnl Autoconf doesn't catch unexpanded LT_ macros by default: +m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl +m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl +dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4 +dnl unless we require an AC_DEFUNed macro: +AC_REQUIRE([LTOPTIONS_VERSION])dnl +AC_REQUIRE([LTSUGAR_VERSION])dnl +AC_REQUIRE([LTVERSION_VERSION])dnl +AC_REQUIRE([LTOBSOLETE_VERSION])dnl +m4_require([_LT_PROG_LTMAIN])dnl + +dnl Parse OPTIONS +_LT_SET_OPTIONS([$0], [$1]) + +# This can be used to rebuild libtool when needed +LIBTOOL_DEPS="$ltmain" + +# Always use our own libtool. +LIBTOOL='$(SHELL) $(top_builddir)/libtool' +AC_SUBST(LIBTOOL)dnl + +_LT_SETUP + +# Only expand once: +m4_define([LT_INIT]) +])# LT_INIT + +# Old names: +AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT]) +AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_PROG_LIBTOOL], []) +dnl AC_DEFUN([AM_PROG_LIBTOOL], []) + + +# _LT_CC_BASENAME(CC) +# ------------------- +# Calculate cc_basename. Skip known compiler wrappers and cross-prefix. +m4_defun([_LT_CC_BASENAME], +[for cc_temp in $1""; do + case $cc_temp in + compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; + distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$ECHO "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` +]) + + +# _LT_FILEUTILS_DEFAULTS +# ---------------------- +# It is okay to use these file commands and assume they have been set +# sensibly after `m4_require([_LT_FILEUTILS_DEFAULTS])'. +m4_defun([_LT_FILEUTILS_DEFAULTS], +[: ${CP="cp -f"} +: ${MV="mv -f"} +: ${RM="rm -f"} +])# _LT_FILEUTILS_DEFAULTS + + +# _LT_SETUP +# --------- +m4_defun([_LT_SETUP], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +_LT_DECL([], [host_alias], [0], [The host system])dnl +_LT_DECL([], [host], [0])dnl +_LT_DECL([], [host_os], [0])dnl +dnl +_LT_DECL([], [build_alias], [0], [The build system])dnl +_LT_DECL([], [build], [0])dnl +_LT_DECL([], [build_os], [0])dnl +dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([LT_PATH_LD])dnl +AC_REQUIRE([LT_PATH_NM])dnl +dnl +AC_REQUIRE([AC_PROG_LN_S])dnl +test -z "$LN_S" && LN_S="ln -s" +_LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl +dnl +AC_REQUIRE([LT_CMD_MAX_LEN])dnl +_LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl +_LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl +dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_CHECK_SHELL_FEATURES])dnl +m4_require([_LT_CMD_RELOAD])dnl +m4_require([_LT_CHECK_MAGIC_METHOD])dnl +m4_require([_LT_CMD_OLD_ARCHIVE])dnl +m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl + +_LT_CONFIG_LIBTOOL_INIT([ +# See if we are running on zsh, and set the options which allow our +# commands through without removal of \ escapes INIT. +if test -n "\${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST +fi +]) +if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST +fi + +_LT_CHECK_OBJDIR + +m4_require([_LT_TAG_COMPILER])dnl +_LT_PROG_ECHO_BACKSLASH + +case $host_os in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +sed_quote_subst='s/\([["`$\\]]\)/\\\1/g' + +# Same as above, but do not quote variable references. +double_quote_subst='s/\([["`\\]]\)/\\\1/g' + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# Sed substitution to delay expansion of an escaped single quote. +delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' + +# Sed substitution to avoid accidental globbing in evaled expressions +no_glob_subst='s/\*/\\\*/g' + +# Global variables: +ofile=libtool +can_build_shared=yes + +# All known linkers require a `.a' archive for static linking (except MSVC, +# which needs '.lib'). +libext=a + +with_gnu_ld="$lt_cv_prog_gnu_ld" + +old_CC="$CC" +old_CFLAGS="$CFLAGS" + +# Set sane defaults for various variables +test -z "$CC" && CC=cc +test -z "$LTCC" && LTCC=$CC +test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS +test -z "$LD" && LD=ld +test -z "$ac_objext" && ac_objext=o + +_LT_CC_BASENAME([$compiler]) + +# Only perform the check for file, if the check method requires it +test -z "$MAGIC_CMD" && MAGIC_CMD=file +case $deplibs_check_method in +file_magic*) + if test "$file_magic_cmd" = '$MAGIC_CMD'; then + _LT_PATH_MAGIC + fi + ;; +esac + +# Use C for the default configuration in the libtool script +LT_SUPPORTED_TAG([CC]) +_LT_LANG_C_CONFIG +_LT_LANG_DEFAULT_CONFIG +_LT_CONFIG_COMMANDS +])# _LT_SETUP + + +# _LT_PROG_LTMAIN +# --------------- +# Note that this code is called both from `configure', and `config.status' +# now that we use AC_CONFIG_COMMANDS to generate libtool. Notably, +# `config.status' has no value for ac_aux_dir unless we are using Automake, +# so we pass a copy along to make sure it has a sensible value anyway. +m4_defun([_LT_PROG_LTMAIN], +[m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl +_LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir']) +ltmain="$ac_aux_dir/ltmain.sh" +])# _LT_PROG_LTMAIN + + +## ------------------------------------- ## +## Accumulate code for creating libtool. ## +## ------------------------------------- ## + +# So that we can recreate a full libtool script including additional +# tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS +# in macros and then make a single call at the end using the `libtool' +# label. + + +# _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS]) +# ---------------------------------------- +# Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later. +m4_define([_LT_CONFIG_LIBTOOL_INIT], +[m4_ifval([$1], + [m4_append([_LT_OUTPUT_LIBTOOL_INIT], + [$1 +])])]) + +# Initialize. +m4_define([_LT_OUTPUT_LIBTOOL_INIT]) + + +# _LT_CONFIG_LIBTOOL([COMMANDS]) +# ------------------------------ +# Register COMMANDS to be passed to AC_CONFIG_COMMANDS later. +m4_define([_LT_CONFIG_LIBTOOL], +[m4_ifval([$1], + [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS], + [$1 +])])]) + +# Initialize. +m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS]) + + +# _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS]) +# ----------------------------------------------------- +m4_defun([_LT_CONFIG_SAVE_COMMANDS], +[_LT_CONFIG_LIBTOOL([$1]) +_LT_CONFIG_LIBTOOL_INIT([$2]) +]) + + +# _LT_FORMAT_COMMENT([COMMENT]) +# ----------------------------- +# Add leading comment marks to the start of each line, and a trailing +# full-stop to the whole comment if one is not present already. +m4_define([_LT_FORMAT_COMMENT], +[m4_ifval([$1], [ +m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])], + [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.]) +)]) + + + +## ------------------------ ## +## FIXME: Eliminate VARNAME ## +## ------------------------ ## + + +# _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?]) +# ------------------------------------------------------------------- +# CONFIGNAME is the name given to the value in the libtool script. +# VARNAME is the (base) name used in the configure script. +# VALUE may be 0, 1 or 2 for a computed quote escaped value based on +# VARNAME. Any other value will be used directly. +m4_define([_LT_DECL], +[lt_if_append_uniq([lt_decl_varnames], [$2], [, ], + [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name], + [m4_ifval([$1], [$1], [$2])]) + lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3]) + m4_ifval([$4], + [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])]) + lt_dict_add_subkey([lt_decl_dict], [$2], + [tagged?], [m4_ifval([$5], [yes], [no])])]) +]) + + +# _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION]) +# -------------------------------------------------------- +m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])]) + + +# lt_decl_tag_varnames([SEPARATOR], [VARNAME1...]) +# ------------------------------------------------ +m4_define([lt_decl_tag_varnames], +[_lt_decl_filter([tagged?], [yes], $@)]) + + +# _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..]) +# --------------------------------------------------------- +m4_define([_lt_decl_filter], +[m4_case([$#], + [0], [m4_fatal([$0: too few arguments: $#])], + [1], [m4_fatal([$0: too few arguments: $#: $1])], + [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)], + [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)], + [lt_dict_filter([lt_decl_dict], $@)])[]dnl +]) + + +# lt_decl_quote_varnames([SEPARATOR], [VARNAME1...]) +# -------------------------------------------------- +m4_define([lt_decl_quote_varnames], +[_lt_decl_filter([value], [1], $@)]) + + +# lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...]) +# --------------------------------------------------- +m4_define([lt_decl_dquote_varnames], +[_lt_decl_filter([value], [2], $@)]) + + +# lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...]) +# --------------------------------------------------- +m4_define([lt_decl_varnames_tagged], +[m4_assert([$# <= 2])dnl +_$0(m4_quote(m4_default([$1], [[, ]])), + m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]), + m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))]) +m4_define([_lt_decl_varnames_tagged], +[m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])]) + + +# lt_decl_all_varnames([SEPARATOR], [VARNAME1...]) +# ------------------------------------------------ +m4_define([lt_decl_all_varnames], +[_$0(m4_quote(m4_default([$1], [[, ]])), + m4_if([$2], [], + m4_quote(lt_decl_varnames), + m4_quote(m4_shift($@))))[]dnl +]) +m4_define([_lt_decl_all_varnames], +[lt_join($@, lt_decl_varnames_tagged([$1], + lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl +]) + + +# _LT_CONFIG_STATUS_DECLARE([VARNAME]) +# ------------------------------------ +# Quote a variable value, and forward it to `config.status' so that its +# declaration there will have the same value as in `configure'. VARNAME +# must have a single quote delimited value for this to work. +m4_define([_LT_CONFIG_STATUS_DECLARE], +[$1='`$ECHO "X$][$1" | $Xsed -e "$delay_single_quote_subst"`']) + + +# _LT_CONFIG_STATUS_DECLARATIONS +# ------------------------------ +# We delimit libtool config variables with single quotes, so when +# we write them to config.status, we have to be sure to quote all +# embedded single quotes properly. In configure, this macro expands +# each variable declared with _LT_DECL (and _LT_TAGDECL) into: +# +# ='`$ECHO "X$" | $Xsed -e "$delay_single_quote_subst"`' +m4_defun([_LT_CONFIG_STATUS_DECLARATIONS], +[m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames), + [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])]) + + +# _LT_LIBTOOL_TAGS +# ---------------- +# Output comment and list of tags supported by the script +m4_defun([_LT_LIBTOOL_TAGS], +[_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl +available_tags="_LT_TAGS"dnl +]) + + +# _LT_LIBTOOL_DECLARE(VARNAME, [TAG]) +# ----------------------------------- +# Extract the dictionary values for VARNAME (optionally with TAG) and +# expand to a commented shell variable setting: +# +# # Some comment about what VAR is for. +# visible_name=$lt_internal_name +m4_define([_LT_LIBTOOL_DECLARE], +[_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], + [description])))[]dnl +m4_pushdef([_libtool_name], + m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl +m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])), + [0], [_libtool_name=[$]$1], + [1], [_libtool_name=$lt_[]$1], + [2], [_libtool_name=$lt_[]$1], + [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl +m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl +]) + + +# _LT_LIBTOOL_CONFIG_VARS +# ----------------------- +# Produce commented declarations of non-tagged libtool config variables +# suitable for insertion in the LIBTOOL CONFIG section of the `libtool' +# script. Tagged libtool config variables (even for the LIBTOOL CONFIG +# section) are produced by _LT_LIBTOOL_TAG_VARS. +m4_defun([_LT_LIBTOOL_CONFIG_VARS], +[m4_foreach([_lt_var], + m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)), + [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])]) + + +# _LT_LIBTOOL_TAG_VARS(TAG) +# ------------------------- +m4_define([_LT_LIBTOOL_TAG_VARS], +[m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames), + [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])]) + + +# _LT_TAGVAR(VARNAME, [TAGNAME]) +# ------------------------------ +m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])]) + + +# _LT_CONFIG_COMMANDS +# ------------------- +# Send accumulated output to $CONFIG_STATUS. Thanks to the lists of +# variables for single and double quote escaping we saved from calls +# to _LT_DECL, we can put quote escaped variables declarations +# into `config.status', and then the shell code to quote escape them in +# for loops in `config.status'. Finally, any additional code accumulated +# from calls to _LT_CONFIG_LIBTOOL_INIT is expanded. +m4_defun([_LT_CONFIG_COMMANDS], +[AC_PROVIDE_IFELSE([LT_OUTPUT], + dnl If the libtool generation code has been placed in $CONFIG_LT, + dnl instead of duplicating it all over again into config.status, + dnl then we will have config.status run $CONFIG_LT later, so it + dnl needs to know what name is stored there: + [AC_CONFIG_COMMANDS([libtool], + [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])], + dnl If the libtool generation code is destined for config.status, + dnl expand the accumulated commands and init code now: + [AC_CONFIG_COMMANDS([libtool], + [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])]) +])#_LT_CONFIG_COMMANDS + + +# Initialize. +m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT], +[ + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +sed_quote_subst='$sed_quote_subst' +double_quote_subst='$double_quote_subst' +delay_variable_subst='$delay_variable_subst' +_LT_CONFIG_STATUS_DECLARATIONS +LTCC='$LTCC' +LTCFLAGS='$LTCFLAGS' +compiler='$compiler_DEFAULT' + +# Quote evaled strings. +for var in lt_decl_all_varnames([[ \ +]], lt_decl_quote_varnames); do + case \`eval \\\\\$ECHO "X\\\\\$\$var"\` in + *[[\\\\\\\`\\"\\\$]]*) + eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"X\\\$\$var\\" | \\\$Xsed -e \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" + ;; + *) + eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" + ;; + esac +done + +# Double-quote double-evaled strings. +for var in lt_decl_all_varnames([[ \ +]], lt_decl_dquote_varnames); do + case \`eval \\\\\$ECHO "X\\\\\$\$var"\` in + *[[\\\\\\\`\\"\\\$]]*) + eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"X\\\$\$var\\" | \\\$Xsed -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" + ;; + *) + eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" + ;; + esac +done + +# Fix-up fallback echo if it was mangled by the above quoting rules. +case \$lt_ECHO in +*'\\\[$]0 --fallback-echo"')dnl " + lt_ECHO=\`\$ECHO "X\$lt_ECHO" | \$Xsed -e 's/\\\\\\\\\\\\\\\[$]0 --fallback-echo"\[$]/\[$]0 --fallback-echo"/'\` + ;; +esac + +_LT_OUTPUT_LIBTOOL_INIT +]) + + +# LT_OUTPUT +# --------- +# This macro allows early generation of the libtool script (before +# AC_OUTPUT is called), incase it is used in configure for compilation +# tests. +AC_DEFUN([LT_OUTPUT], +[: ${CONFIG_LT=./config.lt} +AC_MSG_NOTICE([creating $CONFIG_LT]) +cat >"$CONFIG_LT" <<_LTEOF +#! $SHELL +# Generated by $as_me. +# Run this file to recreate a libtool stub with the current configuration. + +lt_cl_silent=false +SHELL=\${CONFIG_SHELL-$SHELL} +_LTEOF + +cat >>"$CONFIG_LT" <<\_LTEOF +AS_SHELL_SANITIZE +_AS_PREPARE + +exec AS_MESSAGE_FD>&1 +exec AS_MESSAGE_LOG_FD>>config.log +{ + echo + AS_BOX([Running $as_me.]) +} >&AS_MESSAGE_LOG_FD + +lt_cl_help="\ +\`$as_me' creates a local libtool stub from the current configuration, +for use in further configure time tests before the real libtool is +generated. + +Usage: $[0] [[OPTIONS]] + + -h, --help print this help, then exit + -V, --version print version number, then exit + -q, --quiet do not print progress messages + -d, --debug don't remove temporary files + +Report bugs to ." + +lt_cl_version="\ +m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl +m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION]) +configured by $[0], generated by m4_PACKAGE_STRING. + +Copyright (C) 2008 Free Software Foundation, Inc. +This config.lt script is free software; the Free Software Foundation +gives unlimited permision to copy, distribute and modify it." + +while test $[#] != 0 +do + case $[1] in + --version | --v* | -V ) + echo "$lt_cl_version"; exit 0 ;; + --help | --h* | -h ) + echo "$lt_cl_help"; exit 0 ;; + --debug | --d* | -d ) + debug=: ;; + --quiet | --q* | --silent | --s* | -q ) + lt_cl_silent=: ;; + + -*) AC_MSG_ERROR([unrecognized option: $[1] +Try \`$[0] --help' for more information.]) ;; + + *) AC_MSG_ERROR([unrecognized argument: $[1] +Try \`$[0] --help' for more information.]) ;; + esac + shift +done + +if $lt_cl_silent; then + exec AS_MESSAGE_FD>/dev/null +fi +_LTEOF + +cat >>"$CONFIG_LT" <<_LTEOF +_LT_OUTPUT_LIBTOOL_COMMANDS_INIT +_LTEOF + +cat >>"$CONFIG_LT" <<\_LTEOF +AC_MSG_NOTICE([creating $ofile]) +_LT_OUTPUT_LIBTOOL_COMMANDS +AS_EXIT(0) +_LTEOF +chmod +x "$CONFIG_LT" + +# configure is writing to config.log, but config.lt does its own redirection, +# appending to config.log, which fails on DOS, as config.log is still kept +# open by configure. Here we exec the FD to /dev/null, effectively closing +# config.log, so it can be properly (re)opened and appended to by config.lt. +if test "$no_create" != yes; then + lt_cl_success=: + test "$silent" = yes && + lt_config_lt_args="$lt_config_lt_args --quiet" + exec AS_MESSAGE_LOG_FD>/dev/null + $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false + exec AS_MESSAGE_LOG_FD>>config.log + $lt_cl_success || AS_EXIT(1) +fi +])# LT_OUTPUT + + +# _LT_CONFIG(TAG) +# --------------- +# If TAG is the built-in tag, create an initial libtool script with a +# default configuration from the untagged config vars. Otherwise add code +# to config.status for appending the configuration named by TAG from the +# matching tagged config vars. +m4_defun([_LT_CONFIG], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +_LT_CONFIG_SAVE_COMMANDS([ + m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl + m4_if(_LT_TAG, [C], [ + # See if we are running on zsh, and set the options which allow our + # commands through without removal of \ escapes. + if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST + fi + + cfgfile="${ofile}T" + trap "$RM \"$cfgfile\"; exit 1" 1 2 15 + $RM "$cfgfile" + + cat <<_LT_EOF >> "$cfgfile" +#! $SHELL + +# `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services. +# Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: +# NOTE: Changes made to this file will be lost: look at ltmain.sh. +# +_LT_COPYING +_LT_LIBTOOL_TAGS + +# ### BEGIN LIBTOOL CONFIG +_LT_LIBTOOL_CONFIG_VARS +_LT_LIBTOOL_TAG_VARS +# ### END LIBTOOL CONFIG + +_LT_EOF + + case $host_os in + aix3*) + cat <<\_LT_EOF >> "$cfgfile" +# AIX sometimes has problems with the GCC collect2 program. For some +# reason, if we set the COLLECT_NAMES environment variable, the problems +# vanish in a puff of smoke. +if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES +fi +_LT_EOF + ;; + esac + + _LT_PROG_LTMAIN + + # We use sed instead of cat because bash on DJGPP gets confused if + # if finds mixed CR/LF and LF-only lines. Since sed operates in + # text mode, it properly converts lines to CR/LF. This bash problem + # is reportedly fixed, but why not run on old versions too? + sed '/^# Generated shell functions inserted here/q' "$ltmain" >> "$cfgfile" \ + || (rm -f "$cfgfile"; exit 1) + + _LT_PROG_XSI_SHELLFNS + + sed -n '/^# Generated shell functions inserted here/,$p' "$ltmain" >> "$cfgfile" \ + || (rm -f "$cfgfile"; exit 1) + + mv -f "$cfgfile" "$ofile" || + (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") + chmod +x "$ofile" +], +[cat <<_LT_EOF >> "$ofile" + +dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded +dnl in a comment (ie after a #). +# ### BEGIN LIBTOOL TAG CONFIG: $1 +_LT_LIBTOOL_TAG_VARS(_LT_TAG) +# ### END LIBTOOL TAG CONFIG: $1 +_LT_EOF +])dnl /m4_if +], +[m4_if([$1], [], [ + PACKAGE='$PACKAGE' + VERSION='$VERSION' + TIMESTAMP='$TIMESTAMP' + RM='$RM' + ofile='$ofile'], []) +])dnl /_LT_CONFIG_SAVE_COMMANDS +])# _LT_CONFIG + + +# LT_SUPPORTED_TAG(TAG) +# --------------------- +# Trace this macro to discover what tags are supported by the libtool +# --tag option, using: +# autoconf --trace 'LT_SUPPORTED_TAG:$1' +AC_DEFUN([LT_SUPPORTED_TAG], []) + + +# C support is built-in for now +m4_define([_LT_LANG_C_enabled], []) +m4_define([_LT_TAGS], []) + + +# LT_LANG(LANG) +# ------------- +# Enable libtool support for the given language if not already enabled. +AC_DEFUN([LT_LANG], +[AC_BEFORE([$0], [LT_OUTPUT])dnl +m4_case([$1], + [C], [_LT_LANG(C)], + [C++], [_LT_LANG(CXX)], + [Java], [_LT_LANG(GCJ)], + [Fortran 77], [_LT_LANG(F77)], + [Fortran], [_LT_LANG(FC)], + [Windows Resource], [_LT_LANG(RC)], + [m4_ifdef([_LT_LANG_]$1[_CONFIG], + [_LT_LANG($1)], + [m4_fatal([$0: unsupported language: "$1"])])])dnl +])# LT_LANG + + +# _LT_LANG(LANGNAME) +# ------------------ +m4_defun([_LT_LANG], +[m4_ifdef([_LT_LANG_]$1[_enabled], [], + [LT_SUPPORTED_TAG([$1])dnl + m4_append([_LT_TAGS], [$1 ])dnl + m4_define([_LT_LANG_]$1[_enabled], [])dnl + _LT_LANG_$1_CONFIG($1)])dnl +])# _LT_LANG + + +# _LT_LANG_DEFAULT_CONFIG +# ----------------------- +m4_defun([_LT_LANG_DEFAULT_CONFIG], +[AC_PROVIDE_IFELSE([AC_PROG_CXX], + [LT_LANG(CXX)], + [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])]) + +AC_PROVIDE_IFELSE([AC_PROG_F77], + [LT_LANG(F77)], + [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])]) + +AC_PROVIDE_IFELSE([AC_PROG_FC], + [LT_LANG(FC)], + [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])]) + +dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal +dnl pulling things in needlessly. +AC_PROVIDE_IFELSE([AC_PROG_GCJ], + [LT_LANG(GCJ)], + [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], + [LT_LANG(GCJ)], + [AC_PROVIDE_IFELSE([LT_PROG_GCJ], + [LT_LANG(GCJ)], + [m4_ifdef([AC_PROG_GCJ], + [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])]) + m4_ifdef([A][M_PROG_GCJ], + [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])]) + m4_ifdef([LT_PROG_GCJ], + [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])]) + +AC_PROVIDE_IFELSE([LT_PROG_RC], + [LT_LANG(RC)], + [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])]) +])# _LT_LANG_DEFAULT_CONFIG + +# Obsolete macros: +AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)]) +AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)]) +AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)]) +AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_CXX], []) +dnl AC_DEFUN([AC_LIBTOOL_F77], []) +dnl AC_DEFUN([AC_LIBTOOL_FC], []) +dnl AC_DEFUN([AC_LIBTOOL_GCJ], []) + + +# _LT_TAG_COMPILER +# ---------------- +m4_defun([_LT_TAG_COMPILER], +[AC_REQUIRE([AC_PROG_CC])dnl + +_LT_DECL([LTCC], [CC], [1], [A C compiler])dnl +_LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl +_LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl +_LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC +])# _LT_TAG_COMPILER + + +# _LT_COMPILER_BOILERPLATE +# ------------------------ +# Check for compiler boilerplate output or warnings with +# the simple compiler test code. +m4_defun([_LT_COMPILER_BOILERPLATE], +[m4_require([_LT_DECL_SED])dnl +ac_outfile=conftest.$ac_objext +echo "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$RM conftest* +])# _LT_COMPILER_BOILERPLATE + + +# _LT_LINKER_BOILERPLATE +# ---------------------- +# Check for linker boilerplate output or warnings with +# the simple link test code. +m4_defun([_LT_LINKER_BOILERPLATE], +[m4_require([_LT_DECL_SED])dnl +ac_outfile=conftest.$ac_objext +echo "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$RM -r conftest* +])# _LT_LINKER_BOILERPLATE + +# _LT_REQUIRED_DARWIN_CHECKS +# ------------------------- +m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[ + case $host_os in + rhapsody* | darwin*) + AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:]) + AC_CHECK_TOOL([NMEDIT], [nmedit], [:]) + AC_CHECK_TOOL([LIPO], [lipo], [:]) + AC_CHECK_TOOL([OTOOL], [otool], [:]) + AC_CHECK_TOOL([OTOOL64], [otool64], [:]) + _LT_DECL([], [DSYMUTIL], [1], + [Tool to manipulate archived DWARF debug symbol files on Mac OS X]) + _LT_DECL([], [NMEDIT], [1], + [Tool to change global to local symbols on Mac OS X]) + _LT_DECL([], [LIPO], [1], + [Tool to manipulate fat objects and archives on Mac OS X]) + _LT_DECL([], [OTOOL], [1], + [ldd/readelf like tool for Mach-O binaries on Mac OS X]) + _LT_DECL([], [OTOOL64], [1], + [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4]) + + AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod], + [lt_cv_apple_cc_single_mod=no + if test -z "${LT_MULTI_MODULE}"; then + # By default we will add the -single_module flag. You can override + # by either setting the environment variable LT_MULTI_MODULE + # non-empty at configure time, or by adding -multi_module to the + # link flags. + rm -rf libconftest.dylib* + echo "int foo(void){return 1;}" > conftest.c + echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ +-dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD + $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ + -dynamiclib -Wl,-single_module conftest.c 2>conftest.err + _lt_result=$? + if test -f libconftest.dylib && test ! -s conftest.err && test $_lt_result = 0; then + lt_cv_apple_cc_single_mod=yes + else + cat conftest.err >&AS_MESSAGE_LOG_FD + fi + rm -rf libconftest.dylib* + rm -f conftest.* + fi]) + AC_CACHE_CHECK([for -exported_symbols_list linker flag], + [lt_cv_ld_exported_symbols_list], + [lt_cv_ld_exported_symbols_list=no + save_LDFLAGS=$LDFLAGS + echo "_main" > conftest.sym + LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" + AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], + [lt_cv_ld_exported_symbols_list=yes], + [lt_cv_ld_exported_symbols_list=no]) + LDFLAGS="$save_LDFLAGS" + ]) + case $host_os in + rhapsody* | darwin1.[[012]]) + _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;; + darwin1.*) + _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; + darwin*) # darwin 5.x on + # if running on 10.5 or later, the deployment target defaults + # to the OS version, if on x86, and 10.4, the deployment + # target defaults to 10.4. Don't you love it? + case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in + 10.0,*86*-darwin8*|10.0,*-darwin[[91]]*) + _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; + 10.[[012]]*) + _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; + 10.*) + _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; + esac + ;; + esac + if test "$lt_cv_apple_cc_single_mod" = "yes"; then + _lt_dar_single_mod='$single_module' + fi + if test "$lt_cv_ld_exported_symbols_list" = "yes"; then + _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym' + else + _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}' + fi + if test "$DSYMUTIL" != ":"; then + _lt_dsymutil='~$DSYMUTIL $lib || :' + else + _lt_dsymutil= + fi + ;; + esac +]) + + +# _LT_DARWIN_LINKER_FEATURES +# -------------------------- +# Checks for linker and compiler features on darwin +m4_defun([_LT_DARWIN_LINKER_FEATURES], +[ + m4_require([_LT_REQUIRED_DARWIN_CHECKS]) + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_automatic, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_TAGVAR(whole_archive_flag_spec, $1)='' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)="$_lt_dar_allow_undefined" + case $cc_basename in + ifort*) _lt_dar_can_shared=yes ;; + *) _lt_dar_can_shared=$GCC ;; + esac + if test "$_lt_dar_can_shared" = "yes"; then + output_verbose_link_cmd=echo + _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" + _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" + _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" + _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" + m4_if([$1], [CXX], +[ if test "$lt_cv_apple_cc_single_mod" != "yes"; then + _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}" + _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}" + fi +],[]) + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi +]) + +# _LT_SYS_MODULE_PATH_AIX +# ----------------------- +# Links a minimal program and checks the executable +# for the system default hardcoded library path. In most cases, +# this is /usr/lib:/lib, but when the MPI compilers are used +# the location of the communication and MPI libs are included too. +# If we don't find anything, use the default library path according +# to the aix ld manual. +m4_defun([_LT_SYS_MODULE_PATH_AIX], +[m4_require([_LT_DECL_SED])dnl +AC_LINK_IFELSE(AC_LANG_PROGRAM,[ +lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\(.*\)$/\1/ + p + } + }' +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then + aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +fi],[]) +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi +])# _LT_SYS_MODULE_PATH_AIX + + +# _LT_SHELL_INIT(ARG) +# ------------------- +m4_define([_LT_SHELL_INIT], +[ifdef([AC_DIVERSION_NOTICE], + [AC_DIVERT_PUSH(AC_DIVERSION_NOTICE)], + [AC_DIVERT_PUSH(NOTICE)]) +$1 +AC_DIVERT_POP +])# _LT_SHELL_INIT + + +# _LT_PROG_ECHO_BACKSLASH +# ----------------------- +# Add some code to the start of the generated configure script which +# will find an echo command which doesn't interpret backslashes. +m4_defun([_LT_PROG_ECHO_BACKSLASH], +[_LT_SHELL_INIT([ +# Check that we are running under the correct shell. +SHELL=${CONFIG_SHELL-/bin/sh} + +case X$lt_ECHO in +X*--fallback-echo) + # Remove one level of quotation (which was required for Make). + ECHO=`echo "$lt_ECHO" | sed 's,\\\\\[$]\\[$]0,'[$]0','` + ;; +esac + +ECHO=${lt_ECHO-echo} +if test "X[$]1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X[$]1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' ; then + # Yippee, $ECHO works! + : +else + # Restart under the correct shell. + exec $SHELL "[$]0" --no-reexec ${1+"[$]@"} +fi + +if test "X[$]1" = X--fallback-echo; then + # used as fallback echo + shift + cat <<_LT_EOF +[$]* +_LT_EOF + exit 0 +fi + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +if test -z "$lt_ECHO"; then + if test "X${echo_test_string+set}" != Xset; then + # find a string as large as possible, as long as the shell can cope with it + for cmd in 'sed 50q "[$]0"' 'sed 20q "[$]0"' 'sed 10q "[$]0"' 'sed 2q "[$]0"' 'echo test'; do + # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ... + if { echo_test_string=`eval $cmd`; } 2>/dev/null && + { test "X$echo_test_string" = "X$echo_test_string"; } 2>/dev/null + then + break + fi + done + fi + + if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' && + echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + : + else + # The Solaris, AIX, and Digital Unix default echo programs unquote + # backslashes. This makes it impossible to quote backslashes using + # echo "$something" | sed 's/\\/\\\\/g' + # + # So, first we look for a working echo in the user's PATH. + + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for dir in $PATH /usr/ucb; do + IFS="$lt_save_ifs" + if (test -f $dir/echo || test -f $dir/echo$ac_exeext) && + test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + ECHO="$dir/echo" + break + fi + done + IFS="$lt_save_ifs" + + if test "X$ECHO" = Xecho; then + # We didn't find a better echo, so look for alternatives. + if test "X`{ print -r '\t'; } 2>/dev/null`" = 'X\t' && + echo_testing_string=`{ print -r "$echo_test_string"; } 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # This shell has a builtin print -r that does the trick. + ECHO='print -r' + elif { test -f /bin/ksh || test -f /bin/ksh$ac_exeext; } && + test "X$CONFIG_SHELL" != X/bin/ksh; then + # If we have ksh, try running configure again with it. + ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh} + export ORIGINAL_CONFIG_SHELL + CONFIG_SHELL=/bin/ksh + export CONFIG_SHELL + exec $CONFIG_SHELL "[$]0" --no-reexec ${1+"[$]@"} + else + # Try using printf. + ECHO='printf %s\n' + if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' && + echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # Cool, printf works + : + elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL + export CONFIG_SHELL + SHELL="$CONFIG_SHELL" + export SHELL + ECHO="$CONFIG_SHELL [$]0 --fallback-echo" + elif echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + ECHO="$CONFIG_SHELL [$]0 --fallback-echo" + else + # maybe with a smaller string... + prev=: + + for cmd in 'echo test' 'sed 2q "[$]0"' 'sed 10q "[$]0"' 'sed 20q "[$]0"' 'sed 50q "[$]0"'; do + if { test "X$echo_test_string" = "X`eval $cmd`"; } 2>/dev/null + then + break + fi + prev="$cmd" + done + + if test "$prev" != 'sed 50q "[$]0"'; then + echo_test_string=`eval $prev` + export echo_test_string + exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "[$]0" ${1+"[$]@"} + else + # Oops. We lost completely, so just stick with echo. + ECHO=echo + fi + fi + fi + fi + fi +fi + +# Copy echo and quote the copy suitably for passing to libtool from +# the Makefile, instead of quoting the original, which is used later. +lt_ECHO=$ECHO +if test "X$lt_ECHO" = "X$CONFIG_SHELL [$]0 --fallback-echo"; then + lt_ECHO="$CONFIG_SHELL \\\$\[$]0 --fallback-echo" +fi + +AC_SUBST(lt_ECHO) +]) +_LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts]) +_LT_DECL([], [ECHO], [1], + [An echo program that does not interpret backslashes]) +])# _LT_PROG_ECHO_BACKSLASH + + +# _LT_ENABLE_LOCK +# --------------- +m4_defun([_LT_ENABLE_LOCK], +[AC_ARG_ENABLE([libtool-lock], + [AS_HELP_STRING([--disable-libtool-lock], + [avoid locking (might break parallel builds)])]) +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + +# Some flags need to be propagated to the compiler or linker for good +# libtool support. +case $host in +ia64-*-hpux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.$ac_objext` in + *ELF-32*) + HPUX_IA64_MODE="32" + ;; + *ELF-64*) + HPUX_IA64_MODE="64" + ;; + esac + fi + rm -rf conftest* + ;; +*-*-irix6*) + # Find out which ABI we are using. + echo '[#]line __oline__ "configure"' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + if test "$lt_cv_prog_gnu_ld" = yes; then + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -melf32bsmip" + ;; + *N32*) + LD="${LD-ld} -melf32bmipn32" + ;; + *64-bit*) + LD="${LD-ld} -melf64bmip" + ;; + esac + else + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -32" + ;; + *N32*) + LD="${LD-ld} -n32" + ;; + *64-bit*) + LD="${LD-ld} -64" + ;; + esac + fi + fi + rm -rf conftest* + ;; + +x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \ +s390*-*linux*|s390*-*tpf*|sparc*-*linux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.o` in + *32-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_i386_fbsd" + ;; + x86_64-*linux*) + LD="${LD-ld} -m elf_i386" + ;; + ppc64-*linux*|powerpc64-*linux*) + LD="${LD-ld} -m elf32ppclinux" + ;; + s390x-*linux*) + LD="${LD-ld} -m elf_s390" + ;; + sparc64-*linux*) + LD="${LD-ld} -m elf32_sparc" + ;; + esac + ;; + *64-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_x86_64_fbsd" + ;; + x86_64-*linux*) + LD="${LD-ld} -m elf_x86_64" + ;; + ppc*-*linux*|powerpc*-*linux*) + LD="${LD-ld} -m elf64ppc" + ;; + s390*-*linux*|s390*-*tpf*) + LD="${LD-ld} -m elf64_s390" + ;; + sparc*-*linux*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; + +*-*-sco3.2v5*) + # On SCO OpenServer 5, we need -belf to get full-featured binaries. + SAVE_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -belf" + AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, + [AC_LANG_PUSH(C) + AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) + AC_LANG_POP]) + if test x"$lt_cv_cc_needs_belf" != x"yes"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS="$SAVE_CFLAGS" + fi + ;; +sparc*-*solaris*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.o` in + *64-bit*) + case $lt_cv_prog_gnu_ld in + yes*) LD="${LD-ld} -m elf64_sparc" ;; + *) + if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then + LD="${LD-ld} -64" + fi + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; +esac + +need_locks="$enable_libtool_lock" +])# _LT_ENABLE_LOCK + + +# _LT_CMD_OLD_ARCHIVE +# ------------------- +m4_defun([_LT_CMD_OLD_ARCHIVE], +[AC_CHECK_TOOL(AR, ar, false) +test -z "$AR" && AR=ar +test -z "$AR_FLAGS" && AR_FLAGS=cru +_LT_DECL([], [AR], [1], [The archiver]) +_LT_DECL([], [AR_FLAGS], [1]) + +AC_CHECK_TOOL(STRIP, strip, :) +test -z "$STRIP" && STRIP=: +_LT_DECL([], [STRIP], [1], [A symbol stripping program]) + +AC_CHECK_TOOL(RANLIB, ranlib, :) +test -z "$RANLIB" && RANLIB=: +_LT_DECL([], [RANLIB], [1], + [Commands used to install an old-style archive]) + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +if test -n "$RANLIB"; then + case $host_os in + openbsd*) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$oldlib" + ;; + *) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$oldlib" + ;; + esac + old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib" +fi +_LT_DECL([], [old_postinstall_cmds], [2]) +_LT_DECL([], [old_postuninstall_cmds], [2]) +_LT_TAGDECL([], [old_archive_cmds], [2], + [Commands used to build an old-style archive]) +])# _LT_CMD_OLD_ARCHIVE + + +# _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) +# ---------------------------------------------------------------- +# Check whether the given compiler option works +AC_DEFUN([_LT_COMPILER_OPTION], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_SED])dnl +AC_CACHE_CHECK([$1], [$2], + [$2=no + m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$3" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + $2=yes + fi + fi + $RM conftest* +]) + +if test x"[$]$2" = xyes; then + m4_if([$5], , :, [$5]) +else + m4_if([$6], , :, [$6]) +fi +])# _LT_COMPILER_OPTION + +# Old name: +AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], []) + + +# _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [ACTION-SUCCESS], [ACTION-FAILURE]) +# ---------------------------------------------------- +# Check whether the given linker option works +AC_DEFUN([_LT_LINKER_OPTION], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_SED])dnl +AC_CACHE_CHECK([$1], [$2], + [$2=no + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS $3" + echo "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&AS_MESSAGE_LOG_FD + $ECHO "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + $2=yes + fi + else + $2=yes + fi + fi + $RM -r conftest* + LDFLAGS="$save_LDFLAGS" +]) + +if test x"[$]$2" = xyes; then + m4_if([$4], , :, [$4]) +else + m4_if([$5], , :, [$5]) +fi +])# _LT_LINKER_OPTION + +# Old name: +AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], []) + + +# LT_CMD_MAX_LEN +#--------------- +AC_DEFUN([LT_CMD_MAX_LEN], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +# find the maximum length of command line arguments +AC_MSG_CHECKING([the maximum length of command line arguments]) +AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl + i=0 + teststring="ABCD" + + case $build_os in + msdosdjgpp*) + # On DJGPP, this test can blow up pretty badly due to problems in libc + # (any single argument exceeding 2000 bytes causes a buffer overrun + # during glob expansion). Even if it were fixed, the result of this + # check would be larger than it should be. + lt_cv_sys_max_cmd_len=12288; # 12K is about right + ;; + + gnu*) + # Under GNU Hurd, this test is not required because there is + # no limit to the length of command line arguments. + # Libtool will interpret -1 as no limit whatsoever + lt_cv_sys_max_cmd_len=-1; + ;; + + cygwin* | mingw* | cegcc*) + # On Win9x/ME, this test blows up -- it succeeds, but takes + # about 5 minutes as the teststring grows exponentially. + # Worse, since 9x/ME are not pre-emptively multitasking, + # you end up with a "frozen" computer, even though with patience + # the test eventually succeeds (with a max line length of 256k). + # Instead, let's just punt: use the minimum linelength reported by + # all of the supported platforms: 8192 (on NT/2K/XP). + lt_cv_sys_max_cmd_len=8192; + ;; + + beos*) + # On BeOS, this test takes a really really long time. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + amigaos*) + # On AmigaOS with pdksh, this test takes hours, literally. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) + # This has been around since 386BSD, at least. Likely further. + if test -x /sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` + elif test -x /usr/sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` + else + lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs + fi + # And add a safety zone + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + ;; + + interix*) + # We know the value 262144 and hardcode it with a safety zone (like BSD) + lt_cv_sys_max_cmd_len=196608 + ;; + + osf*) + # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure + # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not + # nice to cause kernel panics so lets avoid the loop below. + # First set a reasonable default. + lt_cv_sys_max_cmd_len=16384 + # + if test -x /sbin/sysconfig; then + case `/sbin/sysconfig -q proc exec_disable_arg_limit` in + *1*) lt_cv_sys_max_cmd_len=-1 ;; + esac + fi + ;; + sco3.2v5*) + lt_cv_sys_max_cmd_len=102400 + ;; + sysv5* | sco5v6* | sysv4.2uw2*) + kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` + if test -n "$kargmax"; then + lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[[ ]]//'` + else + lt_cv_sys_max_cmd_len=32768 + fi + ;; + *) + lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` + if test -n "$lt_cv_sys_max_cmd_len"; then + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + else + # Make teststring a little bigger before we do anything with it. + # a 1K string should be a reasonable start. + for i in 1 2 3 4 5 6 7 8 ; do + teststring=$teststring$teststring + done + SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} + # If test is not a shell built-in, we'll probably end up computing a + # maximum length that is only half of the actual maximum length, but + # we can't tell. + while { test "X"`$SHELL [$]0 --fallback-echo "X$teststring$teststring" 2>/dev/null` \ + = "XX$teststring$teststring"; } >/dev/null 2>&1 && + test $i != 17 # 1/2 MB should be enough + do + i=`expr $i + 1` + teststring=$teststring$teststring + done + # Only check the string length outside the loop. + lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` + teststring= + # Add a significant safety factor because C++ compilers can tack on + # massive amounts of additional arguments before passing them to the + # linker. It appears as though 1/2 is a usable value. + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` + fi + ;; + esac +]) +if test -n $lt_cv_sys_max_cmd_len ; then + AC_MSG_RESULT($lt_cv_sys_max_cmd_len) +else + AC_MSG_RESULT(none) +fi +max_cmd_len=$lt_cv_sys_max_cmd_len +_LT_DECL([], [max_cmd_len], [0], + [What is the maximum length of a command?]) +])# LT_CMD_MAX_LEN + +# Old name: +AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], []) + + +# _LT_HEADER_DLFCN +# ---------------- +m4_defun([_LT_HEADER_DLFCN], +[AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl +])# _LT_HEADER_DLFCN + + +# _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, +# ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) +# ---------------------------------------------------------------- +m4_defun([_LT_TRY_DLOPEN_SELF], +[m4_require([_LT_HEADER_DLFCN])dnl +if test "$cross_compiling" = yes; then : + [$4] +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +[#line __oline__ "configure" +#include "confdefs.h" + +#if HAVE_DLFCN_H +#include +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + else + puts (dlerror ()); + + return status; +}] +_LT_EOF + if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) $1 ;; + x$lt_dlneed_uscore) $2 ;; + x$lt_dlunknown|x*) $3 ;; + esac + else : + # compilation failed + $3 + fi +fi +rm -fr conftest* +])# _LT_TRY_DLOPEN_SELF + + +# LT_SYS_DLOPEN_SELF +# ------------------ +AC_DEFUN([LT_SYS_DLOPEN_SELF], +[m4_require([_LT_HEADER_DLFCN])dnl +if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32* | cegcc*) + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen="dlopen" + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],[ + lt_cv_dlopen="dyld" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ]) + ;; + + *) + AC_CHECK_FUNC([shl_load], + [lt_cv_dlopen="shl_load"], + [AC_CHECK_LIB([dld], [shl_load], + [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"], + [AC_CHECK_FUNC([dlopen], + [lt_cv_dlopen="dlopen"], + [AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"], + [AC_CHECK_LIB([svld], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"], + [AC_CHECK_LIB([dld], [dld_link], + [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"]) + ]) + ]) + ]) + ]) + ]) + ;; + esac + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + else + enable_dlopen=no + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS="$CPPFLAGS" + test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS="$LDFLAGS" + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS="$LIBS" + LIBS="$lt_cv_dlopen_libs $LIBS" + + AC_CACHE_CHECK([whether a program can dlopen itself], + lt_cv_dlopen_self, [dnl + _LT_TRY_DLOPEN_SELF( + lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, + lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) + ]) + + if test "x$lt_cv_dlopen_self" = xyes; then + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" + AC_CACHE_CHECK([whether a statically linked program can dlopen itself], + lt_cv_dlopen_self_static, [dnl + _LT_TRY_DLOPEN_SELF( + lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, + lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) + ]) + fi + + CPPFLAGS="$save_CPPFLAGS" + LDFLAGS="$save_LDFLAGS" + LIBS="$save_LIBS" + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi +_LT_DECL([dlopen_support], [enable_dlopen], [0], + [Whether dlopen is supported]) +_LT_DECL([dlopen_self], [enable_dlopen_self], [0], + [Whether dlopen of programs is supported]) +_LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0], + [Whether dlopen of statically linked programs is supported]) +])# LT_SYS_DLOPEN_SELF + +# Old name: +AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], []) + + +# _LT_COMPILER_C_O([TAGNAME]) +# --------------------------- +# Check to see if options -c and -o are simultaneously supported by compiler. +# This macro does not hard code the compiler like AC_PROG_CC_C_O. +m4_defun([_LT_COMPILER_C_O], +[m4_require([_LT_DECL_SED])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_TAG_COMPILER])dnl +AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], + [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)], + [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes + fi + fi + chmod u+w . 2>&AS_MESSAGE_LOG_FD + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* +]) +_LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1], + [Does compiler simultaneously support -c and -o options?]) +])# _LT_COMPILER_C_O + + +# _LT_COMPILER_FILE_LOCKS([TAGNAME]) +# ---------------------------------- +# Check to see if we can do hard links to lock some files if needed +m4_defun([_LT_COMPILER_FILE_LOCKS], +[m4_require([_LT_ENABLE_LOCK])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +_LT_COMPILER_C_O([$1]) + +hard_links="nottested" +if test "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + AC_MSG_CHECKING([if we can lock with hard links]) + hard_links=yes + $RM conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + AC_MSG_RESULT([$hard_links]) + if test "$hard_links" = no; then + AC_MSG_WARN([`$CC' does not support `-c -o', so `make -j' may be unsafe]) + need_locks=warn + fi +else + need_locks=no +fi +_LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?]) +])# _LT_COMPILER_FILE_LOCKS + + +# _LT_CHECK_OBJDIR +# ---------------- +m4_defun([_LT_CHECK_OBJDIR], +[AC_CACHE_CHECK([for objdir], [lt_cv_objdir], +[rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + lt_cv_objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + lt_cv_objdir=_libs +fi +rmdir .libs 2>/dev/null]) +objdir=$lt_cv_objdir +_LT_DECL([], [objdir], [0], + [The name of the directory that contains temporary libtool files])dnl +m4_pattern_allow([LT_OBJDIR])dnl +AC_DEFINE_UNQUOTED(LT_OBJDIR, "$lt_cv_objdir/", + [Define to the sub-directory in which libtool stores uninstalled libraries.]) +])# _LT_CHECK_OBJDIR + + +# _LT_LINKER_HARDCODE_LIBPATH([TAGNAME]) +# -------------------------------------- +# Check hardcoding attributes. +m4_defun([_LT_LINKER_HARDCODE_LIBPATH], +[AC_MSG_CHECKING([how to hardcode library paths into programs]) +_LT_TAGVAR(hardcode_action, $1)= +if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" || + test -n "$_LT_TAGVAR(runpath_var, $1)" || + test "X$_LT_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then + + # We can hardcode non-existent directories. + if test "$_LT_TAGVAR(hardcode_direct, $1)" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" != no && + test "$_LT_TAGVAR(hardcode_minus_L, $1)" != no; then + # Linking always hardcodes the temporary library directory. + _LT_TAGVAR(hardcode_action, $1)=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + _LT_TAGVAR(hardcode_action, $1)=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + _LT_TAGVAR(hardcode_action, $1)=unsupported +fi +AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)]) + +if test "$_LT_TAGVAR(hardcode_action, $1)" = relink || + test "$_LT_TAGVAR(inherit_rpath, $1)" = yes; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi +_LT_TAGDECL([], [hardcode_action], [0], + [How to hardcode a shared library path into an executable]) +])# _LT_LINKER_HARDCODE_LIBPATH + + +# _LT_CMD_STRIPLIB +# ---------------- +m4_defun([_LT_CMD_STRIPLIB], +[m4_require([_LT_DECL_EGREP]) +striplib= +old_striplib= +AC_MSG_CHECKING([whether stripping libraries is possible]) +if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + AC_MSG_RESULT([yes]) +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + old_striplib="$STRIP -S" + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + fi + ;; + *) + AC_MSG_RESULT([no]) + ;; + esac +fi +_LT_DECL([], [old_striplib], [1], [Commands to strip libraries]) +_LT_DECL([], [striplib], [1]) +])# _LT_CMD_STRIPLIB + + +# _LT_SYS_DYNAMIC_LINKER([TAG]) +# ----------------------------- +# PORTME Fill in your ld.so characteristics +m4_defun([_LT_SYS_DYNAMIC_LINKER], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_OBJDUMP])dnl +m4_require([_LT_DECL_SED])dnl +AC_MSG_CHECKING([dynamic linker characteristics]) +m4_if([$1], + [], [ +if test "$GCC" = yes; then + case $host_os in + darwin*) lt_awk_arg="/^libraries:/,/LR/" ;; + *) lt_awk_arg="/^libraries:/" ;; + esac + lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if $ECHO "$lt_search_path_spec" | $GREP ';' >/dev/null ; then + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED -e 's/;/ /g'` + else + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + # Ok, now we have the path, separated by spaces, we can step through it + # and add multilib dir if necessary. + lt_tmp_lt_search_path_spec= + lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` + for lt_sys_path in $lt_search_path_spec; do + if test -d "$lt_sys_path/$lt_multi_os_dir"; then + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir" + else + test -d "$lt_sys_path" && \ + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" + fi + done + lt_search_path_spec=`$ECHO $lt_tmp_lt_search_path_spec | awk ' +BEGIN {RS=" "; FS="/|\n";} { + lt_foo=""; + lt_count=0; + for (lt_i = NF; lt_i > 0; lt_i--) { + if ($lt_i != "" && $lt_i != ".") { + if ($lt_i == "..") { + lt_count++; + } else { + if (lt_count == 0) { + lt_foo="/" $lt_i lt_foo; + } else { + lt_count--; + } + } + } + } + if (lt_foo != "") { lt_freq[[lt_foo]]++; } + if (lt_freq[[lt_foo]] == 1) { print lt_foo; } +}'` + sys_lib_search_path_spec=`$ECHO $lt_search_path_spec` +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi]) +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix[[4-9]]*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[[01]] | aix4.[[01]].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + case $host_cpu in + powerpc) + # Since July 2007 AmigaOS4 officially supports .so libraries. + # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + ;; + m68k) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$ECHO "X$lib" | $Xsed -e '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + esac + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[[45]]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32* | cegcc*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32* | yes,cegcc*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + #soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + soname_spec='`echo ${libname} | sed -e 's/^lib//'`${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw* | cegcc*) + # MinGW DLLs use traditional 'lib' prefix + #soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + soname_spec='`echo ${libname} | $SED -e 's/^lib//'`${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | $GREP "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' +m4_if([$1], [],[ + sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"]) + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[[123]]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[[01]]* | freebsdelf3.[[01]]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \ + freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1) + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + *) # from 4.6 on, and DragonFly + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +interix[[3-9]]*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux* | k*bsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # Some binutils ld are patched to set DT_RUNPATH + save_LDFLAGS=$LDFLAGS + save_libdir=$libdir + eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \ + LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\"" + AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], + [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null], + [shlibpath_overrides_runpath=yes])]) + LDFLAGS=$save_LDFLAGS + libdir=$save_libdir + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +*nto* | *qnx*) + version_type=qnx + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='ldqnx.so' + ;; + +openbsd*) + version_type=sunos + sys_lib_dlsearch_path_spec="/usr/lib" + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[[89]] | openbsd2.[[89]].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +rdos*) + dynamic_linker=no + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + version_type=freebsd-elf + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + if test "$with_gnu_ld" = yes; then + sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' + else + sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' + case $host_os in + sco3.2v5*) + sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" + ;; + esac + fi + sys_lib_dlsearch_path_spec='/usr/lib' + ;; + +tpf*) + # TPF is a cross-target only. Preferred cross-host = GNU/Linux. + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +AC_MSG_RESULT([$dynamic_linker]) +test "$dynamic_linker" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then + sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" +fi +if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then + sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" +fi + +_LT_DECL([], [variables_saved_for_relink], [1], + [Variables whose values should be saved in libtool wrapper scripts and + restored at link time]) +_LT_DECL([], [need_lib_prefix], [0], + [Do we need the "lib" prefix for modules?]) +_LT_DECL([], [need_version], [0], [Do we need a version for libraries?]) +_LT_DECL([], [version_type], [0], [Library versioning type]) +_LT_DECL([], [runpath_var], [0], [Shared library runtime path variable]) +_LT_DECL([], [shlibpath_var], [0],[Shared library path variable]) +_LT_DECL([], [shlibpath_overrides_runpath], [0], + [Is shlibpath searched before the hard-coded library search path?]) +_LT_DECL([], [libname_spec], [1], [Format of library name prefix]) +_LT_DECL([], [library_names_spec], [1], + [[List of archive names. First name is the real one, the rest are links. + The last name is the one that the linker finds with -lNAME]]) +_LT_DECL([], [soname_spec], [1], + [[The coded name of the library, if different from the real name]]) +_LT_DECL([], [postinstall_cmds], [2], + [Command to use after installation of a shared archive]) +_LT_DECL([], [postuninstall_cmds], [2], + [Command to use after uninstallation of a shared archive]) +_LT_DECL([], [finish_cmds], [2], + [Commands used to finish a libtool library installation in a directory]) +_LT_DECL([], [finish_eval], [1], + [[As "finish_cmds", except a single script fragment to be evaled but + not shown]]) +_LT_DECL([], [hardcode_into_libs], [0], + [Whether we should hardcode library paths into libraries]) +_LT_DECL([], [sys_lib_search_path_spec], [2], + [Compile-time system search path for libraries]) +_LT_DECL([], [sys_lib_dlsearch_path_spec], [2], + [Run-time system search path for libraries]) +])# _LT_SYS_DYNAMIC_LINKER + + +# _LT_PATH_TOOL_PREFIX(TOOL) +# -------------------------- +# find a file program which can recognize shared library +AC_DEFUN([_LT_PATH_TOOL_PREFIX], +[m4_require([_LT_DECL_EGREP])dnl +AC_MSG_CHECKING([for $1]) +AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, +[case $MAGIC_CMD in +[[\\/*] | ?:[\\/]*]) + lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD="$MAGIC_CMD" + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR +dnl $ac_dummy forces splitting on constant user-supplied paths. +dnl POSIX.2 word splitting is done only on the output of word expansions, +dnl not every word. This closes a longstanding sh security hole. + ac_dummy="m4_if([$2], , $PATH, [$2])" + for ac_dir in $ac_dummy; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/$1; then + lt_cv_path_MAGIC_CMD="$ac_dir/$1" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD="$lt_cv_path_MAGIC_CMD" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <<_LT_EOF 1>&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +_LT_EOF + fi ;; + esac + fi + break + fi + done + IFS="$lt_save_ifs" + MAGIC_CMD="$lt_save_MAGIC_CMD" + ;; +esac]) +MAGIC_CMD="$lt_cv_path_MAGIC_CMD" +if test -n "$MAGIC_CMD"; then + AC_MSG_RESULT($MAGIC_CMD) +else + AC_MSG_RESULT(no) +fi +_LT_DECL([], [MAGIC_CMD], [0], + [Used to examine libraries when file_magic_cmd begins with "file"])dnl +])# _LT_PATH_TOOL_PREFIX + +# Old name: +AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], []) + + +# _LT_PATH_MAGIC +# -------------- +# find a file program which can recognize a shared library +m4_defun([_LT_PATH_MAGIC], +[_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) +if test -z "$lt_cv_path_MAGIC_CMD"; then + if test -n "$ac_tool_prefix"; then + _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) + else + MAGIC_CMD=: + fi +fi +])# _LT_PATH_MAGIC + + +# LT_PATH_LD +# ---------- +# find the pathname to the GNU or non-GNU linker +AC_DEFUN([LT_PATH_LD], +[AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +m4_require([_LT_DECL_SED])dnl +m4_require([_LT_DECL_EGREP])dnl + +AC_ARG_WITH([gnu-ld], + [AS_HELP_STRING([--with-gnu-ld], + [assume the C compiler uses GNU ld @<:@default=no@:>@])], + [test "$withval" = no || with_gnu_ld=yes], + [with_gnu_ld=no])dnl + +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + AC_MSG_CHECKING([for ld used by $CC]) + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [[\\/]]* | ?:[[\\/]]*) + re_direlt='/[[^/]][[^/]]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` + while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do + ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + AC_MSG_CHECKING([for GNU ld]) +else + AC_MSG_CHECKING([for non-GNU ld]) +fi +AC_CACHE_VAL(lt_cv_path_LD, +[if test -z "$LD"; then + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &1 /dev/null 2>&1; then + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_file_magic_cmd='func_win32_libid' + else + lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?' + lt_cv_file_magic_cmd='$OBJDUMP -f' + fi + lt_cv_deplibs_check_method=pass_all + ;; + +cegcc) + # use the weaker test based on 'objdump'. See mingw*. + lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' + lt_cv_file_magic_cmd='$OBJDUMP -f' + ;; + +darwin* | rhapsody*) + lt_cv_deplibs_check_method=pass_all + ;; + +freebsd* | dragonfly*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + case $host_cpu in + i*86 ) + # Not sure whether the presence of OpenBSD here was a mistake. + # Let's accept both of them until this is cleared up. + lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + ;; + esac + else + lt_cv_deplibs_check_method=pass_all + fi + ;; + +gnu*) + lt_cv_deplibs_check_method=pass_all + ;; + +hpux10.20* | hpux11*) + lt_cv_file_magic_cmd=/usr/bin/file + case $host_cpu in + ia64*) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' + lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so + ;; + hppa*64*) + [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]'] + lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl + ;; + *) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]].[[0-9]]) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +interix[[3-9]]*) + # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$' + ;; + +irix5* | irix6* | nonstopux*) + case $LD in + *-32|*"-32 ") libmagic=32-bit;; + *-n32|*"-n32 ") libmagic=N32;; + *-64|*"-64 ") libmagic=64-bit;; + *) libmagic=never-match;; + esac + lt_cv_deplibs_check_method=pass_all + ;; + +# This must be Linux ELF. +linux* | k*bsd*-gnu) + lt_cv_deplibs_check_method=pass_all + ;; + +netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' + fi + ;; + +newos6*) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=/usr/lib/libnls.so + ;; + +*nto* | *qnx*) + lt_cv_deplibs_check_method=pass_all + ;; + +openbsd*) + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' + fi + ;; + +osf3* | osf4* | osf5*) + lt_cv_deplibs_check_method=pass_all + ;; + +rdos*) + lt_cv_deplibs_check_method=pass_all + ;; + +solaris*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv4 | sysv4.3*) + case $host_vendor in + motorola) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + ncr) + lt_cv_deplibs_check_method=pass_all + ;; + sequent) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" + lt_cv_file_magic_test_file=/lib/libc.so + ;; + siemens) + lt_cv_deplibs_check_method=pass_all + ;; + pc) + lt_cv_deplibs_check_method=pass_all + ;; + esac + ;; + +tpf*) + lt_cv_deplibs_check_method=pass_all + ;; +esac +]) +file_magic_cmd=$lt_cv_file_magic_cmd +deplibs_check_method=$lt_cv_deplibs_check_method +test -z "$deplibs_check_method" && deplibs_check_method=unknown + +_LT_DECL([], [deplibs_check_method], [1], + [Method to check whether dependent libraries are shared objects]) +_LT_DECL([], [file_magic_cmd], [1], + [Command to use when deplibs_check_method == "file_magic"]) +])# _LT_CHECK_MAGIC_METHOD + + +# LT_PATH_NM +# ---------- +# find the pathname to a BSD- or MS-compatible name lister +AC_DEFUN([LT_PATH_NM], +[AC_REQUIRE([AC_PROG_CC])dnl +AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM, +[if test -n "$NM"; then + # Let the user override the test. + lt_cv_path_NM="$NM" +else + lt_nm_to_check="${ac_tool_prefix}nm" + if test -n "$ac_tool_prefix" && test "$build" = "$host"; then + lt_nm_to_check="$lt_nm_to_check nm" + fi + for lt_tmp_nm in $lt_nm_to_check; do + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + tmp_nm="$ac_dir/$lt_tmp_nm" + if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the `sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + # Tru64's nm complains that /dev/null is an invalid object file + case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in + */dev/null* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break + ;; + *) + lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + ;; + esac + ;; + esac + fi + done + IFS="$lt_save_ifs" + done + : ${lt_cv_path_NM=no} +fi]) +if test "$lt_cv_path_NM" != "no"; then + NM="$lt_cv_path_NM" +else + # Didn't find any BSD compatible name lister, look for dumpbin. + AC_CHECK_TOOLS(DUMPBIN, ["dumpbin -symbols" "link -dump -symbols"], :) + AC_SUBST([DUMPBIN]) + if test "$DUMPBIN" != ":"; then + NM="$DUMPBIN" + fi +fi +test -z "$NM" && NM=nm +AC_SUBST([NM]) +_LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl + +AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface], + [lt_cv_nm_interface="BSD nm" + echo "int some_variable = 0;" > conftest.$ac_ext + (eval echo "\"\$as_me:__oline__: $ac_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$ac_compile" 2>conftest.err) + cat conftest.err >&AS_MESSAGE_LOG_FD + (eval echo "\"\$as_me:__oline__: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD) + (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) + cat conftest.err >&AS_MESSAGE_LOG_FD + (eval echo "\"\$as_me:__oline__: output\"" >&AS_MESSAGE_LOG_FD) + cat conftest.out >&AS_MESSAGE_LOG_FD + if $GREP 'External.*some_variable' conftest.out > /dev/null; then + lt_cv_nm_interface="MS dumpbin" + fi + rm -f conftest*]) +])# LT_PATH_NM + +# Old names: +AU_ALIAS([AM_PROG_NM], [LT_PATH_NM]) +AU_ALIAS([AC_PROG_NM], [LT_PATH_NM]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AM_PROG_NM], []) +dnl AC_DEFUN([AC_PROG_NM], []) + + +# LT_LIB_M +# -------- +# check for math library +AC_DEFUN([LT_LIB_M], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +LIBM= +case $host in +*-*-beos* | *-*-cygwin* | *-*-pw32* | *-*-darwin*) + # These system don't have libm, or don't need it + ;; +*-ncr-sysv4.3*) + AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw") + AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") + ;; +*) + AC_CHECK_LIB(m, cos, LIBM="-lm") + ;; +esac +AC_SUBST([LIBM]) +])# LT_LIB_M + +# Old name: +AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_CHECK_LIBM], []) + + +# _LT_COMPILER_NO_RTTI([TAGNAME]) +# ------------------------------- +m4_defun([_LT_COMPILER_NO_RTTI], +[m4_require([_LT_TAG_COMPILER])dnl + +_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= + +if test "$GCC" = yes; then + _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' + + _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], + lt_cv_prog_compiler_rtti_exceptions, + [-fno-rtti -fno-exceptions], [], + [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) +fi +_LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1], + [Compiler flag to turn off builtin functions]) +])# _LT_COMPILER_NO_RTTI + + +# _LT_CMD_GLOBAL_SYMBOLS +# ---------------------- +m4_defun([_LT_CMD_GLOBAL_SYMBOLS], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([LT_PATH_NM])dnl +AC_REQUIRE([LT_PATH_LD])dnl +m4_require([_LT_DECL_SED])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_TAG_COMPILER])dnl + +# Check for command to grab the raw symbol name followed by C symbol from nm. +AC_MSG_CHECKING([command to parse $NM output from $compiler object]) +AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], +[ +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[[BCDEGRST]]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' + +# Define system-specific variables. +case $host_os in +aix*) + symcode='[[BCDT]]' + ;; +cygwin* | mingw* | pw32* | cegcc*) + symcode='[[ABCDGISTW]]' + ;; +hpux*) + if test "$host_cpu" = ia64; then + symcode='[[ABCDEGRST]]' + fi + ;; +irix* | nonstopux*) + symcode='[[BCDEGRST]]' + ;; +osf*) + symcode='[[BCDEGQRST]]' + ;; +solaris*) + symcode='[[BDRT]]' + ;; +sco3.2v5*) + symcode='[[DT]]' + ;; +sysv4.2uw2*) + symcode='[[DT]]' + ;; +sysv5* | sco5v6* | unixware* | OpenUNIX*) + symcode='[[ABDT]]' + ;; +sysv4) + symcode='[[DFNSTU]]' + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +case `$NM -V 2>&1` in +*GNU* | *'with BFD'*) + symcode='[[ABCDGIRSTW]]' ;; +esac + +# Transform an extracted symbol line into a proper C declaration. +# Some systems (esp. on ia64) link data and code symbols differently, +# so use this general approach. +lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" + +# Transform an extracted symbol line into symbol name and symbol address +lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (void *) \&\2},/p'" +lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([[^ ]]*\) $/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \(lib[[^ ]]*\)$/ {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"lib\2\", (void *) \&\2},/p'" + +# Handle CRLF in mingw tool chain +opt_cr= +case $build_os in +mingw*) + opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp + ;; +esac + +# Try without a prefix underscore, then with it. +for ac_symprfx in "" "_"; do + + # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. + symxfrm="\\1 $ac_symprfx\\2 \\2" + + # Write the raw and C identifiers. + if test "$lt_cv_nm_interface" = "MS dumpbin"; then + # Fake it for dumpbin and say T for any non-static function + # and D for any global variable. + # Also find C++ and __fastcall symbols from MSVC++, + # which start with @ or ?. + lt_cv_sys_global_symbol_pipe="$AWK ['"\ +" {last_section=section; section=\$ 3};"\ +" /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ +" \$ 0!~/External *\|/{next};"\ +" / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ +" {if(hide[section]) next};"\ +" {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\ +" {split(\$ 0, a, /\||\r/); split(a[2], s)};"\ +" s[1]~/^[@?]/{print s[1], s[1]; next};"\ +" s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\ +" ' prfx=^$ac_symprfx]" + else + lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" + fi + + # Check to see that the pipe works correctly. + pipe_works=no + + rm -f conftest* + cat > conftest.$ac_ext <<_LT_EOF +#ifdef __cplusplus +extern "C" { +#endif +char nm_test_var; +void nm_test_func(void); +void nm_test_func(void){} +#ifdef __cplusplus +} +#endif +int main(){nm_test_var='a';nm_test_func();return(0);} +_LT_EOF + + if AC_TRY_EVAL(ac_compile); then + # Now try to grab the symbols. + nlist=conftest.nm + if AC_TRY_EVAL(NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist) && test -s "$nlist"; then + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if $GREP ' nm_test_var$' "$nlist" >/dev/null; then + if $GREP ' nm_test_func$' "$nlist" >/dev/null; then + cat <<_LT_EOF > conftest.$ac_ext +#ifdef __cplusplus +extern "C" { +#endif + +_LT_EOF + # Now generate the symbol file. + eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' + + cat <<_LT_EOF >> conftest.$ac_ext + +/* The mapping between symbol names and symbols. */ +const struct { + const char *name; + void *address; +} +lt__PROGRAM__LTX_preloaded_symbols[[]] = +{ + { "@PROGRAM@", (void *) 0 }, +_LT_EOF + $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext + cat <<\_LT_EOF >> conftest.$ac_ext + {0, (void *) 0} +}; + +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt__PROGRAM__LTX_preloaded_symbols; +} +#endif + +#ifdef __cplusplus +} +#endif +_LT_EOF + # Now try linking the two files. + mv conftest.$ac_objext conftstm.$ac_objext + lt_save_LIBS="$LIBS" + lt_save_CFLAGS="$CFLAGS" + LIBS="conftstm.$ac_objext" + CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" + if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then + pipe_works=yes + fi + LIBS="$lt_save_LIBS" + CFLAGS="$lt_save_CFLAGS" + else + echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD + fi + else + echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD + cat conftest.$ac_ext >&5 + fi + rm -rf conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test "$pipe_works" = yes; then + break + else + lt_cv_sys_global_symbol_pipe= + fi +done +]) +if test -z "$lt_cv_sys_global_symbol_pipe"; then + lt_cv_sys_global_symbol_to_cdecl= +fi +if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then + AC_MSG_RESULT(failed) +else + AC_MSG_RESULT(ok) +fi + +_LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1], + [Take the output of nm and produce a listing of raw symbols and C names]) +_LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1], + [Transform the output of nm in a proper C declaration]) +_LT_DECL([global_symbol_to_c_name_address], + [lt_cv_sys_global_symbol_to_c_name_address], [1], + [Transform the output of nm in a C name address pair]) +_LT_DECL([global_symbol_to_c_name_address_lib_prefix], + [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1], + [Transform the output of nm in a C name address pair when lib prefix is needed]) +]) # _LT_CMD_GLOBAL_SYMBOLS + + +# _LT_COMPILER_PIC([TAGNAME]) +# --------------------------- +m4_defun([_LT_COMPILER_PIC], +[m4_require([_LT_TAG_COMPILER])dnl +_LT_TAGVAR(lt_prog_compiler_wl, $1)= +_LT_TAGVAR(lt_prog_compiler_pic, $1)= +_LT_TAGVAR(lt_prog_compiler_static, $1)= + +AC_MSG_CHECKING([for $compiler option to produce PIC]) +m4_if([$1], [CXX], [ + # C++ specific cases for pic, static, wl, etc. + if test "$GXX" = yes; then + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + mingw* | cygwin* | os2* | pw32* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + m4_if([$1], [GCJ], [], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) + ;; + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + *djgpp*) + # DJGPP does not support shared libraries at all + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + interix[[3-9]]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + sysv4*MP*) + if test -d /usr/nec; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + else + case $host_os in + aix[[4-9]]*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + chorus*) + case $cc_basename in + cxch68*) + # Green Hills C++ Compiler + # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" + ;; + esac + ;; + dgux*) + case $cc_basename in + ec++*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + ghcx*) + # Green Hills C++ Compiler + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + freebsd* | dragonfly*) + # FreeBSD uses GNU C++ + ;; + hpux9* | hpux10* | hpux11*) + case $cc_basename in + CC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' + if test "$host_cpu" != ia64; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + fi + ;; + aCC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + ;; + *) + ;; + esac + ;; + interix*) + # This is c89, which is MS Visual C++ (no shared libs) + # Anyone wants to do a port? + ;; + irix5* | irix6* | nonstopux*) + case $cc_basename in + CC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + # CC pic flag -KPIC is the default. + ;; + *) + ;; + esac + ;; + linux* | k*bsd*-gnu) + case $cc_basename in + KCC*) + # KAI C++ Compiler + _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + ecpc* ) + # old Intel C++ for x86_64 which still supported -KPIC. + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + icpc* ) + # Intel C++, used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + cxx*) + # Compaq C++ + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + xlc* | xlC*) + # IBM XL 8.0 on PPC + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + ;; + esac + ;; + esac + ;; + lynxos*) + ;; + m88k*) + ;; + mvs*) + case $cc_basename in + cxx*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' + ;; + *) + ;; + esac + ;; + netbsd*) + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + ;; + RCC*) + # Rational C++ 2.4.1 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + cxx*) + # Digital/Compaq C++ + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + *) + ;; + esac + ;; + psos*) + ;; + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + ;; + gcx*) + # Green Hills C++ Compiler + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + ;; + *) + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + lcc*) + # Lucid + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + case $cc_basename in + CC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + esac + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + *) + ;; + esac + ;; + vxworks*) + ;; + *) + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +], +[ + if test "$GCC" = yes; then + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + m4_if([$1], [GCJ], [], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + # +Z the default + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + + interix[[3-9]]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + enable_shared=no + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + m4_if([$1], [GCJ], [], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) + ;; + + hpux9* | hpux10* | hpux11*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC (with -KPIC) is the default. + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + linux* | k*bsd*-gnu) + case $cc_basename in + # old Intel for x86_64 which still supported -KPIC. + ecc*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + # icc used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + icc* | ifort*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + # Lahey Fortran 8.1. + lf95*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared' + _LT_TAGVAR(lt_prog_compiler_static, $1)='--static' + ;; + pgcc* | pgf77* | pgf90* | pgf95*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + ccc*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All Alpha code is PIC. + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + xl*) + # IBM XL C 8.0/Fortran 10.1 on PPC + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C 5.9 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + ;; + *Sun\ F*) + # Sun Fortran 8.3 passes all unrecognized flags to the linker + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='' + ;; + esac + ;; + esac + ;; + + newsos6) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + + osf3* | osf4* | osf5*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All OSF/1 code is PIC. + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + rdos*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + solaris*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + case $cc_basename in + f77* | f90* | f95*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; + *) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; + esac + ;; + + sunos4*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec ;then + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + unicos*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + + uts4*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + *) + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +]) +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])" + ;; +esac +AC_MSG_RESULT([$_LT_TAGVAR(lt_prog_compiler_pic, $1)]) +_LT_TAGDECL([wl], [lt_prog_compiler_wl], [1], + [How to pass a linker flag through the compiler]) + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then + _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works], + [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)], + [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [], + [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in + "" | " "*) ;; + *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;; + esac], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) +fi +_LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1], + [Additional compiler flags for building library objects]) + +# +# Check to make sure the static flag actually works. +# +wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\" +_LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works], + _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1), + $lt_tmp_static_flag, + [], + [_LT_TAGVAR(lt_prog_compiler_static, $1)=]) +_LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1], + [Compiler flag to prevent dynamic linking]) +])# _LT_COMPILER_PIC + + +# _LT_LINKER_SHLIBS([TAGNAME]) +# ---------------------------- +# See if the linker supports building shared libraries. +m4_defun([_LT_LINKER_SHLIBS], +[AC_REQUIRE([LT_PATH_LD])dnl +AC_REQUIRE([LT_PATH_NM])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_DECL_SED])dnl +m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl +m4_require([_LT_TAG_COMPILER])dnl +AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) +m4_if([$1], [CXX], [ + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + case $host_os in + aix[[4-9]]*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + else + _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + fi + ;; + pw32*) + _LT_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds" + ;; + cygwin* | mingw* | cegcc*) + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;/^.*[[ ]]__nm__/s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' + ;; + *) + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + ;; + esac + _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] +], [ + runpath_var= + _LT_TAGVAR(allow_undefined_flag, $1)= + _LT_TAGVAR(always_export_symbols, $1)=no + _LT_TAGVAR(archive_cmds, $1)= + _LT_TAGVAR(archive_expsym_cmds, $1)= + _LT_TAGVAR(compiler_needs_object, $1)=no + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + _LT_TAGVAR(export_dynamic_flag_spec, $1)= + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + _LT_TAGVAR(hardcode_automatic, $1)=no + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= + _LT_TAGVAR(hardcode_libdir_separator, $1)= + _LT_TAGVAR(hardcode_minus_L, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_TAGVAR(inherit_rpath, $1)=no + _LT_TAGVAR(link_all_deplibs, $1)=unknown + _LT_TAGVAR(module_cmds, $1)= + _LT_TAGVAR(module_expsym_cmds, $1)= + _LT_TAGVAR(old_archive_from_new_cmds, $1)= + _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)= + _LT_TAGVAR(thread_safe_flag_spec, $1)= + _LT_TAGVAR(whole_archive_flag_spec, $1)= + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + _LT_TAGVAR(include_expsyms, $1)= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ` (' and `)$', so one must not match beginning or + # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', + # as well as any symbol that contains `d'. + _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + # Exclude shared library initialization/finalization symbols. +dnl Note also adjust exclude_expsyms for C++ above. + extract_expsyms_cmds= + + case $host_os in + cygwin* | mingw* | pw32* | cegcc*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + interix*) + # we just hope/assume this is gcc and not c89 (= MSVC++) + with_gnu_ld=yes + ;; + openbsd*) + with_gnu_ld=no + ;; + esac + + _LT_TAGVAR(ld_shlibs, $1)=yes + if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then + _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + _LT_TAGVAR(whole_archive_flag_spec, $1)= + fi + supports_anon_versioning=no + case `$LD -v 2>&1` in + *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix[[3-9]]*) + # On AIX/PPC, the GNU linker is very broken + if test "$host_cpu" != ia64; then + _LT_TAGVAR(ld_shlibs, $1)=no + cat <<_LT_EOF 1>&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +_LT_EOF + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='' + ;; + m68k) + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=no + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols' + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + interix[[3-9]]*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + + gnu* | linux* | tpf* | k*bsd*-gnu) + tmp_diet=no + if test "$host_os" = linux-dietlibc; then + case $cc_basename in + diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) + esac + fi + if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ + && test "$tmp_diet" = no + then + tmp_addflag= + tmp_sharedflag='-shared' + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + lf95*) # Lahey Fortran 8.1 + _LT_TAGVAR(whole_archive_flag_spec, $1)= + tmp_sharedflag='--shared' ;; + xl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below) + tmp_sharedflag='-qmkshrobj' + tmp_addflag= ;; + esac + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) # Sun C 5.9 + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + _LT_TAGVAR(compiler_needs_object, $1)=yes + tmp_sharedflag='-G' ;; + *Sun\ F*) # Sun Fortran 8.3 + tmp_sharedflag='-G' ;; + esac + _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + + if test "x$supports_anon_versioning" = xyes; then + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + + case $cc_basename in + xlf*) + # IBM XL Fortran 10.1 on PPC cannot create shared libs itself + _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='-rpath $libdir' + _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $compiler_flags -soname $soname -o $lib' + if test "x$supports_anon_versioning" = xyes; then + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $LD -shared $libobjs $deplibs $compiler_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' + fi + ;; + esac + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris*) + if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then + _LT_TAGVAR(ld_shlibs, $1)=no + cat <<_LT_EOF 1>&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) + case `$LD -v 2>&1` in + *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*) + _LT_TAGVAR(ld_shlibs, $1)=no + cat <<_LT_EOF 1>&2 + +*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not +*** reliably create shared libraries on SCO systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.16.91.0.3 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + ;; + *) + # For security reasons, it is highly recommended that you always + # use absolute paths for naming shared libraries, and exclude the + # DT_RUNPATH tag from executables and libraries. But doing so + # requires that you compile everything twice, which is a pain. + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + sunos4*) + _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + + if test "$_LT_TAGVAR(ld_shlibs, $1)" = no; then + runpath_var= + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_TAGVAR(export_dynamic_flag_spec, $1)= + _LT_TAGVAR(whole_archive_flag_spec, $1)= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=yes + _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + _LT_TAGVAR(hardcode_direct, $1)=unsupported + fi + ;; + + aix[[4-9]]*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + else + _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) + for ld_flag in $LDFLAGS; do + if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then + aix_use_runtimelinking=yes + break + fi + done + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_TAGVAR(archive_cmds, $1)='' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='${wl}-f,' + + if test "$GCC" = yes; then + case $host_os in aix4.[[012]]|aix4.[[012]].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + _LT_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)= + fi + ;; + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + _LT_TAGVAR(always_export_symbols, $1)=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + _LT_TAGVAR(allow_undefined_flag, $1)='-berok' + # Determine the default libpath from the value encoded in an + # empty executable. + _LT_SYS_MODULE_PATH_AIX + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then $ECHO "X${wl}${allow_undefined_flag}" | $Xsed; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' + _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + _LT_SYS_MODULE_PATH_AIX + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' + _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' + # Exported symbols can be pulled into shared objects from archives + _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' + _LT_TAGVAR(archive_cmds_need_lc, $1)=yes + # This is similar to how AIX traditionally builds its shared libraries. + _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='' + ;; + m68k) + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + ;; + + bsdi[[45]]*) + _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=".dll" + # FIXME: Setting linknames here is a bad hack. + _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `$ECHO "X$deplibs" | $Xsed -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' + # FIXME: Should let the user specify the lib program. + _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs' + _LT_TAGVAR(fix_srcfile_path, $1)='`cygpath -w "$srcfile"`' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + ;; + + darwin* | rhapsody*) + _LT_DARWIN_LINKER_FEATURES($1) + ;; + + dgux*) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + freebsd1*) + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | dragonfly*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + hpux9*) + if test "$GCC" = yes; then + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(hardcode_direct, $1)=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + ;; + + hpux10*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + fi + if test "$with_gnu_ld" = no; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + fi + ;; + + hpux11*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + fi + if test "$with_gnu_ld" = no; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + case $host_cpu in + hppa*64*|ia64*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + *) + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test "$GCC" = yes; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + # Try to use the -exported_symbol ld option, if it does not + # work, assume that -exports_file does not work either and + # implicitly export all symbols. + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null" + AC_LINK_IFELSE(int foo(void) {}, + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib' + ) + LDFLAGS="$save_LDFLAGS" + else + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)='no' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(inherit_rpath, $1)=yes + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + newsos6) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *nto* | *qnx*) + ;; + + openbsd*) + if test -f /usr/libexec/ld.so; then + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + else + case $host_os in + openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*) + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + ;; + esac + fi + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + os2*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$ECHO DATA >> $output_objdir/$libname.def~$ECHO " SINGLE NONSHARED" >> $output_objdir/$libname.def~$ECHO EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' + _LT_TAGVAR(old_archive_from_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' + ;; + + osf3*) + if test "$GCC" = yes; then + _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)='no' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test "$GCC" = yes; then + _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + else + _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ + $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp' + + # Both c and cxx compiler support -rpath directly + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)='no' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + solaris*) + _LT_TAGVAR(no_undefined_flag, $1)=' -z defs' + if test "$GCC" = yes; then + wlarc='${wl}' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + else + case `$CC -V 2>&1` in + *"Compilers 5.0"*) + wlarc='' + _LT_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' + ;; + *) + wlarc='${wl}' + _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + ;; + esac + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands `-z linker_flag'. GCC discards it without `$wl', + # but is careful enough not to reorder. + # Supported since Solaris 2.6 (maybe 2.5.1?) + if test "$GCC" = yes; then + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' + else + _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' + fi + ;; + esac + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + + sunos4*) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4) + case $host_vendor in + sni) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' + _LT_TAGVAR(hardcode_direct, $1)=no + ;; + motorola) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4.3*) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + _LT_TAGVAR(ld_shlibs, $1)=yes + fi + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) + _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var='LD_RUN_PATH' + + if test "$GCC" = yes; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We can NOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' + _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' + runpath_var='LD_RUN_PATH' + + if test "$GCC" = yes; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + uts4*) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + + if test x$host_vendor = xsni; then + case $host in + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Blargedynsym' + ;; + esac + fi + fi +]) +AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) +test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no + +_LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld + +_LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl +_LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl +_LT_DECL([], [extract_expsyms_cmds], [2], + [The commands to extract the exported symbol list from a shared archive]) + +# +# Do we need to explicitly link libc? +# +case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in +x|xyes) + # Assume -lc should be added + _LT_TAGVAR(archive_cmds_need_lc, $1)=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $_LT_TAGVAR(archive_cmds, $1) in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + AC_MSG_CHECKING([whether -lc should be explicitly linked in]) + $RM conftest* + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + if AC_TRY_EVAL(ac_compile) 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) + pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1) + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1) + _LT_TAGVAR(allow_undefined_flag, $1)= + if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) + then + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + else + _LT_TAGVAR(archive_cmds_need_lc, $1)=yes + fi + _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $RM conftest* + AC_MSG_RESULT([$_LT_TAGVAR(archive_cmds_need_lc, $1)]) + ;; + esac + fi + ;; +esac + +_LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0], + [Whether or not to add -lc for building shared libraries]) +_LT_TAGDECL([allow_libtool_libs_with_static_runtimes], + [enable_shared_with_static_runtimes], [0], + [Whether or not to disallow shared libs when runtime libs are static]) +_LT_TAGDECL([], [export_dynamic_flag_spec], [1], + [Compiler flag to allow reflexive dlopens]) +_LT_TAGDECL([], [whole_archive_flag_spec], [1], + [Compiler flag to generate shared objects directly from archives]) +_LT_TAGDECL([], [compiler_needs_object], [1], + [Whether the compiler copes with passing no objects directly]) +_LT_TAGDECL([], [old_archive_from_new_cmds], [2], + [Create an old-style archive from a shared archive]) +_LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2], + [Create a temporary old-style archive to link instead of a shared archive]) +_LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive]) +_LT_TAGDECL([], [archive_expsym_cmds], [2]) +_LT_TAGDECL([], [module_cmds], [2], + [Commands used to build a loadable module if different from building + a shared archive.]) +_LT_TAGDECL([], [module_expsym_cmds], [2]) +_LT_TAGDECL([], [with_gnu_ld], [1], + [Whether we are building with GNU ld or not]) +_LT_TAGDECL([], [allow_undefined_flag], [1], + [Flag that allows shared libraries with undefined symbols to be built]) +_LT_TAGDECL([], [no_undefined_flag], [1], + [Flag that enforces no undefined symbols]) +_LT_TAGDECL([], [hardcode_libdir_flag_spec], [1], + [Flag to hardcode $libdir into a binary during linking. + This must work even if $libdir does not exist]) +_LT_TAGDECL([], [hardcode_libdir_flag_spec_ld], [1], + [[If ld is used when linking, flag to hardcode $libdir into a binary + during linking. This must work even if $libdir does not exist]]) +_LT_TAGDECL([], [hardcode_libdir_separator], [1], + [Whether we need a single "-rpath" flag with a separated argument]) +_LT_TAGDECL([], [hardcode_direct], [0], + [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes + DIR into the resulting binary]) +_LT_TAGDECL([], [hardcode_direct_absolute], [0], + [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes + DIR into the resulting binary and the resulting library dependency is + "absolute", i.e impossible to change by setting ${shlibpath_var} if the + library is relocated]) +_LT_TAGDECL([], [hardcode_minus_L], [0], + [Set to "yes" if using the -LDIR flag during linking hardcodes DIR + into the resulting binary]) +_LT_TAGDECL([], [hardcode_shlibpath_var], [0], + [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR + into the resulting binary]) +_LT_TAGDECL([], [hardcode_automatic], [0], + [Set to "yes" if building a shared library automatically hardcodes DIR + into the library and all subsequent libraries and executables linked + against it]) +_LT_TAGDECL([], [inherit_rpath], [0], + [Set to yes if linker adds runtime paths of dependent libraries + to runtime path list]) +_LT_TAGDECL([], [link_all_deplibs], [0], + [Whether libtool must link a program against all its dependency libraries]) +_LT_TAGDECL([], [fix_srcfile_path], [1], + [Fix the shell variable $srcfile for the compiler]) +_LT_TAGDECL([], [always_export_symbols], [0], + [Set to "yes" if exported symbols are required]) +_LT_TAGDECL([], [export_symbols_cmds], [2], + [The commands to list exported symbols]) +_LT_TAGDECL([], [exclude_expsyms], [1], + [Symbols that should not be listed in the preloaded symbols]) +_LT_TAGDECL([], [include_expsyms], [1], + [Symbols that must always be exported]) +_LT_TAGDECL([], [prelink_cmds], [2], + [Commands necessary for linking programs (against libraries) with templates]) +_LT_TAGDECL([], [file_list_spec], [1], + [Specify filename containing input files]) +dnl FIXME: Not yet implemented +dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1], +dnl [Compiler flag to generate thread safe objects]) +])# _LT_LINKER_SHLIBS + + +# _LT_LANG_C_CONFIG([TAG]) +# ------------------------ +# Ensure that the configuration variables for a C compiler are suitably +# defined. These variables are subsequently used by _LT_CONFIG to write +# the compiler configuration to `libtool'. +m4_defun([_LT_LANG_C_CONFIG], +[m4_require([_LT_DECL_EGREP])dnl +lt_save_CC="$CC" +AC_LANG_PUSH(C) + +# Source file extension for C test sources. +ac_ext=c + +# Object file extension for compiled C test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(){return(0);}' + +_LT_TAG_COMPILER +# Save the default compiler, since it gets overwritten when the other +# tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. +compiler_DEFAULT=$CC + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +## CAVEAT EMPTOR: +## There is no encapsulation within the following macros, do not change +## the running order or otherwise move them around unless you know exactly +## what you are doing... +if test -n "$compiler"; then + _LT_COMPILER_NO_RTTI($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + LT_SYS_DLOPEN_SELF + _LT_CMD_STRIPLIB + + # Report which library types will actually be built + AC_MSG_CHECKING([if libtool supports shared libraries]) + AC_MSG_RESULT([$can_build_shared]) + + AC_MSG_CHECKING([whether to build shared libraries]) + test "$can_build_shared" = "no" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + + aix[[4-9]]*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; + esac + AC_MSG_RESULT([$enable_shared]) + + AC_MSG_CHECKING([whether to build static libraries]) + # Make sure either enable_shared or enable_static is yes. + test "$enable_shared" = yes || enable_static=yes + AC_MSG_RESULT([$enable_static]) + + _LT_CONFIG($1) +fi +AC_LANG_POP +CC="$lt_save_CC" +])# _LT_LANG_C_CONFIG + + +# _LT_PROG_CXX +# ------------ +# Since AC_PROG_CXX is broken, in that it returns g++ if there is no c++ +# compiler, we have our own version here. +m4_defun([_LT_PROG_CXX], +[ +pushdef([AC_MSG_ERROR], [_lt_caught_CXX_error=yes]) +AC_PROG_CXX +if test -n "$CXX" && ( test "X$CXX" != "Xno" && + ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || + (test "X$CXX" != "Xg++"))) ; then + AC_PROG_CXXCPP +else + _lt_caught_CXX_error=yes +fi +popdef([AC_MSG_ERROR]) +])# _LT_PROG_CXX + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([_LT_PROG_CXX], []) + + +# _LT_LANG_CXX_CONFIG([TAG]) +# -------------------------- +# Ensure that the configuration variables for a C++ compiler are suitably +# defined. These variables are subsequently used by _LT_CONFIG to write +# the compiler configuration to `libtool'. +m4_defun([_LT_LANG_CXX_CONFIG], +[AC_REQUIRE([_LT_PROG_CXX])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_EGREP])dnl + +AC_LANG_PUSH(C++) +_LT_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_TAGVAR(allow_undefined_flag, $1)= +_LT_TAGVAR(always_export_symbols, $1)=no +_LT_TAGVAR(archive_expsym_cmds, $1)= +_LT_TAGVAR(compiler_needs_object, $1)=no +_LT_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_TAGVAR(hardcode_direct, $1)=no +_LT_TAGVAR(hardcode_direct_absolute, $1)=no +_LT_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= +_LT_TAGVAR(hardcode_libdir_separator, $1)= +_LT_TAGVAR(hardcode_minus_L, $1)=no +_LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported +_LT_TAGVAR(hardcode_automatic, $1)=no +_LT_TAGVAR(inherit_rpath, $1)=no +_LT_TAGVAR(module_cmds, $1)= +_LT_TAGVAR(module_expsym_cmds, $1)= +_LT_TAGVAR(link_all_deplibs, $1)=unknown +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(no_undefined_flag, $1)= +_LT_TAGVAR(whole_archive_flag_spec, $1)= +_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Source file extension for C++ test sources. +ac_ext=cpp + +# Object file extension for compiled C++ test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# No sense in running all these tests if we already determined that +# the CXX compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test "$_lt_caught_CXX_error" != yes; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="int some_variable = 0;" + + # Code to be used in simple link tests + lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }' + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + _LT_TAG_COMPILER + + # save warnings/boilerplate of simple test code + _LT_COMPILER_BOILERPLATE + _LT_LINKER_BOILERPLATE + + # Allow CC to be a program name with arguments. + lt_save_CC=$CC + lt_save_LD=$LD + lt_save_GCC=$GCC + GCC=$GXX + lt_save_with_gnu_ld=$with_gnu_ld + lt_save_path_LD=$lt_cv_path_LD + if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then + lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx + else + $as_unset lt_cv_prog_gnu_ld + fi + if test -n "${lt_cv_path_LDCXX+set}"; then + lt_cv_path_LD=$lt_cv_path_LDCXX + else + $as_unset lt_cv_path_LD + fi + test -z "${LDCXX+set}" || LD=$LDCXX + CC=${CXX-"c++"} + compiler=$CC + _LT_TAGVAR(compiler, $1)=$CC + _LT_CC_BASENAME([$compiler]) + + if test -n "$compiler"; then + # We don't want -fno-exception when compiling C++ code, so set the + # no_builtin_flag separately + if test "$GXX" = yes; then + _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' + else + _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= + fi + + if test "$GXX" = yes; then + # Set up default GNU C++ configuration + + LT_PATH_LD + + # Check if GNU C++ uses GNU ld as the underlying linker, since the + # archiving commands below assume that GNU ld is being used. + if test "$with_gnu_ld" = yes; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + + # If archive_cmds runs LD, not CC, wlarc should be empty + # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to + # investigate it a little bit more. (MM) + wlarc='${wl}' + + # ancient GNU ld didn't support --whole-archive et. al. + if eval "`$CC -print-prog-name=ld` --help 2>&1" | + $GREP 'no-whole-archive' > /dev/null; then + _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + _LT_TAGVAR(whole_archive_flag_spec, $1)= + fi + else + with_gnu_ld=no + wlarc= + + # A generic and very simple default shared library creation + # command for GNU C++ for the case where it uses the native + # linker, instead of GNU ld. If possible, this setting should + # overridden to take advantage of the native linker features on + # the platform it is being used on. + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + fi + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + + else + GXX=no + with_gnu_ld=no + wlarc= + fi + + # PORTME: fill in a description of your system's C++ link characteristics + AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) + _LT_TAGVAR(ld_shlibs, $1)=yes + case $host_os in + aix3*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + aix[[4-9]]*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) + for ld_flag in $LDFLAGS; do + case $ld_flag in + *-brtl*) + aix_use_runtimelinking=yes + break + ;; + esac + done + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_TAGVAR(archive_cmds, $1)='' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='${wl}-f,' + + if test "$GXX" = yes; then + case $host_os in aix4.[[012]]|aix4.[[012]].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + _LT_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to + # export. + _LT_TAGVAR(always_export_symbols, $1)=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + _LT_TAGVAR(allow_undefined_flag, $1)='-berok' + # Determine the default libpath from the value encoded in an empty + # executable. + _LT_SYS_MODULE_PATH_AIX + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then $ECHO "X${wl}${allow_undefined_flag}" | $Xsed; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' + _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + _LT_SYS_MODULE_PATH_AIX + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' + _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' + # Exported symbols can be pulled into shared objects from archives + _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' + _LT_TAGVAR(archive_cmds_need_lc, $1)=yes + # This is similar to how AIX traditionally builds its shared + # libraries. + _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + chorus*) + case $cc_basename in + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=no + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + darwin* | rhapsody*) + _LT_DARWIN_LINKER_FEATURES($1) + ;; + + dgux*) + case $cc_basename in + ec++*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + ghcx*) + # Green Hills C++ Compiler + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + freebsd[[12]]*) + # C++ shared libraries reported to be fairly broken before + # switch to ELF + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + freebsd-elf*) + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + ;; + + freebsd* | dragonfly*) + # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF + # conventions + _LT_TAGVAR(ld_shlibs, $1)=yes + ;; + + gnu*) + ;; + + hpux9*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + aCC*) + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + *) + if test "$GXX" = yes; then + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + hpux10*|hpux11*) + if test $with_gnu_ld = no; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + case $host_cpu in + hppa*64*|ia64*) + ;; + *) + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + ;; + esac + fi + case $host_cpu in + hppa*64*|ia64*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + *) + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + esac + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + aCC*) + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + *) + if test "$GXX" = yes; then + if test $with_gnu_ld = no; then + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + fi + else + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + interix[[3-9]]*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + irix5* | irix6*) + case $cc_basename in + CC*) + # SGI C++ + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + + # Archives containing C++ object files must be created using + # "CC -ar", where "CC" is the IRIX C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' + ;; + *) + if test "$GXX" = yes; then + if test "$with_gnu_ld" = no; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` -o $lib' + fi + fi + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + esac + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(inherit_rpath, $1)=yes + ;; + + linux* | k*bsd*-gnu) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' + ;; + icpc* | ecpc* ) + # Intel C++ + with_gnu_ld=yes + # version 8.0 and above of icpc choke on multiply defined symbols + # if we add $predep_objects and $postdep_objects, however 7.1 and + # earlier do not add the objects themselves. + case `$CC -V 2>&1` in + *"Version 7."*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 8.0 or newer + tmp_idyn= + case $host_cpu in + ia64*) tmp_idyn=' -i_dynamic';; + esac + _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + case `$CC -V` in + *pgCC\ [[1-5]]* | *pgcpp\ [[1-5]]*) + _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ + compile_command="$compile_command `find $tpldir -name \*.o | $NL2SP`"' + _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ + $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | $NL2SP`~ + $RANLIB $oldlib' + _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' + ;; + *) # Version 6 will use weak symbols + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' + ;; + esac + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + ;; + cxx*) + # Compaq C++ + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' + + runpath_var=LD_RUN_PATH + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`$ECHO "X$templist" | $Xsed -e "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + xl*) + # IBM XL 8.0 on PPC, with GNU ld + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + if test "x$supports_anon_versioning" = xyes; then + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' + _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + _LT_TAGVAR(compiler_needs_object, $1)=yes + + # Not sure whether something based on + # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 + # would be better. + output_verbose_link_cmd='echo' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' + ;; + esac + ;; + esac + ;; + + lynxos*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + m88k*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + mvs*) + case $cc_basename in + cxx*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' + wlarc= + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + fi + # Workaround some broken pre-1.5 toolchains + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' + ;; + + *nto* | *qnx*) + _LT_TAGVAR(ld_shlibs, $1)=yes + ;; + + openbsd2*) + # C++ shared libraries are fairly broken + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + openbsd*) + if test -f /usr/libexec/ld.so; then + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + fi + output_verbose_link_cmd=echo + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Archives containing C++ object files must be created using + # the KAI C++ compiler. + case $host in + osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; + *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;; + esac + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + cxx*) + case $host in + osf3*) + _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && $ECHO "X${wl}-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + ;; + *) + _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ + echo "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname ${wl}-input ${wl}$lib.exp `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib~ + $RM $lib.exp' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + ;; + esac + + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`$ECHO "X$templist" | $Xsed -e "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + case $host in + osf3*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + ;; + esac + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + + else + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + psos*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + lcc*) + # Lucid + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_TAGVAR(archive_cmds_need_lc,$1)=yes + _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' + _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands `-z linker_flag'. + # Supported since Solaris 2.6 (maybe 2.5.1?) + _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' + ;; + esac + _LT_TAGVAR(link_all_deplibs, $1)=yes + + output_verbose_link_cmd='echo' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' + ;; + gcx*) + # Green Hills C++ Compiler + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + + # The C++ compiler must be used to create the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' + ;; + *) + # GNU C++ compiler with Solaris linker + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs' + if $CC --version | $GREP -v '^2\.7' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + else + # g++ 2.7 appears to require `-G' NOT `-shared' on this + # platform. + _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + fi + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir' + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' + ;; + esac + fi + ;; + esac + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) + _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We can NOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' + _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + vxworks*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + + AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) + test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no + + _LT_TAGVAR(GCC, $1)="$GXX" + _LT_TAGVAR(LD, $1)="$LD" + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + _LT_SYS_HIDDEN_LIBDEPS($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) + fi # test -n "$compiler" + + CC=$lt_save_CC + LDCXX=$LD + LD=$lt_save_LD + GCC=$lt_save_GCC + with_gnu_ld=$lt_save_with_gnu_ld + lt_cv_path_LDCXX=$lt_cv_path_LD + lt_cv_path_LD=$lt_save_path_LD + lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld + lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld +fi # test "$_lt_caught_CXX_error" != yes + +AC_LANG_POP +])# _LT_LANG_CXX_CONFIG + + +# _LT_SYS_HIDDEN_LIBDEPS([TAGNAME]) +# --------------------------------- +# Figure out "hidden" library dependencies from verbose +# compiler output when linking a shared library. +# Parse the compiler output and extract the necessary +# objects, libraries and library flags. +m4_defun([_LT_SYS_HIDDEN_LIBDEPS], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +# Dependencies to place before and after the object being linked: +_LT_TAGVAR(predep_objects, $1)= +_LT_TAGVAR(postdep_objects, $1)= +_LT_TAGVAR(predeps, $1)= +_LT_TAGVAR(postdeps, $1)= +_LT_TAGVAR(compiler_lib_search_path, $1)= + +dnl we can't use the lt_simple_compile_test_code here, +dnl because it contains code intended for an executable, +dnl not a library. It's possible we should let each +dnl tag define a new lt_????_link_test_code variable, +dnl but it's only used here... +m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF +int a; +void foo (void) { a = 0; } +_LT_EOF +], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF +class Foo +{ +public: + Foo (void) { a = 0; } +private: + int a; +}; +_LT_EOF +], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF + subroutine foo + implicit none + integer*4 a + a=0 + return + end +_LT_EOF +], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF + subroutine foo + implicit none + integer a + a=0 + return + end +_LT_EOF +], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF +public class foo { + private int a; + public void bar (void) { + a = 0; + } +}; +_LT_EOF +]) +dnl Parse the compiler output and extract the necessary +dnl objects, libraries and library flags. +if AC_TRY_EVAL(ac_compile); then + # Parse the compiler output and extract the necessary + # objects, libraries and library flags. + + # Sentinel used to keep track of whether or not we are before + # the conftest object file. + pre_test_object_deps_done=no + + for p in `eval "$output_verbose_link_cmd"`; do + case $p in + + -L* | -R* | -l*) + # Some compilers place space between "-{L,R}" and the path. + # Remove the space. + if test $p = "-L" || + test $p = "-R"; then + prev=$p + continue + else + prev= + fi + + if test "$pre_test_object_deps_done" = no; then + case $p in + -L* | -R*) + # Internal compiler library paths should come after those + # provided the user. The postdeps already come after the + # user supplied libs so there is no need to process them. + if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then + _LT_TAGVAR(compiler_lib_search_path, $1)="${prev}${p}" + else + _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} ${prev}${p}" + fi + ;; + # The "-l" case would never come before the object being + # linked, so don't bother handling this case. + esac + else + if test -z "$_LT_TAGVAR(postdeps, $1)"; then + _LT_TAGVAR(postdeps, $1)="${prev}${p}" + else + _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} ${prev}${p}" + fi + fi + ;; + + *.$objext) + # This assumes that the test object file only shows up + # once in the compiler output. + if test "$p" = "conftest.$objext"; then + pre_test_object_deps_done=yes + continue + fi + + if test "$pre_test_object_deps_done" = no; then + if test -z "$_LT_TAGVAR(predep_objects, $1)"; then + _LT_TAGVAR(predep_objects, $1)="$p" + else + _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p" + fi + else + if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then + _LT_TAGVAR(postdep_objects, $1)="$p" + else + _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p" + fi + fi + ;; + + *) ;; # Ignore the rest. + + esac + done + + # Clean up. + rm -f a.out a.exe +else + echo "libtool.m4: error: problem compiling $1 test program" +fi + +$RM -f confest.$objext + +# PORTME: override above test on systems where it is broken +m4_if([$1], [CXX], +[case $host_os in +interix[[3-9]]*) + # Interix 3.5 installs completely hosed .la files for C++, so rather than + # hack all around it, let's just trust "g++" to DTRT. + _LT_TAGVAR(predep_objects,$1)= + _LT_TAGVAR(postdep_objects,$1)= + _LT_TAGVAR(postdeps,$1)= + ;; + +linux*) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + + # The more standards-conforming stlport4 library is + # incompatible with the Cstd library. Avoid specifying + # it if it's in CXXFLAGS. Ignore libCrun as + # -library=stlport4 depends on it. + case " $CXX $CXXFLAGS " in + *" -library=stlport4 "*) + solaris_use_stlport4=yes + ;; + esac + + if test "$solaris_use_stlport4" != yes; then + _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun' + fi + ;; + esac + ;; + +solaris*) + case $cc_basename in + CC*) + # The more standards-conforming stlport4 library is + # incompatible with the Cstd library. Avoid specifying + # it if it's in CXXFLAGS. Ignore libCrun as + # -library=stlport4 depends on it. + case " $CXX $CXXFLAGS " in + *" -library=stlport4 "*) + solaris_use_stlport4=yes + ;; + esac + + # Adding this requires a known-good setup of shared libraries for + # Sun compiler versions before 5.6, else PIC objects from an old + # archive will be linked into the output, leading to subtle bugs. + if test "$solaris_use_stlport4" != yes; then + _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun' + fi + ;; + esac + ;; +esac +]) + +case " $_LT_TAGVAR(postdeps, $1) " in +*" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; +esac + _LT_TAGVAR(compiler_lib_search_dirs, $1)= +if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then + _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | ${SED} -e 's! -L! !g' -e 's!^ !!'` +fi +_LT_TAGDECL([], [compiler_lib_search_dirs], [1], + [The directories searched by this compiler when creating a shared library]) +_LT_TAGDECL([], [predep_objects], [1], + [Dependencies to place before and after the objects being linked to + create a shared library]) +_LT_TAGDECL([], [postdep_objects], [1]) +_LT_TAGDECL([], [predeps], [1]) +_LT_TAGDECL([], [postdeps], [1]) +_LT_TAGDECL([], [compiler_lib_search_path], [1], + [The library search path used internally by the compiler when linking + a shared library]) +])# _LT_SYS_HIDDEN_LIBDEPS + + +# _LT_PROG_F77 +# ------------ +# Since AC_PROG_F77 is broken, in that it returns the empty string +# if there is no fortran compiler, we have our own version here. +m4_defun([_LT_PROG_F77], +[ +pushdef([AC_MSG_ERROR], [_lt_disable_F77=yes]) +AC_PROG_F77 +if test -z "$F77" || test "X$F77" = "Xno"; then + _lt_disable_F77=yes +fi +popdef([AC_MSG_ERROR]) +])# _LT_PROG_F77 + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([_LT_PROG_F77], []) + + +# _LT_LANG_F77_CONFIG([TAG]) +# -------------------------- +# Ensure that the configuration variables for a Fortran 77 compiler are +# suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to `libtool'. +m4_defun([_LT_LANG_F77_CONFIG], +[AC_REQUIRE([_LT_PROG_F77])dnl +AC_LANG_PUSH(Fortran 77) + +_LT_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_TAGVAR(allow_undefined_flag, $1)= +_LT_TAGVAR(always_export_symbols, $1)=no +_LT_TAGVAR(archive_expsym_cmds, $1)= +_LT_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_TAGVAR(hardcode_direct, $1)=no +_LT_TAGVAR(hardcode_direct_absolute, $1)=no +_LT_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= +_LT_TAGVAR(hardcode_libdir_separator, $1)= +_LT_TAGVAR(hardcode_minus_L, $1)=no +_LT_TAGVAR(hardcode_automatic, $1)=no +_LT_TAGVAR(inherit_rpath, $1)=no +_LT_TAGVAR(module_cmds, $1)= +_LT_TAGVAR(module_expsym_cmds, $1)= +_LT_TAGVAR(link_all_deplibs, $1)=unknown +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(no_undefined_flag, $1)= +_LT_TAGVAR(whole_archive_flag_spec, $1)= +_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Source file extension for f77 test sources. +ac_ext=f + +# Object file extension for compiled f77 test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# No sense in running all these tests if we already determined that +# the F77 compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test "$_lt_disable_F77" != yes; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="\ + subroutine t + return + end +" + + # Code to be used in simple link tests + lt_simple_link_test_code="\ + program t + end +" + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + _LT_TAG_COMPILER + + # save warnings/boilerplate of simple test code + _LT_COMPILER_BOILERPLATE + _LT_LINKER_BOILERPLATE + + # Allow CC to be a program name with arguments. + lt_save_CC="$CC" + lt_save_GCC=$GCC + CC=${F77-"f77"} + compiler=$CC + _LT_TAGVAR(compiler, $1)=$CC + _LT_CC_BASENAME([$compiler]) + GCC=$G77 + if test -n "$compiler"; then + AC_MSG_CHECKING([if libtool supports shared libraries]) + AC_MSG_RESULT([$can_build_shared]) + + AC_MSG_CHECKING([whether to build shared libraries]) + test "$can_build_shared" = "no" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + aix[[4-9]]*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; + esac + AC_MSG_RESULT([$enable_shared]) + + AC_MSG_CHECKING([whether to build static libraries]) + # Make sure either enable_shared or enable_static is yes. + test "$enable_shared" = yes || enable_static=yes + AC_MSG_RESULT([$enable_static]) + + _LT_TAGVAR(GCC, $1)="$G77" + _LT_TAGVAR(LD, $1)="$LD" + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) + fi # test -n "$compiler" + + GCC=$lt_save_GCC + CC="$lt_save_CC" +fi # test "$_lt_disable_F77" != yes + +AC_LANG_POP +])# _LT_LANG_F77_CONFIG + + +# _LT_PROG_FC +# ----------- +# Since AC_PROG_FC is broken, in that it returns the empty string +# if there is no fortran compiler, we have our own version here. +m4_defun([_LT_PROG_FC], +[ +pushdef([AC_MSG_ERROR], [_lt_disable_FC=yes]) +AC_PROG_FC +if test -z "$FC" || test "X$FC" = "Xno"; then + _lt_disable_FC=yes +fi +popdef([AC_MSG_ERROR]) +])# _LT_PROG_FC + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([_LT_PROG_FC], []) + + +# _LT_LANG_FC_CONFIG([TAG]) +# ------------------------- +# Ensure that the configuration variables for a Fortran compiler are +# suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to `libtool'. +m4_defun([_LT_LANG_FC_CONFIG], +[AC_REQUIRE([_LT_PROG_FC])dnl +AC_LANG_PUSH(Fortran) + +_LT_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_TAGVAR(allow_undefined_flag, $1)= +_LT_TAGVAR(always_export_symbols, $1)=no +_LT_TAGVAR(archive_expsym_cmds, $1)= +_LT_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_TAGVAR(hardcode_direct, $1)=no +_LT_TAGVAR(hardcode_direct_absolute, $1)=no +_LT_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= +_LT_TAGVAR(hardcode_libdir_separator, $1)= +_LT_TAGVAR(hardcode_minus_L, $1)=no +_LT_TAGVAR(hardcode_automatic, $1)=no +_LT_TAGVAR(inherit_rpath, $1)=no +_LT_TAGVAR(module_cmds, $1)= +_LT_TAGVAR(module_expsym_cmds, $1)= +_LT_TAGVAR(link_all_deplibs, $1)=unknown +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(no_undefined_flag, $1)= +_LT_TAGVAR(whole_archive_flag_spec, $1)= +_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Source file extension for fc test sources. +ac_ext=${ac_fc_srcext-f} + +# Object file extension for compiled fc test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# No sense in running all these tests if we already determined that +# the FC compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test "$_lt_disable_FC" != yes; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="\ + subroutine t + return + end +" + + # Code to be used in simple link tests + lt_simple_link_test_code="\ + program t + end +" + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + _LT_TAG_COMPILER + + # save warnings/boilerplate of simple test code + _LT_COMPILER_BOILERPLATE + _LT_LINKER_BOILERPLATE + + # Allow CC to be a program name with arguments. + lt_save_CC="$CC" + lt_save_GCC=$GCC + CC=${FC-"f95"} + compiler=$CC + GCC=$ac_cv_fc_compiler_gnu + + _LT_TAGVAR(compiler, $1)=$CC + _LT_CC_BASENAME([$compiler]) + + if test -n "$compiler"; then + AC_MSG_CHECKING([if libtool supports shared libraries]) + AC_MSG_RESULT([$can_build_shared]) + + AC_MSG_CHECKING([whether to build shared libraries]) + test "$can_build_shared" = "no" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + aix[[4-9]]*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; + esac + AC_MSG_RESULT([$enable_shared]) + + AC_MSG_CHECKING([whether to build static libraries]) + # Make sure either enable_shared or enable_static is yes. + test "$enable_shared" = yes || enable_static=yes + AC_MSG_RESULT([$enable_static]) + + _LT_TAGVAR(GCC, $1)="$ac_cv_fc_compiler_gnu" + _LT_TAGVAR(LD, $1)="$LD" + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + _LT_SYS_HIDDEN_LIBDEPS($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) + fi # test -n "$compiler" + + GCC=$lt_save_GCC + CC="$lt_save_CC" +fi # test "$_lt_disable_FC" != yes + +AC_LANG_POP +])# _LT_LANG_FC_CONFIG + + +# _LT_LANG_GCJ_CONFIG([TAG]) +# -------------------------- +# Ensure that the configuration variables for the GNU Java Compiler compiler +# are suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to `libtool'. +m4_defun([_LT_LANG_GCJ_CONFIG], +[AC_REQUIRE([LT_PROG_GCJ])dnl +AC_LANG_SAVE + +# Source file extension for Java test sources. +ac_ext=java + +# Object file extension for compiled Java test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="class foo {}" + +# Code to be used in simple link tests +lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }' + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. +_LT_TAG_COMPILER + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +# Allow CC to be a program name with arguments. +lt_save_CC="$CC" +lt_save_GCC=$GCC +GCC=yes +CC=${GCJ-"gcj"} +compiler=$CC +_LT_TAGVAR(compiler, $1)=$CC +_LT_TAGVAR(LD, $1)="$LD" +_LT_CC_BASENAME([$compiler]) + +# GCJ did not exist at the time GCC didn't implicitly link libc in. +_LT_TAGVAR(archive_cmds_need_lc, $1)=no + +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds + +## CAVEAT EMPTOR: +## There is no encapsulation within the following macros, do not change +## the running order or otherwise move them around unless you know exactly +## what you are doing... +if test -n "$compiler"; then + _LT_COMPILER_NO_RTTI($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) +fi + +AC_LANG_RESTORE + +GCC=$lt_save_GCC +CC="$lt_save_CC" +])# _LT_LANG_GCJ_CONFIG + + +# _LT_LANG_RC_CONFIG([TAG]) +# ------------------------- +# Ensure that the configuration variables for the Windows resource compiler +# are suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to `libtool'. +m4_defun([_LT_LANG_RC_CONFIG], +[AC_REQUIRE([LT_PROG_RC])dnl +AC_LANG_SAVE + +# Source file extension for RC test sources. +ac_ext=rc + +# Object file extension for compiled RC test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' + +# Code to be used in simple link tests +lt_simple_link_test_code="$lt_simple_compile_test_code" + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. +_LT_TAG_COMPILER + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +# Allow CC to be a program name with arguments. +lt_save_CC="$CC" +lt_save_GCC=$GCC +GCC= +CC=${RC-"windres"} +compiler=$CC +_LT_TAGVAR(compiler, $1)=$CC +_LT_CC_BASENAME([$compiler]) +_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes + +if test -n "$compiler"; then + : + _LT_CONFIG($1) +fi + +GCC=$lt_save_GCC +AC_LANG_RESTORE +CC="$lt_save_CC" +])# _LT_LANG_RC_CONFIG + + +# LT_PROG_GCJ +# ----------- +AC_DEFUN([LT_PROG_GCJ], +[m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ], + [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ], + [AC_CHECK_TOOL(GCJ, gcj,) + test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2" + AC_SUBST(GCJFLAGS)])])[]dnl +]) + +# Old name: +AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([LT_AC_PROG_GCJ], []) + + +# LT_PROG_RC +# ---------- +AC_DEFUN([LT_PROG_RC], +[AC_CHECK_TOOL(RC, windres,) +]) + +# Old name: +AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([LT_AC_PROG_RC], []) + + +# _LT_DECL_EGREP +# -------------- +# If we don't have a new enough Autoconf to choose the best grep +# available, choose the one first in the user's PATH. +m4_defun([_LT_DECL_EGREP], +[AC_REQUIRE([AC_PROG_EGREP])dnl +AC_REQUIRE([AC_PROG_FGREP])dnl +test -z "$GREP" && GREP=grep +_LT_DECL([], [GREP], [1], [A grep program that handles long lines]) +_LT_DECL([], [EGREP], [1], [An ERE matcher]) +_LT_DECL([], [FGREP], [1], [A literal string matcher]) +dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too +AC_SUBST([GREP]) +]) + + +# _LT_DECL_OBJDUMP +# -------------- +# If we don't have a new enough Autoconf to choose the best objdump +# available, choose the one first in the user's PATH. +m4_defun([_LT_DECL_OBJDUMP], +[AC_CHECK_TOOL(OBJDUMP, objdump, false) +test -z "$OBJDUMP" && OBJDUMP=objdump +_LT_DECL([], [OBJDUMP], [1], [An object symbol dumper]) +AC_SUBST([OBJDUMP]) +]) + + +# _LT_DECL_SED +# ------------ +# Check for a fully-functional sed program, that truncates +# as few characters as possible. Prefer GNU sed if found. +m4_defun([_LT_DECL_SED], +[AC_PROG_SED +test -z "$SED" && SED=sed +Xsed="$SED -e 1s/^X//" +_LT_DECL([], [SED], [1], [A sed program that does not truncate output]) +_LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"], + [Sed that helps us avoid accidentally triggering echo(1) options like -n]) +])# _LT_DECL_SED + +m4_ifndef([AC_PROG_SED], [ +############################################################ +# NOTE: This macro has been submitted for inclusion into # +# GNU Autoconf as AC_PROG_SED. When it is available in # +# a released version of Autoconf we should remove this # +# macro and use it instead. # +############################################################ + +m4_defun([AC_PROG_SED], +[AC_MSG_CHECKING([for a sed that does not truncate output]) +AC_CACHE_VAL(lt_cv_path_SED, +[# Loop through the user's path and test for sed and gsed. +# Then use that list of sed's as ones to test for truncation. +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for lt_ac_prog in sed gsed; do + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then + lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" + fi + done + done +done +IFS=$as_save_IFS +lt_ac_max=0 +lt_ac_count=0 +# Add /usr/xpg4/bin/sed as it is typically found on Solaris +# along with /bin/sed that truncates output. +for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do + test ! -f $lt_ac_sed && continue + cat /dev/null > conftest.in + lt_ac_count=0 + echo $ECHO_N "0123456789$ECHO_C" >conftest.in + # Check for GNU sed and select it if it is found. + if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then + lt_cv_path_SED=$lt_ac_sed + break + fi + while true; do + cat conftest.in conftest.in >conftest.tmp + mv conftest.tmp conftest.in + cp conftest.in conftest.nl + echo >>conftest.nl + $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break + cmp -s conftest.out conftest.nl || break + # 10000 chars as input seems more than enough + test $lt_ac_count -gt 10 && break + lt_ac_count=`expr $lt_ac_count + 1` + if test $lt_ac_count -gt $lt_ac_max; then + lt_ac_max=$lt_ac_count + lt_cv_path_SED=$lt_ac_sed + fi + done +done +]) +SED=$lt_cv_path_SED +AC_SUBST([SED]) +AC_MSG_RESULT([$SED]) +])#AC_PROG_SED +])#m4_ifndef + +# Old name: +AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([LT_AC_PROG_SED], []) + + +# _LT_CHECK_SHELL_FEATURES +# ------------------------ +# Find out whether the shell is Bourne or XSI compatible, +# or has some other useful features. +m4_defun([_LT_CHECK_SHELL_FEATURES], +[AC_MSG_CHECKING([whether the shell understands some XSI constructs]) +# Try some XSI features +xsi_shell=no +( _lt_dummy="a/b/c" + test "${_lt_dummy##*/},${_lt_dummy%/*},"${_lt_dummy%"$_lt_dummy"}, \ + = c,a/b,, \ + && eval 'test $(( 1 + 1 )) -eq 2 \ + && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \ + && xsi_shell=yes +AC_MSG_RESULT([$xsi_shell]) +_LT_CONFIG_LIBTOOL_INIT([xsi_shell='$xsi_shell']) + +AC_MSG_CHECKING([whether the shell understands "+="]) +lt_shell_append=no +( foo=bar; set foo baz; eval "$[1]+=\$[2]" && test "$foo" = barbaz ) \ + >/dev/null 2>&1 \ + && lt_shell_append=yes +AC_MSG_RESULT([$lt_shell_append]) +_LT_CONFIG_LIBTOOL_INIT([lt_shell_append='$lt_shell_append']) + +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then + lt_unset=unset +else + lt_unset=false +fi +_LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl + +# test EBCDIC or ASCII +case `echo X|tr X '\101'` in + A) # ASCII based system + # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr + lt_SP2NL='tr \040 \012' + lt_NL2SP='tr \015\012 \040\040' + ;; + *) # EBCDIC based system + lt_SP2NL='tr \100 \n' + lt_NL2SP='tr \r\n \100\100' + ;; +esac +_LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl +_LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl +])# _LT_CHECK_SHELL_FEATURES + + +# _LT_PROG_XSI_SHELLFNS +# --------------------- +# Bourne and XSI compatible variants of some useful shell functions. +m4_defun([_LT_PROG_XSI_SHELLFNS], +[case $xsi_shell in + yes) + cat << \_LT_EOF >> "$cfgfile" + +# func_dirname file append nondir_replacement +# Compute the dirname of FILE. If nonempty, add APPEND to the result, +# otherwise set result to NONDIR_REPLACEMENT. +func_dirname () +{ + case ${1} in + */*) func_dirname_result="${1%/*}${2}" ;; + * ) func_dirname_result="${3}" ;; + esac +} + +# func_basename file +func_basename () +{ + func_basename_result="${1##*/}" +} + +# func_dirname_and_basename file append nondir_replacement +# perform func_basename and func_dirname in a single function +# call: +# dirname: Compute the dirname of FILE. If nonempty, +# add APPEND to the result, otherwise set result +# to NONDIR_REPLACEMENT. +# value returned in "$func_dirname_result" +# basename: Compute filename of FILE. +# value retuned in "$func_basename_result" +# Implementation must be kept synchronized with func_dirname +# and func_basename. For efficiency, we do not delegate to +# those functions but instead duplicate the functionality here. +func_dirname_and_basename () +{ + case ${1} in + */*) func_dirname_result="${1%/*}${2}" ;; + * ) func_dirname_result="${3}" ;; + esac + func_basename_result="${1##*/}" +} + +# func_stripname prefix suffix name +# strip PREFIX and SUFFIX off of NAME. +# PREFIX and SUFFIX must not contain globbing or regex special +# characters, hashes, percent signs, but SUFFIX may contain a leading +# dot (in which case that matches only a dot). +func_stripname () +{ + # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are + # positional parameters, so assign one to ordinary parameter first. + func_stripname_result=${3} + func_stripname_result=${func_stripname_result#"${1}"} + func_stripname_result=${func_stripname_result%"${2}"} +} + +# func_opt_split +func_opt_split () +{ + func_opt_split_opt=${1%%=*} + func_opt_split_arg=${1#*=} +} + +# func_lo2o object +func_lo2o () +{ + case ${1} in + *.lo) func_lo2o_result=${1%.lo}.${objext} ;; + *) func_lo2o_result=${1} ;; + esac +} + +# func_xform libobj-or-source +func_xform () +{ + func_xform_result=${1%.*}.lo +} + +# func_arith arithmetic-term... +func_arith () +{ + func_arith_result=$(( $[*] )) +} + +# func_len string +# STRING may not start with a hyphen. +func_len () +{ + func_len_result=${#1} +} + +_LT_EOF + ;; + *) # Bourne compatible functions. + cat << \_LT_EOF >> "$cfgfile" + +# func_dirname file append nondir_replacement +# Compute the dirname of FILE. If nonempty, add APPEND to the result, +# otherwise set result to NONDIR_REPLACEMENT. +func_dirname () +{ + # Extract subdirectory from the argument. + func_dirname_result=`$ECHO "X${1}" | $Xsed -e "$dirname"` + if test "X$func_dirname_result" = "X${1}"; then + func_dirname_result="${3}" + else + func_dirname_result="$func_dirname_result${2}" + fi +} + +# func_basename file +func_basename () +{ + func_basename_result=`$ECHO "X${1}" | $Xsed -e "$basename"` +} + +dnl func_dirname_and_basename +dnl A portable version of this function is already defined in general.m4sh +dnl so there is no need for it here. + +# func_stripname prefix suffix name +# strip PREFIX and SUFFIX off of NAME. +# PREFIX and SUFFIX must not contain globbing or regex special +# characters, hashes, percent signs, but SUFFIX may contain a leading +# dot (in which case that matches only a dot). +# func_strip_suffix prefix name +func_stripname () +{ + case ${2} in + .*) func_stripname_result=`$ECHO "X${3}" \ + | $Xsed -e "s%^${1}%%" -e "s%\\\\${2}\$%%"`;; + *) func_stripname_result=`$ECHO "X${3}" \ + | $Xsed -e "s%^${1}%%" -e "s%${2}\$%%"`;; + esac +} + +# sed scripts: +my_sed_long_opt='1s/^\(-[[^=]]*\)=.*/\1/;q' +my_sed_long_arg='1s/^-[[^=]]*=//' + +# func_opt_split +func_opt_split () +{ + func_opt_split_opt=`$ECHO "X${1}" | $Xsed -e "$my_sed_long_opt"` + func_opt_split_arg=`$ECHO "X${1}" | $Xsed -e "$my_sed_long_arg"` +} + +# func_lo2o object +func_lo2o () +{ + func_lo2o_result=`$ECHO "X${1}" | $Xsed -e "$lo2o"` +} + +# func_xform libobj-or-source +func_xform () +{ + func_xform_result=`$ECHO "X${1}" | $Xsed -e 's/\.[[^.]]*$/.lo/'` +} + +# func_arith arithmetic-term... +func_arith () +{ + func_arith_result=`expr "$[@]"` +} + +# func_len string +# STRING may not start with a hyphen. +func_len () +{ + func_len_result=`expr "$[1]" : ".*" 2>/dev/null || echo $max_cmd_len` +} + +_LT_EOF +esac + +case $lt_shell_append in + yes) + cat << \_LT_EOF >> "$cfgfile" + +# func_append var value +# Append VALUE to the end of shell variable VAR. +func_append () +{ + eval "$[1]+=\$[2]" +} +_LT_EOF + ;; + *) + cat << \_LT_EOF >> "$cfgfile" + +# func_append var value +# Append VALUE to the end of shell variable VAR. +func_append () +{ + eval "$[1]=\$$[1]\$[2]" +} + +_LT_EOF + ;; + esac +]) + diff --git a/Externals/SDL/acinclude/ltdl.m4 b/Externals/SDL/acinclude/ltdl.m4 new file mode 100644 index 0000000000..e2b7129919 --- /dev/null +++ b/Externals/SDL/acinclude/ltdl.m4 @@ -0,0 +1,806 @@ +############################################################################## +# ltdl.m4 - Configure ltdl for the target system. -*-Autoconf-*- +# +# Copyright (C) 1999-2006, 2007, 2008 Free Software Foundation, Inc. +# Written by Thomas Tanner, 1999 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# serial 17 LTDL_INIT + +# LT_CONFIG_LTDL_DIR(DIRECTORY, [LTDL-MODE]) +# ------------------------------------------ +# DIRECTORY contains the libltdl sources. It is okay to call this +# function multiple times, as long as the same DIRECTORY is always given. +AC_DEFUN([LT_CONFIG_LTDL_DIR], +[AC_BEFORE([$0], [LTDL_INIT]) +_$0($*) +])# LT_CONFIG_LTDL_DIR + +# We break this out into a separate macro, so that we can call it safely +# internally without being caught accidentally by the sed scan in libtoolize. +m4_defun([_LT_CONFIG_LTDL_DIR], +[dnl remove trailing slashes +m4_pushdef([_ARG_DIR], m4_bpatsubst([$1], [/*$])) +m4_case(_LTDL_DIR, + [], [dnl only set lt_ltdl_dir if _ARG_DIR is not simply `.' + m4_if(_ARG_DIR, [.], + [], + [m4_define([_LTDL_DIR], _ARG_DIR) + _LT_SHELL_INIT([lt_ltdl_dir=']_ARG_DIR['])])], + [m4_if(_ARG_DIR, _LTDL_DIR, + [], + [m4_fatal([multiple libltdl directories: `]_LTDL_DIR[', `]_ARG_DIR['])])]) +m4_popdef([_ARG_DIR]) +])# _LT_CONFIG_LTDL_DIR + +# Initialise: +m4_define([_LTDL_DIR], []) + + +# _LT_BUILD_PREFIX +# ---------------- +# If Autoconf is new enough, expand to `${top_build_prefix}', otherwise +# to `${top_builddir}/'. +m4_define([_LT_BUILD_PREFIX], +[m4_ifdef([AC_AUTOCONF_VERSION], + [m4_if(m4_version_compare(m4_defn([AC_AUTOCONF_VERSION]), [2.62]), + [-1], [m4_ifdef([_AC_HAVE_TOP_BUILD_PREFIX], + [${top_build_prefix}], + [${top_builddir}/])], + [${top_build_prefix}])], + [${top_builddir}/])[]dnl +]) + + +# LTDL_CONVENIENCE +# ---------------- +# sets LIBLTDL to the link flags for the libltdl convenience library and +# LTDLINCL to the include flags for the libltdl header and adds +# --enable-ltdl-convenience to the configure arguments. Note that +# AC_CONFIG_SUBDIRS is not called here. LIBLTDL will be prefixed with +# '${top_build_prefix}' if available, otherwise with '${top_builddir}/', +# and LTDLINCL will be prefixed with '${top_srcdir}/' (note the single +# quotes!). If your package is not flat and you're not using automake, +# define top_build_prefix, top_builddir, and top_srcdir appropriately +# in your Makefiles. +AC_DEFUN([LTDL_CONVENIENCE], +[AC_BEFORE([$0], [LTDL_INIT])dnl +dnl Although the argument is deprecated and no longer documented, +dnl LTDL_CONVENIENCE used to take a DIRECTORY orgument, if we have one +dnl here make sure it is the same as any other declaration of libltdl's +dnl location! This also ensures lt_ltdl_dir is set when configure.ac is +dnl not yet using an explicit LT_CONFIG_LTDL_DIR. +m4_ifval([$1], [_LT_CONFIG_LTDL_DIR([$1])])dnl +_$0() +])# LTDL_CONVENIENCE + +# AC_LIBLTDL_CONVENIENCE accepted a directory argument in older libtools, +# now we have LT_CONFIG_LTDL_DIR: +AU_DEFUN([AC_LIBLTDL_CONVENIENCE], +[_LT_CONFIG_LTDL_DIR([m4_default([$1], [libltdl])]) +_LTDL_CONVENIENCE]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBLTDL_CONVENIENCE], []) + + +# _LTDL_CONVENIENCE +# ----------------- +# Code shared by LTDL_CONVENIENCE and LTDL_INIT([convenience]). +m4_defun([_LTDL_CONVENIENCE], +[case $enable_ltdl_convenience in + no) AC_MSG_ERROR([this package needs a convenience libltdl]) ;; + "") enable_ltdl_convenience=yes + ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;; +esac +LIBLTDL='_LT_BUILD_PREFIX'"${lt_ltdl_dir+$lt_ltdl_dir/}libltdlc.la" +LTDLDEPS=$LIBLTDL +LTDLINCL='-I${top_srcdir}'"${lt_ltdl_dir+/$lt_ltdl_dir}" + +AC_SUBST([LIBLTDL]) +AC_SUBST([LTDLDEPS]) +AC_SUBST([LTDLINCL]) + +# For backwards non-gettext consistent compatibility... +INCLTDL="$LTDLINCL" +AC_SUBST([INCLTDL]) +])# _LTDL_CONVENIENCE + + +# LTDL_INSTALLABLE +# ---------------- +# sets LIBLTDL to the link flags for the libltdl installable library +# and LTDLINCL to the include flags for the libltdl header and adds +# --enable-ltdl-install to the configure arguments. Note that +# AC_CONFIG_SUBDIRS is not called from here. If an installed libltdl +# is not found, LIBLTDL will be prefixed with '${top_build_prefix}' if +# available, otherwise with '${top_builddir}/', and LTDLINCL will be +# prefixed with '${top_srcdir}/' (note the single quotes!). If your +# package is not flat and you're not using automake, define top_build_prefix, +# top_builddir, and top_srcdir appropriately in your Makefiles. +# In the future, this macro may have to be called after LT_INIT. +AC_DEFUN([LTDL_INSTALLABLE], +[AC_BEFORE([$0], [LTDL_INIT])dnl +dnl Although the argument is deprecated and no longer documented, +dnl LTDL_INSTALLABLE used to take a DIRECTORY orgument, if we have one +dnl here make sure it is the same as any other declaration of libltdl's +dnl location! This also ensures lt_ltdl_dir is set when configure.ac is +dnl not yet using an explicit LT_CONFIG_LTDL_DIR. +m4_ifval([$1], [_LT_CONFIG_LTDL_DIR([$1])])dnl +_$0() +])# LTDL_INSTALLABLE + +# AC_LIBLTDL_INSTALLABLE accepted a directory argument in older libtools, +# now we have LT_CONFIG_LTDL_DIR: +AU_DEFUN([AC_LIBLTDL_INSTALLABLE], +[_LT_CONFIG_LTDL_DIR([m4_default([$1], [libltdl])]) +_LTDL_INSTALLABLE]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBLTDL_INSTALLABLE], []) + + +# _LTDL_INSTALLABLE +# ----------------- +# Code shared by LTDL_INSTALLABLE and LTDL_INIT([installable]). +m4_defun([_LTDL_INSTALLABLE], +[if test -f $prefix/lib/libltdl.la; then + lt_save_LDFLAGS="$LDFLAGS" + LDFLAGS="-L$prefix/lib $LDFLAGS" + AC_CHECK_LIB([ltdl], [lt_dlinit], [lt_lib_ltdl=yes]) + LDFLAGS="$lt_save_LDFLAGS" + if test x"${lt_lib_ltdl-no}" = xyes; then + if test x"$enable_ltdl_install" != xyes; then + # Don't overwrite $prefix/lib/libltdl.la without --enable-ltdl-install + AC_MSG_WARN([not overwriting libltdl at $prefix, force with `--enable-ltdl-install']) + enable_ltdl_install=no + fi + elif test x"$enable_ltdl_install" = xno; then + AC_MSG_WARN([libltdl not installed, but installation disabled]) + fi +fi + +# If configure.ac declared an installable ltdl, and the user didn't override +# with --disable-ltdl-install, we will install the shipped libltdl. +case $enable_ltdl_install in + no) ac_configure_args="$ac_configure_args --enable-ltdl-install=no" + LIBLTDL="-lltdl" + LTDLDEPS= + LTDLINCL= + ;; + *) enable_ltdl_install=yes + ac_configure_args="$ac_configure_args --enable-ltdl-install" + LIBLTDL='_LT_BUILD_PREFIX'"${lt_ltdl_dir+$lt_ltdl_dir/}libltdl.la" + LTDLDEPS=$LIBLTDL + LTDLINCL='-I${top_srcdir}'"${lt_ltdl_dir+/$lt_ltdl_dir}" + ;; +esac + +AC_SUBST([LIBLTDL]) +AC_SUBST([LTDLDEPS]) +AC_SUBST([LTDLINCL]) + +# For backwards non-gettext consistent compatibility... +INCLTDL="$LTDLINCL" +AC_SUBST([INCLTDL]) +])# LTDL_INSTALLABLE + + +# _LTDL_MODE_DISPATCH +# ------------------- +m4_define([_LTDL_MODE_DISPATCH], +[dnl If _LTDL_DIR is `.', then we are configuring libltdl itself: +m4_if(_LTDL_DIR, [], + [], + dnl if _LTDL_MODE was not set already, the default value is `subproject': + [m4_case(m4_default(_LTDL_MODE, [subproject]), + [subproject], [AC_CONFIG_SUBDIRS(_LTDL_DIR) + _LT_SHELL_INIT([lt_dlopen_dir="$lt_ltdl_dir"])], + [nonrecursive], [_LT_SHELL_INIT([lt_dlopen_dir="$lt_ltdl_dir"; lt_libobj_prefix="$lt_ltdl_dir/"])], + [recursive], [], + [m4_fatal([unknown libltdl mode: ]_LTDL_MODE)])])dnl +dnl Be careful not to expand twice: +m4_define([$0], []) +])# _LTDL_MODE_DISPATCH + + +# _LT_LIBOBJ(MODULE_NAME) +# ----------------------- +# Like AC_LIBOBJ, except that MODULE_NAME goes into _LT_LIBOBJS instead +# of into LIBOBJS. +AC_DEFUN([_LT_LIBOBJ], [ + m4_pattern_allow([^_LT_LIBOBJS$]) + _LT_LIBOBJS="$_LT_LIBOBJS $1.$ac_objext" +])# _LT_LIBOBJS + + +# LTDL_INIT([OPTIONS]) +# -------------------- +# Clients of libltdl can use this macro to allow the installer to +# choose between a shipped copy of the ltdl sources or a preinstalled +# version of the library. If the shipped ltdl sources are not in a +# subdirectory named libltdl, the directory name must be given by +# LT_CONFIG_LTDL_DIR. +AC_DEFUN([LTDL_INIT], +[dnl Parse OPTIONS +_LT_SET_OPTIONS([$0], [$1]) + +dnl We need to keep our own list of libobjs separate from our parent project, +dnl and the easiest way to do that is redefine the AC_LIBOBJs macro while +dnl we look for our own LIBOBJs. +m4_pushdef([AC_LIBOBJ], m4_defn([_LT_LIBOBJ])) +m4_pushdef([AC_LIBSOURCES]) + +dnl If not otherwise defined, default to the 1.5.x compatible subproject mode: +m4_if(_LTDL_MODE, [], + [m4_define([_LTDL_MODE], m4_default([$2], [subproject])) + m4_if([-1], [m4_bregexp(_LTDL_MODE, [\(subproject\|\(non\)?recursive\)])], + [m4_fatal([unknown libltdl mode: ]_LTDL_MODE)])]) + +AC_ARG_WITH([included_ltdl], + [AS_HELP_STRING([--with-included-ltdl], + [use the GNU ltdl sources included here])]) + +if test "x$with_included_ltdl" != xyes; then + # We are not being forced to use the included libltdl sources, so + # decide whether there is a useful installed version we can use. + AC_CHECK_HEADER([ltdl.h], + [AC_CHECK_DECL([lt_dlinterface_register], + [AC_CHECK_LIB([ltdl], [lt_dladvise_preload], + [with_included_ltdl=no], + [with_included_ltdl=yes])], + [with_included_ltdl=yes], + [AC_INCLUDES_DEFAULT + #include ])], + [with_included_ltdl=yes], + [AC_INCLUDES_DEFAULT] + ) +fi + +dnl If neither LT_CONFIG_LTDL_DIR, LTDL_CONVENIENCE nor LTDL_INSTALLABLE +dnl was called yet, then for old times' sake, we assume libltdl is in an +dnl eponymous directory: +AC_PROVIDE_IFELSE([LT_CONFIG_LTDL_DIR], [], [_LT_CONFIG_LTDL_DIR([libltdl])]) + +AC_ARG_WITH([ltdl_include], + [AS_HELP_STRING([--with-ltdl-include=DIR], + [use the ltdl headers installed in DIR])]) + +if test -n "$with_ltdl_include"; then + if test -f "$with_ltdl_include/ltdl.h"; then : + else + AC_MSG_ERROR([invalid ltdl include directory: `$with_ltdl_include']) + fi +else + with_ltdl_include=no +fi + +AC_ARG_WITH([ltdl_lib], + [AS_HELP_STRING([--with-ltdl-lib=DIR], + [use the libltdl.la installed in DIR])]) + +if test -n "$with_ltdl_lib"; then + if test -f "$with_ltdl_lib/libltdl.la"; then : + else + AC_MSG_ERROR([invalid ltdl library directory: `$with_ltdl_lib']) + fi +else + with_ltdl_lib=no +fi + +case ,$with_included_ltdl,$with_ltdl_include,$with_ltdl_lib, in + ,yes,no,no,) + m4_case(m4_default(_LTDL_TYPE, [convenience]), + [convenience], [_LTDL_CONVENIENCE], + [installable], [_LTDL_INSTALLABLE], + [m4_fatal([unknown libltdl build type: ]_LTDL_TYPE)]) + ;; + ,no,no,no,) + # If the included ltdl is not to be used, then use the + # preinstalled libltdl we found. + AC_DEFINE([HAVE_LTDL], [1], + [Define this if a modern libltdl is already installed]) + LIBLTDL=-lltdl + LTDLDEPS= + LTDLINCL= + ;; + ,no*,no,*) + AC_MSG_ERROR([`--with-ltdl-include' and `--with-ltdl-lib' options must be used together]) + ;; + *) with_included_ltdl=no + LIBLTDL="-L$with_ltdl_lib -lltdl" + LTDLDEPS= + LTDLINCL="-I$with_ltdl_include" + ;; +esac +INCLTDL="$LTDLINCL" + +# Report our decision... +AC_MSG_CHECKING([where to find libltdl headers]) +AC_MSG_RESULT([$LTDLINCL]) +AC_MSG_CHECKING([where to find libltdl library]) +AC_MSG_RESULT([$LIBLTDL]) + +_LTDL_SETUP + +dnl restore autoconf definition. +m4_popdef([AC_LIBOBJ]) +m4_popdef([AC_LIBSOURCES]) + +AC_CONFIG_COMMANDS_PRE([ + _ltdl_libobjs= + _ltdl_ltlibobjs= + if test -n "$_LT_LIBOBJS"; then + # Remove the extension. + _lt_sed_drop_objext='s/\.o$//;s/\.obj$//' + for i in `for i in $_LT_LIBOBJS; do echo "$i"; done | sed "$_lt_sed_drop_objext" | sort -u`; do + _ltdl_libobjs="$_ltdl_libobjs $lt_libobj_prefix$i.$ac_objext" + _ltdl_ltlibobjs="$_ltdl_ltlibobjs $lt_libobj_prefix$i.lo" + done + fi + AC_SUBST([ltdl_LIBOBJS], [$_ltdl_libobjs]) + AC_SUBST([ltdl_LTLIBOBJS], [$_ltdl_ltlibobjs]) +]) + +# Only expand once: +m4_define([LTDL_INIT]) +])# LTDL_INIT + +# Old names: +AU_DEFUN([AC_LIB_LTDL], [LTDL_INIT($@)]) +AU_DEFUN([AC_WITH_LTDL], [LTDL_INIT($@)]) +AU_DEFUN([LT_WITH_LTDL], [LTDL_INIT($@)]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIB_LTDL], []) +dnl AC_DEFUN([AC_WITH_LTDL], []) +dnl AC_DEFUN([LT_WITH_LTDL], []) + + +# _LTDL_SETUP +# ----------- +# Perform all the checks necessary for compilation of the ltdl objects +# -- including compiler checks and header checks. This is a public +# interface mainly for the benefit of libltdl's own configure.ac, most +# other users should call LTDL_INIT instead. +AC_DEFUN([_LTDL_SETUP], +[AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([LT_SYS_MODULE_EXT])dnl +AC_REQUIRE([LT_SYS_MODULE_PATH])dnl +AC_REQUIRE([LT_SYS_DLSEARCH_PATH])dnl +AC_REQUIRE([LT_LIB_DLLOAD])dnl +AC_REQUIRE([LT_SYS_SYMBOL_USCORE])dnl +AC_REQUIRE([LT_FUNC_DLSYM_USCORE])dnl +AC_REQUIRE([LT_SYS_DLOPEN_DEPLIBS])dnl +AC_REQUIRE([gl_FUNC_ARGZ])dnl + +m4_require([_LT_CHECK_OBJDIR])dnl +m4_require([_LT_HEADER_DLFCN])dnl +m4_require([_LT_CHECK_DLPREOPEN])dnl +m4_require([_LT_DECL_SED])dnl + +dnl Don't require this, or it will be expanded earlier than the code +dnl that sets the variables it relies on: +_LT_ENABLE_INSTALL + +dnl _LTDL_MODE specific code must be called at least once: +_LTDL_MODE_DISPATCH + +# In order that ltdl.c can compile, find out the first AC_CONFIG_HEADERS +# the user used. This is so that ltdl.h can pick up the parent projects +# config.h file, The first file in AC_CONFIG_HEADERS must contain the +# definitions required by ltdl.c. +# FIXME: Remove use of undocumented AC_LIST_HEADERS (2.59 compatibility). +AC_CONFIG_COMMANDS_PRE([dnl +m4_pattern_allow([^LT_CONFIG_H$])dnl +m4_ifset([AH_HEADER], + [LT_CONFIG_H=AH_HEADER], + [m4_ifset([AC_LIST_HEADERS], + [LT_CONFIG_H=`echo "AC_LIST_HEADERS" | $SED 's,^[[ ]]*,,;s,[[ :]].*$,,'`], + [])])]) +AC_SUBST([LT_CONFIG_H]) + +AC_CHECK_HEADERS([unistd.h dl.h sys/dl.h dld.h mach-o/dyld.h dirent.h], + [], [], [AC_INCLUDES_DEFAULT]) + +AC_CHECK_FUNCS([closedir opendir readdir], [], [AC_LIBOBJ([lt__dirent])]) +AC_CHECK_FUNCS([strlcat strlcpy], [], [AC_LIBOBJ([lt__strl])]) + +AC_DEFINE_UNQUOTED([LT_LIBEXT],["$libext"],[The archive extension]) + +name=ltdl +LTDLOPEN=`eval "\\$ECHO \"$libname_spec\""` +AC_SUBST([LTDLOPEN]) +])# _LTDL_SETUP + + +# _LT_ENABLE_INSTALL +# ------------------ +m4_define([_LT_ENABLE_INSTALL], +[AC_ARG_ENABLE([ltdl-install], + [AS_HELP_STRING([--enable-ltdl-install], [install libltdl])]) + +case ,${enable_ltdl_install},${enable_ltdl_convenience} in + *yes*) ;; + *) enable_ltdl_convenience=yes ;; +esac + +m4_ifdef([AM_CONDITIONAL], +[AM_CONDITIONAL(INSTALL_LTDL, test x"${enable_ltdl_install-no}" != xno) + AM_CONDITIONAL(CONVENIENCE_LTDL, test x"${enable_ltdl_convenience-no}" != xno)]) +])# _LT_ENABLE_INSTALL + + +# LT_SYS_DLOPEN_DEPLIBS +# --------------------- +AC_DEFUN([LT_SYS_DLOPEN_DEPLIBS], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_CACHE_CHECK([whether deplibs are loaded by dlopen], + [lt_cv_sys_dlopen_deplibs], + [# PORTME does your system automatically load deplibs for dlopen? + # or its logical equivalent (e.g. shl_load for HP-UX < 11) + # For now, we just catch OSes we know something about -- in the + # future, we'll try test this programmatically. + lt_cv_sys_dlopen_deplibs=unknown + case $host_os in + aix3*|aix4.1.*|aix4.2.*) + # Unknown whether this is true for these versions of AIX, but + # we want this `case' here to explicitly catch those versions. + lt_cv_sys_dlopen_deplibs=unknown + ;; + aix[[4-9]]*) + lt_cv_sys_dlopen_deplibs=yes + ;; + amigaos*) + case $host_cpu in + powerpc) + lt_cv_sys_dlopen_deplibs=no + ;; + esac + ;; + darwin*) + # Assuming the user has installed a libdl from somewhere, this is true + # If you are looking for one http://www.opendarwin.org/projects/dlcompat + lt_cv_sys_dlopen_deplibs=yes + ;; + freebsd* | dragonfly*) + lt_cv_sys_dlopen_deplibs=yes + ;; + gnu* | linux* | k*bsd*-gnu) + # GNU and its variants, using gnu ld.so (Glibc) + lt_cv_sys_dlopen_deplibs=yes + ;; + hpux10*|hpux11*) + lt_cv_sys_dlopen_deplibs=yes + ;; + interix*) + lt_cv_sys_dlopen_deplibs=yes + ;; + irix[[12345]]*|irix6.[[01]]*) + # Catch all versions of IRIX before 6.2, and indicate that we don't + # know how it worked for any of those versions. + lt_cv_sys_dlopen_deplibs=unknown + ;; + irix*) + # The case above catches anything before 6.2, and it's known that + # at 6.2 and later dlopen does load deplibs. + lt_cv_sys_dlopen_deplibs=yes + ;; + netbsd*) + lt_cv_sys_dlopen_deplibs=yes + ;; + openbsd*) + lt_cv_sys_dlopen_deplibs=yes + ;; + osf[[1234]]*) + # dlopen did load deplibs (at least at 4.x), but until the 5.x series, + # it did *not* use an RPATH in a shared library to find objects the + # library depends on, so we explicitly say `no'. + lt_cv_sys_dlopen_deplibs=no + ;; + osf5.0|osf5.0a|osf5.1) + # dlopen *does* load deplibs and with the right loader patch applied + # it even uses RPATH in a shared library to search for shared objects + # that the library depends on, but there's no easy way to know if that + # patch is installed. Since this is the case, all we can really + # say is unknown -- it depends on the patch being installed. If + # it is, this changes to `yes'. Without it, it would be `no'. + lt_cv_sys_dlopen_deplibs=unknown + ;; + osf*) + # the two cases above should catch all versions of osf <= 5.1. Read + # the comments above for what we know about them. + # At > 5.1, deplibs are loaded *and* any RPATH in a shared library + # is used to find them so we can finally say `yes'. + lt_cv_sys_dlopen_deplibs=yes + ;; + qnx*) + lt_cv_sys_dlopen_deplibs=yes + ;; + solaris*) + lt_cv_sys_dlopen_deplibs=yes + ;; + sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + libltdl_cv_sys_dlopen_deplibs=yes + ;; + esac + ]) +if test "$lt_cv_sys_dlopen_deplibs" != yes; then + AC_DEFINE([LTDL_DLOPEN_DEPLIBS], [1], + [Define if the OS needs help to load dependent libraries for dlopen().]) +fi +])# LT_SYS_DLOPEN_DEPLIBS + +# Old name: +AU_ALIAS([AC_LTDL_SYS_DLOPEN_DEPLIBS], [LT_SYS_DLOPEN_DEPLIBS]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LTDL_SYS_DLOPEN_DEPLIBS], []) + + +# LT_SYS_MODULE_EXT +# ----------------- +AC_DEFUN([LT_SYS_MODULE_EXT], +[m4_require([_LT_SYS_DYNAMIC_LINKER])dnl +AC_CACHE_CHECK([which extension is used for runtime loadable modules], + [libltdl_cv_shlibext], +[ +module=yes +eval libltdl_cv_shlibext=$shrext_cmds + ]) +if test -n "$libltdl_cv_shlibext"; then + m4_pattern_allow([LT_MODULE_EXT])dnl + AC_DEFINE_UNQUOTED([LT_MODULE_EXT], ["$libltdl_cv_shlibext"], + [Define to the extension used for runtime loadable modules, say, ".so".]) +fi +])# LT_SYS_MODULE_EXT + +# Old name: +AU_ALIAS([AC_LTDL_SHLIBEXT], [LT_SYS_MODULE_EXT]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LTDL_SHLIBEXT], []) + + +# LT_SYS_MODULE_PATH +# ------------------ +AC_DEFUN([LT_SYS_MODULE_PATH], +[m4_require([_LT_SYS_DYNAMIC_LINKER])dnl +AC_CACHE_CHECK([which variable specifies run-time module search path], + [lt_cv_module_path_var], [lt_cv_module_path_var="$shlibpath_var"]) +if test -n "$lt_cv_module_path_var"; then + m4_pattern_allow([LT_MODULE_PATH_VAR])dnl + AC_DEFINE_UNQUOTED([LT_MODULE_PATH_VAR], ["$lt_cv_module_path_var"], + [Define to the name of the environment variable that determines the run-time module search path.]) +fi +])# LT_SYS_MODULE_PATH + +# Old name: +AU_ALIAS([AC_LTDL_SHLIBPATH], [LT_SYS_MODULE_PATH]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LTDL_SHLIBPATH], []) + + +# LT_SYS_DLSEARCH_PATH +# -------------------- +AC_DEFUN([LT_SYS_DLSEARCH_PATH], +[m4_require([_LT_SYS_DYNAMIC_LINKER])dnl +AC_CACHE_CHECK([for the default library search path], + [lt_cv_sys_dlsearch_path], + [lt_cv_sys_dlsearch_path="$sys_lib_dlsearch_path_spec"]) +if test -n "$lt_cv_sys_dlsearch_path"; then + sys_dlsearch_path= + for dir in $lt_cv_sys_dlsearch_path; do + if test -z "$sys_dlsearch_path"; then + sys_dlsearch_path="$dir" + else + sys_dlsearch_path="$sys_dlsearch_path$PATH_SEPARATOR$dir" + fi + done + m4_pattern_allow([LT_DLSEARCH_PATH])dnl + AC_DEFINE_UNQUOTED([LT_DLSEARCH_PATH], ["$sys_dlsearch_path"], + [Define to the system default library search path.]) +fi +])# LT_SYS_DLSEARCH_PATH + +# Old name: +AU_ALIAS([AC_LTDL_SYSSEARCHPATH], [LT_SYS_DLSEARCH_PATH]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LTDL_SYSSEARCHPATH], []) + + +# _LT_CHECK_DLPREOPEN +# ------------------- +m4_defun([_LT_CHECK_DLPREOPEN], +[m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl +AC_CACHE_CHECK([whether libtool supports -dlopen/-dlpreopen], + [libltdl_cv_preloaded_symbols], + [if test -n "$lt_cv_sys_global_symbol_pipe"; then + libltdl_cv_preloaded_symbols=yes + else + libltdl_cv_preloaded_symbols=no + fi + ]) +if test x"$libltdl_cv_preloaded_symbols" = xyes; then + AC_DEFINE([HAVE_PRELOADED_SYMBOLS], [1], + [Define if libtool can extract symbol lists from object files.]) +fi +])# _LT_CHECK_DLPREOPEN + + +# LT_LIB_DLLOAD +# ------------- +AC_DEFUN([LT_LIB_DLLOAD], +[m4_pattern_allow([^LT_DLLOADERS$]) +LT_DLLOADERS= +AC_SUBST([LT_DLLOADERS]) + +AC_LANG_PUSH([C]) + +LIBADD_DLOPEN= +AC_SEARCH_LIBS([dlopen], [dl], + [AC_DEFINE([HAVE_LIBDL], [1], + [Define if you have the libdl library or equivalent.]) + if test "$ac_cv_search_dlopen" != "none required" ; then + LIBADD_DLOPEN="-ldl" + fi + libltdl_cv_lib_dl_dlopen="yes" + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dlopen.la"], + [AC_LINK_IFELSE([AC_LANG_PROGRAM([[#if HAVE_DLFCN_H +# include +#endif + ]], [[dlopen(0, 0);]])], + [AC_DEFINE([HAVE_LIBDL], [1], + [Define if you have the libdl library or equivalent.]) + libltdl_cv_func_dlopen="yes" + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dlopen.la"], + [AC_CHECK_LIB([svld], [dlopen], + [AC_DEFINE([HAVE_LIBDL], [1], + [Define if you have the libdl library or equivalent.]) + LIBADD_DLOPEN="-lsvld" libltdl_cv_func_dlopen="yes" + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dlopen.la"])])]) +if test x"$libltdl_cv_func_dlopen" = xyes || test x"$libltdl_cv_lib_dl_dlopen" = xyes +then + lt_save_LIBS="$LIBS" + LIBS="$LIBS $LIBADD_DLOPEN" + AC_CHECK_FUNCS([dlerror]) + LIBS="$lt_save_LIBS" +fi +AC_SUBST([LIBADD_DLOPEN]) + +LIBADD_SHL_LOAD= +AC_CHECK_FUNC([shl_load], + [AC_DEFINE([HAVE_SHL_LOAD], [1], + [Define if you have the shl_load function.]) + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}shl_load.la"], + [AC_CHECK_LIB([dld], [shl_load], + [AC_DEFINE([HAVE_SHL_LOAD], [1], + [Define if you have the shl_load function.]) + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}shl_load.la" + LIBADD_SHL_LOAD="-ldld"])]) +AC_SUBST([LIBADD_SHL_LOAD]) + +case $host_os in +darwin[[1567]].*) +# We only want this for pre-Mac OS X 10.4. + AC_CHECK_FUNC([_dyld_func_lookup], + [AC_DEFINE([HAVE_DYLD], [1], + [Define if you have the _dyld_func_lookup function.]) + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dyld.la"]) + ;; +beos*) + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}load_add_on.la" + ;; +cygwin* | mingw* | os2* | pw32*) + AC_CHECK_DECLS([cygwin_conv_path], [], [], [[#include ]]) + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}loadlibrary.la" + ;; +esac + +AC_CHECK_LIB([dld], [dld_link], + [AC_DEFINE([HAVE_DLD], [1], + [Define if you have the GNU dld library.]) + LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dld_link.la"]) +AC_SUBST([LIBADD_DLD_LINK]) + +m4_pattern_allow([^LT_DLPREOPEN$]) +LT_DLPREOPEN= +if test -n "$LT_DLLOADERS" +then + for lt_loader in $LT_DLLOADERS; do + LT_DLPREOPEN="$LT_DLPREOPEN-dlpreopen $lt_loader " + done + AC_DEFINE([HAVE_LIBDLLOADER], [1], + [Define if libdlloader will be built on this platform]) +fi +AC_SUBST([LT_DLPREOPEN]) + +dnl This isn't used anymore, but set it for backwards compatibility +LIBADD_DL="$LIBADD_DLOPEN $LIBADD_SHL_LOAD" +AC_SUBST([LIBADD_DL]) + +AC_LANG_POP +])# LT_LIB_DLLOAD + +# Old name: +AU_ALIAS([AC_LTDL_DLLIB], [LT_LIB_DLLOAD]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LTDL_DLLIB], []) + + +# LT_SYS_SYMBOL_USCORE +# -------------------- +# does the compiler prefix global symbols with an underscore? +AC_DEFUN([LT_SYS_SYMBOL_USCORE], +[m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl +AC_CACHE_CHECK([for _ prefix in compiled symbols], + [lt_cv_sys_symbol_underscore], + [lt_cv_sys_symbol_underscore=no + cat > conftest.$ac_ext <<_LT_EOF +void nm_test_func(){} +int main(){nm_test_func;return 0;} +_LT_EOF + if AC_TRY_EVAL(ac_compile); then + # Now try to grab the symbols. + ac_nlist=conftest.nm + if AC_TRY_EVAL(NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $ac_nlist) && test -s "$ac_nlist"; then + # See whether the symbols have a leading underscore. + if grep '^. _nm_test_func' "$ac_nlist" >/dev/null; then + lt_cv_sys_symbol_underscore=yes + else + if grep '^. nm_test_func ' "$ac_nlist" >/dev/null; then + : + else + echo "configure: cannot find nm_test_func in $ac_nlist" >&AS_MESSAGE_LOG_FD + fi + fi + else + echo "configure: cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD + fi + else + echo "configure: failed program was:" >&AS_MESSAGE_LOG_FD + cat conftest.c >&AS_MESSAGE_LOG_FD + fi + rm -rf conftest* + ]) + sys_symbol_underscore=$lt_cv_sys_symbol_underscore + AC_SUBST([sys_symbol_underscore]) +])# LT_SYS_SYMBOL_USCORE + +# Old name: +AU_ALIAS([AC_LTDL_SYMBOL_USCORE], [LT_SYS_SYMBOL_USCORE]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LTDL_SYMBOL_USCORE], []) + + +# LT_FUNC_DLSYM_USCORE +# -------------------- +AC_DEFUN([LT_FUNC_DLSYM_USCORE], +[AC_REQUIRE([LT_SYS_SYMBOL_USCORE])dnl +if test x"$lt_cv_sys_symbol_underscore" = xyes; then + if test x"$libltdl_cv_func_dlopen" = xyes || + test x"$libltdl_cv_lib_dl_dlopen" = xyes ; then + AC_CACHE_CHECK([whether we have to add an underscore for dlsym], + [libltdl_cv_need_uscore], + [libltdl_cv_need_uscore=unknown + save_LIBS="$LIBS" + LIBS="$LIBS $LIBADD_DLOPEN" + _LT_TRY_DLOPEN_SELF( + [libltdl_cv_need_uscore=no], [libltdl_cv_need_uscore=yes], + [], [libltdl_cv_need_uscore=cross]) + LIBS="$save_LIBS" + ]) + fi +fi + +if test x"$libltdl_cv_need_uscore" = xyes; then + AC_DEFINE([NEED_USCORE], [1], + [Define if dlsym() requires a leading underscore in symbol names.]) +fi +])# LT_FUNC_DLSYM_USCORE + +# Old name: +AU_ALIAS([AC_LTDL_DLSYM_USCORE], [LT_FUNC_DLSYM_USCORE]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LTDL_DLSYM_USCORE], []) + diff --git a/Externals/SDL/acinclude/ltoptions.m4 b/Externals/SDL/acinclude/ltoptions.m4 new file mode 100644 index 0000000000..d4df679195 --- /dev/null +++ b/Externals/SDL/acinclude/ltoptions.m4 @@ -0,0 +1,370 @@ +############################################################################## +# Helper functions for option handling. -*- Autoconf -*- +# +# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc. +# Written by Gary V. Vaughan, 2004 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# serial 6 ltoptions.m4 + +# This is to help aclocal find these macros, as it can't see m4_define. +AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])]) + + +# _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME) +# ------------------------------------------ +m4_define([_LT_MANGLE_OPTION], +[[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])]) + + +# _LT_SET_OPTION(MACRO-NAME, OPTION-NAME) +# --------------------------------------- +# Set option OPTION-NAME for macro MACRO-NAME, and if there is a +# matching handler defined, dispatch to it. Other OPTION-NAMEs are +# saved as a flag. +m4_define([_LT_SET_OPTION], +[m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl +m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]), + _LT_MANGLE_DEFUN([$1], [$2]), + [m4_warning([Unknown $1 option `$2'])])[]dnl +]) + + +# _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET]) +# ------------------------------------------------------------ +# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. +m4_define([_LT_IF_OPTION], +[m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])]) + + +# _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET) +# ------------------------------------------------------- +# Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME +# are set. +m4_define([_LT_UNLESS_OPTIONS], +[m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), + [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option), + [m4_define([$0_found])])])[]dnl +m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3 +])[]dnl +]) + + +# _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST) +# ---------------------------------------- +# OPTION-LIST is a space-separated list of Libtool options associated +# with MACRO-NAME. If any OPTION has a matching handler declared with +# LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about +# the unknown option and exit. +m4_defun([_LT_SET_OPTIONS], +[# Set options +m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), + [_LT_SET_OPTION([$1], _LT_Option)]) + +m4_if([$1],[LT_INIT],[ + dnl + dnl Simply set some default values (i.e off) if boolean options were not + dnl specified: + _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no + ]) + _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no + ]) + dnl + dnl If no reference was made to various pairs of opposing options, then + dnl we run the default mode handler for the pair. For example, if neither + dnl `shared' nor `disable-shared' was passed, we enable building of shared + dnl archives by default: + _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED]) + _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC]) + _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC]) + _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install], + [_LT_ENABLE_FAST_INSTALL]) + ]) +])# _LT_SET_OPTIONS + + +## --------------------------------- ## +## Macros to handle LT_INIT options. ## +## --------------------------------- ## + +# _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME) +# ----------------------------------------- +m4_define([_LT_MANGLE_DEFUN], +[[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])]) + + +# LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE) +# ----------------------------------------------- +m4_define([LT_OPTION_DEFINE], +[m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl +])# LT_OPTION_DEFINE + + +# dlopen +# ------ +LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes +]) + +AU_DEFUN([AC_LIBTOOL_DLOPEN], +[_LT_SET_OPTION([LT_INIT], [dlopen]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you +put the `dlopen' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], []) + + +# win32-dll +# --------- +# Declare package support for building win32 dll's. +LT_OPTION_DEFINE([LT_INIT], [win32-dll], +[enable_win32_dll=yes + +case $host in +*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-cegcc*) + AC_CHECK_TOOL(AS, as, false) + AC_CHECK_TOOL(DLLTOOL, dlltool, false) + AC_CHECK_TOOL(OBJDUMP, objdump, false) + ;; +esac + +test -z "$AS" && AS=as +_LT_DECL([], [AS], [0], [Assembler program])dnl + +test -z "$DLLTOOL" && DLLTOOL=dlltool +_LT_DECL([], [DLLTOOL], [0], [DLL creation program])dnl + +test -z "$OBJDUMP" && OBJDUMP=objdump +_LT_DECL([], [OBJDUMP], [0], [Object dumper program])dnl +])# win32-dll + +AU_DEFUN([AC_LIBTOOL_WIN32_DLL], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +_LT_SET_OPTION([LT_INIT], [win32-dll]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you +put the `win32-dll' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], []) + + +# _LT_ENABLE_SHARED([DEFAULT]) +# ---------------------------- +# implement the --enable-shared flag, and supports the `shared' and +# `disable-shared' LT_INIT options. +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +m4_define([_LT_ENABLE_SHARED], +[m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl +AC_ARG_ENABLE([shared], + [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@], + [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_shared=yes ;; + no) enable_shared=no ;; + *) + enable_shared=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_shared=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_shared=]_LT_ENABLE_SHARED_DEFAULT) + + _LT_DECL([build_libtool_libs], [enable_shared], [0], + [Whether or not to build shared libraries]) +])# _LT_ENABLE_SHARED + +LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])]) +LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])]) + +# Old names: +AC_DEFUN([AC_ENABLE_SHARED], +[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared]) +]) + +AC_DEFUN([AC_DISABLE_SHARED], +[_LT_SET_OPTION([LT_INIT], [disable-shared]) +]) + +AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) +AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AM_ENABLE_SHARED], []) +dnl AC_DEFUN([AM_DISABLE_SHARED], []) + + + +# _LT_ENABLE_STATIC([DEFAULT]) +# ---------------------------- +# implement the --enable-static flag, and support the `static' and +# `disable-static' LT_INIT options. +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +m4_define([_LT_ENABLE_STATIC], +[m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl +AC_ARG_ENABLE([static], + [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@], + [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_static=yes ;; + no) enable_static=no ;; + *) + enable_static=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_static=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_static=]_LT_ENABLE_STATIC_DEFAULT) + + _LT_DECL([build_old_libs], [enable_static], [0], + [Whether or not to build static libraries]) +])# _LT_ENABLE_STATIC + +LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])]) +LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])]) + +# Old names: +AC_DEFUN([AC_ENABLE_STATIC], +[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static]) +]) + +AC_DEFUN([AC_DISABLE_STATIC], +[_LT_SET_OPTION([LT_INIT], [disable-static]) +]) + +AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) +AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AM_ENABLE_STATIC], []) +dnl AC_DEFUN([AM_DISABLE_STATIC], []) + + + +# _LT_ENABLE_FAST_INSTALL([DEFAULT]) +# ---------------------------------- +# implement the --enable-fast-install flag, and support the `fast-install' +# and `disable-fast-install' LT_INIT options. +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +m4_define([_LT_ENABLE_FAST_INSTALL], +[m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl +AC_ARG_ENABLE([fast-install], + [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], + [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_fast_install=yes ;; + no) enable_fast_install=no ;; + *) + enable_fast_install=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_fast_install=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT) + +_LT_DECL([fast_install], [enable_fast_install], [0], + [Whether or not to optimize for fast installation])dnl +])# _LT_ENABLE_FAST_INSTALL + +LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])]) +LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])]) + +# Old names: +AU_DEFUN([AC_ENABLE_FAST_INSTALL], +[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you put +the `fast-install' option into LT_INIT's first parameter.]) +]) + +AU_DEFUN([AC_DISABLE_FAST_INSTALL], +[_LT_SET_OPTION([LT_INIT], [disable-fast-install]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you put +the `disable-fast-install' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], []) +dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], []) + + +# _LT_WITH_PIC([MODE]) +# -------------------- +# implement the --with-pic flag, and support the `pic-only' and `no-pic' +# LT_INIT options. +# MODE is either `yes' or `no'. If omitted, it defaults to `both'. +m4_define([_LT_WITH_PIC], +[AC_ARG_WITH([pic], + [AS_HELP_STRING([--with-pic], + [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], + [pic_mode="$withval"], + [pic_mode=default]) + +test -z "$pic_mode" && pic_mode=m4_default([$1], [default]) + +_LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl +])# _LT_WITH_PIC + +LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])]) +LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])]) + +# Old name: +AU_DEFUN([AC_LIBTOOL_PICMODE], +[_LT_SET_OPTION([LT_INIT], [pic-only]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you +put the `pic-only' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_PICMODE], []) + +## ----------------- ## +## LTDL_INIT Options ## +## ----------------- ## + +m4_define([_LTDL_MODE], []) +LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive], + [m4_define([_LTDL_MODE], [nonrecursive])]) +LT_OPTION_DEFINE([LTDL_INIT], [recursive], + [m4_define([_LTDL_MODE], [recursive])]) +LT_OPTION_DEFINE([LTDL_INIT], [subproject], + [m4_define([_LTDL_MODE], [subproject])]) + +m4_define([_LTDL_TYPE], []) +LT_OPTION_DEFINE([LTDL_INIT], [installable], + [m4_define([_LTDL_TYPE], [installable])]) +LT_OPTION_DEFINE([LTDL_INIT], [convenience], + [m4_define([_LTDL_TYPE], [convenience])]) + diff --git a/Externals/SDL/acinclude/ltsugar.m4 b/Externals/SDL/acinclude/ltsugar.m4 new file mode 100644 index 0000000000..02a939d819 --- /dev/null +++ b/Externals/SDL/acinclude/ltsugar.m4 @@ -0,0 +1,125 @@ +############################################################################## +# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- +# +# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc. +# Written by Gary V. Vaughan, 2004 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# serial 6 ltsugar.m4 + +# This is to help aclocal find these macros, as it can't see m4_define. +AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])]) + + +# lt_join(SEP, ARG1, [ARG2...]) +# ----------------------------- +# Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their +# associated separator. +# Needed until we can rely on m4_join from Autoconf 2.62, since all earlier +# versions in m4sugar had bugs. +m4_define([lt_join], +[m4_if([$#], [1], [], + [$#], [2], [[$2]], + [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])]) +m4_define([_lt_join], +[m4_if([$#$2], [2], [], + [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])]) + + +# lt_car(LIST) +# lt_cdr(LIST) +# ------------ +# Manipulate m4 lists. +# These macros are necessary as long as will still need to support +# Autoconf-2.59 which quotes differently. +m4_define([lt_car], [[$1]]) +m4_define([lt_cdr], +[m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], + [$#], 1, [], + [m4_dquote(m4_shift($@))])]) +m4_define([lt_unquote], $1) + + +# lt_append(MACRO-NAME, STRING, [SEPARATOR]) +# ------------------------------------------ +# Redefine MACRO-NAME to hold its former content plus `SEPARATOR'`STRING'. +# Note that neither SEPARATOR nor STRING are expanded; they are appended +# to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked). +# No SEPARATOR is output if MACRO-NAME was previously undefined (different +# than defined and empty). +# +# This macro is needed until we can rely on Autoconf 2.62, since earlier +# versions of m4sugar mistakenly expanded SEPARATOR but not STRING. +m4_define([lt_append], +[m4_define([$1], + m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])]) + + + +# lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...]) +# ---------------------------------------------------------- +# Produce a SEP delimited list of all paired combinations of elements of +# PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list +# has the form PREFIXmINFIXSUFFIXn. +# Needed until we can rely on m4_combine added in Autoconf 2.62. +m4_define([lt_combine], +[m4_if(m4_eval([$# > 3]), [1], + [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl +[[m4_foreach([_Lt_prefix], [$2], + [m4_foreach([_Lt_suffix], + ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[, + [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])]) + + +# lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ]) +# ----------------------------------------------------------------------- +# Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited +# by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ. +m4_define([lt_if_append_uniq], +[m4_ifdef([$1], + [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1], + [lt_append([$1], [$2], [$3])$4], + [$5])], + [lt_append([$1], [$2], [$3])$4])]) + + +# lt_dict_add(DICT, KEY, VALUE) +# ----------------------------- +m4_define([lt_dict_add], +[m4_define([$1($2)], [$3])]) + + +# lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE) +# -------------------------------------------- +m4_define([lt_dict_add_subkey], +[m4_define([$1($2:$3)], [$4])]) + + +# lt_dict_fetch(DICT, KEY, [SUBKEY]) +# ---------------------------------- +m4_define([lt_dict_fetch], +[m4_ifval([$3], + m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]), + m4_ifdef([$1($2)], [m4_defn([$1($2)])]))]) + + +# lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE]) +# ----------------------------------------------------------------- +m4_define([lt_if_dict_fetch], +[m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4], + [$5], + [$6])]) + + +# lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...]) +# -------------------------------------------------------------- +m4_define([lt_dict_filter], +[m4_if([$5], [], [], + [lt_join(m4_quote(m4_default([$4], [[, ]])), + lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]), + [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl +]) + diff --git a/Externals/SDL/acinclude/ltversion.m4 b/Externals/SDL/acinclude/ltversion.m4 new file mode 100644 index 0000000000..83a83f20ad --- /dev/null +++ b/Externals/SDL/acinclude/ltversion.m4 @@ -0,0 +1,25 @@ +############################################################################## +# ltversion.m4 -- version numbers -*- Autoconf -*- +# +# Copyright (C) 2004 Free Software Foundation, Inc. +# Written by Scott James Remnant, 2004 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# Generated from ltversion.in. + +# serial 3012 ltversion.m4 +# This file is part of GNU Libtool + +m4_define([LT_PACKAGE_VERSION], [2.2.6]) +m4_define([LT_PACKAGE_REVISION], [1.3012]) + +AC_DEFUN([LTVERSION_VERSION], +[macro_version='2.2.6' +macro_revision='1.3012' +_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?]) +_LT_DECL(, macro_revision, 0) +]) + diff --git a/Externals/SDL/acinclude/lt~obsolete.m4 b/Externals/SDL/acinclude/lt~obsolete.m4 new file mode 100644 index 0000000000..3b2acd4d00 --- /dev/null +++ b/Externals/SDL/acinclude/lt~obsolete.m4 @@ -0,0 +1,93 @@ +############################################################################## +# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- +# +# Copyright (C) 2004, 2005, 2007 Free Software Foundation, Inc. +# Written by Scott James Remnant, 2004. +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# serial 4 lt~obsolete.m4 + +# These exist entirely to fool aclocal when bootstrapping libtool. +# +# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN) +# which have later been changed to m4_define as they aren't part of the +# exported API, or moved to Autoconf or Automake where they belong. +# +# The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN +# in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us +# using a macro with the same name in our local m4/libtool.m4 it'll +# pull the old libtool.m4 in (it doesn't see our shiny new m4_define +# and doesn't know about Autoconf macros at all.) +# +# So we provide this file, which has a silly filename so it's always +# included after everything else. This provides aclocal with the +# AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything +# because those macros already exist, or will be overwritten later. +# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. +# +# Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here. +# Yes, that means every name once taken will need to remain here until +# we give up compatibility with versions before 1.7, at which point +# we need to keep only those names which we still refer to. + +# This is to help aclocal find these macros, as it can't see m4_define. +AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])]) + +m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])]) +m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])]) +m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])]) +m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])]) +m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])]) +m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])]) +m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])]) +m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])]) +m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])]) +m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])]) +m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])]) +m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])]) +m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])]) +m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])]) +m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])]) +m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])]) +m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])]) +m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])]) +m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])]) +m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])]) +m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])]) +m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])]) +m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])]) +m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])]) +m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])]) +m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])]) +m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])]) +m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])]) +m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])]) +m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])]) +m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])]) +m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])]) +m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])]) +m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])]) +m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])]) +m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])]) +m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])]) +m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])]) +m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])]) +m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])]) +m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])]) +m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])]) +m4_ifndef([AC_LIBTOOL_RC], [AC_DEFUN([AC_LIBTOOL_RC])]) +m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])]) +m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])]) +m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])]) +m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])]) +m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])]) +m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])]) +m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])]) +m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])]) diff --git a/Externals/SDL/autogen.sh b/Externals/SDL/autogen.sh new file mode 100755 index 0000000000..649d7b31e9 --- /dev/null +++ b/Externals/SDL/autogen.sh @@ -0,0 +1,19 @@ +#!/bin/sh +# +echo "Generating build information using autoconf" +echo "This may take a while ..." + +# Regenerate configuration files +cat acinclude/* >aclocal.m4 +found=false +for autoconf in autoconf autoconf259 autoconf-2.59 +do if which $autoconf >/dev/null 2>&1; then $autoconf && found=true; break; fi +done +if test x$found = xfalse; then + echo "Couldn't find autoconf, aborting" + exit 1 +fi +(cd test; sh autogen.sh) + +# Run configure for this platform +echo "Now you are ready to run ./configure" diff --git a/Externals/SDL/build-scripts/config.guess b/Externals/SDL/build-scripts/config.guess new file mode 100755 index 0000000000..e792aac608 --- /dev/null +++ b/Externals/SDL/build-scripts/config.guess @@ -0,0 +1,1494 @@ +#! /bin/sh +# Attempt to guess a canonical system name. +# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, +# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 +# Free Software Foundation, Inc. + +timestamp='2009-09-18' + +# This file is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA +# 02110-1301, USA. +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + + +# Originally written by Per Bothner. Please send patches (context +# diff format) to and include a ChangeLog +# entry. +# +# This script attempts to guess a canonical system name similar to +# config.sub. If it succeeds, it prints the system name on stdout, and +# exits with 0. Otherwise, it exits with 1. +# +# You can get the latest version of this script from: +# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD + +me=`echo "$0" | sed -e 's,.*/,,'` + +usage="\ +Usage: $0 [OPTION] + +Output the configuration name of the system \`$me' is run on. + +Operation modes: + -h, --help print this help, then exit + -t, --time-stamp print date of last modification, then exit + -v, --version print version number, then exit + +Report bugs and patches to ." + +version="\ +GNU config.guess ($timestamp) + +Originally written by Per Bothner. +Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, +2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. + +This is free software; see the source for copying conditions. There is NO +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + +help=" +Try \`$me --help' for more information." + +# Parse command line +while test $# -gt 0 ; do + case $1 in + --time-stamp | --time* | -t ) + echo "$timestamp" ; exit ;; + --version | -v ) + echo "$version" ; exit ;; + --help | --h* | -h ) + echo "$usage"; exit ;; + -- ) # Stop option processing + shift; break ;; + - ) # Use stdin as input. + break ;; + -* ) + echo "$me: invalid option $1$help" >&2 + exit 1 ;; + * ) + break ;; + esac +done + +if test $# != 0; then + echo "$me: too many arguments$help" >&2 + exit 1 +fi + +trap 'exit 1' 1 2 15 + +# CC_FOR_BUILD -- compiler used by this script. Note that the use of a +# compiler to aid in system detection is discouraged as it requires +# temporary files to be created and, as you can see below, it is a +# headache to deal with in a portable fashion. + +# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still +# use `HOST_CC' if defined, but it is deprecated. + +# Portable tmp directory creation inspired by the Autoconf team. + +set_cc_for_build=' +trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; +trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; +: ${TMPDIR=/tmp} ; + { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || + { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || + { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || + { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; +dummy=$tmp/dummy ; +tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; +case $CC_FOR_BUILD,$HOST_CC,$CC in + ,,) echo "int x;" > $dummy.c ; + for c in cc gcc c89 c99 ; do + if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then + CC_FOR_BUILD="$c"; break ; + fi ; + done ; + if test x"$CC_FOR_BUILD" = x ; then + CC_FOR_BUILD=no_compiler_found ; + fi + ;; + ,,*) CC_FOR_BUILD=$CC ;; + ,*,*) CC_FOR_BUILD=$HOST_CC ;; +esac ; set_cc_for_build= ;' + +# This is needed to find uname on a Pyramid OSx when run in the BSD universe. +# (ghazi@noc.rutgers.edu 1994-08-24) +if (test -f /.attbin/uname) >/dev/null 2>&1 ; then + PATH=$PATH:/.attbin ; export PATH +fi + +UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown +UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown +UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown +UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown + +# Note: order is significant - the case branches are not exclusive. + +case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in + *:NetBSD:*:*) + # NetBSD (nbsd) targets should (where applicable) match one or + # more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*, + # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently + # switched to ELF, *-*-netbsd* would select the old + # object file format. This provides both forward + # compatibility and a consistent mechanism for selecting the + # object file format. + # + # Note: NetBSD doesn't particularly care about the vendor + # portion of the name. We always set it to "unknown". + sysctl="sysctl -n hw.machine_arch" + UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \ + /usr/sbin/$sysctl 2>/dev/null || echo unknown)` + case "${UNAME_MACHINE_ARCH}" in + armeb) machine=armeb-unknown ;; + arm*) machine=arm-unknown ;; + sh3el) machine=shl-unknown ;; + sh3eb) machine=sh-unknown ;; + sh5el) machine=sh5le-unknown ;; + *) machine=${UNAME_MACHINE_ARCH}-unknown ;; + esac + # The Operating System including object format, if it has switched + # to ELF recently, or will in the future. + case "${UNAME_MACHINE_ARCH}" in + arm*|i386|m68k|ns32k|sh3*|sparc|vax) + eval $set_cc_for_build + if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep -q __ELF__ + then + # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). + # Return netbsd for either. FIX? + os=netbsd + else + os=netbsdelf + fi + ;; + *) + os=netbsd + ;; + esac + # The OS release + # Debian GNU/NetBSD machines have a different userland, and + # thus, need a distinct triplet. However, they do not need + # kernel version information, so it can be replaced with a + # suitable tag, in the style of linux-gnu. + case "${UNAME_VERSION}" in + Debian*) + release='-gnu' + ;; + *) + release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` + ;; + esac + # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: + # contains redundant information, the shorter form: + # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. + echo "${machine}-${os}${release}" + exit ;; + *:OpenBSD:*:*) + UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` + echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} + exit ;; + *:ekkoBSD:*:*) + echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} + exit ;; + *:SolidBSD:*:*) + echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} + exit ;; + macppc:MirBSD:*:*) + echo powerpc-unknown-mirbsd${UNAME_RELEASE} + exit ;; + *:MirBSD:*:*) + echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} + exit ;; + alpha:OSF1:*:*) + case $UNAME_RELEASE in + *4.0) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` + ;; + *5.*) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` + ;; + esac + # According to Compaq, /usr/sbin/psrinfo has been available on + # OSF/1 and Tru64 systems produced since 1995. I hope that + # covers most systems running today. This code pipes the CPU + # types through head -n 1, so we only detect the type of CPU 0. + ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` + case "$ALPHA_CPU_TYPE" in + "EV4 (21064)") + UNAME_MACHINE="alpha" ;; + "EV4.5 (21064)") + UNAME_MACHINE="alpha" ;; + "LCA4 (21066/21068)") + UNAME_MACHINE="alpha" ;; + "EV5 (21164)") + UNAME_MACHINE="alphaev5" ;; + "EV5.6 (21164A)") + UNAME_MACHINE="alphaev56" ;; + "EV5.6 (21164PC)") + UNAME_MACHINE="alphapca56" ;; + "EV5.7 (21164PC)") + UNAME_MACHINE="alphapca57" ;; + "EV6 (21264)") + UNAME_MACHINE="alphaev6" ;; + "EV6.7 (21264A)") + UNAME_MACHINE="alphaev67" ;; + "EV6.8CB (21264C)") + UNAME_MACHINE="alphaev68" ;; + "EV6.8AL (21264B)") + UNAME_MACHINE="alphaev68" ;; + "EV6.8CX (21264D)") + UNAME_MACHINE="alphaev68" ;; + "EV6.9A (21264/EV69A)") + UNAME_MACHINE="alphaev69" ;; + "EV7 (21364)") + UNAME_MACHINE="alphaev7" ;; + "EV7.9 (21364A)") + UNAME_MACHINE="alphaev79" ;; + esac + # A Pn.n version is a patched version. + # A Vn.n version is a released version. + # A Tn.n version is a released field test version. + # A Xn.n version is an unreleased experimental baselevel. + # 1.2 uses "1.2" for uname -r. + echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` + exit ;; + Alpha\ *:Windows_NT*:*) + # How do we know it's Interix rather than the generic POSIX subsystem? + # Should we change UNAME_MACHINE based on the output of uname instead + # of the specific Alpha model? + echo alpha-pc-interix + exit ;; + 21064:Windows_NT:50:3) + echo alpha-dec-winnt3.5 + exit ;; + Amiga*:UNIX_System_V:4.0:*) + echo m68k-unknown-sysv4 + exit ;; + *:[Aa]miga[Oo][Ss]:*:*) + echo ${UNAME_MACHINE}-unknown-amigaos + exit ;; + *:[Mm]orph[Oo][Ss]:*:*) + echo ${UNAME_MACHINE}-unknown-morphos + exit ;; + *:OS/390:*:*) + echo i370-ibm-openedition + exit ;; + *:z/VM:*:*) + echo s390-ibm-zvmoe + exit ;; + *:OS400:*:*) + echo powerpc-ibm-os400 + exit ;; + arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) + echo arm-acorn-riscix${UNAME_RELEASE} + exit ;; + arm:riscos:*:*|arm:RISCOS:*:*) + echo arm-unknown-riscos + exit ;; + SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) + echo hppa1.1-hitachi-hiuxmpp + exit ;; + Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) + # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. + if test "`(/bin/universe) 2>/dev/null`" = att ; then + echo pyramid-pyramid-sysv3 + else + echo pyramid-pyramid-bsd + fi + exit ;; + NILE*:*:*:dcosx) + echo pyramid-pyramid-svr4 + exit ;; + DRS?6000:unix:4.0:6*) + echo sparc-icl-nx6 + exit ;; + DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) + case `/usr/bin/uname -p` in + sparc) echo sparc-icl-nx7; exit ;; + esac ;; + s390x:SunOS:*:*) + echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4H:SunOS:5.*:*) + echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) + echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) + eval $set_cc_for_build + SUN_ARCH="i386" + # If there is a compiler, see if it is configured for 64-bit objects. + # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. + # This test works for both compilers. + if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then + if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ + (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ + grep IS_64BIT_ARCH >/dev/null + then + SUN_ARCH="x86_64" + fi + fi + echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:6*:*) + # According to config.sub, this is the proper way to canonicalize + # SunOS6. Hard to guess exactly what SunOS6 will be like, but + # it's likely to be more like Solaris than SunOS4. + echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:*:*) + case "`/usr/bin/arch -k`" in + Series*|S4*) + UNAME_RELEASE=`uname -v` + ;; + esac + # Japanese Language versions have a version number like `4.1.3-JL'. + echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` + exit ;; + sun3*:SunOS:*:*) + echo m68k-sun-sunos${UNAME_RELEASE} + exit ;; + sun*:*:4.2BSD:*) + UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` + test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 + case "`/bin/arch`" in + sun3) + echo m68k-sun-sunos${UNAME_RELEASE} + ;; + sun4) + echo sparc-sun-sunos${UNAME_RELEASE} + ;; + esac + exit ;; + aushp:SunOS:*:*) + echo sparc-auspex-sunos${UNAME_RELEASE} + exit ;; + # The situation for MiNT is a little confusing. The machine name + # can be virtually everything (everything which is not + # "atarist" or "atariste" at least should have a processor + # > m68000). The system name ranges from "MiNT" over "FreeMiNT" + # to the lowercase version "mint" (or "freemint"). Finally + # the system name "TOS" denotes a system which is actually not + # MiNT. But MiNT is downward compatible to TOS, so this should + # be no problem. + atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) + echo m68k-milan-mint${UNAME_RELEASE} + exit ;; + hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) + echo m68k-hades-mint${UNAME_RELEASE} + exit ;; + *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) + echo m68k-unknown-mint${UNAME_RELEASE} + exit ;; + m68k:machten:*:*) + echo m68k-apple-machten${UNAME_RELEASE} + exit ;; + powerpc:machten:*:*) + echo powerpc-apple-machten${UNAME_RELEASE} + exit ;; + RISC*:Mach:*:*) + echo mips-dec-mach_bsd4.3 + exit ;; + RISC*:ULTRIX:*:*) + echo mips-dec-ultrix${UNAME_RELEASE} + exit ;; + VAX*:ULTRIX*:*:*) + echo vax-dec-ultrix${UNAME_RELEASE} + exit ;; + 2020:CLIX:*:* | 2430:CLIX:*:*) + echo clipper-intergraph-clix${UNAME_RELEASE} + exit ;; + mips:*:*:UMIPS | mips:*:*:RISCos) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c +#ifdef __cplusplus +#include /* for printf() prototype */ + int main (int argc, char *argv[]) { +#else + int main (argc, argv) int argc; char *argv[]; { +#endif + #if defined (host_mips) && defined (MIPSEB) + #if defined (SYSTYPE_SYSV) + printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_SVR4) + printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) + printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); + #endif + #endif + exit (-1); + } +EOF + $CC_FOR_BUILD -o $dummy $dummy.c && + dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && + SYSTEM_NAME=`$dummy $dummyarg` && + { echo "$SYSTEM_NAME"; exit; } + echo mips-mips-riscos${UNAME_RELEASE} + exit ;; + Motorola:PowerMAX_OS:*:*) + echo powerpc-motorola-powermax + exit ;; + Motorola:*:4.3:PL8-*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:Power_UNIX:*:*) + echo powerpc-harris-powerunix + exit ;; + m88k:CX/UX:7*:*) + echo m88k-harris-cxux7 + exit ;; + m88k:*:4*:R4*) + echo m88k-motorola-sysv4 + exit ;; + m88k:*:3*:R3*) + echo m88k-motorola-sysv3 + exit ;; + AViiON:dgux:*:*) + # DG/UX returns AViiON for all architectures + UNAME_PROCESSOR=`/usr/bin/uname -p` + if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] + then + if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ + [ ${TARGET_BINARY_INTERFACE}x = x ] + then + echo m88k-dg-dgux${UNAME_RELEASE} + else + echo m88k-dg-dguxbcs${UNAME_RELEASE} + fi + else + echo i586-dg-dgux${UNAME_RELEASE} + fi + exit ;; + M88*:DolphinOS:*:*) # DolphinOS (SVR3) + echo m88k-dolphin-sysv3 + exit ;; + M88*:*:R3*:*) + # Delta 88k system running SVR3 + echo m88k-motorola-sysv3 + exit ;; + XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) + echo m88k-tektronix-sysv3 + exit ;; + Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) + echo m68k-tektronix-bsd + exit ;; + *:IRIX*:*:*) + echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` + exit ;; + ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. + echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id + exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' + i*86:AIX:*:*) + echo i386-ibm-aix + exit ;; + ia64:AIX:*:*) + if [ -x /usr/bin/oslevel ] ; then + IBM_REV=`/usr/bin/oslevel` + else + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} + fi + echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} + exit ;; + *:AIX:2:3) + if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + + main() + { + if (!__power_pc()) + exit(1); + puts("powerpc-ibm-aix3.2.5"); + exit(0); + } +EOF + if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` + then + echo "$SYSTEM_NAME" + else + echo rs6000-ibm-aix3.2.5 + fi + elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then + echo rs6000-ibm-aix3.2.4 + else + echo rs6000-ibm-aix3.2 + fi + exit ;; + *:AIX:*:[456]) + IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` + if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then + IBM_ARCH=rs6000 + else + IBM_ARCH=powerpc + fi + if [ -x /usr/bin/oslevel ] ; then + IBM_REV=`/usr/bin/oslevel` + else + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} + fi + echo ${IBM_ARCH}-ibm-aix${IBM_REV} + exit ;; + *:AIX:*:*) + echo rs6000-ibm-aix + exit ;; + ibmrt:4.4BSD:*|romp-ibm:BSD:*) + echo romp-ibm-bsd4.4 + exit ;; + ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and + echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to + exit ;; # report: romp-ibm BSD 4.3 + *:BOSX:*:*) + echo rs6000-bull-bosx + exit ;; + DPX/2?00:B.O.S.:*:*) + echo m68k-bull-sysv3 + exit ;; + 9000/[34]??:4.3bsd:1.*:*) + echo m68k-hp-bsd + exit ;; + hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) + echo m68k-hp-bsd4.4 + exit ;; + 9000/[34678]??:HP-UX:*:*) + HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` + case "${UNAME_MACHINE}" in + 9000/31? ) HP_ARCH=m68000 ;; + 9000/[34]?? ) HP_ARCH=m68k ;; + 9000/[678][0-9][0-9]) + if [ -x /usr/bin/getconf ]; then + sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` + sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` + case "${sc_cpu_version}" in + 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 + 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 + 532) # CPU_PA_RISC2_0 + case "${sc_kernel_bits}" in + 32) HP_ARCH="hppa2.0n" ;; + 64) HP_ARCH="hppa2.0w" ;; + '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 + esac ;; + esac + fi + if [ "${HP_ARCH}" = "" ]; then + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + + #define _HPUX_SOURCE + #include + #include + + int main () + { + #if defined(_SC_KERNEL_BITS) + long bits = sysconf(_SC_KERNEL_BITS); + #endif + long cpu = sysconf (_SC_CPU_VERSION); + + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1"); break; + case CPU_PA_RISC2_0: + #if defined(_SC_KERNEL_BITS) + switch (bits) + { + case 64: puts ("hppa2.0w"); break; + case 32: puts ("hppa2.0n"); break; + default: puts ("hppa2.0"); break; + } break; + #else /* !defined(_SC_KERNEL_BITS) */ + puts ("hppa2.0"); break; + #endif + default: puts ("hppa1.0"); break; + } + exit (0); + } +EOF + (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` + test -z "$HP_ARCH" && HP_ARCH=hppa + fi ;; + esac + if [ ${HP_ARCH} = "hppa2.0w" ] + then + eval $set_cc_for_build + + # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating + # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler + # generating 64-bit code. GNU and HP use different nomenclature: + # + # $ CC_FOR_BUILD=cc ./config.guess + # => hppa2.0w-hp-hpux11.23 + # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess + # => hppa64-hp-hpux11.23 + + if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | + grep -q __LP64__ + then + HP_ARCH="hppa2.0w" + else + HP_ARCH="hppa64" + fi + fi + echo ${HP_ARCH}-hp-hpux${HPUX_REV} + exit ;; + ia64:HP-UX:*:*) + HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` + echo ia64-hp-hpux${HPUX_REV} + exit ;; + 3050*:HI-UX:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + int + main () + { + long cpu = sysconf (_SC_CPU_VERSION); + /* The order matters, because CPU_IS_HP_MC68K erroneously returns + true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct + results, however. */ + if (CPU_IS_PA_RISC (cpu)) + { + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; + case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; + default: puts ("hppa-hitachi-hiuxwe2"); break; + } + } + else if (CPU_IS_HP_MC68K (cpu)) + puts ("m68k-hitachi-hiuxwe2"); + else puts ("unknown-hitachi-hiuxwe2"); + exit (0); + } +EOF + $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && + { echo "$SYSTEM_NAME"; exit; } + echo unknown-hitachi-hiuxwe2 + exit ;; + 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) + echo hppa1.1-hp-bsd + exit ;; + 9000/8??:4.3bsd:*:*) + echo hppa1.0-hp-bsd + exit ;; + *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) + echo hppa1.0-hp-mpeix + exit ;; + hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) + echo hppa1.1-hp-osf + exit ;; + hp8??:OSF1:*:*) + echo hppa1.0-hp-osf + exit ;; + i*86:OSF1:*:*) + if [ -x /usr/sbin/sysversion ] ; then + echo ${UNAME_MACHINE}-unknown-osf1mk + else + echo ${UNAME_MACHINE}-unknown-osf1 + fi + exit ;; + parisc*:Lites*:*:*) + echo hppa1.1-hp-lites + exit ;; + C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) + echo c1-convex-bsd + exit ;; + C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) + if getsysinfo -f scalar_acc + then echo c32-convex-bsd + else echo c2-convex-bsd + fi + exit ;; + C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) + echo c34-convex-bsd + exit ;; + C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) + echo c38-convex-bsd + exit ;; + C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) + echo c4-convex-bsd + exit ;; + CRAY*Y-MP:*:*:*) + echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*[A-Z]90:*:*:*) + echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ + | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ + -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ + -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*TS:*:*:*) + echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*T3E:*:*:*) + echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*SV1:*:*:*) + echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + *:UNICOS/mp:*:*) + echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) + FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` + FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` + FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` + echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + 5000:UNIX_System_V:4.*:*) + FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` + FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` + echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) + echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} + exit ;; + sparc*:BSD/OS:*:*) + echo sparc-unknown-bsdi${UNAME_RELEASE} + exit ;; + *:BSD/OS:*:*) + echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} + exit ;; + *:FreeBSD:*:*) + case ${UNAME_MACHINE} in + pc98) + echo i386-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + amd64) + echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + *) + echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + esac + exit ;; + i*:CYGWIN*:*) + echo ${UNAME_MACHINE}-pc-cygwin + exit ;; + *:MINGW*:*) + echo ${UNAME_MACHINE}-pc-mingw32 + exit ;; + i*:windows32*:*) + # uname -m includes "-pc" on this system. + echo ${UNAME_MACHINE}-mingw32 + exit ;; + i*:PW*:*) + echo ${UNAME_MACHINE}-pc-pw32 + exit ;; + *:Interix*:[3456]*) + case ${UNAME_MACHINE} in + x86) + echo i586-pc-interix${UNAME_RELEASE} + exit ;; + EM64T | authenticamd | genuineintel) + echo x86_64-unknown-interix${UNAME_RELEASE} + exit ;; + IA64) + echo ia64-unknown-interix${UNAME_RELEASE} + exit ;; + esac ;; + [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) + echo i${UNAME_MACHINE}-pc-mks + exit ;; + 8664:Windows_NT:*) + echo x86_64-pc-mks + exit ;; + i*:Windows_NT*:* | Pentium*:Windows_NT*:*) + # How do we know it's Interix rather than the generic POSIX subsystem? + # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we + # UNAME_MACHINE based on the output of uname instead of i386? + echo i586-pc-interix + exit ;; + i*:UWIN*:*) + echo ${UNAME_MACHINE}-pc-uwin + exit ;; + amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) + echo x86_64-unknown-cygwin + exit ;; + p*:CYGWIN*:*) + echo powerpcle-unknown-cygwin + exit ;; + prep*:SunOS:5.*:*) + echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + *:GNU:*:*) + # the GNU system + echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` + exit ;; + *:GNU/*:*:*) + # other systems with GNU libc and userland + echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu + exit ;; + i*86:Minix:*:*) + echo ${UNAME_MACHINE}-pc-minix + exit ;; + alpha:Linux:*:*) + case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in + EV5) UNAME_MACHINE=alphaev5 ;; + EV56) UNAME_MACHINE=alphaev56 ;; + PCA56) UNAME_MACHINE=alphapca56 ;; + PCA57) UNAME_MACHINE=alphapca56 ;; + EV6) UNAME_MACHINE=alphaev6 ;; + EV67) UNAME_MACHINE=alphaev67 ;; + EV68*) UNAME_MACHINE=alphaev68 ;; + esac + objdump --private-headers /bin/sh | grep -q ld.so.1 + if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi + echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC} + exit ;; + arm*:Linux:*:*) + eval $set_cc_for_build + if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep -q __ARM_EABI__ + then + echo ${UNAME_MACHINE}-unknown-linux-gnu + else + echo ${UNAME_MACHINE}-unknown-linux-gnueabi + fi + exit ;; + avr32*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + cris:Linux:*:*) + echo cris-axis-linux-gnu + exit ;; + crisv32:Linux:*:*) + echo crisv32-axis-linux-gnu + exit ;; + frv:Linux:*:*) + echo frv-unknown-linux-gnu + exit ;; + i*86:Linux:*:*) + echo ${UNAME_MACHINE}-pc-linux-gnu + exit ;; + ia64:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + m32r*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + m68*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + mips:Linux:*:* | mips64:Linux:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #undef CPU + #undef ${UNAME_MACHINE} + #undef ${UNAME_MACHINE}el + #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) + CPU=${UNAME_MACHINE}el + #else + #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) + CPU=${UNAME_MACHINE} + #else + CPU= + #endif + #endif +EOF + eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' + /^CPU/{ + s: ::g + p + }'`" + test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } + ;; + or32:Linux:*:*) + echo or32-unknown-linux-gnu + exit ;; + padre:Linux:*:*) + echo sparc-unknown-linux-gnu + exit ;; + parisc64:Linux:*:* | hppa64:Linux:*:*) + echo hppa64-unknown-linux-gnu + exit ;; + parisc:Linux:*:* | hppa:Linux:*:*) + # Look for CPU level + case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in + PA7*) echo hppa1.1-unknown-linux-gnu ;; + PA8*) echo hppa2.0-unknown-linux-gnu ;; + *) echo hppa-unknown-linux-gnu ;; + esac + exit ;; + ppc64:Linux:*:*) + echo powerpc64-unknown-linux-gnu + exit ;; + ppc:Linux:*:*) + echo powerpc-unknown-linux-gnu + exit ;; + s390:Linux:*:* | s390x:Linux:*:*) + echo ${UNAME_MACHINE}-ibm-linux + exit ;; + sh64*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + sh*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + sparc:Linux:*:* | sparc64:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + vax:Linux:*:*) + echo ${UNAME_MACHINE}-dec-linux-gnu + exit ;; + x86_64:Linux:*:*) + echo x86_64-unknown-linux-gnu + exit ;; + xtensa*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + i*86:DYNIX/ptx:4*:*) + # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. + # earlier versions are messed up and put the nodename in both + # sysname and nodename. + echo i386-sequent-sysv4 + exit ;; + i*86:UNIX_SV:4.2MP:2.*) + # Unixware is an offshoot of SVR4, but it has its own version + # number series starting with 2... + # I am not positive that other SVR4 systems won't match this, + # I just have to hope. -- rms. + # Use sysv4.2uw... so that sysv4* matches it. + echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} + exit ;; + i*86:OS/2:*:*) + # If we were able to find `uname', then EMX Unix compatibility + # is probably installed. + echo ${UNAME_MACHINE}-pc-os2-emx + exit ;; + i*86:XTS-300:*:STOP) + echo ${UNAME_MACHINE}-unknown-stop + exit ;; + i*86:atheos:*:*) + echo ${UNAME_MACHINE}-unknown-atheos + exit ;; + i*86:syllable:*:*) + echo ${UNAME_MACHINE}-pc-syllable + exit ;; + i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) + echo i386-unknown-lynxos${UNAME_RELEASE} + exit ;; + i*86:*DOS:*:*) + echo ${UNAME_MACHINE}-pc-msdosdjgpp + exit ;; + i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) + UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` + if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then + echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} + else + echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} + fi + exit ;; + i*86:*:5:[678]*) + # UnixWare 7.x, OpenUNIX and OpenServer 6. + case `/bin/uname -X | grep "^Machine"` in + *486*) UNAME_MACHINE=i486 ;; + *Pentium) UNAME_MACHINE=i586 ;; + *Pent*|*Celeron) UNAME_MACHINE=i686 ;; + esac + echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} + exit ;; + i*86:*:3.2:*) + if test -f /usr/options/cb.name; then + UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then + UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` + (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 + (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ + && UNAME_MACHINE=i586 + (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ + && UNAME_MACHINE=i686 + (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ + && UNAME_MACHINE=i686 + echo ${UNAME_MACHINE}-pc-sco$UNAME_REL + else + echo ${UNAME_MACHINE}-pc-sysv32 + fi + exit ;; + pc:*:*:*) + # Left here for compatibility: + # uname -m prints for DJGPP always 'pc', but it prints nothing about + # the processor, so we play safe by assuming i586. + # Note: whatever this is, it MUST be the same as what config.sub + # prints for the "djgpp" host, or else GDB configury will decide that + # this is a cross-build. + echo i586-pc-msdosdjgpp + exit ;; + Intel:Mach:3*:*) + echo i386-pc-mach3 + exit ;; + paragon:*:*:*) + echo i860-intel-osf1 + exit ;; + i860:*:4.*:*) # i860-SVR4 + if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then + echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 + else # Add other i860-SVR4 vendors below as they are discovered. + echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 + fi + exit ;; + mini*:CTIX:SYS*5:*) + # "miniframe" + echo m68010-convergent-sysv + exit ;; + mc68k:UNIX:SYSTEM5:3.51m) + echo m68k-convergent-sysv + exit ;; + M680?0:D-NIX:5.3:*) + echo m68k-diab-dnix + exit ;; + M68*:*:R3V[5678]*:*) + test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; + 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) + OS_REL='' + test -r /etc/.relid \ + && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4.3${OS_REL}; exit; } + /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; + 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4; exit; } ;; + NCR*:*:4.2:* | MPRAS*:*:4.2:*) + OS_REL='.3' + test -r /etc/.relid \ + && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4.3${OS_REL}; exit; } + /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } + /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; + m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) + echo m68k-unknown-lynxos${UNAME_RELEASE} + exit ;; + mc68030:UNIX_System_V:4.*:*) + echo m68k-atari-sysv4 + exit ;; + TSUNAMI:LynxOS:2.*:*) + echo sparc-unknown-lynxos${UNAME_RELEASE} + exit ;; + rs6000:LynxOS:2.*:*) + echo rs6000-unknown-lynxos${UNAME_RELEASE} + exit ;; + PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) + echo powerpc-unknown-lynxos${UNAME_RELEASE} + exit ;; + SM[BE]S:UNIX_SV:*:*) + echo mips-dde-sysv${UNAME_RELEASE} + exit ;; + RM*:ReliantUNIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + RM*:SINIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + *:SINIX-*:*:*) + if uname -p 2>/dev/null >/dev/null ; then + UNAME_MACHINE=`(uname -p) 2>/dev/null` + echo ${UNAME_MACHINE}-sni-sysv4 + else + echo ns32k-sni-sysv + fi + exit ;; + PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort + # says + echo i586-unisys-sysv4 + exit ;; + *:UNIX_System_V:4*:FTX*) + # From Gerald Hewes . + # How about differentiating between stratus architectures? -djm + echo hppa1.1-stratus-sysv4 + exit ;; + *:*:*:FTX*) + # From seanf@swdc.stratus.com. + echo i860-stratus-sysv4 + exit ;; + i*86:VOS:*:*) + # From Paul.Green@stratus.com. + echo ${UNAME_MACHINE}-stratus-vos + exit ;; + *:VOS:*:*) + # From Paul.Green@stratus.com. + echo hppa1.1-stratus-vos + exit ;; + mc68*:A/UX:*:*) + echo m68k-apple-aux${UNAME_RELEASE} + exit ;; + news*:NEWS-OS:6*:*) + echo mips-sony-newsos6 + exit ;; + R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) + if [ -d /usr/nec ]; then + echo mips-nec-sysv${UNAME_RELEASE} + else + echo mips-unknown-sysv${UNAME_RELEASE} + fi + exit ;; + BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. + echo powerpc-be-beos + exit ;; + BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. + echo powerpc-apple-beos + exit ;; + BePC:BeOS:*:*) # BeOS running on Intel PC compatible. + echo i586-pc-beos + exit ;; + BePC:Haiku:*:*) # Haiku running on Intel PC compatible. + echo i586-pc-haiku + exit ;; + SX-4:SUPER-UX:*:*) + echo sx4-nec-superux${UNAME_RELEASE} + exit ;; + SX-5:SUPER-UX:*:*) + echo sx5-nec-superux${UNAME_RELEASE} + exit ;; + SX-6:SUPER-UX:*:*) + echo sx6-nec-superux${UNAME_RELEASE} + exit ;; + SX-7:SUPER-UX:*:*) + echo sx7-nec-superux${UNAME_RELEASE} + exit ;; + SX-8:SUPER-UX:*:*) + echo sx8-nec-superux${UNAME_RELEASE} + exit ;; + SX-8R:SUPER-UX:*:*) + echo sx8r-nec-superux${UNAME_RELEASE} + exit ;; + Power*:Rhapsody:*:*) + echo powerpc-apple-rhapsody${UNAME_RELEASE} + exit ;; + *:Rhapsody:*:*) + echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} + exit ;; + *:Darwin:*:*) + UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown + case $UNAME_PROCESSOR in + i386) + eval $set_cc_for_build + if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then + if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \ + (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ + grep IS_64BIT_ARCH >/dev/null + then + UNAME_PROCESSOR="x86_64" + fi + fi ;; + unknown) UNAME_PROCESSOR=powerpc ;; + esac + echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} + exit ;; + *:procnto*:*:* | *:QNX:[0123456789]*:*) + UNAME_PROCESSOR=`uname -p` + if test "$UNAME_PROCESSOR" = "x86"; then + UNAME_PROCESSOR=i386 + UNAME_MACHINE=pc + fi + echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} + exit ;; + *:QNX:*:4*) + echo i386-pc-qnx + exit ;; + NSE-?:NONSTOP_KERNEL:*:*) + echo nse-tandem-nsk${UNAME_RELEASE} + exit ;; + NSR-?:NONSTOP_KERNEL:*:*) + echo nsr-tandem-nsk${UNAME_RELEASE} + exit ;; + *:NonStop-UX:*:*) + echo mips-compaq-nonstopux + exit ;; + BS2000:POSIX*:*:*) + echo bs2000-siemens-sysv + exit ;; + DS/*:UNIX_System_V:*:*) + echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} + exit ;; + *:Plan9:*:*) + # "uname -m" is not consistent, so use $cputype instead. 386 + # is converted to i386 for consistency with other x86 + # operating systems. + if test "$cputype" = "386"; then + UNAME_MACHINE=i386 + else + UNAME_MACHINE="$cputype" + fi + echo ${UNAME_MACHINE}-unknown-plan9 + exit ;; + *:TOPS-10:*:*) + echo pdp10-unknown-tops10 + exit ;; + *:TENEX:*:*) + echo pdp10-unknown-tenex + exit ;; + KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) + echo pdp10-dec-tops20 + exit ;; + XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) + echo pdp10-xkl-tops20 + exit ;; + *:TOPS-20:*:*) + echo pdp10-unknown-tops20 + exit ;; + *:ITS:*:*) + echo pdp10-unknown-its + exit ;; + SEI:*:*:SEIUX) + echo mips-sei-seiux${UNAME_RELEASE} + exit ;; + *:DragonFly:*:*) + echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` + exit ;; + *:*VMS:*:*) + UNAME_MACHINE=`(uname -p) 2>/dev/null` + case "${UNAME_MACHINE}" in + A*) echo alpha-dec-vms ; exit ;; + I*) echo ia64-dec-vms ; exit ;; + V*) echo vax-dec-vms ; exit ;; + esac ;; + *:XENIX:*:SysV) + echo i386-pc-xenix + exit ;; + i*86:skyos:*:*) + echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' + exit ;; + i*86:rdos:*:*) + echo ${UNAME_MACHINE}-pc-rdos + exit ;; + i*86:AROS:*:*) + echo ${UNAME_MACHINE}-pc-aros + exit ;; +esac + +#echo '(No uname command or uname output not recognized.)' 1>&2 +#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2 + +eval $set_cc_for_build +cat >$dummy.c < +# include +#endif +main () +{ +#if defined (sony) +#if defined (MIPSEB) + /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed, + I don't know.... */ + printf ("mips-sony-bsd\n"); exit (0); +#else +#include + printf ("m68k-sony-newsos%s\n", +#ifdef NEWSOS4 + "4" +#else + "" +#endif + ); exit (0); +#endif +#endif + +#if defined (__arm) && defined (__acorn) && defined (__unix) + printf ("arm-acorn-riscix\n"); exit (0); +#endif + +#if defined (hp300) && !defined (hpux) + printf ("m68k-hp-bsd\n"); exit (0); +#endif + +#if defined (NeXT) +#if !defined (__ARCHITECTURE__) +#define __ARCHITECTURE__ "m68k" +#endif + int version; + version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`; + if (version < 4) + printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version); + else + printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version); + exit (0); +#endif + +#if defined (MULTIMAX) || defined (n16) +#if defined (UMAXV) + printf ("ns32k-encore-sysv\n"); exit (0); +#else +#if defined (CMU) + printf ("ns32k-encore-mach\n"); exit (0); +#else + printf ("ns32k-encore-bsd\n"); exit (0); +#endif +#endif +#endif + +#if defined (__386BSD__) + printf ("i386-pc-bsd\n"); exit (0); +#endif + +#if defined (sequent) +#if defined (i386) + printf ("i386-sequent-dynix\n"); exit (0); +#endif +#if defined (ns32000) + printf ("ns32k-sequent-dynix\n"); exit (0); +#endif +#endif + +#if defined (_SEQUENT_) + struct utsname un; + + uname(&un); + + if (strncmp(un.version, "V2", 2) == 0) { + printf ("i386-sequent-ptx2\n"); exit (0); + } + if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */ + printf ("i386-sequent-ptx1\n"); exit (0); + } + printf ("i386-sequent-ptx\n"); exit (0); + +#endif + +#if defined (vax) +# if !defined (ultrix) +# include +# if defined (BSD) +# if BSD == 43 + printf ("vax-dec-bsd4.3\n"); exit (0); +# else +# if BSD == 199006 + printf ("vax-dec-bsd4.3reno\n"); exit (0); +# else + printf ("vax-dec-bsd\n"); exit (0); +# endif +# endif +# else + printf ("vax-dec-bsd\n"); exit (0); +# endif +# else + printf ("vax-dec-ultrix\n"); exit (0); +# endif +#endif + +#if defined (alliant) && defined (i860) + printf ("i860-alliant-bsd\n"); exit (0); +#endif + + exit (1); +} +EOF + +$CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null && SYSTEM_NAME=`$dummy` && + { echo "$SYSTEM_NAME"; exit; } + +# Apollos put the system type in the environment. + +test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit; } + +# Convex versions that predate uname can use getsysinfo(1) + +if [ -x /usr/convex/getsysinfo ] +then + case `getsysinfo -f cpu_type` in + c1*) + echo c1-convex-bsd + exit ;; + c2*) + if getsysinfo -f scalar_acc + then echo c32-convex-bsd + else echo c2-convex-bsd + fi + exit ;; + c34*) + echo c34-convex-bsd + exit ;; + c38*) + echo c38-convex-bsd + exit ;; + c4*) + echo c4-convex-bsd + exit ;; + esac +fi + +cat >&2 < in order to provide the needed +information to handle your system. + +config.guess timestamp = $timestamp + +uname -m = `(uname -m) 2>/dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null` + +hostinfo = `(hostinfo) 2>/dev/null` +/bin/universe = `(/bin/universe) 2>/dev/null` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` +/bin/arch = `(/bin/arch) 2>/dev/null` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` + +UNAME_MACHINE = ${UNAME_MACHINE} +UNAME_RELEASE = ${UNAME_RELEASE} +UNAME_SYSTEM = ${UNAME_SYSTEM} +UNAME_VERSION = ${UNAME_VERSION} +EOF + +exit 1 + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "timestamp='" +# time-stamp-format: "%:y-%02m-%02d" +# time-stamp-end: "'" +# End: diff --git a/Externals/SDL/build-scripts/config.sub b/Externals/SDL/build-scripts/config.sub new file mode 100755 index 0000000000..5ecc18b6ad --- /dev/null +++ b/Externals/SDL/build-scripts/config.sub @@ -0,0 +1,1700 @@ +#! /bin/sh +# Configuration validation subroutine script. +# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, +# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 +# Free Software Foundation, Inc. + +timestamp='2009-10-07' + +# This file is (in principle) common to ALL GNU software. +# The presence of a machine in this file suggests that SOME GNU software +# can handle that machine. It does not imply ALL GNU software can. +# +# This file is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA +# 02110-1301, USA. +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + + +# Please send patches to . Submit a context +# diff and a properly formatted GNU ChangeLog entry. +# +# Configuration subroutine to validate and canonicalize a configuration type. +# Supply the specified configuration type as an argument. +# If it is invalid, we print an error message on stderr and exit with code 1. +# Otherwise, we print the canonical config type on stdout and succeed. + +# You can get the latest version of this script from: +# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD + +# This file is supposed to be the same for all GNU packages +# and recognize all the CPU types, system types and aliases +# that are meaningful with *any* GNU software. +# Each package is responsible for reporting which valid configurations +# it does not support. The user should be able to distinguish +# a failure to support a valid configuration from a meaningless +# configuration. + +# The goal of this file is to map all the various variations of a given +# machine specification into a single specification in the form: +# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM +# or in some cases, the newer four-part form: +# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM +# It is wrong to echo any other type of specification. + +me=`echo "$0" | sed -e 's,.*/,,'` + +usage="\ +Usage: $0 [OPTION] CPU-MFR-OPSYS + $0 [OPTION] ALIAS + +Canonicalize a configuration name. + +Operation modes: + -h, --help print this help, then exit + -t, --time-stamp print date of last modification, then exit + -v, --version print version number, then exit + +Report bugs and patches to ." + +version="\ +GNU config.sub ($timestamp) + +Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, +2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. + +This is free software; see the source for copying conditions. There is NO +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + +help=" +Try \`$me --help' for more information." + +# Parse command line +while test $# -gt 0 ; do + case $1 in + --time-stamp | --time* | -t ) + echo "$timestamp" ; exit ;; + --version | -v ) + echo "$version" ; exit ;; + --help | --h* | -h ) + echo "$usage"; exit ;; + -- ) # Stop option processing + shift; break ;; + - ) # Use stdin as input. + break ;; + -* ) + echo "$me: invalid option $1$help" + exit 1 ;; + + *local*) + # First pass through any local machine types. + echo $1 + exit ;; + + * ) + break ;; + esac +done + +case $# in + 0) echo "$me: missing argument$help" >&2 + exit 1;; + 1) ;; + *) echo "$me: too many arguments$help" >&2 + exit 1;; +esac + +# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). +# Here we must recognize all the valid KERNEL-OS combinations. +maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` +case $maybe_os in + nto-qnx* | linux-gnu* | linux-dietlibc | linux-newlib* | linux-uclibc* | \ + uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | \ + kopensolaris*-gnu* | \ + storm-chaos* | os2-emx* | rtmk-nova*) + os=-$maybe_os + basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` + ;; + *) + basic_machine=`echo $1 | sed 's/-[^-]*$//'` + if [ $basic_machine != $1 ] + then os=`echo $1 | sed 's/.*-/-/'` + else os=; fi + ;; +esac + +### Let's recognize common machines as not being operating systems so +### that things like config.sub decstation-3100 work. We also +### recognize some manufacturers as not being operating systems, so we +### can provide default operating systems below. +case $os in + -sun*os*) + # Prevent following clause from handling this invalid input. + ;; + -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ + -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ + -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ + -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ + -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ + -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ + -apple | -axis | -knuth | -cray | -microblaze) + os= + basic_machine=$1 + ;; + -bluegene*) + os=-cnk + ;; + -sim | -cisco | -oki | -wec | -winbond) + os= + basic_machine=$1 + ;; + -scout) + ;; + -wrs) + os=-vxworks + basic_machine=$1 + ;; + -chorusos*) + os=-chorusos + basic_machine=$1 + ;; + -chorusrdb) + os=-chorusrdb + basic_machine=$1 + ;; + -hiux*) + os=-hiuxwe2 + ;; + -sco6) + os=-sco5v6 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco5) + os=-sco3.2v5 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco4) + os=-sco3.2v4 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco3.2.[4-9]*) + os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco3.2v[4-9]*) + # Don't forget version if it is 3.2v4 or newer. + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco5v6*) + # Don't forget version if it is 3.2v4 or newer. + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco*) + os=-sco3.2v2 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -udk*) + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -isc) + os=-isc2.2 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -clix*) + basic_machine=clipper-intergraph + ;; + -isc*) + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -lynx*) + os=-lynxos + ;; + -ptx*) + basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` + ;; + -windowsnt*) + os=`echo $os | sed -e 's/windowsnt/winnt/'` + ;; + -psos*) + os=-psos + ;; + -mint | -mint[0-9]*) + basic_machine=m68k-atari + os=-mint + ;; +esac + +# Decode aliases for certain CPU-COMPANY combinations. +case $basic_machine in + # Recognize the basic CPU types without company name. + # Some are omitted here because they have special meanings below. + 1750a | 580 \ + | a29k \ + | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ + | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ + | am33_2.0 \ + | arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr | avr32 \ + | bfin \ + | c4x | clipper \ + | d10v | d30v | dlx | dsp16xx \ + | fido | fr30 | frv \ + | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ + | i370 | i860 | i960 | ia64 \ + | ip2k | iq2000 \ + | lm32 \ + | m32c | m32r | m32rle | m68000 | m68k | m88k \ + | maxq | mb | microblaze | mcore | mep | metag \ + | mips | mipsbe | mipseb | mipsel | mipsle \ + | mips16 \ + | mips64 | mips64el \ + | mips64octeon | mips64octeonel \ + | mips64orion | mips64orionel \ + | mips64r5900 | mips64r5900el \ + | mips64vr | mips64vrel \ + | mips64vr4100 | mips64vr4100el \ + | mips64vr4300 | mips64vr4300el \ + | mips64vr5000 | mips64vr5000el \ + | mips64vr5900 | mips64vr5900el \ + | mipsisa32 | mipsisa32el \ + | mipsisa32r2 | mipsisa32r2el \ + | mipsisa64 | mipsisa64el \ + | mipsisa64r2 | mipsisa64r2el \ + | mipsisa64sb1 | mipsisa64sb1el \ + | mipsisa64sr71k | mipsisa64sr71kel \ + | mipstx39 | mipstx39el \ + | mn10200 | mn10300 \ + | moxie \ + | mt \ + | msp430 \ + | nios | nios2 \ + | ns16k | ns32k \ + | or32 \ + | pdp10 | pdp11 | pj | pjl \ + | powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \ + | pyramid \ + | rx \ + | score \ + | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ + | sh64 | sh64le \ + | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ + | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ + | spu | strongarm \ + | tahoe | thumb | tic4x | tic80 | tron \ + | v850 | v850e \ + | we32k \ + | x86 | xc16x | xscale | xscalee[bl] | xstormy16 | xtensa \ + | z8k | z80) + basic_machine=$basic_machine-unknown + ;; + m6811 | m68hc11 | m6812 | m68hc12 | picochip) + # Motorola 68HC11/12. + basic_machine=$basic_machine-unknown + os=-none + ;; + m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) + ;; + ms1) + basic_machine=mt-unknown + ;; + + # We use `pc' rather than `unknown' + # because (1) that's what they normally are, and + # (2) the word "unknown" tends to confuse beginning users. + i*86 | x86_64) + basic_machine=$basic_machine-pc + ;; + # Object if more than one company name word. + *-*-*) + echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 + exit 1 + ;; + # Recognize the basic CPU types with company name. + 580-* \ + | a29k-* \ + | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ + | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ + | alphapca5[67]-* | alpha64pca5[67]-* | arc-* \ + | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ + | avr-* | avr32-* \ + | bfin-* | bs2000-* \ + | c[123]* | c30-* | [cjt]90-* | c4x-* | c54x-* | c55x-* | c6x-* \ + | clipper-* | craynv-* | cydra-* \ + | d10v-* | d30v-* | dlx-* \ + | elxsi-* \ + | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ + | h8300-* | h8500-* \ + | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ + | i*86-* | i860-* | i960-* | ia64-* \ + | ip2k-* | iq2000-* \ + | lm32-* \ + | m32c-* | m32r-* | m32rle-* \ + | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ + | m88110-* | m88k-* | maxq-* | mcore-* | metag-* | microblaze-* \ + | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ + | mips16-* \ + | mips64-* | mips64el-* \ + | mips64octeon-* | mips64octeonel-* \ + | mips64orion-* | mips64orionel-* \ + | mips64r5900-* | mips64r5900el-* \ + | mips64vr-* | mips64vrel-* \ + | mips64vr4100-* | mips64vr4100el-* \ + | mips64vr4300-* | mips64vr4300el-* \ + | mips64vr5000-* | mips64vr5000el-* \ + | mips64vr5900-* | mips64vr5900el-* \ + | mipsisa32-* | mipsisa32el-* \ + | mipsisa32r2-* | mipsisa32r2el-* \ + | mipsisa64-* | mipsisa64el-* \ + | mipsisa64r2-* | mipsisa64r2el-* \ + | mipsisa64sb1-* | mipsisa64sb1el-* \ + | mipsisa64sr71k-* | mipsisa64sr71kel-* \ + | mipstx39-* | mipstx39el-* \ + | mmix-* \ + | mt-* \ + | msp430-* \ + | nios-* | nios2-* \ + | none-* | np1-* | ns16k-* | ns32k-* \ + | orion-* \ + | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ + | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \ + | pyramid-* \ + | romp-* | rs6000-* | rx-* \ + | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ + | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ + | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ + | sparclite-* \ + | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | strongarm-* | sv1-* | sx?-* \ + | tahoe-* | thumb-* \ + | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* | tile-* \ + | tron-* \ + | v850-* | v850e-* | vax-* \ + | we32k-* \ + | x86-* | x86_64-* | xc16x-* | xps100-* | xscale-* | xscalee[bl]-* \ + | xstormy16-* | xtensa*-* \ + | ymp-* \ + | z8k-* | z80-*) + ;; + # Recognize the basic CPU types without company name, with glob match. + xtensa*) + basic_machine=$basic_machine-unknown + ;; + # Recognize the various machine names and aliases which stand + # for a CPU type and a company and sometimes even an OS. + 386bsd) + basic_machine=i386-unknown + os=-bsd + ;; + 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) + basic_machine=m68000-att + ;; + 3b*) + basic_machine=we32k-att + ;; + a29khif) + basic_machine=a29k-amd + os=-udi + ;; + abacus) + basic_machine=abacus-unknown + ;; + adobe68k) + basic_machine=m68010-adobe + os=-scout + ;; + alliant | fx80) + basic_machine=fx80-alliant + ;; + altos | altos3068) + basic_machine=m68k-altos + ;; + am29k) + basic_machine=a29k-none + os=-bsd + ;; + amd64) + basic_machine=x86_64-pc + ;; + amd64-*) + basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + amdahl) + basic_machine=580-amdahl + os=-sysv + ;; + amiga | amiga-*) + basic_machine=m68k-unknown + ;; + amigaos | amigados) + basic_machine=m68k-unknown + os=-amigaos + ;; + amigaunix | amix) + basic_machine=m68k-unknown + os=-sysv4 + ;; + apollo68) + basic_machine=m68k-apollo + os=-sysv + ;; + apollo68bsd) + basic_machine=m68k-apollo + os=-bsd + ;; + aros) + basic_machine=i386-pc + os=-aros + ;; + aux) + basic_machine=m68k-apple + os=-aux + ;; + balance) + basic_machine=ns32k-sequent + os=-dynix + ;; + blackfin) + basic_machine=bfin-unknown + os=-linux + ;; + blackfin-*) + basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'` + os=-linux + ;; + bluegene*) + basic_machine=powerpc-ibm + os=-cnk + ;; + c90) + basic_machine=c90-cray + os=-unicos + ;; + cegcc) + basic_machine=arm-unknown + os=-cegcc + ;; + convex-c1) + basic_machine=c1-convex + os=-bsd + ;; + convex-c2) + basic_machine=c2-convex + os=-bsd + ;; + convex-c32) + basic_machine=c32-convex + os=-bsd + ;; + convex-c34) + basic_machine=c34-convex + os=-bsd + ;; + convex-c38) + basic_machine=c38-convex + os=-bsd + ;; + cray | j90) + basic_machine=j90-cray + os=-unicos + ;; + craynv) + basic_machine=craynv-cray + os=-unicosmp + ;; + cr16) + basic_machine=cr16-unknown + os=-elf + ;; + crds | unos) + basic_machine=m68k-crds + ;; + crisv32 | crisv32-* | etraxfs*) + basic_machine=crisv32-axis + ;; + cris | cris-* | etrax*) + basic_machine=cris-axis + ;; + crx) + basic_machine=crx-unknown + os=-elf + ;; + da30 | da30-*) + basic_machine=m68k-da30 + ;; + decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) + basic_machine=mips-dec + ;; + decsystem10* | dec10*) + basic_machine=pdp10-dec + os=-tops10 + ;; + decsystem20* | dec20*) + basic_machine=pdp10-dec + os=-tops20 + ;; + delta | 3300 | motorola-3300 | motorola-delta \ + | 3300-motorola | delta-motorola) + basic_machine=m68k-motorola + ;; + delta88) + basic_machine=m88k-motorola + os=-sysv3 + ;; + dicos) + basic_machine=i686-pc + os=-dicos + ;; + djgpp) + basic_machine=i586-pc + os=-msdosdjgpp + ;; + dpx20 | dpx20-*) + basic_machine=rs6000-bull + os=-bosx + ;; + dpx2* | dpx2*-bull) + basic_machine=m68k-bull + os=-sysv3 + ;; + ebmon29k) + basic_machine=a29k-amd + os=-ebmon + ;; + elxsi) + basic_machine=elxsi-elxsi + os=-bsd + ;; + encore | umax | mmax) + basic_machine=ns32k-encore + ;; + es1800 | OSE68k | ose68k | ose | OSE) + basic_machine=m68k-ericsson + os=-ose + ;; + fx2800) + basic_machine=i860-alliant + ;; + genix) + basic_machine=ns32k-ns + ;; + gmicro) + basic_machine=tron-gmicro + os=-sysv + ;; + go32) + basic_machine=i386-pc + os=-go32 + ;; + h3050r* | hiux*) + basic_machine=hppa1.1-hitachi + os=-hiuxwe2 + ;; + h8300hms) + basic_machine=h8300-hitachi + os=-hms + ;; + h8300xray) + basic_machine=h8300-hitachi + os=-xray + ;; + h8500hms) + basic_machine=h8500-hitachi + os=-hms + ;; + harris) + basic_machine=m88k-harris + os=-sysv3 + ;; + hp300-*) + basic_machine=m68k-hp + ;; + hp300bsd) + basic_machine=m68k-hp + os=-bsd + ;; + hp300hpux) + basic_machine=m68k-hp + os=-hpux + ;; + hp3k9[0-9][0-9] | hp9[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hp9k2[0-9][0-9] | hp9k31[0-9]) + basic_machine=m68000-hp + ;; + hp9k3[2-9][0-9]) + basic_machine=m68k-hp + ;; + hp9k6[0-9][0-9] | hp6[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hp9k7[0-79][0-9] | hp7[0-79][0-9]) + basic_machine=hppa1.1-hp + ;; + hp9k78[0-9] | hp78[0-9]) + # FIXME: really hppa2.0-hp + basic_machine=hppa1.1-hp + ;; + hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) + # FIXME: really hppa2.0-hp + basic_machine=hppa1.1-hp + ;; + hp9k8[0-9][13679] | hp8[0-9][13679]) + basic_machine=hppa1.1-hp + ;; + hp9k8[0-9][0-9] | hp8[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hppa-next) + os=-nextstep3 + ;; + hppaosf) + basic_machine=hppa1.1-hp + os=-osf + ;; + hppro) + basic_machine=hppa1.1-hp + os=-proelf + ;; + i370-ibm* | ibm*) + basic_machine=i370-ibm + ;; +# I'm not sure what "Sysv32" means. Should this be sysv3.2? + i*86v32) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-sysv32 + ;; + i*86v4*) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-sysv4 + ;; + i*86v) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-sysv + ;; + i*86sol2) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-solaris2 + ;; + i386mach) + basic_machine=i386-mach + os=-mach + ;; + i386-vsta | vsta) + basic_machine=i386-unknown + os=-vsta + ;; + iris | iris4d) + basic_machine=mips-sgi + case $os in + -irix*) + ;; + *) + os=-irix4 + ;; + esac + ;; + isi68 | isi) + basic_machine=m68k-isi + os=-sysv + ;; + m68knommu) + basic_machine=m68k-unknown + os=-linux + ;; + m68knommu-*) + basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'` + os=-linux + ;; + m88k-omron*) + basic_machine=m88k-omron + ;; + magnum | m3230) + basic_machine=mips-mips + os=-sysv + ;; + merlin) + basic_machine=ns32k-utek + os=-sysv + ;; + microblaze) + basic_machine=microblaze-xilinx + ;; + mingw32) + basic_machine=i386-pc + os=-mingw32 + ;; + mingw32ce) + basic_machine=arm-unknown + os=-mingw32ce + ;; + miniframe) + basic_machine=m68000-convergent + ;; + *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) + basic_machine=m68k-atari + os=-mint + ;; + mips3*-*) + basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` + ;; + mips3*) + basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown + ;; + monitor) + basic_machine=m68k-rom68k + os=-coff + ;; + morphos) + basic_machine=powerpc-unknown + os=-morphos + ;; + msdos) + basic_machine=i386-pc + os=-msdos + ;; + ms1-*) + basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` + ;; + mvs) + basic_machine=i370-ibm + os=-mvs + ;; + ncr3000) + basic_machine=i486-ncr + os=-sysv4 + ;; + netbsd386) + basic_machine=i386-unknown + os=-netbsd + ;; + netwinder) + basic_machine=armv4l-rebel + os=-linux + ;; + news | news700 | news800 | news900) + basic_machine=m68k-sony + os=-newsos + ;; + news1000) + basic_machine=m68030-sony + os=-newsos + ;; + news-3600 | risc-news) + basic_machine=mips-sony + os=-newsos + ;; + necv70) + basic_machine=v70-nec + os=-sysv + ;; + next | m*-next ) + basic_machine=m68k-next + case $os in + -nextstep* ) + ;; + -ns2*) + os=-nextstep2 + ;; + *) + os=-nextstep3 + ;; + esac + ;; + nh3000) + basic_machine=m68k-harris + os=-cxux + ;; + nh[45]000) + basic_machine=m88k-harris + os=-cxux + ;; + nindy960) + basic_machine=i960-intel + os=-nindy + ;; + mon960) + basic_machine=i960-intel + os=-mon960 + ;; + nonstopux) + basic_machine=mips-compaq + os=-nonstopux + ;; + np1) + basic_machine=np1-gould + ;; + nsr-tandem) + basic_machine=nsr-tandem + ;; + op50n-* | op60c-*) + basic_machine=hppa1.1-oki + os=-proelf + ;; + openrisc | openrisc-*) + basic_machine=or32-unknown + ;; + os400) + basic_machine=powerpc-ibm + os=-os400 + ;; + OSE68000 | ose68000) + basic_machine=m68000-ericsson + os=-ose + ;; + os68k) + basic_machine=m68k-none + os=-os68k + ;; + pa-hitachi) + basic_machine=hppa1.1-hitachi + os=-hiuxwe2 + ;; + paragon) + basic_machine=i860-intel + os=-osf + ;; + parisc) + basic_machine=hppa-unknown + os=-linux + ;; + parisc-*) + basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'` + os=-linux + ;; + pbd) + basic_machine=sparc-tti + ;; + pbb) + basic_machine=m68k-tti + ;; + pc532 | pc532-*) + basic_machine=ns32k-pc532 + ;; + pc98) + basic_machine=i386-pc + ;; + pc98-*) + basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentium | p5 | k5 | k6 | nexgen | viac3) + basic_machine=i586-pc + ;; + pentiumpro | p6 | 6x86 | athlon | athlon_*) + basic_machine=i686-pc + ;; + pentiumii | pentium2 | pentiumiii | pentium3) + basic_machine=i686-pc + ;; + pentium4) + basic_machine=i786-pc + ;; + pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) + basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentiumpro-* | p6-* | 6x86-* | athlon-*) + basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) + basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentium4-*) + basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pn) + basic_machine=pn-gould + ;; + power) basic_machine=power-ibm + ;; + ppc) basic_machine=powerpc-unknown + ;; + ppc-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ppcle | powerpclittle | ppc-le | powerpc-little) + basic_machine=powerpcle-unknown + ;; + ppcle-* | powerpclittle-*) + basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ppc64) basic_machine=powerpc64-unknown + ;; + ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ppc64le | powerpc64little | ppc64-le | powerpc64-little) + basic_machine=powerpc64le-unknown + ;; + ppc64le-* | powerpc64little-*) + basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ps2) + basic_machine=i386-ibm + ;; + pw32) + basic_machine=i586-unknown + os=-pw32 + ;; + rdos) + basic_machine=i386-pc + os=-rdos + ;; + rom68k) + basic_machine=m68k-rom68k + os=-coff + ;; + rm[46]00) + basic_machine=mips-siemens + ;; + rtpc | rtpc-*) + basic_machine=romp-ibm + ;; + s390 | s390-*) + basic_machine=s390-ibm + ;; + s390x | s390x-*) + basic_machine=s390x-ibm + ;; + sa29200) + basic_machine=a29k-amd + os=-udi + ;; + sb1) + basic_machine=mipsisa64sb1-unknown + ;; + sb1el) + basic_machine=mipsisa64sb1el-unknown + ;; + sde) + basic_machine=mipsisa32-sde + os=-elf + ;; + sei) + basic_machine=mips-sei + os=-seiux + ;; + sequent) + basic_machine=i386-sequent + ;; + sh) + basic_machine=sh-hitachi + os=-hms + ;; + sh5el) + basic_machine=sh5le-unknown + ;; + sh64) + basic_machine=sh64-unknown + ;; + sparclite-wrs | simso-wrs) + basic_machine=sparclite-wrs + os=-vxworks + ;; + sps7) + basic_machine=m68k-bull + os=-sysv2 + ;; + spur) + basic_machine=spur-unknown + ;; + st2000) + basic_machine=m68k-tandem + ;; + stratus) + basic_machine=i860-stratus + os=-sysv4 + ;; + sun2) + basic_machine=m68000-sun + ;; + sun2os3) + basic_machine=m68000-sun + os=-sunos3 + ;; + sun2os4) + basic_machine=m68000-sun + os=-sunos4 + ;; + sun3os3) + basic_machine=m68k-sun + os=-sunos3 + ;; + sun3os4) + basic_machine=m68k-sun + os=-sunos4 + ;; + sun4os3) + basic_machine=sparc-sun + os=-sunos3 + ;; + sun4os4) + basic_machine=sparc-sun + os=-sunos4 + ;; + sun4sol2) + basic_machine=sparc-sun + os=-solaris2 + ;; + sun3 | sun3-*) + basic_machine=m68k-sun + ;; + sun4) + basic_machine=sparc-sun + ;; + sun386 | sun386i | roadrunner) + basic_machine=i386-sun + ;; + sv1) + basic_machine=sv1-cray + os=-unicos + ;; + symmetry) + basic_machine=i386-sequent + os=-dynix + ;; + t3e) + basic_machine=alphaev5-cray + os=-unicos + ;; + t90) + basic_machine=t90-cray + os=-unicos + ;; + tic54x | c54x*) + basic_machine=tic54x-unknown + os=-coff + ;; + tic55x | c55x*) + basic_machine=tic55x-unknown + os=-coff + ;; + tic6x | c6x*) + basic_machine=tic6x-unknown + os=-coff + ;; + tile*) + basic_machine=tile-unknown + os=-linux-gnu + ;; + tx39) + basic_machine=mipstx39-unknown + ;; + tx39el) + basic_machine=mipstx39el-unknown + ;; + toad1) + basic_machine=pdp10-xkl + os=-tops20 + ;; + tower | tower-32) + basic_machine=m68k-ncr + ;; + tpf) + basic_machine=s390x-ibm + os=-tpf + ;; + udi29k) + basic_machine=a29k-amd + os=-udi + ;; + ultra3) + basic_machine=a29k-nyu + os=-sym1 + ;; + v810 | necv810) + basic_machine=v810-nec + os=-none + ;; + vaxv) + basic_machine=vax-dec + os=-sysv + ;; + vms) + basic_machine=vax-dec + os=-vms + ;; + vpp*|vx|vx-*) + basic_machine=f301-fujitsu + ;; + vxworks960) + basic_machine=i960-wrs + os=-vxworks + ;; + vxworks68) + basic_machine=m68k-wrs + os=-vxworks + ;; + vxworks29k) + basic_machine=a29k-wrs + os=-vxworks + ;; + w65*) + basic_machine=w65-wdc + os=-none + ;; + w89k-*) + basic_machine=hppa1.1-winbond + os=-proelf + ;; + xbox) + basic_machine=i686-pc + os=-mingw32 + ;; + xps | xps100) + basic_machine=xps100-honeywell + ;; + ymp) + basic_machine=ymp-cray + os=-unicos + ;; + z8k-*-coff) + basic_machine=z8k-unknown + os=-sim + ;; + z80-*-coff) + basic_machine=z80-unknown + os=-sim + ;; + none) + basic_machine=none-none + os=-none + ;; + +# Here we handle the default manufacturer of certain CPU types. It is in +# some cases the only manufacturer, in others, it is the most popular. + w89k) + basic_machine=hppa1.1-winbond + ;; + op50n) + basic_machine=hppa1.1-oki + ;; + op60c) + basic_machine=hppa1.1-oki + ;; + romp) + basic_machine=romp-ibm + ;; + mmix) + basic_machine=mmix-knuth + ;; + rs6000) + basic_machine=rs6000-ibm + ;; + vax) + basic_machine=vax-dec + ;; + pdp10) + # there are many clones, so DEC is not a safe bet + basic_machine=pdp10-unknown + ;; + pdp11) + basic_machine=pdp11-dec + ;; + we32k) + basic_machine=we32k-att + ;; + sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele) + basic_machine=sh-unknown + ;; + sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) + basic_machine=sparc-sun + ;; + cydra) + basic_machine=cydra-cydrome + ;; + orion) + basic_machine=orion-highlevel + ;; + orion105) + basic_machine=clipper-highlevel + ;; + mac | mpw | mac-mpw) + basic_machine=m68k-apple + ;; + pmac | pmac-mpw) + basic_machine=powerpc-apple + ;; + *-unknown) + # Make sure to match an already-canonicalized machine name. + ;; + *) + echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 + exit 1 + ;; +esac + +# Here we canonicalize certain aliases for manufacturers. +case $basic_machine in + *-digital*) + basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` + ;; + *-commodore*) + basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` + ;; + *) + ;; +esac + +# Decode manufacturer-specific aliases for certain operating systems. + +if [ x"$os" != x"" ] +then +case $os in + # First match some system type aliases + # that might get confused with valid system types. + # -solaris* is a basic system type, with this one exception. + -solaris1 | -solaris1.*) + os=`echo $os | sed -e 's|solaris1|sunos4|'` + ;; + -solaris) + os=-solaris2 + ;; + -svr4*) + os=-sysv4 + ;; + -unixware*) + os=-sysv4.2uw + ;; + -gnu/linux*) + os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` + ;; + # First accept the basic system types. + # The portable systems comes first. + # Each alternative MUST END IN A *, to match a version number. + # -sysv* is not here because it comes later, after sysvr4. + -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ + | -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\ + | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \ + | -kopensolaris* \ + | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ + | -aos* | -aros* \ + | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ + | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ + | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ + | -openbsd* | -solidbsd* \ + | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ + | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ + | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ + | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ + | -chorusos* | -chorusrdb* | -cegcc* \ + | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ + | -mingw32* | -linux-gnu* | -linux-newlib* | -linux-uclibc* \ + | -uxpv* | -beos* | -mpeix* | -udk* \ + | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ + | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ + | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ + | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ + | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ + | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ + | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es*) + # Remember, each alternative MUST END IN *, to match a version number. + ;; + -qnx*) + case $basic_machine in + x86-* | i*86-*) + ;; + *) + os=-nto$os + ;; + esac + ;; + -nto-qnx*) + ;; + -nto*) + os=`echo $os | sed -e 's|nto|nto-qnx|'` + ;; + -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ + | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ + | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) + ;; + -mac*) + os=`echo $os | sed -e 's|mac|macos|'` + ;; + -linux-dietlibc) + os=-linux-dietlibc + ;; + -linux*) + os=`echo $os | sed -e 's|linux|linux-gnu|'` + ;; + -sunos5*) + os=`echo $os | sed -e 's|sunos5|solaris2|'` + ;; + -sunos6*) + os=`echo $os | sed -e 's|sunos6|solaris3|'` + ;; + -opened*) + os=-openedition + ;; + -os400*) + os=-os400 + ;; + -wince*) + os=-wince + ;; + -osfrose*) + os=-osfrose + ;; + -osf*) + os=-osf + ;; + -utek*) + os=-bsd + ;; + -dynix*) + os=-bsd + ;; + -acis*) + os=-aos + ;; + -atheos*) + os=-atheos + ;; + -syllable*) + os=-syllable + ;; + -386bsd) + os=-bsd + ;; + -ctix* | -uts*) + os=-sysv + ;; + -nova*) + os=-rtmk-nova + ;; + -ns2 ) + os=-nextstep2 + ;; + -nsk*) + os=-nsk + ;; + # Preserve the version number of sinix5. + -sinix5.*) + os=`echo $os | sed -e 's|sinix|sysv|'` + ;; + -sinix*) + os=-sysv4 + ;; + -tpf*) + os=-tpf + ;; + -triton*) + os=-sysv3 + ;; + -oss*) + os=-sysv3 + ;; + -svr4) + os=-sysv4 + ;; + -svr3) + os=-sysv3 + ;; + -sysvr4) + os=-sysv4 + ;; + # This must come after -sysvr4. + -sysv*) + ;; + -ose*) + os=-ose + ;; + -es1800*) + os=-ose + ;; + -xenix) + os=-xenix + ;; + -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) + os=-mint + ;; + -aros*) + os=-aros + ;; + -kaos*) + os=-kaos + ;; + -zvmoe) + os=-zvmoe + ;; + -dicos*) + os=-dicos + ;; + -none) + ;; + *) + # Get rid of the `-' at the beginning of $os. + os=`echo $os | sed 's/[^-]*-//'` + echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 + exit 1 + ;; +esac +else + +# Here we handle the default operating systems that come with various machines. +# The value should be what the vendor currently ships out the door with their +# machine or put another way, the most popular os provided with the machine. + +# Note that if you're going to try to match "-MANUFACTURER" here (say, +# "-sun"), then you have to tell the case statement up towards the top +# that MANUFACTURER isn't an operating system. Otherwise, code above +# will signal an error saying that MANUFACTURER isn't an operating +# system, and we'll never get to this point. + +case $basic_machine in + score-*) + os=-elf + ;; + spu-*) + os=-elf + ;; + *-acorn) + os=-riscix1.2 + ;; + arm*-rebel) + os=-linux + ;; + arm*-semi) + os=-aout + ;; + c4x-* | tic4x-*) + os=-coff + ;; + # This must come before the *-dec entry. + pdp10-*) + os=-tops20 + ;; + pdp11-*) + os=-none + ;; + *-dec | vax-*) + os=-ultrix4.2 + ;; + m68*-apollo) + os=-domain + ;; + i386-sun) + os=-sunos4.0.2 + ;; + m68000-sun) + os=-sunos3 + # This also exists in the configure program, but was not the + # default. + # os=-sunos4 + ;; + m68*-cisco) + os=-aout + ;; + mep-*) + os=-elf + ;; + mips*-cisco) + os=-elf + ;; + mips*-*) + os=-elf + ;; + or32-*) + os=-coff + ;; + *-tti) # must be before sparc entry or we get the wrong os. + os=-sysv3 + ;; + sparc-* | *-sun) + os=-sunos4.1.1 + ;; + *-be) + os=-beos + ;; + *-haiku) + os=-haiku + ;; + *-ibm) + os=-aix + ;; + *-knuth) + os=-mmixware + ;; + *-wec) + os=-proelf + ;; + *-winbond) + os=-proelf + ;; + *-oki) + os=-proelf + ;; + *-hp) + os=-hpux + ;; + *-hitachi) + os=-hiux + ;; + i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) + os=-sysv + ;; + *-cbm) + os=-amigaos + ;; + *-dg) + os=-dgux + ;; + *-dolphin) + os=-sysv3 + ;; + m68k-ccur) + os=-rtu + ;; + m88k-omron*) + os=-luna + ;; + *-next ) + os=-nextstep + ;; + *-sequent) + os=-ptx + ;; + *-crds) + os=-unos + ;; + *-ns) + os=-genix + ;; + i370-*) + os=-mvs + ;; + *-next) + os=-nextstep3 + ;; + *-gould) + os=-sysv + ;; + *-highlevel) + os=-bsd + ;; + *-encore) + os=-bsd + ;; + *-sgi) + os=-irix + ;; + *-siemens) + os=-sysv4 + ;; + *-masscomp) + os=-rtu + ;; + f30[01]-fujitsu | f700-fujitsu) + os=-uxpv + ;; + *-rom68k) + os=-coff + ;; + *-*bug) + os=-coff + ;; + *-apple) + os=-macos + ;; + *-atari*) + os=-mint + ;; + *) + os=-none + ;; +esac +fi + +# Here we handle the case where we know the os, and the CPU type, but not the +# manufacturer. We pick the logical manufacturer. +vendor=unknown +case $basic_machine in + *-unknown) + case $os in + -riscix*) + vendor=acorn + ;; + -sunos*) + vendor=sun + ;; + -cnk*|-aix*) + vendor=ibm + ;; + -beos*) + vendor=be + ;; + -hpux*) + vendor=hp + ;; + -mpeix*) + vendor=hp + ;; + -hiux*) + vendor=hitachi + ;; + -unos*) + vendor=crds + ;; + -dgux*) + vendor=dg + ;; + -luna*) + vendor=omron + ;; + -genix*) + vendor=ns + ;; + -mvs* | -opened*) + vendor=ibm + ;; + -os400*) + vendor=ibm + ;; + -ptx*) + vendor=sequent + ;; + -tpf*) + vendor=ibm + ;; + -vxsim* | -vxworks* | -windiss*) + vendor=wrs + ;; + -aux*) + vendor=apple + ;; + -hms*) + vendor=hitachi + ;; + -mpw* | -macos*) + vendor=apple + ;; + -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) + vendor=atari + ;; + -vos*) + vendor=stratus + ;; + esac + basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` + ;; +esac + +echo $basic_machine$os +exit + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "timestamp='" +# time-stamp-format: "%:y-%02m-%02d" +# time-stamp-end: "'" +# End: diff --git a/Externals/SDL/build-scripts/fatbuild.sh b/Externals/SDL/build-scripts/fatbuild.sh new file mode 100755 index 0000000000..b4b1616746 --- /dev/null +++ b/Externals/SDL/build-scripts/fatbuild.sh @@ -0,0 +1,316 @@ +#!/bin/sh +# +# Build a fat binary on Mac OS X, thanks Ryan! + +# Number of CPUs (for make -j) +NCPU=`sysctl -n hw.ncpu` +NJOB=$NCPU +#NJOB=`expr $NCPU + 1` + +# Generic, cross-platform CFLAGS you always want go here. +CFLAGS="-O3 -g -pipe" + +# Locate Xcode SDK path +SDK_PATH=/Developer/SDKs +if [ ! -d $SDK_PATH ]; then + echo "Couldn't find SDK path" + exit 1 +fi + +# See if we can use 10.2 or 10.3 runtime compatibility +if [ -d "$SDK_PATH/MacOSX10.2.8.sdk" ]; then + # PowerPC configure flags (10.2 runtime compatibility) + # We dynamically load X11, so using the system X11 headers is fine. + CONFIG_PPC="--build=`uname -p`-apple-darwin --host=powerpc-apple-darwin \ +--x-includes=/usr/X11R6/include --x-libraries=/usr/X11R6/lib" + + # PowerPC compiler flags + CC_PPC="gcc-3.3 -arch ppc" + CXX_PPC="g++-3.3 -arch ppc" + CFLAGS_PPC="" + CPPFLAGS_PPC="-DMAC_OS_X_VERSION_MIN_REQUIRED=1020 \ +-nostdinc \ +-F$SDK_PATH/MacOSX10.2.8.sdk/System/Library/Frameworks \ +-I$SDK_PATH/MacOSX10.2.8.sdk/usr/include/gcc/darwin/3.3 \ +-isystem $SDK_PATH/MacOSX10.2.8.sdk/usr/include" + + # PowerPC linker flags + LFLAGS_PPC="-Wl,-headerpad_max_install_names -arch ppc \ +-L$SDK_PATH/MacOSX10.2.8.sdk/usr/lib/gcc/darwin/3.3 \ +-F$SDK_PATH/MacOSX10.2.8.sdk/System/Library/Frameworks \ +-Wl,-syslibroot,$SDK_PATH/MacOSX10.2.8.sdk" + +else # 10.2 or 10.3 SDK + + # PowerPC configure flags (10.3 runtime compatibility) + # We dynamically load X11, so using the system X11 headers is fine. + CONFIG_PPC="--build=`uname -p`-apple-darwin --host=powerpc-apple-darwin \ +--x-includes=/usr/X11R6/include --x-libraries=/usr/X11R6/lib" + + # PowerPC compiler flags + CC_PPC="gcc-4.0 -arch ppc" + CXX_PPC="g++-4.0 -arch ppc" + CFLAGS_PPC="" + CPPFLAGS_PPC="-DMAC_OS_X_VERSION_MIN_REQUIRED=1030 \ +-nostdinc \ +-F$SDK_PATH/MacOSX10.3.9.sdk/System/Library/Frameworks \ +-I$SDK_PATH/MacOSX10.3.9.sdk/usr/lib/gcc/powerpc-apple-darwin9/4.0.1/include \ +-isystem $SDK_PATH/MacOSX10.3.9.sdk/usr/include" + + # PowerPC linker flags + LFLAGS_PPC="-Wl,-headerpad_max_install_names -arch ppc -mmacosx-version-min=10.3 \ +-L$SDK_PATH/MacOSX10.3.9.sdk/usr/lib/gcc/powerpc-apple-darwin9/4.0.1 \ +-F$SDK_PATH/MacOSX10.3.9.sdk/System/Library/Frameworks \ +-Wl,-syslibroot,$SDK_PATH/MacOSX10.3.9.sdk" + +fi # 10.2 or 10.3 SDK + +# Intel configure flags (10.4 runtime compatibility) +# We dynamically load X11, so using the system X11 headers is fine. +CONFIG_X86="--build=`uname -p`-apple-darwin --host=i386-apple-darwin \ +--x-includes=/usr/X11R6/include --x-libraries=/usr/X11R6/lib" + +# Intel compiler flags +CC_X86="gcc-4.0 -arch i386" +CXX_X86="g++-4.0 -arch i386" +CFLAGS_X86="-mmacosx-version-min=10.4" +CPPFLAGS_X86="-DMAC_OS_X_VERSION_MIN_REQUIRED=1040 \ +-nostdinc \ +-F$SDK_PATH/MacOSX10.4u.sdk/System/Library/Frameworks \ +-I$SDK_PATH/MacOSX10.4u.sdk/usr/lib/gcc/i686-apple-darwin9/4.0.1/include \ +-isystem $SDK_PATH/MacOSX10.4u.sdk/usr/include" + +# Intel linker flags +LFLAGS_X86="-Wl,-headerpad_max_install_names -arch i386 -mmacosx-version-min=10.4 \ +-L$SDK_PATH/MacOSX10.4u.sdk/usr/lib/gcc/i686-apple-darwin9/4.0.1 \ +-Wl,-syslibroot,$SDK_PATH/MacOSX10.4u.sdk" + +# +# Find the configure script +# +srcdir=`dirname $0`/.. +auxdir=$srcdir/build-scripts +cd $srcdir + +# +# Figure out which phase to build: +# all, +# configure, configure-ppc, configure-x86, +# make, make-ppc, make-x86, merge +# install +# clean +if test x"$1" = x; then + phase=all +else + phase="$1" +fi +case $phase in + all) + configure_ppc="yes" + configure_x86="yes" + make_ppc="yes" + make_x86="yes" + merge="yes" + ;; + configure) + configure_ppc="yes" + configure_x86="yes" + ;; + configure-ppc) + configure_ppc="yes" + ;; + configure-x86) + configure_x86="yes" + ;; + make) + make_ppc="yes" + make_x86="yes" + merge="yes" + ;; + make-ppc) + make_ppc="yes" + ;; + make-x86) + make_x86="yes" + ;; + merge) + merge="yes" + ;; + install) + install_bin="yes" + install_hdrs="yes" + install_lib="yes" + install_data="yes" + install_man="yes" + ;; + install-bin) + install_bin="yes" + ;; + install-hdrs) + install_hdrs="yes" + ;; + install-lib) + install_lib="yes" + ;; + install-data) + install_data="yes" + ;; + install-man) + install_man="yes" + ;; + clean) + clean_ppc="yes" + clean_x86="yes" + ;; + clean-ppc) + clean_ppc="yes" + ;; + clean-x86) + clean_x86="yes" + ;; + *) + echo "Usage: $0 [all|configure[-ppc|-x86]|make[-ppc|-x86]|merge|install|clean]" + exit 1 + ;; +esac +case `uname -p` in + powerpc) + native_path=ppc + ;; + *86) + native_path=x86 + ;; + *) + echo "Couldn't figure out native architecture path" + exit 1 + ;; +esac + +# +# Create the build directories +# +for dir in build build/ppc build/x86; do + if test -d $dir; then + : + else + mkdir $dir || exit 1 + fi +done + +# +# Build the PowerPC binary +# +if test x$configure_ppc = xyes; then + (cd build/ppc && \ + sh ../../configure $CONFIG_PPC CC="$CC_PPC" CXX="$CXX_PPC" CFLAGS="$CFLAGS $CFLAGS_PPC" CPPFLAGS="$CPPFLAGS_PPC" LDFLAGS="$LFLAGS_PPC") || exit 2 +fi +if test x$make_ppc = xyes; then + (cd build/ppc && ls include && make -j$NJOB) || exit 3 +fi + +# +# Build the Intel binary +# +if test x$configure_x86 = xyes; then + (cd build/x86 && \ + sh ../../configure $CONFIG_X86 CC="$CC_X86" CXX="$CXX_X86" CFLAGS="$CFLAGS $CFLAGS_X86" CPPFLAGS="$CPPFLAGS_X86" LDFLAGS="$LFLAGS_X86") || exit 2 +fi +if test x$make_x86 = xyes; then + (cd build/x86 && make -j$NJOB) || exit 3 +fi + +# +# Combine into fat binary +# +if test x$merge = xyes; then + output=.libs + sh $auxdir/mkinstalldirs build/$output + cd build + target=`find . -mindepth 3 -type f -name '*.dylib' | head -1 | sed 's|.*/||'` + (lipo -create -o $output/$target `find . -mindepth 3 -type f -name "*.dylib"` && + ln -sf $target $output/libSDL-1.2.0.dylib && + ln -sf $target $output/libSDL.dylib && + lipo -create -o $output/libSDL.a */build/.libs/libSDL.a && + cp $native_path/build/.libs/libSDL.la $output && + cp $native_path/build/.libs/libSDL.lai $output && + cp $native_path/build/libSDL.la . && + lipo -create -o libSDLmain.a */build/libSDLmain.a && + echo "Build complete!" && + echo "Files can be found in the build directory.") || exit 4 + cd .. +fi + +# +# Install +# +do_install() +{ + echo $* + $* || exit 5 +} +if test x$prefix = x; then + prefix=/usr/local +fi +if test x$exec_prefix = x; then + exec_prefix=$prefix +fi +if test x$bindir = x; then + bindir=$exec_prefix/bin +fi +if test x$libdir = x; then + libdir=$exec_prefix/lib +fi +if test x$includedir = x; then + includedir=$prefix/include +fi +if test x$datadir = x; then + datadir=$prefix/share +fi +if test x$mandir = x; then + mandir=$prefix/man +fi +if test x$install_bin = xyes; then + do_install sh $auxdir/mkinstalldirs $bindir + do_install /usr/bin/install -c -m 755 build/$native_path/sdl-config $bindir/sdl-config +fi +if test x$install_hdrs = xyes; then + do_install sh $auxdir/mkinstalldirs $includedir/SDL + for src in $srcdir/include/*.h; do \ + file=`echo $src | sed -e 's|^.*/||'`; \ + do_install /usr/bin/install -c -m 644 $src $includedir/SDL/$file; \ + done + do_install /usr/bin/install -c -m 644 $srcdir/include/SDL_config_macosx.h $includedir/SDL/SDL_config.h +fi +if test x$install_lib = xyes; then + do_install sh $auxdir/mkinstalldirs $libdir + do_install sh build/$native_path/libtool --mode=install /usr/bin/install -c build/libSDL.la $libdir/libSDL.la + do_install /usr/bin/install -c -m 644 build/libSDLmain.a $libdir/libSDLmain.a + do_install ranlib $libdir/libSDLmain.a +fi +if test x$install_data = xyes; then + do_install sh $auxdir/mkinstalldirs $datadir/aclocal + do_install /usr/bin/install -c -m 644 $srcdir/sdl.m4 $datadir/aclocal/sdl.m4 +fi +if test x$install_man = xyes; then + do_install sh $auxdir/mkinstalldirs $mandir/man3 + for src in $srcdir/docs/man3/*.3; do \ + file=`echo $src | sed -e 's|^.*/||'`; \ + do_install /usr/bin/install -c -m 644 $src $mandir/man3/$file; \ + done +fi + +# +# Clean up +# +do_clean() +{ + echo $* + $* || exit 6 +} +if test x$clean_x86 = xyes; then + do_clean rm -r build/x86 +fi +if test x$clean_ppc = xyes; then + do_clean rm -r build/ppc +fi + diff --git a/Externals/SDL/build-scripts/install-sh b/Externals/SDL/build-scripts/install-sh new file mode 100755 index 0000000000..1a8353401c --- /dev/null +++ b/Externals/SDL/build-scripts/install-sh @@ -0,0 +1,323 @@ +#!/bin/sh +# install - install a program, script, or datafile + +scriptversion=2005-02-02.21 + +# This originates from X11R5 (mit/util/scripts/install.sh), which was +# later released in X11R6 (xc/config/util/install.sh) with the +# following copyright and license. +# +# Copyright (C) 1994 X Consortium +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to +# deal in the Software without restriction, including without limitation the +# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +# sell copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN +# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- +# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# +# Except as contained in this notice, the name of the X Consortium shall not +# be used in advertising or otherwise to promote the sale, use or other deal- +# ings in this Software without prior written authorization from the X Consor- +# tium. +# +# +# FSF changes to this file are in the public domain. +# +# Calling this script install-sh is preferred over install.sh, to prevent +# `make' implicit rules from creating a file called install from it +# when there is no Makefile. +# +# This script is compatible with the BSD install script, but was written +# from scratch. It can only install one file at a time, a restriction +# shared with many OS's install programs. + +# set DOITPROG to echo to test this script + +# Don't use :- since 4.3BSD and earlier shells don't like it. +doit="${DOITPROG-}" + +# put in absolute paths if you don't have them in your path; or use env. vars. + +mvprog="${MVPROG-mv}" +cpprog="${CPPROG-cp}" +chmodprog="${CHMODPROG-chmod}" +chownprog="${CHOWNPROG-chown}" +chgrpprog="${CHGRPPROG-chgrp}" +stripprog="${STRIPPROG-strip}" +rmprog="${RMPROG-rm}" +mkdirprog="${MKDIRPROG-mkdir}" + +chmodcmd="$chmodprog 0755" +chowncmd= +chgrpcmd= +stripcmd= +rmcmd="$rmprog -f" +mvcmd="$mvprog" +src= +dst= +dir_arg= +dstarg= +no_target_directory= + +usage="Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE + or: $0 [OPTION]... SRCFILES... DIRECTORY + or: $0 [OPTION]... -t DIRECTORY SRCFILES... + or: $0 [OPTION]... -d DIRECTORIES... + +In the 1st form, copy SRCFILE to DSTFILE. +In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. +In the 4th, create DIRECTORIES. + +Options: +-c (ignored) +-d create directories instead of installing files. +-g GROUP $chgrpprog installed files to GROUP. +-m MODE $chmodprog installed files to MODE. +-o USER $chownprog installed files to USER. +-s $stripprog installed files. +-t DIRECTORY install into DIRECTORY. +-T report an error if DSTFILE is a directory. +--help display this help and exit. +--version display version info and exit. + +Environment variables override the default commands: + CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG +" + +while test -n "$1"; do + case $1 in + -c) shift + continue;; + + -d) dir_arg=true + shift + continue;; + + -g) chgrpcmd="$chgrpprog $2" + shift + shift + continue;; + + --help) echo "$usage"; exit $?;; + + -m) chmodcmd="$chmodprog $2" + shift + shift + continue;; + + -o) chowncmd="$chownprog $2" + shift + shift + continue;; + + -s) stripcmd=$stripprog + shift + continue;; + + -t) dstarg=$2 + shift + shift + continue;; + + -T) no_target_directory=true + shift + continue;; + + --version) echo "$0 $scriptversion"; exit $?;; + + *) # When -d is used, all remaining arguments are directories to create. + # When -t is used, the destination is already specified. + test -n "$dir_arg$dstarg" && break + # Otherwise, the last argument is the destination. Remove it from $@. + for arg + do + if test -n "$dstarg"; then + # $@ is not empty: it contains at least $arg. + set fnord "$@" "$dstarg" + shift # fnord + fi + shift # arg + dstarg=$arg + done + break;; + esac +done + +if test -z "$1"; then + if test -z "$dir_arg"; then + echo "$0: no input file specified." >&2 + exit 1 + fi + # It's OK to call `install-sh -d' without argument. + # This can happen when creating conditional directories. + exit 0 +fi + +for src +do + # Protect names starting with `-'. + case $src in + -*) src=./$src ;; + esac + + if test -n "$dir_arg"; then + dst=$src + src= + + if test -d "$dst"; then + mkdircmd=: + chmodcmd= + else + mkdircmd=$mkdirprog + fi + else + # Waiting for this to be detected by the "$cpprog $src $dsttmp" command + # might cause directories to be created, which would be especially bad + # if $src (and thus $dsttmp) contains '*'. + if test ! -f "$src" && test ! -d "$src"; then + echo "$0: $src does not exist." >&2 + exit 1 + fi + + if test -z "$dstarg"; then + echo "$0: no destination specified." >&2 + exit 1 + fi + + dst=$dstarg + # Protect names starting with `-'. + case $dst in + -*) dst=./$dst ;; + esac + + # If destination is a directory, append the input filename; won't work + # if double slashes aren't ignored. + if test -d "$dst"; then + if test -n "$no_target_directory"; then + echo "$0: $dstarg: Is a directory" >&2 + exit 1 + fi + dst=$dst/`basename "$src"` + fi + fi + + # This sed command emulates the dirname command. + dstdir=`echo "$dst" | sed -e 's,/*$,,;s,[^/]*$,,;s,/*$,,;s,^$,.,'` + + # Make sure that the destination directory exists. + + # Skip lots of stat calls in the usual case. + if test ! -d "$dstdir"; then + defaultIFS=' + ' + IFS="${IFS-$defaultIFS}" + + oIFS=$IFS + # Some sh's can't handle IFS=/ for some reason. + IFS='%' + set x `echo "$dstdir" | sed -e 's@/@%@g' -e 's@^%@/@'` + shift + IFS=$oIFS + + pathcomp= + + while test $# -ne 0 ; do + pathcomp=$pathcomp$1 + shift + if test ! -d "$pathcomp"; then + $mkdirprog "$pathcomp" + # mkdir can fail with a `File exist' error in case several + # install-sh are creating the directory concurrently. This + # is OK. + test -d "$pathcomp" || exit + fi + pathcomp=$pathcomp/ + done + fi + + if test -n "$dir_arg"; then + $doit $mkdircmd "$dst" \ + && { test -z "$chowncmd" || $doit $chowncmd "$dst"; } \ + && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } \ + && { test -z "$stripcmd" || $doit $stripcmd "$dst"; } \ + && { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; } + + else + dstfile=`basename "$dst"` + + # Make a couple of temp file names in the proper directory. + dsttmp=$dstdir/_inst.$$_ + rmtmp=$dstdir/_rm.$$_ + + # Trap to clean up those temp files at exit. + trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 + trap '(exit $?); exit' 1 2 13 15 + + # Copy the file name to the temp name. + $doit $cpprog "$src" "$dsttmp" && + + # and set any options; do chmod last to preserve setuid bits. + # + # If any of these fail, we abort the whole thing. If we want to + # ignore errors from any of these, just make sure not to ignore + # errors from the above "$doit $cpprog $src $dsttmp" command. + # + { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \ + && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \ + && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \ + && { test -z "$chmodcmd" || $doit $chmodcmd "$dsttmp"; } && + + # Now rename the file to the real destination. + { $doit $mvcmd -f "$dsttmp" "$dstdir/$dstfile" 2>/dev/null \ + || { + # The rename failed, perhaps because mv can't rename something else + # to itself, or perhaps because mv is so ancient that it does not + # support -f. + + # Now remove or move aside any old file at destination location. + # We try this two ways since rm can't unlink itself on some + # systems and the destination file might be busy for other + # reasons. In this case, the final cleanup might fail but the new + # file should still install successfully. + { + if test -f "$dstdir/$dstfile"; then + $doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null \ + || $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null \ + || { + echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2 + (exit 1); exit 1 + } + else + : + fi + } && + + # Now rename the file to the real destination. + $doit $mvcmd "$dsttmp" "$dstdir/$dstfile" + } + } + fi || { (exit 1); exit 1; } +done + +# The final little trick to "correctly" pass the exit status to the exit trap. +{ + (exit 0); exit 0 +} + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-end: "$" +# End: diff --git a/Externals/SDL/build-scripts/ltmain.sh b/Externals/SDL/build-scripts/ltmain.sh new file mode 100644 index 0000000000..d2b860f42d --- /dev/null +++ b/Externals/SDL/build-scripts/ltmain.sh @@ -0,0 +1,8407 @@ +# Generated from ltmain.m4sh. + +# ltmain.sh (GNU libtool) 2.2.6 +# Written by Gordon Matzigkeit , 1996 + +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, 2007 2008 Free Software Foundation, Inc. +# This is free software; see the source for copying conditions. There is NO +# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +# GNU Libtool is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# As a special exception to the GNU General Public License, +# if you distribute this file as part of a program or library that +# is built using GNU Libtool, you may include this file under the +# same distribution terms that you use for the rest of that program. +# +# GNU Libtool is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Libtool; see the file COPYING. If not, a copy +# can be downloaded from http://www.gnu.org/licenses/gpl.html, +# or obtained by writing to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + +# Usage: $progname [OPTION]... [MODE-ARG]... +# +# Provide generalized library-building support services. +# +# --config show all configuration variables +# --debug enable verbose shell tracing +# -n, --dry-run display commands without modifying any files +# --features display basic configuration information and exit +# --mode=MODE use operation mode MODE +# --preserve-dup-deps don't remove duplicate dependency libraries +# --quiet, --silent don't print informational messages +# --tag=TAG use configuration variables from tag TAG +# -v, --verbose print informational messages (default) +# --version print version information +# -h, --help print short or long help message +# +# MODE must be one of the following: +# +# clean remove files from the build directory +# compile compile a source file into a libtool object +# execute automatically set library path, then run a program +# finish complete the installation of libtool libraries +# install install libraries or executables +# link create a library or an executable +# uninstall remove libraries from an installed directory +# +# MODE-ARGS vary depending on the MODE. +# Try `$progname --help --mode=MODE' for a more detailed description of MODE. +# +# When reporting a bug, please describe a test case to reproduce it and +# include the following information: +# +# host-triplet: $host +# shell: $SHELL +# compiler: $LTCC +# compiler flags: $LTCFLAGS +# linker: $LD (gnu? $with_gnu_ld) +# $progname: (GNU libtool) 2.2.6 +# automake: $automake_version +# autoconf: $autoconf_version +# +# Report bugs to . + +PROGRAM=ltmain.sh +PACKAGE=libtool +VERSION=2.2.6 +TIMESTAMP="" +package_revision=1.3012 + +# Be Bourne compatible +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac +fi +BIN_SH=xpg4; export BIN_SH # for Tru64 +DUALCASE=1; export DUALCASE # for MKS sh + +# NLS nuisances: We save the old values to restore during execute mode. +# Only set LANG and LC_ALL to C if already set. +# These must not be set unconditionally because not all systems understand +# e.g. LANG=C (notably SCO). +lt_user_locale= +lt_safe_locale= +for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES +do + eval "if test \"\${$lt_var+set}\" = set; then + save_$lt_var=\$$lt_var + $lt_var=C + export $lt_var + lt_user_locale=\"$lt_var=\\\$save_\$lt_var; \$lt_user_locale\" + lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\" + fi" +done + +$lt_unset CDPATH + + + + + +: ${CP="cp -f"} +: ${ECHO="echo"} +: ${EGREP="/usr/bin/grep -E"} +: ${FGREP="/usr/bin/grep -F"} +: ${GREP="/usr/bin/grep"} +: ${LN_S="ln -s"} +: ${MAKE="make"} +: ${MKDIR="mkdir"} +: ${MV="mv -f"} +: ${RM="rm -f"} +: ${SED="/opt/local/bin/gsed"} +: ${SHELL="${CONFIG_SHELL-/bin/sh}"} +: ${Xsed="$SED -e 1s/^X//"} + +# Global variables: +EXIT_SUCCESS=0 +EXIT_FAILURE=1 +EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing. +EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake. + +exit_status=$EXIT_SUCCESS + +# Make sure IFS has a sensible default +lt_nl=' +' +IFS=" $lt_nl" + +dirname="s,/[^/]*$,," +basename="s,^.*/,," + +# func_dirname_and_basename file append nondir_replacement +# perform func_basename and func_dirname in a single function +# call: +# dirname: Compute the dirname of FILE. If nonempty, +# add APPEND to the result, otherwise set result +# to NONDIR_REPLACEMENT. +# value returned in "$func_dirname_result" +# basename: Compute filename of FILE. +# value retuned in "$func_basename_result" +# Implementation must be kept synchronized with func_dirname +# and func_basename. For efficiency, we do not delegate to +# those functions but instead duplicate the functionality here. +func_dirname_and_basename () +{ + # Extract subdirectory from the argument. + func_dirname_result=`$ECHO "X${1}" | $Xsed -e "$dirname"` + if test "X$func_dirname_result" = "X${1}"; then + func_dirname_result="${3}" + else + func_dirname_result="$func_dirname_result${2}" + fi + func_basename_result=`$ECHO "X${1}" | $Xsed -e "$basename"` +} + +# Generated shell functions inserted here. + +# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh +# is ksh but when the shell is invoked as "sh" and the current value of +# the _XPG environment variable is not equal to 1 (one), the special +# positional parameter $0, within a function call, is the name of the +# function. +progpath="$0" + +# The name of this program: +# In the unlikely event $progname began with a '-', it would play havoc with +# func_echo (imagine progname=-n), so we prepend ./ in that case: +func_dirname_and_basename "$progpath" +progname=$func_basename_result +case $progname in + -*) progname=./$progname ;; +esac + +# Make sure we have an absolute path for reexecution: +case $progpath in + [\\/]*|[A-Za-z]:\\*) ;; + *[\\/]*) + progdir=$func_dirname_result + progdir=`cd "$progdir" && pwd` + progpath="$progdir/$progname" + ;; + *) + save_IFS="$IFS" + IFS=: + for progdir in $PATH; do + IFS="$save_IFS" + test -x "$progdir/$progname" && break + done + IFS="$save_IFS" + test -n "$progdir" || progdir=`pwd` + progpath="$progdir/$progname" + ;; +esac + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed="${SED}"' -e 1s/^X//' +sed_quote_subst='s/\([`"$\\]\)/\\\1/g' + +# Same as above, but do not quote variable references. +double_quote_subst='s/\(["`\\]\)/\\\1/g' + +# Re-`\' parameter expansions in output of double_quote_subst that were +# `\'-ed in input to the same. If an odd number of `\' preceded a '$' +# in input to double_quote_subst, that '$' was protected from expansion. +# Since each input `\' is now two `\'s, look for any number of runs of +# four `\'s followed by two `\'s and then a '$'. `\' that '$'. +bs='\\' +bs2='\\\\' +bs4='\\\\\\\\' +dollar='\$' +sed_double_backslash="\ + s/$bs4/&\\ +/g + s/^$bs2$dollar/$bs&/ + s/\\([^$bs]\\)$bs2$dollar/\\1$bs2$bs$dollar/g + s/\n//g" + +# Standard options: +opt_dry_run=false +opt_help=false +opt_quiet=false +opt_verbose=false +opt_warning=: + +# func_echo arg... +# Echo program name prefixed message, along with the current mode +# name if it has been set yet. +func_echo () +{ + $ECHO "$progname${mode+: }$mode: $*" +} + +# func_verbose arg... +# Echo program name prefixed message in verbose mode only. +func_verbose () +{ + $opt_verbose && func_echo ${1+"$@"} + + # A bug in bash halts the script if the last line of a function + # fails when set -e is in force, so we need another command to + # work around that: + : +} + +# func_error arg... +# Echo program name prefixed message to standard error. +func_error () +{ + $ECHO "$progname${mode+: }$mode: "${1+"$@"} 1>&2 +} + +# func_warning arg... +# Echo program name prefixed warning message to standard error. +func_warning () +{ + $opt_warning && $ECHO "$progname${mode+: }$mode: warning: "${1+"$@"} 1>&2 + + # bash bug again: + : +} + +# func_fatal_error arg... +# Echo program name prefixed message to standard error, and exit. +func_fatal_error () +{ + func_error ${1+"$@"} + exit $EXIT_FAILURE +} + +# func_fatal_help arg... +# Echo program name prefixed message to standard error, followed by +# a help hint, and exit. +func_fatal_help () +{ + func_error ${1+"$@"} + func_fatal_error "$help" +} +help="Try \`$progname --help' for more information." ## default + + +# func_grep expression filename +# Check whether EXPRESSION matches any line of FILENAME, without output. +func_grep () +{ + $GREP "$1" "$2" >/dev/null 2>&1 +} + + +# func_mkdir_p directory-path +# Make sure the entire path to DIRECTORY-PATH is available. +func_mkdir_p () +{ + my_directory_path="$1" + my_dir_list= + + if test -n "$my_directory_path" && test "$opt_dry_run" != ":"; then + + # Protect directory names starting with `-' + case $my_directory_path in + -*) my_directory_path="./$my_directory_path" ;; + esac + + # While some portion of DIR does not yet exist... + while test ! -d "$my_directory_path"; do + # ...make a list in topmost first order. Use a colon delimited + # list incase some portion of path contains whitespace. + my_dir_list="$my_directory_path:$my_dir_list" + + # If the last portion added has no slash in it, the list is done + case $my_directory_path in */*) ;; *) break ;; esac + + # ...otherwise throw away the child directory and loop + my_directory_path=`$ECHO "X$my_directory_path" | $Xsed -e "$dirname"` + done + my_dir_list=`$ECHO "X$my_dir_list" | $Xsed -e 's,:*$,,'` + + save_mkdir_p_IFS="$IFS"; IFS=':' + for my_dir in $my_dir_list; do + IFS="$save_mkdir_p_IFS" + # mkdir can fail with a `File exist' error if two processes + # try to create one of the directories concurrently. Don't + # stop in that case! + $MKDIR "$my_dir" 2>/dev/null || : + done + IFS="$save_mkdir_p_IFS" + + # Bail out if we (or some other process) failed to create a directory. + test -d "$my_directory_path" || \ + func_fatal_error "Failed to create \`$1'" + fi +} + + +# func_mktempdir [string] +# Make a temporary directory that won't clash with other running +# libtool processes, and avoids race conditions if possible. If +# given, STRING is the basename for that directory. +func_mktempdir () +{ + my_template="${TMPDIR-/tmp}/${1-$progname}" + + if test "$opt_dry_run" = ":"; then + # Return a directory name, but don't create it in dry-run mode + my_tmpdir="${my_template}-$$" + else + + # If mktemp works, use that first and foremost + my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null` + + if test ! -d "$my_tmpdir"; then + # Failing that, at least try and use $RANDOM to avoid a race + my_tmpdir="${my_template}-${RANDOM-0}$$" + + save_mktempdir_umask=`umask` + umask 0077 + $MKDIR "$my_tmpdir" + umask $save_mktempdir_umask + fi + + # If we're not in dry-run mode, bomb out on failure + test -d "$my_tmpdir" || \ + func_fatal_error "cannot create temporary directory \`$my_tmpdir'" + fi + + $ECHO "X$my_tmpdir" | $Xsed +} + + +# func_quote_for_eval arg +# Aesthetically quote ARG to be evaled later. +# This function returns two values: FUNC_QUOTE_FOR_EVAL_RESULT +# is double-quoted, suitable for a subsequent eval, whereas +# FUNC_QUOTE_FOR_EVAL_UNQUOTED_RESULT has merely all characters +# which are still active within double quotes backslashified. +func_quote_for_eval () +{ + case $1 in + *[\\\`\"\$]*) + func_quote_for_eval_unquoted_result=`$ECHO "X$1" | $Xsed -e "$sed_quote_subst"` ;; + *) + func_quote_for_eval_unquoted_result="$1" ;; + esac + + case $func_quote_for_eval_unquoted_result in + # Double-quote args containing shell metacharacters to delay + # word splitting, command substitution and and variable + # expansion for a subsequent eval. + # Many Bourne shells cannot handle close brackets correctly + # in scan sets, so we specify it separately. + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + func_quote_for_eval_result="\"$func_quote_for_eval_unquoted_result\"" + ;; + *) + func_quote_for_eval_result="$func_quote_for_eval_unquoted_result" + esac +} + + +# func_quote_for_expand arg +# Aesthetically quote ARG to be evaled later; same as above, +# but do not quote variable references. +func_quote_for_expand () +{ + case $1 in + *[\\\`\"]*) + my_arg=`$ECHO "X$1" | $Xsed \ + -e "$double_quote_subst" -e "$sed_double_backslash"` ;; + *) + my_arg="$1" ;; + esac + + case $my_arg in + # Double-quote args containing shell metacharacters to delay + # word splitting and command substitution for a subsequent eval. + # Many Bourne shells cannot handle close brackets correctly + # in scan sets, so we specify it separately. + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + my_arg="\"$my_arg\"" + ;; + esac + + func_quote_for_expand_result="$my_arg" +} + + +# func_show_eval cmd [fail_exp] +# Unless opt_silent is true, then output CMD. Then, if opt_dryrun is +# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP +# is given, then evaluate it. +func_show_eval () +{ + my_cmd="$1" + my_fail_exp="${2-:}" + + ${opt_silent-false} || { + func_quote_for_expand "$my_cmd" + eval "func_echo $func_quote_for_expand_result" + } + + if ${opt_dry_run-false}; then :; else + eval "$my_cmd" + my_status=$? + if test "$my_status" -eq 0; then :; else + eval "(exit $my_status); $my_fail_exp" + fi + fi +} + + +# func_show_eval_locale cmd [fail_exp] +# Unless opt_silent is true, then output CMD. Then, if opt_dryrun is +# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP +# is given, then evaluate it. Use the saved locale for evaluation. +func_show_eval_locale () +{ + my_cmd="$1" + my_fail_exp="${2-:}" + + ${opt_silent-false} || { + func_quote_for_expand "$my_cmd" + eval "func_echo $func_quote_for_expand_result" + } + + if ${opt_dry_run-false}; then :; else + eval "$lt_user_locale + $my_cmd" + my_status=$? + eval "$lt_safe_locale" + if test "$my_status" -eq 0; then :; else + eval "(exit $my_status); $my_fail_exp" + fi + fi +} + + + + + +# func_version +# Echo version message to standard output and exit. +func_version () +{ + $SED -n '/^# '$PROGRAM' (GNU /,/# warranty; / { + s/^# // + s/^# *$// + s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/ + p + }' < "$progpath" + exit $? +} + +# func_usage +# Echo short help message to standard output and exit. +func_usage () +{ + $SED -n '/^# Usage:/,/# -h/ { + s/^# // + s/^# *$// + s/\$progname/'$progname'/ + p + }' < "$progpath" + $ECHO + $ECHO "run \`$progname --help | more' for full usage" + exit $? +} + +# func_help +# Echo long help message to standard output and exit. +func_help () +{ + $SED -n '/^# Usage:/,/# Report bugs to/ { + s/^# // + s/^# *$// + s*\$progname*'$progname'* + s*\$host*'"$host"'* + s*\$SHELL*'"$SHELL"'* + s*\$LTCC*'"$LTCC"'* + s*\$LTCFLAGS*'"$LTCFLAGS"'* + s*\$LD*'"$LD"'* + s/\$with_gnu_ld/'"$with_gnu_ld"'/ + s/\$automake_version/'"`(automake --version) 2>/dev/null |$SED 1q`"'/ + s/\$autoconf_version/'"`(autoconf --version) 2>/dev/null |$SED 1q`"'/ + p + }' < "$progpath" + exit $? +} + +# func_missing_arg argname +# Echo program name prefixed message to standard error and set global +# exit_cmd. +func_missing_arg () +{ + func_error "missing argument for $1" + exit_cmd=exit +} + +exit_cmd=: + + + + + +# Check that we have a working $ECHO. +if test "X$1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X$1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t'; then + # Yippee, $ECHO works! + : +else + # Restart under the correct shell, and then maybe $ECHO will work. + exec $SHELL "$progpath" --no-reexec ${1+"$@"} +fi + +if test "X$1" = X--fallback-echo; then + # used as fallback echo + shift + cat </dev/null 2>&1; then + taglist="$taglist $tagname" + + # Evaluate the configuration. Be careful to quote the path + # and the sed script, to avoid splitting on whitespace, but + # also don't use non-portable quotes within backquotes within + # quotes we have to do it in 2 steps: + extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` + eval "$extractedcf" + else + func_error "ignoring unknown tag $tagname" + fi + ;; + esac +} + +# Parse options once, thoroughly. This comes as soon as possible in +# the script to make things like `libtool --version' happen quickly. +{ + + # Shorthand for --mode=foo, only valid as the first argument + case $1 in + clean|clea|cle|cl) + shift; set dummy --mode clean ${1+"$@"}; shift + ;; + compile|compil|compi|comp|com|co|c) + shift; set dummy --mode compile ${1+"$@"}; shift + ;; + execute|execut|execu|exec|exe|ex|e) + shift; set dummy --mode execute ${1+"$@"}; shift + ;; + finish|finis|fini|fin|fi|f) + shift; set dummy --mode finish ${1+"$@"}; shift + ;; + install|instal|insta|inst|ins|in|i) + shift; set dummy --mode install ${1+"$@"}; shift + ;; + link|lin|li|l) + shift; set dummy --mode link ${1+"$@"}; shift + ;; + uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) + shift; set dummy --mode uninstall ${1+"$@"}; shift + ;; + esac + + # Parse non-mode specific arguments: + while test "$#" -gt 0; do + opt="$1" + shift + + case $opt in + --config) func_config ;; + + --debug) preserve_args="$preserve_args $opt" + func_echo "enabling shell trace mode" + opt_debug='set -x' + $opt_debug + ;; + + -dlopen) test "$#" -eq 0 && func_missing_arg "$opt" && break + execute_dlfiles="$execute_dlfiles $1" + shift + ;; + + --dry-run | -n) opt_dry_run=: ;; + --features) func_features ;; + --finish) mode="finish" ;; + + --mode) test "$#" -eq 0 && func_missing_arg "$opt" && break + case $1 in + # Valid mode arguments: + clean) ;; + compile) ;; + execute) ;; + finish) ;; + install) ;; + link) ;; + relink) ;; + uninstall) ;; + + # Catch anything else as an error + *) func_error "invalid argument for $opt" + exit_cmd=exit + break + ;; + esac + + mode="$1" + shift + ;; + + --preserve-dup-deps) + opt_duplicate_deps=: ;; + + --quiet|--silent) preserve_args="$preserve_args $opt" + opt_silent=: + ;; + + --verbose| -v) preserve_args="$preserve_args $opt" + opt_silent=false + ;; + + --tag) test "$#" -eq 0 && func_missing_arg "$opt" && break + preserve_args="$preserve_args $opt $1" + func_enable_tag "$1" # tagname is set here + shift + ;; + + # Separate optargs to long options: + -dlopen=*|--mode=*|--tag=*) + func_opt_split "$opt" + set dummy "$func_opt_split_opt" "$func_opt_split_arg" ${1+"$@"} + shift + ;; + + -\?|-h) func_usage ;; + --help) opt_help=: ;; + --version) func_version ;; + + -*) func_fatal_help "unrecognized option \`$opt'" ;; + + *) nonopt="$opt" + break + ;; + esac + done + + + case $host in + *cygwin* | *mingw* | *pw32* | *cegcc*) + # don't eliminate duplications in $postdeps and $predeps + opt_duplicate_compiler_generated_deps=: + ;; + *) + opt_duplicate_compiler_generated_deps=$opt_duplicate_deps + ;; + esac + + # Having warned about all mis-specified options, bail out if + # anything was wrong. + $exit_cmd $EXIT_FAILURE +} + +# func_check_version_match +# Ensure that we are using m4 macros, and libtool script from the same +# release of libtool. +func_check_version_match () +{ + if test "$package_revision" != "$macro_revision"; then + if test "$VERSION" != "$macro_version"; then + if test -z "$macro_version"; then + cat >&2 <<_LT_EOF +$progname: Version mismatch error. This is $PACKAGE $VERSION, but the +$progname: definition of this LT_INIT comes from an older release. +$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION +$progname: and run autoconf again. +_LT_EOF + else + cat >&2 <<_LT_EOF +$progname: Version mismatch error. This is $PACKAGE $VERSION, but the +$progname: definition of this LT_INIT comes from $PACKAGE $macro_version. +$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION +$progname: and run autoconf again. +_LT_EOF + fi + else + cat >&2 <<_LT_EOF +$progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, +$progname: but the definition of this LT_INIT comes from revision $macro_revision. +$progname: You should recreate aclocal.m4 with macros from revision $package_revision +$progname: of $PACKAGE $VERSION and run autoconf again. +_LT_EOF + fi + + exit $EXIT_MISMATCH + fi +} + + +## ----------- ## +## Main. ## +## ----------- ## + +$opt_help || { + # Sanity checks first: + func_check_version_match + + if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then + func_fatal_configuration "not configured to build any kind of library" + fi + + test -z "$mode" && func_fatal_error "error: you must specify a MODE." + + + # Darwin sucks + eval std_shrext=\"$shrext_cmds\" + + + # Only execute mode is allowed to have -dlopen flags. + if test -n "$execute_dlfiles" && test "$mode" != execute; then + func_error "unrecognized option \`-dlopen'" + $ECHO "$help" 1>&2 + exit $EXIT_FAILURE + fi + + # Change the help message to a mode-specific one. + generic_help="$help" + help="Try \`$progname --help --mode=$mode' for more information." +} + + +# func_lalib_p file +# True iff FILE is a libtool `.la' library or `.lo' object file. +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_lalib_p () +{ + test -f "$1" && + $SED -e 4q "$1" 2>/dev/null \ + | $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 +} + +# func_lalib_unsafe_p file +# True iff FILE is a libtool `.la' library or `.lo' object file. +# This function implements the same check as func_lalib_p without +# resorting to external programs. To this end, it redirects stdin and +# closes it afterwards, without saving the original file descriptor. +# As a safety measure, use it only where a negative result would be +# fatal anyway. Works if `file' does not exist. +func_lalib_unsafe_p () +{ + lalib_p=no + if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then + for lalib_p_l in 1 2 3 4 + do + read lalib_p_line + case "$lalib_p_line" in + \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; + esac + done + exec 0<&5 5<&- + fi + test "$lalib_p" = yes +} + +# func_ltwrapper_script_p file +# True iff FILE is a libtool wrapper script +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_ltwrapper_script_p () +{ + func_lalib_p "$1" +} + +# func_ltwrapper_executable_p file +# True iff FILE is a libtool wrapper executable +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_ltwrapper_executable_p () +{ + func_ltwrapper_exec_suffix= + case $1 in + *.exe) ;; + *) func_ltwrapper_exec_suffix=.exe ;; + esac + $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1 +} + +# func_ltwrapper_scriptname file +# Assumes file is an ltwrapper_executable +# uses $file to determine the appropriate filename for a +# temporary ltwrapper_script. +func_ltwrapper_scriptname () +{ + func_ltwrapper_scriptname_result="" + if func_ltwrapper_executable_p "$1"; then + func_dirname_and_basename "$1" "" "." + func_stripname '' '.exe' "$func_basename_result" + func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper" + fi +} + +# func_ltwrapper_p file +# True iff FILE is a libtool wrapper script or wrapper executable +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_ltwrapper_p () +{ + func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" +} + + +# func_execute_cmds commands fail_cmd +# Execute tilde-delimited COMMANDS. +# If FAIL_CMD is given, eval that upon failure. +# FAIL_CMD may read-access the current command in variable CMD! +func_execute_cmds () +{ + $opt_debug + save_ifs=$IFS; IFS='~' + for cmd in $1; do + IFS=$save_ifs + eval cmd=\"$cmd\" + func_show_eval "$cmd" "${2-:}" + done + IFS=$save_ifs +} + + +# func_source file +# Source FILE, adding directory component if necessary. +# Note that it is not necessary on cygwin/mingw to append a dot to +# FILE even if both FILE and FILE.exe exist: automatic-append-.exe +# behavior happens only for exec(3), not for open(2)! Also, sourcing +# `FILE.' does not work on cygwin managed mounts. +func_source () +{ + $opt_debug + case $1 in + */* | *\\*) . "$1" ;; + *) . "./$1" ;; + esac +} + + +# func_infer_tag arg +# Infer tagged configuration to use if any are available and +# if one wasn't chosen via the "--tag" command line option. +# Only attempt this if the compiler in the base compile +# command doesn't match the default compiler. +# arg is usually of the form 'gcc ...' +func_infer_tag () +{ + $opt_debug + if test -n "$available_tags" && test -z "$tagname"; then + CC_quoted= + for arg in $CC; do + func_quote_for_eval "$arg" + CC_quoted="$CC_quoted $func_quote_for_eval_result" + done + case $@ in + # Blanks in the command may have been stripped by the calling shell, + # but not from the CC environment variable when configure was run. + " $CC "* | "$CC "* | " `$ECHO $CC` "* | "`$ECHO $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$ECHO $CC_quoted` "* | "`$ECHO $CC_quoted` "*) ;; + # Blanks at the start of $base_compile will cause this to fail + # if we don't check for them as well. + *) + for z in $available_tags; do + if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then + # Evaluate the configuration. + eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" + CC_quoted= + for arg in $CC; do + # Double-quote args containing other shell metacharacters. + func_quote_for_eval "$arg" + CC_quoted="$CC_quoted $func_quote_for_eval_result" + done + case "$@ " in + " $CC "* | "$CC "* | " `$ECHO $CC` "* | "`$ECHO $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$ECHO $CC_quoted` "* | "`$ECHO $CC_quoted` "*) + # The compiler in the base compile command matches + # the one in the tagged configuration. + # Assume this is the tagged configuration we want. + tagname=$z + break + ;; + esac + fi + done + # If $tagname still isn't set, then no tagged configuration + # was found and let the user know that the "--tag" command + # line option must be used. + if test -z "$tagname"; then + func_echo "unable to infer tagged configuration" + func_fatal_error "specify a tag with \`--tag'" +# else +# func_verbose "using $tagname tagged configuration" + fi + ;; + esac + fi +} + + + +# func_write_libtool_object output_name pic_name nonpic_name +# Create a libtool object file (analogous to a ".la" file), +# but don't create it if we're doing a dry run. +func_write_libtool_object () +{ + write_libobj=${1} + if test "$build_libtool_libs" = yes; then + write_lobj=\'${2}\' + else + write_lobj=none + fi + + if test "$build_old_libs" = yes; then + write_oldobj=\'${3}\' + else + write_oldobj=none + fi + + $opt_dry_run || { + cat >${write_libobj}T <?"'"'"' &()|`$[]' \ + && func_warning "libobj name \`$libobj' may not contain shell special characters." + func_dirname_and_basename "$obj" "/" "" + objname="$func_basename_result" + xdir="$func_dirname_result" + lobj=${xdir}$objdir/$objname + + test -z "$base_compile" && \ + func_fatal_help "you must specify a compilation command" + + # Delete any leftover library objects. + if test "$build_old_libs" = yes; then + removelist="$obj $lobj $libobj ${libobj}T" + else + removelist="$lobj $libobj ${libobj}T" + fi + + # On Cygwin there's no "real" PIC flag so we must build both object types + case $host_os in + cygwin* | mingw* | pw32* | os2* | cegcc*) + pic_mode=default + ;; + esac + if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then + # non-PIC code in shared libraries is not supported + pic_mode=default + fi + + # Calculate the filename of the output object if compiler does + # not support -o with -c + if test "$compiler_c_o" = no; then + output_obj=`$ECHO "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext} + lockfile="$output_obj.lock" + else + output_obj= + need_locks=no + lockfile= + fi + + # Lock this critical section if it is needed + # We use this script file to make the link, it avoids creating a new file + if test "$need_locks" = yes; then + until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do + func_echo "Waiting for $lockfile to be removed" + sleep 2 + done + elif test "$need_locks" = warn; then + if test -f "$lockfile"; then + $ECHO "\ +*** ERROR, $lockfile exists and contains: +`cat $lockfile 2>/dev/null` + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $opt_dry_run || $RM $removelist + exit $EXIT_FAILURE + fi + removelist="$removelist $output_obj" + $ECHO "$srcfile" > "$lockfile" + fi + + $opt_dry_run || $RM $removelist + removelist="$removelist $lockfile" + trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 + + if test -n "$fix_srcfile_path"; then + eval srcfile=\"$fix_srcfile_path\" + fi + func_quote_for_eval "$srcfile" + qsrcfile=$func_quote_for_eval_result + + # Only build a PIC object if we are building libtool libraries. + if test "$build_libtool_libs" = yes; then + # Without this assignment, base_compile gets emptied. + fbsd_hideous_sh_bug=$base_compile + + if test "$pic_mode" != no; then + command="$base_compile $qsrcfile $pic_flag" + else + # Don't build PIC code + command="$base_compile $qsrcfile" + fi + + func_mkdir_p "$xdir$objdir" + + if test -z "$output_obj"; then + # Place PIC objects in $objdir + command="$command -o $lobj" + fi + + func_show_eval_locale "$command" \ + 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' + + if test "$need_locks" = warn && + test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then + $ECHO "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` + +but it should contain: +$srcfile + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $opt_dry_run || $RM $removelist + exit $EXIT_FAILURE + fi + + # Just move the object if needed, then go on to compile the next one + if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then + func_show_eval '$MV "$output_obj" "$lobj"' \ + 'error=$?; $opt_dry_run || $RM $removelist; exit $error' + fi + + # Allow error messages only from the first compilation. + if test "$suppress_opt" = yes; then + suppress_output=' >/dev/null 2>&1' + fi + fi + + # Only build a position-dependent object if we build old libraries. + if test "$build_old_libs" = yes; then + if test "$pic_mode" != yes; then + # Don't build PIC code + command="$base_compile $qsrcfile$pie_flag" + else + command="$base_compile $qsrcfile $pic_flag" + fi + if test "$compiler_c_o" = yes; then + command="$command -o $obj" + fi + + # Suppress compiler output if we already did a PIC compilation. + command="$command$suppress_output" + func_show_eval_locale "$command" \ + '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' + + if test "$need_locks" = warn && + test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then + $ECHO "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` + +but it should contain: +$srcfile + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $opt_dry_run || $RM $removelist + exit $EXIT_FAILURE + fi + + # Just move the object if needed + if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then + func_show_eval '$MV "$output_obj" "$obj"' \ + 'error=$?; $opt_dry_run || $RM $removelist; exit $error' + fi + fi + + $opt_dry_run || { + func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" + + # Unlock the critical section if it was locked + if test "$need_locks" != no; then + removelist=$lockfile + $RM "$lockfile" + fi + } + + exit $EXIT_SUCCESS +} + +$opt_help || { +test "$mode" = compile && func_mode_compile ${1+"$@"} +} + +func_mode_help () +{ + # We need to display help for each of the modes. + case $mode in + "") + # Generic help is extracted from the usage comments + # at the start of this file. + func_help + ;; + + clean) + $ECHO \ +"Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... + +Remove files from the build directory. + +RM is the name of the program to use to delete files associated with each FILE +(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed +to RM. + +If FILE is a libtool library, object or program, all the files associated +with it are deleted. Otherwise, only FILE itself is deleted using RM." + ;; + + compile) + $ECHO \ +"Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE + +Compile a source file into a libtool library object. + +This mode accepts the following additional options: + + -o OUTPUT-FILE set the output file name to OUTPUT-FILE + -no-suppress do not suppress compiler output for multiple passes + -prefer-pic try to building PIC objects only + -prefer-non-pic try to building non-PIC objects only + -shared do not build a \`.o' file suitable for static linking + -static only build a \`.o' file suitable for static linking + +COMPILE-COMMAND is a command to be used in creating a \`standard' object file +from the given SOURCEFILE. + +The output file name is determined by removing the directory component from +SOURCEFILE, then substituting the C source code suffix \`.c' with the +library object suffix, \`.lo'." + ;; + + execute) + $ECHO \ +"Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... + +Automatically set library path, then run a program. + +This mode accepts the following additional options: + + -dlopen FILE add the directory containing FILE to the library path + +This mode sets the library path environment variable according to \`-dlopen' +flags. + +If any of the ARGS are libtool executable wrappers, then they are translated +into their corresponding uninstalled binary, and any of their required library +directories are added to the library path. + +Then, COMMAND is executed, with ARGS as arguments." + ;; + + finish) + $ECHO \ +"Usage: $progname [OPTION]... --mode=finish [LIBDIR]... + +Complete the installation of libtool libraries. + +Each LIBDIR is a directory that contains libtool libraries. + +The commands that this mode executes may require superuser privileges. Use +the \`--dry-run' option if you just want to see what would be executed." + ;; + + install) + $ECHO \ +"Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... + +Install executables or libraries. + +INSTALL-COMMAND is the installation command. The first component should be +either the \`install' or \`cp' program. + +The following components of INSTALL-COMMAND are treated specially: + + -inst-prefix PREFIX-DIR Use PREFIX-DIR as a staging area for installation + +The rest of the components are interpreted as arguments to that command (only +BSD-compatible install options are recognized)." + ;; + + link) + $ECHO \ +"Usage: $progname [OPTION]... --mode=link LINK-COMMAND... + +Link object files or libraries together to form another library, or to +create an executable program. + +LINK-COMMAND is a command using the C compiler that you would use to create +a program from several object files. + +The following components of LINK-COMMAND are treated specially: + + -all-static do not do any dynamic linking at all + -avoid-version do not add a version suffix if possible + -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime + -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols + -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) + -export-symbols SYMFILE + try to export only the symbols listed in SYMFILE + -export-symbols-regex REGEX + try to export only the symbols matching REGEX + -LLIBDIR search LIBDIR for required installed libraries + -lNAME OUTPUT-FILE requires the installed library libNAME + -module build a library that can dlopened + -no-fast-install disable the fast-install mode + -no-install link a not-installable executable + -no-undefined declare that a library does not refer to external symbols + -o OUTPUT-FILE create OUTPUT-FILE from the specified objects + -objectlist FILE Use a list of object files found in FILE to specify objects + -precious-files-regex REGEX + don't remove output files matching REGEX + -release RELEASE specify package release information + -rpath LIBDIR the created library will eventually be installed in LIBDIR + -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries + -shared only do dynamic linking of libtool libraries + -shrext SUFFIX override the standard shared library file extension + -static do not do any dynamic linking of uninstalled libtool libraries + -static-libtool-libs + do not do any dynamic linking of libtool libraries + -version-info CURRENT[:REVISION[:AGE]] + specify library version info [each variable defaults to 0] + -weak LIBNAME declare that the target provides the LIBNAME interface + +All other options (arguments beginning with \`-') are ignored. + +Every other argument is treated as a filename. Files ending in \`.la' are +treated as uninstalled libtool libraries, other files are standard or library +object files. + +If the OUTPUT-FILE ends in \`.la', then a libtool library is created, +only library objects (\`.lo' files) may be specified, and \`-rpath' is +required, except when creating a convenience library. + +If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created +using \`ar' and \`ranlib', or on Windows using \`lib'. + +If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file +is created, otherwise an executable program is created." + ;; + + uninstall) + $ECHO \ +"Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... + +Remove libraries from an installation directory. + +RM is the name of the program to use to delete files associated with each FILE +(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed +to RM. + +If FILE is a libtool library, all the files associated with it are deleted. +Otherwise, only FILE itself is deleted using RM." + ;; + + *) + func_fatal_help "invalid operation mode \`$mode'" + ;; + esac + + $ECHO + $ECHO "Try \`$progname --help' for more information about other modes." + + exit $? +} + + # Now that we've collected a possible --mode arg, show help if necessary + $opt_help && func_mode_help + + +# func_mode_execute arg... +func_mode_execute () +{ + $opt_debug + # The first argument is the command name. + cmd="$nonopt" + test -z "$cmd" && \ + func_fatal_help "you must specify a COMMAND" + + # Handle -dlopen flags immediately. + for file in $execute_dlfiles; do + test -f "$file" \ + || func_fatal_help "\`$file' is not a file" + + dir= + case $file in + *.la) + # Check to see that this really is a libtool archive. + func_lalib_unsafe_p "$file" \ + || func_fatal_help "\`$lib' is not a valid libtool archive" + + # Read the libtool library. + dlname= + library_names= + func_source "$file" + + # Skip this library if it cannot be dlopened. + if test -z "$dlname"; then + # Warn if it was a shared library. + test -n "$library_names" && \ + func_warning "\`$file' was not linked with \`-export-dynamic'" + continue + fi + + func_dirname "$file" "" "." + dir="$func_dirname_result" + + if test -f "$dir/$objdir/$dlname"; then + dir="$dir/$objdir" + else + if test ! -f "$dir/$dlname"; then + func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" + fi + fi + ;; + + *.lo) + # Just add the directory containing the .lo file. + func_dirname "$file" "" "." + dir="$func_dirname_result" + ;; + + *) + func_warning "\`-dlopen' is ignored for non-libtool libraries and objects" + continue + ;; + esac + + # Get the absolute pathname. + absdir=`cd "$dir" && pwd` + test -n "$absdir" && dir="$absdir" + + # Now add the directory to shlibpath_var. + if eval "test -z \"\$$shlibpath_var\""; then + eval "$shlibpath_var=\"\$dir\"" + else + eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" + fi + done + + # This variable tells wrapper scripts just to set shlibpath_var + # rather than running their programs. + libtool_execute_magic="$magic" + + # Check if any of the arguments is a wrapper script. + args= + for file + do + case $file in + -*) ;; + *) + # Do a test to see if this is really a libtool program. + if func_ltwrapper_script_p "$file"; then + func_source "$file" + # Transform arg to wrapped name. + file="$progdir/$program" + elif func_ltwrapper_executable_p "$file"; then + func_ltwrapper_scriptname "$file" + func_source "$func_ltwrapper_scriptname_result" + # Transform arg to wrapped name. + file="$progdir/$program" + fi + ;; + esac + # Quote arguments (to preserve shell metacharacters). + func_quote_for_eval "$file" + args="$args $func_quote_for_eval_result" + done + + if test "X$opt_dry_run" = Xfalse; then + if test -n "$shlibpath_var"; then + # Export the shlibpath_var. + eval "export $shlibpath_var" + fi + + # Restore saved environment variables + for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES + do + eval "if test \"\${save_$lt_var+set}\" = set; then + $lt_var=\$save_$lt_var; export $lt_var + else + $lt_unset $lt_var + fi" + done + + # Now prepare to actually exec the command. + exec_cmd="\$cmd$args" + else + # Display what would be done. + if test -n "$shlibpath_var"; then + eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\"" + $ECHO "export $shlibpath_var" + fi + $ECHO "$cmd$args" + exit $EXIT_SUCCESS + fi +} + +test "$mode" = execute && func_mode_execute ${1+"$@"} + + +# func_mode_finish arg... +func_mode_finish () +{ + $opt_debug + libdirs="$nonopt" + admincmds= + + if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then + for dir + do + libdirs="$libdirs $dir" + done + + for libdir in $libdirs; do + if test -n "$finish_cmds"; then + # Do each command in the finish commands. + func_execute_cmds "$finish_cmds" 'admincmds="$admincmds +'"$cmd"'"' + fi + if test -n "$finish_eval"; then + # Do the single finish_eval. + eval cmds=\"$finish_eval\" + $opt_dry_run || eval "$cmds" || admincmds="$admincmds + $cmds" + fi + done + fi + + # Exit here if they wanted silent mode. + $opt_silent && exit $EXIT_SUCCESS + + $ECHO "X----------------------------------------------------------------------" | $Xsed + $ECHO "Libraries have been installed in:" + for libdir in $libdirs; do + $ECHO " $libdir" + done + $ECHO + $ECHO "If you ever happen to want to link against installed libraries" + $ECHO "in a given directory, LIBDIR, you must either use libtool, and" + $ECHO "specify the full pathname of the library, or use the \`-LLIBDIR'" + $ECHO "flag during linking and do at least one of the following:" + if test -n "$shlibpath_var"; then + $ECHO " - add LIBDIR to the \`$shlibpath_var' environment variable" + $ECHO " during execution" + fi + if test -n "$runpath_var"; then + $ECHO " - add LIBDIR to the \`$runpath_var' environment variable" + $ECHO " during linking" + fi + if test -n "$hardcode_libdir_flag_spec"; then + libdir=LIBDIR + eval flag=\"$hardcode_libdir_flag_spec\" + + $ECHO " - use the \`$flag' linker flag" + fi + if test -n "$admincmds"; then + $ECHO " - have your system administrator run these commands:$admincmds" + fi + if test -f /etc/ld.so.conf; then + $ECHO " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'" + fi + $ECHO + + $ECHO "See any operating system documentation about shared libraries for" + case $host in + solaris2.[6789]|solaris2.1[0-9]) + $ECHO "more information, such as the ld(1), crle(1) and ld.so(8) manual" + $ECHO "pages." + ;; + *) + $ECHO "more information, such as the ld(1) and ld.so(8) manual pages." + ;; + esac + $ECHO "X----------------------------------------------------------------------" | $Xsed + exit $EXIT_SUCCESS +} + +test "$mode" = finish && func_mode_finish ${1+"$@"} + + +# func_mode_install arg... +func_mode_install () +{ + $opt_debug + # There may be an optional sh(1) argument at the beginning of + # install_prog (especially on Windows NT). + if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh || + # Allow the use of GNU shtool's install command. + $ECHO "X$nonopt" | $GREP shtool >/dev/null; then + # Aesthetically quote it. + func_quote_for_eval "$nonopt" + install_prog="$func_quote_for_eval_result " + arg=$1 + shift + else + install_prog= + arg=$nonopt + fi + + # The real first argument should be the name of the installation program. + # Aesthetically quote it. + func_quote_for_eval "$arg" + install_prog="$install_prog$func_quote_for_eval_result" + + # We need to accept at least all the BSD install flags. + dest= + files= + opts= + prev= + install_type= + isdir=no + stripme= + for arg + do + if test -n "$dest"; then + files="$files $dest" + dest=$arg + continue + fi + + case $arg in + -d) isdir=yes ;; + -f) + case " $install_prog " in + *[\\\ /]cp\ *) ;; + *) prev=$arg ;; + esac + ;; + -g | -m | -o) + prev=$arg + ;; + -s) + stripme=" -s" + continue + ;; + -*) + ;; + *) + # If the previous option needed an argument, then skip it. + if test -n "$prev"; then + prev= + else + dest=$arg + continue + fi + ;; + esac + + # Aesthetically quote the argument. + func_quote_for_eval "$arg" + install_prog="$install_prog $func_quote_for_eval_result" + done + + test -z "$install_prog" && \ + func_fatal_help "you must specify an install program" + + test -n "$prev" && \ + func_fatal_help "the \`$prev' option requires an argument" + + if test -z "$files"; then + if test -z "$dest"; then + func_fatal_help "no file or destination specified" + else + func_fatal_help "you must specify a destination" + fi + fi + + # Strip any trailing slash from the destination. + func_stripname '' '/' "$dest" + dest=$func_stripname_result + + # Check to see that the destination is a directory. + test -d "$dest" && isdir=yes + if test "$isdir" = yes; then + destdir="$dest" + destname= + else + func_dirname_and_basename "$dest" "" "." + destdir="$func_dirname_result" + destname="$func_basename_result" + + # Not a directory, so check to see that there is only one file specified. + set dummy $files; shift + test "$#" -gt 1 && \ + func_fatal_help "\`$dest' is not a directory" + fi + case $destdir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + for file in $files; do + case $file in + *.lo) ;; + *) + func_fatal_help "\`$destdir' must be an absolute directory name" + ;; + esac + done + ;; + esac + + # This variable tells wrapper scripts just to set variables rather + # than running their programs. + libtool_install_magic="$magic" + + staticlibs= + future_libdirs= + current_libdirs= + for file in $files; do + + # Do each installation. + case $file in + *.$libext) + # Do the static libraries later. + staticlibs="$staticlibs $file" + ;; + + *.la) + # Check to see that this really is a libtool archive. + func_lalib_unsafe_p "$file" \ + || func_fatal_help "\`$file' is not a valid libtool archive" + + library_names= + old_library= + relink_command= + func_source "$file" + + # Add the libdir to current_libdirs if it is the destination. + if test "X$destdir" = "X$libdir"; then + case "$current_libdirs " in + *" $libdir "*) ;; + *) current_libdirs="$current_libdirs $libdir" ;; + esac + else + # Note the libdir as a future libdir. + case "$future_libdirs " in + *" $libdir "*) ;; + *) future_libdirs="$future_libdirs $libdir" ;; + esac + fi + + func_dirname "$file" "/" "" + dir="$func_dirname_result" + dir="$dir$objdir" + + if test -n "$relink_command"; then + # Determine the prefix the user has applied to our future dir. + inst_prefix_dir=`$ECHO "X$destdir" | $Xsed -e "s%$libdir\$%%"` + + # Don't allow the user to place us outside of our expected + # location b/c this prevents finding dependent libraries that + # are installed to the same prefix. + # At present, this check doesn't affect windows .dll's that + # are installed into $libdir/../bin (currently, that works fine) + # but it's something to keep an eye on. + test "$inst_prefix_dir" = "$destdir" && \ + func_fatal_error "error: cannot install \`$file' to a directory not ending in $libdir" + + if test -n "$inst_prefix_dir"; then + # Stick the inst_prefix_dir data into the link command. + relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` + else + relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%%"` + fi + + func_warning "relinking \`$file'" + func_show_eval "$relink_command" \ + 'func_fatal_error "error: relink \`$file'\'' with the above command before installing it"' + fi + + # See the names of the shared library. + set dummy $library_names; shift + if test -n "$1"; then + realname="$1" + shift + + srcname="$realname" + test -n "$relink_command" && srcname="$realname"T + + # Install the shared library and build the symlinks. + func_show_eval "$install_prog $dir/$srcname $destdir/$realname" \ + 'exit $?' + tstripme="$stripme" + case $host_os in + cygwin* | mingw* | pw32* | cegcc*) + case $realname in + *.dll.a) + tstripme="" + ;; + esac + ;; + esac + if test -n "$tstripme" && test -n "$striplib"; then + func_show_eval "$striplib $destdir/$realname" 'exit $?' + fi + + if test "$#" -gt 0; then + # Delete the old symlinks, and create new ones. + # Try `ln -sf' first, because the `ln' binary might depend on + # the symlink we replace! Solaris /bin/ln does not understand -f, + # so we also need to try rm && ln -s. + for linkname + do + test "$linkname" != "$realname" \ + && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" + done + fi + + # Do each command in the postinstall commands. + lib="$destdir/$realname" + func_execute_cmds "$postinstall_cmds" 'exit $?' + fi + + # Install the pseudo-library for information purposes. + func_basename "$file" + name="$func_basename_result" + instname="$dir/$name"i + func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' + + # Maybe install the static library, too. + test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library" + ;; + + *.lo) + # Install (i.e. copy) a libtool object. + + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile="$destdir/$destname" + else + func_basename "$file" + destfile="$func_basename_result" + destfile="$destdir/$destfile" + fi + + # Deduce the name of the destination old-style object file. + case $destfile in + *.lo) + func_lo2o "$destfile" + staticdest=$func_lo2o_result + ;; + *.$objext) + staticdest="$destfile" + destfile= + ;; + *) + func_fatal_help "cannot copy a libtool object to \`$destfile'" + ;; + esac + + # Install the libtool object if requested. + test -n "$destfile" && \ + func_show_eval "$install_prog $file $destfile" 'exit $?' + + # Install the old object if enabled. + if test "$build_old_libs" = yes; then + # Deduce the name of the old-style object file. + func_lo2o "$file" + staticobj=$func_lo2o_result + func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' + fi + exit $EXIT_SUCCESS + ;; + + *) + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile="$destdir/$destname" + else + func_basename "$file" + destfile="$func_basename_result" + destfile="$destdir/$destfile" + fi + + # If the file is missing, and there is a .exe on the end, strip it + # because it is most likely a libtool script we actually want to + # install + stripped_ext="" + case $file in + *.exe) + if test ! -f "$file"; then + func_stripname '' '.exe' "$file" + file=$func_stripname_result + stripped_ext=".exe" + fi + ;; + esac + + # Do a test to see if this is really a libtool program. + case $host in + *cygwin* | *mingw*) + if func_ltwrapper_executable_p "$file"; then + func_ltwrapper_scriptname "$file" + wrapper=$func_ltwrapper_scriptname_result + else + func_stripname '' '.exe' "$file" + wrapper=$func_stripname_result + fi + ;; + *) + wrapper=$file + ;; + esac + if func_ltwrapper_script_p "$wrapper"; then + notinst_deplibs= + relink_command= + + func_source "$wrapper" + + # Check the variables that should have been set. + test -z "$generated_by_libtool_version" && \ + func_fatal_error "invalid libtool wrapper script \`$wrapper'" + + finalize=yes + for lib in $notinst_deplibs; do + # Check to see that each library is installed. + libdir= + if test -f "$lib"; then + func_source "$lib" + fi + libfile="$libdir/"`$ECHO "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test + if test -n "$libdir" && test ! -f "$libfile"; then + func_warning "\`$lib' has not been installed in \`$libdir'" + finalize=no + fi + done + + relink_command= + func_source "$wrapper" + + outputname= + if test "$fast_install" = no && test -n "$relink_command"; then + $opt_dry_run || { + if test "$finalize" = yes; then + tmpdir=`func_mktempdir` + func_basename "$file$stripped_ext" + file="$func_basename_result" + outputname="$tmpdir/$file" + # Replace the output file specification. + relink_command=`$ECHO "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'` + + $opt_silent || { + func_quote_for_expand "$relink_command" + eval "func_echo $func_quote_for_expand_result" + } + if eval "$relink_command"; then : + else + func_error "error: relink \`$file' with the above command before installing it" + $opt_dry_run || ${RM}r "$tmpdir" + continue + fi + file="$outputname" + else + func_warning "cannot relink \`$file'" + fi + } + else + # Install the binary that we compiled earlier. + file=`$ECHO "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"` + fi + fi + + # remove .exe since cygwin /usr/bin/install will append another + # one anyway + case $install_prog,$host in + */usr/bin/install*,*cygwin*) + case $file:$destfile in + *.exe:*.exe) + # this is ok + ;; + *.exe:*) + destfile=$destfile.exe + ;; + *:*.exe) + func_stripname '' '.exe' "$destfile" + destfile=$func_stripname_result + ;; + esac + ;; + esac + func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' + $opt_dry_run || if test -n "$outputname"; then + ${RM}r "$tmpdir" + fi + ;; + esac + done + + for file in $staticlibs; do + func_basename "$file" + name="$func_basename_result" + + # Set up the ranlib parameters. + oldlib="$destdir/$name" + + func_show_eval "$install_prog \$file \$oldlib" 'exit $?' + + if test -n "$stripme" && test -n "$old_striplib"; then + func_show_eval "$old_striplib $oldlib" 'exit $?' + fi + + # Do each command in the postinstall commands. + func_execute_cmds "$old_postinstall_cmds" 'exit $?' + done + + test -n "$future_libdirs" && \ + func_warning "remember to run \`$progname --finish$future_libdirs'" + + if test -n "$current_libdirs"; then + # Maybe just do a dry run. + $opt_dry_run && current_libdirs=" -n$current_libdirs" + exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs' + else + exit $EXIT_SUCCESS + fi +} + +test "$mode" = install && func_mode_install ${1+"$@"} + + +# func_generate_dlsyms outputname originator pic_p +# Extract symbols from dlprefiles and create ${outputname}S.o with +# a dlpreopen symbol table. +func_generate_dlsyms () +{ + $opt_debug + my_outputname="$1" + my_originator="$2" + my_pic_p="${3-no}" + my_prefix=`$ECHO "$my_originator" | sed 's%[^a-zA-Z0-9]%_%g'` + my_dlsyms= + + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + if test -n "$NM" && test -n "$global_symbol_pipe"; then + my_dlsyms="${my_outputname}S.c" + else + func_error "not configured to extract global symbols from dlpreopened files" + fi + fi + + if test -n "$my_dlsyms"; then + case $my_dlsyms in + "") ;; + *.c) + # Discover the nlist of each of the dlfiles. + nlist="$output_objdir/${my_outputname}.nm" + + func_show_eval "$RM $nlist ${nlist}S ${nlist}T" + + # Parse the name list into a source file. + func_verbose "creating $output_objdir/$my_dlsyms" + + $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ +/* $my_dlsyms - symbol resolution table for \`$my_outputname' dlsym emulation. */ +/* Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION */ + +#ifdef __cplusplus +extern \"C\" { +#endif + +/* External symbol declarations for the compiler. */\ +" + + if test "$dlself" = yes; then + func_verbose "generating symbol list for \`$output'" + + $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" + + # Add our own program objects to the symbol list. + progfiles=`$ECHO "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + for progfile in $progfiles; do + func_verbose "extracting global C symbols from \`$progfile'" + $opt_dry_run || eval "$NM $progfile | $global_symbol_pipe >> '$nlist'" + done + + if test -n "$exclude_expsyms"; then + $opt_dry_run || { + eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' + eval '$MV "$nlist"T "$nlist"' + } + fi + + if test -n "$export_symbols_regex"; then + $opt_dry_run || { + eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' + eval '$MV "$nlist"T "$nlist"' + } + fi + + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + export_symbols="$output_objdir/$outputname.exp" + $opt_dry_run || { + $RM $export_symbols + eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' + case $host in + *cygwin* | *mingw* | *cegcc* ) + eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' + eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' + ;; + esac + } + else + $opt_dry_run || { + eval "${SED} -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' + eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' + eval '$MV "$nlist"T "$nlist"' + case $host in + *cygwin | *mingw* | *cegcc* ) + eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' + eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' + ;; + esac + } + fi + fi + + for dlprefile in $dlprefiles; do + func_verbose "extracting global C symbols from \`$dlprefile'" + func_basename "$dlprefile" + name="$func_basename_result" + $opt_dry_run || { + eval '$ECHO ": $name " >> "$nlist"' + eval "$NM $dlprefile 2>/dev/null | $global_symbol_pipe >> '$nlist'" + } + done + + $opt_dry_run || { + # Make sure we have at least an empty file. + test -f "$nlist" || : > "$nlist" + + if test -n "$exclude_expsyms"; then + $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T + $MV "$nlist"T "$nlist" + fi + + # Try sorting and uniquifying the output. + if $GREP -v "^: " < "$nlist" | + if sort -k 3 /dev/null 2>&1; then + sort -k 3 + else + sort +2 + fi | + uniq > "$nlist"S; then + : + else + $GREP -v "^: " < "$nlist" > "$nlist"S + fi + + if test -f "$nlist"S; then + eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' + else + $ECHO '/* NONE */' >> "$output_objdir/$my_dlsyms" + fi + + $ECHO >> "$output_objdir/$my_dlsyms" "\ + +/* The mapping between symbol names and symbols. */ +typedef struct { + const char *name; + void *address; +} lt_dlsymlist; +" + case $host in + *cygwin* | *mingw* | *cegcc* ) + $ECHO >> "$output_objdir/$my_dlsyms" "\ +/* DATA imports from DLLs on WIN32 con't be const, because + runtime relocations are performed -- see ld's documentation + on pseudo-relocs. */" + lt_dlsym_const= ;; + *osf5*) + echo >> "$output_objdir/$my_dlsyms" "\ +/* This system does not cope well with relocations in const data */" + lt_dlsym_const= ;; + *) + lt_dlsym_const=const ;; + esac + + $ECHO >> "$output_objdir/$my_dlsyms" "\ +extern $lt_dlsym_const lt_dlsymlist +lt_${my_prefix}_LTX_preloaded_symbols[]; +$lt_dlsym_const lt_dlsymlist +lt_${my_prefix}_LTX_preloaded_symbols[] = +{\ + { \"$my_originator\", (void *) 0 }," + + case $need_lib_prefix in + no) + eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" + ;; + *) + eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" + ;; + esac + $ECHO >> "$output_objdir/$my_dlsyms" "\ + {0, (void *) 0} +}; + +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt_${my_prefix}_LTX_preloaded_symbols; +} +#endif + +#ifdef __cplusplus +} +#endif\ +" + } # !$opt_dry_run + + pic_flag_for_symtable= + case "$compile_command " in + *" -static "*) ;; + *) + case $host in + # compiling the symbol table file with pic_flag works around + # a FreeBSD bug that causes programs to crash when -lm is + # linked before any other PIC object. But we must not use + # pic_flag when linking with -static. The problem exists in + # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. + *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) + pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; + *-*-hpux*) + pic_flag_for_symtable=" $pic_flag" ;; + *) + if test "X$my_pic_p" != Xno; then + pic_flag_for_symtable=" $pic_flag" + fi + ;; + esac + ;; + esac + symtab_cflags= + for arg in $LTCFLAGS; do + case $arg in + -pie | -fpie | -fPIE) ;; + *) symtab_cflags="$symtab_cflags $arg" ;; + esac + done + + # Now compile the dynamic symbol file. + func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' + + # Clean up the generated files. + func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T"' + + # Transform the symbol file into the correct name. + symfileobj="$output_objdir/${my_outputname}S.$objext" + case $host in + *cygwin* | *mingw* | *cegcc* ) + if test -f "$output_objdir/$my_outputname.def"; then + compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` + finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` + else + compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` + finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` + fi + ;; + *) + compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` + finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"` + ;; + esac + ;; + *) + func_fatal_error "unknown suffix for \`$my_dlsyms'" + ;; + esac + else + # We keep going just in case the user didn't refer to + # lt_preloaded_symbols. The linker will fail if global_symbol_pipe + # really was required. + + # Nullify the symbol file. + compile_command=`$ECHO "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"` + finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"` + fi +} + +# func_win32_libid arg +# return the library type of file 'arg' +# +# Need a lot of goo to handle *both* DLLs and import libs +# Has to be a shell function in order to 'eat' the argument +# that is supplied when $file_magic_command is called. +func_win32_libid () +{ + $opt_debug + win32_libid_type="unknown" + win32_fileres=`file -L $1 2>/dev/null` + case $win32_fileres in + *ar\ archive\ import\ library*) # definitely import + win32_libid_type="x86 archive import" + ;; + *ar\ archive*) # could be an import, or static + if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | + $EGREP 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then + win32_nmres=`eval $NM -f posix -A $1 | + $SED -n -e ' + 1,100{ + / I /{ + s,.*,import, + p + q + } + }'` + case $win32_nmres in + import*) win32_libid_type="x86 archive import";; + *) win32_libid_type="x86 archive static";; + esac + fi + ;; + *DLL*) + win32_libid_type="x86 DLL" + ;; + *executable*) # but shell scripts are "executable" too... + case $win32_fileres in + *MS\ Windows\ PE\ Intel*) + win32_libid_type="x86 DLL" + ;; + esac + ;; + esac + $ECHO "$win32_libid_type" +} + + + +# func_extract_an_archive dir oldlib +func_extract_an_archive () +{ + $opt_debug + f_ex_an_ar_dir="$1"; shift + f_ex_an_ar_oldlib="$1" + func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" 'exit $?' + if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then + : + else + func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" + fi +} + + +# func_extract_archives gentop oldlib ... +func_extract_archives () +{ + $opt_debug + my_gentop="$1"; shift + my_oldlibs=${1+"$@"} + my_oldobjs="" + my_xlib="" + my_xabs="" + my_xdir="" + + for my_xlib in $my_oldlibs; do + # Extract the objects. + case $my_xlib in + [\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;; + *) my_xabs=`pwd`"/$my_xlib" ;; + esac + func_basename "$my_xlib" + my_xlib="$func_basename_result" + my_xlib_u=$my_xlib + while :; do + case " $extracted_archives " in + *" $my_xlib_u "*) + func_arith $extracted_serial + 1 + extracted_serial=$func_arith_result + my_xlib_u=lt$extracted_serial-$my_xlib ;; + *) break ;; + esac + done + extracted_archives="$extracted_archives $my_xlib_u" + my_xdir="$my_gentop/$my_xlib_u" + + func_mkdir_p "$my_xdir" + + case $host in + *-darwin*) + func_verbose "Extracting $my_xabs" + # Do not bother doing anything if just a dry run + $opt_dry_run || { + darwin_orig_dir=`pwd` + cd $my_xdir || exit $? + darwin_archive=$my_xabs + darwin_curdir=`pwd` + darwin_base_archive=`basename "$darwin_archive"` + darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` + if test -n "$darwin_arches"; then + darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` + darwin_arch= + func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" + for darwin_arch in $darwin_arches ; do + func_mkdir_p "unfat-$$/${darwin_base_archive}-${darwin_arch}" + $LIPO -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}" + cd "unfat-$$/${darwin_base_archive}-${darwin_arch}" + func_extract_an_archive "`pwd`" "${darwin_base_archive}" + cd "$darwin_curdir" + $RM "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" + done # $darwin_arches + ## Okay now we've a bunch of thin objects, gotta fatten them up :) + darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$basename" | sort -u` + darwin_file= + darwin_files= + for darwin_file in $darwin_filelist; do + darwin_files=`find unfat-$$ -name $darwin_file -print | $NL2SP` + $LIPO -create -output "$darwin_file" $darwin_files + done # $darwin_filelist + $RM -rf unfat-$$ + cd "$darwin_orig_dir" + else + cd $darwin_orig_dir + func_extract_an_archive "$my_xdir" "$my_xabs" + fi # $darwin_arches + } # !$opt_dry_run + ;; + *) + func_extract_an_archive "$my_xdir" "$my_xabs" + ;; + esac + my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP` + done + + func_extract_archives_result="$my_oldobjs" +} + + + +# func_emit_wrapper_part1 [arg=no] +# +# Emit the first part of a libtool wrapper script on stdout. +# For more information, see the description associated with +# func_emit_wrapper(), below. +func_emit_wrapper_part1 () +{ + func_emit_wrapper_part1_arg1=no + if test -n "$1" ; then + func_emit_wrapper_part1_arg1=$1 + fi + + $ECHO "\ +#! $SHELL + +# $output - temporary wrapper script for $objdir/$outputname +# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION +# +# The $output program cannot be directly executed until all the libtool +# libraries that it depends on are installed. +# +# This wrapper script should never be moved out of the build directory. +# If it is, it will not operate correctly. + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed='${SED} -e 1s/^X//' +sed_quote_subst='$sed_quote_subst' + +# Be Bourne compatible +if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which + # is contrary to our usage. Disable this feature. + alias -g '\${1+\"\$@\"}'='\"\$@\"' + setopt NO_GLOB_SUBST +else + case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac +fi +BIN_SH=xpg4; export BIN_SH # for Tru64 +DUALCASE=1; export DUALCASE # for MKS sh + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +relink_command=\"$relink_command\" + +# This environment variable determines our operation mode. +if test \"\$libtool_install_magic\" = \"$magic\"; then + # install mode needs the following variables: + generated_by_libtool_version='$macro_version' + notinst_deplibs='$notinst_deplibs' +else + # When we are sourced in execute mode, \$file and \$ECHO are already set. + if test \"\$libtool_execute_magic\" != \"$magic\"; then + ECHO=\"$qecho\" + file=\"\$0\" + # Make sure echo works. + if test \"X\$1\" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift + elif test \"X\`{ \$ECHO '\t'; } 2>/dev/null\`\" = 'X\t'; then + # Yippee, \$ECHO works! + : + else + # Restart under the correct shell, and then maybe \$ECHO will work. + exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"} + fi + fi\ +" + $ECHO "\ + + # Find the directory that this script lives in. + thisdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\` + test \"x\$thisdir\" = \"x\$file\" && thisdir=. + + # Follow symbolic links until we get to the real thisdir. + file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\` + while test -n \"\$file\"; do + destdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\` + + # If there was a directory component, then change thisdir. + if test \"x\$destdir\" != \"x\$file\"; then + case \"\$destdir\" in + [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; + *) thisdir=\"\$thisdir/\$destdir\" ;; + esac + fi + + file=\`\$ECHO \"X\$file\" | \$Xsed -e 's%^.*/%%'\` + file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\` + done +" +} +# end: func_emit_wrapper_part1 + +# func_emit_wrapper_part2 [arg=no] +# +# Emit the second part of a libtool wrapper script on stdout. +# For more information, see the description associated with +# func_emit_wrapper(), below. +func_emit_wrapper_part2 () +{ + func_emit_wrapper_part2_arg1=no + if test -n "$1" ; then + func_emit_wrapper_part2_arg1=$1 + fi + + $ECHO "\ + + # Usually 'no', except on cygwin/mingw when embedded into + # the cwrapper. + WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_part2_arg1 + if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then + # special case for '.' + if test \"\$thisdir\" = \".\"; then + thisdir=\`pwd\` + fi + # remove .libs from thisdir + case \"\$thisdir\" in + *[\\\\/]$objdir ) thisdir=\`\$ECHO \"X\$thisdir\" | \$Xsed -e 's%[\\\\/][^\\\\/]*$%%'\` ;; + $objdir ) thisdir=. ;; + esac + fi + + # Try to get the absolute directory name. + absdir=\`cd \"\$thisdir\" && pwd\` + test -n \"\$absdir\" && thisdir=\"\$absdir\" +" + + if test "$fast_install" = yes; then + $ECHO "\ + program=lt-'$outputname'$exeext + progdir=\"\$thisdir/$objdir\" + + if test ! -f \"\$progdir/\$program\" || + { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\ + test \"X\$file\" != \"X\$progdir/\$program\"; }; then + + file=\"\$\$-\$program\" + + if test ! -d \"\$progdir\"; then + $MKDIR \"\$progdir\" + else + $RM \"\$progdir/\$file\" + fi" + + $ECHO "\ + + # relink executable if necessary + if test -n \"\$relink_command\"; then + if relink_command_output=\`eval \$relink_command 2>&1\`; then : + else + $ECHO \"\$relink_command_output\" >&2 + $RM \"\$progdir/\$file\" + exit 1 + fi + fi + + $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || + { $RM \"\$progdir/\$program\"; + $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } + $RM \"\$progdir/\$file\" + fi" + else + $ECHO "\ + program='$outputname' + progdir=\"\$thisdir/$objdir\" +" + fi + + $ECHO "\ + + if test -f \"\$progdir/\$program\"; then" + + # Export our shlibpath_var if we have one. + if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then + $ECHO "\ + # Add our own library path to $shlibpath_var + $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" + + # Some systems cannot cope with colon-terminated $shlibpath_var + # The second colon is a workaround for a bug in BeOS R4 sed + $shlibpath_var=\`\$ECHO \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\` + + export $shlibpath_var +" + fi + + # fixup the dll searchpath if we need to. + if test -n "$dllsearchpath"; then + $ECHO "\ + # Add the dll search path components to the executable PATH + PATH=$dllsearchpath:\$PATH +" + fi + + $ECHO "\ + if test \"\$libtool_execute_magic\" != \"$magic\"; then + # Run the actual program with our arguments. +" + case $host in + # Backslashes separate directories on plain windows + *-*-mingw | *-*-os2* | *-cegcc*) + $ECHO "\ + exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} +" + ;; + + *) + $ECHO "\ + exec \"\$progdir/\$program\" \${1+\"\$@\"} +" + ;; + esac + $ECHO "\ + \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 + exit 1 + fi + else + # The program doesn't exist. + \$ECHO \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2 + \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 + $ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 + exit 1 + fi +fi\ +" +} +# end: func_emit_wrapper_part2 + + +# func_emit_wrapper [arg=no] +# +# Emit a libtool wrapper script on stdout. +# Don't directly open a file because we may want to +# incorporate the script contents within a cygwin/mingw +# wrapper executable. Must ONLY be called from within +# func_mode_link because it depends on a number of variables +# set therein. +# +# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR +# variable will take. If 'yes', then the emitted script +# will assume that the directory in which it is stored is +# the $objdir directory. This is a cygwin/mingw-specific +# behavior. +func_emit_wrapper () +{ + func_emit_wrapper_arg1=no + if test -n "$1" ; then + func_emit_wrapper_arg1=$1 + fi + + # split this up so that func_emit_cwrapperexe_src + # can call each part independently. + func_emit_wrapper_part1 "${func_emit_wrapper_arg1}" + func_emit_wrapper_part2 "${func_emit_wrapper_arg1}" +} + + +# func_to_host_path arg +# +# Convert paths to host format when used with build tools. +# Intended for use with "native" mingw (where libtool itself +# is running under the msys shell), or in the following cross- +# build environments: +# $build $host +# mingw (msys) mingw [e.g. native] +# cygwin mingw +# *nix + wine mingw +# where wine is equipped with the `winepath' executable. +# In the native mingw case, the (msys) shell automatically +# converts paths for any non-msys applications it launches, +# but that facility isn't available from inside the cwrapper. +# Similar accommodations are necessary for $host mingw and +# $build cygwin. Calling this function does no harm for other +# $host/$build combinations not listed above. +# +# ARG is the path (on $build) that should be converted to +# the proper representation for $host. The result is stored +# in $func_to_host_path_result. +func_to_host_path () +{ + func_to_host_path_result="$1" + if test -n "$1" ; then + case $host in + *mingw* ) + lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' + case $build in + *mingw* ) # actually, msys + # awkward: cmd appends spaces to result + lt_sed_strip_trailing_spaces="s/[ ]*\$//" + func_to_host_path_tmp1=`( cmd //c echo "$1" |\ + $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""` + func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\ + $SED -e "$lt_sed_naive_backslashify"` + ;; + *cygwin* ) + func_to_host_path_tmp1=`cygpath -w "$1"` + func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\ + $SED -e "$lt_sed_naive_backslashify"` + ;; + * ) + # Unfortunately, winepath does not exit with a non-zero + # error code, so we are forced to check the contents of + # stdout. On the other hand, if the command is not + # found, the shell will set an exit code of 127 and print + # *an error message* to stdout. So we must check for both + # error code of zero AND non-empty stdout, which explains + # the odd construction: + func_to_host_path_tmp1=`winepath -w "$1" 2>/dev/null` + if test "$?" -eq 0 && test -n "${func_to_host_path_tmp1}"; then + func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\ + $SED -e "$lt_sed_naive_backslashify"` + else + # Allow warning below. + func_to_host_path_result="" + fi + ;; + esac + if test -z "$func_to_host_path_result" ; then + #func_error "Could not determine host path corresponding to" + #func_error " '$1'" + #func_error "Continuing, but uninstalled executables may not work." + # Fallback: + func_to_host_path_result="$1" + fi + ;; + esac + fi +} +# end: func_to_host_path + +# func_to_host_pathlist arg +# +# Convert pathlists to host format when used with build tools. +# See func_to_host_path(), above. This function supports the +# following $build/$host combinations (but does no harm for +# combinations not listed here): +# $build $host +# mingw (msys) mingw [e.g. native] +# cygwin mingw +# *nix + wine mingw +# +# Path separators are also converted from $build format to +# $host format. If ARG begins or ends with a path separator +# character, it is preserved (but converted to $host format) +# on output. +# +# ARG is a pathlist (on $build) that should be converted to +# the proper representation on $host. The result is stored +# in $func_to_host_pathlist_result. +func_to_host_pathlist () +{ + func_to_host_pathlist_result="$1" + if test -n "$1" ; then + case $host in + *mingw* ) + lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' + # Remove leading and trailing path separator characters from + # ARG. msys behavior is inconsistent here, cygpath turns them + # into '.;' and ';.', and winepath ignores them completely. + func_to_host_pathlist_tmp2="$1" + # Once set for this call, this variable should not be + # reassigned. It is used in tha fallback case. + func_to_host_pathlist_tmp1=`echo "$func_to_host_pathlist_tmp2" |\ + $SED -e 's|^:*||' -e 's|:*$||'` + case $build in + *mingw* ) # Actually, msys. + # Awkward: cmd appends spaces to result. + lt_sed_strip_trailing_spaces="s/[ ]*\$//" + func_to_host_pathlist_tmp2=`( cmd //c echo "$func_to_host_pathlist_tmp1" |\ + $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""` + func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\ + $SED -e "$lt_sed_naive_backslashify"` + ;; + *cygwin* ) + func_to_host_pathlist_tmp2=`cygpath -w -p "$func_to_host_pathlist_tmp1"` + func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\ + $SED -e "$lt_sed_naive_backslashify"` + ;; + * ) + # unfortunately, winepath doesn't convert pathlists + func_to_host_pathlist_result="" + func_to_host_pathlist_oldIFS=$IFS + IFS=: + for func_to_host_pathlist_f in $func_to_host_pathlist_tmp1 ; do + IFS=$func_to_host_pathlist_oldIFS + if test -n "$func_to_host_pathlist_f" ; then + func_to_host_path "$func_to_host_pathlist_f" + if test -n "$func_to_host_path_result" ; then + if test -z "$func_to_host_pathlist_result" ; then + func_to_host_pathlist_result="$func_to_host_path_result" + else + func_to_host_pathlist_result="$func_to_host_pathlist_result;$func_to_host_path_result" + fi + fi + fi + IFS=: + done + IFS=$func_to_host_pathlist_oldIFS + ;; + esac + if test -z "$func_to_host_pathlist_result" ; then + func_error "Could not determine the host path(s) corresponding to" + func_error " '$1'" + func_error "Continuing, but uninstalled executables may not work." + # Fallback. This may break if $1 contains DOS-style drive + # specifications. The fix is not to complicate the expression + # below, but for the user to provide a working wine installation + # with winepath so that path translation in the cross-to-mingw + # case works properly. + lt_replace_pathsep_nix_to_dos="s|:|;|g" + func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp1" |\ + $SED -e "$lt_replace_pathsep_nix_to_dos"` + fi + # Now, add the leading and trailing path separators back + case "$1" in + :* ) func_to_host_pathlist_result=";$func_to_host_pathlist_result" + ;; + esac + case "$1" in + *: ) func_to_host_pathlist_result="$func_to_host_pathlist_result;" + ;; + esac + ;; + esac + fi +} +# end: func_to_host_pathlist + +# func_emit_cwrapperexe_src +# emit the source code for a wrapper executable on stdout +# Must ONLY be called from within func_mode_link because +# it depends on a number of variable set therein. +func_emit_cwrapperexe_src () +{ + cat < +#include +#ifdef _MSC_VER +# include +# include +# include +# define setmode _setmode +#else +# include +# include +# ifdef __CYGWIN__ +# include +# define HAVE_SETENV +# ifdef __STRICT_ANSI__ +char *realpath (const char *, char *); +int putenv (char *); +int setenv (const char *, const char *, int); +# endif +# endif +#endif +#include +#include +#include +#include +#include +#include +#include +#include + +#if defined(PATH_MAX) +# define LT_PATHMAX PATH_MAX +#elif defined(MAXPATHLEN) +# define LT_PATHMAX MAXPATHLEN +#else +# define LT_PATHMAX 1024 +#endif + +#ifndef S_IXOTH +# define S_IXOTH 0 +#endif +#ifndef S_IXGRP +# define S_IXGRP 0 +#endif + +#ifdef _MSC_VER +# define S_IXUSR _S_IEXEC +# define stat _stat +# ifndef _INTPTR_T_DEFINED +# define intptr_t int +# endif +#endif + +#ifndef DIR_SEPARATOR +# define DIR_SEPARATOR '/' +# define PATH_SEPARATOR ':' +#endif + +#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \ + defined (__OS2__) +# define HAVE_DOS_BASED_FILE_SYSTEM +# define FOPEN_WB "wb" +# ifndef DIR_SEPARATOR_2 +# define DIR_SEPARATOR_2 '\\' +# endif +# ifndef PATH_SEPARATOR_2 +# define PATH_SEPARATOR_2 ';' +# endif +#endif + +#ifndef DIR_SEPARATOR_2 +# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) +#else /* DIR_SEPARATOR_2 */ +# define IS_DIR_SEPARATOR(ch) \ + (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) +#endif /* DIR_SEPARATOR_2 */ + +#ifndef PATH_SEPARATOR_2 +# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) +#else /* PATH_SEPARATOR_2 */ +# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) +#endif /* PATH_SEPARATOR_2 */ + +#ifdef __CYGWIN__ +# define FOPEN_WB "wb" +#endif + +#ifndef FOPEN_WB +# define FOPEN_WB "w" +#endif +#ifndef _O_BINARY +# define _O_BINARY 0 +#endif + +#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) +#define XFREE(stale) do { \ + if (stale) { free ((void *) stale); stale = 0; } \ +} while (0) + +#undef LTWRAPPER_DEBUGPRINTF +#if defined DEBUGWRAPPER +# define LTWRAPPER_DEBUGPRINTF(args) ltwrapper_debugprintf args +static void +ltwrapper_debugprintf (const char *fmt, ...) +{ + va_list args; + va_start (args, fmt); + (void) vfprintf (stderr, fmt, args); + va_end (args); +} +#else +# define LTWRAPPER_DEBUGPRINTF(args) +#endif + +const char *program_name = NULL; + +void *xmalloc (size_t num); +char *xstrdup (const char *string); +const char *base_name (const char *name); +char *find_executable (const char *wrapper); +char *chase_symlinks (const char *pathspec); +int make_executable (const char *path); +int check_executable (const char *path); +char *strendzap (char *str, const char *pat); +void lt_fatal (const char *message, ...); +void lt_setenv (const char *name, const char *value); +char *lt_extend_str (const char *orig_value, const char *add, int to_end); +void lt_opt_process_env_set (const char *arg); +void lt_opt_process_env_prepend (const char *arg); +void lt_opt_process_env_append (const char *arg); +int lt_split_name_value (const char *arg, char** name, char** value); +void lt_update_exe_path (const char *name, const char *value); +void lt_update_lib_path (const char *name, const char *value); + +static const char *script_text_part1 = +EOF + + func_emit_wrapper_part1 yes | + $SED -e 's/\([\\"]\)/\\\1/g' \ + -e 's/^/ "/' -e 's/$/\\n"/' + echo ";" + cat <"))); + for (i = 0; i < newargc; i++) + { + LTWRAPPER_DEBUGPRINTF (("(main) newargz[%d] : %s\n", i, (newargz[i] ? newargz[i] : ""))); + } + +EOF + + case $host_os in + mingw*) + cat <<"EOF" + /* execv doesn't actually work on mingw as expected on unix */ + rval = _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz); + if (rval == -1) + { + /* failed to start process */ + LTWRAPPER_DEBUGPRINTF (("(main) failed to launch target \"%s\": errno = %d\n", lt_argv_zero, errno)); + return 127; + } + return rval; +EOF + ;; + *) + cat <<"EOF" + execv (lt_argv_zero, newargz); + return rval; /* =127, but avoids unused variable warning */ +EOF + ;; + esac + + cat <<"EOF" +} + +void * +xmalloc (size_t num) +{ + void *p = (void *) malloc (num); + if (!p) + lt_fatal ("Memory exhausted"); + + return p; +} + +char * +xstrdup (const char *string) +{ + return string ? strcpy ((char *) xmalloc (strlen (string) + 1), + string) : NULL; +} + +const char * +base_name (const char *name) +{ + const char *base; + +#if defined (HAVE_DOS_BASED_FILE_SYSTEM) + /* Skip over the disk name in MSDOS pathnames. */ + if (isalpha ((unsigned char) name[0]) && name[1] == ':') + name += 2; +#endif + + for (base = name; *name; name++) + if (IS_DIR_SEPARATOR (*name)) + base = name + 1; + return base; +} + +int +check_executable (const char *path) +{ + struct stat st; + + LTWRAPPER_DEBUGPRINTF (("(check_executable) : %s\n", + path ? (*path ? path : "EMPTY!") : "NULL!")); + if ((!path) || (!*path)) + return 0; + + if ((stat (path, &st) >= 0) + && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) + return 1; + else + return 0; +} + +int +make_executable (const char *path) +{ + int rval = 0; + struct stat st; + + LTWRAPPER_DEBUGPRINTF (("(make_executable) : %s\n", + path ? (*path ? path : "EMPTY!") : "NULL!")); + if ((!path) || (!*path)) + return 0; + + if (stat (path, &st) >= 0) + { + rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); + } + return rval; +} + +/* Searches for the full path of the wrapper. Returns + newly allocated full path name if found, NULL otherwise + Does not chase symlinks, even on platforms that support them. +*/ +char * +find_executable (const char *wrapper) +{ + int has_slash = 0; + const char *p; + const char *p_next; + /* static buffer for getcwd */ + char tmp[LT_PATHMAX + 1]; + int tmp_len; + char *concat_name; + + LTWRAPPER_DEBUGPRINTF (("(find_executable) : %s\n", + wrapper ? (*wrapper ? wrapper : "EMPTY!") : "NULL!")); + + if ((wrapper == NULL) || (*wrapper == '\0')) + return NULL; + + /* Absolute path? */ +#if defined (HAVE_DOS_BASED_FILE_SYSTEM) + if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') + { + concat_name = xstrdup (wrapper); + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + } + else + { +#endif + if (IS_DIR_SEPARATOR (wrapper[0])) + { + concat_name = xstrdup (wrapper); + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + } +#if defined (HAVE_DOS_BASED_FILE_SYSTEM) + } +#endif + + for (p = wrapper; *p; p++) + if (*p == '/') + { + has_slash = 1; + break; + } + if (!has_slash) + { + /* no slashes; search PATH */ + const char *path = getenv ("PATH"); + if (path != NULL) + { + for (p = path; *p; p = p_next) + { + const char *q; + size_t p_len; + for (q = p; *q; q++) + if (IS_PATH_SEPARATOR (*q)) + break; + p_len = q - p; + p_next = (*q == '\0' ? q : q + 1); + if (p_len == 0) + { + /* empty path: current directory */ + if (getcwd (tmp, LT_PATHMAX) == NULL) + lt_fatal ("getcwd failed"); + tmp_len = strlen (tmp); + concat_name = + XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); + memcpy (concat_name, tmp, tmp_len); + concat_name[tmp_len] = '/'; + strcpy (concat_name + tmp_len + 1, wrapper); + } + else + { + concat_name = + XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); + memcpy (concat_name, p, p_len); + concat_name[p_len] = '/'; + strcpy (concat_name + p_len + 1, wrapper); + } + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + } + } + /* not found in PATH; assume curdir */ + } + /* Relative path | not found in path: prepend cwd */ + if (getcwd (tmp, LT_PATHMAX) == NULL) + lt_fatal ("getcwd failed"); + tmp_len = strlen (tmp); + concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); + memcpy (concat_name, tmp, tmp_len); + concat_name[tmp_len] = '/'; + strcpy (concat_name + tmp_len + 1, wrapper); + + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + return NULL; +} + +char * +chase_symlinks (const char *pathspec) +{ +#ifndef S_ISLNK + return xstrdup (pathspec); +#else + char buf[LT_PATHMAX]; + struct stat s; + char *tmp_pathspec = xstrdup (pathspec); + char *p; + int has_symlinks = 0; + while (strlen (tmp_pathspec) && !has_symlinks) + { + LTWRAPPER_DEBUGPRINTF (("checking path component for symlinks: %s\n", + tmp_pathspec)); + if (lstat (tmp_pathspec, &s) == 0) + { + if (S_ISLNK (s.st_mode) != 0) + { + has_symlinks = 1; + break; + } + + /* search backwards for last DIR_SEPARATOR */ + p = tmp_pathspec + strlen (tmp_pathspec) - 1; + while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) + p--; + if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) + { + /* no more DIR_SEPARATORS left */ + break; + } + *p = '\0'; + } + else + { + char *errstr = strerror (errno); + lt_fatal ("Error accessing file %s (%s)", tmp_pathspec, errstr); + } + } + XFREE (tmp_pathspec); + + if (!has_symlinks) + { + return xstrdup (pathspec); + } + + tmp_pathspec = realpath (pathspec, buf); + if (tmp_pathspec == 0) + { + lt_fatal ("Could not follow symlinks for %s", pathspec); + } + return xstrdup (tmp_pathspec); +#endif +} + +char * +strendzap (char *str, const char *pat) +{ + size_t len, patlen; + + assert (str != NULL); + assert (pat != NULL); + + len = strlen (str); + patlen = strlen (pat); + + if (patlen <= len) + { + str += len - patlen; + if (strcmp (str, pat) == 0) + *str = '\0'; + } + return str; +} + +static void +lt_error_core (int exit_status, const char *mode, + const char *message, va_list ap) +{ + fprintf (stderr, "%s: %s: ", program_name, mode); + vfprintf (stderr, message, ap); + fprintf (stderr, ".\n"); + + if (exit_status >= 0) + exit (exit_status); +} + +void +lt_fatal (const char *message, ...) +{ + va_list ap; + va_start (ap, message); + lt_error_core (EXIT_FAILURE, "FATAL", message, ap); + va_end (ap); +} + +void +lt_setenv (const char *name, const char *value) +{ + LTWRAPPER_DEBUGPRINTF (("(lt_setenv) setting '%s' to '%s'\n", + (name ? name : ""), + (value ? value : ""))); + { +#ifdef HAVE_SETENV + /* always make a copy, for consistency with !HAVE_SETENV */ + char *str = xstrdup (value); + setenv (name, str, 1); +#else + int len = strlen (name) + 1 + strlen (value) + 1; + char *str = XMALLOC (char, len); + sprintf (str, "%s=%s", name, value); + if (putenv (str) != EXIT_SUCCESS) + { + XFREE (str); + } +#endif + } +} + +char * +lt_extend_str (const char *orig_value, const char *add, int to_end) +{ + char *new_value; + if (orig_value && *orig_value) + { + int orig_value_len = strlen (orig_value); + int add_len = strlen (add); + new_value = XMALLOC (char, add_len + orig_value_len + 1); + if (to_end) + { + strcpy (new_value, orig_value); + strcpy (new_value + orig_value_len, add); + } + else + { + strcpy (new_value, add); + strcpy (new_value + add_len, orig_value); + } + } + else + { + new_value = xstrdup (add); + } + return new_value; +} + +int +lt_split_name_value (const char *arg, char** name, char** value) +{ + const char *p; + int len; + if (!arg || !*arg) + return 1; + + p = strchr (arg, (int)'='); + + if (!p) + return 1; + + *value = xstrdup (++p); + + len = strlen (arg) - strlen (*value); + *name = XMALLOC (char, len); + strncpy (*name, arg, len-1); + (*name)[len - 1] = '\0'; + + return 0; +} + +void +lt_opt_process_env_set (const char *arg) +{ + char *name = NULL; + char *value = NULL; + + if (lt_split_name_value (arg, &name, &value) != 0) + { + XFREE (name); + XFREE (value); + lt_fatal ("bad argument for %s: '%s'", env_set_opt, arg); + } + + lt_setenv (name, value); + XFREE (name); + XFREE (value); +} + +void +lt_opt_process_env_prepend (const char *arg) +{ + char *name = NULL; + char *value = NULL; + char *new_value = NULL; + + if (lt_split_name_value (arg, &name, &value) != 0) + { + XFREE (name); + XFREE (value); + lt_fatal ("bad argument for %s: '%s'", env_prepend_opt, arg); + } + + new_value = lt_extend_str (getenv (name), value, 0); + lt_setenv (name, new_value); + XFREE (new_value); + XFREE (name); + XFREE (value); +} + +void +lt_opt_process_env_append (const char *arg) +{ + char *name = NULL; + char *value = NULL; + char *new_value = NULL; + + if (lt_split_name_value (arg, &name, &value) != 0) + { + XFREE (name); + XFREE (value); + lt_fatal ("bad argument for %s: '%s'", env_append_opt, arg); + } + + new_value = lt_extend_str (getenv (name), value, 1); + lt_setenv (name, new_value); + XFREE (new_value); + XFREE (name); + XFREE (value); +} + +void +lt_update_exe_path (const char *name, const char *value) +{ + LTWRAPPER_DEBUGPRINTF (("(lt_update_exe_path) modifying '%s' by prepending '%s'\n", + (name ? name : ""), + (value ? value : ""))); + + if (name && *name && value && *value) + { + char *new_value = lt_extend_str (getenv (name), value, 0); + /* some systems can't cope with a ':'-terminated path #' */ + int len = strlen (new_value); + while (((len = strlen (new_value)) > 0) && IS_PATH_SEPARATOR (new_value[len-1])) + { + new_value[len-1] = '\0'; + } + lt_setenv (name, new_value); + XFREE (new_value); + } +} + +void +lt_update_lib_path (const char *name, const char *value) +{ + LTWRAPPER_DEBUGPRINTF (("(lt_update_lib_path) modifying '%s' by prepending '%s'\n", + (name ? name : ""), + (value ? value : ""))); + + if (name && *name && value && *value) + { + char *new_value = lt_extend_str (getenv (name), value, 0); + lt_setenv (name, new_value); + XFREE (new_value); + } +} + + +EOF +} +# end: func_emit_cwrapperexe_src + +# func_mode_link arg... +func_mode_link () +{ + $opt_debug + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) + # It is impossible to link a dll without this setting, and + # we shouldn't force the makefile maintainer to figure out + # which system we are compiling for in order to pass an extra + # flag for every libtool invocation. + # allow_undefined=no + + # FIXME: Unfortunately, there are problems with the above when trying + # to make a dll which has undefined symbols, in which case not + # even a static library is built. For now, we need to specify + # -no-undefined on the libtool link line when we can be certain + # that all symbols are satisfied, otherwise we get a static library. + allow_undefined=yes + ;; + *) + allow_undefined=yes + ;; + esac + libtool_args=$nonopt + base_compile="$nonopt $@" + compile_command=$nonopt + finalize_command=$nonopt + + compile_rpath= + finalize_rpath= + compile_shlibpath= + finalize_shlibpath= + convenience= + old_convenience= + deplibs= + old_deplibs= + compiler_flags= + linker_flags= + dllsearchpath= + lib_search_path=`pwd` + inst_prefix_dir= + new_inherited_linker_flags= + + avoid_version=no + dlfiles= + dlprefiles= + dlself=no + export_dynamic=no + export_symbols= + export_symbols_regex= + generated= + libobjs= + ltlibs= + module=no + no_install=no + objs= + non_pic_objects= + precious_files_regex= + prefer_static_libs=no + preload=no + prev= + prevarg= + release= + rpath= + xrpath= + perm_rpath= + temp_rpath= + thread_safe=no + vinfo= + vinfo_number=no + weak_libs= + single_module="${wl}-single_module" + func_infer_tag $base_compile + + # We need to know -static, to get the right output filenames. + for arg + do + case $arg in + -shared) + test "$build_libtool_libs" != yes && \ + func_fatal_configuration "can not build a shared library" + build_old_libs=no + break + ;; + -all-static | -static | -static-libtool-libs) + case $arg in + -all-static) + if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then + func_warning "complete static linking is impossible in this configuration" + fi + if test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + prefer_static_libs=yes + ;; + -static) + if test -z "$pic_flag" && test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + prefer_static_libs=built + ;; + -static-libtool-libs) + if test -z "$pic_flag" && test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + prefer_static_libs=yes + ;; + esac + build_libtool_libs=no + build_old_libs=yes + break + ;; + esac + done + + # See if our shared archives depend on static archives. + test -n "$old_archive_from_new_cmds" && build_old_libs=yes + + # Go through the arguments, transforming them on the way. + while test "$#" -gt 0; do + arg="$1" + shift + func_quote_for_eval "$arg" + qarg=$func_quote_for_eval_unquoted_result + func_append libtool_args " $func_quote_for_eval_result" + + # If the previous option needs an argument, assign it. + if test -n "$prev"; then + case $prev in + output) + func_append compile_command " @OUTPUT@" + func_append finalize_command " @OUTPUT@" + ;; + esac + + case $prev in + dlfiles|dlprefiles) + if test "$preload" = no; then + # Add the symbol object into the linking commands. + func_append compile_command " @SYMFILE@" + func_append finalize_command " @SYMFILE@" + preload=yes + fi + case $arg in + *.la | *.lo) ;; # We handle these cases below. + force) + if test "$dlself" = no; then + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + self) + if test "$prev" = dlprefiles; then + dlself=yes + elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then + dlself=yes + else + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + *) + if test "$prev" = dlfiles; then + dlfiles="$dlfiles $arg" + else + dlprefiles="$dlprefiles $arg" + fi + prev= + continue + ;; + esac + ;; + expsyms) + export_symbols="$arg" + test -f "$arg" \ + || func_fatal_error "symbol file \`$arg' does not exist" + prev= + continue + ;; + expsyms_regex) + export_symbols_regex="$arg" + prev= + continue + ;; + framework) + case $host in + *-*-darwin*) + case "$deplibs " in + *" $qarg.ltframework "*) ;; + *) deplibs="$deplibs $qarg.ltframework" # this is fixed later + ;; + esac + ;; + esac + prev= + continue + ;; + inst_prefix) + inst_prefix_dir="$arg" + prev= + continue + ;; + objectlist) + if test -f "$arg"; then + save_arg=$arg + moreargs= + for fil in `cat "$save_arg"` + do +# moreargs="$moreargs $fil" + arg=$fil + # A libtool-controlled object. + + # Check to see that this really is a libtool object. + if func_lalib_unsafe_p "$arg"; then + pic_object= + non_pic_object= + + # Read the .lo file + func_source "$arg" + + if test -z "$pic_object" || + test -z "$non_pic_object" || + test "$pic_object" = none && + test "$non_pic_object" = none; then + func_fatal_error "cannot find name of object for \`$arg'" + fi + + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir="$func_dirname_result" + + if test "$pic_object" != none; then + # Prepend the subdirectory the object is found in. + pic_object="$xdir$pic_object" + + if test "$prev" = dlfiles; then + if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then + dlfiles="$dlfiles $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi + + # CHECK ME: I think I busted this. -Ossama + if test "$prev" = dlprefiles; then + # Preload the old-style object. + dlprefiles="$dlprefiles $pic_object" + prev= + fi + + # A PIC object. + func_append libobjs " $pic_object" + arg="$pic_object" + fi + + # Non-PIC object. + if test "$non_pic_object" != none; then + # Prepend the subdirectory the object is found in. + non_pic_object="$xdir$non_pic_object" + + # A standard non-PIC object + func_append non_pic_objects " $non_pic_object" + if test -z "$pic_object" || test "$pic_object" = none ; then + arg="$non_pic_object" + fi + else + # If the PIC object exists, use it instead. + # $xdir was prepended to $pic_object above. + non_pic_object="$pic_object" + func_append non_pic_objects " $non_pic_object" + fi + else + # Only an error if not doing a dry-run. + if $opt_dry_run; then + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir="$func_dirname_result" + + func_lo2o "$arg" + pic_object=$xdir$objdir/$func_lo2o_result + non_pic_object=$xdir$func_lo2o_result + func_append libobjs " $pic_object" + func_append non_pic_objects " $non_pic_object" + else + func_fatal_error "\`$arg' is not a valid libtool object" + fi + fi + done + else + func_fatal_error "link input file \`$arg' does not exist" + fi + arg=$save_arg + prev= + continue + ;; + precious_regex) + precious_files_regex="$arg" + prev= + continue + ;; + release) + release="-$arg" + prev= + continue + ;; + rpath | xrpath) + # We need an absolute path. + case $arg in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + func_fatal_error "only absolute run-paths are allowed" + ;; + esac + if test "$prev" = rpath; then + case "$rpath " in + *" $arg "*) ;; + *) rpath="$rpath $arg" ;; + esac + else + case "$xrpath " in + *" $arg "*) ;; + *) xrpath="$xrpath $arg" ;; + esac + fi + prev= + continue + ;; + shrext) + shrext_cmds="$arg" + prev= + continue + ;; + weak) + weak_libs="$weak_libs $arg" + prev= + continue + ;; + xcclinker) + linker_flags="$linker_flags $qarg" + compiler_flags="$compiler_flags $qarg" + prev= + func_append compile_command " $qarg" + func_append finalize_command " $qarg" + continue + ;; + xcompiler) + compiler_flags="$compiler_flags $qarg" + prev= + func_append compile_command " $qarg" + func_append finalize_command " $qarg" + continue + ;; + xlinker) + linker_flags="$linker_flags $qarg" + compiler_flags="$compiler_flags $wl$qarg" + prev= + func_append compile_command " $wl$qarg" + func_append finalize_command " $wl$qarg" + continue + ;; + *) + eval "$prev=\"\$arg\"" + prev= + continue + ;; + esac + fi # test -n "$prev" + + prevarg="$arg" + + case $arg in + -all-static) + if test -n "$link_static_flag"; then + # See comment for -static flag below, for more details. + func_append compile_command " $link_static_flag" + func_append finalize_command " $link_static_flag" + fi + continue + ;; + + -allow-undefined) + # FIXME: remove this flag sometime in the future. + func_fatal_error "\`-allow-undefined' must not be used because it is the default" + ;; + + -avoid-version) + avoid_version=yes + continue + ;; + + -dlopen) + prev=dlfiles + continue + ;; + + -dlpreopen) + prev=dlprefiles + continue + ;; + + -export-dynamic) + export_dynamic=yes + continue + ;; + + -export-symbols | -export-symbols-regex) + if test -n "$export_symbols" || test -n "$export_symbols_regex"; then + func_fatal_error "more than one -exported-symbols argument is not allowed" + fi + if test "X$arg" = "X-export-symbols"; then + prev=expsyms + else + prev=expsyms_regex + fi + continue + ;; + + -framework) + prev=framework + continue + ;; + + -inst-prefix-dir) + prev=inst_prefix + continue + ;; + + # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* + # so, if we see these flags be careful not to treat them like -L + -L[A-Z][A-Z]*:*) + case $with_gcc/$host in + no/*-*-irix* | /*-*-irix*) + func_append compile_command " $arg" + func_append finalize_command " $arg" + ;; + esac + continue + ;; + + -L*) + func_stripname '-L' '' "$arg" + dir=$func_stripname_result + if test -z "$dir"; then + if test "$#" -gt 0; then + func_fatal_error "require no space between \`-L' and \`$1'" + else + func_fatal_error "need path for \`-L' option" + fi + fi + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + absdir=`cd "$dir" && pwd` + test -z "$absdir" && \ + func_fatal_error "cannot determine absolute directory name of \`$dir'" + dir="$absdir" + ;; + esac + case "$deplibs " in + *" -L$dir "*) ;; + *) + deplibs="$deplibs -L$dir" + lib_search_path="$lib_search_path $dir" + ;; + esac + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) + testbindir=`$ECHO "X$dir" | $Xsed -e 's*/lib$*/bin*'` + case :$dllsearchpath: in + *":$dir:"*) ;; + ::) dllsearchpath=$dir;; + *) dllsearchpath="$dllsearchpath:$dir";; + esac + case :$dllsearchpath: in + *":$testbindir:"*) ;; + ::) dllsearchpath=$testbindir;; + *) dllsearchpath="$dllsearchpath:$testbindir";; + esac + ;; + esac + continue + ;; + + -l*) + if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc*) + # These systems don't actually have a C or math library (as such) + continue + ;; + *-*-os2*) + # These systems don't actually have a C library (as such) + test "X$arg" = "X-lc" && continue + ;; + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) + # Do not include libc due to us having libc/libc_r. + test "X$arg" = "X-lc" && continue + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C and math libraries are in the System framework + deplibs="$deplibs System.ltframework" + continue + ;; + *-*-sco3.2v5* | *-*-sco5v6*) + # Causes problems with __ctype + test "X$arg" = "X-lc" && continue + ;; + *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) + # Compiler inserts libc in the correct place for threads to work + test "X$arg" = "X-lc" && continue + ;; + esac + elif test "X$arg" = "X-lc_r"; then + case $host in + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) + # Do not include libc_r directly, use -pthread flag. + continue + ;; + esac + fi + deplibs="$deplibs $arg" + continue + ;; + + -module) + module=yes + continue + ;; + + # Tru64 UNIX uses -model [arg] to determine the layout of C++ + # classes, name mangling, and exception handling. + # Darwin uses the -arch flag to determine output architecture. + -model|-arch|-isysroot) + compiler_flags="$compiler_flags $arg" + func_append compile_command " $arg" + func_append finalize_command " $arg" + prev=xcompiler + continue + ;; + + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads) + compiler_flags="$compiler_flags $arg" + func_append compile_command " $arg" + func_append finalize_command " $arg" + case "$new_inherited_linker_flags " in + *" $arg "*) ;; + * ) new_inherited_linker_flags="$new_inherited_linker_flags $arg" ;; + esac + continue + ;; + + -multi_module) + single_module="${wl}-multi_module" + continue + ;; + + -no-fast-install) + fast_install=no + continue + ;; + + -no-install) + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) + # The PATH hackery in wrapper scripts is required on Windows + # and Darwin in order for the loader to find any dlls it needs. + func_warning "\`-no-install' is ignored for $host" + func_warning "assuming \`-no-fast-install' instead" + fast_install=no + ;; + *) no_install=yes ;; + esac + continue + ;; + + -no-undefined) + allow_undefined=no + continue + ;; + + -objectlist) + prev=objectlist + continue + ;; + + -o) prev=output ;; + + -precious-files-regex) + prev=precious_regex + continue + ;; + + -release) + prev=release + continue + ;; + + -rpath) + prev=rpath + continue + ;; + + -R) + prev=xrpath + continue + ;; + + -R*) + func_stripname '-R' '' "$arg" + dir=$func_stripname_result + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + func_fatal_error "only absolute run-paths are allowed" + ;; + esac + case "$xrpath " in + *" $dir "*) ;; + *) xrpath="$xrpath $dir" ;; + esac + continue + ;; + + -shared) + # The effects of -shared are defined in a previous loop. + continue + ;; + + -shrext) + prev=shrext + continue + ;; + + -static | -static-libtool-libs) + # The effects of -static are defined in a previous loop. + # We used to do the same as -all-static on platforms that + # didn't have a PIC flag, but the assumption that the effects + # would be equivalent was wrong. It would break on at least + # Digital Unix and AIX. + continue + ;; + + -thread-safe) + thread_safe=yes + continue + ;; + + -version-info) + prev=vinfo + continue + ;; + + -version-number) + prev=vinfo + vinfo_number=yes + continue + ;; + + -weak) + prev=weak + continue + ;; + + -Wc,*) + func_stripname '-Wc,' '' "$arg" + args=$func_stripname_result + arg= + save_ifs="$IFS"; IFS=',' + for flag in $args; do + IFS="$save_ifs" + func_quote_for_eval "$flag" + arg="$arg $wl$func_quote_for_eval_result" + compiler_flags="$compiler_flags $func_quote_for_eval_result" + done + IFS="$save_ifs" + func_stripname ' ' '' "$arg" + arg=$func_stripname_result + ;; + + -Wl,*) + func_stripname '-Wl,' '' "$arg" + args=$func_stripname_result + arg= + save_ifs="$IFS"; IFS=',' + for flag in $args; do + IFS="$save_ifs" + func_quote_for_eval "$flag" + arg="$arg $wl$func_quote_for_eval_result" + compiler_flags="$compiler_flags $wl$func_quote_for_eval_result" + linker_flags="$linker_flags $func_quote_for_eval_result" + done + IFS="$save_ifs" + func_stripname ' ' '' "$arg" + arg=$func_stripname_result + ;; + + -Xcompiler) + prev=xcompiler + continue + ;; + + -Xlinker) + prev=xlinker + continue + ;; + + -XCClinker) + prev=xcclinker + continue + ;; + + # -msg_* for osf cc + -msg_*) + func_quote_for_eval "$arg" + arg="$func_quote_for_eval_result" + ;; + + # -64, -mips[0-9] enable 64-bit mode on the SGI compiler + # -r[0-9][0-9]* specifies the processor on the SGI compiler + # -xarch=*, -xtarget=* enable 64-bit mode on the Sun compiler + # +DA*, +DD* enable 64-bit mode on the HP compiler + # -q* pass through compiler args for the IBM compiler + # -m*, -t[45]*, -txscale* pass through architecture-specific + # compiler args for GCC + # -F/path gives path to uninstalled frameworks, gcc on darwin + # -p, -pg, --coverage, -fprofile-* pass through profiling flag for GCC + # @file GCC response files + -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ + -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*) + func_quote_for_eval "$arg" + arg="$func_quote_for_eval_result" + func_append compile_command " $arg" + func_append finalize_command " $arg" + compiler_flags="$compiler_flags $arg" + continue + ;; + + # Some other compiler flag. + -* | +*) + func_quote_for_eval "$arg" + arg="$func_quote_for_eval_result" + ;; + + *.$objext) + # A standard object. + objs="$objs $arg" + ;; + + *.lo) + # A libtool-controlled object. + + # Check to see that this really is a libtool object. + if func_lalib_unsafe_p "$arg"; then + pic_object= + non_pic_object= + + # Read the .lo file + func_source "$arg" + + if test -z "$pic_object" || + test -z "$non_pic_object" || + test "$pic_object" = none && + test "$non_pic_object" = none; then + func_fatal_error "cannot find name of object for \`$arg'" + fi + + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir="$func_dirname_result" + + if test "$pic_object" != none; then + # Prepend the subdirectory the object is found in. + pic_object="$xdir$pic_object" + + if test "$prev" = dlfiles; then + if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then + dlfiles="$dlfiles $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi + + # CHECK ME: I think I busted this. -Ossama + if test "$prev" = dlprefiles; then + # Preload the old-style object. + dlprefiles="$dlprefiles $pic_object" + prev= + fi + + # A PIC object. + func_append libobjs " $pic_object" + arg="$pic_object" + fi + + # Non-PIC object. + if test "$non_pic_object" != none; then + # Prepend the subdirectory the object is found in. + non_pic_object="$xdir$non_pic_object" + + # A standard non-PIC object + func_append non_pic_objects " $non_pic_object" + if test -z "$pic_object" || test "$pic_object" = none ; then + arg="$non_pic_object" + fi + else + # If the PIC object exists, use it instead. + # $xdir was prepended to $pic_object above. + non_pic_object="$pic_object" + func_append non_pic_objects " $non_pic_object" + fi + else + # Only an error if not doing a dry-run. + if $opt_dry_run; then + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir="$func_dirname_result" + + func_lo2o "$arg" + pic_object=$xdir$objdir/$func_lo2o_result + non_pic_object=$xdir$func_lo2o_result + func_append libobjs " $pic_object" + func_append non_pic_objects " $non_pic_object" + else + func_fatal_error "\`$arg' is not a valid libtool object" + fi + fi + ;; + + *.$libext) + # An archive. + deplibs="$deplibs $arg" + old_deplibs="$old_deplibs $arg" + continue + ;; + + *.la) + # A libtool-controlled library. + + if test "$prev" = dlfiles; then + # This library was specified with -dlopen. + dlfiles="$dlfiles $arg" + prev= + elif test "$prev" = dlprefiles; then + # The library was specified with -dlpreopen. + dlprefiles="$dlprefiles $arg" + prev= + else + deplibs="$deplibs $arg" + fi + continue + ;; + + # Some other compiler argument. + *) + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + func_quote_for_eval "$arg" + arg="$func_quote_for_eval_result" + ;; + esac # arg + + # Now actually substitute the argument into the commands. + if test -n "$arg"; then + func_append compile_command " $arg" + func_append finalize_command " $arg" + fi + done # argument parsing loop + + test -n "$prev" && \ + func_fatal_help "the \`$prevarg' option requires an argument" + + if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then + eval arg=\"$export_dynamic_flag_spec\" + func_append compile_command " $arg" + func_append finalize_command " $arg" + fi + + oldlibs= + # calculate the name of the file, without its directory + func_basename "$output" + outputname="$func_basename_result" + libobjs_save="$libobjs" + + if test -n "$shlibpath_var"; then + # get the directories listed in $shlibpath_var + eval shlib_search_path=\`\$ECHO \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\` + else + shlib_search_path= + fi + eval sys_lib_search_path=\"$sys_lib_search_path_spec\" + eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" + + func_dirname "$output" "/" "" + output_objdir="$func_dirname_result$objdir" + # Create the object directory. + func_mkdir_p "$output_objdir" + + # Determine the type of output + case $output in + "") + func_fatal_help "you must specify an output file" + ;; + *.$libext) linkmode=oldlib ;; + *.lo | *.$objext) linkmode=obj ;; + *.la) linkmode=lib ;; + *) linkmode=prog ;; # Anything else should be a program. + esac + + specialdeplibs= + + libs= + # Find all interdependent deplibs by searching for libraries + # that are linked more than once (e.g. -la -lb -la) + for deplib in $deplibs; do + if $opt_duplicate_deps ; then + case "$libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + libs="$libs $deplib" + done + + if test "$linkmode" = lib; then + libs="$predeps $libs $compiler_lib_search_path $postdeps" + + # Compute libraries that are listed more than once in $predeps + # $postdeps and mark them as special (i.e., whose duplicates are + # not to be eliminated). + pre_post_deps= + if $opt_duplicate_compiler_generated_deps; then + for pre_post_dep in $predeps $postdeps; do + case "$pre_post_deps " in + *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;; + esac + pre_post_deps="$pre_post_deps $pre_post_dep" + done + fi + pre_post_deps= + fi + + deplibs= + newdependency_libs= + newlib_search_path= + need_relink=no # whether we're linking any uninstalled libtool libraries + notinst_deplibs= # not-installed libtool libraries + notinst_path= # paths that contain not-installed libtool libraries + + case $linkmode in + lib) + passes="conv dlpreopen link" + for file in $dlfiles $dlprefiles; do + case $file in + *.la) ;; + *) + func_fatal_help "libraries can \`-dlopen' only libtool libraries: $file" + ;; + esac + done + ;; + prog) + compile_deplibs= + finalize_deplibs= + alldeplibs=no + newdlfiles= + newdlprefiles= + passes="conv scan dlopen dlpreopen link" + ;; + *) passes="conv" + ;; + esac + + for pass in $passes; do + # The preopen pass in lib mode reverses $deplibs; put it back here + # so that -L comes before libs that need it for instance... + if test "$linkmode,$pass" = "lib,link"; then + ## FIXME: Find the place where the list is rebuilt in the wrong + ## order, and fix it there properly + tmp_deplibs= + for deplib in $deplibs; do + tmp_deplibs="$deplib $tmp_deplibs" + done + deplibs="$tmp_deplibs" + fi + + if test "$linkmode,$pass" = "lib,link" || + test "$linkmode,$pass" = "prog,scan"; then + libs="$deplibs" + deplibs= + fi + if test "$linkmode" = prog; then + case $pass in + dlopen) libs="$dlfiles" ;; + dlpreopen) libs="$dlprefiles" ;; + link) libs="$deplibs %DEPLIBS% $dependency_libs" ;; + esac + fi + if test "$linkmode,$pass" = "lib,dlpreopen"; then + # Collect and forward deplibs of preopened libtool libs + for lib in $dlprefiles; do + # Ignore non-libtool-libs + dependency_libs= + case $lib in + *.la) func_source "$lib" ;; + esac + + # Collect preopened libtool deplibs, except any this library + # has declared as weak libs + for deplib in $dependency_libs; do + deplib_base=`$ECHO "X$deplib" | $Xsed -e "$basename"` + case " $weak_libs " in + *" $deplib_base "*) ;; + *) deplibs="$deplibs $deplib" ;; + esac + done + done + libs="$dlprefiles" + fi + if test "$pass" = dlopen; then + # Collect dlpreopened libraries + save_deplibs="$deplibs" + deplibs= + fi + + for deplib in $libs; do + lib= + found=no + case $deplib in + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads) + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + compiler_flags="$compiler_flags $deplib" + if test "$linkmode" = lib ; then + case "$new_inherited_linker_flags " in + *" $deplib "*) ;; + * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;; + esac + fi + fi + continue + ;; + -l*) + if test "$linkmode" != lib && test "$linkmode" != prog; then + func_warning "\`-l' is ignored for archives/objects" + continue + fi + func_stripname '-l' '' "$deplib" + name=$func_stripname_result + if test "$linkmode" = lib; then + searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" + else + searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" + fi + for searchdir in $searchdirs; do + for search_ext in .la $std_shrext .so .a; do + # Search the libtool library + lib="$searchdir/lib${name}${search_ext}" + if test -f "$lib"; then + if test "$search_ext" = ".la"; then + found=yes + else + found=no + fi + break 2 + fi + done + done + if test "$found" != yes; then + # deplib doesn't seem to be a libtool library + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" + fi + continue + else # deplib is a libtool library + # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, + # We need to do some special things here, and not later. + if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then + case " $predeps $postdeps " in + *" $deplib "*) + if func_lalib_p "$lib"; then + library_names= + old_library= + func_source "$lib" + for l in $old_library $library_names; do + ll="$l" + done + if test "X$ll" = "X$old_library" ; then # only static version available + found=no + func_dirname "$lib" "" "." + ladir="$func_dirname_result" + lib=$ladir/$old_library + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" + fi + continue + fi + fi + ;; + *) ;; + esac + fi + fi + ;; # -l + *.ltframework) + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + if test "$linkmode" = lib ; then + case "$new_inherited_linker_flags " in + *" $deplib "*) ;; + * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;; + esac + fi + fi + continue + ;; + -L*) + case $linkmode in + lib) + deplibs="$deplib $deplibs" + test "$pass" = conv && continue + newdependency_libs="$deplib $newdependency_libs" + func_stripname '-L' '' "$deplib" + newlib_search_path="$newlib_search_path $func_stripname_result" + ;; + prog) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + continue + fi + if test "$pass" = scan; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + func_stripname '-L' '' "$deplib" + newlib_search_path="$newlib_search_path $func_stripname_result" + ;; + *) + func_warning "\`-L' is ignored for archives/objects" + ;; + esac # linkmode + continue + ;; # -L + -R*) + if test "$pass" = link; then + func_stripname '-R' '' "$deplib" + dir=$func_stripname_result + # Make sure the xrpath contains only unique directories. + case "$xrpath " in + *" $dir "*) ;; + *) xrpath="$xrpath $dir" ;; + esac + fi + deplibs="$deplib $deplibs" + continue + ;; + *.la) lib="$deplib" ;; + *.$libext) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + continue + fi + case $linkmode in + lib) + # Linking convenience modules into shared libraries is allowed, + # but linking other static libraries is non-portable. + case " $dlpreconveniencelibs " in + *" $deplib "*) ;; + *) + valid_a_lib=no + case $deplibs_check_method in + match_pattern*) + set dummy $deplibs_check_method; shift + match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` + if eval "\$ECHO \"X$deplib\"" 2>/dev/null | $Xsed -e 10q \ + | $EGREP "$match_pattern_regex" > /dev/null; then + valid_a_lib=yes + fi + ;; + pass_all) + valid_a_lib=yes + ;; + esac + if test "$valid_a_lib" != yes; then + $ECHO + $ECHO "*** Warning: Trying to link with static lib archive $deplib." + $ECHO "*** I have the capability to make that library automatically link in when" + $ECHO "*** you link to this library. But I can only do this if you have a" + $ECHO "*** shared version of the library, which you do not appear to have" + $ECHO "*** because the file extensions .$libext of this argument makes me believe" + $ECHO "*** that it is just a static archive that I should not use here." + else + $ECHO + $ECHO "*** Warning: Linking the shared library $output against the" + $ECHO "*** static library $deplib is not portable!" + deplibs="$deplib $deplibs" + fi + ;; + esac + continue + ;; + prog) + if test "$pass" != link; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + continue + ;; + esac # linkmode + ;; # *.$libext + *.lo | *.$objext) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + elif test "$linkmode" = prog; then + if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then + # If there is no dlopen support or we're linking statically, + # we need to preload. + newdlprefiles="$newdlprefiles $deplib" + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + newdlfiles="$newdlfiles $deplib" + fi + fi + continue + ;; + %DEPLIBS%) + alldeplibs=yes + continue + ;; + esac # case $deplib + + if test "$found" = yes || test -f "$lib"; then : + else + func_fatal_error "cannot find the library \`$lib' or unhandled argument \`$deplib'" + fi + + # Check to see that this really is a libtool archive. + func_lalib_unsafe_p "$lib" \ + || func_fatal_error "\`$lib' is not a valid libtool archive" + + func_dirname "$lib" "" "." + ladir="$func_dirname_result" + + dlname= + dlopen= + dlpreopen= + libdir= + library_names= + old_library= + inherited_linker_flags= + # If the library was installed with an old release of libtool, + # it will not redefine variables installed, or shouldnotlink + installed=yes + shouldnotlink=no + avoidtemprpath= + + + # Read the .la file + func_source "$lib" + + # Convert "-framework foo" to "foo.ltframework" + if test -n "$inherited_linker_flags"; then + tmp_inherited_linker_flags=`$ECHO "X$inherited_linker_flags" | $Xsed -e 's/-framework \([^ $]*\)/\1.ltframework/g'` + for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do + case " $new_inherited_linker_flags " in + *" $tmp_inherited_linker_flag "*) ;; + *) new_inherited_linker_flags="$new_inherited_linker_flags $tmp_inherited_linker_flag";; + esac + done + fi + dependency_libs=`$ECHO "X $dependency_libs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` + if test "$linkmode,$pass" = "lib,link" || + test "$linkmode,$pass" = "prog,scan" || + { test "$linkmode" != prog && test "$linkmode" != lib; }; then + test -n "$dlopen" && dlfiles="$dlfiles $dlopen" + test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen" + fi + + if test "$pass" = conv; then + # Only check for convenience libraries + deplibs="$lib $deplibs" + if test -z "$libdir"; then + if test -z "$old_library"; then + func_fatal_error "cannot find name of link library for \`$lib'" + fi + # It is a libtool convenience library, so add in its objects. + convenience="$convenience $ladir/$objdir/$old_library" + old_convenience="$old_convenience $ladir/$objdir/$old_library" + elif test "$linkmode" != prog && test "$linkmode" != lib; then + func_fatal_error "\`$lib' is not a convenience library" + fi + tmp_libs= + for deplib in $dependency_libs; do + deplibs="$deplib $deplibs" + if $opt_duplicate_deps ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done + continue + fi # $pass = conv + + + # Get the name of the library we link against. + linklib= + for l in $old_library $library_names; do + linklib="$l" + done + if test -z "$linklib"; then + func_fatal_error "cannot find name of link library for \`$lib'" + fi + + # This library was specified with -dlopen. + if test "$pass" = dlopen; then + if test -z "$libdir"; then + func_fatal_error "cannot -dlopen a convenience library: \`$lib'" + fi + if test -z "$dlname" || + test "$dlopen_support" != yes || + test "$build_libtool_libs" = no; then + # If there is no dlname, no dlopen support or we're linking + # statically, we need to preload. We also need to preload any + # dependent libraries so libltdl's deplib preloader doesn't + # bomb out in the load deplibs phase. + dlprefiles="$dlprefiles $lib $dependency_libs" + else + newdlfiles="$newdlfiles $lib" + fi + continue + fi # $pass = dlopen + + # We need an absolute path. + case $ladir in + [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;; + *) + abs_ladir=`cd "$ladir" && pwd` + if test -z "$abs_ladir"; then + func_warning "cannot determine absolute directory name of \`$ladir'" + func_warning "passing it literally to the linker, although it might fail" + abs_ladir="$ladir" + fi + ;; + esac + func_basename "$lib" + laname="$func_basename_result" + + # Find the relevant object directory and library name. + if test "X$installed" = Xyes; then + if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then + func_warning "library \`$lib' was moved." + dir="$ladir" + absdir="$abs_ladir" + libdir="$abs_ladir" + else + dir="$libdir" + absdir="$libdir" + fi + test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes + else + if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then + dir="$ladir" + absdir="$abs_ladir" + # Remove this search path later + notinst_path="$notinst_path $abs_ladir" + else + dir="$ladir/$objdir" + absdir="$abs_ladir/$objdir" + # Remove this search path later + notinst_path="$notinst_path $abs_ladir" + fi + fi # $installed = yes + func_stripname 'lib' '.la' "$laname" + name=$func_stripname_result + + # This library was specified with -dlpreopen. + if test "$pass" = dlpreopen; then + if test -z "$libdir" && test "$linkmode" = prog; then + func_fatal_error "only libraries may -dlpreopen a convenience library: \`$lib'" + fi + # Prefer using a static library (so that no silly _DYNAMIC symbols + # are required to link). + if test -n "$old_library"; then + newdlprefiles="$newdlprefiles $dir/$old_library" + # Keep a list of preopened convenience libraries to check + # that they are being used correctly in the link pass. + test -z "$libdir" && \ + dlpreconveniencelibs="$dlpreconveniencelibs $dir/$old_library" + # Otherwise, use the dlname, so that lt_dlopen finds it. + elif test -n "$dlname"; then + newdlprefiles="$newdlprefiles $dir/$dlname" + else + newdlprefiles="$newdlprefiles $dir/$linklib" + fi + fi # $pass = dlpreopen + + if test -z "$libdir"; then + # Link the convenience library + if test "$linkmode" = lib; then + deplibs="$dir/$old_library $deplibs" + elif test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$dir/$old_library $compile_deplibs" + finalize_deplibs="$dir/$old_library $finalize_deplibs" + else + deplibs="$lib $deplibs" # used for prog,scan pass + fi + continue + fi + + + if test "$linkmode" = prog && test "$pass" != link; then + newlib_search_path="$newlib_search_path $ladir" + deplibs="$lib $deplibs" + + linkalldeplibs=no + if test "$link_all_deplibs" != no || test -z "$library_names" || + test "$build_libtool_libs" = no; then + linkalldeplibs=yes + fi + + tmp_libs= + for deplib in $dependency_libs; do + case $deplib in + -L*) func_stripname '-L' '' "$deplib" + newlib_search_path="$newlib_search_path $func_stripname_result" + ;; + esac + # Need to link against all dependency_libs? + if test "$linkalldeplibs" = yes; then + deplibs="$deplib $deplibs" + else + # Need to hardcode shared library paths + # or/and link against static libraries + newdependency_libs="$deplib $newdependency_libs" + fi + if $opt_duplicate_deps ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done # for deplib + continue + fi # $linkmode = prog... + + if test "$linkmode,$pass" = "prog,link"; then + if test -n "$library_names" && + { { test "$prefer_static_libs" = no || + test "$prefer_static_libs,$installed" = "built,yes"; } || + test -z "$old_library"; }; then + # We need to hardcode the library path + if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then + # Make sure the rpath contains only unique directories. + case "$temp_rpath:" in + *"$absdir:"*) ;; + *) temp_rpath="$temp_rpath$absdir:" ;; + esac + fi + + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) compile_rpath="$compile_rpath $absdir" + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" + esac + ;; + esac + fi # $linkmode,$pass = prog,link... + + if test "$alldeplibs" = yes && + { test "$deplibs_check_method" = pass_all || + { test "$build_libtool_libs" = yes && + test -n "$library_names"; }; }; then + # We only need to search for static libraries + continue + fi + fi + + link_static=no # Whether the deplib will be linked statically + use_static_libs=$prefer_static_libs + if test "$use_static_libs" = built && test "$installed" = yes; then + use_static_libs=no + fi + if test -n "$library_names" && + { test "$use_static_libs" = no || test -z "$old_library"; }; then + case $host in + *cygwin* | *mingw* | *cegcc*) + # No point in relinking DLLs because paths are not encoded + notinst_deplibs="$notinst_deplibs $lib" + need_relink=no + ;; + *) + if test "$installed" = no; then + notinst_deplibs="$notinst_deplibs $lib" + need_relink=yes + fi + ;; + esac + # This is a shared library + + # Warn about portability, can't link against -module's on some + # systems (darwin). Don't bleat about dlopened modules though! + dlopenmodule="" + for dlpremoduletest in $dlprefiles; do + if test "X$dlpremoduletest" = "X$lib"; then + dlopenmodule="$dlpremoduletest" + break + fi + done + if test -z "$dlopenmodule" && test "$shouldnotlink" = yes && test "$pass" = link; then + $ECHO + if test "$linkmode" = prog; then + $ECHO "*** Warning: Linking the executable $output against the loadable module" + else + $ECHO "*** Warning: Linking the shared library $output against the loadable module" + fi + $ECHO "*** $linklib is not portable!" + fi + if test "$linkmode" = lib && + test "$hardcode_into_libs" = yes; then + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) compile_rpath="$compile_rpath $absdir" + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" + esac + ;; + esac + fi + + if test -n "$old_archive_from_expsyms_cmds"; then + # figure out the soname + set dummy $library_names + shift + realname="$1" + shift + libname=`eval "\\$ECHO \"$libname_spec\""` + # use dlname if we got it. it's perfectly good, no? + if test -n "$dlname"; then + soname="$dlname" + elif test -n "$soname_spec"; then + # bleh windows + case $host in + *cygwin* | mingw* | *cegcc*) + func_arith $current - $age + major=$func_arith_result + versuffix="-$major" + ;; + esac + eval soname=\"$soname_spec\" + else + soname="$realname" + fi + + # Make a new name for the extract_expsyms_cmds to use + soroot="$soname" + func_basename "$soroot" + soname="$func_basename_result" + func_stripname 'lib' '.dll' "$soname" + newlib=libimp-$func_stripname_result.a + + # If the library has no export list, then create one now + if test -f "$output_objdir/$soname-def"; then : + else + func_verbose "extracting exported symbol list from \`$soname'" + func_execute_cmds "$extract_expsyms_cmds" 'exit $?' + fi + + # Create $newlib + if test -f "$output_objdir/$newlib"; then :; else + func_verbose "generating import library for \`$soname'" + func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' + fi + # make sure the library variables are pointing to the new library + dir=$output_objdir + linklib=$newlib + fi # test -n "$old_archive_from_expsyms_cmds" + + if test "$linkmode" = prog || test "$mode" != relink; then + add_shlibpath= + add_dir= + add= + lib_linked=yes + case $hardcode_action in + immediate | unsupported) + if test "$hardcode_direct" = no; then + add="$dir/$linklib" + case $host in + *-*-sco3.2v5.0.[024]*) add_dir="-L$dir" ;; + *-*-sysv4*uw2*) add_dir="-L$dir" ;; + *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ + *-*-unixware7*) add_dir="-L$dir" ;; + *-*-darwin* ) + # if the lib is a (non-dlopened) module then we can not + # link against it, someone is ignoring the earlier warnings + if /usr/bin/file -L $add 2> /dev/null | + $GREP ": [^:]* bundle" >/dev/null ; then + if test "X$dlopenmodule" != "X$lib"; then + $ECHO "*** Warning: lib $linklib is a module, not a shared library" + if test -z "$old_library" ; then + $ECHO + $ECHO "*** And there doesn't seem to be a static archive available" + $ECHO "*** The link will probably fail, sorry" + else + add="$dir/$old_library" + fi + elif test -n "$old_library"; then + add="$dir/$old_library" + fi + fi + esac + elif test "$hardcode_minus_L" = no; then + case $host in + *-*-sunos*) add_shlibpath="$dir" ;; + esac + add_dir="-L$dir" + add="-l$name" + elif test "$hardcode_shlibpath_var" = no; then + add_shlibpath="$dir" + add="-l$name" + else + lib_linked=no + fi + ;; + relink) + if test "$hardcode_direct" = yes && + test "$hardcode_direct_absolute" = no; then + add="$dir/$linklib" + elif test "$hardcode_minus_L" = yes; then + add_dir="-L$dir" + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case $libdir in + [\\/]*) + add_dir="$add_dir -L$inst_prefix_dir$libdir" + ;; + esac + fi + add="-l$name" + elif test "$hardcode_shlibpath_var" = yes; then + add_shlibpath="$dir" + add="-l$name" + else + lib_linked=no + fi + ;; + *) lib_linked=no ;; + esac + + if test "$lib_linked" != yes; then + func_fatal_configuration "unsupported hardcode properties" + fi + + if test -n "$add_shlibpath"; then + case :$compile_shlibpath: in + *":$add_shlibpath:"*) ;; + *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;; + esac + fi + if test "$linkmode" = prog; then + test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" + test -n "$add" && compile_deplibs="$add $compile_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + if test "$hardcode_direct" != yes && + test "$hardcode_minus_L" != yes && + test "$hardcode_shlibpath_var" = yes; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; + esac + fi + fi + fi + + if test "$linkmode" = prog || test "$mode" = relink; then + add_shlibpath= + add_dir= + add= + # Finalize command for both is simple: just hardcode it. + if test "$hardcode_direct" = yes && + test "$hardcode_direct_absolute" = no; then + add="$libdir/$linklib" + elif test "$hardcode_minus_L" = yes; then + add_dir="-L$libdir" + add="-l$name" + elif test "$hardcode_shlibpath_var" = yes; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; + esac + add="-l$name" + elif test "$hardcode_automatic" = yes; then + if test -n "$inst_prefix_dir" && + test -f "$inst_prefix_dir$libdir/$linklib" ; then + add="$inst_prefix_dir$libdir/$linklib" + else + add="$libdir/$linklib" + fi + else + # We cannot seem to hardcode it, guess we'll fake it. + add_dir="-L$libdir" + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case $libdir in + [\\/]*) + add_dir="$add_dir -L$inst_prefix_dir$libdir" + ;; + esac + fi + add="-l$name" + fi + + if test "$linkmode" = prog; then + test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" + test -n "$add" && finalize_deplibs="$add $finalize_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + fi + fi + elif test "$linkmode" = prog; then + # Here we assume that one of hardcode_direct or hardcode_minus_L + # is not unsupported. This is valid on all known static and + # shared platforms. + if test "$hardcode_direct" != unsupported; then + test -n "$old_library" && linklib="$old_library" + compile_deplibs="$dir/$linklib $compile_deplibs" + finalize_deplibs="$dir/$linklib $finalize_deplibs" + else + compile_deplibs="-l$name -L$dir $compile_deplibs" + finalize_deplibs="-l$name -L$dir $finalize_deplibs" + fi + elif test "$build_libtool_libs" = yes; then + # Not a shared library + if test "$deplibs_check_method" != pass_all; then + # We're trying link a shared library against a static one + # but the system doesn't support it. + + # Just print a warning and add the library to dependency_libs so + # that the program can be linked against the static library. + $ECHO + $ECHO "*** Warning: This system can not link to static lib archive $lib." + $ECHO "*** I have the capability to make that library automatically link in when" + $ECHO "*** you link to this library. But I can only do this if you have a" + $ECHO "*** shared version of the library, which you do not appear to have." + if test "$module" = yes; then + $ECHO "*** But as you try to build a module library, libtool will still create " + $ECHO "*** a static module, that should work as long as the dlopening application" + $ECHO "*** is linked with the -dlopen flag to resolve symbols at runtime." + if test -z "$global_symbol_pipe"; then + $ECHO + $ECHO "*** However, this would only work if libtool was able to extract symbol" + $ECHO "*** lists from a program, using \`nm' or equivalent, but libtool could" + $ECHO "*** not find such a program. So, this module is probably useless." + $ECHO "*** \`nm' from GNU binutils and a full rebuild may help." + fi + if test "$build_old_libs" = no; then + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + fi + else + deplibs="$dir/$old_library $deplibs" + link_static=yes + fi + fi # link shared/static library? + + if test "$linkmode" = lib; then + if test -n "$dependency_libs" && + { test "$hardcode_into_libs" != yes || + test "$build_old_libs" = yes || + test "$link_static" = yes; }; then + # Extract -R from dependency_libs + temp_deplibs= + for libdir in $dependency_libs; do + case $libdir in + -R*) func_stripname '-R' '' "$libdir" + temp_xrpath=$func_stripname_result + case " $xrpath " in + *" $temp_xrpath "*) ;; + *) xrpath="$xrpath $temp_xrpath";; + esac;; + *) temp_deplibs="$temp_deplibs $libdir";; + esac + done + dependency_libs="$temp_deplibs" + fi + + newlib_search_path="$newlib_search_path $absdir" + # Link against this library + test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs" + # ... and its dependency_libs + tmp_libs= + for deplib in $dependency_libs; do + newdependency_libs="$deplib $newdependency_libs" + if $opt_duplicate_deps ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done + + if test "$link_all_deplibs" != no; then + # Add the search paths of all dependency libraries + for deplib in $dependency_libs; do + case $deplib in + -L*) path="$deplib" ;; + *.la) + func_dirname "$deplib" "" "." + dir="$func_dirname_result" + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;; + *) + absdir=`cd "$dir" && pwd` + if test -z "$absdir"; then + func_warning "cannot determine absolute directory name of \`$dir'" + absdir="$dir" + fi + ;; + esac + if $GREP "^installed=no" $deplib > /dev/null; then + case $host in + *-*-darwin*) + depdepl= + eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` + if test -n "$deplibrary_names" ; then + for tmp in $deplibrary_names ; do + depdepl=$tmp + done + if test -f "$absdir/$objdir/$depdepl" ; then + depdepl="$absdir/$objdir/$depdepl" + darwin_install_name=`${OTOOL} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` + if test -z "$darwin_install_name"; then + darwin_install_name=`${OTOOL64} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` + fi + compiler_flags="$compiler_flags ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}" + linker_flags="$linker_flags -dylib_file ${darwin_install_name}:${depdepl}" + path= + fi + fi + ;; + *) + path="-L$absdir/$objdir" + ;; + esac + else + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` + test -z "$libdir" && \ + func_fatal_error "\`$deplib' is not a valid libtool archive" + test "$absdir" != "$libdir" && \ + func_warning "\`$deplib' seems to be moved" + + path="-L$absdir" + fi + ;; + esac + case " $deplibs " in + *" $path "*) ;; + *) deplibs="$path $deplibs" ;; + esac + done + fi # link_all_deplibs != no + fi # linkmode = lib + done # for deplib in $libs + if test "$pass" = link; then + if test "$linkmode" = "prog"; then + compile_deplibs="$new_inherited_linker_flags $compile_deplibs" + finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" + else + compiler_flags="$compiler_flags "`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` + fi + fi + dependency_libs="$newdependency_libs" + if test "$pass" = dlpreopen; then + # Link the dlpreopened libraries before other libraries + for deplib in $save_deplibs; do + deplibs="$deplib $deplibs" + done + fi + if test "$pass" != dlopen; then + if test "$pass" != conv; then + # Make sure lib_search_path contains only unique directories. + lib_search_path= + for dir in $newlib_search_path; do + case "$lib_search_path " in + *" $dir "*) ;; + *) lib_search_path="$lib_search_path $dir" ;; + esac + done + newlib_search_path= + fi + + if test "$linkmode,$pass" != "prog,link"; then + vars="deplibs" + else + vars="compile_deplibs finalize_deplibs" + fi + for var in $vars dependency_libs; do + # Add libraries to $var in reverse order + eval tmp_libs=\"\$$var\" + new_libs= + for deplib in $tmp_libs; do + # FIXME: Pedantically, this is the right thing to do, so + # that some nasty dependency loop isn't accidentally + # broken: + #new_libs="$deplib $new_libs" + # Pragmatically, this seems to cause very few problems in + # practice: + case $deplib in + -L*) new_libs="$deplib $new_libs" ;; + -R*) ;; + *) + # And here is the reason: when a library appears more + # than once as an explicit dependence of a library, or + # is implicitly linked in more than once by the + # compiler, it is considered special, and multiple + # occurrences thereof are not removed. Compare this + # with having the same library being listed as a + # dependency of multiple other libraries: in this case, + # we know (pedantically, we assume) the library does not + # need to be listed more than once, so we keep only the + # last copy. This is not always right, but it is rare + # enough that we require users that really mean to play + # such unportable linking tricks to link the library + # using -Wl,-lname, so that libtool does not consider it + # for duplicate removal. + case " $specialdeplibs " in + *" $deplib "*) new_libs="$deplib $new_libs" ;; + *) + case " $new_libs " in + *" $deplib "*) ;; + *) new_libs="$deplib $new_libs" ;; + esac + ;; + esac + ;; + esac + done + tmp_libs= + for deplib in $new_libs; do + case $deplib in + -L*) + case " $tmp_libs " in + *" $deplib "*) ;; + *) tmp_libs="$tmp_libs $deplib" ;; + esac + ;; + *) tmp_libs="$tmp_libs $deplib" ;; + esac + done + eval $var=\"$tmp_libs\" + done # for var + fi + # Last step: remove runtime libs from dependency_libs + # (they stay in deplibs) + tmp_libs= + for i in $dependency_libs ; do + case " $predeps $postdeps $compiler_lib_search_path " in + *" $i "*) + i="" + ;; + esac + if test -n "$i" ; then + tmp_libs="$tmp_libs $i" + fi + done + dependency_libs=$tmp_libs + done # for pass + if test "$linkmode" = prog; then + dlfiles="$newdlfiles" + fi + if test "$linkmode" = prog || test "$linkmode" = lib; then + dlprefiles="$newdlprefiles" + fi + + case $linkmode in + oldlib) + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + func_warning "\`-dlopen' is ignored for archives" + fi + + case " $deplibs" in + *\ -l* | *\ -L*) + func_warning "\`-l' and \`-L' are ignored for archives" ;; + esac + + test -n "$rpath" && \ + func_warning "\`-rpath' is ignored for archives" + + test -n "$xrpath" && \ + func_warning "\`-R' is ignored for archives" + + test -n "$vinfo" && \ + func_warning "\`-version-info/-version-number' is ignored for archives" + + test -n "$release" && \ + func_warning "\`-release' is ignored for archives" + + test -n "$export_symbols$export_symbols_regex" && \ + func_warning "\`-export-symbols' is ignored for archives" + + # Now set the variables for building old libraries. + build_libtool_libs=no + oldlibs="$output" + objs="$objs$old_deplibs" + ;; + + lib) + # Make sure we only generate libraries of the form `libNAME.la'. + case $outputname in + lib*) + func_stripname 'lib' '.la' "$outputname" + name=$func_stripname_result + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + ;; + *) + test "$module" = no && \ + func_fatal_help "libtool library \`$output' must begin with \`lib'" + + if test "$need_lib_prefix" != no; then + # Add the "lib" prefix for modules if required + func_stripname '' '.la' "$outputname" + name=$func_stripname_result + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + else + func_stripname '' '.la' "$outputname" + libname=$func_stripname_result + fi + ;; + esac + + if test -n "$objs"; then + if test "$deplibs_check_method" != pass_all; then + func_fatal_error "cannot build libtool library \`$output' from non-libtool objects on this host:$objs" + else + $ECHO + $ECHO "*** Warning: Linking the shared library $output against the non-libtool" + $ECHO "*** objects $objs is not portable!" + libobjs="$libobjs $objs" + fi + fi + + test "$dlself" != no && \ + func_warning "\`-dlopen self' is ignored for libtool libraries" + + set dummy $rpath + shift + test "$#" -gt 1 && \ + func_warning "ignoring multiple \`-rpath's for a libtool library" + + install_libdir="$1" + + oldlibs= + if test -z "$rpath"; then + if test "$build_libtool_libs" = yes; then + # Building a libtool convenience library. + # Some compilers have problems with a `.al' extension so + # convenience libraries should have the same extension an + # archive normally would. + oldlibs="$output_objdir/$libname.$libext $oldlibs" + build_libtool_libs=convenience + build_old_libs=yes + fi + + test -n "$vinfo" && \ + func_warning "\`-version-info/-version-number' is ignored for convenience libraries" + + test -n "$release" && \ + func_warning "\`-release' is ignored for convenience libraries" + else + + # Parse the version information argument. + save_ifs="$IFS"; IFS=':' + set dummy $vinfo 0 0 0 + shift + IFS="$save_ifs" + + test -n "$7" && \ + func_fatal_help "too many parameters to \`-version-info'" + + # convert absolute version numbers to libtool ages + # this retains compatibility with .la files and attempts + # to make the code below a bit more comprehensible + + case $vinfo_number in + yes) + number_major="$1" + number_minor="$2" + number_revision="$3" + # + # There are really only two kinds -- those that + # use the current revision as the major version + # and those that subtract age and use age as + # a minor version. But, then there is irix + # which has an extra 1 added just for fun + # + case $version_type in + darwin|linux|osf|windows|none) + func_arith $number_major + $number_minor + current=$func_arith_result + age="$number_minor" + revision="$number_revision" + ;; + freebsd-aout|freebsd-elf|sunos) + current="$number_major" + revision="$number_minor" + age="0" + ;; + irix|nonstopux) + func_arith $number_major + $number_minor + current=$func_arith_result + age="$number_minor" + revision="$number_minor" + lt_irix_increment=no + ;; + esac + ;; + no) + current="$1" + revision="$2" + age="$3" + ;; + esac + + # Check that each of the things are valid numbers. + case $current in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + func_error "CURRENT \`$current' must be a nonnegative integer" + func_fatal_error "\`$vinfo' is not valid version information" + ;; + esac + + case $revision in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + func_error "REVISION \`$revision' must be a nonnegative integer" + func_fatal_error "\`$vinfo' is not valid version information" + ;; + esac + + case $age in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + func_error "AGE \`$age' must be a nonnegative integer" + func_fatal_error "\`$vinfo' is not valid version information" + ;; + esac + + if test "$age" -gt "$current"; then + func_error "AGE \`$age' is greater than the current interface number \`$current'" + func_fatal_error "\`$vinfo' is not valid version information" + fi + + # Calculate the version variables. + major= + versuffix= + verstring= + case $version_type in + none) ;; + + darwin) + # Like Linux, but with the current version available in + # verstring for coding it into the library header + func_arith $current - $age + major=.$func_arith_result + versuffix="$major.$age.$revision" + # Darwin ld doesn't like 0 for these options... + func_arith $current + 1 + minor_current=$func_arith_result + xlcverstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision" + verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" + ;; + + freebsd-aout) + major=".$current" + versuffix=".$current.$revision"; + ;; + + freebsd-elf) + major=".$current" + versuffix=".$current" + ;; + + irix | nonstopux) + if test "X$lt_irix_increment" = "Xno"; then + func_arith $current - $age + else + func_arith $current - $age + 1 + fi + major=$func_arith_result + + case $version_type in + nonstopux) verstring_prefix=nonstopux ;; + *) verstring_prefix=sgi ;; + esac + verstring="$verstring_prefix$major.$revision" + + # Add in all the interfaces that we are compatible with. + loop=$revision + while test "$loop" -ne 0; do + func_arith $revision - $loop + iface=$func_arith_result + func_arith $loop - 1 + loop=$func_arith_result + verstring="$verstring_prefix$major.$iface:$verstring" + done + + # Before this point, $major must not contain `.'. + major=.$major + versuffix="$major.$revision" + ;; + + linux) + func_arith $current - $age + major=.$func_arith_result + versuffix="$major.$age.$revision" + ;; + + osf) + func_arith $current - $age + major=.$func_arith_result + versuffix=".$current.$age.$revision" + verstring="$current.$age.$revision" + + # Add in all the interfaces that we are compatible with. + loop=$age + while test "$loop" -ne 0; do + func_arith $current - $loop + iface=$func_arith_result + func_arith $loop - 1 + loop=$func_arith_result + verstring="$verstring:${iface}.0" + done + + # Make executables depend on our current version. + verstring="$verstring:${current}.0" + ;; + + qnx) + major=".$current" + versuffix=".$current" + ;; + + sunos) + major=".$current" + versuffix=".$current.$revision" + ;; + + windows) + # Use '-' rather than '.', since we only want one + # extension on DOS 8.3 filesystems. + func_arith $current - $age + major=$func_arith_result + versuffix="-$major" + ;; + + *) + func_fatal_configuration "unknown library version type \`$version_type'" + ;; + esac + + # Clear the version info if we defaulted, and they specified a release. + if test -z "$vinfo" && test -n "$release"; then + major= + case $version_type in + darwin) + # we can't check for "0.0" in archive_cmds due to quoting + # problems, so we reset it completely + verstring= + ;; + *) + verstring="0.0" + ;; + esac + if test "$need_version" = no; then + versuffix= + else + versuffix=".0.0" + fi + fi + + # Remove version info from name if versioning should be avoided + if test "$avoid_version" = yes && test "$need_version" = no; then + major= + versuffix= + verstring="" + fi + + # Check to see if the archive will have undefined symbols. + if test "$allow_undefined" = yes; then + if test "$allow_undefined_flag" = unsupported; then + func_warning "undefined symbols not allowed in $host shared libraries" + build_libtool_libs=no + build_old_libs=yes + fi + else + # Don't allow undefined symbols. + allow_undefined_flag="$no_undefined_flag" + fi + + fi + + func_generate_dlsyms "$libname" "$libname" "yes" + libobjs="$libobjs $symfileobj" + test "X$libobjs" = "X " && libobjs= + + if test "$mode" != relink; then + # Remove our outputs, but don't remove object files since they + # may have been created when compiling PIC objects. + removelist= + tempremovelist=`$ECHO "$output_objdir/*"` + for p in $tempremovelist; do + case $p in + *.$objext | *.gcno) + ;; + $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*) + if test "X$precious_files_regex" != "X"; then + if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 + then + continue + fi + fi + removelist="$removelist $p" + ;; + *) ;; + esac + done + test -n "$removelist" && \ + func_show_eval "${RM}r \$removelist" + fi + + # Now set the variables for building old libraries. + if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then + oldlibs="$oldlibs $output_objdir/$libname.$libext" + + # Transform .lo files to .o files. + oldobjs="$objs "`$ECHO "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP` + fi + + # Eliminate all temporary directories. + #for path in $notinst_path; do + # lib_search_path=`$ECHO "X$lib_search_path " | $Xsed -e "s% $path % %g"` + # deplibs=`$ECHO "X$deplibs " | $Xsed -e "s% -L$path % %g"` + # dependency_libs=`$ECHO "X$dependency_libs " | $Xsed -e "s% -L$path % %g"` + #done + + if test -n "$xrpath"; then + # If the user specified any rpath flags, then add them. + temp_xrpath= + for libdir in $xrpath; do + temp_xrpath="$temp_xrpath -R$libdir" + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" ;; + esac + done + if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then + dependency_libs="$temp_xrpath $dependency_libs" + fi + fi + + # Make sure dlfiles contains only unique files that won't be dlpreopened + old_dlfiles="$dlfiles" + dlfiles= + for lib in $old_dlfiles; do + case " $dlprefiles $dlfiles " in + *" $lib "*) ;; + *) dlfiles="$dlfiles $lib" ;; + esac + done + + # Make sure dlprefiles contains only unique files + old_dlprefiles="$dlprefiles" + dlprefiles= + for lib in $old_dlprefiles; do + case "$dlprefiles " in + *" $lib "*) ;; + *) dlprefiles="$dlprefiles $lib" ;; + esac + done + + if test "$build_libtool_libs" = yes; then + if test -n "$rpath"; then + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc*) + # these systems don't actually have a c library (as such)! + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C library is in the System framework + deplibs="$deplibs System.ltframework" + ;; + *-*-netbsd*) + # Don't link with libc until the a.out ld.so is fixed. + ;; + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) + # Do not include libc due to us having libc/libc_r. + ;; + *-*-sco3.2v5* | *-*-sco5v6*) + # Causes problems with __ctype + ;; + *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) + # Compiler inserts libc in the correct place for threads to work + ;; + *) + # Add libc to deplibs on all other systems if necessary. + if test "$build_libtool_need_lc" = "yes"; then + deplibs="$deplibs -lc" + fi + ;; + esac + fi + + # Transform deplibs into only deplibs that can be linked in shared. + name_save=$name + libname_save=$libname + release_save=$release + versuffix_save=$versuffix + major_save=$major + # I'm not sure if I'm treating the release correctly. I think + # release should show up in the -l (ie -lgmp5) so we don't want to + # add it in twice. Is that correct? + release="" + versuffix="" + major="" + newdeplibs= + droppeddeps=no + case $deplibs_check_method in + pass_all) + # Don't check for shared/static. Everything works. + # This might be a little naive. We might want to check + # whether the library exists or not. But this is on + # osf3 & osf4 and I'm not really sure... Just + # implementing what was already the behavior. + newdeplibs=$deplibs + ;; + test_compile) + # This code stresses the "libraries are programs" paradigm to its + # limits. Maybe even breaks it. We compile a program, linking it + # against the deplibs as a proxy for the library. Then we can check + # whether they linked in statically or dynamically with ldd. + $opt_dry_run || $RM conftest.c + cat > conftest.c </dev/null` + for potent_lib in $potential_libs; do + # Follow soft links. + if ls -lLd "$potent_lib" 2>/dev/null | + $GREP " -> " >/dev/null; then + continue + fi + # The statement above tries to avoid entering an + # endless loop below, in case of cyclic links. + # We might still enter an endless loop, since a link + # loop can be closed while we follow links, + # but so what? + potlib="$potent_lib" + while test -h "$potlib" 2>/dev/null; do + potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'` + case $potliblink in + [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";; + *) potlib=`$ECHO "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";; + esac + done + if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | + $SED -e 10q | + $EGREP "$file_magic_regex" > /dev/null; then + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + break 2 + fi + done + done + fi + if test -n "$a_deplib" ; then + droppeddeps=yes + $ECHO + $ECHO "*** Warning: linker path does not have real file for library $a_deplib." + $ECHO "*** I have the capability to make that library automatically link in when" + $ECHO "*** you link to this library. But I can only do this if you have a" + $ECHO "*** shared version of the library, which you do not appear to have" + $ECHO "*** because I did check the linker path looking for a file starting" + if test -z "$potlib" ; then + $ECHO "*** with $libname but no candidates were found. (...for file magic test)" + else + $ECHO "*** with $libname and none of the candidates passed a file format test" + $ECHO "*** using a file magic. Last file checked: $potlib" + fi + fi + ;; + *) + # Add a -L argument. + newdeplibs="$newdeplibs $a_deplib" + ;; + esac + done # Gone through all deplibs. + ;; + match_pattern*) + set dummy $deplibs_check_method; shift + match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` + for a_deplib in $deplibs; do + case $a_deplib in + -l*) + func_stripname -l '' "$a_deplib" + name=$func_stripname_result + if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then + case " $predeps $postdeps " in + *" $a_deplib "*) + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + ;; + esac + fi + if test -n "$a_deplib" ; then + libname=`eval "\\$ECHO \"$libname_spec\""` + for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do + potential_libs=`ls $i/$libname[.-]* 2>/dev/null` + for potent_lib in $potential_libs; do + potlib="$potent_lib" # see symlink-check above in file_magic test + if eval "\$ECHO \"X$potent_lib\"" 2>/dev/null | $Xsed -e 10q | \ + $EGREP "$match_pattern_regex" > /dev/null; then + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + break 2 + fi + done + done + fi + if test -n "$a_deplib" ; then + droppeddeps=yes + $ECHO + $ECHO "*** Warning: linker path does not have real file for library $a_deplib." + $ECHO "*** I have the capability to make that library automatically link in when" + $ECHO "*** you link to this library. But I can only do this if you have a" + $ECHO "*** shared version of the library, which you do not appear to have" + $ECHO "*** because I did check the linker path looking for a file starting" + if test -z "$potlib" ; then + $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" + else + $ECHO "*** with $libname and none of the candidates passed a file format test" + $ECHO "*** using a regex pattern. Last file checked: $potlib" + fi + fi + ;; + *) + # Add a -L argument. + newdeplibs="$newdeplibs $a_deplib" + ;; + esac + done # Gone through all deplibs. + ;; + none | unknown | *) + newdeplibs="" + tmp_deplibs=`$ECHO "X $deplibs" | $Xsed \ + -e 's/ -lc$//' -e 's/ -[LR][^ ]*//g'` + if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then + for i in $predeps $postdeps ; do + # can't use Xsed below, because $i might contain '/' + tmp_deplibs=`$ECHO "X $tmp_deplibs" | $Xsed -e "s,$i,,"` + done + fi + if $ECHO "X $tmp_deplibs" | $Xsed -e 's/[ ]//g' | + $GREP . >/dev/null; then + $ECHO + if test "X$deplibs_check_method" = "Xnone"; then + $ECHO "*** Warning: inter-library dependencies are not supported in this platform." + else + $ECHO "*** Warning: inter-library dependencies are not known to be supported." + fi + $ECHO "*** All declared inter-library dependencies are being dropped." + droppeddeps=yes + fi + ;; + esac + versuffix=$versuffix_save + major=$major_save + release=$release_save + libname=$libname_save + name=$name_save + + case $host in + *-*-rhapsody* | *-*-darwin1.[012]) + # On Rhapsody replace the C library with the System framework + newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's/ -lc / System.ltframework /'` + ;; + esac + + if test "$droppeddeps" = yes; then + if test "$module" = yes; then + $ECHO + $ECHO "*** Warning: libtool could not satisfy all declared inter-library" + $ECHO "*** dependencies of module $libname. Therefore, libtool will create" + $ECHO "*** a static module, that should work as long as the dlopening" + $ECHO "*** application is linked with the -dlopen flag." + if test -z "$global_symbol_pipe"; then + $ECHO + $ECHO "*** However, this would only work if libtool was able to extract symbol" + $ECHO "*** lists from a program, using \`nm' or equivalent, but libtool could" + $ECHO "*** not find such a program. So, this module is probably useless." + $ECHO "*** \`nm' from GNU binutils and a full rebuild may help." + fi + if test "$build_old_libs" = no; then + oldlibs="$output_objdir/$libname.$libext" + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + else + $ECHO "*** The inter-library dependencies that have been dropped here will be" + $ECHO "*** automatically added whenever a program is linked with this library" + $ECHO "*** or is declared to -dlopen it." + + if test "$allow_undefined" = no; then + $ECHO + $ECHO "*** Since this library must not contain undefined symbols," + $ECHO "*** because either the platform does not support them or" + $ECHO "*** it was explicitly requested with -no-undefined," + $ECHO "*** libtool will only create a static version of it." + if test "$build_old_libs" = no; then + oldlibs="$output_objdir/$libname.$libext" + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + fi + fi + fi + # Done checking deplibs! + deplibs=$newdeplibs + fi + # Time to change all our "foo.ltframework" stuff back to "-framework foo" + case $host in + *-*-darwin*) + newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` + new_inherited_linker_flags=`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` + deplibs=`$ECHO "X $deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` + ;; + esac + + # move library search paths that coincide with paths to not yet + # installed libraries to the beginning of the library search list + new_libs= + for path in $notinst_path; do + case " $new_libs " in + *" -L$path/$objdir "*) ;; + *) + case " $deplibs " in + *" -L$path/$objdir "*) + new_libs="$new_libs -L$path/$objdir" ;; + esac + ;; + esac + done + for deplib in $deplibs; do + case $deplib in + -L*) + case " $new_libs " in + *" $deplib "*) ;; + *) new_libs="$new_libs $deplib" ;; + esac + ;; + *) new_libs="$new_libs $deplib" ;; + esac + done + deplibs="$new_libs" + + # All the library-specific variables (install_libdir is set above). + library_names= + old_library= + dlname= + + # Test again, we may have decided not to build it any more + if test "$build_libtool_libs" = yes; then + if test "$hardcode_into_libs" = yes; then + # Hardcode the library paths + hardcode_libdirs= + dep_rpath= + rpath="$finalize_rpath" + test "$mode" != relink && rpath="$compile_rpath$rpath" + for libdir in $rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + dep_rpath="$dep_rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$perm_rpath " in + *" $libdir "*) ;; + *) perm_rpath="$perm_rpath $libdir" ;; + esac + fi + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + if test -n "$hardcode_libdir_flag_spec_ld"; then + eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\" + else + eval dep_rpath=\"$hardcode_libdir_flag_spec\" + fi + fi + if test -n "$runpath_var" && test -n "$perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $perm_rpath; do + rpath="$rpath$dir:" + done + eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" + fi + test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" + fi + + shlibpath="$finalize_shlibpath" + test "$mode" != relink && shlibpath="$compile_shlibpath$shlibpath" + if test -n "$shlibpath"; then + eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" + fi + + # Get the real and link names of the library. + eval shared_ext=\"$shrext_cmds\" + eval library_names=\"$library_names_spec\" + set dummy $library_names + shift + realname="$1" + shift + + if test -n "$soname_spec"; then + eval soname=\"$soname_spec\" + else + soname="$realname" + fi + if test -z "$dlname"; then + dlname=$soname + fi + + lib="$output_objdir/$realname" + linknames= + for link + do + linknames="$linknames $link" + done + + # Use standard objects if they are pic + test -z "$pic_flag" && libobjs=`$ECHO "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + test "X$libobjs" = "X " && libobjs= + + delfiles= + if test -n "$export_symbols" && test -n "$include_expsyms"; then + $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" + export_symbols="$output_objdir/$libname.uexp" + delfiles="$delfiles $export_symbols" + fi + + orig_export_symbols= + case $host_os in + cygwin* | mingw* | cegcc*) + if test -n "$export_symbols" && test -z "$export_symbols_regex"; then + # exporting using user supplied symfile + if test "x`$SED 1q $export_symbols`" != xEXPORTS; then + # and it's NOT already a .def file. Must figure out + # which of the given symbols are data symbols and tag + # them as such. So, trigger use of export_symbols_cmds. + # export_symbols gets reassigned inside the "prepare + # the list of exported symbols" if statement, so the + # include_expsyms logic still works. + orig_export_symbols="$export_symbols" + export_symbols= + always_export_symbols=yes + fi + fi + ;; + esac + + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then + func_verbose "generating symbol list for \`$libname.la'" + export_symbols="$output_objdir/$libname.exp" + $opt_dry_run || $RM $export_symbols + cmds=$export_symbols_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + func_len " $cmd" + len=$func_len_result + if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then + func_show_eval "$cmd" 'exit $?' + skipped_export=false + else + # The command line is too long to execute in one step. + func_verbose "using reloadable object file for export list..." + skipped_export=: + # Break out early, otherwise skipped_export may be + # set to false by a later but shorter cmd. + break + fi + done + IFS="$save_ifs" + if test -n "$export_symbols_regex" && test "X$skipped_export" != "X:"; then + func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' + func_show_eval '$MV "${export_symbols}T" "$export_symbols"' + fi + fi + fi + + if test -n "$export_symbols" && test -n "$include_expsyms"; then + tmp_export_symbols="$export_symbols" + test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols" + $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"' + fi + + if test "X$skipped_export" != "X:" && test -n "$orig_export_symbols"; then + # The given exports_symbols file has to be filtered, so filter it. + func_verbose "filter symbol list for \`$libname.la' to tag DATA exports" + # FIXME: $output_objdir/$libname.filter potentially contains lots of + # 's' commands which not all seds can handle. GNU sed should be fine + # though. Also, the filter scales superlinearly with the number of + # global variables. join(1) would be nice here, but unfortunately + # isn't a blessed tool. + $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter + delfiles="$delfiles $export_symbols $output_objdir/$libname.filter" + export_symbols=$output_objdir/$libname.def + $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols + fi + + tmp_deplibs= + for test_deplib in $deplibs; do + case " $convenience " in + *" $test_deplib "*) ;; + *) + tmp_deplibs="$tmp_deplibs $test_deplib" + ;; + esac + done + deplibs="$tmp_deplibs" + + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec" && + test "$compiler_needs_object" = yes && + test -z "$libobjs"; then + # extract the archives, so we have objects to list. + # TODO: could optimize this to just extract one archive. + whole_archive_flag_spec= + fi + if test -n "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + test "X$libobjs" = "X " && libobjs= + else + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + + func_extract_archives $gentop $convenience + libobjs="$libobjs $func_extract_archives_result" + test "X$libobjs" = "X " && libobjs= + fi + fi + + if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then + eval flag=\"$thread_safe_flag_spec\" + linker_flags="$linker_flags $flag" + fi + + # Make a backup of the uninstalled library when relinking + if test "$mode" = relink; then + $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? + fi + + # Do each of the archive commands. + if test "$module" = yes && test -n "$module_cmds" ; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + eval test_cmds=\"$module_expsym_cmds\" + cmds=$module_expsym_cmds + else + eval test_cmds=\"$module_cmds\" + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + eval test_cmds=\"$archive_expsym_cmds\" + cmds=$archive_expsym_cmds + else + eval test_cmds=\"$archive_cmds\" + cmds=$archive_cmds + fi + fi + + if test "X$skipped_export" != "X:" && + func_len " $test_cmds" && + len=$func_len_result && + test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then + : + else + # The command line is too long to link in one step, link piecewise + # or, if using GNU ld and skipped_export is not :, use a linker + # script. + + # Save the value of $output and $libobjs because we want to + # use them later. If we have whole_archive_flag_spec, we + # want to use save_libobjs as it was before + # whole_archive_flag_spec was expanded, because we can't + # assume the linker understands whole_archive_flag_spec. + # This may have to be revisited, in case too many + # convenience libraries get linked in and end up exceeding + # the spec. + if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + fi + save_output=$output + output_la=`$ECHO "X$output" | $Xsed -e "$basename"` + + # Clear the reloadable object creation command queue and + # initialize k to one. + test_cmds= + concat_cmds= + objlist= + last_robj= + k=1 + + if test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "$with_gnu_ld" = yes; then + output=${output_objdir}/${output_la}.lnkscript + func_verbose "creating GNU ld script: $output" + $ECHO 'INPUT (' > $output + for obj in $save_libobjs + do + $ECHO "$obj" >> $output + done + $ECHO ')' >> $output + delfiles="$delfiles $output" + elif test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "X$file_list_spec" != X; then + output=${output_objdir}/${output_la}.lnk + func_verbose "creating linker input file list: $output" + : > $output + set x $save_libobjs + shift + firstobj= + if test "$compiler_needs_object" = yes; then + firstobj="$1 " + shift + fi + for obj + do + $ECHO "$obj" >> $output + done + delfiles="$delfiles $output" + output=$firstobj\"$file_list_spec$output\" + else + if test -n "$save_libobjs"; then + func_verbose "creating reloadable object files..." + output=$output_objdir/$output_la-${k}.$objext + eval test_cmds=\"$reload_cmds\" + func_len " $test_cmds" + len0=$func_len_result + len=$len0 + + # Loop over the list of objects to be linked. + for obj in $save_libobjs + do + func_len " $obj" + func_arith $len + $func_len_result + len=$func_arith_result + if test "X$objlist" = X || + test "$len" -lt "$max_cmd_len"; then + func_append objlist " $obj" + else + # The command $test_cmds is almost too long, add a + # command to the queue. + if test "$k" -eq 1 ; then + # The first file doesn't have a previous command to add. + eval concat_cmds=\"$reload_cmds $objlist $last_robj\" + else + # All subsequent reloadable object files will link in + # the last one created. + eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj~\$RM $last_robj\" + fi + last_robj=$output_objdir/$output_la-${k}.$objext + func_arith $k + 1 + k=$func_arith_result + output=$output_objdir/$output_la-${k}.$objext + objlist=$obj + func_len " $last_robj" + func_arith $len0 + $func_len_result + len=$func_arith_result + fi + done + # Handle the remaining objects by creating one last + # reloadable object file. All subsequent reloadable object + # files will link in the last one created. + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\" + if test -n "$last_robj"; then + eval concat_cmds=\"\${concat_cmds}~\$RM $last_robj\" + fi + delfiles="$delfiles $output" + + else + output= + fi + + if ${skipped_export-false}; then + func_verbose "generating symbol list for \`$libname.la'" + export_symbols="$output_objdir/$libname.exp" + $opt_dry_run || $RM $export_symbols + libobjs=$output + # Append the command to create the export file. + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" + if test -n "$last_robj"; then + eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" + fi + fi + + test -n "$save_libobjs" && + func_verbose "creating a temporary reloadable object file: $output" + + # Loop through the commands generated above and execute them. + save_ifs="$IFS"; IFS='~' + for cmd in $concat_cmds; do + IFS="$save_ifs" + $opt_silent || { + func_quote_for_expand "$cmd" + eval "func_echo $func_quote_for_expand_result" + } + $opt_dry_run || eval "$cmd" || { + lt_exit=$? + + # Restore the uninstalled library and exit + if test "$mode" = relink; then + ( cd "$output_objdir" && \ + $RM "${realname}T" && \ + $MV "${realname}U" "$realname" ) + fi + + exit $lt_exit + } + done + IFS="$save_ifs" + + if test -n "$export_symbols_regex" && ${skipped_export-false}; then + func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' + func_show_eval '$MV "${export_symbols}T" "$export_symbols"' + fi + fi + + if ${skipped_export-false}; then + if test -n "$export_symbols" && test -n "$include_expsyms"; then + tmp_export_symbols="$export_symbols" + test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols" + $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"' + fi + + if test -n "$orig_export_symbols"; then + # The given exports_symbols file has to be filtered, so filter it. + func_verbose "filter symbol list for \`$libname.la' to tag DATA exports" + # FIXME: $output_objdir/$libname.filter potentially contains lots of + # 's' commands which not all seds can handle. GNU sed should be fine + # though. Also, the filter scales superlinearly with the number of + # global variables. join(1) would be nice here, but unfortunately + # isn't a blessed tool. + $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter + delfiles="$delfiles $export_symbols $output_objdir/$libname.filter" + export_symbols=$output_objdir/$libname.def + $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols + fi + fi + + libobjs=$output + # Restore the value of output. + output=$save_output + + if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + test "X$libobjs" = "X " && libobjs= + fi + # Expand the library linking commands again to reset the + # value of $libobjs for piecewise linking. + + # Do each of the archive commands. + if test "$module" = yes && test -n "$module_cmds" ; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + cmds=$module_expsym_cmds + else + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + cmds=$archive_expsym_cmds + else + cmds=$archive_cmds + fi + fi + fi + + if test -n "$delfiles"; then + # Append the command to remove temporary files to $cmds. + eval cmds=\"\$cmds~\$RM $delfiles\" + fi + + # Add any objects from preloaded convenience libraries + if test -n "$dlprefiles"; then + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + + func_extract_archives $gentop $dlprefiles + libobjs="$libobjs $func_extract_archives_result" + test "X$libobjs" = "X " && libobjs= + fi + + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $opt_silent || { + func_quote_for_expand "$cmd" + eval "func_echo $func_quote_for_expand_result" + } + $opt_dry_run || eval "$cmd" || { + lt_exit=$? + + # Restore the uninstalled library and exit + if test "$mode" = relink; then + ( cd "$output_objdir" && \ + $RM "${realname}T" && \ + $MV "${realname}U" "$realname" ) + fi + + exit $lt_exit + } + done + IFS="$save_ifs" + + # Restore the uninstalled library and exit + if test "$mode" = relink; then + $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? + + if test -n "$convenience"; then + if test -z "$whole_archive_flag_spec"; then + func_show_eval '${RM}r "$gentop"' + fi + fi + + exit $EXIT_SUCCESS + fi + + # Create links to the real library. + for linkname in $linknames; do + if test "$realname" != "$linkname"; then + func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' + fi + done + + # If -module or -export-dynamic was specified, set the dlname. + if test "$module" = yes || test "$export_dynamic" = yes; then + # On all known operating systems, these are identical. + dlname="$soname" + fi + fi + ;; + + obj) + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + func_warning "\`-dlopen' is ignored for objects" + fi + + case " $deplibs" in + *\ -l* | *\ -L*) + func_warning "\`-l' and \`-L' are ignored for objects" ;; + esac + + test -n "$rpath" && \ + func_warning "\`-rpath' is ignored for objects" + + test -n "$xrpath" && \ + func_warning "\`-R' is ignored for objects" + + test -n "$vinfo" && \ + func_warning "\`-version-info' is ignored for objects" + + test -n "$release" && \ + func_warning "\`-release' is ignored for objects" + + case $output in + *.lo) + test -n "$objs$old_deplibs" && \ + func_fatal_error "cannot build library object \`$output' from non-libtool objects" + + libobj=$output + func_lo2o "$libobj" + obj=$func_lo2o_result + ;; + *) + libobj= + obj="$output" + ;; + esac + + # Delete the old objects. + $opt_dry_run || $RM $obj $libobj + + # Objects from convenience libraries. This assumes + # single-version convenience libraries. Whenever we create + # different ones for PIC/non-PIC, this we'll have to duplicate + # the extraction. + reload_conv_objs= + gentop= + # reload_cmds runs $LD directly, so let us get rid of + # -Wl from whole_archive_flag_spec and hope we can get by with + # turning comma into space.. + wl= + + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec"; then + eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" + reload_conv_objs=$reload_objs\ `$ECHO "X$tmp_whole_archive_flags" | $Xsed -e 's|,| |g'` + else + gentop="$output_objdir/${obj}x" + generated="$generated $gentop" + + func_extract_archives $gentop $convenience + reload_conv_objs="$reload_objs $func_extract_archives_result" + fi + fi + + # Create the old-style object. + reload_objs="$objs$old_deplibs "`$ECHO "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test + + output="$obj" + func_execute_cmds "$reload_cmds" 'exit $?' + + # Exit if we aren't doing a library object file. + if test -z "$libobj"; then + if test -n "$gentop"; then + func_show_eval '${RM}r "$gentop"' + fi + + exit $EXIT_SUCCESS + fi + + if test "$build_libtool_libs" != yes; then + if test -n "$gentop"; then + func_show_eval '${RM}r "$gentop"' + fi + + # Create an invalid libtool object if no PIC, so that we don't + # accidentally link it into a program. + # $show "echo timestamp > $libobj" + # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? + exit $EXIT_SUCCESS + fi + + if test -n "$pic_flag" || test "$pic_mode" != default; then + # Only do commands if we really have different PIC objects. + reload_objs="$libobjs $reload_conv_objs" + output="$libobj" + func_execute_cmds "$reload_cmds" 'exit $?' + fi + + if test -n "$gentop"; then + func_show_eval '${RM}r "$gentop"' + fi + + exit $EXIT_SUCCESS + ;; + + prog) + case $host in + *cygwin*) func_stripname '' '.exe' "$output" + output=$func_stripname_result.exe;; + esac + test -n "$vinfo" && \ + func_warning "\`-version-info' is ignored for programs" + + test -n "$release" && \ + func_warning "\`-release' is ignored for programs" + + test "$preload" = yes \ + && test "$dlopen_support" = unknown \ + && test "$dlopen_self" = unknown \ + && test "$dlopen_self_static" = unknown && \ + func_warning "\`LT_INIT([dlopen])' not used. Assuming no dlopen support." + + case $host in + *-*-rhapsody* | *-*-darwin1.[012]) + # On Rhapsody replace the C library is the System framework + compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'` + finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'` + ;; + esac + + case $host in + *-*-darwin*) + # Don't allow lazy linking, it breaks C++ global constructors + # But is supposedly fixed on 10.4 or later (yay!). + if test "$tagname" = CXX ; then + case ${MACOSX_DEPLOYMENT_TARGET-10.0} in + 10.[0123]) + compile_command="$compile_command ${wl}-bind_at_load" + finalize_command="$finalize_command ${wl}-bind_at_load" + ;; + esac + fi + # Time to change all our "foo.ltframework" stuff back to "-framework foo" + compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` + finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'` + ;; + esac + + + # move library search paths that coincide with paths to not yet + # installed libraries to the beginning of the library search list + new_libs= + for path in $notinst_path; do + case " $new_libs " in + *" -L$path/$objdir "*) ;; + *) + case " $compile_deplibs " in + *" -L$path/$objdir "*) + new_libs="$new_libs -L$path/$objdir" ;; + esac + ;; + esac + done + for deplib in $compile_deplibs; do + case $deplib in + -L*) + case " $new_libs " in + *" $deplib "*) ;; + *) new_libs="$new_libs $deplib" ;; + esac + ;; + *) new_libs="$new_libs $deplib" ;; + esac + done + compile_deplibs="$new_libs" + + + compile_command="$compile_command $compile_deplibs" + finalize_command="$finalize_command $finalize_deplibs" + + if test -n "$rpath$xrpath"; then + # If the user specified any rpath flags, then add them. + for libdir in $rpath $xrpath; do + # This is the magic to use -rpath. + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" ;; + esac + done + fi + + # Now hardcode the library paths + rpath= + hardcode_libdirs= + for libdir in $compile_rpath $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + rpath="$rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$perm_rpath " in + *" $libdir "*) ;; + *) perm_rpath="$perm_rpath $libdir" ;; + esac + fi + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) + testbindir=`${ECHO} "$libdir" | ${SED} -e 's*/lib$*/bin*'` + case :$dllsearchpath: in + *":$libdir:"*) ;; + ::) dllsearchpath=$libdir;; + *) dllsearchpath="$dllsearchpath:$libdir";; + esac + case :$dllsearchpath: in + *":$testbindir:"*) ;; + ::) dllsearchpath=$testbindir;; + *) dllsearchpath="$dllsearchpath:$testbindir";; + esac + ;; + esac + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + compile_rpath="$rpath" + + rpath= + hardcode_libdirs= + for libdir in $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + rpath="$rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$finalize_perm_rpath " in + *" $libdir "*) ;; + *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;; + esac + fi + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + finalize_rpath="$rpath" + + if test -n "$libobjs" && test "$build_old_libs" = yes; then + # Transform all the library objects into standard objects. + compile_command=`$ECHO "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + finalize_command=`$ECHO "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + fi + + func_generate_dlsyms "$outputname" "@PROGRAM@" "no" + + # template prelinking step + if test -n "$prelink_cmds"; then + func_execute_cmds "$prelink_cmds" 'exit $?' + fi + + wrappers_required=yes + case $host in + *cygwin* | *mingw* ) + if test "$build_libtool_libs" != yes; then + wrappers_required=no + fi + ;; + *cegcc) + # Disable wrappers for cegcc, we are cross compiling anyway. + wrappers_required=no + ;; + *) + if test "$need_relink" = no || test "$build_libtool_libs" != yes; then + wrappers_required=no + fi + ;; + esac + if test "$wrappers_required" = no; then + # Replace the output file specification. + compile_command=`$ECHO "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` + link_command="$compile_command$compile_rpath" + + # We have no uninstalled library dependencies, so finalize right now. + exit_status=0 + func_show_eval "$link_command" 'exit_status=$?' + + # Delete the generated files. + if test -f "$output_objdir/${outputname}S.${objext}"; then + func_show_eval '$RM "$output_objdir/${outputname}S.${objext}"' + fi + + exit $exit_status + fi + + if test -n "$compile_shlibpath$finalize_shlibpath"; then + compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" + fi + if test -n "$finalize_shlibpath"; then + finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" + fi + + compile_var= + finalize_var= + if test -n "$runpath_var"; then + if test -n "$perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $perm_rpath; do + rpath="$rpath$dir:" + done + compile_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + if test -n "$finalize_perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $finalize_perm_rpath; do + rpath="$rpath$dir:" + done + finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + fi + + if test "$no_install" = yes; then + # We don't need to create a wrapper script. + link_command="$compile_var$compile_command$compile_rpath" + # Replace the output file specification. + link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` + # Delete the old output file. + $opt_dry_run || $RM $output + # Link the executable and exit + func_show_eval "$link_command" 'exit $?' + exit $EXIT_SUCCESS + fi + + if test "$hardcode_action" = relink; then + # Fast installation is not supported + link_command="$compile_var$compile_command$compile_rpath" + relink_command="$finalize_var$finalize_command$finalize_rpath" + + func_warning "this platform does not like uninstalled shared libraries" + func_warning "\`$output' will be relinked during installation" + else + if test "$fast_install" != no; then + link_command="$finalize_var$compile_command$finalize_rpath" + if test "$fast_install" = yes; then + relink_command=`$ECHO "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'` + else + # fast_install is set to needless + relink_command= + fi + else + link_command="$compile_var$compile_command$compile_rpath" + relink_command="$finalize_var$finalize_command$finalize_rpath" + fi + fi + + # Replace the output file specification. + link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` + + # Delete the old output files. + $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname + + func_show_eval "$link_command" 'exit $?' + + # Now create the wrapper script. + func_verbose "creating $output" + + # Quote the relink command for shipping. + if test -n "$relink_command"; then + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + func_quote_for_eval "$var_value" + relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" + fi + done + relink_command="(cd `pwd`; $relink_command)" + relink_command=`$ECHO "X$relink_command" | $Xsed -e "$sed_quote_subst"` + fi + + # Quote $ECHO for shipping. + if test "X$ECHO" = "X$SHELL $progpath --fallback-echo"; then + case $progpath in + [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";; + *) qecho="$SHELL `pwd`/$progpath --fallback-echo";; + esac + qecho=`$ECHO "X$qecho" | $Xsed -e "$sed_quote_subst"` + else + qecho=`$ECHO "X$ECHO" | $Xsed -e "$sed_quote_subst"` + fi + + # Only actually do things if not in dry run mode. + $opt_dry_run || { + # win32 will think the script is a binary if it has + # a .exe suffix, so we strip it off here. + case $output in + *.exe) func_stripname '' '.exe' "$output" + output=$func_stripname_result ;; + esac + # test for cygwin because mv fails w/o .exe extensions + case $host in + *cygwin*) + exeext=.exe + func_stripname '' '.exe' "$outputname" + outputname=$func_stripname_result ;; + *) exeext= ;; + esac + case $host in + *cygwin* | *mingw* ) + func_dirname_and_basename "$output" "" "." + output_name=$func_basename_result + output_path=$func_dirname_result + cwrappersource="$output_path/$objdir/lt-$output_name.c" + cwrapper="$output_path/$output_name.exe" + $RM $cwrappersource $cwrapper + trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 + + func_emit_cwrapperexe_src > $cwrappersource + + # The wrapper executable is built using the $host compiler, + # because it contains $host paths and files. If cross- + # compiling, it, like the target executable, must be + # executed on the $host or under an emulation environment. + $opt_dry_run || { + $LTCC $LTCFLAGS -o $cwrapper $cwrappersource + $STRIP $cwrapper + } + + # Now, create the wrapper script for func_source use: + func_ltwrapper_scriptname $cwrapper + $RM $func_ltwrapper_scriptname_result + trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 + $opt_dry_run || { + # note: this script will not be executed, so do not chmod. + if test "x$build" = "x$host" ; then + $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result + else + func_emit_wrapper no > $func_ltwrapper_scriptname_result + fi + } + ;; + * ) + $RM $output + trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 + + func_emit_wrapper no > $output + chmod +x $output + ;; + esac + } + exit $EXIT_SUCCESS + ;; + esac + + # See if we need to build an old-fashioned archive. + for oldlib in $oldlibs; do + + if test "$build_libtool_libs" = convenience; then + oldobjs="$libobjs_save $symfileobj" + addlibs="$convenience" + build_libtool_libs=no + else + if test "$build_libtool_libs" = module; then + oldobjs="$libobjs_save" + build_libtool_libs=no + else + oldobjs="$old_deplibs $non_pic_objects" + if test "$preload" = yes && test -f "$symfileobj"; then + oldobjs="$oldobjs $symfileobj" + fi + fi + addlibs="$old_convenience" + fi + + if test -n "$addlibs"; then + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + + func_extract_archives $gentop $addlibs + oldobjs="$oldobjs $func_extract_archives_result" + fi + + # Do each command in the archive commands. + if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then + cmds=$old_archive_from_new_cmds + else + + # Add any objects from preloaded convenience libraries + if test -n "$dlprefiles"; then + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + + func_extract_archives $gentop $dlprefiles + oldobjs="$oldobjs $func_extract_archives_result" + fi + + # POSIX demands no paths to be encoded in archives. We have + # to avoid creating archives with duplicate basenames if we + # might have to extract them afterwards, e.g., when creating a + # static archive out of a convenience library, or when linking + # the entirety of a libtool archive into another (currently + # not supported by libtool). + if (for obj in $oldobjs + do + func_basename "$obj" + $ECHO "$func_basename_result" + done | sort | sort -uc >/dev/null 2>&1); then + : + else + $ECHO "copying selected object files to avoid basename conflicts..." + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + func_mkdir_p "$gentop" + save_oldobjs=$oldobjs + oldobjs= + counter=1 + for obj in $save_oldobjs + do + func_basename "$obj" + objbase="$func_basename_result" + case " $oldobjs " in + " ") oldobjs=$obj ;; + *[\ /]"$objbase "*) + while :; do + # Make sure we don't pick an alternate name that also + # overlaps. + newobj=lt$counter-$objbase + func_arith $counter + 1 + counter=$func_arith_result + case " $oldobjs " in + *[\ /]"$newobj "*) ;; + *) if test ! -f "$gentop/$newobj"; then break; fi ;; + esac + done + func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" + oldobjs="$oldobjs $gentop/$newobj" + ;; + *) oldobjs="$oldobjs $obj" ;; + esac + done + fi + eval cmds=\"$old_archive_cmds\" + + func_len " $cmds" + len=$func_len_result + if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then + cmds=$old_archive_cmds + else + # the command line is too long to link in one step, link in parts + func_verbose "using piecewise archive linking..." + save_RANLIB=$RANLIB + RANLIB=: + objlist= + concat_cmds= + save_oldobjs=$oldobjs + oldobjs= + # Is there a better way of finding the last object in the list? + for obj in $save_oldobjs + do + last_oldobj=$obj + done + eval test_cmds=\"$old_archive_cmds\" + func_len " $test_cmds" + len0=$func_len_result + len=$len0 + for obj in $save_oldobjs + do + func_len " $obj" + func_arith $len + $func_len_result + len=$func_arith_result + func_append objlist " $obj" + if test "$len" -lt "$max_cmd_len"; then + : + else + # the above command should be used before it gets too long + oldobjs=$objlist + if test "$obj" = "$last_oldobj" ; then + RANLIB=$save_RANLIB + fi + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\" + objlist= + len=$len0 + fi + done + RANLIB=$save_RANLIB + oldobjs=$objlist + if test "X$oldobjs" = "X" ; then + eval cmds=\"\$concat_cmds\" + else + eval cmds=\"\$concat_cmds~\$old_archive_cmds\" + fi + fi + fi + func_execute_cmds "$cmds" 'exit $?' + done + + test -n "$generated" && \ + func_show_eval "${RM}r$generated" + + # Now create the libtool archive. + case $output in + *.la) + old_library= + test "$build_old_libs" = yes && old_library="$libname.$libext" + func_verbose "creating $output" + + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + func_quote_for_eval "$var_value" + relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" + fi + done + # Quote the link command for shipping. + relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" + relink_command=`$ECHO "X$relink_command" | $Xsed -e "$sed_quote_subst"` + if test "$hardcode_automatic" = yes ; then + relink_command= + fi + + # Only create the output if not a dry run. + $opt_dry_run || { + for installed in no yes; do + if test "$installed" = yes; then + if test -z "$install_libdir"; then + break + fi + output="$output_objdir/$outputname"i + # Replace all uninstalled libtool libraries with the installed ones + newdependency_libs= + for deplib in $dependency_libs; do + case $deplib in + *.la) + func_basename "$deplib" + name="$func_basename_result" + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` + test -z "$libdir" && \ + func_fatal_error "\`$deplib' is not a valid libtool archive" + newdependency_libs="$newdependency_libs $libdir/$name" + ;; + *) newdependency_libs="$newdependency_libs $deplib" ;; + esac + done + dependency_libs="$newdependency_libs" + newdlfiles= + + for lib in $dlfiles; do + case $lib in + *.la) + func_basename "$lib" + name="$func_basename_result" + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + test -z "$libdir" && \ + func_fatal_error "\`$lib' is not a valid libtool archive" + newdlfiles="$newdlfiles $libdir/$name" + ;; + *) newdlfiles="$newdlfiles $lib" ;; + esac + done + dlfiles="$newdlfiles" + newdlprefiles= + for lib in $dlprefiles; do + case $lib in + *.la) + # Only pass preopened files to the pseudo-archive (for + # eventual linking with the app. that links it) if we + # didn't already link the preopened objects directly into + # the library: + func_basename "$lib" + name="$func_basename_result" + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + test -z "$libdir" && \ + func_fatal_error "\`$lib' is not a valid libtool archive" + newdlprefiles="$newdlprefiles $libdir/$name" + ;; + esac + done + dlprefiles="$newdlprefiles" + else + newdlfiles= + for lib in $dlfiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; + *) abs=`pwd`"/$lib" ;; + esac + newdlfiles="$newdlfiles $abs" + done + dlfiles="$newdlfiles" + newdlprefiles= + for lib in $dlprefiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; + *) abs=`pwd`"/$lib" ;; + esac + newdlprefiles="$newdlprefiles $abs" + done + dlprefiles="$newdlprefiles" + fi + $RM $output + # place dlname in correct position for cygwin + tdlname=$dlname + case $host,$output,$installed,$module,$dlname in + *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;; + esac + $ECHO > $output "\ +# $outputname - a libtool library file +# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION +# +# Please DO NOT delete this file! +# It is necessary for linking the library. + +# The name that we can dlopen(3). +dlname='$tdlname' + +# Names of this library. +library_names='$library_names' + +# The name of the static archive. +old_library='$old_library' + +# Linker flags that can not go in dependency_libs. +inherited_linker_flags='$new_inherited_linker_flags' + +# Libraries that this one depends upon. +dependency_libs='$dependency_libs' + +# Names of additional weak libraries provided by this library +weak_library_names='$weak_libs' + +# Version information for $libname. +current=$current +age=$age +revision=$revision + +# Is this an already installed library? +installed=$installed + +# Should we warn about portability when linking against -modules? +shouldnotlink=$module + +# Files to dlopen/dlpreopen +dlopen='$dlfiles' +dlpreopen='$dlprefiles' + +# Directory that this library needs to be installed in: +libdir='$install_libdir'" + if test "$installed" = no && test "$need_relink" = yes; then + $ECHO >> $output "\ +relink_command=\"$relink_command\"" + fi + done + } + + # Do a symbolic link so that the libtool archive can be found in + # LD_LIBRARY_PATH before the program is installed. + func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' + ;; + esac + exit $EXIT_SUCCESS +} + +{ test "$mode" = link || test "$mode" = relink; } && + func_mode_link ${1+"$@"} + + +# func_mode_uninstall arg... +func_mode_uninstall () +{ + $opt_debug + RM="$nonopt" + files= + rmforce= + exit_status=0 + + # This variable tells wrapper scripts just to set variables rather + # than running their programs. + libtool_install_magic="$magic" + + for arg + do + case $arg in + -f) RM="$RM $arg"; rmforce=yes ;; + -*) RM="$RM $arg" ;; + *) files="$files $arg" ;; + esac + done + + test -z "$RM" && \ + func_fatal_help "you must specify an RM program" + + rmdirs= + + origobjdir="$objdir" + for file in $files; do + func_dirname "$file" "" "." + dir="$func_dirname_result" + if test "X$dir" = X.; then + objdir="$origobjdir" + else + objdir="$dir/$origobjdir" + fi + func_basename "$file" + name="$func_basename_result" + test "$mode" = uninstall && objdir="$dir" + + # Remember objdir for removal later, being careful to avoid duplicates + if test "$mode" = clean; then + case " $rmdirs " in + *" $objdir "*) ;; + *) rmdirs="$rmdirs $objdir" ;; + esac + fi + + # Don't error if the file doesn't exist and rm -f was used. + if { test -L "$file"; } >/dev/null 2>&1 || + { test -h "$file"; } >/dev/null 2>&1 || + test -f "$file"; then + : + elif test -d "$file"; then + exit_status=1 + continue + elif test "$rmforce" = yes; then + continue + fi + + rmfiles="$file" + + case $name in + *.la) + # Possibly a libtool archive, so verify it. + if func_lalib_p "$file"; then + func_source $dir/$name + + # Delete the libtool libraries and symlinks. + for n in $library_names; do + rmfiles="$rmfiles $objdir/$n" + done + test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library" + + case "$mode" in + clean) + case " $library_names " in + # " " in the beginning catches empty $dlname + *" $dlname "*) ;; + *) rmfiles="$rmfiles $objdir/$dlname" ;; + esac + test -n "$libdir" && rmfiles="$rmfiles $objdir/$name $objdir/${name}i" + ;; + uninstall) + if test -n "$library_names"; then + # Do each command in the postuninstall commands. + func_execute_cmds "$postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1' + fi + + if test -n "$old_library"; then + # Do each command in the old_postuninstall commands. + func_execute_cmds "$old_postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1' + fi + # FIXME: should reinstall the best remaining shared library. + ;; + esac + fi + ;; + + *.lo) + # Possibly a libtool object, so verify it. + if func_lalib_p "$file"; then + + # Read the .lo file + func_source $dir/$name + + # Add PIC object to the list of files to remove. + if test -n "$pic_object" && + test "$pic_object" != none; then + rmfiles="$rmfiles $dir/$pic_object" + fi + + # Add non-PIC object to the list of files to remove. + if test -n "$non_pic_object" && + test "$non_pic_object" != none; then + rmfiles="$rmfiles $dir/$non_pic_object" + fi + fi + ;; + + *) + if test "$mode" = clean ; then + noexename=$name + case $file in + *.exe) + func_stripname '' '.exe' "$file" + file=$func_stripname_result + func_stripname '' '.exe' "$name" + noexename=$func_stripname_result + # $file with .exe has already been added to rmfiles, + # add $file without .exe + rmfiles="$rmfiles $file" + ;; + esac + # Do a test to see if this is a libtool program. + if func_ltwrapper_p "$file"; then + if func_ltwrapper_executable_p "$file"; then + func_ltwrapper_scriptname "$file" + relink_command= + func_source $func_ltwrapper_scriptname_result + rmfiles="$rmfiles $func_ltwrapper_scriptname_result" + else + relink_command= + func_source $dir/$noexename + fi + + # note $name still contains .exe if it was in $file originally + # as does the version of $file that was added into $rmfiles + rmfiles="$rmfiles $objdir/$name $objdir/${name}S.${objext}" + if test "$fast_install" = yes && test -n "$relink_command"; then + rmfiles="$rmfiles $objdir/lt-$name" + fi + if test "X$noexename" != "X$name" ; then + rmfiles="$rmfiles $objdir/lt-${noexename}.c" + fi + fi + fi + ;; + esac + func_show_eval "$RM $rmfiles" 'exit_status=1' + done + objdir="$origobjdir" + + # Try to remove the ${objdir}s in the directories where we deleted files + for dir in $rmdirs; do + if test -d "$dir"; then + func_show_eval "rmdir $dir >/dev/null 2>&1" + fi + done + + exit $exit_status +} + +{ test "$mode" = uninstall || test "$mode" = clean; } && + func_mode_uninstall ${1+"$@"} + +test -z "$mode" && { + help="$generic_help" + func_fatal_help "you must specify a MODE" +} + +test -z "$exec_cmd" && \ + func_fatal_help "invalid operation mode \`$mode'" + +if test -n "$exec_cmd"; then + eval exec "$exec_cmd" + exit $EXIT_FAILURE +fi + +exit $exit_status + + +# The TAGs below are defined such that we never get into a situation +# in which we disable both kinds of libraries. Given conflicting +# choices, we go for a static library, that is the most portable, +# since we can't tell whether shared libraries were disabled because +# the user asked for that or because the platform doesn't support +# them. This is particularly important on AIX, because we don't +# support having both static and shared libraries enabled at the same +# time on that platform, so we default to a shared-only configuration. +# If a disable-shared tag is given, we'll fallback to a static-only +# configuration. But we'll never go from static-only to shared-only. + +# ### BEGIN LIBTOOL TAG CONFIG: disable-shared +build_libtool_libs=no +build_old_libs=yes +# ### END LIBTOOL TAG CONFIG: disable-shared + +# ### BEGIN LIBTOOL TAG CONFIG: disable-static +build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` +# ### END LIBTOOL TAG CONFIG: disable-static + +# Local Variables: +# mode:shell-script +# sh-indentation:2 +# End: +# vi:sw=2 + diff --git a/Externals/SDL/build-scripts/makedep.sh b/Externals/SDL/build-scripts/makedep.sh new file mode 100755 index 0000000000..ceffe275b0 --- /dev/null +++ b/Externals/SDL/build-scripts/makedep.sh @@ -0,0 +1,93 @@ +#!/bin/sh +# +# Generate dependencies from a list of source files + +# Check to make sure our environment variables are set +if test x"$INCLUDE" = x -o x"$SOURCES" = x -o x"$output" = x; then + echo "SOURCES, INCLUDE, and output needs to be set" + exit 1 +fi +cache_prefix=".#$$" + +generate_var() +{ + echo $1 | sed -e 's|^.*/||' -e 's|\.|_|g' +} + +search_deps() +{ + base=`echo $1 | sed 's|/[^/]*$||'` + grep '#include "' <$1 | sed -e 's|.*"\([^"]*\)".*|\1|' | \ + while read file + do cache=${cache_prefix}_`generate_var $file` + if test -f $cache; then + : # We already ahve this cached + else + : >$cache + for path in $base `echo $INCLUDE | sed 's|-I||g'` + do dep="$path/$file" + if test -f "$dep"; then + echo " $dep \\" >>$cache + search_deps $dep >>$cache + break + fi + done + fi + cat $cache + done +} + +:>${output}.new +for src in $SOURCES +do echo "Generating dependencies for $src" + ext=`echo $src | sed 's|.*\.\(.*\)|\1|'` + if test x"$ext" = x"rc"; then + obj=`echo $src | sed "s|^.*/\([^ ]*\)\..*|\1.o|g"` + else + obj=`echo $src | sed "s|^.*/\([^ ]*\)\..*|\1.lo|g"` + fi + echo "\$(objects)/$obj: $src \\" >>${output}.new + search_deps $src | sort | uniq >>${output}.new + case $ext in + c) cat >>${output}.new <<__EOF__ + + \$(LIBTOOL) --mode=compile \$(CC) \$(CFLAGS) \$(EXTRA_CFLAGS) -c $src -o \$@ + +__EOF__ + ;; + cc) cat >>${output}.new <<__EOF__ + + \$(LIBTOOL) --mode=compile \$(CC) \$(CFLAGS) \$(EXTRA_CFLAGS) -c $src -o \$@ + +__EOF__ + ;; + m) cat >>${output}.new <<__EOF__ + + \$(LIBTOOL) --mode=compile \$(CC) \$(CFLAGS) \$(EXTRA_CFLAGS) -c $src -o \$@ + +__EOF__ + ;; + asm) cat >>${output}.new <<__EOF__ + + \$(LIBTOOL) --tag=CC --mode=compile \$(auxdir)/strip_fPIC.sh \$(NASM) $src -o \$@ + +__EOF__ + ;; + S) cat >>${output}.new <<__EOF__ + + \$(LIBTOOL) --mode=compile \$(CC) \$(CFLAGS) \$(EXTRA_CFLAGS) -c $src -o \$@ + +__EOF__ + ;; + rc) cat >>${output}.new <<__EOF__ + + \$(WINDRES) $src \$@ + +__EOF__ + ;; + *) echo "Unknown file extension: $ext";; + esac + echo "" >>${output}.new +done +mv ${output}.new ${output} +rm -f ${cache_prefix}* diff --git a/Externals/SDL/build-scripts/mkinstalldirs b/Externals/SDL/build-scripts/mkinstalldirs new file mode 100755 index 0000000000..8ab885ec92 --- /dev/null +++ b/Externals/SDL/build-scripts/mkinstalldirs @@ -0,0 +1,99 @@ +#! /bin/sh +# mkinstalldirs --- make directory hierarchy +# Author: Noah Friedman +# Created: 1993-05-16 +# Public domain + +errstatus=0 +dirmode="" + +usage="\ +Usage: mkinstalldirs [-h] [--help] [-m mode] dir ..." + +# process command line arguments +while test $# -gt 0 ; do + case "${1}" in + -h | --help | --h* ) # -h for help + echo "${usage}" 1>&2; exit 0 ;; + -m ) # -m PERM arg + shift + test $# -eq 0 && { echo "${usage}" 1>&2; exit 1; } + dirmode="${1}" + shift ;; + -- ) shift; break ;; # stop option processing + -* ) echo "${usage}" 1>&2; exit 1 ;; # unknown option + * ) break ;; # first non-opt arg + esac +done + +for file +do + if test -d "$file"; then + shift + else + break + fi +done + +case $# in +0) exit 0 ;; +esac + +case $dirmode in +'') + if mkdir -p -- . 2>/dev/null; then + echo "mkdir -p -- $*" + exec mkdir -p -- "$@" + fi ;; +*) + if mkdir -m "$dirmode" -p -- . 2>/dev/null; then + echo "mkdir -m $dirmode -p -- $*" + exec mkdir -m "$dirmode" -p -- "$@" + fi ;; +esac + +for file +do + set fnord `echo ":$file" | sed -ne 's/^:\//#/;s/^://;s/\// /g;s/^#/\//;p'` + shift + + pathcomp= + for d + do + pathcomp="$pathcomp$d" + case "$pathcomp" in + -* ) pathcomp=./$pathcomp ;; + esac + + if test ! -d "$pathcomp"; then + echo "mkdir $pathcomp" + + mkdir "$pathcomp" || lasterr=$? + + if test ! -d "$pathcomp"; then + errstatus=$lasterr + else + if test ! -z "$dirmode"; then + echo "chmod $dirmode $pathcomp" + + lasterr="" + chmod "$dirmode" "$pathcomp" || lasterr=$? + + if test ! -z "$lasterr"; then + errstatus=$lasterr + fi + fi + fi + fi + + pathcomp="$pathcomp/" + done +done + +exit $errstatus + +# Local Variables: +# mode: shell-script +# sh-indentation: 3 +# End: +# mkinstalldirs ends here diff --git a/Externals/SDL/build-scripts/strip_fPIC.sh b/Externals/SDL/build-scripts/strip_fPIC.sh new file mode 100755 index 0000000000..45d34ba478 --- /dev/null +++ b/Externals/SDL/build-scripts/strip_fPIC.sh @@ -0,0 +1,21 @@ +#!/bin/sh +# +# libtool assumes that the compiler can handle the -fPIC flag +# This isn't always true (for example, nasm can't handle it) +command="" +while [ $# -gt 0 ]; do + case "$1" in + -fPIC) + # Ignore -fPIC option + ;; + -fno-common) + # Ignore -fPIC and -DPIC options + ;; + *) + command="$command $1" + ;; + esac + shift +done +echo $command +exec $command diff --git a/Externals/SDL/configure b/Externals/SDL/configure new file mode 100755 index 0000000000..ea9b5da01b --- /dev/null +++ b/Externals/SDL/configure @@ -0,0 +1,33165 @@ +#! /bin/sh +# Guess values for system-dependent variables and create Makefiles. +# Generated by GNU Autoconf 2.63. +# +# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, +# 2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. +# This configure script is free software; the Free Software Foundation +# gives unlimited permission to copy, distribute and modify it. +## --------------------- ## +## M4sh Initialization. ## +## --------------------- ## + +# Be more Bourne compatible +DUALCASE=1; export DUALCASE # for MKS sh +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in + *posix*) set -o posix ;; +esac + +fi + + + + +# PATH needs CR +# Avoid depending upon Character Ranges. +as_cr_letters='abcdefghijklmnopqrstuvwxyz' +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' +as_cr_Letters=$as_cr_letters$as_cr_LETTERS +as_cr_digits='0123456789' +as_cr_alnum=$as_cr_Letters$as_cr_digits + +as_nl=' +' +export as_nl +# Printing a long string crashes Solaris 7 /usr/bin/printf. +as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo +if (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='printf %s\n' + as_echo_n='printf %s' +else + if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then + as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' + as_echo_n='/usr/ucb/echo -n' + else + as_echo_body='eval expr "X$1" : "X\\(.*\\)"' + as_echo_n_body='eval + arg=$1; + case $arg in + *"$as_nl"*) + expr "X$arg" : "X\\(.*\\)$as_nl"; + arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; + esac; + expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" + ' + export as_echo_n_body + as_echo_n='sh -c $as_echo_n_body as_echo' + fi + export as_echo_body + as_echo='sh -c $as_echo_body as_echo' +fi + +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + PATH_SEPARATOR=: + (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { + (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || + PATH_SEPARATOR=';' + } +fi + +# Support unset when possible. +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then + as_unset=unset +else + as_unset=false +fi + + +# IFS +# We need space, tab and new line, in precisely that order. Quoting is +# there to prevent editors from complaining about space-tab. +# (If _AS_PATH_WALK were called with IFS unset, it would disable word +# splitting by setting IFS to empty value.) +IFS=" "" $as_nl" + +# Find who we are. Look in the path if we contain no directory separator. +case $0 in + *[\\/]* ) as_myself=$0 ;; + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break +done +IFS=$as_save_IFS + + ;; +esac +# We did not find ourselves, most probably we were run as `sh COMMAND' +# in which case we are not to be found in the path. +if test "x$as_myself" = x; then + as_myself=$0 +fi +if test ! -f "$as_myself"; then + $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 + { (exit 1); exit 1; } +fi + +# Work around bugs in pre-3.0 UWIN ksh. +for as_var in ENV MAIL MAILPATH +do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var +done +PS1='$ ' +PS2='> ' +PS4='+ ' + +# NLS nuisances. +LC_ALL=C +export LC_ALL +LANGUAGE=C +export LANGUAGE + +# Required to use basename. +if expr a : '\(a\)' >/dev/null 2>&1 && + test "X`expr 00001 : '.*\(...\)'`" = X001; then + as_expr=expr +else + as_expr=false +fi + +if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then + as_basename=basename +else + as_basename=false +fi + + +# Name of the executable. +as_me=`$as_basename -- "$0" || +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X/"$0" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ + s//\1/ + q + } + /^X\/\(\/\/\)$/{ + s//\1/ + q + } + /^X\/\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + +# CDPATH. +$as_unset CDPATH + + +if test "x$CONFIG_SHELL" = x; then + if (eval ":") 2>/dev/null; then + as_have_required=yes +else + as_have_required=no +fi + + if test $as_have_required = yes && (eval ": +(as_func_return () { + (exit \$1) +} +as_func_success () { + as_func_return 0 +} +as_func_failure () { + as_func_return 1 +} +as_func_ret_success () { + return 0 +} +as_func_ret_failure () { + return 1 +} + +exitcode=0 +if as_func_success; then + : +else + exitcode=1 + echo as_func_success failed. +fi + +if as_func_failure; then + exitcode=1 + echo as_func_failure succeeded. +fi + +if as_func_ret_success; then + : +else + exitcode=1 + echo as_func_ret_success failed. +fi + +if as_func_ret_failure; then + exitcode=1 + echo as_func_ret_failure succeeded. +fi + +if ( set x; as_func_ret_success y && test x = \"\$1\" ); then + : +else + exitcode=1 + echo positional parameters were not saved. +fi + +test \$exitcode = 0) || { (exit 1); exit 1; } + +( + as_lineno_1=\$LINENO + as_lineno_2=\$LINENO + test \"x\$as_lineno_1\" != \"x\$as_lineno_2\" && + test \"x\`expr \$as_lineno_1 + 1\`\" = \"x\$as_lineno_2\") || { (exit 1); exit 1; } +") 2> /dev/null; then + : +else + as_candidate_shells= + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + case $as_dir in + /*) + for as_base in sh bash ksh sh5; do + as_candidate_shells="$as_candidate_shells $as_dir/$as_base" + done;; + esac +done +IFS=$as_save_IFS + + + for as_shell in $as_candidate_shells $SHELL; do + # Try only shells that exist, to save several forks. + if { test -f "$as_shell" || test -f "$as_shell.exe"; } && + { ("$as_shell") 2> /dev/null <<\_ASEOF +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in + *posix*) set -o posix ;; +esac + +fi + + +: +_ASEOF +}; then + CONFIG_SHELL=$as_shell + as_have_required=yes + if { "$as_shell" 2> /dev/null <<\_ASEOF +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in + *posix*) set -o posix ;; +esac + +fi + + +: +(as_func_return () { + (exit $1) +} +as_func_success () { + as_func_return 0 +} +as_func_failure () { + as_func_return 1 +} +as_func_ret_success () { + return 0 +} +as_func_ret_failure () { + return 1 +} + +exitcode=0 +if as_func_success; then + : +else + exitcode=1 + echo as_func_success failed. +fi + +if as_func_failure; then + exitcode=1 + echo as_func_failure succeeded. +fi + +if as_func_ret_success; then + : +else + exitcode=1 + echo as_func_ret_success failed. +fi + +if as_func_ret_failure; then + exitcode=1 + echo as_func_ret_failure succeeded. +fi + +if ( set x; as_func_ret_success y && test x = "$1" ); then + : +else + exitcode=1 + echo positional parameters were not saved. +fi + +test $exitcode = 0) || { (exit 1); exit 1; } + +( + as_lineno_1=$LINENO + as_lineno_2=$LINENO + test "x$as_lineno_1" != "x$as_lineno_2" && + test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2") || { (exit 1); exit 1; } + +_ASEOF +}; then + break +fi + +fi + + done + + if test "x$CONFIG_SHELL" != x; then + for as_var in BASH_ENV ENV + do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var + done + export CONFIG_SHELL + exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"} +fi + + + if test $as_have_required = no; then + echo This script requires a shell more modern than all the + echo shells that I found on your system. Please install a + echo modern shell, or manually run the script under such a + echo shell if you do have one. + { (exit 1); exit 1; } +fi + + +fi + +fi + + + +(eval "as_func_return () { + (exit \$1) +} +as_func_success () { + as_func_return 0 +} +as_func_failure () { + as_func_return 1 +} +as_func_ret_success () { + return 0 +} +as_func_ret_failure () { + return 1 +} + +exitcode=0 +if as_func_success; then + : +else + exitcode=1 + echo as_func_success failed. +fi + +if as_func_failure; then + exitcode=1 + echo as_func_failure succeeded. +fi + +if as_func_ret_success; then + : +else + exitcode=1 + echo as_func_ret_success failed. +fi + +if as_func_ret_failure; then + exitcode=1 + echo as_func_ret_failure succeeded. +fi + +if ( set x; as_func_ret_success y && test x = \"\$1\" ); then + : +else + exitcode=1 + echo positional parameters were not saved. +fi + +test \$exitcode = 0") || { + echo No shell found that supports shell functions. + echo Please tell bug-autoconf@gnu.org about your system, + echo including any error possibly output before this message. + echo This can help us improve future autoconf versions. + echo Configuration will now proceed without shell functions. +} + + + + as_lineno_1=$LINENO + as_lineno_2=$LINENO + test "x$as_lineno_1" != "x$as_lineno_2" && + test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2" || { + + # Create $as_me.lineno as a copy of $as_myself, but with $LINENO + # uniformly replaced by the line number. The first 'sed' inserts a + # line-number line after each line using $LINENO; the second 'sed' + # does the real work. The second script uses 'N' to pair each + # line-number line with the line containing $LINENO, and appends + # trailing '-' during substitution so that $LINENO is not a special + # case at line end. + # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the + # scripts with optimization help from Paolo Bonzini. Blame Lee + # E. McMahon (1931-1989) for sed's syntax. :-) + sed -n ' + p + /[$]LINENO/= + ' <$as_myself | + sed ' + s/[$]LINENO.*/&-/ + t lineno + b + :lineno + N + :loop + s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ + t loop + s/-\n.*// + ' >$as_me.lineno && + chmod +x "$as_me.lineno" || + { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2 + { (exit 1); exit 1; }; } + + # Don't try to exec as it changes $[0], causing all sort of problems + # (the dirname of $[0] is not the place where we might find the + # original and so on. Autoconf is especially sensitive to this). + . "./$as_me.lineno" + # Exit status is that of the last command. + exit +} + + +if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then + as_dirname=dirname +else + as_dirname=false +fi + +ECHO_C= ECHO_N= ECHO_T= +case `echo -n x` in +-n*) + case `echo 'x\c'` in + *c*) ECHO_T=' ';; # ECHO_T is single tab character. + *) ECHO_C='\c';; + esac;; +*) + ECHO_N='-n';; +esac +if expr a : '\(a\)' >/dev/null 2>&1 && + test "X`expr 00001 : '.*\(...\)'`" = X001; then + as_expr=expr +else + as_expr=false +fi + +rm -f conf$$ conf$$.exe conf$$.file +if test -d conf$$.dir; then + rm -f conf$$.dir/conf$$.file +else + rm -f conf$$.dir + mkdir conf$$.dir 2>/dev/null +fi +if (echo >conf$$.file) 2>/dev/null; then + if ln -s conf$$.file conf$$ 2>/dev/null; then + as_ln_s='ln -s' + # ... but there are two gotchas: + # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. + # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. + # In both cases, we have to default to `cp -p'. + ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || + as_ln_s='cp -p' + elif ln conf$$.file conf$$ 2>/dev/null; then + as_ln_s=ln + else + as_ln_s='cp -p' + fi +else + as_ln_s='cp -p' +fi +rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file +rmdir conf$$.dir 2>/dev/null + +if mkdir -p . 2>/dev/null; then + as_mkdir_p=: +else + test -d ./-p && rmdir ./-p + as_mkdir_p=false +fi + +if test -x / >/dev/null 2>&1; then + as_test_x='test -x' +else + if ls -dL / >/dev/null 2>&1; then + as_ls_L_option=L + else + as_ls_L_option= + fi + as_test_x=' + eval sh -c '\'' + if test -d "$1"; then + test -d "$1/."; + else + case $1 in + -*)set "./$1";; + esac; + case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in + ???[sx]*):;;*)false;;esac;fi + '\'' sh + ' +fi +as_executable_p=$as_test_x + +# Sed expression to map a string onto a valid CPP name. +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" + +# Sed expression to map a string onto a valid variable name. +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" + + + + +# Check that we are running under the correct shell. +SHELL=${CONFIG_SHELL-/bin/sh} + +case X$lt_ECHO in +X*--fallback-echo) + # Remove one level of quotation (which was required for Make). + ECHO=`echo "$lt_ECHO" | sed 's,\\\\\$\\$0,'$0','` + ;; +esac + +ECHO=${lt_ECHO-echo} +if test "X$1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X$1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' ; then + # Yippee, $ECHO works! + : +else + # Restart under the correct shell. + exec $SHELL "$0" --no-reexec ${1+"$@"} +fi + +if test "X$1" = X--fallback-echo; then + # used as fallback echo + shift + cat <<_LT_EOF +$* +_LT_EOF + exit 0 +fi + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +if test -z "$lt_ECHO"; then + if test "X${echo_test_string+set}" != Xset; then + # find a string as large as possible, as long as the shell can cope with it + for cmd in 'sed 50q "$0"' 'sed 20q "$0"' 'sed 10q "$0"' 'sed 2q "$0"' 'echo test'; do + # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ... + if { echo_test_string=`eval $cmd`; } 2>/dev/null && + { test "X$echo_test_string" = "X$echo_test_string"; } 2>/dev/null + then + break + fi + done + fi + + if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' && + echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + : + else + # The Solaris, AIX, and Digital Unix default echo programs unquote + # backslashes. This makes it impossible to quote backslashes using + # echo "$something" | sed 's/\\/\\\\/g' + # + # So, first we look for a working echo in the user's PATH. + + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for dir in $PATH /usr/ucb; do + IFS="$lt_save_ifs" + if (test -f $dir/echo || test -f $dir/echo$ac_exeext) && + test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + ECHO="$dir/echo" + break + fi + done + IFS="$lt_save_ifs" + + if test "X$ECHO" = Xecho; then + # We didn't find a better echo, so look for alternatives. + if test "X`{ print -r '\t'; } 2>/dev/null`" = 'X\t' && + echo_testing_string=`{ print -r "$echo_test_string"; } 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # This shell has a builtin print -r that does the trick. + ECHO='print -r' + elif { test -f /bin/ksh || test -f /bin/ksh$ac_exeext; } && + test "X$CONFIG_SHELL" != X/bin/ksh; then + # If we have ksh, try running configure again with it. + ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh} + export ORIGINAL_CONFIG_SHELL + CONFIG_SHELL=/bin/ksh + export CONFIG_SHELL + exec $CONFIG_SHELL "$0" --no-reexec ${1+"$@"} + else + # Try using printf. + ECHO='printf %s\n' + if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' && + echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # Cool, printf works + : + elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "$0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($ORIGINAL_CONFIG_SHELL "$0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL + export CONFIG_SHELL + SHELL="$CONFIG_SHELL" + export SHELL + ECHO="$CONFIG_SHELL $0 --fallback-echo" + elif echo_testing_string=`($CONFIG_SHELL "$0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($CONFIG_SHELL "$0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + ECHO="$CONFIG_SHELL $0 --fallback-echo" + else + # maybe with a smaller string... + prev=: + + for cmd in 'echo test' 'sed 2q "$0"' 'sed 10q "$0"' 'sed 20q "$0"' 'sed 50q "$0"'; do + if { test "X$echo_test_string" = "X`eval $cmd`"; } 2>/dev/null + then + break + fi + prev="$cmd" + done + + if test "$prev" != 'sed 50q "$0"'; then + echo_test_string=`eval $prev` + export echo_test_string + exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "$0" ${1+"$@"} + else + # Oops. We lost completely, so just stick with echo. + ECHO=echo + fi + fi + fi + fi + fi +fi + +# Copy echo and quote the copy suitably for passing to libtool from +# the Makefile, instead of quoting the original, which is used later. +lt_ECHO=$ECHO +if test "X$lt_ECHO" = "X$CONFIG_SHELL $0 --fallback-echo"; then + lt_ECHO="$CONFIG_SHELL \\\$\$0 --fallback-echo" +fi + + + + +exec 7<&0 &1 + +# Name of the host. +# hostname on some systems (SVR3.2, Linux) returns a bogus exit status, +# so uname gets run too. +ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` + +# +# Initializations. +# +ac_default_prefix=/usr/local +ac_clean_files= +ac_config_libobj_dir=. +LIBOBJS= +cross_compiling=no +subdirs= +MFLAGS= +MAKEFLAGS= +SHELL=${CONFIG_SHELL-/bin/sh} + +# Identity of this package. +PACKAGE_NAME= +PACKAGE_TARNAME= +PACKAGE_VERSION= +PACKAGE_STRING= +PACKAGE_BUGREPORT= + +ac_unique_file="README" +# Factoring default headers for most tests. +ac_includes_default="\ +#include +#ifdef HAVE_SYS_TYPES_H +# include +#endif +#ifdef HAVE_SYS_STAT_H +# include +#endif +#ifdef STDC_HEADERS +# include +# include +#else +# ifdef HAVE_STDLIB_H +# include +# endif +#endif +#ifdef HAVE_STRING_H +# if !defined STDC_HEADERS && defined HAVE_MEMORY_H +# include +# endif +# include +#endif +#ifdef HAVE_STRINGS_H +# include +#endif +#ifdef HAVE_INTTYPES_H +# include +#endif +#ifdef HAVE_STDINT_H +# include +#endif +#ifdef HAVE_UNISTD_H +# include +#endif" + +ac_subst_vars='LTLIBOBJS +EXTRA_LDFLAGS +BUILD_LDFLAGS +EXTRA_CFLAGS +BUILD_CFLAGS +SDLMAIN_OBJECTS +SDLMAIN_SOURCES +OBJECTS +SOURCES +INCLUDE +ac_aux_dir +ENABLE_STATIC_FALSE +ENABLE_STATIC_TRUE +ENABLE_SHARED_FALSE +ENABLE_SHARED_TRUE +SDL_RLD_FLAGS +SDL_STATIC_LIBS +SDL_LIBS +SDL_CFLAGS +PTH_CONFIG +OSMESA_CONFIG +CACACONFIG +DIRECTFBCONFIG +X_EXTRA_LIBS +X_LIBS +X_PRE_LIBS +X_CFLAGS +XMKMF +NASMFLAGS +NASM +ARTSCONFIG +PKG_CONFIG +ESD_LIBS +ESD_CFLAGS +ESD_CONFIG +ALSA_LIBS +ALSA_CFLAGS +POW_LIB +LIBOBJS +ALLOCA +WINDRES +SET_MAKE +INSTALL_DATA +INSTALL_SCRIPT +INSTALL_PROGRAM +CXXCPP +ac_ct_CXX +CXXFLAGS +CXX +LT_AGE +LT_REVISION +LT_CURRENT +LT_RELEASE +OTOOL64 +OTOOL +LIPO +NMEDIT +DSYMUTIL +lt_ECHO +RANLIB +STRIP +AR +LN_S +NM +ac_ct_DUMPBIN +DUMPBIN +LD +FGREP +SED +host_os +host_vendor +host_cpu +host +build_os +build_vendor +build_cpu +build +LIBTOOL +OBJDUMP +DLLTOOL +AS +SDL_VERSION +SDL_BINARY_AGE +SDL_INTERFACE_AGE +SDL_MICRO_VERSION +SDL_MINOR_VERSION +SDL_MAJOR_VERSION +EGREP +GREP +CPP +OBJEXT +EXEEXT +ac_ct_CC +CPPFLAGS +LDFLAGS +CFLAGS +CC +target_alias +host_alias +build_alias +LIBS +ECHO_T +ECHO_N +ECHO_C +DEFS +mandir +localedir +libdir +psdir +pdfdir +dvidir +htmldir +infodir +docdir +oldincludedir +includedir +localstatedir +sharedstatedir +sysconfdir +datadir +datarootdir +libexecdir +sbindir +bindir +program_transform_name +prefix +exec_prefix +PACKAGE_BUGREPORT +PACKAGE_STRING +PACKAGE_VERSION +PACKAGE_TARNAME +PACKAGE_NAME +PATH_SEPARATOR +SHELL' +ac_subst_files='' +ac_user_opts=' +enable_option_checking +enable_shared +enable_static +with_pic +enable_fast_install +with_gnu_ld +enable_libtool_lock +enable_libc +enable_audio +enable_video +enable_events +enable_joystick +enable_cdrom +enable_threads +enable_timers +enable_file +enable_loadso +enable_cpuinfo +enable_assembly +enable_oss +enable_alsa +with_alsa_prefix +with_alsa_inc_prefix +enable_alsatest +enable_alsa_shared +enable_esd +with_esd_prefix +with_esd_exec_prefix +enable_esdtest +enable_esd_shared +enable_pulseaudio +enable_pulseaudio_shared +enable_arts +enable_arts_shared +enable_nas +enable_nas_shared +enable_diskaudio +enable_dummyaudio +enable_mintaudio +enable_nasm +enable_altivec +enable_ipod +enable_video_nanox +enable_nanox_debug +enable_nanox_share_memory +enable_nanox_direct_fb +enable_video_x11 +with_x +enable_x11_shared +enable_dga +enable_video_dga +enable_video_x11_dgamouse +enable_video_x11_vm +enable_video_x11_xv +enable_video_x11_xinerama +enable_video_x11_xme +enable_video_x11_xrandr +enable_video_photon +enable_video_carbon +enable_video_cocoa +enable_video_fbcon +enable_video_directfb +enable_video_ps2gs +enable_video_ps3 +enable_video_ggi +enable_video_svga +enable_video_vgl +enable_video_wscons +enable_video_aalib +enable_video_caca +enable_video_qtopia +enable_video_picogui +enable_xbios +enable_gem +enable_video_dummy +enable_video_opengl +enable_osmesa_shared +enable_screensaver +enable_input_events +enable_input_tslib +enable_pth +enable_pthreads +enable_pthread_sem +enable_stdio_redirect +enable_directx +enable_sdl_dlopen +enable_atari_ldg +enable_clock_gettime +enable_rpath +' + ac_precious_vars='build_alias +host_alias +target_alias +CC +CFLAGS +LDFLAGS +LIBS +CPPFLAGS +CPP +CXX +CXXFLAGS +CCC +CXXCPP +XMKMF' + + +# Initialize some variables set by options. +ac_init_help= +ac_init_version=false +ac_unrecognized_opts= +ac_unrecognized_sep= +# The variables have the same names as the options, with +# dashes changed to underlines. +cache_file=/dev/null +exec_prefix=NONE +no_create= +no_recursion= +prefix=NONE +program_prefix=NONE +program_suffix=NONE +program_transform_name=s,x,x, +silent= +site= +srcdir= +verbose= +x_includes=NONE +x_libraries=NONE + +# Installation directory options. +# These are left unexpanded so users can "make install exec_prefix=/foo" +# and all the variables that are supposed to be based on exec_prefix +# by default will actually change. +# Use braces instead of parens because sh, perl, etc. also accept them. +# (The list follows the same order as the GNU Coding Standards.) +bindir='${exec_prefix}/bin' +sbindir='${exec_prefix}/sbin' +libexecdir='${exec_prefix}/libexec' +datarootdir='${prefix}/share' +datadir='${datarootdir}' +sysconfdir='${prefix}/etc' +sharedstatedir='${prefix}/com' +localstatedir='${prefix}/var' +includedir='${prefix}/include' +oldincludedir='/usr/include' +docdir='${datarootdir}/doc/${PACKAGE}' +infodir='${datarootdir}/info' +htmldir='${docdir}' +dvidir='${docdir}' +pdfdir='${docdir}' +psdir='${docdir}' +libdir='${exec_prefix}/lib' +localedir='${datarootdir}/locale' +mandir='${datarootdir}/man' + +ac_prev= +ac_dashdash= +for ac_option +do + # If the previous option needs an argument, assign it. + if test -n "$ac_prev"; then + eval $ac_prev=\$ac_option + ac_prev= + continue + fi + + case $ac_option in + *=*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; + *) ac_optarg=yes ;; + esac + + # Accept the important Cygnus configure options, so we can diagnose typos. + + case $ac_dashdash$ac_option in + --) + ac_dashdash=yes ;; + + -bindir | --bindir | --bindi | --bind | --bin | --bi) + ac_prev=bindir ;; + -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) + bindir=$ac_optarg ;; + + -build | --build | --buil | --bui | --bu) + ac_prev=build_alias ;; + -build=* | --build=* | --buil=* | --bui=* | --bu=*) + build_alias=$ac_optarg ;; + + -cache-file | --cache-file | --cache-fil | --cache-fi \ + | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) + ac_prev=cache_file ;; + -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ + | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) + cache_file=$ac_optarg ;; + + --config-cache | -C) + cache_file=config.cache ;; + + -datadir | --datadir | --datadi | --datad) + ac_prev=datadir ;; + -datadir=* | --datadir=* | --datadi=* | --datad=*) + datadir=$ac_optarg ;; + + -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ + | --dataroo | --dataro | --datar) + ac_prev=datarootdir ;; + -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ + | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) + datarootdir=$ac_optarg ;; + + -disable-* | --disable-*) + ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + { $as_echo "$as_me: error: invalid feature name: $ac_useropt" >&2 + { (exit 1); exit 1; }; } + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"enable_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval enable_$ac_useropt=no ;; + + -docdir | --docdir | --docdi | --doc | --do) + ac_prev=docdir ;; + -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) + docdir=$ac_optarg ;; + + -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) + ac_prev=dvidir ;; + -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) + dvidir=$ac_optarg ;; + + -enable-* | --enable-*) + ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + { $as_echo "$as_me: error: invalid feature name: $ac_useropt" >&2 + { (exit 1); exit 1; }; } + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"enable_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval enable_$ac_useropt=\$ac_optarg ;; + + -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ + | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ + | --exec | --exe | --ex) + ac_prev=exec_prefix ;; + -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ + | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ + | --exec=* | --exe=* | --ex=*) + exec_prefix=$ac_optarg ;; + + -gas | --gas | --ga | --g) + # Obsolete; use --with-gas. + with_gas=yes ;; + + -help | --help | --hel | --he | -h) + ac_init_help=long ;; + -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) + ac_init_help=recursive ;; + -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) + ac_init_help=short ;; + + -host | --host | --hos | --ho) + ac_prev=host_alias ;; + -host=* | --host=* | --hos=* | --ho=*) + host_alias=$ac_optarg ;; + + -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) + ac_prev=htmldir ;; + -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ + | --ht=*) + htmldir=$ac_optarg ;; + + -includedir | --includedir | --includedi | --included | --include \ + | --includ | --inclu | --incl | --inc) + ac_prev=includedir ;; + -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ + | --includ=* | --inclu=* | --incl=* | --inc=*) + includedir=$ac_optarg ;; + + -infodir | --infodir | --infodi | --infod | --info | --inf) + ac_prev=infodir ;; + -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) + infodir=$ac_optarg ;; + + -libdir | --libdir | --libdi | --libd) + ac_prev=libdir ;; + -libdir=* | --libdir=* | --libdi=* | --libd=*) + libdir=$ac_optarg ;; + + -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ + | --libexe | --libex | --libe) + ac_prev=libexecdir ;; + -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ + | --libexe=* | --libex=* | --libe=*) + libexecdir=$ac_optarg ;; + + -localedir | --localedir | --localedi | --localed | --locale) + ac_prev=localedir ;; + -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) + localedir=$ac_optarg ;; + + -localstatedir | --localstatedir | --localstatedi | --localstated \ + | --localstate | --localstat | --localsta | --localst | --locals) + ac_prev=localstatedir ;; + -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ + | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) + localstatedir=$ac_optarg ;; + + -mandir | --mandir | --mandi | --mand | --man | --ma | --m) + ac_prev=mandir ;; + -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) + mandir=$ac_optarg ;; + + -nfp | --nfp | --nf) + # Obsolete; use --without-fp. + with_fp=no ;; + + -no-create | --no-create | --no-creat | --no-crea | --no-cre \ + | --no-cr | --no-c | -n) + no_create=yes ;; + + -no-recursion | --no-recursion | --no-recursio | --no-recursi \ + | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) + no_recursion=yes ;; + + -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ + | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ + | --oldin | --oldi | --old | --ol | --o) + ac_prev=oldincludedir ;; + -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ + | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ + | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) + oldincludedir=$ac_optarg ;; + + -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) + ac_prev=prefix ;; + -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) + prefix=$ac_optarg ;; + + -program-prefix | --program-prefix | --program-prefi | --program-pref \ + | --program-pre | --program-pr | --program-p) + ac_prev=program_prefix ;; + -program-prefix=* | --program-prefix=* | --program-prefi=* \ + | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) + program_prefix=$ac_optarg ;; + + -program-suffix | --program-suffix | --program-suffi | --program-suff \ + | --program-suf | --program-su | --program-s) + ac_prev=program_suffix ;; + -program-suffix=* | --program-suffix=* | --program-suffi=* \ + | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) + program_suffix=$ac_optarg ;; + + -program-transform-name | --program-transform-name \ + | --program-transform-nam | --program-transform-na \ + | --program-transform-n | --program-transform- \ + | --program-transform | --program-transfor \ + | --program-transfo | --program-transf \ + | --program-trans | --program-tran \ + | --progr-tra | --program-tr | --program-t) + ac_prev=program_transform_name ;; + -program-transform-name=* | --program-transform-name=* \ + | --program-transform-nam=* | --program-transform-na=* \ + | --program-transform-n=* | --program-transform-=* \ + | --program-transform=* | --program-transfor=* \ + | --program-transfo=* | --program-transf=* \ + | --program-trans=* | --program-tran=* \ + | --progr-tra=* | --program-tr=* | --program-t=*) + program_transform_name=$ac_optarg ;; + + -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) + ac_prev=pdfdir ;; + -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) + pdfdir=$ac_optarg ;; + + -psdir | --psdir | --psdi | --psd | --ps) + ac_prev=psdir ;; + -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) + psdir=$ac_optarg ;; + + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + silent=yes ;; + + -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) + ac_prev=sbindir ;; + -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ + | --sbi=* | --sb=*) + sbindir=$ac_optarg ;; + + -sharedstatedir | --sharedstatedir | --sharedstatedi \ + | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ + | --sharedst | --shareds | --shared | --share | --shar \ + | --sha | --sh) + ac_prev=sharedstatedir ;; + -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ + | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ + | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ + | --sha=* | --sh=*) + sharedstatedir=$ac_optarg ;; + + -site | --site | --sit) + ac_prev=site ;; + -site=* | --site=* | --sit=*) + site=$ac_optarg ;; + + -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) + ac_prev=srcdir ;; + -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) + srcdir=$ac_optarg ;; + + -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ + | --syscon | --sysco | --sysc | --sys | --sy) + ac_prev=sysconfdir ;; + -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ + | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) + sysconfdir=$ac_optarg ;; + + -target | --target | --targe | --targ | --tar | --ta | --t) + ac_prev=target_alias ;; + -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) + target_alias=$ac_optarg ;; + + -v | -verbose | --verbose | --verbos | --verbo | --verb) + verbose=yes ;; + + -version | --version | --versio | --versi | --vers | -V) + ac_init_version=: ;; + + -with-* | --with-*) + ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + { $as_echo "$as_me: error: invalid package name: $ac_useropt" >&2 + { (exit 1); exit 1; }; } + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"with_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval with_$ac_useropt=\$ac_optarg ;; + + -without-* | --without-*) + ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + { $as_echo "$as_me: error: invalid package name: $ac_useropt" >&2 + { (exit 1); exit 1; }; } + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"with_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval with_$ac_useropt=no ;; + + --x) + # Obsolete; use --with-x. + with_x=yes ;; + + -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ + | --x-incl | --x-inc | --x-in | --x-i) + ac_prev=x_includes ;; + -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ + | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) + x_includes=$ac_optarg ;; + + -x-libraries | --x-libraries | --x-librarie | --x-librari \ + | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) + ac_prev=x_libraries ;; + -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ + | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) + x_libraries=$ac_optarg ;; + + -*) { $as_echo "$as_me: error: unrecognized option: $ac_option +Try \`$0 --help' for more information." >&2 + { (exit 1); exit 1; }; } + ;; + + *=*) + ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` + # Reject names that are not valid shell variable names. + expr "x$ac_envvar" : ".*[^_$as_cr_alnum]" >/dev/null && + { $as_echo "$as_me: error: invalid variable name: $ac_envvar" >&2 + { (exit 1); exit 1; }; } + eval $ac_envvar=\$ac_optarg + export $ac_envvar ;; + + *) + # FIXME: should be removed in autoconf 3.0. + $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 + expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && + $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 + : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} + ;; + + esac +done + +if test -n "$ac_prev"; then + ac_option=--`echo $ac_prev | sed 's/_/-/g'` + { $as_echo "$as_me: error: missing argument to $ac_option" >&2 + { (exit 1); exit 1; }; } +fi + +if test -n "$ac_unrecognized_opts"; then + case $enable_option_checking in + no) ;; + fatal) { $as_echo "$as_me: error: unrecognized options: $ac_unrecognized_opts" >&2 + { (exit 1); exit 1; }; } ;; + *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; + esac +fi + +# Check all directory arguments for consistency. +for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ + datadir sysconfdir sharedstatedir localstatedir includedir \ + oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ + libdir localedir mandir +do + eval ac_val=\$$ac_var + # Remove trailing slashes. + case $ac_val in + */ ) + ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` + eval $ac_var=\$ac_val;; + esac + # Be sure to have absolute directory names. + case $ac_val in + [\\/$]* | ?:[\\/]* ) continue;; + NONE | '' ) case $ac_var in *prefix ) continue;; esac;; + esac + { $as_echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2 + { (exit 1); exit 1; }; } +done + +# There might be people who depend on the old broken behavior: `$host' +# used to hold the argument of --host etc. +# FIXME: To remove some day. +build=$build_alias +host=$host_alias +target=$target_alias + +# FIXME: To remove some day. +if test "x$host_alias" != x; then + if test "x$build_alias" = x; then + cross_compiling=maybe + $as_echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host. + If a cross compiler is detected then cross compile mode will be used." >&2 + elif test "x$build_alias" != "x$host_alias"; then + cross_compiling=yes + fi +fi + +ac_tool_prefix= +test -n "$host_alias" && ac_tool_prefix=$host_alias- + +test "$silent" = yes && exec 6>/dev/null + + +ac_pwd=`pwd` && test -n "$ac_pwd" && +ac_ls_di=`ls -di .` && +ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || + { $as_echo "$as_me: error: working directory cannot be determined" >&2 + { (exit 1); exit 1; }; } +test "X$ac_ls_di" = "X$ac_pwd_ls_di" || + { $as_echo "$as_me: error: pwd does not report name of working directory" >&2 + { (exit 1); exit 1; }; } + + +# Find the source files, if location was not specified. +if test -z "$srcdir"; then + ac_srcdir_defaulted=yes + # Try the directory containing this script, then the parent directory. + ac_confdir=`$as_dirname -- "$as_myself" || +$as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_myself" : 'X\(//\)[^/]' \| \ + X"$as_myself" : 'X\(//\)$' \| \ + X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$as_myself" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + srcdir=$ac_confdir + if test ! -r "$srcdir/$ac_unique_file"; then + srcdir=.. + fi +else + ac_srcdir_defaulted=no +fi +if test ! -r "$srcdir/$ac_unique_file"; then + test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." + { $as_echo "$as_me: error: cannot find sources ($ac_unique_file) in $srcdir" >&2 + { (exit 1); exit 1; }; } +fi +ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" +ac_abs_confdir=`( + cd "$srcdir" && test -r "./$ac_unique_file" || { $as_echo "$as_me: error: $ac_msg" >&2 + { (exit 1); exit 1; }; } + pwd)` +# When building in place, set srcdir=. +if test "$ac_abs_confdir" = "$ac_pwd"; then + srcdir=. +fi +# Remove unnecessary trailing slashes from srcdir. +# Double slashes in file names in object file debugging info +# mess up M-x gdb in Emacs. +case $srcdir in +*/) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; +esac +for ac_var in $ac_precious_vars; do + eval ac_env_${ac_var}_set=\${${ac_var}+set} + eval ac_env_${ac_var}_value=\$${ac_var} + eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} + eval ac_cv_env_${ac_var}_value=\$${ac_var} +done + +# +# Report the --help message. +# +if test "$ac_init_help" = "long"; then + # Omit some internal or obsolete options to make the list less imposing. + # This message is too long to be a string in the A/UX 3.1 sh. + cat <<_ACEOF +\`configure' configures this package to adapt to many kinds of systems. + +Usage: $0 [OPTION]... [VAR=VALUE]... + +To assign environment variables (e.g., CC, CFLAGS...), specify them as +VAR=VALUE. See below for descriptions of some of the useful variables. + +Defaults for the options are specified in brackets. + +Configuration: + -h, --help display this help and exit + --help=short display options specific to this package + --help=recursive display the short help of all the included packages + -V, --version display version information and exit + -q, --quiet, --silent do not print \`checking...' messages + --cache-file=FILE cache test results in FILE [disabled] + -C, --config-cache alias for \`--cache-file=config.cache' + -n, --no-create do not create output files + --srcdir=DIR find the sources in DIR [configure dir or \`..'] + +Installation directories: + --prefix=PREFIX install architecture-independent files in PREFIX + [$ac_default_prefix] + --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX + [PREFIX] + +By default, \`make install' will install all the files in +\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify +an installation prefix other than \`$ac_default_prefix' using \`--prefix', +for instance \`--prefix=\$HOME'. + +For better control, use the options below. + +Fine tuning of the installation directories: + --bindir=DIR user executables [EPREFIX/bin] + --sbindir=DIR system admin executables [EPREFIX/sbin] + --libexecdir=DIR program executables [EPREFIX/libexec] + --sysconfdir=DIR read-only single-machine data [PREFIX/etc] + --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] + --localstatedir=DIR modifiable single-machine data [PREFIX/var] + --libdir=DIR object code libraries [EPREFIX/lib] + --includedir=DIR C header files [PREFIX/include] + --oldincludedir=DIR C header files for non-gcc [/usr/include] + --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] + --datadir=DIR read-only architecture-independent data [DATAROOTDIR] + --infodir=DIR info documentation [DATAROOTDIR/info] + --localedir=DIR locale-dependent data [DATAROOTDIR/locale] + --mandir=DIR man documentation [DATAROOTDIR/man] + --docdir=DIR documentation root [DATAROOTDIR/doc/PACKAGE] + --htmldir=DIR html documentation [DOCDIR] + --dvidir=DIR dvi documentation [DOCDIR] + --pdfdir=DIR pdf documentation [DOCDIR] + --psdir=DIR ps documentation [DOCDIR] +_ACEOF + + cat <<\_ACEOF + +X features: + --x-includes=DIR X include files are in DIR + --x-libraries=DIR X library files are in DIR + +System types: + --build=BUILD configure for building on BUILD [guessed] + --host=HOST cross-compile to build programs to run on HOST [BUILD] +_ACEOF +fi + +if test -n "$ac_init_help"; then + + cat <<\_ACEOF + +Optional Features: + --disable-option-checking ignore unrecognized --enable/--with options + --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) + --enable-FEATURE[=ARG] include FEATURE [ARG=yes] + --enable-shared[=PKGS] build shared libraries [default=yes] + --enable-static[=PKGS] build static libraries [default=yes] + --enable-fast-install[=PKGS] + optimize for fast installation [default=yes] + --disable-libtool-lock avoid locking (might break parallel builds) + --enable-libc Use the system C library [default=yes] + --enable-audio Enable the audio subsystem [default=yes] + --enable-video Enable the video subsystem [default=yes] + --enable-events Enable the events subsystem [default=yes] + --enable-joystick Enable the joystick subsystem [default=yes] + --enable-cdrom Enable the cdrom subsystem [default=yes] + --enable-threads Enable the threading subsystem [default=yes] + --enable-timers Enable the timer subsystem [default=yes] + --enable-file Enable the file subsystem [default=yes] + --enable-loadso Enable the shared object loading subsystem + [default=yes] + --enable-cpuinfo Enable the cpuinfo subsystem [default=yes] + --enable-assembly Enable assembly routines [default=yes] + --enable-oss support the OSS audio API [default=yes] + --enable-alsa support the ALSA audio API [default=yes] + --disable-alsatest Do not try to compile and run a test Alsa program + --enable-alsa-shared dynamically load ALSA audio support [default=yes] + --enable-esd support the Enlightened Sound Daemon [default=yes] + --disable-esdtest Do not try to compile and run a test ESD program + --enable-esd-shared dynamically load ESD audio support [default=yes] + --enable-pulseaudio use PulseAudio [default=yes] + --enable-pulseaudio-shared + dynamically load PulseAudio support [default=yes] + --enable-arts support the Analog Real Time Synthesizer + [default=yes] + --enable-arts-shared dynamically load aRts audio support [default=yes] + --enable-nas support the NAS audio API [default=yes] + --enable-nas-shared dynamically load NAS audio support [default=yes] + --enable-diskaudio support the disk writer audio driver [default=yes] + --enable-dummyaudio support the dummy audio driver [default=yes] + --enable-mintaudio support Atari audio driver [default=yes] + --enable-nasm use nasm assembly blitters on x86 [default=yes] + --enable-altivec use altivec assembly blitters on PPC [default=yes] + --enable-ipod configure SDL to work with iPodLinux [default=no] + --enable-video-nanox use nanox video driver [default=no] + --enable-nanox-debug print debug messages [default=no] + --enable-nanox-share-memory + use share memory [default=no] + --enable-nanox-direct-fb + use direct framebuffer access [default=no] + --enable-video-x11 use X11 video driver [default=yes] + --enable-x11-shared dynamically load X11 support [default=maybe] + --enable-dga allow use of X11 DGA code [default=yes] + --enable-video-dga use DGA 2.0 video driver [default=yes] + --enable-video-x11-dgamouse + use X11 DGA for mouse events [default=yes] + --enable-video-x11-vm use X11 VM extension for fullscreen [default=yes] + --enable-video-x11-xv use X11 XvImage extension for video [default=yes] + --enable-video-x11-xinerama + enable X11 Xinerama support [default=yes] + --enable-video-x11-xme enable Xi Graphics XME for fullscreen + [default=yes] + --enable-video-x11-xrandr + enable X11 Xrandr extension for fullscreen + [default=yes] + --enable-video-photon use QNX Photon video driver [default=yes] + --enable-video-carbon use Carbon/QuickDraw video driver [default=no] + --enable-video-cocoa use Cocoa/Quartz video driver [default=yes] + --enable-video-fbcon use framebuffer console video driver [default=yes] + --enable-video-directfb use DirectFB video driver [default=yes] + --enable-video-ps2gs use PlayStation 2 GS video driver [default=yes] + --enable-video-ps3 use PlayStation 3 Cell driver [default=yes] + --enable-video-ggi use GGI video driver [default=no] + --enable-video-svga use SVGAlib video driver [default=yes] + --enable-video-vgl use VGL video driver [default=yes] + --enable-video-wscons use wscons video driver [default=yes] + --enable-video-aalib use AAlib video driver [default=no] + --enable-video-caca use libcaca video driver [default=no] + --enable-video-qtopia use Qtopia video driver [default=no] + --enable-video-picogui use PicoGUI video driver [default=no] + --enable-video-xbios use Atari Xbios video driver [default=yes] + --enable-video-gem use Atari Gem video driver [default=yes] + --enable-video-dummy use dummy video driver [default=yes] + --enable-video-opengl include OpenGL context creation [default=yes] + --enable-osmesa-shared dynamically load OSMesa OpenGL support + [default=yes] + --enable-screensaver enable screensaver by default while any SDL + application is running [default=no] + --enable-input-events use Linux 2.4 unified input interface + [default=yes] + --enable-input-tslib use the Touchscreen library for input + [default=yes] + --enable-pth use GNU pth library for multi-threading + [default=yes] + --enable-pthreads use POSIX threads for multi-threading + [default=yes] + --enable-pthread-sem use pthread semaphores [default=yes] + --enable-stdio-redirect Redirect STDIO to files on Win32 [default=yes] + --enable-directx use DirectX for Win32 audio/video [default=yes] + --enable-sdl-dlopen use dlopen for shared object loading [default=yes] + --enable-atari-ldg use Atari LDG for shared object loading + [default=yes] + --enable-clock_gettime use clock_gettime() instead of gettimeofday() on + UNIX [default=no] + --enable-rpath use an rpath when linking SDL [default=yes] + +Optional Packages: + --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] + --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) + --with-pic try to use only PIC/non-PIC objects [default=use + both] + --with-gnu-ld assume the C compiler uses GNU ld [default=no] + --with-alsa-prefix=PFX Prefix where Alsa library is installed(optional) + --with-alsa-inc-prefix=PFX Prefix where include libraries are (optional) + --with-esd-prefix=PFX Prefix where ESD is installed (optional) + --with-esd-exec-prefix=PFX Exec prefix where ESD is installed (optional) + --with-x use the X Window System + +Some influential environment variables: + CC C compiler command + CFLAGS C compiler flags + LDFLAGS linker flags, e.g. -L if you have libraries in a + nonstandard directory + LIBS libraries to pass to the linker, e.g. -l + CPPFLAGS C/C++/Objective C preprocessor flags, e.g. -I if + you have headers in a nonstandard directory + CPP C preprocessor + CXX C++ compiler command + CXXFLAGS C++ compiler flags + CXXCPP C++ preprocessor + XMKMF Path to xmkmf, Makefile generator for X Window System + +Use these variables to override the choices made by `configure' or to help +it to find libraries and programs with nonstandard names/locations. + +_ACEOF +ac_status=$? +fi + +if test "$ac_init_help" = "recursive"; then + # If there are subdirs, report their specific --help. + for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue + test -d "$ac_dir" || + { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || + continue + ac_builddir=. + +case "$ac_dir" in +.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; +*) + ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` + # A ".." for each directory in $ac_dir_suffix. + ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` + case $ac_top_builddir_sub in + "") ac_top_builddir_sub=. ac_top_build_prefix= ;; + *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; + esac ;; +esac +ac_abs_top_builddir=$ac_pwd +ac_abs_builddir=$ac_pwd$ac_dir_suffix +# for backward compatibility: +ac_top_builddir=$ac_top_build_prefix + +case $srcdir in + .) # We are building in place. + ac_srcdir=. + ac_top_srcdir=$ac_top_builddir_sub + ac_abs_top_srcdir=$ac_pwd ;; + [\\/]* | ?:[\\/]* ) # Absolute name. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir + ac_abs_top_srcdir=$srcdir ;; + *) # Relative name. + ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_build_prefix$srcdir + ac_abs_top_srcdir=$ac_pwd/$srcdir ;; +esac +ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix + + cd "$ac_dir" || { ac_status=$?; continue; } + # Check for guested configure. + if test -f "$ac_srcdir/configure.gnu"; then + echo && + $SHELL "$ac_srcdir/configure.gnu" --help=recursive + elif test -f "$ac_srcdir/configure"; then + echo && + $SHELL "$ac_srcdir/configure" --help=recursive + else + $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 + fi || ac_status=$? + cd "$ac_pwd" || { ac_status=$?; break; } + done +fi + +test -n "$ac_init_help" && exit $ac_status +if $ac_init_version; then + cat <<\_ACEOF +configure +generated by GNU Autoconf 2.63 + +Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, +2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. +This configure script is free software; the Free Software Foundation +gives unlimited permission to copy, distribute and modify it. +_ACEOF + exit +fi +cat >config.log <<_ACEOF +This file contains any messages produced by compilers while +running configure, to aid debugging if configure makes a mistake. + +It was created by $as_me, which was +generated by GNU Autoconf 2.63. Invocation command line was + + $ $0 $@ + +_ACEOF +exec 5>>config.log +{ +cat <<_ASUNAME +## --------- ## +## Platform. ## +## --------- ## + +hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` +uname -m = `(uname -m) 2>/dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` + +/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` +/usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` +/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` +/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` + +_ASUNAME + +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + $as_echo "PATH: $as_dir" +done +IFS=$as_save_IFS + +} >&5 + +cat >&5 <<_ACEOF + + +## ----------- ## +## Core tests. ## +## ----------- ## + +_ACEOF + + +# Keep a trace of the command line. +# Strip out --no-create and --no-recursion so they do not pile up. +# Strip out --silent because we don't want to record it for future runs. +# Also quote any args containing shell meta-characters. +# Make two passes to allow for proper duplicate-argument suppression. +ac_configure_args= +ac_configure_args0= +ac_configure_args1= +ac_must_keep_next=false +for ac_pass in 1 2 +do + for ac_arg + do + case $ac_arg in + -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + continue ;; + *\'*) + ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; + esac + case $ac_pass in + 1) ac_configure_args0="$ac_configure_args0 '$ac_arg'" ;; + 2) + ac_configure_args1="$ac_configure_args1 '$ac_arg'" + if test $ac_must_keep_next = true; then + ac_must_keep_next=false # Got value, back to normal. + else + case $ac_arg in + *=* | --config-cache | -C | -disable-* | --disable-* \ + | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ + | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ + | -with-* | --with-* | -without-* | --without-* | --x) + case "$ac_configure_args0 " in + "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; + esac + ;; + -* ) ac_must_keep_next=true ;; + esac + fi + ac_configure_args="$ac_configure_args '$ac_arg'" + ;; + esac + done +done +$as_unset ac_configure_args0 || test "${ac_configure_args0+set}" != set || { ac_configure_args0=; export ac_configure_args0; } +$as_unset ac_configure_args1 || test "${ac_configure_args1+set}" != set || { ac_configure_args1=; export ac_configure_args1; } + +# When interrupted or exit'd, cleanup temporary files, and complete +# config.log. We remove comments because anyway the quotes in there +# would cause problems or look ugly. +# WARNING: Use '\'' to represent an apostrophe within the trap. +# WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. +trap 'exit_status=$? + # Save into config.log some information that might help in debugging. + { + echo + + cat <<\_ASBOX +## ---------------- ## +## Cache variables. ## +## ---------------- ## +_ASBOX + echo + # The following way of writing the cache mishandles newlines in values, +( + for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do + eval ac_val=\$$ac_var + case $ac_val in #( + *${as_nl}*) + case $ac_var in #( + *_cv_*) { $as_echo "$as_me:$LINENO: WARNING: cache variable $ac_var contains a newline" >&5 +$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; + esac + case $ac_var in #( + _ | IFS | as_nl) ;; #( + BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( + *) $as_unset $ac_var ;; + esac ;; + esac + done + (set) 2>&1 | + case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( + *${as_nl}ac_space=\ *) + sed -n \ + "s/'\''/'\''\\\\'\'''\''/g; + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" + ;; #( + *) + sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" + ;; + esac | + sort +) + echo + + cat <<\_ASBOX +## ----------------- ## +## Output variables. ## +## ----------------- ## +_ASBOX + echo + for ac_var in $ac_subst_vars + do + eval ac_val=\$$ac_var + case $ac_val in + *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; + esac + $as_echo "$ac_var='\''$ac_val'\''" + done | sort + echo + + if test -n "$ac_subst_files"; then + cat <<\_ASBOX +## ------------------- ## +## File substitutions. ## +## ------------------- ## +_ASBOX + echo + for ac_var in $ac_subst_files + do + eval ac_val=\$$ac_var + case $ac_val in + *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; + esac + $as_echo "$ac_var='\''$ac_val'\''" + done | sort + echo + fi + + if test -s confdefs.h; then + cat <<\_ASBOX +## ----------- ## +## confdefs.h. ## +## ----------- ## +_ASBOX + echo + cat confdefs.h + echo + fi + test "$ac_signal" != 0 && + $as_echo "$as_me: caught signal $ac_signal" + $as_echo "$as_me: exit $exit_status" + } >&5 + rm -f core *.core core.conftest.* && + rm -f -r conftest* confdefs* conf$$* $ac_clean_files && + exit $exit_status +' 0 +for ac_signal in 1 2 13 15; do + trap 'ac_signal='$ac_signal'; { (exit 1); exit 1; }' $ac_signal +done +ac_signal=0 + +# confdefs.h avoids OS command line length limits that DEFS can exceed. +rm -f -r conftest* confdefs.h + +# Predefined preprocessor variables. + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_NAME "$PACKAGE_NAME" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_TARNAME "$PACKAGE_TARNAME" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_VERSION "$PACKAGE_VERSION" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_STRING "$PACKAGE_STRING" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" +_ACEOF + + +# Let the site file select an alternate cache file if it wants to. +# Prefer an explicitly selected file to automatically selected ones. +ac_site_file1=NONE +ac_site_file2=NONE +if test -n "$CONFIG_SITE"; then + ac_site_file1=$CONFIG_SITE +elif test "x$prefix" != xNONE; then + ac_site_file1=$prefix/share/config.site + ac_site_file2=$prefix/etc/config.site +else + ac_site_file1=$ac_default_prefix/share/config.site + ac_site_file2=$ac_default_prefix/etc/config.site +fi +for ac_site_file in "$ac_site_file1" "$ac_site_file2" +do + test "x$ac_site_file" = xNONE && continue + if test -r "$ac_site_file"; then + { $as_echo "$as_me:$LINENO: loading site script $ac_site_file" >&5 +$as_echo "$as_me: loading site script $ac_site_file" >&6;} + sed 's/^/| /' "$ac_site_file" >&5 + . "$ac_site_file" + fi +done + +if test -r "$cache_file"; then + # Some versions of bash will fail to source /dev/null (special + # files actually), so we avoid doing that. + if test -f "$cache_file"; then + { $as_echo "$as_me:$LINENO: loading cache $cache_file" >&5 +$as_echo "$as_me: loading cache $cache_file" >&6;} + case $cache_file in + [\\/]* | ?:[\\/]* ) . "$cache_file";; + *) . "./$cache_file";; + esac + fi +else + { $as_echo "$as_me:$LINENO: creating cache $cache_file" >&5 +$as_echo "$as_me: creating cache $cache_file" >&6;} + >$cache_file +fi + +# Check that the precious variables saved in the cache have kept the same +# value. +ac_cache_corrupted=false +for ac_var in $ac_precious_vars; do + eval ac_old_set=\$ac_cv_env_${ac_var}_set + eval ac_new_set=\$ac_env_${ac_var}_set + eval ac_old_val=\$ac_cv_env_${ac_var}_value + eval ac_new_val=\$ac_env_${ac_var}_value + case $ac_old_set,$ac_new_set in + set,) + { $as_echo "$as_me:$LINENO: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 +$as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,set) + { $as_echo "$as_me:$LINENO: error: \`$ac_var' was not set in the previous run" >&5 +$as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,);; + *) + if test "x$ac_old_val" != "x$ac_new_val"; then + # differences in whitespace do not lead to failure. + ac_old_val_w=`echo x $ac_old_val` + ac_new_val_w=`echo x $ac_new_val` + if test "$ac_old_val_w" != "$ac_new_val_w"; then + { $as_echo "$as_me:$LINENO: error: \`$ac_var' has changed since the previous run:" >&5 +$as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} + ac_cache_corrupted=: + else + { $as_echo "$as_me:$LINENO: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 +$as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} + eval $ac_var=\$ac_old_val + fi + { $as_echo "$as_me:$LINENO: former value: \`$ac_old_val'" >&5 +$as_echo "$as_me: former value: \`$ac_old_val'" >&2;} + { $as_echo "$as_me:$LINENO: current value: \`$ac_new_val'" >&5 +$as_echo "$as_me: current value: \`$ac_new_val'" >&2;} + fi;; + esac + # Pass precious variables to config.status. + if test "$ac_new_set" = set; then + case $ac_new_val in + *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; + *) ac_arg=$ac_var=$ac_new_val ;; + esac + case " $ac_configure_args " in + *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. + *) ac_configure_args="$ac_configure_args '$ac_arg'" ;; + esac + fi +done +if $ac_cache_corrupted; then + { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} + { $as_echo "$as_me:$LINENO: error: changes in the environment can compromise the build" >&5 +$as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} + { { $as_echo "$as_me:$LINENO: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&5 +$as_echo "$as_me: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&2;} + { (exit 1); exit 1; }; } +fi + + + + + + + + + + + + + + + + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +ac_config_headers="$ac_config_headers include/SDL_config.h" + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. +set dummy ${ac_tool_prefix}gcc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}gcc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="gcc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +else + CC="$ac_cv_prog_CC" +fi + +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. +set dummy ${ac_tool_prefix}cc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}cc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + fi +fi +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + ac_prog_rejected=no +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# != 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" + fi +fi +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + for ac_prog in cl.exe + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CC" && break + done +fi +if test -z "$CC"; then + ac_ct_CC=$CC + for ac_prog in cl.exe +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CC" && break +done + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +fi + +fi + + +test -z "$CC" && { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: no acceptable C compiler found in \$PATH +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: no acceptable C compiler found in \$PATH +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; }; } + +# Provide some information about the compiler. +$as_echo "$as_me:$LINENO: checking for C compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +{ (ac_try="$ac_compiler --version >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler --version >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -v >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -v >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -V >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -V >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" +# Try to create an executable without -o first, disregard a.out. +# It will help us diagnose broken compilers, and finding out an intuition +# of exeext. +{ $as_echo "$as_me:$LINENO: checking for C compiler default output file name" >&5 +$as_echo_n "checking for C compiler default output file name... " >&6; } +ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` + +# The possible output files: +ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" + +ac_rmfiles= +for ac_file in $ac_files +do + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + * ) ac_rmfiles="$ac_rmfiles $ac_file";; + esac +done +rm -f $ac_rmfiles + +if { (ac_try="$ac_link_default" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link_default") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. +# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' +# in a Makefile. We should not override ac_cv_exeext if it was cached, +# so that the user can short-circuit this test for compilers unknown to +# Autoconf. +for ac_file in $ac_files '' +do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) + ;; + [ab].out ) + # We found the default executable, but exeext='' is most + # certainly right. + break;; + *.* ) + if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; + then :; else + ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + fi + # We set ac_cv_exeext here because the later test for it is not + # safe: cross compilers may not add the suffix if given an `-o' + # argument, so we may need to know it at that point already. + # Even if this section looks crufty: it has the advantage of + # actually working. + break;; + * ) + break;; + esac +done +test "$ac_cv_exeext" = no && ac_cv_exeext= + +else + ac_file='' +fi + +{ $as_echo "$as_me:$LINENO: result: $ac_file" >&5 +$as_echo "$ac_file" >&6; } +if test -z "$ac_file"; then + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: C compiler cannot create executables +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: C compiler cannot create executables +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } +fi + +ac_exeext=$ac_cv_exeext + +# Check that the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +{ $as_echo "$as_me:$LINENO: checking whether the C compiler works" >&5 +$as_echo_n "checking whether the C compiler works... " >&6; } +# FIXME: These cross compiler hacks should be removed for Autoconf 3.0 +# If not cross compiling, check that we can run a simple program. +if test "$cross_compiling" != yes; then + if { ac_try='./$ac_file' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + cross_compiling=no + else + if test "$cross_compiling" = maybe; then + cross_compiling=yes + else + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; }; } + fi + fi +fi +{ $as_echo "$as_me:$LINENO: result: yes" >&5 +$as_echo "yes" >&6; } + +rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out +ac_clean_files=$ac_clean_files_save +# Check that the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +{ $as_echo "$as_me:$LINENO: checking whether we are cross compiling" >&5 +$as_echo_n "checking whether we are cross compiling... " >&6; } +{ $as_echo "$as_me:$LINENO: result: $cross_compiling" >&5 +$as_echo "$cross_compiling" >&6; } + +{ $as_echo "$as_me:$LINENO: checking for suffix of executables" >&5 +$as_echo_n "checking for suffix of executables... " >&6; } +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # If both `conftest.exe' and `conftest' are `present' (well, observable) +# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will +# work properly (i.e., refer to `conftest.exe'), while it won't with +# `rm'. +for ac_file in conftest.exe conftest conftest.*; do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + break;; + * ) break;; + esac +done +else + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; }; } +fi + +rm -f conftest$ac_cv_exeext +{ $as_echo "$as_me:$LINENO: result: $ac_cv_exeext" >&5 +$as_echo "$ac_cv_exeext" >&6; } + +rm -f conftest.$ac_ext +EXEEXT=$ac_cv_exeext +ac_exeext=$EXEEXT +{ $as_echo "$as_me:$LINENO: checking for suffix of object files" >&5 +$as_echo_n "checking for suffix of object files... " >&6; } +if test "${ac_cv_objext+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.o conftest.obj +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + for ac_file in conftest.o conftest.obj conftest.*; do + test -f "$ac_file" || continue; + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; + *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` + break;; + esac +done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute suffix of object files: cannot compile +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute suffix of object files: cannot compile +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; }; } +fi + +rm -f conftest.$ac_cv_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_objext" >&5 +$as_echo "$ac_cv_objext" >&6; } +OBJEXT=$ac_cv_objext +ac_objext=$OBJEXT +{ $as_echo "$as_me:$LINENO: checking whether we are using the GNU C compiler" >&5 +$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } +if test "${ac_cv_c_compiler_gnu+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_compiler_gnu=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_compiler_gnu=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_c_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_compiler_gnu" >&5 +$as_echo "$ac_cv_c_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GCC=yes +else + GCC= +fi +ac_test_CFLAGS=${CFLAGS+set} +ac_save_CFLAGS=$CFLAGS +{ $as_echo "$as_me:$LINENO: checking whether $CC accepts -g" >&5 +$as_echo_n "checking whether $CC accepts -g... " >&6; } +if test "${ac_cv_prog_cc_g+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_save_c_werror_flag=$ac_c_werror_flag + ac_c_werror_flag=yes + ac_cv_prog_cc_g=no + CFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cc_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + CFLAGS="" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_c_werror_flag=$ac_save_c_werror_flag + CFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cc_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_c_werror_flag=$ac_save_c_werror_flag +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cc_g" >&5 +$as_echo "$ac_cv_prog_cc_g" >&6; } +if test "$ac_test_CFLAGS" = set; then + CFLAGS=$ac_save_CFLAGS +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi +{ $as_echo "$as_me:$LINENO: checking for $CC option to accept ISO C89" >&5 +$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } +if test "${ac_cv_prog_cc_c89+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_cv_prog_cc_c89=no +ac_save_CC=$CC +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#include +#include +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ +struct buf { int x; }; +FILE * (*rcsopen) (struct buf *, struct stat *, int); +static char *e (p, i) + char **p; + int i; +{ + return p[i]; +} +static char *f (char * (*g) (char **, int), char **p, ...) +{ + char *s; + va_list v; + va_start (v,p); + s = g (p, va_arg (v,int)); + va_end (v); + return s; +} + +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has + function prototypes and stuff, but not '\xHH' hex character constants. + These don't provoke an error unfortunately, instead are silently treated + as 'x'. The following induces an error, until -std is added to get + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an + array size at least. It's necessary to write '\x00'==0 to get something + that's true only with -std. */ +int osf4_cc_array ['\x00' == 0 ? 1 : -1]; + +/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters + inside strings and character constants. */ +#define FOO(x) 'x' +int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; + +int test (int i, double x); +struct s1 {int (*f) (int a);}; +struct s2 {int (*f) (double a);}; +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); +int argc; +char **argv; +int +main () +{ +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; + ; + return 0; +} +_ACEOF +for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ + -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" +do + CC="$ac_save_CC $ac_arg" + rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cc_c89=$ac_arg +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext + test "x$ac_cv_prog_cc_c89" != "xno" && break +done +rm -f conftest.$ac_ext +CC=$ac_save_CC + +fi +# AC_CACHE_VAL +case "x$ac_cv_prog_cc_c89" in + x) + { $as_echo "$as_me:$LINENO: result: none needed" >&5 +$as_echo "none needed" >&6; } ;; + xno) + { $as_echo "$as_me:$LINENO: result: unsupported" >&5 +$as_echo "unsupported" >&6; } ;; + *) + CC="$CC $ac_cv_prog_cc_c89" + { $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cc_c89" >&5 +$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; +esac + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +{ $as_echo "$as_me:$LINENO: checking how to run the C preprocessor" >&5 +$as_echo_n "checking how to run the C preprocessor... " >&6; } +# On Suns, sometimes $CPP names a directory. +if test -n "$CPP" && test -d "$CPP"; then + CPP= +fi +if test -z "$CPP"; then + if test "${ac_cv_prog_CPP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + # Double quotes because CPP needs to be expanded + for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" + do + ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi + +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then + # Broken: success on invalid input. +continue +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi + +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + break +fi + + done + ac_cv_prog_CPP=$CPP + +fi + CPP=$ac_cv_prog_CPP +else + ac_cv_prog_CPP=$CPP +fi +{ $as_echo "$as_me:$LINENO: result: $CPP" >&5 +$as_echo "$CPP" >&6; } +ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi + +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then + # Broken: success on invalid input. +continue +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi + +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + : +else + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; }; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +{ $as_echo "$as_me:$LINENO: checking for grep that handles long lines and -e" >&5 +$as_echo_n "checking for grep that handles long lines and -e... " >&6; } +if test "${ac_cv_path_GREP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -z "$GREP"; then + ac_path_GREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in grep ggrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" + { test -f "$ac_path_GREP" && $as_test_x "$ac_path_GREP"; } || continue +# Check for GNU ac_path_GREP and select it if it is found. + # Check for GNU $ac_path_GREP +case `"$ac_path_GREP" --version 2>&1` in +*GNU*) + ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'GREP' >> "conftest.nl" + "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + ac_count=`expr $ac_count + 1` + if test $ac_count -gt ${ac_path_GREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_GREP="$ac_path_GREP" + ac_path_GREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_GREP_found && break 3 + done + done +done +IFS=$as_save_IFS + if test -z "$ac_cv_path_GREP"; then + { { $as_echo "$as_me:$LINENO: error: no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5 +$as_echo "$as_me: error: no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;} + { (exit 1); exit 1; }; } + fi +else + ac_cv_path_GREP=$GREP +fi + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_GREP" >&5 +$as_echo "$ac_cv_path_GREP" >&6; } + GREP="$ac_cv_path_GREP" + + +{ $as_echo "$as_me:$LINENO: checking for egrep" >&5 +$as_echo_n "checking for egrep... " >&6; } +if test "${ac_cv_path_EGREP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 + then ac_cv_path_EGREP="$GREP -E" + else + if test -z "$EGREP"; then + ac_path_EGREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in egrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" + { test -f "$ac_path_EGREP" && $as_test_x "$ac_path_EGREP"; } || continue +# Check for GNU ac_path_EGREP and select it if it is found. + # Check for GNU $ac_path_EGREP +case `"$ac_path_EGREP" --version 2>&1` in +*GNU*) + ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'EGREP' >> "conftest.nl" + "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + ac_count=`expr $ac_count + 1` + if test $ac_count -gt ${ac_path_EGREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_EGREP="$ac_path_EGREP" + ac_path_EGREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_EGREP_found && break 3 + done + done +done +IFS=$as_save_IFS + if test -z "$ac_cv_path_EGREP"; then + { { $as_echo "$as_me:$LINENO: error: no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5 +$as_echo "$as_me: error: no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;} + { (exit 1); exit 1; }; } + fi +else + ac_cv_path_EGREP=$EGREP +fi + + fi +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_EGREP" >&5 +$as_echo "$ac_cv_path_EGREP" >&6; } + EGREP="$ac_cv_path_EGREP" + + +{ $as_echo "$as_me:$LINENO: checking for ANSI C header files" >&5 +$as_echo_n "checking for ANSI C header files... " >&6; } +if test "${ac_cv_header_stdc+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#include +#include + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_header_stdc=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_header_stdc=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +if test $ac_cv_header_stdc = yes; then + # SunOS 4.x string.h does not declare mem*, contrary to ANSI. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "memchr" >/dev/null 2>&1; then + : +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "free" >/dev/null 2>&1; then + : +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. + if test "$cross_compiling" = yes; then + : +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#if ((' ' & 0x0FF) == 0x020) +# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') +# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) +#else +# define ISLOWER(c) \ + (('a' <= (c) && (c) <= 'i') \ + || ('j' <= (c) && (c) <= 'r') \ + || ('s' <= (c) && (c) <= 'z')) +# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) +#endif + +#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) +int +main () +{ + int i; + for (i = 0; i < 256; i++) + if (XOR (islower (i), ISLOWER (i)) + || toupper (i) != TOUPPER (i)) + return 2; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_header_stdc=no +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + + +fi +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_header_stdc" >&5 +$as_echo "$ac_cv_header_stdc" >&6; } +if test $ac_cv_header_stdc = yes; then + +cat >>confdefs.h <<\_ACEOF +#define STDC_HEADERS 1 +_ACEOF + +fi + +# On IRIX 5.3, sys/types and inttypes.h are conflicting. + + + + + + + + + +for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ + inttypes.h stdint.h unistd.h +do +as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +{ $as_echo "$as_me:$LINENO: checking for $ac_header" >&5 +$as_echo_n "checking for $ac_header... " >&6; } +if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default + +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + eval "$as_ac_Header=yes" +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + eval "$as_ac_Header=no" +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +ac_res=`eval 'as_val=${'$as_ac_Header'} + $as_echo "$as_val"'` + { $as_echo "$as_me:$LINENO: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +as_val=`eval 'as_val=${'$as_ac_Header'} + $as_echo "$as_val"'` + if test "x$as_val" = x""yes; then + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + + if test "${ac_cv_header_minix_config_h+set}" = set; then + { $as_echo "$as_me:$LINENO: checking for minix/config.h" >&5 +$as_echo_n "checking for minix/config.h... " >&6; } +if test "${ac_cv_header_minix_config_h+set}" = set; then + $as_echo_n "(cached) " >&6 +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_header_minix_config_h" >&5 +$as_echo "$ac_cv_header_minix_config_h" >&6; } +else + # Is the header compilable? +{ $as_echo "$as_me:$LINENO: checking minix/config.h usability" >&5 +$as_echo_n "checking minix/config.h usability... " >&6; } +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_header_compiler=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_compiler=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +{ $as_echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +$as_echo "$ac_header_compiler" >&6; } + +# Is the header present? +{ $as_echo "$as_me:$LINENO: checking minix/config.h presence" >&5 +$as_echo_n "checking minix/config.h presence... " >&6; } +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then + ac_header_preproc=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi + +rm -f conftest.err conftest.$ac_ext +{ $as_echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +$as_echo "$ac_header_preproc" >&6; } + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: accepted by the compiler, rejected by the preprocessor!" >&5 +$as_echo "$as_me: WARNING: minix/config.h: accepted by the compiler, rejected by the preprocessor!" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: proceeding with the compiler's result" >&5 +$as_echo "$as_me: WARNING: minix/config.h: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: present but cannot be compiled" >&5 +$as_echo "$as_me: WARNING: minix/config.h: present but cannot be compiled" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: check for missing prerequisite headers?" >&5 +$as_echo "$as_me: WARNING: minix/config.h: check for missing prerequisite headers?" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: see the Autoconf documentation" >&5 +$as_echo "$as_me: WARNING: minix/config.h: see the Autoconf documentation" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: section \"Present But Cannot Be Compiled\"" >&5 +$as_echo "$as_me: WARNING: minix/config.h: section \"Present But Cannot Be Compiled\"" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: proceeding with the preprocessor's result" >&5 +$as_echo "$as_me: WARNING: minix/config.h: proceeding with the preprocessor's result" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: minix/config.h: in the future, the compiler will take precedence" >&5 +$as_echo "$as_me: WARNING: minix/config.h: in the future, the compiler will take precedence" >&2;} + + ;; +esac +{ $as_echo "$as_me:$LINENO: checking for minix/config.h" >&5 +$as_echo_n "checking for minix/config.h... " >&6; } +if test "${ac_cv_header_minix_config_h+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_cv_header_minix_config_h=$ac_header_preproc +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_header_minix_config_h" >&5 +$as_echo "$ac_cv_header_minix_config_h" >&6; } + +fi +if test "x$ac_cv_header_minix_config_h" = x""yes; then + MINIX=yes +else + MINIX= +fi + + + if test "$MINIX" = yes; then + +cat >>confdefs.h <<\_ACEOF +#define _POSIX_SOURCE 1 +_ACEOF + + +cat >>confdefs.h <<\_ACEOF +#define _POSIX_1_SOURCE 2 +_ACEOF + + +cat >>confdefs.h <<\_ACEOF +#define _MINIX 1 +_ACEOF + + fi + + + + { $as_echo "$as_me:$LINENO: checking whether it is safe to define __EXTENSIONS__" >&5 +$as_echo_n "checking whether it is safe to define __EXTENSIONS__... " >&6; } +if test "${ac_cv_safe_to_define___extensions__+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +# define __EXTENSIONS__ 1 + $ac_includes_default +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_safe_to_define___extensions__=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_safe_to_define___extensions__=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_safe_to_define___extensions__" >&5 +$as_echo "$ac_cv_safe_to_define___extensions__" >&6; } + test $ac_cv_safe_to_define___extensions__ = yes && + cat >>confdefs.h <<\_ACEOF +#define __EXTENSIONS__ 1 +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define _ALL_SOURCE 1 +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define _GNU_SOURCE 1 +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define _POSIX_PTHREAD_SEMANTICS 1 +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define _TANDEM_SOURCE 1 +_ACEOF + + +ac_aux_dir= +for ac_dir in $srcdir/build-scripts; do + if test -f "$ac_dir/install-sh"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install-sh -c" + break + elif test -f "$ac_dir/install.sh"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install.sh -c" + break + elif test -f "$ac_dir/shtool"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/shtool install -c" + break + fi +done +if test -z "$ac_aux_dir"; then + { { $as_echo "$as_me:$LINENO: error: cannot find install-sh or install.sh in $srcdir/build-scripts" >&5 +$as_echo "$as_me: error: cannot find install-sh or install.sh in $srcdir/build-scripts" >&2;} + { (exit 1); exit 1; }; } +fi + +# These three variables are undocumented and unsupported, +# and are intended to be withdrawn in a future Autoconf release. +# They can cause serious problems if a builder's source tree is in a directory +# whose full name contains unusual characters. +ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. +ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. +ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. + + + +# +# Making releases: +# Edit include/SDL/SDL_version.h and change the version, then: +# SDL_MICRO_VERSION += 1; +# SDL_INTERFACE_AGE += 1; +# SDL_BINARY_AGE += 1; +# if any functions have been added, set SDL_INTERFACE_AGE to 0. +# if backwards compatibility has been broken, +# set SDL_BINARY_AGE and SDL_INTERFACE_AGE to 0. +# +SDL_MAJOR_VERSION=1 +SDL_MINOR_VERSION=2 +SDL_MICRO_VERSION=14 +SDL_INTERFACE_AGE=3 +SDL_BINARY_AGE=14 +SDL_VERSION=$SDL_MAJOR_VERSION.$SDL_MINOR_VERSION.$SDL_MICRO_VERSION + + + + + + + + +# libtool versioning +case `pwd` in + *\ * | *\ *) + { $as_echo "$as_me:$LINENO: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5 +$as_echo "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;; +esac + + + +macro_version='2.2.6' +macro_revision='1.3012' + + + + + + + + + + + + + +ltmain="$ac_aux_dir/ltmain.sh" + +# Make sure we can run config.sub. +$SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || + { { $as_echo "$as_me:$LINENO: error: cannot run $SHELL $ac_aux_dir/config.sub" >&5 +$as_echo "$as_me: error: cannot run $SHELL $ac_aux_dir/config.sub" >&2;} + { (exit 1); exit 1; }; } + +{ $as_echo "$as_me:$LINENO: checking build system type" >&5 +$as_echo_n "checking build system type... " >&6; } +if test "${ac_cv_build+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_build_alias=$build_alias +test "x$ac_build_alias" = x && + ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` +test "x$ac_build_alias" = x && + { { $as_echo "$as_me:$LINENO: error: cannot guess build type; you must specify one" >&5 +$as_echo "$as_me: error: cannot guess build type; you must specify one" >&2;} + { (exit 1); exit 1; }; } +ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || + { { $as_echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $ac_build_alias failed" >&5 +$as_echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $ac_build_alias failed" >&2;} + { (exit 1); exit 1; }; } + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_build" >&5 +$as_echo "$ac_cv_build" >&6; } +case $ac_cv_build in +*-*-*) ;; +*) { { $as_echo "$as_me:$LINENO: error: invalid value of canonical build" >&5 +$as_echo "$as_me: error: invalid value of canonical build" >&2;} + { (exit 1); exit 1; }; };; +esac +build=$ac_cv_build +ac_save_IFS=$IFS; IFS='-' +set x $ac_cv_build +shift +build_cpu=$1 +build_vendor=$2 +shift; shift +# Remember, the first character of IFS is used to create $*, +# except with old shells: +build_os=$* +IFS=$ac_save_IFS +case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac + + +{ $as_echo "$as_me:$LINENO: checking host system type" >&5 +$as_echo_n "checking host system type... " >&6; } +if test "${ac_cv_host+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "x$host_alias" = x; then + ac_cv_host=$ac_cv_build +else + ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || + { { $as_echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&5 +$as_echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&2;} + { (exit 1); exit 1; }; } +fi + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_host" >&5 +$as_echo "$ac_cv_host" >&6; } +case $ac_cv_host in +*-*-*) ;; +*) { { $as_echo "$as_me:$LINENO: error: invalid value of canonical host" >&5 +$as_echo "$as_me: error: invalid value of canonical host" >&2;} + { (exit 1); exit 1; }; };; +esac +host=$ac_cv_host +ac_save_IFS=$IFS; IFS='-' +set x $ac_cv_host +shift +host_cpu=$1 +host_vendor=$2 +shift; shift +# Remember, the first character of IFS is used to create $*, +# except with old shells: +host_os=$* +IFS=$ac_save_IFS +case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac + + +{ $as_echo "$as_me:$LINENO: checking for a sed that does not truncate output" >&5 +$as_echo_n "checking for a sed that does not truncate output... " >&6; } +if test "${ac_cv_path_SED+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ + for ac_i in 1 2 3 4 5 6 7; do + ac_script="$ac_script$as_nl$ac_script" + done + echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed + $as_unset ac_script || ac_script= + if test -z "$SED"; then + ac_path_SED_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in sed gsed; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_SED="$as_dir/$ac_prog$ac_exec_ext" + { test -f "$ac_path_SED" && $as_test_x "$ac_path_SED"; } || continue +# Check for GNU ac_path_SED and select it if it is found. + # Check for GNU $ac_path_SED +case `"$ac_path_SED" --version 2>&1` in +*GNU*) + ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo '' >> "conftest.nl" + "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + ac_count=`expr $ac_count + 1` + if test $ac_count -gt ${ac_path_SED_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_SED="$ac_path_SED" + ac_path_SED_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_SED_found && break 3 + done + done +done +IFS=$as_save_IFS + if test -z "$ac_cv_path_SED"; then + { { $as_echo "$as_me:$LINENO: error: no acceptable sed could be found in \$PATH" >&5 +$as_echo "$as_me: error: no acceptable sed could be found in \$PATH" >&2;} + { (exit 1); exit 1; }; } + fi +else + ac_cv_path_SED=$SED +fi + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_SED" >&5 +$as_echo "$ac_cv_path_SED" >&6; } + SED="$ac_cv_path_SED" + rm -f conftest.sed + +test -z "$SED" && SED=sed +Xsed="$SED -e 1s/^X//" + + + + + + + + + + + +{ $as_echo "$as_me:$LINENO: checking for fgrep" >&5 +$as_echo_n "checking for fgrep... " >&6; } +if test "${ac_cv_path_FGREP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 + then ac_cv_path_FGREP="$GREP -F" + else + if test -z "$FGREP"; then + ac_path_FGREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in fgrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_FGREP="$as_dir/$ac_prog$ac_exec_ext" + { test -f "$ac_path_FGREP" && $as_test_x "$ac_path_FGREP"; } || continue +# Check for GNU ac_path_FGREP and select it if it is found. + # Check for GNU $ac_path_FGREP +case `"$ac_path_FGREP" --version 2>&1` in +*GNU*) + ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'FGREP' >> "conftest.nl" + "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + ac_count=`expr $ac_count + 1` + if test $ac_count -gt ${ac_path_FGREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_FGREP="$ac_path_FGREP" + ac_path_FGREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_FGREP_found && break 3 + done + done +done +IFS=$as_save_IFS + if test -z "$ac_cv_path_FGREP"; then + { { $as_echo "$as_me:$LINENO: error: no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5 +$as_echo "$as_me: error: no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;} + { (exit 1); exit 1; }; } + fi +else + ac_cv_path_FGREP=$FGREP +fi + + fi +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_FGREP" >&5 +$as_echo "$ac_cv_path_FGREP" >&6; } + FGREP="$ac_cv_path_FGREP" + + +test -z "$GREP" && GREP=grep + + + + + + + + + + + + + + + + + + + +# Check whether --with-gnu-ld was given. +if test "${with_gnu_ld+set}" = set; then + withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes +else + with_gnu_ld=no +fi + +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + { $as_echo "$as_me:$LINENO: checking for ld used by $CC" >&5 +$as_echo_n "checking for ld used by $CC... " >&6; } + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [\\/]* | ?:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` + while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do + ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + { $as_echo "$as_me:$LINENO: checking for GNU ld" >&5 +$as_echo_n "checking for GNU ld... " >&6; } +else + { $as_echo "$as_me:$LINENO: checking for non-GNU ld" >&5 +$as_echo_n "checking for non-GNU ld... " >&6; } +fi +if test "${lt_cv_path_LD+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -z "$LD"; then + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &5 +$as_echo "$LD" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi +test -z "$LD" && { { $as_echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5 +$as_echo "$as_me: error: no acceptable ld found in \$PATH" >&2;} + { (exit 1); exit 1; }; } +{ $as_echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5 +$as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } +if test "${lt_cv_prog_gnu_ld+set}" = set; then + $as_echo_n "(cached) " >&6 +else + # I'd rather use --version here, but apparently some GNU lds only accept -v. +case `$LD -v 2>&1 &5 +$as_echo "$lt_cv_prog_gnu_ld" >&6; } +with_gnu_ld=$lt_cv_prog_gnu_ld + + + + + + + + + +{ $as_echo "$as_me:$LINENO: checking for BSD- or MS-compatible name lister (nm)" >&5 +$as_echo_n "checking for BSD- or MS-compatible name lister (nm)... " >&6; } +if test "${lt_cv_path_NM+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$NM"; then + # Let the user override the test. + lt_cv_path_NM="$NM" +else + lt_nm_to_check="${ac_tool_prefix}nm" + if test -n "$ac_tool_prefix" && test "$build" = "$host"; then + lt_nm_to_check="$lt_nm_to_check nm" + fi + for lt_tmp_nm in $lt_nm_to_check; do + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + tmp_nm="$ac_dir/$lt_tmp_nm" + if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the `sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + # Tru64's nm complains that /dev/null is an invalid object file + case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in + */dev/null* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break + ;; + *) + lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + ;; + esac + ;; + esac + fi + done + IFS="$lt_save_ifs" + done + : ${lt_cv_path_NM=no} +fi +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_path_NM" >&5 +$as_echo "$lt_cv_path_NM" >&6; } +if test "$lt_cv_path_NM" != "no"; then + NM="$lt_cv_path_NM" +else + # Didn't find any BSD compatible name lister, look for dumpbin. + if test -n "$ac_tool_prefix"; then + for ac_prog in "dumpbin -symbols" "link -dump -symbols" + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_DUMPBIN+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$DUMPBIN"; then + ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +DUMPBIN=$ac_cv_prog_DUMPBIN +if test -n "$DUMPBIN"; then + { $as_echo "$as_me:$LINENO: result: $DUMPBIN" >&5 +$as_echo "$DUMPBIN" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$DUMPBIN" && break + done +fi +if test -z "$DUMPBIN"; then + ac_ct_DUMPBIN=$DUMPBIN + for ac_prog in "dumpbin -symbols" "link -dump -symbols" +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_DUMPBIN+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_DUMPBIN"; then + ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_DUMPBIN="$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN +if test -n "$ac_ct_DUMPBIN"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_DUMPBIN" >&5 +$as_echo "$ac_ct_DUMPBIN" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_DUMPBIN" && break +done + + if test "x$ac_ct_DUMPBIN" = x; then + DUMPBIN=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + DUMPBIN=$ac_ct_DUMPBIN + fi +fi + + + if test "$DUMPBIN" != ":"; then + NM="$DUMPBIN" + fi +fi +test -z "$NM" && NM=nm + + + + + + +{ $as_echo "$as_me:$LINENO: checking the name lister ($NM) interface" >&5 +$as_echo_n "checking the name lister ($NM) interface... " >&6; } +if test "${lt_cv_nm_interface+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_nm_interface="BSD nm" + echo "int some_variable = 0;" > conftest.$ac_ext + (eval echo "\"\$as_me:4632: $ac_compile\"" >&5) + (eval "$ac_compile" 2>conftest.err) + cat conftest.err >&5 + (eval echo "\"\$as_me:4635: $NM \\\"conftest.$ac_objext\\\"\"" >&5) + (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) + cat conftest.err >&5 + (eval echo "\"\$as_me:4638: output\"" >&5) + cat conftest.out >&5 + if $GREP 'External.*some_variable' conftest.out > /dev/null; then + lt_cv_nm_interface="MS dumpbin" + fi + rm -f conftest* +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_nm_interface" >&5 +$as_echo "$lt_cv_nm_interface" >&6; } + +{ $as_echo "$as_me:$LINENO: checking whether ln -s works" >&5 +$as_echo_n "checking whether ln -s works... " >&6; } +LN_S=$as_ln_s +if test "$LN_S" = "ln -s"; then + { $as_echo "$as_me:$LINENO: result: yes" >&5 +$as_echo "yes" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no, using $LN_S" >&5 +$as_echo "no, using $LN_S" >&6; } +fi + +# find the maximum length of command line arguments +{ $as_echo "$as_me:$LINENO: checking the maximum length of command line arguments" >&5 +$as_echo_n "checking the maximum length of command line arguments... " >&6; } +if test "${lt_cv_sys_max_cmd_len+set}" = set; then + $as_echo_n "(cached) " >&6 +else + i=0 + teststring="ABCD" + + case $build_os in + msdosdjgpp*) + # On DJGPP, this test can blow up pretty badly due to problems in libc + # (any single argument exceeding 2000 bytes causes a buffer overrun + # during glob expansion). Even if it were fixed, the result of this + # check would be larger than it should be. + lt_cv_sys_max_cmd_len=12288; # 12K is about right + ;; + + gnu*) + # Under GNU Hurd, this test is not required because there is + # no limit to the length of command line arguments. + # Libtool will interpret -1 as no limit whatsoever + lt_cv_sys_max_cmd_len=-1; + ;; + + cygwin* | mingw* | cegcc*) + # On Win9x/ME, this test blows up -- it succeeds, but takes + # about 5 minutes as the teststring grows exponentially. + # Worse, since 9x/ME are not pre-emptively multitasking, + # you end up with a "frozen" computer, even though with patience + # the test eventually succeeds (with a max line length of 256k). + # Instead, let's just punt: use the minimum linelength reported by + # all of the supported platforms: 8192 (on NT/2K/XP). + lt_cv_sys_max_cmd_len=8192; + ;; + + beos*) + # On BeOS, this test takes a really really long time. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + amigaos*) + # On AmigaOS with pdksh, this test takes hours, literally. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) + # This has been around since 386BSD, at least. Likely further. + if test -x /sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` + elif test -x /usr/sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` + else + lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs + fi + # And add a safety zone + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + ;; + + interix*) + # We know the value 262144 and hardcode it with a safety zone (like BSD) + lt_cv_sys_max_cmd_len=196608 + ;; + + osf*) + # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure + # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not + # nice to cause kernel panics so lets avoid the loop below. + # First set a reasonable default. + lt_cv_sys_max_cmd_len=16384 + # + if test -x /sbin/sysconfig; then + case `/sbin/sysconfig -q proc exec_disable_arg_limit` in + *1*) lt_cv_sys_max_cmd_len=-1 ;; + esac + fi + ;; + sco3.2v5*) + lt_cv_sys_max_cmd_len=102400 + ;; + sysv5* | sco5v6* | sysv4.2uw2*) + kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` + if test -n "$kargmax"; then + lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[ ]//'` + else + lt_cv_sys_max_cmd_len=32768 + fi + ;; + *) + lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` + if test -n "$lt_cv_sys_max_cmd_len"; then + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + else + # Make teststring a little bigger before we do anything with it. + # a 1K string should be a reasonable start. + for i in 1 2 3 4 5 6 7 8 ; do + teststring=$teststring$teststring + done + SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} + # If test is not a shell built-in, we'll probably end up computing a + # maximum length that is only half of the actual maximum length, but + # we can't tell. + while { test "X"`$SHELL $0 --fallback-echo "X$teststring$teststring" 2>/dev/null` \ + = "XX$teststring$teststring"; } >/dev/null 2>&1 && + test $i != 17 # 1/2 MB should be enough + do + i=`expr $i + 1` + teststring=$teststring$teststring + done + # Only check the string length outside the loop. + lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` + teststring= + # Add a significant safety factor because C++ compilers can tack on + # massive amounts of additional arguments before passing them to the + # linker. It appears as though 1/2 is a usable value. + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` + fi + ;; + esac + +fi + +if test -n $lt_cv_sys_max_cmd_len ; then + { $as_echo "$as_me:$LINENO: result: $lt_cv_sys_max_cmd_len" >&5 +$as_echo "$lt_cv_sys_max_cmd_len" >&6; } +else + { $as_echo "$as_me:$LINENO: result: none" >&5 +$as_echo "none" >&6; } +fi +max_cmd_len=$lt_cv_sys_max_cmd_len + + + + + + +: ${CP="cp -f"} +: ${MV="mv -f"} +: ${RM="rm -f"} + +{ $as_echo "$as_me:$LINENO: checking whether the shell understands some XSI constructs" >&5 +$as_echo_n "checking whether the shell understands some XSI constructs... " >&6; } +# Try some XSI features +xsi_shell=no +( _lt_dummy="a/b/c" + test "${_lt_dummy##*/},${_lt_dummy%/*},"${_lt_dummy%"$_lt_dummy"}, \ + = c,a/b,, \ + && eval 'test $(( 1 + 1 )) -eq 2 \ + && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \ + && xsi_shell=yes +{ $as_echo "$as_me:$LINENO: result: $xsi_shell" >&5 +$as_echo "$xsi_shell" >&6; } + + +{ $as_echo "$as_me:$LINENO: checking whether the shell understands \"+=\"" >&5 +$as_echo_n "checking whether the shell understands \"+=\"... " >&6; } +lt_shell_append=no +( foo=bar; set foo baz; eval "$1+=\$2" && test "$foo" = barbaz ) \ + >/dev/null 2>&1 \ + && lt_shell_append=yes +{ $as_echo "$as_me:$LINENO: result: $lt_shell_append" >&5 +$as_echo "$lt_shell_append" >&6; } + + +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then + lt_unset=unset +else + lt_unset=false +fi + + + + + +# test EBCDIC or ASCII +case `echo X|tr X '\101'` in + A) # ASCII based system + # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr + lt_SP2NL='tr \040 \012' + lt_NL2SP='tr \015\012 \040\040' + ;; + *) # EBCDIC based system + lt_SP2NL='tr \100 \n' + lt_NL2SP='tr \r\n \100\100' + ;; +esac + + + + + + + + + +{ $as_echo "$as_me:$LINENO: checking for $LD option to reload object files" >&5 +$as_echo_n "checking for $LD option to reload object files... " >&6; } +if test "${lt_cv_ld_reload_flag+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_ld_reload_flag='-r' +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_ld_reload_flag" >&5 +$as_echo "$lt_cv_ld_reload_flag" >&6; } +reload_flag=$lt_cv_ld_reload_flag +case $reload_flag in +"" | " "*) ;; +*) reload_flag=" $reload_flag" ;; +esac +reload_cmds='$LD$reload_flag -o $output$reload_objs' +case $host_os in + darwin*) + if test "$GCC" = yes; then + reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs' + else + reload_cmds='$LD$reload_flag -o $output$reload_objs' + fi + ;; +esac + + + + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. +set dummy ${ac_tool_prefix}objdump; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_OBJDUMP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$OBJDUMP"; then + ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +OBJDUMP=$ac_cv_prog_OBJDUMP +if test -n "$OBJDUMP"; then + { $as_echo "$as_me:$LINENO: result: $OBJDUMP" >&5 +$as_echo "$OBJDUMP" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_OBJDUMP"; then + ac_ct_OBJDUMP=$OBJDUMP + # Extract the first word of "objdump", so it can be a program name with args. +set dummy objdump; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OBJDUMP"; then + ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_OBJDUMP="objdump" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP +if test -n "$ac_ct_OBJDUMP"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_OBJDUMP" >&5 +$as_echo "$ac_ct_OBJDUMP" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_OBJDUMP" = x; then + OBJDUMP="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OBJDUMP=$ac_ct_OBJDUMP + fi +else + OBJDUMP="$ac_cv_prog_OBJDUMP" +fi + +test -z "$OBJDUMP" && OBJDUMP=objdump + + + + + + +{ $as_echo "$as_me:$LINENO: checking how to recognize dependent libraries" >&5 +$as_echo_n "checking how to recognize dependent libraries... " >&6; } +if test "${lt_cv_deplibs_check_method+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_file_magic_cmd='$MAGIC_CMD' +lt_cv_file_magic_test_file= +lt_cv_deplibs_check_method='unknown' +# Need to set the preceding variable on all platforms that support +# interlibrary dependencies. +# 'none' -- dependencies not supported. +# `unknown' -- same as none, but documents that we really don't know. +# 'pass_all' -- all dependencies passed with no checks. +# 'test_compile' -- check by making test program. +# 'file_magic [[regex]]' -- check by looking for files in library path +# which responds to the $file_magic_cmd with a given extended regex. +# If you have `file' or equivalent on your system and you're not sure +# whether `pass_all' will *always* work, you probably want this one. + +case $host_os in +aix[4-9]*) + lt_cv_deplibs_check_method=pass_all + ;; + +beos*) + lt_cv_deplibs_check_method=pass_all + ;; + +bsdi[45]*) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' + lt_cv_file_magic_cmd='/usr/bin/file -L' + lt_cv_file_magic_test_file=/shlib/libc.so + ;; + +cygwin*) + # func_win32_libid is a shell function defined in ltmain.sh + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_deplibs_check_method=pass_all + lt_cv_file_magic_cmd='func_win32_libid' + ;; + +mingw* | pw32*) + # Base MSYS/MinGW do not provide the 'file' command needed by + # func_win32_libid shell function, so use a weaker test based on 'objdump', + # unless we find 'file', for example because we are cross-compiling. + if ( file / ) >/dev/null 2>&1; then + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_file_magic_cmd='func_win32_libid' + else + lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?' + lt_cv_file_magic_cmd='$OBJDUMP -f' + fi + lt_cv_deplibs_check_method=pass_all + ;; + +cegcc) + # use the weaker test based on 'objdump'. See mingw*. + lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' + lt_cv_file_magic_cmd='$OBJDUMP -f' + ;; + +darwin* | rhapsody*) + lt_cv_deplibs_check_method=pass_all + ;; + +freebsd* | dragonfly*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + case $host_cpu in + i*86 ) + # Not sure whether the presence of OpenBSD here was a mistake. + # Let's accept both of them until this is cleared up. + lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + ;; + esac + else + lt_cv_deplibs_check_method=pass_all + fi + ;; + +gnu*) + lt_cv_deplibs_check_method=pass_all + ;; + +hpux10.20* | hpux11*) + lt_cv_file_magic_cmd=/usr/bin/file + case $host_cpu in + ia64*) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' + lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so + ;; + hppa*64*) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]' + lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl + ;; + *) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9].[0-9]) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +interix[3-9]*) + # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$' + ;; + +irix5* | irix6* | nonstopux*) + case $LD in + *-32|*"-32 ") libmagic=32-bit;; + *-n32|*"-n32 ") libmagic=N32;; + *-64|*"-64 ") libmagic=64-bit;; + *) libmagic=never-match;; + esac + lt_cv_deplibs_check_method=pass_all + ;; + +# This must be Linux ELF. +linux* | k*bsd*-gnu) + lt_cv_deplibs_check_method=pass_all + ;; + +netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' + fi + ;; + +newos6*) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=/usr/lib/libnls.so + ;; + +*nto* | *qnx*) + lt_cv_deplibs_check_method=pass_all + ;; + +openbsd*) + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' + fi + ;; + +osf3* | osf4* | osf5*) + lt_cv_deplibs_check_method=pass_all + ;; + +rdos*) + lt_cv_deplibs_check_method=pass_all + ;; + +solaris*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv4 | sysv4.3*) + case $host_vendor in + motorola) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + ncr) + lt_cv_deplibs_check_method=pass_all + ;; + sequent) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" + lt_cv_file_magic_test_file=/lib/libc.so + ;; + siemens) + lt_cv_deplibs_check_method=pass_all + ;; + pc) + lt_cv_deplibs_check_method=pass_all + ;; + esac + ;; + +tpf*) + lt_cv_deplibs_check_method=pass_all + ;; +esac + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_deplibs_check_method" >&5 +$as_echo "$lt_cv_deplibs_check_method" >&6; } +file_magic_cmd=$lt_cv_file_magic_cmd +deplibs_check_method=$lt_cv_deplibs_check_method +test -z "$deplibs_check_method" && deplibs_check_method=unknown + + + + + + + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ar", so it can be a program name with args. +set dummy ${ac_tool_prefix}ar; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_AR+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$AR"; then + ac_cv_prog_AR="$AR" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_AR="${ac_tool_prefix}ar" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +AR=$ac_cv_prog_AR +if test -n "$AR"; then + { $as_echo "$as_me:$LINENO: result: $AR" >&5 +$as_echo "$AR" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_AR"; then + ac_ct_AR=$AR + # Extract the first word of "ar", so it can be a program name with args. +set dummy ar; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_AR+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_AR"; then + ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_AR="ar" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_AR=$ac_cv_prog_ac_ct_AR +if test -n "$ac_ct_AR"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_AR" >&5 +$as_echo "$ac_ct_AR" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_AR" = x; then + AR="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + AR=$ac_ct_AR + fi +else + AR="$ac_cv_prog_AR" +fi + +test -z "$AR" && AR=ar +test -z "$AR_FLAGS" && AR_FLAGS=cru + + + + + + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. +set dummy ${ac_tool_prefix}strip; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_STRIP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$STRIP"; then + ac_cv_prog_STRIP="$STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_STRIP="${ac_tool_prefix}strip" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +STRIP=$ac_cv_prog_STRIP +if test -n "$STRIP"; then + { $as_echo "$as_me:$LINENO: result: $STRIP" >&5 +$as_echo "$STRIP" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_STRIP"; then + ac_ct_STRIP=$STRIP + # Extract the first word of "strip", so it can be a program name with args. +set dummy strip; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_STRIP"; then + ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_STRIP="strip" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP +if test -n "$ac_ct_STRIP"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5 +$as_echo "$ac_ct_STRIP" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_STRIP" = x; then + STRIP=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + STRIP=$ac_ct_STRIP + fi +else + STRIP="$ac_cv_prog_STRIP" +fi + +test -z "$STRIP" && STRIP=: + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. +set dummy ${ac_tool_prefix}ranlib; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_RANLIB+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$RANLIB"; then + ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +RANLIB=$ac_cv_prog_RANLIB +if test -n "$RANLIB"; then + { $as_echo "$as_me:$LINENO: result: $RANLIB" >&5 +$as_echo "$RANLIB" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_RANLIB"; then + ac_ct_RANLIB=$RANLIB + # Extract the first word of "ranlib", so it can be a program name with args. +set dummy ranlib; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_RANLIB+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_RANLIB"; then + ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_RANLIB="ranlib" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB +if test -n "$ac_ct_RANLIB"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_RANLIB" >&5 +$as_echo "$ac_ct_RANLIB" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_RANLIB" = x; then + RANLIB=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + RANLIB=$ac_ct_RANLIB + fi +else + RANLIB="$ac_cv_prog_RANLIB" +fi + +test -z "$RANLIB" && RANLIB=: + + + + + + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +if test -n "$RANLIB"; then + case $host_os in + openbsd*) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$oldlib" + ;; + *) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$oldlib" + ;; + esac + old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib" +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + +# Check for command to grab the raw symbol name followed by C symbol from nm. +{ $as_echo "$as_me:$LINENO: checking command to parse $NM output from $compiler object" >&5 +$as_echo_n "checking command to parse $NM output from $compiler object... " >&6; } +if test "${lt_cv_sys_global_symbol_pipe+set}" = set; then + $as_echo_n "(cached) " >&6 +else + +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[BCDEGRST]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([_A-Za-z][_A-Za-z0-9]*\)' + +# Define system-specific variables. +case $host_os in +aix*) + symcode='[BCDT]' + ;; +cygwin* | mingw* | pw32* | cegcc*) + symcode='[ABCDGISTW]' + ;; +hpux*) + if test "$host_cpu" = ia64; then + symcode='[ABCDEGRST]' + fi + ;; +irix* | nonstopux*) + symcode='[BCDEGRST]' + ;; +osf*) + symcode='[BCDEGQRST]' + ;; +solaris*) + symcode='[BDRT]' + ;; +sco3.2v5*) + symcode='[DT]' + ;; +sysv4.2uw2*) + symcode='[DT]' + ;; +sysv5* | sco5v6* | unixware* | OpenUNIX*) + symcode='[ABDT]' + ;; +sysv4) + symcode='[DFNSTU]' + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +case `$NM -V 2>&1` in +*GNU* | *'with BFD'*) + symcode='[ABCDGIRSTW]' ;; +esac + +# Transform an extracted symbol line into a proper C declaration. +# Some systems (esp. on ia64) link data and code symbols differently, +# so use this general approach. +lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" + +# Transform an extracted symbol line into symbol name and symbol address +lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([^ ]*\) $/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"\2\", (void *) \&\2},/p'" +lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([^ ]*\) $/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \(lib[^ ]*\)$/ {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"lib\2\", (void *) \&\2},/p'" + +# Handle CRLF in mingw tool chain +opt_cr= +case $build_os in +mingw*) + opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp + ;; +esac + +# Try without a prefix underscore, then with it. +for ac_symprfx in "" "_"; do + + # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. + symxfrm="\\1 $ac_symprfx\\2 \\2" + + # Write the raw and C identifiers. + if test "$lt_cv_nm_interface" = "MS dumpbin"; then + # Fake it for dumpbin and say T for any non-static function + # and D for any global variable. + # Also find C++ and __fastcall symbols from MSVC++, + # which start with @ or ?. + lt_cv_sys_global_symbol_pipe="$AWK '"\ +" {last_section=section; section=\$ 3};"\ +" /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ +" \$ 0!~/External *\|/{next};"\ +" / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ +" {if(hide[section]) next};"\ +" {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\ +" {split(\$ 0, a, /\||\r/); split(a[2], s)};"\ +" s[1]~/^[@?]/{print s[1], s[1]; next};"\ +" s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\ +" ' prfx=^$ac_symprfx" + else + lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" + fi + + # Check to see that the pipe works correctly. + pipe_works=no + + rm -f conftest* + cat > conftest.$ac_ext <<_LT_EOF +#ifdef __cplusplus +extern "C" { +#endif +char nm_test_var; +void nm_test_func(void); +void nm_test_func(void){} +#ifdef __cplusplus +} +#endif +int main(){nm_test_var='a';nm_test_func();return(0);} +_LT_EOF + + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # Now try to grab the symbols. + nlist=conftest.nm + if { (eval echo "$as_me:$LINENO: \"$NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist\"") >&5 + (eval $NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s "$nlist"; then + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if $GREP ' nm_test_var$' "$nlist" >/dev/null; then + if $GREP ' nm_test_func$' "$nlist" >/dev/null; then + cat <<_LT_EOF > conftest.$ac_ext +#ifdef __cplusplus +extern "C" { +#endif + +_LT_EOF + # Now generate the symbol file. + eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' + + cat <<_LT_EOF >> conftest.$ac_ext + +/* The mapping between symbol names and symbols. */ +const struct { + const char *name; + void *address; +} +lt__PROGRAM__LTX_preloaded_symbols[] = +{ + { "@PROGRAM@", (void *) 0 }, +_LT_EOF + $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext + cat <<\_LT_EOF >> conftest.$ac_ext + {0, (void *) 0} +}; + +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt__PROGRAM__LTX_preloaded_symbols; +} +#endif + +#ifdef __cplusplus +} +#endif +_LT_EOF + # Now try linking the two files. + mv conftest.$ac_objext conftstm.$ac_objext + lt_save_LIBS="$LIBS" + lt_save_CFLAGS="$CFLAGS" + LIBS="conftstm.$ac_objext" + CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext}; then + pipe_works=yes + fi + LIBS="$lt_save_LIBS" + CFLAGS="$lt_save_CFLAGS" + else + echo "cannot find nm_test_func in $nlist" >&5 + fi + else + echo "cannot find nm_test_var in $nlist" >&5 + fi + else + echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 + fi + else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + fi + rm -rf conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test "$pipe_works" = yes; then + break + else + lt_cv_sys_global_symbol_pipe= + fi +done + +fi + +if test -z "$lt_cv_sys_global_symbol_pipe"; then + lt_cv_sys_global_symbol_to_cdecl= +fi +if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then + { $as_echo "$as_me:$LINENO: result: failed" >&5 +$as_echo "failed" >&6; } +else + { $as_echo "$as_me:$LINENO: result: ok" >&5 +$as_echo "ok" >&6; } +fi + + + + + + + + + + + + + + + + + + + + + + +# Check whether --enable-libtool-lock was given. +if test "${enable_libtool_lock+set}" = set; then + enableval=$enable_libtool_lock; +fi + +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + +# Some flags need to be propagated to the compiler or linker for good +# libtool support. +case $host in +ia64-*-hpux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + case `/usr/bin/file conftest.$ac_objext` in + *ELF-32*) + HPUX_IA64_MODE="32" + ;; + *ELF-64*) + HPUX_IA64_MODE="64" + ;; + esac + fi + rm -rf conftest* + ;; +*-*-irix6*) + # Find out which ABI we are using. + echo '#line 5848 "configure"' > conftest.$ac_ext + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + if test "$lt_cv_prog_gnu_ld" = yes; then + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -melf32bsmip" + ;; + *N32*) + LD="${LD-ld} -melf32bmipn32" + ;; + *64-bit*) + LD="${LD-ld} -melf64bmip" + ;; + esac + else + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -32" + ;; + *N32*) + LD="${LD-ld} -n32" + ;; + *64-bit*) + LD="${LD-ld} -64" + ;; + esac + fi + fi + rm -rf conftest* + ;; + +x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \ +s390*-*linux*|s390*-*tpf*|sparc*-*linux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + case `/usr/bin/file conftest.o` in + *32-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_i386_fbsd" + ;; + x86_64-*linux*) + LD="${LD-ld} -m elf_i386" + ;; + ppc64-*linux*|powerpc64-*linux*) + LD="${LD-ld} -m elf32ppclinux" + ;; + s390x-*linux*) + LD="${LD-ld} -m elf_s390" + ;; + sparc64-*linux*) + LD="${LD-ld} -m elf32_sparc" + ;; + esac + ;; + *64-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_x86_64_fbsd" + ;; + x86_64-*linux*) + LD="${LD-ld} -m elf_x86_64" + ;; + ppc*-*linux*|powerpc*-*linux*) + LD="${LD-ld} -m elf64ppc" + ;; + s390*-*linux*|s390*-*tpf*) + LD="${LD-ld} -m elf64_s390" + ;; + sparc*-*linux*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; + +*-*-sco3.2v5*) + # On SCO OpenServer 5, we need -belf to get full-featured binaries. + SAVE_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -belf" + { $as_echo "$as_me:$LINENO: checking whether the C compiler needs -belf" >&5 +$as_echo_n "checking whether the C compiler needs -belf... " >&6; } +if test "${lt_cv_cc_needs_belf+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + lt_cv_cc_needs_belf=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + lt_cv_cc_needs_belf=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_cc_needs_belf" >&5 +$as_echo "$lt_cv_cc_needs_belf" >&6; } + if test x"$lt_cv_cc_needs_belf" != x"yes"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS="$SAVE_CFLAGS" + fi + ;; +sparc*-*solaris*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + case `/usr/bin/file conftest.o` in + *64-bit*) + case $lt_cv_prog_gnu_ld in + yes*) LD="${LD-ld} -m elf64_sparc" ;; + *) + if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then + LD="${LD-ld} -64" + fi + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; +esac + +need_locks="$enable_libtool_lock" + + + case $host_os in + rhapsody* | darwin*) + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. +set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_DSYMUTIL+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$DSYMUTIL"; then + ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +DSYMUTIL=$ac_cv_prog_DSYMUTIL +if test -n "$DSYMUTIL"; then + { $as_echo "$as_me:$LINENO: result: $DSYMUTIL" >&5 +$as_echo "$DSYMUTIL" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_DSYMUTIL"; then + ac_ct_DSYMUTIL=$DSYMUTIL + # Extract the first word of "dsymutil", so it can be a program name with args. +set dummy dsymutil; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_DSYMUTIL+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_DSYMUTIL"; then + ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL +if test -n "$ac_ct_DSYMUTIL"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_DSYMUTIL" >&5 +$as_echo "$ac_ct_DSYMUTIL" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_DSYMUTIL" = x; then + DSYMUTIL=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + DSYMUTIL=$ac_ct_DSYMUTIL + fi +else + DSYMUTIL="$ac_cv_prog_DSYMUTIL" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. +set dummy ${ac_tool_prefix}nmedit; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_NMEDIT+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$NMEDIT"; then + ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +NMEDIT=$ac_cv_prog_NMEDIT +if test -n "$NMEDIT"; then + { $as_echo "$as_me:$LINENO: result: $NMEDIT" >&5 +$as_echo "$NMEDIT" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_NMEDIT"; then + ac_ct_NMEDIT=$NMEDIT + # Extract the first word of "nmedit", so it can be a program name with args. +set dummy nmedit; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_NMEDIT+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_NMEDIT"; then + ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_NMEDIT="nmedit" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT +if test -n "$ac_ct_NMEDIT"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_NMEDIT" >&5 +$as_echo "$ac_ct_NMEDIT" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_NMEDIT" = x; then + NMEDIT=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + NMEDIT=$ac_ct_NMEDIT + fi +else + NMEDIT="$ac_cv_prog_NMEDIT" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args. +set dummy ${ac_tool_prefix}lipo; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_LIPO+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$LIPO"; then + ac_cv_prog_LIPO="$LIPO" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_LIPO="${ac_tool_prefix}lipo" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +LIPO=$ac_cv_prog_LIPO +if test -n "$LIPO"; then + { $as_echo "$as_me:$LINENO: result: $LIPO" >&5 +$as_echo "$LIPO" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_LIPO"; then + ac_ct_LIPO=$LIPO + # Extract the first word of "lipo", so it can be a program name with args. +set dummy lipo; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_LIPO+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_LIPO"; then + ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_LIPO="lipo" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO +if test -n "$ac_ct_LIPO"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_LIPO" >&5 +$as_echo "$ac_ct_LIPO" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_LIPO" = x; then + LIPO=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + LIPO=$ac_ct_LIPO + fi +else + LIPO="$ac_cv_prog_LIPO" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args. +set dummy ${ac_tool_prefix}otool; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_OTOOL+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$OTOOL"; then + ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_OTOOL="${ac_tool_prefix}otool" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +OTOOL=$ac_cv_prog_OTOOL +if test -n "$OTOOL"; then + { $as_echo "$as_me:$LINENO: result: $OTOOL" >&5 +$as_echo "$OTOOL" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_OTOOL"; then + ac_ct_OTOOL=$OTOOL + # Extract the first word of "otool", so it can be a program name with args. +set dummy otool; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_OTOOL+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OTOOL"; then + ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_OTOOL="otool" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL +if test -n "$ac_ct_OTOOL"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_OTOOL" >&5 +$as_echo "$ac_ct_OTOOL" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_OTOOL" = x; then + OTOOL=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OTOOL=$ac_ct_OTOOL + fi +else + OTOOL="$ac_cv_prog_OTOOL" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args. +set dummy ${ac_tool_prefix}otool64; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_OTOOL64+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$OTOOL64"; then + ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +OTOOL64=$ac_cv_prog_OTOOL64 +if test -n "$OTOOL64"; then + { $as_echo "$as_me:$LINENO: result: $OTOOL64" >&5 +$as_echo "$OTOOL64" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_OTOOL64"; then + ac_ct_OTOOL64=$OTOOL64 + # Extract the first word of "otool64", so it can be a program name with args. +set dummy otool64; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_OTOOL64+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OTOOL64"; then + ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_OTOOL64="otool64" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64 +if test -n "$ac_ct_OTOOL64"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_OTOOL64" >&5 +$as_echo "$ac_ct_OTOOL64" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_OTOOL64" = x; then + OTOOL64=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OTOOL64=$ac_ct_OTOOL64 + fi +else + OTOOL64="$ac_cv_prog_OTOOL64" +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:$LINENO: checking for -single_module linker flag" >&5 +$as_echo_n "checking for -single_module linker flag... " >&6; } +if test "${lt_cv_apple_cc_single_mod+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_apple_cc_single_mod=no + if test -z "${LT_MULTI_MODULE}"; then + # By default we will add the -single_module flag. You can override + # by either setting the environment variable LT_MULTI_MODULE + # non-empty at configure time, or by adding -multi_module to the + # link flags. + rm -rf libconftest.dylib* + echo "int foo(void){return 1;}" > conftest.c + echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ +-dynamiclib -Wl,-single_module conftest.c" >&5 + $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ + -dynamiclib -Wl,-single_module conftest.c 2>conftest.err + _lt_result=$? + if test -f libconftest.dylib && test ! -s conftest.err && test $_lt_result = 0; then + lt_cv_apple_cc_single_mod=yes + else + cat conftest.err >&5 + fi + rm -rf libconftest.dylib* + rm -f conftest.* + fi +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_apple_cc_single_mod" >&5 +$as_echo "$lt_cv_apple_cc_single_mod" >&6; } + { $as_echo "$as_me:$LINENO: checking for -exported_symbols_list linker flag" >&5 +$as_echo_n "checking for -exported_symbols_list linker flag... " >&6; } +if test "${lt_cv_ld_exported_symbols_list+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_ld_exported_symbols_list=no + save_LDFLAGS=$LDFLAGS + echo "_main" > conftest.sym + LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + lt_cv_ld_exported_symbols_list=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + lt_cv_ld_exported_symbols_list=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS="$save_LDFLAGS" + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_ld_exported_symbols_list" >&5 +$as_echo "$lt_cv_ld_exported_symbols_list" >&6; } + case $host_os in + rhapsody* | darwin1.[012]) + _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;; + darwin1.*) + _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; + darwin*) # darwin 5.x on + # if running on 10.5 or later, the deployment target defaults + # to the OS version, if on x86, and 10.4, the deployment + # target defaults to 10.4. Don't you love it? + case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in + 10.0,*86*-darwin8*|10.0,*-darwin[91]*) + _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; + 10.[012]*) + _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; + 10.*) + _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; + esac + ;; + esac + if test "$lt_cv_apple_cc_single_mod" = "yes"; then + _lt_dar_single_mod='$single_module' + fi + if test "$lt_cv_ld_exported_symbols_list" = "yes"; then + _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym' + else + _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}' + fi + if test "$DSYMUTIL" != ":"; then + _lt_dsymutil='~$DSYMUTIL $lib || :' + else + _lt_dsymutil= + fi + ;; + esac + + +for ac_header in dlfcn.h +do +as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +{ $as_echo "$as_me:$LINENO: checking for $ac_header" >&5 +$as_echo_n "checking for $ac_header... " >&6; } +if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default + +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + eval "$as_ac_Header=yes" +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + eval "$as_ac_Header=no" +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +ac_res=`eval 'as_val=${'$as_ac_Header'} + $as_echo "$as_val"'` + { $as_echo "$as_me:$LINENO: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +as_val=`eval 'as_val=${'$as_ac_Header'} + $as_echo "$as_val"'` + if test "x$as_val" = x""yes; then + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + +# Set options +enable_win32_dll=yes + +case $host in +*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-cegcc*) + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}as", so it can be a program name with args. +set dummy ${ac_tool_prefix}as; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_AS+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$AS"; then + ac_cv_prog_AS="$AS" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_AS="${ac_tool_prefix}as" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +AS=$ac_cv_prog_AS +if test -n "$AS"; then + { $as_echo "$as_me:$LINENO: result: $AS" >&5 +$as_echo "$AS" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_AS"; then + ac_ct_AS=$AS + # Extract the first word of "as", so it can be a program name with args. +set dummy as; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_AS+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_AS"; then + ac_cv_prog_ac_ct_AS="$ac_ct_AS" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_AS="as" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_AS=$ac_cv_prog_ac_ct_AS +if test -n "$ac_ct_AS"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_AS" >&5 +$as_echo "$ac_ct_AS" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_AS" = x; then + AS="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + AS=$ac_ct_AS + fi +else + AS="$ac_cv_prog_AS" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. +set dummy ${ac_tool_prefix}dlltool; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_DLLTOOL+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$DLLTOOL"; then + ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +DLLTOOL=$ac_cv_prog_DLLTOOL +if test -n "$DLLTOOL"; then + { $as_echo "$as_me:$LINENO: result: $DLLTOOL" >&5 +$as_echo "$DLLTOOL" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_DLLTOOL"; then + ac_ct_DLLTOOL=$DLLTOOL + # Extract the first word of "dlltool", so it can be a program name with args. +set dummy dlltool; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_DLLTOOL+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_DLLTOOL"; then + ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_DLLTOOL="dlltool" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL +if test -n "$ac_ct_DLLTOOL"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_DLLTOOL" >&5 +$as_echo "$ac_ct_DLLTOOL" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_DLLTOOL" = x; then + DLLTOOL="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + DLLTOOL=$ac_ct_DLLTOOL + fi +else + DLLTOOL="$ac_cv_prog_DLLTOOL" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. +set dummy ${ac_tool_prefix}objdump; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_OBJDUMP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$OBJDUMP"; then + ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +OBJDUMP=$ac_cv_prog_OBJDUMP +if test -n "$OBJDUMP"; then + { $as_echo "$as_me:$LINENO: result: $OBJDUMP" >&5 +$as_echo "$OBJDUMP" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_OBJDUMP"; then + ac_ct_OBJDUMP=$OBJDUMP + # Extract the first word of "objdump", so it can be a program name with args. +set dummy objdump; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OBJDUMP"; then + ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_OBJDUMP="objdump" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP +if test -n "$ac_ct_OBJDUMP"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_OBJDUMP" >&5 +$as_echo "$ac_ct_OBJDUMP" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_OBJDUMP" = x; then + OBJDUMP="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OBJDUMP=$ac_ct_OBJDUMP + fi +else + OBJDUMP="$ac_cv_prog_OBJDUMP" +fi + + ;; +esac + +test -z "$AS" && AS=as + + + + + +test -z "$DLLTOOL" && DLLTOOL=dlltool + + + + + +test -z "$OBJDUMP" && OBJDUMP=objdump + + + + + + + + enable_dlopen=no + + + + # Check whether --enable-shared was given. +if test "${enable_shared+set}" = set; then + enableval=$enable_shared; p=${PACKAGE-default} + case $enableval in + yes) enable_shared=yes ;; + no) enable_shared=no ;; + *) + enable_shared=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_shared=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac +else + enable_shared=yes +fi + + + + + + + + + + # Check whether --enable-static was given. +if test "${enable_static+set}" = set; then + enableval=$enable_static; p=${PACKAGE-default} + case $enableval in + yes) enable_static=yes ;; + no) enable_static=no ;; + *) + enable_static=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_static=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac +else + enable_static=yes +fi + + + + + + + + + + +# Check whether --with-pic was given. +if test "${with_pic+set}" = set; then + withval=$with_pic; pic_mode="$withval" +else + pic_mode=default +fi + + +test -z "$pic_mode" && pic_mode=default + + + + + + + + # Check whether --enable-fast-install was given. +if test "${enable_fast_install+set}" = set; then + enableval=$enable_fast_install; p=${PACKAGE-default} + case $enableval in + yes) enable_fast_install=yes ;; + no) enable_fast_install=no ;; + *) + enable_fast_install=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_fast_install=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac +else + enable_fast_install=yes +fi + + + + + + + + + + + +# This can be used to rebuild libtool when needed +LIBTOOL_DEPS="$ltmain" + +# Always use our own libtool. +LIBTOOL='$(SHELL) $(top_builddir)/libtool' + + + + + + + + + + + + + + + + + + + + + + + + + +test -z "$LN_S" && LN_S="ln -s" + + + + + + + + + + + + + + +if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST +fi + +{ $as_echo "$as_me:$LINENO: checking for objdir" >&5 +$as_echo_n "checking for objdir... " >&6; } +if test "${lt_cv_objdir+set}" = set; then + $as_echo_n "(cached) " >&6 +else + rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + lt_cv_objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + lt_cv_objdir=_libs +fi +rmdir .libs 2>/dev/null +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_objdir" >&5 +$as_echo "$lt_cv_objdir" >&6; } +objdir=$lt_cv_objdir + + + + + +cat >>confdefs.h <<_ACEOF +#define LT_OBJDIR "$lt_cv_objdir/" +_ACEOF + + + + + + + + + + + + + + + + + +case $host_os in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +sed_quote_subst='s/\(["`$\\]\)/\\\1/g' + +# Same as above, but do not quote variable references. +double_quote_subst='s/\(["`\\]\)/\\\1/g' + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# Sed substitution to delay expansion of an escaped single quote. +delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' + +# Sed substitution to avoid accidental globbing in evaled expressions +no_glob_subst='s/\*/\\\*/g' + +# Global variables: +ofile=libtool +can_build_shared=yes + +# All known linkers require a `.a' archive for static linking (except MSVC, +# which needs '.lib'). +libext=a + +with_gnu_ld="$lt_cv_prog_gnu_ld" + +old_CC="$CC" +old_CFLAGS="$CFLAGS" + +# Set sane defaults for various variables +test -z "$CC" && CC=cc +test -z "$LTCC" && LTCC=$CC +test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS +test -z "$LD" && LD=ld +test -z "$ac_objext" && ac_objext=o + +for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$ECHO "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + +# Only perform the check for file, if the check method requires it +test -z "$MAGIC_CMD" && MAGIC_CMD=file +case $deplibs_check_method in +file_magic*) + if test "$file_magic_cmd" = '$MAGIC_CMD'; then + { $as_echo "$as_me:$LINENO: checking for ${ac_tool_prefix}file" >&5 +$as_echo_n "checking for ${ac_tool_prefix}file... " >&6; } +if test "${lt_cv_path_MAGIC_CMD+set}" = set; then + $as_echo_n "(cached) " >&6 +else + case $MAGIC_CMD in +[\\/*] | ?:[\\/]*) + lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD="$MAGIC_CMD" + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" + for ac_dir in $ac_dummy; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/${ac_tool_prefix}file; then + lt_cv_path_MAGIC_CMD="$ac_dir/${ac_tool_prefix}file" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD="$lt_cv_path_MAGIC_CMD" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <<_LT_EOF 1>&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +_LT_EOF + fi ;; + esac + fi + break + fi + done + IFS="$lt_save_ifs" + MAGIC_CMD="$lt_save_MAGIC_CMD" + ;; +esac +fi + +MAGIC_CMD="$lt_cv_path_MAGIC_CMD" +if test -n "$MAGIC_CMD"; then + { $as_echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5 +$as_echo "$MAGIC_CMD" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + + + +if test -z "$lt_cv_path_MAGIC_CMD"; then + if test -n "$ac_tool_prefix"; then + { $as_echo "$as_me:$LINENO: checking for file" >&5 +$as_echo_n "checking for file... " >&6; } +if test "${lt_cv_path_MAGIC_CMD+set}" = set; then + $as_echo_n "(cached) " >&6 +else + case $MAGIC_CMD in +[\\/*] | ?:[\\/]*) + lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD="$MAGIC_CMD" + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" + for ac_dir in $ac_dummy; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/file; then + lt_cv_path_MAGIC_CMD="$ac_dir/file" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD="$lt_cv_path_MAGIC_CMD" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <<_LT_EOF 1>&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +_LT_EOF + fi ;; + esac + fi + break + fi + done + IFS="$lt_save_ifs" + MAGIC_CMD="$lt_save_MAGIC_CMD" + ;; +esac +fi + +MAGIC_CMD="$lt_cv_path_MAGIC_CMD" +if test -n "$MAGIC_CMD"; then + { $as_echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5 +$as_echo "$MAGIC_CMD" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + else + MAGIC_CMD=: + fi +fi + + fi + ;; +esac + +# Use C for the default configuration in the libtool script + +lt_save_CC="$CC" +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +# Source file extension for C test sources. +ac_ext=c + +# Object file extension for compiled C test sources. +objext=o +objext=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(){return(0);}' + + + + + + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC + +# Save the default compiler, since it gets overwritten when the other +# tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. +compiler_DEFAULT=$CC + +# save warnings/boilerplate of simple test code +ac_outfile=conftest.$ac_objext +echo "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$RM conftest* + +ac_outfile=conftest.$ac_objext +echo "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$RM -r conftest* + + +## CAVEAT EMPTOR: +## There is no encapsulation within the following macros, do not change +## the running order or otherwise move them around unless you know exactly +## what you are doing... +if test -n "$compiler"; then + +lt_prog_compiler_no_builtin_flag= + +if test "$GCC" = yes; then + lt_prog_compiler_no_builtin_flag=' -fno-builtin' + + { $as_echo "$as_me:$LINENO: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 +$as_echo_n "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; } +if test "${lt_cv_prog_compiler_rtti_exceptions+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_rtti_exceptions=no + ac_outfile=conftest.$ac_objext + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="-fno-rtti -fno-exceptions" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:7515: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:7519: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_rtti_exceptions=yes + fi + fi + $RM conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 +$as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; } + +if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then + lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" +else + : +fi + +fi + + + + + + + lt_prog_compiler_wl= +lt_prog_compiler_pic= +lt_prog_compiler_static= + +{ $as_echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 +$as_echo_n "checking for $compiler option to produce PIC... " >&6; } + + if test "$GCC" = yes; then + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_static='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static='-Bstatic' + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + lt_prog_compiler_pic='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + lt_prog_compiler_pic='-DDLL_EXPORT' + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic='-fno-common' + ;; + + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic='-fPIC' + ;; + esac + ;; + + interix[3-9]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + lt_prog_compiler_can_build_shared=no + enable_shared=no + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic='-fPIC -shared' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic=-Kconform_pic + fi + ;; + + *) + lt_prog_compiler_pic='-fPIC' + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + lt_prog_compiler_wl='-Wl,' + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static='-Bstatic' + else + lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' + fi + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic='-DDLL_EXPORT' + ;; + + hpux9* | hpux10* | hpux11*) + lt_prog_compiler_wl='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + lt_prog_compiler_static='${wl}-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + lt_prog_compiler_wl='-Wl,' + # PIC (with -KPIC) is the default. + lt_prog_compiler_static='-non_shared' + ;; + + linux* | k*bsd*-gnu) + case $cc_basename in + # old Intel for x86_64 which still supported -KPIC. + ecc*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-static' + ;; + # icc used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + icc* | ifort*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fPIC' + lt_prog_compiler_static='-static' + ;; + # Lahey Fortran 8.1. + lf95*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='--shared' + lt_prog_compiler_static='--static' + ;; + pgcc* | pgf77* | pgf90* | pgf95*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fpic' + lt_prog_compiler_static='-Bstatic' + ;; + ccc*) + lt_prog_compiler_wl='-Wl,' + # All Alpha code is PIC. + lt_prog_compiler_static='-non_shared' + ;; + xl*) + # IBM XL C 8.0/Fortran 10.1 on PPC + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-qpic' + lt_prog_compiler_static='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C 5.9 + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + lt_prog_compiler_wl='-Wl,' + ;; + *Sun\ F*) + # Sun Fortran 8.3 passes all unrecognized flags to the linker + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + lt_prog_compiler_wl='' + ;; + esac + ;; + esac + ;; + + newsos6) + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic='-fPIC -shared' + ;; + + osf3* | osf4* | osf5*) + lt_prog_compiler_wl='-Wl,' + # All OSF/1 code is PIC. + lt_prog_compiler_static='-non_shared' + ;; + + rdos*) + lt_prog_compiler_static='-non_shared' + ;; + + solaris*) + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + case $cc_basename in + f77* | f90* | f95*) + lt_prog_compiler_wl='-Qoption ld ';; + *) + lt_prog_compiler_wl='-Wl,';; + esac + ;; + + sunos4*) + lt_prog_compiler_wl='-Qoption ld ' + lt_prog_compiler_pic='-PIC' + lt_prog_compiler_static='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec ;then + lt_prog_compiler_pic='-Kconform_pic' + lt_prog_compiler_static='-Bstatic' + fi + ;; + + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + unicos*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_can_build_shared=no + ;; + + uts4*) + lt_prog_compiler_pic='-pic' + lt_prog_compiler_static='-Bstatic' + ;; + + *) + lt_prog_compiler_can_build_shared=no + ;; + esac + fi + +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic= + ;; + *) + lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" + ;; +esac +{ $as_echo "$as_me:$LINENO: result: $lt_prog_compiler_pic" >&5 +$as_echo "$lt_prog_compiler_pic" >&6; } + + + + + + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic"; then + { $as_echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 +$as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; } +if test "${lt_cv_prog_compiler_pic_works+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_pic_works=no + ac_outfile=conftest.$ac_objext + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic -DPIC" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:7854: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:7858: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_pic_works=yes + fi + fi + $RM conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_pic_works" >&5 +$as_echo "$lt_cv_prog_compiler_pic_works" >&6; } + +if test x"$lt_cv_prog_compiler_pic_works" = xyes; then + case $lt_prog_compiler_pic in + "" | " "*) ;; + *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; + esac +else + lt_prog_compiler_pic= + lt_prog_compiler_can_build_shared=no +fi + +fi + + + + + + +# +# Check to make sure the static flag actually works. +# +wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" +{ $as_echo "$as_me:$LINENO: checking if $compiler static flag $lt_tmp_static_flag works" >&5 +$as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } +if test "${lt_cv_prog_compiler_static_works+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_static_works=no + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS $lt_tmp_static_flag" + echo "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&5 + $ECHO "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_static_works=yes + fi + else + lt_cv_prog_compiler_static_works=yes + fi + fi + $RM -r conftest* + LDFLAGS="$save_LDFLAGS" + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_static_works" >&5 +$as_echo "$lt_cv_prog_compiler_static_works" >&6; } + +if test x"$lt_cv_prog_compiler_static_works" = xyes; then + : +else + lt_prog_compiler_static= +fi + + + + + + + + { $as_echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if test "${lt_cv_prog_compiler_c_o+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:7959: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:7963: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o" >&5 +$as_echo "$lt_cv_prog_compiler_c_o" >&6; } + + + + + + + { $as_echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if test "${lt_cv_prog_compiler_c_o+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:8014: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:8018: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o" >&5 +$as_echo "$lt_cv_prog_compiler_c_o" >&6; } + + + + +hard_links="nottested" +if test "$lt_cv_prog_compiler_c_o" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + { $as_echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 +$as_echo_n "checking if we can lock with hard links... " >&6; } + hard_links=yes + $RM conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + { $as_echo "$as_me:$LINENO: result: $hard_links" >&5 +$as_echo "$hard_links" >&6; } + if test "$hard_links" = no; then + { $as_echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 +$as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + + + + + + + { $as_echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +$as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } + + runpath_var= + allow_undefined_flag= + always_export_symbols=no + archive_cmds= + archive_expsym_cmds= + compiler_needs_object=no + enable_shared_with_static_runtimes=no + export_dynamic_flag_spec= + export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + hardcode_automatic=no + hardcode_direct=no + hardcode_direct_absolute=no + hardcode_libdir_flag_spec= + hardcode_libdir_flag_spec_ld= + hardcode_libdir_separator= + hardcode_minus_L=no + hardcode_shlibpath_var=unsupported + inherit_rpath=no + link_all_deplibs=unknown + module_cmds= + module_expsym_cmds= + old_archive_from_new_cmds= + old_archive_from_expsyms_cmds= + thread_safe_flag_spec= + whole_archive_flag_spec= + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + include_expsyms= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ` (' and `)$', so one must not match beginning or + # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', + # as well as any symbol that contains `d'. + exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + # Exclude shared library initialization/finalization symbols. + extract_expsyms_cmds= + + case $host_os in + cygwin* | mingw* | pw32* | cegcc*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + interix*) + # we just hope/assume this is gcc and not c89 (= MSVC++) + with_gnu_ld=yes + ;; + openbsd*) + with_gnu_ld=no + ;; + esac + + ld_shlibs=yes + if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + export_dynamic_flag_spec='${wl}--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + whole_archive_flag_spec= + fi + supports_anon_versioning=no + case `$LD -v 2>&1` in + *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix[3-9]*) + # On AIX/PPC, the GNU linker is very broken + if test "$host_cpu" != ia64; then + ld_shlibs=no + cat <<_LT_EOF 1>&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +_LT_EOF + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='' + ;; + m68k) + archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + ;; + esac + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + ld_shlibs=no + fi + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec='-L$libdir' + allow_undefined_flag=unsupported + always_export_symbols=no + enable_shared_with_static_runtimes=yes + export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + ld_shlibs=no + fi + ;; + + interix[3-9]*) + hardcode_direct=no + hardcode_shlibpath_var=no + hardcode_libdir_flag_spec='${wl}-rpath,$libdir' + export_dynamic_flag_spec='${wl}-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + archive_expsym_cmds='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + + gnu* | linux* | tpf* | k*bsd*-gnu) + tmp_diet=no + if test "$host_os" = linux-dietlibc; then + case $cc_basename in + diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) + esac + fi + if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ + && test "$tmp_diet" = no + then + tmp_addflag= + tmp_sharedflag='-shared' + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers + whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + lf95*) # Lahey Fortran 8.1 + whole_archive_flag_spec= + tmp_sharedflag='--shared' ;; + xl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) + tmp_sharedflag='-qmkshrobj' + tmp_addflag= ;; + esac + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) # Sun C 5.9 + whole_archive_flag_spec='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + compiler_needs_object=yes + tmp_sharedflag='-G' ;; + *Sun\ F*) # Sun Fortran 8.3 + tmp_sharedflag='-G' ;; + esac + archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + + if test "x$supports_anon_versioning" = xyes; then + archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + + case $cc_basename in + xlf*) + # IBM XL Fortran 10.1 on PPC cannot create shared libs itself + whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive' + hardcode_libdir_flag_spec= + hardcode_libdir_flag_spec_ld='-rpath $libdir' + archive_cmds='$LD -shared $libobjs $deplibs $compiler_flags -soname $soname -o $lib' + if test "x$supports_anon_versioning" = xyes; then + archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $LD -shared $libobjs $deplibs $compiler_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' + fi + ;; + esac + else + ld_shlibs=no + fi + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris*) + if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then + ld_shlibs=no + cat <<_LT_EOF 1>&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + + sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) + case `$LD -v 2>&1` in + *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) + ld_shlibs=no + cat <<_LT_EOF 1>&2 + +*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not +*** reliably create shared libraries on SCO systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.16.91.0.3 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + ;; + *) + # For security reasons, it is highly recommended that you always + # use absolute paths for naming shared libraries, and exclude the + # DT_RUNPATH tag from executables and libraries. But doing so + # requires that you compile everything twice, which is a pain. + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + esac + ;; + + sunos4*) + archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + *) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + esac + + if test "$ld_shlibs" = no; then + runpath_var= + hardcode_libdir_flag_spec= + export_dynamic_flag_spec= + whole_archive_flag_spec= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + allow_undefined_flag=unsupported + always_export_symbols=yes + archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + hardcode_minus_L=yes + if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + hardcode_direct=unsupported + fi + ;; + + aix[4-9]*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) + for ld_flag in $LDFLAGS; do + if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then + aix_use_runtimelinking=yes + break + fi + done + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds='' + hardcode_direct=yes + hardcode_direct_absolute=yes + hardcode_libdir_separator=':' + link_all_deplibs=yes + file_list_spec='${wl}-f,' + + if test "$GCC" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + hardcode_direct=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L=yes + hardcode_libdir_flag_spec='-L$libdir' + hardcode_libdir_separator= + fi + ;; + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + export_dynamic_flag_spec='${wl}-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + always_export_symbols=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + allow_undefined_flag='-berok' + # Determine the default libpath from the value encoded in an + # empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + +lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\(.*\)$/\1/ + p + } + }' +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then + aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +fi +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" + archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then $ECHO "X${wl}${allow_undefined_flag}" | $Xsed; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' + allow_undefined_flag="-z nodefs" + archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + +lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\(.*\)$/\1/ + p + } + }' +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then + aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +fi +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag=' ${wl}-bernotok' + allow_undefined_flag=' ${wl}-berok' + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec='$convenience' + archive_cmds_need_lc=yes + # This is similar to how AIX traditionally builds its shared libraries. + archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='' + ;; + m68k) + archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + ;; + esac + ;; + + bsdi[45]*) + export_dynamic_flag_spec=-rdynamic + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec=' ' + allow_undefined_flag=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=".dll" + # FIXME: Setting linknames here is a bad hack. + archive_cmds='$CC -o $lib $libobjs $compiler_flags `$ECHO "X$deplibs" | $Xsed -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + old_archive_from_new_cmds='true' + # FIXME: Should let the user specify the lib program. + old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' + fix_srcfile_path='`cygpath -w "$srcfile"`' + enable_shared_with_static_runtimes=yes + ;; + + darwin* | rhapsody*) + + + archive_cmds_need_lc=no + hardcode_direct=no + hardcode_automatic=yes + hardcode_shlibpath_var=unsupported + whole_archive_flag_spec='' + link_all_deplibs=yes + allow_undefined_flag="$_lt_dar_allow_undefined" + case $cc_basename in + ifort*) _lt_dar_can_shared=yes ;; + *) _lt_dar_can_shared=$GCC ;; + esac + if test "$_lt_dar_can_shared" = "yes"; then + output_verbose_link_cmd=echo + archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" + module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" + archive_expsym_cmds="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" + module_expsym_cmds="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" + + else + ld_shlibs=no + fi + + ;; + + dgux*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + freebsd1*) + ld_shlibs=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | dragonfly*) + archive_cmds='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + hpux9*) + if test "$GCC" = yes; then + archive_cmds='$RM $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + fi + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + export_dynamic_flag_spec='${wl}-E' + ;; + + hpux10*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + fi + if test "$with_gnu_ld" = no; then + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_flag_spec_ld='+b $libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + hardcode_direct_absolute=yes + export_dynamic_flag_spec='${wl}-E' + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + fi + ;; + + hpux11*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*) + archive_cmds='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*) + archive_cmds='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + fi + if test "$with_gnu_ld" = no; then + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_separator=: + + case $host_cpu in + hppa*64*|ia64*) + hardcode_direct=no + hardcode_shlibpath_var=no + ;; + *) + hardcode_direct=yes + hardcode_direct_absolute=yes + export_dynamic_flag_spec='${wl}-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test "$GCC" = yes; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + # Try to use the -exported_symbol ld option, if it does not + # work, assume that -exports_file does not work either and + # implicitly export all symbols. + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null" + cat >conftest.$ac_ext <<_ACEOF +int foo(void) {} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib' + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS="$save_LDFLAGS" + else + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib' + fi + archive_cmds_need_lc='no' + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + inherit_rpath=yes + link_all_deplibs=yes + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + newsos6) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + hardcode_shlibpath_var=no + ;; + + *nto* | *qnx*) + ;; + + openbsd*) + if test -f /usr/libexec/ld.so; then + hardcode_direct=yes + hardcode_shlibpath_var=no + hardcode_direct_absolute=yes + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' + hardcode_libdir_flag_spec='${wl}-rpath,$libdir' + export_dynamic_flag_spec='${wl}-E' + else + case $host_os in + openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-R$libdir' + ;; + *) + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec='${wl}-rpath,$libdir' + ;; + esac + fi + else + ld_shlibs=no + fi + ;; + + os2*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + allow_undefined_flag=unsupported + archive_cmds='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$ECHO DATA >> $output_objdir/$libname.def~$ECHO " SINGLE NONSHARED" >> $output_objdir/$libname.def~$ECHO EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' + old_archive_from_new_cmds='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' + ;; + + osf3*) + if test "$GCC" = yes; then + allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + fi + archive_cmds_need_lc='no' + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test "$GCC" = yes; then + allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ + $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp' + + # Both c and cxx compiler support -rpath directly + hardcode_libdir_flag_spec='-rpath $libdir' + fi + archive_cmds_need_lc='no' + hardcode_libdir_separator=: + ;; + + solaris*) + no_undefined_flag=' -z defs' + if test "$GCC" = yes; then + wlarc='${wl}' + archive_cmds='$CC -shared ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + else + case `$CC -V 2>&1` in + *"Compilers 5.0"*) + wlarc='' + archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' + ;; + *) + wlarc='${wl}' + archive_cmds='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + ;; + esac + fi + hardcode_libdir_flag_spec='-R$libdir' + hardcode_shlibpath_var=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands `-z linker_flag'. GCC discards it without `$wl', + # but is careful enough not to reorder. + # Supported since Solaris 2.6 (maybe 2.5.1?) + if test "$GCC" = yes; then + whole_archive_flag_spec='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' + else + whole_archive_flag_spec='-z allextract$convenience -z defaultextract' + fi + ;; + esac + link_all_deplibs=yes + ;; + + sunos4*) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + archive_cmds='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + hardcode_libdir_flag_spec='-L$libdir' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + sysv4) + case $host_vendor in + sni) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' + reload_cmds='$CC -r -o $output$reload_objs' + hardcode_direct=no + ;; + motorola) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var=no + ;; + + sysv4.3*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var=no + export_dynamic_flag_spec='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ld_shlibs=yes + fi + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) + no_undefined_flag='${wl}-z,text' + archive_cmds_need_lc=no + hardcode_shlibpath_var=no + runpath_var='LD_RUN_PATH' + + if test "$GCC" = yes; then + archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We can NOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + no_undefined_flag='${wl}-z,text' + allow_undefined_flag='${wl}-z,nodefs' + archive_cmds_need_lc=no + hardcode_shlibpath_var=no + hardcode_libdir_flag_spec='${wl}-R,$libdir' + hardcode_libdir_separator=':' + link_all_deplibs=yes + export_dynamic_flag_spec='${wl}-Bexport' + runpath_var='LD_RUN_PATH' + + if test "$GCC" = yes; then + archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + uts4*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + *) + ld_shlibs=no + ;; + esac + + if test x$host_vendor = xsni; then + case $host in + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + export_dynamic_flag_spec='${wl}-Blargedynsym' + ;; + esac + fi + fi + +{ $as_echo "$as_me:$LINENO: result: $ld_shlibs" >&5 +$as_echo "$ld_shlibs" >&6; } +test "$ld_shlibs" = no && can_build_shared=no + +with_gnu_ld=$with_gnu_ld + + + + + + + + + + + + + + + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $archive_cmds in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + { $as_echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 +$as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } + $RM conftest* + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl + pic_flag=$lt_prog_compiler_pic + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag + allow_undefined_flag= + if { (eval echo "$as_me:$LINENO: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\"") >&5 + (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + then + archive_cmds_need_lc=no + else + archive_cmds_need_lc=yes + fi + allow_undefined_flag=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $RM conftest* + { $as_echo "$as_me:$LINENO: result: $archive_cmds_need_lc" >&5 +$as_echo "$archive_cmds_need_lc" >&6; } + ;; + esac + fi + ;; +esac + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 +$as_echo_n "checking dynamic linker characteristics... " >&6; } + +if test "$GCC" = yes; then + case $host_os in + darwin*) lt_awk_arg="/^libraries:/,/LR/" ;; + *) lt_awk_arg="/^libraries:/" ;; + esac + lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if $ECHO "$lt_search_path_spec" | $GREP ';' >/dev/null ; then + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED -e 's/;/ /g'` + else + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + # Ok, now we have the path, separated by spaces, we can step through it + # and add multilib dir if necessary. + lt_tmp_lt_search_path_spec= + lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` + for lt_sys_path in $lt_search_path_spec; do + if test -d "$lt_sys_path/$lt_multi_os_dir"; then + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir" + else + test -d "$lt_sys_path" && \ + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" + fi + done + lt_search_path_spec=`$ECHO $lt_tmp_lt_search_path_spec | awk ' +BEGIN {RS=" "; FS="/|\n";} { + lt_foo=""; + lt_count=0; + for (lt_i = NF; lt_i > 0; lt_i--) { + if ($lt_i != "" && $lt_i != ".") { + if ($lt_i == "..") { + lt_count++; + } else { + if (lt_count == 0) { + lt_foo="/" $lt_i lt_foo; + } else { + lt_count--; + } + } + } + } + if (lt_foo != "") { lt_freq[lt_foo]++; } + if (lt_freq[lt_foo] == 1) { print lt_foo; } +}'` + sys_lib_search_path_spec=`$ECHO $lt_search_path_spec` +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix[4-9]*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + case $host_cpu in + powerpc) + # Since July 2007 AmigaOS4 officially supports .so libraries. + # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + ;; + m68k) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$ECHO "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + esac + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32* | cegcc*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32* | yes,cegcc*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + #soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + soname_spec='`echo ${libname} | sed -e 's/^lib//'`${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw* | cegcc*) + # MinGW DLLs use traditional 'lib' prefix + #soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + soname_spec='`echo ${libname} | $SED -e 's/^lib//'`${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | $GREP "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + + sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[123]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ + freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + *) # from 4.6 on, and DragonFly + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +interix[3-9]*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux* | k*bsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # Some binutils ld are patched to set DT_RUNPATH + save_LDFLAGS=$LDFLAGS + save_libdir=$libdir + eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \ + LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\"" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then + shlibpath_overrides_runpath=yes +fi + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS=$save_LDFLAGS + libdir=$save_libdir + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +*nto* | *qnx*) + version_type=qnx + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='ldqnx.so' + ;; + +openbsd*) + version_type=sunos + sys_lib_dlsearch_path_spec="/usr/lib" + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[89] | openbsd2.[89].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +rdos*) + dynamic_linker=no + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + version_type=freebsd-elf + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + if test "$with_gnu_ld" = yes; then + sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' + else + sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' + case $host_os in + sco3.2v5*) + sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" + ;; + esac + fi + sys_lib_dlsearch_path_spec='/usr/lib' + ;; + +tpf*) + # TPF is a cross-target only. Preferred cross-host = GNU/Linux. + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +{ $as_echo "$as_me:$LINENO: result: $dynamic_linker" >&5 +$as_echo "$dynamic_linker" >&6; } +test "$dynamic_linker" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then + sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" +fi +if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then + sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 +$as_echo_n "checking how to hardcode library paths into programs... " >&6; } +hardcode_action= +if test -n "$hardcode_libdir_flag_spec" || + test -n "$runpath_var" || + test "X$hardcode_automatic" = "Xyes" ; then + + # We can hardcode non-existent directories. + if test "$hardcode_direct" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_TAGVAR(hardcode_shlibpath_var, )" != no && + test "$hardcode_minus_L" != no; then + # Linking always hardcodes the temporary library directory. + hardcode_action=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action=unsupported +fi +{ $as_echo "$as_me:$LINENO: result: $hardcode_action" >&5 +$as_echo "$hardcode_action" >&6; } + +if test "$hardcode_action" = relink || + test "$inherit_rpath" = yes; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi + + + + + + + if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32* | cegcc*) + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen="dlopen" + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + { $as_echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +$as_echo_n "checking for dlopen in -ldl... " >&6; } +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_dl_dlopen=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_dl_dlopen=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +$as_echo "$ac_cv_lib_dl_dlopen" >&6; } +if test "x$ac_cv_lib_dl_dlopen" = x""yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + + lt_cv_dlopen="dyld" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + +fi + + ;; + + *) + { $as_echo "$as_me:$LINENO: checking for shl_load" >&5 +$as_echo_n "checking for shl_load... " >&6; } +if test "${ac_cv_func_shl_load+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define shl_load to an innocuous variant, in case declares shl_load. + For example, HP-UX 11i declares gettimeofday. */ +#define shl_load innocuous_shl_load + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char shl_load (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef shl_load + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char shl_load (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_shl_load || defined __stub___shl_load +choke me +#endif + +int +main () +{ +return shl_load (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_func_shl_load=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_func_shl_load=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_shl_load" >&5 +$as_echo "$ac_cv_func_shl_load" >&6; } +if test "x$ac_cv_func_shl_load" = x""yes; then + lt_cv_dlopen="shl_load" +else + { $as_echo "$as_me:$LINENO: checking for shl_load in -ldld" >&5 +$as_echo_n "checking for shl_load in -ldld... " >&6; } +if test "${ac_cv_lib_dld_shl_load+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char shl_load (); +int +main () +{ +return shl_load (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_dld_shl_load=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_dld_shl_load=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dld_shl_load" >&5 +$as_echo "$ac_cv_lib_dld_shl_load" >&6; } +if test "x$ac_cv_lib_dld_shl_load" = x""yes; then + lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld" +else + { $as_echo "$as_me:$LINENO: checking for dlopen" >&5 +$as_echo_n "checking for dlopen... " >&6; } +if test "${ac_cv_func_dlopen+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define dlopen to an innocuous variant, in case declares dlopen. + For example, HP-UX 11i declares gettimeofday. */ +#define dlopen innocuous_dlopen + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char dlopen (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef dlopen + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_dlopen || defined __stub___dlopen +choke me +#endif + +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_func_dlopen=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_func_dlopen=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_dlopen" >&5 +$as_echo "$ac_cv_func_dlopen" >&6; } +if test "x$ac_cv_func_dlopen" = x""yes; then + lt_cv_dlopen="dlopen" +else + { $as_echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +$as_echo_n "checking for dlopen in -ldl... " >&6; } +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_dl_dlopen=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_dl_dlopen=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +$as_echo "$ac_cv_lib_dl_dlopen" >&6; } +if test "x$ac_cv_lib_dl_dlopen" = x""yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + { $as_echo "$as_me:$LINENO: checking for dlopen in -lsvld" >&5 +$as_echo_n "checking for dlopen in -lsvld... " >&6; } +if test "${ac_cv_lib_svld_dlopen+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lsvld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_svld_dlopen=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_svld_dlopen=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_svld_dlopen" >&5 +$as_echo "$ac_cv_lib_svld_dlopen" >&6; } +if test "x$ac_cv_lib_svld_dlopen" = x""yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld" +else + { $as_echo "$as_me:$LINENO: checking for dld_link in -ldld" >&5 +$as_echo_n "checking for dld_link in -ldld... " >&6; } +if test "${ac_cv_lib_dld_dld_link+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dld_link (); +int +main () +{ +return dld_link (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_dld_dld_link=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_dld_dld_link=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dld_dld_link" >&5 +$as_echo "$ac_cv_lib_dld_dld_link" >&6; } +if test "x$ac_cv_lib_dld_dld_link" = x""yes; then + lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld" +fi + + +fi + + +fi + + +fi + + +fi + + +fi + + ;; + esac + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + else + enable_dlopen=no + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS="$CPPFLAGS" + test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS="$LDFLAGS" + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS="$LIBS" + LIBS="$lt_cv_dlopen_libs $LIBS" + + { $as_echo "$as_me:$LINENO: checking whether a program can dlopen itself" >&5 +$as_echo_n "checking whether a program can dlopen itself... " >&6; } +if test "${lt_cv_dlopen_self+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +#line 10816 "configure" +#include "confdefs.h" + +#if HAVE_DLFCN_H +#include +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + else + puts (dlerror ()); + + return status; +} +_LT_EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; + x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self=no + fi +fi +rm -fr conftest* + + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_dlopen_self" >&5 +$as_echo "$lt_cv_dlopen_self" >&6; } + + if test "x$lt_cv_dlopen_self" = xyes; then + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" + { $as_echo "$as_me:$LINENO: checking whether a statically linked program can dlopen itself" >&5 +$as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; } +if test "${lt_cv_dlopen_self_static+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self_static=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +#line 10912 "configure" +#include "confdefs.h" + +#if HAVE_DLFCN_H +#include +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + else + puts (dlerror ()); + + return status; +} +_LT_EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self_static=no + fi +fi +rm -fr conftest* + + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_dlopen_self_static" >&5 +$as_echo "$lt_cv_dlopen_self_static" >&6; } + fi + + CPPFLAGS="$save_CPPFLAGS" + LDFLAGS="$save_LDFLAGS" + LIBS="$save_LIBS" + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi + + + + + + + + + + + + + + + + + +striplib= +old_striplib= +{ $as_echo "$as_me:$LINENO: checking whether stripping libraries is possible" >&5 +$as_echo_n "checking whether stripping libraries is possible... " >&6; } +if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + { $as_echo "$as_me:$LINENO: result: yes" >&5 +$as_echo "yes" >&6; } +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + old_striplib="$STRIP -S" + { $as_echo "$as_me:$LINENO: result: yes" >&5 +$as_echo "yes" >&6; } + else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } + fi + ;; + *) + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } + ;; + esac +fi + + + + + + + + + + + + + # Report which library types will actually be built + { $as_echo "$as_me:$LINENO: checking if libtool supports shared libraries" >&5 +$as_echo_n "checking if libtool supports shared libraries... " >&6; } + { $as_echo "$as_me:$LINENO: result: $can_build_shared" >&5 +$as_echo "$can_build_shared" >&6; } + + { $as_echo "$as_me:$LINENO: checking whether to build shared libraries" >&5 +$as_echo_n "checking whether to build shared libraries... " >&6; } + test "$can_build_shared" = "no" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + + aix[4-9]*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; + esac + { $as_echo "$as_me:$LINENO: result: $enable_shared" >&5 +$as_echo "$enable_shared" >&6; } + + { $as_echo "$as_me:$LINENO: checking whether to build static libraries" >&5 +$as_echo_n "checking whether to build static libraries... " >&6; } + # Make sure either enable_shared or enable_static is yes. + test "$enable_shared" = yes || enable_static=yes + { $as_echo "$as_me:$LINENO: result: $enable_static" >&5 +$as_echo "$enable_static" >&6; } + + + + +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +CC="$lt_save_CC" + + + + + + + + + + + + + + ac_config_commands="$ac_config_commands libtool" + + + + +# Only expand once: + + + +LT_RELEASE=$SDL_MAJOR_VERSION.$SDL_MINOR_VERSION +LT_CURRENT=`expr $SDL_MICRO_VERSION - $SDL_INTERFACE_AGE` +LT_REVISION=$SDL_INTERFACE_AGE +LT_AGE=`expr $SDL_BINARY_AGE - $SDL_INTERFACE_AGE` + + + + + + + +ac_aux_dir= +for ac_dir in build-scripts "$srcdir"/build-scripts; do + if test -f "$ac_dir/install-sh"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install-sh -c" + break + elif test -f "$ac_dir/install.sh"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install.sh -c" + break + elif test -f "$ac_dir/shtool"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/shtool install -c" + break + fi +done +if test -z "$ac_aux_dir"; then + { { $as_echo "$as_me:$LINENO: error: cannot find install-sh or install.sh in build-scripts \"$srcdir\"/build-scripts" >&5 +$as_echo "$as_me: error: cannot find install-sh or install.sh in build-scripts \"$srcdir\"/build-scripts" >&2;} + { (exit 1); exit 1; }; } +fi + +# These three variables are undocumented and unsupported, +# and are intended to be withdrawn in a future Autoconf release. +# They can cause serious problems if a builder's source tree is in a directory +# whose full name contains unusual characters. +ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. +ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. +ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. + + + + { $as_echo "$as_me:$LINENO: checking whether byte ordering is bigendian" >&5 +$as_echo_n "checking whether byte ordering is bigendian... " >&6; } +if test "${ac_cv_c_bigendian+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_cv_c_bigendian=unknown + # See if we're dealing with a universal compiler. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifndef __APPLE_CC__ + not a universal capable compiler + #endif + typedef int dummy; + +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + + # Check for potential -arch flags. It is not universal unless + # there are some -arch flags. Note that *ppc* also matches + # ppc64. This check is also rather less than ideal. + case "${CC} ${CFLAGS} ${CPPFLAGS} ${LDFLAGS}" in #( + *-arch*ppc*|*-arch*i386*|*-arch*x86_64*) ac_cv_c_bigendian=universal;; + esac +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + if test $ac_cv_c_bigendian = unknown; then + # See if sys/param.h defines the BYTE_ORDER macro. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + #include + +int +main () +{ +#if ! (defined BYTE_ORDER && defined BIG_ENDIAN \ + && defined LITTLE_ENDIAN && BYTE_ORDER && BIG_ENDIAN \ + && LITTLE_ENDIAN) + bogus endian macros + #endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + # It does; now see whether it defined to BIG_ENDIAN or not. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + #include + +int +main () +{ +#if BYTE_ORDER != BIG_ENDIAN + not big endian + #endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_c_bigendian=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_c_bigendian=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + fi + if test $ac_cv_c_bigendian = unknown; then + # See if defines _LITTLE_ENDIAN or _BIG_ENDIAN (e.g., Solaris). + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +int +main () +{ +#if ! (defined _LITTLE_ENDIAN || defined _BIG_ENDIAN) + bogus endian macros + #endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + # It does; now see whether it defined to _BIG_ENDIAN or not. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +int +main () +{ +#ifndef _BIG_ENDIAN + not big endian + #endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_c_bigendian=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_c_bigendian=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + fi + if test $ac_cv_c_bigendian = unknown; then + # Compile a test program. + if test "$cross_compiling" = yes; then + # Try to guess by grepping values from an object file. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +short int ascii_mm[] = + { 0x4249, 0x4765, 0x6E44, 0x6961, 0x6E53, 0x7953, 0 }; + short int ascii_ii[] = + { 0x694C, 0x5454, 0x656C, 0x6E45, 0x6944, 0x6E61, 0 }; + int use_ascii (int i) { + return ascii_mm[i] + ascii_ii[i]; + } + short int ebcdic_ii[] = + { 0x89D3, 0xE3E3, 0x8593, 0x95C5, 0x89C4, 0x9581, 0 }; + short int ebcdic_mm[] = + { 0xC2C9, 0xC785, 0x95C4, 0x8981, 0x95E2, 0xA8E2, 0 }; + int use_ebcdic (int i) { + return ebcdic_mm[i] + ebcdic_ii[i]; + } + extern int foo; + +int +main () +{ +return use_ascii (foo) == use_ebcdic (foo); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + if grep BIGenDianSyS conftest.$ac_objext >/dev/null; then + ac_cv_c_bigendian=yes + fi + if grep LiTTleEnDian conftest.$ac_objext >/dev/null ; then + if test "$ac_cv_c_bigendian" = unknown; then + ac_cv_c_bigendian=no + else + # finding both strings is unlikely to happen, but who knows? + ac_cv_c_bigendian=unknown + fi + fi +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ + + /* Are we little or big endian? From Harbison&Steele. */ + union + { + long int l; + char c[sizeof (long int)]; + } u; + u.l = 1; + return u.c[sizeof (long int) - 1] == 1; + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_c_bigendian=no +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_c_bigendian=yes +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + + + fi +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_bigendian" >&5 +$as_echo "$ac_cv_c_bigendian" >&6; } + case $ac_cv_c_bigendian in #( + yes) + cat >>confdefs.h <<\_ACEOF +#define WORDS_BIGENDIAN 1 +_ACEOF +;; #( + no) + ;; #( + universal) + +cat >>confdefs.h <<\_ACEOF +#define AC_APPLE_UNIVERSAL_BUILD 1 +_ACEOF + + ;; #( + *) + { { $as_echo "$as_me:$LINENO: error: unknown endianness + presetting ac_cv_c_bigendian=no (or yes) will help" >&5 +$as_echo "$as_me: error: unknown endianness + presetting ac_cv_c_bigendian=no (or yes) will help" >&2;} + { (exit 1); exit 1; }; } ;; + esac + +if test x$ac_cv_c_bigendian = xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_BYTEORDER 4321 +_ACEOF + +else + cat >>confdefs.h <<\_ACEOF +#define SDL_BYTEORDER 1234 +_ACEOF + +fi + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. +set dummy ${ac_tool_prefix}gcc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}gcc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="gcc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +else + CC="$ac_cv_prog_CC" +fi + +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. +set dummy ${ac_tool_prefix}cc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}cc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + fi +fi +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + ac_prog_rejected=no +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# != 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" + fi +fi +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + for ac_prog in cl.exe + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:$LINENO: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CC" && break + done +fi +if test -z "$CC"; then + ac_ct_CC=$CC + for ac_prog in cl.exe +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CC" && break +done + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +fi + +fi + + +test -z "$CC" && { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: no acceptable C compiler found in \$PATH +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: no acceptable C compiler found in \$PATH +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; }; } + +# Provide some information about the compiler. +$as_echo "$as_me:$LINENO: checking for C compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +{ (ac_try="$ac_compiler --version >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler --version >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -v >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -v >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -V >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -V >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + +{ $as_echo "$as_me:$LINENO: checking whether we are using the GNU C compiler" >&5 +$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } +if test "${ac_cv_c_compiler_gnu+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_compiler_gnu=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_compiler_gnu=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_c_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_compiler_gnu" >&5 +$as_echo "$ac_cv_c_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GCC=yes +else + GCC= +fi +ac_test_CFLAGS=${CFLAGS+set} +ac_save_CFLAGS=$CFLAGS +{ $as_echo "$as_me:$LINENO: checking whether $CC accepts -g" >&5 +$as_echo_n "checking whether $CC accepts -g... " >&6; } +if test "${ac_cv_prog_cc_g+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_save_c_werror_flag=$ac_c_werror_flag + ac_c_werror_flag=yes + ac_cv_prog_cc_g=no + CFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cc_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + CFLAGS="" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_c_werror_flag=$ac_save_c_werror_flag + CFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cc_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_c_werror_flag=$ac_save_c_werror_flag +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cc_g" >&5 +$as_echo "$ac_cv_prog_cc_g" >&6; } +if test "$ac_test_CFLAGS" = set; then + CFLAGS=$ac_save_CFLAGS +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi +{ $as_echo "$as_me:$LINENO: checking for $CC option to accept ISO C89" >&5 +$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } +if test "${ac_cv_prog_cc_c89+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_cv_prog_cc_c89=no +ac_save_CC=$CC +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#include +#include +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ +struct buf { int x; }; +FILE * (*rcsopen) (struct buf *, struct stat *, int); +static char *e (p, i) + char **p; + int i; +{ + return p[i]; +} +static char *f (char * (*g) (char **, int), char **p, ...) +{ + char *s; + va_list v; + va_start (v,p); + s = g (p, va_arg (v,int)); + va_end (v); + return s; +} + +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has + function prototypes and stuff, but not '\xHH' hex character constants. + These don't provoke an error unfortunately, instead are silently treated + as 'x'. The following induces an error, until -std is added to get + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an + array size at least. It's necessary to write '\x00'==0 to get something + that's true only with -std. */ +int osf4_cc_array ['\x00' == 0 ? 1 : -1]; + +/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters + inside strings and character constants. */ +#define FOO(x) 'x' +int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; + +int test (int i, double x); +struct s1 {int (*f) (int a);}; +struct s2 {int (*f) (double a);}; +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); +int argc; +char **argv; +int +main () +{ +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; + ; + return 0; +} +_ACEOF +for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ + -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" +do + CC="$ac_save_CC $ac_arg" + rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cc_c89=$ac_arg +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext + test "x$ac_cv_prog_cc_c89" != "xno" && break +done +rm -f conftest.$ac_ext +CC=$ac_save_CC + +fi +# AC_CACHE_VAL +case "x$ac_cv_prog_cc_c89" in + x) + { $as_echo "$as_me:$LINENO: result: none needed" >&5 +$as_echo "none needed" >&6; } ;; + xno) + { $as_echo "$as_me:$LINENO: result: unsupported" >&5 +$as_echo "unsupported" >&6; } ;; + *) + CC="$CC $ac_cv_prog_cc_c89" + { $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cc_c89" >&5 +$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; +esac + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +if test -z "$CXX"; then + if test -n "$CCC"; then + CXX=$CCC + else + if test -n "$ac_tool_prefix"; then + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CXX"; then + ac_cv_prog_CXX="$CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CXX=$ac_cv_prog_CXX +if test -n "$CXX"; then + { $as_echo "$as_me:$LINENO: result: $CXX" >&5 +$as_echo "$CXX" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CXX" && break + done +fi +if test -z "$CXX"; then + ac_ct_CXX=$CXX + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CXX"; then + ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CXX="$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_CXX=$ac_cv_prog_ac_ct_CXX +if test -n "$ac_ct_CXX"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_CXX" >&5 +$as_echo "$ac_ct_CXX" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CXX" && break +done + + if test "x$ac_ct_CXX" = x; then + CXX="g++" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CXX=$ac_ct_CXX + fi +fi + + fi +fi +# Provide some information about the compiler. +$as_echo "$as_me:$LINENO: checking for C++ compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +{ (ac_try="$ac_compiler --version >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler --version >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -v >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -v >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -V >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -V >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + +{ $as_echo "$as_me:$LINENO: checking whether we are using the GNU C++ compiler" >&5 +$as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } +if test "${ac_cv_cxx_compiler_gnu+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_compiler_gnu=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_compiler_gnu=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_cxx_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_cxx_compiler_gnu" >&5 +$as_echo "$ac_cv_cxx_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GXX=yes +else + GXX= +fi +ac_test_CXXFLAGS=${CXXFLAGS+set} +ac_save_CXXFLAGS=$CXXFLAGS +{ $as_echo "$as_me:$LINENO: checking whether $CXX accepts -g" >&5 +$as_echo_n "checking whether $CXX accepts -g... " >&6; } +if test "${ac_cv_prog_cxx_g+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_save_cxx_werror_flag=$ac_cxx_werror_flag + ac_cxx_werror_flag=yes + ac_cv_prog_cxx_g=no + CXXFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cxx_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + CXXFLAGS="" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cxx_werror_flag=$ac_save_cxx_werror_flag + CXXFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cxx_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_cxx_werror_flag=$ac_save_cxx_werror_flag +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cxx_g" >&5 +$as_echo "$ac_cv_prog_cxx_g" >&6; } +if test "$ac_test_CXXFLAGS" = set; then + CXXFLAGS=$ac_save_CXXFLAGS +elif test $ac_cv_prog_cxx_g = yes; then + if test "$GXX" = yes; then + CXXFLAGS="-g -O2" + else + CXXFLAGS="-g" + fi +else + if test "$GXX" = yes; then + CXXFLAGS="-O2" + else + CXXFLAGS= + fi +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +if test -z "$CXX"; then + if test -n "$CCC"; then + CXX=$CCC + else + if test -n "$ac_tool_prefix"; then + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$CXX"; then + ac_cv_prog_CXX="$CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +CXX=$ac_cv_prog_CXX +if test -n "$CXX"; then + { $as_echo "$as_me:$LINENO: result: $CXX" >&5 +$as_echo "$CXX" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CXX" && break + done +fi +if test -z "$CXX"; then + ac_ct_CXX=$CXX + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CXX"; then + ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CXX="$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +ac_ct_CXX=$ac_cv_prog_ac_ct_CXX +if test -n "$ac_ct_CXX"; then + { $as_echo "$as_me:$LINENO: result: $ac_ct_CXX" >&5 +$as_echo "$ac_ct_CXX" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CXX" && break +done + + if test "x$ac_ct_CXX" = x; then + CXX="g++" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CXX=$ac_ct_CXX + fi +fi + + fi +fi +# Provide some information about the compiler. +$as_echo "$as_me:$LINENO: checking for C++ compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +{ (ac_try="$ac_compiler --version >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler --version >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -v >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -v >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (ac_try="$ac_compiler -V >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compiler -V >&5") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + +{ $as_echo "$as_me:$LINENO: checking whether we are using the GNU C++ compiler" >&5 +$as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } +if test "${ac_cv_cxx_compiler_gnu+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_compiler_gnu=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_compiler_gnu=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_cxx_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_cxx_compiler_gnu" >&5 +$as_echo "$ac_cv_cxx_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GXX=yes +else + GXX= +fi +ac_test_CXXFLAGS=${CXXFLAGS+set} +ac_save_CXXFLAGS=$CXXFLAGS +{ $as_echo "$as_me:$LINENO: checking whether $CXX accepts -g" >&5 +$as_echo_n "checking whether $CXX accepts -g... " >&6; } +if test "${ac_cv_prog_cxx_g+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_save_cxx_werror_flag=$ac_cxx_werror_flag + ac_cxx_werror_flag=yes + ac_cv_prog_cxx_g=no + CXXFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cxx_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + CXXFLAGS="" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cxx_werror_flag=$ac_save_cxx_werror_flag + CXXFLAGS="-g" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_prog_cxx_g=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_cxx_werror_flag=$ac_save_cxx_werror_flag +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cxx_g" >&5 +$as_echo "$ac_cv_prog_cxx_g" >&6; } +if test "$ac_test_CXXFLAGS" = set; then + CXXFLAGS=$ac_save_CXXFLAGS +elif test $ac_cv_prog_cxx_g = yes; then + if test "$GXX" = yes; then + CXXFLAGS="-g -O2" + else + CXXFLAGS="-g" + fi +else + if test "$GXX" = yes; then + CXXFLAGS="-O2" + else + CXXFLAGS= + fi +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +if test -n "$CXX" && ( test "X$CXX" != "Xno" && + ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || + (test "X$CXX" != "Xg++"))) ; then + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +{ $as_echo "$as_me:$LINENO: checking how to run the C++ preprocessor" >&5 +$as_echo_n "checking how to run the C++ preprocessor... " >&6; } +if test -z "$CXXCPP"; then + if test "${ac_cv_prog_CXXCPP+set}" = set; then + $as_echo_n "(cached) " >&6 +else + # Double quotes because CXXCPP needs to be expanded + for CXXCPP in "$CXX -E" "/lib/cpp" + do + ac_preproc_ok=false +for ac_cxx_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || + test ! -s conftest.err + }; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi + +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || + test ! -s conftest.err + }; then + # Broken: success on invalid input. +continue +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi + +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + break +fi + + done + ac_cv_prog_CXXCPP=$CXXCPP + +fi + CXXCPP=$ac_cv_prog_CXXCPP +else + ac_cv_prog_CXXCPP=$CXXCPP +fi +{ $as_echo "$as_me:$LINENO: result: $CXXCPP" >&5 +$as_echo "$CXXCPP" >&6; } +ac_preproc_ok=false +for ac_cxx_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || + test ! -s conftest.err + }; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi + +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || + test ! -s conftest.err + }; then + # Broken: success on invalid input. +continue +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi + +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + : +else + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +_lt_caught_CXX_error=yes; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +else + _lt_caught_CXX_error=yes +fi + + + + +ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + +archive_cmds_need_lc_CXX=no +allow_undefined_flag_CXX= +always_export_symbols_CXX=no +archive_expsym_cmds_CXX= +compiler_needs_object_CXX=no +export_dynamic_flag_spec_CXX= +hardcode_direct_CXX=no +hardcode_direct_absolute_CXX=no +hardcode_libdir_flag_spec_CXX= +hardcode_libdir_flag_spec_ld_CXX= +hardcode_libdir_separator_CXX= +hardcode_minus_L_CXX=no +hardcode_shlibpath_var_CXX=unsupported +hardcode_automatic_CXX=no +inherit_rpath_CXX=no +module_cmds_CXX= +module_expsym_cmds_CXX= +link_all_deplibs_CXX=unknown +old_archive_cmds_CXX=$old_archive_cmds +no_undefined_flag_CXX= +whole_archive_flag_spec_CXX= +enable_shared_with_static_runtimes_CXX=no + +# Source file extension for C++ test sources. +ac_ext=cpp + +# Object file extension for compiled C++ test sources. +objext=o +objext_CXX=$objext + +# No sense in running all these tests if we already determined that +# the CXX compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test "$_lt_caught_CXX_error" != yes; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="int some_variable = 0;" + + # Code to be used in simple link tests + lt_simple_link_test_code='int main(int, char *[]) { return(0); }' + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + + + + + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + + # save warnings/boilerplate of simple test code + ac_outfile=conftest.$ac_objext +echo "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$RM conftest* + + ac_outfile=conftest.$ac_objext +echo "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$RM -r conftest* + + + # Allow CC to be a program name with arguments. + lt_save_CC=$CC + lt_save_LD=$LD + lt_save_GCC=$GCC + GCC=$GXX + lt_save_with_gnu_ld=$with_gnu_ld + lt_save_path_LD=$lt_cv_path_LD + if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then + lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx + else + $as_unset lt_cv_prog_gnu_ld + fi + if test -n "${lt_cv_path_LDCXX+set}"; then + lt_cv_path_LD=$lt_cv_path_LDCXX + else + $as_unset lt_cv_path_LD + fi + test -z "${LDCXX+set}" || LD=$LDCXX + CC=${CXX-"c++"} + compiler=$CC + compiler_CXX=$CC + for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$ECHO "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + + if test -n "$compiler"; then + # We don't want -fno-exception when compiling C++ code, so set the + # no_builtin_flag separately + if test "$GXX" = yes; then + lt_prog_compiler_no_builtin_flag_CXX=' -fno-builtin' + else + lt_prog_compiler_no_builtin_flag_CXX= + fi + + if test "$GXX" = yes; then + # Set up default GNU C++ configuration + + + +# Check whether --with-gnu-ld was given. +if test "${with_gnu_ld+set}" = set; then + withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes +else + with_gnu_ld=no +fi + +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + { $as_echo "$as_me:$LINENO: checking for ld used by $CC" >&5 +$as_echo_n "checking for ld used by $CC... " >&6; } + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [\\/]* | ?:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` + while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do + ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + { $as_echo "$as_me:$LINENO: checking for GNU ld" >&5 +$as_echo_n "checking for GNU ld... " >&6; } +else + { $as_echo "$as_me:$LINENO: checking for non-GNU ld" >&5 +$as_echo_n "checking for non-GNU ld... " >&6; } +fi +if test "${lt_cv_path_LD+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -z "$LD"; then + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &5 +$as_echo "$LD" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi +test -z "$LD" && { { $as_echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5 +$as_echo "$as_me: error: no acceptable ld found in \$PATH" >&2;} + { (exit 1); exit 1; }; } +{ $as_echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5 +$as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } +if test "${lt_cv_prog_gnu_ld+set}" = set; then + $as_echo_n "(cached) " >&6 +else + # I'd rather use --version here, but apparently some GNU lds only accept -v. +case `$LD -v 2>&1 &5 +$as_echo "$lt_cv_prog_gnu_ld" >&6; } +with_gnu_ld=$lt_cv_prog_gnu_ld + + + + + + + + # Check if GNU C++ uses GNU ld as the underlying linker, since the + # archiving commands below assume that GNU ld is being used. + if test "$with_gnu_ld" = yes; then + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + + # If archive_cmds runs LD, not CC, wlarc should be empty + # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to + # investigate it a little bit more. (MM) + wlarc='${wl}' + + # ancient GNU ld didn't support --whole-archive et. al. + if eval "`$CC -print-prog-name=ld` --help 2>&1" | + $GREP 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + whole_archive_flag_spec_CXX= + fi + else + with_gnu_ld=no + wlarc= + + # A generic and very simple default shared library creation + # command for GNU C++ for the case where it uses the native + # linker, instead of GNU ld. If possible, this setting should + # overridden to take advantage of the native linker features on + # the platform it is being used on. + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + fi + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + + else + GXX=no + with_gnu_ld=no + wlarc= + fi + + # PORTME: fill in a description of your system's C++ link characteristics + { $as_echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +$as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } + ld_shlibs_CXX=yes + case $host_os in + aix3*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aix[4-9]*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) + for ld_flag in $LDFLAGS; do + case $ld_flag in + *-brtl*) + aix_use_runtimelinking=yes + break + ;; + esac + done + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds_CXX='' + hardcode_direct_CXX=yes + hardcode_direct_absolute_CXX=yes + hardcode_libdir_separator_CXX=':' + link_all_deplibs_CXX=yes + file_list_spec_CXX='${wl}-f,' + + if test "$GXX" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + hardcode_direct_CXX=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L_CXX=yes + hardcode_libdir_flag_spec_CXX='-L$libdir' + hardcode_libdir_separator_CXX= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + export_dynamic_flag_spec_CXX='${wl}-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to + # export. + always_export_symbols_CXX=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + allow_undefined_flag_CXX='-berok' + # Determine the default libpath from the value encoded in an empty + # executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + +lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\(.*\)$/\1/ + p + } + }' +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then + aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +fi +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" + + archive_expsym_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then $ECHO "X${wl}${allow_undefined_flag}" | $Xsed; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + hardcode_libdir_flag_spec_CXX='${wl}-R $libdir:/usr/lib:/lib' + allow_undefined_flag_CXX="-z nodefs" + archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + +lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\(.*\)$/\1/ + p + } + }' +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then + aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` +fi +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag_CXX=' ${wl}-bernotok' + allow_undefined_flag_CXX=' ${wl}-berok' + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec_CXX='$convenience' + archive_cmds_need_lc_CXX=yes + # This is similar to how AIX traditionally builds its shared + # libraries. + archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag_CXX=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds_CXX='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + ld_shlibs_CXX=no + fi + ;; + + chorus*) + case $cc_basename in + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # _LT_TAGVAR(hardcode_libdir_flag_spec, CXX) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec_CXX='-L$libdir' + allow_undefined_flag_CXX=unsupported + always_export_symbols_CXX=no + enable_shared_with_static_runtimes_CXX=yes + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + archive_expsym_cmds_CXX='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + ld_shlibs_CXX=no + fi + ;; + darwin* | rhapsody*) + + + archive_cmds_need_lc_CXX=no + hardcode_direct_CXX=no + hardcode_automatic_CXX=yes + hardcode_shlibpath_var_CXX=unsupported + whole_archive_flag_spec_CXX='' + link_all_deplibs_CXX=yes + allow_undefined_flag_CXX="$_lt_dar_allow_undefined" + case $cc_basename in + ifort*) _lt_dar_can_shared=yes ;; + *) _lt_dar_can_shared=$GCC ;; + esac + if test "$_lt_dar_can_shared" = "yes"; then + output_verbose_link_cmd=echo + archive_cmds_CXX="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" + module_cmds_CXX="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" + archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" + module_expsym_cmds_CXX="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" + if test "$lt_cv_apple_cc_single_mod" != "yes"; then + archive_cmds_CXX="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}" + archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}" + fi + + else + ld_shlibs_CXX=no + fi + + ;; + + dgux*) + case $cc_basename in + ec++*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + ghcx*) + # Green Hills C++ Compiler + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + freebsd[12]*) + # C++ shared libraries reported to be fairly broken before + # switch to ELF + ld_shlibs_CXX=no + ;; + + freebsd-elf*) + archive_cmds_need_lc_CXX=no + ;; + + freebsd* | dragonfly*) + # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF + # conventions + ld_shlibs_CXX=yes + ;; + + gnu*) + ;; + + hpux9*) + hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_CXX=: + export_dynamic_flag_spec_CXX='${wl}-E' + hardcode_direct_CXX=yes + hardcode_minus_L_CXX=yes # Not in the search PATH, + # but as the default + # location of the library. + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aCC*) + archive_cmds_CXX='$RM $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + *) + if test "$GXX" = yes; then + archive_cmds_CXX='$RM $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + + hpux10*|hpux11*) + if test $with_gnu_ld = no; then + hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_CXX=: + + case $host_cpu in + hppa*64*|ia64*) + ;; + *) + export_dynamic_flag_spec_CXX='${wl}-E' + ;; + esac + fi + case $host_cpu in + hppa*64*|ia64*) + hardcode_direct_CXX=no + hardcode_shlibpath_var_CXX=no + ;; + *) + hardcode_direct_CXX=yes + hardcode_direct_absolute_CXX=yes + hardcode_minus_L_CXX=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + esac + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aCC*) + case $host_cpu in + hppa*64*) + archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + *) + if test "$GXX" = yes; then + if test $with_gnu_ld = no; then + case $host_cpu in + hppa*64*) + archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + fi + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + + interix[3-9]*) + hardcode_direct_CXX=no + hardcode_shlibpath_var_CXX=no + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + export_dynamic_flag_spec_CXX='${wl}-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + archive_cmds_CXX='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + archive_expsym_cmds_CXX='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + irix5* | irix6*) + case $cc_basename in + CC*) + # SGI C++ + archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + + # Archives containing C++ object files must be created using + # "CC -ar", where "CC" is the IRIX C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -ar -WR,-u -o $oldlib $oldobjs' + ;; + *) + if test "$GXX" = yes; then + if test "$with_gnu_ld" = no; then + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` -o $lib' + fi + fi + link_all_deplibs_CXX=yes + ;; + esac + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_CXX=: + inherit_rpath_CXX=yes + ;; + + linux* | k*bsd*-gnu) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' + ;; + icpc* | ecpc* ) + # Intel C++ + with_gnu_ld=yes + # version 8.0 and above of icpc choke on multiply defined symbols + # if we add $predep_objects and $postdep_objects, however 7.1 and + # earlier do not add the objects themselves. + case `$CC -V 2>&1` in + *"Version 7."*) + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 8.0 or newer + tmp_idyn= + case $host_cpu in + ia64*) tmp_idyn=' -i_dynamic';; + esac + archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + archive_cmds_need_lc_CXX=no + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + whole_archive_flag_spec_CXX='${wl}--whole-archive$convenience ${wl}--no-whole-archive' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + case `$CC -V` in + *pgCC\ [1-5]* | *pgcpp\ [1-5]*) + prelink_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ + compile_command="$compile_command `find $tpldir -name \*.o | $NL2SP`"' + old_archive_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ + $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | $NL2SP`~ + $RANLIB $oldlib' + archive_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' + archive_expsym_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' + ;; + *) # Version 6 will use weak symbols + archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' + ;; + esac + + hardcode_libdir_flag_spec_CXX='${wl}--rpath ${wl}$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + whole_archive_flag_spec_CXX='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + ;; + cxx*) + # Compaq C++ + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' + + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec_CXX='-rpath $libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`$ECHO "X$templist" | $Xsed -e "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + xl*) + # IBM XL 8.0 on PPC, with GNU ld + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + archive_cmds_CXX='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + if test "x$supports_anon_versioning" = xyes; then + archive_expsym_cmds_CXX='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + no_undefined_flag_CXX=' -zdefs' + archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + archive_expsym_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols' + hardcode_libdir_flag_spec_CXX='-R$libdir' + whole_archive_flag_spec_CXX='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive' + compiler_needs_object_CXX=yes + + # Not sure whether something based on + # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 + # would be better. + output_verbose_link_cmd='echo' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' + ;; + esac + ;; + esac + ;; + + lynxos*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + m88k*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + mvs*) + case $cc_basename in + cxx*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + archive_cmds_CXX='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' + wlarc= + hardcode_libdir_flag_spec_CXX='-R$libdir' + hardcode_direct_CXX=yes + hardcode_shlibpath_var_CXX=no + fi + # Workaround some broken pre-1.5 toolchains + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' + ;; + + *nto* | *qnx*) + ld_shlibs_CXX=yes + ;; + + openbsd2*) + # C++ shared libraries are fairly broken + ld_shlibs_CXX=no + ;; + + openbsd*) + if test -f /usr/libexec/ld.so; then + hardcode_direct_CXX=yes + hardcode_shlibpath_var_CXX=no + hardcode_direct_absolute_CXX=yes + archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib' + export_dynamic_flag_spec_CXX='${wl}-E' + whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + fi + output_verbose_link_cmd=echo + else + ld_shlibs_CXX=no + fi + ;; + + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + hardcode_libdir_separator_CXX=: + + # Archives containing C++ object files must be created using + # the KAI C++ compiler. + case $host in + osf3*) old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' ;; + *) old_archive_cmds_CXX='$CC -o $oldlib $oldobjs' ;; + esac + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + cxx*) + case $host in + osf3*) + allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && $ECHO "X${wl}-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + ;; + *) + allow_undefined_flag_CXX=' -expect_unresolved \*' + archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib' + archive_expsym_cmds_CXX='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ + echo "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname ${wl}-input ${wl}$lib.exp `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib~ + $RM $lib.exp' + hardcode_libdir_flag_spec_CXX='-rpath $libdir' + ;; + esac + + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`$ECHO "X$templist" | $Xsed -e "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' + case $host in + osf3*) + archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + ;; + *) + archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + ;; + esac + + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + + psos*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + lcc*) + # Lucid + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + archive_cmds_need_lc_CXX=yes + no_undefined_flag_CXX=' -zdefs' + archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + hardcode_libdir_flag_spec_CXX='-R$libdir' + hardcode_shlibpath_var_CXX=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands `-z linker_flag'. + # Supported since Solaris 2.6 (maybe 2.5.1?) + whole_archive_flag_spec_CXX='-z allextract$convenience -z defaultextract' + ;; + esac + link_all_deplibs_CXX=yes + + output_verbose_link_cmd='echo' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' + ;; + gcx*) + # Green Hills C++ Compiler + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + + # The C++ compiler must be used to create the archive. + old_archive_cmds_CXX='$CC $LDFLAGS -archive -o $oldlib $oldobjs' + ;; + *) + # GNU C++ compiler with Solaris linker + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + no_undefined_flag_CXX=' ${wl}-z ${wl}defs' + if $CC --version | $GREP -v '^2\.7' > /dev/null; then + archive_cmds_CXX='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + else + # g++ 2.7 appears to require `-G' NOT `-shared' on this + # platform. + archive_cmds_CXX='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"' + fi + + hardcode_libdir_flag_spec_CXX='${wl}-R $wl$libdir' + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + whole_archive_flag_spec_CXX='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' + ;; + esac + fi + ;; + esac + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) + no_undefined_flag_CXX='${wl}-z,text' + archive_cmds_need_lc_CXX=no + hardcode_shlibpath_var_CXX=no + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + archive_cmds_CXX='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds_CXX='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We can NOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + no_undefined_flag_CXX='${wl}-z,text' + allow_undefined_flag_CXX='${wl}-z,nodefs' + archive_cmds_need_lc_CXX=no + hardcode_shlibpath_var_CXX=no + hardcode_libdir_flag_spec_CXX='${wl}-R,$libdir' + hardcode_libdir_separator_CXX=':' + link_all_deplibs_CXX=yes + export_dynamic_flag_spec_CXX='${wl}-Bexport' + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + archive_cmds_CXX='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds_CXX='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + vxworks*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + + { $as_echo "$as_me:$LINENO: result: $ld_shlibs_CXX" >&5 +$as_echo "$ld_shlibs_CXX" >&6; } + test "$ld_shlibs_CXX" = no && can_build_shared=no + + GCC_CXX="$GXX" + LD_CXX="$LD" + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + # Dependencies to place before and after the object being linked: +predep_objects_CXX= +postdep_objects_CXX= +predeps_CXX= +postdeps_CXX= +compiler_lib_search_path_CXX= + +cat > conftest.$ac_ext <<_LT_EOF +class Foo +{ +public: + Foo (void) { a = 0; } +private: + int a; +}; +_LT_EOF + +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # Parse the compiler output and extract the necessary + # objects, libraries and library flags. + + # Sentinel used to keep track of whether or not we are before + # the conftest object file. + pre_test_object_deps_done=no + + for p in `eval "$output_verbose_link_cmd"`; do + case $p in + + -L* | -R* | -l*) + # Some compilers place space between "-{L,R}" and the path. + # Remove the space. + if test $p = "-L" || + test $p = "-R"; then + prev=$p + continue + else + prev= + fi + + if test "$pre_test_object_deps_done" = no; then + case $p in + -L* | -R*) + # Internal compiler library paths should come after those + # provided the user. The postdeps already come after the + # user supplied libs so there is no need to process them. + if test -z "$compiler_lib_search_path_CXX"; then + compiler_lib_search_path_CXX="${prev}${p}" + else + compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} ${prev}${p}" + fi + ;; + # The "-l" case would never come before the object being + # linked, so don't bother handling this case. + esac + else + if test -z "$postdeps_CXX"; then + postdeps_CXX="${prev}${p}" + else + postdeps_CXX="${postdeps_CXX} ${prev}${p}" + fi + fi + ;; + + *.$objext) + # This assumes that the test object file only shows up + # once in the compiler output. + if test "$p" = "conftest.$objext"; then + pre_test_object_deps_done=yes + continue + fi + + if test "$pre_test_object_deps_done" = no; then + if test -z "$predep_objects_CXX"; then + predep_objects_CXX="$p" + else + predep_objects_CXX="$predep_objects_CXX $p" + fi + else + if test -z "$postdep_objects_CXX"; then + postdep_objects_CXX="$p" + else + postdep_objects_CXX="$postdep_objects_CXX $p" + fi + fi + ;; + + *) ;; # Ignore the rest. + + esac + done + + # Clean up. + rm -f a.out a.exe +else + echo "libtool.m4: error: problem compiling CXX test program" +fi + +$RM -f confest.$objext + +# PORTME: override above test on systems where it is broken +case $host_os in +interix[3-9]*) + # Interix 3.5 installs completely hosed .la files for C++, so rather than + # hack all around it, let's just trust "g++" to DTRT. + predep_objects_CXX= + postdep_objects_CXX= + postdeps_CXX= + ;; + +linux*) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + + # The more standards-conforming stlport4 library is + # incompatible with the Cstd library. Avoid specifying + # it if it's in CXXFLAGS. Ignore libCrun as + # -library=stlport4 depends on it. + case " $CXX $CXXFLAGS " in + *" -library=stlport4 "*) + solaris_use_stlport4=yes + ;; + esac + + if test "$solaris_use_stlport4" != yes; then + postdeps_CXX='-library=Cstd -library=Crun' + fi + ;; + esac + ;; + +solaris*) + case $cc_basename in + CC*) + # The more standards-conforming stlport4 library is + # incompatible with the Cstd library. Avoid specifying + # it if it's in CXXFLAGS. Ignore libCrun as + # -library=stlport4 depends on it. + case " $CXX $CXXFLAGS " in + *" -library=stlport4 "*) + solaris_use_stlport4=yes + ;; + esac + + # Adding this requires a known-good setup of shared libraries for + # Sun compiler versions before 5.6, else PIC objects from an old + # archive will be linked into the output, leading to subtle bugs. + if test "$solaris_use_stlport4" != yes; then + postdeps_CXX='-library=Cstd -library=Crun' + fi + ;; + esac + ;; +esac + + +case " $postdeps_CXX " in +*" -lc "*) archive_cmds_need_lc_CXX=no ;; +esac + compiler_lib_search_dirs_CXX= +if test -n "${compiler_lib_search_path_CXX}"; then + compiler_lib_search_dirs_CXX=`echo " ${compiler_lib_search_path_CXX}" | ${SED} -e 's! -L! !g' -e 's!^ !!'` +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + lt_prog_compiler_wl_CXX= +lt_prog_compiler_pic_CXX= +lt_prog_compiler_static_CXX= + +{ $as_echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 +$as_echo_n "checking for $compiler option to produce PIC... " >&6; } + + # C++ specific cases for pic, static, wl, etc. + if test "$GXX" = yes; then + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_CXX='-Bstatic' + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + lt_prog_compiler_pic_CXX='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + lt_prog_compiler_pic_CXX='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + mingw* | cygwin* | os2* | pw32* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + lt_prog_compiler_pic_CXX='-DDLL_EXPORT' + ;; + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic_CXX='-fno-common' + ;; + *djgpp*) + # DJGPP does not support shared libraries at all + lt_prog_compiler_pic_CXX= + ;; + interix[3-9]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic_CXX=-Kconform_pic + fi + ;; + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + ;; + *) + lt_prog_compiler_pic_CXX='-fPIC' + ;; + esac + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic_CXX='-fPIC -shared' + ;; + *) + lt_prog_compiler_pic_CXX='-fPIC' + ;; + esac + else + case $host_os in + aix[4-9]*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_CXX='-Bstatic' + else + lt_prog_compiler_static_CXX='-bnso -bI:/lib/syscalls.exp' + fi + ;; + chorus*) + case $cc_basename in + cxch68*) + # Green Hills C++ Compiler + # _LT_TAGVAR(lt_prog_compiler_static, CXX)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" + ;; + esac + ;; + dgux*) + case $cc_basename in + ec++*) + lt_prog_compiler_pic_CXX='-KPIC' + ;; + ghcx*) + # Green Hills C++ Compiler + lt_prog_compiler_pic_CXX='-pic' + ;; + *) + ;; + esac + ;; + freebsd* | dragonfly*) + # FreeBSD uses GNU C++ + ;; + hpux9* | hpux10* | hpux11*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='${wl}-a ${wl}archive' + if test "$host_cpu" != ia64; then + lt_prog_compiler_pic_CXX='+Z' + fi + ;; + aCC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='${wl}-a ${wl}archive' + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic_CXX='+Z' + ;; + esac + ;; + *) + ;; + esac + ;; + interix*) + # This is c89, which is MS Visual C++ (no shared libs) + # Anyone wants to do a port? + ;; + irix5* | irix6* | nonstopux*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='-non_shared' + # CC pic flag -KPIC is the default. + ;; + *) + ;; + esac + ;; + linux* | k*bsd*-gnu) + case $cc_basename in + KCC*) + # KAI C++ Compiler + lt_prog_compiler_wl_CXX='--backend -Wl,' + lt_prog_compiler_pic_CXX='-fPIC' + ;; + ecpc* ) + # old Intel C++ for x86_64 which still supported -KPIC. + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-static' + ;; + icpc* ) + # Intel C++, used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-fPIC' + lt_prog_compiler_static_CXX='-static' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-fpic' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + cxx*) + # Compaq C++ + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + lt_prog_compiler_pic_CXX= + lt_prog_compiler_static_CXX='-non_shared' + ;; + xlc* | xlC*) + # IBM XL 8.0 on PPC + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-qpic' + lt_prog_compiler_static_CXX='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-Bstatic' + lt_prog_compiler_wl_CXX='-Qoption ld ' + ;; + esac + ;; + esac + ;; + lynxos*) + ;; + m88k*) + ;; + mvs*) + case $cc_basename in + cxx*) + lt_prog_compiler_pic_CXX='-W c,exportall' + ;; + *) + ;; + esac + ;; + netbsd*) + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic_CXX='-fPIC -shared' + ;; + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + lt_prog_compiler_wl_CXX='--backend -Wl,' + ;; + RCC*) + # Rational C++ 2.4.1 + lt_prog_compiler_pic_CXX='-pic' + ;; + cxx*) + # Digital/Compaq C++ + lt_prog_compiler_wl_CXX='-Wl,' + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + lt_prog_compiler_pic_CXX= + lt_prog_compiler_static_CXX='-non_shared' + ;; + *) + ;; + esac + ;; + psos*) + ;; + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-Bstatic' + lt_prog_compiler_wl_CXX='-Qoption ld ' + ;; + gcx*) + # Green Hills C++ Compiler + lt_prog_compiler_pic_CXX='-PIC' + ;; + *) + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + lt_prog_compiler_pic_CXX='-pic' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + lcc*) + # Lucid + lt_prog_compiler_pic_CXX='-pic' + ;; + *) + ;; + esac + ;; + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + esac + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + lt_prog_compiler_pic_CXX='-KPIC' + ;; + *) + ;; + esac + ;; + vxworks*) + ;; + *) + lt_prog_compiler_can_build_shared_CXX=no + ;; + esac + fi + +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic_CXX= + ;; + *) + lt_prog_compiler_pic_CXX="$lt_prog_compiler_pic_CXX -DPIC" + ;; +esac +{ $as_echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_CXX" >&5 +$as_echo "$lt_prog_compiler_pic_CXX" >&6; } + + + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic_CXX"; then + { $as_echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works" >&5 +$as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works... " >&6; } +if test "${lt_cv_prog_compiler_pic_works_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_pic_works_CXX=no + ac_outfile=conftest.$ac_objext + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:15079: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:15083: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_pic_works_CXX=yes + fi + fi + $RM conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_pic_works_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_pic_works_CXX" >&6; } + +if test x"$lt_cv_prog_compiler_pic_works_CXX" = xyes; then + case $lt_prog_compiler_pic_CXX in + "" | " "*) ;; + *) lt_prog_compiler_pic_CXX=" $lt_prog_compiler_pic_CXX" ;; + esac +else + lt_prog_compiler_pic_CXX= + lt_prog_compiler_can_build_shared_CXX=no +fi + +fi + + + +# +# Check to make sure the static flag actually works. +# +wl=$lt_prog_compiler_wl_CXX eval lt_tmp_static_flag=\"$lt_prog_compiler_static_CXX\" +{ $as_echo "$as_me:$LINENO: checking if $compiler static flag $lt_tmp_static_flag works" >&5 +$as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } +if test "${lt_cv_prog_compiler_static_works_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_static_works_CXX=no + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS $lt_tmp_static_flag" + echo "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&5 + $ECHO "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_static_works_CXX=yes + fi + else + lt_cv_prog_compiler_static_works_CXX=yes + fi + fi + $RM -r conftest* + LDFLAGS="$save_LDFLAGS" + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_static_works_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_static_works_CXX" >&6; } + +if test x"$lt_cv_prog_compiler_static_works_CXX" = xyes; then + : +else + lt_prog_compiler_static_CXX= +fi + + + + + { $as_echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if test "${lt_cv_prog_compiler_c_o_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o_CXX=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:15178: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:15182: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o_CXX=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_c_o_CXX" >&6; } + + + + { $as_echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if test "${lt_cv_prog_compiler_c_o_CXX+set}" = set; then + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o_CXX=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:15230: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:15234: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o_CXX=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_c_o_CXX" >&6; } + + + + +hard_links="nottested" +if test "$lt_cv_prog_compiler_c_o_CXX" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + { $as_echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 +$as_echo_n "checking if we can lock with hard links... " >&6; } + hard_links=yes + $RM conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + { $as_echo "$as_me:$LINENO: result: $hard_links" >&5 +$as_echo "$hard_links" >&6; } + if test "$hard_links" = no; then + { $as_echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 +$as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + + + + { $as_echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +$as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } + + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + case $host_os in + aix[4-9]*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds_CXX='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols' + fi + ;; + pw32*) + export_symbols_cmds_CXX="$ltdll_cmds" + ;; + cygwin* | mingw* | cegcc*) + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;/^.*[ ]__nm__/s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' + ;; + *) + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + ;; + esac + exclude_expsyms_CXX='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' + +{ $as_echo "$as_me:$LINENO: result: $ld_shlibs_CXX" >&5 +$as_echo "$ld_shlibs_CXX" >&6; } +test "$ld_shlibs_CXX" = no && can_build_shared=no + +with_gnu_ld_CXX=$with_gnu_ld + + + + + + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc_CXX" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc_CXX=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $archive_cmds_CXX in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + { $as_echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 +$as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } + $RM conftest* + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl_CXX + pic_flag=$lt_prog_compiler_pic_CXX + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag_CXX + allow_undefined_flag_CXX= + if { (eval echo "$as_me:$LINENO: \"$archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\"") >&5 + (eval $archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + then + archive_cmds_need_lc_CXX=no + else + archive_cmds_need_lc_CXX=yes + fi + allow_undefined_flag_CXX=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $RM conftest* + { $as_echo "$as_me:$LINENO: result: $archive_cmds_need_lc_CXX" >&5 +$as_echo "$archive_cmds_need_lc_CXX" >&6; } + ;; + esac + fi + ;; +esac + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 +$as_echo_n "checking dynamic linker characteristics... " >&6; } + +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix[4-9]*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + case $host_cpu in + powerpc) + # Since July 2007 AmigaOS4 officially supports .so libraries. + # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + ;; + m68k) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$ECHO "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + esac + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32* | cegcc*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32* | yes,cegcc*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + #soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + soname_spec='`echo ${libname} | sed -e 's/^lib//'`${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw* | cegcc*) + # MinGW DLLs use traditional 'lib' prefix + #soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + soname_spec='`echo ${libname} | $SED -e 's/^lib//'`${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | $GREP "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[123]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ + freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + *) # from 4.6 on, and DragonFly + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +interix[3-9]*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux* | k*bsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # Some binutils ld are patched to set DT_RUNPATH + save_LDFLAGS=$LDFLAGS + save_libdir=$libdir + eval "libdir=/foo; wl=\"$lt_prog_compiler_wl_CXX\"; \ + LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec_CXX\"" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then + shlibpath_overrides_runpath=yes +fi + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS=$save_LDFLAGS + libdir=$save_libdir + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +*nto* | *qnx*) + version_type=qnx + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='ldqnx.so' + ;; + +openbsd*) + version_type=sunos + sys_lib_dlsearch_path_spec="/usr/lib" + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[89] | openbsd2.[89].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +rdos*) + dynamic_linker=no + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + version_type=freebsd-elf + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + if test "$with_gnu_ld" = yes; then + sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' + else + sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' + case $host_os in + sco3.2v5*) + sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" + ;; + esac + fi + sys_lib_dlsearch_path_spec='/usr/lib' + ;; + +tpf*) + # TPF is a cross-target only. Preferred cross-host = GNU/Linux. + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +{ $as_echo "$as_me:$LINENO: result: $dynamic_linker" >&5 +$as_echo "$dynamic_linker" >&6; } +test "$dynamic_linker" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then + sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" +fi +if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then + sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 +$as_echo_n "checking how to hardcode library paths into programs... " >&6; } +hardcode_action_CXX= +if test -n "$hardcode_libdir_flag_spec_CXX" || + test -n "$runpath_var_CXX" || + test "X$hardcode_automatic_CXX" = "Xyes" ; then + + # We can hardcode non-existent directories. + if test "$hardcode_direct_CXX" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_TAGVAR(hardcode_shlibpath_var, CXX)" != no && + test "$hardcode_minus_L_CXX" != no; then + # Linking always hardcodes the temporary library directory. + hardcode_action_CXX=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action_CXX=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action_CXX=unsupported +fi +{ $as_echo "$as_me:$LINENO: result: $hardcode_action_CXX" >&5 +$as_echo "$hardcode_action_CXX" >&6; } + +if test "$hardcode_action_CXX" = relink || + test "$inherit_rpath_CXX" = yes; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi + + + + + + + + fi # test -n "$compiler" + + CC=$lt_save_CC + LDCXX=$LD + LD=$lt_save_LD + GCC=$lt_save_GCC + with_gnu_ld=$lt_save_with_gnu_ld + lt_cv_path_LDCXX=$lt_cv_path_LD + lt_cv_path_LD=$lt_save_path_LD + lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld + lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld +fi # test "$_lt_caught_CXX_error" != yes + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +# Find a good install program. We prefer a C program (faster), +# so one script is as good as another. But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AmigaOS /C/install, which installs bootblocks on floppy discs +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# OS/2's system install, which has a completely different semantic +# ./install, which can be erroneously created by make from ./install.sh. +# Reject install programs that cannot install multiple files. +{ $as_echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5 +$as_echo_n "checking for a BSD-compatible install... " >&6; } +if test -z "$INSTALL"; then +if test "${ac_cv_path_install+set}" = set; then + $as_echo_n "(cached) " >&6 +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + # Account for people who put trailing slashes in PATH elements. +case $as_dir/ in + ./ | .// | /cC/* | \ + /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ + ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \ + /usr/ucb/* ) ;; + *) + # OSF1 and SCO ODT 3.0 have their own names for install. + # Don't use installbsd from OSF since it installs stuff as root + # by default. + for ac_prog in ginstall scoinst install; do + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; }; then + if test $ac_prog = install && + grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # AIX install. It has an incompatible calling convention. + : + elif test $ac_prog = install && + grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # program-specific install script used by HP pwplus--don't use. + : + else + rm -rf conftest.one conftest.two conftest.dir + echo one > conftest.one + echo two > conftest.two + mkdir conftest.dir + if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && + test -s conftest.one && test -s conftest.two && + test -s conftest.dir/conftest.one && + test -s conftest.dir/conftest.two + then + ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" + break 3 + fi + fi + fi + done + done + ;; +esac + +done +IFS=$as_save_IFS + +rm -rf conftest.one conftest.two conftest.dir + +fi + if test "${ac_cv_path_install+set}" = set; then + INSTALL=$ac_cv_path_install + else + # As a last resort, use the slow shell script. Don't cache a + # value for INSTALL within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the value is a relative name. + INSTALL=$ac_install_sh + fi +fi +{ $as_echo "$as_me:$LINENO: result: $INSTALL" >&5 +$as_echo "$INSTALL" >&6; } + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + +{ $as_echo "$as_me:$LINENO: checking whether ${MAKE-make} sets \$(MAKE)" >&5 +$as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } +set x ${MAKE-make} +ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` +if { as_var=ac_cv_prog_make_${ac_make}_set; eval "test \"\${$as_var+set}\" = set"; }; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.make <<\_ACEOF +SHELL = /bin/sh +all: + @echo '@@@%%%=$(MAKE)=@@@%%%' +_ACEOF +# GNU make sometimes prints "make[1]: Entering...", which would confuse us. +case `${MAKE-make} -f conftest.make 2>/dev/null` in + *@@@%%%=?*=@@@%%%*) + eval ac_cv_prog_make_${ac_make}_set=yes;; + *) + eval ac_cv_prog_make_${ac_make}_set=no;; +esac +rm -f conftest.make +fi +if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then + { $as_echo "$as_me:$LINENO: result: yes" >&5 +$as_echo "yes" >&6; } + SET_MAKE= +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } + SET_MAKE="MAKE=${MAKE-make}" +fi + +if test -z "$host_alias"; then + hostaliaswindres= +else + hostaliaswindres="$host_alias-windres" +fi +for ac_prog in windres $hostaliaswindres $host_os-windres +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_WINDRES+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test -n "$WINDRES"; then + ac_cv_prog_WINDRES="$WINDRES" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_WINDRES="$ac_prog" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + +fi +fi +WINDRES=$ac_cv_prog_WINDRES +if test -n "$WINDRES"; then + { $as_echo "$as_me:$LINENO: result: $WINDRES" >&5 +$as_echo "$WINDRES" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$WINDRES" && break +done + + +INCLUDE="-I$srcdir/include" +if test x$srcdir != x.; then + # Remove SDL_config.h from the source directory, since it's the + # default one, and we want to include the one that we generate. + if test -f $srcdir/include/SDL_config.h; then + rm $srcdir/include/SDL_config.h + fi + INCLUDE="-Iinclude $INCLUDE" +fi +case "$host" in + *-*-cygwin*) + # We build SDL on cygwin without the UNIX emulation layer + BASE_CFLAGS="-I/usr/include/mingw -mno-cygwin" + BASE_LDFLAGS="-mno-cygwin" + ;; + *) + BASE_CFLAGS="-D_GNU_SOURCE=1" + BASE_LDFLAGS="" + ;; +esac +BUILD_CFLAGS="$CFLAGS $CPPFLAGS" +EXTRA_CFLAGS="$INCLUDE $BASE_CFLAGS" +BUILD_LDFLAGS="$LDFLAGS" +EXTRA_LDFLAGS="$BASE_LDFLAGS" +## These are common directories to find software packages +#for path in /usr/freeware /usr/pkg /usr/X11R6 /usr/local; do +# if test -d $path/include; then +# EXTRA_CFLAGS="$EXTRA_CFLAGS -I$path/include" +# fi +# if test -d $path/lib; then +# EXTRA_LDFLAGS="$EXTRA_LDFLAGS -L$path/lib" +# fi +#done +SDL_CFLAGS="$BASE_CFLAGS" +SDL_LIBS="-lSDL $BASE_LDFLAGS" +CPPFLAGS="$CPPFLAGS $EXTRA_CFLAGS" +CFLAGS="$CFLAGS $EXTRA_CFLAGS" +LDFLAGS="$LDFLAGS $EXTRA_LDFLAGS" + +base_libdir=`echo \${libdir} | sed 's/.*\/\(.*\)/\1/; q'` + +find_lib() +{ + gcc_bin_path=`$CC -print-search-dirs 2>/dev/null | fgrep programs: | sed 's/[^=]*=\(.*\)/\1/' | sed 's/:/ /g'` + gcc_lib_path=`$CC -print-search-dirs 2>/dev/null | fgrep libraries: | sed 's/[^=]*=\(.*\)/\1/' | sed 's/:/ /g'` + env_lib_path=`echo $LIBS $LDFLAGS $* | sed 's/-L[ ]*//g'` + if test "$cross_compiling" = yes; then + host_lib_path="" + else + host_lib_path="/usr/$base_libdir /usr/local/$base_libdir" + fi + for path in $gcc_bin_path $gcc_lib_path $env_lib_path $host_lib_path; do + lib=`ls -- $path/$1 2>/dev/null | sort | sed 's/.*\/\(.*\)/\1/; q'` + if test x$lib != x; then + echo $lib + return + fi + done +} + +{ $as_echo "$as_me:$LINENO: checking for an ANSI C-conforming const" >&5 +$as_echo_n "checking for an ANSI C-conforming const... " >&6; } +if test "${ac_cv_c_const+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +/* FIXME: Include the comments suggested by Paul. */ +#ifndef __cplusplus + /* Ultrix mips cc rejects this. */ + typedef int charset[2]; + const charset cs; + /* SunOS 4.1.1 cc rejects this. */ + char const *const *pcpcc; + char **ppc; + /* NEC SVR4.0.2 mips cc rejects this. */ + struct point {int x, y;}; + static struct point const zero = {0,0}; + /* AIX XL C 1.02.0.0 rejects this. + It does not let you subtract one const X* pointer from another in + an arm of an if-expression whose if-part is not a constant + expression */ + const char *g = "string"; + pcpcc = &g + (g ? g-g : 0); + /* HPUX 7.0 cc rejects these. */ + ++pcpcc; + ppc = (char**) pcpcc; + pcpcc = (char const *const *) ppc; + { /* SCO 3.2v4 cc rejects this. */ + char *t; + char const *s = 0 ? (char *) 0 : (char const *) 0; + + *t++ = 0; + if (s) return 0; + } + { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ + int x[] = {25, 17}; + const int *foo = &x[0]; + ++foo; + } + { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ + typedef const int *iptr; + iptr p = 0; + ++p; + } + { /* AIX XL C 1.02.0.0 rejects this saying + "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ + struct s { int j; const int *ap[3]; }; + struct s *b; b->j = 5; + } + { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ + const int foo = 10; + if (!foo) return 0; + } + return !cs[0] && !zero.x; +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_c_const=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_c_const=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_const" >&5 +$as_echo "$ac_cv_c_const" >&6; } +if test $ac_cv_c_const = no; then + +cat >>confdefs.h <<\_ACEOF +#define const /**/ +_ACEOF + +fi + +{ $as_echo "$as_me:$LINENO: checking for inline" >&5 +$as_echo_n "checking for inline... " >&6; } +if test "${ac_cv_c_inline+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_cv_c_inline=no +for ac_kw in inline __inline__ __inline; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifndef __cplusplus +typedef int foo_t; +static $ac_kw foo_t static_foo () {return 0; } +$ac_kw foo_t foo () {return 0; } +#endif + +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_c_inline=$ac_kw +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + test "$ac_cv_c_inline" != no && break +done + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_inline" >&5 +$as_echo "$ac_cv_c_inline" >&6; } + + +case $ac_cv_c_inline in + inline | yes) ;; + *) + case $ac_cv_c_inline in + no) ac_val=;; + *) ac_val=$ac_cv_c_inline;; + esac + cat >>confdefs.h <<_ACEOF +#ifndef __cplusplus +#define inline $ac_val +#endif +_ACEOF + ;; +esac + +{ $as_echo "$as_me:$LINENO: checking for working volatile" >&5 +$as_echo_n "checking for working volatile... " >&6; } +if test "${ac_cv_c_volatile+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + +volatile int x; +int * volatile y = (int *) 0; +return !x && !y; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_c_volatile=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_c_volatile=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_volatile" >&5 +$as_echo "$ac_cv_c_volatile" >&6; } +if test $ac_cv_c_volatile = no; then + +cat >>confdefs.h <<\_ACEOF +#define volatile /**/ +_ACEOF + +fi + + +# Check whether --enable-libc was given. +if test "${enable_libc+set}" = set; then + enableval=$enable_libc; +else + enable_libc=yes +fi + +if test x$enable_libc = xyes; then + cat >>confdefs.h <<\_ACEOF +#define HAVE_LIBC 1 +_ACEOF + + + { $as_echo "$as_me:$LINENO: checking for ANSI C header files" >&5 +$as_echo_n "checking for ANSI C header files... " >&6; } +if test "${ac_cv_header_stdc+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#include +#include + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_cv_header_stdc=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_header_stdc=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +if test $ac_cv_header_stdc = yes; then + # SunOS 4.x string.h does not declare mem*, contrary to ANSI. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "memchr" >/dev/null 2>&1; then + : +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "free" >/dev/null 2>&1; then + : +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. + if test "$cross_compiling" = yes; then + : +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#if ((' ' & 0x0FF) == 0x020) +# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') +# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) +#else +# define ISLOWER(c) \ + (('a' <= (c) && (c) <= 'i') \ + || ('j' <= (c) && (c) <= 'r') \ + || ('s' <= (c) && (c) <= 'z')) +# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) +#endif + +#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) +int +main () +{ + int i; + for (i = 0; i < 256; i++) + if (XOR (islower (i), ISLOWER (i)) + || toupper (i) != TOUPPER (i)) + return 2; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_header_stdc=no +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + + +fi +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_header_stdc" >&5 +$as_echo "$ac_cv_header_stdc" >&6; } +if test $ac_cv_header_stdc = yes; then + +cat >>confdefs.h <<\_ACEOF +#define STDC_HEADERS 1 +_ACEOF + +fi + + + + + + + + + + + + + + + + +for ac_header in sys/types.h stdio.h stdlib.h stddef.h stdarg.h malloc.h memory.h string.h strings.h inttypes.h stdint.h ctype.h math.h iconv.h signal.h +do +as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then + { $as_echo "$as_me:$LINENO: checking for $ac_header" >&5 +$as_echo_n "checking for $ac_header... " >&6; } +if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then + $as_echo_n "(cached) " >&6 +fi +ac_res=`eval 'as_val=${'$as_ac_Header'} + $as_echo "$as_val"'` + { $as_echo "$as_me:$LINENO: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +else + # Is the header compilable? +{ $as_echo "$as_me:$LINENO: checking $ac_header usability" >&5 +$as_echo_n "checking $ac_header usability... " >&6; } +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_header_compiler=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_compiler=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +{ $as_echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +$as_echo "$ac_header_compiler" >&6; } + +# Is the header present? +{ $as_echo "$as_me:$LINENO: checking $ac_header presence" >&5 +$as_echo_n "checking $ac_header presence... " >&6; } +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then + ac_header_preproc=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi + +rm -f conftest.err conftest.$ac_ext +{ $as_echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +$as_echo "$ac_header_preproc" >&6; } + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +$as_echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +$as_echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +$as_echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +$as_echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +$as_echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +$as_echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +$as_echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { $as_echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +$as_echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + + ;; +esac +{ $as_echo "$as_me:$LINENO: checking for $ac_header" >&5 +$as_echo_n "checking for $ac_header... " >&6; } +if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then + $as_echo_n "(cached) " >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +ac_res=`eval 'as_val=${'$as_ac_Header'} + $as_echo "$as_val"'` + { $as_echo "$as_me:$LINENO: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + +fi +as_val=`eval 'as_val=${'$as_ac_Header'} + $as_echo "$as_val"'` + if test "x$as_val" = x""yes; then + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + { $as_echo "$as_me:$LINENO: checking for size_t" >&5 +$as_echo_n "checking for size_t... " >&6; } +if test "${ac_cv_type_size_t+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_cv_type_size_t=no +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if (sizeof (size_t)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if (sizeof ((size_t))) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_type_size_t=yes +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_type_size_t" >&5 +$as_echo "$ac_cv_type_size_t" >&6; } +if test "x$ac_cv_type_size_t" = x""yes; then + : +else + +cat >>confdefs.h <<_ACEOF +#define size_t unsigned int +_ACEOF + +fi + + if test x$ac_cv_header_inttypes_h = xyes -o x$ac_cv_header_stdint_h = xyes; then + { $as_echo "$as_me:$LINENO: checking for int64_t" >&5 +$as_echo_n "checking for int64_t... " >&6; } +if test "${ac_cv_type_int64_t+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_cv_type_int64_t=no +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if (sizeof (int64_t)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if (sizeof ((int64_t))) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + : +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_type_int64_t=yes +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_type_int64_t" >&5 +$as_echo "$ac_cv_type_int64_t" >&6; } + + if test x$ac_cv_type_int64_t = xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_HAS_64BIT_TYPE 1 +_ACEOF + + fi + have_inttypes=yes + fi + + case "$host" in + *-*-cygwin* | *-*-mingw32*) + ;; + *) + # The Ultrix 4.2 mips builtin alloca declared by alloca.h only works +# for constant arguments. Useless! +{ $as_echo "$as_me:$LINENO: checking for working alloca.h" >&5 +$as_echo_n "checking for working alloca.h... " >&6; } +if test "${ac_cv_working_alloca_h+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +char *p = (char *) alloca (2 * sizeof (int)); + if (p) return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_working_alloca_h=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_working_alloca_h=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_working_alloca_h" >&5 +$as_echo "$ac_cv_working_alloca_h" >&6; } +if test $ac_cv_working_alloca_h = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_ALLOCA_H 1 +_ACEOF + +fi + +{ $as_echo "$as_me:$LINENO: checking for alloca" >&5 +$as_echo_n "checking for alloca... " >&6; } +if test "${ac_cv_func_alloca_works+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __GNUC__ +# define alloca __builtin_alloca +#else +# ifdef _MSC_VER +# include +# define alloca _alloca +# else +# ifdef HAVE_ALLOCA_H +# include +# else +# ifdef _AIX + #pragma alloca +# else +# ifndef alloca /* predefined by HP cc +Olibcalls */ +char *alloca (); +# endif +# endif +# endif +# endif +#endif + +int +main () +{ +char *p = (char *) alloca (1); + if (p) return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_func_alloca_works=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_func_alloca_works=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_alloca_works" >&5 +$as_echo "$ac_cv_func_alloca_works" >&6; } + +if test $ac_cv_func_alloca_works = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_ALLOCA 1 +_ACEOF + +else + # The SVR3 libPW and SVR4 libucb both contain incompatible functions +# that cause trouble. Some versions do not even contain alloca or +# contain a buggy version. If you still want to use their alloca, +# use ar to extract alloca.o from them instead of compiling alloca.c. + +ALLOCA=\${LIBOBJDIR}alloca.$ac_objext + +cat >>confdefs.h <<\_ACEOF +#define C_ALLOCA 1 +_ACEOF + + +{ $as_echo "$as_me:$LINENO: checking whether \`alloca.c' needs Cray hooks" >&5 +$as_echo_n "checking whether \`alloca.c' needs Cray hooks... " >&6; } +if test "${ac_cv_os_cray+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#if defined CRAY && ! defined CRAY2 +webecray +#else +wenotbecray +#endif + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "webecray" >/dev/null 2>&1; then + ac_cv_os_cray=yes +else + ac_cv_os_cray=no +fi +rm -f conftest* + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_os_cray" >&5 +$as_echo "$ac_cv_os_cray" >&6; } +if test $ac_cv_os_cray = yes; then + for ac_func in _getb67 GETB67 getb67; do + as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` +{ $as_echo "$as_me:$LINENO: checking for $ac_func" >&5 +$as_echo_n "checking for $ac_func... " >&6; } +if { as_var=$as_ac_var; eval "test \"\${$as_var+set}\" = set"; }; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define $ac_func to an innocuous variant, in case declares $ac_func. + For example, HP-UX 11i declares gettimeofday. */ +#define $ac_func innocuous_$ac_func + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char $ac_func (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef $ac_func + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char $ac_func (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_$ac_func || defined __stub___$ac_func +choke me +#endif + +int +main () +{ +return $ac_func (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + eval "$as_ac_var=yes" +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + eval "$as_ac_var=no" +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +ac_res=`eval 'as_val=${'$as_ac_var'} + $as_echo "$as_val"'` + { $as_echo "$as_me:$LINENO: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +as_val=`eval 'as_val=${'$as_ac_var'} + $as_echo "$as_val"'` + if test "x$as_val" = x""yes; then + +cat >>confdefs.h <<_ACEOF +#define CRAY_STACKSEG_END $ac_func +_ACEOF + + break +fi + + done +fi + +{ $as_echo "$as_me:$LINENO: checking stack direction for C alloca" >&5 +$as_echo_n "checking stack direction for C alloca... " >&6; } +if test "${ac_cv_c_stack_direction+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + ac_cv_c_stack_direction=0 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +find_stack_direction () +{ + static char *addr = 0; + auto char dummy; + if (addr == 0) + { + addr = &dummy; + return find_stack_direction (); + } + else + return (&dummy > addr) ? 1 : -1; +} + +int +main () +{ + return find_stack_direction () < 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_c_stack_direction=1 +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_c_stack_direction=-1 +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_stack_direction" >&5 +$as_echo "$ac_cv_c_stack_direction" >&6; } + +cat >>confdefs.h <<_ACEOF +#define STACK_DIRECTION $ac_cv_c_stack_direction +_ACEOF + + +fi + + ;; + esac + + { $as_echo "$as_me:$LINENO: checking for working memcmp" >&5 +$as_echo_n "checking for working memcmp... " >&6; } +if test "${ac_cv_func_memcmp_working+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + ac_cv_func_memcmp_working=no +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ + + /* Some versions of memcmp are not 8-bit clean. */ + char c0 = '\100', c1 = '\200', c2 = '\201'; + if (memcmp(&c0, &c2, 1) >= 0 || memcmp(&c1, &c2, 1) >= 0) + return 1; + + /* The Next x86 OpenStep bug shows up only when comparing 16 bytes + or more and with at least one buffer not starting on a 4-byte boundary. + William Lewis provided this test program. */ + { + char foo[21]; + char bar[21]; + int i; + for (i = 0; i < 4; i++) + { + char *a = foo + i; + char *b = bar + i; + strcpy (a, "--------01111111"); + strcpy (b, "--------10000000"); + if (memcmp (a, b, 16) >= 0) + return 1; + } + return 0; + } + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_memcmp_working=yes +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_func_memcmp_working=no +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_memcmp_working" >&5 +$as_echo "$ac_cv_func_memcmp_working" >&6; } +test $ac_cv_func_memcmp_working = no && case " $LIBOBJS " in + *" memcmp.$ac_objext "* ) ;; + *) LIBOBJS="$LIBOBJS memcmp.$ac_objext" + ;; +esac + + + if test x$ac_cv_func_memcmp_working = xyes; then + cat >>confdefs.h <<\_ACEOF +#define HAVE_MEMCMP 1 +_ACEOF + + fi + { $as_echo "$as_me:$LINENO: checking for working strtod" >&5 +$as_echo_n "checking for working strtod... " >&6; } +if test "${ac_cv_func_strtod+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + ac_cv_func_strtod=no +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +$ac_includes_default +#ifndef strtod +double strtod (); +#endif +int +main() +{ + { + /* Some versions of Linux strtod mis-parse strings with leading '+'. */ + char *string = " +69"; + char *term; + double value; + value = strtod (string, &term); + if (value != 69 || term != (string + 4)) + return 1; + } + + { + /* Under Solaris 2.4, strtod returns the wrong value for the + terminating character under some conditions. */ + char *string = "NaN"; + char *term; + strtod (string, &term); + if (term != string && *(term - 1) == 0) + return 1; + } + return 0; +} + +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_strtod=yes +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_func_strtod=no +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + + +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_strtod" >&5 +$as_echo "$ac_cv_func_strtod" >&6; } +if test $ac_cv_func_strtod = no; then + case " $LIBOBJS " in + *" strtod.$ac_objext "* ) ;; + *) LIBOBJS="$LIBOBJS strtod.$ac_objext" + ;; +esac + +{ $as_echo "$as_me:$LINENO: checking for pow" >&5 +$as_echo_n "checking for pow... " >&6; } +if test "${ac_cv_func_pow+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define pow to an innocuous variant, in case declares pow. + For example, HP-UX 11i declares gettimeofday. */ +#define pow innocuous_pow + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char pow (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef pow + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char pow (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_pow || defined __stub___pow +choke me +#endif + +int +main () +{ +return pow (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_func_pow=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_func_pow=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_pow" >&5 +$as_echo "$ac_cv_func_pow" >&6; } + +if test $ac_cv_func_pow = no; then + { $as_echo "$as_me:$LINENO: checking for pow in -lm" >&5 +$as_echo_n "checking for pow in -lm... " >&6; } +if test "${ac_cv_lib_m_pow+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lm $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char pow (); +int +main () +{ +return pow (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_m_pow=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_m_pow=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_m_pow" >&5 +$as_echo "$ac_cv_lib_m_pow" >&6; } +if test "x$ac_cv_lib_m_pow" = x""yes; then + POW_LIB=-lm +else + { $as_echo "$as_me:$LINENO: WARNING: cannot find library containing definition of pow" >&5 +$as_echo "$as_me: WARNING: cannot find library containing definition of pow" >&2;} +fi + +fi + +fi + + if test x$ac_cv_func_strtod = xyes; then + cat >>confdefs.h <<\_ACEOF +#define HAVE_STRTOD 1 +_ACEOF + + fi + { $as_echo "$as_me:$LINENO: checking for mprotect" >&5 +$as_echo_n "checking for mprotect... " >&6; } +if test "${ac_cv_func_mprotect+set}" = set; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define mprotect to an innocuous variant, in case declares mprotect. + For example, HP-UX 11i declares gettimeofday. */ +#define mprotect innocuous_mprotect + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char mprotect (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef mprotect + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char mprotect (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_mprotect || defined __stub___mprotect +choke me +#endif + +int +main () +{ +return mprotect (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_func_mprotect=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_func_mprotect=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_mprotect" >&5 +$as_echo "$ac_cv_func_mprotect" >&6; } +if test "x$ac_cv_func_mprotect" = x""yes; then + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + + #include + #include + +int +main () +{ + + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + + cat >>confdefs.h <<\_ACEOF +#define HAVE_MPROTECT 1 +_ACEOF + + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +for ac_func in malloc calloc realloc free getenv putenv unsetenv qsort abs bcopy memset memcpy memmove strlen strlcpy strlcat strdup _strrev _strupr _strlwr strchr strrchr strstr itoa _ltoa _uitoa _ultoa strtol strtoul _i64toa _ui64toa strtoll strtoull atoi atof strcmp strncmp _stricmp strcasecmp _strnicmp strncasecmp sscanf snprintf vsnprintf iconv sigaction setjmp nanosleep +do +as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` +{ $as_echo "$as_me:$LINENO: checking for $ac_func" >&5 +$as_echo_n "checking for $ac_func... " >&6; } +if { as_var=$as_ac_var; eval "test \"\${$as_var+set}\" = set"; }; then + $as_echo_n "(cached) " >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define $ac_func to an innocuous variant, in case declares $ac_func. + For example, HP-UX 11i declares gettimeofday. */ +#define $ac_func innocuous_$ac_func + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char $ac_func (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef $ac_func + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char $ac_func (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_$ac_func || defined __stub___$ac_func +choke me +#endif + +int +main () +{ +return $ac_func (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + eval "$as_ac_var=yes" +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + eval "$as_ac_var=no" +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +fi +ac_res=`eval 'as_val=${'$as_ac_var'} + $as_echo "$as_val"'` + { $as_echo "$as_me:$LINENO: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +as_val=`eval 'as_val=${'$as_ac_var'} + $as_echo "$as_val"'` + if test "x$as_val" = x""yes; then + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_func" | $as_tr_cpp` 1 +_ACEOF + +fi +done + + + { $as_echo "$as_me:$LINENO: checking for libiconv_open in -liconv" >&5 +$as_echo_n "checking for libiconv_open in -liconv... " >&6; } +if test "${ac_cv_lib_iconv_libiconv_open+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-liconv $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char libiconv_open (); +int +main () +{ +return libiconv_open (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_iconv_libiconv_open=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_iconv_libiconv_open=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_iconv_libiconv_open" >&5 +$as_echo "$ac_cv_lib_iconv_libiconv_open" >&6; } +if test "x$ac_cv_lib_iconv_libiconv_open" = x""yes; then + EXTRA_LDFLAGS="$EXTRA_LDFLAGS -liconv" +fi + + { $as_echo "$as_me:$LINENO: checking for pow in -lm" >&5 +$as_echo_n "checking for pow in -lm... " >&6; } +if test "${ac_cv_lib_m_pow+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lm $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char pow (); +int +main () +{ +return pow (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_m_pow=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_m_pow=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_m_pow" >&5 +$as_echo "$ac_cv_lib_m_pow" >&6; } +if test "x$ac_cv_lib_m_pow" = x""yes; then + EXTRA_LDFLAGS="$EXTRA_LDFLAGS -lm" +fi + +fi + +if test x$have_inttypes != xyes; then + # The cast to long int works around a bug in the HP C Compiler +# version HP92453-01 B.11.11.23709.GP, which incorrectly rejects +# declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. +# This bug is HP SR number 8606223364. +{ $as_echo "$as_me:$LINENO: checking size of char" >&5 +$as_echo_n "checking size of char... " >&6; } +if test "${ac_cv_sizeof_char+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (char))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (char))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (char))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (char))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo= ac_hi= +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (char))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr '(' $ac_mid ')' + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_char=$ac_lo;; +'') if test "$ac_cv_type_char" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (char) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (char) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_char=0 + fi ;; +esac +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +static long int longval () { return (long int) (sizeof (char)); } +static unsigned long int ulongval () { return (long int) (sizeof (char)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + return 1; + if (((long int) (sizeof (char))) < 0) + { + long int i = longval (); + if (i != ((long int) (sizeof (char)))) + return 1; + fprintf (f, "%ld", i); + } + else + { + unsigned long int i = ulongval (); + if (i != ((long int) (sizeof (char)))) + return 1; + fprintf (f, "%lu", i); + } + /* Do not output a trailing newline, as this causes \r\n confusion + on some platforms. */ + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_char=`cat conftest.val` +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +if test "$ac_cv_type_char" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (char) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (char) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_char=0 + fi +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.val +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_sizeof_char" >&5 +$as_echo "$ac_cv_sizeof_char" >&6; } + + + +cat >>confdefs.h <<_ACEOF +#define SIZEOF_CHAR $ac_cv_sizeof_char +_ACEOF + + + # The cast to long int works around a bug in the HP C Compiler +# version HP92453-01 B.11.11.23709.GP, which incorrectly rejects +# declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. +# This bug is HP SR number 8606223364. +{ $as_echo "$as_me:$LINENO: checking size of short" >&5 +$as_echo_n "checking size of short... " >&6; } +if test "${ac_cv_sizeof_short+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (short))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (short))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (short))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (short))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo= ac_hi= +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (short))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr '(' $ac_mid ')' + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_short=$ac_lo;; +'') if test "$ac_cv_type_short" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (short) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (short) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_short=0 + fi ;; +esac +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +static long int longval () { return (long int) (sizeof (short)); } +static unsigned long int ulongval () { return (long int) (sizeof (short)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + return 1; + if (((long int) (sizeof (short))) < 0) + { + long int i = longval (); + if (i != ((long int) (sizeof (short)))) + return 1; + fprintf (f, "%ld", i); + } + else + { + unsigned long int i = ulongval (); + if (i != ((long int) (sizeof (short)))) + return 1; + fprintf (f, "%lu", i); + } + /* Do not output a trailing newline, as this causes \r\n confusion + on some platforms. */ + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_short=`cat conftest.val` +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +if test "$ac_cv_type_short" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (short) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (short) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_short=0 + fi +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.val +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_sizeof_short" >&5 +$as_echo "$ac_cv_sizeof_short" >&6; } + + + +cat >>confdefs.h <<_ACEOF +#define SIZEOF_SHORT $ac_cv_sizeof_short +_ACEOF + + + # The cast to long int works around a bug in the HP C Compiler +# version HP92453-01 B.11.11.23709.GP, which incorrectly rejects +# declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. +# This bug is HP SR number 8606223364. +{ $as_echo "$as_me:$LINENO: checking size of int" >&5 +$as_echo_n "checking size of int... " >&6; } +if test "${ac_cv_sizeof_int+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (int))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (int))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (int))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo= ac_hi= +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr '(' $ac_mid ')' + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_int=$ac_lo;; +'') if test "$ac_cv_type_int" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (int) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (int) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_int=0 + fi ;; +esac +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +static long int longval () { return (long int) (sizeof (int)); } +static unsigned long int ulongval () { return (long int) (sizeof (int)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + return 1; + if (((long int) (sizeof (int))) < 0) + { + long int i = longval (); + if (i != ((long int) (sizeof (int)))) + return 1; + fprintf (f, "%ld", i); + } + else + { + unsigned long int i = ulongval (); + if (i != ((long int) (sizeof (int)))) + return 1; + fprintf (f, "%lu", i); + } + /* Do not output a trailing newline, as this causes \r\n confusion + on some platforms. */ + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_int=`cat conftest.val` +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +if test "$ac_cv_type_int" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (int) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (int) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_int=0 + fi +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.val +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_sizeof_int" >&5 +$as_echo "$ac_cv_sizeof_int" >&6; } + + + +cat >>confdefs.h <<_ACEOF +#define SIZEOF_INT $ac_cv_sizeof_int +_ACEOF + + + # The cast to long int works around a bug in the HP C Compiler +# version HP92453-01 B.11.11.23709.GP, which incorrectly rejects +# declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. +# This bug is HP SR number 8606223364. +{ $as_echo "$as_me:$LINENO: checking size of long" >&5 +$as_echo_n "checking size of long... " >&6; } +if test "${ac_cv_sizeof_long+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo= ac_hi= +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr '(' $ac_mid ')' + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_long=$ac_lo;; +'') if test "$ac_cv_type_long" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (long) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (long) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_long=0 + fi ;; +esac +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +static long int longval () { return (long int) (sizeof (long)); } +static unsigned long int ulongval () { return (long int) (sizeof (long)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + return 1; + if (((long int) (sizeof (long))) < 0) + { + long int i = longval (); + if (i != ((long int) (sizeof (long)))) + return 1; + fprintf (f, "%ld", i); + } + else + { + unsigned long int i = ulongval (); + if (i != ((long int) (sizeof (long)))) + return 1; + fprintf (f, "%lu", i); + } + /* Do not output a trailing newline, as this causes \r\n confusion + on some platforms. */ + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_long=`cat conftest.val` +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +if test "$ac_cv_type_long" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (long) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (long) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_long=0 + fi +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.val +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_sizeof_long" >&5 +$as_echo "$ac_cv_sizeof_long" >&6; } + + + +cat >>confdefs.h <<_ACEOF +#define SIZEOF_LONG $ac_cv_sizeof_long +_ACEOF + + + # The cast to long int works around a bug in the HP C Compiler +# version HP92453-01 B.11.11.23709.GP, which incorrectly rejects +# declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. +# This bug is HP SR number 8606223364. +{ $as_echo "$as_me:$LINENO: checking size of long long" >&5 +$as_echo_n "checking size of long long... " >&6; } +if test "${ac_cv_sizeof_long_long+set}" = set; then + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long long))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long long))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long long))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long long))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_lo=$ac_mid; break +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo= ac_hi= +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long int) (sizeof (long long))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + ac_hi=$ac_mid +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_lo=`expr '(' $ac_mid ')' + 1` +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_long_long=$ac_lo;; +'') if test "$ac_cv_type_long_long" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (long long) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (long long) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_long_long=0 + fi ;; +esac +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +static long int longval () { return (long int) (sizeof (long long)); } +static unsigned long int ulongval () { return (long int) (sizeof (long long)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + return 1; + if (((long int) (sizeof (long long))) < 0) + { + long int i = longval (); + if (i != ((long int) (sizeof (long long)))) + return 1; + fprintf (f, "%ld", i); + } + else + { + unsigned long int i = ulongval (); + if (i != ((long int) (sizeof (long long)))) + return 1; + fprintf (f, "%lu", i); + } + /* Do not output a trailing newline, as this causes \r\n confusion + on some platforms. */ + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_long_long=`cat conftest.val` +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +if test "$ac_cv_type_long_long" = yes; then + { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ { $as_echo "$as_me:$LINENO: error: cannot compute sizeof (long long) +See \`config.log' for more details." >&5 +$as_echo "$as_me: error: cannot compute sizeof (long long) +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; }; } + else + ac_cv_sizeof_long_long=0 + fi +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.val +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_sizeof_long_long" >&5 +$as_echo "$ac_cv_sizeof_long_long" >&6; } + + + +cat >>confdefs.h <<_ACEOF +#define SIZEOF_LONG_LONG $ac_cv_sizeof_long_long +_ACEOF + + + if test x$ac_cv_sizeof_char = x1; then + cat >>confdefs.h <<\_ACEOF +#define int8_t signed char +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uint8_t unsigned char +_ACEOF + + fi + if test x$ac_cv_sizeof_short = x2; then + cat >>confdefs.h <<\_ACEOF +#define int16_t signed short +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uint16_t unsigned short +_ACEOF + + else + if test x$ac_cv_sizeof_int = x2; then + cat >>confdefs.h <<\_ACEOF +#define int16_t signed int +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uint16_t unsigned int +_ACEOF + + fi + fi + if test x$ac_cv_sizeof_int = x4; then + cat >>confdefs.h <<\_ACEOF +#define int32_t signed int +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uint32_t unsigned int +_ACEOF + + else + if test x$ac_cv_sizeof_long = x4; then + cat >>confdefs.h <<\_ACEOF +#define int32_t signed long +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uint32_t unsigned long +_ACEOF + + fi + fi + if test x$ac_cv_sizeof_long = x8; then + cat >>confdefs.h <<\_ACEOF +#define int64_t signed long +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uint64_t unsigned long +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define SDL_HAS_64BIT_TYPE 1 +_ACEOF + + else + if test x$ac_cv_sizeof_long_long = x8; then + cat >>confdefs.h <<\_ACEOF +#define int64_t signed long long +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uint64_t unsigned long long +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define SDL_HAS_64BIT_TYPE 1 +_ACEOF + + fi + fi + cat >>confdefs.h <<\_ACEOF +#define size_t unsigned int +_ACEOF + + cat >>confdefs.h <<\_ACEOF +#define uintptr_t unsigned long +_ACEOF + +fi + +# Standard C sources +SOURCES="$SOURCES $srcdir/src/*.c" +SOURCES="$SOURCES $srcdir/src/audio/*.c" +SOURCES="$SOURCES $srcdir/src/cdrom/*.c" +SOURCES="$SOURCES $srcdir/src/cpuinfo/*.c" +SOURCES="$SOURCES $srcdir/src/events/*.c" +SOURCES="$SOURCES $srcdir/src/file/*.c" +SOURCES="$SOURCES $srcdir/src/stdlib/*.c" +SOURCES="$SOURCES $srcdir/src/thread/*.c" +SOURCES="$SOURCES $srcdir/src/timer/*.c" +SOURCES="$SOURCES $srcdir/src/video/*.c" + + +# Check whether --enable-audio was given. +if test "${enable_audio+set}" = set; then + enableval=$enable_audio; +else + enable_audio=yes +fi + +if test x$enable_audio != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-video was given. +if test "${enable_video+set}" = set; then + enableval=$enable_video; +else + enable_video=yes +fi + +if test x$enable_video != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_VIDEO_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-events was given. +if test "${enable_events+set}" = set; then + enableval=$enable_events; +else + enable_events=yes +fi + +if test x$enable_events != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_EVENTS_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-joystick was given. +if test "${enable_joystick+set}" = set; then + enableval=$enable_joystick; +else + enable_joystick=yes +fi + +if test x$enable_joystick != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_JOYSTICK_DISABLED 1 +_ACEOF + +else + SOURCES="$SOURCES $srcdir/src/joystick/*.c" +fi +# Check whether --enable-cdrom was given. +if test "${enable_cdrom+set}" = set; then + enableval=$enable_cdrom; +else + enable_cdrom=yes +fi + +if test x$enable_cdrom != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_CDROM_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-threads was given. +if test "${enable_threads+set}" = set; then + enableval=$enable_threads; +else + enable_threads=yes +fi + +if test x$enable_threads != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_THREADS_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-timers was given. +if test "${enable_timers+set}" = set; then + enableval=$enable_timers; +else + enable_timers=yes +fi + +if test x$enable_timers != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_TIMERS_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-file was given. +if test "${enable_file+set}" = set; then + enableval=$enable_file; +else + enable_file=yes +fi + +if test x$enable_file != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_FILE_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-loadso was given. +if test "${enable_loadso+set}" = set; then + enableval=$enable_loadso; +else + enable_loadso=yes +fi + +if test x$enable_loadso != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_LOADSO_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-cpuinfo was given. +if test "${enable_cpuinfo+set}" = set; then + enableval=$enable_cpuinfo; +else + enable_cpuinfo=yes +fi + +if test x$enable_cpuinfo != xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_CPUINFO_DISABLED 1 +_ACEOF + +fi +# Check whether --enable-assembly was given. +if test "${enable_assembly+set}" = set; then + enableval=$enable_assembly; +else + enable_assembly=yes +fi + +if test x$enable_assembly = xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_ASSEMBLY_ROUTINES 1 +_ACEOF + +fi + +CheckOSS() +{ + # Check whether --enable-oss was given. +if test "${enable_oss+set}" = set; then + enableval=$enable_oss; +else + enable_oss=yes +fi + + if test x$enable_audio = xyes -a x$enable_oss = xyes; then + { $as_echo "$as_me:$LINENO: checking for OSS audio support" >&5 +$as_echo_n "checking for OSS audio support... " >&6; } + have_oss=no + if test x$have_oss != xyes; then + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + + #include + +int +main () +{ + + int arg = SNDCTL_DSP_SETFRAGMENT; + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + + have_oss=yes + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + fi + if test x$have_oss != xyes; then + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + + #include + +int +main () +{ + + int arg = SNDCTL_DSP_SETFRAGMENT; + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + + have_oss=yes + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_OSS_SOUNDCARD_H 1 +_ACEOF + + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + fi + { $as_echo "$as_me:$LINENO: result: $have_oss" >&5 +$as_echo "$have_oss" >&6; } + if test x$have_oss = xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_OSS 1 +_ACEOF + + SOURCES="$SOURCES $srcdir/src/audio/dsp/*.c" + SOURCES="$SOURCES $srcdir/src/audio/dma/*.c" + have_audio=yes + + # We may need to link with ossaudio emulation library + case "$host" in + *-*-openbsd*|*-*-netbsd*) + EXTRA_LDFLAGS="$EXTRA_LDFLAGS -lossaudio";; + esac + fi + fi +} + +CheckALSA() +{ + # Check whether --enable-alsa was given. +if test "${enable_alsa+set}" = set; then + enableval=$enable_alsa; +else + enable_alsa=yes +fi + + if test x$enable_audio = xyes -a x$enable_alsa = xyes; then + alsa_save_CFLAGS="$CFLAGS" +alsa_save_LDFLAGS="$LDFLAGS" +alsa_save_LIBS="$LIBS" +alsa_found=yes + + +# Check whether --with-alsa-prefix was given. +if test "${with_alsa_prefix+set}" = set; then + withval=$with_alsa_prefix; alsa_prefix="$withval" +else + alsa_prefix="" +fi + + + +# Check whether --with-alsa-inc-prefix was given. +if test "${with_alsa_inc_prefix+set}" = set; then + withval=$with_alsa_inc_prefix; alsa_inc_prefix="$withval" +else + alsa_inc_prefix="" +fi + + +# Check whether --enable-alsatest was given. +if test "${enable_alsatest+set}" = set; then + enableval=$enable_alsatest; enable_alsatest="$enableval" +else + enable_alsatest=yes +fi + + +{ $as_echo "$as_me:$LINENO: checking for ALSA CFLAGS" >&5 +$as_echo_n "checking for ALSA CFLAGS... " >&6; } +if test "$alsa_inc_prefix" != "" ; then + ALSA_CFLAGS="$ALSA_CFLAGS -I$alsa_inc_prefix" + CFLAGS="$CFLAGS -I$alsa_inc_prefix" +fi +{ $as_echo "$as_me:$LINENO: result: $ALSA_CFLAGS" >&5 +$as_echo "$ALSA_CFLAGS" >&6; } + +{ $as_echo "$as_me:$LINENO: checking for ALSA LDFLAGS" >&5 +$as_echo_n "checking for ALSA LDFLAGS... " >&6; } +if test "$alsa_prefix" != "" ; then + ALSA_LIBS="$ALSA_LIBS -L$alsa_prefix" + LDFLAGS="$LDFLAGS $ALSA_LIBS" +fi + +ALSA_LIBS="$ALSA_LIBS -lasound -lm -ldl -lpthread" +LIBS=`echo $LIBS | sed 's/-lm//'` +LIBS=`echo $LIBS | sed 's/-ldl//'` +LIBS=`echo $LIBS | sed 's/-lpthread//'` +LIBS=`echo $LIBS | sed 's/ //'` +LIBS="$ALSA_LIBS $LIBS" +{ $as_echo "$as_me:$LINENO: result: $ALSA_LIBS" >&5 +$as_echo "$ALSA_LIBS" >&6; } + +min_alsa_version=0.9.0 +{ $as_echo "$as_me:$LINENO: checking for libasound headers version >= $min_alsa_version" >&5 +$as_echo_n "checking for libasound headers version >= $min_alsa_version... " >&6; } +no_alsa="" + alsa_min_major_version=`echo $min_alsa_version | \ + sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\1/'` + alsa_min_minor_version=`echo $min_alsa_version | \ + sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\2/'` + alsa_min_micro_version=`echo $min_alsa_version | \ + sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\3/'` + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include + +int +main () +{ + +/* ensure backward compatibility */ +#if !defined(SND_LIB_MAJOR) && defined(SOUNDLIB_VERSION_MAJOR) +#define SND_LIB_MAJOR SOUNDLIB_VERSION_MAJOR +#endif +#if !defined(SND_LIB_MINOR) && defined(SOUNDLIB_VERSION_MINOR) +#define SND_LIB_MINOR SOUNDLIB_VERSION_MINOR +#endif +#if !defined(SND_LIB_SUBMINOR) && defined(SOUNDLIB_VERSION_SUBMINOR) +#define SND_LIB_SUBMINOR SOUNDLIB_VERSION_SUBMINOR +#endif + +# if(SND_LIB_MAJOR > $alsa_min_major_version) + exit(0); +# else +# if(SND_LIB_MAJOR < $alsa_min_major_version) +# error not present +# endif + +# if(SND_LIB_MINOR > $alsa_min_minor_version) + exit(0); +# else +# if(SND_LIB_MINOR < $alsa_min_minor_version) +# error not present +# endif + +# if(SND_LIB_SUBMINOR < $alsa_min_micro_version) +# error not present +# endif +# endif +# endif +exit(0); + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + { $as_echo "$as_me:$LINENO: result: found." >&5 +$as_echo "found." >&6; } +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + { $as_echo "$as_me:$LINENO: result: not present." >&5 +$as_echo "not present." >&6; } + + alsa_found=no + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +if test "x$enable_alsatest" = "xyes"; then + +{ $as_echo "$as_me:$LINENO: checking for snd_ctl_open in -lasound" >&5 +$as_echo_n "checking for snd_ctl_open in -lasound... " >&6; } +if test "${ac_cv_lib_asound_snd_ctl_open+set}" = set; then + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lasound $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char snd_ctl_open (); +int +main () +{ +return snd_ctl_open (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + ac_cv_lib_asound_snd_ctl_open=yes +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_cv_lib_asound_snd_ctl_open=no +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_asound_snd_ctl_open" >&5 +$as_echo "$ac_cv_lib_asound_snd_ctl_open" >&6; } +if test "x$ac_cv_lib_asound_snd_ctl_open" = x""yes; then + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBASOUND 1 +_ACEOF + + LIBS="-lasound $LIBS" + +else + + alsa_found=no + +fi + +fi + +if test "x$alsa_found" = "xyes" ; then + have_alsa=yes + LIBS=`echo $LIBS | sed 's/-lasound//g'` + LIBS=`echo $LIBS | sed 's/ //'` + LIBS="-lasound $LIBS" +fi +if test "x$alsa_found" = "xno" ; then + have_alsa=no + CFLAGS="$alsa_save_CFLAGS" + LDFLAGS="$alsa_save_LDFLAGS" + LIBS="$alsa_save_LIBS" + ALSA_CFLAGS="" + ALSA_LIBS="" +fi + + + + + # Restore all flags from before the ALSA detection runs + CFLAGS="$alsa_save_CFLAGS" + LDFLAGS="$alsa_save_LDFLAGS" + LIBS="$alsa_save_LIBS" + if test x$have_alsa = xyes; then + # Check whether --enable-alsa-shared was given. +if test "${enable_alsa_shared+set}" = set; then + enableval=$enable_alsa_shared; +else + enable_alsa_shared=yes +fi + + alsa_lib=`find_lib "libasound.so.*" "$ALSA_LIBS" | sed 's/.*\/\(.*\)/\1/; q'` + + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_ALSA 1 +_ACEOF + + SOURCES="$SOURCES $srcdir/src/audio/alsa/*.c" + EXTRA_CFLAGS="$EXTRA_CFLAGS $ALSA_CFLAGS" + if test x$have_loadso != xyes && \ + test x$enable_alsa_shared = xyes; then + { $as_echo "$as_me:$LINENO: WARNING: You must have SDL_LoadObject() support for dynamic ALSA loading" >&5 +$as_echo "$as_me: WARNING: You must have SDL_LoadObject() support for dynamic ALSA loading" >&2;} + fi + if test x$have_loadso = xyes && \ + test x$enable_alsa_shared = xyes && test x$alsa_lib != x; then + echo "-- dynamic libasound -> $alsa_lib" + cat >>confdefs.h <<_ACEOF +#define SDL_AUDIO_DRIVER_ALSA_DYNAMIC "$alsa_lib" +_ACEOF + + else + EXTRA_LDFLAGS="$EXTRA_LDFLAGS $ALSA_LIBS" + fi + have_audio=yes + fi + fi +} + +CheckDMEDIA() +{ + if test x$enable_audio = xyes; then + { $as_echo "$as_me:$LINENO: checking for dmedia audio support" >&5 +$as_echo_n "checking for dmedia audio support... " >&6; } + have_dmedia=no + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + + #include + +int +main () +{ + + ALport audio_port; + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + + have_dmedia=yes + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + { $as_echo "$as_me:$LINENO: result: $have_dmedia" >&5 +$as_echo "$have_dmedia" >&6; } + # Set up files for the audio library + if test x$have_dmedia = xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_DMEDIA 1 +_ACEOF + + SOURCES="$SOURCES $srcdir/src/audio/dmedia/*.c" + EXTRA_LDFLAGS="$EXTRA_LDFLAGS -laudio" + have_audio=yes + fi + fi +} + +CheckMME() +{ + case $ARCH in + osf) + ;; + *) + return + ;; + esac + if test x$enable_audio = xyes; then + { $as_echo "$as_me:$LINENO: checking for MME audio support" >&5 +$as_echo_n "checking for MME audio support... " >&6; } + MME_CFLAGS="-I/usr/include/mme" + MME_LIBS="-lmme" + have_mme=no + save_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS $MME_CFLAGS" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + + #include + +int +main () +{ + + HWAVEOUT sound; + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + + have_mme=yes + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + CFLAGS="$save_CFLAGS" + { $as_echo "$as_me:$LINENO: result: $have_mme" >&5 +$as_echo "$have_mme" >&6; } + # Set up files for the audio library + if test x$have_mme = xyes; then + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_MMEAUDIO 1 +_ACEOF + + SOURCES="$SOURCES $srcdir/src/audio/mme/*.c" + EXTRA_CFLAGS="$EXTRA_CFLAGS $MME_CFLAGS" + EXTRA_LDFLAGS="$EXTRA_LDFLAGS $MME_LIBS" + have_audio=yes + fi + fi +} + +CheckESD() +{ + # Check whether --enable-esd was given. +if test "${enable_esd+set}" = set; then + enableval=$enable_esd; +else + enable_esd=yes +fi + + if test x$enable_audio = xyes -a x$enable_esd = xyes; then + +# Check whether --with-esd-prefix was given. +if test "${with_esd_prefix+set}" = set; then + withval=$with_esd_prefix; esd_prefix="$withval" +else + esd_prefix="" +fi + + +# Check whether --with-esd-exec-prefix was given. +if test "${with_esd_exec_prefix+set}" = set; then + withval=$with_esd_exec_prefix; esd_exec_prefix="$withval" +else + esd_exec_prefix="" +fi + +# Check whether --enable-esdtest was given. +if test "${enable_esdtest+set}" = set; then + enableval=$enable_esdtest; +else + enable_esdtest=yes +fi + + + if test x$esd_exec_prefix != x ; then + esd_args="$esd_args --exec-prefix=$esd_exec_prefix" + if test x${ESD_CONFIG+set} != xset ; then + ESD_CONFIG=$esd_exec_prefix/bin/esd-config + fi + fi + if test x$esd_prefix != x ; then + esd_args="$esd_args --prefix=$esd_prefix" + if test x${ESD_CONFIG+set} != xset ; then + ESD_CONFIG=$esd_prefix/bin/esd-config + fi + fi + + # Extract the first word of "esd-config", so it can be a program name with args. +set dummy esd-config; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_path_ESD_CONFIG+set}" = set; then + $as_echo_n "(cached) " >&6 +else + case $ESD_CONFIG in + [\\/]* | ?:[\\/]*) + ac_cv_path_ESD_CONFIG="$ESD_CONFIG" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_path_ESD_CONFIG="$as_dir/$ac_word$ac_exec_ext" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + + test -z "$ac_cv_path_ESD_CONFIG" && ac_cv_path_ESD_CONFIG="no" + ;; +esac +fi +ESD_CONFIG=$ac_cv_path_ESD_CONFIG +if test -n "$ESD_CONFIG"; then + { $as_echo "$as_me:$LINENO: result: $ESD_CONFIG" >&5 +$as_echo "$ESD_CONFIG" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + min_esd_version=0.2.8 + { $as_echo "$as_me:$LINENO: checking for ESD - version >= $min_esd_version" >&5 +$as_echo_n "checking for ESD - version >= $min_esd_version... " >&6; } + no_esd="" + if test "$ESD_CONFIG" = "no" ; then + no_esd=yes + else + ESD_CFLAGS=`$ESD_CONFIG $esdconf_args --cflags` + ESD_LIBS=`$ESD_CONFIG $esdconf_args --libs` + + esd_major_version=`$ESD_CONFIG $esd_args --version | \ + sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\1/'` + esd_minor_version=`$ESD_CONFIG $esd_args --version | \ + sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\2/'` + esd_micro_version=`$ESD_CONFIG $esd_config_args --version | \ + sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\3/'` + if test "x$enable_esdtest" = "xyes" ; then + ac_save_CFLAGS="$CFLAGS" + ac_save_LIBS="$LIBS" + CFLAGS="$CFLAGS $ESD_CFLAGS" + LIBS="$LIBS $ESD_LIBS" + rm -f conf.esdtest + if test "$cross_compiling" = yes; then + echo $ac_n "cross compiling; assumed OK... $ac_c" +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#include +#include +#include + +char* +my_strdup (char *str) +{ + char *new_str; + + if (str) + { + new_str = malloc ((strlen (str) + 1) * sizeof(char)); + strcpy (new_str, str); + } + else + new_str = NULL; + + return new_str; +} + +int main () +{ + int major, minor, micro; + char *tmp_version; + + system ("touch conf.esdtest"); + + /* HP/UX 9 (%@#!) writes to sscanf strings */ + tmp_version = my_strdup("$min_esd_version"); + if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, µ) != 3) { + printf("%s, bad version string\n", "$min_esd_version"); + exit(1); + } + + if (($esd_major_version > major) || + (($esd_major_version == major) && ($esd_minor_version > minor)) || + (($esd_major_version == major) && ($esd_minor_version == minor) && ($esd_micro_version >= micro))) + { + return 0; + } + else + { + printf("\n*** 'esd-config --version' returned %d.%d.%d, but the minimum version\n", $esd_major_version, $esd_minor_version, $esd_micro_version); + printf("*** of ESD required is %d.%d.%d. If esd-config is correct, then it is\n", major, minor, micro); + printf("*** best to upgrade to the required version.\n"); + printf("*** If esd-config was wrong, set the environment variable ESD_CONFIG\n"); + printf("*** to point to the correct copy of esd-config, and remove the file\n"); + printf("*** config.cache before re-running configure\n"); + return 1; + } +} + + +_ACEOF +rm -f conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + $as_echo "$as_me: program exited with status $ac_status" >&5 +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +no_esd=yes +fi +rm -rf conftest.dSYM +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + + + CFLAGS="$ac_save_CFLAGS" + LIBS="$ac_save_LIBS" + fi + fi + if test "x$no_esd" = x ; then + { $as_echo "$as_me:$LINENO: result: yes" >&5 +$as_echo "yes" >&6; } + have_esd=yes + else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } + if test "$ESD_CONFIG" = "no" ; then + echo "*** The esd-config script installed by ESD could not be found" + echo "*** If ESD was installed in PREFIX, make sure PREFIX/bin is in" + echo "*** your path, or set the ESD_CONFIG environment variable to the" + echo "*** full path to esd-config." + else + if test -f conf.esdtest ; then + : + else + echo "*** Could not run ESD test program, checking why..." + CFLAGS="$CFLAGS $ESD_CFLAGS" + LIBS="$LIBS $ESD_LIBS" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#include + +int +main () +{ + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_link") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then + echo "*** The test program compiled, but did not run. This usually means" + echo "*** that the run-time linker is not finding ESD or finding the wrong" + echo "*** version of ESD. If it is not finding ESD, you'll need to set your" + echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point" + echo "*** to the installed location Also, make sure you have run ldconfig if that" + echo "*** is required on your system" + echo "***" + echo "*** If you have an old version installed, it is best to remove it, although" + echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH" +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + echo "*** The test program failed to compile or link. See the file config.log for the" + echo "*** exact error that occured. This usually means ESD was incorrectly installed" + echo "*** or that you have moved ESD since it was installed. In the latter case, you" + echo "*** may want to edit the esd-config script: $ESD_CONFIG" +fi + +rm -rf conftest.dSYM +rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ + conftest$ac_exeext conftest.$ac_ext + CFLAGS="$ac_save_CFLAGS" + LIBS="$ac_save_LIBS" + fi + fi + ESD_CFLAGS="" + ESD_LIBS="" + have_esd=no + fi + + + rm -f conf.esdtest + + if test x$have_esd = xyes; then + # Check whether --enable-esd-shared was given. +if test "${enable_esd_shared+set}" = set; then + enableval=$enable_esd_shared; +else + enable_esd_shared=yes +fi + + esd_lib=`find_lib "libesd.so.*" "$ESD_LIBS" | sed 's/.*\/\(.*\)/\1/; q'` + + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_ESD 1 +_ACEOF + + SOURCES="$SOURCES $srcdir/src/audio/esd/*.c" + EXTRA_CFLAGS="$EXTRA_CFLAGS $ESD_CFLAGS" + if test x$have_loadso != xyes && \ + test x$enable_esd_shared = xyes; then + { $as_echo "$as_me:$LINENO: WARNING: You must have SDL_LoadObject() support for dynamic ESD loading" >&5 +$as_echo "$as_me: WARNING: You must have SDL_LoadObject() support for dynamic ESD loading" >&2;} + fi + if test x$have_loadso = xyes && \ + test x$enable_esd_shared = xyes && test x$esd_lib != x; then + echo "-- dynamic libesd -> $esd_lib" + cat >>confdefs.h <<_ACEOF +#define SDL_AUDIO_DRIVER_ESD_DYNAMIC "$esd_lib" +_ACEOF + + else + EXTRA_LDFLAGS="$EXTRA_LDFLAGS $ESD_LIBS" + fi + have_audio=yes + fi + fi +} + +CheckPulseAudio() +{ + # Check whether --enable-pulseaudio was given. +if test "${enable_pulseaudio+set}" = set; then + enableval=$enable_pulseaudio; +else + enable_pulseaudio=yes +fi + + if test x$enable_audio = xyes -a x$enable_pulseaudio = xyes; then + audio_pulse=no + + PULSE_REQUIRED_VERSION=0.9 + + # Extract the first word of "pkg-config", so it can be a program name with args. +set dummy pkg-config; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_path_PKG_CONFIG+set}" = set; then + $as_echo_n "(cached) " >&6 +else + case $PKG_CONFIG in + [\\/]* | ?:[\\/]*) + ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_path_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + + test -z "$ac_cv_path_PKG_CONFIG" && ac_cv_path_PKG_CONFIG="no" + ;; +esac +fi +PKG_CONFIG=$ac_cv_path_PKG_CONFIG +if test -n "$PKG_CONFIG"; then + { $as_echo "$as_me:$LINENO: result: $PKG_CONFIG" >&5 +$as_echo "$PKG_CONFIG" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + { $as_echo "$as_me:$LINENO: checking for PulseAudio $PULSE_REQUIRED_VERSION support" >&5 +$as_echo_n "checking for PulseAudio $PULSE_REQUIRED_VERSION support... " >&6; } + if test x$PKG_CONFIG != xno; then + if $PKG_CONFIG --atleast-pkgconfig-version 0.7 && $PKG_CONFIG --atleast-version $PULSE_REQUIRED_VERSION libpulse-simple; then + PULSE_CFLAGS=`$PKG_CONFIG --cflags libpulse-simple` + PULSE_LIBS=`$PKG_CONFIG --libs libpulse-simple` + audio_pulse=yes + fi + fi + { $as_echo "$as_me:$LINENO: result: $audio_pulse" >&5 +$as_echo "$audio_pulse" >&6; } + + if test x$audio_pulse = xyes; then + # Check whether --enable-pulseaudio-shared was given. +if test "${enable_pulseaudio_shared+set}" = set; then + enableval=$enable_pulseaudio_shared; +else + enable_pulseaudio_shared=yes +fi + + pulse_lib=`find_lib "libpulse-simple.so.*" "$PULSE_LIBS" | sed 's/.*\/\(.*\)/\1/; q'` + + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_PULSE 1 +_ACEOF + + SOURCES="$SOURCES $srcdir/src/audio/pulse/*.c" + EXTRA_CFLAGS="$EXTRA_CFLAGS $PULSE_CFLAGS" + if test x$have_loadso != xyes && \ + test x$enable_pulseaudio_shared = xyes; then + { $as_echo "$as_me:$LINENO: WARNING: You must have SDL_LoadObject() support for dynamic PulseAudio loading" >&5 +$as_echo "$as_me: WARNING: You must have SDL_LoadObject() support for dynamic PulseAudio loading" >&2;} + fi + if test x$have_loadso = xyes && \ + test x$enable_pulseaudio_shared = xyes && test x$pulse_lib != x; then + echo "-- dynamic libpulse-simple -> $pulse_lib" + cat >>confdefs.h <<_ACEOF +#define SDL_AUDIO_DRIVER_PULSE_DYNAMIC "$pulse_lib" +_ACEOF + + else + EXTRA_LDFLAGS="$EXTRA_LDFLAGS $PULSE_LIBS" + fi + have_audio=yes + fi + fi +} + +CheckARTSC() +{ + # Check whether --enable-arts was given. +if test "${enable_arts+set}" = set; then + enableval=$enable_arts; +else + enable_arts=yes +fi + + if test x$enable_audio = xyes -a x$enable_arts = xyes; then + # Extract the first word of "artsc-config", so it can be a program name with args. +set dummy artsc-config; ac_word=$2 +{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_path_ARTSCONFIG+set}" = set; then + $as_echo_n "(cached) " >&6 +else + case $ARTSCONFIG in + [\\/]* | ?:[\\/]*) + ac_cv_path_ARTSCONFIG="$ARTSCONFIG" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_path_ARTSCONFIG="$as_dir/$ac_word$ac_exec_ext" + $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + + ;; +esac +fi +ARTSCONFIG=$ac_cv_path_ARTSCONFIG +if test -n "$ARTSCONFIG"; then + { $as_echo "$as_me:$LINENO: result: $ARTSCONFIG" >&5 +$as_echo "$ARTSCONFIG" >&6; } +else + { $as_echo "$as_me:$LINENO: result: no" >&5 +$as_echo "no" >&6; } +fi + + + if test x$ARTSCONFIG = x -o x$ARTSCONFIG = x'"$ARTSCONFIG"'; then + : # arts isn't installed + else + ARTS_CFLAGS=`$ARTSCONFIG --cflags` + ARTS_LIBS=`$ARTSCONFIG --libs` + { $as_echo "$as_me:$LINENO: checking for aRts development environment" >&5 +$as_echo_n "checking for aRts development environment... " >&6; } + audio_arts=no + save_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS $ARTS_CFLAGS" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + + #include + +int +main () +{ + + arts_stream_t stream; + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\"" +$as_echo "$ac_try_echo") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + + audio_arts=yes + +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + CFLAGS="$save_CFLAGS" + { $as_echo "$as_me:$LINENO: result: $audio_arts" >&5 +$as_echo "$audio_arts" >&6; } + if test x$audio_arts = xyes; then + # Check whether --enable-arts-shared was given. +if test "${enable_arts_shared+set}" = set; then + enableval=$enable_arts_shared; +else + enable_arts_shared=yes +fi + + arts_lib=`find_lib "libartsc.so.*" "$ARTS_LIBS" | sed 's/.*\/\(.*\)/\1/; q'` + + cat >>confdefs.h <<\_ACEOF +#define SDL_AUDIO_DRIVER_ARTS 1 +_ACEOF + + SOURCES="$SOURCES $srcdir/src/audio/arts/*.c" + EXTRA_CFLAGS="$EXTRA_CFLAGS $ARTS_CFLAGS" + if test x$have_loadso != xyes && \ + test x$enable_arts_shared = xyes; then + { $as_echo "$as_me:$LINENO: WARNING: You must have SDL_LoadObject() support for dynamic ARTS loading" >&5 +$as_echo "$as_me: WARNING: You must have SDL_LoadObject() support for dynamic ARTS loading" >&2;} + fi + if test x$have_loadso = xyes && \ + test x$enable_arts_shared = xyes && test x$arts_lib != x; then + echo "-- dynamic libartsc -> $arts_lib" + cat >>confdefs.h <<_ACEOF +#define SDL_AUDIO_DRIVER_ARTS_DYNAMIC "$arts_lib" +_ACEOF + + else + EXTRA_LDFLAGS="$EXTRA_LDFLAGS $ARTS_LIBS" + fi + have_audio=yes + fi + fi + fi +} + +CheckNAS() +{ + # Check whether --enable-nas was given. +if test "${enable_nas+set}" = set; then + enableval=$enable_nas; +else + enable_nas=yes +fi + + if test x$enable_audio = xyes -a x$enable_nas = xyes; then + if test "${ac_cv_header_audio_audiolib_h+set}" = set; then + { $as_echo "$as_me:$LINENO: checking for audio/audiolib.h" >&5 +$as_echo_n "checking for audio/audiolib.h... " >&6; } +if test "${ac_cv_header_audio_audiolib_h+set}" = set; then + $as_echo_n "(cached) " >&6 +fi +{ $as_echo "$as_me:$LINENO: result: $ac_cv_header_audio_audiolib_h" >&5 +$as_echo "$ac_cv_header_audio_audiolib_h" >&6; } +else + # Is the header compilable? +{ $as_echo "$as_me:$LINENO: checking audio/audiolib.h usability" >&5 +$as_echo_n "checking audio/audiolib.h usability... " >&6; } +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include

    +This source is stable, and is fully tested on all supported platforms.
    +Please send bug reports or questions to the SDL mailing list:
    +
    http://www.libsdl.org/mailing-list.php
    +The latest stable release may be found on the + SDL website. +

    + +

    API Documentation

    + +[separator] + +

    SDL 1.2.14 Release Notes

    +

    +SDL 1.2.14 is a significant bug fix release and a recommended update. +

    + +

    General Notes

    + +
    +

    + Fixed flicker when resizing the SDL window +

    +

    + Fixed crash in SDL_SetGammaRamp() +

    +

    + Fixed freeze in SDL_memset() with 0 length when assembly code is disabled. +

    +

    + Added SDL_DISABLE_LOCK_KEYS environment variable to enable normal up/down events for Caps-Lock and Num-Lock keys. +

    +

    + Fixed audio quality problem when converting between 22050 Hz and 44100 Hz. +

    +

    + Fixed a threading crash when a few threads are rapidly created and complete. +

    +

    + Increased accuracy of alpha blending routines. +

    +

    + Fixed crash loading BMP files saved with the scanlines inverted. +

    +

    + Fixed mouse coordinate clamping if SDL_SetVideoMode() isn't called in response to SDL_VIDEORESIZE event. +

    +

    + Added doxygen documentation for the SDL API headers. +

    +
    + +

    Unix Notes

    + +
    +

    + Fixed potential memory corruption due to assembly bug with SDL_revcpy() +

    +

    + Fixed crashes trying to detect SSE features on x86_64 architecture. +

    +

    + Fixed assembly for GCC optimized 50% alpha blending blits. +

    +

    + Added configure option --enable-screensaver, to allow enabling the screensaver by default. +

    +

    + Use XResetScreenSaver() instead of disabling screensaver entirely. +

    +

    + Removed the maximum window size limitation on X11. +

    +

    + Fixed SDL_GL_SWAP_CONTROL on X11. +

    +

    + Fixed setting the X11 window input hint. +

    +

    + Fixed distorted X11 window icon for some visuals. +

    +

    + Fixed detecting X11 libraries for dynamic loading on 64-bit Linux. +

    +

    + SDL_GL_GetAttribute(SDL_GL_SWAP_CONTROL) returns the correct value with GLX_SGI_swap_control. +

    +

    + Added SDL_VIDEO_FULLSCREEN_DISPLAY as a preferred synonym for SDL_VIDEO_FULLSCREEN_HEAD on X11. +

    +

    + The SDL_VIDEO_FULLSCREEN_DISPLAY environment variable can be set to 0 to place fullscreen SDL windows on the first Xinerama screen. +

    +

    + Added the SDL_VIDEO_FBCON_ROTATION environment variable to control output orientation on the framebuffer console. +
    + Valid values are: +

      +
    • not set - Not rotating, no shadow. +
    • "NONE" - Not rotating, but still using shadow. +
    • "CW" - Rotating screen clockwise. +
    • "UD" - Rotating screen upside down. +
    • "CCW" - Rotating screen counter clockwise. +
    +

    +

    + Fixed DirectFB detection on some Linux distributions. +

    +

    + Added code to use the PS3 SPE processors for YUV conversion on Linux. +

    +

    + Updated ALSA support to the latest stable API +

    +

    + ALSA is now preferred over OSS audio. (SDL_AUDIODRIVER=dsp will restore the previous behavior.) +

    +

    + Improved support for PulseAudio +

    +

    + The Network Audio System support is now dynamically loaded at runtime. +

    +

    + Fixed crash with the MP-8866 Dual USB Joypad on newer Linux kernels. +

    +

    + Fixed crash in SDL_Quit() when a joystick has been unplugged. +

    +
    + +

    Windows Notes

    + +
    +

    + Verified 100% compatibility with Windows 7. +

    +

    + Prevent loss of OpenGL context when setting the video mode in response to a window resize event. +

    +

    + Fixed video initialization with SDL_WINDOWID on Windows XP. +

    +

    + Improved mouse input responsiveness for first-person-shooter games. +

    +

    + IME messages are now generated for localized input. +

    +

    + SDL_RWFromFile() takes a UTF-8 filename when opening a file. +

    +

    + The SDL_STDIO_REDIRECT environment variable can be used to override whether SDL redirects stdio to stdout.txt and stderr.txt. +

    +

    + Fixed dynamic object loading on Windows CE. +

    +
    + +

    Mac OS X Notes

    + +
    +

    + SDL now builds on Mac OS X 10.6 (Snow Leopard). +
    + Eric Wing posted a good rundown on the numerous changes here: http://playcontrol.net/ewing/jibberjabber/big_behind-the-scenes_chang.html +

    +

    + The X11 video driver is built by default. +

    +

    + Fixed SDL_VIDEO_WINDOW_POS environment variable for Quartz target. +

    +

    + Fixed setting the starting working directory in release builds. +

    +
    + +[separator] + +

    SDL 1.2.13 Release Notes

    +

    +SDL 1.2.13 is a minor bug fix release. +

    + +

    General Notes

    + +
    +

    + Fixed link error when building with Intel Compiler 10. +

    +

    + Removed stray C++ comment from public headers. +

    +
    + +

    Unix Notes

    + +
    +

    + Fixed crash in SDL_SoftStretch() on secure operating systems. +

    +

    + Fixed undefined symbol on X11 implementations without UTF-8 support. +

    +

    + Worked around BadAlloc error when using XVideo on the XFree86 Intel Integrated Graphics driver. +

    +

    + Scan for all joysticks on Linux instead of stopping at one that was removed. +

    +

    + Fixed use of sdl-config arguments in sdl.m4 +

    +
    + +

    Windows Notes

    + +
    +

    + Fixed crash when a video driver reports higher than 32 bpp video modes. +

    +

    + Fixed restoring the desktop after setting a 24-bit OpenGL video mode. +

    +

    + Fixed window titles on Windows 95/98/ME. +

    +

    + Added SDL_BUTTON_X1 and SDL_BUTTON_X2 constants for extended mouse buttons. +

    +

    + Added support for quoted command line arguments. +

    +
    + +

    Mac OS X Notes

    + +
    +

    + SDL now builds on Mac OS X 10.5 (Leopard). +

    +

    + Fixed high frequency crash involving text input. +

    +

    + Fixed beeping when the escape key is pressed and UNICODE translation is enabled. +

    +

    + Improved trackpad scrolling support. +

    +

    + Fixed joystick hat reporting for certain joysticks. +

    +
    + +[separator] + +

    SDL 1.2.12 Release Notes

    +

    +SDL 1.2.12 is a minor bug fix release. +

    + +

    General Notes

    + +
    +

    + Added support for the PulseAudio sound server: http://www.pulseaudio.org/ +

    +

    + Added SDL_VIDEO_ALLOW_SCREENSAVER to override SDL's disabling of the screensaver on Mac OS X, Windows, and X11. +

    +

    + Fixed buffer overrun crash when resampling audio rates. +

    +

    + Fixed audio bug where converting to mono was doubling the volume. +

    +

    + Fixed off-by-one error in the C implementation of SDL_revcpy() +

    +

    + Fixed compiling with Sun Studio. +

    +

    + Support for AmigaOS has been removed from the main SDL code. +

    +

    + Support for Nokia 9210 "EPOC" driver has been removed from the main SDL code. +

    +

    + Unofficial support for the S60/SymbianOS platform has been added. +

    +

    + Unofficial support for the Nintendo DS platform has been added. +

    +

    + Reenabled MMX assembly for YUV overlay processing (GNU C Compiler only). +

    +
    + +

    Unix Notes

    + +
    +

    + Fixed detection of X11 DGA mouse support. +

    +

    + Improved XIM support for asian character sets. +

    +

    + The GFX_Display has been added to the X11 window information in SDL_syswm.h. +

    +

    + Fixed PAGE_SIZE compile error in the fbcon video driver on newer Linux kernels. +

    +

    + Fixed hang or crash at startup if aRts can't access the hardware. +

    +

    + Fixed relative mouse mode when the cursor starts outside the X11 window. +

    +

    + Fixed accidental free of stack memory in X11 mouse acceleration code. +

    +

    + Closed minor memory leak in XME code. +

    +

    + Fixed TEXTRELs in the library to resolve some PIC issues. +

    +
    + +

    Windows Notes

    + +
    +

    + The GDI video driver makes better use of the palette in 8-bit modes. +

    +

    + The windib driver now supports more mouse buttons with WM_XBUTTON events. +

    +

    + On Windows, SDL_SetVideoMode() will re-create the window instead of failing if the multisample settings are changed. +

    +

    + Added support for UTF-8 window titles on Windows. +

    +

    + Fixed joystick detection on Windows. +

    +

    + Improved performance with Win32 file I/O. +

    +

    + Fixed HBITMAP leak in GAPI driver. +

    +
    + +

    Mac OS X Notes

    + +
    +

    + Added support for multi-axis controllers like 3Dconnxion's SpaceNavigator on Mac OS X. +

    +

    + Fixed YUV overlay crash inside Quicktime on Intel Mac OS X. +

    +

    + Fixed blitting alignment in Altivec alpha blit functions. +

    +

    + Keys F13, F14, and F15 are now usable on Apple keyboards under Mac OS X. +

    +

    + Fixed joystick calibration code on Mac OS X. +

    +

    + Fixed mouse jitter when multiple motion events are queued up in Mac OS X. +

    +

    + Fixed changing the cursor in fullscreen mode on Mac OS X. +

    +
    + +

    Mac OS Classic Notes

    + +
    +

    + Added support for gamma ramps to both toolbox and DrawSprocket video drivers. +

    +
    + +

    BeOS Notes

    + +
    +

    + Implemented mouse grabbing and mouse relative mode on BeOS. +

    +
    + +[separator] + +

    SDL 1.2.11 Release Notes

    +

    +SDL 1.2.11 is a minor bug fix release. +

    + +

    Unix Notes

    + +
    +

    + Dynamic X11 loading is only enabled with gcc 4 supporting -fvisibility=hidden. This fixes crashes related to symbol collisions, and allows building on Solaris and IRIX. +

    +

    + Fixed building SDL with Xinerama disabled. +

    +

    + Fixed DRI OpenGL library loading, using RTLD_GLOBAL in dlopen(). +

    +

    + Added pkgconfig configuration support. +

    +
    + +

    Windows Notes

    + +
    +

    + Setting SDL_GL_SWAP_CONTROL now works with Windows OpenGL. +

    +

    + The Win32 window positioning code works properly for windows with menus. +

    +

    + DirectSound audio quality has been improved on certain sound cards. +

    +

    + Fixed 5.1 audio channel ordering on Windows and Mac OS X. +

    +

    + Plugged a couple of minor memory leaks in the windib video driver. +

    +

    + Fixed type collision with stdint.h when building with gcc on Win32. +

    +

    + Fixed building with the Digital Mars Compiler on Win32. +

    +
    + +

    Mac OS X Notes

    + +
    +

    + The Quartz video driver supports 32x32 cursors on Mac OS X 10.3 and above. +

    +
    + +[separator] + +

    SDL 1.2.10 Release Notes

    +

    +SDL 1.2.10 is a major release, featuring a revamp of the build system and many API improvements and bug fixes. +

    +

    API enhancements

    +
      +
    • + If SDL_OpenAudio() is passed zero for the desired format + fields, the following environment variables will be used + to fill them in: +
      
      +		SDL_AUDIO_FREQUENCY
      +		SDL_AUDIO_FORMAT
      +		SDL_AUDIO_CHANNELS
      +		SDL_AUDIO_SAMPLES
      +
      + If an environment variable is not specified, it will be set + to a reasonable default value. +
    • + SDL_SetVideoMode() now accepts 0 for width or height and will use + the current video mode (or the desktop mode if no mode has been set.) +
    • + Added current_w and current_h to the SDL_VideoInfo structure, + which is set to the desktop resolution during video intialization, + and then set to the current resolution when a video mode is set. +
    • + SDL_GL_LoadLibrary() will load the system default OpenGL library + if it is passed NULL as a parameter. +
    • + Added SDL_GL_SWAP_CONTROL to wait for vsync in OpenGL applications. +
    • + Added SDL_GL_ACCELERATED_VISUAL to guarantee hardware acceleration. +
    • + SDL_WM_SetCaption() now officially takes UTF-8 title and icon strings, and displays international characters on supported platforms. +
    • + Added SDL_GetKeyRepeat() to query the key repeat settings. +
    • + Added the "dummy" audio driver, which can be used to emulate audio + output without a sound card. +
    • + Added SDL_config.h, with defaults for various build environments. +
    + +

    General Notes

    + +
    +

    + The SDL website now has an RSS feed! +

    + The SDL development source code is now managed with Subversion. +

    + SDL now uses the Bugzilla bug tracking system, hosted by icculus.org. +

    + SDL is licensed under version 2.1 of the GNU Lesser General Public License. +

    + The entire build system has been revamped to make it much more portable, including versions of C library functions to make it possible to run SDL on a minimal embedded environment. See README.Porting in the SDL source distribution for information on how to port SDL to a new platform. +

    + SDL_opengl.h has been updated with the latest glext.h from http://oss.sgi.com/projects/ogl-sample/registry/ +

    + Alex Volkov contributed highly optimized RGB <-> RGBA blitters. +

    + +

    Unix Notes

    + +
    +

    + The X11 libraries are dynamically loaded at runtime by default. This allows the distributed version of SDL to run on systems without X11 libraries installed. +

    + The XiG XME extension code is now included in the X11 video driver by default. +

    + XRandR support for video mode switching has been added to the X11 driver, but is disabled because of undesired interactions with window managers. You can enable this by setting the environment variable SDL_VIDEO_X11_XRANDR to 1. +

    + Xinerama multi-head displays are properly handled now, and the SDL_VIDEO_FULLSCREEN_HEAD environment variable can be used to select the screen used for fullscreen video modes. Note that changing the video modes only works on screen 0. +

    + XVidMode video modes are now sorted so they maintain the refresh rates specified in the X11 configuration file. +

    + SDL windows are no longer transparent in X11 compositing systems like XGL. +

    + The mouse is properly released by the X11 video driver if the fullscreen window loses focus. +

    + The X11 input driver now uses XIM to handle international input. +

    + The screensaver and DPMS monitor blanking are disabled while SDL games are running under the X11 and DGA video drivers. This behavior will be formalized and selectable in SDL 1.3. +

    + Fixed a bug preventing stereo OpenGL contexts from being selected on the X11 driver. +

    + The DGA video driver now waits for pending blits involving surfaces before they are freed. This prevents display oddities when using SDL_DisplayFormat() to convert many images. +

    + The framebuffer console video driver now has a parser for /etc/fb.modes for improved video mode handling. +

    + The framebuffer console video driver now allows asynchronous VT switching, and restores the full contents of the screen when switched back. +

    + The framebuffer console now uses CTRL-ALT-FN to switch virtual terminals, to avoid collisions with application key bindings. +

    + The framebuffer console input driver correctly sets IMPS/2 mode for wheel mice. It also properly detects when gpm is in IMPS/2 protocol mode, or passing raw protocol from an IMPS/2 mouse. +

    + The SVGAlib video driver now has support for banked (non-linear) video modes. +

    + A video driver for OpenBSD on the Sharp Zaurus has been contributed by Staffan Ulfberg. See the file README.wscons in the SDL source distribution for details. +

    + Many patches have been incorporated from *BSD ports. +

    + +

    Windows Notes

    + +
    +

    + The "windib" video driver is the default now, to prevent problems with certain laptops, 64-bit Windows, and Windows Vista. The DirectX driver is still available, and can be selected by setting the environment variable SDL_VIDEODRIVER to "directx". +

    + SDL has been ported to 64-bit Windows. +

    + Dmitry Yakimov contributed a GAPI video driver for Windows CE. +

    + The default fullscreen refresh rate has been increased to match the desktop refresh rate, when using equivalent resolutions. A full API for querying and selecting refresh rates is planned for SDL 1.3. +

    + Dialog boxes are now shown when SDL is in windowed OpenGL mode. +

    + The SDL window is recreated when necessary to maintain OpenGL context attributes, when switching between windowed and fullscreen modes. +

    + An SDL_VIDEORESIZE event is properly sent when the SDL window is maximized and restored. +

    + Window positions are retained when switching between fullscreen and windowed modes. +

    + ToUnicode() is used, when available, for improved handling of international keyboard input. +

    + The PrtScrn is now treated normally with both key down and key up events. +

    + Pressing ALT-F4 now delivers an SDL_QUIT event to SDL applications. +

    + Joystick names are now correct for joysticks which have been unplugged and then plugged back in since booting. +

    + An MCI error when playing the last track on a CD-ROM has been fixed. +

    + OpenWatcom projects for building SDL have been provided by Marc Peter. +

    + +

    Mac OS X Notes

    + +
    +

    + SDL now supports building Universal binaries, both through Xcode projects and when using configure/make. See README.MacOSX in the SDL source archive for details. +

    + The X11 video driver with GLX support can be built on Mac OS X, if the X11 development SDK is installed. +

    + Transitions between fullscreen resolutions and windowed mode now use a much faster asynchronous fade to hide desktop flicker. +

    + Icons set with SDL_WM_SetIcon() now have the proper colors on Intel Macs. +

    + +

    OS/2 Notes

    + +
    +

    + Projects for building SDL on OS/2 with OpenWatcom have been contributed by Doodle. See the file README.OS2 in the SDL source distribution for details. +

    + +[separator] + + + diff --git a/Externals/SDL/docs/html/audio.html b/Externals/SDL/docs/html/audio.html new file mode 100644 index 0000000000..94075e2cb8 --- /dev/null +++ b/Externals/SDL/docs/html/audio.html @@ -0,0 +1,242 @@ +Audio
    SDL Library Documentation
    PrevNext

    Chapter 10. Audio

    Table of Contents
    SDL_AudioSpec -- Audio Specification Structure
    SDL_OpenAudio -- Opens the audio device with the desired parameters.
    SDL_PauseAudio -- Pauses and unpauses the audio callback processing
    SDL_GetAudioStatus -- Get the current audio state
    SDL_LoadWAV -- Load a WAVE file
    SDL_FreeWAV -- Frees previously opened WAV data
    SDL_AudioCVT -- Audio Conversion Structure
    SDL_BuildAudioCVT -- Initializes a SDL_AudioCVT structure for conversion
    SDL_ConvertAudio -- Convert audio data to a desired audio format.
    SDL_MixAudio -- Mix audio data
    SDL_LockAudio -- Lock out the callback function
    SDL_UnlockAudio -- Unlock the callback function
    SDL_CloseAudio -- Shuts down audio processing and closes the audio device.

    Sound on the computer is translated from waves that you hear into a series of +values, or samples, each representing the amplitude of the wave. When these +samples are sent in a stream to a sound card, an approximation of the original +wave can be recreated. The more bits used to represent the amplitude, and the +greater frequency these samples are gathered, the closer the approximated +sound is to the original, and the better the quality of sound.

    This library supports both 8 and 16 bit signed and unsigned sound samples, +at frequencies ranging from 11025 Hz to 44100 Hz, depending on the +underlying hardware. If the hardware doesn't support the desired audio +format or frequency, it can be emulated if desired (See +SDL_OpenAudio())

    A commonly supported audio format is 16 bits per sample at 22050 Hz.


    PrevHomeNext
    SDL_JoystickCloseUpSDL_AudioSpec
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/cdrom.html b/Externals/SDL/docs/html/cdrom.html new file mode 100644 index 0000000000..bdd6bfd827 --- /dev/null +++ b/Externals/SDL/docs/html/cdrom.html @@ -0,0 +1,260 @@ +CD-ROM
    SDL Library Documentation
    PrevNext

    Chapter 11. CD-ROM

    Table of Contents
    SDL_CDNumDrives -- Returns the number of CD-ROM drives on the system.
    SDL_CDName -- Returns a human-readable, system-dependent identifier for the CD-ROM.
    SDL_CDOpen -- Opens a CD-ROM drive for access.
    SDL_CDStatus -- Returns the current status of the given drive.
    SDL_CDPlay -- Play a CD
    SDL_CDPlayTracks -- Play the given CD track(s)
    SDL_CDPause -- Pauses a CDROM
    SDL_CDResume -- Resumes a CDROM
    SDL_CDStop -- Stops a CDROM
    SDL_CDEject -- Ejects a CDROM
    SDL_CDClose -- Closes a SDL_CD handle
    SDL_CD -- CDROM Drive Information
    SDL_CDtrack -- CD Track Information Structure

    SDL supports audio control of up to 32 local CD-ROM drives at once.

    You use this API to perform all the basic functions of a CD player, +including listing the tracks, playing, stopping, and ejecting the CD-ROM. +(Currently, multi-changer CD drives are not supported.)

    Before you call any of the SDL CD-ROM functions, you must first call +"SDL_Init(SDL_INIT_CDROM)", which scans the system for +CD-ROM drives, and sets the program up for audio control. Check the +return code, which should be 0, to see if there +were any errors in starting up.

    After you have initialized the library, you can find out how many drives +are available using the SDL_CDNumDrives() function. +The first drive listed is the system default CD-ROM drive. After you have +chosen a drive, and have opened it with SDL_CDOpen(), +you can check the status and start playing if there's a CD in the drive.

    A CD-ROM is organized into one or more tracks, each consisting of a certain +number of "frames". Each frame is ~2K in size, and at normal playing speed, +a CD plays 75 frames per second. SDL works with the number of frames on a +CD, but this can easily be converted to the more familiar minutes/seconds +format by using the FRAMES_TO_MSF() macro.


    PrevHomeNext
    SDL_CloseAudioUpSDL_CDNumDrives
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/event.html b/Externals/SDL/docs/html/event.html new file mode 100644 index 0000000000..f2bddb2c0a --- /dev/null +++ b/Externals/SDL/docs/html/event.html @@ -0,0 +1,216 @@ +Events
    SDL Library Documentation
    PrevNext

    Chapter 8. Events

    Introduction

    Event handling allows your application to receive input from the user. Event handling is initalised (along with video) with a call to: +

    SDL_Init(SDL_INIT_VIDEO);
    +Internally, SDL stores all the events waiting to be handled in an event queue. Using functions like SDL_PollEvent and SDL_PeepEvents you can observe and handle waiting input events.

    The key to event handling in SDL is the SDL_Event union. The event queue itself is composed of a series of SDL_Event unions, one for each waiting event. SDL_Event unions are read from the queue with the SDL_PollEvent function and it is then up to the application to process the information stored with them.


    PrevHomeNext
    SDL_WM_GrabInputUpSDL Event Structures.
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/eventfunctions.html b/Externals/SDL/docs/html/eventfunctions.html new file mode 100644 index 0000000000..f68a29a3bf --- /dev/null +++ b/Externals/SDL/docs/html/eventfunctions.html @@ -0,0 +1,481 @@ +Event Functions.
    SDL Library Documentation
    PrevChapter 8. EventsNext

    Event Functions.

    Table of Contents
    SDL_PumpEvents -- Pumps the event loop, gathering events from the input devices.
    SDL_PeepEvents -- Checks the event queue for messages and optionally returns them.
    SDL_PollEvent -- Polls for currently pending events.
    SDL_WaitEvent -- Waits indefinitely for the next available event.
    SDL_PushEvent -- Pushes an event onto the event queue
    SDL_SetEventFilter -- Sets up a filter to process all events before they are posted +to the event queue.
    SDL_GetEventFilter -- Retrieves a pointer to he event filter
    SDL_EventState -- This function allows you to set the state of processing certain events.
    SDL_GetKeyState -- Get a snapshot of the current keyboard state
    SDL_GetModState -- Get the state of modifier keys.
    SDL_SetModState -- Set the current key modifier state
    SDL_GetKeyName -- Get the name of an SDL virtual keysym
    SDL_EnableUNICODE -- Enable UNICODE translation
    SDL_EnableKeyRepeat -- Set keyboard repeat rate.
    SDL_GetMouseState -- Retrieve the current state of the mouse
    SDL_GetRelativeMouseState -- Retrieve the current state of the mouse
    SDL_GetAppState -- Get the state of the application
    SDL_JoystickEventState -- Enable/disable joystick event polling

    SDL_PumpEventsPumps the event loop, gathering events from the input devices
    SDL_PeepEventsChecks the event queue for messages and optionally returns them
    SDL_PollEventPolls for currently pending events
    SDL_WaitEventWaits indefinitely for the next available event
    SDL_PushEventPushes an event onto the event queue
    SDL_SetEventFilterSets up a filter to process all events
    SDL_EventStateAllows you to set the state of processing certain events
    SDL_GetKeyStateGet a snapshot of the current keyboard state
    SDL_GetModStateGet the state of modifier keys
    SDL_SetModStateSet the state of modifier keys
    SDL_GetKeyNameGet the name of an SDL virtual keysym
    SDL_EnableUNICODEEnable UNICODE translation
    SDL_EnableKeyRepeatSet keyboard repeat rate
    SDL_GetMouseStateRetrieve the current state of the mouse
    SDL_GetRelativeMouseStateRetrieve the current state of the mouse
    SDL_GetAppStateGet the state of the application
    SDL_JoystickEventStateEnable/disable joystick event polling


    PrevHomeNext
    SDLKeyUpSDL_PumpEvents
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/eventstructures.html b/Externals/SDL/docs/html/eventstructures.html new file mode 100644 index 0000000000..c959296220 --- /dev/null +++ b/Externals/SDL/docs/html/eventstructures.html @@ -0,0 +1,233 @@ +SDL Event Structures.
    SDL Library Documentation
    PrevChapter 8. EventsNext

    SDL Event Structures.

    Table of Contents
    SDL_Event -- General event structure
    SDL_ActiveEvent -- Application visibility event structure
    SDL_KeyboardEvent -- Keyboard event structure
    SDL_MouseMotionEvent -- Mouse motion event structure
    SDL_MouseButtonEvent -- Mouse button event structure
    SDL_JoyAxisEvent -- Joystick axis motion event structure
    SDL_JoyButtonEvent -- Joystick button event structure
    SDL_JoyHatEvent -- Joystick hat position change event structure
    SDL_JoyBallEvent -- Joystick trackball motion event structure
    SDL_ResizeEvent -- Window resize event structure
    SDL_ExposeEvent -- Quit requested event
    SDL_SysWMEvent -- Platform-dependent window manager event.
    SDL_UserEvent -- A user-defined event type
    SDL_QuitEvent -- Quit requested event
    SDL_keysym -- Keysym structure
    SDLKey -- Keysym definitions.

    PrevHomeNext
    EventsUpSDL_Event
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/general.html b/Externals/SDL/docs/html/general.html new file mode 100644 index 0000000000..0beb5919f8 --- /dev/null +++ b/Externals/SDL/docs/html/general.html @@ -0,0 +1,225 @@ +General
    SDL Library Documentation
    PrevNext

    Chapter 5. General

    Table of Contents
    SDL_Init -- Initializes SDL
    SDL_InitSubSystem -- Initialize subsystems
    SDL_QuitSubSystem -- Shut down a subsystem
    SDL_Quit -- Shut down SDL
    SDL_WasInit -- Check which subsystems are initialized
    SDL_GetError -- Get SDL error string
    SDL_envvars -- SDL environment variables

    Before SDL can be used in a program it must be initialized with SDL_Init. SDL_Init initializes all the subsystems that the user requests (video, audio, joystick, timers and/or cdrom). Once SDL is initialized with SDL_Init subsystems can be shut down and initialized as needed using SDL_InitSubSystem and SDL_QuitSubSystem.

    SDL must also be shut down before the program exits to make sure it cleans up correctly. Calling SDL_Quit shuts down all subsystems and frees any resources allocated to SDL.


    PrevHomeNext
    SDL ReferenceUpSDL_Init
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guide.html b/Externals/SDL/docs/html/guide.html new file mode 100644 index 0000000000..2c1297ee2b --- /dev/null +++ b/Externals/SDL/docs/html/guide.html @@ -0,0 +1,174 @@ +SDL Guide
    SDL Library Documentation
    PrevNext

    I. SDL Guide


    PrevHomeNext
    SDL Library Documentation Preface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guideaboutsdldoc.html b/Externals/SDL/docs/html/guideaboutsdldoc.html new file mode 100644 index 0000000000..cdb0d783c2 --- /dev/null +++ b/Externals/SDL/docs/html/guideaboutsdldoc.html @@ -0,0 +1,148 @@ +About SDLdoc
    SDL Library Documentation
    PrevPrefaceNext

    About SDLdoc

    SDLdoc (The SDL Documentation Project) was formed to completely rewrite the SDL documentation and to keep it continually up to date. The team consists completely of volunteers ranging from people working with SDL in their spare time to people who use SDL in their everyday working lives.

    The latest version of this documentation can always be found here: http://sdldoc.csn.ul.ie Downloadable PS, man pages and html tarballs are available at http://sdldoc.csn.ul.ie/pub/


    PrevHomeNext
    PrefaceUpCredits
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guideaudioexamples.html b/Externals/SDL/docs/html/guideaudioexamples.html new file mode 100644 index 0000000000..afb7522be7 --- /dev/null +++ b/Externals/SDL/docs/html/guideaudioexamples.html @@ -0,0 +1,228 @@ +Audio Examples
    SDL Library Documentation
    PrevChapter 4. ExamplesNext

    Audio Examples

    Opening the audio device

        SDL_AudioSpec wanted;
    +    extern void fill_audio(void *udata, Uint8 *stream, int len);
    +
    +    /* Set the audio format */
    +    wanted.freq = 22050;
    +    wanted.format = AUDIO_S16;
    +    wanted.channels = 2;    /* 1 = mono, 2 = stereo */
    +    wanted.samples = 1024;  /* Good low-latency value for callback */
    +    wanted.callback = fill_audio;
    +    wanted.userdata = NULL;
    +
    +    /* Open the audio device, forcing the desired format */
    +    if ( SDL_OpenAudio(&wanted, NULL) < 0 ) {
    +        fprintf(stderr, "Couldn't open audio: %s\n", SDL_GetError());
    +        return(-1);
    +    }
    +    return(0);

    Playing audio

        static Uint8 *audio_chunk;
    +    static Uint32 audio_len;
    +    static Uint8 *audio_pos;
    +
    +    /* The audio function callback takes the following parameters:
    +       stream:  A pointer to the audio buffer to be filled
    +       len:     The length (in bytes) of the audio buffer
    +    */
    +    void fill_audio(void *udata, Uint8 *stream, int len)
    +    {
    +        /* Only play if we have data left */
    +        if ( audio_len == 0 )
    +            return;
    +
    +        /* Mix as much data as possible */
    +        len = ( len > audio_len ? audio_len : len );
    +        SDL_MixAudio(stream, audio_pos, len, SDL_MIX_MAXVOLUME);
    +        audio_pos += len;
    +        audio_len -= len;
    +    }
    +
    +    /* Load the audio data ... */
    +
    +    ;;;;;
    +
    +    audio_pos = audio_chunk;
    +
    +    /* Let the callback function play the audio chunk */
    +    SDL_PauseAudio(0);
    +
    +    /* Do some processing */
    +
    +    ;;;;;
    +
    +    /* Wait for sound to complete */
    +    while ( audio_len > 0 ) {
    +        SDL_Delay(100);         /* Sleep 1/10 second */
    +    }
    +    SDL_CloseAudio();


    PrevHomeNext
    Event ExamplesUpCDROM Examples
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidebasicsinit.html b/Externals/SDL/docs/html/guidebasicsinit.html new file mode 100644 index 0000000000..faafdbd920 --- /dev/null +++ b/Externals/SDL/docs/html/guidebasicsinit.html @@ -0,0 +1,240 @@ +Initializing SDL
    SDL Library Documentation
    PrevChapter 1. The BasicsNext

    Initializing SDL

    SDL is composed of eight subsystems - Audio, CDROM, Event Handling, File I/O, Joystick Handling, Threading, Timers and Video. Before you can use any of these subsystems they must be initialized by calling SDL_Init (or SDL_InitSubSystem). SDL_Init must be called before any other SDL function. It automatically initializes the Event Handling, File I/O and Threading subsystems and it takes a parameter specifying which other subsystems to initialize. So, to initialize the default subsystems and the Video subsystems you would call: +

        SDL_Init ( SDL_INIT_VIDEO );
    +To initialize the default subsystems, the Video subsystem and the Timers subsystem you would call: +
        SDL_Init ( SDL_INIT_VIDEO | SDL_INIT_TIMER );

    SDL_Init is complemented by SDL_Quit (and SDL_QuitSubSystem). SDL_Quit shuts down all subsystems, including the default ones. It should always be called before a SDL application exits.

    With SDL_Init and SDL_Quit firmly embedded in your programmers toolkit you can write your first and most basic SDL application. However, we must be prepare to handle errors. Many SDL functions return a value and indicates whether the function has succeeded or failed, SDL_Init, for instance, returns -1 if it could not initialize a subsystem. SDL provides a useful facility that allows you to determine exactly what the problem was, every time an error occurs within SDL an error message is stored which can be retrieved using SDL_GetError. Use this often, you can never know too much about an error.

    Example 1-1. Initializing SDL

    #include "SDL.h"   /* All SDL App's need this */
    +#include <stdio.h>
    +
    +int main(int argc, char *argv[]) {
    +    
    +    printf("Initializing SDL.\n");
    +    
    +    /* Initialize defaults, Video and Audio */
    +    if((SDL_Init(SDL_INIT_VIDEO|SDL_INIT_AUDIO)==-1)) { 
    +        printf("Could not initialize SDL: %s.\n", SDL_GetError());
    +        exit(-1);
    +    }
    +
    +    printf("SDL initialized.\n");
    +
    +    printf("Quiting SDL.\n");
    +    
    +    /* Shutdown all subsystems */
    +    SDL_Quit();
    +    
    +    printf("Quiting....\n");
    +
    +    exit(0);
    +}

    PrevHomeNext
    The BasicsUpGraphics and Video
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidecdromexamples.html b/Externals/SDL/docs/html/guidecdromexamples.html new file mode 100644 index 0000000000..2bc5a16cb5 --- /dev/null +++ b/Externals/SDL/docs/html/guidecdromexamples.html @@ -0,0 +1,275 @@ +CDROM Examples
    SDL Library Documentation
    PrevChapter 4. ExamplesNext

    CDROM Examples

    Listing CD-ROM drives

        #include "SDL.h"
    +
    +    /* Initialize SDL first */
    +    if ( SDL_Init(SDL_INIT_CDROM) < 0 ) {
    +        fprintf(stderr, "Couldn't initialize SDL: %s\n",SDL_GetError());
    +        exit(1);
    +    }
    +    atexit(SDL_Quit);
    +
    +    /* Find out how many CD-ROM drives are connected to the system */
    +    printf("Drives available: %d\n", SDL_CDNumDrives());
    +    for ( i=0; i<SDL_CDNumDrives(); ++i ) {
    +        printf("Drive %d:  \"%s\"\n", i, SDL_CDName(i));
    +    }

    Opening the default drive

        SDL_CD *cdrom;
    +    CDstatus status;
    +    char *status_str;
    +
    +    cdrom = SDL_CDOpen(0);
    +    if ( cdrom == NULL ) {
    +        fprintf(stderr, "Couldn't open default CD-ROM drive: %s\n",
    +                        SDL_GetError());
    +        exit(2);
    +    }
    +
    +    status = SDL_CDStatus(cdrom);
    +    switch (status) {
    +        case CD_TRAYEMPTY:
    +            status_str = "tray empty";
    +            break;
    +        case CD_STOPPED:
    +            status_str = "stopped";
    +            break;
    +        case CD_PLAYING:
    +            status_str = "playing";
    +            break;
    +        case CD_PAUSED:
    +            status_str = "paused";
    +            break;
    +        case CD_ERROR:
    +            status_str = "error state";
    +            break;
    +    }
    +    printf("Drive status: %s\n", status_str);
    +    if ( status >= CD_PLAYING ) {
    +        int m, s, f;
    +        FRAMES_TO_MSF(cdrom->cur_frame, &m, &s, &f);
    +        printf("Currently playing track %d, %d:%2.2d\n",
    +        cdrom->track[cdrom->cur_track].id, m, s);
    +    }

    Listing the tracks on a CD

        SDL_CD *cdrom;          /* Assuming this has already been set.. */
    +    int i;
    +    int m, s, f;
    +
    +    SDL_CDStatus(cdrom);
    +    printf("Drive tracks: %d\n", cdrom->numtracks);
    +    for ( i=0; i<cdrom->numtracks; ++i ) {
    +        FRAMES_TO_MSF(cdrom->track[i].length, &m, &s, &f);
    +        if ( f > 0 )
    +            ++s;
    +        printf("\tTrack (index %d) %d: %d:%2.2d\n", i,
    +        cdrom->track[i].id, m, s);
    +    }

    Play an entire CD

        SDL_CD *cdrom;          /* Assuming this has already been set.. */
    +
    +    // Play entire CD:
    +    if ( CD_INDRIVE(SDL_CDStatus(cdrom)) )
    +        SDL_CDPlayTracks(cdrom, 0, 0, 0, 0);
    +
    +        // Play last track:
    +        if ( CD_INDRIVE(SDL_CDStatus(cdrom)) ) {
    +            SDL_CDPlayTracks(cdrom, cdrom->numtracks-1, 0, 0, 0);
    +        }
    +
    +        // Play first and second track and 10 seconds of third track:
    +        if ( CD_INDRIVE(SDL_CDStatus(cdrom)) )
    +            SDL_CDPlayTracks(cdrom, 0, 0, 2, CD_FPS * 10);


    PrevHomeNext
    Audio ExamplesUpTime Examples
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidecredits.html b/Externals/SDL/docs/html/guidecredits.html new file mode 100644 index 0000000000..b66b28f54d --- /dev/null +++ b/Externals/SDL/docs/html/guidecredits.html @@ -0,0 +1,195 @@ +Credits
    SDL Library Documentation
    PrevPrefaceNext

    Credits

    Sam Lantinga, slouken@libsdl.org
    Martin Donlon, akawaka@skynet.ie
    Mattias Engdegrd
    Julian Peterson
    Ken Jordan
    Maxim Sobolev
    Wesley Poole
    Michael Vance
    Andreas Umbach
    Andreas Hofmeister


    PrevHomeNext
    About SDLdocUpThe Basics
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guideeventexamples.html b/Externals/SDL/docs/html/guideeventexamples.html new file mode 100644 index 0000000000..300136947c --- /dev/null +++ b/Externals/SDL/docs/html/guideeventexamples.html @@ -0,0 +1,247 @@ +Event Examples
    SDL Library Documentation
    PrevChapter 4. ExamplesNext

    Event Examples

    Filtering and Handling Events

    #include <stdio.h>
    +#include <stdlib.h>
    +
    +#include "SDL.h"
    +
    +/* This function may run in a separate event thread */
    +int FilterEvents(const SDL_Event *event) {
    +    static int boycott = 1;
    +
    +    /* This quit event signals the closing of the window */
    +    if ( (event->type == SDL_QUIT) && boycott ) {
    +        printf("Quit event filtered out -- try again.\n");
    +        boycott = 0;
    +        return(0);
    +    }
    +    if ( event->type == SDL_MOUSEMOTION ) {
    +        printf("Mouse moved to (%d,%d)\n",
    +                event->motion.x, event->motion.y);
    +        return(0);    /* Drop it, we've handled it */
    +    }
    +    return(1);
    +}
    +
    +int main(int argc, char *argv[])
    +{
    +    SDL_Event event;
    +
    +    /* Initialize the SDL library (starts the event loop) */
    +    if ( SDL_Init(SDL_INIT_VIDEO) < 0 ) {
    +        fprintf(stderr,
    +                "Couldn't initialize SDL: %s\n", SDL_GetError());
    +        exit(1);
    +    }
    +
    +    /* Clean up on exit, exit on window close and interrupt */
    +    atexit(SDL_Quit);
    +
    +    /* Ignore key events */
    +    SDL_EventState(SDL_KEYDOWN, SDL_IGNORE);
    +    SDL_EventState(SDL_KEYUP, SDL_IGNORE);
    +
    +    /* Filter quit and mouse motion events */
    +    SDL_SetEventFilter(FilterEvents);
    +
    +    /* The mouse isn't much use unless we have a display for reference */
    +    if ( SDL_SetVideoMode(640, 480, 8, 0) == NULL ) {
    +        fprintf(stderr, "Couldn't set 640x480x8 video mode: %s\n",
    +                        SDL_GetError());
    +        exit(1);
    +    }
    +
    +    /* Loop waiting for ESC+Mouse_Button */
    +    while ( SDL_WaitEvent(&event) >= 0 ) {
    +        switch (event.type) {
    +            case SDL_ACTIVEEVENT: {
    +                if ( event.active.state & SDL_APPACTIVE ) {
    +                    if ( event.active.gain ) {
    +                        printf("App activated\n");
    +                    } else {
    +                        printf("App iconified\n");
    +                    }
    +                }
    +            }
    +            break;
    +                    
    +            case SDL_MOUSEBUTTONDOWN: {
    +                Uint8 *keys;
    +
    +                keys = SDL_GetKeyState(NULL);
    +                if ( keys[SDLK_ESCAPE] == SDL_PRESSED ) {
    +                    printf("Bye bye...\n");
    +                    exit(0);
    +                }
    +                printf("Mouse button pressed\n");
    +            }
    +            break;
    +
    +            case SDL_QUIT: {
    +                printf("Quit requested, quitting.\n");
    +                exit(0);
    +            }
    +            break;
    +        }
    +    }
    +    /* This should never happen */
    +    printf("SDL_WaitEvent error: %s\n", SDL_GetError());
    +    exit(1);
    +}


    PrevHomeNext
    ExamplesUpAudio Examples
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guideexamples.html b/Externals/SDL/docs/html/guideexamples.html new file mode 100644 index 0000000000..5b9a8471df --- /dev/null +++ b/Externals/SDL/docs/html/guideexamples.html @@ -0,0 +1,188 @@ +Examples
    SDL Library Documentation
    PrevNext

    Chapter 4. Examples

    Introduction

    For the moment these examples are taken directly from the old SDL documentation. By the 1.2 release these examples should hopefully deal with most common SDL programming problems.


    PrevHomeNext
    Handling the KeyboardUpEvent Examples
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guideinput.html b/Externals/SDL/docs/html/guideinput.html new file mode 100644 index 0000000000..4a82b6761a --- /dev/null +++ b/Externals/SDL/docs/html/guideinput.html @@ -0,0 +1,739 @@ +Input handling
    SDL Library Documentation
    PrevNext

    Chapter 3. Input handling

    Handling Joysticks

    Initialization

    The first step in using a joystick in a SDL program is to initialize the Joystick subsystems of SDL. This done by passing the SDL_INIT_JOYSTICK flag to SDL_Init. The joystick flag will usually be used in conjunction with other flags (like the video flag) because the joystick is usually used to control something.

    Example 3-1. Initializing SDL with Joystick Support

        if (SDL_Init( SDL_INIT_VIDEO | SDL_INIT_JOYSTICK ) < 0)
    +    {
    +        fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
    +        exit(1);
    +    }

    This will attempt to start SDL with both the video and the joystick subsystems activated.

    Querying

    If we have reached this point then we can safely assume that the SDL library has been initialized and that the Joystick subsystem is active. We can now call some video and/or sound functions to get things going before we need the joystick. Eventually we have to make sure that there is actually a joystick to work with. It's wise to always check even if you know a joystick will be present on the system because it can also help detect when the joystick is unplugged. The function used to check for joysticks is SDL_NumJoysticks.

    This function simply returns the number of joysticks available on the system. If it is at least one then we are in good shape. The next step is to determine which joystick the user wants to use. If the number of joysticks available is only one then it is safe to assume that one joystick is the one the user wants to use. SDL has a function to get the name of the joysticks as assigned by the operations system and that function is SDL_JoystickName. The joystick is specified by an index where 0 is the first joystick and the last joystick is the number returned by SDL_NumJoysticks - 1. In the demonstration a list of all available joysticks is printed to stdout.

    Example 3-2. Querying the Number of Available Joysticks

        printf("%i joysticks were found.\n\n", SDL_NumJoysticks() );
    +    printf("The names of the joysticks are:\n");
    +		
    +    for( i=0; i < SDL_NumJoysticks(); i++ ) 
    +    {
    +        printf("    %s\n", SDL_JoystickName(i));
    +    }

    Opening a Joystick and Receiving Joystick Events

    SDL's event driven architecture makes working with joysticks a snap. Joysticks can trigger 4 different types of events: +

    SDL_JoyAxisEventOccurs when an axis changes
    SDL_JoyBallEventOccurs when a joystick trackball's position changes
    SDL_JoyHatEventOccurs when a hat's position changes
    SDL_JoyButtonEventOccurs when a button is pressed or released

    Events are received from all joysticks opened. The first thing that needs to be done in order to receive joystick events is to call SDL_JoystickEventState with the SDL_ENABLE flag. Next you must open the joysticks that you want to receive envents from. This is done with the SDL_JoystickOpen function. For the example we are only interested in events from the first joystick on the system, regardless of what it may be. To receive events from it we would do this:

    Example 3-3. Opening a Joystick

        SDL_Joystick *joystick;
    +
    +    SDL_JoystickEventState(SDL_ENABLE);
    +    joystick = SDL_JoystickOpen(0);

    If we wanted to receive events for other joysticks we would open them with calls to SDL_JoystickOpen just like we opened joystick 0, except we would store the SDL_Joystick structure they return in a different pointer. We only need the joystick pointer when we are querying the joysticks or when we are closing the joystick.

    Up to this point all the code we have is used just to initialize the joysticks in order to read values at run time. All we need now is an event loop, which is something that all SDL programs should have anyway to receive the systems quit events. We must now add code to check the event loop for at least some of the above mentioned events. Let's assume our event loop looks like this: +

        SDL_Event event;
    +    /* Other initializtion code goes here */   
    +
    +    /* Start main game loop here */
    +
    +    while(SDL_PollEvent(&event))
    +    {  
    +        switch(event.type)
    +        {  
    +            case SDL_KEYDOWN:
    +            /* handle keyboard stuff here */				
    +            break;
    +
    +            case SDL_QUIT:
    +            /* Set whatever flags are necessary to */
    +            /* end the main game loop here */
    +            break;
    +        }
    +    }
    +
    +    /* End loop here */
    +To handle Joystick events we merely add cases for them, first we'll add axis handling code. Axis checks can get kinda of tricky because alot of the joystick events received are junk. Joystick axis have a tendency to vary just a little between polling due to the way they are designed. To compensate for this you have to set a threshold for changes and ignore the events that have'nt exceeded the threshold. 10% is usually a good threshold value. This sounds a lot more complicated than it is. Here is the Axis event handler:

    Example 3-4. Joystick Axis Events

        case SDL_JOYAXISMOTION:  /* Handle Joystick Motion */
    +    if ( ( event.jaxis.value < -3200 ) || (event.jaxis.value > 3200 ) ) 
    +    {
    +      /* code goes here */
    +    }
    +    break;

    Another trick with axis events is that up-down and left-right movement are two different sets of axes. The most important axis is axis 0 (left-right) and axis 1 (up-down). To handle them seperatly in the code we do the following:

    Example 3-5. More Joystick Axis Events

        case SDL_JOYAXISMOTION:  /* Handle Joystick Motion */
    +    if ( ( event.jaxis.value < -3200 ) || (event.jaxis.value > 3200 ) ) 
    +    {
    +        if( event.jaxis.axis == 0) 
    +        {
    +            /* Left-right movement code goes here */
    +        }
    +
    +        if( event.jaxis.axis == 1) 
    +        {
    +            /* Up-Down movement code goes here */
    +        }
    +    }
    +    break;

    Ideally the code here should use event.jaxis.value to scale something. For example lets assume you are using the joystick to control the movement of a spaceship. If the user is using an analog joystick and they push the stick a little bit they expect to move less than if they pushed it a lot. Designing your code for this situation is preferred because it makes the experience for users of analog controls better and remains the same for users of digital controls.

    If your joystick has any additional axis then they may be used for other sticks or throttle controls and those axis return values too just with different event.jaxis.axis values.

    Button handling is simple compared to the axis checking.

    Example 3-6. Joystick Button Events

        case SDL_JOYBUTTONDOWN:  /* Handle Joystick Button Presses */
    +    if ( event.jbutton.button == 0 ) 
    +    {
    +        /* code goes here */
    +    }
    +    break;

    Button checks are simpler than axis checks because a button can only be pressed or not pressed. The SDL_JOYBUTTONDOWN event is triggered when a button is pressed and the SDL_JOYBUTTONUP event is fired when a button is released. We do have to know what button was pressed though, that is done by reading the event.jbutton.button field.

    Lastly when we are through using our joysticks we should close them with a call to SDL_JoystickClose. To close our opened joystick 0 we would do this at the end of our program: +

        SDL_JoystickClose(joystick);

    Advanced Joystick Functions

    That takes care of the controls that you can count on being on every joystick under the sun, but there are a few extra things that SDL can support. Joyballs are next on our list, they are alot like axis with a few minor differences. Joyballs store relative changes unlike the the absolute postion stored in a axis event. Also one trackball event contains both the change in x and they change in y. Our case for it is as follows:

    Example 3-7. Joystick Ball Events

        case SDL_JOYBALLMOTION:  /* Handle Joyball Motion */
    +    if( event.jball.ball == 0 )
    +    {
    +      /* ball handling */
    +    }
    +    break;

    The above checks the first joyball on the joystick. The change in position will be stored in event.jball.xrel and event.jball.yrel.

    Finally we have the hat event. Hats report only the direction they are pushed in. We check hat's position with the bitmasks: + +

    SDL_HAT_CENTERED
    SDL_HAT_UP
    SDL_HAT_RIGHT
    SDL_HAT_DOWN
    SDL_HAT_LEFT

    + +Also there are some predefined combinations of the above: +

    SDL_HAT_RIGHTUP
    SDL_HAT_RIGHTDOWN
    SDL_HAT_LEFTUP
    SDL_HAT_LEFTDOWN

    + +Our case for the hat may resemble the following:

    Example 3-8. Joystick Hat Events

        case SDL_JOYHATMOTION:  /* Handle Hat Motion */
    +    if ( event.jhat.value & SDL_HAT_UP )
    +    {
    +        /* Do up stuff here */
    +    }
    +
    +    if ( event.jhat.value & SDL_HAT_LEFT )
    +    {
    +        /* Do left stuff here */
    +    }
    +
    +    if ( event.jhat.value & SDL_HAT_RIGHTDOWN )
    +    {
    +        /* Do right and down together stuff here */
    +    }
    +    break;

    In addition to the queries for number of joysticks on the system and their names there are additional functions to query the capabilities of attached joysticks: +

    SDL_JoystickNumAxesReturns the number of joysitck axes
    SDL_JoystickNumButtonsReturns the number of joysitck buttons
    SDL_JoystickNumBallsReturns the number of joysitck balls
    SDL_JoystickNumHatsReturns the number of joysitck hats

    + +To use these functions we just have to pass in the joystick structure we got when we opened the joystick. For Example:

    Example 3-9. Querying Joystick Characteristics

        int number_of_buttons;
    +    SDL_Joystick *joystick;
    +
    +    joystick = SDL_JoystickOpen(0);
    +    number_of_buttons = SDL_JoystickNumButtons(joystick);

    This block of code would get the number of buttons on the first joystick in the system.


    PrevHomeNext
    Using OpenGL With SDLUpHandling the Keyboard
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guideinputkeyboard.html b/Externals/SDL/docs/html/guideinputkeyboard.html new file mode 100644 index 0000000000..787036c7f2 --- /dev/null +++ b/Externals/SDL/docs/html/guideinputkeyboard.html @@ -0,0 +1,746 @@ +Handling the Keyboard
    SDL Library Documentation
    PrevChapter 3. Input handlingNext

    Handling the Keyboard

    Keyboard Related Structures

    It should make it a lot easier to understand this tutorial is you are familiar with the data types involved in keyboard access, so I'll explain them first.

    SDLKey

    SDLKey is an enumerated type defined in SDL/include/SDL_keysym.h and detailed here. Each SDLKey symbol represents a key, SDLK_a corresponds to the 'a' key on a keyboard, SDLK_SPACE corresponds to the space bar, and so on.

    SDLMod

    SDLMod is an enumerated type, similar to SDLKey, however it enumerates keyboard modifiers (Control, Alt, Shift). The full list of modifier symbols is here. SDLMod values can be AND'd together to represent several modifiers.

    SDL_keysym

    typedef struct{
    +  Uint8 scancode;
    +  SDLKey sym;
    +  SDLMod mod;
    +  Uint16 unicode;
    +} SDL_keysym;

    The SDL_keysym structure describes a key press or a key release. The scancode field is hardware specific and should be ignored unless you know what your doing. The sym field is the SDLKey value of the key being pressed or released. The mod field describes the state of the keyboard modifiers at the time the key press or release occurred. So a value of KMOD_NUM | KMOD_CAPS | KMOD_LSHIFT would mean that Numlock, Capslock and the left shift key were all press (or enabled in the case of the lock keys). Finally, the unicode field stores the 16-bit unicode value of the key.

    Note: It should be noted and understood that this field is only valid when the SDL_keysym is describing a key press, not a key release. Unicode values only make sense on a key press because the unicode value describes an international character and only key presses produce characters. More information on Unicode can be found at www.unicode.org

    Note: Unicode translation must be enabled using the SDL_EnableUNICODE function.

    SDL_KeyboardEvent

    typedef struct{
    +  Uint8 type;
    +  Uint8 state;
    +  SDL_keysym keysym;
    +} SDL_KeyboardEvent;

    The SDL_KeyboardEvent describes a keyboard event (obviously). The key member of the SDL_Event union is a SDL_KeyboardEvent structure. The type field specifies whether the event is a key release (SDL_KEYUP) or a key press (SDL_KEYDOWN) event. The state is largely redundant, it reports the same information as the type field but uses different values (SDL_RELEASED and SDL_PRESSED). The keysym contains information of the key press or release that this event represents (see above).

    Reading Keyboard Events

    Reading keybaord events from the event queue is quite simple (the event queue and using it is described here). We read events using SDL_PollEvent in a while() loop and check for SDL_KEYUP and SDL_KEYDOWN events using a switch statement, like so:

    Example 3-10. Reading Keyboard Events

      SDL_Event event;
    +  .
    +  .
    +  /* Poll for events. SDL_PollEvent() returns 0 when there are no  */
    +  /* more events on the event queue, our while loop will exit when */
    +  /* that occurs.                                                  */
    +  while( SDL_PollEvent( &event ) ){
    +    /* We are only worried about SDL_KEYDOWN and SDL_KEYUP events */
    +    switch( event.type ){
    +      case SDL_KEYDOWN:
    +        printf( "Key press detected\n" );
    +        break;
    +
    +      case SDL_KEYUP:
    +        printf( "Key release detected\n" );
    +        break;
    +
    +      default:
    +        break;
    +    }
    +  }
    +  .
    +  .

    This is a very basic example. No information about the key press or release is interpreted. We will explore the other extreme out our first full example below - reporting all available information about a keyboard event.

    A More Detailed Look

    Before we can read events SDL must be initialised with SDL_Init and a video mode must be set using SDL_SetVideoMode. There are, however, two other functions we must use to obtain all the information required. We must enable unicode translation by calling SDL_EnableUNICODE(1) and we must convert SDLKey values into something printable, using SDL_GetKeyName

    Note: It is useful to note that unicode values < 0x80 translate directly a characters ASCII value. THis is used in the example below

    Example 3-11. Interpreting Key Event Information

    
    #include "SDL.h"
    +
    +    /* Function Prototypes */
    +    void PrintKeyInfo( SDL_KeyboardEvent *key );
    +    void PrintModifiers( SDLMod mod );
    +
    +    /* main */
    +    int main( int argc, char *argv[] ){
    +        
    +        SDL_Event event;
    +        int quit = 0;
    +        
    +        /* Initialise SDL */
    +        if( SDL_Init( SDL_INIT_VIDEO ) < 0){
    +            fprintf( stderr, "Could not initialise SDL: %s\n", SDL_GetError() );
    +            exit( -1 );
    +        }
    +
    +        /* Set a video mode */
    +        if( !SDL_SetVideoMode( 320, 200, 0, 0 ) ){
    +            fprintf( stderr, "Could not set video mode: %s\n", SDL_GetError() );
    +            SDL_Quit();
    +            exit( -1 );
    +        }
    +
    +        /* Enable Unicode translation */
    +        SDL_EnableUNICODE( 1 );
    +
    +        /* Loop until an SDL_QUIT event is found */
    +        while( !quit ){
    +
    +            /* Poll for events */
    +            while( SDL_PollEvent( &event ) ){
    +                
    +                switch( event.type ){
    +                    /* Keyboard event */
    +                    /* Pass the event data onto PrintKeyInfo() */
    +                    case SDL_KEYDOWN:
    +                    case SDL_KEYUP:
    +                        PrintKeyInfo( &event.key );
    +                        break;
    +
    +                    /* SDL_QUIT event (window close) */
    +                    case SDL_QUIT:
    +                        quit = 1;
    +                        break;
    +
    +                    default:
    +                        break;
    +                }
    +
    +            }
    +
    +        }
    +
    +        /* Clean up */
    +        SDL_Quit();
    +        exit( 0 );
    +    }
    +
    +    /* Print all information about a key event */
    +    void PrintKeyInfo( SDL_KeyboardEvent *key ){
    +        /* Is it a release or a press? */
    +        if( key->type == SDL_KEYUP )
    +            printf( "Release:- " );
    +        else
    +            printf( "Press:- " );
    +
    +        /* Print the hardware scancode first */
    +        printf( "Scancode: 0x%02X", key->keysym.scancode );
    +        /* Print the name of the key */
    +        printf( ", Name: %s", SDL_GetKeyName( key->keysym.sym ) );
    +        /* We want to print the unicode info, but we need to make */
    +        /* sure its a press event first (remember, release events */
    +        /* don't have unicode info                                */
    +        if( key->type == SDL_KEYDOWN ){
    +            /* If the Unicode value is less than 0x80 then the    */
    +            /* unicode value can be used to get a printable       */
    +            /* representation of the key, using (char)unicode.    */
    +            printf(", Unicode: " );
    +            if( key->keysym.unicode < 0x80 && key->keysym.unicode > 0 ){
    +                printf( "%c (0x%04X)", (char)key->keysym.unicode,
    +                        key->keysym.unicode );
    +            }
    +            else{
    +                printf( "? (0x%04X)", key->keysym.unicode );
    +            }
    +        }
    +        printf( "\n" );
    +        /* Print modifier info */
    +        PrintModifiers( key->keysym.mod );
    +    }
    +
    +    /* Print modifier info */
    +    void PrintModifiers( SDLMod mod ){
    +        printf( "Modifers: " );
    +
    +        /* If there are none then say so and return */
    +        if( mod == KMOD_NONE ){
    +            printf( "None\n" );
    +            return;
    +        }
    +
    +        /* Check for the presence of each SDLMod value */
    +        /* This looks messy, but there really isn't    */
    +        /* a clearer way.                              */
    +        if( mod & KMOD_NUM ) printf( "NUMLOCK " );
    +        if( mod & KMOD_CAPS ) printf( "CAPSLOCK " );
    +        if( mod & KMOD_LCTRL ) printf( "LCTRL " );
    +        if( mod & KMOD_RCTRL ) printf( "RCTRL " );
    +        if( mod & KMOD_RSHIFT ) printf( "RSHIFT " );
    +        if( mod & KMOD_LSHIFT ) printf( "LSHIFT " );
    +        if( mod & KMOD_RALT ) printf( "RALT " );
    +        if( mod & KMOD_LALT ) printf( "LALT " );
    +        if( mod & KMOD_CTRL ) printf( "CTRL " );
    +        if( mod & KMOD_SHIFT ) printf( "SHIFT " );
    +        if( mod & KMOD_ALT ) printf( "ALT " );
    +        printf( "\n" );
    +    }

    Game-type Input

    I have found that people using keyboard events for games and other interactive applications don't always understand one fundemental point.

    Keyboard events only take place when a keys state changes from being unpressed to pressed, and vice versa.

    Imagine you have an image of an alien that you wish to move around using the cursor keys: when you pressed the left arrow key you want him to slide over to the left, and when you press the down key you want him to slide down the screen. Examine the following code; it highlights an error that many people have made. +

        /* Alien screen coordinates */
    +    int alien_x=0, alien_y=0;
    +    .
    +    .
    +    /* Initialise SDL and video modes and all that */
    +    .
    +    /* Main game loop */
    +    /* Check for events */
    +    while( SDL_PollEvent( &event ) ){
    +        switch( event.type ){
    +            /* Look for a keypress */
    +            case SDL_KEYDOWN:
    +                /* Check the SDLKey values and move change the coords */
    +                switch( event.key.keysym.sym ){
    +                    case SDLK_LEFT:
    +                        alien_x -= 1;
    +                        break;
    +                    case SDLK_RIGHT:
    +                        alien_x += 1;
    +                        break;
    +                    case SDLK_UP:
    +                        alien_y -= 1;
    +                        break;
    +                    case SDLK_DOWN:
    +                        alien_y += 1;
    +                        break;
    +                    default:
    +                        break;
    +                }
    +            }
    +        }
    +    }
    +    .
    +    .
    +At first glance you may think this is a perfectly reasonable piece of code for the task, but it isn't. Like I said keyboard events only occur when a key changes state, so the user would have to press and release the left cursor key 100 times to move the alien 100 pixels to the left.

    To get around this problem we must not use the events to change the position of the alien, we use the events to set flags which are then used in a seperate section of code to move the alien. Something like this:

    Example 3-12. Proper Game Movement

        /* Alien screen coordinates */
    +    int alien_x=0, alien_y=0;
    +    int alien_xvel=0, alien_yvel=0;
    +    .
    +    .
    +    /* Initialise SDL and video modes and all that */
    +    .
    +    /* Main game loop */
    +    /* Check for events */
    +    while( SDL_PollEvent( &event ) ){
    +        switch( event.type ){
    +            /* Look for a keypress */
    +            case SDL_KEYDOWN:
    +                /* Check the SDLKey values and move change the coords */
    +                switch( event.key.keysym.sym ){
    +                    case SDLK_LEFT:
    +                        alien_xvel = -1;
    +                        break;
    +                    case SDLK_RIGHT:
    +                        alien_xvel =  1;
    +                        break;
    +                    case SDLK_UP:
    +                        alien_yvel = -1;
    +                        break;
    +                    case SDLK_DOWN:
    +                        alien_yvel =  1;
    +                        break;
    +                    default:
    +                        break;
    +                }
    +                break;
    +            /* We must also use the SDL_KEYUP events to zero the x */
    +            /* and y velocity variables. But we must also be       */
    +            /* careful not to zero the velocities when we shouldn't*/
    +            case SDL_KEYUP:
    +                switch( event.key.keysym.sym ){
    +                    case SDLK_LEFT:
    +                        /* We check to make sure the alien is moving */
    +                        /* to the left. If it is then we zero the    */
    +                        /* velocity. If the alien is moving to the   */
    +                        /* right then the right key is still press   */
    +                        /* so we don't tocuh the velocity            */
    +                        if( alien_xvel < 0 )
    +                            alien_xvel = 0;
    +                        break;
    +                    case SDLK_RIGHT:
    +                        if( alien_xvel > 0 )
    +                            alien_xvel = 0;
    +                        break;
    +                    case SDLK_UP:
    +                        if( alien_yvel < 0 )
    +                            alien_yvel = 0;
    +                        break;
    +                    case SDLK_DOWN:
    +                        if( alien_yvel > 0 )
    +                            alien_yvel = 0;
    +                        break;
    +                    default:
    +                        break;
    +                }
    +                break;
    +            
    +            default:
    +                break;
    +        }
    +    }
    +    .
    +    .
    +    /* Update the alien position */
    +    alien_x += alien_xvel;
    +    alien_y += alien_yvel;

    As can be seen, we use two extra variables, alien_xvel and alien_yvel, which represent the motion of the ship, it is these variables that we update when we detect keypresses and releases.


    PrevHomeNext
    Input handlingUpExamples
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidepreface.html b/Externals/SDL/docs/html/guidepreface.html new file mode 100644 index 0000000000..9986fc6b75 --- /dev/null +++ b/Externals/SDL/docs/html/guidepreface.html @@ -0,0 +1,178 @@ +Preface
    SDL Library Documentation
    PrevNext

    Preface

    About SDL

    The SDL library is designed to make it easy to write games that run on Linux, *BSD, MacOS, Win32 and BeOS using the various native high-performance media interfaces, (for video, audio, etc) and presenting a single source-code level API to your application. SDL is a fairly low level API, but using it, completely portable applications can be written with a great deal of flexibility.


    PrevHomeNext
    SDL GuideUpAbout SDLdoc
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidethebasics.html b/Externals/SDL/docs/html/guidethebasics.html new file mode 100644 index 0000000000..4f32363f38 --- /dev/null +++ b/Externals/SDL/docs/html/guidethebasics.html @@ -0,0 +1,173 @@ +The Basics
    SDL Library Documentation
    PrevNext

    Chapter 1. The Basics

    Introduction

    The SDL Guide section is pretty incomplete. If you feel you have anything to add mail akawaka@skynet.ie or visit http://akawaka.csn.ul.ie/tne/.


    PrevHomeNext
    CreditsUpInitializing SDL
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidetimeexamples.html b/Externals/SDL/docs/html/guidetimeexamples.html new file mode 100644 index 0000000000..42b5019ebf --- /dev/null +++ b/Externals/SDL/docs/html/guidetimeexamples.html @@ -0,0 +1,183 @@ +Time Examples
    SDL Library Documentation
    PrevChapter 4. ExamplesNext

    Time Examples

    Time based game loop

    #define TICK_INTERVAL    30
    +
    +static Uint32 next_time;
    +
    +Uint32 time_left(void)
    +{
    +    Uint32 now;
    +
    +    now = SDL_GetTicks();
    +    if(next_time <= now)
    +        return 0;
    +    else
    +        return next_time - now;
    +}
    +
    +
    +/* main game loop */
    +
    +    next_time = SDL_GetTicks() + TICK_INTERVAL;
    +    while ( game_running ) {
    +        update_game_state();
    +        SDL_Delay(time_left());
    +        next_time += TICK_INTERVAL;
    +    }


    PrevHomeNext
    CDROM ExamplesUpSDL Reference
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidevideo.html b/Externals/SDL/docs/html/guidevideo.html new file mode 100644 index 0000000000..85da77d1fd --- /dev/null +++ b/Externals/SDL/docs/html/guidevideo.html @@ -0,0 +1,463 @@ +Graphics and Video
    SDL Library Documentation
    PrevNext

    Chapter 2. Graphics and Video

    Introduction to SDL Video

    Video is probably the most common thing that SDL is used for, and +so it has the most complete subsystem. Here are a few +examples to demonstrate the basics.

    Initializing the Video Display

    This is what almost all SDL programs have to do in one way or +another.

    Example 2-1. Initializing the Video Display

        SDL_Surface *screen;
    +
    +    /* Initialize the SDL library */
    +    if( SDL_Init(SDL_INIT_VIDEO) < 0 ) {
    +        fprintf(stderr,
    +                "Couldn't initialize SDL: %s\n", SDL_GetError());
    +        exit(1);
    +    }
    +
    +    /* Clean up on exit */
    +    atexit(SDL_Quit);
    +    
    +    /*
    +     * Initialize the display in a 640x480 8-bit palettized mode,
    +     * requesting a software surface
    +     */
    +    screen = SDL_SetVideoMode(640, 480, 8, SDL_SWSURFACE);
    +    if ( screen == NULL ) {
    +        fprintf(stderr, "Couldn't set 640x480x8 video mode: %s\n",
    +                        SDL_GetError());
    +        exit(1);
    +    }

    Initializing the Best Video Mode

    If you have a preference for a certain pixel depth but will accept any +other, use SDL_SetVideoMode with SDL_ANYFORMAT as below. You can also +use SDL_VideoModeOK() to find the native video mode that is closest to +the mode you request.

    Example 2-2. Initializing the Best Video Mode

        /* Have a preference for 8-bit, but accept any depth */
    +    screen = SDL_SetVideoMode(640, 480, 8, SDL_SWSURFACE|SDL_ANYFORMAT);
    +    if ( screen == NULL ) {
    +        fprintf(stderr, "Couldn't set 640x480x8 video mode: %s\n",
    +                        SDL_GetError());
    +        exit(1);
    +    }
    +    printf("Set 640x480 at %d bits-per-pixel mode\n",
    +           screen->format->BitsPerPixel);

    Loading and Displaying a BMP File

    The following function loads and displays a BMP file given as +argument, once SDL is initialised and a video mode has been set.

    Example 2-3. Loading and Displaying a BMP File

    void display_bmp(char *file_name)
    +{
    +    SDL_Surface *image;
    +
    +    /* Load the BMP file into a surface */
    +    image = SDL_LoadBMP(file_name);
    +    if (image == NULL) {
    +        fprintf(stderr, "Couldn't load %s: %s\n", file_name, SDL_GetError());
    +        return;
    +    }
    +
    +    /*
    +     * Palettized screen modes will have a default palette (a standard
    +     * 8*8*4 colour cube), but if the image is palettized as well we can
    +     * use that palette for a nicer colour matching
    +     */
    +    if (image->format->palette && screen->format->palette) {
    +    SDL_SetColors(screen, image->format->palette->colors, 0,
    +                  image->format->palette->ncolors);
    +    }
    +
    +    /* Blit onto the screen surface */
    +    if(SDL_BlitSurface(image, NULL, screen, NULL) < 0)
    +        fprintf(stderr, "BlitSurface error: %s\n", SDL_GetError());
    +
    +    SDL_UpdateRect(screen, 0, 0, image->w, image->h);
    +
    +    /* Free the allocated BMP surface */
    +    SDL_FreeSurface(image);
    +}

    Drawing Directly to the Display

    The following two functions can be used to get and set single +pixels of a surface. They are carefully written to work with any depth +currently supported by SDL. Remember to lock the surface before +calling them, and to unlock it before calling any other SDL +functions.

    To convert between pixel values and their red, green, blue +components, use SDL_GetRGB() and SDL_MapRGB().

    Example 2-4. getpixel()

    /*
    + * Return the pixel value at (x, y)
    + * NOTE: The surface must be locked before calling this!
    + */
    +Uint32 getpixel(SDL_Surface *surface, int x, int y)
    +{
    +    int bpp = surface->format->BytesPerPixel;
    +    /* Here p is the address to the pixel we want to retrieve */
    +    Uint8 *p = (Uint8 *)surface->pixels + y * surface->pitch + x * bpp;
    +
    +    switch(bpp) {
    +    case 1:
    +        return *p;
    +
    +    case 2:
    +        return *(Uint16 *)p;
    +
    +    case 3:
    +        if(SDL_BYTEORDER == SDL_BIG_ENDIAN)
    +            return p[0] << 16 | p[1] << 8 | p[2];
    +        else
    +            return p[0] | p[1] << 8 | p[2] << 16;
    +
    +    case 4:
    +        return *(Uint32 *)p;
    +
    +    default:
    +        return 0;       /* shouldn't happen, but avoids warnings */
    +    }
    +}

    Example 2-5. putpixel()

    /*
    + * Set the pixel at (x, y) to the given value
    + * NOTE: The surface must be locked before calling this!
    + */
    +void putpixel(SDL_Surface *surface, int x, int y, Uint32 pixel)
    +{
    +    int bpp = surface->format->BytesPerPixel;
    +    /* Here p is the address to the pixel we want to set */
    +    Uint8 *p = (Uint8 *)surface->pixels + y * surface->pitch + x * bpp;
    +
    +    switch(bpp) {
    +    case 1:
    +        *p = pixel;
    +        break;
    +
    +    case 2:
    +        *(Uint16 *)p = pixel;
    +        break;
    +
    +    case 3:
    +        if(SDL_BYTEORDER == SDL_BIG_ENDIAN) {
    +            p[0] = (pixel >> 16) & 0xff;
    +            p[1] = (pixel >> 8) & 0xff;
    +            p[2] = pixel & 0xff;
    +        } else {
    +            p[0] = pixel & 0xff;
    +            p[1] = (pixel >> 8) & 0xff;
    +            p[2] = (pixel >> 16) & 0xff;
    +        }
    +        break;
    +
    +    case 4:
    +        *(Uint32 *)p = pixel;
    +        break;
    +    }
    +}

    The following code uses the putpixel() function above to set a +yellow pixel in the middle of the screen.

    Example 2-6. Using putpixel()

    
    /* Code to set a yellow pixel at the center of the screen */
    +
    +    int x, y;
    +    Uint32 yellow;
    +
    +    /* Map the color yellow to this display (R=0xff, G=0xFF, B=0x00)
    +       Note:  If the display is palettized, you must set the palette first.
    +    */
    +    yellow = SDL_MapRGB(screen->format, 0xff, 0xff, 0x00);
    +
    +    x = screen->w / 2;
    +    y = screen->h / 2;
    +
    +    /* Lock the screen for direct access to the pixels */
    +    if ( SDL_MUSTLOCK(screen) ) {
    +        if ( SDL_LockSurface(screen) < 0 ) {
    +            fprintf(stderr, "Can't lock screen: %s\n", SDL_GetError());
    +            return;
    +        }
    +    }
    +
    +    putpixel(screen, x, y, yellow);
    +
    +    if ( SDL_MUSTLOCK(screen) ) {
    +        SDL_UnlockSurface(screen);
    +    }
    +    /* Update just the part of the display that we've changed */
    +    SDL_UpdateRect(screen, x, y, 1, 1);
    +
    +    return;

    PrevHomeNext
    Initializing SDLUpUsing OpenGL With SDL
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/guidevideoopengl.html b/Externals/SDL/docs/html/guidevideoopengl.html new file mode 100644 index 0000000000..0abd567186 --- /dev/null +++ b/Externals/SDL/docs/html/guidevideoopengl.html @@ -0,0 +1,730 @@ +Using OpenGL With SDL
    SDL Library Documentation
    PrevChapter 2. Graphics and VideoNext

    Using OpenGL With SDL

    SDL has the ability to create and use OpenGL contexts on several platforms(Linux/X11, Win32, BeOS, MacOS Classic/Toolbox, Mac OS X, FreeBSD/X11 and Solaris/X11). This allows you to use SDL's audio, event handling, threads and times in your OpenGL applications (a function often performed by GLUT).

    Initialisation

    Initialising SDL to use OpenGL is not very different to initialising SDL normally. There are three differences; you must pass SDL_OPENGL to SDL_SetVideoMode, you must specify several GL attributes (depth buffer size, framebuffer sizes) using SDL_GL_SetAttribute and finally, if you wish to use double buffering you must specify it as a GL attribute, not by passing the SDL_DOUBLEBUF flag to SDL_SetVideoMode.

    Example 2-7. Initializing SDL with OpenGL

        /* Information about the current video settings. */
    +    const SDL_VideoInfo* info = NULL;
    +    /* Dimensions of our window. */
    +    int width = 0;
    +    int height = 0;
    +    /* Color depth in bits of our window. */
    +    int bpp = 0;
    +    /* Flags we will pass into SDL_SetVideoMode. */
    +    int flags = 0;
    +
    +    /* First, initialize SDL's video subsystem. */
    +    if( SDL_Init( SDL_INIT_VIDEO ) < 0 ) {
    +        /* Failed, exit. */
    +        fprintf( stderr, "Video initialization failed: %s\n",
    +             SDL_GetError( ) );
    +        quit_tutorial( 1 );
    +    }
    +
    +    /* Let's get some video information. */
    +    info = SDL_GetVideoInfo( );
    +
    +    if( !info ) {
    +        /* This should probably never happen. */
    +        fprintf( stderr, "Video query failed: %s\n",
    +             SDL_GetError( ) );
    +        quit_tutorial( 1 );
    +    }
    +
    +    /*
    +     * Set our width/height to 640/480 (you would
    +     * of course let the user decide this in a normal
    +     * app). We get the bpp we will request from
    +     * the display. On X11, VidMode can't change
    +     * resolution, so this is probably being overly
    +     * safe. Under Win32, ChangeDisplaySettings
    +     * can change the bpp.
    +     */
    +    width = 640;
    +    height = 480;
    +    bpp = info->vfmt->BitsPerPixel;
    +
    +    /*
    +     * Now, we want to setup our requested
    +     * window attributes for our OpenGL window.
    +     * We want *at least* 5 bits of red, green
    +     * and blue. We also want at least a 16-bit
    +     * depth buffer.
    +     *
    +     * The last thing we do is request a double
    +     * buffered window. '1' turns on double
    +     * buffering, '0' turns it off.
    +     *
    +     * Note that we do not use SDL_DOUBLEBUF in
    +     * the flags to SDL_SetVideoMode. That does
    +     * not affect the GL attribute state, only
    +     * the standard 2D blitting setup.
    +     */
    +    SDL_GL_SetAttribute( SDL_GL_RED_SIZE, 5 );
    +    SDL_GL_SetAttribute( SDL_GL_GREEN_SIZE, 5 );
    +    SDL_GL_SetAttribute( SDL_GL_BLUE_SIZE, 5 );
    +    SDL_GL_SetAttribute( SDL_GL_DEPTH_SIZE, 16 );
    +    SDL_GL_SetAttribute( SDL_GL_DOUBLEBUFFER, 1 );
    +
    +    /*
    +     * We want to request that SDL provide us
    +     * with an OpenGL window, in a fullscreen
    +     * video mode.
    +     *
    +     * EXERCISE:
    +     * Make starting windowed an option, and
    +     * handle the resize events properly with
    +     * glViewport.
    +     */
    +    flags = SDL_OPENGL | SDL_FULLSCREEN;
    +
    +    /*
    +     * Set the video mode
    +     */
    +    if( SDL_SetVideoMode( width, height, bpp, flags ) == 0 ) {
    +        /* 
    +         * This could happen for a variety of reasons,
    +         * including DISPLAY not being set, the specified
    +         * resolution not being available, etc.
    +         */
    +        fprintf( stderr, "Video mode set failed: %s\n",
    +             SDL_GetError( ) );
    +        quit_tutorial( 1 );
    +    }

    Drawing

    Apart from initialisation, using OpenGL within SDL is the same as using OpenGL +with any other API, e.g. GLUT. You still use all the same function calls and +data types. However if you are using a double-buffered display, then you must +use +SDL_GL_SwapBuffers() +to swap the buffers and update the display. To request double-buffering +with OpenGL, use +SDL_GL_SetAttribute +with SDL_GL_DOUBLEBUFFER, and use +SDL_GL_GetAttribute +to see if you actually got it.

    A full example code listing is now presented below.

    Example 2-8. SDL and OpenGL

    /*
    + * SDL OpenGL Tutorial.
    + * (c) Michael Vance, 2000
    + * briareos@lokigames.com
    + *
    + * Distributed under terms of the LGPL. 
    + */
    +
    +#include <SDL/SDL.h>
    +#include <GL/gl.h>
    +#include <GL/glu.h>
    +
    +#include <stdio.h>
    +#include <stdlib.h>
    +
    +static GLboolean should_rotate = GL_TRUE;
    +
    +static void quit_tutorial( int code )
    +{
    +    /*
    +     * Quit SDL so we can release the fullscreen
    +     * mode and restore the previous video settings,
    +     * etc.
    +     */
    +    SDL_Quit( );
    +
    +    /* Exit program. */
    +    exit( code );
    +}
    +
    +static void handle_key_down( SDL_keysym* keysym )
    +{
    +
    +    /* 
    +     * We're only interested if 'Esc' has
    +     * been presssed.
    +     *
    +     * EXERCISE: 
    +     * Handle the arrow keys and have that change the
    +     * viewing position/angle.
    +     */
    +    switch( keysym->sym ) {
    +    case SDLK_ESCAPE:
    +        quit_tutorial( 0 );
    +        break;
    +    case SDLK_SPACE:
    +        should_rotate = !should_rotate;
    +        break;
    +    default:
    +        break;
    +    }
    +
    +}
    +
    +static void process_events( void )
    +{
    +    /* Our SDL event placeholder. */
    +    SDL_Event event;
    +
    +    /* Grab all the events off the queue. */
    +    while( SDL_PollEvent( &event ) ) {
    +
    +        switch( event.type ) {
    +        case SDL_KEYDOWN:
    +            /* Handle key presses. */
    +            handle_key_down( &event.key.keysym );
    +            break;
    +        case SDL_QUIT:
    +            /* Handle quit requests (like Ctrl-c). */
    +            quit_tutorial( 0 );
    +            break;
    +        }
    +
    +    }
    +
    +}
    +
    +static void draw_screen( void )
    +{
    +    /* Our angle of rotation. */
    +    static float angle = 0.0f;
    +
    +    /*
    +     * EXERCISE:
    +     * Replace this awful mess with vertex
    +     * arrays and a call to glDrawElements.
    +     *
    +     * EXERCISE:
    +     * After completing the above, change
    +     * it to use compiled vertex arrays.
    +     *
    +     * EXERCISE:
    +     * Verify my windings are correct here ;).
    +     */
    +    static GLfloat v0[] = { -1.0f, -1.0f,  1.0f };
    +    static GLfloat v1[] = {  1.0f, -1.0f,  1.0f };
    +    static GLfloat v2[] = {  1.0f,  1.0f,  1.0f };
    +    static GLfloat v3[] = { -1.0f,  1.0f,  1.0f };
    +    static GLfloat v4[] = { -1.0f, -1.0f, -1.0f };
    +    static GLfloat v5[] = {  1.0f, -1.0f, -1.0f };
    +    static GLfloat v6[] = {  1.0f,  1.0f, -1.0f };
    +    static GLfloat v7[] = { -1.0f,  1.0f, -1.0f };
    +    static GLubyte red[]    = { 255,   0,   0, 255 };
    +    static GLubyte green[]  = {   0, 255,   0, 255 };
    +    static GLubyte blue[]   = {   0,   0, 255, 255 };
    +    static GLubyte white[]  = { 255, 255, 255, 255 };
    +    static GLubyte yellow[] = {   0, 255, 255, 255 };
    +    static GLubyte black[]  = {   0,   0,   0, 255 };
    +    static GLubyte orange[] = { 255, 255,   0, 255 };
    +    static GLubyte purple[] = { 255,   0, 255,   0 };
    +
    +    /* Clear the color and depth buffers. */
    +    glClear( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT );
    +
    +    /* We don't want to modify the projection matrix. */
    +    glMatrixMode( GL_MODELVIEW );
    +    glLoadIdentity( );
    +
    +    /* Move down the z-axis. */
    +    glTranslatef( 0.0, 0.0, -5.0 );
    +
    +    /* Rotate. */
    +    glRotatef( angle, 0.0, 1.0, 0.0 );
    +
    +    if( should_rotate ) {
    +
    +        if( ++angle > 360.0f ) {
    +            angle = 0.0f;
    +        }
    +
    +    }
    +
    +    /* Send our triangle data to the pipeline. */
    +    glBegin( GL_TRIANGLES );
    +
    +    glColor4ubv( red );
    +    glVertex3fv( v0 );
    +    glColor4ubv( green );
    +    glVertex3fv( v1 );
    +    glColor4ubv( blue );
    +    glVertex3fv( v2 );
    +
    +    glColor4ubv( red );
    +    glVertex3fv( v0 );
    +    glColor4ubv( blue );
    +    glVertex3fv( v2 );
    +    glColor4ubv( white );
    +    glVertex3fv( v3 );
    +
    +    glColor4ubv( green );
    +    glVertex3fv( v1 );
    +    glColor4ubv( black );
    +    glVertex3fv( v5 );
    +    glColor4ubv( orange );
    +    glVertex3fv( v6 );
    +
    +    glColor4ubv( green );
    +    glVertex3fv( v1 );
    +    glColor4ubv( orange );
    +    glVertex3fv( v6 );
    +    glColor4ubv( blue );
    +    glVertex3fv( v2 );
    +
    +    glColor4ubv( black );
    +    glVertex3fv( v5 );
    +    glColor4ubv( yellow );
    +    glVertex3fv( v4 );
    +    glColor4ubv( purple );
    +    glVertex3fv( v7 );
    +
    +    glColor4ubv( black );
    +    glVertex3fv( v5 );
    +    glColor4ubv( purple );
    +    glVertex3fv( v7 );
    +    glColor4ubv( orange );
    +    glVertex3fv( v6 );
    +
    +    glColor4ubv( yellow );
    +    glVertex3fv( v4 );
    +    glColor4ubv( red );
    +    glVertex3fv( v0 );
    +    glColor4ubv( white );
    +    glVertex3fv( v3 );
    +
    +    glColor4ubv( yellow );
    +    glVertex3fv( v4 );
    +    glColor4ubv( white );
    +    glVertex3fv( v3 );
    +    glColor4ubv( purple );
    +    glVertex3fv( v7 );
    +
    +    glColor4ubv( white );
    +    glVertex3fv( v3 );
    +    glColor4ubv( blue );
    +    glVertex3fv( v2 );
    +    glColor4ubv( orange );
    +    glVertex3fv( v6 );
    +
    +    glColor4ubv( white );
    +    glVertex3fv( v3 );
    +    glColor4ubv( orange );
    +    glVertex3fv( v6 );
    +    glColor4ubv( purple );
    +    glVertex3fv( v7 );
    +
    +    glColor4ubv( green );
    +    glVertex3fv( v1 );
    +    glColor4ubv( red );
    +    glVertex3fv( v0 );
    +    glColor4ubv( yellow );
    +    glVertex3fv( v4 );
    +
    +    glColor4ubv( green );
    +    glVertex3fv( v1 );
    +    glColor4ubv( yellow );
    +    glVertex3fv( v4 );
    +    glColor4ubv( black );
    +    glVertex3fv( v5 );
    +
    +    glEnd( );
    +
    +    /*
    +     * EXERCISE:
    +     * Draw text telling the user that 'Spc'
    +     * pauses the rotation and 'Esc' quits.
    +     * Do it using vetors and textured quads.
    +     */
    +
    +    /*
    +     * Swap the buffers. This this tells the driver to
    +     * render the next frame from the contents of the
    +     * back-buffer, and to set all rendering operations
    +     * to occur on what was the front-buffer.
    +     *
    +     * Double buffering prevents nasty visual tearing
    +     * from the application drawing on areas of the
    +     * screen that are being updated at the same time.
    +     */
    +    SDL_GL_SwapBuffers( );
    +}
    +
    +static void setup_opengl( int width, int height )
    +{
    +    float ratio = (float) width / (float) height;
    +
    +    /* Our shading model--Gouraud (smooth). */
    +    glShadeModel( GL_SMOOTH );
    +
    +    /* Culling. */
    +    glCullFace( GL_BACK );
    +    glFrontFace( GL_CCW );
    +    glEnable( GL_CULL_FACE );
    +
    +    /* Set the clear color. */
    +    glClearColor( 0, 0, 0, 0 );
    +
    +    /* Setup our viewport. */
    +    glViewport( 0, 0, width, height );
    +
    +    /*
    +     * Change to the projection matrix and set
    +     * our viewing volume.
    +     */
    +    glMatrixMode( GL_PROJECTION );
    +    glLoadIdentity( );
    +    /*
    +     * EXERCISE:
    +     * Replace this with a call to glFrustum.
    +     */
    +    gluPerspective( 60.0, ratio, 1.0, 1024.0 );
    +}
    +
    +int main( int argc, char* argv[] )
    +{
    +    /* Information about the current video settings. */
    +    const SDL_VideoInfo* info = NULL;
    +    /* Dimensions of our window. */
    +    int width = 0;
    +    int height = 0;
    +    /* Color depth in bits of our window. */
    +    int bpp = 0;
    +    /* Flags we will pass into SDL_SetVideoMode. */
    +    int flags = 0;
    +
    +    /* First, initialize SDL's video subsystem. */
    +    if( SDL_Init( SDL_INIT_VIDEO ) < 0 ) {
    +        /* Failed, exit. */
    +        fprintf( stderr, "Video initialization failed: %s\n",
    +             SDL_GetError( ) );
    +        quit_tutorial( 1 );
    +    }
    +
    +    /* Let's get some video information. */
    +    info = SDL_GetVideoInfo( );
    +
    +    if( !info ) {
    +        /* This should probably never happen. */
    +        fprintf( stderr, "Video query failed: %s\n",
    +             SDL_GetError( ) );
    +        quit_tutorial( 1 );
    +    }
    +
    +    /*
    +     * Set our width/height to 640/480 (you would
    +     * of course let the user decide this in a normal
    +     * app). We get the bpp we will request from
    +     * the display. On X11, VidMode can't change
    +     * resolution, so this is probably being overly
    +     * safe. Under Win32, ChangeDisplaySettings
    +     * can change the bpp.
    +     */
    +    width = 640;
    +    height = 480;
    +    bpp = info->vfmt->BitsPerPixel;
    +
    +    /*
    +     * Now, we want to setup our requested
    +     * window attributes for our OpenGL window.
    +     * We want *at least* 5 bits of red, green
    +     * and blue. We also want at least a 16-bit
    +     * depth buffer.
    +     *
    +     * The last thing we do is request a double
    +     * buffered window. '1' turns on double
    +     * buffering, '0' turns it off.
    +     *
    +     * Note that we do not use SDL_DOUBLEBUF in
    +     * the flags to SDL_SetVideoMode. That does
    +     * not affect the GL attribute state, only
    +     * the standard 2D blitting setup.
    +     */
    +    SDL_GL_SetAttribute( SDL_GL_RED_SIZE, 5 );
    +    SDL_GL_SetAttribute( SDL_GL_GREEN_SIZE, 5 );
    +    SDL_GL_SetAttribute( SDL_GL_BLUE_SIZE, 5 );
    +    SDL_GL_SetAttribute( SDL_GL_DEPTH_SIZE, 16 );
    +    SDL_GL_SetAttribute( SDL_GL_DOUBLEBUFFER, 1 );
    +
    +    /*
    +     * We want to request that SDL provide us
    +     * with an OpenGL window, in a fullscreen
    +     * video mode.
    +     *
    +     * EXERCISE:
    +     * Make starting windowed an option, and
    +     * handle the resize events properly with
    +     * glViewport.
    +     */
    +    flags = SDL_OPENGL | SDL_FULLSCREEN;
    +
    +    /*
    +     * Set the video mode
    +     */
    +    if( SDL_SetVideoMode( width, height, bpp, flags ) == 0 ) {
    +        /* 
    +         * This could happen for a variety of reasons,
    +         * including DISPLAY not being set, the specified
    +         * resolution not being available, etc.
    +         */
    +        fprintf( stderr, "Video mode set failed: %s\n",
    +             SDL_GetError( ) );
    +        quit_tutorial( 1 );
    +    }
    +
    +    /*
    +     * At this point, we should have a properly setup
    +     * double-buffered window for use with OpenGL.
    +     */
    +    setup_opengl( width, height );
    +
    +    /*
    +     * Now we want to begin our normal app process--
    +     * an event loop with a lot of redrawing.
    +     */
    +    while( 1 ) {
    +        /* Process incoming events. */
    +        process_events( );
    +        /* Draw the screen. */
    +        draw_screen( );
    +    }
    +
    +    /*
    +     * EXERCISE:
    +     * Record timings using SDL_GetTicks() and
    +     * and print out frames per second at program
    +     * end.
    +     */
    +
    +    /* Never reached. */
    +    return 0;
    +}

    PrevHomeNext
    Graphics and VideoUpInput handling
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/index.html b/Externals/SDL/docs/html/index.html new file mode 100644 index 0000000000..f86ff191d3 --- /dev/null +++ b/Externals/SDL/docs/html/index.html @@ -0,0 +1,1156 @@ +
    Table of Contents
    I. SDL Guide
    Preface
    About SDL
    About SDLdoc
    Credits
    1. The Basics
    Introduction
    Initializing SDL
    2. Graphics and Video
    Introduction to SDL Video
    Using OpenGL With SDL
    3. Input handling
    Handling Joysticks
    Handling the Keyboard
    4. Examples
    Introduction
    Event Examples
    Audio Examples
    CDROM Examples
    Time Examples
    II. SDL Reference
    5. General
    SDL_Init -- Initializes SDL
    SDL_InitSubSystem -- Initialize subsystems
    SDL_QuitSubSystem -- Shut down a subsystem
    SDL_Quit -- Shut down SDL
    SDL_WasInit -- Check which subsystems are initialized
    SDL_GetError -- Get SDL error string
    SDL_envvars -- SDL environment variables
    6. Video
    SDL_GetVideoSurface -- returns a pointer to the current display surface
    SDL_GetVideoInfo -- returns a pointer to information about the video hardware
    SDL_VideoDriverName -- Obtain the name of the video driver
    SDL_ListModes -- Returns a pointer to an array of available screen dimensions for +the given format and video flags
    SDL_VideoModeOK -- Check to see if a particular video mode is supported.
    SDL_SetVideoMode -- Set up a video mode with the specified width, height and bits-per-pixel.
    SDL_UpdateRect -- Makes sure the given area is updated on the given screen.
    SDL_UpdateRects -- Makes sure the given list of rectangles is updated on the given screen.
    SDL_Flip -- Swaps screen buffers
    SDL_SetColors -- Sets a portion of the colormap for the given 8-bit surface.
    SDL_SetPalette -- Sets the colors in the palette of an 8-bit surface.
    SDL_SetGamma -- Sets the color gamma function for the display
    SDL_GetGammaRamp -- Gets the color gamma lookup tables for the display
    SDL_SetGammaRamp -- Sets the color gamma lookup tables for the display
    SDL_MapRGB -- Map a RGB color value to a pixel format.
    SDL_MapRGBA -- Map a RGBA color value to a pixel format.
    SDL_GetRGB -- Get RGB values from a pixel in the specified pixel format.
    SDL_GetRGBA -- Get RGBA values from a pixel in the specified pixel format.
    SDL_CreateRGBSurface -- Create an empty SDL_Surface
    SDL_CreateRGBSurfaceFrom -- Create an SDL_Surface from pixel data
    SDL_FreeSurface -- Frees (deletes) a SDL_Surface
    SDL_LockSurface -- Lock a surface for directly access.
    SDL_UnlockSurface -- Unlocks a previously locked surface.
    SDL_LoadBMP -- Load a Windows BMP file into an SDL_Surface.
    SDL_SaveBMP -- Save an SDL_Surface as a Windows BMP file.
    SDL_SetColorKey -- Sets the color key (transparent pixel) in a blittable surface and +RLE acceleration.
    SDL_SetAlpha -- Adjust the alpha properties of a surface
    SDL_SetClipRect -- Sets the clipping rectangle for a surface.
    SDL_GetClipRect -- Gets the clipping rectangle for a surface.
    SDL_ConvertSurface -- Converts a surface to the same format as another surface.
    SDL_BlitSurface -- This performs a fast blit from the source surface to the destination surface.
    SDL_FillRect -- This function performs a fast fill of the given rectangle with some color
    SDL_DisplayFormat -- Convert a surface to the display format
    SDL_DisplayFormatAlpha -- Convert a surface to the display format
    SDL_WarpMouse -- Set the position of the mouse cursor.
    SDL_CreateCursor -- Creates a new mouse cursor.
    SDL_FreeCursor -- Frees a cursor created with SDL_CreateCursor.
    SDL_SetCursor -- Set the currently active mouse cursor.
    SDL_GetCursor -- Get the currently active mouse cursor.
    SDL_ShowCursor -- Toggle whether or not the cursor is shown on the screen.
    SDL_GL_LoadLibrary -- Specify an OpenGL library
    SDL_GL_GetProcAddress -- Get the address of a GL function
    SDL_GL_GetAttribute -- Get the value of a special SDL/OpenGL attribute
    SDL_GL_SetAttribute -- Set a special SDL/OpenGL attribute
    SDL_GL_SwapBuffers -- Swap OpenGL framebuffers/Update Display
    SDL_CreateYUVOverlay -- Create a YUV video overlay
    SDL_LockYUVOverlay -- Lock an overlay
    SDL_UnlockYUVOverlay -- Unlock an overlay
    SDL_DisplayYUVOverlay -- Blit the overlay to the display
    SDL_FreeYUVOverlay -- Free a YUV video overlay
    SDL_GLattr -- SDL GL Attributes
    SDL_Rect -- Defines a rectangular area
    SDL_Color -- Format independent color description
    SDL_Palette -- Color palette for 8-bit pixel formats
    SDL_PixelFormat -- Stores surface format information
    SDL_Surface -- Graphical Surface Structure
    SDL_VideoInfo -- Video Target information
    SDL_Overlay -- YUV video overlay
    7. Window Management
    SDL_WM_SetCaption -- Sets the window tile and icon name.
    SDL_WM_GetCaption -- Gets the window title and icon name.
    SDL_WM_SetIcon -- Sets the icon for the display window.
    SDL_WM_IconifyWindow -- Iconify/Minimise the window
    SDL_WM_ToggleFullScreen -- Toggles fullscreen mode
    SDL_WM_GrabInput -- Grabs mouse and keyboard input.
    8. Events
    Introduction
    SDL Event Structures.
    Event Functions.
    9. Joystick
    SDL_NumJoysticks -- Count available joysticks.
    SDL_JoystickName -- Get joystick name.
    SDL_JoystickOpen -- Opens a joystick for use.
    SDL_JoystickOpened -- Determine if a joystick has been opened
    SDL_JoystickIndex -- Get the index of an SDL_Joystick.
    SDL_JoystickNumAxes -- Get the number of joystick axes
    SDL_JoystickNumBalls -- Get the number of joystick trackballs
    SDL_JoystickNumHats -- Get the number of joystick hats
    SDL_JoystickNumButtons -- Get the number of joysitck buttons
    SDL_JoystickUpdate -- Updates the state of all joysticks
    SDL_JoystickGetAxis -- Get the current state of an axis
    SDL_JoystickGetHat -- Get the current state of a joystick hat
    SDL_JoystickGetButton -- Get the current state of a given button on a given joystick
    SDL_JoystickGetBall -- Get relative trackball motion
    SDL_JoystickClose -- Closes a previously opened joystick
    10. Audio
    SDL_AudioSpec -- Audio Specification Structure
    SDL_OpenAudio -- Opens the audio device with the desired parameters.
    SDL_PauseAudio -- Pauses and unpauses the audio callback processing
    SDL_GetAudioStatus -- Get the current audio state
    SDL_LoadWAV -- Load a WAVE file
    SDL_FreeWAV -- Frees previously opened WAV data
    SDL_AudioCVT -- Audio Conversion Structure
    SDL_BuildAudioCVT -- Initializes a SDL_AudioCVT structure for conversion
    SDL_ConvertAudio -- Convert audio data to a desired audio format.
    SDL_MixAudio -- Mix audio data
    SDL_LockAudio -- Lock out the callback function
    SDL_UnlockAudio -- Unlock the callback function
    SDL_CloseAudio -- Shuts down audio processing and closes the audio device.
    11. CD-ROM
    SDL_CDNumDrives -- Returns the number of CD-ROM drives on the system.
    SDL_CDName -- Returns a human-readable, system-dependent identifier for the CD-ROM.
    SDL_CDOpen -- Opens a CD-ROM drive for access.
    SDL_CDStatus -- Returns the current status of the given drive.
    SDL_CDPlay -- Play a CD
    SDL_CDPlayTracks -- Play the given CD track(s)
    SDL_CDPause -- Pauses a CDROM
    SDL_CDResume -- Resumes a CDROM
    SDL_CDStop -- Stops a CDROM
    SDL_CDEject -- Ejects a CDROM
    SDL_CDClose -- Closes a SDL_CD handle
    SDL_CD -- CDROM Drive Information
    SDL_CDtrack -- CD Track Information Structure
    12. Multi-threaded Programming
    SDL_CreateThread -- Creates a new thread of execution that shares its parent's properties.
    SDL_ThreadID -- Get the 32-bit thread identifier for the current thread.
    SDL_GetThreadID -- Get the SDL thread ID of a SDL_Thread
    SDL_WaitThread -- Wait for a thread to finish.
    SDL_KillThread -- Gracelessly terminates the thread.
    SDL_CreateMutex -- Create a mutex
    SDL_DestroyMutex -- Destroy a mutex
    SDL_mutexP -- Lock a mutex
    SDL_mutexV -- Unlock a mutex
    SDL_CreateSemaphore -- Creates a new semaphore and assigns an initial value to it.
    SDL_DestroySemaphore -- Destroys a semaphore that was created by SDL_CreateSemaphore.
    SDL_SemWait -- Lock a semaphore and suspend the thread if the semaphore value is zero.
    SDL_SemTryWait -- Attempt to lock a semaphore but don't suspend the thread.
    SDL_SemWaitTimeout -- Lock a semaphore, but only wait up to a specified maximum time.
    SDL_SemPost -- Unlock a semaphore.
    SDL_SemValue -- Return the current value of a semaphore.
    SDL_CreateCond -- Create a condition variable
    SDL_DestroyCond -- Destroy a condition variable
    SDL_CondSignal -- Restart a thread wait on a condition variable
    SDL_CondBroadcast -- Restart all threads waiting on a condition variable
    SDL_CondWait -- Wait on a condition variable
    SDL_CondWaitTimeout -- Wait on a condition variable, with timeout
    13. Time
    SDL_GetTicks -- Get the number of milliseconds since the SDL library initialization.
    SDL_Delay -- Wait a specified number of milliseconds before returning.
    SDL_AddTimer -- Add a timer which will call a callback after the specified number of milliseconds has +elapsed.
    SDL_RemoveTimer -- Remove a timer which was added with +SDL_AddTimer.
    SDL_SetTimer -- Set a callback to run after the specified number of milliseconds has +elapsed.

      Next
      SDL Guide
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/joystick.html b/Externals/SDL/docs/html/joystick.html new file mode 100644 index 0000000000..abdb28c197 --- /dev/null +++ b/Externals/SDL/docs/html/joystick.html @@ -0,0 +1,296 @@ +Joystick
    SDL Library Documentation
    PrevNext

    Chapter 9. Joystick

    Table of Contents
    SDL_NumJoysticks -- Count available joysticks.
    SDL_JoystickName -- Get joystick name.
    SDL_JoystickOpen -- Opens a joystick for use.
    SDL_JoystickOpened -- Determine if a joystick has been opened
    SDL_JoystickIndex -- Get the index of an SDL_Joystick.
    SDL_JoystickNumAxes -- Get the number of joystick axes
    SDL_JoystickNumBalls -- Get the number of joystick trackballs
    SDL_JoystickNumHats -- Get the number of joystick hats
    SDL_JoystickNumButtons -- Get the number of joysitck buttons
    SDL_JoystickUpdate -- Updates the state of all joysticks
    SDL_JoystickGetAxis -- Get the current state of an axis
    SDL_JoystickGetHat -- Get the current state of a joystick hat
    SDL_JoystickGetButton -- Get the current state of a given button on a given joystick
    SDL_JoystickGetBall -- Get relative trackball motion
    SDL_JoystickClose -- Closes a previously opened joystick

    Joysticks, and other similar input devices, have a very strong role in game playing and SDL provides comprehensive support for them. Axes, Buttons, POV Hats and trackballs are all supported.

    Joystick support is initialized by passed the SDL_INIT_JOYSTICK flag to SDL_Init. Once initilized joysticks must be opened using SDL_JoystickOpen.

    While using the functions describe in this secton may seem like the best way to access and read from joysticks, in most cases they aren't. Ideally joysticks should be read using the event system. To enable this, you must set the joystick event processing state with SDL_JoystickEventState. Joysticks must be opened before they can be used of course.

    Note: If you are not handling the joystick via the event queue then you must explicitly request a joystick update by calling SDL_JoystickUpdate.

    Note: Force Feedback is not yet support. Sam (slouken@libsdl.org) is soliciting suggestions from people with force-feedback experience on the best wat to desgin the API.


    PrevHomeNext
    SDL_JoystickEventStateUpSDL_NumJoysticks
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/reference.html b/Externals/SDL/docs/html/reference.html new file mode 100644 index 0000000000..e7707a7504 --- /dev/null +++ b/Externals/SDL/docs/html/reference.html @@ -0,0 +1,194 @@ +SDL Reference
    SDL Library Documentation
    PrevNext

    II. SDL Reference


    PrevHomeNext
    Time Examples General
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlactiveevent.html b/Externals/SDL/docs/html/sdlactiveevent.html new file mode 100644 index 0000000000..d3f2821e72 --- /dev/null +++ b/Externals/SDL/docs/html/sdlactiveevent.html @@ -0,0 +1,335 @@ +SDL_ActiveEvent
    SDL Library Documentation
    PrevNext

    SDL_ActiveEvent

    Name

    SDL_ActiveEvent -- Application visibility event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 gain;
    +  Uint8 state;
    +} SDL_ActiveEvent;

    Structure Data

    typeSDL_ACTIVEEVENT.
    gain0 if the event is a loss or 1 if it is a gain.
    stateSDL_APPMOUSEFOCUS if mouse focus was gained or lost, SDL_APPINPUTFOCUS if input focus was gained or lost, or SDL_APPACTIVE if the application was iconified (gain=0) or restored(gain=1).

    Description

    SDL_ActiveEvent is a member of the SDL_Event union and is used when an event of type SDL_ACTIVEEVENT is reported.

    When the mouse leaves or enters the window area a SDL_APPMOUSEFOCUS type activation event occurs, if the mouse entered the window then gain will be 1, otherwise gain will be 0. A SDL_APPINPUTFOCUS type activation event occurs when the application loses or gains keyboard focus. This usually occurs when another application is made active. Finally, a SDL_APPACTIVE type event occurs when the application is either minimised/iconified (gain=0) or restored.

    Note: This event does not occur when an application window is first created.


    PrevHomeNext
    SDL_EventUpSDL_KeyboardEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdladdtimer.html b/Externals/SDL/docs/html/sdladdtimer.html new file mode 100644 index 0000000000..81c49e56d6 --- /dev/null +++ b/Externals/SDL/docs/html/sdladdtimer.html @@ -0,0 +1,296 @@ +SDL_AddTimer
    SDL Library Documentation
    PrevNext

    SDL_AddTimer

    Name

    SDL_AddTimer -- Add a timer which will call a callback after the specified number of milliseconds has +elapsed.

    Synopsis

    #include "SDL.h"

    SDL_TimerID SDL_AddTimer(Uint32 interval, SDL_NewTimerCallback callback, void *param);

    Callback

    /* type definition for the "new" timer callback function */
    +typedef Uint32 (*SDL_NewTimerCallback)(Uint32 interval, void *param);

    Description

    Adds a callback function to be run after the specified number of +milliseconds has elapsed. The callback function is passed the current +timer interval and the user supplied parameter from the +SDL_AddTimer call and returns the next timer +interval. If the returned value from the callback is the same as the one +passed in, the periodic alarm continues, otherwise a new alarm is +scheduled.

    To cancel a currently running timer call +SDL_RemoveTimer with the +timer ID returned from +SDL_AddTimer.

    The timer callback function may run in a different thread than your +main program, and so shouldn't call any functions from within itself. +You may always call SDL_PushEvent, however.

    The granularity of the timer is platform-dependent, but you should count +on it being at least 10 ms as this is the most common number. +This means that if +you request a 16 ms timer, your callback will run approximately 20 ms +later on an unloaded system. If you wanted to set a flag signaling +a frame update at 30 frames per second (every 33 ms), you might set a +timer for 30 ms (see example below). + +If you use this function, you need to pass SDL_INIT_TIMER +to SDL_Init.

    Return Value

    Returns an ID value for the added timer or +NULL if there was an error.

    Examples

    my_timer_id = SDL_AddTimer((33/10)*10, my_callbackfunc, my_callback_param);


    PrevHomeNext
    SDL_DelayUpSDL_RemoveTimer
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlaudiocvt.html b/Externals/SDL/docs/html/sdlaudiocvt.html new file mode 100644 index 0000000000..ff39209080 --- /dev/null +++ b/Externals/SDL/docs/html/sdlaudiocvt.html @@ -0,0 +1,556 @@ +SDL_AudioCVT
    SDL Library Documentation
    PrevNext

    SDL_AudioCVT

    Name

    SDL_AudioCVT -- Audio Conversion Structure

    Structure Definition

    typedef struct{
    +  int needed;
    +  Uint16 src_format;
    +  Uint16 dest_format;
    +  double rate_incr;
    +  Uint8 *buf;
    +  int len;
    +  int len_cvt;
    +  int len_mult;
    +  double len_ratio;
    +  void (*filters[10])(struct SDL_AudioCVT *cvt, Uint16 format);
    +  int filter_index;
    +} SDL_AudioCVT;

    Structure Data

    neededSet to one if the conversion is possible
    src_formatAudio format of the source
    dest_formatAudio format of the destination
    rate_incrRate conversion increment
    bufAudio buffer
    lenLength of the original audio buffer in bytes
    len_cvtLength of converted audio buffer in bytes (calculated)
    len_multbuf must be len*len_mult bytes in size(calculated)
    len_ratioFinal audio size is len*len_ratio
    filters[10](..)Pointers to functions needed for this conversion
    filter_indexCurrent conversion function

    Description

    The SDL_AudioCVT is used to convert audio data between different formats. A SDL_AudioCVT structure is created with the SDL_BuildAudioCVT function, while the actual conversion is done by the SDL_ConvertAudio function.

    Many of the fields in the SDL_AudioCVT structure should be considered private and their function will not be discussed here.

    Uint8 *buf

    This points to the audio data that will be used in the conversion. It is both the source and the destination, which means the converted audio data overwrites the original data. It also means that the converted data may be larger than the original data (if you were converting from 8-bit to 16-bit, for instance), so you must ensure buf is large enough. See below.

    int len

    This is the length of the original audio data in bytes.

    int len_mult

    As explained above, the audio buffer needs to be big enough to store the converted data, which may be bigger than the original audio data. The length of buf should be len*len_mult.

    double len_ratio

    When you have finished converting your audio data, you need to know how much of your audio buffer is valid. len*len_ratio is the size of the converted audio data in bytes. This is very similar to len_mult, however when the convert audio data is shorter than the original len_mult would be 1. len_ratio, on the other hand, would be a fractional number between 0 and 1.


    PrevHomeNext
    SDL_FreeWAVUpSDL_BuildAudioCVT
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlaudiospec.html b/Externals/SDL/docs/html/sdlaudiospec.html new file mode 100644 index 0000000000..fc6fa75035 --- /dev/null +++ b/Externals/SDL/docs/html/sdlaudiospec.html @@ -0,0 +1,589 @@ +SDL_AudioSpec
    SDL Library Documentation
    PrevNext

    SDL_AudioSpec

    Name

    SDL_AudioSpec -- Audio Specification Structure

    Structure Definition

    typedef struct{
    +  int freq;
    +  Uint16 format;
    +  Uint8 channels;
    +  Uint8 silence;
    +  Uint16 samples;
    +  Uint32 size;
    +  void (*callback)(void *userdata, Uint8 *stream, int len);
    +  void *userdata;
    +} SDL_AudioSpec;

    Structure Data

    freqAudio frequency in samples per second
    formatAudio data format
    channelsNumber of channels: 1 mono, 2 stereo
    silenceAudio buffer silence value (calculated)
    samplesAudio buffer size in samples
    sizeAudio buffer size in bytes (calculated)
    callback(..)Callback function for filling the audio buffer
    userdataPointer the user data which is passed to the callback function

    Description

    The SDL_AudioSpec structure is used to describe the format of some audio data. This structure is used by SDL_OpenAudio and SDL_LoadWAV. While all fields are used by SDL_OpenAudio only freq, format, samples and channels are used by SDL_LoadWAV. We will detail these common members here.

    freq

    The number of samples sent to the sound device every second. Common values are 11025, 22050 and 44100. The higher the better.

    format

    Specifies the size and type of each sample element +

    AUDIO_U8

    Unsigned 8-bit samples

    AUDIO_S8

    Signed 8-bit samples

    AUDIO_U16 or AUDIO_U16LSB

    Unsigned 16-bit little-endian samples

    AUDIO_S16 or AUDIO_S16LSB

    Signed 16-bit little-endian samples

    AUDIO_U16MSB

    Unsigned 16-bit big-endian samples

    AUDIO_S16MSB

    Signed 16-bit big-endian samples

    AUDIO_U16SYS

    Either AUDIO_U16LSB or AUDIO_U16MSB depending on you systems endianness

    AUDIO_S16SYS

    Either AUDIO_S16LSB or AUDIO_S16MSB depending on you systems endianness

    channelsThe number of seperate sound channels. 1 is mono (single channel), 2 is stereo (dual channel).
    samplesWhen used with SDL_OpenAudio this refers to the size of the audio buffer in samples. A sample a chunk of audio data of the size specified in format mulitplied by the number of channels. When the SDL_AudioSpec is used with SDL_LoadWAV samples is set to 4096.


    PrevHomeNext
    AudioUpSDL_OpenAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlblitsurface.html b/Externals/SDL/docs/html/sdlblitsurface.html new file mode 100644 index 0000000000..3123ff5dde --- /dev/null +++ b/Externals/SDL/docs/html/sdlblitsurface.html @@ -0,0 +1,339 @@ +SDL_BlitSurface
    SDL Library Documentation
    PrevNext

    SDL_BlitSurface

    Name

    SDL_BlitSurface -- This performs a fast blit from the source surface to the destination surface.

    Synopsis

    #include "SDL.h"

    int SDL_BlitSurface(SDL_Surface *src, SDL_Rect *srcrect, SDL_Surface *dst, SDL_Rect *dstrect);

    Description

    This performs a fast blit from the source surface to the destination surface.

    The width and height in srcrect determine the +size of the copied rectangle. Only the position is used in the +dstrect (the width and height are ignored).

    If srcrect is NULL, the +entire surface is copied. If dstrect is +NULL, then the destination position (upper left +corner) is (0, 0).

    The final blit rectangle is saved in +dstrect after all clipping is performed +(srcrect is not modified).

    The blit function should not be called on a locked surface.

    The results of blitting operations vary greatly depending on whether SDL_SRCAPLHA is set or not. See SDL_SetAlpha for an explaination of how this affects your results. Colorkeying and alpha attributes also interact with surface blitting, as the following pseudo-code should hopefully explain. +

    if (source surface has SDL_SRCALPHA set) {
    +    if (source surface has alpha channel (that is, format->Amask != 0))
    +        blit using per-pixel alpha, ignoring any colour key
    +    else {
    +        if (source surface has SDL_SRCCOLORKEY set)
    +            blit using the colour key AND the per-surface alpha value
    +        else
    +            blit using the per-surface alpha value
    +    }
    +} else {
    +    if (source surface has SDL_SRCCOLORKEY set)
    +        blit using the colour key
    +    else
    +        ordinary opaque rectangular blit
    +}

    Return Value

    If the blit is successful, it returns 0, +otherwise it returns -1.

    If either of the surfaces were in video memory, and the blit returns +-2, the video memory was lost, so it should be +reloaded with artwork and re-blitted: +

            while ( SDL_BlitSurface(image, imgrect, screen, dstrect) == -2 ) {
    +                while ( SDL_LockSurface(image)) < 0 )
    +                        SDL_Delay(10);
    +                -- Write image pixels to image->pixels --
    +                SDL_UnlockSurface(image);
    +        }
    +This happens under DirectX 5.0 when the system switches away from your +fullscreen application. Locking the surface will also fail until you +have access to the video memory again.


    PrevHomeNext
    SDL_ConvertSurfaceUpSDL_FillRect
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlbuildaudiocvt.html b/Externals/SDL/docs/html/sdlbuildaudiocvt.html new file mode 100644 index 0000000000..2e8420e8a9 --- /dev/null +++ b/Externals/SDL/docs/html/sdlbuildaudiocvt.html @@ -0,0 +1,291 @@ +SDL_BuildAudioCVT
    SDL Library Documentation
    PrevNext

    SDL_BuildAudioCVT

    Name

    SDL_BuildAudioCVT -- Initializes a SDL_AudioCVT structure for conversion

    Synopsis

    #include "SDL.h"

    int SDL_BuildAudioCVT(SDL_AudioCVT *cvt, Uint16 src_format, Uint8 src_channels, int src_rate, Uint16 dst_format, Uint8 dst_channels, int dst_rate);

    Description

    Before an SDL_AudioCVT structure can be used to convert audio data it must be initialized with source and destination information.

    src_format and dst_format are the source and destination format of the conversion. (For information on audio formats see SDL_AudioSpec). src_channels and dst_channels are the number of channels in the source and destination formats. Finally, src_rate and dst_rate are the frequency or samples-per-second of the source and destination formats. Once again, see SDL_AudioSpec.

    Return Values

    Returns -1 if the filter could not be built or 1 if it could.

    Examples

    See SDL_ConvertAudio.


    PrevHomeNext
    SDL_AudioCVTUpSDL_ConvertAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcd.html b/Externals/SDL/docs/html/sdlcd.html new file mode 100644 index 0000000000..6f8a7cdf60 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcd.html @@ -0,0 +1,359 @@ +SDL_CD
    SDL Library Documentation
    PrevNext

    SDL_CD

    Name

    SDL_CD -- CDROM Drive Information

    Structure Definition

    typedef struct{
    +  int id;
    +  CDstatus status;
    +  int numtracks;
    +  int cur_track;
    +  int cur_frame;
    +  SDL_CDtrack track[SDL_MAX_TRACKS+1];
    +} SDL_CD;

    Structure Data

    idPrivate drive identifier
    statusDrive status
    numtracksNumber of tracks on the CD
    cur_trackCurrent track
    cur_frameCurrent frame offset within the track
    track[SDL_MAX_TRACKS+1]Array of track descriptions. (see SDL_CDtrack)

    Description

    An SDL_CD structure is returned by SDL_CDOpen. It represents an opened CDROM device and stores information on the layout of the tracks on the disc.

    A frame is the base data unit of a CD. CD_FPS frames is equal to 1 second of music. SDL provides two macros for converting between time and frames: FRAMES_TO_MSF(f, M,S,F) and MSF_TO_FRAMES.

    Examples

    int min, sec, frame;
    +int frame_offset;
    +
    +FRAMES_TO_MSF(cdrom->cur_frame, &min, &sec, &frame);
    +printf("Current Position: %d minutes, %d seconds, %d frames\n", min, sec, frame);
    +
    +frame_offset=MSF_TO_FRAMES(min, sec, frame);

    PrevHomeNext
    SDL_CDCloseUpSDL_CDtrack
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdclose.html b/Externals/SDL/docs/html/sdlcdclose.html new file mode 100644 index 0000000000..2a984a8b47 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdclose.html @@ -0,0 +1,217 @@ +SDL_CDClose
    SDL Library Documentation
    PrevNext

    SDL_CDClose

    Name

    SDL_CDClose -- Closes a SDL_CD handle

    Synopsis

    #include "SDL.h"

    void SDL_CDClose(SDL_CD *cdrom);

    Description

    Closes the given cdrom handle.

    See Also

    SDL_CDOpen, +SDL_CD


    PrevHomeNext
    SDL_CDEjectUpSDL_CD
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdeject.html b/Externals/SDL/docs/html/sdlcdeject.html new file mode 100644 index 0000000000..03a3b780b5 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdeject.html @@ -0,0 +1,226 @@ +SDL_CDEject
    SDL Library Documentation
    PrevNext

    SDL_CDEject

    Name

    SDL_CDEject -- Ejects a CDROM

    Synopsis

    #include "SDL.h"

    int SDL_CDEject(SDL_CD *cdrom);

    Description

    Ejects the given cdrom.

    Return Value

    Returns 0 on success, or -1 on an error.

    See Also

    SDL_CD


    PrevHomeNext
    SDL_CDStopUpSDL_CDClose
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdname.html b/Externals/SDL/docs/html/sdlcdname.html new file mode 100644 index 0000000000..55a18e26e3 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdname.html @@ -0,0 +1,239 @@ +SDL_CDName
    SDL Library Documentation
    PrevNext

    SDL_CDName

    Name

    SDL_CDName -- Returns a human-readable, system-dependent identifier for the CD-ROM.

    Synopsis

    #include "SDL.h"

    const char *SDL_CDName(int drive);

    Description

    Returns a human-readable, system-dependent identifier for the CD-ROM. drive is the index of the drive. Drive indices start to 0 and end at SDL_CDNumDrives()-1.

    Examples

    • "/dev/cdrom"

    • "E:"

    • "/dev/disk/ide/1/master"


    PrevHomeNext
    SDL_CDNumDrivesUpSDL_CDOpen
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdnumdrives.html b/Externals/SDL/docs/html/sdlcdnumdrives.html new file mode 100644 index 0000000000..9816a739bb --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdnumdrives.html @@ -0,0 +1,205 @@ +SDL_CDNumDrives
    SDL Library Documentation
    PrevNext

    SDL_CDNumDrives

    Name

    SDL_CDNumDrives -- Returns the number of CD-ROM drives on the system.

    Synopsis

    #include "SDL.h"

    int SDL_CDNumDrives(void);

    Description

    Returns the number of CD-ROM drives on the system.

    See Also

    SDL_CDOpen


    PrevHomeNext
    CD-ROMUpSDL_CDName
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdopen.html b/Externals/SDL/docs/html/sdlcdopen.html new file mode 100644 index 0000000000..09a6bd9f78 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdopen.html @@ -0,0 +1,275 @@ +SDL_CDOpen
    SDL Library Documentation
    PrevNext

    SDL_CDOpen

    Name

    SDL_CDOpen -- Opens a CD-ROM drive for access.

    Synopsis

    #include "SDL.h"

    SDL_CD *SDL_CDOpen(int drive);

    Description

    Opens a CD-ROM drive for access. It returns a SDL_CD structure on success, or NULL if the drive was invalid or busy. This newly opened CD-ROM becomes the default CD used when other CD functions are passed a NULL CD-ROM handle.

    Drives are numbered starting with 0. +Drive 0 is the system default CD-ROM.

    Examples

    SDL_CD *cdrom;
    +int cur_track;
    +int min, sec, frame;
    +SDL_Init(SDL_INIT_CDROM);
    +atexit(SDL_Quit);
    +
    +/* Check for CD drives */
    +if(!SDL_CDNumDrives()){
    +  /* None found */
    +  fprintf(stderr, "No CDROM devices available\n");
    +  exit(-1);
    +}
    +
    +/* Open the default drive */
    +cdrom=SDL_CDOpen(0);
    +
    +/* Did if open? Check if cdrom is NULL */
    +if(!cdrom){
    +  fprintf(stderr, "Couldn't open drive: %s\n", SDL_GetError());
    +  exit(-1);
    +}
    +
    +/* Print Volume info */
    +printf("Name: %s\n", SDL_CDName(0));
    +printf("Tracks: %d\n", cdrom->numtracks);
    +for(cur_track=0;cur_track < cdrom->numtracks; cur_track++){
    +  FRAMES_TO_MSF(cdrom->track[cur_track].length, &min, &sec, &frame);
    +  printf("\tTrack %d: Length %d:%d\n", cur_track, min, sec);
    +}
    +
    +SDL_CDClose(cdrom);

    PrevHomeNext
    SDL_CDNameUpSDL_CDStatus
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdpause.html b/Externals/SDL/docs/html/sdlcdpause.html new file mode 100644 index 0000000000..4def8e362e --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdpause.html @@ -0,0 +1,233 @@ +SDL_CDPause
    SDL Library Documentation
    PrevNext

    SDL_CDPause

    Name

    SDL_CDPause -- Pauses a CDROM

    Synopsis

    #include "SDL.h"

    int SDL_CDPause(SDL_CD *cdrom);

    Description

    Pauses play on the given cdrom.

    Return Value

    Returns 0 on success, or -1 on an error.


    PrevHomeNext
    SDL_CDPlayTracksUpSDL_CDResume
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdplay.html b/Externals/SDL/docs/html/sdlcdplay.html new file mode 100644 index 0000000000..dc6489cc8d --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdplay.html @@ -0,0 +1,243 @@ +SDL_CDPlay
    SDL Library Documentation
    PrevNext

    SDL_CDPlay

    Name

    SDL_CDPlay -- Play a CD

    Synopsis

    #include "SDL.h"

    int SDL_CDPlay(SDL_CD *cdrom, int start, int length);

    Description

    Plays the given cdrom, starting a frame start for length frames.

    Return Values

    Returns 0 on success, or -1 on an error.


    PrevHomeNext
    SDL_CDStatusUpSDL_CDPlayTracks
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdplaytracks.html b/Externals/SDL/docs/html/sdlcdplaytracks.html new file mode 100644 index 0000000000..7546181904 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdplaytracks.html @@ -0,0 +1,325 @@ +SDL_CDPlayTracks
    SDL Library Documentation
    PrevNext

    SDL_CDPlayTracks

    Name

    SDL_CDPlayTracks -- Play the given CD track(s)

    Synopsis

    #include "SDL.h"

    int SDL_CDPlayTracks(SDL_CD *cdrom, int start_track, int start_frame, int ntracks, int nframes));

    Description

    SDL_CDPlayTracks plays the given CD starting at track +start_track, for ntracks tracks.

    start_frame is the frame offset, from the beginning of the start_track, at which to start. nframes is the frame offset, from the beginning of the last track (start_track+ntracks), at which to end playing.

    SDL_CDPlayTracks should only be called after calling +SDL_CDStatus +to get track information about the CD.

    Note: Data tracks are ignored.

    Return Value

    Returns 0, or -1 +if there was an error.

    Examples

    /* assuming cdrom is a previously opened device */
    +/* Play the entire CD */
    +if(CD_INDRIVE(SDL_CDStatus(cdrom)))
    +  SDL_CDPlayTracks(cdrom, 0, 0, 0, 0);
    +
    +/* Play the first track */
    +if(CD_INDRIVE(SDL_CDStatus(cdrom)))
    +  SDL_CDPlayTracks(cdrom, 0, 0, 1, 0);
    +
    +/* Play first 15 seconds of the 2nd track */
    +if(CD_INDRIVE(SDL_CDStatus(cdrom)))
    +  SDL_CDPlayTracks(cdrom, 1, 0, 0, CD_FPS*15);
    +


    PrevHomeNext
    SDL_CDPlayUpSDL_CDPause
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdresume.html b/Externals/SDL/docs/html/sdlcdresume.html new file mode 100644 index 0000000000..4a25ab69b6 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdresume.html @@ -0,0 +1,233 @@ +SDL_CDResume
    SDL Library Documentation
    PrevNext

    SDL_CDResume

    Name

    SDL_CDResume -- Resumes a CDROM

    Synopsis

    #include "SDL.h"

    int SDL_CDResume(SDL_CD *cdrom);

    Description

    Resumes play on the given cdrom.

    Return Value

    Returns 0 on success, or -1 on an error.


    PrevHomeNext
    SDL_CDPauseUpSDL_CDStop
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdstatus.html b/Externals/SDL/docs/html/sdlcdstatus.html new file mode 100644 index 0000000000..3ebf9657e6 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdstatus.html @@ -0,0 +1,273 @@ +SDL_CDStatus
    SDL Library Documentation
    PrevNext

    SDL_CDStatus

    Name

    SDL_CDStatus -- Returns the current status of the given drive.

    Synopsis

    #include "SDL.h"

    CDstatus SDL_CDStatus(SDL_CD *cdrom);

    /* Given a status, returns true if there's a disk in the drive */
    +#define CD_INDRIVE(status)      ((int)status > 0)

    Description

    This function returns the current status of the given drive. Status is described like so: +

    typedef enum {
    +  CD_TRAYEMPTY,
    +  CD_STOPPED,
    +  CD_PLAYING,
    +  CD_PAUSED,
    +  CD_ERROR = -1
    +} CDstatus;

    If the drive has a CD in it, the table of contents of the CD and current +play position of the CD will be stored in the SDL_CD structure.

    The macro CD_INDRIVE is provided for convenience, +and given a status returns true if there's a disk in the drive.

    Note: SDL_CDStatus also updates the SDL_CD structure passed to it.

    Example

    int playTrack(int track)
    +{
    +  int playing = 0;
    +
    +  if ( CD_INDRIVE(SDL_CDStatus(cdrom)) ) {
    +  /* clamp to the actual number of tracks on the CD */
    +    if (track >= cdrom->numtracks) {
    +      track = cdrom->numtracks-1;
    +    }
    +
    +    if ( SDL_CDPlayTracks(cdrom, track, 0, 1, 0) == 0 ) {
    +      playing = 1;
    +    }
    +  }
    +  return playing;
    +}

    See Also

    SDL_CD


    PrevHomeNext
    SDL_CDOpenUpSDL_CDPlay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdstop.html b/Externals/SDL/docs/html/sdlcdstop.html new file mode 100644 index 0000000000..68f8d81bed --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdstop.html @@ -0,0 +1,226 @@ +SDL_CDStop
    SDL Library Documentation
    PrevNext

    SDL_CDStop

    Name

    SDL_CDStop -- Stops a CDROM

    Synopsis

    #include "SDL.h"

    int SDL_CDStop(SDL_CD *cdrom);

    Description

    Stops play on the given cdrom.

    Return Value

    Returns 0 on success, or -1 on an error.

    See Also

    SDL_CDPlay,


    PrevHomeNext
    SDL_CDResumeUpSDL_CDEject
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcdtrack.html b/Externals/SDL/docs/html/sdlcdtrack.html new file mode 100644 index 0000000000..bbb04bbd25 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcdtrack.html @@ -0,0 +1,313 @@ +SDL_CDtrack
    SDL Library Documentation
    PrevNext

    SDL_CDtrack

    Name

    SDL_CDtrack -- CD Track Information Structure

    Structure Definition

    typedef struct{
    +  Uint8 id;
    +  Uint8 type;
    +  Uint32 length;
    +  Uint32 offset;
    +} SDL_CDtrack;

    Structure Data

    idTrack number (0-99)
    typeSDL_AUDIO_TRACK or SDL_DATA_TRACK
    lengthLength, in frames, of this track
    offsetFrame offset to the beginning of this track

    Description

    SDL_CDtrack stores data on each track on a CD, its fields should be pretty self explainatory. It is a member a the SDL_CD structure.

    Note: Frames can be converted to standard timings. There are CD_FPS frames per second, so SDL_CDtrack.length/CD_FPS=length_in_seconds.

    See Also

    SDL_CD


    PrevHomeNext
    SDL_CDUpMulti-threaded Programming
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcloseaudio.html b/Externals/SDL/docs/html/sdlcloseaudio.html new file mode 100644 index 0000000000..599f058e44 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcloseaudio.html @@ -0,0 +1,205 @@ +SDL_CloseAudio
    SDL Library Documentation
    PrevNext

    SDL_CloseAudio

    Name

    SDL_CloseAudio -- Shuts down audio processing and closes the audio device.

    Synopsis

    #include "SDL.h"

    void SDL_CloseAudio(void);

    Description

    This function shuts down audio processing and closes the audio device.

    See Also

    SDL_OpenAudio


    PrevHomeNext
    SDL_UnlockAudioUpCD-ROM
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcolor.html b/Externals/SDL/docs/html/sdlcolor.html new file mode 100644 index 0000000000..c8b7d44fc9 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcolor.html @@ -0,0 +1,300 @@ +SDL_Color
    SDL Library Documentation
    PrevNext

    SDL_Color

    Name

    SDL_Color -- Format independent color description

    Structure Definition

    typedef struct{
    +  Uint8 r;
    +  Uint8 g;
    +  Uint8 b;
    +  Uint8 unused;
    +} SDL_Color;

    Structure Data

    rRed intensity
    gGreen intensity
    bBlue intensity
    unusedUnused

    Description

    SDL_Color describes a color in a format independent way. You can convert a SDL_Color to a pixel value for a certain pixel format using SDL_MapRGB.


    PrevHomeNext
    SDL_RectUpSDL_Palette
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcondbroadcast.html b/Externals/SDL/docs/html/sdlcondbroadcast.html new file mode 100644 index 0000000000..9b0fc83e0f --- /dev/null +++ b/Externals/SDL/docs/html/sdlcondbroadcast.html @@ -0,0 +1,224 @@ +SDL_CondBroadcast
    SDL Library Documentation
    PrevNext

    SDL_CondBroadcast

    Name

    SDL_CondBroadcast -- Restart all threads waiting on a condition variable

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_CondBroadcast(SDL_cond *cond);

    Description

    Restarts all threads that are waiting on the condition variable, cond. Returns 0 on success, or -1 on an error.


    PrevHomeNext
    SDL_CondSignalUpSDL_CondWait
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcondsignal.html b/Externals/SDL/docs/html/sdlcondsignal.html new file mode 100644 index 0000000000..24e9175994 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcondsignal.html @@ -0,0 +1,224 @@ +SDL_CondSignal
    SDL Library Documentation
    PrevNext

    SDL_CondSignal

    Name

    SDL_CondSignal -- Restart a thread wait on a condition variable

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_CondSignal(SDL_cond *cond);

    Description

    Restart one of the threads that are waiting on the condition variable, cond. Returns 0 on success of -1 on an error.


    PrevHomeNext
    SDL_DestroyCondUpSDL_CondBroadcast
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcondwait.html b/Externals/SDL/docs/html/sdlcondwait.html new file mode 100644 index 0000000000..8f15452589 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcondwait.html @@ -0,0 +1,231 @@ +SDL_CondWait
    SDL Library Documentation
    PrevNext

    SDL_CondWait

    Name

    SDL_CondWait -- Wait on a condition variable

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_CondWait(SDL_cond *cond, SDL_mutex *mut);

    Description

    Wait on the condition variable cond and unlock the provided mutex. The mutex must the locked before entering this function. Returns 0 when it is signalled, or -1 on an error.


    PrevHomeNext
    SDL_CondBroadcastUpSDL_CondWaitTimeout
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcondwaittimeout.html b/Externals/SDL/docs/html/sdlcondwaittimeout.html new file mode 100644 index 0000000000..deed50bfe2 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcondwaittimeout.html @@ -0,0 +1,230 @@ +SDL_CondWaitTimeout
    SDL Library Documentation
    PrevNext

    SDL_CondWaitTimeout

    Name

    SDL_CondWaitTimeout -- Wait on a condition variable, with timeout

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_CondWaitTimeout(SDL_cond *cond, SDL_mutex *mutex, Uint32 ms);

    Description

    Wait on the condition variable cond for, at most, ms milliseconds. mut is unlocked so it must be locked when the function is called. Returns SDL_MUTEX_TIMEDOUT if the condition is not signalled in the allotted time, 0 if it was signalled or -1 on an error.

    See Also

    SDL_CondWait


    PrevHomeNext
    SDL_CondWaitUpTime
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlconvertaudio.html b/Externals/SDL/docs/html/sdlconvertaudio.html new file mode 100644 index 0000000000..52f122968a --- /dev/null +++ b/Externals/SDL/docs/html/sdlconvertaudio.html @@ -0,0 +1,407 @@ +SDL_ConvertAudio
    SDL Library Documentation
    PrevNext

    SDL_ConvertAudio

    Name

    SDL_ConvertAudio -- Convert audio data to a desired audio format.

    Synopsis

    #include "SDL.h"

    int SDL_ConvertAudio(SDL_AudioCVT *cvt);

    Description

    SDL_ConvertAudio takes one parameter, cvt, which was previously initilized. Initilizing a SDL_AudioCVT is a two step process. First of all, the structure must be passed to SDL_BuildAudioCVT along with source and destination format parameters. Secondly, the cvt->buf and cvt->len fields must be setup. cvt->buf should point to the audio data and cvt->len should be set to the length of the audio data in bytes. Remember, the length of the buffer pointed to by buf show be len*len_mult bytes in length.

    Once the SDL_AudioCVTstructure is initilized then we can pass it to SDL_ConvertAudio, which will convert the audio data pointer to by cvt->buf. If SDL_ConvertAudio returned 0 then the conversion was completed successfully, otherwise -1 is returned.

    If the conversion completed successfully then the converted audio data can be read from cvt->buf. The amount of valid, converted, audio data in the buffer is equal to cvt->len*cvt->len_ratio.

    Examples

    /* Converting some WAV data to hardware format */
    +void my_audio_callback(void *userdata, Uint8 *stream, int len);
    +
    +SDL_AudioSpec *desired, *obtained;
    +SDL_AudioSpec wav_spec;
    +SDL_AudioCVT  wav_cvt;
    +Uint32 wav_len;
    +Uint8 *wav_buf;
    +int ret;
    +
    +/* Allocated audio specs */
    +desired = malloc(sizeof(SDL_AudioSpec));
    +obtained = malloc(sizeof(SDL_AudioSpec));
    +
    +/* Set desired format */
    +desired->freq=22050;
    +desired->format=AUDIO_S16LSB;
    +desired->samples=8192;
    +desired->callback=my_audio_callback;
    +desired->userdata=NULL;
    +
    +/* Open the audio device */
    +if ( SDL_OpenAudio(desired, obtained) < 0 ){
    +  fprintf(stderr, "Couldn't open audio: %s\n", SDL_GetError());
    +  exit(-1);
    +}
    +        
    +free(desired);
    +
    +/* Load the test.wav */
    +if( SDL_LoadWAV("test.wav", &wav_spec, &wav_buf, &wav_len) == NULL ){
    +  fprintf(stderr, "Could not open test.wav: %s\n", SDL_GetError());
    +  SDL_CloseAudio();
    +  free(obtained);
    +  exit(-1);
    +}
    +                                            
    +/* Build AudioCVT */
    +ret = SDL_BuildAudioCVT(&wav_cvt,
    +                        wav_spec.format, wav_spec.channels, wav_spec.freq,
    +                        obtained->format, obtained->channels, obtained->freq);
    +
    +/* Check that the convert was built */
    +if(ret==-1){
    +  fprintf(stderr, "Couldn't build converter!\n");
    +  SDL_CloseAudio();
    +  free(obtained);
    +  SDL_FreeWAV(wav_buf);
    +}
    +
    +/* Setup for conversion */
    +wav_cvt.buf = malloc(wav_len * wav_cvt.len_mult);
    +wav_cvt.len = wav_len;
    +memcpy(wav_cvt.buf, wav_buf, wav_len);
    +
    +/* We can delete to original WAV data now */
    +SDL_FreeWAV(wav_buf);
    +
    +/* And now we're ready to convert */
    +SDL_ConvertAudio(&wav_cvt);
    +
    +/* do whatever */
    +.
    +.
    +.
    +.
    +

    PrevHomeNext
    SDL_BuildAudioCVTUpSDL_MixAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlconvertsurface.html b/Externals/SDL/docs/html/sdlconvertsurface.html new file mode 100644 index 0000000000..cc21f7833e --- /dev/null +++ b/Externals/SDL/docs/html/sdlconvertsurface.html @@ -0,0 +1,271 @@ +SDL_ConvertSurface
    SDL Library Documentation
    PrevNext

    SDL_ConvertSurface

    Name

    SDL_ConvertSurface -- Converts a surface to the same format as another surface.

    Synopsis

    #include "SDL/SDL.h"

    SDL_Surface *SDL_ConvertSurface(SDL_Surface *src, SDL_PixelFormat *fmt, Uint32 flags);

    Description

    Creates a new surface of the specified format, and then copies and maps +the given surface to it. If this function fails, it returns +NULL.

    The flags parameter is passed to +SDL_CreateRGBSurface +and has those semantics.

    This function is used internally by +SDL_DisplayFormat.

    This function can only be called after SDL_Init.

    Return Value

    Returns either a pointer to the new surface, or +NULL on error.


    PrevHomeNext
    SDL_GetClipRectUpSDL_BlitSurface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreatecond.html b/Externals/SDL/docs/html/sdlcreatecond.html new file mode 100644 index 0000000000..02fcdb2b3e --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreatecond.html @@ -0,0 +1,240 @@ +SDL_CreateCond
    SDL Library Documentation
    PrevNext

    SDL_CreateCond

    Name

    SDL_CreateCond -- Create a condition variable

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    SDL_cond *SDL_CreateCond(void);

    Description

    Creates a condition variable.

    Examples

    SDL_cond *cond;
    +
    +cond=SDL_CreateCond();
    +.
    +.
    +/* Do stuff */
    +
    +.
    +.
    +SDL_DestroyCond(cond);

    PrevHomeNext
    SDL_SemValueUpSDL_DestroyCond
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreatecursor.html b/Externals/SDL/docs/html/sdlcreatecursor.html new file mode 100644 index 0000000000..a444165ff0 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreatecursor.html @@ -0,0 +1,398 @@ +SDL_CreateCursor
    SDL Library Documentation
    PrevNext

    SDL_CreateCursor

    Name

    SDL_CreateCursor -- Creates a new mouse cursor.

    Synopsis

    #include "SDL.h"

    SDL_Cursor *SDL_CreateCursor(Uint8 *data, Uint8 *mask, int w, int h, int hot_x, int hot_y);

    Description

    Create a cursor using the specified data and mask (in MSB format). +The cursor width must be a multiple of 8 bits.

    The cursor is created in black and white according to the following: +

    Data / MaskResulting pixel on screen
    0 / 1White
    1 / 1Black
    0 / 0Transparent
    1 / 0Inverted color if possible, black if not.

    Cursors created with this function must be freed with +SDL_FreeCursor.

    Example

    /* Stolen from the mailing list */
    +/* Creates a new mouse cursor from an XPM */
    +
    +
    +/* XPM */
    +static const char *arrow[] = {
    +  /* width height num_colors chars_per_pixel */
    +  "    32    32        3            1",
    +  /* colors */
    +  "X c #000000",
    +  ". c #ffffff",
    +  "  c None",
    +  /* pixels */
    +  "X                               ",
    +  "XX                              ",
    +  "X.X                             ",
    +  "X..X                            ",
    +  "X...X                           ",
    +  "X....X                          ",
    +  "X.....X                         ",
    +  "X......X                        ",
    +  "X.......X                       ",
    +  "X........X                      ",
    +  "X.....XXXXX                     ",
    +  "X..X..X                         ",
    +  "X.X X..X                        ",
    +  "XX  X..X                        ",
    +  "X    X..X                       ",
    +  "     X..X                       ",
    +  "      X..X                      ",
    +  "      X..X                      ",
    +  "       XX                       ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "                                ",
    +  "0,0"
    +};
    +
    +static SDL_Cursor *init_system_cursor(const char *image[])
    +{
    +  int i, row, col;
    +  Uint8 data[4*32];
    +  Uint8 mask[4*32];
    +  int hot_x, hot_y;
    +
    +  i = -1;
    +  for ( row=0; row<32; ++row ) {
    +    for ( col=0; col<32; ++col ) {
    +      if ( col % 8 ) {
    +        data[i] <<= 1;
    +        mask[i] <<= 1;
    +      } else {
    +        ++i;
    +        data[i] = mask[i] = 0;
    +      }
    +      switch (image[4+row][col]) {
    +        case 'X':
    +          data[i] |= 0x01;
    +          mask[i] |= 0x01;
    +          break;
    +        case '.':
    +          mask[i] |= 0x01;
    +          break;
    +        case ' ':
    +          break;
    +      }
    +    }
    +  }
    +  sscanf(image[4+row], "%d,%d", &hot_x, &hot_y);
    +  return SDL_CreateCursor(data, mask, 32, 32, hot_x, hot_y);
    +}

    PrevHomeNext
    SDL_WarpMouseUpSDL_FreeCursor
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreatemutex.html b/Externals/SDL/docs/html/sdlcreatemutex.html new file mode 100644 index 0000000000..53ed48bb20 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreatemutex.html @@ -0,0 +1,249 @@ +SDL_CreateMutex
    SDL Library Documentation
    PrevNext

    SDL_CreateMutex

    Name

    SDL_CreateMutex -- Create a mutex

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    SDL_mutex *SDL_CreateMutex(void);

    Description

    Create a new, unlocked mutex.

    Examples

    SDL_mutex *mut;
    +
    +mut=SDL_CreateMutex();
    +.
    +.
    +if(SDL_mutexP(mut)==-1){
    +  fprintf(stderr, "Couldn't lock mutex\n");
    +  exit(-1);
    +}
    +.
    +/* Do stuff while mutex is locked */
    +.
    +.
    +if(SDL_mutexV(mut)==-1){
    +  fprintf(stderr, "Couldn't unlock mutex\n");
    +  exit(-1);
    +}
    +
    +SDL_DestroyMutex(mut);

    PrevHomeNext
    SDL_KillThreadUpSDL_DestroyMutex
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreatergbsurface.html b/Externals/SDL/docs/html/sdlcreatergbsurface.html new file mode 100644 index 0000000000..736ec8f96f --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreatergbsurface.html @@ -0,0 +1,458 @@ +SDL_CreateRGBSurface
    SDL Library Documentation
    PrevNext

    SDL_CreateRGBSurface

    Name

    SDL_CreateRGBSurface -- Create an empty SDL_Surface

    Synopsis

    #include "SDL.h"

    SDL_Surface *SDL_CreateRGBSurface(Uint32 flags, int width, int height, int depth, Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask);

    Description

    Allocate an empty surface (must be called after SDL_SetVideoMode)

    If depth is 8 bits an empty palette is allocated for the surface, otherwise a 'packed-pixel' SDL_PixelFormat is created using the [RGBA]mask's provided (see SDL_PixelFormat). The flags specifies the type of surface that should be created, it is an OR'd combination of the following possible values.

    SDL_SWSURFACESDL will create the surface in system memory. This improves the performance of pixel level access, however you may not be able to take advantage of some types of hardware blitting.
    SDL_HWSURFACESDL will attempt to create the surface in video memory. This will allow SDL to take advantage of Video->Video blits (which are often accelerated).
    SDL_SRCCOLORKEYThis flag turns on colourkeying for blits from this surface. If +SDL_HWSURFACE is also specified and colourkeyed blits +are hardware-accelerated, then SDL will attempt to place the surface in +video memory. +Use SDL_SetColorKey +to set or clear this flag after surface creation.
    SDL_SRCALPHAThis flag turns on alpha-blending for blits from this surface. If +SDL_HWSURFACE is also specified and alpha-blending blits +are hardware-accelerated, then the surface will be placed in video memory if +possible. +Use SDL_SetAlpha to +set or clear this flag after surface creation.

    Note: If an alpha-channel is specified (that is, if Amask is +nonzero), then the SDL_SRCALPHA flag is automatically +set. You may remove this flag by calling +SDL_SetAlpha +after surface creation.

    Return Value

    Returns the created surface, or NULL upon error.

    Example

        /* Create a 32-bit surface with the bytes of each pixel in R,G,B,A order,
    +       as expected by OpenGL for textures */
    +    SDL_Surface *surface;
    +    Uint32 rmask, gmask, bmask, amask;
    +
    +    /* SDL interprets each pixel as a 32-bit number, so our masks must depend
    +       on the endianness (byte order) of the machine */
    +#if SDL_BYTEORDER == SDL_BIG_ENDIAN
    +    rmask = 0xff000000;
    +    gmask = 0x00ff0000;
    +    bmask = 0x0000ff00;
    +    amask = 0x000000ff;
    +#else
    +    rmask = 0x000000ff;
    +    gmask = 0x0000ff00;
    +    bmask = 0x00ff0000;
    +    amask = 0xff000000;
    +#endif
    +
    +    surface = SDL_CreateRGBSurface(SDL_SWSURFACE, width, height, 32,
    +                                   rmask, gmask, bmask, amask);
    +    if(surface == NULL) {
    +        fprintf(stderr, "CreateRGBSurface failed: %s\n", SDL_GetError());
    +        exit(1);
    +    }

    PrevHomeNext
    SDL_GetRGBAUpSDL_CreateRGBSurfaceFrom
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreatergbsurfacefrom.html b/Externals/SDL/docs/html/sdlcreatergbsurfacefrom.html new file mode 100644 index 0000000000..6acfdccae8 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreatergbsurfacefrom.html @@ -0,0 +1,256 @@ +SDL_CreateRGBSurfaceFrom
    SDL Library Documentation
    PrevNext

    SDL_CreateRGBSurfaceFrom

    Name

    SDL_CreateRGBSurfaceFrom -- Create an SDL_Surface from pixel data

    Synopsis

    #include "SDL.h"

    SDL_Surface *SDL_CreateRGBSurfaceFrom(void *pixels, int width, int height, int depth, int pitch, Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask);

    Description

    Creates an SDL_Surface from the provided pixel data.

    The data stored in pixels is assumed to be of the depth specified in the parameter list. The pixel data is not copied into the SDL_Surface structure so it should not be freed until the surface has been freed with a called to SDL_FreeSurface. pitch is the length of each scanline in bytes.

    See SDL_CreateRGBSurface for a more detailed description of the other parameters.

    Return Value

    Returns the created surface, or NULL upon error.


    PrevHomeNext
    SDL_CreateRGBSurfaceUpSDL_FreeSurface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreatesemaphore.html b/Externals/SDL/docs/html/sdlcreatesemaphore.html new file mode 100644 index 0000000000..43dcbf5bff --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreatesemaphore.html @@ -0,0 +1,303 @@ +SDL_CreateSemaphore
    SDL Library Documentation
    PrevNext

    SDL_CreateSemaphore

    Name

    SDL_CreateSemaphore -- Creates a new semaphore and assigns an initial value to it.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    SDL_sem *SDL_CreateSemaphore(Uint32 initial_value);

    Description

    SDL_CreateSemaphore() creates a new semaphore and +initializes it with the value initial_value. +Each locking operation on the semaphore by +SDL_SemWait, +SDL_SemTryWait or +SDL_SemWaitTimeout +will atomically decrement the semaphore value. The locking operation will be blocked +if the semaphore value is not positive (greater than zero). Each unlock operation by +SDL_SemPost +will atomically increment the semaphore value.

    Return Value

    Returns a pointer to an initialized semaphore or +NULL if there was an error.

    Examples

    SDL_sem *my_sem;
    +
    +my_sem = SDL_CreateSemaphore(INITIAL_SEM_VALUE);
    +
    +if (my_sem == NULL) {
    +        return CREATE_SEM_FAILED;
    +}


    PrevHomeNext
    SDL_mutexVUpSDL_DestroySemaphore
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreatethread.html b/Externals/SDL/docs/html/sdlcreatethread.html new file mode 100644 index 0000000000..ca3c2d9201 --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreatethread.html @@ -0,0 +1,223 @@ +SDL_CreateThread
    SDL Library Documentation
    PrevNext

    SDL_CreateThread

    Name

    SDL_CreateThread -- Creates a new thread of execution that shares its parent's properties.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    SDL_Thread *SDL_CreateThread(int (*fn)(void *), void *data);

    Description

    SDL_CreateThread creates a new thread of execution +that shares all of its parent's global memory, signal handlers, +file descriptors, etc, and runs the function fn +passed the void pointer data +The thread quits when this function returns.


    PrevHomeNext
    Multi-threaded ProgrammingUpSDL_ThreadID
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlcreateyuvoverlay.html b/Externals/SDL/docs/html/sdlcreateyuvoverlay.html new file mode 100644 index 0000000000..c24ef6ee2e --- /dev/null +++ b/Externals/SDL/docs/html/sdlcreateyuvoverlay.html @@ -0,0 +1,256 @@ +SDL_CreateYUVOverlay
    SDL Library Documentation
    PrevNext

    SDL_CreateYUVOverlay

    Name

    SDL_CreateYUVOverlay -- Create a YUV video overlay

    Synopsis

    #include "SDL.h"

    SDL_Overlay *SDL_CreateYUVOverlay(int width, int height, Uint32 format, SDL_Surface *display);

    Description

    SDL_CreateYUVOverlay creates a YUV overlay of the specified width, height and format (see SDL_Overlay for a list of available formats), for the provided display. A SDL_Overlay structure is returned.

    The term 'overlay' is a misnomer since, unless the overlay is created in hardware, the contents for the display surface underneath the area where the overlay is shown will be overwritten when the overlay is displayed.


    PrevHomeNext
    SDL_GL_SwapBuffersUpSDL_LockYUVOverlay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdldelay.html b/Externals/SDL/docs/html/sdldelay.html new file mode 100644 index 0000000000..a5417fa66f --- /dev/null +++ b/Externals/SDL/docs/html/sdldelay.html @@ -0,0 +1,231 @@ +SDL_Delay
    SDL Library Documentation
    PrevNext

    SDL_Delay

    Name

    SDL_Delay -- Wait a specified number of milliseconds before returning.

    Synopsis

    #include "SDL.h"

    void SDL_Delay(Uint32 ms);

    Description

    Wait a specified number of milliseconds before returning. SDL_Delay will wait at least the specified time, but possible longer due to OS scheduling.

    Note: Count on a delay granularity of at least 10 ms. +Some platforms have shorter clock ticks but this is the most common.

    See Also

    SDL_AddTimer


    PrevHomeNext
    SDL_GetTicksUpSDL_AddTimer
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdldestroycond.html b/Externals/SDL/docs/html/sdldestroycond.html new file mode 100644 index 0000000000..ac0804286a --- /dev/null +++ b/Externals/SDL/docs/html/sdldestroycond.html @@ -0,0 +1,206 @@ +SDL_DestroyCond
    SDL Library Documentation
    PrevNext

    SDL_DestroyCond

    Name

    SDL_DestroyCond -- Destroy a condition variable

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    void SDL_DestroyCond(SDL_cond *cond);

    Description

    Destroys a condition variable.


    PrevHomeNext
    SDL_CreateCondUpSDL_CondSignal
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdldestroymutex.html b/Externals/SDL/docs/html/sdldestroymutex.html new file mode 100644 index 0000000000..949bfc5d54 --- /dev/null +++ b/Externals/SDL/docs/html/sdldestroymutex.html @@ -0,0 +1,209 @@ +SDL_DestroyMutex
    SDL Library Documentation
    PrevNext

    SDL_DestroyMutex

    Name

    SDL_DestroyMutex -- Destroy a mutex

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    void SDL_DestroyMutex(SDL_mutex *mutex);

    Description

    Destroy a previously created mutex.


    PrevHomeNext
    SDL_CreateMutexUpSDL_mutexP
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdldestroysemaphore.html b/Externals/SDL/docs/html/sdldestroysemaphore.html new file mode 100644 index 0000000000..d32bdfaf57 --- /dev/null +++ b/Externals/SDL/docs/html/sdldestroysemaphore.html @@ -0,0 +1,278 @@ +SDL_DestroySemaphore
    SDL Library Documentation
    PrevNext

    SDL_DestroySemaphore

    Name

    SDL_DestroySemaphore -- Destroys a semaphore that was created by SDL_CreateSemaphore.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    void SDL_DestroySemaphore(SDL_sem *sem);

    Description

    SDL_DestroySemaphore destroys the semaphore pointed to +by sem that was created by +SDL_CreateSemaphore. +It is not safe to destroy a semaphore if there are threads currently blocked +waiting on it.

    Examples

    if (my_sem != NULL) {
    +        SDL_DestroySemaphore(my_sem);
    +        my_sem = NULL;
    +}


    PrevHomeNext
    SDL_CreateSemaphoreUpSDL_SemWait
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdldisplayformat.html b/Externals/SDL/docs/html/sdldisplayformat.html new file mode 100644 index 0000000000..c91adfe50a --- /dev/null +++ b/Externals/SDL/docs/html/sdldisplayformat.html @@ -0,0 +1,262 @@ +SDL_DisplayFormat
    SDL Library Documentation
    PrevNext

    SDL_DisplayFormat

    Name

    SDL_DisplayFormat -- Convert a surface to the display format

    Synopsis

    #include "SDL.h"

    SDL_Surface *SDL_DisplayFormat(SDL_Surface *surface);

    Description

    This function takes a surface and copies it to a new surface of the +pixel format and colors of the video framebuffer, suitable for fast +blitting onto the display surface. It calls +SDL_ConvertSurface

    If you want to take advantage of hardware colorkey or alpha blit +acceleration, you should set the colorkey and alpha value before +calling this function.

    If you want an alpha channel, see SDL_DisplayFormatAlpha.

    Return Value

    If the conversion fails or runs out of memory, it returns +NULL


    PrevHomeNext
    SDL_FillRectUpSDL_DisplayFormatAlpha
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdldisplayformatalpha.html b/Externals/SDL/docs/html/sdldisplayformatalpha.html new file mode 100644 index 0000000000..6e88604d02 --- /dev/null +++ b/Externals/SDL/docs/html/sdldisplayformatalpha.html @@ -0,0 +1,250 @@ +SDL_DisplayFormatAlpha
    SDL Library Documentation
    PrevNext

    SDL_DisplayFormatAlpha

    Name

    SDL_DisplayFormatAlpha -- Convert a surface to the display format

    Synopsis

    #include "SDL.h"

    SDL_Surface *SDL_DisplayFormatAlpha(SDL_Surface *surface);

    Description

    This function takes a surface and copies it to a new surface of the +pixel format and colors of the video framebuffer plus an alpha channel, +suitable for fast blitting onto the display surface. It calls +SDL_ConvertSurface

    If you want to take advantage of hardware colorkey or alpha blit +acceleration, you should set the colorkey and alpha value before +calling this function.

    This function can be used to convert a colourkey to an alpha channel, +if the SDL_SRCCOLORKEY flag is set on the surface. +The generated surface will then be transparent (alpha=0) where the +pixels match the colourkey, and opaque (alpha=255) elsewhere.

    Return Value

    If the conversion fails or runs out of memory, it returns +NULL


    PrevHomeNext
    SDL_DisplayFormatUpSDL_WarpMouse
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdldisplayyuvoverlay.html b/Externals/SDL/docs/html/sdldisplayyuvoverlay.html new file mode 100644 index 0000000000..456c9985df --- /dev/null +++ b/Externals/SDL/docs/html/sdldisplayyuvoverlay.html @@ -0,0 +1,246 @@ +SDL_DisplayYUVOverlay
    SDL Library Documentation
    PrevNext

    SDL_DisplayYUVOverlay

    Name

    SDL_DisplayYUVOverlay -- Blit the overlay to the display

    Synopsis

    #include "SDL.h"

    int SDL_DisplayYUVOverlay(SDL_Overlay *overlay, SDL_Rect *dstrect);

    Description

    Blit the overlay to the surface specified when it was created. The SDL_Rect structure, dstrect, specifies the position and size of the destination. If the dstrect is a larger or smaller than the overlay then the overlay will be scaled, this is optimized for 2x scaling.

    Return Values

    Returns 0 on success


    PrevHomeNext
    SDL_UnlockYUVOverlayUpSDL_FreeYUVOverlay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlenablekeyrepeat.html b/Externals/SDL/docs/html/sdlenablekeyrepeat.html new file mode 100644 index 0000000000..878feb14f3 --- /dev/null +++ b/Externals/SDL/docs/html/sdlenablekeyrepeat.html @@ -0,0 +1,238 @@ +SDL_EnableKeyRepeat
    SDL Library Documentation
    PrevNext

    SDL_EnableKeyRepeat

    Name

    SDL_EnableKeyRepeat -- Set keyboard repeat rate.

    Synopsis

    #include "SDL.h"

    int SDL_EnableKeyRepeat(int delay, int interval);

    Description

    Enables or disables the keyboard repeat rate. delay specifies how long the key must be pressed before it begins repeating, it then repeats at the speed specified by interval. Both delay and interval are expressed in milliseconds.

    Setting delay to 0 disables key repeating completely. Good default values are SDL_DEFAULT_REPEAT_DELAY and SDL_DEFAULT_REPEAT_INTERVAL.

    Return Value

    Returns 0 on success and -1 on failure.


    PrevHomeNext
    SDL_EnableUNICODEUpSDL_GetMouseState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlenableunicode.html b/Externals/SDL/docs/html/sdlenableunicode.html new file mode 100644 index 0000000000..855debbc99 --- /dev/null +++ b/Externals/SDL/docs/html/sdlenableunicode.html @@ -0,0 +1,252 @@ +SDL_EnableUNICODE
    SDL Library Documentation
    PrevNext

    SDL_EnableUNICODE

    Name

    SDL_EnableUNICODE -- Enable UNICODE translation

    Synopsis

    #include "SDL.h"

    int SDL_EnableUNICODE(int enable);

    Description

    Enables/Disables Unicode keyboard translation.

    To obtain the character codes corresponding to received keyboard events, +Unicode translation must first be turned on using this function. The +translation incurs a slight overhead for each keyboard event and is therefore +disabled by default. For each subsequently received key down event, the +unicode member of the +SDL_keysym structure +will then contain the corresponding character code, or zero for keysyms that do +not correspond to any character code.

    A value of 1 for enable enables Unicode translation; +0 disables it, and -1 leaves it unchanged (useful for querying the current +translation mode).

    Note that only key press events will be translated, not release events.

    Return Value

    Returns the previous translation mode (0 or 1).

    See Also

    SDL_keysym


    PrevHomeNext
    SDL_GetKeyNameUpSDL_EnableKeyRepeat
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlenvvars.html b/Externals/SDL/docs/html/sdlenvvars.html new file mode 100644 index 0000000000..8999ed1f1f --- /dev/null +++ b/Externals/SDL/docs/html/sdlenvvars.html @@ -0,0 +1,1227 @@ +SDL_envvars
    SDL Library Documentation
    PrevNext

    SDL_envvars

    Name

    SDL_envvars -- SDL environment variables

    Description

    Not a function, set using setenv()

    Several environment variables are available to modify the +behaviour of SDL. Using these variables isn't recommened and the names +and presence of these variables aren't guaranteed from one release to +the next. However, they can be very useful for debugging +purposes.

    Video

    SDL_FBACCEL

    If set to 0, disable hardware acceleration in the linux fbcon driver.

    SDL_FBDEV

    Frame buffer device to use in the linux fbcon driver, instead of /dev/fb0

    SDL_FULLSCREEN_UPDATE

    In the ps2gs driver, sets the SDL_ASYNCBLIT flag on the +display surface.

    SDL_VIDEODRIVER

    Selectes the video driver for SDL to use. Possible values, in the +order they are tried if this variable is not set:

    x11

    dga

    (the XFree86 DGA2)

    nanox

    (Linux)

    fbcon

    (Linux)

    directfb

    (Linux)

    ps2gs

    (Playstation 2)

    ggi

    vgl

    (BSD)

    svgalib

    (Linux)

    aalib

    directx

    (Win32)

    windib

    (Win32)

    bwindow

    (BeOS)

    toolbox

    (MacOS Classic)

    DSp

    (MacOS Classic)

    Quartz

    (Mac OS X)

    CGX

    (Amiga)

    photon

    (QNX)

    dummy

    SDL_VIDEO_CENTERED

    If set, tries to center the SDL window when running in X11 windowed +mode, or using the CyberGrafix driver.

    SDL_VIDEO_GL_DRIVER

    The openGL driver (shared library) to use for X11. Default is libGL.so.1

    SDL_VIDEO_X11_DGAMOUSE

    With XFree86, enables use of DGA mouse if set.

    SDL_VIDEO_X11_MOUSEACCEL

    For X11, sets the mouse acceleration. The value should be a string +on the form:

    "n/d/t"

    where n and d are the +acceleration numerator/denumerators (so mouse movement is accelerated by +n/d), and +t is the threshold above which acceleration applies +(counted as number of pixels the mouse moves at once).

    SDL_VIDEO_X11_NODIRECTCOLOR

    If set, don't attempt to use DirectColor visuals even if they are +present. (SDL will use them otherwise for gamma correction). +This is needed with older X servers when using the XVideo extension.

    SDL_VIDEO_X11_VISUALID

    ID of an X11 visual to use, overriding SDL's default visual selection +algorithm. It can be in decimal or in hex (prefixed by 0x).

    SDL_VIDEO_YUV_DIRECT

    If set, display YUV overlay directly on the video surface if possible, +instead of on the surface passed to +SDL_CreateYUVOverlay.

    SDL_VIDEO_YUV_HWACCEL

    If not set or set to a nonzero value, SDL will attempt to use +hardware YUV acceleration for video playback.

    SDL_WINDOWID

    For X11 or Win32, contains the ID number of the window to be used by +SDL instead of creating its own window. Either in decimal or +in hex (prefixed by 0x).

    Events/Input

    SDL_MOUSE_RELATIVE

    If set to 0, do not use mouse relative mode in X11. The default is +to use it if the mouse is hidden and input is grabbed.

    SDL_MOUSEDEV

    The mouse device to use for the linux fbcon driver. If not set, +SDL first tries to use GPM in repeater mode, then various other +devices (/dev/pcaux, /dev/adbmouse, /dev/mouse etc).

    SDL_MOUSEDEV_IMPS2

    If set, SDL will not try to auto-detect the IMPS/2 protocol of +a PS/2 mouse but use it right away. For the fbcon and ps2gs drivers.

    SDL_MOUSEDRV

    For the linux fbcon driver: if set to ELO, use the ELO touchscreen +controller as a pointer device

    SDL_NO_RAWKBD

    For the libvga driver: If set, do not attempt to put the keyboard in raw mode.

    SDL_NOMOUSE

    If set, the linux fbcon driver will not use a mouse at all.

    SDL_NO_LOCK_KEYS

    Disable CAPS-LOCK and NUM-LOCK suppression of down+up key events, +suitable for games where the player needs these keys to do more than just toggle. +A value of 1 will effect both CAPS-LOCK and NUM-LOCK. +A value of 2 will effect only CAPS-LOCK. +A value of 3 will effect only NUM-LOCK. +All other values have no effect. +

    Audio

    AUDIODEV

    The audio device to use, if SDL_PATH_DSP isn't set.

    SDL_AUDIODRIVER

    Selects the audio driver for SDL to use. Possible values, in the +order they are tried if this variable is not set:

    openbsd

    (OpenBSD)

    dsp

    (OSS /dev/dsp: Linux, Solaris, BSD etc)

    alsa

    (Linux)

    pulse

    (PulseAudio daemon)

    audio

    (Unix style /dev/audio: SunOS, Solaris etc)

    AL

    (Irix)

    artsc

    (ARTS audio daemon)

    esd

    (esound audio daemon)

    nas

    (NAS audio daemon)

    dma

    (OSS /dev/dsp, using DMA)

    dsound

    (Win32 DirectX)

    waveout

    (Win32 WaveOut)

    baudio

    (BeOS)

    sndmgr

    (MacOS SoundManager)

    paud

    (AIX)

    AHI

    (Amiga)

    disk

    (all; output to file)

    SDL_DISKAUDIOFILE

    The name of the output file for the "disk" audio driver. If not +set, the name sdlaudio.raw is used.

    SDL_DISKAUDIODELAY

    For the "disk" audio driver, how long to wait (in ms) before writing +a full sound buffer. The default is 150 ms.

    SDL_DSP_NOSELECT

    For some audio drivers (alsa, paud, dma and dsp), don't use select() +but a timed method instead. May cure some audio problems, or cause +others.

    SDL_PATH_DSP

    The audio device to use. If not set, SDL tries AUDIODEV and then +a platform-dependent default value (/dev/audio on Solaris, +/dev/dsp on Linux etc).

    CD-ROM

    SDL_CDROM

    A colon-separated list of CD-ROM devices to use, in addition to +the standard devices (typically /dev/cdrom, platform-dependent).

    Debugging

    SDL_DEBUG

    If set, causes every call to SDL_SetError (that +is, every time SDL signals an error) to also print an error message on +stderr.

    Joystick

    SDL_JOYSTICK_DEVICE

    Joystick device to use in the linux joystick driver, in addition +to the usual: /dev/js*, /dev/input/event*, /dev/input/js*

    SDL_LINUX_JOYSTICK

    Special joystick configuration string for linux. The format is

    "name numaxes numhats numballs"

    where name is the name string of the joystick +(possibly in single quotes), and the rest are the number of axes, hats +and balls respectively.


    PrevHomeNext
    SDL_GetErrorUpVideo
    diff --git a/Externals/SDL/docs/html/sdlevent.html b/Externals/SDL/docs/html/sdlevent.html new file mode 100644 index 0000000000..dfd21b7fe6 --- /dev/null +++ b/Externals/SDL/docs/html/sdlevent.html @@ -0,0 +1,994 @@ +SDL_Event
    SDL Library Documentation
    PrevNext

    SDL_Event

    Name

    SDL_Event -- General event structure

    Structure Definition

    typedef union{
    +  Uint8 type;
    +  SDL_ActiveEvent active;
    +  SDL_KeyboardEvent key;
    +  SDL_MouseMotionEvent motion;
    +  SDL_MouseButtonEvent button;
    +  SDL_JoyAxisEvent jaxis;
    +  SDL_JoyBallEvent jball;
    +  SDL_JoyHatEvent jhat;
    +  SDL_JoyButtonEvent jbutton;
    +  SDL_ResizeEvent resize;
    +  SDL_ExposeEvent expose;
    +  SDL_QuitEvent quit;
    +  SDL_UserEvent user;
    +  SDL_SysWMEvent syswm;
    +} SDL_Event;

    Description

    The SDL_Event union is the core to all event handling is SDL, its probably the most important structure after SDL_Surface. SDL_Event is a union of all event structures used in SDL, using it is a simple matter of knowing which union member relates to which event type.

    Event typeEvent Structure
    SDL_ACTIVEEVENTSDL_ActiveEvent
    SDL_KEYDOWN/UPSDL_KeyboardEvent
    SDL_MOUSEMOTIONSDL_MouseMotionEvent
    SDL_MOUSEBUTTONDOWN/UPSDL_MouseButtonEvent
    SDL_JOYAXISMOTIONSDL_JoyAxisEvent
    SDL_JOYBALLMOTIONSDL_JoyBallEvent
    SDL_JOYHATMOTIONSDL_JoyHatEvent
    SDL_JOYBUTTONDOWN/UPSDL_JoyButtonEvent
    SDL_QUITSDL_QuitEvent
    SDL_SYSWMEVENTSDL_SysWMEvent
    SDL_VIDEORESIZESDL_ResizeEvent
    SDL_VIDEOEXPOSESDL_ExposeEvent
    SDL_USEREVENTSDL_UserEvent

    Use

    The SDL_Event structure has two uses

    • Reading events on the event queue

    • Placing events on the event queue

    Reading events from the event queue is done with either SDL_PollEvent or SDL_PeepEvents. We'll use SDL_PollEvent and step through an example.

    First off, we create an empty SDL_Event structure. +

    SDL_Event test_event;
    +SDL_PollEvent removes the next event from the event queue, if there are no events on the queue it returns 0 otherwise it returns 1. We use a while loop to process each event in turn. +
    while(SDL_PollEvent(&test_event)) {
    +The SDL_PollEvent function take a pointer to an SDL_Event structure that is to be filled with event information. We know that if SDL_PollEvent removes an event from the queue then the event information will be placed in our test_event structure, but we also know that the type of event will be placed in the type member of test_event. So to handle each event type seperately we use a switch statement. +
      switch(test_event.type) {
    +We need to know what kind of events we're looking for and the event type's of those events. So lets assume we want to detect where the user is moving the mouse pointer within our application. We look through our event types and notice that SDL_MOUSEMOTION is, more than likely, the event we're looking for. A little more research tells use that SDL_MOUSEMOTION events are handled within the SDL_MouseMotionEvent structure which is the motion member of SDL_Event. We can check for the SDL_MOUSEMOTION event type within our switch statement like so: +
        case SDL_MOUSEMOTION:
    +All we need do now is read the information out of the motion member of test_event. +
          printf("We got a motion event.\n");
    +      printf("Current mouse position is: (%d, %d)\n", test_event.motion.x, test_event.motion.y);
    +      break;
    +    default:
    +      printf("Unhandled Event!\n");
    +      break;
    +  }
    +}
    +printf("Event queue empty.\n");

    It is also possible to push events onto the event queue and so use it as a two-way communication path. Both SDL_PushEvent and SDL_PeepEvents allow you to place events onto the event queue. This is usually used to place a SDL_USEREVENT on the event queue, however you could use it to post fake input events if you wished. Creating your own events is a simple matter of choosing the event type you want, setting the type member and filling the appropriate member structure with information. +

    SDL_Event user_event;
    +
    +user_event.type=SDL_USEREVENT;
    +user_event.user.code=2;
    +user_event.user.data1=NULL;
    +user_event.user.data2=NULL;
    +SDL_PushEvent(&user_event);


    PrevHomeNext
    SDL Event Structures.UpSDL_ActiveEvent
    diff --git a/Externals/SDL/docs/html/sdleventstate.html b/Externals/SDL/docs/html/sdleventstate.html new file mode 100644 index 0000000000..b9a24486cb --- /dev/null +++ b/Externals/SDL/docs/html/sdleventstate.html @@ -0,0 +1,276 @@ +SDL_EventState
    SDL Library Documentation
    PrevNext

    SDL_EventState

    Name

    SDL_EventState -- This function allows you to set the state of processing certain events.

    Synopsis

    #include "SDL.h"

    Uint8 SDL_EventState(Uint8 type, int state);

    Description

    This function allows you to set the state of processing certain event type's.

    If state is set to SDL_IGNORE, +that event type will be automatically dropped from the event queue and will +not be filtered.

    If state is set to SDL_ENABLE, +that event type will be processed normally.

    If state is set to SDL_QUERY, +SDL_EventState will return the current processing +state of the specified event type.

    A list of event type's can be found in the SDL_Event section.

    See Also

    SDL_Event


    PrevHomeNext
    SDL_GetEventFilterUpSDL_GetKeyState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlexposeevent.html b/Externals/SDL/docs/html/sdlexposeevent.html new file mode 100644 index 0000000000..82c2a3e7e2 --- /dev/null +++ b/Externals/SDL/docs/html/sdlexposeevent.html @@ -0,0 +1,252 @@ +SDL_ExposeEvent
    SDL Library Documentation
    PrevNext

    SDL_ExposeEvent

    Name

    SDL_ExposeEvent -- Quit requested event

    Structure Definition

    typedef struct{
    +  Uint8 type
    +} SDL_ExposeEvent;

    Structure Data

    typeSDL_VIDEOEXPOSE

    Description

    SDL_ExposeEvent is a member of the SDL_Event union and is used whan an event of type SDL_VIDEOEXPOSE is reported.

    A VIDEOEXPOSE event is triggered when the screen has been modified +outside of the application, usually by the window manager and needs to +be redrawn.


    PrevHomeNext
    SDL_ResizeEventUpSDL_SysWMEvent
    diff --git a/Externals/SDL/docs/html/sdlfillrect.html b/Externals/SDL/docs/html/sdlfillrect.html new file mode 100644 index 0000000000..4ace062e2d --- /dev/null +++ b/Externals/SDL/docs/html/sdlfillrect.html @@ -0,0 +1,291 @@ +SDL_FillRect
    SDL Library Documentation
    PrevNext

    SDL_FillRect

    Name

    SDL_FillRect -- This function performs a fast fill of the given rectangle with some color

    Synopsis

    #include "SDL.h"

    int SDL_FillRect(SDL_Surface *dst, SDL_Rect *dstrect, Uint32 color);

    Description

    This function performs a fast fill of the given rectangle with +color. If dstrect +is NULL, the whole surface will be filled with +color.

    The color should be a pixel of the format used by the surface, and +can be generated by the +SDL_MapRGB or SDL_MapRGBA +functions. If the color value contains an alpha value then the +destination is simply "filled" with that alpha information, no blending +takes place.

    If there is a clip rectangle set on the destination (set via +SDL_SetClipRect) then this +function will clip based on the intersection of the clip rectangle and +the dstrect rectangle and the dstrect rectangle +will be modified to represent the area actually filled.

    Return Value

    This function returns 0 on success, or +-1 on error.


    PrevHomeNext
    SDL_BlitSurfaceUpSDL_DisplayFormat
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlflip.html b/Externals/SDL/docs/html/sdlflip.html new file mode 100644 index 0000000000..b480f99aa8 --- /dev/null +++ b/Externals/SDL/docs/html/sdlflip.html @@ -0,0 +1,259 @@ +SDL_Flip
    SDL Library Documentation
    PrevNext

    SDL_Flip

    Name

    SDL_Flip -- Swaps screen buffers

    Synopsis

    #include "SDL.h"

    int SDL_Flip(SDL_Surface *screen);

    Description

    On hardware that supports double-buffering, this function sets up a flip +and returns. The hardware will wait for vertical retrace, and then swap +video buffers before the next video surface blit or lock will return. +On hardware that doesn't support double-buffering, this is equivalent +to calling SDL_UpdateRect(screen, 0, 0, 0, 0)

    The SDL_DOUBLEBUF flag must have been passed to +SDL_SetVideoMode, + when +setting the video mode for this function to perform hardware flipping.

    Return Value

    This function returns 0 if successful, or +-1 if there was an error.


    PrevHomeNext
    SDL_UpdateRectsUpSDL_SetColors
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlfreecursor.html b/Externals/SDL/docs/html/sdlfreecursor.html new file mode 100644 index 0000000000..01a4f7c257 --- /dev/null +++ b/Externals/SDL/docs/html/sdlfreecursor.html @@ -0,0 +1,209 @@ +SDL_FreeCursor
    SDL Library Documentation
    PrevNext

    SDL_FreeCursor

    Name

    SDL_FreeCursor -- Frees a cursor created with SDL_CreateCursor.

    Synopsis

    #include "SDL.h"

    void SDL_FreeCursor(SDL_Cursor *cursor);

    Description

    Frees a SDL_Cursor that was created using +SDL_CreateCursor.


    PrevHomeNext
    SDL_CreateCursorUpSDL_SetCursor
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlfreesurface.html b/Externals/SDL/docs/html/sdlfreesurface.html new file mode 100644 index 0000000000..84b6048109 --- /dev/null +++ b/Externals/SDL/docs/html/sdlfreesurface.html @@ -0,0 +1,219 @@ +SDL_FreeSurface
    SDL Library Documentation
    PrevNext

    SDL_FreeSurface

    Name

    SDL_FreeSurface -- Frees (deletes) a SDL_Surface

    Synopsis

    #include "SDL.h"

    void SDL_FreeSurface(SDL_Surface *surface);

    Description

    Frees the resources used by a previously created SDL_Surface. If the surface was created using +SDL_CreateRGBSurfaceFrom then the pixel data is not freed.


    PrevHomeNext
    SDL_CreateRGBSurfaceFromUpSDL_LockSurface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlfreewav.html b/Externals/SDL/docs/html/sdlfreewav.html new file mode 100644 index 0000000000..24242c4b0f --- /dev/null +++ b/Externals/SDL/docs/html/sdlfreewav.html @@ -0,0 +1,222 @@ +SDL_FreeWAV
    SDL Library Documentation
    PrevNext

    SDL_FreeWAV

    Name

    SDL_FreeWAV -- Frees previously opened WAV data

    Synopsis

    #include "SDL.h"

    void SDL_FreeWAV(Uint8 *audio_buf);

    Description

    After a WAVE file has been opened with SDL_LoadWAV its data can eventually be freed with SDL_FreeWAV. audio_buf is a pointer to the buffer created by SDL_LoadWAV.

    See Also

    SDL_LoadWAV


    PrevHomeNext
    SDL_LoadWAVUpSDL_AudioCVT
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlfreeyuvoverlay.html b/Externals/SDL/docs/html/sdlfreeyuvoverlay.html new file mode 100644 index 0000000000..e82340d9e2 --- /dev/null +++ b/Externals/SDL/docs/html/sdlfreeyuvoverlay.html @@ -0,0 +1,233 @@ +SDL_FreeYUVOverlay
    SDL Library Documentation
    PrevNext

    SDL_FreeYUVOverlay

    Name

    SDL_FreeYUVOverlay -- Free a YUV video overlay

    Synopsis

    #include "SDL.h"

    void SDL_FreeYUVOverlay(SDL_Overlay *overlay);

    Description

    Frees and overlay created by SDL_CreateYUVOverlay.


    PrevHomeNext
    SDL_DisplayYUVOverlayUpSDL_GLattr
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetappstate.html b/Externals/SDL/docs/html/sdlgetappstate.html new file mode 100644 index 0000000000..d09e2e0f08 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetappstate.html @@ -0,0 +1,263 @@ +SDL_GetAppState
    SDL Library Documentation
    PrevNext

    SDL_GetAppState

    Name

    SDL_GetAppState -- Get the state of the application

    Synopsis

    #include "SDL.h"

    Uint8 SDL_GetAppState(void);

    Description

    This function returns the current state of the application. The value returned is a bitwise combination of:

    SDL_APPMOUSEFOCUSThe application has mouse focus.
    SDL_APPINPUTFOCUSThe application has keyboard focus
    SDL_APPACTIVEThe application is visible


    PrevHomeNext
    SDL_GetRelativeMouseStateUpSDL_JoystickEventState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetaudiostatus.html b/Externals/SDL/docs/html/sdlgetaudiostatus.html new file mode 100644 index 0000000000..3fc3a09119 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetaudiostatus.html @@ -0,0 +1,221 @@ +SDL_GetAudioStatus
    SDL Library Documentation
    PrevNext

    SDL_GetAudioStatus

    Name

    SDL_GetAudioStatus -- Get the current audio state

    Synopsis

    #include "SDL.h"

    SDL_audiostatusSDL_GetAudioStatus(void);

    Description

    typedef enum{
    +  SDL_AUDIO_STOPPED,
    +  SDL_AUDIO_PAUSED,
    +  SDL_AUDIO_PLAYING
    +} SDL_audiostatus;

    Returns either SDL_AUDIO_STOPPED, SDL_AUDIO_PAUSED or SDL_AUDIO_PLAYING depending on the current audio state.


    PrevHomeNext
    SDL_PauseAudioUpSDL_LoadWAV
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetcliprect.html b/Externals/SDL/docs/html/sdlgetcliprect.html new file mode 100644 index 0000000000..f00ac77f8f --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetcliprect.html @@ -0,0 +1,229 @@ +SDL_GetClipRect
    SDL Library Documentation
    PrevNext

    SDL_GetClipRect

    Name

    SDL_GetClipRect -- Gets the clipping rectangle for a surface.

    Synopsis

    #include "SDL.h"

    void SDL_GetClipRect(SDL_Surface *surface, SDL_Rect *rect);

    Description

    Gets the clipping rectangle for a surface. When this surface is the +destination of a blit, only the area within the clip rectangle is +drawn into.

    The rectangle pointed to by rect will be +filled with the clipping rectangle of the surface.


    PrevHomeNext
    SDL_SetClipRectUpSDL_ConvertSurface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetcursor.html b/Externals/SDL/docs/html/sdlgetcursor.html new file mode 100644 index 0000000000..72ecbc7c09 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetcursor.html @@ -0,0 +1,219 @@ +SDL_GetCursor
    SDL Library Documentation
    PrevNext

    SDL_GetCursor

    Name

    SDL_GetCursor -- Get the currently active mouse cursor.

    Synopsis

    #include "SDL.h"

    SDL_Cursor *SDL_GetCursor(void);

    Description

    Returns the currently active mouse cursor.


    PrevHomeNext
    SDL_SetCursorUpSDL_ShowCursor
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgeterror.html b/Externals/SDL/docs/html/sdlgeterror.html new file mode 100644 index 0000000000..cdf57924a9 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgeterror.html @@ -0,0 +1,205 @@ +SDL_GetError
    SDL Library Documentation
    PrevNext

    SDL_GetError

    Name

    SDL_GetError -- Get SDL error string

    Synopsis

    #include "SDL/SDL.h"

    char *SDL_GetError(void);

    Description

    SDL_GetError returns a NULL terminated string containing information about the last internal SDL error.

    Return Value

    SDL_GetError returns a string containing the last error.


    PrevHomeNext
    SDL_WasInitUpSDL_envvars
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgeteventfilter.html b/Externals/SDL/docs/html/sdlgeteventfilter.html new file mode 100644 index 0000000000..d254d34a52 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgeteventfilter.html @@ -0,0 +1,235 @@ +SDL_GetEventFilter
    SDL Library Documentation
    PrevNext

    SDL_GetEventFilter

    Name

    SDL_GetEventFilter -- Retrieves a pointer to he event filter

    Synopsis

    #include "SDL.h"

    SDL_EventFilter SDL_GetEventFilter(void);

    Description

    This function retrieces a pointer to the event filter that was previously set using SDL_SetEventFilter. An SDL_EventFilter function is defined as: +

    typedef int (*SDL_EventFilter)(const SDL_Event *event);

    Return Value

    Returns a pointer to the event filter or NULL if no filter has been set.


    PrevHomeNext
    SDL_SetEventFilterUpSDL_EventState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetgammaramp.html b/Externals/SDL/docs/html/sdlgetgammaramp.html new file mode 100644 index 0000000000..bfcc03c4d3 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetgammaramp.html @@ -0,0 +1,219 @@ +SDL_GetGammaRamp
    SDL Library Documentation
    PrevNext

    SDL_GetGammaRamp

    Name

    SDL_GetGammaRamp -- Gets the color gamma lookup tables for the display

    Synopsis

    #include "SDL.h"

    int SDL_GetGammaRamp(Uint16 *redtable, Uint16 *greentable, Uint16 *bluetable);

    Description

    Gets the gamma translation lookup tables currently used by the display. +Each table is an array of 256 Uint16 values.

    Not all display hardware is able to change gamma.

    Return Value

    Returns -1 on error.


    PrevHomeNext
    SDL_SetGammaUpSDL_SetGammaRamp
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetkeyname.html b/Externals/SDL/docs/html/sdlgetkeyname.html new file mode 100644 index 0000000000..6c51c9497a --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetkeyname.html @@ -0,0 +1,216 @@ +SDL_GetKeyName
    SDL Library Documentation
    PrevNext

    SDL_GetKeyName

    Name

    SDL_GetKeyName -- Get the name of an SDL virtual keysym

    Synopsis

    #include "SDL.h"

    char *SDL_GetKeyName(SDLKey key);

    Description

    Returns the SDL-defined name of the SDLKey key.

    See Also

    SDLKey


    PrevHomeNext
    SDL_SetModStateUpSDL_EnableUNICODE
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetkeystate.html b/Externals/SDL/docs/html/sdlgetkeystate.html new file mode 100644 index 0000000000..1c16f2e50c --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetkeystate.html @@ -0,0 +1,253 @@ +SDL_GetKeyState
    SDL Library Documentation
    PrevNext

    SDL_GetKeyState

    Name

    SDL_GetKeyState -- Get a snapshot of the current keyboard state

    Synopsis

    #include "SDL.h"

    Uint8 *SDL_GetKeyState(int *numkeys);

    Description

    Gets a snapshot of the current keyboard state. The current state is return as a pointer to an array, the size of this array is stored in numkeys. The array is indexed by the SDLK_* symbols. A value of 1 means the key is pressed and a value of 0 means its not. The pointer returned is a pointer to an internal SDL array and should not be freed by the caller.

    Note: Use SDL_PumpEvents to update the state array.

    Example

    Uint8 *keystate = SDL_GetKeyState(NULL);
    +if ( keystate[SDLK_RETURN] ) printf("Return Key Pressed.\n");


    PrevHomeNext
    SDL_EventStateUpSDL_GetModState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetmodstate.html b/Externals/SDL/docs/html/sdlgetmodstate.html new file mode 100644 index 0000000000..64d2f35621 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetmodstate.html @@ -0,0 +1,257 @@ +SDL_GetModState
    SDL Library Documentation
    PrevNext

    SDL_GetModState

    Name

    SDL_GetModState -- Get the state of modifier keys.

    Synopsis

    #include "SDL.h"

    SDLMod SDL_GetModState(void);

    Description

    Returns the current state of the modifier keys (CTRL, ALT, etc.).

    Return Value

    The return value can be an OR'd combination of the SDLMod enum.

    SDLMod

    typedef enum {
    +  KMOD_NONE  = 0x0000,
    +  KMOD_LSHIFT= 0x0001,
    +  KMOD_RSHIFT= 0x0002,
    +  KMOD_LCTRL = 0x0040,
    +  KMOD_RCTRL = 0x0080,
    +  KMOD_LALT  = 0x0100,
    +  KMOD_RALT  = 0x0200,
    +  KMOD_LMETA = 0x0400,
    +  KMOD_RMETA = 0x0800,
    +  KMOD_NUM   = 0x1000,
    +  KMOD_CAPS  = 0x2000,
    +  KMOD_MODE  = 0x4000,
    +} SDLMod;
    +SDL also defines the following symbols for convenience: +
    #define KMOD_CTRL (KMOD_LCTRL|KMOD_RCTRL)
    +#define KMOD_SHIFT  (KMOD_LSHIFT|KMOD_RSHIFT)
    +#define KMOD_ALT  (KMOD_LALT|KMOD_RALT)
    +#define KMOD_META (KMOD_LMETA|KMOD_RMETA)


    PrevHomeNext
    SDL_GetKeyStateUpSDL_SetModState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetmousestate.html b/Externals/SDL/docs/html/sdlgetmousestate.html new file mode 100644 index 0000000000..d96a55b8d1 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetmousestate.html @@ -0,0 +1,253 @@ +SDL_GetMouseState
    SDL Library Documentation
    PrevNext

    SDL_GetMouseState

    Name

    SDL_GetMouseState -- Retrieve the current state of the mouse

    Synopsis

    #include "SDL.h"

    Uint8 SDL_GetMouseState(int *x, int *y);

    Description

    The current button state is returned as a button bitmask, which can +be tested using the SDL_BUTTON(X) macros, and x and y are set to the +current mouse cursor position. You can pass NULL for either x or y.

    Example

    SDL_PumpEvents();
    +if(SDL_GetMouseState(NULL, NULL)&SDL_BUTTON(1))
    +  printf("Mouse Button 1(left) is pressed.\n");

    PrevHomeNext
    SDL_EnableKeyRepeatUpSDL_GetRelativeMouseState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetrelativemousestate.html b/Externals/SDL/docs/html/sdlgetrelativemousestate.html new file mode 100644 index 0000000000..52a51066b5 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetrelativemousestate.html @@ -0,0 +1,235 @@ +SDL_GetRelativeMouseState
    SDL Library Documentation
    PrevNext

    SDL_GetRelativeMouseState

    Name

    SDL_GetRelativeMouseState -- Retrieve the current state of the mouse

    Synopsis

    #include "SDL.h"

    Uint8 SDL_GetRelativeMouseState(int *x, int *y);

    Description

    The current button state is returned as a button bitmask, which can +be tested using the SDL_BUTTON(X) macros, and x and y are set to the change in the mouse position since the last call to SDL_GetRelativeMouseState or since event initialization. You can pass NULL for either x or y.


    PrevHomeNext
    SDL_GetMouseStateUpSDL_GetAppState
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetrgb.html b/Externals/SDL/docs/html/sdlgetrgb.html new file mode 100644 index 0000000000..47774dc2ed --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetrgb.html @@ -0,0 +1,231 @@ +SDL_GetRGB
    SDL Library Documentation
    PrevNext

    SDL_GetRGB

    Name

    SDL_GetRGB -- Get RGB values from a pixel in the specified pixel format.

    Synopsis

    #include "SDL.h"

    void SDL_GetRGB(Uint32 pixel, SDL_PixelFormat *fmt, Uint8 *r, Uint8 *g, Uint8 *b);

    Description

    Get RGB component values from a pixel stored in the specified pixel format.

    This function uses the entire 8-bit [0..255] range when converting color +components from pixel formats with less than 8-bits per RGB component +(e.g., a completely white pixel in 16-bit RGB565 format would return +[0xff, 0xff, 0xff] not [0xf8, 0xfc, 0xf8]).


    PrevHomeNext
    SDL_MapRGBAUpSDL_GetRGBA
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetrgba.html b/Externals/SDL/docs/html/sdlgetrgba.html new file mode 100644 index 0000000000..a9e1093ad5 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetrgba.html @@ -0,0 +1,222 @@ +SDL_GetRGBA
    SDL Library Documentation
    PrevNext

    SDL_GetRGBA

    Name

    SDL_GetRGBA -- Get RGBA values from a pixel in the specified pixel format.

    Synopsis

    #include "SDL.h"

    void SDL_GetRGBA(Uint32 pixel, SDL_PixelFormat *fmt, Uint8 *r, Uint8 *g, Uint8 *b, Uint8 *a);

    Description

    Get RGBA component values from a pixel stored in the specified pixel format.

    This function uses the entire 8-bit [0..255] range when converting color +components from pixel formats with less than 8-bits per RGB component +(e.g., a completely white pixel in 16-bit RGB565 format would return +[0xff, 0xff, 0xff] not [0xf8, 0xfc, 0xf8]).

    If the surface has no alpha component, the alpha will be returned as 0xff +(100% opaque).


    PrevHomeNext
    SDL_GetRGBUpSDL_CreateRGBSurface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetthreadid.html b/Externals/SDL/docs/html/sdlgetthreadid.html new file mode 100644 index 0000000000..4bc59cb69c --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetthreadid.html @@ -0,0 +1,209 @@ +SDL_GetThreadID
    SDL Library Documentation
    PrevNext

    SDL_GetThreadID

    Name

    SDL_GetThreadID -- Get the SDL thread ID of a SDL_Thread

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    Uint32 SDL_GetThreadID(SDL_Thread *thread);

    Description

    Returns the ID of a SDL_Thread created by SDL_CreateThread.


    PrevHomeNext
    SDL_ThreadIDUpSDL_WaitThread
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetticks.html b/Externals/SDL/docs/html/sdlgetticks.html new file mode 100644 index 0000000000..0911aae1a5 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetticks.html @@ -0,0 +1,206 @@ +SDL_GetTicks
    SDL Library Documentation
    PrevNext

    SDL_GetTicks

    Name

    SDL_GetTicks -- Get the number of milliseconds since the SDL library initialization.

    Synopsis

    #include "SDL.h"

    Uint32 SDL_GetTicks(void);

    Description

    Get the number of milliseconds since the SDL library initialization. +Note that this value wraps if the program runs for more than ~49 days.

    See Also

    SDL_Delay


    PrevHomeNext
    TimeUpSDL_Delay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetvideoinfo.html b/Externals/SDL/docs/html/sdlgetvideoinfo.html new file mode 100644 index 0000000000..25c4b458aa --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetvideoinfo.html @@ -0,0 +1,226 @@ +SDL_GetVideoInfo
    SDL Library Documentation
    PrevNext

    SDL_GetVideoInfo

    Name

    SDL_GetVideoInfo -- returns a pointer to information about the video hardware

    Synopsis

    #include "SDL.h"

    SDL_VideoInfo *SDL_GetVideoInfo(void);

    Description

    This function returns a read-only pointer to information about the video +hardware. If this is called before SDL_SetVideoMode, the +vfmt member of the returned structure will contain the +pixel format of the "best" video mode.


    PrevHomeNext
    SDL_GetVideoSurfaceUpSDL_VideoDriverName
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlgetvideosurface.html b/Externals/SDL/docs/html/sdlgetvideosurface.html new file mode 100644 index 0000000000..905b1f6ac4 --- /dev/null +++ b/Externals/SDL/docs/html/sdlgetvideosurface.html @@ -0,0 +1,208 @@ +SDL_GetVideoSurface
    SDL Library Documentation
    PrevNext

    SDL_GetVideoSurface

    Name

    SDL_GetVideoSurface -- returns a pointer to the current display surface

    Synopsis

    #include "SDL.h"

    SDL_Surface *SDL_GetVideoSurface(void);

    Description

    This function returns a pointer to the current display surface. +If SDL is doing format conversion on the display surface, this +function returns the publicly visible surface, not the real video +surface.

    See Also

    SDL_Surface


    PrevHomeNext
    VideoUpSDL_GetVideoInfo
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlglattr.html b/Externals/SDL/docs/html/sdlglattr.html new file mode 100644 index 0000000000..0ae01272a4 --- /dev/null +++ b/Externals/SDL/docs/html/sdlglattr.html @@ -0,0 +1,379 @@ +SDL_GLattr
    SDL Library Documentation
    PrevNext

    SDL_GLattr

    Name

    SDL_GLattr -- SDL GL Attributes

    Attributes

    SDL_GL_RED_SIZESize of the framebuffer red component, in bits
    SDL_GL_GREEN_SIZESize of the framebuffer green component, in bits
    SDL_GL_BLUE_SIZESize of the framebuffer blue component, in bits
    SDL_GL_ALPHA_SIZESize of the framebuffer alpha component, in bits
    SDL_GL_DOUBLEBUFFER0 or 1, enable or disable double buffering
    SDL_GL_BUFFER_SIZESize of the framebuffer, in bits
    SDL_GL_DEPTH_SIZESize of the depth buffer, in bits
    SDL_GL_STENCIL_SIZESize of the stencil buffer, in bits
    SDL_GL_ACCUM_RED_SIZESize of the accumulation buffer red component, in bits
    SDL_GL_ACCUM_GREEN_SIZESize of the accumulation buffer green component, in bits
    SDL_GL_ACCUM_BLUE_SIZESize of the accumulation buffer blue component, in bits
    SDL_GL_ACCUM_ALPHA_SIZESize of the accumulation buffer alpha component, in bits

    Description

    While you can set most OpenGL attributes normally, the attributes list above must be known before SDL sets the video mode. These attributes a set and read with SDL_GL_SetAttribute and SDL_GL_GetAttribute.


    PrevHomeNext
    SDL_FreeYUVOverlayUpSDL_Rect
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlglgetattribute.html b/Externals/SDL/docs/html/sdlglgetattribute.html new file mode 100644 index 0000000000..26c8913bd2 --- /dev/null +++ b/Externals/SDL/docs/html/sdlglgetattribute.html @@ -0,0 +1,247 @@ +SDL_GL_GetAttribute
    SDL Library Documentation
    PrevNext

    SDL_GL_GetAttribute

    Name

    SDL_GL_GetAttribute -- Get the value of a special SDL/OpenGL attribute

    Synopsis

    #include "SDL.h"

    int SDL_GL_GetAttribute(SDLGLattr attr, int *value);

    Description

    Places the value of the SDL/OpenGL attribute attr into value. This is useful after a call to SDL_SetVideoMode to check whether your attributes have been set as you expected.

    Return Value

    Returns 0 on success, or -1 on an error.


    PrevHomeNext
    SDL_GL_GetProcAddressUpSDL_GL_SetAttribute
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlglgetprocaddress.html b/Externals/SDL/docs/html/sdlglgetprocaddress.html new file mode 100644 index 0000000000..a6cf6e4c11 --- /dev/null +++ b/Externals/SDL/docs/html/sdlglgetprocaddress.html @@ -0,0 +1,262 @@ +SDL_GL_GetProcAddress
    SDL Library Documentation
    PrevNext

    SDL_GL_GetProcAddress

    Name

    SDL_GL_GetProcAddress -- Get the address of a GL function

    Synopsis

    #include "SDL.h"

    void *SDL_GL_GetProcAddress(const char* proc);

    Description

    Returns the address of the GL function proc, or NULL if the function is not found. If the GL library is loaded at runtime, with SDL_GL_LoadLibrary, then all GL functions must be retrieved this way. Usually this is used to retrieve function pointers to OpenGL extensions.

    Example

    typedef void (*GL_ActiveTextureARB_Func)(unsigned int);
    +GL_ActiveTextureARB_Func glActiveTextureARB_ptr = 0;
    +int has_multitexture=1;
    +.
    +.
    +.
    +/* Get function pointer */
    +glActiveTextureARB_ptr=(GL_ActiveTextureARB_Func) SDL_GL_GetProcAddress("glActiveTextureARB");
    +
    +/* Check for a valid function ptr */
    +if(!glActiveTextureARB_ptr){
    +  fprintf(stderr, "Multitexture Extensions not present.\n");
    +  has_multitexture=0;
    +}
    +.
    +.
    +.
    +.
    +if(has_multitexture){
    +  glActiveTextureARB_ptr(GL_TEXTURE0_ARB);
    +  .
    +  .
    +}
    +else{
    +  .
    +  .
    +}

    PrevHomeNext
    SDL_GL_LoadLibraryUpSDL_GL_GetAttribute
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlglloadlibrary.html b/Externals/SDL/docs/html/sdlglloadlibrary.html new file mode 100644 index 0000000000..d3c4c6d79d --- /dev/null +++ b/Externals/SDL/docs/html/sdlglloadlibrary.html @@ -0,0 +1,231 @@ +SDL_GL_LoadLibrary
    SDL Library Documentation
    PrevNext

    SDL_GL_LoadLibrary

    Name

    SDL_GL_LoadLibrary -- Specify an OpenGL library

    Synopsis

    #include "SDL.h"

    int SDL_GL_LoadLibrary(const char *path);

    Description

    If you wish, you may load the OpenGL library at runtime, this must be done before SDL_SetVideoMode is called. The path of the GL library is passed to SDL_GL_LoadLibrary and it returns 0 on success, or -1 on an error. You must then use SDL_GL_GetProcAddress to retrieve function pointers to GL functions.


    PrevHomeNext
    SDL_ShowCursorUpSDL_GL_GetProcAddress
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlglsetattribute.html b/Externals/SDL/docs/html/sdlglsetattribute.html new file mode 100644 index 0000000000..ffb1204b0e --- /dev/null +++ b/Externals/SDL/docs/html/sdlglsetattribute.html @@ -0,0 +1,286 @@ +SDL_GL_SetAttribute
    SDL Library Documentation
    PrevNext

    SDL_GL_SetAttribute

    Name

    SDL_GL_SetAttribute -- Set a special SDL/OpenGL attribute

    Synopsis

    #include "SDL.h"

    int SDL_GL_SetAttribute(SDL_GLattr attr, int value);

    Description

    Sets the OpenGL attribute attr to value. The attributes you set don't take effect until after a call to SDL_SetVideoMode. You should use SDL_GL_GetAttribute to check the values after a SDL_SetVideoMode call.

    Return Value

    Returns 0 on success, or -1 on error.

    Example

    SDL_GL_SetAttribute( SDL_GL_RED_SIZE, 5 );
    +SDL_GL_SetAttribute( SDL_GL_GREEN_SIZE, 5 );
    +SDL_GL_SetAttribute( SDL_GL_BLUE_SIZE, 5 );
    +SDL_GL_SetAttribute( SDL_GL_DEPTH_SIZE, 16 );
    +SDL_GL_SetAttribute( SDL_GL_DOUBLEBUFFER, 1 );
    +if ( (screen=SDL_SetVideoMode( 640, 480, 16, SDL_OPENGL )) == NULL ) {
    +  fprintf(stderr, "Couldn't set GL mode: %s\n", SDL_GetError());
    +  SDL_Quit();
    +  return;
    +}

    Note: The SDL_DOUBLEBUF flag is not required to enable double buffering when setting an OpenGL video mode. Double buffering is enabled or disabled using the SDL_GL_DOUBLEBUFFER attribute.


    PrevHomeNext
    SDL_GL_GetAttributeUpSDL_GL_SwapBuffers
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlglswapbuffers.html b/Externals/SDL/docs/html/sdlglswapbuffers.html new file mode 100644 index 0000000000..fa383414d4 --- /dev/null +++ b/Externals/SDL/docs/html/sdlglswapbuffers.html @@ -0,0 +1,212 @@ +SDL_GL_SwapBuffers
    SDL Library Documentation
    PrevNext

    SDL_GL_SwapBuffers

    Name

    SDL_GL_SwapBuffers -- Swap OpenGL framebuffers/Update Display

    Synopsis

    #include "SDL.h"

    void SDL_GL_SwapBuffers(void );

    Description

    Swap the OpenGL buffers, if double-buffering is supported.


    PrevHomeNext
    SDL_GL_SetAttributeUpSDL_CreateYUVOverlay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlinit.html b/Externals/SDL/docs/html/sdlinit.html new file mode 100644 index 0000000000..11f27b81d1 --- /dev/null +++ b/Externals/SDL/docs/html/sdlinit.html @@ -0,0 +1,368 @@ +SDL_Init
    SDL Library Documentation
    PrevNext

    SDL_Init

    Name

    SDL_Init -- Initializes SDL

    Synopsis

    #include "SDL.h"

    int SDL_Init(Uint32 flags);

    Description

    Initializes SDL. This should be called before all other SDL functions. The flags parameter specifies what part(s) of SDL to initialize.

    SDL_INIT_TIMERInitializes the timer subsystem.
    SDL_INIT_AUDIOInitializes the audio subsystem.
    SDL_INIT_VIDEOInitializes the video subsystem.
    SDL_INIT_CDROMInitializes the cdrom subsystem.
    SDL_INIT_JOYSTICKInitializes the joystick subsystem.
    SDL_INIT_EVERYTHINGInitialize all of the above.
    SDL_INIT_NOPARACHUTEPrevents SDL from catching fatal signals.
    SDL_INIT_EVENTTHREAD 

    Return Value

    Returns -1 on an error or 0 on success.


    PrevHomeNext
    GeneralUpSDL_InitSubSystem
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlinitsubsystem.html b/Externals/SDL/docs/html/sdlinitsubsystem.html new file mode 100644 index 0000000000..917fd1068e --- /dev/null +++ b/Externals/SDL/docs/html/sdlinitsubsystem.html @@ -0,0 +1,283 @@ +SDL_InitSubSystem
    SDL Library Documentation
    PrevNext

    SDL_InitSubSystem

    Name

    SDL_InitSubSystem -- Initialize subsystems

    Synopsis

    #include "SDL.h"

    int SDL_InitSubSystem(Uint32 flags);

    Description

    After SDL has been initialized with SDL_Init you may initialize uninitialized subsystems with SDL_InitSubSystem. The flags parameter is the same as that used in SDL_Init.

    Examples

    /* Seperating Joystick and Video initialization. */
    +SDL_Init(SDL_INIT_VIDEO);
    +.
    +.
    +SDL_SetVideoMode(640, 480, 16, SDL_DOUBLEBUF|SDL_FULLSCREEN);
    +.
    +/* Do Some Video stuff */
    +.
    +.
    +/* Initialize the joystick subsystem */
    +SDL_InitSubSystem(SDL_INIT_JOYSTICK);
    +
    +/* Do some stuff with video and joystick */
    +.
    +.
    +.
    +/* Shut them both down */
    +SDL_Quit();

    Return Value

    Returns -1 on an error or 0 on success.


    PrevHomeNext
    SDL_InitUpSDL_QuitSubSystem
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoyaxisevent.html b/Externals/SDL/docs/html/sdljoyaxisevent.html new file mode 100644 index 0000000000..9f0166959f --- /dev/null +++ b/Externals/SDL/docs/html/sdljoyaxisevent.html @@ -0,0 +1,330 @@ +SDL_JoyAxisEvent
    SDL Library Documentation
    PrevNext

    SDL_JoyAxisEvent

    Name

    SDL_JoyAxisEvent -- Joystick axis motion event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 which;
    +  Uint8 axis;
    +  Sint16 value;
    +} SDL_JoyAxisEvent;

    Structure Data

    typeSDL_JOYAXISMOTION
    whichJoystick device index
    axisJoystick axis index
    valueAxis value (range: -32768 to 32767)

    Description

    SDL_JoyAxisEvent is a member of the SDL_Event union and is used when an event of type SDL_JOYAXISMOTION is reported.

    A SDL_JOYAXISMOTION event occurs when ever a user moves an axis on the joystick. The field which is the index of the joystick that reported the event and axis is the index of the axis (for a more detailed explaination see the Joystick section). value is the current position of the axis.


    PrevHomeNext
    SDL_MouseButtonEventUpSDL_JoyButtonEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoyballevent.html b/Externals/SDL/docs/html/sdljoyballevent.html new file mode 100644 index 0000000000..4ab96fe0e8 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoyballevent.html @@ -0,0 +1,340 @@ +SDL_JoyBallEvent
    SDL Library Documentation
    PrevNext

    SDL_JoyBallEvent

    Name

    SDL_JoyBallEvent -- Joystick trackball motion event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 which;
    +  Uint8 ball;
    +  Sint16 xrel, yrel;
    +} SDL_JoyBallEvent;

    Structure Data

    typeSDL_JOYBALLMOTION
    whichJoystick device index
    ballJoystick trackball index
    xrel, yrelThe relative motion in the X/Y direction

    Description

    SDL_JoyBallEvent is a member of the SDL_Event union and is used when an event of type SDL_JOYBALLMOTION is reported.

    A SDL_JOYBALLMOTION event occurs when a user moves a trackball on the joystick. The field which is the index of the joystick that reported the event and ball is the index of the trackball (for a more detailed explaination see the Joystick section). Trackballs only return relative motion, this is the change in position on the ball since it was last polled (last cycle of the event loop) and it is stored in xrel and yrel.


    PrevHomeNext
    SDL_JoyHatEventUpSDL_ResizeEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoybuttonevent.html b/Externals/SDL/docs/html/sdljoybuttonevent.html new file mode 100644 index 0000000000..d1d9c1ef63 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoybuttonevent.html @@ -0,0 +1,351 @@ +SDL_JoyButtonEvent
    SDL Library Documentation
    PrevNext

    SDL_JoyButtonEvent

    Name

    SDL_JoyButtonEvent -- Joystick button event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 which;
    +  Uint8 button;
    +  Uint8 state;
    +} SDL_JoyButtonEvent;

    Structure Data

    typeSDL_JOYBUTTONDOWN or SDL_JOYBUTTONUP
    whichJoystick device index
    buttonJoystick button index
    stateSDL_PRESSED or SDL_RELEASED

    Description

    SDL_JoyButtonEvent is a member of the SDL_Event union and is used when an event of type SDL_JOYBUTTONDOWN or SDL_JOYBUTTONUP is reported.

    A SDL_JOYBUTTONDOWN or SDL_JOYBUTTONUP event occurs when ever a user presses or releases a button on a joystick. The field which is the index of the joystick that reported the event and button is the index of the button (for a more detailed explaination see the Joystick section). state is the current state or the button which is either SDL_PRESSED or SDL_RELEASED.


    PrevHomeNext
    SDL_JoyAxisEventUpSDL_JoyHatEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoyhatevent.html b/Externals/SDL/docs/html/sdljoyhatevent.html new file mode 100644 index 0000000000..5e115be231 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoyhatevent.html @@ -0,0 +1,413 @@ +SDL_JoyHatEvent
    SDL Library Documentation
    PrevNext

    SDL_JoyHatEvent

    Name

    SDL_JoyHatEvent -- Joystick hat position change event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 which;
    +  Uint8 hat;
    +  Uint8 value;
    +} SDL_JoyHatEvent;

    Structure Data

    typeSDL_JOY
    whichJoystick device index
    hatJoystick hat index
    valueHat position

    Description

    SDL_JoyHatEvent is a member of the SDL_Event union and is used when an event of type SDL_JOYHATMOTION is reported.

    A SDL_JOYHATMOTION event occurs when ever a user moves a hat on the joystick. The field which is the index of the joystick that reported the event and hat is the index of the hat (for a more detailed exlaination see the Joystick section). value is the current position of the hat. It is a logically OR'd combination of the following values (whose meanings should be pretty obvious:) :

    SDL_HAT_CENTERED
    SDL_HAT_UP
    SDL_HAT_RIGHT
    SDL_HAT_DOWN
    SDL_HAT_LEFT

    The following defines are also provided:

    SDL_HAT_RIGHTUP
    SDL_HAT_RIGHTDOWN
    SDL_HAT_LEFTUP
    SDL_HAT_LEFTDOWN


    PrevHomeNext
    SDL_JoyButtonEventUpSDL_JoyBallEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickclose.html b/Externals/SDL/docs/html/sdljoystickclose.html new file mode 100644 index 0000000000..efb44e0fe6 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickclose.html @@ -0,0 +1,223 @@ +SDL_JoystickClose
    SDL Library Documentation
    PrevNext

    SDL_JoystickClose

    Name

    SDL_JoystickClose -- Closes a previously opened joystick

    Synopsis

    #include "SDL.h"

    void SDL_JoystickClose(SDL_Joystick *joystick);

    Description

    Close a joystick that was previously opened with SDL_JoystickOpen.


    PrevHomeNext
    SDL_JoystickGetBallUpAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickeventstate.html b/Externals/SDL/docs/html/sdljoystickeventstate.html new file mode 100644 index 0000000000..11b148a126 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickeventstate.html @@ -0,0 +1,290 @@ +SDL_JoystickEventState
    SDL Library Documentation
    PrevNext

    SDL_JoystickEventState

    Name

    SDL_JoystickEventState -- Enable/disable joystick event polling

    Synopsis

    #include "SDL.h"

    int SDL_JoystickEventState(int state);

    Description

    This function is used to enable or disable joystick event processing. With joystick event processing disabled you will have to update joystick states with SDL_JoystickUpdate and read the joystick information manually. state is either SDL_QUERY, SDL_ENABLE or SDL_IGNORE.

    Note: Joystick event handling is prefered

    Return Value

    If state is SDL_QUERY then the current state is returned, otherwise the new processing state is returned.


    PrevHomeNext
    SDL_GetAppStateUpJoystick
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickgetaxis.html b/Externals/SDL/docs/html/sdljoystickgetaxis.html new file mode 100644 index 0000000000..40a17b4cc2 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickgetaxis.html @@ -0,0 +1,271 @@ +SDL_JoystickGetAxis
    SDL Library Documentation
    PrevNext

    SDL_JoystickGetAxis

    Name

    SDL_JoystickGetAxis -- Get the current state of an axis

    Synopsis

    #include "SDL.h"

    Sint16 SDL_JoystickGetAxis(SDL_Joystick *joystick, int axis);

    Description

    SDL_JoystickGetAxis returns the current state of the given axis on the given joystick.

    On most modern joysticks the X axis is usually represented by axis 0 and the Y axis by axis 1. The value returned by SDL_JoystickGetAxis is a signed integer (-32768 to 32768) representing the current position of the axis, it maybe necessary to impose certain tolerances on these values to account for jitter. It is worth noting that some joysticks use axes 2 and 3 for extra buttons.

    Return Value

    Returns a 16-bit signed integer representing the current position of the axis.

    Examples

    Sint16 x_move, y_move;
    +SDL_Joystick *joy1;
    +.
    +.
    +x_move=SDL_JoystickGetAxis(joy1, 0);
    +y_move=SDL_JoystickGetAxis(joy1, 1);


    PrevHomeNext
    SDL_JoystickUpdateUpSDL_JoystickGetHat
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickgetball.html b/Externals/SDL/docs/html/sdljoystickgetball.html new file mode 100644 index 0000000000..0da252ab1a --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickgetball.html @@ -0,0 +1,262 @@ +SDL_JoystickGetBall
    SDL Library Documentation
    PrevNext

    SDL_JoystickGetBall

    Name

    SDL_JoystickGetBall -- Get relative trackball motion

    Synopsis

    #include "SDL.h"

    int SDL_JoystickGetBall(SDL_Joystick *joystick, int ball, int *dx, int *dy);

    Description

    Get the ball axis change.

    Trackballs can only return relative motion since the last call to SDL_JoystickGetBall, these motion deltas a placed into dx and dy.

    Return Value

    Returns 0 on success or -1 on failure

    Examples

    int delta_x, delta_y;
    +SDL_Joystick *joy;
    +.
    +.
    +.
    +SDL_JoystickUpdate();
    +if(SDL_JoystickGetBall(joy, 0, &delta_x, &delta_y)==-1)
    +  printf("TrackBall Read Error!\n");
    +printf("Trackball Delta- X:%d, Y:%d\n", delta_x, delta_y);


    PrevHomeNext
    SDL_JoystickGetButtonUpSDL_JoystickClose
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickgetbutton.html b/Externals/SDL/docs/html/sdljoystickgetbutton.html new file mode 100644 index 0000000000..680e3569d0 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickgetbutton.html @@ -0,0 +1,231 @@ +SDL_JoystickGetButton
    SDL Library Documentation
    PrevNext

    SDL_JoystickGetButton

    Name

    SDL_JoystickGetButton -- Get the current state of a given button on a given joystick

    Synopsis

    #include "SDL.h"

    Uint8 SDL_JoystickGetButton(SDL_Joystick *joystick, int button);

    Description

    SDL_JoystickGetButton returns the current state of the given button on the given joystick.

    Return Value

    1 if the button is pressed. Otherwise, 0.


    PrevHomeNext
    SDL_JoystickGetHatUpSDL_JoystickGetBall
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickgethat.html b/Externals/SDL/docs/html/sdljoystickgethat.html new file mode 100644 index 0000000000..c638abb7c2 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickgethat.html @@ -0,0 +1,297 @@ +SDL_JoystickGetHat
    SDL Library Documentation
    PrevNext

    SDL_JoystickGetHat

    Name

    SDL_JoystickGetHat -- Get the current state of a joystick hat

    Synopsis

    #include "SDL.h"

    Uint8 SDL_JoystickGetHat(SDL_Joystick *joystick, int hat);

    Description

    SDL_JoystickGetHat returns the current state of the given hat on the given joystick.

    Return Value

    The current state is returned as a Uint8 which is defined as an OR'd combination of one or more of the following

    SDL_HAT_CENTERED
    SDL_HAT_UP
    SDL_HAT_RIGHT
    SDL_HAT_DOWN
    SDL_HAT_LEFT
    SDL_HAT_RIGHTUP
    SDL_HAT_RIGHTDOWN
    SDL_HAT_LEFTUP
    SDL_HAT_LEFTDOWN


    PrevHomeNext
    SDL_JoystickGetAxisUpSDL_JoystickGetButton
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickindex.html b/Externals/SDL/docs/html/sdljoystickindex.html new file mode 100644 index 0000000000..868a75addb --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickindex.html @@ -0,0 +1,218 @@ +SDL_JoystickIndex
    SDL Library Documentation
    PrevNext

    SDL_JoystickIndex

    Name

    SDL_JoystickIndex -- Get the index of an SDL_Joystick.

    Synopsis

    #include "SDL.h"

    int SDL_JoystickIndex(SDL_Joystick *joystick);

    Description

    Returns the index of a given SDL_Joystick structure.

    Return Value

    Index number of the joystick.


    PrevHomeNext
    SDL_JoystickOpenedUpSDL_JoystickNumAxes
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickname.html b/Externals/SDL/docs/html/sdljoystickname.html new file mode 100644 index 0000000000..0add817dc5 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickname.html @@ -0,0 +1,238 @@ +SDL_JoystickName
    SDL Library Documentation
    PrevNext

    SDL_JoystickName

    Name

    SDL_JoystickName -- Get joystick name.

    Synopsis

    #include "SDL.h"

    const char *SDL_JoystickName(int index);

    Description

    Get the implementation dependent name of joystick. The index parameter refers to the N'th joystick on the system.

    Return Value

    Returns a char pointer to the joystick name.

    Examples

    /* Print the names of all attached joysticks */
    +int num_joy, i;
    +num_joy=SDL_NumJoysticks();
    +printf("%d joysticks found\n", num_joy);
    +for(i=0;i<num_joy;i++)
    +  printf("%s\n", SDL_JoystickName(i));


    PrevHomeNext
    SDL_NumJoysticksUpSDL_JoystickOpen
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoysticknumaxes.html b/Externals/SDL/docs/html/sdljoysticknumaxes.html new file mode 100644 index 0000000000..53b67f5239 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoysticknumaxes.html @@ -0,0 +1,225 @@ +SDL_JoystickNumAxes
    SDL Library Documentation
    PrevNext

    SDL_JoystickNumAxes

    Name

    SDL_JoystickNumAxes -- Get the number of joystick axes

    Synopsis

    #include "SDL.h"

    int SDL_JoystickNumAxes(SDL_Joystick *joystick);

    Description

    Return the number of axes available from a previously opened SDL_Joystick.

    Return Value

    Number of axes.


    PrevHomeNext
    SDL_JoystickIndexUpSDL_JoystickNumBalls
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoysticknumballs.html b/Externals/SDL/docs/html/sdljoysticknumballs.html new file mode 100644 index 0000000000..0a8405dc93 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoysticknumballs.html @@ -0,0 +1,225 @@ +SDL_JoystickNumBalls
    SDL Library Documentation
    PrevNext

    SDL_JoystickNumBalls

    Name

    SDL_JoystickNumBalls -- Get the number of joystick trackballs

    Synopsis

    #include "SDL.h"

    int SDL_JoystickNumBalls(SDL_Joystick *joystick);

    Description

    Return the number of trackballs available from a previously opened SDL_Joystick.

    Return Value

    Number of trackballs.


    PrevHomeNext
    SDL_JoystickNumAxesUpSDL_JoystickNumHats
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoysticknumbuttons.html b/Externals/SDL/docs/html/sdljoysticknumbuttons.html new file mode 100644 index 0000000000..625b893a6a --- /dev/null +++ b/Externals/SDL/docs/html/sdljoysticknumbuttons.html @@ -0,0 +1,225 @@ +SDL_JoystickNumButtons
    SDL Library Documentation
    PrevNext

    SDL_JoystickNumButtons

    Name

    SDL_JoystickNumButtons -- Get the number of joysitck buttons

    Synopsis

    #include "SDL.h"

    int SDL_JoystickNumButtons(SDL_Joystick *joystick);

    Description

    Return the number of buttons available from a previously opened SDL_Joystick.

    Return Value

    Number of buttons.


    PrevHomeNext
    SDL_JoystickNumHatsUpSDL_JoystickUpdate
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoysticknumhats.html b/Externals/SDL/docs/html/sdljoysticknumhats.html new file mode 100644 index 0000000000..ed53235854 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoysticknumhats.html @@ -0,0 +1,225 @@ +SDL_JoystickNumHats
    SDL Library Documentation
    PrevNext

    SDL_JoystickNumHats

    Name

    SDL_JoystickNumHats -- Get the number of joystick hats

    Synopsis

    #include "SDL.h"

    int SDL_JoystickNumHats(SDL_Joystick *joystick);

    Description

    Return the number of hats available from a previously opened SDL_Joystick.

    Return Value

    Number of hats.


    PrevHomeNext
    SDL_JoystickNumBallsUpSDL_JoystickNumButtons
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickopen.html b/Externals/SDL/docs/html/sdljoystickopen.html new file mode 100644 index 0000000000..e608c4370f --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickopen.html @@ -0,0 +1,259 @@ +SDL_JoystickOpen
    SDL Library Documentation
    PrevNext

    SDL_JoystickOpen

    Name

    SDL_JoystickOpen -- Opens a joystick for use.

    Synopsis

    #include "SDL.h"

    SDL_Joystick *SDL_JoystickOpen(int index);

    Description

    Opens a joystick for use within SDL. The index refers to the N'th joystick in the system. A joystick must be opened before it game be used.

    Return Value

    Returns a SDL_Joystick structure on success. NULL on failure.

    Examples

    SDL_Joystick *joy;
    +// Check for joystick
    +if(SDL_NumJoysticks()>0){
    +  // Open joystick
    +  joy=SDL_JoystickOpen(0);
    +  
    +  if(joy)
    +  {
    +    printf("Opened Joystick 0\n");
    +    printf("Name: %s\n", SDL_JoystickName(0));
    +    printf("Number of Axes: %d\n", SDL_JoystickNumAxes(joy));
    +    printf("Number of Buttons: %d\n", SDL_JoystickNumButtons(joy));
    +    printf("Number of Balls: %d\n", SDL_JoystickNumBalls(joy));
    +  }
    +  else
    +    printf("Couldn't open Joystick 0\n");
    +  
    +  // Close if opened
    +  if(SDL_JoystickOpened(0))
    +    SDL_JoystickClose(joy);
    +}


    PrevHomeNext
    SDL_JoystickNameUpSDL_JoystickOpened
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickopened.html b/Externals/SDL/docs/html/sdljoystickopened.html new file mode 100644 index 0000000000..5275a099de --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickopened.html @@ -0,0 +1,233 @@ +SDL_JoystickOpened
    SDL Library Documentation
    PrevNext

    SDL_JoystickOpened

    Name

    SDL_JoystickOpened -- Determine if a joystick has been opened

    Synopsis

    #include "SDL.h"

    int SDL_JoystickOpened(int index);

    Description

    Determines whether a joystick has already been opened within the application. index refers to the N'th joystick on the system.

    Return Value

    Returns 1 if the joystick has been opened, or 0 if it has not.


    PrevHomeNext
    SDL_JoystickOpenUpSDL_JoystickIndex
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdljoystickupdate.html b/Externals/SDL/docs/html/sdljoystickupdate.html new file mode 100644 index 0000000000..0cb37dc226 --- /dev/null +++ b/Externals/SDL/docs/html/sdljoystickupdate.html @@ -0,0 +1,211 @@ +SDL_JoystickUpdate
    SDL Library Documentation
    PrevNext

    SDL_JoystickUpdate

    Name

    SDL_JoystickUpdate -- Updates the state of all joysticks

    Synopsis

    #include "SDL.h"

    void SDL_JoystickUpdate(void);

    Description

    Updates the state(position, buttons, etc.) of all open joysticks. If joystick events have been enabled with SDL_JoystickEventState then this is called automatically in the event loop.


    PrevHomeNext
    SDL_JoystickNumButtonsUpSDL_JoystickGetAxis
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlkey.html b/Externals/SDL/docs/html/sdlkey.html new file mode 100644 index 0000000000..6591884d1e --- /dev/null +++ b/Externals/SDL/docs/html/sdlkey.html @@ -0,0 +1,2630 @@ +SDLKey
    SDL Library Documentation
    PrevNext

    SDLKey

    Name

    SDLKey -- Keysym definitions.

    Description

    Table 8-1. SDL Keysym definitions

    SDLKeyASCII valueCommon name
    SDLK_BACKSPACE'\b'backspace
    SDLK_TAB'\t'tab
    SDLK_CLEAR clear
    SDLK_RETURN'\r'return
    SDLK_PAUSE pause
    SDLK_ESCAPE'^['escape
    SDLK_SPACE' 'space
    SDLK_EXCLAIM'!'exclaim
    SDLK_QUOTEDBL'"'quotedbl
    SDLK_HASH'#'hash
    SDLK_DOLLAR'$'dollar
    SDLK_AMPERSAND'&'ampersand
    SDLK_QUOTE'''quote
    SDLK_LEFTPAREN'('left parenthesis
    SDLK_RIGHTPAREN')'right parenthesis
    SDLK_ASTERISK'*'asterisk
    SDLK_PLUS'+'plus sign
    SDLK_COMMA','comma
    SDLK_MINUS'-'minus sign
    SDLK_PERIOD'.'period
    SDLK_SLASH'/'forward slash
    SDLK_0'0'0
    SDLK_1'1'1
    SDLK_2'2'2
    SDLK_3'3'3
    SDLK_4'4'4
    SDLK_5'5'5
    SDLK_6'6'6
    SDLK_7'7'7
    SDLK_8'8'8
    SDLK_9'9'9
    SDLK_COLON':'colon
    SDLK_SEMICOLON';'semicolon
    SDLK_LESS'<'less-than sign
    SDLK_EQUALS'='equals sign
    SDLK_GREATER'>'greater-than sign
    SDLK_QUESTION'?'question mark
    SDLK_AT'@'at
    SDLK_LEFTBRACKET'['left bracket
    SDLK_BACKSLASH'\'backslash
    SDLK_RIGHTBRACKET']'right bracket
    SDLK_CARET'^'caret
    SDLK_UNDERSCORE'_'underscore
    SDLK_BACKQUOTE'`'grave
    SDLK_a'a'a
    SDLK_b'b'b
    SDLK_c'c'c
    SDLK_d'd'd
    SDLK_e'e'e
    SDLK_f'f'f
    SDLK_g'g'g
    SDLK_h'h'h
    SDLK_i'i'i
    SDLK_j'j'j
    SDLK_k'k'k
    SDLK_l'l'l
    SDLK_m'm'm
    SDLK_n'n'n
    SDLK_o'o'o
    SDLK_p'p'p
    SDLK_q'q'q
    SDLK_r'r'r
    SDLK_s's's
    SDLK_t't't
    SDLK_u'u'u
    SDLK_v'v'v
    SDLK_w'w'w
    SDLK_x'x'x
    SDLK_y'y'y
    SDLK_z'z'z
    SDLK_DELETE'^?'delete
    SDLK_KP0 keypad 0
    SDLK_KP1 keypad 1
    SDLK_KP2 keypad 2
    SDLK_KP3 keypad 3
    SDLK_KP4 keypad 4
    SDLK_KP5 keypad 5
    SDLK_KP6 keypad 6
    SDLK_KP7 keypad 7
    SDLK_KP8 keypad 8
    SDLK_KP9 keypad 9
    SDLK_KP_PERIOD'.'keypad period
    SDLK_KP_DIVIDE'/'keypad divide
    SDLK_KP_MULTIPLY'*'keypad multiply
    SDLK_KP_MINUS'-'keypad minus
    SDLK_KP_PLUS'+'keypad plus
    SDLK_KP_ENTER'\r'keypad enter
    SDLK_KP_EQUALS'='keypad equals
    SDLK_UP up arrow
    SDLK_DOWN down arrow
    SDLK_RIGHT right arrow
    SDLK_LEFT left arrow
    SDLK_INSERT insert
    SDLK_HOME home
    SDLK_END end
    SDLK_PAGEUP page up
    SDLK_PAGEDOWN page down
    SDLK_F1 F1
    SDLK_F2 F2
    SDLK_F3 F3
    SDLK_F4 F4
    SDLK_F5 F5
    SDLK_F6 F6
    SDLK_F7 F7
    SDLK_F8 F8
    SDLK_F9 F9
    SDLK_F10 F10
    SDLK_F11 F11
    SDLK_F12 F12
    SDLK_F13 F13
    SDLK_F14 F14
    SDLK_F15 F15
    SDLK_NUMLOCK numlock
    SDLK_CAPSLOCK capslock
    SDLK_SCROLLOCK scrollock
    SDLK_RSHIFT right shift
    SDLK_LSHIFT left shift
    SDLK_RCTRL right ctrl
    SDLK_LCTRL left ctrl
    SDLK_RALT right alt
    SDLK_LALT left alt
    SDLK_RMETA right meta
    SDLK_LMETA left meta
    SDLK_LSUPER left windows key
    SDLK_RSUPER right windows key
    SDLK_MODE mode shift
    SDLK_HELP help
    SDLK_PRINT print-screen
    SDLK_SYSREQ SysRq
    SDLK_BREAK break
    SDLK_MENU menu
    SDLK_POWER power
    SDLK_EURO euro
    + +

    Table 8-2. SDL modifier definitions

    SDL ModifierMeaning
    KMOD_NONENo modifiers applicable
    KMOD_NUMNumlock is down
    KMOD_CAPSCapslock is down
    KMOD_LCTRLLeft Control is down
    KMOD_RCTRLRight Control is down
    KMOD_RSHIFTRight Shift is down
    KMOD_LSHIFTLeft Shift is down
    KMOD_RALTRight Alt is down
    KMOD_LALTLeft Alt is down
    KMOD_CTRLA Control key is down
    KMOD_SHIFTA Shift key is down
    KMOD_ALTAn Alt key is down


    PrevHomeNext
    SDL_keysymUpEvent Functions.
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlkeyboardevent.html b/Externals/SDL/docs/html/sdlkeyboardevent.html new file mode 100644 index 0000000000..1a6962c74a --- /dev/null +++ b/Externals/SDL/docs/html/sdlkeyboardevent.html @@ -0,0 +1,375 @@ +SDL_KeyboardEvent
    SDL Library Documentation
    PrevNext

    SDL_KeyboardEvent

    Name

    SDL_KeyboardEvent -- Keyboard event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 state;
    +  SDL_keysym keysym;
    +} SDL_KeyboardEvent;

    Structure Data

    typeSDL_KEYDOWN or SDL_KEYUP
    stateSDL_PRESSED or SDL_RELEASED
    keysymContains key press information

    Description

    SDL_KeyboardEvent is a member of the SDL_Event union and is used when an event of type SDL_KEYDOWN or SDL_KEYUP is reported.

    The type and state actually report the same information, they just use different values to do it! A keyboard event occurs when a key is released (type=SDK_KEYUP or state=SDL_RELEASED) and when a key is pressed (type=SDL_KEYDOWN or state=SDL_PRESSED). The information on what key was pressed or released is in the keysym structure.

    Note: Repeating SDL_KEYDOWN events will occur if key repeat is enabled (see SDL_EnableKeyRepeat).


    PrevHomeNext
    SDL_ActiveEventUpSDL_MouseMotionEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlkeysym.html b/Externals/SDL/docs/html/sdlkeysym.html new file mode 100644 index 0000000000..7a22f79513 --- /dev/null +++ b/Externals/SDL/docs/html/sdlkeysym.html @@ -0,0 +1,355 @@ +SDL_keysym
    SDL Library Documentation
    PrevNext

    SDL_keysym

    Name

    SDL_keysym -- Keysym structure

    Structure Definition

    typedef struct{
    +  Uint8 scancode;
    +  SDLKey sym;
    +  SDLMod mod;
    +  Uint16 unicode;
    +} SDL_keysym;

    Structure Data

    scancodeHardware specific scancode
    symSDL virtual keysym
    modCurrent key modifiers
    unicodeTranslated character

    Description

    The SDL_keysym structure is used by reporting key presses and releases since it is a part of the SDL_KeyboardEvent.

    The scancode field should generally be left alone, it is the hardware dependent scancode returned by the keyboard. The sym field is extremely useful. It is the SDL-defined value of the key (see SDL Key Syms. This field is very useful when you are checking for certain key presses, like so: +

    .
    +.
    +while(SDL_PollEvent(&event)){
    +  switch(event.type){
    +    case SDL_KEYDOWN:
    +      if(event.key.keysym.sym==SDLK_LEFT)
    +        move_left();
    +      break;
    +    .
    +    .
    +    .
    +  }
    +}
    +.
    +.
    +mod stores the current state of the keyboard modifiers as explained in SDL_GetModState. The unicode is only used when UNICODE translation is enabled with SDL_EnableUNICODE. If unicode is non-zero then this a the UNICODE character corresponding to the keypress. If the high 9 bits of the character are 0, then this maps to the equivalent ASCII character: +
    char ch;
    +if ( (keysym.unicode & 0xFF80) == 0 ) {
    +  ch = keysym.unicode & 0x7F;
    +}
    +else {
    +  printf("An International Character.\n");
    +}
    +UNICODE translation does have a slight overhead so don't enable it unless its needed.

    See Also

    SDLKey


    PrevHomeNext
    SDL_QuitEventUpSDLKey
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlkillthread.html b/Externals/SDL/docs/html/sdlkillthread.html new file mode 100644 index 0000000000..2ce7b9b58f --- /dev/null +++ b/Externals/SDL/docs/html/sdlkillthread.html @@ -0,0 +1,223 @@ +SDL_KillThread
    SDL Library Documentation
    PrevNext

    SDL_KillThread

    Name

    SDL_KillThread -- Gracelessly terminates the thread.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    void SDL_KillThread(SDL_Thread *thread);

    Description

    SDL_KillThread gracelessly terminates the thread +associated with thread. If possible, you should +use some other form of IPC to signal the thread to quit.


    PrevHomeNext
    SDL_WaitThreadUpSDL_CreateMutex
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdllistmodes.html b/Externals/SDL/docs/html/sdllistmodes.html new file mode 100644 index 0000000000..ee7bc0eeec --- /dev/null +++ b/Externals/SDL/docs/html/sdllistmodes.html @@ -0,0 +1,310 @@ +SDL_ListModes
    SDL Library Documentation
    PrevNext

    SDL_ListModes

    Name

    SDL_ListModes -- Returns a pointer to an array of available screen dimensions for +the given format and video flags

    Synopsis

    #include "SDL.h"

    SDL_Rect **SDL_ListModes(SDL_PixelFormat *format, Uint32 flags);

    Description

    Return a pointer to an array of available screen dimensions for the given +format and video flags, sorted largest to smallest. Returns +NULL if there are no dimensions available for a particular +format, or -1 if any dimension is okay for +the given format.

    If format is NULL, the mode list +will be for the format returned by SDL_GetVideoInfo()->vfmt. The flag parameter is an OR'd combination of surface flags. The flags are the same as those used SDL_SetVideoMode and they play a strong role in deciding what modes are valid. For instance, if you pass SDL_HWSURFACE as a flag only modes that support hardware video surfaces will be returned.

    Example

    SDL_Rect **modes;
    +int i;
    +.
    +.
    +.
    +
    +/* Get available fullscreen/hardware modes */
    +modes=SDL_ListModes(NULL, SDL_FULLSCREEN|SDL_HWSURFACE);
    +
    +/* Check is there are any modes available */
    +if(modes == (SDL_Rect **)0){
    +  printf("No modes available!\n");
    +  exit(-1);
    +}
    +
    +/* Check if our resolution is restricted */
    +if(modes == (SDL_Rect **)-1){
    +  printf("All resolutions available.\n");
    +}
    +else{
    +  /* Print valid modes */
    +  printf("Available Modes\n");
    +  for(i=0;modes[i];++i)
    +    printf("  %d x %d\n", modes[i]->w, modes[i]->h);
    +}
    +.
    +.

    PrevHomeNext
    SDL_VideoDriverNameUpSDL_VideoModeOK
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlloadbmp.html b/Externals/SDL/docs/html/sdlloadbmp.html new file mode 100644 index 0000000000..41556e34ae --- /dev/null +++ b/Externals/SDL/docs/html/sdlloadbmp.html @@ -0,0 +1,219 @@ +SDL_LoadBMP
    SDL Library Documentation
    PrevNext

    SDL_LoadBMP

    Name

    SDL_LoadBMP -- Load a Windows BMP file into an SDL_Surface.

    Synopsis

    #include "SDL.h"

    SDL_Surface *SDL_LoadBMP(const char *file);

    Description

    Loads a surface from a named Windows BMP file.

    Return Value

    Returns the new surface, or NULL +if there was an error.

    See Also

    SDL_SaveBMP


    PrevHomeNext
    SDL_UnlockSurfaceUpSDL_SaveBMP
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlloadwav.html b/Externals/SDL/docs/html/sdlloadwav.html new file mode 100644 index 0000000000..8abb73ec36 --- /dev/null +++ b/Externals/SDL/docs/html/sdlloadwav.html @@ -0,0 +1,296 @@ +SDL_LoadWAV
    SDL Library Documentation
    PrevNext

    SDL_LoadWAV

    Name

    SDL_LoadWAV -- Load a WAVE file

    Synopsis

    #include "SDL.h"

    SDL_AudioSpec *SDL_LoadWAV(const char *file, SDL_AudioSpec *spec, Uint8 **audio_buf, Uint32 *audio_len);

    Description

    SDL_LoadWAV +This function loads a WAVE file into memory.

    If this function succeeds, it returns the given +SDL_AudioSpec, +filled with the audio data format of the wave data, and sets +audio_buf to a malloc'd +buffer containing the audio data, and sets audio_len +to the length of that audio buffer, in bytes. You need to free the audio +buffer with SDL_FreeWAV when you are +done with it.

    This function returns NULL and sets the SDL +error message if the wave file cannot be opened, uses an unknown data format, +or is corrupt. Currently raw, MS-ADPCM and IMA-ADPCM WAVE files are supported.

    Example

    SDL_AudioSpec wav_spec;
    +Uint32 wav_length;
    +Uint8 *wav_buffer;
    +
    +/* Load the WAV */
    +if( SDL_LoadWAV("test.wav", &wav_spec, &wav_buffer, &wav_length) == NULL ){
    +  fprintf(stderr, "Could not open test.wav: %s\n", SDL_GetError());
    +  exit(-1);
    +}
    +.
    +.
    +.
    +/* Do stuff with the WAV */
    +.
    +.
    +/* Free It */
    +SDL_FreeWAV(wav_buffer);

    PrevHomeNext
    SDL_GetAudioStatusUpSDL_FreeWAV
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdllockaudio.html b/Externals/SDL/docs/html/sdllockaudio.html new file mode 100644 index 0000000000..0e6fc292b4 --- /dev/null +++ b/Externals/SDL/docs/html/sdllockaudio.html @@ -0,0 +1,208 @@ +SDL_LockAudio
    SDL Library Documentation
    PrevNext

    SDL_LockAudio

    Name

    SDL_LockAudio -- Lock out the callback function

    Synopsis

    #include "SDL.h"

    void SDL_LockAudio(void);

    Description

    The lock manipulated by these functions protects the callback function. +During a LockAudio period, you can be guaranteed that the +callback function is not running. Do not call these from the callback +function or you will cause deadlock.


    PrevHomeNext
    SDL_MixAudioUpSDL_UnlockAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdllocksurface.html b/Externals/SDL/docs/html/sdllocksurface.html new file mode 100644 index 0000000000..40c8959ea0 --- /dev/null +++ b/Externals/SDL/docs/html/sdllocksurface.html @@ -0,0 +1,306 @@ +SDL_LockSurface
    SDL Library Documentation
    PrevNext

    SDL_LockSurface

    Name

    SDL_LockSurface -- Lock a surface for directly access.

    Synopsis

    #include "SDL.h"

    int SDL_LockSurface(SDL_Surface *surface);

    Description

    SDL_LockSurface sets up a surface for directly +accessing the pixels. Between calls to SDL_LockSurface +and SDL_UnlockSurface, you can write to and read from +surface->pixels, using the pixel format stored in +surface->format. Once you are done accessing the +surface, you should use SDL_UnlockSurface to release it.

    Not all surfaces require locking. +If SDL_MUSTLOCK(surface) +evaluates to 0, then you can read and write to the +surface at any time, and the pixel format of the surface will not change.

    No operating system or library calls should be made between lock/unlock +pairs, as critical system locks may be held during this time.

    It should be noted, that since SDL 1.1.8 surface locks are recursive. This means that you can lock a surface multiple times, but each lock must have a match unlock. +

        .
    +    .
    +    SDL_LockSurface( surface );
    +    .
    +    /* Surface is locked */
    +    /* Direct pixel access on surface here */
    +    .
    +    SDL_LockSurface( surface );
    +    .
    +    /* More direct pixel access on surface */
    +    .
    +    SDL_UnlockSurface( surface );
    +    /* Surface is still locked */
    +    /* Note: Is versions < 1.1.8, the surface would have been */
    +    /* no longer locked at this stage                         */
    +    .
    +    SDL_UnlockSurface( surface );
    +    /* Surface is now unlocked */
    +    .
    +    .

    Return Value

    SDL_LockSurface returns 0, +or -1 if the surface couldn't be locked.


    PrevHomeNext
    SDL_FreeSurfaceUpSDL_UnlockSurface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdllockyuvoverlay.html b/Externals/SDL/docs/html/sdllockyuvoverlay.html new file mode 100644 index 0000000000..74e6ce673d --- /dev/null +++ b/Externals/SDL/docs/html/sdllockyuvoverlay.html @@ -0,0 +1,252 @@ +SDL_LockYUVOverlay
    SDL Library Documentation
    PrevNext

    SDL_LockYUVOverlay

    Name

    SDL_LockYUVOverlay -- Lock an overlay

    Synopsis

    #include "SDL.h"

    int SDL_LockYUVOverlay(SDL_Overlay *overlay);

    Description

    Much the same as SDL_LockSurface, SDL_LockYUVOverlay locks the overlay for direct access to pixel data.

    Return Value

    Returns 0 on success, or -1 on an error.


    PrevHomeNext
    SDL_CreateYUVOverlayUpSDL_UnlockYUVOverlay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlmaprgb.html b/Externals/SDL/docs/html/sdlmaprgb.html new file mode 100644 index 0000000000..5086d0c7dc --- /dev/null +++ b/Externals/SDL/docs/html/sdlmaprgb.html @@ -0,0 +1,254 @@ +SDL_MapRGB
    SDL Library Documentation
    PrevNext

    SDL_MapRGB

    Name

    SDL_MapRGB -- Map a RGB color value to a pixel format.

    Synopsis

    #include "SDL.h"

    Uint32 SDL_MapRGB(SDL_PixelFormat *fmt, Uint8 r, Uint8 g, Uint8 b);

    Description

    Maps the RGB color value to the specified pixel format and returns the +pixel value as a 32-bit int.

    If the format has a palette (8-bit) the index of the closest matching +color in the palette will be returned.

    If the specified pixel format has an alpha component it will be returned +as all 1 bits (fully opaque).

    Return Value

    A pixel value best approximating the given RGB color value for a given +pixel format. If the pixel format bpp (color depth) is less than 32-bpp +then the unused upper bits of the return value can safely be ignored +(e.g., with a 16-bpp format the return value can be assigned to a +Uint16, and similarly a Uint8 for an 8-bpp +format).


    PrevHomeNext
    SDL_SetGammaRampUpSDL_MapRGBA
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlmaprgba.html b/Externals/SDL/docs/html/sdlmaprgba.html new file mode 100644 index 0000000000..e6bff276f7 --- /dev/null +++ b/Externals/SDL/docs/html/sdlmaprgba.html @@ -0,0 +1,242 @@ +SDL_MapRGBA
    SDL Library Documentation
    PrevNext

    SDL_MapRGBA

    Name

    SDL_MapRGBA -- Map a RGBA color value to a pixel format.

    Synopsis

    #include "SDL.h"

    Uint32 SDL_MapRGBA(SDL_PixelFormat *fmt, Uint8 r, Uint8 g, Uint8 b, Uint8 a);

    Description

    Maps the RGBA color value to the specified pixel format and returns the +pixel value as a 32-bit int.

    If the format has a palette (8-bit) the index of the closest matching +color in the palette will be returned.

    If the specified pixel format has no alpha component the alpha value +will be ignored (as it will be in formats with a palette).

    Return Value

    A pixel value best approximating the given RGBA color value for a given +pixel format. If the pixel format bpp (color depth) is less than 32-bpp +then the unused upper bits of the return value can safely be ignored +(e.g., with a 16-bpp format the return value can be assigned to a +Uint16, and similarly a Uint8 for an 8-bpp +format).


    PrevHomeNext
    SDL_MapRGBUpSDL_GetRGB
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlmixaudio.html b/Externals/SDL/docs/html/sdlmixaudio.html new file mode 100644 index 0000000000..6cbf0f0dbd --- /dev/null +++ b/Externals/SDL/docs/html/sdlmixaudio.html @@ -0,0 +1,237 @@ +SDL_MixAudio
    SDL Library Documentation
    PrevNext

    SDL_MixAudio

    Name

    SDL_MixAudio -- Mix audio data

    Synopsis

    #include "SDL.h"

    void SDL_MixAudio(Uint8 *dst, Uint8 *src, Uint32 len, int volume);

    Description

    This function takes two audio buffers of len bytes each +of the playing audio format and mixes them, performing addition, volume +adjustment, and overflow clipping. The volume ranges +from 0 to SDL_MIX_MAXVOLUME and should be set to the maximum +value for full audio volume. Note this does not change hardware volume. This is +provided for convenience -- you can mix your own audio data.

    Note: Do not use this function for mixing together more than two streams of sample +data. The output from repeated application of this function may be distorted +by clipping, because there is no accumulator with greater range than the +input (not to mention this being an inefficient way of doing it). +Use mixing functions from SDL_mixer, OpenAL, or write your own mixer instead.


    PrevHomeNext
    SDL_ConvertAudioUpSDL_LockAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlmousebuttonevent.html b/Externals/SDL/docs/html/sdlmousebuttonevent.html new file mode 100644 index 0000000000..b0b40df97a --- /dev/null +++ b/Externals/SDL/docs/html/sdlmousebuttonevent.html @@ -0,0 +1,346 @@ +SDL_MouseButtonEvent
    SDL Library Documentation
    PrevNext

    SDL_MouseButtonEvent

    Name

    SDL_MouseButtonEvent -- Mouse button event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 button;
    +  Uint8 state;
    +  Uint16 x, y;
    +} SDL_MouseButtonEvent;

    Structure Data

    typeSDL_MOUSEBUTTONDOWN or SDL_MOUSEBUTTONUP
    buttonThe mouse button index (SDL_BUTTON_LEFT, SDL_BUTTON_MIDDLE, SDL_BUTTON_RIGHT)
    stateSDL_PRESSED or SDL_RELEASED
    x, yThe X/Y coordinates of the mouse at press/release time

    Description

    SDL_MouseButtonEvent is a member of the SDL_Event union and is used when an event of type SDL_MOUSEBUTTONDOWN or SDL_MOUSEBUTTONUP is reported.

    When a mouse button press or release is detected then number of the button pressed (from 1 to 255, with 1 usually being the left button and 2 the right) is placed into button, the position of the mouse when this event occured is stored in the x and the y fields. Like SDL_KeyboardEvent, information on whether the event was a press or a release event is stored in both the type and state fields, but this should be obvious.


    PrevHomeNext
    SDL_MouseMotionEventUpSDL_JoyAxisEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlmousemotionevent.html b/Externals/SDL/docs/html/sdlmousemotionevent.html new file mode 100644 index 0000000000..3cc7cb5c6a --- /dev/null +++ b/Externals/SDL/docs/html/sdlmousemotionevent.html @@ -0,0 +1,365 @@ +SDL_MouseMotionEvent
    SDL Library Documentation
    PrevNext

    SDL_MouseMotionEvent

    Name

    SDL_MouseMotionEvent -- Mouse motion event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  Uint8 state;
    +  Uint16 x, y;
    +  Sint16 xrel, yrel;
    +} SDL_MouseMotionEvent;

    Structure Data

    typeSDL_MOUSEMOTION
    stateThe current button state
    x, yThe X/Y coordinates of the mouse
    xrel, yrelRelative motion in the X/Y direction

    Description

    SDL_MouseMotionEvent is a member of the SDL_Event union and is used when an event of type SDL_MOUSEMOTION is reported.

    Simply put, a SDL_MOUSEMOTION type event occurs when a user moves the mouse within the application window or when SDL_WarpMouse is called. Both the absolute (x and y) and relative (xrel and yrel) coordinates are reported along with the current button states (state). The button state can be interpreted using the SDL_BUTTON macro (see SDL_GetMouseState).

    If the cursor is hidden (SDL_ShowCursor(0)) and the input is grabbed (SDL_WM_GrabInput(SDL_GRAB_ON)), then the mouse will give relative motion events even when the cursor reaches the edge fo the screen. This is currently only implemented on Windows and Linux/Unix-a-likes.


    PrevHomeNext
    SDL_KeyboardEventUpSDL_MouseButtonEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlmutexp.html b/Externals/SDL/docs/html/sdlmutexp.html new file mode 100644 index 0000000000..fc32ca5996 --- /dev/null +++ b/Externals/SDL/docs/html/sdlmutexp.html @@ -0,0 +1,241 @@ +SDL_mutexP
    SDL Library Documentation
    PrevNext

    SDL_mutexP

    Name

    SDL_mutexP -- Lock a mutex

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_mutexP(SDL_mutex *mutex);

    Description

    Locks the mutex, which was previously created with SDL_CreateMutex. If the mutex is already locked then SDL_mutexP will not return until it is unlocked. Returns 0 on success, or -1 on an error.

    SDL also defines a macro #define SDL_LockMutex(m) SDL_mutexP(m).


    PrevHomeNext
    SDL_DestroyMutexUpSDL_mutexV
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlmutexv.html b/Externals/SDL/docs/html/sdlmutexv.html new file mode 100644 index 0000000000..06a68bdc5e --- /dev/null +++ b/Externals/SDL/docs/html/sdlmutexv.html @@ -0,0 +1,235 @@ +SDL_mutexV
    SDL Library Documentation
    PrevNext

    SDL_mutexV

    Name

    SDL_mutexV -- Unlock a mutex

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_mutexV(SDL_mutex *mutex);

    Description

    Unlocks the mutex, which was previously created with SDL_CreateMutex. Returns 0 on success, or -1 on an error.

    SDL also defines a macro #define SDL_UnlockMutex(m) SDL_mutexV(m).


    PrevHomeNext
    SDL_mutexPUpSDL_CreateSemaphore
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlnumjoysticks.html b/Externals/SDL/docs/html/sdlnumjoysticks.html new file mode 100644 index 0000000000..68e3e3a72e --- /dev/null +++ b/Externals/SDL/docs/html/sdlnumjoysticks.html @@ -0,0 +1,222 @@ +SDL_NumJoysticks
    SDL Library Documentation
    PrevNext

    SDL_NumJoysticks

    Name

    SDL_NumJoysticks -- Count available joysticks.

    Synopsis

    #include "SDL.h"

    int SDL_NumJoysticks(void);

    Description

    Counts the number of joysticks attached to the system.

    Return Value

    Returns the number of attached joysticks


    PrevHomeNext
    JoystickUpSDL_JoystickName
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlopenaudio.html b/Externals/SDL/docs/html/sdlopenaudio.html new file mode 100644 index 0000000000..bcfed54a7f --- /dev/null +++ b/Externals/SDL/docs/html/sdlopenaudio.html @@ -0,0 +1,578 @@ +SDL_OpenAudio
    SDL Library Documentation
    PrevNext

    SDL_OpenAudio

    Name

    SDL_OpenAudio -- Opens the audio device with the desired parameters.

    Synopsis

    #include "SDL.h"

    int SDL_OpenAudio(SDL_AudioSpec *desired, SDL_AudioSpec *obtained);

    Description

    This function opens the audio device with the desired parameters, and +returns 0 if successful, placing the actual hardware parameters in the +structure pointed to by obtained. If obtained is NULL, the audio +data passed to the callback function will be guaranteed to be in the +requested format, and will be automatically converted to the hardware +audio format if necessary. This function returns -1 if it failed +to open the audio device, or couldn't set up the audio thread.

    To open the audio device a desired SDL_AudioSpec must be created. +

    SDL_AudioSpec *desired;
    +.
    +.
    +desired = malloc(sizeof(SDL_AudioSpec));
    +You must then fill this structure with your desired audio specifications.

    desired->freq

    The desired audio frequency in samples-per-second.

    desired->format

    The desired audio format (see SDL_AudioSpec)

    desired->samples

    The desired size of the audio buffer in samples. This number should be a power of two, and may be adjusted by the audio driver to a value more suitable for the hardware. Good values seem to range between 512 and 8192 inclusive, depending on the application and CPU speed. Smaller values yield faster response time, but can lead to underflow if the application is doing heavy processing and cannot fill the audio buffer in time. A stereo sample consists of both right and left channels in LR ordering. Note that the number of samples is directly related to time by the following formula: ms = (samples*1000)/freq

    desired->callback

    This should be set to a function that will be called when the audio device is ready for more data. It is passed a pointer to the audio buffer, and the length in bytes of the audio buffer. This function usually runs in a separate thread, and so you should protect data structures that it accesses by calling SDL_LockAudio and SDL_UnlockAudio in your code. The callback prototype is: +

    void callback(void *userdata, Uint8 *stream, int len);
    +userdata is the pointer stored in userdata field of the SDL_AudioSpec. stream is a pointer to the audio buffer you want to fill with information and len is the length of the audio buffer in bytes.

    desired->userdata

    This pointer is passed as the first parameter to the callback function.

    SDL_OpenAudio reads these fields from the desired SDL_AudioSpec structure pass to the function and attempts to find an audio configuration matching your desired. As mentioned above, if the obtained parameter is NULL then SDL with convert from your desired audio settings to the hardware settings as it plays.

    If obtained is NULL then the desired SDL_AudioSpec is your working specification, otherwise the obtained SDL_AudioSpec becomes the working specification and the desirec specification can be deleted. The data in the working specification is used when building SDL_AudioCVT's for converting loaded data to the hardware format.

    SDL_OpenAudio calculates the size and silence fields for both the desired and obtained specifications. The size field stores the total size of the audio buffer in bytes, while the silence stores the value used to represent silence in the audio buffer

    The audio device starts out playing silence when it's opened, and should be enabled for playing by calling SDL_PauseAudio(0) when you are ready for your audio callback function to be called. Since the audio driver may modify the requested size of the audio buffer, you should allocate any local mixing buffers after you open the audio device.

    Examples

    /* Prototype of our callback function */
    +void my_audio_callback(void *userdata, Uint8 *stream, int len);
    +
    +/* Open the audio device */
    +SDL_AudioSpec *desired, *obtained;
    +SDL_AudioSpec *hardware_spec;
    +
    +/* Allocate a desired SDL_AudioSpec */
    +desired = malloc(sizeof(SDL_AudioSpec));
    +
    +/* Allocate space for the obtained SDL_AudioSpec */
    +obtained = malloc(sizeof(SDL_AudioSpec));
    +
    +/* 22050Hz - FM Radio quality */
    +desired->freq=22050;
    +
    +/* 16-bit signed audio */
    +desired->format=AUDIO_S16LSB;
    +
    +/* Mono */
    +desired->channels=0;
    +
    +/* Large audio buffer reduces risk of dropouts but increases response time */
    +desired->samples=8192;
    +
    +/* Our callback function */
    +desired->callback=my_audio_callback;
    +
    +desired->userdata=NULL;
    +
    +/* Open the audio device */
    +if ( SDL_OpenAudio(desired, obtained) < 0 ){
    +  fprintf(stderr, "Couldn't open audio: %s\n", SDL_GetError());
    +  exit(-1);
    +}
    +/* desired spec is no longer needed */
    +free(desired);
    +hardware_spec=obtained;
    +.
    +.
    +/* Prepare callback for playing */
    +.
    +.
    +.
    +/* Start playing */
    +SDL_PauseAudio(0);

    PrevHomeNext
    SDL_AudioSpecUpSDL_PauseAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdloverlay.html b/Externals/SDL/docs/html/sdloverlay.html new file mode 100644 index 0000000000..422919edc9 --- /dev/null +++ b/Externals/SDL/docs/html/sdloverlay.html @@ -0,0 +1,362 @@ +SDL_Overlay
    SDL Library Documentation
    PrevNext

    SDL_Overlay

    Name

    SDL_Overlay -- YUV video overlay

    Structure Definition

    typedef struct{
    +  Uint32 format;
    +  int w, h;
    +  int planes;
    +  Uint16 *pitches;
    +  Uint8 **pixels;
    +  Uint32 hw_overlay:1;
    +} SDL_Overlay;

    Structure Data

    formatOverlay format (see below)
    w, hWidth and height of overlay
    planesNumber of planes in the overlay. Usually either 1 or 3
    pitchesAn array of pitches, one for each plane. Pitch is the length of a row in bytes.
    pixelsAn array of pointers to teh data of each plane. The overlay should be locked before these pointers are used.
    hw_overlayThis will be set to 1 if the overlay is hardware accelerated.

    Description

    A SDL_Overlay is similar to a SDL_Surface except it stores a YUV overlay. All the fields are read only, except for pixels which should be locked before use. The format field stores the format of the overlay which is one of the following: +

    #define SDL_YV12_OVERLAY  0x32315659  /* Planar mode: Y + V + U */
    +#define SDL_IYUV_OVERLAY  0x56555949  /* Planar mode: Y + U + V */
    +#define SDL_YUY2_OVERLAY  0x32595559  /* Packed mode: Y0+U0+Y1+V0 */
    +#define SDL_UYVY_OVERLAY  0x59565955  /* Packed mode: U0+Y0+V0+Y1 */
    +#define SDL_YVYU_OVERLAY  0x55595659  /* Packed mode: Y0+V0+Y1+U0 */
    +More information on YUV formats can be found at http://www.webartz.com/fourcc/indexyuv.htm.


    PrevHomeNext
    SDL_VideoInfoUpWindow Management
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlpalette.html b/Externals/SDL/docs/html/sdlpalette.html new file mode 100644 index 0000000000..6498ac40ba --- /dev/null +++ b/Externals/SDL/docs/html/sdlpalette.html @@ -0,0 +1,301 @@ +SDL_Palette
    SDL Library Documentation
    PrevNext

    SDL_Palette

    Name

    SDL_Palette -- Color palette for 8-bit pixel formats

    Structure Definition

    typedef struct{
    +  int ncolors;
    +  SDL_Color *colors;
    +} SDL_Palette;

    Structure Data

    ncolorsNumber of colors used in this palette
    colorsPointer to SDL_Color structures that make up the palette.

    Description

    Each pixel in an 8-bit surface is an index into the colors field of the SDL_Palette structure store in SDL_PixelFormat. A SDL_Palette should never need to be created manually. It is automatically created when SDL allocates a SDL_PixelFormat for a surface. The colors values of a SDL_Surfaces palette can be set with the SDL_SetColors.


    PrevHomeNext
    SDL_ColorUpSDL_PixelFormat
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlpauseaudio.html b/Externals/SDL/docs/html/sdlpauseaudio.html new file mode 100644 index 0000000000..39d5a0f0f9 --- /dev/null +++ b/Externals/SDL/docs/html/sdlpauseaudio.html @@ -0,0 +1,221 @@ +SDL_PauseAudio
    SDL Library Documentation
    PrevNext

    SDL_PauseAudio

    Name

    SDL_PauseAudio -- Pauses and unpauses the audio callback processing

    Synopsis

    #include "SDL.h"

    void SDL_PauseAudio(int pause_on);

    Description

    This function pauses and unpauses the audio callback processing. +It should be called with pause_on=0 after opening the audio +device to start playing sound. This is so you can safely initialize +data for your callback function after opening the audio device. +Silence will be written to the audio device during the pause.


    PrevHomeNext
    SDL_OpenAudioUpSDL_GetAudioStatus
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlpeepevents.html b/Externals/SDL/docs/html/sdlpeepevents.html new file mode 100644 index 0000000000..d5a0ff6f9f --- /dev/null +++ b/Externals/SDL/docs/html/sdlpeepevents.html @@ -0,0 +1,321 @@ +SDL_PeepEvents
    SDL Library Documentation
    PrevNext

    SDL_PeepEvents

    Name

    SDL_PeepEvents -- Checks the event queue for messages and optionally returns them.

    Synopsis

    #include "SDL.h"

    int SDL_PeepEvents(SDL_Event *events, int numevents, SDL_eventaction action, Uint32 mask);

    Description

    Checks the event queue for messages and optionally returns them.

    If action is SDL_ADDEVENT, up to +numevents events will be added to the back of the event + queue.

    If action is SDL_PEEKEVENT, up to +numevents events at the front of the event queue, +matching mask, +will be returned and will not be removed from the queue.

    If action is SDL_GETEVENT, up to +numevents events at the front of the event queue, +matching mask, +will be returned and will be removed from the queue.

    The mask parameter is an bitwise OR of +SDL_EVENTMASK(event_type), for all +event types you are interested in.

    This function is thread-safe.

    Return Value

    This function returns the number of events actually stored, or +-1 if there was an error.


    PrevHomeNext
    SDL_PumpEventsUpSDL_PollEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlpixelformat.html b/Externals/SDL/docs/html/sdlpixelformat.html new file mode 100644 index 0000000000..000ddc08b1 --- /dev/null +++ b/Externals/SDL/docs/html/sdlpixelformat.html @@ -0,0 +1,528 @@ +SDL_PixelFormat
    SDL Library Documentation
    PrevNext

    SDL_PixelFormat

    Name

    SDL_PixelFormat -- Stores surface format information

    Structure Definition

    typedef struct SDL_PixelFormat {
    +  SDL_Palette *palette;
    +  Uint8  BitsPerPixel;
    +  Uint8  BytesPerPixel;
    +  Uint8  Rloss, Gloss, Bloss, Aloss;
    +  Uint8  Rshift, Gshift, Bshift, Ashift;
    +  Uint32 Rmask, Gmask, Bmask, Amask;
    +  Uint32 colorkey;
    +  Uint8  alpha;
    +} SDL_PixelFormat;

    Structure Data

    palettePointer to the palette, or NULL if the BitsPerPixel>8
    BitsPerPixelThe number of bits used to represent each pixel in a surface. Usually 8, 16, 24 or 32.
    BytesPerPixelThe number of bytes used to represent each pixel in a surface. Usually one to four.
    [RGBA]maskBinary mask used to retrieve individual color values
    [RGBA]lossPrecision loss of each color component (2[RGBA]loss)
    [RGBA]shiftBinary left shift of each color component in the pixel value
    colorkeyPixel value of transparent pixels
    alphaOverall surface alpha value

    Description

    A SDL_PixelFormat describes the format of the pixel data stored at the pixels field of a SDL_Surface. Every surface stores a SDL_PixelFormat in the format field.

    If you wish to do pixel level modifications on a surface, then understanding how SDL stores its color information is essential.

    8-bit pixel formats are the easiest to understand. Since its an 8-bit format, we have 8 BitsPerPixel and 1 BytesPerPixel. Since BytesPerPixel is 1, all pixels are represented by a Uint8 which contains an index into palette->colors. So, to determine the color of a pixel in a 8-bit surface: we read the color index from surface->pixels and we use that index to read the SDL_Color structure from surface->format->palette->colors. Like so: +

    SDL_Surface *surface;
    +SDL_PixelFormat *fmt;
    +SDL_Color *color;
    +Uint8 index;
    +
    +.
    +.
    +
    +/* Create surface */
    +.
    +.
    +fmt=surface->format;
    +
    +/* Check the bitdepth of the surface */
    +if(fmt->BitsPerPixel!=8){
    +  fprintf(stderr, "Not an 8-bit surface.\n");
    +  return(-1);
    +}
    +
    +/* Lock the surface */
    +SDL_LockSurface(surface);
    +
    +/* Get the topleft pixel */
    +index=*(Uint8 *)surface->pixels;
    +color=fmt->palette->colors[index];
    +
    +/* Unlock the surface */
    +SDL_UnlockSurface(surface);
    +printf("Pixel Color-> Red: %d, Green: %d, Blue: %d. Index: %d\n",
    +          color->r, color->g, color->b, index);
    +.
    +.

    Pixel formats above 8-bit are an entirely different experience. They are +considered to be "TrueColor" formats and the color information is stored in the +pixels themselves, not in a palette. The mask, shift and loss fields tell us +how the color information is encoded. The mask fields allow us to isolate each +color component, the shift fields tell us the number of bits to the right of +each component in the pixel value and the loss fields tell us the number of +bits lost from each component when packing 8-bit color component in a pixel. +

    /* Extracting color components from a 32-bit color value */
    +SDL_PixelFormat *fmt;
    +SDL_Surface *surface;
    +Uint32 temp, pixel;
    +Uint8 red, green, blue, alpha;
    +.
    +.
    +.
    +fmt=surface->format;
    +SDL_LockSurface(surface);
    +pixel=*((Uint32*)surface->pixels);
    +SDL_UnlockSurface(surface);
    +
    +/* Get Red component */
    +temp=pixel&fmt->Rmask; /* Isolate red component */
    +temp=temp>>fmt->Rshift;/* Shift it down to 8-bit */
    +temp=temp<<fmt->Rloss; /* Expand to a full 8-bit number */
    +red=(Uint8)temp;
    +
    +/* Get Green component */
    +temp=pixel&fmt->Gmask; /* Isolate green component */
    +temp=temp>>fmt->Gshift;/* Shift it down to 8-bit */
    +temp=temp<<fmt->Gloss; /* Expand to a full 8-bit number */
    +green=(Uint8)temp;
    +
    +/* Get Blue component */
    +temp=pixel&fmt->Bmask; /* Isolate blue component */
    +temp=temp>>fmt->Bshift;/* Shift it down to 8-bit */
    +temp=temp<<fmt->Bloss; /* Expand to a full 8-bit number */
    +blue=(Uint8)temp;
    +
    +/* Get Alpha component */
    +temp=pixel&fmt->Amask; /* Isolate alpha component */
    +temp=temp>>fmt->Ashift;/* Shift it down to 8-bit */
    +temp=temp<<fmt->Aloss; /* Expand to a full 8-bit number */
    +alpha=(Uint8)temp;
    +
    +printf("Pixel Color -> R: %d,  G: %d,  B: %d,  A: %d\n", red, green, blue, alpha);
    +.
    +.
    +.


    PrevHomeNext
    SDL_PaletteUpSDL_Surface
    diff --git a/Externals/SDL/docs/html/sdlpollevent.html b/Externals/SDL/docs/html/sdlpollevent.html new file mode 100644 index 0000000000..f97c22d963 --- /dev/null +++ b/Externals/SDL/docs/html/sdlpollevent.html @@ -0,0 +1,269 @@ +SDL_PollEvent
    SDL Library Documentation
    PrevNext

    SDL_PollEvent

    Name

    SDL_PollEvent -- Polls for currently pending events.

    Synopsis

    #include "SDL.h"

    int SDL_PollEvent(SDL_Event *event);

    Description

    Polls for currently pending events, and returns 1 +if there are any pending events, or 0 if there +are none available.

    If event is not NULL, the next +event is removed from the queue and stored in that area.

    Examples

    SDL_Event event; /* Event structure */
    +
    +.
    +.
    +.
    +/* Check for events */
    +while(SDL_PollEvent(&event)){  /* Loop until there are no events left on the queue */
    +  switch(event.type){  /* Process the appropiate event type */
    +    case SDL_KEYDOWN:  /* Handle a KEYDOWN event */         
    +      printf("Oh! Key press\n");
    +      break;
    +    case SDL_MOUSEMOTION:
    +      .
    +      .
    +      .
    +    default: /* Report an unhandled event */
    +      printf("I don't know what this event is!\n");
    +  }
    +}


    PrevHomeNext
    SDL_PeepEventsUpSDL_WaitEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlpumpevents.html b/Externals/SDL/docs/html/sdlpumpevents.html new file mode 100644 index 0000000000..a7e528f19a --- /dev/null +++ b/Externals/SDL/docs/html/sdlpumpevents.html @@ -0,0 +1,244 @@ +SDL_PumpEvents
    SDL Library Documentation
    PrevNext

    SDL_PumpEvents

    Name

    SDL_PumpEvents -- Pumps the event loop, gathering events from the input devices.

    Synopsis

    #include "SDL.h"

    void SDL_PumpEvents(void);

    Description

    Pumps the event loop, gathering events from the input devices.

    SDL_PumpEvents gathers all the pending input information from devices and places it on the event queue. Without calls to SDL_PumpEvents no events would ever be placed on the queue. Often calls the need for SDL_PumpEvents is hidden from the user since SDL_PollEvent and SDL_WaitEvent implicitly call SDL_PumpEvents. However, if you are not polling or waiting for events (e.g. you are filtering them), then you must call SDL_PumpEvents to force an event queue update.

    Note: You can only call this function in the thread that set the video mode.


    PrevHomeNext
    Event Functions.UpSDL_PeepEvents
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlpushevent.html b/Externals/SDL/docs/html/sdlpushevent.html new file mode 100644 index 0000000000..6905385c32 --- /dev/null +++ b/Externals/SDL/docs/html/sdlpushevent.html @@ -0,0 +1,266 @@ +SDL_PushEvent
    SDL Library Documentation
    PrevNext

    SDL_PushEvent

    Name

    SDL_PushEvent -- Pushes an event onto the event queue

    Synopsis

    #include "SDL.h"

    int SDL_PushEvent(SDL_Event *event);

    Description

    The event queue can actually be used as a two way communication channel. Not only can events be read from the queue, but the user can also push their own events onto it. event is a pointer to the event structure you wish to push onto the queue.

    Note: Pushing device input events onto the queue doesn't modify the state of the device within SDL.

    Return Value

    Returns 0 on success or -1 if the event couldn't be pushed.

    Examples

    See SDL_Event.


    PrevHomeNext
    SDL_WaitEventUpSDL_SetEventFilter
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlquit.html b/Externals/SDL/docs/html/sdlquit.html new file mode 100644 index 0000000000..1f31c82558 --- /dev/null +++ b/Externals/SDL/docs/html/sdlquit.html @@ -0,0 +1,244 @@ +SDL_Quit
    SDL Library Documentation
    PrevNext

    SDL_Quit

    Name

    SDL_Quit -- Shut down SDL

    Synopsis

    #include "SDL.h"

    void SDL_Quit(void);

    Description

    SDL_Quit shuts down all SDL subsystems and frees the resources allocated to them. This should always be called before you exit. For the sake of simplicity you can set SDL_Quit as your atexit call, like: +

    SDL_Init(SDL_INIT_VIDEO|SDL_INIT_AUDIO);
    +atexit(SDL_Quit);
    +.
    +.

    Note: While using atexit maybe be fine for small programs, more advanced users should shut down SDL in their own cleanup code. Plus, using atexit in a library is a sure way to crash dynamically loaded code


    PrevHomeNext
    SDL_QuitSubSystemUpSDL_WasInit
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlquitevent.html b/Externals/SDL/docs/html/sdlquitevent.html new file mode 100644 index 0000000000..d575f38b7b --- /dev/null +++ b/Externals/SDL/docs/html/sdlquitevent.html @@ -0,0 +1,263 @@ +SDL_QuitEvent
    SDL Library Documentation
    PrevNext

    SDL_QuitEvent

    Name

    SDL_QuitEvent -- Quit requested event

    Structure Definition

    typedef struct{
    +  Uint8 type
    +} SDL_QuitEvent;

    Structure Data

    typeSDL_QUIT

    Description

    SDL_QuitEvent is a member of the SDL_Event union and is used whan an event of type SDL_QUIT is reported.

    As can be seen, the SDL_QuitEvent structure serves no useful purpose. The event itself, on the other hand, is very important. If you filter out or ignore a quit event then it is impossible for the user to close the window. On the other hand, if you do accept a quit event then the application window will be closed, and screen updates will still report success event though the application will no longer be visible.

    Note: The macro SDL_QuitRequested will return non-zero if a quit event is pending


    PrevHomeNext
    SDL_UserEventUpSDL_keysym
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlquitsubsystem.html b/Externals/SDL/docs/html/sdlquitsubsystem.html new file mode 100644 index 0000000000..877e3ce118 --- /dev/null +++ b/Externals/SDL/docs/html/sdlquitsubsystem.html @@ -0,0 +1,248 @@ +SDL_QuitSubSystem
    SDL Library Documentation
    PrevNext

    SDL_QuitSubSystem

    Name

    SDL_QuitSubSystem -- Shut down a subsystem

    Synopsis

    #include "SDL.h"

    void SDL_QuitSubSystem(Uint32 flags);

    Description

    SDL_QuitSubSystem allows you to shut down a subsystem that has been previously initialized by SDL_Init or SDL_InitSubSystem. The flags tells SDL_QuitSubSystem which subsystems to shut down, it uses the same values that are passed to SDL_Init.


    PrevHomeNext
    SDL_InitSubSystemUpSDL_Quit
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlrect.html b/Externals/SDL/docs/html/sdlrect.html new file mode 100644 index 0000000000..ba4a80be69 --- /dev/null +++ b/Externals/SDL/docs/html/sdlrect.html @@ -0,0 +1,258 @@ +SDL_Rect
    SDL Library Documentation
    PrevNext

    SDL_Rect

    Name

    SDL_Rect -- Defines a rectangular area

    Structure Definition

    typedef struct{
    +  Sint16 x, y;
    +  Uint16 w, h;
    +} SDL_Rect;

    Structure Data

    x, yPosition of the upper-left corner of the rectangle
    w, hThe width and height of the rectangle

    Description

    A SDL_Rect defines a rectangular area of pixels. It is used by SDL_BlitSurface to define blitting regions and by several other video functions.


    PrevHomeNext
    SDL_GLattrUpSDL_Color
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlremovetimer.html b/Externals/SDL/docs/html/sdlremovetimer.html new file mode 100644 index 0000000000..26a3d11f7b --- /dev/null +++ b/Externals/SDL/docs/html/sdlremovetimer.html @@ -0,0 +1,236 @@ +SDL_RemoveTimer
    SDL Library Documentation
    PrevNext

    SDL_RemoveTimer

    Name

    SDL_RemoveTimer -- Remove a timer which was added with +SDL_AddTimer.

    Synopsis

    #include "SDL.h"

    SDL_bool SDL_RemoveTimer(SDL_TimerID id);

    Description

    Removes a timer callback previously added with +SDL_AddTimer.

    Return Value

    Returns a boolean value indicating success.

    Examples

    SDL_RemoveTimer(my_timer_id);

    See Also

    SDL_AddTimer


    PrevHomeNext
    SDL_AddTimerUpSDL_SetTimer
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlresizeevent.html b/Externals/SDL/docs/html/sdlresizeevent.html new file mode 100644 index 0000000000..1d446a54cd --- /dev/null +++ b/Externals/SDL/docs/html/sdlresizeevent.html @@ -0,0 +1,307 @@ +SDL_ResizeEvent
    SDL Library Documentation
    PrevNext

    SDL_ResizeEvent

    Name

    SDL_ResizeEvent -- Window resize event structure

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  int w, h;
    +} SDL_ResizeEvent;

    Structure Data

    typeSDL_VIDEORESIZE
    w, hNew width and height of the window

    Description

    SDL_ResizeEvent is a member of the SDL_Event union and is used when an event of type SDL_VIDEORESIZE is reported.

    When SDL_RESIZABLE is passed as a flag to SDL_SetVideoMode the user is allowed to resize the applications window. When the window is resized an SDL_VIDEORESIZE is report, with the new window width and height values stored in w and h, respectively. When an SDL_VIDEORESIZE is recieved the window should be resized to the new dimensions using SDL_SetVideoMode.


    PrevHomeNext
    SDL_JoyBallEventUpSDL_ExposeEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsavebmp.html b/Externals/SDL/docs/html/sdlsavebmp.html new file mode 100644 index 0000000000..4c318ed756 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsavebmp.html @@ -0,0 +1,236 @@ +SDL_SaveBMP
    SDL Library Documentation
    PrevNext

    SDL_SaveBMP

    Name

    SDL_SaveBMP -- Save an SDL_Surface as a Windows BMP file.

    Synopsis

    #include "SDL.h"

    int SDL_SaveBMP(SDL_Surface *surface, const char *file);

    Description

    Saves the SDL_Surface surface as a Windows BMP file named file.

    Return Value

    Returns 0 if successful or +-1 +if there was an error.

    See Also

    SDL_LoadBMP


    PrevHomeNext
    SDL_LoadBMPUpSDL_SetColorKey
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsempost.html b/Externals/SDL/docs/html/sdlsempost.html new file mode 100644 index 0000000000..18fb01ab2f --- /dev/null +++ b/Externals/SDL/docs/html/sdlsempost.html @@ -0,0 +1,299 @@ +SDL_SemPost
    SDL Library Documentation
    PrevNext

    SDL_SemPost

    Name

    SDL_SemPost -- Unlock a semaphore.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_SemPost(SDL_sem *sem);

    Description

    SDL_SemPost unlocks the semaphore pointed to by +sem and atomically increments the semaphores value. +Threads that were blocking on the semaphore may be scheduled after this call +succeeds.

    SDL_SemPost should be called after a semaphore is locked by a successful call to +SDL_SemWait, +SDL_SemTryWait or +SDL_SemWaitTimeout.

    Return Value

    Returns 0 if successful or +-1 if there was an error (leaving the semaphore unchanged).

    Examples

    SDL_SemPost(my_sem);


    PrevHomeNext
    SDL_SemWaitTimeoutUpSDL_SemValue
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsemtrywait.html b/Externals/SDL/docs/html/sdlsemtrywait.html new file mode 100644 index 0000000000..86f47a1c83 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsemtrywait.html @@ -0,0 +1,319 @@ +SDL_SemTryWait
    SDL Library Documentation
    PrevNext

    SDL_SemTryWait

    Name

    SDL_SemTryWait -- Attempt to lock a semaphore but don't suspend the thread.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_SemTryWait(SDL_sem *sem);

    Description

    SDL_SemTryWait is a non-blocking varient of +SDL_SemWait. If the value of the semaphore +pointed to by sem is positive it will atomically +decrement the semaphore value and return 0, otherwise it will return +SDL_MUTEX_TIMEDOUT instead of suspending the thread.

    After SDL_SemTryWait is successful, the semaphore +can be released and its count atomically incremented by a successful call to +SDL_SemPost.

    Return Value

    Returns 0 if the semaphore was successfully locked or +either SDL_MUTEX_TIMEDOUT or -1 +if the thread would have suspended or there was an error, respectivly.

    If the semaphore was not successfully locked, the semaphore will be unchanged.

    Examples

    res = SDL_SemTryWait(my_sem);
    +
    +if (res == SDL_MUTEX_TIMEDOUT) {
    +        return TRY_AGAIN;
    +}
    +if (res == -1) {
    +        return WAIT_ERROR;
    +}
    +
    +...
    +
    +SDL_SemPost(my_sem);


    PrevHomeNext
    SDL_SemWaitUpSDL_SemWaitTimeout
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsemvalue.html b/Externals/SDL/docs/html/sdlsemvalue.html new file mode 100644 index 0000000000..7867369b1b --- /dev/null +++ b/Externals/SDL/docs/html/sdlsemvalue.html @@ -0,0 +1,273 @@ +SDL_SemValue
    SDL Library Documentation
    PrevNext

    SDL_SemValue

    Name

    SDL_SemValue -- Return the current value of a semaphore.

    Synopsis

    #include "SDL.h"
    +#include "SDL/SDL_thread.h"

    Uint32 SDL_SemValue(SDL_sem *sem);

    Description

    SDL_SemValue() returns the current semaphore value from +the semaphore pointed to by sem.

    Return Value

    Returns current value of the semaphore.

    Examples

      sem_value = SDL_SemValue(my_sem);


    PrevHomeNext
    SDL_SemPostUpSDL_CreateCond
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsemwait.html b/Externals/SDL/docs/html/sdlsemwait.html new file mode 100644 index 0000000000..5e98d552ee --- /dev/null +++ b/Externals/SDL/docs/html/sdlsemwait.html @@ -0,0 +1,298 @@ +SDL_SemWait
    SDL Library Documentation
    PrevNext

    SDL_SemWait

    Name

    SDL_SemWait -- Lock a semaphore and suspend the thread if the semaphore value is zero.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_SemWait(SDL_sem *sem);

    Description

    SDL_SemWait() suspends the calling thread until either +the semaphore pointed to by sem has a positive value, +the call is interrupted by a signal or error. If the call is successful it +will atomically decrement the semaphore value.

    After SDL_SemWait() is successful, the semaphore +can be released and its count atomically incremented by a successful call to +SDL_SemPost.

    Return Value

    Returns 0 if successful or +-1 if there was an error (leaving the semaphore unchanged).

    Examples

    if (SDL_SemWait(my_sem) == -1) {
    +        return WAIT_FAILED;
    +}
    +
    +...
    +
    +SDL_SemPost(my_sem);


    PrevHomeNext
    SDL_DestroySemaphoreUpSDL_SemTryWait
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsemwaittimeout.html b/Externals/SDL/docs/html/sdlsemwaittimeout.html new file mode 100644 index 0000000000..788f5b7250 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsemwaittimeout.html @@ -0,0 +1,322 @@ +SDL_SemWaitTimeout
    SDL Library Documentation
    PrevNext

    SDL_SemWaitTimeout

    Name

    SDL_SemWaitTimeout -- Lock a semaphore, but only wait up to a specified maximum time.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    int SDL_SemWaitTimeout(SDL_sem *sem, Uint32 timeout);

    Description

    SDL_SemWaitTimeout() is a varient of +SDL_SemWait +with a maximum timeout value. +If the value of the semaphore pointed to by sem is +positive (greater than zero) it will atomically decrement the semaphore value +and return 0, otherwise it will wait up to timeout +milliseconds trying to lock the semaphore. This function is to be avoided if +possible since on some platforms it is implemented by polling the semaphore +every millisecond in a busy loop.

    After SDL_SemWaitTimeout() is successful, the semaphore +can be released and its count atomically incremented by a successful call to +SDL_SemPost.

    Return Value

    Returns 0 if the semaphore was successfully locked or +either SDL_MUTEX_TIMEDOUT or -1 +if the timeout period was exceeded or there was an error, respectivly.

    If the semaphore was not successfully locked, the semaphore will be unchanged.

    Examples

    res = SDL_SemWaitTimeout(my_sem, WAIT_TIMEOUT_MILLISEC);
    +
    +if (res == SDL_MUTEX_TIMEDOUT) {
    +        return TRY_AGAIN;
    +}
    +if (res == -1) {
    +        return WAIT_ERROR;
    +}
    +
    +...
    +
    +SDL_SemPost(my_sem);


    PrevHomeNext
    SDL_SemTryWaitUpSDL_SemPost
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetalpha.html b/Externals/SDL/docs/html/sdlsetalpha.html new file mode 100644 index 0000000000..fc844981f1 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetalpha.html @@ -0,0 +1,500 @@ +SDL_SetAlpha
    SDL Library Documentation
    PrevNext

    SDL_SetAlpha

    Name

    SDL_SetAlpha -- Adjust the alpha properties of a surface

    Synopsis

    #include "SDL.h"

    int SDL_SetAlpha(SDL_Surface *surface, Uint32 flag, Uint8 alpha);

    Description

    Note: This function and the semantics of SDL alpha blending have changed since version 1.1.4. Up until version 1.1.5, an alpha value of 0 was considered opaque and a value of 255 was considered transparent. This has now been inverted: 0 (SDL_ALPHA_TRANSPARENT) is now considered transparent and 255 (SDL_ALPHA_OPAQUE) is now considered opaque.

    SDL_SetAlpha is used for setting the per-surface alpha +value and/or enabling and disabling alpha blending.

    Thesurface parameter specifies which surface whose alpha +attributes you wish to adjust. flags is used to specify +whether alpha blending should be used (SDL_SRCALPHA) and +whether the surface should use RLE acceleration for blitting +(SDL_RLEACCEL). flags can be an OR'd +combination of these two options, one of these options or 0. If +SDL_SRCALPHA is not passed as a flag then all alpha +information is ignored when blitting the surface. The +alpha parameter is the per-surface alpha value; a +surface need not have an alpha channel to use per-surface alpha and blitting +can still be accelerated with SDL_RLEACCEL.

    Note: The per-surface alpha value of 128 is considered a special case and +is optimised, so it's much faster than other per-surface values.

    Alpha effects surface blitting in the following ways:

    RGBA->RGB with SDL_SRCALPHA

    The source is alpha-blended with the destination, using the alpha channel. SDL_SRCCOLORKEY and the per-surface alpha are ignored.

    RGBA->RGB without SDL_SRCALPHA

    The RGB data is copied from the source. The source alpha channel and the per-surface alpha value are ignored.

    RGB->RGBA with SDL_SRCALPHA

    The source is alpha-blended with the destination using the per-surface alpha +value. If SDL_SRCCOLORKEY is set, only the pixels not +matching the colorkey value are copied. The alpha channel of the copied pixels +is set to opaque.

    RGB->RGBA without SDL_SRCALPHA

    The RGB data is copied from the source and the alpha value of the copied pixels +is set to opaque. If SDL_SRCCOLORKEY is set, only the pixels +not matching the colorkey value are copied.

    RGBA->RGBA with SDL_SRCALPHA

    The source is alpha-blended with the destination using the source alpha +channel. The alpha channel in the destination surface is left untouched. +SDL_SRCCOLORKEY is ignored.

    RGBA->RGBA without SDL_SRCALPHA

    The RGBA data is copied to the destination surface. If SDL_SRCCOLORKEY is set, only the pixels not matching the colorkey value are copied.

    RGB->RGB with SDL_SRCALPHA

    The source is alpha-blended with the destination using the per-surface alpha value. If SDL_SRCCOLORKEY is set, only the pixels not matching the colorkey value are copied.

    RGB->RGB without SDL_SRCALPHA

    The RGB data is copied from the source. If SDL_SRCCOLORKEY is set, only the pixels not matching the colorkey value are copied.

    Note: Note that RGBA->RGBA blits (with SDL_SRCALPHA set) keep the alpha +of the destination surface. This means that you cannot compose two arbitrary +RGBA surfaces this way and get the result you would expect from "overlaying" +them; the destination alpha will work as a mask.

    Also note that per-pixel and per-surface alpha cannot be combined; +the per-pixel alpha is always used if available

    Return Value

    This function returns 0, or +-1 if there was an error.


    PrevHomeNext
    SDL_SetColorKeyUpSDL_SetClipRect
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetcliprect.html b/Externals/SDL/docs/html/sdlsetcliprect.html new file mode 100644 index 0000000000..03898d55ac --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetcliprect.html @@ -0,0 +1,241 @@ +SDL_SetClipRect
    SDL Library Documentation
    PrevNext

    SDL_SetClipRect

    Name

    SDL_SetClipRect -- Sets the clipping rectangle for a surface.

    Synopsis

    #include "SDL.h"

    void SDL_SetClipRect(SDL_Surface *surface, SDL_Rect *rect);

    Description

    Sets the clipping rectangle for a surface. When this surface is the +destination of a blit, only the area within the clip rectangle will be +drawn into.

    The rectangle pointed to by rect will be +clipped to the edges of the surface so that the clip rectangle for a +surface can never fall outside the edges of the surface.

    If rect is NULL the clipping +rectangle will be set to the full size of the surface.


    PrevHomeNext
    SDL_SetAlphaUpSDL_GetClipRect
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetcolorkey.html b/Externals/SDL/docs/html/sdlsetcolorkey.html new file mode 100644 index 0000000000..0cb6695791 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetcolorkey.html @@ -0,0 +1,321 @@ +SDL_SetColorKey
    SDL Library Documentation
    PrevNext

    SDL_SetColorKey

    Name

    SDL_SetColorKey -- Sets the color key (transparent pixel) in a blittable surface and +RLE acceleration.

    Synopsis

    #include "SDL.h"

    int SDL_SetColorKey(SDL_Surface *surface, Uint32 flag, Uint32 key);

    Description

    Sets the color key (transparent pixel) in a blittable surface and enables or + disables RLE blit acceleration.

    RLE acceleration can substantially speed up blitting of images with large +horizontal runs of transparent pixels (i.e., pixels that match the +key value). The key must be of the same pixel format as the surface, SDL_MapRGB is often useful for obtaining an acceptable value.

    If flag is SDL_SRCCOLORKEY then +key is the transparent pixel value in the source image of a +blit.

    If flag is OR'd with +SDL_RLEACCEL then the surface will be draw using RLE +acceleration when drawn with +SDL_BlitSurface. The surface will +actually be encoded for RLE acceleration the first time +SDL_BlitSurface or +SDL_DisplayFormat is called on the +surface.

    If flag is 0, this function clears +any current color key.

    Return Value

    This function returns 0, or +-1 if there was an error.


    PrevHomeNext
    SDL_SaveBMPUpSDL_SetAlpha
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetcolors.html b/Externals/SDL/docs/html/sdlsetcolors.html new file mode 100644 index 0000000000..569564598b --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetcolors.html @@ -0,0 +1,358 @@ +SDL_SetColors
    SDL Library Documentation
    PrevNext

    SDL_SetColors

    Name

    SDL_SetColors -- Sets a portion of the colormap for the given 8-bit surface.

    Synopsis

    #include "SDL.h"

    int SDL_SetColors(SDL_Surface *surface, SDL_Color *colors, int firstcolor, int ncolors);

    Description

    Sets a portion of the colormap for the given 8-bit surface.

    When surface is the surface associated with the current +display, the display colormap will be updated with the requested colors. If +SDL_HWPALETTE was set in SDL_SetVideoMode flags, +SDL_SetColors will always return 1, +and the palette is guaranteed to be set the way you desire, even if the window +colormap has to be warped or run under emulation.

    The color components of a +SDL_Color +structure are 8-bits in size, giving you a total of 2563 +=16777216 colors.

    Palettized (8-bit) screen surfaces with the SDL_HWPALETTE +flag have two palettes, a logical palette that is used for mapping blits +to/from the surface and a physical palette (that determines how the +hardware will map the colors to the display). SDL_SetColors +modifies both palettes (if present), and is equivalent to calling +SDL_SetPalette with the +flags set to +(SDL_LOGPAL | SDL_PHYSPAL).

    Return Value

    If surface is not a palettized surface, this function +does nothing, returning 0. If all of the colors were set +as passed to SDL_SetColors, it will return +1. If not all the color entries were set exactly as +given, it will return 0, and you should look at the +surface palette to determine the actual color palette.

    Example

    /* Create a display surface with a grayscale palette */
    +SDL_Surface *screen;
    +SDL_Color colors[256];
    +int i;
    +.
    +.
    +.
    +/* Fill colors with color information */
    +for(i=0;i<256;i++){
    +  colors[i].r=i;
    +  colors[i].g=i;
    +  colors[i].b=i;
    +}
    +
    +/* Create display */
    +screen=SDL_SetVideoMode(640, 480, 8, SDL_HWPALETTE);
    +if(!screen){
    +  printf("Couldn't set video mode: %s\n", SDL_GetError());
    +  exit(-1);
    +}
    +
    +/* Set palette */
    +SDL_SetColors(screen, colors, 0, 256);
    +.
    +.
    +.
    +.

    PrevHomeNext
    SDL_FlipUpSDL_SetPalette
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetcursor.html b/Externals/SDL/docs/html/sdlsetcursor.html new file mode 100644 index 0000000000..9c5443e53e --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetcursor.html @@ -0,0 +1,222 @@ +SDL_SetCursor
    SDL Library Documentation
    PrevNext

    SDL_SetCursor

    Name

    SDL_SetCursor -- Set the currently active mouse cursor.

    Synopsis

    #include "SDL.h"

    void SDL_SetCursor(SDL_Cursor *cursor);

    Description

    Sets the currently active cursor to +the specified one. +If the cursor is currently visible, the change will be immediately +represented on the display.


    PrevHomeNext
    SDL_FreeCursorUpSDL_GetCursor
    diff --git a/Externals/SDL/docs/html/sdlseteventfilter.html b/Externals/SDL/docs/html/sdlseteventfilter.html new file mode 100644 index 0000000000..0808bab3c6 --- /dev/null +++ b/Externals/SDL/docs/html/sdlseteventfilter.html @@ -0,0 +1,284 @@ +SDL_SetEventFilter
    SDL Library Documentation
    PrevNext

    SDL_SetEventFilter

    Name

    SDL_SetEventFilter -- Sets up a filter to process all events before they are posted +to the event queue.

    Synopsis

    #include "SDL.h"

    void SDL_SetEventFilter(SDL_EventFilter filter);

    Description

    This function sets up a filter to process all events before they are posted +to the event queue. This is a very powerful and flexible feature. The filter +is prototyped as: +

    typedef int (*SDL_EventFilter)(const SDL_Event *event);
    +If the filter returns 1, then the event will be +added to the internal queue. If it returns 0, +then the event will be dropped from the queue. This allows selective +filtering of dynamically.

    There is one caveat when dealing with the SDL_QUITEVENT event type. The +event filter is only called when the window manager desires to close the +application window. If the event filter returns 1, then the window will +be closed, otherwise the window will remain open if possible. +If the quit event is generated by an interrupt signal, it will bypass the +internal queue and be delivered to the application at the next event poll.

    Note: Events pushed onto the queue with SDL_PushEvent or SDL_PeepEvents do not get passed through the event filter.

    Note: Be Careful! The event filter function may run in a different thread so be careful what you do within it.


    PrevHomeNext
    SDL_PushEventUpSDL_GetEventFilter
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetgamma.html b/Externals/SDL/docs/html/sdlsetgamma.html new file mode 100644 index 0000000000..6443a966a2 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetgamma.html @@ -0,0 +1,231 @@ +SDL_SetGamma
    SDL Library Documentation
    PrevNext

    SDL_SetGamma

    Name

    SDL_SetGamma -- Sets the color gamma function for the display

    Synopsis

    #include "SDL.h"

    int SDL_SetGamma(float redgamma, float greengamma, float bluegamma);

    Description

    Sets the "gamma function" for the display of each color component. Gamma +controls the brightness/contrast of colors displayed on the screen. +A gamma value of 1.0 is identity (i.e., no adjustment +is made).

    This function adjusts the gamma based on the "gamma function" parameter, +you can directly specify lookup tables for gamma adjustment with +SDL_SetGammaRamp.

    Not all display hardware is able to change gamma.

    Return Value

    Returns -1 on error (or if gamma adjustment is not supported).


    PrevHomeNext
    SDL_SetPaletteUpSDL_GetGammaRamp
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetgammaramp.html b/Externals/SDL/docs/html/sdlsetgammaramp.html new file mode 100644 index 0000000000..79599c8d51 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetgammaramp.html @@ -0,0 +1,230 @@ +SDL_SetGammaRamp
    SDL Library Documentation
    PrevNext

    SDL_SetGammaRamp

    Name

    SDL_SetGammaRamp -- Sets the color gamma lookup tables for the display

    Synopsis

    #include "SDL.h"

    int SDL_SetGammaRamp(Uint16 *redtable, Uint16 *greentable, Uint16 *bluetable);

    Description

    Sets the gamma lookup tables for the display for each color component. +Each table is an array of 256 Uint16 values, representing a mapping +between the input and output for that channel. The input is the index +into the array, and the output is the 16-bit gamma value at that index, +scaled to the output color precision. You may pass NULL to any of the +channels to leave them unchanged.

    This function adjusts the gamma based on lookup tables, you can also +have the gamma calculated based on a "gamma function" parameter with +SDL_SetGamma.

    Not all display hardware is able to change gamma.

    Return Value

    Returns -1 on error (or if gamma adjustment is not supported).


    PrevHomeNext
    SDL_GetGammaRampUpSDL_MapRGB
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetmodstate.html b/Externals/SDL/docs/html/sdlsetmodstate.html new file mode 100644 index 0000000000..ee69a3f5df --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetmodstate.html @@ -0,0 +1,237 @@ +SDL_SetModState
    SDL Library Documentation
    PrevNext

    SDL_SetModState

    Name

    SDL_SetModState -- Set the current key modifier state

    Synopsis

    #include "SDL.h"

    void SDL_SetModState(SDLMod modstate);

    Description

    The inverse of SDL_GetModState, SDL_SetModState allows you to impose modifier key states on your application.

    Simply pass your desired modifier states into modstate. This value my be a logical OR'd combination of the following:

    typedef enum {
    +  KMOD_NONE  = 0x0000,
    +  KMOD_LSHIFT= 0x0001,
    +  KMOD_RSHIFT= 0x0002,
    +  KMOD_LCTRL = 0x0040,
    +  KMOD_RCTRL = 0x0080,
    +  KMOD_LALT  = 0x0100,
    +  KMOD_RALT  = 0x0200,
    +  KMOD_LMETA = 0x0400,
    +  KMOD_RMETA = 0x0800,
    +  KMOD_NUM   = 0x1000,
    +  KMOD_CAPS  = 0x2000,
    +  KMOD_MODE  = 0x4000,
    +} SDLMod;

    PrevHomeNext
    SDL_GetModStateUpSDL_GetKeyName
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetpalette.html b/Externals/SDL/docs/html/sdlsetpalette.html new file mode 100644 index 0000000000..1622f1590f --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetpalette.html @@ -0,0 +1,352 @@ +SDL_SetPalette
    SDL Library Documentation
    PrevNext

    SDL_SetPalette

    Name

    SDL_SetPalette -- Sets the colors in the palette of an 8-bit surface.

    Synopsis

    #include "SDL.h"

    int SDL_SetPalette(SDL_Surface *surface, int flags, SDL_Color *colors, int firstcolor, int ncolors);

    Description

    Sets a portion of the palette for the given 8-bit surface.

    Palettized (8-bit) screen surfaces with the +SDL_HWPALETTE flag have two palettes, a logical +palette that is used for mapping blits to/from the surface and a +physical palette (that determines how the hardware will map the colors +to the display). SDL_BlitSurface +always uses the logical palette when blitting surfaces (if it has to +convert between surface pixel formats). Because of this, it is often +useful to modify only one or the other palette to achieve various +special color effects (e.g., screen fading, color flashes, screen dimming).

    This function can modify either the logical or physical palette by +specifing SDL_LOGPAL or +SDL_PHYSPALthe in the flags +parameter.

    When surface is the surface associated with the current +display, the display colormap will be updated with the requested colors. If +SDL_HWPALETTE was set in SDL_SetVideoMode flags, +SDL_SetPalette will always return 1, +and the palette is guaranteed to be set the way you desire, even if the window +colormap has to be warped or run under emulation.

    The color components of a +SDL_Color structure +are 8-bits in size, giving you a total of +2563=16777216 colors.

    Return Value

    If surface is not a palettized surface, this function +does nothing, returning 0. If all of the colors were set +as passed to SDL_SetPalette, it will return +1. If not all the color entries were set exactly as +given, it will return 0, and you should look at the +surface palette to determine the actual color palette.

    Example

            /* Create a display surface with a grayscale palette */
    +        SDL_Surface *screen;
    +        SDL_Color colors[256];
    +        int i;
    +        .
    +        .
    +        .
    +        /* Fill colors with color information */
    +        for(i=0;i<256;i++){
    +          colors[i].r=i;
    +          colors[i].g=i;
    +          colors[i].b=i;
    +        }
    +
    +        /* Create display */
    +        screen=SDL_SetVideoMode(640, 480, 8, SDL_HWPALETTE);
    +        if(!screen){
    +          printf("Couldn't set video mode: %s\n", SDL_GetError());
    +          exit(-1);
    +        }
    +
    +        /* Set palette */
    +        SDL_SetPalette(screen, SDL_LOGPAL|SDL_PHYSPAL, colors, 0, 256);
    +        .
    +        .
    +        .
    +        .

    PrevHomeNext
    SDL_SetColorsUpSDL_SetGamma
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsettimer.html b/Externals/SDL/docs/html/sdlsettimer.html new file mode 100644 index 0000000000..40b737ce85 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsettimer.html @@ -0,0 +1,267 @@ +SDL_SetTimer
    SDL Library Documentation
    Prev 

    SDL_SetTimer

    Name

    SDL_SetTimer -- Set a callback to run after the specified number of milliseconds has +elapsed.

    Synopsis

    #include "SDL.h"

    int SDL_SetTimer(Uint32 interval, SDL_TimerCallback callback);

    Callback

    /* Function prototype for the timer callback function */ +typedef Uint32 (*SDL_TimerCallback)(Uint32 interval);

    Description

    Set a callback to run after the specified number of milliseconds has +elapsed. The callback function is passed the current timer interval +and returns the next timer interval. If the returned value is the +same as the one passed in, the periodic alarm continues, otherwise a +new alarm is scheduled.

    To cancel a currently running timer, call +SDL_SetTimer(0, NULL);

    The timer callback function may run in a different thread than your +main constant, and so shouldn't call any functions from within itself.

    The maximum resolution of this timer is 10 ms, which means that if +you request a 16 ms timer, your callback will run approximately 20 ms +later on an unloaded system. If you wanted to set a flag signaling +a frame update at 30 frames per second (every 33 ms), you might set a +timer for 30 ms (see example below).

    If you use this function, you need to pass SDL_INIT_TIMER +to SDL_Init().

    Note: This function is kept for compatibility but has been superseded +by the new timer functions +SDL_AddTimer and +SDL_RemoveTimer which support +multiple timers.

    Examples

    SDL_SetTimer((33/10)*10, my_callback);

    See Also

    SDL_AddTimer


    PrevHome 
    SDL_RemoveTimerUp 
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsetvideomode.html b/Externals/SDL/docs/html/sdlsetvideomode.html new file mode 100644 index 0000000000..8b309b048f --- /dev/null +++ b/Externals/SDL/docs/html/sdlsetvideomode.html @@ -0,0 +1,558 @@ +SDL_SetVideoMode
    SDL Library Documentation
    PrevNext

    SDL_SetVideoMode

    Name

    SDL_SetVideoMode -- Set up a video mode with the specified width, height and bits-per-pixel.

    Synopsis

    #include "SDL.h"

    SDL_Surface *SDL_SetVideoMode(int width, int height, int bpp, Uint32 flags);

    Description

    Set up a video mode with the specified width, height and bits-per-pixel.

    If bpp is 0, it is treated as the +current display bits per pixel.

    The flags parameter is the same as the flags field of the SDL_Surface structure. OR'd combinations of the following values are valid.

    SDL_SWSURFACECreate the video surface in system memory
    SDL_HWSURFACECreate the video surface in video memory
    SDL_ASYNCBLITEnables the use of asynchronous updates of the display surface. This will +usually slow down blitting on single CPU machines, but may provide a speed +increase on SMP systems.
    SDL_ANYFORMATNormally, if a video surface of the requested bits-per-pixel (bpp) is not available, SDL will emulate one with a shadow surface. Passing SDL_ANYFORMAT prevents this and causes SDL to use the video surface, regardless of its pixel depth.
    SDL_HWPALETTEGive SDL exclusive palette access. Without this flag you may not always get the the colors you request with SDL_SetColors or SDL_SetPalette.
    SDL_DOUBLEBUFEnable hardware double buffering; only valid with SDL_HWSURFACE. Calling +SDL_Flip will flip the +buffers and update the screen. All drawing will take place on the surface +that is not displayed at the moment. If double buffering could not be enabled +then SDL_Flip will just perform a +SDL_UpdateRect +on the entire screen.
    SDL_FULLSCREENSDL will attempt to use a fullscreen mode. If a hardware resolution change is +not possible (for whatever reason), the next higher resolution will be used and +the display window centered on a black background.
    SDL_OPENGLCreate an OpenGL rendering context. You should have previously set OpenGL video attributes with SDL_GL_SetAttribute.
    SDL_OPENGLBLITCreate an OpenGL rendering context, like above, but allow normal blitting +operations. The screen (2D) surface may have an alpha channel, and +SDL_UpdateRects +must be used for updating changes to the screen surface. NOTE: This option +is kept for compatibility only, and is not recommended for +new code.
    SDL_RESIZABLECreate a resizable window. When the window is resized by the user a SDL_VIDEORESIZE event is generated and SDL_SetVideoMode can be called again with the new size.
    SDL_NOFRAMEIf possible, SDL_NOFRAME causes SDL to create a window with no title bar or frame decoration. Fullscreen modes automatically have this flag set.

    Note: Whatever flags SDL_SetVideoMode could satisfy are set in the flags member of the returned surface.

    Note: The bpp parameter is the number of bits per pixel, +so a bpp of 24 uses the packed representation of +3 bytes/pixel. For the more common 4 bytes/pixel mode, use a +bpp of 32. Somewhat oddly, both 15 and 16 will +request a 2 bytes/pixel mode, but different pixel formats.

    Return Value

    The framebuffer surface, or NULL if it fails. +The surface returned is freed by SDL_Quit() and should nt be freed by +the caller.


    PrevHomeNext
    SDL_VideoModeOKUpSDL_UpdateRect
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlshowcursor.html b/Externals/SDL/docs/html/sdlshowcursor.html new file mode 100644 index 0000000000..5a8f19da22 --- /dev/null +++ b/Externals/SDL/docs/html/sdlshowcursor.html @@ -0,0 +1,239 @@ +SDL_ShowCursor
    SDL Library Documentation
    PrevNext

    SDL_ShowCursor

    Name

    SDL_ShowCursor -- Toggle whether or not the cursor is shown on the screen.

    Synopsis

    #include "SDL.h"

    int SDL_ShowCursor(int toggle);

    Description

    Toggle whether or not the cursor is shown on the screen. Passing SDL_ENABLE displays the cursor and passing SDL_DISABLE hides it. The current state of the mouse cursor can be queried by passing SDL_QUERY, either SDL_DISABLE or SDL_ENABLE will be returned.

    The cursor starts off displayed, but can be turned off.

    Return Value

    Returns the current state of the cursor.


    PrevHomeNext
    SDL_GetCursorUpSDL_GL_LoadLibrary
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsurface.html b/Externals/SDL/docs/html/sdlsurface.html new file mode 100644 index 0000000000..fda55f173f --- /dev/null +++ b/Externals/SDL/docs/html/sdlsurface.html @@ -0,0 +1,597 @@ +SDL_Surface
    SDL Library Documentation
    PrevNext

    SDL_Surface

    Name

    SDL_Surface -- Graphical Surface Structure

    Structure Definition

    typedef struct SDL_Surface {
    +        Uint32 flags;                           /* Read-only */
    +        SDL_PixelFormat *format;                /* Read-only */
    +        int w, h;                               /* Read-only */
    +        Uint16 pitch;                           /* Read-only */
    +        void *pixels;                           /* Read-write */
    +
    +        /* clipping information */
    +        SDL_Rect clip_rect;                     /* Read-only */
    +
    +        /* Reference count -- used when freeing surface */
    +        int refcount;                           /* Read-mostly */
    +
    +	/* This structure also contains private fields not shown here */
    +} SDL_Surface;

    Structure Data

    flagsSurface flags
    formatPixel format
    w, hWidth and height of the surface
    pitchLength of a surface scanline in bytes
    pixelsPointer to the actual pixel data
    clip_rectsurface clip rectangle

    Description

    SDL_Surface's represent areas of "graphical" +memory, memory that can be drawn to. The video framebuffer is returned +as a SDL_Surface by +SDL_SetVideoMode +and SDL_GetVideoSurface. +Most of the fields should be pretty obvious. +w and h are the +width and height of the surface in pixels. +pixels is a pointer to the actual pixel data, +the surface should be locked +before accessing this field. The clip_rect field +is the clipping rectangle as set by +SDL_SetClipRect.

    The following are supported in the +flags field.

    SDL_SWSURFACESurface is stored in system memory
    SDL_HWSURFACESurface is stored in video memory
    SDL_ASYNCBLITSurface uses asynchronous blits if possible
    SDL_ANYFORMATAllows any pixel-format (Display surface)
    SDL_HWPALETTESurface has exclusive palette
    SDL_DOUBLEBUFSurface is double buffered (Display surface)
    SDL_FULLSCREENSurface is full screen (Display Surface)
    SDL_OPENGLSurface has an OpenGL context (Display Surface)
    SDL_OPENGLBLITSurface supports OpenGL blitting (Display Surface)
    SDL_RESIZABLESurface is resizable (Display Surface)
    SDL_HWACCELSurface blit uses hardware acceleration
    SDL_SRCCOLORKEYSurface use colorkey blitting
    SDL_RLEACCELColorkey blitting is accelerated with RLE
    SDL_SRCALPHASurface blit uses alpha blending
    SDL_PREALLOCSurface uses preallocated memory


    PrevHomeNext
    SDL_PixelFormatUpSDL_VideoInfo
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlsyswmevent.html b/Externals/SDL/docs/html/sdlsyswmevent.html new file mode 100644 index 0000000000..fd7180ee21 --- /dev/null +++ b/Externals/SDL/docs/html/sdlsyswmevent.html @@ -0,0 +1,233 @@ +SDL_SysWMEvent
    SDL Library Documentation
    PrevNext

    SDL_SysWMEvent

    Name

    SDL_SysWMEvent -- Platform-dependent window manager event.

    Description

    The system window manager event contains a pointer to system-specific +information about unknown window manager events. If you enable this event +using +SDL_EventState(), +it will be generated whenever unhandled events are received from the window +manager. This can be used, for example, to implement cut-and-paste in your +application. + +

    typedef struct {
    +         Uint8 type;   /* Always SDL_SYSWMEVENT */
    +         SDL_SysWMmsg *msg;
    + } SDL_SysWMEvent;
    + +If you want to obtain system-specific information about the window manager, +you can fill the version member of a SDL_SysWMinfo +structure (details can be found in SDL_syswm.h, which must be included) using the SDL_VERSION() macro found in +SDL_version.h, and pass it to the +function: +

    int SDL_GetWMInfo(SDL_SysWMinfo *info);


    PrevHomeNext
    SDL_ExposeEventUpSDL_UserEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlthreadid.html b/Externals/SDL/docs/html/sdlthreadid.html new file mode 100644 index 0000000000..e0bde2e2a3 --- /dev/null +++ b/Externals/SDL/docs/html/sdlthreadid.html @@ -0,0 +1,190 @@ +SDL_ThreadID
    SDL Library Documentation
    PrevNext

    SDL_ThreadID

    Name

    SDL_ThreadID -- Get the 32-bit thread identifier for the current thread.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    Uint32 SDL_ThreadID(void);

    Description

    Get the 32-bit thread identifier for the current thread.


    PrevHomeNext
    SDL_CreateThreadUpSDL_GetThreadID
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlunlockaudio.html b/Externals/SDL/docs/html/sdlunlockaudio.html new file mode 100644 index 0000000000..0019bd692a --- /dev/null +++ b/Externals/SDL/docs/html/sdlunlockaudio.html @@ -0,0 +1,211 @@ +SDL_UnlockAudio
    SDL Library Documentation
    PrevNext

    SDL_UnlockAudio

    Name

    SDL_UnlockAudio -- Unlock the callback function

    Synopsis

    #include "SDL.h"

    void SDL_UnlockAudio(void);

    Description

    Unlocks a previous SDL_LockAudio call.


    PrevHomeNext
    SDL_LockAudioUpSDL_CloseAudio
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlunlocksurface.html b/Externals/SDL/docs/html/sdlunlocksurface.html new file mode 100644 index 0000000000..13ba5fc8e2 --- /dev/null +++ b/Externals/SDL/docs/html/sdlunlocksurface.html @@ -0,0 +1,219 @@ +SDL_UnlockSurface
    SDL Library Documentation
    PrevNext

    SDL_UnlockSurface

    Name

    SDL_UnlockSurface -- Unlocks a previously locked surface.

    Synopsis

    #include "SDL.h"

    void SDL_UnlockSurface(SDL_Surface *surface);

    Description

    Surfaces that were previously locked using SDL_LockSurface must be unlocked with SDL_UnlockSurface. Surfaces should be unlocked as soon as possible.

    It should be noted that since 1.1.8, surface locks are recursive. See SDL_LockSurface.


    PrevHomeNext
    SDL_LockSurfaceUpSDL_LoadBMP
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlunlockyuvoverlay.html b/Externals/SDL/docs/html/sdlunlockyuvoverlay.html new file mode 100644 index 0000000000..936ed9eaf7 --- /dev/null +++ b/Externals/SDL/docs/html/sdlunlockyuvoverlay.html @@ -0,0 +1,225 @@ +SDL_UnlockYUVOverlay
    SDL Library Documentation
    PrevNext

    SDL_UnlockYUVOverlay

    Name

    SDL_UnlockYUVOverlay -- Unlock an overlay

    Synopsis

    #include "SDL.h"

    void SDL_UnlockYUVOverlay(SDL_Overlay *overlay);

    Description

    The opposite to SDL_LockYUVOverlay. Unlocks a previously locked overlay. An overlay must be unlocked before it can be displayed.


    PrevHomeNext
    SDL_LockYUVOverlayUpSDL_DisplayYUVOverlay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlupdaterect.html b/Externals/SDL/docs/html/sdlupdaterect.html new file mode 100644 index 0000000000..f54d9f5e24 --- /dev/null +++ b/Externals/SDL/docs/html/sdlupdaterect.html @@ -0,0 +1,266 @@ +SDL_UpdateRect
    SDL Library Documentation
    PrevNext

    SDL_UpdateRect

    Name

    SDL_UpdateRect -- Makes sure the given area is updated on the given screen.

    Synopsis

    #include "SDL.h"

    void SDL_UpdateRect(SDL_Surface *screen, Sint32 x, Sint32 y, Sint32 w, Sint32 h);

    Description

    Makes sure the given area is updated on the given screen. The rectangle must +be confined within the screen boundaries (no clipping is done).

    If 'x', 'y', 'w' +and 'h' are all 0, +SDL_UpdateRect will update the +entire screen.

    This function should not be called while 'screen' is +locked.


    PrevHomeNext
    SDL_SetVideoModeUpSDL_UpdateRects
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlupdaterects.html b/Externals/SDL/docs/html/sdlupdaterects.html new file mode 100644 index 0000000000..0553a7a9d0 --- /dev/null +++ b/Externals/SDL/docs/html/sdlupdaterects.html @@ -0,0 +1,255 @@ +SDL_UpdateRects
    SDL Library Documentation
    PrevNext

    SDL_UpdateRects

    Name

    SDL_UpdateRects -- Makes sure the given list of rectangles is updated on the given screen.

    Synopsis

    #include "SDL.h"

    void SDL_UpdateRects(SDL_Surface *screen, int numrects, SDL_Rect *rects);

    Description

    Makes sure the given list of rectangles is updated on the given screen. +The rectangles must all be confined within the screen boundaries (no +clipping is done).

    This function should not be called while screen is +locked.

    Note: It is adviced to call this function only once per frame, since each +call has some processing overhead. This is no restriction since you +can pass any number of rectangles each time.

    The rectangles are not automatically merged or checked for overlap. In +general, the programmer can use his knowledge about his particular +rectangles to merge them in an efficient way, to avoid overdraw.


    PrevHomeNext
    SDL_UpdateRectUpSDL_Flip
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdluserevent.html b/Externals/SDL/docs/html/sdluserevent.html new file mode 100644 index 0000000000..178769c51d --- /dev/null +++ b/Externals/SDL/docs/html/sdluserevent.html @@ -0,0 +1,337 @@ +SDL_UserEvent
    SDL Library Documentation
    PrevNext

    SDL_UserEvent

    Name

    SDL_UserEvent -- A user-defined event type

    Structure Definition

    typedef struct{
    +  Uint8 type;
    +  int code;
    +  void *data1;
    +  void *data2;
    +} SDL_UserEvent;

    Structure Data

    typeSDL_USEREVENT through to SDL_NUMEVENTS-1
    codeUser defined event code
    data1User defined data pointer
    data2User defined data pointer

    Description

    SDL_UserEvent is in the user member of the structure SDL_Event. This event is unique, it is never created by SDL but only by the user. The event can be pushed onto the event queue using SDL_PushEvent. The contents of the structure members or completely up to the programmer, the only requirement is that type is a value from SDL_USEREVENT to SDL_NUMEVENTS-1 (inclusive).

    Examples

    SDL_Event event;
    +
    +event.type = SDL_USEREVENT;
    +event.user.code = my_event_code;
    +event.user.data1 = significant_data;
    +event.user.data2 = 0;
    +SDL_PushEvent(&event);


    PrevHomeNext
    SDL_SysWMEventUpSDL_QuitEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlvideodrivername.html b/Externals/SDL/docs/html/sdlvideodrivername.html new file mode 100644 index 0000000000..141965623f --- /dev/null +++ b/Externals/SDL/docs/html/sdlvideodrivername.html @@ -0,0 +1,243 @@ +SDL_VideoDriverName
    SDL Library Documentation
    PrevNext

    SDL_VideoDriverName

    Name

    SDL_VideoDriverName -- Obtain the name of the video driver

    Synopsis

    #include "SDL.h"

    char *SDL_VideoDriverName(char *namebuf, int maxlen);

    Description

    The buffer pointed to by namebuf is filled up to a maximum of maxlen characters (include the NULL terminator) with the name of the initialised video driver. The driver name is a simple one word identifier like "x11" or "windib".

    Return Value

    Returns NULL if video has not been initialised with SDL_Init or a pointer to namebuf otherwise.


    PrevHomeNext
    SDL_GetVideoInfoUpSDL_ListModes
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlvideoinfo.html b/Externals/SDL/docs/html/sdlvideoinfo.html new file mode 100644 index 0000000000..3a0da31dad --- /dev/null +++ b/Externals/SDL/docs/html/sdlvideoinfo.html @@ -0,0 +1,408 @@ +SDL_VideoInfo
    SDL Library Documentation
    PrevNext

    SDL_VideoInfo

    Name

    SDL_VideoInfo -- Video Target information

    Structure Definition

    typedef struct{
    +  Uint32 hw_available:1;
    +  Uint32 wm_available:1;
    +  Uint32 blit_hw:1;
    +  Uint32 blit_hw_CC:1;
    +  Uint32 blit_hw_A:1;
    +  Uint32 blit_sw:1;
    +  Uint32 blit_sw_CC:1;
    +  Uint32 blit_sw_A:1;
    +  Uint32 blit_fill;
    +  Uint32 video_mem;
    +  SDL_PixelFormat *vfmt;
    +} SDL_VideoInfo;

    Structure Data

    hw_availableIs it possible to create hardware surfaces?
    wm_availableIs there a window manager available
    blit_hwAre hardware to hardware blits accelerated?
    blit_hw_CCAre hardware to hardware colorkey blits accelerated?
    blit_hw_AAre hardware to hardware alpha blits accelerated?
    blit_swAre software to hardware blits accelerated?
    blit_sw_CCAre software to hardware colorkey blits accelerated?
    blit_sw_AAre software to hardware alpha blits accelerated?
    blit_fillAre color fills accelerated?
    video_memTotal amount of video memory in Kilobytes
    vfmtPixel format of the video device

    Description

    This (read-only) structure is returned by SDL_GetVideoInfo. It contains information on either the 'best' available mode (if called before SDL_SetVideoMode) or the current video mode.


    PrevHomeNext
    SDL_SurfaceUpSDL_Overlay
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlvideomodeok.html b/Externals/SDL/docs/html/sdlvideomodeok.html new file mode 100644 index 0000000000..5d2d6c4eb9 --- /dev/null +++ b/Externals/SDL/docs/html/sdlvideomodeok.html @@ -0,0 +1,270 @@ +SDL_VideoModeOK
    SDL Library Documentation
    PrevNext

    SDL_VideoModeOK

    Name

    SDL_VideoModeOK -- Check to see if a particular video mode is supported.

    Synopsis

    #include "SDL.h"

    int SDL_VideoModeOK(int width, int height, int bpp, Uint32 flags);

    Description

    SDL_VideoModeOK returns 0 +if the requested mode is not supported under any bit depth, or returns the +bits-per-pixel of the closest available mode with the given width, height and requested surface flags (see SDL_SetVideoMode).

    The bits-per-pixel value returned is only a suggested mode. You can usually request and bpp you want when setting the video mode and SDL will emulate that color depth with a shadow video surface.

    The arguments to SDL_VideoModeOK are the same ones you +would pass to SDL_SetVideoMode

    Example

    SDL_Surface *screen;
    +Uint32 bpp;
    +.
    +.
    +.
    +printf("Checking mode 640x480@16bpp.\n");
    +bpp=SDL_VideoModeOK(640, 480, 16, SDL_HWSURFACE);
    +
    +if(!bpp){
    +  printf("Mode not available.\n");
    +  exit(-1);
    +}
    +
    +printf("SDL Recommends 640x480@%dbpp.\n", bpp);
    +screen=SDL_SetVideoMode(640, 480, bpp, SDL_HWSURFACE);
    +.
    +.

    PrevHomeNext
    SDL_ListModesUpSDL_SetVideoMode
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwaitevent.html b/Externals/SDL/docs/html/sdlwaitevent.html new file mode 100644 index 0000000000..b473d3b06e --- /dev/null +++ b/Externals/SDL/docs/html/sdlwaitevent.html @@ -0,0 +1,231 @@ +SDL_WaitEvent
    SDL Library Documentation
    PrevNext

    SDL_WaitEvent

    Name

    SDL_WaitEvent -- Waits indefinitely for the next available event.

    Synopsis

    #include "SDL.h"

    int SDL_WaitEvent(SDL_Event *event);

    Description

    Waits indefinitely for the next available event, returning +1, or 0 if there was +an error while waiting for events.

    If event is not NULL, the next +event is removed from the queue and stored in that area.


    PrevHomeNext
    SDL_PollEventUpSDL_PushEvent
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwaitthread.html b/Externals/SDL/docs/html/sdlwaitthread.html new file mode 100644 index 0000000000..2becfbc47f --- /dev/null +++ b/Externals/SDL/docs/html/sdlwaitthread.html @@ -0,0 +1,231 @@ +SDL_WaitThread
    SDL Library Documentation
    PrevNext

    SDL_WaitThread

    Name

    SDL_WaitThread -- Wait for a thread to finish.

    Synopsis

    #include "SDL.h"
    +#include "SDL_thread.h"

    void SDL_WaitThread(SDL_Thread *thread, int *status);

    Description

    Wait for a thread to finish (timeouts are not supported).

    Return Value

    The return code for the thread function is placed in the area pointed to by +status, if status is not +NULL.


    PrevHomeNext
    SDL_GetThreadIDUpSDL_KillThread
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwarpmouse.html b/Externals/SDL/docs/html/sdlwarpmouse.html new file mode 100644 index 0000000000..e7b2d8d79f --- /dev/null +++ b/Externals/SDL/docs/html/sdlwarpmouse.html @@ -0,0 +1,205 @@ +SDL_WarpMouse
    SDL Library Documentation
    PrevNext

    SDL_WarpMouse

    Name

    SDL_WarpMouse -- Set the position of the mouse cursor.

    Synopsis

    #include "SDL.h"

    void SDL_WarpMouse(Uint16 x, Uint16 y);

    Description

    Set the position of the mouse cursor (generates a mouse motion event).


    PrevHomeNext
    SDL_DisplayFormatAlphaUpSDL_CreateCursor
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwasinit.html b/Externals/SDL/docs/html/sdlwasinit.html new file mode 100644 index 0000000000..b4effeb680 --- /dev/null +++ b/Externals/SDL/docs/html/sdlwasinit.html @@ -0,0 +1,284 @@ +SDL_WasInit
    SDL Library Documentation
    PrevNext

    SDL_WasInit

    Name

    SDL_WasInit -- Check which subsystems are initialized

    Synopsis

    #include "SDL.h"

    Uint32 SDL_WasInit(Uint32 flags);

    Description

    SDL_WasInit allows you to see which SDL subsytems have been initialized. flags is a bitwise OR'd combination of the subsystems you wish to check (see SDL_Init for a list of subsystem flags).

    Return Value

    SDL_WasInit returns a bitwised OR'd combination of the initialized subsystems.

    Examples

    
/* Here are several ways you can use SDL_WasInit() */
    +
    +/* Get init data on all the subsystems */
    +Uint32 subsystem_init;
    +
    +subsystem_init=SDL_WasInit(SDL_INIT_EVERYTHING);
    +
    +if(subsystem_init&SDL_INIT_VIDEO)
    +  printf("Video is initialized.\n");
    +else
    +  printf("Video is not initialized.\n");
    +
    +
    +
    +/* Just check for one specfic subsystem */
    +
    +if(SDL_WasInit(SDL_INIT_VIDEO)!=0)
    +  printf("Video is initialized.\n");
    +else
    +  printf("Video is not initialized.\n");
    +
    +
    +
    +
    +/* Check for two subsystems */
    +
    +Uint32 subsystem_mask=SDL_INIT_VIDEO|SDL_INIT_AUDIO;
    +
    +if(SDL_WasInit(subsystem_mask)==subsystem_mask)
    +  printf("Video and Audio initialized.\n");
    +else
    +  printf("Video and Audio not initialized.\n");

    PrevHomeNext
    SDL_QuitUpSDL_GetError
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwmgetcaption.html b/Externals/SDL/docs/html/sdlwmgetcaption.html new file mode 100644 index 0000000000..829c68aaa1 --- /dev/null +++ b/Externals/SDL/docs/html/sdlwmgetcaption.html @@ -0,0 +1,222 @@ +SDL_WM_GetCaption
    SDL Library Documentation
    PrevNext

    SDL_WM_GetCaption

    Name

    SDL_WM_GetCaption -- Gets the window title and icon name.

    Synopsis

    #include "SDL.h"

    void SDL_WM_GetCaption(char **title, char **icon);

    Description

    Set pointers to the window title and icon name.


    PrevHomeNext
    SDL_WM_SetCaptionUpSDL_WM_SetIcon
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwmgrabinput.html b/Externals/SDL/docs/html/sdlwmgrabinput.html new file mode 100644 index 0000000000..740dcd6b29 --- /dev/null +++ b/Externals/SDL/docs/html/sdlwmgrabinput.html @@ -0,0 +1,224 @@ +SDL_WM_GrabInput
    SDL Library Documentation
    PrevNext

    SDL_WM_GrabInput

    Name

    SDL_WM_GrabInput -- Grabs mouse and keyboard input.

    Synopsis

    #include "SDL.h"

    SDL_GrabMode SDL_WM_GrabInput(SDL_GrabMode mode);

    Description

    Grabbing means that the mouse is confined to the application window, +and nearly all keyboard input is passed directly to the application, +and not interpreted by a window manager, if any.

    When mode is SDL_GRAB_QUERY the grab mode is not changed, but the current grab mode is returned.

    typedef enum {
    +  SDL_GRAB_QUERY,
    +  SDL_GRAB_OFF,
    +  SDL_GRAB_ON
    +} SDL_GrabMode;
    +

    Return Value

    The current/new SDL_GrabMode.


    PrevHomeNext
    SDL_WM_ToggleFullScreenUpEvents
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwmiconifywindow.html b/Externals/SDL/docs/html/sdlwmiconifywindow.html new file mode 100644 index 0000000000..1113656862 --- /dev/null +++ b/Externals/SDL/docs/html/sdlwmiconifywindow.html @@ -0,0 +1,211 @@ +SDL_WM_IconifyWindow
    SDL Library Documentation
    PrevNext

    SDL_WM_IconifyWindow

    Name

    SDL_WM_IconifyWindow -- Iconify/Minimise the window

    Synopsis

    #include "SDL.h"

    int SDL_WM_IconifyWindow(void);

    Description

    If the application is running in a window managed environment SDL attempts to iconify/minimise it. If SDL_WM_IconifyWindow is successful, the application will receive a SDL_APPACTIVE loss event.

    Return Value

    Returns non-zero on success or 0 if iconification is not support or was refused by the window manager.


    PrevHomeNext
    SDL_WM_SetIconUpSDL_WM_ToggleFullScreen
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwmsetcaption.html b/Externals/SDL/docs/html/sdlwmsetcaption.html new file mode 100644 index 0000000000..bc47c278bd --- /dev/null +++ b/Externals/SDL/docs/html/sdlwmsetcaption.html @@ -0,0 +1,212 @@ +SDL_WM_SetCaption
    SDL Library Documentation
    PrevNext

    SDL_WM_SetCaption

    Name

    SDL_WM_SetCaption -- Sets the window tile and icon name.

    Synopsis

    #include "SDL.h"

    void SDL_WM_SetCaption(const char *title, const char *icon);

    Description

    Sets the title-bar and icon name of the display window.


    PrevHomeNext
    Window ManagementUpSDL_WM_GetCaption
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwmseticon.html b/Externals/SDL/docs/html/sdlwmseticon.html new file mode 100644 index 0000000000..12eb207c69 --- /dev/null +++ b/Externals/SDL/docs/html/sdlwmseticon.html @@ -0,0 +1,260 @@ +SDL_WM_SetIcon
    SDL Library Documentation
    PrevNext

    SDL_WM_SetIcon

    Name

    SDL_WM_SetIcon -- Sets the icon for the display window.

    Synopsis

    #include "SDL.h"

    void SDL_WM_SetIcon(SDL_Surface *icon, Uint8 *mask);

    Description

    Sets the icon for the display window. Win32 icons must be 32x32.

    This function must be called before the first call to +SDL_SetVideoMode.

    The mask is a bitmask that describes the shape of the +icon. If mask is NULL, then the shape is determined by +the colorkey of icon, if any, or makes the icon +rectangular (no transparency) otherwise.

    If mask is non-NULL, it points to a bitmap with bits set +where the corresponding pixel should be visible. The format of the bitmap is as +follows: Scanlines come in the usual top-down order. Each scanline consists of +(width / 8) bytes, rounded up. The most significant bit of each byte represents +the leftmost pixel.

    Example

    SDL_WM_SetIcon(SDL_LoadBMP("icon.bmp"), NULL);

    PrevHomeNext
    SDL_WM_GetCaptionUpSDL_WM_IconifyWindow
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/sdlwmtogglefullscreen.html b/Externals/SDL/docs/html/sdlwmtogglefullscreen.html new file mode 100644 index 0000000000..b7973de551 --- /dev/null +++ b/Externals/SDL/docs/html/sdlwmtogglefullscreen.html @@ -0,0 +1,205 @@ +SDL_WM_ToggleFullScreen
    SDL Library Documentation
    PrevNext

    SDL_WM_ToggleFullScreen

    Name

    SDL_WM_ToggleFullScreen -- Toggles fullscreen mode

    Synopsis

    #include "SDL.h"

    int SDL_WM_ToggleFullScreen(SDL_Surface *surface);

    Description

    Toggles the application between windowed and fullscreen mode, if supported. (X11 is the only target currently supported, BeOS support is experimental).

    Return Value

    Returns 0 on failure or 1 on success.


    PrevHomeNext
    SDL_WM_IconifyWindowUpSDL_WM_GrabInput
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/thread.html b/Externals/SDL/docs/html/thread.html new file mode 100644 index 0000000000..c66018eff2 --- /dev/null +++ b/Externals/SDL/docs/html/thread.html @@ -0,0 +1,313 @@ +Multi-threaded Programming
    SDL Library Documentation
    PrevNext

    Chapter 12. Multi-threaded Programming

    Table of Contents
    SDL_CreateThread -- Creates a new thread of execution that shares its parent's properties.
    SDL_ThreadID -- Get the 32-bit thread identifier for the current thread.
    SDL_GetThreadID -- Get the SDL thread ID of a SDL_Thread
    SDL_WaitThread -- Wait for a thread to finish.
    SDL_KillThread -- Gracelessly terminates the thread.
    SDL_CreateMutex -- Create a mutex
    SDL_DestroyMutex -- Destroy a mutex
    SDL_mutexP -- Lock a mutex
    SDL_mutexV -- Unlock a mutex
    SDL_CreateSemaphore -- Creates a new semaphore and assigns an initial value to it.
    SDL_DestroySemaphore -- Destroys a semaphore that was created by SDL_CreateSemaphore.
    SDL_SemWait -- Lock a semaphore and suspend the thread if the semaphore value is zero.
    SDL_SemTryWait -- Attempt to lock a semaphore but don't suspend the thread.
    SDL_SemWaitTimeout -- Lock a semaphore, but only wait up to a specified maximum time.
    SDL_SemPost -- Unlock a semaphore.
    SDL_SemValue -- Return the current value of a semaphore.
    SDL_CreateCond -- Create a condition variable
    SDL_DestroyCond -- Destroy a condition variable
    SDL_CondSignal -- Restart a thread wait on a condition variable
    SDL_CondBroadcast -- Restart all threads waiting on a condition variable
    SDL_CondWait -- Wait on a condition variable
    SDL_CondWaitTimeout -- Wait on a condition variable, with timeout

    SDL provides functions for creating threads, mutexes, semphores and condition variables.

    In general, you must be very aware of concurrency and data integrity issues +when writing multi-threaded programs. Some good guidelines include: +

    • Don't call SDL video/event functions from separate threads

    • Don't use any library functions in separate threads

    • Don't perform any memory management in separate threads

    • Lock global variables which may be accessed by multiple threads

    • Never terminate threads, always set a flag and wait for them to quit

    • Think very carefully about all possible ways your code may interact

    Note: SDL's threading is not implemented on MacOS, due to that lack of preemptive thread support (Mac OS X dos nt suffer from this problem)


    PrevHomeNext
    SDL_CDtrackUpSDL_CreateThread
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/time.html b/Externals/SDL/docs/html/time.html new file mode 100644 index 0000000000..854b7cb57e --- /dev/null +++ b/Externals/SDL/docs/html/time.html @@ -0,0 +1,206 @@ +Time
    SDL Library Documentation
    PrevNext

    Chapter 13. Time

    Table of Contents
    SDL_GetTicks -- Get the number of milliseconds since the SDL library initialization.
    SDL_Delay -- Wait a specified number of milliseconds before returning.
    SDL_AddTimer -- Add a timer which will call a callback after the specified number of milliseconds has +elapsed.
    SDL_RemoveTimer -- Remove a timer which was added with +SDL_AddTimer.
    SDL_SetTimer -- Set a callback to run after the specified number of milliseconds has +elapsed.

    SDL provides several cross-platform functions for dealing with time. +It provides a way to get the current time, a way to wait a little while, +and a simple timer mechanism. These functions give you two ways of moving an +object every x milliseconds: + +

    • Use a timer callback function. This may have the bad effect that it runs in a seperate thread or uses alarm signals, but it's easier to implement.

    • Or you can get the number of milliseconds passed, and move the object if, for example, 30 ms passed.


    PrevHomeNext
    SDL_CondWaitTimeoutUpSDL_GetTicks
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/video.html b/Externals/SDL/docs/html/video.html new file mode 100644 index 0000000000..9b1434e62d --- /dev/null +++ b/Externals/SDL/docs/html/video.html @@ -0,0 +1,507 @@ +Video
    SDL Library Documentation
    PrevNext

    Chapter 6. Video

    Table of Contents
    SDL_GetVideoSurface -- returns a pointer to the current display surface
    SDL_GetVideoInfo -- returns a pointer to information about the video hardware
    SDL_VideoDriverName -- Obtain the name of the video driver
    SDL_ListModes -- Returns a pointer to an array of available screen dimensions for +the given format and video flags
    SDL_VideoModeOK -- Check to see if a particular video mode is supported.
    SDL_SetVideoMode -- Set up a video mode with the specified width, height and bits-per-pixel.
    SDL_UpdateRect -- Makes sure the given area is updated on the given screen.
    SDL_UpdateRects -- Makes sure the given list of rectangles is updated on the given screen.
    SDL_Flip -- Swaps screen buffers
    SDL_SetColors -- Sets a portion of the colormap for the given 8-bit surface.
    SDL_SetPalette -- Sets the colors in the palette of an 8-bit surface.
    SDL_SetGamma -- Sets the color gamma function for the display
    SDL_GetGammaRamp -- Gets the color gamma lookup tables for the display
    SDL_SetGammaRamp -- Sets the color gamma lookup tables for the display
    SDL_MapRGB -- Map a RGB color value to a pixel format.
    SDL_MapRGBA -- Map a RGBA color value to a pixel format.
    SDL_GetRGB -- Get RGB values from a pixel in the specified pixel format.
    SDL_GetRGBA -- Get RGBA values from a pixel in the specified pixel format.
    SDL_CreateRGBSurface -- Create an empty SDL_Surface
    SDL_CreateRGBSurfaceFrom -- Create an SDL_Surface from pixel data
    SDL_FreeSurface -- Frees (deletes) a SDL_Surface
    SDL_LockSurface -- Lock a surface for directly access.
    SDL_UnlockSurface -- Unlocks a previously locked surface.
    SDL_LoadBMP -- Load a Windows BMP file into an SDL_Surface.
    SDL_SaveBMP -- Save an SDL_Surface as a Windows BMP file.
    SDL_SetColorKey -- Sets the color key (transparent pixel) in a blittable surface and +RLE acceleration.
    SDL_SetAlpha -- Adjust the alpha properties of a surface
    SDL_SetClipRect -- Sets the clipping rectangle for a surface.
    SDL_GetClipRect -- Gets the clipping rectangle for a surface.
    SDL_ConvertSurface -- Converts a surface to the same format as another surface.
    SDL_BlitSurface -- This performs a fast blit from the source surface to the destination surface.
    SDL_FillRect -- This function performs a fast fill of the given rectangle with some color
    SDL_DisplayFormat -- Convert a surface to the display format
    SDL_DisplayFormatAlpha -- Convert a surface to the display format
    SDL_WarpMouse -- Set the position of the mouse cursor.
    SDL_CreateCursor -- Creates a new mouse cursor.
    SDL_FreeCursor -- Frees a cursor created with SDL_CreateCursor.
    SDL_SetCursor -- Set the currently active mouse cursor.
    SDL_GetCursor -- Get the currently active mouse cursor.
    SDL_ShowCursor -- Toggle whether or not the cursor is shown on the screen.
    SDL_GL_LoadLibrary -- Specify an OpenGL library
    SDL_GL_GetProcAddress -- Get the address of a GL function
    SDL_GL_GetAttribute -- Get the value of a special SDL/OpenGL attribute
    SDL_GL_SetAttribute -- Set a special SDL/OpenGL attribute
    SDL_GL_SwapBuffers -- Swap OpenGL framebuffers/Update Display
    SDL_CreateYUVOverlay -- Create a YUV video overlay
    SDL_LockYUVOverlay -- Lock an overlay
    SDL_UnlockYUVOverlay -- Unlock an overlay
    SDL_DisplayYUVOverlay -- Blit the overlay to the display
    SDL_FreeYUVOverlay -- Free a YUV video overlay
    SDL_GLattr -- SDL GL Attributes
    SDL_Rect -- Defines a rectangular area
    SDL_Color -- Format independent color description
    SDL_Palette -- Color palette for 8-bit pixel formats
    SDL_PixelFormat -- Stores surface format information
    SDL_Surface -- Graphical Surface Structure
    SDL_VideoInfo -- Video Target information
    SDL_Overlay -- YUV video overlay

    SDL presents a very simple interface to the display framebuffer. The +framebuffer is represented as an offscreen surface to which you can write +directly. If you want the screen to show what you have written, call the update function which will +guarantee that the desired portion of the screen is updated.

    Before you call any of the SDL video functions, you must first call +SDL_Init(SDL_INIT_VIDEO), which initializes the video +and events in the SDL library. Check the return code, which should be +0, to see if there were any errors in starting up.

    If you use both sound and video in your application, you need to call +SDL_Init(SDL_INIT_AUDIO | SDL_INIT_VIDEO) before opening the +sound device, otherwise under Win32 DirectX, you won't be able to set +full-screen display modes.

    After you have initialized the library, you can start up the video display in a +number of ways. The easiest way is to pick a common screen resolution and +depth and just initialize the video, checking for errors. You will probably +get what you want, but SDL may be emulating your requested mode and converting +the display on update. The best way is to +query, for the best +video mode closest to the desired one, and then +convert +your images to that pixel format.

    SDL currently supports any bit depth >= 8 bits per pixel. 8 bpp formats are +considered 8-bit palettized modes, while 12, 15, 16, 24, and 32 bits per pixel +are considered "packed pixel" modes, meaning each pixel contains the RGB color +components packed in the bits of the pixel.

    After you have initialized your video mode, you can take the surface that was +returned, and write to it like any other framebuffer, calling the update +routine as you go.

    When you have finished your video access and are ready to quit your +application, you should call "SDL_Quit()" to shutdown the +video and events.


    PrevHomeNext
    SDL_envvarsUpSDL_GetVideoSurface
    \ No newline at end of file diff --git a/Externals/SDL/docs/html/wm.html b/Externals/SDL/docs/html/wm.html new file mode 100644 index 0000000000..f53a349c16 --- /dev/null +++ b/Externals/SDL/docs/html/wm.html @@ -0,0 +1,188 @@ +Window Management
    SDL Library Documentation
    PrevNext

    Chapter 7. Window Management

    Table of Contents
    SDL_WM_SetCaption -- Sets the window tile and icon name.
    SDL_WM_GetCaption -- Gets the window title and icon name.
    SDL_WM_SetIcon -- Sets the icon for the display window.
    SDL_WM_IconifyWindow -- Iconify/Minimise the window
    SDL_WM_ToggleFullScreen -- Toggles fullscreen mode
    SDL_WM_GrabInput -- Grabs mouse and keyboard input.

    SDL provides a small set of window management functions which allow applications to change their title and toggle from windowed mode to fullscreen (if available)


    PrevHomeNext
    SDL_OverlayUpSDL_WM_SetCaption
    \ No newline at end of file diff --git a/Externals/SDL/docs/images/rainbow.gif b/Externals/SDL/docs/images/rainbow.gif new file mode 100644 index 0000000000000000000000000000000000000000..07eb184f7e0496747543f459ae6981e5d70c0292 GIT binary patch literal 1715 zcmeIx`&ZL-7zgkvilCyKf<7uJpETp+<={wzd25XO(9Rr*H1L8`1ZJscD3|Gx;b;gu zUY8;caKJ*b1(>ruNrB)7N1S3dO>Ls0BelMy=+{JeqSHUnAJFUf_w&R1eV(Y8$dKS< z|Do<27l#8D7OV`|8E`P*WWdD$!vO07B!Cpq3FsnxmI#oDkcg2;k;qsgLn3F1f+b3p zs92(5iH;?DmKa!KVu_h07M36oqy+f{1q4L|#RR1UWd!8}6$F(8RRlEzbp-VU4FpXD z%>*q38wgqn+6g)cIw_x_e3l~csf$k;KA+(u2&hv)T>=CVb%>}_gdnDNF?EO$q|_>< zb}534Hpr+|h9IXFIc<;+LQqh%f?5;^N@`M4vl2l?4Jv9{s!hcoD(Ul4i>aDqL3qw7vI?eQ2tE2*{4 z*sSGF7aOAMD=rnm`{{RE>nm;h{lf}sxl-zc@VBhf2%lgyvNhaLI>RJ&kI&A$emxg}EM02`vS-8PWRU%@7*vzRj_PKlATQE>CvD|nedvrHHNwWKXUjC~I z4=&dV%a`Vl^nUIt7bfTJM&2_2&|z*Ou3F7o%ni-+T-w>WXH0m&eGM<@8pjQs>zchL z??`RdF1l6MT(GE1Qn6Q1)!kgUq^>)xXh|(sYxj( zji)B3W!#RO{AnF;)|9F#WYEsM?)9 z^|rd)(ch2o-@Um*E977K_^0K9KfA_DL|!YsrDFc08*$PV8-3zs+aCEO>?v63_$1AI z$&tAA%F3Iov**?yU7PC}Up&HNMvr=ZQNDkk{6I{+XycL61HYsgvd@W9D=drLAE6UAd|&R1v`J`q&vA{Sb_569=EeVLL`^QPK#BqzOQ%gLH2 zr_bIYr~S@3Wl^;k`U + +Simple DirectMedia Layer Introduction + + +
    +

    Simple DirectMedia Layer Introduction

    +

    +This library is designed to make it easy to write games that run on many +different platforms using the various native high-performance media interfaces, +(for video, audio, etc) and presenting a single source-code level API to +your application. This is a fairly low level API, but using this, completely +portable applications can be written with a great deal of flexibility. +

    +An introduction to SDL can be found online at: + + http://www.libsdl.org/intro.php +

    +Tutorials on a variety of topics can be found online at: + + http://www.libsdl.org/tutorials.php +

    +Documentation in Wiki form can be found online at: + + http://www.libsdl.org/cgi/docwiki.cgi/ +

    +Enjoy! +

    +    Sam Lantinga + +

    +


    +

    Table of Contents

    + +
    diff --git a/Externals/SDL/docs/man3/SDLKey.3 b/Externals/SDL/docs/man3/SDLKey.3 new file mode 100644 index 0000000000..dc74dfaac7 --- /dev/null +++ b/Externals/SDL/docs/man3/SDLKey.3 @@ -0,0 +1,161 @@ +.TH "SDLKey" "3" "Wed 11 Oct 2000, 22:28" "SDL" "SDL API Reference" +.SH "NAME" +SDLKey \- SDL Keysym Definitions +.SH "SDL Keysym definitions" +.PP +\fBSDLKey ASCII value Common Name\fR +.nf +\f(CWSDLK_BACKSPACE '\\b' backspace +SDLK_TAB '\\t' tab +SDLK_CLEAR clear +SDLK_RETURN '\\r' return +SDLK_PAUSE pause +SDLK_ESCAPE '^[' escape +SDLK_SPACE ' ' space +SDLK_EXCLAIM '!' exclaim +SDLK_QUOTEDBL '"' quotedbl +SDLK_HASH '#' hash +SDLK_DOLLAR '$' dollar +SDLK_AMPERSAND '&' ampersand +SDLK_QUOTE ''' quote +SDLK_LEFTPAREN '(' left parenthesis +SDLK_RIGHTPAREN ')' right parenthesis +SDLK_ASTERISK '*' asterisk +SDLK_PLUS '+' plus sign +SDLK_COMMA ',' comma +SDLK_MINUS '-' minus sign +SDLK_PERIOD '.' period +SDLK_SLASH '/' forward slash +SDLK_0 '0' 0 +SDLK_1 '1' 1 +SDLK_2 '2' 2 +SDLK_3 '3' 3 +SDLK_4 '4' 4 +SDLK_5 '5' 5 +SDLK_6 '6' 6 +SDLK_7 '7' 7 +SDLK_8 '8' 8 +SDLK_9 '9' 9 +SDLK_COLON ':' colon +SDLK_SEMICOLON ';' semicolon +SDLK_LESS '<' less-than sign +SDLK_EQUALS '=' equals sign +SDLK_GREATER '>' greater-than sign +SDLK_QUESTION '?' question mark +SDLK_AT '@' at +SDLK_LEFTBRACKET '[' left bracket +SDLK_BACKSLASH '\\' backslash +SDLK_RIGHTBRACKET ']' right bracket +SDLK_CARET '^' caret +SDLK_UNDERSCORE '_' underscore +SDLK_BACKQUOTE '`' grave +SDLK_a 'a' a +SDLK_b 'b' b +SDLK_c 'c' c +SDLK_d 'd' d +SDLK_e 'e' e +SDLK_f 'f' f +SDLK_g 'g' g +SDLK_h 'h' h +SDLK_i 'i' i +SDLK_j 'j' j +SDLK_k 'k' k +SDLK_l 'l' l +SDLK_m 'm' m +SDLK_n 'n' n +SDLK_o 'o' o +SDLK_p 'p' p +SDLK_q 'q' q +SDLK_r 'r' r +SDLK_s 's' s +SDLK_t 't' t +SDLK_u 'u' u +SDLK_v 'v' v +SDLK_w 'w' w +SDLK_x 'x' x +SDLK_y 'y' y +SDLK_z 'z' z +SDLK_DELETE '^?' delete +SDLK_KP0 keypad 0 +SDLK_KP1 keypad 1 +SDLK_KP2 keypad 2 +SDLK_KP3 keypad 3 +SDLK_KP4 keypad 4 +SDLK_KP5 keypad 5 +SDLK_KP6 keypad 6 +SDLK_KP7 keypad 7 +SDLK_KP8 keypad 8 +SDLK_KP9 keypad 9 +SDLK_KP_PERIOD '.' keypad period +SDLK_KP_DIVIDE '/' keypad divide +SDLK_KP_MULTIPLY '*' keypad multiply +SDLK_KP_MINUS '-' keypad minus +SDLK_KP_PLUS '+' keypad plus +SDLK_KP_ENTER '\\r' keypad enter +SDLK_KP_EQUALS '=' keypad equals +SDLK_UP up arrow +SDLK_DOWN down arrow +SDLK_RIGHT right arrow +SDLK_LEFT left arrow +SDLK_INSERT insert +SDLK_HOME home +SDLK_END end +SDLK_PAGEUP page up +SDLK_PAGEDOWN page down +SDLK_F1 F1 +SDLK_F2 F2 +SDLK_F3 F3 +SDLK_F4 F4 +SDLK_F5 F5 +SDLK_F6 F6 +SDLK_F7 F7 +SDLK_F8 F8 +SDLK_F9 F9 +SDLK_F10 F10 +SDLK_F11 F11 +SDLK_F12 F12 +SDLK_F13 F13 +SDLK_F14 F14 +SDLK_F15 F15 +SDLK_NUMLOCK numlock +SDLK_CAPSLOCK capslock +SDLK_SCROLLOCK scrollock +SDLK_RSHIFT right shift +SDLK_LSHIFT left shift +SDLK_RCTRL right ctrl +SDLK_LCTRL left ctrl +SDLK_RALT right alt +SDLK_LALT left alt +SDLK_RMETA right meta +SDLK_LMETA left meta +SDLK_LSUPER left windows key +SDLK_RSUPER right windows key +SDLK_MODE mode shift +SDLK_HELP help +SDLK_PRINT print-screen +SDLK_SYSREQ SysRq +SDLK_BREAK break +SDLK_MENU menu +SDLK_POWER power +SDLK_EURO euro\fR +.fi + + +.SH "SDL modifier definitions" +.PP +\fBSDL Modifier Meaning\fR +.nf +\f(CWKMOD_NONE No modifiers applicable +KMOD_NUM Numlock is down +KMOD_CAPS Capslock is down +KMOD_LCTRL Left Control is down +KMOD_RCTRL Right Control is down +KMOD_RSHIFT Right Shift is down +KMOD_LSHIFT Left Shift is down +KMOD_RALT Right Alt is down +KMOD_LALT Left Alt is down +KMOD_CTRL A Control key is down +KMOD_SHIFT A Shift key is down +KMOD_ALT An Alt key is down\fR +.fi + diff --git a/Externals/SDL/docs/man3/SDL_ActiveEvent.3 b/Externals/SDL/docs/man3/SDL_ActiveEvent.3 new file mode 100644 index 0000000000..068e7c01ad --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ActiveEvent.3 @@ -0,0 +1,38 @@ +.TH "SDL_ActiveEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ActiveEvent \- Application visibility event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 gain; + Uint8 state; +} SDL_ActiveEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_ACTIVEEVENT\&.\fP +.TP 20 +\fBgain\fR +0 if the event is a loss or 1 if it is a gain\&. +.TP 20 +\fBstate\fR +\fBSDL_APPMOUSEFOCUS\fP if mouse focus was gained or lost, \fBSDL_APPINPUTFOCUS\fP if input focus was gained or lost, or \fBSDL_APPACTIVE\fP if the application was iconified (\fBgain\fR=0) or restored(\fBgain\fR=1)\&. +.SH "DESCRIPTION" +.PP +\fBSDL_ActiveEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_ACTIVEEVENT\fP is reported\&. +.PP +When the mouse leaves or enters the window area a \fBSDL_APPMOUSEFOCUS\fP type activation event occurs, if the mouse entered the window then \fBgain\fR will be 1, otherwise \fBgain\fR will be 0\&. A \fBSDL_APPINPUTFOCUS\fP type activation event occurs when the application loses or gains keyboard focus\&. This usually occurs when another application is made active\&. Finally, a \fBSDL_APPACTIVE\fP type event occurs when the application is either minimised/iconified (\fBgain\fR=0) or restored\&. +.PP +.RS +\fBNote: +.PP +This event does not occur when an application window is first created\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_GetAppState\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_AddTimer.3 b/Externals/SDL/docs/man3/SDL_AddTimer.3 new file mode 100644 index 0000000000..bc494ed4b8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_AddTimer.3 @@ -0,0 +1,38 @@ +.TH "SDL_AddTimer" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_AddTimer \- Add a timer which will call a callback after the specified number of milliseconds has elapsed\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_TimerID \fBSDL_AddTimer\fP\fR(\fBUint32 interval, SDL_NewTimerCallback callback, void *param\fR); +.SH "CALLBACK" +.PP +.nf +\f(CW/* type definition for the "new" timer callback function */ +typedef Uint32 (*SDL_NewTimerCallback)(Uint32 interval, void *param);\fR +.fi +.PP +.SH "DESCRIPTION" +.PP +Adds a callback function to be run after the specified number of milliseconds has elapsed\&. The callback function is passed the current timer interval and the user supplied parameter from the \fBSDL_AddTimer\fP call and returns the next timer interval\&. If the returned value from the callback is the same as the one passed in, the periodic alarm continues, otherwise a new alarm is scheduled\&. +.PP +To cancel a currently running timer call \fISDL_RemoveTimer\fR with the timer ID returned from \fBSDL_AddTimer\fP\&. +.PP +The timer callback function may run in a different thread than your main program, and so shouldn\&'t call any functions from within itself\&. You may always call \fISDL_PushEvent\fR, however\&. +.PP +The granularity of the timer is platform-dependent, but you should count on it being at least 10 ms as this is the most common number\&. This means that if you request a 16 ms timer, your callback will run approximately 20 ms later on an unloaded system\&. If you wanted to set a flag signaling a frame update at 30 frames per second (every 33 ms), you might set a timer for 30 ms (see example below)\&. If you use this function, you need to pass \fBSDL_INIT_TIMER\fP to \fISDL_Init\fR\&. +.SH "RETURN VALUE" +.PP +Returns an ID value for the added timer or \fBNULL\fR if there was an error\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWmy_timer_id = SDL_AddTimer((33/10)*10, my_callbackfunc, my_callback_param);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_RemoveTimer\fP\fR, \fI\fBSDL_PushEvent\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_AudioCVT.3 b/Externals/SDL/docs/man3/SDL_AudioCVT.3 new file mode 100644 index 0000000000..f5e348952d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_AudioCVT.3 @@ -0,0 +1,68 @@ +.TH "SDL_AudioCVT" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_AudioCVT \- Audio Conversion Structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + int needed; + Uint16 src_format; + Uint16 dest_format; + double rate_incr; + Uint8 *buf; + int len; + int len_cvt; + int len_mult; + double len_ratio; + void (*filters[10])(struct SDL_AudioCVT *cvt, Uint16 format); + int filter_index; +} SDL_AudioCVT;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBneeded\fR +Set to one if the conversion is possible +.TP 20 +\fBsrc_format\fR +Audio format of the source +.TP 20 +\fBdest_format\fR +Audio format of the destination +.TP 20 +\fBrate_incr\fR +Rate conversion increment +.TP 20 +\fBbuf\fR +Audio buffer +.TP 20 +\fBlen\fR +Length of the original audio buffer in bytes +.TP 20 +\fBlen_cvt\fR +Length of converted audio buffer in bytes (calculated) +.TP 20 +\fBlen_mult\fR +\fBbuf\fR must be \fBlen\fR*\fBlen_mult\fR bytes in size(calculated) +.TP 20 +\fBlen_ratio\fR +Final audio size is \fBlen\fR*\fBlen_ratio\fR +.TP 20 +\fBfilters[10](\&.\&.)\fR +Pointers to functions needed for this conversion +.TP 20 +\fBfilter_index\fR +Current conversion function +.SH "DESCRIPTION" +.PP +The \fBSDL_AudioCVT\fR is used to convert audio data between different formats\&. A \fBSDL_AudioCVT\fR structure is created with the \fI\fBSDL_BuildAudioCVT\fP\fR function, while the actual conversion is done by the \fI\fBSDL_ConvertAudio\fP\fR function\&. +.PP +Many of the fields in the \fBSDL_AudioCVT\fR structure should be considered private and their function will not be discussed here\&. +.IP "\fBUint8 *\fP\fBbuf\fR" 10This points to the audio data that will be used in the conversion\&. It is both the source and the destination, which means the converted audio data overwrites the original data\&. It also means that the converted data may be larger than the original data (if you were converting from 8-bit to 16-bit, for instance), so you must ensure \fBbuf\fR is large enough\&. See below\&. +.IP "\fBint\fP \fBlen\fR" 10This is the length of the original audio data in bytes\&. +.IP "\fBint\fP \fBlen_mult\fR" 10As explained above, the audio buffer needs to be big enough to store the converted data, which may be bigger than the original audio data\&. The length of \fBbuf\fR should be \fBlen\fR*\fBlen_mult\fR\&. +.IP "\fBdouble\fP \fBlen_ratio\fR" 10When you have finished converting your audio data, you need to know how much of your audio buffer is valid\&. \fBlen\fR*\fBlen_ratio\fR is the size of the converted audio data in bytes\&. This is very similar to \fBlen_mult\fR, however when the convert audio data is shorter than the original \fBlen_mult\fR would be 1\&. \fBlen_ratio\fR, on the other hand, would be a fractional number between 0 and 1\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_BuildAudioCVT\fP\fR, \fI\fBSDL_ConvertAudio\fP\fR, \fI\fBSDL_AudioSpec\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_AudioSpec.3 b/Externals/SDL/docs/man3/SDL_AudioSpec.3 new file mode 100644 index 0000000000..c70ffd1735 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_AudioSpec.3 @@ -0,0 +1,70 @@ +.TH "SDL_AudioSpec" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_AudioSpec \- Audio Specification Structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + int freq; + Uint16 format; + Uint8 channels; + Uint8 silence; + Uint16 samples; + Uint32 size; + void (*callback)(void *userdata, Uint8 *stream, int len); + void *userdata; +} SDL_AudioSpec;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBfreq\fR +Audio frequency in samples per second +.TP 20 +\fBformat\fR +Audio data format +.TP 20 +\fBchannels\fR +Number of channels: 1 mono, 2 stereo +.TP 20 +\fBsilence\fR +Audio buffer silence value (calculated) +.TP 20 +\fBsamples\fR +Audio buffer size in samples +.TP 20 +\fBsize\fR +Audio buffer size in bytes (calculated) +.TP 20 +\fBcallback(\&.\&.)\fR +Callback function for filling the audio buffer +.TP 20 +\fBuserdata\fR +Pointer the user data which is passed to the callback function +.SH "DESCRIPTION" +.PP +The \fBSDL_AudioSpec\fR structure is used to describe the format of some audio data\&. This structure is used by \fI\fBSDL_OpenAudio\fP\fR and \fI\fBSDL_LoadWAV\fP\fR\&. While all fields are used by \fBSDL_OpenAudio\fP only \fBfreq\fR, \fBformat\fR, \fBsamples\fR and \fBchannels\fR are used by \fBSDL_LoadWAV\fP\&. We will detail these common members here\&. +.TP 20 +\fBfreq\fR +The number of samples sent to the sound device every second\&. Common values are 11025, 22050 and 44100\&. The higher the better\&. +.TP 20 +\fBformat\fR +Specifies the size and type of each sample element +.IP "\fBAUDIO_U8\fP" 10Unsigned 8-bit samples +.IP "\fBAUDIO_S8\fP" 10Signed 8-bit samples +.IP "\fBAUDIO_U16\fP or \fBAUDIO_U16LSB\fP" 10Unsigned 16-bit little-endian samples +.IP "\fBAUDIO_S16\fP or \fBAUDIO_S16LSB\fP" 10Signed 16-bit little-endian samples +.IP "\fBAUDIO_U16MSB\fP" 10Unsigned 16-bit big-endian samples +.IP "\fBAUDIO_S16MSB\fP" 10Signed 16-bit big-endian samples +.IP "\fBAUDIO_U16SYS\fP" 10Either \fBAUDIO_U16LSB\fP or \fBAUDIO_U16MSB\fP depending on you systems endianness +.IP "\fBAUDIO_S16SYS\fP" 10Either \fBAUDIO_S16LSB\fP or \fBAUDIO_S16MSB\fP depending on you systems endianness +.TP 20 +\fBchannels\fR +The number of seperate sound channels\&. 1 is mono (single channel), 2 is stereo (dual channel)\&. +.TP 20 +\fBsamples\fR +When used with \fI\fBSDL_OpenAudio\fP\fR this refers to the size of the audio buffer in samples\&. A sample a chunk of audio data of the size specified in \fBformat\fR mulitplied by the number of channels\&. When the \fBSDL_AudioSpec\fR is used with \fI\fBSDL_LoadWAV\fP\fR \fBsamples\fR is set to 4096\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_OpenAudio\fP\fR, \fI\fBSDL_LoadWAV\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_BlitSurface.3 b/Externals/SDL/docs/man3/SDL_BlitSurface.3 new file mode 100644 index 0000000000..5f62ffb4bb --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_BlitSurface.3 @@ -0,0 +1,60 @@ +.TH "SDL_BlitSurface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_BlitSurface \- This performs a fast blit from the source surface to the destination surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_BlitSurface\fP\fR(\fBSDL_Surface *src, SDL_Rect *srcrect, SDL_Surface *dst, SDL_Rect *dstrect\fR); +.SH "DESCRIPTION" +.PP +This performs a fast blit from the source surface to the destination surface\&. +.PP +Only the position is used in the \fBdstrect\fR (the width and height are ignored)\&. +.PP +If either \fBsrcrect\fR or \fBdstrect\fR are \fBNULL\fP, the entire surface (\fBsrc\fR or \fBdst\fR) is copied\&. +.PP +The final blit rectangle is saved in \fBdstrect\fR after all clipping is performed (\fBsrcrect\fR is not modified)\&. +.PP +The blit function should not be called on a locked surface\&. +.PP +The results of blitting operations vary greatly depending on whether \fBSDL_SRCAPLHA\fP is set or not\&. See \fISDL_SetAlpha\fR for an explaination of how this affects your results\&. Colorkeying and alpha attributes also interact with surface blitting, as the following pseudo-code should hopefully explain\&. +.PP +.nf +\f(CWif (source surface has SDL_SRCALPHA set) { + if (source surface has alpha channel (that is, format->Amask != 0)) + blit using per-pixel alpha, ignoring any colour key + else { + if (source surface has SDL_SRCCOLORKEY set) + blit using the colour key AND the per-surface alpha value + else + blit using the per-surface alpha value + } +} else { + if (source surface has SDL_SRCCOLORKEY set) + blit using the colour key + else + ordinary opaque rectangular blit +}\fR +.fi +.PP +.SH "RETURN VALUE" +.PP +If the blit is successful, it returns \fB0\fR, otherwise it returns \fB-1\fR\&. +.PP +If either of the surfaces were in video memory, and the blit returns \fB-2\fR, the video memory was lost, so it should be reloaded with artwork and re-blitted: +.PP +.nf +\f(CW while ( SDL_BlitSurface(image, imgrect, screen, dstrect) == -2 ) { + while ( SDL_LockSurface(image)) < 0 ) + Sleep(10); + -- Write image pixels to image->pixels -- + SDL_UnlockSurface(image); + }\fR +.fi +.PP + This happens under DirectX 5\&.0 when the system switches away from your fullscreen application\&. Locking the surface will also fail until you have access to the video memory again\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_LockSurface\fP\fR, \fI\fBSDL_FillRect\fP\fR, \fI\fBSDL_Surface\fR\fR, \fI\fBSDL_Rect\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_BuildAudioCVT.3 b/Externals/SDL/docs/man3/SDL_BuildAudioCVT.3 new file mode 100644 index 0000000000..dfca664a8b --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_BuildAudioCVT.3 @@ -0,0 +1,23 @@ +.TH "SDL_BuildAudioCVT" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_BuildAudioCVT \- Initializes a SDL_AudioCVT structure for conversion +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_BuildAudioCVT\fP\fR(\fBSDL_AudioCVT *cvt, Uint16 src_format, Uint8 src_channels, int src_rate, Uint16 dst_format, Uint8 dst_channels, int dst_rate\fR); +.SH "DESCRIPTION" +.PP +Before an \fI\fBSDL_AudioCVT\fR\fR structure can be used to convert audio data it must be initialized with source and destination information\&. +.PP +\fBsrc_format\fR and \fBdst_format\fR are the source and destination format of the conversion\&. (For information on audio formats see \fI\fB SDL_AudioSpec\fR\fR)\&. \fBsrc_channels\fR and \fBdst_channels\fR are the number of channels in the source and destination formats\&. Finally, \fBsrc_rate\fR and \fBdst_rate\fR are the frequency or samples-per-second of the source and destination formats\&. Once again, see \fI\fBSDL_AudioSpec\fR\fR\&. +.SH "RETURN VALUES" +.PP +Returns \fB-1\fR if the filter could not be built or 1 if it could\&. +.SH "EXAMPLES" +.PP +See \fI\fBSDL_ConvertAudio\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_ConvertAudio\fP\fR, \fI\fBSDL_AudioCVT\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CD.3 b/Externals/SDL/docs/man3/SDL_CD.3 new file mode 100644 index 0000000000..ea218186a0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CD.3 @@ -0,0 +1,57 @@ +.TH "SDL_CD" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CD \- CDROM Drive Information +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + int id; + CDstatus status; + int numtracks; + int cur_track; + int cur_frame; + SDL_CDtrack track[SDL_MAX_TRACKS+1]; +} SDL_CD;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBid\fR +Private drive identifier +.TP 20 +\fBstatus\fR +Drive \fIstatus\fR +.TP 20 +\fBnumtracks\fR +Number of tracks on the CD +.TP 20 +\fBcur_track\fR +Current track +.TP 20 +\fBcur_frame\fR +Current frame offset within the track +.TP 20 +\fBtrack\fR[SDL_MAX_TRACKS+1] +Array of track descriptions\&. (see \fI\fBSDL_CDtrack\fR\fR) +.SH "DESCRIPTION" +.PP +An \fBSDL_CD\fR structure is returned by \fI\fBSDL_CDOpen\fP\fR\&. It represents an opened CDROM device and stores information on the layout of the tracks on the disc\&. +.PP +A frame is the base data unit of a CD\&. \fBCD_FPS\fP frames is equal to 1 second of music\&. SDL provides two macros for converting between time and frames: \fBFRAMES_TO_MSF(f, M,S,F)\fP and \fBMSF_TO_FRAMES\fP\&. +.SH "EXAMPLES" +.PP +.nf +\f(CWint min, sec, frame; +int frame_offset; + +FRAMES_TO_MSF(cdrom->cur_frame, &min, &sec, &frame); +printf("Current Position: %d minutes, %d seconds, %d frames +", min, sec, frame); + +frame_offset=MSF_TO_FRAMES(min, sec, frame);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDOpen\fP\fR, \fI\fBSDL_CDtrack\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDClose.3 b/Externals/SDL/docs/man3/SDL_CDClose.3 new file mode 100644 index 0000000000..9dd29fbab8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDClose.3 @@ -0,0 +1,15 @@ +.TH "SDL_CDClose" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDClose \- Closes a SDL_CD handle +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_CDClose\fP\fR(\fBSDL_CD *cdrom\fR); +.SH "DESCRIPTION" +.PP +Closes the given \fBcdrom\fR handle\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDOpen\fP\fR, \fI\fBSDL_CD\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDEject.3 b/Externals/SDL/docs/man3/SDL_CDEject.3 new file mode 100644 index 0000000000..2f2983d8f4 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDEject.3 @@ -0,0 +1,18 @@ +.TH "SDL_CDEject" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDEject \- Ejects a CDROM +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_CDEject\fP\fR(\fBSDL_CD *cdrom\fR); +.SH "DESCRIPTION" +.PP +Ejects the given \fBcdrom\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CD\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDName.3 b/Externals/SDL/docs/man3/SDL_CDName.3 new file mode 100644 index 0000000000..c6f62984a8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDName.3 @@ -0,0 +1,23 @@ +.TH "SDL_CDName" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDName \- Returns a human-readable, system-dependent identifier for the CD-ROM\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBconst char *\fBSDL_CDName\fP\fR(\fBint drive\fR); +.SH "DESCRIPTION" +.PP +Returns a human-readable, system-dependent identifier for the CD-ROM\&. \fBdrive\fR is the index of the drive\&. Drive indices start to 0 and end at \fBSDL_CDNumDrives()\fP-1\&. +.SH "EXAMPLES" +.PP +.IP " \(bu" 6 +"/dev/cdrom" +.IP " \(bu" 6 +"E:" +.IP " \(bu" 6 +"/dev/disk/ide/1/master" +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDNumDrives\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDNumDrives.3 b/Externals/SDL/docs/man3/SDL_CDNumDrives.3 new file mode 100644 index 0000000000..ad62b68550 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDNumDrives.3 @@ -0,0 +1,15 @@ +.TH "SDL_CDNumDrives" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDNumDrives \- Returns the number of CD-ROM drives on the system\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_CDNumDrives\fP\fR(\fBvoid\fR) +.SH "DESCRIPTION" +.PP +Returns the number of CD-ROM drives on the system\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDOpen\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDOpen.3 b/Externals/SDL/docs/man3/SDL_CDOpen.3 new file mode 100644 index 0000000000..dbf23fc2b0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDOpen.3 @@ -0,0 +1,58 @@ +.TH "SDL_CDOpen" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDOpen \- Opens a CD-ROM drive for access\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_CD *\fBSDL_CDOpen\fP\fR(\fBint drive\fR); +.SH "DESCRIPTION" +.PP +Opens a CD-ROM drive for access\&. It returns a \fI\fBSDL_CD\fR\fR structure on success, or \fBNULL\fP if the drive was invalid or busy\&. This newly opened CD-ROM becomes the default CD used when other CD functions are passed a \fBNULL\fP CD-ROM handle\&. +.PP +Drives are numbered starting with 0\&. Drive 0 is the system default CD-ROM\&. +.SH "EXAMPLES" +.PP +.nf +\f(CWSDL_CD *cdrom; +int cur_track; +int min, sec, frame; +SDL_Init(SDL_INIT_CDROM); +atexit(SDL_Quit); + +/* Check for CD drives */ +if(!SDL_CDNumDrives()){ + /* None found */ + fprintf(stderr, "No CDROM devices available +"); + exit(-1); +} + +/* Open the default drive */ +cdrom=SDL_CDOpen(0); + +/* Did if open? Check if cdrom is NULL */ +if(!cdrom){ + fprintf(stderr, "Couldn\&'t open drive: %s +", SDL_GetError()); + exit(-1); +} + +/* Print Volume info */ +printf("Name: %s +", SDL_CDName(0)); +printf("Tracks: %d +", cdrom->numtracks); +for(cur_track=0;cur_track < cdrom->numtracks; cur_track++){ + FRAMES_TO_MSF(cdrom->track[cur_track]\&.length, &min, &sec, &frame); + printf(" Track %d: Length %d:%d +", cur_track, min, sec); +} + +SDL_CDClose(cdrom);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CD\fR\fR, \fI\fBSDL_CDtrack\fR\fR, \fI\fBSDL_CDClose\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDPause.3 b/Externals/SDL/docs/man3/SDL_CDPause.3 new file mode 100644 index 0000000000..bca06c06d9 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDPause.3 @@ -0,0 +1,18 @@ +.TH "SDL_CDPause" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDPause \- Pauses a CDROM +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_CDPause\fP\fR(\fBSDL_CD *cdrom\fR); +.SH "DESCRIPTION" +.PP +Pauses play on the given \fBcdrom\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDPlay\fP\fR, \fI\fBSDL_CDResume\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDPlay.3 b/Externals/SDL/docs/man3/SDL_CDPlay.3 new file mode 100644 index 0000000000..39c25ecd65 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDPlay.3 @@ -0,0 +1,18 @@ +.TH "SDL_CDPlay" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDPlay \- Play a CD +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_CDPlay\fP\fR(\fBSDL_CD *cdrom, int start, int length\fR); +.SH "DESCRIPTION" +.PP +Plays the given \fBcdrom\fR, starting a frame \fBstart\fR for \fBlength\fR frames\&. +.SH "RETURN VALUES" +.PP +Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDPlayTracks\fP\fR, \fI\fBSDL_CDStop\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDPlayTracks.3 b/Externals/SDL/docs/man3/SDL_CDPlayTracks.3 new file mode 100644 index 0000000000..5a403b3426 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDPlayTracks.3 @@ -0,0 +1,47 @@ +.TH "SDL_CDPlayTracks" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDPlayTracks \- Play the given CD track(s) +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_CDPlayTracks\fP\fR(\fBSDL_CD *cdrom, int start_track, int start_frame, int ntracks, int nframes)\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_CDPlayTracks\fP plays the given CD starting at track \fBstart_track\fR, for \fBntracks\fR tracks\&. +.PP +\fBstart_frame\fR is the frame offset, from the beginning of the \fBstart_track\fR, at which to start\&. \fBnframes\fR is the frame offset, from the beginning of the last track (\fBstart_track\fR+\fBntracks\fR), at which to end playing\&. +.PP +\fBSDL_CDPlayTracks\fP should only be called after calling \fI\fBSDL_CDStatus\fP\fR to get track information about the CD\&. +.PP +.RS +\fBNote: +.PP +Data tracks are ignored\&. +.RE +.SH "RETURN VALUE" +.PP +Returns \fB0\fR, or \fB-1\fR if there was an error\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CW/* assuming cdrom is a previously opened device */ +/* Play the entire CD */ +if(CD_INDRIVE(SDL_CDStatus(cdrom))) + SDL_CDPlayTracks(cdrom, 0, 0, 0, 0); + +/* Play the first track */ +if(CD_INDRIVE(SDL_CDStatus(cdrom))) + SDL_CDPlayTracks(cdrom, 0, 0, 1, 0); + +/* Play first 15 seconds of the 2nd track */ +if(CD_INDRIVE(SDL_CDStatus(cdrom))) + SDL_CDPlayTracks(cdrom, 1, 0, 0, CD_FPS*15);\fR +.fi +.PP + +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDPlay\fP\fR, \fI\fBSDL_CDStatus\fP\fR, \fI\fBSDL_CD\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDResume.3 b/Externals/SDL/docs/man3/SDL_CDResume.3 new file mode 100644 index 0000000000..86f6c2df35 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDResume.3 @@ -0,0 +1,18 @@ +.TH "SDL_CDResume" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDResume \- Resumes a CDROM +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_CDResume\fP\fR(\fBSDL_CD *cdrom\fR); +.SH "DESCRIPTION" +.PP +Resumes play on the given \fBcdrom\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDPlay\fP\fR, \fI\fBSDL_CDPause\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDStatus.3 b/Externals/SDL/docs/man3/SDL_CDStatus.3 new file mode 100644 index 0000000000..77eed7263f --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDStatus.3 @@ -0,0 +1,59 @@ +.TH "SDL_CDStatus" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDStatus \- Returns the current status of the given drive\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBCDstatus \fBSDL_CDStatus\fP\fR(\fBSDL_CD *cdrom\fR); +\fB/* Given a status, returns true if there\&'s a disk in the drive */ +#define CD_INDRIVE(status) ((int)status > 0) +.SH "DESCRIPTION" +.PP +This function returns the current status of the given drive\&. Status is described like so: +.PP +.nf +\f(CWtypedef enum { + CD_TRAYEMPTY, + CD_STOPPED, + CD_PLAYING, + CD_PAUSED, + CD_ERROR = -1 +} CDstatus;\fR +.fi +.PP +.PP +If the drive has a CD in it, the table of contents of the CD and current play position of the CD will be stored in the SDL_CD structure\&. +.PP +The macro \fBCD_INDRIVE\fP is provided for convenience, and given a status returns true if there\&'s a disk in the drive\&. +.PP +.RS +\fBNote: +.PP +\fBSDL_CDStatus\fP also updates the \fI\fBSDL_CD\fR\fR structure passed to it\&. +.RE +.SH "EXAMPLE" +.PP +.nf +\f(CWint playTrack(int track) +{ + int playing = 0; + + if ( CD_INDRIVE(SDL_CDStatus(cdrom)) ) { + /* clamp to the actual number of tracks on the CD */ + if (track >= cdrom->numtracks) { + track = cdrom->numtracks-1; + } + + if ( SDL_CDPlayTracks(cdrom, track, 0, 1, 0) == 0 ) { + playing = 1; + } + } + return playing; +}\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CD\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_CDStop.3 b/Externals/SDL/docs/man3/SDL_CDStop.3 new file mode 100644 index 0000000000..61e2b23d40 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDStop.3 @@ -0,0 +1,18 @@ +.TH "SDL_CDStop" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDStop \- Stops a CDROM +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_CDStop\fP\fR(\fBSDL_CD *cdrom\fR); +.SH "DESCRIPTION" +.PP +Stops play on the given \fBcdrom\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CDPlay\fP\fR, +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_CDtrack.3 b/Externals/SDL/docs/man3/SDL_CDtrack.3 new file mode 100644 index 0000000000..fdac6eeae2 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CDtrack.3 @@ -0,0 +1,40 @@ +.TH "SDL_CDtrack" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CDtrack \- CD Track Information Structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 id; + Uint8 type; + Uint32 length; + Uint32 offset; +} SDL_CDtrack;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBid\fR +Track number (0-99) +.TP 20 +\fBtype\fR +\fBSDL_AUDIO_TRACK\fP or \fBSDL_DATA_TRACK\fP +.TP 20 +\fBlength\fR +Length, in frames, of this track +.TP 20 +\fBoffset\fR +Frame offset to the beginning of this track +.SH "DESCRIPTION" +.PP +\fBSDL_CDtrack\fR stores data on each track on a CD, its fields should be pretty self explainatory\&. It is a member a the \fI\fBSDL_CD\fR\fR structure\&. +.PP +.RS +\fBNote: +.PP +Frames can be converted to standard timings\&. There are \fBCD_FPS\fP frames per second, so \fBSDL_CDtrack\fR\&.\fBlength\fR/\fBCD_FPS\fP=length_in_seconds\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_CD\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_CloseAudio.3 b/Externals/SDL/docs/man3/SDL_CloseAudio.3 new file mode 100644 index 0000000000..85ff1a4241 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CloseAudio.3 @@ -0,0 +1,15 @@ +.TH "SDL_CloseAudio" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CloseAudio \- Shuts down audio processing and closes the audio device\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_CloseAudio\fP\fR(\fBvoid\fR) +.SH "DESCRIPTION" +.PP +This function shuts down audio processing and closes the audio device\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_OpenAudio\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_Color.3 b/Externals/SDL/docs/man3/SDL_Color.3 new file mode 100644 index 0000000000..e96ee8ae5b --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Color.3 @@ -0,0 +1,34 @@ +.TH "SDL_Color" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Color \- Format independent color description +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 r; + Uint8 g; + Uint8 b; + Uint8 unused; +} SDL_Color;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBr\fR +Red intensity +.TP 20 +\fBg\fR +Green intensity +.TP 20 +\fBb\fR +Blue intensity +.TP 20 +\fBunused\fR +Unused +.SH "DESCRIPTION" +.PP +\fBSDL_Color\fR describes a color in a format independent way\&. You can convert a \fBSDL_Color\fR to a pixel value for a certain pixel format using \fI\fBSDL_MapRGB\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_PixelFormat\fR\fR, \fI\fBSDL_SetColors\fP\fR, \fI\fBSDL_Palette\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_CondBroadcast.3 b/Externals/SDL/docs/man3/SDL_CondBroadcast.3 new file mode 100644 index 0000000000..efc50b90b1 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CondBroadcast.3 @@ -0,0 +1,16 @@ +.TH "SDL_CondBroadcast" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CondBroadcast \- Restart all threads waiting on a condition variable +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_CondBroadcast\fP\fR(\fBSDL_cond *cond\fR); +.SH "DESCRIPTION" +.PP +Restarts all threads that are waiting on the condition variable, \fBcond\fR\&. Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CondSignal\fP\fR, \fI\fBSDL_CondWait\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_CondSignal.3 b/Externals/SDL/docs/man3/SDL_CondSignal.3 new file mode 100644 index 0000000000..b09c875438 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CondSignal.3 @@ -0,0 +1,16 @@ +.TH "SDL_CondSignal" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CondSignal \- Restart a thread wait on a condition variable +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_CondSignal\fP\fR(\fBSDL_cond *cond\fR); +.SH "DESCRIPTION" +.PP +Restart one of the threads that are waiting on the condition variable, \fBcond\fR\&. Returns \fB0\fR on success of \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CondWait\fP\fR, \fI\fBSDL_CondBroadcast\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_CondWait.3 b/Externals/SDL/docs/man3/SDL_CondWait.3 new file mode 100644 index 0000000000..642f512bb9 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CondWait.3 @@ -0,0 +1,16 @@ +.TH "SDL_CondWait" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CondWait \- Wait on a condition variable +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_CondWait\fP\fR(\fBSDL_cond *cond, SDL_mutex *mut\fR); +.SH "DESCRIPTION" +.PP +Wait on the condition variable \fBcond\fR and unlock the provided mutex\&. The mutex must the locked before entering this function\&. Returns \fB0\fR when it is signalled, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CondWaitTimeout\fP\fR, \fI\fBSDL_CondSignal\fP\fR, \fI\fBSDL_mutexP\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_CondWaitTimeout.3 b/Externals/SDL/docs/man3/SDL_CondWaitTimeout.3 new file mode 100644 index 0000000000..7b3424db15 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CondWaitTimeout.3 @@ -0,0 +1,16 @@ +.TH "SDL_CondWaitTimeout" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CondWaitTimeout \- Wait on a condition variable, with timeout +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_CondWaitTimeout\fP\fR(\fBSDL_cond *cond, SDL_mutex *mutex, Uint32 ms\fR); +.SH "DESCRIPTION" +.PP +Wait on the condition variable \fBcond\fR for, at most, \fBms\fR milliseconds\&. \fBmut\fR is unlocked so it must be locked when the function is called\&. Returns \fBSDL_MUTEX_TIMEDOUT\fP if the condition is not signalled in the allotted time, \fB0\fR if it was signalled or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CondWait\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_ConvertAudio.3 b/Externals/SDL/docs/man3/SDL_ConvertAudio.3 new file mode 100644 index 0000000000..73ef974f8e --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ConvertAudio.3 @@ -0,0 +1,95 @@ +.TH "SDL_ConvertAudio" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ConvertAudio \- Convert audio data to a desired audio format\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_ConvertAudio\fP\fR(\fBSDL_AudioCVT *cvt\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_ConvertAudio\fP takes one parameter, \fBcvt\fR, which was previously initilized\&. Initilizing a \fI\fBSDL_AudioCVT\fR\fR is a two step process\&. First of all, the structure must be passed to \fI\fBSDL_BuildAudioCVT\fP\fR along with source and destination format parameters\&. Secondly, the \fBcvt\fR->\fBbuf\fR and \fBcvt\fR->\fBlen\fR fields must be setup\&. \fBcvt\fR->\fBbuf\fR should point to the audio data and \fBcvt\fR->\fBlen\fR should be set to the length of the audio data in bytes\&. Remember, the length of the buffer pointed to by \fBbuf\fR show be \fBlen\fR*\fBlen_mult\fR bytes in length\&. +.PP +Once the \fBSDL_AudioCVT\fRstructure is initilized then we can pass it to \fBSDL_ConvertAudio\fP, which will convert the audio data pointer to by \fBcvt\fR->\fBbuf\fR\&. If \fBSDL_ConvertAudio\fP returned \fB0\fR then the conversion was completed successfully, otherwise \fB-1\fR is returned\&. +.PP +If the conversion completed successfully then the converted audio data can be read from \fBcvt\fR->\fBbuf\fR\&. The amount of valid, converted, audio data in the buffer is equal to \fBcvt\fR->\fBlen\fR*\fBcvt\fR->\fBlen_ratio\fR\&. +.SH "EXAMPLES" +.PP +.nf +\f(CW/* Converting some WAV data to hardware format */ +void my_audio_callback(void *userdata, Uint8 *stream, int len); + +SDL_AudioSpec *desired, *obtained; +SDL_AudioSpec wav_spec; +SDL_AudioCVT wav_cvt; +Uint32 wav_len; +Uint8 *wav_buf; +int ret; + +/* Allocated audio specs */ +desired=(SDL_AudioSpec *)malloc(sizeof(SDL_AudioSpec)); +obtained=(SDL_AudioSpec *)malloc(sizeof(SDL_AudioSpec)); + +/* Set desired format */ +desired->freq=22050; +desired->format=AUDIO_S16LSB; +desired->samples=8192; +desired->callback=my_audio_callback; +desired->userdata=NULL; + +/* Open the audio device */ +if ( SDL_OpenAudio(desired, obtained) < 0 ){ + fprintf(stderr, "Couldn\&'t open audio: %s +", SDL_GetError()); + exit(-1); +} + +free(desired); + +/* Load the test\&.wav */ +if( SDL_LoadWAV("test\&.wav", &wav_spec, &wav_buf, &wav_len) == NULL ){ + fprintf(stderr, "Could not open test\&.wav: %s +", SDL_GetError()); + SDL_CloseAudio(); + free(obtained); + exit(-1); +} + +/* Build AudioCVT */ +ret = SDL_BuildAudioCVT(&wav_cvt, + wav_spec\&.format, wav_spec\&.channels, wav_spec\&.freq, + obtained->format, obtained->channels, obtained->freq); + +/* Check that the convert was built */ +if(ret==-1){ + fprintf(stderr, "Couldn\&'t build converter! +"); + SDL_CloseAudio(); + free(obtained); + SDL_FreeWAV(wav_buf); +} + +/* Setup for conversion */ +wav_cvt\&.buf=(Uint8 *)malloc(wav_len*wav_cvt\&.len_mult); +wav_cvt\&.len=wav_len; +memcpy(wav_cvt\&.buf, wav_buf, wav_len); + +/* We can delete to original WAV data now */ +SDL_FreeWAV(wav_buf); + +/* And now we\&'re ready to convert */ +SDL_ConvertAudio(&wav_cvt); + +/* do whatever */ +\&. +\&. +\&. +\&. + +\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_BuildAudioCVT\fP\fR, \fI\fBSDL_AudioCVT\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_ConvertSurface.3 b/Externals/SDL/docs/man3/SDL_ConvertSurface.3 new file mode 100644 index 0000000000..cb24e34109 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ConvertSurface.3 @@ -0,0 +1,24 @@ +.TH "SDL_ConvertSurface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ConvertSurface \- Converts a surface to the same format as another surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL/SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_ConvertSurface\fP\fR(\fBSDL_Surface *src, SDL_PixelFormat *fmt, Uint32 flags\fR); +.SH "DESCRIPTION" +.PP +Creates a new surface of the specified format, and then copies and maps the given surface to it\&. If this function fails, it returns \fBNULL\fP\&. +.PP +The \fBflags\fR parameter is passed to \fI\fBSDL_CreateRGBSurface\fP\fR and has those semantics\&. +.PP +This function is used internally by \fI\fBSDL_DisplayFormat\fP\fR\&. +.PP +This function can only be called after SDL_Init\&. +.SH "RETURN VALUE" +.PP +Returns either a pointer to the new surface, or \fBNULL\fP on error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateRGBSurface\fP\fR, \fI\fBSDL_DisplayFormat\fP\fR, \fI\fBSDL_PixelFormat\fR\fR, \fI\fBSDL_Surface\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_CreateCond.3 b/Externals/SDL/docs/man3/SDL_CreateCond.3 new file mode 100644 index 0000000000..e8c289670f --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateCond.3 @@ -0,0 +1,31 @@ +.TH "SDL_CreateCond" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateCond \- Create a condition variable +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBSDL_cond *\fBSDL_CreateCond\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +Creates a condition variable\&. +.SH "EXAMPLES" +.PP +.nf +\f(CWSDL_cond *cond; + +cond=SDL_CreateCond(); +\&. +\&. +/* Do stuff */ + +\&. +\&. +SDL_DestroyCond(cond);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_DestroyCond\fP\fR, \fI\fBSDL_CondWait\fP\fR, \fI\fBSDL_CondSignal\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_CreateCursor.3 b/Externals/SDL/docs/man3/SDL_CreateCursor.3 new file mode 100644 index 0000000000..ef205c3d84 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateCursor.3 @@ -0,0 +1,120 @@ +.TH "SDL_CreateCursor" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateCursor \- Creates a new mouse cursor\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Cursor *\fBSDL_CreateCursor\fP\fR(\fBUint8 *data, Uint8 *mask, int w, int h, int hot_x, int hot_y\fR); +.SH "DESCRIPTION" +.PP +Create a cursor using the specified \fBdata\fR and \fBmask\fR (in MSB format)\&. The cursor width must be a multiple of 8 bits\&. +.PP +The cursor is created in black and white according to the following: +.TP 20 +\fBData / Mask\fR +\fBResulting pixel on screen\fR +.TP 20 +0 / 1 +White +.TP 20 +1 / 1 +Black +.TP 20 +0 / 0 +Transparent +.TP 20 +1 / 0 +Inverted color if possible, black if not\&. +.PP +Cursors created with this function must be freed with \fISDL_FreeCursor\fR\&. +.SH "EXAMPLE" +.PP +.nf +\f(CW/* Stolen from the mailing list */ +/* Creates a new mouse cursor from an XPM */ + + +/* XPM */ +static const char *arrow[] = { + /* width height num_colors chars_per_pixel */ + " 32 32 3 1", + /* colors */ + "X c #000000", + "\&. c #ffffff", + " c None", + /* pixels */ + "X ", + "XX ", + "X\&.X ", + "X\&.\&.X ", + "X\&.\&.\&.X ", + "X\&.\&.\&.\&.X ", + "X\&.\&.\&.\&.\&.X ", + "X\&.\&.\&.\&.\&.\&.X ", + "X\&.\&.\&.\&.\&.\&.\&.X ", + "X\&.\&.\&.\&.\&.\&.\&.\&.X ", + "X\&.\&.\&.\&.\&.XXXXX ", + "X\&.\&.X\&.\&.X ", + "X\&.X X\&.\&.X ", + "XX X\&.\&.X ", + "X X\&.\&.X ", + " X\&.\&.X ", + " X\&.\&.X ", + " X\&.\&.X ", + " XX ", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + "0,0" +}; + +static SDL_Cursor *init_system_cursor(const char *image[]) +{ + int i, row, col; + Uint8 data[4*32]; + Uint8 mask[4*32]; + int hot_x, hot_y; + + i = -1; + for ( row=0; row<32; ++row ) { + for ( col=0; col<32; ++col ) { + if ( col % 8 ) { + data[i] <<= 1; + mask[i] <<= 1; + } else { + ++i; + data[i] = mask[i] = 0; + } + switch (image[4+row][col]) { + case \&'X\&': + data[i] |= 0x01; + k[i] |= 0x01; + break; + case \&'\&.\&': + mask[i] |= 0x01; + break; + case \&' \&': + break; + } + } + } + sscanf(image[4+row], "%d,%d", &hot_x, &hot_y); + return SDL_CreateCursor(data, mask, 32, 32, hot_x, hot_y); +}\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_FreeCursor\fP\fR, \fI\fBSDL_SetCursor\fP\fR, \fI\fBSDL_ShowCursor\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_CreateMutex.3 b/Externals/SDL/docs/man3/SDL_CreateMutex.3 new file mode 100644 index 0000000000..c665e1ce78 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateMutex.3 @@ -0,0 +1,43 @@ +.TH "SDL_CreateMutex" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateMutex \- Create a mutex +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBSDL_mutex *\fBSDL_CreateMutex\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +Create a new, unlocked mutex\&. +.SH "EXAMPLES" +.PP +.nf +\f(CWSDL_mutex *mut; + +mut=SDL_CreateMutex(); +\&. +\&. +if(SDL_mutexP(mut)==-1){ + fprintf(stderr, "Couldn\&'t lock mutex +"); + exit(-1); +} +\&. +/* Do stuff while mutex is locked */ +\&. +\&. +if(SDL_mutexV(mut)==-1){ + fprintf(stderr, "Couldn\&'t unlock mutex +"); + exit(-1); +} + +SDL_DestroyMutex(mut); +\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_mutexP\fP\fR, \fI\fBSDL_mutexV\fP\fR, \fI\fBSDL_DestroyMutex\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_CreateRGBSurface.3 b/Externals/SDL/docs/man3/SDL_CreateRGBSurface.3 new file mode 100644 index 0000000000..142b7b7b7c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateRGBSurface.3 @@ -0,0 +1,69 @@ +.TH "SDL_CreateRGBSurface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateRGBSurface \- Create an empty SDL_Surface +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_CreateRGBSurface\fP\fR(\fBUint32 flags, int width, int height, int depth, Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask\fR); +.SH "DESCRIPTION" +.PP +Allocate an empty surface (must be called after \fISDL_SetVideoMode\fR) +.PP +If \fBdepth\fR is 8 bits an empty palette is allocated for the surface, otherwise a \&'packed-pixel\&' \fI\fBSDL_PixelFormat\fR\fR is created using the \fB[RGBA]mask\fR\&'s provided (see \fI\fBSDL_PixelFormat\fR\fR)\&. The \fBflags\fR specifies the type of surface that should be created, it is an OR\&'d combination of the following possible values\&. +.TP 20 +\fBSDL_SWSURFACE\fP +SDL will create the surface in system memory\&. This improves the performance of pixel level access, however you may not be able to take advantage of some types of hardware blitting\&. +.TP 20 +\fBSDL_HWSURFACE\fP +SDL will attempt to create the surface in video memory\&. This will allow SDL to take advantage of Video->Video blits (which are often accelerated)\&. +.TP 20 +\fBSDL_SRCCOLORKEY\fP +This flag turns on colourkeying for blits from this surface\&. If \fBSDL_HWSURFACE\fP is also specified and colourkeyed blits are hardware-accelerated, then SDL will attempt to place the surface in video memory\&. Use \fI\fBSDL_SetColorKey\fP\fR to set or clear this flag after surface creation\&. +.TP 20 +\fBSDL_SRCALPHA\fP +This flag turns on alpha-blending for blits from this surface\&. If \fBSDL_HWSURFACE\fP is also specified and alpha-blending blits are hardware-accelerated, then the surface will be placed in video memory if possible\&. Use \fI\fBSDL_SetAlpha\fP\fR to set or clear this flag after surface creation\&. +.PP +.RS +\fBNote: +.PP +If an alpha-channel is specified (that is, if \fBAmask\fR is nonzero), then the \fBSDL_SRCALPHA\fP flag is automatically set\&. You may remove this flag by calling \fI\fBSDL_SetAlpha\fP\fR after surface creation\&. +.RE +.SH "RETURN VALUE" +.PP +Returns the created surface, or \fBNULL\fR upon error\&. +.SH "EXAMPLE" +.PP +.nf +\f(CW /* Create a 32-bit surface with the bytes of each pixel in R,G,B,A order, + as expected by OpenGL for textures */ + SDL_Surface *surface; + Uint32 rmask, gmask, bmask, amask; + + /* SDL interprets each pixel as a 32-bit number, so our masks must depend + on the endianness (byte order) of the machine */ +#if SDL_BYTEORDER == SDL_BIG_ENDIAN + rmask = 0xff000000; + gmask = 0x00ff0000; + bmask = 0x0000ff00; + amask = 0x000000ff; +#else + rmask = 0x000000ff; + gmask = 0x0000ff00; + bmask = 0x00ff0000; + amask = 0xff000000; +#endif + + surface = SDL_CreateRGBSurface(SDL_SWSURFACE, width, height, 32, + rmask, gmask, bmask, amask); + if(surface == NULL) { + fprintf(stderr, "CreateRGBSurface failed: %s +", SDL_GetError()); + exit(1); + }\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateRGBSurfaceFrom\fP\fR, \fI\fBSDL_FreeSurface\fP\fR, \fI\fBSDL_SetVideoMode\fP\fR, \fI\fBSDL_LockSurface\fP\fR, \fI\fBSDL_PixelFormat\fR\fR, \fI\fBSDL_Surface\fR\fR \fI\fBSDL_SetAlpha\fP\fR \fI\fBSDL_SetColorKey\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_CreateRGBSurfaceFrom.3 b/Externals/SDL/docs/man3/SDL_CreateRGBSurfaceFrom.3 new file mode 100644 index 0000000000..5330c1b2b0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateRGBSurfaceFrom.3 @@ -0,0 +1,22 @@ +.TH "SDL_CreateRGBSurfaceFrom" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateRGBSurfaceFrom \- Create an SDL_Surface from pixel data +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_CreateRGBSurfaceFrom\fP\fR(\fBvoid *pixels, int width, int height, int depth, int pitch, Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask\fR); +.SH "DESCRIPTION" +.PP +Creates an SDL_Surface from the provided pixel data\&. +.PP +The data stored in \fBpixels\fR is assumed to be of the \fBdepth\fR specified in the parameter list\&. The pixel data is not copied into the \fBSDL_Surface\fR structure so it should not be freed until the surface has been freed with a called to \fISDL_FreeSurface\fR\&. \fBpitch\fR is the length of each scanline in bytes\&. +.PP +See \fI\fBSDL_CreateRGBSurface\fP\fR for a more detailed description of the other parameters\&. +.SH "RETURN VALUE" +.PP +Returns the created surface, or \fBNULL\fR upon error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateRGBSurface\fP\fR, \fI\fBSDL_FreeSurface\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_CreateSemaphore.3 b/Externals/SDL/docs/man3/SDL_CreateSemaphore.3 new file mode 100644 index 0000000000..b803ead79d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateSemaphore.3 @@ -0,0 +1,32 @@ +.TH "SDL_CreateSemaphore" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateSemaphore \- Creates a new semaphore and assigns an initial value to it\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBSDL_sem *\fBSDL_CreateSemaphore\fP\fR(\fBUint32 initial_value\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_CreateSemaphore()\fP creates a new semaphore and initializes it with the value \fBinitial_value\fR\&. Each locking operation on the semaphore by \fISDL_SemWait\fR, \fISDL_SemTryWait\fR or \fISDL_SemWaitTimeout\fR will atomically decrement the semaphore value\&. The locking operation will be blocked if the semaphore value is not positive (greater than zero)\&. Each unlock operation by \fISDL_SemPost\fR will atomically increment the semaphore value\&. +.SH "RETURN VALUE" +.PP +Returns a pointer to an initialized semaphore or \fBNULL\fR if there was an error\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWSDL_sem *my_sem; + +my_sem = SDL_CreateSemaphore(INITIAL_SEM_VALUE); + +if (my_sem == NULL) { + return CREATE_SEM_FAILED; +}\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_DestroySemaphore\fP\fR, \fI\fBSDL_SemWait\fP\fR, \fI\fBSDL_SemTryWait\fP\fR, \fI\fBSDL_SemWaitTimeout\fP\fR, \fI\fBSDL_SemPost\fP\fR, \fI\fBSDL_SemValue\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_CreateThread.3 b/Externals/SDL/docs/man3/SDL_CreateThread.3 new file mode 100644 index 0000000000..ab9e79ff8d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateThread.3 @@ -0,0 +1,16 @@ +.TH "SDL_CreateThread" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateThread \- Creates a new thread of execution that shares its parent\&'s properties\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBSDL_Thread *\fBSDL_CreateThread\fP\fR(\fBint (*fn)(void *), void *data\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_CreateThread\fP creates a new thread of execution that shares all of its parent\&'s global memory, signal handlers, file descriptors, etc, and runs the function \fBfn\fR passed the void pointer \fBdata\fR The thread quits when this function returns\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_KillThread\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_CreateYUVOverlay.3 b/Externals/SDL/docs/man3/SDL_CreateYUVOverlay.3 new file mode 100644 index 0000000000..fda6bc89a8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_CreateYUVOverlay.3 @@ -0,0 +1,17 @@ +.TH "SDL_CreateYUVOverlay" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_CreateYUVOverlay \- Create a YUV video overlay +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Overlay *\fBSDL_CreateYUVOverlay\fP\fR(\fBint width, int height, Uint32 format, SDL_Surface *display\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_CreateYUVOverlay\fP creates a YUV overlay of the specified \fBwidth\fR, \fBheight\fR and \fBformat\fR (see \fI\fBSDL_Overlay\fR\fR for a list of available formats), for the provided \fBdisplay\fR\&. A \fI\fBSDL_Overlay\fR\fR structure is returned\&. +.PP +The term \&'overlay\&' is a misnomer since, unless the overlay is created in hardware, the contents for the display surface underneath the area where the overlay is shown will be overwritten when the overlay is displayed\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Overlay\fR\fR, \fI\fBSDL_DisplayYUVOverlay\fP\fR, \fI\fBSDL_FreeYUVOverlay\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_Delay.3 b/Externals/SDL/docs/man3/SDL_Delay.3 new file mode 100644 index 0000000000..bfa80b151d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Delay.3 @@ -0,0 +1,21 @@ +.TH "SDL_Delay" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Delay \- Wait a specified number of milliseconds before returning\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_Delay\fP\fR(\fBUint32 ms\fR); +.SH "DESCRIPTION" +.PP +Wait a specified number of milliseconds before returning\&. \fBSDL_Delay\fP will wait at \fIleast\fP the specified time, but possible longer due to OS scheduling\&. +.PP +.RS +\fBNote: +.PP +Count on a delay granularity of \fIat least\fP 10 ms\&. Some platforms have shorter clock ticks but this is the most common\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_AddTimer\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_DestroyCond.3 b/Externals/SDL/docs/man3/SDL_DestroyCond.3 new file mode 100644 index 0000000000..308b9d0696 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_DestroyCond.3 @@ -0,0 +1,16 @@ +.TH "SDL_DestroyCond" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_DestroyCond \- Destroy a condition variable +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBvoid \fBSDL_DestroyCond\fP\fR(\fBSDL_cond *cond\fR); +.SH "DESCRIPTION" +.PP +Destroys a condition variable\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateCond\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_DestroyMutex.3 b/Externals/SDL/docs/man3/SDL_DestroyMutex.3 new file mode 100644 index 0000000000..1582e499c0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_DestroyMutex.3 @@ -0,0 +1,16 @@ +.TH "SDL_DestroyMutex" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_DestroyMutex \- Destroy a mutex +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBvoid \fBSDL_DestroyMutex\fP\fR(\fBSDL_mutex *mutex\fR); +.SH "DESCRIPTION" +.PP +Destroy a previously \fIcreated\fR mutex\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateMutex\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_DestroySemaphore.3 b/Externals/SDL/docs/man3/SDL_DestroySemaphore.3 new file mode 100644 index 0000000000..892334fecb --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_DestroySemaphore.3 @@ -0,0 +1,26 @@ +.TH "SDL_DestroySemaphore" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_DestroySemaphore \- Destroys a semaphore that was created by \fISDL_CreateSemaphore\fR\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBvoid \fBSDL_DestroySemaphore\fP\fR(\fBSDL_sem *sem\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_DestroySemaphore\fP destroys the semaphore pointed to by \fBsem\fR that was created by \fI\fBSDL_CreateSemaphore\fP\fR\&. It is not safe to destroy a semaphore if there are threads currently blocked waiting on it\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWif (my_sem != NULL) { + SDL_DestroySemaphore(my_sem); + my_sem = NULL; +}\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateSemaphore\fP\fR, \fI\fBSDL_SemWait\fP\fR, \fI\fBSDL_SemTryWait\fP\fR, \fI\fBSDL_SemWaitTimeout\fP\fR, \fI\fBSDL_SemPost\fP\fR, \fI\fBSDL_SemValue\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_DisplayFormat.3 b/Externals/SDL/docs/man3/SDL_DisplayFormat.3 new file mode 100644 index 0000000000..ca16e2a451 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_DisplayFormat.3 @@ -0,0 +1,22 @@ +.TH "SDL_DisplayFormat" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_DisplayFormat \- Convert a surface to the display format +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_DisplayFormat\fP\fR(\fBSDL_Surface *surface\fR); +.SH "DESCRIPTION" +.PP +This function takes a surface and copies it to a new surface of the pixel format and colors of the video framebuffer, suitable for fast blitting onto the display surface\&. It calls \fISDL_ConvertSurface\fR +.PP +If you want to take advantage of hardware colorkey or alpha blit acceleration, you should set the colorkey and alpha value before calling this function\&. +.PP +If you want an alpha channel, see \fISDL_DisplayFormatAlpha\fR\&. +.SH "RETURN VALUE" +.PP +If the conversion fails or runs out of memory, it returns \fBNULL\fR +.SH "SEE ALSO" +.PP +\fI\fBSDL_ConvertSurface\fP\fR, \fI\fBSDL_DisplayFormatAlpha\fP\fR \fI\fBSDL_SetAlpha\fP\fR, \fI\fBSDL_SetColorKey\fP\fR, \fI\fBSDL_Surface\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_DisplayFormatAlpha.3 b/Externals/SDL/docs/man3/SDL_DisplayFormatAlpha.3 new file mode 100644 index 0000000000..a87ddd54f1 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_DisplayFormatAlpha.3 @@ -0,0 +1,22 @@ +.TH "SDL_DisplayFormatAlpha" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_DisplayFormatAlpha \- Convert a surface to the display format +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_DisplayFormatAlpha\fP\fR(\fBSDL_Surface *surface\fR); +.SH "DESCRIPTION" +.PP +This function takes a surface and copies it to a new surface of the pixel format and colors of the video framebuffer plus an alpha channel, suitable for fast blitting onto the display surface\&. It calls \fISDL_ConvertSurface\fR +.PP +If you want to take advantage of hardware colorkey or alpha blit acceleration, you should set the colorkey and alpha value before calling this function\&. +.PP +This function can be used to convert a colourkey to an alpha channel, if the \fBSDL_SRCCOLORKEY\fP flag is set on the surface\&. The generated surface will then be transparent (alpha=0) where the pixels match the colourkey, and opaque (alpha=255) elsewhere\&. +.SH "RETURN VALUE" +.PP +If the conversion fails or runs out of memory, it returns \fBNULL\fR +.SH "SEE ALSO" +.PP +\fISDL_ConvertSurface\fR, \fISDL_SetAlpha\fR, \fISDL_SetColorKey\fR, \fISDL_DisplayFormat\fR, \fISDL_Surface\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_DisplayYUVOverlay.3 b/Externals/SDL/docs/man3/SDL_DisplayYUVOverlay.3 new file mode 100644 index 0000000000..d89d94cc37 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_DisplayYUVOverlay.3 @@ -0,0 +1,18 @@ +.TH "SDL_DisplayYUVOverlay" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_DisplayYUVOverlay \- Blit the overlay to the display +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_DisplayYUVOverlay\fP\fR(\fBSDL_Overlay *overlay, SDL_Rect *dstrect\fR); +.SH "DESCRIPTION" +.PP +Blit the \fBoverlay\fR to the surface specified when it was \fIcreated\fR\&. The \fI\fBSDL_Rect\fR\fR structure, \fBdstrect\fR, specifies the position and size of the destination\&. If the \fBdstrect\fR is a larger or smaller than the overlay then the overlay will be scaled, this is optimized for 2x scaling\&. +.SH "RETURN VALUES" +.PP +Returns 0 on success +.SH "SEE ALSO" +.PP +\fI\fBSDL_Overlay\fR\fR, \fI\fBSDL_CreateYUVOverlay\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_EnableKeyRepeat.3 b/Externals/SDL/docs/man3/SDL_EnableKeyRepeat.3 new file mode 100644 index 0000000000..ea4b231b96 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_EnableKeyRepeat.3 @@ -0,0 +1,17 @@ +.TH "SDL_EnableKeyRepeat" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_EnableKeyRepeat \- Set keyboard repeat rate\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_EnableKeyRepeat\fP\fR(\fBint delay, int interval\fR); +.SH "DESCRIPTION" +.PP +Enables or disables the keyboard repeat rate\&. \fBdelay\fR specifies how long the key must be pressed before it begins repeating, it then repeats at the speed specified by \fBinterval\fR\&. Both \fBdelay\fR and \fBinterval\fR are expressed in milliseconds\&. +.PP +Setting \fBdelay\fR to 0 disables key repeating completely\&. Good default values are \fBSDL_DEFAULT_REPEAT_DELAY\fP and \fISDL_DEFAULT_REPEAT_INTERVAL\fP\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success and \fB-1\fR on failure\&. +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_EnableUNICODE.3 b/Externals/SDL/docs/man3/SDL_EnableUNICODE.3 new file mode 100644 index 0000000000..d9d2027009 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_EnableUNICODE.3 @@ -0,0 +1,24 @@ +.TH "SDL_EnableUNICODE" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_EnableUNICODE \- Enable UNICODE translation +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_EnableUNICODE\fP\fR(\fBint enable\fR); +.SH "DESCRIPTION" +.PP +Enables/Disables Unicode keyboard translation\&. +.PP +To obtain the character codes corresponding to received keyboard events, Unicode translation must first be turned on using this function\&. The translation incurs a slight overhead for each keyboard event and is therefore disabled by default\&. For each subsequently received key down event, the \fBunicode\fR member of the \fI\fBSDL_keysym\fR\fR structure will then contain the corresponding character code, or zero for keysyms that do not correspond to any character code\&. +.PP +A value of 1 for \fBenable\fR enables Unicode translation; 0 disables it, and -1 leaves it unchanged (useful for querying the current translation mode)\&. +.PP +Note that only key press events will be translated, not release events\&. +.SH "RETURN VALUE" +.PP +Returns the previous translation mode (\fB0\fR or \fB1\fR)\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_keysym\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_Event.3 b/Externals/SDL/docs/man3/SDL_Event.3 new file mode 100644 index 0000000000..b508f19db8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Event.3 @@ -0,0 +1,182 @@ +.TH "SDL_Event" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Event \- General event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef union{ + Uint8 type; + SDL_ActiveEvent active; + SDL_KeyboardEvent key; + SDL_MouseMotionEvent motion; + SDL_MouseButtonEvent button; + SDL_JoyAxisEvent jaxis; + SDL_JoyBallEvent jball; + SDL_JoyHatEvent jhat; + SDL_JoyButtonEvent jbutton; + SDL_ResizeEvent resize; + SDL_ExposeEvent expose; + SDL_QuitEvent quit; + SDL_UserEvent user; + SDL_SysWMEvent syswm; +} SDL_Event;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +The type of event +.TP 20 +\fBactive\fR +\fIActivation event\fR +.TP 20 +\fBkey\fR +\fIKeyboard event\fR +.TP 20 +\fBmotion\fR +\fIMouse motion event\fR +.TP 20 +\fBbutton\fR +\fIMouse button event\fR +.TP 20 +\fBjaxis\fR +\fIJoystick axis motion event\fR +.TP 20 +\fBjball\fR +\fIJoystick trackball motion event\fR +.TP 20 +\fBjhat\fR +\fIJoystick hat motion event\fR +.TP 20 +\fBjbutton\fR +\fIJoystick button event\fR +.TP 20 +\fBresize\fR +\fIApplication window resize event\fR +.TP 20 +\fBexpose\fR +\fIApplication window expose event\fR +.TP 20 +\fBquit\fR +\fIApplication quit request event\fR +.TP 20 +\fBuser\fR +\fIUser defined event\fR +.TP 20 +\fBsyswm\fR +\fIUndefined window manager event\fR +.SH "DESCRIPTION" +.PP +The \fBSDL_Event\fR union is the core to all event handling is SDL, its probably the most important structure after \fBSDL_Surface\fR\&. \fBSDL_Event\fR is a union of all event structures used in SDL, using it is a simple matter of knowing which union member relates to which event \fBtype\fR\&. +.PP +.TP 20 +\fBEvent \fBtype\fR\fR +\fBEvent Structure\fR +.TP 20 +\fBSDL_ACTIVEEVENT\fP +\fI\fBSDL_ActiveEvent\fR\fR +.TP 20 +\fBSDL_KEYDOWN/UP\fP +\fI\fBSDL_KeyboardEvent\fR\fR +.TP 20 +\fBSDL_MOUSEMOTION\fP +\fI\fBSDL_MouseMotionEvent\fR\fR +.TP 20 +\fBSDL_MOUSEBUTTONDOWN/UP\fP +\fI\fBSDL_MouseButtonEvent\fR\fR +.TP 20 +\fBSDL_JOYAXISMOTION\fP +\fI\fBSDL_JoyAxisEvent\fR\fR +.TP 20 +\fBSDL_JOYBALLMOTION\fP +\fI\fBSDL_JoyBallEvent\fR\fR +.TP 20 +\fBSDL_JOYHATMOTION\fP +\fI\fBSDL_JoyHatEvent\fR\fR +.TP 20 +\fBSDL_JOYBUTTONDOWN/UP\fP +\fI\fBSDL_JoyButtonEvent\fR\fR +.TP 20 +\fBSDL_QUIT\fP +\fI\fBSDL_QuitEvent\fR\fR +.TP 20 +\fBSDL_SYSWMEVENT\fP +\fI\fBSDL_SysWMEvent\fR\fR +.TP 20 +\fBSDL_VIDEORESIZE\fP +\fI\fBSDL_ResizeEvent\fR\fR +.TP 20 +\fBSDL_VIDEOEXPOSE\fP +\fI\fBSDL_ExposeEvent\fR\fR +.TP 20 +\fBSDL_USEREVENT\fP +\fI\fBSDL_UserEvent\fR\fR +.SH "USE" +.PP +The \fBSDL_Event\fR structure has two uses +.IP " \(bu" 6 +Reading events on the event queue +.IP " \(bu" 6 +Placing events on the event queue +.PP +Reading events from the event queue is done with either \fI\fBSDL_PollEvent\fP\fR or \fI\fBSDL_PeepEvents\fP\fR\&. We\&'ll use \fBSDL_PollEvent\fP and step through an example\&. +.PP +First off, we create an empty \fBSDL_Event\fR structure\&. +.PP +.nf +\f(CWSDL_Event test_event;\fR +.fi +.PP + \fBSDL_PollEvent\fP removes the next event from the event queue, if there are no events on the queue it returns \fB0\fR otherwise it returns \fB1\fR\&. We use a \fBwhile\fP loop to process each event in turn\&. +.PP +.nf +\f(CWwhile(SDL_PollEvent(&test_event)) {\fR +.fi +.PP + The \fBSDL_PollEvent\fP function take a pointer to an \fBSDL_Event\fR structure that is to be filled with event information\&. We know that if \fBSDL_PollEvent\fP removes an event from the queue then the event information will be placed in our \fBtest_event\fR structure, but we also know that the \fItype\fP of event will be placed in the \fBtype\fR member of \fBtest_event\fR\&. So to handle each event \fBtype\fR seperately we use a \fBswitch\fP statement\&. +.PP +.nf +\f(CW switch(test_event\&.type) {\fR +.fi +.PP + We need to know what kind of events we\&'re looking for \fIand\fP the event \fBtype\fR\&'s of those events\&. So lets assume we want to detect where the user is moving the mouse pointer within our application\&. We look through our event types and notice that \fBSDL_MOUSEMOTION\fP is, more than likely, the event we\&'re looking for\&. A little \fImore\fR research tells use that \fBSDL_MOUSEMOTION\fP events are handled within the \fI\fBSDL_MouseMotionEvent\fR\fR structure which is the \fBmotion\fR member of \fBSDL_Event\fR\&. We can check for the \fBSDL_MOUSEMOTION\fP event \fBtype\fR within our \fBswitch\fP statement like so: +.PP +.nf +\f(CW case SDL_MOUSEMOTION:\fR +.fi +.PP + All we need do now is read the information out of the \fBmotion\fR member of \fBtest_event\fR\&. +.PP +.nf +\f(CW printf("We got a motion event\&. +"); + printf("Current mouse position is: (%d, %d) +", test_event\&.motion\&.x, test_event\&.motion\&.y); + break; + default: + printf("Unhandled Event! +"); + break; + } +} +printf("Event queue empty\&. +");\fR +.fi +.PP +.PP +It is also possible to push events onto the event queue and so use it as a two-way communication path\&. Both \fI\fBSDL_PushEvent\fP\fR and \fI\fBSDL_PeepEvents\fP\fR allow you to place events onto the event queue\&. This is usually used to place a \fBSDL_USEREVENT\fP on the event queue, however you could use it to post fake input events if you wished\&. Creating your own events is a simple matter of choosing the event type you want, setting the \fBtype\fR member and filling the appropriate member structure with information\&. +.PP +.nf +\f(CWSDL_Event user_event; + +user_event\&.type=SDL_USEREVENT; +user_event\&.user\&.code=2; +user_event\&.user\&.data1=NULL; +user_event\&.user\&.data2=NULL; +SDL_PushEvent(&user_event);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_PollEvent\fP\fR, \fI\fBSDL_PushEvent\fP\fR, \fI\fBSDL_PeepEvents\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_EventState.3 b/Externals/SDL/docs/man3/SDL_EventState.3 new file mode 100644 index 0000000000..5ee6ab56ad --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_EventState.3 @@ -0,0 +1,23 @@ +.TH "SDL_EventState" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_EventState \- This function allows you to set the state of processing certain events\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint8 \fBSDL_EventState\fP\fR(\fBUint8 type, int state\fR); +.SH "DESCRIPTION" +.PP +This function allows you to set the state of processing certain event \fBtype\fR\&'s\&. +.PP +If \fBstate\fR is set to \fBSDL_IGNORE\fP, that event \fBtype\fR will be automatically dropped from the event queue and will not be filtered\&. +.PP +If \fBstate\fR is set to \fBSDL_ENABLE\fP, that event \fBtype\fR will be processed normally\&. +.PP +If \fBstate\fR is set to \fBSDL_QUERY\fP, \fBSDL_EventState\fP will return the current processing state of the specified event \fBtype\fR\&. +.PP +A list of event \fBtype\fR\&'s can be found in the \fI\fBSDL_Event\fR\fR section\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_ExposeEvent.3 b/Externals/SDL/docs/man3/SDL_ExposeEvent.3 new file mode 100644 index 0000000000..e1aa5c30f8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ExposeEvent.3 @@ -0,0 +1,24 @@ +.TH "SDL_ExposeEvent" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ExposeEvent \- Quit requested event +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type +} SDL_ExposeEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_VIDEOEXPOSE\fP +.SH "DESCRIPTION" +.PP +\fBSDL_ExposeEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used whan an event of type \fBSDL_VIDEOEXPOSE\fP is reported\&. +.PP +A VIDEOEXPOSE event is triggered when the screen has been modified outside of the application, usually by the window manager and needs to be redrawn\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_SetEventFilter\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_FillRect.3 b/Externals/SDL/docs/man3/SDL_FillRect.3 new file mode 100644 index 0000000000..c2b83abaf3 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_FillRect.3 @@ -0,0 +1,22 @@ +.TH "SDL_FillRect" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_FillRect \- This function performs a fast fill of the given rectangle with some color +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_FillRect\fP\fR(\fBSDL_Surface *dst, SDL_Rect *dstrect, Uint32 color\fR); +.SH "DESCRIPTION" +.PP +This function performs a fast fill of the given rectangle with \fBcolor\fR\&. If \fBdstrect\fR is \fBNULL\fP, the whole surface will be filled with \fBcolor\fR\&. +.PP +The color should be a pixel of the format used by the surface, and can be generated by the \fISDL_MapRGB\fR or \fISDL_MapRGBA\fR functions\&. If the color value contains an alpha value then the destination is simply "filled" with that alpha information, no blending takes place\&. +.PP +If there is a clip rectangle set on the destination (set via \fISDL_SetClipRect\fR) then this function will clip based on the intersection of the clip rectangle and the \fBdstrect\fR rectangle and the dstrect rectangle will be modified to represent the area actually filled\&. +.SH "RETURN VALUE" +.PP +This function returns \fB0\fR on success, or \fB-1\fR on error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_MapRGB\fP\fR, \fI\fBSDL_MapRGBA\fP\fR, \fI\fBSDL_BlitSurface\fP\fR, \fI\fBSDL_Rect\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_Flip.3 b/Externals/SDL/docs/man3/SDL_Flip.3 new file mode 100644 index 0000000000..b3b2d65dc0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Flip.3 @@ -0,0 +1,20 @@ +.TH "SDL_Flip" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Flip \- Swaps screen buffers +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_Flip\fP\fR(\fBSDL_Surface *screen\fR); +.SH "DESCRIPTION" +.PP +On hardware that supports double-buffering, this function sets up a flip and returns\&. The hardware will wait for vertical retrace, and then swap video buffers before the next video surface blit or lock will return\&. On hardware that doesn\&'t support double-buffering, this is equivalent to calling \fISDL_UpdateRect\fR\fB(screen, 0, 0, 0, 0)\fR +.PP +The \fBSDL_DOUBLEBUF\fP flag must have been passed to \fISDL_SetVideoMode\fR, when setting the video mode for this function to perform hardware flipping\&. +.SH "RETURN VALUE" +.PP +This function returns \fB0\fR if successful, or \fB-1\fR if there was an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetVideoMode\fP\fR, \fI\fBSDL_UpdateRect\fP\fR, \fI\fBSDL_Surface\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_FreeCursor.3 b/Externals/SDL/docs/man3/SDL_FreeCursor.3 new file mode 100644 index 0000000000..22277ea496 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_FreeCursor.3 @@ -0,0 +1,15 @@ +.TH "SDL_FreeCursor" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_FreeCursor \- Frees a cursor created with SDL_CreateCursor\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_FreeCursor\fP\fR(\fBSDL_Cursor *cursor\fR); +.SH "DESCRIPTION" +.PP +Frees a \fBSDL_Cursor\fR that was created using \fISDL_CreateCursor\fR\&. +.SH "SEE ALSO" +.PP +\fISDL_CreateCursor\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_FreeSurface.3 b/Externals/SDL/docs/man3/SDL_FreeSurface.3 new file mode 100644 index 0000000000..d8491392f0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_FreeSurface.3 @@ -0,0 +1,15 @@ +.TH "SDL_FreeSurface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_FreeSurface \- Frees (deletes) a SDL_Surface +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_FreeSurface\fP\fR(\fBSDL_Surface *surface\fR); +.SH "DESCRIPTION" +.PP +Frees the resources used by a previously created \fBSDL_Surface\fR\&. If the surface was created using \fISDL_CreateRGBSurfaceFrom\fR then the pixel data is not freed\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateRGBSurface\fP\fR \fI\fBSDL_CreateRGBSurfaceFrom\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_FreeWAV.3 b/Externals/SDL/docs/man3/SDL_FreeWAV.3 new file mode 100644 index 0000000000..a7cd1483c0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_FreeWAV.3 @@ -0,0 +1,15 @@ +.TH "SDL_FreeWAV" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_FreeWAV \- Frees previously opened WAV data +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_FreeWAV\fP\fR(\fBUint8 *audio_buf\fR); +.SH "DESCRIPTION" +.PP +After a WAVE file has been opened with \fI\fBSDL_LoadWAV\fP\fR its data can eventually be freed with \fBSDL_FreeWAV\fP\&. \fBaudio_buf\fR is a pointer to the buffer created by \fBSDL_LoadWAV\fP\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_LoadWAV\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_FreeYUVOverlay.3 b/Externals/SDL/docs/man3/SDL_FreeYUVOverlay.3 new file mode 100644 index 0000000000..3971a93fda --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_FreeYUVOverlay.3 @@ -0,0 +1,15 @@ +.TH "SDL_FreeYUVOverlay" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_FreeYUVOverlay \- Free a YUV video overlay +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_FreeYUVOverlay\fP\fR(\fBSDL_Overlay *overlay\fR); +.SH "DESCRIPTION" +.PP +Frees and \fI\fBoverlay\fR\fR created by \fI\fBSDL_CreateYUVOverlay\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Overlay\fR\fR, \fI\fBSDL_DisplayYUVOverlay\fP\fR, \fI\fBSDL_FreeYUVOverlay\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GL_GetAttribute.3 b/Externals/SDL/docs/man3/SDL_GL_GetAttribute.3 new file mode 100644 index 0000000000..9135da283c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GL_GetAttribute.3 @@ -0,0 +1,18 @@ +.TH "SDL_GL_GetAttribute" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GL_GetAttribute \- Get the value of a special SDL/OpenGL attribute +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_GL_GetAttribute\fP\fR(\fBSDLGLattr attr, int *value\fR); +.SH "DESCRIPTION" +.PP +Places the value of the SDL/OpenGL \fIattribute\fR \fBattr\fR into \fBvalue\fR\&. This is useful after a call to \fI\fBSDL_SetVideoMode\fP\fR to check whether your attributes have been \fIset\fR as you expected\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GL_SetAttribute\fP\fR, \fIGL Attributes\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GL_GetProcAddress.3 b/Externals/SDL/docs/man3/SDL_GL_GetProcAddress.3 new file mode 100644 index 0000000000..4fcc7a40b5 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GL_GetProcAddress.3 @@ -0,0 +1,48 @@ +.TH "SDL_GL_GetProcAddress" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GL_GetProcAddress \- Get the address of a GL function +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid *\fBSDL_GL_GetProcAddress\fP\fR(\fBconst char* proc\fR); +.SH "DESCRIPTION" +.PP +Returns the address of the GL function \fBproc\fR, or \fBNULL\fR if the function is not found\&. If the GL library is loaded at runtime, with \fI\fBSDL_GL_LoadLibrary\fP\fR, then \fIall\fP GL functions must be retrieved this way\&. Usually this is used to retrieve function pointers to OpenGL extensions\&. +.SH "EXAMPLE" +.PP +.nf +\f(CWtypedef void (*GL_ActiveTextureARB_Func)(unsigned int); +GL_ActiveTextureARB_Func glActiveTextureARB_ptr = 0; +int has_multitexture=1; +\&. +\&. +\&. +/* Get function pointer */ +glActiveTextureARB_ptr=(GL_ActiveTextureARB_Func) SDL_GL_GetProcAddress("glActiveTextureARB"); + +/* Check for a valid function ptr */ +if(!glActiveTextureARB_ptr){ + fprintf(stderr, "Multitexture Extensions not present\&. +"); + has_multitexture=0; +} +\&. +\&. +\&. +\&. +if(has_multitexture){ + glActiveTextureARB_ptr(GL_TEXTURE0_ARB); + \&. + \&. +} +else{ + \&. + \&. +}\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_GL_LoadLibrary\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GL_LoadLibrary.3 b/Externals/SDL/docs/man3/SDL_GL_LoadLibrary.3 new file mode 100644 index 0000000000..e6544c9ca4 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GL_LoadLibrary.3 @@ -0,0 +1,15 @@ +.TH "SDL_GL_LoadLibrary" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GL_LoadLibrary \- Specify an OpenGL library +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_GL_LoadLibrary\fP\fR(\fBconst char *path\fR); +.SH "DESCRIPTION" +.PP +If you wish, you may load the OpenGL library at runtime, this must be done before \fI\fBSDL_SetVideoMode\fP\fR is called\&. The \fBpath\fR of the GL library is passed to \fBSDL_GL_LoadLibrary\fP and it returns \fB0\fR on success, or \fB-1\fR on an error\&. You must then use \fI\fBSDL_GL_GetProcAddress\fP\fR to retrieve function pointers to GL functions\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GL_GetProcAddress\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GL_SetAttribute.3 b/Externals/SDL/docs/man3/SDL_GL_SetAttribute.3 new file mode 100644 index 0000000000..deb38e71b9 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GL_SetAttribute.3 @@ -0,0 +1,40 @@ +.TH "SDL_GL_SetAttribute" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GL_SetAttribute \- Set a special SDL/OpenGL attribute +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_GL_SetAttribute\fP\fR(\fBSDL_GLattr attr, int value\fR); +.SH "DESCRIPTION" +.PP +Sets the OpenGL \fIattribute\fR \fBattr\fR to \fBvalue\fR\&. The attributes you set don\&'t take effect until after a call to \fI\fBSDL_SetVideoMode\fP\fR\&. You should use \fI\fBSDL_GL_GetAttribute\fP\fR to check the values after a \fBSDL_SetVideoMode\fP call\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success, or \fB-1\fR on error\&. +.SH "EXAMPLE" +.PP +.nf +\f(CWSDL_GL_SetAttribute( SDL_GL_RED_SIZE, 5 ); +SDL_GL_SetAttribute( SDL_GL_GREEN_SIZE, 5 ); +SDL_GL_SetAttribute( SDL_GL_BLUE_SIZE, 5 ); +SDL_GL_SetAttribute( SDL_GL_DEPTH_SIZE, 16 ); +SDL_GL_SetAttribute( SDL_GL_DOUBLEBUFFER, 1 ); +if ( (screen=SDL_SetVideoMode( 640, 480, 16, SDL_OPENGL )) == NULL ) { + fprintf(stderr, "Couldn\&'t set GL mode: %s +", SDL_GetError()); + SDL_Quit(); + return; +}\fR +.fi +.PP +.PP +.RS +\fBNote: +.PP +The \fBSDL_DOUBLEBUF\fP flag is not required to enable double buffering when setting an OpenGL video mode\&. Double buffering is enabled or disabled using the SDL_GL_DOUBLEBUFFER attribute\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_GL_GetAttribute\fP\fR, \fIGL Attributes\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GL_SwapBuffers.3 b/Externals/SDL/docs/man3/SDL_GL_SwapBuffers.3 new file mode 100644 index 0000000000..31d31cf3ee --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GL_SwapBuffers.3 @@ -0,0 +1,15 @@ +.TH "SDL_GL_SwapBuffers" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GL_SwapBuffers \- Swap OpenGL framebuffers/Update Display +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_GL_SwapBuffers\fP\fR(\fBvoid \fR); +.SH "DESCRIPTION" +.PP +Swap the OpenGL buffers, if double-buffering is supported\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetVideoMode\fP\fR, \fI\fBSDL_GL_SetAttribute\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GLattr.3 b/Externals/SDL/docs/man3/SDL_GLattr.3 new file mode 100644 index 0000000000..23d3726259 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GLattr.3 @@ -0,0 +1,47 @@ +.TH "SDL_GLattr" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GLattr \- SDL GL Attributes +.SH "ATTRIBUTES" +.TP 20 +\fBSDL_GL_RED_SIZE\fP +Size of the framebuffer red component, in bits +.TP 20 +\fBSDL_GL_GREEN_SIZE\fP +Size of the framebuffer green component, in bits +.TP 20 +\fBSDL_GL_BLUE_SIZE\fP +Size of the framebuffer blue component, in bits +.TP 20 +\fBSDL_GL_ALPHA_SIZE\fP +Size of the framebuffer alpha component, in bits +.TP 20 +\fBSDL_GL_DOUBLEBUFFER\fP +0 or 1, enable or disable double buffering +.TP 20 +\fBSDL_GL_BUFFER_SIZE\fP +Size of the framebuffer, in bits +.TP 20 +\fBSDL_GL_DEPTH_SIZE\fP +Size of the depth buffer, in bits +.TP 20 +\fBSDL_GL_STENCIL_SIZE\fP +Size of the stencil buffer, in bits +.TP 20 +\fBSDL_GL_ACCUM_RED_SIZE\fP +Size of the accumulation buffer red component, in bits +.TP 20 +\fBSDL_GL_ACCUM_GREEN_SIZE\fP +Size of the accumulation buffer green component, in bits +.TP 20 +\fBSDL_GL_ACCUM_BLUE_SIZE\fP +Size of the accumulation buffer blue component, in bits +.TP 20 +\fBSDL_GL_ACCUM_ALPHA_SIZE\fP +Size of the accumulation buffer alpha component, in bits +.SH "DESCRIPTION" +.PP +While you can set most OpenGL attributes normally, the attributes list above must be known \fIbefore\fP SDL sets the video mode\&. These attributes a set and read with \fI\fBSDL_GL_SetAttribute\fP\fR and \fI\fBSDL_GL_GetAttribute\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GL_SetAttribute\fP\fR, \fI\fBSDL_GL_GetAttribute\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetAppState.3 b/Externals/SDL/docs/man3/SDL_GetAppState.3 new file mode 100644 index 0000000000..9d644a142a --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetAppState.3 @@ -0,0 +1,24 @@ +.TH "SDL_GetAppState" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +\fBSDL_GetAppState\fP \- Get the state of the application +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint8 \fBSDL_GetAppState\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +This function returns the current state of the application\&. The value returned is a bitwise combination of: +.TP 20 +\fBSDL_APPMOUSEFOCUS\fP +The application has mouse focus\&. +.TP 20 +\fBSDL_APPINPUTFOCUS\fP +The application has keyboard focus +.TP 20 +\fBSDL_APPACTIVE\fP +The application is visible +.SH "SEE ALSO" +.PP +\fI\fBSDL_ActiveEvent\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_GetAudioStatus.3 b/Externals/SDL/docs/man3/SDL_GetAudioStatus.3 new file mode 100644 index 0000000000..9895c9556c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetAudioStatus.3 @@ -0,0 +1,24 @@ +.TH "SDL_GetAudioStatus" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetAudioStatus \- Get the current audio state +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_audiostatus\fBSDL_GetAudioStatus\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +.nf +\f(CWtypedef enum{ + SDL_AUDIO_STOPPED, + SDL_AUDIO_PAUSED, + SDL_AUDIO_PLAYING +} SDL_audiostatus;\fR +.fi +.PP +.PP +Returns either \fBSDL_AUDIO_STOPPED\fP, \fBSDL_AUDIO_PAUSED\fP or \fBSDL_AUDIO_PLAYING\fP depending on the current audio state\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_PauseAudio\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_GetClipRect.3 b/Externals/SDL/docs/man3/SDL_GetClipRect.3 new file mode 100644 index 0000000000..b911ff6b41 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetClipRect.3 @@ -0,0 +1,17 @@ +.TH "SDL_GetClipRect" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetClipRect \- Gets the clipping rectangle for a surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_GetClipRect\fP\fR(\fBSDL_Surface *surface, SDL_Rect *rect\fR); +.SH "DESCRIPTION" +.PP +Gets the clipping rectangle for a surface\&. When this surface is the destination of a blit, only the area within the clip rectangle is drawn into\&. +.PP +The rectangle pointed to by \fBrect\fR will be filled with the clipping rectangle of the surface\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetClipRect\fP\fR, \fI\fBSDL_BlitSurface\fP\fR, \fI\fBSDL_Surface\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetCursor.3 b/Externals/SDL/docs/man3/SDL_GetCursor.3 new file mode 100644 index 0000000000..ce5ba72a90 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetCursor.3 @@ -0,0 +1,15 @@ +.TH "SDL_GetCursor" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetCursor \- Get the currently active mouse cursor\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Cursor *\fBSDL_GetCursor\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +Returns the currently active mouse cursor\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetCursor\fP\fR, \fI\fBSDL_CreateCursor\fP\fR, \fI\fBSDL_ShowCursor\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetError.3 b/Externals/SDL/docs/man3/SDL_GetError.3 new file mode 100644 index 0000000000..ecdb98cf1e --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetError.3 @@ -0,0 +1,15 @@ +.TH "SDL_GetError" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetError \- Get SDL error string +.SH "SYNOPSIS" +.PP +\fB#include "SDL/SDL\&.h" +.sp +\fBchar *\fBSDL_GetError\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_GetError\fP returns a NULL terminated string containing information about the last internal SDL error\&. +.SH "RETURN VALUE" +.PP +\fBSDL_GetError\fP returns a string containing the last error\&. +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_GetEventFilter.3 b/Externals/SDL/docs/man3/SDL_GetEventFilter.3 new file mode 100644 index 0000000000..41bf33795c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetEventFilter.3 @@ -0,0 +1,23 @@ +.TH "SDL_GetEventFilter" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetEventFilter \- Retrieves a pointer to he event filter +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_EventFilter \fBSDL_GetEventFilter\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +This function retrieces a pointer to the event filter that was previously set using \fI\fBSDL_SetEventFilter\fP\fR\&. An SDL_EventFilter function is defined as: +.PP +.nf +\f(CWtypedef int (*SDL_EventFilter)(const SDL_Event *event);\fR +.fi +.PP +.SH "RETURN VALUE" +.PP +Returns a pointer to the event filter or \fBNULL\fP if no filter has been set\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_SetEventFilter\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_GetGamma.3 b/Externals/SDL/docs/man3/SDL_GetGamma.3 new file mode 100644 index 0000000000..f3493aa8e0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetGamma.3 @@ -0,0 +1,21 @@ +.TH "SDL_GetGamma" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetGamma \- Gets the gamma of the display +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_GetGamma\fP\fR(\fBfloat *red, float *green, float *blue\fR); +.SH "DESCRIPTION" +.PP +Gets the color gamma of the display\&. The gamma value for each color component will be place in the parameters \fBred\fR, \fBgreen\fR and \fBblue\fR\&. The values can range from 0\&.1 to 10\&. +.PP +.RS +\fBNote: +.PP +This function currently only works on XFreee 4\&.0 and up\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetGamma\fP\fR, \fI\fBSDL_SetVideoMode\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetGammaRamp.3 b/Externals/SDL/docs/man3/SDL_GetGammaRamp.3 new file mode 100644 index 0000000000..c1116d52e6 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetGammaRamp.3 @@ -0,0 +1,20 @@ +.TH "SDL_GetGammaRamp" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetGammaRamp \- Gets the color gamma lookup tables for the display +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_GetGammaRamp\fP\fR(\fBUint16 *redtable, Uint16 *greentable, Uint16 *bluetable\fR); +.SH "DESCRIPTION" +.PP +Gets the gamma translation lookup tables currently used by the display\&. Each table is an array of 256 Uint16 values\&. +.PP +Not all display hardware is able to change gamma\&. +.SH "RETURN VALUE" +.PP +Returns -1 on error\&. +.SH "SEE ALSO" +.PP +\fISDL_SetGamma\fR \fISDL_SetGammaRamp\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetKeyName.3 b/Externals/SDL/docs/man3/SDL_GetKeyName.3 new file mode 100644 index 0000000000..fc76ca8fa5 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetKeyName.3 @@ -0,0 +1,15 @@ +.TH "SDL_GetKeyName" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetKeyName \- Get the name of an SDL virtual keysym +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBchar *\fBSDL_GetKeyName\fP\fR(\fBSDLKey key\fR); +.SH "DESCRIPTION" +.PP +Returns the SDL-defined name of the \fI\fBSDLKey\fR\fR \fBkey\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDLKey\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_GetKeyState.3 b/Externals/SDL/docs/man3/SDL_GetKeyState.3 new file mode 100644 index 0000000000..f679c81c61 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetKeyState.3 @@ -0,0 +1,30 @@ +.TH "SDL_GetKeyState" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetKeyState \- Get a snapshot of the current keyboard state +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint8 *\fBSDL_GetKeyState\fP\fR(\fBint *numkeys\fR); +.SH "DESCRIPTION" +.PP +Gets a snapshot of the current keyboard state\&. The current state is return as a pointer to an array, the size of this array is stored in \fBnumkeys\fR\&. The array is indexed by the \fI\fBSDLK_*\fP\fR symbols\&. A value of 1 means the key is pressed and a value of 0 means its not\&. The pointer returned is a pointer to an internal SDL array and should not be freed by the caller\&. +.PP +.RS +\fBNote: +.PP +Use \fI\fBSDL_PumpEvents\fP\fR to update the state array\&. +.RE +.SH "EXAMPLE" +.PP +.PP +.nf +\f(CWUint8 *keystate = SDL_GetKeyState(NULL); +if ( keystate[SDLK_RETURN] ) printf("Return Key Pressed\&. +");\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL Key Symbols\fP\fR, \fI\fBSDL_PumpEvents\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_GetModState.3 b/Externals/SDL/docs/man3/SDL_GetModState.3 new file mode 100644 index 0000000000..5cff3d5db8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetModState.3 @@ -0,0 +1,54 @@ +.TH "SDL_GetModState" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetModState \- Get the state of modifier keys\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDLMod \fBSDL_GetModState\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +Returns the current state of the modifier keys (CTRL, ALT, etc\&.)\&. +.SH "RETURN VALUE" +.PP +The return value can be an OR\&'d combination of the SDLMod enum\&. +.PP +.PP +.RS +\fBSDLMod\fR +.PP +.PP +.nf +\f(CWtypedef enum { + KMOD_NONE = 0x0000, + KMOD_LSHIFT= 0x0001, + KMOD_RSHIFT= 0x0002, + KMOD_LCTRL = 0x0040, + KMOD_RCTRL = 0x0080, + KMOD_LALT = 0x0100, + KMOD_RALT = 0x0200, + KMOD_LMETA = 0x0400, + KMOD_RMETA = 0x0800, + KMOD_NUM = 0x1000, + KMOD_CAPS = 0x2000, + KMOD_MODE = 0x4000, +} SDLMod;\fR +.fi +.PP +.RE + SDL also defines the following symbols for convenience: +.PP +.RS +.PP +.nf +\f(CW#define KMOD_CTRL (KMOD_LCTRL|KMOD_RCTRL) +#define KMOD_SHIFT (KMOD_LSHIFT|KMOD_RSHIFT) +#define KMOD_ALT (KMOD_LALT|KMOD_RALT) +#define KMOD_META (KMOD_LMETA|KMOD_RMETA)\fR +.fi +.PP +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetKeyState\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_GetMouseState.3 b/Externals/SDL/docs/man3/SDL_GetMouseState.3 new file mode 100644 index 0000000000..e92aa43977 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetMouseState.3 @@ -0,0 +1,24 @@ +.TH "SDL_GetMouseState" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetMouseState \- Retrieve the current state of the mouse +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint8 \fBSDL_GetMouseState\fP\fR(\fBint *x, int *y\fR); +.SH "DESCRIPTION" +.PP +The current button state is returned as a button bitmask, which can be tested using the \fBSDL_BUTTON(X)\fP macros, and \fBx\fR and \fBy\fR are set to the current mouse cursor position\&. You can pass \fBNULL\fP for either \fBx\fR or \fBy\fR\&. +.SH "EXAMPLE" +.PP +.nf +\f(CWSDL_PumpEvents(); +if(SDL_GetMouseState(NULL, NULL)&SDL_BUTTON(1)) + printf("Mouse Button 1(left) is pressed\&. +");\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetRelativeMouseState\fP\fR, \fI\fBSDL_PumpEvents\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_GetRGB.3 b/Externals/SDL/docs/man3/SDL_GetRGB.3 new file mode 100644 index 0000000000..f21a162234 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetRGB.3 @@ -0,0 +1,17 @@ +.TH "SDL_GetRGB" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetRGB \- Get RGB values from a pixel in the specified pixel format\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_GetRGB\fP\fR(\fBUint32 pixel, SDL_PixelFormat *fmt, Uint8 *r, Uint8 *g, Uint8 *b\fR); +.SH "DESCRIPTION" +.PP +Get RGB component values from a pixel stored in the specified pixel format\&. +.PP +This function uses the entire 8-bit [0\&.\&.255] range when converting color components from pixel formats with less than 8-bits per RGB component (e\&.g\&., a completely white pixel in 16-bit RGB565 format would return [0xff, 0xff, 0xff] not [0xf8, 0xfc, 0xf8])\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetRGBA\fP\fR, \fI\fBSDL_MapRGB\fP\fR, \fI\fBSDL_MapRGBA\fP\fR, \fI\fBSDL_PixelFormat\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetRGBA.3 b/Externals/SDL/docs/man3/SDL_GetRGBA.3 new file mode 100644 index 0000000000..eba9dfbb23 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetRGBA.3 @@ -0,0 +1,19 @@ +.TH "SDL_GetRGBA" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetRGBA \- Get RGBA values from a pixel in the specified pixel format\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_GetRGBA\fP\fR(\fBUint32 pixel, SDL_PixelFormat *fmt, Uint8 *r, Uint8 *g, Uint8 *b, Uint8 *a\fR); +.SH "DESCRIPTION" +.PP +Get RGBA component values from a pixel stored in the specified pixel format\&. +.PP +This function uses the entire 8-bit [0\&.\&.255] range when converting color components from pixel formats with less than 8-bits per RGB component (e\&.g\&., a completely white pixel in 16-bit RGB565 format would return [0xff, 0xff, 0xff] not [0xf8, 0xfc, 0xf8])\&. +.PP +If the surface has no alpha component, the alpha will be returned as 0xff (100% opaque)\&. +.SH "SEE ALSO" +.PP +\fISDL_GetRGB\fR, \fISDL_MapRGB\fR, \fISDL_MapRGBA\fR, \fISDL_PixelFormat\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetRelativeMouseState.3 b/Externals/SDL/docs/man3/SDL_GetRelativeMouseState.3 new file mode 100644 index 0000000000..349f47d819 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetRelativeMouseState.3 @@ -0,0 +1,15 @@ +.TH "SDL_GetRelativeMouseState" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetRelativeMouseState \- Retrieve the current state of the mouse +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint8 \fBSDL_GetRelativeMouseState\fP\fR(\fBint *x, int *y\fR); +.SH "DESCRIPTION" +.PP +The current button state is returned as a button bitmask, which can be tested using the \fBSDL_BUTTON(X)\fP macros, and \fBx\fR and \fBy\fR are set to the change in the mouse position since the last call to \fBSDL_GetRelativeMouseState\fP or since event initialization\&. You can pass \fBNULL\fP for either \fBx\fR or \fBy\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetMouseState\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_GetThreadID.3 b/Externals/SDL/docs/man3/SDL_GetThreadID.3 new file mode 100644 index 0000000000..6385aeb922 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetThreadID.3 @@ -0,0 +1,16 @@ +.TH "SDL_GetThreadID" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetThreadID \- Get the SDL thread ID of a SDL_Thread +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBUint32 \fBSDL_GetThreadID\fP\fR(\fBSDL_Thread *thread\fR); +.SH "DESCRIPTION" +.PP +Returns the ID of a \fBSDL_Thread\fR created by \fISDL_CreateThread\fR\&. +.SH "SEE ALSO" +.PP +\fISDL_CreateThread\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_GetTicks.3 b/Externals/SDL/docs/man3/SDL_GetTicks.3 new file mode 100644 index 0000000000..4615737b4c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetTicks.3 @@ -0,0 +1,15 @@ +.TH "SDL_GetTicks" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetTicks \- Get the number of milliseconds since the SDL library initialization\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint32 \fBSDL_GetTicks\fP\fR(\fBvoid\fR) +.SH "DESCRIPTION" +.PP +Get the number of milliseconds since the SDL library initialization\&. Note that this value wraps if the program runs for more than ~49 days\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Delay\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetVideoInfo.3 b/Externals/SDL/docs/man3/SDL_GetVideoInfo.3 new file mode 100644 index 0000000000..b82b28e162 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetVideoInfo.3 @@ -0,0 +1,15 @@ +.TH "SDL_GetVideoInfo" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetVideoInfo \- returns a pointer to information about the video hardware +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_VideoInfo *\fBSDL_GetVideoInfo\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +This function returns a read-only pointer to \fIinformation\fR about the video hardware\&. If this is called before \fISDL_SetVideoMode\fR, the \fBvfmt\fR member of the returned structure will contain the pixel format of the "best" video mode\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetVideoMode\fP\fR, \fI\fBSDL_VideoInfo\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_GetVideoSurface.3 b/Externals/SDL/docs/man3/SDL_GetVideoSurface.3 new file mode 100644 index 0000000000..4a5d7eb96a --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_GetVideoSurface.3 @@ -0,0 +1,15 @@ +.TH "SDL_GetVideoSurface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_GetVideoSurface \- returns a pointer to the current display surface +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_GetVideoSurface\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +This function returns a pointer to the current display surface\&. If SDL is doing format conversion on the display surface, this function returns the publicly visible surface, not the real video surface\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Surface\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_Init.3 b/Externals/SDL/docs/man3/SDL_Init.3 new file mode 100644 index 0000000000..5f50054791 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Init.3 @@ -0,0 +1,41 @@ +.TH "SDL_Init" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Init \- Initializes SDL +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_Init\fP\fR(\fBUint32 flags\fR); +.SH "DESCRIPTION" +.PP +Initializes SDL\&. This should be called before all other SDL functions\&. The \fBflags\fR parameter specifies what part(s) of SDL to initialize\&. +.TP 20 +\fBSDL_INIT_TIMER\fP +Initializes the \fItimer\fR subsystem\&. +.TP 20 +\fBSDL_INIT_AUDIO\fP +Initializes the \fIaudio\fR subsystem\&. +.TP 20 +\fBSDL_INIT_VIDEO\fP +Initializes the \fIvideo\fR subsystem\&. +.TP 20 +\fBSDL_INIT_CDROM\fP +Initializes the \fIcdrom\fR subsystem\&. +.TP 20 +\fBSDL_INIT_JOYSTICK\fP +Initializes the \fIjoystick\fR subsystem\&. +.TP 20 +\fBSDL_INIT_EVERYTHING\fP +Initialize all of the above\&. +.TP 20 +\fBSDL_INIT_NOPARACHUTE\fP +Prevents SDL from catching fatal signals\&. +.TP 20 +\fBSDL_INIT_EVENTTHREAD\fP +.SH "RETURN VALUE" +.PP +Returns \fB-1\fR on an error or \fB0\fR on success\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Quit\fP\fR, \fI\fBSDL_InitSubSystem\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_InitSubSystem.3 b/Externals/SDL/docs/man3/SDL_InitSubSystem.3 new file mode 100644 index 0000000000..f0a82a5284 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_InitSubSystem.3 @@ -0,0 +1,41 @@ +.TH "SDL_InitSubSystem" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_InitSubSystem \- Initialize subsystems +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_InitSubSystem\fP\fR(\fBUint32 flags\fR); +.SH "DESCRIPTION" +.PP +After SDL has been initialized with \fI\fBSDL_Init\fP\fR you may initialize uninitialized subsystems with \fBSDL_InitSubSystem\fP\&. The \fBflags\fR parameter is the same as that used in \fI\fBSDL_Init\fP\fR\&. +.SH "EXAMPLES" +.PP +.nf +\f(CW/* Seperating Joystick and Video initialization\&. */ +SDL_Init(SDL_INIT_VIDEO); +\&. +\&. +SDL_SetVideoMode(640, 480, 16, SDL_DOUBLEBUF|SDL_FULLSCREEN); +\&. +/* Do Some Video stuff */ +\&. +\&. +/* Initialize the joystick subsystem */ +SDL_InitSubSystem(SDL_INIT_JOYSTICK); + +/* Do some stuff with video and joystick */ +\&. +\&. +\&. +/* Shut them both down */ +SDL_Quit();\fR +.fi +.PP +.SH "RETURN VALUE" +.PP +Returns \fB-1\fR on an error or \fB0\fR on success\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Init\fP\fR, \fI\fBSDL_Quit\fP\fR, \fI\fBSDL_QuitSubSystem\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoyAxisEvent.3 b/Externals/SDL/docs/man3/SDL_JoyAxisEvent.3 new file mode 100644 index 0000000000..f8301fd70b --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoyAxisEvent.3 @@ -0,0 +1,36 @@ +.TH "SDL_JoyAxisEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoyAxisEvent \- Joystick axis motion event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 which; + Uint8 axis; + Sint16 value; +} SDL_JoyAxisEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_JOYAXISMOTION\fP +.TP 20 +\fBwhich\fR +Joystick device index +.TP 20 +\fBaxis\fR +Joystick axis index +.TP 20 +\fBvalue\fR +Axis value (range: -32768 to 32767) +.SH "DESCRIPTION" +.PP +\fBSDL_JoyAxisEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_JOYAXISMOTION\fP is reported\&. +.PP +A \fBSDL_JOYAXISMOTION\fP event occurs when ever a user moves an axis on the joystick\&. The field \fBwhich\fR is the index of the joystick that reported the event and \fBaxis\fR is the index of the axis (for a more detailed explaination see the \fIJoystick section\fR)\&. \fBvalue\fR is the current position of the axis\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fIJoystick Functions\fR, \fI\fBSDL_JoystickEventState\fP\fR, \fI\fBSDL_JoystickGetAxis\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_JoyBallEvent.3 b/Externals/SDL/docs/man3/SDL_JoyBallEvent.3 new file mode 100644 index 0000000000..7f42f7ba69 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoyBallEvent.3 @@ -0,0 +1,36 @@ +.TH "SDL_JoyBallEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoyBallEvent \- Joystick trackball motion event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 which; + Uint8 ball; + Sint16 xrel, yrel; +} SDL_JoyBallEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_JOYBALLMOTION\fP +.TP 20 +\fBwhich\fR +Joystick device index +.TP 20 +\fBball\fR +Joystick trackball index +.TP 20 +\fBxrel\fR, \fByrel\fR +The relative motion in the X/Y direction +.SH "DESCRIPTION" +.PP +\fBSDL_JoyBallEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_JOYBALLMOTION\fP is reported\&. +.PP +A \fBSDL_JOYBALLMOTION\fP event occurs when a user moves a trackball on the joystick\&. The field \fBwhich\fR is the index of the joystick that reported the event and \fBball\fR is the index of the trackball (for a more detailed explaination see the \fIJoystick section\fR)\&. Trackballs only return relative motion, this is the change in position on the ball since it was last polled (last cycle of the event loop) and it is stored in \fBxrel\fR and \fByrel\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fIJoystick Functions\fR, \fI\fBSDL_JoystickEventState\fP\fR, \fI\fBSDL_JoystickGetBall\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_JoyButtonEvent.3 b/Externals/SDL/docs/man3/SDL_JoyButtonEvent.3 new file mode 100644 index 0000000000..dfd0793a89 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoyButtonEvent.3 @@ -0,0 +1,36 @@ +.TH "SDL_JoyButtonEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoyButtonEvent \- Joystick button event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 which; + Uint8 button; + Uint8 state; +} SDL_JoyButtonEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_JOYBUTTONDOWN\fP or \fBSDL_JOYBUTTONUP\fP +.TP 20 +\fBwhich\fR +Joystick device index +.TP 20 +\fBbutton\fR +Joystick button index +.TP 20 +\fBstate\fR +\fBSDL_PRESSED\fP or \fBSDL_RELEASED\fP +.SH "DESCRIPTION" +.PP +\fBSDL_JoyButtonEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_JOYBUTTONDOWN\fP or \fBSDL_JOYBUTTONUP\fP is reported\&. +.PP +A \fBSDL_JOYBUTTONDOWN\fP or \fBSDL_JOYBUTTONUP\fP event occurs when ever a user presses or releases a button on a joystick\&. The field \fBwhich\fR is the index of the joystick that reported the event and \fBbutton\fR is the index of the button (for a more detailed explaination see the \fIJoystick section\fR)\&. \fBstate\fR is the current state or the button which is either \fBSDL_PRESSED\fP or \fBSDL_RELEASED\fP\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fIJoystick Functions\fR, \fI\fBSDL_JoystickEventState\fP\fR, \fI\fBSDL_JoystickGetButton\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_JoyHatEvent.3 b/Externals/SDL/docs/man3/SDL_JoyHatEvent.3 new file mode 100644 index 0000000000..5817ad68f8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoyHatEvent.3 @@ -0,0 +1,56 @@ +.TH "SDL_JoyHatEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoyHatEvent \- Joystick hat position change event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 which; + Uint8 hat; + Uint8 value; +} SDL_JoyHatEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_JOY\fP +.TP 20 +\fBwhich\fR +Joystick device index +.TP 20 +\fBhat\fR +Joystick hat index +.TP 20 +\fBvalue\fR +Hat position +.SH "DESCRIPTION" +.PP +\fBSDL_JoyHatEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_JOYHATMOTION\fP is reported\&. +.PP +A \fBSDL_JOYHATMOTION\fP event occurs when ever a user moves a hat on the joystick\&. The field \fBwhich\fR is the index of the joystick that reported the event and \fBhat\fR is the index of the hat (for a more detailed exlaination see the \fIJoystick section\fR)\&. \fBvalue\fR is the current position of the hat\&. It is a logically OR\&'d combination of the following values (whose meanings should be pretty obvious:) : +.IP "" 10 +\fBSDL_HAT_CENTERED\fP +.IP "" 10 +\fBSDL_HAT_UP\fP +.IP "" 10 +\fBSDL_HAT_RIGHT\fP +.IP "" 10 +\fBSDL_HAT_DOWN\fP +.IP "" 10 +\fBSDL_HAT_LEFT\fP +.PP +The following defines are also provided: +.IP "" 10 +\fBSDL_HAT_RIGHTUP\fP +.IP "" 10 +\fBSDL_HAT_RIGHTDOWN\fP +.IP "" 10 +\fBSDL_HAT_LEFTUP\fP +.IP "" 10 +\fBSDL_HAT_LEFTDOWN\fP +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fIJoystick Functions\fR, \fI\fBSDL_JoystickEventState\fP\fR, \fI\fBSDL_JoystickGetHat\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_JoystickClose.3 b/Externals/SDL/docs/man3/SDL_JoystickClose.3 new file mode 100644 index 0000000000..281702f116 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickClose.3 @@ -0,0 +1,15 @@ +.TH "SDL_JoystickClose" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickClose \- Closes a previously opened joystick +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_JoystickClose\fP\fR(\fBSDL_Joystick *joystick\fR); +.SH "DESCRIPTION" +.PP +Close a \fBjoystick\fR that was previously opened with \fI\fBSDL_JoystickOpen\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickOpen\fP\fR, \fI\fBSDL_JoystickOpened\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickEventState.3 b/Externals/SDL/docs/man3/SDL_JoystickEventState.3 new file mode 100644 index 0000000000..7e410f3626 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickEventState.3 @@ -0,0 +1,24 @@ +.TH "SDL_JoystickEventState" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickEventState \- Enable/disable joystick event polling +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_JoystickEventState\fP\fR(\fBint state\fR); +.SH "DESCRIPTION" +.PP +This function is used to enable or disable joystick event processing\&. With joystick event processing disabled you will have to update joystick states with \fI\fBSDL_JoystickUpdate\fP\fR and read the joystick information manually\&. \fBstate\fR is either \fBSDL_QUERY\fP, \fBSDL_ENABLE\fP or \fBSDL_IGNORE\fP\&. +.PP +.RS +\fBNote: +.PP +Joystick event handling is prefered +.RE +.SH "RETURN VALUE" +.PP +If \fBstate\fR is \fBSDL_QUERY\fP then the current state is returned, otherwise the new processing \fBstate\fR is returned\&. +.SH "SEE ALSO" +.PP +\fISDL Joystick Functions\fR, \fI\fBSDL_JoystickUpdate\fP\fR, \fI\fBSDL_JoyAxisEvent\fR\fR, \fI\fBSDL_JoyBallEvent\fR\fR, \fI\fBSDL_JoyButtonEvent\fR\fR, \fI\fBSDL_JoyHatEvent\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_JoystickGetAxis.3 b/Externals/SDL/docs/man3/SDL_JoystickGetAxis.3 new file mode 100644 index 0000000000..0a80b3405a --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickGetAxis.3 @@ -0,0 +1,32 @@ +.TH "SDL_JoystickGetAxis" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickGetAxis \- Get the current state of an axis +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSint16 \fBSDL_JoystickGetAxis\fP\fR(\fBSDL_Joystick *joystick, int axis\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_JoystickGetAxis\fP returns the current state of the given \fBaxis\fR on the given \fBjoystick\fR\&. +.PP +On most modern joysticks the X axis is usually represented by \fBaxis\fR 0 and the Y axis by \fBaxis\fR 1\&. The value returned by \fBSDL_JoystickGetAxis\fP is a signed integer (-32768 to 32768) representing the current position of the \fBaxis\fR, it maybe necessary to impose certain tolerances on these values to account for jitter\&. It is worth noting that some joysticks use axes 2 and 3 for extra buttons\&. +.SH "RETURN VALUE" +.PP +Returns a 16-bit signed integer representing the current position of the \fBaxis\fR\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWSint16 x_move, y_move; +SDL_Joystick *joy1; +\&. +\&. +x_move=SDL_JoystickGetAxis(joy1, 0); +y_move=SDL_JoystickGetAxis(joy1, 1);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickNumAxes\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickGetBall.3 b/Externals/SDL/docs/man3/SDL_JoystickGetBall.3 new file mode 100644 index 0000000000..124c910709 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickGetBall.3 @@ -0,0 +1,37 @@ +.TH "SDL_JoystickGetBall" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickGetBall \- Get relative trackball motion +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_JoystickGetBall\fP\fR(\fBSDL_Joystick *joystick, int ball, int *dx, int *dy\fR); +.SH "DESCRIPTION" +.PP +Get the \fBball\fR axis change\&. +.PP +Trackballs can only return relative motion since the last call to \fBSDL_JoystickGetBall\fP, these motion deltas a placed into \fBdx\fR and \fBdy\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success or \fB-1\fR on failure +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWint delta_x, delta_y; +SDL_Joystick *joy; +\&. +\&. +\&. +SDL_JoystickUpdate(); +if(SDL_JoystickGetBall(joy, 0, &delta_x, &delta_y)==-1) + printf("TrackBall Read Error! +"); +printf("Trackball Delta- X:%d, Y:%d +", delta_x, delta_y);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickNumBalls\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickGetButton.3 b/Externals/SDL/docs/man3/SDL_JoystickGetButton.3 new file mode 100644 index 0000000000..e7b336b34b --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickGetButton.3 @@ -0,0 +1,18 @@ +.TH "SDL_JoystickGetButton" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickGetButton \- Get the current state of a given button on a given joystick +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint8 \fBSDL_JoystickGetButton\fP\fR(\fBSDL_Joystick *joystick, int button\fR); +.SH "DESCRIPTION" +.PP +SDL_JoystickGetButton returns the current state of the given \fBbutton\fR on the given \fBjoystick\fR\&. +.SH "RETURN VALUE" +.PP +\fB1\fR if the button is pressed\&. Otherwise, \fB0\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickNumButtons\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickGetHat.3 b/Externals/SDL/docs/man3/SDL_JoystickGetHat.3 new file mode 100644 index 0000000000..cdbd910557 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickGetHat.3 @@ -0,0 +1,36 @@ +.TH "SDL_JoystickGetHat" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickGetHat \- Get the current state of a joystick hat +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint8 \fBSDL_JoystickGetHat\fP\fR(\fBSDL_Joystick *joystick, int hat\fR); +.SH "DESCRIPTION" +.PP +SDL_JoystickGetHat returns the current state of the given \fBhat\fR on the given \fBjoystick\fR\&. +.SH "RETURN VALUE" +.PP +The current state is returned as a Uint8 which is defined as an OR\&'d combination of one or more of the following +.IP "" 10 +\fBSDL_HAT_CENTERED\fP +.IP "" 10 +\fBSDL_HAT_UP\fP +.IP "" 10 +\fBSDL_HAT_RIGHT\fP +.IP "" 10 +\fBSDL_HAT_DOWN\fP +.IP "" 10 +\fBSDL_HAT_LEFT\fP +.IP "" 10 +\fBSDL_HAT_RIGHTUP\fP +.IP "" 10 +\fBSDL_HAT_RIGHTDOWN\fP +.IP "" 10 +\fBSDL_HAT_LEFTUP\fP +.IP "" 10 +\fBSDL_HAT_LEFTDOWN\fP +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickNumHats\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickIndex.3 b/Externals/SDL/docs/man3/SDL_JoystickIndex.3 new file mode 100644 index 0000000000..611e4b67a8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickIndex.3 @@ -0,0 +1,18 @@ +.TH "SDL_JoystickIndex" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickIndex \- Get the index of an SDL_Joystick\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_JoystickIndex\fP\fR(\fBSDL_Joystick *joystick\fR); +.SH "DESCRIPTION" +.PP +Returns the index of a given \fBSDL_Joystick\fR structure\&. +.SH "RETURN VALUE" +.PP +Index number of the joystick\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickOpen\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickName.3 b/Externals/SDL/docs/man3/SDL_JoystickName.3 new file mode 100644 index 0000000000..364297e0d9 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickName.3 @@ -0,0 +1,32 @@ +.TH "SDL_JoystickName" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickName \- Get joystick name\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBconst char *\fBSDL_JoystickName\fP\fR(\fBint index\fR); +.SH "DESCRIPTION" +.PP +Get the implementation dependent name of joystick\&. The \fBindex\fR parameter refers to the N\&'th joystick on the system\&. +.SH "RETURN VALUE" +.PP +Returns a char pointer to the joystick name\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CW/* Print the names of all attached joysticks */ +int num_joy, i; +num_joy=SDL_NumJoysticks(); +printf("%d joysticks found +", num_joy); +for(i=0;i0){ + // Open joystick + joy=SDL_JoystickOpen(0); + + if(joy) + { + printf("Opened Joystick 0 +"); + printf("Name: %s +", SDL_JoystickName(0)); + printf("Number of Axes: %d +", SDL_JoystickNumAxes(joy)); + printf("Number of Buttons: %d +", SDL_JoystickNumButtons(joy)); + printf("Number of Balls: %d +", SDL_JoystickNumBalls(joy)); + } + else + printf("Couldn\&'t open Joystick 0 +"); + + // Close if opened + if(SDL_JoystickOpened(0)) + SDL_JoystickClose(joy); +}\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickClose\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickOpened.3 b/Externals/SDL/docs/man3/SDL_JoystickOpened.3 new file mode 100644 index 0000000000..9d82e09b32 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickOpened.3 @@ -0,0 +1,18 @@ +.TH "SDL_JoystickOpened" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickOpened \- Determine if a joystick has been opened +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_JoystickOpened\fP\fR(\fBint index\fR); +.SH "DESCRIPTION" +.PP +Determines whether a joystick has already been opened within the application\&. \fBindex\fR refers to the N\&'th joystick on the system\&. +.SH "RETURN VALUE" +.PP +Returns \fB1\fR if the joystick has been opened, or \fB0\fR if it has not\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickOpen\fP\fR, \fI\fBSDL_JoystickClose\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_JoystickUpdate.3 b/Externals/SDL/docs/man3/SDL_JoystickUpdate.3 new file mode 100644 index 0000000000..7d1035b1cc --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_JoystickUpdate.3 @@ -0,0 +1,15 @@ +.TH "SDL_JoystickUpdate" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_JoystickUpdate \- Updates the state of all joysticks +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_JoystickUpdate\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +Updates the state(position, buttons, etc\&.) of all open joysticks\&. If joystick events have been enabled with \fI\fBSDL_JoystickEventState\fP\fR then this is called automatically in the event loop\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickEventState\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_KeyboardEvent.3 b/Externals/SDL/docs/man3/SDL_KeyboardEvent.3 new file mode 100644 index 0000000000..4aeea79220 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_KeyboardEvent.3 @@ -0,0 +1,38 @@ +.TH "SDL_KeyboardEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_KeyboardEvent \- Keyboard event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 state; + SDL_keysym keysym; +} SDL_KeyboardEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_KEYDOWN\fP or \fBSDL_KEYUP\fP +.TP 20 +\fBstate\fR +\fBSDL_PRESSED\fP or \fBSDL_RELEASED\fP +.TP 20 +\fBkeysym\fR +Contains key press information +.SH "DESCRIPTION" +.PP +\fBSDL_KeyboardEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_KEYDOWN\fP or \fBSDL_KEYUP\fP is reported\&. +.PP +The \fBtype\fR and \fBstate\fR actually report the same information, they just use different values to do it! A keyboard event occurs when a key is released (\fBtype\fR=\fBSDK_KEYUP\fP or \fBstate\fR=\fBSDL_RELEASED\fP) and when a key is pressed (\fBtype\fR=\fBSDL_KEYDOWN\fP or \fBstate\fR=\fBSDL_PRESSED\fP)\&. The information on what key was pressed or released is in the \fI\fBkeysym\fR\fR structure\&. +.PP +.RS +\fBNote: +.PP +Repeating \fBSDL_KEYDOWN\fP events will occur if key repeat is enabled (see \fI\fBSDL_EnableKeyRepeat\fP\fR)\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_keysym\fR\fR, \fI\fBSDL_EnableKeyRepeat\fP\fR, \fI\fBSDL_EnableUNICODE\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_KillThread.3 b/Externals/SDL/docs/man3/SDL_KillThread.3 new file mode 100644 index 0000000000..2a34f11f83 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_KillThread.3 @@ -0,0 +1,16 @@ +.TH "SDL_KillThread" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_KillThread \- Gracelessly terminates the thread\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBvoid \fBSDL_KillThread\fP\fR(\fBSDL_Thread *thread\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_KillThread\fP gracelessly terminates the thread associated with \fBthread\fR\&. If possible, you should use some other form of IPC to signal the thread to quit\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateThread\fP\fR, \fI\fBSDL_WaitThread\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_ListModes.3 b/Externals/SDL/docs/man3/SDL_ListModes.3 new file mode 100644 index 0000000000..3cc9376afb --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ListModes.3 @@ -0,0 +1,53 @@ +.TH "SDL_ListModes" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ListModes \- Returns a pointer to an array of available screen dimensions for the given format and video flags +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Rect **\fBSDL_ListModes\fP\fR(\fBSDL_PixelFormat *format, Uint32 flags\fR); +.SH "DESCRIPTION" +.PP +Return a pointer to an array of available screen dimensions for the given format and video flags, sorted largest to smallest\&. Returns \fBNULL\fP if there are no dimensions available for a particular format, or \fB-1\fR if any dimension is okay for the given format\&. +.PP +If \fBformat\fR is \fBNULL\fP, the mode list will be for the format returned by \fISDL_GetVideoInfo()\fR->\fBvfmt\fR\&. The \fBflag\fR parameter is an OR\&'d combination of \fIsurface\fR flags\&. The flags are the same as those used \fI\fBSDL_SetVideoMode\fP\fR and they play a strong role in deciding what modes are valid\&. For instance, if you pass \fBSDL_HWSURFACE\fP as a flag only modes that support hardware video surfaces will be returned\&. +.SH "EXAMPLE" +.PP +.nf +\f(CWSDL_Rect **modes; +int i; +\&. +\&. +\&. + +/* Get available fullscreen/hardware modes */ +modes=SDL_ListModes(NULL, SDL_FULLSCREEN|SDL_HWSURFACE); + +/* Check is there are any modes available */ +if(modes == (SDL_Rect **)0){ + printf("No modes available! +"); + exit(-1); +} + +/* Check if or resolution is restricted */ +if(modes == (SDL_Rect **)-1){ + printf("All resolutions available\&. +"); +} +else{ + /* Print valid modes */ + printf("Available Modes +"); + for(i=0;modes[i];++i) + printf(" %d x %d +", modes[i]->w, modes[i]->h); +} +\&. +\&.\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetVideoMode\fP\fR, \fI\fBSDL_GetVideoInfo\fP\fR, \fI\fBSDL_Rect\fR\fR, \fI\fBSDL_PixelFormat\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_LoadBMP.3 b/Externals/SDL/docs/man3/SDL_LoadBMP.3 new file mode 100644 index 0000000000..7e3b4af3a9 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_LoadBMP.3 @@ -0,0 +1,18 @@ +.TH "SDL_LoadBMP" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_LoadBMP \- Load a Windows BMP file into an SDL_Surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_LoadBMP\fP\fR(\fBconst char *file\fR); +.SH "DESCRIPTION" +.PP +Loads a surface from a named Windows BMP file\&. +.SH "RETURN VALUE" +.PP +Returns the new surface, or \fBNULL\fP if there was an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_SaveBMP\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_LoadWAV.3 b/Externals/SDL/docs/man3/SDL_LoadWAV.3 new file mode 100644 index 0000000000..490ff67ef6 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_LoadWAV.3 @@ -0,0 +1,42 @@ +.TH "SDL_LoadWAV" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_LoadWAV \- Load a WAVE file +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_AudioSpec *\fBSDL_LoadWAV\fP\fR(\fBconst char *file, SDL_AudioSpec *spec, Uint8 **audio_buf, Uint32 *audio_len\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_LoadWAV\fP This function loads a WAVE \fBfile\fR into memory\&. +.PP +If this function succeeds, it returns the given \fI\fBSDL_AudioSpec\fP\fR, filled with the audio data format of the wave data, and sets \fBaudio_buf\fR to a \fBmalloc\fP\&'d buffer containing the audio data, and sets \fBaudio_len\fR to the length of that audio buffer, in bytes\&. You need to free the audio buffer with \fI\fBSDL_FreeWAV\fP\fR when you are done with it\&. +.PP +This function returns \fBNULL\fP and sets the SDL error message if the wave file cannot be opened, uses an unknown data format, or is corrupt\&. Currently raw, MS-ADPCM and IMA-ADPCM WAVE files are supported\&. +.SH "EXAMPLE" +.PP +.nf +\f(CWSDL_AudioSpec wav_spec; +Uint32 wav_length; +Uint8 *wav_buffer; + +/* Load the WAV */ +if( SDL_LoadWAV("test\&.wav", &wav_spec, &wav_buffer, &wav_length) == NULL ){ + fprintf(stderr, "Could not open test\&.wav: %s +", SDL_GetError()); + exit(-1); +} +\&. +\&. +\&. +/* Do stuff with the WAV */ +\&. +\&. +/* Free It */ +SDL_FreeWAV(wav_buffer);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_AudioSpec\fR\fR, \fI\fBSDL_OpenAudio\fP\fR, \fI\fBSDL_FreeWAV\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_LockAudio.3 b/Externals/SDL/docs/man3/SDL_LockAudio.3 new file mode 100644 index 0000000000..8c141fd67e --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_LockAudio.3 @@ -0,0 +1,15 @@ +.TH "SDL_LockAudio" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_LockAudio \- Lock out the callback function +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_LockAudio\fP\fR(\fBvoid\fR) +.SH "DESCRIPTION" +.PP +The lock manipulated by these functions protects the callback function\&. During a LockAudio period, you can be guaranteed that the callback function is not running\&. Do not call these from the callback function or you will cause deadlock\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_OpenAudio\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_LockSurface.3 b/Externals/SDL/docs/man3/SDL_LockSurface.3 new file mode 100644 index 0000000000..6db3ad7bd5 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_LockSurface.3 @@ -0,0 +1,48 @@ +.TH "SDL_LockSurface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_LockSurface \- Lock a surface for directly access\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_LockSurface\fP\fR(\fBSDL_Surface *surface\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_LockSurface\fP sets up a surface for directly accessing the pixels\&. Between calls to \fBSDL_LockSurface\fP and \fBSDL_UnlockSurface\fP, you can write to and read from \fBsurface->\fBpixels\fR\fR, using the pixel format stored in \fBsurface->\fBformat\fR\fR\&. Once you are done accessing the surface, you should use \fBSDL_UnlockSurface\fP to release it\&. +.PP +Not all surfaces require locking\&. If \fBSDL_MUSTLOCK\fP(\fBsurface\fR) evaluates to \fB0\fR, then you can read and write to the surface at any time, and the pixel format of the surface will not change\&. +.PP +No operating system or library calls should be made between lock/unlock pairs, as critical system locks may be held during this time\&. +.PP +It should be noted, that since SDL 1\&.1\&.8 surface locks are recursive\&. This means that you can lock a surface multiple times, but each lock must have a match unlock\&. +.PP +.nf +\f(CW \&. + \&. + SDL_LockSurface( surface ); + \&. + /* Surface is locked */ + /* Direct pixel access on surface here */ + \&. + SDL_LockSurface( surface ); + \&. + /* More direct pixel access on surface */ + \&. + SDL_UnlockSurface( surface ); + /* Surface is still locked */ + /* Note: Is versions < 1\&.1\&.8, the surface would have been */ + /* no longer locked at this stage */ + \&. + SDL_UnlockSurface( surface ); + /* Surface is now unlocked */ + \&. + \&.\fR +.fi +.PP +.SH "RETURN VALUE" +.PP +\fBSDL_LockSurface\fP returns \fB0\fR, or \fB-1\fR if the surface couldn\&'t be locked\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_UnlockSurface\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_LockYUVOverlay.3 b/Externals/SDL/docs/man3/SDL_LockYUVOverlay.3 new file mode 100644 index 0000000000..286d96fdec --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_LockYUVOverlay.3 @@ -0,0 +1,18 @@ +.TH "SDL_LockYUVOverlay" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_LockYUVOverlay \- Lock an overlay +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_LockYUVOverlay\fP\fR(\fBSDL_Overlay *overlay\fR); +.SH "DESCRIPTION" +.PP +Much the same as \fI\fBSDL_LockSurface\fP\fR, \fBSDL_LockYUVOverlay\fP locks the \fI\fBoverlay\fR\fR for direct access to pixel data\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_UnlockYUVOverlay\fP\fR, \fI\fBSDL_CreateYUVOverlay\fP\fR, \fI\fBSDL_Overlay\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_MapRGB.3 b/Externals/SDL/docs/man3/SDL_MapRGB.3 new file mode 100644 index 0000000000..1e4c963b49 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_MapRGB.3 @@ -0,0 +1,22 @@ +.TH "SDL_MapRGB" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_MapRGB \- Map a RGB color value to a pixel format\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint32 \fBSDL_MapRGB\fP\fR(\fBSDL_PixelFormat *fmt, Uint8 r, Uint8 g, Uint8 b\fR); +.SH "DESCRIPTION" +.PP +Maps the RGB color value to the specified pixel format and returns the pixel value as a 32-bit int\&. +.PP +If the format has a palette (8-bit) the index of the closest matching color in the palette will be returned\&. +.PP +If the specified pixel format has an alpha component it will be returned as all 1 bits (fully opaque)\&. +.SH "RETURN VALUE" +.PP +A pixel value best approximating the given RGB color value for a given pixel format\&. If the pixel format bpp (color depth) is less than 32-bpp then the unused upper bits of the return value can safely be ignored (e\&.g\&., with a 16-bpp format the return value can be assigned to a \fBUint16\fP, and similarly a \fBUint8\fP for an 8-bpp format)\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetRGB\fP\fR, \fI\fBSDL_GetRGBA\fP\fR, \fI\fBSDL_MapRGBA\fP\fR, \fI\fBSDL_PixelFormat\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_MapRGBA.3 b/Externals/SDL/docs/man3/SDL_MapRGBA.3 new file mode 100644 index 0000000000..03d78d8c02 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_MapRGBA.3 @@ -0,0 +1,22 @@ +.TH "SDL_MapRGBA" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_MapRGBA \- Map a RGBA color value to a pixel format\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint32 \fBSDL_MapRGBA\fP\fR(\fBSDL_PixelFormat *fmt, Uint8 r, Uint8 g, Uint8 b, Uint8 a\fR); +.SH "DESCRIPTION" +.PP +Maps the RGBA color value to the specified pixel format and returns the pixel value as a 32-bit int\&. +.PP +If the format has a palette (8-bit) the index of the closest matching color in the palette will be returned\&. +.PP +If the specified pixel format has no alpha component the alpha value will be ignored (as it will be in formats with a palette)\&. +.SH "RETURN VALUE" +.PP +A pixel value best approximating the given RGBA color value for a given pixel format\&. If the pixel format bpp (color depth) is less than 32-bpp then the unused upper bits of the return value can safely be ignored (e\&.g\&., with a 16-bpp format the return value can be assigned to a \fBUint16\fP, and similarly a \fBUint8\fP for an 8-bpp format)\&. +.SH "SEE ALSO" +.PP +\fISDL_GetRGB\fR, \fISDL_GetRGBA\fR, \fISDL_MapRGB\fR, \fISDL_PixelFormat\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_MixAudio.3 b/Externals/SDL/docs/man3/SDL_MixAudio.3 new file mode 100644 index 0000000000..b98660df6f --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_MixAudio.3 @@ -0,0 +1,21 @@ +.TH "SDL_MixAudio" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_MixAudio \- Mix audio data +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_MixAudio\fP\fR(\fBUint8 *dst, Uint8 *src, Uint32 len, int volume\fR); +.SH "DESCRIPTION" +.PP +This function takes two audio buffers of \fBlen\fR bytes each of the playing audio format and mixes them, performing addition, volume adjustment, and overflow clipping\&. The \fBvolume\fR ranges from 0 to \fBSDL_MIX_MAXVOLUME\fP and should be set to the maximum value for full audio volume\&. Note this does not change hardware volume\&. This is provided for convenience -- you can mix your own audio data\&. +.PP +.RS +\fBNote: +.PP +Do not use this function for mixing together more than two streams of sample data\&. The output from repeated application of this function may be distorted by clipping, because there is no accumulator with greater range than the input (not to mention this being an inefficient way of doing it)\&. Use mixing functions from SDL_mixer, OpenAL, or write your own mixer instead\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_OpenAudio\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_MouseButtonEvent.3 b/Externals/SDL/docs/man3/SDL_MouseButtonEvent.3 new file mode 100644 index 0000000000..d2d34a02b2 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_MouseButtonEvent.3 @@ -0,0 +1,36 @@ +.TH "SDL_MouseButtonEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_MouseButtonEvent \- Mouse button event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 button; + Uint8 state; + Uint16 x, y; +} SDL_MouseButtonEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_MOUSEBUTTONDOWN\fP or \fBSDL_MOUSEBUTTONUP\fP +.TP 20 +\fBbutton\fR +The mouse button index (SDL_BUTTON_LEFT, SDL_BUTTON_MIDDLE, SDL_BUTTON_RIGHT) +.TP 20 +\fBstate\fR +\fBSDL_PRESSED\fP or \fBSDL_RELEASED\fP +.TP 20 +\fBx\fR, \fBy\fR +The X/Y coordinates of the mouse at press/release time +.SH "DESCRIPTION" +.PP +\fBSDL_MouseButtonEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_MOUSEBUTTONDOWN\fP or \fBSDL_MOUSEBUTTONUP\fP is reported\&. +.PP +When a mouse button press or release is detected then number of the button pressed (from 1 to 255, with 1 usually being the left button and 2 the right) is placed into \fBbutton\fR, the position of the mouse when this event occured is stored in the \fBx\fR and the \fBy\fR fields\&. Like \fI\fBSDL_KeyboardEvent\fR\fR, information on whether the event was a press or a release event is stored in both the \fBtype\fR and \fBstate\fR fields, but this should be obvious\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_MouseMotionEvent\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_MouseMotionEvent.3 b/Externals/SDL/docs/man3/SDL_MouseMotionEvent.3 new file mode 100644 index 0000000000..c1b036d2a9 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_MouseMotionEvent.3 @@ -0,0 +1,38 @@ +.TH "SDL_MouseMotionEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_MouseMotionEvent \- Mouse motion event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + Uint8 state; + Uint16 x, y; + Sint16 xrel, yrel; +} SDL_MouseMotionEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_MOUSEMOTION\fP +.TP 20 +\fBstate\fR +The current button state +.TP 20 +\fBx\fR, \fBy\fR +The X/Y coordinates of the mouse +.TP 20 +\fBxrel\fR, \fByrel\fR +Relative motion in the X/Y direction +.SH "DESCRIPTION" +.PP +\fBSDL_MouseMotionEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_MOUSEMOTION\fP is reported\&. +.PP +Simply put, a \fBSDL_MOUSEMOTION\fP type event occurs when a user moves the mouse within the application window or when \fI\fBSDL_WarpMouse\fP\fR is called\&. Both the absolute (\fBx\fR and \fBy\fR) and relative (\fBxrel\fR and \fByrel\fR) coordinates are reported along with the current button states (\fBstate\fR)\&. The button state can be interpreted using the \fBSDL_BUTTON\fP macro (see \fI\fBSDL_GetMouseState\fP\fR)\&. +.PP +If the cursor is hidden (\fI\fBSDL_ShowCursor\fP(0)\fR) and the input is grabbed (\fI\fBSDL_WM_GrabInput\fP(SDL_GRAB_ON)\fR), then the mouse will give relative motion events even when the cursor reaches the edge fo the screen\&. This is currently only implemented on Windows and Linux/Unix-a-likes\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_MouseButtonEvent\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_NumJoysticks.3 b/Externals/SDL/docs/man3/SDL_NumJoysticks.3 new file mode 100644 index 0000000000..c737a1c5c8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_NumJoysticks.3 @@ -0,0 +1,18 @@ +.TH "SDL_NumJoysticks" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_NumJoysticks \- Count available joysticks\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_NumJoysticks\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +Counts the number of joysticks attached to the system\&. +.SH "RETURN VALUE" +.PP +Returns the number of attached joysticks +.SH "SEE ALSO" +.PP +\fI\fBSDL_JoystickName\fP\fR, \fI\fBSDL_JoystickOpen\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_OpenAudio.3 b/Externals/SDL/docs/man3/SDL_OpenAudio.3 new file mode 100644 index 0000000000..38a232ce71 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_OpenAudio.3 @@ -0,0 +1,97 @@ +.TH "SDL_OpenAudio" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_OpenAudio \- Opens the audio device with the desired parameters\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_OpenAudio\fP\fR(\fBSDL_AudioSpec *desired, SDL_AudioSpec *obtained\fR); +.SH "DESCRIPTION" +.PP +This function opens the audio device with the \fBdesired\fR parameters, and returns 0 if successful, placing the actual hardware parameters in the structure pointed to by \fBobtained\fR\&. If \fBobtained\fR is NULL, the audio data passed to the callback function will be guaranteed to be in the requested format, and will be automatically converted to the hardware audio format if necessary\&. This function returns -1 if it failed to open the audio device, or couldn\&'t set up the audio thread\&. +.PP +To open the audio device a \fBdesired\fR \fI\fBSDL_AudioSpec\fR\fR must be created\&. +.PP +.nf +\f(CWSDL_AudioSpec *desired; +\&. +\&. +desired=(SDL_AudioSpec *)malloc(sizeof(SDL_AudioSpec));\fR +.fi +.PP + You must then fill this structure with your desired audio specifications\&. +.IP "\fBdesired\fR->\fBfreq\fR" 10The desired audio frequency in samples-per-second\&. +.IP "\fBdesired\fR->\fBformat\fR" 10The desired audio format (see \fI\fBSDL_AudioSpec\fR\fR) +.IP "\fBdesired\fR->\fBsamples\fR" 10The desired size of the audio buffer in samples\&. This number should be a power of two, and may be adjusted by the audio driver to a value more suitable for the hardware\&. Good values seem to range between 512 and 8192 inclusive, depending on the application and CPU speed\&. Smaller values yield faster response time, but can lead to underflow if the application is doing heavy processing and cannot fill the audio buffer in time\&. A stereo sample consists of both right and left channels in LR ordering\&. Note that the number of samples is directly related to time by the following formula: ms = (samples*1000)/freq +.IP "\fBdesired\fR->\fBcallback\fR" 10This should be set to a function that will be called when the audio device is ready for more data\&. It is passed a pointer to the audio buffer, and the length in bytes of the audio buffer\&. This function usually runs in a separate thread, and so you should protect data structures that it accesses by calling \fI\fBSDL_LockAudio\fP\fR and \fI\fBSDL_UnlockAudio\fP\fR in your code\&. The callback prototype is: +.PP +.nf +\f(CWvoid callback(void *userdata, Uint8 *stream, int len);\fR +.fi +.PP + \fBuserdata\fR is the pointer stored in \fBuserdata\fR field of the \fBSDL_AudioSpec\fR\&. \fBstream\fR is a pointer to the audio buffer you want to fill with information and \fBlen\fR is the length of the audio buffer in bytes\&. +.IP "\fBdesired\fR->\fBuserdata\fR" 10This pointer is passed as the first parameter to the \fBcallback\fP function\&. +.PP +\fBSDL_OpenAudio\fP reads these fields from the \fBdesired\fR \fBSDL_AudioSpec\fR structure pass to the function and attempts to find an audio configuration matching your \fBdesired\fR\&. As mentioned above, if the \fBobtained\fR parameter is \fBNULL\fP then SDL with convert from your \fBdesired\fR audio settings to the hardware settings as it plays\&. +.PP +If \fBobtained\fR is \fBNULL\fP then the \fBdesired\fR \fBSDL_AudioSpec\fR is your working specification, otherwise the \fBobtained\fR \fBSDL_AudioSpec\fR becomes the working specification and the \fBdesirec\fR specification can be deleted\&. The data in the working specification is used when building \fBSDL_AudioCVT\fR\&'s for converting loaded data to the hardware format\&. +.PP +\fBSDL_OpenAudio\fP calculates the \fBsize\fR and \fBsilence\fR fields for both the \fBdesired\fR and \fBobtained\fR specifications\&. The \fBsize\fR field stores the total size of the audio buffer in bytes, while the \fBsilence\fR stores the value used to represent silence in the audio buffer +.PP +The audio device starts out playing \fBsilence\fR when it\&'s opened, and should be enabled for playing by calling \fI\fBSDL_PauseAudio\fP(\fB0\fR)\fR when you are ready for your audio \fBcallback\fR function to be called\&. Since the audio driver may modify the requested \fBsize\fR of the audio buffer, you should allocate any local mixing buffers after you open the audio device\&. +.SH "EXAMPLES" +.PP +.nf +\f(CW/* Prototype of our callback function */ +void my_audio_callback(void *userdata, Uint8 *stream, int len); + +/* Open the audio device */ +SDL_AudioSpec *desired, *obtained; +SDL_AudioSpec *hardware_spec; + +/* Allocate a desired SDL_AudioSpec */ +desired=(SDL_AudioSpec *)malloc(sizeof(SDL_AudioSpec)); + +/* Allocate space for the obtained SDL_AudioSpec */ +obtained=(SDL_AudioSpec *)malloc(sizeof(SDL_AudioSpec)); + +/* 22050Hz - FM Radio quality */ +desired->freq=22050; + +/* 16-bit signed audio */ +desired->format=AUDIO_S16LSB; + +/* Mono */ +desired->channels=0; + +/* Large audio buffer reduces risk of dropouts but increases response time */ +desired->samples=8192; + +/* Our callback function */ +desired->callback=my_audio_callback; + +desired->userdata=NULL; + +/* Open the audio device */ +if ( SDL_OpenAudio(desired, obtained) < 0 ){ + fprintf(stderr, "Couldn\&'t open audio: %s +", SDL_GetError()); + exit(-1); +} +/* desired spec is no longer needed */ +free(desired); +hardware_spec=obtained; +\&. +\&. +/* Prepare callback for playing */ +\&. +\&. +\&. +/* Start playing */ +SDL_PauseAudio(0);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_AudioSpec\fP\fR, \fI\fBSDL_LockAudio\fP\fR, \fI\fBSDL_UnlockAudio\fP\fR, \fI\fBSDL_PauseAudio\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_Overlay.3 b/Externals/SDL/docs/man3/SDL_Overlay.3 new file mode 100644 index 0000000000..a852e918f6 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Overlay.3 @@ -0,0 +1,52 @@ +.TH "SDL_Overlay" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Overlay \- YUV video overlay +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint32 format; + int w, h; + int planes; + Uint16 *pitches; + Uint8 **pixels; + Uint32 hw_overlay:1; +} SDL_Overlay;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBformat\fR +Overlay format (see below) +.TP 20 +\fBw, h\fR +Width and height of overlay +.TP 20 +\fBplanes\fR +Number of planes in the overlay\&. Usually either 1 or 3 +.TP 20 +\fBpitches\fR +An array of pitches, one for each plane\&. Pitch is the length of a row in bytes\&. +.TP 20 +\fBpixels\fR +An array of pointers to teh data of each plane\&. The overlay should be locked before these pointers are used\&. +.TP 20 +\fBhw_overlay\fR +This will be set to 1 if the overlay is hardware accelerated\&. +.SH "DESCRIPTION" +.PP +A \fBSDL_Overlay\fR is similar to a \fI\fBSDL_Surface\fR\fR except it stores a YUV overlay\&. All the fields are read only, except for \fBpixels\fR which should be \fIlocked\fR before use\&. The \fBformat\fR field stores the format of the overlay which is one of the following: +.PP +.nf +\f(CW#define SDL_YV12_OVERLAY 0x32315659 /* Planar mode: Y + V + U */ +#define SDL_IYUV_OVERLAY 0x56555949 /* Planar mode: Y + U + V */ +#define SDL_YUY2_OVERLAY 0x32595559 /* Packed mode: Y0+U0+Y1+V0 */ +#define SDL_UYVY_OVERLAY 0x59565955 /* Packed mode: U0+Y0+V0+Y1 */ +#define SDL_YVYU_OVERLAY 0x55595659 /* Packed mode: Y0+V0+Y1+U0 */\fR +.fi +.PP + More information on YUV formats can be found at \fIhttp://www\&.webartz\&.com/fourcc/indexyuv\&.htm (link to URL http://www.webartz.com/fourcc/indexyuv.htm) \fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateYUVOverlay\fP\fR, \fI\fBSDL_LockYUVOverlay\fP\fR, \fI\fBSDL_UnlockYUVOverlay\fP\fR, \fI\fBSDL_FreeYUVOverlay\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_Palette.3 b/Externals/SDL/docs/man3/SDL_Palette.3 new file mode 100644 index 0000000000..ea5e406d56 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Palette.3 @@ -0,0 +1,26 @@ +.TH "SDL_Palette" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Palette \- Color palette for 8-bit pixel formats +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + int ncolors; + SDL_Color *colors; +} SDL_Palette;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBncolors\fR +Number of colors used in this palette +.TP 20 +\fBcolors\fR +Pointer to \fI\fBSDL_Color\fR\fR structures that make up the palette\&. +.SH "DESCRIPTION" +.PP +Each pixel in an 8-bit surface is an index into the \fBcolors\fR field of the \fBSDL_Palette\fR structure store in \fI\fBSDL_PixelFormat\fR\fR\&. A \fBSDL_Palette\fR should never need to be created manually\&. It is automatically created when SDL allocates a \fBSDL_PixelFormat\fR for a surface\&. The colors values of a \fI\fBSDL_Surface\fR\fRs palette can be set with the \fI\fBSDL_SetColors\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Color\fR\fR, \fI\fBSDL_Surface\fR\fR, \fI\fBSDL_SetColors\fP\fR \fI\fBSDL_SetPalette\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_PauseAudio.3 b/Externals/SDL/docs/man3/SDL_PauseAudio.3 new file mode 100644 index 0000000000..1ca979a81b --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_PauseAudio.3 @@ -0,0 +1,15 @@ +.TH "SDL_PauseAudio" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_PauseAudio \- Pauses and unpauses the audio callback processing +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_PauseAudio\fP\fR(\fBint pause_on\fR); +.SH "DESCRIPTION" +.PP +This function pauses and unpauses the audio callback processing\&. It should be called with \fBpause_on\fR=0 after opening the audio device to start playing sound\&. This is so you can safely initialize data for your callback function after opening the audio device\&. Silence will be written to the audio device during the pause\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetAudioStatus\fP\fR, \fI\fBSDL_OpenAudio\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_PeepEvents.3 b/Externals/SDL/docs/man3/SDL_PeepEvents.3 new file mode 100644 index 0000000000..016542df8f --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_PeepEvents.3 @@ -0,0 +1,26 @@ +.TH "SDL_PeepEvents" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_PeepEvents \- Checks the event queue for messages and optionally returns them\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_PeepEvents\fP\fR(\fBSDL_Event *events, int numevents, SDL_eventaction action, Uint32 mask\fR); +.SH "DESCRIPTION" +.PP +Checks the event queue for messages and optionally returns them\&. +.PP +If \fBaction\fR is \fBSDL_ADDEVENT\fP, up to \fBnumevents\fR events will be added to the back of the event queue\&. +.PP +If \fBaction\fR is \fBSDL_PEEKEVENT\fP, up to \fBnumevents\fR events at the front of the event queue, matching \fI\fBmask\fR\fR, will be returned and will not be removed from the queue\&. +.PP +If \fBaction\fR is \fBSDL_GETEVENT\fP, up to \fBnumevents\fR events at the front of the event queue, matching \fI\fBmask\fR\fR, will be returned and will be removed from the queue\&. +.PP +This function is thread-safe\&. +.SH "RETURN VALUE" +.PP +This function returns the number of events actually stored, or \fB-1\fR if there was an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_PollEvent\fP\fR, \fI\fBSDL_PushEvent\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_PixelFormat.3 b/Externals/SDL/docs/man3/SDL_PixelFormat.3 new file mode 100644 index 0000000000..f91593ebb0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_PixelFormat.3 @@ -0,0 +1,140 @@ +.TH "SDL_PixelFormat" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_PixelFormat \- Stores surface format information +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct SDL_PixelFormat { + SDL_Palette *palette; + Uint8 BitsPerPixel; + Uint8 BytesPerPixel; + Uint8 Rloss, Gloss, Bloss, Aloss; + Uint8 Rshift, Gshift, Bshift, Ashift; + Uint32 Rmask, Gmask, Bmask, Amask; + Uint32 colorkey; + Uint8 alpha; +} SDL_PixelFormat;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBpalette\fR +Pointer to the \fIpalette\fR, or \fBNULL\fP if the \fBBitsPerPixel\fR>8 +.TP 20 +\fBBitsPerPixel\fR +The number of bits used to represent each pixel in a surface\&. Usually 8, 16, 24 or 32\&. +.TP 20 +\fBBytesPerPixel\fR +The number of bytes used to represent each pixel in a surface\&. Usually one to four\&. +.TP 20 +\fB[RGBA]mask\fR +Binary mask used to retrieve individual color values +.TP 20 +\fB[RGBA]loss\fR +Precision loss of each color component (2^[RGBA]loss) +.TP 20 +\fB[RGBA]shift\fR +Binary left shift of each color component in the pixel value +.TP 20 +\fBcolorkey\fR +Pixel value of transparent pixels +.TP 20 +\fBalpha\fR +Overall surface alpha value +.SH "DESCRIPTION" +.PP +A \fBSDL_PixelFormat\fR describes the format of the pixel data stored at the \fBpixels\fR field of a \fI\fBSDL_Surface\fR\fR\&. Every surface stores a \fBSDL_PixelFormat\fR in the \fBformat\fR field\&. +.PP +If you wish to do pixel level modifications on a surface, then understanding how SDL stores its color information is essential\&. +.PP +8-bit pixel formats are the easiest to understand\&. Since its an 8-bit format, we have 8 \fBBitsPerPixel\fR and 1 \fBBytesPerPixel\fR\&. Since \fBBytesPerPixel\fR is 1, all pixels are represented by a Uint8 which contains an index into \fBpalette\fR->\fBcolors\fR\&. So, to determine the color of a pixel in a 8-bit surface: we read the color index from \fBsurface\fR->\fBpixels\fR and we use that index to read the \fI\fBSDL_Color\fR\fR structure from \fBsurface\fR->\fBformat\fR->\fBpalette\fR->\fBcolors\fR\&. Like so: +.PP +.nf +\f(CWSDL_Surface *surface; +SDL_PixelFormat *fmt; +SDL_Color *color; +Uint8 index; + +\&. +\&. + +/* Create surface */ +\&. +\&. +fmt=surface->format; + +/* Check the bitdepth of the surface */ +if(fmt->BitsPerPixel!=8){ + fprintf(stderr, "Not an 8-bit surface\&. +"); + return(-1); +} + +/* Lock the surface */ +SDL_LockSurface(surface); + +/* Get the topleft pixel */ +index=*(Uint8 *)surface->pixels; +color=fmt->palette->colors[index]; + +/* Unlock the surface */ +SDL_UnlockSurface(surface); +printf("Pixel Color-> Red: %d, Green: %d, Blue: %d\&. Index: %d +", + color->r, color->g, color->b, index); +\&. +\&.\fR +.fi +.PP +.PP +Pixel formats above 8-bit are an entirely different experience\&. They are considered to be "TrueColor" formats and the color information is stored in the pixels themselves, not in a palette\&. The mask, shift and loss fields tell us how the color information is encoded\&. The mask fields allow us to isolate each color component, the shift fields tell us the number of bits to the right of each component in the pixel value and the loss fields tell us the number of bits lost from each component when packing 8-bit color component in a pixel\&. +.PP +.nf +\f(CW/* Extracting color components from a 32-bit color value */ +SDL_PixelFormat *fmt; +SDL_Surface *surface; +Uint32 temp, pixel; +Uint8 red, green, blue, alpha; +\&. +\&. +\&. +fmt=surface->format; +SDL_LockSurface(surface); +pixel=*((Uint32*)surface->pixels); +SDL_UnlockSurface(surface); + +/* Get Red component */ +temp=pixel&fmt->Rmask; /* Isolate red component */ +temp=temp>>fmt->Rshift;/* Shift it down to 8-bit */ +temp=temp<Rloss; /* Expand to a full 8-bit number */ +red=(Uint8)temp; + +/* Get Green component */ +temp=pixel&fmt->Gmask; /* Isolate green component */ +temp=temp>>fmt->Gshift;/* Shift it down to 8-bit */ +temp=temp<Gloss; /* Expand to a full 8-bit number */ +green=(Uint8)temp; + +/* Get Blue component */ +temp=pixel&fmt->Bmask; /* Isolate blue component */ +temp=temp>>fmt->Bshift;/* Shift it down to 8-bit */ +temp=temp<Bloss; /* Expand to a full 8-bit number */ +blue=(Uint8)temp; + +/* Get Alpha component */ +temp=pixel&fmt->Amask; /* Isolate alpha component */ +temp=temp>>fmt->Ashift;/* Shift it down to 8-bit */ +temp=temp<Aloss; /* Expand to a full 8-bit number */ +alpha=(Uint8)temp; + +printf("Pixel Color -> R: %d, G: %d, B: %d, A: %d +", red, green, blue, alpha); +\&. +\&. +\&.\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_Surface\fR\fR, \fI\fBSDL_MapRGB\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_PollEvent.3 b/Externals/SDL/docs/man3/SDL_PollEvent.3 new file mode 100644 index 0000000000..6197f7e1b6 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_PollEvent.3 @@ -0,0 +1,44 @@ +.TH "SDL_PollEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_PollEvent \- Polls for currently pending events\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_PollEvent\fP\fR(\fBSDL_Event *event\fR); +.SH "DESCRIPTION" +.PP +Polls for currently pending events, and returns \fB1\fR if there are any pending events, or \fB0\fR if there are none available\&. +.PP +If \fBevent\fR is not \fBNULL\fP, the next event is removed from the queue and stored in that area\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWSDL_Event event; /* Event structure */ + +\&. +\&. +\&. +/* Check for events */ +while(SDL_PollEvent(&event)){ /* Loop until there are no events left on the queue */ + switch(event\&.type){ /* Process the appropiate event type */ + case SDL_KEYDOWN: /* Handle a KEYDOWN event */ + printf("Oh! Key press +"); + break; + case SDL_MOUSEMOTION: + \&. + \&. + \&. + default: /* Report an unhandled event */ + printf("I don\&'t know what this event is! +"); + } +}\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_WaitEvent\fP\fR, \fI\fBSDL_PeepEvents\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_PumpEvents.3 b/Externals/SDL/docs/man3/SDL_PumpEvents.3 new file mode 100644 index 0000000000..62cc13d9e0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_PumpEvents.3 @@ -0,0 +1,23 @@ +.TH "SDL_PumpEvents" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_PumpEvents \- Pumps the event loop, gathering events from the input devices\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_PumpEvents\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +Pumps the event loop, gathering events from the input devices\&. +.PP +\fBSDL_PumpEvents\fP gathers all the pending input information from devices and places it on the event queue\&. Without calls to \fBSDL_PumpEvents\fP no events would ever be placed on the queue\&. Often calls the need for \fBSDL_PumpEvents\fP is hidden from the user since \fI\fBSDL_PollEvent\fP\fR and \fI\fBSDL_WaitEvent\fP\fR implicitly call \fBSDL_PumpEvents\fP\&. However, if you are not polling or waiting for events (e\&.g\&. your filtering them), then you must call \fBSDL_PumpEvents\fP to force an event queue update\&. +.PP +.RS +\fBNote: +.PP +You can only call this function in the thread that set the video mode\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_PollEvent\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_PushEvent.3 b/Externals/SDL/docs/man3/SDL_PushEvent.3 new file mode 100644 index 0000000000..4be188f125 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_PushEvent.3 @@ -0,0 +1,27 @@ +.TH "SDL_PushEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_PushEvent \- Pushes an event onto the event queue +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_PushEvent\fP\fR(\fBSDL_Event *event\fR); +.SH "DESCRIPTION" +.PP +The event queue can actually be used as a two way communication channel\&. Not only can events be read from the queue, but the user can also push their own events onto it\&. \fBevent\fR is a pointer to the event structure you wish to push onto the queue\&. +.PP +.RS +\fBNote: +.PP +Pushing device input events onto the queue doesn\&'t modify the state of the device within SDL\&. +.RE +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on success or \fB-1\fR if the event couldn\&'t be pushed\&. +.SH "EXAMPLES" +.PP +See \fI\fBSDL_Event\fR\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_PollEvent\fP\fR, \fI\fBSDL_PeepEvents\fP\fR, \fI\fBSDL_Event\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_Quit.3 b/Externals/SDL/docs/man3/SDL_Quit.3 new file mode 100644 index 0000000000..42fe8c1b2d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Quit.3 @@ -0,0 +1,29 @@ +.TH "SDL_Quit" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Quit \- Shut down SDL +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_Quit\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_Quit\fP shuts down all SDL subsystems and frees the resources allocated to them\&. This should always be called before you exit\&. For the sake of simplicity you can set \fBSDL_Quit\fP as your \fBatexit\fP call, like: +.PP +.nf +\f(CWSDL_Init(SDL_INIT_VIDEO|SDL_INIT_AUDIO); +atexit(SDL_Quit); +\&. +\&.\fR +.fi +.PP +.PP +.RS +\fBNote: +.PP +While using \fBatexit\fP maybe be fine for small programs, more advanced users should shut down SDL in their own cleanup code\&. Plus, using \fBatexit\fP in a library is a sure way to crash dynamically loaded code +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_QuitSubsystem\fP\fR, \fI\fBSDL_Init\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_QuitEvent.3 b/Externals/SDL/docs/man3/SDL_QuitEvent.3 new file mode 100644 index 0000000000..c357e2a31c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_QuitEvent.3 @@ -0,0 +1,30 @@ +.TH "SDL_QuitEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_QuitEvent \- Quit requested event +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type +} SDL_QuitEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_QUIT\fP +.SH "DESCRIPTION" +.PP +\fBSDL_QuitEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used whan an event of type \fBSDL_QUIT\fP is reported\&. +.PP +As can be seen, the SDL_QuitEvent structure serves no useful purpose\&. The event itself, on the other hand, is very important\&. If you filter out or ignore a quit event then it is impossible for the user to close the window\&. On the other hand, if you do accept a quit event then the application window will be closed, and screen updates will still report success event though the application will no longer be visible\&. +.PP +.RS +\fBNote: +.PP +The macro \fBSDL_QuitRequested\fP will return non-zero if a quit event is pending +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_SetEventFilter\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_QuitSubSystem.3 b/Externals/SDL/docs/man3/SDL_QuitSubSystem.3 new file mode 100644 index 0000000000..79e3ca592d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_QuitSubSystem.3 @@ -0,0 +1,15 @@ +.TH "SDL_QuitSubSystem" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_QuitSubSystem \- Shut down a subsystem +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_QuitSubSystem\fP\fR(\fBUint32 flags\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_QuitSubSystem\fP allows you to shut down a subsystem that has been previously initialized by \fI\fBSDL_Init\fP\fR or \fI\fBSDL_InitSubSystem\fP\fR\&. The \fBflags\fR tells \fBSDL_QuitSubSystem\fP which subsystems to shut down, it uses the same values that are passed to \fI\fBSDL_Init\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Quit\fP\fR, \fI\fBSDL_Init\fP\fR, \fI\fBSDL_InitSubSystem\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_RWFromFile.3 b/Externals/SDL/docs/man3/SDL_RWFromFile.3 new file mode 100644 index 0000000000..9ea68b93d7 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_RWFromFile.3 @@ -0,0 +1,18 @@ +.TH "SDL_FunctionName" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_FunctionName \- Short description of function +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBreturn type\fBSDL_FunctionName\fP\fR(\fBparameter\fR); +.SH "DESCRIPTION" +.PP +Full description +.SH "EXAMPLES" +.PP +examples here +.SH "SEE ALSO" +.PP +\fISDL_AnotherFunction\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_Rect.3 b/Externals/SDL/docs/man3/SDL_Rect.3 new file mode 100644 index 0000000000..8db224de65 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Rect.3 @@ -0,0 +1,26 @@ +.TH "SDL_Rect" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Rect \- Defines a rectangular area +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Sint16 x, y; + Uint16 w, h; +} SDL_Rect;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBx, y\fR +Position of the upper-left corner of the rectangle +.TP 20 +\fBw, h\fR +The width and height of the rectangle +.SH "DESCRIPTION" +.PP +A \fBSDL_Rect\fR defines a rectangular area of pixels\&. It is used by \fI\fBSDL_BlitSurface\fP\fR to define blitting regions and by several other video functions\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_BlitSurface\fP\fR, \fI\fBSDL_UpdateRect\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_RemoveTimer.3 b/Externals/SDL/docs/man3/SDL_RemoveTimer.3 new file mode 100644 index 0000000000..1203c6f54f --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_RemoveTimer.3 @@ -0,0 +1,25 @@ +.TH "SDL_RemoveTimer" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_RemoveTimer \- Remove a timer which was added with \fISDL_AddTimer\fR\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_bool \fBSDL_RemoveTimer\fP\fR(\fBSDL_TimerID id\fR); +.SH "DESCRIPTION" +.PP +Removes a timer callback previously added with \fISDL_AddTimer\fR\&. +.SH "RETURN VALUE" +.PP +Returns a boolean value indicating success\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWSDL_RemoveTimer(my_timer_id);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_AddTimer\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_ResizeEvent.3 b/Externals/SDL/docs/man3/SDL_ResizeEvent.3 new file mode 100644 index 0000000000..7b0a5e2650 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ResizeEvent.3 @@ -0,0 +1,28 @@ +.TH "SDL_ResizeEvent" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ResizeEvent \- Window resize event structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + int w, h; +} SDL_ResizeEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_VIDEORESIZE\fP +.TP 20 +\fBw\fR, \fBh\fR +New width and height of the window +.SH "DESCRIPTION" +.PP +\fBSDL_ResizeEvent\fR is a member of the \fI\fBSDL_Event\fR\fR union and is used when an event of type \fBSDL_VIDEORESIZE\fP is reported\&. +.PP +When \fBSDL_RESIZABLE\fP is passed as a \fBflag\fR to \fI\fBSDL_SetVideoMode\fP\fR the user is allowed to resize the applications window\&. When the window is resized an \fBSDL_VIDEORESIZE\fP is report, with the new window width and height values stored in \fBw\fR and \fBh\fR, respectively\&. When an \fBSDL_VIDEORESIZE\fP is received the window should be resized to the new dimensions using \fI\fBSDL_SetVideoMode\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_SetVideoMode\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_SaveBMP.3 b/Externals/SDL/docs/man3/SDL_SaveBMP.3 new file mode 100644 index 0000000000..61e00dd51d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SaveBMP.3 @@ -0,0 +1,18 @@ +.TH "SDL_SaveBMP" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SaveBMP \- Save an SDL_Surface as a Windows BMP file\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SaveBMP\fP\fR(\fBSDL_Surface *surface, const char *file\fR); +.SH "DESCRIPTION" +.PP +Saves the \fBSDL_Surface\fR \fBsurface\fR as a Windows BMP file named \fBfile\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR if successful or \fB-1\fR if there was an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_LoadBMP\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SemPost.3 b/Externals/SDL/docs/man3/SDL_SemPost.3 new file mode 100644 index 0000000000..5487d2d5ac --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SemPost.3 @@ -0,0 +1,28 @@ +.TH "SDL_SemPost" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SemPost \- Unlock a semaphore\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_SemPost\fP\fR(\fBSDL_sem *sem\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_SemPost\fP unlocks the semaphore pointed to by \fBsem\fR and atomically increments the semaphores value\&. Threads that were blocking on the semaphore may be scheduled after this call succeeds\&. +.PP +\fBSDL_SemPost\fP should be called after a semaphore is locked by a successful call to \fISDL_SemWait\fR, \fISDL_SemTryWait\fR or \fISDL_SemWaitTimeout\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR if successful or \fB-1\fR if there was an error (leaving the semaphore unchanged)\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWSDL_SemPost(my_sem);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateSemaphore\fP\fR, \fI\fBSDL_DestroySemaphore\fP\fR, \fI\fBSDL_SemWait\fP\fR, \fI\fBSDL_SemTryWait\fP\fR, \fI\fBSDL_SemWaitTimeout\fP\fR, \fI\fBSDL_SemValue\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_SemTryWait.3 b/Externals/SDL/docs/man3/SDL_SemTryWait.3 new file mode 100644 index 0000000000..aee9aff191 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SemTryWait.3 @@ -0,0 +1,41 @@ +.TH "SDL_SemTryWait" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SemTryWait \- Attempt to lock a semaphore but don\&'t suspend the thread\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_SemTryWait\fP\fR(\fBSDL_sem *sem\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_SemTryWait\fP is a non-blocking varient of \fI\fBSDL_SemWait\fP\fR\&. If the value of the semaphore pointed to by \fBsem\fR is positive it will atomically decrement the semaphore value and return 0, otherwise it will return \fBSDL_MUTEX_TIMEOUT\fR instead of suspending the thread\&. +.PP +After \fBSDL_SemTryWait\fP is successful, the semaphore can be released and its count atomically incremented by a successful call to \fISDL_SemPost\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR if the semaphore was successfully locked or either \fBSDL_MUTEX_TIMEOUT\fR or \fB-1\fR if the thread would have suspended or there was an error, respectivly\&. +.PP +If the semaphore was not successfully locked, the semaphore will be unchanged\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWres = SDL_SemTryWait(my_sem); + +if (res == SDL_MUTEX_TIMEOUT) { + return TRY_AGAIN; +} +if (res == -1) { + return WAIT_ERROR; +} + +\&.\&.\&. + +SDL_SemPost(my_sem);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateSemaphore\fP\fR, \fI\fBSDL_DestroySemaphore\fP\fR, \fI\fBSDL_SemWait\fP\fR, \fI\fBSDL_SemWaitTimeout\fP\fR, \fI\fBSDL_SemPost\fP\fR, \fI\fBSDL_SemValue\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_SemValue.3 b/Externals/SDL/docs/man3/SDL_SemValue.3 new file mode 100644 index 0000000000..0703143999 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SemValue.3 @@ -0,0 +1,26 @@ +.TH "SDL_SemValue" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SemValue \- Return the current value of a semaphore\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL/SDL_thread\&.h" +.sp +\fBUint32 \fBSDL_SemValue\fP\fR(\fBSDL_sem *sem\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_SemValue()\fP returns the current semaphore value from the semaphore pointed to by \fBsem\fR\&. +.SH "RETURN VALUE" +.PP +Returns current value of the semaphore\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CW sem_value = SDL_SemValue(my_sem);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateSemaphore\fP\fR, \fI\fBSDL_DestroySemaphore\fP\fR, \fI\fBSDL_SemWait\fP\fR, \fI\fBSDL_SemTryWait\fP\fR, \fI\fBSDL_SemWaitTimeout\fP\fR, \fI\fBSDL_SemPost\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_SemWait.3 b/Externals/SDL/docs/man3/SDL_SemWait.3 new file mode 100644 index 0000000000..b7bba3fb73 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SemWait.3 @@ -0,0 +1,34 @@ +.TH "SDL_SemWait" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SemWait \- Lock a semaphore and suspend the thread if the semaphore value is zero\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_SemWait\fP\fR(\fBSDL_sem *sem\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_SemWait()\fP suspends the calling thread until either the semaphore pointed to by \fBsem\fR has a positive value, the call is interrupted by a signal or error\&. If the call is successful it will atomically decrement the semaphore value\&. +.PP +After \fBSDL_SemWait()\fP is successful, the semaphore can be released and its count atomically incremented by a successful call to \fISDL_SemPost\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR if successful or \fB-1\fR if there was an error (leaving the semaphore unchanged)\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWif (SDL_SemWait(my_sem) == -1) { + return WAIT_FAILED; +} + +\&.\&.\&. + +SDL_SemPost(my_sem);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateSemaphore\fP\fR, \fI\fBSDL_DestroySemaphore\fP\fR, \fI\fBSDL_SemTryWait\fP\fR, \fI\fBSDL_SemWaitTimeout\fP\fR, \fI\fBSDL_SemPost\fP\fR, \fI\fBSDL_SemValue\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_SemWaitTimeout.3 b/Externals/SDL/docs/man3/SDL_SemWaitTimeout.3 new file mode 100644 index 0000000000..8afd1cb609 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SemWaitTimeout.3 @@ -0,0 +1,41 @@ +.TH "SDL_SemWaitTimeout" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SemWaitTimeout \- Lock a semaphore, but only wait up to a specified maximum time\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_SemWaitTimeout\fP\fR(\fBSDL_sem *sem, Uint32 timeout\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_SemWaitTimeout()\fP is a varient of \fISDL_SemWait\fR with a maximum timeout value\&. If the value of the semaphore pointed to by \fBsem\fR is positive (greater than zero) it will atomically decrement the semaphore value and return 0, otherwise it will wait up to \fBtimeout\fR milliseconds trying to lock the semaphore\&. This function is to be avoided if possible since on some platforms it is implemented by polling the semaphore every millisecond in a busy loop\&. +.PP +After \fBSDL_SemWaitTimeout()\fP is successful, the semaphore can be released and its count atomically incremented by a successful call to \fISDL_SemPost\fR\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR if the semaphore was successfully locked or either \fBSDL_MUTEX_TIMEOUT\fR or \fB-1\fR if the timeout period was exceeded or there was an error, respectivly\&. +.PP +If the semaphore was not successfully locked, the semaphore will be unchanged\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWres = SDL_SemWaitTimeout(my_sem, WAIT_TIMEOUT_MILLISEC); + +if (res == SDL_MUTEX_TIMEOUT) { + return TRY_AGAIN; +} +if (res == -1) { + return WAIT_ERROR; +} + +\&.\&.\&. + +SDL_SemPost(my_sem);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateSemaphore\fP\fR, \fI\fBSDL_DestroySemaphore\fP\fR, \fI\fBSDL_SemWait\fP\fR, \fI\fBSDL_SemTryWait\fP\fR, \fI\fBSDL_SemPost\fP\fR, \fI\fBSDL_SemValue\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_SetAlpha.3 b/Externals/SDL/docs/man3/SDL_SetAlpha.3 new file mode 100644 index 0000000000..282ecdedc5 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetAlpha.3 @@ -0,0 +1,66 @@ +.TH "SDL_SetAlpha" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetAlpha \- Adjust the alpha properties of a surface +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SetAlpha\fP\fR(\fBSDL_Surface *surface, Uint32 flag, Uint8 alpha\fR); +.SH "DESCRIPTION" +.PP +.RS +\fBNote: +.PP +This function and the semantics of SDL alpha blending have changed since version 1\&.1\&.4\&. Up until version 1\&.1\&.5, an alpha value of 0 was considered opaque and a value of 255 was considered transparent\&. This has now been inverted: 0 (\fBSDL_ALPHA_TRANSPARENT\fP) is now considered transparent and 255 (\fBSDL_ALPHA_OPAQUE\fP) is now considered opaque\&. +.RE +.PP +\fBSDL_SetAlpha\fP is used for setting the per-surface alpha value and/or enabling and disabling alpha blending\&. +.PP +The\fBsurface\fR parameter specifies which surface whose alpha attributes you wish to adjust\&. \fBflags\fR is used to specify whether alpha blending should be used (\fBSDL_SRCALPHA\fP) and whether the surface should use RLE acceleration for blitting (\fBSDL_RLEACCEL\fP)\&. \fBflags\fR can be an OR\&'d combination of these two options, one of these options or 0\&. If \fBSDL_SRCALPHA\fP is not passed as a flag then all alpha information is ignored when blitting the surface\&. The \fBalpha\fR parameter is the per-surface alpha value; a surface need not have an alpha channel to use per-surface alpha and blitting can still be accelerated with \fBSDL_RLEACCEL\fP\&. +.PP +.RS +\fBNote: +.PP +The per-surface alpha value of 128 is considered a special case and is optimised, so it\&'s much faster than other per-surface values\&. +.RE +.PP +Alpha effects surface blitting in the following ways: +.TP 20 +RGBA->RGB with \fBSDL_SRCALPHA\fP +The source is alpha-blended with the destination, using the alpha channel\&. \fBSDL_SRCCOLORKEY\fP and the per-surface alpha are ignored\&. +.TP 20 +RGBA->RGB without \fBSDL_SRCALPHA\fP +The RGB data is copied from the source\&. The source alpha channel and the per-surface alpha value are ignored\&. +.TP 20 +RGB->RGBA with \fBSDL_SRCALPHA\fP +The source is alpha-blended with the destination using the per-surface alpha value\&. If \fBSDL_SRCCOLORKEY\fP is set, only the pixels not matching the colorkey value are copied\&. The alpha channel of the copied pixels is set to opaque\&. +.TP 20 +RGB->RGBA without \fBSDL_SRCALPHA\fP +The RGB data is copied from the source and the alpha value of the copied pixels is set to opaque\&. If \fBSDL_SRCCOLORKEY\fP is set, only the pixels not matching the colorkey value are copied\&. +.TP 20 +RGBA->RGBA with \fBSDL_SRCALPHA\fP +The source is alpha-blended with the destination using the source alpha channel\&. The alpha channel in the destination surface is left untouched\&. \fBSDL_SRCCOLORKEY\fP is ignored\&. +.TP 20 +RGBA->RGBA without \fBSDL_SRCALPHA\fP +The RGBA data is copied to the destination surface\&. If \fBSDL_SRCCOLORKEY\fP is set, only the pixels not matching the colorkey value are copied\&. +.TP 20 +RGB->RGB with \fBSDL_SRCALPHA\fP +The source is alpha-blended with the destination using the per-surface alpha value\&. If \fBSDL_SRCCOLORKEY\fP is set, only the pixels not matching the colorkey value are copied\&. +.TP 20 +RGB->RGB without \fBSDL_SRCALPHA\fP +The RGB data is copied from the source\&. If \fBSDL_SRCCOLORKEY\fP is set, only the pixels not matching the colorkey value are copied\&. +.PP +.RS +\fBNote: +.PP + Note that RGBA->RGBA blits (with SDL_SRCALPHA set) keep the alpha of the destination surface\&. This means that you cannot compose two arbitrary RGBA surfaces this way and get the result you would expect from "overlaying" them; the destination alpha will work as a mask\&. +.PP +Also note that per-pixel and per-surface alpha cannot be combined; the per-pixel alpha is always used if available +.RE +.SH "RETURN VALUE" +.PP +This function returns \fB0\fR, or \fB-1\fR if there was an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_MapRGBA\fP\fR, \fI\fBSDL_GetRGBA\fP\fR, \fI\fBSDL_DisplayFormatAlpha\fP\fR, \fI\fBSDL_BlitSurface\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetClipRect.3 b/Externals/SDL/docs/man3/SDL_SetClipRect.3 new file mode 100644 index 0000000000..a1bde0818c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetClipRect.3 @@ -0,0 +1,19 @@ +.TH "SDL_SetClipRect" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetClipRect \- Sets the clipping rectangle for a surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_SetClipRect\fP\fR(\fBSDL_Surface *surface, SDL_Rect *rect\fR); +.SH "DESCRIPTION" +.PP +Sets the clipping rectangle for a surface\&. When this surface is the destination of a blit, only the area within the clip rectangle will be drawn into\&. +.PP +The rectangle pointed to by \fBrect\fR will be clipped to the edges of the surface so that the clip rectangle for a surface can never fall outside the edges of the surface\&. +.PP +If \fBrect\fR is \fBNULL\fP the clipping rectangle will be set to the full size of the surface\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetClipRect\fP\fR, \fI\fBSDL_BlitSurface\fP\fR, \fI\fBSDL_Surface\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetColorKey.3 b/Externals/SDL/docs/man3/SDL_SetColorKey.3 new file mode 100644 index 0000000000..36f88934a1 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetColorKey.3 @@ -0,0 +1,26 @@ +.TH "SDL_SetColorKey" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetColorKey \- Sets the color key (transparent pixel) in a blittable surface and RLE acceleration\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SetColorKey\fP\fR(\fBSDL_Surface *surface, Uint32 flag, Uint32 key\fR); +.SH "DESCRIPTION" +.PP + Sets the color key (transparent pixel) in a blittable surface and enables or disables RLE blit acceleration\&. +.PP +RLE acceleration can substantially speed up blitting of images with large horizontal runs of transparent pixels (i\&.e\&., pixels that match the \fBkey\fR value)\&. The \fBkey\fR must be of the same pixel format as the \fBsurface\fR, \fI\fBSDL_MapRGB\fP\fR is often useful for obtaining an acceptable value\&. +.PP +If \fBflag\fR is \fBSDL_SRCCOLORKEY\fP then \fBkey\fR is the transparent pixel value in the source image of a blit\&. +.PP +If \fBflag\fR is OR\&'d with \fBSDL_RLEACCEL\fP then the surface will be draw using RLE acceleration when drawn with \fISDL_BlitSurface\fR\&. The surface will actually be encoded for RLE acceleration the first time \fISDL_BlitSurface\fR or \fISDL_DisplayFormat\fR is called on the surface\&. +.PP +If \fBflag\fR is 0, this function clears any current color key\&. +.SH "RETURN VALUE" +.PP +This function returns \fB0\fR, or \fB-1\fR if there was an error\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_BlitSurface\fP\fR, \fI\fBSDL_DisplayFormat\fP\fR, \fI\fBSDL_MapRGB\fP\fR, \fI\fBSDL_SetAlpha\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetColors.3 b/Externals/SDL/docs/man3/SDL_SetColors.3 new file mode 100644 index 0000000000..7137a6c37d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetColors.3 @@ -0,0 +1,57 @@ +.TH "SDL_SetColors" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetColors \- Sets a portion of the colormap for the given 8-bit surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SetColors\fP\fR(\fBSDL_Surface *surface, SDL_Color *colors, int firstcolor, int ncolors\fR); +.SH "DESCRIPTION" +.PP +Sets a portion of the colormap for the given 8-bit surface\&. +.PP +When \fBsurface\fR is the surface associated with the current display, the display colormap will be updated with the requested colors\&. If \fBSDL_HWPALETTE\fP was set in \fISDL_SetVideoMode\fR flags, \fBSDL_SetColors\fP will always return \fB1\fR, and the palette is guaranteed to be set the way you desire, even if the window colormap has to be warped or run under emulation\&. +.PP +The color components of a \fI\fBSDL_Color\fR\fR structure are 8-bits in size, giving you a total of 256^3 =16777216 colors\&. +.PP +Palettized (8-bit) screen surfaces with the \fBSDL_HWPALETTE\fP flag have two palettes, a logical palette that is used for mapping blits to/from the surface and a physical palette (that determines how the hardware will map the colors to the display)\&. \fBSDL_SetColors\fP modifies both palettes (if present), and is equivalent to calling \fISDL_SetPalette\fR with the \fBflags\fR set to \fB(SDL_LOGPAL | SDL_PHYSPAL)\fP\&. +.SH "RETURN VALUE" +.PP +If \fBsurface\fR is not a palettized surface, this function does nothing, returning \fB0\fR\&. If all of the colors were set as passed to \fBSDL_SetColors\fP, it will return \fB1\fR\&. If not all the color entries were set exactly as given, it will return \fB0\fR, and you should look at the surface palette to determine the actual color palette\&. +.SH "EXAMPLE" +.PP +.nf +\f(CW/* Create a display surface with a grayscale palette */ +SDL_Surface *screen; +SDL_Color colors[256]; +int i; +\&. +\&. +\&. +/* Fill colors with color information */ +for(i=0;i<256;i++){ + colors[i]\&.r=i; + colors[i]\&.g=i; + colors[i]\&.b=i; +} + +/* Create display */ +screen=SDL_SetVideoMode(640, 480, 8, SDL_HWPALETTE); +if(!screen){ + printf("Couldn\&'t set video mode: %s +", SDL_GetError()); + exit(-1); +} + +/* Set palette */ +SDL_SetColors(screen, colors, 0, 256); +\&. +\&. +\&. +\&.\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_Color\fR\fR \fI\fBSDL_Surface\fR\fR, \fI\fBSDL_SetPalette\fP\fR, \fI\fBSDL_SetVideoMode\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetCursor.3 b/Externals/SDL/docs/man3/SDL_SetCursor.3 new file mode 100644 index 0000000000..78c4cf9f58 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetCursor.3 @@ -0,0 +1,15 @@ +.TH "SDL_SetCursor" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetCursor \- Set the currently active mouse cursor\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_SetCursor\fP\fR(\fBSDL_Cursor *cursor\fR); +.SH "DESCRIPTION" +.PP +Sets the currently active cursor to the specified one\&. If the cursor is currently visible, the change will be immediately represented on the display\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetCursor\fP\fR, \fI\fBSDL_CreateCursor\fP\fR, \fI\fBSDL_ShowCursor\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetEventFilter.3 b/Externals/SDL/docs/man3/SDL_SetEventFilter.3 new file mode 100644 index 0000000000..8d3ed034e3 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetEventFilter.3 @@ -0,0 +1,35 @@ +.TH "SDL_SetEventFilter" "3" "Tue 11 Sep 2001, 22:59" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetEventFilter \- Sets up a filter to process all events before they are posted to the event queue\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_SetEventFilter\fP\fR(\fBSDL_EventFilter filter\fR); +.SH "DESCRIPTION" +.PP +This function sets up a filter to process all events before they are posted to the event queue\&. This is a very powerful and flexible feature\&. The filter is prototyped as: +.PP +.nf +\f(CWtypedef int (*SDL_EventFilter)(const SDL_Event *event);\fR +.fi +.PP + If the filter returns \fB1\fR, then the event will be added to the internal queue\&. If it returns \fB0\fR, then the event will be dropped from the queue\&. This allows selective filtering of dynamically\&. +.PP +There is one caveat when dealing with the \fBSDL_QUITEVENT\fP event type\&. The event filter is only called when the window manager desires to close the application window\&. If the event filter returns 1, then the window will be closed, otherwise the window will remain open if possible\&. If the quit event is generated by an interrupt signal, it will bypass the internal queue and be delivered to the application at the next event poll\&. +.PP +.RS +\fBNote: +.PP +Events pushed onto the queue with \fI\fBSDL_PushEvent\fP\fR or \fI\fBSDL_PeepEvents\fP\fR do not get passed through the event filter\&. +.RE +.PP +.RS +\fBNote: +.PP +\fIBe Careful!\fP The event filter function may run in a different thread so be careful what you do within it\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_GetEventFilter\fP\fR, \fI\fBSDL_PushEvent\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:59 diff --git a/Externals/SDL/docs/man3/SDL_SetGamma.3 b/Externals/SDL/docs/man3/SDL_SetGamma.3 new file mode 100644 index 0000000000..4897272d01 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetGamma.3 @@ -0,0 +1,22 @@ +.TH "SDL_SetGamma" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetGamma \- Sets the color gamma function for the display +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SetGamma\fP\fR(\fBfloat redgamma, float greengamma, float bluegamma\fR); +.SH "DESCRIPTION" +.PP +Sets the "gamma function" for the display of each color component\&. Gamma controls the brightness/contrast of colors displayed on the screen\&. A gamma value of 1\&.0 is identity (i\&.e\&., no adjustment is made)\&. +.PP +This function adjusts the gamma based on the "gamma function" parameter, you can directly specify lookup tables for gamma adjustment with \fISDL_SetGammaRamp\fR\&. +.PP +Not all display hardware is able to change gamma\&. +.SH "RETURN VALUE" +.PP +Returns -1 on error (or if gamma adjustment is not supported)\&. +.SH "SEE ALSO" +.PP +\fISDL_GetGammaRamp\fR \fISDL_SetGammaRamp\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetGammaRamp.3 b/Externals/SDL/docs/man3/SDL_SetGammaRamp.3 new file mode 100644 index 0000000000..52bf9f5914 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetGammaRamp.3 @@ -0,0 +1,22 @@ +.TH "SDL_SetGammaRamp" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetGammaRamp \- Sets the color gamma lookup tables for the display +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SetGammaRamp\fP\fR(\fBUint16 *redtable, Uint16 *greentable, Uint16 *bluetable\fR); +.SH "DESCRIPTION" +.PP +Sets the gamma lookup tables for the display for each color component\&. Each table is an array of 256 Uint16 values, representing a mapping between the input and output for that channel\&. The input is the index into the array, and the output is the 16-bit gamma value at that index, scaled to the output color precision\&. You may pass NULL to any of the channels to leave them unchanged\&. +.PP +This function adjusts the gamma based on lookup tables, you can also have the gamma calculated based on a "gamma function" parameter with \fISDL_SetGamma\fR\&. +.PP +Not all display hardware is able to change gamma\&. +.SH "RETURN VALUE" +.PP +Returns -1 on error (or if gamma adjustment is not supported)\&. +.SH "SEE ALSO" +.PP +\fISDL_SetGamma\fR \fISDL_GetGammaRamp\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetModState.3 b/Externals/SDL/docs/man3/SDL_SetModState.3 new file mode 100644 index 0000000000..f356ca1e5f --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetModState.3 @@ -0,0 +1,35 @@ +.TH "SDL_SetModState" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetModState \- Set the current key modifier state +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_SetModState\fP\fR(\fBSDLMod modstate\fR); +.SH "DESCRIPTION" +.PP +The inverse of \fI\fBSDL_GetModState\fP\fR, \fBSDL_SetModState\fP allows you to impose modifier key states on your application\&. +.PP +Simply pass your desired modifier states into \fBmodstate\fR\&. This value my be a logical OR\&'d combination of the following: +.PP +.nf +\f(CWtypedef enum { + KMOD_NONE = 0x0000, + KMOD_LSHIFT= 0x0001, + KMOD_RSHIFT= 0x0002, + KMOD_LCTRL = 0x0040, + KMOD_RCTRL = 0x0080, + KMOD_LALT = 0x0100, + KMOD_RALT = 0x0200, + KMOD_LMETA = 0x0400, + KMOD_RMETA = 0x0800, + KMOD_NUM = 0x1000, + KMOD_CAPS = 0x2000, + KMOD_MODE = 0x4000, +} SDLMod;\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_GetModState\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_SetPalette.3 b/Externals/SDL/docs/man3/SDL_SetPalette.3 new file mode 100644 index 0000000000..a2ca3f618e --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetPalette.3 @@ -0,0 +1,59 @@ +.TH "SDL_SetPalette" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetPalette \- Sets the colors in the palette of an 8-bit surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SetPalette\fP\fR(\fBSDL_Surface *surface, int flags, SDL_Color *colors, int firstcolor, int ncolors\fR); +.SH "DESCRIPTION" +.PP +Sets a portion of the palette for the given 8-bit surface\&. +.PP +Palettized (8-bit) screen surfaces with the \fBSDL_HWPALETTE\fP flag have two palettes, a logical palette that is used for mapping blits to/from the surface and a physical palette (that determines how the hardware will map the colors to the display)\&. \fISDL_BlitSurface\fR always uses the logical palette when blitting surfaces (if it has to convert between surface pixel formats)\&. Because of this, it is often useful to modify only one or the other palette to achieve various special color effects (e\&.g\&., screen fading, color flashes, screen dimming)\&. +.PP +This function can modify either the logical or physical palette by specifing \fBSDL_LOGPAL\fP or \fBSDL_PHYSPAL\fPthe in the \fBflags\fR parameter\&. +.PP +When \fBsurface\fR is the surface associated with the current display, the display colormap will be updated with the requested colors\&. If \fBSDL_HWPALETTE\fP was set in \fISDL_SetVideoMode\fR flags, \fBSDL_SetPalette\fP will always return \fB1\fR, and the palette is guaranteed to be set the way you desire, even if the window colormap has to be warped or run under emulation\&. +.PP +The color components of a \fI\fBSDL_Color\fR\fR structure are 8-bits in size, giving you a total of 256^3=16777216 colors\&. +.SH "RETURN VALUE" +.PP +If \fBsurface\fR is not a palettized surface, this function does nothing, returning \fB0\fR\&. If all of the colors were set as passed to \fBSDL_SetPalette\fP, it will return \fB1\fR\&. If not all the color entries were set exactly as given, it will return \fB0\fR, and you should look at the surface palette to determine the actual color palette\&. +.SH "EXAMPLE" +.PP +.nf +\f(CW /* Create a display surface with a grayscale palette */ + SDL_Surface *screen; + SDL_Color colors[256]; + int i; + \&. + \&. + \&. + /* Fill colors with color information */ + for(i=0;i<256;i++){ + colors[i]\&.r=i; + colors[i]\&.g=i; + colors[i]\&.b=i; + } + + /* Create display */ + screen=SDL_SetVideoMode(640, 480, 8, SDL_HWPALETTE); + if(!screen){ + printf("Couldn\&'t set video mode: %s +", SDL_GetError()); + exit(-1); + } + + /* Set palette */ + SDL_SetPalette(screen, SDL_LOGPAL|SDL_PHYSPAL, colors, 0, 256); + \&. + \&. + \&. + \&.\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fISDL_SetColors\fR, \fISDL_SetVideoMode\fR, \fISDL_Surface\fR, \fISDL_Color\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetTimer.3 b/Externals/SDL/docs/man3/SDL_SetTimer.3 new file mode 100644 index 0000000000..418ac86b7d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetTimer.3 @@ -0,0 +1,39 @@ +.TH "SDL_SetTimer" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetTimer \- Set a callback to run after the specified number of milliseconds has elapsed\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_SetTimer\fP\fR(\fBUint32 interval, SDL_TimerCallback callback\fR); +.SH "CALLBACK" +.PP +/* Function prototype for the timer callback function */ typedef Uint32 (*SDL_TimerCallback)(Uint32 interval); +.SH "DESCRIPTION" +.PP +Set a callback to run after the specified number of milliseconds has elapsed\&. The callback function is passed the current timer interval and returns the next timer interval\&. If the returned value is the same as the one passed in, the periodic alarm continues, otherwise a new alarm is scheduled\&. +.PP +To cancel a currently running timer, call \fBSDL_SetTimer(0, NULL);\fP +.PP +The timer callback function may run in a different thread than your main constant, and so shouldn\&'t call any functions from within itself\&. +.PP +The maximum resolution of this timer is 10 ms, which means that if you request a 16 ms timer, your callback will run approximately 20 ms later on an unloaded system\&. If you wanted to set a flag signaling a frame update at 30 frames per second (every 33 ms), you might set a timer for 30 ms (see example below)\&. +.PP +If you use this function, you need to pass \fBSDL_INIT_TIMER\fP to \fBSDL_Init()\fP\&. +.PP +.RS +\fBNote: +.PP +This function is kept for compatibility but has been superseded by the new timer functions \fISDL_AddTimer\fR and \fISDL_RemoveTimer\fR which support multiple timers\&. +.RE +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWSDL_SetTimer((33/10)*10, my_callback);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_AddTimer\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SetVideoMode.3 b/Externals/SDL/docs/man3/SDL_SetVideoMode.3 new file mode 100644 index 0000000000..95defb1836 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SetVideoMode.3 @@ -0,0 +1,67 @@ +.TH "SDL_SetVideoMode" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SetVideoMode \- Set up a video mode with the specified width, height and bits-per-pixel\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_Surface *\fBSDL_SetVideoMode\fP\fR(\fBint width, int height, int bpp, Uint32 flags\fR); +.SH "DESCRIPTION" +.PP +Set up a video mode with the specified width, height and bits-per-pixel\&. +.PP +If \fBbpp\fR is 0, it is treated as the current display bits per pixel\&. +.PP +The \fBflags\fR parameter is the same as the \fBflags\fR field of the \fI\fBSDL_Surface\fR\fR structure\&. OR\&'d combinations of the following values are valid\&. +.TP 20 +\fBSDL_SWSURFACE\fP +Create the video surface in system memory +.TP 20 +\fBSDL_HWSURFACE\fP +Create the video surface in video memory +.TP 20 +\fBSDL_ASYNCBLIT\fP +Enables the use of asynchronous updates of the display surface\&. This will usually slow down blitting on single CPU machines, but may provide a speed increase on SMP systems\&. +.TP 20 +\fBSDL_ANYFORMAT\fP +Normally, if a video surface of the requested bits-per-pixel (\fBbpp\fR) is not available, SDL will emulate one with a shadow surface\&. Passing \fBSDL_ANYFORMAT\fP prevents this and causes SDL to use the video surface, regardless of its pixel depth\&. +.TP 20 +\fBSDL_HWPALETTE\fP +Give SDL exclusive palette access\&. Without this flag you may not always get the the colors you request with \fI\fBSDL_SetColors\fP\fR or \fI\fBSDL_SetPalette\fP\fR\&. +.TP 20 +\fBSDL_DOUBLEBUF\fP +Enable hardware double buffering; only valid with SDL_HWSURFACE\&. Calling \fI\fBSDL_Flip\fP\fR will flip the buffers and update the screen\&. All drawing will take place on the surface that is not displayed at the moment\&. If double buffering could not be enabled then \fBSDL_Flip\fP will just perform a \fI\fBSDL_UpdateRect\fP\fR on the entire screen\&. +.TP 20 +\fBSDL_FULLSCREEN\fP +SDL will attempt to use a fullscreen mode\&. If a hardware resolution change is not possible (for whatever reason), the next higher resolution will be used and the display window centered on a black background\&. +.TP 20 +\fBSDL_OPENGL\fP +Create an OpenGL rendering context\&. You should have previously set OpenGL video attributes with \fI\fBSDL_GL_SetAttribute\fP\fR\&. +.TP 20 +\fBSDL_OPENGLBLIT\fP +Create an OpenGL rendering context, like above, but allow normal blitting operations\&. The screen (2D) surface may have an alpha channel, and \fI\fBSDL_UpdateRects\fP\fR must be used for updating changes to the screen surface\&. +.TP 20 +\fBSDL_RESIZABLE\fP +Create a resizable window\&. When the window is resized by the user a \fI\fBSDL_VIDEORESIZE\fP\fR event is generated and \fBSDL_SetVideoMode\fP can be called again with the new size\&. +.TP 20 +\fBSDL_NOFRAME\fP +If possible, \fBSDL_NOFRAME\fP causes SDL to create a window with no title bar or frame decoration\&. Fullscreen modes automatically have this flag set\&. +.PP +.RS +\fBNote: +.PP +Whatever \fBflags\fR \fBSDL_SetVideoMode\fP could satisfy are set in the \fBflags\fR member of the returned surface\&. +.RE +.PP +.RS +\fBNote: +.PP +The \fBbpp\fR parameter is the number of bits per pixel, so a \fBbpp\fR of 24 uses the packed representation of 3 bytes/pixel\&. For the more common 4 bytes/pixel mode, use a \fBbpp\fR of 32\&. Somewhat oddly, both 15 and 16 will request a 2 bytes/pixel mode, but different pixel formats\&. +.RE +.SH "RETURN VALUE" +.PP +The framebuffer surface, or \fBNULL\fR if it fails\&. The surface returned is freed by SDL_Quit() and should nt be freed by the caller\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_LockSurface\fP\fR, \fI\fBSDL_SetColors\fP\fR, \fI\fBSDL_Flip\fP\fR, \fI\fBSDL_Surface\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_ShowCursor.3 b/Externals/SDL/docs/man3/SDL_ShowCursor.3 new file mode 100644 index 0000000000..0376415c0e --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ShowCursor.3 @@ -0,0 +1,20 @@ +.TH "SDL_ShowCursor" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ShowCursor \- Toggle whether or not the cursor is shown on the screen\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_ShowCursor\fP\fR(\fBint toggle\fR); +.SH "DESCRIPTION" +.PP +Toggle whether or not the cursor is shown on the screen\&. Passing \fBSDL_ENABLE\fP displays the cursor and passing \fBSDL_DISABLE\fP hides it\&. The current state of the mouse cursor can be queried by passing \fBSDL_QUERY\fP, either \fBSDL_DISABLE\fP or \fBSDL_ENABLE\fP will be returned\&. +.PP +The cursor starts off displayed, but can be turned off\&. +.SH "RETURN VALUE" +.PP +Returns the current state of the cursor\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateCursor\fP\fR, \fI\fBSDL_SetCursor\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_Surface.3 b/Externals/SDL/docs/man3/SDL_Surface.3 new file mode 100644 index 0000000000..03d6ff9dc8 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_Surface.3 @@ -0,0 +1,96 @@ +.TH "SDL_Surface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_Surface \- Graphical Surface Structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct SDL_Surface { + Uint32 flags; /* Read-only */ + SDL_PixelFormat *format; /* Read-only */ + int w, h; /* Read-only */ + Uint16 pitch; /* Read-only */ + void *pixels; /* Read-write */ + + /* clipping information */ + SDL_Rect clip_rect; /* Read-only */ + + /* Reference count -- used when freeing surface */ + int refcount; /* Read-mostly */ + + /* This structure also contains private fields not shown here */ +} SDL_Surface;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBflags\fR +Surface flags +.TP 20 +\fBformat\fR +Pixel \fIformat\fR +.TP 20 +\fBw, h\fR +Width and height of the surface +.TP 20 +\fBpitch\fR +Length of a surface scanline in bytes +.TP 20 +\fBpixels\fR +Pointer to the actual pixel data +.TP 20 +\fBclip_rect\fR +surface clip \fIrectangle\fR +.SH "DESCRIPTION" +.PP +\fBSDL_Surface\fR\&'s represent areas of "graphical" memory, memory that can be drawn to\&. The video framebuffer is returned as a \fBSDL_Surface\fR by \fI\fBSDL_SetVideoMode\fP\fR and \fI\fBSDL_GetVideoSurface\fP\fR\&. Most of the fields should be pretty obvious\&. \fBw\fR and \fBh\fR are the width and height of the surface in pixels\&. \fBpixels\fR is a pointer to the actual pixel data, the surface should be \fIlocked\fR before accessing this field\&. The \fBclip_rect\fR field is the clipping rectangle as set by \fI\fBSDL_SetClipRect\fP\fR\&. +.PP +The following are supported in the \fBflags\fR field\&. +.TP 20 +\fBSDL_SWSURFACE\fP +Surface is stored in system memory +.TP 20 +\fBSDL_HWSURFACE\fP +Surface is stored in video memory +.TP 20 +\fBSDL_ASYNCBLIT\fP +Surface uses asynchronous blits if possible +.TP 20 +\fBSDL_ANYFORMAT\fP +Allows any pixel-format (Display surface) +.TP 20 +\fBSDL_HWPALETTE\fP +Surface has exclusive palette +.TP 20 +\fBSDL_DOUBLEBUF\fP +Surface is double buffered (Display surface) +.TP 20 +\fBSDL_FULLSCREEN\fP +Surface is full screen (Display Surface) +.TP 20 +\fBSDL_OPENGL\fP +Surface has an OpenGL context (Display Surface) +.TP 20 +\fBSDL_OPENGLBLIT\fP +Surface supports OpenGL blitting (Display Surface) +.TP 20 +\fBSDL_RESIZABLE\fP +Surface is resizable (Display Surface) +.TP 20 +\fBSDL_HWACCEL\fP +Surface blit uses hardware acceleration +.TP 20 +\fBSDL_SRCCOLORKEY\fP +Surface use colorkey blitting +.TP 20 +\fBSDL_RLEACCEL\fP +Colorkey blitting is accelerated with RLE +.TP 20 +\fBSDL_SRCALPHA\fP +Surface blit uses alpha blending +.TP 20 +\fBSDL_PREALLOC\fP +Surface uses preallocated memory +.SH "SEE ALSO" +.PP +\fI\fBSDL_PixelFormat\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_SysWMEvent.3 b/Externals/SDL/docs/man3/SDL_SysWMEvent.3 new file mode 100644 index 0000000000..ca1b7abff9 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_SysWMEvent.3 @@ -0,0 +1,21 @@ +.TH "SDL_SysWMEvent" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_SysWMEvent \- Platform-dependent window manager event\&. +.SH "DESCRIPTION" +.PP +The system window manager event contains a pointer to system-specific information about unknown window manager events\&. If you enable this event using \fI\fBSDL_EventState()\fP\fR, it will be generated whenever unhandled events are received from the window manager\&. This can be used, for example, to implement cut-and-paste in your application\&. +.PP +.nf +\f(CWtypedef struct { + Uint8 type; /* Always SDL_SysWM */ + } SDL_SysWMEvent;\fR +.fi +.PP + If you want to obtain system-specific information about the window manager, you can fill the version member of a \fBSDL_SysWMinfo\fR structure (details can be found in \fBSDL_syswm\&.h\fP, which must be included) using the \fBSDL_VERSION()\fP macro found in \fBSDL_version\&.h\fP, and pass it to the function: +.PP +.sp +\fBint \fBSDL_GetWMInfo\fP\fR(\fBSDL_SysWMinfo *info\fR); +.SH "SEE ALSO" +.PP +\fI\fBSDL_EventState\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_ThreadID.3 b/Externals/SDL/docs/man3/SDL_ThreadID.3 new file mode 100644 index 0000000000..10e2cf8321 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_ThreadID.3 @@ -0,0 +1,13 @@ +.TH "SDL_ThreadID" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_ThreadID \- Get the 32-bit thread identifier for the current thread\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBUint32 \fBSDL_ThreadID\fP\fR(\fBvoid\fR) +.SH "DESCRIPTION" +.PP +Get the 32-bit thread identifier for the current thread\&. +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_UnlockAudio.3 b/Externals/SDL/docs/man3/SDL_UnlockAudio.3 new file mode 100644 index 0000000000..85063191a2 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_UnlockAudio.3 @@ -0,0 +1,15 @@ +.TH "SDL_UnlockAudio" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference" +.SH "NAME" +SDL_UnlockAudio \- Unlock the callback function +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_UnlockAudio\fP\fR(\fBvoid\fR) +.SH "DESCRIPTION" +.PP +Unlocks a previous \fI\fBSDL_LockAudio\fP\fR call\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_OpenAudio\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58 diff --git a/Externals/SDL/docs/man3/SDL_UnlockSurface.3 b/Externals/SDL/docs/man3/SDL_UnlockSurface.3 new file mode 100644 index 0000000000..a3fe5c9b6c --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_UnlockSurface.3 @@ -0,0 +1,17 @@ +.TH "SDL_UnlockSurface" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_UnlockSurface \- Unlocks a previously locked surface\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_UnlockSurface\fP\fR(\fBSDL_Surface *surface\fR); +.SH "DESCRIPTION" +.PP +Surfaces that were previously locked using \fBSDL_LockSurface\fP must be unlocked with \fBSDL_UnlockSurface\fP\&. Surfaces should be unlocked as soon as possible\&. +.PP +It should be noted that since 1\&.1\&.8, surface locks are recursive\&. See \fI\fBSDL_LockSurface\fP\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_LockSurface\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_UnlockYUVOverlay.3 b/Externals/SDL/docs/man3/SDL_UnlockYUVOverlay.3 new file mode 100644 index 0000000000..1e6b7217eb --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_UnlockYUVOverlay.3 @@ -0,0 +1,15 @@ +.TH "SDL_UnlockYUVOverlay" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_UnlockYUVOverlay \- Unlock an overlay +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_UnlockYUVOverlay\fP\fR(\fBSDL_Overlay *overlay\fR); +.SH "DESCRIPTION" +.PP +The opposite to \fI\fBSDL_LockYUVOverlay\fP\fR\&. Unlocks a previously locked overlay\&. An overlay must be unlocked before it can be displayed\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_UnlockYUVOverlay\fP\fR, \fI\fBSDL_CreateYUVOverlay\fP\fR, \fI\fBSDL_Overlay\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_UpdateRect.3 b/Externals/SDL/docs/man3/SDL_UpdateRect.3 new file mode 100644 index 0000000000..a101a83863 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_UpdateRect.3 @@ -0,0 +1,19 @@ +.TH "SDL_UpdateRect" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_UpdateRect \- Makes sure the given area is updated on the given screen\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_UpdateRect\fP\fR(\fBSDL_Surface *screen, Sint32 x, Sint32 y, Sint32 w, Sint32 h\fR); +.SH "DESCRIPTION" +.PP +Makes sure the given area is updated on the given screen\&. The rectangle must be confined within the screen boundaries (no clipping is done)\&. +.PP +If \&'\fBx\fR\&', \&'\fBy\fR\&', \&'\fBw\fR\&' and \&'\fBh\fR\&' are all 0, \fBSDL_UpdateRect\fP will update the entire screen\&. +.PP +This function should not be called while \&'\fBscreen\fR\&' is \fIlocked\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_UpdateRects\fP\fR, \fI\fBSDL_Rect\fR\fR, \fI\fBSDL_Surface\fR\fR, \fI\fBSDL_LockSurface\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_UpdateRects.3 b/Externals/SDL/docs/man3/SDL_UpdateRects.3 new file mode 100644 index 0000000000..9ffdb08e05 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_UpdateRects.3 @@ -0,0 +1,25 @@ +.TH "SDL_UpdateRects" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_UpdateRects \- Makes sure the given list of rectangles is updated on the given screen\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_UpdateRects\fP\fR(\fBSDL_Surface *screen, int numrects, SDL_Rect *rects\fR); +.SH "DESCRIPTION" +.PP +Makes sure the given list of rectangles is updated on the given screen\&. The rectangles must all be confined within the screen boundaries (no clipping is done)\&. +.PP +This function should not be called while \fBscreen\fR is \fIlocked\fR\&. +.PP +.RS +\fBNote: +.PP +It is adviced to call this function only once per frame, since each call has some processing overhead\&. This is no restriction since you can pass any number of rectangles each time\&. +.PP +The rectangles are not automatically merged or checked for overlap\&. In general, the programmer can use his knowledge about his particular rectangles to merge them in an efficient way, to avoid overdraw\&. +.RE +.SH "SEE ALSO" +.PP +\fI\fBSDL_UpdateRect\fP\fR, \fI\fBSDL_Rect\fR\fR, \fI\fBSDL_Surface\fR\fR, \fI\fBSDL_LockSurface\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_UserEvent.3 b/Externals/SDL/docs/man3/SDL_UserEvent.3 new file mode 100644 index 0000000000..d92ec5356a --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_UserEvent.3 @@ -0,0 +1,47 @@ +.TH "SDL_UserEvent" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_UserEvent \- A user-defined event type +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 type; + int code; + void *data1; + void *data2; +} SDL_UserEvent;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBtype\fR +\fBSDL_USEREVENT\fP through to \fBSDL_NUMEVENTS-1\fP +.TP 20 +\fBcode\fR +User defined event code +.TP 20 +\fBdata1\fR +User defined data pointer +.TP 20 +\fBdata2\fR +User defined data pointer +.SH "DESCRIPTION" +.PP +\fBSDL_UserEvent\fR is in the \fBuser\fR member of the structure \fI\fBSDL_Event\fR\fR\&. This event is unique, it is never created by SDL but only by the user\&. The event can be pushed onto the event queue using \fI\fBSDL_PushEvent\fP\fR\&. The contents of the structure members or completely up to the programmer, the only requirement is that \fBtype\fR is a value from \fBSDL_USEREVENT\fP to \fBSDL_NUMEVENTS-1\fP (inclusive)\&. +.SH "EXAMPLES" +.PP +.PP +.nf +\f(CWSDL_Event event; + +event\&.type = SDL_USEREVENT; +event\&.user\&.code = my_event_code; +event\&.user\&.data1 = significant_data; +event\&.user\&.data2 = 0; +SDL_PushEvent(&event);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_PushEvent\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_VideoDriverName.3 b/Externals/SDL/docs/man3/SDL_VideoDriverName.3 new file mode 100644 index 0000000000..e8563b6503 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_VideoDriverName.3 @@ -0,0 +1,18 @@ +.TH "SDL_VideoDriverName" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_VideoDriverName \- Obtain the name of the video driver +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBchar *\fBSDL_VideoDriverName\fP\fR(\fBchar *namebuf, int maxlen\fR); +.SH "DESCRIPTION" +.PP +The buffer pointed to by \fBnamebuf\fR is filled up to a maximum of \fBmaxlen\fR characters (include the NULL terminator) with the name of the initialised video driver\&. The driver name is a simple one word identifier like "x11" or "windib"\&. +.SH "RETURN VALUE" +.PP +Returns \fBNULL\fP if video has not been initialised with \fBSDL_Init\fP or a pointer to \fBnamebuf\fR otherwise\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Init\fP\fR \fI\fBSDL_InitSubSystem\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_VideoInfo.3 b/Externals/SDL/docs/man3/SDL_VideoInfo.3 new file mode 100644 index 0000000000..c62e1ffdd3 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_VideoInfo.3 @@ -0,0 +1,62 @@ +.TH "SDL_VideoInfo" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_VideoInfo \- Video Target information +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint32 hw_available:1; + Uint32 wm_available:1; + Uint32 blit_hw:1; + Uint32 blit_hw_CC:1; + Uint32 blit_hw_A:1; + Uint32 blit_sw:1; + Uint32 blit_sw_CC:1; + Uint32 blit_sw_A:1; + Uint32 blit_fill; + Uint32 video_mem; + SDL_PixelFormat *vfmt; +} SDL_VideoInfo;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBhw_available\fR +Is it possible to create hardware surfaces? +.TP 20 +\fBwm_available\fR +Is there a window manager available +.TP 20 +\fBblit_hw\fR +Are hardware to hardware blits accelerated? +.TP 20 +\fBblit_hw_CC\fR +Are hardware to hardware colorkey blits accelerated? +.TP 20 +\fBblit_hw_A\fR +Are hardware to hardware alpha blits accelerated? +.TP 20 +\fBblit_sw\fR +Are software to hardware blits accelerated? +.TP 20 +\fBblit_sw_CC\fR +Are software to hardware colorkey blits accelerated? +.TP 20 +\fBblit_sw_A\fR +Are software to hardware alpha blits accelerated? +.TP 20 +\fBblit_fill\fR +Are color fills accelerated? +.TP 20 +\fBvideo_mem\fR +Total amount of video memory in Kilobytes +.TP 20 +\fBvfmt\fR +\fIPixel format\fR of the video device +.SH "DESCRIPTION" +.PP +This (read-only) structure is returned by \fI\fBSDL_GetVideoInfo\fP\fR\&. It contains information on either the \&'best\&' available mode (if called before \fI\fBSDL_SetVideoMode\fP\fR) or the current video mode\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_PixelFormat\fR\fR, \fI\fBSDL_GetVideoInfo\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_VideoModeOK.3 b/Externals/SDL/docs/man3/SDL_VideoModeOK.3 new file mode 100644 index 0000000000..72c9a90733 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_VideoModeOK.3 @@ -0,0 +1,44 @@ +.TH "SDL_VideoModeOK" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_VideoModeOK \- Check to see if a particular video mode is supported\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_VideoModeOK\fP\fR(\fBint width, int height, int bpp, Uint32 flags\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_VideoModeOK\fP returns \fB0\fR if the requested mode is not supported under any bit depth, or returns the bits-per-pixel of the closest available mode with the given width, height and requested \fIsurface\fR flags (see \fI\fBSDL_SetVideoMode\fP\fR)\&. +.PP +The bits-per-pixel value returned is only a suggested mode\&. You can usually request and bpp you want when \fIsetting\fR the video mode and SDL will emulate that color depth with a shadow video surface\&. +.PP +The arguments to \fBSDL_VideoModeOK\fP are the same ones you would pass to \fISDL_SetVideoMode\fR +.SH "EXAMPLE" +.PP +.nf +\f(CWSDL_Surface *screen; +Uint32 bpp; +\&. +\&. +\&. +printf("Checking mode 640x480@16bpp\&. +"); +bpp=SDL_VideoModeOK(640, 480, 16, SDL_HWSURFACE); + +if(!bpp){ + printf("Mode not available\&. +"); + exit(-1); +} + +printf("SDL Recommends 640x480@%dbpp\&. +", bpp); +screen=SDL_SetVideoMode(640, 480, bpp, SDL_HWSURFACE); +\&. +\&.\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetVideoMode\fP\fR, \fI\fBSDL_GetVideoInfo\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_WM_GetCaption.3 b/Externals/SDL/docs/man3/SDL_WM_GetCaption.3 new file mode 100644 index 0000000000..68ed8b2323 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WM_GetCaption.3 @@ -0,0 +1,15 @@ +.TH "SDL_WM_GetCaption" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WM_GetCaption \- Gets the window title and icon name\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_WM_GetCaption\fP\fR(\fBchar **title, char **icon\fR); +.SH "DESCRIPTION" +.PP +Set pointers to the window \fBtitle\fR and \fBicon\fR name\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_WM_SetCaption\fP\fR, \fI\fBSDL_WM_SetIcon\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_WM_GrabInput.3 b/Externals/SDL/docs/man3/SDL_WM_GrabInput.3 new file mode 100644 index 0000000000..556681e70d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WM_GrabInput.3 @@ -0,0 +1,28 @@ +.TH "SDL_WM_GrabInput" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WM_GrabInput \- Grabs mouse and keyboard input\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBSDL_GrabMode \fBSDL_WM_GrabInput\fP\fR(\fBSDL_GrabMode mode\fR); +.SH "DESCRIPTION" +.PP +Grabbing means that the mouse is confined to the application window, and nearly all keyboard input is passed directly to the application, and not interpreted by a window manager, if any\&. +.PP +When \fBmode\fR is \fBSDL_GRAB_QUERY\fP the grab mode is not changed, but the current grab mode is returned\&. +.PP +.PP +.nf +\f(CWtypedef enum { + SDL_GRAB_QUERY, + SDL_GRAB_OFF, + SDL_GRAB_ON +} SDL_GrabMode;\fR +.fi +.PP + +.SH "RETURN VALUE" +.PP +The current/new \fBSDL_GrabMode\fR\&. +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_WM_IconifyWindow.3 b/Externals/SDL/docs/man3/SDL_WM_IconifyWindow.3 new file mode 100644 index 0000000000..922df8f53f --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WM_IconifyWindow.3 @@ -0,0 +1,15 @@ +.TH "SDL_WM_IconifyWindow" "3" "Tue 11 Sep 2001, 23:02" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WM_IconifyWindow \- Iconify/Minimise the window +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_WM_IconifyWindow\fP\fR(\fBvoid\fR); +.SH "DESCRIPTION" +.PP +If the application is running in a window managed environment SDL attempts to iconify/minimise it\&. If \fBSDL_WM_IconifyWindow\fP is successful, the application will receive a \fI\fBSDL_APPACTIVE\fP\fR loss event\&. +.SH "RETURN VALUE" +.PP +Returns non-zero on success or \fB0\fR if iconification is not support or was refused by the window manager\&. +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:02 diff --git a/Externals/SDL/docs/man3/SDL_WM_SetCaption.3 b/Externals/SDL/docs/man3/SDL_WM_SetCaption.3 new file mode 100644 index 0000000000..847ff5d45d --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WM_SetCaption.3 @@ -0,0 +1,15 @@ +.TH "SDL_WM_SetCaption" "3" "Tue 11 Sep 2001, 23:02" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WM_SetCaption \- Sets the window tile and icon name\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_WM_SetCaption\fP\fR(\fBconst char *title, const char *icon\fR); +.SH "DESCRIPTION" +.PP +Sets the title-bar and icon name of the display window\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_WM_GetCaption\fP\fR, \fI\fBSDL_WM_SetIcon\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:02 diff --git a/Externals/SDL/docs/man3/SDL_WM_SetIcon.3 b/Externals/SDL/docs/man3/SDL_WM_SetIcon.3 new file mode 100644 index 0000000000..3f3a51966a --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WM_SetIcon.3 @@ -0,0 +1,27 @@ +.TH "SDL_WM_SetIcon" "3" "Tue 11 Sep 2001, 23:02" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WM_SetIcon \- Sets the icon for the display window\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_WM_SetIcon\fP\fR(\fBSDL_Surface *icon, Uint8 *mask\fR); +.SH "DESCRIPTION" +.PP +Sets the icon for the display window\&. Win32 icons must be 32x32\&. +.PP +This function must be called before the first call to \fISDL_SetVideoMode\fR\&. +.PP +It takes an \fBicon\fR surface, and a \fBmask\fR in MSB format\&. +.PP +If \fBmask\fR is \fBNULL\fP, the entire icon surface will be used as the icon\&. +.SH "EXAMPLE" +.PP +.nf +\f(CWSDL_WM_SetIcon(SDL_LoadBMP("icon\&.bmp"), NULL);\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_SetVideoMode\fP\fR, \fI\fBSDL_WM_SetCaption\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:02 diff --git a/Externals/SDL/docs/man3/SDL_WM_ToggleFullScreen.3 b/Externals/SDL/docs/man3/SDL_WM_ToggleFullScreen.3 new file mode 100644 index 0000000000..d4cf8de151 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WM_ToggleFullScreen.3 @@ -0,0 +1,15 @@ +.TH "SDL_WM_ToggleFullScreen" "3" "Tue 11 Sep 2001, 23:02" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WM_ToggleFullScreen \- Toggles fullscreen mode +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_WM_ToggleFullScreen\fP\fR(\fBSDL_Surface *surface\fR); +.SH "DESCRIPTION" +.PP +Toggles the application between windowed and fullscreen mode, if supported\&. (X11 is the only target currently supported, BeOS support is experimental)\&. +.SH "RETURN VALUE" +.PP +Returns \fB0\fR on failure or \fB1\fR on success\&. +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:02 diff --git a/Externals/SDL/docs/man3/SDL_WaitEvent.3 b/Externals/SDL/docs/man3/SDL_WaitEvent.3 new file mode 100644 index 0000000000..adadb4aa61 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WaitEvent.3 @@ -0,0 +1,17 @@ +.TH "SDL_WaitEvent" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WaitEvent \- Waits indefinitely for the next available event\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBint \fBSDL_WaitEvent\fP\fR(\fBSDL_Event *event\fR); +.SH "DESCRIPTION" +.PP +Waits indefinitely for the next available event, returning \fB1\fR, or \fB0\fR if there was an error while waiting for events\&. +.PP +If \fBevent\fR is not \fBNULL\fP, the next event is removed from the queue and stored in that area\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_Event\fR\fR, \fI\fBSDL_PollEvent\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_WaitThread.3 b/Externals/SDL/docs/man3/SDL_WaitThread.3 new file mode 100644 index 0000000000..11679fc2b5 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WaitThread.3 @@ -0,0 +1,19 @@ +.TH "SDL_WaitThread" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WaitThread \- Wait for a thread to finish\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBvoid \fBSDL_WaitThread\fP\fR(\fBSDL_Thread *thread, int *status\fR); +.SH "DESCRIPTION" +.PP +Wait for a thread to finish (timeouts are not supported)\&. +.SH "RETURN VALUE" +.PP +The return code for the thread function is placed in the area pointed to by \fBstatus\fR, if \fBstatus\fR is not \fBNULL\fR\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateThread\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_WarpMouse.3 b/Externals/SDL/docs/man3/SDL_WarpMouse.3 new file mode 100644 index 0000000000..5cab3cef07 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WarpMouse.3 @@ -0,0 +1,15 @@ +.TH "SDL_WarpMouse" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WarpMouse \- Set the position of the mouse cursor\&. +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBvoid \fBSDL_WarpMouse\fP\fR(\fBUint16 x, Uint16 y\fR); +.SH "DESCRIPTION" +.PP +Set the position of the mouse cursor (generates a mouse motion event)\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_MouseMotionEvent\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_WasInit.3 b/Externals/SDL/docs/man3/SDL_WasInit.3 new file mode 100644 index 0000000000..5bc75c5edb --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_WasInit.3 @@ -0,0 +1,63 @@ +.TH "SDL_WasInit" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_WasInit \- Check which subsystems are initialized +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +.sp +\fBUint32 \fBSDL_WasInit\fP\fR(\fBUint32 flags\fR); +.SH "DESCRIPTION" +.PP +\fBSDL_WasInit\fP allows you to see which SDL subsytems have been \fIinitialized\fR\&. \fBflags\fR is a bitwise OR\&'d combination of the subsystems you wish to check (see \fI\fBSDL_Init\fP\fR for a list of subsystem flags)\&. +.SH "RETURN VALUE" +.PP +\fBSDL_WasInit\fP returns a bitwised OR\&'d combination of the initialized subsystems\&. +.SH "EXAMPLES" +.PP +.nf +\f(CW +/* Here are several ways you can use SDL_WasInit() */ + +/* Get init data on all the subsystems */ +Uint32 subsystem_init; + +subsystem_init=SDL_WasInit(SDL_INIT_EVERYTHING); + +if(subsystem_init&SDL_INIT_VIDEO) + printf("Video is initialized\&. +"); +else + printf("Video is not initialized\&. +"); + + + +/* Just check for one specfic subsystem */ + +if(SDL_WasInit(SDL_INIT_VIDEO)!=0) + printf("Video is initialized\&. +"); +else + printf("Video is not initialized\&. +"); + + + + +/* Check for two subsystems */ + +Uint32 subsystem_mask=SDL_INIT_VIDEO|SDL_INIT_AUDIO; + +if(SDL_WasInit(subsystem_mask)==subsystem_mask) + printf("Video and Audio initialized\&. +"); +else + printf("Video and Audio not initialized\&. +"); +\fR +.fi +.PP +.SH "SEE ALSO" +.PP +\fI\fBSDL_Init\fP\fR, \fI\fBSDL_Subsystem\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_keysym.3 b/Externals/SDL/docs/man3/SDL_keysym.3 new file mode 100644 index 0000000000..52065c15a0 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_keysym.3 @@ -0,0 +1,69 @@ +.TH "SDL_keysym" "3" "Tue 11 Sep 2001, 23:00" "SDL" "SDL API Reference" +.SH "NAME" +SDL_keysym \- Keysym structure +.SH "STRUCTURE DEFINITION" +.PP +.nf +\f(CWtypedef struct{ + Uint8 scancode; + SDLKey sym; + SDLMod mod; + Uint16 unicode; +} SDL_keysym;\fR +.fi +.PP +.SH "STRUCTURE DATA" +.TP 20 +\fBscancode\fR +Hardware specific scancode +.TP 20 +\fBsym\fR +SDL virtual keysym +.TP 20 +\fBmod\fR +Current key modifiers +.TP 20 +\fBunicode\fR +Translated character +.SH "DESCRIPTION" +.PP +The \fBSDL_keysym\fR structure is used by reporting key presses and releases since it is a part of the \fI\fBSDL_KeyboardEvent\fR\fR\&. +.PP +The \fBscancode\fR field should generally be left alone, it is the hardware dependent scancode returned by the keyboard\&. The \fBsym\fR field is extremely useful\&. It is the SDL-defined value of the key (see \fISDL Key Syms\fR\&. This field is very useful when you are checking for certain key presses, like so: +.PP +.nf +\f(CW\&. +\&. +while(SDL_PollEvent(&event)){ + switch(event\&.type){ + case SDL_KEYDOWN: + if(event\&.key\&.keysym\&.sym==SDLK_LEFT) + move_left(); + break; + \&. + \&. + \&. + } +} +\&. +\&.\fR +.fi +.PP + \fBmod\fR stores the current state of the keyboard modifiers as explained in \fI\fBSDL_GetModState\fP\fR\&. The \fBunicode\fR is only used when UNICODE translation is enabled with \fI\fBSDL_EnableUNICODE\fP\fR\&. If \fBunicode\fR is non-zero then this a the UNICODE character corresponding to the keypress\&. If the high 9 bits of the character are 0, then this maps to the equivalent ASCII character: +.PP +.nf +\f(CWchar ch; +if ( (keysym\&.unicode & 0xFF80) == 0 ) { + ch = keysym\&.unicode & 0x7F; +} +else { + printf("An International Character\&. +"); +}\fR +.fi +.PP + UNICODE translation does have a slight overhead so don\&'t enable it unless its needed\&. +.SH "SEE ALSO" +.PP +\fI\fBSDLKey\fR\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:00 diff --git a/Externals/SDL/docs/man3/SDL_mutexP.3 b/Externals/SDL/docs/man3/SDL_mutexP.3 new file mode 100644 index 0000000000..3f2171629e --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_mutexP.3 @@ -0,0 +1,18 @@ +.TH "SDL_mutexP" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_mutexP \- Lock a mutex +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_mutexP\fP\fR(\fBSDL_mutex *mutex\fR); +.SH "DESCRIPTION" +.PP +Locks the \fBmutex\fR, which was previously created with \fI\fBSDL_CreateMutex\fP\fR\&. If the mutex is already locked then \fBSDL_mutexP\fP will not return until it is \fIunlocked\fR\&. Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.PP +SDL also defines a macro \fB#define SDL_LockMutex(m) SDL_mutexP(m)\fP\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateMutex\fP\fR, \fI\fBSDL_mutexV\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/docs/man3/SDL_mutexV.3 b/Externals/SDL/docs/man3/SDL_mutexV.3 new file mode 100644 index 0000000000..e914abb7d6 --- /dev/null +++ b/Externals/SDL/docs/man3/SDL_mutexV.3 @@ -0,0 +1,18 @@ +.TH "SDL_mutexV" "3" "Tue 11 Sep 2001, 23:01" "SDL" "SDL API Reference" +.SH "NAME" +SDL_mutexV \- Unlock a mutex +.SH "SYNOPSIS" +.PP +\fB#include "SDL\&.h" +#include "SDL_thread\&.h" +.sp +\fBint \fBSDL_mutexV\fP\fR(\fBSDL_mutex *mutex\fR); +.SH "DESCRIPTION" +.PP +Unlocks the \fBmutex\fR, which was previously created with \fI\fBSDL_CreateMutex\fP\fR\&. Returns \fB0\fR on success, or \fB-1\fR on an error\&. +.PP +SDL also defines a macro \fB#define SDL_UnlockMutex(m) SDL_mutexV(m)\fP\&. +.SH "SEE ALSO" +.PP +\fI\fBSDL_CreateMutex\fP\fR, \fI\fBSDL_mutexP\fP\fR +.\" created by instant / docbook-to-man, Tue 11 Sep 2001, 23:01 diff --git a/Externals/SDL/include/SDL.h b/Externals/SDL/include/SDL.h new file mode 100644 index 0000000000..119ed7ff14 --- /dev/null +++ b/Externals/SDL/include/SDL.h @@ -0,0 +1,101 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL.h + * Main include header for the SDL library + */ + +#ifndef _SDL_H +#define _SDL_H + +#include "SDL_main.h" +#include "SDL_stdinc.h" +#include "SDL_audio.h" +#include "SDL_cdrom.h" +#include "SDL_cpuinfo.h" +#include "SDL_endian.h" +#include "SDL_error.h" +#include "SDL_events.h" +#include "SDL_loadso.h" +#include "SDL_mutex.h" +#include "SDL_rwops.h" +#include "SDL_thread.h" +#include "SDL_timer.h" +#include "SDL_video.h" +#include "SDL_version.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** @file SDL.h + * @note As of version 0.5, SDL is loaded dynamically into the application + */ + +/** @name SDL_INIT Flags + * These are the flags which may be passed to SDL_Init() -- you should + * specify the subsystems which you will be using in your application. + */ +/*@{*/ +#define SDL_INIT_TIMER 0x00000001 +#define SDL_INIT_AUDIO 0x00000010 +#define SDL_INIT_VIDEO 0x00000020 +#define SDL_INIT_CDROM 0x00000100 +#define SDL_INIT_JOYSTICK 0x00000200 +#define SDL_INIT_NOPARACHUTE 0x00100000 /**< Don't catch fatal signals */ +#define SDL_INIT_EVENTTHREAD 0x01000000 /**< Not supported on all OS's */ +#define SDL_INIT_EVERYTHING 0x0000FFFF +/*@}*/ + +/** This function loads the SDL dynamically linked library and initializes + * the subsystems specified by 'flags' (and those satisfying dependencies) + * Unless the SDL_INIT_NOPARACHUTE flag is set, it will install cleanup + * signal handlers for some commonly ignored fatal signals (like SIGSEGV) + */ +extern DECLSPEC int SDLCALL SDL_Init(Uint32 flags); + +/** This function initializes specific SDL subsystems */ +extern DECLSPEC int SDLCALL SDL_InitSubSystem(Uint32 flags); + +/** This function cleans up specific SDL subsystems */ +extern DECLSPEC void SDLCALL SDL_QuitSubSystem(Uint32 flags); + +/** This function returns mask of the specified subsystems which have + * been initialized. + * If 'flags' is 0, it returns a mask of all initialized subsystems. + */ +extern DECLSPEC Uint32 SDLCALL SDL_WasInit(Uint32 flags); + +/** This function cleans up all initialized subsystems and unloads the + * dynamically linked library. You should call it upon all exit conditions. + */ +extern DECLSPEC void SDLCALL SDL_Quit(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_H */ diff --git a/Externals/SDL/include/SDL_active.h b/Externals/SDL/include/SDL_active.h new file mode 100644 index 0000000000..0ae92f2d56 --- /dev/null +++ b/Externals/SDL/include/SDL_active.h @@ -0,0 +1,63 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_active.h + * Include file for SDL application focus event handling + */ + +#ifndef _SDL_active_h +#define _SDL_active_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** @name The available application states */ +/*@{*/ +#define SDL_APPMOUSEFOCUS 0x01 /**< The app has mouse coverage */ +#define SDL_APPINPUTFOCUS 0x02 /**< The app has input focus */ +#define SDL_APPACTIVE 0x04 /**< The application is active */ +/*@}*/ + +/* Function prototypes */ +/** + * This function returns the current state of the application, which is a + * bitwise combination of SDL_APPMOUSEFOCUS, SDL_APPINPUTFOCUS, and + * SDL_APPACTIVE. If SDL_APPACTIVE is set, then the user is able to + * see your application, otherwise it has been iconified or disabled. + */ +extern DECLSPEC Uint8 SDLCALL SDL_GetAppState(void); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_active_h */ diff --git a/Externals/SDL/include/SDL_audio.h b/Externals/SDL/include/SDL_audio.h new file mode 100644 index 0000000000..3a8e7fa8b8 --- /dev/null +++ b/Externals/SDL/include/SDL_audio.h @@ -0,0 +1,284 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_audio.h + * Access to the raw audio mixing buffer for the SDL library + */ + +#ifndef _SDL_audio_h +#define _SDL_audio_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_endian.h" +#include "SDL_mutex.h" +#include "SDL_thread.h" +#include "SDL_rwops.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * When filling in the desired audio spec structure, + * - 'desired->freq' should be the desired audio frequency in samples-per-second. + * - 'desired->format' should be the desired audio format. + * - 'desired->samples' is the desired size of the audio buffer, in samples. + * This number should be a power of two, and may be adjusted by the audio + * driver to a value more suitable for the hardware. Good values seem to + * range between 512 and 8096 inclusive, depending on the application and + * CPU speed. Smaller values yield faster response time, but can lead + * to underflow if the application is doing heavy processing and cannot + * fill the audio buffer in time. A stereo sample consists of both right + * and left channels in LR ordering. + * Note that the number of samples is directly related to time by the + * following formula: ms = (samples*1000)/freq + * - 'desired->size' is the size in bytes of the audio buffer, and is + * calculated by SDL_OpenAudio(). + * - 'desired->silence' is the value used to set the buffer to silence, + * and is calculated by SDL_OpenAudio(). + * - 'desired->callback' should be set to a function that will be called + * when the audio device is ready for more data. It is passed a pointer + * to the audio buffer, and the length in bytes of the audio buffer. + * This function usually runs in a separate thread, and so you should + * protect data structures that it accesses by calling SDL_LockAudio() + * and SDL_UnlockAudio() in your code. + * - 'desired->userdata' is passed as the first parameter to your callback + * function. + * + * @note The calculated values in this structure are calculated by SDL_OpenAudio() + * + */ +typedef struct SDL_AudioSpec { + int freq; /**< DSP frequency -- samples per second */ + Uint16 format; /**< Audio data format */ + Uint8 channels; /**< Number of channels: 1 mono, 2 stereo */ + Uint8 silence; /**< Audio buffer silence value (calculated) */ + Uint16 samples; /**< Audio buffer size in samples (power of 2) */ + Uint16 padding; /**< Necessary for some compile environments */ + Uint32 size; /**< Audio buffer size in bytes (calculated) */ + /** + * This function is called when the audio device needs more data. + * + * @param[out] stream A pointer to the audio data buffer + * @param[in] len The length of the audio buffer in bytes. + * + * Once the callback returns, the buffer will no longer be valid. + * Stereo samples are stored in a LRLRLR ordering. + */ + void (SDLCALL *callback)(void *userdata, Uint8 *stream, int len); + void *userdata; +} SDL_AudioSpec; + +/** + * @name Audio format flags + * defaults to LSB byte order + */ +/*@{*/ +#define AUDIO_U8 0x0008 /**< Unsigned 8-bit samples */ +#define AUDIO_S8 0x8008 /**< Signed 8-bit samples */ +#define AUDIO_U16LSB 0x0010 /**< Unsigned 16-bit samples */ +#define AUDIO_S16LSB 0x8010 /**< Signed 16-bit samples */ +#define AUDIO_U16MSB 0x1010 /**< As above, but big-endian byte order */ +#define AUDIO_S16MSB 0x9010 /**< As above, but big-endian byte order */ +#define AUDIO_U16 AUDIO_U16LSB +#define AUDIO_S16 AUDIO_S16LSB + +/** + * @name Native audio byte ordering + */ +/*@{*/ +#if SDL_BYTEORDER == SDL_LIL_ENDIAN +#define AUDIO_U16SYS AUDIO_U16LSB +#define AUDIO_S16SYS AUDIO_S16LSB +#else +#define AUDIO_U16SYS AUDIO_U16MSB +#define AUDIO_S16SYS AUDIO_S16MSB +#endif +/*@}*/ + +/*@}*/ + + +/** A structure to hold a set of audio conversion filters and buffers */ +typedef struct SDL_AudioCVT { + int needed; /**< Set to 1 if conversion possible */ + Uint16 src_format; /**< Source audio format */ + Uint16 dst_format; /**< Target audio format */ + double rate_incr; /**< Rate conversion increment */ + Uint8 *buf; /**< Buffer to hold entire audio data */ + int len; /**< Length of original audio buffer */ + int len_cvt; /**< Length of converted audio buffer */ + int len_mult; /**< buffer must be len*len_mult big */ + double len_ratio; /**< Given len, final size is len*len_ratio */ + void (SDLCALL *filters[10])(struct SDL_AudioCVT *cvt, Uint16 format); + int filter_index; /**< Current audio conversion function */ +} SDL_AudioCVT; + + +/* Function prototypes */ + +/** + * @name Audio Init and Quit + * These functions are used internally, and should not be used unless you + * have a specific need to specify the audio driver you want to use. + * You should normally use SDL_Init() or SDL_InitSubSystem(). + */ +/*@{*/ +extern DECLSPEC int SDLCALL SDL_AudioInit(const char *driver_name); +extern DECLSPEC void SDLCALL SDL_AudioQuit(void); +/*@}*/ + +/** + * This function fills the given character buffer with the name of the + * current audio driver, and returns a pointer to it if the audio driver has + * been initialized. It returns NULL if no driver has been initialized. + */ +extern DECLSPEC char * SDLCALL SDL_AudioDriverName(char *namebuf, int maxlen); + +/** + * This function opens the audio device with the desired parameters, and + * returns 0 if successful, placing the actual hardware parameters in the + * structure pointed to by 'obtained'. If 'obtained' is NULL, the audio + * data passed to the callback function will be guaranteed to be in the + * requested format, and will be automatically converted to the hardware + * audio format if necessary. This function returns -1 if it failed + * to open the audio device, or couldn't set up the audio thread. + * + * The audio device starts out playing silence when it's opened, and should + * be enabled for playing by calling SDL_PauseAudio(0) when you are ready + * for your audio callback function to be called. Since the audio driver + * may modify the requested size of the audio buffer, you should allocate + * any local mixing buffers after you open the audio device. + * + * @sa SDL_AudioSpec + */ +extern DECLSPEC int SDLCALL SDL_OpenAudio(SDL_AudioSpec *desired, SDL_AudioSpec *obtained); + +typedef enum { + SDL_AUDIO_STOPPED = 0, + SDL_AUDIO_PLAYING, + SDL_AUDIO_PAUSED +} SDL_audiostatus; + +/** Get the current audio state */ +extern DECLSPEC SDL_audiostatus SDLCALL SDL_GetAudioStatus(void); + +/** + * This function pauses and unpauses the audio callback processing. + * It should be called with a parameter of 0 after opening the audio + * device to start playing sound. This is so you can safely initialize + * data for your callback function after opening the audio device. + * Silence will be written to the audio device during the pause. + */ +extern DECLSPEC void SDLCALL SDL_PauseAudio(int pause_on); + +/** + * This function loads a WAVE from the data source, automatically freeing + * that source if 'freesrc' is non-zero. For example, to load a WAVE file, + * you could do: + * @code SDL_LoadWAV_RW(SDL_RWFromFile("sample.wav", "rb"), 1, ...); @endcode + * + * If this function succeeds, it returns the given SDL_AudioSpec, + * filled with the audio data format of the wave data, and sets + * 'audio_buf' to a malloc()'d buffer containing the audio data, + * and sets 'audio_len' to the length of that audio buffer, in bytes. + * You need to free the audio buffer with SDL_FreeWAV() when you are + * done with it. + * + * This function returns NULL and sets the SDL error message if the + * wave file cannot be opened, uses an unknown data format, or is + * corrupt. Currently raw and MS-ADPCM WAVE files are supported. + */ +extern DECLSPEC SDL_AudioSpec * SDLCALL SDL_LoadWAV_RW(SDL_RWops *src, int freesrc, SDL_AudioSpec *spec, Uint8 **audio_buf, Uint32 *audio_len); + +/** Compatibility convenience function -- loads a WAV from a file */ +#define SDL_LoadWAV(file, spec, audio_buf, audio_len) \ + SDL_LoadWAV_RW(SDL_RWFromFile(file, "rb"),1, spec,audio_buf,audio_len) + +/** + * This function frees data previously allocated with SDL_LoadWAV_RW() + */ +extern DECLSPEC void SDLCALL SDL_FreeWAV(Uint8 *audio_buf); + +/** + * This function takes a source format and rate and a destination format + * and rate, and initializes the 'cvt' structure with information needed + * by SDL_ConvertAudio() to convert a buffer of audio data from one format + * to the other. + * + * @return This function returns 0, or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_BuildAudioCVT(SDL_AudioCVT *cvt, + Uint16 src_format, Uint8 src_channels, int src_rate, + Uint16 dst_format, Uint8 dst_channels, int dst_rate); + +/** + * Once you have initialized the 'cvt' structure using SDL_BuildAudioCVT(), + * created an audio buffer cvt->buf, and filled it with cvt->len bytes of + * audio data in the source format, this function will convert it in-place + * to the desired format. + * The data conversion may expand the size of the audio data, so the buffer + * cvt->buf should be allocated after the cvt structure is initialized by + * SDL_BuildAudioCVT(), and should be cvt->len*cvt->len_mult bytes long. + */ +extern DECLSPEC int SDLCALL SDL_ConvertAudio(SDL_AudioCVT *cvt); + + +#define SDL_MIX_MAXVOLUME 128 +/** + * This takes two audio buffers of the playing audio format and mixes + * them, performing addition, volume adjustment, and overflow clipping. + * The volume ranges from 0 - 128, and should be set to SDL_MIX_MAXVOLUME + * for full audio volume. Note this does not change hardware volume. + * This is provided for convenience -- you can mix your own audio data. + */ +extern DECLSPEC void SDLCALL SDL_MixAudio(Uint8 *dst, const Uint8 *src, Uint32 len, int volume); + +/** + * @name Audio Locks + * The lock manipulated by these functions protects the callback function. + * During a LockAudio/UnlockAudio pair, you can be guaranteed that the + * callback function is not running. Do not call these from the callback + * function or you will cause deadlock. + */ +/*@{*/ +extern DECLSPEC void SDLCALL SDL_LockAudio(void); +extern DECLSPEC void SDLCALL SDL_UnlockAudio(void); +/*@}*/ + +/** + * This function shuts down audio processing and closes the audio device. + */ +extern DECLSPEC void SDLCALL SDL_CloseAudio(void); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_audio_h */ diff --git a/Externals/SDL/include/SDL_byteorder.h b/Externals/SDL/include/SDL_byteorder.h new file mode 100644 index 0000000000..9b93cd69a3 --- /dev/null +++ b/Externals/SDL/include/SDL_byteorder.h @@ -0,0 +1,29 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_byteorder.h + * @deprecated Use SDL_endian.h instead + */ + +/* DEPRECATED */ +#include "SDL_endian.h" diff --git a/Externals/SDL/include/SDL_cdrom.h b/Externals/SDL/include/SDL_cdrom.h new file mode 100644 index 0000000000..fff5cfa158 --- /dev/null +++ b/Externals/SDL/include/SDL_cdrom.h @@ -0,0 +1,202 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_cdrom.h + * This is the CD-audio control API for Simple DirectMedia Layer + */ + +#ifndef _SDL_cdrom_h +#define _SDL_cdrom_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @file SDL_cdrom.h + * In order to use these functions, SDL_Init() must have been called + * with the SDL_INIT_CDROM flag. This causes SDL to scan the system + * for CD-ROM drives, and load appropriate drivers. + */ + +/** The maximum number of CD-ROM tracks on a disk */ +#define SDL_MAX_TRACKS 99 + +/** @name Track Types + * The types of CD-ROM track possible + */ +/*@{*/ +#define SDL_AUDIO_TRACK 0x00 +#define SDL_DATA_TRACK 0x04 +/*@}*/ + +/** The possible states which a CD-ROM drive can be in. */ +typedef enum { + CD_TRAYEMPTY, + CD_STOPPED, + CD_PLAYING, + CD_PAUSED, + CD_ERROR = -1 +} CDstatus; + +/** Given a status, returns true if there's a disk in the drive */ +#define CD_INDRIVE(status) ((int)(status) > 0) + +typedef struct SDL_CDtrack { + Uint8 id; /**< Track number */ + Uint8 type; /**< Data or audio track */ + Uint16 unused; + Uint32 length; /**< Length, in frames, of this track */ + Uint32 offset; /**< Offset, in frames, from start of disk */ +} SDL_CDtrack; + +/** This structure is only current as of the last call to SDL_CDStatus() */ +typedef struct SDL_CD { + int id; /**< Private drive identifier */ + CDstatus status; /**< Current drive status */ + + /** The rest of this structure is only valid if there's a CD in drive */ + /*@{*/ + int numtracks; /**< Number of tracks on disk */ + int cur_track; /**< Current track position */ + int cur_frame; /**< Current frame offset within current track */ + SDL_CDtrack track[SDL_MAX_TRACKS+1]; + /*@}*/ +} SDL_CD; + +/** @name Frames / MSF Conversion Functions + * Conversion functions from frames to Minute/Second/Frames and vice versa + */ +/*@{*/ +#define CD_FPS 75 +#define FRAMES_TO_MSF(f, M,S,F) { \ + int value = f; \ + *(F) = value%CD_FPS; \ + value /= CD_FPS; \ + *(S) = value%60; \ + value /= 60; \ + *(M) = value; \ +} +#define MSF_TO_FRAMES(M, S, F) ((M)*60*CD_FPS+(S)*CD_FPS+(F)) +/*@}*/ + +/* CD-audio API functions: */ + +/** + * Returns the number of CD-ROM drives on the system, or -1 if + * SDL_Init() has not been called with the SDL_INIT_CDROM flag. + */ +extern DECLSPEC int SDLCALL SDL_CDNumDrives(void); + +/** + * Returns a human-readable, system-dependent identifier for the CD-ROM. + * Example: + * - "/dev/cdrom" + * - "E:" + * - "/dev/disk/ide/1/master" + */ +extern DECLSPEC const char * SDLCALL SDL_CDName(int drive); + +/** + * Opens a CD-ROM drive for access. It returns a drive handle on success, + * or NULL if the drive was invalid or busy. This newly opened CD-ROM + * becomes the default CD used when other CD functions are passed a NULL + * CD-ROM handle. + * Drives are numbered starting with 0. Drive 0 is the system default CD-ROM. + */ +extern DECLSPEC SDL_CD * SDLCALL SDL_CDOpen(int drive); + +/** + * This function returns the current status of the given drive. + * If the drive has a CD in it, the table of contents of the CD and current + * play position of the CD will be stored in the SDL_CD structure. + */ +extern DECLSPEC CDstatus SDLCALL SDL_CDStatus(SDL_CD *cdrom); + +/** + * Play the given CD starting at 'start_track' and 'start_frame' for 'ntracks' + * tracks and 'nframes' frames. If both 'ntrack' and 'nframe' are 0, play + * until the end of the CD. This function will skip data tracks. + * This function should only be called after calling SDL_CDStatus() to + * get track information about the CD. + * For example: + * @code + * // Play entire CD: + * if ( CD_INDRIVE(SDL_CDStatus(cdrom)) ) + * SDL_CDPlayTracks(cdrom, 0, 0, 0, 0); + * // Play last track: + * if ( CD_INDRIVE(SDL_CDStatus(cdrom)) ) { + * SDL_CDPlayTracks(cdrom, cdrom->numtracks-1, 0, 0, 0); + * } + * // Play first and second track and 10 seconds of third track: + * if ( CD_INDRIVE(SDL_CDStatus(cdrom)) ) + * SDL_CDPlayTracks(cdrom, 0, 0, 2, 10); + * @endcode + * + * @return This function returns 0, or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_CDPlayTracks(SDL_CD *cdrom, + int start_track, int start_frame, int ntracks, int nframes); + +/** + * Play the given CD starting at 'start' frame for 'length' frames. + * @return It returns 0, or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_CDPlay(SDL_CD *cdrom, int start, int length); + +/** Pause play + * @return returns 0, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_CDPause(SDL_CD *cdrom); + +/** Resume play + * @return returns 0, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_CDResume(SDL_CD *cdrom); + +/** Stop play + * @return returns 0, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_CDStop(SDL_CD *cdrom); + +/** Eject CD-ROM + * @return returns 0, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_CDEject(SDL_CD *cdrom); + +/** Closes the handle for the CD-ROM drive */ +extern DECLSPEC void SDLCALL SDL_CDClose(SDL_CD *cdrom); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_video_h */ diff --git a/Externals/SDL/include/SDL_config.h b/Externals/SDL/include/SDL_config.h new file mode 100644 index 0000000000..a50810169c --- /dev/null +++ b/Externals/SDL/include/SDL_config.h @@ -0,0 +1,45 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_h +#define _SDL_config_h + +#include "SDL_platform.h" + +/* Add any platform that doesn't build using the configure system */ +#if defined(__DREAMCAST__) +#include "SDL_config_dreamcast.h" +#elif defined(__MACOS__) +#include "SDL_config_macos.h" +#elif defined(__MACOSX__) +#include "SDL_config_macosx.h" +#elif defined(__SYMBIAN32__) +#include "SDL_config_symbian.h" /* must be before win32! */ +#elif defined(__WIN32__) +#include "SDL_config_win32.h" +#elif defined(__OS2__) +#include "SDL_config_os2.h" +#else +#include "SDL_config_minimal.h" +#endif /* platform config */ + +#endif /* _SDL_config_h */ diff --git a/Externals/SDL/include/SDL_config.h.default b/Externals/SDL/include/SDL_config.h.default new file mode 100644 index 0000000000..a50810169c --- /dev/null +++ b/Externals/SDL/include/SDL_config.h.default @@ -0,0 +1,45 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_h +#define _SDL_config_h + +#include "SDL_platform.h" + +/* Add any platform that doesn't build using the configure system */ +#if defined(__DREAMCAST__) +#include "SDL_config_dreamcast.h" +#elif defined(__MACOS__) +#include "SDL_config_macos.h" +#elif defined(__MACOSX__) +#include "SDL_config_macosx.h" +#elif defined(__SYMBIAN32__) +#include "SDL_config_symbian.h" /* must be before win32! */ +#elif defined(__WIN32__) +#include "SDL_config_win32.h" +#elif defined(__OS2__) +#include "SDL_config_os2.h" +#else +#include "SDL_config_minimal.h" +#endif /* platform config */ + +#endif /* _SDL_config_h */ diff --git a/Externals/SDL/include/SDL_config.h.in b/Externals/SDL/include/SDL_config.h.in new file mode 100644 index 0000000000..58593ca2a5 --- /dev/null +++ b/Externals/SDL/include/SDL_config.h.in @@ -0,0 +1,310 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_h +#define _SDL_config_h + +/* This is a set of defines to configure the SDL features */ + +/* General platform specific identifiers */ +#include "SDL_platform.h" + +/* Make sure that this isn't included by Visual C++ */ +#ifdef _MSC_VER +#error You should copy include/SDL_config.h.default to include/SDL_config.h +#endif + +/* C language features */ +#undef const +#undef inline +#undef volatile + +/* C datatypes */ +#undef size_t +#undef int8_t +#undef uint8_t +#undef int16_t +#undef uint16_t +#undef int32_t +#undef uint32_t +#undef int64_t +#undef uint64_t +#undef uintptr_t +#undef SDL_HAS_64BIT_TYPE + +/* Endianness */ +#undef SDL_BYTEORDER + +/* Comment this if you want to build without any C library requirements */ +#undef HAVE_LIBC +#if HAVE_LIBC + +/* Useful headers */ +#undef HAVE_ALLOCA_H +#undef HAVE_SYS_TYPES_H +#undef HAVE_STDIO_H +#undef STDC_HEADERS +#undef HAVE_STDLIB_H +#undef HAVE_STDARG_H +#undef HAVE_MALLOC_H +#undef HAVE_MEMORY_H +#undef HAVE_STRING_H +#undef HAVE_STRINGS_H +#undef HAVE_INTTYPES_H +#undef HAVE_STDINT_H +#undef HAVE_CTYPE_H +#undef HAVE_MATH_H +#undef HAVE_ICONV_H +#undef HAVE_SIGNAL_H +#undef HAVE_ALTIVEC_H + +/* C library functions */ +#undef HAVE_MALLOC +#undef HAVE_CALLOC +#undef HAVE_REALLOC +#undef HAVE_FREE +#undef HAVE_ALLOCA +#ifndef _WIN32 /* Don't use C runtime versions of these on Windows */ +#undef HAVE_GETENV +#undef HAVE_PUTENV +#undef HAVE_UNSETENV +#endif +#undef HAVE_QSORT +#undef HAVE_ABS +#undef HAVE_BCOPY +#undef HAVE_MEMSET +#undef HAVE_MEMCPY +#undef HAVE_MEMMOVE +#undef HAVE_MEMCMP +#undef HAVE_STRLEN +#undef HAVE_STRLCPY +#undef HAVE_STRLCAT +#undef HAVE_STRDUP +#undef HAVE__STRREV +#undef HAVE__STRUPR +#undef HAVE__STRLWR +#undef HAVE_INDEX +#undef HAVE_RINDEX +#undef HAVE_STRCHR +#undef HAVE_STRRCHR +#undef HAVE_STRSTR +#undef HAVE_ITOA +#undef HAVE__LTOA +#undef HAVE__UITOA +#undef HAVE__ULTOA +#undef HAVE_STRTOL +#undef HAVE_STRTOUL +#undef HAVE__I64TOA +#undef HAVE__UI64TOA +#undef HAVE_STRTOLL +#undef HAVE_STRTOULL +#undef HAVE_STRTOD +#undef HAVE_ATOI +#undef HAVE_ATOF +#undef HAVE_STRCMP +#undef HAVE_STRNCMP +#undef HAVE__STRICMP +#undef HAVE_STRCASECMP +#undef HAVE__STRNICMP +#undef HAVE_STRNCASECMP +#undef HAVE_SSCANF +#undef HAVE_SNPRINTF +#undef HAVE_VSNPRINTF +#undef HAVE_ICONV +#undef HAVE_SIGACTION +#undef HAVE_SETJMP +#undef HAVE_NANOSLEEP +#undef HAVE_CLOCK_GETTIME +#undef HAVE_GETPAGESIZE +#undef HAVE_MPROTECT + +#else +/* We may need some replacement for stdarg.h here */ +#include +#endif /* HAVE_LIBC */ + +/* Allow disabling of core subsystems */ +#undef SDL_AUDIO_DISABLED +#undef SDL_CDROM_DISABLED +#undef SDL_CPUINFO_DISABLED +#undef SDL_EVENTS_DISABLED +#undef SDL_FILE_DISABLED +#undef SDL_JOYSTICK_DISABLED +#undef SDL_LOADSO_DISABLED +#undef SDL_THREADS_DISABLED +#undef SDL_TIMERS_DISABLED +#undef SDL_VIDEO_DISABLED + +/* Enable various audio drivers */ +#undef SDL_AUDIO_DRIVER_ALSA +#undef SDL_AUDIO_DRIVER_ALSA_DYNAMIC +#undef SDL_AUDIO_DRIVER_ARTS +#undef SDL_AUDIO_DRIVER_ARTS_DYNAMIC +#undef SDL_AUDIO_DRIVER_BAUDIO +#undef SDL_AUDIO_DRIVER_BSD +#undef SDL_AUDIO_DRIVER_COREAUDIO +#undef SDL_AUDIO_DRIVER_DART +#undef SDL_AUDIO_DRIVER_DC +#undef SDL_AUDIO_DRIVER_DISK +#undef SDL_AUDIO_DRIVER_DUMMY +#undef SDL_AUDIO_DRIVER_DMEDIA +#undef SDL_AUDIO_DRIVER_DSOUND +#undef SDL_AUDIO_DRIVER_PULSE +#undef SDL_AUDIO_DRIVER_PULSE_DYNAMIC +#undef SDL_AUDIO_DRIVER_ESD +#undef SDL_AUDIO_DRIVER_ESD_DYNAMIC +#undef SDL_AUDIO_DRIVER_MINT +#undef SDL_AUDIO_DRIVER_MMEAUDIO +#undef SDL_AUDIO_DRIVER_NAS +#undef SDL_AUDIO_DRIVER_NAS_DYNAMIC +#undef SDL_AUDIO_DRIVER_OSS +#undef SDL_AUDIO_DRIVER_OSS_SOUNDCARD_H +#undef SDL_AUDIO_DRIVER_PAUD +#undef SDL_AUDIO_DRIVER_QNXNTO +#undef SDL_AUDIO_DRIVER_SNDMGR +#undef SDL_AUDIO_DRIVER_SUNAUDIO +#undef SDL_AUDIO_DRIVER_WAVEOUT + +/* Enable various cdrom drivers */ +#undef SDL_CDROM_AIX +#undef SDL_CDROM_BEOS +#undef SDL_CDROM_BSDI +#undef SDL_CDROM_DC +#undef SDL_CDROM_DUMMY +#undef SDL_CDROM_FREEBSD +#undef SDL_CDROM_LINUX +#undef SDL_CDROM_MACOS +#undef SDL_CDROM_MACOSX +#undef SDL_CDROM_MINT +#undef SDL_CDROM_OPENBSD +#undef SDL_CDROM_OS2 +#undef SDL_CDROM_OSF +#undef SDL_CDROM_QNX +#undef SDL_CDROM_WIN32 + +/* Enable various input drivers */ +#undef SDL_INPUT_LINUXEV +#undef SDL_INPUT_TSLIB +#undef SDL_JOYSTICK_BEOS +#undef SDL_JOYSTICK_DC +#undef SDL_JOYSTICK_DUMMY +#undef SDL_JOYSTICK_IOKIT +#undef SDL_JOYSTICK_LINUX +#undef SDL_JOYSTICK_MACOS +#undef SDL_JOYSTICK_MINT +#undef SDL_JOYSTICK_OS2 +#undef SDL_JOYSTICK_RISCOS +#undef SDL_JOYSTICK_WINMM +#undef SDL_JOYSTICK_USBHID +#undef SDL_JOYSTICK_USBHID_MACHINE_JOYSTICK_H + +/* Enable various shared object loading systems */ +#undef SDL_LOADSO_BEOS +#undef SDL_LOADSO_DLCOMPAT +#undef SDL_LOADSO_DLOPEN +#undef SDL_LOADSO_DUMMY +#undef SDL_LOADSO_LDG +#undef SDL_LOADSO_MACOS +#undef SDL_LOADSO_OS2 +#undef SDL_LOADSO_WIN32 + +/* Enable various threading systems */ +#undef SDL_THREAD_BEOS +#undef SDL_THREAD_DC +#undef SDL_THREAD_OS2 +#undef SDL_THREAD_PTH +#undef SDL_THREAD_PTHREAD +#undef SDL_THREAD_PTHREAD_RECURSIVE_MUTEX +#undef SDL_THREAD_PTHREAD_RECURSIVE_MUTEX_NP +#undef SDL_THREAD_SPROC +#undef SDL_THREAD_WIN32 + +/* Enable various timer systems */ +#undef SDL_TIMER_BEOS +#undef SDL_TIMER_DC +#undef SDL_TIMER_DUMMY +#undef SDL_TIMER_MACOS +#undef SDL_TIMER_MINT +#undef SDL_TIMER_OS2 +#undef SDL_TIMER_RISCOS +#undef SDL_TIMER_UNIX +#undef SDL_TIMER_WIN32 +#undef SDL_TIMER_WINCE + +/* Enable various video drivers */ +#undef SDL_VIDEO_DRIVER_AALIB +#undef SDL_VIDEO_DRIVER_BWINDOW +#undef SDL_VIDEO_DRIVER_CACA +#undef SDL_VIDEO_DRIVER_DC +#undef SDL_VIDEO_DRIVER_DDRAW +#undef SDL_VIDEO_DRIVER_DGA +#undef SDL_VIDEO_DRIVER_DIRECTFB +#undef SDL_VIDEO_DRIVER_DRAWSPROCKET +#undef SDL_VIDEO_DRIVER_DUMMY +#undef SDL_VIDEO_DRIVER_FBCON +#undef SDL_VIDEO_DRIVER_GAPI +#undef SDL_VIDEO_DRIVER_GEM +#undef SDL_VIDEO_DRIVER_GGI +#undef SDL_VIDEO_DRIVER_IPOD +#undef SDL_VIDEO_DRIVER_NANOX +#undef SDL_VIDEO_DRIVER_OS2FS +#undef SDL_VIDEO_DRIVER_PHOTON +#undef SDL_VIDEO_DRIVER_PICOGUI +#undef SDL_VIDEO_DRIVER_PS2GS +#undef SDL_VIDEO_DRIVER_PS3 +#undef SDL_VIDEO_DRIVER_QTOPIA +#undef SDL_VIDEO_DRIVER_QUARTZ +#undef SDL_VIDEO_DRIVER_RISCOS +#undef SDL_VIDEO_DRIVER_SVGALIB +#undef SDL_VIDEO_DRIVER_TOOLBOX +#undef SDL_VIDEO_DRIVER_VGL +#undef SDL_VIDEO_DRIVER_WINDIB +#undef SDL_VIDEO_DRIVER_WSCONS +#undef SDL_VIDEO_DRIVER_X11 +#undef SDL_VIDEO_DRIVER_X11_DGAMOUSE +#undef SDL_VIDEO_DRIVER_X11_DYNAMIC +#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XEXT +#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XRANDR +#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XRENDER +#undef SDL_VIDEO_DRIVER_X11_VIDMODE +#undef SDL_VIDEO_DRIVER_X11_XINERAMA +#undef SDL_VIDEO_DRIVER_X11_XME +#undef SDL_VIDEO_DRIVER_X11_XRANDR +#undef SDL_VIDEO_DRIVER_X11_XV +#undef SDL_VIDEO_DRIVER_XBIOS + +/* Enable OpenGL support */ +#undef SDL_VIDEO_OPENGL +#undef SDL_VIDEO_OPENGL_GLX +#undef SDL_VIDEO_OPENGL_WGL +#undef SDL_VIDEO_OPENGL_OSMESA +#undef SDL_VIDEO_OPENGL_OSMESA_DYNAMIC + +/* Disable screensaver */ +#undef SDL_VIDEO_DISABLE_SCREENSAVER + +/* Enable assembly routines */ +#undef SDL_ASSEMBLY_ROUTINES +#undef SDL_HERMES_BLITTERS +#undef SDL_ALTIVEC_BLITTERS + +#endif /* _SDL_config_h */ diff --git a/Externals/SDL/include/SDL_config_dreamcast.h b/Externals/SDL/include/SDL_config_dreamcast.h new file mode 100644 index 0000000000..07c2f08155 --- /dev/null +++ b/Externals/SDL/include/SDL_config_dreamcast.h @@ -0,0 +1,106 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_dreamcast_h +#define _SDL_config_dreamcast_h + +#include "SDL_platform.h" + +/* This is a set of defines to configure the SDL features */ + +typedef signed char int8_t; +typedef unsigned char uint8_t; +typedef signed short int16_t; +typedef unsigned short uint16_t; +typedef signed int int32_t; +typedef unsigned int uint32_t; +typedef signed long long int64_t; +typedef unsigned long long uint64_t; +typedef unsigned long uintptr_t; +#define SDL_HAS_64BIT_TYPE 1 + +/* Useful headers */ +#define HAVE_SYS_TYPES_H 1 +#define HAVE_STDIO_H 1 +#define STDC_HEADERS 1 +#define HAVE_STRING_H 1 +#define HAVE_CTYPE_H 1 + +/* C library functions */ +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +#define HAVE_ALLOCA 1 +#define HAVE_GETENV 1 +#define HAVE_PUTENV 1 +#define HAVE_QSORT 1 +#define HAVE_ABS 1 +#define HAVE_BCOPY 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_MEMCMP 1 +#define HAVE_STRLEN 1 +#define HAVE_STRDUP 1 +#define HAVE_INDEX 1 +#define HAVE_RINDEX 1 +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +#define HAVE_STRTOL 1 +#define HAVE_STRTOD 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +#define HAVE_STRICMP 1 +#define HAVE_STRCASECMP 1 +#define HAVE_SSCANF 1 +#define HAVE_SNPRINTF 1 +#define HAVE_VSNPRINTF 1 + +/* Enable various audio drivers */ +#define SDL_AUDIO_DRIVER_DC 1 +#define SDL_AUDIO_DRIVER_DISK 1 +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable various cdrom drivers */ +#define SDL_CDROM_DC 1 + +/* Enable various input drivers */ +#define SDL_JOYSTICK_DC 1 + +/* Enable various shared object loading systems */ +#define SDL_LOADSO_DUMMY 1 + +/* Enable various threading systems */ +#define SDL_THREAD_DC 1 + +/* Enable various timer systems */ +#define SDL_TIMER_DC 1 + +/* Enable various video drivers */ +#define SDL_VIDEO_DRIVER_DC 1 +#define SDL_VIDEO_DRIVER_DUMMY 1 + +#endif /* _SDL_config_dreamcast_h */ diff --git a/Externals/SDL/include/SDL_config_macos.h b/Externals/SDL/include/SDL_config_macos.h new file mode 100644 index 0000000000..4ba5c22c34 --- /dev/null +++ b/Externals/SDL/include/SDL_config_macos.h @@ -0,0 +1,112 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_macos_h +#define _SDL_config_macos_h + +#include "SDL_platform.h" + +/* This is a set of defines to configure the SDL features */ + +#include + +typedef SInt8 int8_t; +typedef UInt8 uint8_t; +typedef SInt16 int16_t; +typedef UInt16 uint16_t; +typedef SInt32 int32_t; +typedef UInt32 uint32_t; +typedef SInt64 int64_t; +typedef UInt64 uint64_t; +typedef unsigned long uintptr_t; + +#define SDL_HAS_64BIT_TYPE 1 + +/* Useful headers */ +#define HAVE_STDIO_H 1 +#define STDC_HEADERS 1 +#define HAVE_STRING_H 1 +#define HAVE_CTYPE_H 1 +#define HAVE_MATH_H 1 +#define HAVE_SIGNAL_H 1 + +/* C library functions */ +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +#define HAVE_ALLOCA 1 +#define HAVE_ABS 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_MEMCMP 1 +#define HAVE_STRLEN 1 +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +#define HAVE_ITOA 1 +#define HAVE_STRTOL 1 +#define HAVE_STRTOD 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +#define HAVE_SSCANF 1 + +/* Enable various audio drivers */ +#define SDL_AUDIO_DRIVER_SNDMGR 1 +#define SDL_AUDIO_DRIVER_DISK 1 +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable various cdrom drivers */ +#if TARGET_API_MAC_CARBON +#define SDL_CDROM_DUMMY 1 +#else +#define SDL_CDROM_MACOS 1 +#endif + +/* Enable various input drivers */ +#if TARGET_API_MAC_CARBON +#define SDL_JOYSTICK_DUMMY 1 +#else +#define SDL_JOYSTICK_MACOS 1 +#endif + +/* Enable various shared object loading systems */ +#define SDL_LOADSO_MACOS 1 + +/* Enable various threading systems */ +#define SDL_THREADS_DISABLED 1 + +/* Enable various timer systems */ +#define SDL_TIMER_MACOS 1 + +/* Enable various video drivers */ +#define SDL_VIDEO_DRIVER_DUMMY 1 +#define SDL_VIDEO_DRIVER_DRAWSPROCKET 1 +#define SDL_VIDEO_DRIVER_TOOLBOX 1 + +/* Enable OpenGL support */ +#define SDL_VIDEO_OPENGL 1 + +#endif /* _SDL_config_macos_h */ diff --git a/Externals/SDL/include/SDL_config_macosx.h b/Externals/SDL/include/SDL_config_macosx.h new file mode 100644 index 0000000000..295b87245e --- /dev/null +++ b/Externals/SDL/include/SDL_config_macosx.h @@ -0,0 +1,150 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_macosx_h +#define _SDL_config_macosx_h + +#include "SDL_platform.h" + +/* This gets us MAC_OS_X_VERSION_MIN_REQUIRED... */ +#include + +/* This is a set of defines to configure the SDL features */ + +#define SDL_HAS_64BIT_TYPE 1 + +/* Useful headers */ +/* If we specified an SDK or have a post-PowerPC chip, then alloca.h exists. */ +#if ( (MAC_OS_X_VERSION_MIN_REQUIRED >= 1030) || (!defined(__POWERPC__)) ) +#define HAVE_ALLOCA_H 1 +#endif +#define HAVE_SYS_TYPES_H 1 +#define HAVE_STDIO_H 1 +#define STDC_HEADERS 1 +#define HAVE_STRING_H 1 +#define HAVE_INTTYPES_H 1 +#define HAVE_STDINT_H 1 +#define HAVE_CTYPE_H 1 +#define HAVE_MATH_H 1 +#define HAVE_SIGNAL_H 1 + +/* C library functions */ +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +#define HAVE_ALLOCA 1 +#define HAVE_GETENV 1 +#define HAVE_PUTENV 1 +#define HAVE_UNSETENV 1 +#define HAVE_QSORT 1 +#define HAVE_ABS 1 +#define HAVE_BCOPY 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_MEMCMP 1 +#define HAVE_STRLEN 1 +#define HAVE_STRLCPY 1 +#define HAVE_STRLCAT 1 +#define HAVE_STRDUP 1 +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +#define HAVE_STRTOL 1 +#define HAVE_STRTOUL 1 +#define HAVE_STRTOLL 1 +#define HAVE_STRTOULL 1 +#define HAVE_STRTOD 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +#define HAVE_STRCASECMP 1 +#define HAVE_STRNCASECMP 1 +#define HAVE_SSCANF 1 +#define HAVE_SNPRINTF 1 +#define HAVE_VSNPRINTF 1 +#define HAVE_SIGACTION 1 +#define HAVE_SETJMP 1 +#define HAVE_NANOSLEEP 1 + +/* Enable various audio drivers */ +#define SDL_AUDIO_DRIVER_COREAUDIO 1 +#define SDL_AUDIO_DRIVER_DISK 1 +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable various cdrom drivers */ +#define SDL_CDROM_MACOSX 1 + +/* Enable various input drivers */ +#define SDL_JOYSTICK_IOKIT 1 + +/* Enable various shared object loading systems */ +#ifdef __ppc__ +/* For Mac OS X 10.2 compatibility */ +#define SDL_LOADSO_DLCOMPAT 1 +#else +#define SDL_LOADSO_DLOPEN 1 +#endif + +/* Enable various threading systems */ +#define SDL_THREAD_PTHREAD 1 +#define SDL_THREAD_PTHREAD_RECURSIVE_MUTEX 1 + +/* Enable various timer systems */ +#define SDL_TIMER_UNIX 1 + +/* Enable various video drivers */ +#define SDL_VIDEO_DRIVER_DUMMY 1 +#if ((defined TARGET_API_MAC_CARBON) && (TARGET_API_MAC_CARBON)) +#define SDL_VIDEO_DRIVER_TOOLBOX 1 +#else +#define SDL_VIDEO_DRIVER_QUARTZ 1 +#endif +#define SDL_VIDEO_DRIVER_DGA 1 +#define SDL_VIDEO_DRIVER_X11 1 +#define SDL_VIDEO_DRIVER_X11_DGAMOUSE 1 +#define SDL_VIDEO_DRIVER_X11_DYNAMIC "/usr/X11R6/lib/libX11.6.dylib" +#define SDL_VIDEO_DRIVER_X11_DYNAMIC_XEXT "/usr/X11R6/lib/libXext.6.dylib" +#define SDL_VIDEO_DRIVER_X11_DYNAMIC_XRANDR "/usr/X11R6/lib/libXrandr.2.dylib" +#define SDL_VIDEO_DRIVER_X11_DYNAMIC_XRENDER "/usr/X11R6/lib/libXrender.1.dylib" +#define SDL_VIDEO_DRIVER_X11_VIDMODE 1 +#define SDL_VIDEO_DRIVER_X11_XINERAMA 1 +#define SDL_VIDEO_DRIVER_X11_XME 1 +#define SDL_VIDEO_DRIVER_X11_XRANDR 1 +#define SDL_VIDEO_DRIVER_X11_XV 1 + +/* Enable OpenGL support */ +#define SDL_VIDEO_OPENGL 1 +#define SDL_VIDEO_OPENGL_GLX 1 + +/* Disable screensaver */ +#define SDL_VIDEO_DISABLE_SCREENSAVER 1 + +/* Enable assembly routines */ +#define SDL_ASSEMBLY_ROUTINES 1 +#ifdef __ppc__ +#define SDL_ALTIVEC_BLITTERS 1 +#endif + +#endif /* _SDL_config_macosx_h */ diff --git a/Externals/SDL/include/SDL_config_minimal.h b/Externals/SDL/include/SDL_config_minimal.h new file mode 100644 index 0000000000..002c56eadb --- /dev/null +++ b/Externals/SDL/include/SDL_config_minimal.h @@ -0,0 +1,62 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_minimal_h +#define _SDL_config_minimal_h + +#include "SDL_platform.h" + +/* This is the minimal configuration that can be used to build SDL */ + +#include + +typedef signed char int8_t; +typedef unsigned char uint8_t; +typedef signed short int16_t; +typedef unsigned short uint16_t; +typedef signed int int32_t; +typedef unsigned int uint32_t; +typedef unsigned int size_t; +typedef unsigned long uintptr_t; + +/* Enable the dummy audio driver (src/audio/dummy/\*.c) */ +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable the stub cdrom driver (src/cdrom/dummy/\*.c) */ +#define SDL_CDROM_DISABLED 1 + +/* Enable the stub joystick driver (src/joystick/dummy/\*.c) */ +#define SDL_JOYSTICK_DISABLED 1 + +/* Enable the stub shared object loader (src/loadso/dummy/\*.c) */ +#define SDL_LOADSO_DISABLED 1 + +/* Enable the stub thread support (src/thread/generic/\*.c) */ +#define SDL_THREADS_DISABLED 1 + +/* Enable the stub timer support (src/timer/dummy/\*.c) */ +#define SDL_TIMERS_DISABLED 1 + +/* Enable the dummy video driver (src/video/dummy/\*.c) */ +#define SDL_VIDEO_DRIVER_DUMMY 1 + +#endif /* _SDL_config_minimal_h */ diff --git a/Externals/SDL/include/SDL_config_nds.h b/Externals/SDL/include/SDL_config_nds.h new file mode 100644 index 0000000000..4ac60a5045 --- /dev/null +++ b/Externals/SDL/include/SDL_config_nds.h @@ -0,0 +1,115 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_nds_h +#define _SDL_config_nds_h + +#include "SDL_platform.h" + +/* This is a set of defines to configure the SDL features */ + +/* General platform specific identifiers */ +#include "SDL_platform.h" + +/* C datatypes */ +#define SDL_HAS_64BIT_TYPE 1 + +/* Endianness */ +#define SDL_BYTEORDER 1234 + +/* Useful headers */ +#define HAVE_ALLOCA_H 1 +#define HAVE_SYS_TYPES_H 1 +#define HAVE_STDIO_H 1 +#define STDC_HEADERS 1 +#define HAVE_STDLIB_H 1 +#define HAVE_STDARG_H 1 +#define HAVE_MALLOC_H 1 +#define HAVE_STRING_H 1 +#define HAVE_INTTYPES_H 1 +#define HAVE_STDINT_H 1 +#define HAVE_CTYPE_H 1 +#define HAVE_MATH_H 1 +#define HAVE_ICONV_H 1 +#define HAVE_SIGNAL_H 1 + +/* C library functions */ +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +#define HAVE_ALLOCA 1 +#define HAVE_GETENV 1 +#define HAVE_PUTENV 1 +#define HAVE_UNSETENV 1 +#define HAVE_QSORT 1 +#define HAVE_ABS 1 +#define HAVE_BCOPY 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_STRLEN 1 +#define HAVE_STRLCPY 1 +#define HAVE_STRLCAT 1 +#define HAVE_STRDUP 1 +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +#define HAVE_STRTOL 1 +#define HAVE_STRTOUL 1 +#define HAVE_STRTOLL 1 +#define HAVE_STRTOULL 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +#define HAVE_STRCASECMP 1 +#define HAVE_STRNCASECMP 1 +#define HAVE_SSCANF 1 +#define HAVE_SNPRINTF 1 +#define HAVE_VSNPRINTF 1 +#define HAVE_SETJMP 1 + +/* Enable various audio drivers */ +#define SDL_AUDIO_DRIVER_NDS 1 +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable the stub cdrom driver (src/cdrom/dummy/\*.c) */ +#define SDL_CDROM_DISABLED 1 + +/* Enable various input drivers */ +#define SDL_JOYSTICK_NDS 1 + +/* Enable the stub shared object loader (src/loadso/dummy/\*.c) */ +#define SDL_LOADSO_DISABLED 1 + +/* Enable the stub thread support (src/thread/generic/\*.c) */ +#define SDL_THREADS_DISABLED 1 + +/* Enable various timer systems */ +#define SDL_TIMER_NDS 1 + +/* Enable various video drivers */ +#define SDL_VIDEO_DRIVER_NDS 1 +#define SDL_VIDEO_DRIVER_DUMMY 1 + +#endif /* _SDL_config_nds_h */ diff --git a/Externals/SDL/include/SDL_config_os2.h b/Externals/SDL/include/SDL_config_os2.h new file mode 100644 index 0000000000..bb40df0018 --- /dev/null +++ b/Externals/SDL/include/SDL_config_os2.h @@ -0,0 +1,141 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_os2_h +#define _SDL_config_os2_h + +#include "SDL_platform.h" + +/* This is a set of defines to configure the SDL features */ + +typedef signed char int8_t; +typedef unsigned char uint8_t; +typedef signed short int16_t; +typedef unsigned short uint16_t; +typedef signed int int32_t; +typedef unsigned int uint32_t; +typedef unsigned int size_t; +typedef unsigned long uintptr_t; +typedef signed long long int64_t; +typedef unsigned long long uint64_t; + +#define SDL_HAS_64BIT_TYPE 1 + +/* Use Watcom's LIBC */ +#define HAVE_LIBC 1 + +/* Useful headers */ +#define HAVE_SYS_TYPES_H 1 +#define HAVE_STDIO_H 1 +#define STDC_HEADERS 1 +#define HAVE_STDLIB_H 1 +#define HAVE_STDARG_H 1 +#define HAVE_MALLOC_H 1 +#define HAVE_MEMORY_H 1 +#define HAVE_STRING_H 1 +#define HAVE_STRINGS_H 1 +#define HAVE_INTTYPES_H 1 +#define HAVE_STDINT_H 1 +#define HAVE_CTYPE_H 1 +#define HAVE_MATH_H 1 +#define HAVE_SIGNAL_H 1 + +/* C library functions */ +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +#define HAVE_ALLOCA 1 +#define HAVE_GETENV 1 +#define HAVE_PUTENV 1 +#define HAVE_UNSETENV 1 +#define HAVE_QSORT 1 +#define HAVE_ABS 1 +#define HAVE_BCOPY 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_MEMCMP 1 +#define HAVE_STRLEN 1 +#define HAVE_STRLCPY 1 +#define HAVE_STRLCAT 1 +#define HAVE_STRDUP 1 +#define HAVE__STRREV 1 +#define HAVE__STRUPR 1 +#define HAVE__STRLWR 1 +#define HAVE_INDEX 1 +#define HAVE_RINDEX 1 +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +#define HAVE_ITOA 1 +#define HAVE__LTOA 1 +#define HAVE__UITOA 1 +#define HAVE__ULTOA 1 +#define HAVE_STRTOL 1 +#define HAVE__I64TOA 1 +#define HAVE__UI64TOA 1 +#define HAVE_STRTOLL 1 +#define HAVE_STRTOD 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +#define HAVE_STRICMP 1 +#define HAVE_STRCASECMP 1 +#define HAVE_SSCANF 1 +#define HAVE_SNPRINTF 1 +#define HAVE_VSNPRINTF 1 +#define HAVE_SETJMP 1 +#define HAVE_CLOCK_GETTIME 1 + +/* Enable various audio drivers */ +#define SDL_AUDIO_DRIVER_DART 1 +#define SDL_AUDIO_DRIVER_DISK 1 +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable various cdrom drivers */ +#define SDL_CDROM_OS2 1 + +/* Enable various input drivers */ +#define SDL_JOYSTICK_OS2 1 + +/* Enable various shared object loading systems */ +#define SDL_LOADSO_OS2 1 + +/* Enable various threading systems */ +#define SDL_THREAD_OS2 1 + +/* Enable various timer systems */ +#define SDL_TIMER_OS2 1 + +/* Enable various video drivers */ +#define SDL_VIDEO_DRIVER_DUMMY 1 +#define SDL_VIDEO_DRIVER_OS2FS 1 + +/* Enable OpenGL support */ +/* Nothing here yet for OS/2... :( */ + +/* Enable assembly routines where available */ +#define SDL_ASSEMBLY_ROUTINES 1 + +#endif /* _SDL_config_os2_h */ diff --git a/Externals/SDL/include/SDL_config_symbian.h b/Externals/SDL/include/SDL_config_symbian.h new file mode 100644 index 0000000000..53527b2324 --- /dev/null +++ b/Externals/SDL/include/SDL_config_symbian.h @@ -0,0 +1,146 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/* + +Symbian version Markus Mertama + +*/ + + +#ifndef _SDL_CONFIG_SYMBIAN_H +#define _SDL_CONFIG_SYMBIAN_H + +#include "SDL_platform.h" + +/* This is the minimal configuration that can be used to build SDL */ + + +#include +#include + + +#ifdef __GCCE__ +#define SYMBIAN32_GCCE +#endif + +#ifndef _SIZE_T_DEFINED +typedef unsigned int size_t; +#endif + +#ifndef _INTPTR_T_DECLARED +typedef unsigned int uintptr_t; +#endif + +#ifndef _INT8_T_DECLARED +typedef signed char int8_t; +#endif + +#ifndef _UINT8_T_DECLARED +typedef unsigned char uint8_t; +#endif + +#ifndef _INT16_T_DECLARED +typedef signed short int16_t; +#endif + +#ifndef _UINT16_T_DECLARED +typedef unsigned short uint16_t; +#endif + +#ifndef _INT32_T_DECLARED +typedef signed int int32_t; +#endif + +#ifndef _UINT32_T_DECLARED +typedef unsigned int uint32_t; +#endif + +#ifndef _INT64_T_DECLARED +typedef signed long long int64_t; +#endif + +#ifndef _UINT64_T_DECLARED +typedef unsigned long long uint64_t; +#endif + +#define SDL_AUDIO_DRIVER_EPOCAUDIO 1 + + +/* Enable the stub cdrom driver (src/cdrom/dummy/\*.c) */ +#define SDL_CDROM_DISABLED 1 + +/* Enable the stub joystick driver (src/joystick/dummy/\*.c) */ +#define SDL_JOYSTICK_DISABLED 1 + +/* Enable the stub shared object loader (src/loadso/dummy/\*.c) */ +#define SDL_LOADSO_DISABLED 1 + +#define SDL_THREAD_SYMBIAN 1 + +#define SDL_VIDEO_DRIVER_EPOC 1 + +#define SDL_VIDEO_OPENGL 0 + +#define SDL_HAS_64BIT_TYPE 1 + +#define HAVE_LIBC 1 +#define HAVE_STDIO_H 1 +#define STDC_HEADERS 1 +#define HAVE_STRING_H 1 +#define HAVE_CTYPE_H 1 +#define HAVE_MATH_H 1 + +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +/*#define HAVE_ALLOCA 1*/ +#define HAVE_QSORT 1 +#define HAVE_ABS 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_MEMCMP 1 +#define HAVE_STRLEN 1 +#define HAVE__STRUPR 1 +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +#define HAVE_ITOA 1 +#define HAVE_STRTOL 1 +#define HAVE_STRTOUL 1 +#define HAVE_STRTOLL 1 +#define HAVE_STRTOD 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +/*#define HAVE__STRICMP 1*/ +#define HAVE__STRNICMP 1 +#define HAVE_SSCANF 1 +#define HAVE_STDARG_H 1 +#define HAVE_STDDEF_H 1 + + + +#endif /* _SDL_CONFIG_SYMBIAN_H */ diff --git a/Externals/SDL/include/SDL_config_win32.h b/Externals/SDL/include/SDL_config_win32.h new file mode 100644 index 0000000000..6d019a8d9c --- /dev/null +++ b/Externals/SDL/include/SDL_config_win32.h @@ -0,0 +1,183 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_config_win32_h +#define _SDL_config_win32_h + +#include "SDL_platform.h" + +/* This is a set of defines to configure the SDL features */ + +#if defined(__GNUC__) || defined(__DMC__) +#define HAVE_STDINT_H 1 +#elif defined(_MSC_VER) +typedef signed __int8 int8_t; +typedef unsigned __int8 uint8_t; +typedef signed __int16 int16_t; +typedef unsigned __int16 uint16_t; +typedef signed __int32 int32_t; +typedef unsigned __int32 uint32_t; +typedef signed __int64 int64_t; +typedef unsigned __int64 uint64_t; +#ifndef _UINTPTR_T_DEFINED +#ifdef _WIN64 +typedef unsigned __int64 uintptr_t; +#else +typedef unsigned int uintptr_t; +#endif +#define _UINTPTR_T_DEFINED +#endif +/* Older Visual C++ headers don't have the Win64-compatible typedefs... */ +#if ((_MSC_VER <= 1200) && (!defined(DWORD_PTR))) +#define DWORD_PTR DWORD +#endif +#if ((_MSC_VER <= 1200) && (!defined(LONG_PTR))) +#define LONG_PTR LONG +#endif +#else /* !__GNUC__ && !_MSC_VER */ +typedef signed char int8_t; +typedef unsigned char uint8_t; +typedef signed short int16_t; +typedef unsigned short uint16_t; +typedef signed int int32_t; +typedef unsigned int uint32_t; +typedef signed long long int64_t; +typedef unsigned long long uint64_t; +#ifndef _SIZE_T_DEFINED_ +#define _SIZE_T_DEFINED_ +typedef unsigned int size_t; +#endif +typedef unsigned int uintptr_t; +#endif /* __GNUC__ || _MSC_VER */ +#define SDL_HAS_64BIT_TYPE 1 + +/* Enabled for SDL 1.2 (binary compatibility) */ +#define HAVE_LIBC 1 +#ifdef HAVE_LIBC +/* Useful headers */ +#define HAVE_STDIO_H 1 +#define STDC_HEADERS 1 +#define HAVE_STRING_H 1 +#define HAVE_CTYPE_H 1 +#define HAVE_MATH_H 1 +#ifndef _WIN32_WCE +#define HAVE_SIGNAL_H 1 +#endif + +/* C library functions */ +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +#define HAVE_ALLOCA 1 +#define HAVE_QSORT 1 +#define HAVE_ABS 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_MEMCMP 1 +#define HAVE_STRLEN 1 +#define HAVE__STRREV 1 +#define HAVE__STRUPR 1 +#define HAVE__STRLWR 1 +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +#define HAVE_ITOA 1 +#define HAVE__LTOA 1 +#define HAVE__ULTOA 1 +#define HAVE_STRTOL 1 +#define HAVE_STRTOUL 1 +#define HAVE_STRTOLL 1 +#define HAVE_STRTOD 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +#define HAVE__STRICMP 1 +#define HAVE__STRNICMP 1 +#define HAVE_SSCANF 1 +#else +#define HAVE_STDARG_H 1 +#define HAVE_STDDEF_H 1 +#endif + +/* Enable various audio drivers */ +#ifndef _WIN32_WCE +#define SDL_AUDIO_DRIVER_DSOUND 1 +#endif +#define SDL_AUDIO_DRIVER_WAVEOUT 1 +#define SDL_AUDIO_DRIVER_DISK 1 +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable various cdrom drivers */ +#ifdef _WIN32_WCE +#define SDL_CDROM_DISABLED 1 +#else +#define SDL_CDROM_WIN32 1 +#endif + +/* Enable various input drivers */ +#ifdef _WIN32_WCE +#define SDL_JOYSTICK_DISABLED 1 +#else +#define SDL_JOYSTICK_WINMM 1 +#endif + +/* Enable various shared object loading systems */ +#define SDL_LOADSO_WIN32 1 + +/* Enable various threading systems */ +#define SDL_THREAD_WIN32 1 + +/* Enable various timer systems */ +#ifdef _WIN32_WCE +#define SDL_TIMER_WINCE 1 +#else +#define SDL_TIMER_WIN32 1 +#endif + +/* Enable various video drivers */ +#ifdef _WIN32_WCE +#define SDL_VIDEO_DRIVER_GAPI 1 +#endif +#ifndef _WIN32_WCE +#define SDL_VIDEO_DRIVER_DDRAW 1 +#endif +#define SDL_VIDEO_DRIVER_DUMMY 1 +#define SDL_VIDEO_DRIVER_WINDIB 1 + +/* Enable OpenGL support */ +#ifndef _WIN32_WCE +#define SDL_VIDEO_OPENGL 1 +#define SDL_VIDEO_OPENGL_WGL 1 +#endif + +/* Disable screensaver */ +#define SDL_VIDEO_DISABLE_SCREENSAVER 1 + +/* Enable assembly routines (Win64 doesn't have inline asm) */ +#ifndef _WIN64 +#define SDL_ASSEMBLY_ROUTINES 1 +#endif + +#endif /* _SDL_config_win32_h */ diff --git a/Externals/SDL/include/SDL_copying.h b/Externals/SDL/include/SDL_copying.h new file mode 100644 index 0000000000..1bd6b84cd8 --- /dev/null +++ b/Externals/SDL/include/SDL_copying.h @@ -0,0 +1,22 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + diff --git a/Externals/SDL/include/SDL_cpuinfo.h b/Externals/SDL/include/SDL_cpuinfo.h new file mode 100644 index 0000000000..f4be8e0323 --- /dev/null +++ b/Externals/SDL/include/SDL_cpuinfo.h @@ -0,0 +1,69 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_cpuinfo.h + * CPU feature detection for SDL + */ + +#ifndef _SDL_cpuinfo_h +#define _SDL_cpuinfo_h + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** This function returns true if the CPU has the RDTSC instruction */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasRDTSC(void); + +/** This function returns true if the CPU has MMX features */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasMMX(void); + +/** This function returns true if the CPU has MMX Ext. features */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasMMXExt(void); + +/** This function returns true if the CPU has 3DNow features */ +extern DECLSPEC SDL_bool SDLCALL SDL_Has3DNow(void); + +/** This function returns true if the CPU has 3DNow! Ext. features */ +extern DECLSPEC SDL_bool SDLCALL SDL_Has3DNowExt(void); + +/** This function returns true if the CPU has SSE features */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE(void); + +/** This function returns true if the CPU has SSE2 features */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE2(void); + +/** This function returns true if the CPU has AltiVec features */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasAltiVec(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_cpuinfo_h */ diff --git a/Externals/SDL/include/SDL_endian.h b/Externals/SDL/include/SDL_endian.h new file mode 100644 index 0000000000..f7a2e2f8c0 --- /dev/null +++ b/Externals/SDL/include/SDL_endian.h @@ -0,0 +1,209 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_endian.h + * Functions for reading and writing endian-specific values + */ + +#ifndef _SDL_endian_h +#define _SDL_endian_h + +#include "SDL_stdinc.h" + +/** @name SDL_ENDIANs + * The two types of endianness + */ +/*@{*/ +#define SDL_LIL_ENDIAN 1234 +#define SDL_BIG_ENDIAN 4321 +/*@}*/ + +#ifndef SDL_BYTEORDER /* Not defined in SDL_config.h? */ +#if defined(__hppa__) || \ + defined(__m68k__) || defined(mc68000) || defined(_M_M68K) || \ + (defined(__MIPS__) && defined(__MISPEB__)) || \ + defined(__ppc__) || defined(__POWERPC__) || defined(_M_PPC) || \ + defined(__sparc__) +#define SDL_BYTEORDER SDL_BIG_ENDIAN +#else +#define SDL_BYTEORDER SDL_LIL_ENDIAN +#endif +#endif /* !SDL_BYTEORDER */ + + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @name SDL_Swap Functions + * Use inline functions for compilers that support them, and static + * functions for those that do not. Because these functions become + * static for compilers that do not support inline functions, this + * header should only be included in files that actually use them. + */ +/*@{*/ +#if defined(__GNUC__) && defined(__i386__) && \ + !(__GNUC__ == 2 && __GNUC_MINOR__ <= 95 /* broken gcc version */) +static __inline__ Uint16 SDL_Swap16(Uint16 x) +{ + __asm__("xchgb %b0,%h0" : "=q" (x) : "0" (x)); + return x; +} +#elif defined(__GNUC__) && defined(__x86_64__) +static __inline__ Uint16 SDL_Swap16(Uint16 x) +{ + __asm__("xchgb %b0,%h0" : "=Q" (x) : "0" (x)); + return x; +} +#elif defined(__GNUC__) && (defined(__powerpc__) || defined(__ppc__)) +static __inline__ Uint16 SDL_Swap16(Uint16 x) +{ + Uint16 result; + + __asm__("rlwimi %0,%2,8,16,23" : "=&r" (result) : "0" (x >> 8), "r" (x)); + return result; +} +#elif defined(__GNUC__) && (defined(__M68000__) || defined(__M68020__)) +static __inline__ Uint16 SDL_Swap16(Uint16 x) +{ + __asm__("rorw #8,%0" : "=d" (x) : "0" (x) : "cc"); + return x; +} +#else +static __inline__ Uint16 SDL_Swap16(Uint16 x) { + return((x<<8)|(x>>8)); +} +#endif + +#if defined(__GNUC__) && defined(__i386__) && \ + !(__GNUC__ == 2 && __GNUC_MINOR__ <= 95 /* broken gcc version */) +static __inline__ Uint32 SDL_Swap32(Uint32 x) +{ + __asm__("bswap %0" : "=r" (x) : "0" (x)); + return x; +} +#elif defined(__GNUC__) && defined(__x86_64__) +static __inline__ Uint32 SDL_Swap32(Uint32 x) +{ + __asm__("bswapl %0" : "=r" (x) : "0" (x)); + return x; +} +#elif defined(__GNUC__) && (defined(__powerpc__) || defined(__ppc__)) +static __inline__ Uint32 SDL_Swap32(Uint32 x) +{ + Uint32 result; + + __asm__("rlwimi %0,%2,24,16,23" : "=&r" (result) : "0" (x>>24), "r" (x)); + __asm__("rlwimi %0,%2,8,8,15" : "=&r" (result) : "0" (result), "r" (x)); + __asm__("rlwimi %0,%2,24,0,7" : "=&r" (result) : "0" (result), "r" (x)); + return result; +} +#elif defined(__GNUC__) && (defined(__M68000__) || defined(__M68020__)) +static __inline__ Uint32 SDL_Swap32(Uint32 x) +{ + __asm__("rorw #8,%0\n\tswap %0\n\trorw #8,%0" : "=d" (x) : "0" (x) : "cc"); + return x; +} +#else +static __inline__ Uint32 SDL_Swap32(Uint32 x) { + return((x<<24)|((x<<8)&0x00FF0000)|((x>>8)&0x0000FF00)|(x>>24)); +} +#endif + +#ifdef SDL_HAS_64BIT_TYPE +#if defined(__GNUC__) && defined(__i386__) && \ + !(__GNUC__ == 2 && __GNUC_MINOR__ <= 95 /* broken gcc version */) +static __inline__ Uint64 SDL_Swap64(Uint64 x) +{ + union { + struct { Uint32 a,b; } s; + Uint64 u; + } v; + v.u = x; + __asm__("bswapl %0 ; bswapl %1 ; xchgl %0,%1" + : "=r" (v.s.a), "=r" (v.s.b) + : "0" (v.s.a), "1" (v.s.b)); + return v.u; +} +#elif defined(__GNUC__) && defined(__x86_64__) +static __inline__ Uint64 SDL_Swap64(Uint64 x) +{ + __asm__("bswapq %0" : "=r" (x) : "0" (x)); + return x; +} +#else +static __inline__ Uint64 SDL_Swap64(Uint64 x) +{ + Uint32 hi, lo; + + /* Separate into high and low 32-bit values and swap them */ + lo = SDL_static_cast(Uint32, x & 0xFFFFFFFF); + x >>= 32; + hi = SDL_static_cast(Uint32, x & 0xFFFFFFFF); + x = SDL_Swap32(lo); + x <<= 32; + x |= SDL_Swap32(hi); + return(x); +} +#endif +#else +/* This is mainly to keep compilers from complaining in SDL code. + * If there is no real 64-bit datatype, then compilers will complain about + * the fake 64-bit datatype that SDL provides when it compiles user code. + */ +#define SDL_Swap64(X) (X) +#endif /* SDL_HAS_64BIT_TYPE */ +/*@}*/ + +/** + * @name SDL_SwapLE and SDL_SwapBE Functions + * Byteswap item from the specified endianness to the native endianness + */ +/*@{*/ +#if SDL_BYTEORDER == SDL_LIL_ENDIAN +#define SDL_SwapLE16(X) (X) +#define SDL_SwapLE32(X) (X) +#define SDL_SwapLE64(X) (X) +#define SDL_SwapBE16(X) SDL_Swap16(X) +#define SDL_SwapBE32(X) SDL_Swap32(X) +#define SDL_SwapBE64(X) SDL_Swap64(X) +#else +#define SDL_SwapLE16(X) SDL_Swap16(X) +#define SDL_SwapLE32(X) SDL_Swap32(X) +#define SDL_SwapLE64(X) SDL_Swap64(X) +#define SDL_SwapBE16(X) (X) +#define SDL_SwapBE32(X) (X) +#define SDL_SwapBE64(X) (X) +#endif +/*@}*/ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_endian_h */ diff --git a/Externals/SDL/include/SDL_error.h b/Externals/SDL/include/SDL_error.h new file mode 100644 index 0000000000..b103703a5b --- /dev/null +++ b/Externals/SDL/include/SDL_error.h @@ -0,0 +1,72 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_error.h + * Simple error message routines for SDL + */ + +#ifndef _SDL_error_h +#define _SDL_error_h + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @name Public functions + */ +/*@{*/ +extern DECLSPEC void SDLCALL SDL_SetError(const char *fmt, ...); +extern DECLSPEC char * SDLCALL SDL_GetError(void); +extern DECLSPEC void SDLCALL SDL_ClearError(void); +/*@}*/ + +/** + * @name Private functions + * @internal Private error message function - used internally + */ +/*@{*/ +#define SDL_OutOfMemory() SDL_Error(SDL_ENOMEM) +#define SDL_Unsupported() SDL_Error(SDL_UNSUPPORTED) +typedef enum { + SDL_ENOMEM, + SDL_EFREAD, + SDL_EFWRITE, + SDL_EFSEEK, + SDL_UNSUPPORTED, + SDL_LASTERROR +} SDL_errorcode; +extern DECLSPEC void SDLCALL SDL_Error(SDL_errorcode code); +/*@}*/ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_error_h */ diff --git a/Externals/SDL/include/SDL_events.h b/Externals/SDL/include/SDL_events.h new file mode 100644 index 0000000000..c94a30c9c9 --- /dev/null +++ b/Externals/SDL/include/SDL_events.h @@ -0,0 +1,356 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file SDL_events.h + * Include file for SDL event handling + */ + +#ifndef _SDL_events_h +#define _SDL_events_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_active.h" +#include "SDL_keyboard.h" +#include "SDL_mouse.h" +#include "SDL_joystick.h" +#include "SDL_quit.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** @name General keyboard/mouse state definitions */ +/*@{*/ +#define SDL_RELEASED 0 +#define SDL_PRESSED 1 +/*@}*/ + +/** Event enumerations */ +typedef enum { + SDL_NOEVENT = 0, /**< Unused (do not remove) */ + SDL_ACTIVEEVENT, /**< Application loses/gains visibility */ + SDL_KEYDOWN, /**< Keys pressed */ + SDL_KEYUP, /**< Keys released */ + SDL_MOUSEMOTION, /**< Mouse moved */ + SDL_MOUSEBUTTONDOWN, /**< Mouse button pressed */ + SDL_MOUSEBUTTONUP, /**< Mouse button released */ + SDL_JOYAXISMOTION, /**< Joystick axis motion */ + SDL_JOYBALLMOTION, /**< Joystick trackball motion */ + SDL_JOYHATMOTION, /**< Joystick hat position change */ + SDL_JOYBUTTONDOWN, /**< Joystick button pressed */ + SDL_JOYBUTTONUP, /**< Joystick button released */ + SDL_QUIT, /**< User-requested quit */ + SDL_SYSWMEVENT, /**< System specific event */ + SDL_EVENT_RESERVEDA, /**< Reserved for future use.. */ + SDL_EVENT_RESERVEDB, /**< Reserved for future use.. */ + SDL_VIDEORESIZE, /**< User resized video mode */ + SDL_VIDEOEXPOSE, /**< Screen needs to be redrawn */ + SDL_EVENT_RESERVED2, /**< Reserved for future use.. */ + SDL_EVENT_RESERVED3, /**< Reserved for future use.. */ + SDL_EVENT_RESERVED4, /**< Reserved for future use.. */ + SDL_EVENT_RESERVED5, /**< Reserved for future use.. */ + SDL_EVENT_RESERVED6, /**< Reserved for future use.. */ + SDL_EVENT_RESERVED7, /**< Reserved for future use.. */ + /** Events SDL_USEREVENT through SDL_MAXEVENTS-1 are for your use */ + SDL_USEREVENT = 24, + /** This last event is only for bounding internal arrays + * It is the number of bits in the event mask datatype -- Uint32 + */ + SDL_NUMEVENTS = 32 +} SDL_EventType; + +/** @name Predefined event masks */ +/*@{*/ +#define SDL_EVENTMASK(X) (1<<(X)) +typedef enum { + SDL_ACTIVEEVENTMASK = SDL_EVENTMASK(SDL_ACTIVEEVENT), + SDL_KEYDOWNMASK = SDL_EVENTMASK(SDL_KEYDOWN), + SDL_KEYUPMASK = SDL_EVENTMASK(SDL_KEYUP), + SDL_KEYEVENTMASK = SDL_EVENTMASK(SDL_KEYDOWN)| + SDL_EVENTMASK(SDL_KEYUP), + SDL_MOUSEMOTIONMASK = SDL_EVENTMASK(SDL_MOUSEMOTION), + SDL_MOUSEBUTTONDOWNMASK = SDL_EVENTMASK(SDL_MOUSEBUTTONDOWN), + SDL_MOUSEBUTTONUPMASK = SDL_EVENTMASK(SDL_MOUSEBUTTONUP), + SDL_MOUSEEVENTMASK = SDL_EVENTMASK(SDL_MOUSEMOTION)| + SDL_EVENTMASK(SDL_MOUSEBUTTONDOWN)| + SDL_EVENTMASK(SDL_MOUSEBUTTONUP), + SDL_JOYAXISMOTIONMASK = SDL_EVENTMASK(SDL_JOYAXISMOTION), + SDL_JOYBALLMOTIONMASK = SDL_EVENTMASK(SDL_JOYBALLMOTION), + SDL_JOYHATMOTIONMASK = SDL_EVENTMASK(SDL_JOYHATMOTION), + SDL_JOYBUTTONDOWNMASK = SDL_EVENTMASK(SDL_JOYBUTTONDOWN), + SDL_JOYBUTTONUPMASK = SDL_EVENTMASK(SDL_JOYBUTTONUP), + SDL_JOYEVENTMASK = SDL_EVENTMASK(SDL_JOYAXISMOTION)| + SDL_EVENTMASK(SDL_JOYBALLMOTION)| + SDL_EVENTMASK(SDL_JOYHATMOTION)| + SDL_EVENTMASK(SDL_JOYBUTTONDOWN)| + SDL_EVENTMASK(SDL_JOYBUTTONUP), + SDL_VIDEORESIZEMASK = SDL_EVENTMASK(SDL_VIDEORESIZE), + SDL_VIDEOEXPOSEMASK = SDL_EVENTMASK(SDL_VIDEOEXPOSE), + SDL_QUITMASK = SDL_EVENTMASK(SDL_QUIT), + SDL_SYSWMEVENTMASK = SDL_EVENTMASK(SDL_SYSWMEVENT) +} SDL_EventMask ; +#define SDL_ALLEVENTS 0xFFFFFFFF +/*@}*/ + +/** Application visibility event structure */ +typedef struct SDL_ActiveEvent { + Uint8 type; /**< SDL_ACTIVEEVENT */ + Uint8 gain; /**< Whether given states were gained or lost (1/0) */ + Uint8 state; /**< A mask of the focus states */ +} SDL_ActiveEvent; + +/** Keyboard event structure */ +typedef struct SDL_KeyboardEvent { + Uint8 type; /**< SDL_KEYDOWN or SDL_KEYUP */ + Uint8 which; /**< The keyboard device index */ + Uint8 state; /**< SDL_PRESSED or SDL_RELEASED */ + SDL_keysym keysym; +} SDL_KeyboardEvent; + +/** Mouse motion event structure */ +typedef struct SDL_MouseMotionEvent { + Uint8 type; /**< SDL_MOUSEMOTION */ + Uint8 which; /**< The mouse device index */ + Uint8 state; /**< The current button state */ + Uint16 x, y; /**< The X/Y coordinates of the mouse */ + Sint16 xrel; /**< The relative motion in the X direction */ + Sint16 yrel; /**< The relative motion in the Y direction */ +} SDL_MouseMotionEvent; + +/** Mouse button event structure */ +typedef struct SDL_MouseButtonEvent { + Uint8 type; /**< SDL_MOUSEBUTTONDOWN or SDL_MOUSEBUTTONUP */ + Uint8 which; /**< The mouse device index */ + Uint8 button; /**< The mouse button index */ + Uint8 state; /**< SDL_PRESSED or SDL_RELEASED */ + Uint16 x, y; /**< The X/Y coordinates of the mouse at press time */ +} SDL_MouseButtonEvent; + +/** Joystick axis motion event structure */ +typedef struct SDL_JoyAxisEvent { + Uint8 type; /**< SDL_JOYAXISMOTION */ + Uint8 which; /**< The joystick device index */ + Uint8 axis; /**< The joystick axis index */ + Sint16 value; /**< The axis value (range: -32768 to 32767) */ +} SDL_JoyAxisEvent; + +/** Joystick trackball motion event structure */ +typedef struct SDL_JoyBallEvent { + Uint8 type; /**< SDL_JOYBALLMOTION */ + Uint8 which; /**< The joystick device index */ + Uint8 ball; /**< The joystick trackball index */ + Sint16 xrel; /**< The relative motion in the X direction */ + Sint16 yrel; /**< The relative motion in the Y direction */ +} SDL_JoyBallEvent; + +/** Joystick hat position change event structure */ +typedef struct SDL_JoyHatEvent { + Uint8 type; /**< SDL_JOYHATMOTION */ + Uint8 which; /**< The joystick device index */ + Uint8 hat; /**< The joystick hat index */ + Uint8 value; /**< The hat position value: + * SDL_HAT_LEFTUP SDL_HAT_UP SDL_HAT_RIGHTUP + * SDL_HAT_LEFT SDL_HAT_CENTERED SDL_HAT_RIGHT + * SDL_HAT_LEFTDOWN SDL_HAT_DOWN SDL_HAT_RIGHTDOWN + * Note that zero means the POV is centered. + */ +} SDL_JoyHatEvent; + +/** Joystick button event structure */ +typedef struct SDL_JoyButtonEvent { + Uint8 type; /**< SDL_JOYBUTTONDOWN or SDL_JOYBUTTONUP */ + Uint8 which; /**< The joystick device index */ + Uint8 button; /**< The joystick button index */ + Uint8 state; /**< SDL_PRESSED or SDL_RELEASED */ +} SDL_JoyButtonEvent; + +/** The "window resized" event + * When you get this event, you are responsible for setting a new video + * mode with the new width and height. + */ +typedef struct SDL_ResizeEvent { + Uint8 type; /**< SDL_VIDEORESIZE */ + int w; /**< New width */ + int h; /**< New height */ +} SDL_ResizeEvent; + +/** The "screen redraw" event */ +typedef struct SDL_ExposeEvent { + Uint8 type; /**< SDL_VIDEOEXPOSE */ +} SDL_ExposeEvent; + +/** The "quit requested" event */ +typedef struct SDL_QuitEvent { + Uint8 type; /**< SDL_QUIT */ +} SDL_QuitEvent; + +/** A user-defined event type */ +typedef struct SDL_UserEvent { + Uint8 type; /**< SDL_USEREVENT through SDL_NUMEVENTS-1 */ + int code; /**< User defined event code */ + void *data1; /**< User defined data pointer */ + void *data2; /**< User defined data pointer */ +} SDL_UserEvent; + +/** If you want to use this event, you should include SDL_syswm.h */ +struct SDL_SysWMmsg; +typedef struct SDL_SysWMmsg SDL_SysWMmsg; +typedef struct SDL_SysWMEvent { + Uint8 type; + SDL_SysWMmsg *msg; +} SDL_SysWMEvent; + +/** General event structure */ +typedef union SDL_Event { + Uint8 type; + SDL_ActiveEvent active; + SDL_KeyboardEvent key; + SDL_MouseMotionEvent motion; + SDL_MouseButtonEvent button; + SDL_JoyAxisEvent jaxis; + SDL_JoyBallEvent jball; + SDL_JoyHatEvent jhat; + SDL_JoyButtonEvent jbutton; + SDL_ResizeEvent resize; + SDL_ExposeEvent expose; + SDL_QuitEvent quit; + SDL_UserEvent user; + SDL_SysWMEvent syswm; +} SDL_Event; + + +/* Function prototypes */ + +/** Pumps the event loop, gathering events from the input devices. + * This function updates the event queue and internal input device state. + * This should only be run in the thread that sets the video mode. + */ +extern DECLSPEC void SDLCALL SDL_PumpEvents(void); + +typedef enum { + SDL_ADDEVENT, + SDL_PEEKEVENT, + SDL_GETEVENT +} SDL_eventaction; + +/** + * Checks the event queue for messages and optionally returns them. + * + * If 'action' is SDL_ADDEVENT, up to 'numevents' events will be added to + * the back of the event queue. + * If 'action' is SDL_PEEKEVENT, up to 'numevents' events at the front + * of the event queue, matching 'mask', will be returned and will not + * be removed from the queue. + * If 'action' is SDL_GETEVENT, up to 'numevents' events at the front + * of the event queue, matching 'mask', will be returned and will be + * removed from the queue. + * + * @return + * This function returns the number of events actually stored, or -1 + * if there was an error. + * + * This function is thread-safe. + */ +extern DECLSPEC int SDLCALL SDL_PeepEvents(SDL_Event *events, int numevents, + SDL_eventaction action, Uint32 mask); + +/** Polls for currently pending events, and returns 1 if there are any pending + * events, or 0 if there are none available. If 'event' is not NULL, the next + * event is removed from the queue and stored in that area. + */ +extern DECLSPEC int SDLCALL SDL_PollEvent(SDL_Event *event); + +/** Waits indefinitely for the next available event, returning 1, or 0 if there + * was an error while waiting for events. If 'event' is not NULL, the next + * event is removed from the queue and stored in that area. + */ +extern DECLSPEC int SDLCALL SDL_WaitEvent(SDL_Event *event); + +/** Add an event to the event queue. + * This function returns 0 on success, or -1 if the event queue was full + * or there was some other error. + */ +extern DECLSPEC int SDLCALL SDL_PushEvent(SDL_Event *event); + +/** @name Event Filtering */ +/*@{*/ +typedef int (SDLCALL *SDL_EventFilter)(const SDL_Event *event); +/** + * This function sets up a filter to process all events before they + * change internal state and are posted to the internal event queue. + * + * The filter is protypted as: + * @code typedef int (SDLCALL *SDL_EventFilter)(const SDL_Event *event); @endcode + * + * If the filter returns 1, then the event will be added to the internal queue. + * If it returns 0, then the event will be dropped from the queue, but the + * internal state will still be updated. This allows selective filtering of + * dynamically arriving events. + * + * @warning Be very careful of what you do in the event filter function, as + * it may run in a different thread! + * + * There is one caveat when dealing with the SDL_QUITEVENT event type. The + * event filter is only called when the window manager desires to close the + * application window. If the event filter returns 1, then the window will + * be closed, otherwise the window will remain open if possible. + * If the quit event is generated by an interrupt signal, it will bypass the + * internal queue and be delivered to the application at the next event poll. + */ +extern DECLSPEC void SDLCALL SDL_SetEventFilter(SDL_EventFilter filter); + +/** + * Return the current event filter - can be used to "chain" filters. + * If there is no event filter set, this function returns NULL. + */ +extern DECLSPEC SDL_EventFilter SDLCALL SDL_GetEventFilter(void); +/*@}*/ + +/** @name Event State */ +/*@{*/ +#define SDL_QUERY -1 +#define SDL_IGNORE 0 +#define SDL_DISABLE 0 +#define SDL_ENABLE 1 +/*@}*/ + +/** +* This function allows you to set the state of processing certain events. +* If 'state' is set to SDL_IGNORE, that event will be automatically dropped +* from the event queue and will not event be filtered. +* If 'state' is set to SDL_ENABLE, that event will be processed normally. +* If 'state' is set to SDL_QUERY, SDL_EventState() will return the +* current processing state of the specified event. +*/ +extern DECLSPEC Uint8 SDLCALL SDL_EventState(Uint8 type, int state); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_events_h */ diff --git a/Externals/SDL/include/SDL_getenv.h b/Externals/SDL/include/SDL_getenv.h new file mode 100644 index 0000000000..253ad88cc5 --- /dev/null +++ b/Externals/SDL/include/SDL_getenv.h @@ -0,0 +1,28 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_getenv.h + * @deprecated Use SDL_stdinc.h instead + */ + +/* DEPRECATED */ +#include "SDL_stdinc.h" diff --git a/Externals/SDL/include/SDL_joystick.h b/Externals/SDL/include/SDL_joystick.h new file mode 100644 index 0000000000..d5135c3d53 --- /dev/null +++ b/Externals/SDL/include/SDL_joystick.h @@ -0,0 +1,187 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_joystick.h + * Include file for SDL joystick event handling + */ + +#ifndef _SDL_joystick_h +#define _SDL_joystick_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** @file SDL_joystick.h + * @note In order to use these functions, SDL_Init() must have been called + * with the SDL_INIT_JOYSTICK flag. This causes SDL to scan the system + * for joysticks, and load appropriate drivers. + */ + +/** The joystick structure used to identify an SDL joystick */ +struct _SDL_Joystick; +typedef struct _SDL_Joystick SDL_Joystick; + +/* Function prototypes */ +/** + * Count the number of joysticks attached to the system + */ +extern DECLSPEC int SDLCALL SDL_NumJoysticks(void); + +/** + * Get the implementation dependent name of a joystick. + * + * This can be called before any joysticks are opened. + * If no name can be found, this function returns NULL. + */ +extern DECLSPEC const char * SDLCALL SDL_JoystickName(int device_index); + +/** + * Open a joystick for use. + * + * @param[in] device_index + * The index passed as an argument refers to + * the N'th joystick on the system. This index is the value which will + * identify this joystick in future joystick events. + * + * @return This function returns a joystick identifier, or NULL if an error occurred. + */ +extern DECLSPEC SDL_Joystick * SDLCALL SDL_JoystickOpen(int device_index); + +/** + * Returns 1 if the joystick has been opened, or 0 if it has not. + */ +extern DECLSPEC int SDLCALL SDL_JoystickOpened(int device_index); + +/** + * Get the device index of an opened joystick. + */ +extern DECLSPEC int SDLCALL SDL_JoystickIndex(SDL_Joystick *joystick); + +/** + * Get the number of general axis controls on a joystick + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumAxes(SDL_Joystick *joystick); + +/** + * Get the number of trackballs on a joystick + * + * Joystick trackballs have only relative motion events associated + * with them and their state cannot be polled. + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumBalls(SDL_Joystick *joystick); + +/** + * Get the number of POV hats on a joystick + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumHats(SDL_Joystick *joystick); + +/** + * Get the number of buttons on a joystick + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumButtons(SDL_Joystick *joystick); + +/** + * Update the current state of the open joysticks. + * + * This is called automatically by the event loop if any joystick + * events are enabled. + */ +extern DECLSPEC void SDLCALL SDL_JoystickUpdate(void); + +/** + * Enable/disable joystick event polling. + * + * If joystick events are disabled, you must call SDL_JoystickUpdate() + * yourself and check the state of the joystick when you want joystick + * information. + * + * @param[in] state The state can be one of SDL_QUERY, SDL_ENABLE or SDL_IGNORE. + */ +extern DECLSPEC int SDLCALL SDL_JoystickEventState(int state); + +/** + * Get the current state of an axis control on a joystick + * + * @param[in] axis The axis indices start at index 0. + * + * @return The state is a value ranging from -32768 to 32767. + */ +extern DECLSPEC Sint16 SDLCALL SDL_JoystickGetAxis(SDL_Joystick *joystick, int axis); + +/** + * @name Hat Positions + * The return value of SDL_JoystickGetHat() is one of the following positions: + */ +/*@{*/ +#define SDL_HAT_CENTERED 0x00 +#define SDL_HAT_UP 0x01 +#define SDL_HAT_RIGHT 0x02 +#define SDL_HAT_DOWN 0x04 +#define SDL_HAT_LEFT 0x08 +#define SDL_HAT_RIGHTUP (SDL_HAT_RIGHT|SDL_HAT_UP) +#define SDL_HAT_RIGHTDOWN (SDL_HAT_RIGHT|SDL_HAT_DOWN) +#define SDL_HAT_LEFTUP (SDL_HAT_LEFT|SDL_HAT_UP) +#define SDL_HAT_LEFTDOWN (SDL_HAT_LEFT|SDL_HAT_DOWN) +/*@}*/ + +/** + * Get the current state of a POV hat on a joystick + * + * @param[in] hat The hat indices start at index 0. + */ +extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetHat(SDL_Joystick *joystick, int hat); + +/** + * Get the ball axis change since the last poll + * + * @param[in] ball The ball indices start at index 0. + * + * @return This returns 0, or -1 if you passed it invalid parameters. + */ +extern DECLSPEC int SDLCALL SDL_JoystickGetBall(SDL_Joystick *joystick, int ball, int *dx, int *dy); + +/** + * Get the current state of a button on a joystick + * + * @param[in] button The button indices start at index 0. + */ +extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetButton(SDL_Joystick *joystick, int button); + +/** + * Close a joystick previously opened with SDL_JoystickOpen() + */ +extern DECLSPEC void SDLCALL SDL_JoystickClose(SDL_Joystick *joystick); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_joystick_h */ diff --git a/Externals/SDL/include/SDL_keyboard.h b/Externals/SDL/include/SDL_keyboard.h new file mode 100644 index 0000000000..7b59d24e55 --- /dev/null +++ b/Externals/SDL/include/SDL_keyboard.h @@ -0,0 +1,135 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_keyboard.h + * Include file for SDL keyboard event handling + */ + +#ifndef _SDL_keyboard_h +#define _SDL_keyboard_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_keysym.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** Keysym structure + * + * - The scancode is hardware dependent, and should not be used by general + * applications. If no hardware scancode is available, it will be 0. + * + * - The 'unicode' translated character is only available when character + * translation is enabled by the SDL_EnableUNICODE() API. If non-zero, + * this is a UNICODE character corresponding to the keypress. If the + * high 9 bits of the character are 0, then this maps to the equivalent + * ASCII character: + * @code + * char ch; + * if ( (keysym.unicode & 0xFF80) == 0 ) { + * ch = keysym.unicode & 0x7F; + * } else { + * An international character.. + * } + * @endcode + */ +typedef struct SDL_keysym { + Uint8 scancode; /**< hardware specific scancode */ + SDLKey sym; /**< SDL virtual keysym */ + SDLMod mod; /**< current key modifiers */ + Uint16 unicode; /**< translated character */ +} SDL_keysym; + +/** This is the mask which refers to all hotkey bindings */ +#define SDL_ALL_HOTKEYS 0xFFFFFFFF + +/* Function prototypes */ +/** + * Enable/Disable UNICODE translation of keyboard input. + * + * This translation has some overhead, so translation defaults off. + * + * @param[in] enable + * If 'enable' is 1, translation is enabled. + * If 'enable' is 0, translation is disabled. + * If 'enable' is -1, the translation state is not changed. + * + * @return It returns the previous state of keyboard translation. + */ +extern DECLSPEC int SDLCALL SDL_EnableUNICODE(int enable); + +#define SDL_DEFAULT_REPEAT_DELAY 500 +#define SDL_DEFAULT_REPEAT_INTERVAL 30 +/** + * Enable/Disable keyboard repeat. Keyboard repeat defaults to off. + * + * @param[in] delay + * 'delay' is the initial delay in ms between the time when a key is + * pressed, and keyboard repeat begins. + * + * @param[in] interval + * 'interval' is the time in ms between keyboard repeat events. + * + * If 'delay' is set to 0, keyboard repeat is disabled. + */ +extern DECLSPEC int SDLCALL SDL_EnableKeyRepeat(int delay, int interval); +extern DECLSPEC void SDLCALL SDL_GetKeyRepeat(int *delay, int *interval); + +/** + * Get a snapshot of the current state of the keyboard. + * Returns an array of keystates, indexed by the SDLK_* syms. + * Usage: + * @code + * Uint8 *keystate = SDL_GetKeyState(NULL); + * if ( keystate[SDLK_RETURN] ) //... \ is pressed. + * @endcode + */ +extern DECLSPEC Uint8 * SDLCALL SDL_GetKeyState(int *numkeys); + +/** + * Get the current key modifier state + */ +extern DECLSPEC SDLMod SDLCALL SDL_GetModState(void); + +/** + * Set the current key modifier state. + * This does not change the keyboard state, only the key modifier flags. + */ +extern DECLSPEC void SDLCALL SDL_SetModState(SDLMod modstate); + +/** + * Get the name of an SDL virtual keysym + */ +extern DECLSPEC char * SDLCALL SDL_GetKeyName(SDLKey key); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_keyboard_h */ diff --git a/Externals/SDL/include/SDL_keysym.h b/Externals/SDL/include/SDL_keysym.h new file mode 100644 index 0000000000..90101286e3 --- /dev/null +++ b/Externals/SDL/include/SDL_keysym.h @@ -0,0 +1,326 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_keysym_h +#define _SDL_keysym_h + +/** What we really want is a mapping of every raw key on the keyboard. + * To support international keyboards, we use the range 0xA1 - 0xFF + * as international virtual keycodes. We'll follow in the footsteps of X11... + * @brief The names of the keys + */ +typedef enum { + /** @name ASCII mapped keysyms + * The keyboard syms have been cleverly chosen to map to ASCII + */ + /*@{*/ + SDLK_UNKNOWN = 0, + SDLK_FIRST = 0, + SDLK_BACKSPACE = 8, + SDLK_TAB = 9, + SDLK_CLEAR = 12, + SDLK_RETURN = 13, + SDLK_PAUSE = 19, + SDLK_ESCAPE = 27, + SDLK_SPACE = 32, + SDLK_EXCLAIM = 33, + SDLK_QUOTEDBL = 34, + SDLK_HASH = 35, + SDLK_DOLLAR = 36, + SDLK_AMPERSAND = 38, + SDLK_QUOTE = 39, + SDLK_LEFTPAREN = 40, + SDLK_RIGHTPAREN = 41, + SDLK_ASTERISK = 42, + SDLK_PLUS = 43, + SDLK_COMMA = 44, + SDLK_MINUS = 45, + SDLK_PERIOD = 46, + SDLK_SLASH = 47, + SDLK_0 = 48, + SDLK_1 = 49, + SDLK_2 = 50, + SDLK_3 = 51, + SDLK_4 = 52, + SDLK_5 = 53, + SDLK_6 = 54, + SDLK_7 = 55, + SDLK_8 = 56, + SDLK_9 = 57, + SDLK_COLON = 58, + SDLK_SEMICOLON = 59, + SDLK_LESS = 60, + SDLK_EQUALS = 61, + SDLK_GREATER = 62, + SDLK_QUESTION = 63, + SDLK_AT = 64, + /* + Skip uppercase letters + */ + SDLK_LEFTBRACKET = 91, + SDLK_BACKSLASH = 92, + SDLK_RIGHTBRACKET = 93, + SDLK_CARET = 94, + SDLK_UNDERSCORE = 95, + SDLK_BACKQUOTE = 96, + SDLK_a = 97, + SDLK_b = 98, + SDLK_c = 99, + SDLK_d = 100, + SDLK_e = 101, + SDLK_f = 102, + SDLK_g = 103, + SDLK_h = 104, + SDLK_i = 105, + SDLK_j = 106, + SDLK_k = 107, + SDLK_l = 108, + SDLK_m = 109, + SDLK_n = 110, + SDLK_o = 111, + SDLK_p = 112, + SDLK_q = 113, + SDLK_r = 114, + SDLK_s = 115, + SDLK_t = 116, + SDLK_u = 117, + SDLK_v = 118, + SDLK_w = 119, + SDLK_x = 120, + SDLK_y = 121, + SDLK_z = 122, + SDLK_DELETE = 127, + /* End of ASCII mapped keysyms */ + /*@}*/ + + /** @name International keyboard syms */ + /*@{*/ + SDLK_WORLD_0 = 160, /* 0xA0 */ + SDLK_WORLD_1 = 161, + SDLK_WORLD_2 = 162, + SDLK_WORLD_3 = 163, + SDLK_WORLD_4 = 164, + SDLK_WORLD_5 = 165, + SDLK_WORLD_6 = 166, + SDLK_WORLD_7 = 167, + SDLK_WORLD_8 = 168, + SDLK_WORLD_9 = 169, + SDLK_WORLD_10 = 170, + SDLK_WORLD_11 = 171, + SDLK_WORLD_12 = 172, + SDLK_WORLD_13 = 173, + SDLK_WORLD_14 = 174, + SDLK_WORLD_15 = 175, + SDLK_WORLD_16 = 176, + SDLK_WORLD_17 = 177, + SDLK_WORLD_18 = 178, + SDLK_WORLD_19 = 179, + SDLK_WORLD_20 = 180, + SDLK_WORLD_21 = 181, + SDLK_WORLD_22 = 182, + SDLK_WORLD_23 = 183, + SDLK_WORLD_24 = 184, + SDLK_WORLD_25 = 185, + SDLK_WORLD_26 = 186, + SDLK_WORLD_27 = 187, + SDLK_WORLD_28 = 188, + SDLK_WORLD_29 = 189, + SDLK_WORLD_30 = 190, + SDLK_WORLD_31 = 191, + SDLK_WORLD_32 = 192, + SDLK_WORLD_33 = 193, + SDLK_WORLD_34 = 194, + SDLK_WORLD_35 = 195, + SDLK_WORLD_36 = 196, + SDLK_WORLD_37 = 197, + SDLK_WORLD_38 = 198, + SDLK_WORLD_39 = 199, + SDLK_WORLD_40 = 200, + SDLK_WORLD_41 = 201, + SDLK_WORLD_42 = 202, + SDLK_WORLD_43 = 203, + SDLK_WORLD_44 = 204, + SDLK_WORLD_45 = 205, + SDLK_WORLD_46 = 206, + SDLK_WORLD_47 = 207, + SDLK_WORLD_48 = 208, + SDLK_WORLD_49 = 209, + SDLK_WORLD_50 = 210, + SDLK_WORLD_51 = 211, + SDLK_WORLD_52 = 212, + SDLK_WORLD_53 = 213, + SDLK_WORLD_54 = 214, + SDLK_WORLD_55 = 215, + SDLK_WORLD_56 = 216, + SDLK_WORLD_57 = 217, + SDLK_WORLD_58 = 218, + SDLK_WORLD_59 = 219, + SDLK_WORLD_60 = 220, + SDLK_WORLD_61 = 221, + SDLK_WORLD_62 = 222, + SDLK_WORLD_63 = 223, + SDLK_WORLD_64 = 224, + SDLK_WORLD_65 = 225, + SDLK_WORLD_66 = 226, + SDLK_WORLD_67 = 227, + SDLK_WORLD_68 = 228, + SDLK_WORLD_69 = 229, + SDLK_WORLD_70 = 230, + SDLK_WORLD_71 = 231, + SDLK_WORLD_72 = 232, + SDLK_WORLD_73 = 233, + SDLK_WORLD_74 = 234, + SDLK_WORLD_75 = 235, + SDLK_WORLD_76 = 236, + SDLK_WORLD_77 = 237, + SDLK_WORLD_78 = 238, + SDLK_WORLD_79 = 239, + SDLK_WORLD_80 = 240, + SDLK_WORLD_81 = 241, + SDLK_WORLD_82 = 242, + SDLK_WORLD_83 = 243, + SDLK_WORLD_84 = 244, + SDLK_WORLD_85 = 245, + SDLK_WORLD_86 = 246, + SDLK_WORLD_87 = 247, + SDLK_WORLD_88 = 248, + SDLK_WORLD_89 = 249, + SDLK_WORLD_90 = 250, + SDLK_WORLD_91 = 251, + SDLK_WORLD_92 = 252, + SDLK_WORLD_93 = 253, + SDLK_WORLD_94 = 254, + SDLK_WORLD_95 = 255, /* 0xFF */ + /*@}*/ + + /** @name Numeric keypad */ + /*@{*/ + SDLK_KP0 = 256, + SDLK_KP1 = 257, + SDLK_KP2 = 258, + SDLK_KP3 = 259, + SDLK_KP4 = 260, + SDLK_KP5 = 261, + SDLK_KP6 = 262, + SDLK_KP7 = 263, + SDLK_KP8 = 264, + SDLK_KP9 = 265, + SDLK_KP_PERIOD = 266, + SDLK_KP_DIVIDE = 267, + SDLK_KP_MULTIPLY = 268, + SDLK_KP_MINUS = 269, + SDLK_KP_PLUS = 270, + SDLK_KP_ENTER = 271, + SDLK_KP_EQUALS = 272, + /*@}*/ + + /** @name Arrows + Home/End pad */ + /*@{*/ + SDLK_UP = 273, + SDLK_DOWN = 274, + SDLK_RIGHT = 275, + SDLK_LEFT = 276, + SDLK_INSERT = 277, + SDLK_HOME = 278, + SDLK_END = 279, + SDLK_PAGEUP = 280, + SDLK_PAGEDOWN = 281, + /*@}*/ + + /** @name Function keys */ + /*@{*/ + SDLK_F1 = 282, + SDLK_F2 = 283, + SDLK_F3 = 284, + SDLK_F4 = 285, + SDLK_F5 = 286, + SDLK_F6 = 287, + SDLK_F7 = 288, + SDLK_F8 = 289, + SDLK_F9 = 290, + SDLK_F10 = 291, + SDLK_F11 = 292, + SDLK_F12 = 293, + SDLK_F13 = 294, + SDLK_F14 = 295, + SDLK_F15 = 296, + /*@}*/ + + /** @name Key state modifier keys */ + /*@{*/ + SDLK_NUMLOCK = 300, + SDLK_CAPSLOCK = 301, + SDLK_SCROLLOCK = 302, + SDLK_RSHIFT = 303, + SDLK_LSHIFT = 304, + SDLK_RCTRL = 305, + SDLK_LCTRL = 306, + SDLK_RALT = 307, + SDLK_LALT = 308, + SDLK_RMETA = 309, + SDLK_LMETA = 310, + SDLK_LSUPER = 311, /**< Left "Windows" key */ + SDLK_RSUPER = 312, /**< Right "Windows" key */ + SDLK_MODE = 313, /**< "Alt Gr" key */ + SDLK_COMPOSE = 314, /**< Multi-key compose key */ + /*@}*/ + + /** @name Miscellaneous function keys */ + /*@{*/ + SDLK_HELP = 315, + SDLK_PRINT = 316, + SDLK_SYSREQ = 317, + SDLK_BREAK = 318, + SDLK_MENU = 319, + SDLK_POWER = 320, /**< Power Macintosh power key */ + SDLK_EURO = 321, /**< Some european keyboards */ + SDLK_UNDO = 322, /**< Atari keyboard has Undo */ + /*@}*/ + + /* Add any other keys here */ + + SDLK_LAST +} SDLKey; + +/** Enumeration of valid key mods (possibly OR'd together) */ +typedef enum { + KMOD_NONE = 0x0000, + KMOD_LSHIFT= 0x0001, + KMOD_RSHIFT= 0x0002, + KMOD_LCTRL = 0x0040, + KMOD_RCTRL = 0x0080, + KMOD_LALT = 0x0100, + KMOD_RALT = 0x0200, + KMOD_LMETA = 0x0400, + KMOD_RMETA = 0x0800, + KMOD_NUM = 0x1000, + KMOD_CAPS = 0x2000, + KMOD_MODE = 0x4000, + KMOD_RESERVED = 0x8000 +} SDLMod; + +#define KMOD_CTRL (KMOD_LCTRL|KMOD_RCTRL) +#define KMOD_SHIFT (KMOD_LSHIFT|KMOD_RSHIFT) +#define KMOD_ALT (KMOD_LALT|KMOD_RALT) +#define KMOD_META (KMOD_LMETA|KMOD_RMETA) + +#endif /* _SDL_keysym_h */ diff --git a/Externals/SDL/include/SDL_loadso.h b/Externals/SDL/include/SDL_loadso.h new file mode 100644 index 0000000000..45a17f9f41 --- /dev/null +++ b/Externals/SDL/include/SDL_loadso.h @@ -0,0 +1,78 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_loadso.h + * System dependent library loading routines + */ + +/** @file SDL_loadso.h + * Some things to keep in mind: + * - These functions only work on C function names. Other languages may + * have name mangling and intrinsic language support that varies from + * compiler to compiler. + * - Make sure you declare your function pointers with the same calling + * convention as the actual library function. Your code will crash + * mysteriously if you do not do this. + * - Avoid namespace collisions. If you load a symbol from the library, + * it is not defined whether or not it goes into the global symbol + * namespace for the application. If it does and it conflicts with + * symbols in your code or other shared libraries, you will not get + * the results you expect. :) + */ + + +#ifndef _SDL_loadso_h +#define _SDL_loadso_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * This function dynamically loads a shared object and returns a pointer + * to the object handle (or NULL if there was an error). + * The 'sofile' parameter is a system dependent name of the object file. + */ +extern DECLSPEC void * SDLCALL SDL_LoadObject(const char *sofile); + +/** + * Given an object handle, this function looks up the address of the + * named function in the shared object and returns it. This address + * is no longer valid after calling SDL_UnloadObject(). + */ +extern DECLSPEC void * SDLCALL SDL_LoadFunction(void *handle, const char *name); + +/** Unload a shared object from memory */ +extern DECLSPEC void SDLCALL SDL_UnloadObject(void *handle); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_loadso_h */ diff --git a/Externals/SDL/include/SDL_main.h b/Externals/SDL/include/SDL_main.h new file mode 100644 index 0000000000..b7f6b2c823 --- /dev/null +++ b/Externals/SDL/include/SDL_main.h @@ -0,0 +1,106 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_main_h +#define _SDL_main_h + +#include "SDL_stdinc.h" + +/** @file SDL_main.h + * Redefine main() on Win32 and MacOS so that it is called by winmain.c + */ + +#if defined(__WIN32__) || \ + (defined(__MWERKS__) && !defined(__BEOS__)) || \ + defined(__MACOS__) || defined(__MACOSX__) || \ + defined(__SYMBIAN32__) || defined(QWS) + +#ifdef __cplusplus +#define C_LINKAGE "C" +#else +#define C_LINKAGE +#endif /* __cplusplus */ + +/** The application's main() function must be called with C linkage, + * and should be declared like this: + * @code + * #ifdef __cplusplus + * extern "C" + * #endif + * int main(int argc, char *argv[]) + * { + * } + * @endcode + */ +#define main SDL_main + +/** The prototype for the application's main() function */ +extern C_LINKAGE int SDL_main(int argc, char *argv[]); + + +/** @name From the SDL library code -- needed for registering the app on Win32 */ +/*@{*/ +#ifdef __WIN32__ + +#include "begin_code.h" +#ifdef __cplusplus +extern "C" { +#endif + +/** This should be called from your WinMain() function, if any */ +extern DECLSPEC void SDLCALL SDL_SetModuleHandle(void *hInst); +/** This can also be called, but is no longer necessary */ +extern DECLSPEC int SDLCALL SDL_RegisterApp(char *name, Uint32 style, void *hInst); +/** This can also be called, but is no longer necessary (SDL_Quit calls it) */ +extern DECLSPEC void SDLCALL SDL_UnregisterApp(void); +#ifdef __cplusplus +} +#endif +#include "close_code.h" +#endif +/*@}*/ + +/** @name From the SDL library code -- needed for registering QuickDraw on MacOS */ +/*@{*/ +#if defined(__MACOS__) + +#include "begin_code.h" +#ifdef __cplusplus +extern "C" { +#endif + +/** Forward declaration so we don't need to include QuickDraw.h */ +struct QDGlobals; + +/** This should be called from your main() function, if any */ +extern DECLSPEC void SDLCALL SDL_InitQuickDraw(struct QDGlobals *the_qd); + +#ifdef __cplusplus +} +#endif +#include "close_code.h" +#endif +/*@}*/ + +#endif /* Need to redefine main()? */ + +#endif /* _SDL_main_h */ diff --git a/Externals/SDL/include/SDL_mouse.h b/Externals/SDL/include/SDL_mouse.h new file mode 100644 index 0000000000..a573f04ee0 --- /dev/null +++ b/Externals/SDL/include/SDL_mouse.h @@ -0,0 +1,143 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_mouse.h + * Include file for SDL mouse event handling + */ + +#ifndef _SDL_mouse_h +#define _SDL_mouse_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +typedef struct WMcursor WMcursor; /**< Implementation dependent */ +typedef struct SDL_Cursor { + SDL_Rect area; /**< The area of the mouse cursor */ + Sint16 hot_x, hot_y; /**< The "tip" of the cursor */ + Uint8 *data; /**< B/W cursor data */ + Uint8 *mask; /**< B/W cursor mask */ + Uint8 *save[2]; /**< Place to save cursor area */ + WMcursor *wm_cursor; /**< Window-manager cursor */ +} SDL_Cursor; + +/* Function prototypes */ +/** + * Retrieve the current state of the mouse. + * The current button state is returned as a button bitmask, which can + * be tested using the SDL_BUTTON(X) macros, and x and y are set to the + * current mouse cursor position. You can pass NULL for either x or y. + */ +extern DECLSPEC Uint8 SDLCALL SDL_GetMouseState(int *x, int *y); + +/** + * Retrieve the current state of the mouse. + * The current button state is returned as a button bitmask, which can + * be tested using the SDL_BUTTON(X) macros, and x and y are set to the + * mouse deltas since the last call to SDL_GetRelativeMouseState(). + */ +extern DECLSPEC Uint8 SDLCALL SDL_GetRelativeMouseState(int *x, int *y); + +/** + * Set the position of the mouse cursor (generates a mouse motion event) + */ +extern DECLSPEC void SDLCALL SDL_WarpMouse(Uint16 x, Uint16 y); + +/** + * Create a cursor using the specified data and mask (in MSB format). + * The cursor width must be a multiple of 8 bits. + * + * The cursor is created in black and white according to the following: + * data mask resulting pixel on screen + * 0 1 White + * 1 1 Black + * 0 0 Transparent + * 1 0 Inverted color if possible, black if not. + * + * Cursors created with this function must be freed with SDL_FreeCursor(). + */ +extern DECLSPEC SDL_Cursor * SDLCALL SDL_CreateCursor + (Uint8 *data, Uint8 *mask, int w, int h, int hot_x, int hot_y); + +/** + * Set the currently active cursor to the specified one. + * If the cursor is currently visible, the change will be immediately + * represented on the display. + */ +extern DECLSPEC void SDLCALL SDL_SetCursor(SDL_Cursor *cursor); + +/** + * Returns the currently active cursor. + */ +extern DECLSPEC SDL_Cursor * SDLCALL SDL_GetCursor(void); + +/** + * Deallocates a cursor created with SDL_CreateCursor(). + */ +extern DECLSPEC void SDLCALL SDL_FreeCursor(SDL_Cursor *cursor); + +/** + * Toggle whether or not the cursor is shown on the screen. + * The cursor start off displayed, but can be turned off. + * SDL_ShowCursor() returns 1 if the cursor was being displayed + * before the call, or 0 if it was not. You can query the current + * state by passing a 'toggle' value of -1. + */ +extern DECLSPEC int SDLCALL SDL_ShowCursor(int toggle); + +/*@{*/ +/** Used as a mask when testing buttons in buttonstate + * Button 1: Left mouse button + * Button 2: Middle mouse button + * Button 3: Right mouse button + * Button 4: Mouse wheel up (may also be a real button) + * Button 5: Mouse wheel down (may also be a real button) + */ +#define SDL_BUTTON(X) (1 << ((X)-1)) +#define SDL_BUTTON_LEFT 1 +#define SDL_BUTTON_MIDDLE 2 +#define SDL_BUTTON_RIGHT 3 +#define SDL_BUTTON_WHEELUP 4 +#define SDL_BUTTON_WHEELDOWN 5 +#define SDL_BUTTON_X1 6 +#define SDL_BUTTON_X2 7 +#define SDL_BUTTON_LMASK SDL_BUTTON(SDL_BUTTON_LEFT) +#define SDL_BUTTON_MMASK SDL_BUTTON(SDL_BUTTON_MIDDLE) +#define SDL_BUTTON_RMASK SDL_BUTTON(SDL_BUTTON_RIGHT) +#define SDL_BUTTON_X1MASK SDL_BUTTON(SDL_BUTTON_X1) +#define SDL_BUTTON_X2MASK SDL_BUTTON(SDL_BUTTON_X2) +/*@}*/ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_mouse_h */ diff --git a/Externals/SDL/include/SDL_mutex.h b/Externals/SDL/include/SDL_mutex.h new file mode 100644 index 0000000000..920971dfa7 --- /dev/null +++ b/Externals/SDL/include/SDL_mutex.h @@ -0,0 +1,177 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_mutex_h +#define _SDL_mutex_h + +/** @file SDL_mutex.h + * Functions to provide thread synchronization primitives + * + * @note These are independent of the other SDL routines. + */ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** Synchronization functions which can time out return this value + * if they time out. + */ +#define SDL_MUTEX_TIMEDOUT 1 + +/** This is the timeout value which corresponds to never time out */ +#define SDL_MUTEX_MAXWAIT (~(Uint32)0) + + +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ +/** @name Mutex functions */ /*@{*/ +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ + +/** The SDL mutex structure, defined in SDL_mutex.c */ +struct SDL_mutex; +typedef struct SDL_mutex SDL_mutex; + +/** Create a mutex, initialized unlocked */ +extern DECLSPEC SDL_mutex * SDLCALL SDL_CreateMutex(void); + +#define SDL_LockMutex(m) SDL_mutexP(m) +/** Lock the mutex + * @return 0, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_mutexP(SDL_mutex *mutex); + +#define SDL_UnlockMutex(m) SDL_mutexV(m) +/** Unlock the mutex + * @return 0, or -1 on error + * + * It is an error to unlock a mutex that has not been locked by + * the current thread, and doing so results in undefined behavior. + */ +extern DECLSPEC int SDLCALL SDL_mutexV(SDL_mutex *mutex); + +/** Destroy a mutex */ +extern DECLSPEC void SDLCALL SDL_DestroyMutex(SDL_mutex *mutex); + +/*@}*/ + +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ +/** @name Semaphore functions */ /*@{*/ +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ + +/** The SDL semaphore structure, defined in SDL_sem.c */ +struct SDL_semaphore; +typedef struct SDL_semaphore SDL_sem; + +/** Create a semaphore, initialized with value, returns NULL on failure. */ +extern DECLSPEC SDL_sem * SDLCALL SDL_CreateSemaphore(Uint32 initial_value); + +/** Destroy a semaphore */ +extern DECLSPEC void SDLCALL SDL_DestroySemaphore(SDL_sem *sem); + +/** + * This function suspends the calling thread until the semaphore pointed + * to by sem has a positive count. It then atomically decreases the semaphore + * count. + */ +extern DECLSPEC int SDLCALL SDL_SemWait(SDL_sem *sem); + +/** Non-blocking variant of SDL_SemWait(). + * @return 0 if the wait succeeds, + * SDL_MUTEX_TIMEDOUT if the wait would block, and -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_SemTryWait(SDL_sem *sem); + +/** Variant of SDL_SemWait() with a timeout in milliseconds, returns 0 if + * the wait succeeds, SDL_MUTEX_TIMEDOUT if the wait does not succeed in + * the allotted time, and -1 on error. + * + * On some platforms this function is implemented by looping with a delay + * of 1 ms, and so should be avoided if possible. + */ +extern DECLSPEC int SDLCALL SDL_SemWaitTimeout(SDL_sem *sem, Uint32 ms); + +/** Atomically increases the semaphore's count (not blocking). + * @return 0, or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_SemPost(SDL_sem *sem); + +/** Returns the current count of the semaphore */ +extern DECLSPEC Uint32 SDLCALL SDL_SemValue(SDL_sem *sem); + +/*@}*/ + +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ +/** @name Condition_variable_functions */ /*@{*/ +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ + +/*@{*/ +/** The SDL condition variable structure, defined in SDL_cond.c */ +struct SDL_cond; +typedef struct SDL_cond SDL_cond; +/*@}*/ + +/** Create a condition variable */ +extern DECLSPEC SDL_cond * SDLCALL SDL_CreateCond(void); + +/** Destroy a condition variable */ +extern DECLSPEC void SDLCALL SDL_DestroyCond(SDL_cond *cond); + +/** Restart one of the threads that are waiting on the condition variable, + * @return 0 or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_CondSignal(SDL_cond *cond); + +/** Restart all threads that are waiting on the condition variable, + * @return 0 or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_CondBroadcast(SDL_cond *cond); + +/** Wait on the condition variable, unlocking the provided mutex. + * The mutex must be locked before entering this function! + * The mutex is re-locked once the condition variable is signaled. + * @return 0 when it is signaled, or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_CondWait(SDL_cond *cond, SDL_mutex *mut); + +/** Waits for at most 'ms' milliseconds, and returns 0 if the condition + * variable is signaled, SDL_MUTEX_TIMEDOUT if the condition is not + * signaled in the allotted time, and -1 on error. + * On some platforms this function is implemented by looping with a delay + * of 1 ms, and so should be avoided if possible. + */ +extern DECLSPEC int SDLCALL SDL_CondWaitTimeout(SDL_cond *cond, SDL_mutex *mutex, Uint32 ms); + +/*@}*/ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_mutex_h */ + diff --git a/Externals/SDL/include/SDL_name.h b/Externals/SDL/include/SDL_name.h new file mode 100644 index 0000000000..511619af56 --- /dev/null +++ b/Externals/SDL/include/SDL_name.h @@ -0,0 +1,11 @@ + +#ifndef _SDLname_h_ +#define _SDLname_h_ + +#if defined(__STDC__) || defined(__cplusplus) +#define NeedFunctionPrototypes 1 +#endif + +#define SDL_NAME(X) SDL_##X + +#endif /* _SDLname_h_ */ diff --git a/Externals/SDL/include/SDL_opengl.h b/Externals/SDL/include/SDL_opengl.h new file mode 100644 index 0000000000..c479a3a4e4 --- /dev/null +++ b/Externals/SDL/include/SDL_opengl.h @@ -0,0 +1,6556 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_opengl.h + * This is a simple file to encapsulate the OpenGL API headers + */ + +#include "SDL_config.h" + +#ifdef __WIN32__ +#define WIN32_LEAN_AND_MEAN +#ifndef NOMINMAX +#define NOMINMAX /* Don't defined min() and max() */ +#endif +#include +#endif +#ifndef NO_SDL_GLEXT +#define __glext_h_ /* Don't let gl.h include glext.h */ +#endif +#if defined(__MACOSX__) +#include /* Header File For The OpenGL Library */ +#include /* Header File For The GLU Library */ +#elif defined(__MACOS__) +#include /* Header File For The OpenGL Library */ +#include /* Header File For The GLU Library */ +#else +#include /* Header File For The OpenGL Library */ +#include /* Header File For The GLU Library */ +#endif +#ifndef NO_SDL_GLEXT +#undef __glext_h_ +#endif + +/** @name GLext.h + * This file taken from "GLext.h" from the Jeff Molofee OpenGL tutorials. + * It is included here because glext.h is not available on some systems. + * If you don't want this version included, simply define "NO_SDL_GLEXT" + */ +/*@{*/ +#ifndef NO_SDL_GLEXT +#if !defined(__glext_h_) && !defined(GL_GLEXT_LEGACY) +#define __glext_h_ + +#ifdef __cplusplus +extern "C" { +#endif + +/* +** License Applicability. Except to the extent portions of this file are +** made subject to an alternative license as permitted in the SGI Free +** Software License B, Version 1.1 (the "License"), the contents of this +** file are subject only to the provisions of the License. You may not use +** this file except in compliance with the License. You may obtain a copy +** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600 +** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at: +** +** http://oss.sgi.com/projects/FreeB +** +** Note that, as provided in the License, the Software is distributed on an +** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS +** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND +** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A +** PARTICULAR PURPOSE, AND NON-INFRINGEMENT. +** +** Original Code. The Original Code is: OpenGL Sample Implementation, +** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics, +** Inc. The Original Code is Copyright (c) 1991-2004 Silicon Graphics, Inc. +** Copyright in any portions created by third parties is as indicated +** elsewhere herein. All Rights Reserved. +** +** Additional Notice Provisions: This software was created using the +** OpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has +** not been independently verified as being compliant with the OpenGL(R) +** version 1.2.1 Specification. +*/ + +#if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) && !defined(__SCITECH_SNAP__) +#define WIN32_LEAN_AND_MEAN 1 +#include +#endif + +#ifndef APIENTRY +#define APIENTRY +#endif +#ifndef APIENTRYP +#define APIENTRYP APIENTRY * +#endif +#ifndef GLAPI +#define GLAPI extern +#endif + +/*************************************************************/ + +/* Header file version number, required by OpenGL ABI for Linux */ +/* glext.h last updated 2005/06/20 */ +/* Current version at http://oss.sgi.com/projects/ogl-sample/registry/ */ +#define GL_GLEXT_VERSION 29 + +#ifndef GL_VERSION_1_2 +#define GL_UNSIGNED_BYTE_3_3_2 0x8032 +#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033 +#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 +#define GL_UNSIGNED_INT_8_8_8_8 0x8035 +#define GL_UNSIGNED_INT_10_10_10_2 0x8036 +#define GL_RESCALE_NORMAL 0x803A +#define GL_TEXTURE_BINDING_3D 0x806A +#define GL_PACK_SKIP_IMAGES 0x806B +#define GL_PACK_IMAGE_HEIGHT 0x806C +#define GL_UNPACK_SKIP_IMAGES 0x806D +#define GL_UNPACK_IMAGE_HEIGHT 0x806E +#define GL_TEXTURE_3D 0x806F +#define GL_PROXY_TEXTURE_3D 0x8070 +#define GL_TEXTURE_DEPTH 0x8071 +#define GL_TEXTURE_WRAP_R 0x8072 +#define GL_MAX_3D_TEXTURE_SIZE 0x8073 +#define GL_UNSIGNED_BYTE_2_3_3_REV 0x8362 +#define GL_UNSIGNED_SHORT_5_6_5 0x8363 +#define GL_UNSIGNED_SHORT_5_6_5_REV 0x8364 +#define GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 +#define GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 +#define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 +#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 +#define GL_BGR 0x80E0 +#define GL_BGRA 0x80E1 +#define GL_MAX_ELEMENTS_VERTICES 0x80E8 +#define GL_MAX_ELEMENTS_INDICES 0x80E9 +#define GL_CLAMP_TO_EDGE 0x812F +#define GL_TEXTURE_MIN_LOD 0x813A +#define GL_TEXTURE_MAX_LOD 0x813B +#define GL_TEXTURE_BASE_LEVEL 0x813C +#define GL_TEXTURE_MAX_LEVEL 0x813D +#define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 +#define GL_SINGLE_COLOR 0x81F9 +#define GL_SEPARATE_SPECULAR_COLOR 0x81FA +#define GL_SMOOTH_POINT_SIZE_RANGE 0x0B12 +#define GL_SMOOTH_POINT_SIZE_GRANULARITY 0x0B13 +#define GL_SMOOTH_LINE_WIDTH_RANGE 0x0B22 +#define GL_SMOOTH_LINE_WIDTH_GRANULARITY 0x0B23 +#define GL_ALIASED_POINT_SIZE_RANGE 0x846D +#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E +#endif + +#ifndef GL_ARB_imaging +#define GL_CONSTANT_COLOR 0x8001 +#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002 +#define GL_CONSTANT_ALPHA 0x8003 +#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 +#define GL_BLEND_COLOR 0x8005 +#define GL_FUNC_ADD 0x8006 +#define GL_MIN 0x8007 +#define GL_MAX 0x8008 +#define GL_BLEND_EQUATION 0x8009 +#define GL_FUNC_SUBTRACT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT 0x800B +#define GL_CONVOLUTION_1D 0x8010 +#define GL_CONVOLUTION_2D 0x8011 +#define GL_SEPARABLE_2D 0x8012 +#define GL_CONVOLUTION_BORDER_MODE 0x8013 +#define GL_CONVOLUTION_FILTER_SCALE 0x8014 +#define GL_CONVOLUTION_FILTER_BIAS 0x8015 +#define GL_REDUCE 0x8016 +#define GL_CONVOLUTION_FORMAT 0x8017 +#define GL_CONVOLUTION_WIDTH 0x8018 +#define GL_CONVOLUTION_HEIGHT 0x8019 +#define GL_MAX_CONVOLUTION_WIDTH 0x801A +#define GL_MAX_CONVOLUTION_HEIGHT 0x801B +#define GL_POST_CONVOLUTION_RED_SCALE 0x801C +#define GL_POST_CONVOLUTION_GREEN_SCALE 0x801D +#define GL_POST_CONVOLUTION_BLUE_SCALE 0x801E +#define GL_POST_CONVOLUTION_ALPHA_SCALE 0x801F +#define GL_POST_CONVOLUTION_RED_BIAS 0x8020 +#define GL_POST_CONVOLUTION_GREEN_BIAS 0x8021 +#define GL_POST_CONVOLUTION_BLUE_BIAS 0x8022 +#define GL_POST_CONVOLUTION_ALPHA_BIAS 0x8023 +#define GL_HISTOGRAM 0x8024 +#define GL_PROXY_HISTOGRAM 0x8025 +#define GL_HISTOGRAM_WIDTH 0x8026 +#define GL_HISTOGRAM_FORMAT 0x8027 +#define GL_HISTOGRAM_RED_SIZE 0x8028 +#define GL_HISTOGRAM_GREEN_SIZE 0x8029 +#define GL_HISTOGRAM_BLUE_SIZE 0x802A +#define GL_HISTOGRAM_ALPHA_SIZE 0x802B +#define GL_HISTOGRAM_LUMINANCE_SIZE 0x802C +#define GL_HISTOGRAM_SINK 0x802D +#define GL_MINMAX 0x802E +#define GL_MINMAX_FORMAT 0x802F +#define GL_MINMAX_SINK 0x8030 +#define GL_TABLE_TOO_LARGE 0x8031 +#define GL_COLOR_MATRIX 0x80B1 +#define GL_COLOR_MATRIX_STACK_DEPTH 0x80B2 +#define GL_MAX_COLOR_MATRIX_STACK_DEPTH 0x80B3 +#define GL_POST_COLOR_MATRIX_RED_SCALE 0x80B4 +#define GL_POST_COLOR_MATRIX_GREEN_SCALE 0x80B5 +#define GL_POST_COLOR_MATRIX_BLUE_SCALE 0x80B6 +#define GL_POST_COLOR_MATRIX_ALPHA_SCALE 0x80B7 +#define GL_POST_COLOR_MATRIX_RED_BIAS 0x80B8 +#define GL_POST_COLOR_MATRIX_GREEN_BIAS 0x80B9 +#define GL_POST_COLOR_MATRIX_BLUE_BIAS 0x80BA +#define GL_POST_COLOR_MATRIX_ALPHA_BIAS 0x80BB +#define GL_COLOR_TABLE 0x80D0 +#define GL_POST_CONVOLUTION_COLOR_TABLE 0x80D1 +#define GL_POST_COLOR_MATRIX_COLOR_TABLE 0x80D2 +#define GL_PROXY_COLOR_TABLE 0x80D3 +#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE 0x80D4 +#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE 0x80D5 +#define GL_COLOR_TABLE_SCALE 0x80D6 +#define GL_COLOR_TABLE_BIAS 0x80D7 +#define GL_COLOR_TABLE_FORMAT 0x80D8 +#define GL_COLOR_TABLE_WIDTH 0x80D9 +#define GL_COLOR_TABLE_RED_SIZE 0x80DA +#define GL_COLOR_TABLE_GREEN_SIZE 0x80DB +#define GL_COLOR_TABLE_BLUE_SIZE 0x80DC +#define GL_COLOR_TABLE_ALPHA_SIZE 0x80DD +#define GL_COLOR_TABLE_LUMINANCE_SIZE 0x80DE +#define GL_COLOR_TABLE_INTENSITY_SIZE 0x80DF +#define GL_CONSTANT_BORDER 0x8151 +#define GL_REPLICATE_BORDER 0x8153 +#define GL_CONVOLUTION_BORDER_COLOR 0x8154 +#endif + +#ifndef GL_VERSION_1_3 +#define GL_TEXTURE0 0x84C0 +#define GL_TEXTURE1 0x84C1 +#define GL_TEXTURE2 0x84C2 +#define GL_TEXTURE3 0x84C3 +#define GL_TEXTURE4 0x84C4 +#define GL_TEXTURE5 0x84C5 +#define GL_TEXTURE6 0x84C6 +#define GL_TEXTURE7 0x84C7 +#define GL_TEXTURE8 0x84C8 +#define GL_TEXTURE9 0x84C9 +#define GL_TEXTURE10 0x84CA +#define GL_TEXTURE11 0x84CB +#define GL_TEXTURE12 0x84CC +#define GL_TEXTURE13 0x84CD +#define GL_TEXTURE14 0x84CE +#define GL_TEXTURE15 0x84CF +#define GL_TEXTURE16 0x84D0 +#define GL_TEXTURE17 0x84D1 +#define GL_TEXTURE18 0x84D2 +#define GL_TEXTURE19 0x84D3 +#define GL_TEXTURE20 0x84D4 +#define GL_TEXTURE21 0x84D5 +#define GL_TEXTURE22 0x84D6 +#define GL_TEXTURE23 0x84D7 +#define GL_TEXTURE24 0x84D8 +#define GL_TEXTURE25 0x84D9 +#define GL_TEXTURE26 0x84DA +#define GL_TEXTURE27 0x84DB +#define GL_TEXTURE28 0x84DC +#define GL_TEXTURE29 0x84DD +#define GL_TEXTURE30 0x84DE +#define GL_TEXTURE31 0x84DF +#define GL_ACTIVE_TEXTURE 0x84E0 +#define GL_CLIENT_ACTIVE_TEXTURE 0x84E1 +#define GL_MAX_TEXTURE_UNITS 0x84E2 +#define GL_TRANSPOSE_MODELVIEW_MATRIX 0x84E3 +#define GL_TRANSPOSE_PROJECTION_MATRIX 0x84E4 +#define GL_TRANSPOSE_TEXTURE_MATRIX 0x84E5 +#define GL_TRANSPOSE_COLOR_MATRIX 0x84E6 +#define GL_MULTISAMPLE 0x809D +#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE 0x809F +#define GL_SAMPLE_COVERAGE 0x80A0 +#define GL_SAMPLE_BUFFERS 0x80A8 +#define GL_SAMPLES 0x80A9 +#define GL_SAMPLE_COVERAGE_VALUE 0x80AA +#define GL_SAMPLE_COVERAGE_INVERT 0x80AB +#define GL_MULTISAMPLE_BIT 0x20000000 +#define GL_NORMAL_MAP 0x8511 +#define GL_REFLECTION_MAP 0x8512 +#define GL_TEXTURE_CUBE_MAP 0x8513 +#define GL_TEXTURE_BINDING_CUBE_MAP 0x8514 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x8515 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x8516 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x8517 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x8518 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x8519 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x851A +#define GL_PROXY_TEXTURE_CUBE_MAP 0x851B +#define GL_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C +#define GL_COMPRESSED_ALPHA 0x84E9 +#define GL_COMPRESSED_LUMINANCE 0x84EA +#define GL_COMPRESSED_LUMINANCE_ALPHA 0x84EB +#define GL_COMPRESSED_INTENSITY 0x84EC +#define GL_COMPRESSED_RGB 0x84ED +#define GL_COMPRESSED_RGBA 0x84EE +#define GL_TEXTURE_COMPRESSION_HINT 0x84EF +#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE 0x86A0 +#define GL_TEXTURE_COMPRESSED 0x86A1 +#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 +#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 +#define GL_CLAMP_TO_BORDER 0x812D +#define GL_COMBINE 0x8570 +#define GL_COMBINE_RGB 0x8571 +#define GL_COMBINE_ALPHA 0x8572 +#define GL_SOURCE0_RGB 0x8580 +#define GL_SOURCE1_RGB 0x8581 +#define GL_SOURCE2_RGB 0x8582 +#define GL_SOURCE0_ALPHA 0x8588 +#define GL_SOURCE1_ALPHA 0x8589 +#define GL_SOURCE2_ALPHA 0x858A +#define GL_OPERAND0_RGB 0x8590 +#define GL_OPERAND1_RGB 0x8591 +#define GL_OPERAND2_RGB 0x8592 +#define GL_OPERAND0_ALPHA 0x8598 +#define GL_OPERAND1_ALPHA 0x8599 +#define GL_OPERAND2_ALPHA 0x859A +#define GL_RGB_SCALE 0x8573 +#define GL_ADD_SIGNED 0x8574 +#define GL_INTERPOLATE 0x8575 +#define GL_SUBTRACT 0x84E7 +#define GL_CONSTANT 0x8576 +#define GL_PRIMARY_COLOR 0x8577 +#define GL_PREVIOUS 0x8578 +#define GL_DOT3_RGB 0x86AE +#define GL_DOT3_RGBA 0x86AF +#endif + +#ifndef GL_VERSION_1_4 +#define GL_BLEND_DST_RGB 0x80C8 +#define GL_BLEND_SRC_RGB 0x80C9 +#define GL_BLEND_DST_ALPHA 0x80CA +#define GL_BLEND_SRC_ALPHA 0x80CB +#define GL_POINT_SIZE_MIN 0x8126 +#define GL_POINT_SIZE_MAX 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE 0x8128 +#define GL_POINT_DISTANCE_ATTENUATION 0x8129 +#define GL_GENERATE_MIPMAP 0x8191 +#define GL_GENERATE_MIPMAP_HINT 0x8192 +#define GL_DEPTH_COMPONENT16 0x81A5 +#define GL_DEPTH_COMPONENT24 0x81A6 +#define GL_DEPTH_COMPONENT32 0x81A7 +#define GL_MIRRORED_REPEAT 0x8370 +#define GL_FOG_COORDINATE_SOURCE 0x8450 +#define GL_FOG_COORDINATE 0x8451 +#define GL_FRAGMENT_DEPTH 0x8452 +#define GL_CURRENT_FOG_COORDINATE 0x8453 +#define GL_FOG_COORDINATE_ARRAY_TYPE 0x8454 +#define GL_FOG_COORDINATE_ARRAY_STRIDE 0x8455 +#define GL_FOG_COORDINATE_ARRAY_POINTER 0x8456 +#define GL_FOG_COORDINATE_ARRAY 0x8457 +#define GL_COLOR_SUM 0x8458 +#define GL_CURRENT_SECONDARY_COLOR 0x8459 +#define GL_SECONDARY_COLOR_ARRAY_SIZE 0x845A +#define GL_SECONDARY_COLOR_ARRAY_TYPE 0x845B +#define GL_SECONDARY_COLOR_ARRAY_STRIDE 0x845C +#define GL_SECONDARY_COLOR_ARRAY_POINTER 0x845D +#define GL_SECONDARY_COLOR_ARRAY 0x845E +#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD +#define GL_TEXTURE_FILTER_CONTROL 0x8500 +#define GL_TEXTURE_LOD_BIAS 0x8501 +#define GL_INCR_WRAP 0x8507 +#define GL_DECR_WRAP 0x8508 +#define GL_TEXTURE_DEPTH_SIZE 0x884A +#define GL_DEPTH_TEXTURE_MODE 0x884B +#define GL_TEXTURE_COMPARE_MODE 0x884C +#define GL_TEXTURE_COMPARE_FUNC 0x884D +#define GL_COMPARE_R_TO_TEXTURE 0x884E +#endif + +#ifndef GL_VERSION_1_5 +#define GL_BUFFER_SIZE 0x8764 +#define GL_BUFFER_USAGE 0x8765 +#define GL_QUERY_COUNTER_BITS 0x8864 +#define GL_CURRENT_QUERY 0x8865 +#define GL_QUERY_RESULT 0x8866 +#define GL_QUERY_RESULT_AVAILABLE 0x8867 +#define GL_ARRAY_BUFFER 0x8892 +#define GL_ELEMENT_ARRAY_BUFFER 0x8893 +#define GL_ARRAY_BUFFER_BINDING 0x8894 +#define GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895 +#define GL_VERTEX_ARRAY_BUFFER_BINDING 0x8896 +#define GL_NORMAL_ARRAY_BUFFER_BINDING 0x8897 +#define GL_COLOR_ARRAY_BUFFER_BINDING 0x8898 +#define GL_INDEX_ARRAY_BUFFER_BINDING 0x8899 +#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING 0x889A +#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING 0x889B +#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING 0x889C +#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING 0x889D +#define GL_WEIGHT_ARRAY_BUFFER_BINDING 0x889E +#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F +#define GL_READ_ONLY 0x88B8 +#define GL_WRITE_ONLY 0x88B9 +#define GL_READ_WRITE 0x88BA +#define GL_BUFFER_ACCESS 0x88BB +#define GL_BUFFER_MAPPED 0x88BC +#define GL_BUFFER_MAP_POINTER 0x88BD +#define GL_STREAM_DRAW 0x88E0 +#define GL_STREAM_READ 0x88E1 +#define GL_STREAM_COPY 0x88E2 +#define GL_STATIC_DRAW 0x88E4 +#define GL_STATIC_READ 0x88E5 +#define GL_STATIC_COPY 0x88E6 +#define GL_DYNAMIC_DRAW 0x88E8 +#define GL_DYNAMIC_READ 0x88E9 +#define GL_DYNAMIC_COPY 0x88EA +#define GL_SAMPLES_PASSED 0x8914 +#define GL_FOG_COORD_SRC GL_FOG_COORDINATE_SOURCE +#define GL_FOG_COORD GL_FOG_COORDINATE +#define GL_CURRENT_FOG_COORD GL_CURRENT_FOG_COORDINATE +#define GL_FOG_COORD_ARRAY_TYPE GL_FOG_COORDINATE_ARRAY_TYPE +#define GL_FOG_COORD_ARRAY_STRIDE GL_FOG_COORDINATE_ARRAY_STRIDE +#define GL_FOG_COORD_ARRAY_POINTER GL_FOG_COORDINATE_ARRAY_POINTER +#define GL_FOG_COORD_ARRAY GL_FOG_COORDINATE_ARRAY +#define GL_FOG_COORD_ARRAY_BUFFER_BINDING GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING +#define GL_SRC0_RGB GL_SOURCE0_RGB +#define GL_SRC1_RGB GL_SOURCE1_RGB +#define GL_SRC2_RGB GL_SOURCE2_RGB +#define GL_SRC0_ALPHA GL_SOURCE0_ALPHA +#define GL_SRC1_ALPHA GL_SOURCE1_ALPHA +#define GL_SRC2_ALPHA GL_SOURCE2_ALPHA +#endif + +#ifndef GL_VERSION_2_0 +#define GL_BLEND_EQUATION_RGB GL_BLEND_EQUATION +#define GL_VERTEX_ATTRIB_ARRAY_ENABLED 0x8622 +#define GL_VERTEX_ATTRIB_ARRAY_SIZE 0x8623 +#define GL_VERTEX_ATTRIB_ARRAY_STRIDE 0x8624 +#define GL_VERTEX_ATTRIB_ARRAY_TYPE 0x8625 +#define GL_CURRENT_VERTEX_ATTRIB 0x8626 +#define GL_VERTEX_PROGRAM_POINT_SIZE 0x8642 +#define GL_VERTEX_PROGRAM_TWO_SIDE 0x8643 +#define GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645 +#define GL_STENCIL_BACK_FUNC 0x8800 +#define GL_STENCIL_BACK_FAIL 0x8801 +#define GL_STENCIL_BACK_PASS_DEPTH_FAIL 0x8802 +#define GL_STENCIL_BACK_PASS_DEPTH_PASS 0x8803 +#define GL_MAX_DRAW_BUFFERS 0x8824 +#define GL_DRAW_BUFFER0 0x8825 +#define GL_DRAW_BUFFER1 0x8826 +#define GL_DRAW_BUFFER2 0x8827 +#define GL_DRAW_BUFFER3 0x8828 +#define GL_DRAW_BUFFER4 0x8829 +#define GL_DRAW_BUFFER5 0x882A +#define GL_DRAW_BUFFER6 0x882B +#define GL_DRAW_BUFFER7 0x882C +#define GL_DRAW_BUFFER8 0x882D +#define GL_DRAW_BUFFER9 0x882E +#define GL_DRAW_BUFFER10 0x882F +#define GL_DRAW_BUFFER11 0x8830 +#define GL_DRAW_BUFFER12 0x8831 +#define GL_DRAW_BUFFER13 0x8832 +#define GL_DRAW_BUFFER14 0x8833 +#define GL_DRAW_BUFFER15 0x8834 +#define GL_BLEND_EQUATION_ALPHA 0x883D +#define GL_POINT_SPRITE 0x8861 +#define GL_COORD_REPLACE 0x8862 +#define GL_MAX_VERTEX_ATTRIBS 0x8869 +#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A +#define GL_MAX_TEXTURE_COORDS 0x8871 +#define GL_MAX_TEXTURE_IMAGE_UNITS 0x8872 +#define GL_FRAGMENT_SHADER 0x8B30 +#define GL_VERTEX_SHADER 0x8B31 +#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49 +#define GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A +#define GL_MAX_VARYING_FLOATS 0x8B4B +#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C +#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D +#define GL_SHADER_TYPE 0x8B4F +#define GL_FLOAT_VEC2 0x8B50 +#define GL_FLOAT_VEC3 0x8B51 +#define GL_FLOAT_VEC4 0x8B52 +#define GL_INT_VEC2 0x8B53 +#define GL_INT_VEC3 0x8B54 +#define GL_INT_VEC4 0x8B55 +#define GL_BOOL 0x8B56 +#define GL_BOOL_VEC2 0x8B57 +#define GL_BOOL_VEC3 0x8B58 +#define GL_BOOL_VEC4 0x8B59 +#define GL_FLOAT_MAT2 0x8B5A +#define GL_FLOAT_MAT3 0x8B5B +#define GL_FLOAT_MAT4 0x8B5C +#define GL_SAMPLER_1D 0x8B5D +#define GL_SAMPLER_2D 0x8B5E +#define GL_SAMPLER_3D 0x8B5F +#define GL_SAMPLER_CUBE 0x8B60 +#define GL_SAMPLER_1D_SHADOW 0x8B61 +#define GL_SAMPLER_2D_SHADOW 0x8B62 +#define GL_DELETE_STATUS 0x8B80 +#define GL_COMPILE_STATUS 0x8B81 +#define GL_LINK_STATUS 0x8B82 +#define GL_VALIDATE_STATUS 0x8B83 +#define GL_INFO_LOG_LENGTH 0x8B84 +#define GL_ATTACHED_SHADERS 0x8B85 +#define GL_ACTIVE_UNIFORMS 0x8B86 +#define GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87 +#define GL_SHADER_SOURCE_LENGTH 0x8B88 +#define GL_ACTIVE_ATTRIBUTES 0x8B89 +#define GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A +#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B +#define GL_SHADING_LANGUAGE_VERSION 0x8B8C +#define GL_CURRENT_PROGRAM 0x8B8D +#define GL_POINT_SPRITE_COORD_ORIGIN 0x8CA0 +#define GL_LOWER_LEFT 0x8CA1 +#define GL_UPPER_LEFT 0x8CA2 +#define GL_STENCIL_BACK_REF 0x8CA3 +#define GL_STENCIL_BACK_VALUE_MASK 0x8CA4 +#define GL_STENCIL_BACK_WRITEMASK 0x8CA5 +#endif + +#ifndef GL_ARB_multitexture +#define GL_TEXTURE0_ARB 0x84C0 +#define GL_TEXTURE1_ARB 0x84C1 +#define GL_TEXTURE2_ARB 0x84C2 +#define GL_TEXTURE3_ARB 0x84C3 +#define GL_TEXTURE4_ARB 0x84C4 +#define GL_TEXTURE5_ARB 0x84C5 +#define GL_TEXTURE6_ARB 0x84C6 +#define GL_TEXTURE7_ARB 0x84C7 +#define GL_TEXTURE8_ARB 0x84C8 +#define GL_TEXTURE9_ARB 0x84C9 +#define GL_TEXTURE10_ARB 0x84CA +#define GL_TEXTURE11_ARB 0x84CB +#define GL_TEXTURE12_ARB 0x84CC +#define GL_TEXTURE13_ARB 0x84CD +#define GL_TEXTURE14_ARB 0x84CE +#define GL_TEXTURE15_ARB 0x84CF +#define GL_TEXTURE16_ARB 0x84D0 +#define GL_TEXTURE17_ARB 0x84D1 +#define GL_TEXTURE18_ARB 0x84D2 +#define GL_TEXTURE19_ARB 0x84D3 +#define GL_TEXTURE20_ARB 0x84D4 +#define GL_TEXTURE21_ARB 0x84D5 +#define GL_TEXTURE22_ARB 0x84D6 +#define GL_TEXTURE23_ARB 0x84D7 +#define GL_TEXTURE24_ARB 0x84D8 +#define GL_TEXTURE25_ARB 0x84D9 +#define GL_TEXTURE26_ARB 0x84DA +#define GL_TEXTURE27_ARB 0x84DB +#define GL_TEXTURE28_ARB 0x84DC +#define GL_TEXTURE29_ARB 0x84DD +#define GL_TEXTURE30_ARB 0x84DE +#define GL_TEXTURE31_ARB 0x84DF +#define GL_ACTIVE_TEXTURE_ARB 0x84E0 +#define GL_CLIENT_ACTIVE_TEXTURE_ARB 0x84E1 +#define GL_MAX_TEXTURE_UNITS_ARB 0x84E2 +#endif + +#ifndef GL_ARB_transpose_matrix +#define GL_TRANSPOSE_MODELVIEW_MATRIX_ARB 0x84E3 +#define GL_TRANSPOSE_PROJECTION_MATRIX_ARB 0x84E4 +#define GL_TRANSPOSE_TEXTURE_MATRIX_ARB 0x84E5 +#define GL_TRANSPOSE_COLOR_MATRIX_ARB 0x84E6 +#endif + +#ifndef GL_ARB_multisample +#define GL_MULTISAMPLE_ARB 0x809D +#define GL_SAMPLE_ALPHA_TO_COVERAGE_ARB 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE_ARB 0x809F +#define GL_SAMPLE_COVERAGE_ARB 0x80A0 +#define GL_SAMPLE_BUFFERS_ARB 0x80A8 +#define GL_SAMPLES_ARB 0x80A9 +#define GL_SAMPLE_COVERAGE_VALUE_ARB 0x80AA +#define GL_SAMPLE_COVERAGE_INVERT_ARB 0x80AB +#define GL_MULTISAMPLE_BIT_ARB 0x20000000 +#endif + +#ifndef GL_ARB_texture_env_add +#endif + +#ifndef GL_ARB_texture_cube_map +#define GL_NORMAL_MAP_ARB 0x8511 +#define GL_REFLECTION_MAP_ARB 0x8512 +#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 +#define GL_TEXTURE_BINDING_CUBE_MAP_ARB 0x8514 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x8515 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x8516 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x8517 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x8518 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x8519 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x851A +#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B +#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_ARB 0x851C +#endif + +#ifndef GL_ARB_texture_compression +#define GL_COMPRESSED_ALPHA_ARB 0x84E9 +#define GL_COMPRESSED_LUMINANCE_ARB 0x84EA +#define GL_COMPRESSED_LUMINANCE_ALPHA_ARB 0x84EB +#define GL_COMPRESSED_INTENSITY_ARB 0x84EC +#define GL_COMPRESSED_RGB_ARB 0x84ED +#define GL_COMPRESSED_RGBA_ARB 0x84EE +#define GL_TEXTURE_COMPRESSION_HINT_ARB 0x84EF +#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE_ARB 0x86A0 +#define GL_TEXTURE_COMPRESSED_ARB 0x86A1 +#define GL_NUM_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A2 +#define GL_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A3 +#endif + +#ifndef GL_ARB_texture_border_clamp +#define GL_CLAMP_TO_BORDER_ARB 0x812D +#endif + +#ifndef GL_ARB_point_parameters +#define GL_POINT_SIZE_MIN_ARB 0x8126 +#define GL_POINT_SIZE_MAX_ARB 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE_ARB 0x8128 +#define GL_POINT_DISTANCE_ATTENUATION_ARB 0x8129 +#endif + +#ifndef GL_ARB_vertex_blend +#define GL_MAX_VERTEX_UNITS_ARB 0x86A4 +#define GL_ACTIVE_VERTEX_UNITS_ARB 0x86A5 +#define GL_WEIGHT_SUM_UNITY_ARB 0x86A6 +#define GL_VERTEX_BLEND_ARB 0x86A7 +#define GL_CURRENT_WEIGHT_ARB 0x86A8 +#define GL_WEIGHT_ARRAY_TYPE_ARB 0x86A9 +#define GL_WEIGHT_ARRAY_STRIDE_ARB 0x86AA +#define GL_WEIGHT_ARRAY_SIZE_ARB 0x86AB +#define GL_WEIGHT_ARRAY_POINTER_ARB 0x86AC +#define GL_WEIGHT_ARRAY_ARB 0x86AD +#define GL_MODELVIEW0_ARB 0x1700 +#define GL_MODELVIEW1_ARB 0x850A +#define GL_MODELVIEW2_ARB 0x8722 +#define GL_MODELVIEW3_ARB 0x8723 +#define GL_MODELVIEW4_ARB 0x8724 +#define GL_MODELVIEW5_ARB 0x8725 +#define GL_MODELVIEW6_ARB 0x8726 +#define GL_MODELVIEW7_ARB 0x8727 +#define GL_MODELVIEW8_ARB 0x8728 +#define GL_MODELVIEW9_ARB 0x8729 +#define GL_MODELVIEW10_ARB 0x872A +#define GL_MODELVIEW11_ARB 0x872B +#define GL_MODELVIEW12_ARB 0x872C +#define GL_MODELVIEW13_ARB 0x872D +#define GL_MODELVIEW14_ARB 0x872E +#define GL_MODELVIEW15_ARB 0x872F +#define GL_MODELVIEW16_ARB 0x8730 +#define GL_MODELVIEW17_ARB 0x8731 +#define GL_MODELVIEW18_ARB 0x8732 +#define GL_MODELVIEW19_ARB 0x8733 +#define GL_MODELVIEW20_ARB 0x8734 +#define GL_MODELVIEW21_ARB 0x8735 +#define GL_MODELVIEW22_ARB 0x8736 +#define GL_MODELVIEW23_ARB 0x8737 +#define GL_MODELVIEW24_ARB 0x8738 +#define GL_MODELVIEW25_ARB 0x8739 +#define GL_MODELVIEW26_ARB 0x873A +#define GL_MODELVIEW27_ARB 0x873B +#define GL_MODELVIEW28_ARB 0x873C +#define GL_MODELVIEW29_ARB 0x873D +#define GL_MODELVIEW30_ARB 0x873E +#define GL_MODELVIEW31_ARB 0x873F +#endif + +#ifndef GL_ARB_matrix_palette +#define GL_MATRIX_PALETTE_ARB 0x8840 +#define GL_MAX_MATRIX_PALETTE_STACK_DEPTH_ARB 0x8841 +#define GL_MAX_PALETTE_MATRICES_ARB 0x8842 +#define GL_CURRENT_PALETTE_MATRIX_ARB 0x8843 +#define GL_MATRIX_INDEX_ARRAY_ARB 0x8844 +#define GL_CURRENT_MATRIX_INDEX_ARB 0x8845 +#define GL_MATRIX_INDEX_ARRAY_SIZE_ARB 0x8846 +#define GL_MATRIX_INDEX_ARRAY_TYPE_ARB 0x8847 +#define GL_MATRIX_INDEX_ARRAY_STRIDE_ARB 0x8848 +#define GL_MATRIX_INDEX_ARRAY_POINTER_ARB 0x8849 +#endif + +#ifndef GL_ARB_texture_env_combine +#define GL_COMBINE_ARB 0x8570 +#define GL_COMBINE_RGB_ARB 0x8571 +#define GL_COMBINE_ALPHA_ARB 0x8572 +#define GL_SOURCE0_RGB_ARB 0x8580 +#define GL_SOURCE1_RGB_ARB 0x8581 +#define GL_SOURCE2_RGB_ARB 0x8582 +#define GL_SOURCE0_ALPHA_ARB 0x8588 +#define GL_SOURCE1_ALPHA_ARB 0x8589 +#define GL_SOURCE2_ALPHA_ARB 0x858A +#define GL_OPERAND0_RGB_ARB 0x8590 +#define GL_OPERAND1_RGB_ARB 0x8591 +#define GL_OPERAND2_RGB_ARB 0x8592 +#define GL_OPERAND0_ALPHA_ARB 0x8598 +#define GL_OPERAND1_ALPHA_ARB 0x8599 +#define GL_OPERAND2_ALPHA_ARB 0x859A +#define GL_RGB_SCALE_ARB 0x8573 +#define GL_ADD_SIGNED_ARB 0x8574 +#define GL_INTERPOLATE_ARB 0x8575 +#define GL_SUBTRACT_ARB 0x84E7 +#define GL_CONSTANT_ARB 0x8576 +#define GL_PRIMARY_COLOR_ARB 0x8577 +#define GL_PREVIOUS_ARB 0x8578 +#endif + +#ifndef GL_ARB_texture_env_crossbar +#endif + +#ifndef GL_ARB_texture_env_dot3 +#define GL_DOT3_RGB_ARB 0x86AE +#define GL_DOT3_RGBA_ARB 0x86AF +#endif + +#ifndef GL_ARB_texture_mirrored_repeat +#define GL_MIRRORED_REPEAT_ARB 0x8370 +#endif + +#ifndef GL_ARB_depth_texture +#define GL_DEPTH_COMPONENT16_ARB 0x81A5 +#define GL_DEPTH_COMPONENT24_ARB 0x81A6 +#define GL_DEPTH_COMPONENT32_ARB 0x81A7 +#define GL_TEXTURE_DEPTH_SIZE_ARB 0x884A +#define GL_DEPTH_TEXTURE_MODE_ARB 0x884B +#endif + +#ifndef GL_ARB_shadow +#define GL_TEXTURE_COMPARE_MODE_ARB 0x884C +#define GL_TEXTURE_COMPARE_FUNC_ARB 0x884D +#define GL_COMPARE_R_TO_TEXTURE_ARB 0x884E +#endif + +#ifndef GL_ARB_shadow_ambient +#define GL_TEXTURE_COMPARE_FAIL_VALUE_ARB 0x80BF +#endif + +#ifndef GL_ARB_window_pos +#endif + +#ifndef GL_ARB_vertex_program +#define GL_COLOR_SUM_ARB 0x8458 +#define GL_VERTEX_PROGRAM_ARB 0x8620 +#define GL_VERTEX_ATTRIB_ARRAY_ENABLED_ARB 0x8622 +#define GL_VERTEX_ATTRIB_ARRAY_SIZE_ARB 0x8623 +#define GL_VERTEX_ATTRIB_ARRAY_STRIDE_ARB 0x8624 +#define GL_VERTEX_ATTRIB_ARRAY_TYPE_ARB 0x8625 +#define GL_CURRENT_VERTEX_ATTRIB_ARB 0x8626 +#define GL_PROGRAM_LENGTH_ARB 0x8627 +#define GL_PROGRAM_STRING_ARB 0x8628 +#define GL_MAX_PROGRAM_MATRIX_STACK_DEPTH_ARB 0x862E +#define GL_MAX_PROGRAM_MATRICES_ARB 0x862F +#define GL_CURRENT_MATRIX_STACK_DEPTH_ARB 0x8640 +#define GL_CURRENT_MATRIX_ARB 0x8641 +#define GL_VERTEX_PROGRAM_POINT_SIZE_ARB 0x8642 +#define GL_VERTEX_PROGRAM_TWO_SIDE_ARB 0x8643 +#define GL_VERTEX_ATTRIB_ARRAY_POINTER_ARB 0x8645 +#define GL_PROGRAM_ERROR_POSITION_ARB 0x864B +#define GL_PROGRAM_BINDING_ARB 0x8677 +#define GL_MAX_VERTEX_ATTRIBS_ARB 0x8869 +#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED_ARB 0x886A +#define GL_PROGRAM_ERROR_STRING_ARB 0x8874 +#define GL_PROGRAM_FORMAT_ASCII_ARB 0x8875 +#define GL_PROGRAM_FORMAT_ARB 0x8876 +#define GL_PROGRAM_INSTRUCTIONS_ARB 0x88A0 +#define GL_MAX_PROGRAM_INSTRUCTIONS_ARB 0x88A1 +#define GL_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A2 +#define GL_MAX_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A3 +#define GL_PROGRAM_TEMPORARIES_ARB 0x88A4 +#define GL_MAX_PROGRAM_TEMPORARIES_ARB 0x88A5 +#define GL_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A6 +#define GL_MAX_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A7 +#define GL_PROGRAM_PARAMETERS_ARB 0x88A8 +#define GL_MAX_PROGRAM_PARAMETERS_ARB 0x88A9 +#define GL_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AA +#define GL_MAX_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AB +#define GL_PROGRAM_ATTRIBS_ARB 0x88AC +#define GL_MAX_PROGRAM_ATTRIBS_ARB 0x88AD +#define GL_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AE +#define GL_MAX_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AF +#define GL_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B0 +#define GL_MAX_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B1 +#define GL_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B2 +#define GL_MAX_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B3 +#define GL_MAX_PROGRAM_LOCAL_PARAMETERS_ARB 0x88B4 +#define GL_MAX_PROGRAM_ENV_PARAMETERS_ARB 0x88B5 +#define GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB 0x88B6 +#define GL_TRANSPOSE_CURRENT_MATRIX_ARB 0x88B7 +#define GL_MATRIX0_ARB 0x88C0 +#define GL_MATRIX1_ARB 0x88C1 +#define GL_MATRIX2_ARB 0x88C2 +#define GL_MATRIX3_ARB 0x88C3 +#define GL_MATRIX4_ARB 0x88C4 +#define GL_MATRIX5_ARB 0x88C5 +#define GL_MATRIX6_ARB 0x88C6 +#define GL_MATRIX7_ARB 0x88C7 +#define GL_MATRIX8_ARB 0x88C8 +#define GL_MATRIX9_ARB 0x88C9 +#define GL_MATRIX10_ARB 0x88CA +#define GL_MATRIX11_ARB 0x88CB +#define GL_MATRIX12_ARB 0x88CC +#define GL_MATRIX13_ARB 0x88CD +#define GL_MATRIX14_ARB 0x88CE +#define GL_MATRIX15_ARB 0x88CF +#define GL_MATRIX16_ARB 0x88D0 +#define GL_MATRIX17_ARB 0x88D1 +#define GL_MATRIX18_ARB 0x88D2 +#define GL_MATRIX19_ARB 0x88D3 +#define GL_MATRIX20_ARB 0x88D4 +#define GL_MATRIX21_ARB 0x88D5 +#define GL_MATRIX22_ARB 0x88D6 +#define GL_MATRIX23_ARB 0x88D7 +#define GL_MATRIX24_ARB 0x88D8 +#define GL_MATRIX25_ARB 0x88D9 +#define GL_MATRIX26_ARB 0x88DA +#define GL_MATRIX27_ARB 0x88DB +#define GL_MATRIX28_ARB 0x88DC +#define GL_MATRIX29_ARB 0x88DD +#define GL_MATRIX30_ARB 0x88DE +#define GL_MATRIX31_ARB 0x88DF +#endif + +#ifndef GL_ARB_fragment_program +#define GL_FRAGMENT_PROGRAM_ARB 0x8804 +#define GL_PROGRAM_ALU_INSTRUCTIONS_ARB 0x8805 +#define GL_PROGRAM_TEX_INSTRUCTIONS_ARB 0x8806 +#define GL_PROGRAM_TEX_INDIRECTIONS_ARB 0x8807 +#define GL_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x8808 +#define GL_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x8809 +#define GL_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x880A +#define GL_MAX_PROGRAM_ALU_INSTRUCTIONS_ARB 0x880B +#define GL_MAX_PROGRAM_TEX_INSTRUCTIONS_ARB 0x880C +#define GL_MAX_PROGRAM_TEX_INDIRECTIONS_ARB 0x880D +#define GL_MAX_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x880E +#define GL_MAX_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x880F +#define GL_MAX_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x8810 +#define GL_MAX_TEXTURE_COORDS_ARB 0x8871 +#define GL_MAX_TEXTURE_IMAGE_UNITS_ARB 0x8872 +#endif + +#ifndef GL_ARB_vertex_buffer_object +#define GL_BUFFER_SIZE_ARB 0x8764 +#define GL_BUFFER_USAGE_ARB 0x8765 +#define GL_ARRAY_BUFFER_ARB 0x8892 +#define GL_ELEMENT_ARRAY_BUFFER_ARB 0x8893 +#define GL_ARRAY_BUFFER_BINDING_ARB 0x8894 +#define GL_ELEMENT_ARRAY_BUFFER_BINDING_ARB 0x8895 +#define GL_VERTEX_ARRAY_BUFFER_BINDING_ARB 0x8896 +#define GL_NORMAL_ARRAY_BUFFER_BINDING_ARB 0x8897 +#define GL_COLOR_ARRAY_BUFFER_BINDING_ARB 0x8898 +#define GL_INDEX_ARRAY_BUFFER_BINDING_ARB 0x8899 +#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING_ARB 0x889A +#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING_ARB 0x889B +#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING_ARB 0x889C +#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING_ARB 0x889D +#define GL_WEIGHT_ARRAY_BUFFER_BINDING_ARB 0x889E +#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING_ARB 0x889F +#define GL_READ_ONLY_ARB 0x88B8 +#define GL_WRITE_ONLY_ARB 0x88B9 +#define GL_READ_WRITE_ARB 0x88BA +#define GL_BUFFER_ACCESS_ARB 0x88BB +#define GL_BUFFER_MAPPED_ARB 0x88BC +#define GL_BUFFER_MAP_POINTER_ARB 0x88BD +#define GL_STREAM_DRAW_ARB 0x88E0 +#define GL_STREAM_READ_ARB 0x88E1 +#define GL_STREAM_COPY_ARB 0x88E2 +#define GL_STATIC_DRAW_ARB 0x88E4 +#define GL_STATIC_READ_ARB 0x88E5 +#define GL_STATIC_COPY_ARB 0x88E6 +#define GL_DYNAMIC_DRAW_ARB 0x88E8 +#define GL_DYNAMIC_READ_ARB 0x88E9 +#define GL_DYNAMIC_COPY_ARB 0x88EA +#endif + +#ifndef GL_ARB_occlusion_query +#define GL_QUERY_COUNTER_BITS_ARB 0x8864 +#define GL_CURRENT_QUERY_ARB 0x8865 +#define GL_QUERY_RESULT_ARB 0x8866 +#define GL_QUERY_RESULT_AVAILABLE_ARB 0x8867 +#define GL_SAMPLES_PASSED_ARB 0x8914 +#endif + +#ifndef GL_ARB_shader_objects +#define GL_PROGRAM_OBJECT_ARB 0x8B40 +#define GL_SHADER_OBJECT_ARB 0x8B48 +#define GL_OBJECT_TYPE_ARB 0x8B4E +#define GL_OBJECT_SUBTYPE_ARB 0x8B4F +#define GL_FLOAT_VEC2_ARB 0x8B50 +#define GL_FLOAT_VEC3_ARB 0x8B51 +#define GL_FLOAT_VEC4_ARB 0x8B52 +#define GL_INT_VEC2_ARB 0x8B53 +#define GL_INT_VEC3_ARB 0x8B54 +#define GL_INT_VEC4_ARB 0x8B55 +#define GL_BOOL_ARB 0x8B56 +#define GL_BOOL_VEC2_ARB 0x8B57 +#define GL_BOOL_VEC3_ARB 0x8B58 +#define GL_BOOL_VEC4_ARB 0x8B59 +#define GL_FLOAT_MAT2_ARB 0x8B5A +#define GL_FLOAT_MAT3_ARB 0x8B5B +#define GL_FLOAT_MAT4_ARB 0x8B5C +#define GL_SAMPLER_1D_ARB 0x8B5D +#define GL_SAMPLER_2D_ARB 0x8B5E +#define GL_SAMPLER_3D_ARB 0x8B5F +#define GL_SAMPLER_CUBE_ARB 0x8B60 +#define GL_SAMPLER_1D_SHADOW_ARB 0x8B61 +#define GL_SAMPLER_2D_SHADOW_ARB 0x8B62 +#define GL_SAMPLER_2D_RECT_ARB 0x8B63 +#define GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 +#define GL_OBJECT_DELETE_STATUS_ARB 0x8B80 +#define GL_OBJECT_COMPILE_STATUS_ARB 0x8B81 +#define GL_OBJECT_LINK_STATUS_ARB 0x8B82 +#define GL_OBJECT_VALIDATE_STATUS_ARB 0x8B83 +#define GL_OBJECT_INFO_LOG_LENGTH_ARB 0x8B84 +#define GL_OBJECT_ATTACHED_OBJECTS_ARB 0x8B85 +#define GL_OBJECT_ACTIVE_UNIFORMS_ARB 0x8B86 +#define GL_OBJECT_ACTIVE_UNIFORM_MAX_LENGTH_ARB 0x8B87 +#define GL_OBJECT_SHADER_SOURCE_LENGTH_ARB 0x8B88 +#endif + +#ifndef GL_ARB_vertex_shader +#define GL_VERTEX_SHADER_ARB 0x8B31 +#define GL_MAX_VERTEX_UNIFORM_COMPONENTS_ARB 0x8B4A +#define GL_MAX_VARYING_FLOATS_ARB 0x8B4B +#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C +#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS_ARB 0x8B4D +#define GL_OBJECT_ACTIVE_ATTRIBUTES_ARB 0x8B89 +#define GL_OBJECT_ACTIVE_ATTRIBUTE_MAX_LENGTH_ARB 0x8B8A +#endif + +#ifndef GL_ARB_fragment_shader +#define GL_FRAGMENT_SHADER_ARB 0x8B30 +#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS_ARB 0x8B49 +#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT_ARB 0x8B8B +#endif + +#ifndef GL_ARB_shading_language_100 +#define GL_SHADING_LANGUAGE_VERSION_ARB 0x8B8C +#endif + +#ifndef GL_ARB_texture_non_power_of_two +#endif + +#ifndef GL_ARB_point_sprite +#define GL_POINT_SPRITE_ARB 0x8861 +#define GL_COORD_REPLACE_ARB 0x8862 +#endif + +#ifndef GL_ARB_fragment_program_shadow +#endif + +#ifndef GL_ARB_draw_buffers +#define GL_MAX_DRAW_BUFFERS_ARB 0x8824 +#define GL_DRAW_BUFFER0_ARB 0x8825 +#define GL_DRAW_BUFFER1_ARB 0x8826 +#define GL_DRAW_BUFFER2_ARB 0x8827 +#define GL_DRAW_BUFFER3_ARB 0x8828 +#define GL_DRAW_BUFFER4_ARB 0x8829 +#define GL_DRAW_BUFFER5_ARB 0x882A +#define GL_DRAW_BUFFER6_ARB 0x882B +#define GL_DRAW_BUFFER7_ARB 0x882C +#define GL_DRAW_BUFFER8_ARB 0x882D +#define GL_DRAW_BUFFER9_ARB 0x882E +#define GL_DRAW_BUFFER10_ARB 0x882F +#define GL_DRAW_BUFFER11_ARB 0x8830 +#define GL_DRAW_BUFFER12_ARB 0x8831 +#define GL_DRAW_BUFFER13_ARB 0x8832 +#define GL_DRAW_BUFFER14_ARB 0x8833 +#define GL_DRAW_BUFFER15_ARB 0x8834 +#endif + +#ifndef GL_ARB_texture_rectangle +#define GL_TEXTURE_RECTANGLE_ARB 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE_ARB 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE_ARB 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE_ARB 0x84F8 +#endif + +#ifndef GL_ARB_color_buffer_float +#define GL_RGBA_FLOAT_MODE_ARB 0x8820 +#define GL_CLAMP_VERTEX_COLOR_ARB 0x891A +#define GL_CLAMP_FRAGMENT_COLOR_ARB 0x891B +#define GL_CLAMP_READ_COLOR_ARB 0x891C +#define GL_FIXED_ONLY_ARB 0x891D +#endif + +#ifndef GL_ARB_half_float_pixel +#define GL_HALF_FLOAT_ARB 0x140B +#endif + +#ifndef GL_ARB_texture_float +#define GL_TEXTURE_RED_TYPE_ARB 0x8C10 +#define GL_TEXTURE_GREEN_TYPE_ARB 0x8C11 +#define GL_TEXTURE_BLUE_TYPE_ARB 0x8C12 +#define GL_TEXTURE_ALPHA_TYPE_ARB 0x8C13 +#define GL_TEXTURE_LUMINANCE_TYPE_ARB 0x8C14 +#define GL_TEXTURE_INTENSITY_TYPE_ARB 0x8C15 +#define GL_TEXTURE_DEPTH_TYPE_ARB 0x8C16 +#define GL_UNSIGNED_NORMALIZED_ARB 0x8C17 +#define GL_RGBA32F_ARB 0x8814 +#define GL_RGB32F_ARB 0x8815 +#define GL_ALPHA32F_ARB 0x8816 +#define GL_INTENSITY32F_ARB 0x8817 +#define GL_LUMINANCE32F_ARB 0x8818 +#define GL_LUMINANCE_ALPHA32F_ARB 0x8819 +#define GL_RGBA16F_ARB 0x881A +#define GL_RGB16F_ARB 0x881B +#define GL_ALPHA16F_ARB 0x881C +#define GL_INTENSITY16F_ARB 0x881D +#define GL_LUMINANCE16F_ARB 0x881E +#define GL_LUMINANCE_ALPHA16F_ARB 0x881F +#endif + +#ifndef GL_ARB_pixel_buffer_object +#define GL_PIXEL_PACK_BUFFER_ARB 0x88EB +#define GL_PIXEL_UNPACK_BUFFER_ARB 0x88EC +#define GL_PIXEL_PACK_BUFFER_BINDING_ARB 0x88ED +#define GL_PIXEL_UNPACK_BUFFER_BINDING_ARB 0x88EF +#endif + +#ifndef GL_EXT_abgr +#define GL_ABGR_EXT 0x8000 +#endif + +#ifndef GL_EXT_blend_color +#define GL_CONSTANT_COLOR_EXT 0x8001 +#define GL_ONE_MINUS_CONSTANT_COLOR_EXT 0x8002 +#define GL_CONSTANT_ALPHA_EXT 0x8003 +#define GL_ONE_MINUS_CONSTANT_ALPHA_EXT 0x8004 +#define GL_BLEND_COLOR_EXT 0x8005 +#endif + +#ifndef GL_EXT_polygon_offset +#define GL_POLYGON_OFFSET_EXT 0x8037 +#define GL_POLYGON_OFFSET_FACTOR_EXT 0x8038 +#define GL_POLYGON_OFFSET_BIAS_EXT 0x8039 +#endif + +#ifndef GL_EXT_texture +#define GL_ALPHA4_EXT 0x803B +#define GL_ALPHA8_EXT 0x803C +#define GL_ALPHA12_EXT 0x803D +#define GL_ALPHA16_EXT 0x803E +#define GL_LUMINANCE4_EXT 0x803F +#define GL_LUMINANCE8_EXT 0x8040 +#define GL_LUMINANCE12_EXT 0x8041 +#define GL_LUMINANCE16_EXT 0x8042 +#define GL_LUMINANCE4_ALPHA4_EXT 0x8043 +#define GL_LUMINANCE6_ALPHA2_EXT 0x8044 +#define GL_LUMINANCE8_ALPHA8_EXT 0x8045 +#define GL_LUMINANCE12_ALPHA4_EXT 0x8046 +#define GL_LUMINANCE12_ALPHA12_EXT 0x8047 +#define GL_LUMINANCE16_ALPHA16_EXT 0x8048 +#define GL_INTENSITY_EXT 0x8049 +#define GL_INTENSITY4_EXT 0x804A +#define GL_INTENSITY8_EXT 0x804B +#define GL_INTENSITY12_EXT 0x804C +#define GL_INTENSITY16_EXT 0x804D +#define GL_RGB2_EXT 0x804E +#define GL_RGB4_EXT 0x804F +#define GL_RGB5_EXT 0x8050 +#define GL_RGB8_EXT 0x8051 +#define GL_RGB10_EXT 0x8052 +#define GL_RGB12_EXT 0x8053 +#define GL_RGB16_EXT 0x8054 +#define GL_RGBA2_EXT 0x8055 +#define GL_RGBA4_EXT 0x8056 +#define GL_RGB5_A1_EXT 0x8057 +#define GL_RGBA8_EXT 0x8058 +#define GL_RGB10_A2_EXT 0x8059 +#define GL_RGBA12_EXT 0x805A +#define GL_RGBA16_EXT 0x805B +#define GL_TEXTURE_RED_SIZE_EXT 0x805C +#define GL_TEXTURE_GREEN_SIZE_EXT 0x805D +#define GL_TEXTURE_BLUE_SIZE_EXT 0x805E +#define GL_TEXTURE_ALPHA_SIZE_EXT 0x805F +#define GL_TEXTURE_LUMINANCE_SIZE_EXT 0x8060 +#define GL_TEXTURE_INTENSITY_SIZE_EXT 0x8061 +#define GL_REPLACE_EXT 0x8062 +#define GL_PROXY_TEXTURE_1D_EXT 0x8063 +#define GL_PROXY_TEXTURE_2D_EXT 0x8064 +#define GL_TEXTURE_TOO_LARGE_EXT 0x8065 +#endif + +#ifndef GL_EXT_texture3D +#define GL_PACK_SKIP_IMAGES_EXT 0x806B +#define GL_PACK_IMAGE_HEIGHT_EXT 0x806C +#define GL_UNPACK_SKIP_IMAGES_EXT 0x806D +#define GL_UNPACK_IMAGE_HEIGHT_EXT 0x806E +#define GL_TEXTURE_3D_EXT 0x806F +#define GL_PROXY_TEXTURE_3D_EXT 0x8070 +#define GL_TEXTURE_DEPTH_EXT 0x8071 +#define GL_TEXTURE_WRAP_R_EXT 0x8072 +#define GL_MAX_3D_TEXTURE_SIZE_EXT 0x8073 +#endif + +#ifndef GL_SGIS_texture_filter4 +#define GL_FILTER4_SGIS 0x8146 +#define GL_TEXTURE_FILTER4_SIZE_SGIS 0x8147 +#endif + +#ifndef GL_EXT_subtexture +#endif + +#ifndef GL_EXT_copy_texture +#endif + +#ifndef GL_EXT_histogram +#define GL_HISTOGRAM_EXT 0x8024 +#define GL_PROXY_HISTOGRAM_EXT 0x8025 +#define GL_HISTOGRAM_WIDTH_EXT 0x8026 +#define GL_HISTOGRAM_FORMAT_EXT 0x8027 +#define GL_HISTOGRAM_RED_SIZE_EXT 0x8028 +#define GL_HISTOGRAM_GREEN_SIZE_EXT 0x8029 +#define GL_HISTOGRAM_BLUE_SIZE_EXT 0x802A +#define GL_HISTOGRAM_ALPHA_SIZE_EXT 0x802B +#define GL_HISTOGRAM_LUMINANCE_SIZE_EXT 0x802C +#define GL_HISTOGRAM_SINK_EXT 0x802D +#define GL_MINMAX_EXT 0x802E +#define GL_MINMAX_FORMAT_EXT 0x802F +#define GL_MINMAX_SINK_EXT 0x8030 +#define GL_TABLE_TOO_LARGE_EXT 0x8031 +#endif + +#ifndef GL_EXT_convolution +#define GL_CONVOLUTION_1D_EXT 0x8010 +#define GL_CONVOLUTION_2D_EXT 0x8011 +#define GL_SEPARABLE_2D_EXT 0x8012 +#define GL_CONVOLUTION_BORDER_MODE_EXT 0x8013 +#define GL_CONVOLUTION_FILTER_SCALE_EXT 0x8014 +#define GL_CONVOLUTION_FILTER_BIAS_EXT 0x8015 +#define GL_REDUCE_EXT 0x8016 +#define GL_CONVOLUTION_FORMAT_EXT 0x8017 +#define GL_CONVOLUTION_WIDTH_EXT 0x8018 +#define GL_CONVOLUTION_HEIGHT_EXT 0x8019 +#define GL_MAX_CONVOLUTION_WIDTH_EXT 0x801A +#define GL_MAX_CONVOLUTION_HEIGHT_EXT 0x801B +#define GL_POST_CONVOLUTION_RED_SCALE_EXT 0x801C +#define GL_POST_CONVOLUTION_GREEN_SCALE_EXT 0x801D +#define GL_POST_CONVOLUTION_BLUE_SCALE_EXT 0x801E +#define GL_POST_CONVOLUTION_ALPHA_SCALE_EXT 0x801F +#define GL_POST_CONVOLUTION_RED_BIAS_EXT 0x8020 +#define GL_POST_CONVOLUTION_GREEN_BIAS_EXT 0x8021 +#define GL_POST_CONVOLUTION_BLUE_BIAS_EXT 0x8022 +#define GL_POST_CONVOLUTION_ALPHA_BIAS_EXT 0x8023 +#endif + +#ifndef GL_SGI_color_matrix +#define GL_COLOR_MATRIX_SGI 0x80B1 +#define GL_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B2 +#define GL_MAX_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B3 +#define GL_POST_COLOR_MATRIX_RED_SCALE_SGI 0x80B4 +#define GL_POST_COLOR_MATRIX_GREEN_SCALE_SGI 0x80B5 +#define GL_POST_COLOR_MATRIX_BLUE_SCALE_SGI 0x80B6 +#define GL_POST_COLOR_MATRIX_ALPHA_SCALE_SGI 0x80B7 +#define GL_POST_COLOR_MATRIX_RED_BIAS_SGI 0x80B8 +#define GL_POST_COLOR_MATRIX_GREEN_BIAS_SGI 0x80B9 +#define GL_POST_COLOR_MATRIX_BLUE_BIAS_SGI 0x80BA +#define GL_POST_COLOR_MATRIX_ALPHA_BIAS_SGI 0x80BB +#endif + +#ifndef GL_SGI_color_table +#define GL_COLOR_TABLE_SGI 0x80D0 +#define GL_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D1 +#define GL_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D2 +#define GL_PROXY_COLOR_TABLE_SGI 0x80D3 +#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D4 +#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D5 +#define GL_COLOR_TABLE_SCALE_SGI 0x80D6 +#define GL_COLOR_TABLE_BIAS_SGI 0x80D7 +#define GL_COLOR_TABLE_FORMAT_SGI 0x80D8 +#define GL_COLOR_TABLE_WIDTH_SGI 0x80D9 +#define GL_COLOR_TABLE_RED_SIZE_SGI 0x80DA +#define GL_COLOR_TABLE_GREEN_SIZE_SGI 0x80DB +#define GL_COLOR_TABLE_BLUE_SIZE_SGI 0x80DC +#define GL_COLOR_TABLE_ALPHA_SIZE_SGI 0x80DD +#define GL_COLOR_TABLE_LUMINANCE_SIZE_SGI 0x80DE +#define GL_COLOR_TABLE_INTENSITY_SIZE_SGI 0x80DF +#endif + +#ifndef GL_SGIS_pixel_texture +#define GL_PIXEL_TEXTURE_SGIS 0x8353 +#define GL_PIXEL_FRAGMENT_RGB_SOURCE_SGIS 0x8354 +#define GL_PIXEL_FRAGMENT_ALPHA_SOURCE_SGIS 0x8355 +#define GL_PIXEL_GROUP_COLOR_SGIS 0x8356 +#endif + +#ifndef GL_SGIX_pixel_texture +#define GL_PIXEL_TEX_GEN_SGIX 0x8139 +#define GL_PIXEL_TEX_GEN_MODE_SGIX 0x832B +#endif + +#ifndef GL_SGIS_texture4D +#define GL_PACK_SKIP_VOLUMES_SGIS 0x8130 +#define GL_PACK_IMAGE_DEPTH_SGIS 0x8131 +#define GL_UNPACK_SKIP_VOLUMES_SGIS 0x8132 +#define GL_UNPACK_IMAGE_DEPTH_SGIS 0x8133 +#define GL_TEXTURE_4D_SGIS 0x8134 +#define GL_PROXY_TEXTURE_4D_SGIS 0x8135 +#define GL_TEXTURE_4DSIZE_SGIS 0x8136 +#define GL_TEXTURE_WRAP_Q_SGIS 0x8137 +#define GL_MAX_4D_TEXTURE_SIZE_SGIS 0x8138 +#define GL_TEXTURE_4D_BINDING_SGIS 0x814F +#endif + +#ifndef GL_SGI_texture_color_table +#define GL_TEXTURE_COLOR_TABLE_SGI 0x80BC +#define GL_PROXY_TEXTURE_COLOR_TABLE_SGI 0x80BD +#endif + +#ifndef GL_EXT_cmyka +#define GL_CMYK_EXT 0x800C +#define GL_CMYKA_EXT 0x800D +#define GL_PACK_CMYK_HINT_EXT 0x800E +#define GL_UNPACK_CMYK_HINT_EXT 0x800F +#endif + +#ifndef GL_EXT_texture_object +#define GL_TEXTURE_PRIORITY_EXT 0x8066 +#define GL_TEXTURE_RESIDENT_EXT 0x8067 +#define GL_TEXTURE_1D_BINDING_EXT 0x8068 +#define GL_TEXTURE_2D_BINDING_EXT 0x8069 +#define GL_TEXTURE_3D_BINDING_EXT 0x806A +#endif + +#ifndef GL_SGIS_detail_texture +#define GL_DETAIL_TEXTURE_2D_SGIS 0x8095 +#define GL_DETAIL_TEXTURE_2D_BINDING_SGIS 0x8096 +#define GL_LINEAR_DETAIL_SGIS 0x8097 +#define GL_LINEAR_DETAIL_ALPHA_SGIS 0x8098 +#define GL_LINEAR_DETAIL_COLOR_SGIS 0x8099 +#define GL_DETAIL_TEXTURE_LEVEL_SGIS 0x809A +#define GL_DETAIL_TEXTURE_MODE_SGIS 0x809B +#define GL_DETAIL_TEXTURE_FUNC_POINTS_SGIS 0x809C +#endif + +#ifndef GL_SGIS_sharpen_texture +#define GL_LINEAR_SHARPEN_SGIS 0x80AD +#define GL_LINEAR_SHARPEN_ALPHA_SGIS 0x80AE +#define GL_LINEAR_SHARPEN_COLOR_SGIS 0x80AF +#define GL_SHARPEN_TEXTURE_FUNC_POINTS_SGIS 0x80B0 +#endif + +#ifndef GL_EXT_packed_pixels +#define GL_UNSIGNED_BYTE_3_3_2_EXT 0x8032 +#define GL_UNSIGNED_SHORT_4_4_4_4_EXT 0x8033 +#define GL_UNSIGNED_SHORT_5_5_5_1_EXT 0x8034 +#define GL_UNSIGNED_INT_8_8_8_8_EXT 0x8035 +#define GL_UNSIGNED_INT_10_10_10_2_EXT 0x8036 +#endif + +#ifndef GL_SGIS_texture_lod +#define GL_TEXTURE_MIN_LOD_SGIS 0x813A +#define GL_TEXTURE_MAX_LOD_SGIS 0x813B +#define GL_TEXTURE_BASE_LEVEL_SGIS 0x813C +#define GL_TEXTURE_MAX_LEVEL_SGIS 0x813D +#endif + +#ifndef GL_SGIS_multisample +#define GL_MULTISAMPLE_SGIS 0x809D +#define GL_SAMPLE_ALPHA_TO_MASK_SGIS 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE_SGIS 0x809F +#define GL_SAMPLE_MASK_SGIS 0x80A0 +#define GL_1PASS_SGIS 0x80A1 +#define GL_2PASS_0_SGIS 0x80A2 +#define GL_2PASS_1_SGIS 0x80A3 +#define GL_4PASS_0_SGIS 0x80A4 +#define GL_4PASS_1_SGIS 0x80A5 +#define GL_4PASS_2_SGIS 0x80A6 +#define GL_4PASS_3_SGIS 0x80A7 +#define GL_SAMPLE_BUFFERS_SGIS 0x80A8 +#define GL_SAMPLES_SGIS 0x80A9 +#define GL_SAMPLE_MASK_VALUE_SGIS 0x80AA +#define GL_SAMPLE_MASK_INVERT_SGIS 0x80AB +#define GL_SAMPLE_PATTERN_SGIS 0x80AC +#endif + +#ifndef GL_EXT_rescale_normal +#define GL_RESCALE_NORMAL_EXT 0x803A +#endif + +#ifndef GL_EXT_vertex_array +#define GL_VERTEX_ARRAY_EXT 0x8074 +#define GL_NORMAL_ARRAY_EXT 0x8075 +#define GL_COLOR_ARRAY_EXT 0x8076 +#define GL_INDEX_ARRAY_EXT 0x8077 +#define GL_TEXTURE_COORD_ARRAY_EXT 0x8078 +#define GL_EDGE_FLAG_ARRAY_EXT 0x8079 +#define GL_VERTEX_ARRAY_SIZE_EXT 0x807A +#define GL_VERTEX_ARRAY_TYPE_EXT 0x807B +#define GL_VERTEX_ARRAY_STRIDE_EXT 0x807C +#define GL_VERTEX_ARRAY_COUNT_EXT 0x807D +#define GL_NORMAL_ARRAY_TYPE_EXT 0x807E +#define GL_NORMAL_ARRAY_STRIDE_EXT 0x807F +#define GL_NORMAL_ARRAY_COUNT_EXT 0x8080 +#define GL_COLOR_ARRAY_SIZE_EXT 0x8081 +#define GL_COLOR_ARRAY_TYPE_EXT 0x8082 +#define GL_COLOR_ARRAY_STRIDE_EXT 0x8083 +#define GL_COLOR_ARRAY_COUNT_EXT 0x8084 +#define GL_INDEX_ARRAY_TYPE_EXT 0x8085 +#define GL_INDEX_ARRAY_STRIDE_EXT 0x8086 +#define GL_INDEX_ARRAY_COUNT_EXT 0x8087 +#define GL_TEXTURE_COORD_ARRAY_SIZE_EXT 0x8088 +#define GL_TEXTURE_COORD_ARRAY_TYPE_EXT 0x8089 +#define GL_TEXTURE_COORD_ARRAY_STRIDE_EXT 0x808A +#define GL_TEXTURE_COORD_ARRAY_COUNT_EXT 0x808B +#define GL_EDGE_FLAG_ARRAY_STRIDE_EXT 0x808C +#define GL_EDGE_FLAG_ARRAY_COUNT_EXT 0x808D +#define GL_VERTEX_ARRAY_POINTER_EXT 0x808E +#define GL_NORMAL_ARRAY_POINTER_EXT 0x808F +#define GL_COLOR_ARRAY_POINTER_EXT 0x8090 +#define GL_INDEX_ARRAY_POINTER_EXT 0x8091 +#define GL_TEXTURE_COORD_ARRAY_POINTER_EXT 0x8092 +#define GL_EDGE_FLAG_ARRAY_POINTER_EXT 0x8093 +#endif + +#ifndef GL_EXT_misc_attribute +#endif + +#ifndef GL_SGIS_generate_mipmap +#define GL_GENERATE_MIPMAP_SGIS 0x8191 +#define GL_GENERATE_MIPMAP_HINT_SGIS 0x8192 +#endif + +#ifndef GL_SGIX_clipmap +#define GL_LINEAR_CLIPMAP_LINEAR_SGIX 0x8170 +#define GL_TEXTURE_CLIPMAP_CENTER_SGIX 0x8171 +#define GL_TEXTURE_CLIPMAP_FRAME_SGIX 0x8172 +#define GL_TEXTURE_CLIPMAP_OFFSET_SGIX 0x8173 +#define GL_TEXTURE_CLIPMAP_VIRTUAL_DEPTH_SGIX 0x8174 +#define GL_TEXTURE_CLIPMAP_LOD_OFFSET_SGIX 0x8175 +#define GL_TEXTURE_CLIPMAP_DEPTH_SGIX 0x8176 +#define GL_MAX_CLIPMAP_DEPTH_SGIX 0x8177 +#define GL_MAX_CLIPMAP_VIRTUAL_DEPTH_SGIX 0x8178 +#define GL_NEAREST_CLIPMAP_NEAREST_SGIX 0x844D +#define GL_NEAREST_CLIPMAP_LINEAR_SGIX 0x844E +#define GL_LINEAR_CLIPMAP_NEAREST_SGIX 0x844F +#endif + +#ifndef GL_SGIX_shadow +#define GL_TEXTURE_COMPARE_SGIX 0x819A +#define GL_TEXTURE_COMPARE_OPERATOR_SGIX 0x819B +#define GL_TEXTURE_LEQUAL_R_SGIX 0x819C +#define GL_TEXTURE_GEQUAL_R_SGIX 0x819D +#endif + +#ifndef GL_SGIS_texture_edge_clamp +#define GL_CLAMP_TO_EDGE_SGIS 0x812F +#endif + +#ifndef GL_SGIS_texture_border_clamp +#define GL_CLAMP_TO_BORDER_SGIS 0x812D +#endif + +#ifndef GL_EXT_blend_minmax +#define GL_FUNC_ADD_EXT 0x8006 +#define GL_MIN_EXT 0x8007 +#define GL_MAX_EXT 0x8008 +#define GL_BLEND_EQUATION_EXT 0x8009 +#endif + +#ifndef GL_EXT_blend_subtract +#define GL_FUNC_SUBTRACT_EXT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT_EXT 0x800B +#endif + +#ifndef GL_EXT_blend_logic_op +#endif + +#ifndef GL_SGIX_interlace +#define GL_INTERLACE_SGIX 0x8094 +#endif + +#ifndef GL_SGIX_pixel_tiles +#define GL_PIXEL_TILE_BEST_ALIGNMENT_SGIX 0x813E +#define GL_PIXEL_TILE_CACHE_INCREMENT_SGIX 0x813F +#define GL_PIXEL_TILE_WIDTH_SGIX 0x8140 +#define GL_PIXEL_TILE_HEIGHT_SGIX 0x8141 +#define GL_PIXEL_TILE_GRID_WIDTH_SGIX 0x8142 +#define GL_PIXEL_TILE_GRID_HEIGHT_SGIX 0x8143 +#define GL_PIXEL_TILE_GRID_DEPTH_SGIX 0x8144 +#define GL_PIXEL_TILE_CACHE_SIZE_SGIX 0x8145 +#endif + +#ifndef GL_SGIS_texture_select +#define GL_DUAL_ALPHA4_SGIS 0x8110 +#define GL_DUAL_ALPHA8_SGIS 0x8111 +#define GL_DUAL_ALPHA12_SGIS 0x8112 +#define GL_DUAL_ALPHA16_SGIS 0x8113 +#define GL_DUAL_LUMINANCE4_SGIS 0x8114 +#define GL_DUAL_LUMINANCE8_SGIS 0x8115 +#define GL_DUAL_LUMINANCE12_SGIS 0x8116 +#define GL_DUAL_LUMINANCE16_SGIS 0x8117 +#define GL_DUAL_INTENSITY4_SGIS 0x8118 +#define GL_DUAL_INTENSITY8_SGIS 0x8119 +#define GL_DUAL_INTENSITY12_SGIS 0x811A +#define GL_DUAL_INTENSITY16_SGIS 0x811B +#define GL_DUAL_LUMINANCE_ALPHA4_SGIS 0x811C +#define GL_DUAL_LUMINANCE_ALPHA8_SGIS 0x811D +#define GL_QUAD_ALPHA4_SGIS 0x811E +#define GL_QUAD_ALPHA8_SGIS 0x811F +#define GL_QUAD_LUMINANCE4_SGIS 0x8120 +#define GL_QUAD_LUMINANCE8_SGIS 0x8121 +#define GL_QUAD_INTENSITY4_SGIS 0x8122 +#define GL_QUAD_INTENSITY8_SGIS 0x8123 +#define GL_DUAL_TEXTURE_SELECT_SGIS 0x8124 +#define GL_QUAD_TEXTURE_SELECT_SGIS 0x8125 +#endif + +#ifndef GL_SGIX_sprite +#define GL_SPRITE_SGIX 0x8148 +#define GL_SPRITE_MODE_SGIX 0x8149 +#define GL_SPRITE_AXIS_SGIX 0x814A +#define GL_SPRITE_TRANSLATION_SGIX 0x814B +#define GL_SPRITE_AXIAL_SGIX 0x814C +#define GL_SPRITE_OBJECT_ALIGNED_SGIX 0x814D +#define GL_SPRITE_EYE_ALIGNED_SGIX 0x814E +#endif + +#ifndef GL_SGIX_texture_multi_buffer +#define GL_TEXTURE_MULTI_BUFFER_HINT_SGIX 0x812E +#endif + +#ifndef GL_EXT_point_parameters +#define GL_POINT_SIZE_MIN_EXT 0x8126 +#define GL_POINT_SIZE_MAX_EXT 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE_EXT 0x8128 +#define GL_DISTANCE_ATTENUATION_EXT 0x8129 +#endif + +#ifndef GL_SGIS_point_parameters +#define GL_POINT_SIZE_MIN_SGIS 0x8126 +#define GL_POINT_SIZE_MAX_SGIS 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE_SGIS 0x8128 +#define GL_DISTANCE_ATTENUATION_SGIS 0x8129 +#endif + +#ifndef GL_SGIX_instruments +#define GL_INSTRUMENT_BUFFER_POINTER_SGIX 0x8180 +#define GL_INSTRUMENT_MEASUREMENTS_SGIX 0x8181 +#endif + +#ifndef GL_SGIX_texture_scale_bias +#define GL_POST_TEXTURE_FILTER_BIAS_SGIX 0x8179 +#define GL_POST_TEXTURE_FILTER_SCALE_SGIX 0x817A +#define GL_POST_TEXTURE_FILTER_BIAS_RANGE_SGIX 0x817B +#define GL_POST_TEXTURE_FILTER_SCALE_RANGE_SGIX 0x817C +#endif + +#ifndef GL_SGIX_framezoom +#define GL_FRAMEZOOM_SGIX 0x818B +#define GL_FRAMEZOOM_FACTOR_SGIX 0x818C +#define GL_MAX_FRAMEZOOM_FACTOR_SGIX 0x818D +#endif + +#ifndef GL_SGIX_tag_sample_buffer +#endif + +#ifndef GL_FfdMaskSGIX +#define GL_TEXTURE_DEFORMATION_BIT_SGIX 0x00000001 +#define GL_GEOMETRY_DEFORMATION_BIT_SGIX 0x00000002 +#endif + +#ifndef GL_SGIX_polynomial_ffd +#define GL_GEOMETRY_DEFORMATION_SGIX 0x8194 +#define GL_TEXTURE_DEFORMATION_SGIX 0x8195 +#define GL_DEFORMATIONS_MASK_SGIX 0x8196 +#define GL_MAX_DEFORMATION_ORDER_SGIX 0x8197 +#endif + +#ifndef GL_SGIX_reference_plane +#define GL_REFERENCE_PLANE_SGIX 0x817D +#define GL_REFERENCE_PLANE_EQUATION_SGIX 0x817E +#endif + +#ifndef GL_SGIX_flush_raster +#endif + +#ifndef GL_SGIX_depth_texture +#define GL_DEPTH_COMPONENT16_SGIX 0x81A5 +#define GL_DEPTH_COMPONENT24_SGIX 0x81A6 +#define GL_DEPTH_COMPONENT32_SGIX 0x81A7 +#endif + +#ifndef GL_SGIS_fog_function +#define GL_FOG_FUNC_SGIS 0x812A +#define GL_FOG_FUNC_POINTS_SGIS 0x812B +#define GL_MAX_FOG_FUNC_POINTS_SGIS 0x812C +#endif + +#ifndef GL_SGIX_fog_offset +#define GL_FOG_OFFSET_SGIX 0x8198 +#define GL_FOG_OFFSET_VALUE_SGIX 0x8199 +#endif + +#ifndef GL_HP_image_transform +#define GL_IMAGE_SCALE_X_HP 0x8155 +#define GL_IMAGE_SCALE_Y_HP 0x8156 +#define GL_IMAGE_TRANSLATE_X_HP 0x8157 +#define GL_IMAGE_TRANSLATE_Y_HP 0x8158 +#define GL_IMAGE_ROTATE_ANGLE_HP 0x8159 +#define GL_IMAGE_ROTATE_ORIGIN_X_HP 0x815A +#define GL_IMAGE_ROTATE_ORIGIN_Y_HP 0x815B +#define GL_IMAGE_MAG_FILTER_HP 0x815C +#define GL_IMAGE_MIN_FILTER_HP 0x815D +#define GL_IMAGE_CUBIC_WEIGHT_HP 0x815E +#define GL_CUBIC_HP 0x815F +#define GL_AVERAGE_HP 0x8160 +#define GL_IMAGE_TRANSFORM_2D_HP 0x8161 +#define GL_POST_IMAGE_TRANSFORM_COLOR_TABLE_HP 0x8162 +#define GL_PROXY_POST_IMAGE_TRANSFORM_COLOR_TABLE_HP 0x8163 +#endif + +#ifndef GL_HP_convolution_border_modes +#define GL_IGNORE_BORDER_HP 0x8150 +#define GL_CONSTANT_BORDER_HP 0x8151 +#define GL_REPLICATE_BORDER_HP 0x8153 +#define GL_CONVOLUTION_BORDER_COLOR_HP 0x8154 +#endif + +#ifndef GL_INGR_palette_buffer +#endif + +#ifndef GL_SGIX_texture_add_env +#define GL_TEXTURE_ENV_BIAS_SGIX 0x80BE +#endif + +#ifndef GL_EXT_color_subtable +#endif + +#ifndef GL_PGI_vertex_hints +#define GL_VERTEX_DATA_HINT_PGI 0x1A22A +#define GL_VERTEX_CONSISTENT_HINT_PGI 0x1A22B +#define GL_MATERIAL_SIDE_HINT_PGI 0x1A22C +#define GL_MAX_VERTEX_HINT_PGI 0x1A22D +#define GL_COLOR3_BIT_PGI 0x00010000 +#define GL_COLOR4_BIT_PGI 0x00020000 +#define GL_EDGEFLAG_BIT_PGI 0x00040000 +#define GL_INDEX_BIT_PGI 0x00080000 +#define GL_MAT_AMBIENT_BIT_PGI 0x00100000 +#define GL_MAT_AMBIENT_AND_DIFFUSE_BIT_PGI 0x00200000 +#define GL_MAT_DIFFUSE_BIT_PGI 0x00400000 +#define GL_MAT_EMISSION_BIT_PGI 0x00800000 +#define GL_MAT_COLOR_INDEXES_BIT_PGI 0x01000000 +#define GL_MAT_SHININESS_BIT_PGI 0x02000000 +#define GL_MAT_SPECULAR_BIT_PGI 0x04000000 +#define GL_NORMAL_BIT_PGI 0x08000000 +#define GL_TEXCOORD1_BIT_PGI 0x10000000 +#define GL_TEXCOORD2_BIT_PGI 0x20000000 +#define GL_TEXCOORD3_BIT_PGI 0x40000000 +#define GL_TEXCOORD4_BIT_PGI 0x80000000 +#define GL_VERTEX23_BIT_PGI 0x00000004 +#define GL_VERTEX4_BIT_PGI 0x00000008 +#endif + +#ifndef GL_PGI_misc_hints +#define GL_PREFER_DOUBLEBUFFER_HINT_PGI 0x1A1F8 +#define GL_CONSERVE_MEMORY_HINT_PGI 0x1A1FD +#define GL_RECLAIM_MEMORY_HINT_PGI 0x1A1FE +#define GL_NATIVE_GRAPHICS_HANDLE_PGI 0x1A202 +#define GL_NATIVE_GRAPHICS_BEGIN_HINT_PGI 0x1A203 +#define GL_NATIVE_GRAPHICS_END_HINT_PGI 0x1A204 +#define GL_ALWAYS_FAST_HINT_PGI 0x1A20C +#define GL_ALWAYS_SOFT_HINT_PGI 0x1A20D +#define GL_ALLOW_DRAW_OBJ_HINT_PGI 0x1A20E +#define GL_ALLOW_DRAW_WIN_HINT_PGI 0x1A20F +#define GL_ALLOW_DRAW_FRG_HINT_PGI 0x1A210 +#define GL_ALLOW_DRAW_MEM_HINT_PGI 0x1A211 +#define GL_STRICT_DEPTHFUNC_HINT_PGI 0x1A216 +#define GL_STRICT_LIGHTING_HINT_PGI 0x1A217 +#define GL_STRICT_SCISSOR_HINT_PGI 0x1A218 +#define GL_FULL_STIPPLE_HINT_PGI 0x1A219 +#define GL_CLIP_NEAR_HINT_PGI 0x1A220 +#define GL_CLIP_FAR_HINT_PGI 0x1A221 +#define GL_WIDE_LINE_HINT_PGI 0x1A222 +#define GL_BACK_NORMALS_HINT_PGI 0x1A223 +#endif + +#ifndef GL_EXT_paletted_texture +#define GL_COLOR_INDEX1_EXT 0x80E2 +#define GL_COLOR_INDEX2_EXT 0x80E3 +#define GL_COLOR_INDEX4_EXT 0x80E4 +#define GL_COLOR_INDEX8_EXT 0x80E5 +#define GL_COLOR_INDEX12_EXT 0x80E6 +#define GL_COLOR_INDEX16_EXT 0x80E7 +#define GL_TEXTURE_INDEX_SIZE_EXT 0x80ED +#endif + +#ifndef GL_EXT_clip_volume_hint +#define GL_CLIP_VOLUME_CLIPPING_HINT_EXT 0x80F0 +#endif + +#ifndef GL_SGIX_list_priority +#define GL_LIST_PRIORITY_SGIX 0x8182 +#endif + +#ifndef GL_SGIX_ir_instrument1 +#define GL_IR_INSTRUMENT1_SGIX 0x817F +#endif + +#ifndef GL_SGIX_calligraphic_fragment +#define GL_CALLIGRAPHIC_FRAGMENT_SGIX 0x8183 +#endif + +#ifndef GL_SGIX_texture_lod_bias +#define GL_TEXTURE_LOD_BIAS_S_SGIX 0x818E +#define GL_TEXTURE_LOD_BIAS_T_SGIX 0x818F +#define GL_TEXTURE_LOD_BIAS_R_SGIX 0x8190 +#endif + +#ifndef GL_SGIX_shadow_ambient +#define GL_SHADOW_AMBIENT_SGIX 0x80BF +#endif + +#ifndef GL_EXT_index_texture +#endif + +#ifndef GL_EXT_index_material +#define GL_INDEX_MATERIAL_EXT 0x81B8 +#define GL_INDEX_MATERIAL_PARAMETER_EXT 0x81B9 +#define GL_INDEX_MATERIAL_FACE_EXT 0x81BA +#endif + +#ifndef GL_EXT_index_func +#define GL_INDEX_TEST_EXT 0x81B5 +#define GL_INDEX_TEST_FUNC_EXT 0x81B6 +#define GL_INDEX_TEST_REF_EXT 0x81B7 +#endif + +#ifndef GL_EXT_index_array_formats +#define GL_IUI_V2F_EXT 0x81AD +#define GL_IUI_V3F_EXT 0x81AE +#define GL_IUI_N3F_V2F_EXT 0x81AF +#define GL_IUI_N3F_V3F_EXT 0x81B0 +#define GL_T2F_IUI_V2F_EXT 0x81B1 +#define GL_T2F_IUI_V3F_EXT 0x81B2 +#define GL_T2F_IUI_N3F_V2F_EXT 0x81B3 +#define GL_T2F_IUI_N3F_V3F_EXT 0x81B4 +#endif + +#ifndef GL_EXT_compiled_vertex_array +#define GL_ARRAY_ELEMENT_LOCK_FIRST_EXT 0x81A8 +#define GL_ARRAY_ELEMENT_LOCK_COUNT_EXT 0x81A9 +#endif + +#ifndef GL_EXT_cull_vertex +#define GL_CULL_VERTEX_EXT 0x81AA +#define GL_CULL_VERTEX_EYE_POSITION_EXT 0x81AB +#define GL_CULL_VERTEX_OBJECT_POSITION_EXT 0x81AC +#endif + +#ifndef GL_SGIX_ycrcb +#define GL_YCRCB_422_SGIX 0x81BB +#define GL_YCRCB_444_SGIX 0x81BC +#endif + +#ifndef GL_SGIX_fragment_lighting +#define GL_FRAGMENT_LIGHTING_SGIX 0x8400 +#define GL_FRAGMENT_COLOR_MATERIAL_SGIX 0x8401 +#define GL_FRAGMENT_COLOR_MATERIAL_FACE_SGIX 0x8402 +#define GL_FRAGMENT_COLOR_MATERIAL_PARAMETER_SGIX 0x8403 +#define GL_MAX_FRAGMENT_LIGHTS_SGIX 0x8404 +#define GL_MAX_ACTIVE_LIGHTS_SGIX 0x8405 +#define GL_CURRENT_RASTER_NORMAL_SGIX 0x8406 +#define GL_LIGHT_ENV_MODE_SGIX 0x8407 +#define GL_FRAGMENT_LIGHT_MODEL_LOCAL_VIEWER_SGIX 0x8408 +#define GL_FRAGMENT_LIGHT_MODEL_TWO_SIDE_SGIX 0x8409 +#define GL_FRAGMENT_LIGHT_MODEL_AMBIENT_SGIX 0x840A +#define GL_FRAGMENT_LIGHT_MODEL_NORMAL_INTERPOLATION_SGIX 0x840B +#define GL_FRAGMENT_LIGHT0_SGIX 0x840C +#define GL_FRAGMENT_LIGHT1_SGIX 0x840D +#define GL_FRAGMENT_LIGHT2_SGIX 0x840E +#define GL_FRAGMENT_LIGHT3_SGIX 0x840F +#define GL_FRAGMENT_LIGHT4_SGIX 0x8410 +#define GL_FRAGMENT_LIGHT5_SGIX 0x8411 +#define GL_FRAGMENT_LIGHT6_SGIX 0x8412 +#define GL_FRAGMENT_LIGHT7_SGIX 0x8413 +#endif + +#ifndef GL_IBM_rasterpos_clip +#define GL_RASTER_POSITION_UNCLIPPED_IBM 0x19262 +#endif + +#ifndef GL_HP_texture_lighting +#define GL_TEXTURE_LIGHTING_MODE_HP 0x8167 +#define GL_TEXTURE_POST_SPECULAR_HP 0x8168 +#define GL_TEXTURE_PRE_SPECULAR_HP 0x8169 +#endif + +#ifndef GL_EXT_draw_range_elements +#define GL_MAX_ELEMENTS_VERTICES_EXT 0x80E8 +#define GL_MAX_ELEMENTS_INDICES_EXT 0x80E9 +#endif + +#ifndef GL_WIN_phong_shading +#define GL_PHONG_WIN 0x80EA +#define GL_PHONG_HINT_WIN 0x80EB +#endif + +#ifndef GL_WIN_specular_fog +#define GL_FOG_SPECULAR_TEXTURE_WIN 0x80EC +#endif + +#ifndef GL_EXT_light_texture +#define GL_FRAGMENT_MATERIAL_EXT 0x8349 +#define GL_FRAGMENT_NORMAL_EXT 0x834A +#define GL_FRAGMENT_COLOR_EXT 0x834C +#define GL_ATTENUATION_EXT 0x834D +#define GL_SHADOW_ATTENUATION_EXT 0x834E +#define GL_TEXTURE_APPLICATION_MODE_EXT 0x834F +#define GL_TEXTURE_LIGHT_EXT 0x8350 +#define GL_TEXTURE_MATERIAL_FACE_EXT 0x8351 +#define GL_TEXTURE_MATERIAL_PARAMETER_EXT 0x8352 +/* reuse GL_FRAGMENT_DEPTH_EXT */ +#endif + +#ifndef GL_SGIX_blend_alpha_minmax +#define GL_ALPHA_MIN_SGIX 0x8320 +#define GL_ALPHA_MAX_SGIX 0x8321 +#endif + +#ifndef GL_SGIX_impact_pixel_texture +#define GL_PIXEL_TEX_GEN_Q_CEILING_SGIX 0x8184 +#define GL_PIXEL_TEX_GEN_Q_ROUND_SGIX 0x8185 +#define GL_PIXEL_TEX_GEN_Q_FLOOR_SGIX 0x8186 +#define GL_PIXEL_TEX_GEN_ALPHA_REPLACE_SGIX 0x8187 +#define GL_PIXEL_TEX_GEN_ALPHA_NO_REPLACE_SGIX 0x8188 +#define GL_PIXEL_TEX_GEN_ALPHA_LS_SGIX 0x8189 +#define GL_PIXEL_TEX_GEN_ALPHA_MS_SGIX 0x818A +#endif + +#ifndef GL_EXT_bgra +#define GL_BGR_EXT 0x80E0 +#define GL_BGRA_EXT 0x80E1 +#endif + +#ifndef GL_SGIX_async +#define GL_ASYNC_MARKER_SGIX 0x8329 +#endif + +#ifndef GL_SGIX_async_pixel +#define GL_ASYNC_TEX_IMAGE_SGIX 0x835C +#define GL_ASYNC_DRAW_PIXELS_SGIX 0x835D +#define GL_ASYNC_READ_PIXELS_SGIX 0x835E +#define GL_MAX_ASYNC_TEX_IMAGE_SGIX 0x835F +#define GL_MAX_ASYNC_DRAW_PIXELS_SGIX 0x8360 +#define GL_MAX_ASYNC_READ_PIXELS_SGIX 0x8361 +#endif + +#ifndef GL_SGIX_async_histogram +#define GL_ASYNC_HISTOGRAM_SGIX 0x832C +#define GL_MAX_ASYNC_HISTOGRAM_SGIX 0x832D +#endif + +#ifndef GL_INTEL_texture_scissor +#endif + +#ifndef GL_INTEL_parallel_arrays +#define GL_PARALLEL_ARRAYS_INTEL 0x83F4 +#define GL_VERTEX_ARRAY_PARALLEL_POINTERS_INTEL 0x83F5 +#define GL_NORMAL_ARRAY_PARALLEL_POINTERS_INTEL 0x83F6 +#define GL_COLOR_ARRAY_PARALLEL_POINTERS_INTEL 0x83F7 +#define GL_TEXTURE_COORD_ARRAY_PARALLEL_POINTERS_INTEL 0x83F8 +#endif + +#ifndef GL_HP_occlusion_test +#define GL_OCCLUSION_TEST_HP 0x8165 +#define GL_OCCLUSION_TEST_RESULT_HP 0x8166 +#endif + +#ifndef GL_EXT_pixel_transform +#define GL_PIXEL_TRANSFORM_2D_EXT 0x8330 +#define GL_PIXEL_MAG_FILTER_EXT 0x8331 +#define GL_PIXEL_MIN_FILTER_EXT 0x8332 +#define GL_PIXEL_CUBIC_WEIGHT_EXT 0x8333 +#define GL_CUBIC_EXT 0x8334 +#define GL_AVERAGE_EXT 0x8335 +#define GL_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8336 +#define GL_MAX_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8337 +#define GL_PIXEL_TRANSFORM_2D_MATRIX_EXT 0x8338 +#endif + +#ifndef GL_EXT_pixel_transform_color_table +#endif + +#ifndef GL_EXT_shared_texture_palette +#define GL_SHARED_TEXTURE_PALETTE_EXT 0x81FB +#endif + +#ifndef GL_EXT_separate_specular_color +#define GL_LIGHT_MODEL_COLOR_CONTROL_EXT 0x81F8 +#define GL_SINGLE_COLOR_EXT 0x81F9 +#define GL_SEPARATE_SPECULAR_COLOR_EXT 0x81FA +#endif + +#ifndef GL_EXT_secondary_color +#define GL_COLOR_SUM_EXT 0x8458 +#define GL_CURRENT_SECONDARY_COLOR_EXT 0x8459 +#define GL_SECONDARY_COLOR_ARRAY_SIZE_EXT 0x845A +#define GL_SECONDARY_COLOR_ARRAY_TYPE_EXT 0x845B +#define GL_SECONDARY_COLOR_ARRAY_STRIDE_EXT 0x845C +#define GL_SECONDARY_COLOR_ARRAY_POINTER_EXT 0x845D +#define GL_SECONDARY_COLOR_ARRAY_EXT 0x845E +#endif + +#ifndef GL_EXT_texture_perturb_normal +#define GL_PERTURB_EXT 0x85AE +#define GL_TEXTURE_NORMAL_EXT 0x85AF +#endif + +#ifndef GL_EXT_multi_draw_arrays +#endif + +#ifndef GL_EXT_fog_coord +#define GL_FOG_COORDINATE_SOURCE_EXT 0x8450 +#define GL_FOG_COORDINATE_EXT 0x8451 +#define GL_FRAGMENT_DEPTH_EXT 0x8452 +#define GL_CURRENT_FOG_COORDINATE_EXT 0x8453 +#define GL_FOG_COORDINATE_ARRAY_TYPE_EXT 0x8454 +#define GL_FOG_COORDINATE_ARRAY_STRIDE_EXT 0x8455 +#define GL_FOG_COORDINATE_ARRAY_POINTER_EXT 0x8456 +#define GL_FOG_COORDINATE_ARRAY_EXT 0x8457 +#endif + +#ifndef GL_REND_screen_coordinates +#define GL_SCREEN_COORDINATES_REND 0x8490 +#define GL_INVERTED_SCREEN_W_REND 0x8491 +#endif + +#ifndef GL_EXT_coordinate_frame +#define GL_TANGENT_ARRAY_EXT 0x8439 +#define GL_BINORMAL_ARRAY_EXT 0x843A +#define GL_CURRENT_TANGENT_EXT 0x843B +#define GL_CURRENT_BINORMAL_EXT 0x843C +#define GL_TANGENT_ARRAY_TYPE_EXT 0x843E +#define GL_TANGENT_ARRAY_STRIDE_EXT 0x843F +#define GL_BINORMAL_ARRAY_TYPE_EXT 0x8440 +#define GL_BINORMAL_ARRAY_STRIDE_EXT 0x8441 +#define GL_TANGENT_ARRAY_POINTER_EXT 0x8442 +#define GL_BINORMAL_ARRAY_POINTER_EXT 0x8443 +#define GL_MAP1_TANGENT_EXT 0x8444 +#define GL_MAP2_TANGENT_EXT 0x8445 +#define GL_MAP1_BINORMAL_EXT 0x8446 +#define GL_MAP2_BINORMAL_EXT 0x8447 +#endif + +#ifndef GL_EXT_texture_env_combine +#define GL_COMBINE_EXT 0x8570 +#define GL_COMBINE_RGB_EXT 0x8571 +#define GL_COMBINE_ALPHA_EXT 0x8572 +#define GL_RGB_SCALE_EXT 0x8573 +#define GL_ADD_SIGNED_EXT 0x8574 +#define GL_INTERPOLATE_EXT 0x8575 +#define GL_CONSTANT_EXT 0x8576 +#define GL_PRIMARY_COLOR_EXT 0x8577 +#define GL_PREVIOUS_EXT 0x8578 +#define GL_SOURCE0_RGB_EXT 0x8580 +#define GL_SOURCE1_RGB_EXT 0x8581 +#define GL_SOURCE2_RGB_EXT 0x8582 +#define GL_SOURCE0_ALPHA_EXT 0x8588 +#define GL_SOURCE1_ALPHA_EXT 0x8589 +#define GL_SOURCE2_ALPHA_EXT 0x858A +#define GL_OPERAND0_RGB_EXT 0x8590 +#define GL_OPERAND1_RGB_EXT 0x8591 +#define GL_OPERAND2_RGB_EXT 0x8592 +#define GL_OPERAND0_ALPHA_EXT 0x8598 +#define GL_OPERAND1_ALPHA_EXT 0x8599 +#define GL_OPERAND2_ALPHA_EXT 0x859A +#endif + +#ifndef GL_APPLE_specular_vector +#define GL_LIGHT_MODEL_SPECULAR_VECTOR_APPLE 0x85B0 +#endif + +#ifndef GL_APPLE_transform_hint +#define GL_TRANSFORM_HINT_APPLE 0x85B1 +#endif + +#ifndef GL_SGIX_fog_scale +#define GL_FOG_SCALE_SGIX 0x81FC +#define GL_FOG_SCALE_VALUE_SGIX 0x81FD +#endif + +#ifndef GL_SUNX_constant_data +#define GL_UNPACK_CONSTANT_DATA_SUNX 0x81D5 +#define GL_TEXTURE_CONSTANT_DATA_SUNX 0x81D6 +#endif + +#ifndef GL_SUN_global_alpha +#define GL_GLOBAL_ALPHA_SUN 0x81D9 +#define GL_GLOBAL_ALPHA_FACTOR_SUN 0x81DA +#endif + +#ifndef GL_SUN_triangle_list +#define GL_RESTART_SUN 0x0001 +#define GL_REPLACE_MIDDLE_SUN 0x0002 +#define GL_REPLACE_OLDEST_SUN 0x0003 +#define GL_TRIANGLE_LIST_SUN 0x81D7 +#define GL_REPLACEMENT_CODE_SUN 0x81D8 +#define GL_REPLACEMENT_CODE_ARRAY_SUN 0x85C0 +#define GL_REPLACEMENT_CODE_ARRAY_TYPE_SUN 0x85C1 +#define GL_REPLACEMENT_CODE_ARRAY_STRIDE_SUN 0x85C2 +#define GL_REPLACEMENT_CODE_ARRAY_POINTER_SUN 0x85C3 +#define GL_R1UI_V3F_SUN 0x85C4 +#define GL_R1UI_C4UB_V3F_SUN 0x85C5 +#define GL_R1UI_C3F_V3F_SUN 0x85C6 +#define GL_R1UI_N3F_V3F_SUN 0x85C7 +#define GL_R1UI_C4F_N3F_V3F_SUN 0x85C8 +#define GL_R1UI_T2F_V3F_SUN 0x85C9 +#define GL_R1UI_T2F_N3F_V3F_SUN 0x85CA +#define GL_R1UI_T2F_C4F_N3F_V3F_SUN 0x85CB +#endif + +#ifndef GL_SUN_vertex +#endif + +#ifndef GL_EXT_blend_func_separate +#define GL_BLEND_DST_RGB_EXT 0x80C8 +#define GL_BLEND_SRC_RGB_EXT 0x80C9 +#define GL_BLEND_DST_ALPHA_EXT 0x80CA +#define GL_BLEND_SRC_ALPHA_EXT 0x80CB +#endif + +#ifndef GL_INGR_color_clamp +#define GL_RED_MIN_CLAMP_INGR 0x8560 +#define GL_GREEN_MIN_CLAMP_INGR 0x8561 +#define GL_BLUE_MIN_CLAMP_INGR 0x8562 +#define GL_ALPHA_MIN_CLAMP_INGR 0x8563 +#define GL_RED_MAX_CLAMP_INGR 0x8564 +#define GL_GREEN_MAX_CLAMP_INGR 0x8565 +#define GL_BLUE_MAX_CLAMP_INGR 0x8566 +#define GL_ALPHA_MAX_CLAMP_INGR 0x8567 +#endif + +#ifndef GL_INGR_interlace_read +#define GL_INTERLACE_READ_INGR 0x8568 +#endif + +#ifndef GL_EXT_stencil_wrap +#define GL_INCR_WRAP_EXT 0x8507 +#define GL_DECR_WRAP_EXT 0x8508 +#endif + +#ifndef GL_EXT_422_pixels +#define GL_422_EXT 0x80CC +#define GL_422_REV_EXT 0x80CD +#define GL_422_AVERAGE_EXT 0x80CE +#define GL_422_REV_AVERAGE_EXT 0x80CF +#endif + +#ifndef GL_NV_texgen_reflection +#define GL_NORMAL_MAP_NV 0x8511 +#define GL_REFLECTION_MAP_NV 0x8512 +#endif + +#ifndef GL_EXT_texture_cube_map +#define GL_NORMAL_MAP_EXT 0x8511 +#define GL_REFLECTION_MAP_EXT 0x8512 +#define GL_TEXTURE_CUBE_MAP_EXT 0x8513 +#define GL_TEXTURE_BINDING_CUBE_MAP_EXT 0x8514 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_EXT 0x8515 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_EXT 0x8516 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_EXT 0x8517 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_EXT 0x8518 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_EXT 0x8519 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_EXT 0x851A +#define GL_PROXY_TEXTURE_CUBE_MAP_EXT 0x851B +#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_EXT 0x851C +#endif + +#ifndef GL_SUN_convolution_border_modes +#define GL_WRAP_BORDER_SUN 0x81D4 +#endif + +#ifndef GL_EXT_texture_env_add +#endif + +#ifndef GL_EXT_texture_lod_bias +#define GL_MAX_TEXTURE_LOD_BIAS_EXT 0x84FD +#define GL_TEXTURE_FILTER_CONTROL_EXT 0x8500 +#define GL_TEXTURE_LOD_BIAS_EXT 0x8501 +#endif + +#ifndef GL_EXT_texture_filter_anisotropic +#define GL_TEXTURE_MAX_ANISOTROPY_EXT 0x84FE +#define GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT 0x84FF +#endif + +#ifndef GL_EXT_vertex_weighting +#define GL_MODELVIEW0_STACK_DEPTH_EXT GL_MODELVIEW_STACK_DEPTH +#define GL_MODELVIEW1_STACK_DEPTH_EXT 0x8502 +#define GL_MODELVIEW0_MATRIX_EXT GL_MODELVIEW_MATRIX +#define GL_MODELVIEW1_MATRIX_EXT 0x8506 +#define GL_VERTEX_WEIGHTING_EXT 0x8509 +#define GL_MODELVIEW0_EXT GL_MODELVIEW +#define GL_MODELVIEW1_EXT 0x850A +#define GL_CURRENT_VERTEX_WEIGHT_EXT 0x850B +#define GL_VERTEX_WEIGHT_ARRAY_EXT 0x850C +#define GL_VERTEX_WEIGHT_ARRAY_SIZE_EXT 0x850D +#define GL_VERTEX_WEIGHT_ARRAY_TYPE_EXT 0x850E +#define GL_VERTEX_WEIGHT_ARRAY_STRIDE_EXT 0x850F +#define GL_VERTEX_WEIGHT_ARRAY_POINTER_EXT 0x8510 +#endif + +#ifndef GL_NV_light_max_exponent +#define GL_MAX_SHININESS_NV 0x8504 +#define GL_MAX_SPOT_EXPONENT_NV 0x8505 +#endif + +#ifndef GL_NV_vertex_array_range +#define GL_VERTEX_ARRAY_RANGE_NV 0x851D +#define GL_VERTEX_ARRAY_RANGE_LENGTH_NV 0x851E +#define GL_VERTEX_ARRAY_RANGE_VALID_NV 0x851F +#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_NV 0x8520 +#define GL_VERTEX_ARRAY_RANGE_POINTER_NV 0x8521 +#endif + +#ifndef GL_NV_register_combiners +#define GL_REGISTER_COMBINERS_NV 0x8522 +#define GL_VARIABLE_A_NV 0x8523 +#define GL_VARIABLE_B_NV 0x8524 +#define GL_VARIABLE_C_NV 0x8525 +#define GL_VARIABLE_D_NV 0x8526 +#define GL_VARIABLE_E_NV 0x8527 +#define GL_VARIABLE_F_NV 0x8528 +#define GL_VARIABLE_G_NV 0x8529 +#define GL_CONSTANT_COLOR0_NV 0x852A +#define GL_CONSTANT_COLOR1_NV 0x852B +#define GL_PRIMARY_COLOR_NV 0x852C +#define GL_SECONDARY_COLOR_NV 0x852D +#define GL_SPARE0_NV 0x852E +#define GL_SPARE1_NV 0x852F +#define GL_DISCARD_NV 0x8530 +#define GL_E_TIMES_F_NV 0x8531 +#define GL_SPARE0_PLUS_SECONDARY_COLOR_NV 0x8532 +#define GL_UNSIGNED_IDENTITY_NV 0x8536 +#define GL_UNSIGNED_INVERT_NV 0x8537 +#define GL_EXPAND_NORMAL_NV 0x8538 +#define GL_EXPAND_NEGATE_NV 0x8539 +#define GL_HALF_BIAS_NORMAL_NV 0x853A +#define GL_HALF_BIAS_NEGATE_NV 0x853B +#define GL_SIGNED_IDENTITY_NV 0x853C +#define GL_SIGNED_NEGATE_NV 0x853D +#define GL_SCALE_BY_TWO_NV 0x853E +#define GL_SCALE_BY_FOUR_NV 0x853F +#define GL_SCALE_BY_ONE_HALF_NV 0x8540 +#define GL_BIAS_BY_NEGATIVE_ONE_HALF_NV 0x8541 +#define GL_COMBINER_INPUT_NV 0x8542 +#define GL_COMBINER_MAPPING_NV 0x8543 +#define GL_COMBINER_COMPONENT_USAGE_NV 0x8544 +#define GL_COMBINER_AB_DOT_PRODUCT_NV 0x8545 +#define GL_COMBINER_CD_DOT_PRODUCT_NV 0x8546 +#define GL_COMBINER_MUX_SUM_NV 0x8547 +#define GL_COMBINER_SCALE_NV 0x8548 +#define GL_COMBINER_BIAS_NV 0x8549 +#define GL_COMBINER_AB_OUTPUT_NV 0x854A +#define GL_COMBINER_CD_OUTPUT_NV 0x854B +#define GL_COMBINER_SUM_OUTPUT_NV 0x854C +#define GL_MAX_GENERAL_COMBINERS_NV 0x854D +#define GL_NUM_GENERAL_COMBINERS_NV 0x854E +#define GL_COLOR_SUM_CLAMP_NV 0x854F +#define GL_COMBINER0_NV 0x8550 +#define GL_COMBINER1_NV 0x8551 +#define GL_COMBINER2_NV 0x8552 +#define GL_COMBINER3_NV 0x8553 +#define GL_COMBINER4_NV 0x8554 +#define GL_COMBINER5_NV 0x8555 +#define GL_COMBINER6_NV 0x8556 +#define GL_COMBINER7_NV 0x8557 +/* reuse GL_TEXTURE0_ARB */ +/* reuse GL_TEXTURE1_ARB */ +/* reuse GL_ZERO */ +/* reuse GL_NONE */ +/* reuse GL_FOG */ +#endif + +#ifndef GL_NV_fog_distance +#define GL_FOG_DISTANCE_MODE_NV 0x855A +#define GL_EYE_RADIAL_NV 0x855B +#define GL_EYE_PLANE_ABSOLUTE_NV 0x855C +/* reuse GL_EYE_PLANE */ +#endif + +#ifndef GL_NV_texgen_emboss +#define GL_EMBOSS_LIGHT_NV 0x855D +#define GL_EMBOSS_CONSTANT_NV 0x855E +#define GL_EMBOSS_MAP_NV 0x855F +#endif + +#ifndef GL_NV_blend_square +#endif + +#ifndef GL_NV_texture_env_combine4 +#define GL_COMBINE4_NV 0x8503 +#define GL_SOURCE3_RGB_NV 0x8583 +#define GL_SOURCE3_ALPHA_NV 0x858B +#define GL_OPERAND3_RGB_NV 0x8593 +#define GL_OPERAND3_ALPHA_NV 0x859B +#endif + +#ifndef GL_MESA_resize_buffers +#endif + +#ifndef GL_MESA_window_pos +#endif + +#ifndef GL_EXT_texture_compression_s3tc +#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 +#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 +#define GL_COMPRESSED_RGBA_S3TC_DXT3_EXT 0x83F2 +#define GL_COMPRESSED_RGBA_S3TC_DXT5_EXT 0x83F3 +#endif + +#ifndef GL_IBM_cull_vertex +#define GL_CULL_VERTEX_IBM 103050 +#endif + +#ifndef GL_IBM_multimode_draw_arrays +#endif + +#ifndef GL_IBM_vertex_array_lists +#define GL_VERTEX_ARRAY_LIST_IBM 103070 +#define GL_NORMAL_ARRAY_LIST_IBM 103071 +#define GL_COLOR_ARRAY_LIST_IBM 103072 +#define GL_INDEX_ARRAY_LIST_IBM 103073 +#define GL_TEXTURE_COORD_ARRAY_LIST_IBM 103074 +#define GL_EDGE_FLAG_ARRAY_LIST_IBM 103075 +#define GL_FOG_COORDINATE_ARRAY_LIST_IBM 103076 +#define GL_SECONDARY_COLOR_ARRAY_LIST_IBM 103077 +#define GL_VERTEX_ARRAY_LIST_STRIDE_IBM 103080 +#define GL_NORMAL_ARRAY_LIST_STRIDE_IBM 103081 +#define GL_COLOR_ARRAY_LIST_STRIDE_IBM 103082 +#define GL_INDEX_ARRAY_LIST_STRIDE_IBM 103083 +#define GL_TEXTURE_COORD_ARRAY_LIST_STRIDE_IBM 103084 +#define GL_EDGE_FLAG_ARRAY_LIST_STRIDE_IBM 103085 +#define GL_FOG_COORDINATE_ARRAY_LIST_STRIDE_IBM 103086 +#define GL_SECONDARY_COLOR_ARRAY_LIST_STRIDE_IBM 103087 +#endif + +#ifndef GL_SGIX_subsample +#define GL_PACK_SUBSAMPLE_RATE_SGIX 0x85A0 +#define GL_UNPACK_SUBSAMPLE_RATE_SGIX 0x85A1 +#define GL_PIXEL_SUBSAMPLE_4444_SGIX 0x85A2 +#define GL_PIXEL_SUBSAMPLE_2424_SGIX 0x85A3 +#define GL_PIXEL_SUBSAMPLE_4242_SGIX 0x85A4 +#endif + +#ifndef GL_SGIX_ycrcb_subsample +#endif + +#ifndef GL_SGIX_ycrcba +#define GL_YCRCB_SGIX 0x8318 +#define GL_YCRCBA_SGIX 0x8319 +#endif + +#ifndef GL_SGI_depth_pass_instrument +#define GL_DEPTH_PASS_INSTRUMENT_SGIX 0x8310 +#define GL_DEPTH_PASS_INSTRUMENT_COUNTERS_SGIX 0x8311 +#define GL_DEPTH_PASS_INSTRUMENT_MAX_SGIX 0x8312 +#endif + +#ifndef GL_3DFX_texture_compression_FXT1 +#define GL_COMPRESSED_RGB_FXT1_3DFX 0x86B0 +#define GL_COMPRESSED_RGBA_FXT1_3DFX 0x86B1 +#endif + +#ifndef GL_3DFX_multisample +#define GL_MULTISAMPLE_3DFX 0x86B2 +#define GL_SAMPLE_BUFFERS_3DFX 0x86B3 +#define GL_SAMPLES_3DFX 0x86B4 +#define GL_MULTISAMPLE_BIT_3DFX 0x20000000 +#endif + +#ifndef GL_3DFX_tbuffer +#endif + +#ifndef GL_EXT_multisample +#define GL_MULTISAMPLE_EXT 0x809D +#define GL_SAMPLE_ALPHA_TO_MASK_EXT 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE_EXT 0x809F +#define GL_SAMPLE_MASK_EXT 0x80A0 +#define GL_1PASS_EXT 0x80A1 +#define GL_2PASS_0_EXT 0x80A2 +#define GL_2PASS_1_EXT 0x80A3 +#define GL_4PASS_0_EXT 0x80A4 +#define GL_4PASS_1_EXT 0x80A5 +#define GL_4PASS_2_EXT 0x80A6 +#define GL_4PASS_3_EXT 0x80A7 +#define GL_SAMPLE_BUFFERS_EXT 0x80A8 +#define GL_SAMPLES_EXT 0x80A9 +#define GL_SAMPLE_MASK_VALUE_EXT 0x80AA +#define GL_SAMPLE_MASK_INVERT_EXT 0x80AB +#define GL_SAMPLE_PATTERN_EXT 0x80AC +#define GL_MULTISAMPLE_BIT_EXT 0x20000000 +#endif + +#ifndef GL_SGIX_vertex_preclip +#define GL_VERTEX_PRECLIP_SGIX 0x83EE +#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF +#endif + +#ifndef GL_SGIX_convolution_accuracy +#define GL_CONVOLUTION_HINT_SGIX 0x8316 +#endif + +#ifndef GL_SGIX_resample +#define GL_PACK_RESAMPLE_SGIX 0x842C +#define GL_UNPACK_RESAMPLE_SGIX 0x842D +#define GL_RESAMPLE_REPLICATE_SGIX 0x842E +#define GL_RESAMPLE_ZERO_FILL_SGIX 0x842F +#define GL_RESAMPLE_DECIMATE_SGIX 0x8430 +#endif + +#ifndef GL_SGIS_point_line_texgen +#define GL_EYE_DISTANCE_TO_POINT_SGIS 0x81F0 +#define GL_OBJECT_DISTANCE_TO_POINT_SGIS 0x81F1 +#define GL_EYE_DISTANCE_TO_LINE_SGIS 0x81F2 +#define GL_OBJECT_DISTANCE_TO_LINE_SGIS 0x81F3 +#define GL_EYE_POINT_SGIS 0x81F4 +#define GL_OBJECT_POINT_SGIS 0x81F5 +#define GL_EYE_LINE_SGIS 0x81F6 +#define GL_OBJECT_LINE_SGIS 0x81F7 +#endif + +#ifndef GL_SGIS_texture_color_mask +#define GL_TEXTURE_COLOR_WRITEMASK_SGIS 0x81EF +#endif + +#ifndef GL_EXT_texture_env_dot3 +#define GL_DOT3_RGB_EXT 0x8740 +#define GL_DOT3_RGBA_EXT 0x8741 +#endif + +#ifndef GL_ATI_texture_mirror_once +#define GL_MIRROR_CLAMP_ATI 0x8742 +#define GL_MIRROR_CLAMP_TO_EDGE_ATI 0x8743 +#endif + +#ifndef GL_NV_fence +#define GL_ALL_COMPLETED_NV 0x84F2 +#define GL_FENCE_STATUS_NV 0x84F3 +#define GL_FENCE_CONDITION_NV 0x84F4 +#endif + +#ifndef GL_IBM_texture_mirrored_repeat +#define GL_MIRRORED_REPEAT_IBM 0x8370 +#endif + +#ifndef GL_NV_evaluators +#define GL_EVAL_2D_NV 0x86C0 +#define GL_EVAL_TRIANGULAR_2D_NV 0x86C1 +#define GL_MAP_TESSELLATION_NV 0x86C2 +#define GL_MAP_ATTRIB_U_ORDER_NV 0x86C3 +#define GL_MAP_ATTRIB_V_ORDER_NV 0x86C4 +#define GL_EVAL_FRACTIONAL_TESSELLATION_NV 0x86C5 +#define GL_EVAL_VERTEX_ATTRIB0_NV 0x86C6 +#define GL_EVAL_VERTEX_ATTRIB1_NV 0x86C7 +#define GL_EVAL_VERTEX_ATTRIB2_NV 0x86C8 +#define GL_EVAL_VERTEX_ATTRIB3_NV 0x86C9 +#define GL_EVAL_VERTEX_ATTRIB4_NV 0x86CA +#define GL_EVAL_VERTEX_ATTRIB5_NV 0x86CB +#define GL_EVAL_VERTEX_ATTRIB6_NV 0x86CC +#define GL_EVAL_VERTEX_ATTRIB7_NV 0x86CD +#define GL_EVAL_VERTEX_ATTRIB8_NV 0x86CE +#define GL_EVAL_VERTEX_ATTRIB9_NV 0x86CF +#define GL_EVAL_VERTEX_ATTRIB10_NV 0x86D0 +#define GL_EVAL_VERTEX_ATTRIB11_NV 0x86D1 +#define GL_EVAL_VERTEX_ATTRIB12_NV 0x86D2 +#define GL_EVAL_VERTEX_ATTRIB13_NV 0x86D3 +#define GL_EVAL_VERTEX_ATTRIB14_NV 0x86D4 +#define GL_EVAL_VERTEX_ATTRIB15_NV 0x86D5 +#define GL_MAX_MAP_TESSELLATION_NV 0x86D6 +#define GL_MAX_RATIONAL_EVAL_ORDER_NV 0x86D7 +#endif + +#ifndef GL_NV_packed_depth_stencil +#define GL_DEPTH_STENCIL_NV 0x84F9 +#define GL_UNSIGNED_INT_24_8_NV 0x84FA +#endif + +#ifndef GL_NV_register_combiners2 +#define GL_PER_STAGE_CONSTANTS_NV 0x8535 +#endif + +#ifndef GL_NV_texture_compression_vtc +#endif + +#ifndef GL_NV_texture_rectangle +#define GL_TEXTURE_RECTANGLE_NV 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE_NV 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE_NV 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE_NV 0x84F8 +#endif + +#ifndef GL_NV_texture_shader +#define GL_OFFSET_TEXTURE_RECTANGLE_NV 0x864C +#define GL_OFFSET_TEXTURE_RECTANGLE_SCALE_NV 0x864D +#define GL_DOT_PRODUCT_TEXTURE_RECTANGLE_NV 0x864E +#define GL_RGBA_UNSIGNED_DOT_PRODUCT_MAPPING_NV 0x86D9 +#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA +#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB +#define GL_DSDT_MAG_INTENSITY_NV 0x86DC +#define GL_SHADER_CONSISTENT_NV 0x86DD +#define GL_TEXTURE_SHADER_NV 0x86DE +#define GL_SHADER_OPERATION_NV 0x86DF +#define GL_CULL_MODES_NV 0x86E0 +#define GL_OFFSET_TEXTURE_MATRIX_NV 0x86E1 +#define GL_OFFSET_TEXTURE_SCALE_NV 0x86E2 +#define GL_OFFSET_TEXTURE_BIAS_NV 0x86E3 +#define GL_OFFSET_TEXTURE_2D_MATRIX_NV GL_OFFSET_TEXTURE_MATRIX_NV +#define GL_OFFSET_TEXTURE_2D_SCALE_NV GL_OFFSET_TEXTURE_SCALE_NV +#define GL_OFFSET_TEXTURE_2D_BIAS_NV GL_OFFSET_TEXTURE_BIAS_NV +#define GL_PREVIOUS_TEXTURE_INPUT_NV 0x86E4 +#define GL_CONST_EYE_NV 0x86E5 +#define GL_PASS_THROUGH_NV 0x86E6 +#define GL_CULL_FRAGMENT_NV 0x86E7 +#define GL_OFFSET_TEXTURE_2D_NV 0x86E8 +#define GL_DEPENDENT_AR_TEXTURE_2D_NV 0x86E9 +#define GL_DEPENDENT_GB_TEXTURE_2D_NV 0x86EA +#define GL_DOT_PRODUCT_NV 0x86EC +#define GL_DOT_PRODUCT_DEPTH_REPLACE_NV 0x86ED +#define GL_DOT_PRODUCT_TEXTURE_2D_NV 0x86EE +#define GL_DOT_PRODUCT_TEXTURE_CUBE_MAP_NV 0x86F0 +#define GL_DOT_PRODUCT_DIFFUSE_CUBE_MAP_NV 0x86F1 +#define GL_DOT_PRODUCT_REFLECT_CUBE_MAP_NV 0x86F2 +#define GL_DOT_PRODUCT_CONST_EYE_REFLECT_CUBE_MAP_NV 0x86F3 +#define GL_HILO_NV 0x86F4 +#define GL_DSDT_NV 0x86F5 +#define GL_DSDT_MAG_NV 0x86F6 +#define GL_DSDT_MAG_VIB_NV 0x86F7 +#define GL_HILO16_NV 0x86F8 +#define GL_SIGNED_HILO_NV 0x86F9 +#define GL_SIGNED_HILO16_NV 0x86FA +#define GL_SIGNED_RGBA_NV 0x86FB +#define GL_SIGNED_RGBA8_NV 0x86FC +#define GL_SIGNED_RGB_NV 0x86FE +#define GL_SIGNED_RGB8_NV 0x86FF +#define GL_SIGNED_LUMINANCE_NV 0x8701 +#define GL_SIGNED_LUMINANCE8_NV 0x8702 +#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 +#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 +#define GL_SIGNED_ALPHA_NV 0x8705 +#define GL_SIGNED_ALPHA8_NV 0x8706 +#define GL_SIGNED_INTENSITY_NV 0x8707 +#define GL_SIGNED_INTENSITY8_NV 0x8708 +#define GL_DSDT8_NV 0x8709 +#define GL_DSDT8_MAG8_NV 0x870A +#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B +#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C +#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D +#define GL_HI_SCALE_NV 0x870E +#define GL_LO_SCALE_NV 0x870F +#define GL_DS_SCALE_NV 0x8710 +#define GL_DT_SCALE_NV 0x8711 +#define GL_MAGNITUDE_SCALE_NV 0x8712 +#define GL_VIBRANCE_SCALE_NV 0x8713 +#define GL_HI_BIAS_NV 0x8714 +#define GL_LO_BIAS_NV 0x8715 +#define GL_DS_BIAS_NV 0x8716 +#define GL_DT_BIAS_NV 0x8717 +#define GL_MAGNITUDE_BIAS_NV 0x8718 +#define GL_VIBRANCE_BIAS_NV 0x8719 +#define GL_TEXTURE_BORDER_VALUES_NV 0x871A +#define GL_TEXTURE_HI_SIZE_NV 0x871B +#define GL_TEXTURE_LO_SIZE_NV 0x871C +#define GL_TEXTURE_DS_SIZE_NV 0x871D +#define GL_TEXTURE_DT_SIZE_NV 0x871E +#define GL_TEXTURE_MAG_SIZE_NV 0x871F +#endif + +#ifndef GL_NV_texture_shader2 +#define GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF +#endif + +#ifndef GL_NV_vertex_array_range2 +#define GL_VERTEX_ARRAY_RANGE_WITHOUT_FLUSH_NV 0x8533 +#endif + +#ifndef GL_NV_vertex_program +#define GL_VERTEX_PROGRAM_NV 0x8620 +#define GL_VERTEX_STATE_PROGRAM_NV 0x8621 +#define GL_ATTRIB_ARRAY_SIZE_NV 0x8623 +#define GL_ATTRIB_ARRAY_STRIDE_NV 0x8624 +#define GL_ATTRIB_ARRAY_TYPE_NV 0x8625 +#define GL_CURRENT_ATTRIB_NV 0x8626 +#define GL_PROGRAM_LENGTH_NV 0x8627 +#define GL_PROGRAM_STRING_NV 0x8628 +#define GL_MODELVIEW_PROJECTION_NV 0x8629 +#define GL_IDENTITY_NV 0x862A +#define GL_INVERSE_NV 0x862B +#define GL_TRANSPOSE_NV 0x862C +#define GL_INVERSE_TRANSPOSE_NV 0x862D +#define GL_MAX_TRACK_MATRIX_STACK_DEPTH_NV 0x862E +#define GL_MAX_TRACK_MATRICES_NV 0x862F +#define GL_MATRIX0_NV 0x8630 +#define GL_MATRIX1_NV 0x8631 +#define GL_MATRIX2_NV 0x8632 +#define GL_MATRIX3_NV 0x8633 +#define GL_MATRIX4_NV 0x8634 +#define GL_MATRIX5_NV 0x8635 +#define GL_MATRIX6_NV 0x8636 +#define GL_MATRIX7_NV 0x8637 +#define GL_CURRENT_MATRIX_STACK_DEPTH_NV 0x8640 +#define GL_CURRENT_MATRIX_NV 0x8641 +#define GL_VERTEX_PROGRAM_POINT_SIZE_NV 0x8642 +#define GL_VERTEX_PROGRAM_TWO_SIDE_NV 0x8643 +#define GL_PROGRAM_PARAMETER_NV 0x8644 +#define GL_ATTRIB_ARRAY_POINTER_NV 0x8645 +#define GL_PROGRAM_TARGET_NV 0x8646 +#define GL_PROGRAM_RESIDENT_NV 0x8647 +#define GL_TRACK_MATRIX_NV 0x8648 +#define GL_TRACK_MATRIX_TRANSFORM_NV 0x8649 +#define GL_VERTEX_PROGRAM_BINDING_NV 0x864A +#define GL_PROGRAM_ERROR_POSITION_NV 0x864B +#define GL_VERTEX_ATTRIB_ARRAY0_NV 0x8650 +#define GL_VERTEX_ATTRIB_ARRAY1_NV 0x8651 +#define GL_VERTEX_ATTRIB_ARRAY2_NV 0x8652 +#define GL_VERTEX_ATTRIB_ARRAY3_NV 0x8653 +#define GL_VERTEX_ATTRIB_ARRAY4_NV 0x8654 +#define GL_VERTEX_ATTRIB_ARRAY5_NV 0x8655 +#define GL_VERTEX_ATTRIB_ARRAY6_NV 0x8656 +#define GL_VERTEX_ATTRIB_ARRAY7_NV 0x8657 +#define GL_VERTEX_ATTRIB_ARRAY8_NV 0x8658 +#define GL_VERTEX_ATTRIB_ARRAY9_NV 0x8659 +#define GL_VERTEX_ATTRIB_ARRAY10_NV 0x865A +#define GL_VERTEX_ATTRIB_ARRAY11_NV 0x865B +#define GL_VERTEX_ATTRIB_ARRAY12_NV 0x865C +#define GL_VERTEX_ATTRIB_ARRAY13_NV 0x865D +#define GL_VERTEX_ATTRIB_ARRAY14_NV 0x865E +#define GL_VERTEX_ATTRIB_ARRAY15_NV 0x865F +#define GL_MAP1_VERTEX_ATTRIB0_4_NV 0x8660 +#define GL_MAP1_VERTEX_ATTRIB1_4_NV 0x8661 +#define GL_MAP1_VERTEX_ATTRIB2_4_NV 0x8662 +#define GL_MAP1_VERTEX_ATTRIB3_4_NV 0x8663 +#define GL_MAP1_VERTEX_ATTRIB4_4_NV 0x8664 +#define GL_MAP1_VERTEX_ATTRIB5_4_NV 0x8665 +#define GL_MAP1_VERTEX_ATTRIB6_4_NV 0x8666 +#define GL_MAP1_VERTEX_ATTRIB7_4_NV 0x8667 +#define GL_MAP1_VERTEX_ATTRIB8_4_NV 0x8668 +#define GL_MAP1_VERTEX_ATTRIB9_4_NV 0x8669 +#define GL_MAP1_VERTEX_ATTRIB10_4_NV 0x866A +#define GL_MAP1_VERTEX_ATTRIB11_4_NV 0x866B +#define GL_MAP1_VERTEX_ATTRIB12_4_NV 0x866C +#define GL_MAP1_VERTEX_ATTRIB13_4_NV 0x866D +#define GL_MAP1_VERTEX_ATTRIB14_4_NV 0x866E +#define GL_MAP1_VERTEX_ATTRIB15_4_NV 0x866F +#define GL_MAP2_VERTEX_ATTRIB0_4_NV 0x8670 +#define GL_MAP2_VERTEX_ATTRIB1_4_NV 0x8671 +#define GL_MAP2_VERTEX_ATTRIB2_4_NV 0x8672 +#define GL_MAP2_VERTEX_ATTRIB3_4_NV 0x8673 +#define GL_MAP2_VERTEX_ATTRIB4_4_NV 0x8674 +#define GL_MAP2_VERTEX_ATTRIB5_4_NV 0x8675 +#define GL_MAP2_VERTEX_ATTRIB6_4_NV 0x8676 +#define GL_MAP2_VERTEX_ATTRIB7_4_NV 0x8677 +#define GL_MAP2_VERTEX_ATTRIB8_4_NV 0x8678 +#define GL_MAP2_VERTEX_ATTRIB9_4_NV 0x8679 +#define GL_MAP2_VERTEX_ATTRIB10_4_NV 0x867A +#define GL_MAP2_VERTEX_ATTRIB11_4_NV 0x867B +#define GL_MAP2_VERTEX_ATTRIB12_4_NV 0x867C +#define GL_MAP2_VERTEX_ATTRIB13_4_NV 0x867D +#define GL_MAP2_VERTEX_ATTRIB14_4_NV 0x867E +#define GL_MAP2_VERTEX_ATTRIB15_4_NV 0x867F +#endif + +#ifndef GL_SGIX_texture_coordinate_clamp +#define GL_TEXTURE_MAX_CLAMP_S_SGIX 0x8369 +#define GL_TEXTURE_MAX_CLAMP_T_SGIX 0x836A +#define GL_TEXTURE_MAX_CLAMP_R_SGIX 0x836B +#endif + +#ifndef GL_SGIX_scalebias_hint +#define GL_SCALEBIAS_HINT_SGIX 0x8322 +#endif + +#ifndef GL_OML_interlace +#define GL_INTERLACE_OML 0x8980 +#define GL_INTERLACE_READ_OML 0x8981 +#endif + +#ifndef GL_OML_subsample +#define GL_FORMAT_SUBSAMPLE_24_24_OML 0x8982 +#define GL_FORMAT_SUBSAMPLE_244_244_OML 0x8983 +#endif + +#ifndef GL_OML_resample +#define GL_PACK_RESAMPLE_OML 0x8984 +#define GL_UNPACK_RESAMPLE_OML 0x8985 +#define GL_RESAMPLE_REPLICATE_OML 0x8986 +#define GL_RESAMPLE_ZERO_FILL_OML 0x8987 +#define GL_RESAMPLE_AVERAGE_OML 0x8988 +#define GL_RESAMPLE_DECIMATE_OML 0x8989 +#endif + +#ifndef GL_NV_copy_depth_to_color +#define GL_DEPTH_STENCIL_TO_RGBA_NV 0x886E +#define GL_DEPTH_STENCIL_TO_BGRA_NV 0x886F +#endif + +#ifndef GL_ATI_envmap_bumpmap +#define GL_BUMP_ROT_MATRIX_ATI 0x8775 +#define GL_BUMP_ROT_MATRIX_SIZE_ATI 0x8776 +#define GL_BUMP_NUM_TEX_UNITS_ATI 0x8777 +#define GL_BUMP_TEX_UNITS_ATI 0x8778 +#define GL_DUDV_ATI 0x8779 +#define GL_DU8DV8_ATI 0x877A +#define GL_BUMP_ENVMAP_ATI 0x877B +#define GL_BUMP_TARGET_ATI 0x877C +#endif + +#ifndef GL_ATI_fragment_shader +#define GL_FRAGMENT_SHADER_ATI 0x8920 +#define GL_REG_0_ATI 0x8921 +#define GL_REG_1_ATI 0x8922 +#define GL_REG_2_ATI 0x8923 +#define GL_REG_3_ATI 0x8924 +#define GL_REG_4_ATI 0x8925 +#define GL_REG_5_ATI 0x8926 +#define GL_REG_6_ATI 0x8927 +#define GL_REG_7_ATI 0x8928 +#define GL_REG_8_ATI 0x8929 +#define GL_REG_9_ATI 0x892A +#define GL_REG_10_ATI 0x892B +#define GL_REG_11_ATI 0x892C +#define GL_REG_12_ATI 0x892D +#define GL_REG_13_ATI 0x892E +#define GL_REG_14_ATI 0x892F +#define GL_REG_15_ATI 0x8930 +#define GL_REG_16_ATI 0x8931 +#define GL_REG_17_ATI 0x8932 +#define GL_REG_18_ATI 0x8933 +#define GL_REG_19_ATI 0x8934 +#define GL_REG_20_ATI 0x8935 +#define GL_REG_21_ATI 0x8936 +#define GL_REG_22_ATI 0x8937 +#define GL_REG_23_ATI 0x8938 +#define GL_REG_24_ATI 0x8939 +#define GL_REG_25_ATI 0x893A +#define GL_REG_26_ATI 0x893B +#define GL_REG_27_ATI 0x893C +#define GL_REG_28_ATI 0x893D +#define GL_REG_29_ATI 0x893E +#define GL_REG_30_ATI 0x893F +#define GL_REG_31_ATI 0x8940 +#define GL_CON_0_ATI 0x8941 +#define GL_CON_1_ATI 0x8942 +#define GL_CON_2_ATI 0x8943 +#define GL_CON_3_ATI 0x8944 +#define GL_CON_4_ATI 0x8945 +#define GL_CON_5_ATI 0x8946 +#define GL_CON_6_ATI 0x8947 +#define GL_CON_7_ATI 0x8948 +#define GL_CON_8_ATI 0x8949 +#define GL_CON_9_ATI 0x894A +#define GL_CON_10_ATI 0x894B +#define GL_CON_11_ATI 0x894C +#define GL_CON_12_ATI 0x894D +#define GL_CON_13_ATI 0x894E +#define GL_CON_14_ATI 0x894F +#define GL_CON_15_ATI 0x8950 +#define GL_CON_16_ATI 0x8951 +#define GL_CON_17_ATI 0x8952 +#define GL_CON_18_ATI 0x8953 +#define GL_CON_19_ATI 0x8954 +#define GL_CON_20_ATI 0x8955 +#define GL_CON_21_ATI 0x8956 +#define GL_CON_22_ATI 0x8957 +#define GL_CON_23_ATI 0x8958 +#define GL_CON_24_ATI 0x8959 +#define GL_CON_25_ATI 0x895A +#define GL_CON_26_ATI 0x895B +#define GL_CON_27_ATI 0x895C +#define GL_CON_28_ATI 0x895D +#define GL_CON_29_ATI 0x895E +#define GL_CON_30_ATI 0x895F +#define GL_CON_31_ATI 0x8960 +#define GL_MOV_ATI 0x8961 +#define GL_ADD_ATI 0x8963 +#define GL_MUL_ATI 0x8964 +#define GL_SUB_ATI 0x8965 +#define GL_DOT3_ATI 0x8966 +#define GL_DOT4_ATI 0x8967 +#define GL_MAD_ATI 0x8968 +#define GL_LERP_ATI 0x8969 +#define GL_CND_ATI 0x896A +#define GL_CND0_ATI 0x896B +#define GL_DOT2_ADD_ATI 0x896C +#define GL_SECONDARY_INTERPOLATOR_ATI 0x896D +#define GL_NUM_FRAGMENT_REGISTERS_ATI 0x896E +#define GL_NUM_FRAGMENT_CONSTANTS_ATI 0x896F +#define GL_NUM_PASSES_ATI 0x8970 +#define GL_NUM_INSTRUCTIONS_PER_PASS_ATI 0x8971 +#define GL_NUM_INSTRUCTIONS_TOTAL_ATI 0x8972 +#define GL_NUM_INPUT_INTERPOLATOR_COMPONENTS_ATI 0x8973 +#define GL_NUM_LOOPBACK_COMPONENTS_ATI 0x8974 +#define GL_COLOR_ALPHA_PAIRING_ATI 0x8975 +#define GL_SWIZZLE_STR_ATI 0x8976 +#define GL_SWIZZLE_STQ_ATI 0x8977 +#define GL_SWIZZLE_STR_DR_ATI 0x8978 +#define GL_SWIZZLE_STQ_DQ_ATI 0x8979 +#define GL_SWIZZLE_STRQ_ATI 0x897A +#define GL_SWIZZLE_STRQ_DQ_ATI 0x897B +#define GL_RED_BIT_ATI 0x00000001 +#define GL_GREEN_BIT_ATI 0x00000002 +#define GL_BLUE_BIT_ATI 0x00000004 +#define GL_2X_BIT_ATI 0x00000001 +#define GL_4X_BIT_ATI 0x00000002 +#define GL_8X_BIT_ATI 0x00000004 +#define GL_HALF_BIT_ATI 0x00000008 +#define GL_QUARTER_BIT_ATI 0x00000010 +#define GL_EIGHTH_BIT_ATI 0x00000020 +#define GL_SATURATE_BIT_ATI 0x00000040 +#define GL_COMP_BIT_ATI 0x00000002 +#define GL_NEGATE_BIT_ATI 0x00000004 +#define GL_BIAS_BIT_ATI 0x00000008 +#endif + +#ifndef GL_ATI_pn_triangles +#define GL_PN_TRIANGLES_ATI 0x87F0 +#define GL_MAX_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F1 +#define GL_PN_TRIANGLES_POINT_MODE_ATI 0x87F2 +#define GL_PN_TRIANGLES_NORMAL_MODE_ATI 0x87F3 +#define GL_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F4 +#define GL_PN_TRIANGLES_POINT_MODE_LINEAR_ATI 0x87F5 +#define GL_PN_TRIANGLES_POINT_MODE_CUBIC_ATI 0x87F6 +#define GL_PN_TRIANGLES_NORMAL_MODE_LINEAR_ATI 0x87F7 +#define GL_PN_TRIANGLES_NORMAL_MODE_QUADRATIC_ATI 0x87F8 +#endif + +#ifndef GL_ATI_vertex_array_object +#define GL_STATIC_ATI 0x8760 +#define GL_DYNAMIC_ATI 0x8761 +#define GL_PRESERVE_ATI 0x8762 +#define GL_DISCARD_ATI 0x8763 +#define GL_OBJECT_BUFFER_SIZE_ATI 0x8764 +#define GL_OBJECT_BUFFER_USAGE_ATI 0x8765 +#define GL_ARRAY_OBJECT_BUFFER_ATI 0x8766 +#define GL_ARRAY_OBJECT_OFFSET_ATI 0x8767 +#endif + +#ifndef GL_EXT_vertex_shader +#define GL_VERTEX_SHADER_EXT 0x8780 +#define GL_VERTEX_SHADER_BINDING_EXT 0x8781 +#define GL_OP_INDEX_EXT 0x8782 +#define GL_OP_NEGATE_EXT 0x8783 +#define GL_OP_DOT3_EXT 0x8784 +#define GL_OP_DOT4_EXT 0x8785 +#define GL_OP_MUL_EXT 0x8786 +#define GL_OP_ADD_EXT 0x8787 +#define GL_OP_MADD_EXT 0x8788 +#define GL_OP_FRAC_EXT 0x8789 +#define GL_OP_MAX_EXT 0x878A +#define GL_OP_MIN_EXT 0x878B +#define GL_OP_SET_GE_EXT 0x878C +#define GL_OP_SET_LT_EXT 0x878D +#define GL_OP_CLAMP_EXT 0x878E +#define GL_OP_FLOOR_EXT 0x878F +#define GL_OP_ROUND_EXT 0x8790 +#define GL_OP_EXP_BASE_2_EXT 0x8791 +#define GL_OP_LOG_BASE_2_EXT 0x8792 +#define GL_OP_POWER_EXT 0x8793 +#define GL_OP_RECIP_EXT 0x8794 +#define GL_OP_RECIP_SQRT_EXT 0x8795 +#define GL_OP_SUB_EXT 0x8796 +#define GL_OP_CROSS_PRODUCT_EXT 0x8797 +#define GL_OP_MULTIPLY_MATRIX_EXT 0x8798 +#define GL_OP_MOV_EXT 0x8799 +#define GL_OUTPUT_VERTEX_EXT 0x879A +#define GL_OUTPUT_COLOR0_EXT 0x879B +#define GL_OUTPUT_COLOR1_EXT 0x879C +#define GL_OUTPUT_TEXTURE_COORD0_EXT 0x879D +#define GL_OUTPUT_TEXTURE_COORD1_EXT 0x879E +#define GL_OUTPUT_TEXTURE_COORD2_EXT 0x879F +#define GL_OUTPUT_TEXTURE_COORD3_EXT 0x87A0 +#define GL_OUTPUT_TEXTURE_COORD4_EXT 0x87A1 +#define GL_OUTPUT_TEXTURE_COORD5_EXT 0x87A2 +#define GL_OUTPUT_TEXTURE_COORD6_EXT 0x87A3 +#define GL_OUTPUT_TEXTURE_COORD7_EXT 0x87A4 +#define GL_OUTPUT_TEXTURE_COORD8_EXT 0x87A5 +#define GL_OUTPUT_TEXTURE_COORD9_EXT 0x87A6 +#define GL_OUTPUT_TEXTURE_COORD10_EXT 0x87A7 +#define GL_OUTPUT_TEXTURE_COORD11_EXT 0x87A8 +#define GL_OUTPUT_TEXTURE_COORD12_EXT 0x87A9 +#define GL_OUTPUT_TEXTURE_COORD13_EXT 0x87AA +#define GL_OUTPUT_TEXTURE_COORD14_EXT 0x87AB +#define GL_OUTPUT_TEXTURE_COORD15_EXT 0x87AC +#define GL_OUTPUT_TEXTURE_COORD16_EXT 0x87AD +#define GL_OUTPUT_TEXTURE_COORD17_EXT 0x87AE +#define GL_OUTPUT_TEXTURE_COORD18_EXT 0x87AF +#define GL_OUTPUT_TEXTURE_COORD19_EXT 0x87B0 +#define GL_OUTPUT_TEXTURE_COORD20_EXT 0x87B1 +#define GL_OUTPUT_TEXTURE_COORD21_EXT 0x87B2 +#define GL_OUTPUT_TEXTURE_COORD22_EXT 0x87B3 +#define GL_OUTPUT_TEXTURE_COORD23_EXT 0x87B4 +#define GL_OUTPUT_TEXTURE_COORD24_EXT 0x87B5 +#define GL_OUTPUT_TEXTURE_COORD25_EXT 0x87B6 +#define GL_OUTPUT_TEXTURE_COORD26_EXT 0x87B7 +#define GL_OUTPUT_TEXTURE_COORD27_EXT 0x87B8 +#define GL_OUTPUT_TEXTURE_COORD28_EXT 0x87B9 +#define GL_OUTPUT_TEXTURE_COORD29_EXT 0x87BA +#define GL_OUTPUT_TEXTURE_COORD30_EXT 0x87BB +#define GL_OUTPUT_TEXTURE_COORD31_EXT 0x87BC +#define GL_OUTPUT_FOG_EXT 0x87BD +#define GL_SCALAR_EXT 0x87BE +#define GL_VECTOR_EXT 0x87BF +#define GL_MATRIX_EXT 0x87C0 +#define GL_VARIANT_EXT 0x87C1 +#define GL_INVARIANT_EXT 0x87C2 +#define GL_LOCAL_CONSTANT_EXT 0x87C3 +#define GL_LOCAL_EXT 0x87C4 +#define GL_MAX_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87C5 +#define GL_MAX_VERTEX_SHADER_VARIANTS_EXT 0x87C6 +#define GL_MAX_VERTEX_SHADER_INVARIANTS_EXT 0x87C7 +#define GL_MAX_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87C8 +#define GL_MAX_VERTEX_SHADER_LOCALS_EXT 0x87C9 +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CA +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_VARIANTS_EXT 0x87CB +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87CC +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INVARIANTS_EXT 0x87CD +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCALS_EXT 0x87CE +#define GL_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CF +#define GL_VERTEX_SHADER_VARIANTS_EXT 0x87D0 +#define GL_VERTEX_SHADER_INVARIANTS_EXT 0x87D1 +#define GL_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87D2 +#define GL_VERTEX_SHADER_LOCALS_EXT 0x87D3 +#define GL_VERTEX_SHADER_OPTIMIZED_EXT 0x87D4 +#define GL_X_EXT 0x87D5 +#define GL_Y_EXT 0x87D6 +#define GL_Z_EXT 0x87D7 +#define GL_W_EXT 0x87D8 +#define GL_NEGATIVE_X_EXT 0x87D9 +#define GL_NEGATIVE_Y_EXT 0x87DA +#define GL_NEGATIVE_Z_EXT 0x87DB +#define GL_NEGATIVE_W_EXT 0x87DC +#define GL_ZERO_EXT 0x87DD +#define GL_ONE_EXT 0x87DE +#define GL_NEGATIVE_ONE_EXT 0x87DF +#define GL_NORMALIZED_RANGE_EXT 0x87E0 +#define GL_FULL_RANGE_EXT 0x87E1 +#define GL_CURRENT_VERTEX_EXT 0x87E2 +#define GL_MVP_MATRIX_EXT 0x87E3 +#define GL_VARIANT_VALUE_EXT 0x87E4 +#define GL_VARIANT_DATATYPE_EXT 0x87E5 +#define GL_VARIANT_ARRAY_STRIDE_EXT 0x87E6 +#define GL_VARIANT_ARRAY_TYPE_EXT 0x87E7 +#define GL_VARIANT_ARRAY_EXT 0x87E8 +#define GL_VARIANT_ARRAY_POINTER_EXT 0x87E9 +#define GL_INVARIANT_VALUE_EXT 0x87EA +#define GL_INVARIANT_DATATYPE_EXT 0x87EB +#define GL_LOCAL_CONSTANT_VALUE_EXT 0x87EC +#define GL_LOCAL_CONSTANT_DATATYPE_EXT 0x87ED +#endif + +#ifndef GL_ATI_vertex_streams +#define GL_MAX_VERTEX_STREAMS_ATI 0x876B +#define GL_VERTEX_STREAM0_ATI 0x876C +#define GL_VERTEX_STREAM1_ATI 0x876D +#define GL_VERTEX_STREAM2_ATI 0x876E +#define GL_VERTEX_STREAM3_ATI 0x876F +#define GL_VERTEX_STREAM4_ATI 0x8770 +#define GL_VERTEX_STREAM5_ATI 0x8771 +#define GL_VERTEX_STREAM6_ATI 0x8772 +#define GL_VERTEX_STREAM7_ATI 0x8773 +#define GL_VERTEX_SOURCE_ATI 0x8774 +#endif + +#ifndef GL_ATI_element_array +#define GL_ELEMENT_ARRAY_ATI 0x8768 +#define GL_ELEMENT_ARRAY_TYPE_ATI 0x8769 +#define GL_ELEMENT_ARRAY_POINTER_ATI 0x876A +#endif + +#ifndef GL_SUN_mesh_array +#define GL_QUAD_MESH_SUN 0x8614 +#define GL_TRIANGLE_MESH_SUN 0x8615 +#endif + +#ifndef GL_SUN_slice_accum +#define GL_SLICE_ACCUM_SUN 0x85CC +#endif + +#ifndef GL_NV_multisample_filter_hint +#define GL_MULTISAMPLE_FILTER_HINT_NV 0x8534 +#endif + +#ifndef GL_NV_depth_clamp +#define GL_DEPTH_CLAMP_NV 0x864F +#endif + +#ifndef GL_NV_occlusion_query +#define GL_PIXEL_COUNTER_BITS_NV 0x8864 +#define GL_CURRENT_OCCLUSION_QUERY_ID_NV 0x8865 +#define GL_PIXEL_COUNT_NV 0x8866 +#define GL_PIXEL_COUNT_AVAILABLE_NV 0x8867 +#endif + +#ifndef GL_NV_point_sprite +#define GL_POINT_SPRITE_NV 0x8861 +#define GL_COORD_REPLACE_NV 0x8862 +#define GL_POINT_SPRITE_R_MODE_NV 0x8863 +#endif + +#ifndef GL_NV_texture_shader3 +#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_NV 0x8850 +#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_SCALE_NV 0x8851 +#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8852 +#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_SCALE_NV 0x8853 +#define GL_OFFSET_HILO_TEXTURE_2D_NV 0x8854 +#define GL_OFFSET_HILO_TEXTURE_RECTANGLE_NV 0x8855 +#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_2D_NV 0x8856 +#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8857 +#define GL_DEPENDENT_HILO_TEXTURE_2D_NV 0x8858 +#define GL_DEPENDENT_RGB_TEXTURE_3D_NV 0x8859 +#define GL_DEPENDENT_RGB_TEXTURE_CUBE_MAP_NV 0x885A +#define GL_DOT_PRODUCT_PASS_THROUGH_NV 0x885B +#define GL_DOT_PRODUCT_TEXTURE_1D_NV 0x885C +#define GL_DOT_PRODUCT_AFFINE_DEPTH_REPLACE_NV 0x885D +#define GL_HILO8_NV 0x885E +#define GL_SIGNED_HILO8_NV 0x885F +#define GL_FORCE_BLUE_TO_ONE_NV 0x8860 +#endif + +#ifndef GL_NV_vertex_program1_1 +#endif + +#ifndef GL_EXT_shadow_funcs +#endif + +#ifndef GL_EXT_stencil_two_side +#define GL_STENCIL_TEST_TWO_SIDE_EXT 0x8910 +#define GL_ACTIVE_STENCIL_FACE_EXT 0x8911 +#endif + +#ifndef GL_ATI_text_fragment_shader +#define GL_TEXT_FRAGMENT_SHADER_ATI 0x8200 +#endif + +#ifndef GL_APPLE_client_storage +#define GL_UNPACK_CLIENT_STORAGE_APPLE 0x85B2 +#endif + +#ifndef GL_APPLE_element_array +#define GL_ELEMENT_ARRAY_APPLE 0x8768 +#define GL_ELEMENT_ARRAY_TYPE_APPLE 0x8769 +#define GL_ELEMENT_ARRAY_POINTER_APPLE 0x876A +#endif + +#ifndef GL_APPLE_fence +#define GL_DRAW_PIXELS_APPLE 0x8A0A +#define GL_FENCE_APPLE 0x8A0B +#endif + +#ifndef GL_APPLE_vertex_array_object +#define GL_VERTEX_ARRAY_BINDING_APPLE 0x85B5 +#endif + +#ifndef GL_APPLE_vertex_array_range +#define GL_VERTEX_ARRAY_RANGE_APPLE 0x851D +#define GL_VERTEX_ARRAY_RANGE_LENGTH_APPLE 0x851E +#define GL_VERTEX_ARRAY_STORAGE_HINT_APPLE 0x851F +#define GL_VERTEX_ARRAY_RANGE_POINTER_APPLE 0x8521 +#define GL_STORAGE_CACHED_APPLE 0x85BE +#define GL_STORAGE_SHARED_APPLE 0x85BF +#endif + +#ifndef GL_APPLE_ycbcr_422 +#define GL_YCBCR_422_APPLE 0x85B9 +#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA +#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB +#endif + +#ifndef GL_S3_s3tc +#define GL_RGB_S3TC 0x83A0 +#define GL_RGB4_S3TC 0x83A1 +#define GL_RGBA_S3TC 0x83A2 +#define GL_RGBA4_S3TC 0x83A3 +#endif + +#ifndef GL_ATI_draw_buffers +#define GL_MAX_DRAW_BUFFERS_ATI 0x8824 +#define GL_DRAW_BUFFER0_ATI 0x8825 +#define GL_DRAW_BUFFER1_ATI 0x8826 +#define GL_DRAW_BUFFER2_ATI 0x8827 +#define GL_DRAW_BUFFER3_ATI 0x8828 +#define GL_DRAW_BUFFER4_ATI 0x8829 +#define GL_DRAW_BUFFER5_ATI 0x882A +#define GL_DRAW_BUFFER6_ATI 0x882B +#define GL_DRAW_BUFFER7_ATI 0x882C +#define GL_DRAW_BUFFER8_ATI 0x882D +#define GL_DRAW_BUFFER9_ATI 0x882E +#define GL_DRAW_BUFFER10_ATI 0x882F +#define GL_DRAW_BUFFER11_ATI 0x8830 +#define GL_DRAW_BUFFER12_ATI 0x8831 +#define GL_DRAW_BUFFER13_ATI 0x8832 +#define GL_DRAW_BUFFER14_ATI 0x8833 +#define GL_DRAW_BUFFER15_ATI 0x8834 +#endif + +#ifndef GL_ATI_pixel_format_float +#define GL_TYPE_RGBA_FLOAT_ATI 0x8820 +#define GL_COLOR_CLEAR_UNCLAMPED_VALUE_ATI 0x8835 +#endif + +#ifndef GL_ATI_texture_env_combine3 +#define GL_MODULATE_ADD_ATI 0x8744 +#define GL_MODULATE_SIGNED_ADD_ATI 0x8745 +#define GL_MODULATE_SUBTRACT_ATI 0x8746 +#endif + +#ifndef GL_ATI_texture_float +#define GL_RGBA_FLOAT32_ATI 0x8814 +#define GL_RGB_FLOAT32_ATI 0x8815 +#define GL_ALPHA_FLOAT32_ATI 0x8816 +#define GL_INTENSITY_FLOAT32_ATI 0x8817 +#define GL_LUMINANCE_FLOAT32_ATI 0x8818 +#define GL_LUMINANCE_ALPHA_FLOAT32_ATI 0x8819 +#define GL_RGBA_FLOAT16_ATI 0x881A +#define GL_RGB_FLOAT16_ATI 0x881B +#define GL_ALPHA_FLOAT16_ATI 0x881C +#define GL_INTENSITY_FLOAT16_ATI 0x881D +#define GL_LUMINANCE_FLOAT16_ATI 0x881E +#define GL_LUMINANCE_ALPHA_FLOAT16_ATI 0x881F +#endif + +#ifndef GL_NV_float_buffer +#define GL_FLOAT_R_NV 0x8880 +#define GL_FLOAT_RG_NV 0x8881 +#define GL_FLOAT_RGB_NV 0x8882 +#define GL_FLOAT_RGBA_NV 0x8883 +#define GL_FLOAT_R16_NV 0x8884 +#define GL_FLOAT_R32_NV 0x8885 +#define GL_FLOAT_RG16_NV 0x8886 +#define GL_FLOAT_RG32_NV 0x8887 +#define GL_FLOAT_RGB16_NV 0x8888 +#define GL_FLOAT_RGB32_NV 0x8889 +#define GL_FLOAT_RGBA16_NV 0x888A +#define GL_FLOAT_RGBA32_NV 0x888B +#define GL_TEXTURE_FLOAT_COMPONENTS_NV 0x888C +#define GL_FLOAT_CLEAR_COLOR_VALUE_NV 0x888D +#define GL_FLOAT_RGBA_MODE_NV 0x888E +#endif + +#ifndef GL_NV_fragment_program +#define GL_MAX_FRAGMENT_PROGRAM_LOCAL_PARAMETERS_NV 0x8868 +#define GL_FRAGMENT_PROGRAM_NV 0x8870 +#define GL_MAX_TEXTURE_COORDS_NV 0x8871 +#define GL_MAX_TEXTURE_IMAGE_UNITS_NV 0x8872 +#define GL_FRAGMENT_PROGRAM_BINDING_NV 0x8873 +#define GL_PROGRAM_ERROR_STRING_NV 0x8874 +#endif + +#ifndef GL_NV_half_float +#define GL_HALF_FLOAT_NV 0x140B +#endif + +#ifndef GL_NV_pixel_data_range +#define GL_WRITE_PIXEL_DATA_RANGE_NV 0x8878 +#define GL_READ_PIXEL_DATA_RANGE_NV 0x8879 +#define GL_WRITE_PIXEL_DATA_RANGE_LENGTH_NV 0x887A +#define GL_READ_PIXEL_DATA_RANGE_LENGTH_NV 0x887B +#define GL_WRITE_PIXEL_DATA_RANGE_POINTER_NV 0x887C +#define GL_READ_PIXEL_DATA_RANGE_POINTER_NV 0x887D +#endif + +#ifndef GL_NV_primitive_restart +#define GL_PRIMITIVE_RESTART_NV 0x8558 +#define GL_PRIMITIVE_RESTART_INDEX_NV 0x8559 +#endif + +#ifndef GL_NV_texture_expand_normal +#define GL_TEXTURE_UNSIGNED_REMAP_MODE_NV 0x888F +#endif + +#ifndef GL_NV_vertex_program2 +#endif + +#ifndef GL_ATI_map_object_buffer +#endif + +#ifndef GL_ATI_separate_stencil +#define GL_STENCIL_BACK_FUNC_ATI 0x8800 +#define GL_STENCIL_BACK_FAIL_ATI 0x8801 +#define GL_STENCIL_BACK_PASS_DEPTH_FAIL_ATI 0x8802 +#define GL_STENCIL_BACK_PASS_DEPTH_PASS_ATI 0x8803 +#endif + +#ifndef GL_ATI_vertex_attrib_array_object +#endif + +#ifndef GL_OES_read_format +#define GL_IMPLEMENTATION_COLOR_READ_TYPE_OES 0x8B9A +#define GL_IMPLEMENTATION_COLOR_READ_FORMAT_OES 0x8B9B +#endif + +#ifndef GL_EXT_depth_bounds_test +#define GL_DEPTH_BOUNDS_TEST_EXT 0x8890 +#define GL_DEPTH_BOUNDS_EXT 0x8891 +#endif + +#ifndef GL_EXT_texture_mirror_clamp +#define GL_MIRROR_CLAMP_EXT 0x8742 +#define GL_MIRROR_CLAMP_TO_EDGE_EXT 0x8743 +#define GL_MIRROR_CLAMP_TO_BORDER_EXT 0x8912 +#endif + +#ifndef GL_EXT_blend_equation_separate +#define GL_BLEND_EQUATION_RGB_EXT GL_BLEND_EQUATION +#define GL_BLEND_EQUATION_ALPHA_EXT 0x883D +#endif + +#ifndef GL_MESA_pack_invert +#define GL_PACK_INVERT_MESA 0x8758 +#endif + +#ifndef GL_MESA_ycbcr_texture +#define GL_UNSIGNED_SHORT_8_8_MESA 0x85BA +#define GL_UNSIGNED_SHORT_8_8_REV_MESA 0x85BB +#define GL_YCBCR_MESA 0x8757 +#endif + +#ifndef GL_EXT_pixel_buffer_object +#define GL_PIXEL_PACK_BUFFER_EXT 0x88EB +#define GL_PIXEL_UNPACK_BUFFER_EXT 0x88EC +#define GL_PIXEL_PACK_BUFFER_BINDING_EXT 0x88ED +#define GL_PIXEL_UNPACK_BUFFER_BINDING_EXT 0x88EF +#endif + +#ifndef GL_NV_fragment_program_option +#endif + +#ifndef GL_NV_fragment_program2 +#define GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 +#define GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 +#define GL_MAX_PROGRAM_IF_DEPTH_NV 0x88F6 +#define GL_MAX_PROGRAM_LOOP_DEPTH_NV 0x88F7 +#define GL_MAX_PROGRAM_LOOP_COUNT_NV 0x88F8 +#endif + +#ifndef GL_NV_vertex_program2_option +/* reuse GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV */ +/* reuse GL_MAX_PROGRAM_CALL_DEPTH_NV */ +#endif + +#ifndef GL_NV_vertex_program3 +/* reuse GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB */ +#endif + +#ifndef GL_EXT_framebuffer_object +#define GL_INVALID_FRAMEBUFFER_OPERATION_EXT 0x0506 +#define GL_MAX_RENDERBUFFER_SIZE_EXT 0x84E8 +#define GL_FRAMEBUFFER_BINDING_EXT 0x8CA6 +#define GL_RENDERBUFFER_BINDING_EXT 0x8CA7 +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE_EXT 0x8CD0 +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME_EXT 0x8CD1 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL_EXT 0x8CD2 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE_EXT 0x8CD3 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET_EXT 0x8CD4 +#define GL_FRAMEBUFFER_COMPLETE_EXT 0x8CD5 +#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT_EXT 0x8CD6 +#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT_EXT 0x8CD7 +#define GL_FRAMEBUFFER_INCOMPLETE_DUPLICATE_ATTACHMENT_EXT 0x8CD8 +#define GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS_EXT 0x8CD9 +#define GL_FRAMEBUFFER_INCOMPLETE_FORMATS_EXT 0x8CDA +#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER_EXT 0x8CDB +#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER_EXT 0x8CDC +#define GL_FRAMEBUFFER_UNSUPPORTED_EXT 0x8CDD +#define GL_MAX_COLOR_ATTACHMENTS_EXT 0x8CDF +#define GL_COLOR_ATTACHMENT0_EXT 0x8CE0 +#define GL_COLOR_ATTACHMENT1_EXT 0x8CE1 +#define GL_COLOR_ATTACHMENT2_EXT 0x8CE2 +#define GL_COLOR_ATTACHMENT3_EXT 0x8CE3 +#define GL_COLOR_ATTACHMENT4_EXT 0x8CE4 +#define GL_COLOR_ATTACHMENT5_EXT 0x8CE5 +#define GL_COLOR_ATTACHMENT6_EXT 0x8CE6 +#define GL_COLOR_ATTACHMENT7_EXT 0x8CE7 +#define GL_COLOR_ATTACHMENT8_EXT 0x8CE8 +#define GL_COLOR_ATTACHMENT9_EXT 0x8CE9 +#define GL_COLOR_ATTACHMENT10_EXT 0x8CEA +#define GL_COLOR_ATTACHMENT11_EXT 0x8CEB +#define GL_COLOR_ATTACHMENT12_EXT 0x8CEC +#define GL_COLOR_ATTACHMENT13_EXT 0x8CED +#define GL_COLOR_ATTACHMENT14_EXT 0x8CEE +#define GL_COLOR_ATTACHMENT15_EXT 0x8CEF +#define GL_DEPTH_ATTACHMENT_EXT 0x8D00 +#define GL_STENCIL_ATTACHMENT_EXT 0x8D20 +#define GL_FRAMEBUFFER_EXT 0x8D40 +#define GL_RENDERBUFFER_EXT 0x8D41 +#define GL_RENDERBUFFER_WIDTH_EXT 0x8D42 +#define GL_RENDERBUFFER_HEIGHT_EXT 0x8D43 +#define GL_RENDERBUFFER_INTERNAL_FORMAT_EXT 0x8D44 +#define GL_STENCIL_INDEX1_EXT 0x8D46 +#define GL_STENCIL_INDEX4_EXT 0x8D47 +#define GL_STENCIL_INDEX8_EXT 0x8D48 +#define GL_STENCIL_INDEX16_EXT 0x8D49 +#define GL_RENDERBUFFER_RED_SIZE_EXT 0x8D50 +#define GL_RENDERBUFFER_GREEN_SIZE_EXT 0x8D51 +#define GL_RENDERBUFFER_BLUE_SIZE_EXT 0x8D52 +#define GL_RENDERBUFFER_ALPHA_SIZE_EXT 0x8D53 +#define GL_RENDERBUFFER_DEPTH_SIZE_EXT 0x8D54 +#define GL_RENDERBUFFER_STENCIL_SIZE_EXT 0x8D55 +#endif + +#ifndef GL_GREMEDY_string_marker +#endif + + +/*************************************************************/ + +#include +#ifndef GL_VERSION_2_0 +/* GL type for program/shader text */ +typedef char GLchar; /* native character */ +#endif + +#ifndef GL_VERSION_1_5 +/* GL types for handling large vertex buffer objects */ +typedef ptrdiff_t GLintptr; +typedef ptrdiff_t GLsizeiptr; +#endif + +#ifndef GL_ARB_vertex_buffer_object +/* GL types for handling large vertex buffer objects */ +typedef ptrdiff_t GLintptrARB; +typedef ptrdiff_t GLsizeiptrARB; +#endif + +#ifndef GL_ARB_shader_objects +/* GL types for handling shader object handles and program/shader text */ +typedef char GLcharARB; /* native character */ +typedef unsigned int GLhandleARB; /* shader object handle */ +#endif + +/* GL types for "half" precision (s10e5) float data in host memory */ +#ifndef GL_ARB_half_float_pixel +typedef unsigned short GLhalfARB; +#endif + +#ifndef GL_NV_half_float +typedef unsigned short GLhalfNV; +#endif + +#ifndef GL_VERSION_1_2 +#define GL_VERSION_1_2 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendColor (GLclampf, GLclampf, GLclampf, GLclampf); +GLAPI void APIENTRY glBlendEquation (GLenum); +GLAPI void APIENTRY glDrawRangeElements (GLenum, GLuint, GLuint, GLsizei, GLenum, const GLvoid *); +GLAPI void APIENTRY glColorTable (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glColorTableParameterfv (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glColorTableParameteriv (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glCopyColorTable (GLenum, GLenum, GLint, GLint, GLsizei); +GLAPI void APIENTRY glGetColorTable (GLenum, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetColorTableParameterfv (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetColorTableParameteriv (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glColorSubTable (GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glCopyColorSubTable (GLenum, GLsizei, GLint, GLint, GLsizei); +GLAPI void APIENTRY glConvolutionFilter1D (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glConvolutionFilter2D (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glConvolutionParameterf (GLenum, GLenum, GLfloat); +GLAPI void APIENTRY glConvolutionParameterfv (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glConvolutionParameteri (GLenum, GLenum, GLint); +GLAPI void APIENTRY glConvolutionParameteriv (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glCopyConvolutionFilter1D (GLenum, GLenum, GLint, GLint, GLsizei); +GLAPI void APIENTRY glCopyConvolutionFilter2D (GLenum, GLenum, GLint, GLint, GLsizei, GLsizei); +GLAPI void APIENTRY glGetConvolutionFilter (GLenum, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetConvolutionParameterfv (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetConvolutionParameteriv (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetSeparableFilter (GLenum, GLenum, GLenum, GLvoid *, GLvoid *, GLvoid *); +GLAPI void APIENTRY glSeparableFilter2D (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *, const GLvoid *); +GLAPI void APIENTRY glGetHistogram (GLenum, GLboolean, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetHistogramParameterfv (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetHistogramParameteriv (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetMinmax (GLenum, GLboolean, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetMinmaxParameterfv (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetMinmaxParameteriv (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glHistogram (GLenum, GLsizei, GLenum, GLboolean); +GLAPI void APIENTRY glMinmax (GLenum, GLenum, GLboolean); +GLAPI void APIENTRY glResetHistogram (GLenum); +GLAPI void APIENTRY glResetMinmax (GLenum); +GLAPI void APIENTRY glTexImage3D (GLenum, GLint, GLint, GLsizei, GLsizei, GLsizei, GLint, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glTexSubImage3D (GLenum, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glCopyTexSubImage3D (GLenum, GLint, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDCOLORPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +typedef void (APIENTRYP PFNGLBLENDEQUATIONPROC) (GLenum mode); +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); +typedef void (APIENTRYP PFNGLCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOPYCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFPROC) (GLenum target, GLenum pname, GLfloat params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIPROC) (GLenum target, GLenum pname, GLint params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSEPARABLEFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); +typedef void (APIENTRYP PFNGLSEPARABLEFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMINMAXPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLHISTOGRAMPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLMINMAXPROC) (GLenum target, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLRESETHISTOGRAMPROC) (GLenum target); +typedef void (APIENTRYP PFNGLRESETMINMAXPROC) (GLenum target); +typedef void (APIENTRYP PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +typedef void (APIENTRYP PFNGLTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +#endif + +#ifndef GL_VERSION_1_3 +#define GL_VERSION_1_3 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glActiveTexture (GLenum); +GLAPI void APIENTRY glClientActiveTexture (GLenum); +GLAPI void APIENTRY glMultiTexCoord1d (GLenum, GLdouble); +GLAPI void APIENTRY glMultiTexCoord1dv (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord1f (GLenum, GLfloat); +GLAPI void APIENTRY glMultiTexCoord1fv (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord1i (GLenum, GLint); +GLAPI void APIENTRY glMultiTexCoord1iv (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord1s (GLenum, GLshort); +GLAPI void APIENTRY glMultiTexCoord1sv (GLenum, const GLshort *); +GLAPI void APIENTRY glMultiTexCoord2d (GLenum, GLdouble, GLdouble); +GLAPI void APIENTRY glMultiTexCoord2dv (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord2f (GLenum, GLfloat, GLfloat); +GLAPI void APIENTRY glMultiTexCoord2fv (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord2i (GLenum, GLint, GLint); +GLAPI void APIENTRY glMultiTexCoord2iv (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord2s (GLenum, GLshort, GLshort); +GLAPI void APIENTRY glMultiTexCoord2sv (GLenum, const GLshort *); +GLAPI void APIENTRY glMultiTexCoord3d (GLenum, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glMultiTexCoord3dv (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord3f (GLenum, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glMultiTexCoord3fv (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord3i (GLenum, GLint, GLint, GLint); +GLAPI void APIENTRY glMultiTexCoord3iv (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord3s (GLenum, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glMultiTexCoord3sv (GLenum, const GLshort *); +GLAPI void APIENTRY glMultiTexCoord4d (GLenum, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glMultiTexCoord4dv (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord4f (GLenum, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glMultiTexCoord4fv (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord4i (GLenum, GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glMultiTexCoord4iv (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord4s (GLenum, GLshort, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glMultiTexCoord4sv (GLenum, const GLshort *); +GLAPI void APIENTRY glLoadTransposeMatrixf (const GLfloat *); +GLAPI void APIENTRY glLoadTransposeMatrixd (const GLdouble *); +GLAPI void APIENTRY glMultTransposeMatrixf (const GLfloat *); +GLAPI void APIENTRY glMultTransposeMatrixd (const GLdouble *); +GLAPI void APIENTRY glSampleCoverage (GLclampf, GLboolean); +GLAPI void APIENTRY glCompressedTexImage3D (GLenum, GLint, GLenum, GLsizei, GLsizei, GLsizei, GLint, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexImage2D (GLenum, GLint, GLenum, GLsizei, GLsizei, GLint, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexImage1D (GLenum, GLint, GLenum, GLsizei, GLint, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexSubImage3D (GLenum, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexSubImage2D (GLenum, GLint, GLint, GLint, GLsizei, GLsizei, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexSubImage1D (GLenum, GLint, GLint, GLsizei, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glGetCompressedTexImage (GLenum, GLint, GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLACTIVETEXTUREPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLCLIENTACTIVETEXTUREPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DPROC) (GLenum target, GLdouble s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FPROC) (GLenum target, GLfloat s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IPROC) (GLenum target, GLint s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SPROC) (GLenum target, GLshort s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DPROC) (GLenum target, GLdouble s, GLdouble t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FPROC) (GLenum target, GLfloat s, GLfloat t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IPROC) (GLenum target, GLint s, GLint t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SPROC) (GLenum target, GLshort s, GLshort t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IPROC) (GLenum target, GLint s, GLint t, GLint r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SPROC) (GLenum target, GLshort s, GLshort t, GLshort r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXFPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXDPROC) (const GLdouble *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXFPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXDPROC) (const GLdouble *m); +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLGETCOMPRESSEDTEXIMAGEPROC) (GLenum target, GLint level, GLvoid *img); +#endif + +#ifndef GL_VERSION_1_4 +#define GL_VERSION_1_4 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendFuncSeparate (GLenum, GLenum, GLenum, GLenum); +GLAPI void APIENTRY glFogCoordf (GLfloat); +GLAPI void APIENTRY glFogCoordfv (const GLfloat *); +GLAPI void APIENTRY glFogCoordd (GLdouble); +GLAPI void APIENTRY glFogCoorddv (const GLdouble *); +GLAPI void APIENTRY glFogCoordPointer (GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glMultiDrawArrays (GLenum, GLint *, GLsizei *, GLsizei); +GLAPI void APIENTRY glMultiDrawElements (GLenum, const GLsizei *, GLenum, const GLvoid* *, GLsizei); +GLAPI void APIENTRY glPointParameterf (GLenum, GLfloat); +GLAPI void APIENTRY glPointParameterfv (GLenum, const GLfloat *); +GLAPI void APIENTRY glPointParameteri (GLenum, GLint); +GLAPI void APIENTRY glPointParameteriv (GLenum, const GLint *); +GLAPI void APIENTRY glSecondaryColor3b (GLbyte, GLbyte, GLbyte); +GLAPI void APIENTRY glSecondaryColor3bv (const GLbyte *); +GLAPI void APIENTRY glSecondaryColor3d (GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glSecondaryColor3dv (const GLdouble *); +GLAPI void APIENTRY glSecondaryColor3f (GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glSecondaryColor3fv (const GLfloat *); +GLAPI void APIENTRY glSecondaryColor3i (GLint, GLint, GLint); +GLAPI void APIENTRY glSecondaryColor3iv (const GLint *); +GLAPI void APIENTRY glSecondaryColor3s (GLshort, GLshort, GLshort); +GLAPI void APIENTRY glSecondaryColor3sv (const GLshort *); +GLAPI void APIENTRY glSecondaryColor3ub (GLubyte, GLubyte, GLubyte); +GLAPI void APIENTRY glSecondaryColor3ubv (const GLubyte *); +GLAPI void APIENTRY glSecondaryColor3ui (GLuint, GLuint, GLuint); +GLAPI void APIENTRY glSecondaryColor3uiv (const GLuint *); +GLAPI void APIENTRY glSecondaryColor3us (GLushort, GLushort, GLushort); +GLAPI void APIENTRY glSecondaryColor3usv (const GLushort *); +GLAPI void APIENTRY glSecondaryColorPointer (GLint, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glWindowPos2d (GLdouble, GLdouble); +GLAPI void APIENTRY glWindowPos2dv (const GLdouble *); +GLAPI void APIENTRY glWindowPos2f (GLfloat, GLfloat); +GLAPI void APIENTRY glWindowPos2fv (const GLfloat *); +GLAPI void APIENTRY glWindowPos2i (GLint, GLint); +GLAPI void APIENTRY glWindowPos2iv (const GLint *); +GLAPI void APIENTRY glWindowPos2s (GLshort, GLshort); +GLAPI void APIENTRY glWindowPos2sv (const GLshort *); +GLAPI void APIENTRY glWindowPos3d (GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glWindowPos3dv (const GLdouble *); +GLAPI void APIENTRY glWindowPos3f (GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glWindowPos3fv (const GLfloat *); +GLAPI void APIENTRY glWindowPos3i (GLint, GLint, GLint); +GLAPI void APIENTRY glWindowPos3iv (const GLint *); +GLAPI void APIENTRY glWindowPos3s (GLshort, GLshort, GLshort); +GLAPI void APIENTRY glWindowPos3sv (const GLshort *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +typedef void (APIENTRYP PFNGLFOGCOORDFPROC) (GLfloat coord); +typedef void (APIENTRYP PFNGLFOGCOORDFVPROC) (const GLfloat *coord); +typedef void (APIENTRYP PFNGLFOGCOORDDPROC) (GLdouble coord); +typedef void (APIENTRYP PFNGLFOGCOORDDVPROC) (const GLdouble *coord); +typedef void (APIENTRYP PFNGLFOGCOORDPOINTERPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSPROC) (GLenum mode, GLint *first, GLsizei *count, GLsizei primcount); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLPOINTPARAMETERIPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERIVPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BPROC) (GLbyte red, GLbyte green, GLbyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BVPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DPROC) (GLdouble red, GLdouble green, GLdouble blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DVPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FPROC) (GLfloat red, GLfloat green, GLfloat blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FVPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IPROC) (GLint red, GLint green, GLint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IVPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SPROC) (GLshort red, GLshort green, GLshort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SVPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBPROC) (GLubyte red, GLubyte green, GLubyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBVPROC) (const GLubyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIPROC) (GLuint red, GLuint green, GLuint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIVPROC) (const GLuint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USPROC) (GLushort red, GLushort green, GLushort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USVPROC) (const GLushort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLORPOINTERPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLWINDOWPOS2DPROC) (GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLWINDOWPOS2DVPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2FPROC) (GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLWINDOWPOS2FVPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2IPROC) (GLint x, GLint y); +typedef void (APIENTRYP PFNGLWINDOWPOS2IVPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2SPROC) (GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLWINDOWPOS2SVPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3DPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLWINDOWPOS3DVPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3FPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLWINDOWPOS3FVPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3IPROC) (GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLWINDOWPOS3IVPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3SPROC) (GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLWINDOWPOS3SVPROC) (const GLshort *v); +#endif + +#ifndef GL_VERSION_1_5 +#define GL_VERSION_1_5 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenQueries (GLsizei, GLuint *); +GLAPI void APIENTRY glDeleteQueries (GLsizei, const GLuint *); +GLAPI GLboolean APIENTRY glIsQuery (GLuint); +GLAPI void APIENTRY glBeginQuery (GLenum, GLuint); +GLAPI void APIENTRY glEndQuery (GLenum); +GLAPI void APIENTRY glGetQueryiv (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetQueryObjectiv (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetQueryObjectuiv (GLuint, GLenum, GLuint *); +GLAPI void APIENTRY glBindBuffer (GLenum, GLuint); +GLAPI void APIENTRY glDeleteBuffers (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenBuffers (GLsizei, GLuint *); +GLAPI GLboolean APIENTRY glIsBuffer (GLuint); +GLAPI void APIENTRY glBufferData (GLenum, GLsizeiptr, const GLvoid *, GLenum); +GLAPI void APIENTRY glBufferSubData (GLenum, GLintptr, GLsizeiptr, const GLvoid *); +GLAPI void APIENTRY glGetBufferSubData (GLenum, GLintptr, GLsizeiptr, GLvoid *); +GLAPI GLvoid* APIENTRY glMapBuffer (GLenum, GLenum); +GLAPI GLboolean APIENTRY glUnmapBuffer (GLenum); +GLAPI void APIENTRY glGetBufferParameteriv (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetBufferPointerv (GLenum, GLenum, GLvoid* *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGENQUERIESPROC) (GLsizei n, GLuint *ids); +typedef void (APIENTRYP PFNGLDELETEQUERIESPROC) (GLsizei n, const GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISQUERYPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINQUERYPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLENDQUERYPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETQUERYIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTIVPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTUIVPROC) (GLuint id, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLBINDBUFFERPROC) (GLenum target, GLuint buffer); +typedef void (APIENTRYP PFNGLDELETEBUFFERSPROC) (GLsizei n, const GLuint *buffers); +typedef void (APIENTRYP PFNGLGENBUFFERSPROC) (GLsizei n, GLuint *buffers); +typedef GLboolean (APIENTRYP PFNGLISBUFFERPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLBUFFERDATAPROC) (GLenum target, GLsizeiptr size, const GLvoid *data, GLenum usage); +typedef void (APIENTRYP PFNGLBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, const GLvoid *data); +typedef void (APIENTRYP PFNGLGETBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, GLvoid *data); +typedef GLvoid* (APIENTRYP PFNGLMAPBUFFERPROC) (GLenum target, GLenum access); +typedef GLboolean (APIENTRYP PFNGLUNMAPBUFFERPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETBUFFERPOINTERVPROC) (GLenum target, GLenum pname, GLvoid* *params); +#endif + +#ifndef GL_VERSION_2_0 +#define GL_VERSION_2_0 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendEquationSeparate (GLenum, GLenum); +GLAPI void APIENTRY glDrawBuffers (GLsizei, const GLenum *); +GLAPI void APIENTRY glStencilOpSeparate (GLenum, GLenum, GLenum, GLenum); +GLAPI void APIENTRY glStencilFuncSeparate (GLenum, GLenum, GLint, GLuint); +GLAPI void APIENTRY glStencilMaskSeparate (GLenum, GLuint); +GLAPI void APIENTRY glAttachShader (GLuint, GLuint); +GLAPI void APIENTRY glBindAttribLocation (GLuint, GLuint, const GLchar *); +GLAPI void APIENTRY glCompileShader (GLuint); +GLAPI GLuint APIENTRY glCreateProgram (void); +GLAPI GLuint APIENTRY glCreateShader (GLenum); +GLAPI void APIENTRY glDeleteProgram (GLuint); +GLAPI void APIENTRY glDeleteShader (GLuint); +GLAPI void APIENTRY glDetachShader (GLuint, GLuint); +GLAPI void APIENTRY glDisableVertexAttribArray (GLuint); +GLAPI void APIENTRY glEnableVertexAttribArray (GLuint); +GLAPI void APIENTRY glGetActiveAttrib (GLuint, GLuint, GLsizei, GLsizei *, GLint *, GLenum *, GLchar *); +GLAPI void APIENTRY glGetActiveUniform (GLuint, GLuint, GLsizei, GLsizei *, GLint *, GLenum *, GLchar *); +GLAPI void APIENTRY glGetAttachedShaders (GLuint, GLsizei, GLsizei *, GLuint *); +GLAPI GLint APIENTRY glGetAttribLocation (GLuint, const GLchar *); +GLAPI void APIENTRY glGetProgramiv (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetProgramInfoLog (GLuint, GLsizei, GLsizei *, GLchar *); +GLAPI void APIENTRY glGetShaderiv (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetShaderInfoLog (GLuint, GLsizei, GLsizei *, GLchar *); +GLAPI void APIENTRY glGetShaderSource (GLuint, GLsizei, GLsizei *, GLchar *); +GLAPI GLint APIENTRY glGetUniformLocation (GLuint, const GLchar *); +GLAPI void APIENTRY glGetUniformfv (GLuint, GLint, GLfloat *); +GLAPI void APIENTRY glGetUniformiv (GLuint, GLint, GLint *); +GLAPI void APIENTRY glGetVertexAttribdv (GLuint, GLenum, GLdouble *); +GLAPI void APIENTRY glGetVertexAttribfv (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetVertexAttribiv (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetVertexAttribPointerv (GLuint, GLenum, GLvoid* *); +GLAPI GLboolean APIENTRY glIsProgram (GLuint); +GLAPI GLboolean APIENTRY glIsShader (GLuint); +GLAPI void APIENTRY glLinkProgram (GLuint); +GLAPI void APIENTRY glShaderSource (GLuint, GLsizei, const GLchar* *, const GLint *); +GLAPI void APIENTRY glUseProgram (GLuint); +GLAPI void APIENTRY glUniform1f (GLint, GLfloat); +GLAPI void APIENTRY glUniform2f (GLint, GLfloat, GLfloat); +GLAPI void APIENTRY glUniform3f (GLint, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glUniform4f (GLint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glUniform1i (GLint, GLint); +GLAPI void APIENTRY glUniform2i (GLint, GLint, GLint); +GLAPI void APIENTRY glUniform3i (GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glUniform4i (GLint, GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glUniform1fv (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform2fv (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform3fv (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform4fv (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform1iv (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniform2iv (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniform3iv (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniform4iv (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniformMatrix2fv (GLint, GLsizei, GLboolean, const GLfloat *); +GLAPI void APIENTRY glUniformMatrix3fv (GLint, GLsizei, GLboolean, const GLfloat *); +GLAPI void APIENTRY glUniformMatrix4fv (GLint, GLsizei, GLboolean, const GLfloat *); +GLAPI void APIENTRY glValidateProgram (GLuint); +GLAPI void APIENTRY glVertexAttrib1d (GLuint, GLdouble); +GLAPI void APIENTRY glVertexAttrib1dv (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib1f (GLuint, GLfloat); +GLAPI void APIENTRY glVertexAttrib1fv (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib1s (GLuint, GLshort); +GLAPI void APIENTRY glVertexAttrib1sv (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib2d (GLuint, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib2dv (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib2f (GLuint, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib2fv (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib2s (GLuint, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib2sv (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib3d (GLuint, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib3dv (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib3f (GLuint, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib3fv (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib3s (GLuint, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib3sv (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4Nbv (GLuint, const GLbyte *); +GLAPI void APIENTRY glVertexAttrib4Niv (GLuint, const GLint *); +GLAPI void APIENTRY glVertexAttrib4Nsv (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4Nub (GLuint, GLubyte, GLubyte, GLubyte, GLubyte); +GLAPI void APIENTRY glVertexAttrib4Nubv (GLuint, const GLubyte *); +GLAPI void APIENTRY glVertexAttrib4Nuiv (GLuint, const GLuint *); +GLAPI void APIENTRY glVertexAttrib4Nusv (GLuint, const GLushort *); +GLAPI void APIENTRY glVertexAttrib4bv (GLuint, const GLbyte *); +GLAPI void APIENTRY glVertexAttrib4d (GLuint, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib4dv (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib4f (GLuint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib4fv (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib4iv (GLuint, const GLint *); +GLAPI void APIENTRY glVertexAttrib4s (GLuint, GLshort, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib4sv (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4ubv (GLuint, const GLubyte *); +GLAPI void APIENTRY glVertexAttrib4uiv (GLuint, const GLuint *); +GLAPI void APIENTRY glVertexAttrib4usv (GLuint, const GLushort *); +GLAPI void APIENTRY glVertexAttribPointer (GLuint, GLint, GLenum, GLboolean, GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEPROC) (GLenum modeRGB, GLenum modeAlpha); +typedef void (APIENTRYP PFNGLDRAWBUFFERSPROC) (GLsizei n, const GLenum *bufs); +typedef void (APIENTRYP PFNGLSTENCILOPSEPARATEPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +typedef void (APIENTRYP PFNGLSTENCILFUNCSEPARATEPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); +typedef void (APIENTRYP PFNGLSTENCILMASKSEPARATEPROC) (GLenum face, GLuint mask); +typedef void (APIENTRYP PFNGLATTACHSHADERPROC) (GLuint program, GLuint shader); +typedef void (APIENTRYP PFNGLBINDATTRIBLOCATIONPROC) (GLuint program, GLuint index, const GLchar *name); +typedef void (APIENTRYP PFNGLCOMPILESHADERPROC) (GLuint shader); +typedef GLuint (APIENTRYP PFNGLCREATEPROGRAMPROC) (void); +typedef GLuint (APIENTRYP PFNGLCREATESHADERPROC) (GLenum type); +typedef void (APIENTRYP PFNGLDELETEPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLDELETESHADERPROC) (GLuint shader); +typedef void (APIENTRYP PFNGLDETACHSHADERPROC) (GLuint program, GLuint shader); +typedef void (APIENTRYP PFNGLDISABLEVERTEXATTRIBARRAYPROC) (GLuint index); +typedef void (APIENTRYP PFNGLENABLEVERTEXATTRIBARRAYPROC) (GLuint index); +typedef void (APIENTRYP PFNGLGETACTIVEATTRIBPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +typedef void (APIENTRYP PFNGLGETATTACHEDSHADERSPROC) (GLuint program, GLsizei maxCount, GLsizei *count, GLuint *obj); +typedef GLint (APIENTRYP PFNGLGETATTRIBLOCATIONPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLGETPROGRAMIVPROC) (GLuint program, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMINFOLOGPROC) (GLuint program, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +typedef void (APIENTRYP PFNGLGETSHADERIVPROC) (GLuint shader, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSHADERINFOLOGPROC) (GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +typedef void (APIENTRYP PFNGLGETSHADERSOURCEPROC) (GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *source); +typedef GLint (APIENTRYP PFNGLGETUNIFORMLOCATIONPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLGETUNIFORMFVPROC) (GLuint program, GLint location, GLfloat *params); +typedef void (APIENTRYP PFNGLGETUNIFORMIVPROC) (GLuint program, GLint location, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBDVPROC) (GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBFVPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIVPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVPROC) (GLuint index, GLenum pname, GLvoid* *pointer); +typedef GLboolean (APIENTRYP PFNGLISPROGRAMPROC) (GLuint program); +typedef GLboolean (APIENTRYP PFNGLISSHADERPROC) (GLuint shader); +typedef void (APIENTRYP PFNGLLINKPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLSHADERSOURCEPROC) (GLuint shader, GLsizei count, const GLchar* *string, const GLint *length); +typedef void (APIENTRYP PFNGLUSEPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLUNIFORM1FPROC) (GLint location, GLfloat v0); +typedef void (APIENTRYP PFNGLUNIFORM2FPROC) (GLint location, GLfloat v0, GLfloat v1); +typedef void (APIENTRYP PFNGLUNIFORM3FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (APIENTRYP PFNGLUNIFORM4FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (APIENTRYP PFNGLUNIFORM1IPROC) (GLint location, GLint v0); +typedef void (APIENTRYP PFNGLUNIFORM2IPROC) (GLint location, GLint v0, GLint v1); +typedef void (APIENTRYP PFNGLUNIFORM3IPROC) (GLint location, GLint v0, GLint v1, GLint v2); +typedef void (APIENTRYP PFNGLUNIFORM4IPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (APIENTRYP PFNGLUNIFORM1FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM2FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM3FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM4FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM1IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM2IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM3IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM4IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLVALIDATEPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FPROC) (GLuint index, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SPROC) (GLuint index, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SPROC) (GLuint index, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NBVPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NIVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NSVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBVPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUSVPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4BVPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4IVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBVPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4USVPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBPOINTERPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid *pointer); +#endif + +#ifndef GL_ARB_multitexture +#define GL_ARB_multitexture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glActiveTextureARB (GLenum); +GLAPI void APIENTRY glClientActiveTextureARB (GLenum); +GLAPI void APIENTRY glMultiTexCoord1dARB (GLenum, GLdouble); +GLAPI void APIENTRY glMultiTexCoord1dvARB (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord1fARB (GLenum, GLfloat); +GLAPI void APIENTRY glMultiTexCoord1fvARB (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord1iARB (GLenum, GLint); +GLAPI void APIENTRY glMultiTexCoord1ivARB (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord1sARB (GLenum, GLshort); +GLAPI void APIENTRY glMultiTexCoord1svARB (GLenum, const GLshort *); +GLAPI void APIENTRY glMultiTexCoord2dARB (GLenum, GLdouble, GLdouble); +GLAPI void APIENTRY glMultiTexCoord2dvARB (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord2fARB (GLenum, GLfloat, GLfloat); +GLAPI void APIENTRY glMultiTexCoord2fvARB (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord2iARB (GLenum, GLint, GLint); +GLAPI void APIENTRY glMultiTexCoord2ivARB (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord2sARB (GLenum, GLshort, GLshort); +GLAPI void APIENTRY glMultiTexCoord2svARB (GLenum, const GLshort *); +GLAPI void APIENTRY glMultiTexCoord3dARB (GLenum, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glMultiTexCoord3dvARB (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord3fARB (GLenum, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glMultiTexCoord3fvARB (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord3iARB (GLenum, GLint, GLint, GLint); +GLAPI void APIENTRY glMultiTexCoord3ivARB (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord3sARB (GLenum, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glMultiTexCoord3svARB (GLenum, const GLshort *); +GLAPI void APIENTRY glMultiTexCoord4dARB (GLenum, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glMultiTexCoord4dvARB (GLenum, const GLdouble *); +GLAPI void APIENTRY glMultiTexCoord4fARB (GLenum, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glMultiTexCoord4fvARB (GLenum, const GLfloat *); +GLAPI void APIENTRY glMultiTexCoord4iARB (GLenum, GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glMultiTexCoord4ivARB (GLenum, const GLint *); +GLAPI void APIENTRY glMultiTexCoord4sARB (GLenum, GLshort, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glMultiTexCoord4svARB (GLenum, const GLshort *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLCLIENTACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DARBPROC) (GLenum target, GLdouble s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FARBPROC) (GLenum target, GLfloat s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IARBPROC) (GLenum target, GLint s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SARBPROC) (GLenum target, GLshort s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DARBPROC) (GLenum target, GLdouble s, GLdouble t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FARBPROC) (GLenum target, GLfloat s, GLfloat t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IARBPROC) (GLenum target, GLint s, GLint t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SARBPROC) (GLenum target, GLshort s, GLshort t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IARBPROC) (GLenum target, GLint s, GLint t, GLint r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IARBPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SVARBPROC) (GLenum target, const GLshort *v); +#endif + +#ifndef GL_ARB_transpose_matrix +#define GL_ARB_transpose_matrix 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glLoadTransposeMatrixfARB (const GLfloat *); +GLAPI void APIENTRY glLoadTransposeMatrixdARB (const GLdouble *); +GLAPI void APIENTRY glMultTransposeMatrixfARB (const GLfloat *); +GLAPI void APIENTRY glMultTransposeMatrixdARB (const GLdouble *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXFARBPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXDARBPROC) (const GLdouble *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXFARBPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXDARBPROC) (const GLdouble *m); +#endif + +#ifndef GL_ARB_multisample +#define GL_ARB_multisample 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSampleCoverageARB (GLclampf, GLboolean); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEARBPROC) (GLclampf value, GLboolean invert); +#endif + +#ifndef GL_ARB_texture_env_add +#define GL_ARB_texture_env_add 1 +#endif + +#ifndef GL_ARB_texture_cube_map +#define GL_ARB_texture_cube_map 1 +#endif + +#ifndef GL_ARB_texture_compression +#define GL_ARB_texture_compression 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCompressedTexImage3DARB (GLenum, GLint, GLenum, GLsizei, GLsizei, GLsizei, GLint, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexImage2DARB (GLenum, GLint, GLenum, GLsizei, GLsizei, GLint, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexImage1DARB (GLenum, GLint, GLenum, GLsizei, GLint, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexSubImage3DARB (GLenum, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexSubImage2DARB (GLenum, GLint, GLint, GLint, GLsizei, GLsizei, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glCompressedTexSubImage1DARB (GLenum, GLint, GLint, GLsizei, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glGetCompressedTexImageARB (GLenum, GLint, GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE2DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE1DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLGETCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint level, GLvoid *img); +#endif + +#ifndef GL_ARB_texture_border_clamp +#define GL_ARB_texture_border_clamp 1 +#endif + +#ifndef GL_ARB_point_parameters +#define GL_ARB_point_parameters 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameterfARB (GLenum, GLfloat); +GLAPI void APIENTRY glPointParameterfvARB (GLenum, const GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPOINTPARAMETERFARBPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVARBPROC) (GLenum pname, const GLfloat *params); +#endif + +#ifndef GL_ARB_vertex_blend +#define GL_ARB_vertex_blend 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glWeightbvARB (GLint, const GLbyte *); +GLAPI void APIENTRY glWeightsvARB (GLint, const GLshort *); +GLAPI void APIENTRY glWeightivARB (GLint, const GLint *); +GLAPI void APIENTRY glWeightfvARB (GLint, const GLfloat *); +GLAPI void APIENTRY glWeightdvARB (GLint, const GLdouble *); +GLAPI void APIENTRY glWeightubvARB (GLint, const GLubyte *); +GLAPI void APIENTRY glWeightusvARB (GLint, const GLushort *); +GLAPI void APIENTRY glWeightuivARB (GLint, const GLuint *); +GLAPI void APIENTRY glWeightPointerARB (GLint, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glVertexBlendARB (GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLWEIGHTBVARBPROC) (GLint size, const GLbyte *weights); +typedef void (APIENTRYP PFNGLWEIGHTSVARBPROC) (GLint size, const GLshort *weights); +typedef void (APIENTRYP PFNGLWEIGHTIVARBPROC) (GLint size, const GLint *weights); +typedef void (APIENTRYP PFNGLWEIGHTFVARBPROC) (GLint size, const GLfloat *weights); +typedef void (APIENTRYP PFNGLWEIGHTDVARBPROC) (GLint size, const GLdouble *weights); +typedef void (APIENTRYP PFNGLWEIGHTUBVARBPROC) (GLint size, const GLubyte *weights); +typedef void (APIENTRYP PFNGLWEIGHTUSVARBPROC) (GLint size, const GLushort *weights); +typedef void (APIENTRYP PFNGLWEIGHTUIVARBPROC) (GLint size, const GLuint *weights); +typedef void (APIENTRYP PFNGLWEIGHTPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLVERTEXBLENDARBPROC) (GLint count); +#endif + +#ifndef GL_ARB_matrix_palette +#define GL_ARB_matrix_palette 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCurrentPaletteMatrixARB (GLint); +GLAPI void APIENTRY glMatrixIndexubvARB (GLint, const GLubyte *); +GLAPI void APIENTRY glMatrixIndexusvARB (GLint, const GLushort *); +GLAPI void APIENTRY glMatrixIndexuivARB (GLint, const GLuint *); +GLAPI void APIENTRY glMatrixIndexPointerARB (GLint, GLenum, GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCURRENTPALETTEMATRIXARBPROC) (GLint index); +typedef void (APIENTRYP PFNGLMATRIXINDEXUBVARBPROC) (GLint size, const GLubyte *indices); +typedef void (APIENTRYP PFNGLMATRIXINDEXUSVARBPROC) (GLint size, const GLushort *indices); +typedef void (APIENTRYP PFNGLMATRIXINDEXUIVARBPROC) (GLint size, const GLuint *indices); +typedef void (APIENTRYP PFNGLMATRIXINDEXPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +#endif + +#ifndef GL_ARB_texture_env_combine +#define GL_ARB_texture_env_combine 1 +#endif + +#ifndef GL_ARB_texture_env_crossbar +#define GL_ARB_texture_env_crossbar 1 +#endif + +#ifndef GL_ARB_texture_env_dot3 +#define GL_ARB_texture_env_dot3 1 +#endif + +#ifndef GL_ARB_texture_mirrored_repeat +#define GL_ARB_texture_mirrored_repeat 1 +#endif + +#ifndef GL_ARB_depth_texture +#define GL_ARB_depth_texture 1 +#endif + +#ifndef GL_ARB_shadow +#define GL_ARB_shadow 1 +#endif + +#ifndef GL_ARB_shadow_ambient +#define GL_ARB_shadow_ambient 1 +#endif + +#ifndef GL_ARB_window_pos +#define GL_ARB_window_pos 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glWindowPos2dARB (GLdouble, GLdouble); +GLAPI void APIENTRY glWindowPos2dvARB (const GLdouble *); +GLAPI void APIENTRY glWindowPos2fARB (GLfloat, GLfloat); +GLAPI void APIENTRY glWindowPos2fvARB (const GLfloat *); +GLAPI void APIENTRY glWindowPos2iARB (GLint, GLint); +GLAPI void APIENTRY glWindowPos2ivARB (const GLint *); +GLAPI void APIENTRY glWindowPos2sARB (GLshort, GLshort); +GLAPI void APIENTRY glWindowPos2svARB (const GLshort *); +GLAPI void APIENTRY glWindowPos3dARB (GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glWindowPos3dvARB (const GLdouble *); +GLAPI void APIENTRY glWindowPos3fARB (GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glWindowPos3fvARB (const GLfloat *); +GLAPI void APIENTRY glWindowPos3iARB (GLint, GLint, GLint); +GLAPI void APIENTRY glWindowPos3ivARB (const GLint *); +GLAPI void APIENTRY glWindowPos3sARB (GLshort, GLshort, GLshort); +GLAPI void APIENTRY glWindowPos3svARB (const GLshort *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLWINDOWPOS2DARBPROC) (GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLWINDOWPOS2DVARBPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2FARBPROC) (GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLWINDOWPOS2FVARBPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2IARBPROC) (GLint x, GLint y); +typedef void (APIENTRYP PFNGLWINDOWPOS2IVARBPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2SARBPROC) (GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLWINDOWPOS2SVARBPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3DARBPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLWINDOWPOS3DVARBPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3FARBPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLWINDOWPOS3FVARBPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3IARBPROC) (GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLWINDOWPOS3IVARBPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3SARBPROC) (GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLWINDOWPOS3SVARBPROC) (const GLshort *v); +#endif + +#ifndef GL_ARB_vertex_program +#define GL_ARB_vertex_program 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttrib1dARB (GLuint, GLdouble); +GLAPI void APIENTRY glVertexAttrib1dvARB (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib1fARB (GLuint, GLfloat); +GLAPI void APIENTRY glVertexAttrib1fvARB (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib1sARB (GLuint, GLshort); +GLAPI void APIENTRY glVertexAttrib1svARB (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib2dARB (GLuint, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib2dvARB (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib2fARB (GLuint, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib2fvARB (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib2sARB (GLuint, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib2svARB (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib3dARB (GLuint, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib3dvARB (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib3fARB (GLuint, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib3fvARB (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib3sARB (GLuint, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib3svARB (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4NbvARB (GLuint, const GLbyte *); +GLAPI void APIENTRY glVertexAttrib4NivARB (GLuint, const GLint *); +GLAPI void APIENTRY glVertexAttrib4NsvARB (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4NubARB (GLuint, GLubyte, GLubyte, GLubyte, GLubyte); +GLAPI void APIENTRY glVertexAttrib4NubvARB (GLuint, const GLubyte *); +GLAPI void APIENTRY glVertexAttrib4NuivARB (GLuint, const GLuint *); +GLAPI void APIENTRY glVertexAttrib4NusvARB (GLuint, const GLushort *); +GLAPI void APIENTRY glVertexAttrib4bvARB (GLuint, const GLbyte *); +GLAPI void APIENTRY glVertexAttrib4dARB (GLuint, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib4dvARB (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib4fARB (GLuint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib4fvARB (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib4ivARB (GLuint, const GLint *); +GLAPI void APIENTRY glVertexAttrib4sARB (GLuint, GLshort, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib4svARB (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4ubvARB (GLuint, const GLubyte *); +GLAPI void APIENTRY glVertexAttrib4uivARB (GLuint, const GLuint *); +GLAPI void APIENTRY glVertexAttrib4usvARB (GLuint, const GLushort *); +GLAPI void APIENTRY glVertexAttribPointerARB (GLuint, GLint, GLenum, GLboolean, GLsizei, const GLvoid *); +GLAPI void APIENTRY glEnableVertexAttribArrayARB (GLuint); +GLAPI void APIENTRY glDisableVertexAttribArrayARB (GLuint); +GLAPI void APIENTRY glProgramStringARB (GLenum, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glBindProgramARB (GLenum, GLuint); +GLAPI void APIENTRY glDeleteProgramsARB (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenProgramsARB (GLsizei, GLuint *); +GLAPI void APIENTRY glProgramEnvParameter4dARB (GLenum, GLuint, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glProgramEnvParameter4dvARB (GLenum, GLuint, const GLdouble *); +GLAPI void APIENTRY glProgramEnvParameter4fARB (GLenum, GLuint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glProgramEnvParameter4fvARB (GLenum, GLuint, const GLfloat *); +GLAPI void APIENTRY glProgramLocalParameter4dARB (GLenum, GLuint, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glProgramLocalParameter4dvARB (GLenum, GLuint, const GLdouble *); +GLAPI void APIENTRY glProgramLocalParameter4fARB (GLenum, GLuint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glProgramLocalParameter4fvARB (GLenum, GLuint, const GLfloat *); +GLAPI void APIENTRY glGetProgramEnvParameterdvARB (GLenum, GLuint, GLdouble *); +GLAPI void APIENTRY glGetProgramEnvParameterfvARB (GLenum, GLuint, GLfloat *); +GLAPI void APIENTRY glGetProgramLocalParameterdvARB (GLenum, GLuint, GLdouble *); +GLAPI void APIENTRY glGetProgramLocalParameterfvARB (GLenum, GLuint, GLfloat *); +GLAPI void APIENTRY glGetProgramivARB (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetProgramStringARB (GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetVertexAttribdvARB (GLuint, GLenum, GLdouble *); +GLAPI void APIENTRY glGetVertexAttribfvARB (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetVertexAttribivARB (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetVertexAttribPointervARB (GLuint, GLenum, GLvoid* *); +GLAPI GLboolean APIENTRY glIsProgramARB (GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DARBPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FARBPROC) (GLuint index, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SARBPROC) (GLuint index, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DARBPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FARBPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SARBPROC) (GLuint index, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NBVARBPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NIVARBPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NSVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBARBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBVARBPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUIVARBPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUSVARBPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4BVARBPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4IVARBPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBVARBPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UIVARBPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4USVARBPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBPOINTERARBPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLENABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); +typedef void (APIENTRYP PFNGLDISABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); +typedef void (APIENTRYP PFNGLPROGRAMSTRINGARBPROC) (GLenum target, GLenum format, GLsizei len, const GLvoid *string); +typedef void (APIENTRYP PFNGLBINDPROGRAMARBPROC) (GLenum target, GLuint program); +typedef void (APIENTRYP PFNGLDELETEPROGRAMSARBPROC) (GLsizei n, const GLuint *programs); +typedef void (APIENTRYP PFNGLGENPROGRAMSARBPROC) (GLsizei n, GLuint *programs); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble *params); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMENVPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble *params); +typedef void (APIENTRYP PFNGLGETPROGRAMENVPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble *params); +typedef void (APIENTRYP PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMIVARBPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMSTRINGARBPROC) (GLenum target, GLenum pname, GLvoid *string); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBDVARBPROC) (GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBFVARBPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIVARBPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVARBPROC) (GLuint index, GLenum pname, GLvoid* *pointer); +typedef GLboolean (APIENTRYP PFNGLISPROGRAMARBPROC) (GLuint program); +#endif + +#ifndef GL_ARB_fragment_program +#define GL_ARB_fragment_program 1 +/* All ARB_fragment_program entry points are shared with ARB_vertex_program. */ +#endif + +#ifndef GL_ARB_vertex_buffer_object +#define GL_ARB_vertex_buffer_object 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindBufferARB (GLenum, GLuint); +GLAPI void APIENTRY glDeleteBuffersARB (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenBuffersARB (GLsizei, GLuint *); +GLAPI GLboolean APIENTRY glIsBufferARB (GLuint); +GLAPI void APIENTRY glBufferDataARB (GLenum, GLsizeiptrARB, const GLvoid *, GLenum); +GLAPI void APIENTRY glBufferSubDataARB (GLenum, GLintptrARB, GLsizeiptrARB, const GLvoid *); +GLAPI void APIENTRY glGetBufferSubDataARB (GLenum, GLintptrARB, GLsizeiptrARB, GLvoid *); +GLAPI GLvoid* APIENTRY glMapBufferARB (GLenum, GLenum); +GLAPI GLboolean APIENTRY glUnmapBufferARB (GLenum); +GLAPI void APIENTRY glGetBufferParameterivARB (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetBufferPointervARB (GLenum, GLenum, GLvoid* *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBINDBUFFERARBPROC) (GLenum target, GLuint buffer); +typedef void (APIENTRYP PFNGLDELETEBUFFERSARBPROC) (GLsizei n, const GLuint *buffers); +typedef void (APIENTRYP PFNGLGENBUFFERSARBPROC) (GLsizei n, GLuint *buffers); +typedef GLboolean (APIENTRYP PFNGLISBUFFERARBPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLBUFFERDATAARBPROC) (GLenum target, GLsizeiptrARB size, const GLvoid *data, GLenum usage); +typedef void (APIENTRYP PFNGLBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, const GLvoid *data); +typedef void (APIENTRYP PFNGLGETBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, GLvoid *data); +typedef GLvoid* (APIENTRYP PFNGLMAPBUFFERARBPROC) (GLenum target, GLenum access); +typedef GLboolean (APIENTRYP PFNGLUNMAPBUFFERARBPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERIVARBPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETBUFFERPOINTERVARBPROC) (GLenum target, GLenum pname, GLvoid* *params); +#endif + +#ifndef GL_ARB_occlusion_query +#define GL_ARB_occlusion_query 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenQueriesARB (GLsizei, GLuint *); +GLAPI void APIENTRY glDeleteQueriesARB (GLsizei, const GLuint *); +GLAPI GLboolean APIENTRY glIsQueryARB (GLuint); +GLAPI void APIENTRY glBeginQueryARB (GLenum, GLuint); +GLAPI void APIENTRY glEndQueryARB (GLenum); +GLAPI void APIENTRY glGetQueryivARB (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetQueryObjectivARB (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetQueryObjectuivARB (GLuint, GLenum, GLuint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGENQUERIESARBPROC) (GLsizei n, GLuint *ids); +typedef void (APIENTRYP PFNGLDELETEQUERIESARBPROC) (GLsizei n, const GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISQUERYARBPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINQUERYARBPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLENDQUERYARBPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETQUERYIVARBPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTIVARBPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTUIVARBPROC) (GLuint id, GLenum pname, GLuint *params); +#endif + +#ifndef GL_ARB_shader_objects +#define GL_ARB_shader_objects 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDeleteObjectARB (GLhandleARB); +GLAPI GLhandleARB APIENTRY glGetHandleARB (GLenum); +GLAPI void APIENTRY glDetachObjectARB (GLhandleARB, GLhandleARB); +GLAPI GLhandleARB APIENTRY glCreateShaderObjectARB (GLenum); +GLAPI void APIENTRY glShaderSourceARB (GLhandleARB, GLsizei, const GLcharARB* *, const GLint *); +GLAPI void APIENTRY glCompileShaderARB (GLhandleARB); +GLAPI GLhandleARB APIENTRY glCreateProgramObjectARB (void); +GLAPI void APIENTRY glAttachObjectARB (GLhandleARB, GLhandleARB); +GLAPI void APIENTRY glLinkProgramARB (GLhandleARB); +GLAPI void APIENTRY glUseProgramObjectARB (GLhandleARB); +GLAPI void APIENTRY glValidateProgramARB (GLhandleARB); +GLAPI void APIENTRY glUniform1fARB (GLint, GLfloat); +GLAPI void APIENTRY glUniform2fARB (GLint, GLfloat, GLfloat); +GLAPI void APIENTRY glUniform3fARB (GLint, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glUniform4fARB (GLint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glUniform1iARB (GLint, GLint); +GLAPI void APIENTRY glUniform2iARB (GLint, GLint, GLint); +GLAPI void APIENTRY glUniform3iARB (GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glUniform4iARB (GLint, GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glUniform1fvARB (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform2fvARB (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform3fvARB (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform4fvARB (GLint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glUniform1ivARB (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniform2ivARB (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniform3ivARB (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniform4ivARB (GLint, GLsizei, const GLint *); +GLAPI void APIENTRY glUniformMatrix2fvARB (GLint, GLsizei, GLboolean, const GLfloat *); +GLAPI void APIENTRY glUniformMatrix3fvARB (GLint, GLsizei, GLboolean, const GLfloat *); +GLAPI void APIENTRY glUniformMatrix4fvARB (GLint, GLsizei, GLboolean, const GLfloat *); +GLAPI void APIENTRY glGetObjectParameterfvARB (GLhandleARB, GLenum, GLfloat *); +GLAPI void APIENTRY glGetObjectParameterivARB (GLhandleARB, GLenum, GLint *); +GLAPI void APIENTRY glGetInfoLogARB (GLhandleARB, GLsizei, GLsizei *, GLcharARB *); +GLAPI void APIENTRY glGetAttachedObjectsARB (GLhandleARB, GLsizei, GLsizei *, GLhandleARB *); +GLAPI GLint APIENTRY glGetUniformLocationARB (GLhandleARB, const GLcharARB *); +GLAPI void APIENTRY glGetActiveUniformARB (GLhandleARB, GLuint, GLsizei, GLsizei *, GLint *, GLenum *, GLcharARB *); +GLAPI void APIENTRY glGetUniformfvARB (GLhandleARB, GLint, GLfloat *); +GLAPI void APIENTRY glGetUniformivARB (GLhandleARB, GLint, GLint *); +GLAPI void APIENTRY glGetShaderSourceARB (GLhandleARB, GLsizei, GLsizei *, GLcharARB *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDELETEOBJECTARBPROC) (GLhandleARB obj); +typedef GLhandleARB (APIENTRYP PFNGLGETHANDLEARBPROC) (GLenum pname); +typedef void (APIENTRYP PFNGLDETACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB attachedObj); +typedef GLhandleARB (APIENTRYP PFNGLCREATESHADEROBJECTARBPROC) (GLenum shaderType); +typedef void (APIENTRYP PFNGLSHADERSOURCEARBPROC) (GLhandleARB shaderObj, GLsizei count, const GLcharARB* *string, const GLint *length); +typedef void (APIENTRYP PFNGLCOMPILESHADERARBPROC) (GLhandleARB shaderObj); +typedef GLhandleARB (APIENTRYP PFNGLCREATEPROGRAMOBJECTARBPROC) (void); +typedef void (APIENTRYP PFNGLATTACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB obj); +typedef void (APIENTRYP PFNGLLINKPROGRAMARBPROC) (GLhandleARB programObj); +typedef void (APIENTRYP PFNGLUSEPROGRAMOBJECTARBPROC) (GLhandleARB programObj); +typedef void (APIENTRYP PFNGLVALIDATEPROGRAMARBPROC) (GLhandleARB programObj); +typedef void (APIENTRYP PFNGLUNIFORM1FARBPROC) (GLint location, GLfloat v0); +typedef void (APIENTRYP PFNGLUNIFORM2FARBPROC) (GLint location, GLfloat v0, GLfloat v1); +typedef void (APIENTRYP PFNGLUNIFORM3FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (APIENTRYP PFNGLUNIFORM4FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (APIENTRYP PFNGLUNIFORM1IARBPROC) (GLint location, GLint v0); +typedef void (APIENTRYP PFNGLUNIFORM2IARBPROC) (GLint location, GLint v0, GLint v1); +typedef void (APIENTRYP PFNGLUNIFORM3IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2); +typedef void (APIENTRYP PFNGLUNIFORM4IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (APIENTRYP PFNGLUNIFORM1FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM2FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM3FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM4FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM1IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM2IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM3IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM4IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLGETOBJECTPARAMETERFVARBPROC) (GLhandleARB obj, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETOBJECTPARAMETERIVARBPROC) (GLhandleARB obj, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETINFOLOGARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei *length, GLcharARB *infoLog); +typedef void (APIENTRYP PFNGLGETATTACHEDOBJECTSARBPROC) (GLhandleARB containerObj, GLsizei maxCount, GLsizei *count, GLhandleARB *obj); +typedef GLint (APIENTRYP PFNGLGETUNIFORMLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB *name); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei *length, GLint *size, GLenum *type, GLcharARB *name); +typedef void (APIENTRYP PFNGLGETUNIFORMFVARBPROC) (GLhandleARB programObj, GLint location, GLfloat *params); +typedef void (APIENTRYP PFNGLGETUNIFORMIVARBPROC) (GLhandleARB programObj, GLint location, GLint *params); +typedef void (APIENTRYP PFNGLGETSHADERSOURCEARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei *length, GLcharARB *source); +#endif + +#ifndef GL_ARB_vertex_shader +#define GL_ARB_vertex_shader 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindAttribLocationARB (GLhandleARB, GLuint, const GLcharARB *); +GLAPI void APIENTRY glGetActiveAttribARB (GLhandleARB, GLuint, GLsizei, GLsizei *, GLint *, GLenum *, GLcharARB *); +GLAPI GLint APIENTRY glGetAttribLocationARB (GLhandleARB, const GLcharARB *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBINDATTRIBLOCATIONARBPROC) (GLhandleARB programObj, GLuint index, const GLcharARB *name); +typedef void (APIENTRYP PFNGLGETACTIVEATTRIBARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei *length, GLint *size, GLenum *type, GLcharARB *name); +typedef GLint (APIENTRYP PFNGLGETATTRIBLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB *name); +#endif + +#ifndef GL_ARB_fragment_shader +#define GL_ARB_fragment_shader 1 +#endif + +#ifndef GL_ARB_shading_language_100 +#define GL_ARB_shading_language_100 1 +#endif + +#ifndef GL_ARB_texture_non_power_of_two +#define GL_ARB_texture_non_power_of_two 1 +#endif + +#ifndef GL_ARB_point_sprite +#define GL_ARB_point_sprite 1 +#endif + +#ifndef GL_ARB_fragment_program_shadow +#define GL_ARB_fragment_program_shadow 1 +#endif + +#ifndef GL_ARB_draw_buffers +#define GL_ARB_draw_buffers 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawBuffersARB (GLsizei, const GLenum *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDRAWBUFFERSARBPROC) (GLsizei n, const GLenum *bufs); +#endif + +#ifndef GL_ARB_texture_rectangle +#define GL_ARB_texture_rectangle 1 +#endif + +#ifndef GL_ARB_color_buffer_float +#define GL_ARB_color_buffer_float 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glClampColorARB (GLenum, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCLAMPCOLORARBPROC) (GLenum target, GLenum clamp); +#endif + +#ifndef GL_ARB_half_float_pixel +#define GL_ARB_half_float_pixel 1 +#endif + +#ifndef GL_ARB_texture_float +#define GL_ARB_texture_float 1 +#endif + +#ifndef GL_ARB_pixel_buffer_object +#define GL_ARB_pixel_buffer_object 1 +#endif + +#ifndef GL_EXT_abgr +#define GL_EXT_abgr 1 +#endif + +#ifndef GL_EXT_blend_color +#define GL_EXT_blend_color 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendColorEXT (GLclampf, GLclampf, GLclampf, GLclampf); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDCOLOREXTPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +#endif + +#ifndef GL_EXT_polygon_offset +#define GL_EXT_polygon_offset 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPolygonOffsetEXT (GLfloat, GLfloat); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPOLYGONOFFSETEXTPROC) (GLfloat factor, GLfloat bias); +#endif + +#ifndef GL_EXT_texture +#define GL_EXT_texture 1 +#endif + +#ifndef GL_EXT_texture3D +#define GL_EXT_texture3D 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexImage3DEXT (GLenum, GLint, GLenum, GLsizei, GLsizei, GLsizei, GLint, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glTexSubImage3DEXT (GLenum, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTEXIMAGE3DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +typedef void (APIENTRYP PFNGLTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); +#endif + +#ifndef GL_SGIS_texture_filter4 +#define GL_SGIS_texture_filter4 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetTexFilterFuncSGIS (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glTexFilterFuncSGIS (GLenum, GLenum, GLsizei, const GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGETTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLfloat *weights); +typedef void (APIENTRYP PFNGLTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLsizei n, const GLfloat *weights); +#endif + +#ifndef GL_EXT_subtexture +#define GL_EXT_subtexture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexSubImage1DEXT (GLenum, GLint, GLint, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glTexSubImage2DEXT (GLenum, GLint, GLint, GLint, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); +typedef void (APIENTRYP PFNGLTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); +#endif + +#ifndef GL_EXT_copy_texture +#define GL_EXT_copy_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCopyTexImage1DEXT (GLenum, GLint, GLenum, GLint, GLint, GLsizei, GLint); +GLAPI void APIENTRY glCopyTexImage2DEXT (GLenum, GLint, GLenum, GLint, GLint, GLsizei, GLsizei, GLint); +GLAPI void APIENTRY glCopyTexSubImage1DEXT (GLenum, GLint, GLint, GLint, GLint, GLsizei); +GLAPI void APIENTRY glCopyTexSubImage2DEXT (GLenum, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei); +GLAPI void APIENTRY glCopyTexSubImage3DEXT (GLenum, GLint, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOPYTEXIMAGE1DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +typedef void (APIENTRYP PFNGLCOPYTEXIMAGE2DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +#endif + +#ifndef GL_EXT_histogram +#define GL_EXT_histogram 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetHistogramEXT (GLenum, GLboolean, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetHistogramParameterfvEXT (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetHistogramParameterivEXT (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetMinmaxEXT (GLenum, GLboolean, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetMinmaxParameterfvEXT (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetMinmaxParameterivEXT (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glHistogramEXT (GLenum, GLsizei, GLenum, GLboolean); +GLAPI void APIENTRY glMinmaxEXT (GLenum, GLenum, GLboolean); +GLAPI void APIENTRY glResetHistogramEXT (GLenum); +GLAPI void APIENTRY glResetMinmaxEXT (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGETHISTOGRAMEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMINMAXEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLHISTOGRAMEXTPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLMINMAXEXTPROC) (GLenum target, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLRESETHISTOGRAMEXTPROC) (GLenum target); +typedef void (APIENTRYP PFNGLRESETMINMAXEXTPROC) (GLenum target); +#endif + +#ifndef GL_EXT_convolution +#define GL_EXT_convolution 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glConvolutionFilter1DEXT (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glConvolutionFilter2DEXT (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glConvolutionParameterfEXT (GLenum, GLenum, GLfloat); +GLAPI void APIENTRY glConvolutionParameterfvEXT (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glConvolutionParameteriEXT (GLenum, GLenum, GLint); +GLAPI void APIENTRY glConvolutionParameterivEXT (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glCopyConvolutionFilter1DEXT (GLenum, GLenum, GLint, GLint, GLsizei); +GLAPI void APIENTRY glCopyConvolutionFilter2DEXT (GLenum, GLenum, GLint, GLint, GLsizei, GLsizei); +GLAPI void APIENTRY glGetConvolutionFilterEXT (GLenum, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetConvolutionParameterfvEXT (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetConvolutionParameterivEXT (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetSeparableFilterEXT (GLenum, GLenum, GLenum, GLvoid *, GLvoid *, GLvoid *); +GLAPI void APIENTRY glSeparableFilter2DEXT (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSEPARABLEFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); +typedef void (APIENTRYP PFNGLSEPARABLEFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); +#endif + +#ifndef GL_EXT_color_matrix +#define GL_EXT_color_matrix 1 +#endif + +#ifndef GL_SGI_color_table +#define GL_SGI_color_table 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorTableSGI (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glColorTableParameterfvSGI (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glColorTableParameterivSGI (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glCopyColorTableSGI (GLenum, GLenum, GLint, GLint, GLsizei); +GLAPI void APIENTRY glGetColorTableSGI (GLenum, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetColorTableParameterfvSGI (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetColorTableParameterivSGI (GLenum, GLenum, GLint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLGETCOLORTABLESGIPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, GLint *params); +#endif + +#ifndef GL_SGIX_pixel_texture +#define GL_SGIX_pixel_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelTexGenSGIX (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPIXELTEXGENSGIXPROC) (GLenum mode); +#endif + +#ifndef GL_SGIS_pixel_texture +#define GL_SGIS_pixel_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelTexGenParameteriSGIS (GLenum, GLint); +GLAPI void APIENTRY glPixelTexGenParameterivSGIS (GLenum, const GLint *); +GLAPI void APIENTRY glPixelTexGenParameterfSGIS (GLenum, GLfloat); +GLAPI void APIENTRY glPixelTexGenParameterfvSGIS (GLenum, const GLfloat *); +GLAPI void APIENTRY glGetPixelTexGenParameterivSGIS (GLenum, GLint *); +GLAPI void APIENTRY glGetPixelTexGenParameterfvSGIS (GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERISGISPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERIVSGISPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERFSGISPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERFVSGISPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETPIXELTEXGENPARAMETERIVSGISPROC) (GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPIXELTEXGENPARAMETERFVSGISPROC) (GLenum pname, GLfloat *params); +#endif + +#ifndef GL_SGIS_texture4D +#define GL_SGIS_texture4D 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexImage4DSGIS (GLenum, GLint, GLenum, GLsizei, GLsizei, GLsizei, GLsizei, GLint, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glTexSubImage4DSGIS (GLenum, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTEXIMAGE4DSGISPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei size4d, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +typedef void (APIENTRYP PFNGLTEXSUBIMAGE4DSGISPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint woffset, GLsizei width, GLsizei height, GLsizei depth, GLsizei size4d, GLenum format, GLenum type, const GLvoid *pixels); +#endif + +#ifndef GL_SGI_texture_color_table +#define GL_SGI_texture_color_table 1 +#endif + +#ifndef GL_EXT_cmyka +#define GL_EXT_cmyka 1 +#endif + +#ifndef GL_EXT_texture_object +#define GL_EXT_texture_object 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLboolean APIENTRY glAreTexturesResidentEXT (GLsizei, const GLuint *, GLboolean *); +GLAPI void APIENTRY glBindTextureEXT (GLenum, GLuint); +GLAPI void APIENTRY glDeleteTexturesEXT (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenTexturesEXT (GLsizei, GLuint *); +GLAPI GLboolean APIENTRY glIsTextureEXT (GLuint); +GLAPI void APIENTRY glPrioritizeTexturesEXT (GLsizei, const GLuint *, const GLclampf *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLboolean (APIENTRYP PFNGLARETEXTURESRESIDENTEXTPROC) (GLsizei n, const GLuint *textures, GLboolean *residences); +typedef void (APIENTRYP PFNGLBINDTEXTUREEXTPROC) (GLenum target, GLuint texture); +typedef void (APIENTRYP PFNGLDELETETEXTURESEXTPROC) (GLsizei n, const GLuint *textures); +typedef void (APIENTRYP PFNGLGENTEXTURESEXTPROC) (GLsizei n, GLuint *textures); +typedef GLboolean (APIENTRYP PFNGLISTEXTUREEXTPROC) (GLuint texture); +typedef void (APIENTRYP PFNGLPRIORITIZETEXTURESEXTPROC) (GLsizei n, const GLuint *textures, const GLclampf *priorities); +#endif + +#ifndef GL_SGIS_detail_texture +#define GL_SGIS_detail_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDetailTexFuncSGIS (GLenum, GLsizei, const GLfloat *); +GLAPI void APIENTRY glGetDetailTexFuncSGIS (GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDETAILTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat *points); +typedef void (APIENTRYP PFNGLGETDETAILTEXFUNCSGISPROC) (GLenum target, GLfloat *points); +#endif + +#ifndef GL_SGIS_sharpen_texture +#define GL_SGIS_sharpen_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSharpenTexFuncSGIS (GLenum, GLsizei, const GLfloat *); +GLAPI void APIENTRY glGetSharpenTexFuncSGIS (GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSHARPENTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat *points); +typedef void (APIENTRYP PFNGLGETSHARPENTEXFUNCSGISPROC) (GLenum target, GLfloat *points); +#endif + +#ifndef GL_EXT_packed_pixels +#define GL_EXT_packed_pixels 1 +#endif + +#ifndef GL_SGIS_texture_lod +#define GL_SGIS_texture_lod 1 +#endif + +#ifndef GL_SGIS_multisample +#define GL_SGIS_multisample 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSampleMaskSGIS (GLclampf, GLboolean); +GLAPI void APIENTRY glSamplePatternSGIS (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSAMPLEMASKSGISPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLSAMPLEPATTERNSGISPROC) (GLenum pattern); +#endif + +#ifndef GL_EXT_rescale_normal +#define GL_EXT_rescale_normal 1 +#endif + +#ifndef GL_EXT_vertex_array +#define GL_EXT_vertex_array 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glArrayElementEXT (GLint); +GLAPI void APIENTRY glColorPointerEXT (GLint, GLenum, GLsizei, GLsizei, const GLvoid *); +GLAPI void APIENTRY glDrawArraysEXT (GLenum, GLint, GLsizei); +GLAPI void APIENTRY glEdgeFlagPointerEXT (GLsizei, GLsizei, const GLboolean *); +GLAPI void APIENTRY glGetPointervEXT (GLenum, GLvoid* *); +GLAPI void APIENTRY glIndexPointerEXT (GLenum, GLsizei, GLsizei, const GLvoid *); +GLAPI void APIENTRY glNormalPointerEXT (GLenum, GLsizei, GLsizei, const GLvoid *); +GLAPI void APIENTRY glTexCoordPointerEXT (GLint, GLenum, GLsizei, GLsizei, const GLvoid *); +GLAPI void APIENTRY glVertexPointerEXT (GLint, GLenum, GLsizei, GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLARRAYELEMENTEXTPROC) (GLint i); +typedef void (APIENTRYP PFNGLCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLDRAWARRAYSEXTPROC) (GLenum mode, GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLEDGEFLAGPOINTEREXTPROC) (GLsizei stride, GLsizei count, const GLboolean *pointer); +typedef void (APIENTRYP PFNGLGETPOINTERVEXTPROC) (GLenum pname, GLvoid* *params); +typedef void (APIENTRYP PFNGLINDEXPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLNORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLTEXCOORDPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLVERTEXPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); +#endif + +#ifndef GL_EXT_misc_attribute +#define GL_EXT_misc_attribute 1 +#endif + +#ifndef GL_SGIS_generate_mipmap +#define GL_SGIS_generate_mipmap 1 +#endif + +#ifndef GL_SGIX_clipmap +#define GL_SGIX_clipmap 1 +#endif + +#ifndef GL_SGIX_shadow +#define GL_SGIX_shadow 1 +#endif + +#ifndef GL_SGIS_texture_edge_clamp +#define GL_SGIS_texture_edge_clamp 1 +#endif + +#ifndef GL_SGIS_texture_border_clamp +#define GL_SGIS_texture_border_clamp 1 +#endif + +#ifndef GL_EXT_blend_minmax +#define GL_EXT_blend_minmax 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendEquationEXT (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDEQUATIONEXTPROC) (GLenum mode); +#endif + +#ifndef GL_EXT_blend_subtract +#define GL_EXT_blend_subtract 1 +#endif + +#ifndef GL_EXT_blend_logic_op +#define GL_EXT_blend_logic_op 1 +#endif + +#ifndef GL_SGIX_interlace +#define GL_SGIX_interlace 1 +#endif + +#ifndef GL_SGIX_pixel_tiles +#define GL_SGIX_pixel_tiles 1 +#endif + +#ifndef GL_SGIX_texture_select +#define GL_SGIX_texture_select 1 +#endif + +#ifndef GL_SGIX_sprite +#define GL_SGIX_sprite 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSpriteParameterfSGIX (GLenum, GLfloat); +GLAPI void APIENTRY glSpriteParameterfvSGIX (GLenum, const GLfloat *); +GLAPI void APIENTRY glSpriteParameteriSGIX (GLenum, GLint); +GLAPI void APIENTRY glSpriteParameterivSGIX (GLenum, const GLint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSPRITEPARAMETERFSGIXPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLSPRITEPARAMETERFVSGIXPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLSPRITEPARAMETERISGIXPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLSPRITEPARAMETERIVSGIXPROC) (GLenum pname, const GLint *params); +#endif + +#ifndef GL_SGIX_texture_multi_buffer +#define GL_SGIX_texture_multi_buffer 1 +#endif + +#ifndef GL_EXT_point_parameters +#define GL_EXT_point_parameters 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameterfEXT (GLenum, GLfloat); +GLAPI void APIENTRY glPointParameterfvEXT (GLenum, const GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPOINTPARAMETERFEXTPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVEXTPROC) (GLenum pname, const GLfloat *params); +#endif + +#ifndef GL_SGIS_point_parameters +#define GL_SGIS_point_parameters 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameterfSGIS (GLenum, GLfloat); +GLAPI void APIENTRY glPointParameterfvSGIS (GLenum, const GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPOINTPARAMETERFSGISPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVSGISPROC) (GLenum pname, const GLfloat *params); +#endif + +#ifndef GL_SGIX_instruments +#define GL_SGIX_instruments 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLint APIENTRY glGetInstrumentsSGIX (void); +GLAPI void APIENTRY glInstrumentsBufferSGIX (GLsizei, GLint *); +GLAPI GLint APIENTRY glPollInstrumentsSGIX (GLint *); +GLAPI void APIENTRY glReadInstrumentsSGIX (GLint); +GLAPI void APIENTRY glStartInstrumentsSGIX (void); +GLAPI void APIENTRY glStopInstrumentsSGIX (GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLint (APIENTRYP PFNGLGETINSTRUMENTSSGIXPROC) (void); +typedef void (APIENTRYP PFNGLINSTRUMENTSBUFFERSGIXPROC) (GLsizei size, GLint *buffer); +typedef GLint (APIENTRYP PFNGLPOLLINSTRUMENTSSGIXPROC) (GLint *marker_p); +typedef void (APIENTRYP PFNGLREADINSTRUMENTSSGIXPROC) (GLint marker); +typedef void (APIENTRYP PFNGLSTARTINSTRUMENTSSGIXPROC) (void); +typedef void (APIENTRYP PFNGLSTOPINSTRUMENTSSGIXPROC) (GLint marker); +#endif + +#ifndef GL_SGIX_texture_scale_bias +#define GL_SGIX_texture_scale_bias 1 +#endif + +#ifndef GL_SGIX_framezoom +#define GL_SGIX_framezoom 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFrameZoomSGIX (GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLFRAMEZOOMSGIXPROC) (GLint factor); +#endif + +#ifndef GL_SGIX_tag_sample_buffer +#define GL_SGIX_tag_sample_buffer 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTagSampleBufferSGIX (void); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTAGSAMPLEBUFFERSGIXPROC) (void); +#endif + +#ifndef GL_SGIX_polynomial_ffd +#define GL_SGIX_polynomial_ffd 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDeformationMap3dSGIX (GLenum, GLdouble, GLdouble, GLint, GLint, GLdouble, GLdouble, GLint, GLint, GLdouble, GLdouble, GLint, GLint, const GLdouble *); +GLAPI void APIENTRY glDeformationMap3fSGIX (GLenum, GLfloat, GLfloat, GLint, GLint, GLfloat, GLfloat, GLint, GLint, GLfloat, GLfloat, GLint, GLint, const GLfloat *); +GLAPI void APIENTRY glDeformSGIX (GLbitfield); +GLAPI void APIENTRY glLoadIdentityDeformationMapSGIX (GLbitfield); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDEFORMATIONMAP3DSGIXPROC) (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, GLdouble w1, GLdouble w2, GLint wstride, GLint worder, const GLdouble *points); +typedef void (APIENTRYP PFNGLDEFORMATIONMAP3FSGIXPROC) (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, GLfloat w1, GLfloat w2, GLint wstride, GLint worder, const GLfloat *points); +typedef void (APIENTRYP PFNGLDEFORMSGIXPROC) (GLbitfield mask); +typedef void (APIENTRYP PFNGLLOADIDENTITYDEFORMATIONMAPSGIXPROC) (GLbitfield mask); +#endif + +#ifndef GL_SGIX_reference_plane +#define GL_SGIX_reference_plane 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glReferencePlaneSGIX (const GLdouble *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLREFERENCEPLANESGIXPROC) (const GLdouble *equation); +#endif + +#ifndef GL_SGIX_flush_raster +#define GL_SGIX_flush_raster 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFlushRasterSGIX (void); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLFLUSHRASTERSGIXPROC) (void); +#endif + +#ifndef GL_SGIX_depth_texture +#define GL_SGIX_depth_texture 1 +#endif + +#ifndef GL_SGIS_fog_function +#define GL_SGIS_fog_function 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFogFuncSGIS (GLsizei, const GLfloat *); +GLAPI void APIENTRY glGetFogFuncSGIS (GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLFOGFUNCSGISPROC) (GLsizei n, const GLfloat *points); +typedef void (APIENTRYP PFNGLGETFOGFUNCSGISPROC) (GLfloat *points); +#endif + +#ifndef GL_SGIX_fog_offset +#define GL_SGIX_fog_offset 1 +#endif + +#ifndef GL_HP_image_transform +#define GL_HP_image_transform 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glImageTransformParameteriHP (GLenum, GLenum, GLint); +GLAPI void APIENTRY glImageTransformParameterfHP (GLenum, GLenum, GLfloat); +GLAPI void APIENTRY glImageTransformParameterivHP (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glImageTransformParameterfvHP (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glGetImageTransformParameterivHP (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetImageTransformParameterfvHP (GLenum, GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERIHPPROC) (GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERFHPPROC) (GLenum target, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, GLfloat *params); +#endif + +#ifndef GL_HP_convolution_border_modes +#define GL_HP_convolution_border_modes 1 +#endif + +#ifndef GL_SGIX_texture_add_env +#define GL_SGIX_texture_add_env 1 +#endif + +#ifndef GL_EXT_color_subtable +#define GL_EXT_color_subtable 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorSubTableEXT (GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glCopyColorSubTableEXT (GLenum, GLsizei, GLint, GLint, GLsizei); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOPYCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); +#endif + +#ifndef GL_PGI_vertex_hints +#define GL_PGI_vertex_hints 1 +#endif + +#ifndef GL_PGI_misc_hints +#define GL_PGI_misc_hints 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glHintPGI (GLenum, GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLHINTPGIPROC) (GLenum target, GLint mode); +#endif + +#ifndef GL_EXT_paletted_texture +#define GL_EXT_paletted_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorTableEXT (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); +GLAPI void APIENTRY glGetColorTableEXT (GLenum, GLenum, GLenum, GLvoid *); +GLAPI void APIENTRY glGetColorTableParameterivEXT (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetColorTableParameterfvEXT (GLenum, GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOLORTABLEEXTPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); +typedef void (APIENTRYP PFNGLGETCOLORTABLEEXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *data); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +#endif + +#ifndef GL_EXT_clip_volume_hint +#define GL_EXT_clip_volume_hint 1 +#endif + +#ifndef GL_SGIX_list_priority +#define GL_SGIX_list_priority 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetListParameterfvSGIX (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetListParameterivSGIX (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glListParameterfSGIX (GLuint, GLenum, GLfloat); +GLAPI void APIENTRY glListParameterfvSGIX (GLuint, GLenum, const GLfloat *); +GLAPI void APIENTRY glListParameteriSGIX (GLuint, GLenum, GLint); +GLAPI void APIENTRY glListParameterivSGIX (GLuint, GLenum, const GLint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGETLISTPARAMETERFVSGIXPROC) (GLuint list, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETLISTPARAMETERIVSGIXPROC) (GLuint list, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLLISTPARAMETERFSGIXPROC) (GLuint list, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLLISTPARAMETERFVSGIXPROC) (GLuint list, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLLISTPARAMETERISGIXPROC) (GLuint list, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLLISTPARAMETERIVSGIXPROC) (GLuint list, GLenum pname, const GLint *params); +#endif + +#ifndef GL_SGIX_ir_instrument1 +#define GL_SGIX_ir_instrument1 1 +#endif + +#ifndef GL_SGIX_calligraphic_fragment +#define GL_SGIX_calligraphic_fragment 1 +#endif + +#ifndef GL_SGIX_texture_lod_bias +#define GL_SGIX_texture_lod_bias 1 +#endif + +#ifndef GL_SGIX_shadow_ambient +#define GL_SGIX_shadow_ambient 1 +#endif + +#ifndef GL_EXT_index_texture +#define GL_EXT_index_texture 1 +#endif + +#ifndef GL_EXT_index_material +#define GL_EXT_index_material 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glIndexMaterialEXT (GLenum, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLINDEXMATERIALEXTPROC) (GLenum face, GLenum mode); +#endif + +#ifndef GL_EXT_index_func +#define GL_EXT_index_func 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glIndexFuncEXT (GLenum, GLclampf); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLINDEXFUNCEXTPROC) (GLenum func, GLclampf ref); +#endif + +#ifndef GL_EXT_index_array_formats +#define GL_EXT_index_array_formats 1 +#endif + +#ifndef GL_EXT_compiled_vertex_array +#define GL_EXT_compiled_vertex_array 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glLockArraysEXT (GLint, GLsizei); +GLAPI void APIENTRY glUnlockArraysEXT (void); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLLOCKARRAYSEXTPROC) (GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLUNLOCKARRAYSEXTPROC) (void); +#endif + +#ifndef GL_EXT_cull_vertex +#define GL_EXT_cull_vertex 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCullParameterdvEXT (GLenum, GLdouble *); +GLAPI void APIENTRY glCullParameterfvEXT (GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCULLPARAMETERDVEXTPROC) (GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLCULLPARAMETERFVEXTPROC) (GLenum pname, GLfloat *params); +#endif + +#ifndef GL_SGIX_ycrcb +#define GL_SGIX_ycrcb 1 +#endif + +#ifndef GL_SGIX_fragment_lighting +#define GL_SGIX_fragment_lighting 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFragmentColorMaterialSGIX (GLenum, GLenum); +GLAPI void APIENTRY glFragmentLightfSGIX (GLenum, GLenum, GLfloat); +GLAPI void APIENTRY glFragmentLightfvSGIX (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glFragmentLightiSGIX (GLenum, GLenum, GLint); +GLAPI void APIENTRY glFragmentLightivSGIX (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glFragmentLightModelfSGIX (GLenum, GLfloat); +GLAPI void APIENTRY glFragmentLightModelfvSGIX (GLenum, const GLfloat *); +GLAPI void APIENTRY glFragmentLightModeliSGIX (GLenum, GLint); +GLAPI void APIENTRY glFragmentLightModelivSGIX (GLenum, const GLint *); +GLAPI void APIENTRY glFragmentMaterialfSGIX (GLenum, GLenum, GLfloat); +GLAPI void APIENTRY glFragmentMaterialfvSGIX (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glFragmentMaterialiSGIX (GLenum, GLenum, GLint); +GLAPI void APIENTRY glFragmentMaterialivSGIX (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glGetFragmentLightfvSGIX (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetFragmentLightivSGIX (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetFragmentMaterialfvSGIX (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetFragmentMaterialivSGIX (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glLightEnviSGIX (GLenum, GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLFRAGMENTCOLORMATERIALSGIXPROC) (GLenum face, GLenum mode); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTFSGIXPROC) (GLenum light, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTISGIXPROC) (GLenum light, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELFSGIXPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELFVSGIXPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELISGIXPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELIVSGIXPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALFSGIXPROC) (GLenum face, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALISGIXPROC) (GLenum face, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLLIGHTENVISGIXPROC) (GLenum pname, GLint param); +#endif + +#ifndef GL_IBM_rasterpos_clip +#define GL_IBM_rasterpos_clip 1 +#endif + +#ifndef GL_HP_texture_lighting +#define GL_HP_texture_lighting 1 +#endif + +#ifndef GL_EXT_draw_range_elements +#define GL_EXT_draw_range_elements 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawRangeElementsEXT (GLenum, GLuint, GLuint, GLsizei, GLenum, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSEXTPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); +#endif + +#ifndef GL_WIN_phong_shading +#define GL_WIN_phong_shading 1 +#endif + +#ifndef GL_WIN_specular_fog +#define GL_WIN_specular_fog 1 +#endif + +#ifndef GL_EXT_light_texture +#define GL_EXT_light_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glApplyTextureEXT (GLenum); +GLAPI void APIENTRY glTextureLightEXT (GLenum); +GLAPI void APIENTRY glTextureMaterialEXT (GLenum, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLAPPLYTEXTUREEXTPROC) (GLenum mode); +typedef void (APIENTRYP PFNGLTEXTURELIGHTEXTPROC) (GLenum pname); +typedef void (APIENTRYP PFNGLTEXTUREMATERIALEXTPROC) (GLenum face, GLenum mode); +#endif + +#ifndef GL_SGIX_blend_alpha_minmax +#define GL_SGIX_blend_alpha_minmax 1 +#endif + +#ifndef GL_EXT_bgra +#define GL_EXT_bgra 1 +#endif + +#ifndef GL_SGIX_async +#define GL_SGIX_async 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glAsyncMarkerSGIX (GLuint); +GLAPI GLint APIENTRY glFinishAsyncSGIX (GLuint *); +GLAPI GLint APIENTRY glPollAsyncSGIX (GLuint *); +GLAPI GLuint APIENTRY glGenAsyncMarkersSGIX (GLsizei); +GLAPI void APIENTRY glDeleteAsyncMarkersSGIX (GLuint, GLsizei); +GLAPI GLboolean APIENTRY glIsAsyncMarkerSGIX (GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLASYNCMARKERSGIXPROC) (GLuint marker); +typedef GLint (APIENTRYP PFNGLFINISHASYNCSGIXPROC) (GLuint *markerp); +typedef GLint (APIENTRYP PFNGLPOLLASYNCSGIXPROC) (GLuint *markerp); +typedef GLuint (APIENTRYP PFNGLGENASYNCMARKERSSGIXPROC) (GLsizei range); +typedef void (APIENTRYP PFNGLDELETEASYNCMARKERSSGIXPROC) (GLuint marker, GLsizei range); +typedef GLboolean (APIENTRYP PFNGLISASYNCMARKERSGIXPROC) (GLuint marker); +#endif + +#ifndef GL_SGIX_async_pixel +#define GL_SGIX_async_pixel 1 +#endif + +#ifndef GL_SGIX_async_histogram +#define GL_SGIX_async_histogram 1 +#endif + +#ifndef GL_INTEL_parallel_arrays +#define GL_INTEL_parallel_arrays 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexPointervINTEL (GLint, GLenum, const GLvoid* *); +GLAPI void APIENTRY glNormalPointervINTEL (GLenum, const GLvoid* *); +GLAPI void APIENTRY glColorPointervINTEL (GLint, GLenum, const GLvoid* *); +GLAPI void APIENTRY glTexCoordPointervINTEL (GLint, GLenum, const GLvoid* *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLVERTEXPOINTERVINTELPROC) (GLint size, GLenum type, const GLvoid* *pointer); +typedef void (APIENTRYP PFNGLNORMALPOINTERVINTELPROC) (GLenum type, const GLvoid* *pointer); +typedef void (APIENTRYP PFNGLCOLORPOINTERVINTELPROC) (GLint size, GLenum type, const GLvoid* *pointer); +typedef void (APIENTRYP PFNGLTEXCOORDPOINTERVINTELPROC) (GLint size, GLenum type, const GLvoid* *pointer); +#endif + +#ifndef GL_HP_occlusion_test +#define GL_HP_occlusion_test 1 +#endif + +#ifndef GL_EXT_pixel_transform +#define GL_EXT_pixel_transform 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelTransformParameteriEXT (GLenum, GLenum, GLint); +GLAPI void APIENTRY glPixelTransformParameterfEXT (GLenum, GLenum, GLfloat); +GLAPI void APIENTRY glPixelTransformParameterivEXT (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glPixelTransformParameterfvEXT (GLenum, GLenum, const GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat *params); +#endif + +#ifndef GL_EXT_pixel_transform_color_table +#define GL_EXT_pixel_transform_color_table 1 +#endif + +#ifndef GL_EXT_shared_texture_palette +#define GL_EXT_shared_texture_palette 1 +#endif + +#ifndef GL_EXT_separate_specular_color +#define GL_EXT_separate_specular_color 1 +#endif + +#ifndef GL_EXT_secondary_color +#define GL_EXT_secondary_color 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSecondaryColor3bEXT (GLbyte, GLbyte, GLbyte); +GLAPI void APIENTRY glSecondaryColor3bvEXT (const GLbyte *); +GLAPI void APIENTRY glSecondaryColor3dEXT (GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glSecondaryColor3dvEXT (const GLdouble *); +GLAPI void APIENTRY glSecondaryColor3fEXT (GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glSecondaryColor3fvEXT (const GLfloat *); +GLAPI void APIENTRY glSecondaryColor3iEXT (GLint, GLint, GLint); +GLAPI void APIENTRY glSecondaryColor3ivEXT (const GLint *); +GLAPI void APIENTRY glSecondaryColor3sEXT (GLshort, GLshort, GLshort); +GLAPI void APIENTRY glSecondaryColor3svEXT (const GLshort *); +GLAPI void APIENTRY glSecondaryColor3ubEXT (GLubyte, GLubyte, GLubyte); +GLAPI void APIENTRY glSecondaryColor3ubvEXT (const GLubyte *); +GLAPI void APIENTRY glSecondaryColor3uiEXT (GLuint, GLuint, GLuint); +GLAPI void APIENTRY glSecondaryColor3uivEXT (const GLuint *); +GLAPI void APIENTRY glSecondaryColor3usEXT (GLushort, GLushort, GLushort); +GLAPI void APIENTRY glSecondaryColor3usvEXT (const GLushort *); +GLAPI void APIENTRY glSecondaryColorPointerEXT (GLint, GLenum, GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BEXTPROC) (GLbyte red, GLbyte green, GLbyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BVEXTPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DEXTPROC) (GLdouble red, GLdouble green, GLdouble blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DVEXTPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FEXTPROC) (GLfloat red, GLfloat green, GLfloat blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FVEXTPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IEXTPROC) (GLint red, GLint green, GLint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IVEXTPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SEXTPROC) (GLshort red, GLshort green, GLshort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SVEXTPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBEXTPROC) (GLubyte red, GLubyte green, GLubyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBVEXTPROC) (const GLubyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIEXTPROC) (GLuint red, GLuint green, GLuint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIVEXTPROC) (const GLuint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USEXTPROC) (GLushort red, GLushort green, GLushort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USVEXTPROC) (const GLushort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); +#endif + +#ifndef GL_EXT_texture_perturb_normal +#define GL_EXT_texture_perturb_normal 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTextureNormalEXT (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTEXTURENORMALEXTPROC) (GLenum mode); +#endif + +#ifndef GL_EXT_multi_draw_arrays +#define GL_EXT_multi_draw_arrays 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiDrawArraysEXT (GLenum, GLint *, GLsizei *, GLsizei); +GLAPI void APIENTRY glMultiDrawElementsEXT (GLenum, const GLsizei *, GLenum, const GLvoid* *, GLsizei); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSEXTPROC) (GLenum mode, GLint *first, GLsizei *count, GLsizei primcount); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSEXTPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount); +#endif + +#ifndef GL_EXT_fog_coord +#define GL_EXT_fog_coord 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFogCoordfEXT (GLfloat); +GLAPI void APIENTRY glFogCoordfvEXT (const GLfloat *); +GLAPI void APIENTRY glFogCoorddEXT (GLdouble); +GLAPI void APIENTRY glFogCoorddvEXT (const GLdouble *); +GLAPI void APIENTRY glFogCoordPointerEXT (GLenum, GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLFOGCOORDFEXTPROC) (GLfloat coord); +typedef void (APIENTRYP PFNGLFOGCOORDFVEXTPROC) (const GLfloat *coord); +typedef void (APIENTRYP PFNGLFOGCOORDDEXTPROC) (GLdouble coord); +typedef void (APIENTRYP PFNGLFOGCOORDDVEXTPROC) (const GLdouble *coord); +typedef void (APIENTRYP PFNGLFOGCOORDPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); +#endif + +#ifndef GL_REND_screen_coordinates +#define GL_REND_screen_coordinates 1 +#endif + +#ifndef GL_EXT_coordinate_frame +#define GL_EXT_coordinate_frame 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTangent3bEXT (GLbyte, GLbyte, GLbyte); +GLAPI void APIENTRY glTangent3bvEXT (const GLbyte *); +GLAPI void APIENTRY glTangent3dEXT (GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glTangent3dvEXT (const GLdouble *); +GLAPI void APIENTRY glTangent3fEXT (GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTangent3fvEXT (const GLfloat *); +GLAPI void APIENTRY glTangent3iEXT (GLint, GLint, GLint); +GLAPI void APIENTRY glTangent3ivEXT (const GLint *); +GLAPI void APIENTRY glTangent3sEXT (GLshort, GLshort, GLshort); +GLAPI void APIENTRY glTangent3svEXT (const GLshort *); +GLAPI void APIENTRY glBinormal3bEXT (GLbyte, GLbyte, GLbyte); +GLAPI void APIENTRY glBinormal3bvEXT (const GLbyte *); +GLAPI void APIENTRY glBinormal3dEXT (GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glBinormal3dvEXT (const GLdouble *); +GLAPI void APIENTRY glBinormal3fEXT (GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glBinormal3fvEXT (const GLfloat *); +GLAPI void APIENTRY glBinormal3iEXT (GLint, GLint, GLint); +GLAPI void APIENTRY glBinormal3ivEXT (const GLint *); +GLAPI void APIENTRY glBinormal3sEXT (GLshort, GLshort, GLshort); +GLAPI void APIENTRY glBinormal3svEXT (const GLshort *); +GLAPI void APIENTRY glTangentPointerEXT (GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glBinormalPointerEXT (GLenum, GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTANGENT3BEXTPROC) (GLbyte tx, GLbyte ty, GLbyte tz); +typedef void (APIENTRYP PFNGLTANGENT3BVEXTPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLTANGENT3DEXTPROC) (GLdouble tx, GLdouble ty, GLdouble tz); +typedef void (APIENTRYP PFNGLTANGENT3DVEXTPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLTANGENT3FEXTPROC) (GLfloat tx, GLfloat ty, GLfloat tz); +typedef void (APIENTRYP PFNGLTANGENT3FVEXTPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLTANGENT3IEXTPROC) (GLint tx, GLint ty, GLint tz); +typedef void (APIENTRYP PFNGLTANGENT3IVEXTPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLTANGENT3SEXTPROC) (GLshort tx, GLshort ty, GLshort tz); +typedef void (APIENTRYP PFNGLTANGENT3SVEXTPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLBINORMAL3BEXTPROC) (GLbyte bx, GLbyte by, GLbyte bz); +typedef void (APIENTRYP PFNGLBINORMAL3BVEXTPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLBINORMAL3DEXTPROC) (GLdouble bx, GLdouble by, GLdouble bz); +typedef void (APIENTRYP PFNGLBINORMAL3DVEXTPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLBINORMAL3FEXTPROC) (GLfloat bx, GLfloat by, GLfloat bz); +typedef void (APIENTRYP PFNGLBINORMAL3FVEXTPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLBINORMAL3IEXTPROC) (GLint bx, GLint by, GLint bz); +typedef void (APIENTRYP PFNGLBINORMAL3IVEXTPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLBINORMAL3SEXTPROC) (GLshort bx, GLshort by, GLshort bz); +typedef void (APIENTRYP PFNGLBINORMAL3SVEXTPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLTANGENTPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLBINORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); +#endif + +#ifndef GL_EXT_texture_env_combine +#define GL_EXT_texture_env_combine 1 +#endif + +#ifndef GL_APPLE_specular_vector +#define GL_APPLE_specular_vector 1 +#endif + +#ifndef GL_APPLE_transform_hint +#define GL_APPLE_transform_hint 1 +#endif + +#ifndef GL_SGIX_fog_scale +#define GL_SGIX_fog_scale 1 +#endif + +#ifndef GL_SUNX_constant_data +#define GL_SUNX_constant_data 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFinishTextureSUNX (void); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLFINISHTEXTURESUNXPROC) (void); +#endif + +#ifndef GL_SUN_global_alpha +#define GL_SUN_global_alpha 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGlobalAlphaFactorbSUN (GLbyte); +GLAPI void APIENTRY glGlobalAlphaFactorsSUN (GLshort); +GLAPI void APIENTRY glGlobalAlphaFactoriSUN (GLint); +GLAPI void APIENTRY glGlobalAlphaFactorfSUN (GLfloat); +GLAPI void APIENTRY glGlobalAlphaFactordSUN (GLdouble); +GLAPI void APIENTRY glGlobalAlphaFactorubSUN (GLubyte); +GLAPI void APIENTRY glGlobalAlphaFactorusSUN (GLushort); +GLAPI void APIENTRY glGlobalAlphaFactoruiSUN (GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORBSUNPROC) (GLbyte factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORSSUNPROC) (GLshort factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORISUNPROC) (GLint factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORFSUNPROC) (GLfloat factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORDSUNPROC) (GLdouble factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORUBSUNPROC) (GLubyte factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORUSSUNPROC) (GLushort factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORUISUNPROC) (GLuint factor); +#endif + +#ifndef GL_SUN_triangle_list +#define GL_SUN_triangle_list 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glReplacementCodeuiSUN (GLuint); +GLAPI void APIENTRY glReplacementCodeusSUN (GLushort); +GLAPI void APIENTRY glReplacementCodeubSUN (GLubyte); +GLAPI void APIENTRY glReplacementCodeuivSUN (const GLuint *); +GLAPI void APIENTRY glReplacementCodeusvSUN (const GLushort *); +GLAPI void APIENTRY glReplacementCodeubvSUN (const GLubyte *); +GLAPI void APIENTRY glReplacementCodePointerSUN (GLenum, GLsizei, const GLvoid* *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUISUNPROC) (GLuint code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUSSUNPROC) (GLushort code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUBSUNPROC) (GLubyte code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUIVSUNPROC) (const GLuint *code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUSVSUNPROC) (const GLushort *code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUBVSUNPROC) (const GLubyte *code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEPOINTERSUNPROC) (GLenum type, GLsizei stride, const GLvoid* *pointer); +#endif + +#ifndef GL_SUN_vertex +#define GL_SUN_vertex 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColor4ubVertex2fSUN (GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat); +GLAPI void APIENTRY glColor4ubVertex2fvSUN (const GLubyte *, const GLfloat *); +GLAPI void APIENTRY glColor4ubVertex3fSUN (GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glColor4ubVertex3fvSUN (const GLubyte *, const GLfloat *); +GLAPI void APIENTRY glColor3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glColor3fVertex3fvSUN (const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glColor4fNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glColor4fNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glTexCoord2fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTexCoord2fVertex3fvSUN (const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glTexCoord4fVertex4fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTexCoord4fVertex4fvSUN (const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glTexCoord2fColor4ubVertex3fSUN (GLfloat, GLfloat, GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTexCoord2fColor4ubVertex3fvSUN (const GLfloat *, const GLubyte *, const GLfloat *); +GLAPI void APIENTRY glTexCoord2fColor3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTexCoord2fColor3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glTexCoord2fNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTexCoord2fNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glTexCoord2fColor4fNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTexCoord2fColor4fNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glTexCoord4fColor4fNormal3fVertex4fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glTexCoord4fColor4fNormal3fVertex4fvSUN (const GLfloat *, const GLfloat *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiVertex3fSUN (GLuint, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiVertex3fvSUN (const GLuint *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiColor4ubVertex3fSUN (GLuint, GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiColor4ubVertex3fvSUN (const GLuint *, const GLubyte *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiColor3fVertex3fSUN (GLuint, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiColor3fVertex3fvSUN (const GLuint *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiNormal3fVertex3fSUN (GLuint, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiNormal3fVertex3fvSUN (const GLuint *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiColor4fNormal3fVertex3fSUN (GLuint, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiColor4fNormal3fVertex3fvSUN (const GLuint *, const GLfloat *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fVertex3fSUN (GLuint, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fVertex3fvSUN (const GLuint *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN (GLuint, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN (const GLuint *, const GLfloat *, const GLfloat *, const GLfloat *); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN (GLuint, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN (const GLuint *, const GLfloat *, const GLfloat *, const GLfloat *, const GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX2FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX2FVSUNPROC) (const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX3FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX3FVSUNPROC) (const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLCOLOR3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLCOLOR3FVERTEX3FVSUNPROC) (const GLfloat *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLNORMAL3FVERTEX3FSUNPROC) (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD4FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLTEXCOORD4FVERTEX4FVSUNPROC) (const GLfloat *tc, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC) (const GLfloat *tc, const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC) (GLuint rc, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC) (GLuint rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC) (const GLuint *rc, const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *tc, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +#endif + +#ifndef GL_EXT_blend_func_separate +#define GL_EXT_blend_func_separate 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendFuncSeparateEXT (GLenum, GLenum, GLenum, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEEXTPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +#endif + +#ifndef GL_INGR_blend_func_separate +#define GL_INGR_blend_func_separate 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendFuncSeparateINGR (GLenum, GLenum, GLenum, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEINGRPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +#endif + +#ifndef GL_INGR_color_clamp +#define GL_INGR_color_clamp 1 +#endif + +#ifndef GL_INGR_interlace_read +#define GL_INGR_interlace_read 1 +#endif + +#ifndef GL_EXT_stencil_wrap +#define GL_EXT_stencil_wrap 1 +#endif + +#ifndef GL_EXT_422_pixels +#define GL_EXT_422_pixels 1 +#endif + +#ifndef GL_NV_texgen_reflection +#define GL_NV_texgen_reflection 1 +#endif + +#ifndef GL_SUN_convolution_border_modes +#define GL_SUN_convolution_border_modes 1 +#endif + +#ifndef GL_EXT_texture_env_add +#define GL_EXT_texture_env_add 1 +#endif + +#ifndef GL_EXT_texture_lod_bias +#define GL_EXT_texture_lod_bias 1 +#endif + +#ifndef GL_EXT_texture_filter_anisotropic +#define GL_EXT_texture_filter_anisotropic 1 +#endif + +#ifndef GL_EXT_vertex_weighting +#define GL_EXT_vertex_weighting 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexWeightfEXT (GLfloat); +GLAPI void APIENTRY glVertexWeightfvEXT (const GLfloat *); +GLAPI void APIENTRY glVertexWeightPointerEXT (GLsizei, GLenum, GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLVERTEXWEIGHTFEXTPROC) (GLfloat weight); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTFVEXTPROC) (const GLfloat *weight); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTPOINTEREXTPROC) (GLsizei size, GLenum type, GLsizei stride, const GLvoid *pointer); +#endif + +#ifndef GL_NV_light_max_exponent +#define GL_NV_light_max_exponent 1 +#endif + +#ifndef GL_NV_vertex_array_range +#define GL_NV_vertex_array_range 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFlushVertexArrayRangeNV (void); +GLAPI void APIENTRY glVertexArrayRangeNV (GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLFLUSHVERTEXARRAYRANGENVPROC) (void); +typedef void (APIENTRYP PFNGLVERTEXARRAYRANGENVPROC) (GLsizei length, const GLvoid *pointer); +#endif + +#ifndef GL_NV_register_combiners +#define GL_NV_register_combiners 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCombinerParameterfvNV (GLenum, const GLfloat *); +GLAPI void APIENTRY glCombinerParameterfNV (GLenum, GLfloat); +GLAPI void APIENTRY glCombinerParameterivNV (GLenum, const GLint *); +GLAPI void APIENTRY glCombinerParameteriNV (GLenum, GLint); +GLAPI void APIENTRY glCombinerInputNV (GLenum, GLenum, GLenum, GLenum, GLenum, GLenum); +GLAPI void APIENTRY glCombinerOutputNV (GLenum, GLenum, GLenum, GLenum, GLenum, GLenum, GLenum, GLboolean, GLboolean, GLboolean); +GLAPI void APIENTRY glFinalCombinerInputNV (GLenum, GLenum, GLenum, GLenum); +GLAPI void APIENTRY glGetCombinerInputParameterfvNV (GLenum, GLenum, GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetCombinerInputParameterivNV (GLenum, GLenum, GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetCombinerOutputParameterfvNV (GLenum, GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetCombinerOutputParameterivNV (GLenum, GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetFinalCombinerInputParameterfvNV (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetFinalCombinerInputParameterivNV (GLenum, GLenum, GLint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOMBINERPARAMETERFVNVPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCOMBINERPARAMETERFNVPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLCOMBINERPARAMETERIVNVPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOMBINERPARAMETERINVPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLCOMBINERINPUTNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +typedef void (APIENTRYP PFNGLCOMBINEROUTPUTNVPROC) (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum); +typedef void (APIENTRYP PFNGLFINALCOMBINERINPUTNVPROC) (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +typedef void (APIENTRYP PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC) (GLenum variable, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC) (GLenum variable, GLenum pname, GLint *params); +#endif + +#ifndef GL_NV_fog_distance +#define GL_NV_fog_distance 1 +#endif + +#ifndef GL_NV_texgen_emboss +#define GL_NV_texgen_emboss 1 +#endif + +#ifndef GL_NV_blend_square +#define GL_NV_blend_square 1 +#endif + +#ifndef GL_NV_texture_env_combine4 +#define GL_NV_texture_env_combine4 1 +#endif + +#ifndef GL_MESA_resize_buffers +#define GL_MESA_resize_buffers 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glResizeBuffersMESA (void); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLRESIZEBUFFERSMESAPROC) (void); +#endif + +#ifndef GL_MESA_window_pos +#define GL_MESA_window_pos 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glWindowPos2dMESA (GLdouble, GLdouble); +GLAPI void APIENTRY glWindowPos2dvMESA (const GLdouble *); +GLAPI void APIENTRY glWindowPos2fMESA (GLfloat, GLfloat); +GLAPI void APIENTRY glWindowPos2fvMESA (const GLfloat *); +GLAPI void APIENTRY glWindowPos2iMESA (GLint, GLint); +GLAPI void APIENTRY glWindowPos2ivMESA (const GLint *); +GLAPI void APIENTRY glWindowPos2sMESA (GLshort, GLshort); +GLAPI void APIENTRY glWindowPos2svMESA (const GLshort *); +GLAPI void APIENTRY glWindowPos3dMESA (GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glWindowPos3dvMESA (const GLdouble *); +GLAPI void APIENTRY glWindowPos3fMESA (GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glWindowPos3fvMESA (const GLfloat *); +GLAPI void APIENTRY glWindowPos3iMESA (GLint, GLint, GLint); +GLAPI void APIENTRY glWindowPos3ivMESA (const GLint *); +GLAPI void APIENTRY glWindowPos3sMESA (GLshort, GLshort, GLshort); +GLAPI void APIENTRY glWindowPos3svMESA (const GLshort *); +GLAPI void APIENTRY glWindowPos4dMESA (GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glWindowPos4dvMESA (const GLdouble *); +GLAPI void APIENTRY glWindowPos4fMESA (GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glWindowPos4fvMESA (const GLfloat *); +GLAPI void APIENTRY glWindowPos4iMESA (GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glWindowPos4ivMESA (const GLint *); +GLAPI void APIENTRY glWindowPos4sMESA (GLshort, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glWindowPos4svMESA (const GLshort *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLWINDOWPOS2DMESAPROC) (GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLWINDOWPOS2DVMESAPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2FMESAPROC) (GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLWINDOWPOS2FVMESAPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2IMESAPROC) (GLint x, GLint y); +typedef void (APIENTRYP PFNGLWINDOWPOS2IVMESAPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2SMESAPROC) (GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLWINDOWPOS2SVMESAPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3DMESAPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLWINDOWPOS3DVMESAPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3FMESAPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLWINDOWPOS3FVMESAPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3IMESAPROC) (GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLWINDOWPOS3IVMESAPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3SMESAPROC) (GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLWINDOWPOS3SVMESAPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4DMESAPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLWINDOWPOS4DVMESAPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4FMESAPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLWINDOWPOS4FVMESAPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4IMESAPROC) (GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLWINDOWPOS4IVMESAPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4SMESAPROC) (GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLWINDOWPOS4SVMESAPROC) (const GLshort *v); +#endif + +#ifndef GL_IBM_cull_vertex +#define GL_IBM_cull_vertex 1 +#endif + +#ifndef GL_IBM_multimode_draw_arrays +#define GL_IBM_multimode_draw_arrays 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiModeDrawArraysIBM (const GLenum *, const GLint *, const GLsizei *, GLsizei, GLint); +GLAPI void APIENTRY glMultiModeDrawElementsIBM (const GLenum *, const GLsizei *, GLenum, const GLvoid* const *, GLsizei, GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLMULTIMODEDRAWARRAYSIBMPROC) (const GLenum *mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride); +typedef void (APIENTRYP PFNGLMULTIMODEDRAWELEMENTSIBMPROC) (const GLenum *mode, const GLsizei *count, GLenum type, const GLvoid* const *indices, GLsizei primcount, GLint modestride); +#endif + +#ifndef GL_IBM_vertex_array_lists +#define GL_IBM_vertex_array_lists 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); +GLAPI void APIENTRY glSecondaryColorPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); +GLAPI void APIENTRY glEdgeFlagPointerListIBM (GLint, const GLboolean* *, GLint); +GLAPI void APIENTRY glFogCoordPointerListIBM (GLenum, GLint, const GLvoid* *, GLint); +GLAPI void APIENTRY glIndexPointerListIBM (GLenum, GLint, const GLvoid* *, GLint); +GLAPI void APIENTRY glNormalPointerListIBM (GLenum, GLint, const GLvoid* *, GLint); +GLAPI void APIENTRY glTexCoordPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); +GLAPI void APIENTRY glVertexPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLSECONDARYCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLEDGEFLAGPOINTERLISTIBMPROC) (GLint stride, const GLboolean* *pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLFOGCOORDPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLINDEXPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLNORMALPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLTEXCOORDPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLVERTEXPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); +#endif + +#ifndef GL_SGIX_subsample +#define GL_SGIX_subsample 1 +#endif + +#ifndef GL_SGIX_ycrcba +#define GL_SGIX_ycrcba 1 +#endif + +#ifndef GL_SGIX_ycrcb_subsample +#define GL_SGIX_ycrcb_subsample 1 +#endif + +#ifndef GL_SGIX_depth_pass_instrument +#define GL_SGIX_depth_pass_instrument 1 +#endif + +#ifndef GL_3DFX_texture_compression_FXT1 +#define GL_3DFX_texture_compression_FXT1 1 +#endif + +#ifndef GL_3DFX_multisample +#define GL_3DFX_multisample 1 +#endif + +#ifndef GL_3DFX_tbuffer +#define GL_3DFX_tbuffer 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTbufferMask3DFX (GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTBUFFERMASK3DFXPROC) (GLuint mask); +#endif + +#ifndef GL_EXT_multisample +#define GL_EXT_multisample 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSampleMaskEXT (GLclampf, GLboolean); +GLAPI void APIENTRY glSamplePatternEXT (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSAMPLEMASKEXTPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLSAMPLEPATTERNEXTPROC) (GLenum pattern); +#endif + +#ifndef GL_SGIX_vertex_preclip +#define GL_SGIX_vertex_preclip 1 +#endif + +#ifndef GL_SGIX_convolution_accuracy +#define GL_SGIX_convolution_accuracy 1 +#endif + +#ifndef GL_SGIX_resample +#define GL_SGIX_resample 1 +#endif + +#ifndef GL_SGIS_point_line_texgen +#define GL_SGIS_point_line_texgen 1 +#endif + +#ifndef GL_SGIS_texture_color_mask +#define GL_SGIS_texture_color_mask 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTextureColorMaskSGIS (GLboolean, GLboolean, GLboolean, GLboolean); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTEXTURECOLORMASKSGISPROC) (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); +#endif + +#ifndef GL_SGIX_igloo_interface +#define GL_SGIX_igloo_interface 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glIglooInterfaceSGIX (GLenum, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLIGLOOINTERFACESGIXPROC) (GLenum pname, const GLvoid *params); +#endif + +#ifndef GL_EXT_texture_env_dot3 +#define GL_EXT_texture_env_dot3 1 +#endif + +#ifndef GL_ATI_texture_mirror_once +#define GL_ATI_texture_mirror_once 1 +#endif + +#ifndef GL_NV_fence +#define GL_NV_fence 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDeleteFencesNV (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenFencesNV (GLsizei, GLuint *); +GLAPI GLboolean APIENTRY glIsFenceNV (GLuint); +GLAPI GLboolean APIENTRY glTestFenceNV (GLuint); +GLAPI void APIENTRY glGetFenceivNV (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glFinishFenceNV (GLuint); +GLAPI void APIENTRY glSetFenceNV (GLuint, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDELETEFENCESNVPROC) (GLsizei n, const GLuint *fences); +typedef void (APIENTRYP PFNGLGENFENCESNVPROC) (GLsizei n, GLuint *fences); +typedef GLboolean (APIENTRYP PFNGLISFENCENVPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLTESTFENCENVPROC) (GLuint fence); +typedef void (APIENTRYP PFNGLGETFENCEIVNVPROC) (GLuint fence, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLFINISHFENCENVPROC) (GLuint fence); +typedef void (APIENTRYP PFNGLSETFENCENVPROC) (GLuint fence, GLenum condition); +#endif + +#ifndef GL_NV_evaluators +#define GL_NV_evaluators 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMapControlPointsNV (GLenum, GLuint, GLenum, GLsizei, GLsizei, GLint, GLint, GLboolean, const GLvoid *); +GLAPI void APIENTRY glMapParameterivNV (GLenum, GLenum, const GLint *); +GLAPI void APIENTRY glMapParameterfvNV (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glGetMapControlPointsNV (GLenum, GLuint, GLenum, GLsizei, GLsizei, GLboolean, GLvoid *); +GLAPI void APIENTRY glGetMapParameterivNV (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGetMapParameterfvNV (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetMapAttribParameterivNV (GLenum, GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetMapAttribParameterfvNV (GLenum, GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glEvalMapsNV (GLenum, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const GLvoid *points); +typedef void (APIENTRYP PFNGLMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, GLvoid *points); +typedef void (APIENTRYP PFNGLGETMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMAPATTRIBPARAMETERIVNVPROC) (GLenum target, GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMAPATTRIBPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLEVALMAPSNVPROC) (GLenum target, GLenum mode); +#endif + +#ifndef GL_NV_packed_depth_stencil +#define GL_NV_packed_depth_stencil 1 +#endif + +#ifndef GL_NV_register_combiners2 +#define GL_NV_register_combiners2 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCombinerStageParameterfvNV (GLenum, GLenum, const GLfloat *); +GLAPI void APIENTRY glGetCombinerStageParameterfvNV (GLenum, GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, GLfloat *params); +#endif + +#ifndef GL_NV_texture_compression_vtc +#define GL_NV_texture_compression_vtc 1 +#endif + +#ifndef GL_NV_texture_rectangle +#define GL_NV_texture_rectangle 1 +#endif + +#ifndef GL_NV_texture_shader +#define GL_NV_texture_shader 1 +#endif + +#ifndef GL_NV_texture_shader2 +#define GL_NV_texture_shader2 1 +#endif + +#ifndef GL_NV_vertex_array_range2 +#define GL_NV_vertex_array_range2 1 +#endif + +#ifndef GL_NV_vertex_program +#define GL_NV_vertex_program 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLboolean APIENTRY glAreProgramsResidentNV (GLsizei, const GLuint *, GLboolean *); +GLAPI void APIENTRY glBindProgramNV (GLenum, GLuint); +GLAPI void APIENTRY glDeleteProgramsNV (GLsizei, const GLuint *); +GLAPI void APIENTRY glExecuteProgramNV (GLenum, GLuint, const GLfloat *); +GLAPI void APIENTRY glGenProgramsNV (GLsizei, GLuint *); +GLAPI void APIENTRY glGetProgramParameterdvNV (GLenum, GLuint, GLenum, GLdouble *); +GLAPI void APIENTRY glGetProgramParameterfvNV (GLenum, GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetProgramivNV (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetProgramStringNV (GLuint, GLenum, GLubyte *); +GLAPI void APIENTRY glGetTrackMatrixivNV (GLenum, GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetVertexAttribdvNV (GLuint, GLenum, GLdouble *); +GLAPI void APIENTRY glGetVertexAttribfvNV (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetVertexAttribivNV (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetVertexAttribPointervNV (GLuint, GLenum, GLvoid* *); +GLAPI GLboolean APIENTRY glIsProgramNV (GLuint); +GLAPI void APIENTRY glLoadProgramNV (GLenum, GLuint, GLsizei, const GLubyte *); +GLAPI void APIENTRY glProgramParameter4dNV (GLenum, GLuint, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glProgramParameter4dvNV (GLenum, GLuint, const GLdouble *); +GLAPI void APIENTRY glProgramParameter4fNV (GLenum, GLuint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glProgramParameter4fvNV (GLenum, GLuint, const GLfloat *); +GLAPI void APIENTRY glProgramParameters4dvNV (GLenum, GLuint, GLuint, const GLdouble *); +GLAPI void APIENTRY glProgramParameters4fvNV (GLenum, GLuint, GLuint, const GLfloat *); +GLAPI void APIENTRY glRequestResidentProgramsNV (GLsizei, const GLuint *); +GLAPI void APIENTRY glTrackMatrixNV (GLenum, GLuint, GLenum, GLenum); +GLAPI void APIENTRY glVertexAttribPointerNV (GLuint, GLint, GLenum, GLsizei, const GLvoid *); +GLAPI void APIENTRY glVertexAttrib1dNV (GLuint, GLdouble); +GLAPI void APIENTRY glVertexAttrib1dvNV (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib1fNV (GLuint, GLfloat); +GLAPI void APIENTRY glVertexAttrib1fvNV (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib1sNV (GLuint, GLshort); +GLAPI void APIENTRY glVertexAttrib1svNV (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib2dNV (GLuint, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib2dvNV (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib2fNV (GLuint, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib2fvNV (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib2sNV (GLuint, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib2svNV (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib3dNV (GLuint, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib3dvNV (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib3fNV (GLuint, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib3fvNV (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib3sNV (GLuint, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib3svNV (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4dNV (GLuint, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexAttrib4dvNV (GLuint, const GLdouble *); +GLAPI void APIENTRY glVertexAttrib4fNV (GLuint, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexAttrib4fvNV (GLuint, const GLfloat *); +GLAPI void APIENTRY glVertexAttrib4sNV (GLuint, GLshort, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexAttrib4svNV (GLuint, const GLshort *); +GLAPI void APIENTRY glVertexAttrib4ubNV (GLuint, GLubyte, GLubyte, GLubyte, GLubyte); +GLAPI void APIENTRY glVertexAttrib4ubvNV (GLuint, const GLubyte *); +GLAPI void APIENTRY glVertexAttribs1dvNV (GLuint, GLsizei, const GLdouble *); +GLAPI void APIENTRY glVertexAttribs1fvNV (GLuint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glVertexAttribs1svNV (GLuint, GLsizei, const GLshort *); +GLAPI void APIENTRY glVertexAttribs2dvNV (GLuint, GLsizei, const GLdouble *); +GLAPI void APIENTRY glVertexAttribs2fvNV (GLuint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glVertexAttribs2svNV (GLuint, GLsizei, const GLshort *); +GLAPI void APIENTRY glVertexAttribs3dvNV (GLuint, GLsizei, const GLdouble *); +GLAPI void APIENTRY glVertexAttribs3fvNV (GLuint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glVertexAttribs3svNV (GLuint, GLsizei, const GLshort *); +GLAPI void APIENTRY glVertexAttribs4dvNV (GLuint, GLsizei, const GLdouble *); +GLAPI void APIENTRY glVertexAttribs4fvNV (GLuint, GLsizei, const GLfloat *); +GLAPI void APIENTRY glVertexAttribs4svNV (GLuint, GLsizei, const GLshort *); +GLAPI void APIENTRY glVertexAttribs4ubvNV (GLuint, GLsizei, const GLubyte *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLboolean (APIENTRYP PFNGLAREPROGRAMSRESIDENTNVPROC) (GLsizei n, const GLuint *programs, GLboolean *residences); +typedef void (APIENTRYP PFNGLBINDPROGRAMNVPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLDELETEPROGRAMSNVPROC) (GLsizei n, const GLuint *programs); +typedef void (APIENTRYP PFNGLEXECUTEPROGRAMNVPROC) (GLenum target, GLuint id, const GLfloat *params); +typedef void (APIENTRYP PFNGLGENPROGRAMSNVPROC) (GLsizei n, GLuint *programs); +typedef void (APIENTRYP PFNGLGETPROGRAMPARAMETERDVNVPROC) (GLenum target, GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETPROGRAMPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMIVNVPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMSTRINGNVPROC) (GLuint id, GLenum pname, GLubyte *program); +typedef void (APIENTRYP PFNGLGETTRACKMATRIXIVNVPROC) (GLenum target, GLuint address, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBDVNVPROC) (GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBFVNVPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIVNVPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVNVPROC) (GLuint index, GLenum pname, GLvoid* *pointer); +typedef GLboolean (APIENTRYP PFNGLISPROGRAMNVPROC) (GLuint id); +typedef void (APIENTRYP PFNGLLOADPROGRAMNVPROC) (GLenum target, GLuint id, GLsizei len, const GLubyte *program); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4DNVPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4DVNVPROC) (GLenum target, GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4FNVPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4FVNVPROC) (GLenum target, GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETERS4DVNVPROC) (GLenum target, GLuint index, GLuint count, const GLdouble *v); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETERS4FVNVPROC) (GLenum target, GLuint index, GLuint count, const GLfloat *v); +typedef void (APIENTRYP PFNGLREQUESTRESIDENTPROGRAMSNVPROC) (GLsizei n, const GLuint *programs); +typedef void (APIENTRYP PFNGLTRACKMATRIXNVPROC) (GLenum target, GLuint address, GLenum matrix, GLenum transform); +typedef void (APIENTRYP PFNGLVERTEXATTRIBPOINTERNVPROC) (GLuint index, GLint fsize, GLenum type, GLsizei stride, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DNVPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FNVPROC) (GLuint index, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SNVPROC) (GLuint index, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DNVPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FNVPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SNVPROC) (GLuint index, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBNVPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBVNVPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4UBVNVPROC) (GLuint index, GLsizei count, const GLubyte *v); +#endif + +#ifndef GL_SGIX_texture_coordinate_clamp +#define GL_SGIX_texture_coordinate_clamp 1 +#endif + +#ifndef GL_SGIX_scalebias_hint +#define GL_SGIX_scalebias_hint 1 +#endif + +#ifndef GL_OML_interlace +#define GL_OML_interlace 1 +#endif + +#ifndef GL_OML_subsample +#define GL_OML_subsample 1 +#endif + +#ifndef GL_OML_resample +#define GL_OML_resample 1 +#endif + +#ifndef GL_NV_copy_depth_to_color +#define GL_NV_copy_depth_to_color 1 +#endif + +#ifndef GL_ATI_envmap_bumpmap +#define GL_ATI_envmap_bumpmap 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexBumpParameterivATI (GLenum, const GLint *); +GLAPI void APIENTRY glTexBumpParameterfvATI (GLenum, const GLfloat *); +GLAPI void APIENTRY glGetTexBumpParameterivATI (GLenum, GLint *); +GLAPI void APIENTRY glGetTexBumpParameterfvATI (GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLTEXBUMPPARAMETERIVATIPROC) (GLenum pname, const GLint *param); +typedef void (APIENTRYP PFNGLTEXBUMPPARAMETERFVATIPROC) (GLenum pname, const GLfloat *param); +typedef void (APIENTRYP PFNGLGETTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); +typedef void (APIENTRYP PFNGLGETTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); +#endif + +#ifndef GL_ATI_fragment_shader +#define GL_ATI_fragment_shader 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint APIENTRY glGenFragmentShadersATI (GLuint); +GLAPI void APIENTRY glBindFragmentShaderATI (GLuint); +GLAPI void APIENTRY glDeleteFragmentShaderATI (GLuint); +GLAPI void APIENTRY glBeginFragmentShaderATI (void); +GLAPI void APIENTRY glEndFragmentShaderATI (void); +GLAPI void APIENTRY glPassTexCoordATI (GLuint, GLuint, GLenum); +GLAPI void APIENTRY glSampleMapATI (GLuint, GLuint, GLenum); +GLAPI void APIENTRY glColorFragmentOp1ATI (GLenum, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glColorFragmentOp2ATI (GLenum, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glColorFragmentOp3ATI (GLenum, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glAlphaFragmentOp1ATI (GLenum, GLuint, GLuint, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glAlphaFragmentOp2ATI (GLenum, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glAlphaFragmentOp3ATI (GLenum, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glSetFragmentShaderConstantATI (GLuint, const GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLuint (APIENTRYP PFNGLGENFRAGMENTSHADERSATIPROC) (GLuint range); +typedef void (APIENTRYP PFNGLBINDFRAGMENTSHADERATIPROC) (GLuint id); +typedef void (APIENTRYP PFNGLDELETEFRAGMENTSHADERATIPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINFRAGMENTSHADERATIPROC) (void); +typedef void (APIENTRYP PFNGLENDFRAGMENTSHADERATIPROC) (void); +typedef void (APIENTRYP PFNGLPASSTEXCOORDATIPROC) (GLuint dst, GLuint coord, GLenum swizzle); +typedef void (APIENTRYP PFNGLSAMPLEMAPATIPROC) (GLuint dst, GLuint interp, GLenum swizzle); +typedef void (APIENTRYP PFNGLCOLORFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +typedef void (APIENTRYP PFNGLCOLORFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +typedef void (APIENTRYP PFNGLCOLORFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); +typedef void (APIENTRYP PFNGLALPHAFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +typedef void (APIENTRYP PFNGLALPHAFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +typedef void (APIENTRYP PFNGLALPHAFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); +typedef void (APIENTRYP PFNGLSETFRAGMENTSHADERCONSTANTATIPROC) (GLuint dst, const GLfloat *value); +#endif + +#ifndef GL_ATI_pn_triangles +#define GL_ATI_pn_triangles 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPNTrianglesiATI (GLenum, GLint); +GLAPI void APIENTRY glPNTrianglesfATI (GLenum, GLfloat); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPNTRIANGLESIATIPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPNTRIANGLESFATIPROC) (GLenum pname, GLfloat param); +#endif + +#ifndef GL_ATI_vertex_array_object +#define GL_ATI_vertex_array_object 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint APIENTRY glNewObjectBufferATI (GLsizei, const GLvoid *, GLenum); +GLAPI GLboolean APIENTRY glIsObjectBufferATI (GLuint); +GLAPI void APIENTRY glUpdateObjectBufferATI (GLuint, GLuint, GLsizei, const GLvoid *, GLenum); +GLAPI void APIENTRY glGetObjectBufferfvATI (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetObjectBufferivATI (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glFreeObjectBufferATI (GLuint); +GLAPI void APIENTRY glArrayObjectATI (GLenum, GLint, GLenum, GLsizei, GLuint, GLuint); +GLAPI void APIENTRY glGetArrayObjectfvATI (GLenum, GLenum, GLfloat *); +GLAPI void APIENTRY glGetArrayObjectivATI (GLenum, GLenum, GLint *); +GLAPI void APIENTRY glVariantArrayObjectATI (GLuint, GLenum, GLsizei, GLuint, GLuint); +GLAPI void APIENTRY glGetVariantArrayObjectfvATI (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetVariantArrayObjectivATI (GLuint, GLenum, GLint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLuint (APIENTRYP PFNGLNEWOBJECTBUFFERATIPROC) (GLsizei size, const GLvoid *pointer, GLenum usage); +typedef GLboolean (APIENTRYP PFNGLISOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLUPDATEOBJECTBUFFERATIPROC) (GLuint buffer, GLuint offset, GLsizei size, const GLvoid *pointer, GLenum preserve); +typedef void (APIENTRYP PFNGLGETOBJECTBUFFERFVATIPROC) (GLuint buffer, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETOBJECTBUFFERIVATIPROC) (GLuint buffer, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLFREEOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLARRAYOBJECTATIPROC) (GLenum array, GLint size, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); +typedef void (APIENTRYP PFNGLGETARRAYOBJECTFVATIPROC) (GLenum array, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETARRAYOBJECTIVATIPROC) (GLenum array, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLVARIANTARRAYOBJECTATIPROC) (GLuint id, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); +typedef void (APIENTRYP PFNGLGETVARIANTARRAYOBJECTFVATIPROC) (GLuint id, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVARIANTARRAYOBJECTIVATIPROC) (GLuint id, GLenum pname, GLint *params); +#endif + +#ifndef GL_EXT_vertex_shader +#define GL_EXT_vertex_shader 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginVertexShaderEXT (void); +GLAPI void APIENTRY glEndVertexShaderEXT (void); +GLAPI void APIENTRY glBindVertexShaderEXT (GLuint); +GLAPI GLuint APIENTRY glGenVertexShadersEXT (GLuint); +GLAPI void APIENTRY glDeleteVertexShaderEXT (GLuint); +GLAPI void APIENTRY glShaderOp1EXT (GLenum, GLuint, GLuint); +GLAPI void APIENTRY glShaderOp2EXT (GLenum, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glShaderOp3EXT (GLenum, GLuint, GLuint, GLuint, GLuint); +GLAPI void APIENTRY glSwizzleEXT (GLuint, GLuint, GLenum, GLenum, GLenum, GLenum); +GLAPI void APIENTRY glWriteMaskEXT (GLuint, GLuint, GLenum, GLenum, GLenum, GLenum); +GLAPI void APIENTRY glInsertComponentEXT (GLuint, GLuint, GLuint); +GLAPI void APIENTRY glExtractComponentEXT (GLuint, GLuint, GLuint); +GLAPI GLuint APIENTRY glGenSymbolsEXT (GLenum, GLenum, GLenum, GLuint); +GLAPI void APIENTRY glSetInvariantEXT (GLuint, GLenum, const GLvoid *); +GLAPI void APIENTRY glSetLocalConstantEXT (GLuint, GLenum, const GLvoid *); +GLAPI void APIENTRY glVariantbvEXT (GLuint, const GLbyte *); +GLAPI void APIENTRY glVariantsvEXT (GLuint, const GLshort *); +GLAPI void APIENTRY glVariantivEXT (GLuint, const GLint *); +GLAPI void APIENTRY glVariantfvEXT (GLuint, const GLfloat *); +GLAPI void APIENTRY glVariantdvEXT (GLuint, const GLdouble *); +GLAPI void APIENTRY glVariantubvEXT (GLuint, const GLubyte *); +GLAPI void APIENTRY glVariantusvEXT (GLuint, const GLushort *); +GLAPI void APIENTRY glVariantuivEXT (GLuint, const GLuint *); +GLAPI void APIENTRY glVariantPointerEXT (GLuint, GLenum, GLuint, const GLvoid *); +GLAPI void APIENTRY glEnableVariantClientStateEXT (GLuint); +GLAPI void APIENTRY glDisableVariantClientStateEXT (GLuint); +GLAPI GLuint APIENTRY glBindLightParameterEXT (GLenum, GLenum); +GLAPI GLuint APIENTRY glBindMaterialParameterEXT (GLenum, GLenum); +GLAPI GLuint APIENTRY glBindTexGenParameterEXT (GLenum, GLenum, GLenum); +GLAPI GLuint APIENTRY glBindTextureUnitParameterEXT (GLenum, GLenum); +GLAPI GLuint APIENTRY glBindParameterEXT (GLenum); +GLAPI GLboolean APIENTRY glIsVariantEnabledEXT (GLuint, GLenum); +GLAPI void APIENTRY glGetVariantBooleanvEXT (GLuint, GLenum, GLboolean *); +GLAPI void APIENTRY glGetVariantIntegervEXT (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetVariantFloatvEXT (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetVariantPointervEXT (GLuint, GLenum, GLvoid* *); +GLAPI void APIENTRY glGetInvariantBooleanvEXT (GLuint, GLenum, GLboolean *); +GLAPI void APIENTRY glGetInvariantIntegervEXT (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetInvariantFloatvEXT (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetLocalConstantBooleanvEXT (GLuint, GLenum, GLboolean *); +GLAPI void APIENTRY glGetLocalConstantIntegervEXT (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetLocalConstantFloatvEXT (GLuint, GLenum, GLfloat *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBEGINVERTEXSHADEREXTPROC) (void); +typedef void (APIENTRYP PFNGLENDVERTEXSHADEREXTPROC) (void); +typedef void (APIENTRYP PFNGLBINDVERTEXSHADEREXTPROC) (GLuint id); +typedef GLuint (APIENTRYP PFNGLGENVERTEXSHADERSEXTPROC) (GLuint range); +typedef void (APIENTRYP PFNGLDELETEVERTEXSHADEREXTPROC) (GLuint id); +typedef void (APIENTRYP PFNGLSHADEROP1EXTPROC) (GLenum op, GLuint res, GLuint arg1); +typedef void (APIENTRYP PFNGLSHADEROP2EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2); +typedef void (APIENTRYP PFNGLSHADEROP3EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3); +typedef void (APIENTRYP PFNGLSWIZZLEEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); +typedef void (APIENTRYP PFNGLWRITEMASKEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); +typedef void (APIENTRYP PFNGLINSERTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); +typedef void (APIENTRYP PFNGLEXTRACTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); +typedef GLuint (APIENTRYP PFNGLGENSYMBOLSEXTPROC) (GLenum datatype, GLenum storagetype, GLenum range, GLuint components); +typedef void (APIENTRYP PFNGLSETINVARIANTEXTPROC) (GLuint id, GLenum type, const GLvoid *addr); +typedef void (APIENTRYP PFNGLSETLOCALCONSTANTEXTPROC) (GLuint id, GLenum type, const GLvoid *addr); +typedef void (APIENTRYP PFNGLVARIANTBVEXTPROC) (GLuint id, const GLbyte *addr); +typedef void (APIENTRYP PFNGLVARIANTSVEXTPROC) (GLuint id, const GLshort *addr); +typedef void (APIENTRYP PFNGLVARIANTIVEXTPROC) (GLuint id, const GLint *addr); +typedef void (APIENTRYP PFNGLVARIANTFVEXTPROC) (GLuint id, const GLfloat *addr); +typedef void (APIENTRYP PFNGLVARIANTDVEXTPROC) (GLuint id, const GLdouble *addr); +typedef void (APIENTRYP PFNGLVARIANTUBVEXTPROC) (GLuint id, const GLubyte *addr); +typedef void (APIENTRYP PFNGLVARIANTUSVEXTPROC) (GLuint id, const GLushort *addr); +typedef void (APIENTRYP PFNGLVARIANTUIVEXTPROC) (GLuint id, const GLuint *addr); +typedef void (APIENTRYP PFNGLVARIANTPOINTEREXTPROC) (GLuint id, GLenum type, GLuint stride, const GLvoid *addr); +typedef void (APIENTRYP PFNGLENABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); +typedef void (APIENTRYP PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); +typedef GLuint (APIENTRYP PFNGLBINDLIGHTPARAMETEREXTPROC) (GLenum light, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDMATERIALPARAMETEREXTPROC) (GLenum face, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDTEXGENPARAMETEREXTPROC) (GLenum unit, GLenum coord, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDTEXTUREUNITPARAMETEREXTPROC) (GLenum unit, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDPARAMETEREXTPROC) (GLenum value); +typedef GLboolean (APIENTRYP PFNGLISVARIANTENABLEDEXTPROC) (GLuint id, GLenum cap); +typedef void (APIENTRYP PFNGLGETVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (APIENTRYP PFNGLGETVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (APIENTRYP PFNGLGETVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +typedef void (APIENTRYP PFNGLGETVARIANTPOINTERVEXTPROC) (GLuint id, GLenum value, GLvoid* *data); +typedef void (APIENTRYP PFNGLGETINVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (APIENTRYP PFNGLGETINVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (APIENTRYP PFNGLGETINVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +typedef void (APIENTRYP PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (APIENTRYP PFNGLGETLOCALCONSTANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (APIENTRYP PFNGLGETLOCALCONSTANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +#endif + +#ifndef GL_ATI_vertex_streams +#define GL_ATI_vertex_streams 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexStream1sATI (GLenum, GLshort); +GLAPI void APIENTRY glVertexStream1svATI (GLenum, const GLshort *); +GLAPI void APIENTRY glVertexStream1iATI (GLenum, GLint); +GLAPI void APIENTRY glVertexStream1ivATI (GLenum, const GLint *); +GLAPI void APIENTRY glVertexStream1fATI (GLenum, GLfloat); +GLAPI void APIENTRY glVertexStream1fvATI (GLenum, const GLfloat *); +GLAPI void APIENTRY glVertexStream1dATI (GLenum, GLdouble); +GLAPI void APIENTRY glVertexStream1dvATI (GLenum, const GLdouble *); +GLAPI void APIENTRY glVertexStream2sATI (GLenum, GLshort, GLshort); +GLAPI void APIENTRY glVertexStream2svATI (GLenum, const GLshort *); +GLAPI void APIENTRY glVertexStream2iATI (GLenum, GLint, GLint); +GLAPI void APIENTRY glVertexStream2ivATI (GLenum, const GLint *); +GLAPI void APIENTRY glVertexStream2fATI (GLenum, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexStream2fvATI (GLenum, const GLfloat *); +GLAPI void APIENTRY glVertexStream2dATI (GLenum, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexStream2dvATI (GLenum, const GLdouble *); +GLAPI void APIENTRY glVertexStream3sATI (GLenum, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexStream3svATI (GLenum, const GLshort *); +GLAPI void APIENTRY glVertexStream3iATI (GLenum, GLint, GLint, GLint); +GLAPI void APIENTRY glVertexStream3ivATI (GLenum, const GLint *); +GLAPI void APIENTRY glVertexStream3fATI (GLenum, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexStream3fvATI (GLenum, const GLfloat *); +GLAPI void APIENTRY glVertexStream3dATI (GLenum, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexStream3dvATI (GLenum, const GLdouble *); +GLAPI void APIENTRY glVertexStream4sATI (GLenum, GLshort, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glVertexStream4svATI (GLenum, const GLshort *); +GLAPI void APIENTRY glVertexStream4iATI (GLenum, GLint, GLint, GLint, GLint); +GLAPI void APIENTRY glVertexStream4ivATI (GLenum, const GLint *); +GLAPI void APIENTRY glVertexStream4fATI (GLenum, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glVertexStream4fvATI (GLenum, const GLfloat *); +GLAPI void APIENTRY glVertexStream4dATI (GLenum, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glVertexStream4dvATI (GLenum, const GLdouble *); +GLAPI void APIENTRY glNormalStream3bATI (GLenum, GLbyte, GLbyte, GLbyte); +GLAPI void APIENTRY glNormalStream3bvATI (GLenum, const GLbyte *); +GLAPI void APIENTRY glNormalStream3sATI (GLenum, GLshort, GLshort, GLshort); +GLAPI void APIENTRY glNormalStream3svATI (GLenum, const GLshort *); +GLAPI void APIENTRY glNormalStream3iATI (GLenum, GLint, GLint, GLint); +GLAPI void APIENTRY glNormalStream3ivATI (GLenum, const GLint *); +GLAPI void APIENTRY glNormalStream3fATI (GLenum, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glNormalStream3fvATI (GLenum, const GLfloat *); +GLAPI void APIENTRY glNormalStream3dATI (GLenum, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glNormalStream3dvATI (GLenum, const GLdouble *); +GLAPI void APIENTRY glClientActiveVertexStreamATI (GLenum); +GLAPI void APIENTRY glVertexBlendEnviATI (GLenum, GLint); +GLAPI void APIENTRY glVertexBlendEnvfATI (GLenum, GLfloat); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLVERTEXSTREAM1SATIPROC) (GLenum stream, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1IATIPROC) (GLenum stream, GLint x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1FATIPROC) (GLenum stream, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1DATIPROC) (GLenum stream, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2SATIPROC) (GLenum stream, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2IATIPROC) (GLenum stream, GLint x, GLint y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2FATIPROC) (GLenum stream, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2DATIPROC) (GLenum stream, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4IATIPROC) (GLenum stream, GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3BATIPROC) (GLenum stream, GLbyte nx, GLbyte ny, GLbyte nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3BVATIPROC) (GLenum stream, const GLbyte *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3SATIPROC) (GLenum stream, GLshort nx, GLshort ny, GLshort nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3IATIPROC) (GLenum stream, GLint nx, GLint ny, GLint nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3FATIPROC) (GLenum stream, GLfloat nx, GLfloat ny, GLfloat nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3DATIPROC) (GLenum stream, GLdouble nx, GLdouble ny, GLdouble nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC) (GLenum stream); +typedef void (APIENTRYP PFNGLVERTEXBLENDENVIATIPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLVERTEXBLENDENVFATIPROC) (GLenum pname, GLfloat param); +#endif + +#ifndef GL_ATI_element_array +#define GL_ATI_element_array 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glElementPointerATI (GLenum, const GLvoid *); +GLAPI void APIENTRY glDrawElementArrayATI (GLenum, GLsizei); +GLAPI void APIENTRY glDrawRangeElementArrayATI (GLenum, GLuint, GLuint, GLsizei); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLELEMENTPOINTERATIPROC) (GLenum type, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLDRAWELEMENTARRAYATIPROC) (GLenum mode, GLsizei count); +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTARRAYATIPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count); +#endif + +#ifndef GL_SUN_mesh_array +#define GL_SUN_mesh_array 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawMeshArraysSUN (GLenum, GLint, GLsizei, GLsizei); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDRAWMESHARRAYSSUNPROC) (GLenum mode, GLint first, GLsizei count, GLsizei width); +#endif + +#ifndef GL_SUN_slice_accum +#define GL_SUN_slice_accum 1 +#endif + +#ifndef GL_NV_multisample_filter_hint +#define GL_NV_multisample_filter_hint 1 +#endif + +#ifndef GL_NV_depth_clamp +#define GL_NV_depth_clamp 1 +#endif + +#ifndef GL_NV_occlusion_query +#define GL_NV_occlusion_query 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenOcclusionQueriesNV (GLsizei, GLuint *); +GLAPI void APIENTRY glDeleteOcclusionQueriesNV (GLsizei, const GLuint *); +GLAPI GLboolean APIENTRY glIsOcclusionQueryNV (GLuint); +GLAPI void APIENTRY glBeginOcclusionQueryNV (GLuint); +GLAPI void APIENTRY glEndOcclusionQueryNV (void); +GLAPI void APIENTRY glGetOcclusionQueryivNV (GLuint, GLenum, GLint *); +GLAPI void APIENTRY glGetOcclusionQueryuivNV (GLuint, GLenum, GLuint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGENOCCLUSIONQUERIESNVPROC) (GLsizei n, GLuint *ids); +typedef void (APIENTRYP PFNGLDELETEOCCLUSIONQUERIESNVPROC) (GLsizei n, const GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISOCCLUSIONQUERYNVPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINOCCLUSIONQUERYNVPROC) (GLuint id); +typedef void (APIENTRYP PFNGLENDOCCLUSIONQUERYNVPROC) (void); +typedef void (APIENTRYP PFNGLGETOCCLUSIONQUERYIVNVPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETOCCLUSIONQUERYUIVNVPROC) (GLuint id, GLenum pname, GLuint *params); +#endif + +#ifndef GL_NV_point_sprite +#define GL_NV_point_sprite 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameteriNV (GLenum, GLint); +GLAPI void APIENTRY glPointParameterivNV (GLenum, const GLint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPOINTPARAMETERINVPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERIVNVPROC) (GLenum pname, const GLint *params); +#endif + +#ifndef GL_NV_texture_shader3 +#define GL_NV_texture_shader3 1 +#endif + +#ifndef GL_NV_vertex_program1_1 +#define GL_NV_vertex_program1_1 1 +#endif + +#ifndef GL_EXT_shadow_funcs +#define GL_EXT_shadow_funcs 1 +#endif + +#ifndef GL_EXT_stencil_two_side +#define GL_EXT_stencil_two_side 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glActiveStencilFaceEXT (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLACTIVESTENCILFACEEXTPROC) (GLenum face); +#endif + +#ifndef GL_ATI_text_fragment_shader +#define GL_ATI_text_fragment_shader 1 +#endif + +#ifndef GL_APPLE_client_storage +#define GL_APPLE_client_storage 1 +#endif + +#ifndef GL_APPLE_element_array +#define GL_APPLE_element_array 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glElementPointerAPPLE (GLenum, const GLvoid *); +GLAPI void APIENTRY glDrawElementArrayAPPLE (GLenum, GLint, GLsizei); +GLAPI void APIENTRY glDrawRangeElementArrayAPPLE (GLenum, GLuint, GLuint, GLint, GLsizei); +GLAPI void APIENTRY glMultiDrawElementArrayAPPLE (GLenum, const GLint *, const GLsizei *, GLsizei); +GLAPI void APIENTRY glMultiDrawRangeElementArrayAPPLE (GLenum, GLuint, GLuint, const GLint *, const GLsizei *, GLsizei); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLELEMENTPOINTERAPPLEPROC) (GLenum type, const GLvoid *pointer); +typedef void (APIENTRYP PFNGLDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); +typedef void (APIENTRYP PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, const GLint *first, const GLsizei *count, GLsizei primcount); +#endif + +#ifndef GL_APPLE_fence +#define GL_APPLE_fence 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenFencesAPPLE (GLsizei, GLuint *); +GLAPI void APIENTRY glDeleteFencesAPPLE (GLsizei, const GLuint *); +GLAPI void APIENTRY glSetFenceAPPLE (GLuint); +GLAPI GLboolean APIENTRY glIsFenceAPPLE (GLuint); +GLAPI GLboolean APIENTRY glTestFenceAPPLE (GLuint); +GLAPI void APIENTRY glFinishFenceAPPLE (GLuint); +GLAPI GLboolean APIENTRY glTestObjectAPPLE (GLenum, GLuint); +GLAPI void APIENTRY glFinishObjectAPPLE (GLenum, GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLGENFENCESAPPLEPROC) (GLsizei n, GLuint *fences); +typedef void (APIENTRYP PFNGLDELETEFENCESAPPLEPROC) (GLsizei n, const GLuint *fences); +typedef void (APIENTRYP PFNGLSETFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLISFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLTESTFENCEAPPLEPROC) (GLuint fence); +typedef void (APIENTRYP PFNGLFINISHFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLTESTOBJECTAPPLEPROC) (GLenum object, GLuint name); +typedef void (APIENTRYP PFNGLFINISHOBJECTAPPLEPROC) (GLenum object, GLint name); +#endif + +#ifndef GL_APPLE_vertex_array_object +#define GL_APPLE_vertex_array_object 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindVertexArrayAPPLE (GLuint); +GLAPI void APIENTRY glDeleteVertexArraysAPPLE (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenVertexArraysAPPLE (GLsizei, const GLuint *); +GLAPI GLboolean APIENTRY glIsVertexArrayAPPLE (GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBINDVERTEXARRAYAPPLEPROC) (GLuint array); +typedef void (APIENTRYP PFNGLDELETEVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint *arrays); +typedef void (APIENTRYP PFNGLGENVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint *arrays); +typedef GLboolean (APIENTRYP PFNGLISVERTEXARRAYAPPLEPROC) (GLuint array); +#endif + +#ifndef GL_APPLE_vertex_array_range +#define GL_APPLE_vertex_array_range 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexArrayRangeAPPLE (GLsizei, GLvoid *); +GLAPI void APIENTRY glFlushVertexArrayRangeAPPLE (GLsizei, GLvoid *); +GLAPI void APIENTRY glVertexArrayParameteriAPPLE (GLenum, GLint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, GLvoid *pointer); +typedef void (APIENTRYP PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, GLvoid *pointer); +typedef void (APIENTRYP PFNGLVERTEXARRAYPARAMETERIAPPLEPROC) (GLenum pname, GLint param); +#endif + +#ifndef GL_APPLE_ycbcr_422 +#define GL_APPLE_ycbcr_422 1 +#endif + +#ifndef GL_S3_s3tc +#define GL_S3_s3tc 1 +#endif + +#ifndef GL_ATI_draw_buffers +#define GL_ATI_draw_buffers 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawBuffersATI (GLsizei, const GLenum *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDRAWBUFFERSATIPROC) (GLsizei n, const GLenum *bufs); +#endif + +#ifndef GL_ATI_pixel_format_float +#define GL_ATI_pixel_format_float 1 +/* This is really a WGL extension, but defines some associated GL enums. + * ATI does not export "GL_ATI_pixel_format_float" in the GL_EXTENSIONS string. + */ +#endif + +#ifndef GL_ATI_texture_env_combine3 +#define GL_ATI_texture_env_combine3 1 +#endif + +#ifndef GL_ATI_texture_float +#define GL_ATI_texture_float 1 +#endif + +#ifndef GL_NV_float_buffer +#define GL_NV_float_buffer 1 +#endif + +#ifndef GL_NV_fragment_program +#define GL_NV_fragment_program 1 +/* Some NV_fragment_program entry points are shared with ARB_vertex_program. */ +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramNamedParameter4fNV (GLuint, GLsizei, const GLubyte *, GLfloat, GLfloat, GLfloat, GLfloat); +GLAPI void APIENTRY glProgramNamedParameter4dNV (GLuint, GLsizei, const GLubyte *, GLdouble, GLdouble, GLdouble, GLdouble); +GLAPI void APIENTRY glProgramNamedParameter4fvNV (GLuint, GLsizei, const GLubyte *, const GLfloat *); +GLAPI void APIENTRY glProgramNamedParameter4dvNV (GLuint, GLsizei, const GLubyte *, const GLdouble *); +GLAPI void APIENTRY glGetProgramNamedParameterfvNV (GLuint, GLsizei, const GLubyte *, GLfloat *); +GLAPI void APIENTRY glGetProgramNamedParameterdvNV (GLuint, GLsizei, const GLubyte *, GLdouble *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4FNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4DNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, const GLfloat *v); +typedef void (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, const GLdouble *v); +typedef void (APIENTRYP PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLdouble *params); +#endif + +#ifndef GL_NV_half_float +#define GL_NV_half_float 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertex2hNV (GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glVertex2hvNV (const GLhalfNV *); +GLAPI void APIENTRY glVertex3hNV (GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glVertex3hvNV (const GLhalfNV *); +GLAPI void APIENTRY glVertex4hNV (GLhalfNV, GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glVertex4hvNV (const GLhalfNV *); +GLAPI void APIENTRY glNormal3hNV (GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glNormal3hvNV (const GLhalfNV *); +GLAPI void APIENTRY glColor3hNV (GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glColor3hvNV (const GLhalfNV *); +GLAPI void APIENTRY glColor4hNV (GLhalfNV, GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glColor4hvNV (const GLhalfNV *); +GLAPI void APIENTRY glTexCoord1hNV (GLhalfNV); +GLAPI void APIENTRY glTexCoord1hvNV (const GLhalfNV *); +GLAPI void APIENTRY glTexCoord2hNV (GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glTexCoord2hvNV (const GLhalfNV *); +GLAPI void APIENTRY glTexCoord3hNV (GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glTexCoord3hvNV (const GLhalfNV *); +GLAPI void APIENTRY glTexCoord4hNV (GLhalfNV, GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glTexCoord4hvNV (const GLhalfNV *); +GLAPI void APIENTRY glMultiTexCoord1hNV (GLenum, GLhalfNV); +GLAPI void APIENTRY glMultiTexCoord1hvNV (GLenum, const GLhalfNV *); +GLAPI void APIENTRY glMultiTexCoord2hNV (GLenum, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glMultiTexCoord2hvNV (GLenum, const GLhalfNV *); +GLAPI void APIENTRY glMultiTexCoord3hNV (GLenum, GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glMultiTexCoord3hvNV (GLenum, const GLhalfNV *); +GLAPI void APIENTRY glMultiTexCoord4hNV (GLenum, GLhalfNV, GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glMultiTexCoord4hvNV (GLenum, const GLhalfNV *); +GLAPI void APIENTRY glFogCoordhNV (GLhalfNV); +GLAPI void APIENTRY glFogCoordhvNV (const GLhalfNV *); +GLAPI void APIENTRY glSecondaryColor3hNV (GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glSecondaryColor3hvNV (const GLhalfNV *); +GLAPI void APIENTRY glVertexWeighthNV (GLhalfNV); +GLAPI void APIENTRY glVertexWeighthvNV (const GLhalfNV *); +GLAPI void APIENTRY glVertexAttrib1hNV (GLuint, GLhalfNV); +GLAPI void APIENTRY glVertexAttrib1hvNV (GLuint, const GLhalfNV *); +GLAPI void APIENTRY glVertexAttrib2hNV (GLuint, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glVertexAttrib2hvNV (GLuint, const GLhalfNV *); +GLAPI void APIENTRY glVertexAttrib3hNV (GLuint, GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glVertexAttrib3hvNV (GLuint, const GLhalfNV *); +GLAPI void APIENTRY glVertexAttrib4hNV (GLuint, GLhalfNV, GLhalfNV, GLhalfNV, GLhalfNV); +GLAPI void APIENTRY glVertexAttrib4hvNV (GLuint, const GLhalfNV *); +GLAPI void APIENTRY glVertexAttribs1hvNV (GLuint, GLsizei, const GLhalfNV *); +GLAPI void APIENTRY glVertexAttribs2hvNV (GLuint, GLsizei, const GLhalfNV *); +GLAPI void APIENTRY glVertexAttribs3hvNV (GLuint, GLsizei, const GLhalfNV *); +GLAPI void APIENTRY glVertexAttribs4hvNV (GLuint, GLsizei, const GLhalfNV *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLVERTEX2HNVPROC) (GLhalfNV x, GLhalfNV y); +typedef void (APIENTRYP PFNGLVERTEX2HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEX3HNVPROC) (GLhalfNV x, GLhalfNV y, GLhalfNV z); +typedef void (APIENTRYP PFNGLVERTEX3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEX4HNVPROC) (GLhalfNV x, GLhalfNV y, GLhalfNV z, GLhalfNV w); +typedef void (APIENTRYP PFNGLVERTEX4HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLNORMAL3HNVPROC) (GLhalfNV nx, GLhalfNV ny, GLhalfNV nz); +typedef void (APIENTRYP PFNGLNORMAL3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLCOLOR3HNVPROC) (GLhalfNV red, GLhalfNV green, GLhalfNV blue); +typedef void (APIENTRYP PFNGLCOLOR3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLCOLOR4HNVPROC) (GLhalfNV red, GLhalfNV green, GLhalfNV blue, GLhalfNV alpha); +typedef void (APIENTRYP PFNGLCOLOR4HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD1HNVPROC) (GLhalfNV s); +typedef void (APIENTRYP PFNGLTEXCOORD1HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD2HNVPROC) (GLhalfNV s, GLhalfNV t); +typedef void (APIENTRYP PFNGLTEXCOORD2HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD3HNVPROC) (GLhalfNV s, GLhalfNV t, GLhalfNV r); +typedef void (APIENTRYP PFNGLTEXCOORD3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD4HNVPROC) (GLhalfNV s, GLhalfNV t, GLhalfNV r, GLhalfNV q); +typedef void (APIENTRYP PFNGLTEXCOORD4HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1HNVPROC) (GLenum target, GLhalfNV s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2HNVPROC) (GLenum target, GLhalfNV s, GLhalfNV t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3HNVPROC) (GLenum target, GLhalfNV s, GLhalfNV t, GLhalfNV r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4HNVPROC) (GLenum target, GLhalfNV s, GLhalfNV t, GLhalfNV r, GLhalfNV q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLFOGCOORDHNVPROC) (GLhalfNV fog); +typedef void (APIENTRYP PFNGLFOGCOORDHVNVPROC) (const GLhalfNV *fog); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3HNVPROC) (GLhalfNV red, GLhalfNV green, GLhalfNV blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTHNVPROC) (GLhalfNV weight); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTHVNVPROC) (const GLhalfNV *weight); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1HNVPROC) (GLuint index, GLhalfNV x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2HNVPROC) (GLuint index, GLhalfNV x, GLhalfNV y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3HNVPROC) (GLuint index, GLhalfNV x, GLhalfNV y, GLhalfNV z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4HNVPROC) (GLuint index, GLhalfNV x, GLhalfNV y, GLhalfNV z, GLhalfNV w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +#endif + +#ifndef GL_NV_pixel_data_range +#define GL_NV_pixel_data_range 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelDataRangeNV (GLenum, GLsizei, GLvoid *); +GLAPI void APIENTRY glFlushPixelDataRangeNV (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPIXELDATARANGENVPROC) (GLenum target, GLsizei length, GLvoid *pointer); +typedef void (APIENTRYP PFNGLFLUSHPIXELDATARANGENVPROC) (GLenum target); +#endif + +#ifndef GL_NV_primitive_restart +#define GL_NV_primitive_restart 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPrimitiveRestartNV (void); +GLAPI void APIENTRY glPrimitiveRestartIndexNV (GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLPRIMITIVERESTARTNVPROC) (void); +typedef void (APIENTRYP PFNGLPRIMITIVERESTARTINDEXNVPROC) (GLuint index); +#endif + +#ifndef GL_NV_texture_expand_normal +#define GL_NV_texture_expand_normal 1 +#endif + +#ifndef GL_NV_vertex_program2 +#define GL_NV_vertex_program2 1 +#endif + +#ifndef GL_ATI_map_object_buffer +#define GL_ATI_map_object_buffer 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLvoid* APIENTRY glMapObjectBufferATI (GLuint); +GLAPI void APIENTRY glUnmapObjectBufferATI (GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLvoid* (APIENTRYP PFNGLMAPOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLUNMAPOBJECTBUFFERATIPROC) (GLuint buffer); +#endif + +#ifndef GL_ATI_separate_stencil +#define GL_ATI_separate_stencil 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glStencilOpSeparateATI (GLenum, GLenum, GLenum, GLenum); +GLAPI void APIENTRY glStencilFuncSeparateATI (GLenum, GLenum, GLint, GLuint); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSTENCILOPSEPARATEATIPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +typedef void (APIENTRYP PFNGLSTENCILFUNCSEPARATEATIPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); +#endif + +#ifndef GL_ATI_vertex_attrib_array_object +#define GL_ATI_vertex_attrib_array_object 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttribArrayObjectATI (GLuint, GLint, GLenum, GLboolean, GLsizei, GLuint, GLuint); +GLAPI void APIENTRY glGetVertexAttribArrayObjectfvATI (GLuint, GLenum, GLfloat *); +GLAPI void APIENTRY glGetVertexAttribArrayObjectivATI (GLuint, GLenum, GLint *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLVERTEXATTRIBARRAYOBJECTATIPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLuint buffer, GLuint offset); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC) (GLuint index, GLenum pname, GLint *params); +#endif + +#ifndef GL_OES_read_format +#define GL_OES_read_format 1 +#endif + +#ifndef GL_EXT_depth_bounds_test +#define GL_EXT_depth_bounds_test 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDepthBoundsEXT (GLclampd, GLclampd); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLDEPTHBOUNDSEXTPROC) (GLclampd zmin, GLclampd zmax); +#endif + +#ifndef GL_EXT_texture_mirror_clamp +#define GL_EXT_texture_mirror_clamp 1 +#endif + +#ifndef GL_EXT_blend_equation_separate +#define GL_EXT_blend_equation_separate 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendEquationSeparateEXT (GLenum, GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEEXTPROC) (GLenum modeRGB, GLenum modeAlpha); +#endif + +#ifndef GL_MESA_pack_invert +#define GL_MESA_pack_invert 1 +#endif + +#ifndef GL_MESA_ycbcr_texture +#define GL_MESA_ycbcr_texture 1 +#endif + +#ifndef GL_EXT_pixel_buffer_object +#define GL_EXT_pixel_buffer_object 1 +#endif + +#ifndef GL_NV_fragment_program_option +#define GL_NV_fragment_program_option 1 +#endif + +#ifndef GL_NV_fragment_program2 +#define GL_NV_fragment_program2 1 +#endif + +#ifndef GL_NV_vertex_program2_option +#define GL_NV_vertex_program2_option 1 +#endif + +#ifndef GL_NV_vertex_program3 +#define GL_NV_vertex_program3 1 +#endif + +#ifndef GL_EXT_framebuffer_object +#define GL_EXT_framebuffer_object 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLboolean APIENTRY glIsRenderbufferEXT (GLuint); +GLAPI void APIENTRY glBindRenderbufferEXT (GLenum, GLuint); +GLAPI void APIENTRY glDeleteRenderbuffersEXT (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenRenderbuffersEXT (GLsizei, GLuint *); +GLAPI void APIENTRY glRenderbufferStorageEXT (GLenum, GLenum, GLsizei, GLsizei); +GLAPI void APIENTRY glGetRenderbufferParameterivEXT (GLenum, GLenum, GLint *); +GLAPI GLboolean APIENTRY glIsFramebufferEXT (GLuint); +GLAPI void APIENTRY glBindFramebufferEXT (GLenum, GLuint); +GLAPI void APIENTRY glDeleteFramebuffersEXT (GLsizei, const GLuint *); +GLAPI void APIENTRY glGenFramebuffersEXT (GLsizei, GLuint *); +GLAPI GLenum APIENTRY glCheckFramebufferStatusEXT (GLenum); +GLAPI void APIENTRY glFramebufferTexture1DEXT (GLenum, GLenum, GLenum, GLuint, GLint); +GLAPI void APIENTRY glFramebufferTexture2DEXT (GLenum, GLenum, GLenum, GLuint, GLint); +GLAPI void APIENTRY glFramebufferTexture3DEXT (GLenum, GLenum, GLenum, GLuint, GLint, GLint); +GLAPI void APIENTRY glFramebufferRenderbufferEXT (GLenum, GLenum, GLenum, GLuint); +GLAPI void APIENTRY glGetFramebufferAttachmentParameterivEXT (GLenum, GLenum, GLenum, GLint *); +GLAPI void APIENTRY glGenerateMipmapEXT (GLenum); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLboolean (APIENTRYP PFNGLISRENDERBUFFEREXTPROC) (GLuint renderbuffer); +typedef void (APIENTRYP PFNGLBINDRENDERBUFFEREXTPROC) (GLenum target, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLDELETERENDERBUFFERSEXTPROC) (GLsizei n, const GLuint *renderbuffers); +typedef void (APIENTRYP PFNGLGENRENDERBUFFERSEXTPROC) (GLsizei n, GLuint *renderbuffers); +typedef void (APIENTRYP PFNGLRENDERBUFFERSTORAGEEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef GLboolean (APIENTRYP PFNGLISFRAMEBUFFEREXTPROC) (GLuint framebuffer); +typedef void (APIENTRYP PFNGLBINDFRAMEBUFFEREXTPROC) (GLenum target, GLuint framebuffer); +typedef void (APIENTRYP PFNGLDELETEFRAMEBUFFERSEXTPROC) (GLsizei n, const GLuint *framebuffers); +typedef void (APIENTRYP PFNGLGENFRAMEBUFFERSEXTPROC) (GLsizei n, GLuint *framebuffers); +typedef GLenum (APIENTRYP PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC) (GLenum target); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE1DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE2DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE3DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +typedef void (APIENTRYP PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLenum target, GLenum attachment, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGENERATEMIPMAPEXTPROC) (GLenum target); +#endif + +#ifndef GL_GREMEDY_string_marker +#define GL_GREMEDY_string_marker 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glStringMarkerGREMEDY (GLsizei, const GLvoid *); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSTRINGMARKERGREMEDYPROC) (GLsizei len, const GLvoid *string); +#endif + + +#ifdef __cplusplus +} +#endif + +#endif +#endif /* NO_SDL_GLEXT */ +/*@}*/ diff --git a/Externals/SDL/include/SDL_platform.h b/Externals/SDL/include/SDL_platform.h new file mode 100644 index 0000000000..11d8673667 --- /dev/null +++ b/Externals/SDL/include/SDL_platform.h @@ -0,0 +1,110 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_platform.h + * Try to get a standard set of platform defines + */ + +#ifndef _SDL_platform_h +#define _SDL_platform_h + +#if defined(_AIX) +#undef __AIX__ +#define __AIX__ 1 +#endif +#if defined(__BEOS__) +#undef __BEOS__ +#define __BEOS__ 1 +#endif +#if defined(__HAIKU__) +#undef __HAIKU__ +#define __HAIKU__ 1 +#endif +#if defined(bsdi) || defined(__bsdi) || defined(__bsdi__) +#undef __BSDI__ +#define __BSDI__ 1 +#endif +#if defined(_arch_dreamcast) +#undef __DREAMCAST__ +#define __DREAMCAST__ 1 +#endif +#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__DragonFly__) +#undef __FREEBSD__ +#define __FREEBSD__ 1 +#endif +#if defined(__HAIKU__) +#undef __HAIKU__ +#define __HAIKU__ 1 +#endif +#if defined(hpux) || defined(__hpux) || defined(__hpux__) +#undef __HPUX__ +#define __HPUX__ 1 +#endif +#if defined(sgi) || defined(__sgi) || defined(__sgi__) || defined(_SGI_SOURCE) +#undef __IRIX__ +#define __IRIX__ 1 +#endif +#if defined(linux) || defined(__linux) || defined(__linux__) +#undef __LINUX__ +#define __LINUX__ 1 +#endif +#if defined(__APPLE__) +#undef __MACOSX__ +#define __MACOSX__ 1 +#elif defined(macintosh) +#undef __MACOS__ +#define __MACOS__ 1 +#endif +#if defined(__NetBSD__) +#undef __NETBSD__ +#define __NETBSD__ 1 +#endif +#if defined(__OpenBSD__) +#undef __OPENBSD__ +#define __OPENBSD__ 1 +#endif +#if defined(__OS2__) +#undef __OS2__ +#define __OS2__ 1 +#endif +#if defined(osf) || defined(__osf) || defined(__osf__) || defined(_OSF_SOURCE) +#undef __OSF__ +#define __OSF__ 1 +#endif +#if defined(__QNXNTO__) +#undef __QNXNTO__ +#define __QNXNTO__ 1 +#endif +#if defined(riscos) || defined(__riscos) || defined(__riscos__) +#undef __RISCOS__ +#define __RISCOS__ 1 +#endif +#if defined(__SVR4) +#undef __SOLARIS__ +#define __SOLARIS__ 1 +#endif +#if defined(WIN32) || defined(_WIN32) +#undef __WIN32__ +#define __WIN32__ 1 +#endif + +#endif /* _SDL_platform_h */ diff --git a/Externals/SDL/include/SDL_quit.h b/Externals/SDL/include/SDL_quit.h new file mode 100644 index 0000000000..6d82e7e061 --- /dev/null +++ b/Externals/SDL/include/SDL_quit.h @@ -0,0 +1,55 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_quit.h + * Include file for SDL quit event handling + */ + +#ifndef _SDL_quit_h +#define _SDL_quit_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +/** @file SDL_quit.h + * An SDL_QUITEVENT is generated when the user tries to close the application + * window. If it is ignored or filtered out, the window will remain open. + * If it is not ignored or filtered, it is queued normally and the window + * is allowed to close. When the window is closed, screen updates will + * complete, but have no effect. + * + * SDL_Init() installs signal handlers for SIGINT (keyboard interrupt) + * and SIGTERM (system termination request), if handlers do not already + * exist, that generate SDL_QUITEVENT events as well. There is no way + * to determine the cause of an SDL_QUITEVENT, but setting a signal + * handler in your application will override the default generation of + * quit events for that signal. + */ + +/** @file SDL_quit.h + * There are no functions directly affecting the quit event + */ + +#define SDL_QuitRequested() \ + (SDL_PumpEvents(), SDL_PeepEvents(NULL,0,SDL_PEEKEVENT,SDL_QUITMASK)) + +#endif /* _SDL_quit_h */ diff --git a/Externals/SDL/include/SDL_rwops.h b/Externals/SDL/include/SDL_rwops.h new file mode 100644 index 0000000000..a450119f1c --- /dev/null +++ b/Externals/SDL/include/SDL_rwops.h @@ -0,0 +1,155 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_rwops.h + * This file provides a general interface for SDL to read and write + * data sources. It can easily be extended to files, memory, etc. + */ + +#ifndef _SDL_rwops_h +#define _SDL_rwops_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** This is the read/write operation structure -- very basic */ + +typedef struct SDL_RWops { + /** Seek to 'offset' relative to whence, one of stdio's whence values: + * SEEK_SET, SEEK_CUR, SEEK_END + * Returns the final offset in the data source. + */ + int (SDLCALL *seek)(struct SDL_RWops *context, int offset, int whence); + + /** Read up to 'maxnum' objects each of size 'size' from the data + * source to the area pointed at by 'ptr'. + * Returns the number of objects read, or -1 if the read failed. + */ + int (SDLCALL *read)(struct SDL_RWops *context, void *ptr, int size, int maxnum); + + /** Write exactly 'num' objects each of size 'objsize' from the area + * pointed at by 'ptr' to data source. + * Returns 'num', or -1 if the write failed. + */ + int (SDLCALL *write)(struct SDL_RWops *context, const void *ptr, int size, int num); + + /** Close and free an allocated SDL_FSops structure */ + int (SDLCALL *close)(struct SDL_RWops *context); + + Uint32 type; + union { +#if defined(__WIN32__) && !defined(__SYMBIAN32__) + struct { + int append; + void *h; + struct { + void *data; + int size; + int left; + } buffer; + } win32io; +#endif +#ifdef HAVE_STDIO_H + struct { + int autoclose; + FILE *fp; + } stdio; +#endif + struct { + Uint8 *base; + Uint8 *here; + Uint8 *stop; + } mem; + struct { + void *data1; + } unknown; + } hidden; + +} SDL_RWops; + + +/** @name Functions to create SDL_RWops structures from various data sources */ +/*@{*/ + +extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromFile(const char *file, const char *mode); + +#ifdef HAVE_STDIO_H +extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromFP(FILE *fp, int autoclose); +#endif + +extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromMem(void *mem, int size); +extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromConstMem(const void *mem, int size); + +extern DECLSPEC SDL_RWops * SDLCALL SDL_AllocRW(void); +extern DECLSPEC void SDLCALL SDL_FreeRW(SDL_RWops *area); + +/*@}*/ + +/** @name Seek Reference Points */ +/*@{*/ +#define RW_SEEK_SET 0 /**< Seek from the beginning of data */ +#define RW_SEEK_CUR 1 /**< Seek relative to current read point */ +#define RW_SEEK_END 2 /**< Seek relative to the end of data */ +/*@}*/ + +/** @name Macros to easily read and write from an SDL_RWops structure */ +/*@{*/ +#define SDL_RWseek(ctx, offset, whence) (ctx)->seek(ctx, offset, whence) +#define SDL_RWtell(ctx) (ctx)->seek(ctx, 0, RW_SEEK_CUR) +#define SDL_RWread(ctx, ptr, size, n) (ctx)->read(ctx, ptr, size, n) +#define SDL_RWwrite(ctx, ptr, size, n) (ctx)->write(ctx, ptr, size, n) +#define SDL_RWclose(ctx) (ctx)->close(ctx) +/*@}*/ + +/** @name Read an item of the specified endianness and return in native format */ +/*@{*/ +extern DECLSPEC Uint16 SDLCALL SDL_ReadLE16(SDL_RWops *src); +extern DECLSPEC Uint16 SDLCALL SDL_ReadBE16(SDL_RWops *src); +extern DECLSPEC Uint32 SDLCALL SDL_ReadLE32(SDL_RWops *src); +extern DECLSPEC Uint32 SDLCALL SDL_ReadBE32(SDL_RWops *src); +extern DECLSPEC Uint64 SDLCALL SDL_ReadLE64(SDL_RWops *src); +extern DECLSPEC Uint64 SDLCALL SDL_ReadBE64(SDL_RWops *src); +/*@}*/ + +/** @name Write an item of native format to the specified endianness */ +/*@{*/ +extern DECLSPEC int SDLCALL SDL_WriteLE16(SDL_RWops *dst, Uint16 value); +extern DECLSPEC int SDLCALL SDL_WriteBE16(SDL_RWops *dst, Uint16 value); +extern DECLSPEC int SDLCALL SDL_WriteLE32(SDL_RWops *dst, Uint32 value); +extern DECLSPEC int SDLCALL SDL_WriteBE32(SDL_RWops *dst, Uint32 value); +extern DECLSPEC int SDLCALL SDL_WriteLE64(SDL_RWops *dst, Uint64 value); +extern DECLSPEC int SDLCALL SDL_WriteBE64(SDL_RWops *dst, Uint64 value); +/*@}*/ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_rwops_h */ diff --git a/Externals/SDL/include/SDL_stdinc.h b/Externals/SDL/include/SDL_stdinc.h new file mode 100644 index 0000000000..e1f85fb75a --- /dev/null +++ b/Externals/SDL/include/SDL_stdinc.h @@ -0,0 +1,620 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_stdinc.h + * This is a general header that includes C language support + */ + +#ifndef _SDL_stdinc_h +#define _SDL_stdinc_h + +#include "SDL_config.h" + + +#ifdef HAVE_SYS_TYPES_H +#include +#endif +#ifdef HAVE_STDIO_H +#include +#endif +#if defined(STDC_HEADERS) +# include +# include +# include +#else +# if defined(HAVE_STDLIB_H) +# include +# elif defined(HAVE_MALLOC_H) +# include +# endif +# if defined(HAVE_STDDEF_H) +# include +# endif +# if defined(HAVE_STDARG_H) +# include +# endif +#endif +#ifdef HAVE_STRING_H +# if !defined(STDC_HEADERS) && defined(HAVE_MEMORY_H) +# include +# endif +# include +#endif +#ifdef HAVE_STRINGS_H +# include +#endif +#if defined(HAVE_INTTYPES_H) +# include +#elif defined(HAVE_STDINT_H) +# include +#endif +#ifdef HAVE_CTYPE_H +# include +#endif +#if defined(HAVE_ICONV) && defined(HAVE_ICONV_H) +# include +#endif + +/** The number of elements in an array */ +#define SDL_arraysize(array) (sizeof(array)/sizeof(array[0])) +#define SDL_TABLESIZE(table) SDL_arraysize(table) + +/* Use proper C++ casts when compiled as C++ to be compatible with the option + -Wold-style-cast of GCC (and -Werror=old-style-cast in GCC 4.2 and above. */ +#ifdef __cplusplus +#define SDL_reinterpret_cast(type, expression) reinterpret_cast(expression) +#define SDL_static_cast(type, expression) static_cast(expression) +#else +#define SDL_reinterpret_cast(type, expression) ((type)(expression)) +#define SDL_static_cast(type, expression) ((type)(expression)) +#endif + +/** @name Basic data types */ +/*@{*/ +typedef enum { + SDL_FALSE = 0, + SDL_TRUE = 1 +} SDL_bool; + +typedef int8_t Sint8; +typedef uint8_t Uint8; +typedef int16_t Sint16; +typedef uint16_t Uint16; +typedef int32_t Sint32; +typedef uint32_t Uint32; + +#ifdef SDL_HAS_64BIT_TYPE +typedef int64_t Sint64; +#ifndef SYMBIAN32_GCCE +typedef uint64_t Uint64; +#endif +#else +/* This is really just a hack to prevent the compiler from complaining */ +typedef struct { + Uint32 hi; + Uint32 lo; +} Uint64, Sint64; +#endif + +/*@}*/ + +/** @name Make sure the types really have the right sizes */ +/*@{*/ +#define SDL_COMPILE_TIME_ASSERT(name, x) \ + typedef int SDL_dummy_ ## name[(x) * 2 - 1] + +SDL_COMPILE_TIME_ASSERT(uint8, sizeof(Uint8) == 1); +SDL_COMPILE_TIME_ASSERT(sint8, sizeof(Sint8) == 1); +SDL_COMPILE_TIME_ASSERT(uint16, sizeof(Uint16) == 2); +SDL_COMPILE_TIME_ASSERT(sint16, sizeof(Sint16) == 2); +SDL_COMPILE_TIME_ASSERT(uint32, sizeof(Uint32) == 4); +SDL_COMPILE_TIME_ASSERT(sint32, sizeof(Sint32) == 4); +SDL_COMPILE_TIME_ASSERT(uint64, sizeof(Uint64) == 8); +SDL_COMPILE_TIME_ASSERT(sint64, sizeof(Sint64) == 8); +/*@}*/ + +/** @name Enum Size Check + * Check to make sure enums are the size of ints, for structure packing. + * For both Watcom C/C++ and Borland C/C++ the compiler option that makes + * enums having the size of an int must be enabled. + * This is "-b" for Borland C/C++ and "-ei" for Watcom C/C++ (v11). + */ +/* Enable enums always int in CodeWarrior (for MPW use "-enum int") */ +#ifdef __MWERKS__ +#pragma enumsalwaysint on +#endif + +typedef enum { + DUMMY_ENUM_VALUE +} SDL_DUMMY_ENUM; + +#ifndef __NDS__ +SDL_COMPILE_TIME_ASSERT(enum, sizeof(SDL_DUMMY_ENUM) == sizeof(int)); +#endif +/*@}*/ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +#ifdef HAVE_MALLOC +#define SDL_malloc malloc +#else +extern DECLSPEC void * SDLCALL SDL_malloc(size_t size); +#endif + +#ifdef HAVE_CALLOC +#define SDL_calloc calloc +#else +extern DECLSPEC void * SDLCALL SDL_calloc(size_t nmemb, size_t size); +#endif + +#ifdef HAVE_REALLOC +#define SDL_realloc realloc +#else +extern DECLSPEC void * SDLCALL SDL_realloc(void *mem, size_t size); +#endif + +#ifdef HAVE_FREE +#define SDL_free free +#else +extern DECLSPEC void SDLCALL SDL_free(void *mem); +#endif + +#if defined(HAVE_ALLOCA) && !defined(alloca) +# if defined(HAVE_ALLOCA_H) +# include +# elif defined(__GNUC__) +# define alloca __builtin_alloca +# elif defined(_MSC_VER) +# include +# define alloca _alloca +# elif defined(__WATCOMC__) +# include +# elif defined(__BORLANDC__) +# include +# elif defined(__DMC__) +# include +# elif defined(__AIX__) + #pragma alloca +# elif defined(__MRC__) + void *alloca (unsigned); +# else + char *alloca (); +# endif +#endif +#ifdef HAVE_ALLOCA +#define SDL_stack_alloc(type, count) (type*)alloca(sizeof(type)*(count)) +#define SDL_stack_free(data) +#else +#define SDL_stack_alloc(type, count) (type*)SDL_malloc(sizeof(type)*(count)) +#define SDL_stack_free(data) SDL_free(data) +#endif + +#ifdef HAVE_GETENV +#define SDL_getenv getenv +#else +extern DECLSPEC char * SDLCALL SDL_getenv(const char *name); +#endif + +#ifdef HAVE_PUTENV +#define SDL_putenv putenv +#else +extern DECLSPEC int SDLCALL SDL_putenv(const char *variable); +#endif + +#ifdef HAVE_QSORT +#define SDL_qsort qsort +#else +extern DECLSPEC void SDLCALL SDL_qsort(void *base, size_t nmemb, size_t size, + int (*compare)(const void *, const void *)); +#endif + +#ifdef HAVE_ABS +#define SDL_abs abs +#else +#define SDL_abs(X) ((X) < 0 ? -(X) : (X)) +#endif + +#define SDL_min(x, y) (((x) < (y)) ? (x) : (y)) +#define SDL_max(x, y) (((x) > (y)) ? (x) : (y)) + +#ifdef HAVE_CTYPE_H +#define SDL_isdigit(X) isdigit(X) +#define SDL_isspace(X) isspace(X) +#define SDL_toupper(X) toupper(X) +#define SDL_tolower(X) tolower(X) +#else +#define SDL_isdigit(X) (((X) >= '0') && ((X) <= '9')) +#define SDL_isspace(X) (((X) == ' ') || ((X) == '\t') || ((X) == '\r') || ((X) == '\n')) +#define SDL_toupper(X) (((X) >= 'a') && ((X) <= 'z') ? ('A'+((X)-'a')) : (X)) +#define SDL_tolower(X) (((X) >= 'A') && ((X) <= 'Z') ? ('a'+((X)-'A')) : (X)) +#endif + +#ifdef HAVE_MEMSET +#define SDL_memset memset +#else +extern DECLSPEC void * SDLCALL SDL_memset(void *dst, int c, size_t len); +#endif + +#if defined(__GNUC__) && defined(i386) +#define SDL_memset4(dst, val, len) \ +do { \ + int u0, u1, u2; \ + __asm__ __volatile__ ( \ + "cld\n\t" \ + "rep ; stosl\n\t" \ + : "=&D" (u0), "=&a" (u1), "=&c" (u2) \ + : "0" (dst), "1" (val), "2" (SDL_static_cast(Uint32, len)) \ + : "memory" ); \ +} while(0) +#endif +#ifndef SDL_memset4 +#define SDL_memset4(dst, val, len) \ +do { \ + unsigned _count = (len); \ + unsigned _n = (_count + 3) / 4; \ + Uint32 *_p = SDL_static_cast(Uint32 *, dst); \ + Uint32 _val = (val); \ + if (len == 0) break; \ + switch (_count % 4) { \ + case 0: do { *_p++ = _val; \ + case 3: *_p++ = _val; \ + case 2: *_p++ = _val; \ + case 1: *_p++ = _val; \ + } while ( --_n ); \ + } \ +} while(0) +#endif + +/* We can count on memcpy existing on Mac OS X and being well-tuned. */ +#if defined(__MACH__) && defined(__APPLE__) +#define SDL_memcpy(dst, src, len) memcpy(dst, src, len) +#elif defined(__GNUC__) && defined(i386) +#define SDL_memcpy(dst, src, len) \ +do { \ + int u0, u1, u2; \ + __asm__ __volatile__ ( \ + "cld\n\t" \ + "rep ; movsl\n\t" \ + "testb $2,%b4\n\t" \ + "je 1f\n\t" \ + "movsw\n" \ + "1:\ttestb $1,%b4\n\t" \ + "je 2f\n\t" \ + "movsb\n" \ + "2:" \ + : "=&c" (u0), "=&D" (u1), "=&S" (u2) \ + : "0" (SDL_static_cast(unsigned, len)/4), "q" (len), "1" (dst),"2" (src) \ + : "memory" ); \ +} while(0) +#endif +#ifndef SDL_memcpy +#ifdef HAVE_MEMCPY +#define SDL_memcpy memcpy +#elif defined(HAVE_BCOPY) +#define SDL_memcpy(d, s, n) bcopy((s), (d), (n)) +#else +extern DECLSPEC void * SDLCALL SDL_memcpy(void *dst, const void *src, size_t len); +#endif +#endif + +/* We can count on memcpy existing on Mac OS X and being well-tuned. */ +#if defined(__MACH__) && defined(__APPLE__) +#define SDL_memcpy4(dst, src, len) memcpy(dst, src, (len)*4) +#elif defined(__GNUC__) && defined(i386) +#define SDL_memcpy4(dst, src, len) \ +do { \ + int ecx, edi, esi; \ + __asm__ __volatile__ ( \ + "cld\n\t" \ + "rep ; movsl" \ + : "=&c" (ecx), "=&D" (edi), "=&S" (esi) \ + : "0" (SDL_static_cast(unsigned, len)), "1" (dst), "2" (src) \ + : "memory" ); \ +} while(0) +#endif +#ifndef SDL_memcpy4 +#define SDL_memcpy4(dst, src, len) SDL_memcpy(dst, src, (len) << 2) +#endif + +#if defined(__GNUC__) && defined(i386) +#define SDL_revcpy(dst, src, len) \ +do { \ + int u0, u1, u2; \ + char *dstp = SDL_static_cast(char *, dst); \ + char *srcp = SDL_static_cast(char *, src); \ + int n = (len); \ + if ( n >= 4 ) { \ + __asm__ __volatile__ ( \ + "std\n\t" \ + "rep ; movsl\n\t" \ + "cld\n\t" \ + : "=&c" (u0), "=&D" (u1), "=&S" (u2) \ + : "0" (n >> 2), \ + "1" (dstp+(n-4)), "2" (srcp+(n-4)) \ + : "memory" ); \ + } \ + switch (n & 3) { \ + case 3: dstp[2] = srcp[2]; \ + case 2: dstp[1] = srcp[1]; \ + case 1: dstp[0] = srcp[0]; \ + break; \ + default: \ + break; \ + } \ +} while(0) +#endif +#ifndef SDL_revcpy +extern DECLSPEC void * SDLCALL SDL_revcpy(void *dst, const void *src, size_t len); +#endif + +#ifdef HAVE_MEMMOVE +#define SDL_memmove memmove +#elif defined(HAVE_BCOPY) +#define SDL_memmove(d, s, n) bcopy((s), (d), (n)) +#else +#define SDL_memmove(dst, src, len) \ +do { \ + if ( dst < src ) { \ + SDL_memcpy(dst, src, len); \ + } else { \ + SDL_revcpy(dst, src, len); \ + } \ +} while(0) +#endif + +#ifdef HAVE_MEMCMP +#define SDL_memcmp memcmp +#else +extern DECLSPEC int SDLCALL SDL_memcmp(const void *s1, const void *s2, size_t len); +#endif + +#ifdef HAVE_STRLEN +#define SDL_strlen strlen +#else +extern DECLSPEC size_t SDLCALL SDL_strlen(const char *string); +#endif + +#ifdef HAVE_STRLCPY +#define SDL_strlcpy strlcpy +#else +extern DECLSPEC size_t SDLCALL SDL_strlcpy(char *dst, const char *src, size_t maxlen); +#endif + +#ifdef HAVE_STRLCAT +#define SDL_strlcat strlcat +#else +extern DECLSPEC size_t SDLCALL SDL_strlcat(char *dst, const char *src, size_t maxlen); +#endif + +#ifdef HAVE_STRDUP +#define SDL_strdup strdup +#else +extern DECLSPEC char * SDLCALL SDL_strdup(const char *string); +#endif + +#ifdef HAVE__STRREV +#define SDL_strrev _strrev +#else +extern DECLSPEC char * SDLCALL SDL_strrev(char *string); +#endif + +#ifdef HAVE__STRUPR +#define SDL_strupr _strupr +#else +extern DECLSPEC char * SDLCALL SDL_strupr(char *string); +#endif + +#ifdef HAVE__STRLWR +#define SDL_strlwr _strlwr +#else +extern DECLSPEC char * SDLCALL SDL_strlwr(char *string); +#endif + +#ifdef HAVE_STRCHR +#define SDL_strchr strchr +#elif defined(HAVE_INDEX) +#define SDL_strchr index +#else +extern DECLSPEC char * SDLCALL SDL_strchr(const char *string, int c); +#endif + +#ifdef HAVE_STRRCHR +#define SDL_strrchr strrchr +#elif defined(HAVE_RINDEX) +#define SDL_strrchr rindex +#else +extern DECLSPEC char * SDLCALL SDL_strrchr(const char *string, int c); +#endif + +#ifdef HAVE_STRSTR +#define SDL_strstr strstr +#else +extern DECLSPEC char * SDLCALL SDL_strstr(const char *haystack, const char *needle); +#endif + +#ifdef HAVE_ITOA +#define SDL_itoa itoa +#else +#define SDL_itoa(value, string, radix) SDL_ltoa((long)value, string, radix) +#endif + +#ifdef HAVE__LTOA +#define SDL_ltoa _ltoa +#else +extern DECLSPEC char * SDLCALL SDL_ltoa(long value, char *string, int radix); +#endif + +#ifdef HAVE__UITOA +#define SDL_uitoa _uitoa +#else +#define SDL_uitoa(value, string, radix) SDL_ultoa((long)value, string, radix) +#endif + +#ifdef HAVE__ULTOA +#define SDL_ultoa _ultoa +#else +extern DECLSPEC char * SDLCALL SDL_ultoa(unsigned long value, char *string, int radix); +#endif + +#ifdef HAVE_STRTOL +#define SDL_strtol strtol +#else +extern DECLSPEC long SDLCALL SDL_strtol(const char *string, char **endp, int base); +#endif + +#ifdef HAVE_STRTOUL +#define SDL_strtoul strtoul +#else +extern DECLSPEC unsigned long SDLCALL SDL_strtoul(const char *string, char **endp, int base); +#endif + +#ifdef SDL_HAS_64BIT_TYPE + +#ifdef HAVE__I64TOA +#define SDL_lltoa _i64toa +#else +extern DECLSPEC char* SDLCALL SDL_lltoa(Sint64 value, char *string, int radix); +#endif + +#ifdef HAVE__UI64TOA +#define SDL_ulltoa _ui64toa +#else +extern DECLSPEC char* SDLCALL SDL_ulltoa(Uint64 value, char *string, int radix); +#endif + +#ifdef HAVE_STRTOLL +#define SDL_strtoll strtoll +#else +extern DECLSPEC Sint64 SDLCALL SDL_strtoll(const char *string, char **endp, int base); +#endif + +#ifdef HAVE_STRTOULL +#define SDL_strtoull strtoull +#else +extern DECLSPEC Uint64 SDLCALL SDL_strtoull(const char *string, char **endp, int base); +#endif + +#endif /* SDL_HAS_64BIT_TYPE */ + +#ifdef HAVE_STRTOD +#define SDL_strtod strtod +#else +extern DECLSPEC double SDLCALL SDL_strtod(const char *string, char **endp); +#endif + +#ifdef HAVE_ATOI +#define SDL_atoi atoi +#else +#define SDL_atoi(X) SDL_strtol(X, NULL, 0) +#endif + +#ifdef HAVE_ATOF +#define SDL_atof atof +#else +#define SDL_atof(X) SDL_strtod(X, NULL) +#endif + +#ifdef HAVE_STRCMP +#define SDL_strcmp strcmp +#else +extern DECLSPEC int SDLCALL SDL_strcmp(const char *str1, const char *str2); +#endif + +#ifdef HAVE_STRNCMP +#define SDL_strncmp strncmp +#else +extern DECLSPEC int SDLCALL SDL_strncmp(const char *str1, const char *str2, size_t maxlen); +#endif + +#ifdef HAVE_STRCASECMP +#define SDL_strcasecmp strcasecmp +#elif defined(HAVE__STRICMP) +#define SDL_strcasecmp _stricmp +#else +extern DECLSPEC int SDLCALL SDL_strcasecmp(const char *str1, const char *str2); +#endif + +#ifdef HAVE_STRNCASECMP +#define SDL_strncasecmp strncasecmp +#elif defined(HAVE__STRNICMP) +#define SDL_strncasecmp _strnicmp +#else +extern DECLSPEC int SDLCALL SDL_strncasecmp(const char *str1, const char *str2, size_t maxlen); +#endif + +#ifdef HAVE_SSCANF +#define SDL_sscanf sscanf +#else +extern DECLSPEC int SDLCALL SDL_sscanf(const char *text, const char *fmt, ...); +#endif + +#ifdef HAVE_SNPRINTF +#define SDL_snprintf snprintf +#else +extern DECLSPEC int SDLCALL SDL_snprintf(char *text, size_t maxlen, const char *fmt, ...); +#endif + +#ifdef HAVE_VSNPRINTF +#define SDL_vsnprintf vsnprintf +#else +extern DECLSPEC int SDLCALL SDL_vsnprintf(char *text, size_t maxlen, const char *fmt, va_list ap); +#endif + +/** @name SDL_ICONV Error Codes + * The SDL implementation of iconv() returns these error codes + */ +/*@{*/ +#define SDL_ICONV_ERROR (size_t)-1 +#define SDL_ICONV_E2BIG (size_t)-2 +#define SDL_ICONV_EILSEQ (size_t)-3 +#define SDL_ICONV_EINVAL (size_t)-4 +/*@}*/ + +#if defined(HAVE_ICONV) && defined(HAVE_ICONV_H) +#define SDL_iconv_t iconv_t +#define SDL_iconv_open iconv_open +#define SDL_iconv_close iconv_close +#else +typedef struct _SDL_iconv_t *SDL_iconv_t; +extern DECLSPEC SDL_iconv_t SDLCALL SDL_iconv_open(const char *tocode, const char *fromcode); +extern DECLSPEC int SDLCALL SDL_iconv_close(SDL_iconv_t cd); +#endif +extern DECLSPEC size_t SDLCALL SDL_iconv(SDL_iconv_t cd, const char **inbuf, size_t *inbytesleft, char **outbuf, size_t *outbytesleft); +/** This function converts a string between encodings in one pass, returning a + * string that must be freed with SDL_free() or NULL on error. + */ +extern DECLSPEC char * SDLCALL SDL_iconv_string(const char *tocode, const char *fromcode, const char *inbuf, size_t inbytesleft); +#define SDL_iconv_utf8_locale(S) SDL_iconv_string("", "UTF-8", S, SDL_strlen(S)+1) +#define SDL_iconv_utf8_ucs2(S) (Uint16 *)SDL_iconv_string("UCS-2", "UTF-8", S, SDL_strlen(S)+1) +#define SDL_iconv_utf8_ucs4(S) (Uint32 *)SDL_iconv_string("UCS-4", "UTF-8", S, SDL_strlen(S)+1) + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_stdinc_h */ diff --git a/Externals/SDL/include/SDL_syswm.h b/Externals/SDL/include/SDL_syswm.h new file mode 100644 index 0000000000..716dddcb73 --- /dev/null +++ b/Externals/SDL/include/SDL_syswm.h @@ -0,0 +1,225 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_syswm.h + * Include file for SDL custom system window manager hooks + */ + +#ifndef _SDL_syswm_h +#define _SDL_syswm_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_version.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** @file SDL_syswm.h + * Your application has access to a special type of event 'SDL_SYSWMEVENT', + * which contains window-manager specific information and arrives whenever + * an unhandled window event occurs. This event is ignored by default, but + * you can enable it with SDL_EventState() + */ +#ifdef SDL_PROTOTYPES_ONLY +struct SDL_SysWMinfo; +typedef struct SDL_SysWMinfo SDL_SysWMinfo; +#else + +/* This is the structure for custom window manager events */ +#if defined(SDL_VIDEO_DRIVER_X11) +#if defined(__APPLE__) && defined(__MACH__) +/* conflicts with Quickdraw.h */ +#define Cursor X11Cursor +#endif + +#include +#include + +#if defined(__APPLE__) && defined(__MACH__) +/* matches the re-define above */ +#undef Cursor +#endif + +/** These are the various supported subsystems under UNIX */ +typedef enum { + SDL_SYSWM_X11 +} SDL_SYSWM_TYPE; + +/** The UNIX custom event structure */ +struct SDL_SysWMmsg { + SDL_version version; + SDL_SYSWM_TYPE subsystem; + union { + XEvent xevent; + } event; +}; + +/** The UNIX custom window manager information structure. + * When this structure is returned, it holds information about which + * low level system it is using, and will be one of SDL_SYSWM_TYPE. + */ +typedef struct SDL_SysWMinfo { + SDL_version version; + SDL_SYSWM_TYPE subsystem; + union { + struct { + Display *display; /**< The X11 display */ + Window window; /**< The X11 display window */ + /** These locking functions should be called around + * any X11 functions using the display variable, + * but not the gfxdisplay variable. + * They lock the event thread, so should not be + * called around event functions or from event filters. + */ + /*@{*/ + void (*lock_func)(void); + void (*unlock_func)(void); + /*@}*/ + + /** @name Introduced in SDL 1.0.2 */ + /*@{*/ + Window fswindow; /**< The X11 fullscreen window */ + Window wmwindow; /**< The X11 managed input window */ + /*@}*/ + + /** @name Introduced in SDL 1.2.12 */ + /*@{*/ + Display *gfxdisplay; /**< The X11 display to which rendering is done */ + /*@}*/ + } x11; + } info; +} SDL_SysWMinfo; + +#elif defined(SDL_VIDEO_DRIVER_NANOX) +#include + +/** The generic custom event structure */ +struct SDL_SysWMmsg { + SDL_version version; + int data; +}; + +/** The windows custom window manager information structure */ +typedef struct SDL_SysWMinfo { + SDL_version version ; + GR_WINDOW_ID window ; /* The display window */ +} SDL_SysWMinfo; + +#elif defined(SDL_VIDEO_DRIVER_WINDIB) || defined(SDL_VIDEO_DRIVER_DDRAW) || defined(SDL_VIDEO_DRIVER_GAPI) +#define WIN32_LEAN_AND_MEAN +#include + +/** The windows custom event structure */ +struct SDL_SysWMmsg { + SDL_version version; + HWND hwnd; /**< The window for the message */ + UINT msg; /**< The type of message */ + WPARAM wParam; /**< WORD message parameter */ + LPARAM lParam; /**< LONG message parameter */ +}; + +/** The windows custom window manager information structure */ +typedef struct SDL_SysWMinfo { + SDL_version version; + HWND window; /**< The Win32 display window */ + HGLRC hglrc; /**< The OpenGL context, if any */ +} SDL_SysWMinfo; + +#elif defined(SDL_VIDEO_DRIVER_RISCOS) + +/** RISC OS custom event structure */ +struct SDL_SysWMmsg { + SDL_version version; + int eventCode; /**< The window for the message */ + int pollBlock[64]; +}; + +/** The RISC OS custom window manager information structure */ +typedef struct SDL_SysWMinfo { + SDL_version version; + int wimpVersion; /**< Wimp version running under */ + int taskHandle; /**< The RISC OS task handle */ + int window; /**< The RISC OS display window */ +} SDL_SysWMinfo; + +#elif defined(SDL_VIDEO_DRIVER_PHOTON) +#include +#include + +/** The QNX custom event structure */ +struct SDL_SysWMmsg { + SDL_version version; + int data; +}; + +/** The QNX custom window manager information structure */ +typedef struct SDL_SysWMinfo { + SDL_version version; + int data; +} SDL_SysWMinfo; + +#else + +/** The generic custom event structure */ +struct SDL_SysWMmsg { + SDL_version version; + int data; +}; + +/** The generic custom window manager information structure */ +typedef struct SDL_SysWMinfo { + SDL_version version; + int data; +} SDL_SysWMinfo; + +#endif /* video driver type */ + +#endif /* SDL_PROTOTYPES_ONLY */ + +/* Function prototypes */ +/** + * This function gives you custom hooks into the window manager information. + * It fills the structure pointed to by 'info' with custom information and + * returns 1 if the function is implemented. If it's not implemented, or + * the version member of the 'info' structure is invalid, it returns 0. + * + * You typically use this function like this: + * @code + * SDL_SysWMInfo info; + * SDL_VERSION(&info.version); + * if ( SDL_GetWMInfo(&info) ) { ... } + * @endcode + */ +extern DECLSPEC int SDLCALL SDL_GetWMInfo(SDL_SysWMinfo *info); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_syswm_h */ diff --git a/Externals/SDL/include/SDL_thread.h b/Externals/SDL/include/SDL_thread.h new file mode 100644 index 0000000000..1ca9a1bc42 --- /dev/null +++ b/Externals/SDL/include/SDL_thread.h @@ -0,0 +1,120 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_thread_h +#define _SDL_thread_h + +/** @file SDL_thread.h + * Header for the SDL thread management routines + * + * @note These are independent of the other SDL routines. + */ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +/* Thread synchronization primitives */ +#include "SDL_mutex.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** The SDL thread structure, defined in SDL_thread.c */ +struct SDL_Thread; +typedef struct SDL_Thread SDL_Thread; + +/** Create a thread */ +#if ((defined(__WIN32__) && !defined(HAVE_LIBC)) || defined(__OS2__)) && !defined(__SYMBIAN32__) +/** + * We compile SDL into a DLL on OS/2. This means, that it's the DLL which + * creates a new thread for the calling process with the SDL_CreateThread() + * API. There is a problem with this, that only the RTL of the SDL.DLL will + * be initialized for those threads, and not the RTL of the calling application! + * To solve this, we make a little hack here. + * We'll always use the caller's _beginthread() and _endthread() APIs to + * start a new thread. This way, if it's the SDL.DLL which uses this API, + * then the RTL of SDL.DLL will be used to create the new thread, and if it's + * the application, then the RTL of the application will be used. + * So, in short: + * Always use the _beginthread() and _endthread() of the calling runtime library! + */ +#define SDL_PASSED_BEGINTHREAD_ENDTHREAD +#ifndef _WIN32_WCE +#include /* This has _beginthread() and _endthread() defined! */ +#endif + +#ifdef __OS2__ +typedef int (*pfnSDL_CurrentBeginThread)(void (*func)(void *), void *, unsigned, void *arg); +typedef void (*pfnSDL_CurrentEndThread)(void); +#elif __GNUC__ +typedef unsigned long (__cdecl *pfnSDL_CurrentBeginThread) (void *, unsigned, + unsigned (__stdcall *func)(void *), void *arg, + unsigned, unsigned *threadID); +typedef void (__cdecl *pfnSDL_CurrentEndThread)(unsigned code); +#else +typedef uintptr_t (__cdecl *pfnSDL_CurrentBeginThread) (void *, unsigned, + unsigned (__stdcall *func)(void *), void *arg, + unsigned, unsigned *threadID); +typedef void (__cdecl *pfnSDL_CurrentEndThread)(unsigned code); +#endif + +extern DECLSPEC SDL_Thread * SDLCALL SDL_CreateThread(int (SDLCALL *fn)(void *), void *data, pfnSDL_CurrentBeginThread pfnBeginThread, pfnSDL_CurrentEndThread pfnEndThread); + +#ifdef __OS2__ +#define SDL_CreateThread(fn, data) SDL_CreateThread(fn, data, _beginthread, _endthread) +#elif defined(_WIN32_WCE) +#define SDL_CreateThread(fn, data) SDL_CreateThread(fn, data, NULL, NULL) +#else +#define SDL_CreateThread(fn, data) SDL_CreateThread(fn, data, _beginthreadex, _endthreadex) +#endif +#else +extern DECLSPEC SDL_Thread * SDLCALL SDL_CreateThread(int (SDLCALL *fn)(void *), void *data); +#endif + +/** Get the 32-bit thread identifier for the current thread */ +extern DECLSPEC Uint32 SDLCALL SDL_ThreadID(void); + +/** Get the 32-bit thread identifier for the specified thread, + * equivalent to SDL_ThreadID() if the specified thread is NULL. + */ +extern DECLSPEC Uint32 SDLCALL SDL_GetThreadID(SDL_Thread *thread); + +/** Wait for a thread to finish. + * The return code for the thread function is placed in the area + * pointed to by 'status', if 'status' is not NULL. + */ +extern DECLSPEC void SDLCALL SDL_WaitThread(SDL_Thread *thread, int *status); + +/** Forcefully kill a thread without worrying about its state */ +extern DECLSPEC void SDLCALL SDL_KillThread(SDL_Thread *thread); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_thread_h */ diff --git a/Externals/SDL/include/SDL_timer.h b/Externals/SDL/include/SDL_timer.h new file mode 100644 index 0000000000..d7cd024601 --- /dev/null +++ b/Externals/SDL/include/SDL_timer.h @@ -0,0 +1,125 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +#ifndef _SDL_timer_h +#define _SDL_timer_h + +/** @file SDL_timer.h + * Header for the SDL time management routines + */ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** This is the OS scheduler timeslice, in milliseconds */ +#define SDL_TIMESLICE 10 + +/** This is the maximum resolution of the SDL timer on all platforms */ +#define TIMER_RESOLUTION 10 /**< Experimentally determined */ + +/** + * Get the number of milliseconds since the SDL library initialization. + * Note that this value wraps if the program runs for more than ~49 days. + */ +extern DECLSPEC Uint32 SDLCALL SDL_GetTicks(void); + +/** Wait a specified number of milliseconds before returning */ +extern DECLSPEC void SDLCALL SDL_Delay(Uint32 ms); + +/** Function prototype for the timer callback function */ +typedef Uint32 (SDLCALL *SDL_TimerCallback)(Uint32 interval); + +/** + * Set a callback to run after the specified number of milliseconds has + * elapsed. The callback function is passed the current timer interval + * and returns the next timer interval. If the returned value is the + * same as the one passed in, the periodic alarm continues, otherwise a + * new alarm is scheduled. If the callback returns 0, the periodic alarm + * is cancelled. + * + * To cancel a currently running timer, call SDL_SetTimer(0, NULL); + * + * The timer callback function may run in a different thread than your + * main code, and so shouldn't call any functions from within itself. + * + * The maximum resolution of this timer is 10 ms, which means that if + * you request a 16 ms timer, your callback will run approximately 20 ms + * later on an unloaded system. If you wanted to set a flag signaling + * a frame update at 30 frames per second (every 33 ms), you might set a + * timer for 30 ms: + * @code SDL_SetTimer((33/10)*10, flag_update); @endcode + * + * If you use this function, you need to pass SDL_INIT_TIMER to SDL_Init(). + * + * Under UNIX, you should not use raise or use SIGALRM and this function + * in the same program, as it is implemented using setitimer(). You also + * should not use this function in multi-threaded applications as signals + * to multi-threaded apps have undefined behavior in some implementations. + * + * This function returns 0 if successful, or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_SetTimer(Uint32 interval, SDL_TimerCallback callback); + +/** @name New timer API + * New timer API, supports multiple timers + * Written by Stephane Peter + */ +/*@{*/ + +/** + * Function prototype for the new timer callback function. + * The callback function is passed the current timer interval and returns + * the next timer interval. If the returned value is the same as the one + * passed in, the periodic alarm continues, otherwise a new alarm is + * scheduled. If the callback returns 0, the periodic alarm is cancelled. + */ +typedef Uint32 (SDLCALL *SDL_NewTimerCallback)(Uint32 interval, void *param); + +/** Definition of the timer ID type */ +typedef struct _SDL_TimerID *SDL_TimerID; + +/** Add a new timer to the pool of timers already running. + * Returns a timer ID, or NULL when an error occurs. + */ +extern DECLSPEC SDL_TimerID SDLCALL SDL_AddTimer(Uint32 interval, SDL_NewTimerCallback callback, void *param); + +/** + * Remove one of the multiple timers knowing its ID. + * Returns a boolean value indicating success. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_RemoveTimer(SDL_TimerID t); + +/*@}*/ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_timer_h */ diff --git a/Externals/SDL/include/SDL_types.h b/Externals/SDL/include/SDL_types.h new file mode 100644 index 0000000000..cfa35236a4 --- /dev/null +++ b/Externals/SDL/include/SDL_types.h @@ -0,0 +1,28 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_types.h + * @deprecated Use SDL_stdinc.h instead. + */ + +/* DEPRECATED */ +#include "SDL_stdinc.h" diff --git a/Externals/SDL/include/SDL_version.h b/Externals/SDL/include/SDL_version.h new file mode 100644 index 0000000000..fa02c3f6da --- /dev/null +++ b/Externals/SDL/include/SDL_version.h @@ -0,0 +1,91 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_version.h + * This header defines the current SDL version + */ + +#ifndef _SDL_version_h +#define _SDL_version_h + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** @name Version Number + * Printable format: "%d.%d.%d", MAJOR, MINOR, PATCHLEVEL + */ +/*@{*/ +#define SDL_MAJOR_VERSION 1 +#define SDL_MINOR_VERSION 2 +#define SDL_PATCHLEVEL 14 +/*@}*/ + +typedef struct SDL_version { + Uint8 major; + Uint8 minor; + Uint8 patch; +} SDL_version; + +/** + * This macro can be used to fill a version structure with the compile-time + * version of the SDL library. + */ +#define SDL_VERSION(X) \ +{ \ + (X)->major = SDL_MAJOR_VERSION; \ + (X)->minor = SDL_MINOR_VERSION; \ + (X)->patch = SDL_PATCHLEVEL; \ +} + +/** This macro turns the version numbers into a numeric value: + * (1,2,3) -> (1203) + * This assumes that there will never be more than 100 patchlevels + */ +#define SDL_VERSIONNUM(X, Y, Z) \ + ((X)*1000 + (Y)*100 + (Z)) + +/** This is the version number macro for the current SDL version */ +#define SDL_COMPILEDVERSION \ + SDL_VERSIONNUM(SDL_MAJOR_VERSION, SDL_MINOR_VERSION, SDL_PATCHLEVEL) + +/** This macro will evaluate to true if compiled with SDL at least X.Y.Z */ +#define SDL_VERSION_ATLEAST(X, Y, Z) \ + (SDL_COMPILEDVERSION >= SDL_VERSIONNUM(X, Y, Z)) + +/** This function gets the version of the dynamically linked SDL library. + * it should NOT be used to fill a version structure, instead you should + * use the SDL_Version() macro. + */ +extern DECLSPEC const SDL_version * SDLCALL SDL_Linked_Version(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_version_h */ diff --git a/Externals/SDL/include/SDL_video.h b/Externals/SDL/include/SDL_video.h new file mode 100644 index 0000000000..8f7f305203 --- /dev/null +++ b/Externals/SDL/include/SDL_video.h @@ -0,0 +1,951 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** @file SDL_video.h + * Header file for access to the SDL raw framebuffer window + */ + +#ifndef _SDL_video_h +#define _SDL_video_h + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_rwops.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** @name Transparency definitions + * These define alpha as the opacity of a surface + */ +/*@{*/ +#define SDL_ALPHA_OPAQUE 255 +#define SDL_ALPHA_TRANSPARENT 0 +/*@}*/ + +/** @name Useful data types */ +/*@{*/ +typedef struct SDL_Rect { + Sint16 x, y; + Uint16 w, h; +} SDL_Rect; + +typedef struct SDL_Color { + Uint8 r; + Uint8 g; + Uint8 b; + Uint8 unused; +} SDL_Color; +#define SDL_Colour SDL_Color + +typedef struct SDL_Palette { + int ncolors; + SDL_Color *colors; +} SDL_Palette; +/*@}*/ + +/** Everything in the pixel format structure is read-only */ +typedef struct SDL_PixelFormat { + SDL_Palette *palette; + Uint8 BitsPerPixel; + Uint8 BytesPerPixel; + Uint8 Rloss; + Uint8 Gloss; + Uint8 Bloss; + Uint8 Aloss; + Uint8 Rshift; + Uint8 Gshift; + Uint8 Bshift; + Uint8 Ashift; + Uint32 Rmask; + Uint32 Gmask; + Uint32 Bmask; + Uint32 Amask; + + /** RGB color key information */ + Uint32 colorkey; + /** Alpha value information (per-surface alpha) */ + Uint8 alpha; +} SDL_PixelFormat; + +/** This structure should be treated as read-only, except for 'pixels', + * which, if not NULL, contains the raw pixel data for the surface. + */ +typedef struct SDL_Surface { + Uint32 flags; /**< Read-only */ + SDL_PixelFormat *format; /**< Read-only */ + int w, h; /**< Read-only */ + Uint16 pitch; /**< Read-only */ + void *pixels; /**< Read-write */ + int offset; /**< Private */ + + /** Hardware-specific surface info */ + struct private_hwdata *hwdata; + + /** clipping information */ + SDL_Rect clip_rect; /**< Read-only */ + Uint32 unused1; /**< for binary compatibility */ + + /** Allow recursive locks */ + Uint32 locked; /**< Private */ + + /** info for fast blit mapping to other surfaces */ + struct SDL_BlitMap *map; /**< Private */ + + /** format version, bumped at every change to invalidate blit maps */ + unsigned int format_version; /**< Private */ + + /** Reference count -- used when freeing surface */ + int refcount; /**< Read-mostly */ +} SDL_Surface; + +/** @name SDL_Surface Flags + * These are the currently supported flags for the SDL_surface + */ +/*@{*/ + +/** Available for SDL_CreateRGBSurface() or SDL_SetVideoMode() */ +/*@{*/ +#define SDL_SWSURFACE 0x00000000 /**< Surface is in system memory */ +#define SDL_HWSURFACE 0x00000001 /**< Surface is in video memory */ +#define SDL_ASYNCBLIT 0x00000004 /**< Use asynchronous blits if possible */ +/*@}*/ + +/** Available for SDL_SetVideoMode() */ +/*@{*/ +#define SDL_ANYFORMAT 0x10000000 /**< Allow any video depth/pixel-format */ +#define SDL_HWPALETTE 0x20000000 /**< Surface has exclusive palette */ +#define SDL_DOUBLEBUF 0x40000000 /**< Set up double-buffered video mode */ +#define SDL_FULLSCREEN 0x80000000 /**< Surface is a full screen display */ +#define SDL_OPENGL 0x00000002 /**< Create an OpenGL rendering context */ +#define SDL_OPENGLBLIT 0x0000000A /**< Create an OpenGL rendering context and use it for blitting */ +#define SDL_RESIZABLE 0x00000010 /**< This video mode may be resized */ +#define SDL_NOFRAME 0x00000020 /**< No window caption or edge frame */ +/*@}*/ + +/** Used internally (read-only) */ +/*@{*/ +#define SDL_HWACCEL 0x00000100 /**< Blit uses hardware acceleration */ +#define SDL_SRCCOLORKEY 0x00001000 /**< Blit uses a source color key */ +#define SDL_RLEACCELOK 0x00002000 /**< Private flag */ +#define SDL_RLEACCEL 0x00004000 /**< Surface is RLE encoded */ +#define SDL_SRCALPHA 0x00010000 /**< Blit uses source alpha blending */ +#define SDL_PREALLOC 0x01000000 /**< Surface uses preallocated memory */ +/*@}*/ + +/*@}*/ + +/** Evaluates to true if the surface needs to be locked before access */ +#define SDL_MUSTLOCK(surface) \ + (surface->offset || \ + ((surface->flags & (SDL_HWSURFACE|SDL_ASYNCBLIT|SDL_RLEACCEL)) != 0)) + +/** typedef for private surface blitting functions */ +typedef int (*SDL_blit)(struct SDL_Surface *src, SDL_Rect *srcrect, + struct SDL_Surface *dst, SDL_Rect *dstrect); + + +/** Useful for determining the video hardware capabilities */ +typedef struct SDL_VideoInfo { + Uint32 hw_available :1; /**< Flag: Can you create hardware surfaces? */ + Uint32 wm_available :1; /**< Flag: Can you talk to a window manager? */ + Uint32 UnusedBits1 :6; + Uint32 UnusedBits2 :1; + Uint32 blit_hw :1; /**< Flag: Accelerated blits HW --> HW */ + Uint32 blit_hw_CC :1; /**< Flag: Accelerated blits with Colorkey */ + Uint32 blit_hw_A :1; /**< Flag: Accelerated blits with Alpha */ + Uint32 blit_sw :1; /**< Flag: Accelerated blits SW --> HW */ + Uint32 blit_sw_CC :1; /**< Flag: Accelerated blits with Colorkey */ + Uint32 blit_sw_A :1; /**< Flag: Accelerated blits with Alpha */ + Uint32 blit_fill :1; /**< Flag: Accelerated color fill */ + Uint32 UnusedBits3 :16; + Uint32 video_mem; /**< The total amount of video memory (in K) */ + SDL_PixelFormat *vfmt; /**< Value: The format of the video surface */ + int current_w; /**< Value: The current video mode width */ + int current_h; /**< Value: The current video mode height */ +} SDL_VideoInfo; + + +/** @name Overlay Formats + * The most common video overlay formats. + * For an explanation of these pixel formats, see: + * http://www.webartz.com/fourcc/indexyuv.htm + * + * For information on the relationship between color spaces, see: + * http://www.neuro.sfc.keio.ac.jp/~aly/polygon/info/color-space-faq.html + */ +/*@{*/ +#define SDL_YV12_OVERLAY 0x32315659 /**< Planar mode: Y + V + U (3 planes) */ +#define SDL_IYUV_OVERLAY 0x56555949 /**< Planar mode: Y + U + V (3 planes) */ +#define SDL_YUY2_OVERLAY 0x32595559 /**< Packed mode: Y0+U0+Y1+V0 (1 plane) */ +#define SDL_UYVY_OVERLAY 0x59565955 /**< Packed mode: U0+Y0+V0+Y1 (1 plane) */ +#define SDL_YVYU_OVERLAY 0x55595659 /**< Packed mode: Y0+V0+Y1+U0 (1 plane) */ +/*@}*/ + +/** The YUV hardware video overlay */ +typedef struct SDL_Overlay { + Uint32 format; /**< Read-only */ + int w, h; /**< Read-only */ + int planes; /**< Read-only */ + Uint16 *pitches; /**< Read-only */ + Uint8 **pixels; /**< Read-write */ + + /** @name Hardware-specific surface info */ + /*@{*/ + struct private_yuvhwfuncs *hwfuncs; + struct private_yuvhwdata *hwdata; + /*@{*/ + + /** @name Special flags */ + /*@{*/ + Uint32 hw_overlay :1; /**< Flag: This overlay hardware accelerated? */ + Uint32 UnusedBits :31; + /*@}*/ +} SDL_Overlay; + + +/** Public enumeration for setting the OpenGL window attributes. */ +typedef enum { + SDL_GL_RED_SIZE, + SDL_GL_GREEN_SIZE, + SDL_GL_BLUE_SIZE, + SDL_GL_ALPHA_SIZE, + SDL_GL_BUFFER_SIZE, + SDL_GL_DOUBLEBUFFER, + SDL_GL_DEPTH_SIZE, + SDL_GL_STENCIL_SIZE, + SDL_GL_ACCUM_RED_SIZE, + SDL_GL_ACCUM_GREEN_SIZE, + SDL_GL_ACCUM_BLUE_SIZE, + SDL_GL_ACCUM_ALPHA_SIZE, + SDL_GL_STEREO, + SDL_GL_MULTISAMPLEBUFFERS, + SDL_GL_MULTISAMPLESAMPLES, + SDL_GL_ACCELERATED_VISUAL, + SDL_GL_SWAP_CONTROL +} SDL_GLattr; + +/** @name flags for SDL_SetPalette() */ +/*@{*/ +#define SDL_LOGPAL 0x01 +#define SDL_PHYSPAL 0x02 +/*@}*/ + +/* Function prototypes */ + +/** + * @name Video Init and Quit + * These functions are used internally, and should not be used unless you + * have a specific need to specify the video driver you want to use. + * You should normally use SDL_Init() or SDL_InitSubSystem(). + */ +/*@{*/ +/** + * Initializes the video subsystem. Sets up a connection + * to the window manager, etc, and determines the current video mode and + * pixel format, but does not initialize a window or graphics mode. + * Note that event handling is activated by this routine. + * + * If you use both sound and video in your application, you need to call + * SDL_Init() before opening the sound device, otherwise under Win32 DirectX, + * you won't be able to set full-screen display modes. + */ +extern DECLSPEC int SDLCALL SDL_VideoInit(const char *driver_name, Uint32 flags); +extern DECLSPEC void SDLCALL SDL_VideoQuit(void); +/*@}*/ + +/** + * This function fills the given character buffer with the name of the + * video driver, and returns a pointer to it if the video driver has + * been initialized. It returns NULL if no driver has been initialized. + */ +extern DECLSPEC char * SDLCALL SDL_VideoDriverName(char *namebuf, int maxlen); + +/** + * This function returns a pointer to the current display surface. + * If SDL is doing format conversion on the display surface, this + * function returns the publicly visible surface, not the real video + * surface. + */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_GetVideoSurface(void); + +/** + * This function returns a read-only pointer to information about the + * video hardware. If this is called before SDL_SetVideoMode(), the 'vfmt' + * member of the returned structure will contain the pixel format of the + * "best" video mode. + */ +extern DECLSPEC const SDL_VideoInfo * SDLCALL SDL_GetVideoInfo(void); + +/** + * Check to see if a particular video mode is supported. + * It returns 0 if the requested mode is not supported under any bit depth, + * or returns the bits-per-pixel of the closest available mode with the + * given width and height. If this bits-per-pixel is different from the + * one used when setting the video mode, SDL_SetVideoMode() will succeed, + * but will emulate the requested bits-per-pixel with a shadow surface. + * + * The arguments to SDL_VideoModeOK() are the same ones you would pass to + * SDL_SetVideoMode() + */ +extern DECLSPEC int SDLCALL SDL_VideoModeOK(int width, int height, int bpp, Uint32 flags); + +/** + * Return a pointer to an array of available screen dimensions for the + * given format and video flags, sorted largest to smallest. Returns + * NULL if there are no dimensions available for a particular format, + * or (SDL_Rect **)-1 if any dimension is okay for the given format. + * + * If 'format' is NULL, the mode list will be for the format given + * by SDL_GetVideoInfo()->vfmt + */ +extern DECLSPEC SDL_Rect ** SDLCALL SDL_ListModes(SDL_PixelFormat *format, Uint32 flags); + +/** + * Set up a video mode with the specified width, height and bits-per-pixel. + * + * If 'bpp' is 0, it is treated as the current display bits per pixel. + * + * If SDL_ANYFORMAT is set in 'flags', the SDL library will try to set the + * requested bits-per-pixel, but will return whatever video pixel format is + * available. The default is to emulate the requested pixel format if it + * is not natively available. + * + * If SDL_HWSURFACE is set in 'flags', the video surface will be placed in + * video memory, if possible, and you may have to call SDL_LockSurface() + * in order to access the raw framebuffer. Otherwise, the video surface + * will be created in system memory. + * + * If SDL_ASYNCBLIT is set in 'flags', SDL will try to perform rectangle + * updates asynchronously, but you must always lock before accessing pixels. + * SDL will wait for updates to complete before returning from the lock. + * + * If SDL_HWPALETTE is set in 'flags', the SDL library will guarantee + * that the colors set by SDL_SetColors() will be the colors you get. + * Otherwise, in 8-bit mode, SDL_SetColors() may not be able to set all + * of the colors exactly the way they are requested, and you should look + * at the video surface structure to determine the actual palette. + * If SDL cannot guarantee that the colors you request can be set, + * i.e. if the colormap is shared, then the video surface may be created + * under emulation in system memory, overriding the SDL_HWSURFACE flag. + * + * If SDL_FULLSCREEN is set in 'flags', the SDL library will try to set + * a fullscreen video mode. The default is to create a windowed mode + * if the current graphics system has a window manager. + * If the SDL library is able to set a fullscreen video mode, this flag + * will be set in the surface that is returned. + * + * If SDL_DOUBLEBUF is set in 'flags', the SDL library will try to set up + * two surfaces in video memory and swap between them when you call + * SDL_Flip(). This is usually slower than the normal single-buffering + * scheme, but prevents "tearing" artifacts caused by modifying video + * memory while the monitor is refreshing. It should only be used by + * applications that redraw the entire screen on every update. + * + * If SDL_RESIZABLE is set in 'flags', the SDL library will allow the + * window manager, if any, to resize the window at runtime. When this + * occurs, SDL will send a SDL_VIDEORESIZE event to you application, + * and you must respond to the event by re-calling SDL_SetVideoMode() + * with the requested size (or another size that suits the application). + * + * If SDL_NOFRAME is set in 'flags', the SDL library will create a window + * without any title bar or frame decoration. Fullscreen video modes have + * this flag set automatically. + * + * This function returns the video framebuffer surface, or NULL if it fails. + * + * If you rely on functionality provided by certain video flags, check the + * flags of the returned surface to make sure that functionality is available. + * SDL will fall back to reduced functionality if the exact flags you wanted + * are not available. + */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_SetVideoMode + (int width, int height, int bpp, Uint32 flags); + +/** @name SDL_Update Functions + * These functions should not be called while 'screen' is locked. + */ +/*@{*/ +/** + * Makes sure the given list of rectangles is updated on the given screen. + */ +extern DECLSPEC void SDLCALL SDL_UpdateRects + (SDL_Surface *screen, int numrects, SDL_Rect *rects); +/** + * If 'x', 'y', 'w' and 'h' are all 0, SDL_UpdateRect will update the entire + * screen. + */ +extern DECLSPEC void SDLCALL SDL_UpdateRect + (SDL_Surface *screen, Sint32 x, Sint32 y, Uint32 w, Uint32 h); +/*@}*/ + +/** + * On hardware that supports double-buffering, this function sets up a flip + * and returns. The hardware will wait for vertical retrace, and then swap + * video buffers before the next video surface blit or lock will return. + * On hardware that doesn not support double-buffering, this is equivalent + * to calling SDL_UpdateRect(screen, 0, 0, 0, 0); + * The SDL_DOUBLEBUF flag must have been passed to SDL_SetVideoMode() when + * setting the video mode for this function to perform hardware flipping. + * This function returns 0 if successful, or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_Flip(SDL_Surface *screen); + +/** + * Set the gamma correction for each of the color channels. + * The gamma values range (approximately) between 0.1 and 10.0 + * + * If this function isn't supported directly by the hardware, it will + * be emulated using gamma ramps, if available. If successful, this + * function returns 0, otherwise it returns -1. + */ +extern DECLSPEC int SDLCALL SDL_SetGamma(float red, float green, float blue); + +/** + * Set the gamma translation table for the red, green, and blue channels + * of the video hardware. Each table is an array of 256 16-bit quantities, + * representing a mapping between the input and output for that channel. + * The input is the index into the array, and the output is the 16-bit + * gamma value at that index, scaled to the output color precision. + * + * You may pass NULL for any of the channels to leave it unchanged. + * If the call succeeds, it will return 0. If the display driver or + * hardware does not support gamma translation, or otherwise fails, + * this function will return -1. + */ +extern DECLSPEC int SDLCALL SDL_SetGammaRamp(const Uint16 *red, const Uint16 *green, const Uint16 *blue); + +/** + * Retrieve the current values of the gamma translation tables. + * + * You must pass in valid pointers to arrays of 256 16-bit quantities. + * Any of the pointers may be NULL to ignore that channel. + * If the call succeeds, it will return 0. If the display driver or + * hardware does not support gamma translation, or otherwise fails, + * this function will return -1. + */ +extern DECLSPEC int SDLCALL SDL_GetGammaRamp(Uint16 *red, Uint16 *green, Uint16 *blue); + +/** + * Sets a portion of the colormap for the given 8-bit surface. If 'surface' + * is not a palettized surface, this function does nothing, returning 0. + * If all of the colors were set as passed to SDL_SetColors(), it will + * return 1. If not all the color entries were set exactly as given, + * it will return 0, and you should look at the surface palette to + * determine the actual color palette. + * + * When 'surface' is the surface associated with the current display, the + * display colormap will be updated with the requested colors. If + * SDL_HWPALETTE was set in SDL_SetVideoMode() flags, SDL_SetColors() + * will always return 1, and the palette is guaranteed to be set the way + * you desire, even if the window colormap has to be warped or run under + * emulation. + */ +extern DECLSPEC int SDLCALL SDL_SetColors(SDL_Surface *surface, + SDL_Color *colors, int firstcolor, int ncolors); + +/** + * Sets a portion of the colormap for a given 8-bit surface. + * 'flags' is one or both of: + * SDL_LOGPAL -- set logical palette, which controls how blits are mapped + * to/from the surface, + * SDL_PHYSPAL -- set physical palette, which controls how pixels look on + * the screen + * Only screens have physical palettes. Separate change of physical/logical + * palettes is only possible if the screen has SDL_HWPALETTE set. + * + * The return value is 1 if all colours could be set as requested, and 0 + * otherwise. + * + * SDL_SetColors() is equivalent to calling this function with + * flags = (SDL_LOGPAL|SDL_PHYSPAL). + */ +extern DECLSPEC int SDLCALL SDL_SetPalette(SDL_Surface *surface, int flags, + SDL_Color *colors, int firstcolor, + int ncolors); + +/** + * Maps an RGB triple to an opaque pixel value for a given pixel format + */ +extern DECLSPEC Uint32 SDLCALL SDL_MapRGB +(const SDL_PixelFormat * const format, + const Uint8 r, const Uint8 g, const Uint8 b); + +/** + * Maps an RGBA quadruple to a pixel value for a given pixel format + */ +extern DECLSPEC Uint32 SDLCALL SDL_MapRGBA +(const SDL_PixelFormat * const format, + const Uint8 r, const Uint8 g, const Uint8 b, const Uint8 a); + +/** + * Maps a pixel value into the RGB components for a given pixel format + */ +extern DECLSPEC void SDLCALL SDL_GetRGB(Uint32 pixel, + const SDL_PixelFormat * const fmt, + Uint8 *r, Uint8 *g, Uint8 *b); + +/** + * Maps a pixel value into the RGBA components for a given pixel format + */ +extern DECLSPEC void SDLCALL SDL_GetRGBA(Uint32 pixel, + const SDL_PixelFormat * const fmt, + Uint8 *r, Uint8 *g, Uint8 *b, Uint8 *a); + +/** @sa SDL_CreateRGBSurface */ +#define SDL_AllocSurface SDL_CreateRGBSurface +/** + * Allocate and free an RGB surface (must be called after SDL_SetVideoMode) + * If the depth is 4 or 8 bits, an empty palette is allocated for the surface. + * If the depth is greater than 8 bits, the pixel format is set using the + * flags '[RGB]mask'. + * If the function runs out of memory, it will return NULL. + * + * The 'flags' tell what kind of surface to create. + * SDL_SWSURFACE means that the surface should be created in system memory. + * SDL_HWSURFACE means that the surface should be created in video memory, + * with the same format as the display surface. This is useful for surfaces + * that will not change much, to take advantage of hardware acceleration + * when being blitted to the display surface. + * SDL_ASYNCBLIT means that SDL will try to perform asynchronous blits with + * this surface, but you must always lock it before accessing the pixels. + * SDL will wait for current blits to finish before returning from the lock. + * SDL_SRCCOLORKEY indicates that the surface will be used for colorkey blits. + * If the hardware supports acceleration of colorkey blits between + * two surfaces in video memory, SDL will try to place the surface in + * video memory. If this isn't possible or if there is no hardware + * acceleration available, the surface will be placed in system memory. + * SDL_SRCALPHA means that the surface will be used for alpha blits and + * if the hardware supports hardware acceleration of alpha blits between + * two surfaces in video memory, to place the surface in video memory + * if possible, otherwise it will be placed in system memory. + * If the surface is created in video memory, blits will be _much_ faster, + * but the surface format must be identical to the video surface format, + * and the only way to access the pixels member of the surface is to use + * the SDL_LockSurface() and SDL_UnlockSurface() calls. + * If the requested surface actually resides in video memory, SDL_HWSURFACE + * will be set in the flags member of the returned surface. If for some + * reason the surface could not be placed in video memory, it will not have + * the SDL_HWSURFACE flag set, and will be created in system memory instead. + */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_CreateRGBSurface + (Uint32 flags, int width, int height, int depth, + Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask); +/** @sa SDL_CreateRGBSurface */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_CreateRGBSurfaceFrom(void *pixels, + int width, int height, int depth, int pitch, + Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask); +extern DECLSPEC void SDLCALL SDL_FreeSurface(SDL_Surface *surface); + +/** + * SDL_LockSurface() sets up a surface for directly accessing the pixels. + * Between calls to SDL_LockSurface()/SDL_UnlockSurface(), you can write + * to and read from 'surface->pixels', using the pixel format stored in + * 'surface->format'. Once you are done accessing the surface, you should + * use SDL_UnlockSurface() to release it. + * + * Not all surfaces require locking. If SDL_MUSTLOCK(surface) evaluates + * to 0, then you can read and write to the surface at any time, and the + * pixel format of the surface will not change. In particular, if the + * SDL_HWSURFACE flag is not given when calling SDL_SetVideoMode(), you + * will not need to lock the display surface before accessing it. + * + * No operating system or library calls should be made between lock/unlock + * pairs, as critical system locks may be held during this time. + * + * SDL_LockSurface() returns 0, or -1 if the surface couldn't be locked. + */ +extern DECLSPEC int SDLCALL SDL_LockSurface(SDL_Surface *surface); +extern DECLSPEC void SDLCALL SDL_UnlockSurface(SDL_Surface *surface); + +/** + * Load a surface from a seekable SDL data source (memory or file.) + * If 'freesrc' is non-zero, the source will be closed after being read. + * Returns the new surface, or NULL if there was an error. + * The new surface should be freed with SDL_FreeSurface(). + */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_LoadBMP_RW(SDL_RWops *src, int freesrc); + +/** Convenience macro -- load a surface from a file */ +#define SDL_LoadBMP(file) SDL_LoadBMP_RW(SDL_RWFromFile(file, "rb"), 1) + +/** + * Save a surface to a seekable SDL data source (memory or file.) + * If 'freedst' is non-zero, the source will be closed after being written. + * Returns 0 if successful or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_SaveBMP_RW + (SDL_Surface *surface, SDL_RWops *dst, int freedst); + +/** Convenience macro -- save a surface to a file */ +#define SDL_SaveBMP(surface, file) \ + SDL_SaveBMP_RW(surface, SDL_RWFromFile(file, "wb"), 1) + +/** + * Sets the color key (transparent pixel) in a blittable surface. + * If 'flag' is SDL_SRCCOLORKEY (optionally OR'd with SDL_RLEACCEL), + * 'key' will be the transparent pixel in the source image of a blit. + * SDL_RLEACCEL requests RLE acceleration for the surface if present, + * and removes RLE acceleration if absent. + * If 'flag' is 0, this function clears any current color key. + * This function returns 0, or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_SetColorKey + (SDL_Surface *surface, Uint32 flag, Uint32 key); + +/** + * This function sets the alpha value for the entire surface, as opposed to + * using the alpha component of each pixel. This value measures the range + * of transparency of the surface, 0 being completely transparent to 255 + * being completely opaque. An 'alpha' value of 255 causes blits to be + * opaque, the source pixels copied to the destination (the default). Note + * that per-surface alpha can be combined with colorkey transparency. + * + * If 'flag' is 0, alpha blending is disabled for the surface. + * If 'flag' is SDL_SRCALPHA, alpha blending is enabled for the surface. + * OR:ing the flag with SDL_RLEACCEL requests RLE acceleration for the + * surface; if SDL_RLEACCEL is not specified, the RLE accel will be removed. + * + * The 'alpha' parameter is ignored for surfaces that have an alpha channel. + */ +extern DECLSPEC int SDLCALL SDL_SetAlpha(SDL_Surface *surface, Uint32 flag, Uint8 alpha); + +/** + * Sets the clipping rectangle for the destination surface in a blit. + * + * If the clip rectangle is NULL, clipping will be disabled. + * If the clip rectangle doesn't intersect the surface, the function will + * return SDL_FALSE and blits will be completely clipped. Otherwise the + * function returns SDL_TRUE and blits to the surface will be clipped to + * the intersection of the surface area and the clipping rectangle. + * + * Note that blits are automatically clipped to the edges of the source + * and destination surfaces. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_SetClipRect(SDL_Surface *surface, const SDL_Rect *rect); + +/** + * Gets the clipping rectangle for the destination surface in a blit. + * 'rect' must be a pointer to a valid rectangle which will be filled + * with the correct values. + */ +extern DECLSPEC void SDLCALL SDL_GetClipRect(SDL_Surface *surface, SDL_Rect *rect); + +/** + * Creates a new surface of the specified format, and then copies and maps + * the given surface to it so the blit of the converted surface will be as + * fast as possible. If this function fails, it returns NULL. + * + * The 'flags' parameter is passed to SDL_CreateRGBSurface() and has those + * semantics. You can also pass SDL_RLEACCEL in the flags parameter and + * SDL will try to RLE accelerate colorkey and alpha blits in the resulting + * surface. + * + * This function is used internally by SDL_DisplayFormat(). + */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_ConvertSurface + (SDL_Surface *src, SDL_PixelFormat *fmt, Uint32 flags); + +/** + * This performs a fast blit from the source surface to the destination + * surface. It assumes that the source and destination rectangles are + * the same size. If either 'srcrect' or 'dstrect' are NULL, the entire + * surface (src or dst) is copied. The final blit rectangles are saved + * in 'srcrect' and 'dstrect' after all clipping is performed. + * If the blit is successful, it returns 0, otherwise it returns -1. + * + * The blit function should not be called on a locked surface. + * + * The blit semantics for surfaces with and without alpha and colorkey + * are defined as follows: + * + * RGBA->RGB: + * SDL_SRCALPHA set: + * alpha-blend (using alpha-channel). + * SDL_SRCCOLORKEY ignored. + * SDL_SRCALPHA not set: + * copy RGB. + * if SDL_SRCCOLORKEY set, only copy the pixels matching the + * RGB values of the source colour key, ignoring alpha in the + * comparison. + * + * RGB->RGBA: + * SDL_SRCALPHA set: + * alpha-blend (using the source per-surface alpha value); + * set destination alpha to opaque. + * SDL_SRCALPHA not set: + * copy RGB, set destination alpha to source per-surface alpha value. + * both: + * if SDL_SRCCOLORKEY set, only copy the pixels matching the + * source colour key. + * + * RGBA->RGBA: + * SDL_SRCALPHA set: + * alpha-blend (using the source alpha channel) the RGB values; + * leave destination alpha untouched. [Note: is this correct?] + * SDL_SRCCOLORKEY ignored. + * SDL_SRCALPHA not set: + * copy all of RGBA to the destination. + * if SDL_SRCCOLORKEY set, only copy the pixels matching the + * RGB values of the source colour key, ignoring alpha in the + * comparison. + * + * RGB->RGB: + * SDL_SRCALPHA set: + * alpha-blend (using the source per-surface alpha value). + * SDL_SRCALPHA not set: + * copy RGB. + * both: + * if SDL_SRCCOLORKEY set, only copy the pixels matching the + * source colour key. + * + * If either of the surfaces were in video memory, and the blit returns -2, + * the video memory was lost, so it should be reloaded with artwork and + * re-blitted: + * @code + * while ( SDL_BlitSurface(image, imgrect, screen, dstrect) == -2 ) { + * while ( SDL_LockSurface(image) < 0 ) + * Sleep(10); + * -- Write image pixels to image->pixels -- + * SDL_UnlockSurface(image); + * } + * @endcode + * + * This happens under DirectX 5.0 when the system switches away from your + * fullscreen application. The lock will also fail until you have access + * to the video memory again. + * + * You should call SDL_BlitSurface() unless you know exactly how SDL + * blitting works internally and how to use the other blit functions. + */ +#define SDL_BlitSurface SDL_UpperBlit + +/** This is the public blit function, SDL_BlitSurface(), and it performs + * rectangle validation and clipping before passing it to SDL_LowerBlit() + */ +extern DECLSPEC int SDLCALL SDL_UpperBlit + (SDL_Surface *src, SDL_Rect *srcrect, + SDL_Surface *dst, SDL_Rect *dstrect); +/** This is a semi-private blit function and it performs low-level surface + * blitting only. + */ +extern DECLSPEC int SDLCALL SDL_LowerBlit + (SDL_Surface *src, SDL_Rect *srcrect, + SDL_Surface *dst, SDL_Rect *dstrect); + +/** + * This function performs a fast fill of the given rectangle with 'color' + * The given rectangle is clipped to the destination surface clip area + * and the final fill rectangle is saved in the passed in pointer. + * If 'dstrect' is NULL, the whole surface will be filled with 'color' + * The color should be a pixel of the format used by the surface, and + * can be generated by the SDL_MapRGB() function. + * This function returns 0 on success, or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_FillRect + (SDL_Surface *dst, SDL_Rect *dstrect, Uint32 color); + +/** + * This function takes a surface and copies it to a new surface of the + * pixel format and colors of the video framebuffer, suitable for fast + * blitting onto the display surface. It calls SDL_ConvertSurface() + * + * If you want to take advantage of hardware colorkey or alpha blit + * acceleration, you should set the colorkey and alpha value before + * calling this function. + * + * If the conversion fails or runs out of memory, it returns NULL + */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_DisplayFormat(SDL_Surface *surface); + +/** + * This function takes a surface and copies it to a new surface of the + * pixel format and colors of the video framebuffer (if possible), + * suitable for fast alpha blitting onto the display surface. + * The new surface will always have an alpha channel. + * + * If you want to take advantage of hardware colorkey or alpha blit + * acceleration, you should set the colorkey and alpha value before + * calling this function. + * + * If the conversion fails or runs out of memory, it returns NULL + */ +extern DECLSPEC SDL_Surface * SDLCALL SDL_DisplayFormatAlpha(SDL_Surface *surface); + + +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ +/** @name YUV video surface overlay functions */ /*@{*/ +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ + +/** This function creates a video output overlay + * Calling the returned surface an overlay is something of a misnomer because + * the contents of the display surface underneath the area where the overlay + * is shown is undefined - it may be overwritten with the converted YUV data. + */ +extern DECLSPEC SDL_Overlay * SDLCALL SDL_CreateYUVOverlay(int width, int height, + Uint32 format, SDL_Surface *display); + +/** Lock an overlay for direct access, and unlock it when you are done */ +extern DECLSPEC int SDLCALL SDL_LockYUVOverlay(SDL_Overlay *overlay); +extern DECLSPEC void SDLCALL SDL_UnlockYUVOverlay(SDL_Overlay *overlay); + +/** Blit a video overlay to the display surface. + * The contents of the video surface underneath the blit destination are + * not defined. + * The width and height of the destination rectangle may be different from + * that of the overlay, but currently only 2x scaling is supported. + */ +extern DECLSPEC int SDLCALL SDL_DisplayYUVOverlay(SDL_Overlay *overlay, SDL_Rect *dstrect); + +/** Free a video overlay */ +extern DECLSPEC void SDLCALL SDL_FreeYUVOverlay(SDL_Overlay *overlay); + +/*@}*/ + +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ +/** @name OpenGL support functions. */ /*@{*/ +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ + +/** + * Dynamically load an OpenGL library, or the default one if path is NULL + * + * If you do this, you need to retrieve all of the GL functions used in + * your program from the dynamic library using SDL_GL_GetProcAddress(). + */ +extern DECLSPEC int SDLCALL SDL_GL_LoadLibrary(const char *path); + +/** + * Get the address of a GL function + */ +extern DECLSPEC void * SDLCALL SDL_GL_GetProcAddress(const char* proc); + +/** + * Set an attribute of the OpenGL subsystem before intialization. + */ +extern DECLSPEC int SDLCALL SDL_GL_SetAttribute(SDL_GLattr attr, int value); + +/** + * Get an attribute of the OpenGL subsystem from the windowing + * interface, such as glX. This is of course different from getting + * the values from SDL's internal OpenGL subsystem, which only + * stores the values you request before initialization. + * + * Developers should track the values they pass into SDL_GL_SetAttribute + * themselves if they want to retrieve these values. + */ +extern DECLSPEC int SDLCALL SDL_GL_GetAttribute(SDL_GLattr attr, int* value); + +/** + * Swap the OpenGL buffers, if double-buffering is supported. + */ +extern DECLSPEC void SDLCALL SDL_GL_SwapBuffers(void); + +/** @name OpenGL Internal Functions + * Internal functions that should not be called unless you have read + * and understood the source code for these functions. + */ +/*@{*/ +extern DECLSPEC void SDLCALL SDL_GL_UpdateRects(int numrects, SDL_Rect* rects); +extern DECLSPEC void SDLCALL SDL_GL_Lock(void); +extern DECLSPEC void SDLCALL SDL_GL_Unlock(void); +/*@}*/ + +/*@}*/ + +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ +/** @name Window Manager Functions */ +/** These functions allow interaction with the window manager, if any. */ /*@{*/ +/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ + +/** + * Sets the title and icon text of the display window (UTF-8 encoded) + */ +extern DECLSPEC void SDLCALL SDL_WM_SetCaption(const char *title, const char *icon); +/** + * Gets the title and icon text of the display window (UTF-8 encoded) + */ +extern DECLSPEC void SDLCALL SDL_WM_GetCaption(char **title, char **icon); + +/** + * Sets the icon for the display window. + * This function must be called before the first call to SDL_SetVideoMode(). + * It takes an icon surface, and a mask in MSB format. + * If 'mask' is NULL, the entire icon surface will be used as the icon. + */ +extern DECLSPEC void SDLCALL SDL_WM_SetIcon(SDL_Surface *icon, Uint8 *mask); + +/** + * This function iconifies the window, and returns 1 if it succeeded. + * If the function succeeds, it generates an SDL_APPACTIVE loss event. + * This function is a noop and returns 0 in non-windowed environments. + */ +extern DECLSPEC int SDLCALL SDL_WM_IconifyWindow(void); + +/** + * Toggle fullscreen mode without changing the contents of the screen. + * If the display surface does not require locking before accessing + * the pixel information, then the memory pointers will not change. + * + * If this function was able to toggle fullscreen mode (change from + * running in a window to fullscreen, or vice-versa), it will return 1. + * If it is not implemented, or fails, it returns 0. + * + * The next call to SDL_SetVideoMode() will set the mode fullscreen + * attribute based on the flags parameter - if SDL_FULLSCREEN is not + * set, then the display will be windowed by default where supported. + * + * This is currently only implemented in the X11 video driver. + */ +extern DECLSPEC int SDLCALL SDL_WM_ToggleFullScreen(SDL_Surface *surface); + +typedef enum { + SDL_GRAB_QUERY = -1, + SDL_GRAB_OFF = 0, + SDL_GRAB_ON = 1, + SDL_GRAB_FULLSCREEN /**< Used internally */ +} SDL_GrabMode; +/** + * This function allows you to set and query the input grab state of + * the application. It returns the new input grab state. + * + * Grabbing means that the mouse is confined to the application window, + * and nearly all keyboard input is passed directly to the application, + * and not interpreted by a window manager, if any. + */ +extern DECLSPEC SDL_GrabMode SDLCALL SDL_WM_GrabInput(SDL_GrabMode mode); + +/*@}*/ + +/** @internal Not in public API at the moment - do not use! */ +extern DECLSPEC int SDLCALL SDL_SoftStretch(SDL_Surface *src, SDL_Rect *srcrect, + SDL_Surface *dst, SDL_Rect *dstrect); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* _SDL_video_h */ diff --git a/Externals/SDL/include/begin_code.h b/Externals/SDL/include/begin_code.h new file mode 100644 index 0000000000..22748090c5 --- /dev/null +++ b/Externals/SDL/include/begin_code.h @@ -0,0 +1,191 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2009 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public + License along with this library; if not, write to the Free + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/** + * @file begin_code.h + * This file sets things up for C dynamic library function definitions, + * static inlined functions, and structures aligned at 4-byte alignment. + * If you don't like ugly C preprocessor code, don't look at this file. :) + */ + +/** + * @file begin_code.h + * This shouldn't be nested -- included it around code only. + */ +#ifdef _begin_code_h +#error Nested inclusion of begin_code.h +#endif +#define _begin_code_h + +/** + * @def DECLSPEC + * Some compilers use a special export keyword + */ +#ifndef DECLSPEC +# if defined(__BEOS__) || defined(__HAIKU__) +# if defined(__GNUC__) +# define DECLSPEC __declspec(dllexport) +# else +# define DECLSPEC __declspec(export) +# endif +# elif defined(__WIN32__) +# ifdef __BORLANDC__ +# ifdef BUILD_SDL +# define DECLSPEC +# else +# define DECLSPEC __declspec(dllimport) +# endif +# else +# define DECLSPEC __declspec(dllexport) +# endif +# elif defined(__OS2__) +# ifdef __WATCOMC__ +# ifdef BUILD_SDL +# define DECLSPEC __declspec(dllexport) +# else +# define DECLSPEC +# endif +# elif defined (__GNUC__) && __GNUC__ < 4 +# /* Added support for GCC-EMX = 4 +# define DECLSPEC __attribute__ ((visibility("default"))) +# else +# define DECLSPEC +# endif +# endif +#endif + +/** + * @def SDLCALL + * By default SDL uses the C calling convention + */ +#ifndef SDLCALL +# if defined(__WIN32__) && !defined(__GNUC__) +# define SDLCALL __cdecl +# elif defined(__OS2__) +# if defined (__GNUC__) && __GNUC__ < 4 +# /* Added support for GCC-EMX