Loop the array of strings only once.

Remove unnecessary loop when marshaling lists of strings as pointers to UTF-8
bytes.
This commit is contained in:
Peter Huene
2020-02-24 18:26:26 -08:00
parent 78ee043524
commit a6ec8f85a6

View File

@@ -496,17 +496,13 @@ namespace Wasmtime
// See: https://github.com/dotnet/runtime/issues/7315
// Therefore, we need to marshal the strings manually
var handles = new GCHandle[strings.Count];
var ptrs = new byte*[strings.Count];
for (int i = 0; i < strings.Count; ++i)
{
handles[i] = GCHandle.Alloc(
Encoding.UTF8.GetBytes(strings[i] + '\0'),
GCHandleType.Pinned
);
}
var ptrs = new byte*[strings.Count];
for (int i = 0; i < strings.Count; ++i)
{
ptrs[i] = (byte*)handles[i].AddrOfPinnedObject();
}