Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
83aeda3f
Commit
83aeda3f
authored
Jan 08, 2007
by
Detlef Riekenberg
Committed by
Alexandre Julliard
Jan 09, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
localspl/tests: Load the user interface dll on demand.
parent
6addb220
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
44 additions
and
2 deletions
+44
-2
localmon.c
dlls/localspl/tests/localmon.c
+44
-2
No files found.
dlls/localspl/tests/localmon.c
View file @
83aeda3f
...
@@ -58,11 +58,18 @@ static BOOL (WINAPI *pXcvOpenPort)(LPCWSTR, ACCESS_MASK, PHANDLE phXcv);
...
@@ -58,11 +58,18 @@ static BOOL (WINAPI *pXcvOpenPort)(LPCWSTR, ACCESS_MASK, PHANDLE phXcv);
static
DWORD
(
WINAPI
*
pXcvDataPort
)(
HANDLE
,
LPCWSTR
,
PBYTE
,
DWORD
,
PBYTE
,
DWORD
,
PDWORD
);
static
DWORD
(
WINAPI
*
pXcvDataPort
)(
HANDLE
,
LPCWSTR
,
PBYTE
,
DWORD
,
PBYTE
,
DWORD
,
PDWORD
);
static
BOOL
(
WINAPI
*
pXcvClosePort
)(
HANDLE
);
static
BOOL
(
WINAPI
*
pXcvClosePort
)(
HANDLE
);
static
HMODULE
hlocalui
;
static
PMONITORUI
(
WINAPI
*
pInitializePrintMonitorUI
)(
VOID
);
static
PMONITORUI
pui
;
static
BOOL
(
WINAPI
*
pAddPortUI
)(
PCWSTR
,
HWND
,
PCWSTR
,
PWSTR
*
);
static
BOOL
(
WINAPI
*
pConfigurePortUI
)(
PCWSTR
,
HWND
,
PCWSTR
);
static
BOOL
(
WINAPI
*
pDeletePortUI
)(
PCWSTR
,
HWND
,
PCWSTR
);
static
WCHAR
cmd_MonitorUIW
[]
=
{
'M'
,
'o'
,
'n'
,
'i'
,
't'
,
'o'
,
'r'
,
'U'
,
'I'
,
0
};
static
WCHAR
cmd_MonitorUIW
[]
=
{
'M'
,
'o'
,
'n'
,
'i'
,
't'
,
'o'
,
'r'
,
'U'
,
'I'
,
0
};
static
WCHAR
cmd_MonitorUI_lcaseW
[]
=
{
'm'
,
'o'
,
'n'
,
'i'
,
't'
,
'o'
,
'r'
,
'u'
,
'i'
,
0
};
static
WCHAR
cmd_MonitorUI_lcaseW
[]
=
{
'm'
,
'o'
,
'n'
,
'i'
,
't'
,
'o'
,
'r'
,
'u'
,
'i'
,
0
};
static
WCHAR
does_not_existW
[]
=
{
'd'
,
'o'
,
'e'
,
's'
,
'_'
,
'n'
,
'o'
,
't'
,
'_'
,
'e'
,
'x'
,
'i'
,
's'
,
't'
,
0
};
static
WCHAR
does_not_existW
[]
=
{
'd'
,
'o'
,
'e'
,
's'
,
'_'
,
'n'
,
'o'
,
't'
,
'_'
,
'e'
,
'x'
,
'i'
,
's'
,
't'
,
0
};
static
WCHAR
emptyW
[]
=
{
0
};
static
WCHAR
emptyW
[]
=
{
0
};
static
WCHAR
Monitors_LocalPortW
[]
=
{
\
static
WCHAR
Monitors_LocalPortW
[]
=
{
'S'
,
'y'
,
's'
,
't'
,
'e'
,
'm'
,
'\\'
,
'S'
,
'y'
,
's'
,
't'
,
'e'
,
'm'
,
'\\'
,
'C'
,
'u'
,
'r'
,
'r'
,
'e'
,
'n'
,
't'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'S'
,
'e'
,
't'
,
'\\'
,
'C'
,
'u'
,
'r'
,
'r'
,
'e'
,
'n'
,
't'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'S'
,
'e'
,
't'
,
'\\'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'\\'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'\\'
,
...
@@ -481,11 +488,15 @@ static void test_XcvOpenPort(void)
...
@@ -481,11 +488,15 @@ static void test_XcvOpenPort(void)
START_TEST
(
localmon
)
START_TEST
(
localmon
)
{
{
DWORD
numentries
;
/* This DLL does not exists on Win9x */
/* This DLL does not exists on Win9x */
hdll
=
LoadLibraryA
(
"localspl.dll"
);
hdll
=
LoadLibraryA
(
"localspl.dll"
);
if
(
!
hdll
)
return
;
if
(
!
hdll
)
return
;
pInitializePrintMonitor
=
(
void
*
)
GetProcAddress
(
hdll
,
"InitializePrintMonitor"
);
pInitializePrintMonitor
=
(
void
*
)
GetProcAddress
(
hdll
,
"InitializePrintMonitor"
);
pInitializePrintMonitorUI
=
(
void
*
)
GetProcAddress
(
hdll
,
"InitializePrintMonitorUI"
);
if
(
!
pInitializePrintMonitor
)
{
if
(
!
pInitializePrintMonitor
)
{
/* The Monitor for "Local Ports" was in a seperate dll before w2k */
/* The Monitor for "Local Ports" was in a seperate dll before w2k */
hlocalmon
=
LoadLibraryA
(
"localmon.dll"
);
hlocalmon
=
LoadLibraryA
(
"localmon.dll"
);
...
@@ -501,7 +512,6 @@ START_TEST(localmon)
...
@@ -501,7 +512,6 @@ START_TEST(localmon)
or InitializePrintMonitor fails. */
or InitializePrintMonitor fails. */
pm
=
pInitializePrintMonitor
(
Monitors_LocalPortW
);
pm
=
pInitializePrintMonitor
(
Monitors_LocalPortW
);
if
(
pm
)
{
if
(
pm
)
{
DWORD
numentries
;
numentries
=
(
pm
->
dwMonitorSize
)
/
sizeof
(
VOID
*
);
numentries
=
(
pm
->
dwMonitorSize
)
/
sizeof
(
VOID
*
);
/* NT4: 14, since w2k: 17 */
/* NT4: 14, since w2k: 17 */
ok
(
numentries
==
14
||
numentries
==
17
,
ok
(
numentries
==
14
||
numentries
==
17
,
...
@@ -525,6 +535,38 @@ START_TEST(localmon)
...
@@ -525,6 +535,38 @@ START_TEST(localmon)
GET_MONITOR_FUNC
(
XcvDataPort
);
GET_MONITOR_FUNC
(
XcvDataPort
);
GET_MONITOR_FUNC
(
XcvClosePort
);
GET_MONITOR_FUNC
(
XcvClosePort
);
}
}
if
((
!
pInitializePrintMonitorUI
)
&&
(
pXcvOpenPort
)
&&
(
pXcvDataPort
)
&&
(
pXcvClosePort
))
{
/* The user interface for "Local Ports" is in a separate dll since w2k */
BYTE
buffer
[
MAX_PATH
];
DWORD
res
;
DWORD
len
;
HANDLE
hXcv
;
res
=
pXcvOpenPort
(
emptyW
,
SERVER_ACCESS_ADMINISTER
,
&
hXcv
);
if
(
res
)
{
res
=
pXcvDataPort
(
hXcv
,
cmd_MonitorUIW
,
NULL
,
0
,
buffer
,
MAX_PATH
,
&
len
);
if
(
res
==
ERROR_SUCCESS
)
hlocalui
=
LoadLibraryW
(
(
LPWSTR
)
buffer
);
if
(
hlocalui
)
pInitializePrintMonitorUI
=
(
void
*
)
GetProcAddress
(
hlocalui
,
"InitializePrintMonitorUI"
);
pXcvClosePort
(
hXcv
);
}
}
if
(
pInitializePrintMonitorUI
)
{
pui
=
pInitializePrintMonitorUI
();
if
(
pui
)
{
numentries
=
(
pui
->
dwMonitorUISize
-
sizeof
(
DWORD
))
/
sizeof
(
VOID
*
);
ok
(
numentries
==
3
,
"dwMonitorUISize (%d) => %d Functions
\n
"
,
pui
->
dwMonitorUISize
,
numentries
);
if
(
numentries
>
2
)
{
pAddPortUI
=
pui
->
pfnAddPortUI
;
pConfigurePortUI
=
pui
->
pfnConfigurePortUI
;
pDeletePortUI
=
pui
->
pfnDeletePortUI
;
}
}
}
test_InitializePrintMonitor
();
test_InitializePrintMonitor
();
test_AddPort
();
test_AddPort
();
...
...
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