Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / CompMod / System / Configuration / AppSettingsReader.cs / 1 / AppSettingsReader.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.Reflection; using System.Configuration; using System.Collections.Specialized; using System.Globalization; namespace System.Configuration { ////// The AppSettingsReader class provides a wrapper for System.Configuration.ConfigurationManager.AppSettings /// which provides a single method for reading values from the config file of a particular type. /// public class AppSettingsReader { private NameValueCollection map; static Type stringType = typeof(string); static Type[] paramsArray = new Type[] { stringType }; static string NullString = "None"; ////// Constructor /// public AppSettingsReader() { map = System.Configuration.ConfigurationManager.AppSettings; } ////// Gets the value for specified key from ConfigurationManager.AppSettings, and returns /// an object of the specified type containing the value from the config file. If the key /// isn't in the config file, or if it is not a valid value for the given type, it will /// throw an exception with a descriptive message so the user can make the appropriate /// change /// public object GetValue(string key, Type type) { if (key == null) throw new ArgumentNullException("key"); if (type == null) throw new ArgumentNullException("type"); string val = map[key]; if (val == null) throw new InvalidOperationException(SR.GetString(SR.AppSettingsReaderNoKey, key)); if (type == stringType) { // It's a string, so we can ALMOST just return the value. The only // tricky point is that if it's the string "(None)", then we want to // return null. And of course we need a way to represent the string // (None), so we use ((None)), and so on... so it's a little complicated. int NoneNesting = GetNoneNesting(val); if (NoneNesting == 0) { // val is not of the form ((..((None))..)) return val; } else if (NoneNesting == 1) { // val is (None) return null; } else { // val is of the form ((..((None))..)) return val.Substring(1, val.Length - 2); } } else { try { return Convert.ChangeType(val, type, CultureInfo.InvariantCulture); } catch (Exception) { string displayString = (val.Length == 0) ? SR.AppSettingsReaderEmptyString : val; throw new InvalidOperationException(SR.GetString(SR.AppSettingsReaderCantParse, displayString, key, type.ToString())); } } } private int GetNoneNesting(string val) { int count = 0; int len = val.Length; if (len > 1) { while (val[count] == '(' && val[len - count - 1] == ')') { count++; } if (count > 0 && string.Compare(NullString, 0, val, count, len - 2 * count, StringComparison.Ordinal) != 0) { // the stuff between the parens is not "None" count = 0; } } return count; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.Reflection; using System.Configuration; using System.Collections.Specialized; using System.Globalization; namespace System.Configuration { ////// The AppSettingsReader class provides a wrapper for System.Configuration.ConfigurationManager.AppSettings /// which provides a single method for reading values from the config file of a particular type. /// public class AppSettingsReader { private NameValueCollection map; static Type stringType = typeof(string); static Type[] paramsArray = new Type[] { stringType }; static string NullString = "None"; ////// Constructor /// public AppSettingsReader() { map = System.Configuration.ConfigurationManager.AppSettings; } ////// Gets the value for specified key from ConfigurationManager.AppSettings, and returns /// an object of the specified type containing the value from the config file. If the key /// isn't in the config file, or if it is not a valid value for the given type, it will /// throw an exception with a descriptive message so the user can make the appropriate /// change /// public object GetValue(string key, Type type) { if (key == null) throw new ArgumentNullException("key"); if (type == null) throw new ArgumentNullException("type"); string val = map[key]; if (val == null) throw new InvalidOperationException(SR.GetString(SR.AppSettingsReaderNoKey, key)); if (type == stringType) { // It's a string, so we can ALMOST just return the value. The only // tricky point is that if it's the string "(None)", then we want to // return null. And of course we need a way to represent the string // (None), so we use ((None)), and so on... so it's a little complicated. int NoneNesting = GetNoneNesting(val); if (NoneNesting == 0) { // val is not of the form ((..((None))..)) return val; } else if (NoneNesting == 1) { // val is (None) return null; } else { // val is of the form ((..((None))..)) return val.Substring(1, val.Length - 2); } } else { try { return Convert.ChangeType(val, type, CultureInfo.InvariantCulture); } catch (Exception) { string displayString = (val.Length == 0) ? SR.AppSettingsReaderEmptyString : val; throw new InvalidOperationException(SR.GetString(SR.AppSettingsReaderCantParse, displayString, key, type.ToString())); } } } private int GetNoneNesting(string val) { int count = 0; int len = val.Length; if (len > 1) { while (val[count] == '(' && val[len - count - 1] == ')') { count++; } if (count > 0 && string.Compare(NullString, 0, val, count, len - 2 * count, StringComparison.Ordinal) != 0) { // the stuff between the parens is not "None" count = 0; } } return count; } } } // 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
- XmlSchemaSimpleTypeList.cs
- DbConnectionPoolGroupProviderInfo.cs
- Site.cs
- BrowserDefinition.cs
- Parameter.cs
- XmlNode.cs
- DataGridViewButtonCell.cs
- CmsUtils.cs
- RangeValueProviderWrapper.cs
- UnhandledExceptionEventArgs.cs
- XmlAnyAttributeAttribute.cs
- ModelItemImpl.cs
- WebPartEditVerb.cs
- EditorZone.cs
- AnnotationResource.cs
- GraphicsPath.cs
- CapabilitiesState.cs
- ZipIOBlockManager.cs
- ListViewSortEventArgs.cs
- FlatButtonAppearance.cs
- PerformanceCounter.cs
- Accessible.cs
- PageTheme.cs
- QfeChecker.cs
- SupportsEventValidationAttribute.cs
- ProviderCommandInfoUtils.cs
- KeyValuePairs.cs
- COAUTHINFO.cs
- BitmapCodecInfo.cs
- EnumBuilder.cs
- SpeechRecognizer.cs
- VersionPair.cs
- selecteditemcollection.cs
- AudioDeviceOut.cs
- ListDictionary.cs
- ActiveXContainer.cs
- WebPartConnectionsConfigureVerb.cs
- AnimatedTypeHelpers.cs
- SemaphoreFullException.cs
- SerialPort.cs
- EventlogProvider.cs
- Storyboard.cs
- CrossContextChannel.cs
- CommandDesigner.cs
- ServerValidateEventArgs.cs
- SystemEvents.cs
- Pool.cs
- ToolStripContentPanelRenderEventArgs.cs
- ImageMapEventArgs.cs
- SrgsOneOf.cs
- FontWeightConverter.cs
- ItemChangedEventArgs.cs
- XsltContext.cs
- TextRangeAdaptor.cs
- DataControlFieldCollection.cs
- Buffer.cs
- Empty.cs
- WebPartConnectionCollection.cs
- StringArrayConverter.cs
- TagMapInfo.cs
- ProtocolViolationException.cs
- ListBoxAutomationPeer.cs
- UnknownWrapper.cs
- ConnectionConsumerAttribute.cs
- CompiledXpathExpr.cs
- ConstraintStruct.cs
- SizeChangedInfo.cs
- OracleColumn.cs
- TypeBuilder.cs
- AdjustableArrowCap.cs
- InvokePatternIdentifiers.cs
- ContextInformation.cs
- ExtensionWindowResizeGrip.cs
- SharedUtils.cs
- SubpageParagraph.cs
- CompModSwitches.cs
- TypeUsage.cs
- WebEvents.cs
- BrushConverter.cs
- AmbientProperties.cs
- InvalidWMPVersionException.cs
- BitmapEffect.cs
- Control.cs
- FixedFindEngine.cs
- TimeSpanStorage.cs
- ServiceModelStringsVersion1.cs
- ClientRuntimeConfig.cs
- PeerNameRecord.cs
- SelfIssuedAuthProofToken.cs
- StreamSecurityUpgradeAcceptorBase.cs
- precedingquery.cs
- AttributeData.cs
- StringOutput.cs
- XmlNamespaceManager.cs
- Function.cs
- SerialPort.cs
- DayRenderEvent.cs
- ISCIIEncoding.cs
- NotifyIcon.cs
- ZipIOExtraFieldPaddingElement.cs