Compare commits

..

No commits in common. "b4519cc2cc4637066619310006645595f0646788" and "09793afafa9bd6eb1d1149642544bc43298945e3" have entirely different histories.

8 changed files with 46 additions and 117 deletions

8
include/cdll.h Normal file
View File

@ -0,0 +1,8 @@
#ifndef __CDLL_H__
#define __CDLL_H__
#include "VoicemeeterRemote.h"
PT_VMR create_interface();
#endif /*__CDLL_H__*/

View File

@ -1,15 +0,0 @@
/**
* Copyright (c) 2024 Onyx and Iris
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the MIT license. See `ivmr.c` for details.
*/
#ifndef __IVMR_H__
#define __IVMR_H__
#include "VoicemeeterRemote.h"
PT_VMR create_interface();
#endif /* __IVMR_H__ */

View File

@ -1,10 +1,3 @@
/**
* Copyright (c) 2024 Onyx and Iris
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the MIT license. See `util.c` for details.
*/
#ifndef __UTIL_H__ #ifndef __UTIL_H__
#define __UTIL_H__ #define __UTIL_H__

View File

@ -1,12 +1,5 @@
/** #ifndef __VMR_H__
* Copyright (c) 2024 Onyx and Iris #define __VMR_H__
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the MIT license. See `wrapper.c` for details.
*/
#ifndef __WRAPPER_H__
#define __WRAPPER_H__
#include <stdbool.h> #include <stdbool.h>
#include "voicemeeterRemote.h" #include "voicemeeterRemote.h"
@ -43,4 +36,4 @@ long macrobutton_setstatus(PT_VMR vmr, long n, float val, long mode);
void clear_dirty(PT_VMR vmr); void clear_dirty(PT_VMR vmr);
#endif /* __WRAPPER_H__ */ #endif /* __VMR_H__ */

View File

@ -1,22 +1,7 @@
/**
* @file ivmr.c
* @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.5.0
* @date 2024-07-06
*
* @copyright Vincent Burel(c)2015-2021 All Rights Reserved
* https://github.com/onyx-and-iris/Voicemeeter-SDK/blob/main/LICENSE
*
* Copyright (c) 2024
* https://github.com/onyx-and-iris/vmrcli/blob/main/LICENSE
*/
#include <stdbool.h> #include <stdbool.h>
#include <stdio.h> #include <stdio.h>
#include <windows.h> #include <windows.h>
#include "ivmr.h" #include "cdll.h"
#include "util.h" #include "util.h"
#include "log.h" #include "log.h"
@ -25,11 +10,6 @@ static T_VBVMR_INTERFACE iVMR;
static long initialize_dll_interfaces(PT_VMR vmr); static long initialize_dll_interfaces(PT_VMR vmr);
static bool registry_get_voicemeeter_folder(char *szDir); static bool registry_get_voicemeeter_folder(char *szDir);
/**
* @brief Create an interface object
*
* @return PT_VMR Pointer to the iVMR interface
*/
PT_VMR create_interface() PT_VMR create_interface()
{ {
PT_VMR vmr = &iVMR; PT_VMR vmr = &iVMR;

View File

@ -1,23 +1,12 @@
/**
* @file util.c
* @author Onyx and Iris (code@onyxandiris.online)
* @brief Utility functions.
* @version 0.5.0
* @date 2024-07-06
*
* @copyright Copyright (c) 2024
* https://github.com/onyx-and-iris/vmrcli/blob/main/LICENSE
*/
#include <stddef.h> #include <stddef.h>
#include <stdio.h> #include <stdio.h>
#include "wrapper.h" #include "vmr.h"
#include "util.h" #include "util.h"
/** /**
* @brief Removes the last part of a path * @brief Removes the last part of a path
* *
* @param szPath Pointer to the path string * @param szPath
*/ */
void remove_name_in_path(char *szPath) void remove_name_in_path(char *szPath)
{ {
@ -32,11 +21,11 @@ void remove_name_in_path(char *szPath)
} }
/** /**
* @brief Replaces multiple newlines and tabs with single spaces * @brief replaces multiple newlines and tabs with single spaces
* *
* @param s The string to be reduced * @param s the string to be reduced
* @param len Current length of the string * @param len current length of the string
* @return int New length of the string * @return int new length of the string
*/ */
int replace_multiple_space_with_one(char *s, size_t len) int replace_multiple_space_with_one(char *s, size_t len)
{ {
@ -74,12 +63,12 @@ int replace_multiple_space_with_one(char *s, size_t len)
} }
/** /**
* @brief Converts Voicemeeter's kind into a string. * @brief
* *
* @param s Pointer to a character buffer * @param s Pointer to a character buffer
* @param kind The kind of Voicemeeter. * @param kind The kind of Voicemeeter.
* @param n Maximum number of characters to be written to the buffer * @param n maximum number of characters to be written to the buffer
* @return char* String representation of the kind of Voicemeeter. * @return char* The kind of Voicemeeter as a string
*/ */
char *kind_as_string(char *s, int kind, int n) char *kind_as_string(char *s, int kind, int n)
{ {
@ -96,12 +85,12 @@ char *kind_as_string(char *s, int kind, int n)
} }
/** /**
* @brief Converts Voicemeeter's version into a string. * @brief returns Voicemeeter's version as a string
* *
* @param s Pointer to a character buffer * @param s string buffer the version will be written to
* @param v Unprocessed version as a long int * @param v unprocessed version as a long int
* @param n Maximum number of characters to be written to the buffer * @param n maximum number of characters to be written to the buffer
* @return char* String representation of the Voicemeeter version * @return char*
*/ */
char *version_as_string(char *s, long v, int n) char *version_as_string(char *s, long v, int n)
{ {

View File

@ -1,32 +1,21 @@
/**
* @file wrapper.c
* @author Onyx and Iris (code@onyxandiris.online)
* @brief Provides public functions that wrap the iVMR calls
* @version 0.5.0
* @date 2024-07-06
*
* @copyright Copyright (c) 2024
* https://github.com/onyx-and-iris/vmrcli/blob/main/LICENSE
*/
#include <windows.h> #include <windows.h>
#include <stdio.h> #include <stdio.h>
#include <time.h> #include <time.h>
#include "wrapper.h" #include "vmr.h"
#include "log.h" #include "log.h"
#include "util.h" #include "util.h"
#define VERSION_STR_LEN 128
#define KIND_STR_LEN 64 #define KIND_STR_LEN 64
#define VERSION_STR_LEN 32
/** /**
* @brief Logs into the API. * @brief Logs into the API.
* Tests for valid connection for up to 2 seconds. * Tests for valid connection for up to 2 seconds.
* If successful initializes the dirty parameters. * If successful initializes the dirty parameters.
* *
* @param vmr Pointer to the iVMR interface * @param vmr
* @param kind The kind of Voicemeeter Gui to launch. * @param kind
* @return long VBVMR_Login return value * @return long
*/ */
long login(PT_VMR vmr, int kind) long login(PT_VMR vmr, int kind)
{ {
@ -70,7 +59,7 @@ long login(PT_VMR vmr, int kind)
* @brief Logs out of the API giving a short wait to allow a * @brief Logs out of the API giving a short wait to allow a
* final instruction to complete. * final instruction to complete.
* *
* @param vmr Pointer to the iVMR interface * @param vmr The API interface as a struct
* @return long VBVMR_Logout return value * @return long VBVMR_Logout return value
*/ */
long logout(PT_VMR vmr) long logout(PT_VMR vmr)

View File

@ -1,29 +1,20 @@
/**
* @file vmrcli.c
* @author Onyx and Iris (code@onyxandiris.online)
* @brief A Voicemeeter Remote Command Line Interface
* @version 0.5.0
* @date 2024-07-06
*
* @copyright Copyright (c) 2024
* https://github.com/onyx-and-iris/vmrcli/blob/main/LICENSE
*/
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <stdbool.h> #include <stdbool.h>
#include <getopt.h> #include <getopt.h>
#include <string.h> #include <string.h>
#include <ctype.h> #include <ctype.h>
#include "ivmr.h" #include "cdll.h"
#include "wrapper.h" #include "vmr.h"
#include "log.h" #include "log.h"
#include "util.h" #include "util.h"
#define MAX_LINE 512 #define MAX_LINE 512
/** /**
* @enum The kind of values a get call may return. * @brief An enum used to define the kind of value
* a 'get' call returns.
*
*/ */
enum enum
{ {
@ -32,7 +23,8 @@ enum
}; };
/** /**
* @struct A struct holding the result of a get call. * @brief A struct holding the result of a get call.
*
*/ */
struct result struct result
{ {
@ -175,6 +167,7 @@ int main(int argc, char *argv[])
/** /**
* @brief prints the help message * @brief prints the help message
*
*/ */
void help() void help()
{ {
@ -192,10 +185,9 @@ void help()
} }
/** /**
* @brief Set the kind of Voicemeeter based on the value of -k flag. * @brief Set the kind object
* For 64 bit systems the value is promoted to X64.
* *
* @param kval Value of the -k flag * @param kval
* @return enum kind * @return enum kind
*/ */
enum kind set_kind(char *kval) enum kind set_kind(char *kval)
@ -232,7 +224,7 @@ enum kind set_kind(char *kval)
* Break if 'Q' is entered on the interactive prompt. * Break if 'Q' is entered on the interactive prompt.
* Each line is passed to parse_input() * Each line is passed to parse_input()
* *
* @param vmr Pointer to the iVMR interface * @param vmr The API interface as a struct
*/ */
void interactive(PT_VMR vmr) void interactive(PT_VMR vmr)
{ {
@ -258,7 +250,7 @@ void interactive(PT_VMR vmr)
* @brief Walks through each line split by a space delimiter. * @brief Walks through each line split by a space delimiter.
* Each token is passed to parse_command() * Each token is passed to parse_command()
* *
* @param vmr Pointer to the iVMR interface * @param vmr The API interface as a struct
* @param input Each input line, from stdin or CLI args * @param input Each input line, from stdin or CLI args
* @param len The length of the input line * @param len The length of the input line
*/ */
@ -280,7 +272,7 @@ void parse_input(PT_VMR vmr, char *input, int len)
* See command type definitions in: * See command type definitions in:
* https://github.com/onyx-and-iris/vmrcli?tab=readme-ov-file#api-commands * https://github.com/onyx-and-iris/vmrcli?tab=readme-ov-file#api-commands
* *
* @param vmr Pointer to the iVMR interface * @param vmr The API interface as a struct
* @param command Each token from the input line as its own command string * @param command Each token from the input line as its own command string
*/ */
void parse_command(PT_VMR vmr, char *command) void parse_command(PT_VMR vmr, char *command)
@ -339,7 +331,7 @@ void parse_command(PT_VMR vmr, char *command)
/** /**
* @brief * @brief
* *
* @param vmr Pointer to the iVMR interface * @param vmr The API interface as a struct
* @param command A parsed 'get' command as a string * @param command A parsed 'get' command as a string
* @param res A struct holding the result of the API call. * @param res A struct holding the result of the API call.
*/ */