new dbus helper function: dbus_call_simple()
[ladish.git] / wscript
blob5657ad0bb196aec2114f166754a6e95b7b0f4388
1 #! /usr/bin/env python
2 # encoding: utf-8
4 import os
5 import Options
6 import Utils
8 APPNAME='ladish'
9 VERSION='1'
10 DBUS_NAME_BASE = 'org.ladish'
12 # these variables are mandatory ('/' are converted automatically)
13 srcdir = '.'
14 blddir = 'build'
16 def display_msg(conf, msg="", status = None, color = None):
17 if status:
18 conf.check_message_1(msg)
19 conf.check_message_2(status, color)
20 else:
21 Utils.pprint('NORMAL', msg)
23 def display_raw_text(conf, text, color = 'NORMAL'):
24 Utils.pprint(color, text, sep = '')
26 def display_line(conf, text, color = 'NORMAL'):
27 Utils.pprint(color, text, sep = os.linesep)
29 def set_options(opt):
30 opt.tool_options('compiler_cc')
31 opt.tool_options('compiler_cxx')
32 opt.add_option('--enable-pkg-config-dbus-service-dir', action='store_true', default=False, help='force D-Bus service install dir to be one returned by pkg-config')
34 def add_cflag(conf, flag):
35 conf.env.append_unique('CXXFLAGS', flag)
36 conf.env.append_unique('CCFLAGS', flag)
38 def configure(conf):
39 conf.check_tool('compiler_cc')
40 conf.check_tool('compiler_cxx')
42 conf.check_cfg(
43 package = 'dbus-1',
44 atleast_version = '1.0.0',
45 mandatory = True,
46 errmsg = "not installed, see http://dbus.freedesktop.org/",
47 args = '--cflags --libs')
49 dbus_dir = conf.check_cfg(package='dbus-1', args='--variable=session_bus_services_dir', msg="Retrieving D-Bus services dir")
50 if not dbus_dir:
51 return
53 dbus_dir = dbus_dir.strip()
54 conf.env['DBUS_SERVICES_DIR_REAL'] = dbus_dir
56 if Options.options.enable_pkg_config_dbus_service_dir:
57 conf.env['DBUS_SERVICES_DIR'] = dbus_dir
58 else:
59 conf.env['DBUS_SERVICES_DIR'] = os.path.join(os.path.normpath(conf.env['PREFIX']), 'share', 'dbus-1', 'services')
61 conf.check_cfg(
62 package = 'uuid',
63 mandatory = True,
64 errmsg = "not installed, see http://e2fsprogs.sourceforge.net/",
65 args = '--cflags --libs')
67 conf.check(header_name='expat.h', define_name="HAVE_EXPAT")
69 if conf.is_defined('HAVE_EXPAT'):
70 conf.env['LIB_EXPAT'] = ['expat']
72 conf.check_cfg(
73 package = 'dbus-glib-1',
74 mandatory = True,
75 errmsg = "not installed, see http://dbus.freedesktop.org/",
76 args = '--cflags --libs')
78 conf.check_cfg(
79 package = 'glibmm-2.4',
80 mandatory = True,
81 errmsg = "not installed, see http://www.gtkmm.org/",
82 args = '--cflags --libs')
84 conf.check_cfg(
85 package = 'gtkmm-2.4',
86 mandatory = True,
87 atleast_version = '2.11.12',
88 errmsg = "not installed, see http://www.gtkmm.org/",
89 args = '--cflags --libs')
91 conf.check_cfg(
92 package = 'libgnomecanvasmm-2.6',
93 mandatory = True,
94 errmsg = "not installed, see http://www.gtkmm.org/",
95 args = '--cflags --libs')
97 conf.check_cfg(
98 package = 'libglademm-2.4',
99 mandatory = True,
100 errmsg = "not installed, see http://www.gtkmm.org/",
101 args = '--cflags --libs')
103 conf.check_cfg(
104 package = 'flowcanvas',
105 mandatory = True,
106 atleast_version = '0.4.0',
107 errmsg = "not installed, see http://drobilla.net/software/flowcanvas/",
108 args = '--cflags --libs')
110 # We need the boost headers package (e.g. libboost-dev)
111 # shared_ptr.hpp and weak_ptr.hpp
112 conf.check_tool('boost')
113 conf.check_boost()
115 add_cflag(conf, '-Wall')
116 add_cflag(conf, '-Werror')
118 conf.define('DATA_DIR', os.path.normpath(os.path.join(conf.env['PREFIX'], 'share', APPNAME)))
119 conf.define('DEFAULT_PROJECT_DIR', "audio-projects")
120 conf.define('PACKAGE_VERSION', VERSION)
121 conf.define('DBUS_NAME_BASE', DBUS_NAME_BASE)
122 conf.define('DBUS_BASE_PATH', '/' + DBUS_NAME_BASE.replace('.', '/'))
123 conf.define('_GNU_SOURCE', 1)
124 conf.write_config_header('config.h')
126 display_msg(conf)
128 display_msg(conf, "==================")
129 version_msg = APPNAME + "-" + VERSION
131 #if svnrev:
132 # version_msg += " exported from r" + rev
133 #else:
134 # version_msg += " git revision will checked and eventually updated during build"
136 display_msg(conf, version_msg)
138 display_msg(conf)
139 display_msg(conf, "Install prefix", conf.env['PREFIX'], 'CYAN')
141 display_msg(conf, 'D-Bus service install directory', conf.env['DBUS_SERVICES_DIR'], 'CYAN')
143 if conf.env['DBUS_SERVICES_DIR'] != conf.env['DBUS_SERVICES_DIR_REAL']:
144 display_msg(conf)
145 display_line(conf, "WARNING: D-Bus session services directory as reported by pkg-config is", 'RED')
146 display_raw_text(conf, "WARNING:", 'RED')
147 display_line(conf, conf.env['DBUS_SERVICES_DIR_REAL'], 'CYAN')
148 display_line(conf, 'WARNING: but service file will be installed in', 'RED')
149 display_raw_text(conf, "WARNING:", 'RED')
150 display_line(conf, conf.env['DBUS_SERVICES_DIR'], 'CYAN')
151 display_line(conf, 'WARNING: You may need to adjust your D-Bus configuration after installing jackdbus', 'RED')
152 display_line(conf, 'WARNING: You can override dbus service install directory', 'RED')
153 display_line(conf, 'WARNING: with --enable-pkg-config-dbus-service-dir option to this script', 'RED')
155 display_msg(conf)
157 def build(bld):
158 daemon = bld.new_task_gen('cc', 'program')
159 daemon.target = 'ladishd'
160 daemon.includes = "build/default" # XXX config.h version.h and other generated files
161 daemon.uselib = 'DBUS-1 LIBXML-2.0 UUID'
162 daemon.ver_header = 'version.h'
163 daemon.env.append_value("LINKFLAGS", ["-lutil", "-ldl"])
164 daemon.source = []
165 for source in [
166 'main.c',
167 'loader.c',
168 'log.c',
169 'sigsegv.c',
170 'proctitle.c',
171 'appdb.c',
172 'procfs.c',
173 'dbus_iface_control.c',
174 'jack_proxy.c',
175 'jack.c',
176 'studio.c',
177 'catdup.c'
179 daemon.source.append(os.path.join("daemon", source))
181 for source in [
182 'service.c',
183 'signal.c',
184 'method.c',
185 'error.c',
186 'object_path.c',
187 'introspection.c',
188 'interface.c',
189 'helpers.c',
191 daemon.source.append(os.path.join("dbus", source))
193 daemon.source.append(os.path.join("common", "safety.c"))
195 # process name.arnaudov.nedko.ladish.service.in -> name.arnaudov.nedko.ladish.service
196 import misc
197 obj = bld.new_task_gen('subst')
198 obj.source = os.path.join('daemon', 'dbus.service.in')
199 obj.target = DBUS_NAME_BASE + '.service'
200 obj.dict = {'dbus_object_path': DBUS_NAME_BASE,
201 'daemon_bin_path': os.path.join(bld.env['PREFIX'], 'bin', daemon.target)}
202 obj.install_path = bld.env['DBUS_SERVICES_DIR'] + os.path.sep
203 obj.fun = misc.subst_func
205 liblash = bld.new_task_gen('cc', 'shlib')
206 liblash.includes = "build/default" # XXX config.h version.h and other generated files
207 liblash.uselib = 'DBUS-1 LIBXML-2.0 UUID'
208 liblash.target = 'lash'
209 liblash.vnum = "1.1.1"
210 liblash.defines = ['LASH_OLD_API', 'DEBUG_OUTPUT_TERMINAL']
211 liblash.source = []
213 for source in [
214 'lash.c',
215 'lash_config.c',
216 'client.c',
217 'dbus_service.c',
218 'dbus_iface_client.c',
219 'protocol.c',
220 'event.c',
221 'args.c',
223 liblash.source.append(os.path.join("lash_compat", "liblash", source))
225 for source in [
226 'service.c',
227 'signal.c',
228 'method.c',
229 'error.c',
230 'object_path.c',
231 'introspection.c',
232 'interface.c',
234 liblash.source.append(os.path.join("dbus", source))
236 liblash.source.append(os.path.join("common", "safety.c"))
237 liblash.source.append(os.path.join("daemon", "legacy", "file.c"))
239 # pkgpyexec_LTLIBRARIES = _lash.la
240 # INCLUDES = $(PYTHON_INCLUDES)
241 # _lash_la_LDFLAGS = -module -avoid-version ../liblash/liblash.la
242 # _lash_la_SOURCES = lash.c lash.h lash_wrap.c
243 # pkgpyexec_SCRIPTS = lash.py
244 # CLEANFILES = lash_wrap.c lash.py lash.pyc zynjacku.defs
245 # EXTRA_DIST = test.py lash.i lash.py
246 # lash_wrap.c lash.py: lash.i lash.h
247 # swig -o lash_wrap.c -I$(top_srcdir) -python $(top_srcdir)/$(subdir)/lash.i
249 #####################################################
250 # gladish
251 gladish = bld.new_task_gen('cxx', 'program')
252 gladish.target = 'gladish'
253 gladish.includes = "build/default" # XXX config.h version.h and other generated files
254 gladish.uselib = 'DBUS-1 LIBGNOMECANVASMM-2.6 LIBGLADEMM-2.4 FLOWCANVAS DBUS-GLIB-1'
255 gladish.source = []
256 for source in [
257 'main.cpp',
258 'Patchage.cpp',
259 'PatchageCanvas.cpp',
260 'StateManager.cpp',
261 'jack_proxy.cpp',
262 'lash_client.cpp',
263 'lash_proxy.cpp',
264 'load_projects_dialog.cpp',
265 'project.cpp',
266 'project_list.cpp',
267 'project_properties.cpp',
268 'session.cpp',
269 'a2j_proxy.cpp',
270 'dbus_helpers.c',
271 'canvas.c',
273 gladish.source.append(os.path.join("gui", source))
275 # Glade UI definitions (XML)
276 bld.install_files(bld.env['DATA_DIR'], 'gui/gui.glade')
278 # 'Desktop' file (menu entry, icon, etc)
279 #obj = bld.create_obj('subst')
280 #obj.source = 'patchage.desktop.in'
281 #obj.target = 'patchage.desktop'
282 #obj.dict = {
283 # 'BINDIR' : bld.env()['BINDIR'],
284 # 'APP_INSTALL_NAME' : bld.env()['APP_INSTALL_NAME'],
285 # 'APP_HUMAN_NAME' : bld.env()['APP_HUMAN_NAME'],
287 #install_as(os.path.normpath(bld.env()['DATADIR'] + 'applications/'), bld.env()['APP_INSTALL_NAME'] + '.desktop', 'build/default/patchage.desktop')
289 # Icons
291 # Installation layout (with /usr prefix)
292 # /usr/bin/patchage
293 # /usr/share/applications/patchage.desktop
294 # /usr/share/icons/hicolor/16x16/apps/patchage.png
295 # /usr/share/icons/hicolor/22x22/apps/patchage.png
296 # /usr/share/icons/hicolor/24x24/apps/patchage.png
297 # /usr/share/icons/hicolor/32x32/apps/patchage.png
298 # /usr/share/icons/hicolor/48x48/apps/patchage.png
299 # /usr/share/icons/hicolor/scalable/apps/patchage.svg
300 # /usr/share/patchage/patchage.glade
302 # icon cache is updated using:
303 # gtk-update-icon-cache -f -t $(datadir)/icons/hicolor
305 # Dave disabled this, ask why before removing this
306 #install_as(os.path.normpath(bld.env()['PREFIX'] + '/share/icons/hicolor/scalable/apps/'), bld.env()['APP_INSTALL_NAME'] + '.svg', 'icons/scalable/patchage.svg')
308 #icon_sizes = ['16x16', '22x22', '24x24', '32x32', '48x48']
309 #for icon_size in icon_sizes:
310 # install_as(os.path.normpath(bld.env()['DATADIR'] + '/icons/hicolor/' + icon_size + '/apps/'), bld.env()['APP_INSTALL_NAME'] + '.png', 'icons/' + icon_size + '/patchage.png')
312 def dist_hook():
313 pass
315 import commands
316 from Constants import RUN_ME
317 from TaskGen import feature, after
318 import Task, Utils
320 @feature('cc')
321 @after('apply_core')
322 def process_git(self):
323 if getattr(self, 'ver_header', None):
324 tsk = self.create_task('git_ver')
325 tsk.set_outputs(self.path.find_or_declare(self.ver_header))
327 def git_ver(self):
328 self.ver = "unknown"
329 self.ver = commands.getoutput("LANG= git rev-parse HEAD").splitlines()[0]
330 if commands.getoutput("LANG= git diff-index --name-only HEAD").splitlines():
331 self.ver += "-dirty"
333 Utils.pprint('BLUE', "git revision " + self.ver)
335 fi = open(self.outputs[0].abspath(self.env), 'w')
336 fi.write('#define GIT_VERSION "%s"\n' % self.ver)
337 fi.close()
339 cls = Task.task_type_from_func('git_ver', vars=[], func=git_ver, color='BLUE', before='cc')
341 def always(self):
342 return RUN_ME
343 cls.runnable_status = always
345 def post_run(self):
346 sg = Utils.h_list(self.ver)
347 node = self.outputs[0]
348 variant = node.variant(self.env)
349 self.generator.bld.node_sigs[variant][node.id] = sg
350 cls.post_run = post_run