forked from OSchip/llvm-project
[Host] File::GetWaitableHandle() should call fileno()
If the file has m_stream, it may not have a m_descriptor. GetWaitableHandle() should call GetDescriptor(), which will call fileno(), so it will get waitable descriptor whenever one is available. Patch by: Lawrence D'Anna Differential revision: https://reviews.llvm.org/D67789 llvm-svn: 372644
This commit is contained in:
parent
869ef0a627
commit
a7d186c796
|
@ -91,7 +91,7 @@ int File::GetDescriptor() const {
|
|||
return kInvalidDescriptor;
|
||||
}
|
||||
|
||||
IOObject::WaitableHandle File::GetWaitableHandle() { return m_descriptor; }
|
||||
IOObject::WaitableHandle File::GetWaitableHandle() { return GetDescriptor(); }
|
||||
|
||||
void File::SetDescriptor(int fd, bool transfer_ownership) {
|
||||
if (IsValid())
|
||||
|
|
|
@ -2,6 +2,7 @@ set (FILES
|
|||
ConnectionFileDescriptorTest.cpp
|
||||
FileActionTest.cpp
|
||||
FileSystemTest.cpp
|
||||
FileTest.cpp
|
||||
HostInfoTest.cpp
|
||||
HostTest.cpp
|
||||
MainLoopTest.cpp
|
||||
|
|
|
@ -0,0 +1,36 @@
|
|||
//===-- FileTest.cpp --------------------------------------------*- C++ -*-===//
|
||||
//
|
||||
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||||
// See https://llvm.org/LICENSE.txt for license information.
|
||||
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "lldb/Host/File.h"
|
||||
#include "llvm/ADT/SmallString.h"
|
||||
#include "llvm/Support/FileSystem.h"
|
||||
#include "llvm/Support/FileUtilities.h"
|
||||
#include "llvm/Support/Path.h"
|
||||
#include "llvm/Support/Program.h"
|
||||
#include "gtest/gtest.h"
|
||||
|
||||
using namespace lldb;
|
||||
using namespace lldb_private;
|
||||
|
||||
TEST(File, GetWaitableHandleFileno) {
|
||||
const auto *Info = testing::UnitTest::GetInstance()->current_test_info();
|
||||
|
||||
llvm::SmallString<128> name;
|
||||
int fd;
|
||||
llvm::sys::fs::createTemporaryFile(llvm::Twine(Info->test_case_name()) + "-" +
|
||||
Info->name(),
|
||||
"test", fd, name);
|
||||
llvm::FileRemover remover(name);
|
||||
ASSERT_GE(fd, 0);
|
||||
|
||||
FILE *stream = fdopen(fd, "r");
|
||||
ASSERT_TRUE(stream);
|
||||
|
||||
File file(stream, true);
|
||||
EXPECT_EQ(file.GetWaitableHandle(), fd);
|
||||
}
|
Loading…
Reference in New Issue