/******************************************************** * ADO.NET 2.0 Data Provider for SQLite Version 3.X * Written by Robert Simpson (robert@blackcastlesoft.com) * * Released to the public domain, use at your own risk! ********************************************************/ namespace Mono.Data.Sqlite { using System; using System.Data; using System.Data.Common; using System.ComponentModel; /// /// SQLite implementation of DbDataAdapter. /// #if !PLATFORM_COMPACTFRAMEWORK [DefaultEvent("RowUpdated")] [ToolboxItem("SQLite.Designer.SqliteDataAdapterToolboxItem, SQLite.Designer, Version=1.0.36.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139")] [Designer("Microsoft.VSDesigner.Data.VS.SqlDataAdapterDesigner, Microsoft.VSDesigner, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")] #endif public sealed class SqliteDataAdapter : DbDataAdapter { private static object _updatingEventPH = new object(); private static object _updatedEventPH = new object(); /// /// This class is just a shell around the DbDataAdapter. Nothing from DbDataAdapter is overridden here, just a few constructors are defined. /// /// /// Default constructor. /// public SqliteDataAdapter() { } /// /// Constructs a data adapter using the specified select command. /// /// The select command to associate with the adapter. public SqliteDataAdapter(SqliteCommand cmd) { SelectCommand = cmd; } /// /// Constructs a data adapter with the supplied select command text and associated with the specified connection. /// /// The select command text to associate with the data adapter. /// The connection to associate with the select command. public SqliteDataAdapter(string commandText, SqliteConnection connection) { SelectCommand = new SqliteCommand(commandText, connection); } /// /// Constructs a data adapter with the specified select command text, and using the specified database connection string. /// /// The select command text to use to construct a select command. /// A connection string suitable for passing to a new SqliteConnection, which is associated with the select command. public SqliteDataAdapter(string commandText, string connectionString) { SqliteConnection cnn = new SqliteConnection(connectionString); SelectCommand = new SqliteCommand(commandText, cnn); } /// /// Row updating event handler /// public event EventHandler RowUpdating { add { #if !PLATFORM_COMPACTFRAMEWORK EventHandler previous = (EventHandler)base.Events[_updatingEventPH]; if ((previous != null) && (value.Target is DbCommandBuilder)) { EventHandler handler = (EventHandler)FindBuilder(previous); if (handler != null) { base.Events.RemoveHandler(_updatingEventPH, handler); } } #endif base.Events.AddHandler(_updatingEventPH, value); } remove { base.Events.RemoveHandler(_updatingEventPH, value); } } #if !PLATFORM_COMPACTFRAMEWORK internal static Delegate FindBuilder(MulticastDelegate mcd) { if (mcd != null) { Delegate[] invocationList = mcd.GetInvocationList(); for (int i = 0; i < invocationList.Length; i++) { if (invocationList[i].Target is DbCommandBuilder) { return invocationList[i]; } } } return null; } #endif /// /// Row updated event handler /// public event EventHandler RowUpdated { add { base.Events.AddHandler(_updatedEventPH, value); } remove { base.Events.RemoveHandler(_updatedEventPH, value); } } /// /// Raised by the underlying DbDataAdapter when a row is being updated /// /// The event's specifics protected override void OnRowUpdating(RowUpdatingEventArgs value) { EventHandler handler = base.Events[_updatingEventPH] as EventHandler; if (handler != null) handler(this, value); } /// /// Raised by DbDataAdapter after a row is updated /// /// The event's specifics protected override void OnRowUpdated(RowUpdatedEventArgs value) { EventHandler handler = base.Events[_updatedEventPH] as EventHandler; if (handler != null) handler(this, value); } /// /// Gets/sets the select command for this DataAdapter /// #if !PLATFORM_COMPACTFRAMEWORK [DefaultValue((string)null), Editor("Microsoft.VSDesigner.Data.Design.DBCommandEditor, Microsoft.VSDesigner, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")] #endif public new SqliteCommand SelectCommand { get { return (SqliteCommand)base.SelectCommand; } set { base.SelectCommand = value; } } /// /// Gets/sets the insert command for this DataAdapter /// #if !PLATFORM_COMPACTFRAMEWORK [DefaultValue((string)null), Editor("Microsoft.VSDesigner.Data.Design.DBCommandEditor, Microsoft.VSDesigner, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")] #endif public new SqliteCommand InsertCommand { get { return (SqliteCommand)base.InsertCommand; } set { base.InsertCommand = value; } } /// /// Gets/sets the update command for this DataAdapter /// #if !PLATFORM_COMPACTFRAMEWORK [DefaultValue((string)null), Editor("Microsoft.VSDesigner.Data.Design.DBCommandEditor, Microsoft.VSDesigner, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")] #endif public new SqliteCommand UpdateCommand { get { return (SqliteCommand)base.UpdateCommand; } set { base.UpdateCommand = value; } } /// /// Gets/sets the delete command for this DataAdapter /// #if !PLATFORM_COMPACTFRAMEWORK [DefaultValue((string)null), Editor("Microsoft.VSDesigner.Data.Design.DBCommandEditor, Microsoft.VSDesigner, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")] #endif public new SqliteCommand DeleteCommand { get { return (SqliteCommand)base.DeleteCommand; } set { base.DeleteCommand = value; } } } }