public PropertySignature ReadPropertySignature(uint signature, PropertyDefinition parentProperty) { PropertySignature propertySig = null; BlobSignatureReader reader; if (TryGetBlobReader(signature, out reader)) { using (reader) { reader.GenericContext = parentProperty.DeclaringType; byte flag = reader.ReadByte(); if ((flag & 8) == 0) { throw new ArgumentException("Signature doesn't refer to a valid property signature."); } propertySig = new PropertySignature(); propertySig.HasThis = (flag & 0x20) != 0; NETGlobals.ReadCompressedUInt32(reader); propertySig.ReturnType = reader.ReadTypeReference(); } } return(propertySig); }
public VariableDefinition[] ReadVariableSignature(uint signature, MethodDefinition parentMethod) { VariableDefinition[] variables = null; BlobSignatureReader reader; if (TryGetBlobReader(signature, parentMethod, out reader)) { using (reader) { reader.GenericContext = parentMethod; byte local_sig = reader.ReadByte(); if (local_sig != 0x7) { throw new ArgumentException("Signature doesn't refer to a valid local variable signature"); } uint count = NETGlobals.ReadCompressedUInt32(reader); if (count == 0) { return(null); } variables = new VariableDefinition[count]; for (int i = 0; i < count; i++) { variables[i] = new VariableDefinition(i, reader.ReadTypeReference()); } } } return(variables); }
/// <summary> /// Gets a string by its offset. /// </summary> /// <param name="offset">The offset of the string.</param> /// <returns></returns> public string GetStringByOffset(uint offset) { string stringValue; if (_readStrings.TryGetValue(offset, out stringValue)) { return(stringValue); } _mainStream.Seek(offset, SeekOrigin.Begin); uint length = (uint)(NETGlobals.ReadCompressedUInt32(_binReader) & -2); if (length == 0) { _readStrings.Add(offset, string.Empty); return(string.Empty); } char[] chars = new char[length / 2]; for (int i = 0; i < length; i += 2) { chars[i / 2] = (char)_binReader.ReadInt16(); } stringValue = new string(chars); _readStrings.Add(offset, stringValue); return(stringValue); }
public IMemberSignature ReadMemberRefSignature(uint sig, IGenericContext context) { IMemberSignature signature = null; BlobSignatureReader reader; if (TryGetBlobReader(sig, context, out reader)) { using (reader) { byte flag = reader.ReadByte(); if (flag == 0x6) { FieldSignature fieldsignature = new FieldSignature(); fieldsignature.ReturnType = reader.ReadTypeReference((ElementType)reader.ReadByte()); signature = fieldsignature; } else { MethodSignature methodsignature = new MethodSignature(); if ((flag & 0x20) != 0) { methodsignature.HasThis = true; flag = (byte)(flag & -33); } if ((flag & 0x40) != 0) { methodsignature.ExplicitThis = true; flag = (byte)(flag & -65); } if ((flag & 0x10) != 0) { int genericsig = NETGlobals.ReadCompressedInt32(reader); if (!context.IsDefinition) { AddMissingGenericParameters(context.Method, genericsig - 1); } } methodsignature.CallingConvention = (MethodCallingConvention)flag; uint paramCount = NETGlobals.ReadCompressedUInt32(reader); methodsignature.ReturnType = reader.ReadTypeReference(); ParameterReference[] parameters = new ParameterReference[paramCount]; for (int i = 0; i < paramCount; i++) { parameters[i] = new ParameterReference() { ParameterType = reader.ReadTypeReference((ElementType)reader.ReadByte()) }; } methodsignature.Parameters = parameters; signature = methodsignature; } } } return(signature); }
public string ReadUtf8String() { if (ReadByte() == 0xFF) { return(string.Empty); } BaseStream.Seek(-1, SeekOrigin.Current); uint size = NETGlobals.ReadCompressedUInt32(this); byte[] rawdata = this.ReadBytes((int)size); return(Encoding.UTF8.GetString(rawdata)); }
public TypeReference[] ReadGenericArguments() { uint number = NETGlobals.ReadCompressedUInt32(this); var genericArguments = new TypeReference[number]; for (int i = 0; i < number; i++) { genericArguments[i] = ReadTypeReference(); } return(genericArguments); }
public TypeReference ReadTypeToken() { TypeReference typeRef; if (_netHeader.TablesHeap.TypeDefOrRef.TryGetMember((int)NETGlobals.ReadCompressedUInt32(this), out typeRef)) { if (typeRef is ISpecification) { typeRef = (typeRef as TypeSpecification).TransformWith(GenericContext) as TypeReference; } } return(typeRef); }
/// <summary> /// Gets the blob value by it's signature/index. /// </summary> /// <param name="index">The index or signature to get the blob value from.</param> /// <returns></returns> public byte[] GetBlob(uint index) { byte[] bytes = null; if (_readBlobs.TryGetValue(index, out bytes)) { return(bytes); } _mainStream.Seek(index, SeekOrigin.Begin); int length = (int)NETGlobals.ReadCompressedUInt32(_binReader); bytes = _binReader.ReadBytes(length); _readBlobs.Add(index, bytes); return(bytes); }
public ArrayType ReadArrayType() { TypeReference arrayType = ReadTypeReference((ElementType)this.ReadByte()); uint rank = NETGlobals.ReadCompressedUInt32(this); uint[] upperbounds = new uint[NETGlobals.ReadCompressedUInt32(this)]; for (int i = 0; i < upperbounds.Length; i++) { upperbounds[i] = NETGlobals.ReadCompressedUInt32(this); } int[] lowerbounds = new int[NETGlobals.ReadCompressedUInt32(this)]; for (int i = 0; i < lowerbounds.Length; i++) { lowerbounds[i] = NETGlobals.ReadCompressedInt32(this); } ArrayDimension[] dimensions = new ArrayDimension[rank]; for (int i = 0; i < rank; i++) { int?lower = null; int?upper = null; if (i < lowerbounds.Length) { lower = new int?(lowerbounds[i]); } if (i < upperbounds.Length) { int x = (int)upperbounds[i]; upper = (lower.HasValue ? new int?(lower.GetValueOrDefault() + x) : 0) - 1; } ArrayDimension dimension = new ArrayDimension(lower, upper); dimensions[i] = dimension; } return(new ArrayType(arrayType, (int)rank, dimensions)); }
public TypeReference[] ReadGenericArgumentsSignature(uint signature, IGenericContext context) { BlobSignatureReader reader; if (TryGetBlobReader(signature, context, out reader)) { using (reader) { if (reader.ReadByte() == 0xa) { uint count = NETGlobals.ReadCompressedUInt32(reader); TypeReference[] types = new TypeReference[count]; for (int i = 0; i < count; i++) { types[i] = reader.ReadTypeReference(); } return(types); } } } throw new ArgumentException("Signature doesn't point to a valid generic arguments signature"); }
public TypeReference ReadTypeReference(ElementType type) { switch (type) { case ElementType.Void: return(_netHeader.TypeSystem.Void); case ElementType.I: return(_netHeader.TypeSystem.IntPtr); case ElementType.I1: return(_netHeader.TypeSystem.Int8); case ElementType.I2: return(_netHeader.TypeSystem.Int16); case ElementType.I4: return(_netHeader.TypeSystem.Int32); case ElementType.I8: return(_netHeader.TypeSystem.Int64); case ElementType.U: return(_netHeader.TypeSystem.UIntPtr); case ElementType.U1: return(_netHeader.TypeSystem.UInt8); case ElementType.U2: return(_netHeader.TypeSystem.UInt16); case ElementType.U4: return(_netHeader.TypeSystem.UInt32); case ElementType.U8: return(_netHeader.TypeSystem.UInt64); case ElementType.Object: return(_netHeader.TypeSystem.Object); case ElementType.R4: return(_netHeader.TypeSystem.Single); case ElementType.R8: return(_netHeader.TypeSystem.Double); case ElementType.String: return(_netHeader.TypeSystem.String); case ElementType.Char: return(_netHeader.TypeSystem.Char); case ElementType.Type: return(_netHeader.TypeSystem.Type); case ElementType.Boolean: return(_netHeader.TypeSystem.Boolean); case ElementType.Ptr: return(new PointerType(ReadTypeReference((ElementType)this.ReadByte()))); case ElementType.MVar: return(GetGenericParameter(GenericParamType.Method, (int)NETGlobals.ReadCompressedUInt32(this))); case ElementType.Var: return(GetGenericParameter(GenericParamType.Type, (int)NETGlobals.ReadCompressedUInt32(this))); case ElementType.Array: return(ReadArrayType()); case ElementType.SzArray: return(new ArrayType(ReadTypeReference((ElementType)this.ReadByte()))); case ElementType.Class: TypeReference typeRef; if (_netHeader.TablesHeap.TypeDefOrRef.TryGetMember((int)NETGlobals.ReadCompressedUInt32(this), out typeRef)) { return(typeRef); } break; case ElementType.ValueType: if (_netHeader.TablesHeap.TypeDefOrRef.TryGetMember((int)NETGlobals.ReadCompressedUInt32(this), out typeRef)) { typeRef.IsValueType = true; return(typeRef); } break; case ElementType.ByRef: return(new ByReferenceType(ReadTypeReference((ElementType)this.ReadByte()))); case ElementType.Pinned: return(new PinnedType(ReadTypeReference((ElementType)this.ReadByte()))); case ElementType.GenericInst: bool isValueType = this.ReadByte() == 0x11; TypeReference reference2 = ReadTypeToken(); GenericInstanceType instance = new GenericInstanceType(reference2); instance._genericArguments = ReadGenericArguments(); instance.IsValueType = isValueType; return(instance); case ElementType.CModOpt: return(new CustomModifierType(ReadTypeToken(), ReadTypeReference(), false)); case ElementType.CModReqD: return(new CustomModifierType(ReadTypeToken(), ReadTypeReference(), true)); } return(new TypeReference(string.Empty, type.ToString(), null) { _netheader = this._netHeader }); }