diff options
author | Alon Zakai <alonzakai@gmail.com> | 2014-01-30 13:46:31 -0800 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2014-01-30 13:46:31 -0800 |
commit | 00ebebfd6c09c4173330c0b661dba6e52a73c0c2 (patch) | |
tree | db856b440f05dcdd7c7771689a63c8f22affc91b /src | |
parent | 5cae031ff9a7551b6f244b110303e26bfa54076b (diff) | |
parent | 31ae7a3a6ea6841f3eb93b23af1de328e2805e84 (diff) |
Merge branch 'rand' of github.com:coolwanglu/emscripten into incoming
Diffstat (limited to 'src')
-rw-r--r-- | src/library.js | 30 |
1 files changed, 24 insertions, 6 deletions
diff --git a/src/library.js b/src/library.js index 4c0f790f..64da5444 100644 --- a/src/library.js +++ b/src/library.js @@ -3447,13 +3447,31 @@ LibraryManager.library = { return limit; }, - // Use browser's Math.random(). We can't set a seed, though. - srand: function(seed) {}, // XXX ignored + __rand_seed: 'allocate([0x0273459b, 0, 0, 0], "i32", ALLOC_STATIC)', + srand__deps: ['__rand_seed'], + srand: function(seed) { + {{{ makeSetValue('___rand_seed', 0, 'seed', 'i32') }}} + }, + rand_r__deps: ['__rand_seed'], + rand_r: function(seedp) { + var val = {{{ makeGetValue('seedp', 0, 'i32') }}}; + // calculate val * 31010991 + 0x676e6177 + // i32 multiplication will be rounded by javascript + var valh = val >> 16; + var vall = val & 0xffff; + + var c = 31010991; + var ch = c >> 16; + var cl = c & 0xffff; + + val = (((valh * cl + vall * ch) << 16) + vall * cl + 0x676e6177) & 0x7fffffff; + + {{{ makeSetValue('seedp', 0, 'val', 'i32') }}} + return val; + }, + rand__deps: ['rand_r'], rand: function() { - return Math.floor(Math.random()*0x80000000); - }, - rand_r: function(seed) { // XXX ignores the seed - return Math.floor(Math.random()*0x80000000); + return _rand_r(___rand_seed); }, drand48: function() { |