Update processor Lua bindings
[ardour.git] / libs / ardour / luabindings.cc
index aa944254892f59249a8c7672ef0fa434f1a80b88..50830d2403eb96d36a589655a5daaf710bf15548 100644 (file)
 
 #include "timecode/bbt_time.h"
 #include "pbd/stateful_diff_command.h"
+#include "pbd/openuri.h"
 #include "evoral/Control.hpp"
 #include "evoral/ControlList.hpp"
 #include "evoral/Range.hpp"
 
 #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"
@@ -53,6 +64,9 @@
 #include "ardour/session.h"
 #include "ardour/session_object.h"
 #include "ardour/sidechain.h"
+#include "ardour/solo_isolate_control.h"
+#include "ardour/solo_safe_control.h"
+#include "ardour/stripable.h"
 #include "ardour/track.h"
 #include "ardour/tempo.h"
 
@@ -68,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 <class T>
@@ -105,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) \
@@ -128,54 +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);
+CLASSINFO(TimeSelection);
+CLASSINFO(TrackSelection);
+CLASSINFO(TrackViewList);
 
-namespace Cairo {
-       class Context;
-}
-CLASSKEYS(Cairo::Context);
-CLASSKEYS(std::vector<double>);
-CLASSKEYS(std::list<ArdourMarker*>);
 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<ARDOUR::Processor>);
-CLASSKEYS(ARDOUR::ParameterDescriptor);
-CLASSKEYS(boost::shared_ptr<ARDOUR::AutomationList>);
-CLASSKEYS(boost::shared_ptr<Evoral::ControlList>);
-CLASSKEYS(ARDOUR::LuaOSC::Address);
-CLASSKEYS(ARDOUR::Session);
+
+CLASSKEYS(ARDOUR::AudioEngine);
 CLASSKEYS(ARDOUR::BufferSet);
+CLASSKEYS(ARDOUR::ChanCount);
 CLASSKEYS(ARDOUR::ChanMapping);
 CLASSKEYS(ARDOUR::DSP::DspShm);
-CLASSKEYS(PBD::ID);
+CLASSKEYS(ARDOUR::DataType);
+CLASSKEYS(ARDOUR::FluidSynth);
 CLASSKEYS(ARDOUR::Location);
+CLASSKEYS(ARDOUR::LuaAPI::Vamp);
+CLASSKEYS(ARDOUR::LuaOSC::Address);
+CLASSKEYS(ARDOUR::LuaProc);
+CLASSKEYS(ARDOUR::LuaTableRef);
+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(PBD::Configuration);
 CLASSKEYS(PBD::PropertyChange);
+CLASSKEYS(PBD::StatefulDestructible);
+
+CLASSKEYS(Evoral::Beats);
+CLASSKEYS(Evoral::Event<framepos_t>);
+
+
 CLASSKEYS(std::vector<std::string>);
-CLASSKEYS(std::list<boost::shared_ptr<ARDOUR::Route> >);
+CLASSKEYS(std::vector<float>);
+CLASSKEYS(std::vector<float*>);
+CLASSKEYS(std::vector<double>);
+
+CLASSKEYS(std::vector<ARDOUR::Plugin::PresetRecord>);
+CLASSKEYS(std::vector<boost::shared_ptr<ARDOUR::Processor> >);
+CLASSKEYS(std::vector<boost::shared_ptr<ARDOUR::Source> >);
+
+CLASSKEYS(std::list<ArdourMarker*>);
+CLASSKEYS(std::list<ARDOUR::AudioRange>);
 CLASSKEYS(std::list<boost::shared_ptr<ARDOUR::Port> >);
+CLASSKEYS(std::list<boost::shared_ptr<ARDOUR::Region> >);
+CLASSKEYS(std::list<boost::shared_ptr<ARDOUR::Route> >);
+
+CLASSKEYS(boost::shared_ptr<ARDOUR::AudioRegion>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::AudioSource>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::Automatable>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::AutomatableSequence<Evoral::Beats> >);
+CLASSKEYS(boost::shared_ptr<ARDOUR::AutomationList>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::MidiModel>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::MidiPlaylist>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::MidiRegion>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::MidiSource>);
 CLASSKEYS(boost::shared_ptr<ARDOUR::PluginInfo>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::Processor>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::Readable>);
 CLASSKEYS(boost::shared_ptr<ARDOUR::Region>);
+CLASSKEYS(boost::shared_ptr<Evoral::ControlList>);
+CLASSKEYS(boost::shared_ptr<Evoral::Note<Evoral::Beats> >);
+CLASSKEYS(boost::shared_ptr<Evoral::Sequence<Evoral::Beats> >);
+
 CLASSKEYS(boost::weak_ptr<ARDOUR::Route>);
-CLASSKEYS(std::list<boost::shared_ptr<ARDOUR::Region> >);
-CLASSKEYS(std::list<ARDOUR::AudioRange>);
-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
 
@@ -215,12 +283,23 @@ LuaBindings::stddef (lua_State* L)
                .beginStdVector <std::string> ("StringVector")
                .endClass ()
 
+       // std::vector<float>
+               .beginStdVector <float> ("FloatVector")
+               .endClass ()
+
+       // register float array (uint8_t*)
+               .registerArray <uint8_t> ("ByteArray")
+
        // register float array (float*)
                .registerArray <float> ("FloatArray")
 
        // register float array (int32_t*)
                .registerArray <int32_t> ("IntArray")
 
+       // std::vector<float*>
+               .beginStdVector <float*> ("FloatArrayVector")
+               .endClass ()
+
        // TODO std::set
                .endNamespace ();
 }
@@ -230,11 +309,17 @@ LuaBindings::common (lua_State* L)
 {
        luabridge::getGlobalNamespace (L)
                .beginNamespace ("PBD")
+
+               .addFunction ("open_uri", (bool (*) (const std::string&))&PBD::open_uri)
+               .addFunction ("open_uri", &PBD::open_folder)
+
                .beginClass <PBD::ID> ("ID")
                .addConstructor <void (*) (std::string)> ()
                .addFunction ("to_s", &PBD::ID::to_s) // TODO special case LUA __tostring ?
                .endClass ()
 
+               .beginStdVector <PBD::ID> ("IdVector").endClass ()
+
                .beginClass <XMLNode> ("XMLNode")
                .addFunction ("name", &XMLNode::name)
                .endClass ()
@@ -254,6 +339,9 @@ LuaBindings::common (lua_State* L)
                .deriveClass <PBD::StatefulDestructible, PBD::Stateful> ("StatefulDestructible")
                .endClass ()
 
+               .deriveClass <PBD::Configuration, PBD::Stateful> ("Configuration")
+               .endClass()
+
                .deriveWSPtrClass <PBD::StatefulDestructible, PBD::Stateful> ("StatefulDestructiblePtr")
                .endClass ()
 
@@ -281,6 +369,42 @@ LuaBindings::common (lua_State* L)
                .addFunction ("get_value", &PBD::Controllable::get_value)
                .endClass ()
 
+               .beginClass <PBD::RingBufferNPT <uint8_t> > ("RingBuffer8")
+               .addConstructor <void (*) (size_t)> ()
+               .addFunction ("reset", &PBD::RingBufferNPT<uint8_t>::reset)
+               .addFunction ("read", &PBD::RingBufferNPT<uint8_t>::read)
+               .addFunction ("write", &PBD::RingBufferNPT<uint8_t>::write)
+               .addFunction ("write_one", &PBD::RingBufferNPT<uint8_t>::write_one)
+               .addFunction ("write_space", &PBD::RingBufferNPT<uint8_t>::write_space)
+               .addFunction ("read_space", &PBD::RingBufferNPT<uint8_t>::read_space)
+               .addFunction ("increment_read_ptr", &PBD::RingBufferNPT<uint8_t>::increment_read_ptr)
+               .addFunction ("increment_write_ptr", &PBD::RingBufferNPT<uint8_t>::increment_write_ptr)
+               .endClass ()
+
+               .beginClass <PBD::RingBufferNPT <float> > ("RingBufferF")
+               .addConstructor <void (*) (size_t)> ()
+               .addFunction ("reset", &PBD::RingBufferNPT<float>::reset)
+               .addFunction ("read", &PBD::RingBufferNPT<float>::read)
+               .addFunction ("write", &PBD::RingBufferNPT<float>::write)
+               .addFunction ("write_one", &PBD::RingBufferNPT<float>::write_one)
+               .addFunction ("write_space", &PBD::RingBufferNPT<float>::write_space)
+               .addFunction ("read_space", &PBD::RingBufferNPT<float>::read_space)
+               .addFunction ("increment_read_ptr", &PBD::RingBufferNPT<float>::increment_read_ptr)
+               .addFunction ("increment_write_ptr", &PBD::RingBufferNPT<float>::increment_write_ptr)
+               .endClass ()
+
+               .beginClass <PBD::RingBufferNPT <int> > ("RingBufferI")
+               .addConstructor <void (*) (size_t)> ()
+               .addFunction ("reset", &PBD::RingBufferNPT<int>::reset)
+               .addFunction ("read", &PBD::RingBufferNPT<int>::read)
+               .addFunction ("write", &PBD::RingBufferNPT<int>::write)
+               .addFunction ("write_one", &PBD::RingBufferNPT<int>::write_one)
+               .addFunction ("write_space", &PBD::RingBufferNPT<int>::write_space)
+               .addFunction ("read_space", &PBD::RingBufferNPT<int>::read_space)
+               .addFunction ("increment_read_ptr", &PBD::RingBufferNPT<int>::increment_read_ptr)
+               .addFunction ("increment_write_ptr", &PBD::RingBufferNPT<int>::increment_write_ptr)
+               .endClass ()
+
                /* PBD enums */
                .beginNamespace ("GroupControlDisposition")
                .addConst ("InverseGroup", PBD::Controllable::GroupControlDisposition(PBD::Controllable::InverseGroup))
@@ -294,12 +418,58 @@ LuaBindings::common (lua_State* L)
                .beginNamespace ("Timecode")
                .beginClass <Timecode::BBT_Time> ("BBT_TIME")
                .addConstructor <void (*) (uint32_t, uint32_t, uint32_t)> ()
+               .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 <Timecode::Time> ("Time")
+               .addConstructor <void (*) (double)> ()
+               .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))
+               .addConst ("TC24", Timecode::TimecodeFormat(Timecode::timecode_24))
+               .addConst ("TC24976", Timecode::TimecodeFormat(Timecode::timecode_24976))
+               .addConst ("TC25", Timecode::TimecodeFormat(Timecode::timecode_25))
+               .addConst ("TC2997", Timecode::TimecodeFormat(Timecode::timecode_2997))
+               .addConst ("TC2997DF", Timecode::TimecodeFormat(Timecode::timecode_2997drop))
+               .addConst ("TC2997000", Timecode::TimecodeFormat(Timecode::timecode_2997000))
+               .addConst ("TC2997000DF", Timecode::TimecodeFormat(Timecode::timecode_2997000drop))
+               .addConst ("TC30", Timecode::TimecodeFormat(Timecode::timecode_30))
+               .addConst ("TC5994", Timecode::TimecodeFormat(Timecode::timecode_5994))
+               .addConst ("TC60", Timecode::TimecodeFormat(Timecode::timecode_60))
+               .endNamespace ()
                .endNamespace ();
 
        luabridge::getGlobalNamespace (L)
 
                .beginNamespace ("Evoral")
+               .beginClass <Evoral::Event<framepos_t> > ("Event")
+               .addFunction ("clear", &Evoral::Event<framepos_t>::clear)
+               .addFunction ("size", &Evoral::Event<framepos_t>::size)
+               .addFunction ("set_buffer", &Evoral::Event<framepos_t>::set_buffer)
+               .addFunction ("buffer", (uint8_t*(Evoral::Event<framepos_t>::*)())&Evoral::Event<framepos_t>::buffer)
+               .addFunction ("time", (framepos_t (Evoral::Event<framepos_t>::*)())&Evoral::Event<framepos_t>::time)
+               .endClass ()
+
+               .beginClass <Evoral::Beats> ("Beats")
+               .addConstructor <void (*) (double)> ()
+               .addFunction ("to_double", &Evoral::Beats::to_double)
+               .endClass ()
+
                .beginClass <Evoral::Parameter> ("Parameter")
                .addConstructor <void (*) (uint32_t, uint8_t, uint32_t)> ()
                .addFunction ("type", &Evoral::Parameter::type)
@@ -341,6 +511,18 @@ LuaBindings::common (lua_State* L)
                .addData ("to", &Evoral::Range<framepos_t>::to)
                .endClass ()
 
+               .deriveWSPtrClass <Evoral::Sequence<Evoral::Beats>, Evoral::ControlSet> ("Sequence")
+               .endClass ()
+
+               .beginWSPtrClass <Evoral::Note<Evoral::Beats> > ("NotePtr")
+               .addFunction ("time", &Evoral::Note<Evoral::Beats>::time)
+               .addFunction ("note", &Evoral::Note<Evoral::Beats>::note)
+               .addFunction ("velocity", &Evoral::Note<Evoral::Beats>::velocity)
+               .addFunction ("off_velocity", &Evoral::Note<Evoral::Beats>::off_velocity)
+               .addFunction ("length", &Evoral::Note<Evoral::Beats>::length)
+               .addFunction ("channel", &Evoral::Note<Evoral::Beats>::channel)
+               .endClass ()
+
                /* libevoral enums */
                .beginNamespace ("InterpolationStyle")
                .addConst ("Discrete", Evoral::ControlList::InterpolationStyle(Evoral::ControlList::Discrete))
@@ -348,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<Vamp::RealTime> ("RealTime")
+               .addConstructor <void (*) (int, int)> ()
+               .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<Vamp::PluginBase> ("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<Vamp::PluginBase::ParameterDescriptor> ("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 <Vamp::PluginBase::ParameterDescriptor> ("ParameterList")
+               .endClass ()
+               .endNamespace () // Vamp::PluginBase
+
+               .deriveClass<Vamp::Plugin, Vamp::PluginBase> ("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<Vamp::Plugin::OutputDescriptor> ("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<Vamp::Plugin::Feature> ("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 <Vamp::Plugin::OutputDescriptor> ("OutputList")
+               .endClass ()
+
+               .beginStdVector <Vamp::Plugin::Feature> ("FeatureList")
+               .endClass ()
+
+               .beginStdMap <int, Vamp::Plugin::FeatureList> ("FeatureSet")
+               .endClass ()
+
+               .endNamespace () // Vamp::Plugin
+               .endNamespace ();// Vamp
+
+       luabridge::getGlobalNamespace (L)
                .beginNamespace ("ARDOUR")
 
                .beginClass <InterThreadInfo> ("InterThreadInfo")
@@ -361,6 +660,16 @@ LuaBindings::common (lua_State* L)
                .addData ("progress", const_cast<float InterThreadInfo::*>(&InterThreadInfo::progress))
                .endClass ()
 
+               .beginClass <Progress> ("Progress")
+               .endClass ()
+
+               .beginClass <MusicFrame> ("MusicFrame")
+               .addConstructor <void (*) (framepos_t, int32_t)> ()
+               .addFunction ("set", &MusicFrame::set)
+               .addData ("frame", &MusicFrame::frame)
+               .addData ("division", &MusicFrame::division)
+               .endClass ()
+
                .beginClass <AudioRange> ("AudioRange")
                .addConstructor <void (*) (framepos_t, framepos_t, uint32_t)> ()
                .addFunction ("length", &AudioRange::length)
@@ -371,7 +680,17 @@ LuaBindings::common (lua_State* L)
                .endClass ()
 
                .beginWSPtrClass <PluginInfo> ("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")
@@ -384,6 +703,9 @@ LuaBindings::common (lua_State* L)
                .addVoidConstructor ()
                .addFunction ("get", static_cast<uint32_t(ChanMapping::*)(DataType, uint32_t) const>(&ChanMapping::get))
                .addFunction ("set", &ChanMapping::set)
+               .addFunction ("count", &ChanMapping::count)
+               .addFunction ("n_total", &ChanMapping::n_total)
+               .addFunction ("is_monotonic", &ChanMapping::is_monotonic)
                .addConst ("Invalid", 4294967295U) // UINT32_MAX
                .endClass ()
 
@@ -428,8 +750,10 @@ LuaBindings::common (lua_State* L)
                .endClass ()
 
                .deriveClass <Location, PBD::StatefulDestructible> ("Location")
+               .addFunction ("name", &Location::name)
                .addFunction ("locked", &Location::locked)
                .addFunction ("lock", &Location::lock)
+               .addFunction ("unlock", &Location::unlock)
                .addFunction ("start", &Location::start)
                .addFunction ("_end", &Location::end) // XXX "end" is a lua reserved word
                .addFunction ("length", &Location::length)
@@ -437,15 +761,26 @@ LuaBindings::common (lua_State* L)
                .addFunction ("set_end", &Location::set_end)
                .addFunction ("set_length", &Location::set)
                .addFunction ("move_to", &Location::move_to)
+               .addFunction ("matches", &Location::matches)
+               .addFunction ("flags", &Location::flags)
+               .addFunction ("is_auto_punch", &Location::is_auto_punch)
+               .addFunction ("is_auto_loop", &Location::is_auto_loop)
+               .addFunction ("is_mark", &Location::is_mark)
+               .addFunction ("is_hidden", &Location::is_hidden)
+               .addFunction ("is_cd_marker", &Location::is_cd_marker)
+               .addFunction ("is_session_range", &Location::is_session_range)
+               .addFunction ("is_range_marker", &Location::is_range_marker)
                .endClass ()
 
                .deriveClass <Locations, PBD::StatefulDestructible> ("Locations")
+               .addFunction ("list", static_cast<Locations::LocationList (Locations::*)()>(&Locations::list))
                .addFunction ("auto_loop_location", &Locations::auto_loop_location)
                .addFunction ("auto_punch_location", &Locations::auto_punch_location)
                .addFunction ("session_range_location", &Locations::session_range_location)
                .addFunction ("first_mark_after", &Locations::first_mark_after)
                .addFunction ("first_mark_before", &Locations::first_mark_before)
                .addFunction ("first_mark_at", &Locations::mark_at)
+               .addFunction ("remove", &Locations::remove)
                .addRefFunction ("marks_either_side", &Locations::marks_either_side)
                .addRefFunction ("find_all_between", &Locations::find_all_between)
                .endClass ()
@@ -468,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 ()
 
@@ -502,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<Port>, 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)
@@ -511,12 +844,103 @@ LuaBindings::common (lua_State* L)
                .addFunction ("n_ports", &IO::n_ports)
                .endClass ()
 
-               .beginClass <RouteGroup> ("RouteGroup")
-               // stub RouteGroup* is needed for new_audio_track()
+               .deriveWSPtrClass <PannerShell, SessionObject> ("PannerShell")
+               .addFunction ("bypassed", &PannerShell::bypassed)
+               .addFunction ("set_bypassed", &PannerShell::set_bypassed)
                .endClass ()
 
-               .deriveWSPtrClass <Route, SessionObject> ("Route")
+               .beginClass <RouteGroup> ("RouteGroup")
+               .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, PBD::Stateful> ("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, SessionObject> ("Stripable")
+               .addCast<Route> ("to_route")
+               .addFunction ("is_auditioner", &Stripable::is_auditioner)
+               .addFunction ("is_master", &Stripable::is_master)
+               .addFunction ("is_monitor", &Stripable::is_monitor)
+               .addFunction ("is_hidden", &Stripable::is_hidden)
+               .addFunction ("is_selected", &Stripable::is_selected)
+               .addFunction ("gain_control", &Stripable::gain_control)
+               .addFunction ("solo_control", &Stripable::solo_control)
+               .addFunction ("solo_isolate_control", &Stripable::solo_isolate_control)
+               .addFunction ("solo_safe_control", &Stripable::solo_safe_control)
+               .addFunction ("mute_control", &Stripable::mute_control)
+               .addFunction ("phase_control", &Stripable::phase_control)
+               .addFunction ("trim_control", &Stripable::trim_control)
+               .addFunction ("rec_enable_control", &Stripable::rec_enable_control)
+               .addFunction ("rec_safe_control", &Stripable::rec_safe_control)
+               .addFunction ("pan_azimuth_control", &Stripable::pan_azimuth_control)
+               .addFunction ("pan_elevation_control", &Stripable::pan_elevation_control)
+               .addFunction ("pan_width_control", &Stripable::pan_width_control)
+               .addFunction ("pan_frontback_control", &Stripable::pan_frontback_control)
+               .addFunction ("pan_lfe_control", &Stripable::pan_lfe_control)
+               .addFunction ("send_level_control", &Stripable::send_level_controllable)
+               .addFunction ("send_enable_control", &Stripable::send_level_controllable)
+               .addFunction ("send_name", &Stripable::send_name)
+               .addFunction ("monitor_control", &Stripable::monitor_control)
+               .addFunction ("master_send_enable_control ", &Stripable::master_send_enable_controllable )
+               .addFunction ("comp_enable_control ", &Stripable::comp_enable_controllable )
+               .addFunction ("comp_threshold_control ", &Stripable::comp_threshold_controllable )
+               .addFunction ("comp_speed_control ", &Stripable::comp_speed_controllable )
+               .addFunction ("comp_mode_control ", &Stripable::comp_mode_controllable )
+               .addFunction ("comp_makeup_control ", &Stripable::comp_makeup_controllable )
+               .addFunction ("comp_redux_control ", &Stripable::comp_redux_controllable )
+               .addFunction ("comp_mode_name", &Stripable::comp_mode_name)
+               .addFunction ("comp_speed_name", &Stripable::comp_speed_name)
+               .addFunction ("eq_band_cnt ", &Stripable::eq_band_cnt)
+               .addFunction ("eq_band_name", &Stripable::eq_band_name)
+               .addFunction ("eq_gain_control", &Stripable::eq_gain_controllable)
+               .addFunction ("eq_freq_control ", &Stripable::eq_freq_controllable )
+               .addFunction ("eq_q_control ", &Stripable::eq_q_controllable )
+               .addFunction ("eq_shape_control ", &Stripable::eq_shape_controllable )
+               .addFunction ("eq_enable_control ", &Stripable::eq_enable_controllable )
+               .addFunction ("eq_hpf_control ", &Stripable::eq_hpf_controllable )
+               .addFunction ("set_presentation_order", &Stripable::set_presentation_order)
+               .addFunction ("presentation_info_ptr", &Stripable::presentation_info_ptr)
+
+               .endClass ()
+
+               .deriveWSPtrClass <Route, Stripable> ("Route")
                .addCast<Track> ("to_track")
+               .addCast<Automatable> ("to_automatable")
                .addFunction ("set_name", &Route::set_name)
                .addFunction ("comment", &Route::comment)
                .addFunction ("active", &Route::active)
@@ -526,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)
@@ -541,14 +971,18 @@ LuaBindings::common (lua_State* L)
                .addFunction ("soloed", &Route::soloed)
                .addFunction ("amp", &Route::amp)
                .addFunction ("trim", &Route::trim)
+               .addFunction ("peak_meter", (boost::shared_ptr<PeakMeter> (Route::*)())&Route::peak_meter)
+               .addFunction ("set_meter_point", &Route::set_meter_point)
                .endClass ()
 
                .deriveWSPtrClass <Playlist, SessionObject> ("Playlist")
+               .addCast<AudioPlaylist> ("to_audioplaylist")
+               .addCast<MidiPlaylist> ("to_midiplaylist")
                .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<framepos_t, framepos_t>
-               //.addFunction ("region_list", &Playlist::region_list) // RegionListProperty&
+               .addFunction ("region_list", &Playlist::region_list)
                .addFunction ("add_region", &Playlist::add_region)
                .addFunction ("remove_region", &Playlist::remove_region)
                .addFunction ("regions_at", &Playlist::regions_at)
@@ -578,15 +1012,19 @@ LuaBindings::common (lua_State* L)
 #endif
                .endClass ()
 
+               .deriveWSPtrClass <AudioPlaylist, Playlist> ("AudioPlaylist")
+               .addFunction ("read", &AudioPlaylist::read)
+               .endClass ()
+
+               .deriveWSPtrClass <MidiPlaylist, Playlist> ("MidiPlaylist")
+               .addFunction ("set_note_mode", &MidiPlaylist::set_note_mode)
+               .endClass ()
+
                .deriveWSPtrClass <Track, Route> ("Track")
                .addCast<AudioTrack> ("to_audio_track")
                .addCast<MidiTrack> ("to_midi_track")
                .addFunction ("set_name", &Track::set_name)
                .addFunction ("can_record", &Track::can_record)
-               //.addFunction ("record_enabled", &Track::record_enabled)
-               //.addFunction ("record_safe", &Track::record_safe)
-               //.addFunction ("set_record_enabled", &Track::set_record_enabled)
-               //.addFunction ("set_record_safe", &Track::set_record_safe)
                .addFunction ("bounceable", &Track::bounceable)
                .addFunction ("bounce", &Track::bounce)
                .addFunction ("bounce_range", &Track::bounce_range)
@@ -599,7 +1037,16 @@ LuaBindings::common (lua_State* L)
                .deriveWSPtrClass <MidiTrack, Track> ("MidiTrack")
                .endClass ()
 
+               .beginWSPtrClass <Readable> ("Readable")
+               .addFunction ("read", &Readable::read)
+               .addFunction ("readable_length", &Readable::readable_length)
+               .addFunction ("n_channels", &Readable::n_channels)
+               .endClass ()
+
                .deriveWSPtrClass <Region, SessionObject> ("Region")
+               .addCast<Readable> ("to_readable")
+               .addCast<MidiRegion> ("to_midiregion")
+               .addCast<AudioRegion> ("to_audioregion")
                /* properties */
                .addFunction ("position", &Region::position)
                .addFunction ("start", &Region::start)
@@ -634,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)
@@ -645,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, Region> ("MidiRegion")
+               .addFunction ("do_export", &MidiRegion::do_export)
+               .addFunction ("midi_source", &MidiRegion::midi_source)
+               .addFunction ("model", (boost::shared_ptr<MidiModel> (MidiRegion::*)())&MidiRegion::midi_source)
+               .addFunction ("start_beats", &MidiRegion::start_beats)
+               .addFunction ("length_beats", &MidiRegion::length_beats)
+               .endClass ()
+
+               .deriveWSPtrClass <AudioRegion, Region> ("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, SessionObject> ("Source")
+               .addCast<AudioSource> ("to_audiosource")
+               .addCast<MidiSource> ("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, Source> ("MidiSource")
+               .addFunction ("empty", &MidiSource::empty)
+               .addFunction ("length", &MidiSource::length)
+               .addFunction ("model", &MidiSource::model)
+               .endClass ()
+
+               .deriveWSPtrClass <AudioSource, Source> ("AudioSource")
+               .addCast<Readable> ("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, Evoral::ControlSet> ("Automatable")
+               .addFunction ("automation_control", (boost::shared_ptr<AutomationControl>(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control)
+               .endClass ()
+
+               .deriveWSPtrClass <AutomatableSequence<Evoral::Beats>, Automatable> ("AutomatableSequence")
+               .addCast<Evoral::Sequence<Evoral::Beats> > ("to_sequence")
+               .endClass ()
+
+               .deriveWSPtrClass <MidiModel, AutomatableSequence<Evoral::Beats> > ("MidiModel")
+               .addFunction ("apply_command", (void (MidiModel::*)(Session*, Command*))&MidiModel::apply_command)
+               .addFunction ("new_note_diff_command", &MidiModel::new_note_diff_command)
                .endClass ()
 
-               .beginWSPtrClass <Source> ("Source")
+               .beginNamespace ("MidiModel")
+               .deriveClass<ARDOUR::MidiModel::DiffCommand, Command> ("DiffCommand")
                .endClass ()
 
+               .deriveClass<ARDOUR::MidiModel::NoteDiffCommand, ARDOUR::MidiModel::DiffCommand> ("NoteDiffCommand")
+               .addFunction ("add", &ARDOUR::MidiModel::NoteDiffCommand::add)
+               .addFunction ("remove", &ARDOUR::MidiModel::NoteDiffCommand::remove)
+               .endClass ()
+
+               .endNamespace () /* ARDOUR::MidiModel */
+
                .beginClass <Plugin::PresetRecord> ("PresetRecord")
                .addVoidConstructor ()
                .addData ("uri", &Plugin::PresetRecord::uri, false)
@@ -664,35 +1187,39 @@ LuaBindings::common (lua_State* L)
                .addData ("valid", &Plugin::PresetRecord::valid, false)
                .endClass ()
 
-               .deriveWSPtrClass <Automatable, Evoral::ControlSet> ("Automatable")
-               .addFunction ("automation_control", (boost::shared_ptr<AutomationControl>(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control)
-               .endClass ()
+               .beginStdVector <Plugin::PresetRecord> ("PresetVector").endClass ()
 
                .deriveClass <ParameterDescriptor, Evoral::ParameterDescriptor> ("ParameterDescriptor")
                .addVoidConstructor ()
                .addData ("label", &ParameterDescriptor::label)
                .addData ("logarithmic", &ParameterDescriptor::logarithmic)
+               .addStaticFunction ("midi_note_name", &ParameterDescriptor::midi_note_name)
                .endClass ()
 
+               .beginStdVector <boost::shared_ptr<ARDOUR::Processor> > ("ProcessorVector").endClass ()
+
                .deriveWSPtrClass <Processor, SessionObject> ("Processor")
                .addCast<Automatable> ("to_automatable")
-               .addCast<PluginInsert> ("to_insert")
+               .addCast<PluginInsert> ("to_insert") // deprecated
+               .addCast<PluginInsert> ("to_plugininsert")
                .addCast<SideChain> ("to_sidechain")
                .addCast<IOProcessor> ("to_ioprocessor")
                .addCast<UnknownProcessor> ("to_unknownprocessor")
                .addCast<Amp> ("to_amp")
-#if 0 // those objects are not yet bound
+               .addCast<PeakMeter> ("to_peakmeter")
                .addCast<MonitorProcessor> ("to_monitorprocessor")
+#if 0 // those objects are not yet bound
                .addCast<CapturingProcessor> ("to_capturingprocessor")
                .addCast<DelayLine> ("to_delayline")
-               .addCast<PeakMeter> ("to_meter")
 #endif
+               .addCast<PeakMeter> ("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 ("control", (boost::shared_ptr<Evoral::Control>(Evoral::ControlSet::*)(const Evoral::Parameter&, bool))&Evoral::ControlSet::control)
-               .addFunction ("automation_control", (boost::shared_ptr<AutomationControl>(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control)
+               .addFunction ("output_streams", &PluginInsert::output_streams)
+               .addFunction ("input_streams", &PluginInsert::input_streams)
                .endClass ()
 
                .deriveWSPtrClass <IOProcessor, Processor> ("IOProcessor")
@@ -706,9 +1233,21 @@ LuaBindings::common (lua_State* L)
                .endClass ()
 
                .deriveWSPtrClass <Delivery, IOProcessor> ("Delivery")
+               .addFunction ("panner_shell", &Route::panner_shell)
+               .endClass ()
+
+               .beginNamespace ("Plugin")
+               .beginClass <Plugin::IOPortDescription> ("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, PBD::StatefulDestructible> ("Plugin")
+               .addCast<LuaProc> ("to_luaproc")
+               .addFunction ("unique_id", &Plugin::unique_id)
                .addFunction ("label", &Plugin::label)
                .addFunction ("name", &Plugin::name)
                .addFunction ("maker", &Plugin::maker)
@@ -719,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, Plugin> ("LuaProc")
+               .addFunction ("shmem", &LuaProc::instance_shm)
+               .addFunction ("table", &LuaProc::instance_ref)
+               .endClass ()
+
                .deriveWSPtrClass <PluginInsert, Processor> ("PluginInsert")
                .addFunction ("plugin", &PluginInsert::plugin)
                .addFunction ("activate", &PluginInsert::activate)
@@ -732,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, PBD::Controllable> ("AutomationControl")
@@ -749,13 +1297,84 @@ LuaBindings::common (lua_State* L)
                .addFunction ("alist", &AutomationControl::alist)
                .endClass ()
 
-               .deriveWSPtrClass <GainControl, AutomationControl> ("GainControl")
+               .deriveWSPtrClass <SlavableAutomationControl, AutomationControl> ("SlavableAutomationControl,")
+               .addFunction ("add_master", &SlavableAutomationControl::add_master)
+               .addFunction ("remove_master", &SlavableAutomationControl::remove_master)
+               .addFunction ("clear_masters", &SlavableAutomationControl::clear_masters)
+               .addFunction ("slaved_to", &SlavableAutomationControl::slaved_to)
+               .addFunction ("slaved", &SlavableAutomationControl::slaved)
+               .addFunction ("get_masters_value", &SlavableAutomationControl::get_masters_value)
+               .addFunction ("get_boolean_masters", &SlavableAutomationControl::get_boolean_masters)
+               //.addFunction ("masters", &SlavableAutomationControl::masters) // not implemented
+               .endClass ()
+
+               .deriveWSPtrClass <PhaseControl, AutomationControl> ("PhaseControl")
+               .addFunction ("set_phase_invert", (void(PhaseControl::*)(uint32_t, bool))&PhaseControl::set_phase_invert)
+               .addFunction ("inverted", &PhaseControl::inverted)
+               .endClass ()
+
+               .deriveWSPtrClass <GainControl, SlavableAutomationControl> ("GainControl")
+               .endClass ()
+
+               .deriveWSPtrClass <SoloControl, SlavableAutomationControl> ("SoloControl")
+               .addFunction ("can_solo", &SoloControl::can_solo)
+               .addFunction ("soloed", &SoloControl::soloed)
+               .addFunction ("self_soloed", &SoloControl::self_soloed)
+               .endClass ()
+
+               .deriveWSPtrClass <MuteControl, SlavableAutomationControl> ("MuteControl")
+               .addFunction ("muted", &MuteControl::muted)
+               .addFunction ("muted_by_self", &MuteControl::muted_by_self)
+               .endClass ()
+
+               .deriveWSPtrClass <SoloIsolateControl, SlavableAutomationControl> ("SoloIsolateControl")
+               .addFunction ("solo_isolated", &SoloIsolateControl::solo_isolated)
+               .addFunction ("self_solo_isolated", &SoloIsolateControl::self_solo_isolated)
+               .endClass ()
+
+               .deriveWSPtrClass <SoloSafeControl, SlavableAutomationControl> ("SoloSafeControl")
+               .addFunction ("solo_safe", &SoloSafeControl::solo_safe)
                .endClass ()
 
                .deriveWSPtrClass <Amp, Processor> ("Amp")
                .addFunction ("gain_control", (boost::shared_ptr<GainControl>(Amp::*)())&Amp::gain_control)
                .endClass ()
 
+               .deriveWSPtrClass <PeakMeter, Processor> ("PeakMeter")
+               .addFunction ("meter_level", &PeakMeter::meter_level)
+               .addFunction ("set_type", &PeakMeter::set_type)
+               .addFunction ("reset_max", &PeakMeter::reset_max)
+               .endClass ()
+
+               .deriveWSPtrClass <MonitorProcessor, Processor> ("MonitorProcessor")
+               .addFunction ("set_cut_all", &MonitorProcessor::set_cut_all)
+               .addFunction ("set_dim_all", &MonitorProcessor::set_dim_all)
+               .addFunction ("set_polarity", &MonitorProcessor::set_polarity)
+               .addFunction ("set_cut", &MonitorProcessor::set_cut)
+               .addFunction ("set_dim", &MonitorProcessor::set_dim)
+               .addFunction ("set_solo", &MonitorProcessor::set_solo)
+               .addFunction ("set_mono", &MonitorProcessor::set_mono)
+               .addFunction ("dim_level", &MonitorProcessor::dim_level)
+               .addFunction ("solo_boost_level", &MonitorProcessor::solo_boost_level)
+               .addFunction ("dimmed", &MonitorProcessor::dimmed)
+               .addFunction ("soloed", &MonitorProcessor::soloed)
+               .addFunction ("inverted", &MonitorProcessor::inverted)
+               .addFunction ("cut", &MonitorProcessor::cut)
+               .addFunction ("cut_all", &MonitorProcessor::cut_all)
+               .addFunction ("dim_all", &MonitorProcessor::dim_all)
+               .addFunction ("mono", &MonitorProcessor::mono)
+               .addFunction ("monitor_active", &MonitorProcessor::monitor_active)
+               .addFunction ("channel_cut_control", &MonitorProcessor::channel_cut_control)
+               .addFunction ("channel_dim_control", &MonitorProcessor::channel_dim_control)
+               .addFunction ("channel_polarity_control", &MonitorProcessor::channel_polarity_control)
+               .addFunction ("channel_solo_control", &MonitorProcessor::channel_solo_control)
+               .addFunction ("dim_control", &MonitorProcessor::dim_control)
+               .addFunction ("cut_control", &MonitorProcessor::cut_control)
+               .addFunction ("mono_control", &MonitorProcessor::mono_control)
+               .addFunction ("dim_level_control", &MonitorProcessor::dim_level_control)
+               .addFunction ("solo_boost_control", &MonitorProcessor::solo_boost_control)
+               .endClass ()
+
                .deriveWSPtrClass <UnknownProcessor, Processor> ("UnknownProcessor")
                .endClass ()
 
@@ -781,12 +1400,21 @@ LuaBindings::common (lua_State* L)
 
                // boost::shared_ptr<RouteList>
                .beginPtrStdList <boost::shared_ptr<Route> > ("RouteListPtr")
+               .addVoidPtrConstructor<std::list<boost::shared_ptr <Route> > > ()
                .endClass ()
 
                // typedef std::list<boost::weak_ptr <Route> > WeakRouteList
                .beginConstStdList <boost::weak_ptr<Route> > ("WeakRouteList")
                .endClass ()
 
+               // RouteList == std::list<boost::shared_ptr<Route> >
+               .beginConstStdList <RouteGroup*> ("RouteGroupList")
+               .endClass ()
+
+               // typedef std::vector<boost::shared_ptr<Source> > Region::SourceList
+               .beginStdVector <boost::shared_ptr<Source> > ("SourceList")
+               .endClass ()
+
                // std::list< boost::weak_ptr <AudioSource> >
                .beginConstStdList <boost::weak_ptr<AudioSource> > ("WeakAudioSourceList")
                .endClass ()
@@ -797,6 +1425,11 @@ LuaBindings::common (lua_State* L)
 
                // boost::shared_ptr <std::list<boost::shared_ptr<Region> > >
                .beginPtrStdList <boost::shared_ptr<Region> > ("RegionListPtr")
+               .addVoidPtrConstructor<std::list<boost::shared_ptr <Region> > > ()
+               .endClass ()
+
+               // typedef std::list<boost::shared_ptr<Processor> > ProcessorList;
+               .beginStdList <boost::shared_ptr<Processor> > ("ProcessorList")
                .endClass ()
 
                //std::list<boost::shared_ptr<Port> > PortList;
@@ -810,6 +1443,14 @@ LuaBindings::common (lua_State* L)
                .beginConstStdList <Location*> ("LocationList")
                .endClass ()
 
+               // std::list<boost::shared_ptr<AutomationControl> > ControlList;
+               .beginStdList <boost::shared_ptr<AutomationControl> > ("ControlList")
+               .endClass ()
+
+               .beginPtrStdList <boost::shared_ptr<AutomationControl> > ("ControlListPtr")
+               .addVoidPtrConstructor<std::list<boost::shared_ptr <AutomationControl> > > ()
+               .endClass ()
+
 #if 0  // depends on Evoal:: Note, Beats see note_fixer.h
        // typedef Evoral::Note<Evoral::Beats> Note;
        // std::set< boost::weak_ptr<Note> >
@@ -824,8 +1465,10 @@ LuaBindings::common (lua_State* L)
                .beginClass <Tempo> ("Tempo")
                .addConstructor <void (*) (double, double)> ()
                .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> ("Meter")
@@ -839,6 +1482,28 @@ LuaBindings::common (lua_State* L)
                .beginClass <TempoMap> ("TempoMap")
                .addFunction ("add_tempo", &TempoMap::add_tempo)
                .addFunction ("add_meter", &TempoMap::add_meter)
+               .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> ("MetricSection")
+               .addFunction ("pulse", &MetricSection::pulse)
+               .addFunction ("set_pulse", &MetricSection::set_pulse)
+               .endClass ()
+
+               .deriveClass <TempoSection, MetricSection> ("TempoSection")
+               .addFunction ("c", (double(TempoSection::*)()const)&TempoSection::c)
+               .endClass ()
+
+               .deriveClass <MeterSection, MetricSection> ("MeterSection")
+               .addCast<Meter> ("to_meter")
+               .addFunction ("set_pulse", &MeterSection::set_pulse)
+               .addFunction ("set_beat", (void(MeterSection::*)(double))&MeterSection::set_beat)
                .endClass ()
 
                .beginClass <ChanCount> ("ChanCount")
@@ -870,6 +1535,23 @@ LuaBindings::common (lua_State* L)
                .addConst ("Lua", ARDOUR::PluginType(Lua))
                .endNamespace ()
 
+               .beginNamespace ("PresentationInfo")
+               .beginNamespace ("Flag")
+               .addConst ("AudioTrack", ARDOUR::PresentationInfo::Flag(PresentationInfo::AudioTrack))
+               .addConst ("MidiTrack", ARDOUR::PresentationInfo::Flag(PresentationInfo::MidiTrack))
+               .addConst ("AudioBus", ARDOUR::PresentationInfo::Flag(PresentationInfo::AudioBus))
+               .addConst ("MidiBus", ARDOUR::PresentationInfo::Flag(PresentationInfo::MidiBus))
+               .addConst ("VCA", ARDOUR::PresentationInfo::Flag(PresentationInfo::VCA))
+               .addConst ("MasterOut", ARDOUR::PresentationInfo::Flag(PresentationInfo::MasterOut))
+               .addConst ("MonitorOut", ARDOUR::PresentationInfo::Flag(PresentationInfo::MonitorOut))
+               .addConst ("Auditioner", ARDOUR::PresentationInfo::Flag(PresentationInfo::Auditioner))
+               .addConst ("Selected", ARDOUR::PresentationInfo::Flag(PresentationInfo::Selected))
+               .addConst ("Hidden", ARDOUR::PresentationInfo::Flag(PresentationInfo::Hidden))
+               .addConst ("GroupOrderSet", ARDOUR::PresentationInfo::Flag(PresentationInfo::OrderSet))
+               .addConst ("StatusMask", ARDOUR::PresentationInfo::Flag(PresentationInfo::StatusMask))
+               .endNamespace ()
+               .endNamespace ()
+
                .beginNamespace ("AutoStyle")
                .addConst ("Absolute", ARDOUR::AutoStyle(Absolute))
                .addConst ("Trim", ARDOUR::AutoStyle(Trim))
@@ -883,15 +1565,70 @@ LuaBindings::common (lua_State* L)
                .endNamespace ()
 
                .beginNamespace ("AutomationType")
+               .addConst ("GainAutomation", ARDOUR::AutomationType(GainAutomation))
                .addConst ("PluginAutomation", ARDOUR::AutomationType(PluginAutomation))
-               .addConst ("PluginAutomation", ARDOUR::AutomationType(GainAutomation))
-               .addConst ("PluginAutomation", ARDOUR::AutomationType(TrimAutomation))
+               .addConst ("SoloAutomation", ARDOUR::AutomationType(SoloAutomation))
+               .addConst ("SoloIsolateAutomation", ARDOUR::AutomationType(SoloIsolateAutomation))
+               .addConst ("SoloSafeAutomation", ARDOUR::AutomationType(SoloSafeAutomation))
+               .addConst ("MuteAutomation", ARDOUR::AutomationType(MuteAutomation))
+               .addConst ("RecEnableAutomation", ARDOUR::AutomationType(RecEnableAutomation))
+               .addConst ("RecSafeAutomation", ARDOUR::AutomationType(RecSafeAutomation))
+               .addConst ("TrimAutomation", ARDOUR::AutomationType(TrimAutomation))
+               .addConst ("PhaseAutomation", ARDOUR::AutomationType(PhaseAutomation))
+               .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))
@@ -900,23 +1637,83 @@ 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))
                .addConst ("SyncPoint", ARDOUR::RegionPoint(SyncPoint))
                .endNamespace ()
 
+               .beginNamespace ("TempoSection")
+               .beginNamespace ("PositionLockStyle")
+               .addConst ("AudioTime", ARDOUR::PositionLockStyle(AudioTime))
+               .addConst ("MusicTime", ARDOUR::PositionLockStyle(MusicTime))
+               .endNamespace ()
+               .endNamespace ()
+
+               .beginNamespace ("TempoSection")
+               .beginNamespace ("Type")
+               .addConst ("Ramp", ARDOUR::TempoSection::Type(TempoSection::Ramp))
+               .addConst ("Constant", ARDOUR::TempoSection::Type(TempoSection::Constant))
+               .endNamespace ()
+               .endNamespace ()
+
                .beginNamespace ("TrackMode")
                .addConst ("Normal", ARDOUR::TrackMode(Start))
                .addConst ("NonLayered", ARDOUR::TrackMode(NonLayered))
                .addConst ("Destructive", ARDOUR::TrackMode(Destructive))
                .endNamespace ()
+
+               .beginNamespace ("SampleFormat")
+               .addConst ("Float", ARDOUR::SampleFormat(FormatFloat))
+               .addConst ("Int24", ARDOUR::SampleFormat(FormatInt24))
+               .addConst ("Int16", ARDOUR::SampleFormat(FormatInt16))
+               .endNamespace ()
+
+               .beginNamespace ("HeaderFormat")
+               .addConst ("BWF", ARDOUR::HeaderFormat(BWF))
+               .addConst ("WAVE", ARDOUR::HeaderFormat(WAVE))
+               .addConst ("WAVE64", ARDOUR::HeaderFormat(WAVE64))
+               .addConst ("CAF", ARDOUR::HeaderFormat(CAF))
+               .addConst ("AIFF", ARDOUR::HeaderFormat(AIFF))
+               .addConst ("iXML", ARDOUR::HeaderFormat(iXML))
+               .addConst ("RF64", ARDOUR::HeaderFormat(RF64))
+               .addConst ("RF64_WAV", ARDOUR::HeaderFormat(RF64_WAV))
+               .addConst ("MBWF", ARDOUR::HeaderFormat(MBWF))
+               .endNamespace ()
+
+               .beginNamespace ("InsertMergePolicy")
+               .addConst ("Reject", ARDOUR::InsertMergePolicy(InsertMergeReject))
+               .addConst ("Relax", ARDOUR::InsertMergePolicy(InsertMergeRelax))
+               .addConst ("Replace", ARDOUR::InsertMergePolicy(InsertMergeReplace))
+               .addConst ("TruncateExisting", ARDOUR::InsertMergePolicy(InsertMergeTruncateExisting))
+               .addConst ("TruncateAddition", ARDOUR::InsertMergePolicy(InsertMergeTruncateAddition))
+               .addConst ("Extend", ARDOUR::InsertMergePolicy(InsertMergeExtend))
+               .endNamespace ()
+
                .endNamespace (); // end ARDOUR
 
        luabridge::getGlobalNamespace (L)
@@ -996,6 +1793,25 @@ LuaBindings::common (lua_State* L)
                .addFunction ("set_buffer_size", &AudioEngine::set_buffer_size)
                .addFunction ("get_last_backend_error", &AudioEngine::get_last_backend_error)
                .endClass()
+
+               .deriveClass <SessionConfiguration, PBD::Configuration> ("SessionConfiguration")
+#undef  CONFIG_VARIABLE
+#undef  CONFIG_VARIABLE_SPECIAL
+#define CONFIG_VARIABLE(Type,var,name,value) \
+               .addFunction ("get_" # var, &SessionConfiguration::get_##var) \
+               .addFunction ("set_" # var, &SessionConfiguration::set_##var) \
+               .addProperty (#var, &SessionConfiguration::get_##var, &SessionConfiguration::set_##var)
+
+#define CONFIG_VARIABLE_SPECIAL(Type,var,name,value,mutator) \
+               .addFunction ("get_" # var, &SessionConfiguration::get_##var) \
+               .addFunction ("set_" # var, &SessionConfiguration::set_##var) \
+               .addProperty (#var, &SessionConfiguration::get_##var, &SessionConfiguration::set_##var)
+
+#include "ardour/session_configuration_vars.h"
+
+#undef CONFIG_VARIABLE
+#undef CONFIG_VARIABLE_SPECIAL
+               .endClass()
                .endNamespace ();
 
        // basic representation of Session
@@ -1010,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)
@@ -1024,16 +1842,20 @@ LuaBindings::common (lua_State* L)
                .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_track", &Session::new_midi_track)
                .addFunction ("new_midi_route", &Session::new_midi_route)
                .addFunction ("get_routes", &Session::get_routes)
                .addFunction ("get_tracks", &Session::get_tracks)
                .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)
-               // STRIPABLE .addFunction ("route_by_remote_id", &Session::route_by_remote_id)
+               .addFunction ("get_remote_nth_stripable", &Session::get_remote_nth_stripable)
+               .addFunction ("get_remote_nth_route", &Session::get_remote_nth_route)
+               .addFunction ("route_by_selected_count", &Session::route_by_selected_count)
                .addFunction ("track_by_diskstream_id", &Session::track_by_diskstream_id)
                .addFunction ("source_by_id", &Session::source_by_id)
                .addFunction ("controllable_by_id", &Session::controllable_by_id)
@@ -1041,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)
@@ -1054,6 +1885,12 @@ LuaBindings::common (lua_State* L)
                .addFunction ("worst_input_latency", &Session::worst_input_latency)
                .addFunction ("worst_track_latency", &Session::worst_track_latency)
                .addFunction ("worst_playback_latency", &Session::worst_playback_latency)
+               .addFunction ("cfg", &Session::cfg)
+               .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> ("RegionFactory")
@@ -1091,74 +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> ("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> ("MidiBuffer")
-               .addEqualCheck ()
-               .addFunction ("silence", &MidiBuffer::silence)
-               .addFunction ("push_event", (bool (MidiBuffer::*)(const Evoral::MIDIEvent<framepos_t>&))&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<const Evoral::MIDIEvent<framepos_t>, MidiBuffer>)
-               .endClass()
-
-               .beginClass <BufferSet> ("BufferSet")
-               .addEqualCheck ()
-               .addFunction ("get_audio", static_cast<AudioBuffer&(BufferSet::*)(size_t)>(&BufferSet::get_audio))
-               .addFunction ("count", static_cast<const ChanCount&(BufferSet::*)()const>(&BufferSet::count))
-               .endClass()
-               .endNamespace ();
-
-       luabridge::getGlobalNamespace (L)
-               .beginNamespace ("Evoral")
-               .beginClass <Evoral::Event<framepos_t> > ("Event")
-               .addFunction ("clear", &Evoral::Event<framepos_t>::clear)
-               .addFunction ("size", &Evoral::Event<framepos_t>::size)
-               .addFunction ("set_buffer", &Evoral::Event<framepos_t>::set_buffer)
-               .addFunction ("buffer", (uint8_t*(Evoral::Event<framepos_t>::*)())&Evoral::Event<framepos_t>::buffer)
-               .endClass ()
-
-               .beginClass <Evoral::Beats> ("Beats")
-               .addFunction ("to_double", &Evoral::Beats::to_double)
+               .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 <ARDOUR::LuaAPI::Vamp> ("Vamp")
+               .addConstructor <void (*) (const std::string&, float)> ()
+               .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 ()
 
-               .deriveClass <Evoral::MIDIEvent<framepos_t>, Evoral::Event<framepos_t> > ("MidiEvent")
-               // add Ctor?
-               .addFunction ("type", &Evoral::MIDIEvent<framepos_t>::type)
-               .addFunction ("channel", &Evoral::MIDIEvent<framepos_t>::channel)
-               .addFunction ("set_type", &Evoral::MIDIEvent<framepos_t>::set_type)
-               .addFunction ("set_channel", &Evoral::MIDIEvent<framepos_t>::set_channel)
-               .endClass ()
-               .endNamespace ();
-
-       // dsp releated session functions
-       luabridge::getGlobalNamespace (L)
-               .beginNamespace ("ARDOUR")
-               .beginClass <Session> ("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")
@@ -1175,6 +1971,7 @@ LuaBindings::dsp (lua_State* L)
                .addFunction ("mmult", &DSP::mmult)
                .addFunction ("log_meter", &DSP::log_meter)
                .addFunction ("log_meter_coeff", &DSP::log_meter_coeff)
+               .addFunction ("process_map", &DSP::process_map)
                .addRefFunction ("peaks", &DSP::peaks)
 
                .beginClass <DSP::LowPass> ("LowPass")
@@ -1188,9 +1985,17 @@ LuaBindings::dsp (lua_State* L)
                .addConstructor <void (*) (double)> ()
                .addFunction ("run", &DSP::Biquad::run)
                .addFunction ("compute", &DSP::Biquad::compute)
+               .addFunction ("configure", &DSP::Biquad::configure)
                .addFunction ("reset", &DSP::Biquad::reset)
                .addFunction ("dB_at_freq", &DSP::Biquad::dB_at_freq)
                .endClass ()
+               .beginClass <DSP::FFTSpectrum> ("FFTSpectrum")
+               .addConstructor <void (*) (uint32_t, double)> ()
+               .addFunction ("set_data_hann", &DSP::FFTSpectrum::set_data_hann)
+               .addFunction ("execute", &DSP::FFTSpectrum::execute)
+               .addFunction ("power_at_bin", &DSP::FFTSpectrum::power_at_bin)
+               .addFunction ("freq_at_bin", &DSP::FFTSpectrum::freq_at_bin)
+               .endClass ()
 
                /* DSP enums */
                .beginNamespace ("BiquadType")
@@ -1206,6 +2011,7 @@ LuaBindings::dsp (lua_State* L)
                .endNamespace ()
 
                .beginClass <DSP::DspShm> ("DspShm")
+               .addConstructor<void (*) (size_t)> ()
                .addFunction ("allocate", &DSP::DspShm::allocate)
                .addFunction ("clear", &DSP::DspShm::clear)
                .addFunction ("to_float", &DSP::DspShm::to_float)
@@ -1215,6 +2021,87 @@ LuaBindings::dsp (lua_State* L)
                .endClass ()
 
                .endNamespace () // DSP
+               .endNamespace ();// end ARDOUR
+}
+
+void
+LuaBindings::dsp (lua_State* L)
+{
+       luabridge::getGlobalNamespace (L)
+               .beginNamespace ("ARDOUR")
+
+               .beginClass <AudioBuffer> ("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> ("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<framepos_t>&))&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<const Evoral::Event<framepos_t>, MidiBuffer>)
+               .endClass()
+
+               .beginClass <BufferSet> ("BufferSet")
+               .addEqualCheck ()
+               .addFunction ("get_audio", static_cast<AudioBuffer&(BufferSet::*)(size_t)>(&BufferSet::get_audio))
+               .addFunction ("get_midi", static_cast<MidiBuffer&(BufferSet::*)(size_t)>(&BufferSet::get_midi))
+               .addFunction ("count", static_cast<const ChanCount&(BufferSet::*)()const>(&BufferSet::count))
+               .endClass()
+               .endNamespace ();
+
+       luabridge::getGlobalNamespace (L)
+               .beginNamespace ("Evoral")
+               .deriveClass <Evoral::Event<framepos_t>, Evoral::Event<framepos_t> > ("Event")
+               // add Ctor?
+               .addFunction ("type", &Evoral::Event<framepos_t>::type)
+               .addFunction ("channel", &Evoral::Event<framepos_t>::channel)
+               .addFunction ("set_type", &Evoral::Event<framepos_t>::set_type)
+               .addFunction ("set_channel", &Evoral::Event<framepos_t>::set_channel)
+               .endClass ()
+               .endNamespace ();
+
+       // dsp releated session functions
+       luabridge::getGlobalNamespace (L)
+               .beginNamespace ("ARDOUR")
+               .beginClass <Session> ("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> ("FluidSynth")
+               .addConstructor <void (*) (float, int)> ()
+               .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> ("LuaTableRef")
+               .addCFunction ("get", &LuaTableRef::get)
+               .addCFunction ("set", &LuaTableRef::set)
+               .endClass ()
+
                .endNamespace (); // ARDOUR
 }
 
@@ -1228,8 +2115,9 @@ 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<RouteList (Session::*)(uint32_t, const std::string&, const std::string&, PlaylistDisposition)> ("new_route_from_template", &Session::new_route_from_template)
+               .addFunction<RouteList (Session::*)(uint32_t, PresentationInfo::order_t, const std::string&, const std::string&, PlaylistDisposition)> ("new_route_from_template", &Session::new_route_from_template)
                // TODO  session_add_audio_track  session_add_midi_track  session_add_mixed_track
                //.addFunction ("new_midi_track", &Session::new_midi_track)
                .endClass ()