2 * Copyright 2005-2007 Jacek Caban for CodeWeavers
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
32 #include "wine/debug.h"
34 #include "mshtml_private.h"
38 WINE_DEFAULT_DEBUG_CHANNEL(mshtml
);
40 #define NSCMD_COPY "cmd_copy"
41 #define NSCMD_SELECTALL "cmd_selectAll"
43 void do_ns_command(HTMLDocument
*This
, const char *cmd
, nsICommandParams
*nsparam
)
45 nsICommandManager
*cmdmgr
;
48 TRACE("(%p)\n", This
);
50 if(!This
->doc_obj
|| !This
->doc_obj
->nscontainer
)
53 nsres
= get_nsinterface((nsISupports
*)This
->doc_obj
->nscontainer
->webbrowser
, &IID_nsICommandManager
, (void**)&cmdmgr
);
54 if(NS_FAILED(nsres
)) {
55 ERR("Could not get nsICommandManager: %08x\n", nsres
);
59 nsres
= nsICommandManager_DoCommand(cmdmgr
, cmd
, nsparam
, This
->window
->window_proxy
);
61 ERR("DoCommand(%s) failed: %08x\n", debugstr_a(cmd
), nsres
);
63 nsICommandManager_Release(cmdmgr
);
66 static nsIClipboardCommands
*get_clipboard_commands(HTMLDocument
*doc
)
68 nsIClipboardCommands
*clipboard_commands
;
69 nsIDocShell
*doc_shell
;
72 nsres
= get_nsinterface((nsISupports
*)doc
->window
->nswindow
, &IID_nsIDocShell
, (void**)&doc_shell
);
73 if(NS_FAILED(nsres
)) {
74 ERR("Could not get nsIDocShell interface\n");
78 nsres
= nsIDocShell_QueryInterface(doc_shell
, &IID_nsIClipboardCommands
, (void**)&clipboard_commands
);
79 nsIDocShell_Release(doc_shell
);
80 if(NS_FAILED(nsres
)) {
81 ERR("Could not get nsIClipboardCommands interface\n");
85 return clipboard_commands
;
88 /**********************************************************
89 * IOleCommandTarget implementation
92 static inline HTMLDocument
*impl_from_IOleCommandTarget(IOleCommandTarget
*iface
)
94 return CONTAINING_RECORD(iface
, HTMLDocument
, IOleCommandTarget_iface
);
97 static HRESULT
exec_open(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
99 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
103 static HRESULT
exec_new(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
105 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
109 static HRESULT
exec_save(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
111 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
115 static HRESULT
exec_save_as(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
117 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
121 static HRESULT
exec_save_copy_as(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
123 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
127 static nsresult
set_head_text(nsIPrintSettings
*settings
, LPCWSTR
template, BOOL head
, int pos
)
132 return nsIPrintSettings_SetHeaderStrLeft(settings
, template);
134 return nsIPrintSettings_SetHeaderStrRight(settings
, template);
136 return nsIPrintSettings_SetHeaderStrCenter(settings
, template);
141 return nsIPrintSettings_SetFooterStrLeft(settings
, template);
143 return nsIPrintSettings_SetFooterStrRight(settings
, template);
145 return nsIPrintSettings_SetFooterStrCenter(settings
, template);
152 static void set_print_template(nsIPrintSettings
*settings
, LPCWSTR
template, BOOL head
)
154 PRUnichar nstemplate
[200]; /* FIXME: Use dynamic allocation */
155 PRUnichar
*p
= nstemplate
;
156 LPCWSTR ptr
=template;
171 case 'b': /* change align */
174 set_head_text(settings
, nstemplate
, head
, pos
);
178 case 'd': { /* short date */
180 GetLocalTime(&systime
);
181 GetDateFormatW(LOCALE_SYSTEM_DEFAULT
, 0, &systime
, NULL
, p
,
182 sizeof(nstemplate
)-(p
-nstemplate
)*sizeof(WCHAR
));
187 case 'p': /* page number */
192 case 'P': /* page count */
193 *p
++ = '?'; /* FIXME */
202 /* FIXME: set window title */
212 set_head_text(settings
, nstemplate
, head
, pos
);
215 set_head_text(settings
, p
, head
, pos
);
218 static void set_default_templates(nsIPrintSettings
*settings
)
222 static const PRUnichar empty
[] = {0};
224 nsIPrintSettings_SetHeaderStrLeft(settings
, empty
);
225 nsIPrintSettings_SetHeaderStrRight(settings
, empty
);
226 nsIPrintSettings_SetHeaderStrCenter(settings
, empty
);
227 nsIPrintSettings_SetFooterStrLeft(settings
, empty
);
228 nsIPrintSettings_SetFooterStrRight(settings
, empty
);
229 nsIPrintSettings_SetFooterStrCenter(settings
, empty
);
231 if(LoadStringW(get_shdoclc(), IDS_PRINT_HEADER_TEMPLATE
, buf
, ARRAY_SIZE(buf
)))
232 set_print_template(settings
, buf
, TRUE
);
234 if(LoadStringW(get_shdoclc(), IDS_PRINT_FOOTER_TEMPLATE
, buf
, ARRAY_SIZE(buf
)))
235 set_print_template(settings
, buf
, FALSE
);
239 static HRESULT
exec_print(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
241 nsIWebBrowserPrint
*nsprint
;
242 nsIPrintSettings
*settings
;
245 TRACE("(%p)->(%d %s %p)\n", This
, nCmdexecopt
, debugstr_variant(pvaIn
), pvaOut
);
248 FIXME("unsupported pvaOut\n");
250 if(!This
->doc_obj
->nscontainer
)
253 nsres
= get_nsinterface((nsISupports
*)This
->doc_obj
->nscontainer
->webbrowser
, &IID_nsIWebBrowserPrint
,
255 if(NS_FAILED(nsres
)) {
256 ERR("Could not get nsIWebBrowserPrint: %08x\n", nsres
);
260 nsres
= nsIWebBrowserPrint_GetGlobalPrintSettings(nsprint
, &settings
);
262 ERR("GetCurrentPrintSettings failed: %08x\n", nsres
);
264 set_default_templates(settings
);
267 switch(V_VT(pvaIn
)) {
268 case VT_BYREF
|VT_ARRAY
: {
272 if(V_ARRAY(pvaIn
)->cDims
!= 1)
273 WARN("cDims = %d\n", V_ARRAY(pvaIn
)->cDims
);
275 SafeArrayAccessData(V_ARRAY(pvaIn
), (void**)&opts
);
276 opts_cnt
= V_ARRAY(pvaIn
)->rgsabound
[0].cElements
;
281 TRACE("setting footer %s\n", debugstr_w(V_BSTR(opts
)));
282 set_print_template(settings
, V_BSTR(opts
), TRUE
);
287 WARN("opts = %s\n", debugstr_variant(opts
));
292 switch(V_VT(opts
+1)) {
294 TRACE("setting footer %s\n", debugstr_w(V_BSTR(opts
+1)));
295 set_print_template(settings
, V_BSTR(opts
+1), FALSE
);
300 WARN("opts[1] = %s\n", debugstr_variant(opts
+1));
305 FIXME("Unsupported opts_cnt %d\n", opts_cnt
);
307 SafeArrayUnaccessData(V_ARRAY(pvaIn
));
311 FIXME("unsupported arg %s\n", debugstr_variant(pvaIn
));
315 nsres
= nsIWebBrowserPrint_Print(nsprint
, settings
, NULL
);
317 ERR("Print failed: %08x\n", nsres
);
319 nsIWebBrowserPrint_Release(nsprint
);
324 static HRESULT
exec_print_preview(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
326 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
330 static HRESULT
exec_page_setup(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
332 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
336 static HRESULT
exec_spell(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
338 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
342 static HRESULT
exec_properties(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
344 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
348 static HRESULT
exec_cut(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
350 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
354 static HRESULT
exec_copy(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
356 TRACE("(%p)->(%d %s %p)\n", This
, nCmdexecopt
, debugstr_variant(pvaIn
), pvaOut
);
358 do_ns_command(This
, NSCMD_COPY
, NULL
);
362 static HRESULT
exec_paste(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
364 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
368 static HRESULT
exec_paste_special(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
370 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
374 static HRESULT
exec_undo(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
376 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
380 static HRESULT
exec_rendo(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
382 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
386 static HRESULT
exec_select_all(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*in
, VARIANT
*out
)
388 TRACE("(%p)\n", This
);
391 FIXME("unsupported args\n");
393 if(This
->doc_obj
->nscontainer
)
394 do_ns_command(This
, NSCMD_SELECTALL
, NULL
);
396 update_doc(This
->doc_obj
, UPDATE_UI
);
400 static HRESULT
exec_clear_selection(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
402 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
406 static HRESULT
exec_zoom(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
408 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
412 static HRESULT
exec_get_zoom_range(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
414 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
420 HTMLOuterWindow
*window
;
423 static void refresh_proc(task_t
*_task
)
425 refresh_task_t
*task
= (refresh_task_t
*)_task
;
426 HTMLOuterWindow
*window
= task
->window
;
428 TRACE("%p\n", window
);
430 window
->readystate
= READYSTATE_UNINITIALIZED
;
432 if(window
->doc_obj
&& window
->doc_obj
->client_cmdtrg
) {
437 IOleCommandTarget_Exec(window
->doc_obj
->client_cmdtrg
, &CGID_ShellDocView
, 37, 0, &var
, NULL
);
440 load_uri(task
->window
, task
->window
->uri
, BINDING_REFRESH
|BINDING_NOFRAG
);
443 static void refresh_destr(task_t
*_task
)
445 refresh_task_t
*task
= (refresh_task_t
*)_task
;
447 IHTMLWindow2_Release(&task
->window
->base
.IHTMLWindow2_iface
);
451 static HRESULT
exec_refresh(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
453 refresh_task_t
*task
;
456 TRACE("(%p)->(%d %s %p)\n", This
, nCmdexecopt
, debugstr_variant(pvaIn
), pvaOut
);
458 if(This
->doc_obj
->client
) {
459 IOleCommandTarget
*olecmd
;
461 hres
= IOleClientSite_QueryInterface(This
->doc_obj
->client
, &IID_IOleCommandTarget
, (void**)&olecmd
);
462 if(SUCCEEDED(hres
)) {
463 hres
= IOleCommandTarget_Exec(olecmd
, &CGID_DocHostCommandHandler
, 2300, nCmdexecopt
, pvaIn
, pvaOut
);
464 IOleCommandTarget_Release(olecmd
);
473 task
= heap_alloc(sizeof(*task
));
475 return E_OUTOFMEMORY
;
477 IHTMLWindow2_AddRef(&This
->window
->base
.IHTMLWindow2_iface
);
478 task
->window
= This
->window
;
480 return push_task(&task
->header
, refresh_proc
, refresh_destr
, This
->window
->task_magic
);
483 static HRESULT
exec_stop(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
485 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
489 static HRESULT
exec_stop_download(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
491 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
495 static HRESULT
exec_find(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
497 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
501 static HRESULT
exec_delete(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
503 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
507 static HRESULT
exec_enable_interaction(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
509 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
513 static HRESULT
exec_on_unload(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
515 TRACE("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
517 /* Tests show that we have nothing more to do here */
520 V_VT(pvaOut
) = VT_BOOL
;
521 V_BOOL(pvaOut
) = VARIANT_TRUE
;
527 static HRESULT
exec_show_page_setup(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
529 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
533 static HRESULT
exec_show_print(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
535 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
539 static HRESULT
exec_close(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
541 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
545 static HRESULT
exec_set_print_template(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
547 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
551 static HRESULT
exec_get_print_template(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
553 FIXME("(%p)->(%d %p %p)\n", This
, nCmdexecopt
, pvaIn
, pvaOut
);
557 static HRESULT
exec_optical_zoom(HTMLDocument
*This
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
559 TRACE("(%p)->(%d %s %p)\n", This
, nCmdexecopt
, debugstr_variant(pvaIn
), pvaOut
);
561 if(!pvaIn
|| V_VT(pvaIn
) != VT_I4
) {
562 FIXME("Unsupported argument %s\n", debugstr_variant(pvaIn
));
566 set_viewer_zoom(This
->doc_obj
->nscontainer
, (float)V_I4(pvaIn
)/100);
570 static HRESULT
query_mshtml_copy(HTMLDocument
*This
, OLECMD
*cmd
)
572 FIXME("(%p)\n", This
);
573 cmd
->cmdf
= OLECMDF_SUPPORTED
|OLECMDF_ENABLED
;
577 static HRESULT
exec_mshtml_copy(HTMLDocument
*This
, DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
579 TRACE("(%p)->(%08x %p %p)\n", This
, cmdexecopt
, in
, out
);
581 if(This
->doc_obj
->usermode
== EDITMODE
)
582 return editor_exec_copy(This
, cmdexecopt
, in
, out
);
584 do_ns_command(This
, NSCMD_COPY
, NULL
);
588 static HRESULT
query_mshtml_cut(HTMLDocument
*This
, OLECMD
*cmd
)
590 FIXME("(%p)\n", This
);
591 cmd
->cmdf
= OLECMDF_SUPPORTED
|OLECMDF_ENABLED
;
595 static HRESULT
exec_mshtml_cut(HTMLDocument
*This
, DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
597 nsIClipboardCommands
*clipboard_commands
;
600 TRACE("(%p)->(%08x %p %p)\n", This
, cmdexecopt
, in
, out
);
602 if(This
->doc_obj
->usermode
== EDITMODE
)
603 return editor_exec_cut(This
, cmdexecopt
, in
, out
);
605 clipboard_commands
= get_clipboard_commands(This
);
606 if(!clipboard_commands
)
609 nsres
= nsIClipboardCommands_CutSelection(clipboard_commands
);
610 nsIClipboardCommands_Release(clipboard_commands
);
611 if(NS_FAILED(nsres
)) {
612 ERR("Paste failed: %08x\n", nsres
);
619 static HRESULT
query_mshtml_paste(HTMLDocument
*This
, OLECMD
*cmd
)
621 FIXME("(%p)\n", This
);
622 cmd
->cmdf
= OLECMDF_SUPPORTED
|OLECMDF_ENABLED
;
626 static HRESULT
exec_mshtml_paste(HTMLDocument
*This
, DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
628 nsIClipboardCommands
*clipboard_commands
;
631 TRACE("(%p)->(%08x %p %p)\n", This
, cmdexecopt
, in
, out
);
633 if(This
->doc_obj
->usermode
== EDITMODE
)
634 return editor_exec_paste(This
, cmdexecopt
, in
, out
);
636 clipboard_commands
= get_clipboard_commands(This
);
637 if(!clipboard_commands
)
640 nsres
= nsIClipboardCommands_Paste(clipboard_commands
);
641 nsIClipboardCommands_Release(clipboard_commands
);
642 if(NS_FAILED(nsres
)) {
643 ERR("Paste failed: %08x\n", nsres
);
650 static HRESULT
query_selall_status(HTMLDocument
*This
, OLECMD
*cmd
)
652 TRACE("(%p)->(%p)\n", This
, cmd
);
654 cmd
->cmdf
= OLECMDF_SUPPORTED
|OLECMDF_ENABLED
;
658 static HRESULT
exec_browsemode(HTMLDocument
*This
, DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
660 WARN("(%p)->(%08x %p %p)\n", This
, cmdexecopt
, in
, out
);
663 FIXME("unsupported args\n");
665 This
->doc_obj
->usermode
= BROWSEMODE
;
670 static HRESULT
exec_editmode(HTMLDocument
*This
, DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
672 TRACE("(%p)->(%08x %p %p)\n", This
, cmdexecopt
, in
, out
);
675 FIXME("unsupported args\n");
677 return setup_edit_mode(This
->doc_obj
);
680 static HRESULT
exec_htmleditmode(HTMLDocument
*This
, DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
682 FIXME("(%p)->(%08x %p %p)\n", This
, cmdexecopt
, in
, out
);
686 static HRESULT
exec_baselinefont3(HTMLDocument
*This
, DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
688 FIXME("(%p)->(%08x %p %p)\n", This
, cmdexecopt
, in
, out
);
692 static HRESULT
exec_respectvisibility_indesign(HTMLDocument
*This
, DWORD cmdexecopt
,
693 VARIANT
*in
, VARIANT
*out
)
695 TRACE("(%p)->(%x %s %p)\n", This
, cmdexecopt
, debugstr_variant(in
), out
);
697 /* This is turned on by default in Gecko. */
698 if(!in
|| V_VT(in
) != VT_BOOL
|| !V_BOOL(in
))
699 FIXME("Unsupported argument %s\n", debugstr_variant(in
));
704 static HRESULT
query_enabled_stub(HTMLDocument
*This
, OLECMD
*cmd
)
708 FIXME("CGID_MSHTML: IDM_PRINT\n");
709 cmd
->cmdf
= OLECMDF_SUPPORTED
|OLECMDF_ENABLED
;
711 case IDM_BLOCKDIRLTR
:
712 FIXME("CGID_MSHTML: IDM_BLOCKDIRLTR\n");
713 cmd
->cmdf
= OLECMDF_SUPPORTED
|OLECMDF_ENABLED
;
715 case IDM_BLOCKDIRRTL
:
716 FIXME("CGID_MSHTML: IDM_BLOCKDIRRTL\n");
717 cmd
->cmdf
= OLECMDF_SUPPORTED
|OLECMDF_ENABLED
;
724 static const struct {
726 HRESULT (*func
)(HTMLDocument
*,DWORD
,VARIANT
*,VARIANT
*);
729 { OLECMDF_SUPPORTED
, exec_open
}, /* OLECMDID_OPEN */
730 { OLECMDF_SUPPORTED
, exec_new
}, /* OLECMDID_NEW */
731 { OLECMDF_SUPPORTED
, exec_save
}, /* OLECMDID_SAVE */
732 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_save_as
}, /* OLECMDID_SAVEAS */
733 { OLECMDF_SUPPORTED
, exec_save_copy_as
}, /* OLECMDID_SAVECOPYAS */
734 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_print
}, /* OLECMDID_PRINT */
735 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_print_preview
}, /* OLECMDID_PRINTPREVIEW */
736 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_page_setup
}, /* OLECMDID_PAGESETUP */
737 { OLECMDF_SUPPORTED
, exec_spell
}, /* OLECMDID_SPELL */
738 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_properties
}, /* OLECMDID_PROPERTIES */
739 { OLECMDF_SUPPORTED
, exec_cut
}, /* OLECMDID_CUT */
740 { OLECMDF_SUPPORTED
, exec_copy
}, /* OLECMDID_COPY */
741 { OLECMDF_SUPPORTED
, exec_paste
}, /* OLECMDID_PASTE */
742 { OLECMDF_SUPPORTED
, exec_paste_special
}, /* OLECMDID_PASTESPECIAL */
743 { OLECMDF_SUPPORTED
, exec_undo
}, /* OLECMDID_UNDO */
744 { OLECMDF_SUPPORTED
, exec_rendo
}, /* OLECMDID_REDO */
745 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_select_all
}, /* OLECMDID_SELECTALL */
746 { OLECMDF_SUPPORTED
, exec_clear_selection
}, /* OLECMDID_CLEARSELECTION */
747 { OLECMDF_SUPPORTED
, exec_zoom
}, /* OLECMDID_ZOOM */
748 { OLECMDF_SUPPORTED
, exec_get_zoom_range
}, /* OLECMDID_GETZOOMRANGE */
750 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_refresh
}, /* OLECMDID_REFRESH */
751 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_stop
}, /* OLECMDID_STOP */
752 {0},{0},{0},{0},{0},{0},
753 { OLECMDF_SUPPORTED
, exec_stop_download
}, /* OLECMDID_STOPDOWNLOAD */
755 { OLECMDF_SUPPORTED
|OLECMDF_ENABLED
, exec_find
}, /* OLECMDID_FIND */
756 { OLECMDF_SUPPORTED
, exec_delete
}, /* OLECMDID_DELETE */
758 { OLECMDF_SUPPORTED
, exec_enable_interaction
}, /* OLECMDID_ENABLE_INTERACTION */
759 { OLECMDF_SUPPORTED
, exec_on_unload
}, /* OLECMDID_ONUNLOAD */
761 { OLECMDF_SUPPORTED
, exec_show_page_setup
}, /* OLECMDID_SHOWPAGESETUP */
762 { OLECMDF_SUPPORTED
, exec_show_print
}, /* OLECMDID_SHOWPRINT */
764 { OLECMDF_SUPPORTED
, exec_close
}, /* OLECMDID_CLOSE */
766 { OLECMDF_SUPPORTED
, exec_set_print_template
}, /* OLECMDID_SETPRINTTEMPLATE */
767 { OLECMDF_SUPPORTED
, exec_get_print_template
}, /* OLECMDID_GETPRINTTEMPLATE */
768 {0},{0},{0},{0},{0},{0},{0},{0},{0},{0},
769 { 0, /* not reported as supported */ exec_optical_zoom
} /* OLECMDID_OPTICAL_ZOOM */
772 static const cmdtable_t base_cmds
[] = {
773 {IDM_COPY
, query_mshtml_copy
, exec_mshtml_copy
},
774 {IDM_PASTE
, query_mshtml_paste
, exec_mshtml_paste
},
775 {IDM_CUT
, query_mshtml_cut
, exec_mshtml_cut
},
776 {IDM_SELECTALL
, query_selall_status
, exec_select_all
},
777 {IDM_BROWSEMODE
, NULL
, exec_browsemode
},
778 {IDM_EDITMODE
, NULL
, exec_editmode
},
779 {IDM_PRINT
, query_enabled_stub
, exec_print
},
780 {IDM_HTMLEDITMODE
, NULL
, exec_htmleditmode
},
781 {IDM_BASELINEFONT3
, NULL
, exec_baselinefont3
},
782 {IDM_BLOCKDIRLTR
, query_enabled_stub
, NULL
},
783 {IDM_BLOCKDIRRTL
, query_enabled_stub
, NULL
},
784 {IDM_RESPECTVISIBILITY_INDESIGN
, NULL
, exec_respectvisibility_indesign
},
788 static HRESULT WINAPI
OleCommandTarget_QueryInterface(IOleCommandTarget
*iface
, REFIID riid
, void **ppv
)
790 HTMLDocument
*This
= impl_from_IOleCommandTarget(iface
);
791 return htmldoc_query_interface(This
, riid
, ppv
);
794 static ULONG WINAPI
OleCommandTarget_AddRef(IOleCommandTarget
*iface
)
796 HTMLDocument
*This
= impl_from_IOleCommandTarget(iface
);
797 return htmldoc_addref(This
);
800 static ULONG WINAPI
OleCommandTarget_Release(IOleCommandTarget
*iface
)
802 HTMLDocument
*This
= impl_from_IOleCommandTarget(iface
);
803 return htmldoc_release(This
);
806 static HRESULT
query_from_table(HTMLDocument
*This
, const cmdtable_t
*cmdtable
, OLECMD
*cmd
)
808 const cmdtable_t
*iter
= cmdtable
;
812 while(iter
->id
&& iter
->id
!= cmd
->cmdID
)
815 if(!iter
->id
|| !iter
->query
)
816 return OLECMDERR_E_NOTSUPPORTED
;
818 return iter
->query(This
, cmd
);
821 static HRESULT WINAPI
OleCommandTarget_QueryStatus(IOleCommandTarget
*iface
, const GUID
*pguidCmdGroup
,
822 ULONG cCmds
, OLECMD prgCmds
[], OLECMDTEXT
*pCmdText
)
824 HTMLDocument
*This
= impl_from_IOleCommandTarget(iface
);
827 TRACE("(%p)->(%s %d %p %p)\n", This
, debugstr_guid(pguidCmdGroup
), cCmds
, prgCmds
, pCmdText
);
830 FIXME("Unsupported pCmdText\n");
837 for(i
=0; i
<cCmds
; i
++) {
838 if(prgCmds
[i
].cmdID
< OLECMDID_OPEN
|| prgCmds
[i
].cmdID
>= ARRAY_SIZE(exec_table
)) {
839 WARN("Unsupported cmdID = %d\n", prgCmds
[i
].cmdID
);
842 if(prgCmds
[i
].cmdID
== OLECMDID_OPEN
|| prgCmds
[i
].cmdID
== OLECMDID_NEW
) {
843 IOleCommandTarget
*cmdtrg
= NULL
;
846 prgCmds
[i
].cmdf
= OLECMDF_SUPPORTED
;
847 if(This
->doc_obj
->client
) {
848 hres
= IOleClientSite_QueryInterface(This
->doc_obj
->client
, &IID_IOleCommandTarget
,
850 if(SUCCEEDED(hres
)) {
851 olecmd
.cmdID
= prgCmds
[i
].cmdID
;
854 hres
= IOleCommandTarget_QueryStatus(cmdtrg
, NULL
, 1, &olecmd
, NULL
);
855 if(SUCCEEDED(hres
) && olecmd
.cmdf
)
856 prgCmds
[i
].cmdf
= olecmd
.cmdf
;
859 ERR("This->client == NULL, native would crash\n");
862 prgCmds
[i
].cmdf
= exec_table
[prgCmds
[i
].cmdID
].cmdf
;
863 TRACE("cmdID = %d returning %x\n", prgCmds
[i
].cmdID
, prgCmds
[i
].cmdf
);
868 return (prgCmds
[cCmds
-1].cmdf
& OLECMDF_SUPPORTED
) ? S_OK
: OLECMDERR_E_NOTSUPPORTED
;
871 if(IsEqualGUID(&CGID_MSHTML
, pguidCmdGroup
)) {
874 for(i
=0; i
<cCmds
; i
++) {
875 hres
= query_from_table(This
, base_cmds
, prgCmds
+i
);
876 if(hres
== OLECMDERR_E_NOTSUPPORTED
)
877 hres
= query_from_table(This
, editmode_cmds
, prgCmds
+i
);
878 if(hres
== OLECMDERR_E_NOTSUPPORTED
)
879 FIXME("CGID_MSHTML: unsupported cmdID %d\n", prgCmds
[i
].cmdID
);
882 return (prgCmds
[cCmds
-1].cmdf
& OLECMDF_SUPPORTED
) ? S_OK
: OLECMDERR_E_NOTSUPPORTED
;
885 FIXME("Unsupported pguidCmdGroup %s\n", debugstr_guid(pguidCmdGroup
));
886 return OLECMDERR_E_UNKNOWNGROUP
;
889 static HRESULT
exec_from_table(HTMLDocument
*This
, const cmdtable_t
*cmdtable
, DWORD cmdid
,
890 DWORD cmdexecopt
, VARIANT
*in
, VARIANT
*out
)
892 const cmdtable_t
*iter
= cmdtable
;
894 while(iter
->id
&& iter
->id
!= cmdid
)
897 if(!iter
->id
|| !iter
->exec
)
898 return OLECMDERR_E_NOTSUPPORTED
;
900 return iter
->exec(This
, cmdexecopt
, in
, out
);
903 static HRESULT WINAPI
OleCommandTarget_Exec(IOleCommandTarget
*iface
, const GUID
*pguidCmdGroup
,
904 DWORD nCmdID
, DWORD nCmdexecopt
, VARIANT
*pvaIn
, VARIANT
*pvaOut
)
906 HTMLDocument
*This
= impl_from_IOleCommandTarget(iface
);
909 if(nCmdID
< OLECMDID_OPEN
|| nCmdID
>= ARRAY_SIZE(exec_table
) || !exec_table
[nCmdID
].func
) {
910 WARN("Unsupported cmdID = %d\n", nCmdID
);
911 return OLECMDERR_E_NOTSUPPORTED
;
914 return exec_table
[nCmdID
].func(This
, nCmdexecopt
, pvaIn
, pvaOut
);
915 }else if(IsEqualGUID(&CGID_Explorer
, pguidCmdGroup
)) {
916 FIXME("unsupported nCmdID %d of CGID_Explorer group\n", nCmdID
);
917 TRACE("%p %p\n", pvaIn
, pvaOut
);
918 return OLECMDERR_E_NOTSUPPORTED
;
919 }else if(IsEqualGUID(&CGID_ShellDocView
, pguidCmdGroup
)) {
920 FIXME("unsupported nCmdID %d of CGID_ShellDocView group\n", nCmdID
);
921 return OLECMDERR_E_NOTSUPPORTED
;
922 }else if(IsEqualGUID(&CGID_MSHTML
, pguidCmdGroup
)) {
923 HRESULT hres
= exec_from_table(This
, base_cmds
, nCmdID
, nCmdexecopt
, pvaIn
, pvaOut
);
924 if(hres
== OLECMDERR_E_NOTSUPPORTED
)
925 hres
= exec_from_table(This
, editmode_cmds
, nCmdID
,
926 nCmdexecopt
, pvaIn
, pvaOut
);
927 if(hres
== OLECMDERR_E_NOTSUPPORTED
)
928 FIXME("unsupported nCmdID %d of CGID_MSHTML group\n", nCmdID
);
933 FIXME("Unsupported pguidCmdGroup %s\n", debugstr_guid(pguidCmdGroup
));
934 return OLECMDERR_E_UNKNOWNGROUP
;
937 static const IOleCommandTargetVtbl OleCommandTargetVtbl
= {
938 OleCommandTarget_QueryInterface
,
939 OleCommandTarget_AddRef
,
940 OleCommandTarget_Release
,
941 OleCommandTarget_QueryStatus
,
942 OleCommandTarget_Exec
945 void show_context_menu(HTMLDocumentObj
*This
, DWORD dwID
, POINT
*ppt
, IDispatch
*elem
)
947 HMENU menu_res
, menu
;
950 if(This
->hostui
&& S_OK
== IDocHostUIHandler_ShowContextMenu(This
->hostui
,
951 dwID
, ppt
, (IUnknown
*)&This
->basedoc
.IOleCommandTarget_iface
, elem
))
954 menu_res
= LoadMenuW(get_shdoclc(), MAKEINTRESOURCEW(IDR_BROWSE_CONTEXT_MENU
));
955 menu
= GetSubMenu(menu_res
, dwID
);
957 cmdid
= TrackPopupMenu(menu
, TPM_LEFTALIGN
| TPM_RIGHTBUTTON
| TPM_RETURNCMD
,
958 ppt
->x
, ppt
->y
, 0, This
->hwnd
, NULL
);
959 DestroyMenu(menu_res
);
962 IOleCommandTarget_Exec(&This
->basedoc
.IOleCommandTarget_iface
, &CGID_MSHTML
, cmdid
, 0,
966 void HTMLDocument_OleCmd_Init(HTMLDocument
*This
)
968 This
->IOleCommandTarget_iface
.lpVtbl
= &OleCommandTargetVtbl
;