seal 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (421) hide show
  1. data/.yardopts +1 -0
  2. data/LICENSE +13 -0
  3. data/README.md +265 -0
  4. data/ext/seal/extconf.rb +45 -0
  5. data/include/al/al.h +724 -0
  6. data/include/al/alc.h +277 -0
  7. data/include/al/efx-presets.h +402 -0
  8. data/include/al/efx.h +758 -0
  9. data/include/mpg123/mpg123.h +1034 -0
  10. data/include/ogg/config_types.h +25 -0
  11. data/include/ogg/ogg.h +210 -0
  12. data/include/ogg/os_types.h +147 -0
  13. data/include/seal.h +23 -0
  14. data/include/seal/buf.h +143 -0
  15. data/include/seal/core.h +95 -0
  16. data/include/seal/efs.h +112 -0
  17. data/include/seal/err.h +93 -0
  18. data/include/seal/fmt.h +58 -0
  19. data/include/seal/listener.h +103 -0
  20. data/include/seal/raw.h +86 -0
  21. data/include/seal/rvb.h +520 -0
  22. data/include/seal/src.h +413 -0
  23. data/include/seal/stream.h +81 -0
  24. data/include/vorbis/codec.h +243 -0
  25. data/include/vorbis/vorbisfile.h +206 -0
  26. data/mpg123/AUTHORS +150 -0
  27. data/mpg123/COPYING +773 -0
  28. data/mpg123/ChangeLog +3 -0
  29. data/mpg123/INSTALL +111 -0
  30. data/mpg123/Makefile.am +99 -0
  31. data/mpg123/Makefile.in +1043 -0
  32. data/mpg123/NEWS +1200 -0
  33. data/mpg123/NEWS.libmpg123 +133 -0
  34. data/mpg123/README +203 -0
  35. data/mpg123/TODO +38 -0
  36. data/mpg123/aclocal.m4 +1168 -0
  37. data/mpg123/build/config.guess +1530 -0
  38. data/mpg123/build/config.sub +1782 -0
  39. data/mpg123/build/depcomp +707 -0
  40. data/mpg123/build/install-sh +527 -0
  41. data/mpg123/build/ltmain.sh +9655 -0
  42. data/mpg123/build/missing +330 -0
  43. data/mpg123/configure +20267 -0
  44. data/mpg123/configure.ac +2178 -0
  45. data/mpg123/doc/ACCURACY +2 -0
  46. data/mpg123/doc/BENCHMARKING +110 -0
  47. data/mpg123/doc/BUGS +3 -0
  48. data/mpg123/doc/CONTACT +17 -0
  49. data/mpg123/doc/LICENSE +22 -0
  50. data/mpg123/doc/Makefile.am +32 -0
  51. data/mpg123/doc/Makefile.in +490 -0
  52. data/mpg123/doc/PATENTS +39 -0
  53. data/mpg123/doc/README.3DNOW +56 -0
  54. data/mpg123/doc/README.gain +171 -0
  55. data/mpg123/doc/README.remote +218 -0
  56. data/mpg123/doc/ROAD_TO_LGPL +270 -0
  57. data/mpg123/doc/THANKS +13 -0
  58. data/mpg123/doc/TODO +63 -0
  59. data/mpg123/doc/doxy_examples.c +21 -0
  60. data/mpg123/doc/doxygen.conf +41 -0
  61. data/mpg123/doc/doxyhead.xhtml +12 -0
  62. data/mpg123/doc/examples/dump_seekindex.c +41 -0
  63. data/mpg123/doc/examples/extract_frames.c +92 -0
  64. data/mpg123/doc/examples/feedseek.c +238 -0
  65. data/mpg123/doc/examples/id3dump.c +178 -0
  66. data/mpg123/doc/examples/mpg123_to_wav.c +118 -0
  67. data/mpg123/doc/examples/mpglib.c +92 -0
  68. data/mpg123/doc/examples/scan.c +47 -0
  69. data/mpg123/doc/libmpg123_speed.txt +84 -0
  70. data/mpg123/equalize.dat +37 -0
  71. data/mpg123/libmpg123.pc.in +11 -0
  72. data/mpg123/m4/addrconfig.m4 +34 -0
  73. data/mpg123/m4/libtool.m4 +7982 -0
  74. data/mpg123/m4/ltoptions.m4 +384 -0
  75. data/mpg123/m4/ltsugar.m4 +123 -0
  76. data/mpg123/m4/ltversion.m4 +23 -0
  77. data/mpg123/m4/lt~obsolete.m4 +98 -0
  78. data/mpg123/makedll.sh +19 -0
  79. data/mpg123/man1/mpg123.1 +512 -0
  80. data/mpg123/mpg123.spec +68 -0
  81. data/mpg123/mpg123.spec.in +68 -0
  82. data/mpg123/ports/MSVC++/2005/libmpg123/libmpg123.vcproj +741 -0
  83. data/mpg123/ports/MSVC++/2008/dump_seekindex/dump_seekindex.vcproj +194 -0
  84. data/mpg123/ports/MSVC++/2008/feedseek/feedseek.vcproj +195 -0
  85. data/mpg123/ports/MSVC++/2008/libmpg123/libmpg123.vcproj +1357 -0
  86. data/mpg123/ports/MSVC++/2008/mpg123.sln +44 -0
  87. data/mpg123/ports/MSVC++/2008/mpglib/mpglib.vcproj +191 -0
  88. data/mpg123/ports/MSVC++/2008/scan/scan.vcproj +195 -0
  89. data/mpg123/ports/MSVC++/2008clr/2008clr.sln +81 -0
  90. data/mpg123/ports/MSVC++/2008clr/examples/ReplaceReaderclr/Program.cs +435 -0
  91. data/mpg123/ports/MSVC++/2008clr/examples/ReplaceReaderclr/Properties/AssemblyInfo.cs +36 -0
  92. data/mpg123/ports/MSVC++/2008clr/examples/ReplaceReaderclr/ReplaceReaderclr.csproj +72 -0
  93. data/mpg123/ports/MSVC++/2008clr/examples/feedseekclr/Program.cs +331 -0
  94. data/mpg123/ports/MSVC++/2008clr/examples/feedseekclr/Properties/AssemblyInfo.cs +36 -0
  95. data/mpg123/ports/MSVC++/2008clr/examples/feedseekclr/feedseekclr.csproj +71 -0
  96. data/mpg123/ports/MSVC++/2008clr/examples/scanclr/Program.cs +79 -0
  97. data/mpg123/ports/MSVC++/2008clr/examples/scanclr/Properties/AssemblyInfo.cs +36 -0
  98. data/mpg123/ports/MSVC++/2008clr/examples/scanclr/scanclr.csproj +70 -0
  99. data/mpg123/ports/MSVC++/2008clr/mpg123clr/AssemblyInfo.cpp +76 -0
  100. data/mpg123/ports/MSVC++/2008clr/mpg123clr/ReadMe.txt +165 -0
  101. data/mpg123/ports/MSVC++/2008clr/mpg123clr/advanced.cpp +91 -0
  102. data/mpg123/ports/MSVC++/2008clr/mpg123clr/advanced.h +130 -0
  103. data/mpg123/ports/MSVC++/2008clr/mpg123clr/dllmain.cpp +19 -0
  104. data/mpg123/ports/MSVC++/2008clr/mpg123clr/enum.h +218 -0
  105. data/mpg123/ports/MSVC++/2008clr/mpg123clr/error.cpp +48 -0
  106. data/mpg123/ports/MSVC++/2008clr/mpg123clr/error.h +134 -0
  107. data/mpg123/ports/MSVC++/2008clr/mpg123clr/id3v1.cpp +92 -0
  108. data/mpg123/ports/MSVC++/2008clr/mpg123clr/id3v1.h +132 -0
  109. data/mpg123/ports/MSVC++/2008clr/mpg123clr/id3v2.cpp +138 -0
  110. data/mpg123/ports/MSVC++/2008clr/mpg123clr/id3v2.h +152 -0
  111. data/mpg123/ports/MSVC++/2008clr/mpg123clr/mpg123clr.cpp +896 -0
  112. data/mpg123/ports/MSVC++/2008clr/mpg123clr/mpg123clr.h +953 -0
  113. data/mpg123/ports/MSVC++/2008clr/mpg123clr/mpg123clr.rc +102 -0
  114. data/mpg123/ports/MSVC++/2008clr/mpg123clr/mpg123clr.vcproj +328 -0
  115. data/mpg123/ports/MSVC++/2008clr/mpg123clr/resource.h +14 -0
  116. data/mpg123/ports/MSVC++/2008clr/mpg123clr/stdafx.cpp +8 -0
  117. data/mpg123/ports/MSVC++/2008clr/mpg123clr/stdafx.h +38 -0
  118. data/mpg123/ports/MSVC++/2008clr/mpg123clr/string.cpp +166 -0
  119. data/mpg123/ports/MSVC++/2008clr/mpg123clr/string.h +265 -0
  120. data/mpg123/ports/MSVC++/2008clr/mpg123clr/targetver.h +24 -0
  121. data/mpg123/ports/MSVC++/2008clr/mpg123clr/text.cpp +67 -0
  122. data/mpg123/ports/MSVC++/2008clr/mpg123clr/text.h +111 -0
  123. data/mpg123/ports/MSVC++/2010/dump_seekindex/dump_seekindex.vcxproj +90 -0
  124. data/mpg123/ports/MSVC++/2010/dump_seekindex/dump_seekindex.vcxproj.filters +6 -0
  125. data/mpg123/ports/MSVC++/2010/feedseek/feedseek.vcxproj +95 -0
  126. data/mpg123/ports/MSVC++/2010/feedseek/feedseek.vcxproj.filters +6 -0
  127. data/mpg123/ports/MSVC++/2010/libmpg123/libmpg123.vcxproj +960 -0
  128. data/mpg123/ports/MSVC++/2010/libmpg123/libmpg123.vcxproj.user +3 -0
  129. data/mpg123/ports/MSVC++/2010/libmpg123/yasm.exe +0 -0
  130. data/mpg123/ports/MSVC++/2010/mpg123.sln +38 -0
  131. data/mpg123/ports/MSVC++/2010/scan/scan.vcxproj +93 -0
  132. data/mpg123/ports/MSVC++/2010/scan/scan.vcxproj.filters +6 -0
  133. data/mpg123/ports/MSVC++/CMP3Stream/INCLUDE/CORE/CORE_FileIn.H +15 -0
  134. data/mpg123/ports/MSVC++/CMP3Stream/INCLUDE/CORE/SourceFilter_MP3.H +139 -0
  135. data/mpg123/ports/MSVC++/CMP3Stream/INCLUDE/IIEP_Def.H +206 -0
  136. data/mpg123/ports/MSVC++/CMP3Stream/INCLUDE/IIEP_FileIn.H +167 -0
  137. data/mpg123/ports/MSVC++/CMP3Stream/README +4 -0
  138. data/mpg123/ports/MSVC++/CMP3Stream/SOURCE/CORE_FileIn.CPP +462 -0
  139. data/mpg123/ports/MSVC++/CMP3Stream/SOURCE/CORE_Log.CPP +122 -0
  140. data/mpg123/ports/MSVC++/CMP3Stream/SOURCE/CORE_Mutex.CPP +35 -0
  141. data/mpg123/ports/MSVC++/CMP3Stream/SOURCE/SourceFilter_MP3Stream.CPP +586 -0
  142. data/mpg123/ports/MSVC++/CMP3Stream/libMPG123/PLACE_LIBMPG123_SOURCES_HERE +0 -0
  143. data/mpg123/ports/MSVC++/CMP3Stream/libMPG123/libMPG123.vcproj +245 -0
  144. data/mpg123/ports/MSVC++/config.h +35 -0
  145. data/mpg123/ports/MSVC++/examples/feedseek.c +240 -0
  146. data/mpg123/ports/MSVC++/examples/scan.c +47 -0
  147. data/mpg123/ports/MSVC++/mpg123.h +46 -0
  148. data/mpg123/ports/MSVC++/msvc.c +59 -0
  149. data/mpg123/ports/README +26 -0
  150. data/mpg123/ports/Sony_PSP/Makefile.psp +38 -0
  151. data/mpg123/ports/Sony_PSP/README +11 -0
  152. data/mpg123/ports/Sony_PSP/config.h +368 -0
  153. data/mpg123/ports/Sony_PSP/readers.c.patch +2 -0
  154. data/mpg123/ports/Xcode/config.h +197 -0
  155. data/mpg123/ports/Xcode/mpg123.h +17 -0
  156. data/mpg123/ports/Xcode/mpg123.xcodeproj/project.pbxproj +670 -0
  157. data/mpg123/ports/mpg123_.pas +478 -0
  158. data/mpg123/scripts/benchmark-cpu.pl +56 -0
  159. data/mpg123/scripts/tag_lyrics.py +76 -0
  160. data/mpg123/src/Makefile.am +186 -0
  161. data/mpg123/src/Makefile.in +1097 -0
  162. data/mpg123/src/audio.c +725 -0
  163. data/mpg123/src/audio.h +106 -0
  164. data/mpg123/src/buffer.c +312 -0
  165. data/mpg123/src/buffer.h +45 -0
  166. data/mpg123/src/common.c +240 -0
  167. data/mpg123/src/common.h +29 -0
  168. data/mpg123/src/config.h.in +436 -0
  169. data/mpg123/src/control_generic.c +809 -0
  170. data/mpg123/src/equalizer.c +48 -0
  171. data/mpg123/src/genre.c +271 -0
  172. data/mpg123/src/genre.h +15 -0
  173. data/mpg123/src/getlopt.c +148 -0
  174. data/mpg123/src/getlopt.h +77 -0
  175. data/mpg123/src/httpget.c +700 -0
  176. data/mpg123/src/httpget.h +66 -0
  177. data/mpg123/src/legacy_module.c +74 -0
  178. data/mpg123/src/libmpg123/Makefile.am +141 -0
  179. data/mpg123/src/libmpg123/Makefile.in +919 -0
  180. data/mpg123/src/libmpg123/compat.c +138 -0
  181. data/mpg123/src/libmpg123/compat.h +178 -0
  182. data/mpg123/src/libmpg123/dct36_3dnow.S +505 -0
  183. data/mpg123/src/libmpg123/dct36_3dnowext.S +512 -0
  184. data/mpg123/src/libmpg123/dct64.c +174 -0
  185. data/mpg123/src/libmpg123/dct64_3dnow.S +712 -0
  186. data/mpg123/src/libmpg123/dct64_3dnowext.S +714 -0
  187. data/mpg123/src/libmpg123/dct64_altivec.c +315 -0
  188. data/mpg123/src/libmpg123/dct64_i386.c +336 -0
  189. data/mpg123/src/libmpg123/dct64_i486.c +342 -0
  190. data/mpg123/src/libmpg123/dct64_mmx.S +811 -0
  191. data/mpg123/src/libmpg123/dct64_neon.S +297 -0
  192. data/mpg123/src/libmpg123/dct64_neon_float.S +270 -0
  193. data/mpg123/src/libmpg123/dct64_sse.S +454 -0
  194. data/mpg123/src/libmpg123/dct64_sse_float.S +401 -0
  195. data/mpg123/src/libmpg123/dct64_x86_64.S +464 -0
  196. data/mpg123/src/libmpg123/dct64_x86_64_float.S +426 -0
  197. data/mpg123/src/libmpg123/debug.h +171 -0
  198. data/mpg123/src/libmpg123/decode.h +268 -0
  199. data/mpg123/src/libmpg123/dither.c +119 -0
  200. data/mpg123/src/libmpg123/dither.h +23 -0
  201. data/mpg123/src/libmpg123/equalizer.c +17 -0
  202. data/mpg123/src/libmpg123/equalizer_3dnow.S +70 -0
  203. data/mpg123/src/libmpg123/feature.c +106 -0
  204. data/mpg123/src/libmpg123/format.c +521 -0
  205. data/mpg123/src/libmpg123/frame.c +1046 -0
  206. data/mpg123/src/libmpg123/frame.h +410 -0
  207. data/mpg123/src/libmpg123/gapless.h +119 -0
  208. data/mpg123/src/libmpg123/getbits.h +100 -0
  209. data/mpg123/src/libmpg123/getcpuflags.S +91 -0
  210. data/mpg123/src/libmpg123/getcpuflags.h +47 -0
  211. data/mpg123/src/libmpg123/huffman.h +340 -0
  212. data/mpg123/src/libmpg123/icy.c +32 -0
  213. data/mpg123/src/libmpg123/icy.h +38 -0
  214. data/mpg123/src/libmpg123/icy2utf8.c +438 -0
  215. data/mpg123/src/libmpg123/icy2utf8.h +10 -0
  216. data/mpg123/src/libmpg123/id3.c +999 -0
  217. data/mpg123/src/libmpg123/id3.h +43 -0
  218. data/mpg123/src/libmpg123/index.c +134 -0
  219. data/mpg123/src/libmpg123/index.h +59 -0
  220. data/mpg123/src/libmpg123/intsym.h +256 -0
  221. data/mpg123/src/libmpg123/l12_integer_tables.h +278 -0
  222. data/mpg123/src/libmpg123/l2tables.h +164 -0
  223. data/mpg123/src/libmpg123/l3_integer_tables.h +1002 -0
  224. data/mpg123/src/libmpg123/layer1.c +155 -0
  225. data/mpg123/src/libmpg123/layer2.c +371 -0
  226. data/mpg123/src/libmpg123/layer3.c +2053 -0
  227. data/mpg123/src/libmpg123/lfs_alias.c +252 -0
  228. data/mpg123/src/libmpg123/lfs_wrap.c +751 -0
  229. data/mpg123/src/libmpg123/libmpg123.c +1607 -0
  230. data/mpg123/src/libmpg123/mangle.h +74 -0
  231. data/mpg123/src/libmpg123/mpeghead.h +87 -0
  232. data/mpg123/src/libmpg123/mpg123.h.in +1075 -0
  233. data/mpg123/src/libmpg123/mpg123lib_intern.h +338 -0
  234. data/mpg123/src/libmpg123/ntom.c +148 -0
  235. data/mpg123/src/libmpg123/optimize.c +964 -0
  236. data/mpg123/src/libmpg123/optimize.h +219 -0
  237. data/mpg123/src/libmpg123/parse.c +1179 -0
  238. data/mpg123/src/libmpg123/parse.h +25 -0
  239. data/mpg123/src/libmpg123/reader.h +137 -0
  240. data/mpg123/src/libmpg123/readers.c +1235 -0
  241. data/mpg123/src/libmpg123/sample.h +152 -0
  242. data/mpg123/src/libmpg123/stringbuf.c +163 -0
  243. data/mpg123/src/libmpg123/synth.c +816 -0
  244. data/mpg123/src/libmpg123/synth.h +196 -0
  245. data/mpg123/src/libmpg123/synth_3dnow.S +318 -0
  246. data/mpg123/src/libmpg123/synth_3dnowext.S +6 -0
  247. data/mpg123/src/libmpg123/synth_8bit.c +142 -0
  248. data/mpg123/src/libmpg123/synth_8bit.h +86 -0
  249. data/mpg123/src/libmpg123/synth_altivec.c +1057 -0
  250. data/mpg123/src/libmpg123/synth_arm.S +271 -0
  251. data/mpg123/src/libmpg123/synth_arm_accurate.S +287 -0
  252. data/mpg123/src/libmpg123/synth_i486.c +252 -0
  253. data/mpg123/src/libmpg123/synth_i586.S +336 -0
  254. data/mpg123/src/libmpg123/synth_i586_dither.S +375 -0
  255. data/mpg123/src/libmpg123/synth_mmx.S +125 -0
  256. data/mpg123/src/libmpg123/synth_mono.h +64 -0
  257. data/mpg123/src/libmpg123/synth_neon.S +123 -0
  258. data/mpg123/src/libmpg123/synth_neon_accurate.S +173 -0
  259. data/mpg123/src/libmpg123/synth_neon_float.S +149 -0
  260. data/mpg123/src/libmpg123/synth_neon_s32.S +168 -0
  261. data/mpg123/src/libmpg123/synth_ntom.h +213 -0
  262. data/mpg123/src/libmpg123/synth_real.c +404 -0
  263. data/mpg123/src/libmpg123/synth_s32.c +411 -0
  264. data/mpg123/src/libmpg123/synth_sse.S +6 -0
  265. data/mpg123/src/libmpg123/synth_sse3d.h +246 -0
  266. data/mpg123/src/libmpg123/synth_sse_accurate.S +294 -0
  267. data/mpg123/src/libmpg123/synth_sse_float.S +241 -0
  268. data/mpg123/src/libmpg123/synth_sse_s32.S +306 -0
  269. data/mpg123/src/libmpg123/synth_stereo_neon.S +175 -0
  270. data/mpg123/src/libmpg123/synth_stereo_neon_accurate.S +262 -0
  271. data/mpg123/src/libmpg123/synth_stereo_neon_float.S +220 -0
  272. data/mpg123/src/libmpg123/synth_stereo_neon_s32.S +247 -0
  273. data/mpg123/src/libmpg123/synth_stereo_sse_accurate.S +508 -0
  274. data/mpg123/src/libmpg123/synth_stereo_sse_float.S +416 -0
  275. data/mpg123/src/libmpg123/synth_stereo_sse_s32.S +540 -0
  276. data/mpg123/src/libmpg123/synth_stereo_x86_64.S +335 -0
  277. data/mpg123/src/libmpg123/synth_stereo_x86_64_accurate.S +454 -0
  278. data/mpg123/src/libmpg123/synth_stereo_x86_64_float.S +396 -0
  279. data/mpg123/src/libmpg123/synth_stereo_x86_64_s32.S +473 -0
  280. data/mpg123/src/libmpg123/synth_x86_64.S +244 -0
  281. data/mpg123/src/libmpg123/synth_x86_64_accurate.S +301 -0
  282. data/mpg123/src/libmpg123/synth_x86_64_float.S +259 -0
  283. data/mpg123/src/libmpg123/synth_x86_64_s32.S +312 -0
  284. data/mpg123/src/libmpg123/synths.h +52 -0
  285. data/mpg123/src/libmpg123/tabinit.c +294 -0
  286. data/mpg123/src/libmpg123/tabinit_mmx.S +210 -0
  287. data/mpg123/src/libmpg123/testcpu.c +35 -0
  288. data/mpg123/src/libmpg123/true.h +14 -0
  289. data/mpg123/src/local.c +63 -0
  290. data/mpg123/src/local.h +21 -0
  291. data/mpg123/src/metaprint.c +373 -0
  292. data/mpg123/src/metaprint.h +17 -0
  293. data/mpg123/src/module.c +306 -0
  294. data/mpg123/src/module.h +48 -0
  295. data/mpg123/src/mpg123.c +1405 -0
  296. data/mpg123/src/mpg123app.h +171 -0
  297. data/mpg123/src/output/Makefile.am +213 -0
  298. data/mpg123/src/output/Makefile.in +1238 -0
  299. data/mpg123/src/output/aix.c +300 -0
  300. data/mpg123/src/output/alib.c +209 -0
  301. data/mpg123/src/output/alsa.c +297 -0
  302. data/mpg123/src/output/arts.c +117 -0
  303. data/mpg123/src/output/coreaudio.c +370 -0
  304. data/mpg123/src/output/dummy.c +78 -0
  305. data/mpg123/src/output/esd.c +167 -0
  306. data/mpg123/src/output/hp.c +184 -0
  307. data/mpg123/src/output/jack.c +450 -0
  308. data/mpg123/src/output/mint.c +197 -0
  309. data/mpg123/src/output/nas.c +335 -0
  310. data/mpg123/src/output/openal.c +197 -0
  311. data/mpg123/src/output/os2.c +665 -0
  312. data/mpg123/src/output/oss.c +319 -0
  313. data/mpg123/src/output/portaudio.c +255 -0
  314. data/mpg123/src/output/pulse.c +164 -0
  315. data/mpg123/src/output/sdl.c +206 -0
  316. data/mpg123/src/output/sgi.c +213 -0
  317. data/mpg123/src/output/sndio.c +161 -0
  318. data/mpg123/src/output/sun.c +281 -0
  319. data/mpg123/src/output/win32.c +229 -0
  320. data/mpg123/src/playlist.c +596 -0
  321. data/mpg123/src/playlist.h +52 -0
  322. data/mpg123/src/resolver.c +319 -0
  323. data/mpg123/src/resolver.h +25 -0
  324. data/mpg123/src/sfifo.c +146 -0
  325. data/mpg123/src/sfifo.h +95 -0
  326. data/mpg123/src/streamdump.c +74 -0
  327. data/mpg123/src/streamdump.h +20 -0
  328. data/mpg123/src/term.c +479 -0
  329. data/mpg123/src/term.h +81 -0
  330. data/mpg123/src/tests/noise.c +52 -0
  331. data/mpg123/src/tests/plain_id3.c +109 -0
  332. data/mpg123/src/tests/seek_accuracy.c +261 -0
  333. data/mpg123/src/tests/seek_whence.c +56 -0
  334. data/mpg123/src/tests/testtext.h +34 -0
  335. data/mpg123/src/tests/text.c +80 -0
  336. data/mpg123/src/wav.c +464 -0
  337. data/mpg123/src/wavhead.h +68 -0
  338. data/mpg123/src/win32_net.c +599 -0
  339. data/mpg123/src/win32_support.c +191 -0
  340. data/mpg123/src/win32_support.h +152 -0
  341. data/mpg123/src/xfermem.c +321 -0
  342. data/mpg123/src/xfermem.h +74 -0
  343. data/mpg123/windows-builds.sh +137 -0
  344. data/msvc/lib/OpenAL32.lib +0 -0
  345. data/spec/fixtures/heal.ogg +0 -0
  346. data/spec/fixtures/tone_up.wav +0 -0
  347. data/spec/seal/buffer_spec.rb +37 -0
  348. data/spec/seal/core_spec.rb +29 -0
  349. data/spec/seal/effect_slot_spec.rb +38 -0
  350. data/spec/seal/listener_spec.rb +33 -0
  351. data/spec/seal/reverb_spec.rb +51 -0
  352. data/spec/seal/source_spec.rb +370 -0
  353. data/spec/seal/stream_spec.rb +38 -0
  354. data/spec/spec_helper.rb +45 -0
  355. data/spec/support/attribute_examples.rb +75 -0
  356. data/spec/support/audio_object_with_format.rb +27 -0
  357. data/spec/support/movable_object.rb +22 -0
  358. data/src/libogg/bitwise.c +857 -0
  359. data/src/libogg/framing.c +2093 -0
  360. data/src/libvorbis/backends.h +144 -0
  361. data/src/libvorbis/bitrate.c +253 -0
  362. data/src/libvorbis/bitrate.h +59 -0
  363. data/src/libvorbis/block.c +1046 -0
  364. data/src/libvorbis/codebook.c +484 -0
  365. data/src/libvorbis/codebook.h +119 -0
  366. data/src/libvorbis/codec_internal.h +167 -0
  367. data/src/libvorbis/envelope.c +375 -0
  368. data/src/libvorbis/envelope.h +80 -0
  369. data/src/libvorbis/floor0.c +221 -0
  370. data/src/libvorbis/floor1.c +1100 -0
  371. data/src/libvorbis/highlevel.h +58 -0
  372. data/src/libvorbis/info.c +668 -0
  373. data/src/libvorbis/lookup.c +94 -0
  374. data/src/libvorbis/lookup.h +32 -0
  375. data/src/libvorbis/lookup_data.h +192 -0
  376. data/src/libvorbis/lpc.c +160 -0
  377. data/src/libvorbis/lpc.h +29 -0
  378. data/src/libvorbis/lsp.c +456 -0
  379. data/src/libvorbis/lsp.h +28 -0
  380. data/src/libvorbis/mapping0.c +816 -0
  381. data/src/libvorbis/masking.h +785 -0
  382. data/src/libvorbis/mdct.c +563 -0
  383. data/src/libvorbis/mdct.h +71 -0
  384. data/src/libvorbis/misc.h +57 -0
  385. data/src/libvorbis/os.h +186 -0
  386. data/src/libvorbis/psy.c +1206 -0
  387. data/src/libvorbis/psy.h +154 -0
  388. data/src/libvorbis/registry.c +45 -0
  389. data/src/libvorbis/registry.h +32 -0
  390. data/src/libvorbis/res0.c +889 -0
  391. data/src/libvorbis/scales.h +90 -0
  392. data/src/libvorbis/sharedbook.c +579 -0
  393. data/src/libvorbis/smallft.c +1255 -0
  394. data/src/libvorbis/smallft.h +34 -0
  395. data/src/libvorbis/synthesis.c +184 -0
  396. data/src/libvorbis/vorbisfile.c +2337 -0
  397. data/src/libvorbis/window.c +2135 -0
  398. data/src/libvorbis/window.h +26 -0
  399. data/src/rubyext.c +2329 -0
  400. data/src/seal/buf.c +124 -0
  401. data/src/seal/core.c +283 -0
  402. data/src/seal/efs.c +74 -0
  403. data/src/seal/err.c +118 -0
  404. data/src/seal/fmt.c +86 -0
  405. data/src/seal/listener.c +111 -0
  406. data/src/seal/mpg.c +174 -0
  407. data/src/seal/mpg.h +24 -0
  408. data/src/seal/ov.c +180 -0
  409. data/src/seal/ov.h +22 -0
  410. data/src/seal/raw.c +59 -0
  411. data/src/seal/reader.c +102 -0
  412. data/src/seal/reader.h +59 -0
  413. data/src/seal/rvb.c +368 -0
  414. data/src/seal/src.c +654 -0
  415. data/src/seal/stream.c +109 -0
  416. data/src/seal/threading.c +66 -0
  417. data/src/seal/threading.h +20 -0
  418. data/src/seal/wav.c +297 -0
  419. data/src/seal/wav.h +23 -0
  420. data/src/win32api.rb +29 -0
  421. metadata +563 -0
@@ -0,0 +1,155 @@
1
+ /*
2
+ layer1.c: the layer 1 decoder
3
+
4
+ copyright 1995-2009 by the mpg123 project - free software under the terms of the LGPL 2.1
5
+ see COPYING and AUTHORS files in distribution or http://mpg123.org
6
+ initially written by Michael Hipp
7
+
8
+ may have a few bugs after last optimization ...
9
+ */
10
+
11
+ #include "mpg123lib_intern.h"
12
+ #include "getbits.h"
13
+
14
+ static void I_step_one(unsigned int balloc[], unsigned int scale_index[2][SBLIMIT],mpg123_handle *fr)
15
+ {
16
+ unsigned int *ba=balloc;
17
+ unsigned int *sca = (unsigned int *) scale_index;
18
+
19
+ if(fr->stereo == 2)
20
+ {
21
+ int i;
22
+ int jsbound = fr->jsbound;
23
+ for(i=0;i<jsbound;i++)
24
+ {
25
+ *ba++ = getbits(fr, 4);
26
+ *ba++ = getbits(fr, 4);
27
+ }
28
+ for(i=jsbound;i<SBLIMIT;i++) *ba++ = getbits(fr, 4);
29
+
30
+ ba = balloc;
31
+
32
+ for(i=0;i<jsbound;i++)
33
+ {
34
+ if ((*ba++))
35
+ *sca++ = getbits(fr, 6);
36
+ if ((*ba++))
37
+ *sca++ = getbits(fr, 6);
38
+ }
39
+ for (i=jsbound;i<SBLIMIT;i++)
40
+ if((*ba++))
41
+ {
42
+ *sca++ = getbits(fr, 6);
43
+ *sca++ = getbits(fr, 6);
44
+ }
45
+ }
46
+ else
47
+ {
48
+ int i;
49
+ for(i=0;i<SBLIMIT;i++) *ba++ = getbits(fr, 4);
50
+
51
+ ba = balloc;
52
+ for (i=0;i<SBLIMIT;i++)
53
+ if ((*ba++))
54
+ *sca++ = getbits(fr, 6);
55
+ }
56
+ }
57
+
58
+ static void I_step_two(real fraction[2][SBLIMIT],unsigned int balloc[2*SBLIMIT], unsigned int scale_index[2][SBLIMIT],mpg123_handle *fr)
59
+ {
60
+ int i,n;
61
+ int smpb[2*SBLIMIT]; /* values: 0-65535 */
62
+ int *sample;
63
+ register unsigned int *ba;
64
+ register unsigned int *sca = (unsigned int *) scale_index;
65
+
66
+ if(fr->stereo == 2)
67
+ {
68
+ int jsbound = fr->jsbound;
69
+ register real *f0 = fraction[0];
70
+ register real *f1 = fraction[1];
71
+ ba = balloc;
72
+ for(sample=smpb,i=0;i<jsbound;i++)
73
+ {
74
+ if((n = *ba++)) *sample++ = getbits(fr, n+1);
75
+
76
+ if((n = *ba++)) *sample++ = getbits(fr, n+1);
77
+ }
78
+ for(i=jsbound;i<SBLIMIT;i++)
79
+ if((n = *ba++))
80
+ *sample++ = getbits(fr, n+1);
81
+
82
+ ba = balloc;
83
+ for(sample=smpb,i=0;i<jsbound;i++)
84
+ {
85
+ if((n=*ba++))
86
+ *f0++ = REAL_MUL_SCALE_LAYER12(DOUBLE_TO_REAL_15( ((-1)<<n) + (*sample++) + 1), fr->muls[n+1][*sca++]);
87
+ else *f0++ = DOUBLE_TO_REAL(0.0);
88
+
89
+ if((n=*ba++))
90
+ *f1++ = REAL_MUL_SCALE_LAYER12(DOUBLE_TO_REAL_15( ((-1)<<n) + (*sample++) + 1), fr->muls[n+1][*sca++]);
91
+ else *f1++ = DOUBLE_TO_REAL(0.0);
92
+ }
93
+ for(i=jsbound;i<SBLIMIT;i++)
94
+ {
95
+ if((n=*ba++))
96
+ {
97
+ real samp = DOUBLE_TO_REAL_15( ((-1)<<n) + (*sample++) + 1);
98
+ *f0++ = REAL_MUL_SCALE_LAYER12(samp, fr->muls[n+1][*sca++]);
99
+ *f1++ = REAL_MUL_SCALE_LAYER12(samp, fr->muls[n+1][*sca++]);
100
+ }
101
+ else *f0++ = *f1++ = DOUBLE_TO_REAL(0.0);
102
+ }
103
+ for(i=fr->down_sample_sblimit;i<32;i++)
104
+ fraction[0][i] = fraction[1][i] = 0.0;
105
+ }
106
+ else
107
+ {
108
+ register real *f0 = fraction[0];
109
+ ba = balloc;
110
+ for(sample=smpb,i=0;i<SBLIMIT;i++)
111
+ if ((n = *ba++))
112
+ *sample++ = getbits(fr, n+1);
113
+
114
+ ba = balloc;
115
+ for(sample=smpb,i=0;i<SBLIMIT;i++)
116
+ {
117
+ if((n=*ba++))
118
+ *f0++ = REAL_MUL_SCALE_LAYER12(DOUBLE_TO_REAL_15( ((-1)<<n) + (*sample++) + 1), fr->muls[n+1][*sca++]);
119
+ else *f0++ = DOUBLE_TO_REAL(0.0);
120
+ }
121
+ for(i=fr->down_sample_sblimit;i<32;i++)
122
+ fraction[0][i] = DOUBLE_TO_REAL(0.0);
123
+ }
124
+ }
125
+
126
+ int do_layer1(mpg123_handle *fr)
127
+ {
128
+ int clip=0;
129
+ int i,stereo = fr->stereo;
130
+ unsigned int balloc[2*SBLIMIT];
131
+ unsigned int scale_index[2][SBLIMIT];
132
+ real (*fraction)[SBLIMIT] = fr->layer1.fraction; /* fraction[2][SBLIMIT] */
133
+ int single = fr->single;
134
+
135
+ fr->jsbound = (fr->mode == MPG_MD_JOINT_STEREO) ? (fr->mode_ext<<2)+4 : 32;
136
+
137
+ if(stereo == 1 || single == SINGLE_MIX) /* I don't see mixing handled here */
138
+ single = SINGLE_LEFT;
139
+
140
+ I_step_one(balloc,scale_index,fr);
141
+
142
+ for(i=0;i<SCALE_BLOCK;i++)
143
+ {
144
+ I_step_two(fraction,balloc,scale_index,fr);
145
+
146
+ if(single != SINGLE_STEREO)
147
+ clip += (fr->synth_mono)(fraction[single], fr);
148
+ else
149
+ clip += (fr->synth_stereo)(fraction[0], fraction[1], fr);
150
+ }
151
+
152
+ return clip;
153
+ }
154
+
155
+
@@ -0,0 +1,371 @@
1
+ /*
2
+ layer2.c: the layer 2 decoder, root of mpg123
3
+
4
+ copyright 1994-2009 by the mpg123 project - free software under the terms of the LGPL 2.1
5
+ see COPYING and AUTHORS files in distribution or http://mpg123.org
6
+ initially written by Michael Hipp
7
+
8
+ mpg123 started as mp2 decoder a long time ago...
9
+ part of this file is required for layer 1, too.
10
+ */
11
+
12
+
13
+ #include "mpg123lib_intern.h"
14
+ #ifndef NO_LAYER2
15
+ #include "l2tables.h"
16
+ #endif
17
+ #include "getbits.h"
18
+
19
+ #ifndef NO_LAYER12 /* Stuff needed for layer I and II. */
20
+
21
+ static int grp_3tab[32 * 3] = { 0, }; /* used: 27 */
22
+ static int grp_5tab[128 * 3] = { 0, }; /* used: 125 */
23
+ static int grp_9tab[1024 * 3] = { 0, }; /* used: 729 */
24
+
25
+ #if defined(REAL_IS_FIXED) && defined(PRECALC_TABLES)
26
+ #include "l12_integer_tables.h"
27
+ #else
28
+ static const double mulmul[27] =
29
+ {
30
+ 0.0 , -2.0/3.0 , 2.0/3.0 ,
31
+ 2.0/7.0 , 2.0/15.0 , 2.0/31.0, 2.0/63.0 , 2.0/127.0 , 2.0/255.0 ,
32
+ 2.0/511.0 , 2.0/1023.0 , 2.0/2047.0 , 2.0/4095.0 , 2.0/8191.0 ,
33
+ 2.0/16383.0 , 2.0/32767.0 , 2.0/65535.0 ,
34
+ -4.0/5.0 , -2.0/5.0 , 2.0/5.0, 4.0/5.0 ,
35
+ -8.0/9.0 , -4.0/9.0 , -2.0/9.0 , 2.0/9.0 , 4.0/9.0 , 8.0/9.0
36
+ };
37
+ #endif
38
+
39
+ void init_layer12(void)
40
+ {
41
+ const int base[3][9] =
42
+ {
43
+ { 1 , 0, 2 , } ,
44
+ { 17, 18, 0 , 19, 20 , } ,
45
+ { 21, 1, 22, 23, 0, 24, 25, 2, 26 }
46
+ };
47
+ int i,j,k,l,len;
48
+ const int tablen[3] = { 3 , 5 , 9 };
49
+ int *itable;
50
+ int *tables[3] = { grp_3tab , grp_5tab , grp_9tab };
51
+
52
+ for(i=0;i<3;i++)
53
+ {
54
+ itable = tables[i];
55
+ len = tablen[i];
56
+ for(j=0;j<len;j++)
57
+ for(k=0;k<len;k++)
58
+ for(l=0;l<len;l++)
59
+ {
60
+ *itable++ = base[i][l];
61
+ *itable++ = base[i][k];
62
+ *itable++ = base[i][j];
63
+ }
64
+ }
65
+ }
66
+
67
+ void init_layer12_stuff(mpg123_handle *fr, real* (*init_table)(mpg123_handle *fr, real *table, int m))
68
+ {
69
+ int k;
70
+ real *table;
71
+ for(k=0;k<27;k++)
72
+ {
73
+ table = init_table(fr, fr->muls[k], k);
74
+ *table++ = 0.0;
75
+ }
76
+ }
77
+
78
+ real* init_layer12_table(mpg123_handle *fr, real *table, int m)
79
+ {
80
+ #if defined(REAL_IS_FIXED) && defined(PRECALC_TABLES)
81
+ int i;
82
+ for(i=0;i<63;i++)
83
+ *table++ = layer12_table[m][i];
84
+ #else
85
+ int i,j;
86
+ for(j=3,i=0;i<63;i++,j--)
87
+ *table++ = DOUBLE_TO_REAL_SCALE_LAYER12(mulmul[m] * pow(2.0,(double) j / 3.0));
88
+ #endif
89
+
90
+ return table;
91
+ }
92
+
93
+ #ifdef OPT_MMXORSSE
94
+ real* init_layer12_table_mmx(mpg123_handle *fr, real *table, int m)
95
+ {
96
+ int i,j;
97
+ if(!fr->p.down_sample)
98
+ {
99
+ for(j=3,i=0;i<63;i++,j--)
100
+ *table++ = DOUBLE_TO_REAL(16384 * mulmul[m] * pow(2.0,(double) j / 3.0));
101
+ }
102
+ else
103
+ {
104
+ for(j=3,i=0;i<63;i++,j--)
105
+ *table++ = DOUBLE_TO_REAL(mulmul[m] * pow(2.0,(double) j / 3.0));
106
+ }
107
+ return table;
108
+ }
109
+ #endif
110
+
111
+ #endif /* NO_LAYER12 */
112
+
113
+ /* The rest is the actual decoding of layer II data. */
114
+
115
+ #ifndef NO_LAYER2
116
+
117
+ static void II_step_one(unsigned int *bit_alloc,int *scale,mpg123_handle *fr)
118
+ {
119
+ int stereo = fr->stereo-1;
120
+ int sblimit = fr->II_sblimit;
121
+ int jsbound = fr->jsbound;
122
+ int sblimit2 = fr->II_sblimit<<stereo;
123
+ const struct al_table *alloc1 = fr->alloc;
124
+ int i;
125
+ unsigned int scfsi_buf[64];
126
+ unsigned int *scfsi,*bita;
127
+ int sc,step;
128
+
129
+ bita = bit_alloc;
130
+ if(stereo)
131
+ {
132
+ for(i=jsbound;i;i--,alloc1+=(1<<step))
133
+ {
134
+ step=alloc1->bits;
135
+ *bita++ = (char) getbits(fr, step);
136
+ *bita++ = (char) getbits(fr, step);
137
+ }
138
+ for(i=sblimit-jsbound;i;i--,alloc1+=(1<<step))
139
+ {
140
+ step=alloc1->bits;
141
+ bita[0] = (char) getbits(fr, step);
142
+ bita[1] = bita[0];
143
+ bita+=2;
144
+ }
145
+ bita = bit_alloc;
146
+ scfsi=scfsi_buf;
147
+
148
+ for(i=sblimit2;i;i--)
149
+ if(*bita++) *scfsi++ = (char) getbits_fast(fr, 2);
150
+ }
151
+ else /* mono */
152
+ {
153
+ for(i=sblimit;i;i--,alloc1+=(1<<step))
154
+ {
155
+ step=alloc1->bits;
156
+ *bita++ = (char) getbits(fr, step);
157
+ }
158
+ bita = bit_alloc;
159
+ scfsi=scfsi_buf;
160
+ for(i=sblimit;i;i--)
161
+ if(*bita++) *scfsi++ = (char) getbits_fast(fr, 2);
162
+ }
163
+
164
+ bita = bit_alloc;
165
+ scfsi=scfsi_buf;
166
+ for(i=sblimit2;i;i--)
167
+ if(*bita++)
168
+ switch(*scfsi++)
169
+ {
170
+ case 0:
171
+ *scale++ = getbits_fast(fr, 6);
172
+ *scale++ = getbits_fast(fr, 6);
173
+ *scale++ = getbits_fast(fr, 6);
174
+ break;
175
+ case 1 :
176
+ *scale++ = sc = getbits_fast(fr, 6);
177
+ *scale++ = sc;
178
+ *scale++ = getbits_fast(fr, 6);
179
+ break;
180
+ case 2:
181
+ *scale++ = sc = getbits_fast(fr, 6);
182
+ *scale++ = sc;
183
+ *scale++ = sc;
184
+ break;
185
+ default: /* case 3 */
186
+ *scale++ = getbits_fast(fr, 6);
187
+ *scale++ = sc = getbits_fast(fr, 6);
188
+ *scale++ = sc;
189
+ break;
190
+ }
191
+ }
192
+
193
+
194
+ static void II_step_two(unsigned int *bit_alloc,real fraction[2][4][SBLIMIT],int *scale,mpg123_handle *fr,int x1)
195
+ {
196
+ int i,j,k,ba;
197
+ int stereo = fr->stereo;
198
+ int sblimit = fr->II_sblimit;
199
+ int jsbound = fr->jsbound;
200
+ const struct al_table *alloc2,*alloc1 = fr->alloc;
201
+ unsigned int *bita=bit_alloc;
202
+ int d1,step;
203
+
204
+ for(i=0;i<jsbound;i++,alloc1+=(1<<step))
205
+ {
206
+ step = alloc1->bits;
207
+ for(j=0;j<stereo;j++)
208
+ {
209
+ if( (ba=*bita++) )
210
+ {
211
+ k=(alloc2 = alloc1+ba)->bits;
212
+ if( (d1=alloc2->d) < 0)
213
+ {
214
+ real cm=fr->muls[k][scale[x1]];
215
+ fraction[j][0][i] = REAL_MUL_SCALE_LAYER12(DOUBLE_TO_REAL_15((int)getbits(fr, k) + d1), cm);
216
+ fraction[j][1][i] = REAL_MUL_SCALE_LAYER12(DOUBLE_TO_REAL_15((int)getbits(fr, k) + d1), cm);
217
+ fraction[j][2][i] = REAL_MUL_SCALE_LAYER12(DOUBLE_TO_REAL_15((int)getbits(fr, k) + d1), cm);
218
+ }
219
+ else
220
+ {
221
+ const int *table[] = { 0,0,0,grp_3tab,0,grp_5tab,0,0,0,grp_9tab };
222
+ unsigned int idx,*tab,m=scale[x1];
223
+ idx = (unsigned int) getbits(fr, k);
224
+ tab = (unsigned int *) (table[d1] + idx + idx + idx);
225
+ fraction[j][0][i] = REAL_SCALE_LAYER12(fr->muls[*tab++][m]);
226
+ fraction[j][1][i] = REAL_SCALE_LAYER12(fr->muls[*tab++][m]);
227
+ fraction[j][2][i] = REAL_SCALE_LAYER12(fr->muls[*tab][m]);
228
+ }
229
+ scale+=3;
230
+ }
231
+ else
232
+ fraction[j][0][i] = fraction[j][1][i] = fraction[j][2][i] = DOUBLE_TO_REAL(0.0);
233
+ }
234
+ }
235
+
236
+ for(i=jsbound;i<sblimit;i++,alloc1+=(1<<step))
237
+ {
238
+ step = alloc1->bits;
239
+ bita++; /* channel 1 and channel 2 bitalloc are the same */
240
+ if( (ba=*bita++) )
241
+ {
242
+ k=(alloc2 = alloc1+ba)->bits;
243
+ if( (d1=alloc2->d) < 0)
244
+ {
245
+ real cm;
246
+ cm=fr->muls[k][scale[x1+3]];
247
+ fraction[0][0][i] = DOUBLE_TO_REAL_15((int)getbits(fr, k) + d1);
248
+ fraction[0][1][i] = DOUBLE_TO_REAL_15((int)getbits(fr, k) + d1);
249
+ fraction[0][2][i] = DOUBLE_TO_REAL_15((int)getbits(fr, k) + d1);
250
+ fraction[1][0][i] = REAL_MUL_SCALE_LAYER12(fraction[0][0][i], cm);
251
+ fraction[1][1][i] = REAL_MUL_SCALE_LAYER12(fraction[0][1][i], cm);
252
+ fraction[1][2][i] = REAL_MUL_SCALE_LAYER12(fraction[0][2][i], cm);
253
+ cm=fr->muls[k][scale[x1]];
254
+ fraction[0][0][i] = REAL_MUL_SCALE_LAYER12(fraction[0][0][i], cm);
255
+ fraction[0][1][i] = REAL_MUL_SCALE_LAYER12(fraction[0][1][i], cm);
256
+ fraction[0][2][i] = REAL_MUL_SCALE_LAYER12(fraction[0][2][i], cm);
257
+ }
258
+ else
259
+ {
260
+ const int *table[] = { 0,0,0,grp_3tab,0,grp_5tab,0,0,0,grp_9tab };
261
+ unsigned int idx,*tab,m1,m2;
262
+ m1 = scale[x1]; m2 = scale[x1+3];
263
+ idx = (unsigned int) getbits(fr, k);
264
+ tab = (unsigned int *) (table[d1] + idx + idx + idx);
265
+ fraction[0][0][i] = REAL_SCALE_LAYER12(fr->muls[*tab][m1]); fraction[1][0][i] = REAL_SCALE_LAYER12(fr->muls[*tab++][m2]);
266
+ fraction[0][1][i] = REAL_SCALE_LAYER12(fr->muls[*tab][m1]); fraction[1][1][i] = REAL_SCALE_LAYER12(fr->muls[*tab++][m2]);
267
+ fraction[0][2][i] = REAL_SCALE_LAYER12(fr->muls[*tab][m1]); fraction[1][2][i] = REAL_SCALE_LAYER12(fr->muls[*tab][m2]);
268
+ }
269
+ scale+=6;
270
+ }
271
+ else
272
+ {
273
+ fraction[0][0][i] = fraction[0][1][i] = fraction[0][2][i] =
274
+ fraction[1][0][i] = fraction[1][1][i] = fraction[1][2][i] = DOUBLE_TO_REAL(0.0);
275
+ }
276
+ /*
277
+ Historic comment...
278
+ should we use individual scalefac for channel 2 or
279
+ is the current way the right one , where we just copy channel 1 to
280
+ channel 2 ??
281
+ The current 'strange' thing is, that we throw away the scalefac
282
+ values for the second channel ...!!
283
+ -> changed .. now we use the scalefac values of channel one !!
284
+ */
285
+ }
286
+
287
+ if(sblimit > (fr->down_sample_sblimit) )
288
+ sblimit = fr->down_sample_sblimit;
289
+
290
+ for(i=sblimit;i<SBLIMIT;i++)
291
+ for (j=0;j<stereo;j++)
292
+ fraction[j][0][i] = fraction[j][1][i] = fraction[j][2][i] = DOUBLE_TO_REAL(0.0);
293
+ }
294
+
295
+
296
+ static void II_select_table(mpg123_handle *fr)
297
+ {
298
+ const int translate[3][2][16] =
299
+ {
300
+ {
301
+ { 0,2,2,2,2,2,2,0,0,0,1,1,1,1,1,0 },
302
+ { 0,2,2,0,0,0,1,1,1,1,1,1,1,1,1,0 }
303
+ },
304
+ {
305
+ { 0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0 },
306
+ { 0,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0 }
307
+ },
308
+ {
309
+ { 0,3,3,3,3,3,3,0,0,0,1,1,1,1,1,0 },
310
+ { 0,3,3,0,0,0,1,1,1,1,1,1,1,1,1,0 }
311
+ }
312
+ };
313
+
314
+ int table,sblim;
315
+ const struct al_table *tables[5] = { alloc_0, alloc_1, alloc_2, alloc_3 , alloc_4 };
316
+ const int sblims[5] = { 27 , 30 , 8, 12 , 30 };
317
+
318
+ if(fr->sampling_frequency >= 3) /* Or equivalent: (fr->lsf == 1) */
319
+ table = 4;
320
+ else
321
+ table = translate[fr->sampling_frequency][2-fr->stereo][fr->bitrate_index];
322
+
323
+ sblim = sblims[table];
324
+ fr->alloc = tables[table];
325
+ fr->II_sblimit = sblim;
326
+ }
327
+
328
+
329
+ int do_layer2(mpg123_handle *fr)
330
+ {
331
+ int clip=0;
332
+ int i,j;
333
+ int stereo = fr->stereo;
334
+ /* pick_table clears unused subbands */
335
+ /* replacement for real fraction[2][4][SBLIMIT], needs alignment. */
336
+ real (*fraction)[4][SBLIMIT] = fr->layer2.fraction;
337
+ unsigned int bit_alloc[64];
338
+ int scale[192];
339
+ int single = fr->single;
340
+
341
+ II_select_table(fr);
342
+ fr->jsbound = (fr->mode == MPG_MD_JOINT_STEREO) ? (fr->mode_ext<<2)+4 : fr->II_sblimit;
343
+
344
+ if(fr->jsbound > fr->II_sblimit)
345
+ {
346
+ fprintf(stderr, "Truncating stereo boundary to sideband limit.\n");
347
+ fr->jsbound=fr->II_sblimit;
348
+ }
349
+
350
+ /* TODO: What happens with mono mixing, actually? */
351
+ if(stereo == 1 || single == SINGLE_MIX) /* also, mix not really handled */
352
+ single = SINGLE_LEFT;
353
+
354
+ II_step_one(bit_alloc, scale, fr);
355
+
356
+ for(i=0;i<SCALE_BLOCK;i++)
357
+ {
358
+ II_step_two(bit_alloc,fraction,scale,fr,i>>2);
359
+ for(j=0;j<3;j++)
360
+ {
361
+ if(single != SINGLE_STEREO)
362
+ clip += (fr->synth_mono)(fraction[single][j], fr);
363
+ else
364
+ clip += (fr->synth_stereo)(fraction[0][j], fraction[1][j], fr);
365
+ }
366
+ }
367
+
368
+ return clip;
369
+ }
370
+
371
+ #endif /* NO_LAYER2 */