X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fluabindings.cc;h=2dbf5adc84c0e8adb15fd1cd06f804b455be5292;hb=9bf40bde3aed831791108bfccc4b1e10b071afdc;hp=34dcabc73696fe1f70a1a2bc347126881829e424;hpb=b9c6ffac214a69bb64e8ba5adbbe0951a9119f09;p=ardour.git diff --git a/libs/ardour/luabindings.cc b/libs/ardour/luabindings.cc index 34dcabc736..2dbf5adc84 100644 --- a/libs/ardour/luabindings.cc +++ b/libs/ardour/luabindings.cc @@ -28,6 +28,7 @@ #include "evoral/Range.hpp" #include "ardour/amp.h" +#include "ardour/async_midi_port.h" #include "ardour/audioengine.h" #include "ardour/audioregion.h" #include "ardour/audiosource.h" @@ -40,6 +41,9 @@ #include "ardour/beats_samples_converter.h" #include "ardour/chan_mapping.h" #include "ardour/dB.h" +#include "ardour/delayline.h" +#include "ardour/disk_reader.h" +#include "ardour/disk_writer.h" #include "ardour/dsp_filter.h" #include "ardour/file_source.h" #include "ardour/fluid_synth.h" @@ -59,12 +63,16 @@ #include "ardour/playlist.h" #include "ardour/plugin.h" #include "ardour/plugin_insert.h" +#include "ardour/polarity_processor.h" #include "ardour/port_manager.h" #include "ardour/progress.h" +#include "ardour/raw_midi_parser.h" #include "ardour/runtime_functions.h" #include "ardour/region.h" #include "ardour/region_factory.h" +#include "ardour/return.h" #include "ardour/route_group.h" +#include "ardour/send.h" #include "ardour/session.h" #include "ardour/session_object.h" #include "ardour/sidechain.h" @@ -537,6 +545,7 @@ LuaBindings::common (lua_State* L) .beginWSPtrClass ("ControlList") .addFunction ("add", &Evoral::ControlList::add) + .addFunction ("editor_add", &Evoral::ControlList::editor_add) .addFunction ("thin", &Evoral::ControlList::thin) .addFunction ("eval", &Evoral::ControlList::eval) .addRefFunction ("rt_safe_eval", &Evoral::ControlList::rt_safe_eval) @@ -821,6 +830,7 @@ LuaBindings::common (lua_State* L) .addFunction ("set_start", &Location::set_start) .addFunction ("set_end", &Location::set_end) .addFunction ("set_length", &Location::set) + .addFunction ("set_name", &Location::set_name) .addFunction ("move_to", &Location::move_to) .addFunction ("matches", &Location::matches) .addFunction ("flags", &Location::flags) @@ -841,6 +851,7 @@ LuaBindings::common (lua_State* L) .addFunction ("first_mark_after", &Locations::first_mark_after) .addFunction ("first_mark_before", &Locations::first_mark_before) .addFunction ("first_mark_at", &Locations::mark_at) + .addFunction ("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) @@ -862,6 +873,7 @@ LuaBindings::common (lua_State* L) .beginWSPtrClass ("Port") .addCast ("to_midiport") + .addCast ("to_asyncmidiport") .addCast ("to_audioport") .addFunction ("name", &Port::name) .addFunction ("pretty_name", &Port::pretty_name) @@ -872,6 +884,10 @@ LuaBindings::common (lua_State* L) .addFunction ("connected_to", (bool (Port::*)(std::string const &)const)&Port::connected_to) .addFunction ("connect", (int (Port::*)(std::string const &))&Port::connect) .addFunction ("disconnect", (int (Port::*)(std::string const &))&Port::disconnect) + .addFunction ("physically_connected", &Port::physically_connected) + .addFunction ("private_latency_range", &Port::private_latency_range) + .addFunction ("public_latency_range", &Port::public_latency_range) + .addRefFunction ("get_connected_latency_range", &Port::get_connected_latency_range) //.addStaticFunction ("port_offset", &Port::port_offset) // static .endClass () @@ -879,11 +895,16 @@ LuaBindings::common (lua_State* L) .endClass () .deriveWSPtrClass ("MidiPort") + .addCast ("to_asyncmidiport") .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 () + .deriveWSPtrClass ("AsyncMIDIPort") + .addFunction ("write", &AsyncMIDIPort::write) + .endClass () + .beginWSPtrClass ("PortSet") .addFunction ("num_ports", (size_t (PortSet::*)(DataType)const)&PortSet::num_ports) .addFunction ("add", &PortSet::add) @@ -909,6 +930,7 @@ LuaBindings::common (lua_State* L) .addFunction ("port_by_name", &IO::nth) .addFunction ("n_ports", &IO::n_ports) .addFunction ("latency", &IO::latency) + .addFunction ("public_latency", &IO::latency) .endClass () .deriveWSPtrClass ("PannerShell") @@ -965,11 +987,15 @@ LuaBindings::common (lua_State* L) .beginWSPtrClass ("Slavable") .addFunction ("assign", &Slavable::assign) .addFunction ("unassign", &Slavable::unassign) + .addFunction ("masters", &Slavable::masters) + .addFunction ("assigned_to", &Slavable::assigned_to) .endClass () .deriveWSPtrClass ("Stripable") .addCast ("to_route") .addCast ("to_vca") + .addCast ("to_slavable") + .addCast ("to_automatable") .addFunction ("is_auditioner", &Stripable::is_auditioner) .addFunction ("is_private_route", &Stripable::is_private_route) .addFunction ("is_master", &Stripable::is_master) @@ -1024,12 +1050,12 @@ LuaBindings::common (lua_State* L) .addFunction ("gain_control", &VCA::gain_control) .addFunction ("solo_control", &VCA::solo_control) .addFunction ("mute_control", &VCA::mute_control) + .addFunction ("slaved_to", &VCA::slaved_to) + .addFunction ("slaved", &VCA::slaved) .endClass () .deriveWSPtrClass ("Route") .addCast ("to_track") - .addCast ("to_automatable") - .addCast ("to_slavable") .addFunction ("set_name", &Route::set_name) .addFunction ("comment", &Route::comment) .addFunction ("active", &Route::active) @@ -1062,8 +1088,8 @@ LuaBindings::common (lua_State* L) .addFunction ("trim", &Route::trim) .addFunction ("peak_meter", (boost::shared_ptr (Route::*)())&Route::peak_meter) .addFunction ("set_meter_point", &Route::set_meter_point) - .addFunction ("initial_delay", &Route::initial_delay) .addFunction ("signal_latency", &Route::signal_latency) + .addFunction ("playback_latency", &Route::playback_latency) .endClass () .deriveWSPtrClass ("Playlist") @@ -1315,11 +1341,16 @@ LuaBindings::common (lua_State* L) .addCast ("to_ioprocessor") .addCast ("to_unknownprocessor") .addCast ("to_amp") + .addCast ("to_diskioprocessor") + .addCast ("to_diskreader") + .addCast ("to_diskwriter") .addCast ("to_peakmeter") .addCast ("to_monitorprocessor") + .addCast ("to_send") + .addCast ("to_polarityprocessor") + .addCast ("to_delayline") #if 0 // those objects are not yet bound .addCast ("to_capturingprocessor") - .addCast ("to_delayline") #endif .addCast ("to_meter") .addFunction ("display_name", &Processor::display_name) @@ -1327,8 +1358,22 @@ LuaBindings::common (lua_State* L) .addFunction ("active", &Processor::active) .addFunction ("activate", &Processor::activate) .addFunction ("deactivate", &Processor::deactivate) - .addFunction ("output_streams", &PluginInsert::output_streams) - .addFunction ("input_streams", &PluginInsert::input_streams) + .addFunction ("input_latency", &Processor::input_latency) + .addFunction ("output_latency", &Processor::output_latency) + .addFunction ("capture_offset", &Processor::capture_offset) + .addFunction ("playback_offset", &Processor::playback_offset) + .addFunction ("output_streams", &Processor::output_streams) + .addFunction ("input_streams", &Processor::input_streams) + .addFunction ("signal_latency", &Processor::signal_latency) + .endClass () + + .deriveWSPtrClass ("DiskIOProcessor") + .endClass () + + .deriveWSPtrClass ("DiskReader") + .endClass () + + .deriveWSPtrClass ("DiskWriter") .endClass () .deriveWSPtrClass ("IOProcessor") @@ -1345,6 +1390,20 @@ LuaBindings::common (lua_State* L) .addFunction ("panner_shell", &Route::panner_shell) .endClass () + .deriveWSPtrClass ("Send") + .addFunction ("get_delay_in", &Send::get_delay_in) + .addFunction ("get_delay_out", &Send::get_delay_out) + .endClass () + + .deriveWSPtrClass ("InternalSend") + .endClass () + + .deriveWSPtrClass ("Return") + .endClass () + + .deriveWSPtrClass ("InternalReturn") + .endClass () + .beginNamespace ("Plugin") .beginClass ("IOPortDescription") .addData ("name", &Plugin::IOPortDescription::name) @@ -1394,6 +1453,11 @@ LuaBindings::common (lua_State* L) .addFunction ("natural_output_streams", &PluginInsert::natural_output_streams) .addFunction ("natural_input_streams", &PluginInsert::natural_input_streams) .addFunction ("reset_parameters_to_default", &PluginInsert::reset_parameters_to_default) + .addFunction ("has_sidechain", &PluginInsert::has_sidechain) + .addFunction ("is_instrument", &PluginInsert::is_instrument) + .addFunction ("type", &PluginInsert::type) + .addFunction ("signal_latency", &PluginInsert::signal_latency) + .addFunction ("get_count", &PluginInsert::get_count) .endClass () .deriveWSPtrClass ("ReadOnlyControl") @@ -1496,9 +1560,24 @@ LuaBindings::common (lua_State* L) .deriveWSPtrClass ("UnknownProcessor") .endClass () + .deriveWSPtrClass ("PolarityProcessor") + .endClass () + + .deriveWSPtrClass ("DelayLine") + .addFunction ("delay", &DelayLine::delay) + .endClass () + .deriveWSPtrClass ("PluginControl") .endClass () + .beginClass ("RawMidiParser") + .addVoidConstructor () + .addFunction ("reset", &RawMidiParser::reset) + .addFunction ("process_byte", &RawMidiParser::process_byte) + .addFunction ("buffer_size", &RawMidiParser::buffer_size) + .addFunction ("midi_buffer", &RawMidiParser::midi_buffer) + .endClass () + .deriveWSPtrClass ("AudioSource") .addFunction ("readable_length", &AudioSource::readable_length) .addFunction ("n_channels", &AudioSource::n_channels) @@ -1524,6 +1603,10 @@ LuaBindings::common (lua_State* L) .beginConstStdList > ("VCAList") .endClass () + // VCAVector == std::vector > + .beginConstStdVector > ("VCAVector") + .endClass () + // boost::shared_ptr .beginPtrStdList > ("RouteListPtr") .addVoidPtrConstructor > > () @@ -2008,7 +2091,10 @@ LuaBindings::common (lua_State* L) .addFunction ("set_output_device_name", &AudioBackend::set_output_device_name) .endClass() - .beginClass ("PortEngine") + .beginClass ("LatencyRange") + .addVoidConstructor () + .addData ("min", &LatencyRange::min) + .addData ("max", &LatencyRange::max) .endClass() .beginClass ("PortManager") @@ -2104,7 +2190,7 @@ LuaBindings::common (lua_State* L) .addFunction ("scripts_changed", &Session::scripts_changed) // used internally .addFunction ("transport_rolling", &Session::transport_rolling) .addFunction ("request_transport_speed", &Session::request_transport_speed) - .addFunction ("transport_frame", &Session::transport_sample) + .addFunction ("transport_sample", &Session::transport_sample) .addFunction ("transport_speed", &Session::transport_speed) .addFunction ("sample_rate", &Session::sample_rate) .addFunction ("nominal_sample_rate", &Session::nominal_sample_rate) @@ -2141,6 +2227,7 @@ LuaBindings::common (lua_State* L) .addFunction ("disable_record", &Session::disable_record) .addFunction ("route_by_id", &Session::route_by_id) .addFunction ("route_by_name", &Session::route_by_name) + .addFunction ("stripable_by_id", &Session::stripable_by_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) @@ -2170,10 +2257,8 @@ LuaBindings::common (lua_State* L) .addFunction ("get_block_size", &Session::get_block_size) .addFunction ("worst_output_latency", &Session::worst_output_latency) .addFunction ("worst_input_latency", &Session::worst_input_latency) - .addFunction ("worst_track_latency", &Session::worst_track_latency) - .addFunction ("worst_track_roll_delay", &Session::worst_track_roll_delay) - .addFunction ("worst_track_out_latency", &Session::worst_track_out_latency) - .addFunction ("worst_playback_latency", &Session::worst_playback_latency) + .addFunction ("worst_route_latency", &Session::worst_route_latency) + .addFunction ("worst_latency_preroll", &Session::worst_latency_preroll) .addFunction ("cfg", &Session::cfg) .addFunction ("route_groups", &Session::route_groups) .addFunction ("new_route_group", &Session::new_route_group) @@ -2291,6 +2376,11 @@ LuaBindings::common (lua_State* L) .addFunction ("power_at_bin", &DSP::FFTSpectrum::power_at_bin) .addFunction ("freq_at_bin", &DSP::FFTSpectrum::freq_at_bin) .endClass () + .beginClass ("Generator") + .addVoidConstructor () + .addFunction ("run", &DSP::Generator::run) + .addFunction ("set_type", &DSP::Generator::set_type) + .endClass () /* DSP enums */ .beginNamespace ("BiquadType") @@ -2305,6 +2395,12 @@ LuaBindings::common (lua_State* L) .addConst ("HighShelf", ARDOUR::DSP::Biquad::HighShelf) .endNamespace () + .beginNamespace ("NoiseType") + .addConst ("UniformWhiteNoise", ARDOUR::DSP::Generator::UniformWhiteNoise) + .addConst ("GaussianWhiteNoise", ARDOUR::DSP::Generator::GaussianWhiteNoise) + .addConst ("PinkNoise", ARDOUR::DSP::Generator::PinkNoise) + .endNamespace () + .beginClass ("DspShm") .addConstructor () .addFunction ("allocate", &DSP::DspShm::allocate)