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
72c8b283
Commit
72c8b283
authored
Oct 06, 2010
by
Jacek Caban
Committed by
Alexandre Julliard
Oct 07, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
urlmon: Added IInternetProtocolEx support to http protocol handler.
parent
8205f627
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
88 additions
and
44 deletions
+88
-44
http.c
dlls/urlmon/http.c
+60
-39
protocol.c
dlls/urlmon/tests/protocol.c
+28
-5
No files found.
dlls/urlmon/http.c
View file @
72c8b283
This diff is collapsed.
Click to expand it.
dlls/urlmon/tests/protocol.c
View file @
72c8b283
...
@@ -2149,6 +2149,7 @@ static IClassFactory mimefilter_cf = { &MimeFilterCFVtbl };
...
@@ -2149,6 +2149,7 @@ static IClassFactory mimefilter_cf = { &MimeFilterCFVtbl };
#define TEST_REDIRECT 0x0080
#define TEST_REDIRECT 0x0080
#define TEST_ABORT 0x0100
#define TEST_ABORT 0x0100
#define TEST_ASYNCREQ 0x0200
#define TEST_ASYNCREQ 0x0200
#define TEST_USEIURI 0x0400
static
void
init_test
(
int
prot
,
DWORD
flags
)
static
void
init_test
(
int
prot
,
DWORD
flags
)
{
{
...
@@ -2565,11 +2566,17 @@ static void test_file_protocol(void) {
...
@@ -2565,11 +2566,17 @@ static void test_file_protocol(void) {
test_file_protocol_fail
();
test_file_protocol_fail
();
}
}
static
BOOL
http_protocol_start
(
LPCWSTR
url
)
static
BOOL
http_protocol_start
(
LPCWSTR
url
,
BOOL
use_iuri
)
{
{
static
BOOL
got_user_agent
=
FALSE
;
static
BOOL
got_user_agent
=
FALSE
;
IUri
*
uri
=
NULL
;
HRESULT
hres
;
HRESULT
hres
;
if
(
use_iuri
&&
pCreateUri
)
{
hres
=
pCreateUri
(
url
,
0
,
0
,
&
uri
);
ok
(
hres
==
S_OK
,
"CreateUri failed: %08x
\n
"
,
hres
);
}
SET_EXPECT
(
GetBindInfo
);
SET_EXPECT
(
GetBindInfo
);
if
(
!
(
bindf
&
BINDF_FROMURLMON
))
if
(
!
(
bindf
&
BINDF_FROMURLMON
))
SET_EXPECT
(
ReportProgress_DIRECTBIND
);
SET_EXPECT
(
ReportProgress_DIRECTBIND
);
...
@@ -2585,8 +2592,21 @@ static BOOL http_protocol_start(LPCWSTR url)
...
@@ -2585,8 +2592,21 @@ static BOOL http_protocol_start(LPCWSTR url)
SET_EXPECT
(
Stream_Seek
);
SET_EXPECT
(
Stream_Seek
);
}
}
hres
=
IInternetProtocol_Start
(
async_protocol
,
url
,
&
protocol_sink
,
&
bind_info
,
0
,
0
);
if
(
uri
)
{
ok
(
hres
==
S_OK
,
"Start failed: %08x
\n
"
,
hres
);
IInternetProtocolEx
*
protocolex
;
hres
=
IInternetProtocol_QueryInterface
(
async_protocol
,
&
IID_IInternetProtocolEx
,
(
void
**
)
&
protocolex
);
ok
(
hres
==
S_OK
,
"Could not get IInternetProtocolEx iface: %08x
\n
"
,
hres
);
hres
=
IInternetProtocolEx_StartEx
(
protocolex
,
uri
,
&
protocol_sink
,
&
bind_info
,
0
,
0
);
ok
(
hres
==
S_OK
,
"Start failed: %08x
\n
"
,
hres
);
IInternetProtocolEx_Release
(
protocolex
);
IUri_Release
(
uri
);
}
else
{
hres
=
IInternetProtocol_Start
(
async_protocol
,
url
,
&
protocol_sink
,
&
bind_info
,
0
,
0
);
ok
(
hres
==
S_OK
,
"Start failed: %08x
\n
"
,
hres
);
}
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
FALSE
;
return
FALSE
;
...
@@ -2714,7 +2734,7 @@ static void test_http_protocol_url(LPCWSTR url, int prot, DWORD flags, DWORD tym
...
@@ -2714,7 +2734,7 @@ static void test_http_protocol_url(LPCWSTR url, int prot, DWORD flags, DWORD tym
SET_EXPECT
(
Switch
);
SET_EXPECT
(
Switch
);
}
}
if
(
!
http_protocol_start
(
url
))
if
(
!
http_protocol_start
(
url
,
(
flags
&
TEST_USEIURI
)
!=
0
))
return
;
return
;
if
(
!
direct_read
&&
!
test_abort
)
if
(
!
direct_read
&&
!
test_abort
)
...
@@ -2837,7 +2857,7 @@ static void test_http_protocol(void)
...
@@ -2837,7 +2857,7 @@ static void test_http_protocol(void)
trace
(
"Testing http protocol (direct read)...
\n
"
);
trace
(
"Testing http protocol (direct read)...
\n
"
);
bindf
=
BINDF_ASYNCHRONOUS
|
BINDF_ASYNCSTORAGE
|
BINDF_PULLDATA
|
BINDF_FROMURLMON
;
bindf
=
BINDF_ASYNCHRONOUS
|
BINDF_ASYNCSTORAGE
|
BINDF_PULLDATA
|
BINDF_FROMURLMON
;
test_http_protocol_url
(
winehq_url
,
HTTP_TEST
,
TEST_DIRECT_READ
,
TYMED_NULL
);
test_http_protocol_url
(
winehq_url
,
HTTP_TEST
,
TEST_DIRECT_READ
|
TEST_USEIURI
,
TYMED_NULL
);
trace
(
"Testing http protocol (redirected)...
\n
"
);
trace
(
"Testing http protocol (redirected)...
\n
"
);
bindf
=
BINDF_ASYNCHRONOUS
|
BINDF_ASYNCSTORAGE
|
BINDF_PULLDATA
|
BINDF_FROMURLMON
;
bindf
=
BINDF_ASYNCHRONOUS
|
BINDF_ASYNCSTORAGE
|
BINDF_PULLDATA
|
BINDF_FROMURLMON
;
...
@@ -3376,6 +3396,9 @@ START_TEST(protocol)
...
@@ -3376,6 +3396,9 @@ START_TEST(protocol)
return
;
return
;
}
}
if
(
!
pCreateUri
)
win_skip
(
"CreateUri not supported
\n
"
);
OleInitialize
(
NULL
);
OleInitialize
(
NULL
);
event_complete
=
CreateEvent
(
NULL
,
FALSE
,
FALSE
,
NULL
);
event_complete
=
CreateEvent
(
NULL
,
FALSE
,
FALSE
,
NULL
);
...
...
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