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.

99 lines
2.6KB

  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. #include "Clip.H"
  19. #include "Timeline.H"
  20. #include <sndfile.h>
  21. #include <stdlib.h>
  22. #include <string.h>
  23. Clip::Clip ( const char *filename ) : _peaks( this )
  24. {
  25. _filename = filename;
  26. SNDFILE *in;
  27. SF_INFO si;
  28. memset( &si, 0, sizeof( si ) );
  29. in = sf_open( filename, SFM_READ, &si );
  30. if ( si.channels != 1 )
  31. printf( "error: incompatible format" );
  32. if ( si.samplerate != timeline.sample_rate )
  33. printf( "error: samplerate mismatch!\n" );
  34. _length = si.frames;
  35. sf_close( in );
  36. _peaks.open( filename );
  37. }
  38. bool
  39. Clip::open ( void )
  40. {
  41. SF_INFO si;
  42. memset( &si, 0, sizeof( si ) );
  43. if ( ! ( _in = sf_open( _filename, SFM_READ, &si ) ) )
  44. return false;
  45. return true;
  46. }
  47. void
  48. Clip::close ( void )
  49. {
  50. sf_close( _in );
  51. }
  52. void
  53. Clip::seek ( nframes_t offset )
  54. {
  55. sf_seek( _in, offset, SEEK_SET );
  56. }
  57. nframes_t
  58. Clip::read ( sample_t *buf, nframes_t len )
  59. {
  60. return sf_read_float ( _in, buf, len );
  61. }
  62. /** read samples from /start/ to /end/ into /buf/ */
  63. nframes_t
  64. Clip::read ( sample_t *buf, nframes_t start, nframes_t end )
  65. {
  66. open();
  67. seek( start );
  68. nframes_t len = read( buf, end - start );
  69. close();
  70. return len;
  71. }