X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fluabindings.cc;h=50830d2403eb96d36a589655a5daaf710bf15548;hb=c12fa9c3cbfd180ff89ef70b62e3fc2e339296de;hp=81d14b2a6fab88fee0a3a5d6a45bc1ca53a2cbf9;hpb=636522bd79774af3e0f3ad11939c15b1dd1e4eb7;p=ardour.git diff --git a/libs/ardour/luabindings.cc b/libs/ardour/luabindings.cc index 81d14b2a6f..50830d2403 100644 --- a/libs/ardour/luabindings.cc +++ b/libs/ardour/luabindings.cc @@ -27,27 +27,36 @@ #include "ardour/amp.h" #include "ardour/audioengine.h" +#include "ardour/audioregion.h" #include "ardour/audiosource.h" #include "ardour/audio_backend.h" #include "ardour/audio_buffer.h" #include "ardour/audio_port.h" #include "ardour/audio_track.h" +#include "ardour/audioplaylist.h" #include "ardour/buffer_set.h" #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" #include "ardour/luaproc.h" #include "ardour/meter.h" +#include "ardour/midi_model.h" #include "ardour/midi_track.h" +#include "ardour/midi_playlist.h" #include "ardour/midi_port.h" +#include "ardour/midi_region.h" +#include "ardour/midi_source.h" +#include "ardour/panner_shell.h" #include "ardour/phase_control.h" #include "ardour/playlist.h" #include "ardour/plugin.h" #include "ardour/plugin_insert.h" #include "ardour/port_manager.h" +#include "ardour/progress.h" #include "ardour/runtime_functions.h" #include "ardour/region.h" #include "ardour/region_factory.h" @@ -73,7 +82,7 @@ * * Really!! A static function with a static variable in a library header * should never ever be replicated, even if it is a template. - * But then again this is windows... what else can go wrong. + * But then again this is windows... what else can go wrong ?! */ template @@ -110,16 +119,11 @@ luabridge::getIdentityKey () /* ...and this is the ugly part of it. * * We need to foward declare classes from gtk2_ardour - * end explicily list classes which are used by gtk2_ardour's bindings. + * AND explicily list classes which are used by gtk2_ardour's bindings. * - * This is needed because some of the GUI classes use objects from libardour - * as function parameters and the .exe would re-create symbols for libardour - * objects. - * - * Classes which don't use libardour symbols could be moved to - * gtk2_ardour/luainstance.cc, but keeping this here reduces code - * duplication and does not give the compiler a chance to even think - * about replicating the symbols. + * This is required because some of the GUI classes use objects from libardour + * as function parameters or return values and the .exe would re-create + * symbols for libardour objects. */ #define CLASSKEYS(CLS) \ @@ -133,66 +137,113 @@ luabridge::getIdentityKey () template void const* luabridge::ClassInfo< CLS >::getClassKey(); \ template void const* luabridge::ClassInfo< CLS >::getConstKey(); +CLASSINFO(ArdourMarker); CLASSINFO(MarkerSelection); -CLASSINFO(TrackSelection); -CLASSINFO(TrackViewList); -CLASSINFO(TimeSelection); -CLASSINFO(RegionSelection); CLASSINFO(PublicEditor); +CLASSINFO(RegionSelection); CLASSINFO(Selection); -CLASSINFO(ArdourMarker); - -namespace LuaCairo { - class ImageSurface; - class PangoLayout; -} -CLASSKEYS(LuaCairo::ImageSurface); -CLASSKEYS(LuaCairo::PangoLayout); +CLASSINFO(TimeSelection); +CLASSINFO(TrackSelection); +CLASSINFO(TrackViewList); -namespace Cairo { - class Context; -} -CLASSKEYS(Cairo::Context); -CLASSKEYS(std::vector); -CLASSKEYS(std::list); CLASSKEYS(std::bitset<47ul>); // LuaSignal::LAST_SIGNAL + +CLASSKEYS(void); +CLASSKEYS(float); +CLASSKEYS(unsigned char); + CLASSKEYS(ArdourMarker*); -CLASSKEYS(ARDOUR::RouteGroup); -CLASSKEYS(ARDOUR::LuaProc); -CLASSKEYS(ARDOUR::DataType); -CLASSKEYS(ARDOUR::ChanCount); -CLASSKEYS(boost::shared_ptr); -CLASSKEYS(ARDOUR::ParameterDescriptor); -CLASSKEYS(boost::shared_ptr); -CLASSKEYS(boost::shared_ptr); -CLASSKEYS(ARDOUR::LuaOSC::Address); -CLASSKEYS(ARDOUR::Session); + +CLASSKEYS(ARDOUR::AudioEngine); CLASSKEYS(ARDOUR::BufferSet); +CLASSKEYS(ARDOUR::ChanCount); CLASSKEYS(ARDOUR::ChanMapping); CLASSKEYS(ARDOUR::DSP::DspShm); +CLASSKEYS(ARDOUR::DataType); +CLASSKEYS(ARDOUR::FluidSynth); +CLASSKEYS(ARDOUR::Location); +CLASSKEYS(ARDOUR::LuaAPI::Vamp); +CLASSKEYS(ARDOUR::LuaOSC::Address); +CLASSKEYS(ARDOUR::LuaProc); CLASSKEYS(ARDOUR::LuaTableRef); -CLASSKEYS(PBD::Configuration); +CLASSKEYS(ARDOUR::MidiModel::NoteDiffCommand); +CLASSKEYS(ARDOUR::MonitorProcessor); +CLASSKEYS(ARDOUR::RouteGroup); +CLASSKEYS(ARDOUR::ParameterDescriptor); +CLASSKEYS(ARDOUR::PeakMeter); +CLASSKEYS(ARDOUR::PluginInfo); +CLASSKEYS(ARDOUR::Plugin::PresetRecord); +CLASSKEYS(ARDOUR::PortEngine); +CLASSKEYS(ARDOUR::PortManager); CLASSKEYS(ARDOUR::PresentationInfo); +CLASSKEYS(ARDOUR::Session); CLASSKEYS(ARDOUR::SessionConfiguration); +CLASSKEYS(ARDOUR::Source); + CLASSKEYS(PBD::ID); -CLASSKEYS(ARDOUR::Location); -CLASSKEYS(ARDOUR::PluginInfo); -CLASSKEYS(ARDOUR::MonitorProcessor); +CLASSKEYS(PBD::Configuration); CLASSKEYS(PBD::PropertyChange); +CLASSKEYS(PBD::StatefulDestructible); + +CLASSKEYS(Evoral::Beats); +CLASSKEYS(Evoral::Event); + + CLASSKEYS(std::vector); -CLASSKEYS(std::list >); +CLASSKEYS(std::vector); +CLASSKEYS(std::vector); +CLASSKEYS(std::vector); + +CLASSKEYS(std::vector); +CLASSKEYS(std::vector >); +CLASSKEYS(std::vector >); + +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); +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(std::list >); -CLASSKEYS(std::list); -CLASSKEYS(Evoral::Beats); -CLASSKEYS(ARDOUR::PortEngine); -CLASSKEYS(ARDOUR::PortManager); -CLASSKEYS(ARDOUR::AudioEngine); -CLASSKEYS(void); -CLASSKEYS(float); + +CLASSKEYS(Vamp::RealTime); +CLASSKEYS(Vamp::PluginBase); +CLASSKEYS(Vamp::PluginBase::ParameterDescriptor); +CLASSKEYS(Vamp::Plugin); +CLASSKEYS(Vamp::Plugin::OutputDescriptor); +CLASSKEYS(Vamp::Plugin::Feature); +CLASSKEYS(Vamp::Plugin::OutputList); +CLASSKEYS(Vamp::Plugin::FeatureList); +CLASSKEYS(Vamp::Plugin::FeatureSet); + +namespace LuaCairo { + class ImageSurface; + class PangoLayout; +} +namespace Cairo { + class Context; +} + +CLASSKEYS(Cairo::Context); +CLASSKEYS(LuaCairo::ImageSurface); +CLASSKEYS(LuaCairo::PangoLayout); #endif // end windows special case @@ -232,6 +283,10 @@ LuaBindings::stddef (lua_State* L) .beginStdVector ("StringVector") .endClass () + // std::vector + .beginStdVector ("FloatVector") + .endClass () + // register float array (uint8_t*) .registerArray ("ByteArray") @@ -241,6 +296,10 @@ LuaBindings::stddef (lua_State* L) // register float array (int32_t*) .registerArray ("IntArray") + // std::vector + .beginStdVector ("FloatArrayVector") + .endClass () + // TODO std::set .endNamespace (); } @@ -359,8 +418,26 @@ LuaBindings::common (lua_State* L) .beginNamespace ("Timecode") .beginClass ("BBT_TIME") .addConstructor () + .addData ("bars", &Timecode::BBT_Time::bars) + .addData ("beats", &Timecode::BBT_Time::beats) + .addData ("ticks", &Timecode::BBT_Time::ticks) + //.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)) @@ -380,6 +457,19 @@ 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) + .endClass () + + .beginClass ("Beats") + .addConstructor () + .addFunction ("to_double", &Evoral::Beats::to_double) + .endClass () + .beginClass ("Parameter") .addConstructor () .addFunction ("type", &Evoral::Parameter::type) @@ -421,6 +511,18 @@ LuaBindings::common (lua_State* L) .addData ("to", &Evoral::Range::to) .endClass () + .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) + .endClass () + /* libevoral enums */ .beginNamespace ("InterpolationStyle") .addConst ("Discrete", Evoral::ControlList::InterpolationStyle(Evoral::ControlList::Discrete)) @@ -428,8 +530,125 @@ LuaBindings::common (lua_State* L) .addConst ("Curved", Evoral::ControlList::InterpolationStyle(Evoral::ControlList::Curved)) .endNamespace () - .endNamespace () // Evoral + .endNamespace (); // Evoral + + luabridge::getGlobalNamespace (L) + .beginNamespace ("Vamp") + + .beginClass ("RealTime") + .addConstructor () + .addData ("sec", &Vamp::RealTime::sec, false) + .addData ("nsec", &Vamp::RealTime::nsec, false) + .addFunction ("usec", &Vamp::RealTime::usec) + .addFunction ("msec", &Vamp::RealTime::msec) + .addFunction ("toString", &Vamp::RealTime::toString) + .addStaticFunction ("realTime2Frame", &Vamp::RealTime::realTime2Frame) + .addStaticFunction ("frame2RealTime", &Vamp::RealTime::frame2RealTime) + .endClass () + + .beginClass ("PluginBase") + .addFunction ("getIdentifier", &Vamp::PluginBase::getIdentifier) + .addFunction ("getName", &Vamp::PluginBase::getName) + .addFunction ("getDescription", &Vamp::PluginBase::getDescription) + .addFunction ("getMaker", &Vamp::PluginBase::getMaker) + .addFunction ("getCopyright", &Vamp::PluginBase::getCopyright) + .addFunction ("getPluginVersion", &Vamp::PluginBase::getPluginVersion) + .addFunction ("getParameterDescriptors", &Vamp::PluginBase::getParameterDescriptors) + .addFunction ("getParameter", &Vamp::PluginBase::getParameter) + .addFunction ("setParameter", &Vamp::PluginBase::setParameter) + .addFunction ("getPrograms", &Vamp::PluginBase::getPrograms) + .addFunction ("getCurrentProgram", &Vamp::PluginBase::getCurrentProgram) + .addFunction ("selectProgram", &Vamp::PluginBase::selectProgram) + .addFunction ("getType", &Vamp::PluginBase::getType) + .endClass () + + .beginNamespace ("PluginBase") + .beginClass ("ParameterDescriptor") + .addData ("identifier", &Vamp::PluginBase::ParameterDescriptor::identifier) + .addData ("name", &Vamp::PluginBase::ParameterDescriptor::name) + .addData ("description", &Vamp::PluginBase::ParameterDescriptor::description) + .addData ("unit", &Vamp::PluginBase::ParameterDescriptor::unit) + .addData ("minValue", &Vamp::PluginBase::ParameterDescriptor::minValue) + .addData ("maxValue", &Vamp::PluginBase::ParameterDescriptor::maxValue) + .addData ("defaultValue", &Vamp::PluginBase::ParameterDescriptor::defaultValue) + .addData ("isQuantized", &Vamp::PluginBase::ParameterDescriptor::isQuantized) + .addData ("quantizeStep", &Vamp::PluginBase::ParameterDescriptor::quantizeStep) + .addData ("valueNames", &Vamp::PluginBase::ParameterDescriptor::valueNames) + .endClass () + + .beginStdVector ("ParameterList") + .endClass () + .endNamespace () // Vamp::PluginBase + + .deriveClass ("Plugin") + //.addFunction ("process", &Vamp::Plugin::process) // unusable due to float*const* -> LuaAPI::Vamp::process + .addFunction ("initialise", &Vamp::Plugin::initialise) + .addFunction ("reset", &Vamp::Plugin::reset) + .addFunction ("getInputDomain", &Vamp::Plugin::getInputDomain) + .addFunction ("getPreferredBlockSize", &Vamp::Plugin::getPreferredBlockSize) + .addFunction ("getPreferredStepSize", &Vamp::Plugin::getPreferredStepSize) + .addFunction ("getMinChannelCount", &Vamp::Plugin::getMinChannelCount) + .addFunction ("getMaxChannelCount", &Vamp::Plugin::getMaxChannelCount) + .addFunction ("getOutputDescriptors", &Vamp::Plugin::getOutputDescriptors) + .addFunction ("getRemainingFeatures", &Vamp::Plugin::getRemainingFeatures) + .addFunction ("getType", &Vamp::Plugin::getType) + .endClass () + + .beginNamespace ("Plugin") + .beginClass ("OutputDescriptor") + .addData ("identifier", &Vamp::Plugin::OutputDescriptor::identifier) + .addData ("description", &Vamp::Plugin::OutputDescriptor::description) + .addData ("unit", &Vamp::Plugin::OutputDescriptor::unit) + .addData ("hasFixedBinCount", &Vamp::Plugin::OutputDescriptor::hasFixedBinCount) + .addData ("binCount", &Vamp::Plugin::OutputDescriptor::binCount) + .addData ("binNames", &Vamp::Plugin::OutputDescriptor::binNames) + .addData ("hasKnownExtents", &Vamp::Plugin::OutputDescriptor::hasKnownExtents) + .addData ("minValue", &Vamp::Plugin::OutputDescriptor::minValue) + .addData ("maxValue", &Vamp::Plugin::OutputDescriptor::maxValue) + .addData ("isQuantized", &Vamp::Plugin::OutputDescriptor::isQuantized) + .addData ("quantizeStep", &Vamp::Plugin::OutputDescriptor::quantizeStep) + .addData ("sampleType", &Vamp::Plugin::OutputDescriptor::sampleType) + .addData ("sampleRate", &Vamp::Plugin::OutputDescriptor::sampleRate) + .addData ("hasDuration", &Vamp::Plugin::OutputDescriptor::hasDuration) + .endClass () + + /* Vamp::Plugin enums */ + .beginNamespace ("InputDomain") + .addConst ("TimeDomain", Vamp::Plugin::InputDomain(Vamp::Plugin::TimeDomain)) + .addConst ("FrequencyDomain", Vamp::Plugin::InputDomain(Vamp::Plugin::FrequencyDomain)) + .endNamespace () + + /* Vamp::Plugin::OutputDescriptor enum */ + .beginNamespace ("OutputDescriptor") + .beginNamespace ("SampleType") + .addConst ("OneSamplePerStep", Vamp::Plugin::OutputDescriptor::SampleType(Vamp::Plugin::OutputDescriptor::OneSamplePerStep)) + .addConst ("FixedSampleRate", Vamp::Plugin::OutputDescriptor::SampleType(Vamp::Plugin::OutputDescriptor::FixedSampleRate)) + .addConst ("VariableSampleRate", Vamp::Plugin::OutputDescriptor::SampleType(Vamp::Plugin::OutputDescriptor::VariableSampleRate)) + .endNamespace () + .endNamespace () /* Vamp::Plugin::OutputDescriptor */ + + .beginClass ("Feature") + .addData ("hasTimestamp", &Vamp::Plugin::Feature::hasTimestamp, false) + .addData ("timestamp", &Vamp::Plugin::Feature::timestamp, false) + .addData ("hasDuration", &Vamp::Plugin::Feature::hasDuration, false) + .addData ("duration", &Vamp::Plugin::Feature::duration, false) + .addData ("values", &Vamp::Plugin::Feature::values, false) + .addData ("label", &Vamp::Plugin::Feature::label, false) + .endClass () + + .beginStdVector ("OutputList") + .endClass () + .beginStdVector ("FeatureList") + .endClass () + + .beginStdMap ("FeatureSet") + .endClass () + + .endNamespace () // Vamp::Plugin + .endNamespace ();// Vamp + + luabridge::getGlobalNamespace (L) .beginNamespace ("ARDOUR") .beginClass ("InterThreadInfo") @@ -441,6 +660,16 @@ LuaBindings::common (lua_State* L) .addData ("progress", const_cast(&InterThreadInfo::progress)) .endClass () + .beginClass ("Progress") + .endClass () + + .beginClass ("MusicFrame") + .addConstructor () + .addFunction ("set", &MusicFrame::set) + .addData ("frame", &MusicFrame::frame) + .addData ("division", &MusicFrame::division) + .endClass () + .beginClass ("AudioRange") .addConstructor () .addFunction ("length", &AudioRange::length) @@ -451,7 +680,17 @@ 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) + .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") @@ -511,6 +750,7 @@ LuaBindings::common (lua_State* L) .endClass () .deriveClass ("Location") + .addFunction ("name", &Location::name) .addFunction ("locked", &Location::locked) .addFunction ("lock", &Location::lock) .addFunction ("unlock", &Location::unlock) @@ -540,6 +780,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 ("remove", &Locations::remove) .addRefFunction ("marks_either_side", &Locations::marks_either_side) .addRefFunction ("find_all_between", &Locations::find_all_between) .endClass () @@ -562,12 +803,9 @@ LuaBindings::common (lua_State* L) .addFunction ("sends_output", &Port::sends_output) .addFunction ("connected", &Port::connected) .addFunction ("disconnect_all", &Port::disconnect_all) - .addFunction ("connected_to_name", (bool (Port::*)(std::string const &)const)&Port::connected_to) - .addFunction ("connect_by_name", (int (Port::*)(std::string const &))&Port::connect) - .addFunction ("disconnect_by_name", (int (Port::*)(std::string const &))&Port::disconnect) - .addFunction ("connected_to", (bool (Port::*)(Port*)const)&Port::connected_to) - .addFunction ("connect", (int (Port::*)(Port*))&Port::connect) - .addFunction ("disconnect", (int (Port::*)(Port*))&Port::disconnect) + .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) //.addStaticFunction ("port_offset", &Port::port_offset) // static .endClass () @@ -596,6 +834,7 @@ LuaBindings::common (lua_State* L) .addFunction ("remove_port", &IO::remove_port) .addFunction ("connect", &IO::connect) .addFunction ("disconnect", (int (IO::*)(boost::shared_ptr, std::string, void *))&IO::disconnect) + .addFunction ("disconnect_all", (int (IO::*)(void *))&IO::disconnect) .addFunction ("physically_connected", &IO::physically_connected) .addFunction ("has_port", &IO::has_port) .addFunction ("nth", &IO::nth) @@ -605,14 +844,51 @@ LuaBindings::common (lua_State* L) .addFunction ("n_ports", &IO::n_ports) .endClass () + .deriveWSPtrClass ("PannerShell") + .addFunction ("bypassed", &PannerShell::bypassed) + .addFunction ("set_bypassed", &PannerShell::set_bypassed) + .endClass () + .beginClass ("RouteGroup") - // stub RouteGroup* is needed for new_audio_track() + .addFunction ("is_active", &RouteGroup::is_active) + .addFunction ("is_relative", &RouteGroup::is_relative) + .addFunction ("is_hidden", &RouteGroup::is_hidden) + .addFunction ("is_gain", &RouteGroup::is_gain) + .addFunction ("is_mute", &RouteGroup::is_mute) + .addFunction ("is_solo", &RouteGroup::is_solo) + .addFunction ("is_recenable", &RouteGroup::is_recenable) + .addFunction ("is_select", &RouteGroup::is_select) + .addFunction ("is_route_active", &RouteGroup::is_route_active) + .addFunction ("is_color", &RouteGroup::is_color) + .addFunction ("is_monitoring", &RouteGroup::is_monitoring) + .addFunction ("group_master_number", &RouteGroup::group_master_number) + .addFunction ("empty", &RouteGroup::empty) + .addFunction ("size", &RouteGroup::size) + .addFunction ("set_active", &RouteGroup::set_active) + .addFunction ("set_relative", &RouteGroup::set_relative) + .addFunction ("set_hidden", &RouteGroup::set_hidden) + .addFunction ("set_gain", &RouteGroup::set_gain) + .addFunction ("set_mute", &RouteGroup::set_mute) + .addFunction ("set_solo", &RouteGroup::set_solo) + .addFunction ("set_recenable", &RouteGroup::set_recenable) + .addFunction ("set_select", &RouteGroup::set_select) + .addFunction ("set_route_active", &RouteGroup::set_route_active) + .addFunction ("set_color", &RouteGroup::set_color) + .addFunction ("set_monitoring", &RouteGroup::set_monitoring) + .addFunction ("add", &RouteGroup::add) + .addFunction ("remove", &RouteGroup::remove) + .addFunction ("clear", &RouteGroup::clear) + .addFunction ("has_subgroup", &RouteGroup::has_subgroup) + .addFunction ("make_subgroup", &RouteGroup::make_subgroup) + .addFunction ("destroy_subgroup", &RouteGroup::destroy_subgroup) + .addFunction ("route_list", &RouteGroup::route_list) .endClass () .deriveClass ("PresentationInfo") .addFunction ("color", &PresentationInfo::color) .addFunction ("set_color", &PresentationInfo::set_color) .addFunction ("order", &PresentationInfo::order) + .addConst ("max_order", ARDOUR::PresentationInfo::max_order) .endClass () .deriveWSPtrClass ("Stripable") @@ -664,6 +940,7 @@ LuaBindings::common (lua_State* L) .deriveWSPtrClass ("Route") .addCast ("to_track") + .addCast ("to_automatable") .addFunction ("set_name", &Route::set_name) .addFunction ("comment", &Route::comment) .addFunction ("active", &Route::active) @@ -673,9 +950,15 @@ 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) + .addFunction ("input", &Route::input) + .addFunction ("output", &Route::output) + .addFunction ("panner_shell", &Route::panner_shell) .addFunction ("set_comment", &Route::set_comment) .addFunction ("strict_io", &Route::strict_io) .addFunction ("set_strict_io", &Route::set_strict_io) @@ -688,9 +971,13 @@ 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") + .addCast ("to_audioplaylist") + .addCast ("to_midiplaylist") .addFunction ("region_by_id", &Playlist::region_by_id) .addFunction ("data_type", &Playlist::data_type) .addFunction ("n_regions", &Playlist::n_regions) @@ -725,6 +1012,14 @@ LuaBindings::common (lua_State* L) #endif .endClass () + .deriveWSPtrClass ("AudioPlaylist") + .addFunction ("read", &AudioPlaylist::read) + .endClass () + + .deriveWSPtrClass ("MidiPlaylist") + .addFunction ("set_note_mode", &MidiPlaylist::set_note_mode) + .endClass () + .deriveWSPtrClass ("Track") .addCast ("to_audio_track") .addCast ("to_midi_track") @@ -742,7 +1037,16 @@ LuaBindings::common (lua_State* L) .deriveWSPtrClass ("MidiTrack") .endClass () + .beginWSPtrClass ("Readable") + .addFunction ("read", &Readable::read) + .addFunction ("readable_length", &Readable::readable_length) + .addFunction ("n_channels", &Readable::n_channels) + .endClass () + .deriveWSPtrClass ("Region") + .addCast ("to_readable") + .addCast ("to_midiregion") + .addCast ("to_audioregion") /* properties */ .addFunction ("position", &Region::position) .addFunction ("start", &Region::start) @@ -777,6 +1081,9 @@ LuaBindings::common (lua_State* L) .addFunction ("nudge_position", &Region::nudge_position) .addFunction ("move_to_natural_position", &Region::move_to_natural_position) .addFunction ("move_start", &Region::move_start) + .addFunction ("master_sources", &Region::master_sources) + .addFunction ("master_source_names", &Region::master_source_names) + .addFunction ("n_channels", &Region::n_channels) .addFunction ("trim_front", &Region::trim_front) .addFunction ("trim_end", &Region::trim_end) .addFunction ("trim_to", &Region::trim_to) @@ -788,17 +1095,90 @@ LuaBindings::common (lua_State* L) .addFunction ("lower_to_bottom", &Region::lower_to_bottom) .addFunction ("set_sync_position", &Region::set_sync_position) .addFunction ("clear_sync_position", &Region::clear_sync_position) + .addFunction ("quarter_note", &Region::quarter_note) .addFunction ("set_hidden", &Region::set_hidden) .addFunction ("set_muted", &Region::set_muted) .addFunction ("set_opaque", &Region::set_opaque) .addFunction ("set_locked", &Region::set_locked) .addFunction ("set_video_locked", &Region::set_video_locked) .addFunction ("set_position_locked", &Region::set_position_locked) + .addFunction ("source", &Region::source) + .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 ("start_beats", &MidiRegion::start_beats) + .addFunction ("length_beats", &MidiRegion::length_beats) + .endClass () + + .deriveWSPtrClass ("AudioRegion") + .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) + .endClass () + + .deriveWSPtrClass ("Source") + .addCast ("to_audiosource") + .addCast ("to_midisource") + .addFunction ("timestamp", &Source::timestamp) + .addFunction ("empty", &Source::empty) + .addFunction ("length", &Source::length) + .addFunction ("natural_position", &Source::natural_position) + .addFunction ("destructive", &Source::destructive) + .addFunction ("writable", &Source::writable) + .addFunction ("has_been_analysed", &Source::has_been_analysed) + .addFunction ("can_be_analysed", &Source::can_be_analysed) + .addFunction ("timeline_position", &Source::timeline_position) + .addFunction ("use_count", &Source::use_count) + .addFunction ("used", &Source::used) + .addFunction ("ancestor_name", &Source::ancestor_name) + .endClass () + + .deriveWSPtrClass ("MidiSource") + .addFunction ("empty", &MidiSource::empty) + .addFunction ("length", &MidiSource::length) + .addFunction ("model", &MidiSource::model) + .endClass () + + .deriveWSPtrClass ("AudioSource") + .addCast ("to_readable") + .addFunction ("readable_length", &AudioSource::readable_length) + .addFunction ("n_channels", &AudioSource::n_channels) + .addFunction ("empty", &Source::empty) + .addFunction ("length", &Source::length) + .addFunction ("read", &AudioSource::read) + .addFunction ("sample_rate", &AudioSource::sample_rate) + .addFunction ("captured_for", &AudioSource::captured_for) + .endClass () + + .deriveWSPtrClass ("Automatable") + .addFunction ("automation_control", (boost::shared_ptr(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control) + .endClass () + + .deriveWSPtrClass , Automatable> ("AutomatableSequence") + .addCast > ("to_sequence") .endClass () - .beginWSPtrClass ("Source") + .deriveWSPtrClass > ("MidiModel") + .addFunction ("apply_command", (void (MidiModel::*)(Session*, Command*))&MidiModel::apply_command) + .addFunction ("new_note_diff_command", &MidiModel::new_note_diff_command) .endClass () + .beginNamespace ("MidiModel") + .deriveClass ("DiffCommand") + .endClass () + + .deriveClass ("NoteDiffCommand") + .addFunction ("add", &ARDOUR::MidiModel::NoteDiffCommand::add) + .addFunction ("remove", &ARDOUR::MidiModel::NoteDiffCommand::remove) + .endClass () + + .endNamespace () /* ARDOUR::MidiModel */ + .beginClass ("PresetRecord") .addVoidConstructor () .addData ("uri", &Plugin::PresetRecord::uri, false) @@ -807,9 +1187,7 @@ LuaBindings::common (lua_State* L) .addData ("valid", &Plugin::PresetRecord::valid, false) .endClass () - .deriveWSPtrClass ("Automatable") - .addFunction ("automation_control", (boost::shared_ptr(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control) - .endClass () + .beginStdVector ("PresetVector").endClass () .deriveClass ("ParameterDescriptor") .addVoidConstructor () @@ -818,23 +1196,30 @@ LuaBindings::common (lua_State* L) .addStaticFunction ("midi_note_name", &ParameterDescriptor::midi_note_name) .endClass () + .beginStdVector > ("ProcessorVector").endClass () + .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_peakmeter") .addCast ("to_monitorprocessor") #if 0 // those objects are not yet bound .addCast ("to_capturingprocessor") .addCast ("to_delayline") - .addCast ("to_meter") #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) .endClass () .deriveWSPtrClass ("IOProcessor") @@ -848,9 +1233,21 @@ LuaBindings::common (lua_State* L) .endClass () .deriveWSPtrClass ("Delivery") + .addFunction ("panner_shell", &Route::panner_shell) .endClass () + .beginNamespace ("Plugin") + .beginClass ("IOPortDescription") + .addData ("name", &Plugin::IOPortDescription::name) + .addData ("is_sidechain", &Plugin::IOPortDescription::is_sidechain) + .addData ("group_name", &Plugin::IOPortDescription::group_name) + .addData ("group_channel", &Plugin::IOPortDescription::group_channel) + .endClass () + .endNamespace () + .deriveWSPtrClass ("Plugin") + .addCast ("to_luaproc") + .addFunction ("unique_id", &Plugin::unique_id) .addFunction ("label", &Plugin::label) .addFunction ("name", &Plugin::name) .addFunction ("maker", &Plugin::maker) @@ -861,10 +1258,17 @@ 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) + .addFunction ("describe_io_port", &Plugin::describe_io_port) .addRefFunction ("get_parameter_descriptor", &Plugin::get_parameter_descriptor) .endClass () + .deriveWSPtrClass ("LuaProc") + .addFunction ("shmem", &LuaProc::instance_shm) + .addFunction ("table", &LuaProc::instance_ref) + .endClass () + .deriveWSPtrClass ("PluginInsert") .addFunction ("plugin", &PluginInsert::plugin) .addFunction ("activate", &PluginInsert::activate) @@ -874,7 +1278,9 @@ LuaBindings::common (lua_State* L) .addFunction ("output_map", (ARDOUR::ChanMapping (PluginInsert::*)(uint32_t) const)&PluginInsert::output_map) .addFunction ("set_input_map", &PluginInsert::set_input_map) .addFunction ("set_output_map", &PluginInsert::set_output_map) - .addFunction ("sidechain_input", &PluginInsert::sidechain_input) + .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) .endClass () .deriveWSPtrClass ("AutomationControl") @@ -934,6 +1340,12 @@ LuaBindings::common (lua_State* L) .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) @@ -988,12 +1400,21 @@ LuaBindings::common (lua_State* L) // boost::shared_ptr .beginPtrStdList > ("RouteListPtr") + .addVoidPtrConstructor > > () .endClass () // typedef std::list > WeakRouteList .beginConstStdList > ("WeakRouteList") .endClass () + // RouteList == std::list > + .beginConstStdList ("RouteGroupList") + .endClass () + + // typedef std::vector > Region::SourceList + .beginStdVector > ("SourceList") + .endClass () + // std::list< boost::weak_ptr > .beginConstStdList > ("WeakAudioSourceList") .endClass () @@ -1004,6 +1425,11 @@ LuaBindings::common (lua_State* L) // boost::shared_ptr > > .beginPtrStdList > ("RegionListPtr") + .addVoidPtrConstructor > > () + .endClass () + + // typedef std::list > ProcessorList; + .beginStdList > ("ProcessorList") .endClass () //std::list > PortList; @@ -1017,6 +1443,14 @@ LuaBindings::common (lua_State* L) .beginConstStdList ("LocationList") .endClass () + // std::list > ControlList; + .beginStdList > ("ControlList") + .endClass () + + .beginPtrStdList > ("ControlListPtr") + .addVoidPtrConstructor > > () + .endClass () + #if 0 // depends on Evoal:: Note, Beats see note_fixer.h // typedef Evoral::Note Note; // std::set< boost::weak_ptr > @@ -1031,8 +1465,10 @@ LuaBindings::common (lua_State* L) .beginClass ("Tempo") .addConstructor () .addFunction ("note_type", &Tempo::note_type) - .addFunction ("beats_per_minute", &Tempo::beats_per_minute) - .addFunction ("frames_per_beat", &Tempo::frames_per_beat) + .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) .endClass () .beginClass ("Meter") @@ -1046,9 +1482,13 @@ 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 ("tempo_section_at_frame", (TempoSection& (TempoMap::*)(framepos_t))&TempoMap::tempo_section_at_frame) + .addFunction ("tempo_section_at_frame", (const TempoSection& (TempoMap::*)(framepos_t) const)&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) + .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) .endClass () .beginClass ("MetricSection") @@ -1057,7 +1497,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") @@ -1135,12 +1575,60 @@ 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") .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 ("Placement") + .addConst ("PreFader", ARDOUR::Placement(PreFader)) + .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)) + .endNamespace () + .beginNamespace ("PortFlags") .addConst ("IsInput", ARDOUR::PortFlags(IsInput)) .addConst ("IsOutput", ARDOUR::PortFlags(IsOutput)) @@ -1149,12 +1637,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::MidiTrackNameSource(SMFTempoIgnore)) + .addConst ("SMFTempoUse", ARDOUR::MidiTrackNameSource(SMFTempoUse)) + .endNamespace () + .beginNamespace ("RegionPoint") .addConst ("Start", ARDOUR::RegionPoint(Start)) .addConst ("End", ARDOUR::RegionPoint(End)) @@ -1320,12 +1826,14 @@ LuaBindings::common (lua_State* L) .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 ("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) .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) @@ -1341,6 +1849,8 @@ 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 ("get_remote_nth_stripable", &Session::get_remote_nth_stripable) @@ -1353,8 +1863,17 @@ LuaBindings::common (lua_State* L) .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) @@ -1367,6 +1886,11 @@ LuaBindings::common (lua_State* L) .addFunction ("worst_track_latency", &Session::worst_track_latency) .addFunction ("worst_playback_latency", &Session::worst_playback_latency) .addFunction ("cfg", &Session::cfg) + .addFunction ("route_groups", &Session::route_groups) + .addFunction ("new_route_group", &Session::new_route_group) + .addFunction ("remove_route_group", (void (Session::*)(RouteGroup*))&Session::remove_route_group) + .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") @@ -1404,81 +1928,33 @@ LuaBindings::common (lua_State* L) .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) - .endNamespace () // end LuaAPI - .endNamespace ();// end ARDOUR -} - -void -LuaBindings::dsp (lua_State* L) -{ - luabridge::getGlobalNamespace (L) - .beginNamespace ("ARDOUR") - - .beginClass ("AudioBuffer") - .addEqualCheck () - .addFunction ("data", (Sample*(AudioBuffer::*)(framecnt_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) - .endClass() - - .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 (); - - 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::MIDIEvent::time) + .addFunction ("monotonic_time", ::g_get_monotonic_time) + .addCFunction ("build_filename", ARDOUR::LuaAPI::build_filename) + .addFunction ("new_noteptr", ARDOUR::LuaAPI::new_noteptr) + .addCFunction ("sample_to_timecode", ARDOUR::LuaAPI::sample_to_timecode) + .addCFunction ("timecode_to_sample", ARDOUR::LuaAPI::timecode_to_sample) + + .beginClass ("Vamp") + .addConstructor () + .addStaticFunction ("list_plugins", &ARDOUR::LuaAPI::Vamp::list_plugins) + .addFunction ("plugin", &ARDOUR::LuaAPI::Vamp::plugin) + .addFunction ("analyze", &ARDOUR::LuaAPI::Vamp::analyze) + .addFunction ("reset", &ARDOUR::LuaAPI::Vamp::reset) + .addFunction ("initialize", &ARDOUR::LuaAPI::Vamp::initialize) + .addFunction ("process", &ARDOUR::LuaAPI::Vamp::process) .endClass () - .beginClass ("Beats") - .addFunction ("to_double", &Evoral::Beats::to_double) - .endClass () - - .deriveClass , Evoral::Event > ("MidiEvent") - // add Ctor? - .addFunction ("type", &Evoral::MIDIEvent::type) - .addFunction ("channel", &Evoral::MIDIEvent::channel) - .addFunction ("set_type", &Evoral::MIDIEvent::set_type) - .addFunction ("set_channel", &Evoral::MIDIEvent::set_channel) - .endClass () - .endNamespace (); - - // dsp releated session functions - luabridge::getGlobalNamespace (L) - .beginNamespace ("ARDOUR") - .beginClass ("Session") - .addFunction ("get_scratch_buffers", &Session::get_scratch_buffers) - .addFunction ("get_silent_buffers", &Session::get_silent_buffers) - .endClass () - .endNamespace (); + .endNamespace () // end LuaAPI + .endNamespace ();// end ARDOUR + // DSP functions luabridge::getGlobalNamespace (L) .beginNamespace ("ARDOUR") .beginNamespace ("DSP") @@ -1545,6 +2021,81 @@ LuaBindings::dsp (lua_State* L) .endClass () .endNamespace () // DSP + .endNamespace ();// end ARDOUR +} + +void +LuaBindings::dsp (lua_State* L) +{ + luabridge::getGlobalNamespace (L) + .beginNamespace ("ARDOUR") + + .beginClass ("AudioBuffer") + .addEqualCheck () + .addFunction ("data", (Sample*(AudioBuffer::*)(framecnt_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) + .endClass() + + .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::Event&))&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 (); + + luabridge::getGlobalNamespace (L) + .beginNamespace ("Evoral") + .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) + .endClass () + .endNamespace (); + + // dsp releated session functions + luabridge::getGlobalNamespace (L) + .beginNamespace ("ARDOUR") + .beginClass ("Session") + .addFunction ("get_scratch_buffers", &Session::get_scratch_buffers) + .addFunction ("get_silent_buffers", &Session::get_silent_buffers) + .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") .beginClass ("LuaTableRef") .addCFunction ("get", &LuaTableRef::get) @@ -1564,6 +2115,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