summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBen Boeckel <MathStuf@gmail.com>2008-12-25 10:17:32 -0500
committerBen Boeckel <MathStuf@gmail.com>2008-12-25 10:17:32 -0500
commit1a95f514ee0ca435cb0c7ebaff22748cd3eba276 (patch)
tree053a192677181cf8d696f08d55be7ef2f0802372
parent7a625d71f8deba0c6b9e922f37b80276a54763a1 (diff)
downloadsigen-1a95f514ee0ca435cb0c7ebaff22748cd3eba276.tar.gz
sigen-1a95f514ee0ca435cb0c7ebaff22748cd3eba276.tar.xz
sigen-1a95f514ee0ca435cb0c7ebaff22748cd3eba276.zip
Added more limit checking to Rules
-rw-r--r--sigmod/Rules.cpp19
1 files changed, 16 insertions, 3 deletions
diff --git a/sigmod/Rules.cpp b/sigmod/Rules.cpp
index 0e3c260e..90f176b9 100644
--- a/sigmod/Rules.cpp
+++ b/sigmod/Rules.cpp
@@ -82,8 +82,12 @@ void Sigmod::Rules::validate()
TEST(setMaxPlayers, maxPlayers);
TEST(setMaxMoves, maxMoves);
TEST(setMaxLevel, maxLevel);
+ TEST(setMaxStages, maxStages);
if (!m_maxMoney)
emit(warning("Player cannot carry any money"));
+ else
+ TEST(setMaxMoney, maxMoney);
+ TEST(setMaxTotalWeight, maxTotalWeight);
if (m_effortValuesAllowed)
{
TEST(setMaxEVPerStat, maxEVPerStat);
@@ -251,17 +255,26 @@ void Sigmod::Rules::setMaxLevel(const int maxLevel)
void Sigmod::Rules::setMaxStages(const int maxStages)
{
- CHECK(maxStages);
+ if (maxStages < 0)
+ emit(error(bounds("maxStages", 0, INT_MAX, maxStages)));
+ else
+ CHECK(maxStages);
}
void Sigmod::Rules::setMaxMoney(const int maxMoney)
{
- CHECK(maxMoney);
+ if (maxMoney < 0)
+ emit(error(bounds("maxMoney", 0, INT_MAX, maxMoney)));
+ else
+ CHECK(maxMoney);
}
void Sigmod::Rules::setMaxTotalWeight(const int maxTotalWeight)
{
- CHECK(maxTotalWeight);
+ if (maxTotalWeight < 0)
+ emit(error(bounds("maxTotalWeight", 0, INT_MAX, maxTotalWeight)));
+ else
+ CHECK(maxTotalWeight);
}
void Sigmod::Rules::setAllowSwitchStyle(const bool allowSwitchStyle)