--- /dev/null
+/*
+winnie - an experimental window system
+
+Copyright (C) 2013 Eleni Maria Stea
+
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+Author: Eleni Maria Stea <elene.mst@gmail.com>
+*/
+
+#include "geom.h"
+
+Rect::Rect()
+{
+ x = y = width = height = 0;
+}
+
+Rect::Rect(int x, int y, int w, int h)
+{
+ this->x = x;
+ this->y = y;
+ width = w;
+ height = h;
+}
+
+static inline int min(int x, int y)
+{
+ return x < y ? x : y;
+}
+
+static inline int max(int x, int y)
+{
+ return x > y ? x : y;
+}
+
+Rect rect_union(const Rect &a, const Rect &b)
+{
+ Rect uni;
+ uni.x = min(a.x, b.x);
+ uni.y = min(a.y, b.y);
+ uni.width = max(a.x + a.width, b.x + b.width) - uni.x;
+ uni.height = max(a.y + a.height, b.y + b.height) - uni.y;
+
+ return uni;
+}
+
+Rect rect_intersection(const Rect &a, const Rect &b)
+{
+ Rect intersect;
+ intersect.x = max(a.x, b.x);
+ intersect.y = max(a.y, b.y);
+ intersect.width = max(min(a.x + a.width, b.x + b.width) - intersect.x, 0);
+ intersect.height = max(min(a.y + a.height, b.y + b.height) - intersect.y, 0);
+
+ return intersect;
+}