diff options
author | Tom Sepez <tsepez@chromium.org> | 2015-02-23 10:22:51 -0800 |
---|---|---|
committer | Tom Sepez <tsepez@chromium.org> | 2015-02-23 10:22:51 -0800 |
commit | 2311b784fe85a0a1d78f78f0f05586059a63fa65 (patch) | |
tree | eba15c615a60f5fd1d0e53c041ee20d8bbc8da59 /fpdfsdk/include/javascript/JS_Define.h | |
parent | e8cde186a6fd8c95c97dab664ff5cc196d238ab0 (diff) | |
download | pdfium-2311b784fe85a0a1d78f78f0f05586059a63fa65.tar.xz |
Merge to XFA: Replace second set of #defines with templates in JS_Define.h
Original Review URL: https://codereview.chromium.org/945623002
TBR=brucedawson@chromium.org
Review URL: https://codereview.chromium.org/948083002
Diffstat (limited to 'fpdfsdk/include/javascript/JS_Define.h')
-rw-r--r-- | fpdfsdk/include/javascript/JS_Define.h | 215 |
1 files changed, 94 insertions, 121 deletions
diff --git a/fpdfsdk/include/javascript/JS_Define.h b/fpdfsdk/include/javascript/JS_Define.h index 4c1cef8b90..72a481dfa4 100644 --- a/fpdfsdk/include/javascript/JS_Define.h +++ b/fpdfsdk/include/javascript/JS_Define.h @@ -42,9 +42,8 @@ typedef CFX_WideString JS_ErrorString; #define JS_TRUE (unsigned)1 #define JS_FALSE (unsigned)0 - -#define CJS_PointsArray CFX_ArrayTemplate<float> -#define CJS_IntArray CFX_ArrayTemplate<int> +typedef CFX_ArrayTemplate<float> CJS_PointsArray; +typedef CFX_ArrayTemplate<int> CJS_IntArray; /* ====================================== PUBLIC DEFINE SPEC ============================================== */ #define JS_WIDESTRING(widestring) L###widestring @@ -269,6 +268,84 @@ void js_class_name::GetConsts(JSConstSpec*& pConsts, int& nSize)\ /* ===================================== SPECIAL JS CLASS =============================================== */ +template <class Alt> +void JSSpecialPropQuery(const char *, v8::Local<v8::String> property,const v8::PropertyCallbackInfo<v8::Integer>& info) { + v8::Isolate* isolate = info.GetIsolate(); + v8::String::Utf8Value utf8_value(property); + CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length()); + CJS_Object* pJSObj = reinterpret_cast<CJS_Object*>(JS_GetPrivate(isolate, info.Holder())); + Alt* pObj = reinterpret_cast<Alt*>(pJSObj->GetEmbedObject()); + FX_BOOL bRet = pObj->QueryProperty(propname.c_str()); + info.GetReturnValue().Set(bRet ? 4 : 0); +} + +template <class Alt> +void JSSpecialPropGet(const char* class_name, + v8::Local<v8::String> property, + const v8::PropertyCallbackInfo<v8::Value>& info) { + v8::Isolate* isolate = info.GetIsolate(); + v8::Local<v8::Context> context = isolate->GetCurrentContext(); + IFXJS_Runtime* pRuntime = (IFXJS_Runtime*)isolate->GetData(2); + IFXJS_Context* pRuntimeContext = pRuntime->GetCurrentContext(); + CJS_Object* pJSObj = reinterpret_cast<CJS_Object*>(JS_GetPrivate(isolate, info.Holder())); + Alt* pObj = reinterpret_cast<Alt*>(pJSObj->GetEmbedObject()); + v8::String::Utf8Value utf8_value(property); + CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length()); + JS_ErrorString sError; + CJS_PropValue value(isolate); + value.StartGetting(); + if (!pObj->DoProperty(pRuntimeContext, propname.c_str(), value, sError)) { + CFX_ByteString cbName; + cbName.Format("%s.%s", class_name, L"GetProperty"); + JS_Error(NULL,CFX_WideString::FromLocal(cbName), sError); + return; + } + info.GetReturnValue().Set((v8::Handle<v8::Value>)value); +} + +template <class Alt> +void JSSpecialPropPut(const char* class_name, + v8::Local<v8::String> property, + v8::Local<v8::Value> value, + const v8::PropertyCallbackInfo<v8::Value>& info) { + v8::Isolate* isolate = info.GetIsolate(); + v8::Local<v8::Context> context = isolate->GetCurrentContext(); + IFXJS_Runtime* pRuntime = (IFXJS_Runtime*)isolate->GetData(2); + IFXJS_Context* pRuntimeContext = pRuntime->GetCurrentContext(); + CJS_Object* pJSObj = reinterpret_cast<CJS_Object*>(JS_GetPrivate(isolate, info.Holder())); + Alt* pObj = reinterpret_cast<Alt*>(pJSObj->GetEmbedObject()); + v8::String::Utf8Value utf8_value(property); + CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length()); + JS_ErrorString sError; + CJS_PropValue PropValue(CJS_Value(isolate,value,VT_unknown)); + PropValue.StartSetting(); + if (!pObj->DoProperty(pRuntimeContext, propname.c_str(), PropValue, sError)) { + CFX_ByteString cbName; + cbName.Format("%s.%s", class_name, "PutProperty"); + JS_Error(NULL,CFX_WideString::FromLocal(cbName), sError); + } +} + +template <class Alt> +void JSSpecialPropDel(const char* class_name, + v8::Local<v8::String> property, + const v8::PropertyCallbackInfo<v8::Boolean>& info) { + v8::Isolate* isolate = info.GetIsolate(); + v8::Local<v8::Context> context = isolate->GetCurrentContext(); + IFXJS_Runtime* pRuntime = (IFXJS_Runtime*)isolate->GetData(2); + IFXJS_Context* pRuntimeContext = pRuntime->GetCurrentContext(); + CJS_Object* pJSObj = reinterpret_cast<CJS_Object*>(JS_GetPrivate(isolate, info.Holder())); + Alt* pObj = reinterpret_cast<Alt*>(pJSObj->GetEmbedObject()); + v8::String::Utf8Value utf8_value(property); + CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length()); + JS_ErrorString sError; + if (!pObj->DelProperty(pRuntimeContext, propname.c_str(), sError)) { + CFX_ByteString cbName; + cbName.Format("%s.%s", class_name, "DelProperty"); + // Probably a missing call to JS_Error(). + } +} + #define DECLARE_SPECIAL_JS_CLASS(js_class_name) \ static JSBool JSConstructor(IFXJS_Context* cc, JSFXObject obj, JSFXObject global);\ static JSBool JSDestructor(JSFXObject obj);\ @@ -280,129 +357,25 @@ void js_class_name::GetConsts(JSConstSpec*& pConsts, int& nSize)\ static JSMethodSpec JS_Class_Methods[];\ static int Init(IJS_Runtime* pRuntime, FXJSOBJTYPE eObjType);\ static const wchar_t* m_pClassName;\ - static void queryprop_##js_class_name##_static(JS_PROPQUERY_ARGS);\ - static void getprop_##js_class_name##_static(JS_NAMED_PROPGET_ARGS);\ - static void putprop_##js_class_name##_static(JS_NAMED_PROPPUT_ARGS);\ - static void delprop_##js_class_name##_static(JS_PROPDEL_ARGS) + static void queryprop_##js_class_name##_static(v8::Local<v8::String> property,const v8::PropertyCallbackInfo<v8::Integer>& info);\ + static void getprop_##js_class_name##_static(v8::Local<v8::String> property, const v8::PropertyCallbackInfo<v8::Value>& info);\ + static void putprop_##js_class_name##_static(v8::Local<v8::String> property,v8::Local<v8::Value> value,const v8::PropertyCallbackInfo<v8::Value>& info);\ + static void delprop_##js_class_name##_static(v8::Local<v8::String> property,const v8::PropertyCallbackInfo<v8::Boolean>& info) #define IMPLEMENT_SPECIAL_JS_CLASS(js_class_name, class_alternate, class_name) \ const wchar_t * js_class_name::m_pClassName = JS_WIDESTRING(class_name);\ - void js_class_name::queryprop_##js_class_name##_static(JS_PROPQUERY_ARGS)\ -{\ - v8::Isolate* isolate = info.GetIsolate();\ - v8::String::Utf8Value utf8_value(property);\ - CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length());\ - CJS_Object* pJSObj = (CJS_Object*)JS_GetPrivate(isolate,info.Holder());\ - ASSERT(pJSObj != NULL);\ - class_alternate* pObj = (class_alternate*)pJSObj->GetEmbedObject();\ - ASSERT(pObj != NULL);\ - FX_BOOL bRet = FALSE;\ - bRet = pObj->QueryProperty(propname.c_str());\ - if (bRet)\ - {\ - info.GetReturnValue().Set(0x004);\ - return ;\ - }\ - else\ - {\ - info.GetReturnValue().Set(0);\ - return ;\ - }\ - return ;\ +void js_class_name::queryprop_##js_class_name##_static(v8::Local<v8::String> property,const v8::PropertyCallbackInfo<v8::Integer>& info) { \ + JSSpecialPropQuery<class_alternate>(#class_name, property, info); \ }\ - void js_class_name::getprop_##js_class_name##_static(JS_NAMED_PROPGET_ARGS)\ -{\ - v8::Isolate* isolate = info.GetIsolate();\ - v8::Local<v8::Context> context = isolate->GetCurrentContext();\ - IFXJS_Runtime* pRuntime = (IFXJS_Runtime*)isolate->GetData(2);\ - if (pRuntime == NULL) return;\ - IFXJS_Context* cc = pRuntime->GetCurrentContext();\ - v8::String::Utf8Value utf8_value(property);\ - CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length());\ - CJS_PropValue value(isolate);\ - value.StartGetting();\ - CJS_Object* pJSObj = (CJS_Object*)JS_GetPrivate(isolate,info.Holder());\ - ASSERT(pJSObj != NULL);\ - class_alternate* pObj = (class_alternate*)pJSObj->GetEmbedObject();\ - ASSERT(pObj != NULL);\ - JS_ErrorString sError;\ - FX_BOOL bRet = FALSE;\ - bRet = pObj->DoProperty(cc, propname.c_str(), value, sError);\ - if (bRet)\ - {\ - info.GetReturnValue().Set((v8::Handle<v8::Value>)value);\ - return ;\ - }\ - else\ - {\ - CFX_ByteString cbName;\ - cbName.Format("%s.%s", #class_name, L"GetProperty");\ - JS_Error(NULL,CFX_WideString::FromLocal(cbName), sError);\ - return ;\ - }\ - JS_Error(NULL,L"GetProperty", L"Embeded object not found!");\ - return ;\ -}\ - void js_class_name::putprop_##js_class_name##_static(JS_NAMED_PROPPUT_ARGS)\ -{\ - v8::Isolate* isolate = info.GetIsolate();\ - v8::Local<v8::Context> context = isolate->GetCurrentContext();\ - IFXJS_Runtime* pRuntime = (IFXJS_Runtime*)isolate->GetData(2);\ - if (pRuntime == NULL) return;\ - IFXJS_Context* cc = pRuntime->GetCurrentContext();\ - v8::String::Utf8Value utf8_value(property);\ - CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length());\ - CJS_PropValue PropValue(CJS_Value(isolate,value,VT_unknown));\ - PropValue.StartSetting();\ - CJS_Object* pJSObj = (CJS_Object*)JS_GetPrivate(isolate,info.Holder());\ - if(!pJSObj) return;\ - class_alternate* pObj = (class_alternate*)pJSObj->GetEmbedObject();\ - ASSERT(pObj != NULL);\ - JS_ErrorString sError;\ - FX_BOOL bRet = FALSE;\ - bRet = pObj->DoProperty(cc, propname.c_str(), PropValue, sError);\ - if (bRet)\ - {\ - return ;\ - }\ - else\ - {\ - CFX_ByteString cbName;\ - cbName.Format("%s.%s", #class_name, "PutProperty");\ - JS_Error(NULL,CFX_WideString::FromLocal(cbName), sError);\ - return ;\ - }\ - JS_Error(NULL,L"PutProperty", L"Embeded object not found!");\ - return ;\ -}\ - void js_class_name::delprop_##js_class_name##_static(JS_PROPDEL_ARGS)\ -{\ - v8::Isolate* isolate = info.GetIsolate();\ - v8::Local<v8::Context> context = isolate->GetCurrentContext();\ - IFXJS_Runtime* pRuntime = (IFXJS_Runtime*)isolate->GetData(2);\ - if (pRuntime == NULL) return;\ - IFXJS_Context* cc = pRuntime->GetCurrentContext();\ - v8::String::Utf8Value utf8_value(property);\ - CFX_WideString propname = CFX_WideString::FromUTF8(*utf8_value, utf8_value.length());\ - CJS_Object* pJSObj = (CJS_Object*)JS_GetPrivate(isolate,info.Holder());\ - ASSERT(pJSObj != NULL);\ - class_alternate* pObj = (class_alternate*)pJSObj->GetEmbedObject();\ - ASSERT(pObj != NULL);\ - JS_ErrorString sError;\ - FX_BOOL bRet = FALSE;\ - bRet = pObj->DelProperty(cc, propname.c_str(), sError);\ - if (bRet)\ - {\ - return ;\ - }\ - else\ - {\ - CFX_ByteString cbName;\ - cbName.Format("%s.%s", #class_name, "DelProperty");\ - return ;\ - }\ - return ;\ +void js_class_name::getprop_##js_class_name##_static(v8::Local<v8::String> property, const v8::PropertyCallbackInfo<v8::Value>& info) { \ + JSSpecialPropGet<class_alternate>(#class_name, property, info); \ +} \ +void js_class_name::putprop_##js_class_name##_static(v8::Local<v8::String> property,v8::Local<v8::Value> value,const v8::PropertyCallbackInfo<v8::Value>& info) {\ + JSSpecialPropPut<class_alternate>(#class_name, property, value, info); \ }\ +void js_class_name::delprop_##js_class_name##_static(v8::Local<v8::String> property,const v8::PropertyCallbackInfo<v8::Boolean>& info) { \ + JSSpecialPropDel<class_alternate>(#class_name, property, info); \ +} \ JSBool js_class_name::JSConstructor(IFXJS_Context* cc, JSFXObject obj,JSFXObject global)\ {\ CJS_Object* pObj = FX_NEW js_class_name(obj);\ |