9 Commits

Author SHA1 Message Date
a7c0bc1620 fix comment 2024-07-12 12:05:43 +01:00
25692a9f35 increase input buffer size
when resetting buffer, clear only bits written to
2024-07-12 12:04:03 +01:00
a05b029e9d specify enum type 2024-07-11 18:45:35 +01:00
68c2022ad7 return quickcommands + i 2024-07-10 23:57:19 +01:00
ff2970f4c5 move quickcommands into parse_command() 2024-07-10 23:37:49 +01:00
f60fc231b0 add note about quick commands to README 2024-07-10 18:20:58 +01:00
c1dad8b99c minor bump 2024-07-10 18:17:13 +01:00
2f2e503ae3 implements a short list of quickcommands 2024-07-10 18:15:11 +01:00
ff69837f19 add LOGIN_TIMEOUT macro 2024-07-10 18:11:58 +01:00
8 changed files with 83 additions and 18 deletions

4
.gitignore vendored
View File

@@ -51,4 +51,6 @@ Module.symvers
Mkfile.old
dkms.conf
.vscode/
.vscode/
test*

View File

@@ -48,6 +48,18 @@ Launch banana GUI, set log level to DEBUG, set Strip 0 label to podmic then prin
.\vmrcli.exe -kbanana -D1 strip[0].label=podmic strip[2].label
```
#### `Quick Commands`
A short list of quick commands are available:
- `lock`: command.lock=1
- `unlock`: command.lock=0
- `show`: command.show=1
- `hide`: command.show=0
- `restart`: command.restart=1
They may be used in direct or interactive mode.
## `Interactive Mode`
Running the following command in Powershell:

View File

@@ -8,9 +8,16 @@
#ifndef __UTIL_H__
#define __UTIL_H__
struct quickcommand
{
char *name;
char *fullcommand;
};
void remove_last_part_of_path(char *fullpath);
char *kind_as_string(char *s, int kind, int n);
char *version_as_string(char *s, long v, int n);
bool is_comment(char *s);
struct quickcommand *command_in_quickcommands(const char *command, const struct quickcommand *quickcommands, int n);
#endif /* __UTIL_H__ */

View File

@@ -11,7 +11,7 @@
#include <stdbool.h>
#include "voicemeeterRemote.h"
enum kind
enum kind : int
{
UNKNOWN = -1,
BASIC = 1,

View File

@@ -3,7 +3,7 @@
* @author Vincent Burel, Onyx and Iris (code@onyxandiris.online)
* @brief Functions for initializing the iVMR interface.
* Defines a single public function that returns a pointer to the interface.
* @version 0.8.0
* @version 0.9.0
* @date 2024-07-06
*
* @copyright Vincent Burel(c)2015-2021 All Rights Reserved

View File

@@ -2,7 +2,7 @@
* @file util.c
* @author Onyx and Iris (code@onyxandiris.online)
* @brief Utility functions.
* @version 0.8.0
* @version 0.9.0
* @date 2024-07-06
*
* @copyright Copyright (c) 2024
@@ -81,4 +81,26 @@ char *version_as_string(char *s, long v, int n)
bool is_comment(char *s)
{
return s[0] == '#';
}
}
/**
* @brief Searches the quickcommands array for a quickcommand
* corresponding to the command_key.
*
* @param command_key The key used to search for the quickcommand
* @param quickcommands Pointer to an array of quickcommands
* @param n The number of quickcommands
* @return struct quickcommand* Pointer to the found quickcommand
* May return NULL if quickcommand not found.
*/
struct quickcommand *command_in_quickcommands(const char *command_key, const struct quickcommand *quickcommands, int n)
{
for (int i = 0; i < n; i++)
{
if (strcmp(command_key, quickcommands[i].name) == 0)
{
return (struct quickcommand *)(quickcommands + i);
}
}
return NULL;
}

View File

@@ -2,7 +2,7 @@
* @file vmrcli.c
* @author Onyx and Iris (code@onyxandiris.online)
* @brief A Voicemeeter Remote Command Line Interface
* @version 0.8.0
* @version 0.9.0
* @date 2024-07-06
*
* @copyright Copyright (c) 2024
@@ -32,12 +32,15 @@
"\tm: Launch the MacroButtons application\n" \
"\ts: Launch the StreamerView application"
#define OPTSTR ":hk:msc:iID:v"
#define MAX_LINE 512
#define MAX_LINE 4096 /* Size of the input buffer */
#define RES_SZ 512 /* Size of the buffer passed to VBVMR_GetParameterStringW */
#define COUNT_OF(x) (sizeof(x) / sizeof(x[0]))
#define DELIMITERS " \t;,"
/**
* @enum The kind of values a get call may return.
*/
enum
enum restype : int
{
FLOAT_T,
STRING_T,
@@ -48,17 +51,17 @@ enum
*/
struct result
{
int type;
enum restype type;
union val
{
float f;
wchar_t s[MAX_LINE];
wchar_t s[RES_SZ];
} val;
};
static bool vflag = false;
static void usage(void);
static void usage();
enum kind set_kind(char *kval);
void interactive(PT_VMR vmr, bool with_prompt);
void parse_input(PT_VMR vmr, char *input);
@@ -238,18 +241,19 @@ enum kind set_kind(char *kval)
void interactive(PT_VMR vmr, bool with_prompt)
{
char input[MAX_LINE];
size_t len;
if (with_prompt)
printf(">> ");
while (fgets(input, MAX_LINE, stdin) != NULL)
{
input[strcspn(input, "\n")] = 0;
if (strlen(input) == 1 && toupper(input[0]) == 'Q')
if ((len = strlen(input)) == 1 && toupper(input[0]) == 'Q')
break;
parse_input(vmr, input);
memset(input, 0, len); /* reset input buffer */
memset(input, 0, MAX_LINE); /* reset input buffer */
if (with_prompt)
printf(">> ");
}
@@ -270,11 +274,11 @@ void parse_input(PT_VMR vmr, char *input)
char *token, *p;
token = strtok_r(input, " \t;,", &p);
token = strtok_r(input, DELIMITERS, &p);
while (token != NULL)
{
parse_command(vmr, token);
token = strtok_r(NULL, " \t;,", &p);
token = strtok_r(NULL, DELIMITERS, &p);
}
}
@@ -290,6 +294,24 @@ void parse_command(PT_VMR vmr, char *command)
{
log_debug("Parsing %s", command);
static const struct quickcommand quickcommands[] = {
{.name = "lock", .fullcommand = "command.lock=1"},
{.name = "unlock", .fullcommand = "command.lock=0"},
{.name = "show", .fullcommand = "command.show=1"},
{.name = "hide", .fullcommand = "command.show=0"},
{.name = "restart", .fullcommand = "command.restart=1"}};
struct quickcommand *qc_ptr = command_in_quickcommands(command, quickcommands, (int)COUNT_OF(quickcommands));
if (qc_ptr != NULL)
{
set_parameters(vmr, qc_ptr->fullcommand);
if (vflag)
{
printf("Setting %s\n", qc_ptr->fullcommand);
}
return;
}
if (command[0] == '!') /* toggle */
{
command++;

View File

@@ -2,7 +2,7 @@
* @file wrapper.c
* @author Onyx and Iris (code@onyxandiris.online)
* @brief Provides public functions that wrap the iVMR calls
* @version 0.8.0
* @version 0.9.0
* @date 2024-07-06
*
* @copyright Copyright (c) 2024
@@ -18,6 +18,7 @@
#define KIND_STR_LEN 64
#define VERSION_STR_LEN 32
#define LOGIN_TIMEOUT 2
/**
* @brief Logs into the API.
@@ -44,7 +45,6 @@ long login(PT_VMR vmr, int kind)
kind_as_string(kind_s, kind, KIND_STR_LEN));
}
int timeout = 2;
time_t start = time(NULL);
do
{
@@ -57,7 +57,7 @@ long login(PT_VMR vmr, int kind)
break;
}
Sleep(50);
} while (time(NULL) < start + timeout);
} while (difftime(time(NULL), start) < LOGIN_TIMEOUT);
if (rep == 0)
{