2019-11-20 16:21:32 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
/*
|
|
|
|
Copyright (C) 2010-2019 EDuke32 developers and contributors
|
|
|
|
Copyright (C) 2019 sirlemonhead, Nuke.YKT
|
|
|
|
This file is part of PCExhumed.
|
|
|
|
PCExhumed is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License version 2
|
|
|
|
as published by the Free Software Foundation.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
//-------------------------------------------------------------------------
|
2019-11-22 23:11:37 +00:00
|
|
|
#include "ns.h"
|
2019-08-26 03:59:14 +00:00
|
|
|
#include "random.h"
|
2019-12-26 21:00:04 +00:00
|
|
|
#include "exhumed.h"
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-11-22 23:11:37 +00:00
|
|
|
BEGIN_PS_NS
|
|
|
|
|
2019-08-26 03:59:14 +00:00
|
|
|
int randA = 0;
|
|
|
|
int randB = 0x11111111;
|
|
|
|
int randC = 0x1010101;
|
|
|
|
|
2019-12-26 21:00:04 +00:00
|
|
|
static SavegameHelper sgh("rand",
|
|
|
|
SV(randA),
|
|
|
|
SV(randB),
|
|
|
|
SV(randC),
|
|
|
|
nullptr);
|
|
|
|
|
2019-08-26 03:59:14 +00:00
|
|
|
|
|
|
|
void InitRandom()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
randA = 0;
|
|
|
|
randB = 0x11111111;
|
|
|
|
randC = 0x1010101;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// TODO - checkme
|
|
|
|
int RandomBit()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
randA = (randA >> 1) | (((randA ^ ((randA >> 1) ^ (randA >> 2) ^ (randA >> 31) ^ (randA >> 6) ^ (randA >> 4))) & 1) << 31);
|
|
|
|
randB = (randB >> 1) | ((((randB >> 2) ^ (randB >> 30)) & 1) << 30);
|
|
|
|
randC = (randC >> 1) | ((((randC >> 1) ^ (randC >> 28)) & 1) << 28);
|
|
|
|
return ((randA == 0) & randC | (randB & randA)) & 1;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
char RandomByte()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
char randByte = RandomBit() << 7;
|
|
|
|
randByte |= RandomBit() << 6;
|
|
|
|
randByte |= RandomBit() << 5;
|
|
|
|
randByte |= RandomBit() << 4;
|
|
|
|
randByte |= RandomBit() << 3;
|
|
|
|
randByte |= RandomBit() << 2;
|
|
|
|
randByte |= RandomBit() << 1;
|
|
|
|
randByte |= RandomBit();
|
|
|
|
return randByte;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
2019-12-02 22:12:32 +00:00
|
|
|
uint16_t RandomWord()
|
2019-08-26 03:59:14 +00:00
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
short randWord = RandomByte() << 8;
|
|
|
|
randWord |= RandomByte();
|
|
|
|
return randWord;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
int RandomLong()
|
2019-08-26 03:59:14 +00:00
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
int randLong = RandomWord() << 16;
|
|
|
|
randLong |= RandomWord();
|
|
|
|
return randLong;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int RandomSize(int nSize)
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
int randSize = 0;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
while (nSize > 0)
|
|
|
|
{
|
|
|
|
randSize = randSize * 2 | RandomBit();
|
|
|
|
nSize--;
|
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
return randSize;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
2019-11-22 23:11:37 +00:00
|
|
|
END_PS_NS
|