Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Core / Microsoft / Scripting / Actions / RuleCache.cs / 1305376 / RuleCache.cs
/* **************************************************************************** * * Copyright (c) Microsoft Corporation. * * This source code is subject to terms and conditions of the Microsoft Public License. A * copy of the license can be found in the License.html file at the root of this distribution. If * you cannot locate the Microsoft Public License, please send an email to * dlr@microsoft.com. By using this source code in any fashion, you are agreeing to be bound * by the terms of the Microsoft Public License. * * You must not remove this notice, or any other, from this software. * * * ***************************************************************************/ using System.ComponentModel; using System.Diagnostics; using System.Dynamic.Utils; namespace System.Runtime.CompilerServices { ////// This API supports the .NET Framework infrastructure and is not intended to be used directly from your code. /// Represents a cache of runtime binding rules. /// ///The delegate type. [EditorBrowsable(EditorBrowsableState.Never), DebuggerStepThrough] public class RuleCachewhere T : class { private T[] _rules = new T[0]; private readonly Object cacheLock = new Object(); private const int MaxRules = 128; internal RuleCache() { } internal T[] GetRules() { return _rules; } // move the rule +2 up. // this is called on every successful rule. internal void MoveRule(T rule, int i) { // limit search to MaxSearch elements. // Rule should not get too far unless it has been already moved up. // need a lock to make sure we are moving the right rule and not loosing any. lock (cacheLock) { const int MaxSearch = 8; int count = _rules.Length - i; if (count > MaxSearch) { count = MaxSearch; } int oldIndex = -1; int max = Math.Min(_rules.Length, i + count); for (int index = i; index < max; index++) { if (_rules[index] == rule) { oldIndex = index; break; } } if (oldIndex < 0) { return; } T oldRule = _rules[oldIndex]; _rules[oldIndex] = _rules[oldIndex - 1]; _rules[oldIndex - 1] = _rules[oldIndex - 2]; _rules[oldIndex - 2] = oldRule; } } internal void AddRule(T newRule) { // need a lock to make sure we are not loosing rules. lock (cacheLock) { _rules = AddOrInsert(_rules, newRule); } } internal void ReplaceRule(T oldRule, T newRule) { // need a lock to make sure we are replacing the right rule lock (cacheLock) { int i = Array.IndexOf(_rules, oldRule); if (i >= 0) { _rules[i] = newRule; return; // DONE } // could not find it. _rules = AddOrInsert(_rules, newRule); } } // Adds to end or or inserts items at InsertPosition private const int InsertPosition = MaxRules / 2; private static T[] AddOrInsert(T[] rules, T item) { if (rules.Length < InsertPosition) { return rules.AddLast(item); } T[] newRules; int newLength = rules.Length + 1; if (newLength > MaxRules) { newLength = MaxRules; newRules = rules; } else { newRules = new T[newLength]; } Array.Copy(rules, 0, newRules, 0, InsertPosition); newRules[InsertPosition] = item; Array.Copy(rules, InsertPosition, newRules, InsertPosition + 1, newLength - InsertPosition - 1); return newRules; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. /* **************************************************************************** * * Copyright (c) Microsoft Corporation. * * This source code is subject to terms and conditions of the Microsoft Public License. A * copy of the license can be found in the License.html file at the root of this distribution. If * you cannot locate the Microsoft Public License, please send an email to * dlr@microsoft.com. By using this source code in any fashion, you are agreeing to be bound * by the terms of the Microsoft Public License. * * You must not remove this notice, or any other, from this software. * * * ***************************************************************************/ using System.ComponentModel; using System.Diagnostics; using System.Dynamic.Utils; namespace System.Runtime.CompilerServices { /// /// This API supports the .NET Framework infrastructure and is not intended to be used directly from your code. /// Represents a cache of runtime binding rules. /// ///The delegate type. [EditorBrowsable(EditorBrowsableState.Never), DebuggerStepThrough] public class RuleCachewhere T : class { private T[] _rules = new T[0]; private readonly Object cacheLock = new Object(); private const int MaxRules = 128; internal RuleCache() { } internal T[] GetRules() { return _rules; } // move the rule +2 up. // this is called on every successful rule. internal void MoveRule(T rule, int i) { // limit search to MaxSearch elements. // Rule should not get too far unless it has been already moved up. // need a lock to make sure we are moving the right rule and not loosing any. lock (cacheLock) { const int MaxSearch = 8; int count = _rules.Length - i; if (count > MaxSearch) { count = MaxSearch; } int oldIndex = -1; int max = Math.Min(_rules.Length, i + count); for (int index = i; index < max; index++) { if (_rules[index] == rule) { oldIndex = index; break; } } if (oldIndex < 0) { return; } T oldRule = _rules[oldIndex]; _rules[oldIndex] = _rules[oldIndex - 1]; _rules[oldIndex - 1] = _rules[oldIndex - 2]; _rules[oldIndex - 2] = oldRule; } } internal void AddRule(T newRule) { // need a lock to make sure we are not loosing rules. lock (cacheLock) { _rules = AddOrInsert(_rules, newRule); } } internal void ReplaceRule(T oldRule, T newRule) { // need a lock to make sure we are replacing the right rule lock (cacheLock) { int i = Array.IndexOf(_rules, oldRule); if (i >= 0) { _rules[i] = newRule; return; // DONE } // could not find it. _rules = AddOrInsert(_rules, newRule); } } // Adds to end or or inserts items at InsertPosition private const int InsertPosition = MaxRules / 2; private static T[] AddOrInsert(T[] rules, T item) { if (rules.Length < InsertPosition) { return rules.AddLast(item); } T[] newRules; int newLength = rules.Length + 1; if (newLength > MaxRules) { newLength = MaxRules; newRules = rules; } else { newRules = new T[newLength]; } Array.Copy(rules, 0, newRules, 0, InsertPosition); newRules[InsertPosition] = item; Array.Copy(rules, InsertPosition, newRules, InsertPosition + 1, newLength - InsertPosition - 1); return newRules; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DynamicHyperLink.cs
- ComboBox.cs
- Label.cs
- GifBitmapEncoder.cs
- InternalResources.cs
- EnumerableRowCollection.cs
- WebPartConnectionsCancelVerb.cs
- ObjectViewEntityCollectionData.cs
- ISAPIRuntime.cs
- _NegoState.cs
- SQLInt16.cs
- IEnumerable.cs
- IdentityHolder.cs
- typedescriptorpermission.cs
- WebServiceFault.cs
- ShapingWorkspace.cs
- Int32Converter.cs
- Relationship.cs
- UnsafeNativeMethods.cs
- InvalidEnumArgumentException.cs
- BrowserDefinitionCollection.cs
- ScrollData.cs
- StatusBarItemAutomationPeer.cs
- DataStorage.cs
- CroppedBitmap.cs
- ReliableSessionBindingElement.cs
- HtmlMobileTextWriter.cs
- ClassHandlersStore.cs
- TextTreeTextElementNode.cs
- TabRenderer.cs
- JoinCqlBlock.cs
- TypeElement.cs
- ProfilePropertyNameValidator.cs
- StructureChangedEventArgs.cs
- Msec.cs
- PointLight.cs
- PropertyDescriptorCollection.cs
- ObjectSet.cs
- TextTreeInsertUndoUnit.cs
- Operator.cs
- XmlWriterSettings.cs
- CallbackValidatorAttribute.cs
- WindowsTokenRoleProvider.cs
- QuaternionRotation3D.cs
- MatrixTransform3D.cs
- PropertyGridCommands.cs
- FieldBuilder.cs
- TileBrush.cs
- MDIControlStrip.cs
- PolyLineSegment.cs
- MachineKey.cs
- DataColumnMapping.cs
- _LocalDataStoreMgr.cs
- HotCommands.cs
- SmtpNtlmAuthenticationModule.cs
- XmlQueryStaticData.cs
- HttpProfileGroupBase.cs
- SelectionPattern.cs
- SqlClientFactory.cs
- DATA_BLOB.cs
- DbProviderSpecificTypePropertyAttribute.cs
- XmlSchemaProviderAttribute.cs
- LambdaCompiler.Lambda.cs
- PointAnimationClockResource.cs
- Style.cs
- ListMarkerLine.cs
- TextEffect.cs
- StringAttributeCollection.cs
- XmlDataSource.cs
- DataMisalignedException.cs
- JavaScriptSerializer.cs
- KeyMatchBuilder.cs
- ClientBuildManagerCallback.cs
- baseaxisquery.cs
- HtmlControl.cs
- GeometryValueSerializer.cs
- TransactionBridge.cs
- StrongNameKeyPair.cs
- CodeExpressionRuleDeclaration.cs
- CompositeCollectionView.cs
- DelimitedListTraceListener.cs
- ProvideValueServiceProvider.cs
- RegexCompilationInfo.cs
- StrokeNode.cs
- GeneratedContractType.cs
- BigInt.cs
- EdmItemCollection.cs
- ToolStripKeyboardHandlingService.cs
- PropertyBuilder.cs
- DynamicField.cs
- BooleanToVisibilityConverter.cs
- Metafile.cs
- DecimalConverter.cs
- ListControlConvertEventArgs.cs
- FullTrustAssembly.cs
- ByteStream.cs
- SqlDataSourceSelectingEventArgs.cs
- BamlLocalizer.cs
- InstallerTypeAttribute.cs
- DynamicILGenerator.cs