unify source copyright headers in gladish
[ladish.git] / wscript
blob041715a260cde268e31db561548eed341f4918b2
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',
178 daemon.source.append(os.path.join("daemon", source))
180 for source in [
181 'service.c',
182 'signal.c',
183 'method.c',
184 'error.c',
185 'object_path.c',
186 'introspection.c',
187 'interface.c',
189 daemon.source.append(os.path.join("dbus", source))
191 daemon.source.append(os.path.join("common", "safety.c"))
193 # process name.arnaudov.nedko.ladish.service.in -> name.arnaudov.nedko.ladish.service
194 import misc
195 obj = bld.new_task_gen('subst')
196 obj.source = os.path.join('daemon', 'dbus.service.in')
197 obj.target = DBUS_NAME_BASE + '.service'
198 obj.dict = {'dbus_object_path': DBUS_NAME_BASE,
199 'daemon_bin_path': os.path.join(bld.env['PREFIX'], 'bin', daemon.target)}
200 obj.install_path = bld.env['DBUS_SERVICES_DIR'] + os.path.sep
201 obj.fun = misc.subst_func
203 liblash = bld.new_task_gen('cc', 'shlib')
204 liblash.includes = "build/default" # XXX config.h version.h and other generated files
205 liblash.uselib = 'DBUS-1 LIBXML-2.0 UUID'
206 liblash.target = 'lash'
207 liblash.vnum = "1.1.1"
208 liblash.defines = ['LASH_OLD_API', 'DEBUG_OUTPUT_TERMINAL']
209 liblash.source = []
211 for source in [
212 'lash.c',
213 'lash_config.c',
214 'client.c',
215 'dbus_service.c',
216 'dbus_iface_client.c',
217 'protocol.c',
218 'event.c',
219 'args.c',
221 liblash.source.append(os.path.join("lash_compat", "liblash", source))
223 for source in [
224 'service.c',
225 'signal.c',
226 'method.c',
227 'error.c',
228 'object_path.c',
229 'introspection.c',
230 'interface.c',
232 liblash.source.append(os.path.join("dbus", source))
234 liblash.source.append(os.path.join("common", "safety.c"))
235 liblash.source.append(os.path.join("daemon", "legacy", "file.c"))
237 # pkgpyexec_LTLIBRARIES = _lash.la
238 # INCLUDES = $(PYTHON_INCLUDES)
239 # _lash_la_LDFLAGS = -module -avoid-version ../liblash/liblash.la
240 # _lash_la_SOURCES = lash.c lash.h lash_wrap.c
241 # pkgpyexec_SCRIPTS = lash.py
242 # CLEANFILES = lash_wrap.c lash.py lash.pyc zynjacku.defs
243 # EXTRA_DIST = test.py lash.i lash.py
244 # lash_wrap.c lash.py: lash.i lash.h
245 # swig -o lash_wrap.c -I$(top_srcdir) -python $(top_srcdir)/$(subdir)/lash.i
247 #####################################################
248 # gladish
249 gladish = bld.new_task_gen('cxx', 'program')
250 gladish.target = 'gladish'
251 gladish.includes = "build/default" # XXX config.h version.h and other generated files
252 gladish.uselib = 'DBUS-1 LIBGNOMECANVASMM-2.6 LIBGLADEMM-2.4 FLOWCANVAS DBUS-GLIB-1'
253 gladish.source = []
254 for source in [
255 'main.cpp',
256 'Patchage.cpp',
257 'PatchageCanvas.cpp',
258 'StateManager.cpp',
259 'jack_proxy.cpp',
260 'lash_client.cpp',
261 'lash_proxy.cpp',
262 'load_projects_dialog.cpp',
263 'project.cpp',
264 'project_list.cpp',
265 'project_properties.cpp',
266 'session.cpp',
267 'a2j_proxy.cpp',
268 'dbus_helpers.c',
269 'canvas.c',
271 gladish.source.append(os.path.join("gui", source))
273 # Glade UI definitions (XML)
274 bld.install_files(bld.env['DATA_DIR'], 'gui/gui.glade')
276 # 'Desktop' file (menu entry, icon, etc)
277 #obj = bld.create_obj('subst')
278 #obj.source = 'patchage.desktop.in'
279 #obj.target = 'patchage.desktop'
280 #obj.dict = {
281 # 'BINDIR' : bld.env()['BINDIR'],
282 # 'APP_INSTALL_NAME' : bld.env()['APP_INSTALL_NAME'],
283 # 'APP_HUMAN_NAME' : bld.env()['APP_HUMAN_NAME'],
285 #install_as(os.path.normpath(bld.env()['DATADIR'] + 'applications/'), bld.env()['APP_INSTALL_NAME'] + '.desktop', 'build/default/patchage.desktop')
287 # Icons
289 # Installation layout (with /usr prefix)
290 # /usr/bin/patchage
291 # /usr/share/applications/patchage.desktop
292 # /usr/share/icons/hicolor/16x16/apps/patchage.png
293 # /usr/share/icons/hicolor/22x22/apps/patchage.png
294 # /usr/share/icons/hicolor/24x24/apps/patchage.png
295 # /usr/share/icons/hicolor/32x32/apps/patchage.png
296 # /usr/share/icons/hicolor/48x48/apps/patchage.png
297 # /usr/share/icons/hicolor/scalable/apps/patchage.svg
298 # /usr/share/patchage/patchage.glade
300 # icon cache is updated using:
301 # gtk-update-icon-cache -f -t $(datadir)/icons/hicolor
303 # Dave disabled this, ask why before removing this
304 #install_as(os.path.normpath(bld.env()['PREFIX'] + '/share/icons/hicolor/scalable/apps/'), bld.env()['APP_INSTALL_NAME'] + '.svg', 'icons/scalable/patchage.svg')
306 #icon_sizes = ['16x16', '22x22', '24x24', '32x32', '48x48']
307 #for icon_size in icon_sizes:
308 # install_as(os.path.normpath(bld.env()['DATADIR'] + '/icons/hicolor/' + icon_size + '/apps/'), bld.env()['APP_INSTALL_NAME'] + '.png', 'icons/' + icon_size + '/patchage.png')
310 def dist_hook():
311 pass
313 import commands
314 from Constants import RUN_ME
315 from TaskGen import feature, after
316 import Task, Utils
318 @feature('cc')
319 @after('apply_core')
320 def process_git(self):
321 if getattr(self, 'ver_header', None):
322 tsk = self.create_task('git_ver')
323 tsk.set_outputs(self.path.find_or_declare(self.ver_header))
325 def git_ver(self):
326 self.ver = "unknown"
327 self.ver = commands.getoutput("LANG= git rev-parse HEAD").splitlines()[0]
328 if commands.getoutput("LANG= git diff-index --name-only HEAD").splitlines():
329 self.ver += "-dirty"
331 Utils.pprint('BLUE', "git revision " + self.ver)
333 fi = open(self.outputs[0].abspath(self.env), 'w')
334 fi.write('#define GIT_VERSION "%s"\n' % self.ver)
335 fi.close()
337 cls = Task.task_type_from_func('git_ver', vars=[], func=git_ver, color='BLUE', before='cc')
339 def always(self):
340 return RUN_ME
341 cls.runnable_status = always
343 def post_run(self):
344 sg = Utils.h_list(self.ver)
345 node = self.outputs[0]
346 variant = node.variant(self.env)
347 self.generator.bld.node_sigs[variant][node.id] = sg
348 cls.post_run = post_run