aboutsummaryrefslogtreecommitdiffstats
path: root/alc/backends/oss.cpp
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2020-08-07 00:11:29 -0700
committerChris Robinson <[email protected]>2020-08-07 00:11:29 -0700
commit84354c792e17ff5df5edc8d7612dd5a2e4ae4f28 (patch)
tree6eaf9a01cc4ba28c67eb395d65a16cec2a49dfd5 /alc/backends/oss.cpp
parent02f841966304efa8f4400f33396142705d3d4eaa (diff)
Cleanup OSS enumeration and fix duplicate names
Diffstat (limited to 'alc/backends/oss.cpp')
-rw-r--r--alc/backends/oss.cpp94
1 files changed, 39 insertions, 55 deletions
diff --git a/alc/backends/oss.cpp b/alc/backends/oss.cpp
index 70a4a09d..1fe3c475 100644
--- a/alc/backends/oss.cpp
+++ b/alc/backends/oss.cpp
@@ -94,14 +94,6 @@ struct DevMap {
std::string device_name;
};
-bool checkName(const al::vector<DevMap> &list, const std::string &name)
-{
- return std::find_if(list.cbegin(), list.cend(),
- [&name](const DevMap &entry) -> bool
- { return entry.name == name; }
- ) != list.cend();
-}
-
al::vector<DevMap> PlaybackDevices;
al::vector<DevMap> CaptureDevices;
@@ -110,60 +102,59 @@ al::vector<DevMap> CaptureDevices;
#define DSP_CAP_OUTPUT 0x00020000
#define DSP_CAP_INPUT 0x00010000
-void ALCossListPopulate(al::vector<DevMap> *devlist, int type)
+void ALCossListPopulate(al::vector<DevMap> &devlist, int type)
{
- devlist->emplace_back(DevMap{DefaultName, (type==DSP_CAP_INPUT) ? DefaultCapture : DefaultPlayback});
+ devlist.emplace_back(DevMap{DefaultName, (type==DSP_CAP_INPUT) ? DefaultCapture : DefaultPlayback});
}
#else
-void ALCossListAppend(al::vector<DevMap> *list, const char *handle, size_t hlen, const char *path, size_t plen)
+void ALCossListAppend(al::vector<DevMap> &list, al::span<const char> handle, al::span<const char> path)
{
#ifdef ALC_OSS_DEVNODE_TRUC
- for(size_t i{0};i < plen;i++)
+ for(size_t i{0};i < path.size();++i)
{
- if(path[i] == '.')
+ if(path[i] == '.' && handle.size() + i >= path.size())
{
- if(strncmp(path + i, handle + hlen + i - plen, plen - i) == 0)
- hlen = hlen + i - plen;
- plen = i;
+ const size_t hoffset{handle.size() + i - path.size()};
+ if(strncmp(path.data() + i, handle.data() + hoffset, path.size() - i) == 0)
+ handle = handle.first(hoffset);
+ path = path.first(i);
}
}
#endif
- if(handle[0] == '\0')
- {
+ if(handle.empty())
handle = path;
- hlen = plen;
- }
- std::string basename{handle, hlen};
- basename.erase(std::find(basename.begin(), basename.end(), '\0'), basename.end());
- std::string devname{path, plen};
- devname.erase(std::find(devname.begin(), devname.end(), '\0'), devname.end());
+ std::string basename{handle.data(), handle.size()};
+ std::string devname{path.data(), path.size()};
- auto iter = std::find_if(list->cbegin(), list->cend(),
- [&devname](const DevMap &entry) -> bool
- { return entry.device_name == devname; }
- );
- if(iter != list->cend())
+ auto match_devname = [&devname](const DevMap &entry) -> bool
+ { return entry.device_name == devname; };
+ if(std::find_if(list.cbegin(), list.cend(), match_devname) != list.cend())
return;
+ auto checkName = [&list](const std::string &name) -> bool
+ {
+ auto match_name = [&name](const DevMap &entry) -> bool { return entry.name == name; };
+ return std::find_if(list.cbegin(), list.cend(), match_name) != list.cend();
+ };
int count{1};
std::string newname{basename};
- while(checkName(PlaybackDevices, newname))
+ while(checkName(newname))
{
newname = basename;
newname += " #";
newname += std::to_string(++count);
}
- list->emplace_back(DevMap{std::move(newname), std::move(devname)});
- const DevMap &entry = list->back();
+ list.emplace_back(DevMap{std::move(newname), std::move(devname)});
+ const DevMap &entry = list.back();
TRACE("Got device \"%s\", \"%s\"\n", entry.name.c_str(), entry.device_name.c_str());
}
-void ALCossListPopulate(al::vector<DevMap> *devlist, int type_flag)
+void ALCossListPopulate(al::vector<DevMap> &devlist, int type_flag)
{
int fd{open("/dev/mixer", O_RDONLY)};
if(fd < 0)
@@ -191,21 +182,14 @@ void ALCossListPopulate(al::vector<DevMap> *devlist, int type_flag)
if(!(ai.caps&type_flag) || ai.devnode[0] == '\0')
continue;
- const char *handle;
- size_t len;
+ al::span<const char> handle;
if(ai.handle[0] != '\0')
- {
- len = strnlen(ai.handle, sizeof(ai.handle));
- handle = ai.handle;
- }
+ handle = {ai.handle, strnlen(ai.handle, sizeof(ai.handle))};
else
- {
- len = strnlen(ai.name, sizeof(ai.name));
- handle = ai.name;
- }
+ handle = {ai.name, strnlen(ai.name, sizeof(ai.name))};
+ al::span<const char> devnode{ai.devnode, strnlen(ai.devnode, sizeof(ai.devnode))};
- ALCossListAppend(devlist, handle, len, ai.devnode,
- strnlen(ai.devnode, sizeof(ai.devnode)));
+ ALCossListAppend(devlist, handle, devnode);
}
done:
@@ -214,19 +198,19 @@ done:
fd = -1;
const char *defdev{((type_flag==DSP_CAP_INPUT) ? DefaultCapture : DefaultPlayback).c_str()};
- auto iter = std::find_if(devlist->cbegin(), devlist->cend(),
+ auto iter = std::find_if(devlist.cbegin(), devlist.cend(),
[defdev](const DevMap &entry) -> bool
{ return entry.device_name == defdev; }
);
- if(iter == devlist->cend())
- devlist->insert(devlist->begin(), DevMap{DefaultName, defdev});
+ if(iter == devlist.cend())
+ devlist.insert(devlist.begin(), DevMap{DefaultName, defdev});
else
{
DevMap entry{std::move(*iter)};
- devlist->erase(iter);
- devlist->insert(devlist->begin(), std::move(entry));
+ devlist.erase(iter);
+ devlist.insert(devlist.begin(), std::move(entry));
}
- devlist->shrink_to_fit();
+ devlist.shrink_to_fit();
}
#endif
@@ -335,7 +319,7 @@ void OSSPlayback::open(const ALCchar *name)
else
{
if(PlaybackDevices.empty())
- ALCossListPopulate(&PlaybackDevices, DSP_CAP_OUTPUT);
+ ALCossListPopulate(PlaybackDevices, DSP_CAP_OUTPUT);
auto iter = std::find_if(PlaybackDevices.cbegin(), PlaybackDevices.cend(),
[&name](const DevMap &entry) -> bool
@@ -539,7 +523,7 @@ void OSScapture::open(const ALCchar *name)
else
{
if(CaptureDevices.empty())
- ALCossListPopulate(&CaptureDevices, DSP_CAP_INPUT);
+ ALCossListPopulate(CaptureDevices, DSP_CAP_INPUT);
auto iter = std::find_if(CaptureDevices.cbegin(), CaptureDevices.cend(),
[&name](const DevMap &entry) -> bool
@@ -682,13 +666,13 @@ std::string OSSBackendFactory::probe(BackendType type)
{
case BackendType::Playback:
PlaybackDevices.clear();
- ALCossListPopulate(&PlaybackDevices, DSP_CAP_OUTPUT);
+ ALCossListPopulate(PlaybackDevices, DSP_CAP_OUTPUT);
std::for_each(PlaybackDevices.cbegin(), PlaybackDevices.cend(), add_device);
break;
case BackendType::Capture:
CaptureDevices.clear();
- ALCossListPopulate(&CaptureDevices, DSP_CAP_INPUT);
+ ALCossListPopulate(CaptureDevices, DSP_CAP_INPUT);
std::for_each(CaptureDevices.cbegin(), CaptureDevices.cend(), add_device);
break;
}