summaryrefslogtreecommitdiffstats
path: root/dom/console/ConsoleInstance.h
diff options
context:
space:
mode:
Diffstat (limited to 'dom/console/ConsoleInstance.h')
-rw-r--r--dom/console/ConsoleInstance.h122
1 files changed, 122 insertions, 0 deletions
diff --git a/dom/console/ConsoleInstance.h b/dom/console/ConsoleInstance.h
new file mode 100644
index 0000000000..5d322a867b
--- /dev/null
+++ b/dom/console/ConsoleInstance.h
@@ -0,0 +1,122 @@
+/* -*- 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_ConsoleInstance_h
+#define mozilla_dom_ConsoleInstance_h
+
+#include "mozilla/dom/Console.h"
+
+namespace mozilla::dom {
+
+class ConsoleInstance final : public nsISupports, public nsWrapperCache {
+ public:
+ NS_DECL_CYCLE_COLLECTING_ISUPPORTS
+ NS_DECL_CYCLE_COLLECTION_WRAPPERCACHE_CLASS(ConsoleInstance)
+
+ explicit ConsoleInstance(JSContext* aCx,
+ const ConsoleInstanceOptions& aOptions);
+
+ // WebIDL methods
+ JSObject* WrapObject(JSContext* aCx,
+ JS::Handle<JSObject*> aGivenProto) override;
+
+ nsPIDOMWindowInner* GetParentObject() const { return nullptr; }
+
+ MOZ_CAN_RUN_SCRIPT
+ void Log(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Info(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Warn(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Error(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Exception(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Debug(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Table(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Trace(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Dir(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Dirxml(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Group(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void GroupCollapsed(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void GroupEnd(JSContext* aCx);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Time(JSContext* aCx, const nsAString& aLabel);
+
+ MOZ_CAN_RUN_SCRIPT
+ void TimeLog(JSContext* aCx, const nsAString& aLabel,
+ const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void TimeEnd(JSContext* aCx, const nsAString& aLabel);
+
+ MOZ_CAN_RUN_SCRIPT
+ void TimeStamp(JSContext* aCx, const JS::Handle<JS::Value> aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Profile(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void ProfileEnd(JSContext* aCx, const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Assert(JSContext* aCx, bool aCondition,
+ const Sequence<JS::Value>& aData);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Count(JSContext* aCx, const nsAString& aLabel);
+
+ MOZ_CAN_RUN_SCRIPT
+ void CountReset(JSContext* aCx, const nsAString& aLabel);
+
+ MOZ_CAN_RUN_SCRIPT
+ void Clear(JSContext* aCx);
+
+ bool ShouldLog(ConsoleLogLevel aLevel);
+
+ // For testing only.
+ void ReportForServiceWorkerScope(const nsAString& aScope,
+ const nsAString& aMessage,
+ const nsAString& aFilename,
+ uint32_t aLineNumber, uint32_t aColumnNumber,
+ ConsoleLevel aLevel);
+
+ private:
+ ~ConsoleInstance();
+
+ void SetLogLevel();
+ static void MaxLogLevelPrefChangedCallback(const char* /* aPrefName */,
+ void* /* aClosure */);
+
+ ConsoleLogLevel mMaxLogLevel;
+ nsCString mMaxLogLevelPref;
+ RefPtr<Console> mConsole;
+};
+
+} // namespace mozilla::dom
+
+#endif // mozilla_dom_ConsoleInstance_h