foo_library.cc 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. // Copyright The OpenTelemetry Authors
  2. // SPDX-License-Identifier: Apache-2.0
  3. #include "opentelemetry/logs/logger.h"
  4. #include "opentelemetry/logs/logger_provider.h"
  5. #include "opentelemetry/logs/provider.h"
  6. #include "opentelemetry/nostd/shared_ptr.h"
  7. #include "opentelemetry/trace/provider.h"
  8. #include "opentelemetry/trace/scope.h"
  9. #include "opentelemetry/trace/span.h"
  10. #include "opentelemetry/trace/span_context.h"
  11. #include "opentelemetry/trace/tracer.h"
  12. #include "opentelemetry/trace/tracer_provider.h"
  13. namespace logs = opentelemetry::logs;
  14. namespace trace = opentelemetry::trace;
  15. namespace
  16. {
  17. opentelemetry::nostd::shared_ptr<trace::Tracer> get_tracer()
  18. {
  19. auto provider = trace::Provider::GetTracerProvider();
  20. return provider->GetTracer("foo_library");
  21. }
  22. opentelemetry::nostd::shared_ptr<logs::Logger> get_logger()
  23. {
  24. auto provider = logs::Provider::GetLoggerProvider();
  25. return provider->GetLogger("foo_library_logger", "foo_library");
  26. }
  27. } // namespace
  28. void foo_library()
  29. {
  30. auto span = get_tracer()->StartSpan("span 1");
  31. auto scoped_span = trace::Scope(get_tracer()->StartSpan("foo_library"));
  32. auto ctx = span->GetContext();
  33. auto logger = get_logger();
  34. logger->Debug("body", ctx.trace_id(), ctx.span_id(), ctx.trace_flags());
  35. }