1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
// Copyright 2015 Brendan Zabarauskas and the gl-rs developers // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. //! # Usage //! //! You can import the pointer style loader and type aliases like so: //! //! ~~~no_run //! # #![allow(unused_imports)] //! extern crate gl; //! # fn main() { //! // include the OpenGL type aliases //! use gl::types::*; //! # } //! ~~~ //! //! You can load the function pointers into their respective function pointers //! using the `load_with` function. You must supply a loader function from your //! context library, This is how it would look using [glfw-rs] //! (https://github.com/PistonDevelopers/glfw-rs): //! //! ~~~ignore //! // the supplied function must be of the type: //! // `&fn(symbol: &'static str) -> *const std::os::raw::c_void` //! gl::load_with(|s| glfw.get_proc_address(s)); //! //! // loading a specific function pointer //! gl::Viewport::load_with(|s| glfw.get_proc_address(s)); //! ~~~ //! //! Calling a function that has not been loaded will result in a failure like: //! `panic!("gl::Viewport was not loaded")`, which aviods a segfault. This feature //! does not cause any run time overhead because the failing functions are //! assigned only when `load_with` is called. //! //! ~~~no_run //! # #![allow(path_statement)] //! # extern crate gl; //! # fn main() { //! // accessing an enum //! gl::TEXTURE_2D; //! //! // calling a function //! unsafe { gl::DrawArrays(gl::TRIANGLES, 0, 3) }; //! //! // functions that take pointers are unsafe //! # let shader = 0; //! # let c_str: *const i8 = std::ptr::null(); //! unsafe { gl::ShaderSource(shader, 1, &c_str, std::ptr::null()) }; //! # } //! ~~~ //! //! Each function pointer has an associated boolean value allowing you to //! check if a function has been loaded at run time. The function accesses a //! corresponding global boolean that is set when `load_with` is called, so there //! shouldn't be much overhead. //! //! ~~~no_run //! if gl::Viewport::is_loaded() { //! // do something... //! } //! ~~~ //! #![crate_name = "gl"] #![crate_type = "lib"] include!(concat!(env!("OUT_DIR"), "/bindings.rs"));