/**************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Contact: http://www.qt.io/licensing/ ** ** This file is part of the QtLocation module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL3$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see http://www.qt.io/terms-conditions. For further ** information use the contact form at http://www.qt.io/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPLv3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or later as published by the Free ** Software Foundation and appearing in the file LICENSE.GPL included in ** the packaging of this file. Please review the following information to ** ensure the GNU General Public License version 2.0 requirements will be ** met: http://www.gnu.org/licenses/gpl-2.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "qplacecategory.h" #include "qplacecategory_p.h" QT_BEGIN_NAMESPACE QPlaceCategoryPrivate::QPlaceCategoryPrivate() : visibility(QLocation::UnspecifiedVisibility) { } QPlaceCategoryPrivate::QPlaceCategoryPrivate(const QPlaceCategoryPrivate &other) : QSharedData(other), categoryId(other.categoryId), name(other.name), visibility(other.visibility), icon(other.icon) { } QPlaceCategoryPrivate::~QPlaceCategoryPrivate() { } QPlaceCategoryPrivate &QPlaceCategoryPrivate::operator=(const QPlaceCategoryPrivate &other) { if (this == &other) return *this; categoryId = other.categoryId; name = other.name; icon = other.icon; return *this; } bool QPlaceCategoryPrivate::isEmpty() const { return categoryId.isEmpty() && name.isEmpty() && icon.isEmpty() && QLocation::UnspecifiedVisibility == visibility; } /*! \class QPlaceCategory \inmodule QtLocation \ingroup QtLocation-places \ingroup QtLocation-places-data \since 5.6 \brief The QPlaceCategory class represents a category that a \l QPlace can be associated with. Categories are used to search for places based on the categories they are associated with. The list/tree of available categories can be obtained from \l QPlaceManager. The \l QPlaceSearchRequest::setCategories() function can be used to limit the search results to places with the specified categories. If the \l QGeoServiceProvider supports it, categories can be created and removed. This functionality is available in the \l QPlaceManager class. */ /*! \fn bool QPlaceCategory::operator!=(const QPlaceCategory &other) const Returns true if \a other is not equal to this category; otherwise returns false. */ /*! Constructs a category. */ QPlaceCategory::QPlaceCategory() : d(new QPlaceCategoryPrivate) { } /*! Constructs a category which is a copy of \a other. */ QPlaceCategory::QPlaceCategory(const QPlaceCategory &other) :d(other.d) { } /*! Destroys the category. */ QPlaceCategory::~QPlaceCategory() { } /*! Assigns \a other to this category and returns a reference to this category. */ QPlaceCategory &QPlaceCategory::operator =(const QPlaceCategory &other) { if (this == &other) return *this; d = other.d; return *this; } /*! Returns true if \a other is equal to this category; otherwise returns false. */ bool QPlaceCategory::operator==(const QPlaceCategory &other) const { return d->categoryId == other.d->categoryId && d->name == other.d->name && (d->visibility == QLocation::UnspecifiedVisibility || other.d->visibility == QLocation::UnspecifiedVisibility || d->visibility == other.d->visibility) && d->icon == other.d->icon; } /*! Returns the identifier of the category. The category identifier is a string which uniquely identifies this category within a particular \l QPlaceManager. The identifier is only meaningful to the QPlaceManager that generated it and is not transferable between managers. */ QString QPlaceCategory::categoryId() const { return d->categoryId; } /*! Sets the \a identifier of the category. */ void QPlaceCategory::setCategoryId(const QString &identifier) { d->categoryId = identifier; } /*! Returns the name of category. */ QString QPlaceCategory::name() const { return d->name; } /*! Sets the \a name of the category. */ void QPlaceCategory::setName(const QString &name) { d->name = name; } /*! Sets the \a visibility of the category. */ void QPlaceCategory::setVisibility(QLocation::Visibility visibility) { d->visibility = visibility; } /*! Returns the visibility of the category. */ QLocation::Visibility QPlaceCategory::visibility() const { return d->visibility; } /*! Returns the icon associated with the category. */ QPlaceIcon QPlaceCategory::icon() const { return d->icon; } /*! Sets the \a icon of the category. */ void QPlaceCategory::setIcon(const QPlaceIcon &icon) { d->icon = icon; } /*! Returns a boolean indicating whether the all the fields of the place category are empty or not. */ bool QPlaceCategory::isEmpty() const { return d->isEmpty(); } QT_END_NAMESPACE