lightdrift-libraw 1.0.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (487) hide show
  1. package/CHANGELOG.md +374 -0
  2. package/LICENSE +21 -0
  3. package/README.md +757 -0
  4. package/binding.gyp +38 -0
  5. package/deps/LibRaw-Source/LibRaw-0.21.4/.clang-format +4 -0
  6. package/deps/LibRaw-Source/LibRaw-0.21.4/COPYRIGHT +27 -0
  7. package/deps/LibRaw-Source/LibRaw-0.21.4/Changelog.txt +2802 -0
  8. package/deps/LibRaw-Source/LibRaw-0.21.4/DEVELOPER-NOTES +20 -0
  9. package/deps/LibRaw-Source/LibRaw-0.21.4/GoPro/dng-sdk-1_4-allow-VC5-validate.diff +21 -0
  10. package/deps/LibRaw-Source/LibRaw-0.21.4/GoPro/dng-sdk-1_6-hide-ccVc5-definitiion.diff +15 -0
  11. package/deps/LibRaw-Source/LibRaw-0.21.4/GoPro/dng-sdk-allow-VC5-validate.diff +21 -0
  12. package/deps/LibRaw-Source/LibRaw-0.21.4/GoPro/gpr_read_image.cpp.diff +29 -0
  13. package/deps/LibRaw-Source/LibRaw-0.21.4/GoPro/gpr_read_image.h.diff +12 -0
  14. package/deps/LibRaw-Source/LibRaw-0.21.4/INSTALL +51 -0
  15. package/deps/LibRaw-Source/LibRaw-0.21.4/LICENSE.CDDL +340 -0
  16. package/deps/LibRaw-Source/LibRaw-0.21.4/LICENSE.LGPL +458 -0
  17. package/deps/LibRaw-Source/LibRaw-0.21.4/LibRaw.pro +19 -0
  18. package/deps/LibRaw-Source/LibRaw-0.21.4/LibRaw.sln +123 -0
  19. package/deps/LibRaw-Source/LibRaw-0.21.4/Makefile.am +140 -0
  20. package/deps/LibRaw-Source/LibRaw-0.21.4/Makefile.devel.nopp +230 -0
  21. package/deps/LibRaw-Source/LibRaw-0.21.4/Makefile.devel.noppr2i +227 -0
  22. package/deps/LibRaw-Source/LibRaw-0.21.4/Makefile.dist +501 -0
  23. package/deps/LibRaw-Source/LibRaw-0.21.4/Makefile.in +1849 -0
  24. package/deps/LibRaw-Source/LibRaw-0.21.4/Makefile.mingw +297 -0
  25. package/deps/LibRaw-Source/LibRaw-0.21.4/Makefile.msvc +628 -0
  26. package/deps/LibRaw-Source/LibRaw-0.21.4/README.DNGSDK.txt +43 -0
  27. package/deps/LibRaw-Source/LibRaw-0.21.4/README.GoPro.txt +112 -0
  28. package/deps/LibRaw-Source/LibRaw-0.21.4/README.RawSpeed.txt +62 -0
  29. package/deps/LibRaw-Source/LibRaw-0.21.4/README.cmake +9 -0
  30. package/deps/LibRaw-Source/LibRaw-0.21.4/README.demosaic-packs +17 -0
  31. package/deps/LibRaw-Source/LibRaw-0.21.4/README.md +106 -0
  32. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed/rawspeed.cpucount-unix.patch +15 -0
  33. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed/rawspeed.qmake-pro-files.patch +84 -0
  34. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed/rawspeed.samsung-decoder.patch +39 -0
  35. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed/rawspeed.uncompressed-color-dng.patch +13 -0
  36. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed/rawspeed.win32-dll.patch +186 -0
  37. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed/rawspeed_xmldata.cpp +4115 -0
  38. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/README.md +69 -0
  39. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/patches/01.CameraMeta-extensibility.patch +13 -0
  40. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/patches/02.Makernotes-processing.patch +36 -0
  41. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/patches/03.remove-limits-and-logging.patch +245 -0
  42. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/patches/04.clang-cl-compatibility.patch +37 -0
  43. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rawspeed3_capi.cpp +251 -0
  44. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rawspeed3_capi.h +83 -0
  45. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rawspeed3_capi_test.cpp +71 -0
  46. package/deps/LibRaw-Source/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rsxml2c.sh +5 -0
  47. package/deps/LibRaw-Source/LibRaw-0.21.4/aclocal.m4 +1446 -0
  48. package/deps/LibRaw-Source/LibRaw-0.21.4/autom4te.cache/output.0 +19332 -0
  49. package/deps/LibRaw-Source/LibRaw-0.21.4/autom4te.cache/output.1 +19332 -0
  50. package/deps/LibRaw-Source/LibRaw-0.21.4/autom4te.cache/output.2 +19332 -0
  51. package/deps/LibRaw-Source/LibRaw-0.21.4/autom4te.cache/requests +544 -0
  52. package/deps/LibRaw-Source/LibRaw-0.21.4/autom4te.cache/traces.0 +3028 -0
  53. package/deps/LibRaw-Source/LibRaw-0.21.4/autom4te.cache/traces.1 +665 -0
  54. package/deps/LibRaw-Source/LibRaw-0.21.4/autom4te.cache/traces.2 +3028 -0
  55. package/deps/LibRaw-Source/LibRaw-0.21.4/bin/.keep_me +2 -0
  56. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/4channels.pro +5 -0
  57. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/4channels.vcxproj +145 -0
  58. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/4channels.vcxproj.filters +18 -0
  59. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/dcraw_emu.pro +6 -0
  60. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/dcraw_emu.vcxproj +145 -0
  61. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/dcraw_emu.vcxproj.filters +18 -0
  62. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/dcraw_half.pro +6 -0
  63. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/dcraw_half.vcxproj +145 -0
  64. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/dcraw_half.vcxproj.filters +18 -0
  65. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/half_mt.pro +10 -0
  66. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/libraw-common-lib.pro +28 -0
  67. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/libraw-common.pro +8 -0
  68. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/libraw.pro +70 -0
  69. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/libraw.vcxproj +234 -0
  70. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/libraw.vcxproj.filters +295 -0
  71. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/mem_image.pro +6 -0
  72. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/mem_image.vcxproj +145 -0
  73. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/mem_image.vcxproj.filters +18 -0
  74. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/multirender_test.pro +6 -0
  75. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/multirender_test.vcxproj +145 -0
  76. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/multirender_test.vcxproj.filters +18 -0
  77. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/openbayer_sample.pro +6 -0
  78. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/openbayer_sample.vcxproj +145 -0
  79. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/openbayer_sample.vcxproj.filters +18 -0
  80. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/postprocessing_benchmark.pro +4 -0
  81. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/postprocessing_benchmark.vcxproj +145 -0
  82. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/postprocessing_benchmark.vcxproj.filters +18 -0
  83. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/raw-identify.pro +6 -0
  84. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/raw-identify.vcxproj +145 -0
  85. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/raw-identify.vcxproj.filters +18 -0
  86. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/rawtextdump.pro +6 -0
  87. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/rawtextdump.vcxproj +145 -0
  88. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/rawtextdump.vcxproj.filters +18 -0
  89. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/simple_dcraw.pro +6 -0
  90. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/simple_dcraw.vcxproj +145 -0
  91. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/simple_dcraw.vcxproj.filters +18 -0
  92. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/unprocessed_raw.pro +6 -0
  93. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/unprocessed_raw.vcxproj +145 -0
  94. package/deps/LibRaw-Source/LibRaw-0.21.4/buildfiles/unprocessed_raw.vcxproj.filters +18 -0
  95. package/deps/LibRaw-Source/LibRaw-0.21.4/compile +347 -0
  96. package/deps/LibRaw-Source/LibRaw-0.21.4/config.guess +1433 -0
  97. package/deps/LibRaw-Source/LibRaw-0.21.4/config.sub +1804 -0
  98. package/deps/LibRaw-Source/LibRaw-0.21.4/configure +19332 -0
  99. package/deps/LibRaw-Source/LibRaw-0.21.4/configure.ac +153 -0
  100. package/deps/LibRaw-Source/LibRaw-0.21.4/depcomp +791 -0
  101. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/API-C.html +187 -0
  102. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/API-CXX.html +881 -0
  103. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/API-datastruct.html +1341 -0
  104. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/API-notes.html +305 -0
  105. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/API-overview.html +66 -0
  106. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/Install-LibRaw.html +124 -0
  107. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/Samples-LibRaw.html +213 -0
  108. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/Why-LibRaw.html +65 -0
  109. package/deps/LibRaw-Source/LibRaw-0.21.4/doc/index.html +38 -0
  110. package/deps/LibRaw-Source/LibRaw-0.21.4/install-sh +501 -0
  111. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/dcraw_defs.h +66 -0
  112. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/dcraw_fileio_defs.h +25 -0
  113. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/defines.h +193 -0
  114. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/dmp_include.h +27 -0
  115. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/libraw_cameraids.h +320 -0
  116. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/libraw_cxx_defs.h +133 -0
  117. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/libraw_internal_funcs.h +412 -0
  118. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/var_defines.h +215 -0
  119. package/deps/LibRaw-Source/LibRaw-0.21.4/internal/x3f_tools.h +539 -0
  120. package/deps/LibRaw-Source/LibRaw-0.21.4/lib/Makefile +3 -0
  121. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw/libraw.h +534 -0
  122. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw/libraw_alloc.h +148 -0
  123. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw/libraw_const.h +814 -0
  124. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw/libraw_datastream.h +410 -0
  125. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw/libraw_internal.h +341 -0
  126. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw/libraw_types.h +1175 -0
  127. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw/libraw_version.h +63 -0
  128. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw.pc.in +12 -0
  129. package/deps/LibRaw-Source/LibRaw-0.21.4/libraw_r.pc.in +12 -0
  130. package/deps/LibRaw-Source/LibRaw-0.21.4/ltmain.sh +11147 -0
  131. package/deps/LibRaw-Source/LibRaw-0.21.4/m4/ax_openmp.m4 +99 -0
  132. package/deps/LibRaw-Source/LibRaw-0.21.4/m4/libtool.m4 +8369 -0
  133. package/deps/LibRaw-Source/LibRaw-0.21.4/m4/ltoptions.m4 +437 -0
  134. package/deps/LibRaw-Source/LibRaw-0.21.4/m4/ltsugar.m4 +124 -0
  135. package/deps/LibRaw-Source/LibRaw-0.21.4/m4/ltversion.m4 +23 -0
  136. package/deps/LibRaw-Source/LibRaw-0.21.4/m4/lt~obsolete.m4 +99 -0
  137. package/deps/LibRaw-Source/LibRaw-0.21.4/missing +215 -0
  138. package/deps/LibRaw-Source/LibRaw-0.21.4/object/.keep_me +0 -0
  139. package/deps/LibRaw-Source/LibRaw-0.21.4/rsxml2c.sh +6 -0
  140. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/4channels.cpp +174 -0
  141. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/Makefile +2 -0
  142. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/dcraw_emu.cpp +670 -0
  143. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/dcraw_half.c +78 -0
  144. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/half_mt.c +178 -0
  145. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/half_mt_win32.c +212 -0
  146. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/mem_image_sample.cpp +282 -0
  147. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/multirender_test.cpp +107 -0
  148. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/openbayer_sample.cpp +65 -0
  149. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/postprocessing_benchmark.cpp +223 -0
  150. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/raw-identify.cpp +743 -0
  151. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/rawtextdump.cpp +144 -0
  152. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/simple_dcraw.cpp +217 -0
  153. package/deps/LibRaw-Source/LibRaw-0.21.4/samples/unprocessed_raw.cpp +319 -0
  154. package/deps/LibRaw-Source/LibRaw-0.21.4/shlib-version.sh +11 -0
  155. package/deps/LibRaw-Source/LibRaw-0.21.4/src/Makefile +2 -0
  156. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/canon_600.cpp +225 -0
  157. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/crx.cpp +2781 -0
  158. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/decoders_dcraw.cpp +1816 -0
  159. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/decoders_libraw.cpp +873 -0
  160. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/decoders_libraw_dcrdefs.cpp +411 -0
  161. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/dng.cpp +284 -0
  162. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/fp_dng.cpp +689 -0
  163. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/fuji_compressed.cpp +1210 -0
  164. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/generic.cpp +101 -0
  165. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/kodak_decoders.cpp +524 -0
  166. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/load_mfbacks.cpp +936 -0
  167. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/smal.cpp +181 -0
  168. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/unpack.cpp +508 -0
  169. package/deps/LibRaw-Source/LibRaw-0.21.4/src/decoders/unpack_thumb.cpp +405 -0
  170. package/deps/LibRaw-Source/LibRaw-0.21.4/src/demosaic/aahd_demosaic.cpp +781 -0
  171. package/deps/LibRaw-Source/LibRaw-0.21.4/src/demosaic/ahd_demosaic.cpp +355 -0
  172. package/deps/LibRaw-Source/LibRaw-0.21.4/src/demosaic/dcb_demosaic.cpp +900 -0
  173. package/deps/LibRaw-Source/LibRaw-0.21.4/src/demosaic/dht_demosaic.cpp +1033 -0
  174. package/deps/LibRaw-Source/LibRaw-0.21.4/src/demosaic/misc_demosaic.cpp +420 -0
  175. package/deps/LibRaw-Source/LibRaw-0.21.4/src/demosaic/xtrans_demosaic.cpp +434 -0
  176. package/deps/LibRaw-Source/LibRaw-0.21.4/src/integration/dngsdk_glue.cpp +416 -0
  177. package/deps/LibRaw-Source/LibRaw-0.21.4/src/integration/rawspeed_glue.cpp +286 -0
  178. package/deps/LibRaw-Source/LibRaw-0.21.4/src/libraw_c_api.cpp +457 -0
  179. package/deps/LibRaw-Source/LibRaw-0.21.4/src/libraw_datastream.cpp +1046 -0
  180. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/adobepano.cpp +154 -0
  181. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/canon.cpp +1335 -0
  182. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/ciff.cpp +411 -0
  183. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/cr3_parser.cpp +896 -0
  184. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/epson.cpp +96 -0
  185. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/exif_gps.cpp +430 -0
  186. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/fuji.cpp +1427 -0
  187. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/hasselblad_model.cpp +538 -0
  188. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/identify.cpp +3167 -0
  189. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/identify_tools.cpp +140 -0
  190. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/kodak.cpp +363 -0
  191. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/leica.cpp +375 -0
  192. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/makernotes.cpp +786 -0
  193. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/mediumformat.cpp +521 -0
  194. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/minolta.cpp +110 -0
  195. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/misc_parsers.cpp +694 -0
  196. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/nikon.cpp +1051 -0
  197. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/normalize_model.cpp +1451 -0
  198. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/olympus.cpp +685 -0
  199. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/p1.cpp +192 -0
  200. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/pentax.cpp +675 -0
  201. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/samsung.cpp +182 -0
  202. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/sony.cpp +2320 -0
  203. package/deps/LibRaw-Source/LibRaw-0.21.4/src/metadata/tiff.cpp +2198 -0
  204. package/deps/LibRaw-Source/LibRaw-0.21.4/src/postprocessing/aspect_ratio.cpp +113 -0
  205. package/deps/LibRaw-Source/LibRaw-0.21.4/src/postprocessing/dcraw_process.cpp +259 -0
  206. package/deps/LibRaw-Source/LibRaw-0.21.4/src/postprocessing/mem_image.cpp +292 -0
  207. package/deps/LibRaw-Source/LibRaw-0.21.4/src/postprocessing/postprocessing_aux.cpp +413 -0
  208. package/deps/LibRaw-Source/LibRaw-0.21.4/src/postprocessing/postprocessing_ph.cpp +31 -0
  209. package/deps/LibRaw-Source/LibRaw-0.21.4/src/postprocessing/postprocessing_utils.cpp +190 -0
  210. package/deps/LibRaw-Source/LibRaw-0.21.4/src/postprocessing/postprocessing_utils_dcrdefs.cpp +308 -0
  211. package/deps/LibRaw-Source/LibRaw-0.21.4/src/preprocessing/ext_preprocess.cpp +127 -0
  212. package/deps/LibRaw-Source/LibRaw-0.21.4/src/preprocessing/preprocessing_ph.cpp +24 -0
  213. package/deps/LibRaw-Source/LibRaw-0.21.4/src/preprocessing/raw2image.cpp +560 -0
  214. package/deps/LibRaw-Source/LibRaw-0.21.4/src/preprocessing/subtract_black.cpp +91 -0
  215. package/deps/LibRaw-Source/LibRaw-0.21.4/src/tables/cameralist.cpp +1268 -0
  216. package/deps/LibRaw-Source/LibRaw-0.21.4/src/tables/colorconst.cpp +57 -0
  217. package/deps/LibRaw-Source/LibRaw-0.21.4/src/tables/colordata.cpp +1841 -0
  218. package/deps/LibRaw-Source/LibRaw-0.21.4/src/tables/wblists.cpp +217 -0
  219. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/curves.cpp +154 -0
  220. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/decoder_info.cpp +413 -0
  221. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/init_close_utils.cpp +340 -0
  222. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/open.cpp +1269 -0
  223. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/phaseone_processing.cpp +101 -0
  224. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/read_utils.cpp +176 -0
  225. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/thumb_utils.cpp +338 -0
  226. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/utils_dcraw.cpp +330 -0
  227. package/deps/LibRaw-Source/LibRaw-0.21.4/src/utils/utils_libraw.cpp +673 -0
  228. package/deps/LibRaw-Source/LibRaw-0.21.4/src/write/apply_profile.cpp +76 -0
  229. package/deps/LibRaw-Source/LibRaw-0.21.4/src/write/file_write.cpp +338 -0
  230. package/deps/LibRaw-Source/LibRaw-0.21.4/src/write/tiff_writer.cpp +73 -0
  231. package/deps/LibRaw-Source/LibRaw-0.21.4/src/write/write_ph.cpp +39 -0
  232. package/deps/LibRaw-Source/LibRaw-0.21.4/src/x3f/x3f_parse_process.cpp +708 -0
  233. package/deps/LibRaw-Source/LibRaw-0.21.4/src/x3f/x3f_utils_patched.cpp +2119 -0
  234. package/deps/LibRaw-Source/LibRaw-0.21.4/version.sh +16 -0
  235. package/deps/LibRaw-Win64/LibRaw-0.21.4/.clang-format +4 -0
  236. package/deps/LibRaw-Win64/LibRaw-0.21.4/COPYRIGHT +27 -0
  237. package/deps/LibRaw-Win64/LibRaw-0.21.4/Changelog.txt +2802 -0
  238. package/deps/LibRaw-Win64/LibRaw-0.21.4/DEVELOPER-NOTES +20 -0
  239. package/deps/LibRaw-Win64/LibRaw-0.21.4/GoPro/dng-sdk-1_4-allow-VC5-validate.diff +21 -0
  240. package/deps/LibRaw-Win64/LibRaw-0.21.4/GoPro/dng-sdk-1_6-hide-ccVc5-definitiion.diff +15 -0
  241. package/deps/LibRaw-Win64/LibRaw-0.21.4/GoPro/dng-sdk-allow-VC5-validate.diff +21 -0
  242. package/deps/LibRaw-Win64/LibRaw-0.21.4/GoPro/gpr_read_image.cpp.diff +29 -0
  243. package/deps/LibRaw-Win64/LibRaw-0.21.4/GoPro/gpr_read_image.h.diff +12 -0
  244. package/deps/LibRaw-Win64/LibRaw-0.21.4/INSTALL +51 -0
  245. package/deps/LibRaw-Win64/LibRaw-0.21.4/LICENSE.CDDL +340 -0
  246. package/deps/LibRaw-Win64/LibRaw-0.21.4/LICENSE.LGPL +458 -0
  247. package/deps/LibRaw-Win64/LibRaw-0.21.4/LibRaw.pro +19 -0
  248. package/deps/LibRaw-Win64/LibRaw-0.21.4/LibRaw.sln +123 -0
  249. package/deps/LibRaw-Win64/LibRaw-0.21.4/Makefile.am +140 -0
  250. package/deps/LibRaw-Win64/LibRaw-0.21.4/Makefile.devel.nopp +230 -0
  251. package/deps/LibRaw-Win64/LibRaw-0.21.4/Makefile.devel.noppr2i +227 -0
  252. package/deps/LibRaw-Win64/LibRaw-0.21.4/Makefile.dist +501 -0
  253. package/deps/LibRaw-Win64/LibRaw-0.21.4/Makefile.in +1849 -0
  254. package/deps/LibRaw-Win64/LibRaw-0.21.4/Makefile.mingw +297 -0
  255. package/deps/LibRaw-Win64/LibRaw-0.21.4/Makefile.msvc +628 -0
  256. package/deps/LibRaw-Win64/LibRaw-0.21.4/README.DNGSDK.txt +43 -0
  257. package/deps/LibRaw-Win64/LibRaw-0.21.4/README.GoPro.txt +112 -0
  258. package/deps/LibRaw-Win64/LibRaw-0.21.4/README.RawSpeed.txt +62 -0
  259. package/deps/LibRaw-Win64/LibRaw-0.21.4/README.cmake +9 -0
  260. package/deps/LibRaw-Win64/LibRaw-0.21.4/README.demosaic-packs +17 -0
  261. package/deps/LibRaw-Win64/LibRaw-0.21.4/README.md +106 -0
  262. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed/rawspeed.cpucount-unix.patch +15 -0
  263. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed/rawspeed.qmake-pro-files.patch +84 -0
  264. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed/rawspeed.samsung-decoder.patch +39 -0
  265. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed/rawspeed.uncompressed-color-dng.patch +13 -0
  266. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed/rawspeed.win32-dll.patch +186 -0
  267. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed/rawspeed_xmldata.cpp +4115 -0
  268. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/README.md +69 -0
  269. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/patches/01.CameraMeta-extensibility.patch +13 -0
  270. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/patches/02.Makernotes-processing.patch +36 -0
  271. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/patches/03.remove-limits-and-logging.patch +245 -0
  272. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/patches/04.clang-cl-compatibility.patch +37 -0
  273. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rawspeed3_capi.cpp +251 -0
  274. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rawspeed3_capi.h +83 -0
  275. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rawspeed3_capi_test.cpp +71 -0
  276. package/deps/LibRaw-Win64/LibRaw-0.21.4/RawSpeed3/rawspeed3_c_api/rsxml2c.sh +5 -0
  277. package/deps/LibRaw-Win64/LibRaw-0.21.4/aclocal.m4 +1446 -0
  278. package/deps/LibRaw-Win64/LibRaw-0.21.4/autom4te.cache/output.0 +19332 -0
  279. package/deps/LibRaw-Win64/LibRaw-0.21.4/autom4te.cache/output.1 +19332 -0
  280. package/deps/LibRaw-Win64/LibRaw-0.21.4/autom4te.cache/output.2 +19332 -0
  281. package/deps/LibRaw-Win64/LibRaw-0.21.4/autom4te.cache/requests +544 -0
  282. package/deps/LibRaw-Win64/LibRaw-0.21.4/autom4te.cache/traces.0 +3028 -0
  283. package/deps/LibRaw-Win64/LibRaw-0.21.4/autom4te.cache/traces.1 +665 -0
  284. package/deps/LibRaw-Win64/LibRaw-0.21.4/autom4te.cache/traces.2 +3028 -0
  285. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/.keep_me +2 -0
  286. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/4channels.exe +0 -0
  287. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/dcraw_emu.exe +0 -0
  288. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/dcraw_half.exe +0 -0
  289. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/half_mt.exe +0 -0
  290. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/libraw.dll +0 -0
  291. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/mem_image.exe +0 -0
  292. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/multirender_test.exe +0 -0
  293. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/openbayer_sample.exe +0 -0
  294. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/postprocessing_benchmark.exe +0 -0
  295. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/raw-identify.exe +0 -0
  296. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/rawtextdump.exe +0 -0
  297. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/simple_dcraw.exe +0 -0
  298. package/deps/LibRaw-Win64/LibRaw-0.21.4/bin/unprocessed_raw.exe +0 -0
  299. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/4channels.pro +5 -0
  300. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/4channels.vcxproj +145 -0
  301. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/4channels.vcxproj.filters +18 -0
  302. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/dcraw_emu.pro +6 -0
  303. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/dcraw_emu.vcxproj +145 -0
  304. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/dcraw_emu.vcxproj.filters +18 -0
  305. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/dcraw_half.pro +6 -0
  306. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/dcraw_half.vcxproj +145 -0
  307. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/dcraw_half.vcxproj.filters +18 -0
  308. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/half_mt.pro +10 -0
  309. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/libraw-common-lib.pro +28 -0
  310. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/libraw-common.pro +8 -0
  311. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/libraw.pro +70 -0
  312. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/libraw.vcxproj +234 -0
  313. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/libraw.vcxproj.filters +295 -0
  314. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/mem_image.pro +6 -0
  315. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/mem_image.vcxproj +145 -0
  316. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/mem_image.vcxproj.filters +18 -0
  317. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/multirender_test.pro +6 -0
  318. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/multirender_test.vcxproj +145 -0
  319. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/multirender_test.vcxproj.filters +18 -0
  320. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/openbayer_sample.pro +6 -0
  321. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/openbayer_sample.vcxproj +145 -0
  322. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/openbayer_sample.vcxproj.filters +18 -0
  323. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/postprocessing_benchmark.pro +4 -0
  324. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/postprocessing_benchmark.vcxproj +145 -0
  325. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/postprocessing_benchmark.vcxproj.filters +18 -0
  326. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/raw-identify.pro +6 -0
  327. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/raw-identify.vcxproj +145 -0
  328. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/raw-identify.vcxproj.filters +18 -0
  329. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/rawtextdump.pro +6 -0
  330. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/rawtextdump.vcxproj +145 -0
  331. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/rawtextdump.vcxproj.filters +18 -0
  332. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/simple_dcraw.pro +6 -0
  333. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/simple_dcraw.vcxproj +145 -0
  334. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/simple_dcraw.vcxproj.filters +18 -0
  335. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/unprocessed_raw.pro +6 -0
  336. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/unprocessed_raw.vcxproj +145 -0
  337. package/deps/LibRaw-Win64/LibRaw-0.21.4/buildfiles/unprocessed_raw.vcxproj.filters +18 -0
  338. package/deps/LibRaw-Win64/LibRaw-0.21.4/compile +347 -0
  339. package/deps/LibRaw-Win64/LibRaw-0.21.4/config.guess +1433 -0
  340. package/deps/LibRaw-Win64/LibRaw-0.21.4/config.sub +1804 -0
  341. package/deps/LibRaw-Win64/LibRaw-0.21.4/configure +19332 -0
  342. package/deps/LibRaw-Win64/LibRaw-0.21.4/configure.ac +153 -0
  343. package/deps/LibRaw-Win64/LibRaw-0.21.4/depcomp +791 -0
  344. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/API-C.html +187 -0
  345. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/API-CXX.html +881 -0
  346. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/API-datastruct.html +1341 -0
  347. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/API-notes.html +305 -0
  348. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/API-overview.html +66 -0
  349. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/Install-LibRaw.html +124 -0
  350. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/Samples-LibRaw.html +213 -0
  351. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/Why-LibRaw.html +65 -0
  352. package/deps/LibRaw-Win64/LibRaw-0.21.4/doc/index.html +38 -0
  353. package/deps/LibRaw-Win64/LibRaw-0.21.4/install-sh +501 -0
  354. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/dcraw_defs.h +66 -0
  355. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/dcraw_fileio_defs.h +25 -0
  356. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/defines.h +193 -0
  357. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/dmp_include.h +27 -0
  358. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/libraw_cameraids.h +320 -0
  359. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/libraw_cxx_defs.h +133 -0
  360. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/libraw_internal_funcs.h +412 -0
  361. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/var_defines.h +215 -0
  362. package/deps/LibRaw-Win64/LibRaw-0.21.4/internal/x3f_tools.h +539 -0
  363. package/deps/LibRaw-Win64/LibRaw-0.21.4/lib/Makefile +3 -0
  364. package/deps/LibRaw-Win64/LibRaw-0.21.4/lib/libraw.exp +0 -0
  365. package/deps/LibRaw-Win64/LibRaw-0.21.4/lib/libraw.lib +0 -0
  366. package/deps/LibRaw-Win64/LibRaw-0.21.4/lib/libraw_static.lib +0 -0
  367. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw/libraw.h +534 -0
  368. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw/libraw_alloc.h +148 -0
  369. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw/libraw_const.h +814 -0
  370. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw/libraw_datastream.h +410 -0
  371. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw/libraw_internal.h +341 -0
  372. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw/libraw_types.h +1175 -0
  373. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw/libraw_version.h +63 -0
  374. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw.pc.in +12 -0
  375. package/deps/LibRaw-Win64/LibRaw-0.21.4/libraw_r.pc.in +12 -0
  376. package/deps/LibRaw-Win64/LibRaw-0.21.4/ltmain.sh +11147 -0
  377. package/deps/LibRaw-Win64/LibRaw-0.21.4/m4/ax_openmp.m4 +99 -0
  378. package/deps/LibRaw-Win64/LibRaw-0.21.4/m4/libtool.m4 +8369 -0
  379. package/deps/LibRaw-Win64/LibRaw-0.21.4/m4/ltoptions.m4 +437 -0
  380. package/deps/LibRaw-Win64/LibRaw-0.21.4/m4/ltsugar.m4 +124 -0
  381. package/deps/LibRaw-Win64/LibRaw-0.21.4/m4/ltversion.m4 +23 -0
  382. package/deps/LibRaw-Win64/LibRaw-0.21.4/m4/lt~obsolete.m4 +99 -0
  383. package/deps/LibRaw-Win64/LibRaw-0.21.4/missing +215 -0
  384. package/deps/LibRaw-Win64/LibRaw-0.21.4/object/.keep_me +0 -0
  385. package/deps/LibRaw-Win64/LibRaw-0.21.4/rsxml2c.sh +6 -0
  386. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/4channels.cpp +174 -0
  387. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/Makefile +2 -0
  388. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/dcraw_emu.cpp +670 -0
  389. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/dcraw_half.c +78 -0
  390. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/half_mt.c +178 -0
  391. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/half_mt_win32.c +212 -0
  392. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/mem_image_sample.cpp +282 -0
  393. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/multirender_test.cpp +107 -0
  394. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/openbayer_sample.cpp +65 -0
  395. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/postprocessing_benchmark.cpp +223 -0
  396. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/raw-identify.cpp +743 -0
  397. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/rawtextdump.cpp +144 -0
  398. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/simple_dcraw.cpp +217 -0
  399. package/deps/LibRaw-Win64/LibRaw-0.21.4/samples/unprocessed_raw.cpp +319 -0
  400. package/deps/LibRaw-Win64/LibRaw-0.21.4/shlib-version.sh +11 -0
  401. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/Makefile +2 -0
  402. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/canon_600.cpp +225 -0
  403. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/crx.cpp +2781 -0
  404. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/decoders_dcraw.cpp +1816 -0
  405. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/decoders_libraw.cpp +873 -0
  406. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/decoders_libraw_dcrdefs.cpp +411 -0
  407. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/dng.cpp +284 -0
  408. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/fp_dng.cpp +689 -0
  409. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/fuji_compressed.cpp +1210 -0
  410. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/generic.cpp +101 -0
  411. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/kodak_decoders.cpp +524 -0
  412. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/load_mfbacks.cpp +936 -0
  413. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/smal.cpp +181 -0
  414. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/unpack.cpp +508 -0
  415. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/decoders/unpack_thumb.cpp +405 -0
  416. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/demosaic/aahd_demosaic.cpp +781 -0
  417. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/demosaic/ahd_demosaic.cpp +355 -0
  418. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/demosaic/dcb_demosaic.cpp +900 -0
  419. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/demosaic/dht_demosaic.cpp +1033 -0
  420. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/demosaic/misc_demosaic.cpp +420 -0
  421. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/demosaic/xtrans_demosaic.cpp +434 -0
  422. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/integration/dngsdk_glue.cpp +416 -0
  423. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/integration/rawspeed_glue.cpp +286 -0
  424. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/libraw_c_api.cpp +457 -0
  425. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/libraw_datastream.cpp +1046 -0
  426. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/adobepano.cpp +154 -0
  427. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/canon.cpp +1335 -0
  428. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/ciff.cpp +411 -0
  429. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/cr3_parser.cpp +896 -0
  430. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/epson.cpp +96 -0
  431. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/exif_gps.cpp +430 -0
  432. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/fuji.cpp +1427 -0
  433. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/hasselblad_model.cpp +538 -0
  434. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/identify.cpp +3167 -0
  435. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/identify_tools.cpp +140 -0
  436. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/kodak.cpp +363 -0
  437. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/leica.cpp +375 -0
  438. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/makernotes.cpp +786 -0
  439. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/mediumformat.cpp +521 -0
  440. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/minolta.cpp +110 -0
  441. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/misc_parsers.cpp +694 -0
  442. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/nikon.cpp +1051 -0
  443. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/normalize_model.cpp +1451 -0
  444. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/olympus.cpp +685 -0
  445. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/p1.cpp +192 -0
  446. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/pentax.cpp +675 -0
  447. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/samsung.cpp +182 -0
  448. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/sony.cpp +2320 -0
  449. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/metadata/tiff.cpp +2198 -0
  450. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/postprocessing/aspect_ratio.cpp +113 -0
  451. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/postprocessing/dcraw_process.cpp +259 -0
  452. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/postprocessing/mem_image.cpp +292 -0
  453. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/postprocessing/postprocessing_aux.cpp +413 -0
  454. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/postprocessing/postprocessing_ph.cpp +31 -0
  455. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/postprocessing/postprocessing_utils.cpp +190 -0
  456. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/postprocessing/postprocessing_utils_dcrdefs.cpp +308 -0
  457. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/preprocessing/ext_preprocess.cpp +127 -0
  458. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/preprocessing/preprocessing_ph.cpp +24 -0
  459. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/preprocessing/raw2image.cpp +560 -0
  460. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/preprocessing/subtract_black.cpp +91 -0
  461. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/tables/cameralist.cpp +1268 -0
  462. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/tables/colorconst.cpp +57 -0
  463. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/tables/colordata.cpp +1841 -0
  464. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/tables/wblists.cpp +217 -0
  465. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/curves.cpp +154 -0
  466. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/decoder_info.cpp +413 -0
  467. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/init_close_utils.cpp +340 -0
  468. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/open.cpp +1269 -0
  469. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/phaseone_processing.cpp +101 -0
  470. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/read_utils.cpp +176 -0
  471. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/thumb_utils.cpp +338 -0
  472. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/utils_dcraw.cpp +330 -0
  473. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/utils/utils_libraw.cpp +673 -0
  474. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/write/apply_profile.cpp +76 -0
  475. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/write/file_write.cpp +338 -0
  476. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/write/tiff_writer.cpp +73 -0
  477. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/write/write_ph.cpp +39 -0
  478. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/x3f/x3f_parse_process.cpp +708 -0
  479. package/deps/LibRaw-Win64/LibRaw-0.21.4/src/x3f/x3f_utils_patched.cpp +2119 -0
  480. package/deps/LibRaw-Win64/LibRaw-0.21.4/version.sh +16 -0
  481. package/lib/index.d.ts +324 -0
  482. package/lib/index.js +761 -0
  483. package/package.json +97 -0
  484. package/src/addon.cpp +8 -0
  485. package/src/libraw_wrapper.cpp +1223 -0
  486. package/src/libraw_wrapper.h +109 -0
  487. package/src/libraw_wrapper_new.cpp +853 -0
@@ -0,0 +1,936 @@
1
+ /* -*- C++ -*-
2
+ * Copyright 2019-2021 LibRaw LLC (info@libraw.org)
3
+ *
4
+ LibRaw uses code from dcraw.c -- Dave Coffin's raw photo decoder,
5
+ dcraw.c is copyright 1997-2018 by Dave Coffin, dcoffin a cybercom o net.
6
+ LibRaw do not use RESTRICTED code from dcraw.c
7
+
8
+ LibRaw is free software; you can redistribute it and/or modify
9
+ it under the terms of the one of two licenses as you choose:
10
+
11
+ 1. GNU LESSER GENERAL PUBLIC LICENSE version 2.1
12
+ (See file LICENSE.LGPL provided in LibRaw distribution archive for details).
13
+
14
+ 2. COMMON DEVELOPMENT AND DISTRIBUTION LICENSE (CDDL) Version 1.0
15
+ (See file LICENSE.CDDL provided in LibRaw distribution archive for details).
16
+
17
+ */
18
+
19
+ #include "../../internal/dcraw_defs.h"
20
+
21
+ inline uint32_t abs32(int32_t x)
22
+ {
23
+ // Branchless version.
24
+ uint32_t sm = x >> 31;
25
+ return (uint32_t) ((x + sm) ^ sm);
26
+ }
27
+
28
+ inline uint32_t min32(uint32_t x, uint32_t y)
29
+ {
30
+ return x < y ? x : y;
31
+ }
32
+
33
+ inline uint32_t max32(uint32_t x, uint32_t y)
34
+ {
35
+ return x > y ? x : y;
36
+ }
37
+
38
+ inline uint32_t constain32(uint32_t x, uint32_t l, uint32_t u)
39
+ {
40
+ return x < l ? l : (x > u ? u : x);
41
+ }
42
+
43
+ int unsigned_cmp(const void *a, const void *b)
44
+ {
45
+ if (!a || !b)
46
+ return 0;
47
+
48
+ return *(unsigned *)a > *(unsigned *)b ? 1 : (*(unsigned *)a < *(unsigned *)b ? -1 : 0);
49
+ }
50
+
51
+ int LibRaw::p1rawc(unsigned row, unsigned col, unsigned& count)
52
+ {
53
+ return (row < raw_height && col < raw_width) ? (++count, RAW(row, col)) : 0;
54
+ }
55
+
56
+ int LibRaw::p1raw(unsigned row, unsigned col)
57
+ {
58
+ return (row < raw_height && col < raw_width) ? RAW(row, col) : 0;
59
+ }
60
+
61
+
62
+ // DNG SDK version of fixing pixels in bad column using averages sets
63
+ // corrected not to use pixels in the same column
64
+ void LibRaw::phase_one_fix_col_pixel_avg(unsigned row, unsigned col)
65
+ {
66
+ static const int8_t dir[3][8][2] = {
67
+ { {-2,-2}, {-2, 2}, {2,-2}, {2, 2}, { 0, 0}, { 0, 0}, {0, 0}, {0, 0} },
68
+ { {-2,-4}, {-4,-2}, {2,-4}, {4,-2}, {-2, 4}, {-4, 2}, {2, 4}, {4, 2} },
69
+ { {-4,-4}, {-4, 4}, {4,-4}, {4, 4}, { 0, 0}, { 0, 0}, {0, 0}, {0, 0} } };
70
+
71
+ for (int set=0; set < 3; ++set)
72
+ {
73
+ uint32_t total = 0;
74
+ uint32_t count = 0;
75
+ for (int i = 0; i < 8; ++i)
76
+ {
77
+ if (!dir[set][i][0] && !dir[set][i][1])
78
+ break;
79
+
80
+ total += p1rawc(row+dir[set][i][0], col+dir[set][i][1], count);
81
+ }
82
+
83
+ if (count)
84
+ {
85
+ RAW(row,col) = (uint16_t)((total + (count >> 1)) / count);
86
+ break;
87
+ }
88
+ }
89
+ }
90
+
91
+ // DNG SDK version of fixing pixels in bad column using gradient prediction
92
+ void LibRaw::phase_one_fix_pixel_grad(unsigned row, unsigned col)
93
+ {
94
+ static const int8_t grad_sets[7][12][2] = {
95
+ { {-4,-2}, { 4, 2}, {-3,-1}, { 1, 1}, {-1,-1}, { 3, 1},
96
+ {-4,-1}, { 0, 1}, {-2,-1}, { 2, 1}, { 0,-1}, { 4, 1} },
97
+ { {-2,-2}, { 2, 2}, {-3,-1}, {-1, 1}, {-1,-1}, { 1, 1},
98
+ { 1,-1}, { 3, 1}, {-2,-1}, { 0, 1}, { 0,-1}, { 2, 1} },
99
+ { {-2,-4}, { 2, 4}, {-1,-3}, { 1, 1}, {-1,-1}, { 1, 3},
100
+ {-2,-1}, { 0, 3}, {-1,-2}, { 1, 2}, { 0,-3}, { 2, 1} },
101
+ { { 0,-2}, { 0, 2}, {-1,-1}, {-1, 1}, { 1,-1}, { 1, 1},
102
+ {-1,-2}, {-1, 2}, { 0,-1}, { 0,-1}, { 1,-2}, { 1, 2} },
103
+ { {-2, 4}, { 2,-4}, {-1, 3}, { 1,-1}, {-1, 1}, { 1,-3},
104
+ {-2, 1}, { 0,-3}, {-1, 2}, { 1,-2}, { 0, 3}, { 2,-1} },
105
+ { {-2, 2}, { 2,-2}, {-3, 1}, {-1,-1}, {-1, 1}, { 1,-1},
106
+ { 1, 1}, { 3,-1}, {-2, 1}, { 0,-1}, { 0, 1}, { 2,-1} },
107
+ { {-4, 2}, { 4,-2}, {-3, 1}, { 1,-1}, {-1, 1}, { 3,-1},
108
+ {-4, 1}, { 0,-1}, {-2, 1}, { 2,-1}, { 0, 1}, { 4,-1} } };
109
+
110
+ uint32_t est[7], grad[7];
111
+ uint32_t lower = min32(p1raw(row,col-2), p1raw(row, col+2));
112
+ uint32_t upper = max32(p1raw(row,col-2), p1raw(row, col+2));
113
+ uint32_t minGrad = 0xFFFFFFFF;
114
+ for (int i = 0; i<7; ++i)
115
+ {
116
+ est[i] = p1raw(row+grad_sets[i][0][0], col+grad_sets[i][0][1]) +
117
+ p1raw(row+grad_sets[i][1][0], col+grad_sets[i][1][1]);
118
+ grad[i] = 0;
119
+ for (int j=0; j<12; j+=2)
120
+ grad[i] += abs32(p1raw(row+grad_sets[i][j][0], col+grad_sets[i][j][1]) -
121
+ p1raw(row+grad_sets[i][j+1][0], col+grad_sets[i][j+1][1]));
122
+ minGrad = min32(minGrad, grad[i]);
123
+ }
124
+
125
+ uint32_t limit = (minGrad * 3) >> 1;
126
+ uint32_t total = 0;
127
+ uint32_t count = 0;
128
+ for (int i = 0; i<7; ++i)
129
+ if (grad[i] <= limit)
130
+ {
131
+ total += est[i];
132
+ count += 2;
133
+ }
134
+ RAW(row, col) = constain32((total + (count >> 1)) / count, lower, upper);
135
+ }
136
+
137
+ void LibRaw::phase_one_flat_field(int is_float, int nc)
138
+ {
139
+ ushort head[8];
140
+ unsigned wide, high, y, x, c, rend, cend, row, col;
141
+ float *mrow, num, mult[4];
142
+
143
+ read_shorts(head, 8);
144
+ if (head[2] == 0 || head[3] == 0 || head[4] == 0 || head[5] == 0)
145
+ return;
146
+ wide = head[2] / head[4] + (head[2] % head[4] != 0);
147
+ high = head[3] / head[5] + (head[3] % head[5] != 0);
148
+ mrow = (float *)calloc(nc * wide, sizeof *mrow);
149
+ for (y = 0; y < high; y++)
150
+ {
151
+ checkCancel();
152
+ for (x = 0; x < wide; x++)
153
+ for (c = 0; c < (unsigned)nc; c += 2)
154
+ {
155
+ num = is_float ? getreal(LIBRAW_EXIFTAG_TYPE_FLOAT) : get2() / 32768.0;
156
+ if (y == 0)
157
+ mrow[c * wide + x] = num;
158
+ else
159
+ mrow[(c + 1) * wide + x] = (num - mrow[c * wide + x]) / head[5];
160
+ }
161
+ if (y == 0)
162
+ continue;
163
+ rend = head[1] + y * head[5];
164
+ for (row = rend - head[5];
165
+ row < raw_height && row < rend && row < unsigned(head[1] + head[3] - head[5]);
166
+ row++)
167
+ {
168
+ for (x = 1; x < wide; x++)
169
+ {
170
+ for (c = 0; c < (unsigned)nc; c += 2)
171
+ {
172
+ mult[c] = mrow[c * wide + x - 1];
173
+ mult[c + 1] = (mrow[c * wide + x] - mult[c]) / head[4];
174
+ }
175
+ cend = head[0] + x * head[4];
176
+ for (col = cend - head[4];
177
+ col < raw_width && col < cend && col < unsigned(head[0] + head[2] - head[4]);
178
+ col++)
179
+ {
180
+ c = nc > 2 ? FC(row - top_margin, col - left_margin) : 0;
181
+ if (!(c & 1))
182
+ {
183
+ c = RAW(row, col) * mult[c];
184
+ RAW(row, col) = LIM(c, 0, 65535);
185
+ }
186
+ for (c = 0; c < (unsigned)nc; c += 2)
187
+ mult[c] += mult[c + 1];
188
+ }
189
+ }
190
+ for (x = 0; x < wide; x++)
191
+ for (c = 0; c < (unsigned)nc; c += 2)
192
+ mrow[c * wide + x] += mrow[(c + 1) * wide + x];
193
+ }
194
+ }
195
+ free(mrow);
196
+ }
197
+
198
+ int LibRaw::phase_one_correct()
199
+ {
200
+ unsigned entries, tag, data, save, col, row, type;
201
+ int len, i, j, k, cip, sum;
202
+ #if 0
203
+ int val[4], dev[4], max;
204
+ #endif
205
+ int head[9], diff, mindiff = INT_MAX, off_412 = 0;
206
+ /* static */ const signed char dir[12][2] = {
207
+ {-1, -1}, {-1, 1}, {1, -1}, {1, 1}, {-2, 0}, {0, -2},
208
+ {0, 2}, {2, 0}, {-2, -2}, {-2, 2}, {2, -2}, {2, 2}};
209
+ float poly[8], num, cfrac, frac, mult[2], *yval[2] = {NULL, NULL};
210
+ ushort *xval[2];
211
+ int qmult_applied = 0, qlin_applied = 0;
212
+ std::vector<unsigned> badCols;
213
+
214
+ if (!meta_length)
215
+ return 0;
216
+ fseek(ifp, meta_offset, SEEK_SET);
217
+ order = get2();
218
+ fseek(ifp, 6, SEEK_CUR);
219
+ fseek(ifp, meta_offset + get4(), SEEK_SET);
220
+ entries = get4();
221
+ get4();
222
+
223
+ try
224
+ {
225
+ while (entries--)
226
+ {
227
+ checkCancel();
228
+ tag = get4();
229
+ len = get4();
230
+ data = get4();
231
+ save = ftell(ifp);
232
+ fseek(ifp, meta_offset + data, SEEK_SET);
233
+ #if 1
234
+ if (ifp->eof())
235
+ {
236
+ // skip bad or unknown tag
237
+ fseek(ifp, save, SEEK_SET);
238
+ continue;
239
+ }
240
+ #endif
241
+ if (tag == 0x0400)
242
+ { /* Sensor defects */
243
+ while ((len -= 8) >= 0)
244
+ {
245
+ col = get2();
246
+ row = get2();
247
+ type = get2();
248
+ get2();
249
+ if (col >= raw_width)
250
+ continue;
251
+ if (type == 131 || type == 137) /* Bad column */
252
+ #if 0
253
+ // Original code by Dave Coffin - it works better by
254
+ // not employing special logic for G1 channel below.
255
+ // Alternatively this column remap (including G1 channel
256
+ // logic) should be called prior to black subtraction
257
+ // unlike other corrections
258
+ for (row = 0; row < raw_height; row++)
259
+ {
260
+ if (FC(row - top_margin, col - left_margin)==1)
261
+ {
262
+ for (sum = i = 0; i < 4; i++)
263
+ sum += val[i] = p1raw(row + dir[i][0], col + dir[i][1]);
264
+ for (max = i = 0; i < 4; i++)
265
+ {
266
+ dev[i] = abs((val[i] << 2) - sum);
267
+ if (dev[max] < dev[i])
268
+ max = i;
269
+ }
270
+ RAW(row, col) = (sum - val[max]) / 3.0 + 0.5;
271
+ }
272
+ else
273
+ {
274
+ for (sum = 0, i = 8; i < 12; i++)
275
+ sum += p1raw(row + dir[i][0], col + dir[i][1]);
276
+ RAW(row, col) =
277
+ 0.5 + sum * 0.0732233 +
278
+ (p1raw(row, col - 2) + p1raw(row, col + 2)) * 0.3535534;
279
+ }
280
+ }
281
+ #else
282
+ // accumulae bad columns to be sorted later
283
+ badCols.push_back(col);
284
+ #endif
285
+ else if (type == 129)
286
+ { /* Bad pixel */
287
+ if (row >= raw_height)
288
+ continue;
289
+ j = (FC(row - top_margin, col - left_margin) != 1) * 4;
290
+ unsigned count = 0;
291
+ for (sum = 0, i = j; i < j + 8; i++)
292
+ sum += p1rawc(row + dir[i][0], col + dir[i][1], count);
293
+ if (count)
294
+ RAW(row, col) = (sum + (count >> 1)) / count;
295
+ }
296
+ }
297
+ }
298
+ else if (tag == 0x0419)
299
+ { /* Polynomial curve - output calibraion */
300
+ for (get4(), i = 0; i < 8; i++)
301
+ poly[i] = getreal(LIBRAW_EXIFTAG_TYPE_FLOAT);
302
+ poly[3] += (ph1.tag_210 - poly[7]) * poly[6] + 1;
303
+ for (i = 0; i < 0x10000; i++)
304
+ {
305
+ num = (poly[5] * i + poly[3]) * i + poly[1];
306
+ curve[i] = LIM(num, 0, 65535);
307
+ }
308
+ goto apply; /* apply to right half */
309
+ }
310
+ else if (tag == 0x041a)
311
+ { /* Polynomial curve */
312
+ for (i = 0; i < 4; i++)
313
+ poly[i] = getreal(LIBRAW_EXIFTAG_TYPE_FLOAT);
314
+ for (i = 0; i < 0x10000; i++)
315
+ {
316
+ for (num = 0, j = 4; j--;)
317
+ num = num * i + poly[j];
318
+ curve[i] = LIM(num + i, 0, 65535);
319
+ }
320
+ apply: /* apply to whole image */
321
+ for (row = 0; row < raw_height; row++)
322
+ {
323
+ checkCancel();
324
+ for (col = (tag & 1) * ph1.split_col; col < raw_width; col++)
325
+ RAW(row, col) = curve[RAW(row, col)];
326
+ }
327
+ }
328
+ else if (tag == 0x0401)
329
+ { /* All-color flat fields - luma calibration*/
330
+ phase_one_flat_field(1, 2);
331
+ }
332
+ else if (tag == 0x0416 || tag == 0x0410)
333
+ {
334
+ // 0x410 - luma calibration
335
+ phase_one_flat_field(0, 2);
336
+ }
337
+ else if (tag == 0x040b)
338
+ { /* Red+blue flat field - croma calibration */
339
+ phase_one_flat_field(0, 4);
340
+ }
341
+ else if (tag == 0x0412)
342
+ {
343
+ fseek(ifp, 36, SEEK_CUR);
344
+ diff = abs(get2() - ph1.tag_21a);
345
+ if (mindiff > diff)
346
+ {
347
+ mindiff = diff;
348
+ off_412 = ftell(ifp) - 38;
349
+ }
350
+ }
351
+ else if (tag == 0x041f && !qlin_applied && ph1.split_col > 0 && ph1.split_col < raw_width
352
+ && ph1.split_row > 0 && ph1.split_row < raw_height)
353
+ { /* Quadrant linearization */
354
+ ushort lc[2][2][16], ref[16];
355
+ int qr, qc;
356
+ bool baddiv = false;
357
+ for (qr = 0; qr < 2; qr++)
358
+ for (qc = 0; qc < 2; qc++)
359
+ {
360
+ for (i = 0; i < 16; i++)
361
+ lc[qr][qc][i] = get4();
362
+ if (lc[qr][qc][15] == 0)
363
+ baddiv = true;
364
+ }
365
+ if(baddiv)
366
+ continue;
367
+ for (i = 0; i < 16; i++)
368
+ {
369
+ int v = 0;
370
+ for (qr = 0; qr < 2; qr++)
371
+ for (qc = 0; qc < 2; qc++)
372
+ v += lc[qr][qc][i];
373
+ ref[i] = (v + 2) >> 2;
374
+ }
375
+ for (qr = 0; qr < 2; qr++)
376
+ {
377
+ for (qc = 0; qc < 2; qc++)
378
+ {
379
+ int cx[19], cf[19];
380
+ for (i = 0; i < 16; i++)
381
+ {
382
+ cx[1 + i] = lc[qr][qc][i];
383
+ cf[1 + i] = ref[i];
384
+ }
385
+ cx[0] = cf[0] = 0;
386
+ cx[17] = cf[17] = ((unsigned int)ref[15] * 65535) / lc[qr][qc][15];
387
+ cf[18] = cx[18] = 65535;
388
+ cubic_spline(cx, cf, 19);
389
+
390
+ for (row = (qr ? ph1.split_row : 0);
391
+ row < unsigned(qr ? raw_height : ph1.split_row); row++)
392
+ {
393
+ checkCancel();
394
+ for (col = (qc ? ph1.split_col : 0);
395
+ col < unsigned(qc ? raw_width : ph1.split_col); col++)
396
+ RAW(row, col) = curve[RAW(row, col)];
397
+ }
398
+ }
399
+ }
400
+ qlin_applied = 1;
401
+ }
402
+ else if (tag == 0x041e && !qmult_applied)
403
+ { /* Quadrant multipliers - output calibraion */
404
+ float qmult[2][2] = {{1, 1}, {1, 1}};
405
+ get4();
406
+ get4();
407
+ get4();
408
+ get4();
409
+ qmult[0][0] = 1.0 + getreal(LIBRAW_EXIFTAG_TYPE_FLOAT);
410
+ get4();
411
+ get4();
412
+ get4();
413
+ get4();
414
+ get4();
415
+ qmult[0][1] = 1.0 + getreal(LIBRAW_EXIFTAG_TYPE_FLOAT);
416
+ get4();
417
+ get4();
418
+ get4();
419
+ qmult[1][0] = 1.0 + getreal(LIBRAW_EXIFTAG_TYPE_FLOAT);
420
+ get4();
421
+ get4();
422
+ get4();
423
+ qmult[1][1] = 1.0 + getreal(LIBRAW_EXIFTAG_TYPE_FLOAT);
424
+ for (row = 0; row < raw_height; row++)
425
+ {
426
+ checkCancel();
427
+ for (col = 0; col < raw_width; col++)
428
+ {
429
+ i = qmult[row >= (unsigned)ph1.split_row][col >= (unsigned)ph1.split_col] *
430
+ RAW(row, col);
431
+ RAW(row, col) = LIM(i, 0, 65535);
432
+ }
433
+ }
434
+ qmult_applied = 1;
435
+ }
436
+ else if (tag == 0x0431 && !qmult_applied && ph1.split_col > 0 && ph1.split_col < raw_width
437
+ && ph1.split_row > 0 && ph1.split_row < raw_height)
438
+ { /* Quadrant combined - four tile gain calibration */
439
+ ushort lc[2][2][7], ref[7];
440
+ int qr, qc;
441
+ for (i = 0; i < 7; i++)
442
+ ref[i] = get4();
443
+ for (qr = 0; qr < 2; qr++)
444
+ for (qc = 0; qc < 2; qc++)
445
+ for (i = 0; i < 7; i++)
446
+ lc[qr][qc][i] = get4();
447
+ for (qr = 0; qr < 2; qr++)
448
+ {
449
+ for (qc = 0; qc < 2; qc++)
450
+ {
451
+ int cx[9], cf[9];
452
+ for (i = 0; i < 7; i++)
453
+ {
454
+ cx[1 + i] = ref[i];
455
+ cf[1 + i] = ((unsigned)ref[i] * lc[qr][qc][i]) / 10000;
456
+ }
457
+ cx[0] = cf[0] = 0;
458
+ cx[8] = cf[8] = 65535;
459
+ cubic_spline(cx, cf, 9);
460
+ for (row = (qr ? ph1.split_row : 0);
461
+ row < unsigned(qr ? raw_height : ph1.split_row); row++)
462
+ {
463
+ checkCancel();
464
+ for (col = (qc ? ph1.split_col : 0);
465
+ col < unsigned(qc ? raw_width : ph1.split_col); col++)
466
+ RAW(row, col) = curve[RAW(row, col)];
467
+ }
468
+ }
469
+ }
470
+ qmult_applied = 1;
471
+ qlin_applied = 1;
472
+ }
473
+ fseek(ifp, save, SEEK_SET);
474
+ }
475
+ if (!badCols.empty())
476
+ {
477
+ qsort(badCols.data(), badCols.size(), sizeof(unsigned), unsigned_cmp);
478
+ bool prevIsolated = true;
479
+ for (i = 0; i < (int)badCols.size(); ++i)
480
+ {
481
+ bool nextIsolated = i == ((int)(badCols.size()-1)) || badCols[i+1]>badCols[i]+4;
482
+ for (row = 0; row < raw_height; ++row)
483
+ if (prevIsolated && nextIsolated)
484
+ phase_one_fix_pixel_grad(row,badCols[i]);
485
+ else
486
+ phase_one_fix_col_pixel_avg(row,badCols[i]);
487
+ prevIsolated = nextIsolated;
488
+ }
489
+ }
490
+ if (off_412)
491
+ {
492
+ fseek(ifp, off_412, SEEK_SET);
493
+ for (i = 0; i < 9; i++)
494
+ head[i] = get4() & 0x7fff;
495
+ unsigned w0 = head[1] * head[3], w1 = head[2] * head[4];
496
+ if (w0 > 10240000 || w1 > 10240000)
497
+ throw LIBRAW_EXCEPTION_ALLOC;
498
+ if (w0 < 1 || w1 < 1)
499
+ throw LIBRAW_EXCEPTION_IO_CORRUPT;
500
+ yval[0] = (float *)calloc(head[1] * head[3] + head[2] * head[4], 6);
501
+ yval[1] = (float *)(yval[0] + head[1] * head[3]);
502
+ xval[0] = (ushort *)(yval[1] + head[2] * head[4]);
503
+ xval[1] = (ushort *)(xval[0] + head[1] * head[3]);
504
+ get2();
505
+ for (i = 0; i < 2; i++)
506
+ for (j = 0; j < head[i + 1] * head[i + 3]; j++)
507
+ yval[i][j] = getreal(LIBRAW_EXIFTAG_TYPE_FLOAT);
508
+ for (i = 0; i < 2; i++)
509
+ for (j = 0; j < head[i + 1] * head[i + 3]; j++)
510
+ xval[i][j] = get2();
511
+ for (row = 0; row < raw_height; row++)
512
+ {
513
+ checkCancel();
514
+ for (col = 0; col < raw_width; col++)
515
+ {
516
+ cfrac = (float)col * head[3] / raw_width;
517
+ cfrac -= cip = cfrac;
518
+ num = RAW(row, col) * 0.5;
519
+ for (i = cip; i < cip + 2; i++)
520
+ {
521
+ for (k = j = 0; j < head[1]; j++)
522
+ if (num < xval[0][k = head[1] * i + j])
523
+ break;
524
+ if (j == 0 || j == head[1] || k < 1 || k >= w0+w1)
525
+ frac = 0;
526
+ else
527
+ {
528
+ int xdiv = (xval[0][k] - xval[0][k - 1]);
529
+ frac = xdiv ? (xval[0][k] - num) / (xval[0][k] - xval[0][k - 1]) : 0;
530
+ }
531
+ if (k < w0 + w1)
532
+ mult[i - cip] = yval[0][k > 0 ? k - 1 : 0] * frac + yval[0][k] * (1 - frac);
533
+ else
534
+ mult[i - cip] = 0;
535
+ }
536
+ i = ((mult[0] * (1 - cfrac) + mult[1] * cfrac) * row + num) * 2;
537
+ RAW(row, col) = LIM(i, 0, 65535);
538
+ }
539
+ }
540
+ free(yval[0]);
541
+ }
542
+ }
543
+ catch (...)
544
+ {
545
+ if (yval[0])
546
+ free(yval[0]);
547
+ return LIBRAW_CANCELLED_BY_CALLBACK;
548
+ }
549
+ return 0;
550
+ }
551
+
552
+ void LibRaw::phase_one_load_raw()
553
+ {
554
+ int a, b, i;
555
+ ushort akey, bkey, t_mask;
556
+
557
+ fseek(ifp, ph1.key_off, SEEK_SET);
558
+ akey = get2();
559
+ bkey = get2();
560
+ t_mask = ph1.format == 1 ? 0x5555 : 0x1354;
561
+ if (ph1.black_col || ph1.black_row)
562
+ {
563
+ imgdata.rawdata.ph1_cblack =
564
+ (short(*)[2])calloc(raw_height * 2, sizeof(ushort));
565
+ imgdata.rawdata.ph1_rblack =
566
+ (short(*)[2])calloc(raw_width * 2, sizeof(ushort));
567
+ if (ph1.black_col)
568
+ {
569
+ fseek(ifp, ph1.black_col, SEEK_SET);
570
+ read_shorts((ushort *)imgdata.rawdata.ph1_cblack[0], raw_height * 2);
571
+ }
572
+ if (ph1.black_row)
573
+ {
574
+ fseek(ifp, ph1.black_row, SEEK_SET);
575
+ read_shorts((ushort *)imgdata.rawdata.ph1_rblack[0], raw_width * 2);
576
+ }
577
+ }
578
+ fseek(ifp, data_offset, SEEK_SET);
579
+ read_shorts(raw_image, raw_width * raw_height);
580
+ if (ph1.format)
581
+ for (i = 0; i < raw_width * raw_height; i += 2)
582
+ {
583
+ a = raw_image[i + 0] ^ akey;
584
+ b = raw_image[i + 1] ^ bkey;
585
+ raw_image[i + 0] = (a & t_mask) | (b & ~t_mask);
586
+ raw_image[i + 1] = (b & t_mask) | (a & ~t_mask);
587
+ }
588
+ }
589
+
590
+ unsigned LibRaw::ph1_bithuff(int nbits, ushort *huff)
591
+ {
592
+ #ifndef LIBRAW_NOTHREADS
593
+ #define bitbuf tls->ph1_bits.bitbuf
594
+ #define vbits tls->ph1_bits.vbits
595
+ #else
596
+ static UINT64 bitbuf = 0;
597
+ static int vbits = 0;
598
+ #endif
599
+ unsigned c;
600
+
601
+ if (nbits == -1)
602
+ return bitbuf = vbits = 0;
603
+ if (nbits == 0)
604
+ return 0;
605
+ if (vbits < nbits)
606
+ {
607
+ bitbuf = bitbuf << 32 | get4();
608
+ vbits += 32;
609
+ }
610
+ c = bitbuf << (64 - vbits) >> (64 - nbits);
611
+ if (huff)
612
+ {
613
+ vbits -= huff[c] >> 8;
614
+ return (uchar)huff[c];
615
+ }
616
+ vbits -= nbits;
617
+ return c;
618
+ #ifndef LIBRAW_NOTHREADS
619
+ #undef bitbuf
620
+ #undef vbits
621
+ #endif
622
+ }
623
+
624
+ void LibRaw::phase_one_load_raw_c()
625
+ {
626
+ static const int length[] = {8, 7, 6, 9, 11, 10, 5, 12, 14, 13};
627
+ int *offset, len[2], pred[2], row, col, i, j;
628
+ ushort *pixel;
629
+ short(*c_black)[2], (*r_black)[2];
630
+ if (ph1.format == 6)
631
+ throw LIBRAW_EXCEPTION_IO_CORRUPT;
632
+
633
+ pixel = (ushort *)calloc(raw_width * 3 + raw_height * 4, 2);
634
+ offset = (int *)(pixel + raw_width);
635
+ fseek(ifp, strip_offset, SEEK_SET);
636
+ for (row = 0; row < raw_height; row++)
637
+ offset[row] = get4();
638
+ c_black = (short(*)[2])(offset + raw_height);
639
+ fseek(ifp, ph1.black_col, SEEK_SET);
640
+ if (ph1.black_col)
641
+ read_shorts((ushort *)c_black[0], raw_height * 2);
642
+ r_black = c_black + raw_height;
643
+ fseek(ifp, ph1.black_row, SEEK_SET);
644
+ if (ph1.black_row)
645
+ read_shorts((ushort *)r_black[0], raw_width * 2);
646
+
647
+ // Copy data to internal copy (ever if not read)
648
+ if (ph1.black_col || ph1.black_row)
649
+ {
650
+ imgdata.rawdata.ph1_cblack =
651
+ (short(*)[2])calloc(raw_height * 2, sizeof(ushort));
652
+ memmove(imgdata.rawdata.ph1_cblack, (ushort *)c_black[0],
653
+ raw_height * 2 * sizeof(ushort));
654
+ imgdata.rawdata.ph1_rblack =
655
+ (short(*)[2])calloc(raw_width * 2, sizeof(ushort));
656
+ memmove(imgdata.rawdata.ph1_rblack, (ushort *)r_black[0],
657
+ raw_width * 2 * sizeof(ushort));
658
+ }
659
+
660
+ for (i = 0; i < 256; i++)
661
+ curve[i] = i * i / 3.969 + 0.5;
662
+ try
663
+ {
664
+ for (row = 0; row < raw_height; row++)
665
+ {
666
+ checkCancel();
667
+ fseek(ifp, data_offset + offset[row], SEEK_SET);
668
+ ph1_bits(-1);
669
+ pred[0] = pred[1] = 0;
670
+ for (col = 0; col < raw_width; col++)
671
+ {
672
+ if (col >= (raw_width & -8))
673
+ len[0] = len[1] = 14;
674
+ else if ((col & 7) == 0)
675
+ for (i = 0; i < 2; i++)
676
+ {
677
+ for (j = 0; j < 5 && !ph1_bits(1); j++)
678
+ ;
679
+ if (j--)
680
+ len[i] = length[j * 2 + ph1_bits(1)];
681
+ }
682
+ if ((i = len[col & 1]) == 14)
683
+ pixel[col] = pred[col & 1] = ph1_bits(16);
684
+ else
685
+ pixel[col] = pred[col & 1] += ph1_bits(i) + 1 - (1 << (i - 1));
686
+ if (pred[col & 1] >> 16)
687
+ derror();
688
+ if (ph1.format == 5 && pixel[col] < 256)
689
+ pixel[col] = curve[pixel[col]];
690
+ }
691
+ if (ph1.format == 8)
692
+ memmove(&RAW(row, 0), &pixel[0], raw_width * 2);
693
+ else
694
+ for (col = 0; col < raw_width; col++)
695
+ RAW(row, col) = pixel[col] << 2;
696
+ }
697
+ }
698
+ catch (...)
699
+ {
700
+ free(pixel);
701
+ throw;
702
+ }
703
+ free(pixel);
704
+ maximum = 0xfffc - ph1.t_black;
705
+ }
706
+
707
+ void LibRaw::hasselblad_load_raw()
708
+ {
709
+ struct jhead jh;
710
+ int shot, row, col, *back[5]={0,0,0,0,0},
711
+ len[2], diff[12], pred, sh, f, c;
712
+ unsigned s;
713
+ unsigned upix, urow, ucol;
714
+ ushort *ip;
715
+
716
+ if (!ljpeg_start(&jh, 0))
717
+ return;
718
+ order = 0x4949;
719
+ ph1_bits(-1);
720
+ try
721
+ {
722
+ back[4] = (int *)calloc(raw_width, 3 * sizeof **back);
723
+ FORC3 back[c] = back[4] + c * raw_width;
724
+ cblack[6] >>= sh = tiff_samples > 1;
725
+ shot = LIM(shot_select, 1, tiff_samples) - 1;
726
+ for (row = 0; row < raw_height; row++)
727
+ {
728
+ checkCancel();
729
+ FORC4 back[(c + 3) & 3] = back[c];
730
+ for (col = 0; col < raw_width; col += 2)
731
+ {
732
+ for (s = 0; s < tiff_samples * 2; s += 2)
733
+ {
734
+ FORC(2) len[c] = ph1_huff(jh.huff[0]);
735
+ FORC(2)
736
+ {
737
+ diff[s + c] = ph1_bits(len[c]);
738
+ if (len[c] > 0 && (diff[s + c] & (1 << (len[c] - 1))) == 0)
739
+ diff[s + c] -= (1 << len[c]) - 1;
740
+ if (diff[s + c] == 65535)
741
+ diff[s + c] = -32768;
742
+ }
743
+ }
744
+ for (s = col; s < unsigned(col + 2); s++)
745
+ {
746
+ pred = 0x8000 + load_flags;
747
+ if (col)
748
+ pred = back[2][s - 2];
749
+ if (col && row > 1)
750
+ switch (jh.psv)
751
+ {
752
+ case 11:
753
+ pred += back[0][s] / 2 - back[0][s - 2] / 2;
754
+ break;
755
+ }
756
+ f = (row & 1) * 3 ^ ((col + s) & 1);
757
+ FORC(int(tiff_samples))
758
+ {
759
+ pred += diff[(s & 1) * tiff_samples + c];
760
+ upix = pred >> sh & 0xffff;
761
+ if (raw_image && c == shot)
762
+ RAW(row, s) = upix;
763
+ if (image)
764
+ {
765
+ urow = row - top_margin + (c & 1);
766
+ ucol = col - left_margin - ((c >> 1) & 1);
767
+ ip = &image[urow * width + ucol][f];
768
+ if (urow < height && ucol < width)
769
+ *ip = c < 4 ? upix : (*ip + upix) >> 1;
770
+ }
771
+ }
772
+ back[2][s] = pred;
773
+ }
774
+ }
775
+ }
776
+ }
777
+ catch (...)
778
+ {
779
+ if(back[4])
780
+ free(back[4]);
781
+ ljpeg_end(&jh);
782
+ throw;
783
+ }
784
+ if(back[4])
785
+ free(back[4]);
786
+ ljpeg_end(&jh);
787
+ if (image)
788
+ mix_green = 1;
789
+ }
790
+
791
+ void LibRaw::leaf_hdr_load_raw()
792
+ {
793
+ ushort *pixel = 0;
794
+ unsigned tile = 0, r, c, row, col;
795
+
796
+ if (!filters || !raw_image)
797
+ {
798
+ if (!image)
799
+ throw LIBRAW_EXCEPTION_IO_CORRUPT;
800
+ pixel = (ushort *)calloc(raw_width, sizeof *pixel);
801
+ }
802
+ try
803
+ {
804
+ FORC(tiff_samples)
805
+ for (r = 0; r < raw_height; r++)
806
+ {
807
+ checkCancel();
808
+ if (r % tile_length == 0)
809
+ {
810
+ fseek(ifp, data_offset + 4 * tile++, SEEK_SET);
811
+ fseek(ifp, get4(), SEEK_SET);
812
+ }
813
+ if (filters && c != shot_select)
814
+ continue;
815
+ if (filters && raw_image)
816
+ pixel = raw_image + r * raw_width;
817
+ read_shorts(pixel, raw_width);
818
+ if (!filters && image && (row = r - top_margin) < height)
819
+ for (col = 0; col < width && col + left_margin < raw_width; col++)
820
+ image[row * width + col][c] = pixel[col + left_margin];
821
+ }
822
+ }
823
+ catch (...)
824
+ {
825
+ if (!filters)
826
+ free(pixel);
827
+ throw;
828
+ }
829
+ if (!filters)
830
+ {
831
+ maximum = 0xffff;
832
+ raw_color = 1;
833
+ free(pixel);
834
+ }
835
+ }
836
+
837
+ void LibRaw::unpacked_load_raw_FujiDBP()
838
+ /*
839
+ for Fuji DBP for GX680, aka DX-2000
840
+ DBP_tile_width = 688;
841
+ DBP_tile_height = 3856;
842
+ DBP_n_tiles = 8;
843
+ */
844
+ {
845
+ int scan_line, tile_n;
846
+ int nTiles;
847
+
848
+ nTiles = 8;
849
+ tile_width = raw_width / nTiles;
850
+
851
+ ushort *tile;
852
+ tile = (ushort *)calloc(raw_height, tile_width * 2);
853
+
854
+ for (tile_n = 0; tile_n < nTiles; tile_n++)
855
+ {
856
+ read_shorts(tile, tile_width * raw_height);
857
+ for (scan_line = 0; scan_line < raw_height; scan_line++)
858
+ {
859
+ memcpy(&raw_image[scan_line * raw_width + tile_n * tile_width],
860
+ &tile[scan_line * tile_width], tile_width * 2);
861
+ }
862
+ }
863
+ free(tile);
864
+ fseek(ifp, -2, SEEK_CUR); // avoid EOF error
865
+ }
866
+
867
+ void LibRaw::sinar_4shot_load_raw()
868
+ {
869
+ ushort *pixel;
870
+ unsigned shot, row, col, r, c;
871
+
872
+ if (raw_image)
873
+ {
874
+ shot = LIM(shot_select, 1, 4) - 1;
875
+ fseek(ifp, data_offset + shot * 4, SEEK_SET);
876
+ fseek(ifp, get4(), SEEK_SET);
877
+ unpacked_load_raw();
878
+ return;
879
+ }
880
+ if (!image)
881
+ throw LIBRAW_EXCEPTION_IO_CORRUPT;
882
+ pixel = (ushort *)calloc(raw_width, sizeof *pixel);
883
+ try
884
+ {
885
+ for (shot = 0; shot < 4; shot++)
886
+ {
887
+ checkCancel();
888
+ fseek(ifp, data_offset + shot * 4, SEEK_SET);
889
+ fseek(ifp, get4(), SEEK_SET);
890
+ for (row = 0; row < raw_height; row++)
891
+ {
892
+ read_shorts(pixel, raw_width);
893
+ if ((r = row - top_margin - (shot >> 1 & 1)) >= height)
894
+ continue;
895
+ for (col = 0; col < raw_width; col++)
896
+ {
897
+ if ((c = col - left_margin - (shot & 1)) >= width)
898
+ continue;
899
+ image[r * width + c][(row & 1) * 3 ^ (~col & 1)] = pixel[col];
900
+ }
901
+ }
902
+ }
903
+ }
904
+ catch (...)
905
+ {
906
+ free(pixel);
907
+ throw;
908
+ }
909
+ free(pixel);
910
+ mix_green = 1;
911
+ }
912
+
913
+ void LibRaw::imacon_full_load_raw()
914
+ {
915
+ if (!image)
916
+ throw LIBRAW_EXCEPTION_IO_CORRUPT;
917
+ int row, col;
918
+
919
+ unsigned short *buf =
920
+ (unsigned short *)malloc(width * 3 * sizeof(unsigned short));
921
+
922
+ for (row = 0; row < height; row++)
923
+ {
924
+ checkCancel();
925
+ read_shorts(buf, width * 3);
926
+ unsigned short(*rowp)[4] = &image[row * width];
927
+ for (col = 0; col < width; col++)
928
+ {
929
+ rowp[col][0] = buf[col * 3];
930
+ rowp[col][1] = buf[col * 3 + 1];
931
+ rowp[col][2] = buf[col * 3 + 2];
932
+ rowp[col][3] = 0;
933
+ }
934
+ }
935
+ free(buf);
936
+ }