io.jaegertracing.zipkin.internal.ThriftSpanEncoder Maven / Gradle / Ivy
/*
* Copyright (c) 2016, Uber Technologies, Inc
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package io.jaegertracing.zipkin.internal;
import com.twitter.zipkin.thriftjava.Span;
import java.io.ByteArrayOutputStream;
import java.util.List;
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.transport.TIOStreamTransport;
import zipkin2.codec.BytesEncoder;
import zipkin2.codec.Encoding;
public final class ThriftSpanEncoder implements BytesEncoder {
@Override
public Encoding encoding() {
return Encoding.THRIFT;
}
@Override public int sizeInBytes(Span input) {
throw new UnsupportedOperationException("unused by internal code");
}
@Override
public byte[] encode(Span thriftSpan) {
// Clear any old data.
protocol.get().baos.reset();
try {
thriftSpan.write(protocol.get());
return protocol.get().baos.toByteArray();
} catch (TException e) {
throw new AssertionError(e);
}
}
@Override public byte[] encodeList(List input) {
throw new UnsupportedOperationException("unused by internal code");
}
static class ReusableTBinaryProtocol extends TBinaryProtocol {
private final ByteArrayOutputStream baos;
ReusableTBinaryProtocol(ByteArrayOutputStream baos) {
super(new TIOStreamTransport(baos));
this.baos = baos;
}
}
final ThreadLocal protocol =
new ThreadLocal() {
@Override
protected ReusableTBinaryProtocol initialValue() {
return new ReusableTBinaryProtocol(new ByteArrayOutputStream());
}
};
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy