Xamarin Public Jenkins (auto-signing) 966bba02bb Imported Upstream version 5.2.0.175
Former-commit-id: bb0468d0f257ff100aa895eb5fe583fb5dfbf900
2017-06-07 13:16:24 +00:00

273 lines
8.6 KiB
C#

//
// System.Web.UI.WebControls.BaseCompareValidator
//
// Authors:
// Chris Toshok (toshok@novell.com)
//
// (C) 2005-2010 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.
//
using System.Text;
using System.Threading;
using System.Globalization;
using System.ComponentModel;
using System.Security.Permissions;
using System.Web.Util;
namespace System.Web.UI.WebControls
{
// CAS
[AspNetHostingPermission (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission (SecurityAction.InheritanceDemand, Level = AspNetHostingPermissionLevel.Minimal)]
public abstract class BaseCompareValidator : BaseValidator
{
protected BaseCompareValidator ()
{
}
protected override void AddAttributesToRender (HtmlTextWriter writer)
{
if (RenderUplevel) {
if (Page != null) {
RegisterExpandoAttribute (ClientID, "type", Type.ToString ());
switch (Type) {
case ValidationDataType.Date:
DateTimeFormatInfo dateTimeFormat = CultureInfo.CurrentCulture.DateTimeFormat;
string pattern = dateTimeFormat.ShortDatePattern;
string dateorder = (pattern.StartsWith ("y", true, Helpers.InvariantCulture) ? "ymd" : (pattern.StartsWith ("m", true, Helpers.InvariantCulture) ? "mdy" : "dmy"));
RegisterExpandoAttribute (ClientID, "dateorder", dateorder);
RegisterExpandoAttribute (ClientID, "cutoffyear", dateTimeFormat.Calendar.TwoDigitYearMax.ToString ());
break;
case ValidationDataType.Currency:
NumberFormatInfo numberFormat = CultureInfo.CurrentCulture.NumberFormat;
RegisterExpandoAttribute (ClientID, "decimalchar", numberFormat.CurrencyDecimalSeparator, true);
RegisterExpandoAttribute (ClientID, "groupchar", numberFormat.CurrencyGroupSeparator, true);
RegisterExpandoAttribute (ClientID, "digits", numberFormat.CurrencyDecimalDigits.ToString());
RegisterExpandoAttribute (ClientID, "groupsize", numberFormat.CurrencyGroupSizes [0].ToString ());
break;
}
}
}
base.AddAttributesToRender (writer);
}
public static bool CanConvert (string text,
ValidationDataType type)
{
object value;
return Convert (text, type, out value);
}
protected static bool Convert (string text,
ValidationDataType type,
out object value)
{
return BaseCompareValidator.Convert(text, type, false, out value);
}
protected static bool Compare (string leftText, string rightText, ValidationCompareOperator op, ValidationDataType type)
{
return BaseCompareValidator.Compare(leftText, false, rightText, false, op, type);
}
protected override bool DetermineRenderUplevel ()
{
/* presumably the CompareValidator client side
* code makes use of newer dom/js stuff than
* the rest of the validators. but ours
* doesn't for the moment, so let's just use
* our present implementation
*/
return base.DetermineRenderUplevel();
}
protected static string GetDateElementOrder ()
{
// I hope there's a better way to implement this...
string pattern = Thread.CurrentThread.CurrentCulture.DateTimeFormat.ShortDatePattern;
StringBuilder order = new StringBuilder();
bool seen_date = false;
bool seen_year = false;
bool seen_month = false;
pattern = pattern.ToLower (Helpers.InvariantCulture);
for (int i = 0; i < pattern.Length; i ++) {
char c = pattern[ i ];
if (c != 'm' && c != 'd' && c != 'y')
continue;
if (c == 'm') {
if (!seen_month) order.Append ("m");
seen_month = true;
} else if (c == 'y') {
if (!seen_year) order.Append ("y");
seen_year = true;
} else /* (c == 'd') */ {
if (!seen_date) order.Append ("d");
seen_date = true;
}
}
return order.ToString ();
}
protected static int GetFullYear (int shortYear)
{
/* This is an implementation that matches the
* docs on msdn, but MS doesn't seem to go by
* their docs (at least in 1.0). */
int cutoff = CutoffYear;
int twodigitcutoff = cutoff % 100;
if (shortYear <= twodigitcutoff)
return cutoff - twodigitcutoff + shortYear;
else
return cutoff - twodigitcutoff - 100 + shortYear;
}
[DefaultValue (false)]
[Themeable (false)]
public bool CultureInvariantValues {
get { return ViewState.GetBool ("CultureInvariantValues", false); }
set { ViewState ["CultureInvariantValues"] = value; }
}
protected static int CutoffYear {
get { return CultureInfo.CurrentCulture.Calendar.TwoDigitYearMax; }
}
[DefaultValue(ValidationDataType.String)]
[Themeable (false)]
[WebSysDescription("")]
[WebCategory("Behavior")]
public ValidationDataType Type {
get { return ViewState ["Type"] == null ? ValidationDataType.String : (ValidationDataType) ViewState ["Type"]; }
set { ViewState ["Type"] = value; }
}
public static bool CanConvert (string text, ValidationDataType type, bool cultureInvariant)
{
object value;
return Convert(text, type, cultureInvariant, out value);
}
protected static bool Compare (string leftText,
bool cultureInvariantLeftText,
string rightText,
bool cultureInvariantRightText,
ValidationCompareOperator op,
ValidationDataType type)
{
object lo, ro;
if (!Convert(leftText, type, cultureInvariantLeftText, out lo))
return false;
/* DataTypeCheck is a unary operator that only
* depends on the lhs */
if (op == ValidationCompareOperator.DataTypeCheck)
return true;
/* pretty crackladen, but if we're unable to
* convert the rhs to @type, the comparison
* succeeds */
if (!Convert(rightText, type, cultureInvariantRightText, out ro))
return true;
int comp = ((IComparable)lo).CompareTo((IComparable)ro);
switch (op) {
case ValidationCompareOperator.Equal:
return comp == 0;
case ValidationCompareOperator.NotEqual:
return comp != 0;
case ValidationCompareOperator.LessThan:
return comp < 0;
case ValidationCompareOperator.LessThanEqual:
return comp <= 0;
case ValidationCompareOperator.GreaterThan:
return comp > 0;
case ValidationCompareOperator.GreaterThanEqual:
return comp >= 0;
default:
return false;
}
}
protected static bool Convert (string text, ValidationDataType type, bool cultureInvariant,out object value)
{
try {
switch (type) {
case ValidationDataType.String:
value = text;
return value != null;
case ValidationDataType.Integer:
IFormatProvider intFormatProvider = (cultureInvariant) ? NumberFormatInfo.InvariantInfo :
NumberFormatInfo.CurrentInfo;
value = Int32.Parse(text, intFormatProvider);
return true;
case ValidationDataType.Double:
IFormatProvider doubleFormatProvider = (cultureInvariant) ? NumberFormatInfo.InvariantInfo :
NumberFormatInfo.CurrentInfo;
value = Double.Parse(text, doubleFormatProvider);
return true;
case ValidationDataType.Date:
IFormatProvider dateFormatProvider = (cultureInvariant) ? DateTimeFormatInfo.InvariantInfo :
DateTimeFormatInfo.CurrentInfo;
value = DateTime.Parse(text, dateFormatProvider);
return true;
case ValidationDataType.Currency:
IFormatProvider currencyFormatProvider = (cultureInvariant) ? NumberFormatInfo.InvariantInfo :
NumberFormatInfo.CurrentInfo;
value = Decimal.Parse(text, NumberStyles.Currency, currencyFormatProvider);
return true;
default:
value = null;
return false;
}
} catch {
value = null;
return false;
}
}
}
}