diff --git a/Userland/Libraries/LibManual/Node.h b/Userland/Libraries/LibManual/Node.h index cf72a984a2..5fcd241121 100644 --- a/Userland/Libraries/LibManual/Node.h +++ b/Userland/Libraries/LibManual/Node.h @@ -25,6 +25,7 @@ public: virtual ErrorOr name() const = 0; virtual bool is_page() const { return false; } virtual bool is_open() const { return false; } + virtual ErrorOr path() const = 0; // Backend for the command-line argument format that Help and man accept. Handles: // [/path/to/documentation.md] (no second argument) diff --git a/Userland/Libraries/LibManual/PageNode.h b/Userland/Libraries/LibManual/PageNode.h index e505e228a0..3dc33d9a67 100644 --- a/Userland/Libraries/LibManual/PageNode.h +++ b/Userland/Libraries/LibManual/PageNode.h @@ -28,7 +28,7 @@ public: virtual ErrorOr name() const override { return m_page; }; virtual bool is_page() const override { return true; } - ErrorOr path() const; + virtual ErrorOr path() const override; static ErrorOr> help_index_page(); diff --git a/Userland/Libraries/LibManual/SectionNode.h b/Userland/Libraries/LibManual/SectionNode.h index 14ddd5bbda..d0d4476eaa 100644 --- a/Userland/Libraries/LibManual/SectionNode.h +++ b/Userland/Libraries/LibManual/SectionNode.h @@ -32,7 +32,7 @@ public: virtual Node const* parent() const override { return nullptr; } virtual ErrorOr name() const override; String const& section_name() const { return m_section; } - ErrorOr path() const; + virtual ErrorOr path() const override; virtual bool is_open() const override { return m_open; } void set_open(bool open); @@ -40,6 +40,7 @@ public: static ErrorOr> try_create_from_number(StringView section_number); protected: + // In this class, the section is a number, but in lower sections it might be the same as the name. String m_section; String m_name;