45 #include "wand/studio.h"
46 #include "wand/MagickWand.h"
47 #include "wand/mogrify-private.h"
48 #include "magick/string-private.h"
84 static MagickBooleanType MontageUsage(
void)
88 " -debug events display copious debugging information\n"
89 " -help print program options\n"
90 " -list type print a list of supported option arguments\n"
91 " -log format format of debugging information\n"
92 " -version print version information",
94 " -adaptive-sharpen geometry\n"
95 " adaptively sharpen pixels; increase effect near edges\n"
96 " -annotate geometry text\n"
97 " annotate the image with text\n"
98 " -auto-orient automagically orient image\n"
99 " -blur geometry reduce image noise and reduce detail levels\n"
100 " -border geometry surround image with a border of color\n"
101 " -crop geometry preferred size and location of the cropped image\n"
102 " -extent geometry set the image size\n"
103 " -flatten flatten a sequence of images\n"
104 " -flip flip image in the vertical direction\n"
105 " -flop flop image in the horizontal direction\n"
106 " -frame geometry surround image with an ornamental border\n"
107 " -layers method optimize, merge, or compare image layers\n"
108 " -monochrome transform image to black and white\n"
109 " -polaroid angle simulate a Polaroid picture\n"
110 " -resize geometry resize the image\n"
111 " -rotate degrees apply Paeth rotation to the image\n"
112 " -scale geometry scale the image\n"
113 " -strip strip image of all profiles and comments\n"
114 " -transform affine transform image\n"
115 " -transpose flip image vertically and rotate 90 degrees\n"
116 " -transparent color make this color transparent within the image\n"
117 " -type type image type\n"
118 " -unsharp geometry sharpen the image",
120 " -adjoin join images into a single multi-image file\n"
121 " -affine matrix affine transform matrix\n"
122 " -alpha option on, activate, off, deactivate, set, opaque, copy\n"
123 " transparent, extract, background, or shape\n"
124 " -authenticate password\n"
125 " decipher image with this password\n"
126 " -blue-primary point chromaticity blue primary point\n"
127 " -bordercolor color border color\n"
128 " -caption string assign a caption to an image\n"
129 " -channel type apply option to select image channels\n"
130 " -colors value preferred number of colors in the image\n"
131 " -colorspace type alternate image colorsapce\n"
132 " -comment string annotate image with comment\n"
133 " -compose operator composite operator\n"
134 " -compress type type of pixel compression when writing the image\n"
135 " -define format:option\n"
136 " define one or more image format options\n"
137 " -delay value display the next image after pausing\n"
138 " -density geometry horizontal and vertical density of the image\n"
139 " -depth value image depth\n"
140 " -display server query font from this X server\n"
141 " -dispose method layer disposal method\n"
142 " -dither method apply error diffusion to image\n"
143 " -draw string annotate the image with a graphic primitive\n"
144 " -encoding type text encoding type\n"
145 " -endian type endianness (MSB or LSB) of the image\n"
146 " -extract geometry extract area from image\n"
147 " -fill color color to use when filling a graphic primitive\n"
148 " -filter type use this filter when resizing an image\n"
149 " -font name render text with this font\n"
150 " -format \"string\" output formatted image characteristics\n"
151 " -gamma value level of gamma correction\n"
152 " -geometry geometry preferred tile and border sizes\n"
153 " -gravity direction which direction to gravitate towards\n"
154 " -green-primary point chromaticity green primary point\n"
155 " -identify identify the format and characteristics of the image\n"
156 " -interlace type type of image interlacing scheme\n"
157 " -interpolate method pixel color interpolation method\n"
158 " -kerning value set the space between two letters\n"
159 " -label string assign a label to an image\n"
160 " -limit type value pixel cache resource limit\n"
161 " -matte store matte channel if the image has one\n"
162 " -mattecolor color frame color\n"
163 " -mode type framing style\n"
164 " -monitor monitor progress\n"
165 " -origin geometry image origin\n"
166 " -page geometry size and location of an image canvas (setting)\n"
167 " -pointsize value font point size\n"
168 " -profile filename add, delete, or apply an image profile\n"
169 " -quality value JPEG/MIFF/PNG compression level\n"
170 " -quantize colorspace reduce colors in this colorspace\n"
171 " -quiet suppress all warning messages\n"
172 " -red-primary point chromaticity red primary point\n"
173 " -regard-warnings pay attention to warning messages\n"
174 " -repage geometry size and location of an image canvas (operator)\n"
175 " -respect-parentheses settings remain in effect until parenthesis boundary\n"
176 " -sampling-factor geometry\n"
177 " horizontal and vertical sampling factor\n"
178 " -scenes range image scene range\n"
179 " -seed value seed a new sequence of pseudo-random numbers\n"
180 " -set attribute value set an image attribute\n"
181 " -shadow add a shadow beneath a tile to simulate depth\n"
182 " -size geometry width and height of image\n"
183 " -stroke color color to use when stroking a graphic primitive\n"
184 " -support factor resize support: > 1.0 is blurry, < 1.0 is sharp\n"
185 " -synchronize synchronize image to storage device\n"
186 " -taint declare the image as modified\n"
187 " -texture filename name of texture to tile onto the image background\n"
188 " -thumbnail geometry create a thumbnail of the image\n"
189 " -tile geometry number of tiles per row and column\n"
190 " -title string decorate the montage image with a title\n"
191 " -transparent-color color\n"
192 " transparent color\n"
193 " -treedepth value color tree depth\n"
194 " -trim trim image edges\n"
195 " -units type the units of image resolution\n"
196 " -verbose print detailed information about the image\n"
197 " -virtual-pixel method\n"
198 " virtual pixel access method\n"
199 " -white-point point chromaticity white point",
200 sequence_operators[] =
201 " -coalesce merge a sequence of images\n"
202 " -composite composite image",
204 " -clone indexes clone an image\n"
205 " -delete indexes delete the image from the image sequence\n"
206 " -duplicate count,indexes\n"
207 " duplicate an image one or more times\n"
208 " -insert index insert last image into the image sequence\n"
209 " -reverse reverse image sequence\n"
210 " -swap indexes swap two images in the image sequence";
212 ListMagickVersion(stdout);
213 (void) printf(
"Usage: %s [options ...] file [ [options ...] file ...] file\n",
215 (void) printf(
"\nImage Settings:\n");
216 (void) puts(settings);
217 (void) printf(
"\nImage Operators:\n");
218 (void) puts(operators);
219 (void) printf(
"\nImage Sequence Operators:\n");
220 (void) puts(sequence_operators);
221 (void) printf(
"\nImage Stack Operators:\n");
222 (void) puts(stack_operators);
223 (void) printf(
"\nMiscellaneous Options:\n");
224 (void) puts(miscellaneous);
226 "\nIn addition to those listed above, you can specify these standard X\n");
228 "resources as command line options: -background, -bordercolor,\n");
230 "-borderwidth, -font, -mattecolor, or -title\n");
232 "\nBy default, the image format of `file' is determined by its magic\n");
234 "number. To specify a particular image format, precede the filename\n");
236 "with an image format name and a colon (i.e. ps:image) or specify the\n");
238 "image type as the filename suffix (i.e. image.ps). Specify 'file' as\n");
239 (void) printf(
"'-' for standard input or output.\n");
243 WandExport MagickBooleanType MontageImageCommand(ImageInfo *image_info,
244 int argc,
char **argv,
char **metadata,ExceptionInfo *exception)
246 #define DestroyMontage() \
248 if (montage_info != (MontageInfo *) NULL) \
249 montage_info=DestroyMontageInfo(montage_info); \
250 if (montage_info != (MontageInfo *) NULL) \
251 montage_info=DestroyMontageInfo(montage_info); \
252 if (montage_image != (Image *) NULL) \
253 montage_image=DestroyImageList(montage_image); \
254 DestroyImageStack(); \
255 for (i=0; i < (ssize_t) argc; i++) \
256 argv[i]=DestroyString(argv[i]); \
257 argv=(char **) RelinquishMagickMemory(argv); \
259 #define ThrowMontageException(asperity,tag,option) \
261 (void) ThrowMagickException(exception,GetMagickModule(),asperity,tag,"`%s'", \
264 return(MagickFalse); \
266 #define ThrowMontageInvalidArgumentException(option,argument) \
268 (void) ThrowMagickException(exception,GetMagickModule(),OptionError, \
269 "InvalidArgument","`%s': %s",option,argument); \
271 return(MagickFalse); \
286 image_stack[MaxImageStackDepth+1];
314 assert(image_info != (ImageInfo *) NULL);
315 assert(image_info->signature == MagickCoreSignature);
316 assert(exception != (ExceptionInfo *) NULL);
317 if (IsEventLogging() != MagickFalse)
318 (void) LogMagickEvent(TraceEvent,GetMagickModule(),
"...");
322 if ((LocaleCompare(
"version",option+1) == 0) ||
323 (LocaleCompare(
"-version",option+1) == 0))
325 ListMagickVersion(stdout);
330 return(MontageUsage());
336 montage_image=NewImageList();
337 montage_info=CloneMontageInfo(image_info,(MontageInfo *) NULL);
339 option=(
char *) NULL;
341 respect_parenthesis=MagickFalse;
344 transparent_color=(
char *) NULL;
348 ReadCommandlLine(argc,&argv);
349 status=ExpandFilenames(&argc,&argv);
350 if (status == MagickFalse)
351 ThrowMontageException(ResourceLimitError,
"MemoryAllocationFailed",
352 GetExceptionMessage(errno));
353 for (i=1; i < (ssize_t) (argc-1); i++)
356 if (LocaleCompare(option,
"(") == 0)
358 FireImageStack(MagickTrue,MagickTrue,pend);
359 if (k == MaxImageStackDepth)
360 ThrowMontageException(OptionError,
"ParenthesisNestedTooDeeply",
365 if (LocaleCompare(option,
")") == 0)
367 FireImageStack(MagickTrue,MagickTrue,MagickTrue);
369 ThrowMontageException(OptionError,
"UnableToParseExpression",option);
373 if (IsCommandOption(option) == MagickFalse)
378 FireImageStack(MagickFalse,MagickFalse,pend);
379 for (scene=(ssize_t) first_scene; scene <= (ssize_t) last_scene ; scene++)
388 if ((LocaleCompare(filename,
"--") == 0) && (i < (ssize_t) (argc-1)))
390 (void) SetImageOption(image_info,
"filename",filename);
391 (void) CopyMagickString(image_info->filename,filename,MaxTextExtent);
392 if (first_scene != last_scene)
395 filename[MaxTextExtent];
400 (void) InterpretImageFilename(image_info,(Image *) NULL,
401 image_info->filename,(int) scene,filename);
402 if (LocaleCompare(filename,image_info->filename) == 0)
403 (
void) FormatLocaleString(filename,MaxTextExtent,
"%s.%.20g",
404 image_info->filename,(
double) scene);
405 (void) CopyMagickString(image_info->filename,filename,
408 (void) CloneString(&image_info->font,montage_info->font);
409 images=ReadImages(image_info,exception);
410 status&=(images != (Image *) NULL) &&
411 (exception->severity < ErrorException);
412 if (images == (Image *) NULL)
414 AppendImageStack(images);
418 pend=image != (Image *) NULL ? MagickTrue : MagickFalse;
423 if (LocaleCompare(
"adaptive-sharpen",option+1) == 0)
426 if (i == (ssize_t) argc)
427 ThrowMontageException(OptionError,
"MissingArgument",option);
428 if (IsGeometry(argv[i]) == MagickFalse)
429 ThrowMontageInvalidArgumentException(option,argv[i]);
432 if (LocaleCompare(
"adjoin",option+1) == 0)
434 if (LocaleCompare(
"affine",option+1) == 0)
439 if (i == (ssize_t) argc)
440 ThrowMontageException(OptionError,
"MissingArgument",option);
441 if (IsGeometry(argv[i]) == MagickFalse)
442 ThrowMontageInvalidArgumentException(option,argv[i]);
445 if (LocaleCompare(
"alpha",option+1) == 0)
453 if (i == (ssize_t) argc)
454 ThrowMontageException(OptionError,
"MissingArgument",option);
455 type=ParseCommandOption(MagickAlphaOptions,MagickFalse,argv[i]);
457 ThrowMontageException(OptionError,
"UnrecognizedAlphaChannelType",
461 if (LocaleCompare(
"annotate",option+1) == 0)
466 if (i == (ssize_t) argc)
467 ThrowMontageException(OptionError,
"MissingArgument",option);
468 if (IsGeometry(argv[i]) == MagickFalse)
469 ThrowMontageInvalidArgumentException(option,argv[i]);
470 if (i == (ssize_t) argc)
471 ThrowMontageException(OptionError,
"MissingArgument",option);
475 if (LocaleCompare(
"auto-orient",option+1) == 0)
477 if (LocaleCompare(
"authenticate",option+1) == 0)
482 if (i == (ssize_t) argc)
483 ThrowMontageException(OptionError,
"MissingArgument",option);
486 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
490 if (LocaleCompare(
"background",option+1) == 0)
495 if (i == (ssize_t) argc)
496 ThrowMontageException(OptionError,
"MissingArgument",option);
497 (void) QueryColorDatabase(argv[i],
498 &montage_info->background_color,exception);
501 if (LocaleCompare(
"blue-primary",option+1) == 0)
506 if (i == (ssize_t) argc)
507 ThrowMontageException(OptionError,
"MissingArgument",option);
508 if (IsGeometry(argv[i]) == MagickFalse)
509 ThrowMontageInvalidArgumentException(option,argv[i]);
512 if (LocaleCompare(
"blur",option+1) == 0)
517 if (i == (ssize_t) argc)
518 ThrowMontageException(OptionError,
"MissingArgument",option);
519 if (IsGeometry(argv[i]) == MagickFalse)
520 ThrowMontageInvalidArgumentException(option,argv[i]);
523 if (LocaleCompare(
"border",option+1) == 0)
527 (void) CopyMagickString(argv[i]+1,
"sans",MaxTextExtent);
528 montage_info->border_width=0;
533 if (i == (ssize_t) argc)
534 ThrowMontageException(OptionError,
"MissingArgument",option);
535 if (IsGeometry(argv[i]) == MagickFalse)
536 ThrowMontageInvalidArgumentException(option,argv[i]);
538 montage_info->border_width=StringToUnsignedLong(argv[i]);
541 if (LocaleCompare(
"bordercolor",option+1) == 0)
546 if (i == (ssize_t) argc)
547 ThrowMontageException(OptionError,
"MissingArgument",option);
548 (void) QueryColorDatabase(argv[i],&montage_info->border_color,
552 if (LocaleCompare(
"borderwidth",option+1) == 0)
554 montage_info->border_width=0;
558 if (i == (ssize_t) argc)
559 ThrowMontageException(OptionError,
"MissingArgument",option);
560 if (IsGeometry(argv[i]) == MagickFalse)
561 ThrowMontageInvalidArgumentException(option,argv[i]);
562 montage_info->border_width=StringToUnsignedLong(argv[i]);
565 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
569 if (LocaleCompare(
"cache",option+1) == 0)
574 if (i == (ssize_t) argc)
575 ThrowMontageException(OptionError,
"MissingArgument",option);
576 if (IsGeometry(argv[i]) == MagickFalse)
577 ThrowMontageInvalidArgumentException(option,argv[i]);
580 if (LocaleCompare(
"caption",option+1) == 0)
585 if (i == (ssize_t) argc)
586 ThrowMontageException(OptionError,
"MissingArgument",option);
589 if (LocaleCompare(
"channel",option+1) == 0)
597 if (i == (ssize_t) argc)
598 ThrowMontageException(OptionError,
"MissingArgument",option);
599 channel=ParseChannelOption(argv[i]);
601 ThrowMontageException(OptionError,
"UnrecognizedChannelType",
605 if (LocaleCompare(
"clone",option+1) == 0)
612 clone_list=CloneImageList(image,exception);
614 clone_list=CloneImageList(image_stack[k-1].image,exception);
615 if (clone_list == (Image *) NULL)
616 ThrowMontageException(ImageError,
"ImageSequenceRequired",option);
617 FireImageStack(MagickTrue,MagickTrue,MagickTrue);
619 clone_images=CloneImages(clone_list,
"-1",exception);
623 if (i == (ssize_t) argc)
624 ThrowMontageException(OptionError,
"MissingArgument",option);
625 if (IsSceneGeometry(argv[i],MagickFalse) == MagickFalse)
626 ThrowMontageInvalidArgumentException(option,argv[i]);
627 clone_images=CloneImages(clone_list,argv[i],exception);
629 if (clone_images == (Image *) NULL)
630 ThrowMontageException(OptionError,
"NoSuchImage",option);
631 AppendImageStack(clone_images);
632 clone_list=DestroyImageList(clone_list);
635 if (LocaleCompare(
"coalesce",option+1) == 0)
637 if (LocaleCompare(
"colors",option+1) == 0)
642 if (i == (ssize_t) argc)
643 ThrowMontageException(OptionError,
"MissingArgument",option);
644 if (IsGeometry(argv[i]) == MagickFalse)
645 ThrowMontageInvalidArgumentException(option,argv[i]);
648 if (LocaleCompare(
"colorspace",option+1) == 0)
656 if (i == (ssize_t) argc)
657 ThrowMontageException(OptionError,
"MissingArgument",option);
658 colorspace=ParseCommandOption(MagickColorspaceOptions,
659 MagickFalse,argv[i]);
661 ThrowMontageException(OptionError,
"UnrecognizedColorspace",
665 if (LocaleCompare(
"comment",option+1) == 0)
670 if (i == (ssize_t) argc)
671 ThrowMontageException(OptionError,
"MissingArgument",option);
674 if (LocaleCompare(
"compose",option+1) == 0)
682 if (i == (ssize_t) argc)
683 ThrowMontageException(OptionError,
"MissingArgument",option);
684 compose=ParseCommandOption(MagickComposeOptions,MagickFalse,argv[i]);
686 ThrowMontageException(OptionError,
"UnrecognizedComposeOperator",
690 if (LocaleCompare(
"composite",option+1) == 0)
692 if (LocaleCompare(
"compress",option+1) == 0)
700 if (i == (ssize_t) argc)
701 ThrowMontageException(OptionError,
"MissingArgument",option);
702 compress=ParseCommandOption(MagickCompressOptions,MagickFalse,
705 ThrowMontageException(OptionError,
"UnrecognizedCompressType",
709 if (LocaleCompare(
"concurrent",option+1) == 0)
711 if (LocaleCompare(
"crop",option+1) == 0)
716 if (i == (ssize_t) argc)
717 ThrowMontageException(OptionError,
"MissingArgument",option);
718 if (IsGeometry(argv[i]) == MagickFalse)
719 ThrowMontageInvalidArgumentException(option,argv[i]);
722 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
726 if (LocaleCompare(
"debug",option+1) == 0)
734 if (i == (ssize_t) argc)
735 ThrowMontageException(OptionError,
"MissingArgument",option);
736 event=ParseCommandOption(MagickLogEventOptions,MagickFalse,argv[i]);
738 ThrowMontageException(OptionError,
"UnrecognizedEventType",
740 (void) SetLogEventMask(argv[i]);
743 if (LocaleCompare(
"define",option+1) == 0)
746 if (i == (ssize_t) argc)
747 ThrowMontageException(OptionError,
"MissingArgument",option);
753 define=GetImageOption(image_info,argv[i]);
754 if (define == (
const char *) NULL)
755 ThrowMontageException(OptionError,
"NoSuchOption",argv[i]);
760 if (LocaleCompare(
"delete",option+1) == 0)
765 if (i == (ssize_t) argc)
766 ThrowMontageException(OptionError,
"MissingArgument",option);
767 if (IsSceneGeometry(argv[i],MagickFalse) == MagickFalse)
768 ThrowMontageInvalidArgumentException(option,argv[i]);
771 if (LocaleCompare(
"delay",option+1) == 0)
776 if (i == (ssize_t) argc)
777 ThrowMontageException(OptionError,
"MissingArgument",option);
778 if (IsGeometry(argv[i]) == MagickFalse)
779 ThrowMontageInvalidArgumentException(option,argv[i]);
782 if (LocaleCompare(
"density",option+1) == 0)
787 if (i == (ssize_t) argc)
788 ThrowMontageException(OptionError,
"MissingArgument",option);
789 if (IsGeometry(argv[i]) == MagickFalse)
790 ThrowMontageInvalidArgumentException(option,argv[i]);
793 if (LocaleCompare(
"depth",option+1) == 0)
798 if (i == (ssize_t) argc)
799 ThrowMontageException(OptionError,
"MissingArgument",option);
800 if (IsGeometry(argv[i]) == MagickFalse)
801 ThrowMontageInvalidArgumentException(option,argv[i]);
804 if (LocaleCompare(
"display",option+1) == 0)
809 if (i == (ssize_t) argc)
810 ThrowMontageException(OptionError,
"MissingArgument",option);
813 if (LocaleCompare(
"dispose",option+1) == 0)
821 if (i == (ssize_t) argc)
822 ThrowMontageException(OptionError,
"MissingArgument",option);
823 dispose=ParseCommandOption(MagickDisposeOptions,MagickFalse,argv[i]);
825 ThrowMontageException(OptionError,
"UnrecognizedDisposeMethod",
829 if (LocaleCompare(
"dither",option+1) == 0)
837 if (i == (ssize_t) argc)
838 ThrowMontageException(OptionError,
"MissingArgument",option);
839 method=ParseCommandOption(MagickDitherOptions,MagickFalse,argv[i]);
841 ThrowMontageException(OptionError,
"UnrecognizedDitherMethod",
845 if (LocaleCompare(
"draw",option+1) == 0)
850 if (i == (ssize_t) argc)
851 ThrowMontageException(OptionError,
"MissingArgument",option);
854 if (LocaleCompare(
"duplicate",option+1) == 0)
859 if (i == (ssize_t) argc)
860 ThrowMontageException(OptionError,
"MissingArgument",option);
861 if (IsGeometry(argv[i]) == MagickFalse)
862 ThrowMontageInvalidArgumentException(option,argv[i]);
865 if (LocaleCompare(
"duration",option+1) == 0)
870 if (i == (ssize_t) argc)
871 ThrowMontageException(OptionError,
"MissingArgument",option);
872 if (IsGeometry(argv[i]) == MagickFalse)
873 ThrowMontageInvalidArgumentException(option,argv[i]);
876 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
880 if (LocaleCompare(
"encoding",option+1) == 0)
885 if (i == (ssize_t) argc)
886 ThrowMontageException(OptionError,
"MissingArgument",option);
889 if (LocaleCompare(
"endian",option+1) == 0)
897 if (i == (ssize_t) argc)
898 ThrowMontageException(OptionError,
"MissingArgument",option);
899 endian=ParseCommandOption(MagickEndianOptions,MagickFalse,
902 ThrowMontageException(OptionError,
"UnrecognizedEndianType",
906 if (LocaleCompare(
"extent",option+1) == 0)
911 if (i == (ssize_t) argc)
912 ThrowMontageException(OptionError,
"MissingArgument",option);
913 if (IsGeometry(argv[i]) == MagickFalse)
914 ThrowMontageInvalidArgumentException(option,argv[i]);
917 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
921 if (LocaleCompare(
"fill",option+1) == 0)
923 (void) QueryColorDatabase(
"none",&montage_info->fill,exception);
927 if (i == (ssize_t) argc)
928 ThrowMontageException(OptionError,
"MissingArgument",option);
929 (void) QueryColorDatabase(argv[i],&montage_info->fill,
933 if (LocaleCompare(
"filter",option+1) == 0)
941 if (i == (ssize_t) argc)
942 ThrowMontageException(OptionError,
"MissingArgument",option);
943 filter=ParseCommandOption(MagickFilterOptions,MagickFalse,argv[i]);
945 ThrowMontageException(OptionError,
"UnrecognizedImageFilter",
949 if (LocaleCompare(
"flatten",option+1) == 0)
951 if (LocaleCompare(
"flip",option+1) == 0)
953 if (LocaleCompare(
"flop",option+1) == 0)
955 if (LocaleCompare(
"font",option+1) == 0)
960 if (i == (ssize_t) argc)
961 ThrowMontageException(OptionError,
"MissingArgument",option);
962 (void) CloneString(&montage_info->font,argv[i]);
965 if (LocaleCompare(
"format",option+1) == 0)
970 if (i == (ssize_t) argc)
971 ThrowMontageException(OptionError,
"MissingArgument",option);
975 if (LocaleCompare(
"frame",option+1) == 0)
979 (void) CopyMagickString(argv[i]+1,
"sans",MaxTextExtent);
980 (void) CloneString(&montage_info->frame,(
char *) NULL);
985 if (i == (ssize_t) argc)
986 ThrowMontageException(OptionError,
"MissingArgument",option);
987 if (IsGeometry(argv[i]) == MagickFalse)
988 ThrowMontageInvalidArgumentException(option,argv[i]);
990 (void) CloneString(&montage_info->frame,argv[i]);
993 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
997 if (LocaleCompare(
"gamma",option+1) == 0)
1000 if (i == (ssize_t) argc)
1001 ThrowMontageException(OptionError,
"MissingArgument",option);
1002 if (IsGeometry(argv[i]) == MagickFalse)
1003 ThrowMontageInvalidArgumentException(option,argv[i]);
1006 if (LocaleCompare(
"geometry",option+1) == 0)
1008 (void) CloneString(&montage_info->geometry,(
char *) NULL);
1012 if (i == (ssize_t) argc)
1013 ThrowMontageException(OptionError,
"MissingArgument",option);
1014 if (IsGeometry(argv[i]) == MagickFalse)
1015 ThrowMontageInvalidArgumentException(option,argv[i]);
1016 (void) CloneString(&montage_info->geometry,argv[i]);
1019 if (LocaleCompare(
"gravity",option+1) == 0)
1024 montage_info->gravity=UndefinedGravity;
1028 if (i == (ssize_t) argc)
1029 ThrowMontageException(OptionError,
"MissingArgument",option);
1030 gravity=ParseCommandOption(MagickGravityOptions,MagickFalse,
1033 ThrowMontageException(OptionError,
"UnrecognizedGravityType",
1035 montage_info->gravity=(GravityType) gravity;
1038 if (LocaleCompare(
"green-primary",option+1) == 0)
1043 if (i == (ssize_t) argc)
1044 ThrowMontageException(OptionError,
"MissingArgument",option);
1045 if (IsGeometry(argv[i]) == MagickFalse)
1046 ThrowMontageInvalidArgumentException(option,argv[i]);
1049 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1053 if ((LocaleCompare(
"help",option+1) == 0) ||
1054 (LocaleCompare(
"-help",option+1) == 0))
1057 return(MontageUsage());
1059 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1063 if (LocaleCompare(
"identify",option+1) == 0)
1065 if (LocaleCompare(
"insert",option+1) == 0)
1070 if (i == (ssize_t) argc)
1071 ThrowMontageException(OptionError,
"MissingArgument",option);
1072 if (IsGeometry(argv[i]) == MagickFalse)
1073 ThrowMontageInvalidArgumentException(option,argv[i]);
1076 if (LocaleCompare(
"interlace",option+1) == 0)
1084 if (i == (ssize_t) argc)
1085 ThrowMontageException(OptionError,
"MissingArgument",option);
1086 interlace=ParseCommandOption(MagickInterlaceOptions,MagickFalse,
1089 ThrowMontageException(OptionError,
"UnrecognizedInterlaceType",
1093 if (LocaleCompare(
"interpolate",option+1) == 0)
1101 if (i == (ssize_t) argc)
1102 ThrowMontageException(OptionError,
"MissingArgument",option);
1103 interpolate=ParseCommandOption(MagickInterpolateOptions,MagickFalse,
1105 if (interpolate < 0)
1106 ThrowMontageException(OptionError,
"UnrecognizedInterpolateMethod",
1110 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1114 if (LocaleCompare(
"kerning",option+1) == 0)
1119 if (i == (ssize_t) argc)
1120 ThrowMontageException(OptionError,
"MissingArgument",option);
1121 if (IsGeometry(argv[i]) == MagickFalse)
1122 ThrowMontageInvalidArgumentException(option,argv[i]);
1125 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1129 if (LocaleCompare(
"label",option+1) == 0)
1134 if (i == (ssize_t) argc)
1135 ThrowMontageException(OptionError,
"MissingArgument",option);
1138 if (LocaleCompare(
"layers",option+1) == 0)
1146 if (i == (ssize_t) argc)
1147 ThrowMontageException(OptionError,
"MissingArgument",option);
1148 type=ParseCommandOption(MagickLayerOptions,MagickFalse,argv[i]);
1150 ThrowMontageException(OptionError,
"UnrecognizedLayerMethod",
1154 if (LocaleCompare(
"limit",option+1) == 0)
1168 if (i == (ssize_t) argc)
1169 ThrowMontageException(OptionError,
"MissingArgument",option);
1170 resource=ParseCommandOption(MagickResourceOptions,MagickFalse,
1173 ThrowMontageException(OptionError,
"UnrecognizedResourceType",
1176 if (i == (ssize_t) argc)
1177 ThrowMontageException(OptionError,
"MissingArgument",option);
1178 value=StringToDouble(argv[i],&p);
1180 if ((p == argv[i]) && (LocaleCompare(
"unlimited",argv[i]) != 0))
1181 ThrowMontageInvalidArgumentException(option,argv[i]);
1184 if (LocaleCompare(
"list",option+1) == 0)
1192 if (i == (ssize_t) argc)
1193 ThrowMontageException(OptionError,
"MissingArgument",option);
1194 list=ParseCommandOption(MagickListOptions,MagickFalse,argv[i]);
1196 ThrowMontageException(OptionError,
"UnrecognizedListType",argv[i]);
1197 status=MogrifyImageInfo(image_info,(
int) (i-j+1),(
const char **)
1200 return(status == 0 ? MagickFalse : MagickTrue);
1202 if (LocaleCompare(
"log",option+1) == 0)
1207 if ((i == (ssize_t) argc) ||
1208 (strchr(argv[i],
'%') == (
char *) NULL))
1209 ThrowMontageException(OptionError,
"MissingArgument",option);
1212 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1216 if (LocaleCompare(
"matte",option+1) == 0)
1218 if (LocaleCompare(
"mattecolor",option+1) == 0)
1223 if (i == (ssize_t) argc)
1224 ThrowMontageException(OptionError,
"MissingArgument",option);
1225 (void) QueryColorDatabase(argv[i],&montage_info->matte_color,
1229 if (LocaleCompare(
"mode",option+1) == 0)
1234 (void) CopyMagickString(argv[i]+1,
"sans",MaxTextExtent);
1238 if (i == (ssize_t) argc)
1239 ThrowMontageException(OptionError,
"MissingArgument",option);
1241 if (LocaleCompare(
"frame",argv[i]) == 0)
1244 (void) CloneString(&montage_info->frame,
"15x15+3+3");
1245 montage_info->shadow=MagickTrue;
1248 if (LocaleCompare(
"unframe",argv[i]) == 0)
1251 montage_info->frame=(
char *) NULL;
1252 montage_info->shadow=MagickFalse;
1253 montage_info->border_width=0;
1256 if (LocaleCompare(
"concatenate",argv[i]) == 0)
1258 mode=ConcatenateMode;
1259 montage_info->frame=(
char *) NULL;
1260 montage_info->shadow=MagickFalse;
1261 montage_info->gravity=(GravityType) NorthWestGravity;
1262 (void) CloneString(&montage_info->geometry,
"+0+0");
1263 montage_info->border_width=0;
1266 if (mode == UndefinedMode)
1267 ThrowMontageException(OptionError,
"UnrecognizedImageMode",
1271 if (LocaleCompare(
"monitor",option+1) == 0)
1273 if (LocaleCompare(
"monochrome",option+1) == 0)
1275 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1279 if (LocaleCompare(
"noop",option+1) == 0)
1281 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1285 if (LocaleCompare(
"origin",option+1) == 0)
1290 if (i == (ssize_t) argc)
1291 ThrowMontageException(OptionError,
"MissingArgument",option);
1292 if (IsGeometry(argv[i]) == MagickFalse)
1293 ThrowMontageInvalidArgumentException(option,argv[i]);
1296 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1300 if (LocaleCompare(
"page",option+1) == 0)
1305 if (i == (ssize_t) argc)
1306 ThrowMontageException(OptionError,
"MissingArgument",option);
1309 if (LocaleCompare(
"pointsize",option+1) == 0)
1311 montage_info->pointsize=12;
1315 if (i == (ssize_t) argc)
1316 ThrowMontageException(OptionError,
"MissingArgument",option);
1317 if (IsGeometry(argv[i]) == MagickFalse)
1318 ThrowMontageInvalidArgumentException(option,argv[i]);
1319 montage_info->pointsize=StringToDouble(argv[i],(
char **) NULL);
1322 if (LocaleCompare(
"polaroid",option+1) == 0)
1327 if (i == (ssize_t) argc)
1328 ThrowMontageException(OptionError,
"MissingArgument",option);
1329 if (IsGeometry(argv[i]) == MagickFalse)
1330 ThrowMontageInvalidArgumentException(option,argv[i]);
1333 if (LocaleCompare(
"profile",option+1) == 0)
1336 if (i == (ssize_t) argc)
1337 ThrowMontageException(OptionError,
"MissingArgument",option);
1340 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1344 if (LocaleCompare(
"quality",option+1) == 0)
1349 if (i == (ssize_t) argc)
1350 ThrowMontageException(OptionError,
"MissingArgument",option);
1351 if (IsGeometry(argv[i]) == MagickFalse)
1352 ThrowMontageInvalidArgumentException(option,argv[i]);
1355 if (LocaleCompare(
"quantize",option+1) == 0)
1363 if (i == (ssize_t) argc)
1364 ThrowMontageException(OptionError,
"MissingArgument",option);
1365 colorspace=ParseCommandOption(MagickColorspaceOptions,
1366 MagickFalse,argv[i]);
1368 ThrowMontageException(OptionError,
"UnrecognizedColorspace",
1372 if (LocaleCompare(
"quiet",option+1) == 0)
1374 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1378 if (LocaleCompare(
"red-primary",option+1) == 0)
1383 if (i == (ssize_t) argc)
1384 ThrowMontageException(OptionError,
"MissingArgument",option);
1385 if (IsGeometry(argv[i]) == MagickFalse)
1386 ThrowMontageInvalidArgumentException(option,argv[i]);
1389 if (LocaleCompare(
"regard-warnings",option+1) == 0)
1391 if (LocaleCompare(
"render",option+1) == 0)
1393 if (LocaleCompare(
"repage",option+1) == 0)
1398 if (i == (ssize_t) argc)
1399 ThrowMontageException(OptionError,
"MissingArgument",option);
1400 if (IsGeometry(argv[i]) == MagickFalse)
1401 ThrowMontageInvalidArgumentException(option,argv[i]);
1404 if (LocaleCompare(
"resize",option+1) == 0)
1409 if (i == (ssize_t) argc)
1410 ThrowMontageException(OptionError,
"MissingArgument",option);
1411 if (IsGeometry(argv[i]) == MagickFalse)
1412 ThrowMontageInvalidArgumentException(option,argv[i]);
1415 if (LocaleNCompare(
"respect-parentheses",option+1,17) == 0)
1417 respect_parenthesis=(*option ==
'-') ? MagickTrue : MagickFalse;
1420 if (LocaleCompare(
"reverse",option+1) == 0)
1422 if (LocaleCompare(
"rotate",option+1) == 0)
1425 if (i == (ssize_t) argc)
1426 ThrowMontageException(OptionError,
"MissingArgument",option);
1427 if (IsGeometry(argv[i]) == MagickFalse)
1428 ThrowMontageInvalidArgumentException(option,argv[i]);
1431 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1435 if (LocaleCompare(
"sampling-factor",option+1) == 0)
1440 if (i == (ssize_t) argc)
1441 ThrowMontageException(OptionError,
"MissingArgument",option);
1442 if (IsGeometry(argv[i]) == MagickFalse)
1443 ThrowMontageInvalidArgumentException(option,argv[i]);
1446 if (LocaleCompare(
"scale",option+1) == 0)
1451 if (i == (ssize_t) argc)
1452 ThrowMontageException(OptionError,
"MissingArgument",option);
1453 if (IsGeometry(argv[i]) == MagickFalse)
1454 ThrowMontageInvalidArgumentException(option,argv[i]);
1457 if (LocaleCompare(
"scenes",option+1) == 0)
1464 if (i == (ssize_t) argc)
1465 ThrowMontageException(OptionError,
"MissingArgument",option);
1466 if (IsSceneGeometry(argv[i],MagickFalse) == MagickFalse)
1467 ThrowMontageInvalidArgumentException(option,argv[i]);
1468 first_scene=(int) StringToLong(argv[i]);
1469 last_scene=first_scene;
1470 (void) sscanf(argv[i],
"%ld-%ld",&first_scene,&last_scene);
1473 if (LocaleCompare(
"seed",option+1) == 0)
1478 if (i == (ssize_t) argc)
1479 ThrowMontageException(OptionError,
"MissingArgument",option);
1480 if (IsGeometry(argv[i]) == MagickFalse)
1481 ThrowMontageInvalidArgumentException(option,argv[i]);
1484 if (LocaleCompare(
"set",option+1) == 0)
1487 if (i == (ssize_t) argc)
1488 ThrowMontageException(OptionError,
"MissingArgument",option);
1492 if (i == (ssize_t) argc)
1493 ThrowMontageException(OptionError,
"MissingArgument",option);
1496 if (LocaleCompare(
"shadow",option+1) == 0)
1500 (void) CopyMagickString(argv[i]+1,
"sans",MaxTextExtent);
1501 montage_info->shadow=(*option ==
'-') ? MagickTrue :
1508 if (i == (ssize_t) argc)
1509 ThrowMontageException(OptionError,
"MissingArgument",option);
1510 if (IsGeometry(argv[i]) == MagickFalse)
1511 ThrowMontageInvalidArgumentException(option,argv[i]);
1514 if (LocaleCompare(
"sharpen",option+1) == 0)
1519 if ((i == (ssize_t) argc) || (IsGeometry(argv[i]) == MagickFalse))
1520 ThrowMontageException(OptionError,
"MissingArgument",option);
1523 if (LocaleCompare(
"size",option+1) == 0)
1528 if (i == (ssize_t) argc)
1529 ThrowMontageException(OptionError,
"MissingArgument",option);
1530 if (IsGeometry(argv[i]) == MagickFalse)
1531 ThrowMontageInvalidArgumentException(option,argv[i]);
1534 if (LocaleCompare(
"stroke",option+1) == 0)
1536 (void) QueryColorDatabase(
"none",&montage_info->stroke,exception);
1540 if (i == (ssize_t) argc)
1541 ThrowMontageException(OptionError,
"MissingArgument",option);
1542 (void) QueryColorDatabase(argv[i],&montage_info->stroke,
1546 if (LocaleCompare(
"strip",option+1) == 0)
1548 if (LocaleCompare(
"strokewidth",option+1) == 0)
1553 if (i == (ssize_t) argc)
1554 ThrowMontageException(OptionError,
"MissingArgument",option);
1555 if (IsGeometry(argv[i]) == MagickFalse)
1556 ThrowMontageInvalidArgumentException(option,argv[i]);
1559 if (LocaleCompare(
"support",option+1) == 0)
1564 if (LocaleCompare(
"swap",option+1) == 0)
1569 if (i == (ssize_t) argc)
1570 ThrowMontageException(OptionError,
"MissingArgument",option);
1571 if (IsGeometry(argv[i]) == MagickFalse)
1572 ThrowMontageInvalidArgumentException(option,argv[i]);
1575 if (LocaleCompare(
"synchronize",option+1) == 0)
1577 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1581 if (LocaleCompare(
"taint",option+1) == 0)
1583 if (LocaleCompare(
"texture",option+1) == 0)
1585 (void) CloneString(&montage_info->texture,(
char *) NULL);
1589 if (i == (ssize_t) argc)
1590 ThrowMontageException(OptionError,
"MissingArgument",option);
1591 (void) CloneString(&montage_info->texture,argv[i]);
1594 if (LocaleCompare(
"thumbnail",option+1) == 0)
1599 if (i == (ssize_t) argc)
1600 ThrowMontageException(OptionError,
"MissingArgument",option);
1601 if (IsGeometry(argv[i]) == MagickFalse)
1602 ThrowMontageInvalidArgumentException(option,argv[i]);
1605 if (LocaleCompare(
"tile",option+1) == 0)
1609 (void) CopyMagickString(argv[i]+1,
"sans",MaxTextExtent);
1610 (void) CloneString(&montage_info->tile,(
char *) NULL);
1615 if (i == (ssize_t) argc)
1616 ThrowMontageException(OptionError,
"MissingArgument",option);
1617 if (IsGeometry(argv[i]) == MagickFalse)
1618 ThrowMontageInvalidArgumentException(option,argv[i]);
1620 (void) CloneString(&montage_info->tile,argv[i]);
1623 if (LocaleCompare(
"tile-offset",option+1) == 0)
1628 if (i == (ssize_t) argc)
1629 ThrowMontageException(OptionError,
"MissingArgument",option);
1630 if (IsGeometry(argv[i]) == MagickFalse)
1631 ThrowMontageInvalidArgumentException(option,argv[i]);
1634 if (LocaleCompare(
"tint",option+1) == 0)
1639 if (i == (ssize_t) argc)
1640 ThrowMontageException(OptionError,
"MissingArgument",option);
1641 if (IsGeometry(argv[i]) == MagickFalse)
1642 ThrowMontageInvalidArgumentException(option,argv[i]);
1645 if (LocaleCompare(
"transform",option+1) == 0)
1647 if (LocaleCompare(
"transpose",option+1) == 0)
1649 if (LocaleCompare(
"title",option+1) == 0)
1651 (void) CloneString(&montage_info->title,(
char *) NULL);
1655 if (i == (ssize_t) argc)
1656 ThrowMontageException(OptionError,
"MissingArgument",option);
1657 (void) CloneString(&montage_info->title,argv[i]);
1660 if (LocaleCompare(
"transform",option+1) == 0)
1662 if (LocaleCompare(
"transparent",option+1) == 0)
1664 transparent_color=(
char *) NULL;
1666 if (i == (ssize_t) argc)
1667 ThrowMontageException(OptionError,
"MissingArgument",option);
1668 (void) CloneString(&transparent_color,argv[i]);
1671 if (LocaleCompare(
"transparent-color",option+1) == 0)
1676 if (i == (ssize_t) argc)
1677 ThrowMontageException(OptionError,
"MissingArgument",option);
1680 if (LocaleCompare(
"treedepth",option+1) == 0)
1685 if (i == (ssize_t) argc)
1686 ThrowMontageException(OptionError,
"MissingArgument",option);
1687 if (IsGeometry(argv[i]) == MagickFalse)
1688 ThrowMontageInvalidArgumentException(option,argv[i]);
1691 if (LocaleCompare(
"trim",option+1) == 0)
1693 if (LocaleCompare(
"type",option+1) == 0)
1701 if (i == (ssize_t) argc)
1702 ThrowMontageException(OptionError,
"MissingArgument",option);
1703 type=ParseCommandOption(MagickTypeOptions,MagickFalse,argv[i]);
1705 ThrowMontageException(OptionError,
"UnrecognizedImageType",
1709 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1713 if (LocaleCompare(
"units",option+1) == 0)
1721 if (i == (ssize_t) argc)
1722 ThrowMontageException(OptionError,
"MissingArgument",option);
1723 units=ParseCommandOption(MagickResolutionOptions,MagickFalse,
1726 ThrowMontageException(OptionError,
"UnrecognizedUnitsType",
1730 if (LocaleCompare(
"unsharp",option+1) == 0)
1735 if (i == (ssize_t) argc)
1736 ThrowMontageException(OptionError,
"MissingArgument",option);
1737 if (IsGeometry(argv[i]) == MagickFalse)
1738 ThrowMontageInvalidArgumentException(option,argv[i]);
1741 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1745 if (LocaleCompare(
"verbose",option+1) == 0)
1749 if ((LocaleCompare(
"version",option+1) == 0) ||
1750 (LocaleCompare(
"-version",option+1) == 0))
1752 ListMagickVersion(stdout);
1755 if (LocaleCompare(
"virtual-pixel",option+1) == 0)
1763 if (i == (ssize_t) argc)
1764 ThrowMontageException(OptionError,
"MissingArgument",option);
1765 method=ParseCommandOption(MagickVirtualPixelOptions,MagickFalse,
1768 ThrowMontageException(OptionError,
1769 "UnrecognizedVirtualPixelMethod",argv[i]);
1772 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1776 if (LocaleCompare(
"white-point",option+1) == 0)
1781 if (i == (ssize_t) argc)
1782 ThrowMontageException(OptionError,
"MissingArgument",option);
1783 if (IsGeometry(argv[i]) == MagickFalse)
1784 ThrowMontageInvalidArgumentException(option,argv[i]);
1787 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1792 ThrowMontageException(OptionError,
"UnrecognizedOption",option)
1794 fire=(GetCommandOptionFlags(MagickCommandOptions,MagickFalse,option) &
1795 FireOptionFlag) == 0 ? MagickFalse : MagickTrue;
1796 if (fire != MagickFalse)
1797 FireImageStack(MagickTrue,MagickTrue,MagickTrue);
1800 ThrowMontageException(OptionError,
"UnbalancedParenthesis",argv[i]);
1801 if (i-- != (ssize_t) (argc-1))
1802 ThrowMontageException(OptionError,
"MissingAnImageFilename",argv[i]);
1803 if (image == (Image *) NULL)
1804 ThrowMontageException(OptionError,
"MissingAnImageFilename",argv[argc-1]);
1805 FinalizeImageSettings(image_info,image,MagickTrue);
1806 if (image == (Image *) NULL)
1807 ThrowMontageException(OptionError,
"MissingAnImageFilename",argv[argc-1]);
1808 (void) CopyMagickString(montage_info->filename,argv[argc-1],MaxTextExtent);
1809 montage_image=MontageImageList(image_info,montage_info,image,exception);
1810 if (montage_image == (Image *) NULL)
1817 GetImageException(montage_image,exception);
1818 (void) CopyMagickString(image_info->filename,argv[argc-1],MaxTextExtent);
1819 (void) CopyMagickString(montage_image->magick_filename,argv[argc-1],
1821 if (*montage_image->magick ==
'\0')
1822 (void) CopyMagickString(montage_image->magick,image->magick,
1824 status&=WriteImages(image_info,montage_image,argv[argc-1],exception);
1825 if (metadata != (
char **) NULL)
1830 text=InterpretImageProperties(image_info,montage_image,format);
1831 InheritException(exception,&montage_image->exception);
1832 if (text == (
char *) NULL)
1833 ThrowMontageException(ResourceLimitError,
"MemoryAllocationFailed",
1834 GetExceptionMessage(errno));
1835 (void) ConcatenateString(&(*metadata),text);
1836 text=DestroyString(text);
1840 return(status != 0 ? MagickTrue : MagickFalse);