Merge pull request #297 from ermshiperete/4959
[mono.git] / mcs / class / corlib / System / BadImageFormatException.cs
index 8ec5ab3ca7c29a98e3619ff9528daced3719e3c8..f48fb2274c193ee6d1a6cc4b362901e405ff8cce 100644 (file)
-// System.BadImageFormatException
 //
-// Sean MacIsaac (macisaac@ximian.com)
+// System.BadImageFormatException.cs
+//
+// Authors:
+//   Sean MacIsaac (macisaac@ximian.com)
+//   Duncan Mak (duncan@ximian.com)
+//   Andreas Nahr (ClassDevelopment@A-SoftTech.com)
 //
 // (C) 2001 Ximian, Inc.
+// 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
+// "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.Globalization;
+using System.Runtime.Serialization;
+using System.Security.Permissions;
+using System.Runtime.InteropServices;
+using System.Text;
 
 namespace System
 {
-       public class BadImageFormatException : Exception
+       [Serializable]
+       [ComVisible (true)]
+       public class BadImageFormatException : SystemException
        {
-               public string FusionLog {
+               const int Result = unchecked ((int)0x8007000B);
+
+               // Fields
+               private string fileName;
+               private string fusionLog;
+
+               // Constructors
+               public BadImageFormatException ()
+                       : base (Locale.GetText ("Format of the executable (.exe) or library (.dll) is invalid."))
+               {
+                       HResult = Result;
+               }
+
+               public BadImageFormatException (string message)
+                       : base (message)
+               {
+                       HResult = Result;
+               }
+
+               protected BadImageFormatException (SerializationInfo info, StreamingContext context)
+                       : base (info, context)
+               {
+                       fileName = info.GetString ("BadImageFormat_FileName");
+                       fusionLog = info.GetString ("BadImageFormat_FusionLog");
+               }
+
+               public BadImageFormatException (string message, Exception inner)
+                       : base (message, inner)
+               {
+                       HResult = Result;
+               }
+
+               public BadImageFormatException (string message, string fileName)
+                       : base (message)
+               {
+                       this.fileName = fileName;
+                       HResult = Result;
+               }
+
+               public BadImageFormatException (string message, string fileName, Exception inner)
+                       : base (message, inner)
+               {
+                       this.fileName = fileName;
+                       HResult = Result;
+               }
+
+               // Properties
+               public override string Message
+               {
                        get {
-                               // FIXME
-                               return null;
+                               if (base.message == null) {
+                                       return string.Format (CultureInfo.CurrentCulture,
+                                               "Could not load file or assembly '{0}' or one of"
+                                               + " its dependencies. An attempt was made to load"
+                                               + " a program with an incorrect format.", fileName);
+                               }
+                               return base.Message;
+                       }
+               }
+
+               public string FileName
+               {
+                       get { return fileName; }
+               }
+
+               [MonoTODO ("Probably not entirely correct. fusionLog needs to be set somehow (we are probably missing internal constuctor)")]
+               public string FusionLog {
+                       // note: MS runtime throws a SecurityException when the Exception is created
+                       // but a FileLoadException once the exception as been thrown. Mono always
+                       // throw a SecurityException in both case (anyway fusionLog is currently empty)
+                       [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
+                       get { return fusionLog; }
+               }
+
+               // Methods
+               public override void GetObjectData (SerializationInfo info, StreamingContext context)
+               {
+                       base.GetObjectData (info, context);
+                       info.AddValue ("BadImageFormat_FileName", fileName);
+                       info.AddValue ("BadImageFormat_FusionLog", fusionLog);
+               }
+
+               public override string ToString ()
+               {
+                       StringBuilder sb = new StringBuilder (GetType ().FullName);
+                       sb.AppendFormat (": {0}", Message);
+
+                       if (fileName != null && fileName.Length > 0) {
+                               sb.Append (Environment.NewLine);
+                               sb.AppendFormat ("File name: '{0}'", fileName);
                        }
+
+                       if (this.InnerException != null)
+                               sb.AppendFormat (" ---> {0}", InnerException);
+
+                       if (this.StackTrace != null) {
+                               sb.Append (Environment.NewLine);
+                               sb.Append (StackTrace);
+                       }
+
+                       return sb.ToString ();
                }
        }
 }