libdatadog 3.0.0.1.0 → 5.0.0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (35) hide show
  1. checksums.yaml +4 -4
  2. data/lib/libdatadog/version.rb +1 -1
  3. data/vendor/{libdatadog-3.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-5.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu}/LICENSE-3rdparty.yml +9906 -5192
  4. data/vendor/{libdatadog-3.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-5.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu}/include/datadog/common.h +135 -93
  5. data/vendor/{libdatadog-3.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-5.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu}/include/datadog/profiling.h +43 -33
  6. data/vendor/libdatadog-5.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
  7. data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
  8. data/vendor/{libdatadog-3.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-5.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl}/LICENSE-3rdparty.yml +9906 -5192
  9. data/vendor/{libdatadog-3.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-5.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl}/include/datadog/common.h +135 -93
  10. data/vendor/{libdatadog-3.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-5.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl}/include/datadog/profiling.h +43 -33
  11. data/vendor/libdatadog-5.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
  12. data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
  13. 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}/LICENSE-3rdparty.yml +9906 -5192
  14. data/vendor/{libdatadog-3.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-5.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu}/include/datadog/common.h +135 -93
  15. 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
  16. data/vendor/libdatadog-5.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
  17. 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
  18. data/vendor/{libdatadog-3.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-5.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl}/LICENSE-3rdparty.yml +9906 -5192
  19. 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
  20. data/vendor/{libdatadog-3.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-5.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl}/include/datadog/profiling.h +43 -33
  21. data/vendor/libdatadog-5.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
  22. 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
  23. metadata +30 -30
  24. data/vendor/libdatadog-3.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
  25. data/vendor/libdatadog-3.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
  26. data/vendor/libdatadog-3.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
  27. data/vendor/libdatadog-3.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/lib/libdatadog_profiling.so +0 -0
  28. /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/LICENSE +0 -0
  29. /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/NOTICE +0 -0
  30. /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/LICENSE +0 -0
  31. /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/NOTICE +0 -0
  32. /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/LICENSE +0 -0
  33. /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/NOTICE +0 -0
  34. /data/vendor/{libdatadog-3.0.0 → libdatadog-5.0.0}/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/LICENSE +0 -0
  35. /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
- typedef enum ddog_prof_Profile_AddResult_Tag {
249
- DDOG_PROF_PROFILE_ADD_RESULT_OK,
250
- DDOG_PROF_PROFILE_ADD_RESULT_ERR,
251
- } ddog_prof_Profile_AddResult_Tag;
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 ddog_prof_Profile_AddResult {
254
- ddog_prof_Profile_AddResult_Tag tag;
309
+ typedef struct ddog_prof_Profile_Result {
310
+ ddog_prof_Profile_Result_Tag tag;
255
311
  union {
256
312
  struct {
257
- uint64_t ok;
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
- } ddog_prof_Profile_AddResult;
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 files,
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 ddog_prof_Profile *ddog_prof_Profile_new(struct ddog_prof_Slice_ValueType sample_types,
174
- const struct ddog_prof_Period *period,
175
- const struct ddog_Timespec *start_time);
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 valid object
180
- * created by the Rust Global allocator.
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 internal id of the sample (> 0) in the Ok
191
- * variant. On error, it holds an error message in the error variant.
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 ddog_prof_Profile_AddResult ddog_prof_Profile_add(struct ddog_prof_Profile *profile,
200
- struct ddog_prof_Sample sample);
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
- void ddog_prof_Profile_set_endpoint(struct ddog_prof_Profile *profile,
221
- uint64_t local_root_span_id,
222
- ddog_CharSlice endpoint);
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
- void ddog_prof_Profile_add_endpoint_count(struct ddog_prof_Profile *profile,
237
- ddog_CharSlice endpoint,
238
- int64_t value);
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 ddog_prof_Profile_UpscalingRuleAddResult ddog_prof_Profile_add_upscaling_rule_poisson(struct ddog_prof_Profile *profile,
261
- struct ddog_prof_Slice_Usize offset_values,
262
- ddog_CharSlice label_name,
263
- ddog_CharSlice label_value,
264
- uintptr_t sum_value_offset,
265
- uintptr_t count_value_offset,
266
- uint64_t sampling_distance);
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 ddog_prof_Profile_UpscalingRuleAddResult ddog_prof_Profile_add_upscaling_rule_proportional(struct ddog_prof_Profile *profile,
288
- struct ddog_prof_Slice_Usize offset_values,
289
- ddog_CharSlice label_name,
290
- ddog_CharSlice label_value,
291
- uint64_t total_sampled,
292
- uint64_t total_real);
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(const struct ddog_prof_Profile *profile,
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
- bool ddog_prof_Profile_reset(struct ddog_prof_Profile *profile,
345
- const struct ddog_Timespec *start_time);
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 */
@@ -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: 3.0.0
13
+ Version:
14
14
  Requires:
15
15
  Libs: -L${libdir} -ldatadog_profiling -Wl,-rpath,${libdir}
16
16
  Libs.private: