From 6972db0d554ba36d05fbd0ada5e303148cbab2bf Mon Sep 17 00:00:00 2001 From: Robin Gareus Date: Sun, 20 Mar 2016 20:52:12 +0100 Subject: add luadoc binary (developer tool) to dump lua bindings output is either JSON or lua-tables. enable via ./waf configure --luadoc ... , needs C++11 --- gtk2_ardour/arluadoc | 9 +++++++++ gtk2_ardour/luadoc.cc | 26 ++++++++++++++++++++++++++ gtk2_ardour/main.cc | 2 ++ gtk2_ardour/wscript | 38 ++++++++++++++++++++++++++++++++++++++ 4 files changed, 75 insertions(+) create mode 100755 gtk2_ardour/arluadoc create mode 100644 gtk2_ardour/luadoc.cc (limited to 'gtk2_ardour') diff --git a/gtk2_ardour/arluadoc b/gtk2_ardour/arluadoc new file mode 100755 index 0000000000..2983cf9103 --- /dev/null +++ b/gtk2_ardour/arluadoc @@ -0,0 +1,9 @@ +#!/bin/sh +TOP=`dirname "$0"`/.. +. $TOP/build/gtk2_ardour/ardev_common_waf.sh +export UBUNTU_MENUPROXY="" + +$TOP/build/gtk2_ardour/luadoc "$@" \ + | sed 's/__cxx11:://g;' \ + | sed 's/std::basic_string\, std::allocator >/std::string/g;' \ + | sed 's/, std::allocator<[^>]*> //g;' diff --git a/gtk2_ardour/luadoc.cc b/gtk2_ardour/luadoc.cc new file mode 100644 index 0000000000..794740eeda --- /dev/null +++ b/gtk2_ardour/luadoc.cc @@ -0,0 +1,26 @@ +#include +#include +#include + +#include "ardour/luabindings.h" +#include "luainstance.h" + +int main (int argc, char **argv) +{ + luabridge::setPrintBindings (true); + LuaState lua; + lua_State* L = lua.getState (); +#ifdef LUADOCOUT + printf ("doc = {\n"); +#else + printf ("[\n"); +#endif + LuaInstance::register_classes (L); + ARDOUR::LuaBindings::dsp (L); +#ifdef LUADOCOUT + printf ("}\n"); +#else + printf ("{} ]\n"); +#endif + return 0; +} diff --git a/gtk2_ardour/main.cc b/gtk2_ardour/main.cc index 6a8347fb1d..83f8491855 100644 --- a/gtk2_ardour/main.cc +++ b/gtk2_ardour/main.cc @@ -273,6 +273,8 @@ extern "C" { int ardour_main (int argc, char *argv[]) +#elif defined NOMAIN +int nomain (int argc, char *argv[]) #else int main (int argc, char *argv[]) #endif diff --git a/gtk2_ardour/wscript b/gtk2_ardour/wscript index 36223bd2cb..72e8120585 100644 --- a/gtk2_ardour/wscript +++ b/gtk2_ardour/wscript @@ -405,6 +405,44 @@ def build(bld): VERSION = "%s.%s" % (bld.env['MAJOR'], bld.env['MINOR']) I18N_PACKAGE = 'gtk2_ardour' + bld.env['MAJOR'] + # Tool to dump lua-bindings (of gtk2ardour + libs) + if re.search ("linux", sys.platform) != None and bld.env['LUABINDINGDOC']: + obj = bld (features = 'cxx c cxxprogram') + obj.install_path = None + obj.source = list(gtk2_ardour_sources) + obj.target = 'luadoc' + obj.includes = ['.', '../libs'] + obj.ldflags = ['-no-undefined'] + obj.use = [ + 'libpbd', + 'libardour', + 'libardour_cp', + 'libtimecode', + 'libmidipp', + 'libgtkmm2ext', + 'libcanvas', + 'libptformat', + ] + obj.defines = [ + 'NOMAIN', + 'PACKAGE="' + I18N_PACKAGE + '"', + 'DATA_DIR="' + os.path.normpath(bld.env['DATADIR']) + '"', + 'CONFIG_DIR="' + os.path.normpath(bld.env['SYSCONFDIR']) + '"', + 'LOCALEDIR="' + os.path.normpath(bld.env['LOCALEDIR']) + '"', + ] + obj.linkflags = '' + obj.uselib = 'UUID FLAC FONTCONFIG GLIBMM GTHREAD GTK OGG CURL DL GTKMM CANVAS FFTW3F LO TAGLIB XML ' + obj.source += [ 'luadoc.cc', 'bundle_env_linux.cc' ] + if bld.is_defined('HAVE_SUIL'): + obj.source += [ 'lv2_plugin_ui.cc' ] + obj.use += [ 'SUIL' ] + if bld.is_defined('LXVST_SUPPORT'): + obj.source += [ 'vst_plugin_ui.cc' ] + obj.source += [ 'linux_vst_gui_support.cc', 'lxvst_plugin_ui.cc' ] + obj.defines += [ 'LXVST_SUPPORT' ] + obj.use += [ 'X11' ] + + if bld.is_defined('WINDOWS_VST_SUPPORT') and bld.env['build_target'] != 'mingw': # Windows VST support w/wine # If we require VST support we build a stub main() and the FST library -- cgit v1.2.3