Mercurial > might-and-magic-trilogy
view Random.cpp @ 27:be2066176d89
On level initialization
author | Nomad |
---|---|
date | Tue, 16 Oct 2012 01:31:05 +0200 |
parents | 8b8875f5b359 |
children |
line wrap: on
line source
#include <math.h> #include "Random.h" #include "mm7_data.h" struct Random *pRnd; // idb //----- (004BE59E) -------------------------------------------------------- void Random::SetRange(int min, int max) { this->min = min; this->range = max - min; } //----- (004BE5B1) -------------------------------------------------------- double Random::GetRandom() { Random *v1; // esi@1 double v2; // st7@1 double v3; // st7@1 v1 = this; this->field_0[3] = this->field_0[2]; this->field_0[2] = this->field_0[1]; v2 = this->field_0[0]; this->field_0[1] = v2; v3 = this->field_0[3] * 1492.0 + this->field_0[2] * 1776.0 + this->field_0[3] * 2111111111.0 + v2 * 5115.0 + this->field_0[4]; v1->field_0[0] = v3 - floor(v3); v1->field_0[4] = v3 * 2.328306436538696e-10; return v3 - v3; } //----- (004BE623) -------------------------------------------------------- int Random::GetInRange() { Random *v1; // esi@1 float v2; // ST10_4@1 double v3; // ST04_8@1 int floored_random; // ecx@1 v1 = this; v2 = GetRandom() * (double)this->range; v3 = v2 + 6.7553994e15; floored_random = LODWORD(v3); if ( SLODWORD(v3) >= v1->range ) floored_random = v1->range; return floored_random + v1->min; } //----- (004BE65D) -------------------------------------------------------- void Random::Initialize(int seed) { int v2; // eax@1 Random *this_; // esi@1 signed int v4; // ecx@3 unsigned int v5; // eax@4 signed int v6; // edi@5 v2 = seed; this_ = this; if ( !seed ) v2 = -1; v4 = 0; do { v5 = (((v2 << 13) ^ (unsigned int)v2) >> 17) ^ (v2 << 13) ^ v2; v2 = 32 * v5 ^ v5; this_->field_0[v4++] = (double)(unsigned int)v2 * 2.328306436538696e-10; } while ( v4 < 5 ); v6 = 19; do { GetRandom(); --v6; } while ( v6 ); }