mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-27 20:25:12 +00:00
Revert "BuiltinData to use const constructor function"
Unfortunately, this does not work with rust 1.70.
This reverts commit 7e516925e9
.
This commit is contained in:
parent
7e516925e9
commit
004953a3b2
1 changed files with 244 additions and 67 deletions
|
@ -109,77 +109,254 @@ struct BuiltinData {
|
||||||
func: BuiltinCmd,
|
func: BuiltinCmd,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl BuiltinData {
|
|
||||||
const fn new(name: &'static wstr, func: BuiltinCmd) -> Self {
|
|
||||||
Self { name, func }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Data about all the builtin commands in fish.
|
// Data about all the builtin commands in fish.
|
||||||
// Functions that are bound to builtin_generic are handled directly by the parser.
|
// Functions that are bound to builtin_generic are handled directly by the parser.
|
||||||
// NOTE: These must be kept in sorted order!
|
// NOTE: These must be kept in sorted order!
|
||||||
const BUILTIN_DATAS: &[BuiltinData] = &[
|
const BUILTIN_DATAS: &[BuiltinData] = &[
|
||||||
BuiltinData::new(L!("."), source::source),
|
BuiltinData {
|
||||||
BuiltinData::new(L!(":"), builtin_true),
|
name: L!("."),
|
||||||
BuiltinData::new(L!("["), test::test), // ]
|
func: source::source,
|
||||||
BuiltinData::new(L!("_"), builtin_gettext),
|
},
|
||||||
BuiltinData::new(L!("abbr"), abbr::abbr),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("and"), builtin_generic),
|
name: L!(":"),
|
||||||
BuiltinData::new(L!("argparse"), argparse::argparse),
|
func: builtin_true,
|
||||||
BuiltinData::new(L!("begin"), builtin_generic),
|
},
|
||||||
BuiltinData::new(L!("bg"), bg::bg),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("bind"), bind::bind),
|
name: L!("["), // ]
|
||||||
BuiltinData::new(L!("block"), block::block),
|
func: test::test,
|
||||||
BuiltinData::new(L!("break"), builtin_break_continue),
|
},
|
||||||
BuiltinData::new(L!("breakpoint"), builtin_breakpoint),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("builtin"), builtin::builtin),
|
name: L!("_"),
|
||||||
BuiltinData::new(L!("case"), builtin_generic),
|
func: builtin_gettext,
|
||||||
BuiltinData::new(L!("cd"), cd::cd),
|
},
|
||||||
BuiltinData::new(L!("command"), command::command),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("commandline"), commandline::commandline),
|
name: L!("abbr"),
|
||||||
BuiltinData::new(L!("complete"), complete::complete),
|
func: abbr::abbr,
|
||||||
BuiltinData::new(L!("contains"), contains::contains),
|
},
|
||||||
BuiltinData::new(L!("continue"), builtin_break_continue),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("count"), count::count),
|
name: L!("and"),
|
||||||
BuiltinData::new(L!("disown"), disown::disown),
|
func: builtin_generic,
|
||||||
BuiltinData::new(L!("echo"), echo::echo),
|
},
|
||||||
BuiltinData::new(L!("else"), builtin_generic),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("emit"), emit::emit),
|
name: L!("argparse"),
|
||||||
BuiltinData::new(L!("end"), builtin_generic),
|
func: argparse::argparse,
|
||||||
BuiltinData::new(L!("eval"), eval::eval),
|
},
|
||||||
BuiltinData::new(L!("exec"), builtin_generic),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("exit"), exit::exit),
|
name: L!("begin"),
|
||||||
BuiltinData::new(L!("false"), builtin_false),
|
func: builtin_generic,
|
||||||
BuiltinData::new(L!("fg"), fg::fg),
|
},
|
||||||
BuiltinData::new(L!("for"), builtin_generic),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("function"), builtin_generic),
|
name: L!("bg"),
|
||||||
BuiltinData::new(L!("functions"), functions::functions),
|
func: bg::bg,
|
||||||
BuiltinData::new(L!("history"), history::history),
|
},
|
||||||
BuiltinData::new(L!("if"), builtin_generic),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("jobs"), jobs::jobs),
|
name: L!("bind"),
|
||||||
BuiltinData::new(L!("math"), math::math),
|
func: bind::bind,
|
||||||
BuiltinData::new(L!("not"), builtin_generic),
|
},
|
||||||
BuiltinData::new(L!("or"), builtin_generic),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("path"), path::path),
|
name: L!("block"),
|
||||||
BuiltinData::new(L!("printf"), printf::printf),
|
func: block::block,
|
||||||
BuiltinData::new(L!("pwd"), pwd::pwd),
|
},
|
||||||
BuiltinData::new(L!("random"), random::random),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("read"), read::read),
|
name: L!("break"),
|
||||||
BuiltinData::new(L!("realpath"), realpath::realpath),
|
func: builtin_break_continue,
|
||||||
BuiltinData::new(L!("return"), r#return::r#return),
|
},
|
||||||
BuiltinData::new(L!("set"), set::set),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("set_color"), set_color::set_color),
|
name: L!("breakpoint"),
|
||||||
BuiltinData::new(L!("source"), source::source),
|
func: builtin_breakpoint,
|
||||||
BuiltinData::new(L!("status"), status::status),
|
},
|
||||||
BuiltinData::new(L!("string"), string::string),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("switch"), builtin_generic),
|
name: L!("builtin"),
|
||||||
BuiltinData::new(L!("test"), test::test),
|
func: builtin::builtin,
|
||||||
BuiltinData::new(L!("time"), builtin_generic),
|
},
|
||||||
BuiltinData::new(L!("true"), builtin_true),
|
BuiltinData {
|
||||||
BuiltinData::new(L!("type"), r#type::r#type),
|
name: L!("case"),
|
||||||
BuiltinData::new(L!("ulimit"), ulimit::ulimit),
|
func: builtin_generic,
|
||||||
BuiltinData::new(L!("wait"), wait::wait),
|
},
|
||||||
BuiltinData::new(L!("while"), builtin_generic),
|
BuiltinData {
|
||||||
|
name: L!("cd"),
|
||||||
|
func: cd::cd,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("command"),
|
||||||
|
func: command::command,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("commandline"),
|
||||||
|
func: commandline::commandline,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("complete"),
|
||||||
|
func: complete::complete,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("contains"),
|
||||||
|
func: contains::contains,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("continue"),
|
||||||
|
func: builtin_break_continue,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("count"),
|
||||||
|
func: count::count,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("disown"),
|
||||||
|
func: disown::disown,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("echo"),
|
||||||
|
func: echo::echo,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("else"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("emit"),
|
||||||
|
func: emit::emit,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("end"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("eval"),
|
||||||
|
func: eval::eval,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("exec"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("exit"),
|
||||||
|
func: exit::exit,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("false"),
|
||||||
|
func: builtin_false,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("fg"),
|
||||||
|
func: fg::fg,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("for"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("function"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("functions"),
|
||||||
|
func: functions::functions,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("history"),
|
||||||
|
func: history::history,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("if"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("jobs"),
|
||||||
|
func: jobs::jobs,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("math"),
|
||||||
|
func: math::math,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("not"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("or"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("path"),
|
||||||
|
func: path::path,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("printf"),
|
||||||
|
func: printf::printf,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("pwd"),
|
||||||
|
func: pwd::pwd,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("random"),
|
||||||
|
func: random::random,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("read"),
|
||||||
|
func: read::read,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("realpath"),
|
||||||
|
func: realpath::realpath,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("return"),
|
||||||
|
func: r#return::r#return,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("set"),
|
||||||
|
func: set::set,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("set_color"),
|
||||||
|
func: set_color::set_color,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("source"),
|
||||||
|
func: source::source,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("status"),
|
||||||
|
func: status::status,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("string"),
|
||||||
|
func: string::string,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("switch"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("test"),
|
||||||
|
func: test::test,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("time"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("true"),
|
||||||
|
func: builtin_true,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("type"),
|
||||||
|
func: r#type::r#type,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("ulimit"),
|
||||||
|
func: ulimit::ulimit,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("wait"),
|
||||||
|
func: wait::wait,
|
||||||
|
},
|
||||||
|
BuiltinData {
|
||||||
|
name: L!("while"),
|
||||||
|
func: builtin_generic,
|
||||||
|
},
|
||||||
];
|
];
|
||||||
assert_sorted_by_name!(BUILTIN_DATAS);
|
assert_sorted_by_name!(BUILTIN_DATAS);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue