Add public to classes and set accessor to properties needed for serialization
authorAmy Yu <amycmyu@gmail.com>
Mon, 11 Jun 2018 23:01:39 +0000 (16:01 -0700)
committerAmy Yu <amycmyu@gmail.com>
Tue, 26 Jun 2018 22:03:30 +0000 (15:03 -0700)
src/tools/r2rdump/GCInfo.cs
src/tools/r2rdump/GCInfoTypes.cs
src/tools/r2rdump/GCSlotTable.cs
src/tools/r2rdump/R2RHeader.cs
src/tools/r2rdump/R2RImportSection.cs
src/tools/r2rdump/R2RMethod.cs
src/tools/r2rdump/R2RReader.cs
src/tools/r2rdump/R2RSection.cs

index cf57db62ac97ed2a9f4413cc5448db1d7171a68a..de2ce66bb169ee934b9be96aee8918c18109e09f 100644 (file)
@@ -9,7 +9,7 @@ using System.Text;
 
 namespace R2RDump
 {
-    class GcInfo
+    public class GcInfo
     {
         private enum GcInfoHeaderFlags
         {
@@ -33,8 +33,8 @@ namespace R2RDump
 
         public struct InterruptibleRange
         {
-            public uint StartOffset { get; }
-            public uint StopOffset { get; }
+            public uint StartOffset { get; set; }
+            public uint StopOffset { get; set; }
             public InterruptibleRange(uint start, uint stop)
             {
                 StartOffset = start;
@@ -335,7 +335,7 @@ namespace R2RDump
             _wantsReportOnlyLeaf = ((headerFlags & GcInfoHeaderFlags.GC_INFO_WANTS_REPORT_ONLY_LEAF) != 0);
         }
 
-        private IEnumerable<uint> EnumerateSafePoints(byte[] image, ref int bitOffset)
+        private List<uint> EnumerateSafePoints(byte[] image, ref int bitOffset)
         {
             List<uint> safePoints = new List<uint>();
             uint numBitsPerOffset = GcInfoTypes.CeilOfLog2(CodeLength);
@@ -347,7 +347,7 @@ namespace R2RDump
             return safePoints;
         }
 
-        private IEnumerable<InterruptibleRange> EnumerateInterruptibleRanges(byte[] image, int interruptibleRangeDelta1EncBase, int interruptibleRangeDelta2EncBase, ref int bitOffset)
+        private List<InterruptibleRange> EnumerateInterruptibleRanges(byte[] image, int interruptibleRangeDelta1EncBase, int interruptibleRangeDelta2EncBase, ref int bitOffset)
         {
             List<InterruptibleRange> ranges = new List<InterruptibleRange>();
             uint lastinterruptibleRangeStopOffset = 0;
index 9b44a595a8eea34368386b5882d582b99631d915..a285ebba5a198acec7ab7442ddea0de155c1d495 100644 (file)
@@ -8,7 +8,7 @@ using System.Text;
 
 namespace R2RDump
 {
-    class GcInfoTypes
+    public class GcInfoTypes
     {
         private Machine _target;
 
@@ -196,8 +196,11 @@ namespace R2RDump
 
     public class GcStackSlot
     {
-        public int SpOffset { get; }
-        public GcStackSlotBase Base { get; }
+        public int SpOffset { get; set; }
+        public GcStackSlotBase Base { get; set; }
+
+        public GcStackSlot() { }
+
         public GcStackSlot(int spOffset, GcStackSlotBase stackSlotBase)
         {
             SpOffset = spOffset;
index f2ebf414c68814e5257ec37fd9b89f0eadb9fd92..d788f4dce2886b087caf66c8c26b89acc31973f0 100644 (file)
@@ -9,13 +9,13 @@ using System.Text;
 
 namespace R2RDump
 {
-    class GcSlotTable
+    public class GcSlotTable
     {
         public struct GcSlot
         {
-            public int RegisterNumber { get; }
-            public GcStackSlot StackSlot { get; }
-            public GcSlotFlags Flags { get; }
+            public int RegisterNumber { get; set; }
+            public GcStackSlot StackSlot { get; set; }
+            public GcSlotFlags Flags { get; set; }
 
             public GcSlot(int registerNumber, GcStackSlot stack, GcSlotFlags flags, bool isUntracked = false)
             {
@@ -50,11 +50,13 @@ namespace R2RDump
             }
         }
 
-        public uint NumRegisters { get; }
-        public uint NumStackSlots { get; }
-        public uint NumUntracked { get; }
-        public uint NumSlots { get; }
-        public List<GcSlot> GcSlots { get; }
+        public uint NumRegisters { get; set; }
+        public uint NumStackSlots { get; set; }
+        public uint NumUntracked { get; set; }
+        public uint NumSlots { get; set; }
+        public List<GcSlot> GcSlots { get; set; }
+
+        public GcSlotTable() { }
 
         public GcSlotTable(byte[] image, Machine machine, GcInfoTypes gcInfoTypes, ref int bitOffset)
         {
index 96eacd583a92f98e5fbbb17583413e5d83fc5a99..cf7e65a0e96841b408f33f08d2ecf6b3f5b15b8e 100644 (file)
@@ -8,7 +8,7 @@ using System.Text;
 
 namespace R2RDump
 {
-    class R2RHeader
+    public class R2RHeader
     {
         [Flags]
         public enum ReadyToRunFlag
@@ -26,35 +26,37 @@ namespace R2RDump
         /// <summary>
         /// RVA to the begining of the ReadyToRun header
         /// </summary>
-        public int RelativeVirtualAddress { get; }
+        public int RelativeVirtualAddress { get; set; }
 
         /// <summary>
         /// Size of the ReadyToRun header
         /// </summary>
-        public int Size { get; }
+        public int Size { get; set; }
 
         /// <summary>
         /// Signature of the header in string and hex formats
         /// </summary>
-        public string SignatureString { get; }
-        public uint Signature { get; }
+        public string SignatureString { get; set; }
+        public uint Signature { get; set; }
 
         /// <summary>
         /// The ReadyToRun version
         /// </summary>
-        public ushort MajorVersion { get; }
-        public ushort MinorVersion { get; }
+        public ushort MajorVersion { get; set; }
+        public ushort MinorVersion { get; set; }
 
         /// <summary>
         /// Flags in the header
         /// eg. PLATFORM_NEUTRAL_SOURCE, SKIP_TYPE_VALIDATION
         /// </summary>
-        public uint Flags { get; }
+        public uint Flags { get; set; }
 
         /// <summary>
         /// The ReadyToRun section RVAs and sizes
         /// </summary>
-        public Dictionary<R2RSection.SectionType, R2RSection> Sections { get; }
+        public IDictionary<R2RSection.SectionType, R2RSection> Sections { get; }
+
+        public R2RHeader() { }
 
         /// <summary>
         /// Initializes the fields of the R2RHeader
@@ -70,7 +72,7 @@ namespace R2RDump
 
             byte[] signature = new byte[sizeof(uint)];
             Array.Copy(image, curOffset, signature, 0, sizeof(uint));
-            SignatureString = System.Text.Encoding.UTF8.GetString(signature);
+            SignatureString = Encoding.UTF8.GetString(signature).Replace("\0", string.Empty); ;
             Signature = NativeReader.ReadUInt32(image, ref curOffset);
             if (Signature != READYTORUN_SIGNATURE)
             {
index aa567d51e82c36eb1ff71a04545833db33930d7f..e91ef3495eb7cdf555dbfb8b51ad07c5c32d2043 100644 (file)
@@ -9,7 +9,7 @@ using System.Text;
 
 namespace R2RDump
 {
-    struct R2RImportSection
+    public struct R2RImportSection
     {
         public enum CorCompileImportType
         {
index 448b5b73e8f09dd9b3914535d1d5a34a40024b9c..3851085045cf37861b03b590c0fc36d4923fed65 100644 (file)
@@ -9,6 +9,7 @@ using System.Linq;
 using System.Reflection.Metadata;
 using System.Reflection.Metadata.Ecma335;
 using System.Text;
+using System.Xml.Serialization;
 
 namespace R2RDump
 {
@@ -17,17 +18,17 @@ namespace R2RDump
 
     }
 
-    class RuntimeFunction
+    public class RuntimeFunction
     {
         /// <summary>
         /// The index of the runtime function
         /// </summary>
-        public int Id { get; }
+        public int Id { get; set; }
 
         /// <summary>
         /// The relative virtual address to the start of the code block
         /// </summary>
-        public int StartAddress { get; }
+        public int StartAddress { get; set; }
 
         /// <summary>
         /// The size of the code block in bytes
@@ -36,12 +37,12 @@ namespace R2RDump
         /// The EndAddress field in the runtime functions section is conditional on machine type
         /// Size is -1 for images without the EndAddress field
         /// </remarks>
-        public int Size { get; }
+        public int Size { get; set; }
 
         /// <summary>
         /// The relative virtual address to the unwind info
         /// </summary>
-        public int UnwindRVA { get; }
+        public int UnwindRVA { get; set; }
 
         public int CodeOffset { get; set; }
 
@@ -52,6 +53,8 @@ namespace R2RDump
 
         public BaseUnwindInfo UnwindInfo { get; }
 
+        public RuntimeFunction() { }
+
         public RuntimeFunction(int id, int startRva, int endRva, int unwindRva, int codeOffset, R2RMethod method, BaseUnwindInfo unwindInfo, GcInfo gcInfo)
         {
             Id = id;
@@ -91,7 +94,7 @@ namespace R2RDump
         }
     }
 
-    class R2RMethod
+    public class R2RMethod
     {
         private const int _mdtMethodDef = 0x06000000;
 
@@ -101,31 +104,31 @@ namespace R2RDump
         /// <summary>
         /// The name of the method
         /// </summary>
-        public string Name { get; }
+        public string Name { get; set; }
 
         /// <summary>
         /// The signature with format: namespace.class.methodName<S, T, ...>(S, T, ...)
         /// </summary>
-        public string SignatureString { get; }
+        public string SignatureString { get; set; }
 
-        public bool IsGeneric { get; }
+        public bool IsGeneric { get; set; }
 
         public MethodSignature<string> Signature { get; }
 
         /// <summary>
         /// The type that the method belongs to
         /// </summary>
-        public string DeclaringType { get; }
+        public string DeclaringType { get; set; }
 
         /// <summary>
         /// The token of the method consisting of the table code (0x06) and row id
         /// </summary>
-        public uint Token { get; }
+        public uint Token { get; set; }
 
         /// <summary>
         /// The row id of the method
         /// </summary>
-        public uint Rid { get; }
+        public uint Rid { get; set; }
 
         /// <summary>
         /// All the runtime functions of this method
@@ -135,8 +138,9 @@ namespace R2RDump
         /// <summary>
         /// The id of the entrypoint runtime function
         /// </summary>
-        public int EntryPointRuntimeFunctionId { get; }
+        public int EntryPointRuntimeFunctionId { get; set; }
 
+        [XmlIgnore]
         public GcInfo GcInfo { get; set; }
 
         /// <summary>
@@ -179,6 +183,8 @@ namespace R2RDump
             Array = 0x1d,
         };
 
+        public R2RMethod() { }
+
         /// <summary>
         /// Extracts the method signature from the metadata by rid
         /// </summary>
index b5d150b597505ae28274442f0648a655edc06986..56539dadbbfd3cb835b5daefaeecf8977745499e 100644 (file)
@@ -32,7 +32,7 @@ namespace R2RDump
         E15 = 15,
     }
 
-    class R2RReader
+    public class R2RReader
     {
         private readonly PEReader _peReader;
         private readonly MetadataReader _mdReader;
@@ -45,23 +45,23 @@ namespace R2RDump
         /// <summary>
         /// Name of the image file
         /// </summary>
-        public string Filename { get; }
+        public string Filename { get; set; }
 
         /// <summary>
         /// True if the image is ReadyToRun
         /// </summary>
-        public bool IsR2R { get; }
+        public bool IsR2R { get; set; }
 
         /// <summary>
         /// The type of target machine
         /// </summary>
-        public Machine Machine { get; }
+        public Machine Machine { get; set; }
 
         /// <summary>
         /// The preferred address of the first byte of image when loaded into memory; 
         /// must be a multiple of 64K.
         /// </summary>
-        public ulong ImageBase { get; }
+        public ulong ImageBase { get; set; }
 
         /// <summary>
         /// The ReadyToRun header
@@ -85,6 +85,8 @@ namespace R2RDump
 
         public IList<R2RImportSection> ImportSections { get; }
 
+        public unsafe R2RReader() { }
+
         /// <summary>
         /// Initializes the fields of the R2RHeader and R2RMethods
         /// </summary>
@@ -313,7 +315,7 @@ namespace R2RDump
             byte[] identifier = new byte[compilerIdentifierSection.Size];
             int identifierOffset = GetOffset(compilerIdentifierSection.RelativeVirtualAddress);
             Array.Copy(Image, identifierOffset, identifier, 0, compilerIdentifierSection.Size);
-            return Encoding.UTF8.GetString(identifier);
+            return Encoding.UTF8.GetString(identifier).Replace("\0", string.Empty);
         }
 
         private void ParseImportSections()
index 8d6d7cf99c578e705bb61c90dddec2facf685a8e..77cf24d98f11ff72c451292c7158ec90e9f770d1 100644 (file)
@@ -8,7 +8,7 @@ using System.Text;
 
 namespace R2RDump
 {
-    struct R2RSection
+    public struct R2RSection
     {
         public enum SectionType
         {
@@ -28,17 +28,17 @@ namespace R2RDump
         /// <summary>
         /// The ReadyToRun section type
         /// </summary>
-        public SectionType Type { get; }
+        public SectionType Type { get; set; }
 
         /// <summary>
         /// The RVA to the section
         /// </summary>
-        public int RelativeVirtualAddress { get; }
+        public int RelativeVirtualAddress { get; set; }
 
         /// <summary>
         /// The size of the section
         /// </summary>
-        public int Size { get; }
+        public int Size { get; set; }
 
         public R2RSection(SectionType type, int rva, int size)
         {