1 /** 2 * Copyright: Mike Wey 2011 3 * License: zlib (See accompanying LICENSE file) 4 * Authors: Mike Wey 5 */ 6 7 module dmagick.CoderInfo; 8 9 import std.conv; 10 import std.string; 11 12 import dmagick.Exception; 13 14 import dmagick.c.magick; 15 16 /** 17 * This provides information about the image formats supported by 18 * Imagemagick. The MatchType determines if a coder should be returned 19 * in the array. MatchType.Any matches both MatchType.True 20 * and MatchType.True. 21 * 22 * Params: 23 * readable = Does the coder need to provide read support. 24 * writable = Does the coder need to provide write support. 25 * multiFrame = Does the coder need to provide multi frame support. 26 */ 27 CoderInfo[] coderInfoList(MatchType readable, MatchType writable, MatchType multiFrame) 28 { 29 size_t length; 30 CoderInfo[] list; 31 32 const(MagickInfo)*[] infoList = 33 GetMagickInfoList("*", &length, DMagickExceptionInfo())[0 .. length]; 34 35 foreach ( info; infoList ) 36 { 37 CoderInfo coder = CoderInfo(info); 38 39 if ( readable == MatchType.False && coder.readable ) 40 continue; 41 42 if ( readable == MatchType.True && !coder.readable ) 43 continue; 44 45 if ( writable == MatchType.False && coder.writable ) 46 continue; 47 48 if ( writable == MatchType.True && !coder.writable ) 49 continue; 50 51 if ( multiFrame == MatchType.False && coder.supportsMultiFrame ) 52 continue; 53 54 if ( multiFrame == MatchType.True && !coder.supportsMultiFrame ) 55 continue; 56 57 list ~= coder; 58 } 59 60 return list; 61 } 62 63 /** 64 * CoderInfo provides the means to get information regarding ImageMagick 65 * support for an image format (designated by a magick string). It may be 66 * used to provide information for a specific named format (provided as an 67 * argument to the constructor). 68 */ 69 struct CoderInfo 70 { 71 /** 72 * Format name. (e.g. "GIF") 73 */ 74 string name; 75 76 /** 77 * Format description. (e.g. "CompuServe graphics interchange format") 78 */ 79 string description; 80 81 /** 82 * Format is readable. 83 */ 84 bool readable; 85 86 /** 87 * Format is writable. 88 */ 89 bool writable; 90 91 /** 92 * Format supports multiple frames. 93 */ 94 bool supportsMultiFrame; 95 96 97 /** 98 * Construct object corresponding to named format. (e.g. "GIF") 99 */ 100 this (string format) 101 { 102 const(MagickInfo)* info = 103 GetMagickInfo(toStringz(format), DMagickExceptionInfo()); 104 105 this(info); 106 } 107 108 this (const(MagickInfo)* info) 109 { 110 name = to!(string)(info.name); 111 description = to!(string)(info.description); 112 readable = info.decoder !is null; 113 writable = info.encoder !is null; 114 supportsMultiFrame = info.adjoin != 0; 115 } 116 } 117 118 /// 119 enum MatchType 120 { 121 Any, /// Don't care. 122 True, /// Matches. 123 False /// Doesn't match. 124 }