mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 13:31:29 +11:00
Iterators returned by wait_events and poll_events are now persistent
This commit is contained in:
parent
bcda363188
commit
8fcd676714
|
@ -47,6 +47,6 @@ fn main() {
|
||||||
context.draw_frame((0.0, 1.0, 0.0, 1.0));
|
context.draw_frame((0.0, 1.0, 0.0, 1.0));
|
||||||
window.swap_buffers();
|
window.swap_buffers();
|
||||||
|
|
||||||
println!("{:?}", window.wait_events().collect::<Vec<glutin::Event>>());
|
println!("{:?}", window.wait_events().next());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,6 +47,6 @@ fn run(window: glutin::Window, color: (f32, f32, f32, f32)) {
|
||||||
context.draw_frame(color);
|
context.draw_frame(color);
|
||||||
window.swap_buffers();
|
window.swap_buffers();
|
||||||
|
|
||||||
window.wait_events().collect::<Vec<glutin::Event>>();
|
window.wait_events().next();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,6 @@ fn main() {
|
||||||
context.draw_frame((0.0, 1.0, 0.0, 1.0));
|
context.draw_frame((0.0, 1.0, 0.0, 1.0));
|
||||||
window.swap_buffers();
|
window.swap_buffers();
|
||||||
|
|
||||||
println!("{:?}", window.wait_events().collect::<Vec<glutin::Event>>());
|
println!("{:?}", window.wait_events().next());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
38
src/lib.rs
38
src/lib.rs
|
@ -537,22 +537,22 @@ impl Window {
|
||||||
self.window.set_inner_size(x, y)
|
self.window.set_inner_size(x, y)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns an iterator to all the events that are currently in the window's events queue.
|
/// Returns an iterator that poll for the next event in the window's events queue.
|
||||||
|
/// Returns `None` if there is no event in the queue.
|
||||||
///
|
///
|
||||||
/// Contrary to `wait_events`, this function never blocks.
|
/// Contrary to `wait_events`, this function never blocks.
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn poll_events(&self) -> PollEventsIterator {
|
pub fn poll_events(&self) -> PollEventsIterator {
|
||||||
PollEventsIterator { data: self.window.poll_events().into_iter() }
|
PollEventsIterator { window: self, data: self.window.poll_events().into_iter() }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Waits for an event, then returns an iterator to all the events that are currently
|
/// Returns an iterator that returns events one by one, blocking if necessary until one is
|
||||||
/// in the window's events queue.
|
/// available.
|
||||||
///
|
///
|
||||||
/// If there are no events in queue when you call the function,
|
/// The iterator never returns `None`.
|
||||||
/// this function will block until there is one.
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn wait_events(&self) -> WaitEventsIterator {
|
pub fn wait_events(&self) -> WaitEventsIterator {
|
||||||
WaitEventsIterator { data: self.window.wait_events().into_iter() }
|
WaitEventsIterator { window: self, data: self.window.wait_events().into_iter() }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Sets the context as the current context.
|
/// Sets the context as the current context.
|
||||||
|
@ -697,13 +697,24 @@ impl gl_common::GlFunctionsSource for HeadlessContext {
|
||||||
/// An iterator for the `poll_events` function.
|
/// An iterator for the `poll_events` function.
|
||||||
// Implementation note: we retreive the list once, then serve each element by one by one.
|
// Implementation note: we retreive the list once, then serve each element by one by one.
|
||||||
// This may change in the future.
|
// This may change in the future.
|
||||||
|
#[cfg(feature = "window")]
|
||||||
pub struct PollEventsIterator<'a> {
|
pub struct PollEventsIterator<'a> {
|
||||||
|
window: &'a Window,
|
||||||
data: RingBufIter<Event>,
|
data: RingBufIter<Event>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "window")]
|
||||||
impl<'a> Iterator for PollEventsIterator<'a> {
|
impl<'a> Iterator for PollEventsIterator<'a> {
|
||||||
type Item = Event;
|
type Item = Event;
|
||||||
fn next(&mut self) -> Option<Event> {
|
fn next(&mut self) -> Option<Event> {
|
||||||
|
if let Some(ev) = self.data.next() {
|
||||||
|
return Some(ev);
|
||||||
|
}
|
||||||
|
|
||||||
|
let PollEventsIterator { window, data } = self.window.poll_events();
|
||||||
|
self.window = window;
|
||||||
|
self.data = data;
|
||||||
|
|
||||||
self.data.next()
|
self.data.next()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -711,14 +722,25 @@ impl<'a> Iterator for PollEventsIterator<'a> {
|
||||||
/// An iterator for the `wait_events` function.
|
/// An iterator for the `wait_events` function.
|
||||||
// Implementation note: we retreive the list once, then serve each element by one by one.
|
// Implementation note: we retreive the list once, then serve each element by one by one.
|
||||||
// This may change in the future.
|
// This may change in the future.
|
||||||
|
#[cfg(feature = "window")]
|
||||||
pub struct WaitEventsIterator<'a> {
|
pub struct WaitEventsIterator<'a> {
|
||||||
|
window: &'a Window,
|
||||||
data: RingBufIter<Event>,
|
data: RingBufIter<Event>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "window")]
|
||||||
impl<'a> Iterator for WaitEventsIterator<'a> {
|
impl<'a> Iterator for WaitEventsIterator<'a> {
|
||||||
type Item = Event;
|
type Item = Event;
|
||||||
fn next(&mut self) -> Option<Event> {
|
fn next(&mut self) -> Option<Event> {
|
||||||
self.data.next()
|
if let Some(ev) = self.data.next() {
|
||||||
|
return Some(ev);
|
||||||
|
}
|
||||||
|
|
||||||
|
let WaitEventsIterator { window, data } = self.window.wait_events();
|
||||||
|
self.window = window;
|
||||||
|
self.data = data;
|
||||||
|
|
||||||
|
self.next()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue