epeg 1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (504) hide show
  1. checksums.yaml +7 -0
  2. data/Gemfile +4 -0
  3. data/MANIFEST +5 -0
  4. data/TODO +1 -0
  5. data/epeg/.dockerignore +4 -0
  6. data/epeg/.gitignore +5 -0
  7. data/epeg/CMakeLists.txt +30 -0
  8. data/epeg/Dockerfile +23 -0
  9. data/epeg/Epeg.h +90 -0
  10. data/epeg/README.md +42 -0
  11. data/epeg/epeg_main.c +1642 -0
  12. data/epeg/epeg_private.h +85 -0
  13. data/epeg/example/.gitignore +1 -0
  14. data/epeg/example/CMakeLists.txt +20 -0
  15. data/epeg/example/example.jpg +0 -0
  16. data/epeg/example/rotatetest.c +29 -0
  17. data/epeg/example/scaletest.c +48 -0
  18. data/epeg/vendor/libjpeg-turbo-2.0.4/BUILDING.md +828 -0
  19. data/epeg/vendor/libjpeg-turbo-2.0.4/CMakeLists.txt +1420 -0
  20. data/epeg/vendor/libjpeg-turbo-2.0.4/ChangeLog.md +1494 -0
  21. data/epeg/vendor/libjpeg-turbo-2.0.4/LICENSE.md +132 -0
  22. data/epeg/vendor/libjpeg-turbo-2.0.4/README.ijg +277 -0
  23. data/epeg/vendor/libjpeg-turbo-2.0.4/README.md +356 -0
  24. data/epeg/vendor/libjpeg-turbo-2.0.4/cderror.h +137 -0
  25. data/epeg/vendor/libjpeg-turbo-2.0.4/cdjpeg.c +145 -0
  26. data/epeg/vendor/libjpeg-turbo-2.0.4/cdjpeg.h +157 -0
  27. data/epeg/vendor/libjpeg-turbo-2.0.4/change.log +315 -0
  28. data/epeg/vendor/libjpeg-turbo-2.0.4/cjpeg.1 +354 -0
  29. data/epeg/vendor/libjpeg-turbo-2.0.4/cjpeg.c +695 -0
  30. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/BuildPackages.cmake +182 -0
  31. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/GNUInstallDirs.cmake +416 -0
  32. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/cmake_uninstall.cmake.in +24 -0
  33. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/testclean.cmake +41 -0
  34. data/epeg/vendor/libjpeg-turbo-2.0.4/cmyk.h +61 -0
  35. data/epeg/vendor/libjpeg-turbo-2.0.4/coderules.txt +78 -0
  36. data/epeg/vendor/libjpeg-turbo-2.0.4/djpeg.1 +296 -0
  37. data/epeg/vendor/libjpeg-turbo-2.0.4/djpeg.c +822 -0
  38. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/annotated.html +104 -0
  39. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/bc_s.png +0 -0
  40. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/bdwn.png +0 -0
  41. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/classes.html +106 -0
  42. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/closed.png +0 -0
  43. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/doxygen-extra.css +3 -0
  44. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/doxygen.css +1184 -0
  45. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/doxygen.png +0 -0
  46. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/dynsections.js +97 -0
  47. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2blank.png +0 -0
  48. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2cl.png +0 -0
  49. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2doc.png +0 -0
  50. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2folderclosed.png +0 -0
  51. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2folderopen.png +0 -0
  52. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2lastnode.png +0 -0
  53. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2link.png +0 -0
  54. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2mlastnode.png +0 -0
  55. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2mnode.png +0 -0
  56. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2mo.png +0 -0
  57. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2node.png +0 -0
  58. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2ns.png +0 -0
  59. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2plastnode.png +0 -0
  60. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2pnode.png +0 -0
  61. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2splitbar.png +0 -0
  62. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2vertline.png +0 -0
  63. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/functions.html +134 -0
  64. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/functions_vars.html +134 -0
  65. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/group___turbo_j_p_e_g.html +2775 -0
  66. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/index.html +90 -0
  67. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/jquery.js +8 -0
  68. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/modules.html +95 -0
  69. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/nav_f.png +0 -0
  70. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/nav_g.png +0 -0
  71. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/nav_h.png +0 -0
  72. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/open.png +0 -0
  73. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_63.html +26 -0
  74. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_63.js +4 -0
  75. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_64.html +26 -0
  76. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_64.js +5 -0
  77. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_68.html +26 -0
  78. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_68.js +4 -0
  79. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6e.html +26 -0
  80. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6e.js +4 -0
  81. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6f.html +26 -0
  82. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6f.js +5 -0
  83. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_72.html +26 -0
  84. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_72.js +4 -0
  85. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_74.html +26 -0
  86. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_74.js +102 -0
  87. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_77.html +26 -0
  88. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_77.js +4 -0
  89. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_78.html +26 -0
  90. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_78.js +4 -0
  91. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_79.html +26 -0
  92. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_79.js +4 -0
  93. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/classes_74.html +26 -0
  94. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/classes_74.js +6 -0
  95. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/close.png +0 -0
  96. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enums_74.html +26 -0
  97. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enums_74.js +8 -0
  98. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enumvalues_74.html +26 -0
  99. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enumvalues_74.js +37 -0
  100. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/functions_74.html +26 -0
  101. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/functions_74.js +31 -0
  102. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/groups_74.html +26 -0
  103. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/groups_74.js +4 -0
  104. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/mag_sel.png +0 -0
  105. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/nomatches.html +12 -0
  106. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search.css +271 -0
  107. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search.js +809 -0
  108. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search_l.png +0 -0
  109. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search_m.png +0 -0
  110. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search_r.png +0 -0
  111. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/typedefs_74.html +26 -0
  112. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/typedefs_74.js +5 -0
  113. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_63.html +26 -0
  114. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_63.js +4 -0
  115. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_64.html +26 -0
  116. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_64.js +5 -0
  117. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_68.html +26 -0
  118. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_68.js +4 -0
  119. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6e.html +26 -0
  120. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6e.js +4 -0
  121. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6f.html +26 -0
  122. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6f.js +5 -0
  123. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_72.html +26 -0
  124. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_72.js +4 -0
  125. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_74.html +26 -0
  126. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_74.js +10 -0
  127. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_77.html +26 -0
  128. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_77.js +4 -0
  129. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_78.html +26 -0
  130. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_78.js +4 -0
  131. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_79.html +26 -0
  132. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_79.js +4 -0
  133. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/structtjregion.html +186 -0
  134. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/structtjscalingfactor.html +148 -0
  135. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/structtjtransform.html +212 -0
  136. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/sync_off.png +0 -0
  137. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/sync_on.png +0 -0
  138. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_a.png +0 -0
  139. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_b.png +0 -0
  140. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_h.png +0 -0
  141. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_s.png +0 -0
  142. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tabs.css +60 -0
  143. data/epeg/vendor/libjpeg-turbo-2.0.4/doxygen-extra.css +3 -0
  144. data/epeg/vendor/libjpeg-turbo-2.0.4/doxygen.config +16 -0
  145. data/epeg/vendor/libjpeg-turbo-2.0.4/example.txt +464 -0
  146. data/epeg/vendor/libjpeg-turbo-2.0.4/jaricom.c +157 -0
  147. data/epeg/vendor/libjpeg-turbo-2.0.4/java/CMakeLists.txt +88 -0
  148. data/epeg/vendor/libjpeg-turbo-2.0.4/java/MANIFEST.MF +2 -0
  149. data/epeg/vendor/libjpeg-turbo-2.0.4/java/README +52 -0
  150. data/epeg/vendor/libjpeg-turbo-2.0.4/java/TJBench.java +1021 -0
  151. data/epeg/vendor/libjpeg-turbo-2.0.4/java/TJExample.java +405 -0
  152. data/epeg/vendor/libjpeg-turbo-2.0.4/java/TJUnitTest.java +960 -0
  153. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/allclasses-frame.html +24 -0
  154. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/allclasses-noframe.html +24 -0
  155. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/constant-values.html +532 -0
  156. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/deprecated-list.html +252 -0
  157. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/help-doc.html +210 -0
  158. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/index-all.html +1029 -0
  159. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/index.html +71 -0
  160. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJ.html +1356 -0
  161. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJCompressor.html +926 -0
  162. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJCustomFilter.html +241 -0
  163. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJDecompressor.html +1255 -0
  164. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJException.html +340 -0
  165. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJScalingFactor.html +343 -0
  166. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJTransform.html +751 -0
  167. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJTransformer.html +421 -0
  168. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/YUVImage.html +765 -0
  169. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/package-frame.html +31 -0
  170. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/package-summary.html +202 -0
  171. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/package-tree.html +160 -0
  172. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/overview-tree.html +164 -0
  173. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/package-list +1 -0
  174. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/background.gif +0 -0
  175. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/tab.gif +0 -0
  176. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/titlebar.gif +0 -0
  177. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/titlebar_end.gif +0 -0
  178. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/script.js +30 -0
  179. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/serialized-form.html +176 -0
  180. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/stylesheet.css +474 -0
  181. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJ.java +584 -0
  182. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJCompressor.java +677 -0
  183. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJCustomFilter.java +76 -0
  184. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJDecompressor.java +931 -0
  185. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJException.java +78 -0
  186. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJLoader-unix.java.in +59 -0
  187. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJLoader-win.java.in +35 -0
  188. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJScalingFactor.java +115 -0
  189. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJTransform.java +227 -0
  190. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJTransformer.java +163 -0
  191. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/YUVImage.java +445 -0
  192. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJ.h +129 -0
  193. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJCompressor.h +101 -0
  194. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJDecompressor.h +101 -0
  195. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJTransformer.h +29 -0
  196. data/epeg/vendor/libjpeg-turbo-2.0.4/jcapimin.c +295 -0
  197. data/epeg/vendor/libjpeg-turbo-2.0.4/jcapistd.c +162 -0
  198. data/epeg/vendor/libjpeg-turbo-2.0.4/jcarith.c +932 -0
  199. data/epeg/vendor/libjpeg-turbo-2.0.4/jccoefct.c +449 -0
  200. data/epeg/vendor/libjpeg-turbo-2.0.4/jccolext.c +144 -0
  201. data/epeg/vendor/libjpeg-turbo-2.0.4/jccolor.c +710 -0
  202. data/epeg/vendor/libjpeg-turbo-2.0.4/jcdctmgr.c +721 -0
  203. data/epeg/vendor/libjpeg-turbo-2.0.4/jchuff.c +1096 -0
  204. data/epeg/vendor/libjpeg-turbo-2.0.4/jchuff.h +42 -0
  205. data/epeg/vendor/libjpeg-turbo-2.0.4/jcicc.c +105 -0
  206. data/epeg/vendor/libjpeg-turbo-2.0.4/jcinit.c +77 -0
  207. data/epeg/vendor/libjpeg-turbo-2.0.4/jcmainct.c +162 -0
  208. data/epeg/vendor/libjpeg-turbo-2.0.4/jcmarker.c +664 -0
  209. data/epeg/vendor/libjpeg-turbo-2.0.4/jcmaster.c +640 -0
  210. data/epeg/vendor/libjpeg-turbo-2.0.4/jcomapi.c +109 -0
  211. data/epeg/vendor/libjpeg-turbo-2.0.4/jconfig.h.in +73 -0
  212. data/epeg/vendor/libjpeg-turbo-2.0.4/jconfig.txt +143 -0
  213. data/epeg/vendor/libjpeg-turbo-2.0.4/jconfigint.h.in +31 -0
  214. data/epeg/vendor/libjpeg-turbo-2.0.4/jcparam.c +541 -0
  215. data/epeg/vendor/libjpeg-turbo-2.0.4/jcphuff.c +1105 -0
  216. data/epeg/vendor/libjpeg-turbo-2.0.4/jcprepct.c +351 -0
  217. data/epeg/vendor/libjpeg-turbo-2.0.4/jcsample.c +539 -0
  218. data/epeg/vendor/libjpeg-turbo-2.0.4/jcstest.c +126 -0
  219. data/epeg/vendor/libjpeg-turbo-2.0.4/jctrans.c +400 -0
  220. data/epeg/vendor/libjpeg-turbo-2.0.4/jdapimin.c +407 -0
  221. data/epeg/vendor/libjpeg-turbo-2.0.4/jdapistd.c +639 -0
  222. data/epeg/vendor/libjpeg-turbo-2.0.4/jdarith.c +773 -0
  223. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatadst-tj.c +203 -0
  224. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatadst.c +293 -0
  225. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatasrc-tj.c +194 -0
  226. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatasrc.c +295 -0
  227. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcoefct.c +692 -0
  228. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcoefct.h +82 -0
  229. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcol565.c +384 -0
  230. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcolext.c +143 -0
  231. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcolor.c +883 -0
  232. data/epeg/vendor/libjpeg-turbo-2.0.4/jdct.h +208 -0
  233. data/epeg/vendor/libjpeg-turbo-2.0.4/jddctmgr.c +352 -0
  234. data/epeg/vendor/libjpeg-turbo-2.0.4/jdhuff.c +831 -0
  235. data/epeg/vendor/libjpeg-turbo-2.0.4/jdhuff.h +238 -0
  236. data/epeg/vendor/libjpeg-turbo-2.0.4/jdicc.c +171 -0
  237. data/epeg/vendor/libjpeg-turbo-2.0.4/jdinput.c +408 -0
  238. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmainct.c +460 -0
  239. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmainct.h +71 -0
  240. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmarker.c +1377 -0
  241. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmaster.c +737 -0
  242. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmaster.h +28 -0
  243. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmerge.c +617 -0
  244. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmrg565.c +354 -0
  245. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmrgext.c +184 -0
  246. data/epeg/vendor/libjpeg-turbo-2.0.4/jdphuff.c +687 -0
  247. data/epeg/vendor/libjpeg-turbo-2.0.4/jdpostct.c +294 -0
  248. data/epeg/vendor/libjpeg-turbo-2.0.4/jdsample.c +518 -0
  249. data/epeg/vendor/libjpeg-turbo-2.0.4/jdsample.h +50 -0
  250. data/epeg/vendor/libjpeg-turbo-2.0.4/jdtrans.c +155 -0
  251. data/epeg/vendor/libjpeg-turbo-2.0.4/jerror.c +251 -0
  252. data/epeg/vendor/libjpeg-turbo-2.0.4/jerror.h +316 -0
  253. data/epeg/vendor/libjpeg-turbo-2.0.4/jfdctflt.c +169 -0
  254. data/epeg/vendor/libjpeg-turbo-2.0.4/jfdctfst.c +227 -0
  255. data/epeg/vendor/libjpeg-turbo-2.0.4/jfdctint.c +288 -0
  256. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctflt.c +240 -0
  257. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctfst.c +371 -0
  258. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctint.c +2627 -0
  259. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctred.c +409 -0
  260. data/epeg/vendor/libjpeg-turbo-2.0.4/jinclude.h +88 -0
  261. data/epeg/vendor/libjpeg-turbo-2.0.4/jmemmgr.c +1179 -0
  262. data/epeg/vendor/libjpeg-turbo-2.0.4/jmemnobs.c +115 -0
  263. data/epeg/vendor/libjpeg-turbo-2.0.4/jmemsys.h +178 -0
  264. data/epeg/vendor/libjpeg-turbo-2.0.4/jmorecfg.h +421 -0
  265. data/epeg/vendor/libjpeg-turbo-2.0.4/jpeg_nbits_table.h +4098 -0
  266. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegcomp.h +31 -0
  267. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegint.h +368 -0
  268. data/epeg/vendor/libjpeg-turbo-2.0.4/jpeglib.h +1132 -0
  269. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegtran.1 +295 -0
  270. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegtran.c +601 -0
  271. data/epeg/vendor/libjpeg-turbo-2.0.4/jquant1.c +859 -0
  272. data/epeg/vendor/libjpeg-turbo-2.0.4/jquant2.c +1285 -0
  273. data/epeg/vendor/libjpeg-turbo-2.0.4/jsimd.h +117 -0
  274. data/epeg/vendor/libjpeg-turbo-2.0.4/jsimd_none.c +418 -0
  275. data/epeg/vendor/libjpeg-turbo-2.0.4/jsimddct.h +70 -0
  276. data/epeg/vendor/libjpeg-turbo-2.0.4/jstdhuff.c +143 -0
  277. data/epeg/vendor/libjpeg-turbo-2.0.4/jutils.c +133 -0
  278. data/epeg/vendor/libjpeg-turbo-2.0.4/jversion.h +52 -0
  279. data/epeg/vendor/libjpeg-turbo-2.0.4/libjpeg.map.in +11 -0
  280. data/epeg/vendor/libjpeg-turbo-2.0.4/libjpeg.txt +3144 -0
  281. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/CMakeLists.txt +1 -0
  282. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5.c +275 -0
  283. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5.h +57 -0
  284. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5cmp.c +59 -0
  285. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5hl.c +125 -0
  286. data/epeg/vendor/libjpeg-turbo-2.0.4/rdbmp.c +689 -0
  287. data/epeg/vendor/libjpeg-turbo-2.0.4/rdcolmap.c +254 -0
  288. data/epeg/vendor/libjpeg-turbo-2.0.4/rdgif.c +39 -0
  289. data/epeg/vendor/libjpeg-turbo-2.0.4/rdjpgcom.1 +63 -0
  290. data/epeg/vendor/libjpeg-turbo-2.0.4/rdjpgcom.c +510 -0
  291. data/epeg/vendor/libjpeg-turbo-2.0.4/rdppm.c +766 -0
  292. data/epeg/vendor/libjpeg-turbo-2.0.4/rdrle.c +389 -0
  293. data/epeg/vendor/libjpeg-turbo-2.0.4/rdswitch.c +424 -0
  294. data/epeg/vendor/libjpeg-turbo-2.0.4/rdtarga.c +509 -0
  295. data/epeg/vendor/libjpeg-turbo-2.0.4/release/Distribution.xml.in +24 -0
  296. data/epeg/vendor/libjpeg-turbo-2.0.4/release/License.rtf +20 -0
  297. data/epeg/vendor/libjpeg-turbo-2.0.4/release/ReadMe.txt +5 -0
  298. data/epeg/vendor/libjpeg-turbo-2.0.4/release/Welcome.rtf +17 -0
  299. data/epeg/vendor/libjpeg-turbo-2.0.4/release/deb-control.in +31 -0
  300. data/epeg/vendor/libjpeg-turbo-2.0.4/release/installer.nsi.in +191 -0
  301. data/epeg/vendor/libjpeg-turbo-2.0.4/release/libjpeg.pc.in +10 -0
  302. data/epeg/vendor/libjpeg-turbo-2.0.4/release/libturbojpeg.pc.in +10 -0
  303. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makecygwinpkg.in +66 -0
  304. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makedpkg.in +115 -0
  305. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makemacpkg.in +284 -0
  306. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makerpm.in +30 -0
  307. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makesrpm.in +48 -0
  308. data/epeg/vendor/libjpeg-turbo-2.0.4/release/maketarball.in +51 -0
  309. data/epeg/vendor/libjpeg-turbo-2.0.4/release/rpm.spec.in +221 -0
  310. data/epeg/vendor/libjpeg-turbo-2.0.4/release/uninstall.in +113 -0
  311. data/epeg/vendor/libjpeg-turbo-2.0.4/sharedlib/CMakeLists.txt +99 -0
  312. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/CMakeLists.txt +385 -0
  313. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm/jsimd.c +721 -0
  314. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm/jsimd_neon.S +2878 -0
  315. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm64/jsimd.c +798 -0
  316. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm64/jsimd_neon.S +3433 -0
  317. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/gas-preprocessor.in +1 -0
  318. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolext-avx2.asm +578 -0
  319. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolext-mmx.asm +476 -0
  320. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolext-sse2.asm +503 -0
  321. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolor-avx2.asm +121 -0
  322. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolor-mmx.asm +121 -0
  323. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolor-sse2.asm +120 -0
  324. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgray-avx2.asm +113 -0
  325. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgray-mmx.asm +113 -0
  326. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgray-sse2.asm +112 -0
  327. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgryext-avx2.asm +457 -0
  328. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgryext-mmx.asm +355 -0
  329. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgryext-sse2.asm +382 -0
  330. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jchuff-sse2.asm +424 -0
  331. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcphuff-sse2.asm +660 -0
  332. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcsample-avx2.asm +388 -0
  333. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcsample-mmx.asm +324 -0
  334. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcsample-sse2.asm +351 -0
  335. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolext-avx2.asm +515 -0
  336. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolext-mmx.asm +404 -0
  337. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolext-sse2.asm +458 -0
  338. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolor-avx2.asm +118 -0
  339. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolor-mmx.asm +117 -0
  340. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolor-sse2.asm +117 -0
  341. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmerge-avx2.asm +136 -0
  342. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmerge-mmx.asm +123 -0
  343. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmerge-sse2.asm +135 -0
  344. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmrgext-avx2.asm +575 -0
  345. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmrgext-mmx.asm +460 -0
  346. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmrgext-sse2.asm +517 -0
  347. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdsample-avx2.asm +760 -0
  348. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdsample-mmx.asm +731 -0
  349. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdsample-sse2.asm +724 -0
  350. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctflt-3dn.asm +318 -0
  351. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctflt-sse.asm +369 -0
  352. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctfst-mmx.asm +395 -0
  353. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctfst-sse2.asm +403 -0
  354. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctint-avx2.asm +331 -0
  355. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctint-mmx.asm +620 -0
  356. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctint-sse2.asm +633 -0
  357. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctflt-3dn.asm +451 -0
  358. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctflt-sse.asm +571 -0
  359. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctflt-sse2.asm +497 -0
  360. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctfst-mmx.asm +499 -0
  361. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctfst-sse2.asm +501 -0
  362. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctint-avx2.asm +453 -0
  363. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctint-mmx.asm +851 -0
  364. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctint-sse2.asm +858 -0
  365. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctred-mmx.asm +704 -0
  366. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctred-sse2.asm +592 -0
  367. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquant-3dn.asm +230 -0
  368. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquant-mmx.asm +276 -0
  369. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquant-sse.asm +208 -0
  370. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquantf-sse2.asm +168 -0
  371. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquanti-avx2.asm +188 -0
  372. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquanti-sse2.asm +201 -0
  373. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jsimd.c +1253 -0
  374. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jsimdcpu.asm +135 -0
  375. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/jsimd.h +1083 -0
  376. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jccolext-mmi.c +483 -0
  377. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jccolor-mmi.c +148 -0
  378. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jcsample-mmi.c +100 -0
  379. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jcsample.h +28 -0
  380. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jdcolext-mmi.c +424 -0
  381. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jdcolor-mmi.c +139 -0
  382. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jdsample-mmi.c +245 -0
  383. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jfdctint-mmi.c +398 -0
  384. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jidctint-mmi.c +571 -0
  385. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jquanti-mmi.c +130 -0
  386. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jsimd.c +610 -0
  387. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jsimd_mmi.h +57 -0
  388. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/loongson-mmintrin.h +1324 -0
  389. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/mips/jsimd.c +1123 -0
  390. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/mips/jsimd_dspr2.S +4479 -0
  391. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/mips/jsimd_dspr2_asm.h +292 -0
  392. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jcolsamp.inc +135 -0
  393. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jdct.inc +31 -0
  394. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jpeg_nbits_table.inc +4097 -0
  395. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jsimdcfg.inc +93 -0
  396. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jsimdcfg.inc.h +131 -0
  397. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jsimdext.inc +479 -0
  398. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jccolext-altivec.c +269 -0
  399. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jccolor-altivec.c +116 -0
  400. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcgray-altivec.c +111 -0
  401. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcgryext-altivec.c +228 -0
  402. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcsample-altivec.c +159 -0
  403. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcsample.h +28 -0
  404. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdcolext-altivec.c +276 -0
  405. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdcolor-altivec.c +106 -0
  406. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdmerge-altivec.c +130 -0
  407. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdmrgext-altivec.c +329 -0
  408. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdsample-altivec.c +400 -0
  409. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jfdctfst-altivec.c +154 -0
  410. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jfdctint-altivec.c +258 -0
  411. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jidctfst-altivec.c +255 -0
  412. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jidctint-altivec.c +357 -0
  413. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jquanti-altivec.c +250 -0
  414. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jsimd.c +872 -0
  415. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jsimd_altivec.h +98 -0
  416. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolext-avx2.asm +558 -0
  417. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolext-sse2.asm +483 -0
  418. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolor-avx2.asm +121 -0
  419. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolor-sse2.asm +120 -0
  420. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgray-avx2.asm +113 -0
  421. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgray-sse2.asm +112 -0
  422. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgryext-avx2.asm +437 -0
  423. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgryext-sse2.asm +362 -0
  424. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jchuff-sse2.asm +346 -0
  425. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcphuff-sse2.asm +637 -0
  426. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcsample-avx2.asm +366 -0
  427. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcsample-sse2.asm +329 -0
  428. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolext-avx2.asm +495 -0
  429. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolext-sse2.asm +438 -0
  430. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolor-avx2.asm +118 -0
  431. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolor-sse2.asm +117 -0
  432. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmerge-avx2.asm +136 -0
  433. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmerge-sse2.asm +135 -0
  434. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmrgext-avx2.asm +593 -0
  435. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmrgext-sse2.asm +535 -0
  436. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdsample-avx2.asm +695 -0
  437. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdsample-sse2.asm +664 -0
  438. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctflt-sse.asm +355 -0
  439. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctfst-sse2.asm +389 -0
  440. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctint-avx2.asm +320 -0
  441. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctint-sse2.asm +619 -0
  442. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctflt-sse2.asm +481 -0
  443. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctfst-sse2.asm +490 -0
  444. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctint-avx2.asm +417 -0
  445. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctint-sse2.asm +846 -0
  446. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctred-sse2.asm +573 -0
  447. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jquantf-sse2.asm +154 -0
  448. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jquanti-avx2.asm +162 -0
  449. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jquanti-sse2.asm +187 -0
  450. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jsimd.c +1076 -0
  451. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jsimdcpu.asm +86 -0
  452. data/epeg/vendor/libjpeg-turbo-2.0.4/structure.txt +904 -0
  453. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/nightshot_iso_100.bmp +0 -0
  454. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/nightshot_iso_100.txt +25 -0
  455. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test.scan +5 -0
  456. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test1.icc +0 -0
  457. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test1.icc.txt +20 -0
  458. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test2.icc +0 -0
  459. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test2.icc.txt +20 -0
  460. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testimgari.jpg +0 -0
  461. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testimgint.jpg +0 -0
  462. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testorig.jpg +0 -0
  463. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testorig.ppm +4 -0
  464. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testorig12.jpg +0 -0
  465. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/vgl_5674_0098.bmp +0 -0
  466. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/vgl_6434_0018a.bmp +0 -0
  467. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/vgl_6548_0026a.bmp +0 -0
  468. data/epeg/vendor/libjpeg-turbo-2.0.4/tjbench.c +1031 -0
  469. data/epeg/vendor/libjpeg-turbo-2.0.4/tjbenchtest.in +256 -0
  470. data/epeg/vendor/libjpeg-turbo-2.0.4/tjbenchtest.java.in +215 -0
  471. data/epeg/vendor/libjpeg-turbo-2.0.4/tjexample.c +396 -0
  472. data/epeg/vendor/libjpeg-turbo-2.0.4/tjexampletest.in +149 -0
  473. data/epeg/vendor/libjpeg-turbo-2.0.4/tjexampletest.java.in +151 -0
  474. data/epeg/vendor/libjpeg-turbo-2.0.4/tjunittest.c +931 -0
  475. data/epeg/vendor/libjpeg-turbo-2.0.4/tjutil.c +70 -0
  476. data/epeg/vendor/libjpeg-turbo-2.0.4/tjutil.h +47 -0
  477. data/epeg/vendor/libjpeg-turbo-2.0.4/transupp.c +1628 -0
  478. data/epeg/vendor/libjpeg-turbo-2.0.4/transupp.h +210 -0
  479. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg-jni.c +1246 -0
  480. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg-mapfile +65 -0
  481. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg-mapfile.jni +101 -0
  482. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg.c +2152 -0
  483. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg.h +1744 -0
  484. data/epeg/vendor/libjpeg-turbo-2.0.4/usage.txt +635 -0
  485. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jconfig.h.in +34 -0
  486. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg62-memsrcdst.def +108 -0
  487. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg62.def +106 -0
  488. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg7-memsrcdst.def +110 -0
  489. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg7.def +108 -0
  490. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg8.def +111 -0
  491. data/epeg/vendor/libjpeg-turbo-2.0.4/wizard.txt +212 -0
  492. data/epeg/vendor/libjpeg-turbo-2.0.4/wrbmp.c +558 -0
  493. data/epeg/vendor/libjpeg-turbo-2.0.4/wrgif.c +413 -0
  494. data/epeg/vendor/libjpeg-turbo-2.0.4/wrjpgcom.1 +103 -0
  495. data/epeg/vendor/libjpeg-turbo-2.0.4/wrjpgcom.c +591 -0
  496. data/epeg/vendor/libjpeg-turbo-2.0.4/wrppm.c +365 -0
  497. data/epeg/vendor/libjpeg-turbo-2.0.4/wrrle.c +309 -0
  498. data/epeg/vendor/libjpeg-turbo-2.0.4/wrtarga.c +261 -0
  499. data/epeg.c +131 -0
  500. data/epeg.gemspec +18 -0
  501. data/extconf.rb +80 -0
  502. data/test.jpg +0 -0
  503. data/test.rb +42 -0
  504. metadata +546 -0
@@ -0,0 +1,931 @@
1
+ /*
2
+ * Copyright (C)2009-2014, 2017-2019 D. R. Commander. All Rights Reserved.
3
+ *
4
+ * Redistribution and use in source and binary forms, with or without
5
+ * modification, are permitted provided that the following conditions are met:
6
+ *
7
+ * - Redistributions of source code must retain the above copyright notice,
8
+ * this list of conditions and the following disclaimer.
9
+ * - Redistributions in binary form must reproduce the above copyright notice,
10
+ * this list of conditions and the following disclaimer in the documentation
11
+ * and/or other materials provided with the distribution.
12
+ * - Neither the name of the libjpeg-turbo Project nor the names of its
13
+ * contributors may be used to endorse or promote products derived from this
14
+ * software without specific prior written permission.
15
+ *
16
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS",
17
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
20
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26
+ * POSSIBILITY OF SUCH DAMAGE.
27
+ */
28
+
29
+ /*
30
+ * This program tests the various code paths in the TurboJPEG C Wrapper
31
+ */
32
+
33
+ #include <stdio.h>
34
+ #include <stdlib.h>
35
+ #include <string.h>
36
+ #include <errno.h>
37
+ #include "tjutil.h"
38
+ #include "turbojpeg.h"
39
+ #include "md5/md5.h"
40
+ #include "cmyk.h"
41
+ #ifdef _WIN32
42
+ #include <time.h>
43
+ #define random() rand()
44
+ #else
45
+ #include <unistd.h>
46
+ #endif
47
+
48
+
49
+ static void usage(char *progName)
50
+ {
51
+ printf("\nUSAGE: %s [options]\n\n", progName);
52
+ printf("Options:\n");
53
+ printf("-yuv = test YUV encoding/decoding support\n");
54
+ printf("-noyuvpad = do not pad each line of each Y, U, and V plane to the nearest\n");
55
+ printf(" 4-byte boundary\n");
56
+ printf("-alloc = test automatic buffer allocation\n");
57
+ printf("-bmp = tjLoadImage()/tjSaveImage() unit test\n\n");
58
+ exit(1);
59
+ }
60
+
61
+
62
+ #define THROW_TJ() { \
63
+ printf("TurboJPEG ERROR:\n%s\n", tjGetErrorStr()); \
64
+ BAILOUT() \
65
+ }
66
+ #define TRY_TJ(f) { if ((f) == -1) THROW_TJ(); }
67
+ #define THROW(m) { printf("ERROR: %s\n", m); BAILOUT() }
68
+ #define THROW_MD5(filename, md5sum, ref) { \
69
+ printf("\n%s has an MD5 sum of %s.\n Should be %s.\n", filename, md5sum, \
70
+ ref); \
71
+ BAILOUT() \
72
+ }
73
+
74
+ const char *subNameLong[TJ_NUMSAMP] = {
75
+ "4:4:4", "4:2:2", "4:2:0", "GRAY", "4:4:0", "4:1:1"
76
+ };
77
+ const char *subName[TJ_NUMSAMP] = {
78
+ "444", "422", "420", "GRAY", "440", "411"
79
+ };
80
+
81
+ const char *pixFormatStr[TJ_NUMPF] = {
82
+ "RGB", "BGR", "RGBX", "BGRX", "XBGR", "XRGB", "Grayscale",
83
+ "RGBA", "BGRA", "ABGR", "ARGB", "CMYK"
84
+ };
85
+
86
+ const int _3byteFormats[] = { TJPF_RGB, TJPF_BGR };
87
+ const int _4byteFormats[] = {
88
+ TJPF_RGBX, TJPF_BGRX, TJPF_XBGR, TJPF_XRGB, TJPF_CMYK
89
+ };
90
+ const int _onlyGray[] = { TJPF_GRAY };
91
+ const int _onlyRGB[] = { TJPF_RGB };
92
+
93
+ int doYUV = 0, alloc = 0, pad = 4;
94
+
95
+ int exitStatus = 0;
96
+ #define BAILOUT() { exitStatus = -1; goto bailout; }
97
+
98
+
99
+ static void initBuf(unsigned char *buf, int w, int h, int pf, int flags)
100
+ {
101
+ int roffset = tjRedOffset[pf];
102
+ int goffset = tjGreenOffset[pf];
103
+ int boffset = tjBlueOffset[pf];
104
+ int ps = tjPixelSize[pf];
105
+ int index, row, col, halfway = 16;
106
+
107
+ if (pf == TJPF_GRAY) {
108
+ memset(buf, 0, w * h * ps);
109
+ for (row = 0; row < h; row++) {
110
+ for (col = 0; col < w; col++) {
111
+ if (flags & TJFLAG_BOTTOMUP) index = (h - row - 1) * w + col;
112
+ else index = row * w + col;
113
+ if (((row / 8) + (col / 8)) % 2 == 0)
114
+ buf[index] = (row < halfway) ? 255 : 0;
115
+ else buf[index] = (row < halfway) ? 76 : 226;
116
+ }
117
+ }
118
+ } else if (pf == TJPF_CMYK) {
119
+ memset(buf, 255, w * h * ps);
120
+ for (row = 0; row < h; row++) {
121
+ for (col = 0; col < w; col++) {
122
+ if (flags & TJFLAG_BOTTOMUP) index = (h - row - 1) * w + col;
123
+ else index = row * w + col;
124
+ if (((row / 8) + (col / 8)) % 2 == 0) {
125
+ if (row >= halfway) buf[index * ps + 3] = 0;
126
+ } else {
127
+ buf[index * ps + 2] = 0;
128
+ if (row < halfway) buf[index * ps + 1] = 0;
129
+ }
130
+ }
131
+ }
132
+ } else {
133
+ memset(buf, 0, w * h * ps);
134
+ for (row = 0; row < h; row++) {
135
+ for (col = 0; col < w; col++) {
136
+ if (flags & TJFLAG_BOTTOMUP) index = (h - row - 1) * w + col;
137
+ else index = row * w + col;
138
+ if (((row / 8) + (col / 8)) % 2 == 0) {
139
+ if (row < halfway) {
140
+ buf[index * ps + roffset] = 255;
141
+ buf[index * ps + goffset] = 255;
142
+ buf[index * ps + boffset] = 255;
143
+ }
144
+ } else {
145
+ buf[index * ps + roffset] = 255;
146
+ if (row >= halfway) buf[index * ps + goffset] = 255;
147
+ }
148
+ }
149
+ }
150
+ }
151
+ }
152
+
153
+
154
+ #define CHECKVAL(v, cv) { \
155
+ if (v < cv - 1 || v > cv + 1) { \
156
+ printf("\nComp. %s at %d,%d should be %d, not %d\n", #v, row, col, cv, \
157
+ v); \
158
+ retval = 0; exitStatus = -1; goto bailout; \
159
+ } \
160
+ }
161
+
162
+ #define CHECKVAL0(v) { \
163
+ if (v > 1) { \
164
+ printf("\nComp. %s at %d,%d should be 0, not %d\n", #v, row, col, v); \
165
+ retval = 0; exitStatus = -1; goto bailout; \
166
+ } \
167
+ }
168
+
169
+ #define CHECKVAL255(v) { \
170
+ if (v < 254) { \
171
+ printf("\nComp. %s at %d,%d should be 255, not %d\n", #v, row, col, v); \
172
+ retval = 0; exitStatus = -1; goto bailout; \
173
+ } \
174
+ }
175
+
176
+
177
+ static int checkBuf(unsigned char *buf, int w, int h, int pf, int subsamp,
178
+ tjscalingfactor sf, int flags)
179
+ {
180
+ int roffset = tjRedOffset[pf];
181
+ int goffset = tjGreenOffset[pf];
182
+ int boffset = tjBlueOffset[pf];
183
+ int aoffset = tjAlphaOffset[pf];
184
+ int ps = tjPixelSize[pf];
185
+ int index, row, col, retval = 1;
186
+ int halfway = 16 * sf.num / sf.denom;
187
+ int blocksize = 8 * sf.num / sf.denom;
188
+
189
+ if (pf == TJPF_GRAY) roffset = goffset = boffset = 0;
190
+
191
+ if (pf == TJPF_CMYK) {
192
+ for (row = 0; row < h; row++) {
193
+ for (col = 0; col < w; col++) {
194
+ unsigned char c, m, y, k;
195
+
196
+ if (flags & TJFLAG_BOTTOMUP) index = (h - row - 1) * w + col;
197
+ else index = row * w + col;
198
+ c = buf[index * ps];
199
+ m = buf[index * ps + 1];
200
+ y = buf[index * ps + 2];
201
+ k = buf[index * ps + 3];
202
+ if (((row / blocksize) + (col / blocksize)) % 2 == 0) {
203
+ CHECKVAL255(c); CHECKVAL255(m); CHECKVAL255(y);
204
+ if (row < halfway) CHECKVAL255(k)
205
+ else CHECKVAL0(k)
206
+ } else {
207
+ CHECKVAL255(c); CHECKVAL0(y); CHECKVAL255(k);
208
+ if (row < halfway) CHECKVAL0(m)
209
+ else CHECKVAL255(m)
210
+ }
211
+ }
212
+ }
213
+ return 1;
214
+ }
215
+
216
+ for (row = 0; row < h; row++) {
217
+ for (col = 0; col < w; col++) {
218
+ unsigned char r, g, b, a;
219
+
220
+ if (flags & TJFLAG_BOTTOMUP) index = (h - row - 1) * w + col;
221
+ else index = row * w + col;
222
+ r = buf[index * ps + roffset];
223
+ g = buf[index * ps + goffset];
224
+ b = buf[index * ps + boffset];
225
+ a = aoffset >= 0 ? buf[index * ps + aoffset] : 0xFF;
226
+ if (((row / blocksize) + (col / blocksize)) % 2 == 0) {
227
+ if (row < halfway) {
228
+ CHECKVAL255(r); CHECKVAL255(g); CHECKVAL255(b);
229
+ } else {
230
+ CHECKVAL0(r); CHECKVAL0(g); CHECKVAL0(b);
231
+ }
232
+ } else {
233
+ if (subsamp == TJSAMP_GRAY) {
234
+ if (row < halfway) {
235
+ CHECKVAL(r, 76); CHECKVAL(g, 76); CHECKVAL(b, 76);
236
+ } else {
237
+ CHECKVAL(r, 226); CHECKVAL(g, 226); CHECKVAL(b, 226);
238
+ }
239
+ } else {
240
+ if (row < halfway) {
241
+ CHECKVAL255(r); CHECKVAL0(g); CHECKVAL0(b);
242
+ } else {
243
+ CHECKVAL255(r); CHECKVAL255(g); CHECKVAL0(b);
244
+ }
245
+ }
246
+ }
247
+ CHECKVAL255(a);
248
+ }
249
+ }
250
+
251
+ bailout:
252
+ if (retval == 0) {
253
+ for (row = 0; row < h; row++) {
254
+ for (col = 0; col < w; col++) {
255
+ if (pf == TJPF_CMYK)
256
+ printf("%.3d/%.3d/%.3d/%.3d ", buf[(row * w + col) * ps],
257
+ buf[(row * w + col) * ps + 1], buf[(row * w + col) * ps + 2],
258
+ buf[(row * w + col) * ps + 3]);
259
+ else
260
+ printf("%.3d/%.3d/%.3d ", buf[(row * w + col) * ps + roffset],
261
+ buf[(row * w + col) * ps + goffset],
262
+ buf[(row * w + col) * ps + boffset]);
263
+ }
264
+ printf("\n");
265
+ }
266
+ }
267
+ return retval;
268
+ }
269
+
270
+
271
+ #define PAD(v, p) ((v + (p) - 1) & (~((p) - 1)))
272
+
273
+ static int checkBufYUV(unsigned char *buf, int w, int h, int subsamp,
274
+ tjscalingfactor sf)
275
+ {
276
+ int row, col;
277
+ int hsf = tjMCUWidth[subsamp] / 8, vsf = tjMCUHeight[subsamp] / 8;
278
+ int pw = PAD(w, hsf), ph = PAD(h, vsf);
279
+ int cw = pw / hsf, ch = ph / vsf;
280
+ int ypitch = PAD(pw, pad), uvpitch = PAD(cw, pad);
281
+ int retval = 1;
282
+ int halfway = 16 * sf.num / sf.denom;
283
+ int blocksize = 8 * sf.num / sf.denom;
284
+
285
+ for (row = 0; row < ph; row++) {
286
+ for (col = 0; col < pw; col++) {
287
+ unsigned char y = buf[ypitch * row + col];
288
+
289
+ if (((row / blocksize) + (col / blocksize)) % 2 == 0) {
290
+ if (row < halfway) CHECKVAL255(y)
291
+ else CHECKVAL0(y);
292
+ } else {
293
+ if (row < halfway) CHECKVAL(y, 76)
294
+ else CHECKVAL(y, 226);
295
+ }
296
+ }
297
+ }
298
+ if (subsamp != TJSAMP_GRAY) {
299
+ halfway = 16 / vsf * sf.num / sf.denom;
300
+
301
+ for (row = 0; row < ch; row++) {
302
+ for (col = 0; col < cw; col++) {
303
+ unsigned char u = buf[ypitch * ph + (uvpitch * row + col)],
304
+ v = buf[ypitch * ph + uvpitch * ch + (uvpitch * row + col)];
305
+
306
+ if (((row * vsf / blocksize) + (col * hsf / blocksize)) % 2 == 0) {
307
+ CHECKVAL(u, 128); CHECKVAL(v, 128);
308
+ } else {
309
+ if (row < halfway) {
310
+ CHECKVAL(u, 85); CHECKVAL255(v);
311
+ } else {
312
+ CHECKVAL0(u); CHECKVAL(v, 149);
313
+ }
314
+ }
315
+ }
316
+ }
317
+ }
318
+
319
+ bailout:
320
+ if (retval == 0) {
321
+ for (row = 0; row < ph; row++) {
322
+ for (col = 0; col < pw; col++)
323
+ printf("%.3d ", buf[ypitch * row + col]);
324
+ printf("\n");
325
+ }
326
+ printf("\n");
327
+ for (row = 0; row < ch; row++) {
328
+ for (col = 0; col < cw; col++)
329
+ printf("%.3d ", buf[ypitch * ph + (uvpitch * row + col)]);
330
+ printf("\n");
331
+ }
332
+ printf("\n");
333
+ for (row = 0; row < ch; row++) {
334
+ for (col = 0; col < cw; col++)
335
+ printf("%.3d ",
336
+ buf[ypitch * ph + uvpitch * ch + (uvpitch * row + col)]);
337
+ printf("\n");
338
+ }
339
+ }
340
+
341
+ return retval;
342
+ }
343
+
344
+
345
+ static void writeJPEG(unsigned char *jpegBuf, unsigned long jpegSize,
346
+ char *filename)
347
+ {
348
+ FILE *file = fopen(filename, "wb");
349
+
350
+ if (!file || fwrite(jpegBuf, jpegSize, 1, file) != 1) {
351
+ printf("ERROR: Could not write to %s.\n%s\n", filename, strerror(errno));
352
+ BAILOUT()
353
+ }
354
+
355
+ bailout:
356
+ if (file) fclose(file);
357
+ }
358
+
359
+
360
+ static void compTest(tjhandle handle, unsigned char **dstBuf,
361
+ unsigned long *dstSize, int w, int h, int pf,
362
+ char *basename, int subsamp, int jpegQual, int flags)
363
+ {
364
+ char tempStr[1024];
365
+ unsigned char *srcBuf = NULL, *yuvBuf = NULL;
366
+ const char *pfStr = pixFormatStr[pf];
367
+ const char *buStrLong =
368
+ (flags & TJFLAG_BOTTOMUP) ? "Bottom-Up" : "Top-Down ";
369
+ const char *buStr = (flags & TJFLAG_BOTTOMUP) ? "BU" : "TD";
370
+
371
+ if ((srcBuf = (unsigned char *)malloc(w * h * tjPixelSize[pf])) == NULL)
372
+ THROW("Memory allocation failure");
373
+ initBuf(srcBuf, w, h, pf, flags);
374
+
375
+ if (*dstBuf && *dstSize > 0) memset(*dstBuf, 0, *dstSize);
376
+
377
+ if (!alloc) flags |= TJFLAG_NOREALLOC;
378
+ if (doYUV) {
379
+ unsigned long yuvSize = tjBufSizeYUV2(w, pad, h, subsamp);
380
+ tjscalingfactor sf = { 1, 1 };
381
+ tjhandle handle2 = tjInitCompress();
382
+
383
+ if (!handle2) THROW_TJ();
384
+
385
+ if ((yuvBuf = (unsigned char *)malloc(yuvSize)) == NULL)
386
+ THROW("Memory allocation failure");
387
+ memset(yuvBuf, 0, yuvSize);
388
+
389
+ printf("%s %s -> YUV %s ... ", pfStr, buStrLong, subNameLong[subsamp]);
390
+ TRY_TJ(tjEncodeYUV3(handle2, srcBuf, w, 0, h, pf, yuvBuf, pad, subsamp,
391
+ flags));
392
+ tjDestroy(handle2);
393
+ if (checkBufYUV(yuvBuf, w, h, subsamp, sf)) printf("Passed.\n");
394
+ else printf("FAILED!\n");
395
+
396
+ printf("YUV %s %s -> JPEG Q%d ... ", subNameLong[subsamp], buStrLong,
397
+ jpegQual);
398
+ TRY_TJ(tjCompressFromYUV(handle, yuvBuf, w, pad, h, subsamp, dstBuf,
399
+ dstSize, jpegQual, flags));
400
+ } else {
401
+ printf("%s %s -> %s Q%d ... ", pfStr, buStrLong, subNameLong[subsamp],
402
+ jpegQual);
403
+ TRY_TJ(tjCompress2(handle, srcBuf, w, 0, h, pf, dstBuf, dstSize, subsamp,
404
+ jpegQual, flags));
405
+ }
406
+
407
+ snprintf(tempStr, 1024, "%s_enc_%s_%s_%s_Q%d.jpg", basename, pfStr, buStr,
408
+ subName[subsamp], jpegQual);
409
+ writeJPEG(*dstBuf, *dstSize, tempStr);
410
+ printf("Done.\n Result in %s\n", tempStr);
411
+
412
+ bailout:
413
+ if (yuvBuf) free(yuvBuf);
414
+ if (srcBuf) free(srcBuf);
415
+ }
416
+
417
+
418
+ static void _decompTest(tjhandle handle, unsigned char *jpegBuf,
419
+ unsigned long jpegSize, int w, int h, int pf,
420
+ char *basename, int subsamp, int flags,
421
+ tjscalingfactor sf)
422
+ {
423
+ unsigned char *dstBuf = NULL, *yuvBuf = NULL;
424
+ int _hdrw = 0, _hdrh = 0, _hdrsubsamp = -1;
425
+ int scaledWidth = TJSCALED(w, sf);
426
+ int scaledHeight = TJSCALED(h, sf);
427
+ unsigned long dstSize = 0;
428
+
429
+ TRY_TJ(tjDecompressHeader2(handle, jpegBuf, jpegSize, &_hdrw, &_hdrh,
430
+ &_hdrsubsamp));
431
+ if (_hdrw != w || _hdrh != h || _hdrsubsamp != subsamp)
432
+ THROW("Incorrect JPEG header");
433
+
434
+ dstSize = scaledWidth * scaledHeight * tjPixelSize[pf];
435
+ if ((dstBuf = (unsigned char *)malloc(dstSize)) == NULL)
436
+ THROW("Memory allocation failure");
437
+ memset(dstBuf, 0, dstSize);
438
+
439
+ if (doYUV) {
440
+ unsigned long yuvSize = tjBufSizeYUV2(scaledWidth, pad, scaledHeight,
441
+ subsamp);
442
+ tjhandle handle2 = tjInitDecompress();
443
+
444
+ if (!handle2) THROW_TJ();
445
+
446
+ if ((yuvBuf = (unsigned char *)malloc(yuvSize)) == NULL)
447
+ THROW("Memory allocation failure");
448
+ memset(yuvBuf, 0, yuvSize);
449
+
450
+ printf("JPEG -> YUV %s ", subNameLong[subsamp]);
451
+ if (sf.num != 1 || sf.denom != 1)
452
+ printf("%d/%d ... ", sf.num, sf.denom);
453
+ else printf("... ");
454
+ TRY_TJ(tjDecompressToYUV2(handle, jpegBuf, jpegSize, yuvBuf, scaledWidth,
455
+ pad, scaledHeight, flags));
456
+ if (checkBufYUV(yuvBuf, scaledWidth, scaledHeight, subsamp, sf))
457
+ printf("Passed.\n");
458
+ else printf("FAILED!\n");
459
+
460
+ printf("YUV %s -> %s %s ... ", subNameLong[subsamp], pixFormatStr[pf],
461
+ (flags & TJFLAG_BOTTOMUP) ? "Bottom-Up" : "Top-Down ");
462
+ TRY_TJ(tjDecodeYUV(handle2, yuvBuf, pad, subsamp, dstBuf, scaledWidth, 0,
463
+ scaledHeight, pf, flags));
464
+ tjDestroy(handle2);
465
+ } else {
466
+ printf("JPEG -> %s %s ", pixFormatStr[pf],
467
+ (flags & TJFLAG_BOTTOMUP) ? "Bottom-Up" : "Top-Down ");
468
+ if (sf.num != 1 || sf.denom != 1)
469
+ printf("%d/%d ... ", sf.num, sf.denom);
470
+ else printf("... ");
471
+ TRY_TJ(tjDecompress2(handle, jpegBuf, jpegSize, dstBuf, scaledWidth, 0,
472
+ scaledHeight, pf, flags));
473
+ }
474
+
475
+ if (checkBuf(dstBuf, scaledWidth, scaledHeight, pf, subsamp, sf, flags))
476
+ printf("Passed.");
477
+ else printf("FAILED!");
478
+ printf("\n");
479
+
480
+ bailout:
481
+ if (yuvBuf) free(yuvBuf);
482
+ if (dstBuf) free(dstBuf);
483
+ }
484
+
485
+
486
+ static void decompTest(tjhandle handle, unsigned char *jpegBuf,
487
+ unsigned long jpegSize, int w, int h, int pf,
488
+ char *basename, int subsamp, int flags)
489
+ {
490
+ int i, n = 0;
491
+ tjscalingfactor *sf = tjGetScalingFactors(&n);
492
+
493
+ if (!sf || !n) THROW_TJ();
494
+
495
+ for (i = 0; i < n; i++) {
496
+ if (subsamp == TJSAMP_444 || subsamp == TJSAMP_GRAY ||
497
+ (subsamp == TJSAMP_411 && sf[i].num == 1 &&
498
+ (sf[i].denom == 2 || sf[i].denom == 1)) ||
499
+ (subsamp != TJSAMP_411 && sf[i].num == 1 &&
500
+ (sf[i].denom == 4 || sf[i].denom == 2 || sf[i].denom == 1)))
501
+ _decompTest(handle, jpegBuf, jpegSize, w, h, pf, basename, subsamp,
502
+ flags, sf[i]);
503
+ }
504
+
505
+ bailout:
506
+ return;
507
+ }
508
+
509
+
510
+ static void doTest(int w, int h, const int *formats, int nformats, int subsamp,
511
+ char *basename)
512
+ {
513
+ tjhandle chandle = NULL, dhandle = NULL;
514
+ unsigned char *dstBuf = NULL;
515
+ unsigned long size = 0;
516
+ int pfi, pf, i;
517
+
518
+ if (!alloc)
519
+ size = tjBufSize(w, h, subsamp);
520
+ if (size != 0)
521
+ if ((dstBuf = (unsigned char *)tjAlloc(size)) == NULL)
522
+ THROW("Memory allocation failure.");
523
+
524
+ if ((chandle = tjInitCompress()) == NULL ||
525
+ (dhandle = tjInitDecompress()) == NULL)
526
+ THROW_TJ();
527
+
528
+ for (pfi = 0; pfi < nformats; pfi++) {
529
+ for (i = 0; i < 2; i++) {
530
+ int flags = 0;
531
+
532
+ if (subsamp == TJSAMP_422 || subsamp == TJSAMP_420 ||
533
+ subsamp == TJSAMP_440 || subsamp == TJSAMP_411)
534
+ flags |= TJFLAG_FASTUPSAMPLE;
535
+ if (i == 1) flags |= TJFLAG_BOTTOMUP;
536
+ pf = formats[pfi];
537
+ compTest(chandle, &dstBuf, &size, w, h, pf, basename, subsamp, 100,
538
+ flags);
539
+ decompTest(dhandle, dstBuf, size, w, h, pf, basename, subsamp, flags);
540
+ if (pf >= TJPF_RGBX && pf <= TJPF_XRGB) {
541
+ printf("\n");
542
+ decompTest(dhandle, dstBuf, size, w, h, pf + (TJPF_RGBA - TJPF_RGBX),
543
+ basename, subsamp, flags);
544
+ }
545
+ printf("\n");
546
+ }
547
+ }
548
+ printf("--------------------\n\n");
549
+
550
+ bailout:
551
+ if (chandle) tjDestroy(chandle);
552
+ if (dhandle) tjDestroy(dhandle);
553
+ if (dstBuf) tjFree(dstBuf);
554
+ }
555
+
556
+
557
+ #if SIZEOF_SIZE_T == 8
558
+ #define CHECKSIZE(function) { \
559
+ if ((unsigned long long)size < (unsigned long long)0xFFFFFFFF) \
560
+ THROW(#function " overflow"); \
561
+ }
562
+ #else
563
+ #define CHECKSIZE(function) { \
564
+ if (size != (unsigned long)(-1) || \
565
+ !strcmp(tjGetErrorStr2(NULL), "No error")) \
566
+ THROW(#function " overflow"); \
567
+ }
568
+ #endif
569
+
570
+ static void overflowTest(void)
571
+ {
572
+ /* Ensure that the various buffer size functions don't overflow */
573
+ unsigned long size;
574
+
575
+ size = tjBufSize(26755, 26755, TJSAMP_444);
576
+ CHECKSIZE(tjBufSize());
577
+ size = TJBUFSIZE(26755, 26755);
578
+ CHECKSIZE(TJBUFSIZE());
579
+ size = tjBufSizeYUV2(37838, 1, 37838, TJSAMP_444);
580
+ CHECKSIZE(tjBufSizeYUV2());
581
+ size = TJBUFSIZEYUV(37838, 37838, TJSAMP_444);
582
+ CHECKSIZE(TJBUFSIZEYUV());
583
+ size = tjBufSizeYUV(37838, 37838, TJSAMP_444);
584
+ CHECKSIZE(tjBufSizeYUV());
585
+ size = tjPlaneSizeYUV(0, 65536, 0, 65536, TJSAMP_444);
586
+ CHECKSIZE(tjPlaneSizeYUV());
587
+
588
+ bailout:
589
+ return;
590
+ }
591
+
592
+
593
+ static void bufSizeTest(void)
594
+ {
595
+ int w, h, i, subsamp;
596
+ unsigned char *srcBuf = NULL, *dstBuf = NULL;
597
+ tjhandle handle = NULL;
598
+ unsigned long dstSize = 0;
599
+
600
+ if ((handle = tjInitCompress()) == NULL) THROW_TJ();
601
+
602
+ printf("Buffer size regression test\n");
603
+ for (subsamp = 0; subsamp < TJ_NUMSAMP; subsamp++) {
604
+ for (w = 1; w < 48; w++) {
605
+ int maxh = (w == 1) ? 2048 : 48;
606
+
607
+ for (h = 1; h < maxh; h++) {
608
+ if (h % 100 == 0) printf("%.4d x %.4d\b\b\b\b\b\b\b\b\b\b\b", w, h);
609
+ if ((srcBuf = (unsigned char *)malloc(w * h * 4)) == NULL)
610
+ THROW("Memory allocation failure");
611
+ if (!alloc || doYUV) {
612
+ if (doYUV) dstSize = tjBufSizeYUV2(w, pad, h, subsamp);
613
+ else dstSize = tjBufSize(w, h, subsamp);
614
+ if ((dstBuf = (unsigned char *)tjAlloc(dstSize)) == NULL)
615
+ THROW("Memory allocation failure");
616
+ }
617
+
618
+ for (i = 0; i < w * h * 4; i++) {
619
+ if (random() < RAND_MAX / 2) srcBuf[i] = 0;
620
+ else srcBuf[i] = 255;
621
+ }
622
+
623
+ if (doYUV) {
624
+ TRY_TJ(tjEncodeYUV3(handle, srcBuf, w, 0, h, TJPF_BGRX, dstBuf, pad,
625
+ subsamp, 0));
626
+ } else {
627
+ TRY_TJ(tjCompress2(handle, srcBuf, w, 0, h, TJPF_BGRX, &dstBuf,
628
+ &dstSize, subsamp, 100,
629
+ alloc ? 0 : TJFLAG_NOREALLOC));
630
+ }
631
+ free(srcBuf); srcBuf = NULL;
632
+ if (!alloc || doYUV) {
633
+ tjFree(dstBuf); dstBuf = NULL;
634
+ }
635
+
636
+ if ((srcBuf = (unsigned char *)malloc(h * w * 4)) == NULL)
637
+ THROW("Memory allocation failure");
638
+ if (!alloc || doYUV) {
639
+ if (doYUV) dstSize = tjBufSizeYUV2(h, pad, w, subsamp);
640
+ else dstSize = tjBufSize(h, w, subsamp);
641
+ if ((dstBuf = (unsigned char *)tjAlloc(dstSize)) == NULL)
642
+ THROW("Memory allocation failure");
643
+ }
644
+
645
+ for (i = 0; i < h * w * 4; i++) {
646
+ if (random() < RAND_MAX / 2) srcBuf[i] = 0;
647
+ else srcBuf[i] = 255;
648
+ }
649
+
650
+ if (doYUV) {
651
+ TRY_TJ(tjEncodeYUV3(handle, srcBuf, h, 0, w, TJPF_BGRX, dstBuf, pad,
652
+ subsamp, 0));
653
+ } else {
654
+ TRY_TJ(tjCompress2(handle, srcBuf, h, 0, w, TJPF_BGRX, &dstBuf,
655
+ &dstSize, subsamp, 100,
656
+ alloc ? 0 : TJFLAG_NOREALLOC));
657
+ }
658
+ free(srcBuf); srcBuf = NULL;
659
+ if (!alloc || doYUV) {
660
+ tjFree(dstBuf); dstBuf = NULL;
661
+ }
662
+ }
663
+ }
664
+ }
665
+ printf("Done. \n");
666
+
667
+ bailout:
668
+ if (srcBuf) free(srcBuf);
669
+ if (dstBuf) tjFree(dstBuf);
670
+ if (handle) tjDestroy(handle);
671
+ }
672
+
673
+
674
+ static void initBitmap(unsigned char *buf, int width, int pitch, int height,
675
+ int pf, int flags)
676
+ {
677
+ int roffset = tjRedOffset[pf];
678
+ int goffset = tjGreenOffset[pf];
679
+ int boffset = tjBlueOffset[pf];
680
+ int ps = tjPixelSize[pf];
681
+ int i, j;
682
+
683
+ for (j = 0; j < height; j++) {
684
+ int row = (flags & TJFLAG_BOTTOMUP) ? height - j - 1 : j;
685
+
686
+ for (i = 0; i < width; i++) {
687
+ unsigned char r = (i * 256 / width) % 256;
688
+ unsigned char g = (j * 256 / height) % 256;
689
+ unsigned char b = (j * 256 / height + i * 256 / width) % 256;
690
+
691
+ memset(&buf[row * pitch + i * ps], 0, ps);
692
+ if (pf == TJPF_GRAY) buf[row * pitch + i * ps] = b;
693
+ else if (pf == TJPF_CMYK)
694
+ rgb_to_cmyk(r, g, b, &buf[row * pitch + i * ps + 0],
695
+ &buf[row * pitch + i * ps + 1],
696
+ &buf[row * pitch + i * ps + 2],
697
+ &buf[row * pitch + i * ps + 3]);
698
+ else {
699
+ buf[row * pitch + i * ps + roffset] = r;
700
+ buf[row * pitch + i * ps + goffset] = g;
701
+ buf[row * pitch + i * ps + boffset] = b;
702
+ }
703
+ }
704
+ }
705
+ }
706
+
707
+
708
+ static int cmpBitmap(unsigned char *buf, int width, int pitch, int height,
709
+ int pf, int flags, int gray2rgb)
710
+ {
711
+ int roffset = tjRedOffset[pf];
712
+ int goffset = tjGreenOffset[pf];
713
+ int boffset = tjBlueOffset[pf];
714
+ int aoffset = tjAlphaOffset[pf];
715
+ int ps = tjPixelSize[pf];
716
+ int i, j;
717
+
718
+ for (j = 0; j < height; j++) {
719
+ int row = (flags & TJFLAG_BOTTOMUP) ? height - j - 1 : j;
720
+
721
+ for (i = 0; i < width; i++) {
722
+ unsigned char r = (i * 256 / width) % 256;
723
+ unsigned char g = (j * 256 / height) % 256;
724
+ unsigned char b = (j * 256 / height + i * 256 / width) % 256;
725
+
726
+ if (pf == TJPF_GRAY) {
727
+ if (buf[row * pitch + i * ps] != b)
728
+ return 0;
729
+ } else if (pf == TJPF_CMYK) {
730
+ unsigned char rf, gf, bf;
731
+
732
+ cmyk_to_rgb(buf[row * pitch + i * ps + 0],
733
+ buf[row * pitch + i * ps + 1],
734
+ buf[row * pitch + i * ps + 2],
735
+ buf[row * pitch + i * ps + 3], &rf, &gf, &bf);
736
+ if (gray2rgb) {
737
+ if (rf != b || gf != b || bf != b)
738
+ return 0;
739
+ } else if (rf != r || gf != g || bf != b) return 0;
740
+ } else {
741
+ if (gray2rgb) {
742
+ if (buf[row * pitch + i * ps + roffset] != b ||
743
+ buf[row * pitch + i * ps + goffset] != b ||
744
+ buf[row * pitch + i * ps + boffset] != b)
745
+ return 0;
746
+ } else if (buf[row * pitch + i * ps + roffset] != r ||
747
+ buf[row * pitch + i * ps + goffset] != g ||
748
+ buf[row * pitch + i * ps + boffset] != b)
749
+ return 0;
750
+ if (aoffset >= 0 && buf[row * pitch + i * ps + aoffset] != 0xFF)
751
+ return 0;
752
+ }
753
+ }
754
+ }
755
+ return 1;
756
+ }
757
+
758
+
759
+ static int doBmpTest(const char *ext, int width, int align, int height, int pf,
760
+ int flags)
761
+ {
762
+ char filename[80], *md5sum, md5buf[65];
763
+ int ps = tjPixelSize[pf], pitch = PAD(width * ps, align), loadWidth = 0,
764
+ loadHeight = 0, retval = 0, pixelFormat = pf;
765
+ unsigned char *buf = NULL;
766
+ char *md5ref;
767
+
768
+ if (pf == TJPF_GRAY) {
769
+ md5ref = !strcasecmp(ext, "ppm") ? "112c682e82ce5de1cca089e20d60000b" :
770
+ "51976530acf75f02beddf5d21149101d";
771
+ } else {
772
+ md5ref = !strcasecmp(ext, "ppm") ? "c0c9f772b464d1896326883a5c79c545" :
773
+ "6d659071b9bfcdee2def22cb58ddadca";
774
+ }
775
+
776
+ if ((buf = (unsigned char *)tjAlloc(pitch * height)) == NULL)
777
+ THROW("Could not allocate memory");
778
+ initBitmap(buf, width, pitch, height, pf, flags);
779
+
780
+ snprintf(filename, 80, "test_bmp_%s_%d_%s.%s", pixFormatStr[pf], align,
781
+ (flags & TJFLAG_BOTTOMUP) ? "bu" : "td", ext);
782
+ TRY_TJ(tjSaveImage(filename, buf, width, pitch, height, pf, flags));
783
+ md5sum = MD5File(filename, md5buf);
784
+ if (strcasecmp(md5sum, md5ref))
785
+ THROW_MD5(filename, md5sum, md5ref);
786
+
787
+ tjFree(buf); buf = NULL;
788
+ if ((buf = tjLoadImage(filename, &loadWidth, align, &loadHeight, &pf,
789
+ flags)) == NULL)
790
+ THROW_TJ();
791
+ if (width != loadWidth || height != loadHeight) {
792
+ printf("\n Image dimensions of %s are bogus\n", filename);
793
+ retval = -1; goto bailout;
794
+ }
795
+ if (!cmpBitmap(buf, width, pitch, height, pf, flags, 0)) {
796
+ printf("\n Pixel data in %s is bogus\n", filename);
797
+ retval = -1; goto bailout;
798
+ }
799
+ if (pf == TJPF_GRAY) {
800
+ tjFree(buf); buf = NULL;
801
+ pf = TJPF_XBGR;
802
+ if ((buf = tjLoadImage(filename, &loadWidth, align, &loadHeight, &pf,
803
+ flags)) == NULL)
804
+ THROW_TJ();
805
+ pitch = PAD(width * tjPixelSize[pf], align);
806
+ if (!cmpBitmap(buf, width, pitch, height, pf, flags, 1)) {
807
+ printf("\n Converting %s to RGB failed\n", filename);
808
+ retval = -1; goto bailout;
809
+ }
810
+
811
+ tjFree(buf); buf = NULL;
812
+ pf = TJPF_CMYK;
813
+ if ((buf = tjLoadImage(filename, &loadWidth, align, &loadHeight, &pf,
814
+ flags)) == NULL)
815
+ THROW_TJ();
816
+ pitch = PAD(width * tjPixelSize[pf], align);
817
+ if (!cmpBitmap(buf, width, pitch, height, pf, flags, 1)) {
818
+ printf("\n Converting %s to CMYK failed\n", filename);
819
+ retval = -1; goto bailout;
820
+ }
821
+ }
822
+ /* Verify that tjLoadImage() returns the proper "preferred" pixel format for
823
+ the file type. */
824
+ tjFree(buf); buf = NULL;
825
+ pf = pixelFormat;
826
+ pixelFormat = TJPF_UNKNOWN;
827
+ if ((buf = tjLoadImage(filename, &loadWidth, align, &loadHeight,
828
+ &pixelFormat, flags)) == NULL)
829
+ THROW_TJ();
830
+ if ((pf == TJPF_GRAY && pixelFormat != TJPF_GRAY) ||
831
+ (pf != TJPF_GRAY && !strcasecmp(ext, "bmp") &&
832
+ pixelFormat != TJPF_BGR) ||
833
+ (pf != TJPF_GRAY && !strcasecmp(ext, "ppm") &&
834
+ pixelFormat != TJPF_RGB)) {
835
+ printf("\n tjLoadImage() returned unexpected pixel format: %s\n",
836
+ pixFormatStr[pixelFormat]);
837
+ retval = -1;
838
+ }
839
+ unlink(filename);
840
+
841
+ bailout:
842
+ if (buf) tjFree(buf);
843
+ if (exitStatus < 0) return exitStatus;
844
+ return retval;
845
+ }
846
+
847
+
848
+ static int bmpTest(void)
849
+ {
850
+ int align, width = 35, height = 39, format;
851
+
852
+ for (align = 1; align <= 8; align *= 2) {
853
+ for (format = 0; format < TJ_NUMPF; format++) {
854
+ printf("%s Top-Down BMP (row alignment = %d bytes) ... ",
855
+ pixFormatStr[format], align);
856
+ if (doBmpTest("bmp", width, align, height, format, 0) == -1)
857
+ return -1;
858
+ printf("OK.\n");
859
+
860
+ printf("%s Top-Down PPM (row alignment = %d bytes) ... ",
861
+ pixFormatStr[format], align);
862
+ if (doBmpTest("ppm", width, align, height, format,
863
+ TJFLAG_BOTTOMUP) == -1)
864
+ return -1;
865
+ printf("OK.\n");
866
+
867
+ printf("%s Bottom-Up BMP (row alignment = %d bytes) ... ",
868
+ pixFormatStr[format], align);
869
+ if (doBmpTest("bmp", width, align, height, format, 0) == -1)
870
+ return -1;
871
+ printf("OK.\n");
872
+
873
+ printf("%s Bottom-Up PPM (row alignment = %d bytes) ... ",
874
+ pixFormatStr[format], align);
875
+ if (doBmpTest("ppm", width, align, height, format,
876
+ TJFLAG_BOTTOMUP) == -1)
877
+ return -1;
878
+ printf("OK.\n");
879
+ }
880
+ }
881
+
882
+ return 0;
883
+ }
884
+
885
+
886
+ int main(int argc, char *argv[])
887
+ {
888
+ int i, num4bf = 5;
889
+
890
+ #ifdef _WIN32
891
+ srand((unsigned int)time(NULL));
892
+ #endif
893
+ if (argc > 1) {
894
+ for (i = 1; i < argc; i++) {
895
+ if (!strcasecmp(argv[i], "-yuv")) doYUV = 1;
896
+ else if (!strcasecmp(argv[i], "-noyuvpad")) pad = 1;
897
+ else if (!strcasecmp(argv[i], "-alloc")) alloc = 1;
898
+ else if (!strcasecmp(argv[i], "-bmp")) return bmpTest();
899
+ else usage(argv[0]);
900
+ }
901
+ }
902
+ if (alloc) printf("Testing automatic buffer allocation\n");
903
+ if (doYUV) num4bf = 4;
904
+ overflowTest();
905
+ doTest(35, 39, _3byteFormats, 2, TJSAMP_444, "test");
906
+ doTest(39, 41, _4byteFormats, num4bf, TJSAMP_444, "test");
907
+ doTest(41, 35, _3byteFormats, 2, TJSAMP_422, "test");
908
+ doTest(35, 39, _4byteFormats, num4bf, TJSAMP_422, "test");
909
+ doTest(39, 41, _3byteFormats, 2, TJSAMP_420, "test");
910
+ doTest(41, 35, _4byteFormats, num4bf, TJSAMP_420, "test");
911
+ doTest(35, 39, _3byteFormats, 2, TJSAMP_440, "test");
912
+ doTest(39, 41, _4byteFormats, num4bf, TJSAMP_440, "test");
913
+ doTest(41, 35, _3byteFormats, 2, TJSAMP_411, "test");
914
+ doTest(35, 39, _4byteFormats, num4bf, TJSAMP_411, "test");
915
+ doTest(39, 41, _onlyGray, 1, TJSAMP_GRAY, "test");
916
+ doTest(41, 35, _3byteFormats, 2, TJSAMP_GRAY, "test");
917
+ doTest(35, 39, _4byteFormats, 4, TJSAMP_GRAY, "test");
918
+ bufSizeTest();
919
+ if (doYUV) {
920
+ printf("\n--------------------\n\n");
921
+ doTest(48, 48, _onlyRGB, 1, TJSAMP_444, "test_yuv0");
922
+ doTest(48, 48, _onlyRGB, 1, TJSAMP_422, "test_yuv0");
923
+ doTest(48, 48, _onlyRGB, 1, TJSAMP_420, "test_yuv0");
924
+ doTest(48, 48, _onlyRGB, 1, TJSAMP_440, "test_yuv0");
925
+ doTest(48, 48, _onlyRGB, 1, TJSAMP_411, "test_yuv0");
926
+ doTest(48, 48, _onlyRGB, 1, TJSAMP_GRAY, "test_yuv0");
927
+ doTest(48, 48, _onlyGray, 1, TJSAMP_GRAY, "test_yuv0");
928
+ }
929
+
930
+ return exitStatus;
931
+ }