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
- MatrixUtil.cs
- Application.cs
- LostFocusEventManager.cs
- NameSpaceExtractor.cs
- EnumValAlphaComparer.cs
- CapabilitiesRule.cs
- FixedSchema.cs
- DataListItem.cs
- DataPagerCommandEventArgs.cs
- XslCompiledTransform.cs
- MobileListItemCollection.cs
- Cloud.cs
- FixedSOMSemanticBox.cs
- ComplexPropertyEntry.cs
- FormsAuthenticationEventArgs.cs
- EdmFunction.cs
- EditCommandColumn.cs
- ExternalCalls.cs
- CodeAssignStatement.cs
- TypeSource.cs
- ActivityCodeDomSerializer.cs
- SparseMemoryStream.cs
- ThreadStaticAttribute.cs
- CustomLineCap.cs
- DictionaryMarkupSerializer.cs
- WaitHandleCannotBeOpenedException.cs
- TransactionProtocolConverter.cs
- PipeSecurity.cs
- CompiledXpathExpr.cs
- PersonalizablePropertyEntry.cs
- PenContext.cs
- StringPropertyBuilder.cs
- EntityContainer.cs
- SQLConvert.cs
- SrgsRule.cs
- Matrix.cs
- ReaderWriterLockWrapper.cs
- InvokeProviderWrapper.cs
- TextEditorCharacters.cs
- Timer.cs
- ValueSerializer.cs
- WriteFileContext.cs
- SHA1CryptoServiceProvider.cs
- Inflater.cs
- ProcessHost.cs
- TextServicesProperty.cs
- _AutoWebProxyScriptHelper.cs
- MatrixTransform3D.cs
- WindowsTitleBar.cs
- TraceHandlerErrorFormatter.cs
- ProtocolsConfigurationHandler.cs
- ViewStateModeByIdAttribute.cs
- XmlSerializerNamespaces.cs
- PersonalizableAttribute.cs
- EdmSchemaAttribute.cs
- XmlSerializerFactory.cs
- TreeNode.cs
- Ref.cs
- ReadWriteSpinLock.cs
- HttpPostClientProtocol.cs
- _DomainName.cs
- XhtmlBasicTextBoxAdapter.cs
- UserPersonalizationStateInfo.cs
- BeginStoryboard.cs
- ListBindingHelper.cs
- WithStatement.cs
- ProfilePropertyMetadata.cs
- Cloud.cs
- BinaryMessageFormatter.cs
- Triplet.cs
- ScrollBar.cs
- GridViewRowCollection.cs
- WebServiceHostFactory.cs
- Baml2006KnownTypes.cs
- PolyBezierSegment.cs
- MSG.cs
- OutputCacheEntry.cs
- LogRestartAreaEnumerator.cs
- OdbcPermission.cs
- WindowsRebar.cs
- HandlerBase.cs
- FactoryMaker.cs
- GCHandleCookieTable.cs
- LZCodec.cs
- CryptoKeySecurity.cs
- PolicyImporterElementCollection.cs
- TargetControlTypeAttribute.cs
- Visual3D.cs
- EllipticalNodeOperations.cs
- ChannelTraceRecord.cs
- ProcessHostFactoryHelper.cs
- UseLicense.cs
- DataGridViewElement.cs
- WindowsAltTab.cs
- XmlSchemaType.cs
- TextEffect.cs
- HtmlControlPersistable.cs
- TypeSource.cs
- MenuItem.cs
- InkSerializer.cs