| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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 #include "chrome/renderer/render_view.h" | 5 #include "chrome/renderer/render_view.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 2133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2144 // the frame, otherwise it will report 'no match' if the focused frame has | 2144 // the frame, otherwise it will report 'no match' if the focused frame has |
| 2145 // reported matches, but no frames after the focused_frame contain a | 2145 // reported matches, but no frames after the focused_frame contain a |
| 2146 // match for the search word(s). | 2146 // match for the search word(s). |
| 2147 if (multi_frame && search_frame == focused_frame) { | 2147 if (multi_frame && search_frame == focused_frame) { |
| 2148 result = search_frame->Find( | 2148 result = search_frame->Find( |
| 2149 request_id, search_text, options, true, // Force wrapping. | 2149 request_id, search_text, options, true, // Force wrapping. |
| 2150 &selection_rect); | 2150 &selection_rect); |
| 2151 } | 2151 } |
| 2152 } | 2152 } |
| 2153 | 2153 |
| 2154 // TODO(jcampan): http://b/issue?id=1157486 Remove StoreForFocus call once | |
| 2155 // we have the fix for 792423. | |
| 2156 search_frame->GetView()->StoreFocusForFrame(search_frame); | |
| 2157 webview()->SetFocusedFrame(search_frame); | 2154 webview()->SetFocusedFrame(search_frame); |
| 2158 } while (!result && search_frame != focused_frame); | 2155 } while (!result && search_frame != focused_frame); |
| 2159 | 2156 |
| 2160 // Make sure we don't leave any frame focused or the focus won't be restored | |
| 2161 // properly in WebViewImpl::SetFocus(). Note that we are talking here about | |
| 2162 // focused on the SelectionController, not FocusController. | |
| 2163 // webview()->GetFocusedFrame() will still return the last focused frame (as | |
| 2164 // it queries the FocusController). | |
| 2165 // TODO(jcampan): http://b/issue?id=1157486 Remove next line once we have the | |
| 2166 // fix for 792423. | |
| 2167 webview()->SetFocusedFrame(NULL); | |
| 2168 | |
| 2169 if (options.findNext) { | 2157 if (options.findNext) { |
| 2170 // Force the main_frame to report the actual count. | 2158 // Force the main_frame to report the actual count. |
| 2171 main_frame->IncreaseMatchCount(0, request_id); | 2159 main_frame->IncreaseMatchCount(0, request_id); |
| 2172 } else { | 2160 } else { |
| 2173 // If nothing is found, set result to "0 of 0", otherwise, set it to | 2161 // If nothing is found, set result to "0 of 0", otherwise, set it to |
| 2174 // "-1 of 1" to indicate that we found at least one item, but we don't know | 2162 // "-1 of 1" to indicate that we found at least one item, but we don't know |
| 2175 // yet what is active. | 2163 // yet what is active. |
| 2176 int ordinal = result ? -1 : 0; // -1 here means, we might know more later. | 2164 int ordinal = result ? -1 : 0; // -1 here means, we might know more later. |
| 2177 int match_count = result ? 1 : 0; // 1 here means possibly more coming. | 2165 int match_count = result ? 1 : 0; // 1 here means possibly more coming. |
| 2178 | 2166 |
| (...skipping 791 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2970 Send(new ViewHostMsg_PasswordFormsSeen(routing_id_, password_forms)); | 2958 Send(new ViewHostMsg_PasswordFormsSeen(routing_id_, password_forms)); |
| 2971 } | 2959 } |
| 2972 | 2960 |
| 2973 void RenderView::Print(WebFrame* frame, bool script_initiated) { | 2961 void RenderView::Print(WebFrame* frame, bool script_initiated) { |
| 2974 DCHECK(frame); | 2962 DCHECK(frame); |
| 2975 if (print_helper_.get() == NULL) { | 2963 if (print_helper_.get() == NULL) { |
| 2976 print_helper_.reset(new PrintWebViewHelper(this)); | 2964 print_helper_.reset(new PrintWebViewHelper(this)); |
| 2977 } | 2965 } |
| 2978 print_helper_->Print(frame, script_initiated); | 2966 print_helper_->Print(frame, script_initiated); |
| 2979 } | 2967 } |
| OLD | NEW |