summaryrefslogtreecommitdiff
path: root/src/parameters_parser.cc
diff options
context:
space:
mode:
authorMaxime Coste <mawww@kakoune.org>2018-02-28 15:09:26 +1100
committerMaxime Coste <mawww@kakoune.org>2018-02-28 15:09:26 +1100
commitedee85a8477fd719d8dc59acf24bec234a957532 (patch)
treebeabcb0e5ca56bd5c61c80fad9efca8ec4676e5f /src/parameters_parser.cc
parent3e50d39f8eb0ef56744f0d1fa91032bd0b8129c8 (diff)
parentf43635c4df7ca91eb46538acd5e84ed19b203bf5 (diff)
Merge remote-tracking branch 'aver-d/option_display'
Diffstat (limited to 'src/parameters_parser.cc')
-rw-r--r--src/parameters_parser.cc19
1 files changed, 17 insertions, 2 deletions
diff --git a/src/parameters_parser.cc b/src/parameters_parser.cc
index 56b1e1cf..7638c246 100644
--- a/src/parameters_parser.cc
+++ b/src/parameters_parser.cc
@@ -7,11 +7,26 @@ namespace Kakoune
String generate_switches_doc(const SwitchMap& switches)
{
+ Vector<int> lengths(switches.size());
+ int i = 0;
+ for (auto& sw : switches) {
+ lengths[i++] = (int)sw.key.length() + (sw.value.takes_arg ? 5: 0);
+ }
+ int maxlen = *std::max_element(lengths.begin(), lengths.end());
+
String res;
- for (auto& sw : switches)
- res += format("-{} {}: {}\n", sw.key,
+ i = 0;
+ for (auto& sw : switches) {
+ int len = lengths[i++];
+ String pad = " ";
+ while (len++ < maxlen)
+ pad += ' ';
+ res += format(" -{} {}{}{}\n",
+ sw.key,
sw.value.takes_arg ? "<arg>" : "",
+ pad,
sw.value.description);
+ }
return res;
}