mirror of
https://github.com/uutils/coreutils
synced 2025-01-07 10:49:09 +00:00
Merge pull request #5494 from Statheres/fix/clippy-implicit-clone
Fix clippy::implicit_clone
This commit is contained in:
commit
7f5b6b0d20
25 changed files with 46 additions and 67 deletions
2
.github/workflows/code-quality.yml
vendored
2
.github/workflows/code-quality.yml
vendored
|
@ -117,7 +117,7 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
## `cargo clippy` lint testing
|
## `cargo clippy` lint testing
|
||||||
unset fault
|
unset fault
|
||||||
CLIPPY_FLAGS="-W clippy::default_trait_access -W clippy::manual_string_new -W clippy::cognitive_complexity"
|
CLIPPY_FLAGS="-W clippy::default_trait_access -W clippy::manual_string_new -W clippy::cognitive_complexity -W clippy::implicit_clone"
|
||||||
fault_type="${{ steps.vars.outputs.FAULT_TYPE }}"
|
fault_type="${{ steps.vars.outputs.FAULT_TYPE }}"
|
||||||
fault_prefix=$(echo "$fault_type" | tr '[:lower:]' '[:upper:]')
|
fault_prefix=$(echo "$fault_type" | tr '[:lower:]' '[:upper:]')
|
||||||
# * convert any warnings to GHA UI annotations; ref: <https://help.github.com/en/actions/reference/workflow-commands-for-github-actions#setting-a-warning-message>
|
# * convert any warnings to GHA UI annotations; ref: <https://help.github.com/en/actions/reference/workflow-commands-for-github-actions#setting-a-warning-message>
|
||||||
|
|
|
@ -54,7 +54,7 @@ impl Config {
|
||||||
format!("{}: No such file or directory", name.maybe_quote()),
|
format!("{}: No such file or directory", name.maybe_quote()),
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
Some(name.to_owned())
|
Some(name.clone())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None => None,
|
None => None,
|
||||||
|
|
|
@ -213,7 +213,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
|
|
||||||
let squeeze_blank = matches.get_flag(options::SQUEEZE_BLANK);
|
let squeeze_blank = matches.get_flag(options::SQUEEZE_BLANK);
|
||||||
let files: Vec<String> = match matches.get_many::<String>(options::FILE) {
|
let files: Vec<String> = match matches.get_many::<String>(options::FILE) {
|
||||||
Some(v) => v.clone().map(|v| v.to_owned()).collect(),
|
Some(v) => v.cloned().collect(),
|
||||||
None => vec!["-".to_owned()],
|
None => vec!["-".to_owned()],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -62,15 +62,9 @@ impl CsplitOptions {
|
||||||
split_name: crash_if_err!(
|
split_name: crash_if_err!(
|
||||||
1,
|
1,
|
||||||
SplitName::new(
|
SplitName::new(
|
||||||
matches
|
matches.get_one::<String>(options::PREFIX).cloned(),
|
||||||
.get_one::<String>(options::PREFIX)
|
matches.get_one::<String>(options::SUFFIX_FORMAT).cloned(),
|
||||||
.map(|s| s.to_owned()),
|
matches.get_one::<String>(options::DIGITS).cloned()
|
||||||
matches
|
|
||||||
.get_one::<String>(options::SUFFIX_FORMAT)
|
|
||||||
.map(|s| s.to_owned()),
|
|
||||||
matches
|
|
||||||
.get_one::<String>(options::DIGITS)
|
|
||||||
.map(|s| s.to_owned())
|
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
keep_files,
|
keep_files,
|
||||||
|
|
|
@ -400,7 +400,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
if s.is_empty() {
|
if s.is_empty() {
|
||||||
Some("\0".to_owned())
|
Some("\0".to_owned())
|
||||||
} else {
|
} else {
|
||||||
Some(s.to_owned())
|
Some(s.clone())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None => None,
|
None => None,
|
||||||
|
@ -491,7 +491,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let files: Vec<String> = matches
|
let files: Vec<String> = matches
|
||||||
.get_many::<String>(options::FILE)
|
.get_many::<String>(options::FILE)
|
||||||
.unwrap_or_default()
|
.unwrap_or_default()
|
||||||
.map(|s| s.to_owned())
|
.cloned()
|
||||||
.collect();
|
.collect();
|
||||||
|
|
||||||
match mode_parse {
|
match mode_parse {
|
||||||
|
|
|
@ -30,7 +30,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let dirnames: Vec<String> = matches
|
let dirnames: Vec<String> = matches
|
||||||
.get_many::<String>(options::DIR)
|
.get_many::<String>(options::DIR)
|
||||||
.unwrap_or_default()
|
.unwrap_or_default()
|
||||||
.map(|s| s.to_owned())
|
.cloned()
|
||||||
.collect();
|
.collect();
|
||||||
|
|
||||||
if dirnames.is_empty() {
|
if dirnames.is_empty() {
|
||||||
|
|
|
@ -506,7 +506,7 @@ fn build_exclude_patterns(matches: &ArgMatches) -> UResult<Vec<Pattern>> {
|
||||||
let excludes_iterator = matches
|
let excludes_iterator = matches
|
||||||
.get_many::<String>(options::EXCLUDE)
|
.get_many::<String>(options::EXCLUDE)
|
||||||
.unwrap_or_default()
|
.unwrap_or_default()
|
||||||
.map(|v| v.to_owned());
|
.cloned();
|
||||||
|
|
||||||
let mut exclude_patterns = Vec::new();
|
let mut exclude_patterns = Vec::new();
|
||||||
for f in excludes_iterator.chain(exclude_from_iterator) {
|
for f in excludes_iterator.chain(exclude_from_iterator) {
|
||||||
|
|
|
@ -35,7 +35,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let bytes = matches.get_flag(options::BYTES);
|
let bytes = matches.get_flag(options::BYTES);
|
||||||
let spaces = matches.get_flag(options::SPACES);
|
let spaces = matches.get_flag(options::SPACES);
|
||||||
let poss_width = match matches.get_one::<String>(options::WIDTH) {
|
let poss_width = match matches.get_one::<String>(options::WIDTH) {
|
||||||
Some(v) => Some(v.to_owned()),
|
Some(v) => Some(v.clone()),
|
||||||
None => obs_width,
|
None => obs_width,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
};
|
};
|
||||||
|
|
||||||
let files = match matches.get_many::<String>(options::FILE) {
|
let files = match matches.get_many::<String>(options::FILE) {
|
||||||
Some(v) => v.map(|v| v.to_owned()).collect(),
|
Some(v) => v.cloned().collect(),
|
||||||
None => vec!["-".to_owned()],
|
None => vec!["-".to_owned()],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -205,7 +205,7 @@ impl HeadOptions {
|
||||||
options.mode = Mode::from(matches)?;
|
options.mode = Mode::from(matches)?;
|
||||||
|
|
||||||
options.files = match matches.get_many::<String>(options::FILES_NAME) {
|
options.files = match matches.get_many::<String>(options::FILES_NAME) {
|
||||||
Some(v) => v.map(|s| s.to_owned()).collect(),
|
Some(v) => v.cloned().collect(),
|
||||||
None => vec!["-".to_owned()],
|
None => vec!["-".to_owned()],
|
||||||
};
|
};
|
||||||
//println!("{:#?}", options);
|
//println!("{:#?}", options);
|
||||||
|
|
|
@ -375,9 +375,7 @@ fn behavior(matches: &ArgMatches) -> UResult<Behavior> {
|
||||||
};
|
};
|
||||||
|
|
||||||
let backup_mode = backup_control::determine_backup_mode(matches)?;
|
let backup_mode = backup_control::determine_backup_mode(matches)?;
|
||||||
let target_dir = matches
|
let target_dir = matches.get_one::<String>(OPT_TARGET_DIRECTORY).cloned();
|
||||||
.get_one::<String>(OPT_TARGET_DIRECTORY)
|
|
||||||
.map(|d| d.to_owned());
|
|
||||||
|
|
||||||
let preserve_timestamps = matches.get_flag(OPT_PRESERVE_TIMESTAMPS);
|
let preserve_timestamps = matches.get_flag(OPT_PRESERVE_TIMESTAMPS);
|
||||||
let compare = matches.get_flag(OPT_COMPARE);
|
let compare = matches.get_flag(OPT_COMPARE);
|
||||||
|
@ -593,7 +591,7 @@ fn standard(mut paths: Vec<String>, b: &Behavior) -> UResult<()> {
|
||||||
let source = sources.first().unwrap();
|
let source = sources.first().unwrap();
|
||||||
|
|
||||||
if source.is_dir() {
|
if source.is_dir() {
|
||||||
return Err(InstallError::OmittingDirectory(source.to_path_buf()).into());
|
return Err(InstallError::OmittingDirectory(source.clone()).into());
|
||||||
}
|
}
|
||||||
|
|
||||||
if target.is_file() || is_new_file_path(&target) {
|
if target.is_file() || is_new_file_path(&target) {
|
||||||
|
@ -628,7 +626,7 @@ fn copy_files_into_dir(files: &[PathBuf], target_dir: &Path, b: &Behavior) -> UR
|
||||||
}
|
}
|
||||||
|
|
||||||
if sourcepath.is_dir() {
|
if sourcepath.is_dir() {
|
||||||
let err = InstallError::OmittingDirectory(sourcepath.to_path_buf());
|
let err = InstallError::OmittingDirectory(sourcepath.clone());
|
||||||
show!(err);
|
show!(err);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -701,12 +699,9 @@ fn perform_backup(to: &Path, b: &Behavior) -> UResult<Option<PathBuf>> {
|
||||||
if let Some(ref backup_path) = backup_path {
|
if let Some(ref backup_path) = backup_path {
|
||||||
// TODO!!
|
// TODO!!
|
||||||
if let Err(err) = fs::rename(to, backup_path) {
|
if let Err(err) = fs::rename(to, backup_path) {
|
||||||
return Err(InstallError::BackupFailed(
|
return Err(
|
||||||
to.to_path_buf(),
|
InstallError::BackupFailed(to.to_path_buf(), backup_path.clone(), err).into(),
|
||||||
backup_path.to_path_buf(),
|
);
|
||||||
err,
|
|
||||||
)
|
|
||||||
.into());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Ok(backup_path)
|
Ok(backup_path)
|
||||||
|
|
|
@ -577,9 +577,7 @@ fn extract_color(options: &clap::ArgMatches) -> bool {
|
||||||
///
|
///
|
||||||
/// A QuotingStyle variant representing the quoting style to use.
|
/// A QuotingStyle variant representing the quoting style to use.
|
||||||
fn extract_quoting_style(options: &clap::ArgMatches, show_control: bool) -> QuotingStyle {
|
fn extract_quoting_style(options: &clap::ArgMatches, show_control: bool) -> QuotingStyle {
|
||||||
let opt_quoting_style = options
|
let opt_quoting_style = options.get_one::<String>(options::QUOTING_STYLE).cloned();
|
||||||
.get_one::<String>(options::QUOTING_STYLE)
|
|
||||||
.map(|cmd_line_qs| cmd_line_qs.to_owned());
|
|
||||||
|
|
||||||
if let Some(style) = opt_quoting_style {
|
if let Some(style) = opt_quoting_style {
|
||||||
match style.as_str() {
|
match style.as_str() {
|
||||||
|
@ -788,9 +786,7 @@ impl Config {
|
||||||
match parse_size_u64(&raw_bs.to_string_lossy()) {
|
match parse_size_u64(&raw_bs.to_string_lossy()) {
|
||||||
Ok(size) => Some(size),
|
Ok(size) => Some(size),
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
show!(LsError::BlockSizeParseError(
|
show!(LsError::BlockSizeParseError(cmd_line_bs.unwrap().clone()));
|
||||||
cmd_line_bs.unwrap().to_owned()
|
|
||||||
));
|
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3056,7 +3052,7 @@ fn display_file_name(
|
||||||
target_data.must_dereference,
|
target_data.must_dereference,
|
||||||
) {
|
) {
|
||||||
Ok(md) => md,
|
Ok(md) => md,
|
||||||
Err(_) => path.md(out).unwrap().to_owned(),
|
Err(_) => path.md(out).unwrap().clone(),
|
||||||
};
|
};
|
||||||
|
|
||||||
name.push_str(&color_name(
|
name.push_str(&color_name(
|
||||||
|
@ -3073,11 +3069,7 @@ fn display_file_name(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
show!(LsError::IOErrorContext(
|
show!(LsError::IOErrorContext(err, path.p_buf.clone(), false));
|
||||||
err,
|
|
||||||
path.p_buf.to_path_buf(),
|
|
||||||
false
|
|
||||||
));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3087,7 +3079,7 @@ fn display_file_name(
|
||||||
if config.context {
|
if config.context {
|
||||||
if let Some(pad_count) = prefix_context {
|
if let Some(pad_count) = prefix_context {
|
||||||
let security_context = if matches!(config.format, Format::Commas) {
|
let security_context = if matches!(config.format, Format::Commas) {
|
||||||
path.security_context.to_owned()
|
path.security_context.clone()
|
||||||
} else {
|
} else {
|
||||||
pad_left(&path.security_context, pad_count)
|
pad_left(&path.security_context, pad_count)
|
||||||
};
|
};
|
||||||
|
|
|
@ -42,7 +42,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
};
|
};
|
||||||
|
|
||||||
let fifos: Vec<String> = match matches.get_many::<String>(options::FIFO) {
|
let fifos: Vec<String> = match matches.get_many::<String>(options::FIFO) {
|
||||||
Some(v) => v.clone().map(|s| s.to_owned()).collect(),
|
Some(v) => v.cloned().collect(),
|
||||||
None => return Err(USimpleError::new(1, "missing operand")),
|
None => return Err(USimpleError::new(1, "missing operand")),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -146,7 +146,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let files: Vec<OsString> = matches
|
let files: Vec<OsString> = matches
|
||||||
.get_many::<OsString>(ARG_FILES)
|
.get_many::<OsString>(ARG_FILES)
|
||||||
.unwrap_or_default()
|
.unwrap_or_default()
|
||||||
.map(|v| v.to_os_string())
|
.cloned()
|
||||||
.collect();
|
.collect();
|
||||||
|
|
||||||
let overwrite_mode = determine_overwrite_mode(&matches);
|
let overwrite_mode = determine_overwrite_mode(&matches);
|
||||||
|
|
|
@ -19,11 +19,11 @@ pub fn parse_options(settings: &mut crate::Settings, opts: &clap::ArgMatches) ->
|
||||||
settings.section_delimiter = if delimiter.len() == 1 {
|
settings.section_delimiter = if delimiter.len() == 1 {
|
||||||
format!("{delimiter}:")
|
format!("{delimiter}:")
|
||||||
} else {
|
} else {
|
||||||
delimiter.to_owned()
|
delimiter.clone()
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
if let Some(val) = opts.get_one::<String>(options::NUMBER_SEPARATOR) {
|
if let Some(val) = opts.get_one::<String>(options::NUMBER_SEPARATOR) {
|
||||||
settings.number_separator = val.to_owned();
|
settings.number_separator = val.clone();
|
||||||
}
|
}
|
||||||
settings.number_format = opts
|
settings.number_format = opts
|
||||||
.get_one::<String>(options::NUMBER_FORMAT)
|
.get_one::<String>(options::NUMBER_FORMAT)
|
||||||
|
|
|
@ -195,7 +195,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
}
|
}
|
||||||
|
|
||||||
let files: Vec<String> = match matches.get_many::<String>(options::FILE) {
|
let files: Vec<String> = match matches.get_many::<String>(options::FILE) {
|
||||||
Some(v) => v.clone().map(|v| v.to_owned()).collect(),
|
Some(v) => v.cloned().collect(),
|
||||||
None => vec!["-".to_owned()],
|
None => vec!["-".to_owned()],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -211,9 +211,7 @@ fn parse_options(args: &ArgMatches) -> Result<NumfmtOptions> {
|
||||||
_ => unreachable!("Should be restricted by clap"),
|
_ => unreachable!("Should be restricted by clap"),
|
||||||
};
|
};
|
||||||
|
|
||||||
let suffix = args
|
let suffix = args.get_one::<String>(options::SUFFIX).cloned();
|
||||||
.get_one::<String>(options::SUFFIX)
|
|
||||||
.map(|s| s.to_owned());
|
|
||||||
|
|
||||||
let invalid =
|
let invalid =
|
||||||
InvalidModes::from_str(args.get_one::<String>(options::INVALID).unwrap()).unwrap();
|
InvalidModes::from_str(args.get_one::<String>(options::INVALID).unwrap()).unwrap();
|
||||||
|
|
|
@ -44,7 +44,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let files = matches
|
let files = matches
|
||||||
.get_many::<String>(options::FILE)
|
.get_many::<String>(options::FILE)
|
||||||
.unwrap()
|
.unwrap()
|
||||||
.map(|s| s.to_owned())
|
.cloned()
|
||||||
.collect();
|
.collect();
|
||||||
let line_ending = LineEnding::from_zero_flag(matches.get_flag(options::ZERO_TERMINATED));
|
let line_ending = LineEnding::from_zero_flag(matches.get_flag(options::ZERO_TERMINATED));
|
||||||
|
|
||||||
|
|
|
@ -720,7 +720,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let matches = uu_app().try_get_matches_from(args)?;
|
let matches = uu_app().try_get_matches_from(args)?;
|
||||||
|
|
||||||
let mut input_files: Vec<String> = match &matches.get_many::<String>(options::FILE) {
|
let mut input_files: Vec<String> = match &matches.get_many::<String>(options::FILE) {
|
||||||
Some(v) => v.clone().map(|v| v.to_owned()).collect(),
|
Some(v) => v.clone().cloned().collect(),
|
||||||
None => vec!["-".to_string()],
|
None => vec!["-".to_string()],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -75,7 +75,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let headcounts = matches
|
let headcounts = matches
|
||||||
.get_many::<String>(options::HEAD_COUNT)
|
.get_many::<String>(options::HEAD_COUNT)
|
||||||
.unwrap_or_default()
|
.unwrap_or_default()
|
||||||
.map(|s| s.to_owned())
|
.cloned()
|
||||||
.collect();
|
.collect();
|
||||||
match parse_head_count(headcounts) {
|
match parse_head_count(headcounts) {
|
||||||
Ok(val) => val,
|
Ok(val) => val,
|
||||||
|
|
|
@ -394,8 +394,8 @@ mod tests {
|
||||||
let (a_info, a_range) = NumInfo::parse(a, &NumInfoParseSettings::default());
|
let (a_info, a_range) = NumInfo::parse(a, &NumInfoParseSettings::default());
|
||||||
let (b_info, b_range) = NumInfo::parse(b, &NumInfoParseSettings::default());
|
let (b_info, b_range) = NumInfo::parse(b, &NumInfoParseSettings::default());
|
||||||
let ordering = numeric_str_cmp(
|
let ordering = numeric_str_cmp(
|
||||||
(&a[a_range.to_owned()], &a_info),
|
(&a[a_range.clone()], &a_info),
|
||||||
(&b[b_range.to_owned()], &b_info),
|
(&b[b_range.clone()], &b_info),
|
||||||
);
|
);
|
||||||
assert_eq!(ordering, expected);
|
assert_eq!(ordering, expected);
|
||||||
let ordering = numeric_str_cmp((&b[b_range], &b_info), (&a[a_range], &a_info));
|
let ordering = numeric_str_cmp((&b[b_range], &b_info), (&a[a_range], &a_info));
|
||||||
|
|
|
@ -506,10 +506,10 @@ impl Settings {
|
||||||
};
|
};
|
||||||
|
|
||||||
let result = Self {
|
let result = Self {
|
||||||
prefix: matches.get_one::<String>(ARG_PREFIX).unwrap().to_owned(),
|
prefix: matches.get_one::<String>(ARG_PREFIX).unwrap().clone(),
|
||||||
suffix,
|
suffix,
|
||||||
input: matches.get_one::<String>(ARG_INPUT).unwrap().to_owned(),
|
input: matches.get_one::<String>(ARG_INPUT).unwrap().clone(),
|
||||||
filter: matches.get_one::<String>(OPT_FILTER).map(|s| s.to_owned()),
|
filter: matches.get_one::<String>(OPT_FILTER).cloned(),
|
||||||
strategy,
|
strategy,
|
||||||
verbose: matches.value_source(OPT_VERBOSE) == Some(ValueSource::CommandLine),
|
verbose: matches.value_source(OPT_VERBOSE) == Some(ValueSource::CommandLine),
|
||||||
separator,
|
separator,
|
||||||
|
|
|
@ -107,7 +107,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let matches = uu_app().try_get_matches_from(args)?;
|
let matches = uu_app().try_get_matches_from(args)?;
|
||||||
|
|
||||||
let files: Vec<String> = match matches.get_many::<String>(options::FILE) {
|
let files: Vec<String> = match matches.get_many::<String>(options::FILE) {
|
||||||
Some(v) => v.clone().map(|v| v.to_owned()).collect(),
|
Some(v) => v.cloned().collect(),
|
||||||
None => vec!["-".to_owned()],
|
None => vec!["-".to_owned()],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ impl FileHandling {
|
||||||
pub fn insert(&mut self, k: &Path, v: PathData, update_last: bool) {
|
pub fn insert(&mut self, k: &Path, v: PathData, update_last: bool) {
|
||||||
let k = Self::canonicalize_path(k);
|
let k = Self::canonicalize_path(k);
|
||||||
if update_last {
|
if update_last {
|
||||||
self.last = Some(k.to_owned());
|
self.last = Some(k.clone());
|
||||||
}
|
}
|
||||||
let _ = self.map.insert(k, v);
|
let _ = self.map.insert(k, v);
|
||||||
}
|
}
|
||||||
|
|
|
@ -279,7 +279,7 @@ impl Observer {
|
||||||
if !path.is_file() {
|
if !path.is_file() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
let mut path = path.to_owned();
|
let mut path = path.clone();
|
||||||
if path.is_relative() {
|
if path.is_relative() {
|
||||||
path = std::env::current_dir()?.join(path);
|
path = std::env::current_dir()?.join(path);
|
||||||
}
|
}
|
||||||
|
@ -345,7 +345,7 @@ impl Observer {
|
||||||
show_error!("{}: file truncated", display_name);
|
show_error!("{}: file truncated", display_name);
|
||||||
self.files.update_reader(event_path)?;
|
self.files.update_reader(event_path)?;
|
||||||
}
|
}
|
||||||
paths.push(event_path.to_owned());
|
paths.push(event_path.clone());
|
||||||
} else if !is_tailable && old_md.is_tailable() {
|
} else if !is_tailable && old_md.is_tailable() {
|
||||||
if pd.reader.is_some() {
|
if pd.reader.is_some() {
|
||||||
self.files.reset_reader(event_path);
|
self.files.reset_reader(event_path);
|
||||||
|
@ -359,7 +359,7 @@ impl Observer {
|
||||||
} else if is_tailable {
|
} else if is_tailable {
|
||||||
show_error!( "{} has appeared; following new file", display_name.quote());
|
show_error!( "{} has appeared; following new file", display_name.quote());
|
||||||
self.files.update_reader(event_path)?;
|
self.files.update_reader(event_path)?;
|
||||||
paths.push(event_path.to_owned());
|
paths.push(event_path.clone());
|
||||||
} else if settings.retry {
|
} else if settings.retry {
|
||||||
if self.follow_descriptor() {
|
if self.follow_descriptor() {
|
||||||
show_error!(
|
show_error!(
|
||||||
|
@ -403,7 +403,7 @@ impl Observer {
|
||||||
"{} cannot be used, reverting to polling",
|
"{} cannot be used, reverting to polling",
|
||||||
text::BACKEND
|
text::BACKEND
|
||||||
);
|
);
|
||||||
self.orphans.push(event_path.to_owned());
|
self.orphans.push(event_path.clone());
|
||||||
let _ = self.watcher_rx.as_mut().unwrap().unwatch(event_path);
|
let _ = self.watcher_rx.as_mut().unwrap().unwatch(event_path);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -451,7 +451,7 @@ impl Observer {
|
||||||
|
|
||||||
if self.follow_descriptor() {
|
if self.follow_descriptor() {
|
||||||
let new_path = event.paths.last().unwrap();
|
let new_path = event.paths.last().unwrap();
|
||||||
paths.push(new_path.to_owned());
|
paths.push(new_path.clone());
|
||||||
|
|
||||||
let new_data = PathData::from_other_with_path(self.files.remove(event_path), new_path);
|
let new_data = PathData::from_other_with_path(self.files.remove(event_path), new_path);
|
||||||
self.files.insert(
|
self.files.insert(
|
||||||
|
|
|
@ -164,7 +164,7 @@ impl Parser {
|
||||||
/// The stream is unchanged and will return the same Symbol on subsequent
|
/// The stream is unchanged and will return the same Symbol on subsequent
|
||||||
/// calls to `next()` or `peek()`.
|
/// calls to `next()` or `peek()`.
|
||||||
fn peek(&mut self) -> Symbol {
|
fn peek(&mut self) -> Symbol {
|
||||||
Symbol::new(self.tokens.peek().map(|s| s.to_os_string()))
|
Symbol::new(self.tokens.peek().cloned())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Test if the next token in the stream is a BOOLOP (-a or -o), without
|
/// Test if the next token in the stream is a BOOLOP (-a or -o), without
|
||||||
|
|
Loading…
Reference in a new issue