rmagick 2.16.0 → 5.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (404) hide show
  1. checksums.yaml +5 -5
  2. data/.devcontainer/Dockerfile +14 -0
  3. data/.devcontainer/ImageMagick6/devcontainer.json +11 -0
  4. data/.devcontainer/devcontainer.json +11 -0
  5. data/.devcontainer/setup-repo.sh +10 -0
  6. data/.devcontainer/setup-user.sh +45 -0
  7. data/.editorconfig +3 -0
  8. data/.github/ISSUE_TEMPLATE.md +17 -0
  9. data/.github/workflows/ci.yml +138 -0
  10. data/.gitignore +7 -1
  11. data/.rspec +1 -0
  12. data/.rubocop.yml +37 -340
  13. data/.rubocop_todo.yml +448 -0
  14. data/.yardopts +5 -0
  15. data/CHANGELOG.md +455 -0
  16. data/CODE_OF_CONDUCT.md +122 -7
  17. data/CONTRIBUTING.md +37 -6
  18. data/Gemfile +0 -6
  19. data/README.md +316 -0
  20. data/Rakefile +74 -100
  21. data/before_install_linux.sh +65 -28
  22. data/before_install_osx.sh +58 -2
  23. data/ext/RMagick/extconf.rb +287 -393
  24. data/ext/RMagick/rmagick.c +106 -111
  25. data/ext/RMagick/rmagick.h +235 -331
  26. data/ext/RMagick/rmagick_gvl.h +224 -0
  27. data/ext/RMagick/rmdraw.c +516 -843
  28. data/ext/RMagick/rmenum.c +316 -755
  29. data/ext/RMagick/rmfill.c +281 -191
  30. data/ext/RMagick/rmilist.c +451 -456
  31. data/ext/RMagick/rmimage.c +6250 -5290
  32. data/ext/RMagick/rminfo.c +721 -894
  33. data/ext/RMagick/rmkinfo.c +228 -0
  34. data/ext/RMagick/rmmain.c +735 -521
  35. data/ext/RMagick/rmmontage.c +127 -172
  36. data/ext/RMagick/rmpixel.c +638 -431
  37. data/ext/RMagick/rmstruct.c +102 -282
  38. data/ext/RMagick/rmutil.c +450 -363
  39. data/lib/rmagick/version.rb +5 -4
  40. data/lib/rmagick.rb +2 -0
  41. data/lib/rmagick_internal.rb +349 -413
  42. data/lib/rvg/clippath.rb +3 -4
  43. data/lib/rvg/container.rb +30 -22
  44. data/lib/rvg/deep_equal.rb +11 -11
  45. data/lib/rvg/describable.rb +2 -2
  46. data/lib/rvg/embellishable.rb +63 -68
  47. data/lib/rvg/misc.rb +136 -139
  48. data/lib/rvg/paint.rb +2 -1
  49. data/lib/rvg/pathdata.rb +7 -8
  50. data/lib/rvg/rvg.rb +47 -46
  51. data/lib/rvg/stretchable.rb +22 -28
  52. data/lib/rvg/stylable.rb +12 -10
  53. data/lib/rvg/text.rb +169 -165
  54. data/lib/rvg/transformable.rb +17 -16
  55. data/lib/rvg/units.rb +5 -5
  56. data/rmagick.gemspec +16 -39
  57. metadata +114 -392
  58. data/.hound.yml +0 -2
  59. data/.simplecov +0 -27
  60. data/.travis.yml +0 -74
  61. data/Doxyfile +0 -1514
  62. data/README.textile +0 -251
  63. data/deprecated/RMagick.rb +0 -6
  64. data/doc/.cvsignore +0 -1
  65. data/doc/comtasks.html +0 -287
  66. data/doc/constants.html +0 -1581
  67. data/doc/css/doc.css +0 -299
  68. data/doc/css/popup.css +0 -34
  69. data/doc/css/ref.css +0 -67
  70. data/doc/draw.html +0 -3272
  71. data/doc/ex/InitialCoords.rb +0 -22
  72. data/doc/ex/NewCoordSys.rb +0 -30
  73. data/doc/ex/OrigCoordSys.rb +0 -16
  74. data/doc/ex/PreserveAspectRatio.rb +0 -204
  75. data/doc/ex/RotateScale.rb +0 -36
  76. data/doc/ex/Skew.rb +0 -38
  77. data/doc/ex/Use01.rb +0 -15
  78. data/doc/ex/Use02.rb +0 -20
  79. data/doc/ex/Use03.rb +0 -16
  80. data/doc/ex/ViewBox.rb +0 -31
  81. data/doc/ex/adaptive_threshold.rb +0 -9
  82. data/doc/ex/add_noise.rb +0 -16
  83. data/doc/ex/affine.rb +0 -48
  84. data/doc/ex/affine_transform.rb +0 -20
  85. data/doc/ex/arc.rb +0 -49
  86. data/doc/ex/arcpath.rb +0 -32
  87. data/doc/ex/arcs01.rb +0 -28
  88. data/doc/ex/arcs02.rb +0 -59
  89. data/doc/ex/average.rb +0 -15
  90. data/doc/ex/axes.rb +0 -64
  91. data/doc/ex/baseline_shift01.rb +0 -17
  92. data/doc/ex/bilevel_channel.rb +0 -8
  93. data/doc/ex/blur_image.rb +0 -12
  94. data/doc/ex/border.rb +0 -10
  95. data/doc/ex/bounding_box.rb +0 -42
  96. data/doc/ex/cbezier1.rb +0 -41
  97. data/doc/ex/cbezier2.rb +0 -41
  98. data/doc/ex/cbezier3.rb +0 -41
  99. data/doc/ex/cbezier4.rb +0 -42
  100. data/doc/ex/cbezier5.rb +0 -42
  101. data/doc/ex/cbezier6.rb +0 -53
  102. data/doc/ex/channel.rb +0 -25
  103. data/doc/ex/charcoal.rb +0 -12
  104. data/doc/ex/chop.rb +0 -29
  105. data/doc/ex/circle.rb +0 -33
  106. data/doc/ex/circle01.rb +0 -16
  107. data/doc/ex/clip_path.rb +0 -60
  108. data/doc/ex/coalesce.rb +0 -57
  109. data/doc/ex/color_fill_to_border.rb +0 -29
  110. data/doc/ex/color_floodfill.rb +0 -28
  111. data/doc/ex/color_histogram.rb +0 -47
  112. data/doc/ex/color_reset.rb +0 -11
  113. data/doc/ex/colorize.rb +0 -16
  114. data/doc/ex/colors.rb +0 -64
  115. data/doc/ex/compose_mask.rb +0 -22
  116. data/doc/ex/composite.rb +0 -133
  117. data/doc/ex/composite_layers.rb +0 -53
  118. data/doc/ex/composite_tiled.rb +0 -21
  119. data/doc/ex/contrast.rb +0 -36
  120. data/doc/ex/crop.rb +0 -31
  121. data/doc/ex/crop_with_gravity.rb +0 -42
  122. data/doc/ex/cubic01.rb +0 -43
  123. data/doc/ex/cubic02.rb +0 -91
  124. data/doc/ex/cycle_colormap.rb +0 -21
  125. data/doc/ex/dissolve.rb +0 -12
  126. data/doc/ex/drawcomp.rb +0 -42
  127. data/doc/ex/drop_shadow.rb +0 -60
  128. data/doc/ex/edge.rb +0 -11
  129. data/doc/ex/ellipse.rb +0 -45
  130. data/doc/ex/ellipse01.rb +0 -21
  131. data/doc/ex/emboss.rb +0 -11
  132. data/doc/ex/enhance.rb +0 -28
  133. data/doc/ex/equalize.rb +0 -11
  134. data/doc/ex/evenodd.rb +0 -42
  135. data/doc/ex/fill_pattern.rb +0 -23
  136. data/doc/ex/flatten_images.rb +0 -36
  137. data/doc/ex/flip.rb +0 -11
  138. data/doc/ex/flop.rb +0 -11
  139. data/doc/ex/font_styles.rb +0 -32
  140. data/doc/ex/fonts.rb +0 -20
  141. data/doc/ex/frame.rb +0 -12
  142. data/doc/ex/gaussian_blur.rb +0 -11
  143. data/doc/ex/get_multiline_type_metrics.rb +0 -41
  144. data/doc/ex/get_pixels.rb +0 -47
  145. data/doc/ex/get_type_metrics.rb +0 -141
  146. data/doc/ex/gradientfill.rb +0 -27
  147. data/doc/ex/grav.rb +0 -45
  148. data/doc/ex/gravity.rb +0 -80
  149. data/doc/ex/group.rb +0 -26
  150. data/doc/ex/hatchfill.rb +0 -27
  151. data/doc/ex/image.rb +0 -44
  152. data/doc/ex/images/Apple.miff +0 -0
  153. data/doc/ex/images/Ballerina.jpg +0 -0
  154. data/doc/ex/images/Ballerina3.jpg +0 -0
  155. data/doc/ex/images/Button_0.gif +0 -0
  156. data/doc/ex/images/Button_1.gif +0 -0
  157. data/doc/ex/images/Button_2.gif +0 -0
  158. data/doc/ex/images/Button_3.gif +0 -0
  159. data/doc/ex/images/Button_4.gif +0 -0
  160. data/doc/ex/images/Button_5.gif +0 -0
  161. data/doc/ex/images/Button_6.gif +0 -0
  162. data/doc/ex/images/Button_7.gif +0 -0
  163. data/doc/ex/images/Button_8.gif +0 -0
  164. data/doc/ex/images/Button_9.gif +0 -0
  165. data/doc/ex/images/Button_A.gif +0 -0
  166. data/doc/ex/images/Button_B.gif +0 -0
  167. data/doc/ex/images/Button_C.gif +0 -0
  168. data/doc/ex/images/Button_D.gif +0 -0
  169. data/doc/ex/images/Button_E.gif +0 -0
  170. data/doc/ex/images/Button_F.gif +0 -0
  171. data/doc/ex/images/Button_G.gif +0 -0
  172. data/doc/ex/images/Button_H.gif +0 -0
  173. data/doc/ex/images/Button_I.gif +0 -0
  174. data/doc/ex/images/Button_J.gif +0 -0
  175. data/doc/ex/images/Button_K.gif +0 -0
  176. data/doc/ex/images/Button_L.gif +0 -0
  177. data/doc/ex/images/Button_M.gif +0 -0
  178. data/doc/ex/images/Button_N.gif +0 -0
  179. data/doc/ex/images/Button_O.gif +0 -0
  180. data/doc/ex/images/Button_P.gif +0 -0
  181. data/doc/ex/images/Button_Q.gif +0 -0
  182. data/doc/ex/images/Button_R.gif +0 -0
  183. data/doc/ex/images/Button_S.gif +0 -0
  184. data/doc/ex/images/Button_T.gif +0 -0
  185. data/doc/ex/images/Button_U.gif +0 -0
  186. data/doc/ex/images/Button_V.gif +0 -0
  187. data/doc/ex/images/Button_W.gif +0 -0
  188. data/doc/ex/images/Button_X.gif +0 -0
  189. data/doc/ex/images/Button_Y.gif +0 -0
  190. data/doc/ex/images/Button_Z.gif +0 -0
  191. data/doc/ex/images/Cheetah.jpg +0 -0
  192. data/doc/ex/images/Coffee.wmf +0 -0
  193. data/doc/ex/images/Flower_Hat.jpg +0 -0
  194. data/doc/ex/images/Gold_Statue.jpg +0 -0
  195. data/doc/ex/images/Hot_Air_Balloons.jpg +0 -0
  196. data/doc/ex/images/Hot_Air_Balloons_H.jpg +0 -0
  197. data/doc/ex/images/Leaf.miff +0 -0
  198. data/doc/ex/images/No.wmf +0 -0
  199. data/doc/ex/images/Polynesia.jpg +0 -0
  200. data/doc/ex/images/Red_Rocks.jpg +0 -0
  201. data/doc/ex/images/Rocks_On_Beach.miff +0 -0
  202. data/doc/ex/images/Shorts.jpg +0 -0
  203. data/doc/ex/images/Snake.wmf +0 -0
  204. data/doc/ex/images/Violin.jpg +0 -0
  205. data/doc/ex/images/Yellow_Rose.miff +0 -0
  206. data/doc/ex/images/big-duck.gif +0 -0
  207. data/doc/ex/images/duck.gif +0 -0
  208. data/doc/ex/images/duck0.gif +0 -0
  209. data/doc/ex/images/duck1.gif +0 -0
  210. data/doc/ex/images/duck10.gif +0 -0
  211. data/doc/ex/images/duck11.gif +0 -0
  212. data/doc/ex/images/duck12.gif +0 -0
  213. data/doc/ex/images/duck13.gif +0 -0
  214. data/doc/ex/images/duck14.gif +0 -0
  215. data/doc/ex/images/duck15.gif +0 -0
  216. data/doc/ex/images/duck2.gif +0 -0
  217. data/doc/ex/images/duck3.gif +0 -0
  218. data/doc/ex/images/duck4.gif +0 -0
  219. data/doc/ex/images/duck5.gif +0 -0
  220. data/doc/ex/images/duck6.gif +0 -0
  221. data/doc/ex/images/duck7.gif +0 -0
  222. data/doc/ex/images/duck8.gif +0 -0
  223. data/doc/ex/images/duck9.gif +0 -0
  224. data/doc/ex/images/graydient230x6.gif +0 -0
  225. data/doc/ex/images/image_with_profile.jpg +0 -0
  226. data/doc/ex/images/logo400x83.gif +0 -0
  227. data/doc/ex/images/model.miff +0 -0
  228. data/doc/ex/images/notimplemented.gif +0 -0
  229. data/doc/ex/images/smile.miff +0 -0
  230. data/doc/ex/images/spin.gif +0 -0
  231. data/doc/ex/implode.rb +0 -34
  232. data/doc/ex/level.rb +0 -11
  233. data/doc/ex/level_colors.rb +0 -11
  234. data/doc/ex/line.rb +0 -41
  235. data/doc/ex/line01.rb +0 -21
  236. data/doc/ex/mask.rb +0 -35
  237. data/doc/ex/matte_fill_to_border.rb +0 -39
  238. data/doc/ex/matte_floodfill.rb +0 -32
  239. data/doc/ex/matte_replace.rb +0 -39
  240. data/doc/ex/median_filter.rb +0 -28
  241. data/doc/ex/modulate.rb +0 -11
  242. data/doc/ex/mono.rb +0 -23
  243. data/doc/ex/morph.rb +0 -25
  244. data/doc/ex/mosaic.rb +0 -35
  245. data/doc/ex/motion_blur.rb +0 -11
  246. data/doc/ex/negate.rb +0 -11
  247. data/doc/ex/negate_channel.rb +0 -9
  248. data/doc/ex/nested_rvg.rb +0 -21
  249. data/doc/ex/nonzero.rb +0 -42
  250. data/doc/ex/normalize.rb +0 -11
  251. data/doc/ex/oil_paint.rb +0 -11
  252. data/doc/ex/opacity.rb +0 -37
  253. data/doc/ex/ordered_dither.rb +0 -11
  254. data/doc/ex/path.rb +0 -63
  255. data/doc/ex/pattern1.rb +0 -25
  256. data/doc/ex/pattern2.rb +0 -26
  257. data/doc/ex/polaroid.rb +0 -27
  258. data/doc/ex/polygon.rb +0 -23
  259. data/doc/ex/polygon01.rb +0 -21
  260. data/doc/ex/polyline.rb +0 -22
  261. data/doc/ex/polyline01.rb +0 -21
  262. data/doc/ex/posterize.rb +0 -8
  263. data/doc/ex/preview.rb +0 -8
  264. data/doc/ex/qbezierpath.rb +0 -52
  265. data/doc/ex/quad01.rb +0 -34
  266. data/doc/ex/quantize-m.rb +0 -25
  267. data/doc/ex/radial_blur.rb +0 -9
  268. data/doc/ex/raise.rb +0 -8
  269. data/doc/ex/random_threshold_channel.rb +0 -13
  270. data/doc/ex/rect01.rb +0 -14
  271. data/doc/ex/rect02.rb +0 -20
  272. data/doc/ex/rectangle.rb +0 -34
  273. data/doc/ex/reduce_noise.rb +0 -28
  274. data/doc/ex/remap.rb +0 -11
  275. data/doc/ex/remap_images.rb +0 -19
  276. data/doc/ex/resize_to_fill.rb +0 -8
  277. data/doc/ex/resize_to_fit.rb +0 -8
  278. data/doc/ex/roll.rb +0 -9
  279. data/doc/ex/rotate.rb +0 -44
  280. data/doc/ex/rotate_f.rb +0 -14
  281. data/doc/ex/roundrect.rb +0 -33
  282. data/doc/ex/rubyname.rb +0 -30
  283. data/doc/ex/rvg_clippath.rb +0 -12
  284. data/doc/ex/rvg_linecap.rb +0 -42
  285. data/doc/ex/rvg_linejoin.rb +0 -40
  286. data/doc/ex/rvg_opacity.rb +0 -18
  287. data/doc/ex/rvg_pattern.rb +0 -26
  288. data/doc/ex/rvg_stroke_dasharray.rb +0 -11
  289. data/doc/ex/segment.rb +0 -11
  290. data/doc/ex/sepiatone.rb +0 -7
  291. data/doc/ex/shade.rb +0 -11
  292. data/doc/ex/shadow.rb +0 -30
  293. data/doc/ex/shave.rb +0 -15
  294. data/doc/ex/shear.rb +0 -10
  295. data/doc/ex/sketch.rb +0 -17
  296. data/doc/ex/skewx.rb +0 -51
  297. data/doc/ex/skewy.rb +0 -47
  298. data/doc/ex/smile.rb +0 -125
  299. data/doc/ex/solarize.rb +0 -11
  300. data/doc/ex/sparse_color.rb +0 -54
  301. data/doc/ex/splice.rb +0 -8
  302. data/doc/ex/spread.rb +0 -11
  303. data/doc/ex/stegano.rb +0 -55
  304. data/doc/ex/stroke_dasharray.rb +0 -42
  305. data/doc/ex/stroke_fill.rb +0 -10
  306. data/doc/ex/stroke_linecap.rb +0 -44
  307. data/doc/ex/stroke_linejoin.rb +0 -48
  308. data/doc/ex/stroke_width.rb +0 -49
  309. data/doc/ex/swirl.rb +0 -17
  310. data/doc/ex/text.rb +0 -37
  311. data/doc/ex/text01.rb +0 -16
  312. data/doc/ex/text_align.rb +0 -36
  313. data/doc/ex/text_antialias.rb +0 -37
  314. data/doc/ex/text_styles.rb +0 -19
  315. data/doc/ex/text_undercolor.rb +0 -28
  316. data/doc/ex/texture_fill_to_border.rb +0 -34
  317. data/doc/ex/texture_floodfill.rb +0 -32
  318. data/doc/ex/texturefill.rb +0 -24
  319. data/doc/ex/threshold.rb +0 -13
  320. data/doc/ex/to_blob.rb +0 -13
  321. data/doc/ex/translate.rb +0 -39
  322. data/doc/ex/transparent.rb +0 -38
  323. data/doc/ex/transpose.rb +0 -9
  324. data/doc/ex/transverse.rb +0 -9
  325. data/doc/ex/tref01.rb +0 -24
  326. data/doc/ex/triangle01.rb +0 -15
  327. data/doc/ex/trim.rb +0 -23
  328. data/doc/ex/tspan01.rb +0 -17
  329. data/doc/ex/tspan02.rb +0 -17
  330. data/doc/ex/tspan03.rb +0 -19
  331. data/doc/ex/unsharp_mask.rb +0 -28
  332. data/doc/ex/viewex.rb +0 -33
  333. data/doc/ex/vignette.rb +0 -12
  334. data/doc/ex/watermark.rb +0 -27
  335. data/doc/ex/wave.rb +0 -9
  336. data/doc/ex/wet_floor.rb +0 -58
  337. data/doc/ex/writing_mode01.rb +0 -26
  338. data/doc/ex/writing_mode02.rb +0 -26
  339. data/doc/ilist.html +0 -2056
  340. data/doc/image1.html +0 -4680
  341. data/doc/image2.html +0 -3665
  342. data/doc/image3.html +0 -4522
  343. data/doc/imageattrs.html +0 -1638
  344. data/doc/imusage.html +0 -514
  345. data/doc/index.html +0 -416
  346. data/doc/info.html +0 -1499
  347. data/doc/magick.html +0 -565
  348. data/doc/optequiv.html +0 -2435
  349. data/doc/rvg.html +0 -975
  350. data/doc/rvgclip.html +0 -248
  351. data/doc/rvggroup.html +0 -305
  352. data/doc/rvgimage.html +0 -289
  353. data/doc/rvgpattern.html +0 -475
  354. data/doc/rvgshape.html +0 -406
  355. data/doc/rvgstyle.html +0 -270
  356. data/doc/rvgtext.html +0 -465
  357. data/doc/rvgtspan.html +0 -238
  358. data/doc/rvgtut.html +0 -530
  359. data/doc/rvguse.html +0 -145
  360. data/doc/rvgxform.html +0 -294
  361. data/doc/scripts/doc.js +0 -22
  362. data/doc/scripts/stripeTables.js +0 -23
  363. data/doc/struct.html +0 -1339
  364. data/doc/usage.html +0 -1621
  365. data/examples/constitute.rb +0 -7
  366. data/examples/crop_with_gravity.rb +0 -42
  367. data/examples/demo.rb +0 -324
  368. data/examples/describe.rb +0 -43
  369. data/examples/find_similar_region.rb +0 -34
  370. data/examples/histogram.rb +0 -321
  371. data/examples/identify.rb +0 -185
  372. data/examples/image_opacity.rb +0 -29
  373. data/examples/import_export.rb +0 -31
  374. data/examples/pattern_fill.rb +0 -38
  375. data/examples/rotating_text.rb +0 -44
  376. data/examples/spinner.rb +0 -49
  377. data/examples/thumbnail.rb +0 -64
  378. data/examples/vignette.rb +0 -78
  379. data/spec/rmagick/ImageList1_spec.rb +0 -24
  380. data/spec/rmagick/draw_spec.rb +0 -156
  381. data/spec/rmagick/image/blue_shift_spec.rb +0 -16
  382. data/spec/rmagick/image/composite_spec.rb +0 -140
  383. data/spec/rmagick/image/constitute_spec.rb +0 -15
  384. data/spec/rmagick/image/dispatch_spec.rb +0 -18
  385. data/spec/rmagick/image/from_blob_spec.rb +0 -14
  386. data/spec/rmagick/image/ping_spec.rb +0 -14
  387. data/spec/rmagick/image/properties_spec.rb +0 -29
  388. data/spec/spec_helper.rb +0 -4
  389. data/test/Image1.rb +0 -565
  390. data/test/Image2.rb +0 -1304
  391. data/test/Image3.rb +0 -1030
  392. data/test/ImageList1.rb +0 -806
  393. data/test/ImageList2.rb +0 -385
  394. data/test/Image_attributes.rb +0 -697
  395. data/test/Import_Export.rb +0 -121
  396. data/test/Info.rb +0 -345
  397. data/test/Magick.rb +0 -321
  398. data/test/Pixel.rb +0 -116
  399. data/test/Preview.rb +0 -57
  400. data/test/cmyk.icm +0 -0
  401. data/test/srgb.icm +0 -0
  402. data/test/test_all_basic.rb +0 -38
  403. data/test/tmpnam_test.rb +0 -50
  404. data/wercker.yml +0 -10
@@ -19,22 +19,40 @@
19
19
  #include <assert.h>
20
20
  #include <stdio.h>
21
21
  #include <ctype.h>
22
- #if defined(HAVE_STDINT_H)
23
- #include <stdint.h>
24
- #endif
25
22
  #include <stdlib.h>
26
23
  #include <math.h>
27
- #include <time.h>
28
- #if defined(HAVE_SYS_TYPES_H)
29
24
  #include <sys/types.h>
30
- #endif
31
25
  #include "ruby.h"
32
- #if defined(HAVE_RUBY_IO_H)
33
- #include "ruby/io.h" // >= 1.9.0-5
26
+ #include "ruby/io.h"
27
+ #include "rmagick_gvl.h"
28
+
29
+ #if defined(__MINGW32__)
30
+ // Ruby defines wrong format specifiers for MinGW. So this defines original macro in here.
31
+ #if SIZEOF_SIZE_T == SIZEOF_LONG
32
+ #define RMIuSIZE "lu"
33
+ #define RMIdSIZE "ld"
34
+ #define RMIsVALUE "li\v"
35
+ #elif SIZEOF_SIZE_T == SIZEOF_LONG_LONG
36
+ #define RMIuSIZE "I64u"
37
+ #define RMIdSIZE "I64d"
38
+ #define RMIsVALUE "I64i\v"
39
+ #endif
34
40
  #else
35
- #include "rubyio.h"
41
+ // Use constants defined in Ruby
42
+ #define RMIuSIZE PRIuSIZE
43
+ #define RMIdSIZE PRIdSIZE
44
+ #define RMIsVALUE PRIsVALUE
36
45
  #endif
37
46
 
47
+ #if defined(__GNUC__)
48
+ #pragma GCC diagnostic push
49
+ #pragma GCC diagnostic ignored "-Wdeclaration-after-statement"
50
+ #pragma GCC diagnostic ignored "-Wunknown-pragmas"
51
+
52
+ #if __GNUC__ > 6
53
+ #pragma GCC diagnostic ignored "-Wimplicit-fallthrough"
54
+ #endif
55
+ #endif
38
56
 
39
57
  // Undef Ruby's versions of these symbols
40
58
  #undef PACKAGE_VERSION
@@ -44,14 +62,23 @@
44
62
  #undef PACKAGE_TARNAME
45
63
  #undef WORDS_BIGENDIAN
46
64
 
47
- #include "magick/MagickCore.h"
48
- #include "magick/magick-config.h"
65
+ #ifndef HAVE_RB_EXT_RACTOR_SAFE
66
+ #undef RUBY_TYPED_FROZEN_SHAREABLE
67
+ #define RUBY_TYPED_FROZEN_SHAREABLE 0
68
+ #endif
49
69
 
50
- // Undef ImageMagick's versions of these symbols
51
- #undef PACKAGE_STRING
70
+ #include "extconf.h"
52
71
 
72
+ #if defined(IMAGEMAGICK_7)
73
+ #include "MagickCore/MagickCore.h"
74
+ #include "MagickCore/magick-config.h"
75
+ #else
76
+ #include "magick/MagickCore.h"
77
+ #include "magick/magick-config.h"
78
+ #endif
53
79
 
54
- #include "extconf.h"
80
+ // Undef ImageMagick's versions of these symbols
81
+ #undef PACKAGE_STRING
55
82
 
56
83
 
57
84
  //! For quoting preprocessor symbols
@@ -59,11 +86,18 @@
59
86
  //! For quoting preprocessor symbols
60
87
  #define Q(q) Q2(q)
61
88
 
89
+ #ifdef __GNUC__
90
+ #define ATTRIBUTE_UNUSED __attribute__((unused))
91
+ #define ATTRIBUTE_NORETURN __attribute__((__noreturn__))
92
+ #else
93
+ #define ATTRIBUTE_UNUSED
94
+ #define ATTRIBUTE_NORETURN
95
+ #endif
62
96
 
63
97
  //! Trace new image creation in bang methods
64
98
  #define UPDATE_DATA_PTR(_obj_, _new_) \
65
- do { (void) rm_trace_creation(_new_);\
66
- DATA_PTR(_obj_) = (void *)(_new_);\
99
+ do { \
100
+ DATA_PTR(_obj_) = (void *)(_new_); \
67
101
  } while(0)
68
102
 
69
103
 
@@ -85,65 +119,23 @@
85
119
 
86
120
  //! degrees to radians conversion
87
121
  #undef DegreesToRadians // defined in ImageMagick.h in 6.0.2
88
- #define DegreesToRadians(x) ((x)*3.14159265358979323846/180.0)
122
+ #define DegreesToRadians(x) ((x)*3.14159265358979323846/180.0)
89
123
 
90
124
  //! pixel intensity calculation
91
125
  #define PIXEL_INTENSITY(q) ((Quantum)(0.299*(q)->red + 0.587*(q)->green + 0.114*(q)->blue + 0.5))
92
126
 
93
127
  //! find maximum of longs
94
- #define LMAX(a,b) ((((long)(a))>((long)(b)))?((long)(a)):((long)(b)))
128
+ #define LMAX(a, b) ((((long)(a))>((long)(b)))?((long)(a)):((long)(b)))
95
129
  //! find maximum of floats
96
- #define FMAX(a,b) ((((double)(a))>((double)(b)))?((double)(a)):((double)(b)))
130
+ #define FMAX(a, b) ((((double)(a))>((double)(b)))?((double)(a)):((double)(b)))
97
131
  //! find minimum of floats
98
- #define FMIN(a,b) ((((double)(a))<=((double)(b)))?((double)(a)):((double)(b)))
132
+ #define FMIN(a, b) ((((double)(a))<=((double)(b)))?((double)(a)):((double)(b)))
99
133
 
100
134
  #define RMAGICK_PI 3.14159265358979 /**< pi */
101
135
 
102
136
  //! round to Quantum
103
137
  #define ROUND_TO_QUANTUM(value) ((Quantum) ((value) > (Quantum)QuantumRange ? QuantumRange : (value) + 0.5))
104
138
 
105
-
106
- // Ruby 1.9.0 changed the name to rb_frame_this_func
107
- #if defined(HAVE_RB_FRAME_THIS_FUNC)
108
- #define THIS_FUNC() rb_frame_this_func() /**< get the Ruby function being called */
109
- #else
110
- #define THIS_FUNC() rb_frame_last_func() /**< get the Ruby function being called */
111
- #endif
112
-
113
- // GetReadFile doesn't exist in Ruby 1.9.0
114
- #if !defined(GetReadFile)
115
- #define GetReadFile(fptr) rb_io_stdio_file(fptr) /**< Ruby read file pointer */
116
- #define GetWriteFile(fptr) rb_io_stdio_file(fptr) /**< Ruby write file pointer */
117
- #endif
118
-
119
- // rb_io_t replaces OpenFile in Ruby 1.9.0
120
- #if defined(HAVE_RB_IO_T)
121
- #undef OpenFile
122
- #define OpenFile rb_io_t /**< Ruby open file */
123
- #endif
124
-
125
- // These macros are required in 1.9.1 but aren't defined prior to 1.8.6.
126
- #if !defined(RSTRING_LEN)
127
- #define RSTRING_LEN(s) (RSTRING((s))->len) /**< Ruby string length */
128
- #endif
129
- #if !defined(RSTRING_PTR)
130
- #define RSTRING_PTR(s) (RSTRING((s))->ptr) /**< Ruby string pointer */
131
- #endif
132
-
133
- // Backport these two macros to 1.8
134
- #if !defined(RARRAY_LEN)
135
- #define RARRAY_LEN(a) RARRAY((a))->len /**< Ruby array length */
136
- #endif
137
- // Matz says this macro is read-only! (see http://www.ruby-forum.com/topic/146072)
138
- #if !defined(RARRAY_PTR)
139
- #define RARRAY_PTR(a) RARRAY((a))->ptr /**< Ruby array pointer */
140
- #endif
141
-
142
- // Backport this macro to 1.8.6
143
- #if !defined(RB_GC_GUARD)
144
- #define RB_GC_GUARD(x) (x)
145
- #endif
146
-
147
139
  //! Convert a C string to a Ruby symbol. Used in marshal_dump/marshal_load methods
148
140
  #define CSTR2SYM(s) ID2SYM(rb_intern(s))
149
141
  //! Convert a C string to a Ruby String, or nil if the ptr is NULL
@@ -154,49 +146,53 @@
154
146
  */
155
147
  #define OBJ_TO_MAGICK_STRING(f, obj) \
156
148
  if ((obj) != Qnil)\
157
- magick_clone_string(&f, RSTRING_PTR(obj));\
149
+ {\
150
+ VALUE str = rb_String(obj);\
151
+ magick_clone_string(&f, StringValueCStr(str));\
152
+ }\
158
153
  else\
159
154
  f = NULL;
160
155
 
161
156
 
162
- /** ImageMagick 6.5.7 replaced DestroyConstitute with
163
- * ConstituteComponentTerminus. Both have the same signature.
164
- */
165
- #if defined(HAVE_CONSTITUTECOMPONENTTERMINUS)
166
- #define DestroyConstitute(void) ConstituteComponentTerminus(void)
167
- #endif
168
-
169
- /** ImageMagick 6.5.9 replaced MagickLibSubversion with
170
- * MagickLibAddendum.
171
- */
172
- #if defined(HAVE_MAGICKLIBADDENDUM)
173
157
  #define MagickLibSubversion MagickLibAddendum
174
- #endif
175
158
 
176
- /** IM 6.4.1 replaced AllocateImage with AcquireImage.
177
- * Both have the same signature.
178
- */
179
- #if !defined(HAVE_ACQUIREIMAGE)
180
- #define AcquireImage(info) AllocateImage(info)
181
- #endif
182
-
183
- // ImageLayerMethod replaced MagickLayerMethod starting with 6.3.6
184
- #if defined(HAVE_TYPE_IMAGELAYERMETHOD)
185
- #define LAYERMETHODTYPE ImageLayerMethod /**< layer method */
186
- #define CLASS_LAYERMETHODTYPE Class_ImageLayerMethod /**< layer method class */
187
- #define LAYERMETHODTYPE_NAME ImageLayerMethod_name /**< layer method name */
188
- #define LAYERMETHODTYPE_NEW ImageLayerMethod_new /**< new layer method */
159
+ typedef ImageInfo Info; /**< Make type name match class name */
160
+ #if defined(IMAGEMAGICK_7)
161
+ typedef struct _QuantumPixelPacket
162
+ {
163
+ Quantum
164
+ red,
165
+ green,
166
+ blue,
167
+ alpha,
168
+ black;
169
+ } QuantumPixelPacket;
170
+
171
+ typedef QuantumPixelPacket Pixel;
172
+ typedef PixelInfo MagickPixel;
173
+ typedef PixelInfo PixelColor;
189
174
  #else
190
- #define LAYERMETHODTYPE MagickLayerMethod /**< layer method */
191
- #define CLASS_LAYERMETHODTYPE Class_MagickLayerMethod /**< layer method class */
192
- #define LAYERMETHODTYPE_NAME MagickLayerMethod_name /**< layer method name */
193
- #define LAYERMETHODTYPE_NEW MagickLayerMethod_new /**< new layer method */
175
+ typedef struct _RMagickPixelPacket
176
+ {
177
+ Quantum
178
+ red,
179
+ green,
180
+ blue,
181
+ opacity,
182
+ black;
183
+ } RMagickPixelPacket;
184
+ typedef RMagickPixelPacket Pixel;
185
+ typedef MagickPixelPacket MagickPixel;
186
+ typedef PixelPacket PixelColor;
187
+ typedef AlphaChannelType AlphaChannelOption;
188
+ typedef DistortImageMethod DistortMethod;
189
+ typedef FilterTypes FilterType;
190
+ typedef InterpolatePixelMethod PixelInterpolateMethod;
191
+ typedef ImageLayerMethod LayerMethod;
192
+ #define TransparentAlpha 0
193
+ #define IMAGEMAGICK_6 1
194
194
  #endif
195
195
 
196
-
197
- typedef ImageInfo Info; /**< Make type name match class name */
198
- typedef PixelPacket Pixel; /**< Make type name match class name */
199
-
200
196
  //! Montage
201
197
  typedef struct
202
198
  {
@@ -218,7 +214,7 @@ typedef struct
218
214
  DrawInfo *info; /**< the DrawInfo struct */
219
215
  VALUE primitives; /**< the primitive string */
220
216
  struct TmpFile_Name *tmpfile_ary; /**< the tmp filenames */
221
- PixelPacket shadow_color; /**< PolaroidOptions#shadow_color */
217
+ PixelColor shadow_color; /**< PolaroidOptions#shadow_color */
222
218
  } Draw; // make the type match the class name
223
219
 
224
220
  // Enum
@@ -293,47 +289,28 @@ typedef enum _QuantumExpressionOperator
293
289
  RShiftQuantumOperator, /**< rshift */
294
290
  SubtractQuantumOperator, /**< subtract */
295
291
  XorQuantumOperator, /**< xor */
296
- #if defined(HAVE_ENUM_POWEVALUATEOPERATOR)
297
292
  PowQuantumOperator, /**< pow */
298
- #endif
299
- #if defined(HAVE_ENUM_LOGEVALUATEOPERATOR)
300
293
  LogQuantumOperator, /**< log */
301
- #endif
302
- #if defined(HAVE_ENUM_THRESHOLDEVALUATEOPERATOR)
303
294
  ThresholdQuantumOperator, /**< threshold */
304
- #endif
305
- #if defined(HAVE_ENUM_THRESHOLDBLACKEVALUATEOPERATOR)
306
295
  ThresholdBlackQuantumOperator, /**< threshold black */
307
- #endif
308
- #if defined(HAVE_ENUM_THRESHOLDWHITEEVALUATEOPERATOR)
309
296
  ThresholdWhiteQuantumOperator, /**< threshold white */
310
- #endif
311
- #if defined(HAVE_ENUM_GAUSSIANNOISEEVALUATEOPERATOR)
312
297
  GaussianNoiseQuantumOperator, /**< gaussian noise */
313
- #endif
314
- #if defined(HAVE_ENUM_IMPULSENOISEEVALUATEOPERATOR)
315
298
  ImpulseNoiseQuantumOperator, /**< impulse noise */
316
- #endif
317
- #if defined(HAVE_ENUM_LAPLACIANNOISEEVALUATEOPERATOR)
318
299
  LaplacianNoiseQuantumOperator, /**< laplacian noise */
319
- #endif
320
- #if defined(HAVE_ENUM_MULTIPLICATIVENOISEEVALUATEOPERATOR)
321
300
  MultiplicativeNoiseQuantumOperator, /**< multiplicative noise */
322
- #endif
323
- #if defined(HAVE_ENUM_POISSONNOISEEVALUATEOPERATOR)
324
301
  PoissonNoiseQuantumOperator, /**< poisson noise */
325
- #endif
326
- #if defined(HAVE_ENUM_UNIFORMNOISEEVALUATEOPERATOR)
327
302
  UniformNoiseQuantumOperator, /**< uniform noise */
328
- #endif
329
- #if defined(HAVE_ENUM_COSINEEVALUATEOPERATOR)
330
303
  CosineQuantumOperator, /**< cosine */
331
- #endif
332
- #if defined(HAVE_ENUM_SINEEVALUATEOPERATOR)
304
+ SetQuantumOperator, /**< set */
333
305
  SineQuantumOperator, /**< sine */
334
- #endif
335
- #if defined(HAVE_ENUM_ADDMODULUSEVALUATEOPERATOR)
336
- AddModulusQuantumOperator /**< add modulus */
306
+ AddModulusQuantumOperator, /**< add modulus */
307
+ MeanQuantumOperator, /**< mean */
308
+ AbsQuantumOperator, /**< abs */
309
+ ExponentialQuantumOperator, /**< exponential */
310
+ MedianQuantumOperator, /**< median */
311
+ SumQuantumOperator /**< sum */
312
+ #if defined(IMAGEMAGICK_GREATER_THAN_EQUAL_6_8_9)
313
+ , RootMeanSquareQuantumOperator /** root mean square */
337
314
  #endif
338
315
  } QuantumExpressionOperator ;
339
316
 
@@ -356,6 +333,7 @@ typedef enum _QuantumExpressionOperator
356
333
  EXTERN VALUE Module_Magick;
357
334
  EXTERN VALUE Class_ImageList;
358
335
  EXTERN VALUE Class_Info;
336
+ EXTERN VALUE Class_KernelInfo;
359
337
  EXTERN VALUE Class_Draw;
360
338
  EXTERN VALUE Class_DrawOptions;
361
339
  EXTERN VALUE Class_Image;
@@ -384,7 +362,7 @@ EXTERN VALUE Class_QuantumExpressionOperator;
384
362
  // Enum classes
385
363
  EXTERN VALUE Class_Enum;
386
364
  EXTERN VALUE Class_AlignType;
387
- EXTERN VALUE Class_AlphaChannelType;
365
+ EXTERN VALUE Class_AlphaChannelOption;
388
366
  EXTERN VALUE Class_AnchorType;
389
367
  EXTERN VALUE Class_ChannelType;
390
368
  EXTERN VALUE Class_ClassType;
@@ -394,148 +372,133 @@ EXTERN VALUE Class_CompositeOperator;
394
372
  EXTERN VALUE Class_CompressionType;
395
373
  EXTERN VALUE Class_DecorationType;
396
374
  EXTERN VALUE Class_DisposeType;
397
- EXTERN VALUE Class_DistortImageMethod;
398
- #if defined(HAVE_TYPE_DITHERMETHOD)
375
+ EXTERN VALUE Class_DistortMethod;
399
376
  EXTERN VALUE Class_DitherMethod;
400
- #endif
401
377
  EXTERN VALUE Class_EndianType;
402
- EXTERN VALUE Class_FilterTypes;
378
+ EXTERN VALUE Class_FilterType;
403
379
  EXTERN VALUE Class_GravityType;
404
380
  EXTERN VALUE Class_ImageType;
405
381
  EXTERN VALUE Class_InterlaceType;
406
- EXTERN VALUE Class_InterpolatePixelMethod;
407
- EXTERN VALUE CLASS_LAYERMETHODTYPE;
382
+ EXTERN VALUE Class_LayerMethod;
408
383
  EXTERN VALUE Class_MagickFunction;
409
384
  EXTERN VALUE Class_NoiseType;
410
385
  EXTERN VALUE Class_OrientationType;
411
386
  EXTERN VALUE Class_PaintMethod;
387
+ EXTERN VALUE Class_PixelInterpolateMethod;
412
388
  EXTERN VALUE Class_PreviewType;
413
389
  EXTERN VALUE Class_RenderingIntent;
414
390
  EXTERN VALUE Class_ResolutionType;
415
- #if defined(HAVE_SPARSECOLORIMAGE)
416
391
  EXTERN VALUE Class_SparseColorMethod;
417
- #endif
418
392
  EXTERN VALUE Class_SpreadMethod;
419
393
  EXTERN VALUE Class_StorageType;
420
394
  EXTERN VALUE Class_StretchType;
421
395
  EXTERN VALUE Class_StyleType;
422
396
  EXTERN VALUE Class_WeightType;
423
397
  EXTERN VALUE Class_VirtualPixelMethod;
398
+ EXTERN VALUE Class_GeometryFlags;
399
+ EXTERN VALUE Class_MorphologyMethod;
400
+ EXTERN VALUE Class_KernelInfoType;
424
401
 
425
402
  /**
426
403
  * Commonly-used IDs
427
404
  */
428
- EXTERN ID rm_ID_trace_proc; /**< "@trace_proc" */
429
405
  EXTERN ID rm_ID_call; /**< "call" */
430
406
  EXTERN ID rm_ID_changed; /**< "changed" */
431
407
  EXTERN ID rm_ID_cur_image; /**< "cur_image" */
432
408
  EXTERN ID rm_ID_dup; /**< "dup" */
433
409
  EXTERN ID rm_ID_fill; /**< "fill" */
434
- EXTERN ID rm_ID_flag; /**< "flag" */
435
- EXTERN ID rm_ID_from_s; /**< "from_s" */
436
410
  EXTERN ID rm_ID_Geometry; /**< "Geometry" */
437
- EXTERN ID rm_ID_GeometryValue; /**< "GeometryValue" */
438
- EXTERN ID rm_ID_has_key_q; /**< "has_key?" */
439
411
  EXTERN ID rm_ID_height; /**< "height" */
440
412
  EXTERN ID rm_ID_initialize_copy; /**< "initialize_copy" */
441
- EXTERN ID rm_ID_length; /**< "length" */
442
413
  EXTERN ID rm_ID_notify_observers; /**< "notify_observers" */
443
414
  EXTERN ID rm_ID_new; /**< "new" */
444
415
  EXTERN ID rm_ID_push; /**< "push" */
445
- EXTERN ID rm_ID_spaceship; /**< "<=>" */
446
- EXTERN ID rm_ID_to_i; /**< "to_i" */
447
- EXTERN ID rm_ID_to_s; /**< "to_s" */
448
416
  EXTERN ID rm_ID_values; /**< "values" */
449
417
  EXTERN ID rm_ID_width; /**< "width" */
450
- EXTERN ID rm_ID_x; /**< "x" */
451
- EXTERN ID rm_ID_y; /**< "y" */
418
+
419
+ extern const rb_data_type_t rm_enum_data_type;
420
+ extern const rb_data_type_t rm_info_data_type;
421
+ extern const rb_data_type_t rm_image_data_type;
422
+ extern const rb_data_type_t rm_draw_data_type;
423
+ extern const rb_data_type_t rm_pixel_data_type;
424
+ extern const rb_data_type_t rm_montage_data_type;
425
+ extern const rb_data_type_t rm_kernel_info_data_type;
452
426
 
453
427
  #if !defined(min)
454
- #define min(a,b) ((a)<(b)?(a):(b)) /**< min of two values */
428
+ #define min(a, b) ((a)<(b)?(a):(b)) /**< min of two values */
455
429
  #endif
456
430
  #if !defined(max)
457
- #define max(a,b) ((a)>(b)?(a):(b)) /**< max of two values */
431
+ #define max(a, b) ((a)>(b)?(a):(b)) /**< max of two values */
458
432
  #endif
459
433
 
460
434
  /**
461
435
  Handle warnings & errors
462
436
  */
463
437
  //! Handle warnings & errors
464
- #define CHECK_EXCEPTION() rm_check_exception(exception, NULL, RetainOnError);
465
-
438
+ #define CHECK_EXCEPTION() rm_check_exception(exception, NULL, RetainOnError)
466
439
 
467
- /*
468
- Call rb_define_method for an attribute accessor method
469
- */
470
- //! attribute reader
471
- #define DCL_ATTR_READER(class, attr) \
472
- rb_define_method(Class_##class, #attr, class##_##attr, 0);
473
- //! attribute writer
474
- #define DCL_ATTR_WRITER(class, attr) \
475
- rb_define_method(Class_##class, #attr "=", class##_##attr##_eq, 1);
476
- //! attribute accessor
477
- #define DCL_ATTR_ACCESSOR(class, attr) \
478
- DCL_ATTR_READER(class, attr) \
479
- DCL_ATTR_WRITER(class, attr)
480
- //! Borrow another class' attribute writer definition
481
- #define SHARE_ATTR_WRITER(to, from, attr) \
482
- rb_define_method(Class_##to, #attr "=", from##_##attr##_eq, 1);
483
440
 
484
441
  /*
485
442
  Define simple attribute accessor methods (boolean, int, string, and double types)
486
443
  */
487
- #define C_bool_to_R_bool(attr) (attr) ? Qtrue : Qfalse /**< C boolean -> Ruby boolean */
488
- #define R_bool_to_C_bool(attr) RTEST(attr) /**< C boolean <- Ruby boolean */
444
+ #define C_boolean_to_R_boolean(attr) (attr) ? Qtrue : Qfalse /**< C boolean -> Ruby boolean */
445
+ #define R_boolean_to_C_boolean(attr) RTEST(attr) /**< C boolean <- Ruby boolean */
489
446
  #define C_int_to_R_int(attr) INT2FIX(attr) /**< C int -> Ruby int */
490
447
  #define R_int_to_C_int(attr) NUM2INT(attr) /**< C int <- Ruby int */
491
- #define C_long_to_R_long(attr) INT2NUM(attr) /**< C long -> Ruby long */
448
+ #define C_long_to_R_long(attr) LONG2NUM(attr) /**< C long -> Ruby long */
492
449
  #define R_long_to_C_long(attr) NUM2LONG(attr) /**< C long <- Ruby long */
493
- #define C_ulong_to_R_ulong(attr) UINT2NUM(attr) /**< C unsigned long -> Ruby unsigned long */
450
+ #define C_ulong_to_R_ulong(attr) ULONG2NUM(attr) /**< C unsigned long -> Ruby unsigned long */
494
451
  #define R_ulong_to_C_ulong(attr) NUM2ULONG(attr) /**< C unsigned long <- Ruby unsigned long */
495
452
  #define C_str_to_R_str(attr) attr ? rb_str_new2(attr) : Qnil /**< C string -> Ruby string */
496
453
  #define C_dbl_to_R_dbl(attr) rb_float_new(attr) /**< C double -> Ruby double */
497
454
  #define R_dbl_to_C_dbl(attr) NUM2DBL(attr) /**< C double <- Ruby double */
498
455
 
499
456
  //! define attribute reader
500
- #define DEF_ATTR_READER(class, attr, type) \
501
- VALUE class##_##attr(VALUE self)\
457
+ #define IMPLEMENT_TYPED_ATTR_READER(class, attr, type, data_type) \
502
458
  {\
503
459
  class *ptr;\
504
460
  if (rb_obj_is_kind_of(self, Class_Image) == Qtrue) {\
505
- (void) rm_check_destroyed(self); \
461
+ rm_check_destroyed(self); \
506
462
  }\
507
- Data_Get_Struct(self, class, ptr);\
463
+ TypedData_Get_Struct(self, class, data_type, ptr);\
508
464
  return C_##type##_to_R_##type(ptr->attr);\
509
465
  }
510
466
 
511
467
  //! define attribute reader when attribute name is different from the field name
512
- #define DEF_ATTR_READERF(class, attr, field, type) \
513
- VALUE class##_##attr(VALUE self)\
468
+ #define IMPLEMENT_TYPED_ATTR_READERF(class, attr, field, type, data_type) \
514
469
  {\
515
470
  class *ptr;\
516
- (void) rm_check_destroyed(self); \
517
- Data_Get_Struct(self, class, ptr);\
471
+ rm_check_destroyed(self); \
472
+ TypedData_Get_Struct(self, class, data_type, ptr);\
518
473
  return C_##type##_to_R_##type(ptr->field);\
519
474
  }
520
475
 
521
476
  //! define attribute writer
522
- #define DEF_ATTR_WRITER(class, attr, type) \
523
- VALUE class##_##attr##_eq(VALUE self, VALUE val)\
477
+ #define IMPLEMENT_TYPED_ATTR_WRITER(class, attr, type, data_type) \
524
478
  {\
525
479
  class *ptr;\
526
480
  if (rb_obj_is_kind_of(self, Class_Image) == Qtrue) {\
527
- (void) rm_check_destroyed(self); \
481
+ rm_check_destroyed(self); \
528
482
  }\
529
483
  rb_check_frozen(self);\
530
- Data_Get_Struct(self, class, ptr);\
484
+ TypedData_Get_Struct(self, class, data_type, ptr);\
531
485
  ptr->attr = R_##type##_to_C_##type(val);\
486
+ return val;\
487
+ }
488
+
489
+ //! define attribute writer when attribute name is different from the field name
490
+ #define IMPLEMENT_TYPED_ATTR_WRITERF(class, attr, field, type, data_type) \
491
+ {\
492
+ class *ptr;\
493
+ if (rb_obj_is_kind_of(self, Class_Image) == Qtrue) {\
494
+ rm_check_destroyed(self); \
495
+ }\
496
+ rb_check_frozen(self);\
497
+ TypedData_Get_Struct(self, class, data_type, ptr);\
498
+ ptr->field = R_##type##_to_C_##type(val);\
532
499
  return self;\
533
500
  }
534
501
 
535
- //! define attribute accessor
536
- #define DEF_ATTR_ACCESSOR(class, attr, type)\
537
- DEF_ATTR_READER(class, attr, type)\
538
- DEF_ATTR_WRITER(class, attr, type)
539
502
 
540
503
  /*
541
504
  * Declare attribute accessors
@@ -551,114 +514,27 @@ EXTERN ID rm_ID_y; /**< "y" */
551
514
  ATTR_READER(class, attr)\
552
515
  ATTR_WRITER(class, attr)
553
516
 
554
- /*
555
- * Define functions to get/set attributes in Image::Info that
556
- * use the Get/SetImageOption API.
557
- */
558
- //! Option attribute reader. For Image::Info.
559
- #define OPTION_ATTR_READER(opt, key) \
560
- VALUE Info_##opt(VALUE self)\
561
- {\
562
- return get_option(self, #key);\
563
- }
564
- //! Option attribute writer. For Image::Info.
565
- #define OPTION_ATTR_WRITER(opt, key) \
566
- VALUE Info_##opt##_eq(VALUE self, VALUE string)\
567
- {\
568
- return set_option(self, #key, string);\
569
- }
570
- //! Option attribute accessor. For Image::Info.
571
- #define OPTION_ATTR_ACCESSOR(opt, key)\
572
- OPTION_ATTR_READER(opt, key)\
573
- OPTION_ATTR_WRITER(opt, key)
574
-
575
-
576
- /*
577
- * Declare Pixel channel attribute writers
578
- */
579
- //! Pixel channel attribute writer.
580
- #define DEF_PIXEL_CHANNEL_WRITER(_channel_) \
581
- extern VALUE \
582
- Pixel_##_channel_##_eq(VALUE self, VALUE v) \
583
- { \
584
- Pixel *pixel; \
585
- \
586
- rb_check_frozen(self); \
587
- Data_Get_Struct(self, Pixel, pixel); \
588
- pixel->_channel_ = APP2QUANTUM(v); \
589
- (void) rb_funcall(self, rm_ID_changed, 0); \
590
- (void) rb_funcall(self, rm_ID_notify_observers, 1, self); \
591
- return QUANTUM2NUM((pixel->_channel_)); \
592
- }
593
-
594
-
595
- /*
596
- * Declare Pixel CMYK channel attribute accessors
597
- */
598
- //! Pixel CMYK channel attribute accessor.
599
- #define DEF_PIXEL_CMYK_CHANNEL_ACCESSOR(_cmyk_channel_, _rgb_channel_) \
600
- extern VALUE \
601
- Pixel_##_cmyk_channel_##_eq(VALUE self, VALUE v) \
602
- { \
603
- Pixel *pixel; \
604
- \
605
- rb_check_frozen(self); \
606
- Data_Get_Struct(self, Pixel, pixel); \
607
- pixel->_rgb_channel_ = APP2QUANTUM(v); \
608
- (void) rb_funcall(self, rm_ID_changed, 0); \
609
- (void) rb_funcall(self, rm_ID_notify_observers, 1, self); \
610
- return QUANTUM2NUM(pixel->_rgb_channel_); \
611
- } \
612
- \
613
- extern VALUE \
614
- Pixel_##_cmyk_channel_(VALUE self) \
615
- { \
616
- Pixel *pixel; \
617
- \
618
- Data_Get_Struct(self, Pixel, pixel); \
619
- return INT2NUM(pixel->_rgb_channel_); \
620
- }
621
-
622
-
623
- /*
624
- * Enum constants - define a subclass of Enum for the specified enumeration.
625
- * Define an instance of the subclass for each member in the enumeration.
626
- * Initialize each instance with its name and value.
627
- */
628
- //! define Ruby enum
629
- #define DEF_ENUM(tag) {\
630
- VALUE _cls, _enum;\
631
- _cls = Class_##tag = rm_define_enum_type(#tag);
632
-
633
- //! define Ruby enumerator elements
634
- #define ENUMERATOR(val)\
635
- _enum = rm_enum_new(_cls, ID2SYM(rb_intern(#val)), INT2NUM(val));\
636
- rb_define_const(Module_Magick, #val, _enum);
637
- //! end of an enumerator
638
- #define END_ENUM }
639
517
 
640
518
  //! Define a Magick module constant
641
519
  #if MAGICKCORE_QUANTUM_DEPTH == 64
642
520
  #define DEF_CONST(constant) rb_define_const(Module_Magick, #constant, ULL2NUM(constant))
521
+ #define DEF_CONSTV(constant, val) rb_define_const(Module_Magick, #constant, ULL2NUM(val))
643
522
  #else // MAGICKCORE_QUANTUM_DEPTH == 8, 16, 32
644
523
  #define DEF_CONST(constant) rb_define_const(Module_Magick, #constant, UINT2NUM(constant))
524
+ #define DEF_CONSTV(constant, val) rb_define_const(Module_Magick, #constant, UINT2NUM(val))
645
525
  #endif
646
526
 
647
-
648
527
  //! Convert a Ruby enum constant back to a C enum member.
649
528
  #define VALUE_TO_ENUM(value, e, type) \
650
529
  do {\
651
530
  MagickEnum *magick_enum;\
652
531
  if (CLASS_OF(value) != Class_##type)\
653
- rb_raise(rb_eTypeError, "wrong enumeration type - expected %s, got %s"\
654
- , rb_class2name(Class_##type),rb_class2name(CLASS_OF(value)));\
655
- Data_Get_Struct(value, MagickEnum, magick_enum);\
532
+ rb_raise(rb_eTypeError, "wrong enumeration type - expected %s, got %s", \
533
+ rb_class2name(Class_##type), rb_class2name(CLASS_OF(value)));\
534
+ TypedData_Get_Struct(value, MagickEnum, &rm_enum_data_type, magick_enum);\
656
535
  e = (type)(magick_enum->val);\
657
536
  } while(0)
658
537
 
659
- //! create case statement, mapping enum to its name
660
- #define ENUM_TO_NAME(_enum) case _enum: return #_enum;
661
-
662
538
 
663
539
  // Method, external function declarations. These declarations are
664
540
  // grouped by the source file in which the methods are defined.
@@ -760,12 +636,11 @@ extern VALUE ImageList_animate(int, VALUE *, VALUE);
760
636
  extern VALUE ImageList_append(VALUE, VALUE);
761
637
  extern VALUE ImageList_average(VALUE);
762
638
  extern VALUE ImageList_coalesce(VALUE);
639
+ extern VALUE ImageList_combine(int, VALUE *, VALUE);
763
640
  extern VALUE ImageList_composite_layers(int, VALUE *, VALUE);
764
641
  extern VALUE ImageList_deconstruct(VALUE);
765
642
  extern VALUE ImageList_display(VALUE);
766
643
  extern VALUE ImageList_flatten_images(VALUE);
767
- extern VALUE ImageList_fx(int, VALUE *, VALUE);
768
- extern VALUE ImageList_map(int, VALUE *, VALUE);
769
644
  extern VALUE ImageList_montage(VALUE);
770
645
  extern VALUE ImageList_morph(VALUE, VALUE);
771
646
  extern VALUE ImageList_mosaic(VALUE);
@@ -802,7 +677,6 @@ ATTR_ACCESSOR(Info, font)
802
677
  ATTR_ACCESSOR(Info, format)
803
678
  ATTR_ACCESSOR(Info, fuzz)
804
679
  ATTR_ACCESSOR(Info, gravity)
805
- ATTR_ACCESSOR(Info, group)
806
680
  ATTR_ACCESSOR(Info, image_type)
807
681
  ATTR_ACCESSOR(Info, interlace)
808
682
  ATTR_ACCESSOR(Info, label)
@@ -814,7 +688,6 @@ ATTR_ACCESSOR(Info, orientation)
814
688
  ATTR_ACCESSOR(Info, origin)
815
689
  ATTR_ACCESSOR(Info, page)
816
690
  ATTR_ACCESSOR(Info, pen)
817
- // ATTR_ACCESSOR(Info, ping) obsolete
818
691
  ATTR_ACCESSOR(Info, pointsize)
819
692
  ATTR_ACCESSOR(Info, quality)
820
693
  ATTR_ACCESSOR(Info, sampling_factor)
@@ -829,7 +702,6 @@ ATTR_ACCESSOR(Info, transparent_color)
829
702
  ATTR_ACCESSOR(Info, undercolor)
830
703
  ATTR_ACCESSOR(Info, units)
831
704
  ATTR_ACCESSOR(Info, view)
832
- //ATTR_ACCESSOR(Info, verbose)
833
705
 
834
706
  extern VALUE Info_alloc(VALUE);
835
707
 
@@ -843,15 +715,26 @@ extern VALUE rm_info_new(void);
843
715
  extern DisposeType rm_dispose_to_enum(const char *);
844
716
  extern GravityType rm_gravity_to_enum(const char *);
845
717
 
718
+ // rmkinfo.c
719
+
720
+ extern VALUE KernelInfo_alloc(VALUE);
721
+
722
+ extern VALUE KernelInfo_initialize(VALUE, VALUE);
723
+ extern VALUE KernelInfo_unity_add(VALUE, VALUE);
724
+ extern VALUE KernelInfo_scale(VALUE, VALUE, VALUE);
725
+ extern VALUE KernelInfo_scale_geometry(VALUE, VALUE);
726
+ extern VALUE KernelInfo_clone(VALUE);
727
+
728
+ extern VALUE KernelInfo_builtin(VALUE, VALUE, VALUE);
729
+
730
+
846
731
  // rmimage.c
847
- ATTR_WRITER(Image, alpha)
848
732
  ATTR_ACCESSOR(Image, background_color)
849
733
  ATTR_READER(Image, base_columns)
850
734
  ATTR_READER(Image, base_filename)
851
735
  ATTR_READER(Image, base_rows)
852
736
  ATTR_ACCESSOR(Image, bias)
853
737
  ATTR_ACCESSOR(Image, black_point_compensation)
854
- ATTR_ACCESSOR(Image, blur)
855
738
  ATTR_ACCESSOR(Image, border_color)
856
739
  ATTR_READER(Image, bounding_box)
857
740
  ATTR_ACCESSOR(Image, chromaticity)
@@ -881,8 +764,6 @@ ATTR_ACCESSOR(Image, image_type)
881
764
  ATTR_ACCESSOR(Image, interlace)
882
765
  ATTR_ACCESSOR(Image, iptc_profile)
883
766
  ATTR_ACCESSOR(Image, iterations)
884
- ATTR_WRITER(Image, mask)
885
- ATTR_ACCESSOR(Image, matte)
886
767
  ATTR_ACCESSOR(Image, matte_color)
887
768
  ATTR_READER(Image, mean_error_per_pixel)
888
769
  ATTR_READER(Image, mime_type)
@@ -892,7 +773,6 @@ ATTR_READER(Image, normalized_mean_error)
892
773
  ATTR_READER(Image, normalized_maximum_error)
893
774
  ATTR_READER(Image, number_colors)
894
775
  ATTR_ACCESSOR(Image, offset)
895
- ATTR_WRITER(Image, opacity)
896
776
  ATTR_ACCESSOR(Image, orientation)
897
777
  ATTR_ACCESSOR(Image, page)
898
778
  ATTR_ACCESSOR(Image, pixel_interpolation_method)
@@ -912,7 +792,7 @@ ATTR_ACCESSOR(Image, x_resolution)
912
792
  ATTR_ACCESSOR(Image, y_resolution)
913
793
 
914
794
  extern ChannelType extract_channels(int *, VALUE *);
915
- extern void raise_ChannelType_error(VALUE);
795
+ extern void raise_ChannelType_error(VALUE) ATTRIBUTE_NORETURN;
916
796
  extern void add_format_prefix(Info *, VALUE);
917
797
 
918
798
  extern VALUE Image_alloc(VALUE);
@@ -954,6 +834,11 @@ extern VALUE Image_compare_channel(int, VALUE *, VALUE);
954
834
  extern VALUE Image_channel_depth(int, VALUE *, VALUE);
955
835
  extern VALUE Image_channel_extrema(int, VALUE *, VALUE);
956
836
  extern VALUE Image_channel_mean(int, VALUE *, VALUE);
837
+ #if defined(HAVE_GETIMAGECHANNELENTROPY) || defined(IMAGEMAGICK_7)
838
+ extern VALUE Image_channel_entropy(int, VALUE *, VALUE);
839
+ #else
840
+ extern VALUE Image_channel_entropy(int, VALUE *, VALUE) ATTRIBUTE_NORETURN;
841
+ #endif
957
842
  extern VALUE Image_charcoal(int, VALUE *, VALUE);
958
843
  extern VALUE Image_chop(VALUE, VALUE, VALUE, VALUE, VALUE);
959
844
  extern VALUE Image_clone(VALUE);
@@ -962,7 +847,6 @@ extern VALUE Image_color_flood_fill(VALUE, VALUE, VALUE, VALUE, VALUE, VALUE);
962
847
  extern VALUE Image_color_histogram(VALUE);
963
848
  extern VALUE Image_colorize(int, VALUE *, VALUE);
964
849
  extern VALUE Image_colormap(int, VALUE *, VALUE);
965
- extern VALUE Image_combine(int, VALUE *, VALUE);
966
850
  extern VALUE Image_composite(int, VALUE *, VALUE);
967
851
  extern VALUE Image_composite_affine(VALUE, VALUE, VALUE);
968
852
  extern VALUE Image_composite_bang(int, VALUE *, VALUE);
@@ -977,6 +861,8 @@ extern VALUE Image_contrast(int, VALUE *, VALUE);
977
861
  extern VALUE Image_contrast_stretch_channel(int, VALUE *, VALUE);
978
862
  extern VALUE Image_convolve(VALUE, VALUE, VALUE);
979
863
  extern VALUE Image_convolve_channel(int, VALUE *, VALUE);
864
+ extern VALUE Image_morphology(VALUE, VALUE, VALUE, VALUE);
865
+ extern VALUE Image_morphology_channel(VALUE, VALUE, VALUE, VALUE, VALUE);
980
866
  extern VALUE Image_copy(VALUE);
981
867
  extern VALUE Image_crop(int, VALUE *, VALUE);
982
868
  extern VALUE Image_crop_bang(int, VALUE *, VALUE);
@@ -1019,6 +905,7 @@ extern VALUE Image_flop_bang(VALUE);
1019
905
  extern VALUE Image_frame(int, VALUE *, VALUE);
1020
906
  extern VALUE Image_from_blob(VALUE, VALUE);
1021
907
  extern VALUE Image_function_channel(int, VALUE *, VALUE);
908
+ extern VALUE Image_fx(int, VALUE *, VALUE);
1022
909
  extern VALUE Image_gamma_channel(int, VALUE *, VALUE);
1023
910
  extern VALUE Image_gamma_correct(int, VALUE *, VALUE);
1024
911
  extern VALUE Image_gaussian_blur(int, VALUE *, VALUE);
@@ -1039,11 +926,10 @@ extern VALUE Image_liquid_rescale(int, VALUE *, VALUE);
1039
926
  extern VALUE Image__load(VALUE, VALUE);
1040
927
  extern VALUE Image_magnify(VALUE);
1041
928
  extern VALUE Image_magnify_bang(VALUE);
1042
- extern VALUE Image_map(int, VALUE *, VALUE);
1043
929
  extern VALUE Image_marshal_dump(VALUE);
1044
930
  extern VALUE Image_marshal_load(VALUE, VALUE);
1045
931
  extern VALUE Image_mask(int, VALUE *, VALUE);
1046
- extern VALUE Image_matte_flood_fill(VALUE, VALUE, VALUE, VALUE, VALUE, VALUE);
932
+ extern VALUE Image_matte_flood_fill(int, VALUE *, VALUE);
1047
933
  extern VALUE Image_median_filter(int, VALUE *, VALUE);
1048
934
  extern VALUE Image_minify(VALUE);
1049
935
  extern VALUE Image_minify_bang(VALUE);
@@ -1115,7 +1001,6 @@ extern VALUE Image_stereo(VALUE, VALUE);
1115
1001
  extern VALUE Image_store_pixels(VALUE, VALUE, VALUE, VALUE, VALUE, VALUE);
1116
1002
  extern VALUE Image_strip_bang(VALUE);
1117
1003
  extern VALUE Image_swirl(VALUE, VALUE);
1118
- extern VALUE Image_sync_profiles(VALUE);
1119
1004
  extern VALUE Image_texture_flood_fill(VALUE, VALUE, VALUE, VALUE, VALUE, VALUE);
1120
1005
  extern VALUE Image_threshold(VALUE, VALUE);
1121
1006
  extern VALUE Image_thumbnail(int, VALUE *, VALUE);
@@ -1144,7 +1029,6 @@ extern VALUE Image_write(VALUE, VALUE);
1144
1029
 
1145
1030
  extern VALUE rm_image_new(Image *);
1146
1031
  extern void rm_image_destroy(void *);
1147
- extern void rm_trace_creation(Image *);
1148
1032
 
1149
1033
 
1150
1034
  // rmfill.c
@@ -1163,12 +1047,11 @@ extern VALUE TextureFill_fill(VALUE, VALUE);
1163
1047
  ATTR_ACCESSOR(Pixel, red)
1164
1048
  ATTR_ACCESSOR(Pixel, green)
1165
1049
  ATTR_ACCESSOR(Pixel, blue)
1166
- ATTR_ACCESSOR(Pixel, opacity)
1050
+ ATTR_ACCESSOR(Pixel, alpha)
1167
1051
  ATTR_ACCESSOR(Pixel, cyan)
1168
1052
  ATTR_ACCESSOR(Pixel, magenta)
1169
1053
  ATTR_ACCESSOR(Pixel, yellow)
1170
1054
  ATTR_ACCESSOR(Pixel, black)
1171
- extern void destroy_Pixel(Pixel *);
1172
1055
  extern VALUE Pixel_alloc(VALUE);
1173
1056
  extern VALUE Pixel_case_eq(VALUE, VALUE);
1174
1057
  extern VALUE Pixel_clone(VALUE);
@@ -1176,7 +1059,6 @@ extern VALUE Pixel_dup(VALUE);
1176
1059
  extern VALUE Pixel_eql_q(VALUE, VALUE);
1177
1060
  extern VALUE Pixel_fcmp(int, VALUE *, VALUE);
1178
1061
  extern VALUE Pixel_from_color(VALUE, VALUE);
1179
- extern VALUE Pixel_from_HSL(VALUE, VALUE);
1180
1062
  extern VALUE Pixel_from_hsla(int, VALUE *, VALUE);
1181
1063
  extern VALUE Pixel_hash(VALUE);
1182
1064
  extern VALUE Pixel_initialize(int, VALUE *, VALUE);
@@ -1186,7 +1068,6 @@ extern VALUE Pixel_marshal_dump(VALUE);
1186
1068
  extern VALUE Pixel_marshal_load(VALUE, VALUE);
1187
1069
  extern VALUE Pixel_spaceship(VALUE, VALUE);
1188
1070
  extern VALUE Pixel_to_color(int, VALUE *, VALUE);
1189
- extern VALUE Pixel_to_HSL(VALUE);
1190
1071
  extern VALUE Pixel_to_hsla(VALUE);
1191
1072
  extern VALUE Pixel_to_s(VALUE);
1192
1073
 
@@ -1197,31 +1078,47 @@ extern VALUE Enum_initialize(VALUE, VALUE, VALUE);
1197
1078
  extern VALUE Enum_to_s(VALUE);
1198
1079
  extern VALUE Enum_to_i(VALUE);
1199
1080
  extern VALUE Enum_spaceship(VALUE, VALUE);
1081
+ extern VALUE Enum_bitwise_or(VALUE, VALUE);
1200
1082
  extern VALUE Enum_case_eq(VALUE, VALUE);
1201
1083
  extern VALUE Enum_type_initialize(VALUE, VALUE, VALUE);
1084
+ extern VALUE Enum_find(VALUE class, int val);
1202
1085
  extern VALUE Enum_type_each(VALUE);
1203
1086
  extern VALUE rm_enum_new(VALUE, VALUE, VALUE);
1087
+ extern VALUE ClassType_find(ClassType);
1088
+ extern VALUE ColorspaceType_find(ColorspaceType);
1089
+ extern const char *ComplianceType_name(ComplianceType *);
1090
+ extern VALUE ComplianceType_find(ComplianceType);
1091
+ extern VALUE CompositeOperator_find(CompositeOperator);
1092
+ extern VALUE CompressionType_find(CompressionType);
1093
+ extern VALUE DisposeType_find(DisposeType);
1094
+ extern VALUE EndianType_find(EndianType);
1095
+ extern VALUE FilterType_find(FilterType);
1096
+ extern VALUE GravityType_find(GravityType);
1097
+ extern VALUE ImageType_find(ImageType);
1098
+ extern VALUE InterlaceType_find(InterlaceType);
1099
+ extern VALUE OrientationType_find(OrientationType);
1100
+ extern VALUE PixelInterpolateMethod_find(PixelInterpolateMethod);
1101
+ extern VALUE RenderingIntent_find(RenderingIntent);
1102
+ extern VALUE ResolutionType_find(ResolutionType);
1103
+ extern const char *StorageType_name(StorageType);
1104
+ extern VALUE StretchType_find(StretchType);
1105
+ extern const char *StretchType_name(StretchType);
1106
+ extern VALUE StyleType_find(StyleType);
1107
+ extern const char *StyleType_name(StyleType);
1108
+ extern VALUE VirtualPixelMethod_find(VirtualPixelMethod);
1204
1109
 
1205
1110
 
1206
1111
  // rmstruct.c
1207
1112
  extern VALUE ChromaticityInfo_to_s(VALUE);
1208
1113
  extern VALUE ChromaticityInfo_new(ChromaticityInfo *);
1209
- extern void Color_to_PixelPacket(PixelPacket *, VALUE);
1210
- extern void Color_to_MagickPixelPacket(Image *, MagickPixelPacket *, VALUE);
1114
+ extern void Color_to_PixelColor(PixelColor *, VALUE);
1115
+ extern void Color_to_MagickPixel(Image *, MagickPixel *, VALUE);
1116
+ extern void Color_to_Pixel(Pixel *, VALUE);
1211
1117
  extern VALUE Color_to_s(VALUE);
1212
1118
  extern VALUE Import_ColorInfo(const ColorInfo *);
1213
- extern VALUE ClassType_new(ClassType);
1214
- extern VALUE ColorspaceType_new(ColorspaceType);
1215
- extern VALUE CompositeOperator_new(CompositeOperator);
1216
- extern VALUE CompressionType_new(CompressionType);
1217
- extern VALUE DisposeType_new(DisposeType);
1218
- extern VALUE EndianType_new(EndianType);
1219
- extern VALUE FilterTypes_new(FilterTypes);
1220
- extern VALUE GravityType_new(GravityType);
1221
1119
  extern VALUE Font_to_s(VALUE);
1222
- extern VALUE ImageType_new(ImageType);
1223
- extern VALUE InterlaceType_new(InterlaceType);
1224
- extern VALUE Pixel_from_MagickPixelPacket(const MagickPixelPacket *);
1120
+ extern VALUE Pixel_from_MagickPixel(const MagickPixel *);
1121
+ extern VALUE Pixel_from_PixelColor(const PixelColor *);
1225
1122
  extern VALUE Pixel_from_PixelPacket(const PixelPacket *);
1226
1123
  extern void Export_PointInfo(PointInfo *, VALUE);
1227
1124
  extern VALUE Import_PointInfo(PointInfo *);
@@ -1229,16 +1126,12 @@ extern VALUE PrimaryInfo_to_s(VALUE);
1229
1126
  extern VALUE Import_PrimaryInfo(PrimaryInfo *);
1230
1127
  extern VALUE RectangleInfo_to_s(VALUE);
1231
1128
  extern VALUE Import_RectangleInfo(RectangleInfo *);
1232
- extern VALUE RenderingIntent_new(RenderingIntent);
1233
- extern VALUE ResolutionType_new(ResolutionType);
1234
1129
  extern VALUE SegmentInfo_to_s(VALUE);
1235
1130
  extern VALUE Import_SegmentInfo(SegmentInfo *);
1236
1131
  extern void Export_AffineMatrix(AffineMatrix *, VALUE);
1237
1132
  extern VALUE Import_AffineMatrix(AffineMatrix *);
1238
1133
  extern void Export_ChromaticityInfo(ChromaticityInfo *, VALUE);
1239
1134
  extern void Export_ColorInfo(ColorInfo *, VALUE);
1240
- extern VALUE InterpolatePixelMethod_new(InterpolatePixelMethod);
1241
- extern VALUE OrientationType_new(OrientationType);
1242
1135
  extern void Export_PrimaryInfo(PrimaryInfo *, VALUE);
1243
1136
  extern void Export_RectangleInfo(RectangleInfo *, VALUE);
1244
1137
  extern void Export_SegmentInfo(SegmentInfo *, VALUE);
@@ -1248,9 +1141,6 @@ extern VALUE Import_TypeInfo(const TypeInfo *);
1248
1141
  extern VALUE TypeMetric_to_s(VALUE);
1249
1142
  extern void Export_TypeInfo(TypeInfo *, VALUE);
1250
1143
  extern VALUE Import_TypeMetric(TypeMetric *);
1251
- extern const char *StorageType_name(StorageType);
1252
- extern VALUE VirtualPixelMethod_new(VirtualPixelMethod);
1253
- extern VALUE LAYERMETHODTYPE_NEW(LAYERMETHODTYPE);
1254
1144
 
1255
1145
 
1256
1146
  // rmutil.c
@@ -1258,38 +1148,42 @@ extern VALUE ImageMagickError_initialize(int, VALUE *, VALUE);
1258
1148
  extern void *magick_malloc(const size_t);
1259
1149
  extern void *magick_safe_malloc(const size_t, const size_t);
1260
1150
  extern void magick_free(void *);
1261
- extern void *magick_realloc(void *, const size_t);
1262
1151
  extern void *magick_safe_realloc(void *, const size_t, const size_t);
1263
1152
  extern void magick_clone_string(char **, const char *);
1153
+ extern Image *rm_acquire_image(ImageInfo *);
1264
1154
  extern VALUE rm_cur_image(VALUE);
1265
- extern VALUE rm_pixelpacket_to_color_name(Image *, PixelPacket *);
1266
- extern VALUE rm_pixelpacket_to_color_name_info(Info *, PixelPacket *);
1267
- extern VALUE rm_no_freeze(VALUE);
1155
+ extern VALUE rm_pixelcolor_to_color_name(Image *, PixelColor *);
1156
+ extern VALUE rm_pixelcolor_to_color_name_info(Info *, PixelColor *);
1157
+ extern void rm_init_magickpixel(const Image *, MagickPixel *);
1158
+ extern void rm_set_magickpixel(MagickPixel *, const char *);
1159
+ extern VALUE rm_no_freeze(VALUE) ATTRIBUTE_NORETURN;
1268
1160
  extern int rm_strcasecmp(const char *, const char *);
1269
1161
  extern int rm_strncasecmp(const char *, const char *, size_t);
1162
+ extern size_t rm_strnlen_s(const char *, size_t);
1270
1163
  extern void rm_check_ary_len(VALUE, long);
1164
+ extern VALUE rm_check_ary_type(VALUE ary);
1271
1165
  extern Image *rm_check_destroyed(VALUE);
1272
1166
  extern Image *rm_check_frozen(VALUE);
1273
- extern VALUE rm_to_s(VALUE);
1274
1167
  extern char *rm_str2cstr(VALUE, long *);
1275
1168
  extern int rm_check_num2dbl(VALUE);
1276
1169
  extern double rm_fuzz_to_dbl(VALUE);
1277
1170
  extern Quantum rm_app2quantum(VALUE);
1278
- extern double rm_percentage(VALUE,double);
1171
+ extern double rm_percentage(VALUE, double);
1279
1172
  extern double rm_str_to_pct(VALUE);
1280
1173
  extern VALUE rm_define_enum_type(const char *);
1281
- extern void rm_write_temp_image(Image *, char *);
1174
+ extern void rm_write_temp_image(Image *, char *, size_t);
1282
1175
  extern void rm_delete_temp_image(char *);
1283
- extern void rm_not_implemented(void);
1176
+ extern void rm_not_implemented(void) ATTRIBUTE_NORETURN;
1284
1177
  extern void rm_attr_write(VALUE, VALUE);
1285
- extern void rm_get_geometry(VALUE, long *, long *, unsigned long *, unsigned long *, int *);
1286
1178
  extern const char *rm_get_property(const Image *, const char *);
1287
1179
  extern MagickBooleanType rm_set_property(Image *, const char *, const char *);
1288
1180
  extern void rm_set_user_artifact(Image *, Info *);
1289
- void rm_set_magick_pixel_packet(Pixel *, MagickPixelPacket *);
1290
1181
  extern void rm_sync_image_options(Image *, Info *);
1291
1182
  extern void rm_split(Image *);
1292
- extern void rm_magick_error(const char *, const char *);
1183
+ extern void rm_magick_error(const char *);
1184
+ #if defined(IMAGEMAGICK_7)
1185
+ extern void rm_set_pixelinfo_alpha(PixelInfo *, const MagickRealType);
1186
+ #endif
1293
1187
 
1294
1188
  //! whether to retain on errors
1295
1189
  typedef enum
@@ -1298,16 +1192,26 @@ typedef enum
1298
1192
  DestroyOnError = 1 /**< do not retain on error */
1299
1193
  } ErrorRetention;
1300
1194
 
1301
- extern void rm_check_image_exception(Image *, ErrorRetention);
1195
+ typedef enum
1196
+ {
1197
+ RetainExceptionRetention,
1198
+ DestroyExceptionRetention
1199
+ } ExceptionRetention;
1200
+
1302
1201
  extern void rm_check_exception(ExceptionInfo *, Image *, ErrorRetention);
1303
1202
  extern void rm_ensure_result(Image *);
1304
1203
  extern Image *rm_clone_image(Image *);
1305
- extern MagickBooleanType rm_progress_monitor(const char *, const MagickOffsetType, const MagickSizeType, void *);
1306
1204
  extern VALUE rm_exif_by_entry(Image *);
1307
1205
  extern VALUE rm_exif_by_number(Image *);
1308
1206
  extern void rm_get_optional_arguments(VALUE);
1309
- extern void rm_fatal_error_handler(const ExceptionType, const char *, const char *);
1207
+ extern void rm_fatal_error_handler(const ExceptionType, const char *, const char *) ATTRIBUTE_NORETURN;
1310
1208
  extern void rm_error_handler(const ExceptionType, const char *, const char *);
1311
1209
  extern void rm_warning_handler(const ExceptionType, const char *, const char *);
1210
+ extern MagickBooleanType rm_should_raise_exception(ExceptionInfo *, const ExceptionRetention);
1211
+ extern void rm_raise_exception(ExceptionInfo *);
1212
+ #if defined(IMAGEMAGICK_6)
1213
+ extern void rm_check_image_exception(Image *, ErrorRetention);
1214
+ #endif
1215
+
1312
1216
  #endif
1313
1217