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.

145 lines
4.2KB

  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_cfg(package='liblo', uselib_store='LIBLO',args="--cflags --libs",
  49. atleast_version='0.26', mandatory=True)
  50. ###
  51. for i in common:
  52. conf.recurse(i)
  53. optimization_flags = [
  54. "-O3",
  55. "-fomit-frame-pointer",
  56. "-ffast-math",
  57. "-pipe"
  58. ]
  59. if Options.options.sse:
  60. print('Using SSE optimization')
  61. optimization_flags.extend( [
  62. "-msse2",
  63. "-mfpmath=sse",
  64. "-ftree-vectorize" ] )
  65. conf.define( 'USE_SSE', 1 )
  66. debug_flags = [ '-O0', '-g3' ]
  67. if Options.options.debug:
  68. print('Building for debugging')
  69. conf.env.append_value('CFLAGS', debug_flags )
  70. conf.env.append_value('CXXFLAGS', debug_flags )
  71. else:
  72. print('Building for performance')
  73. conf.env.append_value('CFLAGS', optimization_flags )
  74. conf.env.append_value('CXXFLAGS', optimization_flags )
  75. conf.define( 'NDEBUG', 1 )
  76. conf.define( "_GNU_SOURCE", 1)
  77. conf.env.append_value('CFLAGS',['-Wall'])
  78. # conf.env.append_value('CXXFLAGS',['-Wall','-fno-exceptions', '-fno-rtti'])
  79. conf.env.append_value('CXXFLAGS',['-Wall','-fno-rtti'])
  80. global_flags = [ '-pthread',
  81. '-D_LARGEFILE64_SOURCE',
  82. '-D_FILE_OFFSET_BITS=64',
  83. '-D_GNU_SOURCE' ]
  84. conf.env.append_value('CFLAGS', global_flags )
  85. conf.env.append_value('CXXFLAGS', global_flags )
  86. conf.env.PROJECT = conf.options.project
  87. if conf.env.PROJECT:
  88. pl = [ conf.env.PROJECT ]
  89. else:
  90. pl = projects;
  91. for i in pl:
  92. Logs.pprint('YELLOW', 'Configuring %s' % i)
  93. conf.recurse(i);
  94. def run(ctx):
  95. if not Options.options.cmd:
  96. Logs.error("missing --cmd option for run command")
  97. return
  98. cmd = Options.options.cmd
  99. Logs.pprint('GREEN', 'Running %s' % cmd)
  100. subprocess.call(cmd, shell=True, env=source_tree_env())
  101. def build(bld):
  102. for i in common:
  103. bld.recurse(i)
  104. if bld.env.PROJECT:
  105. pl = [ bld.env.PROJECT ]
  106. else:
  107. pl = projects;
  108. for i in pl:
  109. bld.recurse(i);