Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / Controls / DataErrorValidationRule.cs / 1305600 / DataErrorValidationRule.cs
//---------------------------------------------------------------------------- // //// Copyright (C) by Microsoft Corporation. All rights reserved. // // // // Description: // DataErrorValidationRule is used when a ValidationError is the result of // a data error in the source item itself (e.g. as exposed by IDataErrorInfo). // //--------------------------------------------------------------------------- using System; using System.Collections; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using MS.Internal; namespace System.Windows.Controls { ////// DataErrorValidationRule can be added to the ValidationRulesCollection of a Binding /// or MultiBinding to indicate that data errors in the source object should /// be considered ValidationErrors /// public sealed class DataErrorValidationRule : ValidationRule { ////// DataErrorValidationRule ctor. /// public DataErrorValidationRule() : base(ValidationStep.UpdatedValue, true) { } ////// Validate is called when Data binding is updating /// public override ValidationResult Validate(object value, CultureInfo cultureInfo) { // This rule is called during the CommittedValue step, so the value is the // owner of the rule collection - either a BindingGroup or an individual // binding expression. BindingGroup bindingGroup; BindingExpression bindingExpr; if ((bindingGroup = value as BindingGroup) != null) { // in a BindingGroup, check the item-level IDataErrorInfo for each // source item in the group IList items = bindingGroup.Items; for (int i=items.Count-1; i>=0; --i) { IDataErrorInfo idei = items[i] as IDataErrorInfo; if (idei != null) { string error = idei.Error; if (!String.IsNullOrEmpty(error)) { return new ValidationResult(false, error); } } } } else if ((bindingExpr = value as BindingExpression) != null) { // in a binding, check the error info for the binding's source // property IDataErrorInfo idei = bindingExpr.SourceItem as IDataErrorInfo; string name = (idei != null) ? bindingExpr.SourcePropertyName : null; if (!String.IsNullOrEmpty(name)) { // get the data error information, if any, by calling idie[name]. // We do this in a paranoid way, even though indexers with // string-valued arguments are not supposed to throw exceptions. // PreSharp uses message numbers that the C# compiler doesn't know about. // Disable the C# complaints, per the PreSharp documentation. #pragma warning disable 1634, 1691 // PreSharp complains about catching NullReference (and other) exceptions. // It doesn't recognize that IsCritical[Application]Exception() handles these correctly. #pragma warning disable 56500 string error; try { error = idei[name]; } catch (Exception ex) { if (CriticalExceptions.IsCriticalApplicationException(ex)) throw; error = null; if (TraceData.IsEnabled) { TraceData.Trace(TraceEventType.Error, TraceData.DataErrorInfoFailed( name, idei.GetType().FullName, ex.GetType().FullName, ex.Message), bindingExpr); } } #pragma warning restore 56500 #pragma warning restore 1634, 1691 if (!String.IsNullOrEmpty(error)) { return new ValidationResult(false, error); } } } else throw new InvalidOperationException(SR.Get(SRID.ValidationRule_UnexpectedValue, this, value)); return ValidationResult.ValidResult; } internal static readonly DataErrorValidationRule Instance = new DataErrorValidationRule(); } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // //// Copyright (C) by Microsoft Corporation. All rights reserved. // // // // Description: // DataErrorValidationRule is used when a ValidationError is the result of // a data error in the source item itself (e.g. as exposed by IDataErrorInfo). // //--------------------------------------------------------------------------- using System; using System.Collections; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using MS.Internal; namespace System.Windows.Controls { ////// DataErrorValidationRule can be added to the ValidationRulesCollection of a Binding /// or MultiBinding to indicate that data errors in the source object should /// be considered ValidationErrors /// public sealed class DataErrorValidationRule : ValidationRule { ////// DataErrorValidationRule ctor. /// public DataErrorValidationRule() : base(ValidationStep.UpdatedValue, true) { } ////// Validate is called when Data binding is updating /// public override ValidationResult Validate(object value, CultureInfo cultureInfo) { // This rule is called during the CommittedValue step, so the value is the // owner of the rule collection - either a BindingGroup or an individual // binding expression. BindingGroup bindingGroup; BindingExpression bindingExpr; if ((bindingGroup = value as BindingGroup) != null) { // in a BindingGroup, check the item-level IDataErrorInfo for each // source item in the group IList items = bindingGroup.Items; for (int i=items.Count-1; i>=0; --i) { IDataErrorInfo idei = items[i] as IDataErrorInfo; if (idei != null) { string error = idei.Error; if (!String.IsNullOrEmpty(error)) { return new ValidationResult(false, error); } } } } else if ((bindingExpr = value as BindingExpression) != null) { // in a binding, check the error info for the binding's source // property IDataErrorInfo idei = bindingExpr.SourceItem as IDataErrorInfo; string name = (idei != null) ? bindingExpr.SourcePropertyName : null; if (!String.IsNullOrEmpty(name)) { // get the data error information, if any, by calling idie[name]. // We do this in a paranoid way, even though indexers with // string-valued arguments are not supposed to throw exceptions. // PreSharp uses message numbers that the C# compiler doesn't know about. // Disable the C# complaints, per the PreSharp documentation. #pragma warning disable 1634, 1691 // PreSharp complains about catching NullReference (and other) exceptions. // It doesn't recognize that IsCritical[Application]Exception() handles these correctly. #pragma warning disable 56500 string error; try { error = idei[name]; } catch (Exception ex) { if (CriticalExceptions.IsCriticalApplicationException(ex)) throw; error = null; if (TraceData.IsEnabled) { TraceData.Trace(TraceEventType.Error, TraceData.DataErrorInfoFailed( name, idei.GetType().FullName, ex.GetType().FullName, ex.Message), bindingExpr); } } #pragma warning restore 56500 #pragma warning restore 1634, 1691 if (!String.IsNullOrEmpty(error)) { return new ValidationResult(false, error); } } } else throw new InvalidOperationException(SR.Get(SRID.ValidationRule_UnexpectedValue, this, value)); return ValidationResult.ValidResult; } internal static readonly DataErrorValidationRule Instance = new DataErrorValidationRule(); } } // 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
- Win32Exception.cs
- DBCommand.cs
- SystemIPAddressInformation.cs
- CodeMemberProperty.cs
- LateBoundBitmapDecoder.cs
- XmlSchemaInferenceException.cs
- DocumentViewerBase.cs
- assertwrapper.cs
- SortKey.cs
- XmlUnspecifiedAttribute.cs
- Attributes.cs
- DataSourceView.cs
- IProvider.cs
- XmlQualifiedName.cs
- HighlightVisual.cs
- SHA512.cs
- _ProxyRegBlob.cs
- ElementUtil.cs
- RtType.cs
- PathFigureCollectionConverter.cs
- DataTablePropertyDescriptor.cs
- RenderCapability.cs
- Thread.cs
- HttpConfigurationContext.cs
- TableProviderWrapper.cs
- X509ChainElement.cs
- Column.cs
- PriorityItem.cs
- SimpleRecyclingCache.cs
- xmlformatgeneratorstatics.cs
- DataGridDesigner.cs
- ChannelFactoryRefCache.cs
- DSASignatureDeformatter.cs
- ToolStripDropDownClosingEventArgs.cs
- Popup.cs
- NumericUpDownAcceleration.cs
- FilterElement.cs
- SessionStateContainer.cs
- UserPreferenceChangingEventArgs.cs
- LocalizationComments.cs
- StringReader.cs
- CompiledELinqQueryState.cs
- OutputScopeManager.cs
- OdbcUtils.cs
- CodeNamespaceImport.cs
- FullTrustAssembly.cs
- PointCollection.cs
- DiscoveryMessageSequenceGenerator.cs
- LoginView.cs
- CheckPair.cs
- WebConfigurationManager.cs
- ProcessHost.cs
- EmptyEnumerator.cs
- OleDbErrorCollection.cs
- AuthenticatedStream.cs
- AdRotator.cs
- PropertyEmitterBase.cs
- DocumentXPathNavigator.cs
- BlurEffect.cs
- PagerStyle.cs
- ProfilePropertySettings.cs
- RemoveFromCollection.cs
- WindowClosedEventArgs.cs
- TextEditorDragDrop.cs
- XmlSchemaCollection.cs
- ToolStripSystemRenderer.cs
- TextPointerBase.cs
- AssemblyFilter.cs
- BaseParaClient.cs
- DateTimeValueSerializer.cs
- SessionStateUtil.cs
- AsymmetricAlgorithm.cs
- ReadOnlyAttribute.cs
- DynamicILGenerator.cs
- WebEventTraceProvider.cs
- StylusShape.cs
- ListViewGroup.cs
- ButtonRenderer.cs
- SqlRetyper.cs
- ProfileParameter.cs
- ProxyGenerationError.cs
- IDQuery.cs
- InfoCardXmlSerializer.cs
- WebControlParameterProxy.cs
- AnnouncementInnerClient11.cs
- ToolStripRenderEventArgs.cs
- ColorConverter.cs
- MatcherBuilder.cs
- JavaScriptString.cs
- XmlReader.cs
- CorrelationQuery.cs
- CommandField.cs
- WindowsIdentity.cs
- DispatcherExceptionEventArgs.cs
- FreezableOperations.cs
- RulePatternOps.cs
- ListSortDescription.cs
- DocumentPageHost.cs
- HandlerMappingMemo.cs
- DispatcherSynchronizationContext.cs