laag-libpng 1.6.34.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (452) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +57 -0
  3. data/LICENSE.txt +133 -0
  4. data/README.org +34 -0
  5. data/ext/laag/libpng/extconf.rb +13 -0
  6. data/laag-libpng.gemspec +20 -0
  7. data/lib/laag/libpng.rb +29 -0
  8. data/vendor/git.code.sf.net/p/libpng/code/ANNOUNCE +35 -0
  9. data/vendor/git.code.sf.net/p/libpng/code/CHANGES +6051 -0
  10. data/vendor/git.code.sf.net/p/libpng/code/CMakeLists.txt +945 -0
  11. data/vendor/git.code.sf.net/p/libpng/code/INSTALL +465 -0
  12. data/vendor/git.code.sf.net/p/libpng/code/LICENSE +133 -0
  13. data/vendor/git.code.sf.net/p/libpng/code/Makefile.am +392 -0
  14. data/vendor/git.code.sf.net/p/libpng/code/README +222 -0
  15. data/vendor/git.code.sf.net/p/libpng/code/TODO +30 -0
  16. data/vendor/git.code.sf.net/p/libpng/code/arm/arm_init.c +135 -0
  17. data/vendor/git.code.sf.net/p/libpng/code/arm/filter_neon.S +253 -0
  18. data/vendor/git.code.sf.net/p/libpng/code/arm/filter_neon_intrinsics.c +387 -0
  19. data/vendor/git.code.sf.net/p/libpng/code/autogen.sh +225 -0
  20. data/vendor/git.code.sf.net/p/libpng/code/configure.ac +533 -0
  21. data/vendor/git.code.sf.net/p/libpng/code/contrib/README.txt +5 -0
  22. data/vendor/git.code.sf.net/p/libpng/code/contrib/arm-neon/README +83 -0
  23. data/vendor/git.code.sf.net/p/libpng/code/contrib/arm-neon/android-ndk.c +39 -0
  24. data/vendor/git.code.sf.net/p/libpng/code/contrib/arm-neon/linux-auxv.c +120 -0
  25. data/vendor/git.code.sf.net/p/libpng/code/contrib/arm-neon/linux.c +161 -0
  26. data/vendor/git.code.sf.net/p/libpng/code/contrib/conftest/README +49 -0
  27. data/vendor/git.code.sf.net/p/libpng/code/contrib/conftest/pngcp.dfa +57 -0
  28. data/vendor/git.code.sf.net/p/libpng/code/contrib/conftest/read.dfa +58 -0
  29. data/vendor/git.code.sf.net/p/libpng/code/contrib/conftest/s_read.dfa +35 -0
  30. data/vendor/git.code.sf.net/p/libpng/code/contrib/conftest/s_write.dfa +33 -0
  31. data/vendor/git.code.sf.net/p/libpng/code/contrib/conftest/simple.dfa +36 -0
  32. data/vendor/git.code.sf.net/p/libpng/code/contrib/conftest/write.dfa +45 -0
  33. data/vendor/git.code.sf.net/p/libpng/code/contrib/examples/README.txt +24 -0
  34. data/vendor/git.code.sf.net/p/libpng/code/contrib/examples/iccfrompng.c +185 -0
  35. data/vendor/git.code.sf.net/p/libpng/code/contrib/examples/pngpixel.c +371 -0
  36. data/vendor/git.code.sf.net/p/libpng/code/contrib/examples/pngtopng.c +98 -0
  37. data/vendor/git.code.sf.net/p/libpng/code/contrib/examples/simpleover.c +648 -0
  38. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/COPYING +340 -0
  39. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/LICENSE +50 -0
  40. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/Makefile.mingw32 +131 -0
  41. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/Makefile.sgi +105 -0
  42. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/Makefile.unx +134 -0
  43. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/Makefile.w32 +114 -0
  44. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/README +186 -0
  45. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/makevms.com +132 -0
  46. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/readpng.c +323 -0
  47. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/readpng.h +88 -0
  48. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/readpng2.c +521 -0
  49. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/readpng2.h +116 -0
  50. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/readppm.c +188 -0
  51. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/rpng-win.c +735 -0
  52. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/rpng-x.c +911 -0
  53. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/rpng2-win.c +1261 -0
  54. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/rpng2-x.c +2143 -0
  55. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/toucan.png +0 -0
  56. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/wpng.c +865 -0
  57. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/writepng.c +401 -0
  58. data/vendor/git.code.sf.net/p/libpng/code/contrib/gregbook/writepng.h +133 -0
  59. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/fakepng.c +65 -0
  60. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/gentests.sh +102 -0
  61. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/makepng.c +1941 -0
  62. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/pngimage.c +1712 -0
  63. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/pngstest-errors.h +165 -0
  64. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/pngstest.c +3829 -0
  65. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/pngunknown.c +1294 -0
  66. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/pngvalid.c +12230 -0
  67. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/readpng.c +115 -0
  68. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/tarith.c +999 -0
  69. data/vendor/git.code.sf.net/p/libpng/code/contrib/libtests/timepng.c +608 -0
  70. data/vendor/git.code.sf.net/p/libpng/code/contrib/mips-msa/README +83 -0
  71. data/vendor/git.code.sf.net/p/libpng/code/contrib/mips-msa/linux.c +64 -0
  72. data/vendor/git.code.sf.net/p/libpng/code/contrib/oss-fuzz/Dockerfile +24 -0
  73. data/vendor/git.code.sf.net/p/libpng/code/contrib/oss-fuzz/README.txt +37 -0
  74. data/vendor/git.code.sf.net/p/libpng/code/contrib/oss-fuzz/build.sh +50 -0
  75. data/vendor/git.code.sf.net/p/libpng/code/contrib/oss-fuzz/libpng_read_fuzzer.cc +180 -0
  76. data/vendor/git.code.sf.net/p/libpng/code/contrib/oss-fuzz/libpng_read_fuzzer.options +2 -0
  77. data/vendor/git.code.sf.net/p/libpng/code/contrib/oss-fuzz/newcc +190 -0
  78. data/vendor/git.code.sf.net/p/libpng/code/contrib/oss-fuzz/png.dict +39 -0
  79. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/README +5 -0
  80. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/decoder/README +10 -0
  81. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/decoder/makefile +151 -0
  82. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/decoder/pngusr.dfa +40 -0
  83. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/decoder/pngusr.h +23 -0
  84. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/encoder/README +10 -0
  85. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/encoder/makefile +150 -0
  86. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/encoder/pngusr.dfa +39 -0
  87. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/encoder/pngusr.h +23 -0
  88. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/preader/README +15 -0
  89. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/preader/makefile +166 -0
  90. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/preader/pngusr.dfa +40 -0
  91. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminim/preader/pngusr.h +23 -0
  92. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/README +153 -0
  93. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/makefile.std +66 -0
  94. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/makefile.tc3 +38 -0
  95. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/makevms.com +92 -0
  96. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/png2pnm.bat +41 -0
  97. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/png2pnm.c +460 -0
  98. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/png2pnm.sh +42 -0
  99. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/pngminus.bat +4 -0
  100. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/pngminus.sh +5 -0
  101. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/pnm2png.bat +41 -0
  102. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/pnm2png.c +638 -0
  103. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngminus/pnm2png.sh +42 -0
  104. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/README +105 -0
  105. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn0g01.png +0 -0
  106. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn0g02.png +0 -0
  107. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn0g04.png +0 -0
  108. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn0g08.png +0 -0
  109. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn0g16.png +0 -0
  110. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn2c08.png +0 -0
  111. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn2c16.png +0 -0
  112. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn3p01.png +0 -0
  113. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn3p02.png +0 -0
  114. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn3p04.png +0 -0
  115. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn3p08.png +0 -0
  116. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn4a08.png +0 -0
  117. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn4a16.png +0 -0
  118. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn6a08.png +0 -0
  119. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/basn6a16.png +0 -0
  120. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbbn0g01.png +0 -0
  121. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbbn0g02.png +0 -0
  122. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbbn0g04.png +0 -0
  123. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbbn2c16.png +0 -0
  124. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbbn3p08.png +0 -0
  125. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbgn2c16.png +0 -0
  126. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbgn3p08.png +0 -0
  127. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbrn2c08.png +0 -0
  128. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbwn0g16.png +0 -0
  129. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbwn3p08.png +0 -0
  130. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftbyn3p08.png +0 -0
  131. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftp0n0g08.png +0 -0
  132. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftp0n2c08.png +0 -0
  133. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftp0n3p08.png +0 -0
  134. data/vendor/git.code.sf.net/p/libpng/code/contrib/pngsuite/ftp1n3p08.png +0 -0
  135. data/vendor/git.code.sf.net/p/libpng/code/contrib/powerpc-vsx/README +81 -0
  136. data/vendor/git.code.sf.net/p/libpng/code/contrib/powerpc-vsx/linux.c +57 -0
  137. data/vendor/git.code.sf.net/p/libpng/code/contrib/powerpc-vsx/linux_aux.c +36 -0
  138. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/bad_iCCP.png +0 -0
  139. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/badadler.png +0 -0
  140. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/badcrc.png +0 -0
  141. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/empty_ancillary_chunks.png +0 -0
  142. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_IDAT.png +0 -0
  143. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_bKGD_chunk.png +0 -0
  144. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_cHRM_chunk.png +0 -0
  145. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_eXIf_chunk.png +0 -0
  146. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_gAMA_chunk.png +0 -0
  147. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_hIST_chunk.png +0 -0
  148. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_iCCP_chunk.png +0 -0
  149. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_iTXt_chunk.png +0 -0
  150. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_juNK_unsafe_to_copy.png +0 -0
  151. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_juNk_safe_to_copy.png +0 -0
  152. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_pCAL_chunk.png +0 -0
  153. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_pHYs_chunk.png +0 -0
  154. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_sCAL_chunk.png +0 -0
  155. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_sPLT_chunk.png +0 -0
  156. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_sRGB_chunk.png +0 -0
  157. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_sTER_chunk.png +0 -0
  158. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_tEXt_chunk.png +0 -0
  159. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_tIME_chunk.png +0 -0
  160. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/crashers/huge_zTXt_chunk.png +0 -0
  161. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1-1.8-tRNS.png +0 -0
  162. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1-1.8.png +0 -0
  163. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1-linear-tRNS.png +0 -0
  164. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1-linear.png +0 -0
  165. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1-sRGB-tRNS.png +0 -0
  166. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1-sRGB.png +0 -0
  167. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1-tRNS.png +0 -0
  168. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-1.png +0 -0
  169. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16-1.8-tRNS.png +0 -0
  170. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16-1.8.png +0 -0
  171. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16-linear-tRNS.png +0 -0
  172. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16-linear.png +0 -0
  173. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16-sRGB-tRNS.png +0 -0
  174. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16-sRGB.png +0 -0
  175. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16-tRNS.png +0 -0
  176. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-16.png +0 -0
  177. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2-1.8-tRNS.png +0 -0
  178. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2-1.8.png +0 -0
  179. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2-linear-tRNS.png +0 -0
  180. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2-linear.png +0 -0
  181. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2-sRGB-tRNS.png +0 -0
  182. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2-sRGB.png +0 -0
  183. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2-tRNS.png +0 -0
  184. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-2.png +0 -0
  185. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4-1.8-tRNS.png +0 -0
  186. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4-1.8.png +0 -0
  187. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4-linear-tRNS.png +0 -0
  188. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4-linear.png +0 -0
  189. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4-sRGB-tRNS.png +0 -0
  190. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4-sRGB.png +0 -0
  191. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4-tRNS.png +0 -0
  192. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-4.png +0 -0
  193. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8-1.8-tRNS.png +0 -0
  194. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8-1.8.png +0 -0
  195. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8-linear-tRNS.png +0 -0
  196. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8-linear.png +0 -0
  197. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8-sRGB-tRNS.png +0 -0
  198. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8-sRGB.png +0 -0
  199. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8-tRNS.png +0 -0
  200. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-8.png +0 -0
  201. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-16-1.8.png +0 -0
  202. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-16-linear.png +0 -0
  203. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-16-sRGB.png +0 -0
  204. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-16.png +0 -0
  205. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-8-1.8.png +0 -0
  206. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-8-linear.png +0 -0
  207. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-8-sRGB.png +0 -0
  208. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/gray-alpha-8.png +0 -0
  209. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/makepngs.sh +94 -0
  210. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1-1.8-tRNS.png +0 -0
  211. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1-1.8.png +0 -0
  212. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1-linear-tRNS.png +0 -0
  213. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1-linear.png +0 -0
  214. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1-sRGB-tRNS.png +0 -0
  215. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1-sRGB.png +0 -0
  216. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1-tRNS.png +0 -0
  217. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-1.png +0 -0
  218. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2-1.8-tRNS.png +0 -0
  219. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2-1.8.png +0 -0
  220. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2-linear-tRNS.png +0 -0
  221. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2-linear.png +0 -0
  222. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2-sRGB-tRNS.png +0 -0
  223. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2-sRGB.png +0 -0
  224. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2-tRNS.png +0 -0
  225. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-2.png +0 -0
  226. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4-1.8-tRNS.png +0 -0
  227. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4-1.8.png +0 -0
  228. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4-linear-tRNS.png +0 -0
  229. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4-linear.png +0 -0
  230. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4-sRGB-tRNS.png +0 -0
  231. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4-sRGB.png +0 -0
  232. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4-tRNS.png +0 -0
  233. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-4.png +0 -0
  234. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8-1.8-tRNS.png +0 -0
  235. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8-1.8.png +0 -0
  236. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8-linear-tRNS.png +0 -0
  237. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8-linear.png +0 -0
  238. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8-sRGB-tRNS.png +0 -0
  239. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8-sRGB.png +0 -0
  240. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8-tRNS.png +0 -0
  241. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/palette-8.png +0 -0
  242. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16-1.8-tRNS.png +0 -0
  243. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16-1.8.png +0 -0
  244. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16-linear-tRNS.png +0 -0
  245. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16-linear.png +0 -0
  246. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16-sRGB-tRNS.png +0 -0
  247. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16-sRGB.png +0 -0
  248. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16-tRNS.png +0 -0
  249. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-16.png +0 -0
  250. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8-1.8-tRNS.png +0 -0
  251. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8-1.8.png +0 -0
  252. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8-linear-tRNS.png +0 -0
  253. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8-linear.png +0 -0
  254. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8-sRGB-tRNS.png +0 -0
  255. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8-sRGB.png +0 -0
  256. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8-tRNS.png +0 -0
  257. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-8.png +0 -0
  258. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-16-1.8.png +0 -0
  259. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-16-linear.png +0 -0
  260. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-16-sRGB.png +0 -0
  261. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-16.png +0 -0
  262. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-8-1.8.png +0 -0
  263. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-8-linear.png +0 -0
  264. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-8-sRGB.png +0 -0
  265. data/vendor/git.code.sf.net/p/libpng/code/contrib/testpngs/rgb-alpha-8.png +0 -0
  266. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/README.txt +27 -0
  267. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/checksum-icc.c +102 -0
  268. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/chkfmt +144 -0
  269. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/cvtcolor.c +188 -0
  270. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/genpng.c +881 -0
  271. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/intgamma.sh +110 -0
  272. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/makesRGB.c +430 -0
  273. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/png-fix-itxt.c +164 -0
  274. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/pngcp.c +2453 -0
  275. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/pngfix.c +4049 -0
  276. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/reindent +25 -0
  277. data/vendor/git.code.sf.net/p/libpng/code/contrib/tools/sRGB.h +48 -0
  278. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/PngFile.c +455 -0
  279. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/PngFile.h +30 -0
  280. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/README.txt +61 -0
  281. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/VisualPng.c +978 -0
  282. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/VisualPng.dsp +147 -0
  283. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/VisualPng.dsw +29 -0
  284. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/VisualPng.ico +0 -0
  285. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/VisualPng.png +0 -0
  286. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/VisualPng.rc +152 -0
  287. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/cexcept.h +248 -0
  288. data/vendor/git.code.sf.net/p/libpng/code/contrib/visupng/resource.h +23 -0
  289. data/vendor/git.code.sf.net/p/libpng/code/example.c +1066 -0
  290. data/vendor/git.code.sf.net/p/libpng/code/intel/filter_sse2_intrinsics.c +406 -0
  291. data/vendor/git.code.sf.net/p/libpng/code/intel/intel_init.c +53 -0
  292. data/vendor/git.code.sf.net/p/libpng/code/libpng-config.in +127 -0
  293. data/vendor/git.code.sf.net/p/libpng/code/libpng-manual.txt +5464 -0
  294. data/vendor/git.code.sf.net/p/libpng/code/libpng.3 +6249 -0
  295. data/vendor/git.code.sf.net/p/libpng/code/libpng.pc.in +12 -0
  296. data/vendor/git.code.sf.net/p/libpng/code/libpngpf.3 +18 -0
  297. data/vendor/git.code.sf.net/p/libpng/code/mips/filter_msa_intrinsics.c +807 -0
  298. data/vendor/git.code.sf.net/p/libpng/code/mips/mips_init.c +129 -0
  299. data/vendor/git.code.sf.net/p/libpng/code/png.5 +74 -0
  300. data/vendor/git.code.sf.net/p/libpng/code/png.c +4614 -0
  301. data/vendor/git.code.sf.net/p/libpng/code/png.h +3278 -0
  302. data/vendor/git.code.sf.net/p/libpng/code/pngbar.jpg +0 -0
  303. data/vendor/git.code.sf.net/p/libpng/code/pngbar.png +0 -0
  304. data/vendor/git.code.sf.net/p/libpng/code/pngconf.h +622 -0
  305. data/vendor/git.code.sf.net/p/libpng/code/pngdebug.h +153 -0
  306. data/vendor/git.code.sf.net/p/libpng/code/pngerror.c +963 -0
  307. data/vendor/git.code.sf.net/p/libpng/code/pngget.c +1248 -0
  308. data/vendor/git.code.sf.net/p/libpng/code/pnginfo.h +267 -0
  309. data/vendor/git.code.sf.net/p/libpng/code/pngmem.c +284 -0
  310. data/vendor/git.code.sf.net/p/libpng/code/pngnow.png +0 -0
  311. data/vendor/git.code.sf.net/p/libpng/code/pngpread.c +1096 -0
  312. data/vendor/git.code.sf.net/p/libpng/code/pngpriv.h +2120 -0
  313. data/vendor/git.code.sf.net/p/libpng/code/pngread.c +4219 -0
  314. data/vendor/git.code.sf.net/p/libpng/code/pngrio.c +120 -0
  315. data/vendor/git.code.sf.net/p/libpng/code/pngrtran.c +5010 -0
  316. data/vendor/git.code.sf.net/p/libpng/code/pngrutil.c +4661 -0
  317. data/vendor/git.code.sf.net/p/libpng/code/pngset.c +1802 -0
  318. data/vendor/git.code.sf.net/p/libpng/code/pngstruct.h +483 -0
  319. data/vendor/git.code.sf.net/p/libpng/code/pngtest.c +2156 -0
  320. data/vendor/git.code.sf.net/p/libpng/code/pngtest.png +0 -0
  321. data/vendor/git.code.sf.net/p/libpng/code/pngtrans.c +864 -0
  322. data/vendor/git.code.sf.net/p/libpng/code/pngusr.dfa +14 -0
  323. data/vendor/git.code.sf.net/p/libpng/code/pngwio.c +168 -0
  324. data/vendor/git.code.sf.net/p/libpng/code/pngwrite.c +2396 -0
  325. data/vendor/git.code.sf.net/p/libpng/code/pngwtran.c +576 -0
  326. data/vendor/git.code.sf.net/p/libpng/code/pngwutil.c +2784 -0
  327. data/vendor/git.code.sf.net/p/libpng/code/powerpc/filter_vsx_intrinsics.c +767 -0
  328. data/vendor/git.code.sf.net/p/libpng/code/powerpc/powerpc_init.c +125 -0
  329. data/vendor/git.code.sf.net/p/libpng/code/projects/owatcom/libpng.tgt +383 -0
  330. data/vendor/git.code.sf.net/p/libpng/code/projects/owatcom/libpng.wpj +112 -0
  331. data/vendor/git.code.sf.net/p/libpng/code/projects/owatcom/pngconfig.mak +160 -0
  332. data/vendor/git.code.sf.net/p/libpng/code/projects/owatcom/pngstest.tgt +219 -0
  333. data/vendor/git.code.sf.net/p/libpng/code/projects/owatcom/pngtest.tgt +179 -0
  334. data/vendor/git.code.sf.net/p/libpng/code/projects/owatcom/pngvalid.tgt +210 -0
  335. data/vendor/git.code.sf.net/p/libpng/code/projects/visualc71/PRJ0041.mak +21 -0
  336. data/vendor/git.code.sf.net/p/libpng/code/projects/visualc71/README.txt +58 -0
  337. data/vendor/git.code.sf.net/p/libpng/code/projects/visualc71/README_zlib.txt +44 -0
  338. data/vendor/git.code.sf.net/p/libpng/code/projects/visualc71/libpng.sln +60 -0
  339. data/vendor/git.code.sf.net/p/libpng/code/projects/visualc71/libpng.vcproj +419 -0
  340. data/vendor/git.code.sf.net/p/libpng/code/projects/visualc71/pngtest.vcproj +267 -0
  341. data/vendor/git.code.sf.net/p/libpng/code/projects/visualc71/zlib.vcproj +391 -0
  342. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/README.txt +97 -0
  343. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/libpng/libpng.vcxproj +234 -0
  344. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/pnglibconf/pnglibconf.vcxproj +61 -0
  345. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/pngstest/pngstest.vcxproj +219 -0
  346. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/pngtest/pngtest.vcxproj +220 -0
  347. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/pngunknown/pngunknown.vcxproj +219 -0
  348. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/pngvalid/pngvalid.vcxproj +219 -0
  349. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/vstudio.sln +109 -0
  350. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/zlib/zlib.vcxproj +175 -0
  351. data/vendor/git.code.sf.net/p/libpng/code/projects/vstudio/zlib.props +58 -0
  352. data/vendor/git.code.sf.net/p/libpng/code/scripts/README.txt +86 -0
  353. data/vendor/git.code.sf.net/p/libpng/code/scripts/SCOPTIONS.ppc +7 -0
  354. data/vendor/git.code.sf.net/p/libpng/code/scripts/checksym.awk +173 -0
  355. data/vendor/git.code.sf.net/p/libpng/code/scripts/def.c +29 -0
  356. data/vendor/git.code.sf.net/p/libpng/code/scripts/descrip.mms +52 -0
  357. data/vendor/git.code.sf.net/p/libpng/code/scripts/dfn.awk +203 -0
  358. data/vendor/git.code.sf.net/p/libpng/code/scripts/genchk.cmake.in +37 -0
  359. data/vendor/git.code.sf.net/p/libpng/code/scripts/genout.cmake.in +93 -0
  360. data/vendor/git.code.sf.net/p/libpng/code/scripts/gensrc.cmake.in +138 -0
  361. data/vendor/git.code.sf.net/p/libpng/code/scripts/intprefix.c +22 -0
  362. data/vendor/git.code.sf.net/p/libpng/code/scripts/libpng-config-body.in +96 -0
  363. data/vendor/git.code.sf.net/p/libpng/code/scripts/libpng-config-head.in +24 -0
  364. data/vendor/git.code.sf.net/p/libpng/code/scripts/libpng.pc.in +10 -0
  365. data/vendor/git.code.sf.net/p/libpng/code/scripts/macro.lst +3 -0
  366. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.32sunu +244 -0
  367. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.64sunu +244 -0
  368. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.acorn +57 -0
  369. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.aix +116 -0
  370. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.amiga +58 -0
  371. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.atari +71 -0
  372. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.bc32 +158 -0
  373. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.beos +222 -0
  374. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.bor +170 -0
  375. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.cegcc +116 -0
  376. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.darwin +225 -0
  377. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.dec +210 -0
  378. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.dj2 +72 -0
  379. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.freebsd +69 -0
  380. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.gcc +87 -0
  381. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.hp64 +231 -0
  382. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.hpgcc +234 -0
  383. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.hpux +229 -0
  384. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.ibmc +90 -0
  385. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.intel +115 -0
  386. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.knr +116 -0
  387. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.linux +247 -0
  388. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.linux-opt +265 -0
  389. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.mips +103 -0
  390. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.msc +100 -0
  391. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.msys +201 -0
  392. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.ne12bsd +56 -0
  393. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.netbsd +56 -0
  394. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.openbsd +88 -0
  395. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.sco +226 -0
  396. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.sggcc +236 -0
  397. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.sgi +237 -0
  398. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.so9 +247 -0
  399. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.solaris +244 -0
  400. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.solaris-x86 +243 -0
  401. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.std +134 -0
  402. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.sunos +115 -0
  403. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.tc3 +100 -0
  404. data/vendor/git.code.sf.net/p/libpng/code/scripts/makefile.vcwin32 +113 -0
  405. data/vendor/git.code.sf.net/p/libpng/code/scripts/makevms.com +142 -0
  406. data/vendor/git.code.sf.net/p/libpng/code/scripts/options.awk +898 -0
  407. data/vendor/git.code.sf.net/p/libpng/code/scripts/pnglibconf.dfa +919 -0
  408. data/vendor/git.code.sf.net/p/libpng/code/scripts/pnglibconf.h.prebuilt +220 -0
  409. data/vendor/git.code.sf.net/p/libpng/code/scripts/pnglibconf.mak +55 -0
  410. data/vendor/git.code.sf.net/p/libpng/code/scripts/pngwin.rc +112 -0
  411. data/vendor/git.code.sf.net/p/libpng/code/scripts/prefix.c +24 -0
  412. data/vendor/git.code.sf.net/p/libpng/code/scripts/smakefile.ppc +34 -0
  413. data/vendor/git.code.sf.net/p/libpng/code/scripts/sym.c +15 -0
  414. data/vendor/git.code.sf.net/p/libpng/code/scripts/symbols.c +58 -0
  415. data/vendor/git.code.sf.net/p/libpng/code/scripts/symbols.def +256 -0
  416. data/vendor/git.code.sf.net/p/libpng/code/scripts/test.cmake.in +31 -0
  417. data/vendor/git.code.sf.net/p/libpng/code/scripts/vers.c +19 -0
  418. data/vendor/git.code.sf.net/p/libpng/code/tests/pngimage-full +2 -0
  419. data/vendor/git.code.sf.net/p/libpng/code/tests/pngimage-quick +2 -0
  420. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest +54 -0
  421. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-1.8 +2 -0
  422. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-1.8-alpha +2 -0
  423. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-linear +2 -0
  424. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-linear-alpha +2 -0
  425. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-none +2 -0
  426. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-none-alpha +2 -0
  427. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-sRGB +2 -0
  428. data/vendor/git.code.sf.net/p/libpng/code/tests/pngstest-sRGB-alpha +2 -0
  429. data/vendor/git.code.sf.net/p/libpng/code/tests/pngtest +2 -0
  430. data/vendor/git.code.sf.net/p/libpng/code/tests/pngtest-badpngs +13 -0
  431. data/vendor/git.code.sf.net/p/libpng/code/tests/pngunknown-IDAT +2 -0
  432. data/vendor/git.code.sf.net/p/libpng/code/tests/pngunknown-discard +2 -0
  433. data/vendor/git.code.sf.net/p/libpng/code/tests/pngunknown-if-safe +2 -0
  434. data/vendor/git.code.sf.net/p/libpng/code/tests/pngunknown-sAPI +2 -0
  435. data/vendor/git.code.sf.net/p/libpng/code/tests/pngunknown-sTER +2 -0
  436. data/vendor/git.code.sf.net/p/libpng/code/tests/pngunknown-save +2 -0
  437. data/vendor/git.code.sf.net/p/libpng/code/tests/pngunknown-vpAg +2 -0
  438. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-16-to-8 +2 -0
  439. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-alpha-mode +2 -0
  440. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-background +2 -0
  441. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-expand16-alpha-mode +2 -0
  442. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-expand16-background +2 -0
  443. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-expand16-transform +2 -0
  444. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-sbit +2 -0
  445. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-threshold +2 -0
  446. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-gamma-transform +2 -0
  447. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-progressive-interlace-standard +2 -0
  448. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-progressive-size +2 -0
  449. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-progressive-standard +2 -0
  450. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-standard +2 -0
  451. data/vendor/git.code.sf.net/p/libpng/code/tests/pngvalid-transform +2 -0
  452. metadata +515 -0
@@ -0,0 +1,1294 @@
1
+
2
+ /* pngunknown.c - test the read side unknown chunk handling
3
+ *
4
+ * Last changed in libpng 1.6.32 [August 24, 2017]
5
+ * Copyright (c) 2015,2017 Glenn Randers-Pehrson
6
+ * Written by John Cunningham Bowler
7
+ *
8
+ * This code is released under the libpng license.
9
+ * For conditions of distribution and use, see the disclaimer
10
+ * and license in png.h
11
+ *
12
+ * NOTES:
13
+ * This is a C program that is intended to be linked against libpng. It
14
+ * allows the libpng unknown handling code to be tested by interpreting
15
+ * arguments to save or discard combinations of chunks. The program is
16
+ * currently just a minimal validation for the built-in libpng facilities.
17
+ */
18
+
19
+ #include <stdlib.h>
20
+ #include <string.h>
21
+ #include <stdio.h>
22
+ #include <setjmp.h>
23
+
24
+ /* Define the following to use this test against your installed libpng, rather
25
+ * than the one being built here:
26
+ */
27
+ #ifdef PNG_FREESTANDING_TESTS
28
+ # include <png.h>
29
+ #else
30
+ # include "../../png.h"
31
+ #endif
32
+
33
+ /* 1.6.1 added support for the configure test harness, which uses 77 to indicate
34
+ * a skipped test, in earlier versions we need to succeed on a skipped test, so:
35
+ */
36
+ #if PNG_LIBPNG_VER >= 10601 && defined(HAVE_CONFIG_H)
37
+ # define SKIP 77
38
+ #else
39
+ # define SKIP 0
40
+ #endif
41
+
42
+
43
+ /* Since this program tests the ability to change the unknown chunk handling
44
+ * these must be defined:
45
+ */
46
+ #if defined(PNG_SET_UNKNOWN_CHUNKS_SUPPORTED) &&\
47
+ defined(PNG_STDIO_SUPPORTED) &&\
48
+ defined(PNG_READ_SUPPORTED)
49
+
50
+ /* One of these must be defined to allow us to find out what happened. It is
51
+ * still useful to set unknown chunk handling without either of these in order
52
+ * to cause *known* chunks to be discarded. This can be a significant
53
+ * efficiency gain, but it can't really be tested here.
54
+ */
55
+ #if defined(PNG_READ_USER_CHUNKS_SUPPORTED) ||\
56
+ defined(PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED)
57
+
58
+ #if PNG_LIBPNG_VER < 10500
59
+ /* This deliberately lacks the PNG_CONST. */
60
+ typedef png_byte *png_const_bytep;
61
+
62
+ /* This is copied from 1.5.1 png.h: */
63
+ #define PNG_INTERLACE_ADAM7_PASSES 7
64
+ #define PNG_PASS_START_ROW(pass) (((1U&~(pass))<<(3-((pass)>>1)))&7)
65
+ #define PNG_PASS_START_COL(pass) (((1U& (pass))<<(3-(((pass)+1)>>1)))&7)
66
+ #define PNG_PASS_ROW_SHIFT(pass) ((pass)>2?(8-(pass))>>1:3)
67
+ #define PNG_PASS_COL_SHIFT(pass) ((pass)>1?(7-(pass))>>1:3)
68
+ #define PNG_PASS_ROWS(height, pass) (((height)+(((1<<PNG_PASS_ROW_SHIFT(pass))\
69
+ -1)-PNG_PASS_START_ROW(pass)))>>PNG_PASS_ROW_SHIFT(pass))
70
+ #define PNG_PASS_COLS(width, pass) (((width)+(((1<<PNG_PASS_COL_SHIFT(pass))\
71
+ -1)-PNG_PASS_START_COL(pass)))>>PNG_PASS_COL_SHIFT(pass))
72
+ #define PNG_ROW_FROM_PASS_ROW(yIn, pass) \
73
+ (((yIn)<<PNG_PASS_ROW_SHIFT(pass))+PNG_PASS_START_ROW(pass))
74
+ #define PNG_COL_FROM_PASS_COL(xIn, pass) \
75
+ (((xIn)<<PNG_PASS_COL_SHIFT(pass))+PNG_PASS_START_COL(pass))
76
+ #define PNG_PASS_MASK(pass,off) ( \
77
+ ((0x110145AFU>>(((7-(off))-(pass))<<2)) & 0xFU) | \
78
+ ((0x01145AF0U>>(((7-(off))-(pass))<<2)) & 0xF0U))
79
+ #define PNG_ROW_IN_INTERLACE_PASS(y, pass) \
80
+ ((PNG_PASS_MASK(pass,0) >> ((y)&7)) & 1)
81
+ #define PNG_COL_IN_INTERLACE_PASS(x, pass) \
82
+ ((PNG_PASS_MASK(pass,1) >> ((x)&7)) & 1)
83
+
84
+ /* These are needed too for the default build: */
85
+ #define PNG_WRITE_16BIT_SUPPORTED
86
+ #define PNG_READ_16BIT_SUPPORTED
87
+
88
+ /* This comes from pnglibconf.h afer 1.5: */
89
+ #define PNG_FP_1 100000
90
+ #define PNG_GAMMA_THRESHOLD_FIXED\
91
+ ((png_fixed_point)(PNG_GAMMA_THRESHOLD * PNG_FP_1))
92
+ #endif
93
+
94
+ #if PNG_LIBPNG_VER < 10600
95
+ /* 1.6.0 constifies many APIs. The following exists to allow pngvalid to be
96
+ * compiled against earlier versions.
97
+ */
98
+ # define png_const_structp png_structp
99
+ #endif
100
+
101
+ #if PNG_LIBPNG_VER < 10700
102
+ /* Copied from libpng 1.7.0 png.h */
103
+ #define PNG_u2(b1, b2) (((unsigned int)(b1) << 8) + (b2))
104
+
105
+ #define PNG_U16(b1, b2) ((png_uint_16)PNG_u2(b1, b2))
106
+ #define PNG_U32(b1, b2, b3, b4)\
107
+ (((png_uint_32)PNG_u2(b1, b2) << 16) + PNG_u2(b3, b4))
108
+
109
+ /* Constants for known chunk types.
110
+ */
111
+ #define png_IDAT PNG_U32( 73, 68, 65, 84)
112
+ #define png_IEND PNG_U32( 73, 69, 78, 68)
113
+ #define png_IHDR PNG_U32( 73, 72, 68, 82)
114
+ #define png_PLTE PNG_U32( 80, 76, 84, 69)
115
+ #define png_bKGD PNG_U32( 98, 75, 71, 68)
116
+ #define png_cHRM PNG_U32( 99, 72, 82, 77)
117
+ #define png_eXIf PNG_U32(101, 88, 73, 102) /* registered July 2017 */
118
+ #define png_fRAc PNG_U32(102, 82, 65, 99) /* registered, not defined */
119
+ #define png_gAMA PNG_U32(103, 65, 77, 65)
120
+ #define png_gIFg PNG_U32(103, 73, 70, 103)
121
+ #define png_gIFt PNG_U32(103, 73, 70, 116) /* deprecated */
122
+ #define png_gIFx PNG_U32(103, 73, 70, 120)
123
+ #define png_hIST PNG_U32(104, 73, 83, 84)
124
+ #define png_iCCP PNG_U32(105, 67, 67, 80)
125
+ #define png_iTXt PNG_U32(105, 84, 88, 116)
126
+ #define png_oFFs PNG_U32(111, 70, 70, 115)
127
+ #define png_pCAL PNG_U32(112, 67, 65, 76)
128
+ #define png_pHYs PNG_U32(112, 72, 89, 115)
129
+ #define png_sBIT PNG_U32(115, 66, 73, 84)
130
+ #define png_sCAL PNG_U32(115, 67, 65, 76)
131
+ #define png_sPLT PNG_U32(115, 80, 76, 84)
132
+ #define png_sRGB PNG_U32(115, 82, 71, 66)
133
+ #define png_sTER PNG_U32(115, 84, 69, 82)
134
+ #define png_tEXt PNG_U32(116, 69, 88, 116)
135
+ #define png_tIME PNG_U32(116, 73, 77, 69)
136
+ #define png_tRNS PNG_U32(116, 82, 78, 83)
137
+ #define png_zTXt PNG_U32(122, 84, 88, 116)
138
+
139
+ /* Test on flag values as defined in the spec (section 5.4): */
140
+ #define PNG_CHUNK_ANCILLARY(c) (1 & ((c) >> 29))
141
+ #define PNG_CHUNK_CRITICAL(c) (!PNG_CHUNK_ANCILLARY(c))
142
+ #define PNG_CHUNK_PRIVATE(c) (1 & ((c) >> 21))
143
+ #define PNG_CHUNK_RESERVED(c) (1 & ((c) >> 13))
144
+ #define PNG_CHUNK_SAFE_TO_COPY(c) (1 & ((c) >> 5))
145
+
146
+ #endif /* PNG_LIBPNG_VER < 10700 */
147
+
148
+ #ifdef __cplusplus
149
+ # define this not_the_cpp_this
150
+ # define new not_the_cpp_new
151
+ # define voidcast(type, value) static_cast<type>(value)
152
+ #else
153
+ # define voidcast(type, value) (value)
154
+ #endif /* __cplusplus */
155
+
156
+ /* Unused formal parameter errors are removed using the following macro which is
157
+ * expected to have no bad effects on performance.
158
+ */
159
+ #ifndef UNUSED
160
+ # if defined(__GNUC__) || defined(_MSC_VER)
161
+ # define UNUSED(param) (void)param;
162
+ # else
163
+ # define UNUSED(param)
164
+ # endif
165
+ #endif
166
+
167
+ /* Types of chunks not known to libpng */
168
+ #define png_vpAg PNG_U32(118, 112, 65, 103)
169
+
170
+ /* Chunk information */
171
+ #define PNG_INFO_tEXt 0x10000000U
172
+ #define PNG_INFO_iTXt 0x20000000U
173
+ #define PNG_INFO_zTXt 0x40000000U
174
+
175
+ #define PNG_INFO_sTER 0x01000000U
176
+ #define PNG_INFO_vpAg 0x02000000U
177
+
178
+ #define ABSENT 0
179
+ #define START 1
180
+ #define END 2
181
+
182
+ static struct
183
+ {
184
+ char name[5];
185
+ png_uint_32 flag;
186
+ png_uint_32 tag;
187
+ int unknown; /* Chunk not known to libpng */
188
+ int all; /* Chunk set by the '-1' option */
189
+ int position; /* position in pngtest.png */
190
+ int keep; /* unknown handling setting */
191
+ } chunk_info[] = {
192
+ /* Critical chunks */
193
+ { "IDAT", PNG_INFO_IDAT, png_IDAT, 0, 0, START, 0 }, /* must be [0] */
194
+ { "PLTE", PNG_INFO_PLTE, png_PLTE, 0, 0, ABSENT, 0 },
195
+
196
+ /* Non-critical chunks that libpng handles */
197
+ /* This is a mess but it seems to be the only way to do it - there is no way
198
+ * to check for a definition outside a #if.
199
+ */
200
+ { "bKGD", PNG_INFO_bKGD, png_bKGD,
201
+ # ifdef PNG_READ_bKGD_SUPPORTED
202
+ 0,
203
+ # else
204
+ 1,
205
+ # endif
206
+ 1, START, 0 },
207
+ { "cHRM", PNG_INFO_cHRM, png_cHRM,
208
+ # ifdef PNG_READ_cHRM_SUPPORTED
209
+ 0,
210
+ # else
211
+ 1,
212
+ # endif
213
+ 1, START, 0 },
214
+ { "eXIf", PNG_INFO_eXIf, png_eXIf,
215
+ # ifdef PNG_READ_eXIf_SUPPORTED
216
+ 0,
217
+ # else
218
+ 1,
219
+ # endif
220
+ 1, END, 0 },
221
+ { "gAMA", PNG_INFO_gAMA, png_gAMA,
222
+ # ifdef PNG_READ_gAMA_SUPPORTED
223
+ 0,
224
+ # else
225
+ 1,
226
+ # endif
227
+ 1, START, 0 },
228
+ { "hIST", PNG_INFO_hIST, png_hIST,
229
+ # ifdef PNG_READ_hIST_SUPPORTED
230
+ 0,
231
+ # else
232
+ 1,
233
+ # endif
234
+ 1, ABSENT, 0 },
235
+ { "iCCP", PNG_INFO_iCCP, png_iCCP,
236
+ # ifdef PNG_READ_iCCP_SUPPORTED
237
+ 0,
238
+ # else
239
+ 1,
240
+ # endif
241
+ 1, ABSENT, 0 },
242
+ { "iTXt", PNG_INFO_iTXt, png_iTXt,
243
+ # ifdef PNG_READ_iTXt_SUPPORTED
244
+ 0,
245
+ # else
246
+ 1,
247
+ # endif
248
+ 1, ABSENT, 0 },
249
+ { "oFFs", PNG_INFO_oFFs, png_oFFs,
250
+ # ifdef PNG_READ_oFFs_SUPPORTED
251
+ 0,
252
+ # else
253
+ 1,
254
+ # endif
255
+ 1, START, 0 },
256
+ { "pCAL", PNG_INFO_pCAL, png_pCAL,
257
+ # ifdef PNG_READ_pCAL_SUPPORTED
258
+ 0,
259
+ # else
260
+ 1,
261
+ # endif
262
+ 1, START, 0 },
263
+ { "pHYs", PNG_INFO_pHYs, png_pHYs,
264
+ # ifdef PNG_READ_pHYs_SUPPORTED
265
+ 0,
266
+ # else
267
+ 1,
268
+ # endif
269
+ 1, START, 0 },
270
+ { "sBIT", PNG_INFO_sBIT, png_sBIT,
271
+ # ifdef PNG_READ_sBIT_SUPPORTED
272
+ 0,
273
+ # else
274
+ 1,
275
+ # endif
276
+ 1, START, 0 },
277
+ { "sCAL", PNG_INFO_sCAL, png_sCAL,
278
+ # ifdef PNG_READ_sCAL_SUPPORTED
279
+ 0,
280
+ # else
281
+ 1,
282
+ # endif
283
+ 1, START, 0 },
284
+ { "sPLT", PNG_INFO_sPLT, png_sPLT,
285
+ # ifdef PNG_READ_sPLT_SUPPORTED
286
+ 0,
287
+ # else
288
+ 1,
289
+ # endif
290
+ 1, ABSENT, 0 },
291
+ { "sRGB", PNG_INFO_sRGB, png_sRGB,
292
+ # ifdef PNG_READ_sRGB_SUPPORTED
293
+ 0,
294
+ # else
295
+ 1,
296
+ # endif
297
+ 1, START, 0 },
298
+ { "tEXt", PNG_INFO_tEXt, png_tEXt,
299
+ # ifdef PNG_READ_tEXt_SUPPORTED
300
+ 0,
301
+ # else
302
+ 1,
303
+ # endif
304
+ 1, START, 0 },
305
+ { "tIME", PNG_INFO_tIME, png_tIME,
306
+ # ifdef PNG_READ_tIME_SUPPORTED
307
+ 0,
308
+ # else
309
+ 1,
310
+ # endif
311
+ 1, START, 0 },
312
+ { "tRNS", PNG_INFO_tRNS, png_tRNS,
313
+ # ifdef PNG_READ_tRNS_SUPPORTED
314
+ 0,
315
+ # else
316
+ 1,
317
+ # endif
318
+ 0, ABSENT, 0 },
319
+ { "zTXt", PNG_INFO_zTXt, png_zTXt,
320
+ # ifdef PNG_READ_zTXt_SUPPORTED
321
+ 0,
322
+ # else
323
+ 1,
324
+ # endif
325
+ 1, END, 0 },
326
+
327
+ /* No libpng handling */
328
+ { "sTER", PNG_INFO_sTER, png_sTER, 1, 1, START, 0 },
329
+ { "vpAg", PNG_INFO_vpAg, png_vpAg, 1, 0, START, 0 },
330
+ };
331
+
332
+ #define NINFO ((int)((sizeof chunk_info)/(sizeof chunk_info[0])))
333
+
334
+ static void
335
+ clear_keep(void)
336
+ {
337
+ int i = NINFO;
338
+ while (--i >= 0)
339
+ chunk_info[i].keep = 0;
340
+ }
341
+
342
+ static int
343
+ find(const char *name)
344
+ {
345
+ int i = NINFO;
346
+ while (--i >= 0)
347
+ {
348
+ if (memcmp(chunk_info[i].name, name, 4) == 0)
349
+ break;
350
+ }
351
+
352
+ return i;
353
+ }
354
+
355
+ static int
356
+ findb(const png_byte *name)
357
+ {
358
+ int i = NINFO;
359
+ while (--i >= 0)
360
+ {
361
+ if (memcmp(chunk_info[i].name, name, 4) == 0)
362
+ break;
363
+ }
364
+
365
+ return i;
366
+ }
367
+
368
+ static int
369
+ find_by_flag(png_uint_32 flag)
370
+ {
371
+ int i = NINFO;
372
+
373
+ while (--i >= 0) if (chunk_info[i].flag == flag) return i;
374
+
375
+ fprintf(stderr, "pngunknown: internal error\n");
376
+ exit(4);
377
+ }
378
+
379
+ static int
380
+ ancillary(const char *name)
381
+ {
382
+ return PNG_CHUNK_ANCILLARY(PNG_U32(name[0], name[1], name[2], name[3]));
383
+ }
384
+
385
+ #ifdef PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED
386
+ static int
387
+ ancillaryb(const png_byte *name)
388
+ {
389
+ return PNG_CHUNK_ANCILLARY(PNG_U32(name[0], name[1], name[2], name[3]));
390
+ }
391
+ #endif
392
+
393
+ /* Type of an error_ptr */
394
+ typedef struct
395
+ {
396
+ jmp_buf error_return;
397
+ png_structp png_ptr;
398
+ png_infop info_ptr, end_ptr;
399
+ png_uint_32 before_IDAT;
400
+ png_uint_32 after_IDAT;
401
+ int error_count;
402
+ int warning_count;
403
+ int keep; /* the default value */
404
+ const char *program;
405
+ const char *file;
406
+ const char *test;
407
+ } display;
408
+
409
+ static const char init[] = "initialization";
410
+ static const char cmd[] = "command line";
411
+
412
+ static void
413
+ init_display(display *d, const char *program)
414
+ {
415
+ memset(d, 0, sizeof *d);
416
+ d->png_ptr = NULL;
417
+ d->info_ptr = d->end_ptr = NULL;
418
+ d->error_count = d->warning_count = 0;
419
+ d->program = program;
420
+ d->file = program;
421
+ d->test = init;
422
+ }
423
+
424
+ static void
425
+ clean_display(display *d)
426
+ {
427
+ png_destroy_read_struct(&d->png_ptr, &d->info_ptr, &d->end_ptr);
428
+
429
+ /* This must not happen - it might cause an app crash */
430
+ if (d->png_ptr != NULL || d->info_ptr != NULL || d->end_ptr != NULL)
431
+ {
432
+ fprintf(stderr, "%s(%s): png_destroy_read_struct error\n", d->file,
433
+ d->test);
434
+ exit(1);
435
+ }
436
+ }
437
+
438
+ PNG_FUNCTION(void, display_exit, (display *d), static PNG_NORETURN)
439
+ {
440
+ ++(d->error_count);
441
+
442
+ if (d->png_ptr != NULL)
443
+ clean_display(d);
444
+
445
+ /* During initialization and if this is a single command line argument set
446
+ * exit now - there is only one test, otherwise longjmp to do the next test.
447
+ */
448
+ if (d->test == init || d->test == cmd)
449
+ exit(1);
450
+
451
+ longjmp(d->error_return, 1);
452
+ }
453
+
454
+ static int
455
+ display_rc(const display *d, int strict)
456
+ {
457
+ return d->error_count + (strict ? d->warning_count : 0);
458
+ }
459
+
460
+ /* libpng error and warning callbacks */
461
+ PNG_FUNCTION(void, (PNGCBAPI error), (png_structp png_ptr, const char *message),
462
+ static PNG_NORETURN)
463
+ {
464
+ display *d = (display*)png_get_error_ptr(png_ptr);
465
+
466
+ fprintf(stderr, "%s(%s): libpng error: %s\n", d->file, d->test, message);
467
+ display_exit(d);
468
+ }
469
+
470
+ static void PNGCBAPI
471
+ warning(png_structp png_ptr, const char *message)
472
+ {
473
+ display *d = (display*)png_get_error_ptr(png_ptr);
474
+
475
+ fprintf(stderr, "%s(%s): libpng warning: %s\n", d->file, d->test, message);
476
+ ++(d->warning_count);
477
+ }
478
+
479
+ static png_uint_32
480
+ get_valid(display *d, png_infop info_ptr)
481
+ {
482
+ png_uint_32 flags = png_get_valid(d->png_ptr, info_ptr, (png_uint_32)~0);
483
+
484
+ /* Map the text chunks back into the flags */
485
+ {
486
+ png_textp text;
487
+ png_uint_32 ntext = png_get_text(d->png_ptr, info_ptr, &text, NULL);
488
+
489
+ while (ntext > 0) switch (text[--ntext].compression)
490
+ {
491
+ case -1:
492
+ flags |= PNG_INFO_tEXt;
493
+ break;
494
+ case 0:
495
+ flags |= PNG_INFO_zTXt;
496
+ break;
497
+ case 1:
498
+ case 2:
499
+ flags |= PNG_INFO_iTXt;
500
+ break;
501
+ default:
502
+ fprintf(stderr, "%s(%s): unknown text compression %d\n", d->file,
503
+ d->test, text[ntext].compression);
504
+ display_exit(d);
505
+ }
506
+ }
507
+
508
+ return flags;
509
+ }
510
+
511
+ #ifdef PNG_READ_USER_CHUNKS_SUPPORTED
512
+ static int PNGCBAPI
513
+ read_callback(png_structp pp, png_unknown_chunkp pc)
514
+ {
515
+ /* This function mimics the behavior of png_set_keep_unknown_chunks by
516
+ * returning '0' to keep the chunk and '1' to discard it.
517
+ */
518
+ display *d = voidcast(display*, png_get_user_chunk_ptr(pp));
519
+ int chunk = findb(pc->name);
520
+ int keep, discard;
521
+
522
+ if (chunk < 0) /* not one in our list, so not a known chunk */
523
+ keep = d->keep;
524
+
525
+ else
526
+ {
527
+ keep = chunk_info[chunk].keep;
528
+ if (keep == PNG_HANDLE_CHUNK_AS_DEFAULT)
529
+ {
530
+ /* See the comments in png.h - use the default for unknown chunks,
531
+ * do not keep known chunks.
532
+ */
533
+ if (chunk_info[chunk].unknown)
534
+ keep = d->keep;
535
+
536
+ else
537
+ keep = PNG_HANDLE_CHUNK_NEVER;
538
+ }
539
+ }
540
+
541
+ switch (keep)
542
+ {
543
+ default:
544
+ fprintf(stderr, "%s(%s): %d: unrecognized chunk option\n", d->file,
545
+ d->test, chunk_info[chunk].keep);
546
+ display_exit(d);
547
+
548
+ case PNG_HANDLE_CHUNK_AS_DEFAULT:
549
+ case PNG_HANDLE_CHUNK_NEVER:
550
+ discard = 1/*handled; discard*/;
551
+ break;
552
+
553
+ case PNG_HANDLE_CHUNK_IF_SAFE:
554
+ case PNG_HANDLE_CHUNK_ALWAYS:
555
+ discard = 0/*not handled; keep*/;
556
+ break;
557
+ }
558
+
559
+ /* Also store information about this chunk in the display, the relevant flag
560
+ * is set if the chunk is to be kept ('not handled'.)
561
+ */
562
+ if (chunk >= 0) if (!discard) /* stupidity to stop a GCC warning */
563
+ {
564
+ png_uint_32 flag = chunk_info[chunk].flag;
565
+
566
+ if (pc->location & PNG_AFTER_IDAT)
567
+ d->after_IDAT |= flag;
568
+
569
+ else
570
+ d->before_IDAT |= flag;
571
+ }
572
+
573
+ /* However if there is no support to store unknown chunks don't ask libpng to
574
+ * do it; there will be an png_error.
575
+ */
576
+ # ifdef PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED
577
+ return discard;
578
+ # else
579
+ return 1; /*handled; discard*/
580
+ # endif
581
+ }
582
+ #endif /* READ_USER_CHUNKS_SUPPORTED */
583
+
584
+ #ifdef PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED
585
+ static png_uint_32
586
+ get_unknown(display *d, png_infop info_ptr, int after_IDAT)
587
+ {
588
+ /* Create corresponding 'unknown' flags */
589
+ png_uint_32 flags = 0;
590
+
591
+ UNUSED(after_IDAT)
592
+
593
+ {
594
+ png_unknown_chunkp unknown;
595
+ int num_unknown = png_get_unknown_chunks(d->png_ptr, info_ptr, &unknown);
596
+
597
+ while (--num_unknown >= 0)
598
+ {
599
+ int chunk = findb(unknown[num_unknown].name);
600
+
601
+ /* Chunks not known to pngunknown must be validated here; since they
602
+ * must also be unknown to libpng the 'display->keep' behavior should
603
+ * have been used.
604
+ */
605
+ if (chunk < 0) switch (d->keep)
606
+ {
607
+ default: /* impossible */
608
+ case PNG_HANDLE_CHUNK_AS_DEFAULT:
609
+ case PNG_HANDLE_CHUNK_NEVER:
610
+ fprintf(stderr, "%s(%s): %s: %s: unknown chunk saved\n",
611
+ d->file, d->test, d->keep ? "discard" : "default",
612
+ unknown[num_unknown].name);
613
+ ++(d->error_count);
614
+ break;
615
+
616
+ case PNG_HANDLE_CHUNK_IF_SAFE:
617
+ if (!ancillaryb(unknown[num_unknown].name))
618
+ {
619
+ fprintf(stderr,
620
+ "%s(%s): if-safe: %s: unknown critical chunk saved\n",
621
+ d->file, d->test, unknown[num_unknown].name);
622
+ ++(d->error_count);
623
+ break;
624
+ }
625
+ /* FALLTHROUGH */ /* (safe) */
626
+ case PNG_HANDLE_CHUNK_ALWAYS:
627
+ break;
628
+ }
629
+
630
+ else
631
+ flags |= chunk_info[chunk].flag;
632
+ }
633
+ }
634
+
635
+ return flags;
636
+ }
637
+ #else /* SAVE_UNKNOWN_CHUNKS */
638
+ static png_uint_32
639
+ get_unknown(display *d, png_infop info_ptr, int after_IDAT)
640
+ /* Otherwise this will return the cached values set by any user callback */
641
+ {
642
+ UNUSED(info_ptr);
643
+
644
+ if (after_IDAT)
645
+ return d->after_IDAT;
646
+
647
+ else
648
+ return d->before_IDAT;
649
+ }
650
+
651
+ # ifndef PNG_READ_USER_CHUNKS_SUPPORTED
652
+ /* The #defines above should mean this is never reached, it's just here as
653
+ * a check to ensure the logic is correct.
654
+ */
655
+ # error No store support and no user chunk support, this will not work
656
+ # endif /* READ_USER_CHUNKS */
657
+ #endif /* SAVE_UNKNOWN_CHUNKS */
658
+
659
+ static int
660
+ check(FILE *fp, int argc, const char **argv, png_uint_32p flags/*out*/,
661
+ display *d, int set_callback)
662
+ {
663
+ int i, npasses, ipass;
664
+ png_uint_32 height;
665
+
666
+ d->keep = PNG_HANDLE_CHUNK_AS_DEFAULT;
667
+ d->before_IDAT = 0;
668
+ d->after_IDAT = 0;
669
+
670
+ /* Some of these errors are permanently fatal and cause an exit here, others
671
+ * are per-test and cause an error return.
672
+ */
673
+ d->png_ptr = png_create_read_struct(PNG_LIBPNG_VER_STRING, d, error,
674
+ warning);
675
+ if (d->png_ptr == NULL)
676
+ {
677
+ fprintf(stderr, "%s(%s): could not allocate png struct\n", d->file,
678
+ d->test);
679
+ /* Terminate here, this error is not test specific. */
680
+ exit(1);
681
+ }
682
+
683
+ d->info_ptr = png_create_info_struct(d->png_ptr);
684
+ d->end_ptr = png_create_info_struct(d->png_ptr);
685
+ if (d->info_ptr == NULL || d->end_ptr == NULL)
686
+ {
687
+ fprintf(stderr, "%s(%s): could not allocate png info\n", d->file,
688
+ d->test);
689
+ clean_display(d);
690
+ exit(1);
691
+ }
692
+
693
+ png_init_io(d->png_ptr, fp);
694
+
695
+ # ifdef PNG_READ_USER_CHUNKS_SUPPORTED
696
+ /* This is only done if requested by the caller; it interferes with the
697
+ * standard store/save mechanism.
698
+ */
699
+ if (set_callback)
700
+ png_set_read_user_chunk_fn(d->png_ptr, d, read_callback);
701
+ # else
702
+ UNUSED(set_callback)
703
+ # endif
704
+
705
+ /* Handle each argument in turn; multiple settings are possible for the same
706
+ * chunk and multiple calls will occur (the last one should override all
707
+ * preceding ones).
708
+ */
709
+ for (i=0; i<argc; ++i)
710
+ {
711
+ const char *equals = strchr(argv[i], '=');
712
+
713
+ if (equals != NULL)
714
+ {
715
+ int chunk, option;
716
+
717
+ if (strcmp(equals+1, "default") == 0)
718
+ option = PNG_HANDLE_CHUNK_AS_DEFAULT;
719
+ else if (strcmp(equals+1, "discard") == 0)
720
+ option = PNG_HANDLE_CHUNK_NEVER;
721
+ else if (strcmp(equals+1, "if-safe") == 0)
722
+ option = PNG_HANDLE_CHUNK_IF_SAFE;
723
+ else if (strcmp(equals+1, "save") == 0)
724
+ option = PNG_HANDLE_CHUNK_ALWAYS;
725
+ else
726
+ {
727
+ fprintf(stderr, "%s(%s): %s: unrecognized chunk option\n", d->file,
728
+ d->test, argv[i]);
729
+ display_exit(d);
730
+ }
731
+
732
+ switch (equals - argv[i])
733
+ {
734
+ case 4: /* chunk name */
735
+ chunk = find(argv[i]);
736
+
737
+ if (chunk >= 0)
738
+ {
739
+ /* These #if tests have the effect of skipping the arguments
740
+ * if SAVE support is unavailable - we can't do a useful test
741
+ * in this case, so we just check the arguments! This could
742
+ * be improved in the future by using the read callback.
743
+ */
744
+ # if PNG_LIBPNG_VER >= 10700 &&\
745
+ !defined(PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED)
746
+ if (option < PNG_HANDLE_CHUNK_IF_SAFE)
747
+ # endif /* 1.7+ SAVE_UNKNOWN_CHUNKS */
748
+ {
749
+ png_byte name[5];
750
+
751
+ memcpy(name, chunk_info[chunk].name, 5);
752
+ png_set_keep_unknown_chunks(d->png_ptr, option, name, 1);
753
+ chunk_info[chunk].keep = option;
754
+ }
755
+ continue;
756
+ }
757
+
758
+ break;
759
+
760
+ case 7: /* default */
761
+ if (memcmp(argv[i], "default", 7) == 0)
762
+ {
763
+ # if PNG_LIBPNG_VER >= 10700 &&\
764
+ !defined(PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED)
765
+ if (option < PNG_HANDLE_CHUNK_IF_SAFE)
766
+ # endif /* 1.7+ SAVE_UNKNOWN_CHUNKS */
767
+ png_set_keep_unknown_chunks(d->png_ptr, option, NULL, 0);
768
+
769
+ d->keep = option;
770
+ continue;
771
+ }
772
+
773
+ break;
774
+
775
+ case 3: /* all */
776
+ if (memcmp(argv[i], "all", 3) == 0)
777
+ {
778
+ # if PNG_LIBPNG_VER >= 10700 &&\
779
+ !defined(PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED)
780
+ if (option < PNG_HANDLE_CHUNK_IF_SAFE)
781
+ # endif /* 1.7+ SAVE_UNKNOWN_CHUNKS */
782
+ png_set_keep_unknown_chunks(d->png_ptr, option, NULL, -1);
783
+
784
+ d->keep = option;
785
+
786
+ for (chunk = 0; chunk < NINFO; ++chunk)
787
+ if (chunk_info[chunk].all)
788
+ chunk_info[chunk].keep = option;
789
+ continue;
790
+ }
791
+
792
+ break;
793
+
794
+ default: /* some misplaced = */
795
+
796
+ break;
797
+ }
798
+ }
799
+
800
+ fprintf(stderr, "%s(%s): %s: unrecognized chunk argument\n", d->file,
801
+ d->test, argv[i]);
802
+ display_exit(d);
803
+ }
804
+
805
+ png_read_info(d->png_ptr, d->info_ptr);
806
+
807
+ switch (png_get_interlace_type(d->png_ptr, d->info_ptr))
808
+ {
809
+ case PNG_INTERLACE_NONE:
810
+ npasses = 1;
811
+ break;
812
+
813
+ case PNG_INTERLACE_ADAM7:
814
+ npasses = PNG_INTERLACE_ADAM7_PASSES;
815
+ break;
816
+
817
+ default:
818
+ /* Hard error because it is not test specific */
819
+ fprintf(stderr, "%s(%s): invalid interlace type\n", d->file, d->test);
820
+ clean_display(d);
821
+ exit(1);
822
+ }
823
+
824
+ /* Skip the image data, if IDAT is not being handled then don't do this
825
+ * because it will cause a CRC error.
826
+ */
827
+ if (chunk_info[0/*IDAT*/].keep == PNG_HANDLE_CHUNK_AS_DEFAULT)
828
+ {
829
+ png_start_read_image(d->png_ptr);
830
+ height = png_get_image_height(d->png_ptr, d->info_ptr);
831
+
832
+ if (npasses > 1)
833
+ {
834
+ png_uint_32 width = png_get_image_width(d->png_ptr, d->info_ptr);
835
+
836
+ for (ipass=0; ipass<npasses; ++ipass)
837
+ {
838
+ png_uint_32 wPass = PNG_PASS_COLS(width, ipass);
839
+
840
+ if (wPass > 0)
841
+ {
842
+ png_uint_32 y;
843
+
844
+ for (y=0; y<height; ++y) if (PNG_ROW_IN_INTERLACE_PASS(y, ipass))
845
+ png_read_row(d->png_ptr, NULL, NULL);
846
+ }
847
+ }
848
+ } /* interlaced */
849
+
850
+ else /* not interlaced */
851
+ {
852
+ png_uint_32 y;
853
+
854
+ for (y=0; y<height; ++y)
855
+ png_read_row(d->png_ptr, NULL, NULL);
856
+ }
857
+ }
858
+
859
+ png_read_end(d->png_ptr, d->end_ptr);
860
+
861
+ flags[0] = get_valid(d, d->info_ptr);
862
+ flags[1] = get_unknown(d, d->info_ptr, 0/*before IDAT*/);
863
+
864
+ /* Only png_read_png sets PNG_INFO_IDAT! */
865
+ flags[chunk_info[0/*IDAT*/].keep != PNG_HANDLE_CHUNK_AS_DEFAULT] |=
866
+ PNG_INFO_IDAT;
867
+
868
+ flags[2] = get_valid(d, d->end_ptr);
869
+ flags[3] = get_unknown(d, d->end_ptr, 1/*after IDAT*/);
870
+
871
+ clean_display(d);
872
+
873
+ return d->keep;
874
+ }
875
+
876
+ static void
877
+ check_error(display *d, png_uint_32 flags, const char *message)
878
+ {
879
+ while (flags)
880
+ {
881
+ png_uint_32 flag = flags & -(png_int_32)flags;
882
+ int i = find_by_flag(flag);
883
+
884
+ fprintf(stderr, "%s(%s): chunk %s: %s\n", d->file, d->test,
885
+ chunk_info[i].name, message);
886
+ ++(d->error_count);
887
+
888
+ flags &= ~flag;
889
+ }
890
+ }
891
+
892
+ static void
893
+ check_handling(display *d, int def, png_uint_32 chunks, png_uint_32 known,
894
+ png_uint_32 unknown, const char *position, int set_callback)
895
+ {
896
+ while (chunks)
897
+ {
898
+ png_uint_32 flag = chunks & -(png_int_32)chunks;
899
+ int i = find_by_flag(flag);
900
+ int keep = chunk_info[i].keep;
901
+ const char *type;
902
+ const char *errorx = NULL;
903
+
904
+ if (chunk_info[i].unknown)
905
+ {
906
+ if (keep == PNG_HANDLE_CHUNK_AS_DEFAULT)
907
+ {
908
+ type = "UNKNOWN (default)";
909
+ keep = def;
910
+ }
911
+
912
+ else
913
+ type = "UNKNOWN (specified)";
914
+
915
+ if (flag & known)
916
+ errorx = "chunk processed";
917
+
918
+ else switch (keep)
919
+ {
920
+ case PNG_HANDLE_CHUNK_AS_DEFAULT:
921
+ if (flag & unknown)
922
+ errorx = "DEFAULT: unknown chunk saved";
923
+ break;
924
+
925
+ case PNG_HANDLE_CHUNK_NEVER:
926
+ if (flag & unknown)
927
+ errorx = "DISCARD: unknown chunk saved";
928
+ break;
929
+
930
+ case PNG_HANDLE_CHUNK_IF_SAFE:
931
+ if (ancillary(chunk_info[i].name))
932
+ {
933
+ if (!(flag & unknown))
934
+ errorx = "IF-SAFE: unknown ancillary chunk lost";
935
+ }
936
+
937
+ else if (flag & unknown)
938
+ errorx = "IF-SAFE: unknown critical chunk saved";
939
+ break;
940
+
941
+ case PNG_HANDLE_CHUNK_ALWAYS:
942
+ if (!(flag & unknown))
943
+ errorx = "SAVE: unknown chunk lost";
944
+ break;
945
+
946
+ default:
947
+ errorx = "internal error: bad keep";
948
+ break;
949
+ }
950
+ } /* unknown chunk */
951
+
952
+ else /* known chunk */
953
+ {
954
+ type = "KNOWN";
955
+
956
+ if (flag & known)
957
+ {
958
+ /* chunk was processed, it won't have been saved because that is
959
+ * caught below when checking for inconsistent processing.
960
+ */
961
+ if (keep != PNG_HANDLE_CHUNK_AS_DEFAULT)
962
+ errorx = "!DEFAULT: known chunk processed";
963
+ }
964
+
965
+ else /* not processed */ switch (keep)
966
+ {
967
+ case PNG_HANDLE_CHUNK_AS_DEFAULT:
968
+ errorx = "DEFAULT: known chunk not processed";
969
+ break;
970
+
971
+ case PNG_HANDLE_CHUNK_NEVER:
972
+ if (flag & unknown)
973
+ errorx = "DISCARD: known chunk saved";
974
+ break;
975
+
976
+ case PNG_HANDLE_CHUNK_IF_SAFE:
977
+ if (ancillary(chunk_info[i].name))
978
+ {
979
+ if (!(flag & unknown))
980
+ errorx = "IF-SAFE: known ancillary chunk lost";
981
+ }
982
+
983
+ else if (flag & unknown)
984
+ errorx = "IF-SAFE: known critical chunk saved";
985
+ break;
986
+
987
+ case PNG_HANDLE_CHUNK_ALWAYS:
988
+ if (!(flag & unknown))
989
+ errorx = "SAVE: known chunk lost";
990
+ break;
991
+
992
+ default:
993
+ errorx = "internal error: bad keep (2)";
994
+ break;
995
+ }
996
+ }
997
+
998
+ if (errorx != NULL)
999
+ {
1000
+ ++(d->error_count);
1001
+ fprintf(stderr, "%s(%s%s): %s %s %s: %s\n", d->file, d->test,
1002
+ set_callback ? ",callback" : "",
1003
+ type, chunk_info[i].name, position, errorx);
1004
+ }
1005
+
1006
+ chunks &= ~flag;
1007
+ }
1008
+ }
1009
+
1010
+ static void
1011
+ perform_one_test(FILE *fp, int argc, const char **argv,
1012
+ png_uint_32 *default_flags, display *d, int set_callback)
1013
+ {
1014
+ int def;
1015
+ png_uint_32 flags[2][4];
1016
+
1017
+ rewind(fp);
1018
+ clear_keep();
1019
+ memcpy(flags[0], default_flags, sizeof flags[0]);
1020
+
1021
+ def = check(fp, argc, argv, flags[1], d, set_callback);
1022
+
1023
+ /* If IDAT is being handled as unknown the image read is skipped and all the
1024
+ * IDATs after the first end up in the end info struct, so in this case add
1025
+ * IDAT to the list of unknowns. (Do this after 'check' above sets the
1026
+ * chunk_info 'keep' fields.)
1027
+ *
1028
+ * Note that the flag setting has to be in the 'known' field to avoid
1029
+ * triggering the consistency check below and the flag must only be set if
1030
+ * there are multiple IDATs, so if the check above did find an unknown IDAT
1031
+ * after IDAT.
1032
+ */
1033
+ if (chunk_info[0/*IDAT*/].keep != PNG_HANDLE_CHUNK_AS_DEFAULT &&
1034
+ (flags[1][3] & PNG_INFO_IDAT) != 0)
1035
+ flags[0][2] |= PNG_INFO_IDAT;
1036
+
1037
+ /* Chunks should either be known or unknown, never both and this should apply
1038
+ * whether the chunk is before or after the IDAT (actually, the app can
1039
+ * probably change this by swapping the handling after the image, but this
1040
+ * test does not do that.)
1041
+ */
1042
+ check_error(d, (flags[0][0]|flags[0][2]) & (flags[0][1]|flags[0][3]),
1043
+ "chunk handled inconsistently in count tests");
1044
+ check_error(d, (flags[1][0]|flags[1][2]) & (flags[1][1]|flags[1][3]),
1045
+ "chunk handled inconsistently in option tests");
1046
+
1047
+ /* Now find out what happened to each chunk before and after the IDAT and
1048
+ * determine if the behavior was correct. First some basic sanity checks,
1049
+ * any known chunk should be known in the original count, any unknown chunk
1050
+ * should be either known or unknown in the original.
1051
+ */
1052
+ {
1053
+ png_uint_32 test;
1054
+
1055
+ test = flags[1][0] & ~flags[0][0];
1056
+ check_error(d, test, "new known chunk before IDAT");
1057
+ test = flags[1][1] & ~(flags[0][0] | flags[0][1]);
1058
+ check_error(d, test, "new unknown chunk before IDAT");
1059
+ test = flags[1][2] & ~flags[0][2];
1060
+ check_error(d, test, "new known chunk after IDAT");
1061
+ test = flags[1][3] & ~(flags[0][2] | flags[0][3]);
1062
+ check_error(d, test, "new unknown chunk after IDAT");
1063
+ }
1064
+
1065
+ /* Now each chunk in the original list should have been handled according to
1066
+ * the options set for that chunk, regardless of whether libpng knows about
1067
+ * it or not.
1068
+ */
1069
+ check_handling(d, def, flags[0][0] | flags[0][1], flags[1][0], flags[1][1],
1070
+ "before IDAT", set_callback);
1071
+ check_handling(d, def, flags[0][2] | flags[0][3], flags[1][2], flags[1][3],
1072
+ "after IDAT", set_callback);
1073
+ }
1074
+
1075
+ static void
1076
+ perform_one_test_safe(FILE *fp, int argc, const char **argv,
1077
+ png_uint_32 *default_flags, display *d, const char *test)
1078
+ {
1079
+ if (setjmp(d->error_return) == 0)
1080
+ {
1081
+ d->test = test; /* allow use of d->error_return */
1082
+ # ifdef PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED
1083
+ perform_one_test(fp, argc, argv, default_flags, d, 0);
1084
+ # endif
1085
+ # ifdef PNG_READ_USER_CHUNKS_SUPPORTED
1086
+ perform_one_test(fp, argc, argv, default_flags, d, 1);
1087
+ # endif
1088
+ d->test = init; /* prevent use of d->error_return */
1089
+ }
1090
+ }
1091
+
1092
+ static const char *standard_tests[] =
1093
+ {
1094
+ "discard", "default=discard", 0,
1095
+ "save", "default=save", 0,
1096
+ "if-safe", "default=if-safe", 0,
1097
+ "vpAg", "vpAg=if-safe", 0,
1098
+ "sTER", "sTER=if-safe", 0,
1099
+ "IDAT", "default=discard", "IDAT=save", 0,
1100
+ "sAPI", "bKGD=save", "cHRM=save", "gAMA=save", "all=discard", "iCCP=save",
1101
+ "sBIT=save", "sRGB=save", "eXIf=save", 0,
1102
+ 0/*end*/
1103
+ };
1104
+
1105
+ static PNG_NORETURN void
1106
+ usage(const char *program, const char *reason)
1107
+ {
1108
+ fprintf(stderr, "pngunknown: %s: usage:\n %s [--strict] "
1109
+ "--default|{(CHNK|default|all)=(default|discard|if-safe|save)} "
1110
+ "testfile.png\n", reason, program);
1111
+ exit(99);
1112
+ }
1113
+
1114
+ int
1115
+ main(int argc, const char **argv)
1116
+ {
1117
+ FILE *fp;
1118
+ png_uint_32 default_flags[4/*valid,unknown{before,after}*/];
1119
+ int strict = 0, default_tests = 0;
1120
+ const char *count_argv = "default=save";
1121
+ const char *touch_file = NULL;
1122
+ display d;
1123
+
1124
+ init_display(&d, argv[0]);
1125
+
1126
+ while (++argv, --argc > 0)
1127
+ {
1128
+ if (strcmp(*argv, "--strict") == 0)
1129
+ strict = 1;
1130
+
1131
+ else if (strcmp(*argv, "--default") == 0)
1132
+ default_tests = 1;
1133
+
1134
+ else if (strcmp(*argv, "--touch") == 0)
1135
+ {
1136
+ if (argc > 1)
1137
+ touch_file = *++argv, --argc;
1138
+
1139
+ else
1140
+ usage(d.program, "--touch: missing file name");
1141
+ }
1142
+
1143
+ else
1144
+ break;
1145
+ }
1146
+
1147
+ /* A file name is required, but there should be no other arguments if
1148
+ * --default was specified.
1149
+ */
1150
+ if (argc <= 0)
1151
+ usage(d.program, "missing test file");
1152
+
1153
+ /* GCC BUG: if (default_tests && argc != 1) triggers some weird GCC argc
1154
+ * optimization which causes warnings with -Wstrict-overflow!
1155
+ */
1156
+ else if (default_tests) if (argc != 1)
1157
+ usage(d.program, "extra arguments");
1158
+
1159
+ /* The name of the test file is the last argument; remove it. */
1160
+ d.file = argv[--argc];
1161
+
1162
+ fp = fopen(d.file, "rb");
1163
+ if (fp == NULL)
1164
+ {
1165
+ perror(d.file);
1166
+ exit(99);
1167
+ }
1168
+
1169
+ /* First find all the chunks, known and unknown, in the test file, a failure
1170
+ * here aborts the whole test.
1171
+ *
1172
+ * If 'save' is supported then the normal saving method should happen,
1173
+ * otherwise if 'read' is supported then the read callback will do the
1174
+ * same thing. If both are supported the 'read' callback won't be
1175
+ * instantiated by default. If 'save' is *not* supported then a user
1176
+ * callback is required even though we can call png_get_unknown_chunks.
1177
+ */
1178
+ if (check(fp, 1, &count_argv, default_flags, &d,
1179
+ # ifdef PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED
1180
+ 0
1181
+ # else
1182
+ 1
1183
+ # endif
1184
+ ) != PNG_HANDLE_CHUNK_ALWAYS)
1185
+ {
1186
+ fprintf(stderr, "%s: %s: internal error\n", d.program, d.file);
1187
+ exit(99);
1188
+ }
1189
+
1190
+ /* Now find what the various supplied options cause to change: */
1191
+ if (!default_tests)
1192
+ {
1193
+ d.test = cmd; /* acts as a flag to say exit, do not longjmp */
1194
+ # ifdef PNG_SAVE_UNKNOWN_CHUNKS_SUPPORTED
1195
+ perform_one_test(fp, argc, argv, default_flags, &d, 0);
1196
+ # endif
1197
+ # ifdef PNG_READ_USER_CHUNKS_SUPPORTED
1198
+ perform_one_test(fp, argc, argv, default_flags, &d, 1);
1199
+ # endif
1200
+ d.test = init;
1201
+ }
1202
+
1203
+ else
1204
+ {
1205
+ const char **test = standard_tests;
1206
+
1207
+ /* Set the exit_test pointer here so we can continue after a libpng error.
1208
+ * NOTE: this leaks memory because the png_struct data from the failing
1209
+ * test is never freed.
1210
+ */
1211
+ while (*test)
1212
+ {
1213
+ const char *this_test = *test++;
1214
+ const char **next = test;
1215
+ int count = display_rc(&d, strict), new_count;
1216
+ const char *result;
1217
+ int arg_count = 0;
1218
+
1219
+ while (*next) ++next, ++arg_count;
1220
+
1221
+ perform_one_test_safe(fp, arg_count, test, default_flags, &d,
1222
+ this_test);
1223
+
1224
+ new_count = display_rc(&d, strict);
1225
+
1226
+ if (new_count == count)
1227
+ result = "PASS";
1228
+
1229
+ else
1230
+ result = "FAIL";
1231
+
1232
+ printf("%s: %s %s\n", result, d.program, this_test);
1233
+
1234
+ test = next+1;
1235
+ }
1236
+ }
1237
+
1238
+ fclose(fp);
1239
+
1240
+ if (display_rc(&d, strict) == 0)
1241
+ {
1242
+ /* Success, touch the success file if appropriate */
1243
+ if (touch_file != NULL)
1244
+ {
1245
+ FILE *fsuccess = fopen(touch_file, "wt");
1246
+
1247
+ if (fsuccess != NULL)
1248
+ {
1249
+ int err = 0;
1250
+ fprintf(fsuccess, "PNG unknown tests succeeded\n");
1251
+ fflush(fsuccess);
1252
+ err = ferror(fsuccess);
1253
+
1254
+ if (fclose(fsuccess) || err)
1255
+ {
1256
+ fprintf(stderr, "%s: write failed\n", touch_file);
1257
+ exit(99);
1258
+ }
1259
+ }
1260
+
1261
+ else
1262
+ {
1263
+ fprintf(stderr, "%s: open failed\n", touch_file);
1264
+ exit(99);
1265
+ }
1266
+ }
1267
+
1268
+ return 0;
1269
+ }
1270
+
1271
+ return 1;
1272
+ }
1273
+
1274
+ #else /* !(READ_USER_CHUNKS || SAVE_UNKNOWN_CHUNKS) */
1275
+ int
1276
+ main(void)
1277
+ {
1278
+ fprintf(stderr,
1279
+ " test ignored: no support to find out about unknown chunks\n");
1280
+ /* So the test is skipped: */
1281
+ return SKIP;
1282
+ }
1283
+ #endif /* READ_USER_CHUNKS || SAVE_UNKNOWN_CHUNKS */
1284
+
1285
+ #else /* !(SET_UNKNOWN_CHUNKS && READ) */
1286
+ int
1287
+ main(void)
1288
+ {
1289
+ fprintf(stderr,
1290
+ " test ignored: no support to modify unknown chunk handling\n");
1291
+ /* So the test is skipped: */
1292
+ return SKIP;
1293
+ }
1294
+ #endif /* SET_UNKNOWN_CHUNKS && READ*/