19#include "moc_qgis.cpp"
21#include "qgsversion.h"
23#include <QCoreApplication>
38#define qgis_xstr(x) qgis_str(x)
84 string.remove( QLocale().groupSeparator() );
85 return QLocale().toDouble(
string, &ok );
91 string.remove( QLocale().groupSeparator() );
92 return QLocale().toInt(
string, &ok );
98 string.remove( QLocale().groupSeparator() );
99 return QLocale().toLongLong(
string, &ok );
110 if ( ( size >> ( 8 *
sizeof( size ) - 1 ) ) != 0 )
112 QgsDebugError( QStringLiteral(
"qgsMalloc - bad size requested: %1" ).arg( size ) );
116 void *p = malloc( size );
119 QgsDebugError( QStringLiteral(
"Allocation of %1 bytes failed." ).arg( size ) );
132 if ( !lhs.isValid() )
133 return rhs.isValid();
134 else if ( lhs.isNull() )
135 return rhs.isValid() && !rhs.isNull();
136 else if ( !rhs.isValid() || rhs.isNull() )
139 switch ( lhs.userType() )
141 case QMetaType::Type::Int:
142 return lhs.toInt() < rhs.toInt();
143 case QMetaType::Type::UInt:
144 return lhs.toUInt() < rhs.toUInt();
145 case QMetaType::Type::LongLong:
146 return lhs.toLongLong() < rhs.toLongLong();
147 case QMetaType::Type::ULongLong:
148 return lhs.toULongLong() < rhs.toULongLong();
149 case QMetaType::Type::Double:
150 return lhs.toDouble() < rhs.toDouble();
151 case QMetaType::Type::QChar:
152 return lhs.toChar() < rhs.toChar();
153 case QMetaType::Type::QDate:
154 return lhs.toDate() < rhs.toDate();
155 case QMetaType::Type::QTime:
156 return lhs.toTime() < rhs.toTime();
157 case QMetaType::Type::QDateTime:
158 return lhs.toDateTime() < rhs.toDateTime();
159 case QMetaType::Type::Bool:
160 return lhs.toBool() < rhs.toBool();
162 case QMetaType::Type::QVariantList:
164 const QList<QVariant> &lhsl = lhs.toList();
165 const QList<QVariant> &rhsl = rhs.toList();
167 int i, n = std::min( lhsl.size(), rhsl.size() );
168 for ( i = 0; i < n && lhsl[i].userType() == rhsl[i].userType() &&
qgsVariantEqual( lhsl[i], rhsl[i] ); i++ )
172 return lhsl.size() < rhsl.size();
177 case QMetaType::Type::QStringList:
179 const QStringList &lhsl = lhs.toStringList();
180 const QStringList &rhsl = rhs.toStringList();
182 int i, n = std::min( lhsl.size(), rhsl.size() );
183 for ( i = 0; i < n && lhsl[i] == rhsl[i]; i++ )
187 return lhsl.size() < rhsl.size();
189 return lhsl[i] < rhsl[i];
193 return QString::localeAwareCompare( lhs.toString(), rhs.toString() ) < 0;
207uint
qHash(
const QVariant &variant )
209 if ( !variant.isValid() || variant.isNull() )
210 return std::numeric_limits<uint>::max();
212 switch ( variant.userType() )
214 case QMetaType::Type::Int:
215 return qHash( variant.toInt() );
216 case QMetaType::Type::UInt:
217 return qHash( variant.toUInt() );
218 case QMetaType::Type::Bool:
219 return qHash( variant.toBool() );
220 case QMetaType::Type::Double:
221 return qHash( variant.toDouble() );
222 case QMetaType::Type::LongLong:
223 return qHash( variant.toLongLong() );
224 case QMetaType::Type::ULongLong:
225 return qHash( variant.toULongLong() );
226 case QMetaType::Type::QString:
227 return qHash( variant.toString() );
228 case QMetaType::Type::QChar:
229 return qHash( variant.toChar() );
230 case QMetaType::Type::QVariantList:
231 return qHash( variant.toList() );
232 case QMetaType::Type::QStringList:
233 return qHash( variant.toStringList() );
234 case QMetaType::Type::QByteArray:
235 return qHash( variant.toByteArray() );
236 case QMetaType::Type::QDate:
237 return qHash( variant.toDate() );
238 case QMetaType::Type::QTime:
239 return qHash( variant.toTime() );
240 case QMetaType::Type::QDateTime:
241 return qHash( variant.toDateTime() );
242 case QMetaType::Type::QUrl:
243 case QMetaType::Type::QLocale:
244 case QMetaType::Type::QRegularExpression:
245#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
246 case QMetaType::Type::QRegExp:
248 return qHash( variant.toString() );
253 return std::numeric_limits<uint>::max();
258 return ( lhs.isNull() == rhs.isNull() && lhs == rhs ) || ( lhs.isNull() && rhs.isNull() && lhs.isValid() && rhs.isValid() );
263 return QStringLiteral(
"1:1000000,1:500000,1:250000,1:100000,1:50000,1:25000,"
264 "1:10000,1:5000,1:2500,1:1000,1:500" );
269 return QString::fromUtf8( VERSION );
281 return QString::fromUtf8( RELEASE_NAME );
291 return GEOSversion();
296 static const int version = QStringLiteral(
"%1%2%3" )
297 .arg( GEOS_VERSION_MAJOR, 2, 10, QChar(
'0' ) )
298 .arg( GEOS_VERSION_MINOR, 2, 10, QChar(
'0' ) )
306 return GEOS_VERSION_MAJOR;
311 return GEOS_VERSION_MINOR;
320#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
322bool qMapLessThanKey<QVariantList>(
const QVariantList &key1,
const QVariantList &key2 )
static const Qgis::MapToolUnit DEFAULT_SNAP_UNITS
Default snapping distance units.
MapToolUnit
Type of unit of tolerance value from settings.
@ Pixels
Pixels unit of tolerance.
static const double DEFAULT_LINE_WIDTH
The default width (in millimeters) for line symbols.
static const double DEFAULT_HIGHLIGHT_MIN_WIDTH_MM
Default highlight line/stroke minimum width in mm.
static QString version()
Version string.
static const int PREVIEW_JOB_DELAY_MS
Delay between the scheduling of 2 preview jobs.
static const double DEFAULT_Z_COORDINATE
Default Z coordinate value.
static const char * QGIS_DEV_VERSION
The development version.
static QString geosVersion()
GEOS string version linked.
static const double DEFAULT_SNAP_TOLERANCE
Default snapping distance tolerance.
static const double DEFAULT_M_COORDINATE
Default M coordinate value.
static const double DEFAULT_HIGHLIGHT_BUFFER_MM
Default highlight buffer in mm.
static int geosVersionPatch()
GEOS Patch version number linked.
static const QColor DEFAULT_HIGHLIGHT_COLOR
Default highlight color.
static Q_DECL_DEPRECATED const double SCALE_PRECISION
Fudge factor used to compare two scales.
static const int MAXIMUM_LAYER_PREVIEW_TIME_MS
Maximum rendering time for a layer of a preview job.
static QString devVersion()
The development version.
static QString releaseName()
Release name.
static QString defaultProjectScales()
A string with default project scales.
static const float DEFAULT_MAPTOPIXEL_THRESHOLD
Default threshold between map coordinates and device coordinates for map2pixel simplification.
static int geosVersionMajor()
GEOS Major version number linked.
static const double DEFAULT_SEARCH_RADIUS_MM
Identify search radius in mm.
static const double DEFAULT_SEGMENT_EPSILON
Default snapping tolerance for segments.
static int versionInt()
Version number used for comparing versions using the "Check QGIS Version" function.
static const int USER_CRS_START_ID
Minimum ID number for a user-defined projection.
static int geosVersionMinor()
GEOS Minor version number linked.
static int geosVersionInt()
GEOS version number linked.
static const double UI_SCALE_FACTOR
UI scaling factor.
static const double DEFAULT_POINT_SIZE
The default size (in millimeters) for point marker symbols.
static QString vsiPrefixForPath(const QString &path)
Returns a the vsi prefix which corresponds to a file path, or an empty string if the path is not asso...
void * qgsMalloc(size_t size)
Allocates size bytes and returns a pointer to the allocated memory.
qlonglong qgsPermissiveToLongLong(QString string, bool &ok)
Converts a string to an qlonglong in a permissive way, e.g., allowing for incorrect numbers of digits...
bool qgsVariantEqual(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether they are equal, two NULL values are always treated a...
uint qHash(const QVariant &variant)
Hash for QVariant.
double qgsPermissiveToDouble(QString string, bool &ok)
Converts a string to a double in a permissive way, e.g., allowing for incorrect numbers of digits bet...
int qgsPermissiveToInt(QString string, bool &ok)
Converts a string to an integer in a permissive way, e.g., allowing for incorrect numbers of digits b...
void qgsFree(void *ptr)
Frees the memory space pointed to by ptr.
QString qgsVsiPrefix(const QString &path)
Returns a the vsi prefix which corresponds to a file path, or an empty string if the path is not asso...
bool qgsVariantLessThan(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether the first is less than the second.
bool qgsVariantGreaterThan(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether the first is greater than the second.
#define QgsDebugError(str)