mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Incremental item path autocomplete
This commit is contained in:
parent
b6dfa349bb
commit
d46dbb9708
@ -537,7 +537,7 @@ impl ServerChatCommand {
|
|||||||
),
|
),
|
||||||
ServerChatCommand::GiveItem => cmd(
|
ServerChatCommand::GiveItem => cmd(
|
||||||
vec![
|
vec![
|
||||||
Enum("item", ITEM_SPECS.clone(), Required),
|
AssetPath("item", ITEM_SPECS.clone(), Required),
|
||||||
Integer("num", 1, Optional),
|
Integer("num", 1, Optional),
|
||||||
],
|
],
|
||||||
"Give yourself some items.\nFor an example or to auto complete use Tab.",
|
"Give yourself some items.\nFor an example or to auto complete use Tab.",
|
||||||
@ -647,7 +647,7 @@ impl ServerChatCommand {
|
|||||||
),
|
),
|
||||||
ServerChatCommand::MakeNpc => cmd(
|
ServerChatCommand::MakeNpc => cmd(
|
||||||
vec![
|
vec![
|
||||||
Enum("entity_config", ENTITY_CONFIGS.clone(), Required),
|
AssetPath("entity_config", ENTITY_CONFIGS.clone(), Required),
|
||||||
Integer("num", 1, Optional),
|
Integer("num", 1, Optional),
|
||||||
],
|
],
|
||||||
"Spawn entity from config near you.\nFor an example or to auto complete use Tab.",
|
"Spawn entity from config near you.\nFor an example or to auto complete use Tab.",
|
||||||
@ -1079,6 +1079,7 @@ impl ServerChatCommand {
|
|||||||
ArgumentSpec::Message(_) => "{/.*/}",
|
ArgumentSpec::Message(_) => "{/.*/}",
|
||||||
ArgumentSpec::SubCommand => "{} {/.*/}",
|
ArgumentSpec::SubCommand => "{} {/.*/}",
|
||||||
ArgumentSpec::Enum(_, _, _) => "{}",
|
ArgumentSpec::Enum(_, _, _) => "{}",
|
||||||
|
ArgumentSpec::AssetPath(_, _, _) => "{}",
|
||||||
ArgumentSpec::Boolean(_, _, _) => "{}",
|
ArgumentSpec::Boolean(_, _, _) => "{}",
|
||||||
ArgumentSpec::Flag(_) => "{}",
|
ArgumentSpec::Flag(_) => "{}",
|
||||||
})
|
})
|
||||||
@ -1146,6 +1147,11 @@ pub enum ArgumentSpec {
|
|||||||
/// * Predefined string completions
|
/// * Predefined string completions
|
||||||
/// * whether it's optional
|
/// * whether it's optional
|
||||||
Enum(&'static str, Vec<String>, Requirement),
|
Enum(&'static str, Vec<String>, Requirement),
|
||||||
|
/// The argument is an asset path. The associated values are
|
||||||
|
/// * label
|
||||||
|
/// * List of all asset paths as strings for completion
|
||||||
|
/// * whether it's optional
|
||||||
|
AssetPath(&'static str, Vec<String>, Requirement),
|
||||||
/// The argument is likely a boolean. The associated values are
|
/// The argument is likely a boolean. The associated values are
|
||||||
/// * label
|
/// * label
|
||||||
/// * suggested tab-completion
|
/// * suggested tab-completion
|
||||||
@ -1222,6 +1228,13 @@ impl ArgumentSpec {
|
|||||||
format!("[{}]", label)
|
format!("[{}]", label)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
ArgumentSpec::AssetPath(label, _, req) => {
|
||||||
|
if &Requirement::Required == req {
|
||||||
|
format!("<{}>", label)
|
||||||
|
} else {
|
||||||
|
format!("[{}]", label)
|
||||||
|
}
|
||||||
|
},
|
||||||
ArgumentSpec::Boolean(label, _, req) => {
|
ArgumentSpec::Boolean(label, _, req) => {
|
||||||
if &Requirement::Required == req {
|
if &Requirement::Required == req {
|
||||||
format!("<{}>", label)
|
format!("<{}>", label)
|
||||||
@ -1246,6 +1259,7 @@ impl ArgumentSpec {
|
|||||||
| ArgumentSpec::Command(r)
|
| ArgumentSpec::Command(r)
|
||||||
| ArgumentSpec::Message(r)
|
| ArgumentSpec::Message(r)
|
||||||
| ArgumentSpec::Enum(_, _, r)
|
| ArgumentSpec::Enum(_, _, r)
|
||||||
|
| ArgumentSpec::AssetPath(_, _, r)
|
||||||
| ArgumentSpec::Boolean(_, _, r) => *r,
|
| ArgumentSpec::Boolean(_, _, r) => *r,
|
||||||
ArgumentSpec::Flag(_) => Requirement::Optional,
|
ArgumentSpec::Flag(_) => Requirement::Optional,
|
||||||
ArgumentSpec::SubCommand => Requirement::Required,
|
ArgumentSpec::SubCommand => Requirement::Required,
|
||||||
|
@ -17,6 +17,7 @@ use common::{
|
|||||||
uuid::Uuid,
|
uuid::Uuid,
|
||||||
};
|
};
|
||||||
use common_net::sync::WorldSyncExt;
|
use common_net::sync::WorldSyncExt;
|
||||||
|
use itertools::Itertools;
|
||||||
use levenshtein::levenshtein;
|
use levenshtein::levenshtein;
|
||||||
use specs::{Join, WorldExt};
|
use specs::{Join, WorldExt};
|
||||||
use strum::{EnumIter, IntoEnumIterator};
|
use strum::{EnumIter, IntoEnumIterator};
|
||||||
@ -100,6 +101,7 @@ impl ClientChatCommand {
|
|||||||
ArgumentSpec::Message(_) => "{/.*/}",
|
ArgumentSpec::Message(_) => "{/.*/}",
|
||||||
ArgumentSpec::SubCommand => "{} {/.*/}",
|
ArgumentSpec::SubCommand => "{} {/.*/}",
|
||||||
ArgumentSpec::Enum(_, _, _) => "{}",
|
ArgumentSpec::Enum(_, _, _) => "{}",
|
||||||
|
ArgumentSpec::AssetPath(_, _, _) => "{}",
|
||||||
ArgumentSpec::Boolean(_, _, _) => "{}",
|
ArgumentSpec::Boolean(_, _, _) => "{}",
|
||||||
ArgumentSpec::Flag(_) => "{}",
|
ArgumentSpec::Flag(_) => "{}",
|
||||||
})
|
})
|
||||||
@ -591,6 +593,16 @@ impl TabComplete for ArgumentSpec {
|
|||||||
.filter(|string| string.starts_with(part))
|
.filter(|string| string.starts_with(part))
|
||||||
.map(|c| c.to_string())
|
.map(|c| c.to_string())
|
||||||
.collect(),
|
.collect(),
|
||||||
|
ArgumentSpec::AssetPath(_, paths, _) => {
|
||||||
|
let depth = part.split('.').count();
|
||||||
|
paths
|
||||||
|
.iter()
|
||||||
|
.map(|path| path.as_str().split('.').take(depth).join("."))
|
||||||
|
.dedup()
|
||||||
|
.filter(|string| string.starts_with(part))
|
||||||
|
.map(|c| c.to_string())
|
||||||
|
.collect()
|
||||||
|
},
|
||||||
ArgumentSpec::Boolean(_, part, _) => ["true", "false"]
|
ArgumentSpec::Boolean(_, part, _) => ["true", "false"]
|
||||||
.iter()
|
.iter()
|
||||||
.filter(|string| string.starts_with(part))
|
.filter(|string| string.starts_with(part))
|
||||||
|
Loading…
Reference in New Issue
Block a user