-
Notifications
You must be signed in to change notification settings - Fork 932
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore(changelog): use 'keep a changelog' format
Links: https://keepachangelog.com/en/1.0.0/ Co-authored-by: Mads Marquart <[email protected]>
- Loading branch information
Showing
1 changed file
with
85 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,44 +1,91 @@ | ||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). | ||
|
||
The sections should follow the order `Added`, `Changed`, `Deprecated`, | ||
`Removed`, and `Fixed`. | ||
|
||
Platform specific changed should be added to the end of the section and grouped | ||
by platform name. Common API additions should have `, implemented` at the end | ||
for platforms where the API was initially implemented. See the following example | ||
on how to add them: | ||
|
||
```md | ||
### Added | ||
|
||
- Add `Window::turbo()`, implemented on X11, Wayland, and Web. | ||
- On X11, add `Window::some_rare_api`. | ||
- On X11, add `Window::even_more_rare_api`. | ||
- On Wayland, add `Window::common_api`. | ||
- On Windows, add `Window::some_rare_api`. | ||
``` | ||
|
||
## Unreleased | ||
|
||
- Deprecate `EventLoop::run` in favor of `EventLoop::run_app`. | ||
- Deprecate `EventLoopExtRunOnDemand::run_on_demand` in favor of `EventLoop::run_app_on_demand`. | ||
- Deprecate `EventLoopExtPumpEvents::pump_events` in favor of `EventLoopExtPumpEvents::pump_app_events`. | ||
### Added | ||
|
||
- Add `OwnedDisplayHandle` type for allowing safe display handle usage outside of | ||
trivial cases. | ||
- Add `ApplicationHandler<T>` trait which mimics `Event<T>`. | ||
- Move `dpi` types to its own crate, and re-export it from the root crate. | ||
- Implement `Sync` for `EventLoopProxy<T: Send>`. | ||
- **Breaking:** Move `Window::new` to `ActiveEventLoop::create_window` and `EventLoop::create_window` (with the latter being deprecated). | ||
- **Breaking:** Rename `EventLoopWindowTarget` to `ActiveEventLoop`. | ||
- **Breaking:** Remove `Deref` implementation for `EventLoop` that gave `EventLoopWindowTarget`. | ||
- **Breaking**: Remove `WindowBuilder` in favor of `WindowAttributes`. | ||
- **Breaking:** Removed unnecessary generic parameter `T` from `EventLoopWindowTarget`. | ||
- On Windows, macOS, X11, Wayland and Web, implement setting images as cursors. See the `custom_cursors.rs` example. | ||
- **Breaking:** Remove `Window::set_cursor_icon` | ||
- Add `WindowBuilder::with_cursor` and `Window::set_cursor` which takes a `CursorIcon` or `CustomCursor` | ||
- Add `CustomCursor::from_rgba` to allow creating cursor images from RGBA data. | ||
- Add `CustomCursorExtWebSys::from_url` to allow loading cursor images from URLs. | ||
- Add `CustomCursorExtWebSys::from_animation` to allow creating animated cursors from other `CustomCursor`s. | ||
- Add `{Active,}EventLoop::create_custom_cursor` to load custom cursor image sources. | ||
- Add `WindowBuilder::with_cursor` and `Window::set_cursor` which takes a | ||
Add `CursorIcon` or `CustomCursor`. | ||
- Add `Sync` implementation for `EventLoopProxy<T: Send>`. | ||
- Add `Window::default_attributes` to get default `WindowAttributes`. | ||
- Add `EventLoop::builder` to get `EventLoopBuilder` without export. | ||
- Add `CustomCursor::from_rgba` to allow creating cursor images from RGBA data. | ||
- Add `CustomCursorExtWebSys::from_url` to allow loading cursor images from URLs. | ||
- Add `CustomCursorExtWebSys::from_animation` to allow creating animated cursors | ||
Add from other `CustomCursor`s. | ||
- Add `{Active,}EventLoop::create_custom_cursor` to load custom cursor image sources. | ||
- Add `ActiveEventLoop::create_window` and `EventLoop::create_window`. | ||
- Add `CustomCursor` which could be set via `Window::set_cursor`, implemented on | ||
Windows, macOS, X11, Wayland, and Web. | ||
- On Web, add to toggle calling `Event.preventDefault()` on `Window`. | ||
- On iOS, add `PinchGesture`, `DoubleTapGesture`, and `RotationGesture` | ||
- On macOS, add services menu. | ||
- **Breaking:** On Web, remove queuing fullscreen request in absence of transient activation. | ||
- On Windows, add `with_title_text_color`, and `with_corner_preference` on | ||
`WindowAttributesExtWindows`. | ||
|
||
### Changed | ||
|
||
- Bump MSRV from `1.65` to `1.70`. | ||
- Rename `TouchpadMagnify` to `PinchGesture`. | ||
- Rename `SmartMagnify` to `DoubleTapGesture`. | ||
- Rename `TouchpadRotate` to `RotationGesture`. | ||
- Rename `EventLoopWindowTarget` to `ActiveEventLoop`. | ||
- Rename `platform::x11::XWindowType` to `platform::x11::WindowType`. | ||
- Rename `VideoMode` to `VideoModeHandle` to represent that it doesn't hold | ||
static data. | ||
- Move `dpi` types to its own crate, and re-export it from the root crate. | ||
- Replace `log` with `tracing`, use `log` feature on `tracing` to restore old | ||
behavior. | ||
- `EventLoop::with_user_event` now returns `EventLoopBuilder`. | ||
- On Web, return `HandleError::Unavailable` when a window handle is not available. | ||
- On Web, return `RawWindowHandle::WebCanvas` instead of `RawWindowHandle::Web`. | ||
- On Web, remove queuing fullscreen request in absence of transient activation. | ||
- On iOS, return `HandleError::Unavailable` when a window handle is not available. | ||
- On macOS, return `HandleError::Unavailable` when a window handle is not available. | ||
- On Windows, remove `WS_CAPTION`, `WS_BORDER`, and `WS_EX_WINDOWEDGE` styles | ||
for child windows without decorations. | ||
|
||
### Deprecated | ||
|
||
- Deprecate `EventLoop::run`, use `EventLoop::run_app`. | ||
- Deprecate `EventLoopExtRunOnDemand::run_on_demand`, use `EventLoop::run_app_on_demand`. | ||
- Deprecate `EventLoopExtPumpEvents::pump_events`, use `EventLoopExtPumpEvents::pump_app_events`. | ||
- Deprecate `Window::set_cursor_icon`, use `Window::set_cursor`. | ||
|
||
### Removed | ||
|
||
- Remove `Window::new`, use `ActiveEventLoop::create_window` and `EventLoop::create_window`. | ||
- Remove `Deref` implementation for `EventLoop` that gave `EventLoopWindowTarget`. | ||
- Remove `WindowBuilder` in favor of `WindowAttributes`. | ||
- Remove Generic parameter `T` from `ActiveEventLoop`. | ||
- Remove `EventLoopBuilder::with_user_event`, use `EventLoop::with_user_event`. | ||
- Remove Redundant `EventLoopError::AlreadyRunning`. | ||
- Remove `WindowAttributes::fullscreen` and expose as field directly. | ||
- On X11, remove `platform::x11::XNotSupported` export. | ||
|
||
### Fixed | ||
|
||
- On Web, fix setting cursor icon overriding cursor visibility. | ||
- **Breaking:** On Web, return `RawWindowHandle::WebCanvas` instead of `RawWindowHandle::Web`. | ||
- **Breaking:** On Web, macOS and iOS, return `HandleError::Unavailable` when a window handle is not available. | ||
- **Breaking:** Bump MSRV from `1.65` to `1.70`. | ||
- On Web, add the ability to toggle calling `Event.preventDefault()` on `Window`. | ||
- **Breaking:** Remove `WindowAttributes::fullscreen()` and expose as field directly. | ||
- **Breaking:** Rename `VideoMode` to `VideoModeHandle` to represent that it doesn't hold static data. | ||
- **Breaking:** No longer export `platform::x11::XNotSupported`. | ||
- **Breaking:** Renamed `platform::x11::XWindowType` to `platform::x11::WindowType`. | ||
- Add the `OwnedDisplayHandle` type for allowing safe display handle usage outside of trivial cases. | ||
- **Breaking:** Rename `TouchpadMagnify` to `PinchGesture`, `SmartMagnify` to `DoubleTapGesture` and `TouchpadRotate` to `RotationGesture` to represent the action rather than the intent. | ||
- on iOS, add detection support for `PinchGesture`, `DoubleTapGesture` and `RotationGesture`. | ||
- on Windows: add `with_system_backdrop`, `with_border_color`, `with_title_background_color`, `with_title_text_color` and `with_corner_preference` | ||
- On Windows, Remove `WS_CAPTION`, `WS_BORDER` and `WS_EX_WINDOWEDGE` styles for child windows without decorations. | ||
- **Breaking:** Removed `EventLoopError::AlreadyRunning`, which can't happen as it is already prevented by the type system. | ||
- Added `EventLoop::builder`, which is intended to replace the (now deprecated) `EventLoopBuilder::new`. | ||
- **Breaking:** Changed the signature of `EventLoop::with_user_event` to return a builder. | ||
- **Breaking:** Removed `EventLoopBuilder::with_user_event`, the functionality is now available in `EventLoop::with_user_event`. | ||
- Add `Window::default_attributes` to get default `WindowAttributes`. | ||
- `log` has been replaced with `tracing`. The old behavior can be emulated by setting the `log` feature on the `tracing` crate. | ||
- On Windows, confine cursor to center of window when grabbed and hidden. | ||
- On Windows, fix cursor not confined to center of window when grabbed and hidden. | ||
- On macOS, fix sequence of mouse events being out of order when dragging on the trackpad. |