Address lints from clippy for beta/nightly (#5709)

* Fix clippy lints in tests

* Replace `format!` in `.push_str()` with `write!`

Stylistically that might be a bit rough but elides an allocation.

Fallibility of allocation is more explicit, but ignored with `let _ =`
like in the clippy example:

https://rust-lang.github.io/rust-clippy/master/index.html#format_push_string

* Remove unused lifetime

* Fix macro crate relative import

* Derive `Eq` for `PartialEq` with `Eq` members

https://rust-lang.github.io/rust-clippy/master/index.html#derive_partial_eq_without_eq

* Remove unnnecessary `.to_string()` for Cow<str>

* Remove `.to_string()` for `tendril::Tendril`

Implements `Deref<Target = str>`
This commit is contained in:
Stefan Holderbach 2022-06-04 08:47:36 +02:00 committed by GitHub
parent a82fa75c31
commit e5d38dcff6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
27 changed files with 81 additions and 71 deletions

View file

@ -1,6 +1,7 @@
use nu_engine::documentation::get_flags_section; use nu_engine::documentation::get_flags_section;
use nu_protocol::{engine::EngineState, levenshtein_distance}; use nu_protocol::{engine::EngineState, levenshtein_distance};
use reedline::{Completer, Suggestion}; use reedline::{Completer, Suggestion};
use std::fmt::Write;
use std::sync::Arc; use std::sync::Arc;
pub struct NuHelpCompleter(Arc<EngineState>); pub struct NuHelpCompleter(Arc<EngineState>);
@ -53,7 +54,7 @@ impl NuHelpCompleter {
long_desc.push_str("\r\n\r\n"); long_desc.push_str("\r\n\r\n");
} }
long_desc.push_str(&format!("Usage:\r\n > {}\r\n", sig.call_signature())); let _ = write!(long_desc, "Usage:\r\n > {}\r\n", sig.call_signature());
if !sig.named.is_empty() { if !sig.named.is_empty() {
long_desc.push_str(&get_flags_section(sig)) long_desc.push_str(&get_flags_section(sig))
@ -65,21 +66,22 @@ impl NuHelpCompleter {
{ {
long_desc.push_str("\r\nParameters:\r\n"); long_desc.push_str("\r\nParameters:\r\n");
for positional in &sig.required_positional { for positional in &sig.required_positional {
long_desc let _ = write!(long_desc, " {}: {}\r\n", positional.name, positional.desc);
.push_str(&format!(" {}: {}\r\n", positional.name, positional.desc));
} }
for positional in &sig.optional_positional { for positional in &sig.optional_positional {
long_desc.push_str(&format!( let _ = write!(
long_desc,
" (optional) {}: {}\r\n", " (optional) {}: {}\r\n",
positional.name, positional.desc positional.name, positional.desc
)); );
} }
if let Some(rest_positional) = &sig.rest_positional { if let Some(rest_positional) = &sig.rest_positional {
long_desc.push_str(&format!( let _ = write!(
long_desc,
" ...{}: {}\r\n", " ...{}: {}\r\n",
rest_positional.name, rest_positional.desc rest_positional.name, rest_positional.desc
)); );
} }
} }

View file

@ -18,7 +18,7 @@ fn variables_completions() {
let mut completer = NuCompleter::new(std::sync::Arc::new(engine), stack); let mut completer = NuCompleter::new(std::sync::Arc::new(engine), stack);
// Test completions for $nu // Test completions for $nu
let suggestions = completer.complete("my-command ".into(), 11); let suggestions = completer.complete("my-command ", 11);
assert_eq!(3, suggestions.len()); assert_eq!(3, suggestions.len());

View file

@ -12,7 +12,7 @@ fn flag_completions() {
// Instatiate a new completer // Instatiate a new completer
let mut completer = NuCompleter::new(std::sync::Arc::new(engine), stack); let mut completer = NuCompleter::new(std::sync::Arc::new(engine), stack);
// Test completions for the 'ls' flags // Test completions for the 'ls' flags
let suggestions = completer.complete("ls -".into(), 4); let suggestions = completer.complete("ls -", 4);
assert_eq!(12, suggestions.len()); assert_eq!(12, suggestions.len());

View file

@ -89,7 +89,7 @@ pub fn merge_input(
dir: PathBuf, dir: PathBuf,
) -> Result<(), ShellError> { ) -> Result<(), ShellError> {
let (block, delta) = { let (block, delta) = {
let mut working_set = StateWorkingSet::new(&engine_state); let mut working_set = StateWorkingSet::new(engine_state);
let (block, err) = parse(&mut working_set, None, input, false, &[]); let (block, err) = parse(&mut working_set, None, input, false, &[]);
@ -98,7 +98,7 @@ pub fn merge_input(
(block, working_set.render()) (block, working_set.render())
}; };
assert!(eval_block( assert!(eval_block(
&engine_state, engine_state,
stack, stack,
&block, &block,
PipelineData::Value( PipelineData::Value(

View file

@ -17,7 +17,7 @@ fn variables_completions() {
let mut completer = NuCompleter::new(std::sync::Arc::new(engine), stack); let mut completer = NuCompleter::new(std::sync::Arc::new(engine), stack);
// Test completions for $nu // Test completions for $nu
let suggestions = completer.complete("$nu.".into(), 4); let suggestions = completer.complete("$nu.", 4);
assert_eq!(8, suggestions.len()); assert_eq!(8, suggestions.len());
@ -36,7 +36,7 @@ fn variables_completions() {
match_suggestions(expected, suggestions); match_suggestions(expected, suggestions);
// Test completions for $nu.h (filter) // Test completions for $nu.h (filter)
let suggestions = completer.complete("$nu.h".into(), 5); let suggestions = completer.complete("$nu.h", 5);
assert_eq!(2, suggestions.len()); assert_eq!(2, suggestions.len());
@ -46,7 +46,7 @@ fn variables_completions() {
match_suggestions(expected, suggestions); match_suggestions(expected, suggestions);
// Test completions for custom var // Test completions for custom var
let suggestions = completer.complete("$actor.".into(), 7); let suggestions = completer.complete("$actor.", 7);
assert_eq!(2, suggestions.len()); assert_eq!(2, suggestions.len());
@ -56,7 +56,7 @@ fn variables_completions() {
match_suggestions(expected, suggestions); match_suggestions(expected, suggestions);
// Test completions for custom var (filtering) // Test completions for custom var (filtering)
let suggestions = completer.complete("$actor.n".into(), 7); let suggestions = completer.complete("$actor.n", 7);
assert_eq!(1, suggestions.len()); assert_eq!(1, suggestions.len());
@ -66,7 +66,7 @@ fn variables_completions() {
match_suggestions(expected, suggestions); match_suggestions(expected, suggestions);
// Test completions for $env // Test completions for $env
let suggestions = completer.complete("$env.".into(), 5); let suggestions = completer.complete("$env.", 5);
assert_eq!(2, suggestions.len()); assert_eq!(2, suggestions.len());
@ -76,7 +76,7 @@ fn variables_completions() {
match_suggestions(expected, suggestions); match_suggestions(expected, suggestions);
// Test completions for $env // Test completions for $env
let suggestions = completer.complete("$env.T".into(), 5); let suggestions = completer.complete("$env.T", 5);
assert_eq!(1, suggestions.len()); assert_eq!(1, suggestions.len());

View file

@ -1,7 +1,7 @@
use nu_ansi_term::{Color, Style}; use nu_ansi_term::{Color, Style};
use serde::Deserialize; use serde::Deserialize;
#[derive(Deserialize, PartialEq, Debug)] #[derive(Deserialize, PartialEq, Eq, Debug)]
pub struct NuStyle { pub struct NuStyle {
pub fg: Option<String>, pub fg: Option<String>,
pub bg: Option<String>, pub bg: Option<String>,

View file

@ -12,7 +12,7 @@ pub struct Base64Config {
pub action_type: ActionType, pub action_type: ActionType,
} }
#[derive(Clone, Copy, PartialEq)] #[derive(Clone, Copy, PartialEq, Eq)]
pub enum ActionType { pub enum ActionType {
Encode, Encode,
Decode, Decode,

View file

@ -87,7 +87,7 @@ fn exec(
redirect_stderr: false, redirect_stderr: false,
}; };
let mut command = external_command.spawn_simple_command(&cwd.to_string_lossy().to_string())?; let mut command = external_command.spawn_simple_command(&cwd.to_string_lossy())?;
command.current_dir(current_dir); command.current_dir(current_dir);
let err = command.exec(); // this replaces our process, should not return let err = command.exec(); // this replaces our process, should not return

View file

@ -428,7 +428,7 @@ pub fn extension_is_one_of(path: &Path, choices: &[&str]) -> bool {
// choices.contains(&&name[..]) // choices.contains(&&name[..])
// } // }
#[derive(Debug, Default, PartialEq)] #[derive(Debug, Default, PartialEq, Eq)]
pub struct FileExtensions; pub struct FileExtensions;
// TODO: We may want to re-add these FileExtensions impl fns back. I have disabled // TODO: We may want to re-add these FileExtensions impl fns back. I have disabled

View file

@ -3,6 +3,7 @@ use nu_protocol::{
engine::{EngineState, Stack}, engine::{EngineState, Stack},
Example, IntoPipelineData, Signature, Span, Value, Example, IntoPipelineData, Signature, Span, Value,
}; };
use std::fmt::Write;
pub fn get_full_help( pub fn get_full_help(
sig: &Signature, sig: &Signature,
@ -62,13 +63,14 @@ fn get_documentation(
} }
if !sig.search_terms.is_empty() { if !sig.search_terms.is_empty() {
long_desc.push_str(&format!( let _ = write!(
long_desc,
"Search terms: {}\n\n", "Search terms: {}\n\n",
sig.search_terms.join(", ") sig.search_terms.join(", ")
)); );
} }
long_desc.push_str(&format!("Usage:\n > {}\n", sig.call_signature())); let _ = write!(long_desc, "Usage:\n > {}\n", sig.call_signature());
if !subcommands.is_empty() { if !subcommands.is_empty() {
long_desc.push_str("\nSubcommands:\n"); long_desc.push_str("\nSubcommands:\n");
@ -87,23 +89,26 @@ fn get_documentation(
{ {
long_desc.push_str("\nParameters:\n"); long_desc.push_str("\nParameters:\n");
for positional in &sig.required_positional { for positional in &sig.required_positional {
long_desc.push_str(&format!( let _ = writeln!(
" {} <{:?}>: {}\n", long_desc,
" {} <{:?}>: {}",
positional.name, positional.shape, positional.desc positional.name, positional.shape, positional.desc
)); );
} }
for positional in &sig.optional_positional { for positional in &sig.optional_positional {
long_desc.push_str(&format!( let _ = writeln!(
" (optional) {} <{:?}>: {}\n", long_desc,
" (optional) {} <{:?}>: {}",
positional.name, positional.shape, positional.desc positional.name, positional.shape, positional.desc
)); );
} }
if let Some(rest_positional) = &sig.rest_positional { if let Some(rest_positional) = &sig.rest_positional {
long_desc.push_str(&format!( let _ = writeln!(
" ...{} <{:?}>: {}\n", long_desc,
" ...{} <{:?}>: {}",
rest_positional.name, rest_positional.shape, rest_positional.desc rest_positional.name, rest_positional.shape, rest_positional.desc
)); );
} }
} }
@ -117,7 +122,7 @@ fn get_documentation(
long_desc.push_str(example.description); long_desc.push_str(example.description);
if config.no_color { if config.no_color {
long_desc.push_str(&format!("\n > {}\n", example.example)); let _ = write!(long_desc, "\n > {}\n", example.example);
} else if let Some(highlighter) = engine_state.find_decl(b"nu-highlight", &[]) { } else if let Some(highlighter) = engine_state.find_decl(b"nu-highlight", &[]) {
let decl = engine_state.get_decl(highlighter); let decl = engine_state.get_decl(highlighter);
@ -135,19 +140,19 @@ fn get_documentation(
let result = output.into_value(Span { start: 0, end: 0 }); let result = output.into_value(Span { start: 0, end: 0 });
match result.as_string() { match result.as_string() {
Ok(s) => { Ok(s) => {
long_desc.push_str(&format!("\n > {}\n", s)); let _ = write!(long_desc, "\n > {}\n", s);
} }
_ => { _ => {
long_desc.push_str(&format!("\n > {}\n", example.example)); let _ = write!(long_desc, "\n > {}\n", example.example);
} }
} }
} }
Err(_) => { Err(_) => {
long_desc.push_str(&format!("\n > {}\n", example.example)); let _ = write!(long_desc, "\n > {}\n", example.example);
} }
} }
} else { } else {
long_desc.push_str(&format!("\n > {}\n", example.example)); let _ = write!(long_desc, "\n > {}\n", example.example);
} }
} }

View file

@ -1108,7 +1108,7 @@ pub fn create_scope(
if !alias_text.is_empty() { if !alias_text.is_empty() {
alias_text.push(' '); alias_text.push(' ');
} }
alias_text.push_str(&String::from_utf8_lossy(contents).to_string()); alias_text.push_str(&String::from_utf8_lossy(contents));
} }
aliases.push(( aliases.push((
Value::String { Value::String {

View file

@ -518,7 +518,7 @@ enum PatternToken {
} }
#[allow(clippy::enum_variant_names)] #[allow(clippy::enum_variant_names)]
#[derive(Copy, Clone, PartialEq)] #[derive(Copy, Clone, PartialEq, Eq)]
enum MatchResult { enum MatchResult {
Match, Match,
SubPatternDoesntMatch, SubPatternDoesntMatch,

View file

@ -13,7 +13,7 @@ use serde::de;
use serde::ser; use serde::ser;
/// The errors that can arise while parsing a JSON stream. /// The errors that can arise while parsing a JSON stream.
#[derive(Clone, PartialEq)] #[derive(Clone, PartialEq, Eq)]
pub enum ErrorCode { pub enum ErrorCode {
/// Catchall for syntax error messages /// Catchall for syntax error messages
Custom(String), Custom(String),

View file

@ -974,7 +974,7 @@ struct VariantDeserializer {
val: Option<Value>, val: Option<Value>,
} }
impl<'de, 'a> de::VariantAccess<'de> for VariantDeserializer { impl<'de> de::VariantAccess<'de> for VariantDeserializer {
type Error = Error; type Error = Error;
fn unit_variant(self) -> Result<()> { fn unit_variant(self) -> Result<()> {
@ -1062,7 +1062,7 @@ struct MapDeserializer {
value: Option<Value>, value: Option<Value>,
} }
impl<'de, 'a> de::MapAccess<'de> for MapDeserializer { impl<'de> de::MapAccess<'de> for MapDeserializer {
type Error = Error; type Error = Error;
fn next_key_seed<K>(&mut self, seed: K) -> Result<Option<K::Value>> fn next_key_seed<K>(&mut self, seed: K) -> Result<Option<K::Value>>

View file

@ -156,10 +156,7 @@ pub fn parse_binary_with_invalid_octal_format() {
assert!(block.len() == 1); assert!(block.len() == 1);
let expressions = &block[0]; let expressions = &block[0];
assert!(expressions.len() == 1); assert!(expressions.len() == 1);
assert!(match &expressions[0].expr { assert!(!matches!(&expressions[0].expr, Expr::Binary(_)))
Expr::Binary(_) => false,
_ => true,
})
} }
#[test] #[test]

View file

@ -2278,7 +2278,7 @@ pub mod signature {
} }
#[repr(u16)] #[repr(u16)]
#[derive(Clone, Copy, Debug, PartialEq)] #[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum Category { pub enum Category {
Default = 0, Default = 0,
Conversions = 1, Conversions = 1,
@ -2841,7 +2841,7 @@ pub mod argument {
} }
#[repr(u16)] #[repr(u16)]
#[derive(Clone, Copy, Debug, PartialEq)] #[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum Shape { pub enum Shape {
None = 0, None = 0,
Any = 1, Any = 1,

View file

@ -18,7 +18,7 @@ pub enum PluginCall {
CallInfo(Box<CallInfo>), CallInfo(Box<CallInfo>),
} }
#[derive(Clone, PartialEq, Serialize, Deserialize, Debug)] #[derive(Clone, PartialEq, Eq, Serialize, Deserialize, Debug)]
pub struct LabeledError { pub struct LabeledError {
pub label: String, pub label: String,
pub msg: String, pub msg: String,

View file

@ -1,6 +1,7 @@
use super::Expression; use super::Expression;
use crate::Span; use crate::Span;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use std::fmt::Write;
#[derive(Debug, Clone, PartialOrd, Serialize, Deserialize)] #[derive(Debug, Clone, PartialOrd, Serialize, Deserialize)]
pub enum PathMember { pub enum PathMember {
@ -32,7 +33,9 @@ impl CellPath {
output.push('.'); output.push('.');
} }
match elem { match elem {
PathMember::Int { val, .. } => output.push_str(&format!("{}", val)), PathMember::Int { val, .. } => {
let _ = write!(output, "{}", val);
}
PathMember::String { val, .. } => output.push_str(val), PathMember::String { val, .. } => output.push_str(val),
} }
} }

View file

@ -3,21 +3,21 @@ use serde::{Deserialize, Serialize};
use crate::{span, ModuleId, Span}; use crate::{span, ModuleId, Span};
use std::collections::HashSet; use std::collections::HashSet;
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
pub enum ImportPatternMember { pub enum ImportPatternMember {
Glob { span: Span }, Glob { span: Span },
Name { name: Vec<u8>, span: Span }, Name { name: Vec<u8>, span: Span },
List { names: Vec<(Vec<u8>, Span)> }, List { names: Vec<(Vec<u8>, Span)> },
} }
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
pub struct ImportPatternHead { pub struct ImportPatternHead {
pub name: Vec<u8>, pub name: Vec<u8>,
pub id: Option<ModuleId>, pub id: Option<ModuleId>,
pub span: Span, pub span: Span,
} }
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
pub struct ImportPattern { pub struct ImportPattern {
pub head: ImportPatternHead, pub head: ImportPatternHead,
pub members: Vec<ImportPatternMember>, pub members: Vec<ImportPatternMember>,

View file

@ -54,13 +54,13 @@ impl Display for Operator {
} }
} }
#[derive(Debug, Copy, Clone, PartialEq, PartialOrd, Serialize, Deserialize)] #[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Serialize, Deserialize)]
pub enum RangeInclusion { pub enum RangeInclusion {
Inclusive, Inclusive,
RightExclusive, RightExclusive,
} }
#[derive(Debug, Copy, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Copy, Clone, PartialEq, Eq, Serialize, Deserialize)]
pub struct RangeOperator { pub struct RangeOperator {
pub inclusion: RangeInclusion, pub inclusion: RangeInclusion,
pub span: Span, pub span: Span,

View file

@ -11,6 +11,7 @@ use crate::PipelineData;
use crate::ShellError; use crate::ShellError;
use crate::SyntaxShape; use crate::SyntaxShape;
use crate::VarId; use crate::VarId;
use std::fmt::Write;
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
pub struct Flag { pub struct Flag {
@ -36,7 +37,7 @@ pub struct PositionalArg {
pub default_value: Option<Expression>, pub default_value: Option<Expression>,
} }
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
pub enum Category { pub enum Category {
Default, Default,
Conversions, Conversions,
@ -345,7 +346,7 @@ impl Signature {
} }
if let Some(rest) = &self.rest_positional { if let Some(rest) = &self.rest_positional {
one_liner.push_str(&format!("...{}", get_positional_short_name(rest, false))); let _ = write!(one_liner, "...{}", get_positional_short_name(rest, false));
} }
// if !self.subcommands.is_empty() { // if !self.subcommands.is_empty() {

View file

@ -1,6 +1,6 @@
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
#[derive(Debug, Clone, Copy, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, Copy, PartialEq, Eq, Serialize, Deserialize)]
pub enum Unit { pub enum Unit {
// Filesize units: metric // Filesize units: metric
Byte, Byte,

View file

@ -138,7 +138,7 @@ pub enum Alignment {
/// The easiest way to create a Cell is just by using `string.into()`, which /// The easiest way to create a Cell is just by using `string.into()`, which
/// uses the **unicode width** of the string (see the `unicode_width` crate). /// uses the **unicode width** of the string (see the `unicode_width` crate).
/// However, the fields are public, if you wish to provide your own length. /// However, the fields are public, if you wish to provide your own length.
#[derive(PartialEq, Debug, Clone)] #[derive(PartialEq, Eq, Debug, Clone)]
pub struct Cell { pub struct Cell {
/// The string to display when this cell gets rendered. /// The string to display when this cell gets rendered.
pub contents: String, pub contents: String,
@ -171,7 +171,7 @@ impl<'a> From<&'a str> for Cell {
} }
/// Direction cells should be written in — either across, or downwards. /// Direction cells should be written in — either across, or downwards.
#[derive(PartialEq, Debug, Copy, Clone)] #[derive(PartialEq, Eq, Debug, Copy, Clone)]
pub enum Direction { pub enum Direction {
/// Starts at the top left and moves rightwards, going back to the first /// Starts at the top left and moves rightwards, going back to the first
/// column for a new row, like a typewriter. /// column for a new row, like a typewriter.
@ -187,7 +187,7 @@ pub type Width = usize;
/// The text to put in between each pair of columns. /// The text to put in between each pair of columns.
/// This does not include any spaces used when aligning cells. /// This does not include any spaces used when aligning cells.
#[derive(PartialEq, Debug)] #[derive(PartialEq, Eq, Debug)]
pub enum Filling { pub enum Filling {
/// A certain number of spaces should be used as the separator. /// A certain number of spaces should be used as the separator.
Spaces(Width), Spaces(Width),
@ -208,7 +208,7 @@ impl Filling {
/// The user-assignable options for a grid view that should be passed to /// The user-assignable options for a grid view that should be passed to
/// [`Grid::new()`](struct.Grid.html#method.new). /// [`Grid::new()`](struct.Grid.html#method.new).
#[derive(PartialEq, Debug)] #[derive(PartialEq, Eq, Debug)]
pub struct GridOptions { pub struct GridOptions {
/// The direction that the cells should be written in — either /// The direction that the cells should be written in — either
/// across, or downwards. /// across, or downwards.
@ -218,7 +218,7 @@ pub struct GridOptions {
pub filling: Filling, pub filling: Filling,
} }
#[derive(PartialEq, Debug)] #[derive(PartialEq, Eq, Debug)]
struct Dimensions { struct Dimensions {
/// The number of lines in the grid. /// The number of lines in the grid.
num_lines: Width, num_lines: Width,

View file

@ -121,7 +121,7 @@ macro_rules! nu_with_plugins {
pub use std::error::Error; pub use std::error::Error;
pub use std::io::prelude::*; pub use std::io::prelude::*;
pub use std::process::{Command, Stdio}; pub use std::process::{Command, Stdio};
pub use crate::NATIVE_PATH_ENV_VAR; pub use $crate::NATIVE_PATH_ENV_VAR;
let commands = &*format!( let commands = &*format!(
" "

View file

@ -2,6 +2,7 @@ use super::nu_process::*;
use super::EnvironmentVariable; use super::EnvironmentVariable;
use std::ffi::OsString; use std::ffi::OsString;
use std::fmt; use std::fmt;
use std::fmt::Write;
#[derive(Default, Debug)] #[derive(Default, Debug)]
pub struct Director { pub struct Director {
@ -94,7 +95,7 @@ impl Executable for Director {
if !commands.is_empty() { if !commands.is_empty() {
commands.push_str("| "); commands.push_str("| ");
} }
commands.push_str(&format!("{}\n", pipeline)); let _ = writeln!(commands, "{}", pipeline);
} }
} }

View file

@ -4,6 +4,7 @@ use crate::query_xml::execute_xpath_query;
use nu_engine::documentation::get_flags_section; use nu_engine::documentation::get_flags_section;
use nu_plugin::{EvaluatedCall, LabeledError, Plugin}; use nu_plugin::{EvaluatedCall, LabeledError, Plugin};
use nu_protocol::{Signature, Spanned, Value}; use nu_protocol::{Signature, Spanned, Value};
use std::fmt::Write;
#[derive(Default)] #[derive(Default)]
pub struct Query; pub struct Query;
@ -59,15 +60,15 @@ impl Query {
pub fn get_brief_subcommand_help(sigs: &[Signature]) -> String { pub fn get_brief_subcommand_help(sigs: &[Signature]) -> String {
let mut help = String::new(); let mut help = String::new();
help.push_str(&format!("{}\n\n", sigs[0].usage)); let _ = write!(help, "{}\n\n", sigs[0].usage);
help.push_str(&format!("Usage:\n > {}\n\n", sigs[0].name)); let _ = write!(help, "Usage:\n > {}\n\n", sigs[0].name);
help.push_str("Subcommands:\n"); help.push_str("Subcommands:\n");
for x in sigs.iter().enumerate() { for x in sigs.iter().enumerate() {
if x.0 == 0 { if x.0 == 0 {
continue; continue;
} }
help.push_str(&format!(" {} - {}\n", x.1.name, x.1.usage)); let _ = writeln!(help, " {} - {}", x.1.name, x.1.usage);
} }
help.push_str(&get_flags_section(&sigs[0])); help.push_str(&get_flags_section(&sigs[0]));

View file

@ -294,7 +294,7 @@ fn cell_content(element: ElementRef) -> String {
let frag = Html::parse_fragment(&element); let frag = Html::parse_fragment(&element);
for node in frag.tree { for node in frag.tree {
if let scraper::node::Node::Text(text) = node { if let scraper::node::Node::Text(text) = node {
dehtmlize.push_str(&text.text.to_string()) dehtmlize.push_str(&text.text)
} }
} }
@ -314,7 +314,7 @@ fn contains_str(slice: &[String], item: &str) -> bool {
let frag = Html::parse_fragment(item); let frag = Html::parse_fragment(item);
for node in frag.tree { for node in frag.tree {
if let scraper::node::Node::Text(text) = node { if let scraper::node::Node::Text(text) = node {
dehtmlized.push_str(&text.text.to_string()); dehtmlized.push_str(&text.text);
} }
} }