| Index: ui/gfx/rect.h
 | 
| diff --git a/ui/gfx/rect.h b/ui/gfx/rect.h
 | 
| index df7f9aac366c9bd39ce5c03a0202c7776805a4e7..a83d6b42cef04fb86489704f6c79ac6ac717ac6e 100644
 | 
| --- a/ui/gfx/rect.h
 | 
| +++ b/ui/gfx/rect.h
 | 
| @@ -1,145 +1,7 @@
 | 
| -// Copyright (c) 2012 The Chromium Authors. All rights reserved.
 | 
| +// Copyright 2013 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.
 | 
|  
 | 
| -// Defines a simple integer rectangle class.  The containment semantics
 | 
| -// are array-like; that is, the coordinate (x, y) is considered to be
 | 
| -// contained by the rectangle, but the coordinate (x + width, y) is not.
 | 
| -// The class will happily let you create malformed rectangles (that is,
 | 
| -// rectangles with negative width and/or height), but there will be assertions
 | 
| -// in the operations (such as Contains()) to complain in this case.
 | 
| +// TODO(beng): remove once callsites are patched.
 | 
| +#include "ui/gfx/geometry/rect.h"
 | 
|  
 | 
| -#ifndef UI_GFX_RECT_H_
 | 
| -#define UI_GFX_RECT_H_
 | 
| -
 | 
| -#include <cmath>
 | 
| -#include <string>
 | 
| -
 | 
| -#include "ui/gfx/point.h"
 | 
| -#include "ui/gfx/rect_base.h"
 | 
| -#include "ui/gfx/rect_f.h"
 | 
| -#include "ui/gfx/size.h"
 | 
| -#include "ui/gfx/vector2d.h"
 | 
| -
 | 
| -#if defined(OS_WIN)
 | 
| -typedef struct tagRECT RECT;
 | 
| -#elif defined(TOOLKIT_GTK)
 | 
| -typedef struct _GdkRectangle GdkRectangle;
 | 
| -#elif defined(OS_IOS)
 | 
| -#include <CoreGraphics/CoreGraphics.h>
 | 
| -#elif defined(OS_MACOSX)
 | 
| -#include <ApplicationServices/ApplicationServices.h>
 | 
| -#endif
 | 
| -
 | 
| -namespace gfx {
 | 
| -
 | 
| -class Insets;
 | 
| -
 | 
| -class GFX_EXPORT Rect
 | 
| -    : public RectBase<Rect, Point, Size, Insets, Vector2d, int> {
 | 
| - public:
 | 
| -  Rect() : RectBase<Rect, Point, Size, Insets, Vector2d, int>(Point()) {}
 | 
| -
 | 
| -  Rect(int width, int height)
 | 
| -      : RectBase<Rect, Point, Size, Insets, Vector2d, int>
 | 
| -            (Size(width, height)) {}
 | 
| -
 | 
| -  Rect(int x, int y, int width, int height)
 | 
| -      : RectBase<Rect, Point, Size, Insets, Vector2d, int>
 | 
| -            (Point(x, y), Size(width, height)) {}
 | 
| -
 | 
| -#if defined(OS_WIN)
 | 
| -  explicit Rect(const RECT& r);
 | 
| -#elif defined(OS_MACOSX)
 | 
| -  explicit Rect(const CGRect& r);
 | 
| -#elif defined(TOOLKIT_GTK)
 | 
| -  explicit Rect(const GdkRectangle& r);
 | 
| -#endif
 | 
| -
 | 
| -  explicit Rect(const gfx::Size& size)
 | 
| -      : RectBase<Rect, Point, Size, Insets, Vector2d, int>(size) {}
 | 
| -
 | 
| -  Rect(const gfx::Point& origin, const gfx::Size& size)
 | 
| -      : RectBase<Rect, Point, Size, Insets, Vector2d, int>(origin, size) {}
 | 
| -
 | 
| -  ~Rect() {}
 | 
| -
 | 
| -#if defined(OS_WIN)
 | 
| -  // Construct an equivalent Win32 RECT object.
 | 
| -  RECT ToRECT() const;
 | 
| -#elif defined(TOOLKIT_GTK)
 | 
| -  GdkRectangle ToGdkRectangle() const;
 | 
| -#elif defined(OS_MACOSX)
 | 
| -  // Construct an equivalent CoreGraphics object.
 | 
| -  CGRect ToCGRect() const;
 | 
| -#endif
 | 
| -
 | 
| -  operator RectF() const {
 | 
| -    return RectF(origin().x(), origin().y(), size().width(), size().height());
 | 
| -  }
 | 
| -
 | 
| -  std::string ToString() const;
 | 
| -};
 | 
| -
 | 
| -inline bool operator==(const Rect& lhs, const Rect& rhs) {
 | 
| -  return lhs.origin() == rhs.origin() && lhs.size() == rhs.size();
 | 
| -}
 | 
| -
 | 
| -inline bool operator!=(const Rect& lhs, const Rect& rhs) {
 | 
| -  return !(lhs == rhs);
 | 
| -}
 | 
| -
 | 
| -GFX_EXPORT Rect operator+(const Rect& lhs, const Vector2d& rhs);
 | 
| -GFX_EXPORT Rect operator-(const Rect& lhs, const Vector2d& rhs);
 | 
| -
 | 
| -inline Rect operator+(const Vector2d& lhs, const Rect& rhs) {
 | 
| -  return rhs + lhs;
 | 
| -}
 | 
| -
 | 
| -GFX_EXPORT Rect IntersectRects(const Rect& a, const Rect& b);
 | 
| -GFX_EXPORT Rect UnionRects(const Rect& a, const Rect& b);
 | 
| -GFX_EXPORT Rect SubtractRects(const Rect& a, const Rect& b);
 | 
| -
 | 
| -// Constructs a rectangle with |p1| and |p2| as opposite corners.
 | 
| -//
 | 
| -// This could also be thought of as "the smallest rect that contains both
 | 
| -// points", except that we consider points on the right/bottom edges of the
 | 
| -// rect to be outside the rect.  So technically one or both points will not be
 | 
| -// contained within the rect, because they will appear on one of these edges.
 | 
| -GFX_EXPORT Rect BoundingRect(const Point& p1, const Point& p2);
 | 
| -
 | 
| -inline Rect ScaleToEnclosingRect(const Rect& rect,
 | 
| -                                 float x_scale,
 | 
| -                                 float y_scale) {
 | 
| -  int x = std::floor(rect.x() * x_scale);
 | 
| -  int y = std::floor(rect.y() * y_scale);
 | 
| -  int r = rect.width() == 0 ? x : std::ceil(rect.right() * x_scale);
 | 
| -  int b = rect.height() == 0 ? y : std::ceil(rect.bottom() * y_scale);
 | 
| -  return Rect(x, y, r - x, b - y);
 | 
| -}
 | 
| -
 | 
| -inline Rect ScaleToEnclosingRect(const Rect& rect, float scale) {
 | 
| -  return ScaleToEnclosingRect(rect, scale, scale);
 | 
| -}
 | 
| -
 | 
| -inline Rect ScaleToEnclosedRect(const Rect& rect,
 | 
| -                                float x_scale,
 | 
| -                                float y_scale) {
 | 
| -  int x = std::ceil(rect.x() * x_scale);
 | 
| -  int y = std::ceil(rect.y() * y_scale);
 | 
| -  int r = rect.width() == 0 ? x : std::floor(rect.right() * x_scale);
 | 
| -  int b = rect.height() == 0 ? y : std::floor(rect.bottom() * y_scale);
 | 
| -  return Rect(x, y, r - x, b - y);
 | 
| -}
 | 
| -
 | 
| -inline Rect ScaleToEnclosedRect(const Rect& rect, float scale) {
 | 
| -  return ScaleToEnclosedRect(rect, scale, scale);
 | 
| -}
 | 
| -
 | 
| -#if !defined(COMPILER_MSVC)
 | 
| -extern template class RectBase<Rect, Point, Size, Insets, Vector2d, int>;
 | 
| -#endif
 | 
| -
 | 
| -}  // namespace gfx
 | 
| -
 | 
| -#endif  // UI_GFX_RECT_H_
 | 
| 
 |