mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 21:31:29 +11:00
Remove the "headless" feature
This commit is contained in:
parent
e953e3d4ea
commit
ace4808fac
|
@ -17,7 +17,7 @@ env:
|
||||||
|
|
||||||
script:
|
script:
|
||||||
- cargo build --verbose
|
- cargo build --verbose
|
||||||
- cargo test --no-run --verbose
|
- cargo test --verbose
|
||||||
- cargo test --verbose --features "headless" --no-default-features
|
- cargo test --verbose --features "headless" --no-default-features
|
||||||
|
|
||||||
os:
|
os:
|
||||||
|
|
|
@ -50,9 +50,9 @@ user32-sys = "0.1"
|
||||||
kernel32-sys = "0.1"
|
kernel32-sys = "0.1"
|
||||||
|
|
||||||
[target.i686-unknown-linux-gnu.dependencies]
|
[target.i686-unknown-linux-gnu.dependencies]
|
||||||
osmesa-sys = "*"
|
osmesa-sys = "0.0.5"
|
||||||
x11 = "*"
|
x11 = "*"
|
||||||
|
|
||||||
[target.x86_64-unknown-linux-gnu.dependencies]
|
[target.x86_64-unknown-linux-gnu.dependencies]
|
||||||
osmesa-sys = "*"
|
osmesa-sys = "0.0.5"
|
||||||
x11 = "*"
|
x11 = "*"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#![cfg(all(any(target_os = "linux", target_os = "freebsd"), feature="headless"))]
|
#![cfg(any(target_os = "linux", target_os = "freebsd"))]
|
||||||
|
|
||||||
use libc;
|
use libc;
|
||||||
use api::osmesa::OsMesaContext;
|
use api::osmesa::{OsMesaContext, OsMesaCreationError};
|
||||||
|
|
||||||
use Api;
|
use Api;
|
||||||
use BuilderAttribs;
|
use BuilderAttribs;
|
||||||
|
@ -83,7 +83,12 @@ impl<'a> Iterator for WaitEventsIterator<'a> {
|
||||||
|
|
||||||
impl Window {
|
impl Window {
|
||||||
pub fn new(builder: BuilderAttribs) -> Result<Window, CreationError> {
|
pub fn new(builder: BuilderAttribs) -> Result<Window, CreationError> {
|
||||||
let opengl = try!(OsMesaContext::new(builder));
|
let opengl = match OsMesaContext::new(builder) {
|
||||||
|
Err(OsMesaCreationError::NotSupported) => return Err(CreationError::NotSupported),
|
||||||
|
Err(OsMesaCreationError::CreationError(e)) => return Err(e),
|
||||||
|
Ok(c) => c
|
||||||
|
};
|
||||||
|
|
||||||
let opengl_dimensions = opengl.get_dimensions();
|
let opengl_dimensions = opengl.get_dimensions();
|
||||||
|
|
||||||
let libcaca = match ffi::LibCaca::open(&Path::new("libcaca.so.0")) {
|
let libcaca = match ffi::LibCaca::open(&Path::new("libcaca.so.0")) {
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
#![cfg(target_os = "macos")]
|
#![cfg(target_os = "macos")]
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
pub use self::headless::HeadlessContext;
|
pub use self::headless::HeadlessContext;
|
||||||
|
|
||||||
use {CreationError, Event, MouseCursor, CursorState};
|
use {CreationError, Event, MouseCursor, CursorState};
|
||||||
|
@ -48,8 +47,6 @@ pub use self::monitor::{MonitorID, get_available_monitors, get_primary_monitor};
|
||||||
|
|
||||||
mod monitor;
|
mod monitor;
|
||||||
mod event;
|
mod event;
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
mod headless;
|
mod headless;
|
||||||
|
|
||||||
static mut shift_pressed: bool = false;
|
static mut shift_pressed: bool = false;
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
#![cfg(all(any(target_os = "linux", target_os = "freebsd"), feature="headless"))]
|
#![cfg(any(target_os = "linux", target_os = "freebsd"))]
|
||||||
|
|
||||||
extern crate osmesa_sys;
|
extern crate osmesa_sys;
|
||||||
|
|
||||||
use Api;
|
use Api;
|
||||||
use BuilderAttribs;
|
use BuilderAttribs;
|
||||||
use CreationError;
|
use CreationError;
|
||||||
use CreationError::OsError;
|
|
||||||
use GlContext;
|
use GlContext;
|
||||||
use PixelFormat;
|
use PixelFormat;
|
||||||
use libc;
|
use libc;
|
||||||
|
@ -19,8 +18,23 @@ pub struct OsMesaContext {
|
||||||
height: u32,
|
height: u32,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub enum OsMesaCreationError {
|
||||||
|
CreationError(CreationError),
|
||||||
|
NotSupported,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<CreationError> for OsMesaCreationError {
|
||||||
|
fn from(e: CreationError) -> OsMesaCreationError {
|
||||||
|
OsMesaCreationError::CreationError(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl OsMesaContext {
|
impl OsMesaContext {
|
||||||
pub fn new(builder: BuilderAttribs) -> Result<OsMesaContext, CreationError> {
|
pub fn new(builder: BuilderAttribs) -> Result<OsMesaContext, OsMesaCreationError> {
|
||||||
|
if let Err(_) = osmesa_sys::OsMesa::try_loading() {
|
||||||
|
return Err(OsMesaCreationError::NotSupported);
|
||||||
|
}
|
||||||
|
|
||||||
let dimensions = builder.dimensions.unwrap();
|
let dimensions = builder.dimensions.unwrap();
|
||||||
|
|
||||||
Ok(OsMesaContext {
|
Ok(OsMesaContext {
|
||||||
|
@ -31,7 +45,7 @@ impl OsMesaContext {
|
||||||
context: unsafe {
|
context: unsafe {
|
||||||
let ctxt = osmesa_sys::OSMesaCreateContext(0x1908, ptr::null_mut());
|
let ctxt = osmesa_sys::OSMesaCreateContext(0x1908, ptr::null_mut());
|
||||||
if ctxt.is_null() {
|
if ctxt.is_null() {
|
||||||
return Err(OsError("OSMesaCreateContext failed".to_string()));
|
return Err(CreationError::OsError("OSMesaCreateContext failed".to_string()).into());
|
||||||
}
|
}
|
||||||
ctxt
|
ctxt
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,10 +2,8 @@
|
||||||
|
|
||||||
pub use api::android::*;
|
pub use api::android::*;
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
pub struct HeadlessContext(i32);
|
pub struct HeadlessContext(i32);
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
impl HeadlessContext {
|
impl HeadlessContext {
|
||||||
/// See the docs in the crate root file.
|
/// See the docs in the crate root file.
|
||||||
pub fn new(_builder: BuilderAttribs) -> Result<HeadlessContext, CreationError> {
|
pub fn new(_builder: BuilderAttribs) -> Result<HeadlessContext, CreationError> {
|
||||||
|
@ -32,7 +30,5 @@ impl HeadlessContext {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
unsafe impl Send for HeadlessContext {}
|
unsafe impl Send for HeadlessContext {}
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
unsafe impl Sync for HeadlessContext {}
|
unsafe impl Sync for HeadlessContext {}
|
||||||
|
|
|
@ -5,10 +5,8 @@ use GlContext;
|
||||||
pub use api::emscripten::{Window, WindowProxy, MonitorID, get_available_monitors};
|
pub use api::emscripten::{Window, WindowProxy, MonitorID, get_available_monitors};
|
||||||
pub use api::emscripten::{get_primary_monitor, WaitEventsIterator, PollEventsIterator};
|
pub use api::emscripten::{get_primary_monitor, WaitEventsIterator, PollEventsIterator};
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
pub struct HeadlessContext(Window);
|
pub struct HeadlessContext(Window);
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
impl HeadlessContext {
|
impl HeadlessContext {
|
||||||
/// See the docs in the crate root file.
|
/// See the docs in the crate root file.
|
||||||
pub fn new(builder: BuilderAttribs) -> Result<HeadlessContext, CreationError> {
|
pub fn new(builder: BuilderAttribs) -> Result<HeadlessContext, CreationError> {
|
||||||
|
@ -16,7 +14,6 @@ impl HeadlessContext {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
impl GlContext for HeadlessContext {
|
impl GlContext for HeadlessContext {
|
||||||
unsafe fn make_current(&self) {
|
unsafe fn make_current(&self) {
|
||||||
self.0.make_current()
|
self.0.make_current()
|
||||||
|
@ -43,7 +40,5 @@ impl GlContext for HeadlessContext {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
unsafe impl Send for HeadlessContext {}
|
unsafe impl Send for HeadlessContext {}
|
||||||
#[cfg(feature = "headless")]
|
|
||||||
unsafe impl Sync for HeadlessContext {}
|
unsafe impl Sync for HeadlessContext {}
|
||||||
|
|
|
@ -1,7 +1,13 @@
|
||||||
#![cfg(target_os = "linux")]
|
#![cfg(target_os = "linux")]
|
||||||
|
|
||||||
#[cfg(feature = "headless")]
|
use Api;
|
||||||
pub use api::osmesa::OsMesaContext as HeadlessContext;
|
use BuilderAttribs;
|
||||||
|
use CreationError;
|
||||||
|
use GlContext;
|
||||||
|
use PixelFormat;
|
||||||
|
use libc;
|
||||||
|
|
||||||
|
use api::osmesa::{self, OsMesaContext};
|
||||||
|
|
||||||
#[cfg(feature = "window")]
|
#[cfg(feature = "window")]
|
||||||
pub use api::x11::{Window, WindowProxy, MonitorID, get_available_monitors, get_primary_monitor};
|
pub use api::x11::{Window, WindowProxy, MonitorID, get_available_monitors, get_primary_monitor};
|
||||||
|
@ -12,3 +18,49 @@ pub use api::x11::{WaitEventsIterator, PollEventsIterator};
|
||||||
pub type Window = (); // TODO: hack to make things work
|
pub type Window = (); // TODO: hack to make things work
|
||||||
#[cfg(not(feature = "window"))]
|
#[cfg(not(feature = "window"))]
|
||||||
pub type MonitorID = (); // TODO: hack to make things work
|
pub type MonitorID = (); // TODO: hack to make things work
|
||||||
|
|
||||||
|
pub struct HeadlessContext(OsMesaContext);
|
||||||
|
|
||||||
|
impl HeadlessContext {
|
||||||
|
pub fn new(builder: BuilderAttribs) -> Result<HeadlessContext, CreationError> {
|
||||||
|
match OsMesaContext::new(builder) {
|
||||||
|
Ok(c) => return Ok(HeadlessContext(c)),
|
||||||
|
Err(osmesa::OsMesaCreationError::NotSupported) => (),
|
||||||
|
Err(osmesa::OsMesaCreationError::CreationError(e)) => return Err(e),
|
||||||
|
};
|
||||||
|
|
||||||
|
Err(CreationError::NotSupported)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl GlContext for HeadlessContext {
|
||||||
|
#[inline]
|
||||||
|
unsafe fn make_current(&self) {
|
||||||
|
self.0.make_current()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn is_current(&self) -> bool {
|
||||||
|
self.0.is_current()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn get_proc_address(&self, addr: &str) -> *const libc::c_void {
|
||||||
|
self.0.get_proc_address(addr)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn swap_buffers(&self) {
|
||||||
|
self.0.swap_buffers()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn get_api(&self) -> Api {
|
||||||
|
self.0.get_api()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn get_pixel_format(&self) -> PixelFormat {
|
||||||
|
self.0.get_pixel_format()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue