obfuz/Plugins/dnlib/DotNet/MD/StringsStream.cs

45 lines
1.3 KiB
C#
Raw Normal View History

// dnlib: See LICENSE.txt for more info
using dnlib.IO;
namespace dnlib.DotNet.MD {
/// <summary>
/// Represents the #Strings stream
/// </summary>
public sealed class StringsStream : HeapStream {
/// <inheritdoc/>
public StringsStream() {
}
/// <inheritdoc/>
public StringsStream(DataReaderFactory mdReaderFactory, uint metadataBaseOffset, StreamHeader streamHeader)
: base(mdReaderFactory, metadataBaseOffset, streamHeader) {
}
/// <summary>
/// Reads a <see cref="UTF8String"/>
/// </summary>
/// <param name="offset">Offset of string</param>
/// <returns>A <see cref="UTF8String"/> instance or <c>null</c> if invalid offset</returns>
public UTF8String Read(uint offset) {
if (offset >= StreamLength)
return null;
byte[] data;
var reader = dataReader;
reader.Position = offset;
data = reader.TryReadBytesUntil(0);
if (data is null)
return null;
return new UTF8String(data);
}
/// <summary>
/// Reads a <see cref="UTF8String"/>. The empty string is returned if <paramref name="offset"/>
/// is invalid.
/// </summary>
/// <param name="offset">Offset of string</param>
/// <returns>A <see cref="UTF8String"/> instance</returns>
public UTF8String ReadNoNull(uint offset) => Read(offset) ?? UTF8String.Empty;
}
}