1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-25 01:42:06 +00:00
serenity/Userland/Libraries/LibCore/Resource.cpp

109 lines
2.8 KiB
C++

/*
* Copyright (c) 2023, Andrew Kaster <akaster@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <AK/LexicalPath.h>
#include <LibCore/Resource.h>
#include <LibCore/ResourceImplementation.h>
#include <LibCore/System.h>
namespace Core {
Resource::Resource(String path, Scheme scheme, NonnullOwnPtr<Core::MappedFile> file)
: m_path(move(path))
, m_scheme(scheme)
, m_data(move(file))
{
}
Resource::Resource(String path, Scheme scheme, ByteBuffer buffer)
: m_path(move(path))
, m_scheme(scheme)
, m_data(move(buffer))
{
}
Resource::Resource(String path, Scheme scheme, DirectoryTag)
: m_path(move(path))
, m_scheme(scheme)
, m_data(DirectoryTag {})
{
}
ErrorOr<NonnullRefPtr<Resource>> Resource::load_from_filesystem(StringView path)
{
auto filepath = LexicalPath(path);
if (filepath.is_absolute())
return load_from_uri(TRY(String::formatted("file://{}", path)));
auto cwd = TRY(Core::System::getcwd());
return load_from_uri(TRY(String::formatted("file://{}", filepath.prepend(cwd).string())));
}
ErrorOr<NonnullRefPtr<Resource>> Resource::load_from_uri(StringView uri)
{
return ResourceImplementation::the().load_from_uri(uri);
}
String Resource::uri() const
{
return MUST(String::formatted("{}://{}", m_scheme == Scheme::Resource ? "resource"sv : "file"sv, m_path));
}
String Resource::filesystem_path() const
{
return ResourceImplementation::the().filesystem_path(*this);
}
String Resource::file_url() const
{
if (m_scheme == Scheme::File)
return uri();
return MUST(String::formatted("file://{}", filesystem_path()));
}
String Resource::filename() const
{
return MUST(String::from_utf8(LexicalPath(m_path.bytes_as_string_view()).basename()));
}
Vector<String> Resource::children() const
{
return ResourceImplementation::the().child_names(*this);
}
ByteBuffer Resource::clone_data() const
{
return m_data.visit(
[](NonnullOwnPtr<Core::MappedFile> const& file) { return MUST(ByteBuffer::copy(file->bytes())); },
[](ByteBuffer const& buffer) { return buffer; },
[](DirectoryTag) -> ByteBuffer { VERIFY_NOT_REACHED(); });
}
ByteBuffer Resource::release_data() &&
{
VERIFY(!m_data.has<DirectoryTag>());
if (m_data.has<NonnullOwnPtr<Core::MappedFile>>())
return MUST(ByteBuffer::copy(m_data.get<NonnullOwnPtr<Core::MappedFile>>()->bytes()));
return move(m_data).get<ByteBuffer>();
}
ReadonlyBytes Resource::data() const
{
return m_data.visit(
[](NonnullOwnPtr<Core::MappedFile> const& file) { return file->bytes(); },
[](ByteBuffer const& buffer) { return buffer.bytes(); },
[](DirectoryTag) -> ReadonlyBytes { VERIFY_NOT_REACHED(); });
}
FixedMemoryStream Resource::stream() const
{
return FixedMemoryStream(data());
}
}