MagickWand 6.9.13-14
Convert, Edit, Or Compose Bitmap Images
Loading...
Searching...
No Matches
identify.c
1/*
2%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3% %
4% %
5% %
6% IIIII DDDD EEEEE N N TTTTT IIIII FFFFF Y Y %
7% I D D E NN N T I F Y Y %
8% I D D EEE N N N T I FFF Y %
9% I D D E N NN T I F Y %
10% IIIII DDDD EEEEE N N T IIIII F Y %
11% %
12% %
13% Identify an Image Format and Characteristics. %
14% %
15% Software Design %
16% Cristy %
17% September 1994 %
18% %
19% %
20% Copyright 1999 ImageMagick Studio LLC, a non-profit organization %
21% dedicated to making software imaging solutions freely available. %
22% %
23% You may not use this file except in compliance with the License. You may %
24% obtain a copy of the License at %
25% %
26% https://imagemagick.org/script/license.php %
27% %
28% Unless required by applicable law or agreed to in writing, software %
29% distributed under the License is distributed on an "AS IS" BASIS, %
30% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. %
31% See the License for the specific language governing permissions and %
32% limitations under the License. %
33% %
34%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
35%
36% The identify program describes the format and characteristics of one or more
37% image files. It also reports if an image is incomplete or corrupt. The
38% information returned includes the image number, the file name, the width and
39% height of the image, whether the image is colormapped or not, the number of
40% colors in the image, the number of bytes in the image, the format of the
41% image (JPEG, PNM, etc.), and finally the number of seconds it took to read
42% and process the image. Many more attributes are available with the verbose
43% option.
44%
45*/
46
47/*
48 Include declarations.
49*/
50#include "wand/studio.h"
51#include "wand/MagickWand.h"
52#include "wand/mogrify-private.h"
53#include "magick/string-private.h"
54
55/*
56%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
57% %
58% %
59% %
60+ I d e n t i f y I m a g e C o m m a n d %
61% %
62% %
63% %
64%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
65%
66% IdentifyImageCommand() describes the format and characteristics of one or
67% more image files. It will also report if an image is incomplete or corrupt.
68% The information displayed includes the scene number, the file name, the
69% width and height of the image, whether the image is colormapped or not,
70% the number of colors in the image, the number of bytes in the image, the
71% format of the image (JPEG, PNM, etc.), and finally the number of seconds
72% it took to read and process the image.
73%
74% The format of the IdentifyImageCommand method is:
75%
76% MagickBooleanType IdentifyImageCommand(ImageInfo *image_info,int argc,
77% char **argv,char **metadata,ExceptionInfo *exception)
78%
79% A description of each parameter follows:
80%
81% o image_info: the image info.
82%
83% o argc: the number of elements in the argument vector.
84%
85% o argv: A text array containing the command line arguments.
86%
87% o metadata: any metadata is returned here.
88%
89% o exception: return any errors or warnings in this structure.
90%
91*/
92
93static MagickBooleanType IdentifyUsage(void)
94{
95 static const char
96 miscellaneous[] =
97 " -debug events display copious debugging information\n"
98 " -help print program options\n"
99 " -list type print a list of supported option arguments\n"
100 " -log format format of debugging information\n"
101 " -version print version information",
102 operators[] =
103 " -auto-orient automagically orient (rotate) image\n"
104 " -grayscale method convert image to grayscale\n"
105 " -negate replace every pixel with its complementary color",
106 settings[] =
107 " -alpha option on, activate, off, deactivate, set, opaque, copy\n"
108 " transparent, extract, background, or shape\n"
109 " -antialias remove pixel-aliasing\n"
110 " -authenticate password\n"
111 " decipher image with this password\n"
112 " -channel type apply option to select image channels\n"
113 " -clip clip along the first path from the 8BIM profile\n"
114 " -clip-mask filename associate a clip mask with the image\n"
115 " -clip-path id clip along a named path from the 8BIM profile\n"
116 " -colorspace type alternate image colorspace\n"
117 " -crop geometry cut out a rectangular region of the image\n"
118 " -define format:option\n"
119 " define one or more image format options\n"
120 " -density geometry horizontal and vertical density of the image\n"
121 " -depth value image depth\n"
122 " -endian type endianness (MSB or LSB) of the image\n"
123 " -extract geometry extract area from image\n"
124 " -features distance analyze image features (e.g. contrast, correlation)\n"
125 " -format \"string\" output formatted image characteristics\n"
126 " -fuzz distance colors within this distance are considered equal\n"
127 " -gamma value of gamma correction\n"
128 " -interlace type type of image interlacing scheme\n"
129 " -interpolate method pixel color interpolation method\n"
130 " -limit type value pixel cache resource limit\n"
131 " -list type Color, Configure, Delegate, Format, Magic, Module,\n"
132 " Resource, or Type\n"
133 " -mask filename associate a mask with the image\n"
134 " -matte store matte channel if the image has one\n"
135 " -moments report image moments\n"
136 " -format \"string\" output formatted image characteristics\n"
137 " -monitor monitor progress\n"
138 " -ping efficiently determine image attributes\n"
139 " -precision value maximum number of significant digits to print\n"
140 " -quiet suppress all warning messages\n"
141 " -regard-warnings pay attention to warning messages\n"
142 " -respect-parentheses settings remain in effect until parenthesis boundary\n"
143 " -sampling-factor geometry\n"
144 " horizontal and vertical sampling factor\n"
145 " -seed value seed a new sequence of pseudo-random numbers\n"
146 " -set attribute value set an image attribute\n"
147 " -size geometry width and height of image\n"
148 " -strip strip image of all profiles and comments\n"
149 " -unique display the number of unique colors in the image\n"
150 " -units type the units of image resolution\n"
151 " -verbose print detailed information about the image\n"
152 " -virtual-pixel method\n"
153 " virtual pixel access method";
154
155 ListMagickVersion(stdout);
156 (void) printf("Usage: %s [options ...] file [ [options ...] "
157 "file ... ]\n",GetClientName());
158 (void) printf("\nImage Settings:\n");
159 (void) puts(settings);
160 (void) printf("\nImage Operators:\n");
161 (void) puts(operators);
162 (void) printf("\nMiscellaneous Options:\n");
163 (void) puts(miscellaneous);
164 (void) printf(
165 "\nBy default, the image format of `file' is determined by its magic\n");
166 (void) printf(
167 "number. To specify a particular image format, precede the filename\n");
168 (void) printf(
169 "with an image format name and a colon (i.e. ps:image) or specify the\n");
170 (void) printf(
171 "image type as the filename suffix (i.e. image.ps). Specify 'file' as\n");
172 (void) printf("'-' for standard input or output.\n");
173 return(MagickTrue);
174}
175
176WandExport MagickBooleanType IdentifyImageCommand(ImageInfo *image_info,
177 int argc,char **argv,char **metadata,ExceptionInfo *exception)
178{
179#define DestroyIdentify() \
180{ \
181 DestroyImageStack(); \
182 for (i=0; i < (ssize_t) argc; i++) \
183 argv[i]=DestroyString(argv[i]); \
184 argv=(char **) RelinquishMagickMemory(argv); \
185}
186#define ThrowIdentifyException(asperity,tag,option) \
187{ \
188 (void) ThrowMagickException(exception,GetMagickModule(),asperity,tag,"`%s'", \
189 option); \
190 DestroyIdentify(); \
191 return(MagickFalse); \
192}
193#define ThrowIdentifyInvalidArgumentException(option,argument) \
194{ \
195 (void) ThrowMagickException(exception,GetMagickModule(),OptionError, \
196 "InvalidArgument","`%s': %s",option,argument); \
197 DestroyIdentify(); \
198 return(MagickFalse); \
199}
200
201 const char
202 *format,
203 *option;
204
205 Image
206 *image;
207
209 image_stack[MaxImageStackDepth+1];
210
211 MagickBooleanType
212 fire,
213 pend,
214 respect_parenthesis;
215
216 MagickStatusType
217 status;
218
219 ssize_t
220 i;
221
222 size_t
223 count;
224
225 ssize_t
226 j,
227 k;
228
229 /*
230 Set defaults.
231 */
232 assert(image_info != (ImageInfo *) NULL);
233 assert(image_info->signature == MagickCoreSignature);
234 assert(exception != (ExceptionInfo *) NULL);
235 if (IsEventLogging() != MagickFalse)
236 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
237 if (argc == 2)
238 {
239 option=argv[1];
240 if ((LocaleCompare("version",option+1) == 0) ||
241 (LocaleCompare("-version",option+1) == 0))
242 {
243 ListMagickVersion(stdout);
244 return(MagickTrue);
245 }
246 }
247 if (argc < 2)
248 {
249 (void) ThrowMagickException(exception,GetMagickModule(),OptionError,
250 "MissingArgument","%s","");
251 (void) IdentifyUsage();
252 return(MagickFalse);
253 }
254 count=0;
255 format=NULL;
256 j=1;
257 k=0;
258 NewImageStack();
259 option=(char *) NULL;
260 pend=MagickFalse;
261 respect_parenthesis=MagickFalse;
262 status=MagickTrue;
263 /*
264 Identify an image.
265 */
266 ReadCommandlLine(argc,&argv);
267 status=ExpandFilenames(&argc,&argv);
268 if (status == MagickFalse)
269 ThrowIdentifyException(ResourceLimitError,"MemoryAllocationFailed",
270 GetExceptionMessage(errno));
271 image_info->ping=MagickTrue;
272 for (i=1; i < (ssize_t) argc; i++)
273 {
274 option=argv[i];
275 if (LocaleCompare(option,"(") == 0)
276 {
277 FireImageStack(MagickFalse,MagickTrue,pend);
278 if (k == MaxImageStackDepth)
279 ThrowIdentifyException(OptionError,"ParenthesisNestedTooDeeply",
280 option);
281 PushImageStack();
282 continue;
283 }
284 if (LocaleCompare(option,")") == 0)
285 {
286 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
287 if (k == 0)
288 ThrowIdentifyException(OptionError,"UnableToParseExpression",option);
289 PopImageStack();
290 continue;
291 }
292 if (IsCommandOption(option) == MagickFalse)
293 {
294 char
295 *filename;
296
297 Image
298 *images;
299
300 ImageInfo
301 *identify_info;
302
303 /*
304 Read input image.
305 */
306 FireImageStack(MagickFalse,MagickFalse,pend);
307 identify_info=CloneImageInfo(image_info);
308 identify_info->verbose=MagickFalse;
309 filename=argv[i];
310 if ((LocaleCompare(filename,"--") == 0) && (i < (ssize_t) (argc-1)))
311 filename=argv[++i];
312 (void) SetImageOption(image_info,"filename",filename);
313 (void) CopyMagickString(identify_info->filename,filename,MaxTextExtent);
314 if (identify_info->ping != MagickFalse)
315 images=PingImages(identify_info,exception);
316 else
317 images=ReadImages(identify_info,exception);
318 identify_info=DestroyImageInfo(identify_info);
319 status&=(images != (Image *) NULL) &&
320 (exception->severity < ErrorException);
321 if (images == (Image *) NULL)
322 continue;
323 AppendImageStack(images);
324 FinalizeImageSettings(image_info,image,MagickFalse);
325 count=0;
326 for ( ; image != (Image *) NULL; image=GetNextImageInList(image))
327 {
328 if (image->scene == 0)
329 image->scene=count++;
330 if (format == (char *) NULL)
331 {
332 (void) IdentifyImage(image,stdout,image_info->verbose);
333 continue;
334 }
335 if (metadata != (char **) NULL)
336 {
337 char
338 *text;
339
340 text=InterpretImageProperties(image_info,image,format);
341 InheritException(exception,&image->exception);
342 if (text == (char *) NULL)
343 ThrowIdentifyException(ResourceLimitError,
344 "MemoryAllocationFailed",GetExceptionMessage(errno));
345 (void) ConcatenateString(&(*metadata),text);
346 text=DestroyString(text);
347 }
348 }
349 RemoveAllImageStack();
350 continue;
351 }
352 pend=image != (Image *) NULL ? MagickTrue : MagickFalse;
353 image_info->ping=MagickFalse;
354 switch (*(option+1))
355 {
356 case 'a':
357 {
358 if (LocaleCompare("alpha",option+1) == 0)
359 {
360 ssize_t
361 type;
362
363 if (*option == '+')
364 break;
365 i++;
366 if (i == (ssize_t) argc)
367 ThrowIdentifyException(OptionError,"MissingArgument",option);
368 type=ParseCommandOption(MagickAlphaOptions,MagickFalse,argv[i]);
369 if (type < 0)
370 ThrowIdentifyException(OptionError,"UnrecognizedAlphaChannelType",
371 argv[i]);
372 break;
373 }
374 if (LocaleCompare("antialias",option+1) == 0)
375 break;
376 if (LocaleCompare("authenticate",option+1) == 0)
377 {
378 if (*option == '+')
379 break;
380 i++;
381 if (i == (ssize_t) argc)
382 ThrowIdentifyException(OptionError,"MissingArgument",option);
383 break;
384 }
385 if (LocaleCompare("auto-orient",option+1) == 0)
386 break;
387 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
388 }
389 case 'c':
390 {
391 if (LocaleCompare("cache",option+1) == 0)
392 {
393 if (*option == '+')
394 break;
395 i++;
396 if (i == (ssize_t) argc)
397 ThrowIdentifyException(OptionError,"MissingArgument",option);
398 if (IsGeometry(argv[i]) == MagickFalse)
399 ThrowIdentifyInvalidArgumentException(option,argv[i]);
400 break;
401 }
402 if (LocaleCompare("channel",option+1) == 0)
403 {
404 ssize_t
405 channel;
406
407 if (*option == '+')
408 break;
409 i++;
410 if (i == (ssize_t) argc)
411 ThrowIdentifyException(OptionError,"MissingArgument",option);
412 channel=ParseChannelOption(argv[i]);
413 if (channel < 0)
414 ThrowIdentifyException(OptionError,"UnrecognizedChannelType",
415 argv[i]);
416 break;
417 }
418 if (LocaleCompare("clip",option+1) == 0)
419 break;
420 if (LocaleCompare("clip-mask",option+1) == 0)
421 {
422 if (*option == '+')
423 break;
424 i++;
425 if (i == (ssize_t) argc)
426 ThrowIdentifyException(OptionError,"MissingArgument",option);
427 break;
428 }
429 if (LocaleCompare("clip-path",option+1) == 0)
430 {
431 i++;
432 if (i == (ssize_t) argc)
433 ThrowIdentifyException(OptionError,"MissingArgument",option);
434 break;
435 }
436 if (LocaleCompare("colorspace",option+1) == 0)
437 {
438 ssize_t
439 colorspace;
440
441 if (*option == '+')
442 break;
443 i++;
444 if (i == (ssize_t) argc)
445 ThrowIdentifyException(OptionError,"MissingArgument",option);
446 colorspace=ParseCommandOption(MagickColorspaceOptions,
447 MagickFalse,argv[i]);
448 if (colorspace < 0)
449 ThrowIdentifyException(OptionError,"UnrecognizedColorspace",
450 argv[i]);
451 break;
452 }
453 if (LocaleCompare("crop",option+1) == 0)
454 {
455 if (*option == '+')
456 break;
457 i++;
458 if (i == (ssize_t) argc)
459 ThrowIdentifyException(OptionError,"MissingArgument",option);
460 if (IsGeometry(argv[i]) == MagickFalse)
461 ThrowIdentifyInvalidArgumentException(option,argv[i]);
462 break;
463 }
464 if (LocaleCompare("concurrent",option+1) == 0)
465 break;
466 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
467 }
468 case 'd':
469 {
470 if (LocaleCompare("debug",option+1) == 0)
471 {
472 ssize_t
473 event;
474
475 if (*option == '+')
476 break;
477 i++;
478 if (i == (ssize_t) argc)
479 ThrowIdentifyException(OptionError,"MissingArgument",option);
480 event=ParseCommandOption(MagickLogEventOptions,MagickFalse,argv[i]);
481 if (event < 0)
482 ThrowIdentifyException(OptionError,"UnrecognizedEventType",
483 argv[i]);
484 (void) SetLogEventMask(argv[i]);
485 break;
486 }
487 if (LocaleCompare("define",option+1) == 0)
488 {
489 i++;
490 if (i == (ssize_t) argc)
491 ThrowIdentifyException(OptionError,"MissingArgument",option);
492 if (*option == '+')
493 {
494 const char
495 *define;
496
497 define=GetImageOption(image_info,argv[i]);
498 if (define == (const char *) NULL)
499 ThrowIdentifyException(OptionError,"NoSuchOption",argv[i]);
500 break;
501 }
502 break;
503 }
504 if (LocaleCompare("density",option+1) == 0)
505 {
506 if (*option == '+')
507 break;
508 i++;
509 if (i == (ssize_t) argc)
510 ThrowIdentifyException(OptionError,"MissingArgument",option);
511 if (IsGeometry(argv[i]) == MagickFalse)
512 ThrowIdentifyInvalidArgumentException(option,argv[i]);
513 break;
514 }
515 if (LocaleCompare("depth",option+1) == 0)
516 {
517 if (*option == '+')
518 break;
519 i++;
520 if (i == (ssize_t) argc)
521 ThrowIdentifyException(OptionError,"MissingArgument",option);
522 if (IsGeometry(argv[i]) == MagickFalse)
523 ThrowIdentifyInvalidArgumentException(option,argv[i]);
524 break;
525 }
526 if (LocaleCompare("duration",option+1) == 0)
527 {
528 if (*option == '+')
529 break;
530 i++;
531 if (i == (ssize_t) argc)
532 ThrowIdentifyException(OptionError,"MissingArgument",option);
533 if (IsGeometry(argv[i]) == MagickFalse)
534 ThrowIdentifyInvalidArgumentException(option,argv[i]);
535 break;
536 }
537 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
538 }
539 case 'e':
540 {
541 if (LocaleCompare("endian",option+1) == 0)
542 {
543 ssize_t
544 endian;
545
546 if (*option == '+')
547 break;
548 i++;
549 if (i == (ssize_t) argc)
550 ThrowIdentifyException(OptionError,"MissingArgument",option);
551 endian=ParseCommandOption(MagickEndianOptions,MagickFalse,
552 argv[i]);
553 if (endian < 0)
554 ThrowIdentifyException(OptionError,"UnrecognizedEndianType",
555 argv[i]);
556 break;
557 }
558 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
559 }
560 case 'f':
561 {
562 if (LocaleCompare("features",option+1) == 0)
563 {
564 if (*option == '+')
565 break;
566 i++;
567 if (i == (ssize_t) argc)
568 ThrowIdentifyException(OptionError,"MissingArgument",option);
569 if (IsGeometry(argv[i]) == MagickFalse)
570 ThrowIdentifyInvalidArgumentException(option,argv[i]);
571 break;
572 }
573 if (LocaleCompare("format",option+1) == 0)
574 {
575 format=(char *) NULL;
576 if (*option == '+')
577 break;
578 i++;
579 if (i == (ssize_t) argc)
580 ThrowIdentifyException(OptionError,"MissingArgument",option);
581 format=argv[i];
582 image_info->ping=MagickFalse;
583 break;
584 }
585 if (LocaleCompare("fuzz",option+1) == 0)
586 {
587 if (*option == '+')
588 break;
589 i++;
590 if (i == (ssize_t) argc)
591 ThrowIdentifyException(OptionError,"MissingArgument",option);
592 if (IsGeometry(argv[i]) == MagickFalse)
593 ThrowIdentifyInvalidArgumentException(option,argv[i]);
594 break;
595 }
596 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
597 }
598 case 'g':
599 {
600 if (LocaleCompare("gamma",option+1) == 0)
601 {
602 i++;
603 if (i == (ssize_t) argc)
604 ThrowIdentifyException(OptionError,"MissingArgument",option);
605 if (IsGeometry(argv[i]) == MagickFalse)
606 ThrowIdentifyInvalidArgumentException(option,argv[i]);
607 break;
608 }
609 if (LocaleCompare("grayscale",option+1) == 0)
610 {
611 ssize_t
612 method;
613
614 if (*option == '+')
615 break;
616 i++;
617 if (i == (ssize_t) argc)
618 ThrowIdentifyException(OptionError,"MissingArgument",option);
619 method=ParseCommandOption(MagickPixelIntensityOptions,MagickFalse,
620 argv[i]);
621 if (method < 0)
622 ThrowIdentifyException(OptionError,"UnrecognizedIntensityMethod",
623 argv[i]);
624 break;
625 }
626 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
627 }
628 case 'h':
629 {
630 if ((LocaleCompare("help",option+1) == 0) ||
631 (LocaleCompare("-help",option+1) == 0))
632 {
633 DestroyIdentify();
634 return(IdentifyUsage());
635 }
636 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
637 }
638 case 'i':
639 {
640 if (LocaleCompare("interlace",option+1) == 0)
641 {
642 ssize_t
643 interlace;
644
645 if (*option == '+')
646 break;
647 i++;
648 if (i == (ssize_t) argc)
649 ThrowIdentifyException(OptionError,"MissingArgument",option);
650 interlace=ParseCommandOption(MagickInterlaceOptions,MagickFalse,
651 argv[i]);
652 if (interlace < 0)
653 ThrowIdentifyException(OptionError,"UnrecognizedInterlaceType",
654 argv[i]);
655 break;
656 }
657 if (LocaleCompare("interpolate",option+1) == 0)
658 {
659 ssize_t
660 interpolate;
661
662 if (*option == '+')
663 break;
664 i++;
665 if (i == (ssize_t) argc)
666 ThrowIdentifyException(OptionError,"MissingArgument",option);
667 interpolate=ParseCommandOption(MagickInterpolateOptions,MagickFalse,
668 argv[i]);
669 if (interpolate < 0)
670 ThrowIdentifyException(OptionError,
671 "UnrecognizedInterpolateMethod",argv[i]);
672 break;
673 }
674 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
675 }
676 case 'l':
677 {
678 if (LocaleCompare("limit",option+1) == 0)
679 {
680 char
681 *p;
682
683 double
684 value;
685
686 ssize_t
687 resource;
688
689 if (*option == '+')
690 break;
691 i++;
692 if (i == (ssize_t) argc)
693 ThrowIdentifyException(OptionError,"MissingArgument",option);
694 resource=ParseCommandOption(MagickResourceOptions,MagickFalse,
695 argv[i]);
696 if (resource < 0)
697 ThrowIdentifyException(OptionError,"UnrecognizedResourceType",
698 argv[i]);
699 i++;
700 if (i == (ssize_t) argc)
701 ThrowIdentifyException(OptionError,"MissingArgument",option);
702 value=StringToDouble(argv[i],&p);
703 (void) value;
704 if ((p == argv[i]) && (LocaleCompare("unlimited",argv[i]) != 0))
705 ThrowIdentifyInvalidArgumentException(option,argv[i]);
706 break;
707 }
708 if (LocaleCompare("list",option+1) == 0)
709 {
710 ssize_t
711 list;
712
713 if (*option == '+')
714 break;
715 i++;
716 if (i == (ssize_t) argc)
717 ThrowIdentifyException(OptionError,"MissingArgument",option);
718 list=ParseCommandOption(MagickListOptions,MagickFalse,argv[i]);
719 if (list < 0)
720 ThrowIdentifyException(OptionError,"UnrecognizedListType",
721 argv[i]);
722 status=MogrifyImageInfo(image_info,(int) (i-j+1),(const char **)
723 argv+j,exception);
724 DestroyIdentify();
725 return(status == 0 ? MagickFalse : MagickTrue);
726 }
727 if (LocaleCompare("log",option+1) == 0)
728 {
729 if (*option == '+')
730 break;
731 i++;
732 if ((i == (ssize_t) argc) ||
733 (strchr(argv[i],'%') == (char *) NULL))
734 ThrowIdentifyException(OptionError,"MissingArgument",option);
735 break;
736 }
737 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
738 }
739 case 'm':
740 {
741 if (LocaleCompare("mask",option+1) == 0)
742 {
743 if (*option == '+')
744 break;
745 i++;
746 if (i == (ssize_t) argc)
747 ThrowIdentifyException(OptionError,"MissingArgument",option);
748 break;
749 }
750 if (LocaleCompare("matte",option+1) == 0)
751 break;
752 if (LocaleCompare("moments",option+1) == 0)
753 break;
754 if (LocaleCompare("monitor",option+1) == 0)
755 break;
756 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
757 }
758 case 'n':
759 {
760 if (LocaleCompare("negate",option+1) == 0)
761 break;
762 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
763 }
764 case 'p':
765 {
766 if (LocaleCompare("ping",option+1) == 0)
767 {
768 image_info->ping=MagickTrue;
769 break;
770 }
771 if (LocaleCompare("precision",option+1) == 0)
772 {
773 if (*option == '+')
774 break;
775 i++;
776 if (i == (ssize_t) argc)
777 ThrowIdentifyException(OptionError,"MissingArgument",option);
778 if (IsGeometry(argv[i]) == MagickFalse)
779 ThrowIdentifyInvalidArgumentException(option,argv[i]);
780 break;
781 }
782 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
783 }
784 case 'q':
785 {
786 if (LocaleCompare("quiet",option+1) == 0)
787 break;
788 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
789 }
790 case 'r':
791 {
792 if (LocaleCompare("regard-warnings",option+1) == 0)
793 break;
794 if (LocaleNCompare("respect-parentheses",option+1,17) == 0)
795 {
796 respect_parenthesis=(*option == '-') ? MagickTrue : MagickFalse;
797 break;
798 }
799 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
800 }
801 case 's':
802 {
803 if (LocaleCompare("sampling-factor",option+1) == 0)
804 {
805 if (*option == '+')
806 break;
807 i++;
808 if (i == (ssize_t) argc)
809 ThrowIdentifyException(OptionError,"MissingArgument",option);
810 if (IsGeometry(argv[i]) == MagickFalse)
811 ThrowIdentifyInvalidArgumentException(option,argv[i]);
812 break;
813 }
814 if (LocaleCompare("seed",option+1) == 0)
815 {
816 if (*option == '+')
817 break;
818 i++;
819 if (i == (ssize_t) argc)
820 ThrowIdentifyException(OptionError,"MissingArgument",option);
821 if (IsGeometry(argv[i]) == MagickFalse)
822 ThrowIdentifyInvalidArgumentException(option,argv[i]);
823 break;
824 }
825 if (LocaleCompare("set",option+1) == 0)
826 {
827 i++;
828 if (i == (ssize_t) argc)
829 ThrowIdentifyException(OptionError,"MissingArgument",option);
830 if (*option == '+')
831 break;
832 i++;
833 if (i == (ssize_t) argc)
834 ThrowIdentifyException(OptionError,"MissingArgument",option);
835 break;
836 }
837 if (LocaleCompare("size",option+1) == 0)
838 {
839 if (*option == '+')
840 break;
841 i++;
842 if (i == (ssize_t) argc)
843 ThrowIdentifyException(OptionError,"MissingArgument",option);
844 if (IsGeometry(argv[i]) == MagickFalse)
845 ThrowIdentifyInvalidArgumentException(option,argv[i]);
846 break;
847 }
848 if (LocaleCompare("strip",option+1) == 0)
849 break;
850 if (LocaleCompare("support",option+1) == 0)
851 {
852 if (*option == '+')
853 break;
854 i++;
855 if (i == (ssize_t) argc)
856 ThrowIdentifyException(OptionError,"MissingArgument",option);
857 if (IsGeometry(argv[i]) == MagickFalse)
858 ThrowIdentifyInvalidArgumentException(option,argv[i]);
859 break;
860 }
861 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
862 }
863 case 'u':
864 {
865 if (LocaleCompare("unique",option+1) == 0)
866 break;
867 if (LocaleCompare("units",option+1) == 0)
868 {
869 ssize_t
870 units;
871
872 if (*option == '+')
873 break;
874 i++;
875 if (i == (ssize_t) argc)
876 ThrowIdentifyException(OptionError,"MissingArgument",option);
877 units=ParseCommandOption(MagickResolutionOptions,MagickFalse,
878 argv[i]);
879 if (units < 0)
880 ThrowIdentifyException(OptionError,"UnrecognizedUnitsType",
881 argv[i]);
882 break;
883 }
884 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
885 }
886 case 'v':
887 {
888 if (LocaleCompare("verbose",option+1) == 0)
889 break;
890 if (LocaleCompare("virtual-pixel",option+1) == 0)
891 {
892 ssize_t
893 method;
894
895 if (*option == '+')
896 break;
897 i++;
898 if (i == (ssize_t) argc)
899 ThrowIdentifyException(OptionError,"MissingArgument",option);
900 method=ParseCommandOption(MagickVirtualPixelOptions,MagickFalse,
901 argv[i]);
902 if (method < 0)
903 ThrowIdentifyException(OptionError,
904 "UnrecognizedVirtualPixelMethod",argv[i]);
905 break;
906 }
907 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
908 }
909 case '?':
910 break;
911 default:
912 ThrowIdentifyException(OptionError,"UnrecognizedOption",option)
913 }
914 fire=(GetCommandOptionFlags(MagickCommandOptions,MagickFalse,option) &
915 FireOptionFlag) == 0 ? MagickFalse : MagickTrue;
916 if (fire != MagickFalse)
917 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
918 }
919 if (k != 0)
920 ThrowIdentifyException(OptionError,"UnbalancedParenthesis",argv[i]);
921 if (i != (ssize_t) argc)
922 ThrowIdentifyException(OptionError,"MissingAnImageFilename",argv[i]);
923 DestroyIdentify();
924 return(status != 0 ? MagickTrue : MagickFalse);
925}