Rename compat.rs to libc.rs

Matches Rust convention better.
This commit is contained in:
Johannes Altmanninger 2024-01-07 19:18:15 +01:00
parent e110d4c672
commit f7c9753c4b
20 changed files with 25 additions and 25 deletions

View file

@ -46,9 +46,9 @@ fn main() {
rsconf::link_libraries(&curses_libnames, LinkType::Default); rsconf::link_libraries(&curses_libnames, LinkType::Default);
cc::Build::new() cc::Build::new()
.file("fish-rust/src/compat.c") .file("fish-rust/src/libc.c")
.include(&build_dir) .include(&build_dir)
.compile("libcompat.a"); .compile("flibc.a");
if compiles("fish-rust/src/cfg/w_exitcode.cpp") { if compiles("fish-rust/src/cfg/w_exitcode.cpp") {
println!("cargo:rustc-cfg=HAVE_WAITSTATUS_SIGNAL_RET"); println!("cargo:rustc-cfg=HAVE_WAITSTATUS_SIGNAL_RET");

View file

@ -9,11 +9,11 @@ use crate::common::unescape_string;
use crate::common::valid_var_name; use crate::common::valid_var_name;
use crate::common::ScopeGuard; use crate::common::ScopeGuard;
use crate::common::UnescapeStringStyle; use crate::common::UnescapeStringStyle;
use crate::compat::MB_CUR_MAX;
use crate::env::EnvMode; use crate::env::EnvMode;
use crate::env::Environment; use crate::env::Environment;
use crate::env::READ_BYTE_LIMIT; use crate::env::READ_BYTE_LIMIT;
use crate::env::{EnvVar, EnvVarFlags}; use crate::env::{EnvVar, EnvVarFlags};
use crate::libc::MB_CUR_MAX;
use crate::nix::isatty; use crate::nix::isatty;
use crate::reader::commandline_set_buffer; use crate::reader::commandline_set_buffer;
use crate::reader::ReaderConfig; use crate::reader::ReaderConfig;

View file

@ -4,8 +4,8 @@ use libc::{c_uint, rlim_t, RLIM_INFINITY};
use nix::errno::Errno; use nix::errno::Errno;
use once_cell::sync::Lazy; use once_cell::sync::Lazy;
use crate::compat::*;
use crate::fallback::{fish_wcswidth, wcscasecmp}; use crate::fallback::{fish_wcswidth, wcscasecmp};
use crate::libc::*;
use crate::wutil::perror; use crate::wutil::perror;
use super::prelude::*; use super::prelude::*;

View file

@ -1,6 +1,5 @@
//! Prototypes for various functions, mostly string utilities, that are used by most parts of fish. //! Prototypes for various functions, mostly string utilities, that are used by most parts of fish.
use crate::compat::MB_CUR_MAX;
use crate::expand::{ use crate::expand::{
BRACE_BEGIN, BRACE_END, BRACE_SEP, BRACE_SPACE, HOME_DIRECTORY, INTERNAL_SEPARATOR, BRACE_BEGIN, BRACE_END, BRACE_SEP, BRACE_SPACE, HOME_DIRECTORY, INTERNAL_SEPARATOR,
PROCESS_EXPAND_SELF, PROCESS_EXPAND_SELF_STR, VARIABLE_EXPAND, VARIABLE_EXPAND_SINGLE, PROCESS_EXPAND_SELF, PROCESS_EXPAND_SELF_STR, VARIABLE_EXPAND, VARIABLE_EXPAND_SINGLE,
@ -9,6 +8,7 @@ use crate::fallback::fish_wcwidth;
use crate::flog::FLOG; use crate::flog::FLOG;
use crate::future_feature_flags::{feature_test, FeatureFlag}; use crate::future_feature_flags::{feature_test, FeatureFlag};
use crate::global_safety::RelaxedAtomicBool; use crate::global_safety::RelaxedAtomicBool;
use crate::libc::MB_CUR_MAX;
use crate::termsize::Termsize; use crate::termsize::Termsize;
use crate::wchar::{decode_byte_from_char, encode_byte_to_char, prelude::*}; use crate::wchar::{decode_byte_from_char, encode_byte_to_char, prelude::*};
use crate::wcstringutil::wcs2string_callback; use crate::wcstringutil::wcs2string_callback;

View file

@ -5,7 +5,6 @@ use super::environment_impl::{
use super::{ConfigPaths, ElectricVar}; use super::{ConfigPaths, ElectricVar};
use crate::abbrs::{abbrs_get_set, Abbreviation, Position}; use crate::abbrs::{abbrs_get_set, Abbreviation, Position};
use crate::common::{str2wcstring, unescape_string, wcs2zstring, UnescapeStringStyle}; use crate::common::{str2wcstring, unescape_string, wcs2zstring, UnescapeStringStyle};
use crate::compat::{stdout_stream, C_PATH_BSHELL, _PATH_BSHELL};
use crate::env::{EnvMode, EnvVar, Statuses}; use crate::env::{EnvMode, EnvVar, Statuses};
use crate::env_dispatch::{env_dispatch_init, env_dispatch_var_change}; use crate::env_dispatch::{env_dispatch_init, env_dispatch_var_change};
use crate::env_universal_common::{CallbackDataList, EnvUniversal}; use crate::env_universal_common::{CallbackDataList, EnvUniversal};
@ -13,6 +12,7 @@ use crate::event::Event;
use crate::flog::FLOG; use crate::flog::FLOG;
use crate::global_safety::RelaxedAtomicBool; use crate::global_safety::RelaxedAtomicBool;
use crate::input::init_input; use crate::input::init_input;
use crate::libc::{stdout_stream, C_PATH_BSHELL, _PATH_BSHELL};
use crate::nix::{geteuid, getpid, isatty}; use crate::nix::{geteuid, getpid, isatty};
use crate::null_terminated_array::OwningNullTerminatedArray; use crate::null_terminated_array::OwningNullTerminatedArray;
use crate::path::{ use crate::path::{
@ -544,7 +544,7 @@ fn setup_user(vars: &EnvStack) {
/// Make sure the PATH variable contains something. /// Make sure the PATH variable contains something.
fn setup_path() { fn setup_path() {
use crate::compat::{confstr, _CS_PATH}; use crate::libc::{confstr, _CS_PATH};
let vars = &GLOBALS; let vars = &GLOBALS;
let path = vars.get_unless_empty(L!("PATH")); let path = vars.get_unless_empty(L!("PATH"));

View file

@ -726,7 +726,7 @@ fn init_locale(vars: &EnvStack) {
.map(|allow_c| !crate::wcstringutil::bool_from_string(&allow_c)) .map(|allow_c| !crate::wcstringutil::bool_from_string(&allow_c))
.unwrap_or(true); .unwrap_or(true);
if fix_locale && crate::compat::MB_CUR_MAX() == 1 { if fix_locale && crate::libc::MB_CUR_MAX() == 1 {
FLOG!(env_locale, "Have singlebyte locale, trying to fix."); FLOG!(env_locale, "Have singlebyte locale, trying to fix.");
for locale in UTF8_LOCALES { for locale in UTF8_LOCALES {
{ {
@ -734,13 +734,13 @@ fn init_locale(vars: &EnvStack) {
// this can fail, that is fine // this can fail, that is fine
unsafe { libc::setlocale(libc::LC_CTYPE, locale.as_ptr()) }; unsafe { libc::setlocale(libc::LC_CTYPE, locale.as_ptr()) };
} }
if crate::compat::MB_CUR_MAX() > 1 { if crate::libc::MB_CUR_MAX() > 1 {
FLOG!(env_locale, "Fixed locale:", locale); FLOG!(env_locale, "Fixed locale:", locale);
break; break;
} }
} }
if crate::compat::MB_CUR_MAX() == 1 { if crate::libc::MB_CUR_MAX() == 1 {
FLOG!(env_locale, "Failed to fix locale."); FLOG!(env_locale, "Failed to fix locale.");
} }
} }

View file

@ -2,12 +2,12 @@ use crate::common::{
read_loop, str2wcstring, timef, unescape_string, valid_var_name, wcs2zstring, write_loop, read_loop, str2wcstring, timef, unescape_string, valid_var_name, wcs2zstring, write_loop,
UnescapeFlags, UnescapeStringStyle, UnescapeFlags, UnescapeStringStyle,
}; };
use crate::compat::{C_O_EXLOCK, UVAR_FILE_SET_MTIME_HACK};
use crate::env::{EnvVar, EnvVarFlags, VarTable}; use crate::env::{EnvVar, EnvVarFlags, VarTable};
use crate::fallback::fish_mkstemp_cloexec; use crate::fallback::fish_mkstemp_cloexec;
use crate::fds::AutoCloseFd; use crate::fds::AutoCloseFd;
use crate::fds::{open_cloexec, wopen_cloexec}; use crate::fds::{open_cloexec, wopen_cloexec};
use crate::flog::{FLOG, FLOGF}; use crate::flog::{FLOG, FLOGF};
use crate::libc::{C_O_EXLOCK, UVAR_FILE_SET_MTIME_HACK};
use crate::path::path_get_config; use crate::path::path_get_config;
use crate::path::{path_get_config_remoteness, DirRemoteness}; use crate::path::{path_get_config_remoteness, DirRemoteness};
use crate::wchar::prelude::*; use crate::wchar::prelude::*;

View file

@ -11,7 +11,6 @@ use crate::common::{
exit_without_destructors, scoped_push_replacer, str2wcstring, wcs2string, wcs2zstring, exit_without_destructors, scoped_push_replacer, str2wcstring, wcs2string, wcs2zstring,
write_loop, ScopeGuard, write_loop, ScopeGuard,
}; };
use crate::compat::_PATH_BSHELL;
use crate::env::{EnvMode, EnvStack, Environment, Statuses, READ_BYTE_LIMIT}; use crate::env::{EnvMode, EnvStack, Environment, Statuses, READ_BYTE_LIMIT};
use crate::env_dispatch::use_posix_spawn; use crate::env_dispatch::use_posix_spawn;
use crate::fds::make_fd_blocking; use crate::fds::make_fd_blocking;
@ -29,6 +28,7 @@ use crate::io::{
BufferedOutputStream, FdOutputStream, IoBufferfill, IoChain, IoClose, IoMode, IoPipe, BufferedOutputStream, FdOutputStream, IoBufferfill, IoChain, IoClose, IoMode, IoPipe,
IoStreams, OutputStream, SeparatedBuffer, StringOutputStream, IoStreams, OutputStream, SeparatedBuffer, StringOutputStream,
}; };
use crate::libc::_PATH_BSHELL;
use crate::nix::isatty; use crate::nix::isatty;
use crate::null_terminated_array::{ use crate::null_terminated_array::{
null_terminated_array_length, AsNullTerminatedArray, OwningNullTerminatedArray, null_terminated_array_length, AsNullTerminatedArray, OwningNullTerminatedArray,

View file

@ -27,7 +27,6 @@ use crate::{
restore_term_foreground_process_group_for_exit, save_term_foreground_process_group, restore_term_foreground_process_group_for_exit, save_term_foreground_process_group,
scoped_push_replacer, str2wcstring, wcs2string, PROFILING_ACTIVE, PROGRAM_NAME, scoped_push_replacer, str2wcstring, wcs2string, PROFILING_ACTIVE, PROGRAM_NAME,
}, },
compat::setlinebuf,
env::Statuses, env::Statuses,
env::{ env::{
environment::{env_init, EnvStack, Environment}, environment::{env_init, EnvStack, Environment},
@ -39,6 +38,7 @@ use crate::{
function, future_feature_flags as features, history, function, future_feature_flags as features, history,
history::start_private_mode, history::start_private_mode,
io::IoChain, io::IoChain,
libc::setlinebuf,
nix::{getpid, isatty}, nix::{getpid, isatty},
parse_constants::{ParseErrorList, ParseTreeFlags}, parse_constants::{ParseErrorList, ParseTreeFlags},
parse_tree::ParsedSource, parse_tree::ParsedSource,

View file

@ -15,7 +15,6 @@ use crate::common::{
str2wcstring, unescape_string, wcs2string, wcs2zstring, UnescapeFlags, UnescapeStringStyle, str2wcstring, unescape_string, wcs2string, wcs2zstring, UnescapeFlags, UnescapeStringStyle,
PROGRAM_NAME, PROGRAM_NAME,
}; };
use crate::compat::setlinebuf;
use crate::env::env_init; use crate::env::env_init;
use crate::env::environment::Environment; use crate::env::environment::Environment;
use crate::env::EnvStack; use crate::env::EnvStack;
@ -25,6 +24,7 @@ use crate::fds::set_cloexec;
use crate::future::{IsOkAnd, IsSomeAnd, IsSorted}; use crate::future::{IsOkAnd, IsSomeAnd, IsSorted};
use crate::global_safety::RelaxedAtomicBool; use crate::global_safety::RelaxedAtomicBool;
use crate::highlight::{colorize, highlight_shell, HighlightRole, HighlightSpec}; use crate::highlight::{colorize, highlight_shell, HighlightRole, HighlightSpec};
use crate::libc::setlinebuf;
use crate::operation_context::OperationContext; use crate::operation_context::OperationContext;
use crate::parse_constants::{ParseTokenType, ParseTreeFlags, SourceRange}; use crate::parse_constants::{ParseTokenType, ParseTreeFlags, SourceRange};
use crate::parse_util::parse_util_compute_indents; use crate::parse_util::parse_util_compute_indents;

View file

@ -10,7 +10,6 @@ use crate::common::{
unescape_string_in_place, valid_var_name, valid_var_name_char, UnescapeFlags, ASCII_MAX, unescape_string_in_place, valid_var_name, valid_var_name_char, UnescapeFlags, ASCII_MAX,
EXPAND_RESERVED_BASE, EXPAND_RESERVED_END, EXPAND_RESERVED_BASE, EXPAND_RESERVED_END,
}; };
use crate::compat::_PC_CASE_SENSITIVE;
use crate::env::Environment; use crate::env::Environment;
use crate::expand::{ use crate::expand::{
expand_one, expand_tilde, expand_to_command_and_args, ExpandFlags, ExpandResultCode, expand_one, expand_tilde, expand_to_command_and_args, ExpandFlags, ExpandResultCode,
@ -23,6 +22,7 @@ use crate::expand::{
use crate::function; use crate::function;
use crate::future_feature_flags::{feature_test, FeatureFlag}; use crate::future_feature_flags::{feature_test, FeatureFlag};
use crate::history::{all_paths_are_valid, HistoryItem}; use crate::history::{all_paths_are_valid, HistoryItem};
use crate::libc::_PC_CASE_SENSITIVE;
use crate::operation_context::OperationContext; use crate::operation_context::OperationContext;
use crate::output::{parse_color, Outputter}; use crate::output::{parse_color, Outputter};
use crate::parse_constants::{ use crate::parse_constants::{

View file

@ -408,7 +408,7 @@ pub trait InputEventQueuer {
} }
ReadbResult::Byte(read_byte) => { ReadbResult::Byte(read_byte) => {
if crate::compat::MB_CUR_MAX() == 1 { if crate::libc::MB_CUR_MAX() == 1 {
// single-byte locale, all values are legal // single-byte locale, all values are legal
// FIXME: this looks wrong, this falsely assumes that // FIXME: this looks wrong, this falsely assumes that
// the single-byte locale is compatible with Unicode upper-ASCII. // the single-byte locale is compatible with Unicode upper-ASCII.

View file

@ -35,8 +35,6 @@ mod ast;
mod autoload; mod autoload;
mod builtins; mod builtins;
mod color; mod color;
#[allow(non_snake_case)]
mod compat;
mod complete; mod complete;
mod curses; mod curses;
mod editable_line; mod editable_line;
@ -67,6 +65,8 @@ mod input_common;
mod io; mod io;
mod job_group; mod job_group;
mod kill; mod kill;
#[allow(non_snake_case)]
mod libc;
mod locale; mod locale;
mod nix; mod nix;
mod null_terminated_array; mod null_terminated_array;

View file

@ -6,13 +6,13 @@ use std::collections::HashMap;
use crate::common::{ use crate::common::{
escape_string, get_ellipsis_char, get_ellipsis_str, EscapeFlags, EscapeStringStyle, escape_string, get_ellipsis_char, get_ellipsis_str, EscapeFlags, EscapeStringStyle,
}; };
use crate::compat::MB_CUR_MAX;
use crate::complete::Completion; use crate::complete::Completion;
use crate::editable_line::EditableLine; use crate::editable_line::EditableLine;
use crate::fallback::{fish_wcswidth, fish_wcwidth}; use crate::fallback::{fish_wcswidth, fish_wcwidth};
#[allow(unused_imports)] #[allow(unused_imports)]
use crate::future::IsSomeAnd; use crate::future::IsSomeAnd;
use crate::highlight::{highlight_shell, HighlightRole, HighlightSpec}; use crate::highlight::{highlight_shell, HighlightRole, HighlightSpec};
use crate::libc::MB_CUR_MAX;
use crate::operation_context::OperationContext; use crate::operation_context::OperationContext;
use crate::screen::{Line, ScreenData}; use crate::screen::{Line, ScreenData};
use crate::termsize::Termsize; use crate::termsize::Termsize;

View file

@ -3,11 +3,11 @@
//! path-related issues. //! path-related issues.
use crate::common::wcs2zstring; use crate::common::wcs2zstring;
#[cfg(not(target_os = "linux"))]
use crate::compat::{MNT_LOCAL, ST_LOCAL};
use crate::env::{EnvMode, EnvStack, Environment}; use crate::env::{EnvMode, EnvStack, Environment};
use crate::expand::{expand_tilde, HOME_DIRECTORY}; use crate::expand::{expand_tilde, HOME_DIRECTORY};
use crate::flog::{FLOG, FLOGF}; use crate::flog::{FLOG, FLOGF};
#[cfg(not(target_os = "linux"))]
use crate::libc::{MNT_LOCAL, ST_LOCAL};
use crate::wchar::prelude::*; use crate::wchar::prelude::*;
use crate::wutil::{normalize_path, path_normalize_for_cd, waccess, wdirname, wmkdir, wstat}; use crate::wutil::{normalize_path, path_normalize_for_cd, waccess, wdirname, wmkdir, wstat};
use errno::{errno, set_errno, Errno}; use errno::{errno, set_errno, Errno};

View file

@ -42,7 +42,6 @@ use crate::common::{
shell_modes, str2wcstring, wcs2string, write_loop, EscapeFlags, EscapeStringStyle, ScopeGuard, shell_modes, str2wcstring, wcs2string, write_loop, EscapeFlags, EscapeStringStyle, ScopeGuard,
PROGRAM_NAME, UTF8_BOM_WCHAR, PROGRAM_NAME, UTF8_BOM_WCHAR,
}; };
use crate::compat::MB_CUR_MAX;
use crate::complete::{ use crate::complete::{
complete, complete_load, sort_and_prioritize, CompleteFlags, Completion, CompletionList, complete, complete_load, sort_and_prioritize, CompleteFlags, Completion, CompletionList,
CompletionRequestOptions, CompletionRequestOptions,
@ -71,6 +70,7 @@ use crate::input::Inputter;
use crate::input_common::{CharEvent, CharInputStyle, ReadlineCmd}; use crate::input_common::{CharEvent, CharInputStyle, ReadlineCmd};
use crate::io::IoChain; use crate::io::IoChain;
use crate::kill::{kill_add, kill_replace, kill_yank, kill_yank_rotate}; use crate::kill::{kill_add, kill_replace, kill_yank, kill_yank_rotate};
use crate::libc::MB_CUR_MAX;
use crate::operation_context::{get_bg_context, OperationContext}; use crate::operation_context::{get_bg_context, OperationContext};
use crate::output::{parse_color, Outputter}; use crate::output::{parse_color, Outputter};
use crate::pager::{PageRendering, Pager, SelectionMotion}; use crate::pager::{PageRendering, Pager, SelectionMotion};

View file

@ -18,13 +18,13 @@ fn setlocale() {
const UTF8_LOCALES: &[&str] = &[ const UTF8_LOCALES: &[&str] = &[
"C.UTF-8", "en_US.UTF-8", "en_GB.UTF-8", "de_DE.UTF-8", "C.utf8", "UTF-8", "C.UTF-8", "en_US.UTF-8", "en_GB.UTF-8", "de_DE.UTF-8", "C.utf8", "UTF-8",
]; ];
if crate::compat::MB_CUR_MAX() > 1 { if crate::libc::MB_CUR_MAX() > 1 {
return; return;
} }
for locale in UTF8_LOCALES { for locale in UTF8_LOCALES {
let locale = std::ffi::CString::new(locale.to_owned()).unwrap(); let locale = std::ffi::CString::new(locale.to_owned()).unwrap();
unsafe { libc::setlocale(libc::LC_CTYPE, locale.as_ptr()) }; unsafe { libc::setlocale(libc::LC_CTYPE, locale.as_ptr()) };
if crate::compat::MB_CUR_MAX() > 1 { if crate::libc::MB_CUR_MAX() > 1 {
return; return;
} }
} }

View file

@ -1,10 +1,10 @@
//! Helper functions for working with wcstring. //! Helper functions for working with wcstring.
use crate::common::{get_ellipsis_char, get_ellipsis_str}; use crate::common::{get_ellipsis_char, get_ellipsis_str};
use crate::compat::MB_CUR_MAX;
use crate::expand::INTERNAL_SEPARATOR; use crate::expand::INTERNAL_SEPARATOR;
use crate::fallback::{fish_wcwidth, wcscasecmp}; use crate::fallback::{fish_wcwidth, wcscasecmp};
use crate::flog::FLOGF; use crate::flog::FLOGF;
use crate::libc::MB_CUR_MAX;
use crate::wchar::{decode_byte_from_char, prelude::*}; use crate::wchar::{decode_byte_from_char, prelude::*};
use crate::wutil::encoding::{wcrtomb, zero_mbstate, AT_LEAST_MB_LEN_MAX}; use crate::wutil::encoding::{wcrtomb, zero_mbstate, AT_LEAST_MB_LEN_MAX};