/*
- Copyright (C) 2000 Paul Davis
+ Copyright (C) 2000 Paul Davis
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
#include <iostream>
-#include <glibmm/thread.h>
+#include <glibmm/threads.h>
-#include <ardour/session.h>
-#include <ardour/route.h>
+#include "ardour/session.h"
+#include "ardour/route.h"
namespace ARDOUR {
-template<class T> void
-Session::foreach_route (T *obj, void (T::*func)(Route&))
+template<class T> void
+Session::foreach_route (T *obj, void (T::*func)(Route&), bool sort)
{
boost::shared_ptr<RouteList> r = routes.reader();
RouteList public_order (*r);
- RoutePublicOrderSorter cmp;
- public_order.sort (cmp);
+ if (sort) {
+ public_order.sort (Stripable::Sorter ());
+ }
for (RouteList::iterator i = public_order.begin(); i != public_order.end(); i++) {
(obj->*func) (**i);
}
}
-template<class T> void
-Session::foreach_route (T *obj, void (T::*func)(boost::shared_ptr<Route>))
+template<class T> void
+Session::foreach_route (T *obj, void (T::*func)(boost::shared_ptr<Route>), bool sort)
{
boost::shared_ptr<RouteList> r = routes.reader();
RouteList public_order (*r);
- RoutePublicOrderSorter cmp;
- public_order.sort (cmp);
+ if (sort) {
+ public_order.sort (Stripable::Sorter ());
+ }
for (RouteList::iterator i = public_order.begin(); i != public_order.end(); i++) {
(obj->*func) (*i);
}
}
-template<class T, class A> void
-Session::foreach_route (T *obj, void (T::*func)(Route&, A), A arg1)
+template<class T, class A> void
+Session::foreach_route (T *obj, void (T::*func)(Route&, A), A arg1, bool sort)
{
boost::shared_ptr<RouteList> r = routes.reader();
RouteList public_order (*r);
- RoutePublicOrderSorter cmp;
- public_order.sort (cmp);
+ if (sort) {
+ public_order.sort (Stripable::Sorter ());
+ }
for (RouteList::iterator i = public_order.begin(); i != public_order.end(); i++) {
(obj->*func) (**i, arg1);