From 6304261b980419eaafde84bc32ff5e8f1c7aa236 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Tue, 27 Dec 2011 01:42:49 +0000 Subject: Re-work layering in possibly debatable ways. Sketchy docs in doc/layering. git-svn-id: svn://localhost/ardour2/branches/3.0@11088 d708f5d6-7413-0410-9779-e7cbd77b26cf --- libs/ardour/ardour/region_sorters.h | 27 ++++++++++----------------- 1 file changed, 10 insertions(+), 17 deletions(-) (limited to 'libs/ardour/ardour/region_sorters.h') diff --git a/libs/ardour/ardour/region_sorters.h b/libs/ardour/ardour/region_sorters.h index ee34dcaafe..0e3203ef20 100644 --- a/libs/ardour/ardour/region_sorters.h +++ b/libs/ardour/ardour/region_sorters.h @@ -30,31 +30,24 @@ struct RegionSortByPosition { } }; -struct RegionSortByLastLayerOp { +struct RegionSortByLayer { bool operator() (boost::shared_ptr a, boost::shared_ptr b) { - return a->last_layer_op() < b->last_layer_op(); + return a->layer() < b->layer(); } }; -struct RegionSortByLayer { +struct RegionSortByAdd { bool operator() (boost::shared_ptr a, boost::shared_ptr b) { - return a->layer() < b->layer(); + return ( + (a->last_layer_op (LayerOpAdd) < b->last_layer_op (LayerOpAdd)) + ); } }; -struct RegionSortByLayerWithPending { - bool operator () (boost::shared_ptr a, boost::shared_ptr b) { - - double p = a->layer (); - if (a->pending_explicit_relayer()) { - p += 0.5; - } - - double q = b->layer (); - if (b->pending_explicit_relayer()) { - q += 0.5; - } - +struct RegionSortByAddOrBounds { + bool operator() (boost::shared_ptr a, boost::shared_ptr b) { + uint64_t const p = std::max (a->last_layer_op (LayerOpAdd), a->last_layer_op (LayerOpBoundsChange)); + uint64_t const q = std::max (b->last_layer_op (LayerOpAdd), b->last_layer_op (LayerOpBoundsChange)); return p < q; } }; -- cgit v1.2.3