mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 13:31:29 +11:00
Implemented gl_core flag
This commit is contained in:
parent
c1ca5d1d87
commit
a42f1f5833
|
@ -1,6 +1,6 @@
|
||||||
[package]
|
[package]
|
||||||
name = "glutin"
|
name = "glutin"
|
||||||
version = "0.0.27"
|
version = "0.0.28"
|
||||||
authors = ["tomaka <pierre.krieger1708@gmail.com>"]
|
authors = ["tomaka <pierre.krieger1708@gmail.com>"]
|
||||||
description = "Cross-plaform OpenGL context provider."
|
description = "Cross-plaform OpenGL context provider."
|
||||||
keywords = ["windowing", "opengl"]
|
keywords = ["windowing", "opengl"]
|
||||||
|
|
1
build.rs
1
build.rs
|
@ -52,6 +52,7 @@ fn main() {
|
||||||
khronos_api::GLX_XML,
|
khronos_api::GLX_XML,
|
||||||
vec![
|
vec![
|
||||||
"GLX_ARB_create_context".to_string(),
|
"GLX_ARB_create_context".to_string(),
|
||||||
|
"GLX_ARB_create_context_profile".to_string(),
|
||||||
"GLX_ARB_framebuffer_sRGB".to_string(),
|
"GLX_ARB_framebuffer_sRGB".to_string(),
|
||||||
"GLX_EXT_framebuffer_sRGB".to_string(),
|
"GLX_EXT_framebuffer_sRGB".to_string(),
|
||||||
"GLX_EXT_swap_control".to_string(),
|
"GLX_EXT_swap_control".to_string(),
|
||||||
|
|
|
@ -9,6 +9,7 @@ use libc;
|
||||||
|
|
||||||
use Api;
|
use Api;
|
||||||
use BuilderAttribs;
|
use BuilderAttribs;
|
||||||
|
use CreationError;
|
||||||
use GlContext;
|
use GlContext;
|
||||||
use GlRequest;
|
use GlRequest;
|
||||||
use PixelFormat;
|
use PixelFormat;
|
||||||
|
@ -334,7 +335,6 @@ impl Window {
|
||||||
Some(window) => window,
|
Some(window) => window,
|
||||||
None => { return Err(OsError(format!("Couldn't create NSWindow"))); },
|
None => { return Err(OsError(format!("Couldn't create NSWindow"))); },
|
||||||
};
|
};
|
||||||
|
|
||||||
let view = match Window::create_view(*window) {
|
let view = match Window::create_view(*window) {
|
||||||
Some(view) => view,
|
Some(view) => view,
|
||||||
None => { return Err(OsError(format!("Couldn't create NSView"))); },
|
None => { return Err(OsError(format!("Couldn't create NSView"))); },
|
||||||
|
@ -469,18 +469,17 @@ impl Window {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_context(view: id, builder: &BuilderAttribs) -> (Option<IdRef>, Option<PixelFormat>) {
|
fn create_context(view: id, builder: &BuilderAttribs) -> Result<(Option<IdRef>, Option<PixelFormat>), CreationError> {
|
||||||
let profile = match builder.gl_version {
|
let profile = match (builder.gl_version, builder.gl_version.to_gl_version(), builder.gl_core) {
|
||||||
GlRequest::Latest => NSOpenGLProfileVersion4_1Core as u32,
|
(GlRequest::Latest, _, Some(false)) => NSOpenGLProfileVersionLegacy as u32,
|
||||||
GlRequest::Specific(Api::OpenGl, (1 ... 2, _)) => NSOpenGLProfileVersionLegacy as u32,
|
(GlRequest::Latest, _, _) => NSOpenGLProfileVersion4_1Core as u32,
|
||||||
GlRequest::Specific(Api::OpenGl, (3, 0)) => NSOpenGLProfileVersionLegacy as u32,
|
(_, Some(1 ... 2, _), Some(true)) |
|
||||||
GlRequest::Specific(Api::OpenGl, (3, 1 ... 2)) => NSOpenGLProfileVersion3_2Core as u32,
|
(_, Some(3 ... 4, _), Some(false)) =>
|
||||||
GlRequest::Specific(Api::OpenGl, _) => NSOpenGLProfileVersion4_1Core as u32,
|
return Err(CreationError::NotSupported),
|
||||||
GlRequest::Specific(_, _) => panic!("Only the OpenGL API is supported"), // FIXME: return Result
|
(_, Some(1 ... 2, _), _) => NSOpenGLProfileVersionLegacy as u32,
|
||||||
GlRequest::GlThenGles { opengl_version: (1 ... 2, _), .. } => NSOpenGLProfileVersionLegacy as u32,
|
(_, Some(3, 0 ... 2), _) => NSOpenGLProfileVersion3_2Core as u32,
|
||||||
GlRequest::GlThenGles { opengl_version: (3, 0), .. } => NSOpenGLProfileVersionLegacy as u32,
|
(_, Some(3 ... 4, _), _) => NSOpenGLProfileVersion4_1Core as u32,
|
||||||
GlRequest::GlThenGles { opengl_version: (3, 1 ... 2), .. } => NSOpenGLProfileVersion3_2Core as u32,
|
_ => return Err(CreationError::NotSupported),
|
||||||
GlRequest::GlThenGles { .. } => NSOpenGLProfileVersion4_1Core as u32,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
// NOTE: OS X no longer has the concept of setting individual
|
// NOTE: OS X no longer has the concept of setting individual
|
||||||
|
@ -517,7 +516,7 @@ impl Window {
|
||||||
// attribute list must be null terminated.
|
// attribute list must be null terminated.
|
||||||
attributes.push(0);
|
attributes.push(0);
|
||||||
|
|
||||||
unsafe {
|
Ok(unsafe {
|
||||||
let pixelformat = IdRef::new(NSOpenGLPixelFormat::alloc(nil).initWithAttributes_(&attributes));
|
let pixelformat = IdRef::new(NSOpenGLPixelFormat::alloc(nil).initWithAttributes_(&attributes));
|
||||||
|
|
||||||
if let Some(pixelformat) = pixelformat.non_nil() {
|
if let Some(pixelformat) = pixelformat.non_nil() {
|
||||||
|
@ -575,7 +574,7 @@ impl Window {
|
||||||
} else {
|
} else {
|
||||||
(None, None)
|
(None, None)
|
||||||
}
|
}
|
||||||
}
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn is_closed(&self) -> bool {
|
pub fn is_closed(&self) -> bool {
|
||||||
|
|
|
@ -52,6 +52,16 @@ impl Context {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if let Some(core) = builder.gl_core {
|
||||||
|
attributes.push(ffi::glx_extra::CONTEXT_PROFILE_MASK_ARB as libc::c_int);
|
||||||
|
attributes.push(if core {
|
||||||
|
ffi::glx_extra::CONTEXT_CORE_PROFILE_BIT_ARB
|
||||||
|
} else {
|
||||||
|
ffi::glx_extra::CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB
|
||||||
|
} as libc::c_int
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
if builder.gl_debug {
|
if builder.gl_debug {
|
||||||
attributes.push(ffi::glx_extra::CONTEXT_FLAGS_ARB as libc::c_int);
|
attributes.push(ffi::glx_extra::CONTEXT_FLAGS_ARB as libc::c_int);
|
||||||
attributes.push(ffi::glx_extra::CONTEXT_DEBUG_BIT_ARB as libc::c_int);
|
attributes.push(ffi::glx_extra::CONTEXT_DEBUG_BIT_ARB as libc::c_int);
|
||||||
|
@ -184,8 +194,6 @@ unsafe impl Sync for Context {}
|
||||||
|
|
||||||
impl Drop for Context {
|
impl Drop for Context {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
use std::ptr;
|
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
// we don't call MakeCurrent(0, 0) because we are not sure that the context
|
// we don't call MakeCurrent(0, 0) because we are not sure that the context
|
||||||
// is still the current one
|
// is still the current one
|
||||||
|
|
|
@ -374,6 +374,22 @@ unsafe fn create_context(extra: Option<(&gl::wgl_extra::Wgl, &BuilderAttribs<'st
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if let Some(core) = builder.gl_core {
|
||||||
|
if is_extension_supported(extra_functions, hdc,
|
||||||
|
"WGL_ARB_create_context_profile")
|
||||||
|
{
|
||||||
|
attributes.push(gl::wgl_extra::CONTEXT_PROFILE_MASK_ARB as libc::c_int);
|
||||||
|
attributes.push(if core {
|
||||||
|
gl::wgl_extra::CONTEXT_CORE_PROFILE_BIT_ARB
|
||||||
|
} else {
|
||||||
|
gl::wgl_extra::CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB
|
||||||
|
} as libc::c_int
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
return Err(CreationError::NotSupported);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if builder.gl_debug {
|
if builder.gl_debug {
|
||||||
attributes.push(gl::wgl_extra::CONTEXT_FLAGS_ARB as libc::c_int);
|
attributes.push(gl::wgl_extra::CONTEXT_FLAGS_ARB as libc::c_int);
|
||||||
attributes.push(gl::wgl_extra::CONTEXT_DEBUG_BIT_ARB as libc::c_int);
|
attributes.push(gl::wgl_extra::CONTEXT_DEBUG_BIT_ARB as libc::c_int);
|
||||||
|
|
19
src/lib.rs
19
src/lib.rs
|
@ -161,6 +161,22 @@ pub enum GlRequest {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl GlRequest {
|
||||||
|
/// Extract the desktop GL version, if any.
|
||||||
|
pub fn to_gl_version(&self) -> Option<(u8, u8)> {
|
||||||
|
match self {
|
||||||
|
&GlRequest::Specific(Api::OpenGl, version) => Some(version),
|
||||||
|
&GlRequest::GlThenGles { opengl_version: version, .. } => Some(version),
|
||||||
|
_ => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The minimum core profile GL context. Useful for getting the minimum
|
||||||
|
/// required GL version while still running on OSX, which often forbids
|
||||||
|
/// the compatibility profile features.
|
||||||
|
pub static GL_CORE: GlRequest = GlRequest::Specific(Api::OpenGl, (3, 2));
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone)]
|
#[derive(Debug, Copy, Clone)]
|
||||||
pub enum MouseCursor {
|
pub enum MouseCursor {
|
||||||
/// The platform-dependent default cursor.
|
/// The platform-dependent default cursor.
|
||||||
|
@ -261,6 +277,7 @@ pub struct BuilderAttribs<'a> {
|
||||||
title: String,
|
title: String,
|
||||||
monitor: Option<platform::MonitorID>,
|
monitor: Option<platform::MonitorID>,
|
||||||
gl_version: GlRequest,
|
gl_version: GlRequest,
|
||||||
|
gl_core: Option<bool>,
|
||||||
gl_debug: bool,
|
gl_debug: bool,
|
||||||
vsync: bool,
|
vsync: bool,
|
||||||
visible: bool,
|
visible: bool,
|
||||||
|
@ -283,6 +300,7 @@ impl BuilderAttribs<'static> {
|
||||||
title: "glutin window".to_string(),
|
title: "glutin window".to_string(),
|
||||||
monitor: None,
|
monitor: None,
|
||||||
gl_version: GlRequest::Latest,
|
gl_version: GlRequest::Latest,
|
||||||
|
gl_core: None,
|
||||||
gl_debug: cfg!(debug_assertions),
|
gl_debug: cfg!(debug_assertions),
|
||||||
vsync: false,
|
vsync: false,
|
||||||
visible: true,
|
visible: true,
|
||||||
|
@ -309,6 +327,7 @@ impl<'a> BuilderAttribs<'a> {
|
||||||
title: self.title,
|
title: self.title,
|
||||||
monitor: self.monitor,
|
monitor: self.monitor,
|
||||||
gl_version: self.gl_version,
|
gl_version: self.gl_version,
|
||||||
|
gl_core: self.gl_core,
|
||||||
gl_debug: self.gl_debug,
|
gl_debug: self.gl_debug,
|
||||||
vsync: self.vsync,
|
vsync: self.vsync,
|
||||||
visible: self.visible,
|
visible: self.visible,
|
||||||
|
|
|
@ -67,6 +67,12 @@ impl<'a> WindowBuilder<'a> {
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Sets the Core/Compatibility flag of the created OpenGL context.
|
||||||
|
pub fn with_gl_core_profile(mut self, core: bool) -> WindowBuilder<'a> {
|
||||||
|
self.attribs.gl_core = Some(core);
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
/// Sets the *debug* flag for the OpenGL context.
|
/// Sets the *debug* flag for the OpenGL context.
|
||||||
///
|
///
|
||||||
/// The default value for this flag is `cfg!(debug_assertions)`, which means that it's enabled
|
/// The default value for this flag is `cfg!(debug_assertions)`, which means that it's enabled
|
||||||
|
@ -124,9 +130,9 @@ impl<'a> WindowBuilder<'a> {
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Sets whether sRGB should be enabled on the window. `None` means "I don't care".
|
/// Sets whether sRGB should be enabled on the window.
|
||||||
pub fn with_srgb(mut self, srgb_enabled: Option<bool>) -> WindowBuilder<'a> {
|
pub fn with_srgb(mut self, srgb: bool) -> WindowBuilder<'a> {
|
||||||
self.attribs.srgb = srgb_enabled;
|
self.attribs.srgb = Some(srgb);
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue