Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / AddIn / AddIn / System / Addin / Hosting / PipelineDeploymentState.cs / 1305376 / PipelineDeploymentState.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Class: PipelineDeploymentState ** ** Purpose: Represents all the add-in pipeline components ** in a directory structure. ** ===========================================================*/ using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Globalization; using System.IO; using System.Text; using System.Reflection; using System.AddIn.MiniReflection; using System.Diagnostics.Contracts; namespace System.AddIn.Hosting { [Serializable] internal sealed class PipelineDeploymentState : DeploymentState { private List_hostAdapters; private List _contracts; private List _addinAdapters; private List _addinBases; private List _partialTokens; private List _fileCounts; internal PipelineDeploymentState() { _hostAdapters = new List (); _contracts = new List (); _addinAdapters = new List (); _addinBases = new List (); _fileCounts = new List (new int[]{0,0,0,0}); } internal List HostAdapters { get { return _hostAdapters; } } internal List Contracts { get { return _contracts; } } internal List AddInAdapters { get { return _addinAdapters; } } internal List AddInBases { get { return _addinBases; } } internal List PartialTokens { get { return _partialTokens; } } internal List FileCounts { get { return _fileCounts; } } internal void ConnectPipeline(Collection warnings) { List result = new List (); // For ease of maintanence & debugging for users of the add-in // model, we must make it easy to report which parts are not // usable, due to missing connections with other parts of the // pipeline. // Real connect loop. foreach (HostAdapter hostAdapter in HostAdapters) { foreach (ContractComponent contract in Contracts) { if (!hostAdapter.Constructors.Contains(contract.TypeInfo)) continue; hostAdapter.ConnectedToNeighbors = true; foreach (AddInAdapter addinAdapter in AddInAdapters) { if (!addinAdapter.Contracts.Contains(contract.TypeInfo)) continue; contract.ConnectedToNeighbors = true; foreach (AddInBase addinBase in AddInBases) { if (!addinAdapter.CanConnectTo(addinBase)) continue; addinAdapter.ConnectedToNeighbors = true; addinBase.ConnectedToNeighbors = true; PartialToken partialToken = new PartialToken(hostAdapter, contract, addinAdapter, addinBase); result.Add(partialToken); } // foreach addinBase } // foreach addinAdapter } // foreach contract } // foreach hostAdapter // Look for unconnected parts. int unconnectedParts = 0; unconnectedParts += LookForUnconnectedParts(HostAdapters, warnings); unconnectedParts += LookForUnconnectedParts(Contracts, warnings); unconnectedParts += LookForUnconnectedParts(AddInAdapters, warnings); unconnectedParts += LookForUnconnectedParts(AddInBases, warnings); #if ADDIN_VERBOSE_WARNINGS warnings.Add(String.Format(CultureInfo.CurrentCulture, "PipelineDeploymentState::Connect: Found {0} valid pipelines.", result.Count)); #endif if (unconnectedParts > 0) warnings.Add(String.Format(CultureInfo.CurrentCulture, Res.CouldntConnectNInvalidParts, unconnectedParts)); _partialTokens = result; } private static int LookForUnconnectedParts (IEnumerable parts, Collection warnings) where T : PipelineComponent { int numUnconnected = 0; foreach (PipelineComponent part in parts) { if (!part.ConnectedToNeighbors) { warnings.Add(String.Format(CultureInfo.CurrentCulture, Res.CouldntConnectOnePart, part.ToString())); numUnconnected++; } } return numUnconnected; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Class: PipelineDeploymentState ** ** Purpose: Represents all the add-in pipeline components ** in a directory structure. ** ===========================================================*/ using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Globalization; using System.IO; using System.Text; using System.Reflection; using System.AddIn.MiniReflection; using System.Diagnostics.Contracts; namespace System.AddIn.Hosting { [Serializable] internal sealed class PipelineDeploymentState : DeploymentState { private List _hostAdapters; private List _contracts; private List _addinAdapters; private List _addinBases; private List _partialTokens; private List _fileCounts; internal PipelineDeploymentState() { _hostAdapters = new List (); _contracts = new List (); _addinAdapters = new List (); _addinBases = new List (); _fileCounts = new List (new int[]{0,0,0,0}); } internal List HostAdapters { get { return _hostAdapters; } } internal List Contracts { get { return _contracts; } } internal List AddInAdapters { get { return _addinAdapters; } } internal List AddInBases { get { return _addinBases; } } internal List PartialTokens { get { return _partialTokens; } } internal List FileCounts { get { return _fileCounts; } } internal void ConnectPipeline(Collection warnings) { List result = new List (); // For ease of maintanence & debugging for users of the add-in // model, we must make it easy to report which parts are not // usable, due to missing connections with other parts of the // pipeline. // Real connect loop. foreach (HostAdapter hostAdapter in HostAdapters) { foreach (ContractComponent contract in Contracts) { if (!hostAdapter.Constructors.Contains(contract.TypeInfo)) continue; hostAdapter.ConnectedToNeighbors = true; foreach (AddInAdapter addinAdapter in AddInAdapters) { if (!addinAdapter.Contracts.Contains(contract.TypeInfo)) continue; contract.ConnectedToNeighbors = true; foreach (AddInBase addinBase in AddInBases) { if (!addinAdapter.CanConnectTo(addinBase)) continue; addinAdapter.ConnectedToNeighbors = true; addinBase.ConnectedToNeighbors = true; PartialToken partialToken = new PartialToken(hostAdapter, contract, addinAdapter, addinBase); result.Add(partialToken); } // foreach addinBase } // foreach addinAdapter } // foreach contract } // foreach hostAdapter // Look for unconnected parts. int unconnectedParts = 0; unconnectedParts += LookForUnconnectedParts(HostAdapters, warnings); unconnectedParts += LookForUnconnectedParts(Contracts, warnings); unconnectedParts += LookForUnconnectedParts(AddInAdapters, warnings); unconnectedParts += LookForUnconnectedParts(AddInBases, warnings); #if ADDIN_VERBOSE_WARNINGS warnings.Add(String.Format(CultureInfo.CurrentCulture, "PipelineDeploymentState::Connect: Found {0} valid pipelines.", result.Count)); #endif if (unconnectedParts > 0) warnings.Add(String.Format(CultureInfo.CurrentCulture, Res.CouldntConnectNInvalidParts, unconnectedParts)); _partialTokens = result; } private static int LookForUnconnectedParts (IEnumerable parts, Collection warnings) where T : PipelineComponent { int numUnconnected = 0; foreach (PipelineComponent part in parts) { if (!part.ConnectedToNeighbors) { warnings.Add(String.Format(CultureInfo.CurrentCulture, Res.CouldntConnectOnePart, part.ToString())); numUnconnected++; } } return numUnconnected; } } } // 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
- TextBlockAutomationPeer.cs
- Rule.cs
- ListenerAdaptersInstallComponent.cs
- RecordConverter.cs
- SimpleMailWebEventProvider.cs
- InputScopeConverter.cs
- CacheDependency.cs
- BamlBinaryReader.cs
- WindowPatternIdentifiers.cs
- ClientSponsor.cs
- CompositeFontFamily.cs
- XmlNavigatorFilter.cs
- BinarySerializer.cs
- SchemaConstraints.cs
- StringBuilder.cs
- MapPathBasedVirtualPathProvider.cs
- ClientSettingsProvider.cs
- IHttpResponseInternal.cs
- DiffuseMaterial.cs
- ProfileManager.cs
- ReadContentAsBinaryHelper.cs
- FixedPageProcessor.cs
- PropertySourceInfo.cs
- SoapElementAttribute.cs
- XPathConvert.cs
- CqlParserHelpers.cs
- TableDetailsCollection.cs
- CharacterBuffer.cs
- PermissionSet.cs
- ObjectListFieldCollection.cs
- BitmapEffectState.cs
- ProfileProvider.cs
- XmlSchemaProviderAttribute.cs
- TextEmbeddedObject.cs
- HttpServerChannel.cs
- PerformanceCounterPermissionEntryCollection.cs
- IISMapPath.cs
- Properties.cs
- TcpConnectionPoolSettingsElement.cs
- RectangleConverter.cs
- OpenFileDialog.cs
- SubpageParaClient.cs
- SQlBooleanStorage.cs
- SynchronizationContext.cs
- TrackingQueryElement.cs
- AuthenticationServiceManager.cs
- EndOfStreamException.cs
- QilTernary.cs
- DataServiceQueryOfT.cs
- KeyGestureValueSerializer.cs
- VariableQuery.cs
- RequestCacheValidator.cs
- _HelperAsyncResults.cs
- ColumnProvider.cs
- FieldBuilder.cs
- CellQuery.cs
- PopupEventArgs.cs
- DataContractAttribute.cs
- NameValuePermission.cs
- IndexedString.cs
- GridEntryCollection.cs
- MeshGeometry3D.cs
- OptimizerPatterns.cs
- Cursor.cs
- MasterPageCodeDomTreeGenerator.cs
- PersistenceProvider.cs
- _ConnectOverlappedAsyncResult.cs
- EntityViewGenerationConstants.cs
- PropertyToken.cs
- TreeViewCancelEvent.cs
- ImageClickEventArgs.cs
- SubordinateTransaction.cs
- ReachSerializationCacheItems.cs
- unitconverter.cs
- SimpleWorkerRequest.cs
- StylusEditingBehavior.cs
- OperationParameterInfoCollection.cs
- KeyFrames.cs
- DataGridViewRowPostPaintEventArgs.cs
- GZipDecoder.cs
- CompilationRelaxations.cs
- TableColumnCollectionInternal.cs
- Predicate.cs
- SkipStoryboardToFill.cs
- DocumentApplication.cs
- MetafileHeaderWmf.cs
- BoundColumn.cs
- SerialReceived.cs
- SettingsAttributeDictionary.cs
- CategoryGridEntry.cs
- SpecularMaterial.cs
- XmlSchemaSubstitutionGroup.cs
- DecoderBestFitFallback.cs
- WindowsRichEdit.cs
- SelectionItemProviderWrapper.cs
- StorageInfo.cs
- PersistenceProviderBehavior.cs
- BitmapSourceSafeMILHandle.cs
- Matrix3DValueSerializer.cs
- TokenFactoryCredential.cs