kicad/thirdparty/sentry-native/src/sentry_backend.h

44 lines
1.4 KiB
C

#ifndef SENTRY_BACKEND_H_INCLUDED
#define SENTRY_BACKEND_H_INCLUDED
#include "sentry_boot.h"
#include "sentry_scope.h"
/**
* This represents the crash handling backend.
* It consists of a few hooks that integrate into the sentry lifecycle and which
* can ensure that any captured crash contains the sentry scope and other
* information.
*/
typedef struct sentry_backend_s sentry_backend_t;
struct sentry_backend_s {
int (*startup_func)(sentry_backend_t *, const sentry_options_t *options);
void (*shutdown_func)(sentry_backend_t *);
void (*free_func)(sentry_backend_t *);
void (*except_func)(sentry_backend_t *, const struct sentry_ucontext_s *);
void (*flush_scope_func)(
sentry_backend_t *, const sentry_options_t *options);
// NOTE: The breadcrumb is not moved into the hook and does not need to be
// `decref`-d internally.
void (*add_breadcrumb_func)(sentry_backend_t *, sentry_value_t breadcrumb,
const sentry_options_t *options);
void (*user_consent_changed_func)(sentry_backend_t *);
uint64_t (*get_last_crash_func)(sentry_backend_t *);
void (*prune_database_func)(sentry_backend_t *);
void *data;
bool can_capture_after_shutdown;
};
/**
* This will free a previously allocated backend.
*/
void sentry__backend_free(sentry_backend_t *backend);
/**
* Create a new backend, depending on build-time configuration.
*/
sentry_backend_t *sentry__backend_new(void);
#endif