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
ac58c3e8
Commit
ac58c3e8
authored
Mar 05, 2014
by
Jacek Caban
Committed by
Alexandre Julliard
Mar 05, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wininet: Renamed read_mode_t to blocking_mode_t.
parent
c4ae0298
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
33 additions
and
33 deletions
+33
-33
http.c
dlls/wininet/http.c
+33
-33
No files found.
dlls/wininet/http.c
View file @
ac58c3e8
...
...
@@ -380,15 +380,15 @@ static LPHTTPHEADERW HTTP_GetHeader(http_request_t *req, LPCWSTR head)
}
typedef
enum
{
READMODE_SYNC
,
READMODE_ASYNC
,
READMODE_NOBLOCK
}
read
_mode_t
;
BLOCKING_ALLOW
,
BLOCKING_DISALLOW
,
BLOCKING_WAITALL
}
blocking
_mode_t
;
struct
data_stream_vtbl_t
{
DWORD
(
*
get_avail_data
)(
data_stream_t
*
,
http_request_t
*
);
BOOL
(
*
end_of_data
)(
data_stream_t
*
,
http_request_t
*
);
DWORD
(
*
read
)(
data_stream_t
*
,
http_request_t
*
,
BYTE
*
,
DWORD
,
DWORD
*
,
read
_mode_t
);
DWORD
(
*
read
)(
data_stream_t
*
,
http_request_t
*
,
BYTE
*
,
DWORD
,
DWORD
*
,
blocking
_mode_t
);
BOOL
(
*
drain_content
)(
data_stream_t
*
,
http_request_t
*
);
void
(
*
destroy
)(
data_stream_t
*
);
};
...
...
@@ -441,7 +441,7 @@ static BOOL gzip_end_of_data(data_stream_t *stream, http_request_t *req)
}
static
DWORD
gzip_read
(
data_stream_t
*
stream
,
http_request_t
*
req
,
BYTE
*
buf
,
DWORD
size
,
DWORD
*
read
,
read_mode_t
read
_mode
)
DWORD
*
read
,
blocking_mode_t
blocking
_mode
)
{
gzip_stream_t
*
gzip_stream
=
(
gzip_stream_t
*
)
stream
;
z_stream
*
zstream
=
&
gzip_stream
->
zstream
;
...
...
@@ -460,13 +460,13 @@ static DWORD gzip_read(data_stream_t *stream, http_request_t *req, BYTE *buf, DW
gzip_stream
->
buf_pos
=
0
;
}
res
=
gzip_stream
->
parent_stream
->
vtbl
->
read
(
gzip_stream
->
parent_stream
,
req
,
gzip_stream
->
buf
+
gzip_stream
->
buf_size
,
sizeof
(
gzip_stream
->
buf
)
-
gzip_stream
->
buf_size
,
&
current_read
,
read
_mode
);
sizeof
(
gzip_stream
->
buf
)
-
gzip_stream
->
buf_size
,
&
current_read
,
blocking
_mode
);
gzip_stream
->
buf_size
+=
current_read
;
if
(
res
!=
ERROR_SUCCESS
)
break
;
end
=
gzip_stream
->
parent_stream
->
vtbl
->
end_of_data
(
gzip_stream
->
parent_stream
,
req
);
if
(
!
current_read
&&
!
end
)
{
if
(
read_mode
!=
READMODE_NOBLOCK
)
{
if
(
blocking_mode
!=
BLOCKING_DISALLOW
)
{
WARN
(
"unexpected end of data
\n
"
);
gzip_stream
->
end_of_data
=
TRUE
;
}
...
...
@@ -497,8 +497,8 @@ static DWORD gzip_read(data_stream_t *stream, http_request_t *req, BYTE *buf, DW
break
;
}
if
(
ret_read
&&
read_mode
==
READMODE_ASYNC
)
read_mode
=
READMODE_NOBLOCK
;
if
(
ret_read
&&
blocking_mode
==
BLOCKING_ALLOW
)
blocking_mode
=
BLOCKING_DISALLOW
;
}
TRACE
(
"read %u bytes
\n
"
,
ret_read
);
...
...
@@ -2566,11 +2566,11 @@ static BOOL end_of_read_data( http_request_t *req )
return
!
req
->
read_size
&&
req
->
data_stream
->
vtbl
->
end_of_data
(
req
->
data_stream
,
req
);
}
static
DWORD
read_http_stream
(
http_request_t
*
req
,
BYTE
*
buf
,
DWORD
size
,
DWORD
*
read
,
read_mode_t
read
_mode
)
static
DWORD
read_http_stream
(
http_request_t
*
req
,
BYTE
*
buf
,
DWORD
size
,
DWORD
*
read
,
blocking_mode_t
blocking
_mode
)
{
DWORD
res
;
res
=
req
->
data_stream
->
vtbl
->
read
(
req
->
data_stream
,
req
,
buf
,
size
,
read
,
read
_mode
);
res
=
req
->
data_stream
->
vtbl
->
read
(
req
->
data_stream
,
req
,
buf
,
size
,
read
,
blocking
_mode
);
assert
(
*
read
<=
size
);
if
(
req
->
hCacheFile
)
{
...
...
@@ -2591,7 +2591,7 @@ static DWORD read_http_stream(http_request_t *req, BYTE *buf, DWORD size, DWORD
}
/* fetch some more data into the read buffer (the read section must be held) */
static
DWORD
refill_read_buffer
(
http_request_t
*
req
,
read_mode_t
read
_mode
,
DWORD
*
read_bytes
)
static
DWORD
refill_read_buffer
(
http_request_t
*
req
,
blocking_mode_t
blocking
_mode
,
DWORD
*
read_bytes
)
{
DWORD
res
,
read
=
0
;
...
...
@@ -2605,7 +2605,7 @@ static DWORD refill_read_buffer(http_request_t *req, read_mode_t read_mode, DWOR
}
res
=
read_http_stream
(
req
,
req
->
read_buf
+
req
->
read_size
,
sizeof
(
req
->
read_buf
)
-
req
->
read_size
,
&
read
,
read
_mode
);
&
read
,
blocking
_mode
);
req
->
read_size
+=
read
;
TRACE
(
"read %u bytes, read_size %u
\n
"
,
read
,
req
->
read_size
);
...
...
@@ -2639,7 +2639,7 @@ static BOOL netconn_end_of_data(data_stream_t *stream, http_request_t *req)
}
static
DWORD
netconn_read
(
data_stream_t
*
stream
,
http_request_t
*
req
,
BYTE
*
buf
,
DWORD
size
,
DWORD
*
read
,
read_mode_t
read
_mode
)
DWORD
*
read
,
blocking_mode_t
blocking
_mode
)
{
netconn_stream_t
*
netconn_stream
=
(
netconn_stream_t
*
)
stream
;
DWORD
res
=
ERROR_SUCCESS
;
...
...
@@ -2647,14 +2647,14 @@ static DWORD netconn_read(data_stream_t *stream, http_request_t *req, BYTE *buf,
size
=
min
(
size
,
netconn_stream
->
content_length
-
netconn_stream
->
content_read
);
if
(
read_mode
==
READMODE_NOBLOCK
)
{
if
(
blocking_mode
==
BLOCKING_DISALLOW
)
{
DWORD
avail
=
netconn_get_avail_data
(
stream
,
req
);
if
(
size
>
avail
)
size
=
avail
;
}
if
(
size
&&
is_valid_netconn
(
req
->
netconn
))
{
if
((
res
=
NETCON_recv
(
req
->
netconn
,
buf
,
size
,
read_mode
==
READMODE_SYNC
?
MSG_WAITALL
:
0
,
&
len
)))
if
((
res
=
NETCON_recv
(
req
->
netconn
,
buf
,
size
,
blocking_mode
==
BLOCKING_WAITALL
?
MSG_WAITALL
:
0
,
&
len
)))
len
=
0
;
if
(
!
len
)
netconn_stream
->
content_length
=
netconn_stream
->
content_read
;
...
...
@@ -2808,7 +2808,7 @@ static BOOL chunked_end_of_data(data_stream_t *stream, http_request_t *req)
}
static
DWORD
chunked_read
(
data_stream_t
*
stream
,
http_request_t
*
req
,
BYTE
*
buf
,
DWORD
size
,
DWORD
*
read
,
read_mode_t
read
_mode
)
DWORD
*
read
,
blocking_mode_t
blocking
_mode
)
{
chunked_stream_t
*
chunked_stream
=
(
chunked_stream_t
*
)
stream
;
DWORD
read_bytes
=
0
,
ret_read
=
0
,
res
=
ERROR_SUCCESS
;
...
...
@@ -2824,7 +2824,7 @@ static DWORD chunked_read(data_stream_t *stream, http_request_t *req, BYTE *buf,
read_bytes
=
min
(
size
,
min
(
chunked_stream
->
buf_size
,
chunked_stream
->
chunk_size
));
/* this could block */
if
(
read_mode
==
READMODE_NOBLOCK
&&
read_bytes
==
chunked_stream
->
chunk_size
)
if
(
blocking_mode
==
BLOCKING_DISALLOW
&&
read_bytes
==
chunked_stream
->
chunk_size
)
break
;
memcpy
(
buf
+
ret_read
,
chunked_stream
->
buf
+
chunked_stream
->
buf_pos
,
read_bytes
);
...
...
@@ -2832,7 +2832,7 @@ static DWORD chunked_read(data_stream_t *stream, http_request_t *req, BYTE *buf,
}
else
{
read_bytes
=
min
(
size
,
chunked_stream
->
chunk_size
);
if
(
read_mode
==
READMODE_NOBLOCK
)
{
if
(
blocking_mode
==
BLOCKING_DISALLOW
)
{
DWORD
avail
;
if
(
!
is_valid_netconn
(
req
->
netconn
)
||
!
NETCON_query_data_available
(
req
->
netconn
,
&
avail
)
||
!
avail
)
...
...
@@ -2854,14 +2854,14 @@ static DWORD chunked_read(data_stream_t *stream, http_request_t *req, BYTE *buf,
size
-=
read_bytes
;
ret_read
+=
read_bytes
;
if
(
size
&&
!
chunked_stream
->
chunk_size
)
{
assert
(
read_mode
!=
READMODE_NOBLOCK
);
assert
(
blocking_mode
!=
BLOCKING_DISALLOW
);
res
=
start_next_chunk
(
chunked_stream
,
req
);
if
(
res
!=
ERROR_SUCCESS
)
break
;
}
if
(
read_mode
==
READMODE_ASYNC
)
read_mode
=
READMODE_NOBLOCK
;
if
(
blocking_mode
==
BLOCKING_ALLOW
)
blocking_mode
=
BLOCKING_DISALLOW
;
}
TRACE
(
"read %u bytes
\n
"
,
ret_read
);
...
...
@@ -2965,20 +2965,20 @@ static void send_request_complete(http_request_t *req, DWORD_PTR result, DWORD e
static
void
HTTP_ReceiveRequestData
(
http_request_t
*
req
,
BOOL
first_notif
,
DWORD
*
ret_size
)
{
DWORD
res
,
read
=
0
,
avail
=
0
;
read
_mode_t
mode
;
blocking
_mode_t
mode
;
TRACE
(
"%p
\n
"
,
req
);
EnterCriticalSection
(
&
req
->
read_section
);
mode
=
first_notif
&&
req
->
read_size
?
READMODE_NOBLOCK
:
READMODE_ASYNC
;
mode
=
first_notif
&&
req
->
read_size
?
BLOCKING_DISALLOW
:
BLOCKING_ALLOW
;
res
=
refill_read_buffer
(
req
,
mode
,
&
read
);
if
(
res
==
ERROR_SUCCESS
)
avail
=
get_avail_data
(
req
);
LeaveCriticalSection
(
&
req
->
read_section
);
if
(
res
!=
ERROR_SUCCESS
||
(
mode
!=
READMODE_NOBLOCK
&&
!
read
))
{
if
(
res
!=
ERROR_SUCCESS
||
(
mode
!=
BLOCKING_DISALLOW
&&
!
read
))
{
WARN
(
"res %u read %u, closing connection
\n
"
,
res
,
read
);
http_release_netconn
(
req
,
FALSE
);
}
...
...
@@ -3000,10 +3000,10 @@ static void HTTP_ReceiveRequestData(http_request_t *req, BOOL first_notif, DWORD
static
DWORD
HTTPREQ_Read
(
http_request_t
*
req
,
void
*
buffer
,
DWORD
size
,
DWORD
*
read
,
BOOL
sync
)
{
DWORD
current_read
=
0
,
ret_read
=
0
;
read_mode_t
read
_mode
;
blocking_mode_t
blocking
_mode
;
DWORD
res
=
ERROR_SUCCESS
;
read_mode
=
req
->
session
->
appInfo
->
hdr
.
dwFlags
&
INTERNET_FLAG_ASYNC
?
READMODE_ASYNC
:
READMODE_SYNC
;
blocking_mode
=
req
->
session
->
appInfo
->
hdr
.
dwFlags
&
INTERNET_FLAG_ASYNC
?
BLOCKING_ALLOW
:
BLOCKING_WAITALL
;
EnterCriticalSection
(
&
req
->
read_section
);
...
...
@@ -3012,12 +3012,12 @@ static DWORD HTTPREQ_Read(http_request_t *req, void *buffer, DWORD size, DWORD *
memcpy
(
buffer
,
req
->
read_buf
+
req
->
read_pos
,
ret_read
);
req
->
read_size
-=
ret_read
;
req
->
read_pos
+=
ret_read
;
if
(
read_mode
==
READMODE_ASYNC
)
read_mode
=
READMODE_NOBLOCK
;
if
(
blocking_mode
==
BLOCKING_ALLOW
)
blocking_mode
=
BLOCKING_DISALLOW
;
}
if
(
ret_read
<
size
)
{
res
=
read_http_stream
(
req
,
(
BYTE
*
)
buffer
+
ret_read
,
size
-
ret_read
,
&
current_read
,
read
_mode
);
res
=
read_http_stream
(
req
,
(
BYTE
*
)
buffer
+
ret_read
,
size
-
ret_read
,
&
current_read
,
blocking
_mode
);
ret_read
+=
current_read
;
}
...
...
@@ -3224,7 +3224,7 @@ static DWORD HTTPREQ_QueryDataAvailable(object_header_t *hdr, DWORD *available,
/* never wait, if we can't enter the section we queue an async request right away */
if
(
TryEnterCriticalSection
(
&
req
->
read_section
))
{
refill_read_buffer
(
req
,
READMODE_NOBLOCK
,
NULL
);
refill_read_buffer
(
req
,
BLOCKING_DISALLOW
,
NULL
);
if
((
*
available
=
get_avail_data
(
req
)))
goto
done
;
if
(
end_of_read_data
(
req
))
goto
done
;
LeaveCriticalSection
(
&
req
->
read_section
);
...
...
@@ -3240,7 +3240,7 @@ static DWORD HTTPREQ_QueryDataAvailable(object_header_t *hdr, DWORD *available,
if
(
!
(
*
available
=
get_avail_data
(
req
))
&&
!
end_of_read_data
(
req
))
{
refill_read_buffer
(
req
,
READMODE_ASYNC
,
NULL
);
refill_read_buffer
(
req
,
BLOCKING_ALLOW
,
NULL
);
*
available
=
get_avail_data
(
req
);
}
...
...
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