Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Shared / MS / Internal / ResourceIDHelper.cs / 1 / ResourceIDHelper.cs
using System; using System.Text; using System.Globalization; namespace MS.Internal { internal static class ResourceIDHelper { // // Convert relative path to the right format which is used // as ResourceID. // MarkupCompiler, ResXGen, Loader will call this method internally. // static internal string GetResourceIDFromRelativePath(string relPath) { // It is important that relPath not contain a fragment or query at this point // // Currently this will always be true because // 1) The resources listed in the .proj file are tested against the filesystem // to see if they exist. If a query or fragment was present this test would fail. // 2) In the new loader the container apis make sure that the fragment and query are // stripped from the Uri to form the part name which is used to load the resource Uri baseUri = new Uri("http://foo/"); Uri srcUri = new Uri(baseUri, relPath.Replace("#", "%23")); return GetResourceIDFromUri(baseUri, srcUri); } // // This is the central place that returns right ResourceID for // the passed SourceUri. // static private string GetResourceIDFromUri(Uri baseUri, Uri sourceUri) { string resourceID = String.Empty; // // Extracts and returns the resource ID from a URI. // If the source URI is under the baseUri, the resource ID is the URI // after the baseUri and any fragment or query has been removed. // The resource ID is always converted to lower case. // // If the sourceUri is not relative to baseUri, Emtpy string is returned // as resource id. // if (baseUri.IsAbsoluteUri == false || sourceUri.IsAbsoluteUri == false) { // // if any passed Uri is not absolute uri, return empty string here. // return resourceID; } if (baseUri.Scheme == sourceUri.Scheme && baseUri.Host == sourceUri.Host) { // // Get the escaped Path part, Path doesn't include Query and Fragment. // string basePath = baseUri.GetComponents(UriComponents.Path, UriFormat.UriEscaped); string sourcePath = sourceUri.GetComponents(UriComponents.Path, UriFormat.UriEscaped); // // Always lower case the Path string. // basePath = basePath.ToLower(CultureInfo.InvariantCulture); sourcePath = sourcePath.ToLower(CultureInfo.InvariantCulture); if (sourcePath.StartsWith(basePath, StringComparison.OrdinalIgnoreCase)) { resourceID = sourcePath.Substring(basePath.Length); } } return resourceID; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System; using System.Text; using System.Globalization; namespace MS.Internal { internal static class ResourceIDHelper { // // Convert relative path to the right format which is used // as ResourceID. // MarkupCompiler, ResXGen, Loader will call this method internally. // static internal string GetResourceIDFromRelativePath(string relPath) { // It is important that relPath not contain a fragment or query at this point // // Currently this will always be true because // 1) The resources listed in the .proj file are tested against the filesystem // to see if they exist. If a query or fragment was present this test would fail. // 2) In the new loader the container apis make sure that the fragment and query are // stripped from the Uri to form the part name which is used to load the resource Uri baseUri = new Uri("http://foo/"); Uri srcUri = new Uri(baseUri, relPath.Replace("#", "%23")); return GetResourceIDFromUri(baseUri, srcUri); } // // This is the central place that returns right ResourceID for // the passed SourceUri. // static private string GetResourceIDFromUri(Uri baseUri, Uri sourceUri) { string resourceID = String.Empty; // // Extracts and returns the resource ID from a URI. // If the source URI is under the baseUri, the resource ID is the URI // after the baseUri and any fragment or query has been removed. // The resource ID is always converted to lower case. // // If the sourceUri is not relative to baseUri, Emtpy string is returned // as resource id. // if (baseUri.IsAbsoluteUri == false || sourceUri.IsAbsoluteUri == false) { // // if any passed Uri is not absolute uri, return empty string here. // return resourceID; } if (baseUri.Scheme == sourceUri.Scheme && baseUri.Host == sourceUri.Host) { // // Get the escaped Path part, Path doesn't include Query and Fragment. // string basePath = baseUri.GetComponents(UriComponents.Path, UriFormat.UriEscaped); string sourcePath = sourceUri.GetComponents(UriComponents.Path, UriFormat.UriEscaped); // // Always lower case the Path string. // basePath = basePath.ToLower(CultureInfo.InvariantCulture); sourcePath = sourcePath.ToLower(CultureInfo.InvariantCulture); if (sourcePath.StartsWith(basePath, StringComparison.OrdinalIgnoreCase)) { resourceID = sourcePath.Substring(basePath.Length); } } return resourceID; } } } // 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
- SqlTransaction.cs
- BamlRecords.cs
- ParameterBuilder.cs
- UnsafeNativeMethods.cs
- DescendentsWalkerBase.cs
- RowSpanVector.cs
- DeferredReference.cs
- GeneralTransform.cs
- ReadOnlyCollection.cs
- MetabaseServerConfig.cs
- AttributeAction.cs
- WebScriptClientGenerator.cs
- _ProxyRegBlob.cs
- HttpCachePolicyElement.cs
- Action.cs
- ManipulationBoundaryFeedbackEventArgs.cs
- DirectionalAction.cs
- GroupLabel.cs
- EntityDataSourceQueryBuilder.cs
- PropagatorResult.cs
- DesignerDataSourceView.cs
- ConfigurationStrings.cs
- LocalizabilityAttribute.cs
- Misc.cs
- VersionedStream.cs
- RequestNavigateEventArgs.cs
- XDeferredAxisSource.cs
- MemberDescriptor.cs
- ClientUIRequest.cs
- InstanceCreationEditor.cs
- AnnotationObservableCollection.cs
- UrlPath.cs
- ContainerControl.cs
- SafeNativeMethods.cs
- ComPlusServiceHost.cs
- Button.cs
- EventSchemaTraceListener.cs
- PropertyPathConverter.cs
- ResourceContainerWrapper.cs
- ReflectionUtil.cs
- WebPartAddingEventArgs.cs
- DynamicFilter.cs
- StringStorage.cs
- ACL.cs
- ConstNode.cs
- DragDeltaEventArgs.cs
- EditorAttribute.cs
- TypeTypeConverter.cs
- DataControlFieldHeaderCell.cs
- DBConnectionString.cs
- JsonFormatWriterGenerator.cs
- VerticalAlignConverter.cs
- StoreContentChangedEventArgs.cs
- Rotation3D.cs
- InplaceBitmapMetadataWriter.cs
- followingquery.cs
- DispatchRuntime.cs
- SelectingProviderEventArgs.cs
- DataPointer.cs
- TerminatorSinks.cs
- ScriptServiceAttribute.cs
- QilInvoke.cs
- InputProcessorProfilesLoader.cs
- DataGridViewRowHeightInfoPushedEventArgs.cs
- TextRenderingModeValidation.cs
- XPathNodeInfoAtom.cs
- VarInfo.cs
- ScrollData.cs
- DbProviderFactoriesConfigurationHandler.cs
- ArrangedElementCollection.cs
- Command.cs
- regiisutil.cs
- Trigger.cs
- DataGridBoundColumn.cs
- DropDownButton.cs
- Mapping.cs
- Exceptions.cs
- WorkflowInspectionServices.cs
- ContentFileHelper.cs
- HtmlHistory.cs
- EntityDataSourceValidationException.cs
- BuildManager.cs
- OdbcError.cs
- XmlNamespaceMapping.cs
- EditorAttribute.cs
- NamespaceDecl.cs
- EntityDataSourceMemberPath.cs
- ValueTable.cs
- Translator.cs
- ReflectionServiceProvider.cs
- PluralizationServiceUtil.cs
- ListSourceHelper.cs
- Section.cs
- HandlerBase.cs
- AppSettingsSection.cs
- ListViewHitTestInfo.cs
- PtsCache.cs
- WizardPanel.cs
- XmlWriterSettings.cs
- MappingMetadataHelper.cs