mirror of
				https://github.com/mozilla/gecko-dev.git
				synced 2025-10-31 16:28:05 +02:00 
			
		
		
		
	 a26eafe5c3
			
		
	
	
		a26eafe5c3
		
	
	
	
	
		
			
			This patch removes the old docshell timeline and timeline markers codebase and replaces them with equivalent Gecko profiler marker. This patch also fixes Bug 1834143, which is a subset of 1421651.
Differential Revision: https://phabricator.services.mozilla.com/D184217
		
	
			
		
			
				
	
	
		
			82 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
	
		
			2.5 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/. */
 | |
| 
 | |
| #include "mozilla/dom/AutoEntryScript.h"
 | |
| 
 | |
| #include <stdint.h>
 | |
| #include <utility>
 | |
| #include "js/ProfilingCategory.h"
 | |
| #include "js/ProfilingStack.h"
 | |
| #include "jsapi.h"
 | |
| #include "mozilla/Assertions.h"
 | |
| #include "mozilla/Maybe.h"
 | |
| #include "mozilla/Span.h"
 | |
| #include "nsCOMPtr.h"
 | |
| #include "nsContentUtils.h"
 | |
| #include "nsGlobalWindowInner.h"
 | |
| #include "nsIDocShell.h"
 | |
| #include "nsJSUtils.h"
 | |
| #include "nsPIDOMWindow.h"
 | |
| #include "nsPIDOMWindowInlines.h"
 | |
| #include "nsString.h"
 | |
| #include "xpcpublic.h"
 | |
| 
 | |
| namespace mozilla::dom {
 | |
| 
 | |
| namespace {
 | |
| // Assert if it's not safe to run script. The helper class
 | |
| // AutoAllowLegacyScriptExecution allows to allow-list
 | |
| // legacy cases where it's actually not safe to run script.
 | |
| #ifdef DEBUG
 | |
| void AssertIfNotSafeToRunScript() {
 | |
|   // if it's safe to run script, then there is nothing to do here.
 | |
|   if (nsContentUtils::IsSafeToRunScript()) {
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   // auto allowing legacy script execution is fine for now.
 | |
|   if (AutoAllowLegacyScriptExecution::IsAllowed()) {
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   MOZ_ASSERT(false, "is it safe to run script?");
 | |
| }
 | |
| #endif
 | |
| 
 | |
| }  // namespace
 | |
| 
 | |
| AutoEntryScript::AutoEntryScript(nsIGlobalObject* aGlobalObject,
 | |
|                                  const char* aReason, bool aIsMainThread)
 | |
|     : AutoJSAPI(aGlobalObject, aIsMainThread, eEntryScript),
 | |
|       mWebIDLCallerPrincipal(nullptr)
 | |
|       // This relies on us having a cx() because the AutoJSAPI constructor
 | |
|       // already ran.
 | |
|       ,
 | |
|       mCallerOverride(cx()),
 | |
|       mAutoProfilerLabel(
 | |
|           "", aReason, JS::ProfilingCategoryPair::JS,
 | |
|           uint32_t(js::ProfilingStackFrame::Flags::RELEVANT_FOR_JS)),
 | |
|       mJSThreadExecution(aGlobalObject, aIsMainThread) {
 | |
|   MOZ_ASSERT(aGlobalObject);
 | |
| 
 | |
|   if (aIsMainThread) {
 | |
| #ifdef DEBUG
 | |
|     AssertIfNotSafeToRunScript();
 | |
| #endif
 | |
|     mScriptActivity.emplace(true);
 | |
|   }
 | |
| }
 | |
| 
 | |
| AutoEntryScript::AutoEntryScript(JSObject* aObject, const char* aReason,
 | |
|                                  bool aIsMainThread)
 | |
|     : AutoEntryScript(xpc::NativeGlobal(aObject), aReason, aIsMainThread) {
 | |
|   // xpc::NativeGlobal uses JS::GetNonCCWObjectGlobal, which asserts that
 | |
|   // aObject is not a CCW.
 | |
| }
 | |
| 
 | |
| AutoEntryScript::~AutoEntryScript() = default;
 | |
| 
 | |
| }  // namespace mozilla::dom
 |