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
- RIPEMD160.cs
- AttributeQuery.cs
- DataGridViewCellValidatingEventArgs.cs
- PageCatalogPart.cs
- LockedHandleGlyph.cs
- TransformGroup.cs
- BitmapEffectCollection.cs
- AsymmetricKeyExchangeDeformatter.cs
- CompareInfo.cs
- ValidatorCollection.cs
- UserNamePasswordClientCredential.cs
- MetadataPropertyCollection.cs
- TypeGeneratedEventArgs.cs
- BinaryObjectInfo.cs
- ADMembershipProvider.cs
- CollectionsUtil.cs
- CodeBlockBuilder.cs
- ThreadStartException.cs
- EnumerableRowCollectionExtensions.cs
- SerializationAttributes.cs
- CodeTypeMember.cs
- KoreanLunisolarCalendar.cs
- BitmapPalettes.cs
- TableLayout.cs
- DLinqAssociationProvider.cs
- CodeExpressionStatement.cs
- LambdaExpression.cs
- SafeNativeMethods.cs
- OleDbEnumerator.cs
- RegexTree.cs
- CheckBoxFlatAdapter.cs
- DataGridViewLayoutData.cs
- CheckBox.cs
- Native.cs
- DataGridViewCellConverter.cs
- SpellCheck.cs
- TagNameToTypeMapper.cs
- ListItemConverter.cs
- Matrix.cs
- EndPoint.cs
- ImageDrawing.cs
- GCHandleCookieTable.cs
- IdentifierService.cs
- CachedRequestParams.cs
- RadioButton.cs
- StringArrayConverter.cs
- XNodeValidator.cs
- FixedSOMContainer.cs
- HtmlInputPassword.cs
- TextEditorTables.cs
- BindingWorker.cs
- DoubleCollection.cs
- ZoneMembershipCondition.cs
- ClassHandlersStore.cs
- IpcServerChannel.cs
- CustomWebEventKey.cs
- AssociationProvider.cs
- Part.cs
- TextTreePropertyUndoUnit.cs
- SystemIPv4InterfaceProperties.cs
- StorageEntitySetMapping.cs
- ConditionalAttribute.cs
- Focus.cs
- CodeBinaryOperatorExpression.cs
- BitmapEffectDrawingContextState.cs
- Label.cs
- StorageConditionPropertyMapping.cs
- HttpApplicationFactory.cs
- EntityCommandCompilationException.cs
- SqlBinder.cs
- BindingExpressionBase.cs
- BamlTreeNode.cs
- WebPartCollection.cs
- XmlSchemaGroupRef.cs
- XMLDiffLoader.cs
- OleDbParameterCollection.cs
- DataGridViewCellToolTipTextNeededEventArgs.cs
- ConnectionManagementSection.cs
- ReplacementText.cs
- XmlNavigatorStack.cs
- SignatureHelper.cs
- BatchWriter.cs
- FrameworkElement.cs
- TypeBrowser.xaml.cs
- LostFocusEventManager.cs
- DataTableMapping.cs
- BitmapEffectInput.cs
- AttachmentCollection.cs
- ProfessionalColorTable.cs
- CompositeScriptReference.cs
- ModifyActivitiesPropertyDescriptor.cs
- GridViewRow.cs
- EntitySqlQueryState.cs
- XmlSchemaSubstitutionGroup.cs
- DllHostInitializer.cs
- MessageSmuggler.cs
- InternalConfigHost.cs
- CodeTypeParameterCollection.cs
- XmlSerializationGeneratedCode.cs
- RealProxy.cs