Struct ExportedTypeRow
- Namespace
- AsmResolver.PE.DotNet.Metadata.Tables
- Assembly
- AsmResolver.PE.dll
Represents a single row in the exported type metadata table.
public struct ExportedTypeRow : IMetadataRow, IReadOnlyList<uint>, IReadOnlyCollection<uint>, IEnumerable<uint>, IEnumerable, IEquatable<ExportedTypeRow>
- Implements
- Inherited Members
Constructors
ExportedTypeRow(TypeAttributes, uint, uint, uint, uint)
Creates a new row for the exported type metadata table.
public ExportedTypeRow(TypeAttributes attributes, uint typeDefinitionId, uint name, uint ns, uint implementation)
Parameters
attributesTypeAttributesThe attributes associated to the exported type.
typeDefinitionIduintThe RID hint of the type definition that was exported.
nameuintThe index into the #Strings heap containing the name of the type reference.
nsuintThe index into the #Strings heap containing the namespace of the type reference.
implementationuintThe Implementation index (an index into either the File, ExportedType or AssemblyRef table), indicating the scope that can be used to resolve the exported type.
Properties
Attributes
Gets or sets the attributes associated to the exported type.
public TypeAttributes Attributes { readonly get; set; }
Property Value
Count
public int Count { get; }
Property Value
Implementation
Gets or sets an Implementation index (an index into either the File, ExportedType or AssemblyRef table), indicating the scope that can be used to resolve the exported type.
public uint Implementation { readonly get; set; }
Property Value
this[int]
public uint this[int index] { get; }
Parameters
indexint
Property Value
Name
Gets or sets an index into the #Strings heap containing the name of the type reference.
public uint Name { readonly get; set; }
Property Value
Remarks
This value should always index a non-empty string.
Namespace
Gets or sets an index into the #Strings heap containing the namespace of the type reference.
public uint Namespace { readonly get; set; }
Property Value
Remarks
This value can be zero. If it is not, it should always index a non-empty string.
TableIndex
Gets or sets the index of the table that this row is stored in.
public TableIndex TableIndex { get; }
Property Value
TypeDefinitionId
Gets or sets the RID hint of the type definition that was exported.
public uint TypeDefinitionId { readonly get; set; }
Property Value
Remarks
This field is used as a hint only. If the entry in the table does not match the name and namespace referenced by Name and Namespace respectively, then the CLR falls back to a search for the type definition.
Methods
Equals(ExportedTypeRow)
public bool Equals(ExportedTypeRow other)
Parameters
otherExportedTypeRow
Returns
Equals(object?)
public override bool Equals(object? obj)
Parameters
objobject
Returns
FromReader(ref BinaryStreamReader, TableLayout)
Reads a single exported type row from an input stream.
public static ExportedTypeRow FromReader(ref BinaryStreamReader reader, TableLayout layout)
Parameters
readerBinaryStreamReaderThe input stream.
layoutTableLayoutThe layout of the exported type table.
Returns
- ExportedTypeRow
The row.
GetEnumerator()
public IEnumerator<uint> GetEnumerator()
Returns
GetHashCode()
public override int GetHashCode()
Returns
ToString()
public override string ToString()
Returns
Write(BinaryStreamWriter, TableLayout)
Writes the row to an output stream.
public void Write(BinaryStreamWriter writer, TableLayout layout)
Parameters
writerBinaryStreamWriterThe output stream writer.
layoutTableLayoutThe new layout of the table.
Operators
operator ==(ExportedTypeRow, ExportedTypeRow)
Determines whether two rows are considered equal.
public static bool operator ==(ExportedTypeRow left, ExportedTypeRow right)
Parameters
leftExportedTypeRowrightExportedTypeRow
Returns
operator !=(ExportedTypeRow, ExportedTypeRow)
Determines whether two rows are not considered equal.
public static bool operator !=(ExportedTypeRow left, ExportedTypeRow right)
Parameters
leftExportedTypeRowrightExportedTypeRow