Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(425)

Side by Side Diff: chrome/browser/ui/views/tabs/browser_tab_strip_controller.cc

Issue 2581023002: Add tab status to accessibility labels (Closed)
Patch Set: Add check for active browser tab index to prevent crashes Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/browser/ui/views/tabs/browser_tab_strip_controller.h" 5 #include "chrome/browser/ui/views/tabs/browser_tab_strip_controller.h"
6 6
7 #include "base/auto_reset.h" 7 #include "base/auto_reset.h"
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/task_runner_util.h" 9 #include "base/task_runner_util.h"
10 #include "base/threading/sequenced_worker_pool.h" 10 #include "base/threading/sequenced_worker_pool.h"
(...skipping 16 matching lines...) Expand all
27 #include "chrome/browser/ui/views/tabs/tab_renderer_data.h" 27 #include "chrome/browser/ui/views/tabs/tab_renderer_data.h"
28 #include "chrome/browser/ui/views/tabs/tab_strip.h" 28 #include "chrome/browser/ui/views/tabs/tab_strip.h"
29 #include "chrome/common/pref_names.h" 29 #include "chrome/common/pref_names.h"
30 #include "chrome/common/url_constants.h" 30 #include "chrome/common/url_constants.h"
31 #include "components/metrics/proto/omnibox_event.pb.h" 31 #include "components/metrics/proto/omnibox_event.pb.h"
32 #include "components/mime_util/mime_util.h" 32 #include "components/mime_util/mime_util.h"
33 #include "components/omnibox/browser/autocomplete_classifier.h" 33 #include "components/omnibox/browser/autocomplete_classifier.h"
34 #include "components/omnibox/browser/autocomplete_match.h" 34 #include "components/omnibox/browser/autocomplete_match.h"
35 #include "components/prefs/pref_service.h" 35 #include "components/prefs/pref_service.h"
36 #include "content/public/browser/browser_thread.h" 36 #include "content/public/browser/browser_thread.h"
37 #include "content/public/browser/navigation_controller.h"
38 #include "content/public/browser/navigation_entry.h"
39 #include "content/public/browser/navigation_handle.h"
37 #include "content/public/browser/notification_service.h" 40 #include "content/public/browser/notification_service.h"
38 #include "content/public/browser/plugin_service.h" 41 #include "content/public/browser/plugin_service.h"
39 #include "content/public/browser/user_metrics.h" 42 #include "content/public/browser/user_metrics.h"
40 #include "content/public/browser/web_contents.h" 43 #include "content/public/browser/web_contents.h"
41 #include "content/public/common/webplugininfo.h" 44 #include "content/public/common/webplugininfo.h"
42 #include "ipc/ipc_message.h" 45 #include "ipc/ipc_message.h"
43 #include "net/base/filename_util.h" 46 #include "net/base/filename_util.h"
44 #include "ui/base/models/list_selection_model.h" 47 #include "ui/base/models/list_selection_model.h"
45 #include "ui/gfx/image/image.h" 48 #include "ui/gfx/image/image.h"
46 #include "ui/views/controls/menu/menu_runner.h" 49 #include "ui/views/controls/menu/menu_runner.h"
47 #include "ui/views/widget/widget.h" 50 #include "ui/views/widget/widget.h"
48 #include "url/origin.h" 51 #include "url/origin.h"
49 52
50 using base::UserMetricsAction; 53 using base::UserMetricsAction;
51 using content::WebContents; 54 using content::WebContents;
52 55
53 namespace { 56 namespace {
54 57
55 TabRendererData::NetworkState TabContentsNetworkState( 58 TabRendererData::NetworkState TabContentsNetworkState(
56 WebContents* contents) { 59 WebContents* contents) {
57 if (!contents || !contents->IsLoadingToDifferentDocument()) 60 if (!contents)
58 return TabRendererData::NETWORK_STATE_NONE; 61 return TabRendererData::NETWORK_STATE_NONE;
62
63 if (!contents->IsLoadingToDifferentDocument()) {
64 content::NavigationEntry* entry =
65 contents->GetController().GetLastCommittedEntry();
66 if (entry && (entry->GetPageType() == content::PAGE_TYPE_ERROR))
67 return TabRendererData::NETWORK_STATE_ERROR;
68 return TabRendererData::NETWORK_STATE_NONE;
69 }
70
59 if (contents->IsWaitingForResponse()) 71 if (contents->IsWaitingForResponse())
60 return TabRendererData::NETWORK_STATE_WAITING; 72 return TabRendererData::NETWORK_STATE_WAITING;
61 return TabRendererData::NETWORK_STATE_LOADING; 73 return TabRendererData::NETWORK_STATE_LOADING;
62 } 74 }
63 75
64 bool DetermineTabStripLayoutStacked(PrefService* prefs, bool* adjust_layout) { 76 bool DetermineTabStripLayoutStacked(PrefService* prefs, bool* adjust_layout) {
65 *adjust_layout = false; 77 *adjust_layout = false;
66 // For ash, always allow entering stacked mode. 78 // For ash, always allow entering stacked mode.
67 #if defined(USE_ASH) 79 #if defined(USE_ASH)
68 *adjust_layout = true; 80 *adjust_layout = true;
(...skipping 344 matching lines...) Expand 10 before | Expand all | Expand 10 after
413 base::Bind(&BrowserTabStripController::OnFindURLMimeTypeCompleted, 425 base::Bind(&BrowserTabStripController::OnFindURLMimeTypeCompleted,
414 weak_ptr_factory_.GetWeakPtr(), 426 weak_ptr_factory_.GetWeakPtr(),
415 url)); 427 url));
416 } 428 }
417 429
418 SkColor BrowserTabStripController::GetToolbarTopSeparatorColor() const { 430 SkColor BrowserTabStripController::GetToolbarTopSeparatorColor() const {
419 return BrowserView::GetBrowserViewForBrowser(browser_)->frame() 431 return BrowserView::GetBrowserViewForBrowser(browser_)->frame()
420 ->GetFrameView()->GetToolbarTopSeparatorColor(); 432 ->GetFrameView()->GetToolbarTopSeparatorColor();
421 } 433 }
422 434
435 base::string16 BrowserTabStripController::GetAccessibleTabName() const {
436 return BrowserView::GetBrowserViewForBrowser(browser_)
sky 2016/12/16 00:52:51 Can you change BrowserTabStripController to take a
edwardjung 2016/12/19 12:59:25 Good point, fixed.
437 ->GetAccessibleWindowTitle();
438 }
439
423 //////////////////////////////////////////////////////////////////////////////// 440 ////////////////////////////////////////////////////////////////////////////////
424 // BrowserTabStripController, TabStripModelObserver implementation: 441 // BrowserTabStripController, TabStripModelObserver implementation:
425 442
426 void BrowserTabStripController::TabInsertedAt(TabStripModel* tab_strip_model, 443 void BrowserTabStripController::TabInsertedAt(TabStripModel* tab_strip_model,
427 WebContents* contents, 444 WebContents* contents,
428 int model_index, 445 int model_index,
429 bool is_active) { 446 bool is_active) {
430 DCHECK(contents); 447 DCHECK(contents);
431 DCHECK(model_->ContainsIndex(model_index)); 448 DCHECK(model_->ContainsIndex(model_index));
432 AddTab(contents, model_index, is_active); 449 AddTab(contents, model_index, is_active);
(...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after
571 content::WebPluginInfo plugin; 588 content::WebPluginInfo plugin;
572 tabstrip_->FileSupported( 589 tabstrip_->FileSupported(
573 url, 590 url,
574 mime_type.empty() || mime_util::IsSupportedMimeType(mime_type) || 591 mime_type.empty() || mime_util::IsSupportedMimeType(mime_type) ||
575 content::PluginService::GetInstance()->GetPluginInfo( 592 content::PluginService::GetInstance()->GetPluginInfo(
576 -1, // process ID 593 -1, // process ID
577 MSG_ROUTING_NONE, // routing ID 594 MSG_ROUTING_NONE, // routing ID
578 model_->profile()->GetResourceContext(), url, url::Origin(), 595 model_->profile()->GetResourceContext(), url, url::Origin(),
579 mime_type, false, NULL, &plugin, NULL)); 596 mime_type, false, NULL, &plugin, NULL));
580 } 597 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698