2022-05-26 18:48:09 +02:00

120 lines
1.5 KiB
C++

//
// FILE: simon.cpp
// AUTHOR: Rob Tillaart
// DATE: 2022-05-26
// VERSION: 0.1.0
// PURPOSE: Arduino library for SIMON
// URL: https://github.com/RobTillaart/SIMON
//
// HISTORY:
// 0.1.0 2022-05-26 initial version
#include "simon.h"
SIMON::SIMON()
{
_idx = 0;
_size = 0;
}
bool SIMON::setSequence(uint8_t * array, uint8_t length)
{
if ((length > _maxSize) || (array == NULL))
{
_size = 0;
return false;
}
for (uint8_t i = 0; i < length; i++)
{
_sequence[i] = array[i];
}
_size = length;
return true;
}
bool SIMON::generateSequence(uint8_t length, uint8_t minimum, uint8_t maximum)
{
if (length > _maxSize)
{
_size = 0;
return false;
}
randomSeed(micros());
for (uint8_t i = 0; i < length; i++)
{
_sequence[i] = random(minimum, maximum + 1);
}
_size = length;
return true;
}
uint8_t SIMON::getSequence(uint8_t * array)
{
for (uint8_t i = 0; i < _size; i++)
{
array[i] = _sequence[i];
}
return _size;
}
void SIMON::clear()
{
_idx = 0;
}
void SIMON::add(uint8_t value)
{
if (_idx == _maxSize)
{
_idx = 0;
}
_answer[_idx] = value;
_idx++;
}
bool SIMON::verify()
{
return verify(_answer, _idx);
}
bool SIMON::verify(uint8_t * array, uint8_t length)
{
if (length != _size) return false;
for (uint8_t i = 0; i < _size; i++)
{
if (_sequence[i] != array[i]) return false;
}
return true;
}
uint8_t SIMON::length()
{
return _idx;
}
uint8_t SIMON::size()
{
return _size;
}
uint8_t SIMON::maxSize()
{
return _maxSize;
}
// -- END OF FILE --