43 #include "wand/studio.h"
44 #include "wand/MagickWand.h"
45 #include "wand/mogrify-private.h"
46 #include "magick/string-private.h"
110 static 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);
228 static 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);
368 WandExport 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);
448 return(CompositeUsage());
449 GetCompositeOptions(&composite_options);
450 filename=(
char *) NULL;
455 option=(
char *) NULL;
457 respect_parenthesis=MagickFalse;
462 composite_image=NewImageList();
463 image=NewImageList();
464 mask_image=NewImageList();
465 ReadCommandlLine(argc,&argv);
466 status=ExpandFilenames(&argc,&argv);
467 if (status == MagickFalse)
468 ThrowCompositeException(ResourceLimitError,
"MemoryAllocationFailed",
469 GetExceptionMessage(errno));
470 for (i=1; i < (ssize_t) (argc-1); i++)
473 if (LocaleCompare(option,
"(") == 0)
475 FireImageStack(MagickFalse,MagickTrue,pend);
476 if (k == MaxImageStackDepth)
477 ThrowCompositeException(OptionError,
"ParenthesisNestedTooDeeply",
482 if (LocaleCompare(option,
")") == 0)
484 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
486 ThrowCompositeException(OptionError,
"UnableToParseExpression",option);
490 if (IsCommandOption(option) == MagickFalse)
498 FireImageStack(MagickFalse,MagickFalse,pend);
500 if ((LocaleCompare(filename,
"--") == 0) && (i < (ssize_t) (argc-1)))
502 (void) SetImageOption(image_info,
"filename",filename);
503 (void) CopyMagickString(image_info->filename,filename,MaxTextExtent);
504 images=ReadImages(image_info,exception);
505 status&=(images != (Image *) NULL) &&
506 (exception->severity < ErrorException);
507 if (images == (Image *) NULL)
509 AppendImageStack(images);
512 pend=image != (Image *) NULL ? MagickTrue : MagickFalse;
517 if (LocaleCompare(
"affine",option+1) == 0)
522 if (i == (ssize_t) argc)
523 ThrowCompositeException(OptionError,
"MissingArgument",option);
524 if (IsGeometry(argv[i]) == MagickFalse)
525 ThrowCompositeInvalidArgumentException(option,argv[i]);
528 if (LocaleCompare(
"alpha",option+1) == 0)
536 if (i == (ssize_t) argc)
537 ThrowCompositeException(OptionError,
"MissingArgument",option);
538 type=ParseCommandOption(MagickAlphaOptions,MagickFalse,argv[i]);
540 ThrowCompositeException(OptionError,
541 "UnrecognizedAlphaChannelType",argv[i]);
544 if (LocaleCompare(
"authenticate",option+1) == 0)
549 if (i == (ssize_t) argc)
550 ThrowCompositeException(OptionError,
"MissingArgument",option);
553 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
557 if (LocaleCompare(
"background",option+1) == 0)
562 if (i == (ssize_t) argc)
563 ThrowCompositeException(OptionError,
"MissingArgument",option);
566 if (LocaleCompare(
"blend",option+1) == 0)
568 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
572 if (i == (ssize_t) argc)
573 ThrowCompositeException(OptionError,
"MissingArgument",option);
574 if (IsGeometry(argv[i]) == MagickFalse)
575 ThrowCompositeInvalidArgumentException(option,argv[i]);
576 (void) CloneString(&composite_options.compose_args,argv[i]);
577 composite_options.compose=BlendCompositeOp;
580 if (LocaleCompare(
"blur",option+1) == 0)
582 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
586 if (i == (ssize_t) argc)
587 ThrowCompositeException(OptionError,
"MissingArgument",option);
588 if (IsGeometry(argv[i]) == MagickFalse)
589 ThrowCompositeInvalidArgumentException(option,argv[i]);
590 (void) CloneString(&composite_options.compose_args,argv[i]);
591 composite_options.compose=BlurCompositeOp;
594 if (LocaleCompare(
"blue-primary",option+1) == 0)
599 if (i == (ssize_t) argc)
600 ThrowCompositeException(OptionError,
"MissingArgument",option);
601 if (IsGeometry(argv[i]) == MagickFalse)
602 ThrowCompositeInvalidArgumentException(option,argv[i]);
605 if (LocaleCompare(
"border",option+1) == 0)
610 if (i == (ssize_t) argc)
611 ThrowCompositeException(OptionError,
"MissingArgument",option);
612 if (IsGeometry(argv[i]) == MagickFalse)
613 ThrowCompositeInvalidArgumentException(option,argv[i]);
616 if (LocaleCompare(
"bordercolor",option+1) == 0)
621 if (i == (ssize_t) argc)
622 ThrowCompositeException(OptionError,
"MissingArgument",option);
625 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
629 if (LocaleCompare(
"cache",option+1) == 0)
634 if (i == (ssize_t) argc)
635 ThrowCompositeException(OptionError,
"MissingArgument",option);
636 if (IsGeometry(argv[i]) == MagickFalse)
637 ThrowCompositeInvalidArgumentException(option,argv[i]);
640 if (LocaleCompare(
"channel",option+1) == 0)
647 composite_options.channel=DefaultChannels;
651 if (i == (ssize_t) argc)
652 ThrowCompositeException(OptionError,
"MissingArgument",option);
653 channel=ParseChannelOption(argv[i]);
655 ThrowCompositeException(OptionError,
"UnrecognizedChannelType",
657 composite_options.channel=(ChannelType) channel;
660 if (LocaleCompare(
"colors",option+1) == 0)
665 if (i == (ssize_t) argc)
666 ThrowCompositeException(OptionError,
"MissingArgument",option);
667 if (IsGeometry(argv[i]) == MagickFalse)
668 ThrowCompositeInvalidArgumentException(option,argv[i]);
671 if (LocaleCompare(
"colorspace",option+1) == 0)
679 if (i == (ssize_t) argc)
680 ThrowCompositeException(OptionError,
"MissingArgument",option);
681 colorspace=ParseCommandOption(MagickColorspaceOptions,
682 MagickFalse,argv[i]);
684 ThrowCompositeException(OptionError,
"UnrecognizedColorspace",
688 if (LocaleCompare(
"comment",option+1) == 0)
693 if (i == (ssize_t) argc)
694 ThrowCompositeException(OptionError,
"MissingArgument",option);
697 if (LocaleCompare(
"compose",option+1) == 0)
702 composite_options.compose=UndefinedCompositeOp;
706 if (i == (ssize_t) argc)
707 ThrowCompositeException(OptionError,
"MissingArgument",option);
708 compose=ParseCommandOption(MagickComposeOptions,MagickFalse,
711 ThrowCompositeException(OptionError,
"UnrecognizedComposeOperator",
713 composite_options.compose=(CompositeOperator) compose;
716 if (LocaleCompare(
"compress",option+1) == 0)
724 if (i == (ssize_t) argc)
725 ThrowCompositeException(OptionError,
"MissingArgument",option);
726 compress=ParseCommandOption(MagickCompressOptions,MagickFalse,
729 ThrowCompositeException(OptionError,
730 "UnrecognizedImageCompression",argv[i]);
733 if (LocaleCompare(
"concurrent",option+1) == 0)
735 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
739 if (LocaleCompare(
"debug",option+1) == 0)
747 if (i == (ssize_t) argc)
748 ThrowCompositeException(OptionError,
"MissingArgument",option);
749 event=ParseCommandOption(MagickLogEventOptions,MagickFalse,argv[i]);
751 ThrowCompositeException(OptionError,
"UnrecognizedEventType",
753 (void) SetLogEventMask(argv[i]);
756 if (LocaleCompare(
"decipher",option+1) == 0)
761 if (i == (ssize_t) argc)
762 ThrowCompositeException(OptionError,
"MissingArgument",option);
765 if (LocaleCompare(
"define",option+1) == 0)
768 if (i == (ssize_t) argc)
769 ThrowCompositeException(OptionError,
"MissingArgument",option);
775 define=GetImageOption(image_info,argv[i]);
776 if (define == (
const char *) NULL)
777 ThrowCompositeException(OptionError,
"NoSuchOption",argv[i]);
782 if (LocaleCompare(
"density",option+1) == 0)
787 if (i == (ssize_t) argc)
788 ThrowCompositeException(OptionError,
"MissingArgument",option);
789 if (IsGeometry(argv[i]) == MagickFalse)
790 ThrowCompositeInvalidArgumentException(option,argv[i]);
793 if (LocaleCompare(
"depth",option+1) == 0)
798 if (i == (ssize_t) argc)
799 ThrowCompositeException(OptionError,
"MissingArgument",option);
800 if (IsGeometry(argv[i]) == MagickFalse)
801 ThrowCompositeInvalidArgumentException(option,argv[i]);
804 if (LocaleCompare(
"displace",option+1) == 0)
806 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
810 if (i == (ssize_t) argc)
811 ThrowCompositeException(OptionError,
"MissingArgument",option);
812 if (IsGeometry(argv[i]) == MagickFalse)
813 ThrowCompositeInvalidArgumentException(option,argv[i]);
814 (void) CloneString(&composite_options.compose_args,argv[i]);
815 composite_options.compose=DisplaceCompositeOp;
818 if (LocaleCompare(
"display",option+1) == 0)
823 if (i == (ssize_t) argc)
824 ThrowCompositeException(OptionError,
"MissingArgument",option);
827 if (LocaleCompare(
"dispose",option+1) == 0)
835 if (i == (ssize_t) argc)
836 ThrowCompositeException(OptionError,
"MissingArgument",option);
837 dispose=ParseCommandOption(MagickDisposeOptions,MagickFalse,argv[i]);
839 ThrowCompositeException(OptionError,
"UnrecognizedDisposeMethod",
843 if (LocaleCompare(
"dissolve",option+1) == 0)
845 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
849 if (i == (ssize_t) argc)
850 ThrowCompositeException(OptionError,
"MissingArgument",option);
851 if (IsGeometry(argv[i]) == MagickFalse)
852 ThrowCompositeInvalidArgumentException(option,argv[i]);
853 (void) CloneString(&composite_options.compose_args,argv[i]);
854 composite_options.compose=DissolveCompositeOp;
857 if (LocaleCompare(
"distort",option+1) == 0)
859 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
863 if (i == (ssize_t) argc)
864 ThrowCompositeException(OptionError,
"MissingArgument",option);
865 if (IsGeometry(argv[i]) == MagickFalse)
866 ThrowCompositeInvalidArgumentException(option,argv[i]);
867 (void) CloneString(&composite_options.compose_args,argv[i]);
868 composite_options.compose=DistortCompositeOp;
871 if (LocaleCompare(
"dither",option+1) == 0)
879 if (i == (ssize_t) argc)
880 ThrowCompositeException(OptionError,
"MissingArgument",option);
881 method=ParseCommandOption(MagickDitherOptions,MagickFalse,argv[i]);
883 ThrowCompositeException(OptionError,
"UnrecognizedDitherMethod",
887 if (LocaleCompare(
"duration",option+1) == 0)
892 if (i == (ssize_t) argc)
893 ThrowCompositeException(OptionError,
"MissingArgument",option);
894 if (IsGeometry(argv[i]) == MagickFalse)
895 ThrowCompositeInvalidArgumentException(option,argv[i]);
898 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
902 if (LocaleCompare(
"encipher",option+1) == 0)
907 if (i == (ssize_t) argc)
908 ThrowCompositeException(OptionError,
"MissingArgument",option);
911 if (LocaleCompare(
"encoding",option+1) == 0)
916 if (i == (ssize_t) argc)
917 ThrowCompositeException(OptionError,
"MissingArgument",option);
920 if (LocaleCompare(
"endian",option+1) == 0)
928 if (i == (ssize_t) argc)
929 ThrowCompositeException(OptionError,
"MissingArgument",option);
930 endian=ParseCommandOption(MagickEndianOptions,MagickFalse,
933 ThrowCompositeException(OptionError,
"UnrecognizedEndianType",
937 if (LocaleCompare(
"extract",option+1) == 0)
942 if (i == (ssize_t) argc)
943 ThrowCompositeException(OptionError,
"MissingArgument",option);
944 if (IsGeometry(argv[i]) == MagickFalse)
945 ThrowCompositeInvalidArgumentException(option,argv[i]);
948 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
952 if (LocaleCompare(
"filter",option+1) == 0)
960 if (i == (ssize_t) argc)
961 ThrowCompositeException(OptionError,
"MissingArgument",option);
962 filter=ParseCommandOption(MagickFilterOptions,MagickFalse,argv[i]);
964 ThrowCompositeException(OptionError,
"UnrecognizedImageFilter",
968 if (LocaleCompare(
"font",option+1) == 0)
973 if (i == (ssize_t) argc)
974 ThrowCompositeException(OptionError,
"MissingArgument",option);
977 if (LocaleCompare(
"format",option+1) == 0)
982 if (i == (ssize_t) argc)
983 ThrowCompositeException(OptionError,
"MissingArgument",option);
987 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
991 if (LocaleCompare(
"geometry",option+1) == 0)
993 (void) CloneString(&composite_options.geometry,(
char *) NULL);
997 if (i == (ssize_t) argc)
998 ThrowCompositeException(OptionError,
"MissingArgument",option);
999 if (IsGeometry(argv[i]) == MagickFalse)
1000 ThrowCompositeInvalidArgumentException(option,argv[i]);
1001 (void) CloneString(&composite_options.geometry,argv[i]);
1004 if (LocaleCompare(
"gravity",option+1) == 0)
1009 composite_options.gravity=UndefinedGravity;
1013 if (i == (ssize_t) argc)
1014 ThrowCompositeException(OptionError,
"MissingArgument",option);
1015 gravity=ParseCommandOption(MagickGravityOptions,MagickFalse,
1018 ThrowCompositeException(OptionError,
"UnrecognizedGravityType",
1020 composite_options.gravity=(GravityType) gravity;
1023 if (LocaleCompare(
"green-primary",option+1) == 0)
1028 if (i == (ssize_t) argc)
1029 ThrowCompositeException(OptionError,
"MissingArgument",option);
1030 if (IsGeometry(argv[i]) == MagickFalse)
1031 ThrowCompositeInvalidArgumentException(option,argv[i]);
1034 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1038 if ((LocaleCompare(
"help",option+1) == 0) ||
1039 (LocaleCompare(
"-help",option+1) == 0))
1042 return(CompositeUsage());
1044 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1048 if (LocaleCompare(
"identify",option+1) == 0)
1050 if (LocaleCompare(
"interlace",option+1) == 0)
1058 if (i == (ssize_t) argc)
1059 ThrowCompositeException(OptionError,
"MissingArgument",option);
1060 interlace=ParseCommandOption(MagickInterlaceOptions,MagickFalse,
1063 ThrowCompositeException(OptionError,
1064 "UnrecognizedInterlaceType",argv[i]);
1067 if (LocaleCompare(
"interpolate",option+1) == 0)
1075 if (i == (ssize_t) argc)
1076 ThrowCompositeException(OptionError,
"MissingArgument",option);
1077 interpolate=ParseCommandOption(MagickInterpolateOptions,MagickFalse,
1079 if (interpolate < 0)
1080 ThrowCompositeException(OptionError,
1081 "UnrecognizedInterpolateMethod",argv[i]);
1084 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1088 if (LocaleCompare(
"label",option+1) == 0)
1093 if (i == (ssize_t) argc)
1094 ThrowCompositeException(OptionError,
"MissingArgument",option);
1097 if (LocaleCompare(
"limit",option+1) == 0)
1111 if (i == (ssize_t) argc)
1112 ThrowCompositeException(OptionError,
"MissingArgument",option);
1113 resource=ParseCommandOption(MagickResourceOptions,MagickFalse,
1116 ThrowCompositeException(OptionError,
"UnrecognizedResourceType",
1119 if (i == (ssize_t) argc)
1120 ThrowCompositeException(OptionError,
"MissingArgument",option);
1121 value=StringToDouble(argv[i],&p);
1123 if ((p == argv[i]) && (LocaleCompare(
"unlimited",argv[i]) != 0))
1124 ThrowCompositeInvalidArgumentException(option,argv[i]);
1127 if (LocaleCompare(
"list",option+1) == 0)
1135 if (i == (ssize_t) argc)
1136 ThrowCompositeException(OptionError,
"MissingArgument",option);
1137 list=ParseCommandOption(MagickListOptions,MagickFalse,argv[i]);
1139 ThrowCompositeException(OptionError,
"UnrecognizedListType",
1141 status=MogrifyImageInfo(image_info,(
int) (i-j+1),(
const char **)
1144 return(status == 0 ? MagickFalse : MagickTrue);
1146 if (LocaleCompare(
"log",option+1) == 0)
1151 if ((i == (ssize_t) argc) || (strchr(argv[i],
'%') == (
char *) NULL))
1152 ThrowCompositeException(OptionError,
"MissingArgument",option);
1155 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1159 if (LocaleCompare(
"matte",option+1) == 0)
1161 if (LocaleCompare(
"monitor",option+1) == 0)
1163 if (LocaleCompare(
"monochrome",option+1) == 0)
1165 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1169 if (LocaleCompare(
"negate",option+1) == 0)
1171 if (LocaleCompare(
"noop",option+1) == 0)
1173 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1177 if (LocaleCompare(
"page",option+1) == 0)
1182 if (i == (ssize_t) argc)
1183 ThrowCompositeException(OptionError,
"MissingArgument",option);
1186 if (LocaleCompare(
"pointsize",option+1) == 0)
1191 if (i == (ssize_t) argc)
1192 ThrowCompositeException(OptionError,
"MissingArgument",option);
1193 if (IsGeometry(argv[i]) == MagickFalse)
1194 ThrowCompositeInvalidArgumentException(option,argv[i]);
1197 if (LocaleCompare(
"process",option+1) == 0)
1202 if (i == (ssize_t) argc)
1203 ThrowCompositeException(OptionError,
"MissingArgument",option);
1206 if (LocaleCompare(
"profile",option+1) == 0)
1209 if (i == (ssize_t) argc)
1210 ThrowCompositeException(OptionError,
"MissingArgument",option);
1213 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1217 if (LocaleCompare(
"quality",option+1) == 0)
1222 if (i == (ssize_t) argc)
1223 ThrowCompositeException(OptionError,
"MissingArgument",option);
1224 if (IsGeometry(argv[i]) == MagickFalse)
1225 ThrowCompositeInvalidArgumentException(option,argv[i]);
1228 if (LocaleCompare(
"quantize",option+1) == 0)
1236 if (i == (ssize_t) argc)
1237 ThrowCompositeException(OptionError,
"MissingArgument",option);
1238 colorspace=ParseCommandOption(MagickColorspaceOptions,
1239 MagickFalse,argv[i]);
1241 ThrowCompositeException(OptionError,
"UnrecognizedColorspace",
1245 if (LocaleCompare(
"quiet",option+1) == 0)
1247 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1251 if (LocaleCompare(
"red-primary",option+1) == 0)
1256 if (i == (ssize_t) argc)
1257 ThrowCompositeException(OptionError,
"MissingArgument",option);
1258 if (IsGeometry(argv[i]) == MagickFalse)
1259 ThrowCompositeInvalidArgumentException(option,argv[i]);
1262 if (LocaleCompare(
"regard-warnings",option+1) == 0)
1264 if (LocaleCompare(
"render",option+1) == 0)
1266 if (LocaleCompare(
"repage",option+1) == 0)
1271 if (i == (ssize_t) argc)
1272 ThrowCompositeException(OptionError,
"MissingArgument",option);
1273 if (IsGeometry(argv[i]) == MagickFalse)
1274 ThrowCompositeInvalidArgumentException(option,argv[i]);
1277 if (LocaleNCompare(
"respect-parentheses",option+1,17) == 0)
1279 respect_parenthesis=(*option ==
'-') ? MagickTrue : MagickFalse;
1282 if (LocaleCompare(
"resize",option+1) == 0)
1287 if (i == (ssize_t) argc)
1288 ThrowCompositeException(OptionError,
"MissingArgument",option);
1289 if (IsGeometry(argv[i]) == MagickFalse)
1290 ThrowCompositeInvalidArgumentException(option,argv[i]);
1293 if (LocaleCompare(
"rotate",option+1) == 0)
1296 if (i == (ssize_t) argc)
1297 ThrowCompositeException(OptionError,
"MissingArgument",option);
1298 if (IsGeometry(argv[i]) == MagickFalse)
1299 ThrowCompositeInvalidArgumentException(option,argv[i]);
1302 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1306 if (LocaleCompare(
"sampling-factor",option+1) == 0)
1311 if (i == (ssize_t) argc)
1312 ThrowCompositeException(OptionError,
"MissingArgument",option);
1313 if (IsGeometry(argv[i]) == MagickFalse)
1314 ThrowCompositeInvalidArgumentException(option,argv[i]);
1317 if (LocaleCompare(
"scene",option+1) == 0)
1322 if (i == (ssize_t) argc)
1323 ThrowCompositeException(OptionError,
"MissingArgument",option);
1324 if (IsGeometry(argv[i]) == MagickFalse)
1325 ThrowCompositeInvalidArgumentException(option,argv[i]);
1328 if (LocaleCompare(
"seed",option+1) == 0)
1333 if (i == (ssize_t) argc)
1334 ThrowCompositeException(OptionError,
"MissingArgument",option);
1335 if (IsGeometry(argv[i]) == MagickFalse)
1336 ThrowCompositeInvalidArgumentException(option,argv[i]);
1339 if (LocaleCompare(
"sharpen",option+1) == 0)
1342 if (i == (ssize_t) argc)
1343 ThrowCompositeException(OptionError,
"MissingArgument",option);
1344 if (IsGeometry(argv[i]) == MagickFalse)
1345 ThrowCompositeInvalidArgumentException(option,argv[i]);
1348 if (LocaleCompare(
"shave",option+1) == 0)
1353 if (i == (ssize_t) argc)
1354 ThrowCompositeException(OptionError,
"MissingArgument",option);
1355 if (IsGeometry(argv[i]) == MagickFalse)
1356 ThrowCompositeInvalidArgumentException(option,argv[i]);
1359 if (LocaleCompare(
"size",option+1) == 0)
1364 if (i == (ssize_t) argc)
1365 ThrowCompositeException(OptionError,
"MissingArgument",option);
1366 if (IsGeometry(argv[i]) == MagickFalse)
1367 ThrowCompositeInvalidArgumentException(option,argv[i]);
1370 if (LocaleCompare(
"stegano",option+1) == 0)
1372 composite_options.stegano=0;
1376 if (i == (ssize_t) argc)
1377 ThrowCompositeException(OptionError,
"MissingArgument",option);
1378 if (IsGeometry(argv[i]) == MagickFalse)
1379 ThrowCompositeInvalidArgumentException(option,argv[i]);
1380 composite_options.stegano=(ssize_t) StringToLong(argv[i])+1;
1383 if (LocaleCompare(
"stereo",option+1) == 0)
1388 composite_options.stereo=MagickFalse;
1392 if (i == (ssize_t) argc)
1393 ThrowCompositeException(OptionError,
"MissingArgument",option);
1394 if (IsGeometry(argv[i]) == MagickFalse)
1395 ThrowCompositeInvalidArgumentException(option,argv[i]);
1396 flags=ParseAbsoluteGeometry(argv[i],&composite_options.offset);
1397 if ((flags & YValue) == 0)
1398 composite_options.offset.y=composite_options.offset.x;
1399 composite_options.stereo=MagickTrue;
1402 if (LocaleCompare(
"strip",option+1) == 0)
1404 if (LocaleCompare(
"support",option+1) == 0)
1409 if (LocaleCompare(
"swap",option+1) == 0)
1414 if (i == (ssize_t) argc)
1415 ThrowCompositeException(OptionError,
"MissingArgument",option);
1416 if (IsGeometry(argv[i]) == MagickFalse)
1417 ThrowCompositeInvalidArgumentException(option,argv[i]);
1420 if (LocaleCompare(
"synchronize",option+1) == 0)
1422 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1426 if (LocaleCompare(
"taint",option+1) == 0)
1428 if (LocaleCompare(
"thumbnail",option+1) == 0)
1433 if (i == (ssize_t) argc)
1434 ThrowCompositeException(OptionError,
"MissingArgument",option);
1435 if (IsGeometry(argv[i]) == MagickFalse)
1436 ThrowCompositeInvalidArgumentException(option,argv[i]);
1439 if (LocaleCompare(
"tile",option+1) == 0)
1441 composite_options.tile=(*option ==
'-') ? MagickTrue : MagickFalse;
1442 (void) CopyMagickString(argv[i]+1,
"sans",MaxTextExtent);
1445 if (LocaleCompare(
"transform",option+1) == 0)
1447 if (LocaleCompare(
"transparent-color",option+1) == 0)
1452 if (i == (ssize_t) argc)
1453 ThrowCompositeException(OptionError,
"MissingArgument",option);
1456 if (LocaleCompare(
"treedepth",option+1) == 0)
1461 if (i == (ssize_t) argc)
1462 ThrowCompositeException(OptionError,
"MissingArgument",option);
1463 if (IsGeometry(argv[i]) == MagickFalse)
1464 ThrowCompositeInvalidArgumentException(option,argv[i]);
1467 if (LocaleCompare(
"type",option+1) == 0)
1475 if (i == (ssize_t) argc)
1476 ThrowCompositeException(OptionError,
"MissingArgument",option);
1477 type=ParseCommandOption(MagickTypeOptions,MagickFalse,argv[i]);
1479 ThrowCompositeException(OptionError,
"UnrecognizedImageType",
1483 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1487 if (LocaleCompare(
"units",option+1) == 0)
1495 if (i == (ssize_t) argc)
1496 ThrowCompositeException(OptionError,
"MissingArgument",option);
1497 units=ParseCommandOption(MagickResolutionOptions,MagickFalse,
1500 ThrowCompositeException(OptionError,
"UnrecognizedUnitsType",
1504 if (LocaleCompare(
"unsharp",option+1) == 0)
1506 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
1510 if (i == (ssize_t) argc)
1511 ThrowCompositeException(OptionError,
"MissingArgument",option);
1512 if (IsGeometry(argv[i]) == MagickFalse)
1513 ThrowCompositeInvalidArgumentException(option,argv[i]);
1514 (void) CloneString(&composite_options.compose_args,argv[i]);
1515 composite_options.compose=ThresholdCompositeOp;
1518 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1522 if (LocaleCompare(
"verbose",option+1) == 0)
1524 if ((LocaleCompare(
"version",option+1) == 0) ||
1525 (LocaleCompare(
"-version",option+1) == 0))
1527 ListMagickVersion(stdout);
1530 if (LocaleCompare(
"virtual-pixel",option+1) == 0)
1538 if (i == (ssize_t) argc)
1539 ThrowCompositeException(OptionError,
"MissingArgument",option);
1540 method=ParseCommandOption(MagickVirtualPixelOptions,MagickFalse,
1543 ThrowCompositeException(OptionError,
1544 "UnrecognizedVirtualPixelMethod",argv[i]);
1547 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1551 if (LocaleCompare(
"watermark",option+1) == 0)
1553 (void) CloneString(&composite_options.compose_args,(
char *) NULL);
1557 if (i == (ssize_t) argc)
1558 ThrowCompositeException(OptionError,
"MissingArgument",option);
1559 if (IsGeometry(argv[i]) == MagickFalse)
1560 ThrowCompositeInvalidArgumentException(option,argv[i]);
1561 (void) CloneString(&composite_options.compose_args,argv[i]);
1562 composite_options.compose=ModulateCompositeOp;
1565 if (LocaleCompare(
"white-point",option+1) == 0)
1570 if (i == (ssize_t) argc)
1571 ThrowCompositeException(OptionError,
"MissingArgument",option);
1572 if (IsGeometry(argv[i]) == MagickFalse)
1573 ThrowCompositeInvalidArgumentException(option,argv[i]);
1576 if (LocaleCompare(
"write",option+1) == 0)
1579 if (i == (ssize_t) argc)
1580 ThrowCompositeException(OptionError,
"MissingArgument",option);
1583 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1588 ThrowCompositeException(OptionError,
"UnrecognizedOption",option)
1590 fire=(GetCommandOptionFlags(MagickCommandOptions,MagickFalse,option) &
1591 FireOptionFlag) == 0 ? MagickFalse : MagickTrue;
1592 if (fire != MagickFalse)
1593 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
1596 ThrowCompositeException(OptionError,
"UnbalancedParenthesis",argv[i]);
1597 if (i-- != (ssize_t) (argc-1))
1598 ThrowCompositeException(OptionError,
"MissingAnImageFilename",argv[i]);
1599 if ((image == (Image *) NULL) || (GetImageListLength(image) < 2))
1600 ThrowCompositeException(OptionError,
"MissingAnImageFilename",argv[argc-1]);
1601 FinalizeImageSettings(image_info,image,MagickTrue);
1602 if ((image == (Image *) NULL) || (GetImageListLength(image) < 2))
1603 ThrowCompositeException(OptionError,
"MissingAnImageFilename",argv[argc-1]);
1607 RemoveImageStack(composite_image);
1608 RemoveImageStack(images);
1609 (void) TransformImage(&composite_image,(
char *) NULL,
1610 composite_image->geometry);
1611 RemoveImageStack(mask_image);
1612 if (mask_image != (Image *) NULL)
1614 if ((composite_options.compose == DisplaceCompositeOp) ||
1615 (composite_options.compose == DistortCompositeOp))
1620 (void) CompositeImage(composite_image,CopyGreenCompositeOp,mask_image,
1622 mask_image=DestroyImage(mask_image);
1629 images->mask=mask_image;
1630 (void) NegateImage(images->mask,MagickFalse);
1633 status&=CompositeImageList(image_info,&images,composite_image,
1634 &composite_options,exception);
1635 composite_image=DestroyImage(composite_image);
1639 status&=WriteImages(image_info,images,argv[argc-1],exception);
1640 if (metadata != (
char **) NULL)
1645 text=InterpretImageProperties(image_info,images,format);
1646 InheritException(exception,&image->exception);
1647 if (text == (
char *) NULL)
1648 ThrowCompositeException(ResourceLimitError,
"MemoryAllocationFailed",
1649 GetExceptionMessage(errno));
1650 (void) ConcatenateString(&(*metadata),text);
1651 text=DestroyString(text);
1653 images=DestroyImageList(images);
1654 RelinquishCompositeOptions(&composite_options);
1656 return(status != 0 ? MagickTrue : MagickFalse);