Replace a bunch of from_ffi with as_wstr calls

from_ffi copies a CxxWString into a new Rust WString, but as_wstr simply
gets the slice of chars directly.

Too many string types!
This commit is contained in:
ridiculousfish 2023-04-16 12:50:53 -07:00
parent 971d257e67
commit ead329db60
7 changed files with 26 additions and 35 deletions

View file

@ -4,11 +4,8 @@ use std::{
sync::{Arc, Mutex, MutexGuard},
};
use crate::wchar::{wstr, WString};
use crate::{
wchar::L,
wchar_ffi::{WCharFromFFI, WCharToFFI},
};
use crate::wchar::{wstr, WString, L};
use crate::wchar_ffi::{AsWstr, WCharFromFFI, WCharToFFI};
use cxx::CxxWString;
use once_cell::sync::Lazy;
@ -353,14 +350,14 @@ impl AbbreviationSet {
/// \return the list of replacers for an input token, in priority order, using the global set.
/// The \p position is given to describe where the token was found.
fn abbrs_match_ffi(token: &CxxWString, position: abbrs_position_t) -> Vec<abbrs_replacer_t> {
with_abbrs(|set| set.r#match(&token.from_ffi(), position.into()))
with_abbrs(|set| set.r#match(token.as_wstr(), position.into()))
.into_iter()
.map(|r| r.into())
.collect()
}
fn abbrs_has_match_ffi(token: &CxxWString, position: abbrs_position_t) -> bool {
with_abbrs(|set| set.has_match(&token.from_ffi(), position.into()))
with_abbrs(|set| set.has_match(token.as_wstr(), position.into()))
}
fn abbrs_list_ffi() -> Vec<abbreviation_t> {
@ -429,7 +426,7 @@ impl<'a> GlobalAbbrs<'a> {
}
fn erase(&mut self, name: &CxxWString) {
self.g.erase(&name.from_ffi());
self.g.erase(name.as_wstr());
}
}
use crate::ffi_tests::add_test;

View file

@ -25,7 +25,7 @@ use crate::tokenizer::{
};
use crate::wchar::{wstr, WString, L};
use crate::wchar_ext::WExt;
use crate::wchar_ffi::{wcharz, wcharz_t, WCharFromFFI, WCharToFFI};
use crate::wchar_ffi::{wcharz, wcharz_t, AsWstr, WCharToFFI};
use crate::wutil::printf::sprintf;
use crate::wutil::wgettext_fmt;
use cxx::{type_id, ExternType};
@ -4387,7 +4387,7 @@ impl Ast {
Box::new(NodeFfi::new(self.top.as_node()))
}
fn dump_ffi(&self, orig: &CxxWString) -> UniquePtr<CxxWString> {
self.dump(&orig.from_ffi()).to_ffi()
self.dump(orig.as_wstr()).to_ffi()
}
}
@ -4398,7 +4398,7 @@ fn ast_parse_ffi(src: &CxxWString, flags: u8, errors: *mut ParseErrorList) -> Bo
Some(unsafe { &*errors }.clone())
};
let ast = Box::new(Ast::parse(
&src.from_ffi(),
&src.as_wstr(),
ParseTreeFlags(flags),
&mut out_errors,
));
@ -4419,7 +4419,7 @@ fn ast_parse_argument_list_ffi(
Some(unsafe { &*errors }.clone())
};
let ast = Box::new(Ast::parse_argument_list(
&src.from_ffi(),
&src.as_wstr(),
ParseTreeFlags(flags),
&mut out_errors,
));
@ -4518,28 +4518,28 @@ impl<'a> NodeFfi<'a> {
self.as_node().source_range()
}
fn source_ffi(&self, orig: &CxxWString) -> UniquePtr<CxxWString> {
self.as_node().source(&orig.from_ffi()).to_ffi()
self.as_node().source(orig.as_wstr()).to_ffi()
}
}
impl Argument {
fn source_ffi(&self, orig: &CxxWString) -> UniquePtr<CxxWString> {
self.source(&orig.from_ffi()).to_ffi()
self.source(orig.as_wstr()).to_ffi()
}
}
impl VariableAssignment {
fn source_ffi(&self, orig: &CxxWString) -> UniquePtr<CxxWString> {
self.source(&orig.from_ffi()).to_ffi()
self.source(orig.as_wstr()).to_ffi()
}
}
impl String_ {
fn source_ffi(&self, orig: &CxxWString) -> UniquePtr<CxxWString> {
self.source(&orig.from_ffi()).to_ffi()
self.source(orig.as_wstr()).to_ffi()
}
}
impl TokenRedirection {
fn source_ffi(&self, orig: &CxxWString) -> UniquePtr<CxxWString> {
self.source(&orig.from_ffi()).to_ffi()
self.source(orig.as_wstr()).to_ffi()
}
}

View file

@ -7,8 +7,7 @@ use crate::builtins::shared::{
use crate::ffi::parser_t;
use crate::ffi::path_get_paths_ffi;
use crate::wchar::{wstr, WString, L};
use crate::wchar_ffi::WCharFromFFI;
use crate::wchar_ffi::WCharToFFI;
use crate::wchar_ffi::{WCharFromFFI, WCharToFFI};
use crate::wgetopt::{wgetopter_t, wopt, woption, woption_argument_t};
use crate::wutil::sprintf;

View file

@ -7,7 +7,7 @@ use crate::{
ffi::parser_t,
path::path_apply_working_directory,
wchar::{wstr, WExt, L},
wchar_ffi::WCharFromFFI,
wchar_ffi::AsWstr,
wgetopt::{wgetopter_t, wopt, woption, woption_argument_t::no_argument},
wutil::{normalize_path, wgettext_fmt, wrealpath},
};
@ -118,7 +118,7 @@ pub fn realpath(
}
} else {
// We need to get the *physical* pwd here.
let realpwd = wrealpath(&parser.vars1().get_pwd_slash().from_ffi());
let realpwd = wrealpath(parser.vars1().get_pwd_slash().as_wstr());
if let Some(realpwd) = realpwd {
let absolute_arg = if arg.starts_with(L!("/")) {

View file

@ -908,7 +908,7 @@ pub fn print(streams: &mut io_streams_t, type_filter: &wstr) {
fn event_print_ffi(streams: Pin<&mut ffi::io_streams_t>, type_filter: &CxxWString) {
let mut streams = io_streams_t::new(streams);
print(&mut streams, &type_filter.from_ffi());
print(&mut streams, type_filter.as_wstr());
}
/// Fire a generic event with the specified name.

View file

@ -3,7 +3,7 @@
use crate::ffi::{fish_wcswidth, fish_wcwidth, wcharz_t};
use crate::tokenizer::variable_assignment_equals_pos;
use crate::wchar::{wstr, WString, L};
use crate::wchar_ffi::{wcharz, WCharFromFFI, WCharToFFI};
use crate::wchar_ffi::{wcharz, AsWstr, WCharFromFFI, WCharToFFI};
use crate::wutil::{sprintf, wgettext_fmt};
use cxx::{type_id, ExternType};
use cxx::{CxxWString, UniquePtr};
@ -565,7 +565,7 @@ impl ParseError {
src: &CxxWString,
is_interactive: bool,
) -> UniquePtr<CxxWString> {
self.describe(&src.from_ffi(), is_interactive).to_ffi()
self.describe(src.as_wstr(), is_interactive).to_ffi()
}
fn describe_with_prefix_ffi(
@ -575,12 +575,7 @@ impl ParseError {
is_interactive: bool,
skip_caret: bool,
) -> UniquePtr<CxxWString> {
self.describe_with_prefix(
&src.from_ffi(),
&prefix.from_ffi(),
is_interactive,
skip_caret,
)
self.describe_with_prefix(src.as_wstr(), prefix.as_wstr(), is_interactive, skip_caret)
.to_ffi()
}
}

View file

@ -7,7 +7,7 @@ use crate::future_feature_flags::{feature_test, FeatureFlag};
use crate::parse_constants::SOURCE_OFFSET_INVALID;
use crate::redirection::RedirectionMode;
use crate::wchar::{wstr, WExt, WString, L};
use crate::wchar_ffi::{wchar_t, WCharFromFFI, WCharToFFI};
use crate::wchar_ffi::{wchar_t, AsWstr, WCharToFFI};
use crate::wutil::wgettext;
use cxx::{CxxWString, SharedPtr, UniquePtr};
use libc::{c_int, STDIN_FILENO, STDOUT_FILENO};
@ -283,7 +283,7 @@ impl Tok {
&str[self.offset as usize..(self.offset + self.length) as usize]
}
fn get_source_ffi(self: &Tok, str: &CxxWString) -> UniquePtr<CxxWString> {
self.get_source(&str.from_ffi()).to_ffi()
self.get_source(str.as_wstr()).to_ffi()
}
}
@ -941,7 +941,7 @@ pub fn tok_command(str: &wstr) -> WString {
WString::new()
}
fn tok_command_ffi(str: &CxxWString) -> UniquePtr<CxxWString> {
tok_command(&str.from_ffi()).to_ffi()
tok_command(str.as_wstr()).to_ffi()
}
impl TryFrom<&wstr> for PipeOrRedir {
@ -1381,7 +1381,7 @@ pub fn variable_assignment_equals_pos(txt: &wstr) -> Option<usize> {
}
fn variable_assignment_equals_pos_ffi(txt: &CxxWString) -> SharedPtr<usize> {
match variable_assignment_equals_pos(&txt.from_ffi()) {
match variable_assignment_equals_pos(txt.as_wstr()) {
Some(p) => SharedPtr::new(p),
None => SharedPtr::null(),
}