Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Metadata / StoreItemCollection.Loader.cs / 1 / StoreItemCollection.Loader.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System.Xml; using System.Collections.Generic; using System.Data.EntityModel.SchemaObjectModel; using System.Data.Common; using System.Diagnostics; using System.Data.Common.Utils; using System.Data.Entity; using System.Text; namespace System.Data.Metadata.Edm { public sealed partial class StoreItemCollection { private class Loader { private string _provider = null; private string _providerManifestToken = null; private DbProviderManifest _providerManifest; private DbProviderFactory _providerFactory; IList_errors; IList _schemas; bool _throwOnError; public Loader(IEnumerable xmlReaders, IEnumerable sourceFilePaths, bool throwOnError) { _throwOnError = throwOnError; LoadItems(xmlReaders, sourceFilePaths); } public IList Errors { get { return _errors; } } public IList Schemas { get { return _schemas; } } public DbProviderManifest ProviderManifest { get { return _providerManifest; } } public DbProviderFactory ProviderFactory { get { return _providerFactory; } } public bool HasNonWarningErrors { get { return !MetadataHelper.CheckIfAllErrorsAreWarnings(_errors); } } private void LoadItems(IEnumerable xmlReaders, IEnumerable sourceFilePaths) { Debug.Assert(_errors == null, "we are expecting this to be the location that sets _errors for the first time"); _errors = SchemaManager.ParseAndValidate(xmlReaders, sourceFilePaths, SchemaDataModelOption.ProviderDataModel, OnProviderNotification, OnProviderManifestTokenNotification, OnProviderManifestNeeded, out _schemas ); if (_throwOnError) { ThrowOnNonWarningErrors(); } } internal void ThrowOnNonWarningErrors() { if (!MetadataHelper.CheckIfAllErrorsAreWarnings(_errors)) { //Future Enhancement: if there is an error, we throw exception with error and warnings. //Otherwise the user has no clue to know about warnings. throw EntityUtil.InvalidSchemaEncountered(Helper.CombineErrorMessage(_errors)); } } private void OnProviderNotification(string provider, Action addError) { string expected = _provider; if (_provider == null) { // Even if the Provider is only now being discovered from the first SSDL file, // it must still match the 'implicit' provider that is implied by the DbConnection // or DbProviderFactory that was used to construct this StoreItemCollection. _provider = provider; InitializeProviderManifest(addError); return; } else { // The provider was previously discovered from a preceeding SSDL file; it is an error // if the 'Provider' attributes in all SSDL files are not identical. if (_provider == provider) { return; } } Debug.Assert(expected != null, "Expected provider name not initialized from _provider or _providerFactory?"); addError(Strings.AllArtifactsMustTargetSameProvider_InvariantName(expected, _provider), ErrorCode.InconsistentProvider, EdmSchemaErrorSeverity.Error); } private void InitializeProviderManifest(Action addError) { if (_providerManifest == null && (_providerManifestToken != null && _provider != null)) { DbProviderFactory factory = null; try { factory = DbProviderServices.GetProviderFactory(_provider); } catch (ArgumentException e) { addError(e.Message, ErrorCode.InvalidProvider, EdmSchemaErrorSeverity.Error); return; } try { DbProviderServices services = DbProviderServices.GetProviderServices(factory); _providerManifest = services.GetProviderManifest(_providerManifestToken); _providerFactory = factory; if (_providerManifest is EdmProviderManifest) { if (_throwOnError) { throw EntityUtil.NotSupported(Strings.OnlyStoreConnectionsSupported); } else { addError(Strings.OnlyStoreConnectionsSupported, ErrorCode.InvalidProvider, EdmSchemaErrorSeverity.Error); } return; } } catch (ProviderIncompatibleException e) { if (_throwOnError) { // we want to surface these as ProviderIncompatibleExceptions if we are "allowed" to. throw; } AddProviderIncompatibleError(e, addError); } } } private void OnProviderManifestTokenNotification(string token, Action addError) { if (_providerManifestToken == null) { _providerManifestToken = token; InitializeProviderManifest(addError); return; } if (_providerManifestToken != token) { addError(Strings.AllArtifactsMustTargetSameProvider_ManifestToken(token, _providerManifestToken), ErrorCode.ProviderManifestTokenMismatch, EdmSchemaErrorSeverity.Error); } } private DbProviderManifest OnProviderManifestNeeded(Action addError) { if (_providerManifest == null) { addError(Strings.ProviderManifestTokenNotFound, ErrorCode.ProviderManifestTokenNotFound, EdmSchemaErrorSeverity.Error); } return _providerManifest; } private void AddProviderIncompatibleError(ProviderIncompatibleException provEx, Action addError) { Debug.Assert(provEx != null); Debug.Assert(addError != null); StringBuilder message = new StringBuilder(provEx.Message); if (provEx.InnerException != null && !string.IsNullOrEmpty(provEx.InnerException.Message)) { message.AppendFormat(" {0}", provEx.InnerException.Message); } addError(message.ToString(), ErrorCode.FailedToRetrieveProviderManifest, EdmSchemaErrorSeverity.Error); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System.Xml; using System.Collections.Generic; using System.Data.EntityModel.SchemaObjectModel; using System.Data.Common; using System.Diagnostics; using System.Data.Common.Utils; using System.Data.Entity; using System.Text; namespace System.Data.Metadata.Edm { public sealed partial class StoreItemCollection { private class Loader { private string _provider = null; private string _providerManifestToken = null; private DbProviderManifest _providerManifest; private DbProviderFactory _providerFactory; IList_errors; IList _schemas; bool _throwOnError; public Loader(IEnumerable xmlReaders, IEnumerable sourceFilePaths, bool throwOnError) { _throwOnError = throwOnError; LoadItems(xmlReaders, sourceFilePaths); } public IList Errors { get { return _errors; } } public IList Schemas { get { return _schemas; } } public DbProviderManifest ProviderManifest { get { return _providerManifest; } } public DbProviderFactory ProviderFactory { get { return _providerFactory; } } public bool HasNonWarningErrors { get { return !MetadataHelper.CheckIfAllErrorsAreWarnings(_errors); } } private void LoadItems(IEnumerable xmlReaders, IEnumerable sourceFilePaths) { Debug.Assert(_errors == null, "we are expecting this to be the location that sets _errors for the first time"); _errors = SchemaManager.ParseAndValidate(xmlReaders, sourceFilePaths, SchemaDataModelOption.ProviderDataModel, OnProviderNotification, OnProviderManifestTokenNotification, OnProviderManifestNeeded, out _schemas ); if (_throwOnError) { ThrowOnNonWarningErrors(); } } internal void ThrowOnNonWarningErrors() { if (!MetadataHelper.CheckIfAllErrorsAreWarnings(_errors)) { //Future Enhancement: if there is an error, we throw exception with error and warnings. //Otherwise the user has no clue to know about warnings. throw EntityUtil.InvalidSchemaEncountered(Helper.CombineErrorMessage(_errors)); } } private void OnProviderNotification(string provider, Action addError) { string expected = _provider; if (_provider == null) { // Even if the Provider is only now being discovered from the first SSDL file, // it must still match the 'implicit' provider that is implied by the DbConnection // or DbProviderFactory that was used to construct this StoreItemCollection. _provider = provider; InitializeProviderManifest(addError); return; } else { // The provider was previously discovered from a preceeding SSDL file; it is an error // if the 'Provider' attributes in all SSDL files are not identical. if (_provider == provider) { return; } } Debug.Assert(expected != null, "Expected provider name not initialized from _provider or _providerFactory?"); addError(Strings.AllArtifactsMustTargetSameProvider_InvariantName(expected, _provider), ErrorCode.InconsistentProvider, EdmSchemaErrorSeverity.Error); } private void InitializeProviderManifest(Action addError) { if (_providerManifest == null && (_providerManifestToken != null && _provider != null)) { DbProviderFactory factory = null; try { factory = DbProviderServices.GetProviderFactory(_provider); } catch (ArgumentException e) { addError(e.Message, ErrorCode.InvalidProvider, EdmSchemaErrorSeverity.Error); return; } try { DbProviderServices services = DbProviderServices.GetProviderServices(factory); _providerManifest = services.GetProviderManifest(_providerManifestToken); _providerFactory = factory; if (_providerManifest is EdmProviderManifest) { if (_throwOnError) { throw EntityUtil.NotSupported(Strings.OnlyStoreConnectionsSupported); } else { addError(Strings.OnlyStoreConnectionsSupported, ErrorCode.InvalidProvider, EdmSchemaErrorSeverity.Error); } return; } } catch (ProviderIncompatibleException e) { if (_throwOnError) { // we want to surface these as ProviderIncompatibleExceptions if we are "allowed" to. throw; } AddProviderIncompatibleError(e, addError); } } } private void OnProviderManifestTokenNotification(string token, Action addError) { if (_providerManifestToken == null) { _providerManifestToken = token; InitializeProviderManifest(addError); return; } if (_providerManifestToken != token) { addError(Strings.AllArtifactsMustTargetSameProvider_ManifestToken(token, _providerManifestToken), ErrorCode.ProviderManifestTokenMismatch, EdmSchemaErrorSeverity.Error); } } private DbProviderManifest OnProviderManifestNeeded(Action addError) { if (_providerManifest == null) { addError(Strings.ProviderManifestTokenNotFound, ErrorCode.ProviderManifestTokenNotFound, EdmSchemaErrorSeverity.Error); } return _providerManifest; } private void AddProviderIncompatibleError(ProviderIncompatibleException provEx, Action addError) { Debug.Assert(provEx != null); Debug.Assert(addError != null); StringBuilder message = new StringBuilder(provEx.Message); if (provEx.InnerException != null && !string.IsNullOrEmpty(provEx.InnerException.Message)) { message.AppendFormat(" {0}", provEx.InnerException.Message); } addError(message.ToString(), ErrorCode.FailedToRetrieveProviderManifest, EdmSchemaErrorSeverity.Error); } } } } // 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
- LineServicesRun.cs
- WebRequestModuleElementCollection.cs
- Int32Animation.cs
- SortQuery.cs
- NetMsmqBindingElement.cs
- QueryParameter.cs
- Hash.cs
- AnnotationMap.cs
- XmlSchemaComplexContentExtension.cs
- ViewBox.cs
- M3DUtil.cs
- SiteMapNodeItemEventArgs.cs
- TransformerConfigurationWizardBase.cs
- ReadOnlyPermissionSet.cs
- ToolStripManager.cs
- SafeCoTaskMem.cs
- HasCopySemanticsAttribute.cs
- ItemAutomationPeer.cs
- PeerObject.cs
- NavigationService.cs
- DataListItemCollection.cs
- SecurityToken.cs
- ImageDrawing.cs
- FieldNameLookup.cs
- ControlParameter.cs
- WeakEventTable.cs
- FormViewInsertEventArgs.cs
- CodeCommentStatement.cs
- BitmapCacheBrush.cs
- MailMessage.cs
- Misc.cs
- ListViewUpdatedEventArgs.cs
- FormsAuthenticationCredentials.cs
- _ConnectOverlappedAsyncResult.cs
- QueryableDataSourceEditData.cs
- Section.cs
- ButtonColumn.cs
- NamedElement.cs
- Image.cs
- QuotedStringWriteStateInfo.cs
- DataDocumentXPathNavigator.cs
- ResourcesChangeInfo.cs
- DataIdProcessor.cs
- DBCommandBuilder.cs
- CdpEqualityComparer.cs
- IndividualDeviceConfig.cs
- DataGridBoolColumn.cs
- WizardSideBarListControlItem.cs
- ContentTextAutomationPeer.cs
- DataSourceControlBuilder.cs
- DataGridAutomationPeer.cs
- SimpleRecyclingCache.cs
- DropDownHolder.cs
- DocumentSchemaValidator.cs
- TextElementEditingBehaviorAttribute.cs
- MSG.cs
- InheritanceRules.cs
- SqlStatistics.cs
- SoapMessage.cs
- StyleSelector.cs
- JulianCalendar.cs
- EventSourceCreationData.cs
- RemoteWebConfigurationHostStream.cs
- TypeDescriptorContext.cs
- EasingKeyFrames.cs
- LifetimeMonitor.cs
- DebugHandleTracker.cs
- CookielessHelper.cs
- EpmSyndicationContentDeSerializer.cs
- ComplusEndpointConfigContainer.cs
- Pts.cs
- StateChangeEvent.cs
- UnsafeNativeMethods.cs
- Animatable.cs
- BuildProviderAppliesToAttribute.cs
- CompositeFontParser.cs
- SqlCaseSimplifier.cs
- DataControlFieldHeaderCell.cs
- BookmarkManager.cs
- TableLayoutStyleCollection.cs
- ZipIOModeEnforcingStream.cs
- SQLMembershipProvider.cs
- InternalConfigRoot.cs
- CombinedGeometry.cs
- PenContext.cs
- ClientSettingsProvider.cs
- XmlUTF8TextReader.cs
- LinkConverter.cs
- PropertyGridCommands.cs
- ThicknessAnimationUsingKeyFrames.cs
- Border.cs
- GridViewRowCollection.cs
- RichTextBox.cs
- ColorTranslator.cs
- ImagingCache.cs
- StyleConverter.cs
- AdornedElementPlaceholder.cs
- SizeF.cs
- XmlSchemaComplexContent.cs
- LayoutTableCell.cs