chore: remove native_mate (Part 7) (#20561)
* refactor: use gin converters in api::Protocol * refactor: convert JS constructor impl to gin * refactor: use InitWithArgs helper * fix: gin_helper::Dictionary should behave the same with mate * fix cpplint warnings * refactor: no more need to patch gin/dictionary.h
This commit is contained in:
parent
6c6bff81ac
commit
1ecfcc8c70
43 changed files with 274 additions and 368 deletions
|
@ -10,6 +10,7 @@ source_set("native_mate") {
|
|||
"//v8:v8_headers",
|
||||
]
|
||||
public_configs = [ ":native_mate_config" ]
|
||||
include_dirs = [ ".." ]
|
||||
sources = [
|
||||
"native_mate/arguments.cc",
|
||||
"native_mate/arguments.h",
|
||||
|
|
|
@ -11,6 +11,7 @@
|
|||
|
||||
#include "base/bind.h"
|
||||
#include "native_mate/function_template.h"
|
||||
#include "shell/common/gin_helper/function_template.h"
|
||||
|
||||
namespace mate {
|
||||
|
||||
|
@ -30,7 +31,8 @@ inline WrappableBase* InvokeFactory(
|
|||
Arguments* args,
|
||||
const base::Callback<WrappableBase*(P1)>& callback) {
|
||||
typename CallbackParamTraits<P1>::LocalType a1;
|
||||
if (!GetNextArgument(args, 0, true, &a1))
|
||||
gin::Arguments gin_args(args->info());
|
||||
if (!gin_helper::GetNextArgument(&gin_args, 0, true, &a1))
|
||||
return nullptr;
|
||||
return callback.Run(a1);
|
||||
}
|
||||
|
@ -41,8 +43,9 @@ inline WrappableBase* InvokeFactory(
|
|||
const base::Callback<WrappableBase*(P1, P2)>& callback) {
|
||||
typename CallbackParamTraits<P1>::LocalType a1;
|
||||
typename CallbackParamTraits<P2>::LocalType a2;
|
||||
if (!GetNextArgument(args, 0, true, &a1) ||
|
||||
!GetNextArgument(args, 0, false, &a2))
|
||||
gin::Arguments gin_args(args->info());
|
||||
if (!gin_helper::GetNextArgument(&gin_args, 0, true, &a1) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a2))
|
||||
return nullptr;
|
||||
return callback.Run(a1, a2);
|
||||
}
|
||||
|
@ -54,9 +57,10 @@ inline WrappableBase* InvokeFactory(
|
|||
typename CallbackParamTraits<P1>::LocalType a1;
|
||||
typename CallbackParamTraits<P2>::LocalType a2;
|
||||
typename CallbackParamTraits<P3>::LocalType a3;
|
||||
if (!GetNextArgument(args, 0, true, &a1) ||
|
||||
!GetNextArgument(args, 0, false, &a2) ||
|
||||
!GetNextArgument(args, 0, false, &a3))
|
||||
gin::Arguments gin_args(args->info());
|
||||
if (!gin_helper::GetNextArgument(&gin_args, 0, true, &a1) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a2) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a3))
|
||||
return nullptr;
|
||||
return callback.Run(a1, a2, a3);
|
||||
}
|
||||
|
@ -69,10 +73,11 @@ inline WrappableBase* InvokeFactory(
|
|||
typename CallbackParamTraits<P2>::LocalType a2;
|
||||
typename CallbackParamTraits<P3>::LocalType a3;
|
||||
typename CallbackParamTraits<P4>::LocalType a4;
|
||||
if (!GetNextArgument(args, 0, true, &a1) ||
|
||||
!GetNextArgument(args, 0, false, &a2) ||
|
||||
!GetNextArgument(args, 0, false, &a3) ||
|
||||
!GetNextArgument(args, 0, false, &a4))
|
||||
gin::Arguments gin_args(args->info());
|
||||
if (!gin_helper::GetNextArgument(&gin_args, 0, true, &a1) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a2) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a3) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a4))
|
||||
return nullptr;
|
||||
return callback.Run(a1, a2, a3, a4);
|
||||
}
|
||||
|
@ -86,11 +91,12 @@ inline WrappableBase* InvokeFactory(
|
|||
typename CallbackParamTraits<P3>::LocalType a3;
|
||||
typename CallbackParamTraits<P4>::LocalType a4;
|
||||
typename CallbackParamTraits<P5>::LocalType a5;
|
||||
if (!GetNextArgument(args, 0, true, &a1) ||
|
||||
!GetNextArgument(args, 0, false, &a2) ||
|
||||
!GetNextArgument(args, 0, false, &a3) ||
|
||||
!GetNextArgument(args, 0, false, &a4) ||
|
||||
!GetNextArgument(args, 0, false, &a5))
|
||||
gin::Arguments gin_args(args->info());
|
||||
if (!gin_helper::GetNextArgument(&gin_args, 0, true, &a1) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a2) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a3) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a4) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a5))
|
||||
return nullptr;
|
||||
return callback.Run(a1, a2, a3, a4, a5);
|
||||
}
|
||||
|
@ -110,12 +116,13 @@ inline WrappableBase* InvokeFactory(
|
|||
typename CallbackParamTraits<P4>::LocalType a4;
|
||||
typename CallbackParamTraits<P5>::LocalType a5;
|
||||
typename CallbackParamTraits<P6>::LocalType a6;
|
||||
if (!GetNextArgument(args, 0, true, &a1) ||
|
||||
!GetNextArgument(args, 0, false, &a2) ||
|
||||
!GetNextArgument(args, 0, false, &a3) ||
|
||||
!GetNextArgument(args, 0, false, &a4) ||
|
||||
!GetNextArgument(args, 0, false, &a5) ||
|
||||
!GetNextArgument(args, 0, false, &a6))
|
||||
gin::Arguments gin_args(args->info());
|
||||
if (!gin_helper::GetNextArgument(&gin_args, 0, true, &a1) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a2) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a3) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a4) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a5) ||
|
||||
!gin_helper::GetNextArgument(&gin_args, 0, false, &a6))
|
||||
return nullptr;
|
||||
return callback.Run(a1, a2, a3, a4, a5, a6);
|
||||
}
|
||||
|
|
|
@ -115,4 +115,22 @@ struct Converter<Dictionary> {
|
|||
|
||||
} // namespace mate
|
||||
|
||||
namespace gin {
|
||||
|
||||
// Keep compatibility with gin.
|
||||
template <>
|
||||
struct Converter<mate::Dictionary> {
|
||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||
const mate::Dictionary& in) {
|
||||
return mate::ConvertToV8(isolate, in);
|
||||
}
|
||||
static bool FromV8(v8::Isolate* isolate,
|
||||
v8::Local<v8::Value> val,
|
||||
mate::Dictionary* out) {
|
||||
return mate::ConvertFromV8(isolate, val, out);
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace gin
|
||||
|
||||
#endif // NATIVE_MATE_NATIVE_MATE_DICTIONARY_H_
|
||||
|
|
|
@ -5,11 +5,11 @@
|
|||
#ifndef NATIVE_MATE_NATIVE_MATE_FUNCTION_TEMPLATE_H_
|
||||
#define NATIVE_MATE_NATIVE_MATE_FUNCTION_TEMPLATE_H_
|
||||
|
||||
#include "../shell/common/gin_helper/destroyable.h"
|
||||
#include "../shell/common/gin_helper/error_thrower.h"
|
||||
#include "base/callback.h"
|
||||
#include "native_mate/arguments.h"
|
||||
#include "native_mate/wrappable_base.h"
|
||||
#include "shell/common/gin_helper/destroyable.h"
|
||||
#include "shell/common/gin_helper/error_thrower.h"
|
||||
|
||||
// =============================== NOTICE ===============================
|
||||
// Do not add code here, native_mate is being removed. Any new code
|
||||
|
|
|
@ -69,4 +69,22 @@ mate::Handle<T> CreateHandle(v8::Isolate* isolate, T* object) {
|
|||
|
||||
} // namespace mate
|
||||
|
||||
namespace gin {
|
||||
|
||||
// Keep compatibility with gin.
|
||||
template <typename T>
|
||||
struct Converter<mate::Handle<T>> {
|
||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||
const mate::Handle<T>& in) {
|
||||
return mate::ConvertToV8(isolate, in);
|
||||
}
|
||||
static bool FromV8(v8::Isolate* isolate,
|
||||
v8::Local<v8::Value> val,
|
||||
mate::Handle<T>* out) {
|
||||
return mate::ConvertFromV8(isolate, val, out);
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace gin
|
||||
|
||||
#endif // NATIVE_MATE_NATIVE_MATE_HANDLE_H_
|
||||
|
|
|
@ -5,6 +5,7 @@
|
|||
#include "native_mate/wrappable.h"
|
||||
|
||||
#include "base/logging.h"
|
||||
#include "gin/arguments.h"
|
||||
#include "native_mate/dictionary.h"
|
||||
#include "native_mate/object_template_builder_deprecated.h"
|
||||
|
||||
|
@ -37,6 +38,12 @@ v8::MaybeLocal<v8::Object> WrappableBase::GetWrapper(
|
|||
return v8::MaybeLocal<v8::Object>();
|
||||
}
|
||||
|
||||
void WrappableBase::InitWithArgs(gin::Arguments* args) {
|
||||
v8::Local<v8::Object> holder;
|
||||
args->GetHolder(&holder);
|
||||
InitWith(args->isolate(), holder);
|
||||
}
|
||||
|
||||
void WrappableBase::InitWith(v8::Isolate* isolate,
|
||||
v8::Local<v8::Object> wrapper) {
|
||||
CHECK(wrapper_.IsEmpty());
|
||||
|
|
|
@ -97,4 +97,28 @@ struct Converter<T*,
|
|||
|
||||
} // namespace mate
|
||||
|
||||
namespace gin {
|
||||
|
||||
// Provides compatibility for gin.
|
||||
template <typename T>
|
||||
struct Converter<
|
||||
T*,
|
||||
typename std::enable_if<
|
||||
std::is_convertible<T*, mate::WrappableBase*>::value>::type> {
|
||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate, T* val) {
|
||||
if (val)
|
||||
return val->GetWrapper();
|
||||
else
|
||||
return v8::Null(isolate);
|
||||
}
|
||||
|
||||
static bool FromV8(v8::Isolate* isolate, v8::Local<v8::Value> val, T** out) {
|
||||
*out = static_cast<T*>(static_cast<mate::WrappableBase*>(
|
||||
mate::internal::FromV8Impl(isolate, val)));
|
||||
return *out != nullptr;
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace gin
|
||||
|
||||
#endif // NATIVE_MATE_NATIVE_MATE_WRAPPABLE_H_
|
||||
|
|
|
@ -6,8 +6,9 @@
|
|||
#define NATIVE_MATE_NATIVE_MATE_WRAPPABLE_BASE_H_
|
||||
|
||||
namespace gin {
|
||||
class Arguments;
|
||||
struct Destroyable;
|
||||
}
|
||||
} // namespace gin
|
||||
|
||||
namespace mate {
|
||||
|
||||
|
@ -47,6 +48,9 @@ class WrappableBase {
|
|||
// This method should only be called by classes using Constructor.
|
||||
virtual void InitWith(v8::Isolate* isolate, v8::Local<v8::Object> wrapper);
|
||||
|
||||
// Helper to migrate from native_mate to gin.
|
||||
void InitWithArgs(gin::Arguments* args);
|
||||
|
||||
private:
|
||||
friend struct gin::Destroyable;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue