/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* 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 js_EnvironmentChain_h #define js_EnvironmentChain_h #include "mozilla/Attributes.h" // MOZ_RAII #include // size_t #include "jstypes.h" // JS_PUBLIC_API #include "js/GCVector.h" // JS::RootedVector struct JS_PUBLIC_API JSContext; class JS_PUBLIC_API JSObject; namespace JS { enum class SupportUnscopables : bool { No = false, Yes = true }; /** * JS::EnvironmentChain stores a list of objects to put on the environment * chain. * * Internally the engine will create a non-syntactic 'with' environment for each * of these objects. Note that 'with' environments aren't optimized well so you * should use this class only if you really have to. * * The SupportUnscopables enum class controls whether these non-syntactic 'with' * environments support Symbol.unscopables similar to syntactic 'with' * statements in JS. * * Passing SupportUnscopables::No is better for performance because it lets us * skip the Symbol.unscopables property lookup. Some Web APIs require supporting * Symbol.unscopables though. In Firefox, SupportUnscopables::Yes is used for * event handlers. */ class MOZ_RAII JS_PUBLIC_API EnvironmentChain { JS::RootedObjectVector chain_; SupportUnscopables supportUnscopables_; public: EnvironmentChain(JSContext* cx, SupportUnscopables supportUnscopables) : chain_(cx), supportUnscopables_(supportUnscopables) {} EnvironmentChain(const EnvironmentChain&) = delete; void operator=(const EnvironmentChain&) = delete; [[nodiscard]] bool append(JSObject* obj) { return chain_.append(obj); } bool empty() const { return chain_.empty(); } size_t length() const { return chain_.length(); } RootedObjectVector& chain() { return chain_; } const RootedObjectVector& chain() const { return chain_; } void setSupportUnscopables(SupportUnscopables supportUnscopables) { supportUnscopables_ = supportUnscopables; } SupportUnscopables supportUnscopables() const { return supportUnscopables_; } }; } // namespace JS #endif /* js_EnvironmentChain_h */