Quintiq file version 2.0
|
#parent: #root
|
Method AfterMethodCall_TryBlock (LibOpt_Task task, LibOpt_Run run, Boolean hasto_unregistertask)
|
{
|
Description:
|
[*
|
This method should only be used within a `try{...}` block. To be more precise, it should be used after the `BeforeMethodCall_TryBlock` method and some method that could throw errors are called.
|
The method will first try to force any propagation errors (if they exist), so that these propagation errors are nicely handled. In particular, these errors should show up as a child of the `LibOpt_Task.SnapshotComponent` snapshot in the 'Snapshots' form.
|
Since we are about to leave a `try{...}` block, the current transaction won't be safe anymore, so `this.EndSafeTransaction();` is called.
|
Finally, the `LibOpt_Task` is unregistered from the `LibOpt_CurrentTransaction`. By unregistering the `LibOpt_Task`, we ensure that any errors in future `LibOpt_Tasks` won't show up as a child of the `LibOpt_Task.SnapshotComponent` snapshot.
|
*]
|
TextBody:
|
[*
|
// A propagation issue might have been introduced since the previous time 'PropagateToFindPropagationErrors' was called.
|
// If this is the case, then calling 'PropagateToFindPropagationErrors' will result in a propagation error.
|
// AfterMethodCall_TryBlock should only be called from some try{...}onerror{...} block. Therefore, the propagation error is handled gracefully.
|
// When an error occurs, a LibOpt_SnapshotError is created and placed under the component of the last registered task. (Which is why we call 'PropagateToFindPropagationErrors' before calling 'this.UnregisterTask( task )').
|
// Automatic propagation is disabled by default. It can be enabled in the context menu of the Optimizer and Run forms
|
LibOpt_CurrentTransaction::PropagateToFindPropagationErrors( run );
|
|
// We are about to leave a 'safe' `try{...}` block, so the 'IsSafe' method should return 'false' when it is called.
|
// The 'EndSafeTransaction' resets the `TransactionGUID` attribute. This ensures that the 'IsSafe' method will return 'false' when it is called.
|
this.EndSafeTransaction();
|
|
this.UnregisterTask( task, hasto_unregistertask );
|
*]
|
}
|