/**
* This file is part of TelepathyQt4
*
* @copyright Copyright (C) 2010 Collabora Ltd.
* @copyright Copyright (C) 2010 Nokia Corporation
* @license LGPL 2.1
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include
#include "TelepathyQt4/_gen/fixed-feature-factory.moc.hpp"
#include
namespace Tp
{
struct TELEPATHY_QT4_NO_EXPORT FixedFeatureFactory::Private
{
Features features;
};
/**
* \class FixedFeatureFactory
* \ingroup utils
* \headerfile TelepathyQt4/fixed-feature-factory.h
*
* \brief The FixedFeatureFactory class is a base class for all D-Bus proxy
* factories which want the same set of features for all constructed proxies.
*/
/**
* Class constructor.
*
* The intention for storing the bus here is that it generally doesn't make sense to construct
* proxies for multiple buses in the same context. Allowing that would lead to more complex keying
* needs in the cache, as well.
*
* \param bus The D-Bus bus connection for the objects constructed using this factory.
*/
FixedFeatureFactory::FixedFeatureFactory(const QDBusConnection &bus)
: DBusProxyFactory(bus), mPriv(new Private)
{
}
/**
* Class destructor.
*/
FixedFeatureFactory::~FixedFeatureFactory()
{
delete mPriv;
}
/**
* Gets the features this factory will make ready on constructed proxies.
*
* \return The set of features.
*/
Features FixedFeatureFactory::features() const
{
return mPriv->features;
}
/**
* Adds a single feature this factory will make ready on further constructed proxies.
*
* No feature removal is provided, to guard against uncooperative modules removing features other
* modules have set and depend on.
*
* \param feature The feature to add.
*/
void FixedFeatureFactory::addFeature(const Feature &feature)
{
addFeatures(Features(feature));
}
/**
* Adds a set of features this factory will make ready on further constructed proxies.
*
* No feature removal is provided, to guard against uncooperative modules removing features other
* modules have set and depend on.
*
* \param features The features to add.
*/
void FixedFeatureFactory::addFeatures(const Features &features)
{
mPriv->features.unite(features);
}
/**
* Fixed implementation of the per-proxy feature getter.
*
* \return features(), irrespective of the actual \a proxy.
*/
Features FixedFeatureFactory::featuresFor(const DBusProxyPtr &proxy) const
{
Q_UNUSED(proxy);
return features();
}
}