2009-01-23 Marek Habersack <mhabersack@novell.com>
[mono.git] / mcs / class / System.Web / System.Web.UI / DataSourceView.cs
index 0b59c6fc5e707db784e39c26316e111a6c2ec72f..23bf81b24ae6c2b91b3e398ad9705c8f2ec5b62a 100644 (file)
@@ -39,13 +39,21 @@ using System.ComponentModel;
 namespace System.Web.UI {
        public abstract class DataSourceView
        {
-               IDataSource dataSourceOwner;
+               //IDataSource dataSourceOwner;
                string viewName = String.Empty;
 
                protected DataSourceView (IDataSource owner, string viewName)
                {
-                       this.dataSourceOwner = owner;
+                       if (owner == null)
+                               throw new ArgumentNullException ("owner");
+
+                       //this.dataSourceOwner = owner;
                        this.viewName = viewName;
+                       owner.DataSourceChanged += new EventHandler (OnDataSourceChanged);
+               }
+
+               void OnDataSourceChanged (object sender, EventArgs e) {
+                       OnDataSourceViewChanged (EventArgs.Empty);
                }
 
                public virtual void Delete (IDictionary keys, IDictionary values,
@@ -54,12 +62,12 @@ namespace System.Web.UI {
                        if (callBack == null)
                                throw new ArgumentNullException ("callBack");
 
-                       int rowAffected = 0;
+                       int rowAffected;
                        try {
                                rowAffected = ExecuteDelete (keys, values);
                        }
                        catch (Exception e) {
-                               if (!callBack (rowAffected, e))
+                               if (!callBack (0, e))
                                        throw;
                                return;
                        }
@@ -91,16 +99,16 @@ namespace System.Web.UI {
                        if (callBack == null)
                                throw new ArgumentNullException("callBack");
 
-                       int rowAffected = 0;
-                       Exception passOn = null;
+                       int rowAffected;
                        try {
                                rowAffected = ExecuteInsert (values);
                        } catch (Exception e) {
-                               passOn = e;
+                               if (!callBack (0, e))
+                                       throw;
+                               return;
                        }
 
-                       if (!callBack (rowAffected, passOn) && passOn != null)
-                               throw passOn;
+                       callBack (rowAffected, null);
                }
 
                protected virtual void OnDataSourceViewChanged (EventArgs eventArgs)
@@ -148,16 +156,16 @@ namespace System.Web.UI {
                        if (callBack == null)
                                throw new ArgumentNullException ("callBack");
 
-                       int rowAffected = 0;
-                       Exception passOn = null;
+                       int rowAffected;
                        try {
                                rowAffected = ExecuteUpdate (keys, values, oldValues);
                        } catch (Exception e) {
-                               passOn = e;
+                               if (!callBack (0, e))
+                                       throw;
+                               return;
                        }
 
-                       if (!callBack (rowAffected, passOn) && passOn != null)
-                               throw passOn;
+                       callBack (rowAffected, null);
                } 
                
                public virtual bool CanDelete { get { return false; } }