summaryrefslogtreecommitdiffstats
path: root/toolkit/crashreporter/CrashAnnotations.h.in
diff options
context:
space:
mode:
Diffstat (limited to 'toolkit/crashreporter/CrashAnnotations.h.in')
-rw-r--r--toolkit/crashreporter/CrashAnnotations.h.in105
1 files changed, 105 insertions, 0 deletions
diff --git a/toolkit/crashreporter/CrashAnnotations.h.in b/toolkit/crashreporter/CrashAnnotations.h.in
new file mode 100644
index 0000000000..7ea8c98bc1
--- /dev/null
+++ b/toolkit/crashreporter/CrashAnnotations.h.in
@@ -0,0 +1,105 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+#ifndef CrashAnnotations_h
+#define CrashAnnotations_h
+
+#include <cstddef>
+#include <cstdint>
+
+namespace CrashReporter {
+
+// Typed enum representing all crash annotations
+enum class Annotation : uint32_t {
+${enum}
+};
+
+// Stringified crash annotation names
+const char* const kAnnotationStrings[] = {
+${strings}
+};
+
+// Type of each annotation
+enum class AnnotationType : uint8_t {
+ String = 0, // Any type of string, const char*, nsCString, etc...
+ Boolean = 1, // Stored as a byte
+ U32 = 2, // C/C++'s uint32_t or Rust's u32
+ U64 = 3, // C/C++'s uint64_t or Rust's u64
+ USize = 4, // C/C++'s size_t or Rust's usize
+};
+
+// Type of each annotation
+const AnnotationType kAnnotationTypes[] = {
+${types}
+};
+
+// Allowlist of crash annotations that can be included in a crash ping
+const Annotation kCrashPingAllowedList[] = {
+${allowedlist}
+};
+
+// Annotations which should be skipped when they have specific values
+struct AnnotationSkipValue {
+ Annotation annotation;
+ const char* value;
+};
+
+const AnnotationSkipValue kSkipIfList[] = {
+${skiplist}
+};
+
+/**
+ * Return the string representation of a crash annotation.
+ *
+ * @param aAnnotation a crash annotation
+ * @returns A constant string holding the annotation name
+ */
+static inline const char* AnnotationToString(Annotation aAnnotation) {
+ return kAnnotationStrings[static_cast<uint32_t>(aAnnotation)];
+}
+
+/**
+ * Converts a string to its corresponding crash annotation.
+ *
+ * @param aResult a reference where the annotation will be stored
+ * @param aValue the string to be converted
+ * @return true if the string was successfully converted, false if it did not
+ * correspond to any known annotation
+ */
+bool AnnotationFromString(Annotation& aResult, const char* aValue);
+
+/**
+ * Checks if the given crash annotation is allowed for inclusion in the crash
+ * ping.
+ *
+ * @param aAnnotation the crash annotation to be checked
+ * @return true if the annotation can be included in the crash ping, false
+ * otherwise
+ */
+bool IsAnnotationAllowedForPing(Annotation aAnnotation);
+
+/**
+ * Checks if the annotation should be included. Some annotations are skipped if
+ * their value matches a specific one (like the value 0).
+ *
+ * @param aAnnotation the crash annotation to be checked
+ * @param aValue the contents of the annotation as a string
+ * @return true if the annotation should be included, false otherwise
+ */
+bool ShouldIncludeAnnotation(Annotation aAnnotation, const char* aValue);
+
+/**
+ * Abstract annotation writer, this is needed only for code that writes out
+ * annotations in the exception handler.
+ */
+class AnnotationWriter {
+ public:
+ virtual void Write(Annotation aAnnotation, const char* aValue,
+ size_t aLen = 0) = 0;
+ virtual void Write(Annotation aAnnotation, uint64_t aValue) = 0;
+};
+
+} // namespace CrashReporter
+
+#endif // CrashAnnotations_h