/************************************************************************ ** ** @file vexceptionbadid.h ** @author Roman Telezhinsky ** @date November 15, 2013 ** ** @brief ** @copyright ** This source code is part of the Valentine project, a pattern making ** program, whose allow create and modeling patterns of clothing. ** Copyright (C) 2013 Valentina project ** All Rights Reserved. ** ** Valentina 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 3 of the License, or ** (at your option) any later version. ** ** Valentina 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 Valentina. If not, see . ** *************************************************************************/ #ifndef VEXCEPTIONBADID_H #define VEXCEPTIONBADID_H #include "vexception.h" /** * @brief The VExceptionBadId class for exception bad id */ class VExceptionBadId : public VException { public: /** * @brief VExceptionBadId exception bad id * @param what string with error * @param id id */ VExceptionBadId(const QString &what, const qint64 &id) :VException(what), id(id), key(QString()){} /** * @brief VExceptionBadId exception bad id * @param what string with error * @param key string key */ VExceptionBadId(const QString &what, const QString &key) :VException(what), id(0), key(key){} /** * @brief VExceptionBadId copy constructor * @param e exception */ VExceptionBadId(const VExceptionBadId &e) :VException(e), id(e.BadId()), key(e.BadKey()){} virtual ~VExceptionBadId() noexcept (true){} /** * @brief ErrorMessage return main error message * @return main error message */ virtual QString ErrorMessage() const; /** * @brief BadId return bad id * @return id */ inline qint64 BadId() const {return id; } /** * @brief BadKey return bad key * @return key */ inline QString BadKey() const {return key; } protected: /** * @brief id id */ qint64 id; /** * @brief key key */ QString key; }; #endif // VEXCEPTIONBADID_H