libdatadog 3.0.0.1.0-x86_64-linux → 5.0.0.1.0-x86_64-linux
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-3.0.0 → libdatadog-5.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/LICENSE-3rdparty.yml +9906 -5192
- data/vendor/{libdatadog-3.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-5.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu}/include/datadog/common.h +135 -93
- data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/profiling.h +43 -33
- data/vendor/libdatadog-5.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
- data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
- data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/LICENSE-3rdparty.yml +9906 -5192
- data/vendor/{libdatadog-3.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-5.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl}/include/datadog/common.h +135 -93
- data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/include/datadog/profiling.h +43 -33
- data/vendor/libdatadog-5.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
- data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
- metadata +16 -16
- data/vendor/libdatadog-3.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
- data/vendor/libdatadog-3.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
- /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/LICENSE +0 -0
- /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/NOTICE +0 -0
- /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/LICENSE +0 -0
- /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/NOTICE +0 -0
@@ -40,6 +40,8 @@
|
|
40
40
|
# define DDOG_CHECK_RETURN
|
41
41
|
#endif
|
42
42
|
|
43
|
+
typedef struct ddog_Endpoint ddog_Endpoint;
|
44
|
+
|
43
45
|
typedef struct ddog_Tag ddog_Tag;
|
44
46
|
|
45
47
|
/**
|
@@ -70,7 +72,13 @@ typedef struct ddog_Error {
|
|
70
72
|
* so every operation on it is unsafe!
|
71
73
|
*/
|
72
74
|
typedef struct ddog_Slice_CChar {
|
75
|
+
/**
|
76
|
+
* Must be non-null and suitably aligned for the underlying type.
|
77
|
+
*/
|
73
78
|
const char *ptr;
|
79
|
+
/**
|
80
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
81
|
+
*/
|
74
82
|
uintptr_t len;
|
75
83
|
} ddog_Slice_CChar;
|
76
84
|
|
@@ -107,14 +115,52 @@ typedef struct ddog_Vec_Tag_ParseResult {
|
|
107
115
|
|
108
116
|
typedef struct ddog_CancellationToken ddog_CancellationToken;
|
109
117
|
|
110
|
-
typedef struct ddog_prof_Profile ddog_prof_Profile;
|
111
|
-
|
112
118
|
typedef struct ddog_prof_Exporter ddog_prof_Exporter;
|
113
119
|
|
114
120
|
typedef struct ddog_prof_ProfiledEndpointsStats ddog_prof_ProfiledEndpointsStats;
|
115
121
|
|
116
122
|
typedef struct ddog_prof_Exporter_Request ddog_prof_Exporter_Request;
|
117
123
|
|
124
|
+
/**
|
125
|
+
* Remember, the data inside of each member is potentially coming from FFI,
|
126
|
+
* so every operation on it is unsafe!
|
127
|
+
*/
|
128
|
+
typedef struct ddog_Slice_U8 {
|
129
|
+
/**
|
130
|
+
* Must be non-null and suitably aligned for the underlying type.
|
131
|
+
*/
|
132
|
+
const uint8_t *ptr;
|
133
|
+
/**
|
134
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
135
|
+
*/
|
136
|
+
uintptr_t len;
|
137
|
+
} ddog_Slice_U8;
|
138
|
+
|
139
|
+
/**
|
140
|
+
* Use to represent bytes -- does not need to be valid UTF-8.
|
141
|
+
*/
|
142
|
+
typedef struct ddog_Slice_U8 ddog_ByteSlice;
|
143
|
+
|
144
|
+
typedef struct ddog_prof_Exporter_File {
|
145
|
+
ddog_CharSlice name;
|
146
|
+
ddog_ByteSlice file;
|
147
|
+
} ddog_prof_Exporter_File;
|
148
|
+
|
149
|
+
/**
|
150
|
+
* Remember, the data inside of each member is potentially coming from FFI,
|
151
|
+
* so every operation on it is unsafe!
|
152
|
+
*/
|
153
|
+
typedef struct ddog_prof_Exporter_Slice_File {
|
154
|
+
/**
|
155
|
+
* Must be non-null and suitably aligned for the underlying type.
|
156
|
+
*/
|
157
|
+
const struct ddog_prof_Exporter_File *ptr;
|
158
|
+
/**
|
159
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
160
|
+
*/
|
161
|
+
uintptr_t len;
|
162
|
+
} ddog_prof_Exporter_Slice_File;
|
163
|
+
|
118
164
|
typedef enum ddog_Endpoint_Tag {
|
119
165
|
DDOG_ENDPOINT_AGENT,
|
120
166
|
DDOG_ENDPOINT_AGENTLESS,
|
@@ -177,34 +223,6 @@ typedef struct ddog_Timespec {
|
|
177
223
|
uint32_t nanoseconds;
|
178
224
|
} ddog_Timespec;
|
179
225
|
|
180
|
-
/**
|
181
|
-
* Remember, the data inside of each member is potentially coming from FFI,
|
182
|
-
* so every operation on it is unsafe!
|
183
|
-
*/
|
184
|
-
typedef struct ddog_Slice_U8 {
|
185
|
-
const uint8_t *ptr;
|
186
|
-
uintptr_t len;
|
187
|
-
} ddog_Slice_U8;
|
188
|
-
|
189
|
-
/**
|
190
|
-
* Use to represent bytes -- does not need to be valid UTF-8.
|
191
|
-
*/
|
192
|
-
typedef struct ddog_Slice_U8 ddog_ByteSlice;
|
193
|
-
|
194
|
-
typedef struct ddog_prof_Exporter_File {
|
195
|
-
ddog_CharSlice name;
|
196
|
-
ddog_ByteSlice file;
|
197
|
-
} ddog_prof_Exporter_File;
|
198
|
-
|
199
|
-
/**
|
200
|
-
* Remember, the data inside of each member is potentially coming from FFI,
|
201
|
-
* so every operation on it is unsafe!
|
202
|
-
*/
|
203
|
-
typedef struct ddog_prof_Exporter_Slice_File {
|
204
|
-
const struct ddog_prof_Exporter_File *ptr;
|
205
|
-
uintptr_t len;
|
206
|
-
} ddog_prof_Exporter_Slice_File;
|
207
|
-
|
208
226
|
typedef struct ddog_HttpStatus {
|
209
227
|
uint16_t code;
|
210
228
|
} ddog_HttpStatus;
|
@@ -226,6 +244,34 @@ typedef struct ddog_prof_Exporter_SendResult {
|
|
226
244
|
};
|
227
245
|
} ddog_prof_Exporter_SendResult;
|
228
246
|
|
247
|
+
/**
|
248
|
+
* Represents a profile. Do not access its member for any reason, only use
|
249
|
+
* the C API functions on this struct.
|
250
|
+
*/
|
251
|
+
typedef struct ddog_prof_Profile {
|
252
|
+
struct ddog_prof_Profile *inner;
|
253
|
+
} ddog_prof_Profile;
|
254
|
+
|
255
|
+
/**
|
256
|
+
* Returned by [ddog_prof_Profile_new].
|
257
|
+
*/
|
258
|
+
typedef enum ddog_prof_Profile_NewResult_Tag {
|
259
|
+
DDOG_PROF_PROFILE_NEW_RESULT_OK,
|
260
|
+
DDOG_PROF_PROFILE_NEW_RESULT_ERR,
|
261
|
+
} ddog_prof_Profile_NewResult_Tag;
|
262
|
+
|
263
|
+
typedef struct ddog_prof_Profile_NewResult {
|
264
|
+
ddog_prof_Profile_NewResult_Tag tag;
|
265
|
+
union {
|
266
|
+
struct {
|
267
|
+
struct ddog_prof_Profile ok;
|
268
|
+
};
|
269
|
+
struct {
|
270
|
+
struct ddog_Error err;
|
271
|
+
};
|
272
|
+
};
|
273
|
+
} ddog_prof_Profile_NewResult;
|
274
|
+
|
229
275
|
typedef struct ddog_prof_ValueType {
|
230
276
|
ddog_CharSlice type_;
|
231
277
|
ddog_CharSlice unit;
|
@@ -236,7 +282,13 @@ typedef struct ddog_prof_ValueType {
|
|
236
282
|
* so every operation on it is unsafe!
|
237
283
|
*/
|
238
284
|
typedef struct ddog_prof_Slice_ValueType {
|
285
|
+
/**
|
286
|
+
* Must be non-null and suitably aligned for the underlying type.
|
287
|
+
*/
|
239
288
|
const struct ddog_prof_ValueType *ptr;
|
289
|
+
/**
|
290
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
291
|
+
*/
|
240
292
|
uintptr_t len;
|
241
293
|
} ddog_prof_Slice_ValueType;
|
242
294
|
|
@@ -245,22 +297,30 @@ typedef struct ddog_prof_Period {
|
|
245
297
|
int64_t value;
|
246
298
|
} ddog_prof_Period;
|
247
299
|
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
300
|
+
/**
|
301
|
+
* A generic result type for when a profiling operation may fail, but there's
|
302
|
+
* nothing to return in the case of success.
|
303
|
+
*/
|
304
|
+
typedef enum ddog_prof_Profile_Result_Tag {
|
305
|
+
DDOG_PROF_PROFILE_RESULT_OK,
|
306
|
+
DDOG_PROF_PROFILE_RESULT_ERR,
|
307
|
+
} ddog_prof_Profile_Result_Tag;
|
252
308
|
|
253
|
-
typedef struct
|
254
|
-
|
309
|
+
typedef struct ddog_prof_Profile_Result {
|
310
|
+
ddog_prof_Profile_Result_Tag tag;
|
255
311
|
union {
|
256
312
|
struct {
|
257
|
-
|
313
|
+
/**
|
314
|
+
* Do not use the value of Ok. This value only exists to overcome
|
315
|
+
* Rust -> C code generation.
|
316
|
+
*/
|
317
|
+
bool ok;
|
258
318
|
};
|
259
319
|
struct {
|
260
320
|
struct ddog_Error err;
|
261
321
|
};
|
262
322
|
};
|
263
|
-
}
|
323
|
+
} ddog_prof_Profile_Result;
|
264
324
|
|
265
325
|
typedef struct ddog_prof_Mapping {
|
266
326
|
/**
|
@@ -309,31 +369,12 @@ typedef struct ddog_prof_Function {
|
|
309
369
|
int64_t start_line;
|
310
370
|
} ddog_prof_Function;
|
311
371
|
|
312
|
-
typedef struct ddog_prof_Line {
|
313
|
-
/**
|
314
|
-
* The corresponding profile.Function for this line.
|
315
|
-
*/
|
316
|
-
struct ddog_prof_Function function;
|
317
|
-
/**
|
318
|
-
* Line number in source code.
|
319
|
-
*/
|
320
|
-
int64_t line;
|
321
|
-
} ddog_prof_Line;
|
322
|
-
|
323
|
-
/**
|
324
|
-
* Remember, the data inside of each member is potentially coming from FFI,
|
325
|
-
* so every operation on it is unsafe!
|
326
|
-
*/
|
327
|
-
typedef struct ddog_prof_Slice_Line {
|
328
|
-
const struct ddog_prof_Line *ptr;
|
329
|
-
uintptr_t len;
|
330
|
-
} ddog_prof_Slice_Line;
|
331
|
-
|
332
372
|
typedef struct ddog_prof_Location {
|
333
373
|
/**
|
334
374
|
* todo: how to handle unknown mapping?
|
335
375
|
*/
|
336
376
|
struct ddog_prof_Mapping mapping;
|
377
|
+
struct ddog_prof_Function function;
|
337
378
|
/**
|
338
379
|
* The instruction address for this location, if available. It
|
339
380
|
* should be within [Mapping.memory_start...Mapping.memory_limit]
|
@@ -342,24 +383,7 @@ typedef struct ddog_prof_Location {
|
|
342
383
|
* the beginning of the instruction if necessary.
|
343
384
|
*/
|
344
385
|
uint64_t address;
|
345
|
-
|
346
|
-
* Multiple line indicates this location has inlined functions,
|
347
|
-
* where the last entry represents the caller into which the
|
348
|
-
* preceding entries were inlined.
|
349
|
-
*
|
350
|
-
* E.g., if memcpy() is inlined into printf:
|
351
|
-
* line[0].function_name == "memcpy"
|
352
|
-
* line[1].function_name == "printf"
|
353
|
-
*/
|
354
|
-
struct ddog_prof_Slice_Line lines;
|
355
|
-
/**
|
356
|
-
* Provides an indication that multiple symbols map to this location's
|
357
|
-
* address, for example due to identical code folding by the linker. In that
|
358
|
-
* case the line information above represents one of the multiple
|
359
|
-
* symbols. This field must be recomputed when the symbolization state of the
|
360
|
-
* profile changes.
|
361
|
-
*/
|
362
|
-
bool is_folded;
|
386
|
+
int64_t line;
|
363
387
|
} ddog_prof_Location;
|
364
388
|
|
365
389
|
/**
|
@@ -367,7 +391,13 @@ typedef struct ddog_prof_Location {
|
|
367
391
|
* so every operation on it is unsafe!
|
368
392
|
*/
|
369
393
|
typedef struct ddog_prof_Slice_Location {
|
394
|
+
/**
|
395
|
+
* Must be non-null and suitably aligned for the underlying type.
|
396
|
+
*/
|
370
397
|
const struct ddog_prof_Location *ptr;
|
398
|
+
/**
|
399
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
400
|
+
*/
|
371
401
|
uintptr_t len;
|
372
402
|
} ddog_prof_Slice_Location;
|
373
403
|
|
@@ -376,7 +406,13 @@ typedef struct ddog_prof_Slice_Location {
|
|
376
406
|
* so every operation on it is unsafe!
|
377
407
|
*/
|
378
408
|
typedef struct ddog_Slice_I64 {
|
409
|
+
/**
|
410
|
+
* Must be non-null and suitably aligned for the underlying type.
|
411
|
+
*/
|
379
412
|
const int64_t *ptr;
|
413
|
+
/**
|
414
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
415
|
+
*/
|
380
416
|
uintptr_t len;
|
381
417
|
} ddog_Slice_I64;
|
382
418
|
|
@@ -404,7 +440,13 @@ typedef struct ddog_prof_Label {
|
|
404
440
|
* so every operation on it is unsafe!
|
405
441
|
*/
|
406
442
|
typedef struct ddog_prof_Slice_Label {
|
443
|
+
/**
|
444
|
+
* Must be non-null and suitably aligned for the underlying type.
|
445
|
+
*/
|
407
446
|
const struct ddog_prof_Label *ptr;
|
447
|
+
/**
|
448
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
449
|
+
*/
|
408
450
|
uintptr_t len;
|
409
451
|
} ddog_prof_Slice_Label;
|
410
452
|
|
@@ -429,29 +471,18 @@ typedef struct ddog_prof_Sample {
|
|
429
471
|
struct ddog_prof_Slice_Label labels;
|
430
472
|
} ddog_prof_Sample;
|
431
473
|
|
432
|
-
typedef enum ddog_prof_Profile_UpscalingRuleAddResult_Tag {
|
433
|
-
DDOG_PROF_PROFILE_UPSCALING_RULE_ADD_RESULT_OK,
|
434
|
-
DDOG_PROF_PROFILE_UPSCALING_RULE_ADD_RESULT_ERR,
|
435
|
-
} ddog_prof_Profile_UpscalingRuleAddResult_Tag;
|
436
|
-
|
437
|
-
typedef struct ddog_prof_Profile_UpscalingRuleAddResult {
|
438
|
-
ddog_prof_Profile_UpscalingRuleAddResult_Tag tag;
|
439
|
-
union {
|
440
|
-
struct {
|
441
|
-
bool ok;
|
442
|
-
};
|
443
|
-
struct {
|
444
|
-
struct ddog_Error err;
|
445
|
-
};
|
446
|
-
};
|
447
|
-
} ddog_prof_Profile_UpscalingRuleAddResult;
|
448
|
-
|
449
474
|
/**
|
450
475
|
* Remember, the data inside of each member is potentially coming from FFI,
|
451
476
|
* so every operation on it is unsafe!
|
452
477
|
*/
|
453
478
|
typedef struct ddog_prof_Slice_Usize {
|
479
|
+
/**
|
480
|
+
* Must be non-null and suitably aligned for the underlying type.
|
481
|
+
*/
|
454
482
|
const uintptr_t *ptr;
|
483
|
+
/**
|
484
|
+
* The number of elements (not bytes) that `.ptr` points to.
|
485
|
+
*/
|
455
486
|
uintptr_t len;
|
456
487
|
} ddog_prof_Slice_Usize;
|
457
488
|
|
@@ -493,6 +524,17 @@ void ddog_Error_drop(struct ddog_Error *error);
|
|
493
524
|
*/
|
494
525
|
ddog_CharSlice ddog_Error_message(const struct ddog_Error *error);
|
495
526
|
|
527
|
+
DDOG_CHECK_RETURN struct ddog_Endpoint *ddog_endpoint_from_url(ddog_CharSlice url);
|
528
|
+
|
529
|
+
DDOG_CHECK_RETURN struct ddog_Endpoint *ddog_endpoint_from_api_key(ddog_CharSlice api_key);
|
530
|
+
|
531
|
+
DDOG_CHECK_RETURN
|
532
|
+
struct ddog_Error *ddog_endpoint_from_api_key_and_site(ddog_CharSlice api_key,
|
533
|
+
ddog_CharSlice site,
|
534
|
+
struct ddog_Endpoint **endpoint);
|
535
|
+
|
536
|
+
void ddog_endpoint_drop(struct ddog_Endpoint*);
|
537
|
+
|
496
538
|
DDOG_CHECK_RETURN struct ddog_Vec_Tag ddog_Vec_Tag_new(void);
|
497
539
|
|
498
540
|
void ddog_Vec_Tag_drop(struct ddog_Vec_Tag);
|
@@ -11,6 +11,8 @@
|
|
11
11
|
#include <stdint.h>
|
12
12
|
#include "common.h"
|
13
13
|
|
14
|
+
DDOG_CHECK_RETURN struct ddog_prof_Exporter_Slice_File ddog_prof_Exporter_Slice_File_empty(void);
|
15
|
+
|
14
16
|
/**
|
15
17
|
* Creates an endpoint that uses the agent.
|
16
18
|
* # Arguments
|
@@ -74,7 +76,8 @@ DDOG_CHECK_RETURN
|
|
74
76
|
struct ddog_prof_Exporter_Request_BuildResult ddog_prof_Exporter_Request_build(struct ddog_prof_Exporter *exporter,
|
75
77
|
struct ddog_Timespec start,
|
76
78
|
struct ddog_Timespec end,
|
77
|
-
struct ddog_prof_Exporter_Slice_File
|
79
|
+
struct ddog_prof_Exporter_Slice_File files_to_compress_and_export,
|
80
|
+
struct ddog_prof_Exporter_Slice_File files_to_export_unmodified,
|
78
81
|
const struct ddog_Vec_Tag *optional_additional_tags,
|
79
82
|
const struct ddog_prof_ProfiledEndpointsStats *optional_endpoints_stats,
|
80
83
|
const ddog_CharSlice *optional_internal_metadata_json,
|
@@ -170,14 +173,14 @@ void ddog_CancellationToken_drop(struct ddog_CancellationToken *token);
|
|
170
173
|
* and must have the correct number of elements for the slice.
|
171
174
|
*/
|
172
175
|
DDOG_CHECK_RETURN
|
173
|
-
struct
|
174
|
-
|
175
|
-
|
176
|
+
struct ddog_prof_Profile_NewResult ddog_prof_Profile_new(struct ddog_prof_Slice_ValueType sample_types,
|
177
|
+
const struct ddog_prof_Period *period,
|
178
|
+
const struct ddog_Timespec *start_time);
|
176
179
|
|
177
180
|
/**
|
178
181
|
* # Safety
|
179
|
-
* The `profile` can be null, but if non-null it must point to a
|
180
|
-
*
|
182
|
+
* The `profile` can be null, but if non-null it must point to a Profile
|
183
|
+
* made by this module, which has not previously been dropped.
|
181
184
|
*/
|
182
185
|
void ddog_prof_Profile_drop(struct ddog_prof_Profile *profile);
|
183
186
|
|
@@ -187,8 +190,8 @@ void ddog_prof_Profile_drop(struct ddog_prof_Profile *profile);
|
|
187
190
|
* module. All pointers inside the `sample` need to be valid for the duration
|
188
191
|
* of this call.
|
189
192
|
*
|
190
|
-
* If successful, it returns the
|
191
|
-
*
|
193
|
+
* If successful, it returns the Ok variant.
|
194
|
+
* On error, it holds an error message in the error variant.
|
192
195
|
*
|
193
196
|
* # Safety
|
194
197
|
* The `profile` ptr must point to a valid Profile object created by this
|
@@ -196,8 +199,9 @@ void ddog_prof_Profile_drop(struct ddog_prof_Profile *profile);
|
|
196
199
|
* This call is _NOT_ thread-safe.
|
197
200
|
*/
|
198
201
|
DDOG_CHECK_RETURN
|
199
|
-
struct
|
200
|
-
|
202
|
+
struct ddog_prof_Profile_Result ddog_prof_Profile_add(struct ddog_prof_Profile *profile,
|
203
|
+
struct ddog_prof_Sample sample,
|
204
|
+
int64_t timestamp);
|
201
205
|
|
202
206
|
/**
|
203
207
|
* Associate an endpoint to a given local root span id.
|
@@ -217,9 +221,10 @@ struct ddog_prof_Profile_AddResult ddog_prof_Profile_add(struct ddog_prof_Profil
|
|
217
221
|
* module.
|
218
222
|
* This call is _NOT_ thread-safe.
|
219
223
|
*/
|
220
|
-
|
221
|
-
|
222
|
-
|
224
|
+
DDOG_CHECK_RETURN
|
225
|
+
struct ddog_prof_Profile_Result ddog_prof_Profile_set_endpoint(struct ddog_prof_Profile *profile,
|
226
|
+
uint64_t local_root_span_id,
|
227
|
+
ddog_CharSlice endpoint);
|
223
228
|
|
224
229
|
/**
|
225
230
|
* Count the number of times an endpoint has been seen.
|
@@ -233,9 +238,10 @@ void ddog_prof_Profile_set_endpoint(struct ddog_prof_Profile *profile,
|
|
233
238
|
* module.
|
234
239
|
* This call is _NOT_ thread-safe.
|
235
240
|
*/
|
236
|
-
|
237
|
-
|
238
|
-
|
241
|
+
DDOG_CHECK_RETURN
|
242
|
+
struct ddog_prof_Profile_Result ddog_prof_Profile_add_endpoint_count(struct ddog_prof_Profile *profile,
|
243
|
+
ddog_CharSlice endpoint,
|
244
|
+
int64_t value);
|
239
245
|
|
240
246
|
/**
|
241
247
|
* Add a poisson-based upscaling rule which will be use to adjust values and make them
|
@@ -257,13 +263,13 @@ void ddog_prof_Profile_add_endpoint_count(struct ddog_prof_Profile *profile,
|
|
257
263
|
* This call is _NOT_ thread-safe.
|
258
264
|
*/
|
259
265
|
DDOG_CHECK_RETURN
|
260
|
-
struct
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
266
|
+
struct ddog_prof_Profile_Result ddog_prof_Profile_add_upscaling_rule_poisson(struct ddog_prof_Profile *profile,
|
267
|
+
struct ddog_prof_Slice_Usize offset_values,
|
268
|
+
ddog_CharSlice label_name,
|
269
|
+
ddog_CharSlice label_value,
|
270
|
+
uintptr_t sum_value_offset,
|
271
|
+
uintptr_t count_value_offset,
|
272
|
+
uint64_t sampling_distance);
|
267
273
|
|
268
274
|
/**
|
269
275
|
* Add a proportional-based upscaling rule which will be use to adjust values and make them
|
@@ -284,12 +290,12 @@ struct ddog_prof_Profile_UpscalingRuleAddResult ddog_prof_Profile_add_upscaling_
|
|
284
290
|
* This call is _NOT_ thread-safe.
|
285
291
|
*/
|
286
292
|
DDOG_CHECK_RETURN
|
287
|
-
struct
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
+
struct ddog_prof_Profile_Result ddog_prof_Profile_add_upscaling_rule_proportional(struct ddog_prof_Profile *profile,
|
294
|
+
struct ddog_prof_Slice_Usize offset_values,
|
295
|
+
ddog_CharSlice label_name,
|
296
|
+
ddog_CharSlice label_value,
|
297
|
+
uint64_t total_sampled,
|
298
|
+
uint64_t total_real);
|
293
299
|
|
294
300
|
/**
|
295
301
|
* # Safety
|
@@ -301,6 +307,7 @@ void ddog_prof_EncodedProfile_drop(struct ddog_prof_EncodedProfile *profile);
|
|
301
307
|
|
302
308
|
/**
|
303
309
|
* Serialize the aggregated profile.
|
310
|
+
* Drains the data, and then resets the profile for future use.
|
304
311
|
*
|
305
312
|
* Don't forget to clean up the ok with `ddog_prof_EncodedProfile_drop` or
|
306
313
|
* the error variant with `ddog_Error_drop` when you are done with them.
|
@@ -314,6 +321,7 @@ void ddog_prof_EncodedProfile_drop(struct ddog_prof_EncodedProfile *profile);
|
|
314
321
|
* under anomalous conditions this may fail as system clocks can be adjusted,
|
315
322
|
* or the programmer accidentally passed an earlier time. The duration of
|
316
323
|
* the serialized profile will be set to zero for these cases.
|
324
|
+
* * `start_time` - Optional start time for the next profile.
|
317
325
|
*
|
318
326
|
* # Safety
|
319
327
|
* The `profile` must point to a valid profile object.
|
@@ -321,9 +329,10 @@ void ddog_prof_EncodedProfile_drop(struct ddog_prof_EncodedProfile *profile);
|
|
321
329
|
* The `duration_nanos` must be null or otherwise point to a valid i64.
|
322
330
|
*/
|
323
331
|
DDOG_CHECK_RETURN
|
324
|
-
struct ddog_prof_Profile_SerializeResult ddog_prof_Profile_serialize(
|
332
|
+
struct ddog_prof_Profile_SerializeResult ddog_prof_Profile_serialize(struct ddog_prof_Profile *profile,
|
325
333
|
const struct ddog_Timespec *end_time,
|
326
|
-
const int64_t *duration_nanos
|
334
|
+
const int64_t *duration_nanos,
|
335
|
+
const struct ddog_Timespec *start_time);
|
327
336
|
|
328
337
|
DDOG_CHECK_RETURN struct ddog_Slice_U8 ddog_Vec_U8_as_slice(const struct ddog_Vec_U8 *vec);
|
329
338
|
|
@@ -341,7 +350,8 @@ DDOG_CHECK_RETURN struct ddog_Slice_U8 ddog_Vec_U8_as_slice(const struct ddog_Ve
|
|
341
350
|
* can be called across an FFI boundary, the compiler cannot enforce this.
|
342
351
|
* If `time` is not null, it must point to a valid Timespec object.
|
343
352
|
*/
|
344
|
-
|
345
|
-
|
353
|
+
DDOG_CHECK_RETURN
|
354
|
+
struct ddog_prof_Profile_Result ddog_prof_Profile_reset(struct ddog_prof_Profile *profile,
|
355
|
+
const struct ddog_Timespec *start_time);
|
346
356
|
|
347
357
|
#endif /* DDOG_PROFILING_H */
|
Binary file
|
@@ -10,7 +10,7 @@ includedir=${prefix}/include
|
|
10
10
|
|
11
11
|
Name: datadog_profiling
|
12
12
|
Description: Contains common code used to implement Datadog's Continuous Profilers. (Dynamic linking variant, sets rpath)
|
13
|
-
Version:
|
13
|
+
Version:
|
14
14
|
Requires:
|
15
15
|
Libs: -L${libdir} -ldatadog_profiling -Wl,-rpath,${libdir}
|
16
16
|
Libs.private:
|