mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-21 06:01:43 +00:00
t/common: Refactor WinMR builder [NFC]
This commit is contained in:
parent
0a8fa312d6
commit
8b30819b35
|
@ -271,41 +271,45 @@ wmr_open_system(struct xrt_builder *xb,
|
|||
assert(xret_unlock == XRT_SUCCESS);
|
||||
(void)xret_unlock;
|
||||
|
||||
struct u_system_devices *usysd = u_system_devices_allocate();
|
||||
struct xrt_system_devices *xsysd = NULL;
|
||||
{
|
||||
struct u_system_devices *usysd = u_system_devices_allocate();
|
||||
xsysd = &usysd->base;
|
||||
}
|
||||
|
||||
usysd->base.xdevs[usysd->base.xdev_count++] = head;
|
||||
xsysd->xdevs[xsysd->xdev_count++] = head;
|
||||
if (left != NULL) {
|
||||
usysd->base.xdevs[usysd->base.xdev_count++] = left;
|
||||
xsysd->xdevs[xsysd->xdev_count++] = left;
|
||||
}
|
||||
if (right != NULL) {
|
||||
usysd->base.xdevs[usysd->base.xdev_count++] = right;
|
||||
xsysd->xdevs[xsysd->xdev_count++] = right;
|
||||
}
|
||||
if (ht_left != NULL) {
|
||||
usysd->base.xdevs[usysd->base.xdev_count++] = ht_left;
|
||||
xsysd->xdevs[xsysd->xdev_count++] = ht_left;
|
||||
}
|
||||
if (ht_right != NULL) {
|
||||
usysd->base.xdevs[usysd->base.xdev_count++] = ht_right;
|
||||
xsysd->xdevs[xsysd->xdev_count++] = ht_right;
|
||||
}
|
||||
|
||||
usysd->base.roles.head = head;
|
||||
if (left != NULL) {
|
||||
usysd->base.roles.left = left;
|
||||
} else {
|
||||
usysd->base.roles.left = ht_left;
|
||||
// Use hand tracking if no controllers.
|
||||
if (left == NULL) {
|
||||
left = ht_left;
|
||||
}
|
||||
if (right != NULL) {
|
||||
usysd->base.roles.right = right;
|
||||
} else {
|
||||
usysd->base.roles.right = ht_right;
|
||||
if (right == NULL) {
|
||||
right = ht_right;
|
||||
}
|
||||
|
||||
// Find hand tracking devices.
|
||||
usysd->base.roles.hand_tracking.left = u_system_devices_get_ht_device_left(&usysd->base);
|
||||
usysd->base.roles.hand_tracking.right = u_system_devices_get_ht_device_right(&usysd->base);
|
||||
|
||||
// Assign to role(s).
|
||||
xsysd->roles.head = head;
|
||||
xsysd->roles.left = left;
|
||||
xsysd->roles.right = right;
|
||||
xsysd->roles.hand_tracking.left = ht_left;
|
||||
xsysd->roles.hand_tracking.right = ht_right;
|
||||
|
||||
// Create space overseer last once all devices set.
|
||||
struct xrt_space_overseer *xso = NULL;
|
||||
u_builder_create_space_overseer(&usysd->base, &xso);
|
||||
u_builder_create_space_overseer(xsysd, &xso);
|
||||
assert(xso != NULL);
|
||||
|
||||
|
||||
|
@ -313,7 +317,7 @@ wmr_open_system(struct xrt_builder *xb,
|
|||
* Output.
|
||||
*/
|
||||
|
||||
*out_xsysd = &usysd->base;
|
||||
*out_xsysd = xsysd;
|
||||
*out_xso = xso;
|
||||
|
||||
return XRT_SUCCESS;
|
||||
|
|
Loading…
Reference in a new issue