diff options
author | IOhannes m zmölnig <zmoelnig@umlautQ.umlaeute.mur.at> | 2016-01-25 11:25:59 +0100 |
---|---|---|
committer | IOhannes m zmölnig <zmoelnig@umlautQ.umlaeute.mur.at> | 2016-01-25 11:25:59 +0100 |
commit | 110d59c341b8c50c04f30d90e85e9b8f6f329a0e (patch) | |
tree | 174afbe2ded41ae03923b93a0c4e6975e3163ad5 /sndlib2xen.c | |
parent | e5328e59987b90c4e98959510b810510e384650d (diff) |
Imported Upstream version 16.1
Diffstat (limited to 'sndlib2xen.c')
-rw-r--r-- | sndlib2xen.c | 2857 |
1 files changed, 662 insertions, 2195 deletions
diff --git a/sndlib2xen.c b/sndlib2xen.c index 886cff9..1684b01 100644 --- a/sndlib2xen.c +++ b/sndlib2xen.c @@ -1,6 +1,6 @@ /* Tie sndlib into Xen */ -#include <mus-config.h> +#include "mus-config.h" #if USE_SND #include "snd.h" @@ -23,29 +23,36 @@ #include <string.h> #include <errno.h> + +#ifdef _MSC_VER + #pragma warning(disable: 4244) +#endif + #include "_sndlib.h" #include "sndlib-strings.h" -#include "sndlib2xen.h" #include "vct.h" #include "clm.h" +#include "sndlib2xen.h" +#include "clm2xen.h" -#ifndef S_setB +#ifndef S_set #if HAVE_RUBY - #define S_setB "set_" + #define S_set "set_" #endif #if HAVE_SCHEME - #define S_setB "set! " + #define S_set "set! " #endif #if HAVE_FORTH - #define S_setB "set-" + #define S_set "set-" #endif #endif + /* originally I tried to simplify C GC by using global static strings that were * freed whenever the associated function was called again, on the assumption * that the preceding value was now unused. In a multithread context, that - * assumption is false, so I can't use code like this: + * assumption is false, so I didn't use code like this: * * static char *tmpstr = NULL; * @@ -57,214 +64,245 @@ * } */ -static XEN g_mus_sound_loop_info(XEN gfilename) +static Xen g_mus_sound_loop_info(Xen gfilename) { #define H_mus_sound_loop_info "(" S_mus_sound_loop_info " filename): synth loop info for sound as a list: (start1 \ end1 start2 end2 base-note base-detune mode1 mode2)" int *res; - XEN sres = XEN_EMPTY_LIST; + Xen sres = Xen_empty_list; char *str = NULL; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ONLY_ARG, S_mus_sound_loop_info, "a string"); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, S_mus_sound_loop_info, "a string"); - res = mus_sound_loop_info(str = mus_expand_filename(XEN_TO_C_STRING(gfilename))); + res = mus_sound_loop_info(str = mus_expand_filename(Xen_string_to_C_string(gfilename))); if (str) free(str); if (res) { - sres = XEN_LIST_8(C_TO_XEN_INT(res[0]), C_TO_XEN_INT(res[1]), C_TO_XEN_INT(res[2]), - C_TO_XEN_INT(res[3]), C_TO_XEN_INT(res[4]), C_TO_XEN_INT(res[5]), - C_TO_XEN_INT(res[6]), C_TO_XEN_INT(res[7])); + sres = Xen_list_8(C_int_to_Xen_integer(res[0]), C_int_to_Xen_integer(res[1]), C_int_to_Xen_integer(res[2]), + C_int_to_Xen_integer(res[3]), C_int_to_Xen_integer(res[4]), C_int_to_Xen_integer(res[5]), + C_int_to_Xen_integer(res[6]), C_int_to_Xen_integer(res[7])); free(res); } return(sres); } -static XEN g_mus_sound_mark_info(XEN gfilename) +static Xen g_mus_sound_mark_info(Xen gfilename) { #define H_mus_sound_mark_info "(" S_mus_sound_mark_info " filename): aifc header mark info as a list of lists: ((id pos)...)" int *mark_ids, *mark_positions; int marks = 0; - XEN sres = XEN_EMPTY_LIST; + Xen sres = Xen_empty_list; char *str = NULL; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ONLY_ARG, S_mus_sound_mark_info, "a string"); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, S_mus_sound_mark_info, "a string"); - marks = mus_sound_mark_info(str = mus_expand_filename(XEN_TO_C_STRING(gfilename)), &mark_ids, &mark_positions); + marks = mus_sound_mark_info(str = mus_expand_filename(Xen_string_to_C_string(gfilename)), &mark_ids, &mark_positions); if (str) free(str); if (marks > 0) { int i; for (i = 0; i < marks; i++) - sres = XEN_CONS(XEN_LIST_2(C_TO_XEN_INT(mark_ids[i]), - C_TO_XEN_INT(mark_positions[i])), + sres = Xen_cons(Xen_list_2(C_int_to_Xen_integer(mark_ids[i]), + C_int_to_Xen_integer(mark_positions[i])), sres); } return(sres); } -static XEN gmus_sound(const char *caller, int (*func)(const char *file), XEN gfilename) +static Xen gmus_sound(const char *caller, int (*func)(const char *file), Xen gfilename) { char *str = NULL; - XEN result; + Xen result; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ONLY_ARG, caller, "a string"); - str = mus_expand_filename(XEN_TO_C_STRING(gfilename)); - result = C_TO_XEN_INT((*func)(str)); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, caller, "a string"); + str = mus_expand_filename(Xen_string_to_C_string(gfilename)); + result = C_int_to_Xen_integer((*func)(str)); if (str) free(str); return(result); } -static XEN gmus_sound_set(const char *caller, int (*func)(const char *file, int newval), XEN gfilename, XEN val) +static Xen gmus_sound_set(const char *caller, int (*func)(const char *file, int newval), Xen gfilename, Xen val) { char *str = NULL; - XEN result; + Xen result; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ARG_1, caller, "a string"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(val), val, XEN_ARG_2, caller, "an integer"); - str = mus_expand_filename(XEN_TO_C_STRING(gfilename)); - result = C_TO_XEN_INT((*func)(str, XEN_TO_C_INT(val))); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, caller, "a string"); + Xen_check_type(Xen_is_integer(val), val, 2, caller, "an integer"); + str = mus_expand_filename(Xen_string_to_C_string(gfilename)); + result = C_int_to_Xen_integer((*func)(str, Xen_integer_to_C_int(val))); if (str) free(str); return(result); } -static XEN glmus_sound(const char *caller, mus_long_t (*func)(const char *file), XEN gfilename) +static Xen glmus_sound(const char *caller, mus_long_t (*func)(const char *file), Xen gfilename) { char *str = NULL; - XEN result; + Xen result; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ONLY_ARG, caller, "a string"); - str = mus_expand_filename(XEN_TO_C_STRING(gfilename)); - result = C_TO_XEN_INT64_T((*func)(str)); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, caller, "a string"); + str = mus_expand_filename(Xen_string_to_C_string(gfilename)); + result = C_llong_to_Xen_llong((*func)(str)); if (str) free(str); return(result); } -static XEN glmus_sound_set(const char *caller, int (*func)(const char *file, mus_long_t newval), XEN gfilename, XEN val) +static Xen glmus_sound_set(const char *caller, int (*func)(const char *file, mus_long_t newval), Xen gfilename, Xen val) { char *str = NULL; - XEN result; + Xen result; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ARG_1, caller, "a string"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(val), val, XEN_ARG_2, caller, "a number"); - str = mus_expand_filename(XEN_TO_C_STRING(gfilename)); - result = C_TO_XEN_INT64_T((*func)(str, XEN_TO_C_INT64_T(val))); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, caller, "a string"); + Xen_check_type(Xen_is_number(val), val, 2, caller, "a number"); + str = mus_expand_filename(Xen_string_to_C_string(gfilename)); + result = C_llong_to_Xen_llong((*func)(str, Xen_llong_to_C_llong(val))); if (str) free(str); return(result); } -static XEN g_mus_sound_samples(XEN filename) +static Xen g_mus_sound_samples(Xen filename) { - #define H_mus_sound_samples "(" S_mus_sound_samples " filename): samples (frames * channels) in sound file" + #define H_mus_sound_samples "(" S_mus_sound_samples " filename): samples (framples * channels) in sound file" return(glmus_sound(S_mus_sound_samples, mus_sound_samples, filename)); } -static XEN g_mus_sound_set_samples(XEN filename, XEN val) +static Xen g_mus_sound_set_samples(Xen filename, Xen val) { - return(glmus_sound_set(S_setB S_mus_sound_samples, mus_sound_set_samples, filename, val)); + return(glmus_sound_set(S_set S_mus_sound_samples, mus_sound_set_samples, filename, val)); } -XEN g_mus_sound_frames(XEN filename) +Xen g_mus_sound_framples(Xen filename) { - #define H_mus_sound_frames "(" S_mus_sound_frames " filename): frames (samples / channel) in sound file" - return(glmus_sound(S_mus_sound_frames, mus_sound_frames, filename)); + #define H_mus_sound_framples "(" S_mus_sound_framples " filename): framples (samples / channel) in sound file" + return(glmus_sound(S_mus_sound_framples, mus_sound_framples, filename)); } -static XEN g_mus_sound_datum_size(XEN filename) +static Xen g_mus_sound_datum_size(Xen filename) { - #define H_mus_sound_datum_size "(" S_mus_sound_datum_size " filename): bytes per sample used by the data in sound file (data format dependent)" + #define H_mus_sound_datum_size "(" S_mus_sound_datum_size " filename): bytes per sample used by the data in sound file (sample type dependent)" return(gmus_sound(S_mus_sound_datum_size, mus_sound_datum_size, filename)); } -static XEN g_mus_sound_data_location(XEN filename) +static Xen g_mus_sound_data_location(Xen filename) { #define H_mus_sound_data_location "(" S_mus_sound_data_location " filename): location (in bytes) of first sample of sound data" return(glmus_sound(S_mus_sound_data_location, mus_sound_data_location, filename)); } -static XEN g_mus_sound_set_data_location(XEN filename, XEN val) +static Xen g_mus_sound_set_data_location(Xen filename, Xen val) { - return(glmus_sound_set(S_setB S_mus_sound_data_location, mus_sound_set_data_location, filename, val)); + return(glmus_sound_set(S_set S_mus_sound_data_location, mus_sound_set_data_location, filename, val)); } -XEN g_mus_sound_chans(XEN filename) +Xen g_mus_sound_chans(Xen filename) { #define H_mus_sound_chans "(" S_mus_sound_chans " filename): channels of data in sound file" return(gmus_sound(S_mus_sound_chans, mus_sound_chans, filename)); } -static XEN g_mus_sound_set_chans(XEN filename, XEN val) +static Xen g_mus_sound_set_chans(Xen filename, Xen val) { - return(gmus_sound_set(S_setB S_mus_sound_chans, mus_sound_set_chans, filename, val)); + return(gmus_sound_set(S_set S_mus_sound_chans, mus_sound_set_chans, filename, val)); } -XEN g_mus_sound_srate(XEN filename) +Xen g_mus_sound_srate(Xen filename) { #define H_mus_sound_srate "(" S_mus_sound_srate " filename): sampling rate of sound file" return(gmus_sound(S_mus_sound_srate, mus_sound_srate, filename)); } -static XEN g_mus_sound_set_srate(XEN filename, XEN val) +static Xen g_mus_sound_set_srate(Xen filename, Xen val) { - return(gmus_sound_set(S_setB S_mus_sound_srate, mus_sound_set_srate, filename, val)); + return(gmus_sound_set(S_set S_mus_sound_srate, mus_sound_set_srate, filename, val)); } -static XEN g_mus_sound_header_type(XEN filename) +static Xen g_mus_sound_header_type(Xen filename) { #define H_mus_sound_header_type "(" S_mus_sound_header_type " filename): header type (e.g. " S_mus_aifc ") of sound file" - return(gmus_sound(S_mus_sound_header_type, mus_sound_header_type, filename)); + + char *str = NULL; + Xen result; + + Xen_check_type(Xen_is_string(filename), filename, 1, S_mus_sound_header_type, "a string"); + str = mus_expand_filename(Xen_string_to_C_string(filename)); + result = C_int_to_Xen_integer((int)mus_sound_header_type(str)); + if (str) free(str); + return(result); } -static XEN g_mus_sound_set_header_type(XEN filename, XEN val) +static Xen g_mus_sound_set_header_type(Xen filename, Xen val) { - return(gmus_sound_set(S_setB S_mus_sound_header_type, mus_sound_set_header_type, filename, val)); + char *str = NULL; + Xen result; + + Xen_check_type(Xen_is_string(filename), filename, 1, S_set S_mus_sound_header_type, "a string"); + Xen_check_type(Xen_is_integer(val), val, 2, S_set S_mus_sound_header_type, "an integer"); + str = mus_expand_filename(Xen_string_to_C_string(filename)); + result = C_int_to_Xen_integer((int)mus_sound_set_header_type(str, (mus_header_t)Xen_integer_to_C_int(val))); + if (str) free(str); + return(result); } -static XEN g_mus_sound_data_format(XEN filename) +static Xen g_mus_sound_sample_type(Xen filename) { - #define H_mus_sound_data_format "(" S_mus_sound_data_format " filename): data format (e.g. " S_mus_bshort ") of data in sound file" - return(gmus_sound(S_mus_sound_data_format, mus_sound_data_format, filename)); + #define H_mus_sound_sample_type "(" S_mus_sound_sample_type " filename): sample type (e.g. " S_mus_bshort ") of data in sound file" + char *str = NULL; + Xen result; + + Xen_check_type(Xen_is_string(filename), filename, 1, S_mus_sound_sample_type, "a string"); + str = mus_expand_filename(Xen_string_to_C_string(filename)); + result = C_int_to_Xen_integer((int)mus_sound_sample_type(str)); + if (str) free(str); + return(result); } -static XEN g_mus_sound_set_data_format(XEN filename, XEN val) +static Xen g_mus_sound_set_sample_type(Xen filename, Xen val) { - return(gmus_sound_set(S_setB S_mus_sound_data_format, mus_sound_set_data_format, filename, val)); + char *str = NULL; + Xen result; + + Xen_check_type(Xen_is_string(filename), filename, 1, S_set S_mus_sound_sample_type, "a string"); + Xen_check_type(Xen_is_integer(val), val, 2, S_set S_mus_sound_sample_type, "an integer"); + str = mus_expand_filename(Xen_string_to_C_string(filename)); + result = C_int_to_Xen_integer((int)mus_sound_set_sample_type(str, (mus_sample_t)Xen_integer_to_C_int(val))); + if (str) free(str); + return(result); } -static XEN g_mus_sound_length(XEN filename) +static Xen g_mus_sound_length(Xen filename) { #define H_mus_sound_length "(" S_mus_sound_length " filename): sound file length in bytes" return(glmus_sound(S_mus_sound_length, mus_sound_length, filename)); } -static XEN g_mus_sound_type_specifier(XEN filename) +static Xen g_mus_sound_type_specifier(Xen filename) { #define H_mus_sound_type_specifier "(" S_mus_sound_type_specifier " filename): original sound file header type identifier (e.g. 0x2e736e64)" return(gmus_sound(S_mus_sound_type_specifier, mus_sound_type_specifier, filename)); } -static XEN g_mus_sound_forget(XEN filename) +static Xen g_mus_sound_forget(Xen filename) { #define H_mus_sound_forget "(" S_mus_sound_forget " filename): remove 'filename' from sound cache. If you create, then later \ delete a sound file, " S_mus_sound_forget " can be used to clear it from sndlib's cache of sound files" @@ -272,305 +310,308 @@ delete a sound file, " S_mus_sound_forget " can be used to clear it from sndlib' } -static XEN g_mus_sound_prune(void) +static Xen g_mus_sound_prune(void) { #define H_mus_sound_prune "(" S_mus_sound_prune "): remove all defunct entries from sndlib's sound file cache." - return(C_TO_XEN_INT(mus_sound_prune())); + return(C_int_to_Xen_integer(mus_sound_prune())); } -static XEN g_mus_sound_comment(XEN gfilename) +static Xen g_mus_sound_comment(Xen gfilename) { #define H_mus_sound_comment "(" S_mus_sound_comment " filename): comment (a string) found in sound file's header" char *res = NULL, *str = NULL; - XEN newstr; + Xen newstr; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ONLY_ARG, S_mus_sound_comment, "a string"); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, S_mus_sound_comment, "a string"); - res = mus_sound_comment(str = mus_expand_filename(XEN_TO_C_STRING(gfilename))); + res = mus_sound_comment(str = mus_expand_filename(Xen_string_to_C_string(gfilename))); if (str) free(str); - newstr = C_TO_XEN_STRING(res); + newstr = C_string_to_Xen_string(res); if (res) free(res); return(newstr); } -static XEN g_mus_sound_write_date(XEN filename) +static Xen g_mus_sound_write_date(Xen filename) { char *str = NULL; - XEN result; + Xen result; #define H_mus_sound_write_date "(" S_mus_sound_write_date " filename): write date of sound file" - XEN_ASSERT_TYPE(XEN_STRING_P(filename), filename, XEN_ONLY_ARG, S_mus_sound_write_date, "a string"); - str = mus_expand_filename(XEN_TO_C_STRING(filename)); - result = C_TO_XEN_ULONG((unsigned long)mus_sound_write_date(str)); /* actually time_t */ + Xen_check_type(Xen_is_string(filename), filename, 1, S_mus_sound_write_date, "a string"); + str = mus_expand_filename(Xen_string_to_C_string(filename)); + result = C_ulong_to_Xen_ulong((unsigned long)mus_sound_write_date(str)); /* actually time_t */ if (str) free(str); return(result); } -static XEN g_mus_header_raw_defaults(void) +static Xen g_mus_header_writable(Xen head, Xen data) { - #define H_mus_header_raw_defaults "(" S_mus_header_raw_defaults "): returns list '(srate chans format) of current raw sound default attributes" - int srate, chans, data_format; - mus_header_raw_defaults(&srate, &chans, &data_format); - return(XEN_LIST_3(C_TO_XEN_INT(srate), - C_TO_XEN_INT(chans), - C_TO_XEN_INT(data_format))); + #define H_mus_header_writable "(" S_mus_header_writable " header-type sample-type) returns " PROC_TRUE " if the header can handle the sample type" + Xen_check_type(Xen_is_integer(head), head, 1, S_mus_header_writable, "a header type"); + Xen_check_type(Xen_is_integer(data), data, 2, S_mus_header_writable, "a sample type"); + return(C_bool_to_Xen_boolean(mus_header_writable((mus_header_t)Xen_integer_to_C_int(head), (mus_sample_t)Xen_integer_to_C_int(data)))); } - -static XEN g_mus_header_set_raw_defaults(XEN lst) +static Xen g_mus_header_raw_defaults(void) { - XEN_ASSERT_TYPE((XEN_LIST_P(lst)) && (XEN_LIST_LENGTH(lst) == 3), lst, XEN_ONLY_ARG, S_mus_header_raw_defaults, "a list: '(srate chans data-format)"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(XEN_CAR(lst)), XEN_CAR(lst), XEN_ARG_1, S_mus_header_raw_defaults, "an integer = srate"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(XEN_CADR(lst)), XEN_CADR(lst), XEN_ARG_2, S_mus_header_raw_defaults, "an integer = chans"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(XEN_CADDR(lst)), XEN_CADDR(lst), XEN_ARG_3, S_mus_header_raw_defaults, "an integer = data-format"); - mus_header_set_raw_defaults(XEN_TO_C_INT(XEN_CAR(lst)), - XEN_TO_C_INT(XEN_CADR(lst)), - XEN_TO_C_INT(XEN_CADDR(lst))); - return(lst); + #define H_mus_header_raw_defaults "(" S_mus_header_raw_defaults "): returns list '(srate chans sample-type) of current raw sound default attributes" + int srate, chans; + mus_sample_t sample_type; + mus_header_raw_defaults(&srate, &chans, &sample_type); + return(Xen_list_3(C_int_to_Xen_integer(srate), + C_int_to_Xen_integer(chans), + C_int_to_Xen_integer((int)sample_type))); } -static XEN g_mus_header_type_name(XEN type) +static Xen g_mus_header_set_raw_defaults(Xen lst) { - #define H_mus_header_type_name "(" S_mus_header_type_name " type): header type (e.g. " S_mus_aiff ") as a string" - XEN_ASSERT_TYPE(XEN_INTEGER_P(type), type, XEN_ONLY_ARG, S_mus_header_type_name, "an integer (header-type id)"); - return(C_TO_XEN_STRING(mus_header_type_name(XEN_TO_C_INT(type)))); + Xen_check_type((Xen_is_list(lst)) && (Xen_list_length(lst) == 3), lst, 1, S_mus_header_raw_defaults, "a list: '(srate chans sample-type)"); + Xen_check_type(Xen_is_integer(Xen_car(lst)), Xen_car(lst), 1, S_mus_header_raw_defaults, "an integer = srate"); + Xen_check_type(Xen_is_integer(Xen_cadr(lst)), Xen_cadr(lst), 2, S_mus_header_raw_defaults, "an integer = chans"); + Xen_check_type(Xen_is_integer(Xen_caddr(lst)), Xen_caddr(lst), 3, S_mus_header_raw_defaults, "an integer = sample-type"); + mus_header_set_raw_defaults(Xen_integer_to_C_int(Xen_car(lst)), + Xen_integer_to_C_int(Xen_cadr(lst)), + (mus_sample_t)Xen_integer_to_C_int(Xen_caddr(lst))); + return(lst); } -static XEN g_mus_header_type_to_string(XEN type) +static Xen g_mus_header_type_name(Xen type) { - #define H_mus_header_type_to_string "(" S_mus_header_type_to_string " type): header type (e.g. " S_mus_aiff ") as a string" - XEN_ASSERT_TYPE(XEN_INTEGER_P(type), type, XEN_ONLY_ARG, S_mus_header_type_to_string, "an integer (header-type id)"); - return(C_TO_XEN_STRING(mus_header_type_to_string(XEN_TO_C_INT(type)))); + #define H_mus_header_type_name "(" S_mus_header_type_name " type): header type (e.g. " S_mus_aiff ") as a string" + Xen_check_type(Xen_is_integer(type), type, 1, S_mus_header_type_name, "an integer (header-type id)"); + return(C_string_to_Xen_string(mus_header_type_name((mus_header_t)Xen_integer_to_C_int(type)))); } -static XEN g_mus_data_format_name(XEN format) +static Xen g_mus_header_type_to_string(Xen type) { - #define H_mus_data_format_name "(" S_mus_data_format_name " format): data format (e.g. " S_mus_bshort ") as a string" - XEN_ASSERT_TYPE(XEN_INTEGER_P(format), format, XEN_ONLY_ARG, S_mus_data_format_name, "an integer (data-format id)"); - return(C_TO_XEN_STRING(mus_data_format_name(XEN_TO_C_INT(format)))); + #define H_mus_header_type_to_string "(" S_mus_header_type_to_string " type): header type (e.g. " S_mus_aiff ") as a string" + Xen_check_type(Xen_is_integer(type), type, 1, S_mus_header_type_to_string, "an integer (header-type id)"); + return(C_string_to_Xen_string(mus_header_type_to_string((mus_header_t)Xen_integer_to_C_int(type)))); } -static XEN g_mus_data_format_to_string(XEN format) +static Xen g_mus_sample_type_name(Xen samp_type) { - #define H_mus_data_format_to_string "(" S_mus_data_format_to_string " format): data format (e.g. " S_mus_bshort ") as a string" - XEN_ASSERT_TYPE(XEN_INTEGER_P(format), format, XEN_ONLY_ARG, S_mus_data_format_to_string, "an integer (data-format id)"); - return(C_TO_XEN_STRING(mus_data_format_to_string(XEN_TO_C_INT(format)))); + #define H_mus_sample_type_name "(" S_mus_sample_type_name " samp_type): sample type (e.g. " S_mus_bshort ") as a string" + Xen_check_type(Xen_is_integer(samp_type), samp_type, 1, S_mus_sample_type_name, "an integer (sample-type id)"); + return(C_string_to_Xen_string(mus_sample_type_name((mus_sample_t)Xen_integer_to_C_int(samp_type)))); } -static XEN g_mus_bytes_per_sample(XEN format) +static Xen g_mus_sample_type_to_string(Xen samp_type) { - #define H_mus_bytes_per_sample "(" S_mus_bytes_per_sample " format): number of bytes per sample in \ -format (e.g. " S_mus_bshort " = 2)" - XEN_ASSERT_TYPE(XEN_INTEGER_P(format), format, XEN_ONLY_ARG, S_mus_bytes_per_sample, "an integer (data-format id)"); - return(C_TO_XEN_INT(mus_bytes_per_sample(XEN_TO_C_INT(format)))); + #define H_mus_sample_type_to_string "(" S_mus_sample_type_to_string " samp_type): sample type (e.g. " S_mus_bshort ") as a string" + Xen_check_type(Xen_is_integer(samp_type), samp_type, 1, S_mus_sample_type_to_string, "an integer (sample-type id)"); + return(C_string_to_Xen_string(mus_sample_type_to_string((mus_sample_t)Xen_integer_to_C_int(samp_type)))); } -static XEN g_mus_audio_describe(void) +static Xen g_mus_bytes_per_sample(Xen samp_type) { - #define H_mus_audio_describe "(" S_mus_audio_describe "): returns a string describing the current audio hardware setup" - return(C_TO_XEN_STRING(mus_audio_describe())); + #define H_mus_bytes_per_sample "(" S_mus_bytes_per_sample " sample-type): number of bytes per sample in \ +sample-type (e.g. " S_mus_bshort " = 2)" + Xen_check_type(Xen_is_integer(samp_type), samp_type, 1, S_mus_bytes_per_sample, "an integer (sample-type id)"); + return(C_int_to_Xen_integer(mus_bytes_per_sample((mus_sample_t)Xen_integer_to_C_int(samp_type)))); } -static XEN g_mus_sound_duration(XEN gfilename) +static Xen g_mus_sound_duration(Xen gfilename) { #define H_mus_sound_duration "(" S_mus_sound_duration " filename): duration (in seconds) of sound file" float res; char *str = NULL; - XEN_ASSERT_TYPE(XEN_STRING_P(gfilename), gfilename, XEN_ONLY_ARG, S_mus_sound_duration, "a string"); - res = mus_sound_duration(str = mus_expand_filename(XEN_TO_C_STRING(gfilename))); + Xen_check_type(Xen_is_string(gfilename), gfilename, 1, S_mus_sound_duration, "a string"); + res = mus_sound_duration(str = mus_expand_filename(Xen_string_to_C_string(gfilename))); if (str) free(str); - return(C_TO_XEN_DOUBLE(res)); + return(C_double_to_Xen_real(res)); } -static XEN g_mus_oss_set_buffers(XEN num, XEN size) +static Xen g_mus_oss_set_buffers(Xen num, Xen size) { #define H_mus_oss_set_buffers "(" S_mus_oss_set_buffers " num size): set Linux OSS 'fragment' number and size. \ If Snd's controls seem sluggish, try (" S_mus_oss_set_buffers " 4 12) or even (" S_mus_oss_set_buffers " 2 12). \ This reduces the on-card buffering, but may introduce clicks." #if (HAVE_OSS || HAVE_ALSA) - XEN_ASSERT_TYPE(XEN_INTEGER_P(num), num, XEN_ARG_1, S_mus_oss_set_buffers, "an integer"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(size), size, XEN_ARG_2, S_mus_oss_set_buffers, "an integer"); - mus_oss_set_buffers(XEN_TO_C_INT(num), - XEN_TO_C_INT(size)); + Xen_check_type(Xen_is_integer(num), num, 1, S_mus_oss_set_buffers, "an integer"); + Xen_check_type(Xen_is_integer(size), size, 2, S_mus_oss_set_buffers, "an integer"); + mus_oss_set_buffers(Xen_integer_to_C_int(num), + Xen_integer_to_C_int(size)); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_buffers(void) +static Xen g_mus_alsa_buffers(void) { #define H_mus_alsa_buffers "(" S_mus_alsa_buffers "): current number of ALSA periods." #if HAVE_ALSA - return(C_TO_XEN_INT(mus_alsa_buffers())); + return(C_int_to_Xen_integer(mus_alsa_buffers())); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_set_buffers(XEN val) +static Xen g_mus_alsa_set_buffers(Xen val) { - XEN_ASSERT_TYPE(XEN_INTEGER_P(val), val, XEN_ONLY_ARG, S_setB S_mus_alsa_buffers, "an integer"); + Xen_check_type(Xen_is_integer(val), val, 1, S_set S_mus_alsa_buffers, "an integer"); #if HAVE_ALSA - return(C_TO_XEN_INT(mus_alsa_set_buffers(XEN_TO_C_INT(val)))); + return(C_int_to_Xen_integer(mus_alsa_set_buffers(Xen_integer_to_C_int(val)))); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_buffer_size(void) +static Xen g_mus_alsa_buffer_size(void) { #define H_mus_alsa_buffer_size "(" S_mus_alsa_buffer_size "): current size of ALSA buffers." #if HAVE_ALSA - return(C_TO_XEN_INT(mus_alsa_buffer_size())); + return(C_int_to_Xen_integer(mus_alsa_buffer_size())); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_set_buffer_size(XEN val) +static Xen g_mus_alsa_set_buffer_size(Xen val) { - XEN_ASSERT_TYPE(XEN_INTEGER_P(val), val, XEN_ONLY_ARG, S_setB S_mus_alsa_buffer_size, "an integer"); + Xen_check_type(Xen_is_integer(val), val, 1, S_set S_mus_alsa_buffer_size, "an integer"); #if HAVE_ALSA - return(C_TO_XEN_INT(mus_alsa_set_buffer_size(XEN_TO_C_INT(val)))); + return(C_int_to_Xen_integer(mus_alsa_set_buffer_size(Xen_integer_to_C_int(val)))); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_device(void) +static Xen g_mus_alsa_device(void) { #define H_mus_alsa_device "(" S_mus_alsa_device "): current ALSA device." #if HAVE_ALSA - return(C_TO_XEN_STRING(mus_alsa_device())); + return(C_string_to_Xen_string(mus_alsa_device())); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_set_device(XEN val) +static Xen g_mus_alsa_set_device(Xen val) { - XEN_ASSERT_TYPE(XEN_STRING_P(val), val, XEN_ONLY_ARG, S_setB S_mus_alsa_device, "a string (ALSA device name)"); + Xen_check_type(Xen_is_string(val), val, 1, S_set S_mus_alsa_device, "a string (ALSA device name)"); #if HAVE_ALSA - return(C_TO_XEN_STRING(mus_alsa_set_device(XEN_TO_C_STRING(val)))); + return(C_string_to_Xen_string(mus_alsa_set_device(Xen_string_to_C_string(val)))); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_playback_device(void) +static Xen g_mus_alsa_playback_device(void) { #define H_mus_alsa_playback_device "(" S_mus_alsa_playback_device "): current ALSA playback device." #if HAVE_ALSA - return(C_TO_XEN_STRING(mus_alsa_playback_device())); + return(C_string_to_Xen_string(mus_alsa_playback_device())); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_set_playback_device(XEN val) +static Xen g_mus_alsa_set_playback_device(Xen val) { - XEN_ASSERT_TYPE(XEN_STRING_P(val), val, XEN_ONLY_ARG, S_setB S_mus_alsa_playback_device, "a string (ALSA device name)"); + Xen_check_type(Xen_is_string(val), val, 1, S_set S_mus_alsa_playback_device, "a string (ALSA device name)"); #if HAVE_ALSA - return(C_TO_XEN_STRING(mus_alsa_set_playback_device(XEN_TO_C_STRING(val)))); + return(C_string_to_Xen_string(mus_alsa_set_playback_device(Xen_string_to_C_string(val)))); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_capture_device(void) +static Xen g_mus_alsa_capture_device(void) { #define H_mus_alsa_capture_device "(" S_mus_alsa_capture_device "): current ALSA capture device." #if HAVE_ALSA - return(C_TO_XEN_STRING(mus_alsa_capture_device())); + return(C_string_to_Xen_string(mus_alsa_capture_device())); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_set_capture_device(XEN val) +static Xen g_mus_alsa_set_capture_device(Xen val) { - XEN_ASSERT_TYPE(XEN_STRING_P(val), val, XEN_ONLY_ARG, S_setB S_mus_alsa_capture_device, "a string (ALSA device name)"); + Xen_check_type(Xen_is_string(val), val, 1, S_set S_mus_alsa_capture_device, "a string (ALSA device name)"); #if HAVE_ALSA - return(C_TO_XEN_STRING(mus_alsa_set_capture_device(XEN_TO_C_STRING(val)))); + return(C_string_to_Xen_string(mus_alsa_set_capture_device(Xen_string_to_C_string(val)))); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_squelch_warning(void) +static Xen g_mus_alsa_squelch_warning(void) { #define H_mus_alsa_squelch_warning "(" S_mus_alsa_squelch_warning "): whether to squelch ALSA srate mismatch warnings." #if HAVE_ALSA - return(C_TO_XEN_BOOLEAN(mus_alsa_squelch_warning())); + return(C_bool_to_Xen_boolean(mus_alsa_squelch_warning())); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_alsa_set_squelch_warning(XEN val) +static Xen g_mus_alsa_set_squelch_warning(Xen val) { - XEN_ASSERT_TYPE(XEN_BOOLEAN_P(val), val, XEN_ONLY_ARG, S_setB S_mus_alsa_squelch_warning, "a boolean"); + Xen_check_type(Xen_is_boolean(val), val, 1, S_set S_mus_alsa_squelch_warning, "a boolean"); #if HAVE_ALSA - return(C_TO_XEN_BOOLEAN(mus_alsa_set_squelch_warning(XEN_TO_C_BOOLEAN(val)))); + return(C_bool_to_Xen_boolean(mus_alsa_set_squelch_warning(Xen_boolean_to_C_bool(val)))); #endif - return(XEN_FALSE); + return(Xen_false); } -static XEN g_mus_sound_maxamp_exists(XEN file) +static Xen g_mus_sound_maxamp_exists(Xen file) { #define H_mus_sound_maxamp_exists "(" S_mus_sound_maxamp_exists " filename): " PROC_TRUE " if sound's maxamp data is available \ in the sound cache; if it isn't, a call on " S_mus_sound_maxamp " has to open and read the data to get the maxamp." bool val; char *str = NULL; - XEN_ASSERT_TYPE(XEN_STRING_P(file), file, XEN_ONLY_ARG, S_mus_sound_maxamp_exists, "a string"); - val = mus_sound_maxamp_exists(str = mus_expand_filename(XEN_TO_C_STRING(file))); + Xen_check_type(Xen_is_string(file), file, 1, S_mus_sound_maxamp_exists, "a string"); + val = mus_sound_maxamp_exists(str = mus_expand_filename(Xen_string_to_C_string(file))); if (str) free(str); - return(C_TO_XEN_BOOLEAN(val)); + return(C_bool_to_Xen_boolean(val)); } -XEN g_mus_sound_maxamp(XEN file) +Xen g_mus_sound_maxamp(Xen file) { #define H_mus_sound_maxamp "(" S_mus_sound_maxamp " filename): maxamps in sound (a list of paired amps (floats) and locations (samples))" int chans; char *filename; - XEN res = XEN_EMPTY_LIST; + Xen res = Xen_empty_list; - XEN_ASSERT_TYPE(XEN_STRING_P(file), file, XEN_ONLY_ARG, S_mus_sound_maxamp, "a string"); + Xen_check_type(Xen_is_string(file), file, 1, S_mus_sound_maxamp, "a string"); - filename = mus_expand_filename(XEN_TO_C_STRING(file)); + filename = mus_expand_filename(Xen_string_to_C_string(file)); chans = mus_sound_chans(filename); if (chans > 0) { mus_long_t rtn; - int i; - mus_sample_t *vals; + mus_float_t *vals; mus_long_t *times; - vals = (mus_sample_t *)calloc(chans, sizeof(mus_sample_t)); + vals = (mus_float_t *)calloc(chans, sizeof(mus_float_t)); times = (mus_long_t *)calloc(chans, sizeof(mus_long_t)); rtn = mus_sound_maxamps(filename, chans, vals, times); if (rtn != MUS_ERROR) - for (i = chans - 1; i >= 0; i--) - res = XEN_CONS(C_TO_XEN_INT64_T(times[i]), - XEN_CONS(C_TO_XEN_DOUBLE(MUS_SAMPLE_TO_FLOAT(vals[i])), res)); + { + int i; + for (i = chans - 1; i >= 0; i--) + res = Xen_cons(C_llong_to_Xen_llong(times[i]), Xen_cons(C_double_to_Xen_real(vals[i]), res)); + } free(vals); free(times); if (filename) free(filename); @@ -578,22 +619,22 @@ XEN g_mus_sound_maxamp(XEN file) else { if (filename) free(filename); - XEN_ERROR(BAD_HEADER, - XEN_LIST_1(C_TO_XEN_STRING(S_mus_sound_maxamp ": chans <= 0"))); + Xen_error(BAD_HEADER, + Xen_list_1(C_string_to_Xen_string(S_mus_sound_maxamp ": chans <= 0"))); } return(res); } -static XEN g_mus_sound_set_maxamp(XEN file, XEN vals) +static Xen g_mus_sound_set_maxamp(Xen file, Xen vals) { int chans; char *filename; - XEN_ASSERT_TYPE(XEN_STRING_P(file), file, XEN_ARG_1, S_setB S_mus_sound_maxamp, "a string"); - XEN_ASSERT_TYPE(XEN_LIST_P(vals), vals, XEN_ARG_2, S_setB S_mus_sound_maxamp, "a list"); + Xen_check_type(Xen_is_string(file), file, 1, S_set S_mus_sound_maxamp, "a string"); + Xen_check_type(Xen_is_list(vals), vals, 2, S_set S_mus_sound_maxamp, "a list"); - filename = mus_expand_filename(XEN_TO_C_STRING(file)); + filename = mus_expand_filename(Xen_string_to_C_string(file)); chans = mus_sound_chans(filename); /* presumably any actual error here will be trapped via mus-error (raised in mus_header_read via read_sound_file_header), @@ -601,25 +642,26 @@ static XEN g_mus_sound_set_maxamp(XEN file, XEN vals) */ if (chans > 0) { - XEN lst; + Xen lst; int i, j, len; - mus_sample_t *mvals; + mus_float_t *mvals; mus_long_t *times; - len = XEN_LIST_LENGTH(vals); + len = Xen_list_length(vals); if (len < (chans * 2)) - XEN_WRONG_TYPE_ARG_ERROR(S_setB S_mus_sound_maxamp, 2, vals, "max amp list length must = 2 * chans"); + Xen_wrong_type_arg_error(S_set S_mus_sound_maxamp, 2, vals, "max amp list length must = 2 * chans"); if (len > chans * 2) len = chans * 2; - mvals = (mus_sample_t *)calloc(chans, sizeof(mus_sample_t)); + mvals = (mus_float_t *)calloc(chans, sizeof(mus_float_t)); times = (mus_long_t *)calloc(chans, sizeof(mus_long_t)); - for (i = 0, j = 0, lst = XEN_COPY_ARG(vals); i < len; i += 2, j++, lst = XEN_CDDR(lst)) + for (i = 0, j = 0, lst = Xen_copy_arg(vals); i < len; i += 2, j++, lst = Xen_cddr(lst)) { - times[j] = XEN_TO_C_INT64_T_OR_ELSE(XEN_CAR(lst), 0); - mvals[j] = MUS_DOUBLE_TO_SAMPLE(XEN_TO_C_DOUBLE(XEN_CADR(lst))); + times[j] = Xen_llong_to_C_llong(Xen_car(lst)); + mvals[j] = Xen_real_to_C_double(Xen_cadr(lst)); } + fprintf(stderr, "set in g_mus_sound_set_maxamp\n"); mus_sound_set_maxamps(filename, chans, mvals, times); free(mvals); free(times); @@ -628,719 +670,151 @@ static XEN g_mus_sound_set_maxamp(XEN file, XEN vals) else { if (filename) free(filename); - XEN_ERROR(BAD_HEADER, - XEN_LIST_1(C_TO_XEN_STRING(S_setB S_mus_sound_maxamp ": chans <= 0"))); + Xen_error(BAD_HEADER, + Xen_list_1(C_string_to_Xen_string(S_set S_mus_sound_maxamp ": chans <= 0"))); } return(vals); } -static XEN g_mus_sound_open_input(XEN file) -{ - #define H_mus_sound_open_input "(" S_mus_sound_open_input " filename): open filename for (low-level) sound input, \ -return file descriptor (an integer)" - int fd; - char *str = NULL; - XEN_ASSERT_TYPE(XEN_STRING_P(file), file, XEN_ONLY_ARG, S_mus_sound_open_input, "a string"); - fd = mus_sound_open_input(str = mus_expand_filename(XEN_TO_C_STRING(file))); - if (str) free(str); - return(C_TO_XEN_INT(fd)); -} - - -static XEN g_mus_sound_open_output(XEN file, XEN srate, XEN chans, XEN data_format, XEN header_type, XEN comment) +#define S_mus_sound_preload "mus-sound-preload" +static Xen g_mus_sound_preload(Xen file) { + #define H_mus_sound_preload "(" S_mus_sound_preload " filename): save filename's data in memory (faster opens and so on)." + char *str; - #define H_mus_sound_open_output "(" S_mus_sound_open_output " filename :optional (srate 44100) (chans 1) data-format header-type (comment \"\")): \ -open filename for (low-level) sound output with the given srate and so on; return the file descriptor (an integer). \ -The file size is normally set later via " S_mus_sound_close_output ". srate is an integer, comment is a string, \ -data-format is a sndlib format indicator such as " S_mus_bshort ", if " PROC_FALSE " if defaults to a format compatible with sndlib, \ -header-type is a sndlib type indicator such as " S_mus_aiff "; sndlib currently only writes 5 or so header types." - - int fd = -1, df; - XEN_ASSERT_TYPE(XEN_STRING_P(file), file, XEN_ARG_1, S_mus_sound_open_output, "a string"); - XEN_ASSERT_TYPE(XEN_INTEGER_OR_BOOLEAN_IF_BOUND_P(srate), srate, XEN_ARG_2, S_mus_sound_open_output, "an integer or " PROC_FALSE); - XEN_ASSERT_TYPE(XEN_INTEGER_OR_BOOLEAN_IF_BOUND_P(chans), chans, XEN_ARG_3, S_mus_sound_open_output, "an integer or " PROC_FALSE); - XEN_ASSERT_TYPE(XEN_INTEGER_OR_BOOLEAN_IF_BOUND_P(data_format), data_format, XEN_ARG_4, S_mus_sound_open_output, "a data-format or " PROC_FALSE); - XEN_ASSERT_TYPE(XEN_INTEGER_OR_BOOLEAN_IF_BOUND_P(header_type), header_type, XEN_ARG_5, S_mus_sound_open_output, "a header-type or " PROC_FALSE); - XEN_ASSERT_TYPE((XEN_STRING_P(comment) || (XEN_NOT_BOUND_P(comment))), comment, XEN_ARG_6, S_mus_sound_open_output, "a string"); + Xen_check_type(Xen_is_string(file), file, 1, S_mus_sound_preload, "a string"); + str = mus_expand_filename(Xen_string_to_C_string(file)); - df = XEN_TO_C_INT_OR_ELSE(data_format, (int)MUS_OUT_FORMAT); - if (mus_data_format_p(df)) + if (str) { - int ht; -#if MUS_LITTLE_ENDIAN - ht = XEN_TO_C_INT_OR_ELSE(header_type, (int)MUS_RIFF); -#else - ht = XEN_TO_C_INT_OR_ELSE(header_type, (int)MUS_NEXT); -#endif - /* now check that data format and header type are ok together */ - if (mus_header_type_p(ht)) + int ifd; + ifd = mus_sound_open_input(str); + if (ifd != MUS_ERROR) { - int chns; - - if (!mus_header_writable(ht, df)) - { - if ((XEN_INTEGER_P(data_format)) && - (XEN_INTEGER_P(header_type))) - XEN_ERROR(XEN_ERROR_TYPE("bad-data"), - XEN_LIST_3(C_TO_XEN_STRING(S_mus_sound_open_output ": ~A header can't handle ~A data"), - C_TO_XEN_STRING(mus_header_type_name(ht)), - C_TO_XEN_STRING(mus_data_format_name(df)))); - - if (!(XEN_INTEGER_P(data_format))) - { - switch (df) - { - case MUS_BFLOAT: df = MUS_LFLOAT; break; - case MUS_BDOUBLE: df = MUS_LDOUBLE; break; - case MUS_BINT: df = MUS_LINT; break; - case MUS_LFLOAT: df = MUS_BFLOAT; break; - case MUS_LDOUBLE: df = MUS_BDOUBLE; break; - case MUS_LINT: df = MUS_BINT; break; - } - if (!mus_header_writable(ht, df)) - { - int i; - for (i = 1; i < MUS_NUM_DATA_FORMATS; i++) /* MUS_UNSUPPORTED is 0 */ - { - df = i; - if (mus_header_writable(ht, df)) - break; - } - } - } - else - { - ht = MUS_NEXT; - } - - if (!mus_header_writable(ht, df)) - XEN_ERROR(XEN_ERROR_TYPE("bad-data"), - XEN_LIST_3(C_TO_XEN_STRING(S_mus_sound_open_output ": ~A header can't handle ~A data"), - C_TO_XEN_STRING(mus_header_type_name(ht)), - C_TO_XEN_STRING(mus_data_format_name(df)))); - } - - chns = XEN_TO_C_INT_OR_ELSE(chans, 1); - if (chns > 0) - { - const char *com = NULL; - char *str = NULL; - if (XEN_STRING_P(comment)) com = XEN_TO_C_STRING(comment); - fd = mus_sound_open_output(str = mus_expand_filename(XEN_TO_C_STRING(file)), - XEN_TO_C_INT_OR_ELSE(srate, 44100), /* not DEFAULT_OUTPUT_SRATE here because that depends on Snd */ - chns, df, ht, com); - if (str) free(str); - } - else XEN_OUT_OF_RANGE_ERROR(S_mus_sound_open_output, 3, chans, "chans ~A <= 0?"); + int i, chans; + mus_float_t **bufs; + mus_long_t framples; + chans = mus_sound_chans(str); + framples = mus_sound_framples(str) + 8; /* + 8 for readers than wander off the end */ + bufs = (mus_float_t **)malloc(chans * sizeof(mus_float_t *)); + for (i = 0; i < chans; i++) + bufs[i] = (mus_float_t *)malloc(framples * sizeof(mus_float_t)); + + mus_file_seek_frample(ifd, 0); + mus_file_read_file(ifd, 0, chans, framples, bufs); + mus_sound_set_saved_data(str, bufs); + mus_sound_close_input(ifd); } - else XEN_OUT_OF_RANGE_ERROR(S_mus_sound_open_output, 5, header_type, "~A: invalid header type"); - } - else XEN_OUT_OF_RANGE_ERROR(S_mus_sound_open_output, 4, data_format, "~A: invalid data format"); - return(C_TO_XEN_INT(fd)); -} - - -static XEN g_mus_sound_reopen_output(XEN file, XEN chans, XEN data_format, XEN header_type, XEN data_loc) -{ - - #define H_mus_sound_reopen_output "(" S_mus_sound_reopen_output " filename :optional (chans 1) data-format header-type data-location): \ -reopen (without alteration) filename for output \ -data-format and header-type are sndlib indicators such as " S_mus_bshort " or " S_mus_aiff ". \ -data-location should be retrieved from a previous call to " S_mus_sound_data_location "." - - int fd = -1, df; - char *filename; - XEN_ASSERT_TYPE(XEN_STRING_P(file), file, XEN_ARG_1, S_mus_sound_reopen_output, "a string"); - XEN_ASSERT_TYPE(XEN_INTEGER_OR_BOOLEAN_IF_BOUND_P(chans), chans, XEN_ARG_2, S_mus_sound_reopen_output, "an integer or " PROC_FALSE); - XEN_ASSERT_TYPE(XEN_INTEGER_OR_BOOLEAN_IF_BOUND_P(data_format), data_format, XEN_ARG_3, S_mus_sound_reopen_output, "a data-format or " PROC_FALSE); - XEN_ASSERT_TYPE(XEN_INTEGER_OR_BOOLEAN_IF_BOUND_P(header_type), header_type, XEN_ARG_4, S_mus_sound_reopen_output, "a header-type or " PROC_FALSE); - XEN_ASSERT_TYPE(XEN_INT64_T_P(data_loc) || XEN_FALSE_P(data_loc) || XEN_NOT_BOUND_P(data_loc), - data_loc, XEN_ARG_5, S_mus_sound_reopen_output, "an integer or " PROC_FALSE); - - filename = mus_expand_filename(XEN_TO_C_STRING(file)); - - /* use existing settings if unbound as args */ - if (XEN_INTEGER_P(data_format)) - df = XEN_TO_C_INT(data_format); - else - { - df = mus_sound_data_format(filename); - if (df == MUS_ERROR) - df = MUS_OUT_FORMAT; - } - if (mus_data_format_p(df)) - { - int ht; - if (XEN_INTEGER_P(header_type)) - ht = XEN_TO_C_INT(header_type); - else - { - ht = mus_sound_header_type(filename); - if (ht == MUS_ERROR) -#if MUS_LITTLE_ENDIAN - ht = MUS_RIFF; -#else - ht = MUS_NEXT; -#endif - } - if (mus_header_type_p(ht)) - { - int chns; - if (XEN_INTEGER_P(chans)) - chns = XEN_TO_C_INT(chans); - else - { - chns = mus_sound_chans(filename); - if (chns == MUS_ERROR) - chns = 1; - } - if (chns > 0) - { - mus_long_t dloc; - if (XEN_INT64_T_P(data_loc)) - dloc = XEN_TO_C_INT64_T(data_loc); - else - { - dloc = mus_sound_data_location(filename); - if (dloc == MUS_ERROR) - dloc = 0; - } - fd = mus_sound_reopen_output(filename, chns, df, ht, dloc); - if (filename) free(filename); - } - else XEN_OUT_OF_RANGE_ERROR(S_mus_sound_reopen_output, 2, chans, "chans <= 0?"); - } - else XEN_OUT_OF_RANGE_ERROR(S_mus_sound_reopen_output, 4, header_type, "~A: invalid header type"); - } - else XEN_OUT_OF_RANGE_ERROR(S_mus_sound_reopen_output, 3, data_format, "~A: invalid data format"); - return(C_TO_XEN_INT(fd)); -} - - -#if (!HAVE_UNISTD_H) || (_MSC_VER) -#ifndef STDIN_FILENO -#define STDIN_FILENO 0 -#endif -#ifndef STDOUT_FILENO -#define STDOUT_FILENO 1 -#endif -#ifndef STDERR_FILENO -#define STDERR_FILENO 2 -#endif -#endif - -static XEN g_mus_sound_close_input(XEN fd) -{ - #define H_mus_sound_close_input "(" S_mus_sound_close_input " fd): close (low-level) file fd that was opened \ -by " S_mus_sound_open_input "." - int nfd; - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ONLY_ARG, S_mus_sound_close_input, "an integer"); - nfd = XEN_TO_C_INT(fd); - if ((nfd < 0) || (nfd == STDIN_FILENO) || (nfd == STDOUT_FILENO) || (nfd == STDERR_FILENO)) - XEN_OUT_OF_RANGE_ERROR(S_mus_sound_close_input, 1, fd, "~A: invalid file number"); - return(C_TO_XEN_INT(mus_sound_close_input(XEN_TO_C_INT(fd)))); -} - - -static XEN g_mus_sound_close_output(XEN fd, XEN bytes) -{ - #define H_mus_sound_close_output "(" S_mus_sound_close_output " fd bytes): close (low-level) file fd \ -that was opened by " S_mus_sound_open_output " after updating its header (if any) to reflect bytes, the new file data size" - - int nfd; - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ARG_1, S_mus_sound_close_output, "an integer"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(bytes), bytes, XEN_ARG_2, S_mus_sound_close_output, "a number"); - nfd = XEN_TO_C_INT(fd); - if ((nfd < 0) || (nfd == STDIN_FILENO) || (nfd == STDOUT_FILENO) || (nfd == STDERR_FILENO)) - XEN_OUT_OF_RANGE_ERROR(S_mus_sound_close_output, 1, fd, "~A: invalid file number"); - return(C_TO_XEN_INT(mus_sound_close_output(XEN_TO_C_INT(fd), - XEN_TO_C_INT64_T_OR_ELSE(bytes, 0)))); -} - - -static XEN g_mus_sound_read(XEN fd, XEN beg, XEN end, XEN chans, XEN sv) -{ - #define H_mus_sound_read "(" S_mus_sound_read " fd beg end chans sdata): read sound data from file fd, \ -filling sound-data sdata's buffers starting at beg (buffer location), going to end" - - sound_data *sd; - mus_long_t bg, nd; - - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ARG_1, S_mus_sound_read, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(beg), beg, XEN_ARG_2, S_mus_sound_read, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(end), end, XEN_ARG_3, S_mus_sound_read, "an integer"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(chans), chans, XEN_ARG_4, S_mus_sound_read, "an integer"); - XEN_ASSERT_TYPE(sound_data_p(sv), sv, XEN_ARG_5, S_mus_sound_read, "a sound-data object"); - - sd = XEN_TO_SOUND_DATA(sv); - bg = XEN_TO_C_INT64_T(beg); - nd = XEN_TO_C_INT64_T(end); - if ((nd - bg) >= sd->length) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_4(C_TO_XEN_STRING(S_mus_sound_read ": end - beg (~A - ~A) >= sound-data array length, ~A"), - end, - beg, - C_TO_XEN_INT64_T(sd->length))); - -#if SNDLIB_USE_FLOATS - return(C_TO_XEN_INT(mus_file_read(XEN_TO_C_INT(fd), bg, nd, XEN_TO_C_INT(chans), sd->data))); -#else - { - mus_sample_t **sdata; - int i; - mus_long_t j, result; - sdata = (mus_sample_t **)calloc(sd->chans, sizeof(mus_sample_t *)); - for (i = 0; i < sd->chans; i++) sdata[i] = (mus_sample_t *)calloc(sd->length, sizeof(mus_sample_t)); - result = mus_file_read(XEN_TO_C_INT(fd), bg, nd, XEN_TO_C_INT(chans), sdata); - for (i = 0; i < sd->chans; i++) - for (j = 0; j < sd->length; j++) - sd->data[i][j] = MUS_SAMPLE_TO_DOUBLE(sdata[i][j]); - for (i = 0; i < sd->chans; i++) - free(sdata[i]); - free(sdata); - return(C_TO_XEN_INT(result)); - } -#endif -} - - -static XEN g_mus_sound_write(XEN fd, XEN beg, XEN end, XEN chans, XEN sv) -{ - #define H_mus_sound_write "(" S_mus_sound_write " fd beg end chans sdata): write sound-data sdata's data to file fd, \ -starting at beg (buffer location), going to end" - - sound_data *sd; - mus_long_t bg, nd; - - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ARG_1, S_mus_sound_write, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(beg), beg, XEN_ARG_2, S_mus_sound_write, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(end), end, XEN_ARG_3, S_mus_sound_write, "an integer"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(chans), chans, XEN_ARG_4, S_mus_sound_write, "an integer"); - XEN_ASSERT_TYPE(sound_data_p(sv), sv, XEN_ARG_5, S_mus_sound_write, "a sound-data object"); - - /* even here we can write memory that doesn't belong to us if clipping */ - sd = XEN_TO_SOUND_DATA(sv); - bg = XEN_TO_C_INT64_T(beg); - nd = XEN_TO_C_INT64_T(end); - if ((nd - bg) >= sd->length) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_4(C_TO_XEN_STRING(S_mus_sound_write ": end - beg (~A - ~A) >= sound-data array length, ~A"), - end, - beg, - C_TO_XEN_INT64_T(sd->length))); - -#if SNDLIB_USE_FLOATS - return(C_TO_XEN_INT(mus_file_write(XEN_TO_C_INT(fd), bg, nd, XEN_TO_C_INT(chans), sd->data))); -#else - { - mus_sample_t **sdata; - int i; - mus_long_t j, result; - sdata = (mus_sample_t **)calloc(sd->chans, sizeof(mus_sample_t *)); - for (i = 0; i < sd->chans; i++) - sdata[i] = (mus_sample_t *)calloc(sd->length, sizeof(mus_sample_t)); - for (i = 0; i < sd->chans; i++) - for (j = 0; j < sd->length; j++) - sdata[i][j] = MUS_DOUBLE_TO_SAMPLE(sd->data[i][j]); - result = mus_file_write(XEN_TO_C_INT(fd), bg, nd, XEN_TO_C_INT(chans), sdata); - for (i = 0; i < sd->chans; i++) - free(sdata[i]); - free(sdata); - return(C_TO_XEN_INT(result)); - } -#endif -} - - -static XEN g_mus_sound_seek_frame(XEN fd, XEN offset) -{ - #define H_mus_sound_seek_frame "(" S_mus_sound_seek_frame " fd frame): move the current read/write location in file fd \ -to the frame offset" - - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ARG_1, S_mus_sound_seek_frame, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(offset), offset, XEN_ARG_2, S_mus_sound_seek_frame, "an integer"); - return(C_TO_XEN_INT64_T(mus_file_seek_frame(XEN_TO_C_INT(fd), - XEN_TO_C_INT64_T(offset)))); -} - - -/* since mus-audio-read|write assume sound-data vectors communicating with Scheme, - * we can't assume that the user has had a chance to deal with type problems. - * So, we keep track of each audio line's current read|write format and - * translate in mus_audio_read|write if necessary - */ - -static int audio_io_size = 0; -static int *audio_io_lines = NULL; -static int *audio_io_formats = NULL; - -int mus_audio_io_format(int line); -int mus_audio_io_format(int line) -{ - int i; - for (i = 0; i < audio_io_size; i++) - if (audio_io_lines[i] == line) - return(audio_io_formats[i]); - return(MUS_UNKNOWN); -} - - -#define audio_io_read_format(Line) (mus_audio_io_format(Line) & 0xffff) -#define audio_io_write_format(Line) (mus_audio_io_format(Line) >> 16) - -static void audio_io_set_format(int line, int format) -{ - int i, old_size; - - for (i = 0; i < audio_io_size; i++) - if (audio_io_lines[i] == line) - { - audio_io_formats[i] = format; - return; - } - - /* we get here if the table is not big enough */ - old_size = audio_io_size; - audio_io_size += 8; - if (old_size == 0) - { - audio_io_lines = (int *)malloc(audio_io_size * sizeof(int)); - audio_io_formats = (int *)malloc(audio_io_size * sizeof(int)); + free(str); } - else - { - audio_io_lines = (int *)realloc(audio_io_lines, audio_io_size * sizeof(int)); - audio_io_formats = (int *)realloc(audio_io_formats, audio_io_size * sizeof(int)); - } - for (i = old_size + 1; i < audio_io_size; i++) - { - audio_io_lines[i] = -1; - audio_io_formats[i] = MUS_UNKNOWN; - } - audio_io_lines[old_size] = line; - audio_io_formats[old_size] = format; -} - - -#define audio_io_set_read_format(Line, Format) audio_io_set_format(Line, ((mus_audio_io_format(Line) & 0xffff0000) | Format)) -#define audio_io_set_write_format(Line, Format) audio_io_set_format(Line, ((mus_audio_io_format(Line) & 0xffff) | (Format << 16))) - - -static XEN g_mus_audio_open_output(XEN dev, XEN srate, XEN chans, XEN format, XEN size) -{ - #if HAVE_SCHEME - #define audio_open_example "(" S_mus_audio_open_output " " S_mus_audio_default " 22050 1 " S_mus_lshort " 256)" - #endif - #if HAVE_RUBY - #define audio_open_example "mus_audio_open_output(Mus_audio_default, 22050, 1, Mus_lshort, 256)" - #endif - #if HAVE_FORTH - #define audio_open_example "mus-audio-default 22050 1 mus-lshort 256 mus-audio-open-output" - #endif - - #define H_mus_audio_open_output "(" S_mus_audio_open_output " device srate chans format bytes): \ -open the audio device ready for output at the given srate and so on; \ -return the audio line number:\n " audio_open_example - - int line, idev, ifmt, isize, israte, ichans; - - XEN_ASSERT_TYPE(XEN_INTEGER_P(dev), dev, XEN_ARG_1, S_mus_audio_open_output, "an integer"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(srate), srate, XEN_ARG_2, S_mus_audio_open_output, "a number"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(chans), chans, XEN_ARG_3, S_mus_audio_open_output, "an integer"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(format), format, XEN_ARG_4, S_mus_audio_open_output, "an integer"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(size), size, XEN_ARG_5, S_mus_audio_open_output, "a number"); - - idev = XEN_TO_C_INT(dev); - israte = XEN_TO_C_INT_OR_ELSE(srate, 0); - ichans = XEN_TO_C_INT(chans); - ifmt = XEN_TO_C_INT(format); - isize = XEN_TO_C_INT_OR_ELSE(size, 0); - - if (!(mus_data_format_p(ifmt))) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_output, 4, format, "~A: invalid data format"); - if (isize < 0) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_output, 5, size, "size ~A < 0?"); - if (israte <= 0) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_output, 2, srate, "srate ~A <= 0?"); - if ((ichans <= 0) || (ichans > 256)) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_output, 3, chans, "chans ~A <= 0 or > 256?"); - - line = mus_audio_open_output(idev, israte, ichans, ifmt, isize); - audio_io_set_write_format(line, ifmt); - return(C_TO_XEN_INT(line)); -} - - -static XEN g_mus_audio_open_input(XEN dev, XEN srate, XEN chans, XEN format, XEN size) -{ - #define H_mus_audio_open_input "(" S_mus_audio_open_input " (device srate chans format bufsize): \ -open the audio device ready for input with the indicated attributes; return the audio line number" - - int line, idev, ifmt, isize, israte, ichans; - - XEN_ASSERT_TYPE(XEN_INTEGER_P(dev), dev, XEN_ARG_1, S_mus_audio_open_input, "an integer"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(srate), srate, XEN_ARG_2, S_mus_audio_open_input, "a number"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(chans), chans, XEN_ARG_3, S_mus_audio_open_input, "an integer"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(format), format, XEN_ARG_4, S_mus_audio_open_input, "an integer"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(size), size, XEN_ARG_5, S_mus_audio_open_input, "a number"); - - idev = XEN_TO_C_INT(dev); - israte = XEN_TO_C_INT_OR_ELSE(srate, 0); - ichans = XEN_TO_C_INT(chans); - ifmt = XEN_TO_C_INT(format); - isize = XEN_TO_C_INT_OR_ELSE(size, 0); - - if (!(mus_data_format_p(ifmt))) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_input, 4, format, "~A: invalid data format"); - if (isize < 0) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_input, 5, size, "size ~A < 0?"); - if (israte <= 0) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_input, 2, srate, "srate ~A <= 0?"); - if (ichans <= 0) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_open_input, 3, chans, "chans ~A <= 0?"); - - line = mus_audio_open_input(idev, israte, ichans, ifmt, isize); - audio_io_set_read_format(line, ifmt); - return(C_TO_XEN_INT(line)); + return(file); } -static XEN g_mus_audio_close(XEN line) -{ - int res; - #define H_mus_audio_close "(" S_mus_audio_close " line): close the audio hardware line" - XEN_ASSERT_TYPE(XEN_INTEGER_P(line), line, XEN_ONLY_ARG, S_mus_audio_close, "an integer"); - res = mus_audio_close(XEN_TO_C_INT(line)); - return(C_TO_XEN_INT(res)); -} - - -/* these take a sndlib buffer (sound_data) and handle the conversion to the interleaved char* internally */ -/* so, they take "frames", not "bytes", and a sound_data object, not char* etc */ - -static XEN g_mus_audio_write(XEN line, XEN sdata, XEN frames, XEN start) -{ - #define H_mus_audio_write "(" S_mus_audio_write " line sdata frames (start 0)): write frames of data (channels * frames = samples) \ -to the audio line from sound-data sdata." - - char *obuf; - sound_data *sd; - int outbytes, val, fmt, fd; - mus_long_t frms, beg = 0; - - XEN_ASSERT_TYPE(XEN_INTEGER_P(line), line, XEN_ARG_1, S_mus_audio_write, "an integer"); - XEN_ASSERT_TYPE(sound_data_p(sdata), sdata, XEN_ARG_2, S_mus_audio_write, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(frames), frames, XEN_ARG_3, S_mus_audio_write, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(start) || XEN_NOT_BOUND_P(start), start, XEN_ARG_4, S_mus_audio_write, "an integer"); - - sd = XEN_TO_SOUND_DATA(sdata); - frms = XEN_TO_C_INT64_T(frames); - if (frms > sd->length) - XEN_OUT_OF_RANGE_ERROR(S_mus_audio_write, 3, frames, "frames ~A > sound-data buffer length"); - if (XEN_BOUND_P(start)) - beg = XEN_TO_C_INT64_T(start); +/* global default clipping values */ - fd = XEN_TO_C_INT(line); - fmt = audio_io_write_format(fd); - outbytes = frms * sd->chans * mus_bytes_per_sample(fmt); - obuf = (char *)calloc(outbytes, sizeof(char)); -#if SNDLIB_USE_FLOATS - mus_file_write_buffer(fmt, beg, beg + frms - 1, sd->chans, sd->data, obuf, true); /* true -> clipped */ -#else - { - mus_sample_t **sdata; - int i; - mus_long_t j; - sdata = (mus_sample_t **)calloc(sd->chans, sizeof(mus_sample_t *)); - for (i = 0; i < sd->chans; i++) - sdata[i] = (mus_sample_t *)calloc(sd->length, sizeof(mus_sample_t)); - for (i = 0; i < sd->chans; i++) - for (j = 0; j < sd->length; j++) - sdata[i][j] = MUS_DOUBLE_TO_SAMPLE(sd->data[i][j]); - mus_file_write_buffer(fmt, 0, frms - 1, sd->chans, sdata, obuf, true); - for (i = 0; i < sd->chans; i++) - free(sdata[i]); - free(sdata); - } -#endif - val = mus_audio_write(fd, obuf, outbytes); - free(obuf); - return(C_TO_XEN_INT(val)); -} - - -static XEN g_mus_audio_read(XEN line, XEN sdata, XEN frames) -{ - #define H_mus_audio_read "(" S_mus_audio_read " line sdata frames): read frames of data (channels * frames = samples) \ -from the audio line into sound-data sdata." - - char *inbuf; - sound_data *sd; - int val, inbytes, fd, fmt; - mus_long_t frms; - - XEN_ASSERT_TYPE(XEN_INTEGER_P(line), line, XEN_ARG_1, S_mus_audio_read, "an integer"); - XEN_ASSERT_TYPE(sound_data_p(sdata), sdata, XEN_ARG_2, S_mus_audio_read, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(frames), frames, XEN_ARG_3, S_mus_audio_read, "an integer"); - - sd = XEN_TO_SOUND_DATA(sdata); - frms = XEN_TO_C_INT64_T(frames); - fd = XEN_TO_C_INT(line); - fmt = audio_io_read_format(fd); - inbytes = frms * sd->chans * mus_bytes_per_sample(fmt); - inbuf = (char *)calloc(inbytes, sizeof(char)); - val = mus_audio_read(fd, inbuf, inbytes); -#if SNDLIB_USE_FLOATS - mus_file_read_buffer(fmt, 0, sd->chans, frms, sd->data, inbuf); /* frms here because this is "nints" not "end"! */ -#else - { - mus_sample_t **sdata; - int i; - mus_long_t j; - sdata = (mus_sample_t **)calloc(sd->chans, sizeof(mus_sample_t *)); - for (i = 0; i < sd->chans; i++) sdata[i] = (mus_sample_t *)calloc(sd->length, sizeof(mus_sample_t)); - mus_file_read_buffer(fmt, 0, sd->chans, frms, sdata, inbuf); - for (i = 0; i < sd->chans; i++) - for (j = 0; j < sd->length; j++) - sd->data[i][j] = MUS_SAMPLE_TO_DOUBLE(sdata[i][j]); - for (i = 0; i < sd->chans; i++) - free(sdata[i]); - free(sdata); - } -#endif - free(inbuf); - return(C_TO_XEN_INT(val)); -} - - -/* global default clipping and prescaler values */ - -static XEN g_mus_clipping(void) +static Xen g_mus_clipping(void) { #define H_mus_clipping "(" S_mus_clipping "): whether sound data written to a file should be clipped" - return(C_TO_XEN_BOOLEAN(mus_clipping())); -} - - -static XEN g_mus_set_clipping(XEN clipped) -{ - XEN_ASSERT_TYPE(XEN_BOOLEAN_P(clipped), clipped, XEN_ONLY_ARG, S_setB S_mus_clipping, "a boolean"); - return(C_TO_XEN_BOOLEAN(mus_set_clipping(XEN_TO_C_BOOLEAN(clipped)))); -} - - -static XEN g_mus_prescaler(void) -{ - #define H_mus_prescaler "(" S_mus_prescaler "): default prescaler (normally 1.0)" - return(C_TO_XEN_DOUBLE(mus_prescaler())); + return(C_bool_to_Xen_boolean(mus_clipping())); } -static XEN g_mus_set_prescaler(XEN val) +static Xen g_mus_set_clipping(Xen clipped) { - XEN_ASSERT_TYPE(XEN_NUMBER_P(val), val, XEN_ARG_1, S_setB S_mus_prescaler, "a number"); - return(C_TO_XEN_DOUBLE(mus_set_prescaler(XEN_TO_C_DOUBLE(val)))); + Xen_check_type(Xen_is_boolean(clipped), clipped, 1, S_set S_mus_clipping, "a boolean"); + return(C_bool_to_Xen_boolean(mus_set_clipping(Xen_boolean_to_C_bool(clipped)))); } -/* file local clipping and prescaler values */ +/* file local clipping values */ -static XEN g_mus_file_clipping(XEN fd) +static Xen g_mus_file_clipping(Xen fd) { #define H_mus_file_clipping "(" S_mus_file_clipping " fd): whether sound data written to file 'fd' should be clipped" - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ONLY_ARG, S_mus_file_clipping, "an integer"); - return(C_TO_XEN_BOOLEAN(mus_file_clipping(XEN_TO_C_INT(fd)))); + Xen_check_type(Xen_is_integer(fd), fd, 1, S_mus_file_clipping, "an integer"); + return(C_bool_to_Xen_boolean(mus_file_clipping(Xen_integer_to_C_int(fd)))); } -static XEN g_mus_file_set_clipping(XEN fd, XEN clipped) +static Xen g_mus_file_set_clipping(Xen fd, Xen clipped) { - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ARG_1, S_setB S_mus_file_clipping, "an integer"); - XEN_ASSERT_TYPE(XEN_BOOLEAN_P(clipped), clipped, XEN_ARG_2, S_setB S_mus_file_clipping, "a boolean"); - return(C_TO_XEN_BOOLEAN(mus_file_set_clipping(XEN_TO_C_INT(fd), XEN_TO_C_BOOLEAN(clipped)))); + Xen_check_type(Xen_is_integer(fd), fd, 1, S_set S_mus_file_clipping, "an integer"); + Xen_check_type(Xen_is_boolean(clipped), clipped, 2, S_set S_mus_file_clipping, "a boolean"); + return(C_bool_to_Xen_boolean(mus_file_set_clipping(Xen_integer_to_C_int(fd), Xen_boolean_to_C_bool(clipped)))); } -static XEN g_mus_file_prescaler(XEN fd) -{ - #define H_mus_file_prescaler "(" S_mus_file_prescaler " fd): prescaler associated with file 'fd'" - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ONLY_ARG, S_mus_file_prescaler, "an integer"); - return(C_TO_XEN_DOUBLE(mus_file_prescaler(XEN_TO_C_INT(fd)))); -} - -static XEN g_mus_file_set_prescaler(XEN fd, XEN val) -{ - XEN_ASSERT_TYPE(XEN_INTEGER_P(fd), fd, XEN_ARG_1, S_setB S_mus_file_prescaler, "an integer"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(val), val, XEN_ARG_1, S_setB S_mus_prescaler, "a number"); - return(C_TO_XEN_DOUBLE(mus_file_set_prescaler(XEN_TO_C_INT(fd), XEN_TO_C_DOUBLE(val)))); -} - - -XEN g_mus_expand_filename(XEN file) +Xen g_mus_expand_filename(Xen file) { #define H_mus_expand_filename "(" S_mus_expand_filename " name): expand 'name' into a canonical or absolute filename, that is, \ one in which all directories in the path are explicit." char *str = NULL; - XEN result; + Xen result; - XEN_ASSERT_TYPE(XEN_STRING_P(file), file, XEN_ONLY_ARG, S_mus_expand_filename, "a string"); - str = mus_expand_filename(XEN_TO_C_STRING(file)); - result = C_TO_XEN_STRING(str); + Xen_check_type(Xen_is_string(file), file, 1, S_mus_expand_filename, "a string"); + str = mus_expand_filename(Xen_string_to_C_string(file)); + result = C_string_to_Xen_string(str); if (str) free(str); return(result); } -static XEN g_mus_sound_report_cache(XEN file) +static Xen g_mus_sound_report_cache(Xen file) { #define H_mus_sound_report_cache "(" S_mus_sound_report_cache " (name)): print the current sound \ cache info to the file given or stdout" + const char *name; - XEN res = XEN_FALSE; - if (XEN_NOT_BOUND_P(file)) - mus_sound_report_cache(stdout); - else + if (!Xen_is_bound(file)) + { + mus_sound_report_cache(stdout); + return(Xen_false); + } + + Xen_check_type(Xen_is_string(file), file, 1, S_mus_sound_report_cache, "a string"); + name = Xen_string_to_C_string(file); + if (name) { - FILE *fd; - const char *name; char *str = NULL; - name = XEN_TO_C_STRING(file); - fd = FOPEN(str = mus_expand_filename(name), "w"); - if (str) free(str); - if (fd) - { - mus_sound_report_cache(fd); - FCLOSE(fd, name); - } - else + str = mus_expand_filename(name); + if (str) { - XEN_ERROR(XEN_ERROR_TYPE("cannot-save"), - XEN_LIST_3(C_TO_XEN_STRING(S_mus_sound_report_cache ": ~S ~A"), - file, - C_TO_XEN_STRING(STRERROR(errno)))); + FILE *fd; + fd = FOPEN(str, "w"); + free(str); + if (fd) + { + mus_sound_report_cache(fd); + FCLOSE(fd, name); + return(file); + } } - return(file); } - return(res); + + Xen_error(Xen_make_error_type("cannot-save"), + Xen_list_3(C_string_to_Xen_string(S_mus_sound_report_cache ": ~S ~A"), + file, + C_string_to_Xen_string(STRERROR(errno)))); + return(Xen_false); } -static XEN g_mus_error_type_to_string(XEN err) +static Xen g_mus_error_type_to_string(Xen err) { #define H_mus_error_type_to_string "(" S_mus_error_type_to_string " err): string description of err (a sndlib error type)" - XEN_ASSERT_TYPE(XEN_INTEGER_P(err), err, XEN_ONLY_ARG, S_mus_error_type_to_string, "an integer"); - return(C_TO_XEN_STRING((char *)mus_error_type_to_string(XEN_TO_C_INT(err)))); + Xen_check_type(Xen_is_integer(err), err, 1, S_mus_error_type_to_string, "an integer"); + return(C_string_to_Xen_string((char *)mus_error_type_to_string(Xen_integer_to_C_int(err)))); } -static XEN g_array_to_file(XEN filename, XEN data, XEN len, XEN srate, XEN channels) +static Xen g_array_to_file(Xen filename, Xen data, Xen len, Xen srate, Xen channels) { #define H_array_to_file "(" S_array_to_file " filename data len srate channels): write 'data', \ -a vct of interleaved samples, to the sound file 'filename' set up to have the given \ +a " S_vct " of interleaved samples, to the sound file 'filename' set up to have the given \ srate and channels. 'len' samples are written." /* this exists for compatibility with the Common Lisp version of CLM. Ideally, we'd get rid @@ -1351,1453 +825,446 @@ srate and channels. 'len' samples are written." mus_long_t olen, samps; vct *v; - XEN_ASSERT_TYPE(XEN_STRING_P(filename), filename, XEN_ARG_1, S_array_to_file, "a string"); - XEN_ASSERT_TYPE(MUS_VCT_P(data), data, XEN_ARG_2, S_array_to_file, "a vct"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(len), len, XEN_ARG_3, S_array_to_file, "an integer"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(srate), srate, XEN_ARG_4, S_array_to_file, "an integer"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(channels), channels, XEN_ARG_5, S_array_to_file, "an integer"); + Xen_check_type(Xen_is_string(filename), filename, 1, S_array_to_file, "a string"); + Xen_check_type(mus_is_vct(data), data, 2, S_array_to_file, "a " S_vct); + Xen_check_type(Xen_is_llong(len), len, 3, S_array_to_file, "an integer"); + Xen_check_type(Xen_is_integer(srate), srate, 4, S_array_to_file, "an integer"); + Xen_check_type(Xen_is_integer(channels), channels, 5, S_array_to_file, "an integer"); - v = XEN_TO_VCT(data); - samps = XEN_TO_C_INT64_T(len); + v = Xen_to_vct(data); + samps = Xen_llong_to_C_llong(len); if (samps <= 0) - XEN_OUT_OF_RANGE_ERROR(S_array_to_file, 3, len, "samples ~A <= 0?"); - if (samps > v->length) - samps = v->length; + Xen_out_of_range_error(S_array_to_file, 3, len, "samples <= 0?"); + if (samps > mus_vct_length(v)) + samps = mus_vct_length(v); - olen = mus_float_array_to_file(XEN_TO_C_STRING(filename), - v->data, + olen = mus_float_array_to_file(Xen_string_to_C_string(filename), + mus_vct_data(v), samps, - XEN_TO_C_INT(srate), - XEN_TO_C_INT(channels)); - return(C_TO_XEN_INT64_T(olen)); + Xen_integer_to_C_int(srate), + Xen_integer_to_C_int(channels)); + return(C_llong_to_Xen_llong(olen)); } -static XEN g_file_to_array(XEN filename, XEN chan, XEN start, XEN samples, XEN data) +static Xen g_file_to_array(Xen filename, Xen chan, Xen start, Xen samples, Xen data) { #define H_file_to_array "(" S_file_to_array " filename chan start samples data): read the sound file \ -'filename' placing samples from channel 'chan' into the vct 'data' starting in the file \ -at frame 'start' and reading 'samples' samples altogether." +'filename' placing samples from channel 'chan' into the " S_vct " 'data' starting in the file \ +at frample 'start' and reading 'samples' samples altogether." - int chn; + int chn, chans; mus_long_t samps; vct *v; const char *name = NULL; - XEN_ASSERT_TYPE(XEN_STRING_P(filename), filename, XEN_ARG_1, S_file_to_array, "a string"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(chan), chan, XEN_ARG_2, S_file_to_array, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(start), start, XEN_ARG_3, S_file_to_array, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(samples), samples, XEN_ARG_4, S_file_to_array, "an integer"); - XEN_ASSERT_TYPE((MUS_VCT_P(data)), data, XEN_ARG_5, S_file_to_array, "a vct"); + Xen_check_type(Xen_is_string(filename), filename, 1, S_file_to_array, "a string"); + Xen_check_type(Xen_is_integer(chan), chan, 2, S_file_to_array, "an integer"); + Xen_check_type(Xen_is_llong(start), start, 3, S_file_to_array, "an integer"); + Xen_check_type(Xen_is_llong(samples), samples, 4, S_file_to_array, "an integer"); + Xen_check_type((mus_is_vct(data)), data, 5, S_file_to_array, "a " S_vct); - name = XEN_TO_C_STRING(filename); + name = Xen_string_to_C_string(filename); if (!(mus_file_probe(name))) - XEN_ERROR(NO_SUCH_FILE, - XEN_LIST_3(C_TO_XEN_STRING(S_file_to_array ": ~S ~A"), + Xen_error(NO_SUCH_FILE, + Xen_list_3(C_string_to_Xen_string(S_file_to_array ": ~S ~A"), filename, - C_TO_XEN_STRING(STRERROR(errno)))); + C_string_to_Xen_string(STRERROR(errno)))); - v = XEN_TO_VCT(data); + v = Xen_to_vct(data); - samps = XEN_TO_C_INT64_T(samples); + samps = Xen_llong_to_C_llong(samples); if (samps <= 0) - XEN_OUT_OF_RANGE_ERROR(S_file_to_array, 4, samples, "samples ~A <= 0?"); - if (samps > v->length) - samps = v->length; - - chn = XEN_TO_C_INT(chan); - if ((chn < 0) || (chn > mus_sound_chans(name))) - XEN_ERROR(NO_SUCH_CHANNEL, - XEN_LIST_4(C_TO_XEN_STRING(S_file_to_array ": invalid chan: ~A, ~S has ~A chans"), + Xen_out_of_range_error(S_file_to_array, 4, samples, "samples <= 0?"); + if (samps > mus_vct_length(v)) + samps = mus_vct_length(v); + + chn = Xen_integer_to_C_int(chan); + chans = mus_sound_chans(name); + if ((chn < 0) || (chn > chans)) + Xen_error(NO_SUCH_CHANNEL, + Xen_list_4(C_string_to_Xen_string(S_file_to_array ": invalid chan: ~A, ~S has ~A chans"), chan, filename, - C_TO_XEN_INT(mus_sound_chans(name)))); + C_int_to_Xen_integer(chans))); - if (mus_sound_chans(name) <= 0) - XEN_ERROR(BAD_HEADER, - XEN_LIST_2(C_TO_XEN_STRING(S_file_to_array ": ~S chans <= 0"), + if (chans <= 0) + Xen_error(BAD_HEADER, + Xen_list_2(C_string_to_Xen_string(S_file_to_array ": ~S chans <= 0"), filename)); - mus_file_to_float_array(name, chn, XEN_TO_C_INT64_T(start), samps, v->data); + mus_file_to_float_array(name, chn, Xen_llong_to_C_llong(start), samps, mus_vct_data(v)); return(data); } -static XEN new_sound_hook; +static Xen new_sound_hook; static void g_new_sound_hook(const char *filename) { - if (XEN_HOOKED(new_sound_hook)) + if (Xen_hook_has_list(new_sound_hook)) { #if HAVE_SCHEME - int gc_loc; -#endif - XEN procs = XEN_HOOK_PROCEDURES(new_sound_hook); - XEN fname; - - fname = C_TO_XEN_STRING(filename); -#if HAVE_SCHEME - gc_loc = s7_gc_protect(s7, fname); -#endif - - while (XEN_NOT_NULL_P(procs)) + s7_call(s7, new_sound_hook, s7_cons(s7, C_string_to_Xen_string(filename), Xen_empty_list)); +#else + Xen procs, fname; + fname = C_string_to_Xen_string(filename); + procs = Xen_hook_list(new_sound_hook); + while (!Xen_is_null(procs)) { - XEN_CALL_1(XEN_CAR(procs), - fname, - S_new_sound_hook); - procs = XEN_CDR (procs); + Xen_call_with_1_arg(Xen_car(procs), fname, S_new_sound_hook); + procs = Xen_cdr(procs); } -#if HAVE_SCHEME - s7_gc_unprotect_at(s7, gc_loc); #endif } } -#if HAVE_OSS -#define S_mus_audio_reinitialize "mus-audio-reinitialize" -static XEN g_mus_audio_reinitialize(void) -{ - #define H_mus_audio_reinitialize "(" S_mus_audio_reinitialize "): force audio device re-initialization" - return(C_TO_XEN_INT(mus_audio_reinitialize())); -} -#endif - - - -static XEN_OBJECT_TYPE sound_data_tag = 0; - -bool sound_data_p(XEN obj) {return(XEN_OBJECT_TYPE_P(obj, sound_data_tag));} - -#define SOUND_DATA_P(Obj) XEN_OBJECT_TYPE_P(Obj, sound_data_tag) - -static XEN g_sound_data_p(XEN obj) -{ - #define H_sound_data_p "(" S_sound_data_p " obj): is 'obj' is a sound-data object" - return(C_TO_XEN_BOOLEAN(sound_data_p(obj))); -} - - -void sound_data_free(sound_data *sd) +static Xen sound_path; +Xen g_mus_sound_path(void) { - if (sd) - { - if ((sd->data) && (!(sd->wrapped))) - { - int i; - for (i = 0; i < sd->chans; i++) if (sd->data[i]) free(sd->data[i]); - free(sd->data); - } - sd->data = NULL; - sd->chans = 0; - free(sd); - } -} - - -XEN_MAKE_OBJECT_FREE_PROCEDURE(sound_data, free_sound_data, sound_data_free) - - -char *sound_data_to_string(sound_data *sd) -{ - char *buf; - int len, chans; /* len=print length */ - char flt[24]; - - if (sd == NULL) return(NULL); - - len = mus_vct_print_length(); - if (len > sd->length) len = sd->length; - - chans = sd->chans; - buf = (char *)calloc(64 + len * 24 * chans, sizeof(char)); - - sprintf(buf, "#<sound-data[chans=%d, length=" MUS_LD "]:", sd->chans, sd->length); - if (len > 0) - { - int i, chn; - for (chn = 0; chn < chans; chn++) - { - mus_snprintf(flt, 24, "\n (%.3f", sd->data[chn][0]); - strcat(buf, flt); - for (i = 1; i < len; i++) - { - mus_snprintf(flt, 24, " %.3f", sd->data[chn][i]); - strcat(buf, flt); - } - if (sd->length > mus_vct_print_length()) - strcat(buf, " ..."); - strcat(buf, ")"); - } - } - strcat(buf, ">"); - return(buf); -} - - -XEN_MAKE_OBJECT_PRINT_PROCEDURE(sound_data, print_sound_data, sound_data_to_string) - - -bool sound_data_equalp(sound_data *v1, sound_data *v2) -{ - if (v1 == v2) return(true); - if ((v1) && (v2) && - (v1->chans == v2->chans) && - (v1->length == v2->length)) - { - int chn; - for (chn = 0; chn < v1->chans; chn++) - if (!(mus_arrays_are_equal(v1->data[chn], v2->data[chn], - mus_float_equal_fudge_factor(), - v1->length))) - return(false); - return(true); - } - return(false); + #define H_mus_sound_path "(" S_mus_sound_path "): a list of directories to search for sound files." + return(sound_path); } #if HAVE_SCHEME -static bool s7_equalp_sound_data(void *s1, void *s2) -{ - return(sound_data_equalp((sound_data *)s1, (sound_data *)s2)); -} -#else - -static XEN equalp_sound_data(XEN obj1, XEN obj2) -{ -#if HAVE_RUBY || HAVE_FORTH - if ((!(SOUND_DATA_P(obj1))) || (!(SOUND_DATA_P(obj2)))) return(XEN_FALSE); + static int sound_path_loc = -1; + static s7_pointer mus_sound_path_symbol; #endif - return(C_TO_XEN_BOOLEAN(sound_data_equalp(XEN_TO_SOUND_DATA(obj1), XEN_TO_SOUND_DATA(obj2)))); -} -#endif - -static XEN g_sound_data_length(XEN obj) -{ - #define H_sound_data_length "(" S_sound_data_length " sd): length (in samples) of each channel of sound-data sd" - sound_data *sd; - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ONLY_ARG, S_sound_data_length, "a sound-data object"); - sd = XEN_TO_SOUND_DATA(obj); - return(C_TO_XEN_INT64_T(sd->length)); -} - - -static XEN g_sound_data_chans(XEN obj) -{ - #define H_sound_data_chans "(" S_sound_data_chans " sd): number of channels in sound-data sd" - sound_data *sd; - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ONLY_ARG, S_sound_data_chans, "a sound-data object"); - sd = XEN_TO_SOUND_DATA(obj); - return(C_TO_XEN_INT(sd->chans)); -} - - -sound_data *c_make_sound_data(int chans, mus_long_t frames) -{ - int i; - sound_data *sd; - - sd = (sound_data *)malloc(sizeof(sound_data)); - sd->length = frames; - sd->chans = chans; - sd->wrapped = false; - sd->data = (mus_float_t **)calloc(chans, sizeof(mus_float_t *)); - for (i = 0; i < chans; i++) - sd->data[i] = (mus_float_t *)calloc(frames, sizeof(mus_float_t)); - return(sd); -} - - -XEN make_sound_data(int chans, mus_long_t frames) -{ - #define H_make_sound_data "(" S_make_sound_data " chans frames): return a new sound-data object with 'chans' channels, each having 'frames' samples" - sound_data *sd; - sd = c_make_sound_data(chans, frames); - XEN_MAKE_AND_RETURN_OBJECT(sound_data_tag, sd, 0, free_sound_data); -} - -XEN wrap_sound_data(int chans, mus_long_t frames, mus_float_t **data) -{ - sound_data *sd; - sd = (sound_data *)malloc(sizeof(sound_data)); - sd->length = frames; - sd->chans = chans; - sd->wrapped = true; - sd->data = data; - XEN_MAKE_AND_RETURN_OBJECT(sound_data_tag, sd, 0, free_sound_data); -} - - -static XEN g_make_sound_data(XEN chans, XEN frames) -{ - int chns; - mus_long_t frms; - - XEN_ASSERT_TYPE(XEN_INTEGER_P(chans), chans, XEN_ARG_1, S_make_sound_data, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(frames), frames, XEN_ARG_2, S_make_sound_data, "an integer"); - - chns = XEN_TO_C_INT(chans); - if (chns <= 0) - XEN_OUT_OF_RANGE_ERROR(S_make_sound_data, 1, chans, "chans ~A <= 0?"); - if (chns > (1 << 26)) - XEN_OUT_OF_RANGE_ERROR(S_make_sound_data, 1, chans, "chans arg ~A too large"); - - frms = XEN_TO_C_INT64_T(frames); - if (frms <= 0) - XEN_OUT_OF_RANGE_ERROR(S_make_sound_data, 2, frames, "frames ~A <= 0?"); - if ((frms > mus_max_malloc()) || - (((mus_long_t)(frms * sizeof(mus_float_t))) > mus_max_malloc())) - XEN_OUT_OF_RANGE_ERROR(S_make_sound_data, 2, frames, "frames arg ~A too large (see mus-max-malloc)"); - - return(make_sound_data(chns, frms)); - -} - - -static XEN g_sound_data_ref(XEN obj, XEN chan, XEN frame_num) -{ - #define H_sound_data_ref "(" S_sound_data_ref " sd chan i): sample in channel chan at location i of sound-data sd: sd[chan][i]" - sound_data *sd; - mus_long_t loc; - int chn; - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ARG_1, S_sound_data_ref, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(chan), chan, XEN_ARG_2, S_sound_data_ref, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(frame_num), frame_num, XEN_ARG_3, S_sound_data_ref, "an integer"); - - sd = XEN_TO_SOUND_DATA(obj); - - chn = XEN_TO_C_INT(chan); - if (chn < 0) - XEN_OUT_OF_RANGE_ERROR(S_sound_data_ref, 2, chan, "~A: invalid channel"); - if (chn >= sd->chans) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_3(C_TO_XEN_STRING(S_sound_data_ref ": chan: ~A >= sound-data chans, ~A"), - chan, - C_TO_XEN_INT(sd->chans))); - - loc = XEN_TO_C_INT64_T(frame_num); - if (loc < 0) - XEN_OUT_OF_RANGE_ERROR(S_sound_data_ref, 3, frame_num, "~A: invalid frame"); - if (loc >= sd->length) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_3(C_TO_XEN_STRING(S_sound_data_ref ": frame: ~A >= sound-data length, ~A"), - frame_num, - C_TO_XEN_INT64_T(sd->length))); - - return(C_TO_XEN_DOUBLE(sd->data[chn][loc])); -} - - -XEN g_sound_data_maxamp(XEN obj) -{ - #define H_sound_data_maxamp "(" S_sound_data_maxamp " sd): list of maxamps of data in sd" - sound_data *sd; - int i, chans; - mus_long_t j, len; - - XEN lst = XEN_EMPTY_LIST; - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ARG_1, S_sound_data_maxamp, "a sound-data object"); - - sd = XEN_TO_SOUND_DATA(obj); - chans = sd->chans; - len = sd->length; - - for (i = chans - 1; i >= 0; i--) - { - mus_float_t mx; - mus_float_t *buf; - mx = -10000.0; - buf = sd->data[i]; - for (j = 0; j < len; j++) - { - if (buf[j] > mx) - mx = buf[j]; - else - if (-buf[j] > mx) - mx = -buf[j]; - } - lst = XEN_CONS(C_TO_XEN_DOUBLE(mx), lst); - } - return(lst); -} - - -mus_float_t sound_data_peak(sound_data *sd) +static Xen g_mus_set_sound_path(Xen val) { - int chn; - mus_long_t i; - mus_float_t mx = 0.0; - for (chn = 0; chn < sd->chans; chn++) - for (i = 0; i < sd->length; i++) - if (fabs(sd->data[chn][i]) > mx) - mx = fabs(sd->data[chn][i]); - return(mx); -} - - -static XEN g_sound_data_peak(XEN obj) -{ - #define H_sound_data_peak "(" S_sound_data_peak " sd): overall maxamp of data in sd" - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ARG_1, S_sound_data_maxamp, "a sound-data object"); - return(C_TO_XEN_DOUBLE(sound_data_peak(XEN_TO_SOUND_DATA(obj)))); -} - - -#if HAVE_FORTH -static XEN sound_data_apply(XEN obj, XEN chan, XEN i) -{ - return(g_sound_data_ref(obj, chan, i)); -} -#endif - + Xen_check_type(Xen_is_list(val), val, 1, S_set S_mus_sound_path, "a list"); #if HAVE_SCHEME -static XEN g_sound_data_set(XEN obj, XEN chan, XEN frame_num, XEN val); -static XEN g_sound_data_copy(XEN obj); -static XEN g_sound_data_fillB(XEN sdobj, XEN scl); - -static XEN sound_data_apply(s7_scheme *sc, XEN obj, XEN args) -{ - return(g_sound_data_ref(obj, XEN_CAR(args), XEN_CADR(args))); -} - -static XEN s7_sound_data_set(s7_scheme *sc, XEN obj, XEN args) -{ - return(g_sound_data_set(obj, XEN_CAR(args), XEN_CADR(args), XEN_CADDR(args))); -} - -static XEN s7_sound_data_length(s7_scheme *sc, XEN obj) -{ - return(g_sound_data_length(obj)); -} - -static XEN s7_sound_data_copy(s7_scheme *sc, XEN obj) -{ - return(g_sound_data_copy(obj)); -} - -static XEN s7_sound_data_fill(s7_scheme *sc, XEN obj, XEN val) -{ - return(g_sound_data_fillB(obj, val)); -} + if (sound_path_loc != -1) + s7_gc_unprotect_at(s7, sound_path_loc); + sound_path = val; + sound_path_loc = s7_gc_protect(s7, sound_path); + s7_symbol_set_value(s7, mus_sound_path_symbol, val); +#else + if (sound_path != Xen_empty_list) + Xen_GC_unprotect(sound_path); + Xen_GC_protect(val); + sound_path = val; #endif - - -static XEN g_sound_data_set(XEN obj, XEN chan, XEN frame_num, XEN val) -{ - #define H_sound_data_setB "(" S_sound_data_setB " sd chan i val): set sound-data sd's i-th element in channel chan to val: sd[chan][i] = val" - sound_data *sd; - int chn; - mus_long_t loc; - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ARG_1, S_sound_data_setB, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_INTEGER_P(chan), chan, XEN_ARG_2, S_sound_data_setB, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(frame_num), frame_num, XEN_ARG_3, S_sound_data_setB, "an integer"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(val), val, XEN_ARG_4, S_sound_data_setB, "a number"); - - sd = XEN_TO_SOUND_DATA(obj); - chn = XEN_TO_C_INT(chan); - if (chn < 0) - XEN_OUT_OF_RANGE_ERROR(S_sound_data_setB, 2, chan, "~A: invalid channel"); - if (chn >= sd->chans) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_3(C_TO_XEN_STRING(S_sound_data_setB ": chan: ~A >= sound-data chans, ~A"), - chan, - C_TO_XEN_INT(sd->chans))); - - loc = XEN_TO_C_INT64_T(frame_num); - if (loc < 0) - XEN_OUT_OF_RANGE_ERROR(S_sound_data_setB, 3, frame_num, "~A: invalid frame"); - if (loc >= sd->length) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_3(C_TO_XEN_STRING(S_sound_data_setB ": frame: ~A >= sound-data length, ~A"), - frame_num, - C_TO_XEN_INT64_T(sd->length))); - - sd->data[chn][loc] = XEN_TO_C_DOUBLE(val); return(val); } -sound_data *sound_data_scale(sound_data *sd, mus_float_t scaler) -{ - int chn; - mus_long_t i; - if (scaler == 0.0) - { - for (chn = 0; chn < sd->chans; chn++) - mus_clear_array(sd->data[chn], sd->length); - } - else - { - if (scaler != 1.0) - for (chn = 0; chn < sd->chans; chn++) - for (i = 0; i < sd->length; i++) - sd->data[chn][i] *= scaler; - } - return(sd); -} - - -static XEN g_sound_data_scaleB(XEN sdobj, XEN scl) -{ - #define H_sound_data_scaleB "(" S_sound_data_scaleB " sd scl): scales (multiplies) sound-data sd's data by scl" - - XEN_ASSERT_TYPE(SOUND_DATA_P(sdobj), sdobj, XEN_ARG_1, S_sound_data_scaleB, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(scl), scl, XEN_ARG_2, S_sound_data_scaleB, "a number"); - - sound_data_scale(XEN_TO_SOUND_DATA(sdobj), XEN_TO_C_DOUBLE(scl)); - return(sdobj); -} - - -sound_data *sound_data_fill(sound_data *sd, mus_float_t scaler) -{ - int chn; - mus_long_t i; - if (scaler == 0.0) - { - for (chn = 0; chn < sd->chans; chn++) - mus_clear_array(sd->data[chn], sd->length); - } - else - { - for (chn = 0; chn < sd->chans; chn++) - for (i = 0; i < sd->length; i++) - sd->data[chn][i] = scaler; - } - return(sd); -} - - -static XEN g_sound_data_fillB(XEN sdobj, XEN scl) -{ - #define H_sound_data_fillB "(" S_sound_data_fillB " sd value): fills the sound-data object sd with value" - - XEN_ASSERT_TYPE(SOUND_DATA_P(sdobj), sdobj, XEN_ARG_1, S_sound_data_fillB, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(scl), scl, XEN_ARG_2, S_sound_data_fillB, "a number"); - - sound_data_fill(XEN_TO_SOUND_DATA(sdobj), XEN_TO_C_DOUBLE(scl)); - return(sdobj); -} - - -sound_data *sound_data_copy(sound_data *sd) -{ - int i; - sound_data *sdnew; - sdnew = c_make_sound_data(sd->chans, sd->length); - for (i = 0; i < sd->chans; i++) - memcpy((void *)(sdnew->data[i]), (void *)(sd->data[i]), sd->length * sizeof(mus_float_t)); - return(sdnew); -} - - -static XEN g_sound_data_copy(XEN obj) -{ - sound_data *sdnew; - #define H_sound_data_copy "(" S_sound_data_copy " sd): returns a copy of the sound-data object sd" - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ONLY_ARG, S_sound_data_copy, "a sound-data object"); - - sdnew = sound_data_copy(XEN_TO_SOUND_DATA(obj)); - XEN_MAKE_AND_RETURN_OBJECT(sound_data_tag, sdnew, 0, free_sound_data); -} - - -sound_data *sound_data_reverse(sound_data *sd) -{ - int chn; - mus_long_t i, j; - - for (chn = 0; chn < sd->chans; chn++) - for (i = 0, j = sd->length - 1; i < j; i++, j--) - { - mus_float_t tmp; - tmp = sd->data[chn][i]; - sd->data[chn][i] = sd->data[chn][j]; - sd->data[chn][j] = tmp; - } - return(sd); -} - - -static XEN g_sound_data_reverseB(XEN obj) -{ - #define H_sound_data_reverseB "(" S_sound_data_reverseB " sd): reverses the elements (within each channel) of sound-data object sd" - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ONLY_ARG, S_sound_data_reverseB, "a sound-data object"); - - sound_data_reverse(XEN_TO_SOUND_DATA(obj)); - return(obj); -} - - -sound_data *sound_data_add(sound_data *sd1, sound_data *sd2) -{ - int i, chns; - mus_long_t j, len; - - chns = sd1->chans; - if (chns > sd2->chans) chns = sd2->chans; - len = sd1->length; - if (len > sd2->length) len = sd2->length; - - for (i = 0; i < chns; i++) - for (j = 0; j < len; j++) - sd1->data[i][j] += sd2->data[i][j]; - - return(sd1); -} - - -static XEN g_sound_data_addB(XEN obj1, XEN obj2) -{ - #define H_sound_data_addB "(" S_sound_data_addB " sd1 sd2): adds (element-wise) sd2 to sd1, returning sd1" - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj1), obj1, XEN_ARG_1, S_sound_data_addB, "a sound-data object"); - XEN_ASSERT_TYPE(SOUND_DATA_P(obj2), obj2, XEN_ARG_2, S_sound_data_addB, "a sound-data object"); - - sound_data_add(XEN_TO_SOUND_DATA(obj1), XEN_TO_SOUND_DATA(obj2)); - return(obj1); -} - - -sound_data *sound_data_multiply(sound_data *sd1, sound_data *sd2) -{ - int i, chns; - mus_long_t j, len; - - chns = sd1->chans; - if (chns > sd2->chans) chns = sd2->chans; - len = sd1->length; - if (len > sd2->length) len = sd2->length; - - for (i = 0; i < chns; i++) - for (j = 0; j < len; j++) - sd1->data[i][j] *= sd2->data[i][j]; - - return(sd1); -} - - -static XEN g_sound_data_multiplyB(XEN obj1, XEN obj2) -{ - #define H_sound_data_multiplyB "(" S_sound_data_multiplyB " sd1 sd2): multiplies (element-wise) sd1 by sd2, returning sd1" - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj1), obj1, XEN_ARG_1, S_sound_data_multiplyB, "a sound-data object"); - XEN_ASSERT_TYPE(SOUND_DATA_P(obj2), obj2, XEN_ARG_2, S_sound_data_multiplyB, "a sound-data object"); - - sound_data_multiply(XEN_TO_SOUND_DATA(obj1), XEN_TO_SOUND_DATA(obj2)); - return(obj1); -} - - -sound_data *sound_data_offset(sound_data *sd, mus_float_t off) -{ - if (off != 0.0) - { - int i; - mus_long_t j; - for (i = 0; i < sd->chans; i++) - for (j = 0; j < sd->length; j++) - sd->data[i][j] += off; - } - return(sd); -} - - -static XEN g_sound_data_offsetB(XEN obj, XEN offset) -{ - #define H_sound_data_offsetB "(" S_sound_data_offsetB " sd val): adds val to each element of sd, returning sd" - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj), obj, XEN_ARG_1, S_sound_data_offsetB, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_NUMBER_P(offset), offset, XEN_ARG_2, S_sound_data_offsetB, "a number"); - - sound_data_offset(XEN_TO_SOUND_DATA(obj), XEN_TO_C_DOUBLE(offset)); - return(obj); -} - - -static XEN g_sound_data_add(XEN obj1, XEN obj2) -{ - #define H_sound_data_add "(" S_sound_data_add " obj1 obj2): adds obj1 to obj2, either or both of which can be sound-data objects" - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj1) || XEN_NUMBER_P(obj1), obj1, XEN_ARG_1, S_sound_data_add, "a sound-data object or a number"); - XEN_ASSERT_TYPE(SOUND_DATA_P(obj2) || XEN_NUMBER_P(obj2), obj2, XEN_ARG_2, S_sound_data_add, "a sound-data object or a number"); - - if (SOUND_DATA_P(obj1)) - { - if (SOUND_DATA_P(obj2)) - return(g_sound_data_addB(obj1, obj2)); - return(g_sound_data_offsetB(obj1, obj2)); - } - if (SOUND_DATA_P(obj2)) - return(g_sound_data_offsetB(obj2, obj1)); - return(C_TO_XEN_DOUBLE(XEN_TO_C_DOUBLE(obj1) + XEN_TO_C_DOUBLE(obj2))); -} - - -static XEN g_sound_data_multiply(XEN obj1, XEN obj2) -{ - #define H_sound_data_multiply "(" S_sound_data_multiply " obj1 obj2): multiplies obj1 by obj2, either or both of which can be sound-data objects" - - XEN_ASSERT_TYPE(SOUND_DATA_P(obj1) || XEN_NUMBER_P(obj1), obj1, XEN_ARG_1, S_sound_data_multiply, "a sound-data object or a number"); - XEN_ASSERT_TYPE(SOUND_DATA_P(obj2) || XEN_NUMBER_P(obj2), obj2, XEN_ARG_2, S_sound_data_multiply, "a sound-data object or a number"); - - if (SOUND_DATA_P(obj1)) - { - if (SOUND_DATA_P(obj2)) - return(g_sound_data_multiplyB(obj1, obj2)); - return(g_sound_data_scaleB(obj1, obj2)); - } - if (SOUND_DATA_P(obj2)) - return(g_sound_data_scaleB(obj2, obj1)); - return(C_TO_XEN_DOUBLE(XEN_TO_C_DOUBLE(obj1) * XEN_TO_C_DOUBLE(obj2))); -} - - - -static XEN g_sound_data_to_vct(XEN sdobj, XEN chan, XEN vobj) +static Xen g_mus_max_malloc(void) { - #define H_sound_data_to_vct "(" S_sound_data_to_vct " sd chan v): copies sound-data sd's channel chan data into vct v" - vct *v; - sound_data *sd; - int chn; - mus_long_t len; - - XEN_ASSERT_TYPE(SOUND_DATA_P(sdobj), sdobj, XEN_ARG_1, S_sound_data_to_vct, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_INTEGER_IF_BOUND_P(chan), chan, XEN_ARG_2, S_sound_data_to_vct, "an integer"); - XEN_ASSERT_TYPE(XEN_NOT_BOUND_P(vobj) || MUS_VCT_P(vobj), vobj, XEN_ARG_3, S_sound_data_to_vct, "a vct"); - - sd = XEN_TO_SOUND_DATA(sdobj); - chn = XEN_TO_C_INT_OR_ELSE(chan, 0); - if (chn < 0) - XEN_OUT_OF_RANGE_ERROR(S_sound_data_to_vct, 2, chan, "~A: invalid channel"); - if (chn >= sd->chans) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_3(C_TO_XEN_STRING(S_sound_data_to_vct ": chan: ~A >= sound-data chans, ~A"), - chan, - C_TO_XEN_INT(sd->chans))); - - if (!(MUS_VCT_P(vobj))) - vobj = xen_make_vct(sd->length, (mus_float_t *)calloc(sd->length, sizeof(mus_float_t))); - v = XEN_TO_VCT(vobj); - - if (sd->length < v->length) - len = sd->length; - else len = v->length; - - memcpy((void *)(v->data), (void *)(sd->data[chn]), len * sizeof(mus_float_t)); - - return(vobj); -} - - -static XEN g_vct_to_sound_data(XEN vobj, XEN sdobj, XEN chan) -{ - #define H_vct_to_sound_data "(" S_vct_to_sound_data " v sd chan): copies vct v's data into sound-data sd's channel chan" - vct *v; - sound_data *sd; - XEN obj = XEN_FALSE; - int chn; - mus_long_t len; - - XEN_ASSERT_TYPE(MUS_VCT_P(vobj), vobj, XEN_ARG_1, S_vct_to_sound_data, "a vct"); - XEN_ASSERT_TYPE(XEN_NOT_BOUND_P(sdobj) || SOUND_DATA_P(sdobj), sdobj, XEN_ARG_2, S_vct_to_sound_data, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_INTEGER_IF_BOUND_P(chan), chan, XEN_ARG_3, S_vct_to_sound_data, "an integer"); - - v = XEN_TO_VCT(vobj); - chn = XEN_TO_C_INT_OR_ELSE(chan, 0); - if (chn < 0) - XEN_OUT_OF_RANGE_ERROR(S_vct_to_sound_data, 3, chan, "~A: invalid channel"); - if (!(SOUND_DATA_P(sdobj))) - { - if (chn > 0) - XEN_OUT_OF_RANGE_ERROR(S_vct_to_sound_data, 3, chan, "~A: invalid channel"); - obj = make_sound_data(1, v->length); - sd = XEN_TO_SOUND_DATA(obj); - } - else - { - sd = XEN_TO_SOUND_DATA(sdobj); - if (chn >= sd->chans) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_3(C_TO_XEN_STRING(S_vct_to_sound_data ": chan: ~A >= sound-data chans, ~A"), - chan, - C_TO_XEN_INT(sd->chans))); - obj = sdobj; - } - if (sd->length < v->length) - len = sd->length; - else len = v->length; - memcpy((void *)(sd->data[chn]), (void *)(v->data), len * sizeof(mus_float_t)); - return(obj); -} - - -static void *mus_long_t_memmove(char *dest, const char *source, mus_long_t length) -{ - /* not void, as in gnulib, because that makes C++ unhappy! */ - char *d0 = dest; - if (source < dest) - /* Moving from low mem to hi mem; start at end. */ - for (source += length, dest += length; length; --length) - *--dest = *--source; - else - if (source != dest) - { - /* Moving from hi mem to low mem; start at beginning. */ - for (; length; --length) - *dest++ = *source++; - } - return((void *)d0); -} - - -#define S_sound_data_to_sound_data "sound-data->sound-data" - -static XEN g_sound_data_to_sound_data(XEN sd_in, XEN sd_out, XEN start, XEN frames, XEN cycle_length) -{ - #define H_sound_data_to_sound_data "(" S_sound_data_to_sound_data " sd-in sd-out start frames cycle-length): \ -copies sound-data sd-in's data from 0 for 'frames' frames into 'sd-out' starting at 'start', wrapping around if sd-out's end (or cycle-length) is reached." - - sound_data *sdi, *sdo; - int i, chans; - mus_long_t j = 0, len, beg, olen, ilen, cycle; - - XEN_ASSERT_TYPE(SOUND_DATA_P(sd_in), sd_in, XEN_ARG_1, S_sound_data_to_sound_data, "a sound-data object"); - XEN_ASSERT_TYPE(SOUND_DATA_P(sd_out), sd_out, XEN_ARG_2, S_sound_data_to_sound_data, "a sound-data object"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(start), start, XEN_ARG_3, S_sound_data_to_sound_data, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(frames), frames, XEN_ARG_4, S_sound_data_to_sound_data, "an integer"); - XEN_ASSERT_TYPE(XEN_INT64_T_P(cycle_length), cycle_length, XEN_ARG_5, S_sound_data_to_sound_data, "an integer"); - - sdi = XEN_TO_SOUND_DATA(sd_in); - sdo = XEN_TO_SOUND_DATA(sd_out); - - ilen = sdi->length; - olen = sdo->length; - - beg = XEN_TO_C_INT64_T(start); - if (beg < 0) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_2(C_TO_XEN_STRING(S_sound_data_to_sound_data ": start: ~A < 0"), - start)); - if (beg >= olen) beg = 0; - - len = XEN_TO_C_INT64_T(frames); - if ((len < 0) || (len > ilen)) - XEN_ERROR(XEN_ERROR_TYPE("out-of-range"), - XEN_LIST_2(C_TO_XEN_STRING(S_sound_data_to_sound_data ": frames: ~A?"), - frames)); - - cycle = XEN_TO_C_INT64_T(cycle_length); - if (beg >= cycle) beg = 0; - if (cycle > olen) cycle = olen; - - chans = sdo->chans; - if (chans > sdi->chans) - chans = sdi->chans; - - if ((beg + len) < cycle) - { - for (i = 0; i < chans; i++) - mus_long_t_memmove((char *)(sdo->data[i] + beg), (const char *)(sdi->data[i]), len * sizeof(mus_float_t)); - j = beg + len; - } - else - { - for (i = 0; i < chans; i++) - { - mus_long_t k; - j = beg; - for (k = 0; k < len; k++) - { - sdo->data[i][j++] = sdi->data[i][k]; - if (j == cycle) j = 0; - } - } - } - return(C_TO_XEN_INT64_T(j)); + #define H_mus_max_malloc "(" S_mus_max_malloc "): maximum number of bytes we will try to malloc." + return(C_llong_to_Xen_llong(mus_max_malloc())); } - -#if HAVE_FORTH -#define S_sound_data_to_vector "sound-data->vector" - -static XEN g_sound_data_to_vector(XEN sdata) -{ -#define H_sound_data_to_vector "(" S_sound_data_to_vector " sd): \ -returns a vector of length sd->chans containing all channels of sound-data sd as vct." - long chn; - sound_data *sd; - FTH vec; - - XEN_ASSERT_TYPE(SOUND_DATA_P(sdata), sdata, XEN_ONLY_ARG, S_sound_data_to_vector, "a sound-data object"); - sd = XEN_TO_SOUND_DATA(sdata); - vec = XEN_MAKE_VECTOR(sd->chans, FTH_NIL); - - for (chn = 0; chn < sd->chans; chn++) - XEN_VECTOR_SET(vec, chn, g_sound_data_to_vct(sdata, C_TO_XEN_INT(chn), XEN_UNDEFINED)); - return vec; -} +#if HAVE_SCHEME + static s7_pointer mus_max_malloc_symbol; #endif - -#if HAVE_RUBY -static XEN sound_data_each(XEN obj) -{ - int j; - mus_long_t i; - sound_data *sd; - sd = XEN_TO_SOUND_DATA(obj); - for (j = 0; j < sd->chans; j++) - for (i = 0; i < sd->length; i++) - rb_yield(C_TO_XEN_DOUBLE(sd->data[j][i])); - return(obj); -} - - -static XEN sound_data_compare(XEN vr1, XEN vr2) -{ - mus_long_t i, len; - int j; - sound_data *v1, *v2; - if ((SOUND_DATA_P(vr1)) && (SOUND_DATA_P(vr2))) - { - v1 = XEN_TO_SOUND_DATA(vr1); - v2 = XEN_TO_SOUND_DATA(vr2); - if (v1->chans > v2->chans) - return(C_TO_XEN_INT(1)); - if (v1->chans < v2->chans) - return(C_TO_XEN_INT(-1)); - len = v1->length; - if (len > v2->length) len = v2->length; - for (j = 0; j < v1->chans; j++) - for (i = 0; i < len; i++) - if (v1->data[j][i] < v2->data[j][i]) - return(C_TO_XEN_INT(-1)); - else - if (v1->data[j][i] > v2->data[j][i]) - return(C_TO_XEN_INT(1)); - len = v1->length - v2->length; - if (len == 0) return(XEN_ZERO); - if (len > 0) return(C_TO_XEN_INT(1)); - } - return(C_TO_XEN_INT(-1)); -} - - -static XEN sound_data_size(XEN obj) +static Xen g_mus_set_max_malloc(Xen val) { - sound_data *sd; - sd = XEN_TO_SOUND_DATA(obj); - return(C_TO_XEN_INT64_T(sd->length * sd->chans)); -} - - -static XEN sound_data_chans(XEN obj) -{ - sound_data *sd; - sd = XEN_TO_SOUND_DATA(obj); - return(C_TO_XEN_INT(sd->chans)); -} - - -static XEN g_rb_sound_data_fill(XEN obj, XEN val) -{ - sound_data_fill(XEN_TO_SOUND_DATA(obj), XEN_TO_C_DOUBLE(val)); - return(val); -} - - -static XEN g_rb_make_sound_data(XEN self, XEN chans, XEN frames) -{ - return(g_make_sound_data(chans, frames)); -} + mus_long_t size; + Xen_check_type(Xen_is_llong(val), val, 1, S_set S_mus_max_malloc, "an integer"); + size = Xen_llong_to_C_llong(val); +#if HAVE_SCHEME + s7_symbol_set_value(s7, mus_max_malloc_symbol, s7_make_integer(s7, size)); #endif - - - -static XEN g_mus_max_malloc(void) -{ - #define H_mus_max_malloc "(" S_mus_max_malloc "): maximum number of bytes we will try to malloc." - return(C_TO_XEN_INT64_T(mus_max_malloc())); + return(C_llong_to_Xen_llong(mus_set_max_malloc(size))); } -static XEN g_mus_set_max_malloc(XEN val) -{ - XEN_ASSERT_TYPE(XEN_INT64_T_P(val), val, XEN_ONLY_ARG, S_setB S_mus_max_malloc, "an integer"); - return(C_TO_XEN_INT64_T(mus_set_max_malloc(XEN_TO_C_INT64_T(val)))); -} - - -static XEN g_mus_max_table_size(void) +static Xen g_mus_max_table_size(void) { #define H_mus_max_table_size "(" S_mus_max_table_size "): maximum table size." - return(C_TO_XEN_INT64_T(mus_max_table_size())); + return(C_llong_to_Xen_llong(mus_max_table_size())); } -static XEN g_mus_set_max_table_size(XEN val) +#if HAVE_SCHEME + static s7_pointer mus_max_table_size_symbol; +#endif + +static Xen g_mus_set_max_table_size(Xen val) { - XEN_ASSERT_TYPE(XEN_INT64_T_P(val), val, XEN_ONLY_ARG, S_setB S_mus_max_table_size, "an integer"); - return(C_TO_XEN_INT64_T(mus_set_max_table_size(XEN_TO_C_INT64_T(val)))); + mus_long_t size; + Xen_check_type(Xen_is_llong(val), val, 1, S_set S_mus_max_table_size, "an integer"); + size = Xen_llong_to_C_llong(val); +#if HAVE_SCHEME + s7_symbol_set_value(s7, mus_max_table_size_symbol, s7_make_integer(s7, size)); +#endif + return(C_llong_to_Xen_llong(mus_set_max_table_size(size))); } -#if MUS_MAC_OSX +#if __APPLE__ #define S_mus_audio_output_properties_mutable "mus-audio-output-properties-mutable" -static XEN g_mus_audio_output_properties_mutable(XEN mut) +static Xen g_mus_audio_output_properties_mutable(Xen mut) { #define H_mus_audio_output_properties_mutable "(" S_mus_audio_output_properties_mutable " val): can DAC settings be changed to match the current sound" - XEN_ASSERT_TYPE(XEN_BOOLEAN_P(mut), mut, XEN_ONLY_ARG, S_mus_audio_output_properties_mutable, "a boolean"); - return(C_TO_XEN_BOOLEAN(mus_audio_output_properties_mutable(XEN_TO_C_BOOLEAN(mut)))); + Xen_check_type(Xen_is_boolean(mut), mut, 1, S_mus_audio_output_properties_mutable, "a boolean"); + return(C_bool_to_Xen_boolean(mus_audio_output_properties_mutable(Xen_boolean_to_C_bool(mut)))); } #endif -#ifdef XEN_ARGIFY_1 -XEN_NARGIFY_1(g_sound_data_length_w, g_sound_data_length) -XEN_NARGIFY_1(g_sound_data_chans_w, g_sound_data_chans) -XEN_NARGIFY_1(g_sound_data_copy_w, g_sound_data_copy) -XEN_NARGIFY_2(g_sound_data_addB_w, g_sound_data_addB) -XEN_NARGIFY_2(g_sound_data_add_w, g_sound_data_add) -XEN_NARGIFY_2(g_sound_data_offsetB_w, g_sound_data_offsetB) -XEN_NARGIFY_2(g_sound_data_multiplyB_w, g_sound_data_multiplyB) -XEN_NARGIFY_2(g_sound_data_multiply_w, g_sound_data_multiply) -XEN_NARGIFY_3(g_sound_data_ref_w, g_sound_data_ref) -XEN_NARGIFY_4(g_sound_data_set_w, g_sound_data_set) -XEN_NARGIFY_2(g_make_sound_data_w, g_make_sound_data) -XEN_NARGIFY_1(g_sound_data_p_w, g_sound_data_p) -XEN_NARGIFY_1(g_sound_data_maxamp_w, g_sound_data_maxamp) -XEN_NARGIFY_1(g_sound_data_peak_w, g_sound_data_peak) -XEN_NARGIFY_2(g_sound_data_scaleB_w, g_sound_data_scaleB) -XEN_NARGIFY_2(g_sound_data_fillB_w, g_sound_data_fillB) -XEN_NARGIFY_1(g_sound_data_reverseB_w, g_sound_data_reverseB) -XEN_ARGIFY_3(g_sound_data_to_vct_w, g_sound_data_to_vct) -XEN_NARGIFY_5(g_sound_data_to_sound_data_w, g_sound_data_to_sound_data) -XEN_ARGIFY_3(g_vct_to_sound_data_w, g_vct_to_sound_data) -XEN_NARGIFY_1(g_mus_sound_samples_w, g_mus_sound_samples) -XEN_NARGIFY_2(g_mus_sound_set_samples_w, g_mus_sound_set_samples) -XEN_NARGIFY_1(g_mus_sound_frames_w, g_mus_sound_frames) -XEN_NARGIFY_1(g_mus_sound_duration_w, g_mus_sound_duration) -XEN_NARGIFY_1(g_mus_sound_datum_size_w, g_mus_sound_datum_size) -XEN_NARGIFY_1(g_mus_sound_data_location_w, g_mus_sound_data_location) -XEN_NARGIFY_2(g_mus_sound_set_data_location_w, g_mus_sound_set_data_location) -XEN_NARGIFY_1(g_mus_sound_chans_w, g_mus_sound_chans) -XEN_NARGIFY_2(g_mus_sound_set_chans_w, g_mus_sound_set_chans) -XEN_NARGIFY_1(g_mus_sound_srate_w, g_mus_sound_srate) -XEN_NARGIFY_2(g_mus_sound_set_srate_w, g_mus_sound_set_srate) -XEN_NARGIFY_1(g_mus_sound_header_type_w, g_mus_sound_header_type) -XEN_NARGIFY_2(g_mus_sound_set_header_type_w, g_mus_sound_set_header_type) -XEN_NARGIFY_1(g_mus_sound_data_format_w, g_mus_sound_data_format) -XEN_NARGIFY_2(g_mus_sound_set_data_format_w, g_mus_sound_set_data_format) -XEN_NARGIFY_1(g_mus_sound_length_w, g_mus_sound_length) -XEN_NARGIFY_1(g_mus_sound_type_specifier_w, g_mus_sound_type_specifier) -XEN_NARGIFY_1(g_mus_header_type_name_w, g_mus_header_type_name) -XEN_NARGIFY_1(g_mus_header_type_to_string_w, g_mus_header_type_to_string) -XEN_NARGIFY_1(g_mus_data_format_name_w, g_mus_data_format_name) -XEN_NARGIFY_1(g_mus_data_format_to_string_w, g_mus_data_format_to_string) -XEN_NARGIFY_1(g_mus_sound_comment_w, g_mus_sound_comment) -XEN_NARGIFY_1(g_mus_sound_write_date_w, g_mus_sound_write_date) -XEN_NARGIFY_1(g_mus_bytes_per_sample_w, g_mus_bytes_per_sample) -XEN_NARGIFY_1(g_mus_sound_loop_info_w, g_mus_sound_loop_info) -XEN_NARGIFY_1(g_mus_sound_mark_info_w, g_mus_sound_mark_info) -XEN_NARGIFY_1(g_mus_sound_maxamp_w, g_mus_sound_maxamp) -XEN_NARGIFY_2(g_mus_sound_set_maxamp_w, g_mus_sound_set_maxamp) -XEN_NARGIFY_1(g_mus_sound_maxamp_exists_w, g_mus_sound_maxamp_exists) -XEN_NARGIFY_1(g_mus_sound_open_input_w, g_mus_sound_open_input) -XEN_NARGIFY_1(g_mus_sound_close_input_w, g_mus_sound_close_input) - -XEN_NARGIFY_0(g_mus_audio_describe_w, g_mus_audio_describe) -XEN_NARGIFY_1(g_mus_audio_close_w, g_mus_audio_close) -XEN_ARGIFY_4(g_mus_audio_write_w, g_mus_audio_write) -XEN_NARGIFY_3(g_mus_audio_read_w, g_mus_audio_read) -XEN_NARGIFY_5(g_mus_audio_open_output_w, g_mus_audio_open_output) -XEN_NARGIFY_5(g_mus_audio_open_input_w, g_mus_audio_open_input) - -XEN_NARGIFY_0(g_mus_clipping_w, g_mus_clipping) -XEN_NARGIFY_1(g_mus_set_clipping_w, g_mus_set_clipping) -XEN_NARGIFY_1(g_mus_file_clipping_w, g_mus_file_clipping) -XEN_NARGIFY_2(g_mus_file_set_clipping_w, g_mus_file_set_clipping) -XEN_NARGIFY_0(g_mus_prescaler_w, g_mus_prescaler) -XEN_NARGIFY_1(g_mus_set_prescaler_w, g_mus_set_prescaler) -XEN_NARGIFY_1(g_mus_file_prescaler_w, g_mus_file_prescaler) -XEN_NARGIFY_2(g_mus_file_set_prescaler_w, g_mus_file_set_prescaler) -XEN_NARGIFY_0(g_mus_header_raw_defaults_w, g_mus_header_raw_defaults) -XEN_NARGIFY_1(g_mus_header_set_raw_defaults_w, g_mus_header_set_raw_defaults) -XEN_NARGIFY_1(g_mus_expand_filename_w, g_mus_expand_filename) -XEN_ARGIFY_6(g_mus_sound_open_output_w, g_mus_sound_open_output) -XEN_ARGIFY_5(g_mus_sound_reopen_output_w, g_mus_sound_reopen_output) -XEN_NARGIFY_2(g_mus_sound_close_output_w, g_mus_sound_close_output) -XEN_NARGIFY_5(g_mus_sound_read_w, g_mus_sound_read) -XEN_NARGIFY_5(g_mus_sound_write_w, g_mus_sound_write) -XEN_NARGIFY_2(g_mus_sound_seek_frame_w, g_mus_sound_seek_frame) -XEN_ARGIFY_1(g_mus_sound_report_cache_w, g_mus_sound_report_cache) -XEN_NARGIFY_1(g_mus_sound_forget_w, g_mus_sound_forget) -XEN_NARGIFY_0(g_mus_sound_prune_w, g_mus_sound_prune) -XEN_NARGIFY_1(g_mus_error_type_to_string_w, g_mus_error_type_to_string) -XEN_NARGIFY_2(g_mus_oss_set_buffers_w, g_mus_oss_set_buffers) -XEN_NARGIFY_5(g_array_to_file_w, g_array_to_file) -XEN_NARGIFY_5(g_file_to_array_w, g_file_to_array) -XEN_NARGIFY_0(g_mus_alsa_buffers_w, g_mus_alsa_buffers) -XEN_NARGIFY_1(g_mus_alsa_set_buffers_w, g_mus_alsa_set_buffers) -XEN_NARGIFY_0(g_mus_alsa_buffer_size_w, g_mus_alsa_buffer_size) -XEN_NARGIFY_1(g_mus_alsa_set_buffer_size_w, g_mus_alsa_set_buffer_size) -XEN_NARGIFY_0(g_mus_alsa_device_w, g_mus_alsa_device) -XEN_NARGIFY_1(g_mus_alsa_set_device_w, g_mus_alsa_set_device) -XEN_NARGIFY_0(g_mus_alsa_playback_device_w, g_mus_alsa_playback_device) -XEN_NARGIFY_1(g_mus_alsa_set_playback_device_w, g_mus_alsa_set_playback_device) -XEN_NARGIFY_0(g_mus_alsa_capture_device_w, g_mus_alsa_capture_device) -XEN_NARGIFY_1(g_mus_alsa_set_capture_device_w, g_mus_alsa_set_capture_device) -XEN_NARGIFY_0(g_mus_alsa_squelch_warning_w, g_mus_alsa_squelch_warning) -XEN_NARGIFY_1(g_mus_alsa_set_squelch_warning_w, g_mus_alsa_set_squelch_warning) - -#if HAVE_OSS - XEN_NARGIFY_0(g_mus_audio_reinitialize_w, g_mus_audio_reinitialize) -#endif - -#if MUS_MAC_OSX -XEN_NARGIFY_1(g_mus_audio_output_properties_mutable_w, g_mus_audio_output_properties_mutable) -#endif - -XEN_NARGIFY_0(g_mus_max_malloc_w, g_mus_max_malloc) -XEN_NARGIFY_1(g_mus_set_max_malloc_w, g_mus_set_max_malloc) -XEN_NARGIFY_0(g_mus_max_table_size_w, g_mus_max_table_size) -XEN_NARGIFY_1(g_mus_set_max_table_size_w, g_mus_set_max_table_size) - -#else -#define g_sound_data_length_w g_sound_data_length -#define g_sound_data_chans_w g_sound_data_chans -#define g_sound_data_copy_w g_sound_data_copy -#define g_sound_data_addB_w g_sound_data_addB -#define g_sound_data_add_w g_sound_data_add -#define g_sound_data_offsetB_w g_sound_data_offsetB -#define g_sound_data_multiplyB_w g_sound_data_multiplyB -#define g_sound_data_multiply_w g_sound_data_multiply -#define g_sound_data_ref_w g_sound_data_ref -#define g_sound_data_set_w g_sound_data_set -#define g_make_sound_data_w g_make_sound_data -#define g_sound_data_p_w g_sound_data_p -#define g_sound_data_maxamp_w g_sound_data_maxamp -#define g_sound_data_peak_w g_sound_data_peak -#define g_sound_data_scaleB_w g_sound_data_scaleB -#define g_sound_data_fillB_w g_sound_data_fillB -#define g_sound_data_reverseB_w g_sound_data_reverseB -#define g_sound_data_to_vct_w g_sound_data_to_vct -#define g_sound_data_to_sound_data_w g_sound_data_to_sound_data -#define g_vct_to_sound_data_w g_vct_to_sound_data -#define g_mus_sound_samples_w g_mus_sound_samples -#define g_mus_sound_set_samples_w g_mus_sound_set_samples -#define g_mus_sound_frames_w g_mus_sound_frames -#define g_mus_sound_duration_w g_mus_sound_duration -#define g_mus_sound_datum_size_w g_mus_sound_datum_size -#define g_mus_sound_data_location_w g_mus_sound_data_location -#define g_mus_sound_set_data_location_w g_mus_sound_set_data_location -#define g_mus_sound_chans_w g_mus_sound_chans -#define g_mus_sound_set_chans_w g_mus_sound_set_chans -#define g_mus_sound_srate_w g_mus_sound_srate -#define g_mus_sound_set_srate_w g_mus_sound_set_srate -#define g_mus_sound_header_type_w g_mus_sound_header_type -#define g_mus_sound_set_header_type_w g_mus_sound_set_header_type -#define g_mus_sound_data_format_w g_mus_sound_data_format -#define g_mus_sound_set_data_format_w g_mus_sound_set_data_format -#define g_mus_sound_length_w g_mus_sound_length -#define g_mus_sound_type_specifier_w g_mus_sound_type_specifier -#define g_mus_header_type_name_w g_mus_header_type_name -#define g_mus_data_format_name_w g_mus_data_format_name -#define g_mus_header_type_to_string_w g_mus_header_type_to_string -#define g_mus_data_format_to_string_w g_mus_data_format_to_string -#define g_mus_sound_comment_w g_mus_sound_comment -#define g_mus_sound_write_date_w g_mus_sound_write_date -#define g_mus_bytes_per_sample_w g_mus_bytes_per_sample -#define g_mus_sound_loop_info_w g_mus_sound_loop_info -#define g_mus_sound_mark_info_w g_mus_sound_mark_info -#define g_mus_sound_maxamp_w g_mus_sound_maxamp -#define g_mus_sound_set_maxamp_w g_mus_sound_set_maxamp -#define g_mus_sound_maxamp_exists_w g_mus_sound_maxamp_exists -#define g_mus_sound_open_input_w g_mus_sound_open_input -#define g_mus_sound_close_input_w g_mus_sound_close_input - -#define g_mus_audio_describe_w g_mus_audio_describe -#define g_mus_audio_close_w g_mus_audio_close -#define g_mus_audio_write_w g_mus_audio_write -#define g_mus_audio_read_w g_mus_audio_read -#define g_mus_audio_open_output_w g_mus_audio_open_output -#define g_mus_audio_open_input_w g_mus_audio_open_input - -#define g_mus_clipping_w g_mus_clipping -#define g_mus_set_clipping_w g_mus_set_clipping -#define g_mus_file_clipping_w g_mus_file_clipping -#define g_mus_file_set_clipping_w g_mus_file_set_clipping -#define g_mus_prescaler_w g_mus_prescaler -#define g_mus_set_prescaler_w g_mus_set_prescaler -#define g_mus_file_prescaler_w g_mus_file_prescaler -#define g_mus_file_set_prescaler_w g_mus_file_set_prescaler -#define g_mus_header_raw_defaults_w g_mus_header_raw_defaults -#define g_mus_header_set_raw_defaults_w g_mus_header_set_raw_defaults -#define g_mus_expand_filename_w g_mus_expand_filename -#define g_mus_sound_open_output_w g_mus_sound_open_output -#define g_mus_sound_reopen_output_w g_mus_sound_reopen_output -#define g_mus_sound_close_output_w g_mus_sound_close_output -#define g_mus_sound_read_w g_mus_sound_read -#define g_mus_sound_write_w g_mus_sound_write -#define g_mus_sound_seek_frame_w g_mus_sound_seek_frame -#define g_mus_sound_report_cache_w g_mus_sound_report_cache -#define g_mus_sound_forget_w g_mus_sound_forget -#define g_mus_sound_prune_w g_mus_sound_prune -#define g_mus_error_type_to_string_w g_mus_error_type_to_string -#define g_mus_oss_set_buffers_w g_mus_oss_set_buffers -#define g_array_to_file_w g_array_to_file -#define g_file_to_array_w g_file_to_array -#define g_mus_alsa_buffers_w g_mus_alsa_buffers -#define g_mus_alsa_set_buffers_w g_mus_alsa_set_buffers -#define g_mus_alsa_buffer_size_w g_mus_alsa_buffer_size -#define g_mus_alsa_set_buffer_size_w g_mus_alsa_set_buffer_size -#define g_mus_alsa_device_w g_mus_alsa_device -#define g_mus_alsa_set_device_w g_mus_alsa_set_device -#define g_mus_alsa_playback_device_w g_mus_alsa_playback_device -#define g_mus_alsa_set_playback_device_w g_mus_alsa_set_playback_device -#define g_mus_alsa_capture_device_w g_mus_alsa_capture_device -#define g_mus_alsa_set_capture_device_w g_mus_alsa_set_capture_device -#define g_mus_alsa_squelch_warning_w g_mus_alsa_squelch_warning -#define g_mus_alsa_set_squelch_warning_w g_mus_alsa_set_squelch_warning -#if HAVE_OSS - #define g_mus_audio_reinitialize_w g_mus_audio_reinitialize -#endif -#if MUS_MAC_OSX - #define g_mus_audio_output_properties_mutable_w g_mus_audio_output_properties_mutable +Xen_wrap_1_arg(g_mus_sound_samples_w, g_mus_sound_samples) +Xen_wrap_2_args(g_mus_sound_set_samples_w, g_mus_sound_set_samples) +Xen_wrap_1_arg(g_mus_sound_framples_w, g_mus_sound_framples) +Xen_wrap_1_arg(g_mus_sound_duration_w, g_mus_sound_duration) +Xen_wrap_1_arg(g_mus_sound_datum_size_w, g_mus_sound_datum_size) +Xen_wrap_1_arg(g_mus_sound_data_location_w, g_mus_sound_data_location) +Xen_wrap_2_args(g_mus_sound_set_data_location_w, g_mus_sound_set_data_location) +Xen_wrap_1_arg(g_mus_sound_chans_w, g_mus_sound_chans) +Xen_wrap_2_args(g_mus_sound_set_chans_w, g_mus_sound_set_chans) +Xen_wrap_1_arg(g_mus_sound_srate_w, g_mus_sound_srate) +Xen_wrap_2_args(g_mus_sound_set_srate_w, g_mus_sound_set_srate) +Xen_wrap_1_arg(g_mus_sound_header_type_w, g_mus_sound_header_type) +Xen_wrap_2_args(g_mus_sound_set_header_type_w, g_mus_sound_set_header_type) +Xen_wrap_1_arg(g_mus_sound_sample_type_w, g_mus_sound_sample_type) +Xen_wrap_2_args(g_mus_sound_set_sample_type_w, g_mus_sound_set_sample_type) +Xen_wrap_1_arg(g_mus_sound_length_w, g_mus_sound_length) +Xen_wrap_1_arg(g_mus_sound_type_specifier_w, g_mus_sound_type_specifier) +Xen_wrap_1_arg(g_mus_header_type_name_w, g_mus_header_type_name) +Xen_wrap_1_arg(g_mus_header_type_to_string_w, g_mus_header_type_to_string) +Xen_wrap_1_arg(g_mus_sample_type_name_w, g_mus_sample_type_name) +Xen_wrap_1_arg(g_mus_sample_type_to_string_w, g_mus_sample_type_to_string) +Xen_wrap_1_arg(g_mus_sound_comment_w, g_mus_sound_comment) +Xen_wrap_1_arg(g_mus_sound_write_date_w, g_mus_sound_write_date) +Xen_wrap_1_arg(g_mus_bytes_per_sample_w, g_mus_bytes_per_sample) +Xen_wrap_1_arg(g_mus_sound_loop_info_w, g_mus_sound_loop_info) +Xen_wrap_1_arg(g_mus_sound_mark_info_w, g_mus_sound_mark_info) +Xen_wrap_1_arg(g_mus_sound_maxamp_w, g_mus_sound_maxamp) +Xen_wrap_2_args(g_mus_sound_set_maxamp_w, g_mus_sound_set_maxamp) +Xen_wrap_1_arg(g_mus_sound_maxamp_exists_w, g_mus_sound_maxamp_exists) +Xen_wrap_1_arg(g_mus_sound_preload_w, g_mus_sound_preload) + +Xen_wrap_no_args(g_mus_clipping_w, g_mus_clipping) +Xen_wrap_1_arg(g_mus_set_clipping_w, g_mus_set_clipping) +Xen_wrap_1_arg(g_mus_file_clipping_w, g_mus_file_clipping) +Xen_wrap_2_args(g_mus_file_set_clipping_w, g_mus_file_set_clipping) +Xen_wrap_no_args(g_mus_header_raw_defaults_w, g_mus_header_raw_defaults) +Xen_wrap_1_arg(g_mus_header_set_raw_defaults_w, g_mus_header_set_raw_defaults) +Xen_wrap_2_args(g_mus_header_writable_w, g_mus_header_writable) +Xen_wrap_1_arg(g_mus_expand_filename_w, g_mus_expand_filename) +Xen_wrap_1_optional_arg(g_mus_sound_report_cache_w, g_mus_sound_report_cache) +Xen_wrap_1_arg(g_mus_sound_forget_w, g_mus_sound_forget) +Xen_wrap_no_args(g_mus_sound_prune_w, g_mus_sound_prune) +Xen_wrap_1_arg(g_mus_error_type_to_string_w, g_mus_error_type_to_string) +Xen_wrap_2_args(g_mus_oss_set_buffers_w, g_mus_oss_set_buffers) +Xen_wrap_5_args(g_array_to_file_w, g_array_to_file) +Xen_wrap_5_args(g_file_to_array_w, g_file_to_array) +Xen_wrap_no_args(g_mus_alsa_buffers_w, g_mus_alsa_buffers) +Xen_wrap_1_arg(g_mus_alsa_set_buffers_w, g_mus_alsa_set_buffers) +Xen_wrap_no_args(g_mus_alsa_buffer_size_w, g_mus_alsa_buffer_size) +Xen_wrap_1_arg(g_mus_alsa_set_buffer_size_w, g_mus_alsa_set_buffer_size) +Xen_wrap_no_args(g_mus_alsa_device_w, g_mus_alsa_device) +Xen_wrap_1_arg(g_mus_alsa_set_device_w, g_mus_alsa_set_device) +Xen_wrap_no_args(g_mus_alsa_playback_device_w, g_mus_alsa_playback_device) +Xen_wrap_1_arg(g_mus_alsa_set_playback_device_w, g_mus_alsa_set_playback_device) +Xen_wrap_no_args(g_mus_alsa_capture_device_w, g_mus_alsa_capture_device) +Xen_wrap_1_arg(g_mus_alsa_set_capture_device_w, g_mus_alsa_set_capture_device) +Xen_wrap_no_args(g_mus_alsa_squelch_warning_w, g_mus_alsa_squelch_warning) +Xen_wrap_1_arg(g_mus_alsa_set_squelch_warning_w, g_mus_alsa_set_squelch_warning) + +#if __APPLE__ +Xen_wrap_1_arg(g_mus_audio_output_properties_mutable_w, g_mus_audio_output_properties_mutable) #endif -#define g_mus_max_malloc_w g_mus_max_malloc -#define g_mus_set_max_malloc_w g_mus_set_max_malloc -#define g_mus_max_table_size_w g_mus_max_table_size -#define g_mus_set_max_table_size_w g_mus_set_max_table_size +Xen_wrap_no_args(g_mus_max_malloc_w, g_mus_max_malloc) +Xen_wrap_1_arg(g_mus_set_max_malloc_w, g_mus_set_max_malloc) +Xen_wrap_no_args(g_mus_max_table_size_w, g_mus_max_table_size) +Xen_wrap_1_arg(g_mus_set_max_table_size_w, g_mus_set_max_table_size) +Xen_wrap_no_args(g_mus_sound_path_w, g_mus_sound_path) +Xen_wrap_1_arg(g_mus_set_sound_path_w, g_mus_set_sound_path) +#if HAVE_SCHEME + static s7_pointer acc_mus_max_table_size(s7_scheme *sc, s7_pointer args) {return(g_mus_set_max_table_size(s7_cadr(args)));} + static s7_pointer acc_mus_max_malloc(s7_scheme *sc, s7_pointer args) {return(g_mus_set_max_malloc(s7_cadr(args)));} + static s7_pointer acc_mus_sound_path(s7_scheme *sc, s7_pointer args) {return(g_mus_set_sound_path(s7_cadr(args)));} #endif void mus_sndlib_xen_initialize(void) { - mus_sound_initialize(); - #if HAVE_SCHEME - sound_data_tag = XEN_MAKE_OBJECT_TYPE("<sound-data>", print_sound_data, free_sound_data, s7_equalp_sound_data, NULL, - sound_data_apply, s7_sound_data_set, s7_sound_data_length, s7_sound_data_copy, s7_sound_data_fill); -#else - sound_data_tag = XEN_MAKE_OBJECT_TYPE("SoundData", sizeof(sound_data)); + s7_pointer pl_is, pl_isi, pl_si, pl_ss, pl_ps, pl_psp, pl_i, pl_bii, pl_p, pl_rs, pl_bi, pl_bib, pl_b; + s7_pointer pl_l, pl_isfiii, pl_fsiiif, pl_bs, pl_ts; #endif -#if HAVE_FORTH - fth_set_object_inspect(sound_data_tag, print_sound_data); - fth_set_object_equal(sound_data_tag, equalp_sound_data); - fth_set_object_to_array(sound_data_tag, g_sound_data_to_vector); - fth_set_object_length(sound_data_tag, g_sound_data_length); - fth_set_object_free(sound_data_tag, free_sound_data); - fth_set_object_apply(sound_data_tag, XEN_PROCEDURE_CAST sound_data_apply, 2, 0, 0); -#endif + mus_sound_initialize(); + sound_path = Xen_empty_list; #if HAVE_RUBY Init_Hook(); - rb_include_module(sound_data_tag, rb_mComparable); - rb_include_module(sound_data_tag, rb_mEnumerable); - rb_define_method(sound_data_tag, "to_s", XEN_PROCEDURE_CAST print_sound_data, 0); - rb_define_method(sound_data_tag, "eql?", XEN_PROCEDURE_CAST equalp_sound_data, 1); - rb_define_method(sound_data_tag, "==", XEN_PROCEDURE_CAST equalp_sound_data, 1); - rb_define_method(sound_data_tag, "each", XEN_PROCEDURE_CAST sound_data_each, 0); - rb_define_method(sound_data_tag, "<=>", XEN_PROCEDURE_CAST sound_data_compare, 1); - rb_define_method(sound_data_tag, "[]", XEN_PROCEDURE_CAST g_sound_data_ref, 2); - rb_define_method(sound_data_tag, "[]=", XEN_PROCEDURE_CAST g_sound_data_set, 3); - rb_define_method(sound_data_tag, "length", XEN_PROCEDURE_CAST sound_data_size, 0); - rb_define_method(sound_data_tag, "size", XEN_PROCEDURE_CAST sound_data_size, 0); - rb_define_method(sound_data_tag, "fill", XEN_PROCEDURE_CAST g_rb_sound_data_fill, 1); - rb_define_method(sound_data_tag, "dup", XEN_PROCEDURE_CAST g_sound_data_copy, 0); - rb_define_method(sound_data_tag, "chans", XEN_PROCEDURE_CAST sound_data_chans, 0); - rb_define_method(sound_data_tag, "peak", XEN_PROCEDURE_CAST g_sound_data_peak, 0); - rb_define_method(sound_data_tag, "offset!", XEN_PROCEDURE_CAST g_sound_data_offsetB, 1); - rb_define_method(sound_data_tag, "multiply!", XEN_PROCEDURE_CAST g_sound_data_multiplyB, 1); - - rb_define_method(sound_data_tag, "add!", XEN_PROCEDURE_CAST g_sound_data_addB, 1); - rb_define_method(sound_data_tag, "scale!", XEN_PROCEDURE_CAST g_sound_data_scaleB, 1); - rb_define_method(sound_data_tag, "reverse!", XEN_PROCEDURE_CAST g_sound_data_reverseB, 0); - - rb_define_singleton_method(sound_data_tag, "new", XEN_PROCEDURE_CAST g_rb_make_sound_data, 2); #endif - XEN_DEFINE_CONSTANT(S_mus_out_format, MUS_OUT_FORMAT, "sample format for fastest IO"); - XEN_DEFINE_CONSTANT(S_mus_unsupported, MUS_UNSUPPORTED, "unsupported header id"); - XEN_DEFINE_CONSTANT(S_mus_next, MUS_NEXT, "NeXT (Sun) sound header id"); - XEN_DEFINE_CONSTANT(S_mus_aifc, MUS_AIFC, "AIFC sound header id"); - XEN_DEFINE_CONSTANT(S_mus_rf64, MUS_RF64, "RF64 sound header id"); - XEN_DEFINE_CONSTANT(S_mus_riff, MUS_RIFF, "RIFF (MS wave) sound header id"); - XEN_DEFINE_CONSTANT(S_mus_nist, MUS_NIST, "NIST (Sphere) sound header id"); - XEN_DEFINE_CONSTANT(S_mus_raw, MUS_RAW, "raw (headerless) sound header id"); - XEN_DEFINE_CONSTANT(S_mus_ircam, MUS_IRCAM, "IRCAM sound header id"); - XEN_DEFINE_CONSTANT(S_mus_aiff, MUS_AIFF, "AIFF (old-style) sound header id"); - XEN_DEFINE_CONSTANT(S_mus_bicsf, MUS_BICSF, "BICSF header id"); - XEN_DEFINE_CONSTANT(S_mus_voc, MUS_VOC, "VOC header id"); - XEN_DEFINE_CONSTANT(S_mus_svx, MUS_SVX, "SVX (IFF) header id"); - XEN_DEFINE_CONSTANT(S_mus_soundfont, MUS_SOUNDFONT, "soundfont header id"); - XEN_DEFINE_CONSTANT(S_mus_caff, MUS_CAFF, "Apple Core Audio File Format header id"); - - XEN_DEFINE_CONSTANT(S_mus_unknown, MUS_UNKNOWN, "unknown data format"); - XEN_DEFINE_CONSTANT(S_mus_bshort, MUS_BSHORT, "big-endian short data format id"); - XEN_DEFINE_CONSTANT(S_mus_lshort, MUS_LSHORT, "little-endian short data format id"); - XEN_DEFINE_CONSTANT(S_mus_mulaw, MUS_MULAW, "mulaw (8-bit) data format id"); - XEN_DEFINE_CONSTANT(S_mus_alaw, MUS_ALAW, "alaw (8-bit) data format id"); - XEN_DEFINE_CONSTANT(S_mus_byte, MUS_BYTE, "signed byte data format id"); - XEN_DEFINE_CONSTANT(S_mus_ubyte, MUS_UBYTE, "unsigned byte data format id"); - XEN_DEFINE_CONSTANT(S_mus_bfloat, MUS_BFLOAT, "big-endian float data format id"); - XEN_DEFINE_CONSTANT(S_mus_lfloat, MUS_LFLOAT, "little-endian float data format id"); - XEN_DEFINE_CONSTANT(S_mus_bint, MUS_BINT, "big-endian int data format id"); - XEN_DEFINE_CONSTANT(S_mus_lint, MUS_LINT, "little-endian int data format id"); - XEN_DEFINE_CONSTANT(S_mus_bintn, MUS_BINTN, "normalized big-endian int data format id"); - XEN_DEFINE_CONSTANT(S_mus_lintn, MUS_LINTN, "normalized little-endian int data format id"); - XEN_DEFINE_CONSTANT(S_mus_b24int, MUS_B24INT, "big-endian 24-bit data format id"); - XEN_DEFINE_CONSTANT(S_mus_l24int, MUS_L24INT, "little-endian 24-bit data format id"); - XEN_DEFINE_CONSTANT(S_mus_bdouble, MUS_BDOUBLE, "big-endian double data format id"); - XEN_DEFINE_CONSTANT(S_mus_ldouble, MUS_LDOUBLE, "little-endian double data format id"); - XEN_DEFINE_CONSTANT(S_mus_ubshort, MUS_UBSHORT, "unsigned big-endian short data format id"); - XEN_DEFINE_CONSTANT(S_mus_ulshort, MUS_ULSHORT, "unsigned little-endian short data format id"); - XEN_DEFINE_CONSTANT(S_mus_bdouble_unscaled, MUS_BDOUBLE_UNSCALED, "unscaled big-endian double data format id"); - XEN_DEFINE_CONSTANT(S_mus_ldouble_unscaled, MUS_LDOUBLE_UNSCALED, "unscaled little-endian double data format id"); - XEN_DEFINE_CONSTANT(S_mus_bfloat_unscaled, MUS_BFLOAT_UNSCALED, "unscaled big-endian float data format id"); - XEN_DEFINE_CONSTANT(S_mus_lfloat_unscaled, MUS_LFLOAT_UNSCALED, "unscaled little-endian float data format id"); - - XEN_DEFINE_CONSTANT(S_mus_audio_default, MUS_AUDIO_DEFAULT, "default audio device"); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_sound_samples, g_mus_sound_samples_w, H_mus_sound_samples, - S_setB S_mus_sound_samples, g_mus_sound_set_samples_w, 1, 0, 2, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_sound_data_location, g_mus_sound_data_location_w, H_mus_sound_data_location, - S_setB S_mus_sound_data_location, g_mus_sound_set_data_location_w, 1, 0, 2, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_sound_chans, g_mus_sound_chans_w, H_mus_sound_chans, - S_setB S_mus_sound_chans, g_mus_sound_set_chans_w, 1, 0, 2, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_sound_srate, g_mus_sound_srate_w, H_mus_sound_srate, - S_setB S_mus_sound_srate, g_mus_sound_set_srate_w, 1, 0, 2, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_sound_header_type, g_mus_sound_header_type_w, H_mus_sound_header_type, - S_setB S_mus_sound_header_type, g_mus_sound_set_header_type_w, 1, 0, 2, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_sound_data_format, g_mus_sound_data_format_w, H_mus_sound_data_format, - S_setB S_mus_sound_data_format, g_mus_sound_set_data_format_w, 1, 0, 2, 0); - - XEN_DEFINE_PROCEDURE(S_sound_data_length, g_sound_data_length_w, 1, 0, 0, H_sound_data_length); - XEN_DEFINE_PROCEDURE(S_sound_data_chans, g_sound_data_chans_w, 1, 0, 0, H_sound_data_chans); - XEN_DEFINE_PROCEDURE(S_sound_data_copy, g_sound_data_copy_w, 1, 0, 0, H_sound_data_copy); - XEN_DEFINE_PROCEDURE(S_sound_data_addB, g_sound_data_addB_w, 2, 0, 0, H_sound_data_addB); - XEN_DEFINE_PROCEDURE(S_sound_data_add, g_sound_data_add_w, 2, 0, 0, H_sound_data_add); - XEN_DEFINE_PROCEDURE(S_sound_data_offsetB, g_sound_data_offsetB_w, 2, 0, 0, H_sound_data_offsetB); - XEN_DEFINE_PROCEDURE(S_sound_data_multiplyB, g_sound_data_multiplyB_w, 2, 0, 0, H_sound_data_multiplyB); - XEN_DEFINE_PROCEDURE(S_sound_data_multiply, g_sound_data_multiply_w, 2, 0, 0, H_sound_data_multiply); - XEN_DEFINE_PROCEDURE(S_make_sound_data, g_make_sound_data_w, 2, 0, 0, H_make_sound_data); - XEN_DEFINE_PROCEDURE(S_sound_data_p, g_sound_data_p_w, 1, 0, 0, H_sound_data_p); - XEN_DEFINE_PROCEDURE(S_sound_data_maxamp, g_sound_data_maxamp_w, 1, 0, 0, H_sound_data_maxamp); - XEN_DEFINE_PROCEDURE(S_sound_data_peak, g_sound_data_peak_w, 1, 0, 0, H_sound_data_peak); - XEN_DEFINE_PROCEDURE(S_sound_data_setB, g_sound_data_set_w, 4, 0, 0, H_sound_data_setB); - XEN_DEFINE_PROCEDURE(S_sound_data_scaleB, g_sound_data_scaleB_w, 2, 0, 0, H_sound_data_scaleB); - XEN_DEFINE_PROCEDURE(S_sound_data_fillB, g_sound_data_fillB_w, 2, 0, 0, H_sound_data_fillB); - XEN_DEFINE_PROCEDURE(S_sound_data_reverseB, g_sound_data_reverseB_w, 1, 0, 0, H_sound_data_reverseB); - XEN_DEFINE_PROCEDURE(S_sound_data_to_vct, g_sound_data_to_vct_w, 1, 2, 0, H_sound_data_to_vct); - XEN_DEFINE_PROCEDURE(S_sound_data_to_sound_data, g_sound_data_to_sound_data_w, 5, 0, 0, H_sound_data_to_sound_data); - XEN_DEFINE_PROCEDURE(S_vct_to_sound_data, g_vct_to_sound_data_w, 1, 2, 0, H_vct_to_sound_data); - - XEN_DEFINE_PROCEDURE(S_mus_sound_frames, g_mus_sound_frames_w, 1, 0, 0, H_mus_sound_frames); - XEN_DEFINE_PROCEDURE(S_mus_sound_duration, g_mus_sound_duration_w, 1, 0, 0, H_mus_sound_duration); - XEN_DEFINE_PROCEDURE(S_mus_sound_datum_size, g_mus_sound_datum_size_w, 1, 0, 0, H_mus_sound_datum_size); - XEN_DEFINE_PROCEDURE(S_mus_sound_length, g_mus_sound_length_w, 1, 0, 0, H_mus_sound_length); - XEN_DEFINE_PROCEDURE(S_mus_sound_type_specifier, g_mus_sound_type_specifier_w, 1, 0, 0, H_mus_sound_type_specifier); - XEN_DEFINE_PROCEDURE(S_mus_header_type_name, g_mus_header_type_name_w, 1, 0, 0, H_mus_header_type_name); - XEN_DEFINE_PROCEDURE(S_mus_header_type_to_string,g_mus_header_type_to_string_w, 1, 0, 0, H_mus_header_type_to_string); - XEN_DEFINE_PROCEDURE(S_mus_data_format_name, g_mus_data_format_name_w, 1, 0, 0, H_mus_data_format_name); - XEN_DEFINE_PROCEDURE(S_mus_data_format_to_string,g_mus_data_format_to_string_w, 1, 0, 0, H_mus_data_format_to_string); - XEN_DEFINE_PROCEDURE(S_mus_sound_comment, g_mus_sound_comment_w, 1, 0, 0, H_mus_sound_comment); - XEN_DEFINE_PROCEDURE(S_mus_sound_write_date, g_mus_sound_write_date_w, 1, 0, 0, H_mus_sound_write_date); - XEN_DEFINE_PROCEDURE(S_mus_bytes_per_sample, g_mus_bytes_per_sample_w, 1, 0, 0, H_mus_bytes_per_sample); - XEN_DEFINE_PROCEDURE(S_mus_sound_loop_info, g_mus_sound_loop_info_w, 1, 0, 0, H_mus_sound_loop_info); - XEN_DEFINE_PROCEDURE(S_mus_sound_mark_info, g_mus_sound_mark_info_w, 1, 0, 0, H_mus_sound_mark_info); - XEN_DEFINE_PROCEDURE(S_mus_sound_maxamp_exists, g_mus_sound_maxamp_exists_w, 1, 0, 0, H_mus_sound_maxamp_exists); - XEN_DEFINE_PROCEDURE(S_mus_sound_forget, g_mus_sound_forget_w, 1, 0, 0, H_mus_sound_forget); - XEN_DEFINE_PROCEDURE(S_mus_sound_prune, g_mus_sound_prune_w, 0, 0, 0, H_mus_sound_prune); - XEN_DEFINE_PROCEDURE(S_mus_sound_open_input, g_mus_sound_open_input_w, 1, 0, 0, H_mus_sound_open_input); - XEN_DEFINE_PROCEDURE(S_mus_sound_close_input, g_mus_sound_close_input_w, 1, 0, 0, H_mus_sound_close_input); - - XEN_DEFINE_PROCEDURE(S_mus_audio_describe, g_mus_audio_describe_w, 0, 0, 0, H_mus_audio_describe); - XEN_DEFINE_PROCEDURE(S_mus_audio_close, g_mus_audio_close_w, 1, 0, 0, H_mus_audio_close); - XEN_DEFINE_PROCEDURE(S_mus_audio_write, g_mus_audio_write_w, 3, 1, 0, H_mus_audio_write); - XEN_DEFINE_PROCEDURE(S_mus_audio_read, g_mus_audio_read_w, 3, 0, 0, H_mus_audio_read); - XEN_DEFINE_PROCEDURE(S_mus_audio_open_output, g_mus_audio_open_output_w, 5, 0, 0, H_mus_audio_open_output); - XEN_DEFINE_PROCEDURE(S_mus_audio_open_input, g_mus_audio_open_input_w, 5, 0, 0, H_mus_audio_open_input); - - XEN_DEFINE_PROCEDURE(S_mus_expand_filename, g_mus_expand_filename_w, 1, 0, 0, H_mus_expand_filename); - XEN_DEFINE_PROCEDURE(S_mus_sound_open_output, g_mus_sound_open_output_w, 1, 5, 0, H_mus_sound_open_output); - XEN_DEFINE_PROCEDURE(S_mus_sound_reopen_output, g_mus_sound_reopen_output_w, 1, 4, 0, H_mus_sound_reopen_output); - XEN_DEFINE_PROCEDURE(S_mus_sound_close_output, g_mus_sound_close_output_w, 2, 0, 0, H_mus_sound_close_output); - XEN_DEFINE_PROCEDURE(S_mus_sound_read, g_mus_sound_read_w, 5, 0, 0, H_mus_sound_read); - XEN_DEFINE_PROCEDURE(S_mus_sound_write, g_mus_sound_write_w, 5, 0, 0, H_mus_sound_write); - XEN_DEFINE_PROCEDURE(S_mus_sound_seek_frame, g_mus_sound_seek_frame_w, 2, 0, 0, H_mus_sound_seek_frame); - XEN_DEFINE_PROCEDURE(S_mus_sound_report_cache, g_mus_sound_report_cache_w, 0, 1, 0, H_mus_sound_report_cache); - XEN_DEFINE_PROCEDURE(S_mus_error_type_to_string, g_mus_error_type_to_string_w, 1, 0, 0, H_mus_error_type_to_string); - XEN_DEFINE_PROCEDURE(S_mus_oss_set_buffers, g_mus_oss_set_buffers_w, 2, 0, 0, H_mus_oss_set_buffers); - XEN_DEFINE_PROCEDURE(S_array_to_file, g_array_to_file_w, 5, 0, 0, H_array_to_file); - XEN_DEFINE_PROCEDURE(S_file_to_array, g_file_to_array_w, 5, 0, 0, H_file_to_array); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_header_raw_defaults, g_mus_header_raw_defaults_w, H_mus_header_raw_defaults, - S_setB S_mus_header_raw_defaults, g_mus_header_set_raw_defaults_w, 0, 0, 1, 0); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_prescaler, g_mus_prescaler_w, H_mus_prescaler, - S_setB S_mus_prescaler, g_mus_set_prescaler_w, 0, 0, 1, 0); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_file_prescaler, g_mus_file_prescaler_w, H_mus_file_prescaler, - S_setB S_mus_file_prescaler, g_mus_file_set_prescaler_w, 1, 0, 2, 0); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_clipping, g_mus_clipping_w, H_mus_clipping, - S_setB S_mus_clipping, g_mus_set_clipping_w, 0, 0, 1, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_file_clipping, g_mus_file_clipping_w, H_mus_file_clipping, - S_setB S_mus_file_clipping, g_mus_file_set_clipping_w, 1, 0, 2, 0); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_sound_data_ref, g_sound_data_ref_w, H_sound_data_ref, - S_setB S_sound_data_ref, g_sound_data_set_w, 3, 0, 4, 0); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_sound_maxamp, g_mus_sound_maxamp_w, H_mus_sound_maxamp, - S_setB S_mus_sound_maxamp, g_mus_sound_set_maxamp_w, 1, 0, 2, 0); + Xen_define_constant(S_mus_out_format, MUS_OUT_SAMPLE_TYPE, "sample type for fastest IO"); + Xen_define_constant(S_mus_unknown_header, MUS_UNKNOWN_HEADER, "unknown header type"); + Xen_define_constant(S_mus_next, MUS_NEXT, "NeXT (Sun) sound header id"); + Xen_define_constant(S_mus_aifc, MUS_AIFC, "AIFC sound header id"); + Xen_define_constant(S_mus_rf64, MUS_RF64, "RF64 sound header id"); + Xen_define_constant(S_mus_riff, MUS_RIFF, "RIFF (MS wave) sound header id"); + Xen_define_constant(S_mus_nist, MUS_NIST, "NIST (Sphere) sound header id"); + Xen_define_constant(S_mus_raw, MUS_RAW, "raw (headerless) sound header id"); + Xen_define_constant(S_mus_ircam, MUS_IRCAM, "IRCAM sound header id"); + Xen_define_constant(S_mus_aiff, MUS_AIFF, "AIFF (old-style) sound header id"); + Xen_define_constant(S_mus_bicsf, MUS_BICSF, "BICSF header id"); + Xen_define_constant(S_mus_voc, MUS_VOC, "VOC header id"); + Xen_define_constant(S_mus_svx, MUS_SVX, "SVX (IFF) header id"); + Xen_define_constant(S_mus_soundfont, MUS_SOUNDFONT, "soundfont header id"); + Xen_define_constant(S_mus_caff, MUS_CAFF, "Apple Core Audio File Format header id"); + + Xen_define_constant(S_mus_unknown_sample, MUS_UNKNOWN_SAMPLE, "unknown sample type"); + Xen_define_constant(S_mus_bshort, MUS_BSHORT, "big-endian short sample type id"); + Xen_define_constant(S_mus_lshort, MUS_LSHORT, "little-endian short sample type id"); + Xen_define_constant(S_mus_mulaw, MUS_MULAW, "mulaw (8-bit) sample type id"); + Xen_define_constant(S_mus_alaw, MUS_ALAW, "alaw (8-bit) sample type id"); + Xen_define_constant(S_mus_byte, MUS_BYTE, "signed byte sample type id"); + Xen_define_constant(S_mus_ubyte, MUS_UBYTE, "unsigned byte sample type id"); + Xen_define_constant(S_mus_bfloat, MUS_BFLOAT, "big-endian float sample type id"); + Xen_define_constant(S_mus_lfloat, MUS_LFLOAT, "little-endian float sample type id"); + Xen_define_constant(S_mus_bint, MUS_BINT, "big-endian int sample type id"); + Xen_define_constant(S_mus_lint, MUS_LINT, "little-endian int sample type id"); + Xen_define_constant(S_mus_bintn, MUS_BINTN, "normalized big-endian int sample type id"); + Xen_define_constant(S_mus_lintn, MUS_LINTN, "normalized little-endian int sample type id"); + Xen_define_constant(S_mus_b24int, MUS_B24INT, "big-endian 24-bit sample type id"); + Xen_define_constant(S_mus_l24int, MUS_L24INT, "little-endian 24-bit sample type id"); + Xen_define_constant(S_mus_bdouble, MUS_BDOUBLE, "big-endian double sample type id"); + Xen_define_constant(S_mus_ldouble, MUS_LDOUBLE, "little-endian double sample type id"); + Xen_define_constant(S_mus_ubshort, MUS_UBSHORT, "unsigned big-endian short sample type id"); + Xen_define_constant(S_mus_ulshort, MUS_ULSHORT, "unsigned little-endian short sample type id"); + Xen_define_constant(S_mus_bdouble_unscaled, MUS_BDOUBLE_UNSCALED, "unscaled big-endian double sample type id"); + Xen_define_constant(S_mus_ldouble_unscaled, MUS_LDOUBLE_UNSCALED, "unscaled little-endian double sample type id"); + Xen_define_constant(S_mus_bfloat_unscaled, MUS_BFLOAT_UNSCALED, "unscaled big-endian float sample type id"); + Xen_define_constant(S_mus_lfloat_unscaled, MUS_LFLOAT_UNSCALED, "unscaled little-endian float sample type id"); - /* these are no-ops if not ALSA, but that makes it easier to maintain global initialization files */ - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_alsa_buffers, g_mus_alsa_buffers_w, H_mus_alsa_buffers, - S_setB S_mus_alsa_buffers, g_mus_alsa_set_buffers_w, 0, 0, 1, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_alsa_buffer_size, g_mus_alsa_buffer_size_w, H_mus_alsa_buffer_size, - S_setB S_mus_alsa_buffer_size, g_mus_alsa_set_buffer_size_w, 0, 0, 1, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_alsa_device, g_mus_alsa_device_w, H_mus_alsa_device, - S_setB S_mus_alsa_device, g_mus_alsa_set_device_w, 0, 0, 1, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_alsa_playback_device, g_mus_alsa_playback_device_w, H_mus_alsa_playback_device, - S_setB S_mus_alsa_playback_device, g_mus_alsa_set_playback_device_w, 0, 0, 1, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_alsa_capture_device, g_mus_alsa_capture_device_w, H_mus_alsa_capture_device, - S_setB S_mus_alsa_capture_device, g_mus_alsa_set_capture_device_w, 0, 0, 1, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_alsa_squelch_warning, g_mus_alsa_squelch_warning_w, H_mus_alsa_squelch_warning, - S_setB S_mus_alsa_squelch_warning, g_mus_alsa_set_squelch_warning_w, 0, 0, 1, 0); - - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_max_malloc, g_mus_max_malloc_w, H_mus_max_malloc, - S_setB S_mus_max_malloc, g_mus_set_max_malloc_w, 0, 0, 1, 0); - XEN_DEFINE_PROCEDURE_WITH_SETTER(S_mus_max_table_size, g_mus_max_table_size_w, H_mus_max_table_size, - S_setB S_mus_max_table_size, g_mus_set_max_table_size_w, 0, 0, 1, 0); - -#if HAVE_OSS - XEN_DEFINE_PROCEDURE(S_mus_audio_reinitialize, g_mus_audio_reinitialize_w, 0, 0, 0, H_mus_audio_reinitialize); +#if HAVE_SCHEME + { + s7_pointer s, i, p, b, r, f, t, l; + s = s7_make_symbol(s7, "string?"); + i = s7_make_symbol(s7, "integer?"); + p = s7_make_symbol(s7, "pair?"); + l = s7_make_symbol(s7, "list?"); + b = s7_make_symbol(s7, "boolean?"); + r = s7_make_symbol(s7, "real?"); + f = s7_make_symbol(s7, "float-vector?"); + t = s7_t(s7); + pl_is = s7_make_signature(s7, 2, i, s); + pl_isi = s7_make_signature(s7, 3, i, s, i); + pl_si = s7_make_signature(s7, 2, s, i); + pl_ss = s7_make_signature(s7, 2, s, s); + pl_ts = s7_make_signature(s7, 2, t, s); + pl_ps = s7_make_signature(s7, 2, p, s); + pl_psp = s7_make_signature(s7, 3, p, s, p); + pl_i = s7_make_circular_signature(s7, 0, 1, i); + pl_bii = s7_make_signature(s7, 3, b, i, i); + pl_p = s7_make_circular_signature(s7, 0, 1, p); + pl_l = s7_make_circular_signature(s7, 0, 1, l); + pl_rs = s7_make_signature(s7, 2, r, s); + pl_bi = s7_make_signature(s7, 2, b, i); + pl_bib = s7_make_signature(s7, 3, b, i, b); + pl_b = s7_make_circular_signature(s7, 0, 1, b); + pl_bs = s7_make_signature(s7, 2, b, s); + pl_isfiii = s7_make_signature(s7, 6, i, s, f, i, i, i); + pl_fsiiif = s7_make_signature(s7, 6, f, s, i, i, i, f); + } #endif -#if HAVE_FORTH - XEN_DEFINE_PROCEDURE(S_sound_data_to_vector, g_sound_data_to_vector /* no _w! */, 1, 0, 0, H_sound_data_to_vector); -#endif + Xen_define_typed_dilambda(S_mus_sound_samples, g_mus_sound_samples_w, H_mus_sound_samples, + S_set S_mus_sound_samples, g_mus_sound_set_samples_w, 1, 0, 2, 0, pl_is, pl_isi); + Xen_define_typed_dilambda(S_mus_sound_data_location, g_mus_sound_data_location_w, H_mus_sound_data_location, + S_set S_mus_sound_data_location, g_mus_sound_set_data_location_w, 1, 0, 2, 0, pl_is, pl_isi); + Xen_define_typed_dilambda(S_mus_sound_chans, g_mus_sound_chans_w, H_mus_sound_chans, + S_set S_mus_sound_chans, g_mus_sound_set_chans_w, 1, 0, 2, 0, pl_is, pl_isi); + Xen_define_typed_dilambda(S_mus_sound_srate, g_mus_sound_srate_w, H_mus_sound_srate, + S_set S_mus_sound_srate, g_mus_sound_set_srate_w, 1, 0, 2, 0, pl_is, pl_isi); + Xen_define_typed_dilambda(S_mus_sound_header_type, g_mus_sound_header_type_w, H_mus_sound_header_type, + S_set S_mus_sound_header_type, g_mus_sound_set_header_type_w, 1, 0, 2, 0, pl_is, pl_isi); + Xen_define_typed_dilambda(S_mus_sound_sample_type, g_mus_sound_sample_type_w, H_mus_sound_sample_type, + S_set S_mus_sound_sample_type, g_mus_sound_set_sample_type_w, 1, 0, 2, 0, pl_is, pl_isi); + + Xen_define_typed_procedure(S_mus_sound_framples, g_mus_sound_framples_w, 1, 0, 0, H_mus_sound_framples, pl_is); + Xen_define_typed_procedure("mus-sound-frames", g_mus_sound_framples_w, 1, 0, 0, H_mus_sound_framples, pl_is); + Xen_define_typed_procedure(S_mus_sound_duration, g_mus_sound_duration_w, 1, 0, 0, H_mus_sound_duration, pl_rs); + Xen_define_typed_procedure(S_mus_sound_datum_size, g_mus_sound_datum_size_w, 1, 0, 0, H_mus_sound_datum_size, pl_is); + Xen_define_typed_procedure(S_mus_sound_length, g_mus_sound_length_w, 1, 0, 0, H_mus_sound_length, pl_is); + Xen_define_typed_procedure(S_mus_sound_type_specifier, g_mus_sound_type_specifier_w, 1, 0, 0, H_mus_sound_type_specifier, pl_is); + Xen_define_typed_procedure(S_mus_header_type_name, g_mus_header_type_name_w, 1, 0, 0, H_mus_header_type_name, pl_si); + Xen_define_typed_procedure(S_mus_header_type_to_string,g_mus_header_type_to_string_w, 1, 0, 0, H_mus_header_type_to_string, pl_si); + Xen_define_typed_procedure(S_mus_header_writable, g_mus_header_writable_w, 2, 0, 0, H_mus_header_writable, pl_bii); + Xen_define_typed_procedure(S_mus_sample_type_name, g_mus_sample_type_name_w, 1, 0, 0, H_mus_sample_type_name, pl_si); + Xen_define_typed_procedure(S_mus_sample_type_to_string,g_mus_sample_type_to_string_w, 1, 0, 0, H_mus_sample_type_to_string, pl_si); + Xen_define_typed_procedure(S_mus_sound_comment, g_mus_sound_comment_w, 1, 0, 0, H_mus_sound_comment, pl_ts); + Xen_define_typed_procedure(S_mus_sound_write_date, g_mus_sound_write_date_w, 1, 0, 0, H_mus_sound_write_date, pl_is); + Xen_define_typed_procedure(S_mus_bytes_per_sample, g_mus_bytes_per_sample_w, 1, 0, 0, H_mus_bytes_per_sample, pl_i); + Xen_define_typed_procedure(S_mus_sound_loop_info, g_mus_sound_loop_info_w, 1, 0, 0, H_mus_sound_loop_info, pl_ps); + Xen_define_typed_procedure(S_mus_sound_mark_info, g_mus_sound_mark_info_w, 1, 0, 0, H_mus_sound_mark_info, pl_ps); + Xen_define_typed_procedure(S_mus_sound_maxamp_exists, g_mus_sound_maxamp_exists_w, 1, 0, 0, H_mus_sound_maxamp_exists, pl_bs); + Xen_define_typed_procedure(S_mus_sound_forget, g_mus_sound_forget_w, 1, 0, 0, H_mus_sound_forget, pl_is); + Xen_define_typed_procedure(S_mus_sound_prune, g_mus_sound_prune_w, 0, 0, 0, H_mus_sound_prune, pl_i); + + Xen_define_typed_procedure(S_mus_expand_filename, g_mus_expand_filename_w, 1, 0, 0, H_mus_expand_filename, pl_ss); + Xen_define_typed_procedure(S_mus_sound_report_cache, g_mus_sound_report_cache_w, 0, 1, 0, H_mus_sound_report_cache, NULL); + Xen_define_typed_procedure(S_mus_error_type_to_string, g_mus_error_type_to_string_w, 1, 0, 0, H_mus_error_type_to_string, pl_si); + Xen_define_typed_procedure(S_mus_oss_set_buffers, g_mus_oss_set_buffers_w, 2, 0, 0, H_mus_oss_set_buffers, pl_bii); + Xen_define_typed_procedure(S_array_to_file, g_array_to_file_w, 5, 0, 0, H_array_to_file, pl_isfiii); + Xen_define_typed_procedure(S_file_to_array, g_file_to_array_w, 5, 0, 0, H_file_to_array, pl_fsiiif); + + Xen_define_typed_procedure(S_mus_sound_preload, g_mus_sound_preload_w, 1, 0, 0, H_mus_sound_preload, pl_ss); + + Xen_define_typed_dilambda(S_mus_header_raw_defaults, g_mus_header_raw_defaults_w, H_mus_header_raw_defaults, + S_set S_mus_header_raw_defaults, g_mus_header_set_raw_defaults_w, 0, 0, 1, 0, pl_p, pl_p); + + Xen_define_typed_dilambda(S_mus_clipping, g_mus_clipping_w, H_mus_clipping, + S_set S_mus_clipping, g_mus_set_clipping_w, 0, 0, 1, 0, pl_b, pl_b); + Xen_define_typed_dilambda(S_mus_file_clipping, g_mus_file_clipping_w, H_mus_file_clipping, + S_set S_mus_file_clipping, g_mus_file_set_clipping_w, 1, 0, 2, 0, pl_bi, pl_bib); + Xen_define_typed_dilambda(S_mus_sound_maxamp, g_mus_sound_maxamp_w, H_mus_sound_maxamp, + S_set S_mus_sound_maxamp, g_mus_sound_set_maxamp_w, 1, 0, 2, 0, pl_ps, pl_psp); + + /* these are no-ops if not ALSA, but that makes it easier to maintain global initialization files */ + Xen_define_typed_dilambda(S_mus_alsa_buffers, g_mus_alsa_buffers_w, H_mus_alsa_buffers, S_set + S_mus_alsa_buffers, g_mus_alsa_set_buffers_w, 0, 0, 1, 0, NULL, NULL); + Xen_define_typed_dilambda(S_mus_alsa_buffer_size, g_mus_alsa_buffer_size_w, H_mus_alsa_buffer_size, + S_set S_mus_alsa_buffer_size, g_mus_alsa_set_buffer_size_w, 0, 0, 1, 0, NULL, NULL); + Xen_define_typed_dilambda(S_mus_alsa_device, g_mus_alsa_device_w, H_mus_alsa_device, + S_set S_mus_alsa_device, g_mus_alsa_set_device_w, 0, 0, 1, 0, NULL, NULL); + Xen_define_typed_dilambda(S_mus_alsa_playback_device, g_mus_alsa_playback_device_w, H_mus_alsa_playback_device, + S_set S_mus_alsa_playback_device, g_mus_alsa_set_playback_device_w, 0, 0, 1, 0, NULL, NULL); + Xen_define_typed_dilambda(S_mus_alsa_capture_device, g_mus_alsa_capture_device_w, H_mus_alsa_capture_device, + S_set S_mus_alsa_capture_device, g_mus_alsa_set_capture_device_w, 0, 0, 1, 0, NULL, NULL); + Xen_define_typed_dilambda(S_mus_alsa_squelch_warning, g_mus_alsa_squelch_warning_w, H_mus_alsa_squelch_warning, + S_set S_mus_alsa_squelch_warning, g_mus_alsa_set_squelch_warning_w, 0, 0, 1, 0, NULL, NULL); + + Xen_define_typed_dilambda(S_mus_max_malloc, g_mus_max_malloc_w, H_mus_max_malloc, + S_set S_mus_max_malloc, g_mus_set_max_malloc_w, 0, 0, 1, 0, pl_i, pl_i); + Xen_define_typed_dilambda(S_mus_max_table_size, g_mus_max_table_size_w, H_mus_max_table_size, + S_set S_mus_max_table_size, g_mus_set_max_table_size_w, 0, 0, 1, 0, pl_i, pl_i); + Xen_define_typed_dilambda(S_mus_sound_path, g_mus_sound_path_w, H_mus_sound_path, + S_set S_mus_sound_path, g_mus_set_sound_path_w, 0, 0, 1, 0, pl_l, pl_l); -#if MUS_MAC_OSX - XEN_DEFINE_PROCEDURE(S_mus_audio_output_properties_mutable, g_mus_audio_output_properties_mutable_w, 1, 0, 0, H_mus_audio_output_properties_mutable); +#if HAVE_SCHEME + mus_max_table_size_symbol = s7_define_variable(s7, "*" S_mus_max_table_size "*", s7_make_integer(s7, MUS_MAX_TABLE_SIZE_DEFAULT)); + s7_symbol_set_documentation(s7, mus_max_table_size_symbol, "*mus-max-table-size*: maximum table size."); + s7_symbol_set_access(s7, mus_max_table_size_symbol, s7_make_function(s7, "[acc-mus-max-table-size]" "]", acc_mus_max_table_size, 2, 0, false, "accessor")); + + mus_max_malloc_symbol = s7_define_variable(s7, "*" S_mus_max_malloc "*", s7_make_integer(s7, MUS_MAX_MALLOC_DEFAULT)); + s7_symbol_set_documentation(s7, mus_max_malloc_symbol, "*mus-max-malloc*: maximum number of bytes we will try to malloc."); + s7_symbol_set_access(s7, mus_max_malloc_symbol, s7_make_function(s7, "[acc-mus-max-malloc]" "]", acc_mus_max_malloc, 2, 0, false, "accessor")); + + mus_sound_path_symbol = s7_define_variable(s7, "*" S_mus_sound_path "*", s7_nil(s7)); + s7_symbol_set_documentation(s7, mus_sound_path_symbol, "*" S_mus_sound_path "* is a list of directories to search for sound files"); + s7_symbol_set_access(s7, mus_sound_path_symbol, s7_make_function(s7, "[acc-mus-sound-path]" "]", acc_mus_sound_path, 2, 0, false, "accessor")); #endif +#if __APPLE__ + Xen_define_procedure(S_mus_audio_output_properties_mutable, g_mus_audio_output_properties_mutable_w, 1, 0, 0, H_mus_audio_output_properties_mutable); +#endif - #define H_new_sound_hook S_new_sound_hook "(filename): called when a new sound file is being created" - new_sound_hook = XEN_DEFINE_HOOK(S_new_sound_hook, 1, H_new_sound_hook); /* arg = filename */ + #define H_new_sound_hook S_new_sound_hook "(name): called when a new sound file is being created" + new_sound_hook = Xen_define_hook(S_new_sound_hook, "(make-hook 'name)", 1, H_new_sound_hook); mus_header_write_set_hook(g_new_sound_hook); - XEN_YES_WE_HAVE("sndlib"); + Xen_provide_feature("sndlib"); } |