/* * Copyright (c) 2019-2020, Sergey Bugaev * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include namespace Markdown { class Document final { public: Document(OwnPtr container) : m_container(move(container)) { } String render_to_html() const; String render_to_inline_html() const; String render_for_terminal(size_t view_width = 0) const; /* * Walk recursively through the document tree. Returning `RecursionDecision::Recurse` from * `Visitor::visit` proceeds with the next element of the pre-order walk, usually a child element. * Returning `RecursionDecision::Continue` skips the subtree, and usually proceeds with the next * sibling. Returning `RecursionDecision::Break` breaks the recursion, with no further calls to * any of the `Visitor::visit` methods. * * Note that `walk()` will only return `RecursionDecision::Continue` or `RecursionDecision::Break`. */ RecursionDecision walk(Visitor&) const; static OwnPtr parse(StringView); private: OwnPtr m_container; }; }