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.

253 lines
7.0KB

  1. /*******************************************************************************/
  2. /* Copyright (C) 2008 Jonathan Moore Liles */
  3. /* */
  4. /* This program is free software; you can redistribute it and/or modify it */
  5. /* under the terms of the GNU General Public License as published by the */
  6. /* Free Software Foundation; either version 2 of the License, or (at your */
  7. /* option) any later version. */
  8. /* */
  9. /* This program is distributed in the hope that it will be useful, but WITHOUT */
  10. /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
  11. /* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for */
  12. /* more details. */
  13. /* */
  14. /* You should have received a copy of the GNU General Public License along */
  15. /* with This program; see the file COPYING. If not,write to the Free Software */
  16. /* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
  17. /*******************************************************************************/
  18. #pragma once
  19. #include <FL/Fl.H>
  20. #include "Sequence.H"
  21. #include <FL/Fl_Group.H>
  22. #include <FL/Fl_Input.H>
  23. #include <FL/Fl_Button.H>
  24. #include <FL/Fl_Menu_Button.H>
  25. #include <FL/Fl_Pack.H>
  26. #include <FL/Fl_Box.H>
  27. #include <FL/fl_draw.H>
  28. #include "Loggable.H"
  29. /* TODO: rename this to Audio_Track or something since it's clearly audio specific. */
  30. #include <vector>
  31. using std::vector;
  32. #include "Port.H"
  33. #include "Timeline.H"
  34. #include "Control_Sequence.H"
  35. class Playback_DS;
  36. class Record_DS;
  37. class Port;
  38. class Region;
  39. class Audio_File;
  40. class Track : public Fl_Group, public Loggable
  41. {
  42. public:
  43. Track ( const char *L, int channels=1 );
  44. ~Track ( );
  45. static bool soloing ( void ) { return _soloing; }
  46. static const char *capture_format;
  47. private:
  48. static int _soloing;
  49. char *_name;
  50. bool _selected;
  51. bool _show_all_takes;
  52. int _size;
  53. enum { AUDIO } _type;
  54. Sequence *_track;
  55. Region *_capture; /* capture region */
  56. Audio_File *_capture_af; /* capture write source */
  57. bool configure_outputs ( int n );
  58. bool configure_inputs ( int n );
  59. void update_port_names ( void );
  60. const char *name_for_port( Port::type_e type, int n );
  61. Track ( ) : Fl_Group( 0, 0, 1, 1 )
  62. {
  63. init();
  64. timeline->add_track( this );
  65. }
  66. void init ( void );
  67. public:
  68. Fl_Input *name_field;
  69. Fl_Button *record_button;
  70. Fl_Button *mute_button;
  71. Fl_Button *solo_button;
  72. Fl_Menu_Button *take_menu;
  73. Fl_Group *controls;
  74. Fl_Pack *pack;
  75. Fl_Pack *control;
  76. Fl_Pack *takes;
  77. vector<Port> input; /* input ports... */
  78. vector<Port> output; /* output ports... */
  79. Playback_DS *playback_ds;
  80. Record_DS *record_ds;
  81. // const char *class_name ( void ) { return "Track"; }
  82. void
  83. set ( Log_Entry &e )
  84. {
  85. for ( int i = 0; i < e.size(); ++i )
  86. {
  87. const char *s, *v;
  88. e.get( i, &s, &v );
  89. if ( ! strcmp( s, ":h" ) )
  90. {
  91. size( atoi( v ) );
  92. // Fl_Widget::size( w(), height() );
  93. resize();
  94. }
  95. else if ( ! strcmp( s, ":s" ) )
  96. _selected = atoi( v );
  97. // else if ( ! strcmp( s, ":armed"
  98. else if ( ! strcmp( s, ":n" ) )
  99. name( v );
  100. else if ( ! strcmp( s, ":i" ) )
  101. configure_inputs( atoi( v ) );
  102. else if ( ! strcmp( s, ":o" ) )
  103. configure_outputs( atoi( v ) );
  104. else if ( ! strcmp( s, ":c" ) )
  105. {
  106. color( (Fl_Color)atol( v ) );
  107. redraw();
  108. }
  109. else if ( ! strcmp( s, ":t" ) )
  110. {
  111. int i;
  112. sscanf( v, "%X", &i );
  113. if ( i )
  114. {
  115. Sequence *t = (Sequence*)Loggable::find( i );
  116. /* FIXME: our track might not have been
  117. * defined yet... what should we do about this
  118. * chicken/egg problem? */
  119. if ( t )
  120. {
  121. // assert( t );
  122. track( t );
  123. }
  124. }
  125. }
  126. }
  127. }
  128. virtual void get ( Log_Entry &e ) const
  129. {
  130. e.add( ":n", _name );
  131. e.add( ":t", track() );
  132. e.add( ":s", _selected );
  133. e.add( ":h", size() );
  134. e.add( ":i", input.size() );
  135. e.add( ":o", output.size() );
  136. e.add( ":c", color() );
  137. }
  138. /* for loggable */
  139. LOG_CREATE_FUNC( Track );
  140. void add ( Control_Sequence *t );
  141. void add ( Sequence *t );
  142. void remove ( Sequence *t );
  143. void remove ( Control_Sequence *t );
  144. int size ( void ) const { return _size; }
  145. void resize ( void );
  146. void size ( int v );
  147. int height ( void ) const
  148. {
  149. static int table[] = { 30, 80, 150, 300 };
  150. return table[ _size ];
  151. }
  152. void show_all_takes ( bool b )
  153. {
  154. _show_all_takes = b;
  155. resize();
  156. }
  157. void name ( const char *name )
  158. {
  159. if ( _name )
  160. free( _name );
  161. _name = strdup( name );
  162. if ( name_field )
  163. name_field->value( _name );
  164. update_port_names();
  165. }
  166. const char * name ( void ) const { return _name; }
  167. bool mute ( void ) const { return mute_button->value(); }
  168. bool solo ( void ) const { return solo_button->value(); }
  169. bool armed ( void ) const { return record_button->value(); }
  170. bool selected ( void ) const { return _selected; }
  171. static void cb_input_field ( Fl_Widget *w, void *v );
  172. void cb_input_field ( void );
  173. static void cb_button ( Fl_Widget *w, void *v );
  174. void cb_button ( Fl_Widget *w );
  175. static int width ( void ) { return 150; }
  176. void track( Sequence * t );
  177. Sequence * track ( void ) const { return _track; }
  178. void draw ( void );
  179. int handle ( int m );
  180. const Region *capture ( void ) const { return _capture; }
  181. /* Engine */
  182. nframes_t process ( nframes_t nframes );
  183. void seek ( nframes_t frame );
  184. void record ( nframes_t nframes );
  185. void write ( sample_t *buf, nframes_t nframes );
  186. void stop ( nframes_t nframes );
  187. };