blob: d9e33fcdc13e0041f9ee981b77c7559eaf48bfbe (
plain)
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
|
// Copyright (C) 2021 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qqnxmediadevices_p.h"
#include "qmediadevices.h"
#include "private/qcameradevice_p.h"
#include "qcameradevice.h"
#include "qqnxaudiosource_p.h"
#include "qqnxaudiosink_p.h"
#include "qqnxaudiodevice_p.h"
#include <qdir.h>
#include <qdebug.h>
QT_BEGIN_NAMESPACE
static QList<QAudioDevice> enumeratePcmDevices(QAudioDevice::Mode mode)
{
if (mode == QAudioDevice::Null)
return {};
QDir dir(QStringLiteral("/dev/snd"));
dir.setFilter(QDir::Files);
dir.setSorting(QDir::Name);
// QNX PCM devices names start with the pcm prefix and end either with the
// 'p' (playback) or 'c' (capture) suffix
const char modeSuffix = mode == QAudioDevice::Input ? 'c' : 'p';
QList<QAudioDevice> devices;
for (const QString &entry : dir.entryList()) {
if (entry.startsWith(QStringLiteral("pcm")) && entry.back() == modeSuffix)
devices << (new QnxAudioDeviceInfo(entry.toUtf8(), mode))->create();
}
return devices;
}
QQnxMediaDevices::QQnxMediaDevices()
: QPlatformMediaDevices()
{
}
QList<QAudioDevice> QQnxMediaDevices::audioInputs() const
{
return ::enumeratePcmDevices(QAudioDevice::Input);
}
QList<QAudioDevice> QQnxMediaDevices::audioOutputs() const
{
return ::enumeratePcmDevices(QAudioDevice::Output);
}
QPlatformAudioSource *QQnxMediaDevices::createAudioSource(const QAudioDevice &deviceInfo,
QObject *parent)
{
return new QQnxAudioSource(deviceInfo, parent);
}
QPlatformAudioSink *QQnxMediaDevices::createAudioSink(const QAudioDevice &deviceInfo,
QObject *parent)
{
return new QQnxAudioSink(deviceInfo, parent);
}
QT_END_NAMESPACE
|