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
- ClientConvert.cs
- WebRequestModuleElement.cs
- ConnectionsZoneDesigner.cs
- TextParentUndoUnit.cs
- BuildProvider.cs
- XamlSerializationHelper.cs
- RepeaterItemEventArgs.cs
- BaseTypeViewSchema.cs
- ImpersonationOption.cs
- MemberInfoSerializationHolder.cs
- AsyncStreamReader.cs
- SoapSchemaMember.cs
- DataSourceConverter.cs
- AspNetSynchronizationContext.cs
- Graphics.cs
- AssociationSetMetadata.cs
- HandleCollector.cs
- Journal.cs
- ColorConvertedBitmapExtension.cs
- QilGeneratorEnv.cs
- ReadOnlyHierarchicalDataSource.cs
- ElasticEase.cs
- SignatureToken.cs
- DelegatingMessage.cs
- MappingMetadataHelper.cs
- TextEffect.cs
- EntityParameter.cs
- DataGridViewCellConverter.cs
- DbUpdateCommandTree.cs
- ToolStripItemEventArgs.cs
- MSAAEventDispatcher.cs
- StylusPlugin.cs
- ItemCheckedEvent.cs
- WebRequestModuleElementCollection.cs
- DataListCommandEventArgs.cs
- ButtonField.cs
- xmlfixedPageInfo.cs
- BindingManagerDataErrorEventArgs.cs
- EventPrivateKey.cs
- SchemaHelper.cs
- ConditionValidator.cs
- Stacktrace.cs
- NativeMethodsCLR.cs
- Stylesheet.cs
- MessageBuffer.cs
- CookielessHelper.cs
- SecurityException.cs
- InfiniteIntConverter.cs
- ScrollProperties.cs
- SqlTypeConverter.cs
- Configuration.cs
- KeyboardDevice.cs
- SafeHandles.cs
- InitializerFacet.cs
- ClientOptions.cs
- OracleRowUpdatedEventArgs.cs
- SystemResourceHost.cs
- SqlRecordBuffer.cs
- Application.cs
- PointAnimationUsingPath.cs
- ConfigurationConverterBase.cs
- MessageRpc.cs
- SqlDataSourceConfigureSortForm.cs
- HttpVersion.cs
- GetLedgerRequest.cs
- NonBatchDirectoryCompiler.cs
- ObjectFactoryCodeDomTreeGenerator.cs
- AlternationConverter.cs
- SiteMapProvider.cs
- ControlCommandSet.cs
- MimeBasePart.cs
- AuthorizationSection.cs
- CustomError.cs
- FrameSecurityDescriptor.cs
- Debugger.cs
- ObjectPersistData.cs
- VirtualizingPanel.cs
- HybridDictionary.cs
- Debug.cs
- ComPlusInstanceContextInitializer.cs
- ListViewInsertedEventArgs.cs
- Processor.cs
- FieldTemplateFactory.cs
- Rect.cs
- SupportsEventValidationAttribute.cs
- Int16.cs
- DictionaryContent.cs
- _NestedSingleAsyncResult.cs
- StringCollectionEditor.cs
- Constants.cs
- DataTableClearEvent.cs
- AttributeAction.cs
- TextRangeSerialization.cs
- Sorting.cs
- PerfCounters.cs
- TemplatePropertyEntry.cs
- XmlDocument.cs
- OutputWindow.cs
- BaseProcessor.cs
- DataGridRowHeaderAutomationPeer.cs