[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:
Jonas Devlieghere 2019-09-23 19:34:26 +00:00
parent 869ef0a627
commit a7d186c796
3 changed files with 38 additions and 1 deletions

View File

@ -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())

View File

@ -2,6 +2,7 @@ set (FILES
ConnectionFileDescriptorTest.cpp
FileActionTest.cpp
FileSystemTest.cpp
FileTest.cpp
HostInfoTest.cpp
HostTest.cpp
MainLoopTest.cpp

View File

@ -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);
}