Indentation fix, cleanup.
[AROS.git] / arch / all-pc / acpica / source / os_specific / service_layers / osunixdir.c
blob2e007e94d2a45f45b68b28a22b0db4baee8f5948
1 /******************************************************************************
3 * Module Name: osunixdir - Unix directory access interfaces
5 *****************************************************************************/
7 /*
8 * Copyright (C) 2000 - 2013, Intel Corp.
9 * All rights reserved.
11 * Redistribution and use in source and binary forms, with or without
12 * modification, are permitted provided that the following conditions
13 * are met:
14 * 1. Redistributions of source code must retain the above copyright
15 * notice, this list of conditions, and the following disclaimer,
16 * without modification.
17 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18 * substantially similar to the "NO WARRANTY" disclaimer below
19 * ("Disclaimer") and any redistribution must be conditioned upon
20 * including a substantially similar Disclaimer requirement for further
21 * binary redistribution.
22 * 3. Neither the names of the above-listed copyright holders nor the names
23 * of any contributors may be used to endorse or promote products derived
24 * from this software without specific prior written permission.
26 * Alternatively, this software may be distributed under the terms of the
27 * GNU General Public License ("GPL") version 2 as published by the Free
28 * Software Foundation.
30 * NO WARRANTY
31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41 * POSSIBILITY OF SUCH DAMAGES.
44 #include <acpi.h>
46 #include <stdio.h>
47 #include <stdlib.h>
48 #include <string.h>
49 #include <dirent.h>
50 #include <fnmatch.h>
51 #include <ctype.h>
52 #include <sys/stat.h>
55 * Allocated structure returned from OsOpenDirectory
57 typedef struct ExternalFindInfo
59 char *DirPathname;
60 DIR *DirPtr;
61 char temp_buffer[256];
62 char *WildcardSpec;
63 char RequestedFileType;
65 } EXTERNAL_FIND_INFO;
68 /*******************************************************************************
70 * FUNCTION: AcpiOsOpenDirectory
72 * PARAMETERS: DirPathname - Full pathname to the directory
73 * WildcardSpec - string of the form "*.c", etc.
75 * RETURN: A directory "handle" to be used in subsequent search operations.
76 * NULL returned on failure.
78 * DESCRIPTION: Open a directory in preparation for a wildcard search
80 ******************************************************************************/
82 void *
83 AcpiOsOpenDirectory (
84 char *DirPathname,
85 char *WildcardSpec,
86 char RequestedFileType)
88 EXTERNAL_FIND_INFO *ExternalInfo;
89 DIR *dir;
92 /* Allocate the info struct that will be returned to the caller */
94 ExternalInfo = calloc (1, sizeof (EXTERNAL_FIND_INFO));
95 if (!ExternalInfo)
97 return (NULL);
100 /* Get the directory stream */
102 dir = opendir (DirPathname);
103 if (!dir)
105 fprintf (stderr, "Cannot open directory - %s\n", DirPathname);
106 free (ExternalInfo);
107 return (NULL);
110 /* Save the info in the return structure */
112 ExternalInfo->WildcardSpec = WildcardSpec;
113 ExternalInfo->RequestedFileType = RequestedFileType;
114 ExternalInfo->DirPathname = DirPathname;
115 ExternalInfo->DirPtr = dir;
116 return (ExternalInfo);
120 /*******************************************************************************
122 * FUNCTION: AcpiOsGetNextFilename
124 * PARAMETERS: DirHandle - Created via AcpiOsOpenDirectory
126 * RETURN: Next filename matched. NULL if no more matches.
128 * DESCRIPTION: Get the next file in the directory that matches the wildcard
129 * specification.
131 ******************************************************************************/
133 char *
134 AcpiOsGetNextFilename (
135 void *DirHandle)
137 EXTERNAL_FIND_INFO *ExternalInfo = DirHandle;
138 struct dirent *dir_entry;
139 char *temp_str;
140 int str_len;
141 struct stat temp_stat;
142 int err;
145 while ((dir_entry = readdir (ExternalInfo->DirPtr)))
147 if (!fnmatch (ExternalInfo->WildcardSpec, dir_entry->d_name, 0))
149 if (dir_entry->d_name[0] == '.')
151 continue;
154 str_len = strlen (dir_entry->d_name) +
155 strlen (ExternalInfo->DirPathname) + 2;
157 temp_str = calloc (str_len, 1);
158 if (!temp_str)
160 fprintf (stderr,
161 "Could not allocate buffer for temporary string\n");
162 return (NULL);
165 strcpy (temp_str, ExternalInfo->DirPathname);
166 strcat (temp_str, "/");
167 strcat (temp_str, dir_entry->d_name);
169 err = stat (temp_str, &temp_stat);
170 free (temp_str);
171 if (err == -1)
173 fprintf (stderr,
174 "Cannot stat file (should not happen) - %s\n",
175 temp_str);
176 return (NULL);
179 if ((S_ISDIR (temp_stat.st_mode)
180 && (ExternalInfo->RequestedFileType == REQUEST_DIR_ONLY))
182 ((!S_ISDIR (temp_stat.st_mode)
183 && ExternalInfo->RequestedFileType == REQUEST_FILE_ONLY)))
185 /* copy to a temp buffer because dir_entry struct is on the stack */
187 strcpy (ExternalInfo->temp_buffer, dir_entry->d_name);
188 return (ExternalInfo->temp_buffer);
193 return (NULL);
197 /*******************************************************************************
199 * FUNCTION: AcpiOsCloseDirectory
201 * PARAMETERS: DirHandle - Created via AcpiOsOpenDirectory
203 * RETURN: None.
205 * DESCRIPTION: Close the open directory and cleanup.
207 ******************************************************************************/
209 void
210 AcpiOsCloseDirectory (
211 void *DirHandle)
213 EXTERNAL_FIND_INFO *ExternalInfo = DirHandle;
216 /* Close the directory and free allocations */
218 closedir (ExternalInfo->DirPtr);
219 free (DirHandle);