/********************************************************
* 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; }
}
}
}