| Index: webkit/glue/dom_operations.cc | 
| diff --git a/webkit/glue/dom_operations.cc b/webkit/glue/dom_operations.cc | 
| index 2d0fb68644315e3d6590747f9ba078ae8d841713..07c43b295b72564fca454b452694be2b73bc0f30 100644 | 
| --- a/webkit/glue/dom_operations.cc | 
| +++ b/webkit/glue/dom_operations.cc | 
| @@ -7,8 +7,7 @@ | 
| #include <set> | 
|  | 
| #include "base/compiler_specific.h" | 
| -#include "base/string_number_conversions.h" | 
| -#include "base/string_split.h" | 
| +#include "base/logging.h" | 
| #include "base/string_util.h" | 
| #include "third_party/WebKit/WebKit/chromium/public/WebAnimationController.h" | 
| #include "third_party/WebKit/WebKit/chromium/public/WebDocument.h" | 
| @@ -239,139 +238,6 @@ bool GetAllSavableResourceLinksForCurrentPage(WebView* view, | 
| return true; | 
| } | 
|  | 
| -// Sizes a single size (the width or height) from a 'sizes' attribute. A size | 
| -// matches must match the following regex: [1-9][0-9]*. | 
| -static int ParseSingleIconSize(const string16& text) { | 
| -  // Size must not start with 0, and be between 0 and 9. | 
| -  if (text.empty() || !(text[0] >= L'1' && text[0] <= L'9')) | 
| -    return 0; | 
| -  // Make sure all chars are from 0-9. | 
| -  for (size_t i = 1; i < text.length(); ++i) { | 
| -    if (!(text[i] >= L'0' && text[i] <= L'9')) | 
| -      return 0; | 
| -  } | 
| -  int output; | 
| -  if (!base::StringToInt(text, &output)) | 
| -    return 0; | 
| -  return output; | 
| -} | 
| - | 
| -// Parses an icon size. An icon size must match the following regex: | 
| -// [1-9][0-9]*x[1-9][0-9]*. | 
| -// If the input couldn't be parsed, a size with a width/height < 0 is returned. | 
| -static gfx::Size ParseIconSize(const string16& text) { | 
| -  std::vector<string16> sizes; | 
| -  base::SplitStringDontTrim(text, L'x', &sizes); | 
| -  if (sizes.size() != 2) | 
| -    return gfx::Size(); | 
| - | 
| -  return gfx::Size(ParseSingleIconSize(sizes[0]), | 
| -                   ParseSingleIconSize(sizes[1])); | 
| -} | 
| - | 
| -WebApplicationInfo::WebApplicationInfo() {} | 
| - | 
| -WebApplicationInfo::~WebApplicationInfo() {} | 
| - | 
| -bool ParseIconSizes(const string16& text, | 
| -                    std::vector<gfx::Size>* sizes, | 
| -                    bool* is_any) { | 
| -  *is_any = false; | 
| -  std::vector<string16> size_strings; | 
| -  SplitStringAlongWhitespace(text, &size_strings); | 
| -  for (size_t i = 0; i < size_strings.size(); ++i) { | 
| -    if (EqualsASCII(size_strings[i], "any")) { | 
| -      *is_any = true; | 
| -    } else { | 
| -      gfx::Size size = ParseIconSize(size_strings[i]); | 
| -      if (size.width() <= 0 || size.height() <= 0) | 
| -        return false;  // Bogus size. | 
| -      sizes->push_back(size); | 
| -    } | 
| -  } | 
| -  if (*is_any && !sizes->empty()) { | 
| -    // If is_any is true, it must occur by itself. | 
| -    return false; | 
| -  } | 
| -  return (*is_any || !sizes->empty()); | 
| -} | 
| - | 
| -static void AddInstallIcon(const WebElement& link, | 
| -                           std::vector<WebApplicationInfo::IconInfo>* icons) { | 
| -  WebString href = link.getAttribute("href"); | 
| -  if (href.isNull() || href.isEmpty()) | 
| -    return; | 
| - | 
| -  // Get complete url. | 
| -  GURL url = link.document().completeURL(href); | 
| -  if (!url.is_valid()) | 
| -    return; | 
| - | 
| -  if (!link.hasAttribute("sizes")) | 
| -    return; | 
| - | 
| -  bool is_any = false; | 
| -  std::vector<gfx::Size> icon_sizes; | 
| -  if (!ParseIconSizes(link.getAttribute("sizes"), &icon_sizes, &is_any) || | 
| -      is_any || | 
| -      icon_sizes.size() != 1) { | 
| -    return; | 
| -  } | 
| -  WebApplicationInfo::IconInfo icon_info; | 
| -  icon_info.width = icon_sizes[0].width(); | 
| -  icon_info.height = icon_sizes[0].height(); | 
| -  icon_info.url = url; | 
| -  icons->push_back(icon_info); | 
| -} | 
| - | 
| -void GetApplicationInfo(WebView* view, WebApplicationInfo* app_info) { | 
| -  WebFrame* main_frame = view->mainFrame(); | 
| -  if (!main_frame) | 
| -    return; | 
| - | 
| -  WebDocument doc = main_frame->document(); | 
| -  if (doc.isNull()) | 
| -    return; | 
| - | 
| -  WebElement head = main_frame->document().head(); | 
| -  if (head.isNull()) | 
| -    return; | 
| - | 
| -  WebNodeList children = head.childNodes(); | 
| -  for (unsigned i = 0; i < children.length(); ++i) { | 
| -    WebNode child = children.item(i); | 
| -    if (!child.isElementNode()) | 
| -      continue; | 
| -    WebElement elem = child.to<WebElement>(); | 
| - | 
| -    if (elem.hasTagName("link")) { | 
| -      std::string rel = elem.getAttribute("rel").utf8(); | 
| -      // "rel" attribute may use either "icon" or "shortcut icon". | 
| -      // see also | 
| -      //   <http://en.wikipedia.org/wiki/Favicon> | 
| -      //   <http://dev.w3.org/html5/spec/Overview.html#rel-icon> | 
| -      if (LowerCaseEqualsASCII(rel, "icon") || | 
| -          LowerCaseEqualsASCII(rel, "shortcut icon")) | 
| -        AddInstallIcon(elem, &app_info->icons); | 
| -    } else if (elem.hasTagName("meta") && elem.hasAttribute("name")) { | 
| -      std::string name = elem.getAttribute("name").utf8(); | 
| -      WebString content = elem.getAttribute("content"); | 
| -      if (name == "application-name") { | 
| -        app_info->title = content; | 
| -      } else if (name == "description") { | 
| -        app_info->description = content; | 
| -      } else if (name == "application-url") { | 
| -        std::string url = content.utf8(); | 
| -        GURL main_url = main_frame->url(); | 
| -        app_info->app_url = main_url.is_valid() ? | 
| -            main_url.Resolve(url) : GURL(url); | 
| -        if (!app_info->app_url.is_valid()) | 
| -          app_info->app_url = GURL(); | 
| -      } | 
| -    } | 
| -  } | 
| -} | 
| - | 
| bool PauseAnimationAtTimeOnElementWithId(WebView* view, | 
| const std::string& animation_name, | 
| double time, | 
|  |