43#include "wand/studio.h"
44#include "wand/MagickWand.h"
45#include "wand/mogrify-private.h"
46#include "magick/string-private.h"
110static MagickBooleanType CompositeImageList(ImageInfo *image_info,Image **image,
112 ExceptionInfo *exception)
117 assert(image_info != (ImageInfo *) NULL);
118 assert(image_info->signature == MagickCoreSignature);
119 assert(image != (Image **) NULL);
120 assert((*image)->signature == MagickCoreSignature);
121 assert(exception != (ExceptionInfo *) NULL);
122 if (IsEventLogging() != MagickFalse)
123 (void) LogMagickEvent(TraceEvent,GetMagickModule(),
"%s",(*image)->filename);
126 if (composite_image != (Image *) NULL)
128 assert(composite_image->signature == MagickCoreSignature);
129 switch( composite_options->compose )
131 case BlendCompositeOp:
132 case BlurCompositeOp:
133 case DisplaceCompositeOp:
134 case DistortCompositeOp:
135 case DissolveCompositeOp:
136 case ModulateCompositeOp:
137 case ThresholdCompositeOp:
139 (void) SetImageArtifact(*image,
"compose:args",
140 composite_options->compose_args);
149 if (composite_options->stegano != 0)
154 (*image)->offset=composite_options->stegano-1;
155 stegano_image=SteganoImage(*image,composite_image,exception);
156 if (stegano_image != (Image *) NULL)
158 *image=DestroyImageList(*image);
159 *image=stegano_image;
163 if (composite_options->stereo != MagickFalse)
168 stereo_image=StereoAnaglyphImage(*image,composite_image,
169 composite_options->offset.x,composite_options->offset.y,
171 if (stereo_image != (Image *) NULL)
173 *image=DestroyImageList(*image);
178 if (composite_options->tile != MagickFalse)
190 (void) SetImageArtifact(composite_image,
"compose:outside-overlay",
192 columns=composite_image->columns;
193 for (y=0; y < (ssize_t) (*image)->rows; y+=(ssize_t) composite_image->rows)
194 for (x=0; x < (ssize_t) (*image)->columns; x+=(ssize_t) columns)
195 status&=CompositeImageChannel(*image,
196 composite_options->channel,composite_options->compose,
197 composite_image,x,y);
198 GetImageException(*image,exception);
208 SetGeometry(*image,&geometry);
209 (void) ParseAbsoluteGeometry(composite_options->geometry,
211 geometry.width=composite_image->columns;
212 geometry.height=composite_image->rows;
213 GravityAdjustGeometry((*image)->columns,(*image)->rows,
214 composite_options->gravity, &geometry);
215 (*image)->gravity=(GravityType) composite_options->gravity;
219 status&=CompositeImageChannel(*image,composite_options->channel,
220 composite_options->compose,composite_image,geometry.x,
222 GetImageException(*image,exception);
225 return(status != 0 ? MagickTrue : MagickFalse);
228static MagickBooleanType CompositeUsage(
void)
232 " -debug events display copious debugging information\n"
233 " -help print program options\n"
234 " -list type print a list of supported option arguments\n"
235 " -log format format of debugging information\n"
236 " -version print version information",
238 " -blend geometry blend images\n"
239 " -border geometry surround image with a border of color\n"
240 " -bordercolor color border color\n"
241 " -colors value preferred number of colors in the image\n"
242 " -decipher filename convert cipher pixels to plain pixels\n"
243 " -displace geometry shift lookup according to a relative displacement map\n"
244 " -dissolve value dissolve the two images a given percent\n"
245 " -distort geometry shift lookup according to a absolute distortion map\n"
246 " -encipher filename convert plain pixels to cipher pixels\n"
247 " -extract geometry extract area from image\n"
248 " -geometry geometry location of the composite image\n"
249 " -identify identify the format and characteristics of the image\n"
250 " -monochrome transform image to black and white\n"
251 " -negate replace every pixel with its complementary color \n"
252 " -profile filename add ICM or IPTC information profile to image\n"
253 " -quantize colorspace reduce colors in this colorspace\n"
254 " -rotate degrees apply Paeth rotation to the image\n"
255 " -resize geometry resize the image\n"
256 " -sharpen geometry sharpen the image\n"
257 " -shave geometry shave pixels from the image edges\n"
258 " -stegano offset hide watermark within an image\n"
259 " -stereo geometry combine two image to create a stereo anaglyph\n"
260 " -strip strip image of all profiles and comments\n"
261 " -thumbnail geometry create a thumbnail of the image\n"
262 " -transform affine transform image\n"
263 " -type type image type\n"
264 " -unsharp geometry sharpen the image\n"
265 " -watermark geometry percent brightness and saturation of a watermark\n"
266 " -write filename write images to this file",
268 " -affine matrix affine transform matrix\n"
269 " -alpha option on, activate, off, deactivate, set, opaque, copy\n"
270 " transparent, extract, background, or shape\n"
271 " -authenticate password\n"
272 " decipher image with this password\n"
273 " -blue-primary point chromaticity blue primary point\n"
274 " -channel type apply option to select image channels\n"
275 " -colorspace type alternate image colorspace\n"
276 " -comment string annotate image with comment\n"
277 " -compose operator composite operator\n"
278 " -compress type type of pixel compression when writing the image\n"
279 " -define format:option\n"
280 " define one or more image format options\n"
281 " -depth value image depth\n"
282 " -density geometry horizontal and vertical density of the image\n"
283 " -display server get image or font from this X server\n"
284 " -dispose method layer disposal method\n"
285 " -dither method apply error diffusion to image\n"
286 " -encoding type text encoding type\n"
287 " -endian type endianness (MSB or LSB) of the image\n"
288 " -filter type use this filter when resizing an image\n"
289 " -font name render text with this font\n"
290 " -format \"string\" output formatted image characteristics\n"
291 " -gravity type which direction to gravitate towards\n"
292 " -green-primary point chromaticity green primary point\n"
293 " -interlace type type of image interlacing scheme\n"
294 " -interpolate method pixel color interpolation method\n"
295 " -label string assign a label to an image\n"
296 " -limit type value pixel cache resource limit\n"
297 " -matte store matte channel if the image has one\n"
298 " -monitor monitor progress\n"
299 " -page geometry size and location of an image canvas (setting)\n"
300 " -pointsize value font point size\n"
301 " -quality value JPEG/MIFF/PNG compression level\n"
302 " -quiet suppress all warning messages\n"
303 " -red-primary point chromaticity red primary point\n"
304 " -regard-warnings pay attention to warning messages\n"
305 " -repage geometry size and location of an image canvas (operator)\n"
306 " -respect-parentheses settings remain in effect until parenthesis boundary\n"
307 " -sampling-factor geometry\n"
308 " horizontal and vertical sampling factor\n"
309 " -scene value image scene number\n"
310 " -seed value seed a new sequence of pseudo-random numbers\n"
311 " -size geometry width and height of image\n"
312 " -support factor resize support: > 1.0 is blurry, < 1.0 is sharp\n"
313 " -synchronize synchronize image to storage device\n"
314 " -taint declare the image as modified\n"
315 " -transparent-color color\n"
316 " transparent color\n"
317 " -treedepth value color tree depth\n"
318 " -tile repeat composite operation across and down image\n"
319 " -units type the units of image resolution\n"
320 " -verbose print detailed information about the image\n"
321 " -virtual-pixel method\n"
322 " virtual pixel access method\n"
323 " -white-point point chromaticity white point",
325 " -swap indexes swap two images in the image sequence";
327 ListMagickVersion(stdout);
328 (void) printf(
"Usage: %s [options ...] image [options ...] composite\n"
329 " [ [options ...] mask ] [options ...] composite\n",
331 (void) printf(
"\nImage Settings:\n");
332 (void) puts(settings);
333 (void) printf(
"\nImage Operators:\n");
334 (void) puts(operators);
335 (void) printf(
"\nImage Stack Operators:\n");
336 (void) puts(stack_operators);
337 (void) printf(
"\nMiscellaneous Options:\n");
338 (void) puts(miscellaneous);
340 "\nBy default, the image format of `file' is determined by its magic\n");
342 "number. To specify a particular image format, precede the filename\n");
344 "with an image format name and a colon (i.e. ps:image) or specify the\n");
346 "image type as the filename suffix (i.e. image.ps). Specify 'file' as\n");
347 (void) printf(
"'-' for standard input or output.\n");
353 (void) memset(composite_options,0,
sizeof(*composite_options));
354 composite_options->channel=DefaultChannels;
355 composite_options->compose=OverCompositeOp;
360 if (composite_options->compose_args != (
char *) NULL)
361 composite_options->compose_args=(
char *)
362 RelinquishMagickMemory(composite_options->compose_args);
363 if (composite_options->geometry != (
char *) NULL)
364 composite_options->geometry=(
char *)
365 RelinquishMagickMemory(composite_options->geometry);
368WandExport MagickBooleanType CompositeImageCommand(ImageInfo *image_info,
369 int argc,
char **argv,
char **metadata,ExceptionInfo *exception)
371#define NotInitialized (unsigned int) (~0)
372#define DestroyComposite() \
374 RelinquishCompositeOptions(&composite_options); \
375 DestroyImageStack(); \
376 for (i=0; i < (ssize_t) argc; i++) \
377 argv[i]=DestroyString(argv[i]); \
378 argv=(char **) RelinquishMagickMemory(argv); \
380#define ThrowCompositeException(asperity,tag,option) \
382 (void) ThrowMagickException(exception,GetMagickModule(),asperity,tag,"`%s'", \
383 option == (char *) NULL ? GetExceptionMessage(errno) : option); \
384 DestroyComposite(); \
385 return(MagickFalse); \
387#define ThrowCompositeInvalidArgumentException(option,argument) \
389 (void) ThrowMagickException(exception,GetMagickModule(),OptionError, \
390 "InvalidArgument","`%s': %s",option,argument); \
391 DestroyComposite(); \
392 return(MagickFalse); \
412 image_stack[MaxImageStackDepth+1];
432 assert(image_info != (ImageInfo *) NULL);
433 assert(image_info->signature == MagickCoreSignature);
434 if (image_info->debug != MagickFalse)
435 (void) LogMagickEvent(TraceEvent,GetMagickModule(),
"...");
436 assert(exception != (ExceptionInfo *) NULL);
440 if ((LocaleCompare(
"version",option+1) == 0) ||
441 (LocaleCompare(
"-version",option+1) == 0))
443 ListMagickVersion(stdout);
449 (void) ThrowMagickException(exception,GetMagickModule(),OptionError,
450 "MissingArgument",
"%s",
"");
451 (void) CompositeUsage();
454 GetCompositeOptions(&composite_options);
455 filename=(
char *) NULL;
460 option=(
char *) NULL;
462 respect_parenthesis=MagickFalse;
467 composite_image=NewImageList();
468 image=NewImageList();
469 mask_image=NewImageList();
470 ReadCommandlLine(argc,&argv);
471 status=ExpandFilenames(&argc,&argv);
472 if (status == MagickFalse)
473 ThrowCompositeException(ResourceLimitError,
"MemoryAllocationFailed",
474 GetExceptionMessage(errno));
475 for (i=1; i < (ssize_t) (argc-1); i++)
478 if (LocaleCompare(option,
"(") == 0)
480 FireImageStack(MagickFalse,MagickTrue,pend);
481 if (k == MaxImageStackDepth)
482 ThrowCompositeException(OptionError,
"ParenthesisNestedTooDeeply",
487 if (LocaleCompare(option,
")") == 0)
489 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
491 ThrowCompositeException(OptionError,
"UnableToParseExpression",option);
495 if (IsCommandOption(option) == MagickFalse)
503 FireImageStack(MagickFalse,MagickFalse,pend);
505 if ((LocaleCompare(filename,
"--") == 0) && (i < (ssize_t) (argc-1)))
507 (void) SetImageOption(image_info,
"filename",filename);
508 (void) CopyMagickString(image_info->filename,filename,MaxTextExtent);
509 images=ReadImages(image_info,exception);
510 status&=(images != (Image *) NULL) &&
511 (exception->severity < ErrorException);
512 if (images == (Image *) NULL)
514 AppendImageStack(images);
517 pend=image != (Image *) NULL ? MagickTrue : MagickFalse;
522 if (LocaleCompare(
"affine",option+1) == 0)
527 if (i == (ssize_t) argc)
528 ThrowCompositeException(OptionError,
"MissingArgument",option);
529 if (IsGeometry(argv[i]) == MagickFalse)
530 ThrowCompositeInvalidArgumentException(option,argv[i]);
533 if (LocaleCompare(
"alpha",option+1) == 0)
541 if (i == (ssize_t) argc)
542 ThrowCompositeException(OptionError,
"MissingArgument",option);
543 type=ParseCommandOption(MagickAlphaOptions,MagickFalse,argv[i]);
545 ThrowCompositeException(OptionError,
546 "UnrecognizedAlphaChannelType",argv[i]);
549 if (LocaleCompare(
"authenticate",option+1) == 0)
554 if (i == (ssize_t) argc)
555 ThrowCompositeException(OptionError,
"MissingArgument",option);
558 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
562 if (LocaleCompare(
"background",option+1) == 0)
567 if (i == (ssize_t) argc)
568 ThrowCompositeException(OptionError,
"MissingArgument",option);
571 if (LocaleCompare(
"blend",option+1) == 0)
573 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
577 if (i == (ssize_t) argc)
578 ThrowCompositeException(OptionError,
"MissingArgument",option);
579 if (IsGeometry(argv[i]) == MagickFalse)
580 ThrowCompositeInvalidArgumentException(option,argv[i]);
581 (void) CloneString(&composite_options.compose_args,argv[i]);
582 composite_options.compose=BlendCompositeOp;
585 if (LocaleCompare(
"blur",option+1) == 0)
587 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
591 if (i == (ssize_t) argc)
592 ThrowCompositeException(OptionError,
"MissingArgument",option);
593 if (IsGeometry(argv[i]) == MagickFalse)
594 ThrowCompositeInvalidArgumentException(option,argv[i]);
595 (void) CloneString(&composite_options.compose_args,argv[i]);
596 composite_options.compose=BlurCompositeOp;
599 if (LocaleCompare(
"blue-primary",option+1) == 0)
604 if (i == (ssize_t) argc)
605 ThrowCompositeException(OptionError,
"MissingArgument",option);
606 if (IsGeometry(argv[i]) == MagickFalse)
607 ThrowCompositeInvalidArgumentException(option,argv[i]);
610 if (LocaleCompare(
"border",option+1) == 0)
615 if (i == (ssize_t) argc)
616 ThrowCompositeException(OptionError,
"MissingArgument",option);
617 if (IsGeometry(argv[i]) == MagickFalse)
618 ThrowCompositeInvalidArgumentException(option,argv[i]);
621 if (LocaleCompare(
"bordercolor",option+1) == 0)
626 if (i == (ssize_t) argc)
627 ThrowCompositeException(OptionError,
"MissingArgument",option);
630 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
634 if (LocaleCompare(
"cache",option+1) == 0)
639 if (i == (ssize_t) argc)
640 ThrowCompositeException(OptionError,
"MissingArgument",option);
641 if (IsGeometry(argv[i]) == MagickFalse)
642 ThrowCompositeInvalidArgumentException(option,argv[i]);
645 if (LocaleCompare(
"channel",option+1) == 0)
652 composite_options.channel=DefaultChannels;
656 if (i == (ssize_t) argc)
657 ThrowCompositeException(OptionError,
"MissingArgument",option);
658 channel=ParseChannelOption(argv[i]);
660 ThrowCompositeException(OptionError,
"UnrecognizedChannelType",
662 composite_options.channel=(ChannelType) channel;
665 if (LocaleCompare(
"colors",option+1) == 0)
670 if (i == (ssize_t) argc)
671 ThrowCompositeException(OptionError,
"MissingArgument",option);
672 if (IsGeometry(argv[i]) == MagickFalse)
673 ThrowCompositeInvalidArgumentException(option,argv[i]);
676 if (LocaleCompare(
"colorspace",option+1) == 0)
684 if (i == (ssize_t) argc)
685 ThrowCompositeException(OptionError,
"MissingArgument",option);
686 colorspace=ParseCommandOption(MagickColorspaceOptions,
687 MagickFalse,argv[i]);
689 ThrowCompositeException(OptionError,
"UnrecognizedColorspace",
693 if (LocaleCompare(
"comment",option+1) == 0)
698 if (i == (ssize_t) argc)
699 ThrowCompositeException(OptionError,
"MissingArgument",option);
702 if (LocaleCompare(
"compose",option+1) == 0)
707 composite_options.compose=UndefinedCompositeOp;
711 if (i == (ssize_t) argc)
712 ThrowCompositeException(OptionError,
"MissingArgument",option);
713 compose=ParseCommandOption(MagickComposeOptions,MagickFalse,
716 ThrowCompositeException(OptionError,
"UnrecognizedComposeOperator",
718 composite_options.compose=(CompositeOperator) compose;
721 if (LocaleCompare(
"compress",option+1) == 0)
729 if (i == (ssize_t) argc)
730 ThrowCompositeException(OptionError,
"MissingArgument",option);
731 compress=ParseCommandOption(MagickCompressOptions,MagickFalse,
734 ThrowCompositeException(OptionError,
735 "UnrecognizedImageCompression",argv[i]);
738 if (LocaleCompare(
"concurrent",option+1) == 0)
740 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
744 if (LocaleCompare(
"debug",option+1) == 0)
752 if (i == (ssize_t) argc)
753 ThrowCompositeException(OptionError,
"MissingArgument",option);
754 event=ParseCommandOption(MagickLogEventOptions,MagickFalse,argv[i]);
756 ThrowCompositeException(OptionError,
"UnrecognizedEventType",
758 (void) SetLogEventMask(argv[i]);
761 if (LocaleCompare(
"decipher",option+1) == 0)
766 if (i == (ssize_t) argc)
767 ThrowCompositeException(OptionError,
"MissingArgument",option);
770 if (LocaleCompare(
"define",option+1) == 0)
773 if (i == (ssize_t) argc)
774 ThrowCompositeException(OptionError,
"MissingArgument",option);
780 define=GetImageOption(image_info,argv[i]);
781 if (define == (
const char *) NULL)
782 ThrowCompositeException(OptionError,
"NoSuchOption",argv[i]);
787 if (LocaleCompare(
"density",option+1) == 0)
792 if (i == (ssize_t) argc)
793 ThrowCompositeException(OptionError,
"MissingArgument",option);
794 if (IsGeometry(argv[i]) == MagickFalse)
795 ThrowCompositeInvalidArgumentException(option,argv[i]);
798 if (LocaleCompare(
"depth",option+1) == 0)
803 if (i == (ssize_t) argc)
804 ThrowCompositeException(OptionError,
"MissingArgument",option);
805 if (IsGeometry(argv[i]) == MagickFalse)
806 ThrowCompositeInvalidArgumentException(option,argv[i]);
809 if (LocaleCompare(
"displace",option+1) == 0)
811 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
815 if (i == (ssize_t) argc)
816 ThrowCompositeException(OptionError,
"MissingArgument",option);
817 if (IsGeometry(argv[i]) == MagickFalse)
818 ThrowCompositeInvalidArgumentException(option,argv[i]);
819 (void) CloneString(&composite_options.compose_args,argv[i]);
820 composite_options.compose=DisplaceCompositeOp;
823 if (LocaleCompare(
"display",option+1) == 0)
828 if (i == (ssize_t) argc)
829 ThrowCompositeException(OptionError,
"MissingArgument",option);
832 if (LocaleCompare(
"dispose",option+1) == 0)
840 if (i == (ssize_t) argc)
841 ThrowCompositeException(OptionError,
"MissingArgument",option);
842 dispose=ParseCommandOption(MagickDisposeOptions,MagickFalse,argv[i]);
844 ThrowCompositeException(OptionError,
"UnrecognizedDisposeMethod",
848 if (LocaleCompare(
"dissolve",option+1) == 0)
850 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
854 if (i == (ssize_t) argc)
855 ThrowCompositeException(OptionError,
"MissingArgument",option);
856 if (IsGeometry(argv[i]) == MagickFalse)
857 ThrowCompositeInvalidArgumentException(option,argv[i]);
858 (void) CloneString(&composite_options.compose_args,argv[i]);
859 composite_options.compose=DissolveCompositeOp;
862 if (LocaleCompare(
"distort",option+1) == 0)
864 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
868 if (i == (ssize_t) argc)
869 ThrowCompositeException(OptionError,
"MissingArgument",option);
870 if (IsGeometry(argv[i]) == MagickFalse)
871 ThrowCompositeInvalidArgumentException(option,argv[i]);
872 (void) CloneString(&composite_options.compose_args,argv[i]);
873 composite_options.compose=DistortCompositeOp;
876 if (LocaleCompare(
"dither",option+1) == 0)
884 if (i == (ssize_t) argc)
885 ThrowCompositeException(OptionError,
"MissingArgument",option);
886 method=ParseCommandOption(MagickDitherOptions,MagickFalse,argv[i]);
888 ThrowCompositeException(OptionError,
"UnrecognizedDitherMethod",
892 if (LocaleCompare(
"duration",option+1) == 0)
897 if (i == (ssize_t) argc)
898 ThrowCompositeException(OptionError,
"MissingArgument",option);
899 if (IsGeometry(argv[i]) == MagickFalse)
900 ThrowCompositeInvalidArgumentException(option,argv[i]);
903 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
907 if (LocaleCompare(
"encipher",option+1) == 0)
912 if (i == (ssize_t) argc)
913 ThrowCompositeException(OptionError,
"MissingArgument",option);
916 if (LocaleCompare(
"encoding",option+1) == 0)
921 if (i == (ssize_t) argc)
922 ThrowCompositeException(OptionError,
"MissingArgument",option);
925 if (LocaleCompare(
"endian",option+1) == 0)
933 if (i == (ssize_t) argc)
934 ThrowCompositeException(OptionError,
"MissingArgument",option);
935 endian=ParseCommandOption(MagickEndianOptions,MagickFalse,
938 ThrowCompositeException(OptionError,
"UnrecognizedEndianType",
942 if (LocaleCompare(
"extract",option+1) == 0)
947 if (i == (ssize_t) argc)
948 ThrowCompositeException(OptionError,
"MissingArgument",option);
949 if (IsGeometry(argv[i]) == MagickFalse)
950 ThrowCompositeInvalidArgumentException(option,argv[i]);
953 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
957 if (LocaleCompare(
"filter",option+1) == 0)
965 if (i == (ssize_t) argc)
966 ThrowCompositeException(OptionError,
"MissingArgument",option);
967 filter=ParseCommandOption(MagickFilterOptions,MagickFalse,argv[i]);
969 ThrowCompositeException(OptionError,
"UnrecognizedImageFilter",
973 if (LocaleCompare(
"font",option+1) == 0)
978 if (i == (ssize_t) argc)
979 ThrowCompositeException(OptionError,
"MissingArgument",option);
982 if (LocaleCompare(
"format",option+1) == 0)
987 if (i == (ssize_t) argc)
988 ThrowCompositeException(OptionError,
"MissingArgument",option);
992 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
996 if (LocaleCompare(
"geometry",option+1) == 0)
998 (void) CloneString(&composite_options.geometry,(
char *) NULL);
1002 if (i == (ssize_t) argc)
1003 ThrowCompositeException(OptionError,
"MissingArgument",option);
1004 if (IsGeometry(argv[i]) == MagickFalse)
1005 ThrowCompositeInvalidArgumentException(option,argv[i]);
1006 (void) CloneString(&composite_options.geometry,argv[i]);
1009 if (LocaleCompare(
"gravity",option+1) == 0)
1014 composite_options.gravity=UndefinedGravity;
1018 if (i == (ssize_t) argc)
1019 ThrowCompositeException(OptionError,
"MissingArgument",option);
1020 gravity=ParseCommandOption(MagickGravityOptions,MagickFalse,
1023 ThrowCompositeException(OptionError,
"UnrecognizedGravityType",
1025 composite_options.gravity=(GravityType) gravity;
1028 if (LocaleCompare(
"green-primary",option+1) == 0)
1033 if (i == (ssize_t) argc)
1034 ThrowCompositeException(OptionError,
"MissingArgument",option);
1035 if (IsGeometry(argv[i]) == MagickFalse)
1036 ThrowCompositeInvalidArgumentException(option,argv[i]);
1039 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1043 if ((LocaleCompare(
"help",option+1) == 0) ||
1044 (LocaleCompare(
"-help",option+1) == 0))
1047 return(CompositeUsage());
1049 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1053 if (LocaleCompare(
"identify",option+1) == 0)
1055 if (LocaleCompare(
"interlace",option+1) == 0)
1063 if (i == (ssize_t) argc)
1064 ThrowCompositeException(OptionError,
"MissingArgument",option);
1065 interlace=ParseCommandOption(MagickInterlaceOptions,MagickFalse,
1068 ThrowCompositeException(OptionError,
1069 "UnrecognizedInterlaceType",argv[i]);
1072 if (LocaleCompare(
"interpolate",option+1) == 0)
1080 if (i == (ssize_t) argc)
1081 ThrowCompositeException(OptionError,
"MissingArgument",option);
1082 interpolate=ParseCommandOption(MagickInterpolateOptions,MagickFalse,
1084 if (interpolate < 0)
1085 ThrowCompositeException(OptionError,
1086 "UnrecognizedInterpolateMethod",argv[i]);
1089 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1093 if (LocaleCompare(
"label",option+1) == 0)
1098 if (i == (ssize_t) argc)
1099 ThrowCompositeException(OptionError,
"MissingArgument",option);
1102 if (LocaleCompare(
"limit",option+1) == 0)
1116 if (i == (ssize_t) argc)
1117 ThrowCompositeException(OptionError,
"MissingArgument",option);
1118 resource=ParseCommandOption(MagickResourceOptions,MagickFalse,
1121 ThrowCompositeException(OptionError,
"UnrecognizedResourceType",
1124 if (i == (ssize_t) argc)
1125 ThrowCompositeException(OptionError,
"MissingArgument",option);
1126 value=StringToDouble(argv[i],&p);
1128 if ((p == argv[i]) && (LocaleCompare(
"unlimited",argv[i]) != 0))
1129 ThrowCompositeInvalidArgumentException(option,argv[i]);
1132 if (LocaleCompare(
"list",option+1) == 0)
1140 if (i == (ssize_t) argc)
1141 ThrowCompositeException(OptionError,
"MissingArgument",option);
1142 list=ParseCommandOption(MagickListOptions,MagickFalse,argv[i]);
1144 ThrowCompositeException(OptionError,
"UnrecognizedListType",
1146 status=MogrifyImageInfo(image_info,(
int) (i-j+1),(
const char **)
1149 return(status == 0 ? MagickFalse : MagickTrue);
1151 if (LocaleCompare(
"log",option+1) == 0)
1156 if ((i == (ssize_t) argc) || (strchr(argv[i],
'%') == (
char *) NULL))
1157 ThrowCompositeException(OptionError,
"MissingArgument",option);
1160 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1164 if (LocaleCompare(
"matte",option+1) == 0)
1166 if (LocaleCompare(
"monitor",option+1) == 0)
1168 if (LocaleCompare(
"monochrome",option+1) == 0)
1170 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1174 if (LocaleCompare(
"negate",option+1) == 0)
1176 if (LocaleCompare(
"noop",option+1) == 0)
1178 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1182 if (LocaleCompare(
"page",option+1) == 0)
1187 if (i == (ssize_t) argc)
1188 ThrowCompositeException(OptionError,
"MissingArgument",option);
1191 if (LocaleCompare(
"pointsize",option+1) == 0)
1196 if (i == (ssize_t) argc)
1197 ThrowCompositeException(OptionError,
"MissingArgument",option);
1198 if (IsGeometry(argv[i]) == MagickFalse)
1199 ThrowCompositeInvalidArgumentException(option,argv[i]);
1202 if (LocaleCompare(
"process",option+1) == 0)
1207 if (i == (ssize_t) argc)
1208 ThrowCompositeException(OptionError,
"MissingArgument",option);
1211 if (LocaleCompare(
"profile",option+1) == 0)
1214 if (i == (ssize_t) argc)
1215 ThrowCompositeException(OptionError,
"MissingArgument",option);
1218 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1222 if (LocaleCompare(
"quality",option+1) == 0)
1227 if (i == (ssize_t) argc)
1228 ThrowCompositeException(OptionError,
"MissingArgument",option);
1229 if (IsGeometry(argv[i]) == MagickFalse)
1230 ThrowCompositeInvalidArgumentException(option,argv[i]);
1233 if (LocaleCompare(
"quantize",option+1) == 0)
1241 if (i == (ssize_t) argc)
1242 ThrowCompositeException(OptionError,
"MissingArgument",option);
1243 colorspace=ParseCommandOption(MagickColorspaceOptions,
1244 MagickFalse,argv[i]);
1246 ThrowCompositeException(OptionError,
"UnrecognizedColorspace",
1250 if (LocaleCompare(
"quiet",option+1) == 0)
1252 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1256 if (LocaleCompare(
"red-primary",option+1) == 0)
1261 if (i == (ssize_t) argc)
1262 ThrowCompositeException(OptionError,
"MissingArgument",option);
1263 if (IsGeometry(argv[i]) == MagickFalse)
1264 ThrowCompositeInvalidArgumentException(option,argv[i]);
1267 if (LocaleCompare(
"regard-warnings",option+1) == 0)
1269 if (LocaleCompare(
"render",option+1) == 0)
1271 if (LocaleCompare(
"repage",option+1) == 0)
1276 if (i == (ssize_t) argc)
1277 ThrowCompositeException(OptionError,
"MissingArgument",option);
1278 if (IsGeometry(argv[i]) == MagickFalse)
1279 ThrowCompositeInvalidArgumentException(option,argv[i]);
1282 if (LocaleNCompare(
"respect-parentheses",option+1,17) == 0)
1284 respect_parenthesis=(*option ==
'-') ? MagickTrue : MagickFalse;
1287 if (LocaleCompare(
"resize",option+1) == 0)
1292 if (i == (ssize_t) argc)
1293 ThrowCompositeException(OptionError,
"MissingArgument",option);
1294 if (IsGeometry(argv[i]) == MagickFalse)
1295 ThrowCompositeInvalidArgumentException(option,argv[i]);
1298 if (LocaleCompare(
"rotate",option+1) == 0)
1301 if (i == (ssize_t) argc)
1302 ThrowCompositeException(OptionError,
"MissingArgument",option);
1303 if (IsGeometry(argv[i]) == MagickFalse)
1304 ThrowCompositeInvalidArgumentException(option,argv[i]);
1307 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1311 if (LocaleCompare(
"sampling-factor",option+1) == 0)
1316 if (i == (ssize_t) argc)
1317 ThrowCompositeException(OptionError,
"MissingArgument",option);
1318 if (IsGeometry(argv[i]) == MagickFalse)
1319 ThrowCompositeInvalidArgumentException(option,argv[i]);
1322 if (LocaleCompare(
"scene",option+1) == 0)
1327 if (i == (ssize_t) argc)
1328 ThrowCompositeException(OptionError,
"MissingArgument",option);
1329 if (IsGeometry(argv[i]) == MagickFalse)
1330 ThrowCompositeInvalidArgumentException(option,argv[i]);
1333 if (LocaleCompare(
"seed",option+1) == 0)
1338 if (i == (ssize_t) argc)
1339 ThrowCompositeException(OptionError,
"MissingArgument",option);
1340 if (IsGeometry(argv[i]) == MagickFalse)
1341 ThrowCompositeInvalidArgumentException(option,argv[i]);
1344 if (LocaleCompare(
"sharpen",option+1) == 0)
1347 if (i == (ssize_t) argc)
1348 ThrowCompositeException(OptionError,
"MissingArgument",option);
1349 if (IsGeometry(argv[i]) == MagickFalse)
1350 ThrowCompositeInvalidArgumentException(option,argv[i]);
1353 if (LocaleCompare(
"shave",option+1) == 0)
1358 if (i == (ssize_t) argc)
1359 ThrowCompositeException(OptionError,
"MissingArgument",option);
1360 if (IsGeometry(argv[i]) == MagickFalse)
1361 ThrowCompositeInvalidArgumentException(option,argv[i]);
1364 if (LocaleCompare(
"size",option+1) == 0)
1369 if (i == (ssize_t) argc)
1370 ThrowCompositeException(OptionError,
"MissingArgument",option);
1371 if (IsGeometry(argv[i]) == MagickFalse)
1372 ThrowCompositeInvalidArgumentException(option,argv[i]);
1375 if (LocaleCompare(
"stegano",option+1) == 0)
1377 composite_options.stegano=0;
1381 if (i == (ssize_t) argc)
1382 ThrowCompositeException(OptionError,
"MissingArgument",option);
1383 if (IsGeometry(argv[i]) == MagickFalse)
1384 ThrowCompositeInvalidArgumentException(option,argv[i]);
1385 composite_options.stegano=(ssize_t) StringToLong(argv[i])+1;
1388 if (LocaleCompare(
"stereo",option+1) == 0)
1393 composite_options.stereo=MagickFalse;
1397 if (i == (ssize_t) argc)
1398 ThrowCompositeException(OptionError,
"MissingArgument",option);
1399 if (IsGeometry(argv[i]) == MagickFalse)
1400 ThrowCompositeInvalidArgumentException(option,argv[i]);
1401 flags=ParseAbsoluteGeometry(argv[i],&composite_options.offset);
1402 if ((flags & YValue) == 0)
1403 composite_options.offset.y=composite_options.offset.x;
1404 composite_options.stereo=MagickTrue;
1407 if (LocaleCompare(
"strip",option+1) == 0)
1409 if (LocaleCompare(
"support",option+1) == 0)
1414 if (LocaleCompare(
"swap",option+1) == 0)
1419 if (i == (ssize_t) argc)
1420 ThrowCompositeException(OptionError,
"MissingArgument",option);
1421 if (IsGeometry(argv[i]) == MagickFalse)
1422 ThrowCompositeInvalidArgumentException(option,argv[i]);
1425 if (LocaleCompare(
"synchronize",option+1) == 0)
1427 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1431 if (LocaleCompare(
"taint",option+1) == 0)
1433 if (LocaleCompare(
"thumbnail",option+1) == 0)
1438 if (i == (ssize_t) argc)
1439 ThrowCompositeException(OptionError,
"MissingArgument",option);
1440 if (IsGeometry(argv[i]) == MagickFalse)
1441 ThrowCompositeInvalidArgumentException(option,argv[i]);
1444 if (LocaleCompare(
"tile",option+1) == 0)
1446 composite_options.tile=(*option ==
'-') ? MagickTrue : MagickFalse;
1447 (void) CopyMagickString(argv[i]+1,
"sans",MaxTextExtent);
1450 if (LocaleCompare(
"transform",option+1) == 0)
1452 if (LocaleCompare(
"transparent-color",option+1) == 0)
1457 if (i == (ssize_t) argc)
1458 ThrowCompositeException(OptionError,
"MissingArgument",option);
1461 if (LocaleCompare(
"treedepth",option+1) == 0)
1466 if (i == (ssize_t) argc)
1467 ThrowCompositeException(OptionError,
"MissingArgument",option);
1468 if (IsGeometry(argv[i]) == MagickFalse)
1469 ThrowCompositeInvalidArgumentException(option,argv[i]);
1472 if (LocaleCompare(
"type",option+1) == 0)
1480 if (i == (ssize_t) argc)
1481 ThrowCompositeException(OptionError,
"MissingArgument",option);
1482 type=ParseCommandOption(MagickTypeOptions,MagickFalse,argv[i]);
1484 ThrowCompositeException(OptionError,
"UnrecognizedImageType",
1488 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1492 if (LocaleCompare(
"units",option+1) == 0)
1500 if (i == (ssize_t) argc)
1501 ThrowCompositeException(OptionError,
"MissingArgument",option);
1502 units=ParseCommandOption(MagickResolutionOptions,MagickFalse,
1505 ThrowCompositeException(OptionError,
"UnrecognizedUnitsType",
1509 if (LocaleCompare(
"unsharp",option+1) == 0)
1511 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
1515 if (i == (ssize_t) argc)
1516 ThrowCompositeException(OptionError,
"MissingArgument",option);
1517 if (IsGeometry(argv[i]) == MagickFalse)
1518 ThrowCompositeInvalidArgumentException(option,argv[i]);
1519 (void) CloneString(&composite_options.compose_args,argv[i]);
1520 composite_options.compose=ThresholdCompositeOp;
1523 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1527 if (LocaleCompare(
"verbose",option+1) == 0)
1529 if ((LocaleCompare(
"version",option+1) == 0) ||
1530 (LocaleCompare(
"-version",option+1) == 0))
1532 ListMagickVersion(stdout);
1535 if (LocaleCompare(
"virtual-pixel",option+1) == 0)
1543 if (i == (ssize_t) argc)
1544 ThrowCompositeException(OptionError,
"MissingArgument",option);
1545 method=ParseCommandOption(MagickVirtualPixelOptions,MagickFalse,
1548 ThrowCompositeException(OptionError,
1549 "UnrecognizedVirtualPixelMethod",argv[i]);
1552 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1556 if (LocaleCompare(
"watermark",option+1) == 0)
1558 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
1562 if (i == (ssize_t) argc)
1563 ThrowCompositeException(OptionError,
"MissingArgument",option);
1564 if (IsGeometry(argv[i]) == MagickFalse)
1565 ThrowCompositeInvalidArgumentException(option,argv[i]);
1566 (void) CloneString(&composite_options.compose_args,argv[i]);
1567 composite_options.compose=ModulateCompositeOp;
1570 if (LocaleCompare(
"white-point",option+1) == 0)
1575 if (i == (ssize_t) argc)
1576 ThrowCompositeException(OptionError,
"MissingArgument",option);
1577 if (IsGeometry(argv[i]) == MagickFalse)
1578 ThrowCompositeInvalidArgumentException(option,argv[i]);
1581 if (LocaleCompare(
"write",option+1) == 0)
1584 if (i == (ssize_t) argc)
1585 ThrowCompositeException(OptionError,
"MissingArgument",option);
1588 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1593 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1595 fire=(GetCommandOptionFlags(MagickCommandOptions,MagickFalse,option) &
1596 FireOptionFlag) == 0 ? MagickFalse : MagickTrue;
1597 if (fire != MagickFalse)
1598 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
1601 ThrowCompositeException(OptionError,
"UnbalancedParenthesis",argv[i]);
1602 if (i-- != (ssize_t) (argc-1))
1603 ThrowCompositeException(OptionError,
"MissingAnImageFilename",argv[i]);
1604 if ((image == (Image *) NULL) || (GetImageListLength(image) < 2))
1605 ThrowCompositeException(OptionError,
"MissingAnImageFilename",argv[argc-1]);
1606 FinalizeImageSettings(image_info,image,MagickTrue);
1607 if ((image == (Image *) NULL) || (GetImageListLength(image) < 2))
1608 ThrowCompositeException(OptionError,
"MissingAnImageFilename",argv[argc-1]);
1612 RemoveImageStack(composite_image);
1613 RemoveImageStack(images);
1614 (void) TransformImage(&composite_image,(
char *) NULL,
1615 composite_image->geometry);
1616 RemoveImageStack(mask_image);
1617 if (mask_image != (Image *) NULL)
1619 if ((composite_options.compose == DisplaceCompositeOp) ||
1620 (composite_options.compose == DistortCompositeOp))
1625 (void) CompositeImage(composite_image,CopyGreenCompositeOp,mask_image,
1627 mask_image=DestroyImage(mask_image);
1634 images->mask=mask_image;
1635 (void) NegateImage(images->mask,MagickFalse);
1638 status&=CompositeImageList(image_info,&images,composite_image,
1639 &composite_options,exception);
1640 composite_image=DestroyImage(composite_image);
1644 status&=WriteImages(image_info,images,argv[argc-1],exception);
1645 if (metadata != (
char **) NULL)
1650 text=InterpretImageProperties(image_info,images,format);
1651 InheritException(exception,&image->exception);
1652 if (text == (
char *) NULL)
1653 ThrowCompositeException(ResourceLimitError,
"MemoryAllocationFailed",
1654 GetExceptionMessage(errno));
1655 (void) ConcatenateString(&(*metadata),text);
1656 text=DestroyString(text);
1658 images=DestroyImageList(images);
1659 RelinquishCompositeOptions(&composite_options);
1661 return(status != 0 ? MagickTrue : MagickFalse);