Héctor Ramos da7873563b Migrate Android sources to MIT license header
Reviewed By: fkgozali

Differential Revision: D8065619

fbshipit-source-id: 719c303b40c96950bab8e5dde9a75f449b2956c6
2018-05-31 15:37:30 -07:00

130 lines
2.7 KiB
C++

// Copyright (c) 2004-present, Facebook, Inc.
// This source code is licensed under the MIT license found in the
// LICENSE file in the root directory of this source tree.
#pragma once
#include <algorithm>
#include <tuple>
#include <CoreGraphics/CGBase.h>
namespace facebook {
namespace react {
/*
* Exact type of float numbers which ideally should match a type behing
* platform- and chip-architecture-specific float type.
*/
using Float = CGFloat;
/*
* Large positive number signifies that the `Float` values is `undefined`.
*/
const Float kFloatUndefined = CGFLOAT_MAX;
const Float kFloatMax = CGFLOAT_MAX;
const Float kFloatMin = CGFLOAT_MIN;
/*
* Point
*/
struct Point {
Float x {0};
Float y {0};
Point& operator += (const Point& rhs) {
x += rhs.x;
y += rhs.y;
return *this;
}
friend Point operator + (Point lhs, const Point& rhs) {
return lhs += rhs;
}
bool operator ==(const Point& rhs) const {
return
std::tie(this->x, this->y) ==
std::tie(rhs.x, rhs.y);
}
bool operator !=(const Point& rhs) const {
return !(*this == rhs);
}
};
/*
* Size
*/
struct Size {
Float width {0};
Float height {0};
bool operator ==(const Size& rhs) const {
return
std::tie(this->width, this->height) ==
std::tie(rhs.width, rhs.height);
}
bool operator !=(const Size& rhs) const {
return !(*this == rhs);
}
};
/*
* Rect: Point and Size
*/
struct Rect {
Point origin {0, 0};
Size size {0, 0};
bool operator ==(const Rect& rhs) const {
return
std::tie(this->origin, this->size) ==
std::tie(rhs.origin, rhs.size);
}
bool operator !=(const Rect& rhs) const {
return !(*this == rhs);
}
Float getMaxX() const { return size.width > 0 ? origin.x + size.width : origin.x; }
Float getMaxY() const { return size.height > 0 ? origin.y + size.height : origin.y; }
Float getMinX() const { return size.width >= 0 ? origin.x : origin.x + size.width; }
Float getMinY() const { return size.height >= 0 ? origin.y : origin.y + size.height; }
void unionInPlace(const Rect &rect) {
Float x1 = std::min(getMinX(), rect.getMinX());
Float y1 = std::min(getMinY(), rect.getMinY());
Float x2 = std::max(getMaxX(), rect.getMaxX());
Float y2 = std::max(getMaxY(), rect.getMaxY());
origin = {x1, y1};
size = {x2 - x1, y2 - y1};
}
};
/*
* EdgeInsets
*/
struct EdgeInsets {
Float left {0};
Float top {0};
Float right {0};
Float bottom {0};
bool operator ==(const EdgeInsets& rhs) const {
return
std::tie(this->left, this->top, this->right, this->bottom) ==
std::tie(rhs.left, rhs.top, rhs.right, rhs.bottom);
}
bool operator !=(const EdgeInsets& rhs) const {
return !(*this == rhs);
}
};
} // namespace react
} // namespace facebook