[corlib] Parse datetime string using culture calendar. Fixes #18052
[mono.git] / mcs / class / corlib / System.Security.Policy / StrongNameMembershipCondition.cs
index 583899ace9282aaee3f0c17f769c70117ec3cbdf..7b29b47231f88255067ef4b92183e94c1b6566cc 100644 (file)
@@ -3,12 +3,10 @@
 //
 // Author:
 //      Duncan Mak (duncan@ximian.com)
+//     Sebastien Pouliot  <sebastien@ximian.com>
 //
 // (C) 2003 Duncan Mak, Ximian Inc.
-//
-
-//
-// Copyright (C) 2004 Novell, Inc (http://www.novell.com)
+// Copyright (C) 2004-2005 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
 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 //
 
-using System;
+using System.Collections;
 using System.Globalization;
 using System.Security.Permissions;
+using System.Runtime.InteropServices;
+using System.Text;
 
 namespace System.Security.Policy {
 
        [Serializable]
-        public sealed class StrongNameMembershipCondition
-                : IMembershipCondition, ISecurityEncodable, ISecurityPolicyEncodable, IConstantMembershipCondition
-        {
-                StrongNamePublicKeyBlob blob;
-                string name;
-                Version version;
+       [ComVisible (true)]
+        public sealed class StrongNameMembershipCondition : IMembershipCondition, IConstantMembershipCondition {
+
+               private readonly int version = 1;
+
+               private StrongNamePublicKeyBlob blob;
+               private string name;
+               private Version assemblyVersion;
                 
                 public StrongNameMembershipCondition (StrongNamePublicKeyBlob blob, string name, Version version)
                 {
@@ -51,7 +53,8 @@ namespace System.Security.Policy {
 
                         this.blob = blob;
                         this.name = name;
-                        this.version = version;
+                       if (version != null)
+                               assemblyVersion = (Version) version.Clone ();
                 }
 
                // for PolicyLevel (to avoid validation duplication)
@@ -60,31 +63,28 @@ namespace System.Security.Policy {
                        FromXml (e);
                }
 
+               // so System.Activator.CreateInstance can create an instance...
+               internal StrongNameMembershipCondition ()
+               {
+               }
+
                // properties
 
                 public string Name {
-
                         get { return name; }
-
                         set { name = value; }
                 }
 
                 public Version Version {
-
-                        get { return version; }
-
-                        set { version = value; }
+                        get { return assemblyVersion; }
+                        set { assemblyVersion = value; }
                 }
 
                 public StrongNamePublicKeyBlob PublicKey {
-
                         get { return blob; }
-
                         set {
                                 if (value == null)
-                                        throw new ArgumentNullException (
-                                                Locale.GetText ("The argument is null."));
-
+                                        throw new ArgumentNullException ("PublicKey");
                                blob = value;
                        }
                }
@@ -94,11 +94,17 @@ namespace System.Security.Policy {
                        if (evidence == null)
                                return false;
 
-                       foreach (object o in evidence) {
-                               if (o is StrongName) {
-                                       StrongName sn = (o as StrongName);
-                                       if (sn.PublicKey.Equals (blob) && (sn.Name == name) && (sn.Version.Equals (version)))
-                                               return true;
+                       IEnumerator e = evidence.GetHostEnumerator ();
+                       while (e.MoveNext ()) {
+                               StrongName sn = (e.Current as StrongName);
+                               if (sn != null) {
+                                       if (!sn.PublicKey.Equals (blob))
+                                               return false;
+                                       if ((name != null) && (name != sn.Name))
+                                               return false;
+                                       if ((assemblyVersion != null) && !assemblyVersion.Equals (sn.Version))
+                                               return false;
+                                       return true;
                                }
                        }
                        return false;
@@ -106,21 +112,26 @@ namespace System.Security.Policy {
 
                public IMembershipCondition Copy ()
                {
-                       return new StrongNameMembershipCondition (blob, name, version);
+                       return new StrongNameMembershipCondition (blob, name, assemblyVersion);
                }
 
                public override bool Equals (object o)
-               {        
-                       if (o is StrongNameMembershipCondition == false)
+               {
+                       StrongNameMembershipCondition snmc = (o as StrongNameMembershipCondition);
+                       if (snmc == null)
                                return false;
-                       else {
-                               StrongNameMembershipCondition snmc = (StrongNameMembershipCondition) o;
-                               return (snmc.Name == Name && snmc.Version == Version && snmc.PublicKey == PublicKey);
-                       }
+                       if (!snmc.PublicKey.Equals (PublicKey))
+                               return false;
+                       if (name != snmc.Name)
+                               return false;
+                       if (assemblyVersion != null)
+                               return assemblyVersion.Equals (snmc.Version);
+                       return (snmc.Version == null);
                }
 
                public override int GetHashCode ()
                {
+                       // name and version aren't part of the calculation
                        return blob.GetHashCode ();
                }
 
@@ -131,28 +142,26 @@ namespace System.Security.Policy {
 
                public void FromXml (SecurityElement e, PolicyLevel level)
                {
-                       if (e == null)
-                               throw new ArgumentNullException ("e");
-
-                       if (e.Attribute ("class").IndexOf (GetType ().Name) < 0)
-                               throw new ArgumentException (Locale.GetText ("Invalid class"));
-
-                       if (e.Attribute ("version") != "1")
-                               throw new ArgumentException (Locale.GetText ("Invalid version"));
+                       MembershipConditionHelper.CheckSecurityElement (e, "e", version, version);
 
                        blob = StrongNamePublicKeyBlob.FromString (e.Attribute ("PublicKeyBlob"));
                        name = e.Attribute ("Name");
                        string v = (string) e.Attribute ("AssemblyVersion");
                        if (v == null)
-                               version = new Version ();
+                               assemblyVersion = null;
                        else
-                               version = new Version (v);
+                               assemblyVersion = new Version (v);
                }
 
                 public override string ToString ()
                 {
-                        return String.Format ( "Strong Name - {0} name = {1} version {2}",
-                                        blob, name, version);
+                       StringBuilder sb = new StringBuilder ("StrongName - ");
+                       sb.Append (blob);
+                       if (name != null)
+                               sb.AppendFormat (" name = {0}", name);
+                       if (assemblyVersion != null)
+                               sb.AppendFormat (" version = {0}", assemblyVersion);
+                       return sb.ToString ();
                 }
 
                 public SecurityElement ToXml ()
@@ -162,17 +171,19 @@ namespace System.Security.Policy {
 
                 public SecurityElement ToXml (PolicyLevel level)
                 {
-                        SecurityElement element = new SecurityElement ("IMembershipCondition");
-                        element.AddAttribute ("class", this.GetType ().AssemblyQualifiedName);
-                        element.AddAttribute ("version", "1");
-
-                        element.AddAttribute ("PublicKeyBlob", blob.ToString ());
-                        element.AddAttribute ("Name", name);
-                       string v = version.ToString ();
-                       if (v != "0.0")
-                               element.AddAttribute ("AssemblyVersion", version.ToString ());
-
-                       return element;
+                       // PolicyLevel isn't used as there's no need to resolve NamedPermissionSet references
+                       SecurityElement se = MembershipConditionHelper.Element (typeof (StrongNameMembershipCondition), version);
+
+                       if (blob != null)
+                               se.AddAttribute ("PublicKeyBlob", blob.ToString ());
+                       if (name != null)
+                               se.AddAttribute ("Name", name);
+                       if (assemblyVersion != null) {
+                               string v = assemblyVersion.ToString ();
+                               if (v != "0.0")
+                                       se.AddAttribute ("AssemblyVersion", v);
+                       }
+                       return se;
                 }
         }
 }