mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 22:14:53 +00:00
Move POD components of library_data_t to separate struct
This allows them to be accessed as regular fields from Rust, rather than having to create setter/getter methods for each of them.
This commit is contained in:
parent
59fe124c40
commit
77a474ee37
5 changed files with 22 additions and 19 deletions
|
@ -2,7 +2,7 @@ use libc::c_int;
|
||||||
|
|
||||||
use super::r#return::parse_return_value;
|
use super::r#return::parse_return_value;
|
||||||
use super::shared::io_streams_t;
|
use super::shared::io_streams_t;
|
||||||
use crate::ffi::{parser_t, Repin};
|
use crate::ffi::parser_t;
|
||||||
use crate::wchar::wstr;
|
use crate::wchar::wstr;
|
||||||
|
|
||||||
/// Function for handling the exit builtin.
|
/// Function for handling the exit builtin.
|
||||||
|
@ -20,7 +20,7 @@ pub fn exit(
|
||||||
// TODO: in concurrent mode this won't successfully exit a pipeline, as there are other parsers
|
// TODO: in concurrent mode this won't successfully exit a pipeline, as there are other parsers
|
||||||
// involved. That is, `exit | sleep 1000` may not exit as hoped. Need to rationalize what
|
// involved. That is, `exit | sleep 1000` may not exit as hoped. Need to rationalize what
|
||||||
// behavior we want here.
|
// behavior we want here.
|
||||||
parser.pin().libdata().set_exit_current_script(true);
|
parser.libdata_pod().exit_current_script = true;
|
||||||
|
|
||||||
return Some(retval);
|
return Some(retval);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,7 @@ use super::shared::{
|
||||||
BUILTIN_ERR_NOT_NUMBER, STATUS_CMD_OK, STATUS_INVALID_ARGS,
|
BUILTIN_ERR_NOT_NUMBER, STATUS_CMD_OK, STATUS_INVALID_ARGS,
|
||||||
};
|
};
|
||||||
use crate::builtins::shared::BUILTIN_ERR_TOO_MANY_ARGUMENTS;
|
use crate::builtins::shared::BUILTIN_ERR_TOO_MANY_ARGUMENTS;
|
||||||
use crate::ffi::{parser_t, Repin};
|
use crate::ffi::parser_t;
|
||||||
use crate::wchar::{wstr, L};
|
use crate::wchar::{wstr, L};
|
||||||
use crate::wgetopt::{wgetopter_t, wopt, woption, woption_argument_t};
|
use crate::wgetopt::{wgetopter_t, wopt, woption, woption_argument_t};
|
||||||
use crate::wutil::fish_wcstoi;
|
use crate::wutil::fish_wcstoi;
|
||||||
|
@ -79,14 +79,15 @@ pub fn r#return(
|
||||||
|
|
||||||
// If we're not in a function, exit the current script (but not an interactive shell).
|
// If we're not in a function, exit the current script (but not an interactive shell).
|
||||||
if !has_function_block {
|
if !has_function_block {
|
||||||
if !parser.is_interactive() {
|
let ld = parser.libdata_pod();
|
||||||
parser.pin().libdata().set_exit_current_script(true);
|
if !ld.is_interactive {
|
||||||
|
ld.exit_current_script = true;
|
||||||
}
|
}
|
||||||
return Some(retval);
|
return Some(retval);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Mark a return in the libdata.
|
// Mark a return in the libdata.
|
||||||
parser.pin().libdata().set_returning(true);
|
parser.libdata_pod().returning = true;
|
||||||
|
|
||||||
return Some(retval);
|
return Some(retval);
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,6 +47,7 @@ include_cpp! {
|
||||||
generate!("job_t")
|
generate!("job_t")
|
||||||
generate!("process_t")
|
generate!("process_t")
|
||||||
generate!("library_data_t")
|
generate!("library_data_t")
|
||||||
|
generate_pod!("library_data_pod_t")
|
||||||
|
|
||||||
generate!("proc_wait_any")
|
generate!("proc_wait_any")
|
||||||
|
|
||||||
|
@ -80,6 +81,12 @@ impl parser_t {
|
||||||
let ffi_jobs = self.ffi_jobs();
|
let ffi_jobs = self.ffi_jobs();
|
||||||
unsafe { slice::from_raw_parts(ffi_jobs.jobs, ffi_jobs.count) }
|
unsafe { slice::from_raw_parts(ffi_jobs.jobs, ffi_jobs.count) }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn libdata_pod(&mut self) -> &mut library_data_pod_t {
|
||||||
|
let libdata = self.pin().ffi_libdata_pod();
|
||||||
|
|
||||||
|
unsafe { &mut *libdata }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl job_t {
|
impl job_t {
|
||||||
|
|
|
@ -39,14 +39,6 @@ static wcstring user_presentable_path(const wcstring &path, const environment_t
|
||||||
return replace_home_directory_with_tilde(path, vars);
|
return replace_home_directory_with_tilde(path, vars);
|
||||||
}
|
}
|
||||||
|
|
||||||
void library_data_t::set_exit_current_script(bool val) {
|
|
||||||
exit_current_script = val;
|
|
||||||
};
|
|
||||||
|
|
||||||
void library_data_t::set_returning(bool val) {
|
|
||||||
returning = val;
|
|
||||||
};
|
|
||||||
|
|
||||||
parser_t::parser_t(std::shared_ptr<env_stack_t> vars, bool is_principal)
|
parser_t::parser_t(std::shared_ptr<env_stack_t> vars, bool is_principal)
|
||||||
: variables(std::move(vars)), is_principal_(is_principal) {
|
: variables(std::move(vars)), is_principal_(is_principal) {
|
||||||
assert(variables.get() && "Null variables in parser initializer");
|
assert(variables.get() && "Null variables in parser initializer");
|
||||||
|
@ -497,6 +489,8 @@ job_t *parser_t::job_get_from_pid(pid_t pid) const {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
library_data_pod_t *parser_t::ffi_libdata_pod() { return &library_data; }
|
||||||
|
|
||||||
profile_item_t *parser_t::create_profile_item() {
|
profile_item_t *parser_t::create_profile_item() {
|
||||||
if (g_profiling_active) {
|
if (g_profiling_active) {
|
||||||
profile_items.emplace_back();
|
profile_items.emplace_back();
|
||||||
|
|
11
src/parser.h
11
src/parser.h
|
@ -146,8 +146,8 @@ struct profile_item_t {
|
||||||
|
|
||||||
class parse_execution_context_t;
|
class parse_execution_context_t;
|
||||||
|
|
||||||
/// Miscellaneous data used to avoid recursion and others.
|
/// Plain-Old-Data components of `struct library_data_t` that can be shared over FFI
|
||||||
struct library_data_t {
|
struct library_data_pod_t {
|
||||||
/// A counter incremented every time a command executes.
|
/// A counter incremented every time a command executes.
|
||||||
uint64_t exec_count{0};
|
uint64_t exec_count{0};
|
||||||
|
|
||||||
|
@ -207,7 +207,10 @@ struct library_data_t {
|
||||||
|
|
||||||
/// The read limit to apply to captured subshell output, or 0 for none.
|
/// The read limit to apply to captured subshell output, or 0 for none.
|
||||||
size_t read_limit{0};
|
size_t read_limit{0};
|
||||||
|
};
|
||||||
|
|
||||||
|
/// Miscellaneous data used to avoid recursion and others.
|
||||||
|
struct library_data_t : public library_data_pod_t {
|
||||||
/// The current filename we are evaluating, either from builtin source or on the command line.
|
/// The current filename we are evaluating, either from builtin source or on the command line.
|
||||||
filename_ref_t current_filename{};
|
filename_ref_t current_filename{};
|
||||||
|
|
||||||
|
@ -231,9 +234,6 @@ struct library_data_t {
|
||||||
/// Used to get the full text of the current job for `status current-commandline`.
|
/// Used to get the full text of the current job for `status current-commandline`.
|
||||||
wcstring commandline;
|
wcstring commandline;
|
||||||
} status_vars;
|
} status_vars;
|
||||||
|
|
||||||
void set_exit_current_script(bool val);
|
|
||||||
void set_returning(bool val);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/// The result of parser_t::eval family.
|
/// The result of parser_t::eval family.
|
||||||
|
@ -486,6 +486,7 @@ class parser_t : public std::enable_shared_from_this<parser_t> {
|
||||||
|
|
||||||
/// autocxx junk.
|
/// autocxx junk.
|
||||||
RustFFIJobList ffi_jobs() const;
|
RustFFIJobList ffi_jobs() const;
|
||||||
|
library_data_pod_t *ffi_libdata_pod();
|
||||||
|
|
||||||
/// autocxx junk.
|
/// autocxx junk.
|
||||||
bool ffi_has_funtion_block() const;
|
bool ffi_has_funtion_block() const;
|
||||||
|
|
Loading…
Reference in a new issue