Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / xsp / System / Web / UI / DataSourceView.cs / 1 / DataSourceView.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI { using System.Collections; using System.ComponentModel; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public abstract class DataSourceView { private static readonly object EventDataSourceViewChanged = new object(); private EventHandlerList _events; private string _name; protected DataSourceView(IDataSource owner, string viewName) { if (owner == null) { throw new ArgumentNullException("owner"); } if (viewName == null) { throw new ArgumentNullException("viewName"); } _name = viewName; DataSourceControl dataSourceControl = owner as DataSourceControl; if (dataSourceControl != null) { dataSourceControl.DataSourceChangedInternal += new EventHandler(OnDataSourceChangedInternal); } else { owner.DataSourceChanged += new EventHandler(OnDataSourceChangedInternal); } } // CanX properties indicate whether the data source allows each // operation, and if so, whether it's appropriate to do so. // For instance, a control may allow Deletion, but if a required Delete // command isn't set, CanDelete should be false, because a Delete // operation would fail. public virtual bool CanDelete { get { return false; } } public virtual bool CanInsert { get { return false; } } public virtual bool CanPage { get { return false; } } public virtual bool CanRetrieveTotalRowCount { get { return false; } } public virtual bool CanSort { get { return false; } } public virtual bool CanUpdate { get { return false; } } ////// Indicates the list of event handler delegates for the view. This property is read-only. /// protected EventHandlerList Events { get { if (_events == null) { _events = new EventHandlerList(); } return _events; } } public string Name { get { return _name; } } public event EventHandler DataSourceViewChanged { add { Events.AddHandler(EventDataSourceViewChanged, value); } remove { Events.RemoveHandler(EventDataSourceViewChanged, value); } } public virtual void Delete(IDictionary keys, IDictionary oldValues, DataSourceViewOperationCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } int affectedRecords = 0; bool performedCallback = false; try { affectedRecords = ExecuteDelete(keys, oldValues); } catch (Exception ex) { performedCallback = true; if (!callback(affectedRecords, ex)) { throw; } } finally { if (!performedCallback) { callback(affectedRecords, null); } } } ////// Performs a delete operation on the specified list. This is only /// supported by a DataSourceControl when CanDelete returns true. /// /// /// The set of name/value pairs used to filter /// the items in the list that should be deleted. /// /// /// The complete set of name/value pairs used to filter /// the items in the list that should be deleted. /// ////// The number of items that were affected by the operation. /// protected virtual int ExecuteDelete(IDictionary keys, IDictionary oldValues) { throw new NotSupportedException(); } ////// Performs an insert operation on the specified list. This is only /// supported by a DataControl when CanInsert is true. /// /// /// The set of name/value pairs to be used to initialize /// a new item in the list. /// ////// The number of items that were affected by the operation. /// protected virtual int ExecuteInsert(IDictionary values) { throw new NotSupportedException(); } ////// protected internal abstract IEnumerable ExecuteSelect(DataSourceSelectArguments arguments); ////// Performs an update operation on the specified list. This is only /// supported by a DataControl when CanUpdate is true. /// /// /// The set of name/value pairs used to filter /// the items in the list that should be updated. /// /// /// The set of name/value pairs to be used to update the /// items in the list. /// /// /// The set of name/value pairs to be used to identify the /// item to be updated. /// ////// The number of items that were affected by the operation. /// protected virtual int ExecuteUpdate(IDictionary keys, IDictionary values, IDictionary oldValues) { throw new NotSupportedException(); } private void OnDataSourceChangedInternal(object sender, EventArgs e) { OnDataSourceViewChanged(e); } protected virtual void OnDataSourceViewChanged(EventArgs e) { EventHandler handler = Events[EventDataSourceViewChanged] as EventHandler; if (handler != null) { handler(this, e); } } public virtual void Insert(IDictionary values, DataSourceViewOperationCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } int affectedRecords = 0; bool performedCallback = false; try { affectedRecords = ExecuteInsert(values); } catch (Exception ex) { performedCallback = true; if (!callback(affectedRecords, ex)) { throw; } } finally { if (!performedCallback) { callback(affectedRecords, null); } } } protected internal virtual void RaiseUnsupportedCapabilityError(DataSourceCapabilities capability) { if (!CanPage && ((capability & DataSourceCapabilities.Page) != 0)) { throw new NotSupportedException(SR.GetString(SR.DataSourceView_NoPaging)); } if (!CanSort && ((capability & DataSourceCapabilities.Sort) != 0)) { throw new NotSupportedException(SR.GetString(SR.DataSourceView_NoSorting)); } if (!CanRetrieveTotalRowCount && ((capability & DataSourceCapabilities.RetrieveTotalRowCount) != 0)) { throw new NotSupportedException(SR.GetString(SR.DataSourceView_NoRowCount)); } } public virtual void Select(DataSourceSelectArguments arguments, DataSourceViewSelectCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } callback(ExecuteSelect(arguments)); } public virtual void Update(IDictionary keys, IDictionary values, IDictionary oldValues, DataSourceViewOperationCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } int affectedRecords = 0; bool performedCallback = false; try { affectedRecords = ExecuteUpdate(keys, values, oldValues); } catch (Exception ex) { performedCallback = true; if (!callback(affectedRecords, ex)) { throw; } } finally { if (!performedCallback) { callback(affectedRecords, null); } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI { using System.Collections; using System.ComponentModel; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public abstract class DataSourceView { private static readonly object EventDataSourceViewChanged = new object(); private EventHandlerList _events; private string _name; protected DataSourceView(IDataSource owner, string viewName) { if (owner == null) { throw new ArgumentNullException("owner"); } if (viewName == null) { throw new ArgumentNullException("viewName"); } _name = viewName; DataSourceControl dataSourceControl = owner as DataSourceControl; if (dataSourceControl != null) { dataSourceControl.DataSourceChangedInternal += new EventHandler(OnDataSourceChangedInternal); } else { owner.DataSourceChanged += new EventHandler(OnDataSourceChangedInternal); } } // CanX properties indicate whether the data source allows each // operation, and if so, whether it's appropriate to do so. // For instance, a control may allow Deletion, but if a required Delete // command isn't set, CanDelete should be false, because a Delete // operation would fail. public virtual bool CanDelete { get { return false; } } public virtual bool CanInsert { get { return false; } } public virtual bool CanPage { get { return false; } } public virtual bool CanRetrieveTotalRowCount { get { return false; } } public virtual bool CanSort { get { return false; } } public virtual bool CanUpdate { get { return false; } } ////// Indicates the list of event handler delegates for the view. This property is read-only. /// protected EventHandlerList Events { get { if (_events == null) { _events = new EventHandlerList(); } return _events; } } public string Name { get { return _name; } } public event EventHandler DataSourceViewChanged { add { Events.AddHandler(EventDataSourceViewChanged, value); } remove { Events.RemoveHandler(EventDataSourceViewChanged, value); } } public virtual void Delete(IDictionary keys, IDictionary oldValues, DataSourceViewOperationCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } int affectedRecords = 0; bool performedCallback = false; try { affectedRecords = ExecuteDelete(keys, oldValues); } catch (Exception ex) { performedCallback = true; if (!callback(affectedRecords, ex)) { throw; } } finally { if (!performedCallback) { callback(affectedRecords, null); } } } ////// Performs a delete operation on the specified list. This is only /// supported by a DataSourceControl when CanDelete returns true. /// /// /// The set of name/value pairs used to filter /// the items in the list that should be deleted. /// /// /// The complete set of name/value pairs used to filter /// the items in the list that should be deleted. /// ////// The number of items that were affected by the operation. /// protected virtual int ExecuteDelete(IDictionary keys, IDictionary oldValues) { throw new NotSupportedException(); } ////// Performs an insert operation on the specified list. This is only /// supported by a DataControl when CanInsert is true. /// /// /// The set of name/value pairs to be used to initialize /// a new item in the list. /// ////// The number of items that were affected by the operation. /// protected virtual int ExecuteInsert(IDictionary values) { throw new NotSupportedException(); } ////// protected internal abstract IEnumerable ExecuteSelect(DataSourceSelectArguments arguments); ////// Performs an update operation on the specified list. This is only /// supported by a DataControl when CanUpdate is true. /// /// /// The set of name/value pairs used to filter /// the items in the list that should be updated. /// /// /// The set of name/value pairs to be used to update the /// items in the list. /// /// /// The set of name/value pairs to be used to identify the /// item to be updated. /// ////// The number of items that were affected by the operation. /// protected virtual int ExecuteUpdate(IDictionary keys, IDictionary values, IDictionary oldValues) { throw new NotSupportedException(); } private void OnDataSourceChangedInternal(object sender, EventArgs e) { OnDataSourceViewChanged(e); } protected virtual void OnDataSourceViewChanged(EventArgs e) { EventHandler handler = Events[EventDataSourceViewChanged] as EventHandler; if (handler != null) { handler(this, e); } } public virtual void Insert(IDictionary values, DataSourceViewOperationCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } int affectedRecords = 0; bool performedCallback = false; try { affectedRecords = ExecuteInsert(values); } catch (Exception ex) { performedCallback = true; if (!callback(affectedRecords, ex)) { throw; } } finally { if (!performedCallback) { callback(affectedRecords, null); } } } protected internal virtual void RaiseUnsupportedCapabilityError(DataSourceCapabilities capability) { if (!CanPage && ((capability & DataSourceCapabilities.Page) != 0)) { throw new NotSupportedException(SR.GetString(SR.DataSourceView_NoPaging)); } if (!CanSort && ((capability & DataSourceCapabilities.Sort) != 0)) { throw new NotSupportedException(SR.GetString(SR.DataSourceView_NoSorting)); } if (!CanRetrieveTotalRowCount && ((capability & DataSourceCapabilities.RetrieveTotalRowCount) != 0)) { throw new NotSupportedException(SR.GetString(SR.DataSourceView_NoRowCount)); } } public virtual void Select(DataSourceSelectArguments arguments, DataSourceViewSelectCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } callback(ExecuteSelect(arguments)); } public virtual void Update(IDictionary keys, IDictionary values, IDictionary oldValues, DataSourceViewOperationCallback callback) { if (callback == null) { throw new ArgumentNullException("callback"); } int affectedRecords = 0; bool performedCallback = false; try { affectedRecords = ExecuteUpdate(keys, values, oldValues); } catch (Exception ex) { performedCallback = true; if (!callback(affectedRecords, ex)) { throw; } } finally { if (!performedCallback) { callback(affectedRecords, null); } } } } } // 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
- Stream.cs
- EUCJPEncoding.cs
- EventProviderTraceListener.cs
- SqlTrackingService.cs
- XpsFixedDocumentReaderWriter.cs
- SmiMetaDataProperty.cs
- HtmlTextBoxAdapter.cs
- InvalidDataContractException.cs
- CreateUserErrorEventArgs.cs
- __Filters.cs
- CollectionViewSource.cs
- ProcessHostConfigUtils.cs
- GridViewCommandEventArgs.cs
- UserNamePasswordValidationMode.cs
- ReturnType.cs
- SqlDataSourceParameterParser.cs
- TimeoutValidationAttribute.cs
- ContentFileHelper.cs
- SqlPersonalizationProvider.cs
- RelatedEnd.cs
- MapPathBasedVirtualPathProvider.cs
- ConnectionPoint.cs
- GridViewRow.cs
- Matrix3DValueSerializer.cs
- SoundPlayerAction.cs
- DocumentationServerProtocol.cs
- FactoryRecord.cs
- CheckoutException.cs
- PackWebRequestFactory.cs
- SafeNativeMethods.cs
- MaskDesignerDialog.cs
- ExceptionUtility.cs
- formatstringdialog.cs
- BrowserCapabilitiesCompiler.cs
- ContextProperty.cs
- AuthenticationConfig.cs
- RandomDelaySendsAsyncResult.cs
- TabItemWrapperAutomationPeer.cs
- CardSpaceSelector.cs
- IxmlLineInfo.cs
- UnsignedPublishLicense.cs
- TransformerTypeCollection.cs
- CatchBlock.cs
- MulticastDelegate.cs
- MemberAccessException.cs
- TextServicesDisplayAttributePropertyRanges.cs
- TextWriter.cs
- VirtualDirectoryMapping.cs
- SerializationStore.cs
- ListViewTableRow.cs
- TreePrinter.cs
- ClientTargetSection.cs
- Freezable.cs
- Comparer.cs
- XmlCDATASection.cs
- SafeArchiveContext.cs
- PrinterSettings.cs
- InertiaRotationBehavior.cs
- EntityDataReader.cs
- PropertyPathConverter.cs
- XamlPoint3DCollectionSerializer.cs
- TableSectionStyle.cs
- HttpServerUtilityBase.cs
- MaterialGroup.cs
- DownloadProgressEventArgs.cs
- AsyncPostBackTrigger.cs
- HMACSHA1.cs
- FieldBuilder.cs
- VarRemapper.cs
- VisualProxy.cs
- WebHttpSecurity.cs
- DynamicDocumentPaginator.cs
- ImageList.cs
- SequentialOutput.cs
- EntitySqlQueryCacheKey.cs
- SafeNativeMethods.cs
- MemoryMappedFileSecurity.cs
- ChineseLunisolarCalendar.cs
- Timer.cs
- HebrewNumber.cs
- SqlDataSourceCommandEventArgs.cs
- RegexMatch.cs
- Profiler.cs
- DesignerVerb.cs
- ToolStripPanel.cs
- FillRuleValidation.cs
- EdmRelationshipRoleAttribute.cs
- ContainerParaClient.cs
- AuditLog.cs
- InputLanguageProfileNotifySink.cs
- ConfigurationSchemaErrors.cs
- HttpResponse.cs
- ButtonChrome.cs
- MsmqIntegrationInputChannel.cs
- MachineSettingsSection.cs
- ImmComposition.cs
- Exceptions.cs
- StrokeNode.cs
- HttpCookieCollection.cs
- DependencyProperty.cs