Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / wpf / src / Core / CSharp / MS / Internal / TextFormatting / CultureMapper.cs / 1 / CultureMapper.cs
//------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// Description: The CultureMapper class implements static methods for mapping
// CultureInfo objects from WPF clients to CultureInfo objects
// that can be used internally by text formatting code.
//
// History:
// 1-30-2006 : niklasb - Created
//
//-----------------------------------------------------------------------
using System;
using System.Globalization;
using System.Diagnostics;
using MS.Internal.PresentationCore;
namespace MS.Internal.TextFormatting
{
///
/// Implements static methods for mapping CultureInfo objects.
///
internal static class CultureMapper
{
///
/// Returns a specific culture given an arbitrary CultureInfo, which may be null, the invariant
/// culture, or a neutral culture.
///
public static CultureInfo GetSpecificCulture(CultureInfo runCulture)
{
// Assume default culture unless we can do better.
CultureInfo specificCulture = DefaultTextCulture;
if (runCulture != null)
{
// Assign _cachedCultureMap to a local variable for thread safety. The reference assignment
// is atomic and the CachedCultureMap class is immutable.
CachedCultureMap cachedCultureMap = _cachedCultureMap;
if (cachedCultureMap != null && object.ReferenceEquals(cachedCultureMap.OriginalCulture, runCulture))
return cachedCultureMap.SpecificCulture;
// Unfortunately we cannot use reference comparison here because, for example, new CultureInfo("")
// creates an invariant culture which (being a new object) is obviously not the same instance as
// CultureInfo.InvariantCulture.
if (runCulture != CultureInfo.InvariantCulture)
{
if (!runCulture.IsNeutralCulture)
{
// It's already a specific culture (neither neutral nor InvariantCulture)
specificCulture = runCulture;
}
else
{
// Get the culture name. Note that the string expected by CreateSpecificCulture corresponds
// to the Name property, not IetfLanguageTag, so that's what we use.
string cultureName = runCulture.Name;
if (!string.IsNullOrEmpty(cultureName))
{
try
{
CultureInfo culture = CultureInfo.CreateSpecificCulture(cultureName);
specificCulture = SafeSecurityHelper.GetCultureInfoByIetfLanguageTag(culture.IetfLanguageTag);
}
catch (ArgumentException)
{
// This exception occurs if the culture name is invalid or has no corresponding specific
// culture. we can safely ignore the exception and fall back to DefaultTextCulture.
specificCulture = DefaultTextCulture;
}
}
}
}
// Save the mapping so the next call will be fast if we're given the same runCulture.
// Again, the reference assignment is atomic so this is thread safe.
_cachedCultureMap = new CachedCultureMap(runCulture, specificCulture);
}
return specificCulture;
}
private class CachedCultureMap
{
public CachedCultureMap(CultureInfo originalCulture, CultureInfo specificCulture)
{
_originalCulture = originalCulture;
_specificCulture = specificCulture;
}
///
/// Original CultureInfo object from text formatting client; could be the invariant culture,
/// a neutral culture, or a specific culture.
///
public CultureInfo OriginalCulture
{
get { return _originalCulture; }
}
///
/// CultureInfo object to use for text formatting. This is guaranteed to be a specific (i.e.,
/// neither neutral nor invariant) culture. It may be the same object as OriginalCulture if
/// the latter is already a specific culture.
///
public CultureInfo SpecificCulture
{
get { return _specificCulture; }
}
private CultureInfo _originalCulture;
private CultureInfo _specificCulture;
}
private static readonly CultureInfo DefaultTextCulture = CultureInfo.GetCultureInfoByIetfLanguageTag("en-US");
private static CachedCultureMap _cachedCultureMap = null;
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// Description: The CultureMapper class implements static methods for mapping
// CultureInfo objects from WPF clients to CultureInfo objects
// that can be used internally by text formatting code.
//
// History:
// 1-30-2006 : niklasb - Created
//
//-----------------------------------------------------------------------
using System;
using System.Globalization;
using System.Diagnostics;
using MS.Internal.PresentationCore;
namespace MS.Internal.TextFormatting
{
///
/// Implements static methods for mapping CultureInfo objects.
///
internal static class CultureMapper
{
///
/// Returns a specific culture given an arbitrary CultureInfo, which may be null, the invariant
/// culture, or a neutral culture.
///
public static CultureInfo GetSpecificCulture(CultureInfo runCulture)
{
// Assume default culture unless we can do better.
CultureInfo specificCulture = DefaultTextCulture;
if (runCulture != null)
{
// Assign _cachedCultureMap to a local variable for thread safety. The reference assignment
// is atomic and the CachedCultureMap class is immutable.
CachedCultureMap cachedCultureMap = _cachedCultureMap;
if (cachedCultureMap != null && object.ReferenceEquals(cachedCultureMap.OriginalCulture, runCulture))
return cachedCultureMap.SpecificCulture;
// Unfortunately we cannot use reference comparison here because, for example, new CultureInfo("")
// creates an invariant culture which (being a new object) is obviously not the same instance as
// CultureInfo.InvariantCulture.
if (runCulture != CultureInfo.InvariantCulture)
{
if (!runCulture.IsNeutralCulture)
{
// It's already a specific culture (neither neutral nor InvariantCulture)
specificCulture = runCulture;
}
else
{
// Get the culture name. Note that the string expected by CreateSpecificCulture corresponds
// to the Name property, not IetfLanguageTag, so that's what we use.
string cultureName = runCulture.Name;
if (!string.IsNullOrEmpty(cultureName))
{
try
{
CultureInfo culture = CultureInfo.CreateSpecificCulture(cultureName);
specificCulture = SafeSecurityHelper.GetCultureInfoByIetfLanguageTag(culture.IetfLanguageTag);
}
catch (ArgumentException)
{
// This exception occurs if the culture name is invalid or has no corresponding specific
// culture. we can safely ignore the exception and fall back to DefaultTextCulture.
specificCulture = DefaultTextCulture;
}
}
}
}
// Save the mapping so the next call will be fast if we're given the same runCulture.
// Again, the reference assignment is atomic so this is thread safe.
_cachedCultureMap = new CachedCultureMap(runCulture, specificCulture);
}
return specificCulture;
}
private class CachedCultureMap
{
public CachedCultureMap(CultureInfo originalCulture, CultureInfo specificCulture)
{
_originalCulture = originalCulture;
_specificCulture = specificCulture;
}
///
/// Original CultureInfo object from text formatting client; could be the invariant culture,
/// a neutral culture, or a specific culture.
///
public CultureInfo OriginalCulture
{
get { return _originalCulture; }
}
///
/// CultureInfo object to use for text formatting. This is guaranteed to be a specific (i.e.,
/// neither neutral nor invariant) culture. It may be the same object as OriginalCulture if
/// the latter is already a specific culture.
///
public CultureInfo SpecificCulture
{
get { return _specificCulture; }
}
private CultureInfo _originalCulture;
private CultureInfo _specificCulture;
}
private static readonly CultureInfo DefaultTextCulture = CultureInfo.GetCultureInfoByIetfLanguageTag("en-US");
private static CachedCultureMap _cachedCultureMap = null;
}
}
// 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
- _BasicClient.cs
- CompareValidator.cs
- TreeIterator.cs
- VisualTreeFlattener.cs
- Identity.cs
- ClipboardProcessor.cs
- StringValidator.cs
- XmlSchemaComplexContentExtension.cs
- ComEventsInfo.cs
- TableParaClient.cs
- BrowserCapabilitiesFactory.cs
- RoleService.cs
- ThreadPool.cs
- HtmlCommandAdapter.cs
- BStrWrapper.cs
- DataSetMappper.cs
- _Connection.cs
- RawAppCommandInputReport.cs
- SQLStringStorage.cs
- Substitution.cs
- SQLDecimal.cs
- TypeDefinition.cs
- HtmlPhoneCallAdapter.cs
- DynamicField.cs
- GridViewRowEventArgs.cs
- OracleRowUpdatedEventArgs.cs
- StructuralObject.cs
- UInt32.cs
- EntityTypeBase.cs
- ErrorStyle.cs
- Tokenizer.cs
- ComboBox.cs
- _OSSOCK.cs
- ComplexLine.cs
- StyleHelper.cs
- StreamGeometryContext.cs
- SpeechUI.cs
- BuildResultCache.cs
- HttpModuleCollection.cs
- XmlSchemaException.cs
- EventProviderWriter.cs
- ImplicitInputBrush.cs
- AmbientLight.cs
- SqlEnums.cs
- MemberDescriptor.cs
- SqlConnectionManager.cs
- TextBlock.cs
- Renderer.cs
- ScrollItemPattern.cs
- VisualStateGroup.cs
- UrlAuthFailedErrorFormatter.cs
- BoundField.cs
- PrtTicket_Editor.cs
- XomlCompilerParameters.cs
- DynamicResourceExtension.cs
- SrgsElement.cs
- JsonDeserializer.cs
- SingleResultAttribute.cs
- ComplusEndpointConfigContainer.cs
- AutoResetEvent.cs
- DBParameter.cs
- Models.cs
- SchemaReference.cs
- odbcmetadatacolumnnames.cs
- ReaderWriterLock.cs
- ValueOfAction.cs
- DateTimeSerializationSection.cs
- ConfigPathUtility.cs
- TextTrailingWordEllipsis.cs
- DBCommandBuilder.cs
- DataTableCollection.cs
- MenuAdapter.cs
- ProxyWebPart.cs
- UpdateCommand.cs
- PerCallInstanceContextProvider.cs
- AttributeQuery.cs
- IImplicitResourceProvider.cs
- ZipFileInfo.cs
- ParallelLoopState.cs
- DiscardableAttribute.cs
- VectorConverter.cs
- JsonObjectDataContract.cs
- ListViewPagedDataSource.cs
- ToolStripItemTextRenderEventArgs.cs
- OutputCacheEntry.cs
- SizeFConverter.cs
- ArrayWithOffset.cs
- Matrix3D.cs
- DigestComparer.cs
- RegexParser.cs
- RepeatInfo.cs
- TraceSection.cs
- ThrowHelper.cs
- MimeBasePart.cs
- ToolStripDropDownButton.cs
- BypassElement.cs
- MemoryStream.cs
- BinaryObjectWriter.cs
- PartBasedPackageProperties.cs
- DriveInfo.cs