#ifndef JACK_MIXER_H__DAEB51D8_5861_40F2_92E4_24CA495A384D__INCLUDED
#define JACK_MIXER_H__DAEB51D8_5861_40F2_92E4_24CA495A384D__INCLUDED
-#ifdef SWIG
-%module jack_mixer_c
-%include "typemaps.i"
-%apply double *OUTPUT { double * left_ptr, double * right_ptr, double * mono_ptr };
-%{
#include <stdbool.h>
-#include "jack_mixer.h"
-%}
-#endif
+#include <jack/jack.h>
+
+#include "scale.h"
typedef void * jack_mixer_t;
+typedef void * jack_mixer_kmeter_t;
typedef void * jack_mixer_channel_t;
typedef void * jack_mixer_output_channel_t;
-typedef void * jack_mixer_scale_t;
typedef void * jack_mixer_threshold_t;
+enum midi_behavior_mode { Jump_To_Value, Pick_Up };
+
jack_mixer_t
create(
const char * jack_client_name_ptr,
jack_mixer_t mixer,
int new_channel);
+int
+get_midi_behavior_mode(
+ jack_mixer_t mixer);
+
+unsigned int
+set_midi_behavior_mode(
+ jack_mixer_t mixer,
+ enum midi_behavior_mode mode);
+
jack_mixer_channel_t
add_channel(
jack_mixer_t mixer,
const char * channel_name,
bool stereo);
+void kmeter_init(jack_mixer_kmeter_t km,
+ int sr,
+ int fsize,
+ float hold,
+ float fall);
+
+void kmeter_process(
+ jack_mixer_kmeter_t km,
+ jack_default_audio_sample_t *p,
+ int start,
+ int end);
+
const char *
channel_get_name(
jack_mixer_channel_t channel);
jack_mixer_channel_t channel,
double * mono_ptr);
+
+/* returned values are in dBFS */
+void
+channel_stereo_kmeter_read(
+ jack_mixer_channel_t channel,
+ double * left_ptr,
+ double * right_ptr,
+ double * left_rms_ptr,
+ double * right_rms_ptr);
+
+/* returned value is in dBFS */
+void
+channel_mono_kmeter_read(
+ jack_mixer_channel_t channel,
+ double * mono_ptr,
+ double * mono_rms_ptr);
+
+
+
bool
channel_is_stereo(
jack_mixer_channel_t channel);
channel_volume_read(
jack_mixer_channel_t channel);
+void
+channels_volumes_read(jack_mixer_t mixer_ptr);
+
/* balance is from -1.0 (full left) to +1.0 (full right) */
void
channel_balance_write(
jack_mixer_channel_t channel,
int new_cc);
+int
+channel_get_solo_midi_cc(
+ jack_mixer_channel_t channel);
+
+unsigned int
+channel_set_solo_midi_cc(
+ jack_mixer_channel_t channel,
+ int new_cc);
+
+void channel_set_midi_cc_volume_picked_up(jack_mixer_channel_t channel,
+ bool status);
+
+void channel_set_midi_cc_balance_picked_up(jack_mixer_channel_t channel,
+ bool status);
+
+void
+channel_autoset_volume_midi_cc(
+ jack_mixer_channel_t channel);
+
+void
+channel_autoset_balance_midi_cc(
+ jack_mixer_channel_t channel);
+
+void
+channel_autoset_mute_midi_cc(
+ jack_mixer_channel_t channel);
+
void
-channel_autoset_midi_cc(
+channel_autoset_solo_midi_cc(
jack_mixer_channel_t channel);
void
remove_channel(
jack_mixer_channel_t channel);
+void
+remove_channels(
+ jack_mixer_t mixer);
+
/* returned value is in dBFS */
double
channel_abspeak_read(
channel_get_midi_in_got_events(
jack_mixer_channel_t channel);
-jack_mixer_scale_t
-scale_create();
-
-bool
-scale_add_threshold(
- jack_mixer_scale_t scale,
- float db,
- float scale_value);
-
-void
-scale_calculate_coefficients(
- jack_mixer_scale_t scale);
-
-double
-scale_db_to_scale(
- jack_mixer_scale_t scale,
- double db);
-
-double
-scale_scale_to_db(
- jack_mixer_scale_t scale,
- double scale_value);
-
-void
-scale_destroy(
- jack_mixer_scale_t scale);
-
jack_mixer_output_channel_t
add_output_channel(
jack_mixer_t mixer,
output_channel_is_prefader(
jack_mixer_output_channel_t output_channel);
+void output_channel_set_in_prefader(jack_mixer_output_channel_t output_channel,
+ jack_mixer_channel_t input_channel,
+ bool prefader_value);
+
+bool
+output_channel_is_in_prefader(
+ jack_mixer_output_channel_t output_channel,
+ jack_mixer_channel_t channel);
+
#endif /* #ifndef JACK_MIXER_H__DAEB51D8_5861_40F2_92E4_24CA495A384D__INCLUDED */