X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fluabindings.cc;h=e77510921366fb31912688ce0383610340ac05f3;hb=88c82aeb56c62d9d0c0acff51e360492ad9b8d23;hp=42184e3473e39f27a38caaaa558361801a3044c3;hpb=7f9befae2ddfa4e815b6bd02c8425fc8df96a025;p=ardour.git diff --git a/libs/ardour/luabindings.cc b/libs/ardour/luabindings.cc index 42184e3473..e775109213 100644 --- a/libs/ardour/luabindings.cc +++ b/libs/ardour/luabindings.cc @@ -18,14 +18,17 @@ #include -#include "timecode/bbt_time.h" #include "pbd/stateful_diff_command.h" #include "pbd/openuri.h" + +#include "temporal/bbt_time.h" + #include "evoral/Control.hpp" #include "evoral/ControlList.hpp" #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" @@ -35,9 +38,14 @@ #include "ardour/audio_track.h" #include "ardour/audioplaylist.h" #include "ardour/buffer_set.h" +#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" #include "ardour/interthread_info.h" #include "ardour/lua_api.h" @@ -55,11 +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" @@ -68,6 +81,8 @@ #include "ardour/stripable.h" #include "ardour/track.h" #include "ardour/tempo.h" +#include "ardour/vca.h" +#include "ardour/vca_manager.h" #include "LuaBridge/LuaBridge.h" @@ -137,23 +152,36 @@ luabridge::getIdentityKey () template void const* luabridge::ClassInfo< CLS >::getConstKey(); CLASSINFO(ArdourMarker); +CLASSINFO(AxisView); CLASSINFO(MarkerSelection); CLASSINFO(PublicEditor); CLASSINFO(RegionSelection); +CLASSINFO(RegionView); +CLASSINFO(StripableTimeAxisView); +CLASSINFO(RouteTimeAxisView); +CLASSINFO(RouteUI); +CLASSINFO(Selectable); CLASSINFO(Selection); +CLASSINFO(TimeAxisView); +CLASSINFO(TimeAxisViewItem); CLASSINFO(TimeSelection); CLASSINFO(TrackSelection); CLASSINFO(TrackViewList); -CLASSKEYS(std::bitset<47ul>); // LuaSignal::LAST_SIGNAL + +CLASSKEYS(std::bitset<48ul>); // LuaSignal::LAST_SIGNAL CLASSKEYS(void); CLASSKEYS(float); CLASSKEYS(unsigned char); CLASSKEYS(ArdourMarker*); +CLASSKEYS(Selectable*); +CLASSKEYS(std::list); CLASSKEYS(ARDOUR::AudioEngine); +CLASSKEYS(ARDOUR::BeatsSamplesConverter); +CLASSKEYS(ARDOUR::DoubleBeatsSamplesConverter); CLASSKEYS(ARDOUR::BufferSet); CLASSKEYS(ARDOUR::ChanCount); CLASSKEYS(ARDOUR::ChanMapping); @@ -175,39 +203,52 @@ CLASSKEYS(ARDOUR::Plugin::PresetRecord); CLASSKEYS(ARDOUR::PortEngine); CLASSKEYS(ARDOUR::PortManager); CLASSKEYS(ARDOUR::PresentationInfo); +CLASSKEYS(ARDOUR::RCConfiguration); CLASSKEYS(ARDOUR::Session); CLASSKEYS(ARDOUR::SessionConfiguration); +CLASSKEYS(ARDOUR::Slavable); CLASSKEYS(ARDOUR::Source); +CLASSKEYS(ARDOUR::VCA); +CLASSKEYS(ARDOUR::VCAManager); CLASSKEYS(PBD::ID); CLASSKEYS(PBD::Configuration); CLASSKEYS(PBD::PropertyChange); CLASSKEYS(PBD::StatefulDestructible); -CLASSKEYS(Evoral::Beats); -CLASSKEYS(Evoral::Event); +CLASSKEYS(Temporal::Beats); +CLASSKEYS(Evoral::Event); +CLASSKEYS(Evoral::ControlEvent); CLASSKEYS(std::vector); CLASSKEYS(std::vector); CLASSKEYS(std::vector); CLASSKEYS(std::vector); +CLASSKEYS(std::list); + +CLASSKEYS(std::list); CLASSKEYS(std::vector); CLASSKEYS(std::vector >); CLASSKEYS(std::vector >); +CLASSKEYS(std::list >); // PluginInfoList CLASSKEYS(std::list); +CLASSKEYS(std::list); CLASSKEYS(std::list); CLASSKEYS(std::list >); CLASSKEYS(std::list >); CLASSKEYS(std::list >); +CLASSKEYS(std::list >); +CLASSKEYS(boost::shared_ptr > >); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); -CLASSKEYS(boost::shared_ptr >); +CLASSKEYS(boost::shared_ptr >); CLASSKEYS(boost::shared_ptr); +CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); @@ -217,10 +258,14 @@ CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::shared_ptr); -CLASSKEYS(boost::shared_ptr >); -CLASSKEYS(boost::shared_ptr >); +CLASSKEYS(boost::shared_ptr >); +CLASSKEYS(boost::shared_ptr >); +CLASSKEYS(boost::shared_ptr); +CLASSKEYS(boost::shared_ptr); +CLASSKEYS(boost::shared_ptr); CLASSKEYS(boost::weak_ptr); +CLASSKEYS(boost::weak_ptr); CLASSKEYS(Vamp::RealTime); CLASSKEYS(Vamp::PluginBase); @@ -236,6 +281,12 @@ namespace LuaCairo { class ImageSurface; class PangoLayout; } + +namespace LuaDialog { + class Message; + class Dialog; +} + namespace Cairo { class Context; } @@ -244,6 +295,9 @@ CLASSKEYS(Cairo::Context); CLASSKEYS(LuaCairo::ImageSurface); CLASSKEYS(LuaCairo::PangoLayout); +CLASSKEYS(LuaDialog::Message); +CLASSKEYS(LuaDialog::Dialog); + #endif // end windows special case /* Some notes on Lua bindings for libardour and friends @@ -269,6 +323,11 @@ CLASSKEYS(LuaCairo::PangoLayout); using namespace ARDOUR; +/** Access libardour global configuration */ +static RCConfiguration* _libardour_config () { + return ARDOUR::Config; +} + void LuaBindings::stddef (lua_State* L) { @@ -299,6 +358,10 @@ LuaBindings::stddef (lua_State* L) .beginStdVector ("FloatArrayVector") .endClass () + // samplepos_t, sampleoffset_t lists e.g. AnalysisFeatureList + .beginStdList ("Int64List") + .endClass () + // TODO std::set .endNamespace (); } @@ -423,6 +486,20 @@ LuaBindings::common (lua_State* L) //.addStaticData ("ticks_per_beat", &Timecode::BBT_Time::ticks_per_beat, false) .endClass () + .beginClass ("Time") + .addConstructor () + .addData ("negative", &Timecode::Time::negative) + .addData ("hours", &Timecode::Time::hours) + .addData ("minutes", &Timecode::Time::minutes) + .addData ("seconds", &Timecode::Time::seconds) + .addData ("frames", &Timecode::Time::frames) + .addData ("subframes", &Timecode::Time::subframes) + .addData ("rate", &Timecode::Time::rate) + .addData ("drop", &Timecode::Time::drop) + .endClass () + + // TODO add increment, decrement; push it into the class + /* libtimecode enums */ .beginNamespace ("TimecodeFormat") .addConst ("TC23976", Timecode::TimecodeFormat(Timecode::timecode_23976)) @@ -442,17 +519,17 @@ LuaBindings::common (lua_State* L) luabridge::getGlobalNamespace (L) .beginNamespace ("Evoral") - .beginClass > ("Event") - .addFunction ("clear", &Evoral::Event::clear) - .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::Event::time) + .beginClass > ("Event") + .addFunction ("clear", &Evoral::Event::clear) + .addFunction ("size", &Evoral::Event::size) + .addFunction ("set_buffer", &Evoral::Event::set_buffer) + .addFunction ("buffer", (uint8_t*(Evoral::Event::*)())&Evoral::Event::buffer) + .addFunction ("time", (samplepos_t (Evoral::Event::*)())&Evoral::Event::time) .endClass () - .beginClass ("Beats") + .beginClass ("Beats") .addConstructor () - .addFunction ("to_double", &Evoral::Beats::to_double) + .addFunction ("to_double", &Temporal::Beats::to_double) .endClass () .beginClass ("Parameter") @@ -462,8 +539,14 @@ LuaBindings::common (lua_State* L) .addFunction ("id", &Evoral::Parameter::id) .endClass () + .beginClass ("ControlEvent") + .addData ("when", &Evoral::ControlEvent::when) + .addData ("value", &Evoral::ControlEvent::value) + .endClass () + .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) @@ -472,7 +555,9 @@ LuaBindings::common (lua_State* L) .addFunction ("truncate_end", &Evoral::ControlList::truncate_end) .addFunction ("truncate_start", &Evoral::ControlList::truncate_start) .addFunction ("clear", (void (Evoral::ControlList::*)(double, double))&Evoral::ControlList::clear) + .addFunction ("clear_list", (void (Evoral::ControlList::*)())&Evoral::ControlList::clear) .addFunction ("in_write_pass", &Evoral::ControlList::in_write_pass) + .addFunction ("events", &Evoral::ControlList::events) .endClass () .beginWSPtrClass ("ControlSet") @@ -488,24 +573,25 @@ LuaBindings::common (lua_State* L) .addData ("upper", &Evoral::ParameterDescriptor::upper) .addData ("normal", &Evoral::ParameterDescriptor::normal) .addData ("toggled", &Evoral::ParameterDescriptor::toggled) + .addData ("logarithmic", &Evoral::ParameterDescriptor::logarithmic) .endClass () - .beginClass > ("Range") - .addConstructor () - .addData ("from", &Evoral::Range::from) - .addData ("to", &Evoral::Range::to) + .beginClass > ("Range") + .addConstructor () + .addData ("from", &Evoral::Range::from) + .addData ("to", &Evoral::Range::to) .endClass () - .deriveWSPtrClass , Evoral::ControlSet> ("Sequence") + .deriveWSPtrClass , Evoral::ControlSet> ("Sequence") .endClass () - .beginWSPtrClass > ("NotePtr") - .addFunction ("time", &Evoral::Note::time) - .addFunction ("note", &Evoral::Note::note) - .addFunction ("velocity", &Evoral::Note::velocity) - .addFunction ("off_velocity", &Evoral::Note::off_velocity) - .addFunction ("length", &Evoral::Note::length) - .addFunction ("channel", &Evoral::Note::channel) + .beginWSPtrClass > ("NotePtr") + .addFunction ("time", &Evoral::Note::time) + .addFunction ("note", &Evoral::Note::note) + .addFunction ("velocity", &Evoral::Note::velocity) + .addFunction ("off_velocity", &Evoral::Note::off_velocity) + .addFunction ("length", &Evoral::Note::length) + .addFunction ("channel", &Evoral::Note::channel) .endClass () /* libevoral enums */ @@ -645,8 +731,18 @@ LuaBindings::common (lua_State* L) .addData ("progress", const_cast(&InterThreadInfo::progress)) .endClass () + .beginClass ("Progress") + .endClass () + + .beginClass ("MusicSample") + .addConstructor () + .addFunction ("set", &MusicSample::set) + .addData ("frame", &MusicSample::sample) + .addData ("division", &MusicSample::division) + .endClass () + .beginClass ("AudioRange") - .addConstructor () + .addConstructor () .addFunction ("length", &AudioRange::length) .addFunction ("equal", &AudioRange::equal) .addData ("start", &AudioRange::start) @@ -655,7 +751,7 @@ LuaBindings::common (lua_State* L) .endClass () .beginWSPtrClass ("PluginInfo") - .addVoidConstructor () + .addNilPtrConstructor () .addData ("name", &PluginInfo::name, false) .addData ("category", &PluginInfo::category, false) .addData ("creator", &PluginInfo::creator, false) @@ -688,7 +784,7 @@ LuaBindings::common (lua_State* L) // templated class definitions .beginClass > ("BoolProperty").endClass () .beginClass > ("FloatProperty").endClass () - .beginClass > ("FrameposProperty").endClass () + .beginClass > ("FrameposProperty").endClass () // actual references (TODO: also expose GQuark for std::set) // ardour/region.h .addConst ("Start", &ARDOUR::Properties::start) @@ -703,7 +799,7 @@ LuaBindings::common (lua_State* L) // expand templated PropertyDescriptor .addFunction ("containsBool", &PBD::PropertyChange::contains) .addFunction ("containsFloat", &PBD::PropertyChange::contains) - .addFunction ("containsFramePos", &PBD::PropertyChange::contains) + .addFunction ("containsFramePos", &PBD::PropertyChange::contains) .endClass () .beginClass ("PropertyList") @@ -713,10 +809,10 @@ LuaBindings::common (lua_State* L) .deriveClass ("OwnedPropertyList") .endClass () - .beginWSPtrClass ("AutomationList") + .deriveWSPtrClass ("AutomationList") .addCast ("to_stateful") .addCast ("to_statefuldestructible") - .addCast ("list") + .addCast ("list") // deprecated .addFunction ("get_state", &AutomationList::get_state) .addFunction ("memento_command", &AutomationList::memento_command) .addFunction ("touching", &AutomationList::touching) @@ -735,6 +831,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) @@ -755,12 +852,13 @@ 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) .endClass () - .beginWSPtrClass ("SessionObject") + .beginWSPtrClass ("SessionObjectPtr") /* SessionObject is-a PBD::StatefulDestructible, * but multiple inheritance is not covered by luabridge, * we need explicit casts */ @@ -769,8 +867,14 @@ LuaBindings::common (lua_State* L) .addFunction ("name", &SessionObject::name) .endClass () + .beginClass ("SessionObject") + .addFunction ("name", &SessionObject::name) + .addCast ("to_stateful") + .endClass () + .beginWSPtrClass ("Port") .addCast ("to_midiport") + .addCast ("to_asyncmidiport") .addCast ("to_audioport") .addFunction ("name", &Port::name) .addFunction ("pretty_name", &Port::pretty_name) @@ -781,6 +885,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 () @@ -788,11 +896,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) @@ -817,6 +930,8 @@ LuaBindings::common (lua_State* L) .addFunction ("midi", &IO::midi) .addFunction ("port_by_name", &IO::nth) .addFunction ("n_ports", &IO::n_ports) + .addFunction ("latency", &IO::latency) + .addFunction ("public_latency", &IO::latency) .endClass () .deriveWSPtrClass ("PannerShell") @@ -824,7 +939,7 @@ LuaBindings::common (lua_State* L) .addFunction ("set_bypassed", &PannerShell::set_bypassed) .endClass () - .beginClass ("RouteGroup") + .deriveClass ("RouteGroup") .addFunction ("is_active", &RouteGroup::is_active) .addFunction ("is_relative", &RouteGroup::is_relative) .addFunction ("is_hidden", &RouteGroup::is_hidden) @@ -853,6 +968,8 @@ LuaBindings::common (lua_State* L) .addFunction ("add", &RouteGroup::add) .addFunction ("remove", &RouteGroup::remove) .addFunction ("clear", &RouteGroup::clear) + .addFunction ("set_rgba", &RouteGroup::set_rgba) + .addFunction ("rgba", &RouteGroup::rgba) .addFunction ("has_subgroup", &RouteGroup::has_subgroup) .addFunction ("make_subgroup", &RouteGroup::make_subgroup) .addFunction ("destroy_subgroup", &RouteGroup::destroy_subgroup) @@ -863,12 +980,25 @@ LuaBindings::common (lua_State* L) .addFunction ("color", &PresentationInfo::color) .addFunction ("set_color", &PresentationInfo::set_color) .addFunction ("order", &PresentationInfo::order) + .addFunction ("special", &PresentationInfo::special) + .addFunction ("flags", &PresentationInfo::flags) .addConst ("max_order", ARDOUR::PresentationInfo::max_order) .endClass () + .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) .addFunction ("is_monitor", &Stripable::is_monitor) .addFunction ("is_hidden", &Stripable::is_hidden) @@ -901,18 +1031,30 @@ LuaBindings::common (lua_State* L) .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_enable_control ", &Stripable::eq_enable_controllable ) .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 ("filter_freq_controllable ", &Stripable::filter_freq_controllable ) + .addFunction ("filter_slope_controllable ", &Stripable::filter_slope_controllable ) + .addFunction ("filter_enable_controllable ", &Stripable::filter_enable_controllable ) .addFunction ("set_presentation_order", &Stripable::set_presentation_order) .addFunction ("presentation_info_ptr", &Stripable::presentation_info_ptr) .endClass () + .deriveWSPtrClass ("VCA") + .addFunction ("full_name", &VCA::full_name) + .addFunction ("number", &VCA::number) + .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") .addFunction ("set_name", &Route::set_name) @@ -924,7 +1066,9 @@ LuaBindings::common (lua_State* L) .addFunction ("nth_send", &Route::nth_send) .addFunction ("add_processor_by_index", &Route::add_processor_by_index) .addFunction ("remove_processor", &Route::remove_processor) + .addFunction ("remove_processors", &Route::remove_processors) .addFunction ("replace_processor", &Route::replace_processor) + .addFunction ("reorder_processors", &Route::reorder_processors) .addFunction ("the_instrument", &Route::the_instrument) .addFunction ("n_inputs", &Route::n_inputs) .addFunction ("n_outputs", &Route::n_outputs) @@ -945,6 +1089,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 ("signal_latency", &Route::signal_latency) + .addFunction ("playback_latency", &Route::playback_latency) .endClass () .deriveWSPtrClass ("Playlist") @@ -953,13 +1099,14 @@ LuaBindings::common (lua_State* L) .addFunction ("region_by_id", &Playlist::region_by_id) .addFunction ("data_type", &Playlist::data_type) .addFunction ("n_regions", &Playlist::n_regions) - //.addFunction ("get_extent", &Playlist::get_extent) // pair + //.addFunction ("get_extent", &Playlist::get_extent) // pair .addFunction ("region_list", &Playlist::region_list) .addFunction ("add_region", &Playlist::add_region) .addFunction ("remove_region", &Playlist::remove_region) .addFunction ("regions_at", &Playlist::regions_at) .addFunction ("top_region_at", &Playlist::top_region_at) .addFunction ("top_unmuted_region_at", &Playlist::top_unmuted_region_at) + .addFunction ("find_next_transient", &Playlist::find_next_transient) .addFunction ("find_next_region", &Playlist::find_next_region) .addFunction ("find_next_region_boundary", &Playlist::find_next_region_boundary) .addFunction ("count_regions_at", &Playlist::count_regions_at) @@ -970,13 +1117,13 @@ LuaBindings::common (lua_State* L) .addFunction ("lower_region", &Playlist::lower_region) .addFunction ("raise_region_to_top", &Playlist::raise_region_to_top) .addFunction ("lower_region_to_bottom", &Playlist::lower_region_to_bottom) - .addFunction ("duplicate", (void (Playlist::*)(boost::shared_ptr, framepos_t, framecnt_t, float))&Playlist::duplicate) + .addFunction ("duplicate", (void (Playlist::*)(boost::shared_ptr, samplepos_t, samplecnt_t, float))&Playlist::duplicate) .addFunction ("duplicate_until", &Playlist::duplicate_until) .addFunction ("duplicate_range", &Playlist::duplicate_range) .addFunction ("combine", &Playlist::combine) .addFunction ("uncombine", &Playlist::uncombine) .addFunction ("split_region", &Playlist::split_region) - .addFunction ("split", (void (Playlist::*)(framepos_t))&Playlist::split) + .addFunction ("split", (void (Playlist::*)(samplepos_t))&Playlist::split) .addFunction ("cut", (boost::shared_ptr (Playlist::*)(std::list&, bool))&Playlist::cut) #if 0 .addFunction ("copy", &Playlist::copy) @@ -1045,6 +1192,10 @@ LuaBindings::common (lua_State* L) .addFunction ("covers", &Region::covers) .addFunction ("at_natural_position", &Region::at_natural_position) .addFunction ("is_compound", &Region::is_compound) + + .addFunction ("has_transients", &Region::has_transients) + .addFunction ("transients", (AnalysisFeatureList (Region::*)())&Region::transients) + /* editing operations */ .addFunction ("set_length", &Region::set_length) .addFunction ("set_start", &Region::set_start) @@ -1075,12 +1226,13 @@ LuaBindings::common (lua_State* L) .addFunction ("set_video_locked", &Region::set_video_locked) .addFunction ("set_position_locked", &Region::set_position_locked) .addFunction ("source", &Region::source) + .addFunction ("control", static_cast(Region::*)(const Evoral::Parameter&, bool)>(&Region::control)) .endClass () .deriveWSPtrClass ("MidiRegion") .addFunction ("do_export", &MidiRegion::do_export) .addFunction ("midi_source", &MidiRegion::midi_source) - .addFunction ("model", (boost::shared_ptr (MidiRegion::*)())&MidiRegion::midi_source) + .addFunction ("model", (boost::shared_ptr (MidiRegion::*)())&MidiRegion::model) .addFunction ("start_beats", &MidiRegion::start_beats) .addFunction ("length_beats", &MidiRegion::length_beats) .endClass () @@ -1089,11 +1241,15 @@ LuaBindings::common (lua_State* L) .addFunction ("audio_source", &AudioRegion::audio_source) .addFunction ("set_scale_amplitude", &AudioRegion::set_scale_amplitude) .addFunction ("scale_amplitude", &AudioRegion::scale_amplitude) + .addFunction ("maximum_amplitude", &AudioRegion::maximum_amplitude) + .addFunction ("rms", &AudioRegion::rms) + .addRefFunction ("separate_by_channel", &AudioRegion::separate_by_channel) .endClass () .deriveWSPtrClass ("Source") .addCast ("to_audiosource") .addCast ("to_midisource") + .addCast ("to_filesource") .addFunction ("timestamp", &Source::timestamp) .addFunction ("empty", &Source::empty) .addFunction ("length", &Source::length) @@ -1108,6 +1264,15 @@ LuaBindings::common (lua_State* L) .addFunction ("ancestor_name", &Source::ancestor_name) .endClass () + .deriveWSPtrClass ("FileSource") + .addFunction ("path", &FileSource::path) + .addFunction ("within_session", &FileSource::within_session) + .addFunction ("channel", &FileSource::channel) + .addFunction ("origin", &FileSource::origin) + .addFunction ("take_id", &FileSource::take_id) + .addFunction ("gain", &FileSource::gain) + .endClass () + .deriveWSPtrClass ("MidiSource") .addFunction ("empty", &MidiSource::empty) .addFunction ("length", &MidiSource::length) @@ -1126,14 +1291,16 @@ LuaBindings::common (lua_State* L) .endClass () .deriveWSPtrClass ("Automatable") + .addCast ("to_slavable") .addFunction ("automation_control", (boost::shared_ptr(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control) + //.addFunction ("what_can_be_automated", &Automatable::what_can_be_automated) .endClass () - .deriveWSPtrClass , Automatable> ("AutomatableSequence") - .addCast > ("to_sequence") + .deriveWSPtrClass , Automatable> ("AutomatableSequence") + .addCast > ("to_sequence") .endClass () - .deriveWSPtrClass > ("MidiModel") + .deriveWSPtrClass > ("MidiModel") .addFunction ("apply_command", (void (MidiModel::*)(Session*, Command*))&MidiModel::apply_command) .addFunction ("new_note_diff_command", &MidiModel::new_note_diff_command) .endClass () @@ -1158,11 +1325,11 @@ LuaBindings::common (lua_State* L) .endClass () .beginStdVector ("PresetVector").endClass () + .beginStdList > ("PluginInfoList").endClass () .deriveClass ("ParameterDescriptor") .addVoidConstructor () .addData ("label", &ParameterDescriptor::label) - .addData ("logarithmic", &ParameterDescriptor::logarithmic) .addStaticFunction ("midi_note_name", &ParameterDescriptor::midi_note_name) .endClass () @@ -1170,24 +1337,45 @@ LuaBindings::common (lua_State* L) .deriveWSPtrClass ("Processor") .addCast ("to_automatable") - .addCast ("to_insert") + .addCast ("to_insert") // deprecated + .addCast ("to_plugininsert") .addCast ("to_sidechain") .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) + .addFunction ("display_to_user", &Processor::display_to_user) .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") @@ -1204,6 +1392,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) @@ -1220,11 +1422,15 @@ LuaBindings::common (lua_State* L) .addFunction ("name", &Plugin::name) .addFunction ("maker", &Plugin::maker) .addFunction ("parameter_count", &Plugin::parameter_count) + .addFunction ("parameter_label", &Plugin::parameter_label) .addRefFunction ("nth_parameter", &Plugin::nth_parameter) .addFunction ("preset_by_label", &Plugin::preset_by_label) .addFunction ("preset_by_uri", &Plugin::preset_by_uri) .addFunction ("load_preset", &Plugin::load_preset) .addFunction ("parameter_is_input", &Plugin::parameter_is_input) + .addFunction ("parameter_is_output", &Plugin::parameter_is_output) + .addFunction ("parameter_is_control", &Plugin::parameter_is_control) + .addFunction ("parameter_is_audio", &Plugin::parameter_is_audio) .addFunction ("get_docs", &Plugin::get_docs) .addFunction ("get_info", &Plugin::get_info) .addFunction ("get_parameter_docs", &Plugin::get_parameter_docs) @@ -1248,14 +1454,25 @@ LuaBindings::common (lua_State* L) .addFunction ("set_output_map", &PluginInsert::set_output_map) .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") + .addFunction ("get_parameter", &ReadOnlyControl::get_parameter) + .addFunction ("describe_parameter", &ReadOnlyControl::describe_parameter) + .addFunction ("desc", &ReadOnlyControl::desc) .endClass () .deriveWSPtrClass ("AutomationControl") .addCast ("to_ctrl") + .addCast ("to_slavable") .addFunction ("automation_state", &AutomationControl::automation_state) - .addFunction ("automation_style", &AutomationControl::automation_style) .addFunction ("set_automation_state", &AutomationControl::set_automation_state) - .addFunction ("set_automation_style", &AutomationControl::set_automation_style) .addFunction ("start_touch", &AutomationControl::start_touch) .addFunction ("stop_touch", &AutomationControl::stop_touch) .addFunction ("get_value", &AutomationControl::get_value) @@ -1264,7 +1481,7 @@ LuaBindings::common (lua_State* L) .addFunction ("alist", &AutomationControl::alist) .endClass () - .deriveWSPtrClass ("SlavableAutomationControl,") + .deriveWSPtrClass ("SlavableAutomationControl") .addFunction ("add_master", &SlavableAutomationControl::add_master) .addFunction ("remove_master", &SlavableAutomationControl::remove_master) .addFunction ("clear_masters", &SlavableAutomationControl::clear_masters) @@ -1345,9 +1562,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) @@ -1365,16 +1597,29 @@ LuaBindings::common (lua_State* L) .beginConstStdList > ("RouteList") .endClass () + // StripableList == std::list > + .beginConstStdList > ("StripableList") + .endClass () + + // VCAList == std::list > + .beginConstStdList > ("VCAList") + .endClass () + + // VCAVector == std::vector > + .beginConstStdVector > ("VCAVector") + .endClass () + // boost::shared_ptr .beginPtrStdList > ("RouteListPtr") + .addVoidPtrConstructor > > () .endClass () // typedef std::list > WeakRouteList .beginConstStdList > ("WeakRouteList") .endClass () - // RouteList == std::list > - .beginConstStdList ("RouteGroupList") + // RouteGroupList == std::list + .beginConstStdCPtrList ("RouteGroupList") .endClass () // typedef std::vector > Region::SourceList @@ -1385,12 +1630,25 @@ LuaBindings::common (lua_State* L) .beginConstStdList > ("WeakAudioSourceList") .endClass () + // typedef std::vector > RegionVector + .beginStdVector > ("RegionVector") + .endClass () + // typedef std::list > RegionList .beginConstStdList > ("RegionList") .endClass () // boost::shared_ptr > > .beginPtrStdList > ("RegionListPtr") + .addVoidPtrConstructor > > () + .endClass () + + // RegionFactory::RegionMap + .beginStdMap > ("RegionMap") + .endClass () + + // typedef std::list > ProcessorList; + .beginStdList > ("ProcessorList") .endClass () //std::list > PortList; @@ -1404,8 +1662,22 @@ LuaBindings::common (lua_State* L) .beginConstStdList ("LocationList") .endClass () + // std::list > ControlList; + .beginStdList > ("ControlList") + .endClass () + + .beginPtrStdList > ("ControlListPtr") + .addVoidPtrConstructor > > () + .endClass () + + .beginStdList > > ("NotePtrList") + .endClass () + + .beginConstStdList ("EventList") + .endClass () + #if 0 // depends on Evoal:: Note, Beats see note_fixer.h - // typedef Evoral::Note Note; + // typedef Evoral::Note Note; // std::set< boost::weak_ptr > .beginStdSet > ("WeakNoteSet") .endClass () @@ -1416,31 +1688,46 @@ LuaBindings::common (lua_State* L) .endClass () .beginClass ("Tempo") - .addConstructor () + .addConstructor () .addFunction ("note_type", &Tempo::note_type) .addFunction ("note_types_per_minute", (double (Tempo::*)() const)&Tempo::note_types_per_minute) .addFunction ("quarter_notes_per_minute", &Tempo::quarter_notes_per_minute) - .addFunction ("frames_per_quarter_note", &Tempo::frames_per_quarter_note) - .addFunction ("frames_per_note_type", &Tempo::frames_per_note_type) + .addFunction ("samples_per_quarter_note", &Tempo::samples_per_quarter_note) + .addFunction ("samples_per_note_type", &Tempo::samples_per_note_type) .endClass () .beginClass ("Meter") .addConstructor () .addFunction ("divisions_per_bar", &Meter::divisions_per_bar) .addFunction ("note_divisor", &Meter::note_divisor) - .addFunction ("frames_per_bar", &Meter::frames_per_bar) - .addFunction ("frames_per_grid", &Meter::frames_per_grid) + .addFunction ("samples_per_bar", &Meter::samples_per_bar) + .addFunction ("samples_per_grid", &Meter::samples_per_grid) + .endClass () + + .beginClass ("BeatsSamplesConverter") + .addConstructor () + .addFunction ("to", &BeatsSamplesConverter::to) + .addFunction ("from", &BeatsSamplesConverter::from) + .endClass () + + .beginClass ("DoubleBeatsSamplesConverter") + .addConstructor () + .addFunction ("to", &DoubleBeatsSamplesConverter::to) + .addFunction ("from", &DoubleBeatsSamplesConverter::from) .endClass () .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 ("tempo_section_at_frame", (TempoSection& (TempoMap::*)(samplepos_t))&TempoMap::tempo_section_at_sample) + .addFunction ("tempo_section_at_frame", (const TempoSection& (TempoMap::*)(samplepos_t) const)&TempoMap::tempo_section_at_sample) + .addFunction ("meter_section_at_frame", &TempoMap::meter_section_at_sample) .addFunction ("meter_section_at_beat", &TempoMap::meter_section_at_beat) - .addFunction ("bbt_at_frame", &TempoMap::bbt_at_frame) - .addFunction ("exact_beat_at_frame", &TempoMap::exact_beat_at_frame) - .addFunction ("exact_qn_at_frame", &TempoMap::exact_qn_at_frame) + .addFunction ("bbt_at_frame", &TempoMap::bbt_at_sample) + .addFunction ("exact_beat_at_frame", &TempoMap::exact_beat_at_sample) + .addFunction ("exact_qn_at_frame", &TempoMap::exact_qn_at_sample) + .addFunction ("samplepos_plus_qn", &TempoMap::samplepos_plus_qn) + .addFunction ("framewalk_to_qn", &TempoMap::framewalk_to_qn) .endClass () .beginClass ("MetricSection") @@ -1449,7 +1736,7 @@ LuaBindings::common (lua_State* L) .endClass () .deriveClass ("TempoSection") - .addFunction ("c_func", (double(TempoSection::*)()const)&TempoSection::c_func) + .addFunction ("c", (double(TempoSection::*)()const)&TempoSection::c) .endClass () .deriveClass ("MeterSection") @@ -1497,23 +1784,18 @@ LuaBindings::common (lua_State* L) .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)) - .endNamespace () - .beginNamespace ("AutoState") .addConst ("Off", ARDOUR::AutoState(Off)) .addConst ("Write", ARDOUR::AutoState(Write)) .addConst ("Touch", ARDOUR::AutoState(Touch)) .addConst ("Play", ARDOUR::AutoState(Play)) + .addConst ("Latch", ARDOUR::AutoState(Latch)) .endNamespace () .beginNamespace ("AutomationType") @@ -1527,6 +1809,12 @@ LuaBindings::common (lua_State* L) .addConst ("RecSafeAutomation", ARDOUR::AutomationType(RecSafeAutomation)) .addConst ("TrimAutomation", ARDOUR::AutomationType(TrimAutomation)) .addConst ("PhaseAutomation", ARDOUR::AutomationType(PhaseAutomation)) + .addConst ("MidiCCAutomation", ARDOUR::AutomationType(MidiCCAutomation)) + .addConst ("MidiPgmChangeAutomation", ARDOUR::AutomationType(MidiPgmChangeAutomation)) + .addConst ("MidiPitchBenderAutomation", ARDOUR::AutomationType(MidiPitchBenderAutomation)) + .addConst ("MidiChannelPressureAutomation", ARDOUR::AutomationType(MidiChannelPressureAutomation)) + .addConst ("MidiNotePressureAutomation", ARDOUR::AutomationType(MidiNotePressureAutomation)) + .addConst ("MidiSystemExclusiveAutomation", ARDOUR::AutomationType(MidiSystemExclusiveAutomation)) .endNamespace () .beginNamespace ("SrcQuality") @@ -1563,6 +1851,13 @@ LuaBindings::common (lua_State* L) .addConst ("PostFader", ARDOUR::Placement(PostFader)) .endNamespace () + .beginNamespace ("MonitorChoice") + .addConst ("MonitorAuto", ARDOUR::MonitorChoice(MonitorAuto)) + .addConst ("MonitorInput", ARDOUR::MonitorChoice(MonitorInput)) + .addConst ("MonitorDisk", ARDOUR::MonitorChoice(MonitorDisk)) + .addConst ("MonitorCue", ARDOUR::MonitorChoice(MonitorCue)) + .endNamespace () + .beginNamespace ("NoteMode") .addConst ("Sustained", ARDOUR::NoteMode(Sustained)) .addConst ("Percussive", ARDOUR::NoteMode(Percussive)) @@ -1576,12 +1871,30 @@ LuaBindings::common (lua_State* L) .addConst ("IsTerminal", ARDOUR::PortFlags(IsTerminal)) .endNamespace () + .beginNamespace ("MidiPortFlags") + .addConst ("MidiPortMusic", ARDOUR::MidiPortFlags(MidiPortMusic)) + .addConst ("MidiPortControl", ARDOUR::MidiPortFlags(MidiPortControl)) + .addConst ("MidiPortSelection", ARDOUR::MidiPortFlags(MidiPortSelection)) + .addConst ("MidiPortVirtual", ARDOUR::MidiPortFlags(MidiPortVirtual)) + .endNamespace () + .beginNamespace ("PlaylistDisposition") .addConst ("CopyPlaylist", ARDOUR::PlaylistDisposition(CopyPlaylist)) .addConst ("NewPlaylist", ARDOUR::PlaylistDisposition(NewPlaylist)) .addConst ("SharePlaylist", ARDOUR::PlaylistDisposition(SharePlaylist)) .endNamespace () + .beginNamespace ("MidiTrackNameSource") + .addConst ("SMFTrackNumber", ARDOUR::MidiTrackNameSource(SMFTrackNumber)) + .addConst ("SMFTrackName", ARDOUR::MidiTrackNameSource(SMFTrackName)) + .addConst ("SMFInstrumentName", ARDOUR::MidiTrackNameSource(SMFInstrumentName)) + .endNamespace () + + .beginNamespace ("MidiTempoMapDisposition") + .addConst ("SMFTempoIgnore", ARDOUR::MidiTempoMapDisposition(SMFTempoIgnore)) + .addConst ("SMFTempoUse", ARDOUR::MidiTempoMapDisposition(SMFTempoUse)) + .endNamespace () + .beginNamespace ("RegionPoint") .addConst ("Start", ARDOUR::RegionPoint(Start)) .addConst ("End", ARDOUR::RegionPoint(End)) @@ -1635,6 +1948,107 @@ LuaBindings::common (lua_State* L) .addConst ("Extend", ARDOUR::InsertMergePolicy(InsertMergeExtend)) .endNamespace () + .beginNamespace ("AFLPosition") + .addConst ("AFLFromBeforeProcessors", ARDOUR::AFLPosition(AFLFromBeforeProcessors)) + .addConst ("AFLFromAfterProcessors", ARDOUR::AFLPosition(AFLFromAfterProcessors)) + .endNamespace () + + .beginNamespace ("PFLPosition") + .addConst ("PFLFromBeforeProcessors", ARDOUR::PFLPosition(PFLFromBeforeProcessors)) + .addConst ("PFLFromAfterProcessors", ARDOUR::PFLPosition(PFLFromAfterProcessors)) + .endNamespace () + + .beginNamespace ("AutoReturnTarget") + .addConst ("LastLocate", ARDOUR::AutoReturnTarget(LastLocate)) + .addConst ("RangeSelectionStart", ARDOUR::AutoReturnTarget(RangeSelectionStart)) + .addConst ("Loop", ARDOUR::AutoReturnTarget(Loop)) + .addConst ("RegionSelectionStart", ARDOUR::AutoReturnTarget(RegionSelectionStart)) + .endNamespace () + + .beginNamespace ("FadeShape") + .addConst ("FadeLinear", ARDOUR::FadeShape(FadeLinear)) + .addConst ("FadeFast", ARDOUR::FadeShape(FadeFast)) + .addConst ("FadeSlow", ARDOUR::FadeShape(FadeSlow)) + .addConst ("FadeConstantPower", ARDOUR::FadeShape(FadeConstantPower)) + .addConst ("FadeSymmetric", ARDOUR::FadeShape(FadeSymmetric)) + .endNamespace () + + .beginNamespace ("DenormalModel") + .addConst ("DenormalNone", ARDOUR::DenormalModel(DenormalNone)) + .addConst ("DenormalFTZ", ARDOUR::DenormalModel(DenormalFTZ)) + .addConst ("DenormalDAZ", ARDOUR::DenormalModel(DenormalDAZ)) + .addConst ("DenormalFTZDAZ", ARDOUR::DenormalModel(DenormalFTZDAZ)) + .endNamespace () + + .beginNamespace ("BufferingPreset") + .addConst ("Small", ARDOUR::BufferingPreset(Small)) + .addConst ("Medium", ARDOUR::BufferingPreset(Medium)) + .addConst ("Large", ARDOUR::BufferingPreset(Large)) + .addConst ("Custom", ARDOUR::BufferingPreset(Custom)) + .endNamespace () + + .beginNamespace ("EditMode") + .addConst ("Slide", ARDOUR::EditMode(Slide)) + .addConst ("Splice", ARDOUR::EditMode(Splice)) + .addConst ("Ripple", ARDOUR::EditMode(Ripple)) + .addConst ("Lock", ARDOUR::EditMode(Lock)) + .endNamespace () + + .beginNamespace ("AutoConnectOption") + .addConst ("ManualConnect", ARDOUR::AutoConnectOption(ManualConnect)) + .addConst ("AutoConnectPhysical", ARDOUR::AutoConnectOption(AutoConnectPhysical)) + .addConst ("AutoConnectMaster", ARDOUR::AutoConnectOption(AutoConnectMaster)) + .endNamespace () + + .beginNamespace ("LayerModel") + .addConst ("LaterHigher", ARDOUR::LayerModel(LaterHigher)) + .addConst ("Manual", ARDOUR::LayerModel(Manual)) + .endNamespace () + + .beginNamespace ("ListenPosition") + .addConst ("AfterFaderListen", ARDOUR::ListenPosition(AfterFaderListen)) + .addConst ("PreFaderListen", ARDOUR::ListenPosition(PreFaderListen)) + .endNamespace () + + .beginNamespace ("MonitorModel") + .addConst ("HardwareMonitoring", ARDOUR::MonitorModel(HardwareMonitoring)) + .addConst ("SoftwareMonitoring", ARDOUR::MonitorModel(SoftwareMonitoring)) + .addConst ("ExternalMonitoring", ARDOUR::MonitorModel(ExternalMonitoring)) + .endNamespace () + + .beginNamespace ("RegionSelectionAfterSplit") + .addConst ("None", ARDOUR::RegionSelectionAfterSplit(None)) + .addConst ("NewlyCreatedLeft", ARDOUR::RegionSelectionAfterSplit(NewlyCreatedLeft)) + .addConst ("NewlyCreatedRight", ARDOUR::RegionSelectionAfterSplit(NewlyCreatedRight)) + .addConst ("NewlyCreatedBoth", ARDOUR::RegionSelectionAfterSplit(NewlyCreatedBoth)) + .addConst ("Existing", ARDOUR::RegionSelectionAfterSplit(Existing)) + .addConst ("ExistingNewlyCreatedLeft", ARDOUR::RegionSelectionAfterSplit(ExistingNewlyCreatedLeft)) + .addConst ("ExistingNewlyCreatedRight", ARDOUR::RegionSelectionAfterSplit(ExistingNewlyCreatedRight)) + .addConst ("ExistingNewlyCreatedBoth", ARDOUR::RegionSelectionAfterSplit(ExistingNewlyCreatedBoth)) + .endNamespace () + + .beginNamespace ("ShuttleBehaviour") + .addConst ("Sprung", ARDOUR::ShuttleBehaviour(Sprung)) + .addConst ("Wheel", ARDOUR::ShuttleBehaviour(Wheel)) + .endNamespace () + + .beginNamespace ("ShuttleUnits") + .addConst ("Percentage", ARDOUR::ShuttleUnits(Percentage)) + .addConst ("Semitones", ARDOUR::ShuttleUnits(Semitones)) + .endNamespace () + + .beginNamespace ("SyncSource") + .addConst ("Engine", ARDOUR::SyncSource(Engine)) + .addConst ("MTC", ARDOUR::SyncSource(MTC)) + .addConst ("MIDIClock", ARDOUR::SyncSource(MIDIClock)) + .addConst ("LTC", ARDOUR::SyncSource(LTC)) + .endNamespace () + + .beginNamespace ("TracksAutoNamingRule") + .addConst ("UseDefaultNames", ARDOUR::TracksAutoNamingRule(UseDefaultNames)) + .addConst ("NameAfterDriver", ARDOUR::TracksAutoNamingRule(NameAfterDriver)) + .endNamespace () + .endNamespace (); // end ARDOUR luabridge::getGlobalNamespace (L) @@ -1642,7 +2056,7 @@ LuaBindings::common (lua_State* L) .beginClass ("AudioBackendInfo") .addData ("name", &AudioBackendInfo::name) .endClass() - .beginStdVector ("BackendVector").endClass () + .beginConstStdVector ("BackendVector").endClass () .beginClass ("DeviceStatus") .addData ("name", &AudioBackend::DeviceStatus::name) @@ -1679,7 +2093,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") @@ -1715,6 +2132,34 @@ LuaBindings::common (lua_State* L) .addFunction ("get_last_backend_error", &AudioEngine::get_last_backend_error) .endClass() + .deriveClass ("VCAManager") + .addFunction ("create_vca", &VCAManager::create_vca) + .addFunction ("remove_vca", &VCAManager::remove_vca) + .addFunction ("vca_by_number", &VCAManager::vca_by_number) + .addFunction ("vca_by_name", &VCAManager::vca_by_name) + .addFunction ("vcas", &VCAManager::vcas) + .addFunction ("n_vcas", &VCAManager::n_vcas) + .endClass() + + .deriveClass ("RCConfiguration") +#undef CONFIG_VARIABLE +#undef CONFIG_VARIABLE_SPECIAL +#define CONFIG_VARIABLE(Type,var,name,value) \ + .addFunction ("get_" # var, &RCConfiguration::get_##var) \ + .addFunction ("set_" # var, &RCConfiguration::set_##var) \ + .addProperty (#var, &RCConfiguration::get_##var, &RCConfiguration::set_##var) + +#define CONFIG_VARIABLE_SPECIAL(Type,var,name,value,mutator) \ + .addFunction ("get_" # var, &RCConfiguration::get_##var) \ + .addFunction ("set_" # var, &RCConfiguration::set_##var) \ + .addProperty (#var, &RCConfiguration::get_##var, &RCConfiguration::set_##var) + +#include "ardour/rc_configuration_vars.h" + +#undef CONFIG_VARIABLE +#undef CONFIG_VARIABLE_SPECIAL + .endClass() + .deriveClass ("SessionConfiguration") #undef CONFIG_VARIABLE #undef CONFIG_VARIABLE_SPECIAL @@ -1733,6 +2178,10 @@ LuaBindings::common (lua_State* L) #undef CONFIG_VARIABLE #undef CONFIG_VARIABLE_SPECIAL .endClass() + + // we could use addProperty () + .addFunction ("config", &_libardour_config) + .endNamespace (); // basic representation of Session @@ -1743,11 +2192,11 @@ 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_frame) + .addFunction ("transport_sample", &Session::transport_sample) .addFunction ("transport_speed", &Session::transport_speed) - .addFunction ("frame_rate", &Session::frame_rate) - .addFunction ("nominal_frame_rate", &Session::nominal_frame_rate) - .addFunction ("frames_per_timecode_frame", &Session::frames_per_timecode_frame) + .addFunction ("sample_rate", &Session::sample_rate) + .addFunction ("nominal_sample_rate", &Session::nominal_sample_rate) + .addFunction ("samples_per_timecode_frame", &Session::samples_per_timecode_frame) .addFunction ("timecode_frames_per_hour", &Session::timecode_frames_per_hour) .addFunction ("timecode_frames_per_second", &Session::timecode_frames_per_second) .addFunction ("timecode_drop_frames", &Session::timecode_drop_frames) @@ -1758,15 +2207,21 @@ LuaBindings::common (lua_State* L) .addFunction ("last_transport_start", &Session::last_transport_start) .addFunction ("goto_start", &Session::goto_start) .addFunction ("goto_end", &Session::goto_end) - .addFunction ("current_start_frame", &Session::current_start_frame) - .addFunction ("current_end_frame", &Session::current_end_frame) + .addFunction ("current_start_frame", &Session::current_start_sample) + .addFunction ("current_end_frame", &Session::current_end_sample) .addFunction ("actively_recording", &Session::actively_recording) .addFunction ("new_audio_track", &Session::new_audio_track) .addFunction ("new_audio_route", &Session::new_audio_route) .addFunction ("new_midi_track", &Session::new_midi_track) .addFunction ("new_midi_route", &Session::new_midi_route) + + .addFunction ("add_master_bus", &Session::add_master_bus) + .addFunction ("add_monitor_section", &Session::add_monitor_section) + .addFunction ("remove_monitor_section", &Session::remove_monitor_section) + .addFunction ("get_routes", &Session::get_routes) .addFunction ("get_tracks", &Session::get_tracks) + .addFunction ("get_stripables", (StripableList (Session::*)() const)&Session::get_stripables) .addFunction ("name", &Session::name) .addFunction ("path", &Session::path) .addFunction ("record_status", &Session::record_status) @@ -1774,18 +2229,27 @@ 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) - .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) .addFunction ("processor_by_id", &Session::processor_by_id) .addFunction ("snap_name", &Session::snap_name) .addFunction ("monitor_out", &Session::monitor_out) .addFunction ("master_out", &Session::master_out) + .addFunction ("add_internal_sends", &Session::add_internal_sends) .addFunction ("tempo_map", (TempoMap& (Session::*)())&Session::tempo_map) .addFunction ("locations", &Session::locations) + .addFunction ("soloing", &Session::soloing) + .addFunction ("listening", &Session::listening) + .addFunction ("solo_isolated", &Session::solo_isolated) + .addFunction ("cancel_all_solo", &Session::cancel_all_solo) + .addFunction ("clear_all_solo_state", &Session::clear_all_solo_state) + .addFunction ("set_controls", &Session::set_controls) + .addFunction ("set_control", &Session::set_control) + .addFunction ("set_exclusive_input_active", &Session::set_exclusive_input_active) .addFunction ("begin_reversible_command", (void (Session::*)(const std::string&))&Session::begin_reversible_command) .addFunction ("commit_reversible_command", &Session::commit_reversible_command) .addFunction ("abort_reversible_command", &Session::abort_reversible_command) @@ -1795,16 +2259,23 @@ 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_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) + .addFunction ("end_is_free", &Session::end_is_free) + .addFunction ("set_end_is_free", &Session::set_end_is_free) .addFunction ("remove_route_group", (void (Session::*)(RouteGroup*))&Session::remove_route_group) + .addFunction ("vca_manager", &Session::vca_manager_ptr) + .addExtCFunction ("timecode_to_sample_lua", ARDOUR::LuaAPI::timecode_to_sample_lua) + .addExtCFunction ("sample_to_timecode_lua", ARDOUR::LuaAPI::sample_to_timecode_lua) .endClass () .beginClass ("RegionFactory") .addStaticFunction ("region_by_id", &RegionFactory::region_by_id) + .addStaticFunction ("regions", &RegionFactory::regions) + .addStaticFunction ("clone_region", static_cast (*)(boost::shared_ptr, bool, bool)>(&RegionFactory::create)) .endClass () /* session enums (rt-safe, common) */ @@ -1834,17 +2305,24 @@ LuaBindings::common (lua_State* L) .beginNamespace ("LuaAPI") .addFunction ("nil_proc", ARDOUR::LuaAPI::nil_processor) .addFunction ("new_luaproc", ARDOUR::LuaAPI::new_luaproc) + .addFunction ("list_plugins", ARDOUR::LuaAPI::list_plugins) .addFunction ("new_plugin_info", ARDOUR::LuaAPI::new_plugin_info) .addFunction ("new_plugin", ARDOUR::LuaAPI::new_plugin) .addFunction ("set_processor_param", ARDOUR::LuaAPI::set_processor_param) .addFunction ("set_plugin_insert_param", ARDOUR::LuaAPI::set_plugin_insert_param) + .addFunction ("reset_processor_to_default", ARDOUR::LuaAPI::reset_processor_to_default) .addRefFunction ("get_processor_param", ARDOUR::LuaAPI::get_processor_param) .addRefFunction ("get_plugin_insert_param", ARDOUR::LuaAPI::get_plugin_insert_param) .addCFunction ("plugin_automation", ARDOUR::LuaAPI::plugin_automation) .addCFunction ("hsla_to_rgba", ARDOUR::LuaAPI::hsla_to_rgba) + .addCFunction ("color_to_rgba", ARDOUR::LuaAPI::color_to_rgba) .addFunction ("usleep", Glib::usleep) + .addFunction ("monotonic_time", ::g_get_monotonic_time) .addCFunction ("build_filename", ARDOUR::LuaAPI::build_filename) .addFunction ("new_noteptr", ARDOUR::LuaAPI::new_noteptr) + .addFunction ("note_list", ARDOUR::LuaAPI::note_list) + .addCFunction ("sample_to_timecode", ARDOUR::LuaAPI::sample_to_timecode) + .addCFunction ("timecode_to_sample", ARDOUR::LuaAPI::timecode_to_sample) .beginClass ("Vamp") .addConstructor () @@ -1901,6 +2379,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") @@ -1915,6 +2398,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) @@ -1937,11 +2426,11 @@ LuaBindings::dsp (lua_State* L) .beginClass ("AudioBuffer") .addEqualCheck () - .addFunction ("data", (Sample*(AudioBuffer::*)(framecnt_t))&AudioBuffer::data) + .addFunction ("data", (Sample*(AudioBuffer::*)(samplecnt_t))&AudioBuffer::data) .addFunction ("silence", &AudioBuffer::silence) .addFunction ("apply_gain", &AudioBuffer::apply_gain) .addFunction ("check_silence", &AudioBuffer::check_silence) - .addFunction ("read_from", (void (AudioBuffer::*)(const Sample*, framecnt_t, framecnt_t, framecnt_t))&AudioBuffer::check_silence) + .addFunction ("read_from", (void (AudioBuffer::*)(const Sample*, samplecnt_t, samplecnt_t, samplecnt_t))&AudioBuffer::check_silence) .endClass() .beginClass ("MidiBuffer") @@ -1951,10 +2440,10 @@ LuaBindings::dsp (lua_State* L) .addFunction ("empty", &MidiBuffer::empty) .addFunction ("resize", &MidiBuffer::resize) .addFunction ("copy", (void (MidiBuffer::*)(MidiBuffer const * const))&MidiBuffer::copy) - .addFunction ("push_event", (bool (MidiBuffer::*)(const Evoral::Event&))&MidiBuffer::push_back) - .addFunction ("push_back", (bool (MidiBuffer::*)(framepos_t, size_t, const uint8_t*))&MidiBuffer::push_back) + .addFunction ("push_event", (bool (MidiBuffer::*)(const Evoral::Event&))&MidiBuffer::push_back) + .addFunction ("push_back", (bool (MidiBuffer::*)(samplepos_t, size_t, const uint8_t*))&MidiBuffer::push_back) // TODO iterators.. - .addExtCFunction ("table", &luabridge::CFunc::listToTable, MidiBuffer>) + .addExtCFunction ("table", &luabridge::CFunc::listToTable, MidiBuffer>) .endClass() .beginClass ("BufferSet") @@ -1967,12 +2456,12 @@ LuaBindings::dsp (lua_State* L) luabridge::getGlobalNamespace (L) .beginNamespace ("Evoral") - .deriveClass , Evoral::Event > ("MidiEvent") + .deriveClass , Evoral::Event > ("Event") // add Ctor? - .addFunction ("type", &Evoral::Event::type) - .addFunction ("channel", &Evoral::Event::channel) - .addFunction ("set_type", &Evoral::Event::set_type) - .addFunction ("set_channel", &Evoral::Event::set_channel) + .addFunction ("type", &Evoral::Event::type) + .addFunction ("channel", &Evoral::Event::channel) + .addFunction ("set_type", &Evoral::Event::set_type) + .addFunction ("set_channel", &Evoral::Event::set_channel) .endClass () .endNamespace (); @@ -2020,6 +2509,7 @@ LuaBindings::session (lua_State* L) .addFunction ("save_state", &Session::save_state) .addFunction ("set_dirty", &Session::set_dirty) .addFunction ("unknown_processors", &Session::unknown_processors) + .addFunction ("export_track_state", &Session::export_track_state) .addFunction ("new_route_from_template", &Session::new_route_from_template) // TODO session_add_audio_track session_add_midi_track session_add_mixed_track