CompositeActivity Class


The .NET API Reference documentation has a new home. Visit the .NET API Browser on to see the new experience.

Note: This API is now obsolete.

Derivative of Activity that is the base class for all activities that contain other activities. A CompositeActivity is responsible for managing the execution of its child activities.

Namespace:   System.Workflow.ComponentModel
Assembly:  System.Workflow.ComponentModel (in System.Workflow.ComponentModel.dll)

[ObsoleteAttribute("The System.Workflow.* types are deprecated.  Instead, please use the new types from System.Activities.*")]
public class CompositeActivity : Activity


Initializes a new instance of the CompositeActivity class.


Initializes a new instance of the CompositeActivity class from an Object which implements the IEnumerable interface with type Activity.


Initializes a new instance of the CompositeActivity class, along with the name for that activity.


Gets the object representing the collection, ActivityCollection, of all child activities.


Gets or sets a value which controls whether the individual activities within Activities can be modified.


Gets or sets the user-defined description of the Activity.(Inherited from Activity.)


Gets the value that indicates whether this instance is in design or run-time mode.(Inherited from DependencyObject.)


Gets or sets a value that indicates whether this instance is enabled for execution and validation.(Inherited from Activity.)


Gets the read-only collection that represents the subset of Activities that are enabled.


Gets the ActivityExecutionResult of the last attempt to run this instance.(Inherited from Activity.)


Gets the current ActivityExecutionStatus of this instance.(Inherited from Activity.)


Gets information about whether the activity is executing within the default ActivityExecutionContext of the workflow instance.(Inherited from Activity.)


Gets or sets the name of this instance. This name must conform to the variable naming convention of the programming language that is being used in the Workflow project.(Inherited from Activity.)


Gets the CompositeActivity that contains this Activity.(Inherited from Activity.)


Gets the parent DependencyObject in the DependencyObject graph.(Inherited from DependencyObject.)


Gets the qualified name of the activity. Qualified activity names are always unique in a workflow instance.(Inherited from Activity.)


Gets or sets a reference to the Site component of the DependencyObject.(Inherited from DependencyObject.)


Gets an IDictionary that associates custom data with this class instance.(Inherited from DependencyObject.)


Gets the Guid associated with the instance.(Inherited from Activity.)

System_CAPS_pubmethodAddHandler(DependencyProperty, Object)

Adds a handler for an event of a DependencyObject.(Inherited from DependencyObject.)


Applies the WorkflowChanges manifest in the parameter to this instance.


Called by the workflow runtime to cancel execution of an activity that is currently executing.(Inherited from Activity.)


Creates a deep copy of the Activity.(Inherited from Activity.)


Releases all the resources used by the DependencyObject.(Inherited from DependencyObject.)


Calls Dispose on this instance, and optionally calls Dispose on all child activities of this instance.(Overrides DependencyObject.Dispose(Boolean).)


Determines whether the specified object is equal to the current object.(Inherited from Object.)


Called by the workflow runtime to execute an activity. (Inherited from Activity.)


Provided as an override to Object.Finalize to clean up any unmanaged resources deterministically.(Inherited from DependencyObject.)


Returns the instance of the Activity whose name is requested from the set of all activities running under the root activity of this instance, which is within the workflow.(Inherited from Activity.)

System_CAPS_pubmethodGetActivityByName(String, Boolean)

Returns the instance of the Activity whose name is requested from the set of all activities under the root the Activity of this instance if the second parameter is false and under the current Activity if the second parameter is true.(Inherited from Activity.)


Provides access to the ActivityBind associated with the specific DependencyProperty.(Inherited from DependencyObject.)

System_CAPS_protmethodGetBoundValue(ActivityBind, Type)

Retrieves the Object that is the subject of an ActivityBind.(Inherited from DependencyObject.)


Returns an array that contains all of the currently executing instances of the specified activity.


Serves as the default hash function. (Inherited from Object.)


Gets an array that contains the delegates for the specified DependencyProperty.(Inherited from DependencyObject.)


Gets the Type of the current instance.(Inherited from Object.)


Provides access to the value of the designated DependencyProperty.(Inherited from DependencyObject.)


Provides access to the bound object of a DependencyProperty and bypasses the GetValue override.(Inherited from DependencyObject.)

System_CAPS_protmethodHandleFault(ActivityExecutionContext, Exception)

Called when an exception is raised within the context of the execution of this instance.(Overrides Activity.HandleFault(ActivityExecutionContext, Exception).)


Initializes all appropriate child activities of this instance and the specified IServiceProvider.(Overrides Activity.Initialize(IServiceProvider).)


Performs initialization on dependency properties when overridden in a derived class.(Inherited from DependencyObject.)

System_CAPS_protmethodInvoke<T>(EventHandler<T>, T)

Subscribes an EventHandler and invokes that delegate.(Inherited from Activity.)

System_CAPS_protmethodInvoke<T>(IActivityEventListener<T>, T)

Subscribes an IActivityEventListener<T> and invokes that delegate.(Inherited from Activity.)


Indicates whether the value of a DependencyProperty is set as a binding. See SetBinding.(Inherited from DependencyObject.)


Creates a shallow copy of the current Object.(Inherited from Object.)


Determines whether the metaproperties of this DependencyObject equals the metaproperties of the parameterized DependencyObject.(Inherited from DependencyObject.)

System_CAPS_protmethodOnActivityChangeAdd(ActivityExecutionContext, Activity)

Calls when an activity is added.

System_CAPS_protmethodOnActivityChangeRemove(ActivityExecutionContext, Activity)

Called when an activity is removed.


Called by the workflow runtime engine every time the ActivityExecutionContext for this activity is loaded.(Overrides Activity.OnActivityExecutionContextLoad(IServiceProvider).)


Called by the workflow runtime engine every time the ActivityExecutionContext for this activity is unloaded.(Overrides Activity.OnActivityExecutionContextUnload(IServiceProvider).)


Called by the workflow runtime as part of the activity's transition to the closed state.(Inherited from Activity.)


Performs additional processing when the Activities property changes.


Event that occurs before a change being made to the underlying Activities.


Called after changes have been made to the collection Activities of this instance.

System_CAPS_protmethodRaiseEvent(DependencyProperty, Object, EventArgs)

Raises an Event associated with the specified dependency property.(Inherited from Activity.)

System_CAPS_protmethodRaiseGenericEvent<T>(DependencyProperty, Object, T)

Raises the event associated with the referenced DependencyProperty.(Inherited from Activity.)

System_CAPS_pubmethodRegisterForStatusChange(DependencyProperty, IActivityEventListener<ActivityExecutionStatusChangedEventArgs>)

Registers the specified DependencyProperty for the status change event.(Inherited from Activity.)

System_CAPS_pubmethodRemoveHandler(DependencyProperty, Object)

Removes an EventHandler from an associated DependencyProperty.(Inherited from DependencyObject.)


Removes a DependencyProperty from the DependencyObject.(Inherited from DependencyObject.)


Writes the Activity to a Stream for persistence.(Inherited from Activity.)

System_CAPS_pubmethodSave(Stream, IFormatter)

Writes the Activity to a Stream for persistence using the custom IFormatter provided for serialization.(Inherited from Activity.)

System_CAPS_pubmethodSetBinding(DependencyProperty, ActivityBind)

Sets the ActivityBind for the specified DependencyProperty. (Inherited from DependencyObject.)

System_CAPS_protmethodSetBoundValue(ActivityBind, Object)

Sets the value of the target ActivityBind.(Inherited from DependencyObject.)

System_CAPS_protmethodSetReadOnlyPropertyValue(DependencyProperty, Object)

Sets the value of a DependencyProperty, which is read-only.(Inherited from DependencyObject.)

System_CAPS_pubmethodSetValue(DependencyProperty, Object)

Sets the value of the DependencyProperty to the object.(Inherited from DependencyObject.)

System_CAPS_pubmethodSetValueBase(DependencyProperty, Object)

Sets the value of the DependencyProperty to the specified Object, bypassing the SetValue.(Inherited from DependencyObject.)


Provides a string that represents this instance.(Inherited from Activity.)


Informs the run-time tracking infrastructure of pending tracking information.(Inherited from Activity.)

System_CAPS_protmethodTrackData(String, Object)

Informs the run-time tracking infrastructure of pending tracking information.(Inherited from Activity.)


Called by the workflow runtime engine when an activity transitions into the Closed state from the Initialized state.(Overrides Activity.Uninitialize(IServiceProvider).)

System_CAPS_pubmethodUnregisterForStatusChange(DependencyProperty, IActivityEventListener<ActivityExecutionStatusChangedEventArgs>)

Un-registers the specified DependencyProperty for the status change event.(Inherited from Activity.)


Occurs when the activity execution is canceled. (Inherited from Activity.)


Occurs when an Activity has completed execution.(Inherited from Activity.)


Occurs when running a compensation method on the Activity.(Inherited from Activity.)


Occurs when the Activity is run.(Inherited from Activity.)


Occurs when an exception is raised during the running of the instance.(Inherited from Activity.)


Occurs when the ActivityExecutionStatus of a running Activity changes.(Inherited from Activity.)


Represents the method that handles the Disposed event of a component.(Inherited from DependencyObject.)


This material discusses types and namespaces that are obsolete. For more information, see Deprecated Types in Windows Workflow Foundation 4.5.

A CompositeActivity manages the execution of its child activities using ActivityExecutionContext class methods and events defined on the Activity class. For example, a child activity is scheduled for execution using the ExecuteActivity of ActivityExecutionContext. A CompositeActivity activity can be notified when a child activity completes its execution by subscribing to the Closed event defined on Activity.

The workflow runtime enforces certain constraints on CompositeActivity execution, the most fundamental of which is that a CompositeActivity activity cannot move to the Closed state if any child activities are still in a Executing, Canceling, Compensating, or Faulting, state.

This example shows a basic CompositeActivity that executes its first child activity for execution. When the child activity moves to the Closed state, the composite activity is notified and then completes its execution.

public class HasOneChildActivity : CompositeActivity
    protected override ActivityExecutionStatus Execute(ActivityExecutionContext executionContext)
        Activity child = this.EnabledActivities[0];
        child.Closed += this.ChildClosed;

        return ActivityExecutionStatus.Executing;

    void ChildClosed(object sender, ActivityExecutionStatusChangedEventArgs e)
        e.Activity.Closed -= this.ChildClosed;
        ActivityExecutionContext executionContext = sender as ActivityExecutionContext;


.NET Framework
Available since 3.0

Any public static ( Shared in Visual Basic) members of this type are thread safe. Any instance members are not guaranteed to be thread safe.

Return to top