Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGaurav Vaish <gvaish@mono-cvs.ximian.com>2002-10-29 07:50:44 +0300
committerGaurav Vaish <gvaish@mono-cvs.ximian.com>2002-10-29 07:50:44 +0300
commitdca003cca9a8f6a7eb8dfda10d96a85322887904 (patch)
treed85e2ef1eb9c52577a4b6f34ef25a0d483454031 /mcs/class/System.Web/System.Web.UI.WebControls/BaseCompareValidator.cs
parent901f90fdb3d101ad66784b853aa501ab4dd32434 (diff)
2002-10-28 Gaurav Vaish <gvaish_mono@lycos.com>
* BaseCompareValidator.cs - Fixed operator bug in Compare(string, string, ...) * CompareValidator.cs - EvaluateIsValid() : Implemented. svn path=/trunk/mcs/; revision=8651
Diffstat (limited to 'mcs/class/System.Web/System.Web.UI.WebControls/BaseCompareValidator.cs')
-rwxr-xr-xmcs/class/System.Web/System.Web.UI.WebControls/BaseCompareValidator.cs622
1 files changed, 311 insertions, 311 deletions
diff --git a/mcs/class/System.Web/System.Web.UI.WebControls/BaseCompareValidator.cs b/mcs/class/System.Web/System.Web.UI.WebControls/BaseCompareValidator.cs
index a918280d3e9..5509eca53e8 100755
--- a/mcs/class/System.Web/System.Web.UI.WebControls/BaseCompareValidator.cs
+++ b/mcs/class/System.Web/System.Web.UI.WebControls/BaseCompareValidator.cs
@@ -1,311 +1,311 @@
-/**
- * Namespace: System.Web.UI.WebControls
- * Class: BaseCompareValidator
- *
- * Author: Gaurav Vaish
- * Maintainer: gvaish@iitk.ac.in
- * Implementation: yes
- * Contact: <gvaish@iitk.ac.in>
- * Status: 100%
- *
- * (C) Gaurav Vaish (2001)
- */
-
-using System;
-using System.Collections;
-using System.Globalization;
-using System.Text;
-using System.Text.RegularExpressions;
-using System.Web;
-using System.Web.UI;
-using System.ComponentModel;
-
-namespace System.Web.UI.WebControls
-{
- public abstract class BaseCompareValidator: BaseValidator
- {
- protected BaseCompareValidator(): base()
- {
- }
-
- public static bool CanConvert(string text, ValidationDataType type)
- {
- object o = null;
- return Convert(text, type, out o);
- }
-
- [DefaultValue(ValidationDataType.String)]
- [WebCategory("Behaviour")]
- [WebSysDescription("RangeValidator_Type")]
- public ValidationDataType Type
- {
- get
- {
- object o = ViewState["Type"];
- if(o!=null)
- return (ValidationDataType)o;
- return ValidationDataType.String;
- }
- set
- {
- if(!System.Enum.IsDefined(typeof(ValidationDataType), value))
- throw new ArgumentException();
- ViewState["Type"] = value;
- }
- }
-
- protected static int CutoffYear
- {
- get
- {
- return DateTimeFormatInfo.CurrentInfo.Calendar.TwoDigitYearMax;
- }
- }
-
- protected static int GetFullYear(int shortYear)
- {
- int century = DateTime.Today.Year - (DateTime.Today.Year % 100);
- if(century < CutoffYear)
- {
- return (shortYear + century);
- }
- return (shortYear + century - 100);
- }
-
- protected override void AddAttributesToRender(HtmlTextWriter writer)
- {
- base.AddAttributesToRender(writer);
- if(RenderUplevel)
- {
- writer.AddAttribute("type", PropertyConverter.EnumToString(typeof(ValidationDataType), Type));
- NumberFormatInfo currInfo = NumberFormatInfo.CurrentInfo;
- if(Type == ValidationDataType.Double)
- {
- writer.AddAttribute("decimalchar", currInfo.NumberDecimalSeparator);
- return;
- }
- if(Type == ValidationDataType.Currency)
- {
- writer.AddAttribute("decimalchar", currInfo.CurrencyDecimalSeparator);
- string grpSep = currInfo.CurrencyGroupSeparator;
- if(grpSep[0] == 0xA0)
- {
- grpSep = " ";
- }
- writer.AddAttribute("groupchar", grpSep);
- writer.AddAttribute("digits", currInfo.CurrencyDecimalDigits.ToString(NumberFormatInfo.InvariantInfo));
- return;
- }
- if(Type == ValidationDataType.Date)
- {
- writer.AddAttribute("cutoffyear", CutoffYear.ToString());
- writer.AddAttribute("century", ( DateTime.Today.Year - (DateTime.Today.Year % 100) ).ToString());
- return;
- }
- }
- }
-
- protected override bool DetermineRenderUplevel()
- {
- if(Type == ValidationDataType.Date && DateTimeFormatInfo.CurrentInfo.Calendar.GetType() != typeof(GregorianCalendar))
- {
- return false;
- }
- return base.DetermineRenderUplevel();
- }
-
- /// <summary>
- /// Undocumented
- /// </summary>
- protected static bool Compare(string leftText, string rightText, ValidationCompareOperator op, ValidationDataType type)
- {
- object left = null, right = null;
- if(!Convert(leftText, type, out left))
- {
- return false;
- }
- if(op == ValidationCompareOperator.DataTypeCheck)
- {
- return true;
- }
- if(!Convert(rightText, type, out right))
- {
- return true;
- }
- int compareResult = 0;
- switch(type)
- {
- case ValidationDataType.String:
- compareResult = ((String)left).CompareTo(right);
- break;
- case ValidationDataType.Integer:
- compareResult = ((int)left).CompareTo(right);
- break;
- case ValidationDataType.Double:
- compareResult = ((Double)left).CompareTo(right);
- break;
- case ValidationDataType.Date:
- compareResult = ((DateTime)left).CompareTo(right);
- break;
- case ValidationDataType.Currency:
- compareResult = ((Decimal)left).CompareTo(right);
- break;
- }
- switch(op)
- {
- case ValidationCompareOperator.Equal:
- return (compareResult == 0);
- case ValidationCompareOperator.NotEqual:
- return (compareResult != 0);
- case ValidationCompareOperator.GreaterThan:
- return (compareResult > 0);
- case ValidationCompareOperator.GreaterThanEqual:
- return (compareResult >= 0);
- case ValidationCompareOperator.LessThan:
- return (compareResult < 0);
- case ValidationCompareOperator.LessThanEqual:
- return (compareResult == 0);
- }
- return false;
- }
-
- /// <summary>
- /// Undocumented
- /// </summary>
- protected static string GetDateElementOrder()
- {
- string pattern = DateTimeFormatInfo.CurrentInfo.ShortDatePattern;
-
- //TODO: What are the various possibilities?
- // I can think of only y*/M*/d*, d*/M*/y*, M*/d*/y*
- if(pattern.IndexOf('y') < pattern.IndexOf('M'))
- {
- return "ymd";
- }
- if(pattern.IndexOf('M') < pattern.IndexOf('d'))
- {
- return "mdy";
- }
- return "dmy";
- }
-
- /// <summary>
- /// Undocumented
- /// </summary>
- protected static bool Convert(string text, ValidationDataType type, out object convertedValue)
- {
- convertedValue = null;
- try
- {
- switch(type)
- {
- case ValidationDataType.String: convertedValue = text;
- break;
- case ValidationDataType.Integer: convertedValue = Int32.Parse(text, CultureInfo.InvariantCulture);
- break;
- case ValidationDataType.Double:
- Match matchDouble = Regex.Match(text, @"^\s*([-\+])?(\d+)?(\"
- + NumberFormatInfo.CurrentInfo.NumberDecimalSeparator
- + @"(\d+))?\s*$");
- if(matchDouble.Success)
- {
- string sign = (matchDouble.Groups[1].Success ? matchDouble.Groups[1].Value : "+");
- string decPart = (matchDouble.Groups[2].Success ? matchDouble.Groups[2].Value : "0");
- string mantissa = (matchDouble.Groups[4].Success ? matchDouble.Groups[4].Value : "0");
- convertedValue = Double.Parse(sign + decPart + "." + mantissa, CultureInfo.InvariantCulture);
- }
- break;
- case ValidationDataType.Date:
- if(DateTimeFormatInfo.CurrentInfo.Calendar.GetType() != typeof(GregorianCalendar))
- {
- convertedValue = DateTime.Parse(text);
- break;
- }
- string order = GetDateElementOrder();
- int date = 0, mth = 0, year = 0;
- Match matchDate = Regex.Match(text, @"^\s*((\d{4})|(\d{2}))([\.\/-])(\d{1,2})\4(\d{1,2})\s*$");
- if(matchDate.Success && order == "ymd")
- {
- date = Int32.Parse(matchDate.Groups[6].Value, CultureInfo.InvariantCulture);
- mth = Int32.Parse(matchDate.Groups[5].Value, CultureInfo.InvariantCulture);
- year = Int32.Parse((matchDate.Groups[2].Success ? matchDate.Groups[2].Value : matchDate.Groups[3].Value), CultureInfo.InvariantCulture);
- } else
- {
- matchDate = Regex.Match(text, @"^\s*(\d{1,2})([\.\/-])(\d{1,2})\2((\d{4}|\d{2}))\s*$");
- if(matchDate.Success)
- {
- if(order == "dmy")
- {
- date = Int32.Parse(matchDate.Groups[1].Value, CultureInfo.InvariantCulture);
- mth = Int32.Parse(matchDate.Groups[3].Value, CultureInfo.InvariantCulture);
- year = Int32.Parse((matchDate.Groups[5].Success ? matchDate.Groups[5].Value : matchDate.Groups[6].Value), CultureInfo.InvariantCulture);
- }
- if(order == "mdy")
- {
- date = Int32.Parse(matchDate.Groups[3].Value, CultureInfo.InvariantCulture);
- mth = Int32.Parse(matchDate.Groups[1].Value, CultureInfo.InvariantCulture);
- year = Int32.Parse((matchDate.Groups[5].Success ? matchDate.Groups[5].Value : matchDate.Groups[6].Value), CultureInfo.InvariantCulture);
- }
- }
- }
- year = (year < 100 ? GetFullYear(year) : year);
- if(matchDate.Success && date!=0 && mth!=0 && year!=0)
- {
- convertedValue = new DateTime(year, mth, date);
- }
- break;
- case ValidationDataType.Currency:
- string decSep = NumberFormatInfo.CurrentInfo.CurrencyDecimalSeparator;
- string grpSep = NumberFormatInfo.CurrentInfo.CurrencyGroupSeparator;
- int decDig = NumberFormatInfo.CurrentInfo.CurrencyDecimalDigits;
- if(grpSep[0] == 0xA0)
- {
- grpSep = " ";
- }
- string[] patternArray = new string[5];
- patternArray[0] = "^\\s*([-\\+])?(((\\d+)\\";
- patternArray[1] = grpSep;
- patternArray[2] = @")*)(\d+)";
- if(decDig > 0)
- {
- string[] decPattern = new string[5];
- decPattern[0] = "(\\";
- decPattern[1] = decSep;
- decPattern[2] = @"(\d{1,";
- decPattern[3] = decDig.ToString(NumberFormatInfo.InvariantInfo);
- decPattern[4] = @"}))";
- patternArray[3] = String.Concat(decPattern);
-
- } else
- {
- patternArray[3] = String.Empty;
- }
- patternArray[4] = @"?\s*$";
- Match matchCurrency = Regex.Match(text, String.Concat(patternArray));
- if(matchCurrency.Success)
- {
- StringBuilder sb = new StringBuilder();
- sb.Append(matchCurrency.Groups[1]);
- CaptureCollection cc = matchCurrency.Groups[4].Captures;
- foreach(IEnumerable current in cc)
- {
- sb.Append((Capture)current);
- }
- sb.Append(matchCurrency.Groups[5]);
- if(decDig > 0)
- {
- sb.Append(".");
- sb.Append(matchCurrency.Groups[7]);
- }
- convertedValue = Decimal.Parse(sb.ToString(), CultureInfo.InvariantCulture);
- }
- break;
- }
- } catch(Exception e)
- {
- convertedValue = null;
- }
- return (convertedValue != null);
- }
- }
-}
+/**
+ * Namespace: System.Web.UI.WebControls
+ * Class: BaseCompareValidator
+ *
+ * Author: Gaurav Vaish
+ * Maintainer: gvaish@iitk.ac.in
+ * Implementation: yes
+ * Contact: <gvaish@iitk.ac.in>
+ * Status: 100%
+ *
+ * (C) Gaurav Vaish (2001)
+ */
+
+using System;
+using System.Collections;
+using System.Globalization;
+using System.Text;
+using System.Text.RegularExpressions;
+using System.Web;
+using System.Web.UI;
+using System.ComponentModel;
+
+namespace System.Web.UI.WebControls
+{
+ public abstract class BaseCompareValidator: BaseValidator
+ {
+ protected BaseCompareValidator(): base()
+ {
+ }
+
+ public static bool CanConvert(string text, ValidationDataType type)
+ {
+ object o = null;
+ return Convert(text, type, out o);
+ }
+
+ [DefaultValue(ValidationDataType.String)]
+ [WebCategory("Behaviour")]
+ [WebSysDescription("RangeValidator_Type")]
+ public ValidationDataType Type
+ {
+ get
+ {
+ object o = ViewState["Type"];
+ if(o!=null)
+ return (ValidationDataType)o;
+ return ValidationDataType.String;
+ }
+ set
+ {
+ if(!System.Enum.IsDefined(typeof(ValidationDataType), value))
+ throw new ArgumentException();
+ ViewState["Type"] = value;
+ }
+ }
+
+ protected static int CutoffYear
+ {
+ get
+ {
+ return DateTimeFormatInfo.CurrentInfo.Calendar.TwoDigitYearMax;
+ }
+ }
+
+ protected static int GetFullYear(int shortYear)
+ {
+ int century = DateTime.Today.Year - (DateTime.Today.Year % 100);
+ if(century < CutoffYear)
+ {
+ return (shortYear + century);
+ }
+ return (shortYear + century - 100);
+ }
+
+ protected override void AddAttributesToRender(HtmlTextWriter writer)
+ {
+ base.AddAttributesToRender(writer);
+ if(RenderUplevel)
+ {
+ writer.AddAttribute("type", PropertyConverter.EnumToString(typeof(ValidationDataType), Type));
+ NumberFormatInfo currInfo = NumberFormatInfo.CurrentInfo;
+ if(Type == ValidationDataType.Double)
+ {
+ writer.AddAttribute("decimalchar", currInfo.NumberDecimalSeparator);
+ return;
+ }
+ if(Type == ValidationDataType.Currency)
+ {
+ writer.AddAttribute("decimalchar", currInfo.CurrencyDecimalSeparator);
+ string grpSep = currInfo.CurrencyGroupSeparator;
+ if(grpSep[0] == 0xA0)
+ {
+ grpSep = " ";
+ }
+ writer.AddAttribute("groupchar", grpSep);
+ writer.AddAttribute("digits", currInfo.CurrencyDecimalDigits.ToString(NumberFormatInfo.InvariantInfo));
+ return;
+ }
+ if(Type == ValidationDataType.Date)
+ {
+ writer.AddAttribute("cutoffyear", CutoffYear.ToString());
+ writer.AddAttribute("century", ( DateTime.Today.Year - (DateTime.Today.Year % 100) ).ToString());
+ return;
+ }
+ }
+ }
+
+ protected override bool DetermineRenderUplevel()
+ {
+ if(Type == ValidationDataType.Date && DateTimeFormatInfo.CurrentInfo.Calendar.GetType() != typeof(GregorianCalendar))
+ {
+ return false;
+ }
+ return base.DetermineRenderUplevel();
+ }
+
+ /// <summary>
+ /// Undocumented
+ /// </summary>
+ protected static bool Compare(string leftText, string rightText, ValidationCompareOperator op, ValidationDataType type)
+ {
+ object left = null, right = null;
+ if(!Convert(leftText, type, out left))
+ {
+ return false;
+ }
+ if(op == ValidationCompareOperator.DataTypeCheck)
+ {
+ return true;
+ }
+ if(!Convert(rightText, type, out right))
+ {
+ return true;
+ }
+ int compareResult = 0;
+ switch(type)
+ {
+ case ValidationDataType.String:
+ compareResult = ((String)left).CompareTo(right);
+ break;
+ case ValidationDataType.Integer:
+ compareResult = ((int)left).CompareTo(right);
+ break;
+ case ValidationDataType.Double:
+ compareResult = ((Double)left).CompareTo(right);
+ break;
+ case ValidationDataType.Date:
+ compareResult = ((DateTime)left).CompareTo(right);
+ break;
+ case ValidationDataType.Currency:
+ compareResult = ((Decimal)left).CompareTo(right);
+ break;
+ }
+ switch(op)
+ {
+ case ValidationCompareOperator.Equal:
+ return (compareResult == 0);
+ case ValidationCompareOperator.NotEqual:
+ return (compareResult != 0);
+ case ValidationCompareOperator.GreaterThan:
+ return (compareResult > 0);
+ case ValidationCompareOperator.GreaterThanEqual:
+ return (compareResult >= 0);
+ case ValidationCompareOperator.LessThan:
+ return (compareResult < 0);
+ case ValidationCompareOperator.LessThanEqual:
+ return (compareResult <= 0);
+ }
+ return false;
+ }
+
+ /// <summary>
+ /// Undocumented
+ /// </summary>
+ protected static string GetDateElementOrder()
+ {
+ string pattern = DateTimeFormatInfo.CurrentInfo.ShortDatePattern;
+
+ //TODO: What are the various possibilities?
+ // I can think of only y*/M*/d*, d*/M*/y*, M*/d*/y*
+ if(pattern.IndexOf('y') < pattern.IndexOf('M'))
+ {
+ return "ymd";
+ }
+ if(pattern.IndexOf('M') < pattern.IndexOf('d'))
+ {
+ return "mdy";
+ }
+ return "dmy";
+ }
+
+ /// <summary>
+ /// Undocumented
+ /// </summary>
+ protected static bool Convert(string text, ValidationDataType type, out object convertedValue)
+ {
+ convertedValue = null;
+ try
+ {
+ switch(type)
+ {
+ case ValidationDataType.String: convertedValue = text;
+ break;
+ case ValidationDataType.Integer: convertedValue = Int32.Parse(text, CultureInfo.InvariantCulture);
+ break;
+ case ValidationDataType.Double:
+ Match matchDouble = Regex.Match(text, @"^\s*([-\+])?(\d+)?(\"
+ + NumberFormatInfo.CurrentInfo.NumberDecimalSeparator
+ + @"(\d+))?\s*$");
+ if(matchDouble.Success)
+ {
+ string sign = (matchDouble.Groups[1].Success ? matchDouble.Groups[1].Value : "+");
+ string decPart = (matchDouble.Groups[2].Success ? matchDouble.Groups[2].Value : "0");
+ string mantissa = (matchDouble.Groups[4].Success ? matchDouble.Groups[4].Value : "0");
+ convertedValue = Double.Parse(sign + decPart + "." + mantissa, CultureInfo.InvariantCulture);
+ }
+ break;
+ case ValidationDataType.Date:
+ if(DateTimeFormatInfo.CurrentInfo.Calendar.GetType() != typeof(GregorianCalendar))
+ {
+ convertedValue = DateTime.Parse(text);
+ break;
+ }
+ string order = GetDateElementOrder();
+ int date = 0, mth = 0, year = 0;
+ Match matchDate = Regex.Match(text, @"^\s*((\d{4})|(\d{2}))([\.\/-])(\d{1,2})\4(\d{1,2})\s*$");
+ if(matchDate.Success && order == "ymd")
+ {
+ date = Int32.Parse(matchDate.Groups[6].Value, CultureInfo.InvariantCulture);
+ mth = Int32.Parse(matchDate.Groups[5].Value, CultureInfo.InvariantCulture);
+ year = Int32.Parse((matchDate.Groups[2].Success ? matchDate.Groups[2].Value : matchDate.Groups[3].Value), CultureInfo.InvariantCulture);
+ } else
+ {
+ matchDate = Regex.Match(text, @"^\s*(\d{1,2})([\.\/-])(\d{1,2})\2((\d{4}|\d{2}))\s*$");
+ if(matchDate.Success)
+ {
+ if(order == "dmy")
+ {
+ date = Int32.Parse(matchDate.Groups[1].Value, CultureInfo.InvariantCulture);
+ mth = Int32.Parse(matchDate.Groups[3].Value, CultureInfo.InvariantCulture);
+ year = Int32.Parse((matchDate.Groups[5].Success ? matchDate.Groups[5].Value : matchDate.Groups[6].Value), CultureInfo.InvariantCulture);
+ }
+ if(order == "mdy")
+ {
+ date = Int32.Parse(matchDate.Groups[3].Value, CultureInfo.InvariantCulture);
+ mth = Int32.Parse(matchDate.Groups[1].Value, CultureInfo.InvariantCulture);
+ year = Int32.Parse((matchDate.Groups[5].Success ? matchDate.Groups[5].Value : matchDate.Groups[6].Value), CultureInfo.InvariantCulture);
+ }
+ }
+ }
+ year = (year < 100 ? GetFullYear(year) : year);
+ if(matchDate.Success && date!=0 && mth!=0 && year!=0)
+ {
+ convertedValue = new DateTime(year, mth, date);
+ }
+ break;
+ case ValidationDataType.Currency:
+ string decSep = NumberFormatInfo.CurrentInfo.CurrencyDecimalSeparator;
+ string grpSep = NumberFormatInfo.CurrentInfo.CurrencyGroupSeparator;
+ int decDig = NumberFormatInfo.CurrentInfo.CurrencyDecimalDigits;
+ if(grpSep[0] == 0xA0)
+ {
+ grpSep = " ";
+ }
+ string[] patternArray = new string[5];
+ patternArray[0] = "^\\s*([-\\+])?(((\\d+)\\";
+ patternArray[1] = grpSep;
+ patternArray[2] = @")*)(\d+)";
+ if(decDig > 0)
+ {
+ string[] decPattern = new string[5];
+ decPattern[0] = "(\\";
+ decPattern[1] = decSep;
+ decPattern[2] = @"(\d{1,";
+ decPattern[3] = decDig.ToString(NumberFormatInfo.InvariantInfo);
+ decPattern[4] = @"}))";
+ patternArray[3] = String.Concat(decPattern);
+
+ } else
+ {
+ patternArray[3] = String.Empty;
+ }
+ patternArray[4] = @"?\s*$";
+ Match matchCurrency = Regex.Match(text, String.Concat(patternArray));
+ if(matchCurrency.Success)
+ {
+ StringBuilder sb = new StringBuilder();
+ sb.Append(matchCurrency.Groups[1]);
+ CaptureCollection cc = matchCurrency.Groups[4].Captures;
+ foreach(IEnumerable current in cc)
+ {
+ sb.Append((Capture)current);
+ }
+ sb.Append(matchCurrency.Groups[5]);
+ if(decDig > 0)
+ {
+ sb.Append(".");
+ sb.Append(matchCurrency.Groups[7]);
+ }
+ convertedValue = Decimal.Parse(sb.ToString(), CultureInfo.InvariantCulture);
+ }
+ break;
+ }
+ } catch(Exception e)
+ {
+ convertedValue = null;
+ }
+ return (convertedValue != null);
+ }
+ }
+}