summaryrefslogtreecommitdiff
path: root/crypto/LPdir_win.c
diff options
context:
space:
mode:
authorRichard Levitte <levitte@openssl.org>2004-07-20 21:24:43 +0000
committerRichard Levitte <levitte@openssl.org>2004-07-20 21:24:43 +0000
commit64ba6cf222ad7c6aab234cad068309a748f4a644 (patch)
tree525ac95f57aadf15d2a55ff35a62181702b8e726 /crypto/LPdir_win.c
parent210a4f78ae78799f7dc8f4b115c3727eb2d24bd8 (diff)
downloadopenssl-new-64ba6cf222ad7c6aab234cad068309a748f4a644.tar.gz
From LPlib:
Windows changes that detects if multibyte characters are available and deals with them properly. Contributed by Andy Polyakov <appro@fy.chalmers.se>
Diffstat (limited to 'crypto/LPdir_win.c')
-rw-r--r--crypto/LPdir_win.c66
1 files changed, 44 insertions, 22 deletions
diff --git a/crypto/LPdir_win.c b/crypto/LPdir_win.c
index 1a2663cf1e..fcb8004993 100644
--- a/crypto/LPdir_win.c
+++ b/crypto/LPdir_win.c
@@ -1,4 +1,4 @@
-/* $LP: LPlib/source/LPdir_win.c,v 1.3 2004/07/19 16:34:54 _cvs_levitte Exp $ */
+/* $LP: LPlib/source/LPdir_win.c,v 1.4 2004/07/20 21:15:55 _cvs_levitte Exp $ */
/*
* Copyright (c) 2004, Richard Levitte <richard@levitte.org>
* All rights reserved.
@@ -25,6 +25,7 @@
* SUCH DAMAGE.
*/
#include <windows.h>
+#include <tchar.h>
#ifndef LPDIR_H
#include "LPdir.h"
#endif
@@ -57,29 +58,31 @@ const char *LP_find_file(LP_DIR_CTX **ctx, const char *directory)
}
memset(*ctx, '\0', sizeof(LP_DIR_CTX));
-#ifdef LP_SYS_WINCE
- {
- WCHAR *wdir = NULL;
- size_t index = 0;
+ if (sizeof(TCHAR) != sizeof(char))
+ {
+ TCHAR *wdir = NULL;
+ size_t index = 0,len=strlen(direcory);
- wdir = (WCHAR *)malloc((strlen(directory) + 1) * 2);
- if (wdir == NULL)
- {
- errno = ENOMEM;
- free(*ctx);
- return 0;
- }
+ wdir = (TCHAR *)malloc((len + 1) * sizeof(TCHAR));
+ if (wdir == NULL)
+ {
+ errno = ENOMEM;
+ free(*ctx);
+ return 0;
+ }
- for (index = 0; index < strlen(directory) + 1; index++)
- wdir[index] = (short)directory[index];
+#ifdef LP_MULTIBYTE_AVAILABLE
+ if (!MultiByteToWideChar (CP_THREAD_ACP,0,directory,len,wdir,len+1))
+#endif
+ for (index = 0; index < strlen(directory) + 1; index++)
+ wdir[index] = (TCHAR)directory[index];
- (*ctx)->handle = FindFirstFile(wdir, &(*ctx)->ctx);
+ (*ctx)->handle = FindFirstFile(wdir, &(*ctx)->ctx);
- free(wdir);
- }
-#else
- (*ctx)->handle = FindFirstFile(directory, &(*ctx)->ctx);
-#endif
+ free(wdir);
+ }
+ else
+ (*ctx)->handle = FindFirstFile(directory, &(*ctx)->ctx);
if ((*ctx)->handle == INVALID_HANDLE_VALUE)
{
@@ -97,8 +100,27 @@ const char *LP_find_file(LP_DIR_CTX **ctx, const char *directory)
}
}
- strncpy((*ctx)->entry_name, (*ctx)->ctx.cFileName,
- sizeof((*ctx)->entry_name));
+ if (sizeof(TCHAR) != sizeof(char))
+ {
+ TCHAR *wdir=(*ctx)->ctx.cFileName;
+ size_t i,len;
+
+ for (len=0;wdir[len] && len<(sizeof((*ctx)->entry_name)-1);)
+ len++;
+
+#ifdef LP_MULTIBYTE_AVAILABLE
+ if (!WideCharToMultiByte (CP_THREAD_ACP,0,wdir,len,
+ (*ctx)->entry_name,
+ sizeof((*ctx)->entry_name)-1,NULL,0))
+#endif
+ for (i=0;i<len;i++) (*ctx)->entry_name[i] = (char)wdir[i];
+ }
+ else
+ strncpy((*ctx)->entry_name, (*ctx)->ctx.cFileName,
+ sizeof((*ctx)->entry_name)-1);
+
+ (*ctx)->entry_name[sizeof((*ctx)->entry_name)-1] = '\0';
+
return (*ctx)->entry_name;
}