mirror of
https://github.com/Palakis/obs-websocket.git
synced 2024-08-30 18:12:16 +00:00
Utils: Switch to obs_enum_scenes()
for GetSceneList
More threadsafe than `obs_frontend_get_scenes()`, not that either are in any way threadsafe.
This commit is contained in:
parent
4d8b80a5a7
commit
64df33152a
@ -197,20 +197,19 @@ std::vector<std::string> Utils::Obs::ListHelper::GetHotkeyNameList()
|
|||||||
|
|
||||||
std::vector<json> Utils::Obs::ListHelper::GetSceneList()
|
std::vector<json> Utils::Obs::ListHelper::GetSceneList()
|
||||||
{
|
{
|
||||||
obs_frontend_source_list sceneList = {};
|
|
||||||
obs_frontend_get_scenes(&sceneList);
|
|
||||||
|
|
||||||
std::vector<json> ret;
|
std::vector<json> ret;
|
||||||
for (size_t i = 0; i < sceneList.sources.num; i++) {
|
auto sceneEnumProc = [](void *param, obs_source_t *scene) {
|
||||||
obs_source_t *scene = sceneList.sources.array[i];
|
auto ret = reinterpret_cast<std::vector<json>*>(param);
|
||||||
|
|
||||||
json sceneJson;
|
json sceneJson;
|
||||||
sceneJson["sceneName"] = obs_source_get_name(scene);
|
sceneJson["sceneName"] = obs_source_get_name(scene);
|
||||||
sceneJson["sceneIndex"] = sceneList.sources.num - (i + 1);
|
|
||||||
sceneJson["isGroup"] = obs_source_is_group(scene);
|
sceneJson["isGroup"] = obs_source_is_group(scene);
|
||||||
ret.push_back(sceneJson);
|
|
||||||
}
|
|
||||||
|
|
||||||
obs_frontend_source_list_free(&sceneList);
|
ret->push_back(sceneJson);
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
obs_enum_scenes(sceneEnumProc, &ret);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -276,7 +275,7 @@ std::vector<json> Utils::Obs::ListHelper::GetTransitionList()
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct EnumInputInfo {
|
struct EnumInputInfo {
|
||||||
std::string inputKind;
|
std::string inputKind; // For searching by input kind
|
||||||
std::vector<json> inputs;
|
std::vector<json> inputs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user