404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.221.136.116: ~ $
/*
   +----------------------------------------------------------------------+
   | Copyright (c) The PHP Group                                          |
   +----------------------------------------------------------------------+
   | This source file is subject to version 3.01 of the PHP license,      |
   | that is bundled with this package in the file LICENSE, and is        |
   | available through the world-wide-web at the following url:           |
   | https://www.php.net/license/3_01.txt                                 |
   | If you did not receive a copy of the PHP license and are unable to   |
   | obtain it through the world-wide-web, please send a note to          |
   | license@php.net so we can mail you a copy immediately.               |
   +----------------------------------------------------------------------+
   | Authors: Rasmus Lerdorf <rasmus@php.net>                             |
   |          Zeev Suraski <zeev@php.net>                                 |
   |          Pedro Melo <melo@ip.pt>                                     |
   |          Sterling Hughes <sterling@php.net>                          |
   |                                                                      |
   | Based on code from: Shawn Cokus <Cokus@math.washington.edu>          |
   +----------------------------------------------------------------------+
 */

#ifndef PHP_RAND_H
#define	PHP_RAND_H

#include "php_lcg.h"
#include "php_mt_rand.h"

/* System Rand functions */
#ifndef RAND_MAX
#define RAND_MAX PHP_MT_RAND_MAX
#endif

#define PHP_RAND_MAX PHP_MT_RAND_MAX

/*
 * A bit of tricky math here.  We want to avoid using a modulus because
 * that simply tosses the high-order bits and might skew the distribution
 * of random values over the range.  Instead we map the range directly.
 *
 * We need to map the range from 0...M evenly to the range a...b
 * Let n = the random number and n' = the mapped random number
 *
 * Then we have: n' = a + n(b-a)/M
 *
 * We have a problem here in that only n==M will get mapped to b which
 # means the chances of getting b is much much less than getting any of
 # the other values in the range.  We can fix this by increasing our range
 # artificially and using:
 #
 #               n' = a + n(b-a+1)/M
 *
 # Now we only have a problem if n==M which would cause us to produce a
 # number of b+1 which would be bad.  So we bump M up by one to make sure
 # this will never happen, and the final algorithm looks like this:
 #
 #               n' = a + n(b-a+1)/(M+1)
 *
 * -RL
 */
#define RAND_RANGE_BADSCALING(__n, __min, __max, __tmax) \
	(__n) = (__min) + (zend_long) ((double) ( (double) (__max) - (__min) + 1.0) * ((__n) / ((__tmax) + 1.0)))

#ifdef PHP_WIN32
#define GENERATE_SEED() (((zend_long) ((zend_ulong) time(NULL) * (zend_ulong) GetCurrentProcessId())) ^ ((zend_long) (1000000.0 * php_combined_lcg())))
#else
#define GENERATE_SEED() (((zend_long) ((zend_ulong) time(NULL) * (zend_ulong) getpid())) ^ ((zend_long) (1000000.0 * php_combined_lcg())))
#endif

PHPAPI void php_srand(zend_long seed);
PHPAPI zend_long php_rand(void);

#endif	/* PHP_RAND_H */

Filemanager

Name Type Size Permission Actions
base64.h File 3.59 KB 0644
basic_functions.h File 4.87 KB 0644
basic_functions_arginfo.h File 125.21 KB 0644
crc32.h File 4.79 KB 0644
crc32_x86.h File 1.82 KB 0644
credits.h File 1.53 KB 0644
credits_ext.h File 5.24 KB 0644
credits_sapi.h File 835 B 0644
crypt_blowfish.h File 790 B 0644
crypt_freesec.h File 662 B 0644
css.h File 1.04 KB 0644
datetime.h File 1.14 KB 0644
dir_arginfo.h File 1.83 KB 0644
dl.h File 1.46 KB 0644
dl_arginfo.h File 269 B 0644
exec.h File 1.27 KB 0644
file.h File 3.93 KB 0644
flock_compat.h File 2.06 KB 0644
fsock.h File 1.22 KB 0644
head.h File 1.53 KB 0644
hrtime.h File 2.31 KB 0644
html.h File 2.34 KB 0644
html_tables.h File 472.26 KB 0644
info.h File 22.94 KB 0644
md5.h File 2.02 KB 0644
pack.h File 1.05 KB 0644
pageinfo.h File 1.15 KB 0644
php_array.h File 2.24 KB 0644
php_assert.h File 1.24 KB 0644
php_browscap.h File 1.11 KB 0644
php_crypt.h File 1.37 KB 0644
php_crypt_r.h File 1.64 KB 0644
php_dir.h File 1.28 KB 0644
php_dns.h File 2.58 KB 0644
php_ext_syslog.h File 1.17 KB 0644
php_filestat.h File 2.1 KB 0644
php_fopen_wrappers.h File 1.79 KB 0644
php_http.h File 1.33 KB 0644
php_image.h File 2.17 KB 0644
php_incomplete_class.h File 2.15 KB 0644
php_lcg.h File 1.31 KB 0644
php_mail.h File 2.16 KB 0644
php_math.h File 3.55 KB 0644
php_mt_rand.h File 1.81 KB 0644
php_net.h File 1.14 KB 0644
php_password.h File 2.76 KB 0644
php_rand.h File 3.05 KB 0644
php_random.h File 1.86 KB 0644
php_smart_string.h File 1.13 KB 0644
php_smart_string_public.h File 1.14 KB 0644
php_standard.h File 1.91 KB 0644
php_string.h File 3.95 KB 0644
php_uuencode.h File 1.18 KB 0644
php_var.h File 3.41 KB 0644
php_versioning.h File 1.18 KB 0644
proc_open.h File 1.67 KB 0644
quot_print.h File 1.23 KB 0644
scanf.h File 1.95 KB 0644
sha1.h File 1.62 KB 0644
streamsfuncs.h File 1.11 KB 0644
url.h File 2.08 KB 0644
url_scanner_ex.h File 2.32 KB 0644
user_filters_arginfo.h File 2.45 KB 0644