mirror of
https://github.com/nushell/nushell
synced 2025-01-14 06:04:09 +00:00
Use nightly clippy to kill dead code/fix style (#12334)
- **Remove duplicated imports** - **Remove unused field in `CompletionOptions`** - **Remove unused struct in `nu-table`** - **Clarify generic bounds** - **Simplify a subtrait bound for `ExactSizeIterator`** - **Use `unwrap_or_default`** - **Use `Option` directly instead of empty string** - **Elide unneeded clone in `to html`**
This commit is contained in:
parent
ff2aba7ae3
commit
e889679d42
17 changed files with 46 additions and 84 deletions
|
@ -95,7 +95,6 @@ impl std::error::Error for InvalidMatchAlgorithm {}
|
||||||
pub struct CompletionOptions {
|
pub struct CompletionOptions {
|
||||||
pub case_sensitive: bool,
|
pub case_sensitive: bool,
|
||||||
pub positional: bool,
|
pub positional: bool,
|
||||||
pub sort_by: SortBy,
|
|
||||||
pub match_algorithm: MatchAlgorithm,
|
pub match_algorithm: MatchAlgorithm,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,7 +103,6 @@ impl Default for CompletionOptions {
|
||||||
Self {
|
Self {
|
||||||
case_sensitive: true,
|
case_sensitive: true,
|
||||||
positional: true,
|
positional: true,
|
||||||
sort_by: SortBy::Ascending,
|
|
||||||
match_algorithm: MatchAlgorithm::Prefix,
|
match_algorithm: MatchAlgorithm::Prefix,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -108,11 +108,6 @@ impl Completer for CustomCompletion {
|
||||||
.get("positional")
|
.get("positional")
|
||||||
.and_then(|val| val.as_bool().ok())
|
.and_then(|val| val.as_bool().ok())
|
||||||
.unwrap_or(true),
|
.unwrap_or(true),
|
||||||
sort_by: if should_sort {
|
|
||||||
SortBy::Ascending
|
|
||||||
} else {
|
|
||||||
SortBy::None
|
|
||||||
},
|
|
||||||
match_algorithm: match options.get("completion_algorithm") {
|
match_algorithm: match options.get("completion_algorithm") {
|
||||||
Some(option) => option
|
Some(option) => option
|
||||||
.coerce_string()
|
.coerce_string()
|
||||||
|
|
|
@ -680,10 +680,9 @@ fn run_regexes(hash: &HashMap<u32, (&'static str, String)>, contents: &str) -> S
|
||||||
let hash_count: u32 = hash.len() as u32;
|
let hash_count: u32 = hash.len() as u32;
|
||||||
for n in 0..hash_count {
|
for n in 0..hash_count {
|
||||||
let value = hash.get(&n).expect("error getting hash at index");
|
let value = hash.get(&n).expect("error getting hash at index");
|
||||||
//println!("{},{}", value.0, value.1);
|
|
||||||
let re = Regex::new(value.0).expect("problem with color regex");
|
let re = Regex::new(value.0).expect("problem with color regex");
|
||||||
let after = re.replace_all(&working_string, &value.1[..]).to_string();
|
let after = re.replace_all(&working_string, &value.1[..]).to_string();
|
||||||
working_string = after.clone();
|
working_string = after;
|
||||||
}
|
}
|
||||||
working_string
|
working_string
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use nu_engine::command_prelude::*;
|
use nu_engine::command_prelude::*;
|
||||||
use nu_protocol::ast::{CellPath, PathMember};
|
use nu_protocol::ast::PathMember;
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct IntoCellPath;
|
pub struct IntoCellPath;
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
use nu_engine::command_prelude::*;
|
use nu_engine::command_prelude::*;
|
||||||
use nu_parser::{parse_unit_value, DURATION_UNIT_GROUPS};
|
use nu_parser::{parse_unit_value, DURATION_UNIT_GROUPS};
|
||||||
use nu_protocol::{
|
use nu_protocol::{ast::Expr, Unit};
|
||||||
ast::{CellPath, Expr},
|
|
||||||
Unit,
|
|
||||||
};
|
|
||||||
|
|
||||||
const NS_PER_SEC: i64 = 1_000_000_000;
|
const NS_PER_SEC: i64 = 1_000_000_000;
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
|
|
@ -1,7 +1,4 @@
|
||||||
use crate::{
|
use crate::*;
|
||||||
help::{HelpAliases, HelpCommands, HelpEscapes, HelpExterns, HelpModules, HelpOperators},
|
|
||||||
*,
|
|
||||||
};
|
|
||||||
use nu_protocol::engine::{EngineState, StateWorkingSet};
|
use nu_protocol::engine::{EngineState, StateWorkingSet};
|
||||||
|
|
||||||
pub fn add_shell_command_context(mut engine_state: EngineState) -> EngineState {
|
pub fn add_shell_command_context(mut engine_state: EngineState) -> EngineState {
|
||||||
|
|
|
@ -6,9 +6,6 @@ use std::{io::BufReader, path::Path};
|
||||||
#[cfg(feature = "sqlite")]
|
#[cfg(feature = "sqlite")]
|
||||||
use crate::database::SQLiteDatabase;
|
use crate::database::SQLiteDatabase;
|
||||||
|
|
||||||
#[cfg(feature = "sqlite")]
|
|
||||||
use nu_protocol::IntoPipelineData;
|
|
||||||
|
|
||||||
#[cfg(unix)]
|
#[cfg(unix)]
|
||||||
use std::os::unix::fs::PermissionsExt;
|
use std::os::unix::fs::PermissionsExt;
|
||||||
|
|
||||||
|
|
|
@ -368,10 +368,9 @@ fn find_with_rest_and_highlight(
|
||||||
let highlight_style =
|
let highlight_style =
|
||||||
style_computer.compute("search_result", &Value::string("search result", span));
|
style_computer.compute("search_result", &Value::string("search result", span));
|
||||||
|
|
||||||
let cols_to_search_in_map = match call.get_flag(&engine_state, stack, "columns")? {
|
let cols_to_search_in_map: Vec<_> = call
|
||||||
Some(cols) => cols,
|
.get_flag(&engine_state, stack, "columns")?
|
||||||
None => vec![],
|
.unwrap_or_default();
|
||||||
};
|
|
||||||
|
|
||||||
let cols_to_search_in_filter = cols_to_search_in_map.clone();
|
let cols_to_search_in_filter = cols_to_search_in_map.clone();
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
use nu_engine::command_prelude::*;
|
use nu_engine::command_prelude::*;
|
||||||
|
|
||||||
use std::convert::TryInto;
|
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct Skip;
|
pub struct Skip;
|
||||||
|
|
||||||
|
|
|
@ -85,24 +85,22 @@ impl Command for StorDelete {
|
||||||
let db = Box::new(SQLiteDatabase::new(std::path::Path::new(MEMORY_DB), None));
|
let db = Box::new(SQLiteDatabase::new(std::path::Path::new(MEMORY_DB), None));
|
||||||
|
|
||||||
if let Some(new_table_name) = table_name_opt {
|
if let Some(new_table_name) = table_name_opt {
|
||||||
let where_clause = match where_clause_opt {
|
|
||||||
Some(where_stmt) => where_stmt,
|
|
||||||
None => String::new(),
|
|
||||||
};
|
|
||||||
|
|
||||||
if let Ok(conn) = db.open_connection() {
|
if let Ok(conn) = db.open_connection() {
|
||||||
let sql_stmt = if where_clause.is_empty() {
|
let sql_stmt = match where_clause_opt {
|
||||||
// We're deleting an entire table
|
None => {
|
||||||
format!("DROP TABLE {}", new_table_name)
|
// We're deleting an entire table
|
||||||
} else {
|
format!("DROP TABLE {}", new_table_name)
|
||||||
// We're just deleting some rows
|
}
|
||||||
let mut delete_stmt = format!("DELETE FROM {} ", new_table_name);
|
Some(where_clause) => {
|
||||||
|
// We're just deleting some rows
|
||||||
|
let mut delete_stmt = format!("DELETE FROM {} ", new_table_name);
|
||||||
|
|
||||||
// Yup, this is a bit janky, but I'm not sure a better way to do this without having
|
// Yup, this is a bit janky, but I'm not sure a better way to do this without having
|
||||||
// --and and --or flags as well as supporting ==, !=, <>, is null, is not null, etc.
|
// --and and --or flags as well as supporting ==, !=, <>, is null, is not null, etc.
|
||||||
// and other sql syntax. So, for now, just type a sql where clause as a string.
|
// and other sql syntax. So, for now, just type a sql where clause as a string.
|
||||||
delete_stmt.push_str(&format!("WHERE {}", where_clause));
|
delete_stmt.push_str(&format!("WHERE {}", where_clause));
|
||||||
delete_stmt
|
delete_stmt
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// dbg!(&sql_stmt);
|
// dbg!(&sql_stmt);
|
||||||
|
|
|
@ -919,7 +919,7 @@ fn get_abbriviated_dummy(head: &[Value], tail: &VecDeque<Value>) -> Value {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_record_list<'a>(mut batch: impl Iterator<Item = &'a Value> + ExactSizeIterator) -> bool {
|
fn is_record_list<'a>(mut batch: impl ExactSizeIterator<Item = &'a Value>) -> bool {
|
||||||
batch.len() > 0 && batch.all(|value| matches!(value, Value::Record { .. }))
|
batch.len() > 0 && batch.all(|value| matches!(value, Value::Record { .. }))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -318,9 +318,9 @@ where
|
||||||
type Ok = ();
|
type Ok = ();
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn serialize_element<T: ?Sized>(&mut self, value: &T) -> Result<()>
|
fn serialize_element<T>(&mut self, value: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
self.ser
|
self.ser
|
||||||
.formatter
|
.formatter
|
||||||
|
@ -345,9 +345,9 @@ where
|
||||||
type Ok = ();
|
type Ok = ();
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn serialize_element<T: ?Sized>(&mut self, value: &T) -> Result<()>
|
fn serialize_element<T>(&mut self, value: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
ser::SerializeSeq::serialize_element(self, value)
|
ser::SerializeSeq::serialize_element(self, value)
|
||||||
}
|
}
|
||||||
|
@ -365,9 +365,9 @@ where
|
||||||
type Ok = ();
|
type Ok = ();
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn serialize_field<T: ?Sized>(&mut self, value: &T) -> Result<()>
|
fn serialize_field<T>(&mut self, value: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
ser::SerializeSeq::serialize_element(self, value)
|
ser::SerializeSeq::serialize_element(self, value)
|
||||||
}
|
}
|
||||||
|
@ -385,9 +385,9 @@ where
|
||||||
type Ok = ();
|
type Ok = ();
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn serialize_field<T: ?Sized>(&mut self, value: &T) -> Result<()>
|
fn serialize_field<T>(&mut self, value: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
ser::SerializeSeq::serialize_element(self, value)
|
ser::SerializeSeq::serialize_element(self, value)
|
||||||
}
|
}
|
||||||
|
@ -409,9 +409,9 @@ where
|
||||||
type Ok = ();
|
type Ok = ();
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn serialize_key<T: ?Sized>(&mut self, key: &T) -> Result<()>
|
fn serialize_key<T>(&mut self, key: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
self.ser
|
self.ser
|
||||||
.formatter
|
.formatter
|
||||||
|
@ -423,9 +423,9 @@ where
|
||||||
self.ser.formatter.colon(&mut self.ser.writer)
|
self.ser.formatter.colon(&mut self.ser.writer)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn serialize_value<T: ?Sized>(&mut self, value: &T) -> Result<()>
|
fn serialize_value<T>(&mut self, value: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
value.serialize(&mut *self.ser)
|
value.serialize(&mut *self.ser)
|
||||||
}
|
}
|
||||||
|
@ -446,9 +446,9 @@ where
|
||||||
type Ok = ();
|
type Ok = ();
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn serialize_field<T: ?Sized>(&mut self, key: &'static str, value: &T) -> Result<()>
|
fn serialize_field<T>(&mut self, key: &'static str, value: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
ser::SerializeMap::serialize_entry(self, key, value)
|
ser::SerializeMap::serialize_entry(self, key, value)
|
||||||
}
|
}
|
||||||
|
@ -466,9 +466,9 @@ where
|
||||||
type Ok = ();
|
type Ok = ();
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn serialize_field<T: ?Sized>(&mut self, key: &'static str, value: &T) -> Result<()>
|
fn serialize_field<T>(&mut self, key: &'static str, value: &T) -> Result<()>
|
||||||
where
|
where
|
||||||
T: serde::Serialize,
|
T: serde::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
ser::SerializeStruct::serialize_field(self, key, value)
|
ser::SerializeStruct::serialize_field(self, key, value)
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
use std::collections::{btree_map, BTreeMap};
|
use std::collections::{btree_map, BTreeMap};
|
||||||
|
|
||||||
#[cfg(feature = "preserve_order")]
|
#[cfg(feature = "preserve_order")]
|
||||||
use linked_hash_map::{self, LinkedHashMap};
|
use linked_hash_map::LinkedHashMap;
|
||||||
|
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
use std::io;
|
use std::io;
|
||||||
|
@ -1094,9 +1094,9 @@ impl<'de> de::MapAccess<'de> for MapDeserializer {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn to_value<T: ?Sized>(value: &T) -> Result<Value>
|
pub fn to_value<T>(value: &T) -> Result<Value>
|
||||||
where
|
where
|
||||||
T: ser::Serialize,
|
T: ser::Serialize + ?Sized,
|
||||||
{
|
{
|
||||||
value.serialize(Serializer)
|
value.serialize(Serializer)
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,6 @@ use crate::{
|
||||||
lex::{lex, lex_signature},
|
lex::{lex, lex_signature},
|
||||||
lite_parser::{lite_parse, LiteCommand, LitePipeline, LiteRedirection, LiteRedirectionTarget},
|
lite_parser::{lite_parse, LiteCommand, LitePipeline, LiteRedirection, LiteRedirectionTarget},
|
||||||
parse_keywords::*,
|
parse_keywords::*,
|
||||||
parse_mut,
|
|
||||||
parse_patterns::parse_pattern,
|
parse_patterns::parse_pattern,
|
||||||
parse_shape_specs::{parse_shape_name, parse_type, ShapeDescriptorUse},
|
parse_shape_specs::{parse_shape_name, parse_type, ShapeDescriptorUse},
|
||||||
type_check::{self, math_result_type, type_compatible},
|
type_check::{self, math_result_type, type_compatible},
|
||||||
|
@ -13,8 +12,8 @@ use log::trace;
|
||||||
use nu_engine::DIR_VAR_PARSER_INFO;
|
use nu_engine::DIR_VAR_PARSER_INFO;
|
||||||
use nu_protocol::{
|
use nu_protocol::{
|
||||||
ast::*, engine::StateWorkingSet, eval_const::eval_constant, span, BlockId, DidYouMean, Flag,
|
ast::*, engine::StateWorkingSet, eval_const::eval_constant, span, BlockId, DidYouMean, Flag,
|
||||||
ParseError, PositionalArg, Signature, Span, Spanned, SyntaxShape, Type, Unit, VarId,
|
ParseError, PositionalArg, Signature, Span, Spanned, SyntaxShape, Type, VarId, ENV_VARIABLE_ID,
|
||||||
ENV_VARIABLE_ID, IN_VARIABLE_ID,
|
IN_VARIABLE_ID,
|
||||||
};
|
};
|
||||||
use std::{
|
use std::{
|
||||||
collections::{HashMap, HashSet},
|
collections::{HashMap, HashSet},
|
||||||
|
@ -23,9 +22,6 @@ use std::{
|
||||||
sync::Arc,
|
sync::Arc,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(feature = "plugin")]
|
|
||||||
use crate::parse_keywords::parse_register;
|
|
||||||
|
|
||||||
pub fn garbage(span: Span) -> Expression {
|
pub fn garbage(span: Span) -> Expression {
|
||||||
Expression::garbage(span)
|
Expression::garbage(span)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
use core::primitive::str;
|
use core::fmt;
|
||||||
use core::{default::Default, fmt};
|
|
||||||
use nu_ansi_term::{Color, Style};
|
use nu_ansi_term::{Color, Style};
|
||||||
|
|
||||||
/// Returns a one-line hexdump of `source` grouped in default format without header
|
/// Returns a one-line hexdump of `source` grouped in default format without header
|
||||||
|
|
|
@ -595,14 +595,14 @@ impl PipelineData {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Simplified flatmapper. For full iterator support use `.into_iter()` instead
|
/// Simplified flatmapper. For full iterator support use `.into_iter()` instead
|
||||||
pub fn flat_map<U: 'static, F>(
|
pub fn flat_map<U, F>(
|
||||||
self,
|
self,
|
||||||
mut f: F,
|
mut f: F,
|
||||||
ctrlc: Option<Arc<AtomicBool>>,
|
ctrlc: Option<Arc<AtomicBool>>,
|
||||||
) -> Result<PipelineData, ShellError>
|
) -> Result<PipelineData, ShellError>
|
||||||
where
|
where
|
||||||
Self: Sized,
|
Self: Sized,
|
||||||
U: IntoIterator<Item = Value>,
|
U: IntoIterator<Item = Value> + 'static,
|
||||||
<U as IntoIterator>::IntoIter: 'static + Send,
|
<U as IntoIterator>::IntoIter: 'static + Send,
|
||||||
F: FnMut(Value) -> U + 'static + Send,
|
F: FnMut(Value) -> U + 'static + Send,
|
||||||
{
|
{
|
||||||
|
|
|
@ -457,17 +457,6 @@ fn load_theme(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct FooterStyle;
|
|
||||||
|
|
||||||
impl<R: ExactRecords, D> TableOption<R, D, ColoredConfig> for FooterStyle {
|
|
||||||
fn change(self, records: &mut R, cfg: &mut ColoredConfig, _: &mut D) {
|
|
||||||
if let Some(line) = cfg.get_horizontal_line(1).cloned() {
|
|
||||||
let count_rows = records.count_rows();
|
|
||||||
cfg.insert_horizontal_line(count_rows - 1, line);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn maybe_truncate_columns(
|
fn maybe_truncate_columns(
|
||||||
data: &mut NuRecords,
|
data: &mut NuRecords,
|
||||||
theme: &TableTheme,
|
theme: &TableTheme,
|
||||||
|
|
Loading…
Reference in a new issue