Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / Misc / ConfigPathUtility.cs / 1 / ConfigPathUtility.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Configuration { #if CONFIGPATHUTILITY_SYSTEMWEB using Debug=System.Web.Util.Debug; #endif internal static class ConfigPathUtility { private const char SeparatorChar = '/'; // // A configPath is valid if // * It does not start or end with a '/' // * It is not null or empty, except in the case of the root configuration record // * It does not contain '\' // * It does not contain a path component equal to "." or ".." // // The checks for '\', ".", and ".." are not strictly necessary, but their presence // could lead to problems for configuration hosts. // static internal bool IsValid(string configPath) { if (String.IsNullOrEmpty(configPath)) { return false; } int start = -1; for (int examine = 0; examine <= configPath.Length; examine++) { char ch; if (examine < configPath.Length) { ch = configPath[examine]; } else { ch = SeparatorChar; } // backslash disallowed if (ch == '\\') { return false; } if (ch == SeparatorChar) { // double slash disallowed // note this check also purposefully catches starting and ending slash if (examine == start + 1) { return false; } // "." disallowed if (examine == start + 2 && configPath[start + 1] == '.') { return false; } // ".." disallowed if (examine == start + 3 && configPath[start + 1] == '.' && configPath[start + 2] == '.') { return false; } start = examine; } } return true; } #if !CONFIGPATHUTILITY_SYSTEMWEB static internal string Combine(string parentConfigPath, string childConfigPath) { Debug.Assert(String.IsNullOrEmpty(parentConfigPath) || IsValid(parentConfigPath), "String.IsNullOrEmpty(parentConfigPath) || IsValid(parentConfigPath)"); Debug.Assert(String.IsNullOrEmpty(childConfigPath) || IsValid(childConfigPath), "String.IsNullOrEmpty(childConfigPath) || IsValid(childConfigPath)"); if (String.IsNullOrEmpty(parentConfigPath)) { return childConfigPath; } if (String.IsNullOrEmpty(childConfigPath)) { return parentConfigPath; } return parentConfigPath + "/" + childConfigPath; } static internal string[] GetParts(string configPath) { Debug.Assert(IsValid(configPath), "IsValid(configPath)"); string[] parts = configPath.Split(SeparatorChar); return parts; } // // Return the last part of a config path, e.g. // GetName("MACHINE/WEBROOT/Default Web Site/app") == "app" // static internal string GetName(string configPath) { Debug.Assert(String.IsNullOrEmpty(configPath) || IsValid(configPath), "String.IsNullOrEmpty(configPath) || IsValid(configPath)"); if (String.IsNullOrEmpty(configPath)) { return configPath; } int index = configPath.LastIndexOf('/'); if (index == -1) { return configPath; } Debug.Assert(index != configPath.Length - 1); return configPath.Substring(index + 1); } #endif // Avoid unused code warning in System.Configuration by including functions in assembly-specific #defines #if CONFIGPATHUTILITY_SYSTEMWEB static internal string GetParent(string configPath) { Debug.Assert(String.IsNullOrEmpty(configPath) || IsValid(configPath), "String.IsNullOrEmpty(configPath) || IsValid(configPath)"); if (String.IsNullOrEmpty(configPath)) { return null; } string parentConfigPath; int lastSlash = configPath.LastIndexOf(SeparatorChar); if (lastSlash == -1) { parentConfigPath = null; } else { parentConfigPath = configPath.Substring(0, lastSlash); } return parentConfigPath; } #endif } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Configuration { #if CONFIGPATHUTILITY_SYSTEMWEB using Debug=System.Web.Util.Debug; #endif internal static class ConfigPathUtility { private const char SeparatorChar = '/'; // // A configPath is valid if // * It does not start or end with a '/' // * It is not null or empty, except in the case of the root configuration record // * It does not contain '\' // * It does not contain a path component equal to "." or ".." // // The checks for '\', ".", and ".." are not strictly necessary, but their presence // could lead to problems for configuration hosts. // static internal bool IsValid(string configPath) { if (String.IsNullOrEmpty(configPath)) { return false; } int start = -1; for (int examine = 0; examine <= configPath.Length; examine++) { char ch; if (examine < configPath.Length) { ch = configPath[examine]; } else { ch = SeparatorChar; } // backslash disallowed if (ch == '\\') { return false; } if (ch == SeparatorChar) { // double slash disallowed // note this check also purposefully catches starting and ending slash if (examine == start + 1) { return false; } // "." disallowed if (examine == start + 2 && configPath[start + 1] == '.') { return false; } // ".." disallowed if (examine == start + 3 && configPath[start + 1] == '.' && configPath[start + 2] == '.') { return false; } start = examine; } } return true; } #if !CONFIGPATHUTILITY_SYSTEMWEB static internal string Combine(string parentConfigPath, string childConfigPath) { Debug.Assert(String.IsNullOrEmpty(parentConfigPath) || IsValid(parentConfigPath), "String.IsNullOrEmpty(parentConfigPath) || IsValid(parentConfigPath)"); Debug.Assert(String.IsNullOrEmpty(childConfigPath) || IsValid(childConfigPath), "String.IsNullOrEmpty(childConfigPath) || IsValid(childConfigPath)"); if (String.IsNullOrEmpty(parentConfigPath)) { return childConfigPath; } if (String.IsNullOrEmpty(childConfigPath)) { return parentConfigPath; } return parentConfigPath + "/" + childConfigPath; } static internal string[] GetParts(string configPath) { Debug.Assert(IsValid(configPath), "IsValid(configPath)"); string[] parts = configPath.Split(SeparatorChar); return parts; } // // Return the last part of a config path, e.g. // GetName("MACHINE/WEBROOT/Default Web Site/app") == "app" // static internal string GetName(string configPath) { Debug.Assert(String.IsNullOrEmpty(configPath) || IsValid(configPath), "String.IsNullOrEmpty(configPath) || IsValid(configPath)"); if (String.IsNullOrEmpty(configPath)) { return configPath; } int index = configPath.LastIndexOf('/'); if (index == -1) { return configPath; } Debug.Assert(index != configPath.Length - 1); return configPath.Substring(index + 1); } #endif // Avoid unused code warning in System.Configuration by including functions in assembly-specific #defines #if CONFIGPATHUTILITY_SYSTEMWEB static internal string GetParent(string configPath) { Debug.Assert(String.IsNullOrEmpty(configPath) || IsValid(configPath), "String.IsNullOrEmpty(configPath) || IsValid(configPath)"); if (String.IsNullOrEmpty(configPath)) { return null; } string parentConfigPath; int lastSlash = configPath.LastIndexOf(SeparatorChar); if (lastSlash == -1) { parentConfigPath = null; } else { parentConfigPath = configPath.Substring(0, lastSlash); } return parentConfigPath; } #endif } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DataBoundControlHelper.cs
- XmlMapping.cs
- GenericTypeParameterConverter.cs
- ThrowOnMultipleAssignment.cs
- NegotiationTokenAuthenticatorStateCache.cs
- SecureUICommand.cs
- ProfileSection.cs
- SignatureGenerator.cs
- ValueSerializer.cs
- CallbackException.cs
- FrugalMap.cs
- FileVersion.cs
- UnsafeCollabNativeMethods.cs
- uribuilder.cs
- MruCache.cs
- TextEditorCopyPaste.cs
- AutomationEvent.cs
- ForAllOperator.cs
- UserControlCodeDomTreeGenerator.cs
- EndpointDiscoveryMetadata11.cs
- Literal.cs
- ZipArchive.cs
- WindowsServiceElement.cs
- ColorTransformHelper.cs
- AuthenticationModulesSection.cs
- TextProviderWrapper.cs
- BindingSource.cs
- LeaseManager.cs
- AutoSizeComboBox.cs
- RadioButtonDesigner.cs
- HeaderedItemsControl.cs
- LicFileLicenseProvider.cs
- RelatedEnd.cs
- GenericsInstances.cs
- TdsRecordBufferSetter.cs
- DataMemberConverter.cs
- StyleHelper.cs
- VirtualPathData.cs
- WindowsHyperlink.cs
- AlignmentYValidation.cs
- SqlTypesSchemaImporter.cs
- TextRenderer.cs
- DecoderReplacementFallback.cs
- XmlSequenceWriter.cs
- TraceHandler.cs
- FileUtil.cs
- _ShellExpression.cs
- PreservationFileWriter.cs
- DynamicRendererThreadManager.cs
- ModelItemImpl.cs
- ModelItemCollectionImpl.cs
- EventLogPermission.cs
- MenuAdapter.cs
- DbBuffer.cs
- MetafileHeader.cs
- WindowsGrip.cs
- TdsValueSetter.cs
- CharEntityEncoderFallback.cs
- ObjectDataSourceDesigner.cs
- TemplateNameScope.cs
- KeyValuePairs.cs
- DetailsViewModeEventArgs.cs
- DrawItemEvent.cs
- EarlyBoundInfo.cs
- Label.cs
- TemplatedWizardStep.cs
- LassoHelper.cs
- HMACSHA1.cs
- TimeoutStream.cs
- SystemIPv6InterfaceProperties.cs
- _NegoState.cs
- Fonts.cs
- ObjectDataSourceDisposingEventArgs.cs
- PointLightBase.cs
- ToolBarButton.cs
- RootBuilder.cs
- PassportAuthentication.cs
- ClassValidator.cs
- BrowsableAttribute.cs
- IriParsingElement.cs
- ToolBarTray.cs
- ParameterInfo.cs
- IndentTextWriter.cs
- TerminatorSinks.cs
- ColorPalette.cs
- ASCIIEncoding.cs
- StateManagedCollection.cs
- XmlReaderDelegator.cs
- SocketManager.cs
- InstancePersistenceException.cs
- PolicyStatement.cs
- Reference.cs
- XPathDescendantIterator.cs
- DesignerDataParameter.cs
- ExpressionNormalizer.cs
- WebBrowsableAttribute.cs
- ArraySubsetEnumerator.cs
- ProcessHostFactoryHelper.cs
- ToolStripRenderEventArgs.cs
- PointIndependentAnimationStorage.cs