diff options
author | djm <> | 2008-09-06 12:15:53 +0000 |
---|---|---|
committer | djm <> | 2008-09-06 12:15:53 +0000 |
commit | f69b11f62c3e6c9d4db22529933cf93b6301f7b1 (patch) | |
tree | ec748bb51a7a2ac81befdc69d06cd4d45a476bd4 /src/lib/libcrypto/LPdir_win.c | |
parent | d5e315499a1ca7bacd7fc271e246a659969370e5 (diff) | |
download | openbsd-f69b11f62c3e6c9d4db22529933cf93b6301f7b1.tar.gz openbsd-f69b11f62c3e6c9d4db22529933cf93b6301f7b1.tar.bz2 openbsd-f69b11f62c3e6c9d4db22529933cf93b6301f7b1.zip |
import of OpenSSL 0.9.8h
Diffstat (limited to 'src/lib/libcrypto/LPdir_win.c')
-rw-r--r-- | src/lib/libcrypto/LPdir_win.c | 155 |
1 files changed, 155 insertions, 0 deletions
diff --git a/src/lib/libcrypto/LPdir_win.c b/src/lib/libcrypto/LPdir_win.c new file mode 100644 index 0000000000..09b475beed --- /dev/null +++ b/src/lib/libcrypto/LPdir_win.c | |||
@@ -0,0 +1,155 @@ | |||
1 | /* $LP: LPlib/source/LPdir_win.c,v 1.10 2004/08/26 13:36:05 _cvs_levitte Exp $ */ | ||
2 | /* | ||
3 | * Copyright (c) 2004, Richard Levitte <richard@levitte.org> | ||
4 | * All rights reserved. | ||
5 | * | ||
6 | * Redistribution and use in source and binary forms, with or without | ||
7 | * modification, are permitted provided that the following conditions | ||
8 | * are met: | ||
9 | * 1. Redistributions of source code must retain the above copyright | ||
10 | * notice, this list of conditions and the following disclaimer. | ||
11 | * 2. Redistributions in binary form must reproduce the above copyright | ||
12 | * notice, this list of conditions and the following disclaimer in the | ||
13 | * documentation and/or other materials provided with the distribution. | ||
14 | * | ||
15 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||
16 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||
17 | * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||
18 | * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||
19 | * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||
20 | * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||
21 | * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
22 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||
23 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
24 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
25 | * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
26 | */ | ||
27 | #include <windows.h> | ||
28 | #include <tchar.h> | ||
29 | #ifndef LPDIR_H | ||
30 | #include "LPdir.h" | ||
31 | #endif | ||
32 | |||
33 | /* We're most likely overcautious here, but let's reserve for | ||
34 | broken WinCE headers and explicitly opt for UNICODE call. | ||
35 | Keep in mind that our WinCE builds are compiled with -DUNICODE | ||
36 | [as well as -D_UNICODE]. */ | ||
37 | #if defined(LP_SYS_WINCE) && !defined(FindFirstFile) | ||
38 | # define FindFirstFile FindFirstFileW | ||
39 | #endif | ||
40 | #if defined(LP_SYS_WINCE) && !defined(FindFirstFile) | ||
41 | # define FindNextFile FindNextFileW | ||
42 | #endif | ||
43 | |||
44 | #ifndef NAME_MAX | ||
45 | #define NAME_MAX 255 | ||
46 | #endif | ||
47 | |||
48 | struct LP_dir_context_st | ||
49 | { | ||
50 | WIN32_FIND_DATA ctx; | ||
51 | HANDLE handle; | ||
52 | char entry_name[NAME_MAX+1]; | ||
53 | }; | ||
54 | |||
55 | const char *LP_find_file(LP_DIR_CTX **ctx, const char *directory) | ||
56 | { | ||
57 | struct dirent *direntry = NULL; | ||
58 | |||
59 | if (ctx == NULL || directory == NULL) | ||
60 | { | ||
61 | errno = EINVAL; | ||
62 | return 0; | ||
63 | } | ||
64 | |||
65 | errno = 0; | ||
66 | if (*ctx == NULL) | ||
67 | { | ||
68 | *ctx = (LP_DIR_CTX *)malloc(sizeof(LP_DIR_CTX)); | ||
69 | if (*ctx == NULL) | ||
70 | { | ||
71 | errno = ENOMEM; | ||
72 | return 0; | ||
73 | } | ||
74 | memset(*ctx, '\0', sizeof(LP_DIR_CTX)); | ||
75 | |||
76 | if (sizeof(TCHAR) != sizeof(char)) | ||
77 | { | ||
78 | TCHAR *wdir = NULL; | ||
79 | /* len_0 denotes string length *with* trailing 0 */ | ||
80 | size_t index = 0,len_0 = strlen(directory) + 1; | ||
81 | |||
82 | wdir = (TCHAR *)malloc(len_0 * sizeof(TCHAR)); | ||
83 | if (wdir == NULL) | ||
84 | { | ||
85 | free(*ctx); | ||
86 | *ctx = NULL; | ||
87 | errno = ENOMEM; | ||
88 | return 0; | ||
89 | } | ||
90 | |||
91 | #ifdef LP_MULTIBYTE_AVAILABLE | ||
92 | if (!MultiByteToWideChar(CP_ACP, 0, directory, len_0, (WCHAR *)wdir, len_0)) | ||
93 | #endif | ||
94 | for (index = 0; index < len_0; index++) | ||
95 | wdir[index] = (TCHAR)directory[index]; | ||
96 | |||
97 | (*ctx)->handle = FindFirstFile(wdir, &(*ctx)->ctx); | ||
98 | |||
99 | free(wdir); | ||
100 | } | ||
101 | else | ||
102 | (*ctx)->handle = FindFirstFile((TCHAR *)directory, &(*ctx)->ctx); | ||
103 | |||
104 | if ((*ctx)->handle == INVALID_HANDLE_VALUE) | ||
105 | { | ||
106 | free(*ctx); | ||
107 | *ctx = NULL; | ||
108 | errno = EINVAL; | ||
109 | return 0; | ||
110 | } | ||
111 | } | ||
112 | else | ||
113 | { | ||
114 | if (FindNextFile((*ctx)->handle, &(*ctx)->ctx) == FALSE) | ||
115 | { | ||
116 | return 0; | ||
117 | } | ||
118 | } | ||
119 | |||
120 | if (sizeof(TCHAR) != sizeof(char)) | ||
121 | { | ||
122 | TCHAR *wdir = (*ctx)->ctx.cFileName; | ||
123 | size_t index, len_0 = 0; | ||
124 | |||
125 | while (wdir[len_0] && len_0 < (sizeof((*ctx)->entry_name) - 1)) len_0++; | ||
126 | len_0++; | ||
127 | |||
128 | #ifdef LP_MULTIBYTE_AVAILABLE | ||
129 | if (!WideCharToMultiByte(CP_ACP, 0, (WCHAR *)wdir, len_0, (*ctx)->entry_name, | ||
130 | sizeof((*ctx)->entry_name), NULL, 0)) | ||
131 | #endif | ||
132 | for (index = 0; index < len_0; index++) | ||
133 | (*ctx)->entry_name[index] = (char)wdir[index]; | ||
134 | } | ||
135 | else | ||
136 | strncpy((*ctx)->entry_name, (const char *)(*ctx)->ctx.cFileName, | ||
137 | sizeof((*ctx)->entry_name)-1); | ||
138 | |||
139 | (*ctx)->entry_name[sizeof((*ctx)->entry_name)-1] = '\0'; | ||
140 | |||
141 | return (*ctx)->entry_name; | ||
142 | } | ||
143 | |||
144 | int LP_find_file_end(LP_DIR_CTX **ctx) | ||
145 | { | ||
146 | if (ctx != NULL && *ctx != NULL) | ||
147 | { | ||
148 | FindClose((*ctx)->handle); | ||
149 | free(*ctx); | ||
150 | *ctx = NULL; | ||
151 | return 1; | ||
152 | } | ||
153 | errno = EINVAL; | ||
154 | return 0; | ||
155 | } | ||