Assists music production by grouping standalone programs into sessions. Community version of "Non Session Manager".
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

157 lines
5.0KB

  1. #!/usr/bin/env python
  2. import os
  3. import subprocess
  4. import waflib.Logs as Logs, waflib.Options as Options
  5. import string
  6. VERSION = 'xxx'
  7. APPNAME = 'non-things'
  8. top = '.'
  9. out = 'build'
  10. common = [ 'nonlib', 'FL' ]
  11. projects = [ 'timeline', 'mixer', 'sequencer', 'session-manager' ]
  12. def options(opt):
  13. # opt.add_option('--use-system-ntk', action='store_true', default=False,
  14. # dest='use_system_ntk',
  15. # help="Link to system-installed shared NTK instead of bundled version")
  16. opt.add_option('--enable-debug', action='store_true', default=False, dest='debug',
  17. help='Build for debugging')
  18. opt.add_option('--disable-sse', action='store_false', default=True, dest='sse',
  19. help='Disable SSE optimization')
  20. opt.add_option('--project', action='store', default=False, dest='project',
  21. help='Limit build to a single project (' + ', '.join( projects ) + ')')
  22. for i in projects:
  23. opt.recurse(i)
  24. def configure(conf):
  25. conf.load('compiler_c')
  26. conf.load('compiler_cxx')
  27. conf.load('gnu_dirs')
  28. conf.load('ntk_fluid')
  29. conf.load('gccdeps')
  30. conf.line_just = 52
  31. conf.env['LIB_PTHREAD'] = ['pthread']
  32. conf.env['LIB_DL'] = ['dl']
  33. conf.env['LIB_M'] = ['m']
  34. # NTK_EXTRA_FLAGS=''
  35. # if not Options.options.use_system_ntk:
  36. # print 'Using bundled NTK'
  37. # os.environ['PKG_CONFIG_PATH'] = 'lib/ntk/build/:' + os.environ.get('PKG_CONFIG_PATH','')
  38. # NTK_EXTRA_FLAGS='--static'
  39. # PWD = os.environ.get('PWD','')
  40. # os.environ['PATH'] = PWD + '/lib/ntk/build/fluid:' + os.environ.get('PATH','')
  41. conf.check_cfg(package='ntk', uselib_store='NTK', args='--cflags --libs',
  42. atleast_version='1.3.0', mandatory=True)
  43. conf.check_cfg(package='ntk_images', uselib_store='NTK_IMAGES', args=' --cflags --libs',
  44. atleast_version='1.3.0', mandatory=True)
  45. conf.find_program('ntk-fluid', var='NTK_FLUID')
  46. conf.check_cfg(package='jack', uselib_store='JACK', args="--cflags --libs",
  47. atleast_version='0.103.0', mandatory=True)
  48. conf.check_cc(msg='Checking for jack_port_get_latency_range()',
  49. define_name='HAVE_JACK_PORT_GET_LATENCY_RANGE',
  50. fragment='#include <jack/jack.h>\nint main (int argc, char**argv) { jack_port_get_latency_range( (jack_port_t*)0, JackCaptureLatency, (jack_latency_range_t *)0 ); }',
  51. mandatory=False);
  52. conf.check_cfg(package='x11', uselib_store='XLIB',args="--cflags --libs",
  53. mandatory=True)
  54. conf.check_cfg(package='liblo', uselib_store='LIBLO',args="--cflags --libs",
  55. atleast_version='0.26', mandatory=True)
  56. conf.check_cc(msg='Checking for compiler pointer alignment hints',
  57. uselib_store='HAS_BUILTIN_ASSUME_ALIGNED',
  58. fragment='int main ( char**argv, int argc ) { const char *s = (const char*)__builtin_assume_aligned( 0, 16 ); return 0; }',
  59. execute=False, mandatory=False)
  60. ###
  61. for i in common:
  62. conf.recurse(i)
  63. optimization_flags = [
  64. "-O3",
  65. "-fomit-frame-pointer",
  66. "-ffast-math",
  67. "-pipe"
  68. ]
  69. if Options.options.sse:
  70. print('Using SSE optimization')
  71. optimization_flags.extend( [
  72. "-msse2",
  73. "-mfpmath=sse" ] );
  74. conf.define( 'USE_SSE', 1 )
  75. debug_flags = [ '-O0', '-g3' ]
  76. if Options.options.debug:
  77. print('Building for debugging')
  78. conf.env.append_value('CFLAGS', debug_flags )
  79. conf.env.append_value('CXXFLAGS', debug_flags )
  80. else:
  81. print('Building for performance')
  82. conf.env.append_value('CFLAGS', optimization_flags )
  83. conf.env.append_value('CXXFLAGS', optimization_flags )
  84. conf.define( 'NDEBUG', 1 )
  85. conf.define( "_GNU_SOURCE", 1)
  86. conf.env.append_value('CFLAGS',['-Wall'])
  87. # conf.env.append_value('CXXFLAGS',['-Wall','-fno-exceptions', '-fno-rtti'])
  88. conf.env.append_value('CXXFLAGS',['-Wall','-fno-rtti'])
  89. global_flags = [ '-pthread',
  90. '-D_LARGEFILE64_SOURCE',
  91. '-D_FILE_OFFSET_BITS=64',
  92. '-D_GNU_SOURCE' ]
  93. conf.env.append_value('CFLAGS', global_flags )
  94. conf.env.append_value('CXXFLAGS', global_flags )
  95. conf.env.PROJECT = conf.options.project
  96. if conf.env.PROJECT:
  97. pl = [ conf.env.PROJECT ]
  98. else:
  99. pl = projects;
  100. for i in pl:
  101. Logs.pprint('YELLOW', 'Configuring %s' % i)
  102. conf.recurse(i);
  103. def run(ctx):
  104. if not Options.options.cmd:
  105. Logs.error("missing --cmd option for run command")
  106. return
  107. cmd = Options.options.cmd
  108. Logs.pprint('GREEN', 'Running %s' % cmd)
  109. subprocess.call(cmd, shell=True, env=source_tree_env())
  110. def build(bld):
  111. for i in common:
  112. bld.recurse(i)
  113. if bld.env.PROJECT:
  114. pl = [ bld.env.PROJECT ]
  115. else:
  116. pl = projects;
  117. for i in pl:
  118. bld.recurse(i);