Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / NetFx40 / Tools / System.Activities.Presentation / System / Activities / Presentation / Base / Interaction / Model / ModelEditingScope.cs / 1305376 / ModelEditingScope.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
namespace System.Activities.Presentation.Model {
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Activities.Presentation;
using System.Diagnostics.CodeAnalysis;
using System.Runtime;
///
/// A ModelEditingScope represents a group of changes to the
/// editing store. Change groups are transactional:
/// changes made under an editing scope can be committed
/// or aborted as a unit.
///
/// When an editing scope is committed, the editing store
/// takes all changes that occurred within it and applies
/// them to the model. If the editing scope�s Revert method
/// is called, or the editing scope is disposed before Complete
/// is called, the editing scope will instead reverse the
/// changes made to the underlying objects, reapplying state
/// from the editing store. This provides a solid basis for
/// an undo mechanism.
///
public abstract class ModelEditingScope : IDisposable {
private string _description;
private bool _completed;
private bool _reverted;
///
/// Creates a new ModelEditingScope object.
///
protected ModelEditingScope() { }
///
/// Describes the group. You may change this property
/// anytime before the group is committed.
///
public string Description {
get { return (_description == null ? string.Empty : _description); }
set { _description = value; }
}
///
/// Completes the editing scope. If the editing scope has
/// already been reverted or completed, this will throw an
/// InvalidOperationException. Calling Complete calls the
/// protected OnComplete method.
///
/// If ModelEditingScope
/// has already been complted or reverted.
[SuppressMessage("Microsoft.Usage", "CA1816:CallGCSuppressFinalizeCorrectly", Justification = "By design.")]
[SuppressMessage("Microsoft.Design", "CA1031:DoNotCatchGeneralExceptionTypes", Justification = "By design.")]
public void Complete()
{
if (_reverted) throw FxTrace.Exception.AsError(new InvalidOperationException(System.Activities.Presentation.Internal.Properties.Resources.Error_EditingScopeReverted));
if (_completed) throw FxTrace.Exception.AsError(new InvalidOperationException(System.Activities.Presentation.Internal.Properties.Resources.Error_EdtingScopeCompleted));
if (CanComplete()) {
bool successful = false;
_completed = true; // prevent recursive commits
try {
OnComplete();
successful = true;
}
catch (Exception e)
{
_completed = false;
Revert();
if (Fx.IsFatal(e))
{
throw;
}
if (!OnException(e))
{
throw;
}
}
finally {
if (successful) {
GC.SuppressFinalize(this);
}
else {
_completed = false;
}
}
}
else
Revert(); // We are not allowed to do completion, revert the change.
}
///
/// Abandons the changes made during the editing scope. If the
/// group has already been committed or aborted, this will
/// throw an InvalidOperationException. Calling Revert calls
/// the protected OnRevert with �false� for the
/// finalizing parameter.
///
/// If ModelEditingScope
/// has already been committed.
[SuppressMessage("Microsoft.Usage", "CA1816:CallGCSuppressFinalizeCorrectly", Justification = "By design.")]
[SuppressMessage("Microsoft.Design", "CA1031:DoNotCatchGeneralExceptionTypes", Justification = "By design.")]
public void Revert()
{
if (_completed) throw FxTrace.Exception.AsError(new InvalidOperationException(System.Activities.Presentation.Internal.Properties.Resources.Error_EdtingScopeCompleted));
if (_reverted) return;
bool successful = false;
_reverted = true;
try
{
OnRevert(false);
successful = true;
}
catch(Exception e)
{
_reverted = false;
if (Fx.IsFatal(e))
{
throw;
}
if (!OnException(e))
{
throw;
}
}
finally {
if (successful) {
GC.SuppressFinalize(this);
}
else {
_reverted = false;
}
}
}
///
/// Implements IDisposable.Dispose as follows:
///
/// 1. If the editing scope has already been completed or reverted, do nothing.
/// 2. Revert the editing scope.
///
/// GC.SuppressFinalize(this) is called through Revert(), so suppress the FxCop violation.
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Performance", "CA1816:DisposeMethodsShouldCallSuppressFinalize")]
public void Dispose() {
Dispose(true);
}
///
/// Disposes this object by aborting changes.
///
///
protected virtual void Dispose(bool disposing) {
if (!_completed && !_reverted) {
if (disposing) {
Revert();
}
else {
OnRevert(true);
}
}
}
///
/// Performs the actual complete of the editing scope.
///
protected abstract void OnComplete();
///
/// Determines if OnComplete should be called, or if the change should instead be reverted. Reasons
/// for reverting may include file cannot be checked out of a source control system for modification.
///
/// Returns true if completion can occur, false if the change should instead revert
protected abstract bool CanComplete();
///
/// Performs the actual revert of the editing scope.
///
///
/// True if the abort is ocurring because the object
/// is being finalized. Some undo systems may attempt to
/// abort in this case, while others may abandon the
/// change and record it as a reactive undo.
///
protected abstract void OnRevert(bool finalizing);
///
/// Handle the exception during Complete and Revert.
///
///
/// The exception to handle.
///
///
/// True if the exception is handled, false if otherwise
///
protected abstract bool OnException(Exception exception);
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- FormatterConverter.cs
- RemotingServices.cs
- Win32MouseDevice.cs
- XamlNamespaceHelper.cs
- GlyphManager.cs
- ControlFilterExpression.cs
- ColorConverter.cs
- TreeNodeCollection.cs
- ModelServiceImpl.cs
- PointUtil.cs
- DbConnectionPoolIdentity.cs
- Function.cs
- XPathNodePointer.cs
- WebBrowserNavigatingEventHandler.cs
- StylusTip.cs
- UnauthorizedWebPart.cs
- MatrixCamera.cs
- ManifestResourceInfo.cs
- EventRouteFactory.cs
- TagPrefixCollection.cs
- ToolStripLabel.cs
- ComplexTypeEmitter.cs
- ListView.cs
- PropertyGridCommands.cs
- ETagAttribute.cs
- MSHTMLHost.cs
- SignerInfo.cs
- PrintDialogException.cs
- ClientBuildManagerCallback.cs
- ProcessModelInfo.cs
- TranslateTransform.cs
- ColumnBinding.cs
- SignedPkcs7.cs
- QueryOutputWriter.cs
- WorkflowCompensationBehavior.cs
- PointLight.cs
- HierarchicalDataTemplate.cs
- ListDataHelper.cs
- BaseDataListActionList.cs
- SiteOfOriginContainer.cs
- SkipQueryOptionExpression.cs
- IERequestCache.cs
- XmlEntity.cs
- WindowsAltTab.cs
- CacheVirtualItemsEvent.cs
- RemotingClientProxy.cs
- TimerElapsedEvenArgs.cs
- PanelStyle.cs
- RemotingConfigParser.cs
- OutputCacheModule.cs
- HttpDictionary.cs
- TagPrefixInfo.cs
- ComPlusSynchronizationContext.cs
- SeparatorAutomationPeer.cs
- FullTrustAssembly.cs
- FtpWebRequest.cs
- ExpandoClass.cs
- UrlMapping.cs
- CRYPTPROTECT_PROMPTSTRUCT.cs
- InitializerFacet.cs
- OrderedDictionary.cs
- CellRelation.cs
- XmlWriter.cs
- ThrowHelper.cs
- KeyManager.cs
- ExtenderControl.cs
- ExtensionSurface.cs
- FormatConvertedBitmap.cs
- LinqDataSource.cs
- XmlCharacterData.cs
- DynamicDataExtensions.cs
- MenuItemCollection.cs
- PropertyFilterAttribute.cs
- TableLayoutStyleCollection.cs
- PolyQuadraticBezierSegment.cs
- Condition.cs
- ThreadStartException.cs
- MimeFormatExtensions.cs
- EndCreateSecurityTokenRequest.cs
- SQLDecimalStorage.cs
- RectConverter.cs
- XmlDomTextWriter.cs
- Storyboard.cs
- ColumnCollection.cs
- ObjectFactoryCodeDomTreeGenerator.cs
- Attributes.cs
- Margins.cs
- RegionData.cs
- Validator.cs
- TraceData.cs
- DocumentPaginator.cs
- ProfileInfo.cs
- SqlBulkCopy.cs
- ImageEditor.cs
- ToReply.cs
- AssociationType.cs
- HostProtectionException.cs
- GridViewPageEventArgs.cs
- Transform.cs
- ChildrenQuery.cs