Kernel: Edit lock scopes and make string copy able to fail
This commit is contained in:
parent
a2f5ad7bed
commit
b6c4a2dbf1
|
@ -577,8 +577,8 @@ namespace Kernel
|
||||||
BAN::String absolute_source, absolute_target;
|
BAN::String absolute_source, absolute_target;
|
||||||
{
|
{
|
||||||
LockGuard _(m_lock);
|
LockGuard _(m_lock);
|
||||||
absolute_source = TRY(absolute_path_of(source));
|
TRY(absolute_source.append(TRY(absolute_path_of(source))));
|
||||||
absolute_target = TRY(absolute_path_of(target));
|
TRY(absolute_target.append(TRY(absolute_path_of(target))));
|
||||||
}
|
}
|
||||||
TRY(VirtualFileSystem::get().mount(m_credentials, absolute_source, absolute_target));
|
TRY(VirtualFileSystem::get().mount(m_credentials, absolute_source, absolute_target));
|
||||||
return {};
|
return {};
|
||||||
|
@ -593,6 +593,7 @@ namespace Kernel
|
||||||
|
|
||||||
BAN::ErrorOr<long> Process::sys_stat(BAN::StringView path, struct stat* out, int flags)
|
BAN::ErrorOr<long> Process::sys_stat(BAN::StringView path, struct stat* out, int flags)
|
||||||
{
|
{
|
||||||
|
LockGuard _(m_lock);
|
||||||
int fd = TRY(sys_open(path, flags));
|
int fd = TRY(sys_open(path, flags));
|
||||||
auto ret = sys_fstat(fd, out);
|
auto ret = sys_fstat(fd, out);
|
||||||
MUST(sys_close(fd));
|
MUST(sys_close(fd));
|
||||||
|
@ -935,18 +936,14 @@ namespace Kernel
|
||||||
|
|
||||||
BAN::ErrorOr<BAN::String> Process::absolute_path_of(BAN::StringView path) const
|
BAN::ErrorOr<BAN::String> Process::absolute_path_of(BAN::StringView path) const
|
||||||
{
|
{
|
||||||
|
ASSERT(m_lock.is_locked());
|
||||||
|
|
||||||
if (path.empty() || path == "."sv)
|
if (path.empty() || path == "."sv)
|
||||||
{
|
|
||||||
LockGuard _(m_lock);
|
|
||||||
return m_working_directory;
|
return m_working_directory;
|
||||||
}
|
|
||||||
|
|
||||||
BAN::String absolute_path;
|
BAN::String absolute_path;
|
||||||
if (path.front() != '/')
|
if (path.front() != '/')
|
||||||
{
|
|
||||||
LockGuard _(m_lock);
|
|
||||||
TRY(absolute_path.append(m_working_directory));
|
TRY(absolute_path.append(m_working_directory));
|
||||||
}
|
|
||||||
|
|
||||||
if (!absolute_path.empty() && absolute_path.back() != '/')
|
if (!absolute_path.empty() && absolute_path.back() != '/')
|
||||||
TRY(absolute_path.push_back('/'));
|
TRY(absolute_path.push_back('/'));
|
||||||
|
|
Loading…
Reference in New Issue