/* -*- 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__