blob: bd16e92e9ea2801f7274d4aab6f51e0e9d4783d5 [file] [log] [blame]
/* This file is part of the KDE project
Copyright (C) 2005-2006 Matthias Kretz <kretz@kde.org>
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) version 3, or any
later version accepted by the membership of KDE e.V. (or its
successor approved by the membership of KDE e.V.), Nokia Corporation
(or its successors, if any) and the KDE Free Qt Foundation, which shall
act as a proxy defined in Section 6 of version 3 of the license.
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, see <http://www.gnu.org/licenses/>.
*/
#include "backendcapabilities.h"
#include "backendcapabilities_p.h"
#include "phonondefs_p.h"
#include "backendinterface.h"
#include "factory_p.h"
#include "globalconfig.h"
#include "globalstatic_p.h"
#include "objectdescription.h"
#include <QtCore/QList>
#include <QtCore/QSet>
#include <QtCore/QStringList>
QT_BEGIN_NAMESPACE
PHONON_GLOBAL_STATIC(Phonon::BackendCapabilitiesPrivate, globalBCPrivate)
namespace Phonon
{
BackendCapabilities::Notifier *BackendCapabilities::notifier()
{
return globalBCPrivate;
}
QStringList BackendCapabilities::availableMimeTypes()
{
if (BackendInterface *backendIface = qobject_cast<BackendInterface *>(Factory::backend()))
return backendIface->availableMimeTypes();
else
return QStringList();
}
bool BackendCapabilities::isMimeTypeAvailable(const QString &mimeType)
{
QObject *m_backendObject = Factory::backend(false);
if (!m_backendObject) {
if (!Factory::isMimeTypeAvailable(mimeType)) {
return false;
}
// without loading the backend we found out that the MIME type might be supported, now we
// want to know for certain. For that we need to load the backend.
m_backendObject = Factory::backend(true);
}
if (!m_backendObject) {
// no backend == no MIME type supported at all
return false;
}
return availableMimeTypes().contains(mimeType);
}
QList<AudioOutputDevice> BackendCapabilities::availableAudioOutputDevices()
{
QList<AudioOutputDevice> ret;
#ifndef QT_NO_PHONON_SETTINGSGROUP
const QList<int> deviceIndexes = GlobalConfig().audioOutputDeviceListFor(Phonon::NoCategory);
for (int i = 0; i < deviceIndexes.count(); ++i) {
ret.append(AudioOutputDevice::fromIndex(deviceIndexes.at(i)));
}
#endif //QT_NO_PHONON_SETTINGSGROUP
return ret;
}
#ifndef QT_NO_PHONON_AUDIOCAPTURE
QList<AudioCaptureDevice> BackendCapabilities::availableAudioCaptureDevices()
{
QList<AudioCaptureDevice> ret;
const QList<int> deviceIndexes = GlobalConfig().audioCaptureDeviceListFor(Phonon::NoCategory);
for (int i = 0; i < deviceIndexes.count(); ++i) {
ret.append(AudioCaptureDevice::fromIndex(deviceIndexes.at(i)));
}
return ret;
}
#endif //QT_NO_PHONON_AUDIOCAPTURE
#ifndef QT_NO_PHONON_EFFECT
QList<EffectDescription> BackendCapabilities::availableAudioEffects()
{
BackendInterface *backendIface = qobject_cast<BackendInterface *>(Factory::backend());
QList<EffectDescription> ret;
if (backendIface) {
const QList<int> deviceIndexes = backendIface->objectDescriptionIndexes(Phonon::EffectType);
for (int i = 0; i < deviceIndexes.count(); ++i) {
ret.append(EffectDescription::fromIndex(deviceIndexes.at(i)));
}
}
return ret;
}
#endif //QT_NO_PHONON_EFFECT
} // namespace Phonon
QT_END_NAMESPACE
#include "moc_backendcapabilities.cpp"
// vim: sw=4 ts=4