efl/src/bindings/js/ecore_js/ecore_js_poller.cc

187 lines
5.7 KiB
C++

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <Ecore_Js.hh>
namespace efl { namespace ecore { namespace js {
namespace {
Ecore_Poller* extract_poller(v8::Local<v8::Object> object)
{
auto ptr = v8::External::Cast(*object->GetInternalField(0))->Value();
return reinterpret_cast<Ecore_Poller*>(ptr);
}
v8::Local<v8::Object> wrap_poller(Ecore_Poller *poller,
v8::Isolate *isolate)
{
using v8::Boolean;
using v8::String;
using v8::ObjectTemplate;
using v8::FunctionTemplate;
auto obj_tpl = compatibility_new<ObjectTemplate>(isolate);
obj_tpl->SetInternalFieldCount(1);
auto ret = obj_tpl->NewInstance();
auto del = [](compatibility_callback_info_type info)
-> compatibility_return_type {
if (info.Length() != 0)
return compatibility_return();
ecore_poller_del(extract_poller(info.This()));
return compatibility_return();
};
ret->Set(compatibility_new<String>(isolate, "del"),
compatibility_new<FunctionTemplate>(isolate, del)->GetFunction());
ret->SetInternalField(0, compatibility_new<v8::External>(isolate, poller));
return ret;
}
void register_poller_core(v8::Isolate *isolate, v8::Handle<v8::Object> global,
v8::Handle<v8::String> name)
{
using v8::Integer;
global->Set(name, compatibility_new<Integer>(isolate, ECORE_POLLER_CORE));
}
void register_poller_poll_interval_set(v8::Isolate *isolate,
v8::Handle<v8::Object> global,
v8::Handle<v8::String> name)
{
using v8::Integer;
using v8::FunctionTemplate;
auto f = [](compatibility_callback_info_type args)
-> compatibility_return_type {
if (args.Length() != 2 || !args[0]->IsNumber() || !args[1]->IsNumber())
return compatibility_return();
Ecore_Poller_Type type;
switch ((int)(args[0]->NumberValue())) {
case ECORE_POLLER_CORE:
type = ECORE_POLLER_CORE;
break;
default:
return compatibility_return();
}
ecore_poller_poll_interval_set(type, args[1]->NumberValue());
return compatibility_return();
};
global->Set(name,
compatibility_new<FunctionTemplate>(isolate, f)->GetFunction());
}
void register_poller_poll_interval_get(v8::Isolate *isolate,
v8::Handle<v8::Object> global,
v8::Handle<v8::String> name)
{
using v8::Integer;
using v8::FunctionTemplate;
auto f = [](compatibility_callback_info_type args)
-> compatibility_return_type {
if (args.Length() != 1 || !args[0]->IsNumber())
return compatibility_return();
Ecore_Poller_Type type;
switch ((int)(args[0]->NumberValue())) {
case ECORE_POLLER_CORE:
type = ECORE_POLLER_CORE;
break;
default:
return compatibility_return();
}
auto isolate = args.GetIsolate();
auto ret = ecore_poller_poll_interval_get(type);
return compatibility_return(compatibility_new<Integer>(isolate, ret),
args);
};
global->Set(name,
compatibility_new<FunctionTemplate>(isolate, f)->GetFunction());
}
void register_poller_add(v8::Isolate *isolate, v8::Handle<v8::Object> global,
v8::Handle<v8::String> name)
{
using v8::Integer;
using v8::Value;
using v8::FunctionTemplate;
using v8::Isolate;
using v8::Function;
auto f = [](compatibility_callback_info_type args)
-> compatibility_return_type {
if (args.Length() != 3 || !args[0]->IsNumber() || !args[1]->IsNumber()
|| !args[2]->IsFunction()) {
return compatibility_return();
}
Ecore_Poller_Type type;
switch ((int)(args[0]->NumberValue())) {
case ECORE_POLLER_CORE:
type = ECORE_POLLER_CORE;
break;
default:
return compatibility_return();
}
auto isolate = args.GetIsolate();
auto f = new efl::eina::js::global_ref<Value>(isolate, args[2]);
auto cb = [](void *data) -> Eina_Bool {
auto persistent = static_cast<efl::eina::js::global_ref<Value>*>(data);
auto o = persistent->handle();
auto ret = Function::Cast(*o)->Call(o->ToObject(), 0, NULL);
auto bret = ret->IsBoolean() && ret->BooleanValue();
if (!bret)
{
persistent->dispose();
delete persistent;
}
return bret ? EINA_TRUE : EINA_FALSE;
};
auto ret = ecore_poller_add(type, args[1]->NumberValue(), cb, f);
return compatibility_return(wrap_poller(ret, isolate), args);
};
global->Set(name,
compatibility_new<FunctionTemplate>(isolate, f)->GetFunction());
}
}
EAPI
void register_ecore_poller(v8::Isolate *isolate,v8::Handle<v8::Object> exports)
{
register_poller_core(isolate, exports,
compatibility_new<v8::String>(isolate, "CORE"));
register_poller_poll_interval_set(isolate, exports,
compatibility_new<v8::String>(isolate,
"setPollInterval"));
register_poller_poll_interval_get(isolate, exports,
compatibility_new<v8::String>(isolate,
"getPollInterval"));
register_poller_add(isolate, exports,
compatibility_new<v8::String>(isolate, "add"));
}
} } } // namespace efl { namespace js {