Chromium Code Reviews| Index: fpdfsdk/src/javascript/Consts.cpp |
| diff --git a/fpdfsdk/src/javascript/Consts.cpp b/fpdfsdk/src/javascript/Consts.cpp |
| index 261f8257a811dc54aea1a39c8c0bf06b8d2347f9..c0c4b3553cbec603486b978aae8c678d8a6d4f1e 100644 |
| --- a/fpdfsdk/src/javascript/Consts.cpp |
| +++ b/fpdfsdk/src/javascript/Consts.cpp |
| @@ -11,8 +11,6 @@ |
| #include "fpdfsdk/src/javascript/JS_Object.h" |
| #include "fpdfsdk/src/javascript/JS_Value.h" |
| -/* ------------------------------ border ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_Border) |
| JS_STATIC_CONST_ENTRY_STRING(L"s", L"solid") |
| JS_STATIC_CONST_ENTRY_STRING(L"b", L"beveled") |
| @@ -20,22 +18,16 @@ JS_STATIC_CONST_ENTRY_STRING(L"d", L"dashed") |
| JS_STATIC_CONST_ENTRY_STRING(L"i", L"inset") |
| JS_STATIC_CONST_ENTRY_STRING(L"u", L"underline") |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_Border, border) |
| -/* ------------------------------ display ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_Display) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"visible", 0) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"hidden", 1) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"noPrint", 2) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"noView", 3) |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_Display, display) |
| -/* ------------------------------ font ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_Font) |
| JS_STATIC_CONST_ENTRY_STRING(L"Times", L"Times-Roman") |
| JS_STATIC_CONST_ENTRY_STRING(L"TimesB", L"Times-Bold") |
| @@ -52,22 +44,16 @@ JS_STATIC_CONST_ENTRY_STRING(L"CourBI", L"Courier-BoldOblique") |
| JS_STATIC_CONST_ENTRY_STRING(L"Symbol", L"Symbol") |
| JS_STATIC_CONST_ENTRY_STRING(L"ZapfD", L"ZapfDingbats") |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_Font, font) |
| -/* ------------------------------ highlight ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_Highlight) |
| JS_STATIC_CONST_ENTRY_STRING(L"n", L"none") |
| JS_STATIC_CONST_ENTRY_STRING(L"i", L"invert") |
| JS_STATIC_CONST_ENTRY_STRING(L"p", L"push") |
| JS_STATIC_CONST_ENTRY_STRING(L"o", L"outline") |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_Highlight, highlight) |
| -/* ------------------------------ position ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_Position) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"textOnly", 0) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"iconOnly", 1) |
| @@ -77,31 +63,22 @@ JS_STATIC_CONST_ENTRY_NUMBER(L"iconTextH", 4) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"textIconH", 5) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"overlay", 6) |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_Position, position) |
| -/* ------------------------------ scaleHow ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_ScaleHow) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"proportional", 0) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"anamorphic", 1) |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_ScaleHow, scaleHow) |
| -/* ------------------------------ scaleWhen ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_ScaleWhen) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"always", 0) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"never", 1) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"tooBig", 2) |
| JS_STATIC_CONST_ENTRY_NUMBER(L"tooSmall", 3) |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_ScaleWhen, scaleWhen) |
| -/* ------------------------------ style ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_Style) |
| JS_STATIC_CONST_ENTRY_STRING(L"ch", L"check") |
| JS_STATIC_CONST_ENTRY_STRING(L"cr", L"cross") |
| @@ -110,11 +87,8 @@ JS_STATIC_CONST_ENTRY_STRING(L"ci", L"circle") |
| JS_STATIC_CONST_ENTRY_STRING(L"st", L"star") |
| JS_STATIC_CONST_ENTRY_STRING(L"sq", L"square") |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_Style, style) |
| -/* ------------------------------ zoomtype ------------------------------ */ |
| - |
| BEGIN_JS_STATIC_CONST(CJS_Zoomtype) |
| JS_STATIC_CONST_ENTRY_STRING(L"none", L"NoVary") |
| JS_STATIC_CONST_ENTRY_STRING(L"fitP", L"FitPage") |
| @@ -124,172 +98,103 @@ JS_STATIC_CONST_ENTRY_STRING(L"fitV", L"FitVisibleWidth") |
| JS_STATIC_CONST_ENTRY_STRING(L"pref", L"Preferred") |
| JS_STATIC_CONST_ENTRY_STRING(L"refW", L"ReflowWidth") |
| END_JS_STATIC_CONST() |
| - |
| IMPLEMENT_JS_CLASS_CONST(CJS_Zoomtype, zoomtype) |
| -/* ------------------------------ CJS_GlobalConsts ------------------------- */ |
| - |
| -static void DefineGlobalConstString(CJS_Runtime* pRuntime, |
| - const wchar_t* pConstName, |
| - const wchar_t* pValue) { |
| - FXJS_DefineGlobalConst(pRuntime->GetIsolate(), pConstName, |
| - FXJS_NewString(pRuntime->GetIsolate(), pValue)); |
| -} |
| +#define GLOBAL_STRING(rt, name, value) \ |
|
Tom Sepez
2016/03/02 20:02:49
Note: there are JS tests that these values haven't
|
| + FXJS_DefineGlobalConst( \ |
| + (rt)->GetIsolate(), (name), \ |
| + [](const v8::FunctionCallbackInfo<v8::Value>& info) { \ |
| + info.GetReturnValue().Set(FXJS_NewString(info.GetIsolate(), (value))); \ |
| + }) |
| void CJS_GlobalConsts::DefineJSObjects(CJS_Runtime* pRuntime) { |
| - DefineGlobalConstString( |
| - pRuntime, L"IDS_GREATER_THAN", |
| - L"Invalid value: must be greater than or equal to % s."); |
| - DefineGlobalConstString( |
| - pRuntime, L"IDS_GT_AND_LT", |
| - L"Invalid value: must be greater than or equal to % s " |
| - L"and less than or equal to % s."); |
| - DefineGlobalConstString(pRuntime, L"IDS_LESS_THAN", |
| - L"Invalid value: must be less than or equal to % s."); |
| - DefineGlobalConstString(pRuntime, L"IDS_INVALID_MONTH", L"**Invalid**"); |
| - DefineGlobalConstString( |
| + GLOBAL_STRING(pRuntime, L"IDS_GREATER_THAN", |
| + L"Invalid value: must be greater than or equal to % s."); |
| + |
| + GLOBAL_STRING(pRuntime, L"IDS_GT_AND_LT", |
| + L"Invalid value: must be greater than or equal to % s " |
| + L"and less than or equal to % s."); |
| + |
| + GLOBAL_STRING(pRuntime, L"IDS_LESS_THAN", |
| + L"Invalid value: must be less than or equal to % s."); |
| + |
| + GLOBAL_STRING(pRuntime, L"IDS_INVALID_MONTH", L"**Invalid**"); |
| + GLOBAL_STRING( |
| pRuntime, L"IDS_INVALID_DATE", |
| L"Invalid date / time: please ensure that the date / time exists.Field"); |
| - DefineGlobalConstString( |
| - pRuntime, L"IDS_INVALID_VALUE", |
| - L"The value entered does not match the format of the field"); |
| - DefineGlobalConstString(pRuntime, L"IDS_AM", L"am"); |
| - DefineGlobalConstString(pRuntime, L"IDS_PM", L"pm"); |
| - DefineGlobalConstString( |
| - pRuntime, L"IDS_MONTH_INFO", |
| - L"January[1] February[2] March[3] April[4] May[5] " |
| - L"June[6] July[7] August[8] September[9] October[10] " |
| - L"November[11] December[12] Sept[9] Jan[1] Feb[2] Mar[3] " |
| - L"Apr[4] Jun[6] Jul[7] Aug[8] Sep[9] Oct[10] Nov[11] " |
| - L"Dec[12]"); |
| - DefineGlobalConstString(pRuntime, L"IDS_STARTUP_CONSOLE_MSG", L"** ^ _ ^ **"); |
| -} |
| -/* ------------------------------ CJS_GlobalArrays ------------------------ */ |
| - |
| -void DefineGlobalConstStringArray(CJS_Runtime* pRuntime, |
| - const wchar_t* sConstName, |
| - const wchar_t** pValues, |
| - size_t nValues) { |
| - CJS_Array array(pRuntime); |
| - for (size_t i = 0; i < nValues; ++i) { |
| - array.SetElement(i, CJS_Value(pRuntime, pValues[i])); |
| - } |
| - CJS_PropValue prop(pRuntime); |
| - prop << array; |
| - FXJS_DefineGlobalConst(pRuntime->GetIsolate(), sConstName, prop.ToV8Value()); |
| + GLOBAL_STRING(pRuntime, L"IDS_INVALID_VALUE", |
| + L"The value entered does not match the format of the field"); |
| + |
| + GLOBAL_STRING(pRuntime, L"IDS_AM", L"am"); |
| + GLOBAL_STRING(pRuntime, L"IDS_PM", L"pm"); |
| + GLOBAL_STRING(pRuntime, L"IDS_MONTH_INFO", |
| + L"January[1] February[2] March[3] April[4] May[5] " |
| + L"June[6] July[7] August[8] September[9] October[10] " |
| + L"November[11] December[12] Sept[9] Jan[1] Feb[2] Mar[3] " |
| + L"Apr[4] Jun[6] Jul[7] Aug[8] Sep[9] Oct[10] Nov[11] " |
| + L"Dec[12]"); |
| + |
| + GLOBAL_STRING(pRuntime, L"IDS_STARTUP_CONSOLE_MSG", L"** ^ _ ^ **"); |
| } |
| +#define GLOBAL_ARRAY(rt, name, ...) \ |
| + FXJS_DefineGlobalConst( \ |
| + (rt)->GetIsolate(), (name), \ |
| + [](const v8::FunctionCallbackInfo<v8::Value>& info) { \ |
| + const FX_WCHAR* values[] = {__VA_ARGS__}; \ |
| + auto array = FXJS_NewArray(info.GetIsolate()); \ |
| + for (size_t i = 0; i < FX_ArraySize(values); ++i) \ |
| + array->Set(i, FXJS_NewString(info.GetIsolate(), values[i])); \ |
| + info.GetReturnValue().Set(array); \ |
| + }) |
| + |
| void CJS_GlobalArrays::DefineJSObjects(CJS_Runtime* pRuntime) { |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_NUMBER_ENTRY_DOT_SEP"; |
| - const FX_WCHAR* ArrayContent[] = {L"[+-]?\\d*\\.?\\d*"}; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_NUMBER_COMMIT_DOT_SEP"; |
| - const FX_WCHAR* ArrayContent[] = { |
| - L"[+-]?\\d+(\\.\\d+)?", /* -1.0 or -1 */ |
| - L"[+-]?\\.\\d+", /* -.1 */ |
| - L"[+-]?\\d+\\." /* -1. */ |
| - }; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_NUMBER_ENTRY_COMMA_SEP"; |
| - const FX_WCHAR* ArrayContent[] = {L"[+-]?\\d*,?\\d*"}; |
| - |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_NUMBER_COMMIT_COMMA_SEP"; |
| - const FX_WCHAR* ArrayContent[] = { |
| - L"[+-]?\\d+([.,]\\d+)?", /* -1,0 or -1 */ |
| - L"[+-]?[.,]\\d+", /* -,1 */ |
| - L"[+-]?\\d+[.,]" /* -1, */ |
| - }; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_ZIP_ENTRY"; |
| - const FX_WCHAR* ArrayContent[] = {L"\\d{0,5}"}; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_ZIP_COMMIT"; |
| - const FX_WCHAR* ArrayContent[] = {L"\\d{5}"}; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_ZIP4_ENTRY"; |
| - const FX_WCHAR* ArrayContent[] = {L"\\d{0,5}(\\.|[- ])?\\d{0,4}"}; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_ZIP4_COMMIT"; |
| - const FX_WCHAR* ArrayContent[] = {L"\\d{5}(\\.|[- ])?\\d{4}"}; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_PHONE_ENTRY"; |
| - const FX_WCHAR* ArrayContent[] = { |
| - L"\\d{0,3}(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", /* 555-1234 or 408 |
| - 555-1234 */ |
| - L"\\(\\d{0,3}", /* (408 */ |
| - L"\\(\\d{0,3}\\)(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", /* (408) |
| - 555-1234 */ |
| - /* (allow the addition of parens as an afterthought) */ |
| - L"\\(\\d{0,3}(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", /* (408 555-1234 |
| - */ |
| - L"\\d{0,3}\\)(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", /* 408) 555-1234 |
| - */ |
| - L"011(\\.|[- \\d])*" /* international */ |
| - }; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_PHONE_COMMIT"; |
| - const FX_WCHAR* ArrayContent[] = { |
| - L"\\d{3}(\\.|[- ])?\\d{4}", /* 555-1234 */ |
| - L"\\d{3}(\\.|[- ])?\\d{3}(\\.|[- ])?\\d{4}", /* 408 555-1234 */ |
| - L"\\(\\d{3}\\)(\\.|[- ])?\\d{3}(\\.|[- ])?\\d{4}", /* (408) 555-1234 */ |
| - L"011(\\.|[- \\d])*" /* international */ |
| - }; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_SSN_ENTRY"; |
| - const FX_WCHAR* ArrayContent[] = { |
| - L"\\d{0,3}(\\.|[- ])?\\d{0,2}(\\.|[- ])?\\d{0,4}"}; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| - |
| - { |
| - const FX_WCHAR* ArrayName = L"RE_SSN_COMMIT"; |
| - const FX_WCHAR* ArrayContent[] = { |
| - L"\\d{3}(\\.|[- ])?\\d{2}(\\.|[- ])?\\d{4}"}; |
| - DefineGlobalConstStringArray(pRuntime, ArrayName, ArrayContent, |
| - FX_ArraySize(ArrayContent)); |
| - } |
| + GLOBAL_ARRAY(pRuntime, L"RE_NUMBER_ENTRY_DOT_SEP", L"[+-]?\\d*\\.?\\d*"); |
| + GLOBAL_ARRAY(pRuntime, L"RE_NUMBER_COMMIT_DOT_SEP", |
| + L"[+-]?\\d+(\\.\\d+)?", // -1.0 or -1 |
| + L"[+-]?\\.\\d+", // -.1 |
| + L"[+-]?\\d+\\."); // -1. |
| + |
| + GLOBAL_ARRAY(pRuntime, L"RE_NUMBER_ENTRY_COMMA_SEP", L"[+-]?\\d*,?\\d*"); |
| + GLOBAL_ARRAY(pRuntime, L"RE_NUMBER_COMMIT_COMMA_SEP", |
| + L"[+-]?\\d+([.,]\\d+)?", // -1,0 or -1 |
| + L"[+-]?[.,]\\d+", // -,1 |
| + L"[+-]?\\d+[.,]"); // -1, |
| + |
| + GLOBAL_ARRAY(pRuntime, L"RE_ZIP_ENTRY", L"\\d{0,5}"); |
| + GLOBAL_ARRAY(pRuntime, L"RE_ZIP_COMMIT", L"\\d{5}"); |
| + GLOBAL_ARRAY(pRuntime, L"RE_ZIP4_ENTRY", L"\\d{0,5}(\\.|[- ])?\\d{0,4}"); |
| + GLOBAL_ARRAY(pRuntime, L"RE_ZIP4_COMMIT", L"\\d{5}(\\.|[- ])?\\d{4}"); |
| + GLOBAL_ARRAY(pRuntime, L"RE_PHONE_ENTRY", |
| + // 555-1234 or 408 555-1234 |
| + L"\\d{0,3}(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", |
| + |
| + // (408 |
| + L"\\(\\d{0,3}", |
| + |
| + // (408) 555-1234 |
| + // (allow the addition of parens as an afterthought) |
| + L"\\(\\d{0,3}\\)(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", |
| + |
| + // (408 555-1234 |
| + L"\\(\\d{0,3}(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", |
| + |
| + // 408) 555-1234 |
| + L"\\d{0,3}\\)(\\.|[- ])?\\d{0,3}(\\.|[- ])?\\d{0,4}", |
| + |
| + // international |
| + L"011(\\.|[- \\d])*"); |
| + |
| + GLOBAL_ARRAY( |
| + pRuntime, L"RE_PHONE_COMMIT", L"\\d{3}(\\.|[- ])?\\d{4}", // 555-1234 |
| + L"\\d{3}(\\.|[- ])?\\d{3}(\\.|[- ])?\\d{4}", // 408 555-1234 |
| + L"\\(\\d{3}\\)(\\.|[- ])?\\d{3}(\\.|[- ])?\\d{4}", // (408) 555-1234 |
| + L"011(\\.|[- \\d])*"); // international |
| + |
| + GLOBAL_ARRAY(pRuntime, L"RE_SSN_ENTRY", |
| + L"\\d{0,3}(\\.|[- ])?\\d{0,2}(\\.|[- ])?\\d{0,4}"); |
| + |
| + GLOBAL_ARRAY(pRuntime, L"RE_SSN_COMMIT", |
| + L"\\d{3}(\\.|[- ])?\\d{2}(\\.|[- ])?\\d{4}"); |
| } |