Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WF / Activities / Rules / RuleSet.cs / 1305376 / RuleSet.cs
// ---------------------------------------------------------------------------- // Copyright (C) 2005 Microsoft Corporation All Rights Reserved // --------------------------------------------------------------------------- using System.Collections.Generic; using System.ComponentModel; using System.Workflow.ComponentModel; using System.Workflow.ComponentModel.Compiler; using System.Workflow.Activities.Common; namespace System.Workflow.Activities.Rules { public enum RuleChainingBehavior { None, UpdateOnly, Full }; [Serializable] public class RuleSet { internal const string RuleSetTrackingKey = "RuleSet."; internal string name; internal string description; internal Listrules; internal RuleChainingBehavior behavior = RuleChainingBehavior.Full; private bool runtimeInitialized; private object syncLock = new object(); // keep track of cached data [NonSerialized] private RuleEngine cachedEngine; [NonSerialized] private RuleValidation cachedValidation; public RuleSet() { this.rules = new List (); } public RuleSet(string name) : this() { this.name = name; } public RuleSet(string name, string description) : this(name) { this.description = description; } public string Name { get { return name; } set { if (runtimeInitialized) throw new InvalidOperationException(SR.GetString(SR.Error_CanNotChangeAtRuntime)); name = value; } } public string Description { get { return description; } set { if (runtimeInitialized) throw new InvalidOperationException(SR.GetString(SR.Error_CanNotChangeAtRuntime)); description = value; } } public RuleChainingBehavior ChainingBehavior { get { return behavior; } set { if (runtimeInitialized) throw new InvalidOperationException(SR.GetString(SR.Error_CanNotChangeAtRuntime)); behavior = value; } } [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)] public ICollection Rules { get { return rules; } } public bool Validate(RuleValidation validation) { if (validation == null) throw new ArgumentNullException("validation"); // Validate each rule. Dictionary ruleNames = new Dictionary (); foreach (Rule r in rules) { if (!string.IsNullOrEmpty(r.Name)) // invalid names caught when validating the rule { if (ruleNames.ContainsKey(r.Name)) { // Duplicate rule name found. ValidationError error = new ValidationError(Messages.Error_DuplicateRuleName, ErrorNumbers.Error_DuplicateConditions); error.UserData[RuleUserDataKeys.ErrorObject] = r; validation.AddError(error); } else { ruleNames.Add(r.Name, null); } } r.Validate(validation); } if (validation.Errors == null || validation.Errors.Count == 0) return true; return false; } public void Execute(RuleExecution ruleExecution) { // we have no way of knowing if the ruleset has been changed, so no caching done if (ruleExecution == null) throw new ArgumentNullException("ruleExecution"); if (ruleExecution.Validation == null) throw new ArgumentException(SR.GetString(SR.Error_MissingValidationProperty), "ruleExecution"); RuleEngine engine = new RuleEngine(this, ruleExecution.Validation, ruleExecution.ActivityExecutionContext); engine.Execute(ruleExecution); } internal void Execute(Activity activity, ActivityExecutionContext executionContext) { // this can be called from multiple threads if multiple workflows are // running at the same time (only a single workflow is single-threaded) // we want to only lock around the validation and preprocessing, so that // execution can run in parallel. if (activity == null) throw new ArgumentNullException("activity"); Type activityType = activity.GetType(); RuleEngine engine = null; lock (syncLock) { // do we have something useable cached? if ((cachedEngine == null) || (cachedValidation == null) || (cachedValidation.ThisType != activityType)) { // no cache (or its invalid) RuleValidation validation = new RuleValidation(activityType, null); engine = new RuleEngine(this, validation, executionContext); cachedValidation = validation; cachedEngine = engine; } else { // this will happen if the ruleset has already been processed // we can simply use the previously processed engine engine = cachedEngine; } } // when we get here, we have a local RuleEngine all ready to go // we are outside the lock, so these can run in parallel engine.Execute(activity, executionContext); } public RuleSet Clone() { RuleSet newRuleSet = (RuleSet)this.MemberwiseClone(); newRuleSet.runtimeInitialized = false; if (this.rules != null) { newRuleSet.rules = new List (); foreach (Rule r in this.rules) newRuleSet.rules.Add(r.Clone()); } return newRuleSet; } public override bool Equals(object obj) { RuleSet other = obj as RuleSet; if (other == null) return false; if ((this.Name != other.Name) || (this.Description != other.Description) || (this.ChainingBehavior != other.ChainingBehavior) || (this.Rules.Count != other.Rules.Count)) return false; // look similar, compare each rule for (int i = 0; i < this.rules.Count; ++i) { if (!this.rules[i].Equals(other.rules[i])) return false; } return true; } public override int GetHashCode() { return base.GetHashCode(); } internal void OnRuntimeInitialized() { lock (syncLock) { if (runtimeInitialized) return; foreach (Rule rule in rules) { rule.OnRuntimeInitialized(); } runtimeInitialized = true; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. // ---------------------------------------------------------------------------- // Copyright (C) 2005 Microsoft Corporation All Rights Reserved // --------------------------------------------------------------------------- using System.Collections.Generic; using System.ComponentModel; using System.Workflow.ComponentModel; using System.Workflow.ComponentModel.Compiler; using System.Workflow.Activities.Common; namespace System.Workflow.Activities.Rules { public enum RuleChainingBehavior { None, UpdateOnly, Full }; [Serializable] public class RuleSet { internal const string RuleSetTrackingKey = "RuleSet."; internal string name; internal string description; internal List rules; internal RuleChainingBehavior behavior = RuleChainingBehavior.Full; private bool runtimeInitialized; private object syncLock = new object(); // keep track of cached data [NonSerialized] private RuleEngine cachedEngine; [NonSerialized] private RuleValidation cachedValidation; public RuleSet() { this.rules = new List (); } public RuleSet(string name) : this() { this.name = name; } public RuleSet(string name, string description) : this(name) { this.description = description; } public string Name { get { return name; } set { if (runtimeInitialized) throw new InvalidOperationException(SR.GetString(SR.Error_CanNotChangeAtRuntime)); name = value; } } public string Description { get { return description; } set { if (runtimeInitialized) throw new InvalidOperationException(SR.GetString(SR.Error_CanNotChangeAtRuntime)); description = value; } } public RuleChainingBehavior ChainingBehavior { get { return behavior; } set { if (runtimeInitialized) throw new InvalidOperationException(SR.GetString(SR.Error_CanNotChangeAtRuntime)); behavior = value; } } [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)] public ICollection Rules { get { return rules; } } public bool Validate(RuleValidation validation) { if (validation == null) throw new ArgumentNullException("validation"); // Validate each rule. Dictionary ruleNames = new Dictionary (); foreach (Rule r in rules) { if (!string.IsNullOrEmpty(r.Name)) // invalid names caught when validating the rule { if (ruleNames.ContainsKey(r.Name)) { // Duplicate rule name found. ValidationError error = new ValidationError(Messages.Error_DuplicateRuleName, ErrorNumbers.Error_DuplicateConditions); error.UserData[RuleUserDataKeys.ErrorObject] = r; validation.AddError(error); } else { ruleNames.Add(r.Name, null); } } r.Validate(validation); } if (validation.Errors == null || validation.Errors.Count == 0) return true; return false; } public void Execute(RuleExecution ruleExecution) { // we have no way of knowing if the ruleset has been changed, so no caching done if (ruleExecution == null) throw new ArgumentNullException("ruleExecution"); if (ruleExecution.Validation == null) throw new ArgumentException(SR.GetString(SR.Error_MissingValidationProperty), "ruleExecution"); RuleEngine engine = new RuleEngine(this, ruleExecution.Validation, ruleExecution.ActivityExecutionContext); engine.Execute(ruleExecution); } internal void Execute(Activity activity, ActivityExecutionContext executionContext) { // this can be called from multiple threads if multiple workflows are // running at the same time (only a single workflow is single-threaded) // we want to only lock around the validation and preprocessing, so that // execution can run in parallel. if (activity == null) throw new ArgumentNullException("activity"); Type activityType = activity.GetType(); RuleEngine engine = null; lock (syncLock) { // do we have something useable cached? if ((cachedEngine == null) || (cachedValidation == null) || (cachedValidation.ThisType != activityType)) { // no cache (or its invalid) RuleValidation validation = new RuleValidation(activityType, null); engine = new RuleEngine(this, validation, executionContext); cachedValidation = validation; cachedEngine = engine; } else { // this will happen if the ruleset has already been processed // we can simply use the previously processed engine engine = cachedEngine; } } // when we get here, we have a local RuleEngine all ready to go // we are outside the lock, so these can run in parallel engine.Execute(activity, executionContext); } public RuleSet Clone() { RuleSet newRuleSet = (RuleSet)this.MemberwiseClone(); newRuleSet.runtimeInitialized = false; if (this.rules != null) { newRuleSet.rules = new List (); foreach (Rule r in this.rules) newRuleSet.rules.Add(r.Clone()); } return newRuleSet; } public override bool Equals(object obj) { RuleSet other = obj as RuleSet; if (other == null) return false; if ((this.Name != other.Name) || (this.Description != other.Description) || (this.ChainingBehavior != other.ChainingBehavior) || (this.Rules.Count != other.Rules.Count)) return false; // look similar, compare each rule for (int i = 0; i < this.rules.Count; ++i) { if (!this.rules[i].Equals(other.rules[i])) return false; } return true; } public override int GetHashCode() { return base.GetHashCode(); } internal void OnRuntimeInitialized() { lock (syncLock) { if (runtimeInitialized) return; foreach (Rule rule in rules) { rule.OnRuntimeInitialized(); } runtimeInitialized = true; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DetailsViewRowCollection.cs
- WindowsFormsLinkLabel.cs
- PtsCache.cs
- ProcessProtocolHandler.cs
- Timer.cs
- ConnectionProviderAttribute.cs
- UITypeEditor.cs
- ColumnWidthChangedEvent.cs
- wgx_commands.cs
- ToolboxItemFilterAttribute.cs
- TypeDescriptorContext.cs
- DataGridCaption.cs
- PrimitiveRenderer.cs
- HyperLink.cs
- ControlAdapter.cs
- Visual3D.cs
- Pair.cs
- MetadataSerializer.cs
- TemplateField.cs
- PolyQuadraticBezierSegmentFigureLogic.cs
- EventRouteFactory.cs
- Binding.cs
- UnsafeNativeMethods.cs
- GenericTypeParameterBuilder.cs
- InternalControlCollection.cs
- EntityProviderFactory.cs
- _SslSessionsCache.cs
- EntityCommand.cs
- filewebrequest.cs
- SqlParameter.cs
- AnimationStorage.cs
- SQLConvert.cs
- RIPEMD160Managed.cs
- ArithmeticLiteral.cs
- EncoderParameter.cs
- StateDesigner.Layouts.cs
- DesignerActionKeyboardBehavior.cs
- NonBatchDirectoryCompiler.cs
- UnionCodeGroup.cs
- DateTime.cs
- MiniModule.cs
- MatrixUtil.cs
- ContainerTracking.cs
- FixedTextBuilder.cs
- CompositeFontParser.cs
- SmtpReplyReaderFactory.cs
- BoundColumn.cs
- FixedSOMImage.cs
- figurelength.cs
- ManipulationInertiaStartingEventArgs.cs
- BatchStream.cs
- Pens.cs
- SoapAttributes.cs
- QuaternionKeyFrameCollection.cs
- XmlValidatingReaderImpl.cs
- SoapTypeAttribute.cs
- __ComObject.cs
- AxisAngleRotation3D.cs
- SimpleType.cs
- SerializationInfoEnumerator.cs
- DefaultAsyncDataDispatcher.cs
- ClientSettingsStore.cs
- util.cs
- DbConnectionPoolCounters.cs
- EasingKeyFrames.cs
- HtmlInputText.cs
- UniqueEventHelper.cs
- OleDbWrapper.cs
- CodeLinePragma.cs
- UIntPtr.cs
- TreeBuilderXamlTranslator.cs
- ProxyWebPartManager.cs
- RightsManagementEncryptionTransform.cs
- DataGridViewRowCancelEventArgs.cs
- SetStoryboardSpeedRatio.cs
- TransportSecurityProtocolFactory.cs
- UnknownWrapper.cs
- XmlNodeChangedEventManager.cs
- ConfigXmlCDataSection.cs
- BaseCodeDomTreeGenerator.cs
- EntitySqlQueryCacheEntry.cs
- WebBrowserNavigatedEventHandler.cs
- AmbientProperties.cs
- AsyncOperation.cs
- ClientFormsAuthenticationCredentials.cs
- ReversePositionQuery.cs
- RecommendedAsConfigurableAttribute.cs
- ServiceObjectContainer.cs
- TableRowGroupCollection.cs
- PromptBuilder.cs
- NameScopePropertyAttribute.cs
- StorageFunctionMapping.cs
- CaseStatement.cs
- Geometry3D.cs
- FragmentNavigationEventArgs.cs
- CollectionConverter.cs
- PageThemeParser.cs
- RegexTree.cs
- WebPartConnectVerb.cs
- MsmqMessageProperty.cs