From 4b5c09627b62c548903264bb5271d24ffd346971 Mon Sep 17 00:00:00 2001 From: grovesNL Date: Sun, 26 May 2024 23:50:51 -0230 Subject: [PATCH] Add note about context drop requirements --- src/lib.rs | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/src/lib.rs b/src/lib.rs index ddf1cfa..ac2d24f 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -87,6 +87,19 @@ pub struct ProgramBinary { pub format: u32, } +/// A trait for types that can be used as a context for OpenGL, OpenGL ES, and WebGL functions. +/// +/// This trait is sealed and cannot be implemented outside of this crate. +/// +/// # Safety +/// +/// All GL API usage must be valid. For example, each function call should follow the rules in the +/// relevant GL specification for the type of context being used. This crate doesn't enforce these +/// rules, so it is up to the caller to ensure they're followed. +/// +/// The context implementing this trait must be current when it is dropped. This is necessary to +/// ensure that certain context state can be deleted on the correct thread. Usually this is only +/// a concern for desktop GL contexts that are shared between threads. pub trait HasContext: __private::Sealed { type Shader: Copy + Clone + Debug + Eq + Hash + Ord + PartialEq + PartialOrd; type Program: Copy + Clone + Debug + Eq + Hash + Ord + PartialEq + PartialOrd;