mirror of
https://github.com/pinnacle-comp/pinnacle.git
synced 2025-01-13 08:01:05 +01:00
Simplify tag in API
This commit is contained in:
parent
9475c9965d
commit
2d42f01b8a
6 changed files with 68 additions and 52 deletions
|
@ -37,12 +37,9 @@
|
|||
--Outputs
|
||||
---@field GetOutputProps { output_name: string }
|
||||
--Tags
|
||||
---@field GetTagsByName { tag_name: string }
|
||||
---@field GetTagOutput { tag_id: TagId }
|
||||
---@field GetTagActive { tag_id: TagId }
|
||||
---@field GetTagName { tag_id: TagId }
|
||||
---@field GetTagProps { tag_id: TagId }
|
||||
|
||||
---@alias Request _Request | "GetWindows" | "GetOutputs"
|
||||
---@alias Request _Request | "GetWindows" | "GetOutputs" | "GetTags"
|
||||
|
||||
---@class IncomingMsg
|
||||
---@field CallCallback { callback_id: integer, args: Args }
|
||||
|
@ -67,5 +64,4 @@
|
|||
---@field OutputProps { make: string?, model: string?, loc: integer[]?, res: integer[]?, refresh_rate: integer?, physical_size: integer[]?, focused: boolean?, tag_ids: integer[]? }
|
||||
--Tags
|
||||
---@field Tags { tag_ids: TagId[] }
|
||||
---@field TagActive { active: boolean? }
|
||||
---@field TagName { name: string? }
|
||||
---@field TagProps { active: boolean?, name: string?, output_name: string? }
|
||||
|
|
|
@ -297,13 +297,13 @@ end
|
|||
---@return Output|nil
|
||||
function output.get_for_tag(tag)
|
||||
SendRequest({
|
||||
GetTagOutput = {
|
||||
GetTagProps = {
|
||||
tag_id = tag:id(),
|
||||
},
|
||||
})
|
||||
|
||||
local response = ReadMsg()
|
||||
local output_name = response.RequestResponse.response.Output.output_name
|
||||
local output_name = response.RequestResponse.response.TagProps.output_name
|
||||
|
||||
if output_name == nil then
|
||||
return nil
|
||||
|
|
|
@ -42,13 +42,13 @@ end
|
|||
---@return boolean|nil active `true` if the tag is active, `false` if not, and `nil` if the tag doesn't exist.
|
||||
function tg:active()
|
||||
SendRequest({
|
||||
GetTagActive = {
|
||||
GetTagProps = {
|
||||
tag_id = self._id,
|
||||
},
|
||||
})
|
||||
|
||||
local response = ReadMsg()
|
||||
local active = response.RequestResponse.response.TagActive.active
|
||||
local active = response.RequestResponse.response.TagProps.active
|
||||
return active
|
||||
end
|
||||
|
||||
|
@ -56,13 +56,13 @@ end
|
|||
---@return string|nil name The name of this tag, or nil if it doesn't exist.
|
||||
function tg:name()
|
||||
SendRequest({
|
||||
GetTagName = {
|
||||
GetTagProps = {
|
||||
tag_id = self._id,
|
||||
},
|
||||
})
|
||||
|
||||
local response = ReadMsg()
|
||||
local name = response.RequestResponse.response.TagName.name
|
||||
local name = response.RequestResponse.response.TagProps.name
|
||||
return name
|
||||
end
|
||||
|
||||
|
@ -74,7 +74,7 @@ end
|
|||
|
||||
---Set this tag's layout.
|
||||
---@param layout Layout
|
||||
function tg:set_layout(layout) -- TODO: output param
|
||||
function tg:set_layout(layout)
|
||||
local name = self:name()
|
||||
if name ~= nil then
|
||||
tag.set_layout(name, layout)
|
||||
|
@ -266,11 +266,29 @@ end
|
|||
---@param name string The name of the tags you want.
|
||||
---@return Tag[]
|
||||
function tag.get_by_name(name)
|
||||
SendRequest({
|
||||
GetTagsByName = {
|
||||
tag_name = name,
|
||||
},
|
||||
})
|
||||
SendRequest("GetTags")
|
||||
|
||||
local response = ReadMsg()
|
||||
|
||||
local tag_ids = response.RequestResponse.response.Tags.tag_ids
|
||||
|
||||
---@type Tag[]
|
||||
local tags = {}
|
||||
|
||||
for _, tag_id in pairs(tag_ids) do
|
||||
local t = new_tag(tag_id)
|
||||
if t:name() == name then
|
||||
table.insert(tags, t)
|
||||
end
|
||||
end
|
||||
|
||||
return tags
|
||||
end
|
||||
|
||||
---Get all tags across all ouptuts.
|
||||
---@return Tag[]
|
||||
function tag.get_all()
|
||||
SendRequest("GetTags")
|
||||
|
||||
local response = ReadMsg()
|
||||
|
||||
|
|
|
@ -113,6 +113,25 @@ require("pinnacle").setup(function(pinnacle)
|
|||
for _, tg in pairs(tags) do
|
||||
print(tg:name())
|
||||
print((tg:output() and tg:output():name()) or "nil output")
|
||||
print(tg:active())
|
||||
end
|
||||
|
||||
print("----------------------")
|
||||
|
||||
local tags = tag.get_by_name("2")
|
||||
for _, tg in pairs(tags) do
|
||||
print(tg:name())
|
||||
print((tg:output() and tg:output():name()) or "nil output")
|
||||
print(tg:active())
|
||||
end
|
||||
|
||||
print("----------------------")
|
||||
|
||||
local tags = tag.get_all()
|
||||
for _, tg in pairs(tags) do
|
||||
print(tg:name())
|
||||
print((tg:output() and tg:output():name()) or "nil output")
|
||||
print(tg:active())
|
||||
end
|
||||
end)
|
||||
|
||||
|
|
|
@ -106,10 +106,8 @@ pub enum Request {
|
|||
GetOutputs,
|
||||
GetOutputProps { output_name: String },
|
||||
// Tags
|
||||
GetTagsByName { tag_name: String },
|
||||
GetTagOutput { tag_id: TagId },
|
||||
GetTagActive { tag_id: TagId },
|
||||
GetTagName { tag_id: TagId },
|
||||
GetTags,
|
||||
GetTagProps { tag_id: TagId },
|
||||
}
|
||||
|
||||
#[derive(Debug, PartialEq, Eq, Copy, Clone, serde::Serialize, serde::Deserialize)]
|
||||
|
@ -228,10 +226,9 @@ pub enum RequestResponse {
|
|||
Tags {
|
||||
tag_ids: Vec<TagId>,
|
||||
},
|
||||
TagActive {
|
||||
TagProps {
|
||||
active: Option<bool>,
|
||||
},
|
||||
TagName {
|
||||
name: Option<String>,
|
||||
output_name: Option<String>,
|
||||
},
|
||||
}
|
||||
|
|
36
src/state.rs
36
src/state.rs
|
@ -479,12 +479,11 @@ impl<B: Backend> State<B> {
|
|||
)
|
||||
.expect("failed to send to client");
|
||||
}
|
||||
Request::GetTagsByName { tag_name } => {
|
||||
Request::GetTags => {
|
||||
let tag_ids = self
|
||||
.space
|
||||
.outputs()
|
||||
.flat_map(|op| op.with_state(|state| state.tags.clone()))
|
||||
.filter(|tag| tag.name() == tag_name)
|
||||
.map(|tag| tag.id())
|
||||
.collect::<Vec<_>>();
|
||||
crate::api::send_to_client(
|
||||
|
@ -495,35 +494,22 @@ impl<B: Backend> State<B> {
|
|||
)
|
||||
.expect("failed to send to client");
|
||||
}
|
||||
Request::GetTagOutput { tag_id } => {
|
||||
let output_name = tag_id
|
||||
.tag(self)
|
||||
Request::GetTagProps { tag_id } => {
|
||||
let tag = tag_id.tag(self);
|
||||
let output_name = tag
|
||||
.as_ref()
|
||||
.and_then(|tag| tag.output(self))
|
||||
.map(|output| output.name());
|
||||
let active = tag.as_ref().map(|tag| tag.active());
|
||||
let name = tag.as_ref().map(|tag| tag.name());
|
||||
crate::api::send_to_client(
|
||||
&mut stream,
|
||||
&OutgoingMsg::RequestResponse {
|
||||
response: RequestResponse::Output { output_name },
|
||||
response: RequestResponse::TagProps {
|
||||
active,
|
||||
name,
|
||||
output_name,
|
||||
},
|
||||
)
|
||||
.expect("failed to send to client");
|
||||
}
|
||||
Request::GetTagActive { tag_id } => {
|
||||
let active = tag_id.tag(self).map(|tag| tag.active());
|
||||
crate::api::send_to_client(
|
||||
&mut stream,
|
||||
&OutgoingMsg::RequestResponse {
|
||||
response: RequestResponse::TagActive { active },
|
||||
},
|
||||
)
|
||||
.expect("failed to send to client");
|
||||
}
|
||||
Request::GetTagName { tag_id } => {
|
||||
let name = tag_id.tag(self).map(|tag| tag.name());
|
||||
crate::api::send_to_client(
|
||||
&mut stream,
|
||||
&OutgoingMsg::RequestResponse {
|
||||
response: RequestResponse::TagName { name },
|
||||
},
|
||||
)
|
||||
.expect("failed to send to client");
|
||||
|
|
Loading…
Reference in a new issue