diff options
| author | Jonas Maier <jonas@x77.dev> | 2026-05-03 16:44:08 +0200 |
|---|---|---|
| committer | Jonas Maier <jonas@x77.dev> | 2026-05-03 16:44:08 +0200 |
| commit | f4d2b541f2dd499044ac428e4c266cf48c91b4d8 (patch) | |
| tree | 1d1431914a0bc12049a721ae03bc99903de8d90a /src/run/builtin.rs | |
| parent | f07eb9509920be72e98ebd51caf7a8edb768371c (diff) | |
| download | pish-f4d2b541f2dd499044ac428e4c266cf48c91b4d8.tar.gz | |
source builtin
Diffstat (limited to 'src/run/builtin.rs')
| -rw-r--r-- | src/run/builtin.rs | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/src/run/builtin.rs b/src/run/builtin.rs index 4a7e332..a52c345 100644 --- a/src/run/builtin.rs +++ b/src/run/builtin.rs @@ -665,7 +665,7 @@ impl Builtin for bind { if args.len() == 0 { let mut dump = |map: &HashMap<BString, crate::parse::Command<PostExpansion>>, - category: &str| + category: &str| -> std::io::Result<()> { let mut entries: Vec<_> = map.iter().collect(); entries.sort_by_key(|x| x.0); @@ -766,6 +766,8 @@ impl Builtin for exit { break num; }; + println!("bye!\r"); + std::process::exit(exit_code); } @@ -831,3 +833,26 @@ impl Builtin for ct { Ok(()) } } + +#[derive(Copy, Clone)] +pub struct source; + +impl Builtin for source { + fn name(&self) -> &str { + "source" + } + + fn io( + &self, + session: Arc<Mutex<Session>>, + args: &[BString], + _stdin: &mut dyn Read, + _stdout: &mut dyn Write, + ) -> Result { + for file in args.iter() { + // TODO: useful error propagation (?) + super::source(session.clone(), file).map_err(|_| Error::Exit(-1))?; + } + Ok(()) + } +} |
