Skip to content

Commit

Permalink
SpanData was errorneously defined as abstract (open-telemetry#106)
Browse files Browse the repository at this point in the history
  • Loading branch information
SergeyKanzhelev authored and Sergey Kanzhelev committed Feb 18, 2020
1 parent ed4ea31 commit 43d7bbf
Showing 1 changed file with 2 additions and 14 deletions.
16 changes: 2 additions & 14 deletions specification/tracing-api.md
Original file line number Diff line number Diff line change
Expand Up @@ -180,20 +180,8 @@ Order of attributes is not significant.

## SpanData

`SpanData` MUST be an abstract class or interface. As `SpanData` is used for the
code instrumentation, it is NOT expected alternative implementations of a
`SpanData` will be supplied by consumer of telemetry (i.e. telemetry vendor).
Typical use case for alternative implementations is to implement lazy
calculation of properties and minimize the number of allocation required at
instrumentation point. So it will be done by instrumentation code. For instance,
alternative implementation of `SpanData` may hold a reference on an object. And
all getters will be implemented by lazily calculating the required properties at
a moment that `SpanData` is passed to one of exporters.

Implementations of `SpanData` MUST return the same value in getters when that
getter was called multiple times. It is also discouraged to throw exceptions
from getters. Default value or value indicating an error SHOULD be returned
instead if possible.
`SpanData` is an immutable and final class. All getters of `SpanData` are thread
safe and can be called any number of times.

`API` MUST provide a way of [constructing `SpanData`](#constructing-spandata)
that can be recorded using `Tracer` method `RecordSpanData`.
Expand Down

0 comments on commit 43d7bbf

Please sign in to comment.