Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WF / RunTime / Hosting / WorkflowPersistenceService.cs / 1305376 / WorkflowPersistenceService.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.IO; using System.IO.Compression; using System.Workflow.Runtime; using System.Workflow.ComponentModel; using System.Diagnostics; namespace System.Workflow.Runtime.Hosting { ///Service for saving engine state. public abstract class WorkflowPersistenceService : WorkflowRuntimeService { ///Saves the state of a workflow instance. /// The workflow instance state to save internal protected abstract void SaveWorkflowInstanceState(Activity rootActivity, bool unlock); ////// internal protected abstract void UnlockWorkflowInstanceState(Activity rootActivity); /// Loads the state of a workflow instance. /// The unique ID of the instance to load ///The workflow instance state internal protected abstract Activity LoadWorkflowInstanceState(Guid instanceId); ///Saves the state of a completed scope. /// The completed scope to save internal protected abstract void SaveCompletedContextActivity(Activity activity); ///Loads the state of a completed scope /// The unique identifier of the completed scope ///The completed scope or null internal protected abstract Activity LoadCompletedContextActivity(Guid scopeId, Activity outerActivity); ////// /// The value of the "UnloadOnIdle" flag internal protected abstract bool UnloadOnIdle(Activity activity); static protected byte[] GetDefaultSerializedForm(Activity activity) { DateTime startTime = DateTime.Now; Byte[] result; Debug.Assert(activity != null, "Null activity"); using (MemoryStream stream = new MemoryStream(10240)) { stream.Position = 0; activity.Save(stream); using (MemoryStream compressedStream = new MemoryStream((int)stream.Length)) { using (GZipStream gzs = new GZipStream(compressedStream, CompressionMode.Compress, true)) { gzs.Write(stream.GetBuffer(), 0, (int)stream.Length); } ActivityExecutionContextInfo executionContextInfo = (ActivityExecutionContextInfo)activity.GetValue(Activity.ActivityExecutionContextInfoProperty); TimeSpan timeElapsed = DateTime.Now - startTime; WorkflowTrace.Host.TraceEvent(TraceEventType.Information, 0, "Serialized a {0} with id {1} to length {2}. Took {3}.", executionContextInfo, executionContextInfo.ContextGuid, compressedStream.Length, timeElapsed); result = compressedStream.GetBuffer(); Array.Resize(ref result, Convert.ToInt32(compressedStream.Length)); } } return result; } static protected Activity RestoreFromDefaultSerializedForm(Byte[] activityBytes, Activity outerActivity) { DateTime startTime = DateTime.Now; Activity state; MemoryStream stream = new MemoryStream(activityBytes); stream.Position = 0; using (GZipStream gzs = new GZipStream(stream, CompressionMode.Decompress, true)) { state = Activity.Load(gzs, outerActivity); } Debug.Assert(state != null, "invalid state recovered"); TimeSpan timeElapsed = DateTime.Now - startTime; WorkflowTrace.Host.TraceEvent(TraceEventType.Information, 0, "Deserialized a {0} to length {1}. Took {2}.", state, stream.Length, timeElapsed); return state; } static protected internal bool GetIsBlocked(Activity rootActivity) { return (bool)rootActivity.GetValue(WorkflowExecutor.IsBlockedProperty); } static protected internal string GetSuspendOrTerminateInfo(Activity rootActivity) { return (string)rootActivity.GetValue(WorkflowExecutor.SuspendOrTerminateInfoProperty); } static protected internal WorkflowStatus GetWorkflowStatus(Activity rootActivity) { return (WorkflowStatus)rootActivity.GetValue(WorkflowExecutor.WorkflowStatusProperty); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.IO; using System.IO.Compression; using System.Workflow.Runtime; using System.Workflow.ComponentModel; using System.Diagnostics; namespace System.Workflow.Runtime.Hosting { ///Service for saving engine state. public abstract class WorkflowPersistenceService : WorkflowRuntimeService { ///Saves the state of a workflow instance. /// The workflow instance state to save internal protected abstract void SaveWorkflowInstanceState(Activity rootActivity, bool unlock); ////// internal protected abstract void UnlockWorkflowInstanceState(Activity rootActivity); /// Loads the state of a workflow instance. /// The unique ID of the instance to load ///The workflow instance state internal protected abstract Activity LoadWorkflowInstanceState(Guid instanceId); ///Saves the state of a completed scope. /// The completed scope to save internal protected abstract void SaveCompletedContextActivity(Activity activity); ///Loads the state of a completed scope /// The unique identifier of the completed scope ///The completed scope or null internal protected abstract Activity LoadCompletedContextActivity(Guid scopeId, Activity outerActivity); ////// /// The value of the "UnloadOnIdle" flag internal protected abstract bool UnloadOnIdle(Activity activity); static protected byte[] GetDefaultSerializedForm(Activity activity) { DateTime startTime = DateTime.Now; Byte[] result; Debug.Assert(activity != null, "Null activity"); using (MemoryStream stream = new MemoryStream(10240)) { stream.Position = 0; activity.Save(stream); using (MemoryStream compressedStream = new MemoryStream((int)stream.Length)) { using (GZipStream gzs = new GZipStream(compressedStream, CompressionMode.Compress, true)) { gzs.Write(stream.GetBuffer(), 0, (int)stream.Length); } ActivityExecutionContextInfo executionContextInfo = (ActivityExecutionContextInfo)activity.GetValue(Activity.ActivityExecutionContextInfoProperty); TimeSpan timeElapsed = DateTime.Now - startTime; WorkflowTrace.Host.TraceEvent(TraceEventType.Information, 0, "Serialized a {0} with id {1} to length {2}. Took {3}.", executionContextInfo, executionContextInfo.ContextGuid, compressedStream.Length, timeElapsed); result = compressedStream.GetBuffer(); Array.Resize(ref result, Convert.ToInt32(compressedStream.Length)); } } return result; } static protected Activity RestoreFromDefaultSerializedForm(Byte[] activityBytes, Activity outerActivity) { DateTime startTime = DateTime.Now; Activity state; MemoryStream stream = new MemoryStream(activityBytes); stream.Position = 0; using (GZipStream gzs = new GZipStream(stream, CompressionMode.Decompress, true)) { state = Activity.Load(gzs, outerActivity); } Debug.Assert(state != null, "invalid state recovered"); TimeSpan timeElapsed = DateTime.Now - startTime; WorkflowTrace.Host.TraceEvent(TraceEventType.Information, 0, "Deserialized a {0} to length {1}. Took {2}.", state, stream.Length, timeElapsed); return state; } static protected internal bool GetIsBlocked(Activity rootActivity) { return (bool)rootActivity.GetValue(WorkflowExecutor.IsBlockedProperty); } static protected internal string GetSuspendOrTerminateInfo(Activity rootActivity) { return (string)rootActivity.GetValue(WorkflowExecutor.SuspendOrTerminateInfoProperty); } static protected internal WorkflowStatus GetWorkflowStatus(Activity rootActivity) { return (WorkflowStatus)rootActivity.GetValue(WorkflowExecutor.WorkflowStatusProperty); } } } // 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
- _SecureChannel.cs
- SQLDateTimeStorage.cs
- ProcessRequestArgs.cs
- LinkTarget.cs
- Content.cs
- MissingFieldException.cs
- ListItemViewControl.cs
- WrappedIUnknown.cs
- SqlClientMetaDataCollectionNames.cs
- RegexRunner.cs
- ListDataBindEventArgs.cs
- Int32CAMarshaler.cs
- OracleEncoding.cs
- InstanceDataCollectionCollection.cs
- AutomationIdentifierGuids.cs
- DivideByZeroException.cs
- ListViewDeletedEventArgs.cs
- RecognizeCompletedEventArgs.cs
- PartitionerQueryOperator.cs
- XmlDownloadManager.cs
- CursorInteropHelper.cs
- CryptoStream.cs
- Popup.cs
- DependencyPropertyHelper.cs
- ManipulationDeltaEventArgs.cs
- EntityProviderFactory.cs
- NumberSubstitution.cs
- CommandManager.cs
- backend.cs
- ApplicationManager.cs
- ControlAdapter.cs
- DragEvent.cs
- TypefaceCollection.cs
- UnsafeNativeMethods.cs
- DetailsViewModeEventArgs.cs
- StreamHelper.cs
- ManualResetEvent.cs
- DelegatingConfigHost.cs
- Wizard.cs
- ChangePassword.cs
- MethodToken.cs
- CipherData.cs
- HtmlFormWrapper.cs
- EmptyCollection.cs
- RemotingServices.cs
- IteratorFilter.cs
- CatalogZoneBase.cs
- RNGCryptoServiceProvider.cs
- DesignColumnCollection.cs
- ObjectKeyFrameCollection.cs
- GroupAggregateExpr.cs
- XmlSchemaComplexContentRestriction.cs
- CodeSnippetExpression.cs
- EntryWrittenEventArgs.cs
- XmlBoundElement.cs
- XmlEncoding.cs
- ObjectNavigationPropertyMapping.cs
- AsnEncodedData.cs
- AudioDeviceOut.cs
- PenThreadPool.cs
- PerspectiveCamera.cs
- CurrencyManager.cs
- SafeFileMappingHandle.cs
- Debug.cs
- TickBar.cs
- SplitterPanel.cs
- SoapWriter.cs
- BitSet.cs
- TaskFileService.cs
- RedirectionProxy.cs
- DataBindingHandlerAttribute.cs
- ThreadStaticAttribute.cs
- DiscoveryDocumentReference.cs
- OrderPreservingPipeliningMergeHelper.cs
- ProfileSettingsCollection.cs
- TaskFormBase.cs
- CatalogPartDesigner.cs
- ToolBar.cs
- InputLanguageProfileNotifySink.cs
- Method.cs
- SmtpMail.cs
- DateTimeOffsetStorage.cs
- ItemsPresenter.cs
- DataGridCaption.cs
- TraceHandlerErrorFormatter.cs
- ChainOfResponsibility.cs
- ImageConverter.cs
- DataContractSerializerSection.cs
- StrongNameMembershipCondition.cs
- SqlBooleanMismatchVisitor.cs
- ListControl.cs
- ReferenceEqualityComparer.cs
- IsolationInterop.cs
- ErrorProvider.cs
- GuidelineCollection.cs
- TargetControlTypeAttribute.cs
- DiscoveryClientProtocol.cs
- ExecutionContext.cs
- BooleanExpr.cs
- DecimalStorage.cs