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
d22928fb
Commit
d22928fb
authored
Nov 19, 2014
by
Hans Leidekker
Committed by
Alexandre Julliard
Nov 20, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ieframe: Send command state change notifications from history navigation handlers.
parent
9db50228
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
191 additions
and
21 deletions
+191
-21
ieframe.h
dlls/ieframe/ieframe.h
+1
-0
navigate.c
dlls/ieframe/navigate.c
+35
-0
oleobject.c
dlls/ieframe/oleobject.c
+3
-0
webbrowser.c
dlls/ieframe/tests/webbrowser.c
+152
-21
No files found.
dlls/ieframe/ieframe.h
View file @
d22928fb
...
@@ -273,6 +273,7 @@ HRESULT dochost_object_available(DocHost*,IUnknown*) DECLSPEC_HIDDEN;
...
@@ -273,6 +273,7 @@ HRESULT dochost_object_available(DocHost*,IUnknown*) DECLSPEC_HIDDEN;
void
set_doc_state
(
DocHost
*
,
READYSTATE
)
DECLSPEC_HIDDEN
;
void
set_doc_state
(
DocHost
*
,
READYSTATE
)
DECLSPEC_HIDDEN
;
void
deactivate_document
(
DocHost
*
)
DECLSPEC_HIDDEN
;
void
deactivate_document
(
DocHost
*
)
DECLSPEC_HIDDEN
;
void
create_doc_view_hwnd
(
DocHost
*
)
DECLSPEC_HIDDEN
;
void
create_doc_view_hwnd
(
DocHost
*
)
DECLSPEC_HIDDEN
;
void
on_commandstate_change
(
DocHost
*
,
LONG
,
VARIANT_BOOL
)
DECLSPEC_HIDDEN
;
#define WM_DOCHOSTTASK (WM_USER+0x300)
#define WM_DOCHOSTTASK (WM_USER+0x300)
void
push_dochost_task
(
DocHost
*
,
task_header_t
*
,
task_proc_t
,
task_destr_t
,
BOOL
)
DECLSPEC_HIDDEN
;
void
push_dochost_task
(
DocHost
*
,
task_header_t
*
,
task_proc_t
,
task_destr_t
,
BOOL
)
DECLSPEC_HIDDEN
;
...
...
dlls/ieframe/navigate.c
View file @
d22928fb
...
@@ -773,6 +773,27 @@ static void doc_navigate_task_destr(task_header_t *t)
...
@@ -773,6 +773,27 @@ static void doc_navigate_task_destr(task_header_t *t)
heap_free
(
task
);
heap_free
(
task
);
}
}
void
on_commandstate_change
(
DocHost
*
doc_host
,
LONG
command
,
VARIANT_BOOL
enable
)
{
DISPPARAMS
dispparams
;
VARIANTARG
params
[
2
];
TRACE
(
"command=%d enable=%d
\n
"
,
command
,
enable
);
dispparams
.
cArgs
=
2
;
dispparams
.
cNamedArgs
=
0
;
dispparams
.
rgdispidNamedArgs
=
NULL
;
dispparams
.
rgvarg
=
params
;
V_VT
(
params
)
=
VT_BOOL
;
V_BOOL
(
params
)
=
enable
;
V_VT
(
params
+
1
)
=
VT_I4
;
V_I4
(
params
+
1
)
=
command
;
call_sink
(
doc_host
->
cps
.
wbe2
,
DISPID_COMMANDSTATECHANGE
,
&
dispparams
);
}
static
void
doc_navigate_proc
(
DocHost
*
This
,
task_header_t
*
t
)
static
void
doc_navigate_proc
(
DocHost
*
This
,
task_header_t
*
t
)
{
{
task_doc_navigate_t
*
task
=
(
task_doc_navigate_t
*
)
t
;
task_doc_navigate_t
*
task
=
(
task_doc_navigate_t
*
)
t
;
...
@@ -876,6 +897,9 @@ static HRESULT navigate_bsc(DocHost *This, BindStatusCallback *bsc, IMoniker *mo
...
@@ -876,6 +897,9 @@ static HRESULT navigate_bsc(DocHost *This, BindStatusCallback *bsc, IMoniker *mo
return
S_OK
;
return
S_OK
;
}
}
on_commandstate_change
(
This
,
CSC_NAVIGATEBACK
,
VARIANT_FALSE
);
on_commandstate_change
(
This
,
CSC_NAVIGATEFORWARD
,
VARIANT_FALSE
);
if
(
This
->
document
)
if
(
This
->
document
)
deactivate_document
(
This
);
deactivate_document
(
This
);
...
@@ -1069,6 +1093,17 @@ static HRESULT navigate_history(DocHost *This, unsigned travellog_pos)
...
@@ -1069,6 +1093,17 @@ static HRESULT navigate_history(DocHost *This, unsigned travellog_pos)
return
E_NOTIMPL
;
return
E_NOTIMPL
;
}
}
if
(
travellog_pos
<
This
->
travellog
.
position
)
{
on_commandstate_change
(
This
,
CSC_NAVIGATEBACK
,
VARIANT_FALSE
);
on_commandstate_change
(
This
,
CSC_NAVIGATEFORWARD
,
VARIANT_TRUE
);
}
else
if
(
travellog_pos
>
This
->
travellog
.
position
)
{
on_commandstate_change
(
This
,
CSC_NAVIGATEBACK
,
VARIANT_TRUE
);
on_commandstate_change
(
This
,
CSC_NAVIGATEFORWARD
,
VARIANT_FALSE
);
}
This
->
travellog
.
loading_pos
=
travellog_pos
;
This
->
travellog
.
loading_pos
=
travellog_pos
;
entry
=
This
->
travellog
.
log
+
This
->
travellog
.
loading_pos
;
entry
=
This
->
travellog
.
log
+
This
->
travellog
.
loading_pos
;
...
...
dlls/ieframe/oleobject.c
View file @
d22928fb
...
@@ -442,6 +442,9 @@ static HRESULT WINAPI OleObject_SetClientSite(IOleObject *iface, LPOLECLIENTSITE
...
@@ -442,6 +442,9 @@ static HRESULT WINAPI OleObject_SetClientSite(IOleObject *iface, LPOLECLIENTSITE
release_client_site
(
This
);
release_client_site
(
This
);
if
(
!
pClientSite
)
{
if
(
!
pClientSite
)
{
on_commandstate_change
(
&
This
->
doc_host
,
CSC_NAVIGATEBACK
,
VARIANT_FALSE
);
on_commandstate_change
(
&
This
->
doc_host
,
CSC_NAVIGATEFORWARD
,
VARIANT_FALSE
);
if
(
This
->
doc_host
.
document
)
if
(
This
->
doc_host
.
document
)
deactivate_document
(
&
This
->
doc_host
);
deactivate_document
(
&
This
->
doc_host
);
return
S_OK
;
return
S_OK
;
...
...
dlls/ieframe/tests/webbrowser.c
View file @
d22928fb
...
@@ -96,7 +96,9 @@ DEFINE_EXPECT(Invoke_DOWNLOADBEGIN);
...
@@ -96,7 +96,9 @@ DEFINE_EXPECT(Invoke_DOWNLOADBEGIN);
DEFINE_EXPECT
(
Invoke_BEFORENAVIGATE2
);
DEFINE_EXPECT
(
Invoke_BEFORENAVIGATE2
);
DEFINE_EXPECT
(
Invoke_SETSECURELOCKICON
);
DEFINE_EXPECT
(
Invoke_SETSECURELOCKICON
);
DEFINE_EXPECT
(
Invoke_FILEDOWNLOAD
);
DEFINE_EXPECT
(
Invoke_FILEDOWNLOAD
);
DEFINE_EXPECT
(
Invoke_COMMANDSTATECHANGE
);
DEFINE_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
DEFINE_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
DEFINE_EXPECT
(
Invoke_COMMANDSTATECHANGE_UPDATECOMMANDS
);
DEFINE_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
DEFINE_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
DEFINE_EXPECT
(
Invoke_ONMENUBAR
);
DEFINE_EXPECT
(
Invoke_ONMENUBAR
);
DEFINE_EXPECT
(
Invoke_ONADDRESSBAR
);
DEFINE_EXPECT
(
Invoke_ONADDRESSBAR
);
...
@@ -156,7 +158,8 @@ static BOOL is_downloading, is_first_load, use_container_olecmd, test_close, is_
...
@@ -156,7 +158,8 @@ static BOOL is_downloading, is_first_load, use_container_olecmd, test_close, is_
static
HRESULT
hr_dochost_TranslateAccelerator
=
E_NOTIMPL
;
static
HRESULT
hr_dochost_TranslateAccelerator
=
E_NOTIMPL
;
static
HRESULT
hr_site_TranslateAccelerator
=
E_NOTIMPL
;
static
HRESULT
hr_site_TranslateAccelerator
=
E_NOTIMPL
;
static
const
char
*
current_url
;
static
const
char
*
current_url
;
static
int
wb_version
;
static
int
wb_version
,
expect_navigate_back_enable
,
set_navigate_back_enable
,
expect_navigate_forward_enable
,
set_navigate_forward_enable
,
expect_update_commands_enable
,
set_update_commands_enable
;
#define DWL_EXPECT_BEFORE_NAVIGATE 0x01
#define DWL_EXPECT_BEFORE_NAVIGATE 0x01
#define DWL_FROM_PUT_HREF 0x02
#define DWL_FROM_PUT_HREF 0x02
...
@@ -878,15 +881,31 @@ static HRESULT WINAPI WebBrowserEvents2_Invoke(IDispatch *iface, DISPID dispIdMe
...
@@ -878,15 +881,31 @@ static HRESULT WINAPI WebBrowserEvents2_Invoke(IDispatch *iface, DISPID dispIdMe
break
;
break
;
case
DISPID_COMMANDSTATECHANGE
:
case
DISPID_COMMANDSTATECHANGE
:
CHECK_EXPECT2
(
Invoke_COMMANDSTATECHANGE
);
ok
(
pDispParams
->
rgvarg
!=
NULL
,
"rgvarg == NULL
\n
"
);
ok
(
pDispParams
->
rgvarg
!=
NULL
,
"rgvarg == NULL
\n
"
);
ok
(
pDispParams
->
cArgs
==
2
,
"cArgs=%d, expected 2
\n
"
,
pDispParams
->
cArgs
);
ok
(
pDispParams
->
cArgs
==
2
,
"cArgs=%d, expected 2
\n
"
,
pDispParams
->
cArgs
);
ok
(
V_VT
(
pDispParams
->
rgvarg
)
==
VT_BOOL
,
"V_VT(pDispParams->rgvarg) = %d
\n
"
,
V_VT
(
pDispParams
->
rgvarg
));
ok
(
V_VT
(
pDispParams
->
rgvarg
)
==
VT_BOOL
,
"V_VT(pDispParams->rgvarg) = %d
\n
"
,
V_VT
(
pDispParams
->
rgvarg
));
ok
(
V_VT
(
pDispParams
->
rgvarg
+
1
)
==
VT_I4
,
"V_VT(pDispParams->rgvarg+1) = %d
\n
"
,
V_VT
(
pDispParams
->
rgvarg
+
1
));
ok
(
V_VT
(
pDispParams
->
rgvarg
+
1
)
==
VT_I4
,
"V_VT(pDispParams->rgvarg+1) = %d
\n
"
,
V_VT
(
pDispParams
->
rgvarg
+
1
));
ok
(
V_I4
(
pDispParams
->
rgvarg
+
1
)
==
CSC_NAVIGATEFORWARD
||
V_I4
(
pDispParams
->
rgvarg
+
1
)
==
CSC_NAVIGATEBACK
||
V_I4
(
pDispParams
->
rgvarg
+
1
)
==
CSC_UPDATECOMMANDS
,
"V_I4(pDispParams->rgvarg+1) = %x
\n
"
,
V_I4
(
pDispParams
->
rgvarg
+
1
));
/* TODO: Check args */
if
(
V_I4
(
pDispParams
->
rgvarg
+
1
)
==
CSC_NAVIGATEFORWARD
)
{
CHECK_EXPECT2
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
set_navigate_forward_enable
=
V_BOOL
(
pDispParams
->
rgvarg
);
}
else
if
(
V_I4
(
pDispParams
->
rgvarg
+
1
)
==
CSC_NAVIGATEBACK
)
{
CHECK_EXPECT2
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
set_navigate_back_enable
=
V_BOOL
(
pDispParams
->
rgvarg
);
}
else
if
(
V_I4
(
pDispParams
->
rgvarg
+
1
)
==
CSC_UPDATECOMMANDS
)
{
todo_wine
CHECK_EXPECT2
(
Invoke_COMMANDSTATECHANGE_UPDATECOMMANDS
);
set_update_commands_enable
=
V_BOOL
(
pDispParams
->
rgvarg
);
}
break
;
break
;
case
DISPID_DOWNLOADCOMPLETE
:
case
DISPID_DOWNLOADCOMPLETE
:
...
@@ -1914,7 +1933,18 @@ static void test_ClientSite(IWebBrowser2 *unk, IOleClientSite *client, BOOL stop
...
@@ -1914,7 +1933,18 @@ static void test_ClientSite(IWebBrowser2 *unk, IOleClientSite *client, BOOL stop
}
else
if
(
stop_download
)
{
}
else
if
(
stop_download
)
{
SET_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
SET_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
if
(
use_container_olecmd
)
SET_EXPECT
(
Exec_SETDOWNLOADSTATE_0
);
if
(
use_container_olecmd
)
SET_EXPECT
(
Exec_SETDOWNLOADSTATE_0
);
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE
);
expect_navigate_back_enable
=
0
;
set_navigate_back_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
expect_navigate_forward_enable
=
0
;
set_navigate_forward_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
expect_update_commands_enable
=
0
;
set_update_commands_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_UPDATECOMMANDS
);
}
else
{
}
else
{
SET_EXPECT
(
Invoke_STATUSTEXTCHANGE
);
SET_EXPECT
(
Invoke_STATUSTEXTCHANGE
);
SET_EXPECT
(
Invoke_PROGRESSCHANGE
);
SET_EXPECT
(
Invoke_PROGRESSCHANGE
);
...
@@ -1931,7 +1961,18 @@ static void test_ClientSite(IWebBrowser2 *unk, IOleClientSite *client, BOOL stop
...
@@ -1931,7 +1961,18 @@ static void test_ClientSite(IWebBrowser2 *unk, IOleClientSite *client, BOOL stop
}
else
if
(
stop_download
)
{
}
else
if
(
stop_download
)
{
todo_wine
CHECK_CALLED
(
Invoke_DOWNLOADCOMPLETE
);
todo_wine
CHECK_CALLED
(
Invoke_DOWNLOADCOMPLETE
);
if
(
use_container_olecmd
)
todo_wine
CHECK_CALLED
(
Exec_SETDOWNLOADSTATE_0
);
if
(
use_container_olecmd
)
todo_wine
CHECK_CALLED
(
Exec_SETDOWNLOADSTATE_0
);
todo_wine
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
ok
(
expect_navigate_back_enable
==
set_navigate_back_enable
,
"got %d
\n
"
,
set_navigate_back_enable
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
ok
(
expect_navigate_forward_enable
==
set_navigate_forward_enable
,
"got %d
\n
"
,
set_navigate_forward_enable
);
todo_wine
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_UPDATECOMMANDS
);
todo_wine
ok
(
expect_update_commands_enable
==
set_update_commands_enable
,
"got %d
\n
"
,
set_update_commands_enable
);
}
else
{
}
else
{
CLEAR_CALLED
(
Invoke_STATUSTEXTCHANGE
);
/* Called by IE9 */
CLEAR_CALLED
(
Invoke_STATUSTEXTCHANGE
);
/* Called by IE9 */
CLEAR_CALLED
(
Invoke_PROGRESSCHANGE
);
CLEAR_CALLED
(
Invoke_PROGRESSCHANGE
);
...
@@ -2650,7 +2691,15 @@ static void test_Navigate2(IWebBrowser2 *webbrowser, const char *nav_url)
...
@@ -2650,7 +2691,15 @@ static void test_Navigate2(IWebBrowser2 *webbrowser, const char *nav_url)
SET_EXPECT
(
Invoke_SETSECURELOCKICON
);
SET_EXPECT
(
Invoke_SETSECURELOCKICON
);
SET_EXPECT
(
Invoke_FILEDOWNLOAD
);
SET_EXPECT
(
Invoke_FILEDOWNLOAD
);
if
(
use_container_olecmd
)
SET_EXPECT
(
Exec_SETDOWNLOADSTATE_0
);
if
(
use_container_olecmd
)
SET_EXPECT
(
Exec_SETDOWNLOADSTATE_0
);
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE
);
expect_navigate_back_enable
=
0
;
set_navigate_back_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
expect_navigate_forward_enable
=
0
;
set_navigate_forward_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
SET_EXPECT
(
EnableModeless_TRUE
);
SET_EXPECT
(
EnableModeless_TRUE
);
if
(
!
use_container_olecmd
)
SET_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
if
(
!
use_container_olecmd
)
SET_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
if
(
is_file
)
SET_EXPECT
(
Invoke_PROGRESSCHANGE
);
if
(
is_file
)
SET_EXPECT
(
Invoke_PROGRESSCHANGE
);
...
@@ -2682,7 +2731,15 @@ static void test_Navigate2(IWebBrowser2 *webbrowser, const char *nav_url)
...
@@ -2682,7 +2731,15 @@ static void test_Navigate2(IWebBrowser2 *webbrowser, const char *nav_url)
if
(
use_container_olecmd
)
todo_wine
CHECK_CALLED
(
Exec_SETPROGRESSPOS
);
if
(
use_container_olecmd
)
todo_wine
CHECK_CALLED
(
Exec_SETPROGRESSPOS
);
todo_wine
CHECK_CALLED
(
Invoke_SETSECURELOCKICON
);
todo_wine
CHECK_CALLED
(
Invoke_SETSECURELOCKICON
);
todo_wine
CHECK_CALLED
(
Invoke_FILEDOWNLOAD
);
todo_wine
CHECK_CALLED
(
Invoke_FILEDOWNLOAD
);
todo_wine
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
ok
(
expect_navigate_back_enable
==
set_navigate_back_enable
,
"got %d
\n
"
,
set_navigate_back_enable
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
ok
(
expect_navigate_forward_enable
==
set_navigate_forward_enable
,
"got %d
\n
"
,
set_navigate_forward_enable
);
if
(
use_container_olecmd
)
todo_wine
CHECK_CALLED
(
Exec_SETDOWNLOADSTATE_0
);
if
(
use_container_olecmd
)
todo_wine
CHECK_CALLED
(
Exec_SETDOWNLOADSTATE_0
);
CHECK_CALLED
(
EnableModeless_TRUE
);
CHECK_CALLED
(
EnableModeless_TRUE
);
if
(
is_file
)
todo_wine
CHECK_CALLED
(
Invoke_PROGRESSCHANGE
);
if
(
is_file
)
todo_wine
CHECK_CALLED
(
Invoke_PROGRESSCHANGE
);
...
@@ -2804,7 +2861,19 @@ static void test_download(DWORD flags)
...
@@ -2804,7 +2861,19 @@ static void test_download(DWORD flags)
SET_EXPECT
(
Invoke_SETSECURELOCKICON
);
SET_EXPECT
(
Invoke_SETSECURELOCKICON
);
SET_EXPECT
(
Invoke_282
);
SET_EXPECT
(
Invoke_282
);
SET_EXPECT
(
EnableModeless_FALSE
);
SET_EXPECT
(
EnableModeless_FALSE
);
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE
);
expect_navigate_back_enable
=
0
;
set_navigate_back_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
expect_navigate_forward_enable
=
0
;
set_navigate_forward_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
expect_update_commands_enable
=
0
;
set_update_commands_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_UPDATECOMMANDS
);
SET_EXPECT
(
Invoke_STATUSTEXTCHANGE
);
SET_EXPECT
(
Invoke_STATUSTEXTCHANGE
);
SET_EXPECT
(
SetStatusText
);
SET_EXPECT
(
SetStatusText
);
SET_EXPECT
(
EnableModeless_TRUE
);
SET_EXPECT
(
EnableModeless_TRUE
);
...
@@ -2851,7 +2920,7 @@ static void test_download(DWORD flags)
...
@@ -2851,7 +2920,7 @@ static void test_download(DWORD flags)
todo_wine
CHECK_CALLED
(
EnableModeless_FALSE
);
todo_wine
CHECK_CALLED
(
EnableModeless_FALSE
);
else
else
CLEAR_CALLED
(
EnableModeless_FALSE
);
/* IE 8 */
CLEAR_CALLED
(
EnableModeless_FALSE
);
/* IE 8 */
CLEAR_CALLED
(
Invoke_COMMANDSTATECHANGE
);
CLEAR_CALLED
(
Invoke_COMMANDSTATECHANGE
_UPDATECOMMANDS
);
todo_wine
CHECK_CALLED
(
Invoke_STATUSTEXTCHANGE
);
todo_wine
CHECK_CALLED
(
Invoke_STATUSTEXTCHANGE
);
todo_wine
CHECK_CALLED
(
SetStatusText
);
todo_wine
CHECK_CALLED
(
SetStatusText
);
if
(
is_first_load
)
if
(
is_first_load
)
...
@@ -3010,23 +3079,40 @@ static void test_put_href(IWebBrowser2 *unk, const char *url)
...
@@ -3010,23 +3079,40 @@ static void test_put_href(IWebBrowser2 *unk, const char *url)
test_ready_state
(
READYSTATE_COMPLETE
);
test_ready_state
(
READYSTATE_COMPLETE
);
}
}
static
void
test_go_back
(
IWebBrowser2
*
wb
,
const
char
*
back_url
)
static
void
test_go_back
(
IWebBrowser2
*
wb
,
const
char
*
back_url
,
int
back_enable
,
int
forward_enable
,
int
forward_todo
)
{
{
HRESULT
hres
;
HRESULT
hres
;
current_url
=
back_url
;
current_url
=
back_url
;
SET_EXPECT
(
Invoke_BEFORENAVIGATE2
);
SET_EXPECT
(
Invoke_BEFORENAVIGATE2
);
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE
);
expect_navigate_back_enable
=
back_enable
;
set_navigate_back_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
expect_navigate_forward_enable
=
forward_enable
;
set_navigate_forward_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
SET_EXPECT
(
Invoke_PROPERTYCHANGE
);
SET_EXPECT
(
Invoke_PROPERTYCHANGE
);
hres
=
IWebBrowser2_GoBack
(
wb
);
hres
=
IWebBrowser2_GoBack
(
wb
);
ok
(
hres
==
S_OK
,
"GoBack failed: %08x
\n
"
,
hres
);
ok
(
hres
==
S_OK
,
"GoBack failed: %08x
\n
"
,
hres
);
CHECK_CALLED
(
Invoke_BEFORENAVIGATE2
);
CHECK_CALLED
(
Invoke_BEFORENAVIGATE2
);
todo_wine
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
ok
(
expect_navigate_back_enable
==
set_navigate_back_enable
,
"got %d
\n
"
,
set_navigate_back_enable
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
if
(
forward_todo
)
todo_wine
ok
(
expect_navigate_forward_enable
==
set_navigate_forward_enable
,
"got %d
\n
"
,
set_navigate_forward_enable
);
else
ok
(
expect_navigate_forward_enable
==
set_navigate_forward_enable
,
"got %d
\n
"
,
set_navigate_forward_enable
);
CLEAR_CALLED
(
Invoke_PROPERTYCHANGE
);
/* called by IE11 */
CLEAR_CALLED
(
Invoke_PROPERTYCHANGE
);
/* called by IE11 */
}
}
static
void
test_go_forward
(
IWebBrowser2
*
wb
,
const
char
*
forward_url
)
static
void
test_go_forward
(
IWebBrowser2
*
wb
,
const
char
*
forward_url
,
int
back_enable
,
int
forward_enable
)
{
{
HRESULT
hres
;
HRESULT
hres
;
...
@@ -3034,11 +3120,26 @@ static void test_go_forward(IWebBrowser2 *wb, const char *forward_url)
...
@@ -3034,11 +3120,26 @@ static void test_go_forward(IWebBrowser2 *wb, const char *forward_url)
dwl_flags
|=
DWL_FROM_GOFORWARD
;
dwl_flags
|=
DWL_FROM_GOFORWARD
;
SET_EXPECT
(
Invoke_BEFORENAVIGATE2
);
SET_EXPECT
(
Invoke_BEFORENAVIGATE2
);
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE
);
expect_navigate_back_enable
=
back_enable
;
set_navigate_back_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
expect_navigate_forward_enable
=
forward_enable
;
set_navigate_forward_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
hres
=
IWebBrowser2_GoForward
(
wb
);
hres
=
IWebBrowser2_GoForward
(
wb
);
ok
(
hres
==
S_OK
,
"GoForward failed: %08x
\n
"
,
hres
);
ok
(
hres
==
S_OK
,
"GoForward failed: %08x
\n
"
,
hres
);
CHECK_CALLED
(
Invoke_BEFORENAVIGATE2
);
CHECK_CALLED
(
Invoke_BEFORENAVIGATE2
);
todo_wine
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
ok
(
expect_navigate_back_enable
==
set_navigate_back_enable
,
"got %d
\n
"
,
set_navigate_back_enable
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
ok
(
expect_navigate_forward_enable
==
set_navigate_forward_enable
,
"got %d
\n
"
,
set_navigate_forward_enable
);
}
}
static
void
test_QueryInterface
(
IWebBrowser2
*
wb
)
static
void
test_QueryInterface
(
IWebBrowser2
*
wb
)
...
@@ -3389,7 +3490,18 @@ static void test_Close(IWebBrowser2 *wb, BOOL do_download)
...
@@ -3389,7 +3490,18 @@ static void test_Close(IWebBrowser2 *wb, BOOL do_download)
SET_EXPECT
(
OnInPlaceDeactivate
);
SET_EXPECT
(
OnInPlaceDeactivate
);
SET_EXPECT
(
Invoke_STATUSTEXTCHANGE
);
SET_EXPECT
(
Invoke_STATUSTEXTCHANGE
);
if
(
!
do_download
)
{
if
(
!
do_download
)
{
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE
);
expect_navigate_back_enable
=
0
;
set_navigate_back_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
expect_navigate_forward_enable
=
0
;
set_navigate_forward_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
expect_update_commands_enable
=
0
;
set_update_commands_enable
=
0xdead
;
SET_EXPECT
(
Invoke_COMMANDSTATECHANGE_UPDATECOMMANDS
);
SET_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
SET_EXPECT
(
Invoke_DOWNLOADCOMPLETE
);
}
}
hres
=
IOleObject_Close
(
oo
,
OLECLOSE_NOSAVE
);
hres
=
IOleObject_Close
(
oo
,
OLECLOSE_NOSAVE
);
...
@@ -3401,7 +3513,18 @@ static void test_Close(IWebBrowser2 *wb, BOOL do_download)
...
@@ -3401,7 +3513,18 @@ static void test_Close(IWebBrowser2 *wb, BOOL do_download)
CHECK_CALLED
(
OnInPlaceDeactivate
);
CHECK_CALLED
(
OnInPlaceDeactivate
);
CLEAR_CALLED
(
Invoke_STATUSTEXTCHANGE
);
/* Called by IE9 */
CLEAR_CALLED
(
Invoke_STATUSTEXTCHANGE
);
/* Called by IE9 */
if
(
!
do_download
)
{
if
(
!
do_download
)
{
todo_wine
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEBACK
);
ok
(
expect_navigate_back_enable
==
set_navigate_back_enable
,
"got %d
\n
"
,
set_navigate_back_enable
);
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_NAVIGATEFORWARD
);
ok
(
expect_navigate_forward_enable
==
set_navigate_forward_enable
,
"got %d
\n
"
,
set_navigate_forward_enable
);
todo_wine
CHECK_CALLED
(
Invoke_COMMANDSTATECHANGE_UPDATECOMMANDS
);
todo_wine
ok
(
expect_update_commands_enable
==
set_update_commands_enable
,
"got %d
\n
"
,
set_update_commands_enable
);
todo_wine
CHECK_CALLED
(
Invoke_DOWNLOADCOMPLETE
);
todo_wine
CHECK_CALLED
(
Invoke_DOWNLOADCOMPLETE
);
}
}
...
@@ -3494,11 +3617,19 @@ static void test_WebBrowser(BOOL do_download, BOOL do_close)
...
@@ -3494,11 +3617,19 @@ static void test_WebBrowser(BOOL do_download, BOOL do_close)
test_download
(
DWL_FROM_PUT_HREF
|
DWL_HTTP
);
test_download
(
DWL_FROM_PUT_HREF
|
DWL_HTTP
);
trace
(
"GoBack...
\n
"
);
trace
(
"GoBack...
\n
"
);
test_go_back
(
webbrowser
,
"http://test.winehq.org/tests/hello.html"
);
test_go_back
(
webbrowser
,
"http://test.winehq.org/tests/hello.html"
,
0
,
0
,
1
);
test_download
(
DWL_FROM_GOBACK
|
DWL_HTTP
);
trace
(
"GoForward...
\n
"
);
test_go_forward
(
webbrowser
,
"http://test.winehq.org/tests/winehq_snapshot/"
,
-
1
,
0
);
test_download
(
DWL_FROM_GOFORWARD
|
DWL_HTTP
);
trace
(
"GoBack...
\n
"
);
test_go_back
(
webbrowser
,
"http://test.winehq.org/tests/hello.html"
,
0
,
-
1
,
0
);
test_download
(
DWL_FROM_GOBACK
|
DWL_HTTP
);
test_download
(
DWL_FROM_GOBACK
|
DWL_HTTP
);
trace
(
"GoForward...
\n
"
);
trace
(
"GoForward...
\n
"
);
test_go_forward
(
webbrowser
,
"http://test.winehq.org/tests/winehq_snapshot/"
);
test_go_forward
(
webbrowser
,
"http://test.winehq.org/tests/winehq_snapshot/"
,
-
1
,
0
);
test_download
(
DWL_FROM_GOFORWARD
|
DWL_HTTP
);
test_download
(
DWL_FROM_GOFORWARD
|
DWL_HTTP
);
}
else
{
}
else
{
trace
(
"Navigate2 repeated with the same URL...
\n
"
);
trace
(
"Navigate2 repeated with the same URL...
\n
"
);
...
...
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