mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-09-30 08:41:15 +00:00
HackStudio: Add ProjectFile::create_if_needed
This commit is contained in:
parent
ba6cbf160b
commit
684cc5f027
Notes:
sideshowbarker
2024-07-18 21:41:16 +09:00
Author: https://github.com/itamar8910 Commit: https://github.com/SerenityOS/serenity/commit/684cc5f0274 Pull-request: https://github.com/SerenityOS/serenity/pull/5654 Issue: https://github.com/SerenityOS/serenity/issues/5569 Issue: https://github.com/SerenityOS/serenity/issues/5574 Issue: https://github.com/SerenityOS/serenity/issues/5634
|
@ -37,17 +37,8 @@ ProjectFile::ProjectFile(const String& name)
|
|||
|
||||
GUI::TextDocument& ProjectFile::document() const
|
||||
{
|
||||
if (!m_document) {
|
||||
m_document = CodeDocument::create(m_name);
|
||||
auto file_or_error = Core::File::open(m_name, Core::File::ReadOnly);
|
||||
if (file_or_error.is_error()) {
|
||||
warnln("Couldn't open '{}': {}", m_name, file_or_error.error());
|
||||
// This is okay though, we'll just go with an empty document and create the file when saving.
|
||||
} else {
|
||||
auto& file = *file_or_error.value();
|
||||
m_document->set_text(file.read_all());
|
||||
}
|
||||
}
|
||||
create_document_if_needed();
|
||||
VERIFY(m_document);
|
||||
return *m_document;
|
||||
}
|
||||
|
||||
|
@ -71,4 +62,27 @@ void ProjectFile::horizontal_scroll_value(int horizontal_scroll_value)
|
|||
m_horizontal_scroll_value = horizontal_scroll_value;
|
||||
}
|
||||
|
||||
CodeDocument& ProjectFile::code_document() const
|
||||
{
|
||||
create_document_if_needed();
|
||||
VERIFY(m_document);
|
||||
return *m_document;
|
||||
}
|
||||
|
||||
void ProjectFile::create_document_if_needed() const
|
||||
{
|
||||
if (m_document)
|
||||
return;
|
||||
|
||||
m_document = CodeDocument::create(m_name);
|
||||
auto file_or_error = Core::File::open(m_name, Core::File::ReadOnly);
|
||||
if (file_or_error.is_error()) {
|
||||
warnln("Couldn't open '{}': {}", m_name, file_or_error.error());
|
||||
// This is okay though, we'll just go with an empty document and create the file when saving.
|
||||
} else {
|
||||
auto& file = *file_or_error.value();
|
||||
m_document->set_text(file.read_all());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -44,6 +44,7 @@ public:
|
|||
const String& name() const { return m_name; }
|
||||
|
||||
GUI::TextDocument& document() const;
|
||||
CodeDocument& code_document() const;
|
||||
|
||||
int vertical_scroll_value() const;
|
||||
void vertical_scroll_value(int);
|
||||
|
@ -52,6 +53,7 @@ public:
|
|||
|
||||
private:
|
||||
explicit ProjectFile(const String& name);
|
||||
void create_document_if_needed() const;
|
||||
|
||||
String m_name;
|
||||
mutable RefPtr<CodeDocument> m_document;
|
||||
|
|
Loading…
Reference in a new issue