projects
/
mono.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Drop this one too
[mono.git]
/
mcs
/
class
/
Mono.Data.SqliteClient
/
Mono.Data.SqliteClient
/
SqliteParameter.cs
diff --git
a/mcs/class/Mono.Data.SqliteClient/Mono.Data.SqliteClient/SqliteParameter.cs
b/mcs/class/Mono.Data.SqliteClient/Mono.Data.SqliteClient/SqliteParameter.cs
index 2f3fe13de877e0f09332454324fc52e14b2f4073..b0dca170f7e2115f18802e2f566183ff96979072 100644
(file)
--- a/
mcs/class/Mono.Data.SqliteClient/Mono.Data.SqliteClient/SqliteParameter.cs
+++ b/
mcs/class/Mono.Data.SqliteClient/Mono.Data.SqliteClient/SqliteParameter.cs
@@
-31,16
+31,26
@@
using System;
using System.Data;
using System;
using System.Data;
+#if NET_2_0
+using System.Data.Common;
+#endif
namespace Mono.Data.SqliteClient
{
namespace Mono.Data.SqliteClient
{
- public class SqliteParameter : IDbDataParameter
+ public class SqliteParameter :
+#if NET_2_0
+ DbParameter
+#else
+ IDbDataParameter
+#endif
{
#region Fields
private string name;
private DbType type;
{
#region Fields
private string name;
private DbType type;
+ private DbType originalType;
+ private bool typeSet;
private string source_column;
private ParameterDirection direction;
private DataRowVersion row_version;
private string source_column;
private ParameterDirection direction;
private DataRowVersion row_version;
@@
-48,6
+58,8
@@
namespace Mono.Data.SqliteClient
private byte precision;
private byte scale;
private int size;
private byte precision;
private byte scale;
private int size;
+ private bool isNullable;
+ private bool sourceColumnNullMapping;
#endregion
#endregion
@@
-57,28
+69,31
@@
namespace Mono.Data.SqliteClient
{
type = DbType.String;
direction = ParameterDirection.Input;
{
type = DbType.String;
direction = ParameterDirection.Input;
+ isNullable = true;
}
}
- public SqliteParameter (string name
_in, DbType type_in
)
+ public SqliteParameter (string name
, DbType type
)
{
{
- name = name_in;
- type = type_in;
+ this.name = name;
+ this.type = type;
+ isNullable = true;
}
}
- public SqliteParameter (string name
_in, object param_value_in
)
+ public SqliteParameter (string name
, object value
)
{
{
-
name = name_in
;
+
this.name = name
;
type = DbType.String;
type = DbType.String;
- param_value =
param_value_in
;
+ param_value =
value
;
direction = ParameterDirection.Input;
direction = ParameterDirection.Input;
+ isNullable = true;
}
}
- public SqliteParameter (string name
_in, DbType type_in, int size_in) : this (name_in, type_in
)
+ public SqliteParameter (string name
, DbType type, int size) : this (name, type
)
{
{
-
size = size_in
;
+
this.size = size
;
}
}
- public SqliteParameter (string name
_in, DbType type_in, int size, string src_column) : this (name_in ,type_in
)
+ public SqliteParameter (string name
, DbType type, int size, string src_column) : this (name ,type, size
)
{
source_column = src_column;
}
{
source_column = src_column;
}
@@
-87,25
+102,48
@@
namespace Mono.Data.SqliteClient
#region Properties
#region Properties
+#if NET_2_0
+ override
+#endif
public DbType DbType {
get { return type; }
public DbType DbType {
get { return type; }
- set { type = value; }
+ set {
+ if (!typeSet) {
+ originalType = type;
+ typeSet = true;
+ }
+ type = value;
+ if (!typeSet)
+ originalType = type;
+ }
}
}
-
+
+#if NET_2_0
+ override
+#endif
public ParameterDirection Direction {
get { return direction; }
set { direction = value; }
}
public ParameterDirection Direction {
get { return direction; }
set { direction = value; }
}
-
+
+#if NET_2_0
+ override
+#endif
public bool IsNullable {
public bool IsNullable {
- get { return true; }
+ get { return isNullable; }
+#if NET_2_0
+ set { isNullable = value; }
+#endif
}
}
-
+
+#if NET_2_0
+ override
+#endif
public string ParameterName {
get { return name; }
set { name = value; }
}
public string ParameterName {
get { return name; }
set { name = value; }
}
-
+
public byte Precision {
get { return precision; }
set { precision = value; }
public byte Precision {
get { return precision; }
set { precision = value; }
@@
-115,22
+153,41
@@
namespace Mono.Data.SqliteClient
get { return scale; }
set { scale = value; }
}
get { return scale; }
set { scale = value; }
}
-
+
+#if NET_2_0
+ override
+#endif
public int Size {
get { return size; }
set { size = value; }
}
public int Size {
get { return size; }
set { size = value; }
}
+#if NET_2_0
+ override
+#endif
public string SourceColumn {
get { return source_column; }
set { source_column = value; }
}
public string SourceColumn {
get { return source_column; }
set { source_column = value; }
}
-
+
+#if NET_2_0
+ public override bool SourceColumnNullMapping {
+ get { return sourceColumnNullMapping; }
+ set { sourceColumnNullMapping = value; }
+ }
+#endif
+
+#if NET_2_0
+ override
+#endif
public DataRowVersion SourceVersion {
get { return row_version; }
set { row_version = value; }
}
public DataRowVersion SourceVersion {
get { return row_version; }
set { row_version = value; }
}
+#if NET_2_0
+ override
+#endif
public object Value {
get { return param_value; }
set { param_value = value; }
public object Value {
get { return param_value; }
set { param_value = value; }
@@
-138,5
+195,13
@@
namespace Mono.Data.SqliteClient
#endregion
#endregion
+ #region methods
+#if NET_2_0
+ public override void ResetDbType ()
+ {
+ type = originalType;
+ }
+#endif
+ #endregion
}
}
}
}