convert codebase to use Temporal for various time types
[ardour.git] / libs / ardour / luabindings.cc
index 66ff8d626d00fbee116a164ba0b6cbd54956b623..b8932d9301b2d97cb0d5d644d3b43d8dfd620cda 100644 (file)
@@ -18,7 +18,7 @@
 
 #include <glibmm.h>
 
-#include "timecode/bbt_time.h"
+#include "temporal/bbt_time.h"
 #include "pbd/stateful_diff_command.h"
 #include "pbd/openuri.h"
 #include "evoral/Control.hpp"
 #include "ardour/audio_track.h"
 #include "ardour/audioplaylist.h"
 #include "ardour/buffer_set.h"
+#include "ardour/beats_samples_converter.h"
 #include "ardour/chan_mapping.h"
 #include "ardour/dB.h"
 #include "ardour/dsp_filter.h"
+#include "ardour/file_source.h"
 #include "ardour/fluid_synth.h"
 #include "ardour/interthread_info.h"
 #include "ardour/lua_api.h"
@@ -56,6 +58,7 @@
 #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"
@@ -68,6 +71,8 @@
 #include "ardour/stripable.h"
 #include "ardour/track.h"
 #include "ardour/tempo.h"
+#include "ardour/vca.h"
+#include "ardour/vca_manager.h"
 
 #include "LuaBridge/LuaBridge.h"
 
@@ -137,23 +142,36 @@ luabridge::getIdentityKey ()
        template void const* luabridge::ClassInfo< CLS >::getConstKey();
 
 CLASSINFO(ArdourMarker);
+CLASSINFO(AxisView);
 CLASSINFO(MarkerSelection);
 CLASSINFO(PublicEditor);
 CLASSINFO(RegionSelection);
+CLASSINFO(RegionView);
+CLASSINFO(StripableTimeAxisView);
+CLASSINFO(RouteTimeAxisView);
+CLASSINFO(RouteUI);
+CLASSINFO(Selectable);
 CLASSINFO(Selection);
+CLASSINFO(TimeAxisView);
+CLASSINFO(TimeAxisViewItem);
 CLASSINFO(TimeSelection);
 CLASSINFO(TrackSelection);
 CLASSINFO(TrackViewList);
 
-CLASSKEYS(std::bitset<47ul>); // LuaSignal::LAST_SIGNAL
+
+CLASSKEYS(std::bitset<48ul>); // LuaSignal::LAST_SIGNAL
 
 CLASSKEYS(void);
 CLASSKEYS(float);
 CLASSKEYS(unsigned char);
 
 CLASSKEYS(ArdourMarker*);
+CLASSKEYS(Selectable*);
+CLASSKEYS(std::list<Selectable*>);
 
 CLASSKEYS(ARDOUR::AudioEngine);
+CLASSKEYS(ARDOUR::BeatsSamplesConverter);
+CLASSKEYS(ARDOUR::DoubleBeatsSamplesConverter);
 CLASSKEYS(ARDOUR::BufferSet);
 CLASSKEYS(ARDOUR::ChanCount);
 CLASSKEYS(ARDOUR::ChanMapping);
@@ -175,39 +193,51 @@ CLASSKEYS(ARDOUR::Plugin::PresetRecord);
 CLASSKEYS(ARDOUR::PortEngine);
 CLASSKEYS(ARDOUR::PortManager);
 CLASSKEYS(ARDOUR::PresentationInfo);
+CLASSKEYS(ARDOUR::RCConfiguration);
 CLASSKEYS(ARDOUR::Session);
 CLASSKEYS(ARDOUR::SessionConfiguration);
+CLASSKEYS(ARDOUR::Slavable);
 CLASSKEYS(ARDOUR::Source);
+CLASSKEYS(ARDOUR::VCA);
+CLASSKEYS(ARDOUR::VCAManager);
 
 CLASSKEYS(PBD::ID);
 CLASSKEYS(PBD::Configuration);
 CLASSKEYS(PBD::PropertyChange);
 CLASSKEYS(PBD::StatefulDestructible);
 
-CLASSKEYS(Evoral::Beats);
-CLASSKEYS(Evoral::Event<framepos_t>);
+CLASSKEYS(Temporal::Beats);
+CLASSKEYS(Evoral::Event<samplepos_t>);
+CLASSKEYS(Evoral::ControlEvent);
 
 
 CLASSKEYS(std::vector<std::string>);
 CLASSKEYS(std::vector<float>);
 CLASSKEYS(std::vector<float*>);
 CLASSKEYS(std::vector<double>);
+CLASSKEYS(std::list<int64_t>);
+
+CLASSKEYS(std::list<Evoral::ControlEvent*>);
 
 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<TimeAxisView*>);
 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(std::list<boost::shared_ptr<ARDOUR::Stripable> >);
+CLASSKEYS(boost::shared_ptr<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::AutomatableSequence<Temporal::Beats> >);
 CLASSKEYS(boost::shared_ptr<ARDOUR::AutomationList>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::FileSource>);
 CLASSKEYS(boost::shared_ptr<ARDOUR::MidiModel>);
 CLASSKEYS(boost::shared_ptr<ARDOUR::MidiPlaylist>);
 CLASSKEYS(boost::shared_ptr<ARDOUR::MidiRegion>);
@@ -217,10 +247,14 @@ 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::shared_ptr<Evoral::Note<Temporal::Beats> >);
+CLASSKEYS(boost::shared_ptr<Evoral::Sequence<Temporal::Beats> >);
 
+CLASSKEYS(boost::shared_ptr<ARDOUR::Playlist>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::Route>);
+CLASSKEYS(boost::shared_ptr<ARDOUR::VCA>);
 CLASSKEYS(boost::weak_ptr<ARDOUR::Route>);
+CLASSKEYS(boost::weak_ptr<ARDOUR::VCA>);
 
 CLASSKEYS(Vamp::RealTime);
 CLASSKEYS(Vamp::PluginBase);
@@ -236,6 +270,12 @@ namespace LuaCairo {
        class ImageSurface;
        class PangoLayout;
 }
+
+namespace LuaDialog {
+       class Message;
+       class Dialog;
+}
+
 namespace Cairo {
        class Context;
 }
@@ -244,6 +284,9 @@ CLASSKEYS(Cairo::Context);
 CLASSKEYS(LuaCairo::ImageSurface);
 CLASSKEYS(LuaCairo::PangoLayout);
 
+CLASSKEYS(LuaDialog::Message);
+CLASSKEYS(LuaDialog::Dialog);
+
 #endif // end windows special case
 
 /* Some notes on Lua bindings for libardour and friends
@@ -269,6 +312,11 @@ CLASSKEYS(LuaCairo::PangoLayout);
 
 using namespace ARDOUR;
 
+/** Access libardour global configuration */
+static RCConfiguration* _libardour_config () {
+       return ARDOUR::Config;
+}
+
 void
 LuaBindings::stddef (lua_State* L)
 {
@@ -299,6 +347,10 @@ LuaBindings::stddef (lua_State* L)
                .beginStdVector <float*> ("FloatArrayVector")
                .endClass ()
 
+               // samplepos_t, sampleoffset_t lists e.g. AnalysisFeatureList
+               .beginStdList <int64_t> ("Int64List")
+               .endClass ()
+
        // TODO std::set
                .endNamespace ();
 }
@@ -423,6 +475,20 @@ LuaBindings::common (lua_State* L)
                //.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))
@@ -442,17 +508,17 @@ LuaBindings::common (lua_State* L)
        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)
+               .beginClass <Evoral::Event<samplepos_t> > ("Event")
+               .addFunction ("clear", &Evoral::Event<samplepos_t>::clear)
+               .addFunction ("size", &Evoral::Event<samplepos_t>::size)
+               .addFunction ("set_buffer", &Evoral::Event<samplepos_t>::set_buffer)
+               .addFunction ("buffer", (uint8_t*(Evoral::Event<samplepos_t>::*)())&Evoral::Event<samplepos_t>::buffer)
+               .addFunction ("time", (samplepos_t (Evoral::Event<samplepos_t>::*)())&Evoral::Event<samplepos_t>::time)
                .endClass ()
 
-               .beginClass <Evoral::Beats> ("Beats")
+               .beginClass <Temporal::Beats> ("Beats")
                .addConstructor <void (*) (double)> ()
-               .addFunction ("to_double", &Evoral::Beats::to_double)
+               .addFunction ("to_double", &Temporal::Beats::to_double)
                .endClass ()
 
                .beginClass <Evoral::Parameter> ("Parameter")
@@ -462,6 +528,11 @@ LuaBindings::common (lua_State* L)
                .addFunction ("id", &Evoral::Parameter::id)
                .endClass ()
 
+               .beginClass <Evoral::ControlEvent> ("ControlEvent")
+               .addData ("when", &Evoral::ControlEvent::when)
+               .addData ("value", &Evoral::ControlEvent::value)
+               .endClass ()
+
                .beginWSPtrClass <Evoral::ControlList> ("ControlList")
                .addFunction ("add", &Evoral::ControlList::add)
                .addFunction ("thin", &Evoral::ControlList::thin)
@@ -472,7 +543,9 @@ LuaBindings::common (lua_State* L)
                .addFunction ("truncate_end", &Evoral::ControlList::truncate_end)
                .addFunction ("truncate_start", &Evoral::ControlList::truncate_start)
                .addFunction ("clear", (void (Evoral::ControlList::*)(double, double))&Evoral::ControlList::clear)
+               .addFunction ("clear_list", (void (Evoral::ControlList::*)())&Evoral::ControlList::clear)
                .addFunction ("in_write_pass", &Evoral::ControlList::in_write_pass)
+               .addFunction ("events", &Evoral::ControlList::events)
                .endClass ()
 
                .beginWSPtrClass <Evoral::ControlSet> ("ControlSet")
@@ -488,24 +561,25 @@ LuaBindings::common (lua_State* L)
                .addData ("upper", &Evoral::ParameterDescriptor::upper)
                .addData ("normal", &Evoral::ParameterDescriptor::normal)
                .addData ("toggled", &Evoral::ParameterDescriptor::toggled)
+               .addData ("logarithmic", &Evoral::ParameterDescriptor::logarithmic)
                .endClass ()
 
-               .beginClass <Evoral::Range<framepos_t> > ("Range")
-               .addConstructor <void (*) (framepos_t, framepos_t)> ()
-               .addData ("from", &Evoral::Range<framepos_t>::from)
-               .addData ("to", &Evoral::Range<framepos_t>::to)
+               .beginClass <Evoral::Range<samplepos_t> > ("Range")
+               .addConstructor <void (*) (samplepos_t, samplepos_t)> ()
+               .addData ("from", &Evoral::Range<samplepos_t>::from)
+               .addData ("to", &Evoral::Range<samplepos_t>::to)
                .endClass ()
 
-               .deriveWSPtrClass <Evoral::Sequence<Evoral::Beats>, Evoral::ControlSet> ("Sequence")
+               .deriveWSPtrClass <Evoral::Sequence<Temporal::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)
+               .beginWSPtrClass <Evoral::Note<Temporal::Beats> > ("NotePtr")
+               .addFunction ("time", &Evoral::Note<Temporal::Beats>::time)
+               .addFunction ("note", &Evoral::Note<Temporal::Beats>::note)
+               .addFunction ("velocity", &Evoral::Note<Temporal::Beats>::velocity)
+               .addFunction ("off_velocity", &Evoral::Note<Temporal::Beats>::off_velocity)
+               .addFunction ("length", &Evoral::Note<Temporal::Beats>::length)
+               .addFunction ("channel", &Evoral::Note<Temporal::Beats>::channel)
                .endClass ()
 
                /* libevoral enums */
@@ -645,8 +719,18 @@ LuaBindings::common (lua_State* L)
                .addData ("progress", const_cast<float InterThreadInfo::*>(&InterThreadInfo::progress))
                .endClass ()
 
+               .beginClass <Progress> ("Progress")
+               .endClass ()
+
+               .beginClass <MusicSample> ("MusicSample")
+               .addConstructor <void (*) (samplepos_t, int32_t)> ()
+               .addFunction ("set", &MusicSample::set)
+               .addData ("frame", &MusicSample::sample)
+               .addData ("division", &MusicSample::division)
+               .endClass ()
+
                .beginClass <AudioRange> ("AudioRange")
-               .addConstructor <void (*) (framepos_t, framepos_t, uint32_t)> ()
+               .addConstructor <void (*) (samplepos_t, samplepos_t, uint32_t)> ()
                .addFunction ("length", &AudioRange::length)
                .addFunction ("equal", &AudioRange::equal)
                .addData ("start", &AudioRange::start)
@@ -655,7 +739,7 @@ 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)
@@ -688,7 +772,7 @@ LuaBindings::common (lua_State* L)
                // templated class definitions
                .beginClass <PBD::PropertyDescriptor<bool> > ("BoolProperty").endClass ()
                .beginClass <PBD::PropertyDescriptor<float> > ("FloatProperty").endClass ()
-               .beginClass <PBD::PropertyDescriptor<framepos_t> > ("FrameposProperty").endClass ()
+               .beginClass <PBD::PropertyDescriptor<samplepos_t> > ("FrameposProperty").endClass ()
                // actual references (TODO: also expose GQuark for std::set)
                //   ardour/region.h
                .addConst ("Start", &ARDOUR::Properties::start)
@@ -703,7 +787,7 @@ LuaBindings::common (lua_State* L)
                // expand templated PropertyDescriptor<T>
                .addFunction ("containsBool", &PBD::PropertyChange::contains<bool>)
                .addFunction ("containsFloat", &PBD::PropertyChange::contains<float>)
-               .addFunction ("containsFramePos", &PBD::PropertyChange::contains<framepos_t>)
+               .addFunction ("containsFramePos", &PBD::PropertyChange::contains<samplepos_t>)
                .endClass ()
 
                .beginClass <PBD::PropertyList> ("PropertyList")
@@ -713,10 +797,10 @@ LuaBindings::common (lua_State* L)
                .deriveClass <PBD::OwnedPropertyList, PBD::PropertyList> ("OwnedPropertyList")
                .endClass ()
 
-               .beginWSPtrClass <AutomationList> ("AutomationList")
+               .deriveWSPtrClass <AutomationList, Evoral::ControlList> ("AutomationList")
                .addCast<PBD::Stateful> ("to_stateful")
                .addCast<PBD::StatefulDestructible> ("to_statefuldestructible")
-               .addCast<Evoral::ControlList> ("list")
+               .addCast<Evoral::ControlList> ("list") // deprecated
                .addFunction ("get_state", &AutomationList::get_state)
                .addFunction ("memento_command", &AutomationList::memento_command)
                .addFunction ("touching", &AutomationList::touching)
@@ -760,7 +844,7 @@ LuaBindings::common (lua_State* L)
                .addRefFunction ("find_all_between", &Locations::find_all_between)
                .endClass ()
 
-               .beginWSPtrClass <SessionObject> ("SessionObject")
+               .beginWSPtrClass <SessionObject> ("SessionObjectPtr")
                /* SessionObject is-a PBD::StatefulDestructible,
                 * but multiple inheritance is not covered by luabridge,
                 * we need explicit casts */
@@ -769,6 +853,11 @@ LuaBindings::common (lua_State* L)
                .addFunction ("name", &SessionObject::name)
                .endClass ()
 
+               .beginClass <SessionObject> ("SessionObject")
+               .addFunction ("name", &SessionObject::name)
+               .addCast<PBD::Stateful> ("to_stateful")
+               .endClass ()
+
                .beginWSPtrClass <Port> ("Port")
                .addCast<MidiPort> ("to_midiport")
                .addCast<AudioPort> ("to_audioport")
@@ -817,6 +906,7 @@ LuaBindings::common (lua_State* L)
                .addFunction ("midi", &IO::midi)
                .addFunction ("port_by_name", &IO::nth)
                .addFunction ("n_ports", &IO::n_ports)
+               .addFunction ("latency", &IO::latency)
                .endClass ()
 
                .deriveWSPtrClass <PannerShell, SessionObject> ("PannerShell")
@@ -824,7 +914,7 @@ LuaBindings::common (lua_State* L)
                .addFunction ("set_bypassed", &PannerShell::set_bypassed)
                .endClass ()
 
-               .beginClass <RouteGroup> ("RouteGroup")
+               .deriveClass <RouteGroup, SessionObject> ("RouteGroup")
                .addFunction ("is_active", &RouteGroup::is_active)
                .addFunction ("is_relative", &RouteGroup::is_relative)
                .addFunction ("is_hidden", &RouteGroup::is_hidden)
@@ -853,6 +943,8 @@ LuaBindings::common (lua_State* L)
                .addFunction ("add", &RouteGroup::add)
                .addFunction ("remove", &RouteGroup::remove)
                .addFunction ("clear", &RouteGroup::clear)
+               .addFunction ("set_rgba", &RouteGroup::set_rgba)
+               .addFunction ("rgba", &RouteGroup::rgba)
                .addFunction ("has_subgroup", &RouteGroup::has_subgroup)
                .addFunction ("make_subgroup", &RouteGroup::make_subgroup)
                .addFunction ("destroy_subgroup", &RouteGroup::destroy_subgroup)
@@ -863,12 +955,21 @@ LuaBindings::common (lua_State* L)
                .addFunction ("color", &PresentationInfo::color)
                .addFunction ("set_color", &PresentationInfo::set_color)
                .addFunction ("order", &PresentationInfo::order)
+               .addFunction ("special", &PresentationInfo::special)
+               .addFunction ("flags", &PresentationInfo::flags)
                .addConst ("max_order", ARDOUR::PresentationInfo::max_order)
                .endClass ()
 
+               .beginWSPtrClass <Slavable> ("Slavable")
+               .addFunction ("assign", &Slavable::assign)
+               .addFunction ("unassign", &Slavable::unassign)
+               .endClass ()
+
                .deriveWSPtrClass <Stripable, SessionObject> ("Stripable")
                .addCast<Route> ("to_route")
+               .addCast<VCA> ("to_vca")
                .addFunction ("is_auditioner", &Stripable::is_auditioner)
+               .addFunction ("is_private_route", &Stripable::is_private_route)
                .addFunction ("is_master", &Stripable::is_master)
                .addFunction ("is_monitor", &Stripable::is_monitor)
                .addFunction ("is_hidden", &Stripable::is_hidden)
@@ -901,20 +1002,32 @@ LuaBindings::common (lua_State* L)
                .addFunction ("comp_mode_name", &Stripable::comp_mode_name)
                .addFunction ("comp_speed_name", &Stripable::comp_speed_name)
                .addFunction ("eq_band_cnt ", &Stripable::eq_band_cnt)
+               .addFunction ("eq_enable_control ", &Stripable::eq_enable_controllable )
                .addFunction ("eq_band_name", &Stripable::eq_band_name)
                .addFunction ("eq_gain_control", &Stripable::eq_gain_controllable)
                .addFunction ("eq_freq_control ", &Stripable::eq_freq_controllable )
                .addFunction ("eq_q_control ", &Stripable::eq_q_controllable )
                .addFunction ("eq_shape_control ", &Stripable::eq_shape_controllable )
-               .addFunction ("eq_enable_control ", &Stripable::eq_enable_controllable )
-               .addFunction ("eq_hpf_control ", &Stripable::eq_hpf_controllable )
+               .addFunction ("filter_freq_controllable ", &Stripable::filter_freq_controllable )
+               .addFunction ("filter_slope_controllable ", &Stripable::filter_slope_controllable )
+               .addFunction ("filter_enable_controllable ", &Stripable::filter_enable_controllable )
                .addFunction ("set_presentation_order", &Stripable::set_presentation_order)
                .addFunction ("presentation_info_ptr", &Stripable::presentation_info_ptr)
 
                .endClass ()
 
+               .deriveWSPtrClass <VCA, Stripable> ("VCA")
+               .addFunction ("full_name", &VCA::full_name)
+               .addFunction ("number", &VCA::number)
+               .addFunction ("gain_control", &VCA::gain_control)
+               .addFunction ("solo_control", &VCA::solo_control)
+               .addFunction ("mute_control", &VCA::mute_control)
+               .endClass ()
+
                .deriveWSPtrClass <Route, Stripable> ("Route")
                .addCast<Track> ("to_track")
+               .addCast<Automatable> ("to_automatable")
+               .addCast<Slavable> ("to_slavable")
                .addFunction ("set_name", &Route::set_name)
                .addFunction ("comment", &Route::comment)
                .addFunction ("active", &Route::active)
@@ -924,7 +1037,9 @@ LuaBindings::common (lua_State* L)
                .addFunction ("nth_send", &Route::nth_send)
                .addFunction ("add_processor_by_index", &Route::add_processor_by_index)
                .addFunction ("remove_processor", &Route::remove_processor)
+               .addFunction ("remove_processors", &Route::remove_processors)
                .addFunction ("replace_processor", &Route::replace_processor)
+               .addFunction ("reorder_processors", &Route::reorder_processors)
                .addFunction ("the_instrument", &Route::the_instrument)
                .addFunction ("n_inputs", &Route::n_inputs)
                .addFunction ("n_outputs", &Route::n_outputs)
@@ -945,6 +1060,8 @@ LuaBindings::common (lua_State* L)
                .addFunction ("trim", &Route::trim)
                .addFunction ("peak_meter", (boost::shared_ptr<PeakMeter> (Route::*)())&Route::peak_meter)
                .addFunction ("set_meter_point", &Route::set_meter_point)
+               .addFunction ("initial_delay", &Route::initial_delay)
+               .addFunction ("signal_latency", &Route::signal_latency)
                .endClass ()
 
                .deriveWSPtrClass <Playlist, SessionObject> ("Playlist")
@@ -953,13 +1070,14 @@ LuaBindings::common (lua_State* L)
                .addFunction ("region_by_id", &Playlist::region_by_id)
                .addFunction ("data_type", &Playlist::data_type)
                .addFunction ("n_regions", &Playlist::n_regions)
-               //.addFunction ("get_extent", &Playlist::get_extent) // pair<framepos_t, framepos_t>
+               //.addFunction ("get_extent", &Playlist::get_extent) // pair<samplepos_t, samplepos_t>
                .addFunction ("region_list", &Playlist::region_list)
                .addFunction ("add_region", &Playlist::add_region)
                .addFunction ("remove_region", &Playlist::remove_region)
                .addFunction ("regions_at", &Playlist::regions_at)
                .addFunction ("top_region_at", &Playlist::top_region_at)
                .addFunction ("top_unmuted_region_at", &Playlist::top_unmuted_region_at)
+               .addFunction ("find_next_transient", &Playlist::find_next_transient)
                .addFunction ("find_next_region", &Playlist::find_next_region)
                .addFunction ("find_next_region_boundary", &Playlist::find_next_region_boundary)
                .addFunction ("count_regions_at", &Playlist::count_regions_at)
@@ -970,13 +1088,13 @@ LuaBindings::common (lua_State* L)
                .addFunction ("lower_region", &Playlist::lower_region)
                .addFunction ("raise_region_to_top", &Playlist::raise_region_to_top)
                .addFunction ("lower_region_to_bottom", &Playlist::lower_region_to_bottom)
-               .addFunction ("duplicate", (void (Playlist::*)(boost::shared_ptr<Region>, framepos_t, framecnt_t, float))&Playlist::duplicate)
+               .addFunction ("duplicate", (void (Playlist::*)(boost::shared_ptr<Region>, samplepos_t, samplecnt_t, float))&Playlist::duplicate)
                .addFunction ("duplicate_until", &Playlist::duplicate_until)
                .addFunction ("duplicate_range", &Playlist::duplicate_range)
                .addFunction ("combine", &Playlist::combine)
                .addFunction ("uncombine", &Playlist::uncombine)
                .addFunction ("split_region", &Playlist::split_region)
-               .addFunction ("split", (void (Playlist::*)(framepos_t))&Playlist::split)
+               .addFunction ("split", (void (Playlist::*)(samplepos_t))&Playlist::split)
                .addFunction ("cut", (boost::shared_ptr<Playlist> (Playlist::*)(std::list<AudioRange>&, bool))&Playlist::cut)
 #if 0
                .addFunction ("copy", &Playlist::copy)
@@ -1045,6 +1163,10 @@ LuaBindings::common (lua_State* L)
                .addFunction ("covers", &Region::covers)
                .addFunction ("at_natural_position", &Region::at_natural_position)
                .addFunction ("is_compound", &Region::is_compound)
+
+               .addFunction ("has_transients", &Region::has_transients)
+               .addFunction ("transients", (AnalysisFeatureList (Region::*)())&Region::transients)
+
                /* editing operations */
                .addFunction ("set_length", &Region::set_length)
                .addFunction ("set_start", &Region::set_start)
@@ -1075,12 +1197,13 @@ LuaBindings::common (lua_State* L)
                .addFunction ("set_video_locked", &Region::set_video_locked)
                .addFunction ("set_position_locked", &Region::set_position_locked)
                .addFunction ("source", &Region::source)
+               .addFunction ("control", static_cast<boost::shared_ptr<Evoral::Control>(Region::*)(const Evoral::Parameter&, bool)>(&Region::control))
                .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 ("model", (boost::shared_ptr<MidiModel> (MidiRegion::*)())&MidiRegion::model)
                .addFunction ("start_beats", &MidiRegion::start_beats)
                .addFunction ("length_beats", &MidiRegion::length_beats)
                .endClass ()
@@ -1089,11 +1212,15 @@ LuaBindings::common (lua_State* L)
                .addFunction ("audio_source", &AudioRegion::audio_source)
                .addFunction ("set_scale_amplitude", &AudioRegion::set_scale_amplitude)
                .addFunction ("scale_amplitude", &AudioRegion::scale_amplitude)
+               .addFunction ("maximum_amplitude", &AudioRegion::maximum_amplitude)
+               .addFunction ("rms", &AudioRegion::rms)
+               .addRefFunction ("separate_by_channel", &AudioRegion::separate_by_channel)
                .endClass ()
 
                .deriveWSPtrClass <Source, SessionObject> ("Source")
                .addCast<AudioSource> ("to_audiosource")
                .addCast<MidiSource> ("to_midisource")
+               .addCast<FileSource> ("to_filesource")
                .addFunction ("timestamp", &Source::timestamp)
                .addFunction ("empty", &Source::empty)
                .addFunction ("length", &Source::length)
@@ -1108,6 +1235,15 @@ LuaBindings::common (lua_State* L)
                .addFunction ("ancestor_name", &Source::ancestor_name)
                .endClass ()
 
+               .deriveWSPtrClass <FileSource, Source> ("FileSource")
+               .addFunction ("path", &FileSource::path)
+               .addFunction ("within_session", &FileSource::within_session)
+               .addFunction ("channel", &FileSource::channel)
+               .addFunction ("origin", &FileSource::origin)
+               .addFunction ("take_id", &FileSource::take_id)
+               .addFunction ("gain", &FileSource::gain)
+               .endClass ()
+
                .deriveWSPtrClass <MidiSource, Source> ("MidiSource")
                .addFunction ("empty", &MidiSource::empty)
                .addFunction ("length", &MidiSource::length)
@@ -1126,14 +1262,16 @@ LuaBindings::common (lua_State* L)
                .endClass ()
 
                .deriveWSPtrClass <Automatable, Evoral::ControlSet> ("Automatable")
+               .addCast<Slavable> ("to_slavable")
                .addFunction ("automation_control", (boost::shared_ptr<AutomationControl>(Automatable::*)(const Evoral::Parameter&, bool))&Automatable::automation_control)
+               //.addFunction ("what_can_be_automated", &Automatable::what_can_be_automated)
                .endClass ()
 
-               .deriveWSPtrClass <AutomatableSequence<Evoral::Beats>, Automatable> ("AutomatableSequence")
-               .addCast<Evoral::Sequence<Evoral::Beats> > ("to_sequence")
+               .deriveWSPtrClass <AutomatableSequence<Temporal::Beats>, Automatable> ("AutomatableSequence")
+               .addCast<Evoral::Sequence<Temporal::Beats> > ("to_sequence")
                .endClass ()
 
-               .deriveWSPtrClass <MidiModel, AutomatableSequence<Evoral::Beats> > ("MidiModel")
+               .deriveWSPtrClass <MidiModel, AutomatableSequence<Temporal::Beats> > ("MidiModel")
                .addFunction ("apply_command", (void (MidiModel::*)(Session*, Command*))&MidiModel::apply_command)
                .addFunction ("new_note_diff_command", &MidiModel::new_note_diff_command)
                .endClass ()
@@ -1162,7 +1300,6 @@ LuaBindings::common (lua_State* L)
                .deriveClass <ParameterDescriptor, Evoral::ParameterDescriptor> ("ParameterDescriptor")
                .addVoidConstructor ()
                .addData ("label", &ParameterDescriptor::label)
-               .addData ("logarithmic", &ParameterDescriptor::logarithmic)
                .addStaticFunction ("midi_note_name", &ParameterDescriptor::midi_note_name)
                .endClass ()
 
@@ -1170,7 +1307,8 @@ LuaBindings::common (lua_State* L)
 
                .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")
@@ -1183,6 +1321,7 @@ LuaBindings::common (lua_State* L)
 #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)
@@ -1220,11 +1359,15 @@ LuaBindings::common (lua_State* L)
                .addFunction ("name", &Plugin::name)
                .addFunction ("maker", &Plugin::maker)
                .addFunction ("parameter_count", &Plugin::parameter_count)
+               .addFunction ("parameter_label", &Plugin::parameter_label)
                .addRefFunction ("nth_parameter", &Plugin::nth_parameter)
                .addFunction ("preset_by_label", &Plugin::preset_by_label)
                .addFunction ("preset_by_uri", &Plugin::preset_by_uri)
                .addFunction ("load_preset", &Plugin::load_preset)
                .addFunction ("parameter_is_input", &Plugin::parameter_is_input)
+               .addFunction ("parameter_is_output", &Plugin::parameter_is_output)
+               .addFunction ("parameter_is_control", &Plugin::parameter_is_control)
+               .addFunction ("parameter_is_audio", &Plugin::parameter_is_audio)
                .addFunction ("get_docs", &Plugin::get_docs)
                .addFunction ("get_info", &Plugin::get_info)
                .addFunction ("get_parameter_docs", &Plugin::get_parameter_docs)
@@ -1248,14 +1391,20 @@ LuaBindings::common (lua_State* L)
                .addFunction ("set_output_map", &PluginInsert::set_output_map)
                .addFunction ("natural_output_streams", &PluginInsert::natural_output_streams)
                .addFunction ("natural_input_streams", &PluginInsert::natural_input_streams)
+               .addFunction ("reset_parameters_to_default", &PluginInsert::reset_parameters_to_default)
+               .endClass ()
+
+               .deriveWSPtrClass <ReadOnlyControl, PBD::StatefulDestructible> ("ReadOnlyControl")
+               .addFunction ("get_parameter", &ReadOnlyControl::get_parameter)
+               .addFunction ("describe_parameter", &ReadOnlyControl::describe_parameter)
+               .addFunction ("desc", &ReadOnlyControl::desc)
                .endClass ()
 
                .deriveWSPtrClass <AutomationControl, PBD::Controllable> ("AutomationControl")
                .addCast<Evoral::Control> ("to_ctrl")
+               .addCast<SlavableAutomationControl> ("to_slavable")
                .addFunction ("automation_state", &AutomationControl::automation_state)
-               .addFunction ("automation_style", &AutomationControl::automation_style)
                .addFunction ("set_automation_state", &AutomationControl::set_automation_state)
-               .addFunction ("set_automation_style", &AutomationControl::set_automation_style)
                .addFunction ("start_touch", &AutomationControl::start_touch)
                .addFunction ("stop_touch", &AutomationControl::stop_touch)
                .addFunction ("get_value", &AutomationControl::get_value)
@@ -1264,7 +1413,7 @@ LuaBindings::common (lua_State* L)
                .addFunction ("alist", &AutomationControl::alist)
                .endClass ()
 
-               .deriveWSPtrClass <SlavableAutomationControl, AutomationControl> ("SlavableAutomationControl,")
+               .deriveWSPtrClass <SlavableAutomationControl, AutomationControl> ("SlavableAutomationControl")
                .addFunction ("add_master", &SlavableAutomationControl::add_master)
                .addFunction ("remove_master", &SlavableAutomationControl::remove_master)
                .addFunction ("clear_masters", &SlavableAutomationControl::clear_masters)
@@ -1365,16 +1514,25 @@ LuaBindings::common (lua_State* L)
                .beginConstStdList <boost::shared_ptr<Route> > ("RouteList")
                .endClass ()
 
+               // StripableList == std::list<boost::shared_ptr<Stripable> >
+               .beginConstStdList <boost::shared_ptr<Stripable> > ("StripableList")
+               .endClass ()
+
+               // VCAList == std::list<boost::shared_ptr<VCA> >
+               .beginConstStdList <boost::shared_ptr<VCA> > ("VCAList")
+               .endClass ()
+
                // 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")
+               // RouteGroupList == std::list<RouteGroup*>
+               .beginConstStdCPtrList <RouteGroup> ("RouteGroupList")
                .endClass ()
 
                // typedef std::vector<boost::shared_ptr<Source> > Region::SourceList
@@ -1385,12 +1543,25 @@ LuaBindings::common (lua_State* L)
                .beginConstStdList <boost::weak_ptr<AudioSource> > ("WeakAudioSourceList")
                .endClass ()
 
+               // typedef std::vector<boost::shared_ptr<Region> > RegionVector
+               .beginStdVector <boost::shared_ptr<Region> > ("RegionVector")
+               .endClass ()
+
                // typedef std::list<boost::shared_ptr<Region> > RegionList
                .beginConstStdList <boost::shared_ptr<Region> > ("RegionList")
                .endClass ()
 
                // boost::shared_ptr <std::list<boost::shared_ptr<Region> > >
                .beginPtrStdList <boost::shared_ptr<Region> > ("RegionListPtr")
+               .addVoidPtrConstructor<std::list<boost::shared_ptr <Region> > > ()
+               .endClass ()
+
+               // RegionFactory::RegionMap
+               .beginStdMap <PBD::ID,boost::shared_ptr<Region> > ("RegionMap")
+               .endClass ()
+
+               // typedef std::list<boost::shared_ptr<Processor> > ProcessorList;
+               .beginStdList <boost::shared_ptr<Processor> > ("ProcessorList")
                .endClass ()
 
                //std::list<boost::shared_ptr<Port> > PortList;
@@ -1404,8 +1575,22 @@ 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 ()
+
+               .beginStdList <boost::shared_ptr<Evoral::Note<Temporal::Beats> > > ("NotePtrList")
+               .endClass ()
+
+               .beginConstStdList <Evoral::ControlEvent*> ("EventList")
+               .endClass ()
+
 #if 0  // depends on Evoal:: Note, Beats see note_fixer.h
-       // typedef Evoral::Note<Evoral::Beats> Note;
+       // typedef Evoral::Note<Temporal::Beats> Note;
        // std::set< boost::weak_ptr<Note> >
                .beginStdSet <boost::weak_ptr<Note> > ("WeakNoteSet")
                .endClass ()
@@ -1416,31 +1601,46 @@ LuaBindings::common (lua_State* L)
                .endClass ()
 
                .beginClass <Tempo> ("Tempo")
-               .addConstructor <void (*) (double, double)> ()
+               .addConstructor <void (*) (double, double, double)> ()
                .addFunction ("note_type", &Tempo::note_type)
                .addFunction ("note_types_per_minute",  (double (Tempo::*)() const)&Tempo::note_types_per_minute)
                .addFunction ("quarter_notes_per_minute", &Tempo::quarter_notes_per_minute)
-               .addFunction ("frames_per_quarter_note", &Tempo::frames_per_quarter_note)
-               .addFunction ("frames_per_note_type", &Tempo::frames_per_note_type)
+               .addFunction ("samples_per_quarter_note", &Tempo::samples_per_quarter_note)
+               .addFunction ("samples_per_note_type", &Tempo::samples_per_note_type)
                .endClass ()
 
                .beginClass <Meter> ("Meter")
                .addConstructor <void (*) (double, double)> ()
                .addFunction ("divisions_per_bar", &Meter::divisions_per_bar)
                .addFunction ("note_divisor", &Meter::note_divisor)
-               .addFunction ("frames_per_bar", &Meter::frames_per_bar)
-               .addFunction ("frames_per_grid", &Meter::frames_per_grid)
+               .addFunction ("samples_per_bar", &Meter::samples_per_bar)
+               .addFunction ("samples_per_grid", &Meter::samples_per_grid)
+               .endClass ()
+
+               .beginClass <BeatsSamplesConverter> ("BeatsSamplesConverter")
+               .addConstructor <void (*) (const TempoMap&, samplepos_t)> ()
+               .addFunction ("to", &BeatsSamplesConverter::to)
+               .addFunction ("from", &BeatsSamplesConverter::from)
+               .endClass ()
+
+               .beginClass <DoubleBeatsSamplesConverter> ("DoubleBeatsSamplesConverter")
+               .addConstructor <void (*) (const TempoMap&, samplepos_t)> ()
+               .addFunction ("to", &DoubleBeatsSamplesConverter::to)
+               .addFunction ("from", &DoubleBeatsSamplesConverter::from)
                .endClass ()
 
                .beginClass <TempoMap> ("TempoMap")
                .addFunction ("add_tempo", &TempoMap::add_tempo)
                .addFunction ("add_meter", &TempoMap::add_meter)
-               .addFunction ("tempo_section_at_frame", &TempoMap::tempo_section_at_frame)
-               .addFunction ("meter_section_at_frame", &TempoMap::meter_section_at_frame)
+               .addFunction ("tempo_section_at_frame", (TempoSection& (TempoMap::*)(samplepos_t))&TempoMap::tempo_section_at_sample)
+               .addFunction ("tempo_section_at_frame", (const TempoSection& (TempoMap::*)(samplepos_t) const)&TempoMap::tempo_section_at_sample)
+               .addFunction ("meter_section_at_frame", &TempoMap::meter_section_at_sample)
                .addFunction ("meter_section_at_beat", &TempoMap::meter_section_at_beat)
-               .addFunction ("bbt_at_frame", &TempoMap::bbt_at_frame)
-               .addFunction ("exact_beat_at_frame", &TempoMap::exact_beat_at_frame)
-               .addFunction ("exact_qn_at_frame", &TempoMap::exact_qn_at_frame)
+               .addFunction ("bbt_at_frame", &TempoMap::bbt_at_sample)
+               .addFunction ("exact_beat_at_frame", &TempoMap::exact_beat_at_sample)
+               .addFunction ("exact_qn_at_frame", &TempoMap::exact_qn_at_sample)
+               .addFunction ("samplepos_plus_qn", &TempoMap::samplepos_plus_qn)
+               .addFunction ("framewalk_to_qn", &TempoMap::framewalk_to_qn)
                .endClass ()
 
                .beginClass <MetricSection> ("MetricSection")
@@ -1449,7 +1649,7 @@ LuaBindings::common (lua_State* L)
                .endClass ()
 
                .deriveClass <TempoSection, MetricSection> ("TempoSection")
-               .addFunction ("c_func", (double(TempoSection::*)()const)&TempoSection::c_func)
+               .addFunction ("c", (double(TempoSection::*)()const)&TempoSection::c)
                .endClass ()
 
                .deriveClass <MeterSection, MetricSection> ("MeterSection")
@@ -1497,23 +1697,18 @@ LuaBindings::common (lua_State* L)
                .addConst ("MasterOut", ARDOUR::PresentationInfo::Flag(PresentationInfo::MasterOut))
                .addConst ("MonitorOut", ARDOUR::PresentationInfo::Flag(PresentationInfo::MonitorOut))
                .addConst ("Auditioner", ARDOUR::PresentationInfo::Flag(PresentationInfo::Auditioner))
-               .addConst ("Selected", ARDOUR::PresentationInfo::Flag(PresentationInfo::Selected))
                .addConst ("Hidden", ARDOUR::PresentationInfo::Flag(PresentationInfo::Hidden))
                .addConst ("GroupOrderSet", ARDOUR::PresentationInfo::Flag(PresentationInfo::OrderSet))
                .addConst ("StatusMask", ARDOUR::PresentationInfo::Flag(PresentationInfo::StatusMask))
                .endNamespace ()
                .endNamespace ()
 
-               .beginNamespace ("AutoStyle")
-               .addConst ("Absolute", ARDOUR::AutoStyle(Absolute))
-               .addConst ("Trim", ARDOUR::AutoStyle(Trim))
-               .endNamespace ()
-
                .beginNamespace ("AutoState")
                .addConst ("Off", ARDOUR::AutoState(Off))
                .addConst ("Write", ARDOUR::AutoState(Write))
                .addConst ("Touch", ARDOUR::AutoState(Touch))
                .addConst ("Play", ARDOUR::AutoState(Play))
+               .addConst ("Latch", ARDOUR::AutoState(Latch))
                .endNamespace ()
 
                .beginNamespace ("AutomationType")
@@ -1527,6 +1722,12 @@ LuaBindings::common (lua_State* L)
                .addConst ("RecSafeAutomation", ARDOUR::AutomationType(RecSafeAutomation))
                .addConst ("TrimAutomation", ARDOUR::AutomationType(TrimAutomation))
                .addConst ("PhaseAutomation", ARDOUR::AutomationType(PhaseAutomation))
+               .addConst ("MidiCCAutomation", ARDOUR::AutomationType(MidiCCAutomation))
+               .addConst ("MidiPgmChangeAutomation", ARDOUR::AutomationType(MidiPgmChangeAutomation))
+               .addConst ("MidiPitchBenderAutomation", ARDOUR::AutomationType(MidiPitchBenderAutomation))
+               .addConst ("MidiChannelPressureAutomation", ARDOUR::AutomationType(MidiChannelPressureAutomation))
+               .addConst ("MidiNotePressureAutomation", ARDOUR::AutomationType(MidiNotePressureAutomation))
+               .addConst ("MidiSystemExclusiveAutomation", ARDOUR::AutomationType(MidiSystemExclusiveAutomation))
                .endNamespace ()
 
                .beginNamespace ("SrcQuality")
@@ -1563,6 +1764,13 @@ LuaBindings::common (lua_State* L)
                .addConst ("PostFader", ARDOUR::Placement(PostFader))
                .endNamespace ()
 
+               .beginNamespace ("MonitorChoice")
+               .addConst ("MonitorAuto", ARDOUR::MonitorChoice(MonitorAuto))
+               .addConst ("MonitorInput", ARDOUR::MonitorChoice(MonitorInput))
+               .addConst ("MonitorDisk", ARDOUR::MonitorChoice(MonitorDisk))
+               .addConst ("MonitorCue", ARDOUR::MonitorChoice(MonitorCue))
+               .endNamespace ()
+
                .beginNamespace ("NoteMode")
                .addConst ("Sustained", ARDOUR::NoteMode(Sustained))
                .addConst ("Percussive", ARDOUR::NoteMode(Percussive))
@@ -1576,12 +1784,30 @@ LuaBindings::common (lua_State* L)
                .addConst ("IsTerminal", ARDOUR::PortFlags(IsTerminal))
                .endNamespace ()
 
+               .beginNamespace ("MidiPortFlags")
+               .addConst ("MidiPortMusic", ARDOUR::MidiPortFlags(MidiPortMusic))
+               .addConst ("MidiPortControl", ARDOUR::MidiPortFlags(MidiPortControl))
+               .addConst ("MidiPortSelection", ARDOUR::MidiPortFlags(MidiPortSelection))
+               .addConst ("MidiPortVirtual", ARDOUR::MidiPortFlags(MidiPortVirtual))
+               .endNamespace ()
+
                .beginNamespace ("PlaylistDisposition")
                .addConst ("CopyPlaylist", ARDOUR::PlaylistDisposition(CopyPlaylist))
                .addConst ("NewPlaylist", ARDOUR::PlaylistDisposition(NewPlaylist))
                .addConst ("SharePlaylist", ARDOUR::PlaylistDisposition(SharePlaylist))
                .endNamespace ()
 
+               .beginNamespace ("MidiTrackNameSource")
+               .addConst ("SMFTrackNumber", ARDOUR::MidiTrackNameSource(SMFTrackNumber))
+               .addConst ("SMFTrackName", ARDOUR::MidiTrackNameSource(SMFTrackName))
+               .addConst ("SMFInstrumentName", ARDOUR::MidiTrackNameSource(SMFInstrumentName))
+               .endNamespace ()
+
+               .beginNamespace ("MidiTempoMapDisposition")
+               .addConst ("SMFTempoIgnore", ARDOUR::MidiTempoMapDisposition(SMFTempoIgnore))
+               .addConst ("SMFTempoUse", ARDOUR::MidiTempoMapDisposition(SMFTempoUse))
+               .endNamespace ()
+
                .beginNamespace ("RegionPoint")
                .addConst ("Start", ARDOUR::RegionPoint(Start))
                .addConst ("End", ARDOUR::RegionPoint(End))
@@ -1635,6 +1861,107 @@ LuaBindings::common (lua_State* L)
                .addConst ("Extend", ARDOUR::InsertMergePolicy(InsertMergeExtend))
                .endNamespace ()
 
+               .beginNamespace ("AFLPosition")
+               .addConst ("AFLFromBeforeProcessors", ARDOUR::AFLPosition(AFLFromBeforeProcessors))
+               .addConst ("AFLFromAfterProcessors", ARDOUR::AFLPosition(AFLFromAfterProcessors))
+               .endNamespace ()
+
+               .beginNamespace ("PFLPosition")
+               .addConst ("PFLFromBeforeProcessors", ARDOUR::PFLPosition(PFLFromBeforeProcessors))
+               .addConst ("PFLFromAfterProcessors", ARDOUR::PFLPosition(PFLFromAfterProcessors))
+               .endNamespace ()
+
+               .beginNamespace ("AutoReturnTarget")
+               .addConst ("LastLocate", ARDOUR::AutoReturnTarget(LastLocate))
+               .addConst ("RangeSelectionStart", ARDOUR::AutoReturnTarget(RangeSelectionStart))
+               .addConst ("Loop", ARDOUR::AutoReturnTarget(Loop))
+               .addConst ("RegionSelectionStart", ARDOUR::AutoReturnTarget(RegionSelectionStart))
+               .endNamespace ()
+
+               .beginNamespace ("FadeShape")
+               .addConst ("FadeLinear", ARDOUR::FadeShape(FadeLinear))
+               .addConst ("FadeFast", ARDOUR::FadeShape(FadeFast))
+               .addConst ("FadeSlow", ARDOUR::FadeShape(FadeSlow))
+               .addConst ("FadeConstantPower", ARDOUR::FadeShape(FadeConstantPower))
+               .addConst ("FadeSymmetric", ARDOUR::FadeShape(FadeSymmetric))
+               .endNamespace ()
+
+               .beginNamespace ("DenormalModel")
+               .addConst ("DenormalNone", ARDOUR::DenormalModel(DenormalNone))
+               .addConst ("DenormalFTZ", ARDOUR::DenormalModel(DenormalFTZ))
+               .addConst ("DenormalDAZ", ARDOUR::DenormalModel(DenormalDAZ))
+               .addConst ("DenormalFTZDAZ", ARDOUR::DenormalModel(DenormalFTZDAZ))
+               .endNamespace ()
+
+               .beginNamespace ("BufferingPreset")
+               .addConst ("Small", ARDOUR::BufferingPreset(Small))
+               .addConst ("Medium", ARDOUR::BufferingPreset(Medium))
+               .addConst ("Large", ARDOUR::BufferingPreset(Large))
+               .addConst ("Custom", ARDOUR::BufferingPreset(Custom))
+               .endNamespace ()
+
+               .beginNamespace ("EditMode")
+               .addConst ("Slide", ARDOUR::EditMode(Slide))
+               .addConst ("Splice", ARDOUR::EditMode(Splice))
+               .addConst ("Ripple", ARDOUR::EditMode(Ripple))
+               .addConst ("Lock", ARDOUR::EditMode(Lock))
+               .endNamespace ()
+
+               .beginNamespace ("AutoConnectOption")
+               .addConst ("ManualConnect", ARDOUR::AutoConnectOption(ManualConnect))
+               .addConst ("AutoConnectPhysical", ARDOUR::AutoConnectOption(AutoConnectPhysical))
+               .addConst ("AutoConnectMaster", ARDOUR::AutoConnectOption(AutoConnectMaster))
+               .endNamespace ()
+
+               .beginNamespace ("LayerModel")
+               .addConst ("LaterHigher", ARDOUR::LayerModel(LaterHigher))
+               .addConst ("Manual", ARDOUR::LayerModel(Manual))
+               .endNamespace ()
+
+               .beginNamespace ("ListenPosition")
+               .addConst ("AfterFaderListen", ARDOUR::ListenPosition(AfterFaderListen))
+               .addConst ("PreFaderListen", ARDOUR::ListenPosition(PreFaderListen))
+               .endNamespace ()
+
+               .beginNamespace ("MonitorModel")
+               .addConst ("HardwareMonitoring", ARDOUR::MonitorModel(HardwareMonitoring))
+               .addConst ("SoftwareMonitoring", ARDOUR::MonitorModel(SoftwareMonitoring))
+               .addConst ("ExternalMonitoring", ARDOUR::MonitorModel(ExternalMonitoring))
+               .endNamespace ()
+
+               .beginNamespace ("RegionSelectionAfterSplit")
+               .addConst ("None", ARDOUR::RegionSelectionAfterSplit(None))
+               .addConst ("NewlyCreatedLeft", ARDOUR::RegionSelectionAfterSplit(NewlyCreatedLeft))
+               .addConst ("NewlyCreatedRight", ARDOUR::RegionSelectionAfterSplit(NewlyCreatedRight))
+               .addConst ("NewlyCreatedBoth", ARDOUR::RegionSelectionAfterSplit(NewlyCreatedBoth))
+               .addConst ("Existing", ARDOUR::RegionSelectionAfterSplit(Existing))
+               .addConst ("ExistingNewlyCreatedLeft", ARDOUR::RegionSelectionAfterSplit(ExistingNewlyCreatedLeft))
+               .addConst ("ExistingNewlyCreatedRight", ARDOUR::RegionSelectionAfterSplit(ExistingNewlyCreatedRight))
+               .addConst ("ExistingNewlyCreatedBoth", ARDOUR::RegionSelectionAfterSplit(ExistingNewlyCreatedBoth))
+               .endNamespace ()
+
+               .beginNamespace ("ShuttleBehaviour")
+               .addConst ("Sprung", ARDOUR::ShuttleBehaviour(Sprung))
+               .addConst ("Wheel", ARDOUR::ShuttleBehaviour(Wheel))
+               .endNamespace ()
+
+               .beginNamespace ("ShuttleUnits")
+               .addConst ("Percentage", ARDOUR::ShuttleUnits(Percentage))
+               .addConst ("Semitones", ARDOUR::ShuttleUnits(Semitones))
+               .endNamespace ()
+
+               .beginNamespace ("SyncSource")
+               .addConst ("Engine", ARDOUR::SyncSource(Engine))
+               .addConst ("MTC", ARDOUR::SyncSource(MTC))
+               .addConst ("MIDIClock", ARDOUR::SyncSource(MIDIClock))
+               .addConst ("LTC", ARDOUR::SyncSource(LTC))
+               .endNamespace ()
+
+               .beginNamespace ("TracksAutoNamingRule")
+               .addConst ("UseDefaultNames", ARDOUR::TracksAutoNamingRule(UseDefaultNames))
+               .addConst ("NameAfterDriver", ARDOUR::TracksAutoNamingRule(NameAfterDriver))
+               .endNamespace ()
+
                .endNamespace (); // end ARDOUR
 
        luabridge::getGlobalNamespace (L)
@@ -1642,7 +1969,7 @@ LuaBindings::common (lua_State* L)
                .beginClass <AudioBackendInfo> ("AudioBackendInfo")
                .addData ("name", &AudioBackendInfo::name)
                .endClass()
-               .beginStdVector <const AudioBackendInfo*> ("BackendVector").endClass ()
+               .beginConstStdVector <const AudioBackendInfo*> ("BackendVector").endClass ()
 
                .beginClass <AudioBackend::DeviceStatus> ("DeviceStatus")
                .addData ("name", &AudioBackend::DeviceStatus::name)
@@ -1715,6 +2042,34 @@ LuaBindings::common (lua_State* L)
                .addFunction ("get_last_backend_error", &AudioEngine::get_last_backend_error)
                .endClass()
 
+               .deriveClass <VCAManager, PBD::StatefulDestructible> ("VCAManager")
+               .addFunction ("create_vca", &VCAManager::create_vca)
+               .addFunction ("remove_vca", &VCAManager::remove_vca)
+               .addFunction ("vca_by_number", &VCAManager::vca_by_number)
+               .addFunction ("vca_by_name", &VCAManager::vca_by_name)
+               .addFunction ("vcas", &VCAManager::vcas)
+               .addFunction ("n_vcas", &VCAManager::n_vcas)
+               .endClass()
+
+               .deriveClass <RCConfiguration, PBD::Configuration> ("RCConfiguration")
+#undef  CONFIG_VARIABLE
+#undef  CONFIG_VARIABLE_SPECIAL
+#define CONFIG_VARIABLE(Type,var,name,value) \
+               .addFunction ("get_" # var, &RCConfiguration::get_##var) \
+               .addFunction ("set_" # var, &RCConfiguration::set_##var) \
+               .addProperty (#var, &RCConfiguration::get_##var, &RCConfiguration::set_##var)
+
+#define CONFIG_VARIABLE_SPECIAL(Type,var,name,value,mutator) \
+               .addFunction ("get_" # var, &RCConfiguration::get_##var) \
+               .addFunction ("set_" # var, &RCConfiguration::set_##var) \
+               .addProperty (#var, &RCConfiguration::get_##var, &RCConfiguration::set_##var)
+
+#include "ardour/rc_configuration_vars.h"
+
+#undef CONFIG_VARIABLE
+#undef CONFIG_VARIABLE_SPECIAL
+               .endClass()
+
                .deriveClass <SessionConfiguration, PBD::Configuration> ("SessionConfiguration")
 #undef  CONFIG_VARIABLE
 #undef  CONFIG_VARIABLE_SPECIAL
@@ -1733,6 +2088,10 @@ LuaBindings::common (lua_State* L)
 #undef CONFIG_VARIABLE
 #undef CONFIG_VARIABLE_SPECIAL
                .endClass()
+
+               // we could use addProperty ()
+               .addFunction ("config", &_libardour_config)
+
                .endNamespace ();
 
        // basic representation of Session
@@ -1743,11 +2102,11 @@ LuaBindings::common (lua_State* L)
                .addFunction ("scripts_changed", &Session::scripts_changed) // used internally
                .addFunction ("transport_rolling", &Session::transport_rolling)
                .addFunction ("request_transport_speed", &Session::request_transport_speed)
-               .addFunction ("transport_frame", &Session::transport_frame)
+               .addFunction ("transport_frame", &Session::transport_sample)
                .addFunction ("transport_speed", &Session::transport_speed)
-               .addFunction ("frame_rate", &Session::frame_rate)
-               .addFunction ("nominal_frame_rate", &Session::nominal_frame_rate)
-               .addFunction ("frames_per_timecode_frame", &Session::frames_per_timecode_frame)
+               .addFunction ("sample_rate", &Session::sample_rate)
+               .addFunction ("nominal_sample_rate", &Session::nominal_sample_rate)
+               .addFunction ("samples_per_timecode_frame", &Session::samples_per_timecode_frame)
                .addFunction ("timecode_frames_per_hour", &Session::timecode_frames_per_hour)
                .addFunction ("timecode_frames_per_second", &Session::timecode_frames_per_second)
                .addFunction ("timecode_drop_frames", &Session::timecode_drop_frames)
@@ -1758,15 +2117,21 @@ LuaBindings::common (lua_State* L)
                .addFunction ("last_transport_start", &Session::last_transport_start)
                .addFunction ("goto_start", &Session::goto_start)
                .addFunction ("goto_end", &Session::goto_end)
-               .addFunction ("current_start_frame", &Session::current_start_frame)
-               .addFunction ("current_end_frame", &Session::current_end_frame)
+               .addFunction ("current_start_frame", &Session::current_start_sample)
+               .addFunction ("current_end_frame", &Session::current_end_sample)
                .addFunction ("actively_recording", &Session::actively_recording)
                .addFunction ("new_audio_track", &Session::new_audio_track)
                .addFunction ("new_audio_route", &Session::new_audio_route)
                .addFunction ("new_midi_track", &Session::new_midi_track)
                .addFunction ("new_midi_route", &Session::new_midi_route)
+
+               .addFunction ("add_master_bus", &Session::add_master_bus)
+               .addFunction ("add_monitor_section", &Session::add_monitor_section)
+               .addFunction ("remove_monitor_section", &Session::remove_monitor_section)
+
                .addFunction ("get_routes", &Session::get_routes)
                .addFunction ("get_tracks", &Session::get_tracks)
+               .addFunction ("get_stripables", (StripableList (Session::*)() const)&Session::get_stripables)
                .addFunction ("name", &Session::name)
                .addFunction ("path", &Session::path)
                .addFunction ("record_status", &Session::record_status)
@@ -1777,15 +2142,23 @@ LuaBindings::common (lua_State* L)
                .addFunction ("get_remote_nth_stripable", &Session::get_remote_nth_stripable)
                .addFunction ("get_remote_nth_route", &Session::get_remote_nth_route)
                .addFunction ("route_by_selected_count", &Session::route_by_selected_count)
-               .addFunction ("track_by_diskstream_id", &Session::track_by_diskstream_id)
                .addFunction ("source_by_id", &Session::source_by_id)
                .addFunction ("controllable_by_id", &Session::controllable_by_id)
                .addFunction ("processor_by_id", &Session::processor_by_id)
                .addFunction ("snap_name", &Session::snap_name)
                .addFunction ("monitor_out", &Session::monitor_out)
                .addFunction ("master_out", &Session::master_out)
+               .addFunction ("add_internal_sends", &Session::add_internal_sends)
                .addFunction ("tempo_map", (TempoMap& (Session::*)())&Session::tempo_map)
                .addFunction ("locations", &Session::locations)
+               .addFunction ("soloing", &Session::soloing)
+               .addFunction ("listening", &Session::listening)
+               .addFunction ("solo_isolated", &Session::solo_isolated)
+               .addFunction ("cancel_all_solo", &Session::cancel_all_solo)
+               .addFunction ("clear_all_solo_state", &Session::clear_all_solo_state)
+               .addFunction ("set_controls", &Session::set_controls)
+               .addFunction ("set_control", &Session::set_control)
+               .addFunction ("set_exclusive_input_active", &Session::set_exclusive_input_active)
                .addFunction ("begin_reversible_command", (void (Session::*)(const std::string&))&Session::begin_reversible_command)
                .addFunction ("commit_reversible_command", &Session::commit_reversible_command)
                .addFunction ("abort_reversible_command", &Session::abort_reversible_command)
@@ -1796,15 +2169,24 @@ LuaBindings::common (lua_State* L)
                .addFunction ("worst_output_latency", &Session::worst_output_latency)
                .addFunction ("worst_input_latency", &Session::worst_input_latency)
                .addFunction ("worst_track_latency", &Session::worst_track_latency)
+               .addFunction ("worst_track_roll_delay", &Session::worst_track_roll_delay)
+               .addFunction ("worst_track_out_latency", &Session::worst_track_out_latency)
                .addFunction ("worst_playback_latency", &Session::worst_playback_latency)
                .addFunction ("cfg", &Session::cfg)
                .addFunction ("route_groups", &Session::route_groups)
                .addFunction ("new_route_group", &Session::new_route_group)
+               .addFunction ("end_is_free", &Session::end_is_free)
+               .addFunction ("set_end_is_free", &Session::set_end_is_free)
                .addFunction ("remove_route_group", (void (Session::*)(RouteGroup*))&Session::remove_route_group)
+               .addFunction ("vca_manager", &Session::vca_manager_ptr)
+               .addExtCFunction ("timecode_to_sample_lua", ARDOUR::LuaAPI::timecode_to_sample_lua)
+               .addExtCFunction ("sample_to_timecode_lua", ARDOUR::LuaAPI::sample_to_timecode_lua)
                .endClass ()
 
                .beginClass <RegionFactory> ("RegionFactory")
                .addStaticFunction ("region_by_id", &RegionFactory::region_by_id)
+               .addStaticFunction ("regions", &RegionFactory::regions)
+               .addStaticFunction ("clone_region", static_cast<boost::shared_ptr<Region> (*)(boost::shared_ptr<Region>, bool, bool)>(&RegionFactory::create))
                .endClass ()
 
                /* session enums (rt-safe, common) */
@@ -1838,13 +2220,19 @@ 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)
+               .addFunction ("monotonic_time", ::g_get_monotonic_time)
                .addCFunction ("build_filename", ARDOUR::LuaAPI::build_filename)
                .addFunction ("new_noteptr", ARDOUR::LuaAPI::new_noteptr)
+               .addFunction ("note_list", ARDOUR::LuaAPI::note_list)
+               .addCFunction ("sample_to_timecode", ARDOUR::LuaAPI::sample_to_timecode)
+               .addCFunction ("timecode_to_sample", ARDOUR::LuaAPI::timecode_to_sample)
 
                .beginClass <ARDOUR::LuaAPI::Vamp> ("Vamp")
                .addConstructor <void (*) (const std::string&, float)> ()
@@ -1937,11 +2325,11 @@ LuaBindings::dsp (lua_State* L)
 
                .beginClass <AudioBuffer> ("AudioBuffer")
                .addEqualCheck ()
-               .addFunction ("data", (Sample*(AudioBuffer::*)(framecnt_t))&AudioBuffer::data)
+               .addFunction ("data", (Sample*(AudioBuffer::*)(samplecnt_t))&AudioBuffer::data)
                .addFunction ("silence", &AudioBuffer::silence)
                .addFunction ("apply_gain", &AudioBuffer::apply_gain)
                .addFunction ("check_silence", &AudioBuffer::check_silence)
-               .addFunction ("read_from", (void (AudioBuffer::*)(const Sample*, framecnt_t, framecnt_t, framecnt_t))&AudioBuffer::check_silence)
+               .addFunction ("read_from", (void (AudioBuffer::*)(const Sample*, samplecnt_t, samplecnt_t, samplecnt_t))&AudioBuffer::check_silence)
                .endClass()
 
                .beginClass <MidiBuffer> ("MidiBuffer")
@@ -1951,10 +2339,10 @@ LuaBindings::dsp (lua_State* L)
                .addFunction ("empty", &MidiBuffer::empty)
                .addFunction ("resize", &MidiBuffer::resize)
                .addFunction ("copy", (void (MidiBuffer::*)(MidiBuffer const * const))&MidiBuffer::copy)
-               .addFunction ("push_event", (bool (MidiBuffer::*)(const Evoral::Event<framepos_t>&))&MidiBuffer::push_back)
-               .addFunction ("push_back", (bool (MidiBuffer::*)(framepos_t, size_t, const uint8_t*))&MidiBuffer::push_back)
+               .addFunction ("push_event", (bool (MidiBuffer::*)(const Evoral::Event<samplepos_t>&))&MidiBuffer::push_back)
+               .addFunction ("push_back", (bool (MidiBuffer::*)(samplepos_t, size_t, const uint8_t*))&MidiBuffer::push_back)
                // TODO iterators..
-               .addExtCFunction ("table", &luabridge::CFunc::listToTable<const Evoral::Event<framepos_t>, MidiBuffer>)
+               .addExtCFunction ("table", &luabridge::CFunc::listToTable<const Evoral::Event<samplepos_t>, MidiBuffer>)
                .endClass()
 
                .beginClass <BufferSet> ("BufferSet")
@@ -1967,12 +2355,12 @@ LuaBindings::dsp (lua_State* L)
 
        luabridge::getGlobalNamespace (L)
                .beginNamespace ("Evoral")
-               .deriveClass <Evoral::Event<framepos_t>, Evoral::Event<framepos_t> > ("Event")
+               .deriveClass <Evoral::Event<samplepos_t>, Evoral::Event<samplepos_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)
+               .addFunction ("type", &Evoral::Event<samplepos_t>::type)
+               .addFunction ("channel", &Evoral::Event<samplepos_t>::channel)
+               .addFunction ("set_type", &Evoral::Event<samplepos_t>::set_type)
+               .addFunction ("set_channel", &Evoral::Event<samplepos_t>::set_channel)
                .endClass ()
                .endNamespace ();
 
@@ -2020,6 +2408,7 @@ LuaBindings::session (lua_State* L)
                .addFunction ("save_state", &Session::save_state)
                .addFunction ("set_dirty", &Session::set_dirty)
                .addFunction ("unknown_processors", &Session::unknown_processors)
+               .addFunction ("export_track_state", &Session::export_track_state)
 
                .addFunction<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