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
- RegexTypeEditor.cs
- RequestCache.cs
- BufferedWebEventProvider.cs
- GridViewRowPresenterBase.cs
- RegexMatchCollection.cs
- Pair.cs
- RichTextBox.cs
- UniqueConstraint.cs
- RequestCachingSection.cs
- ISFTagAndGuidCache.cs
- ColumnResult.cs
- PixelShader.cs
- GlobalItem.cs
- DataGridItemCollection.cs
- BamlRecordReader.cs
- CSharpCodeProvider.cs
- SplayTreeNode.cs
- ErrorRuntimeConfig.cs
- BitmapEffectDrawingContextState.cs
- UriSectionData.cs
- SystemInfo.cs
- WebErrorHandler.cs
- TreeNodeBinding.cs
- ByteRangeDownloader.cs
- AlternateView.cs
- SqlUserDefinedAggregateAttribute.cs
- DatagridviewDisplayedBandsData.cs
- TransformCollection.cs
- WorkflowRuntime.cs
- HtmlInputImage.cs
- ActivityDesignerLayoutSerializers.cs
- WebServiceAttribute.cs
- QilPatternVisitor.cs
- NavigationProgressEventArgs.cs
- TimeSpanConverter.cs
- SoapExtensionTypeElement.cs
- XmlJsonReader.cs
- IUnknownConstantAttribute.cs
- ConfigurationElementProperty.cs
- RowType.cs
- HttpCachePolicyElement.cs
- FunctionImportElement.cs
- LogWriteRestartAreaAsyncResult.cs
- GridViewRowCollection.cs
- SettingsProviderCollection.cs
- PropertyGridEditorPart.cs
- TrustSection.cs
- CharacterShapingProperties.cs
- WpfPayload.cs
- ElapsedEventArgs.cs
- RelationshipType.cs
- ResourceAssociationTypeEnd.cs
- XamlPointCollectionSerializer.cs
- ReadOnlyHierarchicalDataSource.cs
- RedirectionProxy.cs
- DataControlFieldTypeEditor.cs
- ErrorStyle.cs
- _CommandStream.cs
- DelegateHelpers.Generated.cs
- LinkedResourceCollection.cs
- DataReaderContainer.cs
- ExpressionBuilder.cs
- TextEndOfLine.cs
- ExpressionWriter.cs
- ProcessStartInfo.cs
- filewebrequest.cs
- MenuItemStyle.cs
- ResourcePart.cs
- SpeechRecognizer.cs
- ToolStripPanel.cs
- NotSupportedException.cs
- entitydatasourceentitysetnameconverter.cs
- PolyBezierSegment.cs
- XmlDocumentFragment.cs
- EventlogProvider.cs
- StylusEventArgs.cs
- TdsRecordBufferSetter.cs
- UiaCoreProviderApi.cs
- TogglePatternIdentifiers.cs
- TextDocumentView.cs
- ExpressionVisitorHelpers.cs
- XmlDictionaryReader.cs
- ResourceSetExpression.cs
- SqlAggregateChecker.cs
- WindowsIdentity.cs
- Type.cs
- IndentedWriter.cs
- MarkupCompiler.cs
- AppDomainProtocolHandler.cs
- FullTextState.cs
- Quaternion.cs
- StorageMappingFragment.cs
- XPathNodeList.cs
- GC.cs
- AssemblyCache.cs
- EdmError.cs
- NegotiationTokenAuthenticatorState.cs
- TextServicesManager.cs
- XmlUrlResolver.cs
- LineProperties.cs