libdatadog 19.1.0.1.0 → 21.0.0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/libdatadog/version.rb +1 -1
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/bin/libdatadog-crashtracking-receiver +0 -0
- data/vendor/{libdatadog-19.1.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-21.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu}/include/datadog/common.h +569 -527
- data/vendor/{libdatadog-19.1.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-21.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu}/include/datadog/crashtracker.h +0 -34
- data/vendor/{libdatadog-19.1.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-21.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu}/include/datadog/data-pipeline.h +9 -11
- data/vendor/libdatadog-21.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/include/datadog/ddsketch.h +89 -0
- data/vendor/{libdatadog-19.1.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-21.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu}/include/datadog/library-config.h +2 -2
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/include/datadog/profiling.h +2 -1
- data/vendor/libdatadog-21.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/lib/libdatadog_profiling.debug +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
- data/vendor/libdatadog-21.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/libdatadog_v21.0.0.tar +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/bin/libdatadog-crashtracking-receiver +0 -0
- data/vendor/{libdatadog-19.1.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-21.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl}/include/datadog/common.h +569 -527
- data/vendor/{libdatadog-19.1.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-21.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl}/include/datadog/crashtracker.h +0 -34
- data/vendor/{libdatadog-19.1.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-21.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl}/include/datadog/data-pipeline.h +9 -11
- data/vendor/libdatadog-21.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/include/datadog/ddsketch.h +89 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/include/datadog/library-config.h +2 -2
- data/vendor/{libdatadog-19.1.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-21.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl}/include/datadog/profiling.h +2 -1
- data/vendor/libdatadog-21.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/lib/libdatadog_profiling.debug +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
- data/vendor/libdatadog-21.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/libdatadog_v21.0.0.tar +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/bin/libdatadog-crashtracking-receiver +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/common.h +569 -527
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/crashtracker.h +0 -34
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/data-pipeline.h +9 -11
- data/vendor/libdatadog-21.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/ddsketch.h +89 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/library-config.h +2 -2
- data/vendor/{libdatadog-19.1.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-21.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu}/include/datadog/profiling.h +2 -1
- data/vendor/libdatadog-21.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/libdatadog_profiling.debug +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
- data/vendor/libdatadog-21.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/libdatadog_v21.0.0.tar +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/bin/libdatadog-crashtracking-receiver +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/include/datadog/common.h +569 -527
- data/vendor/{libdatadog-19.1.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-21.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl}/include/datadog/crashtracker.h +0 -34
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/include/datadog/data-pipeline.h +9 -11
- data/vendor/libdatadog-21.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/include/datadog/ddsketch.h +89 -0
- data/vendor/{libdatadog-19.1.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-21.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl}/include/datadog/library-config.h +2 -2
- data/vendor/{libdatadog-19.1.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-21.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl}/include/datadog/profiling.h +2 -1
- data/vendor/libdatadog-21.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/libdatadog_profiling.debug +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
- data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
- data/vendor/libdatadog-21.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/libdatadog_v21.0.0.tar +0 -0
- metadata +57 -57
- data/vendor/libdatadog-19.1.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/LICENSE +0 -202
- data/vendor/libdatadog-19.1.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/LICENSE-3rdparty.yml +0 -50849
- data/vendor/libdatadog-19.1.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/NOTICE +0 -4
- data/vendor/libdatadog-19.1.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/LICENSE +0 -202
- data/vendor/libdatadog-19.1.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/LICENSE-3rdparty.yml +0 -50849
- data/vendor/libdatadog-19.1.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/NOTICE +0 -4
- data/vendor/libdatadog-19.1.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/LICENSE +0 -202
- data/vendor/libdatadog-19.1.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/LICENSE-3rdparty.yml +0 -50849
- data/vendor/libdatadog-19.1.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/NOTICE +0 -4
- data/vendor/libdatadog-19.1.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/LICENSE +0 -202
- data/vendor/libdatadog-19.1.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/LICENSE-3rdparty.yml +0 -50849
- data/vendor/libdatadog-19.1.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/NOTICE +0 -4
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/include/datadog/blazesym.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/include/datadog/log.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/include/datadog/telemetry.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/include/datadog/blazesym.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/include/datadog/log.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/include/datadog/telemetry.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/blazesym.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/log.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/telemetry.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/include/datadog/blazesym.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/include/datadog/log.h +0 -0
- /data/vendor/{libdatadog-19.1.0 → libdatadog-21.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/include/datadog/telemetry.h +0 -0
@@ -792,9 +792,9 @@ typedef struct ddog_prof_FunctionId_Result {
|
|
792
792
|
* A value of 0 means "no string" or "empty string" (they are synonymous).
|
793
793
|
*/
|
794
794
|
typedef struct OpaqueStringId {
|
795
|
-
uint32_t
|
795
|
+
uint32_t offset;
|
796
796
|
} OpaqueStringId;
|
797
|
-
#define OpaqueStringId_ZERO (OpaqueStringId){
|
797
|
+
#define OpaqueStringId_ZERO (OpaqueStringId){ }
|
798
798
|
|
799
799
|
typedef struct OpaqueStringId OpaqueStringId;
|
800
800
|
|
@@ -1224,695 +1224,737 @@ typedef struct ddog_ContextKey {
|
|
1224
1224
|
enum ddog_MetricType _1;
|
1225
1225
|
} ddog_ContextKey;
|
1226
1226
|
|
1227
|
-
|
1228
|
-
|
1229
|
-
|
1230
|
-
|
1231
|
-
|
1232
|
-
|
1233
|
-
|
1234
|
-
|
1235
|
-
|
1236
|
-
|
1237
|
-
|
1238
|
-
|
1239
|
-
|
1240
|
-
|
1241
|
-
|
1242
|
-
|
1243
|
-
|
1244
|
-
|
1245
|
-
|
1246
|
-
|
1247
|
-
|
1248
|
-
|
1249
|
-
|
1227
|
+
/**
|
1228
|
+
* Represent error codes that `Error` struct can hold
|
1229
|
+
*/
|
1230
|
+
typedef enum ddog_TraceExporterErrorCode {
|
1231
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_ADDRESS_IN_USE,
|
1232
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_CONNECTION_ABORTED,
|
1233
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_CONNECTION_REFUSED,
|
1234
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_CONNECTION_RESET,
|
1235
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_BODY_FORMAT,
|
1236
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_BODY_TOO_LONG,
|
1237
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_CLIENT,
|
1238
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_EMPTY_BODY,
|
1239
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_PARSE,
|
1240
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_SERVER,
|
1241
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_UNKNOWN,
|
1242
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_WRONG_STATUS,
|
1243
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_ARGUMENT,
|
1244
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_DATA,
|
1245
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_INPUT,
|
1246
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_URL,
|
1247
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_IO_ERROR,
|
1248
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_NETWORK_UNKNOWN,
|
1249
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_SERDE,
|
1250
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_SHUTDOWN,
|
1251
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_TIMED_OUT,
|
1252
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_TELEMETRY,
|
1253
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_INTERNAL,
|
1254
|
+
DDOG_TRACE_EXPORTER_ERROR_CODE_PANIC,
|
1255
|
+
} ddog_TraceExporterErrorCode;
|
1250
1256
|
|
1251
1257
|
/**
|
1252
|
-
*
|
1253
|
-
*
|
1254
|
-
* The idea is that if a crash consistently occurs while a particular operation
|
1255
|
-
* is ongoing, its likely related.
|
1256
|
-
*
|
1257
|
-
* In the future, we might also track wall-clock time of operations
|
1258
|
-
* (or some statistical sampling thereof) using the same enum.
|
1258
|
+
* Structure containing the agent response to a trace payload
|
1259
|
+
* MUST be freed with `ddog_trace_exporter_response_free`
|
1259
1260
|
*
|
1260
|
-
*
|
1261
|
-
*
|
1261
|
+
* If the agent payload version is enabled on the trace exporter, and
|
1262
|
+
* the agent response indicates that the payload version hasn't changed,
|
1263
|
+
* the body will be empty.
|
1262
1264
|
*/
|
1263
|
-
typedef
|
1264
|
-
|
1265
|
-
|
1266
|
-
DDOG_CRASHT_OP_TYPES_PROFILER_UNWINDING,
|
1267
|
-
DDOG_CRASHT_OP_TYPES_PROFILER_SERIALIZING,
|
1268
|
-
/**
|
1269
|
-
* Dummy value to allow easier iteration
|
1270
|
-
*/
|
1271
|
-
DDOG_CRASHT_OP_TYPES_SIZE,
|
1272
|
-
} ddog_crasht_OpTypes;
|
1265
|
+
typedef struct ddog_TraceExporterResponse ddog_TraceExporterResponse;
|
1266
|
+
|
1267
|
+
typedef struct ddog_TraceExporter ddog_TraceExporter;
|
1273
1268
|
|
1274
1269
|
/**
|
1275
|
-
*
|
1276
|
-
*
|
1270
|
+
* The TraceExporterConfig object will hold the configuration properties for the TraceExporter.
|
1271
|
+
* Once the configuration is passed to the TraceExporter constructor the config is no longer
|
1272
|
+
* needed by the handle and it can be freed.
|
1277
1273
|
*/
|
1278
|
-
typedef
|
1279
|
-
DDOG_CRASHT_SI_CODES_BUS_ADRALN,
|
1280
|
-
DDOG_CRASHT_SI_CODES_BUS_ADRERR,
|
1281
|
-
DDOG_CRASHT_SI_CODES_BUS_MCEERR_AO,
|
1282
|
-
DDOG_CRASHT_SI_CODES_BUS_MCEERR_AR,
|
1283
|
-
DDOG_CRASHT_SI_CODES_BUS_OBJERR,
|
1284
|
-
DDOG_CRASHT_SI_CODES_ILL_BADSTK,
|
1285
|
-
DDOG_CRASHT_SI_CODES_ILL_COPROC,
|
1286
|
-
DDOG_CRASHT_SI_CODES_ILL_ILLADR,
|
1287
|
-
DDOG_CRASHT_SI_CODES_ILL_ILLOPC,
|
1288
|
-
DDOG_CRASHT_SI_CODES_ILL_ILLOPN,
|
1289
|
-
DDOG_CRASHT_SI_CODES_ILL_ILLTRP,
|
1290
|
-
DDOG_CRASHT_SI_CODES_ILL_PRVOPC,
|
1291
|
-
DDOG_CRASHT_SI_CODES_ILL_PRVREG,
|
1292
|
-
DDOG_CRASHT_SI_CODES_SEGV_ACCERR,
|
1293
|
-
DDOG_CRASHT_SI_CODES_SEGV_BNDERR,
|
1294
|
-
DDOG_CRASHT_SI_CODES_SEGV_MAPERR,
|
1295
|
-
DDOG_CRASHT_SI_CODES_SEGV_PKUERR,
|
1296
|
-
DDOG_CRASHT_SI_CODES_SI_ASYNCIO,
|
1297
|
-
DDOG_CRASHT_SI_CODES_SI_KERNEL,
|
1298
|
-
DDOG_CRASHT_SI_CODES_SI_MESGQ,
|
1299
|
-
DDOG_CRASHT_SI_CODES_SI_QUEUE,
|
1300
|
-
DDOG_CRASHT_SI_CODES_SI_SIGIO,
|
1301
|
-
DDOG_CRASHT_SI_CODES_SI_TIMER,
|
1302
|
-
DDOG_CRASHT_SI_CODES_SI_TKILL,
|
1303
|
-
DDOG_CRASHT_SI_CODES_SI_USER,
|
1304
|
-
DDOG_CRASHT_SI_CODES_SYS_SECCOMP,
|
1305
|
-
DDOG_CRASHT_SI_CODES_UNKNOWN,
|
1306
|
-
} ddog_crasht_SiCodes;
|
1274
|
+
typedef struct ddog_TraceExporterConfig ddog_TraceExporterConfig;
|
1307
1275
|
|
1308
1276
|
/**
|
1309
|
-
*
|
1277
|
+
* Structure that contains error information that `TraceExporter` API can return.
|
1310
1278
|
*/
|
1311
|
-
typedef
|
1312
|
-
|
1313
|
-
|
1314
|
-
|
1315
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGILL,
|
1316
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGTRAP,
|
1317
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGABRT,
|
1318
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGBUS,
|
1319
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGFPE,
|
1320
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGKILL,
|
1321
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGUSR1,
|
1322
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGSEGV,
|
1323
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGUSR2,
|
1324
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGPIPE,
|
1325
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGALRM,
|
1326
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGTERM,
|
1327
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGCHLD,
|
1328
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGCONT,
|
1329
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGSTOP,
|
1330
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGTSTP,
|
1331
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGTTIN,
|
1332
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGTTOU,
|
1333
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGURG,
|
1334
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGXCPU,
|
1335
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGXFSZ,
|
1336
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGVTALRM,
|
1337
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGPROF,
|
1338
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGWINCH,
|
1339
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGIO,
|
1340
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGSYS,
|
1341
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGEMT,
|
1342
|
-
DDOG_CRASHT_SIGNAL_NAMES_SIGINFO,
|
1343
|
-
DDOG_CRASHT_SIGNAL_NAMES_UNKNOWN,
|
1344
|
-
} ddog_crasht_SignalNames;
|
1279
|
+
typedef struct ddog_TraceExporterError {
|
1280
|
+
enum ddog_TraceExporterErrorCode code;
|
1281
|
+
char *msg;
|
1282
|
+
} ddog_TraceExporterError;
|
1345
1283
|
|
1346
1284
|
/**
|
1347
|
-
*
|
1348
|
-
* If the stack is sufficiently corruputed, it is possible (but unlikely),
|
1349
|
-
* for stack trace collection itself to crash.
|
1350
|
-
* We recommend fully enabling stacktrace collection, but having an environment
|
1351
|
-
* variable to allow downgrading the collector.
|
1285
|
+
* FFI compatible configuration for the TelemetryClient.
|
1352
1286
|
*/
|
1353
|
-
typedef
|
1287
|
+
typedef struct ddog_TelemetryClientConfig {
|
1354
1288
|
/**
|
1355
|
-
*
|
1289
|
+
* How often telemetry should be sent, in milliseconds.
|
1356
1290
|
*/
|
1357
|
-
|
1358
|
-
DDOG_CRASHT_STACKTRACE_COLLECTION_WITHOUT_SYMBOLS,
|
1291
|
+
uint64_t interval;
|
1359
1292
|
/**
|
1360
|
-
*
|
1361
|
-
*
|
1362
|
-
*
|
1363
|
-
*
|
1293
|
+
* A V4 UUID that represents a tracer session. This ID should:
|
1294
|
+
* - Be generated when the tracer starts
|
1295
|
+
* - Be identical within the context of a host (i.e. multiple threads/processes that belong to
|
1296
|
+
* a single instrumented app should share the same runtime_id)
|
1297
|
+
* - Be associated with traces to allow correlation between traces and telemetry data
|
1364
1298
|
*/
|
1365
|
-
|
1366
|
-
|
1367
|
-
|
1368
|
-
|
1369
|
-
|
1370
|
-
|
1371
|
-
|
1299
|
+
ddog_CharSlice runtime_id;
|
1300
|
+
/**
|
1301
|
+
* Whether to enable debug mode for telemetry.
|
1302
|
+
* When enabled, sets the DD-Telemetry-Debug-Enabled header to true.
|
1303
|
+
* Defaults to false.
|
1304
|
+
*/
|
1305
|
+
bool debug_enabled;
|
1306
|
+
} ddog_TelemetryClientConfig;
|
1372
1307
|
|
1373
|
-
typedef
|
1308
|
+
typedef enum ddog_LibraryConfigSource {
|
1309
|
+
DDOG_LIBRARY_CONFIG_SOURCE_LOCAL_STABLE_CONFIG = 0,
|
1310
|
+
DDOG_LIBRARY_CONFIG_SOURCE_FLEET_STABLE_CONFIG = 1,
|
1311
|
+
} ddog_LibraryConfigSource;
|
1374
1312
|
|
1375
|
-
typedef struct
|
1313
|
+
typedef struct ddog_Configurator ddog_Configurator;
|
1376
1314
|
|
1377
|
-
|
1315
|
+
/**
|
1316
|
+
* Ffi safe type representing a borrowed null-terminated C array
|
1317
|
+
* Equivalent to a std::ffi::CStr
|
1318
|
+
*/
|
1319
|
+
typedef struct ddog_CStr {
|
1378
1320
|
/**
|
1379
|
-
*
|
1380
|
-
* allowed but not recommended for the pointer to be null when the len is
|
1381
|
-
* zero.
|
1321
|
+
* Null terminated char array
|
1382
1322
|
*/
|
1383
|
-
|
1323
|
+
char *ptr;
|
1384
1324
|
/**
|
1385
|
-
*
|
1386
|
-
* than or equal to [isize::MAX].
|
1325
|
+
* Length of the array, not counting the null-terminator
|
1387
1326
|
*/
|
1388
|
-
uintptr_t
|
1389
|
-
}
|
1327
|
+
uintptr_t length;
|
1328
|
+
} ddog_CStr;
|
1390
1329
|
|
1391
|
-
typedef struct
|
1330
|
+
typedef struct ddog_Slice_CharSlice {
|
1392
1331
|
/**
|
1393
1332
|
* Should be non-null and suitably aligned for the underlying type. It is
|
1394
1333
|
* allowed but not recommended for the pointer to be null when the len is
|
1395
1334
|
* zero.
|
1396
1335
|
*/
|
1397
|
-
const
|
1336
|
+
const ddog_CharSlice *ptr;
|
1398
1337
|
/**
|
1399
1338
|
* The number of elements (not bytes) that `.ptr` points to. Must be less
|
1400
1339
|
* than or equal to [isize::MAX].
|
1401
1340
|
*/
|
1402
1341
|
uintptr_t len;
|
1403
|
-
}
|
1342
|
+
} ddog_Slice_CharSlice;
|
1404
1343
|
|
1405
|
-
typedef struct
|
1406
|
-
struct
|
1407
|
-
|
1408
|
-
|
1409
|
-
|
1410
|
-
|
1411
|
-
|
1412
|
-
|
1413
|
-
|
1344
|
+
typedef struct ddog_ProcessInfo {
|
1345
|
+
struct ddog_Slice_CharSlice args;
|
1346
|
+
struct ddog_Slice_CharSlice envp;
|
1347
|
+
ddog_CharSlice language;
|
1348
|
+
} ddog_ProcessInfo;
|
1349
|
+
|
1350
|
+
/**
|
1351
|
+
* Ffi safe type representing an owned null-terminated C array
|
1352
|
+
* Equivalent to a std::ffi::CString
|
1353
|
+
*/
|
1354
|
+
typedef struct ddog_CString {
|
1414
1355
|
/**
|
1415
|
-
*
|
1356
|
+
* Null terminated char array
|
1416
1357
|
*/
|
1417
|
-
|
1418
|
-
enum ddog_crasht_StacktraceCollection resolve_frames;
|
1358
|
+
char *ptr;
|
1419
1359
|
/**
|
1420
|
-
*
|
1421
|
-
* If empty, use the default set.
|
1360
|
+
* Length of the array, not counting the null-terminator
|
1422
1361
|
*/
|
1423
|
-
|
1424
|
-
|
1425
|
-
* Timeout in milliseconds before the signal handler starts tearing things down to return.
|
1426
|
-
* If 0, uses the default timeout as specified in
|
1427
|
-
* `datadog_crashtracker::shared::constants::DD_CRASHTRACK_DEFAULT_TIMEOUT`. Otherwise, uses
|
1428
|
-
* the specified timeout value.
|
1429
|
-
* This is given as a uint32_t, but the actual timeout needs to fit inside of an i32 (max
|
1430
|
-
* 2^31-1). This is a limitation of the various interfaces used to guarantee the timeout.
|
1431
|
-
*/
|
1432
|
-
uint32_t timeout_ms;
|
1433
|
-
bool use_alt_stack;
|
1434
|
-
} ddog_crasht_Config;
|
1435
|
-
|
1436
|
-
typedef struct ddog_crasht_EnvVar {
|
1437
|
-
ddog_CharSlice key;
|
1438
|
-
ddog_CharSlice val;
|
1439
|
-
} ddog_crasht_EnvVar;
|
1440
|
-
|
1441
|
-
typedef struct ddog_crasht_Slice_EnvVar {
|
1442
|
-
/**
|
1443
|
-
* Should be non-null and suitably aligned for the underlying type. It is
|
1444
|
-
* allowed but not recommended for the pointer to be null when the len is
|
1445
|
-
* zero.
|
1446
|
-
*/
|
1447
|
-
const struct ddog_crasht_EnvVar *ptr;
|
1448
|
-
/**
|
1449
|
-
* The number of elements (not bytes) that `.ptr` points to. Must be less
|
1450
|
-
* than or equal to [isize::MAX].
|
1451
|
-
*/
|
1452
|
-
uintptr_t len;
|
1453
|
-
} ddog_crasht_Slice_EnvVar;
|
1454
|
-
|
1455
|
-
typedef struct ddog_crasht_ReceiverConfig {
|
1456
|
-
struct ddog_crasht_Slice_CharSlice args;
|
1457
|
-
struct ddog_crasht_Slice_EnvVar env;
|
1458
|
-
ddog_CharSlice path_to_receiver_binary;
|
1459
|
-
/**
|
1460
|
-
* Optional filename to forward stderr to (useful for logging/debugging)
|
1461
|
-
*/
|
1462
|
-
ddog_CharSlice optional_stderr_filename;
|
1463
|
-
/**
|
1464
|
-
* Optional filename to forward stdout to (useful for logging/debugging)
|
1465
|
-
*/
|
1466
|
-
ddog_CharSlice optional_stdout_filename;
|
1467
|
-
} ddog_crasht_ReceiverConfig;
|
1362
|
+
uintptr_t length;
|
1363
|
+
} ddog_CString;
|
1468
1364
|
|
1469
|
-
typedef struct
|
1470
|
-
|
1471
|
-
|
1472
|
-
|
1473
|
-
|
1474
|
-
|
1475
|
-
*/
|
1476
|
-
const struct ddog_Vec_Tag *tags;
|
1477
|
-
} ddog_crasht_Metadata;
|
1365
|
+
typedef struct ddog_LibraryConfig {
|
1366
|
+
struct ddog_CString name;
|
1367
|
+
struct ddog_CString value;
|
1368
|
+
enum ddog_LibraryConfigSource source;
|
1369
|
+
struct ddog_CString config_id;
|
1370
|
+
} ddog_LibraryConfig;
|
1478
1371
|
|
1479
|
-
|
1480
|
-
|
1481
|
-
|
1482
|
-
|
1483
|
-
|
1484
|
-
|
1485
|
-
const int *ptr;
|
1486
|
-
/**
|
1487
|
-
* The number of elements (not bytes) that `.ptr` points to. Must be less
|
1488
|
-
* than or equal to [isize::MAX].
|
1489
|
-
*/
|
1372
|
+
/**
|
1373
|
+
* Holds the raw parts of a Rust Vec; it should only be created from Rust,
|
1374
|
+
* never from C.
|
1375
|
+
*/
|
1376
|
+
typedef struct ddog_Vec_LibraryConfig {
|
1377
|
+
const struct ddog_LibraryConfig *ptr;
|
1490
1378
|
uintptr_t len;
|
1491
|
-
|
1379
|
+
uintptr_t capacity;
|
1380
|
+
} ddog_Vec_LibraryConfig;
|
1492
1381
|
|
1493
1382
|
/**
|
1494
|
-
* A
|
1495
|
-
* or may return <T> in case of success.
|
1383
|
+
* A result type that includes debug/log messages along with the data
|
1496
1384
|
*/
|
1497
|
-
typedef
|
1498
|
-
|
1499
|
-
|
1500
|
-
}
|
1385
|
+
typedef struct ddog_OkResult {
|
1386
|
+
struct ddog_Vec_LibraryConfig value;
|
1387
|
+
struct ddog_CString logs;
|
1388
|
+
} ddog_OkResult;
|
1501
1389
|
|
1502
|
-
typedef
|
1503
|
-
|
1390
|
+
typedef enum ddog_LibraryConfigLoggedResult_Tag {
|
1391
|
+
DDOG_LIBRARY_CONFIG_LOGGED_RESULT_OK,
|
1392
|
+
DDOG_LIBRARY_CONFIG_LOGGED_RESULT_ERR,
|
1393
|
+
} ddog_LibraryConfigLoggedResult_Tag;
|
1394
|
+
|
1395
|
+
typedef struct ddog_LibraryConfigLoggedResult {
|
1396
|
+
ddog_LibraryConfigLoggedResult_Tag tag;
|
1504
1397
|
union {
|
1505
1398
|
struct {
|
1506
|
-
|
1399
|
+
struct ddog_OkResult ok;
|
1507
1400
|
};
|
1508
1401
|
struct {
|
1509
1402
|
struct ddog_Error err;
|
1510
1403
|
};
|
1511
1404
|
};
|
1512
|
-
}
|
1405
|
+
} ddog_LibraryConfigLoggedResult;
|
1513
1406
|
|
1514
1407
|
/**
|
1515
|
-
*
|
1516
|
-
* Do not access its member for any reason, only use the C API functions on this struct.
|
1408
|
+
* C-compatible representation of an anonymous file handle
|
1517
1409
|
*/
|
1518
|
-
typedef struct
|
1519
|
-
|
1520
|
-
|
1410
|
+
typedef struct ddog_TracerMemfdHandle {
|
1411
|
+
/**
|
1412
|
+
* File descriptor (relevant only on Linux)
|
1413
|
+
*/
|
1414
|
+
int fd;
|
1415
|
+
} ddog_TracerMemfdHandle;
|
1521
1416
|
|
1522
1417
|
/**
|
1523
|
-
*
|
1524
|
-
*
|
1418
|
+
* A generic result type for when an operation may fail,
|
1419
|
+
* or may return <T> in case of success.
|
1525
1420
|
*/
|
1526
|
-
typedef
|
1527
|
-
|
1528
|
-
|
1529
|
-
|
1530
|
-
typedef enum ddog_crasht_CrashInfo_NewResult_Tag {
|
1531
|
-
DDOG_CRASHT_CRASH_INFO_NEW_RESULT_OK,
|
1532
|
-
DDOG_CRASHT_CRASH_INFO_NEW_RESULT_ERR,
|
1533
|
-
} ddog_crasht_CrashInfo_NewResult_Tag;
|
1421
|
+
typedef enum ddog_Result_TracerMemfdHandle_Tag {
|
1422
|
+
DDOG_RESULT_TRACER_MEMFD_HANDLE_OK_TRACER_MEMFD_HANDLE,
|
1423
|
+
DDOG_RESULT_TRACER_MEMFD_HANDLE_ERR_TRACER_MEMFD_HANDLE,
|
1424
|
+
} ddog_Result_TracerMemfdHandle_Tag;
|
1534
1425
|
|
1535
|
-
typedef struct
|
1536
|
-
|
1426
|
+
typedef struct ddog_Result_TracerMemfdHandle {
|
1427
|
+
ddog_Result_TracerMemfdHandle_Tag tag;
|
1537
1428
|
union {
|
1538
1429
|
struct {
|
1539
|
-
struct
|
1430
|
+
struct ddog_TracerMemfdHandle ok;
|
1540
1431
|
};
|
1541
1432
|
struct {
|
1542
1433
|
struct ddog_Error err;
|
1543
1434
|
};
|
1544
1435
|
};
|
1545
|
-
}
|
1546
|
-
|
1547
|
-
typedef struct ddog_crasht_OsInfo {
|
1548
|
-
ddog_CharSlice architecture;
|
1549
|
-
ddog_CharSlice bitness;
|
1550
|
-
ddog_CharSlice os_type;
|
1551
|
-
ddog_CharSlice version;
|
1552
|
-
} ddog_crasht_OsInfo;
|
1436
|
+
} ddog_Result_TracerMemfdHandle;
|
1553
1437
|
|
1554
|
-
|
1555
|
-
|
1556
|
-
|
1438
|
+
/**
|
1439
|
+
* Log level for filtering log events.
|
1440
|
+
*/
|
1441
|
+
typedef enum ddog_LogEventLevel {
|
1442
|
+
/**
|
1443
|
+
* The "trace" level.
|
1444
|
+
*
|
1445
|
+
* Designates very low priority, often extremely verbose, information.
|
1446
|
+
*/
|
1447
|
+
DDOG_LOG_EVENT_LEVEL_TRACE = 0,
|
1448
|
+
/**
|
1449
|
+
* The "debug" level.
|
1450
|
+
*
|
1451
|
+
* Designates lower priority information.
|
1452
|
+
*/
|
1453
|
+
DDOG_LOG_EVENT_LEVEL_DEBUG = 1,
|
1454
|
+
/**
|
1455
|
+
* The "info" level.
|
1456
|
+
*
|
1457
|
+
* Designates useful information.
|
1458
|
+
*/
|
1459
|
+
DDOG_LOG_EVENT_LEVEL_INFO = 2,
|
1460
|
+
/**
|
1461
|
+
* The "warn" level.
|
1462
|
+
*
|
1463
|
+
* Designates hazardous situations.
|
1464
|
+
*/
|
1465
|
+
DDOG_LOG_EVENT_LEVEL_WARN = 3,
|
1466
|
+
/**
|
1467
|
+
* The "error" level.
|
1468
|
+
*
|
1469
|
+
* Designates very serious errors.
|
1470
|
+
*/
|
1471
|
+
DDOG_LOG_EVENT_LEVEL_ERROR = 4,
|
1472
|
+
} ddog_LogEventLevel;
|
1557
1473
|
|
1558
|
-
|
1559
|
-
|
1560
|
-
|
1561
|
-
|
1562
|
-
|
1563
|
-
|
1564
|
-
|
1474
|
+
/**
|
1475
|
+
* Target for standard stream output.
|
1476
|
+
*/
|
1477
|
+
typedef enum ddog_StdTarget {
|
1478
|
+
/**
|
1479
|
+
* Write to standard output (stdout).
|
1480
|
+
*/
|
1481
|
+
DDOG_STD_TARGET_OUT,
|
1482
|
+
/**
|
1483
|
+
* Write to standard error (stderr).
|
1484
|
+
*/
|
1485
|
+
DDOG_STD_TARGET_ERR,
|
1486
|
+
} ddog_StdTarget;
|
1565
1487
|
|
1566
|
-
|
1567
|
-
|
1568
|
-
|
1569
|
-
|
1488
|
+
/**
|
1489
|
+
* Configuration for standard stream output.
|
1490
|
+
*/
|
1491
|
+
typedef struct ddog_StdConfig {
|
1492
|
+
/**
|
1493
|
+
* Target stream (stdout or stderr)
|
1494
|
+
*/
|
1495
|
+
enum ddog_StdTarget target;
|
1496
|
+
} ddog_StdConfig;
|
1570
1497
|
|
1571
1498
|
/**
|
1572
|
-
*
|
1573
|
-
* Do not access its member for any reason, only use the C API functions on this struct.
|
1499
|
+
* Configuration for file output.
|
1574
1500
|
*/
|
1575
|
-
typedef struct
|
1576
|
-
|
1577
|
-
|
1501
|
+
typedef struct ddog_FileConfig {
|
1502
|
+
/**
|
1503
|
+
* Path to the log file
|
1504
|
+
*/
|
1505
|
+
ddog_CharSlice path;
|
1506
|
+
/**
|
1507
|
+
* Maximum total number of files (current + rotated) to keep on disk.
|
1508
|
+
* When this limit is exceeded, the oldest rotated files are deleted.
|
1509
|
+
* Set to 0 to disable file cleanup.
|
1510
|
+
*/
|
1511
|
+
uint64_t max_files;
|
1512
|
+
/**
|
1513
|
+
* Maximum size in bytes for each log file.
|
1514
|
+
* Set to 0 to disable size-based rotation.
|
1515
|
+
*/
|
1516
|
+
uint64_t max_size_bytes;
|
1517
|
+
} ddog_FileConfig;
|
1578
1518
|
|
1579
|
-
|
1580
|
-
|
1581
|
-
|
1582
|
-
|
1583
|
-
|
1584
|
-
|
1519
|
+
/**
|
1520
|
+
* This is a minimal DDSketch implementation
|
1521
|
+
*
|
1522
|
+
* This implementation only supports a part of the standard (which is also only the parts dd
|
1523
|
+
* backend supports :shrug:)
|
1524
|
+
* - max length contiguous bin store, with lower bin collapse behavior.
|
1525
|
+
* - Positive or zero values
|
1526
|
+
*
|
1527
|
+
* The default sketch has a 1% relative accuracy, and only accepts positive points
|
1528
|
+
*
|
1529
|
+
* See <https://github.com/DataDog/sketches-go> for the reference implementation
|
1530
|
+
*/
|
1531
|
+
typedef struct ddsketch_DDSketch ddsketch_DDSketch;
|
1585
1532
|
|
1586
1533
|
/**
|
1587
1534
|
* Represents an object that should only be referred to by its handle.
|
1588
1535
|
* Do not access its member for any reason, only use the C API functions on this struct.
|
1589
1536
|
*/
|
1590
|
-
typedef struct
|
1591
|
-
struct
|
1592
|
-
}
|
1537
|
+
typedef struct ddsketch_Handle_DDSketch {
|
1538
|
+
struct ddsketch_DDSketch *inner;
|
1539
|
+
} ddsketch_Handle_DDSketch;
|
1593
1540
|
|
1594
|
-
typedef enum
|
1595
|
-
|
1596
|
-
|
1597
|
-
|
1541
|
+
typedef enum ddog_crasht_BuildIdType {
|
1542
|
+
DDOG_CRASHT_BUILD_ID_TYPE_GNU,
|
1543
|
+
DDOG_CRASHT_BUILD_ID_TYPE_GO,
|
1544
|
+
DDOG_CRASHT_BUILD_ID_TYPE_PDB,
|
1545
|
+
DDOG_CRASHT_BUILD_ID_TYPE_SHA1,
|
1546
|
+
} ddog_crasht_BuildIdType;
|
1598
1547
|
|
1599
|
-
typedef
|
1600
|
-
|
1601
|
-
|
1602
|
-
|
1603
|
-
struct ddog_crasht_Handle_StackFrame ok;
|
1604
|
-
};
|
1605
|
-
struct {
|
1606
|
-
struct ddog_Error err;
|
1607
|
-
};
|
1608
|
-
};
|
1609
|
-
} ddog_crasht_StackFrame_NewResult;
|
1548
|
+
typedef enum ddog_crasht_DemangleOptions {
|
1549
|
+
DDOG_CRASHT_DEMANGLE_OPTIONS_COMPLETE,
|
1550
|
+
DDOG_CRASHT_DEMANGLE_OPTIONS_NAME_ONLY,
|
1551
|
+
} ddog_crasht_DemangleOptions;
|
1610
1552
|
|
1611
|
-
|
1612
|
-
|
1613
|
-
|
1614
|
-
|
1615
|
-
|
1616
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_CONNECTION_ABORTED,
|
1617
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_CONNECTION_REFUSED,
|
1618
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_CONNECTION_RESET,
|
1619
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_BODY_FORMAT,
|
1620
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_BODY_TOO_LONG,
|
1621
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_CLIENT,
|
1622
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_EMPTY_BODY,
|
1623
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_PARSE,
|
1624
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_SERVER,
|
1625
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_UNKNOWN,
|
1626
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_HTTP_WRONG_STATUS,
|
1627
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_ARGUMENT,
|
1628
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_DATA,
|
1629
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_INPUT,
|
1630
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_INVALID_URL,
|
1631
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_IO_ERROR,
|
1632
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_NETWORK_UNKNOWN,
|
1633
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_SERDE,
|
1634
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_TIMED_OUT,
|
1635
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_INTERNAL,
|
1636
|
-
DDOG_TRACE_EXPORTER_ERROR_CODE_PANIC,
|
1637
|
-
} ddog_TraceExporterErrorCode;
|
1553
|
+
typedef enum ddog_crasht_ErrorKind {
|
1554
|
+
DDOG_CRASHT_ERROR_KIND_PANIC,
|
1555
|
+
DDOG_CRASHT_ERROR_KIND_UNHANDLED_EXCEPTION,
|
1556
|
+
DDOG_CRASHT_ERROR_KIND_UNIX_SIGNAL,
|
1557
|
+
} ddog_crasht_ErrorKind;
|
1638
1558
|
|
1639
|
-
|
1640
|
-
|
1641
|
-
|
1642
|
-
|
1643
|
-
|
1644
|
-
* the agent response indicates that the payload version hasn't changed,
|
1645
|
-
* the body will be empty.
|
1646
|
-
*/
|
1647
|
-
typedef struct ddog_TraceExporterResponse ddog_TraceExporterResponse;
|
1559
|
+
typedef enum ddog_crasht_FileType {
|
1560
|
+
DDOG_CRASHT_FILE_TYPE_APK,
|
1561
|
+
DDOG_CRASHT_FILE_TYPE_ELF,
|
1562
|
+
DDOG_CRASHT_FILE_TYPE_PE,
|
1563
|
+
} ddog_crasht_FileType;
|
1648
1564
|
|
1649
1565
|
/**
|
1650
|
-
*
|
1651
|
-
*
|
1652
|
-
*
|
1653
|
-
*
|
1654
|
-
* If the input format is set as `Proxy`, the exporter will forward traces to the agent without
|
1655
|
-
* deserializing them.
|
1656
|
-
*
|
1657
|
-
* # Features
|
1658
|
-
* When the input format is set to `V04` the TraceExporter will deserialize the traces and perform
|
1659
|
-
* some operation before sending them to the agent. The available operations are described below.
|
1566
|
+
* This enum represents operations a the tracked library might be engaged in.
|
1567
|
+
* Currently only implemented for profiling.
|
1568
|
+
* The idea is that if a crash consistently occurs while a particular operation
|
1569
|
+
* is ongoing, its likely related.
|
1660
1570
|
*
|
1661
|
-
*
|
1662
|
-
*
|
1571
|
+
* In the future, we might also track wall-clock time of operations
|
1572
|
+
* (or some statistical sampling thereof) using the same enum.
|
1663
1573
|
*
|
1664
|
-
*
|
1665
|
-
*
|
1666
|
-
* another task to send stats when a time bucket expire. When this feature is enabled the
|
1667
|
-
* TraceExporter drops all spans that may not be sampled by the agent.
|
1574
|
+
* NOTE: This enum is known to be non-exhaustive. Feel free to add new types
|
1575
|
+
* as needed.
|
1668
1576
|
*/
|
1669
|
-
typedef
|
1577
|
+
typedef enum ddog_crasht_OpTypes {
|
1578
|
+
DDOG_CRASHT_OP_TYPES_PROFILER_INACTIVE = 0,
|
1579
|
+
DDOG_CRASHT_OP_TYPES_PROFILER_COLLECTING_SAMPLE,
|
1580
|
+
DDOG_CRASHT_OP_TYPES_PROFILER_UNWINDING,
|
1581
|
+
DDOG_CRASHT_OP_TYPES_PROFILER_SERIALIZING,
|
1582
|
+
/**
|
1583
|
+
* Dummy value to allow easier iteration
|
1584
|
+
*/
|
1585
|
+
DDOG_CRASHT_OP_TYPES_SIZE,
|
1586
|
+
} ddog_crasht_OpTypes;
|
1670
1587
|
|
1671
1588
|
/**
|
1672
|
-
*
|
1673
|
-
*
|
1674
|
-
* needed by the handle and it can be freed.
|
1589
|
+
* See https://man7.org/linux/man-pages/man2/sigaction.2.html
|
1590
|
+
* MUST REMAIN IN SYNC WITH THE ENUM IN emit_sigcodes.c
|
1675
1591
|
*/
|
1676
|
-
typedef
|
1592
|
+
typedef enum ddog_crasht_SiCodes {
|
1593
|
+
DDOG_CRASHT_SI_CODES_BUS_ADRALN,
|
1594
|
+
DDOG_CRASHT_SI_CODES_BUS_ADRERR,
|
1595
|
+
DDOG_CRASHT_SI_CODES_BUS_MCEERR_AO,
|
1596
|
+
DDOG_CRASHT_SI_CODES_BUS_MCEERR_AR,
|
1597
|
+
DDOG_CRASHT_SI_CODES_BUS_OBJERR,
|
1598
|
+
DDOG_CRASHT_SI_CODES_ILL_BADSTK,
|
1599
|
+
DDOG_CRASHT_SI_CODES_ILL_COPROC,
|
1600
|
+
DDOG_CRASHT_SI_CODES_ILL_ILLADR,
|
1601
|
+
DDOG_CRASHT_SI_CODES_ILL_ILLOPC,
|
1602
|
+
DDOG_CRASHT_SI_CODES_ILL_ILLOPN,
|
1603
|
+
DDOG_CRASHT_SI_CODES_ILL_ILLTRP,
|
1604
|
+
DDOG_CRASHT_SI_CODES_ILL_PRVOPC,
|
1605
|
+
DDOG_CRASHT_SI_CODES_ILL_PRVREG,
|
1606
|
+
DDOG_CRASHT_SI_CODES_SEGV_ACCERR,
|
1607
|
+
DDOG_CRASHT_SI_CODES_SEGV_BNDERR,
|
1608
|
+
DDOG_CRASHT_SI_CODES_SEGV_MAPERR,
|
1609
|
+
DDOG_CRASHT_SI_CODES_SEGV_PKUERR,
|
1610
|
+
DDOG_CRASHT_SI_CODES_SI_ASYNCIO,
|
1611
|
+
DDOG_CRASHT_SI_CODES_SI_KERNEL,
|
1612
|
+
DDOG_CRASHT_SI_CODES_SI_MESGQ,
|
1613
|
+
DDOG_CRASHT_SI_CODES_SI_QUEUE,
|
1614
|
+
DDOG_CRASHT_SI_CODES_SI_SIGIO,
|
1615
|
+
DDOG_CRASHT_SI_CODES_SI_TIMER,
|
1616
|
+
DDOG_CRASHT_SI_CODES_SI_TKILL,
|
1617
|
+
DDOG_CRASHT_SI_CODES_SI_USER,
|
1618
|
+
DDOG_CRASHT_SI_CODES_SYS_SECCOMP,
|
1619
|
+
DDOG_CRASHT_SI_CODES_UNKNOWN,
|
1620
|
+
} ddog_crasht_SiCodes;
|
1677
1621
|
|
1678
1622
|
/**
|
1679
|
-
*
|
1623
|
+
* See https://man7.org/linux/man-pages/man7/signal.7.html
|
1680
1624
|
*/
|
1681
|
-
typedef
|
1682
|
-
|
1683
|
-
|
1684
|
-
|
1625
|
+
typedef enum ddog_crasht_SignalNames {
|
1626
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGHUP,
|
1627
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGINT,
|
1628
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGQUIT,
|
1629
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGILL,
|
1630
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGTRAP,
|
1631
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGABRT,
|
1632
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGBUS,
|
1633
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGFPE,
|
1634
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGKILL,
|
1635
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGUSR1,
|
1636
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGSEGV,
|
1637
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGUSR2,
|
1638
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGPIPE,
|
1639
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGALRM,
|
1640
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGTERM,
|
1641
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGCHLD,
|
1642
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGCONT,
|
1643
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGSTOP,
|
1644
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGTSTP,
|
1645
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGTTIN,
|
1646
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGTTOU,
|
1647
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGURG,
|
1648
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGXCPU,
|
1649
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGXFSZ,
|
1650
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGVTALRM,
|
1651
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGPROF,
|
1652
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGWINCH,
|
1653
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGIO,
|
1654
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGSYS,
|
1655
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGEMT,
|
1656
|
+
DDOG_CRASHT_SIGNAL_NAMES_SIGINFO,
|
1657
|
+
DDOG_CRASHT_SIGNAL_NAMES_UNKNOWN,
|
1658
|
+
} ddog_crasht_SignalNames;
|
1685
1659
|
|
1686
1660
|
/**
|
1687
|
-
*
|
1661
|
+
* Stacktrace collection occurs in the context of a crashing process.
|
1662
|
+
* If the stack is sufficiently corruputed, it is possible (but unlikely),
|
1663
|
+
* for stack trace collection itself to crash.
|
1664
|
+
* We recommend fully enabling stacktrace collection, but having an environment
|
1665
|
+
* variable to allow downgrading the collector.
|
1688
1666
|
*/
|
1689
|
-
typedef
|
1667
|
+
typedef enum ddog_crasht_StacktraceCollection {
|
1690
1668
|
/**
|
1691
|
-
*
|
1669
|
+
* Stacktrace collection occurs in the
|
1692
1670
|
*/
|
1693
|
-
|
1671
|
+
DDOG_CRASHT_STACKTRACE_COLLECTION_DISABLED,
|
1672
|
+
DDOG_CRASHT_STACKTRACE_COLLECTION_WITHOUT_SYMBOLS,
|
1694
1673
|
/**
|
1695
|
-
*
|
1696
|
-
*
|
1697
|
-
*
|
1698
|
-
*
|
1699
|
-
* - Be associated with traces to allow correlation between traces and telemetry data
|
1674
|
+
* This option uses `backtrace::resolve_frame_unsynchronized()` to gather symbol information
|
1675
|
+
* and also unwind inlined functions. Enabling this feature will not only provide symbolic
|
1676
|
+
* details, but may also yield additional or less stack frames compared to other
|
1677
|
+
* configurations.
|
1700
1678
|
*/
|
1701
|
-
|
1679
|
+
DDOG_CRASHT_STACKTRACE_COLLECTION_ENABLED_WITH_INPROCESS_SYMBOLS,
|
1680
|
+
DDOG_CRASHT_STACKTRACE_COLLECTION_ENABLED_WITH_SYMBOLS_IN_RECEIVER,
|
1681
|
+
} ddog_crasht_StacktraceCollection;
|
1682
|
+
|
1683
|
+
typedef struct ddog_crasht_CrashInfo ddog_crasht_CrashInfo;
|
1684
|
+
|
1685
|
+
typedef struct ddog_crasht_CrashInfoBuilder ddog_crasht_CrashInfoBuilder;
|
1686
|
+
|
1687
|
+
typedef struct ddog_crasht_StackFrame ddog_crasht_StackFrame;
|
1688
|
+
|
1689
|
+
typedef struct ddog_crasht_StackTrace ddog_crasht_StackTrace;
|
1690
|
+
|
1691
|
+
typedef struct ddog_crasht_Slice_CharSlice {
|
1702
1692
|
/**
|
1703
|
-
*
|
1704
|
-
*
|
1705
|
-
*
|
1693
|
+
* Should be non-null and suitably aligned for the underlying type. It is
|
1694
|
+
* allowed but not recommended for the pointer to be null when the len is
|
1695
|
+
* zero.
|
1706
1696
|
*/
|
1707
|
-
|
1708
|
-
|
1709
|
-
|
1710
|
-
|
1711
|
-
|
1712
|
-
|
1713
|
-
}
|
1697
|
+
const ddog_CharSlice *ptr;
|
1698
|
+
/**
|
1699
|
+
* The number of elements (not bytes) that `.ptr` points to. Must be less
|
1700
|
+
* than or equal to [isize::MAX].
|
1701
|
+
*/
|
1702
|
+
uintptr_t len;
|
1703
|
+
} ddog_crasht_Slice_CharSlice;
|
1714
1704
|
|
1715
|
-
typedef struct
|
1705
|
+
typedef struct ddog_crasht_Slice_I32 {
|
1706
|
+
/**
|
1707
|
+
* Should be non-null and suitably aligned for the underlying type. It is
|
1708
|
+
* allowed but not recommended for the pointer to be null when the len is
|
1709
|
+
* zero.
|
1710
|
+
*/
|
1711
|
+
const int32_t *ptr;
|
1712
|
+
/**
|
1713
|
+
* The number of elements (not bytes) that `.ptr` points to. Must be less
|
1714
|
+
* than or equal to [isize::MAX].
|
1715
|
+
*/
|
1716
|
+
uintptr_t len;
|
1717
|
+
} ddog_crasht_Slice_I32;
|
1716
1718
|
|
1717
|
-
|
1718
|
-
|
1719
|
-
|
1720
|
-
|
1721
|
-
typedef struct ddog_CStr {
|
1719
|
+
typedef struct ddog_crasht_Config {
|
1720
|
+
struct ddog_crasht_Slice_CharSlice additional_files;
|
1721
|
+
bool create_alt_stack;
|
1722
|
+
bool demangle_names;
|
1722
1723
|
/**
|
1723
|
-
*
|
1724
|
+
* The endpoint to send the crash report to (can be a file://).
|
1725
|
+
* If None, the crashtracker will infer the agent host from env variables.
|
1724
1726
|
*/
|
1725
|
-
|
1727
|
+
const struct ddog_Endpoint *endpoint;
|
1726
1728
|
/**
|
1727
|
-
*
|
1729
|
+
* Optional filename for a unix domain socket if the receiver is used asynchonously
|
1728
1730
|
*/
|
1729
|
-
|
1730
|
-
|
1731
|
+
ddog_CharSlice optional_unix_socket_filename;
|
1732
|
+
enum ddog_crasht_StacktraceCollection resolve_frames;
|
1733
|
+
/**
|
1734
|
+
* The set of signals we should be registered for.
|
1735
|
+
* If empty, use the default set.
|
1736
|
+
*/
|
1737
|
+
struct ddog_crasht_Slice_I32 signals;
|
1738
|
+
/**
|
1739
|
+
* Timeout in milliseconds before the signal handler starts tearing things down to return.
|
1740
|
+
* If 0, uses the default timeout as specified in
|
1741
|
+
* `datadog_crashtracker::shared::constants::DD_CRASHTRACK_DEFAULT_TIMEOUT`. Otherwise, uses
|
1742
|
+
* the specified timeout value.
|
1743
|
+
* This is given as a uint32_t, but the actual timeout needs to fit inside of an i32 (max
|
1744
|
+
* 2^31-1). This is a limitation of the various interfaces used to guarantee the timeout.
|
1745
|
+
*/
|
1746
|
+
uint32_t timeout_ms;
|
1747
|
+
bool use_alt_stack;
|
1748
|
+
} ddog_crasht_Config;
|
1731
1749
|
|
1732
|
-
typedef struct
|
1750
|
+
typedef struct ddog_crasht_EnvVar {
|
1751
|
+
ddog_CharSlice key;
|
1752
|
+
ddog_CharSlice val;
|
1753
|
+
} ddog_crasht_EnvVar;
|
1754
|
+
|
1755
|
+
typedef struct ddog_crasht_Slice_EnvVar {
|
1733
1756
|
/**
|
1734
1757
|
* Should be non-null and suitably aligned for the underlying type. It is
|
1735
1758
|
* allowed but not recommended for the pointer to be null when the len is
|
1736
1759
|
* zero.
|
1737
1760
|
*/
|
1738
|
-
const
|
1761
|
+
const struct ddog_crasht_EnvVar *ptr;
|
1739
1762
|
/**
|
1740
1763
|
* The number of elements (not bytes) that `.ptr` points to. Must be less
|
1741
1764
|
* than or equal to [isize::MAX].
|
1742
1765
|
*/
|
1743
1766
|
uintptr_t len;
|
1744
|
-
}
|
1745
|
-
|
1746
|
-
typedef struct ddog_ProcessInfo {
|
1747
|
-
struct ddog_Slice_CharSlice args;
|
1748
|
-
struct ddog_Slice_CharSlice envp;
|
1749
|
-
ddog_CharSlice language;
|
1750
|
-
} ddog_ProcessInfo;
|
1767
|
+
} ddog_crasht_Slice_EnvVar;
|
1751
1768
|
|
1752
|
-
|
1753
|
-
|
1754
|
-
|
1755
|
-
|
1756
|
-
typedef struct ddog_CString {
|
1769
|
+
typedef struct ddog_crasht_ReceiverConfig {
|
1770
|
+
struct ddog_crasht_Slice_CharSlice args;
|
1771
|
+
struct ddog_crasht_Slice_EnvVar env;
|
1772
|
+
ddog_CharSlice path_to_receiver_binary;
|
1757
1773
|
/**
|
1758
|
-
*
|
1774
|
+
* Optional filename to forward stderr to (useful for logging/debugging)
|
1759
1775
|
*/
|
1760
|
-
|
1776
|
+
ddog_CharSlice optional_stderr_filename;
|
1761
1777
|
/**
|
1762
|
-
*
|
1778
|
+
* Optional filename to forward stdout to (useful for logging/debugging)
|
1763
1779
|
*/
|
1764
|
-
|
1765
|
-
}
|
1780
|
+
ddog_CharSlice optional_stdout_filename;
|
1781
|
+
} ddog_crasht_ReceiverConfig;
|
1766
1782
|
|
1767
|
-
typedef struct
|
1768
|
-
|
1769
|
-
|
1770
|
-
|
1771
|
-
|
1772
|
-
|
1783
|
+
typedef struct ddog_crasht_Metadata {
|
1784
|
+
ddog_CharSlice library_name;
|
1785
|
+
ddog_CharSlice library_version;
|
1786
|
+
ddog_CharSlice family;
|
1787
|
+
/**
|
1788
|
+
* Should include "service", "environment", etc
|
1789
|
+
*/
|
1790
|
+
const struct ddog_Vec_Tag *tags;
|
1791
|
+
} ddog_crasht_Metadata;
|
1773
1792
|
|
1774
|
-
|
1775
|
-
|
1776
|
-
|
1777
|
-
|
1778
|
-
|
1779
|
-
|
1793
|
+
typedef struct ddog_crasht_Slice_CInt {
|
1794
|
+
/**
|
1795
|
+
* Should be non-null and suitably aligned for the underlying type. It is
|
1796
|
+
* allowed but not recommended for the pointer to be null when the len is
|
1797
|
+
* zero.
|
1798
|
+
*/
|
1799
|
+
const int *ptr;
|
1800
|
+
/**
|
1801
|
+
* The number of elements (not bytes) that `.ptr` points to. Must be less
|
1802
|
+
* than or equal to [isize::MAX].
|
1803
|
+
*/
|
1780
1804
|
uintptr_t len;
|
1781
|
-
|
1782
|
-
} ddog_Vec_LibraryConfig;
|
1805
|
+
} ddog_crasht_Slice_CInt;
|
1783
1806
|
|
1784
1807
|
/**
|
1785
1808
|
* A generic result type for when an operation may fail,
|
1786
1809
|
* or may return <T> in case of success.
|
1787
1810
|
*/
|
1788
|
-
typedef enum
|
1789
|
-
|
1790
|
-
|
1791
|
-
}
|
1811
|
+
typedef enum ddog_crasht_Result_Usize_Tag {
|
1812
|
+
DDOG_CRASHT_RESULT_USIZE_OK_USIZE,
|
1813
|
+
DDOG_CRASHT_RESULT_USIZE_ERR_USIZE,
|
1814
|
+
} ddog_crasht_Result_Usize_Tag;
|
1792
1815
|
|
1793
|
-
typedef struct
|
1794
|
-
|
1816
|
+
typedef struct ddog_crasht_Result_Usize {
|
1817
|
+
ddog_crasht_Result_Usize_Tag tag;
|
1795
1818
|
union {
|
1796
1819
|
struct {
|
1797
|
-
|
1820
|
+
uintptr_t ok;
|
1798
1821
|
};
|
1799
1822
|
struct {
|
1800
1823
|
struct ddog_Error err;
|
1801
1824
|
};
|
1802
1825
|
};
|
1803
|
-
}
|
1826
|
+
} ddog_crasht_Result_Usize;
|
1804
1827
|
|
1805
1828
|
/**
|
1806
|
-
*
|
1829
|
+
* Represents an object that should only be referred to by its handle.
|
1830
|
+
* Do not access its member for any reason, only use the C API functions on this struct.
|
1807
1831
|
*/
|
1808
|
-
typedef struct
|
1809
|
-
|
1810
|
-
|
1811
|
-
*/
|
1812
|
-
int fd;
|
1813
|
-
} ddog_TracerMemfdHandle;
|
1832
|
+
typedef struct ddog_crasht_Handle_CrashInfo {
|
1833
|
+
struct ddog_crasht_CrashInfo *inner;
|
1834
|
+
} ddog_crasht_Handle_CrashInfo;
|
1814
1835
|
|
1815
1836
|
/**
|
1816
|
-
*
|
1817
|
-
*
|
1837
|
+
* Represents an object that should only be referred to by its handle.
|
1838
|
+
* Do not access its member for any reason, only use the C API functions on this struct.
|
1818
1839
|
*/
|
1819
|
-
typedef
|
1820
|
-
|
1821
|
-
|
1822
|
-
} ddog_Result_TracerMemfdHandle_Tag;
|
1840
|
+
typedef struct ddog_crasht_Handle_CrashInfoBuilder {
|
1841
|
+
struct ddog_crasht_CrashInfoBuilder *inner;
|
1842
|
+
} ddog_crasht_Handle_CrashInfoBuilder;
|
1823
1843
|
|
1824
|
-
typedef
|
1825
|
-
|
1844
|
+
typedef enum ddog_crasht_CrashInfoBuilder_NewResult_Tag {
|
1845
|
+
DDOG_CRASHT_CRASH_INFO_BUILDER_NEW_RESULT_OK,
|
1846
|
+
DDOG_CRASHT_CRASH_INFO_BUILDER_NEW_RESULT_ERR,
|
1847
|
+
} ddog_crasht_CrashInfoBuilder_NewResult_Tag;
|
1848
|
+
|
1849
|
+
typedef struct ddog_crasht_CrashInfoBuilder_NewResult {
|
1850
|
+
ddog_crasht_CrashInfoBuilder_NewResult_Tag tag;
|
1826
1851
|
union {
|
1827
1852
|
struct {
|
1828
|
-
struct
|
1853
|
+
struct ddog_crasht_Handle_CrashInfoBuilder ok;
|
1829
1854
|
};
|
1830
1855
|
struct {
|
1831
1856
|
struct ddog_Error err;
|
1832
1857
|
};
|
1833
1858
|
};
|
1834
|
-
}
|
1859
|
+
} ddog_crasht_CrashInfoBuilder_NewResult;
|
1835
1860
|
|
1836
|
-
|
1837
|
-
|
1838
|
-
|
1839
|
-
|
1840
|
-
/**
|
1841
|
-
* The "trace" level.
|
1842
|
-
*
|
1843
|
-
* Designates very low priority, often extremely verbose, information.
|
1844
|
-
*/
|
1845
|
-
DDOG_LOG_EVENT_LEVEL_TRACE = 0,
|
1846
|
-
/**
|
1847
|
-
* The "debug" level.
|
1848
|
-
*
|
1849
|
-
* Designates lower priority information.
|
1850
|
-
*/
|
1851
|
-
DDOG_LOG_EVENT_LEVEL_DEBUG = 1,
|
1852
|
-
/**
|
1853
|
-
* The "info" level.
|
1854
|
-
*
|
1855
|
-
* Designates useful information.
|
1856
|
-
*/
|
1857
|
-
DDOG_LOG_EVENT_LEVEL_INFO = 2,
|
1858
|
-
/**
|
1859
|
-
* The "warn" level.
|
1860
|
-
*
|
1861
|
-
* Designates hazardous situations.
|
1862
|
-
*/
|
1863
|
-
DDOG_LOG_EVENT_LEVEL_WARN = 3,
|
1864
|
-
/**
|
1865
|
-
* The "error" level.
|
1866
|
-
*
|
1867
|
-
* Designates very serious errors.
|
1868
|
-
*/
|
1869
|
-
DDOG_LOG_EVENT_LEVEL_ERROR = 4,
|
1870
|
-
} ddog_LogEventLevel;
|
1861
|
+
typedef enum ddog_crasht_CrashInfo_NewResult_Tag {
|
1862
|
+
DDOG_CRASHT_CRASH_INFO_NEW_RESULT_OK,
|
1863
|
+
DDOG_CRASHT_CRASH_INFO_NEW_RESULT_ERR,
|
1864
|
+
} ddog_crasht_CrashInfo_NewResult_Tag;
|
1871
1865
|
|
1872
|
-
|
1873
|
-
|
1874
|
-
|
1875
|
-
|
1876
|
-
|
1877
|
-
|
1878
|
-
|
1879
|
-
|
1880
|
-
|
1881
|
-
|
1882
|
-
|
1883
|
-
|
1884
|
-
|
1866
|
+
typedef struct ddog_crasht_CrashInfo_NewResult {
|
1867
|
+
ddog_crasht_CrashInfo_NewResult_Tag tag;
|
1868
|
+
union {
|
1869
|
+
struct {
|
1870
|
+
struct ddog_crasht_Handle_CrashInfo ok;
|
1871
|
+
};
|
1872
|
+
struct {
|
1873
|
+
struct ddog_Error err;
|
1874
|
+
};
|
1875
|
+
};
|
1876
|
+
} ddog_crasht_CrashInfo_NewResult;
|
1877
|
+
|
1878
|
+
typedef struct ddog_crasht_OsInfo {
|
1879
|
+
ddog_CharSlice architecture;
|
1880
|
+
ddog_CharSlice bitness;
|
1881
|
+
ddog_CharSlice os_type;
|
1882
|
+
ddog_CharSlice version;
|
1883
|
+
} ddog_crasht_OsInfo;
|
1884
|
+
|
1885
|
+
typedef struct ddog_crasht_ProcInfo {
|
1886
|
+
uint32_t pid;
|
1887
|
+
} ddog_crasht_ProcInfo;
|
1888
|
+
|
1889
|
+
typedef struct ddog_crasht_SigInfo {
|
1890
|
+
ddog_CharSlice addr;
|
1891
|
+
int code;
|
1892
|
+
enum ddog_crasht_SiCodes code_human_readable;
|
1893
|
+
int signo;
|
1894
|
+
enum ddog_crasht_SignalNames signo_human_readable;
|
1895
|
+
} ddog_crasht_SigInfo;
|
1896
|
+
|
1897
|
+
typedef struct ddog_crasht_Span {
|
1898
|
+
ddog_CharSlice id;
|
1899
|
+
ddog_CharSlice thread_name;
|
1900
|
+
} ddog_crasht_Span;
|
1885
1901
|
|
1886
1902
|
/**
|
1887
|
-
*
|
1903
|
+
* Represents an object that should only be referred to by its handle.
|
1904
|
+
* Do not access its member for any reason, only use the C API functions on this struct.
|
1888
1905
|
*/
|
1889
|
-
typedef struct
|
1890
|
-
|
1891
|
-
|
1892
|
-
|
1893
|
-
|
1894
|
-
|
1906
|
+
typedef struct ddog_crasht_Handle_StackTrace {
|
1907
|
+
struct ddog_crasht_StackTrace *inner;
|
1908
|
+
} ddog_crasht_Handle_StackTrace;
|
1909
|
+
|
1910
|
+
typedef struct ddog_crasht_ThreadData {
|
1911
|
+
bool crashed;
|
1912
|
+
ddog_CharSlice name;
|
1913
|
+
struct ddog_crasht_Handle_StackTrace stack;
|
1914
|
+
ddog_CharSlice state;
|
1915
|
+
} ddog_crasht_ThreadData;
|
1895
1916
|
|
1896
1917
|
/**
|
1897
|
-
*
|
1918
|
+
* Represents an object that should only be referred to by its handle.
|
1919
|
+
* Do not access its member for any reason, only use the C API functions on this struct.
|
1898
1920
|
*/
|
1899
|
-
typedef struct
|
1900
|
-
|
1901
|
-
|
1902
|
-
|
1903
|
-
|
1904
|
-
|
1905
|
-
|
1906
|
-
|
1907
|
-
|
1908
|
-
|
1909
|
-
|
1910
|
-
|
1911
|
-
|
1912
|
-
|
1913
|
-
|
1914
|
-
|
1915
|
-
|
1921
|
+
typedef struct ddog_crasht_Handle_StackFrame {
|
1922
|
+
struct ddog_crasht_StackFrame *inner;
|
1923
|
+
} ddog_crasht_Handle_StackFrame;
|
1924
|
+
|
1925
|
+
typedef enum ddog_crasht_StackFrame_NewResult_Tag {
|
1926
|
+
DDOG_CRASHT_STACK_FRAME_NEW_RESULT_OK,
|
1927
|
+
DDOG_CRASHT_STACK_FRAME_NEW_RESULT_ERR,
|
1928
|
+
} ddog_crasht_StackFrame_NewResult_Tag;
|
1929
|
+
|
1930
|
+
typedef struct ddog_crasht_StackFrame_NewResult {
|
1931
|
+
ddog_crasht_StackFrame_NewResult_Tag tag;
|
1932
|
+
union {
|
1933
|
+
struct {
|
1934
|
+
struct ddog_crasht_Handle_StackFrame ok;
|
1935
|
+
};
|
1936
|
+
struct {
|
1937
|
+
struct ddog_Error err;
|
1938
|
+
};
|
1939
|
+
};
|
1940
|
+
} ddog_crasht_StackFrame_NewResult;
|
1941
|
+
|
1942
|
+
typedef enum ddog_crasht_StackTrace_NewResult_Tag {
|
1943
|
+
DDOG_CRASHT_STACK_TRACE_NEW_RESULT_OK,
|
1944
|
+
DDOG_CRASHT_STACK_TRACE_NEW_RESULT_ERR,
|
1945
|
+
} ddog_crasht_StackTrace_NewResult_Tag;
|
1946
|
+
|
1947
|
+
typedef struct ddog_crasht_StackTrace_NewResult {
|
1948
|
+
ddog_crasht_StackTrace_NewResult_Tag tag;
|
1949
|
+
union {
|
1950
|
+
struct {
|
1951
|
+
struct ddog_crasht_Handle_StackTrace ok;
|
1952
|
+
};
|
1953
|
+
struct {
|
1954
|
+
struct ddog_Error err;
|
1955
|
+
};
|
1956
|
+
};
|
1957
|
+
} ddog_crasht_StackTrace_NewResult;
|
1916
1958
|
|
1917
1959
|
#ifdef __cplusplus
|
1918
1960
|
extern "C" {
|