summaryrefslogtreecommitdiffstats
path: root/dom/indexedDB/ProfilerHelpers.h
diff options
context:
space:
mode:
Diffstat (limited to 'dom/indexedDB/ProfilerHelpers.h')
-rw-r--r--dom/indexedDB/ProfilerHelpers.h145
1 files changed, 145 insertions, 0 deletions
diff --git a/dom/indexedDB/ProfilerHelpers.h b/dom/indexedDB/ProfilerHelpers.h
new file mode 100644
index 0000000000..efba9d9cd0
--- /dev/null
+++ b/dom/indexedDB/ProfilerHelpers.h
@@ -0,0 +1,145 @@
+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim: set ts=8 sts=2 et sw=2 tw=80: */
+/* 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 mozilla_dom_indexeddb_profilerhelpers_h__
+#define mozilla_dom_indexeddb_profilerhelpers_h__
+
+// This file is not exported and is only meant to be included in IndexedDB
+// source files.
+
+#include "IndexedDatabaseManager.h"
+#include "mozilla/dom/BindingDeclarations.h"
+#include "mozilla/dom/IDBCursorBinding.h"
+#include "nsID.h"
+#include "nsString.h"
+
+namespace mozilla::dom {
+
+class Event;
+class IDBDatabase;
+class IDBIndex;
+class IDBKeyRange;
+class IDBObjectStore;
+class IDBTransaction;
+
+namespace indexedDB {
+
+class Key;
+
+template <bool CheckLoggingMode>
+class LoggingIdString final : public nsAutoCStringN<NSID_LENGTH> {
+ public:
+ LoggingIdString();
+
+ explicit LoggingIdString(const nsID& aID);
+};
+
+class MOZ_STACK_CLASS LoggingString final : public nsAutoCString {
+ public:
+ explicit LoggingString(IDBDatabase* aDatabase);
+ explicit LoggingString(const IDBTransaction& aTransaction);
+ explicit LoggingString(IDBObjectStore* aObjectStore);
+ explicit LoggingString(IDBIndex* aIndex);
+ explicit LoggingString(IDBKeyRange* aKeyRange);
+ explicit LoggingString(const Key& aKey);
+ explicit LoggingString(const IDBCursorDirection aDirection);
+ explicit LoggingString(const Optional<uint64_t>& aVersion);
+ explicit LoggingString(const Optional<uint32_t>& aLimit);
+
+ LoggingString(IDBObjectStore* aObjectStore, const Key& aKey);
+ LoggingString(Event* aEvent, const char16_t* aDefault);
+};
+
+// Both the aDetailedFmt and the aConciseFmt need to match the variable argument
+// list, so we use MOZ_FORMAT_PRINTF twice here.
+void MOZ_FORMAT_PRINTF(1, 3) MOZ_FORMAT_PRINTF(2, 3)
+ LoggingHelper(const char* aDetailedFmt, const char* aConciseFmt, ...);
+
+} // namespace indexedDB
+} // namespace mozilla::dom
+
+#define IDB_LOG_MARK(_detailedFmt, _conciseFmt, _loggingId, ...) \
+ mozilla::dom::indexedDB::LoggingHelper("IndexedDB %s: " _detailedFmt, \
+ "IndexedDB %s: " _conciseFmt, \
+ _loggingId, ##__VA_ARGS__)
+
+#define IDB_LOG_ID_STRING(...) \
+ mozilla::dom::indexedDB::LoggingIdString<true>(__VA_ARGS__).get()
+
+#define IDB_LOG_STRINGIFY(...) \
+ mozilla::dom::indexedDB::LoggingString(__VA_ARGS__).get()
+
+// IDB_LOG_MARK_DETAILED_PARENT and IDB_LOG_MARK_DETAILED_CHILD should have the
+// same width.
+#define IDB_LOG_MARK_DETAILED_PARENT "Parent"
+#define IDB_LOG_MARK_DETAILED_CHILD "Child "
+
+#define IDB_LOG_MARK_CONCISE_PARENT "P"
+#define IDB_LOG_MARK_CONCISE_CHILD "C"
+
+#define IDB_LOG_MARK_DETAILED_TRANSACTION "Transaction[%" PRIi64 "]"
+#define IDB_LOG_MARK_DETAILED_REQUEST "Request[%" PRIu64 "]"
+
+#define IDB_LOG_MARK_CONCISE_TRANSACTION "T[%" PRIi64 "]"
+#define IDB_LOG_MARK_CONCISE_REQUEST "R[%" PRIu64 "]"
+
+#define IDB_LOG_MARK_TRANSACTION_REQUEST( \
+ _detailedPeer, _concisePeer, _detailedFmt, _conciseFmt, _loggingId, \
+ _transactionSerialNumber, _requestSerialNumber, ...) \
+ IDB_LOG_MARK(_detailedPeer " " IDB_LOG_MARK_DETAILED_TRANSACTION \
+ " " IDB_LOG_MARK_DETAILED_REQUEST \
+ ": " _detailedFmt, \
+ _concisePeer " " IDB_LOG_MARK_CONCISE_TRANSACTION \
+ " " IDB_LOG_MARK_CONCISE_REQUEST ": " _conciseFmt, \
+ _loggingId, _transactionSerialNumber, _requestSerialNumber, \
+ ##__VA_ARGS__)
+
+#define IDB_LOG_MARK_PARENT_TRANSACTION_REQUEST( \
+ _detailedFmt, _conciseFmt, _loggingId, _transactionSerialNumber, \
+ _requestSerialNumber, ...) \
+ IDB_LOG_MARK_TRANSACTION_REQUEST( \
+ IDB_LOG_MARK_DETAILED_PARENT, IDB_LOG_MARK_CONCISE_PARENT, _detailedFmt, \
+ _conciseFmt, _loggingId, _transactionSerialNumber, _requestSerialNumber, \
+ ##__VA_ARGS__)
+
+#define IDB_LOG_MARK_CHILD_TRANSACTION_REQUEST(_detailedFmt, _conciseFmt, \
+ _transactionSerialNumber, \
+ _requestSerialNumber, ...) \
+ IDB_LOG_MARK_TRANSACTION_REQUEST( \
+ IDB_LOG_MARK_DETAILED_CHILD, IDB_LOG_MARK_CONCISE_CHILD, _detailedFmt, \
+ _conciseFmt, IDB_LOG_ID_STRING(), _transactionSerialNumber, \
+ _requestSerialNumber, ##__VA_ARGS__)
+
+#define IDB_LOG_MARK_CHILD_REQUEST(_detailedFmt, _conciseFmt, \
+ _requestSerialNumber, ...) \
+ IDB_LOG_MARK(IDB_LOG_MARK_DETAILED_CHILD " " IDB_LOG_MARK_DETAILED_REQUEST \
+ ": " _detailedFmt, \
+ IDB_LOG_MARK_CONCISE_CHILD " " IDB_LOG_MARK_CONCISE_REQUEST \
+ ": " _conciseFmt, \
+ IDB_LOG_ID_STRING(), _requestSerialNumber, ##__VA_ARGS__)
+
+#define IDB_LOG_MARK_TRANSACTION(_detailedPeer, _concisePeer, _detailedFmt, \
+ _conciseFmt, _loggingId, \
+ _transactionSerialNumber, ...) \
+ IDB_LOG_MARK( \
+ _detailedPeer " " IDB_LOG_MARK_DETAILED_TRANSACTION ": " _detailedFmt, \
+ _concisePeer " " IDB_LOG_MARK_CONCISE_TRANSACTION ": " _conciseFmt, \
+ _loggingId, _transactionSerialNumber, ##__VA_ARGS__)
+
+#define IDB_LOG_MARK_PARENT_TRANSACTION(_detailedFmt, _conciseFmt, _loggingId, \
+ _transactionSerialNumber, ...) \
+ IDB_LOG_MARK_TRANSACTION( \
+ IDB_LOG_MARK_DETAILED_PARENT, IDB_LOG_MARK_CONCISE_PARENT, _detailedFmt, \
+ _conciseFmt, _loggingId, _transactionSerialNumber, ##__VA_ARGS__)
+
+#define IDB_LOG_MARK_CHILD_TRANSACTION(_detailedFmt, _conciseFmt, \
+ _transactionSerialNumber, ...) \
+ IDB_LOG_MARK_TRANSACTION(IDB_LOG_MARK_DETAILED_CHILD, \
+ IDB_LOG_MARK_CONCISE_CHILD, _detailedFmt, \
+ _conciseFmt, IDB_LOG_ID_STRING(), \
+ _transactionSerialNumber, ##__VA_ARGS__)
+
+#endif // mozilla_dom_indexeddb_profilerhelpers_h__