use crate::{
app::AppContext,
keys,
pattern::*,
verb::*,
};
pub struct MatchingVerbRow<'v> {
name: Option<String>,
shortcut: Option<String>,
pub verb: &'v Verb,
pub keys_desc: String,
}
impl MatchingVerbRow<'_> {
pub fn name(&self) -> &str {
self.name
.as_deref()
.unwrap_or_else(|| match self.verb.names.first() {
Some(s) => s.as_str(),
_ => " ",
})
}
pub fn shortcut(&self) -> &str {
self.shortcut
.as_deref()
.unwrap_or_else(|| match self.verb.names.get(1) {
Some(s) => s.as_str(),
_ => " ",
})
}
}
pub fn matching_verb_rows<'v>(
pat: &Pattern,
con: &'v AppContext,
) -> Vec<MatchingVerbRow<'v>> {
let mut rows = Vec::new();
for verb in con.verb_store.verbs() {
if !verb.show_in_doc {
continue;
}
let mut name = None;
let mut shortcut = None;
if pat.is_some() {
let mut ok = false;
name = verb.names.first().and_then(|s| {
pat.search_string(s).map(|nm| {
ok = true;
nm.wrap(s, "**", "**")
})
});
shortcut = verb.names.get(1).and_then(|s| {
pat.search_string(s).map(|nm| {
ok = true;
nm.wrap(s, "**", "**")
})
});
if !ok {
continue;
}
}
let keys_desc = verb
.keys
.iter()
.filter(|&&k| con.modal || !keys::is_key_only_modal(k))
.map(|&k| keys::KEY_FORMAT.to_string(k))
.collect::<Vec<String>>() .join(", ");
rows.push(MatchingVerbRow {
name,
shortcut,
verb,
keys_desc,
});
}
rows
}