Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Core / CSharp / MS / Internal / Shaping / UshortList2.cs / 1305600 / UshortList2.cs
//------------------------------------------------------------------------
//
// Microsoft Avalon
// Copyright (C) Microsoft Corporation, 2002
//
// File: List2.cs
//
// Contents: Internal growable list with sublisting
//
// Created: 11-04-2002 Worachai Chaoweeraprasit (wchao)
// 16-07-2002 sergeym - major rewrite.
//
//-----------------------------------------------------------------------
using System.Windows;
using System;
using System.Collections;
using System.Diagnostics;
using MS.Internal;
using System.Security;
using System.Security.Permissions;
namespace MS.Internal.Shaping
{
///
/// Growable ushort array.
/// Only current sublist is visible for client. Sublists should be processed
/// in sequence from start to end.
///
internal class UshortList
{
internal UshortList(int capacity, int leap)
{
Invariant.Assert(capacity >= 0 && leap >= 0, "Invalid parameter");
_storage = new UshortArray(capacity, leap);
}
internal UshortList(ushort[] array)
{
Invariant.Assert(array != null, "Invalid parameter");
_storage = new UshortArray(array);
}
internal UshortList(CheckedUShortPointer unsafeArray, int arrayLength)
{
_storage = new UnsafeUshortArray(unsafeArray, arrayLength);
_length = arrayLength;
}
///
/// Critical: This code accepts pointers and manipulates
/// them without validation.Critical for set only
/// TreatAsSafe: The method does proper bound check.
///
public ushort this[int index]
{
[SecurityCritical,SecurityTreatAsSafe]
get
{
Invariant.Assert(index >= 0 && index < _length, "Index out of range");
return _storage[_index + index];
}
[SecurityCritical,SecurityTreatAsSafe]
set
{
Invariant.Assert(index >= 0 && index < _length, "Index out of range");
_storage[_index + index] = value;
}
}
///
/// Length of current sublist
///
///
/// Critical: This code accepts pointers and manipulates
/// them without validation, critical only for set
///
public int Length
{
get { return _length; }
[SecurityCritical]
set { _length = value; }
}
///
/// Offset inside whole storage
///
public int Offset
{
get { return _index; }
}
///
/// Reset processing sequence to the start of the storage
///
public void SetRange(int index, int length)
{
Invariant.Assert(length >= 0 && (index + length) <= _storage.Length, "List out of storage");
_index = index;
_length = length;
}
///
/// Insert elements to the current run. Elements are not intialized.
///
/// Position
/// Number of elements
public void Insert(int index, int count)
{
Invariant.Assert(index <= _length && index >= 0, "Index out of range");
Invariant.Assert(count > 0, "Invalid argument");
_storage.Insert(_index + index, count, _index + _length);
_length += count;
}
///
/// Remove elements from the current run.
///
/// Position
/// Number of elements
public void Remove(int index, int count)
{
Invariant.Assert(index < _length && index >= 0, "Index out of range");
Invariant.Assert(count > 0 && (index + count) <= _length, "Invalid argument");
_storage.Remove(_index + index, count, _index + _length);
_length -= count;
}
public ushort[] ToArray()
{
return _storage.ToArray();
}
public ushort[] GetCopy()
{
return _storage.GetSubsetCopy(_index,_length);
}
private UshortBuffer _storage;
private int _index;
private int _length;
}
///
/// Abstract ushort buffer
///
internal abstract class UshortBuffer
{
protected int _leap;
public abstract ushort this[int index] { get; set; }
public abstract int Length { get; }
public virtual ushort[] ToArray()
{
Debug.Assert(false, "Not supported");
return null;
}
public virtual ushort[] GetSubsetCopy(int index, int count)
{
Debug.Assert(false, "Not supported");
return null;
}
public virtual void Insert(int index, int count, int length)
{
Debug.Assert(false, "Not supported");
}
public virtual void Remove(int index, int count, int length)
{
Debug.Assert(false, "Not supported");
}
}
///
/// Ushort buffer implemented as managed ushort array
///
internal class UshortArray : UshortBuffer
{
private ushort[] _array;
internal UshortArray(ushort[] array)
{
_array = array;
}
internal UshortArray(int capacity, int leap)
{
_array = new ushort[capacity];
_leap = leap;
}
public override ushort this[int index]
{
get { return _array[index]; }
set { _array[index] = value; }
}
public override int Length
{
get { return _array.Length; }
}
public override ushort[] ToArray()
{
return _array;
}
public override ushort[] GetSubsetCopy(int index, int count)
{
ushort[] subsetArray = new ushort[count];
//Move elements
Buffer.BlockCopy(
_array,
index * sizeof(ushort),
subsetArray,
0,
((index + count) <= _array.Length ? count : _array.Length) * sizeof(ushort)
);
return subsetArray;
}
public override void Insert(int index, int count, int length)
{
int newLength = length + count;
if (newLength > _array.Length)
{
Invariant.Assert(_leap > 0, "Growing an ungrowable list!");
//increase storage by integral number of _leaps.
int extra = newLength - _array.Length;
int newArraySize = _array.Length + ((extra - 1) / _leap + 1) * _leap;
// get a new buffer
ushort[] newArray = new ushort[newArraySize];
//Move elements
Buffer.BlockCopy(_array, 0, newArray, 0, index * sizeof(ushort));
if (index < length)
{
Buffer.BlockCopy(
_array,
index * sizeof(ushort),
newArray,
(index + count) * sizeof(ushort),
(length - index) * sizeof(ushort)
);
}
_array = newArray;
}
else
{
if (index < length)
{
Buffer.BlockCopy(
_array,
index * sizeof(ushort),
_array,
(index + count) * sizeof(ushort),
(length - index) * sizeof(ushort)
);
}
}
}
public override void Remove(int index, int count, int length)
{
Buffer.BlockCopy(
_array,
(index + count) * sizeof(ushort),
_array,
(index) * sizeof(ushort),
(length - index - count) * sizeof(ushort)
);
}
}
///
/// Ushort buffer implemented as unmanaged ushort array
///
internal unsafe class UnsafeUshortArray : UshortBuffer
{
///
/// Critical:Holds reference to a pointer
///
[SecurityCritical]
private ushort* _array;
///
/// Critical:Can be used to cause a buffer overrun
///
private SecurityCriticalDataForSet _arrayLength;
///
/// Critical: This code probes into checked pointer.
/// Safe : The pointer is validated at probing.
///
[SecurityCritical, SecurityTreatAsSafe]
internal UnsafeUshortArray(CheckedUShortPointer array, int arrayLength)
{
_array = array.Probe(0, arrayLength);
_arrayLength.Value = arrayLength;
}
///
/// Critical: This code accepts pointers and manipulates
/// them without validation.Critical for set only
/// Safe : Setter does propery bound check.
///
public override ushort this[int index]
{
[SecurityCritical,SecurityTreatAsSafe]
get
{
Invariant.Assert(index >= 0 && index < _arrayLength.Value);
return _array[index];
}
[SecurityCritical, SecurityTreatAsSafe]
set
{
Invariant.Assert(index >= 0 && index < _arrayLength.Value);
_array[index] = value;
}
}
public override int Length
{
get { return _arrayLength.Value; }
}
}
}
// 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
- SchemaAttDef.cs
- FrameworkRichTextComposition.cs
- UnknownBitmapDecoder.cs
- InsufficientMemoryException.cs
- ListComponentEditorPage.cs
- UnionQueryOperator.cs
- CacheVirtualItemsEvent.cs
- Trace.cs
- ReachVisualSerializer.cs
- ManagementObjectCollection.cs
- SelectionPatternIdentifiers.cs
- Slider.cs
- DataObjectCopyingEventArgs.cs
- WebBrowserNavigatingEventHandler.cs
- HTMLTagNameToTypeMapper.cs
- DisplayMemberTemplateSelector.cs
- SqlServer2KCompatibilityCheck.cs
- ConfigurationLocationCollection.cs
- SessionStateContainer.cs
- UpdatePanelTriggerCollection.cs
- BitStack.cs
- ManipulationCompletedEventArgs.cs
- SQLInt32.cs
- CompilerLocalReference.cs
- InvalidateEvent.cs
- TrustLevel.cs
- KeyProperty.cs
- LoginName.cs
- UnsafeNetInfoNativeMethods.cs
- RoleManagerEventArgs.cs
- TypeUtil.cs
- ImageBrush.cs
- XmlSerializationGeneratedCode.cs
- XPathCompiler.cs
- EntityRecordInfo.cs
- ExpressionConverter.cs
- UserControlAutomationPeer.cs
- SqlDeflator.cs
- SingleSelectRootGridEntry.cs
- MasterPageBuildProvider.cs
- COM2Enum.cs
- GridLength.cs
- RectValueSerializer.cs
- WebServiceErrorEvent.cs
- StrongNameMembershipCondition.cs
- KeyValueSerializer.cs
- ExpressionNode.cs
- SamlAuthorityBinding.cs
- XmlQueryType.cs
- PartManifestEntry.cs
- ConvertBinder.cs
- ColumnMapCopier.cs
- AtomPub10CategoriesDocumentFormatter.cs
- PersonalizationState.cs
- Point3DCollectionConverter.cs
- TableAdapterManagerGenerator.cs
- RowUpdatedEventArgs.cs
- HtmlTableRow.cs
- XmlFormatReaderGenerator.cs
- SafeProcessHandle.cs
- PageWrapper.cs
- PerformanceCounterCategory.cs
- UIPropertyMetadata.cs
- ObjectViewFactory.cs
- WebColorConverter.cs
- codemethodreferenceexpression.cs
- ConnectionProviderAttribute.cs
- XmlExpressionDumper.cs
- GlobalizationAssembly.cs
- XmlSchemaFacet.cs
- SessionParameter.cs
- UIElementCollection.cs
- FunctionDescription.cs
- BoundsDrawingContextWalker.cs
- FileFormatException.cs
- HttpGetProtocolImporter.cs
- HostingEnvironmentSection.cs
- PaintValueEventArgs.cs
- RawUIStateInputReport.cs
- TitleStyle.cs
- ICollection.cs
- FontUnitConverter.cs
- LinearQuaternionKeyFrame.cs
- InitializationEventAttribute.cs
- Transform.cs
- Baml6Assembly.cs
- BitmapEffect.cs
- DesignTimeResourceProviderFactoryAttribute.cs
- TranslateTransform.cs
- TypeRestriction.cs
- EventProvider.cs
- ImplicitInputBrush.cs
- QuaternionAnimation.cs
- WebConvert.cs
- ParameterBuilder.cs
- DependencySource.cs
- BuilderInfo.cs
- DesignerForm.cs
- ListSortDescription.cs
- PeerNearMe.cs