| Index: chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc | 
| diff --git a/chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc b/chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..aa6caf3a1ccc05060173e1557af7730cb6c14f73 | 
| --- /dev/null | 
| +++ b/chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc | 
| @@ -0,0 +1,55 @@ | 
| +// Copyright (c) 2014 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 "base/values.h" | 
| +#include "chrome/test/chromedriver/chrome/device_metrics.h" | 
| +#include "chrome/test/chromedriver/chrome/devtools_client.h" | 
| +#include "chrome/test/chromedriver/chrome/mobile_emulation_override_manager.h" | 
| +#include "chrome/test/chromedriver/chrome/status.h" | 
| + | 
| +MobileEmulationOverrideManager::MobileEmulationOverrideManager( | 
| +    DevToolsClient* client, | 
| +    const DeviceMetrics* device_metrics) | 
| +    : client_(client), overridden_device_metrics_(device_metrics) { | 
| +  if (overridden_device_metrics_) | 
| +    client_->AddListener(this); | 
| +} | 
| + | 
| +MobileEmulationOverrideManager::~MobileEmulationOverrideManager() { | 
| +} | 
| + | 
| +Status MobileEmulationOverrideManager::OnConnected(DevToolsClient* client) { | 
| +  return ApplyOverrideIfNeeded(); | 
| +} | 
| + | 
| +Status MobileEmulationOverrideManager::OnEvent( | 
| +    DevToolsClient* client, | 
| +    const std::string& method, | 
| +    const base::DictionaryValue& params) { | 
| +  if (method == "Page.frameNavigated") { | 
| +    const base::Value* unused_value; | 
| +    if (!params.Get("frame.parentId", &unused_value)) | 
| +      return ApplyOverrideIfNeeded(); | 
| +  } | 
| +  return Status(kOk); | 
| +} | 
| + | 
| +Status MobileEmulationOverrideManager::ApplyOverrideIfNeeded() { | 
| +  if (overridden_device_metrics_ == NULL) | 
| +    return Status(kOk); | 
| + | 
| +  base::DictionaryValue params; | 
| +  params.SetInteger("width", overridden_device_metrics_->width); | 
| +  params.SetInteger("height", overridden_device_metrics_->height); | 
| +  params.SetDouble("deviceScaleFactor", | 
| +                   overridden_device_metrics_->device_scale_factor); | 
| +  params.SetBoolean("emulateViewport", | 
| +                    overridden_device_metrics_->emulate_viewport); | 
| +  params.SetBoolean("fitWindow", overridden_device_metrics_->fit_window); | 
| +  params.SetBoolean("textAutosizing", | 
| +                    overridden_device_metrics_->text_autosizing); | 
| +  params.SetDouble("fontScaleFactor", | 
| +                   overridden_device_metrics_->font_scale_factor); | 
| +  return client_->SendCommand("Page.setDeviceMetricsOverride", params); | 
| +} | 
|  |