-
Notifications
You must be signed in to change notification settings - Fork 443
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Please add default constructor and move constructor/assignment op to Scope class #1298
Comments
Scope object is meant to control the Span reference life cycle inside Context - It attaches Span to Context during creation and detaches during destruction. Creating Scope objects without Span may have an undesired behavior if not used properly. Also, going through your scenario above, I don't think you need a Scope object if you are explicitly ending the Span using |
This needs to be analyzed and documented. Maybe it is would be enough to track if Scope object is empty, and disallow assigning value to non-empty one (e.g. by throwing An alternative is to have some way to disable tracing, e.g. like discussed in open-telemetry/opentelemetry-specification#530 . BTW, in the meantime I found that Scope class has implicit move constructor, so I am able to dynamically move-create Scope like below. This workaround is good enough for me: std::unique_ptr<opentelemetry::trace::Scope> scope;
if (...)
scope = std::unique_ptr<opentelemetry::trace::Scope>(new opentelemetry::trace::Scope(tracer->WithActiveSpan(span)));
Deep inside |
This issue was marked as stale due to lack of activity. It will be closed in 7 days if no furthur activity occurs. |
@sirzooro, Do you think adding a new api (say) void EventLoop()
{
while (1)
{
auto obj = queue->Dequeue();
if (obj->TraceEnabled())
{
tracer->UseSpan(tracer->StartSpan(obj->GetName()));
}
obj->Run();
if (tracer->GetCurrentSpan()->GetContext()->IsValid()) {
tracer->GetCurrentSpan()->End();
}
}
} |
What |
My initial thought was not to use this in combination with the |
Some interaction is needed - |
Is your feature request related to a problem?
I have event loop which gets objects from a queue and processes them. I want to create Span in this loop and set is as active span. Some of these objects are for health checks, and I want to exclude them from telemetry. Span objects are stored in
nostd::shared_ptr
, so I can declare variable first and then conditionally assign value to it. However I cannot do the same with Scope object, declaration and initialization must happen at the same time.Describe the solution you'd like
Please add default constructor and move constructor/assignment operator to Scope class. This would allow to create empty Scope object first, and then conditionally move-assign value later.
Describe alternatives you've considered
Now I need to create two code branches - one for tracing enabled where code creates Scope object and perform processing, and another with processing only.
Additional context
This sample code presents what I would like to do:
The text was updated successfully, but these errors were encountered: