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
cf2a3af6
Commit
cf2a3af6
authored
Apr 02, 2010
by
Andrew Eikum
Committed by
Alexandre Julliard
Apr 05, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mshtml: Implement HTTPChannel::GetResponseHeader.
parent
f40682eb
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
110 additions
and
6 deletions
+110
-6
mshtml_private.h
dlls/mshtml/mshtml_private.h
+7
-0
navigate.c
dlls/mshtml/navigate.c
+66
-4
nsio.c
dlls/mshtml/nsio.c
+37
-2
No files found.
dlls/mshtml/mshtml_private.h
View file @
cf2a3af6
...
...
@@ -463,9 +463,16 @@ typedef struct {
char
*
content_type
;
char
*
charset
;
PRUint32
response_status
;
struct
list
response_headers
;
UINT
url_scheme
;
}
nsChannel
;
struct
ResponseHeader
{
struct
list
entry
;
WCHAR
*
header
;
WCHAR
*
data
;
};
typedef
struct
{
HRESULT
(
*
qi
)(
HTMLDOMNode
*
,
REFIID
,
void
**
);
void
(
*
destructor
)(
HTMLDOMNode
*
);
...
...
dlls/mshtml/navigate.c
View file @
cf2a3af6
...
...
@@ -62,7 +62,7 @@ typedef struct {
HRESULT
(
*
stop_binding
)(
BSCallback
*
,
HRESULT
);
HRESULT
(
*
read_data
)(
BSCallback
*
,
IStream
*
);
HRESULT
(
*
on_progress
)(
BSCallback
*
,
ULONG
,
LPCWSTR
);
HRESULT
(
*
on_response
)(
BSCallback
*
,
DWORD
);
HRESULT
(
*
on_response
)(
BSCallback
*
,
DWORD
,
LPCWSTR
);
}
BSCallbackVtbl
;
struct
BSCallback
{
...
...
@@ -493,7 +493,7 @@ static HRESULT WINAPI HttpNegotiate_OnResponse(IHttpNegotiate2 *iface, DWORD dwR
TRACE
(
"(%p)->(%d %s %s %p)
\n
"
,
This
,
dwResponseCode
,
debugstr_w
(
szResponseHeaders
),
debugstr_w
(
szRequestHeaders
),
pszAdditionalRequestHeaders
);
return
This
->
vtbl
->
on_response
(
This
,
dwResponseCode
);
return
This
->
vtbl
->
on_response
(
This
,
dwResponseCode
,
szResponseHeaders
);
}
static
HRESULT
WINAPI
HttpNegotiate_GetRootSecurityId
(
IHttpNegotiate2
*
iface
,
...
...
@@ -825,7 +825,8 @@ static HRESULT BufferBSC_on_progress(BSCallback *bsc, ULONG status_code, LPCWSTR
return
S_OK
;
}
static
HRESULT
BufferBSC_on_response
(
BSCallback
*
bsc
,
DWORD
response_code
)
static
HRESULT
BufferBSC_on_response
(
BSCallback
*
bsc
,
DWORD
response_code
,
LPCWSTR
response_headers
)
{
return
S_OK
;
}
...
...
@@ -1099,11 +1100,72 @@ static HRESULT nsChannelBSC_on_progress(BSCallback *bsc, ULONG status_code, LPCW
return
S_OK
;
}
static
HRESULT
nsChannelBSC_on_response
(
BSCallback
*
bsc
,
DWORD
response_code
)
static
HRESULT
nsChannelBSC_on_response
(
BSCallback
*
bsc
,
DWORD
response_code
,
LPCWSTR
response_headers
)
{
nsChannelBSC
*
This
=
NSCHANNELBSC_THIS
(
bsc
);
This
->
nschannel
->
response_status
=
response_code
;
if
(
response_headers
)
{
const
WCHAR
*
hdr_start
,
*
hdr_end
;
hdr_start
=
strchrW
(
response_headers
,
'\r'
);
while
(
hdr_start
)
{
const
WCHAR
*
colon
;
struct
ResponseHeader
*
new_header
;
int
len
;
hdr_start
+=
2
;
hdr_end
=
strchrW
(
hdr_start
,
'\r'
);
if
(
!
hdr_end
)
{
WARN
(
"Header doesn't end with CRLF: %s
\n
"
,
wine_dbgstr_w
(
hdr_start
));
break
;
}
if
(
hdr_end
==
hdr_start
)
break
;
for
(
colon
=
hdr_start
;
*
colon
!=
':'
&&
colon
!=
hdr_end
;
++
colon
);
if
(
*
colon
!=
':'
)
{
WARN
(
"Header missing colon: %s
\n
"
,
wine_dbgstr_w
(
hdr_start
));
hdr_start
=
strchrW
(
hdr_start
,
'\r'
);
continue
;
}
new_header
=
heap_alloc
(
sizeof
(
struct
ResponseHeader
));
if
(
!
new_header
)
return
E_OUTOFMEMORY
;
len
=
colon
-
hdr_start
;
new_header
->
header
=
heap_alloc
((
len
+
1
)
*
sizeof
(
WCHAR
));
if
(
!
new_header
->
header
)
{
heap_free
(
new_header
);
return
E_OUTOFMEMORY
;
}
memcpy
(
new_header
->
header
,
hdr_start
,
len
*
sizeof
(
WCHAR
));
new_header
->
header
[
len
]
=
0
;
colon
++
;
while
(
*
colon
==
' '
)
colon
++
;
len
=
hdr_end
-
colon
;
new_header
->
data
=
heap_alloc
((
len
+
1
)
*
sizeof
(
WCHAR
));
if
(
!
new_header
->
data
)
{
heap_free
(
new_header
->
header
);
heap_free
(
new_header
);
return
E_OUTOFMEMORY
;
}
memcpy
(
new_header
->
data
,
colon
,
len
*
sizeof
(
WCHAR
));
new_header
->
data
[
len
]
=
0
;
list_add_head
(
&
This
->
nschannel
->
response_headers
,
&
new_header
->
entry
);
TRACE
(
"Adding header to list: (%s):(%s)
\n
"
,
wine_dbgstr_w
(
new_header
->
header
),
wine_dbgstr_w
(
new_header
->
data
));
hdr_start
=
strchrW
(
hdr_start
,
'\r'
);
}
}
return
S_OK
;
}
...
...
dlls/mshtml/nsio.c
View file @
cf2a3af6
...
...
@@ -363,6 +363,8 @@ static nsrefcnt NSAPI nsChannel_Release(nsIHttpChannel *iface)
LONG
ref
=
InterlockedDecrement
(
&
This
->
ref
);
if
(
!
ref
)
{
struct
ResponseHeader
*
header
,
*
next_hdr
;
nsIURI_Release
(
NSURI
(
This
->
uri
));
if
(
This
->
owner
)
nsISupports_Release
(
This
->
owner
);
...
...
@@ -376,6 +378,14 @@ static nsrefcnt NSAPI nsChannel_Release(nsIHttpChannel *iface)
nsIURI_Release
(
This
->
original_uri
);
heap_free
(
This
->
content_type
);
heap_free
(
This
->
charset
);
LIST_FOR_EACH_ENTRY_SAFE
(
header
,
next_hdr
,
&
This
->
response_headers
,
struct
ResponseHeader
,
entry
)
{
list_remove
(
&
header
->
entry
);
heap_free
(
header
->
header
);
heap_free
(
header
->
data
);
heap_free
(
header
);
}
heap_free
(
This
);
}
...
...
@@ -1066,10 +1076,34 @@ static nsresult NSAPI nsChannel_GetResponseHeader(nsIHttpChannel *iface,
const
nsACString
*
header
,
nsACString
*
_retval
)
{
nsChannel
*
This
=
NSCHANNEL_THIS
(
iface
);
const
char
*
header_str
;
WCHAR
*
header_wstr
;
struct
ResponseHeader
*
this_header
;
FIXME
(
"(%p)->(%p %p)
\n
"
,
This
,
header
,
_retval
);
nsACString_GetData
(
header
,
&
header_str
);
TRACE
(
"(%p)->(%p(%s) %p)
\n
"
,
This
,
header
,
header_str
,
_retval
);
return
NS_ERROR_NOT_IMPLEMENTED
;
header_wstr
=
heap_strdupAtoW
(
header_str
);
if
(
!
header_wstr
)
return
NS_ERROR_UNEXPECTED
;
LIST_FOR_EACH_ENTRY
(
this_header
,
&
This
->
response_headers
,
struct
ResponseHeader
,
entry
)
{
if
(
!
strcmpW
(
this_header
->
header
,
header_wstr
))
{
char
*
data
=
heap_strdupWtoA
(
this_header
->
data
);
if
(
!
data
)
{
heap_free
(
header_wstr
);
return
NS_ERROR_UNEXPECTED
;
}
nsACString_SetData
(
_retval
,
data
);
heap_free
(
data
);
heap_free
(
header_wstr
);
return
NS_OK
;
}
}
heap_free
(
header_wstr
);
return
NS_ERROR_NOT_AVAILABLE
;
}
static
nsresult
NSAPI
nsChannel_SetResponseHeader
(
nsIHttpChannel
*
iface
,
...
...
@@ -2521,6 +2555,7 @@ static nsresult NSAPI nsIOService_NewChannelFromURI(nsIIOService *iface, nsIURI
ret
->
lpIHttpChannelInternalVtbl
=
&
nsHttpChannelInternalVtbl
;
ret
->
ref
=
1
;
ret
->
uri
=
wine_uri
;
list_init
(
&
ret
->
response_headers
);
nsIURI_AddRef
(
aURI
);
ret
->
original_uri
=
aURI
;
...
...
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