geodecoderstatus.h 5.17 KB
Newer Older
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 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
/**
******************************************************************************
*
* @file       geodecoderstatus.h
* @author     The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
* @brief      
* @see        The GNU Public License (GPL) Version 3
* @defgroup   OPMapWidget
* @{
* 
*****************************************************************************/
/* 
* This program 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.
* 
* 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 GEODECODERSTATUS_H
#define GEODECODERSTATUS_H

#include <QObject>
#include <QMetaObject>
#include <QMetaEnum>
#include <QStringList>
namespace core {
    class GeoCoderStatusCode:public QObject
    {
        Q_OBJECT
        Q_ENUMS(Types)
    public:
                enum Types
        {
            /// <summary>
            /// unknow response
            /// </summary>
            Unknow = -1,

            /// <summary>
            /// No errors occurred; the address was successfully parsed and its geocode has been returned.
            /// </summary>
            G_GEO_SUCCESS=200,

            /// <summary>
            /// A directions request could not be successfully parsed.
            /// For example, the request may have been rejected if it contained more than the maximum number of waypoints allowed.
            /// </summary>
            G_GEO_BAD_REQUEST=400,

            /// <summary>
            /// A geocoding or directions request could not be successfully processed, yet the exact reason for the failure is not known.
            /// </summary>
            G_GEO_SERVER_ERROR=500,

            /// <summary>
            /// The HTTP q parameter was either missing or had no value.
            /// For geocoding requests, this means that an empty address was specified as input. For directions requests, this means that no query was specified in the input.
            /// </summary>
            G_GEO_MISSING_QUERY=601,

            /// <summary>
            /// Synonym for G_GEO_MISSING_QUERY.
            /// </summary>
            G_GEO_MISSING_ADDRESS=601,

            /// <summary>
            ///  No corresponding geographic location could be found for the specified address.
            ///  This may be due to the fact that the address is relatively new, or it may be incorrect.
            /// </summary>
            G_GEO_UNKNOWN_ADDRESS=602,

            /// <summary>
            /// The geocode for the given address or the route for the given directions query cannot be returned due to legal or contractual reasons.
            /// </summary>
            G_GEO_UNAVAILABLE_ADDRESS=603,

            /// <summary>
            /// The GDirections object could not compute directions between the points mentioned in the query.
            /// This is usually because there is no route available between the two points, or because we do not have data for routing in that region.
            /// </summary>
            G_GEO_UNKNOWN_DIRECTIONS=604,

            /// <summary>
            /// The given key is either invalid or does not match the domain for which it was given.
            /// </summary>
            G_GEO_BAD_KEY=610,

            /// <summary>
            /// The given key has gone over the requests limit in the 24 hour period or has submitted too many requests in too short a period of time.
            /// If you're sending multiple requests in parallel or in a tight loop, use a timer or pause in your code to make sure you don't send the requests too quickly.
            /// </summary>
            G_GEO_TOO_MANY_QUERIES=620

        };
        static QString StrByType(Types const& value)
        {
            QMetaObject metaObject = GeoCoderStatusCode().staticMetaObject;
            QMetaEnum metaEnum= metaObject.enumerator( metaObject.indexOfEnumerator("Types"));
            QString s=metaEnum.valueToKey(value);
            return s;
        }
        static Types TypeByStr(QString const& value)
        {
            QMetaObject metaObject = GeoCoderStatusCode().staticMetaObject;
            QMetaEnum metaEnum= metaObject.enumerator( metaObject.indexOfEnumerator("Types"));
            Types s=(Types)metaEnum.keyToValue(value.toLatin1());
            return s;
        }
        static QStringList TypesList()
        {
            QStringList ret;
            QMetaObject metaObject = GeoCoderStatusCode().staticMetaObject;
            QMetaEnum metaEnum= metaObject.enumerator( metaObject.indexOfEnumerator("Types"));
            for(int x=0;x<metaEnum.keyCount();++x)
            {
                ret.append(metaEnum.key(x));
            }
            return ret;
        }

    };
}
#endif // GEODECODERSTATUS_H