[INFO] crate nl80211-rs 0.1.0 is already in cache [INFO] extracting crate nl80211-rs 0.1.0 into work/ex/clippy-test-run/sources/stable/reg/nl80211-rs/0.1.0 [INFO] extracting crate nl80211-rs 0.1.0 into work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/reg/nl80211-rs/0.1.0 [INFO] validating manifest of nl80211-rs-0.1.0 on toolchain stable [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of nl80211-rs-0.1.0 on toolchain stable+rustflags=-Dclippy::into_iter_on_array [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing nl80211-rs-0.1.0 [INFO] finished frobbing nl80211-rs-0.1.0 [INFO] frobbed toml for nl80211-rs-0.1.0 written to work/ex/clippy-test-run/sources/stable/reg/nl80211-rs/0.1.0/Cargo.toml [INFO] started frobbing nl80211-rs-0.1.0 [INFO] finished frobbing nl80211-rs-0.1.0 [INFO] frobbed toml for nl80211-rs-0.1.0 written to work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/reg/nl80211-rs/0.1.0/Cargo.toml [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] linting nl80211-rs-0.1.0 against stable for clippy-test-run [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/clippy-test-run/worker-2/stable:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/clippy-test-run/sources/stable/reg/nl80211-rs/0.1.0:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+stable" "clippy" "--frozen" "--all" "--all-targets"` [INFO] [stdout] a31979a629f3603d00a96b888be041162604091bd49b66025c63343d2fa33c62 [INFO] running `"docker" "start" "-a" "a31979a629f3603d00a96b888be041162604091bd49b66025c63343d2fa33c62"` [INFO] [stderr] Checking netlink-rust v0.1.0 [INFO] [stderr] Compiling nl80211-buildtools v0.1.0 [INFO] [stderr] Compiling nl80211-rs v0.1.0 (/opt/crater/workdir) [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:20:36 [INFO] [stderr] | [INFO] [stderr] 20 | Ok(RawInformationElement { identifier: identifier, data: data }) [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `identifier` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::redundant_field_names)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:20:60 [INFO] [stderr] | [INFO] [stderr] 20 | Ok(RawInformationElement { identifier: identifier, data: data }) [INFO] [stderr] | ^^^^^^^^^^ help: replace it with: `data` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:39:13 [INFO] [stderr] | [INFO] [stderr] 39 | elements: elements, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: replace it with: `elements` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:260:17 [INFO] [stderr] | [INFO] [stderr] 260 | version: version, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: replace it with: `version` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:262:17 [INFO] [stderr] | [INFO] [stderr] 262 | ciphers: ciphers, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: replace it with: `ciphers` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:263:17 [INFO] [stderr] | [INFO] [stderr] 263 | akms: akms, [INFO] [stderr] | ^^^^^^^^^^ help: replace it with: `akms` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:265:17 [INFO] [stderr] | [INFO] [stderr] 265 | ptksa_counters: ptksa_counters, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `ptksa_counters` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:266:17 [INFO] [stderr] | [INFO] [stderr] 266 | gtksa_counters: gtksa_counters, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `gtksa_counters` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:103:17 [INFO] [stderr] | [INFO] [stderr] 103 | device_id: device_id, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: replace it with: `device_id` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:105:17 [INFO] [stderr] | [INFO] [stderr] 105 | interface_type: interface_type, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `interface_type` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:106:17 [INFO] [stderr] | [INFO] [stderr] 106 | tx_power_level: tx_power_level, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `tx_power_level` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:107:17 [INFO] [stderr] | [INFO] [stderr] 107 | ssid: ssid, [INFO] [stderr] | ^^^^^^^^^^ help: replace it with: `ssid` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:108:17 [INFO] [stderr] | [INFO] [stderr] 108 | channel_width: channel_width, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `channel_width` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_phy.rs:42:17 [INFO] [stderr] | [INFO] [stderr] 42 | commands: commands, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: replace it with: `commands` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:20:36 [INFO] [stderr] | [INFO] [stderr] 20 | Ok(RawInformationElement { identifier: identifier, data: data }) [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `identifier` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::redundant_field_names)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:20:60 [INFO] [stderr] | [INFO] [stderr] 20 | Ok(RawInformationElement { identifier: identifier, data: data }) [INFO] [stderr] | ^^^^^^^^^^ help: replace it with: `data` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:39:13 [INFO] [stderr] | [INFO] [stderr] 39 | elements: elements, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: replace it with: `elements` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:260:17 [INFO] [stderr] | [INFO] [stderr] 260 | version: version, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: replace it with: `version` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:262:17 [INFO] [stderr] | [INFO] [stderr] 262 | ciphers: ciphers, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: replace it with: `ciphers` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:263:17 [INFO] [stderr] | [INFO] [stderr] 263 | akms: akms, [INFO] [stderr] | ^^^^^^^^^^ help: replace it with: `akms` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:265:17 [INFO] [stderr] | [INFO] [stderr] 265 | ptksa_counters: ptksa_counters, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `ptksa_counters` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/information_element.rs:266:17 [INFO] [stderr] | [INFO] [stderr] 266 | gtksa_counters: gtksa_counters, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `gtksa_counters` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:103:17 [INFO] [stderr] | [INFO] [stderr] 103 | device_id: device_id, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: replace it with: `device_id` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:105:17 [INFO] [stderr] | [INFO] [stderr] 105 | interface_type: interface_type, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `interface_type` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:106:17 [INFO] [stderr] | [INFO] [stderr] 106 | tx_power_level: tx_power_level, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `tx_power_level` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:107:17 [INFO] [stderr] | [INFO] [stderr] 107 | ssid: ssid, [INFO] [stderr] | ^^^^^^^^^^ help: replace it with: `ssid` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_interface.rs:108:17 [INFO] [stderr] | [INFO] [stderr] 108 | channel_width: channel_width, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `channel_width` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> src/wireless_phy.rs:42:17 [INFO] [stderr] | [INFO] [stderr] 42 | commands: commands, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: replace it with: `commands` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:59:16 [INFO] [stderr] | [INFO] [stderr] 59 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ff_ffff` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::unreadable_literal)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:59:30 [INFO] [stderr] | [INFO] [stderr] 59 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:81:49 [INFO] [stderr] | [INFO] [stderr] 81 | CipherSuite::UseGroupCipherSuite => 0x00ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:82:54 [INFO] [stderr] | [INFO] [stderr] 82 | CipherSuite::WiredEquivalentPrivacy40 => 0x01ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x01ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:83:58 [INFO] [stderr] | [INFO] [stderr] 83 | CipherSuite::TemporalKeyIntegrityProtocol => 0x02ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x02ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:84:55 [INFO] [stderr] | [INFO] [stderr] 84 | CipherSuite::CounterModeCbcMacProtocol => 0x04ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x04ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:85:55 [INFO] [stderr] | [INFO] [stderr] 85 | CipherSuite::WiredEquivalentPrivacy104 => 0x05ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x05ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:86:56 [INFO] [stderr] | [INFO] [stderr] 86 | CipherSuite::BroadcastIntegrityProtocol => 0x06ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x06ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:87:61 [INFO] [stderr] | [INFO] [stderr] 87 | CipherSuite::GroupAddressedTrafficNotAllowed => 0x07ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x07ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:88:41 [INFO] [stderr] | [INFO] [stderr] 88 | CipherSuite::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:127:16 [INFO] [stderr] | [INFO] [stderr] 127 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ff_ffff` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:127:30 [INFO] [stderr] | [INFO] [stderr] 127 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:151:82 [INFO] [stderr] | [INFO] [stderr] 151 | AuthenticationKeyManagement::PairwiseMasterKeySecurityAssociation => 0x01ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x01ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:152:58 [INFO] [stderr] | [INFO] [stderr] 152 | AuthenticationKeyManagement::PreSharedKey => 0x02ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x02ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:153:65 [INFO] [stderr] | [INFO] [stderr] 153 | AuthenticationKeyManagement::FastTransitionPMKSA => 0x03ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x03ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:154:72 [INFO] [stderr] | [INFO] [stderr] 154 | AuthenticationKeyManagement::FastTransitionPreSharedKey => 0x04ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x04ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:155:57 [INFO] [stderr] | [INFO] [stderr] 155 | AuthenticationKeyManagement::PMKSASha256 => 0x05ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x05ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:156:64 [INFO] [stderr] | [INFO] [stderr] 156 | AuthenticationKeyManagement::PreSharedKeySha256 => 0x06ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x06ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:157:69 [INFO] [stderr] | [INFO] [stderr] 157 | AuthenticationKeyManagement::TunneledDirectLinkSetup => 0x07ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x07ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:158:80 [INFO] [stderr] | [INFO] [stderr] 158 | AuthenticationKeyManagement::SimultaneousAuthenticationOfEquals => 0x08ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x08ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:159:63 [INFO] [stderr] | [INFO] [stderr] 159 | AuthenticationKeyManagement::FastTransitionSAE => 0x09ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x09ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:160:57 [INFO] [stderr] | [INFO] [stderr] 160 | AuthenticationKeyManagement::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/information_element.rs:269:6 [INFO] [stderr] | [INFO] [stderr] 269 | return Err(io::Error::new(io::ErrorKind::InvalidData, "Invalid RSN element").into()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove `return` as shown: `Err(io::Error::new(io::ErrorKind::InvalidData, "Invalid RSN element").into())` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::needless_return)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:59:16 [INFO] [stderr] | [INFO] [stderr] 59 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ff_ffff` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::unreadable_literal)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:59:30 [INFO] [stderr] | [INFO] [stderr] 59 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:81:49 [INFO] [stderr] | [INFO] [stderr] 81 | CipherSuite::UseGroupCipherSuite => 0x00ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:82:54 [INFO] [stderr] | [INFO] [stderr] 82 | CipherSuite::WiredEquivalentPrivacy40 => 0x01ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x01ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:83:58 [INFO] [stderr] | [INFO] [stderr] 83 | CipherSuite::TemporalKeyIntegrityProtocol => 0x02ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x02ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:84:55 [INFO] [stderr] | [INFO] [stderr] 84 | CipherSuite::CounterModeCbcMacProtocol => 0x04ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x04ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:85:55 [INFO] [stderr] | [INFO] [stderr] 85 | CipherSuite::WiredEquivalentPrivacy104 => 0x05ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x05ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:86:56 [INFO] [stderr] | [INFO] [stderr] 86 | CipherSuite::BroadcastIntegrityProtocol => 0x06ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x06ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:87:61 [INFO] [stderr] | [INFO] [stderr] 87 | CipherSuite::GroupAddressedTrafficNotAllowed => 0x07ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x07ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:88:41 [INFO] [stderr] | [INFO] [stderr] 88 | CipherSuite::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:127:16 [INFO] [stderr] | [INFO] [stderr] 127 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ff_ffff` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:127:30 [INFO] [stderr] | [INFO] [stderr] 127 | if v & 0x00ffffff == 0x00ac0f00 { [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:151:82 [INFO] [stderr] | [INFO] [stderr] 151 | AuthenticationKeyManagement::PairwiseMasterKeySecurityAssociation => 0x01ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x01ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:152:58 [INFO] [stderr] | [INFO] [stderr] 152 | AuthenticationKeyManagement::PreSharedKey => 0x02ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x02ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:153:65 [INFO] [stderr] | [INFO] [stderr] 153 | AuthenticationKeyManagement::FastTransitionPMKSA => 0x03ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x03ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:154:72 [INFO] [stderr] | [INFO] [stderr] 154 | AuthenticationKeyManagement::FastTransitionPreSharedKey => 0x04ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x04ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:155:57 [INFO] [stderr] | [INFO] [stderr] 155 | AuthenticationKeyManagement::PMKSASha256 => 0x05ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x05ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:156:64 [INFO] [stderr] | [INFO] [stderr] 156 | AuthenticationKeyManagement::PreSharedKeySha256 => 0x06ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x06ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:157:69 [INFO] [stderr] | [INFO] [stderr] 157 | AuthenticationKeyManagement::TunneledDirectLinkSetup => 0x07ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x07ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:158:80 [INFO] [stderr] | [INFO] [stderr] 158 | AuthenticationKeyManagement::SimultaneousAuthenticationOfEquals => 0x08ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x08ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:159:63 [INFO] [stderr] | [INFO] [stderr] 159 | AuthenticationKeyManagement::FastTransitionSAE => 0x09ac0f00, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x09ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> src/information_element.rs:160:57 [INFO] [stderr] | [INFO] [stderr] 160 | AuthenticationKeyManagement::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0x00ac_0f00` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/information_element.rs:269:6 [INFO] [stderr] | [INFO] [stderr] 269 | return Err(io::Error::new(io::ErrorKind::InvalidData, "Invalid RSN element").into()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove `return` as shown: `Err(io::Error::new(io::ErrorKind::InvalidData, "Invalid RSN element").into())` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::needless_return)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: this loop could be written as a `while let` loop [INFO] [stderr] --> src/information_element.rs:32:9 [INFO] [stderr] | [INFO] [stderr] 32 | / loop { [INFO] [stderr] 33 | | match RawInformationElement::parse(reader) { [INFO] [stderr] 34 | | Ok(ie) => elements.push(ie), [INFO] [stderr] 35 | | Err(_) => break, [INFO] [stderr] 36 | | } [INFO] [stderr] 37 | | } [INFO] [stderr] | |_________^ help: try: `while let Ok(ie) = RawInformationElement::parse(reader) { .. }` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::while_let_loop)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#while_let_loop [INFO] [stderr] [INFO] [stderr] warning: casting u8 to u32 may become silently lossy if types change [INFO] [stderr] --> src/information_element.rs:88:54 [INFO] [stderr] | [INFO] [stderr] 88 | CipherSuite::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: try: `u32::from(v)` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::cast_lossless)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to u32 may become silently lossy if types change [INFO] [stderr] --> src/information_element.rs:160:70 [INFO] [stderr] | [INFO] [stderr] 160 | AuthenticationKeyManagement::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: try: `u32::from(v)` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_interface.rs:341:13 [INFO] [stderr] | [INFO] [stderr] 341 | / match message { [INFO] [stderr] 342 | | Message::Data(m) => { [INFO] [stderr] 343 | | if m.header.identifier == family_id { [INFO] [stderr] 344 | | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] ... | [INFO] [stderr] 351 | | _ => (), [INFO] [stderr] 352 | | } [INFO] [stderr] | |_____________^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::single_match)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 341 | if let Message::Data(m) = message { [INFO] [stderr] 342 | if m.header.identifier == family_id { [INFO] [stderr] 343 | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] 344 | match WirelessInterface::from_message(gmsg, family_id) { [INFO] [stderr] 345 | Ok(wi) => devices.push(wi), [INFO] [stderr] 346 | Err(_) => (), [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_interface.rs:345:25 [INFO] [stderr] | [INFO] [stderr] 345 | / match WirelessInterface::from_message(gmsg, family_id) { [INFO] [stderr] 346 | | Ok(wi) => devices.push(wi), [INFO] [stderr] 347 | | Err(_) => (), [INFO] [stderr] 348 | | } [INFO] [stderr] | |_________________________^ help: try this: `if let Ok(wi) = WirelessInterface::from_message(gmsg, family_id) { devices.push(wi) }` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_phy.rs:28:25 [INFO] [stderr] | [INFO] [stderr] 28 | / match Command::convert_from(attr.as_u32()? as u8) { [INFO] [stderr] 29 | | Some(cmd) => commands.push(cmd), [INFO] [stderr] 30 | | None => (), [INFO] [stderr] 31 | | } [INFO] [stderr] | |_________________________^ help: try this: `if let Some(cmd) = Command::convert_from(attr.as_u32()? as u8) { commands.push(cmd) }` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_phy.rs:73:17 [INFO] [stderr] | [INFO] [stderr] 73 | / match message { [INFO] [stderr] 74 | | netlink::Message::Data(m) => { [INFO] [stderr] 75 | | if m.header.identifier == family_id { [INFO] [stderr] 76 | | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] ... | [INFO] [stderr] 83 | | _ => (), [INFO] [stderr] 84 | | } [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 73 | if let netlink::Message::Data(m) = message { [INFO] [stderr] 74 | if m.header.identifier == family_id { [INFO] [stderr] 75 | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] 76 | match WirelessPhy::from_message(gmsg) { [INFO] [stderr] 77 | Ok(phy) => phys.push(phy), [INFO] [stderr] 78 | Err(_) => (), [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_phy.rs:77:29 [INFO] [stderr] | [INFO] [stderr] 77 | / match WirelessPhy::from_message(gmsg) { [INFO] [stderr] 78 | | Ok(phy) => phys.push(phy), [INFO] [stderr] 79 | | Err(_) => (), [INFO] [stderr] 80 | | } [INFO] [stderr] | |_____________________________^ help: try this: `if let Ok(phy) = WirelessPhy::from_message(gmsg) { phys.push(phy) }` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] [INFO] [stderr] warning: this loop could be written as a `while let` loop [INFO] [stderr] --> src/information_element.rs:32:9 [INFO] [stderr] | [INFO] [stderr] 32 | / loop { [INFO] [stderr] 33 | | match RawInformationElement::parse(reader) { [INFO] [stderr] 34 | | Ok(ie) => elements.push(ie), [INFO] [stderr] 35 | | Err(_) => break, [INFO] [stderr] 36 | | } [INFO] [stderr] 37 | | } [INFO] [stderr] | |_________^ help: try: `while let Ok(ie) = RawInformationElement::parse(reader) { .. }` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::while_let_loop)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#while_let_loop [INFO] [stderr] [INFO] [stderr] warning: casting u8 to u32 may become silently lossy if types change [INFO] [stderr] --> src/information_element.rs:88:54 [INFO] [stderr] | [INFO] [stderr] 88 | CipherSuite::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: try: `u32::from(v)` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::cast_lossless)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to u32 may become silently lossy if types change [INFO] [stderr] --> src/information_element.rs:160:70 [INFO] [stderr] | [INFO] [stderr] 160 | AuthenticationKeyManagement::Reserved(v) => 0x00ac0f00 | (v as u32) << 24, [INFO] [stderr] | ^^^^^^^^^^ help: try: `u32::from(v)` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: using `print!()` with a format string that ends in a single newline, consider using `println!()` instead [INFO] [stderr] --> examples/nl80211.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | print!("{} bytes\n", slice.len()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::print_with_newline)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#print_with_newline [INFO] [stderr] [INFO] [stderr] warning: using `print!()` with a format string that ends in a single newline, consider using `println!()` instead [INFO] [stderr] --> examples/nl80211.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | print!("\n"); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#print_with_newline [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:281:13 [INFO] [stderr] | [INFO] [stderr] 281 | channel_1: channel_1, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: replace it with: `channel_1` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::redundant_field_names)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:282:13 [INFO] [stderr] | [INFO] [stderr] 282 | channel_2: channel_2, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: replace it with: `channel_2` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:283:13 [INFO] [stderr] | [INFO] [stderr] 283 | channel_width: channel_width, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `channel_width` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:284:13 [INFO] [stderr] | [INFO] [stderr] 284 | status: status, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: replace it with: `status` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:285:13 [INFO] [stderr] | [INFO] [stderr] 285 | ciphers: ciphers, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: replace it with: `ciphers` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:286:13 [INFO] [stderr] | [INFO] [stderr] 286 | akms: akms, [INFO] [stderr] | ^^^^^^^^^^ help: replace it with: `akms` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:287:13 [INFO] [stderr] | [INFO] [stderr] 287 | pmf: pmf, [INFO] [stderr] | ^^^^^^^^ help: replace it with: `pmf` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_interface.rs:341:13 [INFO] [stderr] | [INFO] [stderr] 341 | / match message { [INFO] [stderr] 342 | | Message::Data(m) => { [INFO] [stderr] 343 | | if m.header.identifier == family_id { [INFO] [stderr] 344 | | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] ... | [INFO] [stderr] 351 | | _ => (), [INFO] [stderr] 352 | | } [INFO] [stderr] | |_____________^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::single_match)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 341 | if let Message::Data(m) = message { [INFO] [stderr] 342 | if m.header.identifier == family_id { [INFO] [stderr] 343 | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] 344 | match WirelessInterface::from_message(gmsg, family_id) { [INFO] [stderr] 345 | Ok(wi) => devices.push(wi), [INFO] [stderr] 346 | Err(_) => (), [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_interface.rs:345:25 [INFO] [stderr] | [INFO] [stderr] 345 | / match WirelessInterface::from_message(gmsg, family_id) { [INFO] [stderr] 346 | | Ok(wi) => devices.push(wi), [INFO] [stderr] 347 | | Err(_) => (), [INFO] [stderr] 348 | | } [INFO] [stderr] | |_________________________^ help: try this: `if let Ok(wi) = WirelessInterface::from_message(gmsg, family_id) { devices.push(wi) }` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_phy.rs:28:25 [INFO] [stderr] | [INFO] [stderr] 28 | / match Command::convert_from(attr.as_u32()? as u8) { [INFO] [stderr] 29 | | Some(cmd) => commands.push(cmd), [INFO] [stderr] 30 | | None => (), [INFO] [stderr] 31 | | } [INFO] [stderr] | |_________________________^ help: try this: `if let Some(cmd) = Command::convert_from(attr.as_u32()? as u8) { commands.push(cmd) }` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:387:22 [INFO] [stderr] | [INFO] [stderr] 387 | Ok(Monitor { family: family, event_socket: event_socket, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: replace it with: `family` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:387:38 [INFO] [stderr] | [INFO] [stderr] 387 | Ok(Monitor { family: family, event_socket: event_socket, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `event_socket` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: redundant field names in struct initialization [INFO] [stderr] --> examples/nl80211.rs:388:13 [INFO] [stderr] | [INFO] [stderr] 388 | control_socket: control_socket, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace it with: `control_socket` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_field_names [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_phy.rs:73:17 [INFO] [stderr] | [INFO] [stderr] 73 | / match message { [INFO] [stderr] 74 | | netlink::Message::Data(m) => { [INFO] [stderr] 75 | | if m.header.identifier == family_id { [INFO] [stderr] 76 | | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] ... | [INFO] [stderr] 83 | | _ => (), [INFO] [stderr] 84 | | } [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 73 | if let netlink::Message::Data(m) = message { [INFO] [stderr] 74 | if m.header.identifier == family_id { [INFO] [stderr] 75 | let gmsg = generic::Message::parse(&mut io::Cursor::new(m.data))?; [INFO] [stderr] 76 | match WirelessPhy::from_message(gmsg) { [INFO] [stderr] 77 | Ok(phy) => phys.push(phy), [INFO] [stderr] 78 | Err(_) => (), [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/wireless_phy.rs:77:29 [INFO] [stderr] | [INFO] [stderr] 77 | / match WirelessPhy::from_message(gmsg) { [INFO] [stderr] 78 | | Ok(phy) => phys.push(phy), [INFO] [stderr] 79 | | Err(_) => (), [INFO] [stderr] 80 | | } [INFO] [stderr] | |_____________________________^ help: try this: `if let Ok(phy) = WirelessPhy::from_message(gmsg) { phys.push(phy) }` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> examples/nl80211.rs:86:13 [INFO] [stderr] | [INFO] [stderr] 86 | return (self.frequency - 5000) / 5 [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove `return` as shown: `(self.frequency - 5000) / 5` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::needless_return)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> examples/nl80211.rs:89:13 [INFO] [stderr] | [INFO] [stderr] 89 | return 0xffffffff [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: remove `return` as shown: `0xffffffff` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: long literal lacking separators [INFO] [stderr] --> examples/nl80211.rs:89:20 [INFO] [stderr] | [INFO] [stderr] 89 | return 0xffffffff [INFO] [stderr] | ^^^^^^^^^^ help: consider: `0xffff_ffff` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::unreadable_literal)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unreadable_literal [INFO] [stderr] [INFO] [stderr] warning: this `else { if .. }` block can be collapsed [INFO] [stderr] --> examples/nl80211.rs:212:26 [INFO] [stderr] | [INFO] [stderr] 212 | else { [INFO] [stderr] | __________________________^ [INFO] [stderr] 213 | | if let Some(ie_id) = nl80211::InformationElementId::convert_from(ie.identifier) { [INFO] [stderr] 214 | | match ie_id { [INFO] [stderr] 215 | | nl80211::InformationElementId::HighThroughputOperation => { [INFO] [stderr] ... | [INFO] [stderr] 265 | | } [INFO] [stderr] 266 | | } [INFO] [stderr] | |_____________________^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::collapsible_if)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#collapsible_if [INFO] [stderr] help: try [INFO] [stderr] | [INFO] [stderr] 212 | else if let Some(ie_id) = nl80211::InformationElementId::convert_from(ie.identifier) { [INFO] [stderr] 213 | match ie_id { [INFO] [stderr] 214 | nl80211::InformationElementId::HighThroughputOperation => { [INFO] [stderr] 215 | if ie.data.len() == 22 { [INFO] [stderr] 216 | let width = if ie.data[1] & 0x04 == 0 { 20 } else { 40 }; [INFO] [stderr] 217 | if channel_width < width { [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: casting i32 to f64 may become silently lossy if types change [INFO] [stderr] --> examples/nl80211.rs:95:22 [INFO] [stderr] | [INFO] [stderr] 95 | let signal = self.signal as f64 / 100.0; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: try: `f64::from(self.signal)` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::cast_lossless)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting i32 to f64 may become silently lossy if types change [INFO] [stderr] --> examples/nl80211.rs:105:22 [INFO] [stderr] | [INFO] [stderr] 105 | let signal = self.signal as f64 / 100.0; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: try: `f64::from(self.signal)` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> examples/nl80211.rs:158:17 [INFO] [stderr] | [INFO] [stderr] 158 | / match attr.as_u32() { [INFO] [stderr] 159 | | Ok(value) => { [INFO] [stderr] 160 | | status = match value { [INFO] [stderr] 161 | | 0 => AccessPointStatus::Authenticated, [INFO] [stderr] ... | [INFO] [stderr] 167 | | Err(_) => (), [INFO] [stderr] 168 | | } [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::single_match)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 158 | if let Ok(value) = attr.as_u32() { [INFO] [stderr] 159 | status = match value { [INFO] [stderr] 160 | 0 => AccessPointStatus::Authenticated, [INFO] [stderr] 161 | 1 => AccessPointStatus::Associated, [INFO] [stderr] 162 | 2 => AccessPointStatus::Joined, [INFO] [stderr] 163 | _ => AccessPointStatus::None, [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: `ref` on an entire `let` pattern is discouraged, take a reference with `&` instead [INFO] [stderr] --> examples/nl80211.rs:184:21 [INFO] [stderr] | [INFO] [stderr] 184 | for ref ie in ies.elements { [INFO] [stderr] | ^^^^^^ ------------ help: try: `let ie = &ies.elements;` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::toplevel_ref_arg)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#toplevel_ref_arg [INFO] [stderr] [INFO] [stderr] warning: `ref` on an entire `let` pattern is discouraged, take a reference with `&` instead [INFO] [stderr] --> examples/nl80211.rs:208:21 [INFO] [stderr] | [INFO] [stderr] 208 | for ref ie in ies.elements { [INFO] [stderr] | ^^^^^^ ------------ help: try: `let ie = &ies.elements;` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#toplevel_ref_arg [INFO] [stderr] [INFO] [stderr] warning: `ref` on an entire `let` pattern is discouraged, take a reference with `&` instead [INFO] [stderr] --> examples/nl80211.rs:297:13 [INFO] [stderr] | [INFO] [stderr] 297 | for ref attr in &message.attributes { [INFO] [stderr] | ^^^^^^^^ ------------------- help: try: `let attr = &&message.attributes;` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#toplevel_ref_arg [INFO] [stderr] [INFO] [stderr] error: handle written amount returned or use `Write::write_all` instead [INFO] [stderr] --> examples/nl80211.rs:319:5 [INFO] [stderr] | [INFO] [stderr] 319 | handle.write(b"Scan Results ---\n")?; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[deny(clippy::unused_io_amount)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unused_io_amount [INFO] [stderr] [INFO] [stderr] warning: `ref` on an entire `let` pattern is discouraged, take a reference with `&` instead [INFO] [stderr] --> examples/nl80211.rs:383:13 [INFO] [stderr] | [INFO] [stderr] 383 | for ref group in &family.multicast_groups { [INFO] [stderr] | ^^^^^^^^^ ------------------------ help: try: `let group = &&family.multicast_groups;` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#toplevel_ref_arg [INFO] [stderr] [INFO] [stderr] warning: `ref` on an entire `let` pattern is discouraged, take a reference with `&` instead [INFO] [stderr] --> examples/nl80211.rs:459:29 [INFO] [stderr] | [INFO] [stderr] 459 | for ref attr in &msg.attributes { [INFO] [stderr] | ^^^^^^^^ --------------- help: try: `let attr = &&msg.attributes;` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#toplevel_ref_arg [INFO] [stderr] [INFO] [stderr] warning: `ref` on an entire `let` pattern is discouraged, take a reference with `&` instead [INFO] [stderr] --> examples/nl80211.rs:486:37 [INFO] [stderr] | [INFO] [stderr] 486 | for ref attr in &msg.attributes { [INFO] [stderr] | ^^^^^^^^ --------------- help: try: `let attr = &&msg.attributes;` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#toplevel_ref_arg [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> examples/nl80211.rs:489:37 [INFO] [stderr] | [INFO] [stderr] 489 | / match attr_id { [INFO] [stderr] 490 | | nl80211::Attribute::Frame => { [INFO] [stderr] 491 | | let data = &attr.as_bytes(); [INFO] [stderr] 492 | | show_slice(&data); [INFO] [stderr] ... | [INFO] [stderr] 506 | | _ => (), [INFO] [stderr] 507 | | } [INFO] [stderr] | |_____________________________________^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 489 | if let nl80211::Attribute::Frame = attr_id { [INFO] [stderr] 490 | let data = &attr.as_bytes(); [INFO] [stderr] 491 | show_slice(&data); [INFO] [stderr] 492 | let mut hwa = [0u8; 6]; [INFO] [stderr] 493 | // See 8.2.3 in 802.11-2012.pdf [INFO] [stderr] 494 | let mut reader = io::Cursor::new(&data); [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: `ref` on an entire `let` pattern is discouraged, take a reference with `&` instead [INFO] [stderr] --> examples/nl80211.rs:541:37 [INFO] [stderr] | [INFO] [stderr] 541 | for ref attr in &msg.attributes { [INFO] [stderr] | ^^^^^^^^ --------------- help: try: `let attr = &&msg.attributes;` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#toplevel_ref_arg [INFO] [stderr] [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] error: Could not compile `nl80211-rs`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "a31979a629f3603d00a96b888be041162604091bd49b66025c63343d2fa33c62"` [INFO] running `"docker" "rm" "-f" "a31979a629f3603d00a96b888be041162604091bd49b66025c63343d2fa33c62"` [INFO] [stdout] a31979a629f3603d00a96b888be041162604091bd49b66025c63343d2fa33c62