summaryrefslogtreecommitdiff
path: root/vst/SConscript
diff options
context:
space:
mode:
Diffstat (limited to 'vst/SConscript')
-rw-r--r--vst/SConscript37
1 files changed, 34 insertions, 3 deletions
diff --git a/vst/SConscript b/vst/SConscript
index a711a1386d..988a386de3 100644
--- a/vst/SConscript
+++ b/vst/SConscript
@@ -4,7 +4,9 @@ import os
import os.path
import glob
-Import('env install_prefix final_prefix config_prefix libraries')
+from stat import *
+
+Import('env install_prefix final_prefix config_prefix subst_dict libraries')
ardour_vst = env.Copy()
@@ -49,6 +51,35 @@ ardour_vst.Merge ([
libraries['jack']
])
-wine_executable = ardour_vst.Program (target = 'ardour_vst', source = sources)
+#
+# run winegcc to build a mini-win32 executable that wine can run. note: this also
+# generates a script called 'ardour_vst' which we don't use
+#
+
+wine_generated_executable = ardour_vst.Program (target = 'ardour_vst', source = sources)
+
+#
+# generate a shell script that will run the .exe file correctly
+#
+
+wine_executable = ardour_vst.SubstInFile ('ardourvst', 'ardourvst.in', SUBST_DICT = subst_dict)
+
+# make sure the scripts are executable
+
+if ardour_vst['VST']:
+ ardour_vst.AddPostAction (wine_executable, ardour_vst.Action (Chmod ('vst/ardevst', 0755)))
+ ardour_vst.AddPostAction (wine_executable, ardour_vst.Action (Chmod (wine_executable, 0755)))
+ Default([wine_generated_executable, wine_executable])
+
+ # the wine script - into the bin dir
+ env.Alias('install', env.Install(os.path.join(install_prefix, 'bin'), wine_executable))
+ # the win32 executable - into the lib dir since the wine script will look for it there
+ env.Alias('install', env.Install(os.path.join(install_prefix, 'lib/ardour2'), 'ardour_vst.exe.so'))
+
+env.Alias ('tarball', env.Distribute (env['DISTTREE'],
+ [ 'SConscript',
+ 'winmain.c',
+ 'ardourvst.in',
+ 'ardevst'
+ ]))
-Default(wine_executable)