Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / 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
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SettingsProviderCollection.cs
- Parser.cs
- NetworkInformationException.cs
- DomainUpDown.cs
- MatcherBuilder.cs
- SqlNamer.cs
- EventEntry.cs
- DbProviderSpecificTypePropertyAttribute.cs
- SessionMode.cs
- DefaultTextStore.cs
- RequestResponse.cs
- UidManager.cs
- DataChangedEventManager.cs
- XPathMessageFilterElementCollection.cs
- TypeLoadException.cs
- Permission.cs
- AddInIpcChannel.cs
- SimpleBitVector32.cs
- Delay.cs
- RequestResizeEvent.cs
- LinkedResource.cs
- XDRSchema.cs
- XmlDocument.cs
- MILUtilities.cs
- ReturnType.cs
- ScriptIgnoreAttribute.cs
- DataControlPagerLinkButton.cs
- SimpleApplicationHost.cs
- UidPropertyAttribute.cs
- CompressionTransform.cs
- XPathScanner.cs
- SuppressMergeCheckAttribute.cs
- ContentTextAutomationPeer.cs
- KeyValueConfigurationElement.cs
- CollectionView.cs
- JavaScriptString.cs
- LinkedDataMemberFieldEditor.cs
- XmlSchemaException.cs
- tooltip.cs
- Hash.cs
- SubpageParaClient.cs
- MissingMemberException.cs
- FontNamesConverter.cs
- Utils.cs
- WebPartDisplayMode.cs
- QueuePathEditor.cs
- ToolStripProgressBar.cs
- CompiledIdentityConstraint.cs
- ChtmlMobileTextWriter.cs
- ReflectPropertyDescriptor.cs
- AlphabetConverter.cs
- OutputCacheSettingsSection.cs
- HtmlInputFile.cs
- SequenceFullException.cs
- SafeFileMappingHandle.cs
- DispatcherExceptionFilterEventArgs.cs
- CreateUserWizardStep.cs
- HttpModuleCollection.cs
- _AutoWebProxyScriptWrapper.cs
- HttpChannelHelper.cs
- ProjectionCamera.cs
- GridViewRowPresenterBase.cs
- LeftCellWrapper.cs
- ContractMapping.cs
- ToolStripDropDown.cs
- Size3D.cs
- ButtonBaseAdapter.cs
- VisualTarget.cs
- OrderedEnumerableRowCollection.cs
- UnsafeNativeMethods.cs
- RadioButtonList.cs
- SrgsElementFactoryCompiler.cs
- InputScopeNameConverter.cs
- LocalValueEnumerator.cs
- BigInt.cs
- DataTableReader.cs
- ProxyWebPart.cs
- DynamicQueryStringParameter.cs
- TemplateXamlParser.cs
- Flowchart.cs
- DeviceSpecificDesigner.cs
- PhysicalAddress.cs
- WebPartTransformer.cs
- TextEditorParagraphs.cs
- PriorityQueue.cs
- TimeManager.cs
- TextRangeEditLists.cs
- MILUtilities.cs
- BufferedGraphics.cs
- Vertex.cs
- XsdDateTime.cs
- HtmlTernaryTree.cs
- ServiceCredentialsElement.cs
- DateBoldEvent.cs
- ComponentConverter.cs
- _NTAuthentication.cs
- ConfigXmlElement.cs
- GC.cs
- Attributes.cs
- QueryResults.cs