diff --git a/product/ERP5/Tool/SimulationTool.py b/product/ERP5/Tool/SimulationTool.py
index 6aba19cefb2f1bb3fe063c49ae564f023ef8faf2..557f95efaaccc607700e236d570cde94bd6144ca 100755
--- a/product/ERP5/Tool/SimulationTool.py
+++ b/product/ERP5/Tool/SimulationTool.py
@@ -226,9 +226,8 @@ class SimulationTool (Folder, UniqueObject):
                    Typically, check_list is :
                    (DateMovementList,PathMovementList,...)
       """
-      from Products.ERP5.MovementGroup import RootMovementGroup
       if check_list is None:
-        check_list = ()
+        check_list = []
       s_tool = self.portal_simulation
       my_root_group = s_tool.root_movement_group.getInstance(check_list=check_list)
       for movement in movement_list:
@@ -239,271 +238,32 @@ class SimulationTool (Folder, UniqueObject):
 
     #######################################################
     # Movement Group Collection / Delivery Creation
-    def collectMovement(self, movement_list,
-                        check_order = 1, check_path = 1, check_date = 1, check_criterion = 0,
-                        check_resource = 1, check_base_variant = 0, check_variant = 1):
-      current_order = 2
-      check_list = [check_order, check_path, check_date, check_criterion, check_resource, check_base_variant, check_variant]
-      for i in range(len(check_list)):
-        if check_list[i]:
-          check_list[i] = current_order
-          current_order += 1
-      check_order = check_list[0]
-      check_path = check_list[1]
-      check_date = check_list[2]
-      check_criterion = check_list[3]
-      check_resource = check_list[4]
-      check_base_variant = check_list[5]
-      check_variant = check_list[6]
-    
-      return self.orderedCollectMovement(movement_list=movement_list,
-                                    check_order=check_order,
-                                    check_path=check_path,
-                                    check_date=check_date,
-                                    check_criterion=check_criterion,
-                                    check_resource=check_resource,
-                                    check_base_variant=check_base_variant,
-                                    check_variant=check_variant)
-    
-                                    
-    def orderedCollectMovement(self, movement_list,
-                        check_order = 2, check_path = 3, check_date = 4, check_criterion = 0,
-                        check_resource = 5, check_base_variant = 0, check_variant = 6):
-      LOG('orderedCollectMovement :', 0, 'movement_list = %s' % repr(movement_list))
-
-      class RootGroup:
-
-        def getNestedClass(self, class_list):
-          for a in class_list:
-            if a[0]:
-              return a[1]
-          return None
-
-        def setNestedClass(self):
-          """
-            This sets an appropriate nested class.
-          """
-          def cmpfunc(a,b):
-            return cmp(a[0],b[0])
-          
-          class_list = [(1, RootGroup),
-                        (check_order, OrderGroup),
-                        (check_path, PathGroup),
-                        (check_date, DateGroup),
-                        (check_criterion, CriterionGroup),
-                        (check_resource, ResourceGroup),
-                        (check_base_variant, BaseVariantGroup),
-                        (check_variant, VariantGroup),
-                        ]
-          class_list.sort(cmpfunc)
-          for i in range(len(class_list)):
-            if class_list[i][1] == self.__class__:
-              break
-          else:
-            raise RuntimeError, "no appropriate nested class is found for %s" % str(self)
-
-          self.nested_class = self.getNestedClass(class_list[i+1:])
-
-        def __init__(self, movement=None):
-          self.nested_class = None
-          self.setNestedClass()
-          self.movement_list = []
-          self.group_list = []
-          if movement is not None :
-            self.append(movement)
-
-        def appendGroup(self, movement):
-          if self.nested_class is not None:
-            self.group_list.append(self.nested_class(movement))
-
-        def append(self,movement):
-          self.movement_list.append(movement)
-          movement_in_group = 0
-          for group in self.group_list :
-            if group.test(movement) :
-              group.append(movement)
-              movement_in_group = 1
-              break
-          if movement_in_group == 0 :
-            self.appendGroup(movement)
-
-      class OrderGroup(RootGroup):
-
-        def __init__(self,movement):
-          RootGroup.__init__(self,movement)
-          if hasattr(movement, 'getRootAppliedRule'):
-            # This is a simulation movement
-            order_value = movement.getRootAppliedRule().getCausalityValue(
-                                                      portal_type=order_type_list)
-            if order_value is None:
-              # In some cases (ex. DeliveryRule), there is no order
-              # we may consider a PackingList as the order in the OrderGroup
-              order_value = movement.getRootAppliedRule().getCausalityValue(
-                              portal_type=delivery_type_list)
-          else:
-            # This is a temp movement
-            order_value = None
-          if order_value is None:
-            order_relative_url = None
-          else:
-            # get the id of the enclosing delivery
-            # for this cell or line
-            order_relative_url = order_value.getRelativeUrl()
-          self.order = order_relative_url
-
-        def test(self,movement):
-          if hasattr(movement, 'getRootAppliedRule'):
-            order_value = movement.getRootAppliedRule().getCausalityValue(
-                                                        portal_type=order_type_list)
-
-            if order_value is None:
-              # In some cases (ex. DeliveryRule), there is no order
-              # we may consider a PackingList as the order in the OrderGroup
-              order_value = movement.getRootAppliedRule().getCausalityValue(
-                              portal_type=delivery_type_list)
-          else:
-            # This is a temp movement
-            order_value = None
-          if order_value is None:
-            order_relative_url = None
-          else:
-            # get the id of the enclosing delivery
-            # for this cell or line
-            order_relative_url = order_value.getRelativeUrl()
-          if order_relative_url == self.order:
-            return 1
-          else :
-            return 0
-
-      class PathGroup(RootGroup):
-
-        def __init__(self,movement):
-          RootGroup.__init__(self,movement)
-          self.source = movement.getSource()
-          self.destination = movement.getDestination()
-          self.source_section = movement.getSourceSection()
-          self.destination_section = movement.getDestinationSection()
-          self.target_source = movement.getTargetSource()
-          self.target_destination = movement.getTargetDestination()
-          self.target_source_section = movement.getTargetSourceSection()
-          self.target_destination_section = movement.getTargetDestinationSection()
-
-
-        def test(self,movement):
-          if movement.getSource() == self.source and \
-            movement.getDestination() == self.destination and \
-            movement.getSourceSection() == self.source_section and \
-            movement.getDestinationSection() == self.destination_section and \
-            movement.getTargetSource() == self.target_source and \
-            movement.getTargetDestination() == self.target_destination and \
-            movement.getTargetSourceSection() == self.target_source_section and \
-            movement.getTargetDestinationSection() == self.target_destination_section :
-
-            return 1
-          else :
-            return 0
-
-      class DateGroup(RootGroup):
-
-        def __init__(self,movement):
-          RootGroup.__init__(self,movement)
-          self.target_start_date = movement.getTargetStartDate()
-          self.target_stop_date = movement.getTargetStopDate()
-          self.start_date = movement.getStartDate()
-          self.stop_date = movement.getStopDate()
-
-        def test(self,movement):
-          if movement.getStartDate() == self.start_date and \
-            movement.getStopDate() == self.stop_date :
-            return 1
-          else :
-            return 0
-
-      class CriterionGroup(RootGroup):
-
-        def __init__(self,movement):
-          RootGroup.__init__(self,movement)
-          if hasattr(movement, 'getGroupCriterion'):
-            self.criterion = movement.getGroupCriterion()
-          else:
-            self.criterion = None
+    def collectMovement(self, movement_list,check_list=None,**kw):
+      """
+      group movements in the way we want. Thanks to this method, we are able to retrieve
+      movement classed by order, resource, criterion,.... 
 
-        def test(self,movement):
-          # we must have the same criterion
-          if hasattr(movement, 'getGroupCriterion'):
-            criterion = movement.getGroupCriterion()
-          else:
-            criterion = None
-          return self.criterion == criterion
-
-      class ResourceGroup(RootGroup):
-
-        def __init__(self,movement):
-          RootGroup.__init__(self,movement)
-          self.resource = movement.getResource()
-
-        def test(self,movement):
-          if movement.getResource() == self.resource :
-            return 1
-          else :
-            return 0
-
-      class BaseVariantGroup(RootGroup):
-
-        def __init__(self,movement):
-          RootGroup.__init__(self,movement)
-          self.base_category_list = movement.getVariationBaseCategoryList()
-          if self.base_category_list is None:
-            LOG('BaseVariantGroup __init__', 0, 'movement = %s, movement.showDict() = %s' % (repr(movement), repr(movement.showDict())))
-            self.base_category_list = []
-
-        def test(self,movement):
-          # we must have the same number of categories
-          categories_identity = 0
-          #LOG('BaseVariantGroup', 0, 'self.base_category_list = %s, movement = %s, movement.getVariationBaseCategoryList() = %s' % (repr(self.base_category_list), repr(movement), repr(movement.getVariationBaseCategoryList())))
-          movement_base_category_list = movement.getVariationBaseCategoryList()
-          if movement_base_category_list is None:
-            LOG('BaseVariantGroup test', 0, 'movement = %s, movement.showDict() = %s' % (repr(movement), repr(movement.showDict())))
-            movement_base_category_list = []
-          if len(self.base_category_list) == len(movement_base_category_list):
-            for category in movement_base_category_list:
-              if not category in self.base_category_list :
-                break
-            else :
-              categories_identity = 1
-          return categories_identity
-
-      class VariantGroup(RootGroup):
-
-        def __init__(self,movement):
-          RootGroup.__init__(self,movement)
-          self.category_list = movement.getVariationCategoryList()
-          if self.category_list is None:
-            LOG('VariantGroup __init__', 0, 'movement = %s, movement.showDict() = %s' % (repr(movement), repr(movement.showDict())))
-            self.category_list = []
-
-        def test(self,movement):
-          # we must have the same number of categories
-          categories_identity = 0
-          movement_category_list = movement.getVariationCategoryList()
-          if movement_category_list is None:
-            LOG('VariantGroup test', 0, 'movement = %s, movement.showDict() = %s' % (repr(movement), repr(movement.showDict())))
-            movement_category_list = []
-          if len(self.category_list) == len(movement_category_list):
-            for category in movement_category_list:
-              if not category in self.category_list :
-                break
-            else :
-              categories_identity = 1
-          return categories_identity
+      movement_list : the list of movement wich we want to group
 
-      my_root_group = RootGroup()
-      for movement in movement_list :
+      check_list : the list of classes used to group movements. The order
+                   of the list is important and determines by what we will
+                   group movement first
+                   Typically, check_list is :
+                   [DateMovementGroup,PathMovementGroup,...]
+      """
+      s_tool = self.portal_simulation
+      if check_list is None:
+        # For compatibility reasons, by default we keep the previous order
+        check_list = [s_tool.order_movement_group,s_tool.path_movement_group,
+                      s_tool.date_movement_group,
+                      s_tool.resource_movement_group,s_tool.variant_movement_group]
+      my_root_group = s_tool.root_movement_group.getInstance(check_list=check_list)
+      for movement in movement_list:
         if not movement in my_root_group.movement_list :
-          my_root_group.append(movement)
+          my_root_group.append(movement,check_list=check_list)
 
       return my_root_group
-
+    
     def buildOrderList(self, movement_group):
       # Build orders from a list of movements (attached to orders)
       order_list = []