mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 06:44:58 +00:00

This commit un-deprecates DeprecatedString, and repurposes it as a byte string. As the null state has already been removed, there are no other particularly hairy blockers in repurposing this type as a byte string (what it _really_ is). This commit is auto-generated: $ xs=$(ack -l \bDeprecatedString\b\|deprecated_string AK Userland \ Meta Ports Ladybird Tests Kernel) $ perl -pie 's/\bDeprecatedString\b/ByteString/g; s/deprecated_string/byte_string/g' $xs $ clang-format --style=file -i \ $(git diff --name-only | grep \.cpp\|\.h) $ gn format $(git ls-files '*.gn' '*.gni')
68 lines
1.6 KiB
C++
68 lines
1.6 KiB
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include "ProjectFile.h"
|
|
#include <LibCore/File.h>
|
|
|
|
namespace HackStudio {
|
|
|
|
ProjectFile::ProjectFile(ByteString const& name)
|
|
: m_name(name)
|
|
{
|
|
}
|
|
|
|
GUI::TextDocument& ProjectFile::document() const
|
|
{
|
|
create_document_if_needed();
|
|
VERIFY(m_document);
|
|
return *m_document;
|
|
}
|
|
|
|
int ProjectFile::vertical_scroll_value() const
|
|
{
|
|
return m_vertical_scroll_value;
|
|
}
|
|
|
|
void ProjectFile::vertical_scroll_value(int vertical_scroll_value)
|
|
{
|
|
m_vertical_scroll_value = vertical_scroll_value;
|
|
}
|
|
|
|
int ProjectFile::horizontal_scroll_value() const
|
|
{
|
|
return m_horizontal_scroll_value;
|
|
}
|
|
|
|
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::OpenMode::Read);
|
|
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.
|
|
return;
|
|
}
|
|
|
|
auto& file = *file_or_error.value();
|
|
m_could_render_text = m_document->set_text(file.read_until_eof().release_value_but_fixme_should_propagate_errors());
|
|
}
|
|
|
|
}
|