rmagick 4.0.0 → 5.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (420) hide show
  1. checksums.yaml +4 -4
  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 +5 -1
  11. data/.rspec +1 -0
  12. data/.rubocop.yml +24 -0
  13. data/.rubocop_todo.yml +150 -297
  14. data/.yardopts +5 -0
  15. data/CHANGELOG.md +222 -0
  16. data/CODE_OF_CONDUCT.md +122 -7
  17. data/CONTRIBUTING.md +14 -10
  18. data/README.md +316 -0
  19. data/Rakefile +59 -93
  20. data/before_install_linux.sh +23 -29
  21. data/before_install_osx.sh +58 -2
  22. data/ext/RMagick/extconf.rb +191 -110
  23. data/ext/RMagick/rmagick.c +77 -104
  24. data/ext/RMagick/rmagick.h +138 -99
  25. data/ext/RMagick/rmagick_gvl.h +224 -0
  26. data/ext/RMagick/rmdraw.c +464 -526
  27. data/ext/RMagick/rmenum.c +132 -121
  28. data/ext/RMagick/rmfill.c +223 -83
  29. data/ext/RMagick/rmilist.c +360 -288
  30. data/ext/RMagick/rmimage.c +5550 -4318
  31. data/ext/RMagick/rminfo.c +637 -818
  32. data/ext/RMagick/rmkinfo.c +88 -92
  33. data/ext/RMagick/rmmain.c +462 -263
  34. data/ext/RMagick/rmmontage.c +105 -150
  35. data/ext/RMagick/rmpixel.c +554 -359
  36. data/ext/RMagick/rmstruct.c +81 -94
  37. data/ext/RMagick/rmutil.c +279 -270
  38. data/lib/rmagick/version.rb +3 -1
  39. data/lib/rmagick.rb +2 -0
  40. data/lib/rmagick_internal.rb +118 -104
  41. data/lib/rvg/clippath.rb +2 -1
  42. data/lib/rvg/container.rb +10 -5
  43. data/lib/rvg/describable.rb +1 -1
  44. data/lib/rvg/embellishable.rb +5 -4
  45. data/lib/rvg/misc.rb +15 -12
  46. data/lib/rvg/paint.rb +2 -1
  47. data/lib/rvg/pathdata.rb +12 -11
  48. data/lib/rvg/rvg.rb +10 -6
  49. data/lib/rvg/stylable.rb +9 -7
  50. data/lib/rvg/text.rb +11 -6
  51. data/lib/rvg/transformable.rb +3 -2
  52. data/lib/rvg/units.rb +1 -1
  53. data/rmagick.gemspec +13 -12
  54. metadata +63 -419
  55. data/.appveyor.yml +0 -45
  56. data/.circleci/config.yml +0 -56
  57. data/.ruby-version +0 -1
  58. data/.simplecov +0 -27
  59. data/.travis.yml +0 -62
  60. data/Doxyfile +0 -1514
  61. data/README.textile +0 -259
  62. data/benchmarks/memory/README.md +0 -50
  63. data/benchmarks/memory/image_new.rb +0 -8
  64. data/benchmarks/memory/rmagick.gnuplot +0 -16
  65. data/deprecated/RMagick.rb +0 -6
  66. data/doc/.cvsignore +0 -1
  67. data/doc/comtasks.html +0 -287
  68. data/doc/constants.html +0 -1581
  69. data/doc/css/doc.css +0 -299
  70. data/doc/css/popup.css +0 -34
  71. data/doc/css/ref.css +0 -67
  72. data/doc/draw.html +0 -3272
  73. data/doc/ex/InitialCoords.rb +0 -22
  74. data/doc/ex/NewCoordSys.rb +0 -30
  75. data/doc/ex/OrigCoordSys.rb +0 -16
  76. data/doc/ex/PreserveAspectRatio.rb +0 -204
  77. data/doc/ex/RotateScale.rb +0 -36
  78. data/doc/ex/Skew.rb +0 -38
  79. data/doc/ex/Use01.rb +0 -15
  80. data/doc/ex/Use02.rb +0 -20
  81. data/doc/ex/Use03.rb +0 -16
  82. data/doc/ex/ViewBox.rb +0 -31
  83. data/doc/ex/adaptive_threshold.rb +0 -9
  84. data/doc/ex/add_noise.rb +0 -16
  85. data/doc/ex/affine.rb +0 -48
  86. data/doc/ex/affine_transform.rb +0 -20
  87. data/doc/ex/arc.rb +0 -49
  88. data/doc/ex/arcpath.rb +0 -32
  89. data/doc/ex/arcs01.rb +0 -28
  90. data/doc/ex/arcs02.rb +0 -59
  91. data/doc/ex/average.rb +0 -15
  92. data/doc/ex/axes.rb +0 -64
  93. data/doc/ex/baseline_shift01.rb +0 -17
  94. data/doc/ex/bilevel_channel.rb +0 -8
  95. data/doc/ex/blur_image.rb +0 -12
  96. data/doc/ex/border.rb +0 -10
  97. data/doc/ex/bounding_box.rb +0 -42
  98. data/doc/ex/cbezier1.rb +0 -41
  99. data/doc/ex/cbezier2.rb +0 -41
  100. data/doc/ex/cbezier3.rb +0 -41
  101. data/doc/ex/cbezier4.rb +0 -42
  102. data/doc/ex/cbezier5.rb +0 -42
  103. data/doc/ex/cbezier6.rb +0 -53
  104. data/doc/ex/channel.rb +0 -25
  105. data/doc/ex/charcoal.rb +0 -12
  106. data/doc/ex/chop.rb +0 -29
  107. data/doc/ex/circle.rb +0 -33
  108. data/doc/ex/circle01.rb +0 -16
  109. data/doc/ex/clip_path.rb +0 -60
  110. data/doc/ex/coalesce.rb +0 -57
  111. data/doc/ex/color_fill_to_border.rb +0 -29
  112. data/doc/ex/color_floodfill.rb +0 -28
  113. data/doc/ex/color_histogram.rb +0 -47
  114. data/doc/ex/color_reset.rb +0 -11
  115. data/doc/ex/colorize.rb +0 -16
  116. data/doc/ex/colors.rb +0 -64
  117. data/doc/ex/compose_mask.rb +0 -22
  118. data/doc/ex/composite.rb +0 -133
  119. data/doc/ex/composite_layers.rb +0 -52
  120. data/doc/ex/composite_tiled.rb +0 -21
  121. data/doc/ex/contrast.rb +0 -36
  122. data/doc/ex/crop.rb +0 -31
  123. data/doc/ex/crop_with_gravity.rb +0 -42
  124. data/doc/ex/cubic01.rb +0 -43
  125. data/doc/ex/cubic02.rb +0 -91
  126. data/doc/ex/cycle_colormap.rb +0 -21
  127. data/doc/ex/dissolve.rb +0 -12
  128. data/doc/ex/drawcomp.rb +0 -41
  129. data/doc/ex/drop_shadow.rb +0 -60
  130. data/doc/ex/edge.rb +0 -11
  131. data/doc/ex/ellipse.rb +0 -45
  132. data/doc/ex/ellipse01.rb +0 -21
  133. data/doc/ex/emboss.rb +0 -11
  134. data/doc/ex/enhance.rb +0 -28
  135. data/doc/ex/equalize.rb +0 -11
  136. data/doc/ex/evenodd.rb +0 -42
  137. data/doc/ex/fill_pattern.rb +0 -23
  138. data/doc/ex/flatten_images.rb +0 -36
  139. data/doc/ex/flip.rb +0 -11
  140. data/doc/ex/flop.rb +0 -11
  141. data/doc/ex/font_styles.rb +0 -32
  142. data/doc/ex/fonts.rb +0 -16
  143. data/doc/ex/frame.rb +0 -12
  144. data/doc/ex/gaussian_blur.rb +0 -11
  145. data/doc/ex/get_multiline_type_metrics.rb +0 -41
  146. data/doc/ex/get_pixels.rb +0 -45
  147. data/doc/ex/get_type_metrics.rb +0 -142
  148. data/doc/ex/gradientfill.rb +0 -27
  149. data/doc/ex/grav.rb +0 -45
  150. data/doc/ex/gravity.rb +0 -78
  151. data/doc/ex/group.rb +0 -26
  152. data/doc/ex/hatchfill.rb +0 -27
  153. data/doc/ex/image.rb +0 -44
  154. data/doc/ex/images/Apple.miff +0 -0
  155. data/doc/ex/images/Ballerina.jpg +0 -0
  156. data/doc/ex/images/Ballerina3.jpg +0 -0
  157. data/doc/ex/images/Button_0.gif +0 -0
  158. data/doc/ex/images/Button_1.gif +0 -0
  159. data/doc/ex/images/Button_2.gif +0 -0
  160. data/doc/ex/images/Button_3.gif +0 -0
  161. data/doc/ex/images/Button_4.gif +0 -0
  162. data/doc/ex/images/Button_5.gif +0 -0
  163. data/doc/ex/images/Button_6.gif +0 -0
  164. data/doc/ex/images/Button_7.gif +0 -0
  165. data/doc/ex/images/Button_8.gif +0 -0
  166. data/doc/ex/images/Button_9.gif +0 -0
  167. data/doc/ex/images/Button_A.gif +0 -0
  168. data/doc/ex/images/Button_B.gif +0 -0
  169. data/doc/ex/images/Button_C.gif +0 -0
  170. data/doc/ex/images/Button_D.gif +0 -0
  171. data/doc/ex/images/Button_E.gif +0 -0
  172. data/doc/ex/images/Button_F.gif +0 -0
  173. data/doc/ex/images/Button_G.gif +0 -0
  174. data/doc/ex/images/Button_H.gif +0 -0
  175. data/doc/ex/images/Button_I.gif +0 -0
  176. data/doc/ex/images/Button_J.gif +0 -0
  177. data/doc/ex/images/Button_K.gif +0 -0
  178. data/doc/ex/images/Button_L.gif +0 -0
  179. data/doc/ex/images/Button_M.gif +0 -0
  180. data/doc/ex/images/Button_N.gif +0 -0
  181. data/doc/ex/images/Button_O.gif +0 -0
  182. data/doc/ex/images/Button_P.gif +0 -0
  183. data/doc/ex/images/Button_Q.gif +0 -0
  184. data/doc/ex/images/Button_R.gif +0 -0
  185. data/doc/ex/images/Button_S.gif +0 -0
  186. data/doc/ex/images/Button_T.gif +0 -0
  187. data/doc/ex/images/Button_U.gif +0 -0
  188. data/doc/ex/images/Button_V.gif +0 -0
  189. data/doc/ex/images/Button_W.gif +0 -0
  190. data/doc/ex/images/Button_X.gif +0 -0
  191. data/doc/ex/images/Button_Y.gif +0 -0
  192. data/doc/ex/images/Button_Z.gif +0 -0
  193. data/doc/ex/images/Cheetah.jpg +0 -0
  194. data/doc/ex/images/Coffee.png +0 -0
  195. data/doc/ex/images/Flower_Hat.jpg +0 -0
  196. data/doc/ex/images/Gold_Statue.jpg +0 -0
  197. data/doc/ex/images/Hot_Air_Balloons.jpg +0 -0
  198. data/doc/ex/images/Hot_Air_Balloons_H.jpg +0 -0
  199. data/doc/ex/images/Leaf.miff +0 -0
  200. data/doc/ex/images/No.png +0 -0
  201. data/doc/ex/images/Polynesia.jpg +0 -0
  202. data/doc/ex/images/Red_Rocks.jpg +0 -0
  203. data/doc/ex/images/Rocks_On_Beach.miff +0 -0
  204. data/doc/ex/images/Shorts.jpg +0 -0
  205. data/doc/ex/images/Snake.png +0 -0
  206. data/doc/ex/images/Violin.jpg +0 -0
  207. data/doc/ex/images/Yellow_Rose.miff +0 -0
  208. data/doc/ex/images/big-duck.gif +0 -0
  209. data/doc/ex/images/duck.gif +0 -0
  210. data/doc/ex/images/duck0.gif +0 -0
  211. data/doc/ex/images/duck1.gif +0 -0
  212. data/doc/ex/images/duck10.gif +0 -0
  213. data/doc/ex/images/duck11.gif +0 -0
  214. data/doc/ex/images/duck12.gif +0 -0
  215. data/doc/ex/images/duck13.gif +0 -0
  216. data/doc/ex/images/duck14.gif +0 -0
  217. data/doc/ex/images/duck15.gif +0 -0
  218. data/doc/ex/images/duck2.gif +0 -0
  219. data/doc/ex/images/duck3.gif +0 -0
  220. data/doc/ex/images/duck4.gif +0 -0
  221. data/doc/ex/images/duck5.gif +0 -0
  222. data/doc/ex/images/duck6.gif +0 -0
  223. data/doc/ex/images/duck7.gif +0 -0
  224. data/doc/ex/images/duck8.gif +0 -0
  225. data/doc/ex/images/duck9.gif +0 -0
  226. data/doc/ex/images/graydient230x6.gif +0 -0
  227. data/doc/ex/images/image_with_profile.jpg +0 -0
  228. data/doc/ex/images/logo400x83.gif +0 -0
  229. data/doc/ex/images/model.miff +0 -0
  230. data/doc/ex/images/notimplemented.gif +0 -0
  231. data/doc/ex/images/smile.miff +0 -0
  232. data/doc/ex/images/spin.gif +0 -0
  233. data/doc/ex/implode.rb +0 -34
  234. data/doc/ex/level.rb +0 -11
  235. data/doc/ex/level_colors.rb +0 -11
  236. data/doc/ex/line.rb +0 -41
  237. data/doc/ex/line01.rb +0 -21
  238. data/doc/ex/mask.rb +0 -35
  239. data/doc/ex/matte_fill_to_border.rb +0 -39
  240. data/doc/ex/matte_floodfill.rb +0 -32
  241. data/doc/ex/matte_replace.rb +0 -39
  242. data/doc/ex/median_filter.rb +0 -28
  243. data/doc/ex/modulate.rb +0 -11
  244. data/doc/ex/mono.rb +0 -23
  245. data/doc/ex/morph.rb +0 -25
  246. data/doc/ex/mosaic.rb +0 -37
  247. data/doc/ex/motion_blur.rb +0 -11
  248. data/doc/ex/negate.rb +0 -11
  249. data/doc/ex/negate_channel.rb +0 -9
  250. data/doc/ex/nested_rvg.rb +0 -21
  251. data/doc/ex/nonzero.rb +0 -42
  252. data/doc/ex/normalize.rb +0 -11
  253. data/doc/ex/oil_paint.rb +0 -11
  254. data/doc/ex/opacity.rb +0 -37
  255. data/doc/ex/ordered_dither.rb +0 -11
  256. data/doc/ex/path.rb +0 -63
  257. data/doc/ex/pattern1.rb +0 -25
  258. data/doc/ex/pattern2.rb +0 -26
  259. data/doc/ex/polaroid.rb +0 -26
  260. data/doc/ex/polygon.rb +0 -23
  261. data/doc/ex/polygon01.rb +0 -21
  262. data/doc/ex/polyline.rb +0 -22
  263. data/doc/ex/polyline01.rb +0 -21
  264. data/doc/ex/posterize.rb +0 -8
  265. data/doc/ex/preview.rb +0 -8
  266. data/doc/ex/qbezierpath.rb +0 -52
  267. data/doc/ex/quad01.rb +0 -34
  268. data/doc/ex/quantize-m.rb +0 -25
  269. data/doc/ex/radial_blur.rb +0 -9
  270. data/doc/ex/raise.rb +0 -8
  271. data/doc/ex/random_threshold_channel.rb +0 -13
  272. data/doc/ex/rect01.rb +0 -14
  273. data/doc/ex/rect02.rb +0 -20
  274. data/doc/ex/rectangle.rb +0 -34
  275. data/doc/ex/reduce_noise.rb +0 -28
  276. data/doc/ex/remap.rb +0 -11
  277. data/doc/ex/remap_images.rb +0 -19
  278. data/doc/ex/resize_to_fill.rb +0 -8
  279. data/doc/ex/resize_to_fit.rb +0 -8
  280. data/doc/ex/roll.rb +0 -9
  281. data/doc/ex/rotate.rb +0 -44
  282. data/doc/ex/rotate_f.rb +0 -14
  283. data/doc/ex/roundrect.rb +0 -33
  284. data/doc/ex/rubyname.rb +0 -30
  285. data/doc/ex/rvg_clippath.rb +0 -12
  286. data/doc/ex/rvg_linecap.rb +0 -42
  287. data/doc/ex/rvg_linejoin.rb +0 -40
  288. data/doc/ex/rvg_opacity.rb +0 -18
  289. data/doc/ex/rvg_pattern.rb +0 -26
  290. data/doc/ex/rvg_stroke_dasharray.rb +0 -11
  291. data/doc/ex/segment.rb +0 -11
  292. data/doc/ex/sepiatone.rb +0 -7
  293. data/doc/ex/shade.rb +0 -11
  294. data/doc/ex/shadow.rb +0 -30
  295. data/doc/ex/shave.rb +0 -15
  296. data/doc/ex/shear.rb +0 -10
  297. data/doc/ex/sketch.rb +0 -17
  298. data/doc/ex/skewx.rb +0 -51
  299. data/doc/ex/skewy.rb +0 -47
  300. data/doc/ex/smile.rb +0 -126
  301. data/doc/ex/solarize.rb +0 -11
  302. data/doc/ex/sparse_color.rb +0 -55
  303. data/doc/ex/splice.rb +0 -8
  304. data/doc/ex/spread.rb +0 -11
  305. data/doc/ex/stegano.rb +0 -54
  306. data/doc/ex/stroke_dasharray.rb +0 -42
  307. data/doc/ex/stroke_fill.rb +0 -10
  308. data/doc/ex/stroke_linecap.rb +0 -44
  309. data/doc/ex/stroke_linejoin.rb +0 -48
  310. data/doc/ex/stroke_width.rb +0 -49
  311. data/doc/ex/swirl.rb +0 -17
  312. data/doc/ex/text.rb +0 -37
  313. data/doc/ex/text01.rb +0 -16
  314. data/doc/ex/text_align.rb +0 -36
  315. data/doc/ex/text_antialias.rb +0 -37
  316. data/doc/ex/text_styles.rb +0 -19
  317. data/doc/ex/text_undercolor.rb +0 -28
  318. data/doc/ex/texture_fill_to_border.rb +0 -34
  319. data/doc/ex/texture_floodfill.rb +0 -32
  320. data/doc/ex/texturefill.rb +0 -24
  321. data/doc/ex/threshold.rb +0 -13
  322. data/doc/ex/to_blob.rb +0 -13
  323. data/doc/ex/translate.rb +0 -39
  324. data/doc/ex/transparent.rb +0 -38
  325. data/doc/ex/transpose.rb +0 -9
  326. data/doc/ex/transverse.rb +0 -9
  327. data/doc/ex/tref01.rb +0 -24
  328. data/doc/ex/triangle01.rb +0 -15
  329. data/doc/ex/trim.rb +0 -23
  330. data/doc/ex/tspan01.rb +0 -17
  331. data/doc/ex/tspan02.rb +0 -17
  332. data/doc/ex/tspan03.rb +0 -19
  333. data/doc/ex/unsharp_mask.rb +0 -28
  334. data/doc/ex/viewex.rb +0 -33
  335. data/doc/ex/vignette.rb +0 -12
  336. data/doc/ex/watermark.rb +0 -27
  337. data/doc/ex/wave.rb +0 -9
  338. data/doc/ex/wet_floor.rb +0 -58
  339. data/doc/ex/writing_mode01.rb +0 -26
  340. data/doc/ex/writing_mode02.rb +0 -26
  341. data/doc/ilist.html +0 -2056
  342. data/doc/image1.html +0 -4680
  343. data/doc/image2.html +0 -3665
  344. data/doc/image3.html +0 -4522
  345. data/doc/imageattrs.html +0 -1638
  346. data/doc/imusage.html +0 -514
  347. data/doc/index.html +0 -416
  348. data/doc/info.html +0 -1499
  349. data/doc/magick.html +0 -570
  350. data/doc/optequiv.html +0 -2435
  351. data/doc/rvg.html +0 -975
  352. data/doc/rvgclip.html +0 -248
  353. data/doc/rvggroup.html +0 -305
  354. data/doc/rvgimage.html +0 -289
  355. data/doc/rvgpattern.html +0 -475
  356. data/doc/rvgshape.html +0 -406
  357. data/doc/rvgstyle.html +0 -270
  358. data/doc/rvgtext.html +0 -465
  359. data/doc/rvgtspan.html +0 -238
  360. data/doc/rvgtut.html +0 -530
  361. data/doc/rvguse.html +0 -145
  362. data/doc/rvgxform.html +0 -294
  363. data/doc/scripts/doc.js +0 -22
  364. data/doc/scripts/stripeTables.js +0 -23
  365. data/doc/struct.html +0 -1339
  366. data/doc/usage.html +0 -1621
  367. data/examples/constitute.rb +0 -7
  368. data/examples/crop_with_gravity.rb +0 -43
  369. data/examples/demo.rb +0 -323
  370. data/examples/describe.rb +0 -41
  371. data/examples/find_similar_region.rb +0 -34
  372. data/examples/histogram.rb +0 -312
  373. data/examples/identify.rb +0 -174
  374. data/examples/image_opacity.rb +0 -28
  375. data/examples/import_export.rb +0 -31
  376. data/examples/pattern_fill.rb +0 -37
  377. data/examples/rotating_text.rb +0 -45
  378. data/examples/spinner.rb +0 -49
  379. data/examples/thumbnail.rb +0 -64
  380. data/examples/vignette.rb +0 -78
  381. data/spec/rmagick/ImageList1_spec.rb +0 -24
  382. data/spec/rmagick/draw_spec.rb +0 -155
  383. data/spec/rmagick/image/blue_shift_spec.rb +0 -14
  384. data/spec/rmagick/image/channel_entropy_spec.rb +0 -9
  385. data/spec/rmagick/image/composite_spec.rb +0 -72
  386. data/spec/rmagick/image/constitute_spec.rb +0 -13
  387. data/spec/rmagick/image/dispatch_spec.rb +0 -16
  388. data/spec/rmagick/image/from_blob_spec.rb +0 -12
  389. data/spec/rmagick/image/ping_spec.rb +0 -12
  390. data/spec/rmagick/image/properties_spec.rb +0 -27
  391. data/spec/rmagick/image/read_spec.rb +0 -28
  392. data/spec/spec_helper.rb +0 -10
  393. data/spec/support/issue_200/app.rb +0 -8
  394. data/test/Draw.rb +0 -351
  395. data/test/Enum.rb +0 -228
  396. data/test/Fill.rb +0 -93
  397. data/test/Image1.rb +0 -606
  398. data/test/Image2.rb +0 -1408
  399. data/test/Image3.rb +0 -1086
  400. data/test/ImageList1.rb +0 -858
  401. data/test/ImageList2.rb +0 -375
  402. data/test/Image_attributes.rb +0 -635
  403. data/test/Import_Export.rb +0 -111
  404. data/test/Info.rb +0 -436
  405. data/test/KernelInfo.rb +0 -59
  406. data/test/Magick.rb +0 -311
  407. data/test/Pixel.rb +0 -259
  408. data/test/PolaroidOptions.rb +0 -23
  409. data/test/Preview.rb +0 -26
  410. data/test/Struct.rb +0 -45
  411. data/test/appearance/Montage.rb +0 -26
  412. data/test/appearance/appearance_assertion.rb +0 -13
  413. data/test/appearance/expected/montage_border_color.jpg +0 -0
  414. data/test/cmyk.icm +0 -0
  415. data/test/lib/internal/Draw.rb +0 -811
  416. data/test/lib/internal/Geometry.rb +0 -98
  417. data/test/lib/internal/Magick.rb +0 -40
  418. data/test/srgb.icm +0 -0
  419. data/test/test_all_basic.rb +0 -49
  420. data/test/tmpnam_test.rb +0 -50
@@ -14,6 +14,7 @@
14
14
 
15
15
 
16
16
 
17
+ static VALUE rm_yield_handle_exception(VALUE, VALUE) ATTRIBUTE_NORETURN;
17
18
 
18
19
  static VALUE
19
20
  rm_yield_body(VALUE object)
@@ -26,22 +27,19 @@ rm_yield_handle_exception(VALUE allocated_area, VALUE exc)
26
27
  {
27
28
  magick_free((void *)allocated_area);
28
29
  rb_exc_raise(exc);
29
- return Qnil; /* not reachable */
30
30
  }
31
31
 
32
32
  /**
33
33
  * If called with the optional block, iterates over the colors, otherwise
34
- * returns an array of Magick::Color objects.
34
+ * returns an array of {Magick::Color} objects.
35
35
  *
36
- * Ruby usage:
37
- * - @verbatim Magick::colors @endverbatim
38
- * - @verbatim Magick::colors { |colorinfo| } @endverbatim
36
+ * @overload colors
37
+ * @return [Array<Magick::Color>] the array of {Magick::Color}
39
38
  *
40
- * Notes:
41
- * - There are 3 implementations.
39
+ * @overload colors
40
+ * @yield [colorinfo]
41
+ * @yieldparam colorinfo [Magick::Color] the color
42
42
  *
43
- * @param class the class on which the method is run.
44
- * @return either the input class (if a block was given) or the array of colors.
45
43
  */
46
44
  VALUE
47
45
  Magick_colors(VALUE class)
@@ -54,8 +52,8 @@ Magick_colors(VALUE class)
54
52
  exception = AcquireExceptionInfo();
55
53
 
56
54
  color_info_list = GetColorInfoList("*", &number_colors, exception);
57
- CHECK_EXCEPTION()
58
- (void) DestroyExceptionInfo(exception);
55
+ CHECK_EXCEPTION();
56
+ DestroyExceptionInfo(exception);
59
57
 
60
58
 
61
59
  if (rb_block_given_p())
@@ -72,7 +70,7 @@ Magick_colors(VALUE class)
72
70
  ary = rb_ary_new2((long) number_colors);
73
71
  for (x = 0; x < number_colors; x++)
74
72
  {
75
- (void) rb_ary_push(ary, Import_ColorInfo(color_info_list[x]));
73
+ rb_ary_push(ary, Import_ColorInfo(color_info_list[x]));
76
74
  }
77
75
 
78
76
  magick_free((void *)color_info_list);
@@ -84,14 +82,15 @@ Magick_colors(VALUE class)
84
82
 
85
83
  /**
86
84
  * If called with the optional block, iterates over the fonts, otherwise returns
87
- * an array of Magick::Font objects.
85
+ * an array of {Magick::Font} objects.
88
86
  *
89
- * Ruby usage:
90
- * - @verbatim Magick::fonts @endverbatim
91
- * - @verbatim Magick::fonts { |fontinfo| } @endverbatim
87
+ * @overload fonts
88
+ * @return [Array<Magick::Font>] the array of {Magick::Font}
89
+ *
90
+ * @overload fonts
91
+ * @yield [fontinfo]
92
+ * @yieldparam fontinfo [Magick::Font] the font
92
93
  *
93
- * @param class the class on which the method is run.
94
- * @return either the input class (if a block was given) or the array of fonts.
95
94
  */
96
95
  VALUE
97
96
  Magick_fonts(VALUE class)
@@ -103,8 +102,8 @@ Magick_fonts(VALUE class)
103
102
 
104
103
  exception = AcquireExceptionInfo();
105
104
  type_info = GetTypeInfoList("*", &number_types, exception);
106
- CHECK_EXCEPTION()
107
- (void) DestroyExceptionInfo(exception);
105
+ CHECK_EXCEPTION();
106
+ DestroyExceptionInfo(exception);
108
107
 
109
108
  if (rb_block_given_p())
110
109
  {
@@ -120,7 +119,7 @@ Magick_fonts(VALUE class)
120
119
  ary = rb_ary_new2((long)number_types);
121
120
  for (x = 0; x < number_types; x++)
122
121
  {
123
- (void) rb_ary_push(ary, Import_TypeInfo((const TypeInfo *)type_info[x]));
122
+ rb_ary_push(ary, Import_TypeInfo((const TypeInfo *)type_info[x]));
124
123
  }
125
124
  magick_free((void *)type_info);
126
125
  RB_GC_GUARD(ary);
@@ -138,7 +137,7 @@ Magick_fonts(VALUE class)
138
137
  * - "R" is "r" if ImageMagick can read that format, or "-" otherwise.
139
138
  * - "W" is "w" if ImageMagick can write that format, or "-" otherwise.
140
139
  * - "A" is "+" if the format supports multi-image files, or "-" otherwise.
141
- *
140
+ *
142
141
  * No Ruby usage (internal function)
143
142
  *
144
143
  * @param magick_info a MagickInfo object.
@@ -162,21 +161,13 @@ MagickInfo_to_format(const MagickInfo *magick_info)
162
161
  * Build the @@formats hash. The hash keys are image formats. The hash values
163
162
  * specify the format "mode string", i.e. a description of what ImageMagick can
164
163
  * do with that format. The mode string is in the form "BRWA", where
165
- * - "B" is "*" if the format has native blob support, or " " otherwise.
166
- * - "R" is "r" if ImageMagick can read that format, or "-" otherwise.
167
- * - "W" is "w" if ImageMagick can write that format, or "-" otherwise.
168
- * - "A" is "+" if the format supports multi-image files, or "-" otherwise.
169
- *
170
- * Ruby usage:
171
- * - @verbatim Magick.init_formats @endverbatim
172
164
  *
173
- * Notes:
174
- * - Only called once.
175
- * - There are 3 implementations.
165
+ * - "B" is "*" if the format has native blob support, or " " otherwise.
166
+ * - "R" is "r" if ImageMagick can read that format, or "-" otherwise.
167
+ * - "W" is "w" if ImageMagick can write that format, or "-" otherwise.
168
+ * - "A" is "+" if the format supports multi-image files, or "-" otherwise.
176
169
  *
177
- * @param class the class on which the method is run.
178
- * @return the formats hash.
179
- * @see MagickInfo_to_format
170
+ * @return [Hash] the formats hash.
180
171
  */
181
172
  VALUE
182
173
  Magick_init_formats(VALUE class ATTRIBUTE_UNUSED)
@@ -191,15 +182,15 @@ Magick_init_formats(VALUE class ATTRIBUTE_UNUSED)
191
182
  // IM 6.1.3 added an exception argument to GetMagickInfoList
192
183
  exception = AcquireExceptionInfo();
193
184
  magick_info = GetMagickInfoList("*", &number_formats, exception);
194
- CHECK_EXCEPTION()
195
- (void) DestroyExceptionInfo(exception);
185
+ CHECK_EXCEPTION();
186
+ DestroyExceptionInfo(exception);
196
187
 
197
188
 
198
189
  for (x = 0; x < number_formats; x++)
199
190
  {
200
- (void) rb_hash_aset(formats
201
- , rb_str_new2(magick_info[x]->name)
202
- , MagickInfo_to_format((const MagickInfo *)magick_info[x]));
191
+ rb_hash_aset(formats,
192
+ rb_str_new2(magick_info[x]->name),
193
+ MagickInfo_to_format((const MagickInfo *)magick_info[x]));
203
194
  }
204
195
  magick_free((void *)magick_info);
205
196
  RB_GC_GUARD(formats);
@@ -211,14 +202,16 @@ Magick_init_formats(VALUE class ATTRIBUTE_UNUSED)
211
202
  * Get/set resource limits. If a limit is specified the old limit is set to the
212
203
  * new value. Either way the current/old limit is returned.
213
204
  *
214
- * Ruby usage:
215
- * - @verbatim Magick.limit_resource(resource) @endverbatim
216
- * - @verbatim Magick.limit_resource(resource, limit) @endverbatim
205
+ * @overload limit_resource(resource)
206
+ * Get resource limits.
207
+ * @param resource [String, Symbol] the type of resource
217
208
  *
218
- * @param argc number of input arguments.
219
- * @param argv array of input arguments.
220
- * @param class the class on which the method is run.
221
- * @return the current/old limit.
209
+ * @overload limit_resource(resource, limit)
210
+ * Set resource limits.
211
+ * @param resource [String, Symbol] the type of resource
212
+ * @param limit [Numeric] the new limit number
213
+ *
214
+ * @return [Numeric] the old limit.
222
215
  */
223
216
  VALUE
224
217
  Magick_limit_resource(int argc, VALUE *argv, VALUE class)
@@ -269,7 +262,7 @@ Magick_limit_resource(int argc, VALUE *argv, VALUE class)
269
262
  break;
270
263
 
271
264
  default:
272
- str = StringValuePtr(resource);
265
+ str = StringValueCStr(resource);
273
266
  if (*str == '\0')
274
267
  {
275
268
  return class;
@@ -311,7 +304,7 @@ Magick_limit_resource(int argc, VALUE *argv, VALUE class)
311
304
 
312
305
  if (argc > 1)
313
306
  {
314
- (void) SetMagickResourceLimit(res, (MagickSizeType)NUM2ULONG(limit));
307
+ SetMagickResourceLimit(res, (MagickSizeType)NUM2ULONG(limit));
315
308
  }
316
309
 
317
310
  RB_GC_GUARD(limit);
@@ -325,22 +318,14 @@ Magick_limit_resource(int argc, VALUE *argv, VALUE class)
325
318
  * threshold is exceeded, all subsequent pixels cache operations are to/from
326
319
  * disk.
327
320
  *
328
- * Ruby usage:
329
- * - @verbatim Magick.set_cache_threshold(megabytes) @endverbatim
330
- *
331
- * Notes:
332
- * - singleton method
333
- *
334
- * @param class the class on which the method is run.
335
- * @param threshold the number of megabytes to set.
336
- * @return the class.
321
+ * @param threshold [Numeric] the number of megabytes to set.
337
322
  */
338
323
  VALUE
339
324
  Magick_set_cache_threshold(VALUE class, VALUE threshold)
340
325
  {
341
326
  unsigned long thrshld = NUM2ULONG(threshold);
342
- (void) SetMagickResourceLimit(MemoryResource, (MagickSizeType)thrshld);
343
- (void) SetMagickResourceLimit(MapResource, (MagickSizeType)(2*thrshld));
327
+ SetMagickResourceLimit(MemoryResource, (MagickSizeType)thrshld);
328
+ SetMagickResourceLimit(MapResource, (MagickSizeType)(2*thrshld));
344
329
  return class;
345
330
  }
346
331
 
@@ -348,32 +333,25 @@ Magick_set_cache_threshold(VALUE class, VALUE threshold)
348
333
  /**
349
334
  * Set the log event mask.
350
335
  *
351
- * Ruby usage:
352
- * - @verbatim Magick.set_log_event_mask(event) @endverbatim
353
- * - @verbatim Magick.set_log_event_mask(event,...) @endverbatim
336
+ * The arguments are one of:
354
337
  *
355
- * Notes:
356
- * - "event" is one of
357
- * - "all"
358
- * - "annotate"
359
- * - "blob"
360
- * - "cache"
361
- * - "coder"
362
- * - "configure"
363
- * - "deprecate"
364
- * - "locale"
365
- * - "none"
366
- * - "render"
367
- * - "transform"
368
- * - "user"
369
- * - "x11"
370
- * - Multiple events can be specified.
371
- * - Event names may be capitalized.
338
+ * - "all"
339
+ * - "annotate"
340
+ * - "blob"
341
+ * - "cache"
342
+ * - "coder"
343
+ * - "configure"
344
+ * - "deprecate"
345
+ * - "locale"
346
+ * - "none"
347
+ * - "render"
348
+ * - "transform"
349
+ * - "user"
350
+ * - "x11"
372
351
  *
373
- * @param argc number of input arguments.
374
- * @param argv array of input arguments.
375
- * @param class the class on which the method is run.
376
- * @return the class.
352
+ * Multiple events can be specified as the aruments. Event names may be capitalized.
353
+ *
354
+ * @param args [String] the mask of log event.
377
355
  */
378
356
  VALUE
379
357
  Magick_set_log_event_mask(int argc, VALUE *argv, VALUE class)
@@ -386,38 +364,33 @@ Magick_set_log_event_mask(int argc, VALUE *argv, VALUE class)
386
364
  }
387
365
  for (x = 0; x < argc; x++)
388
366
  {
389
- (void) SetLogEventMask(StringValuePtr(argv[x]));
367
+ SetLogEventMask(StringValueCStr(argv[x]));
390
368
  }
391
369
  return class;
392
370
  }
393
371
 
394
372
  /**
395
373
  * Set the format for log messages.
396
- *
397
- * Ruby usage:
398
- * - @verbatim Magick.set_log_format(format) @endverbatim
399
374
  *
400
- * Notes:
401
- * - Format is a string containing one or more of:
402
- * - %t - current time
403
- * - %r - elapsed time
404
- * - %u - user time
405
- * - %p - pid
406
- * - %m - module (source file name)
407
- * - %f - function name
408
- * - %l - line number
409
- * - %d - event domain (one of the events listed above)
410
- * - %e - event name
411
- * - Plus other characters, including \\n, etc.
375
+ * Format is a string containing one or more of:
376
+ *
377
+ * - %t - current time
378
+ * - %r - elapsed time
379
+ * - %u - user time
380
+ * - %p - pid
381
+ * - %m - module (source file name)
382
+ * - %f - function name
383
+ * - %l - line number
384
+ * - %d - event domain (one of the events listed above)
385
+ * - %e - event name
386
+ * - Plus other characters, including \\n, etc.
412
387
  *
413
- * @param class the class on which the method is run.
414
- * @param format the format to set.
415
- * @return the class.
388
+ * @param format [String] the format to set.
416
389
  */
417
390
  VALUE
418
391
  Magick_set_log_format(VALUE class, VALUE format)
419
392
  {
420
- SetLogFormat(StringValuePtr(format));
393
+ SetLogFormat(StringValueCStr(format));
421
394
  return class;
422
395
  }
423
396