Skip to content

Commit 9feada2

Browse files
committed
Update run_forever to hijack thread
1 parent 2e83bac commit 9feada2

14 files changed

Lines changed: 100 additions & 64 deletions

examples/cursor.rs

Lines changed: 21 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1,22 +1,21 @@
11
extern crate winit;
22

3-
use winit::{Event, ElementState, MouseCursor, WindowEvent, KeyboardInput, ControlFlow};
3+
use winit::{Event, EventLoop, ElementState, MouseCursor, WindowEvent, KeyboardInput, ControlFlow};
44

55
fn main() {
6-
let mut events_loop = winit::EventLoop::new();
6+
let mut events_loop = EventLoop::new();
77

88
let window = winit::WindowBuilder::new().build(&events_loop).unwrap();
99
window.set_title("A fantastic window!");
1010

11-
let cursors = [MouseCursor::Default, MouseCursor::Crosshair, MouseCursor::Hand, MouseCursor::Arrow, MouseCursor::Move, MouseCursor::Text, MouseCursor::Wait, MouseCursor::Help, MouseCursor::Progress, MouseCursor::NotAllowed, MouseCursor::ContextMenu, MouseCursor::Cell, MouseCursor::VerticalText, MouseCursor::Alias, MouseCursor::Copy, MouseCursor::NoDrop, MouseCursor::Grab, MouseCursor::Grabbing, MouseCursor::AllScroll, MouseCursor::ZoomIn, MouseCursor::ZoomOut, MouseCursor::EResize, MouseCursor::NResize, MouseCursor::NeResize, MouseCursor::NwResize, MouseCursor::SResize, MouseCursor::SeResize, MouseCursor::SwResize, MouseCursor::WResize, MouseCursor::EwResize, MouseCursor::NsResize, MouseCursor::NeswResize, MouseCursor::NwseResize, MouseCursor::ColResize, MouseCursor::RowResize];
1211
let mut cursor_idx = 0;
1312

14-
events_loop.run_forever(|event| {
13+
events_loop.run_forever(move |event, _: &EventLoop| {
1514
match event {
1615
Event::WindowEvent { event: WindowEvent::KeyboardInput { input: KeyboardInput { state: ElementState::Pressed, .. }, .. }, .. } => {
17-
println!("Setting cursor to \"{:?}\"", cursors[cursor_idx]);
18-
window.set_cursor(cursors[cursor_idx]);
19-
if cursor_idx < cursors.len() - 1 {
16+
println!("Setting cursor to \"{:?}\"", CURSORS[cursor_idx]);
17+
window.set_cursor(CURSORS[cursor_idx]);
18+
if cursor_idx < CURSORS.len() - 1 {
2019
cursor_idx += 1;
2120
} else {
2221
cursor_idx = 0;
@@ -30,3 +29,18 @@ fn main() {
3029
ControlFlow::Continue
3130
});
3231
}
32+
33+
const CURSORS: &[MouseCursor] = &[
34+
MouseCursor::Default, MouseCursor::Crosshair, MouseCursor::Hand,
35+
MouseCursor::Arrow, MouseCursor::Move, MouseCursor::Text,
36+
MouseCursor::Wait, MouseCursor::Help, MouseCursor::Progress,
37+
MouseCursor::NotAllowed, MouseCursor::ContextMenu, MouseCursor::Cell,
38+
MouseCursor::VerticalText, MouseCursor::Alias, MouseCursor::Copy,
39+
MouseCursor::NoDrop, MouseCursor::Grab, MouseCursor::Grabbing,
40+
MouseCursor::AllScroll, MouseCursor::ZoomIn, MouseCursor::ZoomOut,
41+
MouseCursor::EResize, MouseCursor::NResize, MouseCursor::NeResize,
42+
MouseCursor::NwResize, MouseCursor::SResize, MouseCursor::SeResize,
43+
MouseCursor::SwResize, MouseCursor::WResize, MouseCursor::EwResize,
44+
MouseCursor::NsResize, MouseCursor::NeswResize, MouseCursor::NwseResize,
45+
MouseCursor::ColResize, MouseCursor::RowResize
46+
];

examples/cursor_grab.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ fn main() {
88
.build(&events_loop)
99
.unwrap();
1010

11-
events_loop.run_forever(|event| {
11+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
1212
if let winit::Event::WindowEvent { event, .. } = event {
1313
use winit::WindowEvent::*;
1414
match event {

examples/fullscreen.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,7 @@ fn main() {
3535
let mut is_maximized = false;
3636
let mut decorations = true;
3737

38-
events_loop.run_forever(|event| {
38+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
3939
println!("{:?}", event);
4040

4141
match event {

examples/handling_close.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ fn main() {
1010

1111
let mut close_requested = false;
1212

13-
events_loop.run_forever(|event| {
13+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
1414
use winit::WindowEvent::*;
1515
use winit::ElementState::Released;
1616
use winit::VirtualKeyCode::{N, Y};

examples/min_max_size.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,7 @@ fn main() {
1212
window.set_min_dimensions(Some(LogicalSize::new(400.0, 200.0)));
1313
window.set_max_dimensions(Some(LogicalSize::new(800.0, 400.0)));
1414

15-
events_loop.run_forever(|event| {
15+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
1616
println!("{:?}", event);
1717

1818
match event {

examples/multiwindow.rs

Lines changed: 16 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -11,19 +11,25 @@ fn main() {
1111
windows.insert(window.id(), window);
1212
}
1313

14-
events_loop.run_forever(|event| {
14+
events_loop.run_forever(move |event, events_loop: &winit::EventLoop| {
1515
match event {
16-
winit::Event::WindowEvent {
17-
event: winit::WindowEvent::CloseRequested,
18-
window_id,
19-
} => {
20-
println!("Window {:?} has received the signal to close", window_id);
16+
winit::Event::WindowEvent { event, window_id } => {
17+
match event {
18+
winit::WindowEvent::CloseRequested => {
19+
println!("Window {:?} has received the signal to close", window_id);
2120

22-
// This drops the window, causing it to close.
23-
windows.remove(&window_id);
21+
// This drops the window, causing it to close.
22+
windows.remove(&window_id);
2423

25-
if windows.is_empty() {
26-
return winit::ControlFlow::Break;
24+
if windows.is_empty() {
25+
return winit::ControlFlow::Break;
26+
}
27+
},
28+
winit::WindowEvent::KeyboardInput{..} => {
29+
let window = winit::Window::new(&events_loop).unwrap();
30+
windows.insert(window.id(), window);
31+
},
32+
_ => ()
2733
}
2834
}
2935
_ => (),

examples/proxy.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@ fn main() {
1818
}
1919
});
2020

21-
events_loop.run_forever(|event| {
21+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
2222
println!("{:?}", event);
2323
match event {
2424
winit::Event::WindowEvent { event: winit::WindowEvent::CloseRequested, .. } =>

examples/resizable.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,7 @@ fn main() {
1212
.build(&events_loop)
1313
.unwrap();
1414

15-
events_loop.run_forever(|event| {
15+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
1616
match event {
1717
winit::Event::WindowEvent { event, .. } => match event {
1818
winit::WindowEvent::CloseRequested => return winit::ControlFlow::Break,

examples/transparent.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ fn main() {
99

1010
window.set_title("A fantastic window!");
1111

12-
events_loop.run_forever(|event| {
12+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
1313
println!("{:?}", event);
1414

1515
match event {

examples/window.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,14 @@
11
extern crate winit;
22

33
fn main() {
4-
let mut events_loop = winit::EventLoop::new();
4+
let events_loop = winit::EventLoop::new();
55

66
let _window = winit::WindowBuilder::new()
77
.with_title("A fantastic window!")
88
.build(&events_loop)
99
.unwrap();
1010

11-
events_loop.run_forever(|event| {
11+
events_loop.run_forever(move |event, _: &winit::EventLoop| {
1212
println!("{:?}", event);
1313

1414
match event {

0 commit comments

Comments
 (0)