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,563 @@
1
+ /********************************************************************
2
+ * *
3
+ * THIS FILE IS PART OF THE OggVorbis SOFTWARE CODEC SOURCE CODE. *
4
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
5
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
6
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
7
+ * *
8
+ * THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2009 *
9
+ * by the Xiph.Org Foundation http://www.xiph.org/ *
10
+ * *
11
+ ********************************************************************
12
+
13
+ function: normalized modified discrete cosine transform
14
+ power of two length transform only [64 <= n ]
15
+ last mod: $Id: mdct.c 16227 2009-07-08 06:58:46Z xiphmont $
16
+
17
+ Original algorithm adapted long ago from _The use of multirate filter
18
+ banks for coding of high quality digital audio_, by T. Sporer,
19
+ K. Brandenburg and B. Edler, collection of the European Signal
20
+ Processing Conference (EUSIPCO), Amsterdam, June 1992, Vol.1, pp
21
+ 211-214
22
+
23
+ The below code implements an algorithm that no longer looks much like
24
+ that presented in the paper, but the basic structure remains if you
25
+ dig deep enough to see it.
26
+
27
+ This module DOES NOT INCLUDE code to generate/apply the window
28
+ function. Everybody has their own weird favorite including me... I
29
+ happen to like the properties of y=sin(.5PI*sin^2(x)), but others may
30
+ vehemently disagree.
31
+
32
+ ********************************************************************/
33
+
34
+ /* this can also be run as an integer transform by uncommenting a
35
+ define in mdct.h; the integerization is a first pass and although
36
+ it's likely stable for Vorbis, the dynamic range is constrained and
37
+ roundoff isn't done (so it's noisy). Consider it functional, but
38
+ only a starting point. There's no point on a machine with an FPU */
39
+
40
+ #include <stdio.h>
41
+ #include <stdlib.h>
42
+ #include <string.h>
43
+ #include <math.h>
44
+ #include "vorbis/codec.h"
45
+ #include "mdct.h"
46
+ #include "os.h"
47
+ #include "misc.h"
48
+
49
+ /* build lookups for trig functions; also pre-figure scaling and
50
+ some window function algebra. */
51
+
52
+ void mdct_init(mdct_lookup *lookup,int n){
53
+ int *bitrev=_ogg_malloc(sizeof(*bitrev)*(n/4));
54
+ DATA_TYPE *T=_ogg_malloc(sizeof(*T)*(n+n/4));
55
+
56
+ int i;
57
+ int n2=n>>1;
58
+ int log2n=lookup->log2n=rint(log((float)n)/log(2.f));
59
+ lookup->n=n;
60
+ lookup->trig=T;
61
+ lookup->bitrev=bitrev;
62
+
63
+ /* trig lookups... */
64
+
65
+ for(i=0;i<n/4;i++){
66
+ T[i*2]=FLOAT_CONV(cos((M_PI/n)*(4*i)));
67
+ T[i*2+1]=FLOAT_CONV(-sin((M_PI/n)*(4*i)));
68
+ T[n2+i*2]=FLOAT_CONV(cos((M_PI/(2*n))*(2*i+1)));
69
+ T[n2+i*2+1]=FLOAT_CONV(sin((M_PI/(2*n))*(2*i+1)));
70
+ }
71
+ for(i=0;i<n/8;i++){
72
+ T[n+i*2]=FLOAT_CONV(cos((M_PI/n)*(4*i+2))*.5);
73
+ T[n+i*2+1]=FLOAT_CONV(-sin((M_PI/n)*(4*i+2))*.5);
74
+ }
75
+
76
+ /* bitreverse lookup... */
77
+
78
+ {
79
+ int mask=(1<<(log2n-1))-1,i,j;
80
+ int msb=1<<(log2n-2);
81
+ for(i=0;i<n/8;i++){
82
+ int acc=0;
83
+ for(j=0;msb>>j;j++)
84
+ if((msb>>j)&i)acc|=1<<j;
85
+ bitrev[i*2]=((~acc)&mask)-1;
86
+ bitrev[i*2+1]=acc;
87
+
88
+ }
89
+ }
90
+ lookup->scale=FLOAT_CONV(4.f/n);
91
+ }
92
+
93
+ /* 8 point butterfly (in place, 4 register) */
94
+ STIN void mdct_butterfly_8(DATA_TYPE *x){
95
+ REG_TYPE r0 = x[6] + x[2];
96
+ REG_TYPE r1 = x[6] - x[2];
97
+ REG_TYPE r2 = x[4] + x[0];
98
+ REG_TYPE r3 = x[4] - x[0];
99
+
100
+ x[6] = r0 + r2;
101
+ x[4] = r0 - r2;
102
+
103
+ r0 = x[5] - x[1];
104
+ r2 = x[7] - x[3];
105
+ x[0] = r1 + r0;
106
+ x[2] = r1 - r0;
107
+
108
+ r0 = x[5] + x[1];
109
+ r1 = x[7] + x[3];
110
+ x[3] = r2 + r3;
111
+ x[1] = r2 - r3;
112
+ x[7] = r1 + r0;
113
+ x[5] = r1 - r0;
114
+
115
+ }
116
+
117
+ /* 16 point butterfly (in place, 4 register) */
118
+ STIN void mdct_butterfly_16(DATA_TYPE *x){
119
+ REG_TYPE r0 = x[1] - x[9];
120
+ REG_TYPE r1 = x[0] - x[8];
121
+
122
+ x[8] += x[0];
123
+ x[9] += x[1];
124
+ x[0] = MULT_NORM((r0 + r1) * cPI2_8);
125
+ x[1] = MULT_NORM((r0 - r1) * cPI2_8);
126
+
127
+ r0 = x[3] - x[11];
128
+ r1 = x[10] - x[2];
129
+ x[10] += x[2];
130
+ x[11] += x[3];
131
+ x[2] = r0;
132
+ x[3] = r1;
133
+
134
+ r0 = x[12] - x[4];
135
+ r1 = x[13] - x[5];
136
+ x[12] += x[4];
137
+ x[13] += x[5];
138
+ x[4] = MULT_NORM((r0 - r1) * cPI2_8);
139
+ x[5] = MULT_NORM((r0 + r1) * cPI2_8);
140
+
141
+ r0 = x[14] - x[6];
142
+ r1 = x[15] - x[7];
143
+ x[14] += x[6];
144
+ x[15] += x[7];
145
+ x[6] = r0;
146
+ x[7] = r1;
147
+
148
+ mdct_butterfly_8(x);
149
+ mdct_butterfly_8(x+8);
150
+ }
151
+
152
+ /* 32 point butterfly (in place, 4 register) */
153
+ STIN void mdct_butterfly_32(DATA_TYPE *x){
154
+ REG_TYPE r0 = x[30] - x[14];
155
+ REG_TYPE r1 = x[31] - x[15];
156
+
157
+ x[30] += x[14];
158
+ x[31] += x[15];
159
+ x[14] = r0;
160
+ x[15] = r1;
161
+
162
+ r0 = x[28] - x[12];
163
+ r1 = x[29] - x[13];
164
+ x[28] += x[12];
165
+ x[29] += x[13];
166
+ x[12] = MULT_NORM( r0 * cPI1_8 - r1 * cPI3_8 );
167
+ x[13] = MULT_NORM( r0 * cPI3_8 + r1 * cPI1_8 );
168
+
169
+ r0 = x[26] - x[10];
170
+ r1 = x[27] - x[11];
171
+ x[26] += x[10];
172
+ x[27] += x[11];
173
+ x[10] = MULT_NORM(( r0 - r1 ) * cPI2_8);
174
+ x[11] = MULT_NORM(( r0 + r1 ) * cPI2_8);
175
+
176
+ r0 = x[24] - x[8];
177
+ r1 = x[25] - x[9];
178
+ x[24] += x[8];
179
+ x[25] += x[9];
180
+ x[8] = MULT_NORM( r0 * cPI3_8 - r1 * cPI1_8 );
181
+ x[9] = MULT_NORM( r1 * cPI3_8 + r0 * cPI1_8 );
182
+
183
+ r0 = x[22] - x[6];
184
+ r1 = x[7] - x[23];
185
+ x[22] += x[6];
186
+ x[23] += x[7];
187
+ x[6] = r1;
188
+ x[7] = r0;
189
+
190
+ r0 = x[4] - x[20];
191
+ r1 = x[5] - x[21];
192
+ x[20] += x[4];
193
+ x[21] += x[5];
194
+ x[4] = MULT_NORM( r1 * cPI1_8 + r0 * cPI3_8 );
195
+ x[5] = MULT_NORM( r1 * cPI3_8 - r0 * cPI1_8 );
196
+
197
+ r0 = x[2] - x[18];
198
+ r1 = x[3] - x[19];
199
+ x[18] += x[2];
200
+ x[19] += x[3];
201
+ x[2] = MULT_NORM(( r1 + r0 ) * cPI2_8);
202
+ x[3] = MULT_NORM(( r1 - r0 ) * cPI2_8);
203
+
204
+ r0 = x[0] - x[16];
205
+ r1 = x[1] - x[17];
206
+ x[16] += x[0];
207
+ x[17] += x[1];
208
+ x[0] = MULT_NORM( r1 * cPI3_8 + r0 * cPI1_8 );
209
+ x[1] = MULT_NORM( r1 * cPI1_8 - r0 * cPI3_8 );
210
+
211
+ mdct_butterfly_16(x);
212
+ mdct_butterfly_16(x+16);
213
+
214
+ }
215
+
216
+ /* N point first stage butterfly (in place, 2 register) */
217
+ STIN void mdct_butterfly_first(DATA_TYPE *T,
218
+ DATA_TYPE *x,
219
+ int points){
220
+
221
+ DATA_TYPE *x1 = x + points - 8;
222
+ DATA_TYPE *x2 = x + (points>>1) - 8;
223
+ REG_TYPE r0;
224
+ REG_TYPE r1;
225
+
226
+ do{
227
+
228
+ r0 = x1[6] - x2[6];
229
+ r1 = x1[7] - x2[7];
230
+ x1[6] += x2[6];
231
+ x1[7] += x2[7];
232
+ x2[6] = MULT_NORM(r1 * T[1] + r0 * T[0]);
233
+ x2[7] = MULT_NORM(r1 * T[0] - r0 * T[1]);
234
+
235
+ r0 = x1[4] - x2[4];
236
+ r1 = x1[5] - x2[5];
237
+ x1[4] += x2[4];
238
+ x1[5] += x2[5];
239
+ x2[4] = MULT_NORM(r1 * T[5] + r0 * T[4]);
240
+ x2[5] = MULT_NORM(r1 * T[4] - r0 * T[5]);
241
+
242
+ r0 = x1[2] - x2[2];
243
+ r1 = x1[3] - x2[3];
244
+ x1[2] += x2[2];
245
+ x1[3] += x2[3];
246
+ x2[2] = MULT_NORM(r1 * T[9] + r0 * T[8]);
247
+ x2[3] = MULT_NORM(r1 * T[8] - r0 * T[9]);
248
+
249
+ r0 = x1[0] - x2[0];
250
+ r1 = x1[1] - x2[1];
251
+ x1[0] += x2[0];
252
+ x1[1] += x2[1];
253
+ x2[0] = MULT_NORM(r1 * T[13] + r0 * T[12]);
254
+ x2[1] = MULT_NORM(r1 * T[12] - r0 * T[13]);
255
+
256
+ x1-=8;
257
+ x2-=8;
258
+ T+=16;
259
+
260
+ }while(x2>=x);
261
+ }
262
+
263
+ /* N/stage point generic N stage butterfly (in place, 2 register) */
264
+ STIN void mdct_butterfly_generic(DATA_TYPE *T,
265
+ DATA_TYPE *x,
266
+ int points,
267
+ int trigint){
268
+
269
+ DATA_TYPE *x1 = x + points - 8;
270
+ DATA_TYPE *x2 = x + (points>>1) - 8;
271
+ REG_TYPE r0;
272
+ REG_TYPE r1;
273
+
274
+ do{
275
+
276
+ r0 = x1[6] - x2[6];
277
+ r1 = x1[7] - x2[7];
278
+ x1[6] += x2[6];
279
+ x1[7] += x2[7];
280
+ x2[6] = MULT_NORM(r1 * T[1] + r0 * T[0]);
281
+ x2[7] = MULT_NORM(r1 * T[0] - r0 * T[1]);
282
+
283
+ T+=trigint;
284
+
285
+ r0 = x1[4] - x2[4];
286
+ r1 = x1[5] - x2[5];
287
+ x1[4] += x2[4];
288
+ x1[5] += x2[5];
289
+ x2[4] = MULT_NORM(r1 * T[1] + r0 * T[0]);
290
+ x2[5] = MULT_NORM(r1 * T[0] - r0 * T[1]);
291
+
292
+ T+=trigint;
293
+
294
+ r0 = x1[2] - x2[2];
295
+ r1 = x1[3] - x2[3];
296
+ x1[2] += x2[2];
297
+ x1[3] += x2[3];
298
+ x2[2] = MULT_NORM(r1 * T[1] + r0 * T[0]);
299
+ x2[3] = MULT_NORM(r1 * T[0] - r0 * T[1]);
300
+
301
+ T+=trigint;
302
+
303
+ r0 = x1[0] - x2[0];
304
+ r1 = x1[1] - x2[1];
305
+ x1[0] += x2[0];
306
+ x1[1] += x2[1];
307
+ x2[0] = MULT_NORM(r1 * T[1] + r0 * T[0]);
308
+ x2[1] = MULT_NORM(r1 * T[0] - r0 * T[1]);
309
+
310
+ T+=trigint;
311
+ x1-=8;
312
+ x2-=8;
313
+
314
+ }while(x2>=x);
315
+ }
316
+
317
+ STIN void mdct_butterflies(mdct_lookup *init,
318
+ DATA_TYPE *x,
319
+ int points){
320
+
321
+ DATA_TYPE *T=init->trig;
322
+ int stages=init->log2n-5;
323
+ int i,j;
324
+
325
+ if(--stages>0){
326
+ mdct_butterfly_first(T,x,points);
327
+ }
328
+
329
+ for(i=1;--stages>0;i++){
330
+ for(j=0;j<(1<<i);j++)
331
+ mdct_butterfly_generic(T,x+(points>>i)*j,points>>i,4<<i);
332
+ }
333
+
334
+ for(j=0;j<points;j+=32)
335
+ mdct_butterfly_32(x+j);
336
+
337
+ }
338
+
339
+ void mdct_clear(mdct_lookup *l){
340
+ if(l){
341
+ if(l->trig)_ogg_free(l->trig);
342
+ if(l->bitrev)_ogg_free(l->bitrev);
343
+ memset(l,0,sizeof(*l));
344
+ }
345
+ }
346
+
347
+ STIN void mdct_bitreverse(mdct_lookup *init,
348
+ DATA_TYPE *x){
349
+ int n = init->n;
350
+ int *bit = init->bitrev;
351
+ DATA_TYPE *w0 = x;
352
+ DATA_TYPE *w1 = x = w0+(n>>1);
353
+ DATA_TYPE *T = init->trig+n;
354
+
355
+ do{
356
+ DATA_TYPE *x0 = x+bit[0];
357
+ DATA_TYPE *x1 = x+bit[1];
358
+
359
+ REG_TYPE r0 = x0[1] - x1[1];
360
+ REG_TYPE r1 = x0[0] + x1[0];
361
+ REG_TYPE r2 = MULT_NORM(r1 * T[0] + r0 * T[1]);
362
+ REG_TYPE r3 = MULT_NORM(r1 * T[1] - r0 * T[0]);
363
+
364
+ w1 -= 4;
365
+
366
+ r0 = HALVE(x0[1] + x1[1]);
367
+ r1 = HALVE(x0[0] - x1[0]);
368
+
369
+ w0[0] = r0 + r2;
370
+ w1[2] = r0 - r2;
371
+ w0[1] = r1 + r3;
372
+ w1[3] = r3 - r1;
373
+
374
+ x0 = x+bit[2];
375
+ x1 = x+bit[3];
376
+
377
+ r0 = x0[1] - x1[1];
378
+ r1 = x0[0] + x1[0];
379
+ r2 = MULT_NORM(r1 * T[2] + r0 * T[3]);
380
+ r3 = MULT_NORM(r1 * T[3] - r0 * T[2]);
381
+
382
+ r0 = HALVE(x0[1] + x1[1]);
383
+ r1 = HALVE(x0[0] - x1[0]);
384
+
385
+ w0[2] = r0 + r2;
386
+ w1[0] = r0 - r2;
387
+ w0[3] = r1 + r3;
388
+ w1[1] = r3 - r1;
389
+
390
+ T += 4;
391
+ bit += 4;
392
+ w0 += 4;
393
+
394
+ }while(w0<w1);
395
+ }
396
+
397
+ void mdct_backward(mdct_lookup *init, DATA_TYPE *in, DATA_TYPE *out){
398
+ int n=init->n;
399
+ int n2=n>>1;
400
+ int n4=n>>2;
401
+
402
+ /* rotate */
403
+
404
+ DATA_TYPE *iX = in+n2-7;
405
+ DATA_TYPE *oX = out+n2+n4;
406
+ DATA_TYPE *T = init->trig+n4;
407
+
408
+ do{
409
+ oX -= 4;
410
+ oX[0] = MULT_NORM(-iX[2] * T[3] - iX[0] * T[2]);
411
+ oX[1] = MULT_NORM (iX[0] * T[3] - iX[2] * T[2]);
412
+ oX[2] = MULT_NORM(-iX[6] * T[1] - iX[4] * T[0]);
413
+ oX[3] = MULT_NORM (iX[4] * T[1] - iX[6] * T[0]);
414
+ iX -= 8;
415
+ T += 4;
416
+ }while(iX>=in);
417
+
418
+ iX = in+n2-8;
419
+ oX = out+n2+n4;
420
+ T = init->trig+n4;
421
+
422
+ do{
423
+ T -= 4;
424
+ oX[0] = MULT_NORM (iX[4] * T[3] + iX[6] * T[2]);
425
+ oX[1] = MULT_NORM (iX[4] * T[2] - iX[6] * T[3]);
426
+ oX[2] = MULT_NORM (iX[0] * T[1] + iX[2] * T[0]);
427
+ oX[3] = MULT_NORM (iX[0] * T[0] - iX[2] * T[1]);
428
+ iX -= 8;
429
+ oX += 4;
430
+ }while(iX>=in);
431
+
432
+ mdct_butterflies(init,out+n2,n2);
433
+ mdct_bitreverse(init,out);
434
+
435
+ /* roatate + window */
436
+
437
+ {
438
+ DATA_TYPE *oX1=out+n2+n4;
439
+ DATA_TYPE *oX2=out+n2+n4;
440
+ DATA_TYPE *iX =out;
441
+ T =init->trig+n2;
442
+
443
+ do{
444
+ oX1-=4;
445
+
446
+ oX1[3] = MULT_NORM (iX[0] * T[1] - iX[1] * T[0]);
447
+ oX2[0] = -MULT_NORM (iX[0] * T[0] + iX[1] * T[1]);
448
+
449
+ oX1[2] = MULT_NORM (iX[2] * T[3] - iX[3] * T[2]);
450
+ oX2[1] = -MULT_NORM (iX[2] * T[2] + iX[3] * T[3]);
451
+
452
+ oX1[1] = MULT_NORM (iX[4] * T[5] - iX[5] * T[4]);
453
+ oX2[2] = -MULT_NORM (iX[4] * T[4] + iX[5] * T[5]);
454
+
455
+ oX1[0] = MULT_NORM (iX[6] * T[7] - iX[7] * T[6]);
456
+ oX2[3] = -MULT_NORM (iX[6] * T[6] + iX[7] * T[7]);
457
+
458
+ oX2+=4;
459
+ iX += 8;
460
+ T += 8;
461
+ }while(iX<oX1);
462
+
463
+ iX=out+n2+n4;
464
+ oX1=out+n4;
465
+ oX2=oX1;
466
+
467
+ do{
468
+ oX1-=4;
469
+ iX-=4;
470
+
471
+ oX2[0] = -(oX1[3] = iX[3]);
472
+ oX2[1] = -(oX1[2] = iX[2]);
473
+ oX2[2] = -(oX1[1] = iX[1]);
474
+ oX2[3] = -(oX1[0] = iX[0]);
475
+
476
+ oX2+=4;
477
+ }while(oX2<iX);
478
+
479
+ iX=out+n2+n4;
480
+ oX1=out+n2+n4;
481
+ oX2=out+n2;
482
+ do{
483
+ oX1-=4;
484
+ oX1[0]= iX[3];
485
+ oX1[1]= iX[2];
486
+ oX1[2]= iX[1];
487
+ oX1[3]= iX[0];
488
+ iX+=4;
489
+ }while(oX1>oX2);
490
+ }
491
+ }
492
+
493
+ void mdct_forward(mdct_lookup *init, DATA_TYPE *in, DATA_TYPE *out){
494
+ int n=init->n;
495
+ int n2=n>>1;
496
+ int n4=n>>2;
497
+ int n8=n>>3;
498
+ DATA_TYPE *w=alloca(n*sizeof(*w)); /* forward needs working space */
499
+ DATA_TYPE *w2=w+n2;
500
+
501
+ /* rotate */
502
+
503
+ /* window + rotate + step 1 */
504
+
505
+ REG_TYPE r0;
506
+ REG_TYPE r1;
507
+ DATA_TYPE *x0=in+n2+n4;
508
+ DATA_TYPE *x1=x0+1;
509
+ DATA_TYPE *T=init->trig+n2;
510
+
511
+ int i=0;
512
+
513
+ for(i=0;i<n8;i+=2){
514
+ x0 -=4;
515
+ T-=2;
516
+ r0= x0[2] + x1[0];
517
+ r1= x0[0] + x1[2];
518
+ w2[i]= MULT_NORM(r1*T[1] + r0*T[0]);
519
+ w2[i+1]= MULT_NORM(r1*T[0] - r0*T[1]);
520
+ x1 +=4;
521
+ }
522
+
523
+ x1=in+1;
524
+
525
+ for(;i<n2-n8;i+=2){
526
+ T-=2;
527
+ x0 -=4;
528
+ r0= x0[2] - x1[0];
529
+ r1= x0[0] - x1[2];
530
+ w2[i]= MULT_NORM(r1*T[1] + r0*T[0]);
531
+ w2[i+1]= MULT_NORM(r1*T[0] - r0*T[1]);
532
+ x1 +=4;
533
+ }
534
+
535
+ x0=in+n;
536
+
537
+ for(;i<n2;i+=2){
538
+ T-=2;
539
+ x0 -=4;
540
+ r0= -x0[2] - x1[0];
541
+ r1= -x0[0] - x1[2];
542
+ w2[i]= MULT_NORM(r1*T[1] + r0*T[0]);
543
+ w2[i+1]= MULT_NORM(r1*T[0] - r0*T[1]);
544
+ x1 +=4;
545
+ }
546
+
547
+
548
+ mdct_butterflies(init,w+n2,n2);
549
+ mdct_bitreverse(init,w);
550
+
551
+ /* roatate + window */
552
+
553
+ T=init->trig+n2;
554
+ x0=out+n2;
555
+
556
+ for(i=0;i<n4;i++){
557
+ x0--;
558
+ out[i] =MULT_NORM((w[0]*T[0]+w[1]*T[1])*init->scale);
559
+ x0[0] =MULT_NORM((w[0]*T[1]-w[1]*T[0])*init->scale);
560
+ w+=2;
561
+ T+=2;
562
+ }
563
+ }