mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 02:12:09 -05:00
5319e3a03f
We have a much safer and more powerful alternative now, so let's move the few users over.
57 lines
1 KiB
C++
57 lines
1 KiB
C++
/*
|
|
* Copyright (c) 2021, Peter Elliott <pelliott@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibCore/Directory.h>
|
|
#include <LibCore/LockFile.h>
|
|
#include <errno.h>
|
|
#include <fcntl.h>
|
|
#include <sys/file.h>
|
|
#include <unistd.h>
|
|
|
|
namespace Core {
|
|
|
|
LockFile::LockFile(char const* filename, Type type)
|
|
: m_filename(filename)
|
|
{
|
|
if (Core::Directory::create(LexicalPath(m_filename).parent(), Core::Directory::CreateDirectories::Yes).is_error())
|
|
return;
|
|
|
|
m_fd = open(filename, O_RDONLY | O_CREAT | O_CLOEXEC, 0666);
|
|
if (m_fd == -1) {
|
|
m_errno = errno;
|
|
return;
|
|
}
|
|
|
|
if (flock(m_fd, LOCK_NB | ((type == Type::Exclusive) ? LOCK_EX : LOCK_SH)) == -1) {
|
|
m_errno = errno;
|
|
close(m_fd);
|
|
m_fd = -1;
|
|
}
|
|
}
|
|
|
|
LockFile::~LockFile()
|
|
{
|
|
release();
|
|
}
|
|
|
|
bool LockFile::is_held() const
|
|
{
|
|
return m_fd != -1;
|
|
}
|
|
|
|
void LockFile::release()
|
|
{
|
|
if (m_fd == -1)
|
|
return;
|
|
|
|
unlink(m_filename);
|
|
flock(m_fd, LOCK_NB | LOCK_UN);
|
|
close(m_fd);
|
|
|
|
m_fd = -1;
|
|
}
|
|
|
|
}
|