Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / CompMod / System / Configuration / AppSettingsReader.cs / 1305376 / 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
- UDPClient.cs
- Converter.cs
- SmtpMail.cs
- SynthesizerStateChangedEventArgs.cs
- AttributeEmitter.cs
- ContainerParagraph.cs
- Section.cs
- RTLAwareMessageBox.cs
- RadioButtonList.cs
- DictionarySectionHandler.cs
- safemediahandle.cs
- ListQueryResults.cs
- BindingExpression.cs
- __Filters.cs
- CancellationToken.cs
- SingleKeyFrameCollection.cs
- RelationshipWrapper.cs
- NamespaceMapping.cs
- HebrewNumber.cs
- CustomUserNameSecurityTokenAuthenticator.cs
- X509ChainElement.cs
- ExcCanonicalXml.cs
- _Connection.cs
- CodeSnippetTypeMember.cs
- ConditionalAttribute.cs
- GatewayIPAddressInformationCollection.cs
- ActionFrame.cs
- CharAnimationBase.cs
- ObjectStateManager.cs
- CollectionChangedEventManager.cs
- DelayedRegex.cs
- Overlapped.cs
- Point3DCollection.cs
- ConsumerConnectionPointCollection.cs
- SimpleApplicationHost.cs
- InkPresenter.cs
- HttpCacheParams.cs
- datacache.cs
- Configuration.cs
- TypeHelpers.cs
- CommandTreeTypeHelper.cs
- ListBoxItemWrapperAutomationPeer.cs
- BadImageFormatException.cs
- HttpCacheParams.cs
- unsafenativemethodsother.cs
- CounterSetInstanceCounterDataSet.cs
- RegexCapture.cs
- RequestSecurityToken.cs
- SqlMethodAttribute.cs
- CheckBoxList.cs
- FormViewPagerRow.cs
- GuidTagList.cs
- TextSpanModifier.cs
- ColumnMap.cs
- ArglessEventHandlerProxy.cs
- RequestResizeEvent.cs
- SettingsSection.cs
- Container.cs
- AdRotator.cs
- FilteredSchemaElementLookUpTable.cs
- SqlUdtInfo.cs
- MultiBindingExpression.cs
- DirtyTextRange.cs
- SQLChars.cs
- SoapElementAttribute.cs
- TableNameAttribute.cs
- SmiContextFactory.cs
- HtmlHead.cs
- Win32SafeHandles.cs
- BrowserTree.cs
- ReferenceEqualityComparer.cs
- SynchronizingStream.cs
- DecimalAverageAggregationOperator.cs
- BitmapFrame.cs
- ScrollItemProviderWrapper.cs
- WebPartHeaderCloseVerb.cs
- errorpatternmatcher.cs
- CodeGroup.cs
- RTLAwareMessageBox.cs
- ResourceKey.cs
- PreservationFileReader.cs
- XmlEncodedRawTextWriter.cs
- cryptoapiTransform.cs
- RelationshipNavigation.cs
- WorkerRequest.cs
- SiteMembershipCondition.cs
- Rotation3D.cs
- MonitoringDescriptionAttribute.cs
- WebPartCloseVerb.cs
- SchemaDeclBase.cs
- ToolStripLabel.cs
- LeaseManager.cs
- InternalConfirm.cs
- COM2ExtendedUITypeEditor.cs
- QilParameter.cs
- StatusInfoItem.cs
- WebScriptServiceHost.cs
- StatusBarPanel.cs
- DataRowCollection.cs
- RegexEditorDialog.cs