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
e6fc0c5d
Commit
e6fc0c5d
authored
May 31, 2006
by
Jacek Caban
Committed by
Alexandre Julliard
Jun 01, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
urlmon: Use task queue for cross thread calls in on_progress.
parent
08685417
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
7 additions
and
45 deletions
+7
-45
binding.c
dlls/urlmon/binding.c
+7
-45
No files found.
dlls/urlmon/binding.c
View file @
e6fc0c5d
...
...
@@ -107,7 +107,6 @@ struct Binding {
#define STREAM(x) ((IStream*) &(x)->lpStreamVtbl)
#define WM_MK_ONPROGRESS (WM_USER+100)
#define WM_MK_CONTINUE (WM_USER+101)
static
void
push_task
(
task_t
*
task
)
...
...
@@ -175,22 +174,7 @@ static void do_tasks(Binding *This)
static
LRESULT
WINAPI
notif_wnd_proc
(
HWND
hwnd
,
UINT
msg
,
WPARAM
wParam
,
LPARAM
lParam
)
{
switch
(
msg
)
{
case
WM_MK_ONPROGRESS
:
{
on_progress_data
*
data
=
(
on_progress_data
*
)
lParam
;
TRACE
(
"WM_MK_PROGRESS %p
\n
"
,
data
);
IBindStatusCallback_OnProgress
(
data
->
binding
->
callback
,
data
->
progress
,
data
->
progress_max
,
data
->
status_code
,
data
->
status_text
);
IBinding_Release
(
BINDING
(
data
->
binding
));
HeapFree
(
GetProcessHeap
(),
0
,
data
->
status_text
);
HeapFree
(
GetProcessHeap
(),
0
,
data
);
return
0
;
}
case
WM_MK_CONTINUE
:
{
if
(
msg
==
WM_MK_CONTINUE
)
{
Binding
*
binding
=
(
Binding
*
)
lParam
;
do_tasks
(
binding
);
...
...
@@ -198,7 +182,6 @@ static LRESULT WINAPI notif_wnd_proc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
IBinding_Release
(
BINDING
(
binding
));
return
0
;
}
}
return
DefWindowProcW
(
hwnd
,
msg
,
wParam
,
lParam
);
}
...
...
@@ -248,33 +231,7 @@ static void on_progress(Binding *This, ULONG progress, ULONG progress_max,
{
task_t
*
task
;
if
(
GetCurrentThreadId
()
!=
This
->
apartment_thread
)
{
on_progress_data
*
data
;
data
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
data
));
IBinding_AddRef
(
BINDING
(
This
));
data
->
binding
=
This
;
data
->
progress
=
progress
;
data
->
progress_max
=
progress_max
;
data
->
status_code
=
status_code
;
if
(
status_text
)
{
DWORD
size
=
(
strlenW
(
status_text
)
+
1
)
*
sizeof
(
WCHAR
);
data
->
status_text
=
HeapAlloc
(
GetProcessHeap
(),
0
,
size
);
memcpy
(
data
->
status_text
,
status_text
,
size
);
}
else
{
data
->
status_text
=
NULL
;
}
PostMessageW
(
This
->
notif_hwnd
,
WM_MK_ONPROGRESS
,
0
,
(
LPARAM
)
data
);
return
;
}
if
(
!
This
->
continue_call
)
{
if
(
GetCurrentThreadId
()
==
This
->
apartment_thread
&&
!
This
->
continue_call
)
{
IBindStatusCallback_OnProgress
(
This
->
callback
,
progress
,
progress_max
,
status_code
,
status_text
);
return
;
...
...
@@ -301,6 +258,11 @@ static void on_progress(Binding *This, ULONG progress, ULONG progress_max,
}
push_task
(
task
);
if
(
GetCurrentThreadId
()
!=
This
->
apartment_thread
)
{
IBinding_AddRef
(
BINDING
(
This
));
PostMessageW
(
This
->
notif_hwnd
,
WM_MK_CONTINUE
,
0
,
(
LPARAM
)
This
);
}
}
static
void
dump_BINDINFO
(
BINDINFO
*
bi
)
...
...
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