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.

168 lines
5.4KB

  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',tooldir='tools.waf')
  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. if Options.options.sse:
  35. if os.system("grep -q '^flags.*\<sse2\>' /proc/cpuinfo"):
  36. Options.options.sse = 0
  37. print( "Processor lacks sse, disabling..." )
  38. # NTK_EXTRA_FLAGS=''
  39. # if not Options.options.use_system_ntk:
  40. # print 'Using bundled NTK'
  41. # os.environ['PKG_CONFIG_PATH'] = 'lib/ntk/build/:' + os.environ.get('PKG_CONFIG_PATH','')
  42. # NTK_EXTRA_FLAGS='--static'
  43. # PWD = os.environ.get('PWD','')
  44. # os.environ['PATH'] = PWD + '/lib/ntk/build/fluid:' + os.environ.get('PATH','')
  45. conf.check_cfg(package='ntk', uselib_store='NTK', args='--cflags --libs',
  46. atleast_version='1.3.0', mandatory=True)
  47. conf.check_cfg(package='ntk_images', uselib_store='NTK_IMAGES', args=' --cflags --libs',
  48. atleast_version='1.3.0', mandatory=True)
  49. conf.find_program('ntk-fluid', var='NTK_FLUID')
  50. conf.check_cfg(package='jack', uselib_store='JACK', args="--cflags --libs",
  51. atleast_version='0.103.0', mandatory=True)
  52. conf.check_cc(msg='Checking for jack_port_get_latency_range()',
  53. define_name='HAVE_JACK_PORT_GET_LATENCY_RANGE',
  54. 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 ); }',
  55. mandatory=False);
  56. conf.check(function_name='jack_get_property',
  57. header_name='jack/metadata.h',
  58. define_name='HAVE_JACK_METADATA',
  59. uselib='JACK',
  60. mandatory=False)
  61. conf.check_cfg(package='x11', uselib_store='XLIB',args="--cflags --libs",
  62. mandatory=True)
  63. conf.check_cfg(package='liblo', uselib_store='LIBLO',args="--cflags --libs",
  64. atleast_version='0.26', mandatory=True)
  65. conf.check_cc(msg='Checking for compiler pointer alignment hints',
  66. uselib_store='HAS_BUILTIN_ASSUME_ALIGNED',
  67. fragment='int main ( char**argv, int argc ) { const char *s = (const char*)__builtin_assume_aligned( 0, 16 ); return 0; }',
  68. execute=False, mandatory=False)
  69. ###
  70. for i in common:
  71. conf.recurse(i)
  72. optimization_flags = [
  73. "-O3",
  74. "-fomit-frame-pointer",
  75. "-ffast-math",
  76. "-pipe"
  77. ]
  78. if Options.options.sse:
  79. print('Using SSE optimization')
  80. optimization_flags.extend( [
  81. "-msse2",
  82. "-mfpmath=sse" ] );
  83. conf.define( 'USE_SSE', 1 )
  84. debug_flags = [ '-O0', '-g3' ]
  85. if Options.options.debug:
  86. print('Building for debugging')
  87. conf.env.append_value('CFLAGS', debug_flags )
  88. conf.env.append_value('CXXFLAGS', debug_flags )
  89. else:
  90. print('Building for performance')
  91. conf.env.append_value('CFLAGS', optimization_flags )
  92. conf.env.append_value('CXXFLAGS', optimization_flags )
  93. conf.define( 'NDEBUG', 1 )
  94. conf.define( "_GNU_SOURCE", 1)
  95. conf.env.append_value('CFLAGS',['-Wall'])
  96. # conf.env.append_value('CXXFLAGS',['-Wall','-fno-exceptions', '-fno-rtti'])
  97. conf.env.append_value('CXXFLAGS',['-Wall','-fno-rtti'])
  98. global_flags = [ '-pthread',
  99. '-D_LARGEFILE64_SOURCE',
  100. '-D_FILE_OFFSET_BITS=64',
  101. '-D_GNU_SOURCE' ]
  102. conf.env.append_value('CFLAGS', global_flags )
  103. conf.env.append_value('CXXFLAGS', global_flags )
  104. conf.env.PROJECT = conf.options.project
  105. if conf.env.PROJECT:
  106. pl = [ conf.env.PROJECT ]
  107. else:
  108. pl = projects;
  109. for i in pl:
  110. Logs.pprint('YELLOW', 'Configuring %s' % i)
  111. conf.recurse(i);
  112. def run(ctx):
  113. if not Options.options.cmd:
  114. Logs.error("missing --cmd option for run command")
  115. return
  116. cmd = Options.options.cmd
  117. Logs.pprint('GREEN', 'Running %s' % cmd)
  118. subprocess.call(cmd, shell=True, env=source_tree_env())
  119. def build(bld):
  120. for i in common:
  121. bld.recurse(i)
  122. if bld.env.PROJECT:
  123. pl = [ bld.env.PROJECT ]
  124. else:
  125. pl = projects;
  126. for i in pl:
  127. bld.recurse(i);