Skip to content

Commit

Permalink
Marshal span status description without allocation (open-telemetry#6423)
Browse files Browse the repository at this point in the history
  • Loading branch information
laurit authored May 3, 2024
1 parent f8e6358 commit 2db5bb8
Showing 1 changed file with 5 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
import io.opentelemetry.exporter.internal.marshal.ProtoEnumInfo;
import io.opentelemetry.exporter.internal.marshal.Serializer;
import io.opentelemetry.exporter.internal.marshal.StatelessMarshaler;
import io.opentelemetry.exporter.internal.marshal.StatelessMarshalerUtil;
import io.opentelemetry.proto.trace.v1.internal.Status;
import io.opentelemetry.sdk.trace.data.StatusData;
import java.io.IOException;
Expand All @@ -24,20 +25,19 @@ final class SpanStatusStatelessMarshaler implements StatelessMarshaler<StatusDat
public void writeTo(Serializer output, StatusData status, MarshalerContext context)
throws IOException {
ProtoEnumInfo protoStatusCode = toProtoSpanStatus(status);
byte[] descriptionUtf8 = context.getData(byte[].class);

output.serializeString(Status.MESSAGE, descriptionUtf8);
output.serializeStringWithContext(Status.MESSAGE, status.getDescription(), context);
output.serializeEnum(Status.CODE, protoStatusCode);
}

@Override
public int getBinarySerializedSize(StatusData status, MarshalerContext context) {
ProtoEnumInfo protoStatusCode = toProtoSpanStatus(status);
byte[] descriptionUtf8 = MarshalerUtil.toBytes(status.getDescription());
context.addData(descriptionUtf8);

int size = 0;
size += MarshalerUtil.sizeBytes(Status.MESSAGE, descriptionUtf8);
size +=
StatelessMarshalerUtil.sizeStringWithContext(
Status.MESSAGE, status.getDescription(), context);
size += MarshalerUtil.sizeEnum(Status.CODE, protoStatusCode);

return size;
Expand Down

0 comments on commit 2db5bb8

Please sign in to comment.