Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / ndp / fx / src / xsp / System / Web / UI / DataSourceControl.cs / 1 / DataSourceControl.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI { using System.Collections; using System.ComponentModel; using System.Security.Permissions; ////// A DataSourceControl represents a data source that can be used to /// data-bind a DataBoundControl. /// DataSourceControl is an abstract base class that defines the /// interface between a DataBoundControl and its data source. /// The design of DataSourceControl enables creation of a variety of /// data controls with different underlying data sources such /// as SqlDataControl, WebServiceDataControl, XmlDataControl etc. /// The data source is implemented as a control even though it /// has no visual rendering, to allow it to be persisted /// declaratively, and to allow it to participate in state /// management should it choose to. /// In abstract terms a DataSourceControl has an underlying data source. /// This data source may contain one or more lists of data within it. /// Each list is associated with a name and at the bare minimum /// supports enumeration via the IEnumerable interface. A DataBoundControl /// is typically bound to a single list within the DataControl. /// [ Bindable(false), ControlBuilder(typeof(DataSourceControlBuilder)), Designer("System.Web.UI.Design.DataSourceDesigner, " + AssemblyRef.SystemDesign), NonVisualControl() ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public abstract class DataSourceControl : Control, IDataSource, IListSource { private static readonly object EventDataSourceChanged = new object(); private static readonly object EventDataSourceChangedInternal = new object(); [ EditorBrowsable(EditorBrowsableState.Never), ] public override string ClientID { get { return base.ClientID; } } [ EditorBrowsable(EditorBrowsableState.Never), ] public override ControlCollection Controls { get { return base.Controls; } } [ Browsable(false), DefaultValue(false), EditorBrowsable(EditorBrowsableState.Never), ] public override bool EnableTheming { get { return false; } set { throw new NotSupportedException(SR.GetString(SR.NoThemingSupport, this.GetType().Name)); } } [ Browsable(false), DefaultValue(""), EditorBrowsable(EditorBrowsableState.Never), ] public override string SkinID { get { return String.Empty; } set { throw new NotSupportedException(SR.GetString(SR.NoThemingSupport, this.GetType().Name)); } } ////// Gets or sets a value that indicates whether a control should be rendered on /// the page. /// [ Browsable(false), DefaultValue(false), EditorBrowsable(EditorBrowsableState.Never), ] public override bool Visible { get { return false; } set { throw new NotSupportedException(SR.GetString(SR.ControlNonVisual, this.GetType().Name)); } } ////// Raised internally by a DataSource when data-related state is /// changed. DataSourceViews attach to this event so that they can /// be notified when the parent data source changes. /// This event is separate from DataSourceChanged because the DataSourceView /// attaches to it and fires its DataSourceViewChanged event. We want that /// to fire before the DataSourceChanged event. /// internal event EventHandler DataSourceChangedInternal { add { Events.AddHandler(EventDataSourceChangedInternal, value); } remove { Events.RemoveHandler(EventDataSourceChangedInternal, value); } } [ EditorBrowsable(EditorBrowsableState.Never), ] public override void ApplyStyleSheetSkin(Page page) { base.ApplyStyleSheetSkin(page); } ////// Overidden to prevent child controls from being added to this control. /// protected override ControlCollection CreateControlCollection() { return new EmptyControlCollection(this); } [ EditorBrowsable(EditorBrowsableState.Never), ] public override Control FindControl(string id) { return base.FindControl(id); } ////// [ EditorBrowsable(EditorBrowsableState.Never), ] public override void Focus() { throw new NotSupportedException(SR.GetString(SR.NoFocusSupport, this.GetType().Name)); } protected abstract DataSourceView GetView(string viewName); protected virtual ICollection GetViewNames() { return null; } [ EditorBrowsable(EditorBrowsableState.Never), ] public override bool HasControls() { return base.HasControls(); } private void OnDataSourceChanged(EventArgs e) { EventHandler handler = (EventHandler)Events[EventDataSourceChanged]; if (handler != null) { handler(this, e); } } private void OnDataSourceChangedInternal(EventArgs e) { EventHandler handler = (EventHandler)Events[EventDataSourceChangedInternal]; if (handler != null) { handler(this, e); } } protected virtual void RaiseDataSourceChangedEvent(EventArgs e) { OnDataSourceChangedInternal(e); OnDataSourceChanged(e); } [ EditorBrowsable(EditorBrowsableState.Never), ] public override void RenderControl(HtmlTextWriter writer) { base.RenderControl(writer); } #region Implementation of IDataSource ////// Raised when the underlying data source has changed. The /// change may be due to a change in the control's properties, /// or a change in the data due to an edit action performed by /// the DataSourceControl. /// event EventHandler IDataSource.DataSourceChanged { add { Events.AddHandler(EventDataSourceChanged, value); } remove { Events.RemoveHandler(EventDataSourceChanged, value); } } ///DataSourceView IDataSource.GetView(string viewName) { return GetView(viewName); } /// ICollection IDataSource.GetViewNames() { return GetViewNames(); } #endregion #region Implementation of IListSource /// bool IListSource.ContainsListCollection { get { if (DesignMode) { return false; } return ListSourceHelper.ContainsListCollection(this); } } /// IList IListSource.GetList() { if (DesignMode) { return null; } return ListSourceHelper.GetList(this); } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI { using System.Collections; using System.ComponentModel; using System.Security.Permissions; ////// A DataSourceControl represents a data source that can be used to /// data-bind a DataBoundControl. /// DataSourceControl is an abstract base class that defines the /// interface between a DataBoundControl and its data source. /// The design of DataSourceControl enables creation of a variety of /// data controls with different underlying data sources such /// as SqlDataControl, WebServiceDataControl, XmlDataControl etc. /// The data source is implemented as a control even though it /// has no visual rendering, to allow it to be persisted /// declaratively, and to allow it to participate in state /// management should it choose to. /// In abstract terms a DataSourceControl has an underlying data source. /// This data source may contain one or more lists of data within it. /// Each list is associated with a name and at the bare minimum /// supports enumeration via the IEnumerable interface. A DataBoundControl /// is typically bound to a single list within the DataControl. /// [ Bindable(false), ControlBuilder(typeof(DataSourceControlBuilder)), Designer("System.Web.UI.Design.DataSourceDesigner, " + AssemblyRef.SystemDesign), NonVisualControl() ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public abstract class DataSourceControl : Control, IDataSource, IListSource { private static readonly object EventDataSourceChanged = new object(); private static readonly object EventDataSourceChangedInternal = new object(); [ EditorBrowsable(EditorBrowsableState.Never), ] public override string ClientID { get { return base.ClientID; } } [ EditorBrowsable(EditorBrowsableState.Never), ] public override ControlCollection Controls { get { return base.Controls; } } [ Browsable(false), DefaultValue(false), EditorBrowsable(EditorBrowsableState.Never), ] public override bool EnableTheming { get { return false; } set { throw new NotSupportedException(SR.GetString(SR.NoThemingSupport, this.GetType().Name)); } } [ Browsable(false), DefaultValue(""), EditorBrowsable(EditorBrowsableState.Never), ] public override string SkinID { get { return String.Empty; } set { throw new NotSupportedException(SR.GetString(SR.NoThemingSupport, this.GetType().Name)); } } ////// Gets or sets a value that indicates whether a control should be rendered on /// the page. /// [ Browsable(false), DefaultValue(false), EditorBrowsable(EditorBrowsableState.Never), ] public override bool Visible { get { return false; } set { throw new NotSupportedException(SR.GetString(SR.ControlNonVisual, this.GetType().Name)); } } ////// Raised internally by a DataSource when data-related state is /// changed. DataSourceViews attach to this event so that they can /// be notified when the parent data source changes. /// This event is separate from DataSourceChanged because the DataSourceView /// attaches to it and fires its DataSourceViewChanged event. We want that /// to fire before the DataSourceChanged event. /// internal event EventHandler DataSourceChangedInternal { add { Events.AddHandler(EventDataSourceChangedInternal, value); } remove { Events.RemoveHandler(EventDataSourceChangedInternal, value); } } [ EditorBrowsable(EditorBrowsableState.Never), ] public override void ApplyStyleSheetSkin(Page page) { base.ApplyStyleSheetSkin(page); } ////// Overidden to prevent child controls from being added to this control. /// protected override ControlCollection CreateControlCollection() { return new EmptyControlCollection(this); } [ EditorBrowsable(EditorBrowsableState.Never), ] public override Control FindControl(string id) { return base.FindControl(id); } ////// [ EditorBrowsable(EditorBrowsableState.Never), ] public override void Focus() { throw new NotSupportedException(SR.GetString(SR.NoFocusSupport, this.GetType().Name)); } protected abstract DataSourceView GetView(string viewName); protected virtual ICollection GetViewNames() { return null; } [ EditorBrowsable(EditorBrowsableState.Never), ] public override bool HasControls() { return base.HasControls(); } private void OnDataSourceChanged(EventArgs e) { EventHandler handler = (EventHandler)Events[EventDataSourceChanged]; if (handler != null) { handler(this, e); } } private void OnDataSourceChangedInternal(EventArgs e) { EventHandler handler = (EventHandler)Events[EventDataSourceChangedInternal]; if (handler != null) { handler(this, e); } } protected virtual void RaiseDataSourceChangedEvent(EventArgs e) { OnDataSourceChangedInternal(e); OnDataSourceChanged(e); } [ EditorBrowsable(EditorBrowsableState.Never), ] public override void RenderControl(HtmlTextWriter writer) { base.RenderControl(writer); } #region Implementation of IDataSource ////// Raised when the underlying data source has changed. The /// change may be due to a change in the control's properties, /// or a change in the data due to an edit action performed by /// the DataSourceControl. /// event EventHandler IDataSource.DataSourceChanged { add { Events.AddHandler(EventDataSourceChanged, value); } remove { Events.RemoveHandler(EventDataSourceChanged, value); } } ///DataSourceView IDataSource.GetView(string viewName) { return GetView(viewName); } /// ICollection IDataSource.GetViewNames() { return GetViewNames(); } #endregion #region Implementation of IListSource /// bool IListSource.ContainsListCollection { get { if (DesignMode) { return false; } return ListSourceHelper.ContainsListCollection(this); } } /// IList IListSource.GetList() { if (DesignMode) { return null; } return ListSourceHelper.GetList(this); } #endregion } } // 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
- SelectionWordBreaker.cs
- SerialPort.cs
- FixedDocumentPaginator.cs
- ClientEventManager.cs
- HwndSourceKeyboardInputSite.cs
- FloaterParagraph.cs
- Expander.cs
- HtmlInputCheckBox.cs
- QilName.cs
- WinFormsComponentEditor.cs
- HMACSHA384.cs
- BreadCrumbTextConverter.cs
- Profiler.cs
- AnnotationObservableCollection.cs
- _IPv4Address.cs
- ActivationServices.cs
- HMACMD5.cs
- ChangeDirector.cs
- InputLanguageSource.cs
- PeerToPeerException.cs
- EmbeddedMailObjectsCollection.cs
- EmptyEnumerator.cs
- SqlBooleanMismatchVisitor.cs
- TypedAsyncResult.cs
- ButtonStandardAdapter.cs
- SAPIEngineTypes.cs
- Win32PrintDialog.cs
- TreeNodeCollection.cs
- NamespaceCollection.cs
- ValidationSummary.cs
- CodeSubDirectory.cs
- DataList.cs
- HttpWrapper.cs
- ISAPIApplicationHost.cs
- PasswordBox.cs
- DecoderNLS.cs
- TimerExtension.cs
- CustomAttributeBuilder.cs
- SizeIndependentAnimationStorage.cs
- ProjectionCamera.cs
- EditorServiceContext.cs
- MouseButtonEventArgs.cs
- CodeDOMUtility.cs
- PermissionToken.cs
- DataStreamFromComStream.cs
- Authorization.cs
- RtfNavigator.cs
- HashStream.cs
- AppDomainManager.cs
- EditorPartChrome.cs
- PrePrepareMethodAttribute.cs
- DefaultBinder.cs
- TextElementAutomationPeer.cs
- CompoundFileReference.cs
- CollectionViewGroupRoot.cs
- ValueOfAction.cs
- CompositionDesigner.cs
- ExtensionFile.cs
- ExpressionEditorAttribute.cs
- CodeNamespaceCollection.cs
- ValidationPropertyAttribute.cs
- C14NUtil.cs
- storagemappingitemcollection.viewdictionary.cs
- ContextBase.cs
- TextAction.cs
- SequentialWorkflowRootDesigner.cs
- CheckBoxAutomationPeer.cs
- JoinSymbol.cs
- BuildResult.cs
- DtdParser.cs
- ActionItem.cs
- HtmlElementErrorEventArgs.cs
- UndirectedGraph.cs
- CompiledQueryCacheEntry.cs
- DataSourceControlBuilder.cs
- DiscoveryMessageSequenceCD1.cs
- SiteMapSection.cs
- RecordConverter.cs
- HatchBrush.cs
- PageThemeCodeDomTreeGenerator.cs
- EditingCoordinator.cs
- WebReferencesBuildProvider.cs
- TypedAsyncResult.cs
- UserControlParser.cs
- ReferencedCollectionType.cs
- CompensationDesigner.cs
- Model3DGroup.cs
- OpCodes.cs
- ListItemParagraph.cs
- EventItfInfo.cs
- StoreItemCollection.Loader.cs
- MappingSource.cs
- safesecurityhelperavalon.cs
- SortedDictionary.cs
- ModuleBuilderData.cs
- FeatureManager.cs
- ReadOnlyCollection.cs
- PublishLicense.cs
- ClientTargetCollection.cs
- HttpModuleActionCollection.cs