stereorize.c 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. /****************************************************************************
  2. *
  3. * Programs for processing sound files in raw- or WAV-format.
  4. * -- Merge two mono WAV-files to one stereo WAV-file.
  5. *
  6. * Name: stereorize.c
  7. * Version: 1.1
  8. * Author: Mark Roberts <mark@manumark.de>
  9. * Michael Labuschke <michael@labuschke.de>
  10. *
  11. ****************************************************************************/
  12. #include <stdio.h>
  13. #include <stdlib.h>
  14. #include <string.h>
  15. #include <errno.h>
  16. #include <time.h>
  17. #include <assert.h>
  18. #include "frame.h"
  19. static char *Version = "stereorize 1.1, November 5th 2000";
  20. static char *Usage =
  21. "Usage: stereorize [options] infile-left infile-right outfile\n\n"
  22. "Example:\n"
  23. " stereorize left.wav right.wav stereo.wav -h\n\n"
  24. "Creates stereo.wav (with WAV-header, option -h) from data in mono files\n"
  25. "left.wav and right.wav.\n"
  26. ;
  27. int main( int argcount, char *args[])
  28. {
  29. int i, k[2], maxk, stdin_in_use=FALSE;
  30. short *leftsample, *rightsample, *stereosample;
  31. FILE *channel[2];
  32. char *filename[2], *tempname;
  33. version = Version;
  34. usage = Usage;
  35. channel[0] = NULL;
  36. channel[1] = NULL;
  37. parseargs( argcount, args, NOFILES | NOCOMPLAIN);
  38. for (i = 0; i < 2; i++)
  39. {
  40. filename[i] = parsefilearg( argcount, args);
  41. if (filename[i] == NULL)
  42. argerrornum( NULL, ME_NOTENOUGHFILES);
  43. if (strcmp (filename[i], "-") == 0)
  44. {
  45. if (stdin_in_use)
  46. argerrortxt( filename[i] + 1,
  47. "Cannot use <stdin> for both input files");
  48. filename[i] = "<stdin>";
  49. channel[i] = stdin;
  50. stdin_in_use = TRUE;
  51. }
  52. else
  53. {
  54. channel[i] = fopen(filename[i], "rb");
  55. }
  56. if (channel[i] == NULL)
  57. fatalerror( "Error opening input file '%s': %s\n", filename[i],strerror(errno));
  58. else
  59. inform("Using file '%s' as input\n", filename[i]);
  60. }
  61. for (i = 0; i < 2; i++)
  62. {
  63. assert ( channel[i] != NULL);
  64. readwavheader( channel[i]);
  65. if (iswav && channels != 1)
  66. inform("Warning: '%s' is no mono file\n", filename[i]);
  67. }
  68. outfilename = parsefilearg( argcount, args);
  69. if (outfilename == NULL) argerrornum( NULL, ME_NOOUTFILE);
  70. if (strcmp (outfilename, "-") == 0)
  71. {
  72. outfilename = "<stdout>";
  73. out = stdout;
  74. }
  75. else
  76. {
  77. out = fopen(outfilename, "wb");
  78. }
  79. if (out == NULL)
  80. fatalerror( "Error opening output file '%s': %s\n", outfilename,strerror(errno));
  81. else
  82. inform("Using file '%s' as output\n", outfilename);
  83. if ((tempname = parsefilearg( argcount, args)) != NULL)
  84. argerrornum( tempname, ME_TOOMANYFILES);
  85. checknoargs(argcount, args); /* Check that no arguments are left */
  86. leftsample = malloc( sizeof(*leftsample) * BUFFSIZE);
  87. rightsample = malloc( sizeof(*leftsample) * BUFFSIZE);
  88. stereosample = malloc( sizeof(*leftsample) * 2 * BUFFSIZE);
  89. if (leftsample == NULL || rightsample == NULL || stereosample == NULL)
  90. fatalperror ("");
  91. channels = 2; /* Output files are stereo */
  92. if (wavout)
  93. {
  94. if ((strcmp(outfilename,"<stdout>")!=0) && (fseek( out, 0, SEEK_SET) != 0))
  95. fatalerror("Couldn't navigate output file '%s': %s\n",outfilename, strerror(errno));
  96. makewavheader();
  97. }
  98. startstopwatch();
  99. while (TRUE)
  100. {
  101. maxk = 0;
  102. for (i = 0; i < 2; i++)
  103. {
  104. k[i] = fread(i==0? leftsample : rightsample,
  105. sizeof(*leftsample),
  106. BUFFSIZE,
  107. channel[i]);
  108. if (k[i] == -1)
  109. fatalerror("Error reading file '%s': %s\n", filename[i],strerror(errno));
  110. if (k[i] > maxk)
  111. maxk = k[i];
  112. }
  113. if (maxk == 0)
  114. myexit (0);
  115. /*-------------------------------------------------*
  116. * First the left channel as far as it goes ... *
  117. *-------------------------------------------------*/
  118. for (i = 0; i < k[0]; i++)
  119. stereosample[2 * i] = leftsample[i];
  120. /*-------------------------------------------------*
  121. * ... and fill up till the end of this buffer. *
  122. *-------------------------------------------------*/
  123. for (; i < maxk; i++)
  124. stereosample[2 * i] = 0;
  125. /*-------------------------------------------------*
  126. * Next the right channel as far as it goes ... *
  127. *-------------------------------------------------*/
  128. for (i = 0; i < k[1]; i++)
  129. stereosample[2 * i + 1] = rightsample[i];
  130. /*-------------------------------------------------*
  131. * ... and fill up till the end of this buffer. *
  132. *-------------------------------------------------*/
  133. for (; i < maxk; i++)
  134. stereosample[2 * i + 1] = 0;
  135. fwrite(stereosample, sizeof(*leftsample), 2 * maxk, out);
  136. if (ferror( out) != 0)
  137. fatalerror("Error writing to file '%s': %s\n",
  138. outfilename, strerror(errno));
  139. }
  140. /* That was an endless loop. This point is never reached. */
  141. }