[Erp5-report] r23081 - /erp5/trunk/products/ERP5/TargetSolver/ResourceBackpropagation.py

nobody at svn.erp5.org nobody at svn.erp5.org
Thu Aug 21 14:45:17 CEST 2008


Author: kazuhiko
Date: Thu Aug 21 14:45:16 2008
New Revision: 23081

URL: http://svn.erp5.org?rev=23081&view=rev
Log:
remove duplicate codes by calling super class's methods.

Modified:
    erp5/trunk/products/ERP5/TargetSolver/ResourceBackpropagation.py

Modified: erp5/trunk/products/ERP5/TargetSolver/ResourceBackpropagation.py
URL: http://svn.erp5.org/erp5/trunk/products/ERP5/TargetSolver/ResourceBackpropagation.py?rev=23081&r1=23080&r2=23081&view=diff
==============================================================================
--- erp5/trunk/products/ERP5/TargetSolver/ResourceBackpropagation.py (original)
+++ erp5/trunk/products/ERP5/TargetSolver/ResourceBackpropagation.py Thu Aug 21 14:45:16 2008
@@ -28,7 +28,6 @@
 ##############################################################################
 
 from CopyToTarget import CopyToTarget
-from Products.ERP5Type.DateUtils import createDateTimeFromMillis
 
 class ResourceBackpropagation(CopyToTarget):
   """
@@ -40,36 +39,19 @@
       Get interesting values
       XXX: better description is possible. But is it needed ?
     """
-    # Get interesting value
-    old_quantity = simulation_movement.getQuantity()
-    old_start_date = simulation_movement.getStartDate()
-    old_stop_date = simulation_movement.getStopDate()
-    new_quantity = simulation_movement.getDeliveryQuantity() * \
-                   simulation_movement.getDeliveryRatio()
-    new_start_date = simulation_movement.getDeliveryStartDateList()[0]
-    new_stop_date = simulation_movement.getDeliveryStopDateList()[0]
-    # Calculate delta
-    quantity_ratio = 0
-    if old_quantity not in (None,0.0): # XXX: What if quantity happens to be an integer ?
-      quantity_ratio = new_quantity / old_quantity
-    start_date_delta = 0
-    stop_date_delta = 0
-    # get the date delta in milliseconds, to prevent rounding issues
-    if new_start_date is not None and old_start_date is not None:
-      start_date_delta = new_start_date.millis() - old_start_date.millis()
-    if new_stop_date is not None and old_stop_date is not None:
-      stop_date_delta = new_stop_date.millis() - old_stop_date.millis()
-    return {
-      'quantity_ratio': quantity_ratio,
-      'start_date_delta': start_date_delta,
-      'stop_date_delta': stop_date_delta,
+    value_delta_dict = CopyToTarget._generateValueDeltaDict(
+      self, simulation_movement)
+    value_delta_dict.update(
+      {
       'resource_list' :
           simulation_movement.getDeliveryValue().getResourceList(),
       'variation_category_list':
           simulation_movement.getDeliveryValue().getVariationCategoryList(),
       'variation_property_dict':
           simulation_movement.getDeliveryValue().getVariationPropertyDict(),
-    }
+      })
+
+    return value_delta_dict
 
   def _generateValueDict(self, simulation_movement, quantity_ratio=1, 
                          start_date_delta=0, stop_date_delta=0,
@@ -80,15 +62,13 @@
     """
     Generate values to save on simulation movement.
     """
-    value_dict = {}
-    # Modify quantity, start_date, stop_date
-    start_date = simulation_movement.getStartDate()
-    if start_date is not None:
-      value_dict['start_date'] = createDateTimeFromMillis(start_date.millis() + start_date_delta)
-    stop_date = simulation_movement.getStopDate()
-    if stop_date is not None:
-      value_dict['stop_date'] = createDateTimeFromMillis(stop_date.millis() + stop_date_delta)
-    value_dict['quantity'] = simulation_movement.getQuantity() * quantity_ratio
+    value_dict = CopyToTarget._generateValueDict(
+      self, simulation_movement, quantity_ratio=quantity_ratio,
+      start_date_delta=start_date_delta, stop_date_delta=stop_date_delta,
+      resource_list=resource_list,
+      variation_category_list=variation_category_list,
+      variation_property_dict=variation_property_dict, **value_delta_dict)
+    # Modify resource etc.
     if resource_list:
       value_dict['resource_list'] = resource_list
     if variation_category_list:




More information about the Erp5-report mailing list