2 * Bittorrent Client using Qt and libtorrent.
3 * Copyright (C) 2017 Mike Tzou
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public License
7 * as published by the Free Software Foundation; either version 2
8 * of the License, or (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 * In addition, as a special exception, the copyright holders give permission to
20 * link this program with the OpenSSL project's "OpenSSL" library (or with
21 * modified versions of it that use the same license as the "OpenSSL" library),
22 * and distribute the linked executables. You must obey the GNU General Public
23 * License in all respects for all of the code used other than "OpenSSL". If you
24 * modify file(s), you may extend this exception to your version of the file(s),
25 * but you are not obligated to do so. If you do not wish to do so, delete this
26 * exception statement from your version.
33 #include <QtSystemDetection>
46 #include "base/global.h"
49 #include "base/utils/os.h"
57 // need to satisfy UniformRandomBitGenerator requirements
59 using result_type
= uint32_t;
62 : m_rtlGenRandom
{Utils::OS::loadWinAPI
<PRTLGENRANDOM
>(u
"Advapi32.dll"_s
, "SystemFunction036")}
65 qFatal("Failed to load RtlGenRandom()");
68 static constexpr result_type
min()
70 return std::numeric_limits
<result_type
>::min();
73 static constexpr result_type
max()
75 return std::numeric_limits
<result_type
>::max();
78 result_type
operator()()
81 const bool result
= m_rtlGenRandom(&buf
, sizeof(buf
));
83 qFatal("RtlGenRandom() failed");
89 using PRTLGENRANDOM
= BOOLEAN (WINAPI
*)(PVOID
, ULONG
);
90 const PRTLGENRANDOM m_rtlGenRandom
;
95 // need to satisfy UniformRandomBitGenerator requirements
97 using result_type
= uint32_t;
100 : m_randDev
{fopen("/dev/urandom", "rb")}
103 qFatal("Failed to open /dev/urandom. Reason: %s. Error code: %d.\n", std::strerror(errno
), errno
);
111 static constexpr result_type
min()
113 return std::numeric_limits
<result_type
>::min();
116 static constexpr result_type
max()
118 return std::numeric_limits
<result_type
>::max();
121 result_type
operator()() const
124 if (fread(&buf
, sizeof(buf
), 1, m_randDev
) != 1)
125 qFatal("Read /dev/urandom error. Reason: %s. Error code: %d.\n", std::strerror(errno
), errno
);
131 FILE *m_randDev
= nullptr;
136 uint32_t Utils::Random::rand(const uint32_t min
, const uint32_t max
)
138 static RandomLayer layer
;
140 // new distribution is cheap: https://stackoverflow.com/a/19036349
141 std::uniform_int_distribution
<uint32_t> uniform(min
, max
);
143 return uniform(layer
);