diff options
| author | 2022-04-29 10:48:09 +0200 | |
|---|---|---|
| committer | 2022-04-29 10:48:09 +0200 | |
| commit | 07c5f6ec23fcf9237a24e71adcfacabce677f818 (patch) | |
| tree | 588e8c5f82b9163181fad3581f610e6f1d88cba4 /src/libparser/validatorlist.h | |
| parent | a9153f1615a842cfb9e9bcda4d9071e202618569 (diff) | |
| download | OneRoll-07c5f6ec23fcf9237a24e71adcfacabce677f818.tar.gz OneRoll-07c5f6ec23fcf9237a24e71adcfacabce677f818.zip | |
Change file organization.
Diffstat (limited to 'src/libparser/validatorlist.h')
| -rw-r--r-- | src/libparser/validatorlist.h | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/src/libparser/validatorlist.h b/src/libparser/validatorlist.h new file mode 100644 index 0000000..ad2c9d4 --- /dev/null +++ b/src/libparser/validatorlist.h @@ -0,0 +1,99 @@ +/*************************************************************************** + * Copyright (C) 2014 by Renaud Guezennec * + * http://www.rolisteam.org/contact * + * * + * This file is part of DiceParser * + * * + * DiceParser is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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., * + * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + ***************************************************************************/ +#ifndef VALIDATORLIST_H +#define VALIDATORLIST_H + +#include <QList> +#include <QString> +#include <QVector> +#include <Qt> + +#include <diceparser/diceparserhelper.h> +#include <functional> + +class Validator; +class Die; +class Result; + +class ValidatorResult +{ + +public: + ValidatorResult(); + + const std::vector<std::pair<Die*, qint64>>& validDice() const; + std::vector<std::pair<Die*, qint64>>& validDiceRef(); + void setValidDice(const std::vector<std::pair<Die*, qint64>>& pairs); + void appendValidDice(Die* die, qint64 sum); + + void setAllTrue(bool allTrue); + bool allTrue() const; + + bool contains(Die* die); + +private: + std::vector<std::pair<Die*, qint64>> m_validDice; + bool m_allTrue= false; + + /*friend bool operator>(const ValidatorResult& a, const ValidatorResult& b) + { + if(a.m_validDice.size() > b.m_validDice.size()) + return true; + if(a.m_validDice.size() == b.m_validDice.size()) + { + if(!a.m_allTrue && b.m_allTrue) + return true; + else + return false; + } + return false; + }*/ +}; +/** + * @brief The BooleanCondition class is a Validator class checking validity from logic expression. + * It manages many operators (see : @ref LogicOperator). + */ +class ValidatorList +{ +public: + ValidatorList(); + virtual ~ValidatorList(); + + virtual qint64 hasValid(Die* b, bool recursive, bool unhighlight= false) const; + + void setOperationList(const QVector<Dice::LogicOperation>& m); + void setValidators(const QList<Validator*>& valids); + + QString toString(); + + virtual Dice::CONDITION_STATE isValidRangeSize(const std::pair<qint64, qint64>& range) const; + + virtual ValidatorList* getCopy() const; + + void validResult(Result* result, bool recursive, bool unlight, std::function<void(Die*, qint64)> functor) const; + +private: + QVector<Dice::LogicOperation> m_operators; + QList<Validator*> m_validatorList; +}; + +#endif // VALIDATORLIST_H |