Chromium Code Reviews| Index: third_party/WebKit/Source/bindings/core/v8/ScriptModule.h |
| diff --git a/third_party/WebKit/Source/bindings/core/v8/ScriptModule.h b/third_party/WebKit/Source/bindings/core/v8/ScriptModule.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..a18ed394e666d26c77712f5a7f5bf93bc03b5b65 |
| --- /dev/null |
| +++ b/third_party/WebKit/Source/bindings/core/v8/ScriptModule.h |
| @@ -0,0 +1,143 @@ |
| +// Copyright 2017 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef ScriptModule_h |
| +#define ScriptModule_h |
| + |
| +#include "bindings/core/v8/ScriptState.h" |
| +#include "bindings/core/v8/SharedPersistent.h" |
| +#include "core/CoreExport.h" |
| +#include "wtf/Allocator.h" |
| +#include "wtf/HashTableDeletedValueType.h" |
| +#include "wtf/HashTraits.h" |
| +#include "wtf/Vector.h" |
| +#include "wtf/text/WTFString.h" |
| +#include <v8.h> |
| + |
| +namespace blink { |
| + |
| +class ScriptModuleIdentifier; |
| +class ScriptState; |
| + |
| +// A ScriptModule wraps a handle to v8::Module for its carry outside V8 |
|
dominicc (has gone to gerrit)
2017/01/11 03:23:47
Grammar: "for its carry" doesn't make sense. Maybe
kouhei (in TOK)
2017/01/17 05:26:13
Done.
|
| +// bindings. |
| +// |
| +// Note: Use ModulatorImpl to provide scriptState context to actually |
|
dominicc (has gone to gerrit)
2017/01/11 03:23:47
Hmm, why do these abstractions need to depend on o
kouhei (in TOK)
2017/01/17 05:26:12
adamk, dominicc: PTAL
|
| +// operate or extract information from ScriptModule. |
| +class CORE_EXPORT ScriptModule final { |
| + DISALLOW_NEW_EXCEPT_PLACEMENT_NEW(); |
| + |
| + public: |
| + static ScriptModule compile(v8::Isolate*, |
| + const String& source, |
| + const String& fileName); |
| + |
| + ScriptModule() {} |
| + ScriptModule(const ScriptModule& module) |
|
dominicc (has gone to gerrit)
2017/01/11 03:23:47
Just curious but is it possible to use = default f
kouhei (in TOK)
2017/01/17 05:26:13
Done.
|
| + : m_module(module.m_module), m_identityHash(module.m_identityHash) {} |
| + ~ScriptModule(); |
| + |
| + bool instantiate(ScriptState*); |
| + void evaluate(ScriptState*); |
| + |
| + Vector<String> moduleRequests(ScriptState*); |
| + |
| + bool isNull() const { return !m_module || m_module->isEmpty(); } |
| + ScriptModuleIdentifier identifier(); |
| + |
| + private: |
| + friend class ScriptModuleIdentifier; |
| + ScriptModule(v8::Isolate*, v8::Local<v8::Module>); |
| + |
| + static v8::MaybeLocal<v8::Module> resolveModuleCallback( |
| + v8::Local<v8::Context>, |
| + v8::Local<v8::String> specifier, |
| + v8::Local<v8::Module> referrer); |
| + |
| + RefPtr<SharedPersistent<v8::Module>> m_module; |
| + unsigned m_identityHash = 0; |
| +}; |
| + |
| +// TODO(kouhei): Split header/cpp |
| +// TODO(kouhei): PeekType which can be construct w/ only v8::Local |
| +class ScriptModuleIdentifier { |
|
dominicc (has gone to gerrit)
2017/01/11 03:23:47
Is this class pulling its weight? If you don't add
kouhei (in TOK)
2017/01/17 05:26:12
Reason 1: One ScriptModule instance per v8::Module
|
| + public: |
| + class Hash; |
| + |
| + ScriptModuleIdentifier() = default; |
| + ScriptModuleIdentifier(const ScriptModuleIdentifier& id) |
| + : m_module(id.m_module), m_identityHash(id.m_identityHash) {} |
| + ScriptModuleIdentifier(WTF::HashTableDeletedValueType) |
| + : m_module(WTF::HashTableDeletedValue) {} |
| + /* |
| + FIXME(kouhei): need move op= |
| + ScriptModuleIdentifier(ScriptModuleIdentifier&& id) |
| + : m_module(std::move(id.m_module)), m_identityHash(id.m_identityHash) {} |
| + */ |
| + ~ScriptModuleIdentifier() = default; |
| + |
| + bool isHashTableDeletedValue() const { |
| + return m_module.isHashTableDeletedValue(); |
| + } |
| + |
| + bool operator==(const blink::ScriptModuleIdentifier& rhs) const { |
| + if (m_module.isHashTableDeletedValue() && |
|
dominicc (has gone to gerrit)
2017/01/11 03:23:47
Hmm, why not just implement so isSafeToCompareEmpt
kouhei (in TOK)
2017/01/17 05:26:13
Done.
|
| + rhs.m_module.isHashTableDeletedValue()) |
| + return true; |
| + |
| + blink::SharedPersistent<v8::Module>* lhsp = m_module.get(); |
| + blink::SharedPersistent<v8::Module>* rhsp = rhs.m_module.get(); |
| + if (lhsp == rhsp) |
| + return true; |
| + if (!lhsp || !rhsp) |
| + return false; |
| + return *lhsp == *rhsp; |
| + } |
| + |
| + private: |
| + friend class ScriptModule; |
| + friend struct ScriptModuleIdentifierHash; |
| + |
| + explicit ScriptModuleIdentifier( |
| + const RefPtr<SharedPersistent<v8::Module>>& module, |
| + unsigned identityHash) |
| + : m_module(module), m_identityHash(identityHash) {} |
| + |
| + // TODO(kouhei): Make ScriptModule move-only and make this ScopedPersistent. |
| + RefPtr<SharedPersistent<v8::Module>> m_module; |
| + unsigned m_identityHash = 0; |
| +}; |
| + |
| +struct ScriptModuleIdentifierHash { |
| + STATIC_ONLY(ScriptModuleIdentifierHash); |
| + |
| + public: |
| + static unsigned hash(const blink::ScriptModuleIdentifier& key) { |
| + return static_cast<unsigned>(key.m_identityHash); |
| + } |
| + |
| + static bool equal(const blink::ScriptModuleIdentifier& a, |
| + const blink::ScriptModuleIdentifier& b) { |
| + return a == b; |
| + } |
| + |
| + static const bool safeToCompareToEmptyOrDeleted = false; |
| +}; |
| + |
| +} // namespace blink |
| + |
| +namespace WTF { |
| + |
| +template <> |
| +struct DefaultHash<blink::ScriptModuleIdentifier> { |
| + using Hash = blink::ScriptModuleIdentifierHash; |
| +}; |
| + |
| +template <> |
| +struct HashTraits<blink::ScriptModuleIdentifier> |
| + : public SimpleClassHashTraits<blink::ScriptModuleIdentifier> {}; |
| + |
| +} // namespace WTF |
| + |
| +#endif // ScriptModule_h |