]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/arrangement.h
Convert all list containers to vectors
[libs/gltk.git] / source / arrangement.h
index 284d3f7edd7079279848ce4f9e1371e29d484b77..26e28a6f10f4967b45b480a8bd76005e84672f22 100644 (file)
@@ -1,15 +1,24 @@
 #ifndef MSP_GLTK_ARRANGEMENT_H_
 #define MSP_GLTK_ARRANGEMENT_H_
 
-#include <list>
+#include <stdexcept>
+#include <vector>
+#include <msp/core/noncopyable.h>
 #include "layout.h"
+#include "mspgltk_api.h"
 
 namespace Msp {
 namespace GLtk {
 
 class Widget;
 
-class Arrangement
+class MSPGLTK_API arrangement_error: public std::logic_error
+{
+public:
+       arrangement_error(const std::string &w): std::logic_error(w) { }
+};
+
+class MSPGLTK_API Arrangement: public NonCopyable
 {
 protected:
        enum Side
@@ -22,18 +31,17 @@ protected:
 
        struct Edge
        {
-               std::list<Widget *> widgets;
-               bool aligned;
-
-               Edge();
+               std::vector<Widget *> widgets;
+               bool aligned = false;
 
                bool empty() { return widgets.empty(); }
                void clear();
                void add(Widget &, bool);
+               void align();
        };
 
        Layout &layout;
-       Arrangement *parent;
+       Arrangement *parent = nullptr;
        Edge edges[4];
 
        Arrangement(Layout &);
@@ -48,8 +56,11 @@ protected:
        virtual void finish_widget(Widget &) = 0;
        virtual void finish_slot() = 0;
        const Edge &get_edge(Side s) const { return edges[s]; }
-       void add_constraint(Widget &, Layout::ConstraintType, Side);
-       void add_constraint(Widget &, Layout::ConstraintType, const Edge &);
+       void add_constraint(Widget &, Layout::ConstraintType, Side, int = -1);
+       void add_constraint(Widget &, Layout::ConstraintType, const Edge &, int = -1);
+
+       static Layout::ConstraintType get_order_constraint(Side, bool);
+       static Layout::ConstraintType get_align_constraint(Side);
 };
 
 } // namespace GLtk