glsl-include

Crates.ioglsl-include
lib.rsglsl-include
version0.3.1
sourcesrc
created_at2018-04-09 02:41:56.316158
updated_at2019-03-02 18:09:03.067872
descriptionA library for expanding #include directives in GLSL source strings
homepage
repositoryhttps://github.com/jshrake/glsl-include
max_upload_size
id59657
size24,082
Justin Shrake (jshrake)

documentation

https://docs.rs/glsl-include/

README

glsl-include   Build Status Build Status-win Latest Version

glsl-include is a rust library for expanding #include directives in GLSL source strings


Quick Start

Cargo.toml:

[dependencies]
glsl-include = "0.3"

main.rs:

extern crate glsl_include;
use glsl_include::Context;

fn main () {
    let main = r"
        #version 410
        #include <platform.glsl>
        #include <common.glsl>
        out vec4 fragColor;
        void main () {
            fragColor = vec4(1.0);
        }";
    let platform = "void platform_fn() {}";
    let common = "uniform float iTime;";
    let expanded_src = Context::new()
        .include("platform.glsl", platform)
        .include("common.glsl",common)
        .expand(main).unwrap();
}

pragma include

The library also expands #pragma include statements with no additonal configuration required.

Benchmarks

cargo bench

The workflow I currently use for benchmarking a changeset:

git checkout master; cargo bench
git checkout feature-branch; cargo bench

For the best results with criterion, install gnuplot (macos: brew install gnuplot)

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Commit count: 80

cargo fmt