OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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/browser_commands.h" | 5 #include "chrome/browser/ui/browser_commands.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
9 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
10 #include "base/strings/utf_string_conversions.h" | 10 #include "base/strings/utf_string_conversions.h" |
(...skipping 644 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
655 // window next to the tab being duplicated. | 655 // window next to the tab being duplicated. |
656 int index = browser->tab_strip_model()->GetIndexOfWebContents(contents); | 656 int index = browser->tab_strip_model()->GetIndexOfWebContents(contents); |
657 pinned = browser->tab_strip_model()->IsTabPinned(index); | 657 pinned = browser->tab_strip_model()->IsTabPinned(index); |
658 int add_types = TabStripModel::ADD_ACTIVE | | 658 int add_types = TabStripModel::ADD_ACTIVE | |
659 TabStripModel::ADD_INHERIT_GROUP | | 659 TabStripModel::ADD_INHERIT_GROUP | |
660 (pinned ? TabStripModel::ADD_PINNED : 0); | 660 (pinned ? TabStripModel::ADD_PINNED : 0); |
661 browser->tab_strip_model()->InsertWebContentsAt( | 661 browser->tab_strip_model()->InsertWebContentsAt( |
662 index + 1, contents_dupe, add_types); | 662 index + 1, contents_dupe, add_types); |
663 } else { | 663 } else { |
664 Browser* new_browser = NULL; | 664 Browser* new_browser = NULL; |
665 if (browser->is_app() && | 665 if (browser->is_app() && browser->type() == Browser::TYPE_HOSTED_POPUP) { |
666 !browser->is_type_popup()) { | |
667 new_browser = new Browser( | 666 new_browser = new Browser( |
668 Browser::CreateParams::CreateForApp(browser->type(), | 667 Browser::CreateParams::CreateForApp(Browser::TYPE_HOSTED_POPUP, |
669 browser->app_name(), | 668 browser->app_name(), |
670 gfx::Rect(), | 669 gfx::Rect(), |
671 browser->profile(), | 670 browser->profile(), |
672 browser->host_desktop_type())); | 671 browser->host_desktop_type())); |
673 } else { | 672 } else { |
674 new_browser = new Browser( | 673 new_browser = new Browser( |
675 Browser::CreateParams(browser->type(), browser->profile(), | 674 Browser::CreateParams(browser->type(), browser->profile(), |
676 browser->host_desktop_type())); | 675 browser->host_desktop_type())); |
677 } | 676 } |
678 // Preserve the size of the original window. The new window has already | 677 // Preserve the size of the original window. The new window has already |
(...skipping 555 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1234 content::WebContents* contents) { | 1233 content::WebContents* contents) { |
1235 const GURL& url = contents->GetController().GetActiveEntry()->GetURL(); | 1234 const GURL& url = contents->GetController().GetActiveEntry()->GetURL(); |
1236 std::string app_name = web_app::GenerateApplicationNameFromURL(url); | 1235 std::string app_name = web_app::GenerateApplicationNameFromURL(url); |
1237 | 1236 |
1238 int index = browser->tab_strip_model()->GetIndexOfWebContents(contents); | 1237 int index = browser->tab_strip_model()->GetIndexOfWebContents(contents); |
1239 if (index >= 0) | 1238 if (index >= 0) |
1240 browser->tab_strip_model()->DetachWebContentsAt(index); | 1239 browser->tab_strip_model()->DetachWebContentsAt(index); |
1241 | 1240 |
1242 Browser* app_browser = new Browser( | 1241 Browser* app_browser = new Browser( |
1243 Browser::CreateParams::CreateForApp( | 1242 Browser::CreateParams::CreateForApp( |
1244 Browser::TYPE_POPUP, app_name, gfx::Rect(), browser->profile(), | 1243 Browser::TYPE_HOSTED_POPUP, app_name, gfx::Rect(), browser->profile(), |
1245 browser->host_desktop_type())); | 1244 browser->host_desktop_type())); |
1246 app_browser->tab_strip_model()->AppendWebContents(contents, true); | 1245 app_browser->tab_strip_model()->AppendWebContents(contents, true); |
1247 | 1246 |
1248 contents->GetMutableRendererPrefs()->can_accept_load_drops = false; | 1247 contents->GetMutableRendererPrefs()->can_accept_load_drops = false; |
1249 contents->GetRenderViewHost()->SyncRendererPrefs(); | 1248 contents->GetRenderViewHost()->SyncRendererPrefs(); |
1250 app_browser->window()->Show(); | 1249 app_browser->window()->Show(); |
1251 } | 1250 } |
1252 | 1251 |
1253 } // namespace chrome | 1252 } // namespace chrome |
OLD | NEW |