diff options
| author | Maxime Coste <mawww@kakoune.org> | 2018-02-28 15:09:26 +1100 |
|---|---|---|
| committer | Maxime Coste <mawww@kakoune.org> | 2018-02-28 15:09:26 +1100 |
| commit | edee85a8477fd719d8dc59acf24bec234a957532 (patch) | |
| tree | beabcb0e5ca56bd5c61c80fad9efca8ec4676e5f /src/parameters_parser.cc | |
| parent | 3e50d39f8eb0ef56744f0d1fa91032bd0b8129c8 (diff) | |
| parent | f43635c4df7ca91eb46538acd5e84ed19b203bf5 (diff) | |
Merge remote-tracking branch 'aver-d/option_display'
Diffstat (limited to 'src/parameters_parser.cc')
| -rw-r--r-- | src/parameters_parser.cc | 19 |
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; } |
