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
- MimeObjectFactory.cs
- SortExpressionBuilder.cs
- TextModifierScope.cs
- HttpCachePolicyElement.cs
- MDIWindowDialog.cs
- Wildcard.cs
- SoapSchemaImporter.cs
- CompilerErrorCollection.cs
- PropertyEntry.cs
- IndexExpression.cs
- MenuItemBindingCollection.cs
- TagPrefixCollection.cs
- InstanceView.cs
- EasingQuaternionKeyFrame.cs
- DrawListViewColumnHeaderEventArgs.cs
- ServiceOperationParameter.cs
- WebPartTransformer.cs
- ClientUrlResolverWrapper.cs
- ValidationSettings.cs
- MdiWindowListStrip.cs
- TreeViewBindingsEditorForm.cs
- BitmapData.cs
- MouseCaptureWithinProperty.cs
- BindingMemberInfo.cs
- DefaultCommandConverter.cs
- StoreUtilities.cs
- WebPartConnectionsDisconnectVerb.cs
- JoinQueryOperator.cs
- SqlAliaser.cs
- EventTrigger.cs
- PrinterSettings.cs
- FormsAuthentication.cs
- ActivationArguments.cs
- TrackingValidationObjectDictionary.cs
- SspiSafeHandles.cs
- ValidationError.cs
- MenuAdapter.cs
- Font.cs
- XmlQueryRuntime.cs
- WebServiceHost.cs
- DeclarationUpdate.cs
- HashRepartitionStream.cs
- SignatureHelper.cs
- CaretElement.cs
- SoapSchemaExporter.cs
- ScriptControlManager.cs
- VarInfo.cs
- PrintingPermission.cs
- SafeRightsManagementQueryHandle.cs
- ZipFileInfo.cs
- ScriptControlManager.cs
- XmlQualifiedNameTest.cs
- RestHandler.cs
- TypedTableBaseExtensions.cs
- AsyncStreamReader.cs
- _NtlmClient.cs
- AnonymousIdentificationModule.cs
- MissingMemberException.cs
- MergeFilterQuery.cs
- _ChunkParse.cs
- CommunicationException.cs
- MinMaxParagraphWidth.cs
- WeakReferenceEnumerator.cs
- Int32CollectionConverter.cs
- ListDictionaryInternal.cs
- SQLMembershipProvider.cs
- QueryInterceptorAttribute.cs
- ViewStateException.cs
- EnumConverter.cs
- ConfigurationFileMap.cs
- MenuBindingsEditor.cs
- ValidationSummary.cs
- WebPartDisplayModeCollection.cs
- KerberosTokenFactoryCredential.cs
- DocumentViewerBase.cs
- ListControl.cs
- NullableBoolConverter.cs
- TextComposition.cs
- BitSet.cs
- EntryIndex.cs
- CodeEventReferenceExpression.cs
- NotImplementedException.cs
- SimpleHandlerFactory.cs
- StringArrayConverter.cs
- WebBrowserHelper.cs
- RootDesignerSerializerAttribute.cs
- ScrollItemProviderWrapper.cs
- PhysicalOps.cs
- ReadOnlyDataSourceView.cs
- XamlStyleSerializer.cs
- ExceptQueryOperator.cs
- SemanticAnalyzer.cs
- ReferencedAssembly.cs
- InternalsVisibleToAttribute.cs
- FlowDocumentScrollViewerAutomationPeer.cs
- InstancePersistenceContext.cs
- MultipleViewProviderWrapper.cs
- ServiceDefaults.cs
- SchemaElementLookUpTable.cs
- XmlCharCheckingReader.cs