File: dynamic_load-example.cpp

package info (click to toggle)
opentracing-cpp 1.6.0-4.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,572 kB
  • sloc: cpp: 14,234; ansic: 68; sh: 16; makefile: 5
file content (69 lines) | stat: -rw-r--r-- 2,007 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Demonstrates how to load a tracer library in at runtime and how to use it
// to construct spans. To run it using the mocktracer, invoke with
//
//     TRACER_CONFIG=`mktemp`
//     echo '{ "output_file": "/dev/stdout" }' > $TRACER_CONFIG
//     dynamic_load-example /path/to/libopentracing_mocktracer.so $TRACER_CONFIG

#include <opentracing/dynamic_load.h>
#include <cassert>
#include <cerrno>
#include <fstream>
#include <iostream>
#include <iterator>
#include <string>

#ifdef _MSC_VER
#pragma warning(push)
#pragma warning(disable : 4996)
#endif

int main(int argc, char* argv[]) {
  if (argc != 3) {
    std::cerr << "Usage: <tracer_library> <tracer_config_file>\n";
    return -1;
  }

  // Load the tracer library.
  std::string error_message;
  auto handle_maybe =
      opentracing::DynamicallyLoadTracingLibrary(argv[1], error_message);
  if (!handle_maybe) {
    std::cerr << "Failed to load tracer library " << error_message << "\n";
    return -1;
  }

  // Read in the tracer's configuration.
  std::ifstream istream{argv[2]};
  if (!istream.good()) {
    std::cerr << "Failed to open tracer config file " << argv[2] << ": "
              << std::strerror(errno) << "\n";
    return -1;
  }
  std::string tracer_config{std::istreambuf_iterator<char>{istream},
                            std::istreambuf_iterator<char>{}};

  // Construct a tracer.
  auto& tracer_factory = handle_maybe->tracer_factory();
  auto tracer_maybe =
      tracer_factory.MakeTracer(tracer_config.c_str(), error_message);
  if (!tracer_maybe) {
    std::cerr << "Failed to create tracer " << error_message << "\n";
    return -1;
  }
  auto& tracer = *tracer_maybe;

  // Use the tracer to create some spans.
  {
    auto span_a = tracer->StartSpan("A");
    assert(span_a != nullptr);
    span_a->SetTag("abc", 123);
    auto span_b =
        tracer->StartSpan("B", {opentracing::ChildOf(&span_a->context())});
    assert(span_b != nullptr);
    span_b->SetTag("xyz", 987);
  }

  tracer->Close();
  return 0;
}