cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 1 | /* |
cristy | 1454be7 | 2011-12-19 01:52:48 +0000 | [diff] [blame] | 2 | Copyright 1999-2012 ImageMagick Studio LLC, a non-profit organization |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 3 | dedicated to making software imaging solutions freely available. |
| 4 | |
| 5 | You may not use this file except in compliance with the License. |
| 6 | obtain a copy of the License at |
| 7 | |
| 8 | http://www.imagemagick.org/script/license.php |
| 9 | |
| 10 | Unless required by applicable law or agreed to in writing, software |
| 11 | distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | See the License for the specific language governing permissions and |
| 14 | limitations under the License. |
| 15 | |
| 16 | MagickCore option methods. |
| 17 | */ |
| 18 | #ifndef _MAGICKCORE_OPTION_H |
| 19 | #define _MAGICKCORE_OPTION_H |
| 20 | |
| 21 | #if defined(__cplusplus) || defined(c_plusplus) |
| 22 | extern "C" { |
| 23 | #endif |
| 24 | |
| 25 | typedef enum |
| 26 | { |
| 27 | MagickUndefinedOptions = -1, |
| 28 | MagickAlignOptions = 0, |
cristy | 288a353 | 2012-08-28 00:19:44 +0000 | [diff] [blame] | 29 | MagickAlphaChannelOptions, |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 30 | MagickBooleanOptions, |
| 31 | MagickChannelOptions, |
| 32 | MagickClassOptions, |
| 33 | MagickClipPathOptions, |
| 34 | MagickCoderOptions, |
| 35 | MagickColorOptions, |
| 36 | MagickColorspaceOptions, |
| 37 | MagickCommandOptions, |
| 38 | MagickComposeOptions, |
| 39 | MagickCompressOptions, |
| 40 | MagickConfigureOptions, |
| 41 | MagickDataTypeOptions, |
| 42 | MagickDebugOptions, |
| 43 | MagickDecorateOptions, |
| 44 | MagickDelegateOptions, |
cristy | c9b1295 | 2010-03-28 01:12:28 +0000 | [diff] [blame] | 45 | MagickDirectionOptions, |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 46 | MagickDisposeOptions, |
| 47 | MagickDistortOptions, |
| 48 | MagickDitherOptions, |
| 49 | MagickEndianOptions, |
| 50 | MagickEvaluateOptions, |
| 51 | MagickFillRuleOptions, |
| 52 | MagickFilterOptions, |
| 53 | MagickFontOptions, |
| 54 | MagickFontsOptions, |
| 55 | MagickFormatOptions, |
| 56 | MagickFunctionOptions, |
| 57 | MagickGravityOptions, |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 58 | MagickIntentOptions, |
| 59 | MagickInterlaceOptions, |
| 60 | MagickInterpolateOptions, |
anthony | 29188a8 | 2010-01-22 10:12:34 +0000 | [diff] [blame] | 61 | MagickKernelOptions, |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 62 | MagickLayerOptions, |
| 63 | MagickLineCapOptions, |
| 64 | MagickLineJoinOptions, |
| 65 | MagickListOptions, |
| 66 | MagickLocaleOptions, |
| 67 | MagickLogEventOptions, |
| 68 | MagickLogOptions, |
| 69 | MagickMagicOptions, |
| 70 | MagickMethodOptions, |
| 71 | MagickMetricOptions, |
| 72 | MagickMimeOptions, |
| 73 | MagickModeOptions, |
| 74 | MagickModuleOptions, |
anthony | 29188a8 | 2010-01-22 10:12:34 +0000 | [diff] [blame] | 75 | MagickMorphologyOptions, |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 76 | MagickNoiseOptions, |
| 77 | MagickOrientationOptions, |
cristy | 6dcb9b8 | 2011-10-23 23:21:25 +0000 | [diff] [blame] | 78 | MagickPixelChannelOptions, |
| 79 | MagickPixelTraitOptions, |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 80 | MagickPolicyOptions, |
| 81 | MagickPolicyDomainOptions, |
| 82 | MagickPolicyRightsOptions, |
| 83 | MagickPreviewOptions, |
| 84 | MagickPrimitiveOptions, |
| 85 | MagickQuantumFormatOptions, |
| 86 | MagickResolutionOptions, |
| 87 | MagickResourceOptions, |
| 88 | MagickSparseColorOptions, |
cristy | 0834d64 | 2011-03-18 18:26:08 +0000 | [diff] [blame] | 89 | MagickStatisticOptions, |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 90 | MagickStorageOptions, |
| 91 | MagickStretchOptions, |
| 92 | MagickStyleOptions, |
| 93 | MagickThresholdOptions, |
| 94 | MagickTypeOptions, |
| 95 | MagickValidateOptions, |
anthony | 29188a8 | 2010-01-22 10:12:34 +0000 | [diff] [blame] | 96 | MagickVirtualPixelOptions |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 97 | } CommandOption; |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 98 | |
| 99 | typedef enum |
| 100 | { |
| 101 | UndefinedValidate, |
| 102 | NoValidate = 0x00000, |
| 103 | CompareValidate = 0x00001, |
| 104 | CompositeValidate = 0x00002, |
| 105 | ConvertValidate = 0x00004, |
| 106 | FormatsInMemoryValidate = 0x00008, |
| 107 | FormatsOnDiskValidate = 0x00010, |
| 108 | IdentifyValidate = 0x00020, |
| 109 | ImportExportValidate = 0x00040, |
| 110 | MontageValidate = 0x00080, |
| 111 | StreamValidate = 0x00100, |
| 112 | AllValidate = 0x7fffffff |
| 113 | } ValidateType; |
| 114 | |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 115 | /* |
| 116 | Flags to describe classes of image processing options. |
anthony | fd706f9 | 2012-01-19 04:22:02 +0000 | [diff] [blame] | 117 | These are used to determine how a option should be processed, and |
| 118 | allow use to avoid attempting to process each option in every way posible. |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 119 | */ |
anthony | ce2716b | 2011-04-22 09:51:34 +0000 | [diff] [blame] | 120 | typedef enum |
| 121 | { |
anthony | fd706f9 | 2012-01-19 04:22:02 +0000 | [diff] [blame] | 122 | UndefinedOptionFlag = 0x0000, /* option flag is not in use */ |
| 123 | |
anthony | 3ae4293 | 2012-04-16 13:59:49 +0000 | [diff] [blame] | 124 | ImageInfoOptionFlag = 0x0001, /* Setting stored in ImageInfo */ |
| 125 | DrawInfoOptionFlag = 0x0002, /* Setting stored in DrawInfo */ |
| 126 | QuantizeInfoOptionFlag = 0x0004, /* Setting stored in QuantizeInfo */ |
anthony | 22de272 | 2012-04-19 14:43:00 +0000 | [diff] [blame] | 127 | GlobalOptionFlag = 0x0008, /* Global Setting or Control */ |
anthony | 964d28e | 2012-05-17 23:39:46 +0000 | [diff] [blame] | 128 | SettingOptionFlags = 0x000F, /* mask any setting option */ |
anthony | fd706f9 | 2012-01-19 04:22:02 +0000 | [diff] [blame] | 129 | |
anthony | 464f1c4 | 2012-04-22 08:51:01 +0000 | [diff] [blame] | 130 | NoImageOperatorFlag = 0x0010, /* Images not required operator */ |
| 131 | SimpleOperatorFlag = 0x0020, /* Simple Image processing operator */ |
| 132 | ListOperatorFlag = 0x0040, /* Multi-Image processing operator */ |
anthony | bcdb020 | 2012-04-12 11:54:26 +0000 | [diff] [blame] | 133 | GenesisOptionFlag = 0x0080, /* MagickCommandGenesis() Only Option */ |
anthony | fd706f9 | 2012-01-19 04:22:02 +0000 | [diff] [blame] | 134 | |
anthony | 464f1c4 | 2012-04-22 08:51:01 +0000 | [diff] [blame] | 135 | SpecialOptionFlag = 0x0100, /* Operator with Special Requirements */ |
| 136 | /* EG: for specific CLI commands */ |
anthony | 8226e72 | 2012-04-05 14:25:46 +0000 | [diff] [blame] | 137 | |
anthony | 964d28e | 2012-05-17 23:39:46 +0000 | [diff] [blame] | 138 | AlwaysInterpretArgsFlag = 0x0400, /* Always Interpret escapes in Args */ |
anthony | 4837ac2 | 2012-05-18 23:39:48 +0000 | [diff] [blame] | 139 | /* CF: "convert" compatibility mode */ |
anthony | 964d28e | 2012-05-17 23:39:46 +0000 | [diff] [blame] | 140 | NeverInterpretArgsFlag = 0x0800, /* Never Interpret escapes in Args */ |
anthony | 4837ac2 | 2012-05-18 23:39:48 +0000 | [diff] [blame] | 141 | /* Typical because it's a filename */ |
anthony | 964d28e | 2012-05-17 23:39:46 +0000 | [diff] [blame] | 142 | |
anthony | 668f43a | 2012-02-20 14:55:32 +0000 | [diff] [blame] | 143 | NonMagickOptionFlag = 0x1000, /* Option not used by Magick Command */ |
anthony | 975a8d7 | 2012-04-12 13:54:36 +0000 | [diff] [blame] | 144 | FireOptionFlag = 0x2000, /* Convert operation seq firing point */ |
| 145 | DeprecateOptionFlag = 0x4000, /* Deprecate option (no code) */ |
anthony | 4837ac2 | 2012-05-18 23:39:48 +0000 | [diff] [blame] | 146 | ReplacedOptionFlag = 0x8800 /* Replaced Option (but still works) */ |
anthony | af2746d | 2012-01-16 00:16:10 +0000 | [diff] [blame] | 147 | |
anthony | ce2716b | 2011-04-22 09:51:34 +0000 | [diff] [blame] | 148 | } CommandOptionFlags; |
| 149 | |
anthony | 464f1c4 | 2012-04-22 08:51:01 +0000 | [diff] [blame] | 150 | typedef struct _OptionInfo |
| 151 | { |
| 152 | const char |
| 153 | *mnemonic; |
| 154 | |
| 155 | ssize_t |
| 156 | type, |
| 157 | flags; |
| 158 | |
| 159 | MagickBooleanType |
| 160 | stealth; |
| 161 | } OptionInfo; |
| 162 | |
anthony | fd706f9 | 2012-01-19 04:22:02 +0000 | [diff] [blame] | 163 | |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 164 | extern MagickExport char |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 165 | **GetCommandOptions(const CommandOption), |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 166 | *GetNextImageOption(const ImageInfo *), |
| 167 | *RemoveImageOption(ImageInfo *,const char *); |
| 168 | |
| 169 | extern MagickExport const char |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 170 | *CommandOptionToMnemonic(const CommandOption,const ssize_t), |
| 171 | *GetImageOption(const ImageInfo *,const char *); |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 172 | |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 173 | extern MagickExport MagickBooleanType |
| 174 | CloneImageOptions(ImageInfo *,const ImageInfo *), |
| 175 | DefineImageOption(ImageInfo *,const char *), |
| 176 | DeleteImageOption(ImageInfo *,const char *), |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 177 | IsCommandOption(const char *), |
| 178 | ListCommandOptions(FILE *,const CommandOption,ExceptionInfo *), |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 179 | SetImageOption(ImageInfo *,const char *,const char *); |
| 180 | |
cristy | 5ed838e | 2010-05-31 00:05:35 +0000 | [diff] [blame] | 181 | extern MagickExport ssize_t |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 182 | GetCommandOptionFlags(const CommandOption,const MagickBooleanType, |
| 183 | const char *), |
cristy | 5ed838e | 2010-05-31 00:05:35 +0000 | [diff] [blame] | 184 | ParseChannelOption(const char *), |
cristy | 953c4bd | 2012-02-24 01:04:04 +0000 | [diff] [blame] | 185 | ParsePixelChannelOption(const char *), |
cristy | 042ee78 | 2011-04-22 18:48:30 +0000 | [diff] [blame] | 186 | ParseCommandOption(const CommandOption,const MagickBooleanType,const char *); |
cristy | 5ed838e | 2010-05-31 00:05:35 +0000 | [diff] [blame] | 187 | |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 188 | extern MagickExport void |
| 189 | DestroyImageOptions(ImageInfo *), |
| 190 | ResetImageOptions(const ImageInfo *), |
| 191 | ResetImageOptionIterator(const ImageInfo *); |
| 192 | |
anthony | 32d85bf | 2012-02-15 14:54:59 +0000 | [diff] [blame] | 193 | extern MagickExport const OptionInfo |
| 194 | *GetCommandOptionInfo(const char *value); |
| 195 | |
cristy | 3ed852e | 2009-09-05 21:47:34 +0000 | [diff] [blame] | 196 | #if defined(__cplusplus) || defined(c_plusplus) |
| 197 | } |
| 198 | #endif |
| 199 | |
| 200 | #endif |