PageRenderTime 99ms CodeModel.GetById 21ms RepoModel.GetById 0ms app.codeStats 2ms

/plugins/ImageMagick-6.3.2/wand/mogrify.c

https://bitbucket.org/sisko/operation-caribou
C | 6683 lines | 5890 code | 235 blank | 558 comment | 2356 complexity | 86a449ee3127915f3d6a0808fc5a0ece MD5 | raw file
Possible License(s): MPL-2.0-no-copyleft-exception, LGPL-2.1
  1. /*
  2. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  3. % %
  4. % %
  5. % %
  6. % M M OOO GGGGG RRRR IIIII FFFFF Y Y %
  7. % MM MM O O G R R I F Y Y %
  8. % M M M O O G GGG RRRR I FFF Y %
  9. % M M O O G G R R I F Y %
  10. % M M OOO GGGG R R IIIII F Y %
  11. % %
  12. % %
  13. % ImageMagick Module Methods %
  14. % %
  15. % Software Design %
  16. % John Cristy %
  17. % March 2000 %
  18. % %
  19. % %
  20. % Copyright 1999-2006 ImageMagick Studio LLC, a non-profit organization %
  21. % dedicated to making software imaging solutions freely available. %
  22. % %
  23. % You may not use this file except in compliance with the License. You may %
  24. % obtain a copy of the License at %
  25. % %
  26. % http://www.imagemagick.org/script/license.php %
  27. % %
  28. % Unless required by applicable law or agreed to in writing, software %
  29. % distributed under the License is distributed on an "AS IS" BASIS, %
  30. % WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. %
  31. % See the License for the specific language governing permissions and %
  32. % limitations under the License. %
  33. % %
  34. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  35. %
  36. %
  37. %
  38. */
  39. /*
  40. Include declarations.
  41. */
  42. #include "wand/studio.h"
  43. #include "wand/MagickWand.h"
  44. #include "wand/mogrify-private.h"
  45. /*
  46. Define declarations.
  47. */
  48. #define ThrowWandFatalException(severity,tag,context) \
  49. { \
  50. ExceptionInfo \
  51. exception; \
  52. \
  53. GetExceptionInfo(&exception); \
  54. (void) ThrowMagickException(&exception,GetMagickModule(),severity,tag, \
  55. "`%s'",context); \
  56. CatchException(&exception); \
  57. (void) DestroyExceptionInfo(&exception); \
  58. }
  59. #define UndefinedCompressionQuality 0UL
  60. /*
  61. Constant declaration.
  62. */
  63. static const char
  64. *BackgroundColor = "#fff", /* white */
  65. *BorderColor = "#dfdfdf", /* gray */
  66. *MatteColor = "#bdbdbd"; /* gray */
  67. /*
  68. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  69. % %
  70. % %
  71. % %
  72. + M o g r i f y I m a g e %
  73. % %
  74. % %
  75. % %
  76. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  77. %
  78. % MogrifyImage() applies image processing options to an image as prescribed
  79. % by command line options.
  80. %
  81. % The format of the MogrifyImage method is:
  82. %
  83. % MagickBooleanType MogrifyImage(ImageInfo *image_info,const int argc,
  84. % const char **argv,Image **image)
  85. %
  86. % A description of each parameter follows:
  87. %
  88. % o image_info: The image info..
  89. %
  90. % o argc: Specifies a pointer to an integer describing the number of
  91. % elements in the argument vector.
  92. %
  93. % o argv: Specifies a pointer to a text array containing the command line
  94. % arguments.
  95. %
  96. % o image: The image.
  97. %
  98. % o exception: Return any errors or warnings in this structure.
  99. %
  100. */
  101. static inline long MagickMax(const long x,const long y)
  102. {
  103. if (x > y)
  104. return(x);
  105. return(y);
  106. }
  107. static MagickBooleanType MonitorProgress(const char *tag,
  108. const MagickOffsetType quantum,const MagickSizeType span,
  109. void *wand_unused(client_data))
  110. {
  111. char
  112. message[MaxTextExtent];
  113. const char
  114. *locale_message;
  115. if (span < 2)
  116. return(MagickTrue);
  117. (void) FormatMagickString(message,MaxTextExtent,"Monitor/%s",tag);
  118. locale_message=GetLocaleMessage(message);
  119. if (locale_message == message)
  120. locale_message=tag;
  121. (void) fprintf(stdout,"%s: %02ld%%\r",locale_message,(long)
  122. (100L*quantum/(span-1)));
  123. if ((MagickSizeType) quantum == (span-1))
  124. (void) fprintf(stdout,"\n");
  125. (void) fflush(stdout);
  126. return(MagickTrue);
  127. }
  128. WandExport MagickBooleanType MogrifyImage(ImageInfo *image_info,const int argc,
  129. const char **argv,Image **image,ExceptionInfo *exception)
  130. {
  131. ChannelType
  132. channel;
  133. const char
  134. *format,
  135. *option;
  136. DrawInfo
  137. *draw_info;
  138. GeometryInfo
  139. geometry_info;
  140. Image
  141. *region_image;
  142. long
  143. count;
  144. MagickBooleanType
  145. status;
  146. MagickPixelPacket
  147. fill;
  148. MagickStatusType
  149. flags;
  150. QuantizeInfo
  151. *quantize_info;
  152. RectangleInfo
  153. geometry,
  154. region_geometry;
  155. register long
  156. i;
  157. /*
  158. Initialize method variables.
  159. */
  160. assert(image_info != (const ImageInfo *) NULL);
  161. assert(image_info->signature == MagickSignature);
  162. assert(image != (Image **) NULL);
  163. assert((*image)->signature == MagickSignature);
  164. if ((*image)->debug != MagickFalse)
  165. (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",(*image)->filename);
  166. if (argc < 0)
  167. return(MagickTrue);
  168. for (i=0; i < (long) argc; i++)
  169. if (strlen(argv[i]) > (MaxTextExtent/2-1))
  170. ThrowWandFatalException(OptionFatalError,"OptionLengthExceedsLimit",
  171. argv[i]);
  172. draw_info=CloneDrawInfo(image_info,(DrawInfo *) NULL);
  173. quantize_info=AcquireQuantizeInfo(image_info);
  174. SetGeometryInfo(&geometry_info);
  175. channel=image_info->channel;
  176. GetMagickPixelPacket(*image,&fill);
  177. SetMagickPixelPacket(&(*image)->background_color,(IndexPacket *) NULL,&fill);
  178. format=GetImageOption(image_info,"format");
  179. SetGeometry(*image,&region_geometry);
  180. region_image=NewImageList();
  181. /*
  182. Transmogrify the image.
  183. */
  184. for (i=0; i < (long) argc; i++)
  185. {
  186. option=argv[i];
  187. if (IsMagickOption(option) == MagickFalse)
  188. continue;
  189. count=MagickMax(ParseMagickOption(MagickCommandOptions,MagickFalse,option),
  190. 0L);
  191. if ((i+count) >= argc)
  192. break;
  193. status=MogrifyImageInfo(image_info,count+1,argv+i,exception);
  194. switch (*(option+1))
  195. {
  196. case 'a':
  197. {
  198. if (LocaleCompare("adaptive-blur",option+1) == 0)
  199. {
  200. Image
  201. *blur_image;
  202. /*
  203. Blur image.
  204. */
  205. flags=ParseGeometry(argv[i+1],&geometry_info);
  206. if ((flags & SigmaValue) == 0)
  207. geometry_info.sigma=1.0;
  208. blur_image=AdaptiveBlurImageChannel(*image,channel,
  209. geometry_info.rho,geometry_info.sigma,exception);
  210. if (blur_image == (Image *) NULL)
  211. break;
  212. InheritException(&blur_image->exception,exception);
  213. *image=DestroyImage(*image);
  214. *image=blur_image;
  215. break;
  216. }
  217. if (LocaleCompare("adaptive-resize",option+1) == 0)
  218. {
  219. Image
  220. *resize_image;
  221. /*
  222. Resize image.
  223. */
  224. (void) ParseSizeGeometry(*image,argv[i+1],&geometry);
  225. resize_image=AdaptiveResizeImage(*image,geometry.width,
  226. geometry.height,exception);
  227. if (resize_image == (Image *) NULL)
  228. break;
  229. InheritException(&resize_image->exception,exception);
  230. *image=DestroyImage(*image);
  231. *image=resize_image;
  232. break;
  233. }
  234. if (LocaleCompare("adaptive-sharpen",option+1) == 0)
  235. {
  236. Image
  237. *sharp_image;
  238. /*
  239. Sharpen image.
  240. */
  241. flags=ParseGeometry(argv[i+1],&geometry_info);
  242. if ((flags & SigmaValue) == 0)
  243. geometry_info.sigma=1.0;
  244. sharp_image=AdaptiveSharpenImageChannel(*image,channel,
  245. geometry_info.rho,geometry_info.sigma,exception);
  246. if (sharp_image == (Image *) NULL)
  247. break;
  248. InheritException(&sharp_image->exception,exception);
  249. *image=DestroyImage(*image);
  250. *image=sharp_image;
  251. break;
  252. }
  253. if (LocaleCompare("affine",option+1) == 0)
  254. {
  255. /*
  256. Affine matrix.
  257. */
  258. if (*option == '+')
  259. {
  260. GetAffineMatrix(&draw_info->affine);
  261. break;
  262. }
  263. (void) ParseAffineGeometry(argv[i+1],&draw_info->affine);
  264. break;
  265. }
  266. if (LocaleCompare("annotate",option+1) == 0)
  267. {
  268. char
  269. geometry[MaxTextExtent];
  270. /*
  271. Annotate image.
  272. */
  273. SetGeometryInfo(&geometry_info);
  274. flags=ParseGeometry(argv[i+1],&geometry_info);
  275. if ((flags & SigmaValue) == 0)
  276. geometry_info.sigma=geometry_info.rho;
  277. (void) CloneString(&draw_info->text,InterpretImageProperties(
  278. image_info,*image,argv[i+2]));
  279. (void) FormatMagickString(geometry,MaxTextExtent,"%+f%+f",
  280. geometry_info.xi,geometry_info.psi);
  281. (void) CloneString(&draw_info->geometry,geometry);
  282. draw_info->affine.sx=cos(DegreesToRadians(
  283. fmod(geometry_info.rho,360.0)));
  284. draw_info->affine.rx=sin(DegreesToRadians(
  285. fmod(geometry_info.rho,360.0)));
  286. draw_info->affine.ry=(-sin(DegreesToRadians(
  287. fmod(geometry_info.sigma,360.0))));
  288. draw_info->affine.sy=cos(DegreesToRadians(
  289. fmod(geometry_info.sigma,360.0)));
  290. (void) AnnotateImage(*image,draw_info);
  291. break;
  292. }
  293. if (LocaleCompare("antialias",option+1) == 0)
  294. {
  295. draw_info->stroke_antialias=(*option == '-') ? MagickTrue :
  296. MagickFalse;
  297. draw_info->text_antialias=(*option == '-') ? MagickTrue :
  298. MagickFalse;
  299. break;
  300. }
  301. if (LocaleCompare("auto-orient",option+1) == 0)
  302. {
  303. Image
  304. *orient_image;
  305. orient_image=NewImageList();
  306. switch ((*image)->orientation)
  307. {
  308. case TopRightOrientation:
  309. {
  310. orient_image=FlopImage(*image,exception);
  311. break;
  312. }
  313. case BottomRightOrientation:
  314. {
  315. orient_image=RotateImage(*image,180.0,exception);
  316. break;
  317. }
  318. case BottomLeftOrientation:
  319. {
  320. orient_image=FlipImage(*image,exception);
  321. break;
  322. }
  323. case LeftTopOrientation:
  324. {
  325. orient_image=TransposeImage(*image,exception);
  326. break;
  327. }
  328. case RightTopOrientation:
  329. {
  330. orient_image=RotateImage(*image,90.0,exception);
  331. break;
  332. }
  333. case RightBottomOrientation:
  334. {
  335. orient_image=TransverseImage(*image,exception);
  336. break;
  337. }
  338. case LeftBottomOrientation:
  339. {
  340. orient_image=RotateImage(*image,270.0,exception);
  341. break;
  342. }
  343. default:
  344. break;
  345. }
  346. if (orient_image == (Image *) NULL)
  347. break;
  348. InheritException(&orient_image->exception,exception);
  349. *image=DestroyImage(*image);
  350. *image=orient_image;
  351. break;
  352. }
  353. break;
  354. }
  355. case 'b':
  356. {
  357. if (LocaleCompare("background",option+1) == 0)
  358. {
  359. if (*option == '+')
  360. {
  361. (void) QueryColorDatabase(BackgroundColor,
  362. &(*image)->background_color,exception);
  363. break;
  364. }
  365. (void) QueryColorDatabase(argv[i+1],&(*image)->background_color,
  366. exception);
  367. break;
  368. }
  369. if (LocaleCompare("bias",option+1) == 0)
  370. {
  371. (*image)->bias=StringToDouble(argv[i+1],QuantumRange);
  372. break;
  373. }
  374. if (LocaleCompare("black-threshold",option+1) == 0)
  375. {
  376. /*
  377. Threshold black image.
  378. */
  379. (void) BlackThresholdImage(*image,argv[i+1]);
  380. break;
  381. }
  382. if (LocaleCompare("black-point-compensation",option+1) == 0)
  383. {
  384. (*image)->black_point_compensation=(*option == '-') ? MagickTrue :
  385. MagickFalse;
  386. break;
  387. }
  388. if (LocaleCompare("blue-primary",option+1) == 0)
  389. {
  390. /*
  391. Blue chromaticity primary point.
  392. */
  393. if (*option == '+')
  394. {
  395. (*image)->chromaticity.blue_primary.x=0.0;
  396. (*image)->chromaticity.blue_primary.y=0.0;
  397. break;
  398. }
  399. flags=ParseGeometry(argv[i+1],&geometry_info);
  400. (*image)->chromaticity.blue_primary.x=geometry_info.rho;
  401. (*image)->chromaticity.blue_primary.y=geometry_info.sigma;
  402. if ((flags & SigmaValue) == 0)
  403. (*image)->chromaticity.blue_primary.y=
  404. (*image)->chromaticity.blue_primary.x;
  405. break;
  406. }
  407. if (LocaleCompare("blur",option+1) == 0)
  408. {
  409. Image
  410. *blur_image;
  411. /*
  412. Gaussian blur image.
  413. */
  414. flags=ParseGeometry(argv[i+1],&geometry_info);
  415. if ((flags & SigmaValue) == 0)
  416. geometry_info.sigma=1.0;
  417. blur_image=BlurImageChannel(*image,channel,
  418. geometry_info.rho,geometry_info.sigma,exception);
  419. if (blur_image == (Image *) NULL)
  420. break;
  421. InheritException(&blur_image->exception,exception);
  422. *image=DestroyImage(*image);
  423. *image=blur_image;
  424. break;
  425. }
  426. if (LocaleCompare("border",option+1) == 0)
  427. {
  428. Image
  429. *border_image;
  430. /*
  431. Surround image with a border of solid color.
  432. */
  433. flags=ParsePageGeometry(*image,argv[i+1],&geometry);
  434. if ((flags & SigmaValue) == 0)
  435. geometry.height=geometry.width;
  436. border_image=BorderImage(*image,&geometry,exception);
  437. if (border_image == (Image *) NULL)
  438. break;
  439. InheritException(&border_image->exception,exception);
  440. *image=DestroyImage(*image);
  441. *image=border_image;
  442. break;
  443. }
  444. if (LocaleCompare("bordercolor",option+1) == 0)
  445. {
  446. if (*option == '+')
  447. {
  448. (void) QueryColorDatabase(BorderColor,&(*image)->border_color,
  449. exception);
  450. draw_info->border_color=(*image)->border_color;
  451. break;
  452. }
  453. (void) QueryColorDatabase(argv[i+1],&(*image)->border_color,
  454. exception);
  455. draw_info->border_color=(*image)->border_color;
  456. break;
  457. }
  458. if (LocaleCompare("box",option+1) == 0)
  459. {
  460. (void) QueryColorDatabase(argv[i+1],&draw_info->undercolor,
  461. exception);
  462. break;
  463. }
  464. break;
  465. }
  466. case 'c':
  467. {
  468. if (LocaleCompare("cache",option+1) == 0)
  469. {
  470. unsigned long
  471. limit;
  472. limit=(~0UL);
  473. if (LocaleCompare("unlimited",argv[i+1]) != 0)
  474. limit=(unsigned long) atol(argv[i+1]);
  475. (void) SetMagickResourceLimit(MemoryResource,limit);
  476. (void) SetMagickResourceLimit(MapResource,2*limit);
  477. break;
  478. }
  479. if (LocaleCompare("channel",option+1) == 0)
  480. {
  481. if (*option == '+')
  482. {
  483. channel=DefaultChannels;
  484. break;
  485. }
  486. channel=(ChannelType) ParseChannelOption(argv[i+1]);
  487. break;
  488. }
  489. if (LocaleCompare("charcoal",option+1) == 0)
  490. {
  491. Image
  492. *charcoal_image;
  493. /*
  494. Charcoal image.
  495. */
  496. flags=ParseGeometry(argv[i+1],&geometry_info);
  497. if ((flags & SigmaValue) == 0)
  498. geometry_info.sigma=1.0;
  499. charcoal_image=CharcoalImage(*image,geometry_info.rho,
  500. geometry_info.sigma,exception);
  501. if (charcoal_image == (Image *) NULL)
  502. break;
  503. InheritException(&charcoal_image->exception,exception);
  504. *image=DestroyImage(*image);
  505. *image=charcoal_image;
  506. break;
  507. }
  508. if (LocaleCompare("chop",option+1) == 0)
  509. {
  510. Image
  511. *chop_image;
  512. /*
  513. Chop the image.
  514. */
  515. (void) ParseGravityGeometry(*image,argv[i+1],&geometry);
  516. chop_image=ChopImage(*image,&geometry,exception);
  517. if (chop_image == (Image *) NULL)
  518. break;
  519. InheritException(&chop_image->exception,exception);
  520. *image=DestroyImage(*image);
  521. *image=chop_image;
  522. break;
  523. }
  524. if (LocaleCompare("clip",option+1) == 0)
  525. {
  526. if (*option == '+')
  527. {
  528. (void) SetImageClipMask(*image,(Image *) NULL);
  529. break;
  530. }
  531. (void) ClipImage(*image);
  532. break;
  533. }
  534. if (LocaleCompare("clip-mask",option+1) == 0)
  535. {
  536. Image
  537. *mask;
  538. ImageInfo
  539. *mask_info;
  540. long
  541. y;
  542. register long
  543. x;
  544. register PixelPacket
  545. *q;
  546. if (*option == '+')
  547. {
  548. /*
  549. Remove a mask.
  550. */
  551. (void) SetImageMask(*image,(Image *) NULL);
  552. break;
  553. }
  554. /*
  555. Set the image mask.
  556. */
  557. mask_info=CloneImageInfo(image_info);
  558. (void) CopyMagickString(mask_info->filename,argv[i+1],
  559. MaxTextExtent);
  560. mask=ReadImage(mask_info,exception);
  561. CatchException(exception);
  562. mask_info=DestroyImageInfo(mask_info);
  563. if (mask == (Image *) NULL)
  564. break;
  565. for (y=0; y < (long) mask->rows; y++)
  566. {
  567. q=GetImagePixels(mask,0,y,mask->columns,1);
  568. if (q == (PixelPacket *) NULL)
  569. break;
  570. for (x=0; x < (long) mask->columns; x++)
  571. {
  572. if (mask->matte == MagickFalse)
  573. q->opacity=PixelIntensityToQuantum(q);
  574. q->red=q->opacity;
  575. q->green=q->opacity;
  576. q->blue=q->opacity;
  577. q++;
  578. }
  579. if (SyncImagePixels(mask) == MagickFalse)
  580. break;
  581. }
  582. if (SetImageStorageClass(mask,DirectClass) == MagickFalse)
  583. return(MagickFalse);
  584. mask->matte=MagickTrue;
  585. (void) SetImageClipMask(*image,mask);
  586. break;
  587. }
  588. if (LocaleCompare("clip-path",option+1) == 0)
  589. {
  590. (void) ClipPathImage(*image,argv[i+1],
  591. *option == '-' ? MagickTrue : MagickFalse);
  592. break;
  593. }
  594. if (LocaleCompare("colorize",option+1) == 0)
  595. {
  596. Image
  597. *colorize_image;
  598. /*
  599. Colorize the image.
  600. */
  601. colorize_image=ColorizeImage(*image,argv[i+1],draw_info->fill,
  602. exception);
  603. if (colorize_image == (Image *) NULL)
  604. break;
  605. InheritException(&colorize_image->exception,exception);
  606. *image=DestroyImage(*image);
  607. *image=colorize_image;
  608. break;
  609. }
  610. if (LocaleCompare("colors",option+1) == 0)
  611. {
  612. /*
  613. Reduce the number of colors in the image.
  614. */
  615. quantize_info->number_colors=(unsigned long) atol(argv[i+1]);
  616. if (quantize_info->number_colors == 0)
  617. break;
  618. if (((*image)->storage_class == DirectClass) ||
  619. (*image)->colors > quantize_info->number_colors)
  620. (void) QuantizeImage(quantize_info,*image);
  621. else
  622. CompressImageColormap(*image);
  623. break;
  624. }
  625. if (LocaleCompare("colorspace",option+1) == 0)
  626. {
  627. ColorspaceType
  628. colorspace;
  629. if (*option == '+')
  630. {
  631. (void) SetImageColorspace(*image,RGBColorspace);
  632. break;
  633. }
  634. colorspace=(ColorspaceType) ParseMagickOption(
  635. MagickColorspaceOptions,MagickFalse,argv[i+1]);
  636. (void) SetImageColorspace(*image,colorspace);
  637. break;
  638. }
  639. if (LocaleCompare("compose",option+1) == 0)
  640. {
  641. if (*option == '+')
  642. {
  643. (*image)->compose=OverCompositeOp;
  644. break;
  645. }
  646. (*image)->compose=(CompositeOperator) ParseMagickOption(
  647. MagickCompositeOptions,MagickFalse,argv[i+1]);
  648. break;
  649. }
  650. if (LocaleCompare("compress",option+1) == 0)
  651. {
  652. if (*option == '+')
  653. {
  654. (*image)->compression=UndefinedCompression;
  655. break;
  656. }
  657. (*image)->compression=(CompressionType) ParseMagickOption(
  658. MagickCompressionOptions,MagickFalse,argv[i+1]);
  659. break;
  660. }
  661. if (LocaleCompare("contrast",option+1) == 0)
  662. {
  663. (void) ContrastImage(*image,(*option == '-') ? MagickTrue :
  664. MagickFalse);
  665. break;
  666. }
  667. if (LocaleCompare("contrast-stretch",option+1) == 0)
  668. {
  669. GeometryInfo
  670. geometry_info;
  671. MagickRealType
  672. black_point,
  673. white_point;
  674. MagickStatusType
  675. flags;
  676. /*
  677. Parse levels.
  678. */
  679. flags=ParseGeometry(argv[i+1],&geometry_info);
  680. black_point=geometry_info.rho;
  681. white_point=(MagickRealType) (*image)->columns*(*image)->rows;
  682. if ((flags & SigmaValue) != 0)
  683. white_point=geometry_info.sigma;
  684. if ((flags & PercentValue) != 0)
  685. {
  686. black_point*=(MagickRealType) (*image)->columns*
  687. (*image)->rows/100.0f;
  688. white_point*=(MagickRealType) (*image)->columns*
  689. (*image)->rows/100.0f;
  690. }
  691. if ((flags & SigmaValue) == 0)
  692. white_point=(MagickRealType) (*image)->columns*(*image)->rows-
  693. black_point;
  694. (void) ContrastStretchImageChannel(*image,channel,black_point,
  695. white_point);
  696. break;
  697. }
  698. if (LocaleCompare("convolve",option+1) == 0)
  699. {
  700. char
  701. *p,
  702. token[MaxTextExtent];
  703. double
  704. *kernel;
  705. Image
  706. *convolve_image;
  707. register long
  708. x;
  709. unsigned long
  710. order;
  711. /*
  712. Convolve image.
  713. */
  714. p=(char *) argv[i+1];
  715. for (x=0; *p != '\0'; x++)
  716. {
  717. GetMagickToken(p,&p,token);
  718. if (*token == ',')
  719. GetMagickToken(p,&p,token);
  720. }
  721. order=(unsigned long) sqrt((double) x+1.0);
  722. kernel=(double *) AcquireMagickMemory(order*order*sizeof(*kernel));
  723. if (kernel == (double *) NULL)
  724. ThrowWandFatalException(ResourceLimitFatalError,
  725. "MemoryAllocationFailed",(*image)->filename);
  726. p=(char *) argv[i+1];
  727. for (x=0; *p != '\0'; x++)
  728. {
  729. GetMagickToken(p,&p,token);
  730. if (*token == ',')
  731. GetMagickToken(p,&p,token);
  732. kernel[x]=atof(token);
  733. }
  734. for ( ; x < (long) (order*order); x++)
  735. kernel[x]=0.0;
  736. convolve_image=ConvolveImageChannel(*image,channel,order,kernel,
  737. exception);
  738. kernel=(double *) RelinquishMagickMemory(kernel);
  739. if (convolve_image == (Image *) NULL)
  740. break;
  741. InheritException(&convolve_image->exception,exception);
  742. *image=DestroyImage(*image);
  743. *image=convolve_image;
  744. break;
  745. }
  746. if (LocaleCompare("crop",option+1) == 0)
  747. {
  748. if (*option == '+')
  749. break;
  750. break;
  751. }
  752. if (LocaleCompare("cycle",option+1) == 0)
  753. {
  754. /*
  755. Cycle an image colormap.
  756. */
  757. (void) CycleColormapImage(*image,atoi(argv[i+1]));
  758. break;
  759. }
  760. break;
  761. }
  762. case 'd':
  763. {
  764. if (LocaleCompare("debug",option+1) == 0)
  765. {
  766. if (*option == '+')
  767. {
  768. (void) SetLogEventMask("none");
  769. break;
  770. }
  771. (void) SetLogEventMask(argv[i+1]);
  772. break;
  773. }
  774. if (LocaleCompare("density",option+1) == 0)
  775. {
  776. GeometryInfo
  777. geometry_info;
  778. /*
  779. Set image density.
  780. */
  781. (void) CloneString(&draw_info->density,argv[i+1]);
  782. flags=ParseGeometry(argv[i+1],&geometry_info);
  783. (*image)->x_resolution=geometry_info.rho;
  784. (*image)->y_resolution=geometry_info.sigma;
  785. if ((flags & SigmaValue) == 0)
  786. (*image)->y_resolution=(*image)->x_resolution;
  787. break;
  788. }
  789. if (LocaleCompare("despeckle",option+1) == 0)
  790. {
  791. Image
  792. *despeckle_image;
  793. /*
  794. Reduce the speckles within an image.
  795. */
  796. despeckle_image=DespeckleImage(*image,exception);
  797. if (despeckle_image == (Image *) NULL)
  798. break;
  799. InheritException(&despeckle_image->exception,exception);
  800. *image=DestroyImage(*image);
  801. *image=despeckle_image;
  802. break;
  803. }
  804. if (LocaleCompare("display",option+1) == 0)
  805. {
  806. (void) CloneString(&draw_info->server_name,argv[i+1]);
  807. break;
  808. }
  809. if (LocaleCompare("dither",option+1) == 0)
  810. {
  811. quantize_info->dither=(*option == '-') ? MagickTrue : MagickFalse;
  812. break;
  813. }
  814. if (LocaleCompare("draw",option+1) == 0)
  815. {
  816. /*
  817. Draw image.
  818. */
  819. (void) CloneString(&draw_info->primitive,argv[i+1]);
  820. (void) DrawImage(*image,draw_info);
  821. break;
  822. }
  823. break;
  824. }
  825. case 'e':
  826. {
  827. if (LocaleCompare("edge",option+1) == 0)
  828. {
  829. Image
  830. *edge_image;
  831. /*
  832. Enhance edges in the image.
  833. */
  834. flags=ParseGeometry(argv[i+1],&geometry_info);
  835. if ((flags & SigmaValue) == 0)
  836. geometry_info.sigma=1.0;
  837. edge_image=EdgeImage(*image,geometry_info.rho,exception);
  838. if (edge_image == (Image *) NULL)
  839. break;
  840. InheritException(&edge_image->exception,exception);
  841. *image=DestroyImage(*image);
  842. *image=edge_image;
  843. break;
  844. }
  845. if (LocaleCompare("emboss",option+1) == 0)
  846. {
  847. Image
  848. *emboss_image;
  849. /*
  850. Gaussian embossen image.
  851. */
  852. flags=ParseGeometry(argv[i+1],&geometry_info);
  853. if ((flags & SigmaValue) == 0)
  854. geometry_info.sigma=1.0;
  855. emboss_image=EmbossImage(*image,geometry_info.rho,
  856. geometry_info.sigma,exception);
  857. if (emboss_image == (Image *) NULL)
  858. break;
  859. InheritException(&emboss_image->exception,exception);
  860. *image=DestroyImage(*image);
  861. *image=emboss_image;
  862. break;
  863. }
  864. if (LocaleCompare("encoding",option+1) == 0)
  865. {
  866. (void) CloneString(&draw_info->encoding,argv[i+1]);
  867. break;
  868. }
  869. if (LocaleCompare("endian",option+1) == 0)
  870. {
  871. if (*option == '+')
  872. {
  873. (*image)->endian=LSBEndian;
  874. break;
  875. }
  876. (*image)->endian=(EndianType) ParseMagickOption(MagickEndianOptions,
  877. MagickFalse,argv[i+1]);
  878. break;
  879. }
  880. if (LocaleCompare("enhance",option+1) == 0)
  881. {
  882. Image
  883. *enhance_image;
  884. /*
  885. Enhance image.
  886. */
  887. enhance_image=EnhanceImage(*image,exception);
  888. if (enhance_image == (Image *) NULL)
  889. break;
  890. InheritException(&enhance_image->exception,exception);
  891. *image=DestroyImage(*image);
  892. *image=enhance_image;
  893. break;
  894. }
  895. if (LocaleCompare("equalize",option+1) == 0)
  896. {
  897. /*
  898. Equalize image.
  899. */
  900. (void) EqualizeImage(*image);
  901. break;
  902. }
  903. if (LocaleCompare("evaluate",option+1) == 0)
  904. {
  905. double
  906. constant;
  907. MagickEvaluateOperator
  908. op;
  909. op=(MagickEvaluateOperator) ParseMagickOption(MagickEvaluateOptions,
  910. MagickFalse,argv[i+1]);
  911. constant=StringToDouble(argv[i+2],QuantumRange);
  912. (void) EvaluateImageChannel(*image,channel,op,constant,
  913. exception);
  914. break;
  915. }
  916. if (LocaleCompare("extent",option+1) == 0)
  917. {
  918. Image
  919. *extent_image;
  920. /*
  921. Set the image extent.
  922. */
  923. (void) ParseGravityGeometry(*image,argv[i+1],&geometry);
  924. extent_image=ExtentImage(*image,&geometry,exception);
  925. if (extent_image == (Image *) NULL)
  926. break;
  927. InheritException(&extent_image->exception,exception);
  928. *image=DestroyImage(*image);
  929. *image=extent_image;
  930. break;
  931. }
  932. break;
  933. }
  934. case 'f':
  935. {
  936. if (LocaleCompare("family",option+1) == 0)
  937. {
  938. if (*option == '+')
  939. draw_info->family=(char *) RelinquishMagickMemory(
  940. draw_info->family);
  941. else
  942. (void) CloneString(&draw_info->family,argv[i+1]);
  943. break;
  944. }
  945. if (LocaleCompare("fill",option+1) == 0)
  946. {
  947. ExceptionInfo
  948. *sans;
  949. if (*option == '+')
  950. {
  951. (void) QueryMagickColor("none",&fill,exception);
  952. (void) QueryColorDatabase("none",&draw_info->fill,exception);
  953. break;
  954. }
  955. sans=AcquireExceptionInfo();
  956. (void) QueryMagickColor(argv[i+1],&fill,sans);
  957. status=QueryColorDatabase(argv[i+1],&draw_info->fill,sans);
  958. sans=DestroyExceptionInfo(sans);
  959. if (status == MagickFalse)
  960. draw_info->fill_pattern=ReadImage(image_info,exception);
  961. break;
  962. }
  963. if (LocaleCompare("filter",option+1) == 0)
  964. {
  965. if (*option == '+')
  966. {
  967. (*image)->filter=UndefinedFilter;
  968. break;
  969. }
  970. (*image)->filter=(FilterTypes) ParseMagickOption(
  971. MagickFilterOptions,MagickFalse,argv[i+1]);
  972. break;
  973. }
  974. if (LocaleCompare("flip",option+1) == 0)
  975. {
  976. Image
  977. *flip_image;
  978. /*
  979. Flip image scanlines.
  980. */
  981. flip_image=FlipImage(*image,exception);
  982. if (flip_image == (Image *) NULL)
  983. break;
  984. InheritException(&flip_image->exception,exception);
  985. *image=DestroyImage(*image);
  986. *image=flip_image;
  987. break;
  988. }
  989. if (LocaleCompare("flop",option+1) == 0)
  990. {
  991. Image
  992. *flop_image;
  993. /*
  994. Flop image scanlines.
  995. */
  996. flop_image=FlopImage(*image,exception);
  997. if (flop_image == (Image *) NULL)
  998. break;
  999. InheritException(&flop_image->exception,exception);
  1000. *image=DestroyImage(*image);
  1001. *image=flop_image;
  1002. break;
  1003. }
  1004. if (LocaleCompare("floodfill",option+1) == 0)
  1005. {
  1006. PixelPacket
  1007. target;
  1008. /*
  1009. Floodfill image.
  1010. */
  1011. (void) ParsePageGeometry(*image,argv[i+1],&geometry);
  1012. (void) QueryColorDatabase(argv[i+2],&target,exception);
  1013. (void) ColorFloodfillImage(*image,draw_info,target,geometry.x,
  1014. geometry.y,FloodfillMethod);
  1015. break;
  1016. }
  1017. if (LocaleCompare("font",option+1) == 0)
  1018. {
  1019. if (*option == '+')
  1020. {
  1021. draw_info->font=(char *) RelinquishMagickMemory(
  1022. draw_info->font);
  1023. break;
  1024. }
  1025. (void) CloneString(&draw_info->font,argv[i+1]);
  1026. break;
  1027. }
  1028. if (LocaleCompare("format",option+1) == 0)
  1029. {
  1030. format=argv[i+1];
  1031. break;
  1032. }
  1033. if (LocaleCompare("frame",option+1) == 0)
  1034. {
  1035. FrameInfo
  1036. frame_info;
  1037. Image
  1038. *frame_image;
  1039. /*
  1040. Surround image with an ornamental border.
  1041. */
  1042. (void) ParsePageGeometry(*image,argv[i+1],&geometry);
  1043. frame_info.width=geometry.width;
  1044. frame_info.height=geometry.height;
  1045. frame_info.outer_bevel=geometry.x;
  1046. frame_info.inner_bevel=geometry.y;
  1047. frame_info.x=(long) frame_info.width;
  1048. frame_info.y=(long) frame_info.height;
  1049. frame_info.width=(*image)->columns+2*frame_info.width;
  1050. frame_info.height=(*image)->rows+2*frame_info.height;
  1051. frame_image=FrameImage(*image,&frame_info,exception);
  1052. if (frame_image == (Image *) NULL)
  1053. break;
  1054. InheritException(&frame_image->exception,exception);
  1055. *image=DestroyImage(*image);
  1056. *image=frame_image;
  1057. break;
  1058. }
  1059. if (LocaleCompare("fuzz",option+1) == 0)
  1060. {
  1061. if (*option == '+')
  1062. {
  1063. (*image)->fuzz=0.0;
  1064. break;
  1065. }
  1066. (*image)->fuzz=StringToDouble(argv[i+1],QuantumRange+1.0);
  1067. break;
  1068. }
  1069. break;
  1070. }
  1071. case 'g':
  1072. {
  1073. if (LocaleCompare("gamma",option+1) == 0)
  1074. {
  1075. if (*option == '+')
  1076. (*image)->gamma=atof(argv[i+1]);
  1077. else
  1078. {
  1079. if (strchr(argv[i+1],',') != (char *) NULL)
  1080. (void) GammaImage(*image,argv[i+1]);
  1081. else
  1082. (void) GammaImageChannel(*image,channel,
  1083. atof(argv[i+1]));
  1084. }
  1085. break;
  1086. }
  1087. if ((LocaleCompare("gaussian-blur",option+1) == 0) ||
  1088. (LocaleCompare("gaussian",option+1) == 0))
  1089. {
  1090. Image
  1091. *gaussian_image;
  1092. /*
  1093. Gaussian blur image.
  1094. */
  1095. flags=ParseGeometry(argv[i+1],&geometry_info);
  1096. if ((flags & SigmaValue) == 0)
  1097. geometry_info.sigma=1.0;
  1098. gaussian_image=GaussianBlurImageChannel(*image,channel,
  1099. geometry_info.rho,geometry_info.sigma,exception);
  1100. if (gaussian_image == (Image *) NULL)
  1101. break;
  1102. InheritException(&gaussian_image->exception,exception);
  1103. *image=DestroyImage(*image);
  1104. *image=gaussian_image;
  1105. break;
  1106. }
  1107. if (LocaleCompare("geometry",option+1) == 0)
  1108. {
  1109. if (*option == '+')
  1110. {
  1111. if ((*image)->geometry != (char *) NULL)
  1112. (*image)->geometry=(char *) RelinquishMagickMemory(
  1113. (*image)->geometry);
  1114. break;
  1115. }
  1116. (void) CloneString(&(*image)->geometry,argv[i+1]);
  1117. flags=ParseSizeGeometry(*image,argv[i+1],&geometry);
  1118. if (((flags & XValue) == 0) && ((flags & YValue) == 0))
  1119. {
  1120. Image
  1121. *zoom_image;
  1122. /*
  1123. Resize image.
  1124. */
  1125. zoom_image=ZoomImage(*image,geometry.width,geometry.height,
  1126. exception);
  1127. if (zoom_image == (Image *) NULL)
  1128. break;
  1129. InheritException(&zoom_image->exception,exception);
  1130. *image=DestroyImage(*image);
  1131. *image=zoom_image;
  1132. }
  1133. break;
  1134. }
  1135. if (LocaleCompare("gravity",option+1) == 0)
  1136. {
  1137. if (*option == '+')
  1138. (*image)->gravity=UndefinedGravity;
  1139. else
  1140. (*image)->gravity=(GravityType) ParseMagickOption(
  1141. MagickGravityOptions,MagickFalse,argv[i+1]);
  1142. draw_info->gravity=(*image)->gravity;
  1143. break;
  1144. }
  1145. if (LocaleCompare("green-primary",option+1) == 0)
  1146. {
  1147. /*
  1148. Green chromaticity primary point.
  1149. */
  1150. if (*option == '+')
  1151. {
  1152. (*image)->chromaticity.green_primary.x=0.0;
  1153. (*image)->chromaticity.green_primary.y=0.0;
  1154. break;
  1155. }
  1156. flags=ParseGeometry(argv[i+1],&geometry_info);
  1157. (*image)->chromaticity.green_primary.x=geometry_info.rho;
  1158. (*image)->chromaticity.green_primary.y=geometry_info.sigma;
  1159. if ((flags & SigmaValue) == 0)
  1160. (*image)->chromaticity.green_primary.y=
  1161. (*image)->chromaticity.green_primary.x;
  1162. break;
  1163. }
  1164. break;
  1165. }
  1166. case 'i':
  1167. {
  1168. if (LocaleCompare("identify",option+1) == 0)
  1169. {
  1170. char
  1171. *text;
  1172. if (format == (char *) NULL)
  1173. {
  1174. (void) IdentifyImage(*image,stdout,image_info->verbose);
  1175. break;
  1176. }
  1177. text=InterpretImageProperties(image_info,*image,format);
  1178. if (text == (char *) NULL)
  1179. break;
  1180. (void) fputs(text,stdout);
  1181. (void) fputc('\n',stdout);
  1182. text=(char *) RelinquishMagickMemory(text);
  1183. break;
  1184. }
  1185. if (LocaleCompare("implode",option+1) == 0)
  1186. {
  1187. Image
  1188. *implode_image;
  1189. /*
  1190. Implode image.
  1191. */
  1192. (void) ParseGeometry(argv[i+1],&geometry_info);
  1193. implode_image=ImplodeImage(*image,geometry_info.rho,exception);
  1194. if (implode_image == (Image *) NULL)
  1195. break;
  1196. InheritException(&implode_image->exception,exception);
  1197. *image=DestroyImage(*image);
  1198. *image=implode_image;
  1199. break;
  1200. }
  1201. if (LocaleCompare("intent",option+1) == 0)
  1202. {
  1203. if (*option == '+')
  1204. {
  1205. (*image)->rendering_intent=UndefinedIntent;
  1206. break;
  1207. }
  1208. (*image)->rendering_intent=(RenderingIntent) ParseMagickOption(
  1209. MagickIntentOptions,MagickFalse,argv[i+1]);
  1210. break;
  1211. }
  1212. if (LocaleCompare("interlace",option+1) == 0)
  1213. {
  1214. /*
  1215. Interlace method.
  1216. */
  1217. if (*option == '+')
  1218. {
  1219. (*image)->interlace=UndefinedInterlace;
  1220. break;
  1221. }
  1222. (*image)->interlace=(InterlaceType) ParseMagickOption(
  1223. MagickInterlaceOptions,MagickFalse,argv[i+1]);
  1224. break;
  1225. }
  1226. if (LocaleCompare("interpolate",option+1) == 0)
  1227. {
  1228. /*
  1229. Interpolate method.
  1230. */
  1231. if (*option == '+')
  1232. {
  1233. (*image)->interpolate=UndefinedInterpolatePixel;
  1234. break;
  1235. }
  1236. (*image)->interpolate=(InterpolatePixelMethod) ParseMagickOption(
  1237. MagickInterpolateOptions,MagickFalse,argv[i+1]);
  1238. break;
  1239. }
  1240. break;
  1241. }
  1242. case 'l':
  1243. {
  1244. if (LocaleCompare("lat",option+1) == 0)
  1245. {
  1246. Image
  1247. *threshold_image;
  1248. /*
  1249. Local adaptive threshold image.
  1250. */
  1251. flags=ParseGeometry(argv[i+1],&geometry_info);
  1252. if ((flags & PercentValue) != 0)
  1253. geometry_info.xi=QuantumRange*geometry_info.xi/100.0;
  1254. threshold_image=AdaptiveThresholdImage(*image,(unsigned long)
  1255. geometry_info.rho,(unsigned long) geometry_info.sigma,
  1256. (long) geometry_info.xi,exception);
  1257. if (threshold_image == (Image *) NULL)
  1258. break;
  1259. InheritException(&threshold_image->exception,exception);
  1260. *image=DestroyImage(*image);
  1261. *image=threshold_image;
  1262. break;
  1263. }
  1264. if (LocaleCompare("level",option+1) == 0)
  1265. {
  1266. GeometryInfo
  1267. geometry_info;
  1268. MagickRealType
  1269. black_point,
  1270. gamma,
  1271. white_point;
  1272. MagickStatusType
  1273. flags;
  1274. /*
  1275. Parse levels.
  1276. */
  1277. flags=ParseGeometry(argv[i+1],&geometry_info);
  1278. black_point=geometry_info.rho;
  1279. white_point=(MagickRealType) QuantumRange;
  1280. if ((flags & SigmaValue) != 0)
  1281. white_point=geometry_info.sigma;
  1282. gamma=1.0;
  1283. if ((flags & XiValue) != 0)
  1284. gamma=geometry_info.xi;
  1285. if ((white_point <= 10.0) && (gamma > 10.0))
  1286. {
  1287. MagickRealType
  1288. swap;
  1289. swap=gamma;
  1290. gamma=white_point;
  1291. white_point=swap;
  1292. }
  1293. if ((flags & PercentValue) != 0)
  1294. {
  1295. black_point*=(MagickRealType) (QuantumRange/100.0);
  1296. white_point*=(MagickRealType) (QuantumRange/100.0);
  1297. }
  1298. if ((flags & SigmaValue) == 0)
  1299. white_point=(MagickRealType) QuantumRange-black_point;
  1300. (void) LevelImageChannel(*image,channel,black_point,white_point,
  1301. gamma);
  1302. break;
  1303. }
  1304. if (LocaleCompare("limit",option+1) == 0)
  1305. {
  1306. ResourceType
  1307. type;
  1308. unsigned long
  1309. limit;
  1310. if (*option == '+')
  1311. break;
  1312. type=(ResourceType) ParseMagickOption(MagickResourceOptions,
  1313. MagickFalse,argv[i+1]);
  1314. limit=(~0UL);
  1315. if (LocaleCompare("unlimited",argv[i+2]) != 0)
  1316. limit=(unsigned long) atol(argv[i+2]);
  1317. (void) SetMagickResourceLimit(type,limit);
  1318. break;
  1319. }
  1320. if (LocaleCompare("linear-stretch",option+1) == 0)
  1321. {
  1322. GeometryInfo
  1323. geometry_info;
  1324. MagickRealType
  1325. black_point,
  1326. white_point;
  1327. MagickStatusType
  1328. flags;
  1329. /*
  1330. Parse levels.
  1331. */
  1332. flags=ParseGeometry(argv[i+1],&geometry_info);
  1333. black_point=geometry_info.rho;
  1334. white_point=(MagickRealType) (*image)->columns*(*image)->rows;
  1335. if ((flags & SigmaValue) != 0)
  1336. white_point=geometry_info.sigma;
  1337. if ((flags & PercentValue) != 0)
  1338. {
  1339. black_point*=(MagickRealType) (*image)->columns*
  1340. (*image)->rows/100.0f;
  1341. white_point*=(MagickRealType) (*image)->columns*
  1342. (*image)->rows/100.0f;
  1343. }
  1344. if ((flags & SigmaValue) == 0)
  1345. white_point=(MagickRealType) (*image)->columns*(*image)->rows-
  1346. black_point;
  1347. (void) LinearStretchImage(*image,black_point,white_point);
  1348. break;
  1349. }
  1350. if (LocaleCompare("linewidth",option+1) == 0)
  1351. {
  1352. draw_info->stroke_width=atof(argv[i+1]);
  1353. break;
  1354. }
  1355. if (LocaleCompare("loop",option+1) == 0)
  1356. {
  1357. /*
  1358. Set image iterations.
  1359. */
  1360. (*image)->iterations=(unsigned long) atol(argv[i+1]);
  1361. break;
  1362. }
  1363. break;
  1364. }
  1365. case 'm':
  1366. {
  1367. if (LocaleCompare("map",option+1) == 0)
  1368. {
  1369. Image
  1370. *map_image;
  1371. ImageInfo
  1372. *map_info;
  1373. /*
  1374. Transform image colors to match this set of colors.
  1375. */
  1376. if (*option == '+')
  1377. break;
  1378. map_info=CloneImageInfo(image_info);
  1379. (void) CopyMagickString(map_info->filename,argv[i+1],
  1380. MaxTextExtent);
  1381. map_image=ReadImage(map_info,exception);
  1382. map_info=DestroyImageInfo(map_info);
  1383. CatchException(exception);
  1384. if (map_image == (Image *) NULL)
  1385. break;
  1386. (void) MapImage(*image,map_image,quantize_info->dither);
  1387. map_image=DestroyImage(map_image);
  1388. break;
  1389. }
  1390. if (LocaleCompare("mask",option+1) == 0)
  1391. {
  1392. Image
  1393. *mask;
  1394. ImageInfo
  1395. *mask_info;
  1396. if (*option == '+')
  1397. {
  1398. /*
  1399. Remove a mask.
  1400. */
  1401. (void) SetImageMask(*image,(Image *) NULL);
  1402. break;
  1403. }
  1404. /*
  1405. Set the image mask.
  1406. */
  1407. mask_info=CloneImageInfo(image_info);
  1408. (void) CopyMagickString(mask_info->filename,argv[i+1],
  1409. MaxTextExtent);
  1410. mask=ReadImage(mask_info,exception);
  1411. CatchException(exception);
  1412. mask_info=DestroyImageInfo(mask_info);
  1413. if (mask == (Image *) NULL)
  1414. break;
  1415. (void) SetImageMask(*image,mask);
  1416. break;
  1417. }
  1418. if (LocaleCompare("matte",option+1) == 0)
  1419. {
  1420. if (*option == '-')
  1421. if ((*image)->matte == MagickFalse)
  1422. (void) SetImageOpacity(*image,OpaqueOpacity);
  1423. (*image)->matte=(*option == '-') ? MagickTrue : MagickFalse;
  1424. break;
  1425. }
  1426. if (LocaleCompare("mattecolor",option+1) == 0)
  1427. {
  1428. if (*option == '+')
  1429. {
  1430. (void) QueryColorDatabase(MatteColor,&(*image)->matte_color,
  1431. exception);
  1432. break;
  1433. }
  1434. (void) QueryColorDatabase(argv[i+1],&(*image)->matte_color,
  1435. exception);
  1436. break;
  1437. }
  1438. if (LocaleCompare("median",option+1) == 0)
  1439. {
  1440. Image
  1441. *median_image;
  1442. /*
  1443. Median filter image.
  1444. */
  1445. (void) ParseGeometry(argv[i+1],&geometry_info);
  1446. median_image=MedianFilterImage(*image,geometry_info.rho,exception);
  1447. if (median_image == (Image *) NULL)
  1448. break;
  1449. InheritException(&median_image->exception,exception);
  1450. *image=DestroyImage(*image);
  1451. *image=median_image;
  1452. break;
  1453. }
  1454. if (LocaleCompare("modulate",option+1) == 0)
  1455. {
  1456. (void) ModulateImage(*image,argv[i+1]);
  1457. break;
  1458. }
  1459. if (LocaleCompare("monitor",option+1) == 0)
  1460. {
  1461. (void) SetImageProgressMonitor(*image,MonitorProgress,
  1462. (void *) NULL);
  1463. break;
  1464. }
  1465. if (LocaleCompare("monochrome",option+1) == 0)
  1466. {
  1467. (void) SetImageType(*image,BilevelType);
  1468. break;
  1469. }
  1470. if (LocaleCompare("motion-blur",option+1) == 0)
  1471. {
  1472. Image
  1473. *blur_image;
  1474. /*
  1475. Motion blur image.
  1476. */
  1477. flags=ParseGeometry(argv[i+1],&geometry_info);
  1478. if ((flags & SigmaValue) == 0)
  1479. geometry_info.sigma=1.0;
  1480. blur_image=MotionBlurImage(*image,geometry_info.rho,
  1481. geometry_info.sigma,geometry_info.xi,exception);
  1482. if (blur_image == (Image *) NULL)
  1483. break;
  1484. InheritException(&blur_image->exception,exception);
  1485. *image=DestroyImage(*image);
  1486. *image=blur_image;
  1487. break;
  1488. }
  1489. break;
  1490. }
  1491. case 'n':
  1492. {
  1493. if (LocaleCompare("negate",option+1) == 0)
  1494. {
  1495. (void) NegateImageChannel(*image,channel,
  1496. *option == '+' ? MagickTrue : MagickFalse);
  1497. break;
  1498. }
  1499. if (LocaleCompare("noise",option+1) == 0)
  1500. {
  1501. Image
  1502. *noisy_image;
  1503. if (*option == '-')
  1504. {
  1505. (void) ParseGeometry(argv[i+1],&geometry_info);
  1506. noisy_image=ReduceNoiseImage(*image,geometry_info.rho,
  1507. exception);
  1508. }
  1509. else
  1510. {
  1511. NoiseType
  1512. noise;
  1513. noise=(NoiseType) ParseMagickOption(MagickNoiseOptions,
  1514. MagickFalse,argv[i+1]);
  1515. noisy_image=AddNoiseImageChannel(*image,channel,noise,
  1516. exception);
  1517. }
  1518. if (noisy_image == (Image *) NULL)
  1519. break;
  1520. InheritException(&noisy_image->exception,exception);
  1521. *image=DestroyImage(*image);
  1522. *image=noisy_image;
  1523. break;
  1524. }
  1525. if (LocaleCompare("normalize",option+1) == 0)
  1526. {
  1527. (void) NormalizeImageChannel(*image,channel);
  1528. break;
  1529. }
  1530. break;
  1531. }
  1532. case 'o':
  1533. {
  1534. if (LocaleCompare("opaque",option+1) == 0)
  1535. {
  1536. MagickPixelPacket
  1537. target;
  1538. (void) QueryMagickColor(argv[i+1],&target,exception);
  1539. (void) PaintOpaqueImageChannel(*image,channel,&target,&fill);
  1540. break;
  1541. }
  1542. if (LocaleCompare("ordered-dither",option+1) == 0)
  1543. {
  1544. (void) OrderedPosterizeImageChannel(*image,channel,
  1545. argv[i+1],exception);
  1546. break;
  1547. }
  1548. break;
  1549. }
  1550. case 'p':
  1551. {
  1552. if (LocaleCompare("paint",option+1) == 0)
  1553. {
  1554. Image
  1555. *paint_image;
  1556. /*
  1557. Oil paint image.
  1558. */
  1559. (void) ParseGeometry(argv[i+1],&geometry_info);
  1560. paint_image=OilPaintImage(*image,geometry_info.rho,exception);
  1561. if (paint_image == (Image *) NULL)
  1562. break;
  1563. InheritException(&paint_image->exception,exception);
  1564. *image=DestroyImage(*image);
  1565. *image=paint_image;
  1566. break;
  1567. }
  1568. if (LocaleCompare("pen",option+1) == 0)
  1569. {
  1570. if (*option == '+')
  1571. {
  1572. (void) QueryColorDatabase("none",&draw_info->fill,exception);
  1573. break;
  1574. }
  1575. (void) QueryColorDatabase(argv[i+1],&draw_info->fill,exception);
  1576. break;
  1577. }
  1578. if (LocaleCompare("pointsize",option+1) == 0)
  1579. {
  1580. if (*option == '+')
  1581. (void) ParseGeometry("12",&geometry_info);
  1582. else
  1583. (void) ParseGeometry(argv[i+1],&geometry_info);
  1584. draw_info->pointsize=geometry_info.rho;
  1585. break;
  1586. }
  1587. if (LocaleCompare("polaroid",option+1) == 0)
  1588. {
  1589. double
  1590. angle;
  1591. Image
  1592. *polaroid_image;
  1593. /*
  1594. Simulate a Polaroid picture.
  1595. */
  1596. angle=15.0*(GetRandomValue()-0.5);
  1597. if (*option == '-')
  1598. {
  1599. SetGeometryInfo(&geometry_info);
  1600. flags=ParseGeometry(argv[i+1],&geometry_info);
  1601. angle=geometry_info.rho;
  1602. }
  1603. polaroid_image=PolaroidImage(*image,draw_info,angle,exception);
  1604. if (polaroid_image == (Image *) NULL)
  1605. break;
  1606. InheritException(&polaroid_image->exception,exception);
  1607. *image=DestroyImage(*image);
  1608. *image=polaroid_image;
  1609. break;
  1610. }
  1611. if (LocaleCompare("posterize",option+1) == 0)
  1612. {
  1613. /*
  1614. Posterize image.
  1615. */
  1616. (void) PosterizeImage(*image,(unsigned long) atol(argv[i+1]),
  1617. quantize_info->dither);
  1618. break;
  1619. }
  1620. if (LocaleCompare("preview",option+1) == 0)
  1621. {
  1622. Image
  1623. *preview_image;
  1624. PreviewType
  1625. preview_type;
  1626. /*
  1627. Preview image.
  1628. */
  1629. if (*option == '+')
  1630. preview_type=UndefinedPreview;
  1631. else
  1632. preview_type=(PreviewType) ParseMagickOption(MagickPreviewOptions,
  1633. MagickFalse,argv[i+1]);
  1634. preview_image=PreviewImage(*image,preview_type,exception);
  1635. if (preview_image == (Image *) NULL)
  1636. break;
  1637. InheritException(&preview_image->exception,exception);
  1638. *image=DestroyImage(*image);
  1639. *image=preview_image;
  1640. break;
  1641. }
  1642. if (LocaleCompare("profile",option+1) == 0)
  1643. {
  1644. const char
  1645. *name;
  1646. const StringInfo
  1647. *profile;
  1648. Image
  1649. *profile_image;
  1650. ImageInfo
  1651. *profile_info;
  1652. if (*option == '+')
  1653. {
  1654. /*
  1655. Remove a profile from the image.
  1656. */
  1657. (void) ProfileImage(*image,argv[i+1],
  1658. (const unsigned char *) NULL,0,MagickTrue);
  1659. break;
  1660. }
  1661. /*
  1662. Associate a profile with the image.
  1663. */
  1664. profile_info=CloneImageInfo(image_info);
  1665. profile=GetImageProfile(*image,"iptc");
  1666. if (profile != (StringInfo *) NULL)
  1667. profile_info->profile=(void *) CloneStringInfo(profile);
  1668. (void) CopyMagickString(profile_info->filename,argv[i+1],
  1669. MaxTextExtent);
  1670. profile_image=ReadImage(profile_info,exception);
  1671. CatchException(exception);
  1672. profile_info=DestroyImageInfo(profile_info);
  1673. if (profile_image == (Image *) NULL)
  1674. break;
  1675. ResetImageProfileIterator(profile_image);
  1676. name=GetNextImageProfile(profile_image);
  1677. while (name != (const char *) NULL)
  1678. {
  1679. profile=GetImageProfile(profile_image,name);
  1680. if (profile != (StringInfo *) NULL)
  1681. (void) ProfileImage(*image,name,GetStringInfoDatum(profile),(unsigned long)
  1682. GetStringInfoLength(profile),MagickFalse);
  1683. name=GetNextImageProfile(profile_image);
  1684. }
  1685. profile_image=DestroyImage(profile_image);
  1686. break;
  1687. }
  1688. break;
  1689. }
  1690. case 'q':
  1691. {
  1692. if (LocaleCompare("quality",option+1) == 0)
  1693. {
  1694. /*
  1695. Set image compression quality.
  1696. */
  1697. if (*option == '+')
  1698. {
  1699. (*image)->quality=UndefinedCompressionQuality;
  1700. break;
  1701. }
  1702. (*image)->quality=(unsigned long) atol(argv[i+1]);
  1703. break;
  1704. }
  1705. if (LocaleCompare("quantize",option+1) == 0)
  1706. {
  1707. if (*option == '+')
  1708. {
  1709. quantize_info->colorspace=UndefinedColorspace;
  1710. break;
  1711. }
  1712. quantize_info->colorspace=(ColorspaceType) ParseMagickOption(
  1713. MagickColorspaceOptions,MagickFalse,argv[i+1]);
  1714. break;
  1715. }
  1716. break;
  1717. }
  1718. case 'r':
  1719. {
  1720. if (LocaleCompare("radial-blur",option+1) == 0)
  1721. {
  1722. Image
  1723. *blur_image;
  1724. /*
  1725. Radial blur image.
  1726. */
  1727. blur_image=RadialBlurImageChannel(*image,channel,
  1728. atof(argv[i+1]),exception);
  1729. if (blur_image == (Image *) NULL)
  1730. break;
  1731. InheritException(&blur_image->exception,exception);
  1732. *image=DestroyImage(*image);
  1733. *image=blur_image;
  1734. break;
  1735. }
  1736. if (LocaleCompare("raise",option+1) == 0)
  1737. {
  1738. /*
  1739. Surround image with a raise of solid color.
  1740. */
  1741. (void) ParsePageGeometry(*image,argv[i+1],&geometry);
  1742. (void) RaiseImage(*image,&geometry,(MagickBooleanType)
  1743. (*option == '-'));
  1744. break;
  1745. }
  1746. if (LocaleCompare("random-threshold",option+1) == 0)
  1747. {
  1748. /*
  1749. Threshold image.
  1750. */
  1751. (void) RandomThresholdImageChannel(*image,channel,
  1752. argv[i+1],exception);
  1753. break;
  1754. }
  1755. if (LocaleCompare("recolor",option+1) == 0)
  1756. {
  1757. char
  1758. *p,
  1759. token[MaxTextExtent];
  1760. double
  1761. *color_matrix;
  1762. Image
  1763. *recolor_image;
  1764. register long
  1765. x;
  1766. unsigned long
  1767. order;
  1768. /*
  1769. Transform color image.
  1770. */
  1771. p=(char *) argv[i+1];
  1772. for (x=0; *p != '\0'; x++)
  1773. {
  1774. GetMagickToken(p,&p,token);
  1775. if (*token == ',')
  1776. GetMagickToken(p,&p,token);
  1777. }
  1778. order=(unsigned long) sqrt((double) x+1.0);
  1779. color_matrix=(double *) AcquireMagickMemory(order*order*
  1780. sizeof(*color_matrix));
  1781. if (color_matrix == (double *) NULL)
  1782. ThrowWandFatalException(ResourceLimitFatalError,
  1783. "MemoryAllocationFailed",(*image)->filename);
  1784. p=(char *) argv[i+1];
  1785. for (x=0; *p != '\0'; x++)
  1786. {
  1787. GetMagickToken(p,&p,token);
  1788. if (*token == ',')
  1789. GetMagickToken(p,&p,token);
  1790. color_matrix[x]=atof(token);
  1791. }
  1792. for ( ; x < (long) (order*order); x++)
  1793. color_matrix[x]=0.0;
  1794. recolor_image=RecolorImage(*image,order,color_matrix,exception);
  1795. color_matrix=(double *) RelinquishMagickMemory(color_matrix);
  1796. if (recolor_image == (Image *) NULL)
  1797. break;
  1798. InheritException(&recolor_image->exception,exception);
  1799. *image=DestroyImage(*image);
  1800. *image=recolor_image;
  1801. break;
  1802. }
  1803. if (LocaleCompare("red-primary",option+1) == 0)
  1804. {
  1805. /*
  1806. Red chromaticity primary point.
  1807. */
  1808. if (*option == '+')
  1809. {
  1810. (*image)->chromaticity.red_primary.x=0.0;
  1811. (*image)->chromaticity.red_primary.y=0.0;
  1812. break;
  1813. }
  1814. flags=ParseGeometry(argv[i+1],&geometry_info);
  1815. (*image)->chromaticity.red_primary.x=geometry_info.rho;
  1816. (*image)->chromaticity.red_primary.y=geometry_info.sigma;
  1817. if ((flags & SigmaValue) == 0)
  1818. (*image)->chromaticity.red_primary.y=
  1819. (*image)->chromaticity.red_primary.x;
  1820. break;
  1821. }
  1822. if (LocaleCompare("regard-warnings",option+1) == 0)
  1823. break;
  1824. if (LocaleCompare("region",option+1) == 0)
  1825. {
  1826. Image
  1827. *crop_image;
  1828. if (region_image != (Image *) NULL)
  1829. {
  1830. /*
  1831. Composite region.
  1832. */
  1833. (void) CompositeImage(region_image,
  1834. (*image)->matte != MagickFalse ? OverCompositeOp :
  1835. CopyCompositeOp,*image,region_geometry.x,region_geometry.y);
  1836. InheritException(&region_image->exception,exception);
  1837. *image=DestroyImage(*image);
  1838. *image=region_image;
  1839. }
  1840. if (*option == '+')
  1841. break;
  1842. /*
  1843. Apply transformations to a selected region of the image.
  1844. */
  1845. (void) ParseGravityGeometry(*image,argv[i+1],&region_geometry);
  1846. crop_image=CropImage(*image,&region_geometry,exception);
  1847. if (crop_image == (Image *) NULL)
  1848. break;
  1849. region_image=(*image);
  1850. *image=crop_image;
  1851. break;
  1852. }
  1853. if (LocaleCompare("render",option+1) == 0)
  1854. {
  1855. draw_info->render=(*option == '+') ? MagickTrue : MagickFalse;
  1856. break;
  1857. }
  1858. if (LocaleCompare("repage",option+1) == 0)
  1859. {
  1860. if (*option == '+')
  1861. {
  1862. (void) ParseAbsoluteGeometry("0x0+0+0",&(*image)->page);
  1863. break;
  1864. }
  1865. flags=ParseAbsoluteGeometry(argv[i+1],&geometry);
  1866. if ((flags & WidthValue) != 0)
  1867. {
  1868. if ((flags & HeightValue) == 0)
  1869. geometry.height=geometry.width;
  1870. (*image)->page.width=geometry.width;
  1871. (*image)->page.height=geometry.height;
  1872. }
  1873. if ((flags & AspectValue) != 0)
  1874. {
  1875. if ((flags & XValue) != 0)
  1876. (*image)->page.x+=geometry.x;
  1877. if ((flags & YValue) != 0)
  1878. (*image)->page.y+=geometry.y;
  1879. }
  1880. else
  1881. {
  1882. if ((flags & XValue) != 0)
  1883. {
  1884. (*image)->page.x=geometry.x;
  1885. if (((*image)->page.width == 0) && (geometry.x > 0))
  1886. (*image)->page.width=(*image)->columns+geometry.x;
  1887. }
  1888. if ((flags & YValue) != 0)
  1889. {
  1890. (*image)->page.y=geometry.y;
  1891. if (((*image)->page.height == 0) && (geometry.y > 0))
  1892. (*image)->page.height=(*image)->rows+geometry.y;
  1893. }
  1894. }
  1895. break;
  1896. }
  1897. if (LocaleCompare("resample",option+1) == 0)
  1898. {
  1899. Image
  1900. *resample_image;
  1901. unsigned long
  1902. height,
  1903. width;
  1904. /*
  1905. Resize image.
  1906. */
  1907. if (((*image)->x_resolution == 0.0) ||
  1908. ((*image)->y_resolution == 0.0))
  1909. ThrowWandFatalException(ImageError,"ImageResolutionNotDefined",
  1910. (*image)->filename);
  1911. flags=ParseGeometry(argv[i+1],&geometry_info);
  1912. if ((flags & SigmaValue) == 0)
  1913. geometry_info.sigma=geometry_info.rho;
  1914. width=(unsigned long) (geometry_info.rho*(*image)->columns/
  1915. (*image)->x_resolution+0.5);
  1916. height=(unsigned long) (geometry_info.sigma*(*image)->rows/
  1917. (*image)->y_resolution+0.5);
  1918. (*image)->x_resolution=geometry_info.rho;
  1919. (*image)->y_resolution=geometry_info.sigma;
  1920. resample_image=ResizeImage(*image,width,height,(*image)->filter,
  1921. (*image)->blur,exception);
  1922. if (resample_image == (Image *) NULL)
  1923. break;
  1924. InheritException(&resample_image->exception,exception);
  1925. *image=DestroyImage(*image);
  1926. *image=resample_image;
  1927. break;
  1928. }
  1929. if (LocaleCompare("resize",option+1) == 0)
  1930. {
  1931. Image
  1932. *resize_image;
  1933. /*
  1934. Resize image.
  1935. */
  1936. (void) ParseSizeGeometry(*image,argv[i+1],&geometry);
  1937. resize_image=ResizeImage(*image,geometry.width,geometry.height,
  1938. (*image)->filter,(*image)->blur,exception);
  1939. if (resize_image == (Image *) NULL)
  1940. break;
  1941. InheritException(&resize_image->exception,exception);
  1942. *image=DestroyImage(*image);
  1943. *image=resize_image;
  1944. break;
  1945. }
  1946. if (LocaleCompare("roll",option+1) == 0)
  1947. {
  1948. Image
  1949. *roll_image;
  1950. /*
  1951. Roll image.
  1952. */
  1953. (void) ParsePageGeometry(*image,argv[i+1],&geometry);
  1954. roll_image=RollImage(*image,geometry.x,geometry.y,exception);
  1955. if (roll_image == (Image *) NULL)
  1956. break;
  1957. InheritException(&roll_image->exception,exception);
  1958. *image=DestroyImage(*image);
  1959. *image=roll_image;
  1960. break;
  1961. }
  1962. if (LocaleCompare("rotate",option+1) == 0)
  1963. {
  1964. char
  1965. *geometry;
  1966. Image
  1967. *rotate_image;
  1968. /*
  1969. Check for conditional image rotation.
  1970. */
  1971. if (strchr(argv[i+1],'>') != (char *) NULL)
  1972. if ((*image)->columns <= (*image)->rows)
  1973. break;
  1974. if (strchr(argv[i+1],'<') != (char *) NULL)
  1975. if ((*image)->columns >= (*image)->rows)
  1976. break;
  1977. /*
  1978. Rotate image.
  1979. */
  1980. geometry=ConstantString(argv[i+1]);
  1981. (void) SubstituteString(&geometry,">","");
  1982. (void) SubstituteString(&geometry,"<","");
  1983. (void) ParseGeometry(geometry,&geometry_info);
  1984. geometry=(char *) RelinquishMagickMemory(geometry);
  1985. rotate_image=RotateImage(*image,geometry_info.rho,exception);
  1986. if (rotate_image == (Image *) NULL)
  1987. break;
  1988. InheritException(&rotate_image->exception,exception);
  1989. *image=DestroyImage(*image);
  1990. *image=rotate_image;
  1991. break;
  1992. }
  1993. break;
  1994. }
  1995. case 's':
  1996. {
  1997. if (LocaleCompare("sample",option+1) == 0)
  1998. {
  1999. Image
  2000. *sample_image;
  2001. /*
  2002. Sample image with pixel replication.
  2003. */
  2004. (void) ParseSizeGeometry(*image,argv[i+1],&geometry);
  2005. sample_image=SampleImage(*image,geometry.width,geometry.height,
  2006. exception);
  2007. if (sample_image == (Image *) NULL)
  2008. break;
  2009. InheritException(&sample_image->exception,exception);
  2010. *image=DestroyImage(*image);
  2011. *image=sample_image;
  2012. break;
  2013. }
  2014. if (LocaleCompare("scale",option+1) == 0)
  2015. {
  2016. Image
  2017. *scale_image;
  2018. /*
  2019. Resize image.
  2020. */
  2021. (void) ParseSizeGeometry(*image,argv[i+1],&geometry);
  2022. scale_image=ScaleImage(*image,geometry.width,geometry.height,
  2023. exception);
  2024. if (scale_image == (Image *) NULL)
  2025. break;
  2026. InheritException(&scale_image->exception,exception);
  2027. *image=DestroyImage(*image);
  2028. *image=scale_image;
  2029. break;
  2030. }
  2031. if (LocaleCompare("separate",option+1) == 0)
  2032. {
  2033. Image
  2034. *separate_images;
  2035. /*
  2036. Break channels into separate images.
  2037. */
  2038. separate_images=SeparateImages(*image,channel,exception);
  2039. if (separate_images == (Image *) NULL)
  2040. break;
  2041. InheritException(&separate_images->exception,exception);
  2042. *image=DestroyImage(*image);
  2043. *image=separate_images;
  2044. break;
  2045. }
  2046. if (LocaleCompare("sepia-tone",option+1) == 0)
  2047. {
  2048. double
  2049. threshold;
  2050. Image
  2051. *sepia_image;
  2052. /*
  2053. Sepia-tone image.
  2054. */
  2055. threshold=StringToDouble(argv[i+1],QuantumRange);
  2056. sepia_image=SepiaToneImage(*image,threshold,exception);
  2057. if (sepia_image == (Image *) NULL)
  2058. break;
  2059. InheritException(&sepia_image->exception,exception);
  2060. *image=DestroyImage(*image);
  2061. *image=sepia_image;
  2062. break;
  2063. }
  2064. if (LocaleCompare("segment",option+1) == 0)
  2065. {
  2066. /*
  2067. Segment image.
  2068. */
  2069. flags=ParseGeometry(argv[i+1],&geometry_info);
  2070. if ((flags & SigmaValue) == 0)
  2071. geometry_info.sigma=1.0;
  2072. (void) SegmentImage(*image,image_info->colorspace,
  2073. image_info->verbose,geometry_info.rho,geometry_info.sigma);
  2074. break;
  2075. }
  2076. if (LocaleCompare("set",option+1) == 0)
  2077. {
  2078. /*
  2079. Set image attribute.
  2080. */
  2081. (void) DeleteImageProperty(*image,argv[i+1]);
  2082. if (*option == '-')
  2083. (void) SetImageProperty(*image,argv[i+1],argv[i+2]);
  2084. break;
  2085. }
  2086. if (LocaleCompare("shade",option+1) == 0)
  2087. {
  2088. Image
  2089. *shade_image;
  2090. /*
  2091. Shade image.
  2092. */
  2093. flags=ParseGeometry(argv[i+1],&geometry_info);
  2094. if ((flags & SigmaValue) == 0)
  2095. geometry_info.sigma=0.0;
  2096. shade_image=ShadeImage(*image,(*option == '-') ? MagickTrue :
  2097. MagickFalse,geometry_info.rho,geometry_info.sigma,exception);
  2098. if (shade_image == (Image *) NULL)
  2099. break;
  2100. InheritException(&shade_image->exception,exception);
  2101. *image=DestroyImage(*image);
  2102. *image=shade_image;
  2103. break;
  2104. }
  2105. if (LocaleCompare("shadow",option+1) == 0)
  2106. {
  2107. Image
  2108. *shadow_image;
  2109. /*
  2110. Shadow image.
  2111. */
  2112. flags=ParseGeometry(argv[i+1],&geometry_info);
  2113. if ((flags & SigmaValue) == 0)
  2114. geometry_info.sigma=1.0;
  2115. if ((flags & XiValue) == 0)
  2116. geometry_info.xi=4.0;
  2117. if ((flags & PsiValue) == 0)
  2118. geometry_info.psi=4.0;
  2119. shadow_image=ShadowImage(*image,geometry_info.rho,
  2120. geometry_info.sigma,(long) (geometry_info.xi+0.5),(long)
  2121. (geometry_info.psi+0.5),exception);
  2122. if (shadow_image == (Image *) NULL)
  2123. break;
  2124. InheritException(&shadow_image->exception,exception);
  2125. *image=DestroyImage(*image);
  2126. *image=shadow_image;
  2127. break;
  2128. }
  2129. if (LocaleCompare("sharpen",option+1) == 0)
  2130. {
  2131. Image
  2132. *sharp_image;
  2133. /*
  2134. Sharpen image.
  2135. */
  2136. flags=ParseGeometry(argv[i+1],&geometry_info);
  2137. if ((flags & SigmaValue) == 0)
  2138. geometry_info.sigma=1.0;
  2139. sharp_image=SharpenImageChannel(*image,channel,
  2140. geometry_info.rho,geometry_info.sigma,exception);
  2141. if (sharp_image == (Image *) NULL)
  2142. break;
  2143. InheritException(&sharp_image->exception,exception);
  2144. *image=DestroyImage(*image);
  2145. *image=sharp_image;
  2146. break;
  2147. }
  2148. if (LocaleCompare("shave",option+1) == 0)
  2149. {
  2150. Image
  2151. *shave_image;
  2152. /*
  2153. Shave the image edges.
  2154. */
  2155. flags=ParsePageGeometry(*image,argv[i+1],&geometry);
  2156. shave_image=ShaveImage(*image,&geometry,exception);
  2157. if (shave_image == (Image *) NULL)
  2158. break;
  2159. InheritException(&shave_image->exception,exception);
  2160. *image=DestroyImage(*image);
  2161. *image=shave_image;
  2162. break;
  2163. }
  2164. if (LocaleCompare("shear",option+1) == 0)
  2165. {
  2166. Image
  2167. *shear_image;
  2168. /*
  2169. Shear image.
  2170. */
  2171. flags=ParseGeometry(argv[i+1],&geometry_info);
  2172. if ((flags & SigmaValue) == 0)
  2173. geometry_info.sigma=geometry_info.rho;
  2174. shear_image=ShearImage(*image,geometry_info.rho,geometry_info.sigma,
  2175. exception);
  2176. if (shear_image == (Image *) NULL)
  2177. break;
  2178. InheritException(&shear_image->exception,exception);
  2179. *image=DestroyImage(*image);
  2180. *image=shear_image;
  2181. break;
  2182. }
  2183. if (LocaleCompare("sigmoidal-contrast",option+1) == 0)
  2184. {
  2185. /*
  2186. Sigmoidal non-linearity contrast control.
  2187. */
  2188. flags=ParseGeometry(argv[i+1],&geometry_info);
  2189. if ((flags & SigmaValue) == 0)
  2190. geometry_info.sigma=QuantumRange/2.0;
  2191. if ((flags & PercentValue) != 0)
  2192. geometry_info.sigma=QuantumRange*geometry_info.sigma/100.0;
  2193. (void) SigmoidalContrastImageChannel(*image,channel,
  2194. (*option == '-') ? MagickTrue : MagickFalse,geometry_info.rho,
  2195. geometry_info.sigma);
  2196. break;
  2197. }
  2198. if (LocaleCompare("sketch",option+1) == 0)
  2199. {
  2200. Image
  2201. *sketch_image;
  2202. /*
  2203. Sketch image.
  2204. */
  2205. flags=ParseGeometry(argv[i+1],&geometry_info);
  2206. if ((flags & SigmaValue) == 0)
  2207. geometry_info.sigma=1.0;
  2208. sketch_image=SketchImage(*image,geometry_info.rho,
  2209. geometry_info.sigma,geometry_info.xi,exception);
  2210. if (sketch_image == (Image *) NULL)
  2211. break;
  2212. InheritException(&sketch_image->exception,exception);
  2213. *image=DestroyImage(*image);
  2214. *image=sketch_image;
  2215. break;
  2216. }
  2217. if (LocaleCompare("solarize",option+1) == 0)
  2218. {
  2219. double
  2220. threshold;
  2221. threshold=StringToDouble(argv[i+1],QuantumRange);
  2222. (void) SolarizeImage(*image,threshold);
  2223. break;
  2224. }
  2225. if (LocaleCompare("splice",option+1) == 0)
  2226. {
  2227. Image
  2228. *splice_image;
  2229. /*
  2230. Splice a solid color into the image.
  2231. */
  2232. (void) ParseGravityGeometry(*image,argv[i+1],&geometry);
  2233. splice_image=SpliceImage(*image,&geometry,exception);
  2234. if (splice_image == (Image *) NULL)
  2235. break;
  2236. InheritException(&splice_image->exception,exception);
  2237. *image=DestroyImage(*image);
  2238. *image=splice_image;
  2239. break;
  2240. }
  2241. if (LocaleCompare("spread",option+1) == 0)
  2242. {
  2243. Image
  2244. *spread_image;
  2245. /*
  2246. Spread an image.
  2247. */
  2248. (void) ParseGeometry(argv[i+1],&geometry_info);
  2249. spread_image=SpreadImage(*image,geometry_info.rho,exception);
  2250. if (spread_image == (Image *) NULL)
  2251. break;
  2252. InheritException(&spread_image->exception,exception);
  2253. *image=DestroyImage(*image);
  2254. *image=spread_image;
  2255. break;
  2256. }
  2257. if (LocaleCompare("stretch",option+1) == 0)
  2258. {
  2259. if (*option == '+')
  2260. {
  2261. draw_info->stretch=UndefinedStretch;
  2262. break;
  2263. }
  2264. draw_info->stretch=(StretchType) ParseMagickOption(
  2265. MagickStretchOptions,MagickFalse,argv[i+1]);
  2266. break;
  2267. }
  2268. if (LocaleCompare("strip",option+1) == 0)
  2269. {
  2270. /*
  2271. Strip image of profiles and comments.
  2272. */
  2273. (void) StripImage(*image);
  2274. break;
  2275. }
  2276. if (LocaleCompare("stroke",option+1) == 0)
  2277. {
  2278. ExceptionInfo
  2279. *sans;
  2280. if (*option == '+')
  2281. {
  2282. (void) QueryColorDatabase("none",&draw_info->stroke,exception);
  2283. break;
  2284. }
  2285. sans=AcquireExceptionInfo();
  2286. status=QueryColorDatabase(argv[i+1],&draw_info->stroke,sans);
  2287. sans=DestroyExceptionInfo(sans);
  2288. if (status == MagickFalse)
  2289. draw_info->stroke_pattern=ReadImage(image_info,exception);
  2290. break;
  2291. }
  2292. if (LocaleCompare("strokewidth",option+1) == 0)
  2293. {
  2294. draw_info->stroke_width=atof(argv[i+1]);
  2295. break;
  2296. }
  2297. if (LocaleCompare("style",option+1) == 0)
  2298. {
  2299. if (*option == '+')
  2300. {
  2301. draw_info->style=UndefinedStyle;
  2302. break;
  2303. }
  2304. draw_info->style=(StyleType) ParseMagickOption(MagickStyleOptions,
  2305. MagickFalse,argv[i+1]);
  2306. break;
  2307. }
  2308. if (LocaleCompare("support",option+1) == 0)
  2309. {
  2310. (*image)->blur=1.0;
  2311. if (*option == '+')
  2312. break;
  2313. (*image)->blur=atof(argv[i+1]);
  2314. break;
  2315. }
  2316. if (LocaleCompare("swirl",option+1) == 0)
  2317. {
  2318. Image
  2319. *swirl_image;
  2320. /*
  2321. Swirl image.
  2322. */
  2323. (void) ParseGeometry(argv[i+1],&geometry_info);
  2324. swirl_image=SwirlImage(*image,geometry_info.rho,exception);
  2325. if (swirl_image == (Image *) NULL)
  2326. break;
  2327. InheritException(&swirl_image->exception,exception);
  2328. *image=DestroyImage(*image);
  2329. *image=swirl_image;
  2330. break;
  2331. }
  2332. break;
  2333. }
  2334. case 't':
  2335. {
  2336. if (LocaleCompare("threshold",option+1) == 0)
  2337. {
  2338. double
  2339. threshold;
  2340. /*
  2341. Threshold image.
  2342. */
  2343. threshold=StringToDouble(argv[i+1],QuantumRange);
  2344. (void) BilevelImageChannel(*image,channel,threshold);
  2345. break;
  2346. }
  2347. if (LocaleCompare("thumbnail",option+1) == 0)
  2348. {
  2349. Image
  2350. *thumbnail_image;
  2351. /*
  2352. Thumbnail image.
  2353. */
  2354. (void) ParseSizeGeometry(*image,argv[i+1],&geometry);
  2355. thumbnail_image=ThumbnailImage(*image,geometry.width,
  2356. geometry.height,exception);
  2357. if (thumbnail_image == (Image *) NULL)
  2358. break;
  2359. InheritException(&thumbnail_image->exception,exception);
  2360. *image=DestroyImage(*image);
  2361. *image=thumbnail_image;
  2362. break;
  2363. }
  2364. if (LocaleCompare("tile",option+1) == 0)
  2365. {
  2366. Image
  2367. *fill_pattern;
  2368. ImageInfo
  2369. *tile_info;
  2370. if (*option == '+')
  2371. {
  2372. if (draw_info->fill_pattern != (Image *) NULL)
  2373. draw_info->fill_pattern=DestroyImage(draw_info->fill_pattern);
  2374. break;
  2375. }
  2376. tile_info=CloneImageInfo(image_info);
  2377. (void) CopyMagickString(tile_info->filename,argv[i+1],
  2378. MaxTextExtent);
  2379. fill_pattern=ReadImage(tile_info,exception);
  2380. CatchException(exception);
  2381. tile_info=DestroyImageInfo(tile_info);
  2382. if (fill_pattern == (Image *) NULL)
  2383. break;
  2384. draw_info->fill_pattern=CloneImage(fill_pattern,0,0,MagickTrue,
  2385. exception);
  2386. fill_pattern=DestroyImage(fill_pattern);
  2387. break;
  2388. }
  2389. if (LocaleCompare("tint",option+1) == 0)
  2390. {
  2391. Image
  2392. *tint_image;
  2393. /*
  2394. Tint the image.
  2395. */
  2396. tint_image=TintImage(*image,argv[i+1],draw_info->fill,exception);
  2397. if (tint_image == (Image *) NULL)
  2398. break;
  2399. InheritException(&tint_image->exception,exception);
  2400. *image=DestroyImage(*image);
  2401. *image=tint_image;
  2402. break;
  2403. }
  2404. if (LocaleCompare("transform",option+1) == 0)
  2405. {
  2406. Image
  2407. *transform_image;
  2408. /*
  2409. Affine transform image.
  2410. */
  2411. transform_image=AffineTransformImage(*image,&draw_info->affine,
  2412. exception);
  2413. if (transform_image == (Image *) NULL)
  2414. break;
  2415. InheritException(&transform_image->exception,exception);
  2416. *image=DestroyImage(*image);
  2417. *image=transform_image;
  2418. break;
  2419. }
  2420. if (LocaleCompare("transparent",option+1) == 0)
  2421. {
  2422. MagickPixelPacket
  2423. target;
  2424. (void) QueryMagickColor(argv[i+1],&target,exception);
  2425. (void) PaintTransparentImage(*image,&target,TransparentOpacity);
  2426. break;
  2427. }
  2428. if (LocaleCompare("transparent-color",option+1) == 0)
  2429. {
  2430. if (*option == '+')
  2431. {
  2432. (void) QueryColorDatabase("none",&(*image)->transparent_color,
  2433. exception);
  2434. break;
  2435. }
  2436. (void) QueryColorDatabase(argv[i+1],&(*image)->transparent_color,
  2437. exception);
  2438. break;
  2439. }
  2440. if (LocaleCompare("transpose",option+1) == 0)
  2441. {
  2442. Image
  2443. *transpose_image;
  2444. /*
  2445. Transpose image scanlines.
  2446. */
  2447. transpose_image=TransposeImage(*image,exception);
  2448. if (transpose_image == (Image *) NULL)
  2449. break;
  2450. InheritException(&transpose_image->exception,exception);
  2451. *image=DestroyImage(*image);
  2452. *image=transpose_image;
  2453. break;
  2454. }
  2455. if (LocaleCompare("transverse",option+1) == 0)
  2456. {
  2457. Image
  2458. *transverse_image;
  2459. /*
  2460. Transverse image scanlines.
  2461. */
  2462. transverse_image=TransverseImage(*image,exception);
  2463. if (transverse_image == (Image *) NULL)
  2464. break;
  2465. InheritException(&transverse_image->exception,exception);
  2466. *image=DestroyImage(*image);
  2467. *image=transverse_image;
  2468. break;
  2469. }
  2470. if (LocaleCompare("treedepth",option+1) == 0)
  2471. {
  2472. quantize_info->tree_depth=(unsigned long) atol(argv[i+1]);
  2473. }
  2474. if (LocaleCompare("trim",option+1) == 0)
  2475. {
  2476. Image
  2477. *trim_image;
  2478. trim_image=TrimImage(*image,exception);
  2479. if (trim_image == (Image *) NULL)
  2480. break;
  2481. InheritException(&trim_image->exception,exception);
  2482. *image=DestroyImage(*image);
  2483. *image=trim_image;
  2484. break;
  2485. }
  2486. if (LocaleCompare("type",option+1) == 0)
  2487. {
  2488. ImageType
  2489. type;
  2490. if (*option == '+')
  2491. type=UndefinedType;
  2492. else
  2493. type=(ImageType) ParseMagickOption(MagickImageOptions,MagickFalse,
  2494. argv[i+1]);
  2495. (void) SetImageType(*image,type);
  2496. break;
  2497. }
  2498. break;
  2499. }
  2500. case 'u':
  2501. {
  2502. if (LocaleCompare("undercolor",option+1) == 0)
  2503. {
  2504. (void) QueryColorDatabase(argv[i+1],&draw_info->undercolor,
  2505. exception);
  2506. break;
  2507. }
  2508. if (LocaleCompare("unique-colors",option+1) == 0)
  2509. {
  2510. Image
  2511. *unique_image;
  2512. /*
  2513. Unique image colors.
  2514. */
  2515. unique_image=UniqueImageColors(*image,exception);
  2516. if (unique_image == (Image *) NULL)
  2517. break;
  2518. InheritException(&unique_image->exception,exception);
  2519. *image=DestroyImage(*image);
  2520. *image=unique_image;
  2521. break;
  2522. }
  2523. if (LocaleCompare("units",option+1) == 0)
  2524. {
  2525. ResolutionType
  2526. units;
  2527. if (*option != '+')
  2528. units=(ResolutionType) ParseMagickOption(MagickResolutionOptions,
  2529. MagickFalse,argv[i+1]);
  2530. else
  2531. {
  2532. units=UndefinedResolution;
  2533. (*image)->x_resolution=0.0;
  2534. (*image)->y_resolution=0.0;
  2535. }
  2536. if ((*image)->units != units)
  2537. switch ((*image)->units)
  2538. {
  2539. case PixelsPerInchResolution:
  2540. {
  2541. if (units == PixelsPerCentimeterResolution)
  2542. {
  2543. (*image)->x_resolution/=2.54;
  2544. (*image)->y_resolution/=2.54;
  2545. }
  2546. break;
  2547. }
  2548. case PixelsPerCentimeterResolution:
  2549. {
  2550. if (units == PixelsPerInchResolution)
  2551. {
  2552. (*image)->x_resolution*=2.54;
  2553. (*image)->y_resolution*=2.54;
  2554. }
  2555. break;
  2556. }
  2557. default:
  2558. break;
  2559. }
  2560. (*image)->units=units;
  2561. break;
  2562. }
  2563. if (LocaleCompare("unsharp",option+1) == 0)
  2564. {
  2565. Image
  2566. *unsharp_image;
  2567. /*
  2568. Unsharp mask image.
  2569. */
  2570. flags=ParseGeometry(argv[i+1],&geometry_info);
  2571. if ((flags & SigmaValue) == 0)
  2572. geometry_info.sigma=1.0;
  2573. if ((flags & XiValue) == 0)
  2574. geometry_info.xi=1.0;
  2575. if ((flags & PsiValue) == 0)
  2576. geometry_info.psi=0.05;
  2577. unsharp_image=UnsharpMaskImageChannel(*image,channel,
  2578. geometry_info.rho,geometry_info.sigma,geometry_info.xi,
  2579. geometry_info.psi,exception);
  2580. if (unsharp_image == (Image *) NULL)
  2581. break;
  2582. InheritException(&unsharp_image->exception,exception);
  2583. *image=DestroyImage(*image);
  2584. *image=unsharp_image;
  2585. break;
  2586. }
  2587. break;
  2588. }
  2589. case 'v':
  2590. {
  2591. if ((LocaleCompare("version",option+1) == 0) ||
  2592. (LocaleCompare("-version",option+1) == 0))
  2593. break;
  2594. if (LocaleCompare("vignette",option+1) == 0)
  2595. {
  2596. Image
  2597. *vignette_image;
  2598. /*
  2599. Vignette image.
  2600. */
  2601. flags=ParseGeometry(argv[i+1],&geometry_info);
  2602. if ((flags & SigmaValue) == 0)
  2603. geometry_info.sigma=1.0;
  2604. if ((flags & XiValue) == 0)
  2605. geometry_info.xi=0.1*(*image)->columns;
  2606. if ((flags & PsiValue) == 0)
  2607. geometry_info.psi=0.1*(*image)->rows;
  2608. vignette_image=VignetteImage(*image,geometry_info.rho,
  2609. geometry_info.sigma,(long) (geometry_info.xi+0.5),(long)
  2610. (geometry_info.psi+0.5),exception);
  2611. if (vignette_image == (Image *) NULL)
  2612. break;
  2613. InheritException(&vignette_image->exception,exception);
  2614. *image=DestroyImage(*image);
  2615. *image=vignette_image;
  2616. break;
  2617. }
  2618. if (LocaleCompare("virtual-pixel",option+1) == 0)
  2619. {
  2620. if (*option == '+')
  2621. {
  2622. (void) SetImageVirtualPixelMethod(*image,
  2623. UndefinedVirtualPixelMethod);
  2624. break;
  2625. }
  2626. (void) SetImageVirtualPixelMethod(*image,(VirtualPixelMethod)
  2627. ParseMagickOption(MagickVirtualPixelOptions,MagickFalse,
  2628. argv[i+1]));
  2629. break;
  2630. }
  2631. break;
  2632. }
  2633. case 'w':
  2634. {
  2635. if (LocaleCompare("wave",option+1) == 0)
  2636. {
  2637. Image
  2638. *wave_image;
  2639. /*
  2640. Wave image.
  2641. */
  2642. flags=ParseGeometry(argv[i+1],&geometry_info);
  2643. if ((flags & SigmaValue) == 0)
  2644. geometry_info.sigma=1.0;
  2645. wave_image=WaveImage(*image,geometry_info.rho,geometry_info.sigma,
  2646. exception);
  2647. if (wave_image == (Image *) NULL)
  2648. break;
  2649. InheritException(&wave_image->exception,exception);
  2650. *image=DestroyImage(*image);
  2651. *image=wave_image;
  2652. break;
  2653. }
  2654. if (LocaleCompare("weight",option+1) == 0)
  2655. {
  2656. draw_info->weight=(unsigned long) atol(argv[i+1]);
  2657. if (LocaleCompare(argv[i+1],"all") == 0)
  2658. draw_info->weight=0;
  2659. if (LocaleCompare(argv[i+1],"bold") == 0)
  2660. draw_info->weight=700;
  2661. if (LocaleCompare(argv[i+1],"bolder") == 0)
  2662. if (draw_info->weight <= 800)
  2663. draw_info->weight+=100;
  2664. if (LocaleCompare(argv[i+1],"lighter") == 0)
  2665. if (draw_info->weight >= 100)
  2666. draw_info->weight-=100;
  2667. if (LocaleCompare(argv[i+1],"normal") == 0)
  2668. draw_info->weight=400;
  2669. break;
  2670. }
  2671. if (LocaleCompare("white-point",option+1) == 0)
  2672. {
  2673. /*
  2674. White chromaticity point.
  2675. */
  2676. if (*option == '+')
  2677. {
  2678. (*image)->chromaticity.white_point.x=0.0;
  2679. (*image)->chromaticity.white_point.y=0.0;
  2680. break;
  2681. }
  2682. flags=ParseGeometry(argv[i+1],&geometry_info);
  2683. (*image)->chromaticity.white_point.x=geometry_info.rho;
  2684. (*image)->chromaticity.white_point.y=geometry_info.sigma;
  2685. if ((flags & SigmaValue) == 0)
  2686. (*image)->chromaticity.white_point.y=
  2687. (*image)->chromaticity.white_point.x;
  2688. break;
  2689. }
  2690. if (LocaleCompare("white-threshold",option+1) == 0)
  2691. {
  2692. /*
  2693. Threshold white image.
  2694. */
  2695. (void) WhiteThresholdImage(*image,argv[i+1]);
  2696. break;
  2697. }
  2698. break;
  2699. }
  2700. default:
  2701. break;
  2702. }
  2703. i+=count;
  2704. }
  2705. if (region_image != (Image *) NULL)
  2706. {
  2707. /*
  2708. Composite transformed region onto image.
  2709. */
  2710. (void) CompositeImage(region_image,(*image)->matte != MagickFalse ?
  2711. OverCompositeOp : CopyCompositeOp,*image,region_geometry.x,
  2712. region_geometry.y);
  2713. InheritException(&region_image->exception,exception);
  2714. *image=DestroyImage(*image);
  2715. *image=region_image;
  2716. }
  2717. /*
  2718. Free resources.
  2719. */
  2720. quantize_info=DestroyQuantizeInfo(quantize_info);
  2721. draw_info=DestroyDrawInfo(draw_info);
  2722. status=(*image)->exception.severity == UndefinedException ?
  2723. MagickTrue : MagickFalse;
  2724. return(status);
  2725. }
  2726. /*
  2727. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  2728. % %
  2729. % %
  2730. % %
  2731. % M o g r i f y I m a g e C o m m a n d %
  2732. % %
  2733. % %
  2734. % %
  2735. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  2736. %
  2737. % MogrifyImageCommand() transforms an image or a sequence of images. These
  2738. % transforms include image scaling, image rotation, color reduction, and
  2739. % others. The transmogrified image overwrites the original image.
  2740. %
  2741. % The format of the MogrifyImageCommand method is:
  2742. %
  2743. % MagickBooleanType MogrifyImageCommand(ImageInfo *image_info,int argc,
  2744. % const char **argv,char **metadata,ExceptionInfo *exception)
  2745. %
  2746. % A description of each parameter follows:
  2747. %
  2748. % o image_info: The image info.
  2749. %
  2750. % o argc: The number of elements in the argument vector.
  2751. %
  2752. % o argv: A text array containing the command line arguments.
  2753. %
  2754. % o metadata: any metadata is returned here.
  2755. %
  2756. % o exception: Return any errors or warnings in this structure.
  2757. %
  2758. %
  2759. */
  2760. static void MogrifyUsage(void)
  2761. {
  2762. static const char
  2763. *operators[]=
  2764. {
  2765. "-adaptive-blur geometry",
  2766. " adaptively blur pixels; decrease effect near edges",
  2767. "-adaptive-resize geometry",
  2768. " adaptively resize image with data dependent triangulation",
  2769. "-adaptive-sharpen geometry",
  2770. " adaptively sharpen pixels; increase effect near edges",
  2771. "-annotate geometry text",
  2772. " annotate the image with text",
  2773. "-auto-orient automatically orient image",
  2774. "-black-threshold value",
  2775. " force all pixels below the threshold into black",
  2776. "-blur geometry reduce image noise and reduce detail levels",
  2777. "-border geometry surround image with a border of color",
  2778. "-charcoal radius simulate a charcoal drawing",
  2779. "-chop geometry remove pixels from the image interior",
  2780. "-clip clip along the first path from the 8BIM profile",
  2781. "-clip-mask filename associate a clip mask with the image",
  2782. "-clip-path id clip along a named path from the 8BIM profile",
  2783. "-colorize value colorize the image with the fill color",
  2784. "-contrast enhance or reduce the image contrast",
  2785. "-contrast-stretch geometry",
  2786. " improve contrast by `stretching' the intensity range",
  2787. "-convolve coefficients",
  2788. " apply a convolution kernel to the image",
  2789. "-cycle amount cycle the image colormap",
  2790. "-despeckle reduce the speckles within an image",
  2791. "-draw string annotate the image with a graphic primitive",
  2792. "-edge radius apply a filter to detect edges in the image",
  2793. "-emboss radius emboss an image",
  2794. "-enhance apply a digital filter to enhance a noisy image",
  2795. "-equalize perform histogram equalization to an image",
  2796. "-evaluate operator value",
  2797. " evaluate an arithmetic, relational, or logical expression",
  2798. "-extent geometry set the image size",
  2799. "-extract geometry extract area from image",
  2800. "-flip flip image vertically",
  2801. "-floodfill geometry color",
  2802. " floodfill the image with color",
  2803. "-flop flop image horizontally",
  2804. "-frame geometry surround image with an ornamental border",
  2805. "-gamma value level of gamma correction",
  2806. "-gaussian-blur geometry",
  2807. " reduce image noise and reduce detail levels",
  2808. "-geometry geometry perferred size or location of the image",
  2809. "-help print program options",
  2810. "-identify identify the format and characteristics of the image",
  2811. "-implode amount implode image pixels about the center",
  2812. "-lat geometry local adaptive thresholding",
  2813. "-layers method optimize or compare image layers",
  2814. "-level value adjust the level of image contrast",
  2815. "-linear-stretch geometry",
  2816. " improve contrast by `stretching with saturation' the intensity range",
  2817. "-median radius apply a median filter to the image",
  2818. "-modulate value vary the brightness, saturation, and hue",
  2819. "-monochrome transform image to black and white",
  2820. "-motion-blur geometry",
  2821. " simulate motion blur",
  2822. "-negate replace every pixel with its complementary color ",
  2823. "-noise radius add or reduce noise in an image",
  2824. "-normalize transform image to span the full range of colors",
  2825. "-opaque color change this color to the fill color",
  2826. "-ordered-dither NxN",
  2827. " add a noise pattern to the image with specific amplitudes",
  2828. "-paint radius simulate an oil painting",
  2829. "-polaroid angle simulate a Polaroid picture",
  2830. "-posterize levels reduce the image to a limited number of color levels",
  2831. "-print string interpret string and print to console",
  2832. "-profile filename add, delete, or apply an image profile",
  2833. "-quantize colorspace reduce colors in this colorspace",
  2834. "-radial-blur angle radial blur the image",
  2835. "-raise value lighten/darken image edges to create a 3-D effect",
  2836. "-random-threshold low,high",
  2837. " random threshold the image",
  2838. "-recolor matrix translate, scale, shear, or rotate image colors",
  2839. "-region geometry apply options to a portion of the image",
  2840. "-render render vector graphics",
  2841. "-repage geometry size and location of an image canvas",
  2842. "-resample geometry change the resolution of an image",
  2843. "-resize geometry resize the image",
  2844. "-roll geometry roll an image vertically or horizontally",
  2845. "-rotate degrees apply Paeth rotation to the image",
  2846. "-sample geometry scale image with pixel sampling",
  2847. "-scale geometry scale the image",
  2848. "-segment values segment an image",
  2849. "-sepia-tone threshold",
  2850. " simulate a sepia-toned photo",
  2851. "-set property value set an image property",
  2852. "-shade degrees shade the image using a distant light source",
  2853. "-shadow geometry simulate an image shadow",
  2854. "-sharpen geometry sharpen the image",
  2855. "-shave geometry shave pixels from the image edges",
  2856. "-shear geometry slide one edge of the image along the X or Y axis",
  2857. "-sigmoidal-contrast geometry",
  2858. " lightness rescaling using sigmoidal contrast enhancement",
  2859. "-sketch geometry simulate a pencil sketch",
  2860. "-solarize threshold negate all pixels above the threshold level",
  2861. "-splice geometry splice the background color into the image",
  2862. "-spread amount displace image pixels by a random amount",
  2863. "-strip strip image of all profiles and comments",
  2864. "-swirl degrees swirl image pixels about the center",
  2865. "-threshold value threshold the image",
  2866. "-thumbnail geometry create a thumbnail of the image",
  2867. "-tile filename tile image when filling a graphic primitive",
  2868. "-tint value tint the image with the fill color",
  2869. "-transform affine transform image",
  2870. "-transparent color make this color transparent within the image",
  2871. "-transpose flip image vertically and rotate 90 degrees",
  2872. "-transverse flop image horizontally and rotate 270 degrees",
  2873. "-trim trim image edges",
  2874. "-type type image type",
  2875. "-unique-colors discard all but one of any pixel color",
  2876. "-unsharp geometry sharpen the image",
  2877. "-version print version information",
  2878. "-vignette geometry soften the edges of the image in vignette style",
  2879. "-wave geometry alter an image along a sine wave",
  2880. "-white-threshold value",
  2881. " force all pixels above the threshold into white",
  2882. (char *) NULL
  2883. },
  2884. *settings[]=
  2885. {
  2886. "-adjoin join images into a single multi-image file",
  2887. "-affine matrix affine transform matrix",
  2888. "-antialias remove pixel-aliasing",
  2889. "-authenticate value decrypt image with this password",
  2890. "-background color background color",
  2891. "-bias value add bias when convolving an image",
  2892. "-black-point-compensation",
  2893. " use black point compensation",
  2894. "-blue-primary point chromaticity blue primary point",
  2895. "-bordercolor color border color",
  2896. "-caption string assign a caption to an image",
  2897. "-channel type apply option to select image channels",
  2898. "-colors value preferred number of colors in the image",
  2899. "-colorspace type alternate image colorspace",
  2900. "-comment string annotate image with comment",
  2901. "-compose operator set image composite operator",
  2902. "-compress type type of pixel compression when writing the image",
  2903. "-debug events display copious debugging information",
  2904. "-define format:option",
  2905. " define one or more image format options",
  2906. "-delay value display the next image after pausing",
  2907. "-density geometry horizontal and vertical density of the image",
  2908. "-depth value image depth",
  2909. "-display server get image or font from this X server",
  2910. "-dispose method GIF disposal method",
  2911. "-dither apply Floyd/Steinberg error diffusion to image",
  2912. "-encoding type text encoding type",
  2913. "-endian type endianness (MSB or LSB) of the image",
  2914. "-family name render text with this font family",
  2915. "-fill color color to use when filling a graphic primitive",
  2916. "-filter type use this filter when resizing an image",
  2917. "-font name render text with this font",
  2918. "-format type image format type",
  2919. "-fuzz distance colors within this distance are considered equal",
  2920. "-gravity type horizontal and vertical text placement",
  2921. "-green-primary point chromaticity green primary point",
  2922. "-intent type type of rendering intent when managing the image color",
  2923. "-interlace type type of image interlacing scheme",
  2924. "-interpolate method pixel color interpolation method",
  2925. "-label string assign a label to an image",
  2926. "-limit type value pixel cache resource limit",
  2927. "-log format format of debugging information",
  2928. "-loop iterations add Netscape loop extension to your GIF animation",
  2929. "-mask filename associate a mask with the image",
  2930. "-matte store matte channel if the image has one",
  2931. "-mattecolor color frame color",
  2932. "-monitor monitor progress",
  2933. "-orient type image orientation",
  2934. "-origin geometry image origin",
  2935. "-page geometry size and location of an image canvas (setting)",
  2936. "-path path write images to this path on disk",
  2937. "-ping efficiently determine image attributes",
  2938. "-pointsize value font point size",
  2939. "-preview type image preview type",
  2940. "-quality value JPEG/MIFF/PNG compression level",
  2941. "-quiet suppress all error or warning messages",
  2942. "-red-primary point chromaticity red primary point",
  2943. "-regard-warnings pay attention to warning messages",
  2944. "-sampling-factor geometry",
  2945. " horizontal and vertical sampling factor",
  2946. "-scene value image scene number",
  2947. "-seed value pseudo-random number generator seed value",
  2948. "-size geometry width and height of image",
  2949. "-stretch type render text with this font stretch",
  2950. "-stroke color graphic primitive stroke color",
  2951. "-strokewidth value graphic primitive stroke width",
  2952. "-style type render text with this font style",
  2953. "-support factor resize support: > 1.0 is blurry, < 1.0 is sharp",
  2954. "-texture filename name of texture to tile onto the image background",
  2955. "-treedepth value color tree depth",
  2956. "-transparent-color color",
  2957. " transparent color",
  2958. "-undercolor color annotation bounding box color",
  2959. "-units type the units of image resolution",
  2960. "-verbose print detailed information about the image",
  2961. "-view FlashPix viewing transforms",
  2962. "-virtual-pixel method",
  2963. " virtual pixel access method",
  2964. "-weight type render text with this font weight",
  2965. "-white-point point chromaticity white point",
  2966. (char *) NULL
  2967. };
  2968. const char
  2969. **p;
  2970. (void) printf("Version: %s\n",GetMagickVersion((unsigned long *) NULL));
  2971. (void) printf("Copyright: %s\n\n",GetMagickCopyright());
  2972. (void) printf("Usage: %s [options ...] file [ [options ...] file ...]\n",
  2973. GetClientName());
  2974. (void) printf("\nImage Settings:\n");
  2975. for (p=settings; *p != (char *) NULL; p++)
  2976. (void) printf(" %s\n",*p);
  2977. (void) printf("\nImage Operators:\n");
  2978. for (p=operators; *p != (char *) NULL; p++)
  2979. (void) printf(" %s\n",*p);
  2980. (void) printf(
  2981. "\nBy default, the image format of `file' is determined by its magic\n");
  2982. (void) printf(
  2983. "number. To specify a particular image format, precede the filename\n");
  2984. (void) printf(
  2985. "with an image format name and a colon (i.e. ps:image) or specify the\n");
  2986. (void) printf(
  2987. "image type as the filename suffix (i.e. image.ps). Specify 'file' as\n");
  2988. (void) printf("'-' for standard input or output.\n");
  2989. exit(0);
  2990. }
  2991. WandExport MagickBooleanType MogrifyImageCommand(ImageInfo *image_info,
  2992. int argc,char **argv,char **wand_unused(metadata),ExceptionInfo *exception)
  2993. {
  2994. #define DestroyMogrify() \
  2995. { \
  2996. if (format != (char *) NULL) \
  2997. format=(char *) RelinquishMagickMemory(format); \
  2998. if (path != (char *) NULL) \
  2999. path=(char *) RelinquishMagickMemory(path); \
  3000. for ( ; k >= 0; k--) \
  3001. image_stack[k]=DestroyImageList(image_stack[k]); \
  3002. for (i=0; i < (long) argc; i++) \
  3003. argv[i]=(char *) RelinquishMagickMemory(argv[i]); \
  3004. argv=(char **) RelinquishMagickMemory(argv); \
  3005. }
  3006. #define ThrowMogrifyException(asperity,tag,option) \
  3007. { \
  3008. (void) ThrowMagickException(exception,GetMagickModule(),asperity,tag,"`%s'", \
  3009. option); \
  3010. DestroyMogrify(); \
  3011. return(MagickFalse); \
  3012. }
  3013. #define ThrowMogrifyInvalidArgumentException(option,argument) \
  3014. { \
  3015. (void) ThrowMagickException(exception,GetMagickModule(),OptionError, \
  3016. "InvalidArgument","`%s': %s",argument,option); \
  3017. DestroyMogrify(); \
  3018. return(MagickFalse); \
  3019. }
  3020. char
  3021. *format,
  3022. *option,
  3023. *path;
  3024. Image
  3025. *image_stack[MaxImageStackDepth+1];
  3026. long
  3027. j,
  3028. k;
  3029. register long
  3030. i;
  3031. MagickBooleanType
  3032. global_colormap;
  3033. MagickBooleanType
  3034. fire,
  3035. pend;
  3036. MagickStatusType
  3037. status;
  3038. /*
  3039. Set defaults.
  3040. */
  3041. assert(image_info != (ImageInfo *) NULL);
  3042. assert(image_info->signature == MagickSignature);
  3043. if (image_info->debug != MagickFalse)
  3044. (void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
  3045. assert(exception != (ExceptionInfo *) NULL);
  3046. if (argc < 2)
  3047. MogrifyUsage();
  3048. format=(char *) NULL;
  3049. path=(char *) NULL;
  3050. global_colormap=MagickFalse;
  3051. k=0;
  3052. j=1;
  3053. image_stack[k]=NewImageList();
  3054. pend=MagickFalse;
  3055. option=(char *) NULL;
  3056. status=MagickTrue;
  3057. /*
  3058. Parse command line.
  3059. */
  3060. ReadCommandlLine(argc,&argv);
  3061. status=ExpandFilenames(&argc,&argv);
  3062. if (status == MagickFalse)
  3063. {
  3064. char
  3065. *message;
  3066. message=GetExceptionMessage(errno);
  3067. ThrowMogrifyException(ResourceLimitError,"MemoryAllocationFailed",
  3068. message);
  3069. message=(char *) RelinquishMagickMemory(message);
  3070. }
  3071. for (i=1; i < (long) argc; i++)
  3072. {
  3073. option=argv[i];
  3074. if (LocaleCompare(option,"(") == 0)
  3075. {
  3076. if (k == MaxImageStackDepth)
  3077. ThrowMogrifyException(OptionError,"ParenthesisNestedTooDeeply",
  3078. option);
  3079. MogrifyImageStack(image_stack[k],MagickTrue,pend);
  3080. k++;
  3081. image_stack[k]=NewImageList();
  3082. continue;
  3083. }
  3084. if (LocaleCompare(option,")") == 0)
  3085. {
  3086. if (k == 0)
  3087. ThrowMogrifyException(OptionError,"UnableToParseExpression",option);
  3088. if (image_stack[k] != (Image *) NULL)
  3089. {
  3090. MogrifyImageStack(image_stack[k],MagickTrue,MagickTrue);
  3091. AppendImageToList(&image_stack[k-1],image_stack[k]);
  3092. }
  3093. k--;
  3094. continue;
  3095. }
  3096. if (IsMagickOption(option) == MagickFalse)
  3097. {
  3098. char
  3099. *filename;
  3100. Image
  3101. *image;
  3102. /*
  3103. Option is a file name: begin by reading image from specified file.
  3104. */
  3105. MogrifyImageStack(image_stack[k],MagickFalse,pend);
  3106. filename=argv[i];
  3107. if ((LocaleCompare(filename,"--") == 0) && (i < (argc-1)))
  3108. filename=argv[++i];
  3109. (void) CopyMagickString(image_info->filename,filename,MaxTextExtent);
  3110. image=ReadImage(image_info,exception);
  3111. status&=(image != (Image *) NULL) &&
  3112. (exception->severity < ErrorException);
  3113. if (image == (Image *) NULL)
  3114. continue;
  3115. if (format != (char *) NULL)
  3116. AppendImageFormat(format,image->filename);
  3117. if (path != (char *) NULL)
  3118. {
  3119. GetPathComponent(option,TailPath,filename);
  3120. (void) FormatMagickString(image->filename,MaxTextExtent,"%s%c%s",
  3121. path,*DirectorySeparator,filename);
  3122. }
  3123. AppendImageToList(&image_stack[k],image);
  3124. MogrifyImageStack(image_stack[k],MagickFalse,MagickTrue);
  3125. if (global_colormap != MagickFalse)
  3126. (void) MapImages(image,(Image *) NULL,image_info->dither);
  3127. /*
  3128. Write transmogrified image to disk.
  3129. */
  3130. status&=WriteImages(image_info,image_stack[k],image_stack[k]->filename,
  3131. exception);
  3132. image_stack[k]=DestroyImageList(image_stack[k]);
  3133. continue;
  3134. }
  3135. pend=image_stack[k] != (Image *) NULL ? MagickTrue : MagickFalse;
  3136. switch (*(option+1))
  3137. {
  3138. case 'a':
  3139. {
  3140. if (LocaleCompare("adaptive-blur",option+1) == 0)
  3141. {
  3142. i++;
  3143. if (i == (long) argc)
  3144. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3145. if (IsGeometry(argv[i]) == MagickFalse)
  3146. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3147. break;
  3148. }
  3149. if (LocaleCompare("adaptive-resize",option+1) == 0)
  3150. {
  3151. i++;
  3152. if (i == (long) argc)
  3153. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3154. if (IsGeometry(argv[i]) == MagickFalse)
  3155. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3156. break;
  3157. }
  3158. if (LocaleCompare("adaptive-sharpen",option+1) == 0)
  3159. {
  3160. i++;
  3161. if (i == (long) argc)
  3162. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3163. if (IsGeometry(argv[i]) == MagickFalse)
  3164. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3165. break;
  3166. }
  3167. if (LocaleCompare("affine",option+1) == 0)
  3168. {
  3169. if (*option == '+')
  3170. break;
  3171. i++;
  3172. if (i == (long) argc)
  3173. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3174. if (IsGeometry(argv[i]) == MagickFalse)
  3175. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3176. break;
  3177. }
  3178. if (LocaleCompare("annotate",option+1) == 0)
  3179. {
  3180. if (*option == '+')
  3181. break;
  3182. i++;
  3183. if (i == (long) argc)
  3184. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3185. if (IsGeometry(argv[i]) == MagickFalse)
  3186. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3187. if (i == (long) argc)
  3188. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3189. i++;
  3190. break;
  3191. }
  3192. if (LocaleCompare("antialias",option+1) == 0)
  3193. break;
  3194. if (LocaleCompare("authenticate",option+1) == 0)
  3195. {
  3196. if (*option == '+')
  3197. break;
  3198. i++;
  3199. if (i == (long) argc)
  3200. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3201. break;
  3202. }
  3203. if (LocaleCompare("auto-orient",option+1) == 0)
  3204. break;
  3205. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3206. }
  3207. case 'b':
  3208. {
  3209. if (LocaleCompare("background",option+1) == 0)
  3210. {
  3211. if (*option == '+')
  3212. break;
  3213. i++;
  3214. if (i == (long) argc)
  3215. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3216. break;
  3217. }
  3218. if (LocaleCompare("bias",option+1) == 0)
  3219. {
  3220. if (*option == '+')
  3221. break;
  3222. i++;
  3223. if (i == (long) (argc-1))
  3224. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3225. if (IsGeometry(argv[i]) == MagickFalse)
  3226. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3227. break;
  3228. }
  3229. if (LocaleCompare("black-point-compensation",option+1) == 0)
  3230. break;
  3231. if (LocaleCompare("black-threshold",option+1) == 0)
  3232. {
  3233. if (*option == '+')
  3234. break;
  3235. i++;
  3236. if (i == (long) argc)
  3237. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3238. if (IsGeometry(argv[i]) == MagickFalse)
  3239. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3240. break;
  3241. }
  3242. if (LocaleCompare("blue-primary",option+1) == 0)
  3243. {
  3244. if (*option == '+')
  3245. break;
  3246. i++;
  3247. if (i == (long) argc)
  3248. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3249. if (IsGeometry(argv[i]) == MagickFalse)
  3250. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3251. break;
  3252. }
  3253. if (LocaleCompare("blur",option+1) == 0)
  3254. {
  3255. i++;
  3256. if (i == (long) argc)
  3257. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3258. if (IsGeometry(argv[i]) == MagickFalse)
  3259. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3260. break;
  3261. }
  3262. if (LocaleCompare("border",option+1) == 0)
  3263. {
  3264. if (*option == '+')
  3265. break;
  3266. i++;
  3267. if (i == (long) argc)
  3268. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3269. if (IsGeometry(argv[i]) == MagickFalse)
  3270. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3271. break;
  3272. }
  3273. if (LocaleCompare("bordercolor",option+1) == 0)
  3274. {
  3275. if (*option == '+')
  3276. break;
  3277. i++;
  3278. if (i == (long) argc)
  3279. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3280. break;
  3281. }
  3282. if (LocaleCompare("box",option+1) == 0)
  3283. {
  3284. if (*option == '+')
  3285. break;
  3286. i++;
  3287. if (i == (long) argc)
  3288. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3289. break;
  3290. }
  3291. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3292. }
  3293. case 'c':
  3294. {
  3295. if (LocaleCompare("cache",option+1) == 0)
  3296. {
  3297. if (*option == '+')
  3298. break;
  3299. i++;
  3300. if (i == (long) argc)
  3301. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3302. if (IsGeometry(argv[i]) == MagickFalse)
  3303. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3304. break;
  3305. }
  3306. if (LocaleCompare("caption",option+1) == 0)
  3307. {
  3308. if (*option == '+')
  3309. break;
  3310. i++;
  3311. if (i == (long) argc)
  3312. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3313. break;
  3314. }
  3315. if (LocaleCompare("channel",option+1) == 0)
  3316. {
  3317. long
  3318. channel;
  3319. if (*option == '+')
  3320. break;
  3321. i++;
  3322. if (i == (long) (argc-1))
  3323. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3324. channel=ParseChannelOption(argv[i]);
  3325. if (channel < 0)
  3326. ThrowMogrifyException(OptionError,"UnrecognizedChannelType",
  3327. argv[i]);
  3328. break;
  3329. }
  3330. if (LocaleCompare("charcoal",option+1) == 0)
  3331. {
  3332. if (*option == '+')
  3333. break;
  3334. i++;
  3335. if (i == (long) argc)
  3336. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3337. if (IsGeometry(argv[i]) == MagickFalse)
  3338. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3339. break;
  3340. }
  3341. if (LocaleCompare("chop",option+1) == 0)
  3342. {
  3343. if (*option == '+')
  3344. break;
  3345. i++;
  3346. if (i == (long) argc)
  3347. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3348. if (IsGeometry(argv[i]) == MagickFalse)
  3349. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3350. break;
  3351. }
  3352. if (LocaleCompare("clip-mask",option+1) == 0)
  3353. {
  3354. if (*option == '+')
  3355. break;
  3356. i++;
  3357. if (i == (long) argc)
  3358. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3359. break;
  3360. }
  3361. if (LocaleCompare("colorize",option+1) == 0)
  3362. {
  3363. if (*option == '+')
  3364. break;
  3365. i++;
  3366. if (i == (long) argc)
  3367. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3368. if (IsGeometry(argv[i]) == MagickFalse)
  3369. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3370. break;
  3371. }
  3372. if (LocaleCompare("colors",option+1) == 0)
  3373. {
  3374. if (*option == '+')
  3375. break;
  3376. i++;
  3377. if (i == (long) argc)
  3378. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3379. if (IsGeometry(argv[i]) == MagickFalse)
  3380. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3381. break;
  3382. }
  3383. if (LocaleCompare("colorspace",option+1) == 0)
  3384. {
  3385. long
  3386. colorspace;
  3387. if (*option == '+')
  3388. break;
  3389. i++;
  3390. if (i == (long) argc)
  3391. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3392. colorspace=ParseMagickOption(MagickColorspaceOptions,MagickFalse,
  3393. argv[i]);
  3394. if (colorspace < 0)
  3395. ThrowMogrifyException(OptionError,"UnrecognizedColorspace",
  3396. argv[i]);
  3397. break;
  3398. }
  3399. if (LocaleCompare("comment",option+1) == 0)
  3400. {
  3401. if (*option == '+')
  3402. break;
  3403. i++;
  3404. if (i == (long) argc)
  3405. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3406. break;
  3407. }
  3408. if (LocaleCompare("compress",option+1) == 0)
  3409. {
  3410. long
  3411. compression;
  3412. if (*option == '+')
  3413. break;
  3414. i++;
  3415. if (i == (long) argc)
  3416. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3417. compression=ParseMagickOption(MagickCompressionOptions,MagickFalse,
  3418. argv[i]);
  3419. if (compression < 0)
  3420. ThrowMogrifyException(OptionError,"UnrecognizedImageCompression",
  3421. argv[i]);
  3422. break;
  3423. }
  3424. if (LocaleCompare("contrast",option+1) == 0)
  3425. break;
  3426. if (LocaleCompare("contrast-stretch",option+1) == 0)
  3427. {
  3428. i++;
  3429. if (i == (long) argc)
  3430. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3431. if (IsGeometry(argv[i]) == MagickFalse)
  3432. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3433. break;
  3434. }
  3435. if (LocaleCompare("convolve",option+1) == 0)
  3436. {
  3437. if (*option == '+')
  3438. break;
  3439. i++;
  3440. if (i == (long) argc)
  3441. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3442. if (IsGeometry(argv[i]) == MagickFalse)
  3443. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3444. break;
  3445. }
  3446. if (LocaleCompare("crop",option+1) == 0)
  3447. {
  3448. if (*option == '+')
  3449. break;
  3450. i++;
  3451. if (i == (long) argc)
  3452. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3453. if (IsGeometry(argv[i]) == MagickFalse)
  3454. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3455. break;
  3456. }
  3457. if (LocaleCompare("cycle",option+1) == 0)
  3458. {
  3459. if (*option == '+')
  3460. break;
  3461. i++;
  3462. if (i == (long) argc)
  3463. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3464. if (IsGeometry(argv[i]) == MagickFalse)
  3465. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3466. break;
  3467. }
  3468. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3469. }
  3470. case 'd':
  3471. {
  3472. if (LocaleCompare("debug",option+1) == 0)
  3473. {
  3474. long
  3475. event;
  3476. if (*option == '+')
  3477. break;
  3478. i++;
  3479. if (i == (long) argc)
  3480. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3481. event=ParseMagickOption(MagickLogEventOptions,MagickFalse,argv[i]);
  3482. if (event < 0)
  3483. ThrowMogrifyException(OptionError,"UnrecognizedEventType",
  3484. argv[i]);
  3485. (void) SetLogEventMask(argv[i]);
  3486. break;
  3487. }
  3488. if (LocaleCompare("define",option+1) == 0)
  3489. {
  3490. i++;
  3491. if (i == (long) argc)
  3492. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3493. if (*option == '+')
  3494. {
  3495. const char
  3496. *define;
  3497. define=GetImageOption(image_info,argv[i]);
  3498. if (define == (const char *) NULL)
  3499. ThrowMogrifyException(OptionError,"NoSuchOption",argv[i]);
  3500. break;
  3501. }
  3502. break;
  3503. }
  3504. if (LocaleCompare("delay",option+1) == 0)
  3505. {
  3506. if (*option == '+')
  3507. break;
  3508. i++;
  3509. if (i == (long) argc)
  3510. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3511. if (IsGeometry(argv[i]) == MagickFalse)
  3512. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3513. break;
  3514. }
  3515. if (LocaleCompare("density",option+1) == 0)
  3516. {
  3517. if (*option == '+')
  3518. break;
  3519. i++;
  3520. if (i == (long) argc)
  3521. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3522. if (IsGeometry(argv[i]) == MagickFalse)
  3523. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3524. break;
  3525. }
  3526. if (LocaleCompare("depth",option+1) == 0)
  3527. {
  3528. if (*option == '+')
  3529. break;
  3530. i++;
  3531. if (i == (long) argc)
  3532. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3533. if (IsGeometry(argv[i]) == MagickFalse)
  3534. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3535. break;
  3536. }
  3537. if (LocaleCompare("despeckle",option+1) == 0)
  3538. break;
  3539. if (LocaleCompare("display",option+1) == 0)
  3540. {
  3541. if (*option == '+')
  3542. break;
  3543. i++;
  3544. if (i == (long) argc)
  3545. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3546. break;
  3547. }
  3548. if (LocaleCompare("dispose",option+1) == 0)
  3549. {
  3550. long
  3551. dispose;
  3552. if (*option == '+')
  3553. break;
  3554. i++;
  3555. if (i == (long) argc)
  3556. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3557. dispose=ParseMagickOption(MagickDisposeOptions,MagickFalse,argv[i]);
  3558. if (dispose < 0)
  3559. ThrowMogrifyException(OptionError,"UnrecognizedDisposeMethod",
  3560. argv[i]);
  3561. break;
  3562. }
  3563. if (LocaleCompare("dither",option+1) == 0)
  3564. break;
  3565. if (LocaleCompare("draw",option+1) == 0)
  3566. {
  3567. if (*option == '+')
  3568. break;
  3569. i++;
  3570. if (i == (long) argc)
  3571. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3572. break;
  3573. }
  3574. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3575. }
  3576. case 'e':
  3577. {
  3578. if (LocaleCompare("edge",option+1) == 0)
  3579. {
  3580. if (*option == '+')
  3581. break;
  3582. i++;
  3583. if (i == (long) argc)
  3584. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3585. if (IsGeometry(argv[i]) == MagickFalse)
  3586. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3587. break;
  3588. }
  3589. if (LocaleCompare("emboss",option+1) == 0)
  3590. {
  3591. if (*option == '+')
  3592. break;
  3593. i++;
  3594. if (i == (long) argc)
  3595. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3596. if (IsGeometry(argv[i]) == MagickFalse)
  3597. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3598. break;
  3599. }
  3600. if (LocaleCompare("encoding",option+1) == 0)
  3601. {
  3602. if (*option == '+')
  3603. break;
  3604. i++;
  3605. if (i == (long) argc)
  3606. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3607. break;
  3608. }
  3609. if (LocaleCompare("endian",option+1) == 0)
  3610. {
  3611. long
  3612. endian;
  3613. if (*option == '+')
  3614. break;
  3615. i++;
  3616. if (i == (long) argc)
  3617. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3618. endian=ParseMagickOption(MagickEndianOptions,MagickFalse,argv[i]);
  3619. if (endian < 0)
  3620. ThrowMogrifyException(OptionError,"UnrecognizedEndianType",
  3621. argv[i]);
  3622. break;
  3623. }
  3624. if (LocaleCompare("enhance",option+1) == 0)
  3625. break;
  3626. if (LocaleCompare("equalize",option+1) == 0)
  3627. break;
  3628. if (LocaleCompare("evaluate",option+1) == 0)
  3629. {
  3630. long
  3631. op;
  3632. if (*option == '+')
  3633. break;
  3634. i++;
  3635. if (i == (long) argc)
  3636. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3637. op=ParseMagickOption(MagickEvaluateOptions,MagickFalse,argv[i]);
  3638. if (op < 0)
  3639. ThrowMogrifyException(OptionError,
  3640. "UnrecognizedEvaluateOperator",argv[i]);
  3641. i++;
  3642. if (i == (long) (argc-1))
  3643. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3644. if (IsGeometry(argv[i]) == MagickFalse)
  3645. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3646. break;
  3647. }
  3648. if (LocaleCompare("extent",option+1) == 0)
  3649. {
  3650. if (*option == '+')
  3651. break;
  3652. i++;
  3653. if (i == (long) argc)
  3654. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3655. if (IsGeometry(argv[i]) == MagickFalse)
  3656. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3657. break;
  3658. }
  3659. if (LocaleCompare("extract",option+1) == 0)
  3660. {
  3661. if (*option == '+')
  3662. break;
  3663. i++;
  3664. if (i == (long) argc)
  3665. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3666. if (IsGeometry(argv[i]) == MagickFalse)
  3667. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3668. break;
  3669. }
  3670. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3671. }
  3672. case 'f':
  3673. {
  3674. if (LocaleCompare("family",option+1) == 0)
  3675. {
  3676. if (*option == '+')
  3677. break;
  3678. i++;
  3679. if (i == (long) (argc-1))
  3680. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3681. break;
  3682. }
  3683. if (LocaleCompare("fill",option+1) == 0)
  3684. {
  3685. if (*option == '+')
  3686. break;
  3687. i++;
  3688. if (i == (long) argc)
  3689. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3690. break;
  3691. }
  3692. if (LocaleCompare("filter",option+1) == 0)
  3693. {
  3694. long
  3695. filter;
  3696. if (*option == '+')
  3697. break;
  3698. i++;
  3699. if (i == (long) argc)
  3700. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3701. filter=ParseMagickOption(MagickFilterOptions,MagickFalse,argv[i]);
  3702. if (filter < 0)
  3703. ThrowMogrifyException(OptionError,"UnrecognizedImageFilter",
  3704. argv[i]);
  3705. break;
  3706. }
  3707. if (LocaleCompare("flip",option+1) == 0)
  3708. break;
  3709. if (LocaleCompare("flop",option+1) == 0)
  3710. break;
  3711. if (LocaleCompare("floodfill",option+1) == 0)
  3712. {
  3713. if (*option == '+')
  3714. break;
  3715. i++;
  3716. if (i == (long) argc)
  3717. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3718. if (IsGeometry(argv[i]) == MagickFalse)
  3719. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3720. if (i == (long) argc)
  3721. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3722. i++;
  3723. break;
  3724. }
  3725. if (LocaleCompare("font",option+1) == 0)
  3726. {
  3727. if (*option == '+')
  3728. break;
  3729. i++;
  3730. if (i == (long) argc)
  3731. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3732. break;
  3733. }
  3734. if (LocaleCompare("format",option+1) == 0)
  3735. {
  3736. (void) CopyMagickString(argv[i]+1,"sans",MaxTextExtent);
  3737. (void) CloneString(&format,(char *) NULL);
  3738. if (*option == '+')
  3739. break;
  3740. i++;
  3741. if (i == (long) argc)
  3742. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3743. (void) CloneString(&format,argv[i]);
  3744. (void) CopyMagickString(image_info->filename,format,
  3745. MaxTextExtent);
  3746. (void) ConcatenateMagickString(image_info->filename,":",
  3747. MaxTextExtent);
  3748. (void) SetImageInfo(image_info,MagickFalse,exception);
  3749. if (*image_info->magick == '\0')
  3750. ThrowMogrifyException(OptionError,"UnrecognizedImageFormat",
  3751. format);
  3752. break;
  3753. }
  3754. if (LocaleCompare("frame",option+1) == 0)
  3755. {
  3756. if (*option == '+')
  3757. break;
  3758. i++;
  3759. if (i == (long) argc)
  3760. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3761. if (IsGeometry(argv[i]) == MagickFalse)
  3762. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3763. break;
  3764. }
  3765. if (LocaleCompare("fuzz",option+1) == 0)
  3766. {
  3767. if (*option == '+')
  3768. break;
  3769. i++;
  3770. if (i == (long) argc)
  3771. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3772. if (IsGeometry(argv[i]) == MagickFalse)
  3773. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3774. break;
  3775. }
  3776. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3777. }
  3778. case 'g':
  3779. {
  3780. if (LocaleCompare("gamma",option+1) == 0)
  3781. {
  3782. i++;
  3783. if (i == (long) argc)
  3784. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3785. if (IsGeometry(argv[i]) == MagickFalse)
  3786. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3787. break;
  3788. }
  3789. if ((LocaleCompare("gaussian-blur",option+1) == 0) ||
  3790. (LocaleCompare("gaussian",option+1) == 0))
  3791. {
  3792. i++;
  3793. if (i == (long) argc)
  3794. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3795. if (IsGeometry(argv[i]) == MagickFalse)
  3796. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3797. break;
  3798. }
  3799. if (LocaleCompare("geometry",option+1) == 0)
  3800. {
  3801. if (*option == '+')
  3802. break;
  3803. i++;
  3804. if (i == (long) argc)
  3805. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3806. if (IsGeometry(argv[i]) == MagickFalse)
  3807. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3808. break;
  3809. }
  3810. if (LocaleCompare("gravity",option+1) == 0)
  3811. {
  3812. long
  3813. gravity;
  3814. if (*option == '+')
  3815. break;
  3816. i++;
  3817. if (i == (long) argc)
  3818. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3819. gravity=ParseMagickOption(MagickGravityOptions,MagickFalse,argv[i]);
  3820. if (gravity < 0)
  3821. ThrowMogrifyException(OptionError,"UnrecognizedGravityType",
  3822. argv[i]);
  3823. break;
  3824. }
  3825. if (LocaleCompare("green-primary",option+1) == 0)
  3826. {
  3827. if (*option == '+')
  3828. break;
  3829. i++;
  3830. if (i == (long) argc)
  3831. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3832. if (IsGeometry(argv[i]) == MagickFalse)
  3833. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3834. break;
  3835. }
  3836. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3837. }
  3838. case 'h':
  3839. {
  3840. if ((LocaleCompare("help",option+1) == 0) ||
  3841. (LocaleCompare("-help",option+1) == 0))
  3842. MogrifyUsage();
  3843. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3844. }
  3845. case 'i':
  3846. {
  3847. if (LocaleCompare("identify",option+1) == 0)
  3848. break;
  3849. if (LocaleCompare("implode",option+1) == 0)
  3850. {
  3851. if (*option == '+')
  3852. break;
  3853. i++;
  3854. if (i == (long) argc)
  3855. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3856. if (IsGeometry(argv[i]) == MagickFalse)
  3857. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3858. break;
  3859. }
  3860. if (LocaleCompare("intent",option+1) == 0)
  3861. {
  3862. long
  3863. intent;
  3864. if (*option == '+')
  3865. break;
  3866. i++;
  3867. if (i == (long) (argc-1))
  3868. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3869. intent=ParseMagickOption(MagickIntentOptions,MagickFalse,argv[i]);
  3870. if (intent < 0)
  3871. ThrowMogrifyException(OptionError,"UnrecognizedIntentType",
  3872. argv[i]);
  3873. break;
  3874. }
  3875. if (LocaleCompare("interlace",option+1) == 0)
  3876. {
  3877. long
  3878. interlace;
  3879. if (*option == '+')
  3880. break;
  3881. i++;
  3882. if (i == (long) argc)
  3883. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3884. interlace=ParseMagickOption(MagickInterlaceOptions,MagickFalse,
  3885. argv[i]);
  3886. if (interlace < 0)
  3887. ThrowMogrifyException(OptionError,"UnrecognizedInterlaceType",
  3888. argv[i]);
  3889. break;
  3890. }
  3891. if (LocaleCompare("interpolate",option+1) == 0)
  3892. {
  3893. long
  3894. interpolate;
  3895. if (*option == '+')
  3896. break;
  3897. i++;
  3898. if (i == (long) argc)
  3899. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3900. interpolate=ParseMagickOption(MagickInterpolateOptions,MagickFalse,
  3901. argv[i]);
  3902. if (interpolate < 0)
  3903. ThrowMogrifyException(OptionError,"UnrecognizedInterpolateMethod",
  3904. argv[i]);
  3905. break;
  3906. }
  3907. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  3908. }
  3909. case 'l':
  3910. {
  3911. if (LocaleCompare("label",option+1) == 0)
  3912. {
  3913. if (*option == '+')
  3914. break;
  3915. i++;
  3916. if (i == (long) argc)
  3917. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3918. break;
  3919. }
  3920. if (LocaleCompare("lat",option+1) == 0)
  3921. {
  3922. if (*option == '+')
  3923. break;
  3924. i++;
  3925. if (i == (long) argc)
  3926. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3927. if (IsGeometry(argv[i]) == MagickFalse)
  3928. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3929. }
  3930. if (LocaleCompare("layers",option+1) == 0)
  3931. {
  3932. long
  3933. type;
  3934. if (*option == '+')
  3935. break;
  3936. i++;
  3937. if (i == (long) (argc-1))
  3938. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3939. type=ParseMagickOption(MagickLayersOptions,MagickFalse,argv[i]);
  3940. if (type < 0)
  3941. ThrowMogrifyException(OptionError,"UnrecognizedLayerMethod",
  3942. argv[i]);
  3943. break;
  3944. }
  3945. if (LocaleCompare("level",option+1) == 0)
  3946. {
  3947. i++;
  3948. if (i == (long) argc)
  3949. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3950. if (IsGeometry(argv[i]) == MagickFalse)
  3951. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3952. break;
  3953. }
  3954. if (LocaleCompare("linewidth",option+1) == 0)
  3955. {
  3956. if (*option == '+')
  3957. break;
  3958. i++;
  3959. if (i == (long) argc)
  3960. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3961. if (IsGeometry(argv[i]) == MagickFalse)
  3962. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3963. break;
  3964. }
  3965. if (LocaleCompare("limit",option+1) == 0)
  3966. {
  3967. long
  3968. resource;
  3969. if (*option == '+')
  3970. break;
  3971. i++;
  3972. if (i == (long) argc)
  3973. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3974. resource=ParseMagickOption(MagickResourceOptions,MagickFalse,
  3975. argv[i]);
  3976. if (resource < 0)
  3977. ThrowMogrifyException(OptionError,"UnrecognizedResourceType",
  3978. argv[i]);
  3979. i++;
  3980. if (i == (long) argc)
  3981. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3982. if ((LocaleCompare("unlimited",argv[i]) != 0) &&
  3983. (IsGeometry(argv[i]) == MagickFalse))
  3984. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  3985. break;
  3986. }
  3987. if (LocaleCompare("list",option+1) == 0)
  3988. {
  3989. long
  3990. list;
  3991. if (*option == '+')
  3992. break;
  3993. i++;
  3994. if (i == (long) argc)
  3995. ThrowMogrifyException(OptionError,"MissingArgument",option);
  3996. list=ParseMagickOption(MagickListOptions,MagickFalse,argv[i]);
  3997. if (list < 0)
  3998. ThrowMogrifyException(OptionError,"UnrecognizedListType",argv[i]);
  3999. (void) MogrifyImageInfo(image_info,(int) (i-j+1),(const char **)
  4000. argv+j,exception);
  4001. return(MagickTrue);
  4002. }
  4003. if (LocaleCompare("log",option+1) == 0)
  4004. {
  4005. if (*option == '+')
  4006. break;
  4007. i++;
  4008. if ((i == (long) argc) ||
  4009. (strchr(argv[i],'%') == (char *) NULL))
  4010. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4011. break;
  4012. }
  4013. if (LocaleCompare("loop",option+1) == 0)
  4014. {
  4015. if (*option == '+')
  4016. break;
  4017. i++;
  4018. if (i == (long) argc)
  4019. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4020. if (IsGeometry(argv[i]) == MagickFalse)
  4021. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4022. break;
  4023. }
  4024. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4025. }
  4026. case 'm':
  4027. {
  4028. if (LocaleCompare("map",option+1) == 0)
  4029. {
  4030. global_colormap=(*option == '+') ? MagickTrue : MagickFalse;
  4031. if (*option == '+')
  4032. break;
  4033. i++;
  4034. if (i == (long) argc)
  4035. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4036. break;
  4037. }
  4038. if (LocaleCompare("mask",option+1) == 0)
  4039. {
  4040. if (*option == '+')
  4041. break;
  4042. i++;
  4043. if (i == (long) argc)
  4044. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4045. break;
  4046. }
  4047. if (LocaleCompare("matte",option+1) == 0)
  4048. break;
  4049. if (LocaleCompare("mattecolor",option+1) == 0)
  4050. {
  4051. if (*option == '+')
  4052. break;
  4053. i++;
  4054. if (i == (long) argc)
  4055. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4056. break;
  4057. }
  4058. if (LocaleCompare("modulate",option+1) == 0)
  4059. {
  4060. if (*option == '+')
  4061. break;
  4062. i++;
  4063. if (i == (long) argc)
  4064. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4065. if (IsGeometry(argv[i]) == MagickFalse)
  4066. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4067. break;
  4068. }
  4069. if (LocaleCompare("median",option+1) == 0)
  4070. {
  4071. if (*option == '+')
  4072. break;
  4073. i++;
  4074. if (i == (long) argc)
  4075. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4076. if (IsGeometry(argv[i]) == MagickFalse)
  4077. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4078. break;
  4079. }
  4080. if (LocaleCompare("monitor",option+1) == 0)
  4081. break;
  4082. if (LocaleCompare("monochrome",option+1) == 0)
  4083. break;
  4084. if (LocaleCompare("motion-blur",option+1) == 0)
  4085. {
  4086. if (*option == '+')
  4087. break;
  4088. i++;
  4089. if (i == (long) argc)
  4090. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4091. if (IsGeometry(argv[i]) == MagickFalse)
  4092. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4093. break;
  4094. }
  4095. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4096. }
  4097. case 'n':
  4098. {
  4099. if (LocaleCompare("negate",option+1) == 0)
  4100. break;
  4101. if (LocaleCompare("noise",option+1) == 0)
  4102. {
  4103. i++;
  4104. if (i == (long) argc)
  4105. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4106. if (*option == '+')
  4107. {
  4108. long
  4109. noise;
  4110. noise=ParseMagickOption(MagickNoiseOptions,MagickFalse,argv[i]);
  4111. if (noise < 0)
  4112. ThrowMogrifyException(OptionError,"UnrecognizedNoiseType",
  4113. argv[i]);
  4114. break;
  4115. }
  4116. if (IsGeometry(argv[i]) == MagickFalse)
  4117. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4118. break;
  4119. }
  4120. if (LocaleCompare("noop",option+1) == 0)
  4121. break;
  4122. if (LocaleCompare("normalize",option+1) == 0)
  4123. break;
  4124. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4125. }
  4126. case 'o':
  4127. {
  4128. if (LocaleCompare("opaque",option+1) == 0)
  4129. {
  4130. if (*option == '+')
  4131. break;
  4132. i++;
  4133. if (i == (long) argc)
  4134. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4135. break;
  4136. }
  4137. if (LocaleCompare("ordered-dither",option+1) == 0)
  4138. {
  4139. if (*option == '+')
  4140. break;
  4141. i++;
  4142. if (i == (long) argc)
  4143. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4144. break;
  4145. }
  4146. if (LocaleCompare("orient",option+1) == 0)
  4147. {
  4148. long
  4149. orientation;
  4150. orientation=UndefinedOrientation;
  4151. if (*option == '+')
  4152. break;
  4153. i++;
  4154. if (i == (long) (argc-1))
  4155. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4156. orientation=ParseMagickOption(MagickOrientationOptions,MagickFalse,
  4157. argv[i]);
  4158. if (orientation < 0)
  4159. ThrowMogrifyException(OptionError,"UnrecognizedImageOrientation",
  4160. argv[i]);
  4161. break;
  4162. }
  4163. if (LocaleCompare("origin",option+1) == 0)
  4164. {
  4165. if (*option == '+')
  4166. break;
  4167. i++;
  4168. if (i == (long) argc)
  4169. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4170. if (IsGeometry(argv[i]) == MagickFalse)
  4171. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4172. break;
  4173. }
  4174. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4175. }
  4176. case 'p':
  4177. {
  4178. if (LocaleCompare("page",option+1) == 0)
  4179. {
  4180. if (*option == '+')
  4181. break;
  4182. i++;
  4183. if (i == (long) argc)
  4184. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4185. break;
  4186. }
  4187. if (LocaleCompare("paint",option+1) == 0)
  4188. {
  4189. if (*option == '+')
  4190. break;
  4191. i++;
  4192. if (i == (long) argc)
  4193. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4194. if (IsGeometry(argv[i]) == MagickFalse)
  4195. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4196. break;
  4197. }
  4198. if (LocaleCompare("path",option+1) == 0)
  4199. {
  4200. (void) CloneString(&path,(char *) NULL);
  4201. if (*option == '+')
  4202. break;
  4203. i++;
  4204. if (i == (long) argc)
  4205. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4206. (void) CloneString(&path,argv[i]);
  4207. break;
  4208. }
  4209. if (LocaleCompare("pointsize",option+1) == 0)
  4210. {
  4211. if (*option == '+')
  4212. break;
  4213. i++;
  4214. if (i == (long) argc)
  4215. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4216. if (IsGeometry(argv[i]) == MagickFalse)
  4217. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4218. break;
  4219. }
  4220. if (LocaleCompare("polaroid",option+1) == 0)
  4221. {
  4222. if (*option == '+')
  4223. break;
  4224. i++;
  4225. if (i == (long) argc)
  4226. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4227. if (IsGeometry(argv[i]) == MagickFalse)
  4228. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4229. break;
  4230. }
  4231. if (LocaleCompare("posterize",option+1) == 0)
  4232. {
  4233. if (*option == '+')
  4234. break;
  4235. i++;
  4236. if (i == (long) argc)
  4237. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4238. if (IsGeometry(argv[i]) == MagickFalse)
  4239. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4240. break;
  4241. }
  4242. if (LocaleCompare("print",option+1) == 0)
  4243. {
  4244. if (*option == '+')
  4245. break;
  4246. i++;
  4247. if (i == (long) argc)
  4248. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4249. break;
  4250. }
  4251. if (LocaleCompare("profile",option+1) == 0)
  4252. {
  4253. i++;
  4254. if (i == (long) argc)
  4255. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4256. break;
  4257. }
  4258. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4259. }
  4260. case 'q':
  4261. {
  4262. if (LocaleCompare("quality",option+1) == 0)
  4263. {
  4264. if (*option == '+')
  4265. break;
  4266. i++;
  4267. if (i == (long) argc)
  4268. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4269. if (IsGeometry(argv[i]) == MagickFalse)
  4270. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4271. break;
  4272. }
  4273. if (LocaleCompare("quantize",option+1) == 0)
  4274. {
  4275. long
  4276. colorspace;
  4277. if (*option == '+')
  4278. break;
  4279. i++;
  4280. if (i == (long) (argc-1))
  4281. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4282. colorspace=ParseMagickOption(MagickColorspaceOptions,MagickFalse,
  4283. argv[i]);
  4284. if (colorspace < 0)
  4285. ThrowMogrifyException(OptionError,"UnrecognizedColorspace",
  4286. argv[i]);
  4287. break;
  4288. }
  4289. if (LocaleCompare("quiet",option+1) == 0)
  4290. break;
  4291. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4292. }
  4293. case 'r':
  4294. {
  4295. if (LocaleCompare("radial-blur",option+1) == 0)
  4296. {
  4297. i++;
  4298. if (i == (long) argc)
  4299. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4300. if (IsGeometry(argv[i]) == MagickFalse)
  4301. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4302. break;
  4303. }
  4304. if (LocaleCompare("raise",option+1) == 0)
  4305. {
  4306. i++;
  4307. if (i == (long) argc)
  4308. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4309. if (IsGeometry(argv[i]) == MagickFalse)
  4310. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4311. break;
  4312. }
  4313. if (LocaleCompare("random-threshold",option+1) == 0)
  4314. {
  4315. if (*option == '+')
  4316. break;
  4317. i++;
  4318. if (i == (long) argc)
  4319. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4320. if (IsGeometry(argv[i]) == MagickFalse)
  4321. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4322. break;
  4323. }
  4324. if (LocaleCompare("red-primary",option+1) == 0)
  4325. {
  4326. if (*option == '+')
  4327. break;
  4328. i++;
  4329. if (i == (long) argc)
  4330. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4331. if (IsGeometry(argv[i]) == MagickFalse)
  4332. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4333. }
  4334. if (LocaleCompare("region",option+1) == 0)
  4335. {
  4336. if (*option == '+')
  4337. break;
  4338. i++;
  4339. if (i == (long) argc)
  4340. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4341. if (IsGeometry(argv[i]) == MagickFalse)
  4342. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4343. break;
  4344. }
  4345. if (LocaleCompare("render",option+1) == 0)
  4346. break;
  4347. if (LocaleCompare("repage",option+1) == 0)
  4348. {
  4349. if (*option == '+')
  4350. break;
  4351. i++;
  4352. if (i == (long) argc)
  4353. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4354. if (IsGeometry(argv[i]) == MagickFalse)
  4355. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4356. break;
  4357. }
  4358. if (LocaleCompare("resample",option+1) == 0)
  4359. {
  4360. if (*option == '+')
  4361. break;
  4362. i++;
  4363. if (i == (long) argc)
  4364. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4365. if (IsGeometry(argv[i]) == MagickFalse)
  4366. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4367. break;
  4368. }
  4369. if (LocaleCompare("resize",option+1) == 0)
  4370. {
  4371. if (*option == '+')
  4372. break;
  4373. i++;
  4374. if (i == (long) argc)
  4375. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4376. if (IsGeometry(argv[i]) == MagickFalse)
  4377. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4378. break;
  4379. }
  4380. if (LocaleCompare("roll",option+1) == 0)
  4381. {
  4382. if (*option == '+')
  4383. break;
  4384. i++;
  4385. if (i == (long) argc)
  4386. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4387. if (IsGeometry(argv[i]) == MagickFalse)
  4388. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4389. break;
  4390. }
  4391. if (LocaleCompare("rotate",option+1) == 0)
  4392. {
  4393. i++;
  4394. if (i == (long) argc)
  4395. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4396. if (IsGeometry(argv[i]) == MagickFalse)
  4397. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4398. break;
  4399. }
  4400. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4401. }
  4402. case 's':
  4403. {
  4404. if (LocaleCompare("sample",option+1) == 0)
  4405. {
  4406. if (*option == '+')
  4407. break;
  4408. i++;
  4409. if (i == (long) argc)
  4410. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4411. if (IsGeometry(argv[i]) == MagickFalse)
  4412. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4413. break;
  4414. }
  4415. if (LocaleCompare("sampling-factor",option+1) == 0)
  4416. {
  4417. if (*option == '+')
  4418. break;
  4419. i++;
  4420. if (i == (long) argc)
  4421. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4422. if (IsGeometry(argv[i]) == MagickFalse)
  4423. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4424. break;
  4425. }
  4426. if (LocaleCompare("scale",option+1) == 0)
  4427. {
  4428. if (*option == '+')
  4429. break;
  4430. i++;
  4431. if (i == (long) argc)
  4432. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4433. if (IsGeometry(argv[i]) == MagickFalse)
  4434. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4435. break;
  4436. }
  4437. if (LocaleCompare("scene",option+1) == 0)
  4438. {
  4439. if (*option == '+')
  4440. break;
  4441. i++;
  4442. if (i == (long) argc)
  4443. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4444. if (IsGeometry(argv[i]) == MagickFalse)
  4445. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4446. break;
  4447. }
  4448. if (LocaleCompare("seed",option+1) == 0)
  4449. {
  4450. unsigned long
  4451. seed;
  4452. if (*option == '+')
  4453. break;
  4454. i++;
  4455. if (i == (long) argc)
  4456. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4457. if (IsGeometry(argv[i]) == MagickFalse)
  4458. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4459. seed=(unsigned long) atol(argv[i]);
  4460. DistillRandomEvent((unsigned char *) &seed,sizeof(seed));
  4461. break;
  4462. }
  4463. if (LocaleCompare("segment",option+1) == 0)
  4464. {
  4465. if (*option == '+')
  4466. break;
  4467. i++;
  4468. if (i == (long) argc)
  4469. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4470. if (IsGeometry(argv[i]) == MagickFalse)
  4471. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4472. break;
  4473. }
  4474. if (LocaleCompare("separate",option+1) == 0)
  4475. break;
  4476. if (LocaleCompare("sepia-tone",option+1) == 0)
  4477. {
  4478. if (*option == '+')
  4479. break;
  4480. i++;
  4481. if (i == (long) argc)
  4482. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4483. if (IsGeometry(argv[i]) == MagickFalse)
  4484. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4485. break;
  4486. }
  4487. if (LocaleCompare("set",option+1) == 0)
  4488. {
  4489. i++;
  4490. if (i == (long) argc)
  4491. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4492. if (*option == '+')
  4493. break;
  4494. i++;
  4495. if (i == (long) argc)
  4496. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4497. break;
  4498. }
  4499. if (LocaleCompare("shade",option+1) == 0)
  4500. {
  4501. i++;
  4502. if (i == (long) argc)
  4503. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4504. if (IsGeometry(argv[i]) == MagickFalse)
  4505. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4506. break;
  4507. }
  4508. if (LocaleCompare("shadow",option+1) == 0)
  4509. {
  4510. if (*option == '+')
  4511. break;
  4512. i++;
  4513. if (i == (long) argc)
  4514. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4515. if (IsGeometry(argv[i]) == MagickFalse)
  4516. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4517. break;
  4518. }
  4519. if (LocaleCompare("sharpen",option+1) == 0)
  4520. {
  4521. i++;
  4522. if (i == (long) argc)
  4523. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4524. if (IsGeometry(argv[i]) == MagickFalse)
  4525. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4526. break;
  4527. }
  4528. if (LocaleCompare("shave",option+1) == 0)
  4529. {
  4530. if (*option == '+')
  4531. break;
  4532. i++;
  4533. if (i == (long) argc)
  4534. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4535. if (IsGeometry(argv[i]) == MagickFalse)
  4536. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4537. break;
  4538. }
  4539. if (LocaleCompare("shear",option+1) == 0)
  4540. {
  4541. i++;
  4542. if (i == (long) argc)
  4543. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4544. if (IsGeometry(argv[i]) == MagickFalse)
  4545. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4546. break;
  4547. }
  4548. if (LocaleCompare("sigmoidal-contrast",option+1) == 0)
  4549. {
  4550. i++;
  4551. if (i == (long) (argc-1))
  4552. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4553. if (IsGeometry(argv[i]) == MagickFalse)
  4554. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4555. break;
  4556. }
  4557. if (LocaleCompare("size",option+1) == 0)
  4558. {
  4559. if (*option == '+')
  4560. break;
  4561. i++;
  4562. if (i == (long) argc)
  4563. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4564. if (IsGeometry(argv[i]) == MagickFalse)
  4565. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4566. break;
  4567. }
  4568. if (LocaleCompare("sketch",option+1) == 0)
  4569. {
  4570. if (*option == '+')
  4571. break;
  4572. i++;
  4573. if (i == (long) argc)
  4574. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4575. if (IsGeometry(argv[i]) == MagickFalse)
  4576. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4577. break;
  4578. }
  4579. if (LocaleCompare("solarize",option+1) == 0)
  4580. {
  4581. if (*option == '+')
  4582. break;
  4583. i++;
  4584. if (i == (long) argc)
  4585. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4586. if (IsGeometry(argv[i]) == MagickFalse)
  4587. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4588. break;
  4589. }
  4590. if (LocaleCompare("spread",option+1) == 0)
  4591. {
  4592. if (*option == '+')
  4593. break;
  4594. i++;
  4595. if (i == (long) argc)
  4596. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4597. if (IsGeometry(argv[i]) == MagickFalse)
  4598. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4599. break;
  4600. }
  4601. if (LocaleCompare("stretch",option+1) == 0)
  4602. {
  4603. long
  4604. stretch;
  4605. if (*option == '+')
  4606. break;
  4607. i++;
  4608. if (i == (long) (argc-1))
  4609. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4610. stretch=ParseMagickOption(MagickStretchOptions,MagickFalse,argv[i]);
  4611. if (stretch < 0)
  4612. ThrowMogrifyException(OptionError,"UnrecognizedStyleType",
  4613. argv[i]);
  4614. break;
  4615. }
  4616. if (LocaleCompare("strip",option+1) == 0)
  4617. break;
  4618. if (LocaleCompare("stroke",option+1) == 0)
  4619. {
  4620. if (*option == '+')
  4621. break;
  4622. i++;
  4623. if (i == (long) argc)
  4624. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4625. break;
  4626. }
  4627. if (LocaleCompare("strokewidth",option+1) == 0)
  4628. {
  4629. if (*option == '+')
  4630. break;
  4631. i++;
  4632. if (i == (long) argc)
  4633. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4634. if (IsGeometry(argv[i]) == MagickFalse)
  4635. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4636. break;
  4637. }
  4638. if (LocaleCompare("style",option+1) == 0)
  4639. {
  4640. long
  4641. style;
  4642. if (*option == '+')
  4643. break;
  4644. i++;
  4645. if (i == (long) (argc-1))
  4646. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4647. style=ParseMagickOption(MagickStyleOptions,MagickFalse,argv[i]);
  4648. if (style < 0)
  4649. ThrowMogrifyException(OptionError,"UnrecognizedStyleType",
  4650. argv[i]);
  4651. break;
  4652. }
  4653. if (LocaleCompare("support",option+1) == 0)
  4654. {
  4655. if (*option == '+')
  4656. break;
  4657. i++;
  4658. if (i == (long) argc)
  4659. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4660. if (IsGeometry(argv[i]) == MagickFalse)
  4661. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4662. break;
  4663. }
  4664. if (LocaleCompare("swirl",option+1) == 0)
  4665. {
  4666. if (*option == '+')
  4667. break;
  4668. i++;
  4669. if (i == (long) argc)
  4670. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4671. if (IsGeometry(argv[i]) == MagickFalse)
  4672. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4673. break;
  4674. }
  4675. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4676. }
  4677. case 't':
  4678. {
  4679. if (LocaleCompare("texture",option+1) == 0)
  4680. {
  4681. if (*option == '+')
  4682. break;
  4683. i++;
  4684. if (i == (long) argc)
  4685. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4686. break;
  4687. }
  4688. if (LocaleCompare("tile",option+1) == 0)
  4689. {
  4690. if (*option == '+')
  4691. break;
  4692. i++;
  4693. if (i == (long) (argc-1))
  4694. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4695. break;
  4696. }
  4697. if (LocaleCompare("tint",option+1) == 0)
  4698. {
  4699. if (*option == '+')
  4700. break;
  4701. i++;
  4702. if (i == (long) (argc-1))
  4703. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4704. if (IsGeometry(argv[i]) == MagickFalse)
  4705. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4706. break;
  4707. }
  4708. if (LocaleCompare("transform",option+1) == 0)
  4709. break;
  4710. if (LocaleCompare("transpose",option+1) == 0)
  4711. break;
  4712. if (LocaleCompare("transverse",option+1) == 0)
  4713. break;
  4714. if (LocaleCompare("threshold",option+1) == 0)
  4715. {
  4716. if (*option == '+')
  4717. break;
  4718. i++;
  4719. if (i == (long) argc)
  4720. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4721. if (IsGeometry(argv[i]) == MagickFalse)
  4722. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4723. break;
  4724. }
  4725. if (LocaleCompare("thumbnail",option+1) == 0)
  4726. {
  4727. if (*option == '+')
  4728. break;
  4729. i++;
  4730. if (i == (long) argc)
  4731. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4732. if (IsGeometry(argv[i]) == MagickFalse)
  4733. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4734. break;
  4735. }
  4736. if (LocaleCompare("transparent",option+1) == 0)
  4737. {
  4738. if (*option == '+')
  4739. break;
  4740. i++;
  4741. if (i == (long) argc)
  4742. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4743. break;
  4744. }
  4745. if (LocaleCompare("transparent-color",option+1) == 0)
  4746. {
  4747. if (*option == '+')
  4748. break;
  4749. i++;
  4750. if (i == (long) (argc-1))
  4751. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4752. break;
  4753. }
  4754. if (LocaleCompare("treedepth",option+1) == 0)
  4755. {
  4756. if (*option == '+')
  4757. break;
  4758. i++;
  4759. if (i == (long) argc)
  4760. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4761. if (IsGeometry(argv[i]) == MagickFalse)
  4762. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4763. break;
  4764. }
  4765. if (LocaleCompare("trim",option+1) == 0)
  4766. break;
  4767. if (LocaleCompare("type",option+1) == 0)
  4768. {
  4769. long
  4770. type;
  4771. if (*option == '+')
  4772. break;
  4773. i++;
  4774. if (i == (long) argc)
  4775. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4776. type=ParseMagickOption(MagickImageOptions,MagickFalse,argv[i]);
  4777. if (type < 0)
  4778. ThrowMogrifyException(OptionError,"UnrecognizedImageType",
  4779. argv[i]);
  4780. break;
  4781. }
  4782. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4783. }
  4784. case 'u':
  4785. {
  4786. if (LocaleCompare("undercolor",option+1) == 0)
  4787. {
  4788. if (*option == '+')
  4789. break;
  4790. i++;
  4791. if (i == (long) argc)
  4792. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4793. break;
  4794. }
  4795. if (LocaleCompare("unique-colors",option+1) == 0)
  4796. break;
  4797. if (LocaleCompare("units",option+1) == 0)
  4798. {
  4799. long
  4800. units;
  4801. if (*option == '+')
  4802. break;
  4803. i++;
  4804. if (i == (long) argc)
  4805. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4806. units=ParseMagickOption(MagickResolutionOptions,MagickFalse,
  4807. argv[i]);
  4808. if (units < 0)
  4809. ThrowMogrifyException(OptionError,"UnrecognizedUnitsType",
  4810. argv[i]);
  4811. break;
  4812. }
  4813. if (LocaleCompare("unsharp",option+1) == 0)
  4814. {
  4815. i++;
  4816. if (i == (long) argc)
  4817. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4818. if (IsGeometry(argv[i]) == MagickFalse)
  4819. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4820. break;
  4821. }
  4822. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4823. }
  4824. case 'v':
  4825. {
  4826. if (LocaleCompare("verbose",option+1) == 0)
  4827. {
  4828. image_info->verbose=(*option == '-') ? MagickTrue : MagickFalse;
  4829. break;
  4830. }
  4831. if ((LocaleCompare("version",option+1) == 0) ||
  4832. (LocaleCompare("-version",option+1) == 0))
  4833. break;
  4834. if (LocaleCompare("view",option+1) == 0)
  4835. {
  4836. if (*option == '+')
  4837. break;
  4838. i++;
  4839. if (i == (long) argc)
  4840. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4841. break;
  4842. }
  4843. if (LocaleCompare("vignette",option+1) == 0)
  4844. {
  4845. if (*option == '+')
  4846. break;
  4847. i++;
  4848. if (i == (long) argc)
  4849. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4850. if (IsGeometry(argv[i]) == MagickFalse)
  4851. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4852. break;
  4853. }
  4854. if (LocaleCompare("virtual-pixel",option+1) == 0)
  4855. {
  4856. long
  4857. method;
  4858. if (*option == '+')
  4859. break;
  4860. i++;
  4861. if (i == (long) argc)
  4862. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4863. method=ParseMagickOption(MagickVirtualPixelOptions,MagickFalse,
  4864. argv[i]);
  4865. if (method < 0)
  4866. ThrowMogrifyException(OptionError,
  4867. "UnrecognizedVirtualPixelMethod",argv[i]);
  4868. break;
  4869. }
  4870. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4871. }
  4872. case 'w':
  4873. {
  4874. if (LocaleCompare("wave",option+1) == 0)
  4875. {
  4876. i++;
  4877. if (i == (long) argc)
  4878. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4879. if (IsGeometry(argv[i]) == MagickFalse)
  4880. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4881. break;
  4882. }
  4883. if (LocaleCompare("weight",option+1) == 0)
  4884. {
  4885. if (*option == '+')
  4886. break;
  4887. i++;
  4888. if (i == (long) (argc-1))
  4889. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4890. break;
  4891. }
  4892. if (LocaleCompare("white-point",option+1) == 0)
  4893. {
  4894. if (*option == '+')
  4895. break;
  4896. i++;
  4897. if (i == (long) argc)
  4898. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4899. if (IsGeometry(argv[i]) == MagickFalse)
  4900. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4901. break;
  4902. }
  4903. if (LocaleCompare("white-threshold",option+1) == 0)
  4904. {
  4905. if (*option == '+')
  4906. break;
  4907. i++;
  4908. if (i == (long) argc)
  4909. ThrowMogrifyException(OptionError,"MissingArgument",option);
  4910. if (IsGeometry(argv[i]) == MagickFalse)
  4911. ThrowMogrifyInvalidArgumentException(option,argv[i]);
  4912. break;
  4913. }
  4914. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4915. }
  4916. case '?':
  4917. break;
  4918. default:
  4919. ThrowMogrifyException(OptionError,"UnrecognizedOption",option)
  4920. }
  4921. fire=(MagickBooleanType) ParseMagickOption(MagickMogrifyOptions,MagickFalse,
  4922. option+1);
  4923. if (fire == MagickTrue)
  4924. MogrifyImageStack(image_stack[k],MagickTrue,MagickTrue);
  4925. }
  4926. if (k != 0)
  4927. ThrowMogrifyException(OptionError,"UnbalancedParenthesis",argv[i]);
  4928. if (i != argc)
  4929. ThrowMogrifyException(OptionError,"MissingAnImageFilename",argv[i]);
  4930. DestroyMogrify();
  4931. return(status != 0 ? MagickTrue : MagickFalse);
  4932. }
  4933. /*
  4934. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  4935. % %
  4936. % %
  4937. % %
  4938. + M o g r i f y I m a g e I n f o %
  4939. % %
  4940. % %
  4941. % %
  4942. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  4943. %
  4944. % MogrifyImageInfo() applies image processing settings to the image as
  4945. % prescribed by command line options.
  4946. %
  4947. % The format of the MogrifyImageInfo method is:
  4948. %
  4949. % MagickBooleanType MogrifyImageInfo(ImageInfo *image_info,const int argc,
  4950. % const char **argv,ExceptionInfo *exception)
  4951. %
  4952. % A description of each parameter follows:
  4953. %
  4954. % o image_info: The image info..
  4955. %
  4956. % o argc: Specifies a pointer to an integer describing the number of
  4957. % elements in the argument vector.
  4958. %
  4959. % o argv: Specifies a pointer to a text array containing the command line
  4960. % arguments.
  4961. %
  4962. % o exception: Return any errors or warnings in this structure.
  4963. %
  4964. */
  4965. WandExport MagickBooleanType MogrifyImageInfo(ImageInfo *image_info,
  4966. const int argc,const char **argv,ExceptionInfo *exception)
  4967. {
  4968. const char
  4969. *option;
  4970. GeometryInfo
  4971. geometry_info;
  4972. long
  4973. count;
  4974. register long
  4975. i;
  4976. /*
  4977. Initialize method variables.
  4978. */
  4979. assert(image_info != (ImageInfo *) NULL);
  4980. assert(image_info->signature == MagickSignature);
  4981. if (image_info->debug != MagickFalse)
  4982. (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",
  4983. image_info->filename);
  4984. if (argc < 0)
  4985. return(MagickTrue);
  4986. for (i=0; i < (long) argc; i++)
  4987. if (strlen(argv[i]) > (MaxTextExtent/2-1))
  4988. ThrowWandFatalException(OptionFatalError,"OptionLengthExceedsLimit",
  4989. argv[i]);
  4990. /*
  4991. Set the image settings.
  4992. */
  4993. for (i=0; i < (long) argc; i++)
  4994. {
  4995. option=argv[i];
  4996. if (IsMagickOption(option) == MagickFalse)
  4997. continue;
  4998. count=MagickMax(ParseMagickOption(MagickCommandOptions,MagickFalse,option),
  4999. 0L);
  5000. if ((i+count) >= argc)
  5001. break;
  5002. switch (*(option+1))
  5003. {
  5004. case 'a':
  5005. {
  5006. if (LocaleCompare("adjoin",option+1) == 0)
  5007. {
  5008. image_info->adjoin=(*option == '-') ? MagickTrue : MagickFalse;
  5009. break;
  5010. }
  5011. if (LocaleCompare("antialias",option+1) == 0)
  5012. {
  5013. image_info->antialias=(*option == '-') ? MagickTrue : MagickFalse;
  5014. break;
  5015. }
  5016. if (LocaleCompare("authenticate",option+1) == 0)
  5017. {
  5018. if (*option == '+')
  5019. (void) CloneString(&image_info->authenticate,(char *) NULL);
  5020. else
  5021. (void) CloneString(&image_info->authenticate,argv[i+1]);
  5022. break;
  5023. }
  5024. break;
  5025. }
  5026. case 'b':
  5027. {
  5028. if (LocaleCompare("background",option+1) == 0)
  5029. {
  5030. if (*option == '+')
  5031. {
  5032. (void) QueryColorDatabase(BackgroundColor,
  5033. &image_info->background_color,exception);
  5034. break;
  5035. }
  5036. (void) QueryColorDatabase(argv[i+1],&image_info->background_color,
  5037. exception);
  5038. break;
  5039. }
  5040. if (LocaleCompare("bordercolor",option+1) == 0)
  5041. {
  5042. if (*option == '+')
  5043. {
  5044. (void) QueryColorDatabase(BorderColor,&image_info->border_color,
  5045. exception);
  5046. break;
  5047. }
  5048. (void) QueryColorDatabase(argv[i+1],&image_info->border_color,
  5049. exception);
  5050. break;
  5051. }
  5052. if (LocaleCompare("box",option+1) == 0)
  5053. {
  5054. if (*option == '+')
  5055. {
  5056. (void) SetImageOption(image_info,"undercolor","none");
  5057. break;
  5058. }
  5059. (void) SetImageOption(image_info,"undercolor",argv[i+1]);
  5060. break;
  5061. }
  5062. break;
  5063. }
  5064. case 'c':
  5065. {
  5066. if (LocaleCompare("cache",option+1) == 0)
  5067. {
  5068. unsigned long
  5069. limit;
  5070. limit=(~0UL);
  5071. if (LocaleCompare("unlimited",argv[i+1]) != 0)
  5072. limit=(unsigned long) atol(argv[i+1]);
  5073. (void) SetMagickResourceLimit(MemoryResource,limit);
  5074. (void) SetMagickResourceLimit(MapResource,2*limit);
  5075. break;
  5076. }
  5077. if (LocaleCompare("caption",option+1) == 0)
  5078. {
  5079. if (*option == '+')
  5080. {
  5081. (void) RemoveImageOption(image_info,option+1);
  5082. break;
  5083. }
  5084. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5085. break;
  5086. }
  5087. if (LocaleCompare("channel",option+1) == 0)
  5088. {
  5089. if (*option == '+')
  5090. {
  5091. image_info->channel=DefaultChannels;
  5092. break;
  5093. }
  5094. image_info->channel=(ChannelType) ParseChannelOption(argv[i+1]);
  5095. break;
  5096. }
  5097. if (LocaleCompare("colors",option+1) == 0)
  5098. {
  5099. image_info->colors=(unsigned long) atol(argv[i+1]);
  5100. break;
  5101. }
  5102. if (LocaleCompare("colorspace",option+1) == 0)
  5103. {
  5104. if (*option == '+')
  5105. {
  5106. image_info->colorspace=UndefinedColorspace;
  5107. break;
  5108. }
  5109. image_info->colorspace=(ColorspaceType) ParseMagickOption(
  5110. MagickColorspaceOptions,MagickFalse,argv[i+1]);
  5111. break;
  5112. }
  5113. if (LocaleCompare("comment",option+1) == 0)
  5114. {
  5115. if (*option == '+')
  5116. {
  5117. (void) RemoveImageOption(image_info,option+1);
  5118. break;
  5119. }
  5120. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5121. break;
  5122. }
  5123. if (LocaleCompare("compress",option+1) == 0)
  5124. {
  5125. if (*option == '+')
  5126. {
  5127. image_info->compression=UndefinedCompression;
  5128. break;
  5129. }
  5130. image_info->compression=(CompressionType) ParseMagickOption(
  5131. MagickCompressionOptions,MagickFalse,argv[i+1]);
  5132. break;
  5133. }
  5134. break;
  5135. }
  5136. case 'd':
  5137. {
  5138. if (LocaleCompare("debug",option+1) == 0)
  5139. {
  5140. if (*option == '+')
  5141. (void) SetLogEventMask("none");
  5142. else
  5143. (void) SetLogEventMask(argv[i+1]);
  5144. image_info->debug=IsEventLogging();
  5145. break;
  5146. }
  5147. if (LocaleCompare("define",option+1) == 0)
  5148. {
  5149. if (*option == '+')
  5150. {
  5151. (void) RemoveImageOption(image_info,argv[i+1]);
  5152. break;
  5153. }
  5154. (void) DefineImageOption(image_info,argv[i+1]);
  5155. break;
  5156. }
  5157. if (LocaleCompare("delay",option+1) == 0)
  5158. {
  5159. if (*option == '+')
  5160. {
  5161. (void) RemoveImageOption(image_info,option+1);
  5162. break;
  5163. }
  5164. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5165. break;
  5166. }
  5167. if (LocaleCompare("density",option+1) == 0)
  5168. {
  5169. /*
  5170. Set image density.
  5171. */
  5172. if (*option == '+')
  5173. {
  5174. image_info->density=(char *) RelinquishMagickMemory(
  5175. image_info->density);
  5176. break;
  5177. }
  5178. (void) CloneString(&image_info->density,argv[i+1]);
  5179. break;
  5180. }
  5181. if (LocaleCompare("depth",option+1) == 0)
  5182. {
  5183. if (*option == '+')
  5184. {
  5185. image_info->depth=QuantumDepth;
  5186. break;
  5187. }
  5188. image_info->depth=(unsigned long) atol(argv[i+1]);
  5189. break;
  5190. }
  5191. if (LocaleCompare("display",option+1) == 0)
  5192. {
  5193. if (*option == '+')
  5194. {
  5195. image_info->server_name=(char *) RelinquishMagickMemory(
  5196. image_info->server_name);
  5197. break;
  5198. }
  5199. (void) CloneString(&image_info->server_name,argv[i+1]);
  5200. break;
  5201. }
  5202. if (LocaleCompare("dispose",option+1) == 0)
  5203. {
  5204. if (*option == '+')
  5205. {
  5206. (void) RemoveImageOption(image_info,option+1);
  5207. break;
  5208. }
  5209. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5210. break;
  5211. }
  5212. if (LocaleCompare("dither",option+1) == 0)
  5213. {
  5214. image_info->dither=(*option == '-') ? MagickTrue : MagickFalse;
  5215. break;
  5216. }
  5217. break;
  5218. }
  5219. case 'e':
  5220. {
  5221. if (LocaleCompare("endian",option+1) == 0)
  5222. {
  5223. if (*option == '+')
  5224. {
  5225. image_info->endian=LSBEndian;
  5226. break;
  5227. }
  5228. image_info->endian=(EndianType) ParseMagickOption(
  5229. MagickEndianOptions,MagickFalse,argv[i+1]);
  5230. break;
  5231. }
  5232. if (LocaleCompare("extract",option+1) == 0)
  5233. {
  5234. /*
  5235. Set image extract geometry.
  5236. */
  5237. if (*option == '+')
  5238. {
  5239. image_info->extract=(char *) RelinquishMagickMemory(
  5240. image_info->extract);
  5241. break;
  5242. }
  5243. (void) CloneString(&image_info->extract,argv[i+1]);
  5244. break;
  5245. }
  5246. break;
  5247. }
  5248. case 'f':
  5249. {
  5250. if (LocaleCompare("fill",option+1) == 0)
  5251. {
  5252. if (*option == '+')
  5253. {
  5254. (void) RemoveImageOption(image_info,option+1);
  5255. break;
  5256. }
  5257. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5258. break;
  5259. }
  5260. if (LocaleCompare("font",option+1) == 0)
  5261. {
  5262. if (*option == '+')
  5263. {
  5264. image_info->font=(char *) RelinquishMagickMemory(
  5265. image_info->font);
  5266. break;
  5267. }
  5268. (void) CloneString(&image_info->font,argv[i+1]);
  5269. break;
  5270. }
  5271. if (LocaleCompare("format",option+1) == 0)
  5272. {
  5273. register char
  5274. *q;
  5275. for (q=strchr(argv[i+1],'%'); q != (char *) NULL; q=strchr(q+1,'%'))
  5276. if (strchr("gkrz@#",*(q+1)) != (char *) NULL)
  5277. image_info->ping=MagickFalse;
  5278. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5279. break;
  5280. }
  5281. if (LocaleCompare("fuzz",option+1) == 0)
  5282. {
  5283. if (*option == '+')
  5284. {
  5285. image_info->fuzz=0.0;
  5286. break;
  5287. }
  5288. image_info->fuzz=StringToDouble(argv[i+1],QuantumRange+1.0);
  5289. break;
  5290. }
  5291. break;
  5292. }
  5293. case 'g':
  5294. {
  5295. if (LocaleCompare("gravity",option+1) == 0)
  5296. {
  5297. if (*option == '+')
  5298. {
  5299. (void) RemoveImageOption(image_info,option+1);
  5300. break;
  5301. }
  5302. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5303. break;
  5304. }
  5305. break;
  5306. }
  5307. case 'i':
  5308. {
  5309. if (LocaleCompare("intent",option+1) == 0)
  5310. {
  5311. if (*option == '+')
  5312. {
  5313. (void) RemoveImageOption(image_info,option+1);
  5314. break;
  5315. }
  5316. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5317. break;
  5318. }
  5319. if (LocaleCompare("interlace",option+1) == 0)
  5320. {
  5321. if (*option == '+')
  5322. {
  5323. image_info->interlace=UndefinedInterlace;
  5324. break;
  5325. }
  5326. image_info->interlace=(InterlaceType) ParseMagickOption(
  5327. MagickInterlaceOptions,MagickFalse,argv[i+1]);
  5328. break;
  5329. }
  5330. if (LocaleCompare("interpolate",option+1) == 0)
  5331. {
  5332. if (*option == '+')
  5333. {
  5334. (void) RemoveImageOption(image_info,option+1);
  5335. break;
  5336. }
  5337. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5338. break;
  5339. }
  5340. break;
  5341. }
  5342. case 'l':
  5343. {
  5344. if (LocaleCompare("label",option+1) == 0)
  5345. {
  5346. if (*option == '+')
  5347. {
  5348. (void) RemoveImageOption(image_info,option+1);
  5349. break;
  5350. }
  5351. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5352. break;
  5353. }
  5354. if (LocaleCompare("limit",option+1) == 0)
  5355. {
  5356. ResourceType
  5357. type;
  5358. unsigned long
  5359. limit;
  5360. if (*option == '+')
  5361. break;
  5362. type=(ResourceType) ParseMagickOption(MagickResourceOptions,
  5363. MagickFalse,argv[i+1]);
  5364. limit=(~0UL);
  5365. if (LocaleCompare("unlimited",argv[i+2]) != 0)
  5366. limit=(unsigned long) atol(argv[i+2]);
  5367. (void) SetMagickResourceLimit(type,limit);
  5368. break;
  5369. }
  5370. if (LocaleCompare("list",option+1) == 0)
  5371. {
  5372. long
  5373. list;
  5374. /*
  5375. Display configuration list.
  5376. */
  5377. list=ParseMagickOption(MagickListOptions,MagickFalse,argv[i+1]);
  5378. switch (list)
  5379. {
  5380. case MagickCoderOptions:
  5381. {
  5382. (void) ListCoderInfo((FILE *) NULL,exception);
  5383. break;
  5384. }
  5385. case MagickColorOptions:
  5386. {
  5387. (void) ListColorInfo((FILE *) NULL,exception);
  5388. break;
  5389. }
  5390. case MagickConfigureOptions:
  5391. {
  5392. (void) ListConfigureInfo((FILE *) NULL,exception);
  5393. break;
  5394. }
  5395. case MagickDelegateOptions:
  5396. {
  5397. (void) ListDelegateInfo((FILE *) NULL,exception);
  5398. break;
  5399. }
  5400. case MagickFormatOptions:
  5401. {
  5402. (void) ListMagickInfo((FILE *) NULL,exception);
  5403. break;
  5404. }
  5405. case MagickLocaleOptions:
  5406. {
  5407. (void) ListLocaleInfo((FILE *) NULL,exception);
  5408. break;
  5409. }
  5410. case MagickLogOptions:
  5411. {
  5412. (void) ListLogInfo((FILE *) NULL,exception);
  5413. break;
  5414. }
  5415. case MagickMagicOptions:
  5416. {
  5417. (void) ListMagicInfo((FILE *) NULL,exception);
  5418. break;
  5419. }
  5420. case MagickMimeOptions:
  5421. {
  5422. (void) ListMimeInfo((FILE *) NULL,exception);
  5423. break;
  5424. }
  5425. #if defined(SupportMagickModules)
  5426. case MagickModuleOptions:
  5427. {
  5428. (void) ListModuleInfo((FILE *) NULL,exception);
  5429. break;
  5430. }
  5431. #endif
  5432. case MagickResourceOptions:
  5433. {
  5434. (void) ListMagickResourceInfo((FILE *) NULL,exception);
  5435. break;
  5436. }
  5437. case MagickThresholdOptions:
  5438. {
  5439. (void) ListThresholdMaps((FILE *) NULL,exception);
  5440. break;
  5441. }
  5442. case MagickTypeOptions:
  5443. {
  5444. (void) ListTypeInfo((FILE *) NULL,exception);
  5445. break;
  5446. }
  5447. default:
  5448. {
  5449. (void) ListMagickOptionInfo((FILE *) NULL,(MagickOption) list,
  5450. exception);
  5451. break;
  5452. }
  5453. }
  5454. }
  5455. if (LocaleCompare("log",option+1) == 0)
  5456. {
  5457. if (*option == '+')
  5458. break;
  5459. (void) SetLogFormat(argv[i+1]);
  5460. break;
  5461. }
  5462. break;
  5463. }
  5464. case 'm':
  5465. {
  5466. if (LocaleCompare("mattecolor",option+1) == 0)
  5467. {
  5468. if (*option == '+')
  5469. {
  5470. (void) QueryColorDatabase(MatteColor,&image_info->matte_color,
  5471. exception);
  5472. break;
  5473. }
  5474. (void) QueryColorDatabase(argv[i+1],&image_info->matte_color,
  5475. exception);
  5476. break;
  5477. }
  5478. if (LocaleCompare("monitor",option+1) == 0)
  5479. {
  5480. (void) SetImageInfoProgressMonitor(image_info,MonitorProgress,
  5481. (void *) NULL);
  5482. break;
  5483. }
  5484. if (LocaleCompare("monochrome",option+1) == 0)
  5485. {
  5486. image_info->monochrome=(*option == '-') ? MagickTrue : MagickFalse;
  5487. break;
  5488. }
  5489. break;
  5490. }
  5491. case 'o':
  5492. {
  5493. if (LocaleCompare("orient",option+1) == 0)
  5494. {
  5495. if (*option == '+')
  5496. {
  5497. image_info->orientation=UndefinedOrientation;
  5498. break;
  5499. }
  5500. image_info->orientation=(OrientationType) ParseMagickOption(
  5501. MagickOrientationOptions,MagickFalse,argv[i+1]);
  5502. break;
  5503. }
  5504. if (LocaleCompare("origin",option+1) == 0)
  5505. {
  5506. if (*option == '+')
  5507. {
  5508. (void) RemoveImageOption(image_info,option+1);
  5509. break;
  5510. }
  5511. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5512. break;
  5513. }
  5514. break;
  5515. }
  5516. case 'p':
  5517. {
  5518. if (LocaleCompare("page",option+1) == 0)
  5519. {
  5520. char
  5521. *canonical_page,
  5522. page[MaxTextExtent];
  5523. const char
  5524. *image_option;
  5525. MagickStatusType
  5526. flags;
  5527. RectangleInfo
  5528. geometry;
  5529. if (*option == '+')
  5530. {
  5531. (void) RemoveImageOption(image_info,option+1);
  5532. (void) CloneString(&image_info->page,(char *) NULL);
  5533. break;
  5534. }
  5535. (void) ResetMagickMemory(&geometry,0,sizeof(geometry));
  5536. image_option=GetImageOption(image_info,"page");
  5537. if (image_option != (const char *) NULL)
  5538. flags=ParseAbsoluteGeometry(image_option,&geometry);
  5539. canonical_page=GetPageGeometry(argv[i+1]);
  5540. flags=ParseAbsoluteGeometry(canonical_page,&geometry);
  5541. canonical_page=(char *) RelinquishMagickMemory(canonical_page);
  5542. (void) FormatMagickString(page,MaxTextExtent,"%lux%lu",
  5543. geometry.width,geometry.height);
  5544. if (((flags & XValue) != 0) || ((flags & YValue) != 0))
  5545. (void) FormatMagickString(page,MaxTextExtent,"%lux%lu%+ld%+ld",
  5546. geometry.width,geometry.height,geometry.x,geometry.y);
  5547. (void) SetImageOption(image_info,option+1,page);
  5548. (void) CloneString(&image_info->page,page);
  5549. break;
  5550. }
  5551. if (LocaleCompare("pen",option+1) == 0)
  5552. {
  5553. if (*option == '+')
  5554. {
  5555. (void) RemoveImageOption(image_info,option+1);
  5556. break;
  5557. }
  5558. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5559. break;
  5560. }
  5561. if (LocaleCompare("ping",option+1) == 0)
  5562. {
  5563. image_info->ping=(*option == '-') ? MagickTrue : MagickFalse;
  5564. break;
  5565. }
  5566. if (LocaleCompare("pointsize",option+1) == 0)
  5567. {
  5568. if (*option == '+')
  5569. geometry_info.rho=0.0;
  5570. else
  5571. (void) ParseGeometry(argv[i+1],&geometry_info);
  5572. image_info->pointsize=geometry_info.rho;
  5573. break;
  5574. }
  5575. if (LocaleCompare("preview",option+1) == 0)
  5576. {
  5577. /*
  5578. Preview image.
  5579. */
  5580. if (*option == '+')
  5581. {
  5582. image_info->preview_type=UndefinedPreview;
  5583. break;
  5584. }
  5585. image_info->preview_type=(PreviewType) ParseMagickOption(
  5586. MagickPreviewOptions,MagickFalse,argv[i+1]);
  5587. break;
  5588. }
  5589. break;
  5590. }
  5591. case 'q':
  5592. {
  5593. if (LocaleCompare("quality",option+1) == 0)
  5594. {
  5595. /*
  5596. Set image compression quality.
  5597. */
  5598. if (*option == '+')
  5599. {
  5600. image_info->quality=UndefinedCompressionQuality;
  5601. break;
  5602. }
  5603. image_info->quality=(unsigned long) atol(argv[i+1]);
  5604. break;
  5605. }
  5606. if (LocaleCompare("quiet",option+1) == 0)
  5607. {
  5608. static ErrorHandler
  5609. error_handler = (WarningHandler) NULL;
  5610. static WarningHandler
  5611. warning_handler = (WarningHandler) NULL;
  5612. if (*option == '+')
  5613. {
  5614. /*
  5615. Restore error or warning messages.
  5616. */
  5617. error_handler=SetErrorHandler((ErrorHandler) NULL);
  5618. warning_handler=SetWarningHandler((WarningHandler) NULL);
  5619. break;
  5620. }
  5621. /*
  5622. Suppress error or warning messages.
  5623. */
  5624. error_handler=SetErrorHandler(error_handler);
  5625. warning_handler=SetWarningHandler(warning_handler);
  5626. break;
  5627. }
  5628. break;
  5629. }
  5630. case 's':
  5631. {
  5632. if (LocaleCompare("sampling-factor",option+1) == 0)
  5633. {
  5634. /*
  5635. Set image sampling factor.
  5636. */
  5637. if (*option == '+')
  5638. {
  5639. image_info->sampling_factor=(char *) RelinquishMagickMemory(
  5640. image_info->sampling_factor);
  5641. break;
  5642. }
  5643. (void) CloneString(&image_info->sampling_factor,argv[i+1]);
  5644. break;
  5645. }
  5646. if (LocaleCompare("size",option+1) == 0)
  5647. {
  5648. if (*option == '+')
  5649. {
  5650. image_info->size=(char *) RelinquishMagickMemory(
  5651. image_info->size);
  5652. break;
  5653. }
  5654. (void) CloneString(&image_info->size,argv[i+1]);
  5655. break;
  5656. }
  5657. if (LocaleCompare("stroke",option+1) == 0)
  5658. {
  5659. if (*option == '+')
  5660. {
  5661. (void) RemoveImageOption(image_info,option+1);
  5662. break;
  5663. }
  5664. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5665. break;
  5666. }
  5667. if (LocaleCompare("strokewidth",option+1) == 0)
  5668. {
  5669. if (*option == '+')
  5670. {
  5671. (void) RemoveImageOption(image_info,option+1);
  5672. break;
  5673. }
  5674. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5675. break;
  5676. }
  5677. break;
  5678. }
  5679. case 't':
  5680. {
  5681. if (LocaleCompare("texture",option+1) == 0)
  5682. {
  5683. if (*option == '+')
  5684. {
  5685. image_info->texture=(char *) RelinquishMagickMemory(
  5686. image_info->texture);
  5687. break;
  5688. }
  5689. (void) CloneString(&image_info->texture,argv[i+1]);
  5690. break;
  5691. }
  5692. if (LocaleCompare("type",option+1) == 0)
  5693. {
  5694. if (*option == '+')
  5695. {
  5696. image_info->type=UndefinedType;
  5697. break;
  5698. }
  5699. image_info->type=(ImageType) ParseMagickOption(MagickImageOptions,
  5700. MagickFalse,argv[i+1]);
  5701. break;
  5702. }
  5703. break;
  5704. }
  5705. case 'u':
  5706. {
  5707. if (LocaleCompare("undercolor",option+1) == 0)
  5708. {
  5709. if (*option == '+')
  5710. {
  5711. (void) RemoveImageOption(image_info,option+1);
  5712. break;
  5713. }
  5714. (void) SetImageOption(image_info,option+1,argv[i+1]);
  5715. break;
  5716. }
  5717. if (LocaleCompare("units",option+1) == 0)
  5718. {
  5719. if (*option == '+')
  5720. {
  5721. image_info->units=UndefinedResolution;
  5722. break;
  5723. }
  5724. image_info->units=(ResolutionType) ParseMagickOption(
  5725. MagickResolutionOptions,MagickFalse,argv[i+1]);
  5726. break;
  5727. }
  5728. break;
  5729. }
  5730. case 'v':
  5731. {
  5732. if (LocaleCompare("verbose",option+1) == 0)
  5733. {
  5734. image_info->verbose=(*option == '-') ? MagickTrue : MagickFalse;
  5735. break;
  5736. }
  5737. if (LocaleCompare("view",option+1) == 0)
  5738. {
  5739. if (*option == '+')
  5740. {
  5741. image_info->view=(char *) RelinquishMagickMemory(
  5742. image_info->view);
  5743. break;
  5744. }
  5745. (void) CloneString(&image_info->view,argv[i+1]);
  5746. break;
  5747. }
  5748. if (LocaleCompare("virtual-pixel",option+1) == 0)
  5749. {
  5750. if (*option == '+')
  5751. {
  5752. image_info->virtual_pixel_method=UndefinedVirtualPixelMethod;
  5753. break;
  5754. }
  5755. image_info->virtual_pixel_method=(VirtualPixelMethod)
  5756. ParseMagickOption(MagickVirtualPixelOptions,MagickFalse,
  5757. argv[i+1]);
  5758. break;
  5759. }
  5760. break;
  5761. }
  5762. default:
  5763. break;
  5764. }
  5765. i+=count;
  5766. }
  5767. return(exception->severity == UndefinedException ? MagickTrue : MagickFalse);
  5768. }
  5769. /*
  5770. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  5771. % %
  5772. % %
  5773. % %
  5774. + M o g r i f y I m a g e L i s t %
  5775. % %
  5776. % %
  5777. % %
  5778. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  5779. %
  5780. % MogrifyImageList() applies any command line options that might affect the
  5781. % entire image list (e.g. -append, -coalesce, etc.).
  5782. %
  5783. % The format of the MogrifyImage method is:
  5784. %
  5785. % MagickBooleanType MogrifyImageList(ImageInfo *image_info,const int argc,
  5786. % const char **argv,Image **images,ExceptionInfo *exception)
  5787. %
  5788. % A description of each parameter follows:
  5789. %
  5790. % o image_info: The image info..
  5791. %
  5792. % o argc: Specifies a pointer to an integer describing the number of
  5793. % elements in the argument vector.
  5794. %
  5795. % o argv: Specifies a pointer to a text array containing the command line
  5796. % arguments.
  5797. %
  5798. % o images: The images.
  5799. %
  5800. % o exception: Return any errors or warnings in this structure.
  5801. %
  5802. */
  5803. WandExport MagickBooleanType MogrifyImageList(ImageInfo *image_info,
  5804. const int argc,const char **argv,Image **images,ExceptionInfo *exception)
  5805. {
  5806. ChannelType
  5807. channel;
  5808. CompositeOperator
  5809. compose;
  5810. const char
  5811. *option;
  5812. long
  5813. count,
  5814. index;
  5815. MagickBooleanType
  5816. dither;
  5817. MagickStatusType
  5818. status;
  5819. register long
  5820. i;
  5821. /*
  5822. Apply options to the image list.
  5823. */
  5824. assert(image_info != (ImageInfo *) NULL);
  5825. assert(image_info->signature == MagickSignature);
  5826. assert(images != (Image **) NULL);
  5827. assert((*images)->signature == MagickSignature);
  5828. if ((*images)->debug != MagickFalse)
  5829. (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",
  5830. (*images)->filename);
  5831. if ((argc <= 0) || (*argv == (char *) NULL))
  5832. return(MagickTrue);
  5833. channel=image_info->channel;
  5834. compose=(*images)->compose;
  5835. dither=image_info->dither;
  5836. status=MagickTrue;
  5837. for (i=0; i < (long) argc; i++)
  5838. {
  5839. option=argv[i];
  5840. if (IsMagickOption(option) == MagickFalse)
  5841. continue;
  5842. count=MagickMax(ParseMagickOption(MagickCommandOptions,MagickFalse,option),
  5843. 0L);
  5844. if ((i+count) >= argc)
  5845. break;
  5846. status=MogrifyImageInfo(image_info,count+1,argv+i,exception);
  5847. switch (*(option+1))
  5848. {
  5849. case 'a':
  5850. {
  5851. if (LocaleCompare("append",option+1) == 0)
  5852. {
  5853. Image
  5854. *append_image;
  5855. append_image=AppendImages(*images,*option == '-' ?
  5856. MagickTrue : MagickFalse,exception);
  5857. if (append_image == (Image *) NULL)
  5858. break;
  5859. InheritException(&append_image->exception,exception);
  5860. *images=DestroyImageList(*images);
  5861. *images=append_image;
  5862. break;
  5863. }
  5864. if (LocaleCompare("average",option+1) == 0)
  5865. {
  5866. Image
  5867. *average_image;
  5868. average_image=AverageImages(*images,exception);
  5869. if (average_image == (Image *) NULL)
  5870. break;
  5871. InheritException(&average_image->exception,exception);
  5872. *images=DestroyImageList(*images);
  5873. *images=average_image;
  5874. break;
  5875. }
  5876. break;
  5877. }
  5878. case 'c':
  5879. {
  5880. if (LocaleCompare("channel",option+1) == 0)
  5881. {
  5882. if (*option == '+')
  5883. {
  5884. channel=DefaultChannels;
  5885. break;
  5886. }
  5887. channel=(ChannelType) ParseChannelOption(argv[i+1]);
  5888. break;
  5889. }
  5890. if (LocaleCompare("coalesce",option+1) == 0)
  5891. {
  5892. Image
  5893. *coalesce_image;
  5894. coalesce_image=CoalesceImages(*images,exception);
  5895. if (coalesce_image == (Image *) NULL)
  5896. break;
  5897. InheritException(&coalesce_image->exception,exception);
  5898. *images=DestroyImageList(*images);
  5899. *images=coalesce_image;
  5900. break;
  5901. }
  5902. if (LocaleCompare("combine",option+1) == 0)
  5903. {
  5904. Image
  5905. *combine_image;
  5906. combine_image=CombineImages(*images,channel,exception);
  5907. if (combine_image == (Image *) NULL)
  5908. break;
  5909. InheritException(&combine_image->exception,exception);
  5910. *images=DestroyImageList(*images);
  5911. *images=combine_image;
  5912. break;
  5913. }
  5914. if (LocaleCompare("compose",option+1) == 0)
  5915. {
  5916. if (*option == '+')
  5917. {
  5918. compose=OverCompositeOp;
  5919. break;
  5920. }
  5921. compose=(CompositeOperator) ParseMagickOption(
  5922. MagickCompositeOptions,MagickFalse,argv[i+1]);
  5923. break;
  5924. }
  5925. if (LocaleCompare("composite",option+1) == 0)
  5926. {
  5927. char
  5928. composite_geometry[MaxTextExtent];
  5929. Image
  5930. *clip_image,
  5931. *composite_image,
  5932. *image;
  5933. RectangleInfo
  5934. geometry;
  5935. image=RemoveFirstImageFromList(images);
  5936. composite_image=RemoveFirstImageFromList(images);
  5937. if (composite_image == (Image *) NULL)
  5938. break;
  5939. (void) TransformImage(&composite_image,(char *) NULL,
  5940. composite_image->geometry);
  5941. SetGeometry(composite_image,&geometry);
  5942. (void) ParseAbsoluteGeometry(composite_image->geometry,&geometry);
  5943. (void) FormatMagickString(composite_geometry,MaxTextExtent,
  5944. "%lux%lu%+ld%+ld",composite_image->columns,composite_image->rows,
  5945. geometry.x,geometry.y);
  5946. (void) ParseGravityGeometry(image,composite_geometry,&geometry);
  5947. clip_image=RemoveFirstImageFromList(images);
  5948. if (clip_image != (Image *) NULL)
  5949. {
  5950. image->mask=clip_image;
  5951. (void) NegateImage(image->mask,MagickFalse);
  5952. }
  5953. (void) CompositeImage(image,compose,composite_image,geometry.x,
  5954. geometry.y);
  5955. composite_image=DestroyImage(composite_image);
  5956. InheritException(&image->exception,exception);
  5957. *images=DestroyImageList(*images);
  5958. *images=image;
  5959. break;
  5960. }
  5961. if (LocaleCompare("crop",option+1) == 0)
  5962. {
  5963. (void) TransformImages(images,argv[i+1],(char *) NULL);
  5964. break;
  5965. }
  5966. break;
  5967. }
  5968. case 'd':
  5969. {
  5970. if (LocaleCompare("deconstruct",option+1) == 0)
  5971. {
  5972. Image
  5973. *deconstruct_image;
  5974. deconstruct_image=DeconstructImages(*images,exception);
  5975. if (deconstruct_image == (Image *) NULL)
  5976. break;
  5977. InheritException(&deconstruct_image->exception,exception);
  5978. *images=DestroyImageList(*images);
  5979. *images=deconstruct_image;
  5980. break;
  5981. }
  5982. if (LocaleCompare("delete",option+1) == 0)
  5983. {
  5984. if (*option == '+')
  5985. DeleteImages(images,"-1",exception);
  5986. else
  5987. DeleteImages(images,argv[i+1],exception);
  5988. break;
  5989. }
  5990. if (LocaleCompare("dither",option+1) == 0)
  5991. {
  5992. dither=(*option == '-') ? MagickTrue : MagickFalse;
  5993. break;
  5994. }
  5995. break;
  5996. }
  5997. case 'f':
  5998. {
  5999. if (LocaleCompare("flatten",option+1) == 0)
  6000. {
  6001. Image
  6002. *flatten_image;
  6003. flatten_image=FlattenImages(*images,exception);
  6004. if (flatten_image == (Image *) NULL)
  6005. break;
  6006. InheritException(&flatten_image->exception,exception);
  6007. *images=DestroyImageList(*images);
  6008. *images=flatten_image;
  6009. break;
  6010. }
  6011. if (LocaleCompare("fx",option+1) == 0)
  6012. {
  6013. Image
  6014. *fx_image;
  6015. fx_image=FxImageChannel(*images,channel,argv[i+1],exception);
  6016. if (fx_image == (Image *) NULL)
  6017. break;
  6018. InheritException(&fx_image->exception,exception);
  6019. *images=DestroyImageList(*images);
  6020. *images=fx_image;
  6021. break;
  6022. }
  6023. break;
  6024. }
  6025. case 'g':
  6026. {
  6027. if (LocaleCompare("gravity",option+1) == 0)
  6028. {
  6029. if (*option == '+')
  6030. {
  6031. (*images)->gravity=UndefinedGravity;
  6032. break;
  6033. }
  6034. (*images)->gravity=(GravityType) ParseMagickOption(
  6035. MagickGravityOptions,MagickFalse,argv[i+1]);
  6036. break;
  6037. }
  6038. break;
  6039. }
  6040. case 'i':
  6041. {
  6042. if (LocaleCompare("insert",option+1) == 0)
  6043. {
  6044. Image
  6045. *p,
  6046. *q;
  6047. index=0;
  6048. if (*option != '+')
  6049. index=atol(argv[i+1]);
  6050. p=RemoveLastImageFromList(images);
  6051. if (p == (Image *) NULL)
  6052. {
  6053. (void) ThrowMagickException(exception,GetMagickModule(),
  6054. OptionError,"NoSuchImage","`%s'",argv[i+1]);
  6055. break;
  6056. }
  6057. q=p;
  6058. if (index == 0)
  6059. PrependImageToList(images,q);
  6060. else
  6061. if (index == (long) GetImageListLength(*images))
  6062. AppendImageToList(images,q);
  6063. else
  6064. {
  6065. q=GetImageFromList(*images,index-1);
  6066. if (q == (Image *) NULL)
  6067. {
  6068. (void) ThrowMagickException(exception,GetMagickModule(),
  6069. OptionError,"NoSuchImage","`%s'",argv[i+1]);
  6070. break;
  6071. }
  6072. InsertImageInList(&q,p);
  6073. }
  6074. *images=GetFirstImageInList(q);
  6075. break;
  6076. }
  6077. break;
  6078. }
  6079. case 'l':
  6080. {
  6081. if (LocaleCompare("layers",option+1) == 0)
  6082. {
  6083. Image
  6084. *layers;
  6085. MagickLayerMethod
  6086. type;
  6087. type=(MagickLayerMethod) ParseMagickOption(MagickLayersOptions,
  6088. MagickFalse,argv[i+1]);
  6089. switch (type)
  6090. {
  6091. case CoalesceLayer:
  6092. {
  6093. layers=CoalesceImages(*images,exception);
  6094. break;
  6095. }
  6096. case DisposeLayer:
  6097. {
  6098. layers=DisposeImages(*images,exception);
  6099. break;
  6100. }
  6101. case OptimizeLayer:
  6102. {
  6103. layers=OptimizeImageLayers(*images,exception);
  6104. break;
  6105. }
  6106. case OptimizePlusLayer:
  6107. {
  6108. layers=OptimizePlusImageLayers(*images,exception);
  6109. break;
  6110. }
  6111. default:
  6112. {
  6113. layers=CompareImageLayers(*images,type,exception);
  6114. break;
  6115. }
  6116. }
  6117. if (layers == (Image *) NULL)
  6118. break;
  6119. InheritException(&layers->exception,exception);
  6120. *images=DestroyImageList(*images);
  6121. *images=layers;
  6122. break;
  6123. }
  6124. break;
  6125. }
  6126. case 'm':
  6127. {
  6128. if (LocaleCompare("map",option+1) == 0)
  6129. {
  6130. if (*option == '+')
  6131. {
  6132. (void) MapImages(*images,(Image *) NULL,dither);
  6133. break;
  6134. }
  6135. i++;
  6136. break;
  6137. }
  6138. if (LocaleCompare("mask",option+1) == 0)
  6139. {
  6140. Image
  6141. *image,
  6142. *mask;
  6143. image=RemoveFirstImageFromList(images);
  6144. mask=RemoveFirstImageFromList(images);
  6145. if (mask == (Image *) NULL)
  6146. break;
  6147. image->mask=mask;
  6148. (void) NegateImage(image->mask,MagickFalse);
  6149. *images=DestroyImageList(*images);
  6150. *images=image;
  6151. break;
  6152. }
  6153. if (LocaleCompare("morph",option+1) == 0)
  6154. {
  6155. Image
  6156. *morph_image;
  6157. morph_image=MorphImages(*images,(unsigned long) atol(argv[i+1]),
  6158. exception);
  6159. if (morph_image == (Image *) NULL)
  6160. break;
  6161. InheritException(&morph_image->exception,exception);
  6162. *images=DestroyImageList(*images);
  6163. *images=morph_image;
  6164. break;
  6165. }
  6166. if (LocaleCompare("mosaic",option+1) == 0)
  6167. {
  6168. Image
  6169. *mosaic_image;
  6170. mosaic_image=MosaicImages(*images,exception);
  6171. if (mosaic_image == (Image *) NULL)
  6172. break;
  6173. InheritException(&mosaic_image->exception,exception);
  6174. *images=DestroyImageList(*images);
  6175. *images=mosaic_image;
  6176. break;
  6177. }
  6178. break;
  6179. }
  6180. case 'p':
  6181. {
  6182. if (LocaleCompare("print",option+1) == 0)
  6183. {
  6184. char
  6185. *string;
  6186. string=InterpretImageProperties(image_info,*images,argv[i+1]);
  6187. if (string == (char *) NULL)
  6188. break;
  6189. (void) fprintf(stdout,"%s",string);
  6190. string=(char *) RelinquishMagickMemory(string);
  6191. }
  6192. if (LocaleCompare("process",option+1) == 0)
  6193. {
  6194. char
  6195. **arguments;
  6196. int
  6197. j,
  6198. number_arguments;
  6199. arguments=StringToArgv(argv[i+1],&number_arguments);
  6200. if (arguments == (char **) NULL)
  6201. break;
  6202. if ((argc > 1) && (strchr(arguments[1],'=') != (char *) NULL))
  6203. {
  6204. char
  6205. *arguments,
  6206. breaker,
  6207. quote,
  6208. *token;
  6209. int
  6210. next,
  6211. status;
  6212. size_t
  6213. length;
  6214. TokenInfo
  6215. *token_info;
  6216. /*
  6217. Support old style syntax, filter="-option arg".
  6218. */
  6219. length=strlen(argv[i+1]);
  6220. token=(char *) AcquireMagickMemory(length+MaxTextExtent);
  6221. if (token == (char *) NULL)
  6222. break;
  6223. next=0;
  6224. arguments=(char *) argv[i+1];
  6225. token_info=AcquireTokenInfo();
  6226. status=Tokenizer(token_info,0,token,length,arguments,"","=",
  6227. "\"",'\0',&breaker,&next,&quote);
  6228. token_info=DestroyTokenInfo(token_info);
  6229. if (status == 0)
  6230. {
  6231. char
  6232. *argv;
  6233. argv=(char *) &(arguments[next]);
  6234. (void) ExecuteModuleProcess(token,&(*images),1,&argv);
  6235. }
  6236. token=(char *) RelinquishMagickMemory(token);
  6237. break;
  6238. }
  6239. (void) ExecuteModuleProcess(arguments[1],&(*images),
  6240. number_arguments-2,arguments+2);
  6241. for (j=1; j < number_arguments; j++)
  6242. arguments[j]=(char *) RelinquishMagickMemory(arguments[j]);
  6243. arguments=(char **) RelinquishMagickMemory(arguments);
  6244. break;
  6245. }
  6246. break;
  6247. }
  6248. case 's':
  6249. {
  6250. if (LocaleCompare("scene",option+1) == 0)
  6251. {
  6252. Image
  6253. *p;
  6254. long
  6255. scene;
  6256. p=GetFirstImageInList(*images);
  6257. for (scene=atol(argv[i+1]); p != (Image *) NULL; scene++)
  6258. {
  6259. p->scene=(unsigned long) scene;
  6260. p=GetNextImageInList(p);
  6261. }
  6262. break;
  6263. }
  6264. if (LocaleCompare("swap",option+1) == 0)
  6265. {
  6266. Image
  6267. *p,
  6268. *q,
  6269. *swap;
  6270. long
  6271. swap_index;
  6272. index=(-1);
  6273. swap_index=(-2);
  6274. if (*option != '+')
  6275. {
  6276. GeometryInfo
  6277. geometry_info;
  6278. MagickStatusType
  6279. flags;
  6280. flags=ParseGeometry(argv[i+1],&geometry_info);
  6281. index=(long) geometry_info.rho;
  6282. if ((flags & SigmaValue) != 0)
  6283. swap_index=(long) geometry_info.sigma;
  6284. }
  6285. p=GetImageFromList(*images,index);
  6286. q=GetImageFromList(*images,swap_index);
  6287. if ((p == (Image *) NULL) || (q == (Image *) NULL))
  6288. {
  6289. (void) ThrowMagickException(exception,GetMagickModule(),
  6290. OptionError,"NoSuchImage","`%s'",(*images)->filename);
  6291. break;
  6292. }
  6293. swap=CloneImage(p,0,0,MagickTrue,exception);
  6294. ReplaceImageInList(&p,CloneImage(q,0,0,MagickTrue,exception));
  6295. ReplaceImageInList(&q,swap);
  6296. *images=GetFirstImageInList(q);
  6297. break;
  6298. }
  6299. break;
  6300. }
  6301. case 'w':
  6302. {
  6303. if (LocaleCompare("write",option+1) == 0)
  6304. {
  6305. Image
  6306. *write_images;
  6307. ImageInfo
  6308. *write_info;
  6309. write_images=(*images);
  6310. if (*option == '+')
  6311. write_images=CloneImageList(*images,exception);
  6312. write_info=CloneImageInfo(image_info);
  6313. status&=WriteImages(write_info,write_images,argv[i+1],exception);
  6314. write_info=DestroyImageInfo(write_info);
  6315. if (*option == '+')
  6316. write_images=DestroyImageList(write_images);
  6317. break;
  6318. }
  6319. break;
  6320. }
  6321. default:
  6322. break;
  6323. }
  6324. i+=count;
  6325. }
  6326. return(status != 0 ? MagickTrue : MagickFalse);
  6327. }
  6328. /*
  6329. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  6330. % %
  6331. % %
  6332. % %
  6333. + M o g r i f y I m a g e s %
  6334. % %
  6335. % %
  6336. % %
  6337. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  6338. %
  6339. % MogrifyImages() applies image processing options to a sequence of images as
  6340. % prescribed by command line options.
  6341. %
  6342. % The format of the MogrifyImage method is:
  6343. %
  6344. % MagickBooleanType MogrifyImages(ImageInfo *image_info,const int argc,
  6345. % const char **argv,Image **images,Exceptioninfo *exception)
  6346. %
  6347. % A description of each parameter follows:
  6348. %
  6349. % o image_info: The image info..
  6350. %
  6351. % o argc: Specifies a pointer to an integer describing the number of
  6352. % elements in the argument vector.
  6353. %
  6354. % o argv: Specifies a pointer to a text array containing the command line
  6355. % arguments.
  6356. %
  6357. % o images: The images.
  6358. %
  6359. % o exception: Return any errors or warnings in this structure.
  6360. %
  6361. %
  6362. */
  6363. WandExport MagickBooleanType MogrifyImages(ImageInfo *image_info,
  6364. const int argc,const char **argv,Image **images,ExceptionInfo *exception)
  6365. {
  6366. #define MogrifyImageTag "Mogrify/Image"
  6367. const char
  6368. *option;
  6369. Image
  6370. *image,
  6371. *mogrify_images;
  6372. long
  6373. count;
  6374. MagickStatusType
  6375. status;
  6376. register long
  6377. i;
  6378. unsigned long
  6379. number_images,
  6380. scene;
  6381. /*
  6382. Apply options to individual images in the list.
  6383. */
  6384. assert(image_info != (ImageInfo *) NULL);
  6385. assert(image_info->signature == MagickSignature);
  6386. if (images == (Image **) NULL)
  6387. return(MogrifyImage(image_info,argc,argv,images,exception));
  6388. assert((*images)->signature == MagickSignature);
  6389. if ((*images)->debug != MagickFalse)
  6390. (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",
  6391. (*images)->filename);
  6392. if ((argc <= 0) || (*argv == (char *) NULL))
  6393. return(MagickTrue);
  6394. scene=MagickFalse;
  6395. for (i=0; i < (long) argc; i++)
  6396. {
  6397. option=argv[i];
  6398. if (IsMagickOption(option) == MagickFalse)
  6399. continue;
  6400. count=MagickMax(ParseMagickOption(MagickCommandOptions,MagickFalse,option),
  6401. 0L);
  6402. if ((i+count) >= argc)
  6403. break;
  6404. switch (*(option+1))
  6405. {
  6406. case 's':
  6407. {
  6408. if (LocaleCompare("scene",option+1) == 0)
  6409. scene=MagickTrue;
  6410. break;
  6411. }
  6412. default:
  6413. break;
  6414. }
  6415. i+=count;
  6416. }
  6417. (void) SetImageInfoProgressMonitor(image_info,(MagickProgressMonitor) NULL,
  6418. (void *) NULL);
  6419. mogrify_images=NewImageList();
  6420. number_images=GetImageListLength(*images);
  6421. for (i=0; i < (long) number_images; i++)
  6422. {
  6423. image=RemoveFirstImageFromList(images);
  6424. status&=MogrifyImage(image_info,argc,argv,&image,exception);
  6425. if (scene != MagickFalse)
  6426. image->scene=(unsigned long) i;
  6427. AppendImageToList(&mogrify_images,image);
  6428. if ((image->progress_monitor != (MagickProgressMonitor) NULL) &&
  6429. (QuantumTick(i,number_images) != MagickFalse))
  6430. {
  6431. status=image->progress_monitor(MogrifyImageTag,i,number_images,
  6432. image->client_data);
  6433. if (status == MagickFalse)
  6434. break;
  6435. }
  6436. }
  6437. status=MogrifyImageList(image_info,argc,argv,&mogrify_images,exception);
  6438. *images=mogrify_images;
  6439. return(status != 0 ? MagickTrue : MagickFalse);
  6440. }