Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / xsp / System / Web / UI / WebControls / CompositeDataBoundControl.cs / 1 / CompositeDataBoundControl.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.Collections; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public abstract class CompositeDataBoundControl : DataBoundControl, INamingContainer { internal const string ItemCountViewStateKey = "_!ItemCount"; public override ControlCollection Controls { get { EnsureChildControls(); return base.Controls; } } ////// Overriden by DataBoundControl to determine if the control should /// recreate its control hierarchy based on values in view state. /// If the control hierarchy should be created, i.e. view state does /// exist, it calls CreateChildControls with a dummy (empty) data source /// which is usable for enumeration purposes only. /// protected internal override void CreateChildControls() { Controls.Clear(); object controlCount = ViewState[ItemCountViewStateKey]; if (controlCount == null && RequiresDataBinding) { EnsureDataBound(); } if (controlCount != null && ((int)controlCount) != -1) { DummyDataSource dummyDataSource = new DummyDataSource((int)controlCount); CreateChildControls(dummyDataSource, false); ClearChildViewState(); } } ////// Performs the work of creating the control hierarchy based on a data source. /// When dataBinding is true, the specified data source contains real /// data, and the data is supposed to be pushed into the UI. /// When dataBinding is false, the specified data source is a dummy data /// source, that allows enumerating the right number of items, but the items /// themselves are null and do not contain data. In this case, the recreated /// control hierarchy reinitializes its state from view state. /// It enables a DataBoundControl to encapsulate the logic of creating its /// control hierarchy in both modes into a single code path. /// /// /// The data source to be used to enumerate items. /// /// /// Whether the method has been called from DataBind or not. /// ////// The number of items created based on the data source. Put another way, its /// the number of items enumerated from the data source. /// protected abstract int CreateChildControls(IEnumerable dataSource, bool dataBinding); ////// Overriden by DataBoundControl to use its properties to determine the real /// data source that the control should bind to. It then clears the existing /// control hierarchy, and calls createChildControls to create a new control /// hierarchy based on the resolved data source. /// The implementation resolves various data source related properties to /// arrive at the appropriate IEnumerable implementation to use as the real /// data source. /// When resolving data sources, the DataSourceControlID takes highest precedence. /// In this mode, DataMember is used to access the appropriate list from the /// DataControl. /// If DataSourceControlID is not set, the value of the DataSource property is used. /// In this second alternative, DataMember is used to extract the appropriate /// list if the control has been handed an IListSource as a data source. /// protected internal override void PerformDataBinding(IEnumerable data) { base.PerformDataBinding(data); Controls.Clear(); ClearChildViewState(); TrackViewState(); int controlCount = CreateChildControls(data, true); ChildControlsCreated = true; ViewState[ItemCountViewStateKey] = controlCount; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.Collections; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public abstract class CompositeDataBoundControl : DataBoundControl, INamingContainer { internal const string ItemCountViewStateKey = "_!ItemCount"; public override ControlCollection Controls { get { EnsureChildControls(); return base.Controls; } } ////// Overriden by DataBoundControl to determine if the control should /// recreate its control hierarchy based on values in view state. /// If the control hierarchy should be created, i.e. view state does /// exist, it calls CreateChildControls with a dummy (empty) data source /// which is usable for enumeration purposes only. /// protected internal override void CreateChildControls() { Controls.Clear(); object controlCount = ViewState[ItemCountViewStateKey]; if (controlCount == null && RequiresDataBinding) { EnsureDataBound(); } if (controlCount != null && ((int)controlCount) != -1) { DummyDataSource dummyDataSource = new DummyDataSource((int)controlCount); CreateChildControls(dummyDataSource, false); ClearChildViewState(); } } ////// Performs the work of creating the control hierarchy based on a data source. /// When dataBinding is true, the specified data source contains real /// data, and the data is supposed to be pushed into the UI. /// When dataBinding is false, the specified data source is a dummy data /// source, that allows enumerating the right number of items, but the items /// themselves are null and do not contain data. In this case, the recreated /// control hierarchy reinitializes its state from view state. /// It enables a DataBoundControl to encapsulate the logic of creating its /// control hierarchy in both modes into a single code path. /// /// /// The data source to be used to enumerate items. /// /// /// Whether the method has been called from DataBind or not. /// ////// The number of items created based on the data source. Put another way, its /// the number of items enumerated from the data source. /// protected abstract int CreateChildControls(IEnumerable dataSource, bool dataBinding); ////// Overriden by DataBoundControl to use its properties to determine the real /// data source that the control should bind to. It then clears the existing /// control hierarchy, and calls createChildControls to create a new control /// hierarchy based on the resolved data source. /// The implementation resolves various data source related properties to /// arrive at the appropriate IEnumerable implementation to use as the real /// data source. /// When resolving data sources, the DataSourceControlID takes highest precedence. /// In this mode, DataMember is used to access the appropriate list from the /// DataControl. /// If DataSourceControlID is not set, the value of the DataSource property is used. /// In this second alternative, DataMember is used to extract the appropriate /// list if the control has been handed an IListSource as a data source. /// protected internal override void PerformDataBinding(IEnumerable data) { base.PerformDataBinding(data); Controls.Clear(); ClearChildViewState(); TrackViewState(); int controlCount = CreateChildControls(data, true); ChildControlsCreated = true; ViewState[ItemCountViewStateKey] = controlCount; } } } // 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
- SQLDouble.cs
- ScrollPatternIdentifiers.cs
- GlyphingCache.cs
- IntSecurity.cs
- GridViewColumn.cs
- SecurityManager.cs
- Block.cs
- TypeReference.cs
- ServiceSecurityAuditElement.cs
- TcpProcessProtocolHandler.cs
- DataDocumentXPathNavigator.cs
- SQLRoleProvider.cs
- SqlDataSourceQuery.cs
- TCPListener.cs
- XmlStringTable.cs
- WaitHandleCannotBeOpenedException.cs
- Vector3D.cs
- WindowsFormsLinkLabel.cs
- CaseStatementSlot.cs
- SvcMapFile.cs
- AsnEncodedData.cs
- Exceptions.cs
- TdsParserStateObject.cs
- TextParagraphView.cs
- SoapIgnoreAttribute.cs
- DocumentViewerHelper.cs
- ListViewItem.cs
- ValueTypePropertyReference.cs
- ServicesUtilities.cs
- WebBrowsableAttribute.cs
- IriParsingElement.cs
- EnterpriseServicesHelper.cs
- ModifiableIteratorCollection.cs
- GradientStop.cs
- ExpanderAutomationPeer.cs
- BitmapEffectrendercontext.cs
- PrintDocument.cs
- NavigationWindow.cs
- EntityDesignerDataSourceView.cs
- Vector3dCollection.cs
- InstanceHandleReference.cs
- FlowLayout.cs
- NullReferenceException.cs
- HtmlToClrEventProxy.cs
- PageTheme.cs
- FieldReference.cs
- UnsignedPublishLicense.cs
- MonitoringDescriptionAttribute.cs
- StatusBarItem.cs
- AccessDataSource.cs
- BinarySerializer.cs
- Symbol.cs
- WindowsSolidBrush.cs
- DispatcherHooks.cs
- DrawingGroup.cs
- RelatedCurrencyManager.cs
- DataGridViewButtonColumn.cs
- BaseResourcesBuildProvider.cs
- DataSetUtil.cs
- TemplateKeyConverter.cs
- WindowsSysHeader.cs
- AvTraceFormat.cs
- Column.cs
- Point3DConverter.cs
- UrlAuthorizationModule.cs
- CryptoApi.cs
- SqlCacheDependencySection.cs
- EntityObject.cs
- Int16KeyFrameCollection.cs
- DbQueryCommandTree.cs
- BufferBuilder.cs
- backend.cs
- SubpageParaClient.cs
- AlphaSortedEnumConverter.cs
- MarkupCompiler.cs
- ListViewEditEventArgs.cs
- ChtmlLinkAdapter.cs
- ProcessThreadCollection.cs
- IntAverageAggregationOperator.cs
- FontDifferentiator.cs
- CacheDict.cs
- TableLayoutStyle.cs
- DiagnosticsConfigurationHandler.cs
- PartialList.cs
- PageBuildProvider.cs
- TraceHwndHost.cs
- EntityTypeEmitter.cs
- AttributeQuery.cs
- TextTreeInsertUndoUnit.cs
- WebRequestModuleElement.cs
- NeutralResourcesLanguageAttribute.cs
- ServiceOperation.cs
- Update.cs
- GlyphCache.cs
- ChildrenQuery.cs
- UpdateExpressionVisitor.cs
- XmlSchemaObjectCollection.cs
- HasCopySemanticsAttribute.cs
- TextSerializer.cs
- MessageQueuePermissionAttribute.cs