Skip to content

Commit 7b50c0a

Browse files
committed
feat: pop-os megasquash
x11: Workaround nvidia driver lacking DRI feat(mouse area): add double click mouse area: add double click compositor: Add code to extract adapter from x11 refactor: Extract ids_from_dev from wayland specific code wayland: Don't crash if libwayland isn't available feat(sctk): support for overflow widget sctk: Fixes for cursor icon * With multiple windows, `SetCursor` is only sent for the focused window. Fixing a flicker between icons when two windows are using different cursors. * If there is a drag surface, let that surface set the cursor. And not any other. * Set cursor on `enter`, and when switching between CSDs and app area. Fixes pop-os/libcosmic#533. improv(sctk): per-surface cursor position tracking feat(sctk): support ShowWindowMenu Make text wrap configurable fix(core): state order and handling of new trees fix: settings.decorations enables SSD refactor(sctk): convert window actions fix: enable the tokio feature for accesskit_unix fix: only try to connect to clipboard if on linux iced_wgpu: don't query Wayland on macos Update `window_clipboard` sctk: Unmap subsurfaces instead of immediately destroying them Destroying a surface is immediate, rather than synchronized with commits. This fixes a flickering behavior with drag and drop in cosmic-workspaces. sctk: Add alpha setting to `Subsurface` widget sctk: Update `sctk`, `wayland-protocols` Update for cosmic-text undefined buffer size Adapt to cosmic-text undefined width change fix: unset VK_LOADER_DRIVERS_DISABLE after enumeration Allows applications to be launched on the NVIDIA GPU with Vulkan support Adapt to new cosmic-text wgpu: Fix wayland device id conversion wgpu: Fix querying adapter, even if we already have one wgpu: fix nvidia gpu powering up in hybrid setups cargo fmt fix: refactor dnd impl to support responsive widget fix: update read and write methods so they don't recurse fix(core): replace debug_assert in diff fix: avoid with_borrow_mut fix: better handling of state tree This persists widget state associated with widgets assigned custom IDs even when the tree structure changes, but resets state if the custom ID is not found. fix: emit Event::Resized to fix nav bar in cosmic-settings fix(image): guess the image format before decoding iced_wgpu: Query wayland for the device to use, if possible sctk: Support `start_drag` with drags started from touch events sctk: Add touch support fix: update widnow-clipboard tag fix: clean up dnd surfaces when a window is removed Adjust to line ending needing to be specified as part of cosmic_text::BufferLine sctk: Add support for drag-and-drop surface offsets This adds an offset `Vector` as an argument to `on_drag`, and allows passing an offset to `start_drag`. Some applications using drag and drop want the top left corner of the drag surface (as happens without an offset). But others want the drag surface to be offset based on where the cursor is on the widget when starting the drag. This can just be `-1 * offset`, but may be scaled if the drag surface is a different size from the original widget. fix(sctk): nested popup parent feat(mouseare): mouse enter and exit fix(tiny_skia): damage fix(scrollable): filter scroll events in the wrong direction sctk: Use empty input region for subsurfaces This seems to work, and is a better way to deal with subsurface input if there aren't any problems. This way, input events simply go to the parent surface, so we don't have to deal with various edge cases related to that. (Though for compositor-side issues, we still need to fix those for other clients.) This helps with an issue with drag-and-drop and subsurfaces on Smithay, and a different issue on Kwin (in KDE 5.27, at least). Send `DataSource` events to all surfaces Previously these events are directed to the first surface, then removed from `sctk_events`. Which is definitely not right. slider & toggler roundness Update window_clipboard to pop-dnd-4 fix(tiny-skia): non-simple border scaling the issue can be seen with sharp corners when using the screenshot portal with scaling Add read_primary/write_primary chore: update tag fix: translate offer positions in scrollable fix(winit multi-window): handle exit_on_close request fix(scrollable): pass child layout when calculating drag destinations fix(container): id and set_id should use content Clean up after lock surfaces are destroyed Call unlock on session lock chore: update tag fixes for dnd sctk: Fix handling of DnD with subsurfaces (#122) Map subsurface to parent and add offset. refactor: remove Sync bound for Message fix: pass correct state and layout for container widgets fix: docs feat: update advertised drag destinations after rebuilding an interface fix: color format & multi-window fix: doc feat: winit dnd fix: ambiguous import chore: reexport mime from window_clipboard chore: use tag clippy feat: add actions and commands for new clipboard methods cleanup docs feat: custom mime types for Clipboard sctk: Fix handling of layer surface `pointer_interactivity` (#115) A null `region` represents an infinite region (the default). To set an empty region, we need to create a `wl_region`. fix(tiny_skia): disable shadows due to rendering glitch fix(winit): add static lifetimes to multi-window application update fix(winit): add static lifetimes to application update Use `TypeId` to identify `subscription::Map` (cherry picked from commit f39a5fd) fix(sctk): destroy drag icon and send event after cancel action fix: clipboard cleanup fix(sctk): clipboard dummy impl typo refactor(sctk): optional clipboard fix(sctk): broadcast events after update when broadcasting events for no specific surface, it should be done after update so that the runtime subscription is current fix(multi_window): enable drag resize sctk: Map subsurface pointer events to parent surface, with offset sctk_subsurface: Use two surfaces, handle button presses Useful for testing pointer input to subsurfaces. sctk: Add `subsurface_ids` mapping subsurface to parent and offset sctk_subsurface_gst: NV12 surface suppport; disabled Whether or not this works seems to depend on driver, or gstreamer version... Handle frame callbacks for subsurfaces, and `commit` parent surface If the main surface is occluded completely by opaque subsurfaces, it may not receive `frame` events. So we need to request frame events for all subsurfaces as well. Additionally, with "synchronized" subsurfaces, we need to `commit` the parent surface for subsurface changes to take effect. Fixes issues with subsurfaces updating slowly, or only when mouse moved under some circumstances. examples/sctk_subsurface_gst: Cache `BufferSource` in `BufferRef` qdata Similar to `waylandsink`. Allows us to avoid creating a buffer source (and ultimately `wl_buffer`) for every buffer swap. sctk/subsurface: Cache `wl_buffer`s Creating a new `wl_buffer` each frame seems to perform poorly. We can instead keep a cache of `wl_buffer`s we have created from a `BufferSource`. sctk/subsurface: Avoid unnecessary subsurface commits if unchanged feat(slider): add breakpoints fix: autosize surface layout Autosized surfaces perform the layout step to get the size and then again when building the interface, but sometimes the calculated size is not enough space when used as a bound, so we need to add a tiny amount to the calculated size. This also makes the event loop timeout duration configurable. Viewport physical size is calculated directly from the logical size now as well in iced-sctk to avoid inconsistencies that resulted from recalculating the logical size after using it to calculate the physical size. fix(sctk): send close event instead of close requested when a window is closed sctk: add command to set maximize state Add `show_window_menu` action Winit currently supports this only on Windows and Wayland. This requests that a context menu is shown at the cursor position, like the menu normally triggered by right clicking the title bar. This is important for implementing client side decorations with Iced widgets. Remove unnecessary redraw request This was particularly visible on Redox where there is no vsync, but also causes unnecessary redraws on Linux chore: update accesskit Disable broken rustdoc links sctk: Add `Subsurface` widget (#79) This adds a widget that attaches an shm or dma buffer to a subsurface, scaled with `wp_viewporter`. By exposing this as a widget, rather than as a type of window, it can be positioned and scaled like any other iced widget. It provides an API that's similar to an iced image. The initial version of this just took a `wl_buffer`. But this makes buffer re-use problematic. In particular, the docs for `wl_surface::attach` note that `wl_buffer::release` events become unreliable if a buffer is attached to multiple surfaces. And indicates that a client should create multiple `wl_buffer` instances, or use `wp_linux_buffer_release`. So we store information about the buffer, and create `wl_buffer`s as needed. `SubsurfaceBuffer::new` also returns a future that's signaled when all references are destroyed, both `wl_buffer`s and any instance of the `SubsurfaceBuffer` that might still be used in the `view`. So this seems like the best solution for now, within the model-view-update architecture. This has two examples: `sctk_subsurface`, showing a single-color shm buffer, and `sctk_subsurface_gst`, which plays an h264 video to a subsurface with vaapi decoding. chore: use pop-os fork of winit chore: unpin cosmic-text Update wgpu to a commit that fixes use on Nvidia drivers This can be tested with something like `VK_ICD_FILENAMES=/usr/share/vulkan/icd.d/nvidia_icd.json cargo run -p tour --features iced/wgpu`. On Nvidia I'm seeing a flood of `Suboptimal present of frame` warnings. So some improvement may still be needed here. But if it doesn't regress behavior on other hardware, that seems like an improvement over freezing. fix(winit): pass text with modifiers in event chore: update cosmic-text and glyphon fix: distinguish between the key character and the utf8 of a key event feat(wgpu): use alpha modes for compositing if available chore: use updated softbuffer fix: typo fix: downgrade resvg fix: core/serde chore: remove default features typo: add rev to glyphon Update to cosmic-text refactor Fix docs error Add function to fill a Raw Fixes for last commit fix: broadcast surface events dnd_listener: Fix behavior when there are multiple listeners (#87) A `dnd_listener` widget shouldn't handle a DnD event when the dnd drag isn't within the widget's bounds. So add a few more checks for this. Enter/leave events generated by `DndOfferEvent::Motion` also don't behave as one might expect, since the enter may occur before the leave depending on the order it calls `on_event` on the widget. Not sure how to address that, but cosmic-workspaces can just ignore the leave events for now. Otherwise, this seems to be working fine, after these changes. chore: fix sctk multi-window dependency cleanup: formatting and clippy fix(example): sctk_drag id fix: translate the wayland event position for content inside a scrollable fix: set web-sys to =0.3.64 fix: clip mask checks chore: use advanced text shaping for pick list fix: dnd widget layout fix: ambiguous palette import chore: remove artifacts job fix: CI tests fix: add back the window id to the frames subscription fix: tooltip children and diff refactor: udpate gradient angles for slider reexport limits fix: editor and sctk_todos examples cleanup: clippy cleanup git workflows chore: cleanup iced_widget refactor Update mod.rs chore: update softbuffer Hack to remove image blur iced_core: feature for serde serialization of KeyCode fix(wgpu): handle border_radius property with image raster feat: add border radius to image rendering feat: Add side mouse button events cleanup: clippy fixes and formatting Part of this is a refactor of the ID cleanup: clippy and fmt fix: test workflow fix: add note in CHANGELOG fix: clippy refactor: restore default style of slider feat: allow setting the width and height of a rule fix: slider gradient angle feat: gradient backgground for the slider rail feat(mouse-area): added on_drag method fix(widget): container inherited wrong icon color from renderer fix(button): inherit icon color if set to none feat(renderer): define default icon color By default, this is the same as the text color for best visibility. feat(winit): client-side resize drag support feat(winit): client-side resize drag support Make vertical scroll properties optional fix: quad rendering including border only inside of the bounds Move `Screenshot` inside `window` module Added offscreen rendering support for wgpu & tiny-skia exposed with the window::screenshot command. Provide access to font from each crate Use nested for lazy widgets Use layout with children for nesting Introduce internal `overlay::Nested` for `UserInterface` fix: reset button state if the cursor leaves runtime: Handle widget operations in `program::State` helper (#46) chore: default line height, text size, and shaping for cosmic feat: sctk shell fix: quad rendering including border only inside of the bounds fix: better slider drawing (it allows just the border part of the handle quad outside of the layout bouds, which isn't great, but is ok for our purposes due to being transparent) cleanup: fix & format fix: use iced_core::Font cleanup fix: allow leaving out winit & iced-sctk fix: settings fix: slider draw improvements fix: websocket example fix: modal example fix: scrollable example fix: toast example fix: avoid panicking in iced_sctk with lazy widgets in auto-size surfaces fix: todos panic fix: only diff auto-sized surfaces in iced_sctk build_user_interface & improve sctk examples wip (iced-sctk): window resize with icons feat (iced-sctk): support for setting cursor refactor: default decorations to client fix: set window geometry after receiving configure fix: size limits with no max bound must be cut off fix: send size update when autosized surface resizes fix: use ceil size for positioner cleanup: remove dbg statement fix: remove a destroyed surface from compositor surfaces fix errors after rebase and wip scaling support fix: handling of scale factor in set_logical_size fix (sctk_drag example): add .into for border radius fix: fractional scaling sctk: Fire RedrawRequests wip: animations via frame event fix / refactor iced-sctk redraw & frame event handling cleanup: note about frame request in iced-sctk fix: send resize when necessary for layer surface and popups too fix: always request redraw for a new surface fix: scaling and autosize surface improvements refactor: sctk_lazy keyboard interactivity feat(sctk): configurable natural_scroll property feat: send state and capabilities events when there are changes fix: redraw when an update is needed and clean up the logic Update sctk to latest commit Fix compilation of sctk drag example fix(sctk): update interface before checking if it has a redraw request refactor: after autosize surface resize wait to redraw until the resize has been applied refactor: better handling of autosize surfaces chore: update sctk chore: update sctk fixes sctk_drag example fix: default to ControlFlow::Wait for applications with no surface this seems to help CPU usage for app library and launcher default to 250ms timeout in the event loop Update sctk sctk: Implement xdg-activation support fix: don't require Flags to be clone for settings on wayland chore: error if neither winit or wayland feature is set chore: Allow compiling without windowing system (#65) fix(iced-sctk): handle exit_on_close_request fix: make sure that each widget operation operates on every interface This should be ok even for widget actions like focus next because there can only ever be a single focused widget cargo fmt cleanup: dbg statement fix(iced-sctk): replace panic with handling for remaining enum variants refactor: use iced clipboard for interacting with the selection refactor: allow passing an activation token when creating a window sctk: Add support for `ext-session-lock` protocol fix(sctk): build and use tree for layout of autosize surfaces Update winit to latest commit used by upstream iced fix(sctk): send key characters fix(sctk): check if key is a named key first refactor(sctk): keep compositor surface in state feat: accessibility with some widget impls feat: stable ids a11y: Don't unconditionally pull winit (#43) Update conversion.rs integration fixes integration integration integration integration s integration some integration work more integration Update Cargo.toml Update mod.rs Update multi_window.rs s more integration more integration (ryanabx wip #100000) more integration!! integration 2 integration more integration (rbx) s integration integration work integration Update Cargo.toml integration simple integration things int integration to 175 integration(170) Co-Authored-By: Ashley Wulber <[email protected]> Co-Authored-By: Victoria Brekenfeld <[email protected]> Co-Authored-By: Eduardo Flores <[email protected]> Co-Authored-By: Michael Murphy <[email protected]> Co-Authored-By: wiiznokes <[email protected]> Co-Authored-By: Jeremy Soller <[email protected]> Co-Authored-By: Ryan Brue <[email protected]> fix(column): handle keys len change fix: iced-sctk a11y wip: winit single window updates tokio feature hangs even without a11y feature fix: multiwindow a11y fixes fix: component update winit wip: sctk integration to winit shell refactor: remove accesskit_unix fix: svg fix: remove wayland default feature feat: derive Hash for image Handle fix: cleanup 0.13 rebase errors fix: remove path dependencies conversion for Radius conversion for Padding setter for Svg border radius re-export Limits fix: connect clipboard if disconnected on layer surface or popup creation fix: connect clipboard if disconnected on session lock surface creation fix: update size of layer surface after configure fix: insert user interfaces for popup and lock surfaces on creation fix: svg scaling feat: popups on winit windows fix: default text shaping to advanced fix: fallback to renderer icon style if svg is symbolic fixes fix: sctk frame handling feat: autosize handling fix: better autosize handling fix: avoid duplicate window events from sctk fix: better handling of popups fix: refactor redraw handling for sctk fix: include id in frames fix: image fix: scrollable delta direction sctk: unregister clipboard when surface is done set min / max size when size is requested fix: popups filter pointer events feat: add Hide variant to mouse Interaction dnd fixes fix: use physical width for DnD surface fix: tiny-skia svg quality refactor: peek_dnd try to parse data cleanup text conversion cleanup svg scaling fixes background color fix Introduce consecutive_click_distance like other toolkits do such as gtk,qt,imgui.
1 parent f1526b2 commit 7b50c0a

File tree

229 files changed

+18927
-1169
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

229 files changed

+18927
-1169
lines changed

.github/workflows/audit.yml

-12
Original file line numberDiff line numberDiff line change
@@ -16,15 +16,3 @@ jobs:
1616
run: cargo update
1717
- name: Audit vulnerabilities
1818
run: cargo audit
19-
20-
# artifacts:
21-
# runs-on: ubuntu-latest
22-
# steps:
23-
# - uses: hecrj/setup-rust-action@v2
24-
# - name: Install cargo-outdated
25-
# run: cargo install cargo-outdated
26-
# - uses: actions/checkout@master
27-
# - name: Delete `web-sys` dependency from `integration` example
28-
# run: sed -i '$d' examples/integration/Cargo.toml
29-
# - name: Find outdated dependencies
30-
# run: cargo outdated --workspace --exit-code 1 --ignore raw-window-handle

.github/workflows/lint.yml

+5-2
Original file line numberDiff line numberDiff line change
@@ -7,11 +7,14 @@ jobs:
77
- uses: hecrj/setup-rust-action@v2
88
with:
99
components: clippy
10+
1011
- uses: actions/checkout@master
1112
- name: Install dependencies
1213
run: |
1314
export DEBIAN_FRONTED=noninteractive
1415
sudo apt-get -qq update
15-
sudo apt-get install -y libxkbcommon-dev libgtk-3-dev
16+
sudo apt-get install -y libxkbcommon-dev libgtk-3-dev libwayland-dev
1617
- name: Check lints
17-
run: cargo lint
18+
run: |
19+
cargo clippy --no-default-features --features "winit" --all-targets
20+
cargo clippy --no-default-features --features "wayland wgpu svg canvas qr_code lazy debug tokio palette web-colors a11y"

.github/workflows/test.yml

+33-3
Original file line numberDiff line numberDiff line change
@@ -19,8 +19,38 @@ jobs:
1919
run: |
2020
export DEBIAN_FRONTED=noninteractive
2121
sudo apt-get -qq update
22-
sudo apt-get install -y libxkbcommon-dev libgtk-3-dev
22+
sudo apt-get install -y libxkbcommon-dev libwayland-dev
2323
- name: Run tests
2424
run: |
25-
cargo test --verbose --workspace
26-
cargo test --verbose --workspace --all-features
25+
cargo test --verbose --features "winit wgpu svg canvas qr_code lazy debug tokio palette web-colors a11y"
26+
cargo test -p iced_accessibility
27+
cargo test -p iced_core
28+
cargo test -p iced_futures
29+
cargo test -p iced_graphics
30+
cargo test -p iced_renderer
31+
cargo test -p iced_runtime
32+
cargo test -p iced_tiny_skia
33+
cargo test -p iced_widget
34+
cargo test -p iced_wgpu
35+
- name: test wayland
36+
if: matrix.os == 'ubuntu-latest'
37+
run: |
38+
cargo test --verbose --features "wayland wgpu svg canvas qr_code lazy debug tokio palette web-colors a11y"
39+
cargo test -p iced_sctk
40+
41+
web:
42+
runs-on: ubuntu-latest
43+
steps:
44+
- uses: hecrj/setup-rust-action@v1
45+
with:
46+
rust-version: stable
47+
targets: wasm32-unknown-unknown
48+
- uses: actions/checkout@master
49+
- name: Run checks
50+
run: cargo check --package iced --target wasm32-unknown-unknown --no-default-features --features "winit"
51+
- name: Check compilation of `tour` example
52+
run: cargo build --package tour --target wasm32-unknown-unknown
53+
- name: Check compilation of `todos` example
54+
run: cargo build --package todos --target wasm32-unknown-unknown
55+
- name: Check compilation of `integration` example
56+
run: cargo build --package integration --target wasm32-unknown-unknown

CHANGELOG.md

+6
Original file line numberDiff line numberDiff line change
@@ -227,6 +227,8 @@ Many thanks to...
227227
- @wiiznokes
228228
- @woelfman
229229
- @Zaubentrucker
230+
- @ryanabx
231+
- @edfloreshz
230232

231233
## [0.12.1] - 2024-02-22
232234
### Added
@@ -413,6 +415,10 @@ Many thanks to...
413415
- @william-shere
414416
- @wyatt-herkamp
415417

418+
Many thanks to...
419+
- @jackpot51
420+
- @wash2
421+
416422
## [0.10.0] - 2023-07-28
417423
### Added
418424
- Text shaping, font fallback, and `iced_wgpu` overhaul. [#1697](https://github.com/iced-rs/iced/pull/1697)

Cargo.toml

+70-21
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ all-features = true
2222
maintenance = { status = "actively-developed" }
2323

2424
[features]
25-
default = ["wgpu", "tiny-skia", "fira-sans", "auto-detect-theme"]
25+
default = ["tiny-skia"]
2626
# Enable the `wgpu` GPU-accelerated renderer backend
2727
wgpu = ["iced_renderer/wgpu", "iced_widget/wgpu"]
2828
# Enable the `tiny-skia` software renderer backend
@@ -42,11 +42,11 @@ markdown = ["iced_widget/markdown"]
4242
# Enables lazy widgets
4343
lazy = ["iced_widget/lazy"]
4444
# Enables a debug view in native platforms (press F12)
45-
debug = ["iced_winit/debug"]
45+
debug = ["iced_winit?/debug"]
4646
# Enables `tokio` as the `executor::Default` on native platforms
47-
tokio = ["iced_futures/tokio"]
47+
tokio = ["iced_futures/tokio", "iced_accessibility?/tokio"]
4848
# Enables `async-std` as the `executor::Default` on native platforms
49-
async-std = ["iced_futures/async-std"]
49+
async-std = ["iced_futures/async-std", "iced_accessibility?/async-io"]
5050
# Enables `smol` as the `executor::Default` on native platforms
5151
smol = ["iced_futures/smol"]
5252
# Enables querying system information
@@ -58,28 +58,45 @@ webgl = ["iced_renderer/webgl"]
5858
# Enables the syntax `highlighter` module
5959
highlighter = ["iced_highlighter", "iced_widget/highlighter"]
6060
# Enables experimental multi-window support.
61-
multi-window = ["iced_winit/multi-window"]
61+
multi-window = ["iced_winit?/multi-window"]
6262
# Enables the advanced module
6363
advanced = ["iced_core/advanced", "iced_widget/advanced"]
6464
# Enables embedding Fira Sans as the default font on Wasm builds
6565
fira-sans = ["iced_renderer/fira-sans"]
66+
67+
6668
# Enables auto-detecting light/dark mode for the built-in theme
6769
auto-detect-theme = ["iced_core/auto-detect-theme"]
68-
# Enables strict assertions for debugging purposes at the expense of performance
6970
strict-assertions = ["iced_renderer/strict-assertions"]
71+
# Enables the `accesskit` accessibility library
72+
a11y = [
73+
"iced_accessibility",
74+
"iced_core/a11y",
75+
"iced_widget/a11y",
76+
"iced_winit?/a11y",
77+
]
78+
# Enables the winit shell. Conflicts with `wayland` and `glutin`.
79+
winit = ["iced_winit", "iced_accessibility?/accesskit_winit"]
7080

81+
82+
# Enables the sctk shell.
83+
wayland = ["iced_widget/wayland", "iced_core/wayland", "iced_winit/wayland"]
7184
[dependencies]
7285
iced_core.workspace = true
7386
iced_futures.workspace = true
7487
iced_renderer.workspace = true
7588
iced_widget.workspace = true
7689
iced_winit.features = ["program"]
7790
iced_winit.workspace = true
78-
91+
iced_winit.optional = true
7992
iced_highlighter.workspace = true
8093
iced_highlighter.optional = true
81-
94+
iced_accessibility.workspace = true
95+
iced_accessibility.optional = true
8296
thiserror.workspace = true
97+
window_clipboard.workspace = true
98+
mime.workspace = true
99+
dnd.workspace = true
83100

84101
image.workspace = true
85102
image.optional = true
@@ -116,7 +133,9 @@ members = [
116133
"widget",
117134
"winit",
118135
"examples/*",
136+
"accessibility",
119137
]
138+
exclude = ["examples/integration"]
120139

121140
[workspace.package]
122141
version = "0.14.0-dev"
@@ -141,16 +160,27 @@ iced_tiny_skia = { version = "0.14.0-dev", path = "tiny_skia" }
141160
iced_wgpu = { version = "0.14.0-dev", path = "wgpu" }
142161
iced_widget = { version = "0.14.0-dev", path = "widget" }
143162
iced_winit = { version = "0.14.0-dev", path = "winit" }
163+
iced_accessibility = { version = "0.1", path = "accessibility" }
144164

145165
async-std = "1.0"
146-
bitflags = "2.0"
166+
# bitflags = "2.0"
167+
bitflags = "2.5"
147168
bytemuck = { version = "1.0", features = ["derive"] }
148169
bytes = "1.6"
149-
cosmic-text = "0.12"
170+
171+
cosmic-text = { git = "https://github.com/pop-os/cosmic-text.git" }
172+
# cosmic-text = "0.10"
173+
174+
150175
dark-light = "1.0"
151176
futures = "0.3"
152177
glam = "0.25"
153-
glyphon = { git = "https://github.com/hecrj/glyphon.git", rev = "0d7ba1bba4dd71eb88d2cface5ce649db2413cb7" }
178+
glyphon = { package = "iced_glyphon", git = "https://github.com/pop-os/glyphon.git", tag = "iced-0.14-dev" }
179+
# glyphon = { package = "iced_glyphon", path = "../../../glyphon" }
180+
resvg = "0.42"
181+
182+
183+
web-sys = "0.3.69"
154184
guillotiere = "0.6"
155185
half = "2.2"
156186
image = { version = "0.24", default-features = false }
@@ -166,12 +196,12 @@ palette = "0.7"
166196
pulldown-cmark = "0.11"
167197
qrcode = { version = "0.13", default-features = false }
168198
raw-window-handle = "0.6"
169-
resvg = "0.42"
170199
rustc-hash = "2.0"
200+
sctk = { package = "smithay-client-toolkit", version = "0.19.1" }
171201
smol = "1.0"
172202
smol_str = "0.2"
173-
softbuffer = "0.4"
174-
syntect = "5.1"
203+
softbuffer = { git = "https://github.com/pop-os/softbuffer", tag = "cosmic-4.0" }
204+
syntect = "5.2"
175205
sysinfo = "0.30"
176206
thiserror = "1.0"
177207
tiny-skia = "0.11"
@@ -181,18 +211,33 @@ unicode-segmentation = "1.0"
181211
url = "2.5"
182212
wasm-bindgen-futures = "0.4"
183213
wasm-timer = "0.2"
184-
web-sys = "0.3.69"
185214
web-time = "1.1"
186215
wgpu = "22.0"
216+
wayland-protocols = { version = "0.32.1", features = ["staging"] }
217+
# web-time = "1.1"
218+
219+
220+
# wgpu = "0.19"
221+
# Newer wgpu commit that fixes Vulkan backend on Nvidia
187222
winapi = "0.3"
188-
window_clipboard = "0.4.1"
189-
winit = "0.30"
223+
# window_clipboard = "0.4.1"
224+
225+
window_clipboard = { git = "https://github.com/pop-os/window_clipboard.git", tag = "pop-0.13" }
226+
dnd = { git = "https://github.com/pop-os/window_clipboard.git", tag = "pop-0.13" }
227+
mime = { git = "https://github.com/pop-os/window_clipboard.git", tag = "pop-0.13" }
228+
winit = { git = "https://github.com/pop-os/winit.git", tag = "iced-xdg-surface-0.13" }
229+
# winit = { path = "../../winit" }
230+
# winit = { git = "https://github.com/iced-rs/winit.git", rev = "254d6b3420ce4e674f516f7a2bd440665e05484d" }
231+
# winit = { git = "https://github.com/rust-windowing/winit.git", rev = "241b7a80bba96c91fa3901729cd5dec66abb9be4" }
232+
# winit = { path = "../../../winit" }
233+
190234

191235
[workspace.lints.rust]
192-
rust_2018_idioms = { level = "forbid", priority = -1 }
193-
missing_debug_implementations = "deny"
194-
missing_docs = "deny"
195-
unsafe_code = "deny"
236+
# rust_2018_idioms = { level = "forbid", priority = -1 }
237+
# missing_debug_implementations = "deny"
238+
# missing_docs = "deny"
239+
# unsafe_code = "deny"
240+
# TODO(POP): We have some unsafe code that needs to be fixed
196241
unused_results = "deny"
197242

198243
[workspace.lints.clippy]
@@ -212,3 +257,7 @@ useless_conversion = "deny"
212257

213258
[workspace.lints.rustdoc]
214259
broken_intra_doc_links = "forbid"
260+
261+
# [patch."https://github.com/rust-windowing/winit.git"]
262+
# winit = { git = "https://github.com/rust-windowing/winit.git", rev = "241b7a80bba96c91fa3901729cd5dec66abb9be4" }
263+
# winit = { path = "../../../winit" }

accessibility/Cargo.toml

+24
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
[package]
2+
name = "iced_accessibility"
3+
version = "0.1.0"
4+
edition = "2021"
5+
6+
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
7+
# TODO Ashley re-export more platform adapters
8+
[features]
9+
async-io = ["accesskit_winit?/async-io"]
10+
tokio = ["accesskit_winit?/tokio"]
11+
12+
[dependencies]
13+
accesskit = { git = "https://github.com/wash2/accesskit", tag = "iced-xdg-surface-0.13" }
14+
accesskit_windows = { git = "https://github.com/wash2/accesskit", tag = "iced-xdg-surface-0.13", optional = true }
15+
accesskit_macos = { git = "https://github.com/wash2/accesskit", tag = "iced-xdg-surface-0.13", optional = true }
16+
accesskit_winit = { git = "https://github.com/wash2/accesskit", tag = "iced-xdg-surface-0.13", optional = true, default-features = false, features = [
17+
"rwh_06",
18+
] }
19+
# accesskit = { path = "../../../../accesskit/common" }
20+
# accesskit_windows = { path = "../../../../accesskit/platforms/windows", optional = true }
21+
# accesskit_macos = { path = "../../../../accesskit/platforms/macos", optional = true }
22+
# accesskit_winit = { path = "../../../../accesskit/platforms/winit", optional = true, default-features = false, features = [
23+
# "rwh_06",
24+
# ] }

accessibility/src/a11y_tree.rs

+80
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,80 @@
1+
use crate::{A11yId, A11yNode, IdEq};
2+
3+
#[derive(Debug, Clone, Default)]
4+
/// Accessible tree of nodes
5+
pub struct A11yTree {
6+
/// The root of the current widget, children of the parent widget or the Window if there is no parent widget
7+
root: Vec<A11yNode>,
8+
/// The children of a widget and its children
9+
children: Vec<A11yNode>,
10+
}
11+
12+
impl A11yTree {
13+
/// Create a new A11yTree
14+
/// XXX if you use this method, you will need to manually add the children of the root nodes
15+
pub fn new(root: Vec<A11yNode>, children: Vec<A11yNode>) -> Self {
16+
Self { root, children }
17+
}
18+
19+
pub fn leaf<T: Into<A11yId>>(node: accesskit::NodeBuilder, id: T) -> Self {
20+
Self {
21+
root: vec![A11yNode::new(node, id)],
22+
children: vec![],
23+
}
24+
}
25+
26+
/// Helper for creating an A11y tree with a single root node and some children
27+
pub fn node_with_child_tree(mut root: A11yNode, child_tree: Self) -> Self {
28+
root.add_children(
29+
child_tree.root.iter().map(|n| n.id()).cloned().collect(),
30+
);
31+
Self {
32+
root: vec![root],
33+
children: child_tree
34+
.children
35+
.into_iter()
36+
.chain(child_tree.root)
37+
.collect(),
38+
}
39+
}
40+
41+
/// Joins multiple trees into a single tree
42+
pub fn join<T: Iterator<Item = Self>>(trees: T) -> Self {
43+
trees.fold(Self::default(), |mut acc, A11yTree { root, children }| {
44+
acc.root.extend(root);
45+
acc.children.extend(children);
46+
acc
47+
})
48+
}
49+
50+
pub fn root(&self) -> &Vec<A11yNode> {
51+
&self.root
52+
}
53+
54+
pub fn children(&self) -> &Vec<A11yNode> {
55+
&self.children
56+
}
57+
58+
pub fn root_mut(&mut self) -> &mut Vec<A11yNode> {
59+
&mut self.root
60+
}
61+
62+
pub fn children_mut(&mut self) -> &mut Vec<A11yNode> {
63+
&mut self.children
64+
}
65+
66+
pub fn contains(&self, id: &A11yId) -> bool {
67+
self.root.iter().any(|n| IdEq::eq(n.id(), id))
68+
|| self.children.iter().any(|n| IdEq::eq(n.id(), id))
69+
}
70+
}
71+
72+
impl From<A11yTree> for Vec<(accesskit::NodeId, accesskit::Node)> {
73+
fn from(tree: A11yTree) -> Vec<(accesskit::NodeId, accesskit::Node)> {
74+
tree.root
75+
.into_iter()
76+
.map(|node| node.into())
77+
.chain(tree.children.into_iter().map(|node| node.into()))
78+
.collect()
79+
}
80+
}

0 commit comments

Comments
 (0)