FactMetaData.h 4.57 KB
Newer Older
Don Gagne's avatar
Don Gagne committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
/*=====================================================================
 
 QGroundControl Open Source Ground Control Station
 
 (c) 2009 - 2014 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 
 This file is part of the QGROUNDCONTROL project
 
 QGROUNDCONTROL 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.
 
 QGROUNDCONTROL 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 QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
 
 ======================================================================*/

/// @file
///     @author Don Gagne <don@thegagnes.com>

#ifndef FactMetaData_H
#define FactMetaData_H

#include <QObject>
#include <QString>
#include <QVariant>

/// Holds the meta data associated with a Fact.
///
/// Holds the meta data associated with a Fact. This is kept in a seperate object from the Fact itself
/// since you may have multiple instances of the same Fact. But there is only ever one FactMetaData
/// instance or each Fact.
class FactMetaData : public QObject
{
    Q_OBJECT
    
public:
    typedef enum {
        valueTypeUint8,
        valueTypeInt8,
        valueTypeUint16,
        valueTypeInt16,
        valueTypeUint32,
        valueTypeInt32,
        valueTypeFloat,
        valueTypeDouble
    } ValueType_t;
    
Don Gagne's avatar
Don Gagne committed
55
    FactMetaData(QObject* parent = NULL);
56
    FactMetaData(ValueType_t type, QObject* parent = NULL);
Don Gagne's avatar
Don Gagne committed
57 58 59
    FactMetaData(const FactMetaData& other, QObject* parent = NULL);

    const FactMetaData& operator=(const FactMetaData& other);
60 61

    // Property accessors
62 63 64
    QString     name(void) const                    { return _name; }
    QString     group(void) const                   { return _group; }
    ValueType_t type(void) const                    { return _type; }
65
    QVariant    defaultValue(void) const;
66 67 68 69 70 71 72 73 74
    bool		defaultValueAvailable(void) const   { return _defaultValueAvailable; }
    QString     shortDescription(void) const        { return _shortDescription; }
    QString     longDescription(void) const         { return _longDescription;}
    QString     units(void) const                   { return _units; }
    QVariant    min(void) const                     { return _min; }
    QVariant    max(void) const                     { return _max; }
    bool        minIsDefaultForType(void) const     { return _minIsDefaultForType; }
    bool        maxIsDefaultForType(void) const     { return _maxIsDefaultForType; }
    int         decimalPlaces(void) const           { return _decimalPlaces; }
75 76

    // Property setters
Don Gagne's avatar
Don Gagne committed
77
    void setName(const QString& name)                           { _name = name; }
78 79 80 81 82
    void setGroup(const QString& group)                         { _group = group; }
    void setDefaultValue(const QVariant& defaultValue);
    void setShortDescription(const QString& shortDescription)   { _shortDescription = shortDescription; }
    void setLongDescription(const QString& longDescription)     { _longDescription = longDescription;}
    void setUnits(const QString& units)                         { _units = units; }
83 84
    void setMin(const QVariant& max);
    void setMax(const QVariant& max);
85
    void setDecimalPlaces(int decimalPlaces)                    { _decimalPlaces = decimalPlaces; }
Don Gagne's avatar
Don Gagne committed
86 87 88 89 90 91 92 93
    
    /// Converts the specified value, validating against meta data
    ///     @param value Value to convert, can be string
    ///     @param convertOnly true: convert to correct type only, do not validate against meta data
    ///     @param typeValue Converted value, correctly typed
    ///     @param errorString Error string if convert fails
    /// @returns false: Convert failed, errorString set
    bool convertAndValidate(const QVariant& value, bool convertOnly, QVariant& typedValue, QString& errorString);
Don Gagne's avatar
Don Gagne committed
94

95 96
    static const int defaultDecimalPlaces = 3;

97
private:
98 99
    QVariant _minForType(void) const;
    QVariant _maxForType(void) const;
100
    
Don Gagne's avatar
Don Gagne committed
101
    QString     _name;
102 103 104 105 106 107 108 109 110
    QString     _group;
    ValueType_t _type;
    QVariant    _defaultValue;
	bool		_defaultValueAvailable;
    QString     _shortDescription;
    QString     _longDescription;
    QString     _units;
    QVariant    _min;
    QVariant    _max;
Don Gagne's avatar
Don Gagne committed
111 112
    bool        _minIsDefaultForType;
    bool        _maxIsDefaultForType;
113
    int         _decimalPlaces;
Don Gagne's avatar
Don Gagne committed
114 115
};

116
#endif