Skip to content

Update Github Action File #129

Update Github Action File

Update Github Action File #129

Triggered via push January 17, 2024 00:00
Status Success
Total duration 17s
Artifacts

learn-sapio.yml

on: push
Fit to window
Zoom out
Zoom in

Annotations

117 warnings
deploy
The following actions uses node12 which is deprecated and will be forced to run on node16: actions/checkout@v2. For more info: https://github.blog/changelog/2023-06-13-github-actions-all-actions-will-run-on-node16-instead-of-node12-by-default/
unused `std::result::Result` that must be used: cli/src/contracts/server.rs#L48
warning: unused `std::result::Result` that must be used --> cli/src/contracts/server.rs:48:25 | 48 | resp.send(req.handle().await); | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = note: this `Result` may be an `Err` variant, which should be handled = note: `#[warn(unused_must_use)]` on by default help: use `let _ = ...` to ignore the resulting value | 48 | let _ = resp.send(req.handle().await); | +++++++
the borrowed expression implements the required traits: cli/src/main.rs#L317
warning: the borrowed expression implements the required traits --> cli/src/main.rs:317:70 | 317 | std::fs::write(args.value_of_os("out").unwrap(), &base64::encode(bytes))?; | ^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `base64::encode(bytes)` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args
the borrowed expression implements the required traits: cli/src/main.rs#L267
warning: the borrowed expression implements the required traits --> cli/src/main.rs:267:46 | 267 | std::fs::write(file_out, &base64::encode(bytes))?; | ^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `base64::encode(bytes)` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args
the borrowed expression implements the required traits: cli/src/util.rs#L46
warning: the borrowed expression implements the required traits --> cli/src/util.rs:46:25 | 46 | &base64::decode(&if let Some(psbt) = psbt_str { | _________________________^ 47 | | psbt.into() 48 | | } else { 49 | | let mut s = String::new(); 50 | | tokio::io::stdin().read_to_string(&mut s).await?; 51 | | s 52 | | })?[..], | |_________^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args = note: `#[warn(clippy::needless_borrows_for_generic_args)]` on by default help: change this to | 46 ~ &base64::decode(if let Some(psbt) = psbt_str { 47 + psbt.into() 48 + } else { 49 + let mut s = String::new(); 50 + tokio::io::stdin().read_to_string(&mut s).await?; 51 + s 52 ~ })?[..], |
very complex type used. Consider factoring parts into `type` definitions: cli/src/contracts/server.rs#L26
warning: very complex type used. Consider factoring parts into `type` definitions --> cli/src/contracts/server.rs:26:21 | 26 | pub fn new() -> ( | _____________________^ 27 | | Self, 28 | | UnboundedSender<(Request, oneshot::Sender<Response>)>, 29 | | broadcast::Sender<()>, 30 | | ) { | |_____^ | = 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
casting to the same type is unnecessary (`u32` -> `u32`): cli/src/contracts/request.rs#L338
warning: casting to the same type is unnecessary (`u32` -> `u32`) --> cli/src/contracts/request.rs:338:38 | 338 | OutPoint::new(tx.txid(), vout as u32), | ^^^^^^^^^^^ help: try: `vout` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast = note: `#[warn(clippy::unnecessary_cast)]` on by default
writing `&PathBuf` instead of `&Path` involves a new object where a slice will do: cli/src/config.rs#L105
warning: writing `&PathBuf` instead of `&Path` involves a new object where a slice will do --> cli/src/config.rs:105:28 | 105 | pub fn serialize<S>(p: &PathBuf, s: S) -> Result<S::Ok, S::Error> | ^^^^^^^^ help: change this to: `&Path` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#ptr_arg = note: `#[warn(clippy::ptr_arg)]` on by default
an implementation of `From` is preferred since it gives you `Into<_>` for free where the reverse isn't true: cli/src/config.rs#L96
warning: an implementation of `From` is preferred since it gives you `Into<_>` for free where the reverse isn't true --> cli/src/config.rs:96:1 | 96 | impl Into<PathBuf> for PathBufWrapped { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: `impl From<Local> for Foreign` is allowed by the orphan rules, for more information see https://doc.rust-lang.org/reference/items/implementations.html#trait-implementation-coherence = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#from_over_into = note: `#[warn(clippy::from_over_into)]` on by default help: replace the `Into` implementation with `From<config::PathBufWrapped>` | 96 ~ impl From<PathBufWrapped> for PathBuf { 97 ~ fn from(val: PathBufWrapped) -> Self { 98 ~ val.0 |
unused import: `Write`: cli/src/contracts/request.rs#L31
warning: unused import: `Write` --> cli/src/contracts/request.rs:31:36 | 31 | use std::fmt::{Display, Formatter, Write}; | ^^^^^ | = note: `#[warn(unused_imports)]` on by default
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L358
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:358:9 | 358 | / env.memory 359 | | .as_ref() 360 | | .unwrap() 361 | | .view(&store) 362 | | .write(bytes as u64, s.as_bytes()); | |______________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 358 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L343
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:343:9 | 343 | / env.memory 344 | | .as_ref() 345 | | .unwrap() 346 | | .view(&store) 347 | | .read(psbt, &mut buf[..]); | |_____________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 343 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L326
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:326:9 | 326 | / env.memory 327 | | .as_ref() 328 | | .unwrap() 329 | | .view(&store) 330 | | .write(bytes as u64, s.as_bytes()); | |______________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 326 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L311
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:311:13 | 311 | / env.memory 312 | | .as_ref() 313 | | .unwrap() 314 | | .view(&store) 315 | | .read(hash, &mut buf[..]); | |_________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 311 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L298
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:298:9 | 298 | w.write_all(&v[..]); | ^^^^^^^^^^^^^^^^^^^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 298 | let _ = w.write_all(&v[..]); | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L297
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:297:9 | 297 | mem.read(a as u64, &mut v[..]); | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 297 | let _ = mem.read(a as u64, &mut v[..]); | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L276
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:276:21 | 276 | / env.memory 277 | | .as_ref() 278 | | .unwrap() 279 | | .view(&store) 280 | | .write(bytes as u64, comp_s.as_bytes()); | |_______________________________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 276 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L208
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:208:17 | 208 | / env.memory 209 | | .as_ref() 210 | | .unwrap() 211 | | .view(&store) 212 | | .read(path as u64, &mut v[..path_len as usize]); | |___________________________________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 208 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L198
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:198:17 | 198 | / env.memory 199 | | .as_ref() 200 | | .unwrap() 201 | | .view(&store) 202 | | .read(json as u64, &mut v[..json_len as usize]); | |___________________________________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 198 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L171
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:171:13 | 171 | / env.memory 172 | | .as_ref() 173 | | .unwrap() 174 | | .view(&store) 175 | | .read(key, &mut buf[..]); | |________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 171 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L110
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:110:9 | 110 | / env.memory 111 | | .as_ref() 112 | | .unwrap() 113 | | .view(&store) 114 | | .write_u8(ok as u64, is_ok); | |_______________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 110 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L101
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:101:13 | 101 | / env.memory 102 | | .as_ref() 103 | | .unwrap() 104 | | .view(&store) 105 | | .write(out as u64, b); | |_____________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 101 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/mod.rs#L92
warning: unused `std::result::Result` that must be used --> plugins/src/host/mod.rs:92:17 | 92 | / env.memory 93 | | .as_ref() 94 | | .unwrap() 95 | | .view(&store) 96 | | .read(key as u64, &mut buf[..]); | |___________________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 92 | let _ = env.memory | +++++++
unused `std::result::Result` that must be used: plugins/src/host/plugin_handle/wasm.rs#L223
warning: unused `std::result::Result` that must be used --> plugins/src/host/plugin_handle/wasm.rs:223:9 | 223 | mem.read(p, &mut v[..]); | ^^^^^^^^^^^^^^^^^^^^^^^ | = note: this `Result` may be an `Err` variant, which should be handled help: use `let _ = ...` to ignore the resulting value | 223 | let _ = mem.read(p, &mut v[..]); | +++++++
unused `std::result::Result` that must be used: plugins/src/host/plugin_handle/wasm.rs#L191
warning: unused `std::result::Result` that must be used --> plugins/src/host/plugin_handle/wasm.rs:191:9 | 191 | / env.memory 192 | | .as_ref() 193 | | .ok_or(CompilationError::ModuleFailedToGetMemory( 194 | | "Memory Missing".into(), 195 | | ))? 196 | | .view(&self.store) 197 | | .write(offset as u64, &s.as_bytes()[..]); | |____________________________________________________^ | = note: this `Result` may be an `Err` variant, which should be handled = note: `#[warn(unused_must_use)]` on by default help: use `let _ = ...` to ignore the resulting value | 191 | let _ = env.memory | +++++++
you should consider adding a `Default` implementation for `API<Input, Output>`: plugins/src/lib.rs#L41
warning: you should consider adding a `Default` implementation for `API<Input, Output>` --> plugins/src/lib.rs:41:5 | 41 | / pub fn new() -> Self { 42 | | API { 43 | | arguments: schemars::schema_for!(Input), 44 | | returns: schemars::schema_for!(Output), 45 | | _pd: Default::default(), 46 | | } 47 | | } | |_____^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default = note: `#[warn(clippy::new_without_default)]` on by default help: try adding this | 35 + impl<Input, Output> Default for API<Input, Output> 36 + where 37 + Input: JsonSchema, 38 + Output: JsonSchema, 39 + { 40 + fn default() -> Self { 41 + Self::new() 42 + } 43 + } |
this `to_owned` call clones the Cow<'_, str> itself and does not cause the Cow<'_, str> contents to become owned: plugins/src/host/mod.rs#L214
warning: this `to_owned` call clones the Cow<'_, str> itself and does not cause the Cow<'_, str> contents to become owned --> plugins/src/host/mod.rs:214:22 | 214 | &String::from_utf8_lossy(&v[..path_len as usize]).to_owned(), | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#suspicious_to_owned help: depending on intent, either make the Cow an Owned variant | 214 | &String::from_utf8_lossy(&v[..path_len as usize]).into_owned(), | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ help: or clone the Cow itself | 214 | &String::from_utf8_lossy(&v[..path_len as usize]).clone(), | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
this `to_owned` call clones the Cow<'_, str> itself and does not cause the Cow<'_, str> contents to become owned: plugins/src/host/mod.rs#L204
warning: this `to_owned` call clones the Cow<'_, str> itself and does not cause the Cow<'_, str> contents to become owned --> plugins/src/host/mod.rs:204:22 | 204 | &String::from_utf8_lossy(&v[..json_len as usize]).to_owned(), | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#suspicious_to_owned = note: `#[warn(clippy::suspicious_to_owned)]` on by default help: depending on intent, either make the Cow an Owned variant | 204 | &String::from_utf8_lossy(&v[..json_len as usize]).into_owned(), | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ help: or clone the Cow itself | 204 | &String::from_utf8_lossy(&v[..json_len as usize]).clone(), | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
this function has too many arguments (8/7): plugins/src/host/plugin_handle/wasm.rs#L227
warning: this function has too many arguments (8/7) --> plugins/src/host/plugin_handle/wasm.rs:227:5 | 227 | / fn setup_plugin_inner<I: Into<PathBuf> + Clone>( 228 | | mut store: Store, 229 | | path: I, 230 | | this: [u8; 32], ... | 235 | | key: WASMCacheID, 236 | | ) -> Result<Self, Box<dyn Error>> { | |_____________________________________^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#too_many_arguments = note: `#[warn(clippy::too_many_arguments)]` on by default
redundant slicing of the whole range: plugins/src/host/plugin_handle/wasm.rs#L197
warning: redundant slicing of the whole range --> plugins/src/host/plugin_handle/wasm.rs:197:35 | 197 | .write(offset as u64, &s.as_bytes()[..]); | ^^^^^^^^^^^^^^^^^ help: use the original value instead: `s.as_bytes()` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_slicing = note: `#[warn(clippy::redundant_slicing)]` on by default
question mark operator is useless here: plugins/src/host/plugin_handle/wasm.rs#L88
warning: question mark operator is useless here --> plugins/src/host/plugin_handle/wasm.rs:88:9 | 88 | / Ok(Self::setup_plugin_inner( 89 | | Store::default(), 90 | | env.path.clone(), 91 | | env.this, ... | 96 | | self.key, 97 | | )?) | |___________^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_question_mark = note: `#[warn(clippy::needless_question_mark)]` on by default help: try removing question mark and `Ok()` | 88 ~ Self::setup_plugin_inner( 89 + Store::default(), 90 + env.path.clone(), 91 + env.this, 92 + Some(env.module_map.clone()), 93 + self.net, 94 + &env.emulator, 95 + self.module.clone(), 96 + self.key, 97 + ) |
unsafe function's docs miss `# Safety` section: plugins/src/client/plugin.rs#L113
warning: unsafe function's docs miss `# Safety` section --> plugins/src/client/plugin.rs:113:5 | 113 | unsafe fn register(name: &'static str, logo: Option<&'static [u8]>) { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#missing_safety_doc
unsafe function's docs miss `# Safety` section: plugins/src/client/plugin.rs#L63
warning: unsafe function's docs miss `# Safety` section --> plugins/src/client/plugin.rs:63:5 | 63 | / unsafe fn create_result( 64 | | p: *mut c_char, 65 | | c: *mut c_char, 66 | | ) -> Result<Self::Output, CompilationError> { | |_______________________________________________^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#missing_safety_doc
unsafe function's docs miss `# Safety` section: plugins/src/client/plugin.rs#L57
warning: unsafe function's docs miss `# Safety` section --> plugins/src/client/plugin.rs:57:5 | 57 | unsafe fn create(p: *mut c_char, c: *mut c_char) -> *mut c_char { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#missing_safety_doc = note: `#[warn(clippy::missing_safety_doc)]` on by default
method `get_memory` is never used: plugins/src/host/plugin_handle/wasm.rs#L201
warning: method `get_memory` is never used --> plugins/src/host/plugin_handle/wasm.rs:201:8 | 100 | impl<Output> WasmPluginHandle<Output> { | ------------------------------------- method in this implementation ... 201 | fn get_memory(&self) -> Result<&Memory, CompilationError> { | ^^^^^^^^^^
field `instance` is never read: plugins/src/host/plugin_handle/wasm.rs#L64
warning: field `instance` is never read --> plugins/src/host/plugin_handle/wasm.rs:64:5 | 60 | pub struct WasmPluginHandle<Output> { | ---------------- field in this struct ... 64 | instance: Instance, | ^^^^^^^^ | = note: `#[warn(dead_code)]` on by default
very complex type used. Consider factoring parts into `type` definitions: sapio-contrib/src/contracts/tic_tac_toe.rs#L72
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio-contrib/src/contracts/tic_tac_toe.rs:72:12 | 72 | cache: Arc<Mutex<BTreeMap<(&'static str, Board, Tile), Vec<Template>>>>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
this `as_str` is redundant and can be removed as the method immediately following exists on `String` too: sapio-contrib/src/contracts/op_return_chain.rs#L50
warning: this `as_str` is redundant and can be removed as the method immediately following exists on `String` too --> sapio-contrib/src/contracts/op_return_chain.rs:50:48 | 50 | &Compiled::from_op_return(data.as_str().as_bytes())?, | ^^^^^^^^^^^^^^^^^ help: try: `as_bytes` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_as_str = note: `#[warn(clippy::redundant_as_str)]` on by default
an implementation of `From` is preferred since it gives you `Into<_>` for free where the reverse isn't true: sapio-contrib/src/contracts/hanukkah.rs#L111
warning: an implementation of `From` is preferred since it gives you `Into<_>` for free where the reverse isn't true --> sapio-contrib/src/contracts/hanukkah.rs:111:1 | 111 | impl Into<String> for Recipients { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: `impl From<Local> for Foreign` is allowed by the orphan rules, for more information see https://doc.rust-lang.org/reference/items/implementations.html#trait-implementation-coherence = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#from_over_into = note: `#[warn(clippy::from_over_into)]` on by default help: replace the `Into` implementation with `From<contracts::hanukkah::Recipients>` | 111 ~ impl From<Recipients> for String { 112 ~ fn from(val: Recipients) -> Self { 113 ~ val.0 |
use of `default` to create a unit struct: sapio-contrib/src/contracts/federated_sidechain.rs#L77
warning: use of `default` to create a unit struct --> sapio-contrib/src/contracts/federated_sidechain.rs:77:37 | 77 | _pd: PhantomData::default(), | ^^^^^^^^^^^ help: remove this call to `default` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#default_constructed_unit_structs = note: `#[warn(clippy::default_constructed_unit_structs)]` on by default
very complex type used. Consider factoring parts into `type` definitions: sapio-contrib/src/contracts/dynamic.rs#L59
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio-contrib/src/contracts/dynamic.rs:59:16 | 59 | let v: Vec<fn() -> Option<actions::ThenFuncAsFinishOrFunc<'static, D<'static>, ()>>> = | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
the following explicit lifetimes could be elided: 'a: sapio-contrib/src/contracts/dynamic.rs#L48
warning: the following explicit lifetimes could be elided: 'a --> sapio-contrib/src/contracts/dynamic.rs:48:22 | 48 | fn ensure_amount<'a>(&'a self, _ctx: Context) -> Result<Amount, CompilationError> { | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 48 - fn ensure_amount<'a>(&'a self, _ctx: Context) -> Result<Amount, CompilationError> { 48 + fn ensure_amount(&self, _ctx: Context) -> Result<Amount, CompilationError> { |
the following explicit lifetimes could be elided: 'a: sapio-contrib/src/contracts/dynamic.rs#L45
warning: the following explicit lifetimes could be elided: 'a --> sapio-contrib/src/contracts/dynamic.rs:45:17 | 45 | fn metadata<'a>(&'a self, _ctx: Context) -> Result<ObjectMetadata, CompilationError> { | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 45 - fn metadata<'a>(&'a self, _ctx: Context) -> Result<ObjectMetadata, CompilationError> { 45 + fn metadata(&self, _ctx: Context) -> Result<ObjectMetadata, CompilationError> { |
the following explicit lifetimes could be elided: 'a: sapio-contrib/src/contracts/dynamic.rs#L42
warning: the following explicit lifetimes could be elided: 'a --> sapio-contrib/src/contracts/dynamic.rs:42:22 | 42 | fn get_inner_ref<'a>(&'a self) -> &Self { | ^^ ^^ ^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 42 - fn get_inner_ref<'a>(&'a self) -> &Self { 42 + fn get_inner_ref(&self) -> &Self { |
the following explicit lifetimes could be elided: 'a: sapio-contrib/src/contracts/dynamic.rs#L39
warning: the following explicit lifetimes could be elided: 'a --> sapio-contrib/src/contracts/dynamic.rs:39:19 | 39 | fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<Self>>] { | ^^ ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 39 - fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<Self>>] { 39 + fn finish_fns(&self) -> &[fn() -> Option<actions::Guard<Self>>] { |
the following explicit lifetimes could be elided: 'a: sapio-contrib/src/contracts/dynamic.rs#L34
warning: the following explicit lifetimes could be elided: 'a --> sapio-contrib/src/contracts/dynamic.rs:34:22 | 34 | fn finish_or_fns<'a>( | ^^ 35 | &'a self, | ^^ 36 | ) -> &'a [fn() -> Option<Box<dyn actions::CallableAsFoF<Self, Self::StatefulArguments>>>] { | ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes = note: `#[warn(clippy::needless_lifetimes)]` on by default help: elide the lifetimes | 34 ~ fn finish_or_fns( 35 ~ &self, 36 ~ ) -> &[fn() -> Option<Box<dyn actions::CallableAsFoF<Self, Self::StatefulArguments>>>] { |
very complex type used. Consider factoring parts into `type` definitions: sapio-contrib/src/contracts/dynamic.rs#L20
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio-contrib/src/contracts/dynamic.rs:20:8 | 20 | v: Vec<fn() -> Option<actions::ThenFuncAsFinishOrFunc<'a, D<'a>, ()>>>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
casting to the same type is unnecessary (`u64` -> `u64`): sapio-contrib/src/contracts/derivatives/risk_reversal.rs#L132
warning: casting to the same type is unnecessary (`u64` -> `u64`) --> sapio-contrib/src/contracts/derivatives/risk_reversal.rs:132:33 | 132 | .derive_num(strike as u64)? | ^^^^^^^^^^^^^ help: try: `strike` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast
casting to the same type is unnecessary (`u64` -> `u64`): sapio-contrib/src/contracts/derivatives/put.rs#L44
warning: casting to the same type is unnecessary (`u64` -> `u64`) --> sapio-contrib/src/contracts/derivatives/put.rs:44:33 | 44 | .derive_num(price as u64)? | ^^^^^^^^^^^^ help: try: `price` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast
casting to the same type is unnecessary (`u64` -> `u64`): sapio-contrib/src/contracts/derivatives/call.rs#L48
warning: casting to the same type is unnecessary (`u64` -> `u64`) --> sapio-contrib/src/contracts/derivatives/call.rs:48:33 | 48 | .derive_num(price as u64)? | ^^^^^^^^^^^^ help: try: `price` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast = note: `#[warn(clippy::unnecessary_cast)]` on by default
this `impl` can be derived: sapio-contrib/src/contracts/coin_pool.rs#L134
warning: this `impl` can be derived --> sapio-contrib/src/contracts/coin_pool.rs:134:1 | 134 | / impl Default for UpdateTypes { 135 | | fn default() -> Self { 136 | | UpdateTypes::NoUpdate 137 | | } 138 | | } | |_^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#derivable_impls = help: remove the manual implementation... help: ...and instead derive it... | 114 + #[derive(Default)] 115 | pub enum UpdateTypes { | help: ...and mark the default variant | 132 ~ #[default] 133 ~ NoUpdate, |
useless conversion to the same type: `sapio_bitcoin::util::amount::CoinAmount`: sapio-contrib/src/contracts/channel.rs#L273
warning: useless conversion to the same type: `sapio_bitcoin::util::amount::CoinAmount` --> sapio-contrib/src/contracts/channel.rs:273:29 | 273 | amount: self.amount.try_into().unwrap(), | ^^^^^^^^^^^^^^^^^^^^^^ | = help: consider removing `.try_into()` = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_conversion = note: `#[warn(clippy::useless_conversion)]` on by default
very complex type used. Consider factoring parts into `type` definitions: sapio-contrib/src/contracts/channel.rs#L158
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio-contrib/src/contracts/channel.rs:158:30 | 158 | static ref DB_TYPES: Mutex<BTreeMap<String, fn(&str) -> Arc<Mutex<dyn DB>>>> = | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = 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
this `impl` can be derived: sapio-contrib/src/contracts/channel.rs#L111
warning: this `impl` can be derived --> sapio-contrib/src/contracts/channel.rs:111:1 | 111 | / impl Default for Args { 112 | | fn default() -> Self { 113 | | Args::None 114 | | } 115 | | } | |_^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#derivable_impls = note: `#[warn(clippy::derivable_impls)]` on by default = help: remove the manual implementation... help: ...and instead derive it... | 105 + #[derive(Default)] 106 | pub enum Args { | help: ...and mark the default variant | 109 ~ #[default] 110 ~ None, |
function `candles_left` is never used: sapio-contrib/src/contracts/hanukkah.rs#L34
warning: function `candles_left` is never used --> sapio-contrib/src/contracts/hanukkah.rs:34:4 | 34 | fn candles_left(s: u8) -> u8 { | ^^^^^^^^^^^^
variants `LinearPositive`, `GeometricPositive`, and `Sigmoid` are never constructed: sapio-contrib/src/contracts/derivatives/dlc.rs#L142
warning: variants `LinearPositive`, `GeometricPositive`, and `Sigmoid` are never constructed --> sapio-contrib/src/contracts/derivatives/dlc.rs:142:5 | 139 | enum SplitFunctions { | -------------- variants in this enum ... 142 | LinearPositive(Intercept), | ^^^^^^^^^^^^^^ 143 | /// A Geometric starting at the intercept parameter to 1.0 144 | GeometricPositive(Intercept), | ^^^^^^^^^^^^^^^^^ ... 149 | Sigmoid(Offset), | ^^^^^^^ | = note: `SplitFunctions` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
field `url` is never read: sapio-contrib/src/contracts/derivatives/dlc.rs#L30
warning: field `url` is never read --> sapio-contrib/src/contracts/derivatives/dlc.rs:30:5 | 29 | struct BasicOracle { | ----------- field in this struct 30 | url: String, | ^^^
field `0` is never read: sapio-contrib/src/contracts/derivatives/dlc.rs#L19
warning: field `0` is never read --> sapio-contrib/src/contracts/derivatives/dlc.rs:19:14 | 19 | struct Event(String); | ----- ^^^^^^ | | | field in this struct | help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field | 19 | struct Event(()); | ~~
function `register_db` is never used: sapio-contrib/src/contracts/channel.rs#L162
warning: function `register_db` is never used --> sapio-contrib/src/contracts/channel.rs:162:12 | 162 | pub fn register_db(s: String, f: fn(&str) -> Arc<Mutex<dyn DB>>) { | ^^^^^^^^^^^
fields `revoke` and `split` are never read: sapio-contrib/src/contracts/channel.rs#L89
warning: fields `revoke` and `split` are never read --> sapio-contrib/src/contracts/channel.rs:89:5 | 87 | pub struct Update { | ------ fields in this struct 88 | /// hash to revoke 89 | revoke: bitcoin::hashes::sha256::Hash, | ^^^^^^ 90 | /// the balances of the channel 91 | split: (CoinAmount, CoinAmount), | ^^^^^ | = note: `Update` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis = note: `#[warn(dead_code)]` on by default
unused `std::result::Result` that must be used: examples/dcf_mining_pool/src/main.rs#L121
warning: unused `std::result::Result` that must be used --> examples/dcf_mining_pool/src/main.rs:121:13 | 121 | v.await; | ^^^^^^^ | = note: this `Result` may be an `Err` variant, which should be handled = note: `#[warn(unused_must_use)]` on by default help: use `let _ = ...` to ignore the resulting value | 121 | let _ = v.await; | +++++++
empty `loop {}` wastes CPU cycles: examples/dcf_mining_pool/src/main.rs#L210
warning: empty `loop {}` wastes CPU cycles --> examples/dcf_mining_pool/src/main.rs:210:5 | 210 | loop {} | ^^^^^^^ | = help: you should either use `panic!()` or add `std::thread::sleep(..);` to the loop body = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#empty_loop = note: `#[warn(clippy::empty_loop)]` on by default
method `compute_for_block` is never used: examples/dcf_mining_pool/src/main.rs#L69
warning: method `compute_for_block` is never used --> examples/dcf_mining_pool/src/main.rs:69:14 | 68 | impl Coordinator { | ---------------- method in this implementation 69 | async fn compute_for_block( | ^^^^^^^^^^^^^^^^^
struct `Coordinator` is never constructed: examples/dcf_mining_pool/src/main.rs#L62
warning: struct `Coordinator` is never constructed --> examples/dcf_mining_pool/src/main.rs:62:8 | 62 | struct Coordinator { | ^^^^^^^^^^^
associated function `from_block` is never used: examples/dcf_mining_pool/src/main.rs#L33
warning: associated function `from_block` is never used --> examples/dcf_mining_pool/src/main.rs:33:8 | 32 | impl BlockNotes { | --------------- associated function in this implementation 33 | fn from_block(block: Block) -> BlockNotes { | ^^^^^^^^^^
field `participated` is never read: examples/dcf_mining_pool/src/main.rs#L29
warning: field `participated` is never read --> examples/dcf_mining_pool/src/main.rs:29:5 | 26 | struct BlockNotes { | ---------- field in this struct ... 29 | participated: Option<bool>, | ^^^^^^^^^^^^ | = note: `#[warn(dead_code)]` on by default
unused doc comment: examples/dcf_mining_pool/src/main.rs#L186
warning: unused doc comment --> examples/dcf_mining_pool/src/main.rs:186:13 | 186 | /// all of the payments needing to be sent | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 187 | participants, | ------------ rustdoc does not generate documentation for expression fields | = help: use `//` for a plain comment = note: `#[warn(unused_doc_comments)]` on by default
use of deprecated associated function `sapio_bitcoin::util::bip32::ExtendedPubKey::from_private`: use ExtendedPubKey::from_priv: ctv_emulators/src/bin/main.rs#L24
warning: use of deprecated associated function `sapio_bitcoin::util::bip32::ExtendedPubKey::from_private`: use ExtendedPubKey::from_priv --> ctv_emulators/src/bin/main.rs:24:35 | 24 | let pk_root = ExtendedPubKey::from_private(&Secp256k1::new(), &root); | ^^^^^^^^^^^^ | = note: `#[warn(deprecated)]` on by default
writing `&Vec` instead of `&[_]` involves a new object where a slice will do: sapio-psbt/src/lib.rs#L219
warning: writing `&Vec` instead of `&[_]` involves a new object where a slice will do --> sapio-psbt/src/lib.rs:219:27 | 219 | fingerprints_map: &'a Vec<(Fingerprint, &'a ExtendedPrivKey)>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `&'a [(Fingerprint, &'a ExtendedPrivKey)]` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#ptr_arg
writing `&Vec` instead of `&[_]` involves a new object where a slice will do: sapio-psbt/src/lib.rs#L188
warning: writing `&Vec` instead of `&[_]` involves a new object where a slice will do --> sapio-psbt/src/lib.rs:188:27 | 188 | fingerprints_map: &Vec<(Fingerprint, &ExtendedPrivKey)>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `&[(Fingerprint, &ExtendedPrivKey)]` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#ptr_arg = note: `#[warn(clippy::ptr_arg)]` on by default
use of deprecated associated function `sapio_bitcoin::sapio_secp256k1::Message::from_slice`: use from_digest_slice instead: sapio-psbt/src/lib.rs#L283
warning: use of deprecated associated function `sapio_bitcoin::sapio_secp256k1::Message::from_slice`: use from_digest_slice instead --> sapio-psbt/src/lib.rs:283:44 | 283 | let msg = bitcoin::secp256k1::Message::from_slice(&sighash[..]).expect("Size must be correct."); | ^^^^^^^^^^ | = note: `#[warn(deprecated)]` on by default
casting to the same type is unnecessary (`usize` -> `usize`): ctv_emulators/src/msgs.rs#L46
warning: casting to the same type is unnecessary (`usize` -> `usize`) --> ctv_emulators/src/msgs.rs:46:42 | 46 | || de::Error::invalid_length(self.0 as usize, &"Expected at least 4 bytes."); | ^^^^^^^^^^^^^^^ help: try: `self.0` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast = note: `#[warn(clippy::unnecessary_cast)]` on by default
name `PSBT` contains a capitalized acronym: ctv_emulators/src/msgs.rs#L20
warning: name `PSBT` contains a capitalized acronym --> ctv_emulators/src/msgs.rs:20:12 | 20 | pub struct PSBT(pub PartiallySignedTransaction); | ^^^^ help: consider making the acronym lowercase, except the initial letter: `Psbt` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#upper_case_acronyms = note: `#[warn(clippy::upper_case_acronyms)]` on by default
constant `MAX_MSG` is never used: ctv_emulators/src/lib.rs#L27
warning: constant `MAX_MSG` is never used --> ctv_emulators/src/lib.rs:27:7 | 27 | const MAX_MSG: usize = 1_000_000; | ^^^^^^^ | = note: `#[warn(dead_code)]` on by default
use of deprecated associated function `sapio_bitcoin::sapio_secp256k1::Message::from_slice`: use from_digest_slice instead: ctv_emulators/src/servers/hd.rs#L98
warning: use of deprecated associated function `sapio_bitcoin::sapio_secp256k1::Message::from_slice`: use from_digest_slice instead --> ctv_emulators/src/servers/hd.rs:98:52 | 98 | let msg = bitcoin::secp256k1::Message::from_slice(&sighash[..]) | ^^^^^^^^^^ | = note: `#[warn(deprecated)]` on by default
returning the result of a `let` binding from a block: sapio/src/util/extended_address.rs#L100
warning: returning the result of a `let` binding from a block --> sapio/src/util/extended_address.rs:100:17 | 99 | let r = d.script_pubkey(); | -------------------------- unnecessary `let` binding 100 | r | ^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_and_return help: return the expression directly | 99 ~ 100 ~ d.script_pubkey() |
you should consider adding a `Default` implementation for `AmountRange`: sapio/src/util/amountrange.rs#L78
warning: you should consider adding a `Default` implementation for `AmountRange` --> sapio/src/util/amountrange.rs:78:5 | 78 | / pub fn new() -> AmountRange { 79 | | AmountRange { 80 | | min: None, 81 | | max: None, 82 | | } 83 | | } | |_____^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default help: try adding this | 76 + impl Default for AmountRange { 77 + fn default() -> Self { 78 + Self::new() 79 + } 80 + } |
you should consider adding a `Default` implementation for `TemplateMetadata`: sapio/src/template/mod.rs#L49
warning: you should consider adding a `Default` implementation for `TemplateMetadata` --> sapio/src/template/mod.rs:49:5 | 49 | / pub fn new() -> Self { 50 | | TemplateMetadata { 51 | | simp: BTreeMap::new(), 52 | | color: None, ... | 55 | | } 56 | | } | |_____^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default = note: `#[warn(clippy::new_without_default)]` on by default help: try adding this | 43 + impl Default for TemplateMetadata { 44 + fn default() -> Self { 45 + Self::new() 46 + } 47 + } |
use of a fallible conversion when an infallible one could be used: sapio/src/template/builder.rs#L230
warning: use of a fallible conversion when an infallible one could be used --> sapio/src/template/builder.rs:230:27 | 230 | let default_seq = RelTime::try_from(0).unwrap().into(); | ^^^^^^^^^^^^^^^^^ help: use: `From::from` | = note: converting `u16` to `LockTime<Rel, MTP>` cannot fail = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_fallible_conversions = note: `#[warn(clippy::unnecessary_fallible_conversions)]` on by default
returning the result of a `let` binding from a block: sapio/src/template/builder.rs#L261
warning: returning the result of a `let` binding from a block --> sapio/src/template/builder.rs:261:9 | 255 | / let t = bitcoin::Transaction { 256 | | version: self.version, 257 | | lock_time: self.lock_time.unwrap_or(default_nlt).get(), 258 | | input, 259 | | output, 260 | | }; | |__________- unnecessary `let` binding 261 | t | ^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_and_return help: return the expression directly | 255 ~ 256 ~ bitcoin::Transaction { 257 + version: self.version, 258 + lock_time: self.lock_time.unwrap_or(default_nlt).get(), 259 + input, 260 + output, 261 + } |
this `impl` can be derived: sapio/src/template/output.rs#L42
warning: this `impl` can be derived --> sapio/src/template/output.rs:42:1 | 42 | / impl Default for OutputMeta { 43 | | fn default() -> Self { 44 | | OutputMeta { 45 | | extra: Default::default(), ... | 48 | | } 49 | | } | |_^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#derivable_impls = help: remove the manual implementation... help: ...and instead derive it | 13 + #[derive(Default)] 14 | pub struct OutputMeta { |
this `impl` can be derived: sapio/src/template/input.rs#L56
warning: this `impl` can be derived --> sapio/src/template/input.rs:56:1 | 56 | / impl Default for InputMetadata { 57 | | fn default() -> Self { 58 | | InputMetadata { 59 | | extra: Default::default(), ... | 62 | | } 63 | | } | |_^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#derivable_impls = note: `#[warn(clippy::derivable_impls)]` on by default = help: remove the manual implementation... help: ...and instead derive it | 13 + #[derive(Default)] 14 | pub struct InputMetadata { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L190
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:190:22 | 190 | fn ensure_amount<'a>(&'a self, ctx: Context) -> Result<Amount, CompilationError> { | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 190 - fn ensure_amount<'a>(&'a self, ctx: Context) -> Result<Amount, CompilationError> { 190 + fn ensure_amount(&self, ctx: Context) -> Result<Amount, CompilationError> { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L187
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:187:17 | 187 | fn metadata<'a>(&'a self, ctx: Context) -> Result<ObjectMetadata, CompilationError> { | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 187 - fn metadata<'a>(&'a self, ctx: Context) -> Result<ObjectMetadata, CompilationError> { 187 + fn metadata(&self, ctx: Context) -> Result<ObjectMetadata, CompilationError> { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L183
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:183:22 | 183 | fn get_inner_ref<'a>(&'a self) -> &Self::Ref { | ^^ ^^ ^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 183 - fn get_inner_ref<'a>(&'a self) -> &Self::Ref { 183 + fn get_inner_ref(&self) -> &Self::Ref { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L180
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:180:19 | 180 | fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<Self::Ref>>] { | ^^ ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 180 - fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<Self::Ref>>] { 180 + fn finish_fns(&self) -> &[fn() -> Option<actions::Guard<Self::Ref>>] { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L174
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:174:22 | 174 | fn finish_or_fns<'a>( | ^^ 175 | &'a self, | ^^ 176 | ) -> &'a [fn() -> Option<Box<dyn actions::CallableAsFoF<Self::Ref, Self::StatefulArguments>>>] | ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 174 ~ fn finish_or_fns( 175 ~ &self, 176 ~ ) -> &[fn() -> Option<Box<dyn actions::CallableAsFoF<Self::Ref, Self::StatefulArguments>>>] |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L154
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:154:22 | 154 | fn ensure_amount<'a>(&'a self, ctx: Context) -> Result<Amount, CompilationError>; | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 154 - fn ensure_amount<'a>(&'a self, ctx: Context) -> Result<Amount, CompilationError>; 154 + fn ensure_amount(&self, ctx: Context) -> Result<Amount, CompilationError>; |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L152
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:152:17 | 152 | fn metadata<'a>(&'a self, ctx: Context) -> Result<ObjectMetadata, CompilationError>; | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 152 - fn metadata<'a>(&'a self, ctx: Context) -> Result<ObjectMetadata, CompilationError>; 152 + fn metadata(&self, ctx: Context) -> Result<ObjectMetadata, CompilationError>; |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L150
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:150:22 | 150 | fn get_inner_ref<'a>(&'a self) -> &'a Self::Ref; | ^^ ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 150 - fn get_inner_ref<'a>(&'a self) -> &'a Self::Ref; 150 + fn get_inner_ref(&self) -> &Self::Ref; |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L148
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:148:19 | 148 | fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<Self::Ref>>]; | ^^ ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 148 - fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<Self::Ref>>]; 148 + fn finish_fns(&self) -> &[fn() -> Option<actions::Guard<Self::Ref>>]; |
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/mod.rs#L148
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/mod.rs:148:36 | 148 | fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<Self::Ref>>]; | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L144
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:144:22 | 144 | fn finish_or_fns<'a>( | ^^ 145 | &'a self, | ^^ 146 | ) -> &'a [fn() -> Option<Box<dyn actions::CallableAsFoF<Self::Ref, Self::StatefulArguments>>>]; | ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 144 ~ fn finish_or_fns( 145 ~ &self, 146 ~ ) -> &[fn() -> Option<Box<dyn actions::CallableAsFoF<Self::Ref, Self::StatefulArguments>>>]; |
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/mod.rs#L146
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/mod.rs:146:10 | 146 | ) -> &'a [fn() -> Option<Box<dyn actions::CallableAsFoF<Self::Ref, Self::StatefulArguments>>>]; | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/mod.rs#L137
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/mod.rs:137:10 | 137 | ) -> &'a [fn() -> Option< | __________^ 138 | | actions::ThenFuncAsFinishOrFunc<'a, Self::Ref, Self::StatefulArguments>, 139 | | >] | |______^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L109
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:109:22 | 109 | fn ensure_amount<'a>(&'a self, ctx: Context) -> Result<Amount, CompilationError> { | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 109 - fn ensure_amount<'a>(&'a self, ctx: Context) -> Result<Amount, CompilationError> { 109 + fn ensure_amount(&self, ctx: Context) -> Result<Amount, CompilationError> { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L105
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:105:17 | 105 | fn metadata<'a>(&'a self, ctx: Context) -> Result<ObjectMetadata, CompilationError> { | ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 105 - fn metadata<'a>(&'a self, ctx: Context) -> Result<ObjectMetadata, CompilationError> { 105 + fn metadata(&self, ctx: Context) -> Result<ObjectMetadata, CompilationError> { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L98
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:98:19 | 98 | fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<S>>] { | ^^ ^^ ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes help: elide the lifetimes | 98 - fn finish_fns<'a>(&'a self) -> &'a [fn() -> Option<actions::Guard<S>>] { 98 + fn finish_fns(&self) -> &[fn() -> Option<actions::Guard<S>>] { |
the following explicit lifetimes could be elided: 'a: sapio/src/contract/mod.rs#L93
warning: the following explicit lifetimes could be elided: 'a --> sapio/src/contract/mod.rs:93:22 | 93 | fn finish_or_fns<'a>( | ^^ 94 | &'a self, | ^^ 95 | ) -> &'a [fn() -> Option<Box<dyn actions::CallableAsFoF<S, Self::StatefulArguments>>>] { | ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes = note: `#[warn(clippy::needless_lifetimes)]` on by default help: elide the lifetimes | 93 ~ fn finish_or_fns( 94 ~ &self, 95 ~ ) -> &[fn() -> Option<Box<dyn actions::CallableAsFoF<S, Self::StatefulArguments>>>] { |
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/mod.rs#L73
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/mod.rs:73:26 | 73 | pub ensure_amount_f: Box<dyn (Fn(&S, Context) -> Result<Amount, CompilationError>)>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/mod.rs#L71
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/mod.rs:71:21 | 71 | pub metadata_f: Box<dyn (Fn(&S, Context) -> Result<ObjectMetadata, CompilationError>)>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/mod.rs#L67
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/mod.rs:67:20 | 67 | pub finish_or: Vec<fn() -> Option<Box<dyn actions::CallableAsFoF<S, T>>>>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/mod.rs#L65
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/mod.rs:65:15 | 65 | pub then: Vec<fn() -> Option<actions::ThenFuncAsFinishOrFunc<'a, S, T>>>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#type_complexity
this lifetime isn't used in the function definition: sapio/src/contract/context.rs#L71
warning: this lifetime isn't used in the function definition --> sapio/src/contract/context.rs:71:23 | 71 | pub fn derive_str<'a>(&mut self, path: Arc<String>) -> Result<Self, CompilationError> { | ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#extra_unused_lifetimes
unsafe function's docs miss `# Safety` section: sapio/src/contract/context.rs#L58
warning: unsafe function's docs miss `# Safety` section --> sapio/src/contract/context.rs:58:5 | 58 | pub unsafe fn get_effects_internal(&self) -> &Arc<MapEffectDB> { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#missing_safety_doc = note: `#[warn(clippy::missing_safety_doc)]` on by default
returning the result of a `let` binding from a block: sapio/src/contract/compiler/mod.rs#L406
warning: returning the result of a `let` binding from a block --> sapio/src/contract/compiler/mod.rs:406:13 | 402 | / let r = Ok(txtmpl_clauses 403 | | .into_iter() 404 | | .map(|policy| policy.compile().map_err(Into::<CompilationError>::into)) 405 | | .collect::<Result<Vec<_>, _>>()?); | |__________________________________________________- unnecessary `let` binding 406 | r | ^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_and_return help: return the expression directly | 402 ~ 403 ~ Ok(txtmpl_clauses 404 + .into_iter() 405 + .map(|policy| policy.compile().map_err(Into::<CompilationError>::into)) 406 + .collect::<Result<Vec<_>, _>>()?) |
explicit call to `.into_iter()` in function argument accepting `IntoIterator`: sapio/src/contract/compiler/mod.rs#L324
warning: explicit call to `.into_iter()` in function argument accepting `IntoIterator` --> sapio/src/contract/compiler/mod.rs:324:24 | 324 | .chain(clause_accumulator.into_iter()) | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider removing the `.into_iter()`: `clause_accumulator` | note: this parameter accepts any `IntoIterator`, so you don't need to call `.into_iter()` --> /rustc/714b29a17ff5fa727c794bbb60bfd335f8e75d42/library/core/src/iter/traits/iterator.rs:524:12 = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_conversion = note: `#[warn(clippy::useless_conversion)]` on by default
returning the result of a `let` binding from a block: sapio/src/contract/compiler/mod.rs#L272
warning: returning the result of a `let` binding from a block --> sapio/src/contract/compiler/mod.rs:272:21 | 267 | / let r = ( 268 | | None, 269 | | combine_txtmpls(nullability, txtmpl_clauses, guards)?, 270 | | guard_metadata, 271 | | ); | |______________________- unnecessary `let` binding 272 | r | ^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_and_return = note: `#[warn(clippy::let_and_return)]` on by default help: return the expression directly | 267 ~ 268 ~ ( 269 + None, 270 + combine_txtmpls(nullability, txtmpl_clauses, guards)?, 271 + guard_metadata, 272 + ) |
this lifetime isn't used in the impl: sapio/src/contract/compiler/mod.rs#L47
warning: this lifetime isn't used in the impl --> sapio/src/contract/compiler/mod.rs:47:10 | 47 | impl<'a, C> ImplSeal for C where C: super::AnyContract {} | ^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#extra_unused_lifetimes = note: `#[warn(clippy::extra_unused_lifetimes)]` on by default
very complex type used. Consider factoring parts into `type` definitions: sapio/src/contract/actions/finish.rs#L30
warning: very complex type used. Consider factoring parts into `type` definitions --> sapio/src/contract/actions/finish.rs:30:19 | 30 | pub simp_gen: Option< | ___________________^ 31 | | fn( 32 | | &ContractSelf, 33 | | Context, ... | 36 | | -> Result<Vec<Box<dyn SIMPAttachableAt<ContinuationPointLT>>>, CompilationError>, 37 | | >, | |_____^ | = 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
use of `default` to create a unit struct: sapio/src/contract/actions/then.rs#L61
warning: use of `default` to create a unit struct --> sapio/src/contract/actions/then.rs:61:27 | 61 | f: PhantomData::default(), | ^^^^^^^^^^^ help: remove this call to `default` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#default_constructed_unit_structs = note: `#[warn(clippy::default_constructed_unit_structs)]` on by default
usage of `Iterator::fold` on a type that implements `Try`: sapio/src/contract/abi/object/mod.rs#L85
warning: usage of `Iterator::fold` on a type that implements `Try` --> sapio/src/contract/abi/object/mod.rs:85:39 | 85 | v.into_iter().fold( | _______________________________________^ 86 | | Ok(Default::default()), 87 | | |ra: Result<BTreeMap<_, Vec<Value>>, CompilationError>, b| { 88 | | let mut a = ra?; ... | 93 | | }, 94 | | )?, | |_________________________^ help: use `try_fold` instead: `try_fold(Default::default(), |ra: Result<BTreeMap<_, Vec<Value>>, CompilationError>, b| ...)` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_try_fold = note: `#[warn(clippy::manual_try_fold)]` on by default
field assignment outside of initializer for an instance created with Default::default(): sapio/src/contract/abi/object/bind.rs#L51
warning: field assignment outside of initializer for an instance created with Default::default() --> sapio/src/contract/abi/object/bind.rs:51:9 | 51 | mock_out.vout = 0; | ^^^^^^^^^^^^^^^^^^ | note: consider initializing the variable with `sapio_bitcoin::OutPoint { vout: 0, ..Default::default() }` and removing relevant reassignments --> sapio/src/contract/abi/object/bind.rs:50:9 | 50 | let mut mock_out = OutPoint::default(); | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#field_reassign_with_default = note: `#[warn(clippy::field_reassign_with_default)]` on by default
unused import: `SIMP`: sapio/src/template/output.rs#L9
warning: unused import: `SIMP` --> sapio/src/template/output.rs:9:53 | 9 | use sapio_base::simp::{SIMPError, TemplateOutputLT, SIMP}; | ^^^^
unused import: `SIMP`: sapio/src/contract/abi/continuation.rs#L10
warning: unused import: `SIMP` --> sapio/src/contract/abi/continuation.rs:10:53 | 10 | use sapio_base::simp::{SIMPAttachableAt, SIMPError, SIMP}; | ^^^^ | = note: `#[warn(unused_imports)]` on by default
use of deprecated method `sapio_bitcoin::Transaction::get_weight`: Please use `transaction::weight` instead.: sapio/src/contract/compiler/mod.rs#L342
warning: use of deprecated method `sapio_bitcoin::Transaction::get_weight`: Please use `transaction::weight` instead. --> sapio/src/contract/compiler/mod.rs:342:32 | 342 | let tx_size = a.tx.get_weight() + estimated_max_size; | ^^^^^^^^^^ | = note: `#[warn(deprecated)]` on by default
private item shadows public glob re-export: sapio-base/src/effects/mod.rs#L9
warning: private item shadows public glob re-export --> sapio-base/src/effects/mod.rs:9:5 | 9 | use crate::reverse_path::ReversePath; | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | note: the name `ReversePath` in the type namespace is supposed to be publicly re-exported here --> sapio-base/src/effects/mod.rs:19:9 | 19 | pub use reverse_path::*; | ^^^^^^^^^^^^^^^ note: but the private item here shadows it --> sapio-base/src/effects/mod.rs:9:5 | 9 | use crate::reverse_path::ReversePath; | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ = note: `#[warn(hidden_glob_reexports)]` on by default