mirror of
https://github.com/nushell/nushell
synced 2025-01-13 21:55:07 +00:00
make module imports in scripts used for relative path. (#5913)
* always load env * add interactive argument for read_config_file
This commit is contained in:
parent
58fa2e51a2
commit
6dde231dde
2 changed files with 48 additions and 27 deletions
|
@ -18,6 +18,7 @@ pub(crate) fn read_config_file(
|
||||||
config_file: Option<Spanned<String>>,
|
config_file: Option<Spanned<String>>,
|
||||||
is_perf_true: bool,
|
is_perf_true: bool,
|
||||||
is_env_config: bool,
|
is_env_config: bool,
|
||||||
|
interactive: bool,
|
||||||
) {
|
) {
|
||||||
// Load config startup file
|
// Load config startup file
|
||||||
if let Some(file) = config_file {
|
if let Some(file) = config_file {
|
||||||
|
@ -46,7 +47,13 @@ pub(crate) fn read_config_file(
|
||||||
|
|
||||||
config_path.push(if is_env_config { ENV_FILE } else { CONFIG_FILE });
|
config_path.push(if is_env_config { ENV_FILE } else { CONFIG_FILE });
|
||||||
|
|
||||||
if !config_path.exists() {
|
let config_file = if is_env_config {
|
||||||
|
include_str!("../docs/sample_config/default_env.nu")
|
||||||
|
} else {
|
||||||
|
include_str!("../docs/sample_config/default_config.nu")
|
||||||
|
};
|
||||||
|
|
||||||
|
if !config_path.exists() && interactive {
|
||||||
let file_msg = if is_env_config {
|
let file_msg = if is_env_config {
|
||||||
"environment config"
|
"environment config"
|
||||||
} else {
|
} else {
|
||||||
|
@ -64,12 +71,6 @@ pub(crate) fn read_config_file(
|
||||||
.read_line(&mut answer)
|
.read_line(&mut answer)
|
||||||
.expect("Failed to read user input");
|
.expect("Failed to read user input");
|
||||||
|
|
||||||
let config_file = if is_env_config {
|
|
||||||
include_str!("../docs/sample_config/default_env.nu")
|
|
||||||
} else {
|
|
||||||
include_str!("../docs/sample_config/default_config.nu")
|
|
||||||
};
|
|
||||||
|
|
||||||
match answer.to_lowercase().trim() {
|
match answer.to_lowercase().trim() {
|
||||||
"y" | "" => {
|
"y" | "" => {
|
||||||
let mut output = File::create(&config_path).expect("Unable to create file");
|
let mut output = File::create(&config_path).expect("Unable to create file");
|
||||||
|
@ -93,6 +94,19 @@ pub(crate) fn read_config_file(
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// Just use the contents of "default_config.nu" or "default_env.nu"
|
||||||
|
eval_source(
|
||||||
|
engine_state,
|
||||||
|
stack,
|
||||||
|
config_file.as_bytes(),
|
||||||
|
if is_env_config {
|
||||||
|
"default_env.nu"
|
||||||
|
} else {
|
||||||
|
"default_config.nu"
|
||||||
|
},
|
||||||
|
PipelineData::new(Span::new(0, 0)),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
eval_config_contents(config_path, engine_state, stack);
|
eval_config_contents(config_path, engine_state, stack);
|
||||||
|
|
47
src/main.rs
47
src/main.rs
|
@ -206,6 +206,14 @@ fn main() -> Result<()> {
|
||||||
is_perf_true(),
|
is_perf_true(),
|
||||||
);
|
);
|
||||||
// only want to load config and env if relative argument is provided.
|
// only want to load config and env if relative argument is provided.
|
||||||
|
config_files::read_config_file(
|
||||||
|
&mut engine_state,
|
||||||
|
&mut stack,
|
||||||
|
binary_args.env_file,
|
||||||
|
is_perf_true(),
|
||||||
|
true,
|
||||||
|
false,
|
||||||
|
);
|
||||||
if binary_args.config_file.is_some() {
|
if binary_args.config_file.is_some() {
|
||||||
config_files::read_config_file(
|
config_files::read_config_file(
|
||||||
&mut engine_state,
|
&mut engine_state,
|
||||||
|
@ -213,15 +221,7 @@ fn main() -> Result<()> {
|
||||||
binary_args.config_file,
|
binary_args.config_file,
|
||||||
is_perf_true(),
|
is_perf_true(),
|
||||||
false,
|
false,
|
||||||
);
|
false,
|
||||||
}
|
|
||||||
if binary_args.env_file.is_some() {
|
|
||||||
config_files::read_config_file(
|
|
||||||
&mut engine_state,
|
|
||||||
&mut stack,
|
|
||||||
binary_args.env_file,
|
|
||||||
is_perf_true(),
|
|
||||||
true,
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -251,6 +251,14 @@ fn main() -> Result<()> {
|
||||||
is_perf_true(),
|
is_perf_true(),
|
||||||
);
|
);
|
||||||
// only want to load config and env if relative argument is provided.
|
// only want to load config and env if relative argument is provided.
|
||||||
|
config_files::read_config_file(
|
||||||
|
&mut engine_state,
|
||||||
|
&mut stack,
|
||||||
|
binary_args.env_file,
|
||||||
|
is_perf_true(),
|
||||||
|
true,
|
||||||
|
false,
|
||||||
|
);
|
||||||
if binary_args.config_file.is_some() {
|
if binary_args.config_file.is_some() {
|
||||||
config_files::read_config_file(
|
config_files::read_config_file(
|
||||||
&mut engine_state,
|
&mut engine_state,
|
||||||
|
@ -258,15 +266,7 @@ fn main() -> Result<()> {
|
||||||
binary_args.config_file,
|
binary_args.config_file,
|
||||||
is_perf_true(),
|
is_perf_true(),
|
||||||
false,
|
false,
|
||||||
);
|
false,
|
||||||
}
|
|
||||||
if binary_args.env_file.is_some() {
|
|
||||||
config_files::read_config_file(
|
|
||||||
&mut engine_state,
|
|
||||||
&mut stack,
|
|
||||||
binary_args.env_file,
|
|
||||||
is_perf_true(),
|
|
||||||
true,
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -323,8 +323,15 @@ fn setup_config(
|
||||||
info!("read_config_file {}:{}:{}", file!(), line!(), column!());
|
info!("read_config_file {}:{}:{}", file!(), line!(), column!());
|
||||||
}
|
}
|
||||||
|
|
||||||
config_files::read_config_file(engine_state, stack, env_file, is_perf_true(), true);
|
config_files::read_config_file(engine_state, stack, env_file, is_perf_true(), true, true);
|
||||||
config_files::read_config_file(engine_state, stack, config_file, is_perf_true(), false);
|
config_files::read_config_file(
|
||||||
|
engine_state,
|
||||||
|
stack,
|
||||||
|
config_file,
|
||||||
|
is_perf_true(),
|
||||||
|
false,
|
||||||
|
true,
|
||||||
|
);
|
||||||
|
|
||||||
if is_login_shell {
|
if is_login_shell {
|
||||||
config_files::read_loginshell_file(engine_state, stack, is_perf_true());
|
config_files::read_loginshell_file(engine_state, stack, is_perf_true());
|
||||||
|
|
Loading…
Reference in a new issue