Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / Collections / Generic / IList.cs / 1305376 / IList.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Interface: IList ** **[....] ** ** ** Purpose: Base interface for all generic lists. ** ** ===========================================================*/ namespace System.Collections.Generic { using System; using System.Collections; using System.Runtime.CompilerServices; using System.Diagnostics.Contracts; // An IList is an ordered collection of objects. The exact ordering // is up to the implementation of the list, ranging from a sorted // order to insertion order. // Note that T[] : IList, and we want to ensure that if you use // IList , we ensure a YourValueType[] can be used // without jitting. Hence the TypeDependencyAttribute on SZArrayHelper. // This is a special hack internally though - see VM\compile.cpp. // The same attribute is on IEnumerable and ICollection . [TypeDependencyAttribute("System.SZArrayHelper")] [ContractClass(typeof(IListContract<>))] public interface IList : ICollection { // The Item property provides methods to read and edit entries in the List. T this[int index] { get; set; } // Returns the index of a particular item, if it is in the list. // Returns -1 if the item isn't in the list. int IndexOf(T item); // Inserts value into the list at position index. // index must be non-negative and less than or equal to the // number of elements in the list. If index equals the number // of items in the list, then value is appended to the end. void Insert(int index, T item); // Removes the item at position index. void RemoveAt(int index); } [ContractClassFor(typeof(IList<>))] internal abstract class IListContract : IList { T IList .this[int index] { get { //Contract.Requires(index >= 0); //Contract.Requires(index < ((ICollection )this).Count); return default(T); } set { //Contract.Requires(index >= 0); //Contract.Requires(index < ((ICollection )this).Count); } } IEnumerator System.Collections.IEnumerable.GetEnumerator() { Contract.Ensures(Contract.Result () != null); return default(IEnumerator); } IEnumerator IEnumerable .GetEnumerator() { Contract.Ensures(Contract.Result >() != null); return default(IEnumerator ); } [Pure] int IList .IndexOf(T value) { Contract.Ensures(Contract.Result () >= -1); Contract.Ensures(Contract.Result () < ((ICollection )this).Count); return default(int); } void IList .Insert(int index, T value) { //Contract.Requires(index >= 0); //Contract.Requires(index <= ((ICollection )this).Count); // For inserting immediately after the end. //Contract.Ensures(((ICollection )this).Count == Contract.OldValue(((ICollection )this).Count) + 1); // Not threadsafe } void IList .RemoveAt(int index) { //Contract.Requires(index >= 0); //Contract.Requires(index < ((ICollection )this).Count); //Contract.Ensures(((ICollection )this).Count == Contract.OldValue(((ICollection )this).Count) - 1); // Not threadsafe } #region ICollection Members void ICollection .Add(T value) { //Contract.Ensures(((ICollection )this).Count == Contract.OldValue(((ICollection )this).Count) + 1); // Not threadsafe } bool ICollection .IsReadOnly { get { return default(bool); } } int ICollection .Count { get { Contract.Ensures(Contract.Result () >= 0); return default(int); } } void ICollection .Clear() { // For fixed-sized collections like arrays, Clear will not change the Count property. // But we can't express that in a contract because we have no IsFixedSize property on // our generic collection interfaces. } bool ICollection .Contains(T value) { return default(bool); } void ICollection .CopyTo(T[] array, int startIndex) { //Contract.Requires(array != null); //Contract.Requires(startIndex >= 0); //Contract.Requires(startIndex + ((ICollection )this).Count <= array.Length); } bool ICollection .Remove(T value) { // No information if removal fails. return default(bool); } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Interface: IList ** ** [....] ** ** ** Purpose: Base interface for all generic lists. ** ** ===========================================================*/ namespace System.Collections.Generic { using System; using System.Collections; using System.Runtime.CompilerServices; using System.Diagnostics.Contracts; // An IList is an ordered collection of objects. The exact ordering // is up to the implementation of the list, ranging from a sorted // order to insertion order. // Note that T[] : IList, and we want to ensure that if you use // IList , we ensure a YourValueType[] can be used // without jitting. Hence the TypeDependencyAttribute on SZArrayHelper. // This is a special hack internally though - see VM\compile.cpp. // The same attribute is on IEnumerable and ICollection . [TypeDependencyAttribute("System.SZArrayHelper")] [ContractClass(typeof(IListContract<>))] public interface IList : ICollection { // The Item property provides methods to read and edit entries in the List. T this[int index] { get; set; } // Returns the index of a particular item, if it is in the list. // Returns -1 if the item isn't in the list. int IndexOf(T item); // Inserts value into the list at position index. // index must be non-negative and less than or equal to the // number of elements in the list. If index equals the number // of items in the list, then value is appended to the end. void Insert(int index, T item); // Removes the item at position index. void RemoveAt(int index); } [ContractClassFor(typeof(IList<>))] internal abstract class IListContract : IList { T IList .this[int index] { get { //Contract.Requires(index >= 0); //Contract.Requires(index < ((ICollection )this).Count); return default(T); } set { //Contract.Requires(index >= 0); //Contract.Requires(index < ((ICollection )this).Count); } } IEnumerator System.Collections.IEnumerable.GetEnumerator() { Contract.Ensures(Contract.Result () != null); return default(IEnumerator); } IEnumerator IEnumerable .GetEnumerator() { Contract.Ensures(Contract.Result >() != null); return default(IEnumerator ); } [Pure] int IList .IndexOf(T value) { Contract.Ensures(Contract.Result () >= -1); Contract.Ensures(Contract.Result () < ((ICollection )this).Count); return default(int); } void IList .Insert(int index, T value) { //Contract.Requires(index >= 0); //Contract.Requires(index <= ((ICollection )this).Count); // For inserting immediately after the end. //Contract.Ensures(((ICollection )this).Count == Contract.OldValue(((ICollection )this).Count) + 1); // Not threadsafe } void IList .RemoveAt(int index) { //Contract.Requires(index >= 0); //Contract.Requires(index < ((ICollection )this).Count); //Contract.Ensures(((ICollection )this).Count == Contract.OldValue(((ICollection )this).Count) - 1); // Not threadsafe } #region ICollection Members void ICollection .Add(T value) { //Contract.Ensures(((ICollection )this).Count == Contract.OldValue(((ICollection )this).Count) + 1); // Not threadsafe } bool ICollection .IsReadOnly { get { return default(bool); } } int ICollection .Count { get { Contract.Ensures(Contract.Result () >= 0); return default(int); } } void ICollection .Clear() { // For fixed-sized collections like arrays, Clear will not change the Count property. // But we can't express that in a contract because we have no IsFixedSize property on // our generic collection interfaces. } bool ICollection .Contains(T value) { return default(bool); } void ICollection .CopyTo(T[] array, int startIndex) { //Contract.Requires(array != null); //Contract.Requires(startIndex >= 0); //Contract.Requires(startIndex + ((ICollection )this).Count <= array.Length); } bool ICollection .Remove(T value) { // No information if removal fails. return default(bool); } #endregion } } // 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
- LateBoundBitmapDecoder.cs
- DataGridViewAutoSizeColumnsModeEventArgs.cs
- SchemaElementLookUpTable.cs
- StreamUpgradeProvider.cs
- XmlFormatExtensionAttribute.cs
- HandleTable.cs
- Utils.cs
- EntityClassGenerator.cs
- CollectionViewGroupRoot.cs
- ParallelQuery.cs
- WebServiceAttribute.cs
- RefreshPropertiesAttribute.cs
- MessageDesigner.cs
- EditableLabelControl.cs
- Queue.cs
- MulticastOption.cs
- FixedHighlight.cs
- CodeDomSerializerBase.cs
- XmlSerializationReader.cs
- QueryOpeningEnumerator.cs
- Rect.cs
- UniqueConstraint.cs
- Button.cs
- SystemBrushes.cs
- SatelliteContractVersionAttribute.cs
- MachineKeySection.cs
- XamlLoadErrorInfo.cs
- IsolatedStorage.cs
- Request.cs
- NavigationWindowAutomationPeer.cs
- EventOpcode.cs
- CompilationRelaxations.cs
- UIElementParagraph.cs
- FastEncoderWindow.cs
- HtmlElementEventArgs.cs
- bidPrivateBase.cs
- SizeAnimationBase.cs
- TargetException.cs
- PageCodeDomTreeGenerator.cs
- DataRowCollection.cs
- Rectangle.cs
- DataListDesigner.cs
- AdornedElementPlaceholder.cs
- HostProtectionPermission.cs
- CacheEntry.cs
- TypeSource.cs
- TouchDevice.cs
- TabControl.cs
- EventListenerClientSide.cs
- PropertyManager.cs
- _ChunkParse.cs
- formatstringdialog.cs
- __FastResourceComparer.cs
- CuspData.cs
- DataGridViewImageCell.cs
- Region.cs
- NullNotAllowedCollection.cs
- GrammarBuilderRuleRef.cs
- AssertSection.cs
- XPathNodeInfoAtom.cs
- DataRecordInternal.cs
- PolicyManager.cs
- ReferentialConstraintRoleElement.cs
- DSASignatureFormatter.cs
- RawContentTypeMapper.cs
- SoapInteropTypes.cs
- TdsEnums.cs
- TranslateTransform3D.cs
- MouseOverProperty.cs
- KeyboardEventArgs.cs
- ChangeDirector.cs
- ForceCopyBuildProvider.cs
- Image.cs
- MsmqHostedTransportConfiguration.cs
- JournalEntry.cs
- hwndwrapper.cs
- SettingsAttributeDictionary.cs
- PtsContext.cs
- XmlRootAttribute.cs
- ColorConverter.cs
- RewritingSimplifier.cs
- CreateUserWizardDesigner.cs
- GetUserPreferenceRequest.cs
- ClrPerspective.cs
- SqlRecordBuffer.cs
- GuidelineSet.cs
- FixedTextContainer.cs
- PolyLineSegmentFigureLogic.cs
- ConfigurationFileMap.cs
- ApplicationFileParser.cs
- KeyValueConfigurationCollection.cs
- Module.cs
- PropertyGridCommands.cs
- SmtpClient.cs
- NativeMethodsOther.cs
- SymbolEqualComparer.cs
- Transform3DGroup.cs
- PropertyNames.cs
- rsa.cs
- ProviderConnectionPoint.cs