Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Objects / DataRecordObjectView.cs / 1 / DataRecordObjectView.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner jhutson // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Data.Common; using System.Data.Metadata; using System.Data.Metadata.Edm; using System.Reflection; namespace System.Data.Objects { ////// ObjectView that provides binding to a list of data records. /// ////// This class provides an implementation of ITypedList that returns property descriptors /// for each column of results in a data record. /// internal sealed class DataRecordObjectView : ObjectView, ITypedList { /// /// Cache of the property descriptors for the element type of the root list wrapped by ObjectView. /// private PropertyDescriptorCollection _propertyDescriptorsCache; ////// EDM RowType that describes the shape of record elements. /// private RowType _rowType; internal DataRecordObjectView(IObjectViewDataviewData, object eventDataSource, RowType rowType, Type propertyComponentType) : base(viewData, eventDataSource) { if (!typeof(IDataRecord).IsAssignableFrom(propertyComponentType)) { propertyComponentType = typeof(IDataRecord); } _rowType = rowType; _propertyDescriptorsCache = MaterializedDataRecord.CreatePropertyDescriptorCollection(_rowType, propertyComponentType, true); } /// /// Return a /// ///instance that represents /// a strongly-typed indexer property on the specified type. /// that may define the appropriate indexer. /// /// /// ///instance of indexer defined on supplied type /// that returns an object of any type but ; /// or null if no such indexer is defined on the supplied type. /// /// The algorithm here is lifted from System.Windows.Forms.ListBindingHelper, /// from the GetTypedIndexer method. /// The Entity Framework could not take a dependency on WinForms, /// so we lifted the appropriate parts from the WinForms code here. /// A bit ----, but much better than guessing as to what algorithm is proper for data binding. /// private static PropertyInfo GetTypedIndexer(Type type) { PropertyInfo indexer = null; if (typeof(IList).IsAssignableFrom(type) || typeof(ITypedList).IsAssignableFrom(type) || typeof(IListSource).IsAssignableFrom(type)) { System.Reflection.PropertyInfo[] props = type.GetProperties(BindingFlags.Public | BindingFlags.Instance); for (int idx = 0; idx < props.Length; idx++) { if (props[idx].GetIndexParameters().Length > 0 && props[idx].PropertyType != typeof(object)) { indexer = props[idx]; //Prefer the standard indexer, if there is one if (indexer.Name == "Item") { break; } } } } return indexer; } ////// Return the element type for the supplied type. /// /// ////// If ///represents a list type that doesn't also implement ITypedList or IListSource, /// return the element type for items in that list. /// Otherwise, return the type supplied by . /// /// The algorithm here is lifted from System.Windows.Forms.ListBindingHelper, /// from the GetListItemType(object) method. /// The Entity Framework could not take a dependency on WinForms, /// so we lifted the appropriate parts from the WinForms code here. /// A bit ----, but much better than guessing as to what algorithm is proper for data binding. /// private static Type GetListItemType(Type type) { Type itemType; if (typeof(Array).IsAssignableFrom(type)) { itemType = type.GetElementType(); } else { PropertyInfo typedIndexer = GetTypedIndexer(type); if (typedIndexer != null) { itemType = typedIndexer.PropertyType; } else { itemType = type; } } return itemType; } #region ITypedList Members PropertyDescriptorCollection System.ComponentModel.ITypedList.GetItemProperties(PropertyDescriptor[] listAccessors) { PropertyDescriptorCollection propertyDescriptors; if (listAccessors == null || listAccessors.Length == 0) { // Caller is requesting property descriptors for the root element type. propertyDescriptors = _propertyDescriptorsCache; } else { // Use the last PropertyDescriptor in the array to build the collection of returned property descriptors. PropertyDescriptor propertyDescriptor = listAccessors[listAccessors.Length - 1]; FieldDescriptor fieldDescriptor = propertyDescriptor as FieldDescriptor; // If the property descriptor describes a data record with the EDM type of RowType, // construct the collection of property descriptors from the property's EDM metadata. // Otherwise use the CLR type of the property. if (fieldDescriptor != null && fieldDescriptor.EdmProperty != null && fieldDescriptor.EdmProperty.TypeUsage.EdmType.BuiltInTypeKind == BuiltInTypeKind.RowType) { // Retrieve property descriptors from EDM metadata. propertyDescriptors = MaterializedDataRecord.CreatePropertyDescriptorCollection((RowType)fieldDescriptor.EdmProperty.TypeUsage.EdmType, typeof(IDataRecord), true); } else { // Use the CLR type. propertyDescriptors = TypeDescriptor.GetProperties(GetListItemType(propertyDescriptor.PropertyType)); } } return propertyDescriptors; } string System.ComponentModel.ITypedList.GetListName(PropertyDescriptor[] listAccessors) { return _rowType.Name; } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner jhutson // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Data.Common; using System.Data.Metadata; using System.Data.Metadata.Edm; using System.Reflection; namespace System.Data.Objects { ////// ObjectView that provides binding to a list of data records. /// ////// This class provides an implementation of ITypedList that returns property descriptors /// for each column of results in a data record. /// internal sealed class DataRecordObjectView : ObjectView, ITypedList { /// /// Cache of the property descriptors for the element type of the root list wrapped by ObjectView. /// private PropertyDescriptorCollection _propertyDescriptorsCache; ////// EDM RowType that describes the shape of record elements. /// private RowType _rowType; internal DataRecordObjectView(IObjectViewDataviewData, object eventDataSource, RowType rowType, Type propertyComponentType) : base(viewData, eventDataSource) { if (!typeof(IDataRecord).IsAssignableFrom(propertyComponentType)) { propertyComponentType = typeof(IDataRecord); } _rowType = rowType; _propertyDescriptorsCache = MaterializedDataRecord.CreatePropertyDescriptorCollection(_rowType, propertyComponentType, true); } /// /// Return a /// ///instance that represents /// a strongly-typed indexer property on the specified type. /// that may define the appropriate indexer. /// /// /// ///instance of indexer defined on supplied type /// that returns an object of any type but ; /// or null if no such indexer is defined on the supplied type. /// /// The algorithm here is lifted from System.Windows.Forms.ListBindingHelper, /// from the GetTypedIndexer method. /// The Entity Framework could not take a dependency on WinForms, /// so we lifted the appropriate parts from the WinForms code here. /// A bit ----, but much better than guessing as to what algorithm is proper for data binding. /// private static PropertyInfo GetTypedIndexer(Type type) { PropertyInfo indexer = null; if (typeof(IList).IsAssignableFrom(type) || typeof(ITypedList).IsAssignableFrom(type) || typeof(IListSource).IsAssignableFrom(type)) { System.Reflection.PropertyInfo[] props = type.GetProperties(BindingFlags.Public | BindingFlags.Instance); for (int idx = 0; idx < props.Length; idx++) { if (props[idx].GetIndexParameters().Length > 0 && props[idx].PropertyType != typeof(object)) { indexer = props[idx]; //Prefer the standard indexer, if there is one if (indexer.Name == "Item") { break; } } } } return indexer; } ////// Return the element type for the supplied type. /// /// ////// If ///represents a list type that doesn't also implement ITypedList or IListSource, /// return the element type for items in that list. /// Otherwise, return the type supplied by . /// /// The algorithm here is lifted from System.Windows.Forms.ListBindingHelper, /// from the GetListItemType(object) method. /// The Entity Framework could not take a dependency on WinForms, /// so we lifted the appropriate parts from the WinForms code here. /// A bit ----, but much better than guessing as to what algorithm is proper for data binding. /// private static Type GetListItemType(Type type) { Type itemType; if (typeof(Array).IsAssignableFrom(type)) { itemType = type.GetElementType(); } else { PropertyInfo typedIndexer = GetTypedIndexer(type); if (typedIndexer != null) { itemType = typedIndexer.PropertyType; } else { itemType = type; } } return itemType; } #region ITypedList Members PropertyDescriptorCollection System.ComponentModel.ITypedList.GetItemProperties(PropertyDescriptor[] listAccessors) { PropertyDescriptorCollection propertyDescriptors; if (listAccessors == null || listAccessors.Length == 0) { // Caller is requesting property descriptors for the root element type. propertyDescriptors = _propertyDescriptorsCache; } else { // Use the last PropertyDescriptor in the array to build the collection of returned property descriptors. PropertyDescriptor propertyDescriptor = listAccessors[listAccessors.Length - 1]; FieldDescriptor fieldDescriptor = propertyDescriptor as FieldDescriptor; // If the property descriptor describes a data record with the EDM type of RowType, // construct the collection of property descriptors from the property's EDM metadata. // Otherwise use the CLR type of the property. if (fieldDescriptor != null && fieldDescriptor.EdmProperty != null && fieldDescriptor.EdmProperty.TypeUsage.EdmType.BuiltInTypeKind == BuiltInTypeKind.RowType) { // Retrieve property descriptors from EDM metadata. propertyDescriptors = MaterializedDataRecord.CreatePropertyDescriptorCollection((RowType)fieldDescriptor.EdmProperty.TypeUsage.EdmType, typeof(IDataRecord), true); } else { // Use the CLR type. propertyDescriptors = TypeDescriptor.GetProperties(GetListItemType(propertyDescriptor.PropertyType)); } } return propertyDescriptors; } string System.ComponentModel.ITypedList.GetListName(PropertyDescriptor[] listAccessors) { return _rowType.Name; } #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
- SystemUdpStatistics.cs
- MimeWriter.cs
- ColumnHeader.cs
- Encoding.cs
- RenderOptions.cs
- PathFigure.cs
- Brushes.cs
- FormatterServices.cs
- NestedContainer.cs
- Identity.cs
- BevelBitmapEffect.cs
- OracleConnectionStringBuilder.cs
- RoleManagerSection.cs
- Random.cs
- SupportingTokenSecurityTokenResolver.cs
- SmiContext.cs
- XmlExtensionFunction.cs
- CompositeFontInfo.cs
- SessionEndingEventArgs.cs
- SecureConversationVersion.cs
- ImportCatalogPart.cs
- SendKeys.cs
- WindowInteractionStateTracker.cs
- SerializationAttributes.cs
- RadioButtonList.cs
- MouseDevice.cs
- DrawTreeNodeEventArgs.cs
- TileBrush.cs
- ZipPackagePart.cs
- XamlFigureLengthSerializer.cs
- SqlGatherConsumedAliases.cs
- WebPartActionVerb.cs
- StateChangeEvent.cs
- CompoundFileIOPermission.cs
- CacheChildrenQuery.cs
- FrugalList.cs
- SignedXmlDebugLog.cs
- MonthCalendar.cs
- xsdvalidator.cs
- ChunkedMemoryStream.cs
- XmlNamespaceDeclarationsAttribute.cs
- TypeExtensionSerializer.cs
- Executor.cs
- DataObjectPastingEventArgs.cs
- ColumnBinding.cs
- TableCell.cs
- JoinGraph.cs
- PngBitmapDecoder.cs
- SessionStateModule.cs
- WebPartPersonalization.cs
- DirectionalLight.cs
- CookieParameter.cs
- HiddenField.cs
- TcpSocketManager.cs
- selecteditemcollection.cs
- StringInfo.cs
- RegexGroupCollection.cs
- DocumentGridContextMenu.cs
- processwaithandle.cs
- TemplateField.cs
- WorkBatch.cs
- ServicesUtilities.cs
- StylusPointCollection.cs
- WebPartConnectVerb.cs
- SettingsPropertyWrongTypeException.cs
- UIElementAutomationPeer.cs
- WebPartDisplayModeEventArgs.cs
- StringFreezingAttribute.cs
- DataGridAutoFormat.cs
- PostBackOptions.cs
- RegexStringValidator.cs
- XmlSchemaSubstitutionGroup.cs
- DBNull.cs
- AnonymousIdentificationSection.cs
- TextCompositionEventArgs.cs
- ConvertersCollection.cs
- NGCPageContentCollectionSerializerAsync.cs
- Panel.cs
- Inline.cs
- StringToken.cs
- ReflectEventDescriptor.cs
- DataSourceProvider.cs
- FontWeightConverter.cs
- TypeTypeConverter.cs
- SoapIncludeAttribute.cs
- Literal.cs
- BulletedList.cs
- ChannelTraceRecord.cs
- cookieexception.cs
- ContentControl.cs
- WorkBatch.cs
- SolidBrush.cs
- TriState.cs
- TypedRowHandler.cs
- MessageFault.cs
- ConfigurationManagerHelper.cs
- Utils.cs
- Debug.cs
- Sequence.cs
- FlowDocumentScrollViewerAutomationPeer.cs