Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Framework / MS / Internal / Utility / BindUriHelper.cs / 1 / BindUriHelper.cs
//------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2001 // // File: BindUriHelper.cs // // Description: BindUriHelper class. Allows bindToObject, bindToStream // // History: 04-13-01 - marka - created //----------------------------------------------------------------------------- using System; using System.IO; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.Text; using MS.Win32; using System.Security.Permissions; #if PRESENTATIONFRAMEWORK using System.Windows; using System.Windows.Navigation; using System.Windows.Media; using MS.Internal.PresentationFramework; using MS.Internal.AppModel; using System.Windows.Controls; using MS.Internal ; using System.Security; using System.IO.Packaging; using System.Reflection; using MS.Internal.Utility; using System.Net; // In order to avoid generating warnings about unknown message numbers and // unknown pragmas when compiling your C# source code with the actual C# compiler, // you need to disable warnings 1634 and 1691. (Presharp Documentation) #pragma warning disable 1634, 1691 namespace MS.Internal.Utility { // A BindUriHelper class // See also WpfWebRequestHelper. internal static partial class BindUriHelper { private const string PLACEBOURI = "http://microsoft.com/"; static private Uri placeboBase = new Uri(PLACEBOURI); private const string FRAGMENTMARKER = "#"; static internal Uri GetResolvedUri(Uri originalUri) { return GetResolvedUri(null, originalUri); } ////// /// ////// Relative Uri resolution logic /// /// if baseUriString != "" /// { /// if (baseUriString is absolute uri) /// { /// determine uriToNavigate as baseUriString + inputUri /// } /// else /// { /// determine uri to navigate wrt application's base uri + baseUriString + inputUri /// } /// } /// else /// { /// Get the element's NavigationService /// if(NavigationService.CurrentSource is absolute uri) /// { /// determine uriToNavigate as NavigationService.CurrentSource + inputUri /// } /// else // this will be more common /// { /// determine uriToNavigate wrt application's base uri (pack://application,,,/) + NavigationService.CurrentSource + inputUri /// } /// /// /// If no ns in tree, resolve against the application's base /// } /// /// /// /// ///static internal Uri GetUriToNavigate(DependencyObject element, Uri baseUri, Uri inputUri) { Uri uriToNavigate = inputUri; if ((inputUri == null) || (inputUri.IsAbsoluteUri == true)) { return uriToNavigate; } // BaseUri doesn't contain the last part of the path: filename, // so when the inputUri is fragment we cannot resolve with BaseUri, instead // we should resolve with the element's NavigationService's CurrentSource. if (StartWithFragment(inputUri)) { baseUri = null; } if (baseUri != null) { if (baseUri.IsAbsoluteUri == false) { uriToNavigate = GetResolvedUri(BindUriHelper.GetResolvedUri(null, baseUri), inputUri); } else { uriToNavigate = GetResolvedUri(baseUri, inputUri); } } else // we're in here when baseUri is not set i.e. it's null { Uri currentSource = null; // if the it is an INavigator (Frame, NavWin), we should use its CurrentSource property. // Otherwise we need to get NavigationService of the container that this element is hosted in, // and use its CurrentSource. if (element != null) { INavigator navigator = element as INavigator; if (navigator != null) { currentSource = navigator.CurrentSource; } else { NavigationService ns = null; ns = element.GetValue(NavigationService.NavigationServiceProperty) as NavigationService; currentSource = (ns == null) ? null : ns.CurrentSource; } } if (currentSource != null) { if (currentSource.IsAbsoluteUri) { uriToNavigate = GetResolvedUri(currentSource, inputUri); } else { uriToNavigate = GetResolvedUri(GetResolvedUri(null, currentSource), inputUri); } } else { // // For now we resolve to Application's base uriToNavigate = BindUriHelper.GetResolvedUri(null, inputUri); } } return uriToNavigate; } static internal bool StartWithFragment(Uri uri) { return uri.OriginalString.StartsWith(FRAGMENTMARKER, StringComparison.Ordinal); } // Return Fragment string for a given uri without the leading # static internal string GetFragment(Uri uri) { Uri workuri = uri; string fragment = String.Empty; string frag; if (uri.IsAbsoluteUri == false) { // this is a relative uri, and Fragement() doesn't work with relative uris. The base uri is completley irrelevant // here and will never affect the returned fragment, but the method requires something to be there. Therefore, // we will use "http://microsoft.com" as a convenient substitute. workuri = new Uri(placeboBase, uri); } frag = workuri.Fragment; if (frag != null && frag.Length > 0) { // take off the pound fragment = frag.Substring(1); } return fragment; } // In NavigationService we do not want to show users pack://application,,,/ with the // Source property or any event arguments. static internal Uri GetUriRelativeToPackAppBase(Uri original) { if (original == null) { return null; } Uri resolved = GetResolvedUri(original); Uri packUri = BaseUriHelper.PackAppBaseUri; Uri relative = packUri.MakeRelativeUri(resolved); return relative; } static internal bool IsXamlMimeType(ContentType mimeType) { if (MimeTypeMapper.XamlMime.AreTypeAndSubTypeEqual(mimeType) || MimeTypeMapper.FixedDocumentSequenceMime.AreTypeAndSubTypeEqual(mimeType) || MimeTypeMapper.FixedDocumentMime.AreTypeAndSubTypeEqual(mimeType) || MimeTypeMapper.FixedPageMime.AreTypeAndSubTypeEqual(mimeType)) { return true; } return false; } } } #endif // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2001 // // File: BindUriHelper.cs // // Description: BindUriHelper class. Allows bindToObject, bindToStream // // History: 04-13-01 - marka - created //----------------------------------------------------------------------------- using System; using System.IO; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.Text; using MS.Win32; using System.Security.Permissions; #if PRESENTATIONFRAMEWORK using System.Windows; using System.Windows.Navigation; using System.Windows.Media; using MS.Internal.PresentationFramework; using MS.Internal.AppModel; using System.Windows.Controls; using MS.Internal ; using System.Security; using System.IO.Packaging; using System.Reflection; using MS.Internal.Utility; using System.Net; // In order to avoid generating warnings about unknown message numbers and // unknown pragmas when compiling your C# source code with the actual C# compiler, // you need to disable warnings 1634 and 1691. (Presharp Documentation) #pragma warning disable 1634, 1691 namespace MS.Internal.Utility { // A BindUriHelper class // See also WpfWebRequestHelper. internal static partial class BindUriHelper { private const string PLACEBOURI = "http://microsoft.com/"; static private Uri placeboBase = new Uri(PLACEBOURI); private const string FRAGMENTMARKER = "#"; static internal Uri GetResolvedUri(Uri originalUri) { return GetResolvedUri(null, originalUri); } /// /// /// ////// Relative Uri resolution logic /// /// if baseUriString != "" /// { /// if (baseUriString is absolute uri) /// { /// determine uriToNavigate as baseUriString + inputUri /// } /// else /// { /// determine uri to navigate wrt application's base uri + baseUriString + inputUri /// } /// } /// else /// { /// Get the element's NavigationService /// if(NavigationService.CurrentSource is absolute uri) /// { /// determine uriToNavigate as NavigationService.CurrentSource + inputUri /// } /// else // this will be more common /// { /// determine uriToNavigate wrt application's base uri (pack://application,,,/) + NavigationService.CurrentSource + inputUri /// } /// /// /// If no ns in tree, resolve against the application's base /// } /// /// /// /// ///static internal Uri GetUriToNavigate(DependencyObject element, Uri baseUri, Uri inputUri) { Uri uriToNavigate = inputUri; if ((inputUri == null) || (inputUri.IsAbsoluteUri == true)) { return uriToNavigate; } // BaseUri doesn't contain the last part of the path: filename, // so when the inputUri is fragment we cannot resolve with BaseUri, instead // we should resolve with the element's NavigationService's CurrentSource. if (StartWithFragment(inputUri)) { baseUri = null; } if (baseUri != null) { if (baseUri.IsAbsoluteUri == false) { uriToNavigate = GetResolvedUri(BindUriHelper.GetResolvedUri(null, baseUri), inputUri); } else { uriToNavigate = GetResolvedUri(baseUri, inputUri); } } else // we're in here when baseUri is not set i.e. it's null { Uri currentSource = null; // if the it is an INavigator (Frame, NavWin), we should use its CurrentSource property. // Otherwise we need to get NavigationService of the container that this element is hosted in, // and use its CurrentSource. if (element != null) { INavigator navigator = element as INavigator; if (navigator != null) { currentSource = navigator.CurrentSource; } else { NavigationService ns = null; ns = element.GetValue(NavigationService.NavigationServiceProperty) as NavigationService; currentSource = (ns == null) ? null : ns.CurrentSource; } } if (currentSource != null) { if (currentSource.IsAbsoluteUri) { uriToNavigate = GetResolvedUri(currentSource, inputUri); } else { uriToNavigate = GetResolvedUri(GetResolvedUri(null, currentSource), inputUri); } } else { // // For now we resolve to Application's base uriToNavigate = BindUriHelper.GetResolvedUri(null, inputUri); } } return uriToNavigate; } static internal bool StartWithFragment(Uri uri) { return uri.OriginalString.StartsWith(FRAGMENTMARKER, StringComparison.Ordinal); } // Return Fragment string for a given uri without the leading # static internal string GetFragment(Uri uri) { Uri workuri = uri; string fragment = String.Empty; string frag; if (uri.IsAbsoluteUri == false) { // this is a relative uri, and Fragement() doesn't work with relative uris. The base uri is completley irrelevant // here and will never affect the returned fragment, but the method requires something to be there. Therefore, // we will use "http://microsoft.com" as a convenient substitute. workuri = new Uri(placeboBase, uri); } frag = workuri.Fragment; if (frag != null && frag.Length > 0) { // take off the pound fragment = frag.Substring(1); } return fragment; } // In NavigationService we do not want to show users pack://application,,,/ with the // Source property or any event arguments. static internal Uri GetUriRelativeToPackAppBase(Uri original) { if (original == null) { return null; } Uri resolved = GetResolvedUri(original); Uri packUri = BaseUriHelper.PackAppBaseUri; Uri relative = packUri.MakeRelativeUri(resolved); return relative; } static internal bool IsXamlMimeType(ContentType mimeType) { if (MimeTypeMapper.XamlMime.AreTypeAndSubTypeEqual(mimeType) || MimeTypeMapper.FixedDocumentSequenceMime.AreTypeAndSubTypeEqual(mimeType) || MimeTypeMapper.FixedDocumentMime.AreTypeAndSubTypeEqual(mimeType) || MimeTypeMapper.FixedPageMime.AreTypeAndSubTypeEqual(mimeType)) { return true; } return false; } } } #endif // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
![Network programming in C#, Network Programming in VB.NET, Network Programming in .NET](/images/book.jpg)
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- CodeCommentStatement.cs
- AssemblyCollection.cs
- ViewStateModeByIdAttribute.cs
- _IPv6Address.cs
- CodeLabeledStatement.cs
- FileEnumerator.cs
- NameValuePermission.cs
- CommentEmitter.cs
- DBConnectionString.cs
- XmlAnyElementAttribute.cs
- DataKeyCollection.cs
- LayoutManager.cs
- FontFamily.cs
- HtmlControlPersistable.cs
- PaperSize.cs
- SqlTypeConverter.cs
- DrawingServices.cs
- PrivateFontCollection.cs
- XmlSchemaGroupRef.cs
- ScriptResourceInfo.cs
- ViewManagerAttribute.cs
- BamlVersionHeader.cs
- StylesEditorDialog.cs
- DataSourceHelper.cs
- InstanceNameConverter.cs
- DesignSurfaceManager.cs
- MimeObjectFactory.cs
- PenThread.cs
- XmlSchemaAny.cs
- SystemIPGlobalProperties.cs
- DataGridViewRowEventArgs.cs
- ListViewContainer.cs
- TextSelection.cs
- MouseGesture.cs
- HostedHttpContext.cs
- XPathNavigatorKeyComparer.cs
- _DynamicWinsockMethods.cs
- ApplicationTrust.cs
- AdRotator.cs
- FocusManager.cs
- TextBoxBase.cs
- Converter.cs
- DynamicQueryStringParameter.cs
- DesignerListAdapter.cs
- ItemChangedEventArgs.cs
- SqlIdentifier.cs
- DataControlImageButton.cs
- DataGridLinkButton.cs
- DependencyPropertyHelper.cs
- CodeIdentifiers.cs
- ObjectDataProvider.cs
- LoginUtil.cs
- CompilerGlobalScopeAttribute.cs
- DataGridViewCheckBoxCell.cs
- SchemaMapping.cs
- SchemaHelper.cs
- TypePresenter.xaml.cs
- DataServiceQueryOfT.cs
- ContextMenuAutomationPeer.cs
- WebPartActionVerb.cs
- BezierSegment.cs
- ModelPerspective.cs
- UnitControl.cs
- HtmlAnchor.cs
- BindingGroup.cs
- XmlChildEnumerator.cs
- PersonalizationProvider.cs
- DesignerRegion.cs
- XhtmlStyleClass.cs
- XPathEmptyIterator.cs
- SerialErrors.cs
- WorkflowMarkupSerializationProvider.cs
- TypeExtensions.cs
- ParameterCollectionEditor.cs
- BamlMapTable.cs
- LayoutEvent.cs
- ActivitySurrogateSelector.cs
- QueryStringConverter.cs
- TextRenderer.cs
- HttpResponseInternalBase.cs
- OracleLob.cs
- CreateParams.cs
- BindingSource.cs
- DataGridViewButtonCell.cs
- ContentElement.cs
- FrameworkElementAutomationPeer.cs
- FolderLevelBuildProviderCollection.cs
- ClientFormsAuthenticationCredentials.cs
- HMACSHA512.cs
- InstanceContextManager.cs
- AdapterUtil.cs
- ByteAnimationBase.cs
- CodeDirectiveCollection.cs
- TreeIterator.cs
- QuaternionRotation3D.cs
- EdmConstants.cs
- LinkUtilities.cs
- WebConfigurationHost.cs
- OpCopier.cs
- HttpDebugHandler.cs