59 lines
1.8 KiB
C++
59 lines
1.8 KiB
C++
/* -*- 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 MMPrinter_h
|
|
#define MMPrinter_h
|
|
|
|
#include "mozilla/Maybe.h"
|
|
#include "mozilla/dom/DOMTypes.h"
|
|
#include "nsString.h"
|
|
|
|
namespace mozilla::dom {
|
|
|
|
class MMPrinter {
|
|
public:
|
|
static void Print(char const* aLocation, const nsAString& aMsg,
|
|
ClonedMessageData const& aData) {
|
|
if (MOZ_UNLIKELY(MOZ_LOG_TEST(MMPrinter::sMMLog, LogLevel::Debug))) {
|
|
Maybe<uint64_t> msgId = MMPrinter::PrintHeader(aLocation, aMsg);
|
|
if (!msgId.isSome()) {
|
|
return;
|
|
}
|
|
MMPrinter::PrintData(*msgId, aData);
|
|
}
|
|
}
|
|
|
|
static void Print(char const* aLocation, const nsACString& aActorName,
|
|
const nsAString& aMessageName,
|
|
const Maybe<ClonedMessageData>& aData) {
|
|
if (MOZ_UNLIKELY(MOZ_LOG_TEST(MMPrinter::sMMLog, LogLevel::Debug))) {
|
|
Maybe<uint64_t> msgId = MMPrinter::PrintHeader(
|
|
aLocation,
|
|
NS_ConvertUTF8toUTF16(aActorName + " - "_ns) + aMessageName);
|
|
|
|
if (!msgId.isSome()) {
|
|
return;
|
|
}
|
|
|
|
if (aData.isSome()) {
|
|
MMPrinter::PrintData(*msgId, *aData);
|
|
} else {
|
|
MMPrinter::PrintNoData(*msgId);
|
|
}
|
|
}
|
|
}
|
|
|
|
private:
|
|
static LazyLogModule sMMLog;
|
|
static Maybe<uint64_t> PrintHeader(char const* aLocation,
|
|
const nsAString& aMsg);
|
|
static void PrintNoData(uint64_t aMsgId);
|
|
static void PrintData(uint64_t aMsgId, ClonedMessageData const& aData);
|
|
};
|
|
|
|
} // namespace mozilla::dom
|
|
|
|
#endif /* MMPrinter_h */
|