mmerror.c
上传用户:wstnjxml
上传日期:2014-04-03
资源大小:7248k
文件大小:5k
源码类别:

Windows CE

开发平台:

C/C++

  1. /* MikMod sound library
  2. (c) 1998, 1999, 2000 Miodrag Vallat and others - see file AUTHORS for
  3. complete list.
  4. This library is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU Library General Public License as
  6. published by the Free Software Foundation; either version 2 of
  7. the License, or (at your option) any later version.
  8.  
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12. GNU Library General Public License for more details.
  13.  
  14. You should have received a copy of the GNU Library General Public
  15. License along with this library; if not, write to the Free Software
  16. Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
  17. 02111-1307, USA.
  18. */
  19. /*==============================================================================
  20.   $Id: mmerror.c,v 1.1.1.1 2004/01/21 01:36:35 raph Exp $
  21.   Error handling functions.
  22.   Register an error handler with _mm_RegisterErrorHandler() and you're all set.
  23. ==============================================================================*/
  24. /*
  25. The global variables _mm_errno, and _mm_critical are set before the error
  26. handler in called.  See below for the values of these variables.
  27. */
  28. #ifdef HAVE_CONFIG_H
  29. #include "config.h"
  30. #endif
  31. #include "mikmod_internals.h"
  32. CHAR *_mm_errmsg[MMERR_MAX+1] =
  33. {
  34. /* No error */
  35. "No error",
  36. /* Generic errors */
  37. "Could not open requested file",
  38. "Out of memory",
  39. "Dynamic linking failed",
  40. /* Sample errors */
  41. "Out of memory to load sample",
  42. "Out of sample handles to load sample",
  43. "Sample format not recognized",
  44. /* Module errors */
  45. "Failure loading module pattern",
  46. "Failure loading module track",
  47. "Failure loading module header",
  48. "Failure loading sampleinfo",
  49. "Module format not recognized",
  50. "Module sample format not recognized",
  51. "Synthsounds not supported in MED files",
  52. "Compressed sample is invalid",
  53. /* Driver errors: */
  54. "Sound device not detected",
  55. "Device number out of range",
  56. "Software mixer failure",
  57. "Could not open sound device",
  58. "This driver supports 8 bit linear output only",
  59. "This driver supports 16 bit linear output only",
  60. "This driver supports stereo output only",
  61. "This driver supports uLaw output (8 bit mono, 8 kHz) only",
  62. "Unable to set non-blocking mode for audio device",
  63. /* AudioFile driver errors  */
  64. "Cannot find suitable AudioFile audio port",
  65. /* AIX driver errors */
  66. "Configuration (init step) of audio device failed",
  67. "Configuration (control step) of audio device failed",
  68. "Configuration (start step) of audio device failed",
  69. /* ALSA driver errors */
  70. /* EsounD driver errors */
  71. /* Ultrasound driver errors */
  72. "Ultrasound driver only works in 16 bit stereo 44 KHz",
  73. "Ultrasound card could not be reset",
  74. "Could not start Ultrasound timer",
  75. /* HP driver errors  */
  76. "Unable to select 16bit-linear sample format",
  77. "Could not select requested sample-rate",
  78. "Could not select requested number of channels",
  79. "Unable to select audio output",
  80. "Unable to get audio description",
  81. "Could not set transmission buffer size",
  82. /* Open Sound System driver errors */
  83. "Could not set fragment size",
  84. "Could not set sample size",
  85. "Could not set mono/stereo setting",
  86. "Could not set sample rate",
  87. /* SGI driver errors */
  88. "Unsupported sample rate",
  89. "Hardware does not support 16 bit sound",
  90. "Hardware does not support 8 bit sound",
  91. "Hardware does not support stereo sound",
  92. "Hardware does not support mono sound",
  93. /* Sun driver errors */
  94. "Sound device initialization failed",
  95. /* OS/2 drivers errors */
  96. "Could not set mixing parameters",
  97. "Could not create playback semaphores",
  98. "Could not create playback timer",
  99. "Could not create playback thread",
  100. /* DirectSound driver errors */
  101. "Could not set playback priority",
  102. "Could not create playback buffers",
  103. "Could not set playback format",
  104. "Could not register callback",
  105. "Could not register event",
  106. "Could not create playback thread",
  107. "Could not initialize playback thread",
  108. /* Windows Multimedia API driver errors */
  109. "Invalid device handle",
  110. "The resource is already allocated",
  111. "Invalid device identifier",
  112. "Unsupported output format",
  113. "Unknown error",
  114. /* Macintosh driver errors */
  115. "Unsupported sample rate",
  116. "Could not start playback",
  117. /* Invalid error */
  118. "Invalid error code"
  119. };
  120. MIKMODAPI char *MikMod_strerror(int code)
  121. {
  122. if ((code<0)||(code>MMERR_MAX)) code=MMERR_MAX+1;
  123. return _mm_errmsg[code];
  124. }
  125. /* User installed error callback */
  126. MikMod_handler_t _mm_errorhandler = NULL;
  127. MIKMODAPI int  _mm_errno = 0;
  128. MIKMODAPI BOOL _mm_critical = 0;
  129. MikMod_handler_t _mm_registererrorhandler(MikMod_handler_t proc)
  130. {
  131. MikMod_handler_t oldproc=_mm_errorhandler;
  132. _mm_errorhandler = proc;
  133. return oldproc;
  134. }
  135. MIKMODAPI MikMod_handler_t MikMod_RegisterErrorHandler(MikMod_handler_t proc)
  136. {
  137. MikMod_handler_t result;
  138. MUTEX_LOCK(vars);
  139. result=_mm_registererrorhandler(proc);
  140. MUTEX_UNLOCK(vars);
  141. return result;
  142. }
  143. /* ex:set ts=4: */