Support info markup spanning multiple lines
Preserve the active face accross lines Fixes #4313
This commit is contained in:
parent
e454b393cf
commit
726bec4670
|
@ -2299,11 +2299,7 @@ const CommandDesc info_cmd = {
|
|||
auto title = parser.get_switch("title").value_or(StringView{});
|
||||
if (parser.get_switch("markup"))
|
||||
context.client().info_show(parse_display_line(title, context.faces()),
|
||||
parser[0] | split<StringView>('\n')
|
||||
| transform([&](StringView s) {
|
||||
return parse_display_line(s, context.faces());
|
||||
})
|
||||
| gather<DisplayLineList>(),
|
||||
parse_display_line_list(parser[0], context.faces()),
|
||||
pos, style);
|
||||
else
|
||||
context.client().info_show(title.str(), parser[0], pos, style);
|
||||
|
|
|
@ -257,13 +257,12 @@ void DisplayBuffer::optimize()
|
|||
line.optimize();
|
||||
}
|
||||
|
||||
DisplayLine parse_display_line(StringView line, const FaceRegistry& faces, const HashMap<String, DisplayLine>& builtins)
|
||||
DisplayLine parse_display_line(StringView line, Face& face, const FaceRegistry& faces, const HashMap<String, DisplayLine>& builtins)
|
||||
{
|
||||
DisplayLine res;
|
||||
bool was_antislash = false;
|
||||
auto pos = line.begin();
|
||||
String content;
|
||||
Face face;
|
||||
for (auto it = line.begin(), end = line.end(); it != end; ++it)
|
||||
{
|
||||
const char c = *it;
|
||||
|
@ -332,4 +331,19 @@ DisplayLine parse_display_line(StringView line, const FaceRegistry& faces, const
|
|||
return res;
|
||||
}
|
||||
|
||||
DisplayLine parse_display_line(StringView line, const FaceRegistry& faces, const HashMap<String, DisplayLine>& builtins)
|
||||
{
|
||||
Face face{};
|
||||
return parse_display_line(line, face, faces, builtins);
|
||||
}
|
||||
|
||||
DisplayLineList parse_display_line_list(StringView content, const FaceRegistry& faces, const HashMap<String, DisplayLine>& builtins)
|
||||
{
|
||||
return content | split<StringView>('\n')
|
||||
| transform([&, face=Face{}](StringView s) mutable {
|
||||
return parse_display_line(s, face, faces, builtins);
|
||||
})
|
||||
| gather<DisplayLineList>();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -157,6 +157,7 @@ using DisplayLineList = Vector<DisplayLine>;
|
|||
class FaceRegistry;
|
||||
|
||||
DisplayLine parse_display_line(StringView line, const FaceRegistry& faces, const HashMap<String, DisplayLine>& builtins = {});
|
||||
DisplayLineList parse_display_line_list(StringView content, const FaceRegistry& faces, const HashMap<String, DisplayLine>& builtins = {});
|
||||
|
||||
class DisplayBuffer : public UseMemoryDomain<MemoryDomain::Display>
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue
Block a user