
random_device::random_device(const string&) wrongly assumes that open can only validly return a file descriptor greater than zero. This results in random_device believing that it didn't successfully open the device causing it to throw in it's constructor, this ends up leaking a file descriptor. The fix is simple, don't error on file descriptors which are zero. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@210060 91177308-0d34-0410-b5e6-96231b3b80d8
50 lines
1.0 KiB
C++
50 lines
1.0 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
// Source Licenses. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// <random>
|
|
|
|
// class random_device;
|
|
|
|
// explicit random_device(const string& token = "/dev/urandom");
|
|
|
|
#include <random>
|
|
#include <cassert>
|
|
#include <unistd.h>
|
|
|
|
int main()
|
|
{
|
|
try
|
|
{
|
|
std::random_device r("wrong file");
|
|
assert(false);
|
|
}
|
|
catch (const std::system_error& e)
|
|
{
|
|
}
|
|
{
|
|
std::random_device r;
|
|
}
|
|
{
|
|
int ec;
|
|
ec = close(STDIN_FILENO);
|
|
assert(!ec);
|
|
ec = close(STDOUT_FILENO);
|
|
assert(!ec);
|
|
ec = close(STDERR_FILENO);
|
|
assert(!ec);
|
|
std::random_device r;
|
|
}
|
|
{
|
|
std::random_device r("/dev/urandom");;
|
|
}
|
|
{
|
|
std::random_device r("/dev/random");;
|
|
}
|
|
}
|