Compare commits

..

No commits in common. "main" and "v0.10.0" have entirely different histories.

5 changed files with 25 additions and 93 deletions

View File

@ -5,29 +5,13 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
# [0.10.3] - 2025-06-07 # [0.10.0]
### Added
- filter list:
- --ffmpeg, --vlc flags
- Muted column to list table
# [0.10.2] - 2025-06-04
### Added ### Added
- screenshot save command, see [ScreenshotCmd](https://github.com/onyx-and-iris/gobs-cli?tab=readme-ov-file#screenshotcmd) - screenshot save command, see [ScreenshotCmd](https://github.com/onyx-and-iris/gobs-cli?tab=readme-ov-file#screenshotcmd)
### Fixed # [0.9.0]
- filter list:
- sourceName arg now defaults to current scene.
- defaults are printed for any unmodified values.
- sceneitem list:
- prints enabled mark instead of true/false
# [0.9.0] - 2025-06-02
### Added ### Added
@ -37,7 +21,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- version command renamed to obs-version - version command renamed to obs-version
# [0.8.2] - 2025-05-29 # [0.8.2]
### Added ### Added

View File

@ -223,8 +223,6 @@ gobs-cli group status START "test_group"
- --input: List all inputs. - --input: List all inputs.
- --output: List all outputs. - --output: List all outputs.
- --colour: List all colour sources. - --colour: List all colour sources.
- --ffmpeg: List all ffmpeg sources.
- --vlc: List all VLC sources.
```console ```console
gobs-cli input list gobs-cli input list
@ -515,10 +513,6 @@ gobs-cli hotkey trigger-sequence OBS_KEY_F1 --shift --ctrl
- list: List all filters. - list: List all filters.
*optional*
- args: SourceName
- defaults to current scene
```console ```console
gobs-cli filter list gobs-cli filter list
``` ```
@ -567,7 +561,7 @@ gobs-cli projector list-monitors
- defaults to 0 - defaults to 0
*optional* *optional*
- args: SourceName - args: <source_name>
- defaults to current scene - defaults to current scene
```console ```console
@ -591,7 +585,7 @@ gobs-cli projector open --monitor-index=1 "test_group"
- --quality: - --quality:
- defaults to -1 - defaults to -1
- args: SourceName FilePath - args: <source_name> <output_path>
```console ```console
gobs-cli screenshot save --width=2560 --height=1440 "Scene" "C:\Users\me\Videos\screenshot.png" gobs-cli screenshot save --width=2560 --height=1440 "Scene" "C:\Users\me\Videos\screenshot.png"

View File

@ -2,7 +2,6 @@ package main
import ( import (
"fmt" "fmt"
"maps"
"sort" "sort"
"strings" "strings"
@ -21,27 +20,19 @@ type FilterCmd struct {
// FilterListCmd provides a command to list all filters in a scene. // FilterListCmd provides a command to list all filters in a scene.
type FilterListCmd struct { type FilterListCmd struct {
SourceName string `arg:"" help:"Name of the source to list filters from." default:""` SourceName string `arg:"" help:"Name of the source to list filters from."`
} }
// Run executes the command to list all filters in a scene. // Run executes the command to list all filters in a scene.
func (cmd *FilterListCmd) Run(ctx *context) error { func (cmd *FilterListCmd) Run(ctx *context) error {
if cmd.SourceName == "" { filters, err := ctx.Client.Filters.GetSourceFilterList(
currentScene, err := ctx.Client.Scenes.GetCurrentProgramScene()
if err != nil {
return fmt.Errorf("failed to get current program scene: %w", err)
}
cmd.SourceName = currentScene.SceneName
}
sourceFilters, err := ctx.Client.Filters.GetSourceFilterList(
filters.NewGetSourceFilterListParams().WithSourceName(cmd.SourceName), filters.NewGetSourceFilterListParams().WithSourceName(cmd.SourceName),
) )
if err != nil { if err != nil {
return err return err
} }
if len(sourceFilters.Filters) == 0 { if len(filters.Filters) == 0 {
fmt.Fprintf(ctx.Out, "No filters found for source %s.\n", cmd.SourceName) fmt.Fprintf(ctx.Out, "No filters found for source %s.\n", cmd.SourceName)
return nil return nil
} }
@ -51,20 +42,10 @@ func (cmd *FilterListCmd) Run(ctx *context) error {
t.SetAlignment(table.AlignLeft, table.AlignLeft, table.AlignCenter, table.AlignLeft) t.SetAlignment(table.AlignLeft, table.AlignLeft, table.AlignCenter, table.AlignLeft)
t.SetHeaders("Filter Name", "Kind", "Enabled", "Settings") t.SetHeaders("Filter Name", "Kind", "Enabled", "Settings")
for _, filter := range sourceFilters.Filters { for _, filter := range filters.Filters {
defaultSettings, err := ctx.Client.Filters.GetSourceFilterDefaultSettings(
filters.NewGetSourceFilterDefaultSettingsParams().
WithFilterKind(filter.FilterKind),
)
if err != nil {
return fmt.Errorf("failed to get default settings for filter %s: %w",
filter.FilterName, err)
}
maps.Insert(defaultSettings.DefaultFilterSettings, maps.All(filter.FilterSettings))
var lines []string var lines []string
for k, v := range defaultSettings.DefaultFilterSettings { for k, v := range filter.FilterSettings {
lines = append(lines, fmt.Sprintf("%s: %v", snakeCaseToTitleCase(k), v)) lines = append(lines, fmt.Sprintf("%s %v", k, v))
} }
sort.Slice(lines, func(i, j int) bool { sort.Slice(lines, func(i, j int) bool {
return strings.ToLower(lines[i]) < strings.ToLower(lines[j]) return strings.ToLower(lines[i]) < strings.ToLower(lines[j])

View File

@ -21,8 +21,6 @@ type InputListCmd struct {
Input bool `flag:"" help:"List all inputs." aliases:"i"` Input bool `flag:"" help:"List all inputs." aliases:"i"`
Output bool `flag:"" help:"List all outputs." aliases:"o"` Output bool `flag:"" help:"List all outputs." aliases:"o"`
Colour bool `flag:"" help:"List all colour sources." aliases:"c"` Colour bool `flag:"" help:"List all colour sources." aliases:"c"`
Ffmpeg bool `flag:"" help:"List all ffmpeg sources." aliases:"f"`
Vlc bool `flag:"" help:"List all VLC sources." aliases:"v"`
} }
// Run executes the command to list all inputs. // Run executes the command to list all inputs.
@ -34,47 +32,22 @@ func (cmd *InputListCmd) Run(ctx *context) error {
t := table.New(ctx.Out) t := table.New(ctx.Out)
t.SetPadding(3) t.SetPadding(3)
t.SetAlignment(table.AlignLeft, table.AlignLeft, table.AlignCenter) t.SetAlignment(table.AlignLeft, table.AlignLeft)
t.SetHeaders("Input Name", "Kind", "Muted") t.SetHeaders("Input Name", "Kind")
for _, input := range resp.Inputs { for _, input := range resp.Inputs {
var muteMark string if cmd.Input && strings.Contains(input.InputKind, "input") {
for _, kind := range []string{"input", "output", "ffmpeg", "vlc"} { t.AddRow(input.InputName, input.InputKind)
if strings.Contains(input.InputKind, kind) { }
resp, err := ctx.Client.Inputs.GetInputMute( if cmd.Output && strings.Contains(input.InputKind, "output") {
inputs.NewGetInputMuteParams().WithInputName(input.InputName), t.AddRow(input.InputName, input.InputKind)
) }
if err != nil { if cmd.Colour && strings.Contains(input.InputKind, "color") { // nolint
return fmt.Errorf("failed to get input mute state: %w", err) t.AddRow(input.InputName, input.InputKind)
}
muteMark = getEnabledMark(resp.InputMuted)
break
}
} }
type filter struct { if !cmd.Input && !cmd.Output && !cmd.Colour {
enabled bool t.AddRow(input.InputName, input.InputKind)
keyword string
}
filters := []filter{
{cmd.Input, "input"},
{cmd.Output, "output"},
{cmd.Colour, "color"}, // nolint: misspell
{cmd.Ffmpeg, "ffmpeg"},
{cmd.Vlc, "vlc"},
}
var added bool
for _, f := range filters {
if f.enabled && strings.Contains(input.InputKind, f.keyword) {
t.AddRow(input.InputName, input.InputKind, muteMark)
added = true
break
}
}
if !added && (!cmd.Input && !cmd.Output && !cmd.Colour && !cmd.Ffmpeg && !cmd.Vlc) {
t.AddRow(input.InputName, input.InputKind, muteMark)
} }
} }
t.Render() t.Render()

View File

@ -71,11 +71,11 @@ func (cmd *SceneItemListCmd) Run(ctx *context) error {
fmt.Sprintf("%d", groupItem.SceneItemID), fmt.Sprintf("%d", groupItem.SceneItemID),
groupItem.SourceName, groupItem.SourceName,
item.SourceName, item.SourceName,
getEnabledMark(item.SceneItemEnabled && groupItem.SceneItemEnabled), fmt.Sprintf("%t", item.SceneItemEnabled && groupItem.SceneItemEnabled),
) )
} }
} else { } else {
t.AddRow(fmt.Sprintf("%d", item.SceneItemID), item.SourceName, "", getEnabledMark(item.SceneItemEnabled)) t.AddRow(fmt.Sprintf("%d", item.SceneItemID), item.SourceName, "", fmt.Sprintf("%t", item.SceneItemEnabled))
} }
} }
t.Render() t.Render()