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
a546e8ac
Commit
a546e8ac
authored
Mar 09, 2017
by
Jacek Caban
Committed by
Alexandre Julliard
Mar 10, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wininet: Reimplemented InternetQueryDataAvailable on top of async_read.
Signed-off-by:
Jacek Caban
<
jacek@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
08808747
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
41 additions
and
37 deletions
+41
-37
http.c
dlls/wininet/http.c
+41
-37
No files found.
dlls/wininet/http.c
View file @
a546e8ac
...
...
@@ -3285,56 +3285,60 @@ static DWORD HTTPREQ_ReadFile(object_header_t *hdr, void *buffer, DWORD size, DW
return
res
;
}
typedef
struct
{
task_header_t
hdr
;
DWORD
*
ret_size
;
}
http_data_available_task_t
;
static
void
AsyncQueryDataAvailableProc
(
task_header_t
*
hdr
)
{
http_data_available_task_t
*
task
=
(
http_data_available_task_t
*
)
hdr
;
HTTP_ReceiveRequestData
((
http_request_t
*
)
task
->
hdr
.
hdr
,
FALSE
,
task
->
ret_size
);
}
static
DWORD
HTTPREQ_QueryDataAvailable
(
object_header_t
*
hdr
,
DWORD
*
available
,
DWORD
flags
,
DWORD_PTR
ctx
)
{
http_request_t
*
req
=
(
http_request_t
*
)
hdr
;
DWORD
res
=
ERROR_SUCCESS
,
avail
=
0
,
error
=
ERROR_SUCCESS
;
BOOL
allow_blocking
,
notify_received
=
FALSE
;
TRACE
(
"(%p %p %x %lx)
\n
"
,
req
,
available
,
flags
,
ctx
);
if
(
req
->
session
->
appInfo
->
hdr
.
dwFlags
&
INTERNET_FLAG_ASYNC
)
{
http_data_available_task_t
*
task
;
if
(
flags
&
~
(
IRF_ASYNC
|
IRF_NO_WAIT
))
FIXME
(
"these dwFlags aren't implemented: 0x%x
\n
"
,
flags
&
~
(
IRF_ASYNC
|
IRF_NO_WAIT
));
/* 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
,
BLOCKING_DISALLOW
,
NULL
);
if
((
*
available
=
get_avail_data
(
req
)))
goto
done
;
if
(
end_of_read_data
(
req
))
goto
done
;
LeaveCriticalSection
(
&
req
->
read_section
);
}
*
available
=
0
;
allow_blocking
=
!
(
req
->
session
->
appInfo
->
hdr
.
dwFlags
&
INTERNET_FLAG_ASYNC
);
task
=
alloc_async_task
(
&
req
->
hdr
,
AsyncQueryDataAvailableProc
,
sizeof
(
*
task
));
task
->
ret_size
=
available
;
INTERNET_AsyncCall
(
&
task
->
hdr
);
return
ERROR_IO_PENDING
;
}
if
(
allow_blocking
||
TryEnterCriticalSection
(
&
req
->
read_section
))
{
if
(
allow_blocking
)
EnterCriticalSection
(
&
req
->
read_section
);
if
(
hdr
->
dwError
==
ERROR_SUCCESS
)
hdr
->
dwError
=
INTERNET_HANDLE_IN_USE
;
else
if
(
hdr
->
dwError
==
INTERNET_HANDLE_IN_USE
)
hdr
->
dwError
=
ERROR_INTERNET_INTERNAL_ERROR
;
EnterCriticalSection
(
&
req
->
read_section
)
;
avail
=
req
->
read_size
;
if
(
!
(
*
available
=
get_avail_data
(
req
))
&&
!
end_of_read_data
(
req
))
{
refill_read_buffer
(
req
,
BLOCKING_ALLOW
,
NULL
);
*
available
=
get_avail_data
(
req
);
if
(
!
avail
&&
!
end_of_read_data
(
req
))
{
LeaveCriticalSection
(
&
req
->
read_section
);
INTERNET_SendCallback
(
&
req
->
hdr
,
req
->
hdr
.
dwContext
,
INTERNET_STATUS_RECEIVING_RESPONSE
,
NULL
,
0
);
EnterCriticalSection
(
&
req
->
read_section
);
notify_received
=
TRUE
;
res
=
refill_read_buffer
(
req
,
allow_blocking
?
BLOCKING_ALLOW
:
BLOCKING_DISALLOW
,
&
avail
);
}
if
(
hdr
->
dwError
==
INTERNET_HANDLE_IN_USE
)
hdr
->
dwError
=
ERROR_SUCCESS
;
else
error
=
hdr
->
dwError
;
LeaveCriticalSection
(
&
req
->
read_section
);
}
else
{
res
=
WSAEWOULDBLOCK
;
}
done:
LeaveCriticalSection
(
&
req
->
read_section
);
if
(
res
==
WSAEWOULDBLOCK
)
return
async_read
(
req
,
NULL
,
0
,
0
,
available
);
TRACE
(
"returning %u
\n
"
,
*
available
);
return
ERROR_SUCCESS
;
if
(
res
!=
ERROR_SUCCESS
)
return
res
;
*
available
=
avail
;
if
(
notify_received
)
INTERNET_SendCallback
(
&
req
->
hdr
,
req
->
hdr
.
dwContext
,
INTERNET_STATUS_RESPONSE_RECEIVED
,
&
avail
,
sizeof
(
avail
));
return
error
;
}
static
DWORD
HTTPREQ_LockRequestFile
(
object_header_t
*
hdr
,
req_file_t
**
ret
)
...
...
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