OLD | NEW |
---|---|
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 // | 4 // |
5 // IE toolband implementation. | 5 // IE toolband implementation. |
6 #include "ceee/ie/plugin/toolband/tool_band.h" | 6 #include "ceee/ie/plugin/toolband/tool_band.h" |
7 | 7 |
8 #include <atlsafe.h> | 8 #include <atlsafe.h> |
9 #include <atlstr.h> | 9 #include <atlstr.h> |
10 #include <shlguid.h> | 10 #include <shlguid.h> |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
50 _ATL_FUNC_INFO ToolBand::handler_type_idispatch_variantref_ = | 50 _ATL_FUNC_INFO ToolBand::handler_type_idispatch_variantref_ = |
51 { CC_STDCALL, VT_EMPTY, 2, { VT_DISPATCH, VT_VARIANT | VT_BYREF } }; | 51 { CC_STDCALL, VT_EMPTY, 2, { VT_DISPATCH, VT_VARIANT | VT_BYREF } }; |
52 | 52 |
53 ToolBand::ToolBand() | 53 ToolBand::ToolBand() |
54 : already_tried_installing_(false), | 54 : already_tried_installing_(false), |
55 own_line_flag_(false), | 55 own_line_flag_(false), |
56 already_checked_own_line_flag_(false), | 56 already_checked_own_line_flag_(false), |
57 listening_to_browser_events_(false), | 57 listening_to_browser_events_(false), |
58 band_id_(0), | 58 band_id_(0), |
59 is_quitting_(false), | 59 is_quitting_(false), |
60 already_sent_id_to_bho_(false), | |
60 current_width_(kToolBandMinWidth), | 61 current_width_(kToolBandMinWidth), |
61 current_height_(kToolBandHeight) { | 62 current_height_(kToolBandHeight) { |
62 TRACE_EVENT_BEGIN("ceee.toolband", this, ""); | 63 TRACE_EVENT_BEGIN("ceee.toolband", this, ""); |
63 } | 64 } |
64 | 65 |
65 ToolBand::~ToolBand() { | 66 ToolBand::~ToolBand() { |
66 TRACE_EVENT_END("ceee.toolband", this, ""); | 67 TRACE_EVENT_END("ceee.toolband", this, ""); |
67 } | 68 } |
68 | 69 |
69 HRESULT ToolBand::FinalConstruct() { | 70 HRESULT ToolBand::FinalConstruct() { |
(...skipping 452 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
522 // on overinstall when Chrome has already auto-updated. | 523 // on overinstall when Chrome has already auto-updated. |
523 // | 524 // |
524 // If it turns out no extension is installed, we will handle that | 525 // If it turns out no extension is installed, we will handle that |
525 // error in the OnCfGetEnabledExtensionsComplete callback. | 526 // error in the OnCfGetEnabledExtensionsComplete callback. |
526 chrome_frame_->getEnabledExtensions(); | 527 chrome_frame_->getEnabledExtensions(); |
527 } | 528 } |
528 | 529 |
529 STDMETHODIMP_(void) ToolBand::OnCfGetEnabledExtensionsComplete( | 530 STDMETHODIMP_(void) ToolBand::OnCfGetEnabledExtensionsComplete( |
530 SAFEARRAY* extension_directories) { | 531 SAFEARRAY* extension_directories) { |
531 CComSafeArray<BSTR> directories; | 532 CComSafeArray<BSTR> directories; |
532 EnsureBhoIsAvailable(); // We will require a working bho to do anything. | 533 EnsureBhoIsAvailable(); // We will require a working bho to do anything. |
motek.
2010/11/30 22:33:09
So, what about 'if (SUCCEEDED(EnsureBhoIsAvailable
Cindy Lau
2010/12/01 00:01:36
The other thing EnsureBhoIsAvailable does is to ac
motek.
2010/12/01 00:13:49
On 2010/12/01 00:01:36, Cindy Lau wrote:
Yes, my p
| |
533 directories.Attach(extension_directories); // MUST DETACH BEFORE RETURNING | 534 directories.Attach(extension_directories); // MUST DETACH BEFORE RETURNING |
534 | 535 |
535 // TODO(joi@chromium.org) Handle multiple extensions. | 536 // TODO(joi@chromium.org) Handle multiple extensions. |
536 if (directories.GetCount() > 0) { | 537 if (directories.GetCount() > 0) { |
537 // If our extension_path is not a CRX, it MUST be the same as the installed | 538 // If our extension_path is not a CRX, it MUST be the same as the installed |
538 // extension path which would be an exploded extension. | 539 // extension path which would be an exploded extension. |
539 // If you get this DCHECK, you may have changed your registry settings to | 540 // If you get this DCHECK, you may have changed your registry settings to |
540 // debug with an exploded extension, but you didn't uninstall the previous | 541 // debug with an exploded extension, but you didn't uninstall the previous |
541 // extension, either via the Chrome UI or by simply wiping out your | 542 // extension, either via the Chrome UI or by simply wiping out your |
542 // profile folder. | 543 // profile folder. |
(...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
735 chrome_frame_internal_.QueryFrom(chrome_frame_); | 736 chrome_frame_internal_.QueryFrom(chrome_frame_); |
736 if (chrome_frame_internal_) { | 737 if (chrome_frame_internal_) { |
737 return chrome_frame_internal_->getSessionId(session_id); | 738 return chrome_frame_internal_->getSessionId(session_id); |
738 } | 739 } |
739 } | 740 } |
740 NOTREACHED(); | 741 NOTREACHED(); |
741 return E_UNEXPECTED; | 742 return E_UNEXPECTED; |
742 } | 743 } |
743 | 744 |
744 HRESULT ToolBand::SendSessionIdToBho(IUnknown* bho) { | 745 HRESULT ToolBand::SendSessionIdToBho(IUnknown* bho) { |
746 if (already_sent_id_to_bho_) | |
747 return S_FALSE; | |
motek.
2010/11/30 22:33:09
I am not sure if the return value of 'Ensure' shou
Cindy Lau
2010/12/01 00:01:36
See my comment above.
| |
745 // Now send the tool band's session ID to the BHO. | 748 // Now send the tool band's session ID to the BHO. |
746 ScopedComPtr<ICeeeBho> ceee_bho; | 749 ScopedComPtr<ICeeeBho> ceee_bho; |
747 HRESULT hr = ceee_bho.QueryFrom(bho); | 750 HRESULT hr = ceee_bho.QueryFrom(bho); |
748 if (SUCCEEDED(hr)) { | 751 if (SUCCEEDED(hr)) { |
749 int session_id = 0; | 752 int session_id = 0; |
750 hr = GetSessionId(&session_id); | 753 hr = GetSessionId(&session_id); |
751 if (SUCCEEDED(hr)) { | 754 if (SUCCEEDED(hr)) { |
752 return ceee_bho->SetToolBandSessionId(session_id); | 755 hr = ceee_bho->SetToolBandSessionId(session_id); |
756 if (SUCCEEDED(hr)) | |
757 already_sent_id_to_bho_ = true; | |
758 return hr; | |
753 } | 759 } |
754 } | 760 } |
755 return E_FAIL; | 761 return E_FAIL; |
756 } | 762 } |
OLD | NEW |