1 /*
2 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3 % %
4 % %
5 % %
6 % V V M M SSSSS %
7 % V V MM MM SS %
8 % V V M M M SSS %
9 % V V M M SS %
10 % V M M SSSSS %
11 % %
12 % %
13 % MagickCore VMS Utility Methods %
14 % %
15 % Software Design %
16 % Cristy %
17 % October 1994 %
18 % %
19 % %
20 % Copyright 1999-2020 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 directory methods are strongly based on similar methods written
37 % by Rich Salz.
38 %
39 */
40
41 #if defined(vms)
42 /*
43 Include declarations.
44 */
45 #include "MagickCore/studio.h"
46 #include "MagickCore/string_.h"
47 #include "MagickCore/memory_.h"
48 #include "MagickCore/vms.h"
49
50 #if !defined(_AXP_) && (!defined(__VMS_VER) || (__VMS_VER < 70000000))
51 /*
52 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
53 % %
54 % %
55 % %
56 % c l o s e d i r %
57 % %
58 % %
59 % %
60 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
61 %
62 % closedir() closes the named directory stream and frees the DIR structure.
63 %
64 % The format of the closedir method is:
65 %
66 %
67 % A description of each parameter follows:
68 %
69 % o entry: Specifies a pointer to a DIR structure.
70 %
71 %
72 */
closedir(DIR * directory)73 void closedir(DIR *directory)
74 {
75 if (image->debug != MagickFalse)
76 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
77 assert(directory != (DIR *) NULL);
78 directory->pattern=DestroyString(directory->pattern);
79 directory=DestroyString(directory);
80 }
81
82 /*
83 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
84 % %
85 % %
86 % %
87 % o p e n d i r %
88 % %
89 % %
90 % %
91 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
92 %
93 % opendir() opens the directory named by filename and associates a directory
94 % stream with it.
95 %
96 % The format of the opendir method is:
97 %
98 % opendir(entry)
99 %
100 % A description of each parameter follows:
101 %
102 % o entry: Specifies a pointer to a DIR structure.
103 %
104 %
105 */
opendir(char * name)106 DIR *opendir(char *name)
107 {
108 DIR
109 *directory;
110
111 /*
112 Allocate memory for handle and the pattern.
113 */
114 directory=(DIR *) AcquireMagickMemory(sizeof(DIR));
115 if (directory == (DIR *) NULL)
116 {
117 errno=ENOMEM;
118 return((DIR *) NULL);
119 }
120 if (strcmp(".",name) == 0)
121 name="";
122 directory->pattern=(char *) AcquireQuantumMemory(strlen(name)+sizeof("*.*")+
123 1UL,sizeof(*directory->pattern));
124 if (directory->pattern == (char *) NULL)
125 {
126 directory=DestroyString(directory);
127 errno=ENOMEM;
128 return(NULL);
129 }
130 /*
131 Initialize descriptor.
132 */
133 (void) FormatLocaleString(directory->pattern,MagickPathExtent,"%s*.*",name);
134 directory->context=0;
135 directory->pat.dsc$a_pointer=directory->pattern;
136 directory->pat.dsc$w_length=strlen(directory->pattern);
137 directory->pat.dsc$b_dtype=DSC$K_DTYPE_T;
138 directory->pat.dsc$b_class=DSC$K_CLASS_S;
139 return(directory);
140 }
141
142 /*
143 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
144 % %
145 % %
146 % %
147 % r e a d d i r %
148 % %
149 % %
150 % %
151 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
152 %
153 % readdir() returns a pointer to a structure representing the directory entry
154 % at the current position in the directory stream to which entry refers.
155 %
156 % The format of the readdir
157 %
158 % readdir(entry)
159 %
160 % A description of each parameter follows:
161 %
162 % o entry: Specifies a pointer to a DIR structure.
163 %
164 %
165 */
readdir(DIR * directory)166 struct dirent *readdir(DIR *directory)
167 {
168 char
169 buffer[sizeof(directory->entry.d_name)];
170
171 int
172 status;
173
174 register char
175 *p;
176
177 register int
178 i;
179
180 struct dsc$descriptor_s
181 result;
182
183 /*
184 Initialize the result descriptor.
185 */
186 result.dsc$a_pointer=buffer;
187 result.dsc$w_length=sizeof(buffer)-2;
188 result.dsc$b_dtype=DSC$K_DTYPE_T;
189 result.dsc$b_class=DSC$K_CLASS_S;
190 status=lib$find_file(&directory->pat,&result,&directory->context);
191 if ((status == RMS$_NMF) || (directory->context == 0L))
192 return((struct dirent *) NULL);
193 /*
194 Lowercase all filenames.
195 */
196 buffer[sizeof(buffer)-1]='\0';
197 for (p=buffer; *p; p++)
198 if (isupper((int) ((unsigned char) *p)))
199 *p=LocaleLowercase(*p);
200 /*
201 Skip any directory component and just copy the name.
202 */
203 p=buffer;
204 while (isspace((int) ((unsigned char) *p)) == 0)
205 p++;
206 *p='\0';
207 p=strchr(buffer,']');
208 if (p)
209 (void) CopyMagickString(directory->entry.d_name,p+1,MagickPathExtent);
210 else
211 (void) CopyMagickString(directory->entry.d_name,buffer,MagickPathExtent);
212 directory->entry.d_namlen=strlen(directory->entry.d_name);
213 return(&directory->entry);
214 }
215 #endif /* !defined(_AXP_) && (!defined(__VMS_VER) || (__VMS_VER < 70000000)) */
216
217 /*
218 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
219 % %
220 % %
221 % %
222 % I s M a g i c k C o n f l i c t %
223 % %
224 % %
225 % %
226 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
227 %
228 % VMSIsMagickConflict() returns true if the image format conflicts with a
229 % logical drive (.e.g. SYS$SCRATCH:).
230 %
231 % Contributed by Forrest Cahoon (forrest@wiredaemons.com)
232 %
233 % The format of the VMSIsMagickConflict method is:
234 %
235 % MagickBooleanType VMSIsMagickConflict(const char *magick)
236 %
237 % A description of each parameter follows:
238 %
239 % o magick: Specifies the image format.
240 %
241 %
242 */
VMSIsMagickConflict(const char * magick)243 MagickExport MagickBooleanType VMSIsMagickConflict(const char *magick)
244 {
245 ile3
246 item_list[2];
247
248 int
249 device_class,
250 status;
251
252 struct dsc$descriptor_s
253 device;
254
255 assert(magick != (char *) NULL);
256 device.dsc$w_length=strlen(magick);
257 device.dsc$a_pointer=(char *) magick;
258 device.dsc$b_class=DSC$K_CLASS_S;
259 device.dsc$b_dtype=DSC$K_DTYPE_T;
260 item_list[0].ile3$w_length=sizeof(device_class);
261 item_list[0].ile3$w_code=DVI$_DEVCLASS;
262 item_list[0].ile3$ps_bufaddr=&device_class;
263 item_list[0].ile3$ps_retlen_addr=NULL;
264 (void) memset(&item_list[1],0,sizeof(item_list[1]));
265 status=sys$getdviw(0,0,&device,&item_list,0,0,0,0);
266 if ((status == SS$_NONLOCAL) ||
267 ((status & 0x01) && (device_class & (DC$_DISK | DC$_TAPE))))
268 return(MagickTrue);
269 return(MagickFalse);
270 }
271 #endif /* defined(vms) */
272