mirror of
https://github.com/RGBCube/serenity
synced 2025-05-20 14:25:08 +00:00
Kernel: Add a Process::FileDescriptions::get_if_valid(index) API
Note that this is not the same as ::at(index), which has a different precondition ("allocated" vs "valid").
This commit is contained in:
parent
c1ffc17134
commit
e9feced041
2 changed files with 26 additions and 0 deletions
|
@ -428,6 +428,29 @@ RefPtr<Process> Process::from_pid(ProcessID pid)
|
|||
});
|
||||
}
|
||||
|
||||
const Process::FileDescriptionAndFlags* Process::FileDescriptions::get_if_valid(size_t i) const
|
||||
{
|
||||
ScopedSpinLock lock(m_fds_lock);
|
||||
if (m_fds_metadatas.size() <= i)
|
||||
return nullptr;
|
||||
|
||||
if (auto& metadata = m_fds_metadatas[i]; metadata.is_valid())
|
||||
return &metadata;
|
||||
|
||||
return nullptr;
|
||||
}
|
||||
Process::FileDescriptionAndFlags* Process::FileDescriptions::get_if_valid(size_t i)
|
||||
{
|
||||
ScopedSpinLock lock(m_fds_lock);
|
||||
if (m_fds_metadatas.size() <= i)
|
||||
return nullptr;
|
||||
|
||||
if (auto& metadata = m_fds_metadatas[i]; metadata.is_valid())
|
||||
return &metadata;
|
||||
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
const Process::FileDescriptionAndFlags& Process::FileDescriptions::at(size_t i) const
|
||||
{
|
||||
ScopedSpinLock lock(m_fds_lock);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue