Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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
- FtpWebRequest.cs
- PingReply.cs
- DataGridViewRowPostPaintEventArgs.cs
- CompositeScriptReferenceEventArgs.cs
- XsltQilFactory.cs
- Font.cs
- ComponentConverter.cs
- Activity.cs
- DocumentViewerHelper.cs
- DataControlButton.cs
- AsyncCompletedEventArgs.cs
- CopyAttributesAction.cs
- ZipIOBlockManager.cs
- NameValueFileSectionHandler.cs
- RequestResponse.cs
- ProcessInfo.cs
- HttpRawResponse.cs
- Speller.cs
- SqlStatistics.cs
- SmiTypedGetterSetter.cs
- RealizedColumnsBlock.cs
- SystemColors.cs
- ParameterReplacerVisitor.cs
- EntityDataSourceColumn.cs
- XmlQueryOutput.cs
- DataGridViewAutoSizeColumnsModeEventArgs.cs
- httpapplicationstate.cs
- HScrollBar.cs
- PageSetupDialog.cs
- TextEditorContextMenu.cs
- StyleBamlTreeBuilder.cs
- SoapFault.cs
- EncoderParameter.cs
- QilBinary.cs
- ValidationHelper.cs
- ExpandCollapsePattern.cs
- StringFreezingAttribute.cs
- SystemInfo.cs
- ProcessHost.cs
- Model3D.cs
- AdapterDictionary.cs
- EventSchemaTraceListener.cs
- WebBrowsableAttribute.cs
- webbrowsersite.cs
- coordinatorscratchpad.cs
- SimpleHandlerBuildProvider.cs
- RelationshipSet.cs
- TextRangeEditTables.cs
- PresentationAppDomainManager.cs
- PlainXmlDeserializer.cs
- LinkClickEvent.cs
- DllNotFoundException.cs
- RtfControlWordInfo.cs
- DbSetClause.cs
- PermissionRequestEvidence.cs
- HasCopySemanticsAttribute.cs
- PersistenceProviderBehavior.cs
- DataGridDesigner.cs
- CachedBitmap.cs
- DataGridViewRowHeightInfoPushedEventArgs.cs
- MenuItem.cs
- ProcessHost.cs
- RectKeyFrameCollection.cs
- DataSourceView.cs
- PackagePart.cs
- BamlReader.cs
- MetafileEditor.cs
- WebHttpBinding.cs
- _HeaderInfo.cs
- DataGridColumnDropSeparator.cs
- DataGridViewColumnDesigner.cs
- DateTimeParse.cs
- ExpressionBindings.cs
- securitycriticaldataClass.cs
- StandardCommands.cs
- messageonlyhwndwrapper.cs
- BitVector32.cs
- HttpCachePolicy.cs
- ServiceHttpModule.cs
- Clock.cs
- CompareValidator.cs
- SmiRequestExecutor.cs
- BoundConstants.cs
- HttpRuntimeSection.cs
- ConfigurationValue.cs
- RequiredFieldValidator.cs
- _HeaderInfo.cs
- Barrier.cs
- StrokeRenderer.cs
- TemplateManager.cs
- StringSorter.cs
- AstTree.cs
- Helpers.cs
- SelectionItemPattern.cs
- HtmlGenericControl.cs
- safemediahandle.cs
- VectorCollectionConverter.cs
- HtmlControl.cs
- InputLanguageProfileNotifySink.cs
- InternalPermissions.cs