Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / CompMod / System / Collections / Specialized / FixedStringLookup.cs / 1 / FixedStringLookup.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
namespace System.Collections.Specialized {
using System;
using System.Collections;
using System.Diagnostics;
using System.Globalization;
// This class provides a very efficient way to lookup an entry in a list of strings,
// providing that they are declared in a particular way.
// It requires the set of strings to be orderded into an array of arrays of strings.
// The first indexer must the length of the string, so that each sub-array is of the
// same length. The contained array must be in alphabetical order. Furthermore, if the
// table is to be searched case-insensitively, the strings must all be lower case.
internal static class FixedStringLookup {
// Returns whether the match is found in the lookup table
internal static bool Contains(string[][] lookupTable, string value, bool ignoreCase) {
int length = value.Length;
if (length <= 0 || length - 1 >= lookupTable.Length) {
return false;
}
string[] subArray = lookupTable[length - 1];
if (subArray == null) {
return false;
}
return Contains(subArray, value, ignoreCase);
}
#if DEBUG
internal static void VerifyLookupTable(string[][] lookupTable, bool ignoreCase) {
for (int i = 0; i < lookupTable.Length; i++) {
string[] subArray = lookupTable[i];
if (subArray != null) {
string lastValue = null;
for (int j = 0; j < subArray.Length; j++) {
string value = subArray[j];
// Must all be the length of the hashed position
Debug.Assert(value.Length == i + 1, "Lookup table contains an item in the wrong subtable. Item name: " + value);
if (lastValue != null) {
// Must be sorted within the sub array;
Debug.Assert(string.Compare(lastValue, value, ((ignoreCase) ? StringComparison.OrdinalIgnoreCase : StringComparison.Ordinal)) < 0,
String.Format(CultureInfo.InvariantCulture, "Lookup table is out of order. Items {0} and {1} are reversed", lastValue, value));
}
lastValue = value;
}
}
}
}
#endif
// This routine finds a hit within a single sorted array, with the assumption that the
// value and all the strings are of the same length.
private static bool Contains(string[] array, string value, bool ignoreCase) {
int min = 0;
int max = array.Length;
int pos = 0;
char searchChar;
while (pos < value.Length) {
if (ignoreCase) {
searchChar = char.ToLower(value[pos], CultureInfo.InvariantCulture);
} else {
searchChar = value[pos];
}
if ((max - min) <= 1) {
// we are down to a single item, so we can stay on this row until the end.
if (searchChar != array[min][pos]) {
return false;
}
pos++;
continue;
}
// There are multiple items to search, use binary search to find one of the hits
if (!FindCharacter(array, searchChar, pos, ref min, ref max)) {
return false;
}
// and move to next char
pos++;
}
return true;
}
// Do a binary search on the character array at the specific position and constrict the ranges appropriately.
private static bool FindCharacter(string[] array, char value, int pos, ref int min, ref int max) {
int index = min;
while (min < max) {
index = (min + max) / 2;
char comp = array[index][pos];
if (value == comp) {
// We have a match. Now adjust to any adjacent matches
int newMin = index;
while (newMin > min && array[newMin - 1][pos] == value) {
newMin--;
}
min = newMin;
int newMax = index + 1;
while (newMax < max && array[newMax][pos] == value) {
newMax++;
}
max = newMax;
return true;
}
if (value < comp) {
max = index;
}
else {
min = index + 1;
}
}
return false;
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
namespace System.Collections.Specialized {
using System;
using System.Collections;
using System.Diagnostics;
using System.Globalization;
// This class provides a very efficient way to lookup an entry in a list of strings,
// providing that they are declared in a particular way.
// It requires the set of strings to be orderded into an array of arrays of strings.
// The first indexer must the length of the string, so that each sub-array is of the
// same length. The contained array must be in alphabetical order. Furthermore, if the
// table is to be searched case-insensitively, the strings must all be lower case.
internal static class FixedStringLookup {
// Returns whether the match is found in the lookup table
internal static bool Contains(string[][] lookupTable, string value, bool ignoreCase) {
int length = value.Length;
if (length <= 0 || length - 1 >= lookupTable.Length) {
return false;
}
string[] subArray = lookupTable[length - 1];
if (subArray == null) {
return false;
}
return Contains(subArray, value, ignoreCase);
}
#if DEBUG
internal static void VerifyLookupTable(string[][] lookupTable, bool ignoreCase) {
for (int i = 0; i < lookupTable.Length; i++) {
string[] subArray = lookupTable[i];
if (subArray != null) {
string lastValue = null;
for (int j = 0; j < subArray.Length; j++) {
string value = subArray[j];
// Must all be the length of the hashed position
Debug.Assert(value.Length == i + 1, "Lookup table contains an item in the wrong subtable. Item name: " + value);
if (lastValue != null) {
// Must be sorted within the sub array;
Debug.Assert(string.Compare(lastValue, value, ((ignoreCase) ? StringComparison.OrdinalIgnoreCase : StringComparison.Ordinal)) < 0,
String.Format(CultureInfo.InvariantCulture, "Lookup table is out of order. Items {0} and {1} are reversed", lastValue, value));
}
lastValue = value;
}
}
}
}
#endif
// This routine finds a hit within a single sorted array, with the assumption that the
// value and all the strings are of the same length.
private static bool Contains(string[] array, string value, bool ignoreCase) {
int min = 0;
int max = array.Length;
int pos = 0;
char searchChar;
while (pos < value.Length) {
if (ignoreCase) {
searchChar = char.ToLower(value[pos], CultureInfo.InvariantCulture);
} else {
searchChar = value[pos];
}
if ((max - min) <= 1) {
// we are down to a single item, so we can stay on this row until the end.
if (searchChar != array[min][pos]) {
return false;
}
pos++;
continue;
}
// There are multiple items to search, use binary search to find one of the hits
if (!FindCharacter(array, searchChar, pos, ref min, ref max)) {
return false;
}
// and move to next char
pos++;
}
return true;
}
// Do a binary search on the character array at the specific position and constrict the ranges appropriately.
private static bool FindCharacter(string[] array, char value, int pos, ref int min, ref int max) {
int index = min;
while (min < max) {
index = (min + max) / 2;
char comp = array[index][pos];
if (value == comp) {
// We have a match. Now adjust to any adjacent matches
int newMin = index;
while (newMin > min && array[newMin - 1][pos] == value) {
newMin--;
}
min = newMin;
int newMax = index + 1;
while (newMax < max && array[newMax][pos] == value) {
newMax++;
}
max = newMax;
return true;
}
if (value < comp) {
max = index;
}
else {
min = index + 1;
}
}
return false;
}
}
}
// 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
- CalendarTable.cs
- Variant.cs
- FontStyles.cs
- SqlClientWrapperSmiStreamChars.cs
- DispatcherFrame.cs
- UriSection.cs
- IndexedDataBuffer.cs
- DateTimeFormat.cs
- HttpSysSettings.cs
- RichTextBoxDesigner.cs
- ExtensionFile.cs
- MemoryFailPoint.cs
- FrameworkContentElement.cs
- BitmapEffectDrawing.cs
- COAUTHIDENTITY.cs
- SchemaTableColumn.cs
- MsmqInputChannel.cs
- ResXFileRef.cs
- KernelTypeValidation.cs
- DockingAttribute.cs
- WebEvents.cs
- hresults.cs
- safemediahandle.cs
- RecordBuilder.cs
- QuaternionValueSerializer.cs
- TraceFilter.cs
- FormatterServices.cs
- OutputCacheProfile.cs
- XPathDocumentIterator.cs
- SplitContainer.cs
- InputScopeConverter.cs
- ClientEventManager.cs
- HttpCookie.cs
- SqlCachedBuffer.cs
- VBCodeProvider.cs
- RunInstallerAttribute.cs
- ExpressionBuilderCollection.cs
- httpstaticobjectscollection.cs
- BamlTreeMap.cs
- DataSourceSelectArguments.cs
- PositiveTimeSpanValidator.cs
- ConfigurationElement.cs
- PropertySegmentSerializer.cs
- CompressStream.cs
- SaveFileDialogDesigner.cs
- AnnotationResourceChangedEventArgs.cs
- HandoffBehavior.cs
- UniqueTransportManagerRegistration.cs
- DBCommandBuilder.cs
- SHA512Managed.cs
- DocumentOrderQuery.cs
- DragEvent.cs
- ComponentEvent.cs
- DesignerTextBoxAdapter.cs
- CqlLexerHelpers.cs
- SQLByteStorage.cs
- InstanceStore.cs
- ListParagraph.cs
- TemplatePropertyEntry.cs
- SqlComparer.cs
- TraceUtility.cs
- NonBatchDirectoryCompiler.cs
- StringResourceManager.cs
- UpdateManifestForBrowserApplication.cs
- Content.cs
- TemplateControlParser.cs
- EntityDataReader.cs
- MonthChangedEventArgs.cs
- XmlSchemaValidator.cs
- MetabaseSettingsIis7.cs
- ZipIOFileItemStream.cs
- PropertyCondition.cs
- Serializer.cs
- CatalogPartCollection.cs
- FormatVersion.cs
- RouteItem.cs
- SystemFonts.cs
- TriggerAction.cs
- GenericTypeParameterBuilder.cs
- LineBreakRecord.cs
- DockingAttribute.cs
- SelectionWordBreaker.cs
- CustomValidator.cs
- TextDecorationCollectionConverter.cs
- XmlNavigatorFilter.cs
- DataGridCellEditEndingEventArgs.cs
- Function.cs
- DbProviderConfigurationHandler.cs
- PassportAuthenticationEventArgs.cs
- Debug.cs
- MeshGeometry3D.cs
- SelectionRangeConverter.cs
- VectorValueSerializer.cs
- InputManager.cs
- storepermissionattribute.cs
- WindowsToolbar.cs
- DataTableReader.cs
- QualificationDataAttribute.cs
- XmlDataCollection.cs
- SQLByte.cs