Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
cb566755
Commit
cb566755
authored
Oct 23, 2008
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mpr: Use a mountmgr ioctl to retrieve the UNC name for a drive.
parent
abe00bbe
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
50 additions
and
24 deletions
+50
-24
wnet.c
dlls/mpr/wnet.c
+50
-24
No files found.
dlls/mpr/wnet.c
View file @
cb566755
...
@@ -24,10 +24,13 @@
...
@@ -24,10 +24,13 @@
#include "windef.h"
#include "windef.h"
#include "winbase.h"
#include "winbase.h"
#include "winnls.h"
#include "winnls.h"
#include "winioctl.h"
#include "winnetwk.h"
#include "winnetwk.h"
#include "npapi.h"
#include "npapi.h"
#include "winreg.h"
#include "winreg.h"
#include "winuser.h"
#include "winuser.h"
#define WINE_MOUNTMGR_EXTENSIONS
#include "ddk/mountmgr.h"
#include "wine/debug.h"
#include "wine/debug.h"
#include "wine/unicode.h"
#include "wine/unicode.h"
#include "mprres.h"
#include "mprres.h"
...
@@ -1750,6 +1753,52 @@ DWORD WINAPI WNetGetConnectionA( LPCSTR lpLocalName,
...
@@ -1750,6 +1753,52 @@ DWORD WINAPI WNetGetConnectionA( LPCSTR lpLocalName,
return
ret
;
return
ret
;
}
}
/* find the network connection for a given drive; helper for WNetGetConnection */
static
DWORD
get_drive_connection
(
WCHAR
letter
,
LPWSTR
remote
,
LPDWORD
size
)
{
char
buffer
[
1024
];
struct
mountmgr_unix_drive
*
data
=
(
struct
mountmgr_unix_drive
*
)
buffer
;
HANDLE
mgr
;
DWORD
ret
=
WN_NOT_CONNECTED
;
if
((
mgr
=
CreateFileW
(
MOUNTMGR_DOS_DEVICE_NAME
,
GENERIC_READ
|
GENERIC_WRITE
,
FILE_SHARE_READ
|
FILE_SHARE_WRITE
,
NULL
,
OPEN_EXISTING
,
0
,
0
))
==
INVALID_HANDLE_VALUE
)
{
ERR
(
"failed to open mount manager err %u
\n
"
,
GetLastError
()
);
return
ret
;
}
memset
(
data
,
0
,
sizeof
(
*
data
)
);
data
->
letter
=
letter
;
if
(
DeviceIoControl
(
mgr
,
IOCTL_MOUNTMGR_QUERY_UNIX_DRIVE
,
data
,
sizeof
(
*
data
),
data
,
sizeof
(
buffer
),
NULL
,
NULL
))
{
char
*
p
,
*
mount_point
=
buffer
+
data
->
mount_point_offset
;
DWORD
len
;
if
(
data
->
mount_point_offset
&&
!
strncmp
(
mount_point
,
"unc/"
,
4
))
{
mount_point
+=
2
;
mount_point
[
0
]
=
'\\'
;
for
(
p
=
mount_point
;
*
p
;
p
++
)
if
(
*
p
==
'/'
)
*
p
=
'\\'
;
len
=
MultiByteToWideChar
(
CP_UNIXCP
,
0
,
mount_point
,
-
1
,
NULL
,
0
);
if
(
len
>
*
size
)
{
*
size
=
len
;
ret
=
WN_MORE_DATA
;
}
else
{
*
size
=
MultiByteToWideChar
(
CP_UNIXCP
,
0
,
mount_point
,
-
1
,
remote
,
*
size
);
ret
=
WN_SUCCESS
;
}
}
}
CloseHandle
(
mgr
);
return
ret
;
}
/**************************************************************************
/**************************************************************************
* WNetGetConnectionW [MPR.@]
* WNetGetConnectionW [MPR.@]
*
*
...
@@ -1778,31 +1827,8 @@ DWORD WINAPI WNetGetConnectionW( LPCWSTR lpLocalName,
...
@@ -1778,31 +1827,8 @@ DWORD WINAPI WNetGetConnectionW( LPCWSTR lpLocalName,
switch
(
GetDriveTypeW
(
lpLocalName
))
switch
(
GetDriveTypeW
(
lpLocalName
))
{
{
case
DRIVE_REMOTE
:
case
DRIVE_REMOTE
:
{
ret
=
get_drive_connection
(
lpLocalName
[
0
],
lpRemoteName
,
lpBufferSize
);
static
const
WCHAR
unc
[]
=
{
'u'
,
'n'
,
'c'
,
'\\'
};
WCHAR
rremote
[
MAX_PATH
],
*
remote
=
rremote
;
if
(
!
QueryDosDeviceW
(
lpLocalName
,
remote
,
MAX_PATH
))
remote
[
0
]
=
0
;
else
if
(
!
strncmpW
(
remote
,
unc
,
4
))
{
remote
+=
2
;
remote
[
0
]
=
'\\'
;
}
else
if
(
remote
[
0
]
!=
'\\'
||
remote
[
1
]
!=
'\\'
)
FIXME
(
"Don't know how to convert %s to an unc
\n
"
,
debugstr_w
(
remote
));
if
(
strlenW
(
remote
)
+
1
>
*
lpBufferSize
)
{
*
lpBufferSize
=
strlenW
(
remote
)
+
1
;
ret
=
WN_MORE_DATA
;
}
else
{
strcpyW
(
lpRemoteName
,
remote
);
*
lpBufferSize
=
strlenW
(
lpRemoteName
)
+
1
;
ret
=
WN_SUCCESS
;
}
break
;
break
;
}
case
DRIVE_REMOVABLE
:
case
DRIVE_REMOVABLE
:
case
DRIVE_FIXED
:
case
DRIVE_FIXED
:
case
DRIVE_CDROM
:
case
DRIVE_CDROM
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment