465 lines
11 KiB
C#
Raw Normal View History

//
// System.Web.UI.WebControls.Parameter
//
// Authors:
// Ben Maurer (bmaurer@users.sourceforge.net)
// Sanjay Gupta (gsanjay@novell.com)
//
// (C) 2003 Ben Maurer
// (C) 2004 Novell, Inc. (http://www.novell.com)
//
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
#if NET_2_0
using System.Collections;
using System.Collections.Specialized;
using System.Text;
using System.Data;
using System.ComponentModel;
namespace System.Web.UI.WebControls {
[DefaultPropertyAttribute ("DefaultValue")]
public class Parameter : ICloneable, IStateManager
{
public Parameter () : base ()
{
}
protected Parameter (Parameter original)
{
if (original == null)
throw new NullReferenceException (".NET emulation");
this.DefaultValue = original.DefaultValue;
this.Direction = original.Direction;
this.ConvertEmptyStringToNull = original.ConvertEmptyStringToNull;
this.Type = original.Type;
this.Name = original.Name;
}
public Parameter (string name)
{
this.Name = name;
}
public Parameter(string name, TypeCode type) : this (name)
{
this.Type = type;
}
public Parameter (string name, TypeCode type, string defaultValue) : this (name, type)
{
this.DefaultValue = defaultValue;
}
public Parameter (string name, DbType dbType) : this (name)
{
this.DbType = dbType;
}
public Parameter (string name, DbType dbType, string defaultValue) : this (name, dbType)
{
this.DefaultValue = defaultValue;
}
public static TypeCode ConvertDbTypeToTypeCode (DbType dbType)
{
switch (dbType) {
case DbType.AnsiString:
case DbType.AnsiStringFixedLength:
case DbType.StringFixedLength:
case DbType.String:
return TypeCode.String;
case DbType.Binary:
case DbType.Guid:
case DbType.Object:
case DbType.Xml:
case DbType.DateTimeOffset:
return TypeCode.Object;
case DbType.Byte:
return TypeCode.Byte;
case DbType.Boolean:
return TypeCode.Boolean;
case DbType.Currency:
case DbType.Decimal:
case DbType.VarNumeric:
return TypeCode.Decimal;
case DbType.Date:
case DbType.DateTime:
case DbType.DateTime2:
case DbType.Time:
return TypeCode.DateTime;
case DbType.Double:
return TypeCode.Double;
case DbType.Int16:
return TypeCode.Int16;
case DbType.Int32:
return TypeCode.Int32;
case DbType.Int64:
return TypeCode.Int64;
case DbType.SByte:
return TypeCode.SByte;
case DbType.Single:
return TypeCode.Single;
case DbType.UInt16:
return TypeCode.UInt16;
case DbType.UInt32:
return TypeCode.UInt32;
case DbType.UInt64:
return TypeCode.UInt64;
default:
return TypeCode.Object;
}
}
public static DbType ConvertTypeCodeToDbType (TypeCode typeCode)
{
switch (typeCode) {
case TypeCode.Empty:
case TypeCode.Object:
case TypeCode.DBNull:
return DbType.Object;
case TypeCode.Boolean:
return DbType.Boolean;
case TypeCode.Char:
return DbType.StringFixedLength;
case TypeCode.SByte:
return DbType.SByte;
case TypeCode.Byte:
return DbType.Byte;
case TypeCode.Int16:
return DbType.Int16;
case TypeCode.UInt16:
return DbType.UInt16;
case TypeCode.Int32:
return DbType.Int32;
case TypeCode.UInt32:
return DbType.UInt32;
case TypeCode.Int64:
return DbType.Int64;
case TypeCode.UInt64:
return DbType.UInt64;
case TypeCode.Single:
return DbType.Single;
case TypeCode.Double:
return DbType.Double;
case TypeCode.Decimal:
return DbType.Decimal;
case TypeCode.DateTime:
return DbType.DateTime;
case TypeCode.String:
return DbType.String;
default:
return DbType.Object;
}
}
public DbType GetDatabaseType ()
{
DbType dt = this.DbType;
if (dt != DbType.Object)
throw new InvalidOperationException ("The DbType property is already set to a value other than DbType.Object.");
return ConvertTypeCodeToDbType (this.Type);
}
protected virtual Parameter Clone ()
{
return new Parameter (this);
}
protected void OnParameterChanged ()
{
if (_owner != null)
_owner.CallOnParameterChanged ();
}
protected virtual void LoadViewState (object savedState)
{
ViewState.LoadViewState (savedState);
}
protected virtual object SaveViewState ()
{
return ViewState.SaveViewState ();
}
protected virtual void TrackViewState ()
{
isTrackingViewState = true;
if (viewState != null)
viewState.TrackViewState ();
}
object ICloneable.Clone ()
{
return this.Clone ();
}
void IStateManager.LoadViewState (object savedState)
{
this.LoadViewState (savedState);
}
object IStateManager.SaveViewState ()
{
return this.SaveViewState ();
}
void IStateManager.TrackViewState ()
{
this.TrackViewState ();
}
bool IStateManager.IsTrackingViewState {
get { return this.IsTrackingViewState; }
}
// MSDN: The ToString method returns the Name property of the Parameter object. If the Parameter object has no name, ToString returns String.Empty.
public override string ToString ()
{
return Name;
}
[WebCategoryAttribute ("Parameter")]
[DefaultValueAttribute (null)]
[WebSysDescriptionAttribute ("Default value to be used in case value is null.")]
public string DefaultValue {
get { return ViewState.GetString ("DefaultValue", null); }
set {
if (DefaultValue != value) {
ViewState ["DefaultValue"] = value;
OnParameterChanged ();
}
}
}
[WebCategoryAttribute ("Parameter")]
[DefaultValueAttribute ("Input")]
[WebSysDescriptionAttribute ("Parameter's direction.")]
public ParameterDirection Direction
{
get { return (ParameterDirection) ViewState.GetInt ("Direction", (int)ParameterDirection.Input); }
set {
if (Direction != value) {
ViewState ["Direction"] = value;
OnParameterChanged ();
}
}
}
[WebCategoryAttribute ("Parameter")]
[DefaultValueAttribute ("")]
[WebSysDescriptionAttribute ("Parameter's name.")]
public string Name
{
get {
string s = ViewState ["Name"] as string;
if (s != null)
return s;
return String.Empty;
}
set {
if (Name != value) {
ViewState ["Name"] = value;
OnParameterChanged ();
}
}
}
[WebCategoryAttribute ("Parameter")]
[DefaultValueAttribute (true)]
[WebSysDescriptionAttribute ("Checks whether an empty string is treated as a null value.")]
public bool ConvertEmptyStringToNull
{
get { return ViewState.GetBool ("ConvertEmptyStringToNull", true); }
set {
if (ConvertEmptyStringToNull != value) {
ViewState["ConvertEmptyStringToNull"] = value;
OnParameterChanged ();
}
}
}
[WebCategoryAttribute ("Parameter")]
[DefaultValueAttribute (DbType.Object)]
[WebSysDescriptionAttribute ("Parameter's DbType.")]
public DbType DbType
{
get {
object o = ViewState ["DbType"];
if (o == null)
return DbType.Object;
return (DbType) o;
}
set {
if (DbType != value) {
ViewState ["DbType"] = value;
OnParameterChanged ();
}
}
}
[DefaultValue (0)]
public int Size {
get { return ViewState.GetInt ("Size", 0); }
set {
if (Size != value) {
ViewState["Size"] = value;
OnParameterChanged ();
}
}
}
[DefaultValueAttribute (TypeCode.Empty)]
[WebCategoryAttribute ("Parameter"),
WebSysDescriptionAttribute("Represents type of the parameter.")]
public TypeCode Type {
get { return (TypeCode) ViewState.GetInt ("Type", (int)TypeCode.Empty); }
set {
if (Type != value) {
ViewState ["Type"] = value;
OnParameterChanged ();
}
}
}
StateBag viewState;
[BrowsableAttribute (false),
DesignerSerializationVisibilityAttribute (DesignerSerializationVisibility.Hidden)]
protected StateBag ViewState {
get {
if (viewState == null) {
viewState = new StateBag ();
if (IsTrackingViewState)
viewState.TrackViewState ();
}
return viewState;
}
}
bool isTrackingViewState = false;
protected bool IsTrackingViewState {
get { return isTrackingViewState; }
}
// MSDN: The default implementation of the Evaluate method is to return
// a null reference (Nothing in Visual Basic) in all cases.
// Classes that derive from the Parameter class override the Evaluate method
// to return an updated parameter value. For example, the ControlParameter object
// returns the value of the control that it is bound to, while
// the QueryStringParameter object retrieves the current name/value pair from
// the HttpRequest object.
#if NET_4_0
protected internal
#else
protected
#endif
virtual object Evaluate (HttpContext context, Control control)
{
return null;
}
internal void UpdateValue (HttpContext context, Control control)
{
object oldValue = ViewState ["ParameterValue"];
object newValue = Evaluate (context, control);
if (!object.Equals (oldValue, newValue)) {
ViewState ["ParameterValue"] = newValue;
OnParameterChanged ();
}
}
internal object GetValue (HttpContext context, Control control)
{
UpdateValue (context, control);
object value = ConvertValue (ViewState ["ParameterValue"]);
if (value == null)
value = ConvertValue (DefaultValue);
return value;
}
internal object ConvertValue (object val)
{
if (val == null) return null;
if (ConvertEmptyStringToNull && val.Equals (string.Empty))
return null;
return Type != TypeCode.Empty ? Convert.ChangeType (val, Type) : val;
}
protected internal virtual void SetDirty()
{
ViewState.SetDirty (true);
}
ParameterCollection _owner;
internal void SetOwnerCollection (ParameterCollection own)
{
_owner = own;
}
}
}
#endif