X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fluabindings.cc;h=6bacc9b7cacd8ec5fa6d83d06c85ee8e988ab9b7;hb=1389fa9e2246a1b7faf193932a7c3ca4ba559c64;hp=cf1699021f4917179d32133271c6acebbae4a605;hpb=fe74c587f3054180d8c1243c50d97411450e009e;p=ardour.git diff --git a/libs/ardour/luabindings.cc b/libs/ardour/luabindings.cc index cf1699021f..6bacc9b7ca 100644 --- a/libs/ardour/luabindings.cc +++ b/libs/ardour/luabindings.cc @@ -20,6 +20,7 @@ #include "timecode/bbt_time.h" #include "pbd/stateful_diff_command.h" +#include "pbd/openuri.h" #include "evoral/Control.hpp" #include "evoral/ControlList.hpp" #include "evoral/Range.hpp" @@ -35,6 +36,7 @@ #include "ardour/chan_mapping.h" #include "ardour/dB.h" #include "ardour/dsp_filter.h" +#include "ardour/fluid_synth.h" #include "ardour/interthread_info.h" #include "ardour/lua_api.h" #include "ardour/luabindings.h" @@ -42,6 +44,7 @@ #include "ardour/meter.h" #include "ardour/midi_track.h" #include "ardour/midi_port.h" +#include "ardour/phase_control.h" #include "ardour/playlist.h" #include "ardour/plugin.h" #include "ardour/plugin_insert.h" @@ -53,6 +56,9 @@ #include "ardour/session.h" #include "ardour/session_object.h" #include "ardour/sidechain.h" +#include "ardour/solo_isolate_control.h" +#include "ardour/solo_safe_control.h" +#include "ardour/stripable.h" #include "ardour/track.h" #include "ardour/tempo.h" @@ -137,6 +143,13 @@ CLASSINFO(PublicEditor); CLASSINFO(Selection); CLASSINFO(ArdourMarker); +namespace LuaCairo { + class ImageSurface; + class PangoLayout; +} +CLASSKEYS(LuaCairo::ImageSurface); +CLASSKEYS(LuaCairo::PangoLayout); + namespace Cairo { class Context; } @@ -155,26 +168,38 @@ CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); CLASSKEYS(ARDOUR::LuaOSC::Address); CLASSKEYS(ARDOUR::Session); +CLASSKEYS(ARDOUR::PeakMeter); CLASSKEYS(ARDOUR::BufferSet); CLASSKEYS(ARDOUR::ChanMapping); +CLASSKEYS(ARDOUR::FluidSynth); CLASSKEYS(ARDOUR::DSP::DspShm); +CLASSKEYS(ARDOUR::LuaTableRef); +CLASSKEYS(PBD::Configuration); +CLASSKEYS(ARDOUR::PresentationInfo); +CLASSKEYS(ARDOUR::SessionConfiguration); CLASSKEYS(PBD::ID); CLASSKEYS(ARDOUR::Location); CLASSKEYS(ARDOUR::PluginInfo); +CLASSKEYS(ARDOUR::MonitorProcessor); +CLASSKEYS(ARDOUR::Plugin::PresetRecord); +CLASSKEYS(std::vector); CLASSKEYS(PBD::PropertyChange); CLASSKEYS(std::vector); CLASSKEYS(std::list >); CLASSKEYS(std::list >); +CLASSKEYS(std::vector >); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::weak_ptr); CLASSKEYS(std::list >); CLASSKEYS(std::list); CLASSKEYS(Evoral::Beats); +CLASSKEYS(ARDOUR::PortEngine); CLASSKEYS(ARDOUR::PortManager); CLASSKEYS(ARDOUR::AudioEngine); CLASSKEYS(void); CLASSKEYS(float); +CLASSKEYS(unsigned char); #endif // end windows special case @@ -214,6 +239,9 @@ LuaBindings::stddef (lua_State* L) .beginStdVector ("StringVector") .endClass () + // register float array (uint8_t*) + .registerArray ("ByteArray") + // register float array (float*) .registerArray ("FloatArray") @@ -229,11 +257,17 @@ LuaBindings::common (lua_State* L) { luabridge::getGlobalNamespace (L) .beginNamespace ("PBD") + + .addFunction ("open_uri", (bool (*) (const std::string&))&PBD::open_uri) + .addFunction ("open_uri", &PBD::open_folder) + .beginClass ("ID") .addConstructor () .addFunction ("to_s", &PBD::ID::to_s) // TODO special case LUA __tostring ? .endClass () + .beginStdVector ("IdVector").endClass () + .beginClass ("XMLNode") .addFunction ("name", &XMLNode::name) .endClass () @@ -253,6 +287,9 @@ LuaBindings::common (lua_State* L) .deriveClass ("StatefulDestructible") .endClass () + .deriveClass ("Configuration") + .endClass() + .deriveWSPtrClass ("StatefulDestructiblePtr") .endClass () @@ -280,6 +317,42 @@ LuaBindings::common (lua_State* L) .addFunction ("get_value", &PBD::Controllable::get_value) .endClass () + .beginClass > ("RingBuffer8") + .addConstructor () + .addFunction ("reset", &PBD::RingBufferNPT::reset) + .addFunction ("read", &PBD::RingBufferNPT::read) + .addFunction ("write", &PBD::RingBufferNPT::write) + .addFunction ("write_one", &PBD::RingBufferNPT::write_one) + .addFunction ("write_space", &PBD::RingBufferNPT::write_space) + .addFunction ("read_space", &PBD::RingBufferNPT::read_space) + .addFunction ("increment_read_ptr", &PBD::RingBufferNPT::increment_read_ptr) + .addFunction ("increment_write_ptr", &PBD::RingBufferNPT::increment_write_ptr) + .endClass () + + .beginClass > ("RingBufferF") + .addConstructor () + .addFunction ("reset", &PBD::RingBufferNPT::reset) + .addFunction ("read", &PBD::RingBufferNPT::read) + .addFunction ("write", &PBD::RingBufferNPT::write) + .addFunction ("write_one", &PBD::RingBufferNPT::write_one) + .addFunction ("write_space", &PBD::RingBufferNPT::write_space) + .addFunction ("read_space", &PBD::RingBufferNPT::read_space) + .addFunction ("increment_read_ptr", &PBD::RingBufferNPT::increment_read_ptr) + .addFunction ("increment_write_ptr", &PBD::RingBufferNPT::increment_write_ptr) + .endClass () + + .beginClass > ("RingBufferI") + .addConstructor () + .addFunction ("reset", &PBD::RingBufferNPT::reset) + .addFunction ("read", &PBD::RingBufferNPT::read) + .addFunction ("write", &PBD::RingBufferNPT::write) + .addFunction ("write_one", &PBD::RingBufferNPT::write_one) + .addFunction ("write_space", &PBD::RingBufferNPT::write_space) + .addFunction ("read_space", &PBD::RingBufferNPT::read_space) + .addFunction ("increment_read_ptr", &PBD::RingBufferNPT::increment_read_ptr) + .addFunction ("increment_write_ptr", &PBD::RingBufferNPT::increment_write_ptr) + .endClass () + /* PBD enums */ .beginNamespace ("GroupControlDisposition") .addConst ("InverseGroup", PBD::Controllable::GroupControlDisposition(PBD::Controllable::InverseGroup)) @@ -294,6 +367,21 @@ LuaBindings::common (lua_State* L) .beginClass ("BBT_TIME") .addConstructor () .endClass () + + /* libtimecode enums */ + .beginNamespace ("TimecodeFormat") + .addConst ("TC23976", Timecode::TimecodeFormat(Timecode::timecode_23976)) + .addConst ("TC24", Timecode::TimecodeFormat(Timecode::timecode_24)) + .addConst ("TC24976", Timecode::TimecodeFormat(Timecode::timecode_24976)) + .addConst ("TC25", Timecode::TimecodeFormat(Timecode::timecode_25)) + .addConst ("TC2997", Timecode::TimecodeFormat(Timecode::timecode_2997)) + .addConst ("TC2997DF", Timecode::TimecodeFormat(Timecode::timecode_2997drop)) + .addConst ("TC2997000", Timecode::TimecodeFormat(Timecode::timecode_2997000)) + .addConst ("TC2997000DF", Timecode::TimecodeFormat(Timecode::timecode_2997000drop)) + .addConst ("TC30", Timecode::TimecodeFormat(Timecode::timecode_30)) + .addConst ("TC5994", Timecode::TimecodeFormat(Timecode::timecode_5994)) + .addConst ("TC60", Timecode::TimecodeFormat(Timecode::timecode_60)) + .endNamespace () .endNamespace (); luabridge::getGlobalNamespace (L) @@ -371,6 +459,16 @@ LuaBindings::common (lua_State* L) .beginWSPtrClass ("PluginInfo") .addVoidConstructor () + .addData ("name", &PluginInfo::name, false) + .addData ("category", &PluginInfo::category, false) + .addData ("creator", &PluginInfo::creator, false) + .addData ("path", &PluginInfo::path, false) + .addData ("n_inputs", &PluginInfo::n_inputs, false) + .addData ("n_outputs", &PluginInfo::n_outputs, false) + .addData ("type", &PluginInfo::type, false) + .addData ("unique_id", &PluginInfo::unique_id, false) + .addFunction ("is_instrument", &PluginInfo::is_instrument) + .addFunction ("get_presets", &PluginInfo::get_presets) .endClass () .beginNamespace ("Route") @@ -383,6 +481,9 @@ LuaBindings::common (lua_State* L) .addVoidConstructor () .addFunction ("get", static_cast(&ChanMapping::get)) .addFunction ("set", &ChanMapping::set) + .addFunction ("count", &ChanMapping::count) + .addFunction ("n_total", &ChanMapping::n_total) + .addFunction ("is_monotonic", &ChanMapping::is_monotonic) .addConst ("Invalid", 4294967295U) // UINT32_MAX .endClass () @@ -427,8 +528,10 @@ LuaBindings::common (lua_State* L) .endClass () .deriveClass ("Location") + .addFunction ("name", &Location::name) .addFunction ("locked", &Location::locked) .addFunction ("lock", &Location::lock) + .addFunction ("unlock", &Location::unlock) .addFunction ("start", &Location::start) .addFunction ("_end", &Location::end) // XXX "end" is a lua reserved word .addFunction ("length", &Location::length) @@ -436,15 +539,26 @@ LuaBindings::common (lua_State* L) .addFunction ("set_end", &Location::set_end) .addFunction ("set_length", &Location::set) .addFunction ("move_to", &Location::move_to) + .addFunction ("matches", &Location::matches) + .addFunction ("flags", &Location::flags) + .addFunction ("is_auto_punch", &Location::is_auto_punch) + .addFunction ("is_auto_loop", &Location::is_auto_loop) + .addFunction ("is_mark", &Location::is_mark) + .addFunction ("is_hidden", &Location::is_hidden) + .addFunction ("is_cd_marker", &Location::is_cd_marker) + .addFunction ("is_session_range", &Location::is_session_range) + .addFunction ("is_range_marker", &Location::is_range_marker) .endClass () .deriveClass ("Locations") + .addFunction ("list", static_cast(&Locations::list)) .addFunction ("auto_loop_location", &Locations::auto_loop_location) .addFunction ("auto_punch_location", &Locations::auto_punch_location) .addFunction ("session_range_location", &Locations::session_range_location) .addFunction ("first_mark_after", &Locations::first_mark_after) .addFunction ("first_mark_before", &Locations::first_mark_before) .addFunction ("first_mark_at", &Locations::mark_at) + .addFunction ("remove", &Locations::remove) .addRefFunction ("marks_either_side", &Locations::marks_either_side) .addRefFunction ("find_all_between", &Locations::find_all_between) .endClass () @@ -459,6 +573,8 @@ LuaBindings::common (lua_State* L) .endClass () .beginWSPtrClass ("Port") + .addCast ("to_midiport") + .addCast ("to_audioport") .addFunction ("name", &Port::name) .addFunction ("pretty_name", &Port::pretty_name) .addFunction ("receives_input", &Port::receives_input) @@ -471,6 +587,7 @@ LuaBindings::common (lua_State* L) .addFunction ("connected_to", (bool (Port::*)(Port*)const)&Port::connected_to) .addFunction ("connect", (int (Port::*)(Port*))&Port::connect) .addFunction ("disconnect", (int (Port::*)(Port*))&Port::disconnect) + //.addStaticFunction ("port_offset", &Port::port_offset) // static .endClass () .deriveWSPtrClass ("AudioPort") @@ -479,6 +596,7 @@ LuaBindings::common (lua_State* L) .deriveWSPtrClass ("MidiPort") .addFunction ("input_active", &MidiPort::input_active) .addFunction ("set_input_active", &MidiPort::set_input_active) + .addFunction ("get_midi_buffer", &MidiPort::get_midi_buffer) // DSP only .endClass () .beginWSPtrClass ("PortSet") @@ -510,13 +628,68 @@ LuaBindings::common (lua_State* L) // stub RouteGroup* is needed for new_audio_track() .endClass () - .deriveWSPtrClass ("Route") + .deriveClass ("PresentationInfo") + .addFunction ("color", &PresentationInfo::color) + .addFunction ("set_color", &PresentationInfo::set_color) + .addFunction ("order", &PresentationInfo::order) + .endClass () + + .deriveWSPtrClass ("Stripable") + .addCast ("to_route") + .addFunction ("is_auditioner", &Stripable::is_auditioner) + .addFunction ("is_master", &Stripable::is_master) + .addFunction ("is_monitor", &Stripable::is_monitor) + .addFunction ("is_hidden", &Stripable::is_hidden) + .addFunction ("is_selected", &Stripable::is_selected) + .addFunction ("gain_control", &Stripable::gain_control) + .addFunction ("solo_control", &Stripable::solo_control) + .addFunction ("solo_isolate_control", &Stripable::solo_isolate_control) + .addFunction ("solo_safe_control", &Stripable::solo_safe_control) + .addFunction ("mute_control", &Stripable::mute_control) + .addFunction ("phase_control", &Stripable::phase_control) + .addFunction ("trim_control", &Stripable::trim_control) + .addFunction ("rec_enable_control", &Stripable::rec_enable_control) + .addFunction ("rec_safe_control", &Stripable::rec_safe_control) + .addFunction ("pan_azimuth_control", &Stripable::pan_azimuth_control) + .addFunction ("pan_elevation_control", &Stripable::pan_elevation_control) + .addFunction ("pan_width_control", &Stripable::pan_width_control) + .addFunction ("pan_frontback_control", &Stripable::pan_frontback_control) + .addFunction ("pan_lfe_control", &Stripable::pan_lfe_control) + .addFunction ("send_level_control", &Stripable::send_level_controllable) + .addFunction ("send_enable_control", &Stripable::send_level_controllable) + .addFunction ("send_name", &Stripable::send_name) + .addFunction ("monitor_control", &Stripable::monitor_control) + .addFunction ("master_send_enable_control ", &Stripable::master_send_enable_controllable ) + .addFunction ("comp_enable_control ", &Stripable::comp_enable_controllable ) + .addFunction ("comp_threshold_control ", &Stripable::comp_threshold_controllable ) + .addFunction ("comp_speed_control ", &Stripable::comp_speed_controllable ) + .addFunction ("comp_mode_control ", &Stripable::comp_mode_controllable ) + .addFunction ("comp_makeup_control ", &Stripable::comp_makeup_controllable ) + .addFunction ("comp_redux_control ", &Stripable::comp_redux_controllable ) + .addFunction ("comp_mode_name", &Stripable::comp_mode_name) + .addFunction ("comp_speed_name", &Stripable::comp_speed_name) + .addFunction ("eq_band_cnt ", &Stripable::eq_band_cnt) + .addFunction ("eq_band_name", &Stripable::eq_band_name) + .addFunction ("eq_gain_control", &Stripable::eq_gain_controllable) + .addFunction ("eq_freq_control ", &Stripable::eq_freq_controllable ) + .addFunction ("eq_q_control ", &Stripable::eq_q_controllable ) + .addFunction ("eq_shape_control ", &Stripable::eq_shape_controllable ) + .addFunction ("eq_enable_control ", &Stripable::eq_enable_controllable ) + .addFunction ("eq_hpf_control ", &Stripable::eq_hpf_controllable ) + .addFunction ("set_presentation_order", &Stripable::set_presentation_order) + .addFunction ("presentation_info_ptr", &Stripable::presentation_info_ptr) + + .endClass () + + .deriveWSPtrClass ("Route") .addCast ("to_track") .addFunction ("set_name", &Route::set_name) .addFunction ("comment", &Route::comment) .addFunction ("active", &Route::active) .addFunction ("set_active", &Route::set_active) .addFunction ("nth_plugin", &Route::nth_plugin) + .addFunction ("nth_processor", &Route::nth_processor) + .addFunction ("nth_send", &Route::nth_send) .addFunction ("add_processor_by_index", &Route::add_processor_by_index) .addFunction ("remove_processor", &Route::remove_processor) .addFunction ("replace_processor", &Route::replace_processor) @@ -534,6 +707,8 @@ LuaBindings::common (lua_State* L) .addFunction ("soloed", &Route::soloed) .addFunction ("amp", &Route::amp) .addFunction ("trim", &Route::trim) + .addFunction ("peak_meter", (boost::shared_ptr (Route::*)())&Route::peak_meter) + .addFunction ("set_meter_point", &Route::set_meter_point) .endClass () .deriveWSPtrClass ("Playlist") @@ -541,7 +716,7 @@ LuaBindings::common (lua_State* L) .addFunction ("data_type", &Playlist::data_type) .addFunction ("n_regions", &Playlist::n_regions) //.addFunction ("get_extent", &Playlist::get_extent) // pair - //.addFunction ("region_list", &Playlist::region_list) // RegionListProperty& + .addFunction ("region_list", &Playlist::region_list) .addFunction ("add_region", &Playlist::add_region) .addFunction ("remove_region", &Playlist::remove_region) .addFunction ("regions_at", &Playlist::regions_at) @@ -576,10 +751,6 @@ LuaBindings::common (lua_State* L) .addCast ("to_midi_track") .addFunction ("set_name", &Track::set_name) .addFunction ("can_record", &Track::can_record) - .addFunction ("record_enabled", &Track::record_enabled) - .addFunction ("record_safe", &Track::record_safe) - .addFunction ("set_record_enabled", &Track::set_record_enabled) - .addFunction ("set_record_safe", &Track::set_record_safe) .addFunction ("bounceable", &Track::bounceable) .addFunction ("bounce", &Track::bounce) .addFunction ("bounce_range", &Track::bounce_range) @@ -657,6 +828,8 @@ LuaBindings::common (lua_State* L) .addData ("valid", &Plugin::PresetRecord::valid, false) .endClass () + .beginStdVector ("PresetVector").endClass () + .deriveWSPtrClass ("Automatable") .addFunction ("automation_control", (boost::shared_ptr(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control) .endClass () @@ -665,19 +838,29 @@ LuaBindings::common (lua_State* L) .addVoidConstructor () .addData ("label", &ParameterDescriptor::label) .addData ("logarithmic", &ParameterDescriptor::logarithmic) + .addStaticFunction ("midi_note_name", &ParameterDescriptor::midi_note_name) .endClass () + .beginStdVector > ("ProcessorVector").endClass () + .deriveWSPtrClass ("Processor") .addCast ("to_automatable") .addCast ("to_insert") .addCast ("to_sidechain") .addCast ("to_ioprocessor") + .addCast ("to_unknownprocessor") + .addCast ("to_amp") + .addCast ("to_peakmeter") + .addCast ("to_monitorprocessor") +#if 0 // those objects are not yet bound + .addCast ("to_capturingprocessor") + .addCast ("to_delayline") + .addCast ("to_meter") +#endif .addFunction ("display_name", &Processor::display_name) .addFunction ("active", &Processor::active) .addFunction ("activate", &Processor::activate) .addFunction ("deactivate", &Processor::deactivate) - .addFunction ("control", (boost::shared_ptr(Evoral::ControlSet::*)(const Evoral::Parameter&, bool))&Evoral::ControlSet::control) - .addFunction ("automation_control", (boost::shared_ptr(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control) .endClass () .deriveWSPtrClass ("IOProcessor") @@ -704,6 +887,7 @@ LuaBindings::common (lua_State* L) .addFunction ("load_preset", &Plugin::load_preset) .addFunction ("parameter_is_input", &Plugin::parameter_is_input) .addFunction ("get_docs", &Plugin::get_docs) + .addFunction ("get_info", &Plugin::get_info) .addFunction ("get_parameter_docs", &Plugin::get_parameter_docs) .addRefFunction ("get_parameter_descriptor", &Plugin::get_parameter_descriptor) .endClass () @@ -734,13 +918,87 @@ LuaBindings::common (lua_State* L) .addFunction ("alist", &AutomationControl::alist) .endClass () - .deriveWSPtrClass ("GainControl") + .deriveWSPtrClass ("SlavableAutomationControl,") + .addFunction ("add_master", &SlavableAutomationControl::add_master) + .addFunction ("remove_master", &SlavableAutomationControl::remove_master) + .addFunction ("clear_masters", &SlavableAutomationControl::clear_masters) + .addFunction ("slaved_to", &SlavableAutomationControl::slaved_to) + .addFunction ("slaved", &SlavableAutomationControl::slaved) + .addFunction ("get_masters_value", &SlavableAutomationControl::get_masters_value) + .addFunction ("get_boolean_masters", &SlavableAutomationControl::get_boolean_masters) + //.addFunction ("masters", &SlavableAutomationControl::masters) // not implemented + .endClass () + + .deriveWSPtrClass ("PhaseControl") + .addFunction ("set_phase_invert", (void(PhaseControl::*)(uint32_t, bool))&PhaseControl::set_phase_invert) + .addFunction ("inverted", &PhaseControl::inverted) + .endClass () + + .deriveWSPtrClass ("GainControl") + .endClass () + + .deriveWSPtrClass ("SoloControl") + .addFunction ("can_solo", &SoloControl::can_solo) + .addFunction ("soloed", &SoloControl::soloed) + .addFunction ("self_soloed", &SoloControl::self_soloed) + .endClass () + + .deriveWSPtrClass ("MuteControl") + .addFunction ("muted", &MuteControl::muted) + .addFunction ("muted_by_self", &MuteControl::muted_by_self) + .endClass () + + .deriveWSPtrClass ("SoloIsolateControl") + .addFunction ("solo_isolated", &SoloIsolateControl::solo_isolated) + .addFunction ("self_solo_isolated", &SoloIsolateControl::self_solo_isolated) + .endClass () + + .deriveWSPtrClass ("SoloSafeControl") + .addFunction ("solo_safe", &SoloSafeControl::solo_safe) .endClass () .deriveWSPtrClass ("Amp") .addFunction ("gain_control", (boost::shared_ptr(Amp::*)())&Amp::gain_control) .endClass () + .deriveWSPtrClass ("PeakMeter") + .addFunction ("meter_level", &PeakMeter::meter_level) + .addFunction ("set_type", &PeakMeter::set_type) + .addFunction ("reset_max", &PeakMeter::reset_max) + .endClass () + + .deriveWSPtrClass ("MonitorProcessor") + .addFunction ("set_cut_all", &MonitorProcessor::set_cut_all) + .addFunction ("set_dim_all", &MonitorProcessor::set_dim_all) + .addFunction ("set_polarity", &MonitorProcessor::set_polarity) + .addFunction ("set_cut", &MonitorProcessor::set_cut) + .addFunction ("set_dim", &MonitorProcessor::set_dim) + .addFunction ("set_solo", &MonitorProcessor::set_solo) + .addFunction ("set_mono", &MonitorProcessor::set_mono) + .addFunction ("dim_level", &MonitorProcessor::dim_level) + .addFunction ("solo_boost_level", &MonitorProcessor::solo_boost_level) + .addFunction ("dimmed", &MonitorProcessor::dimmed) + .addFunction ("soloed", &MonitorProcessor::soloed) + .addFunction ("inverted", &MonitorProcessor::inverted) + .addFunction ("cut", &MonitorProcessor::cut) + .addFunction ("cut_all", &MonitorProcessor::cut_all) + .addFunction ("dim_all", &MonitorProcessor::dim_all) + .addFunction ("mono", &MonitorProcessor::mono) + .addFunction ("monitor_active", &MonitorProcessor::monitor_active) + .addFunction ("channel_cut_control", &MonitorProcessor::channel_cut_control) + .addFunction ("channel_dim_control", &MonitorProcessor::channel_dim_control) + .addFunction ("channel_polarity_control", &MonitorProcessor::channel_polarity_control) + .addFunction ("channel_solo_control", &MonitorProcessor::channel_solo_control) + .addFunction ("dim_control", &MonitorProcessor::dim_control) + .addFunction ("cut_control", &MonitorProcessor::cut_control) + .addFunction ("mono_control", &MonitorProcessor::mono_control) + .addFunction ("dim_level_control", &MonitorProcessor::dim_level_control) + .addFunction ("solo_boost_control", &MonitorProcessor::solo_boost_control) + .endClass () + + .deriveWSPtrClass ("UnknownProcessor") + .endClass () + .deriveWSPtrClass ("PluginControl") .endClass () @@ -821,6 +1079,24 @@ LuaBindings::common (lua_State* L) .beginClass ("TempoMap") .addFunction ("add_tempo", &TempoMap::add_tempo) .addFunction ("add_meter", &TempoMap::add_meter) + .addFunction ("tempo_section_at_frame", &TempoMap::tempo_section_at_frame) + .addFunction ("meter_section_at_frame", &TempoMap::meter_section_at_frame) + .addFunction ("meter_section_at_beat", &TempoMap::meter_section_at_beat) + .endClass () + + .beginClass ("MetricSection") + .addFunction ("pulse", &MetricSection::pulse) + .addFunction ("set_pulse", &MetricSection::set_pulse) + .endClass () + + .deriveClass ("TempoSection") + .addFunction ("c_func", (double(TempoSection::*)()const)&TempoSection::c_func) + .endClass () + + .deriveClass ("MeterSection") + .addCast ("to_meter") + .addFunction ("set_pulse", &MeterSection::set_pulse) + .addFunction ("set_beat", (void(MeterSection::*)(double))&MeterSection::set_beat) .endClass () .beginClass ("ChanCount") @@ -852,6 +1128,23 @@ LuaBindings::common (lua_State* L) .addConst ("Lua", ARDOUR::PluginType(Lua)) .endNamespace () + .beginNamespace ("PresentationInfo") + .beginNamespace ("Flag") + .addConst ("AudioTrack", ARDOUR::PresentationInfo::Flag(PresentationInfo::AudioTrack)) + .addConst ("MidiTrack", ARDOUR::PresentationInfo::Flag(PresentationInfo::MidiTrack)) + .addConst ("AudioBus", ARDOUR::PresentationInfo::Flag(PresentationInfo::AudioBus)) + .addConst ("MidiBus", ARDOUR::PresentationInfo::Flag(PresentationInfo::MidiBus)) + .addConst ("VCA", ARDOUR::PresentationInfo::Flag(PresentationInfo::VCA)) + .addConst ("MasterOut", ARDOUR::PresentationInfo::Flag(PresentationInfo::MasterOut)) + .addConst ("MonitorOut", ARDOUR::PresentationInfo::Flag(PresentationInfo::MonitorOut)) + .addConst ("Auditioner", ARDOUR::PresentationInfo::Flag(PresentationInfo::Auditioner)) + .addConst ("Selected", ARDOUR::PresentationInfo::Flag(PresentationInfo::Selected)) + .addConst ("Hidden", ARDOUR::PresentationInfo::Flag(PresentationInfo::Hidden)) + .addConst ("GroupOrderSet", ARDOUR::PresentationInfo::Flag(PresentationInfo::OrderSet)) + .addConst ("StatusMask", ARDOUR::PresentationInfo::Flag(PresentationInfo::StatusMask)) + .endNamespace () + .endNamespace () + .beginNamespace ("AutoStyle") .addConst ("Absolute", ARDOUR::AutoStyle(Absolute)) .addConst ("Trim", ARDOUR::AutoStyle(Trim)) @@ -865,15 +1158,47 @@ LuaBindings::common (lua_State* L) .endNamespace () .beginNamespace ("AutomationType") + .addConst ("GainAutomation", ARDOUR::AutomationType(GainAutomation)) .addConst ("PluginAutomation", ARDOUR::AutomationType(PluginAutomation)) - .addConst ("PluginAutomation", ARDOUR::AutomationType(GainAutomation)) - .addConst ("PluginAutomation", ARDOUR::AutomationType(TrimAutomation)) + .addConst ("SoloAutomation", ARDOUR::AutomationType(SoloAutomation)) + .addConst ("SoloIsolateAutomation", ARDOUR::AutomationType(SoloIsolateAutomation)) + .addConst ("SoloSafeAutomation", ARDOUR::AutomationType(SoloSafeAutomation)) + .addConst ("MuteAutomation", ARDOUR::AutomationType(MuteAutomation)) + .addConst ("RecEnableAutomation", ARDOUR::AutomationType(RecEnableAutomation)) + .addConst ("RecSafeAutomation", ARDOUR::AutomationType(RecSafeAutomation)) + .addConst ("TrimAutomation", ARDOUR::AutomationType(TrimAutomation)) + .addConst ("PhaseAutomation", ARDOUR::AutomationType(PhaseAutomation)) .endNamespace () .beginNamespace ("SrcQuality") .addConst ("SrcBest", ARDOUR::SrcQuality(SrcBest)) .endNamespace () + .beginNamespace ("MeterType") + .addConst ("MeterMaxSignal", ARDOUR::MeterType(MeterMaxSignal)) + .addConst ("MeterMaxPeak", ARDOUR::MeterType(MeterMaxPeak)) + .addConst ("MeterPeak", ARDOUR::MeterType(MeterPeak)) + .addConst ("MeterKrms", ARDOUR::MeterType(MeterKrms)) + .addConst ("MeterK20", ARDOUR::MeterType(MeterK20)) + .addConst ("MeterK14", ARDOUR::MeterType(MeterK14)) + .addConst ("MeterIEC1DIN", ARDOUR::MeterType(MeterIEC1DIN)) + .addConst ("MeterIEC1NOR", ARDOUR::MeterType(MeterIEC1NOR)) + .addConst ("MeterIEC2BBC", ARDOUR::MeterType(MeterIEC2BBC)) + .addConst ("MeterIEC2EBU", ARDOUR::MeterType(MeterIEC2EBU)) + .addConst ("MeterVU", ARDOUR::MeterType(MeterVU)) + .addConst ("MeterK12", ARDOUR::MeterType(MeterK12)) + .addConst ("MeterPeak0dB", ARDOUR::MeterType(MeterPeak0dB)) + .addConst ("MeterMCP", ARDOUR::MeterType(MeterMCP)) + .endNamespace () + + .beginNamespace ("MeterPoint") + .addConst ("MeterInput", ARDOUR::MeterPoint(MeterInput)) + .addConst ("MeterPreFader", ARDOUR::MeterPoint(MeterPreFader)) + .addConst ("MeterPostFader", ARDOUR::MeterPoint(MeterPostFader)) + .addConst ("MeterOutput", ARDOUR::MeterPoint(MeterOutput)) + .addConst ("MeterCustom", ARDOUR::MeterPoint(MeterCustom)) + .endNamespace () + .beginNamespace ("PortFlags") .addConst ("IsInput", ARDOUR::PortFlags(IsInput)) .addConst ("IsOutput", ARDOUR::PortFlags(IsOutput)) @@ -894,11 +1219,53 @@ LuaBindings::common (lua_State* L) .addConst ("SyncPoint", ARDOUR::RegionPoint(SyncPoint)) .endNamespace () + .beginNamespace ("TempoSection") + .beginNamespace ("PositionLockStyle") + .addConst ("AudioTime", ARDOUR::PositionLockStyle(AudioTime)) + .addConst ("MusicTime", ARDOUR::PositionLockStyle(MusicTime)) + .endNamespace () + .endNamespace () + + .beginNamespace ("TempoSection") + .beginNamespace ("Type") + .addConst ("Ramp", ARDOUR::TempoSection::Type(TempoSection::Ramp)) + .addConst ("Constant", ARDOUR::TempoSection::Type(TempoSection::Constant)) + .endNamespace () + .endNamespace () + .beginNamespace ("TrackMode") .addConst ("Normal", ARDOUR::TrackMode(Start)) .addConst ("NonLayered", ARDOUR::TrackMode(NonLayered)) .addConst ("Destructive", ARDOUR::TrackMode(Destructive)) .endNamespace () + + .beginNamespace ("SampleFormat") + .addConst ("Float", ARDOUR::SampleFormat(FormatFloat)) + .addConst ("Int24", ARDOUR::SampleFormat(FormatInt24)) + .addConst ("Int16", ARDOUR::SampleFormat(FormatInt16)) + .endNamespace () + + .beginNamespace ("HeaderFormat") + .addConst ("BWF", ARDOUR::HeaderFormat(BWF)) + .addConst ("WAVE", ARDOUR::HeaderFormat(WAVE)) + .addConst ("WAVE64", ARDOUR::HeaderFormat(WAVE64)) + .addConst ("CAF", ARDOUR::HeaderFormat(CAF)) + .addConst ("AIFF", ARDOUR::HeaderFormat(AIFF)) + .addConst ("iXML", ARDOUR::HeaderFormat(iXML)) + .addConst ("RF64", ARDOUR::HeaderFormat(RF64)) + .addConst ("RF64_WAV", ARDOUR::HeaderFormat(RF64_WAV)) + .addConst ("MBWF", ARDOUR::HeaderFormat(MBWF)) + .endNamespace () + + .beginNamespace ("InsertMergePolicy") + .addConst ("Reject", ARDOUR::InsertMergePolicy(InsertMergeReject)) + .addConst ("Relax", ARDOUR::InsertMergePolicy(InsertMergeRelax)) + .addConst ("Replace", ARDOUR::InsertMergePolicy(InsertMergeReplace)) + .addConst ("TruncateExisting", ARDOUR::InsertMergePolicy(InsertMergeTruncateExisting)) + .addConst ("TruncateAddition", ARDOUR::InsertMergePolicy(InsertMergeTruncateAddition)) + .addConst ("Extend", ARDOUR::InsertMergePolicy(InsertMergeExtend)) + .endNamespace () + .endNamespace (); // end ARDOUR luabridge::getGlobalNamespace (L) @@ -943,6 +1310,9 @@ LuaBindings::common (lua_State* L) .addFunction ("set_output_device_name", &AudioBackend::set_output_device_name) .endClass() + .beginClass ("PortEngine") + .endClass() + .beginClass ("PortManager") .addFunction ("port_engine", &PortManager::port_engine) .addFunction ("connected", &PortManager::connected) @@ -975,6 +1345,25 @@ LuaBindings::common (lua_State* L) .addFunction ("set_buffer_size", &AudioEngine::set_buffer_size) .addFunction ("get_last_backend_error", &AudioEngine::get_last_backend_error) .endClass() + + .deriveClass ("SessionConfiguration") +#undef CONFIG_VARIABLE +#undef CONFIG_VARIABLE_SPECIAL +#define CONFIG_VARIABLE(Type,var,name,value) \ + .addFunction ("get_" # var, &SessionConfiguration::get_##var) \ + .addFunction ("set_" # var, &SessionConfiguration::set_##var) \ + .addProperty (#var, &SessionConfiguration::get_##var, &SessionConfiguration::set_##var) + +#define CONFIG_VARIABLE_SPECIAL(Type,var,name,value,mutator) \ + .addFunction ("get_" # var, &SessionConfiguration::get_##var) \ + .addFunction ("set_" # var, &SessionConfiguration::set_##var) \ + .addProperty (#var, &SessionConfiguration::get_##var, &SessionConfiguration::set_##var) + +#include "ardour/session_configuration_vars.h" + +#undef CONFIG_VARIABLE +#undef CONFIG_VARIABLE_SPECIAL + .endClass() .endNamespace (); // basic representation of Session @@ -995,6 +1384,8 @@ LuaBindings::common (lua_State* L) .addFunction ("timecode_drop_frames", &Session::timecode_drop_frames) .addFunction ("request_locate", &Session::request_locate) .addFunction ("request_stop", &Session::request_stop) + .addFunction ("request_play_loop", &Session::request_play_loop) + .addFunction ("get_play_loop", &Session::get_play_loop) .addFunction ("last_transport_start", &Session::last_transport_start) .addFunction ("goto_start", &Session::goto_start) .addFunction ("goto_end", &Session::goto_end) @@ -1010,9 +1401,13 @@ LuaBindings::common (lua_State* L) .addFunction ("name", &Session::name) .addFunction ("path", &Session::path) .addFunction ("record_status", &Session::record_status) + .addFunction ("maybe_enable_record", &Session::maybe_enable_record) + .addFunction ("disable_record", &Session::disable_record) .addFunction ("route_by_id", &Session::route_by_id) .addFunction ("route_by_name", &Session::route_by_name) - .addFunction ("route_by_remote_id", &Session::route_by_remote_id) + .addFunction ("get_remote_nth_stripable", &Session::get_remote_nth_stripable) + .addFunction ("get_remote_nth_route", &Session::get_remote_nth_route) + .addFunction ("route_by_selected_count", &Session::route_by_selected_count) .addFunction ("track_by_diskstream_id", &Session::track_by_diskstream_id) .addFunction ("source_by_id", &Session::source_by_id) .addFunction ("controllable_by_id", &Session::controllable_by_id) @@ -1033,6 +1428,7 @@ LuaBindings::common (lua_State* L) .addFunction ("worst_input_latency", &Session::worst_input_latency) .addFunction ("worst_track_latency", &Session::worst_track_latency) .addFunction ("worst_playback_latency", &Session::worst_playback_latency) + .addFunction ("cfg", &Session::cfg) .endClass () .beginClass ("RegionFactory") @@ -1071,7 +1467,9 @@ LuaBindings::common (lua_State* L) .addFunction ("set_processor_param", ARDOUR::LuaAPI::set_processor_param) .addFunction ("set_plugin_insert_param", ARDOUR::LuaAPI::set_plugin_insert_param) .addCFunction ("plugin_automation", ARDOUR::LuaAPI::plugin_automation) + .addCFunction ("hsla_to_rgba", ARDOUR::LuaAPI::hsla_to_rgba) .addFunction ("usleep", Glib::usleep) + .addCFunction ("build_filename", ARDOUR::LuaAPI::build_filename) .endNamespace () // end LuaAPI .endNamespace ();// end ARDOUR } @@ -1094,13 +1492,20 @@ LuaBindings::dsp (lua_State* L) .beginClass ("MidiBuffer") .addEqualCheck () .addFunction ("silence", &MidiBuffer::silence) + .addFunction ("size", &MidiBuffer::size) .addFunction ("empty", &MidiBuffer::empty) + .addFunction ("resize", &MidiBuffer::resize) + .addFunction ("copy", (void (MidiBuffer::*)(MidiBuffer const * const))&MidiBuffer::copy) + .addFunction ("push_event", (bool (MidiBuffer::*)(const Evoral::MIDIEvent&))&MidiBuffer::push_back) + .addFunction ("push_back", (bool (MidiBuffer::*)(framepos_t, size_t, const uint8_t*))&MidiBuffer::push_back) // TODO iterators.. + .addExtCFunction ("table", &luabridge::CFunc::listToTable, MidiBuffer>) .endClass() .beginClass ("BufferSet") .addEqualCheck () .addFunction ("get_audio", static_cast(&BufferSet::get_audio)) + .addFunction ("get_midi", static_cast(&BufferSet::get_midi)) .addFunction ("count", static_cast(&BufferSet::count)) .endClass() .endNamespace (); @@ -1112,6 +1517,7 @@ LuaBindings::dsp (lua_State* L) .addFunction ("size", &Evoral::Event::size) .addFunction ("set_buffer", &Evoral::Event::set_buffer) .addFunction ("buffer", (uint8_t*(Evoral::Event::*)())&Evoral::Event::buffer) + .addFunction ("time", (framepos_t (Evoral::Event::*)())&Evoral::MIDIEvent::time) .endClass () .beginClass ("Beats") @@ -1122,8 +1528,8 @@ LuaBindings::dsp (lua_State* L) // add Ctor? .addFunction ("type", &Evoral::MIDIEvent::type) .addFunction ("channel", &Evoral::MIDIEvent::channel) - .addFunction ("set_type", &Evoral::MIDIEvent::type) - .addFunction ("set_channel", &Evoral::MIDIEvent::channel) + .addFunction ("set_type", &Evoral::MIDIEvent::set_type) + .addFunction ("set_channel", &Evoral::MIDIEvent::set_channel) .endClass () .endNamespace (); @@ -1136,6 +1542,20 @@ LuaBindings::dsp (lua_State* L) .endClass () .endNamespace (); + luabridge::getGlobalNamespace (L) + .beginNamespace ("ARDOUR") + .beginClass ("FluidSynth") + .addConstructor () + .addFunction ("load_sf2", &FluidSynth::load_sf2) + .addFunction ("synth", &FluidSynth::synth) + .addFunction ("midi_event", &FluidSynth::midi_event) + .addFunction ("panic", &FluidSynth::panic) + .addFunction ("select_program", &FluidSynth::select_program) + .addFunction ("program_count", &FluidSynth::program_count) + .addFunction ("program_name", &FluidSynth::program_name) + .endClass () + .endNamespace (); + luabridge::getGlobalNamespace (L) .beginNamespace ("ARDOUR") .beginNamespace ("DSP") @@ -1152,6 +1572,7 @@ LuaBindings::dsp (lua_State* L) .addFunction ("mmult", &DSP::mmult) .addFunction ("log_meter", &DSP::log_meter) .addFunction ("log_meter_coeff", &DSP::log_meter_coeff) + .addFunction ("process_map", &DSP::process_map) .addRefFunction ("peaks", &DSP::peaks) .beginClass ("LowPass") @@ -1161,27 +1582,37 @@ LuaBindings::dsp (lua_State* L) .addFunction ("set_cutoff", &DSP::LowPass::set_cutoff) .addFunction ("reset", &DSP::LowPass::reset) .endClass () - .beginClass ("Biquad") + .beginClass ("Biquad") .addConstructor () - .addFunction ("run", &DSP::BiQuad::run) - .addFunction ("compute", &DSP::BiQuad::compute) - .addFunction ("reset", &DSP::BiQuad::reset) + .addFunction ("run", &DSP::Biquad::run) + .addFunction ("compute", &DSP::Biquad::compute) + .addFunction ("configure", &DSP::Biquad::configure) + .addFunction ("reset", &DSP::Biquad::reset) + .addFunction ("dB_at_freq", &DSP::Biquad::dB_at_freq) + .endClass () + .beginClass ("FFTSpectrum") + .addConstructor () + .addFunction ("set_data_hann", &DSP::FFTSpectrum::set_data_hann) + .addFunction ("execute", &DSP::FFTSpectrum::execute) + .addFunction ("power_at_bin", &DSP::FFTSpectrum::power_at_bin) + .addFunction ("freq_at_bin", &DSP::FFTSpectrum::freq_at_bin) .endClass () /* DSP enums */ - .beginNamespace ("BiQuadType") - .addConst ("LowPass", ARDOUR::DSP::BiQuad::LowPass) - .addConst ("HighPass", ARDOUR::DSP::BiQuad::HighPass) - .addConst ("BandPassSkirt", ARDOUR::DSP::BiQuad::BandPassSkirt) - .addConst ("BandPass0dB", ARDOUR::DSP::BiQuad::BandPass0dB) - .addConst ("Notch", ARDOUR::DSP::BiQuad::Notch) - .addConst ("AllPass", ARDOUR::DSP::BiQuad::AllPass) - .addConst ("Peaking", ARDOUR::DSP::BiQuad::Peaking) - .addConst ("LowShelf", ARDOUR::DSP::BiQuad::LowShelf) - .addConst ("HighShelf", ARDOUR::DSP::BiQuad::HighShelf) + .beginNamespace ("BiquadType") + .addConst ("LowPass", ARDOUR::DSP::Biquad::LowPass) + .addConst ("HighPass", ARDOUR::DSP::Biquad::HighPass) + .addConst ("BandPassSkirt", ARDOUR::DSP::Biquad::BandPassSkirt) + .addConst ("BandPass0dB", ARDOUR::DSP::Biquad::BandPass0dB) + .addConst ("Notch", ARDOUR::DSP::Biquad::Notch) + .addConst ("AllPass", ARDOUR::DSP::Biquad::AllPass) + .addConst ("Peaking", ARDOUR::DSP::Biquad::Peaking) + .addConst ("LowShelf", ARDOUR::DSP::Biquad::LowShelf) + .addConst ("HighShelf", ARDOUR::DSP::Biquad::HighShelf) .endNamespace () .beginClass ("DspShm") + .addConstructor () .addFunction ("allocate", &DSP::DspShm::allocate) .addFunction ("clear", &DSP::DspShm::clear) .addFunction ("to_float", &DSP::DspShm::to_float) @@ -1191,6 +1622,12 @@ LuaBindings::dsp (lua_State* L) .endClass () .endNamespace () // DSP + + .beginClass ("LuaTableRef") + .addCFunction ("get", &LuaTableRef::get) + .addCFunction ("set", &LuaTableRef::set) + .endClass () + .endNamespace (); // ARDOUR } @@ -1205,7 +1642,7 @@ LuaBindings::session (lua_State* L) .addFunction ("set_dirty", &Session::set_dirty) .addFunction ("unknown_processors", &Session::unknown_processors) - .addFunction ("new_route_from_template", &Session::new_route_from_template) + .addFunction ("new_route_from_template", &Session::new_route_from_template) // TODO session_add_audio_track session_add_midi_track session_add_mixed_track //.addFunction ("new_midi_track", &Session::new_midi_track) .endClass ()