Update to latest iced (2/2) #40
Annotations
10 errors and 39 warnings
casting `usize` to `u16` may truncate the value:
src/widget/dots.rs#L241
error: casting `usize` to `u16` may truncate the value
--> src/widget/dots.rs:241:38
|
241 | ... shell.publish((self.on_click)(i as u16));
| ^^^^^^^^
|
= help: if this is intentional allow the lint with `#[allow(clippy::cast_possible_truncation)]` ...
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_possible_truncation
= note: `#[deny(clippy::cast_possible_truncation)]` implied by `#[deny(clippy::pedantic)]`
help: ... or use `try_from` and handle the error accordingly
|
241 | shell.publish((self.on_click)(u16::try_from(i)));
| ~~~~~~~~~~~~~~~~
|
redundant redefinition of a binding `wolf_gifts`:
src/view/splat_extras.rs#L258
error: redundant redefinition of a binding `wolf_gifts`
--> src/view/splat_extras.rs:258:6
|
258 | let wolf_gifts = wolf_gifts;
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
help: `wolf_gifts` is initially defined here
--> src/view/splat_extras.rs:227:8
|
227 | let wolf_gifts: Vec<Translated<WolfGift>> = WolfGift::all()
| ^^^^^^^^^^
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_locals
|
redundant redefinition of a binding `shadow_gifts`:
src/view/splat_extras.rs#L239
error: redundant redefinition of a binding `shadow_gifts`
--> src/view/splat_extras.rs:239:6
|
239 | let shadow_gifts = shadow_gifts;
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
help: `shadow_gifts` is initially defined here
--> src/view/splat_extras.rs:222:8
|
222 | let shadow_gifts: Vec<Translated<ShadowGift>> = ShadowGift::all()
| ^^^^^^^^^^^^
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_locals
|
casting `u16` to `i16` may wrap around the value:
src/view/overview.rs#L276
error: casting `u16` to `i16` may wrap around the value
--> src/view/overview.rs:276:29
|
276 | character.base_size = (val as i16 - character.get_modifier(Trait::Size)) as u16;
| ^^^^^^^^^^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_possible_wrap
= note: `#[deny(clippy::cast_possible_wrap)]` implied by `#[deny(clippy::pedantic)]`
|
casting `i16` to `u16` may lose the sign of the value:
src/view/overview.rs#L276
error: casting `i16` to `u16` may lose the sign of the value
--> src/view/overview.rs:276:28
|
276 | character.base_size = (val as i16 - character.get_modifier(Trait::Size)) as u16;
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_sign_loss
= note: `#[deny(clippy::cast_sign_loss)]` implied by `#[deny(clippy::pedantic)]`
|
unnecessary boolean `not` operation:
src/component/skills.rs#L122
error: unnecessary boolean `not` operation
--> src/component/skills.rs:122:6
|
122 | / if !specialties.is_empty() {
123 | | theme::Text::Color(Color::from_rgb(0.0, 0.7, 0.0))
124 | | } else {
125 | | theme::Text::Default
126 | | },
| |_____________________^
|
= help: remove the `!` and swap the blocks of the `if`/`else`
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#if_not_else
= note: `#[deny(clippy::if_not_else)]` implied by `#[deny(clippy::pedantic)]`
|
redundant redefinition of a binding `skill`:
src/component/skills.rs#L104
error: redundant redefinition of a binding `skill`
--> src/component/skills.rs:104:8
|
104 | ... let skill = skill;
| ^^^^^^^^^^^^^^^^^^
|
help: `skill` is initially defined here
--> src/component/skills.rs:93:7
|
93 | for skill in Skill::get(cat) {
| ^^^^^
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_locals
= note: `#[deny(clippy::redundant_locals)]` on by default
|
binding's name is too similar to existing binding:
src/view/splat_extras.rs#L301
error: binding's name is too similar to existing binding
--> src/view/splat_extras.rs:301:7
|
301 | let rites = if let Splat::Werewolf(.., data) = &character.splat {
| ^^^^^
|
note: existing binding defined here
--> src/view/splat_extras.rs:149:7
|
149 | let rotes: Element<Self::Event, Theme> = if let Splat::Mage(.., data) = &character.splat {
| ^^^^^
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#similar_names
note: the lint level is defined here
--> src/main.rs:2:9
|
2 | #![deny(clippy::pedantic)]
| ^^^^^^^^^^^^^^^^
= note: `#[deny(clippy::similar_names)]` implied by `#[deny(clippy::pedantic)]`
|
check
Clippy had exited with the 101 exit code
|
test
The process '/home/runner/.cargo/bin/cargo' failed with exit code 101
|
struct update has no effect, all the fields in the struct have already been specified:
src/main.rs#L619
warning: struct update has no effect, all the fields in the struct have already been specified
--> src/main.rs:619:7
|
619 | ..Default::default()
| ^^^^^^^^^^^^^^^^^^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_update
= note: `#[warn(clippy::needless_update)]` on by default
|
using `map` over `inspect`:
src/main.rs#L118
warning: using `map` over `inspect`
--> src/main.rs:118:5
|
118 | .map(|val| {
| ^^^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_inspect
= note: `#[warn(clippy::manual_inspect)]` on by default
help: try
|
118 ~ .inspect(|val| {
119 ~ val.calc_mod_map();
|
|
redundant pattern matching, consider using `is_some()`:
src/widget/track.rs#L151
warning: redundant pattern matching, consider using `is_some()`
--> src/widget/track.rs:151:13
|
151 | if let Some(_) = cursor.position_over(layout.bounds()) {
| -------^^^^^^^---------------------------------------- help: try: `if cursor.position_over(layout.bounds()).is_some()`
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching
|
redundant pattern matching, consider using `is_some()`:
src/widget/dots.rs#L233
warning: redundant pattern matching, consider using `is_some()`
--> src/widget/dots.rs:233:13
|
233 | if let Some(_) = cursor.position_over(layout.bounds()) {
| -------^^^^^^^---------------------------------------- help: try: `if cursor.position_over(layout.bounds()).is_some()`
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching
|
redundant pattern matching, consider using `is_some()`:
src/widget/dots.rs#L165
warning: redundant pattern matching, consider using `is_some()`
--> src/widget/dots.rs:165:11
|
165 | if let Some(_) = cursor.position_over(bounds) {
| -------^^^^^^^------------------------------- help: try: `if cursor.position_over(bounds).is_some()`
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching
= note: `#[warn(clippy::redundant_pattern_matching)]` on by default
|
very complex type used. Consider factoring parts into `type` definitions:
src/view/overview.rs#L506
warning: very complex type used. Consider factoring parts into `type` definitions
--> src/view/overview.rs:506:37
|
506 | let (passive, common, specific): (
| ______________________________________________^
507 | | Element<Self::Event, Theme>,
508 | | Element<Self::Event, Theme>,
509 | | Element<Self::Event, Theme>,
510 | | ) = if let KuruthTriggers::_Custom(KuruthTriggerSet {
| |_____________^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
= note: `#[warn(clippy::type_complexity)]` on by default
|
large size difference between variants:
src/view/creator.rs#L23
warning: large size difference between variants
--> src/view/creator.rs:23:1
|
23 | / pub enum Event {
24 | | SplatChanged(Splat), // TODO: Switch to using a unit-varianted "SplatKind" enum here
| | ------------------- the largest variant contains at least 208 bytes
25 | | Done,
| | ---- the second-largest variant carries no data at all
26 | | }
| |_^ the entire enum is at least 208 bytes
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#large_enum_variant
= note: `#[warn(clippy::large_enum_variant)]` on by default
help: consider boxing the large fields to reduce the total size of the enum
|
24 | SplatChanged(Box<Splat>), // TODO: Switch to using a unit-varianted "SplatKind" enum here
| ~~~~~~~~~~
|
usage of an `Arc` that is not `Send` and `Sync`:
src/i18n.rs#L86
warning: usage of an `Arc` that is not `Send` and `Sync`
--> src/i18n.rs:86:42
|
86 | let localizer_arc: Arc<dyn Localizer> = Arc::new(localizer);
| ^^^^^^^^^^^^^^^^^^^
|
= note: `Arc<DefaultLocalizer<'_>>` is not `Send` and `Sync` as `DefaultLocalizer<'_>` is neither `Send` nor `Sync`
= help: if the `Arc` will not used be across threads replace it with an `Rc`
= help: otherwise make `DefaultLocalizer<'_>` `Send` and `Sync` or consider a wrapper type such as `Mutex`
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#arc_with_non_send_sync
= note: `#[warn(clippy::arc_with_non_send_sync)]` on by default
|
all variants have the same postfix: `Changed`:
src/component/skills.rs#L41
warning: all variants have the same postfix: `Changed`
--> src/component/skills.rs:41:1
|
41 | / pub enum Event {
42 | | SkillChanged(u16, Skill),
43 | | RoteSkillChanged(Skill),
44 | | SpecialtyChanged(Skill, usize, String),
45 | | SpecialtySkillChanged(Skill),
46 | | }
| |_^
|
= help: remove the postfixes and use full paths to the variants instead of glob imports
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#enum_variant_names
= note: `#[warn(clippy::enum_variant_names)]` on by default
|
you seem to be trying to use `match` for destructuring a single pattern. Consider using `if let`:
src/component/integrity.rs#L56
warning: you seem to be trying to use `match` for destructuring a single pattern. Consider using `if let`
--> src/component/integrity.rs:56:37
|
56 | Event::IntegrityDamage(wound) => match &mut character.splat {
| ______________________________________________^
57 | | Splat::Changeling(.., data) => {
58 | | data.clarity.poke(&wound);
59 | | if let Wound::Lethal = wound {
... |
63 | | _ => {}
64 | | },
| |_____________^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match
= note: `#[warn(clippy::single_match)]` on by default
help: try
|
56 ~ Event::IntegrityDamage(wound) => if let Splat::Changeling(.., data) = &mut character.splat {
57 ~ data.clarity.poke(&wound);
58 ~ if let Wound::Lethal = wound {
59 ~ data.clarity.poke(&Wound::Aggravated);
60 ~ }
61 ~ },
|
|
method `abilities` is never used:
src/view/equipment.rs#L35
warning: method `abilities` is never used
--> src/view/equipment.rs:35:5
|
27 | impl<Message> EquipmentTab<Message> {
| ----------------------------------- method in this implementation
...
35 | fn abilities(&self, _character: &Character) -> Element<Event> {
| ^^^^^^^^^
|
variant `Msg` is never constructed:
src/main.rs#L83
warning: variant `Msg` is never constructed
--> src/main.rs:83:2
|
77 | enum Message {
| ------- variant in this enum
...
83 | Msg,
| ^^^
|
= note: `Message` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
= note: `#[warn(dead_code)]` on by default
|
unused variable: `cursor`:
src/widget/track.rs#L107
warning: unused variable: `cursor`
--> src/widget/track.rs:107:3
|
107 | cursor: mouse::Cursor,
| ^^^^^^ help: if this is intentional, prefix it with an underscore: `_cursor`
|
= note: `#[warn(unused_variables)]` on by default
|
unused import: `iced::border::Radius`:
src/widget/track.rs#L11
warning: unused import: `iced::border::Radius`
--> src/widget/track.rs:11:5
|
11 | use iced::border::Radius;
| ^^^^^^^^^^^^^^^^^^^^
|
unused import: `SplatExtrasTab`:
src/view/mod.rs#L11
warning: unused import: `SplatExtrasTab`
--> src/view/mod.rs:11:42
|
11 | pub use splat_extras::{splat_extras_tab, SplatExtrasTab};
| ^^^^^^^^^^^^^^
|
unused import: `OverviewTab`:
src/view/mod.rs#L10
warning: unused import: `OverviewTab`
--> src/view/mod.rs:10:34
|
10 | pub use overview::{overview_tab, OverviewTab};
| ^^^^^^^^^^^
|
unused import: `EquipmentTab`:
src/view/mod.rs#L9
warning: unused import: `EquipmentTab`
--> src/view/mod.rs:9:36
|
9 | pub use equipment::{equipment_tab, EquipmentTab};
| ^^^^^^^^^^^^
|
unused import: `CreatorView`:
src/view/mod.rs#L8
warning: unused import: `CreatorView`
--> src/view/mod.rs:8:33
|
8 | pub use creator::{creator_view, CreatorView};
| ^^^^^^^^^^^
|
unused import: `CharacterList`:
src/view/mod.rs#L7
warning: unused import: `CharacterList`
--> src/view/mod.rs:7:42
|
7 | pub use character_list::{character_list, CharacterList};
| ^^^^^^^^^^^^^
|
unused import: `TraitsComponent`:
src/component/mod.rs#L17
warning: unused import: `TraitsComponent`
--> src/component/mod.rs:17:36
|
17 | pub use traits::{traits_component, TraitsComponent};
| ^^^^^^^^^^^^^^^
|
unused import: `SkillsComponent`:
src/component/mod.rs#L16
warning: unused import: `SkillsComponent`
--> src/component/mod.rs:16:36
|
16 | pub use skills::{skills_component, SkillsComponent};
| ^^^^^^^^^^^^^^^
|
unused import: `MeritComponent`:
src/component/mod.rs#L15
warning: unused import: `MeritComponent`
--> src/component/mod.rs:15:35
|
15 | pub use merits::{merit_component, MeritComponent};
| ^^^^^^^^^^^^^^
|
unused import: `List`:
src/component/mod.rs#L14
warning: unused import: `List`
--> src/component/mod.rs:14:22
|
14 | pub use list::{list, List};
| ^^^^
|
unused import: `IntegrityComponent`:
src/component/mod.rs#L13
warning: unused import: `IntegrityComponent`
--> src/component/mod.rs:13:42
|
13 | pub use integrity::{integrity_component, IntegrityComponent};
| ^^^^^^^^^^^^^^^^^^
|
unused import: `InfoBar`:
src/component/mod.rs#L12
warning: unused import: `InfoBar`
--> src/component/mod.rs:12:26
|
12 | pub use info::{info_bar, InfoBar};
| ^^^^^^^
|
unused import: `FormsComponent`:
src/component/mod.rs#L11
warning: unused import: `FormsComponent`
--> src/component/mod.rs:11:34
|
11 | pub use forms::{forms_component, FormsComponent};
| ^^^^^^^^^^^^^^
|
unused import: `AttributeBar`:
src/component/mod.rs#L10
warning: unused import: `AttributeBar`
--> src/component/mod.rs:10:37
|
10 | pub use attributes::{attribute_bar, AttributeBar};
| ^^^^^^^^^^^^
|
= note: `#[warn(unused_imports)]` on by default
|
check
The following actions uses node12 which is deprecated and will be forced to run on node16: actions-rs/toolchain@v1, actions-rs/cargo@v1, actions-rs/clippy-check@v1. For more info: https://github.blog/changelog/2023-06-13-github-actions-all-actions-will-run-on-node16-instead-of-node12-by-default/
|
check
The following actions uses Node.js version which is deprecated and will be forced to run on node20: actions-rs/toolchain@v1, actions-rs/cargo@v1, actions-rs/clippy-check@v1. For more info: https://github.blog/changelog/2024-03-07-github-actions-all-actions-will-run-on-node20-instead-of-node16-by-default/
|
check
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
check
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
check
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
check
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
test
The following actions uses node12 which is deprecated and will be forced to run on node16: actions-rs/toolchain@v1, actions-rs/cargo@v1. For more info: https://github.blog/changelog/2023-06-13-github-actions-all-actions-will-run-on-node16-instead-of-node12-by-default/
|
test
The following actions uses Node.js version which is deprecated and will be forced to run on node20: actions/checkout@v3, actions-rs/toolchain@v1, actions-rs/cargo@v1. For more info: https://github.blog/changelog/2024-03-07-github-actions-all-actions-will-run-on-node20-instead-of-node16-by-default/
|
test
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
test
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
test
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
test
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|