| // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #include "chrome/browser/automation/testing_automation_provider.h" |
| |
| #import <Cocoa/Cocoa.h> |
| |
| #include "ui/base/l10n/l10n_util.h" |
| #include "base/logging.h" |
| #include "base/strings/sys_string_conversions.h" |
| #include "chrome/browser/automation/automation_browser_tracker.h" |
| #include "chrome/browser/automation/automation_window_tracker.h" |
| #import "chrome/browser/ui/cocoa/browser_window_controller.h" |
| #include "chrome/browser/ui/cocoa/tabs/tab_window_controller.h" |
| #include "chrome/browser/ui/view_ids.h" |
| #include "grit/generated_resources.h" |
| #include "ui/base/l10n/l10n_util_mac.h" |
| |
| void TestingAutomationProvider::TerminateSession(int handle, bool* success) { |
| *success = false; |
| NOTIMPLEMENTED(); |
| } |
| |
| void TestingAutomationProvider::WindowGetViewBounds(int handle, |
| int view_id, |
| bool screen_coordinates, |
| bool* success, |
| gfx::Rect* bounds) { |
| *success = false; |
| |
| // At the moment we hard code the view ID used by WebDriver and do |
| // not support arbitrary view IDs. suzhe is working on general view |
| // ID support for the Mac. |
| if (view_id != VIEW_ID_TAB_CONTAINER) { |
| NOTIMPLEMENTED(); |
| return; |
| } |
| |
| NSWindow* window = window_tracker_->GetResource(handle); |
| if (!window) |
| return; |
| |
| BrowserWindowController* controller = [window windowController]; |
| DCHECK([controller isKindOfClass:[BrowserWindowController class]]); |
| if (![controller isKindOfClass:[BrowserWindowController class]]) |
| return; |
| NSView* tab = |
| [[[controller tabStripController] activeTabContentsController] view]; |
| if (!tab) |
| return; |
| |
| NSRect rect = [tab convertRect:[tab bounds] toView:nil]; |
| // The origin of the bounding box should be the top left of the tab contents, |
| // not bottom left, to match other platforms. |
| rect.origin.y += rect.size.height; |
| CGFloat coord_sys_height; |
| if (screen_coordinates && [[NSScreen screens] count] > 0) { |
| rect.origin = [window convertBaseToScreen:rect.origin]; |
| coord_sys_height = |
| [[[NSScreen screens] objectAtIndex:0] frame].size.height; |
| } else { |
| coord_sys_height = [window frame].size.height; |
| } |
| // Flip coordinate system. |
| rect.origin.y = coord_sys_height - rect.origin.y; |
| *bounds = gfx::Rect(NSRectToCGRect(rect)); |
| *success = true; |
| } |
| |
| void TestingAutomationProvider::SetWindowBounds(int handle, |
| const gfx::Rect& bounds, |
| bool* success) { |
| *success = false; |
| NSWindow* window = window_tracker_->GetResource(handle); |
| if (window) { |
| NSRect new_bounds = NSRectFromCGRect(bounds.ToCGRect()); |
| |
| if ([[NSScreen screens] count] > 0) { |
| new_bounds.origin.y = |
| [[[NSScreen screens] objectAtIndex:0] frame].size.height - |
| new_bounds.origin.y - new_bounds.size.height; |
| } |
| |
| [window setFrame:new_bounds display:NO]; |
| *success = true; |
| } |
| } |