/* Copyright (C) 2003 Bob Ham Copyright (C) 2008 Nedko Arnaudov This program is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef __jack_driver_interface_h__ #define __jack_driver_interface_h__ #ifdef __cplusplus extern "C" { #endif #include #include "jslist.h" #include "JackCompilerDeps.h" #include "JackSystemDeps.h" #define JACK_DRIVER_NAME_MAX 15 #define JACK_DRIVER_PARAM_NAME_MAX 15 #define JACK_DRIVER_PARAM_STRING_MAX 127 #define JACK_DRIVER_PARAM_DESC 255 #define JACK_PATH_MAX 511 #define JACK_CONSTRAINT_FLAG_RANGE ((uint32_t)1) /**< if set, constraint is a range (min-max) */ #define JACK_CONSTRAINT_FLAG_STRICT ((uint32_t)2) /**< if set, constraint is strict, i.e. supplying non-matching value will not work */ #define JACK_CONSTRAINT_FLAG_FAKE_VALUE ((uint32_t)4) /**< if set, values have no user meaningful meaning */ /** Driver parameter types */ typedef enum { JackDriverParamInt = 1, JackDriverParamUInt, JackDriverParamChar, JackDriverParamString, JackDriverParamBool } jack_driver_param_type_t; /** Driver types */ typedef enum { JackDriverMaster = 1, JackDriverSlave, JackDriverNone, } jack_driver_type_t; /** Driver parameter value */ typedef union { uint32_t ui; int32_t i; char c; char str[JACK_DRIVER_PARAM_STRING_MAX + 1]; } jack_driver_param_value_t; typedef struct { jack_driver_param_value_t value; char short_desc[64]; /**< A short (~30 chars) description for the user */ } jack_driver_param_value_enum_t; struct jack_constraint_enum_uint32_descriptor { uint32_t value; const char * short_desc; }; struct jack_constraint_enum_sint32_descriptor { int32_t value; const char * short_desc; }; struct jack_constraint_enum_char_descriptor { char value; const char * short_desc; }; struct jack_constraint_enum_str_descriptor { const char * value; const char * short_desc; }; typedef struct { uint32_t flags; /**< JACK_CONSTRAINT_FLAG_XXX */ union { struct { jack_driver_param_value_t min; jack_driver_param_value_t max; } range; /**< valid when JACK_CONSTRAINT_FLAG_RANGE flag is set */ struct { uint32_t count; jack_driver_param_value_enum_t * possible_values_array; } enumeration; /**< valid when JACK_CONSTRAINT_FLAG_RANGE flag is not set */ } constraint; } jack_driver_param_constraint_desc_t; /** A driver parameter descriptor */ typedef struct { char name[JACK_DRIVER_NAME_MAX + 1]; /**< The parameter's name */ char character; /**< The parameter's character (for getopt, etc) */ jack_driver_param_type_t type; /**< The parameter's type */ jack_driver_param_value_t value; /**< The parameter's (default) value */ jack_driver_param_constraint_desc_t * constraint; /**< Pointer to parameter constraint descriptor. NULL if there is no constraint */ char short_desc[64]; /**< A short (~30 chars) description for the user */ char long_desc[1024]; /**< A longer description for the user */ } jack_driver_param_desc_t; /** A driver parameter */ typedef struct { char character; jack_driver_param_value_t value; } jack_driver_param_t; /** A struct for describing a jack driver */ typedef struct { char name[JACK_DRIVER_NAME_MAX + 1]; /**< The driver's canonical name */ jack_driver_type_t type; /**< The driver's type */ char desc[JACK_DRIVER_PARAM_DESC + 1]; /**< The driver's extended description */ #ifdef WIN32 wchar_t file[JACK_PATH_MAX + 1]; /**< The filename of the driver's shared object file */ #else char file[JACK_PATH_MAX + 1]; /**< The filename of the driver's shared object file */ #endif uint32_t nparams; /**< The number of parameters the driver has */ jack_driver_param_desc_t * params; /**< An array of parameter descriptors */ } jack_driver_desc_t; typedef struct { uint32_t size; /* size of the param array, in elements */ } jack_driver_desc_filler_t; int jack_parse_driver_params(jack_driver_desc_t * desc, int argc, char* argv[], JSList ** param_ptr); // To be used by drivers SERVER_EXPORT jack_driver_desc_t * /* Newly allocated driver descriptor, NULL on failure */ jack_driver_descriptor_construct( const char * name, /* Driver name */ jack_driver_type_t type, /* Driver type */ const char * description, /* Driver description */ jack_driver_desc_filler_t * filler); /* Pointer to stack var to be supplied to jack_driver_descriptor_add_parameter() as well. Can be NULL for drivers that have no parameters. */ SERVER_EXPORT int /* 0 on failure */ jack_driver_descriptor_add_parameter( jack_driver_desc_t * driver_descr, /* Pointer to driver descriptor as returned by jack_driver_descriptor_construct() */ jack_driver_desc_filler_t * filler, /* Pointer to the stack var that was supplied to jack_driver_descriptor_add_parameter(). */ const char * name, /* Parameter's name */ char character, /* Parameter's character (for getopt, etc) */ jack_driver_param_type_t type, /* The parameter's type */ const jack_driver_param_value_t * value_ptr, /* Pointer to parameter's (default) value */ jack_driver_param_constraint_desc_t * constraint, /* Pointer to parameter constraint descriptor. NULL if there is no constraint */ const char * short_desc, /* A short (~30 chars) description for the user */ const char * long_desc); /* A longer description for the user, if NULL short_desc will be used */ SERVER_EXPORT int jack_constraint_add_enum( jack_driver_param_constraint_desc_t ** constraint_ptr_ptr, uint32_t * array_size_ptr, jack_driver_param_value_t * value_ptr, const char * short_desc); SERVER_EXPORT void jack_constraint_free(jack_driver_param_constraint_desc_t * constraint_ptr); #define JACK_CONSTRAINT_COMPOSE_ENUM(type) \ SERVER_EXPORT \ jack_driver_param_constraint_desc_t * \ jack_constraint_compose_enum_ ## type( \ uint32_t flags, \ struct jack_constraint_enum_ ## type ## _descriptor * descr_array_ptr) JACK_CONSTRAINT_COMPOSE_ENUM(uint32); JACK_CONSTRAINT_COMPOSE_ENUM(sint32); JACK_CONSTRAINT_COMPOSE_ENUM(char); JACK_CONSTRAINT_COMPOSE_ENUM(str); typedef jack_driver_desc_t * (*JackDriverDescFunction) (); #ifdef __cplusplus } #endif #endif /* __jack_driver_interface_h__ */