the patch fixing issue
[mono.git] / mcs / class / corlib / System.Reflection.Emit / LocalBuilder.cs
old mode 100755 (executable)
new mode 100644 (file)
index 64a134b..87a7225
@@ -38,60 +38,94 @@ using System.Reflection;
 using System.Reflection.Emit;
 using System.Globalization;
 using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
 using System.Diagnostics.SymbolStore;
 
 namespace System.Reflection.Emit {
-       public sealed class LocalBuilder {
-               //
-               // These are kept in sync with reflection.h
-               //
+       [ComVisible (true)]
+       [ComDefaultInterface (typeof (_LocalBuilder))]
+       [ClassInterface (ClassInterfaceType.None)]
+       [StructLayout (LayoutKind.Sequential)]
+       public sealed class LocalBuilder : LocalVariableInfo, _LocalBuilder {
+
+               // Some fields are already defined in LocalVariableInfo
                #region Sync with reflection.h
-               private Type type;
                private string name;
-               private bool is_pinned;
                #endregion
                
-               //
-               // Order does not matter after here
-               //
-               internal ushort position;
                internal ILGenerator ilgen;
+               int startOffset;
+               int endOffset;
 
                internal LocalBuilder (Type t, ILGenerator ilgen)
                {
                        this.type = t;
                        this.ilgen = ilgen;
                }
-               public void SetLocalSymInfo (string lname, int startOffset, int endOffset)
-               {
-                       this.name = lname;
 
-                       SignatureHelper sighelper = SignatureHelper.GetLocalVarSigHelper (ilgen.module);
-                       sighelper.AddArgument (type);
-                       byte[] signature = sighelper.GetSignature ();
+               public void SetLocalSymInfo (string name, int startOffset, int endOffset)
+               {
+                       this.name = name;
+                       this.startOffset = startOffset;
+                       this.endOffset = endOffset;
+               }
 
-                       ilgen.sym_writer.DefineLocalVariable (lname, FieldAttributes.Private,
-                                                                 signature, SymAddressKind.ILOffset,
-                                                                 (int) position, 0, 0,
-                                                                 startOffset, endOffset);
+               public void SetLocalSymInfo (string name)
+               {
+                       SetLocalSymInfo (name, 0, 0);
                }
 
-               public void SetLocalSymInfo (string lname)
+               public override Type LocalType
                {
-                       SetLocalSymInfo (lname, 0, 0);
+                       get {
+                               return type;
+                       }
                }
 
+               public override bool IsPinned
+               {
+                       get {
+                               return is_pinned;
+                       }
+               }
 
-               public Type LocalType
+               public override int LocalIndex
                {
                        get {
-                               return type;
+                               return position;
                        }
                }
+
+               internal string Name {
+                       get { return name; }
+               }
+               
+               internal int StartOffset {
+                       get { return startOffset; }
+               }
                
-               internal void MakePinned ()
+               internal int EndOffset {
+                       get { return endOffset; }
+               }
+
+               void _LocalBuilder.GetIDsOfNames ([In] ref Guid riid, IntPtr rgszNames, uint cNames, uint lcid, IntPtr rgDispId)
+               {
+                       throw new NotImplementedException ();
+               }
+
+               void _LocalBuilder.GetTypeInfo (uint iTInfo, uint lcid, IntPtr ppTInfo)
+               {
+                       throw new NotImplementedException ();
+               }
+
+               void _LocalBuilder.GetTypeInfoCount (out uint pcTInfo)
+               {
+                       throw new NotImplementedException ();
+               }
+
+               void _LocalBuilder.Invoke (uint dispIdMember, [In] ref Guid riid, uint lcid, short wFlags, IntPtr pDispParams, IntPtr pVarResult, IntPtr pExcepInfo, IntPtr puArgErr)
                {
-                       is_pinned = true;
+                       throw new NotImplementedException ();
                }
        }
 }