Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'winsup/cygwin/path.cc')
-rw-r--r--winsup/cygwin/path.cc35
1 files changed, 20 insertions, 15 deletions
diff --git a/winsup/cygwin/path.cc b/winsup/cygwin/path.cc
index 6b1e44cbd..cec315b74 100644
--- a/winsup/cygwin/path.cc
+++ b/winsup/cygwin/path.cc
@@ -75,6 +75,7 @@ details. */
#include "shared_info.h"
#include "registry.h"
#include "cygtls.h"
+#include "ntdll.h"
#include <assert.h>
static int normalize_win32_path (const char *, char *, char *&);
@@ -488,25 +489,29 @@ path_conv::set_normalized_path (const char *path_copy, bool strip_tail)
PUNICODE_STRING
path_conv::get_nt_native_path (UNICODE_STRING &upath)
{
- if (path[0] != '\\') /* X:\... or NUL, etc. */
+ if (path[0] == '\\' && path[1] != '\\')
{
- str2uni_cat (upath, "\\??\\");
- str2uni_cat (upath, path);
+ /* This handles all paths already given in NT speak. On writing this
+ comment, these are the raw device paths. */
+ if (RtlCreateUnicodeStringFromAsciiz (&upath, path))
+ return &upath;
}
- else if (path[1] != '\\') /* \Device\... */
- str2uni_cat (upath, path);
- else if (path[2] != '.'
- || path[3] != '\\') /* \\server\share\... */
- {
- str2uni_cat (upath, "\\??\\UNC\\");
- str2uni_cat (upath, path + 2);
- }
- else /* \\.\device */
+ else
{
- str2uni_cat (upath, "\\??\\");
- str2uni_cat (upath, path + 4);
+ wchar_t wc_path[CYG_MAX_PATH];
+ sys_mbstowcs (wc_path, path, CYG_MAX_PATH);
+ if (RtlDosPathNameToNtPathName_U (wc_path, &upath, NULL, NULL))
+ {
+#ifdef DEBUGGING
+ char nt_path[CYG_MAX_PATH + 7];
+ sys_wcstombs (nt_path, upath.Buffer, CYG_MAX_PATH + 7);
+ debug_printf ("DOS: <%s> NT: <%s>", path, nt_path);
+#endif
+ return &upath;
+ }
}
- return &upath;
+ set_errno (ENOMEM);
+ return NULL;
}
/* Convert an arbitrary path SRC to a pure Win32 path, suitable for