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.

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