123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892 |
- /*********************************************************************
- * NAN - Native Abstractions for Node.js
- *
- * Copyright (c) 2018 NAN contributors:
- * - Rod Vagg <https://github.com/rvagg>
- * - Benjamin Byholm <https://github.com/kkoopa>
- * - Trevor Norris <https://github.com/trevnorris>
- * - Nathan Rajlich <https://github.com/TooTallNate>
- * - Brett Lawson <https://github.com/brett19>
- * - Ben Noordhuis <https://github.com/bnoordhuis>
- * - David Siegel <https://github.com/agnat>
- * - Michael Ira Krufky <https://github.com/mkrufky>
- *
- * MIT License <https://github.com/nodejs/nan/blob/master/LICENSE.md>
- *
- * Version 2.14.0: current Node 12.2.0, Node 12: 0.12.18, Node 10: 0.10.48, iojs: 3.3.1
- *
- * See https://github.com/nodejs/nan for the latest update to this file
- **********************************************************************************/
-
- #ifndef NAN_H_
- #define NAN_H_
-
- #include <node_version.h>
-
- #define NODE_0_10_MODULE_VERSION 11
- #define NODE_0_12_MODULE_VERSION 14
- #define ATOM_0_21_MODULE_VERSION 41
- #define IOJS_1_0_MODULE_VERSION 42
- #define IOJS_1_1_MODULE_VERSION 43
- #define IOJS_2_0_MODULE_VERSION 44
- #define IOJS_3_0_MODULE_VERSION 45
- #define NODE_4_0_MODULE_VERSION 46
- #define NODE_5_0_MODULE_VERSION 47
- #define NODE_6_0_MODULE_VERSION 48
- #define NODE_7_0_MODULE_VERSION 51
- #define NODE_8_0_MODULE_VERSION 57
- #define NODE_9_0_MODULE_VERSION 59
- #define NODE_10_0_MODULE_VERSION 64
- #define NODE_11_0_MODULE_VERSION 67
- #define NODE_12_0_MODULE_VERSION 72
-
- #ifdef _MSC_VER
- # define NAN_HAS_CPLUSPLUS_11 (_MSC_VER >= 1800)
- #else
- # define NAN_HAS_CPLUSPLUS_11 (__cplusplus >= 201103L)
- #endif
-
- #if NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION && !NAN_HAS_CPLUSPLUS_11
- # error This version of node/NAN/v8 requires a C++11 compiler
- #endif
-
- #include <uv.h>
- #include <node.h>
- #include <node_buffer.h>
- #include <node_object_wrap.h>
- #include <algorithm>
- #include <cstring>
- #include <climits>
- #include <cstdlib>
- #include <utility>
- #if defined(_MSC_VER)
- # pragma warning( push )
- # pragma warning( disable : 4530 )
- # include <queue>
- # include <string>
- # include <vector>
- # pragma warning( pop )
- #else
- # include <queue>
- # include <string>
- # include <vector>
- #endif
-
- // uv helpers
- #ifdef UV_VERSION_MAJOR
- # ifndef UV_VERSION_PATCH
- # define UV_VERSION_PATCH 0
- # endif
- # define NAUV_UVVERSION ((UV_VERSION_MAJOR << 16) | \
- (UV_VERSION_MINOR << 8) | \
- (UV_VERSION_PATCH))
- #else
- # define NAUV_UVVERSION 0x000b00
- #endif
-
- #if NAUV_UVVERSION < 0x000b0b
- # ifdef WIN32
- # include <windows.h>
- # else
- # include <pthread.h>
- # endif
- #endif
-
- namespace Nan {
-
- #define NAN_CONCAT(a, b) NAN_CONCAT_HELPER(a, b)
- #define NAN_CONCAT_HELPER(a, b) a##b
-
- #define NAN_INLINE inline // TODO(bnoordhuis) Remove in v3.0.0.
-
- #if defined(__GNUC__) && \
- !(defined(V8_DISABLE_DEPRECATIONS) && V8_DISABLE_DEPRECATIONS)
- # define NAN_DEPRECATED __attribute__((deprecated))
- #elif defined(_MSC_VER) && \
- !(defined(V8_DISABLE_DEPRECATIONS) && V8_DISABLE_DEPRECATIONS)
- # define NAN_DEPRECATED __declspec(deprecated)
- #else
- # define NAN_DEPRECATED
- #endif
-
- #if NAN_HAS_CPLUSPLUS_11
- # define NAN_DISALLOW_ASSIGN(CLASS) void operator=(const CLASS&) = delete;
- # define NAN_DISALLOW_COPY(CLASS) CLASS(const CLASS&) = delete;
- # define NAN_DISALLOW_MOVE(CLASS) \
- CLASS(CLASS&&) = delete; /* NOLINT(build/c++11) */ \
- void operator=(CLASS&&) = delete;
- #else
- # define NAN_DISALLOW_ASSIGN(CLASS) void operator=(const CLASS&);
- # define NAN_DISALLOW_COPY(CLASS) CLASS(const CLASS&);
- # define NAN_DISALLOW_MOVE(CLASS)
- #endif
-
- #define NAN_DISALLOW_ASSIGN_COPY(CLASS) \
- NAN_DISALLOW_ASSIGN(CLASS) \
- NAN_DISALLOW_COPY(CLASS)
-
- #define NAN_DISALLOW_ASSIGN_MOVE(CLASS) \
- NAN_DISALLOW_ASSIGN(CLASS) \
- NAN_DISALLOW_MOVE(CLASS)
-
- #define NAN_DISALLOW_COPY_MOVE(CLASS) \
- NAN_DISALLOW_COPY(CLASS) \
- NAN_DISALLOW_MOVE(CLASS)
-
- #define NAN_DISALLOW_ASSIGN_COPY_MOVE(CLASS) \
- NAN_DISALLOW_ASSIGN(CLASS) \
- NAN_DISALLOW_COPY(CLASS) \
- NAN_DISALLOW_MOVE(CLASS)
-
- #define TYPE_CHECK(T, S) \
- while (false) { \
- *(static_cast<T *volatile *>(0)) = static_cast<S*>(0); \
- }
-
- //=== RegistrationFunction =====================================================
-
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- typedef v8::Handle<v8::Object> ADDON_REGISTER_FUNCTION_ARGS_TYPE;
- #else
- typedef v8::Local<v8::Object> ADDON_REGISTER_FUNCTION_ARGS_TYPE;
- #endif
-
- #define NAN_MODULE_INIT(name) \
- void name(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE target)
-
- #if NODE_MAJOR_VERSION >= 10 || \
- NODE_MAJOR_VERSION == 9 && NODE_MINOR_VERSION >= 3
- #define NAN_MODULE_WORKER_ENABLED(module_name, registration) \
- extern "C" NODE_MODULE_EXPORT void \
- NAN_CONCAT(node_register_module_v, NODE_MODULE_VERSION)( \
- v8::Local<v8::Object> exports, v8::Local<v8::Value> module, \
- v8::Local<v8::Context> context) \
- { \
- registration(exports); \
- }
- #else
- #define NAN_MODULE_WORKER_ENABLED(module_name, registration) \
- NODE_MODULE(module_name, registration)
- #endif
-
- //=== CallbackInfo =============================================================
-
- #include "nan_callbacks.h" // NOLINT(build/include)
-
- //==============================================================================
-
- #if (NODE_MODULE_VERSION < NODE_0_12_MODULE_VERSION)
- typedef v8::Script UnboundScript;
- typedef v8::Script BoundScript;
- #else
- typedef v8::UnboundScript UnboundScript;
- typedef v8::Script BoundScript;
- #endif
-
- #if (NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION)
- typedef v8::String::ExternalAsciiStringResource
- ExternalOneByteStringResource;
- #else
- typedef v8::String::ExternalOneByteStringResource
- ExternalOneByteStringResource;
- #endif
-
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
- template<typename T>
- class NonCopyablePersistentTraits :
- public v8::NonCopyablePersistentTraits<T> {};
- template<typename T>
- class CopyablePersistentTraits :
- public v8::CopyablePersistentTraits<T> {};
-
- template<typename T>
- class PersistentBase :
- public v8::PersistentBase<T> {};
-
- template<typename T, typename M = v8::NonCopyablePersistentTraits<T> >
- class Persistent;
- #else
- template<typename T> class NonCopyablePersistentTraits;
- template<typename T> class PersistentBase;
- template<typename T, typename P> class WeakCallbackData;
- template<typename T, typename M = NonCopyablePersistentTraits<T> >
- class Persistent;
- #endif // NODE_MODULE_VERSION
-
- template<typename T>
- class Maybe {
- public:
- inline bool IsNothing() const { return !has_value_; }
- inline bool IsJust() const { return has_value_; }
-
- inline T ToChecked() const { return FromJust(); }
- inline void Check() const { FromJust(); }
-
- inline bool To(T* out) const {
- if (IsJust()) *out = value_;
- return IsJust();
- }
-
- inline T FromJust() const {
- #if defined(V8_ENABLE_CHECKS)
- assert(IsJust() && "FromJust is Nothing");
- #endif // V8_ENABLE_CHECKS
- return value_;
- }
-
- inline T FromMaybe(const T& default_value) const {
- return has_value_ ? value_ : default_value;
- }
-
- inline bool operator==(const Maybe &other) const {
- return (IsJust() == other.IsJust()) &&
- (!IsJust() || FromJust() == other.FromJust());
- }
-
- inline bool operator!=(const Maybe &other) const {
- return !operator==(other);
- }
-
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 || \
- (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
- // Allow implicit conversions from v8::Maybe<T> to Nan::Maybe<T>.
- Maybe(const v8::Maybe<T>& that) // NOLINT(runtime/explicit)
- : has_value_(that.IsJust())
- , value_(that.FromMaybe(T())) {}
- #endif
-
- private:
- Maybe() : has_value_(false) {}
- explicit Maybe(const T& t) : has_value_(true), value_(t) {}
- bool has_value_;
- T value_;
-
- template<typename U>
- friend Maybe<U> Nothing();
- template<typename U>
- friend Maybe<U> Just(const U& u);
- };
-
- template<typename T>
- inline Maybe<T> Nothing() {
- return Maybe<T>();
- }
-
- template<typename T>
- inline Maybe<T> Just(const T& t) {
- return Maybe<T>(t);
- }
-
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 || \
- (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
- # include "nan_maybe_43_inl.h" // NOLINT(build/include)
- #else
- # include "nan_maybe_pre_43_inl.h" // NOLINT(build/include)
- #endif
-
- #include "nan_converters.h" // NOLINT(build/include)
- #include "nan_new.h" // NOLINT(build/include)
-
- #if NAUV_UVVERSION < 0x000b17
- #define NAUV_WORK_CB(func) \
- void func(uv_async_t *async, int)
- #else
- #define NAUV_WORK_CB(func) \
- void func(uv_async_t *async)
- #endif
-
- #if NAUV_UVVERSION >= 0x000b0b
-
- typedef uv_key_t nauv_key_t;
-
- inline int nauv_key_create(nauv_key_t *key) {
- return uv_key_create(key);
- }
-
- inline void nauv_key_delete(nauv_key_t *key) {
- uv_key_delete(key);
- }
-
- inline void* nauv_key_get(nauv_key_t *key) {
- return uv_key_get(key);
- }
-
- inline void nauv_key_set(nauv_key_t *key, void *value) {
- uv_key_set(key, value);
- }
-
- #else
-
- /* Implement thread local storage for older versions of libuv.
- * This is essentially a backport of libuv commit 5d2434bf
- * written by Ben Noordhuis, adjusted for names and inline.
- */
-
- #ifndef WIN32
-
- typedef pthread_key_t nauv_key_t;
-
- inline int nauv_key_create(nauv_key_t* key) {
- return -pthread_key_create(key, NULL);
- }
-
- inline void nauv_key_delete(nauv_key_t* key) {
- if (pthread_key_delete(*key))
- abort();
- }
-
- inline void* nauv_key_get(nauv_key_t* key) {
- return pthread_getspecific(*key);
- }
-
- inline void nauv_key_set(nauv_key_t* key, void* value) {
- if (pthread_setspecific(*key, value))
- abort();
- }
-
- #else
-
- typedef struct {
- DWORD tls_index;
- } nauv_key_t;
-
- inline int nauv_key_create(nauv_key_t* key) {
- key->tls_index = TlsAlloc();
- if (key->tls_index == TLS_OUT_OF_INDEXES)
- return UV_ENOMEM;
- return 0;
- }
-
- inline void nauv_key_delete(nauv_key_t* key) {
- if (TlsFree(key->tls_index) == FALSE)
- abort();
- key->tls_index = TLS_OUT_OF_INDEXES;
- }
-
- inline void* nauv_key_get(nauv_key_t* key) {
- void* value = TlsGetValue(key->tls_index);
- if (value == NULL)
- if (GetLastError() != ERROR_SUCCESS)
- abort();
- return value;
- }
-
- inline void nauv_key_set(nauv_key_t* key, void* value) {
- if (TlsSetValue(key->tls_index, value) == FALSE)
- abort();
- }
-
- #endif
- #endif
-
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- template<typename T>
- v8::Local<T> New(v8::Handle<T>);
- #endif
-
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 || \
- (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
- typedef v8::WeakCallbackType WeakCallbackType;
- #else
- struct WeakCallbackType {
- enum E {kParameter, kInternalFields};
- E type;
- WeakCallbackType(E other) : type(other) {} // NOLINT(runtime/explicit)
- inline bool operator==(E other) { return other == this->type; }
- inline bool operator!=(E other) { return !operator==(other); }
- };
- #endif
-
- template<typename P> class WeakCallbackInfo;
-
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- # include "nan_persistent_12_inl.h" // NOLINT(build/include)
- #else
- # include "nan_persistent_pre_12_inl.h" // NOLINT(build/include)
- #endif
-
- namespace imp {
- static const size_t kMaxLength = 0x3fffffff;
- // v8::String::REPLACE_INVALID_UTF8 was introduced
- // in node.js v0.10.29 and v0.8.27.
- #if NODE_MAJOR_VERSION > 0 || \
- NODE_MINOR_VERSION > 10 || \
- NODE_MINOR_VERSION == 10 && NODE_PATCH_VERSION >= 29 || \
- NODE_MINOR_VERSION == 8 && NODE_PATCH_VERSION >= 27
- static const unsigned kReplaceInvalidUtf8 = v8::String::REPLACE_INVALID_UTF8;
- #else
- static const unsigned kReplaceInvalidUtf8 = 0;
- #endif
- } // end of namespace imp
-
- //=== HandleScope ==============================================================
-
- class HandleScope {
- v8::HandleScope scope;
-
- public:
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- inline HandleScope() : scope(v8::Isolate::GetCurrent()) {}
- inline static int NumberOfHandles() {
- return v8::HandleScope::NumberOfHandles(v8::Isolate::GetCurrent());
- }
- #else
- inline HandleScope() : scope() {}
- inline static int NumberOfHandles() {
- return v8::HandleScope::NumberOfHandles();
- }
- #endif
-
- private:
- // Make it hard to create heap-allocated or illegal handle scopes by
- // disallowing certain operations.
- HandleScope(const HandleScope &);
- void operator=(const HandleScope &);
- void *operator new(size_t size);
- void operator delete(void *, size_t) {
- abort();
- }
- };
-
- class EscapableHandleScope {
- public:
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- inline EscapableHandleScope() : scope(v8::Isolate::GetCurrent()) {}
-
- inline static int NumberOfHandles() {
- return v8::EscapableHandleScope::NumberOfHandles(v8::Isolate::GetCurrent());
- }
-
- template<typename T>
- inline v8::Local<T> Escape(v8::Local<T> value) {
- return scope.Escape(value);
- }
-
- private:
- v8::EscapableHandleScope scope;
- #else
- inline EscapableHandleScope() : scope() {}
-
- inline static int NumberOfHandles() {
- return v8::HandleScope::NumberOfHandles();
- }
-
- template<typename T>
- inline v8::Local<T> Escape(v8::Local<T> value) {
- return scope.Close(value);
- }
-
- private:
- v8::HandleScope scope;
- #endif
-
- private:
- // Make it hard to create heap-allocated or illegal handle scopes by
- // disallowing certain operations.
- EscapableHandleScope(const EscapableHandleScope &);
- void operator=(const EscapableHandleScope &);
- void *operator new(size_t size);
- void operator delete(void *, size_t) {
- abort();
- }
- };
-
- //=== TryCatch =================================================================
-
- class TryCatch {
- v8::TryCatch try_catch_;
- friend void FatalException(const TryCatch&);
-
- public:
- #if NODE_MODULE_VERSION > NODE_0_12_MODULE_VERSION
- TryCatch() : try_catch_(v8::Isolate::GetCurrent()) {}
- #endif
-
- inline bool HasCaught() const { return try_catch_.HasCaught(); }
-
- inline bool CanContinue() const { return try_catch_.CanContinue(); }
-
- inline v8::Local<v8::Value> ReThrow() {
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- return New(try_catch_.ReThrow());
- #else
- return try_catch_.ReThrow();
- #endif
- }
-
- inline v8::Local<v8::Value> Exception() const {
- return try_catch_.Exception();
- }
-
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 || \
- (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
- inline v8::MaybeLocal<v8::Value> StackTrace() const {
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- return scope.Escape(try_catch_.StackTrace(isolate->GetCurrentContext())
- .FromMaybe(v8::Local<v8::Value>()));
- }
- #else
- inline MaybeLocal<v8::Value> StackTrace() const {
- return try_catch_.StackTrace();
- }
- #endif
-
- inline v8::Local<v8::Message> Message() const {
- return try_catch_.Message();
- }
-
- inline void Reset() { try_catch_.Reset(); }
-
- inline void SetVerbose(bool value) { try_catch_.SetVerbose(value); }
-
- inline void SetCaptureMessage(bool value) {
- try_catch_.SetCaptureMessage(value);
- }
- };
-
- v8::Local<v8::Value> MakeCallback(v8::Local<v8::Object> target,
- v8::Local<v8::Function> func,
- int argc,
- v8::Local<v8::Value>* argv);
- v8::Local<v8::Value> MakeCallback(v8::Local<v8::Object> target,
- v8::Local<v8::String> symbol,
- int argc,
- v8::Local<v8::Value>* argv);
- v8::Local<v8::Value> MakeCallback(v8::Local<v8::Object> target,
- const char* method,
- int argc,
- v8::Local<v8::Value>* argv);
-
- // === AsyncResource ===========================================================
-
- class AsyncResource {
- public:
- AsyncResource(
- v8::Local<v8::String> name
- , v8::Local<v8::Object> resource = New<v8::Object>()) {
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- v8::Isolate* isolate = v8::Isolate::GetCurrent();
-
- if (resource.IsEmpty()) {
- resource = New<v8::Object>();
- }
-
- context = node::EmitAsyncInit(isolate, resource, name);
- #endif
- }
-
- AsyncResource(
- const char* name
- , v8::Local<v8::Object> resource = New<v8::Object>()) {
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- v8::Isolate* isolate = v8::Isolate::GetCurrent();
-
- if (resource.IsEmpty()) {
- resource = New<v8::Object>();
- }
-
- v8::Local<v8::String> name_string =
- New<v8::String>(name).ToLocalChecked();
- context = node::EmitAsyncInit(isolate, resource, name_string);
- #endif
- }
-
- ~AsyncResource() {
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- v8::Isolate* isolate = v8::Isolate::GetCurrent();
- node::EmitAsyncDestroy(isolate, context);
- #endif
- }
-
- inline MaybeLocal<v8::Value> runInAsyncScope(
- v8::Local<v8::Object> target
- , v8::Local<v8::Function> func
- , int argc
- , v8::Local<v8::Value>* argv) {
- #if NODE_MODULE_VERSION < NODE_9_0_MODULE_VERSION
- return MakeCallback(target, func, argc, argv);
- #else
- return node::MakeCallback(
- v8::Isolate::GetCurrent(), target, func, argc, argv, context);
- #endif
- }
-
- inline MaybeLocal<v8::Value> runInAsyncScope(
- v8::Local<v8::Object> target
- , v8::Local<v8::String> symbol
- , int argc
- , v8::Local<v8::Value>* argv) {
- #if NODE_MODULE_VERSION < NODE_9_0_MODULE_VERSION
- return MakeCallback(target, symbol, argc, argv);
- #else
- return node::MakeCallback(
- v8::Isolate::GetCurrent(), target, symbol, argc, argv, context);
- #endif
- }
-
- inline MaybeLocal<v8::Value> runInAsyncScope(
- v8::Local<v8::Object> target
- , const char* method
- , int argc
- , v8::Local<v8::Value>* argv) {
- #if NODE_MODULE_VERSION < NODE_9_0_MODULE_VERSION
- return MakeCallback(target, method, argc, argv);
- #else
- return node::MakeCallback(
- v8::Isolate::GetCurrent(), target, method, argc, argv, context);
- #endif
- }
-
- private:
- NAN_DISALLOW_ASSIGN_COPY_MOVE(AsyncResource)
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- node::async_context context;
- #endif
- };
-
- inline uv_loop_t* GetCurrentEventLoop() {
- #if NODE_MAJOR_VERSION >= 10 || \
- NODE_MAJOR_VERSION == 9 && NODE_MINOR_VERSION >= 3 || \
- NODE_MAJOR_VERSION == 8 && NODE_MINOR_VERSION >= 10
- return node::GetCurrentEventLoop(v8::Isolate::GetCurrent());
- #else
- return uv_default_loop();
- #endif
- }
-
- //============ =================================================================
-
- /* node 0.12 */
- #if NODE_MODULE_VERSION >= NODE_0_12_MODULE_VERSION
- inline
- void SetCounterFunction(v8::CounterLookupCallback cb) {
- v8::Isolate::GetCurrent()->SetCounterFunction(cb);
- }
-
- inline
- void SetCreateHistogramFunction(v8::CreateHistogramCallback cb) {
- v8::Isolate::GetCurrent()->SetCreateHistogramFunction(cb);
- }
-
- inline
- void SetAddHistogramSampleFunction(v8::AddHistogramSampleCallback cb) {
- v8::Isolate::GetCurrent()->SetAddHistogramSampleFunction(cb);
- }
-
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 || \
- (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
- inline bool IdleNotification(int idle_time_in_ms) {
- return v8::Isolate::GetCurrent()->IdleNotificationDeadline(
- idle_time_in_ms * 0.001);
- }
- # else
- inline bool IdleNotification(int idle_time_in_ms) {
- return v8::Isolate::GetCurrent()->IdleNotification(idle_time_in_ms);
- }
- #endif
-
- inline void LowMemoryNotification() {
- v8::Isolate::GetCurrent()->LowMemoryNotification();
- }
-
- inline void ContextDisposedNotification() {
- v8::Isolate::GetCurrent()->ContextDisposedNotification();
- }
- #else
- inline
- void SetCounterFunction(v8::CounterLookupCallback cb) {
- v8::V8::SetCounterFunction(cb);
- }
-
- inline
- void SetCreateHistogramFunction(v8::CreateHistogramCallback cb) {
- v8::V8::SetCreateHistogramFunction(cb);
- }
-
- inline
- void SetAddHistogramSampleFunction(v8::AddHistogramSampleCallback cb) {
- v8::V8::SetAddHistogramSampleFunction(cb);
- }
-
- inline bool IdleNotification(int idle_time_in_ms) {
- return v8::V8::IdleNotification(idle_time_in_ms);
- }
-
- inline void LowMemoryNotification() {
- v8::V8::LowMemoryNotification();
- }
-
- inline void ContextDisposedNotification() {
- v8::V8::ContextDisposedNotification();
- }
- #endif
-
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION) // Node 0.12
- inline v8::Local<v8::Primitive> Undefined() {
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- return scope.Escape(New(v8::Undefined(v8::Isolate::GetCurrent())));
- # else
- return v8::Undefined(v8::Isolate::GetCurrent());
- # endif
- }
-
- inline v8::Local<v8::Primitive> Null() {
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- return scope.Escape(New(v8::Null(v8::Isolate::GetCurrent())));
- # else
- return v8::Null(v8::Isolate::GetCurrent());
- # endif
- }
-
- inline v8::Local<v8::Boolean> True() {
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- return scope.Escape(New(v8::True(v8::Isolate::GetCurrent())));
- # else
- return v8::True(v8::Isolate::GetCurrent());
- # endif
- }
-
- inline v8::Local<v8::Boolean> False() {
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- return scope.Escape(New(v8::False(v8::Isolate::GetCurrent())));
- # else
- return v8::False(v8::Isolate::GetCurrent());
- # endif
- }
-
- inline v8::Local<v8::String> EmptyString() {
- return v8::String::Empty(v8::Isolate::GetCurrent());
- }
-
- inline int AdjustExternalMemory(int bc) {
- return static_cast<int>(
- v8::Isolate::GetCurrent()->AdjustAmountOfExternalAllocatedMemory(bc));
- }
-
- inline void SetTemplate(
- v8::Local<v8::Template> templ
- , const char *name
- , v8::Local<v8::Data> value) {
- templ->Set(v8::Isolate::GetCurrent(), name, value);
- }
-
- inline void SetTemplate(
- v8::Local<v8::Template> templ
- , v8::Local<v8::String> name
- , v8::Local<v8::Data> value
- , v8::PropertyAttribute attributes) {
- templ->Set(name, value, attributes);
- }
-
- inline v8::Local<v8::Context> GetCurrentContext() {
- return v8::Isolate::GetCurrent()->GetCurrentContext();
- }
-
- inline void* GetInternalFieldPointer(
- v8::Local<v8::Object> object
- , int index) {
- return object->GetAlignedPointerFromInternalField(index);
- }
-
- inline void SetInternalFieldPointer(
- v8::Local<v8::Object> object
- , int index
- , void* value) {
- object->SetAlignedPointerInInternalField(index, value);
- }
-
- # define NAN_GC_CALLBACK(name) \
- void name(v8::Isolate *isolate, v8::GCType type, v8::GCCallbackFlags flags)
-
- #if NODE_MODULE_VERSION <= NODE_4_0_MODULE_VERSION
- typedef v8::Isolate::GCEpilogueCallback GCEpilogueCallback;
- typedef v8::Isolate::GCPrologueCallback GCPrologueCallback;
- #else
- typedef v8::Isolate::GCCallback GCEpilogueCallback;
- typedef v8::Isolate::GCCallback GCPrologueCallback;
- #endif
-
- inline void AddGCEpilogueCallback(
- GCEpilogueCallback callback
- , v8::GCType gc_type_filter = v8::kGCTypeAll) {
- v8::Isolate::GetCurrent()->AddGCEpilogueCallback(callback, gc_type_filter);
- }
-
- inline void RemoveGCEpilogueCallback(
- GCEpilogueCallback callback) {
- v8::Isolate::GetCurrent()->RemoveGCEpilogueCallback(callback);
- }
-
- inline void AddGCPrologueCallback(
- GCPrologueCallback callback
- , v8::GCType gc_type_filter = v8::kGCTypeAll) {
- v8::Isolate::GetCurrent()->AddGCPrologueCallback(callback, gc_type_filter);
- }
-
- inline void RemoveGCPrologueCallback(
- GCPrologueCallback callback) {
- v8::Isolate::GetCurrent()->RemoveGCPrologueCallback(callback);
- }
-
- inline void GetHeapStatistics(
- v8::HeapStatistics *heap_statistics) {
- v8::Isolate::GetCurrent()->GetHeapStatistics(heap_statistics);
- }
-
- # define X(NAME) \
- inline v8::Local<v8::Value> NAME(const char *msg) { \
- EscapableHandleScope scope; \
- return scope.Escape(v8::Exception::NAME(New(msg).ToLocalChecked())); \
- } \
- \
- inline \
- v8::Local<v8::Value> NAME(v8::Local<v8::String> msg) { \
- return v8::Exception::NAME(msg); \
- } \
- \
- inline void Throw ## NAME(const char *msg) { \
- HandleScope scope; \
- v8::Isolate::GetCurrent()->ThrowException( \
- v8::Exception::NAME(New(msg).ToLocalChecked())); \
- } \
- \
- inline void Throw ## NAME(v8::Local<v8::String> msg) { \
- HandleScope scope; \
- v8::Isolate::GetCurrent()->ThrowException( \
- v8::Exception::NAME(msg)); \
- }
-
- X(Error)
- X(RangeError)
- X(ReferenceError)
- X(SyntaxError)
- X(TypeError)
-
- # undef X
-
- inline void ThrowError(v8::Local<v8::Value> error) {
- v8::Isolate::GetCurrent()->ThrowException(error);
- }
-
- inline MaybeLocal<v8::Object> NewBuffer(
- char *data
- , size_t length
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
- , node::Buffer::FreeCallback callback
- #else
- , node::smalloc::FreeCallback callback
- #endif
- , void *hint
- ) {
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- assert(length <= imp::kMaxLength && "too large buffer");
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
- return node::Buffer::New(
- v8::Isolate::GetCurrent(), data, length, callback, hint);
- #else
- return node::Buffer::New(v8::Isolate::GetCurrent(), data, length, callback,
- hint);
- #endif
- }
-
- inline MaybeLocal<v8::Object> CopyBuffer(
- const char *data
- , uint32_t size
- ) {
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- assert(size <= imp::kMaxLength && "too large buffer");
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
- return node::Buffer::Copy(
- v8::Isolate::GetCurrent(), data, size);
- #else
- return node::Buffer::New(v8::Isolate::GetCurrent(), data, size);
- #endif
- }
-
- inline MaybeLocal<v8::Object> NewBuffer(uint32_t size) {
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- assert(size <= imp::kMaxLength && "too large buffer");
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
- return node::Buffer::New(
- v8::Isolate::GetCurrent(), size);
- #else
- return node::Buffer::New(v8::Isolate::GetCurrent(), size);
- #endif
- }
-
- inline MaybeLocal<v8::Object> NewBuffer(
- char* data
- , uint32_t size
- ) {
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- assert(size <= imp::kMaxLength && "too large buffer");
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
- return node::Buffer::New(v8::Isolate::GetCurrent(), data, size);
- #else
- return node::Buffer::Use(v8::Isolate::GetCurrent(), data, size);
- #endif
- }
-
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 || \
- (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
- inline MaybeLocal<v8::String>
- NewOneByteString(const uint8_t * value, int length = -1) {
- return v8::String::NewFromOneByte(v8::Isolate::GetCurrent(), value,
- v8::NewStringType::kNormal, length);
- }
-
- inline MaybeLocal<BoundScript> CompileScript(
- v8::Local<v8::String> s
- , const v8::ScriptOrigin& origin
- ) {
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- v8::ScriptCompiler::Source source(s, origin);
- return scope.Escape(
- v8::ScriptCompiler::Compile(isolate->GetCurrentContext(), &source)
- .FromMaybe(v8::Local<BoundScript>()));
- }
-
- inline MaybeLocal<BoundScript> CompileScript(
- v8::Local<v8::String> s
- ) {
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- v8::ScriptCompiler::Source source(s);
- return scope.Escape(
- v8::ScriptCompiler::Compile(isolate->GetCurrentContext(), &source)
- .FromMaybe(v8::Local<BoundScript>()));
- }
-
- inline MaybeLocal<v8::Value> RunScript(
- v8::Local<UnboundScript> script
- ) {
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- return scope.Escape(script->BindToCurrentContext()
- ->Run(isolate->GetCurrentContext())
- .FromMaybe(v8::Local<v8::Value>()));
- }
-
- inline MaybeLocal<v8::Value> RunScript(
- v8::Local<BoundScript> script
- ) {
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- return scope.Escape(script->Run(isolate->GetCurrentContext())
- .FromMaybe(v8::Local<v8::Value>()));
- }
- #else
- inline MaybeLocal<v8::String>
- NewOneByteString(const uint8_t * value, int length = -1) {
- return v8::String::NewFromOneByte(v8::Isolate::GetCurrent(), value,
- v8::String::kNormalString, length);
- }
-
- inline MaybeLocal<BoundScript> CompileScript(
- v8::Local<v8::String> s
- , const v8::ScriptOrigin& origin
- ) {
- v8::ScriptCompiler::Source source(s, origin);
- return v8::ScriptCompiler::Compile(v8::Isolate::GetCurrent(), &source);
- }
-
- inline MaybeLocal<BoundScript> CompileScript(
- v8::Local<v8::String> s
- ) {
- v8::ScriptCompiler::Source source(s);
- return v8::ScriptCompiler::Compile(v8::Isolate::GetCurrent(), &source);
- }
-
- inline MaybeLocal<v8::Value> RunScript(
- v8::Local<UnboundScript> script
- ) {
- EscapableHandleScope scope;
- return scope.Escape(script->BindToCurrentContext()->Run());
- }
-
- inline MaybeLocal<v8::Value> RunScript(
- v8::Local<BoundScript> script
- ) {
- return script->Run();
- }
- #endif
-
- NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
- v8::Local<v8::Object> target
- , v8::Local<v8::Function> func
- , int argc
- , v8::Local<v8::Value>* argv) {
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- return scope.Escape(New(node::MakeCallback(
- v8::Isolate::GetCurrent(), target, func, argc, argv)));
- #else
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- AsyncResource res("nan:makeCallback");
- return res.runInAsyncScope(target, func, argc, argv)
- .FromMaybe(v8::Local<v8::Value>());
- # else
- return node::MakeCallback(
- v8::Isolate::GetCurrent(), target, func, argc, argv);
- # endif // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- #endif // NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- }
-
- NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
- v8::Local<v8::Object> target
- , v8::Local<v8::String> symbol
- , int argc
- , v8::Local<v8::Value>* argv) {
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- return scope.Escape(New(node::MakeCallback(
- v8::Isolate::GetCurrent(), target, symbol, argc, argv)));
- #else
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- AsyncResource res("nan:makeCallback");
- return res.runInAsyncScope(target, symbol, argc, argv)
- .FromMaybe(v8::Local<v8::Value>());
- # else
- return node::MakeCallback(
- v8::Isolate::GetCurrent(), target, symbol, argc, argv);
- # endif // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- #endif // NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- }
-
- NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
- v8::Local<v8::Object> target
- , const char* method
- , int argc
- , v8::Local<v8::Value>* argv) {
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- return scope.Escape(New(node::MakeCallback(
- v8::Isolate::GetCurrent(), target, method, argc, argv)));
- #else
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- AsyncResource res("nan:makeCallback");
- return res.runInAsyncScope(target, method, argc, argv)
- .FromMaybe(v8::Local<v8::Value>());
- # else
- return node::MakeCallback(
- v8::Isolate::GetCurrent(), target, method, argc, argv);
- # endif // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- #endif // NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- }
-
- inline void FatalException(const TryCatch& try_catch) {
- node::FatalException(v8::Isolate::GetCurrent(), try_catch.try_catch_);
- }
-
- inline v8::Local<v8::Value> ErrnoException(
- int errorno
- , const char* syscall = NULL
- , const char* message = NULL
- , const char* path = NULL) {
- return node::ErrnoException(v8::Isolate::GetCurrent(), errorno, syscall,
- message, path);
- }
-
- NAN_DEPRECATED inline v8::Local<v8::Value> NanErrnoException(
- int errorno
- , const char* syscall = NULL
- , const char* message = NULL
- , const char* path = NULL) {
- return ErrnoException(errorno, syscall, message, path);
- }
-
- template<typename T>
- inline void SetIsolateData(
- v8::Isolate *isolate
- , T *data
- ) {
- isolate->SetData(0, data);
- }
-
- template<typename T>
- inline T *GetIsolateData(
- v8::Isolate *isolate
- ) {
- return static_cast<T*>(isolate->GetData(0));
- }
-
- class Utf8String {
- public:
- inline explicit Utf8String(v8::Local<v8::Value> from) :
- length_(0), str_(str_st_) {
- HandleScope scope;
- if (!from.IsEmpty()) {
- #if NODE_MAJOR_VERSION >= 10
- v8::Local<v8::Context> context = GetCurrentContext();
- v8::Local<v8::String> string =
- from->ToString(context).FromMaybe(v8::Local<v8::String>());
- #else
- v8::Local<v8::String> string = from->ToString();
- #endif
- if (!string.IsEmpty()) {
- size_t len = 3 * string->Length() + 1;
- assert(len <= INT_MAX);
- if (len > sizeof (str_st_)) {
- str_ = static_cast<char*>(malloc(len));
- assert(str_ != 0);
- }
- const int flags =
- v8::String::NO_NULL_TERMINATION | imp::kReplaceInvalidUtf8;
- #if NODE_MAJOR_VERSION >= 11
- length_ = string->WriteUtf8(v8::Isolate::GetCurrent(), str_,
- static_cast<int>(len), 0, flags);
- #else
- // See https://github.com/nodejs/nan/issues/832.
- // Disable the warning as there is no way around it.
- #ifdef _MSC_VER
- #pragma warning(push)
- #pragma warning(disable : 4996)
- #endif
- #ifdef __GNUC__
- #pragma GCC diagnostic push
- #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
- #endif
- length_ = string->WriteUtf8(str_, static_cast<int>(len), 0, flags);
- #ifdef __GNUC__
- #pragma GCC diagnostic pop
- #endif
- #ifdef _MSC_VER
- #pragma warning(pop)
- #endif
- #endif // NODE_MAJOR_VERSION < 11
- str_[length_] = '\0';
- }
- }
- }
-
- inline int length() const {
- return length_;
- }
-
- inline char* operator*() { return str_; }
- inline const char* operator*() const { return str_; }
-
- inline ~Utf8String() {
- if (str_ != str_st_) {
- free(str_);
- }
- }
-
- private:
- NAN_DISALLOW_ASSIGN_COPY_MOVE(Utf8String)
-
- int length_;
- char *str_;
- char str_st_[1024];
- };
-
- #else // Node 0.8 and 0.10
- inline v8::Local<v8::Primitive> Undefined() {
- EscapableHandleScope scope;
- return scope.Escape(New(v8::Undefined()));
- }
-
- inline v8::Local<v8::Primitive> Null() {
- EscapableHandleScope scope;
- return scope.Escape(New(v8::Null()));
- }
-
- inline v8::Local<v8::Boolean> True() {
- EscapableHandleScope scope;
- return scope.Escape(New(v8::True()));
- }
-
- inline v8::Local<v8::Boolean> False() {
- EscapableHandleScope scope;
- return scope.Escape(New(v8::False()));
- }
-
- inline v8::Local<v8::String> EmptyString() {
- return v8::String::Empty();
- }
-
- inline int AdjustExternalMemory(int bc) {
- return static_cast<int>(v8::V8::AdjustAmountOfExternalAllocatedMemory(bc));
- }
-
- inline void SetTemplate(
- v8::Local<v8::Template> templ
- , const char *name
- , v8::Local<v8::Data> value) {
- templ->Set(name, value);
- }
-
- inline void SetTemplate(
- v8::Local<v8::Template> templ
- , v8::Local<v8::String> name
- , v8::Local<v8::Data> value
- , v8::PropertyAttribute attributes) {
- templ->Set(name, value, attributes);
- }
-
- inline v8::Local<v8::Context> GetCurrentContext() {
- return v8::Context::GetCurrent();
- }
-
- inline void* GetInternalFieldPointer(
- v8::Local<v8::Object> object
- , int index) {
- return object->GetPointerFromInternalField(index);
- }
-
- inline void SetInternalFieldPointer(
- v8::Local<v8::Object> object
- , int index
- , void* value) {
- object->SetPointerInInternalField(index, value);
- }
-
- # define NAN_GC_CALLBACK(name) \
- void name(v8::GCType type, v8::GCCallbackFlags flags)
-
- inline void AddGCEpilogueCallback(
- v8::GCEpilogueCallback callback
- , v8::GCType gc_type_filter = v8::kGCTypeAll) {
- v8::V8::AddGCEpilogueCallback(callback, gc_type_filter);
- }
- inline void RemoveGCEpilogueCallback(
- v8::GCEpilogueCallback callback) {
- v8::V8::RemoveGCEpilogueCallback(callback);
- }
- inline void AddGCPrologueCallback(
- v8::GCPrologueCallback callback
- , v8::GCType gc_type_filter = v8::kGCTypeAll) {
- v8::V8::AddGCPrologueCallback(callback, gc_type_filter);
- }
- inline void RemoveGCPrologueCallback(
- v8::GCPrologueCallback callback) {
- v8::V8::RemoveGCPrologueCallback(callback);
- }
- inline void GetHeapStatistics(
- v8::HeapStatistics *heap_statistics) {
- v8::V8::GetHeapStatistics(heap_statistics);
- }
-
- # define X(NAME) \
- inline v8::Local<v8::Value> NAME(const char *msg) { \
- EscapableHandleScope scope; \
- return scope.Escape(v8::Exception::NAME(New(msg).ToLocalChecked())); \
- } \
- \
- inline \
- v8::Local<v8::Value> NAME(v8::Local<v8::String> msg) { \
- return v8::Exception::NAME(msg); \
- } \
- \
- inline void Throw ## NAME(const char *msg) { \
- HandleScope scope; \
- v8::ThrowException(v8::Exception::NAME(New(msg).ToLocalChecked())); \
- } \
- \
- inline \
- void Throw ## NAME(v8::Local<v8::String> errmsg) { \
- HandleScope scope; \
- v8::ThrowException(v8::Exception::NAME(errmsg)); \
- }
-
- X(Error)
- X(RangeError)
- X(ReferenceError)
- X(SyntaxError)
- X(TypeError)
-
- # undef X
-
- inline void ThrowError(v8::Local<v8::Value> error) {
- v8::ThrowException(error);
- }
-
- inline MaybeLocal<v8::Object> NewBuffer(
- char *data
- , size_t length
- , node::Buffer::free_callback callback
- , void *hint
- ) {
- EscapableHandleScope scope;
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- assert(length <= imp::kMaxLength && "too large buffer");
- return scope.Escape(
- New(node::Buffer::New(data, length, callback, hint)->handle_));
- }
-
- inline MaybeLocal<v8::Object> CopyBuffer(
- const char *data
- , uint32_t size
- ) {
- EscapableHandleScope scope;
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- assert(size <= imp::kMaxLength && "too large buffer");
- #if NODE_MODULE_VERSION >= NODE_0_10_MODULE_VERSION
- return scope.Escape(New(node::Buffer::New(data, size)->handle_));
- #else
- return scope.Escape(
- New(node::Buffer::New(const_cast<char *>(data), size)->handle_));
- #endif
- }
-
- inline MaybeLocal<v8::Object> NewBuffer(uint32_t size) {
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- EscapableHandleScope scope;
- assert(size <= imp::kMaxLength && "too large buffer");
- return scope.Escape(New(node::Buffer::New(size)->handle_));
- }
-
- inline void FreeData(char *data, void *hint) {
- (void) hint; // unused
- delete[] data;
- }
-
- inline MaybeLocal<v8::Object> NewBuffer(
- char* data
- , uint32_t size
- ) {
- EscapableHandleScope scope;
- // arbitrary buffer lengths requires
- // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
- assert(size <= imp::kMaxLength && "too large buffer");
- return scope.Escape(
- New(node::Buffer::New(data, size, FreeData, NULL)->handle_));
- }
-
- namespace imp {
- inline void
- widenString(std::vector<uint16_t> *ws, const uint8_t *s, int l) {
- size_t len = static_cast<size_t>(l);
- if (l < 0) {
- len = strlen(reinterpret_cast<const char*>(s));
- }
- assert(len <= INT_MAX && "string too long");
- ws->resize(len);
- std::copy(s, s + len, ws->begin()); // NOLINT(build/include_what_you_use)
- }
- } // end of namespace imp
-
- inline MaybeLocal<v8::String>
- NewOneByteString(const uint8_t * value, int length = -1) {
- std::vector<uint16_t> wideString; // NOLINT(build/include_what_you_use)
- imp::widenString(&wideString, value, length);
- return v8::String::New(wideString.data(),
- static_cast<int>(wideString.size()));
- }
-
- inline MaybeLocal<BoundScript> CompileScript(
- v8::Local<v8::String> s
- , const v8::ScriptOrigin& origin
- ) {
- return v8::Script::Compile(s, const_cast<v8::ScriptOrigin *>(&origin));
- }
-
- inline MaybeLocal<BoundScript> CompileScript(
- v8::Local<v8::String> s
- ) {
- return v8::Script::Compile(s);
- }
-
- inline
- MaybeLocal<v8::Value> RunScript(v8::Local<v8::Script> script) {
- return script->Run();
- }
-
- inline v8::Local<v8::Value> MakeCallback(
- v8::Local<v8::Object> target
- , v8::Local<v8::Function> func
- , int argc
- , v8::Local<v8::Value>* argv) {
- v8::HandleScope scope;
- return scope.Close(New(node::MakeCallback(target, func, argc, argv)));
- }
-
- inline v8::Local<v8::Value> MakeCallback(
- v8::Local<v8::Object> target
- , v8::Local<v8::String> symbol
- , int argc
- , v8::Local<v8::Value>* argv) {
- v8::HandleScope scope;
- return scope.Close(New(node::MakeCallback(target, symbol, argc, argv)));
- }
-
- inline v8::Local<v8::Value> MakeCallback(
- v8::Local<v8::Object> target
- , const char* method
- , int argc
- , v8::Local<v8::Value>* argv) {
- v8::HandleScope scope;
- return scope.Close(New(node::MakeCallback(target, method, argc, argv)));
- }
-
- inline void FatalException(const TryCatch& try_catch) {
- node::FatalException(const_cast<v8::TryCatch &>(try_catch.try_catch_));
- }
-
- inline v8::Local<v8::Value> ErrnoException(
- int errorno
- , const char* syscall = NULL
- , const char* message = NULL
- , const char* path = NULL) {
- return node::ErrnoException(errorno, syscall, message, path);
- }
-
- NAN_DEPRECATED inline v8::Local<v8::Value> NanErrnoException(
- int errorno
- , const char* syscall = NULL
- , const char* message = NULL
- , const char* path = NULL) {
- return ErrnoException(errorno, syscall, message, path);
- }
-
-
- template<typename T>
- inline void SetIsolateData(
- v8::Isolate *isolate
- , T *data
- ) {
- isolate->SetData(data);
- }
-
- template<typename T>
- inline T *GetIsolateData(
- v8::Isolate *isolate
- ) {
- return static_cast<T*>(isolate->GetData());
- }
-
- class Utf8String {
- public:
- inline explicit Utf8String(v8::Local<v8::Value> from) :
- length_(0), str_(str_st_) {
- v8::HandleScope scope;
- if (!from.IsEmpty()) {
- v8::Local<v8::String> string = from->ToString();
- if (!string.IsEmpty()) {
- size_t len = 3 * string->Length() + 1;
- assert(len <= INT_MAX);
- if (len > sizeof (str_st_)) {
- str_ = static_cast<char*>(malloc(len));
- assert(str_ != 0);
- }
- const int flags =
- v8::String::NO_NULL_TERMINATION | imp::kReplaceInvalidUtf8;
- length_ = string->WriteUtf8(str_, static_cast<int>(len), 0, flags);
- str_[length_] = '\0';
- }
- }
- }
-
- inline int length() const {
- return length_;
- }
-
- inline char* operator*() { return str_; }
- inline const char* operator*() const { return str_; }
-
- inline ~Utf8String() {
- if (str_ != str_st_) {
- free(str_);
- }
- }
-
- private:
- NAN_DISALLOW_ASSIGN_COPY_MOVE(Utf8String)
-
- int length_;
- char *str_;
- char str_st_[1024];
- };
-
- #endif // NODE_MODULE_VERSION
-
- typedef void (*FreeCallback)(char *data, void *hint);
-
- typedef const FunctionCallbackInfo<v8::Value>& NAN_METHOD_ARGS_TYPE;
- typedef void NAN_METHOD_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Value>& NAN_GETTER_ARGS_TYPE;
- typedef void NAN_GETTER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<void>& NAN_SETTER_ARGS_TYPE;
- typedef void NAN_SETTER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Value>&
- NAN_PROPERTY_GETTER_ARGS_TYPE;
- typedef void NAN_PROPERTY_GETTER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Value>&
- NAN_PROPERTY_SETTER_ARGS_TYPE;
- typedef void NAN_PROPERTY_SETTER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Array>&
- NAN_PROPERTY_ENUMERATOR_ARGS_TYPE;
- typedef void NAN_PROPERTY_ENUMERATOR_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Boolean>&
- NAN_PROPERTY_DELETER_ARGS_TYPE;
- typedef void NAN_PROPERTY_DELETER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Integer>&
- NAN_PROPERTY_QUERY_ARGS_TYPE;
- typedef void NAN_PROPERTY_QUERY_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Value>& NAN_INDEX_GETTER_ARGS_TYPE;
- typedef void NAN_INDEX_GETTER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Value>& NAN_INDEX_SETTER_ARGS_TYPE;
- typedef void NAN_INDEX_SETTER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Array>&
- NAN_INDEX_ENUMERATOR_ARGS_TYPE;
- typedef void NAN_INDEX_ENUMERATOR_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Boolean>&
- NAN_INDEX_DELETER_ARGS_TYPE;
- typedef void NAN_INDEX_DELETER_RETURN_TYPE;
-
- typedef const PropertyCallbackInfo<v8::Integer>&
- NAN_INDEX_QUERY_ARGS_TYPE;
- typedef void NAN_INDEX_QUERY_RETURN_TYPE;
-
- #define NAN_METHOD(name) \
- Nan::NAN_METHOD_RETURN_TYPE name(Nan::NAN_METHOD_ARGS_TYPE info)
- #define NAN_GETTER(name) \
- Nan::NAN_GETTER_RETURN_TYPE name( \
- v8::Local<v8::String> property \
- , Nan::NAN_GETTER_ARGS_TYPE info)
- #define NAN_SETTER(name) \
- Nan::NAN_SETTER_RETURN_TYPE name( \
- v8::Local<v8::String> property \
- , v8::Local<v8::Value> value \
- , Nan::NAN_SETTER_ARGS_TYPE info)
- #define NAN_PROPERTY_GETTER(name) \
- Nan::NAN_PROPERTY_GETTER_RETURN_TYPE name( \
- v8::Local<v8::String> property \
- , Nan::NAN_PROPERTY_GETTER_ARGS_TYPE info)
- #define NAN_PROPERTY_SETTER(name) \
- Nan::NAN_PROPERTY_SETTER_RETURN_TYPE name( \
- v8::Local<v8::String> property \
- , v8::Local<v8::Value> value \
- , Nan::NAN_PROPERTY_SETTER_ARGS_TYPE info)
- #define NAN_PROPERTY_ENUMERATOR(name) \
- Nan::NAN_PROPERTY_ENUMERATOR_RETURN_TYPE name( \
- Nan::NAN_PROPERTY_ENUMERATOR_ARGS_TYPE info)
- #define NAN_PROPERTY_DELETER(name) \
- Nan::NAN_PROPERTY_DELETER_RETURN_TYPE name( \
- v8::Local<v8::String> property \
- , Nan::NAN_PROPERTY_DELETER_ARGS_TYPE info)
- #define NAN_PROPERTY_QUERY(name) \
- Nan::NAN_PROPERTY_QUERY_RETURN_TYPE name( \
- v8::Local<v8::String> property \
- , Nan::NAN_PROPERTY_QUERY_ARGS_TYPE info)
- # define NAN_INDEX_GETTER(name) \
- Nan::NAN_INDEX_GETTER_RETURN_TYPE name( \
- uint32_t index \
- , Nan::NAN_INDEX_GETTER_ARGS_TYPE info)
- #define NAN_INDEX_SETTER(name) \
- Nan::NAN_INDEX_SETTER_RETURN_TYPE name( \
- uint32_t index \
- , v8::Local<v8::Value> value \
- , Nan::NAN_INDEX_SETTER_ARGS_TYPE info)
- #define NAN_INDEX_ENUMERATOR(name) \
- Nan::NAN_INDEX_ENUMERATOR_RETURN_TYPE \
- name(Nan::NAN_INDEX_ENUMERATOR_ARGS_TYPE info)
- #define NAN_INDEX_DELETER(name) \
- Nan::NAN_INDEX_DELETER_RETURN_TYPE name( \
- uint32_t index \
- , Nan::NAN_INDEX_DELETER_ARGS_TYPE info)
- #define NAN_INDEX_QUERY(name) \
- Nan::NAN_INDEX_QUERY_RETURN_TYPE name( \
- uint32_t index \
- , Nan::NAN_INDEX_QUERY_ARGS_TYPE info)
-
- class Callback {
- public:
- Callback() {}
-
- explicit Callback(const v8::Local<v8::Function> &fn) : handle_(fn) {}
-
- ~Callback() {
- handle_.Reset();
- }
-
- bool operator==(const Callback &other) const {
- return handle_ == other.handle_;
- }
-
- bool operator!=(const Callback &other) const {
- return !operator==(other);
- }
-
- inline
- v8::Local<v8::Function> operator*() const { return GetFunction(); }
-
- NAN_DEPRECATED inline v8::Local<v8::Value> operator()(
- v8::Local<v8::Object> target
- , int argc = 0
- , v8::Local<v8::Value> argv[] = 0) const {
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- AsyncResource async("nan:Callback:operator()");
- return Call_(isolate, target, argc, argv, &async)
- .FromMaybe(v8::Local<v8::Value>());
- # else
- return Call_(isolate, target, argc, argv);
- # endif // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- #else
- return Call_(target, argc, argv);
- #endif // NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- }
-
- NAN_DEPRECATED inline v8::Local<v8::Value> operator()(
- int argc = 0
- , v8::Local<v8::Value> argv[] = 0) const {
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- AsyncResource async("nan:Callback:operator()");
- return scope.Escape(Call_(isolate, isolate->GetCurrentContext()->Global(),
- argc, argv, &async)
- .FromMaybe(v8::Local<v8::Value>()));
- # else
- return scope.Escape(
- Call_(isolate, isolate->GetCurrentContext()->Global(), argc, argv));
- # endif // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- #else
- v8::HandleScope scope;
- return scope.Close(Call_(v8::Context::GetCurrent()->Global(), argc, argv));
- #endif // NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- }
-
- inline MaybeLocal<v8::Value> operator()(
- AsyncResource* resource
- , int argc = 0
- , v8::Local<v8::Value> argv[] = 0) const {
- return this->Call(argc, argv, resource);
- }
-
- inline MaybeLocal<v8::Value> operator()(
- AsyncResource* resource
- , v8::Local<v8::Object> target
- , int argc = 0
- , v8::Local<v8::Value> argv[] = 0) const {
- return this->Call(target, argc, argv, resource);
- }
-
- // TODO(kkoopa): remove
- inline void SetFunction(const v8::Local<v8::Function> &fn) {
- Reset(fn);
- }
-
- inline void Reset(const v8::Local<v8::Function> &fn) {
- handle_.Reset(fn);
- }
-
- inline void Reset() {
- handle_.Reset();
- }
-
- inline v8::Local<v8::Function> GetFunction() const {
- return New(handle_);
- }
-
- inline bool IsEmpty() const {
- return handle_.IsEmpty();
- }
-
- // Deprecated: For async callbacks Use the versions that accept an
- // AsyncResource. If this callback does not correspond to an async resource,
- // that is, it is a synchronous function call on a non-empty JS stack, you
- // should Nan::Call instead.
- NAN_DEPRECATED inline v8::Local<v8::Value>
- Call(v8::Local<v8::Object> target
- , int argc
- , v8::Local<v8::Value> argv[]) const {
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- AsyncResource async("nan:Callback:Call");
- return Call_(isolate, target, argc, argv, &async)
- .FromMaybe(v8::Local<v8::Value>());
- # else
- return Call_(isolate, target, argc, argv);
- # endif // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- #else
- return Call_(target, argc, argv);
- #endif
- }
-
- // Deprecated: For async callbacks Use the versions that accept an
- // AsyncResource. If this callback does not correspond to an async resource,
- // that is, it is a synchronous function call on a non-empty JS stack, you
- // should Nan::Call instead.
- NAN_DEPRECATED inline v8::Local<v8::Value>
- Call(int argc, v8::Local<v8::Value> argv[]) const {
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- AsyncResource async("nan:Callback:Call");
- return scope.Escape(Call_(isolate, isolate->GetCurrentContext()->Global(),
- argc, argv, &async)
- .FromMaybe(v8::Local<v8::Value>()));
- # else
- return scope.Escape(
- Call_(isolate, isolate->GetCurrentContext()->Global(), argc, argv));
- # endif // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- #else
- v8::HandleScope scope;
- return scope.Close(Call_(v8::Context::GetCurrent()->Global(), argc, argv));
- #endif
- }
-
- inline MaybeLocal<v8::Value>
- Call(v8::Local<v8::Object> target
- , int argc
- , v8::Local<v8::Value> argv[]
- , AsyncResource* resource) const {
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- v8::Isolate* isolate = v8::Isolate::GetCurrent();
- return Call_(isolate, target, argc, argv, resource);
- #elif NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- return Call_(isolate, target, argc, argv);
- #else
- return Call_(target, argc, argv);
- #endif
- }
-
- inline MaybeLocal<v8::Value>
- Call(int argc, v8::Local<v8::Value> argv[], AsyncResource* resource) const {
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- v8::Isolate* isolate = v8::Isolate::GetCurrent();
- return Call(isolate->GetCurrentContext()->Global(), argc, argv, resource);
- #elif NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Isolate *isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- return scope.Escape(
- Call_(isolate, isolate->GetCurrentContext()->Global(), argc, argv));
- #else
- v8::HandleScope scope;
- return scope.Close(Call_(v8::Context::GetCurrent()->Global(), argc, argv));
- #endif
- }
-
- private:
- NAN_DISALLOW_ASSIGN_COPY_MOVE(Callback)
- Persistent<v8::Function> handle_;
-
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
- MaybeLocal<v8::Value> Call_(v8::Isolate *isolate
- , v8::Local<v8::Object> target
- , int argc
- , v8::Local<v8::Value> argv[]
- , AsyncResource* resource) const {
- EscapableHandleScope scope;
- v8::Local<v8::Function> func = New(handle_);
- auto maybe = resource->runInAsyncScope(target, func, argc, argv);
- v8::Local<v8::Value> local;
- if (!maybe.ToLocal(&local)) return MaybeLocal<v8::Value>();
- return scope.Escape(local);
- }
- #elif NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Local<v8::Value> Call_(v8::Isolate *isolate
- , v8::Local<v8::Object> target
- , int argc
- , v8::Local<v8::Value> argv[]) const {
- EscapableHandleScope scope;
-
- v8::Local<v8::Function> callback = New(handle_);
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
- return scope.Escape(New(node::MakeCallback(
- isolate
- , target
- , callback
- , argc
- , argv
- )));
- # else
- return scope.Escape(node::MakeCallback(
- isolate
- , target
- , callback
- , argc
- , argv
- ));
- # endif
- }
- #else
- v8::Local<v8::Value> Call_(v8::Local<v8::Object> target
- , int argc
- , v8::Local<v8::Value> argv[]) const {
- EscapableHandleScope scope;
-
- v8::Local<v8::Function> callback = New(handle_);
- return scope.Escape(New(node::MakeCallback(
- target
- , callback
- , argc
- , argv
- )));
- }
- #endif
- };
-
- inline MaybeLocal<v8::Value> Call(
- const Nan::Callback& callback
- , v8::Local<v8::Object> recv
- , int argc
- , v8::Local<v8::Value> argv[]) {
- return Call(*callback, recv, argc, argv);
- }
-
- inline MaybeLocal<v8::Value> Call(
- const Nan::Callback& callback
- , int argc
- , v8::Local<v8::Value> argv[]) {
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
- v8::Isolate* isolate = v8::Isolate::GetCurrent();
- v8::EscapableHandleScope scope(isolate);
- return scope.Escape(
- Call(*callback, isolate->GetCurrentContext()->Global(), argc, argv)
- .FromMaybe(v8::Local<v8::Value>()));
- #else
- EscapableHandleScope scope;
- return scope.Escape(
- Call(*callback, v8::Context::GetCurrent()->Global(), argc, argv)
- .FromMaybe(v8::Local<v8::Value>()));
- #endif
- }
-
- inline MaybeLocal<v8::Value> Call(
- v8::Local<v8::String> symbol
- , v8::Local<v8::Object> recv
- , int argc
- , v8::Local<v8::Value> argv[]) {
- EscapableHandleScope scope;
- v8::Local<v8::Value> fn_v =
- Get(recv, symbol).FromMaybe(v8::Local<v8::Value>());
- if (fn_v.IsEmpty() || !fn_v->IsFunction()) return v8::Local<v8::Value>();
- v8::Local<v8::Function> fn = fn_v.As<v8::Function>();
- return scope.Escape(
- Call(fn, recv, argc, argv).FromMaybe(v8::Local<v8::Value>()));
- }
-
- inline MaybeLocal<v8::Value> Call(
- const char* method
- , v8::Local<v8::Object> recv
- , int argc
- , v8::Local<v8::Value> argv[]) {
- EscapableHandleScope scope;
- v8::Local<v8::String> method_string =
- New<v8::String>(method).ToLocalChecked();
- return scope.Escape(
- Call(method_string, recv, argc, argv).FromMaybe(v8::Local<v8::Value>()));
- }
-
- /* abstract */ class AsyncWorker {
- public:
- explicit AsyncWorker(Callback *callback_,
- const char* resource_name = "nan:AsyncWorker")
- : callback(callback_), errmsg_(NULL) {
- request.data = this;
-
- HandleScope scope;
- v8::Local<v8::Object> obj = New<v8::Object>();
- persistentHandle.Reset(obj);
- async_resource = new AsyncResource(resource_name, obj);
- }
-
- virtual ~AsyncWorker() {
- HandleScope scope;
-
- if (!persistentHandle.IsEmpty())
- persistentHandle.Reset();
- delete callback;
- delete[] errmsg_;
- delete async_resource;
- }
-
- virtual void WorkComplete() {
- HandleScope scope;
-
- if (errmsg_ == NULL)
- HandleOKCallback();
- else
- HandleErrorCallback();
- delete callback;
- callback = NULL;
- }
-
- inline void SaveToPersistent(
- const char *key, const v8::Local<v8::Value> &value) {
- HandleScope scope;
- Set(New(persistentHandle), New(key).ToLocalChecked(), value).FromJust();
- }
-
- inline void SaveToPersistent(
- const v8::Local<v8::String> &key, const v8::Local<v8::Value> &value) {
- HandleScope scope;
- Set(New(persistentHandle), key, value).FromJust();
- }
-
- inline void SaveToPersistent(
- uint32_t index, const v8::Local<v8::Value> &value) {
- HandleScope scope;
- Set(New(persistentHandle), index, value).FromJust();
- }
-
- inline v8::Local<v8::Value> GetFromPersistent(const char *key) const {
- EscapableHandleScope scope;
- return scope.Escape(
- Get(New(persistentHandle), New(key).ToLocalChecked())
- .FromMaybe(v8::Local<v8::Value>()));
- }
-
- inline v8::Local<v8::Value>
- GetFromPersistent(const v8::Local<v8::String> &key) const {
- EscapableHandleScope scope;
- return scope.Escape(
- Get(New(persistentHandle), key)
- .FromMaybe(v8::Local<v8::Value>()));
- }
-
- inline v8::Local<v8::Value> GetFromPersistent(uint32_t index) const {
- EscapableHandleScope scope;
- return scope.Escape(
- Get(New(persistentHandle), index)
- .FromMaybe(v8::Local<v8::Value>()));
- }
-
- virtual void Execute() = 0;
-
- uv_work_t request;
-
- virtual void Destroy() {
- delete this;
- }
-
- protected:
- Persistent<v8::Object> persistentHandle;
- Callback *callback;
- AsyncResource *async_resource;
-
- virtual void HandleOKCallback() {
- HandleScope scope;
-
- callback->Call(0, NULL, async_resource);
- }
-
- virtual void HandleErrorCallback() {
- HandleScope scope;
-
- v8::Local<v8::Value> argv[] = {
- v8::Exception::Error(New<v8::String>(ErrorMessage()).ToLocalChecked())
- };
- callback->Call(1, argv, async_resource);
- }
-
- void SetErrorMessage(const char *msg) {
- delete[] errmsg_;
-
- size_t size = strlen(msg) + 1;
- errmsg_ = new char[size];
- memcpy(errmsg_, msg, size);
- }
-
- const char* ErrorMessage() const {
- return errmsg_;
- }
-
- private:
- NAN_DISALLOW_ASSIGN_COPY_MOVE(AsyncWorker)
- char *errmsg_;
- };
-
- /* abstract */ class AsyncBareProgressWorkerBase : public AsyncWorker {
- public:
- explicit AsyncBareProgressWorkerBase(
- Callback *callback_,
- const char* resource_name = "nan:AsyncBareProgressWorkerBase")
- : AsyncWorker(callback_, resource_name) {
- uv_async_init(
- GetCurrentEventLoop()
- , &async
- , AsyncProgress_
- );
- async.data = this;
- }
-
- virtual ~AsyncBareProgressWorkerBase() {
- }
-
- virtual void WorkProgress() = 0;
-
- virtual void Destroy() {
- uv_close(reinterpret_cast<uv_handle_t*>(&async), AsyncClose_);
- }
-
- private:
- inline static NAUV_WORK_CB(AsyncProgress_) {
- AsyncBareProgressWorkerBase *worker =
- static_cast<AsyncBareProgressWorkerBase*>(async->data);
- worker->WorkProgress();
- }
-
- inline static void AsyncClose_(uv_handle_t* handle) {
- AsyncBareProgressWorkerBase *worker =
- static_cast<AsyncBareProgressWorkerBase*>(handle->data);
- delete worker;
- }
-
- protected:
- uv_async_t async;
- };
-
- template<class T>
- /* abstract */
- class AsyncBareProgressWorker : public AsyncBareProgressWorkerBase {
- public:
- explicit AsyncBareProgressWorker(
- Callback *callback_,
- const char* resource_name = "nan:AsyncBareProgressWorker")
- : AsyncBareProgressWorkerBase(callback_, resource_name) {
- uv_mutex_init(&async_lock);
- }
-
- virtual ~AsyncBareProgressWorker() {
- uv_mutex_destroy(&async_lock);
- }
-
- class ExecutionProgress {
- friend class AsyncBareProgressWorker;
- public:
- void Signal() const {
- uv_mutex_lock(&that_->async_lock);
- uv_async_send(&that_->async);
- uv_mutex_unlock(&that_->async_lock);
- }
-
- void Send(const T* data, size_t count) const {
- that_->SendProgress_(data, count);
- }
-
- private:
- explicit ExecutionProgress(AsyncBareProgressWorker *that) : that_(that) {}
- NAN_DISALLOW_ASSIGN_COPY_MOVE(ExecutionProgress)
- AsyncBareProgressWorker* const that_;
- };
-
- virtual void Execute(const ExecutionProgress& progress) = 0;
- virtual void HandleProgressCallback(const T *data, size_t size) = 0;
-
- protected:
- uv_mutex_t async_lock;
-
- private:
- void Execute() /*final override*/ {
- ExecutionProgress progress(this);
- Execute(progress);
- }
-
- virtual void SendProgress_(const T *data, size_t count) = 0;
- };
-
- template<class T>
- /* abstract */
- class AsyncProgressWorkerBase : public AsyncBareProgressWorker<T> {
- public:
- explicit AsyncProgressWorkerBase(
- Callback *callback_,
- const char* resource_name = "nan:AsyncProgressWorkerBase")
- : AsyncBareProgressWorker<T>(callback_, resource_name), asyncdata_(NULL),
- asyncsize_(0) {
- }
-
- virtual ~AsyncProgressWorkerBase() {
- delete[] asyncdata_;
- }
-
- void WorkProgress() {
- uv_mutex_lock(&this->async_lock);
- T *data = asyncdata_;
- size_t size = asyncsize_;
- asyncdata_ = NULL;
- asyncsize_ = 0;
- uv_mutex_unlock(&this->async_lock);
-
- // Don't send progress events after we've already completed.
- if (this->callback) {
- this->HandleProgressCallback(data, size);
- }
- delete[] data;
- }
-
- private:
- void SendProgress_(const T *data, size_t count) {
- T *new_data = new T[count];
- {
- T *it = new_data;
- std::copy(data, data + count, it);
- }
-
- uv_mutex_lock(&this->async_lock);
- T *old_data = asyncdata_;
- asyncdata_ = new_data;
- asyncsize_ = count;
- uv_async_send(&this->async);
- uv_mutex_unlock(&this->async_lock);
-
- delete[] old_data;
- }
-
- T *asyncdata_;
- size_t asyncsize_;
- };
-
- // This ensures compatibility to the previous un-templated AsyncProgressWorker
- // class definition.
- typedef AsyncProgressWorkerBase<char> AsyncProgressWorker;
-
- template<class T>
- /* abstract */
- class AsyncBareProgressQueueWorker : public AsyncBareProgressWorkerBase {
- public:
- explicit AsyncBareProgressQueueWorker(
- Callback *callback_,
- const char* resource_name = "nan:AsyncBareProgressQueueWorker")
- : AsyncBareProgressWorkerBase(callback_, resource_name) {
- }
-
- virtual ~AsyncBareProgressQueueWorker() {
- }
-
- class ExecutionProgress {
- friend class AsyncBareProgressQueueWorker;
- public:
- void Send(const T* data, size_t count) const {
- that_->SendProgress_(data, count);
- }
-
- private:
- explicit ExecutionProgress(AsyncBareProgressQueueWorker *that)
- : that_(that) {}
- NAN_DISALLOW_ASSIGN_COPY_MOVE(ExecutionProgress)
- AsyncBareProgressQueueWorker* const that_;
- };
-
- virtual void Execute(const ExecutionProgress& progress) = 0;
- virtual void HandleProgressCallback(const T *data, size_t size) = 0;
-
- private:
- void Execute() /*final override*/ {
- ExecutionProgress progress(this);
- Execute(progress);
- }
-
- virtual void SendProgress_(const T *data, size_t count) = 0;
- };
-
- template<class T>
- /* abstract */
- class AsyncProgressQueueWorker : public AsyncBareProgressQueueWorker<T> {
- public:
- explicit AsyncProgressQueueWorker(
- Callback *callback_,
- const char* resource_name = "nan:AsyncProgressQueueWorker")
- : AsyncBareProgressQueueWorker<T>(callback_) {
- uv_mutex_init(&async_lock);
- }
-
- virtual ~AsyncProgressQueueWorker() {
- uv_mutex_lock(&async_lock);
-
- while (!asyncdata_.empty()) {
- std::pair<T*, size_t> &datapair = asyncdata_.front();
- T *data = datapair.first;
-
- asyncdata_.pop();
-
- delete[] data;
- }
-
- uv_mutex_unlock(&async_lock);
- uv_mutex_destroy(&async_lock);
- }
-
- void WorkComplete() {
- WorkProgress();
- AsyncWorker::WorkComplete();
- }
-
- void WorkProgress() {
- uv_mutex_lock(&async_lock);
-
- while (!asyncdata_.empty()) {
- std::pair<T*, size_t> &datapair = asyncdata_.front();
-
- T *data = datapair.first;
- size_t size = datapair.second;
-
- asyncdata_.pop();
- uv_mutex_unlock(&async_lock);
-
- // Don't send progress events after we've already completed.
- if (this->callback) {
- this->HandleProgressCallback(data, size);
- }
-
- delete[] data;
-
- uv_mutex_lock(&async_lock);
- }
-
- uv_mutex_unlock(&async_lock);
- }
-
- private:
- void SendProgress_(const T *data, size_t count) {
- T *new_data = new T[count];
- {
- T *it = new_data;
- std::copy(data, data + count, it);
- }
-
- uv_mutex_lock(&async_lock);
- asyncdata_.push(std::pair<T*, size_t>(new_data, count));
- uv_mutex_unlock(&async_lock);
-
- uv_async_send(&this->async);
- }
-
- uv_mutex_t async_lock;
- std::queue<std::pair<T*, size_t> > asyncdata_;
- };
-
- inline void AsyncExecute (uv_work_t* req) {
- AsyncWorker *worker = static_cast<AsyncWorker*>(req->data);
- worker->Execute();
- }
-
- inline void AsyncExecuteComplete (uv_work_t* req) {
- AsyncWorker* worker = static_cast<AsyncWorker*>(req->data);
- worker->WorkComplete();
- worker->Destroy();
- }
-
- inline void AsyncQueueWorker (AsyncWorker* worker) {
- uv_queue_work(
- GetCurrentEventLoop()
- , &worker->request
- , AsyncExecute
- , reinterpret_cast<uv_after_work_cb>(AsyncExecuteComplete)
- );
- }
-
- namespace imp {
-
- inline
- ExternalOneByteStringResource const*
- GetExternalResource(v8::Local<v8::String> str) {
- #if NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION
- return str->GetExternalAsciiStringResource();
- #else
- return str->GetExternalOneByteStringResource();
- #endif
- }
-
- inline
- bool
- IsExternal(v8::Local<v8::String> str) {
- #if NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION
- return str->IsExternalAscii();
- #else
- return str->IsExternalOneByte();
- #endif
- }
-
- } // end of namespace imp
-
- enum Encoding {ASCII, UTF8, BASE64, UCS2, BINARY, HEX, BUFFER};
-
- #if NODE_MODULE_VERSION < NODE_0_10_MODULE_VERSION
- # include "nan_string_bytes.h" // NOLINT(build/include)
- #endif
-
- inline v8::Local<v8::Value> Encode(
- const void *buf, size_t len, enum Encoding encoding = BINARY) {
- #if (NODE_MODULE_VERSION >= ATOM_0_21_MODULE_VERSION)
- v8::Isolate* isolate = v8::Isolate::GetCurrent();
- node::encoding node_enc = static_cast<node::encoding>(encoding);
-
- if (encoding == UCS2) {
- return node::Encode(
- isolate
- , reinterpret_cast<const uint16_t *>(buf)
- , len / 2);
- } else {
- return node::Encode(
- isolate
- , reinterpret_cast<const char *>(buf)
- , len
- , node_enc);
- }
- #elif (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
- return node::Encode(
- v8::Isolate::GetCurrent()
- , buf, len
- , static_cast<node::encoding>(encoding));
- #else
- # if NODE_MODULE_VERSION >= NODE_0_10_MODULE_VERSION
- return node::Encode(buf, len, static_cast<node::encoding>(encoding));
- # else
- return imp::Encode(reinterpret_cast<const char*>(buf), len, encoding);
- # endif
- #endif
- }
-
- inline ssize_t DecodeBytes(
- v8::Local<v8::Value> val, enum Encoding encoding = BINARY) {
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
- return node::DecodeBytes(
- v8::Isolate::GetCurrent()
- , val
- , static_cast<node::encoding>(encoding));
- #else
- # if (NODE_MODULE_VERSION < NODE_0_10_MODULE_VERSION)
- if (encoding == BUFFER) {
- return node::DecodeBytes(val, node::BINARY);
- }
- # endif
- return node::DecodeBytes(val, static_cast<node::encoding>(encoding));
- #endif
- }
-
- inline ssize_t DecodeWrite(
- char *buf
- , size_t len
- , v8::Local<v8::Value> val
- , enum Encoding encoding = BINARY) {
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
- return node::DecodeWrite(
- v8::Isolate::GetCurrent()
- , buf
- , len
- , val
- , static_cast<node::encoding>(encoding));
- #else
- # if (NODE_MODULE_VERSION < NODE_0_10_MODULE_VERSION)
- if (encoding == BUFFER) {
- return node::DecodeWrite(buf, len, val, node::BINARY);
- }
- # endif
- return node::DecodeWrite(
- buf
- , len
- , val
- , static_cast<node::encoding>(encoding));
- #endif
- }
-
- inline void SetPrototypeTemplate(
- v8::Local<v8::FunctionTemplate> templ
- , const char *name
- , v8::Local<v8::Data> value
- ) {
- HandleScope scope;
- SetTemplate(templ->PrototypeTemplate(), name, value);
- }
-
- inline void SetPrototypeTemplate(
- v8::Local<v8::FunctionTemplate> templ
- , v8::Local<v8::String> name
- , v8::Local<v8::Data> value
- , v8::PropertyAttribute attributes
- ) {
- HandleScope scope;
- SetTemplate(templ->PrototypeTemplate(), name, value, attributes);
- }
-
- inline void SetInstanceTemplate(
- v8::Local<v8::FunctionTemplate> templ
- , const char *name
- , v8::Local<v8::Data> value
- ) {
- HandleScope scope;
- SetTemplate(templ->InstanceTemplate(), name, value);
- }
-
- inline void SetInstanceTemplate(
- v8::Local<v8::FunctionTemplate> templ
- , v8::Local<v8::String> name
- , v8::Local<v8::Data> value
- , v8::PropertyAttribute attributes
- ) {
- HandleScope scope;
- SetTemplate(templ->InstanceTemplate(), name, value, attributes);
- }
-
- namespace imp {
-
- // Note(@agnat): Helper to distinguish different receiver types. The first
- // version deals with receivers derived from v8::Template. The second version
- // handles everything else. The final argument only serves as discriminator and
- // is unused.
- template <typename T>
- inline
- void
- SetMethodAux(T recv,
- v8::Local<v8::String> name,
- v8::Local<v8::FunctionTemplate> tpl,
- v8::Template *) {
- recv->Set(name, tpl);
- }
-
- template <typename T>
- inline
- void
- SetMethodAux(T recv,
- v8::Local<v8::String> name,
- v8::Local<v8::FunctionTemplate> tpl,
- ...) {
- Set(recv, name, GetFunction(tpl).ToLocalChecked());
- }
-
- } // end of namespace imp
-
- template <typename T, template <typename> class HandleType>
- inline void SetMethod(
- HandleType<T> recv
- , const char *name
- , FunctionCallback callback) {
- HandleScope scope;
- v8::Local<v8::FunctionTemplate> t = New<v8::FunctionTemplate>(callback);
- v8::Local<v8::String> fn_name = New(name).ToLocalChecked();
- t->SetClassName(fn_name);
- // Note(@agnat): Pass an empty T* as discriminator. See note on
- // SetMethodAux(...) above
- imp::SetMethodAux(recv, fn_name, t, static_cast<T*>(0));
- }
-
- inline void SetPrototypeMethod(
- v8::Local<v8::FunctionTemplate> recv
- , const char* name, FunctionCallback callback) {
- HandleScope scope;
- v8::Local<v8::FunctionTemplate> t = New<v8::FunctionTemplate>(
- callback
- , v8::Local<v8::Value>()
- , New<v8::Signature>(recv));
- v8::Local<v8::String> fn_name = New(name).ToLocalChecked();
- recv->PrototypeTemplate()->Set(fn_name, t);
- t->SetClassName(fn_name);
- }
-
- //=== Accessors and Such =======================================================
-
- inline void SetAccessor(
- v8::Local<v8::ObjectTemplate> tpl
- , v8::Local<v8::String> name
- , GetterCallback getter
- , SetterCallback setter = 0
- , v8::Local<v8::Value> data = v8::Local<v8::Value>()
- , v8::AccessControl settings = v8::DEFAULT
- , v8::PropertyAttribute attribute = v8::None
- , imp::Sig signature = imp::Sig()) {
- HandleScope scope;
-
- imp::NativeGetter getter_ =
- imp::GetterCallbackWrapper;
- imp::NativeSetter setter_ =
- setter ? imp::SetterCallbackWrapper : 0;
-
- v8::Local<v8::ObjectTemplate> otpl = New<v8::ObjectTemplate>();
- otpl->SetInternalFieldCount(imp::kAccessorFieldCount);
- v8::Local<v8::Object> obj = NewInstance(otpl).ToLocalChecked();
-
- obj->SetInternalField(
- imp::kGetterIndex
- , New<v8::External>(reinterpret_cast<void *>(getter)));
-
- if (setter != 0) {
- obj->SetInternalField(
- imp::kSetterIndex
- , New<v8::External>(reinterpret_cast<void *>(setter)));
- }
-
- if (!data.IsEmpty()) {
- obj->SetInternalField(imp::kDataIndex, data);
- }
-
- tpl->SetAccessor(
- name
- , getter_
- , setter_
- , obj
- , settings
- , attribute
- , signature);
- }
-
- inline bool SetAccessor(
- v8::Local<v8::Object> obj
- , v8::Local<v8::String> name
- , GetterCallback getter
- , SetterCallback setter = 0
- , v8::Local<v8::Value> data = v8::Local<v8::Value>()
- , v8::AccessControl settings = v8::DEFAULT
- , v8::PropertyAttribute attribute = v8::None) {
- HandleScope scope;
-
- imp::NativeGetter getter_ =
- imp::GetterCallbackWrapper;
- imp::NativeSetter setter_ =
- setter ? imp::SetterCallbackWrapper : 0;
-
- v8::Local<v8::ObjectTemplate> otpl = New<v8::ObjectTemplate>();
- otpl->SetInternalFieldCount(imp::kAccessorFieldCount);
- v8::Local<v8::Object> dataobj = NewInstance(otpl).ToLocalChecked();
-
- dataobj->SetInternalField(
- imp::kGetterIndex
- , New<v8::External>(reinterpret_cast<void *>(getter)));
-
- if (!data.IsEmpty()) {
- dataobj->SetInternalField(imp::kDataIndex, data);
- }
-
- if (setter) {
- dataobj->SetInternalField(
- imp::kSetterIndex
- , New<v8::External>(reinterpret_cast<void *>(setter)));
- }
-
- #if (NODE_MODULE_VERSION >= NODE_6_0_MODULE_VERSION)
- return obj->SetAccessor(
- GetCurrentContext()
- , name
- , getter_
- , setter_
- , dataobj
- , settings
- , attribute).FromMaybe(false);
- #else
- return obj->SetAccessor(
- name
- , getter_
- , setter_
- , dataobj
- , settings
- , attribute);
- #endif
- }
-
- inline void SetNamedPropertyHandler(
- v8::Local<v8::ObjectTemplate> tpl
- , PropertyGetterCallback getter
- , PropertySetterCallback setter = 0
- , PropertyQueryCallback query = 0
- , PropertyDeleterCallback deleter = 0
- , PropertyEnumeratorCallback enumerator = 0
- , v8::Local<v8::Value> data = v8::Local<v8::Value>()) {
- HandleScope scope;
-
- imp::NativePropertyGetter getter_ =
- imp::PropertyGetterCallbackWrapper;
- imp::NativePropertySetter setter_ =
- setter ? imp::PropertySetterCallbackWrapper : 0;
- imp::NativePropertyQuery query_ =
- query ? imp::PropertyQueryCallbackWrapper : 0;
- imp::NativePropertyDeleter *deleter_ =
- deleter ? imp::PropertyDeleterCallbackWrapper : 0;
- imp::NativePropertyEnumerator enumerator_ =
- enumerator ? imp::PropertyEnumeratorCallbackWrapper : 0;
-
- v8::Local<v8::ObjectTemplate> otpl = New<v8::ObjectTemplate>();
- otpl->SetInternalFieldCount(imp::kPropertyFieldCount);
- v8::Local<v8::Object> obj = NewInstance(otpl).ToLocalChecked();
- obj->SetInternalField(
- imp::kPropertyGetterIndex
- , New<v8::External>(reinterpret_cast<void *>(getter)));
-
- if (setter) {
- obj->SetInternalField(
- imp::kPropertySetterIndex
- , New<v8::External>(reinterpret_cast<void *>(setter)));
- }
-
- if (query) {
- obj->SetInternalField(
- imp::kPropertyQueryIndex
- , New<v8::External>(reinterpret_cast<void *>(query)));
- }
-
- if (deleter) {
- obj->SetInternalField(
- imp::kPropertyDeleterIndex
- , New<v8::External>(reinterpret_cast<void *>(deleter)));
- }
-
- if (enumerator) {
- obj->SetInternalField(
- imp::kPropertyEnumeratorIndex
- , New<v8::External>(reinterpret_cast<void *>(enumerator)));
- }
-
- if (!data.IsEmpty()) {
- obj->SetInternalField(imp::kDataIndex, data);
- }
-
- #if NODE_MODULE_VERSION > NODE_0_12_MODULE_VERSION
- tpl->SetHandler(v8::NamedPropertyHandlerConfiguration(
- getter_, setter_, query_, deleter_, enumerator_, obj));
- #else
- tpl->SetNamedPropertyHandler(
- getter_
- , setter_
- , query_
- , deleter_
- , enumerator_
- , obj);
- #endif
- }
-
- inline void SetIndexedPropertyHandler(
- v8::Local<v8::ObjectTemplate> tpl
- , IndexGetterCallback getter
- , IndexSetterCallback setter = 0
- , IndexQueryCallback query = 0
- , IndexDeleterCallback deleter = 0
- , IndexEnumeratorCallback enumerator = 0
- , v8::Local<v8::Value> data = v8::Local<v8::Value>()) {
- HandleScope scope;
-
- imp::NativeIndexGetter getter_ =
- imp::IndexGetterCallbackWrapper;
- imp::NativeIndexSetter setter_ =
- setter ? imp::IndexSetterCallbackWrapper : 0;
- imp::NativeIndexQuery query_ =
- query ? imp::IndexQueryCallbackWrapper : 0;
- imp::NativeIndexDeleter deleter_ =
- deleter ? imp::IndexDeleterCallbackWrapper : 0;
- imp::NativeIndexEnumerator enumerator_ =
- enumerator ? imp::IndexEnumeratorCallbackWrapper : 0;
-
- v8::Local<v8::ObjectTemplate> otpl = New<v8::ObjectTemplate>();
- otpl->SetInternalFieldCount(imp::kIndexPropertyFieldCount);
- v8::Local<v8::Object> obj = NewInstance(otpl).ToLocalChecked();
- obj->SetInternalField(
- imp::kIndexPropertyGetterIndex
- , New<v8::External>(reinterpret_cast<void *>(getter)));
-
- if (setter) {
- obj->SetInternalField(
- imp::kIndexPropertySetterIndex
- , New<v8::External>(reinterpret_cast<void *>(setter)));
- }
-
- if (query) {
- obj->SetInternalField(
- imp::kIndexPropertyQueryIndex
- , New<v8::External>(reinterpret_cast<void *>(query)));
- }
-
- if (deleter) {
- obj->SetInternalField(
- imp::kIndexPropertyDeleterIndex
- , New<v8::External>(reinterpret_cast<void *>(deleter)));
- }
-
- if (enumerator) {
- obj->SetInternalField(
- imp::kIndexPropertyEnumeratorIndex
- , New<v8::External>(reinterpret_cast<void *>(enumerator)));
- }
-
- if (!data.IsEmpty()) {
- obj->SetInternalField(imp::kDataIndex, data);
- }
-
- #if NODE_MODULE_VERSION > NODE_0_12_MODULE_VERSION
- tpl->SetHandler(v8::IndexedPropertyHandlerConfiguration(
- getter_, setter_, query_, deleter_, enumerator_, obj));
- #else
- tpl->SetIndexedPropertyHandler(
- getter_
- , setter_
- , query_
- , deleter_
- , enumerator_
- , obj);
- #endif
- }
-
- inline void SetCallHandler(
- v8::Local<v8::FunctionTemplate> tpl
- , FunctionCallback callback
- , v8::Local<v8::Value> data = v8::Local<v8::Value>()) {
- HandleScope scope;
-
- v8::Local<v8::ObjectTemplate> otpl = New<v8::ObjectTemplate>();
- otpl->SetInternalFieldCount(imp::kFunctionFieldCount);
- v8::Local<v8::Object> obj = NewInstance(otpl).ToLocalChecked();
-
- obj->SetInternalField(
- imp::kFunctionIndex
- , New<v8::External>(reinterpret_cast<void *>(callback)));
-
- if (!data.IsEmpty()) {
- obj->SetInternalField(imp::kDataIndex, data);
- }
-
- tpl->SetCallHandler(imp::FunctionCallbackWrapper, obj);
- }
-
-
- inline void SetCallAsFunctionHandler(
- v8::Local<v8::ObjectTemplate> tpl,
- FunctionCallback callback,
- v8::Local<v8::Value> data = v8::Local<v8::Value>()) {
- HandleScope scope;
-
- v8::Local<v8::ObjectTemplate> otpl = New<v8::ObjectTemplate>();
- otpl->SetInternalFieldCount(imp::kFunctionFieldCount);
- v8::Local<v8::Object> obj = NewInstance(otpl).ToLocalChecked();
-
- obj->SetInternalField(
- imp::kFunctionIndex
- , New<v8::External>(reinterpret_cast<void *>(callback)));
-
- if (!data.IsEmpty()) {
- obj->SetInternalField(imp::kDataIndex, data);
- }
-
- tpl->SetCallAsFunctionHandler(imp::FunctionCallbackWrapper, obj);
- }
-
- //=== Weak Persistent Handling =================================================
-
- #include "nan_weak.h" // NOLINT(build/include)
-
- //=== ObjectWrap ===============================================================
-
- #include "nan_object_wrap.h" // NOLINT(build/include)
-
- //=== HiddenValue/Private ======================================================
-
- #include "nan_private.h" // NOLINT(build/include)
-
- //=== Export ==================================================================
-
- inline
- void
- Export(ADDON_REGISTER_FUNCTION_ARGS_TYPE target, const char *name,
- FunctionCallback f) {
- HandleScope scope;
-
- Set(target, New<v8::String>(name).ToLocalChecked(),
- GetFunction(New<v8::FunctionTemplate>(f)).ToLocalChecked());
- }
-
- //=== Tap Reverse Binding =====================================================
-
- struct Tap {
- explicit Tap(v8::Local<v8::Value> t) : t_() {
- HandleScope scope;
-
- t_.Reset(To<v8::Object>(t).ToLocalChecked());
- }
-
- ~Tap() { t_.Reset(); } // not sure if neccessary
-
- inline void plan(int i) {
- HandleScope scope;
- v8::Local<v8::Value> arg = New(i);
- Call("plan", New(t_), 1, &arg);
- }
-
- inline void ok(bool isOk, const char *msg = NULL) {
- HandleScope scope;
- v8::Local<v8::Value> args[2];
- args[0] = New(isOk);
- if (msg) args[1] = New(msg).ToLocalChecked();
- Call("ok", New(t_), msg ? 2 : 1, args);
- }
-
- inline void pass(const char * msg = NULL) {
- HandleScope scope;
- v8::Local<v8::Value> hmsg;
- if (msg) hmsg = New(msg).ToLocalChecked();
- Call("pass", New(t_), msg ? 1 : 0, &hmsg);
- }
-
- inline void end() {
- HandleScope scope;
- Call("end", New(t_), 0, NULL);
- }
-
- private:
- Persistent<v8::Object> t_;
- };
-
- #define NAN_STRINGIZE2(x) #x
- #define NAN_STRINGIZE(x) NAN_STRINGIZE2(x)
- #define NAN_TEST_EXPRESSION(expression) \
- ( expression ), __FILE__ ":" NAN_STRINGIZE(__LINE__) ": " #expression
-
- #define NAN_EXPORT(target, function) Export(target, #function, function)
-
- #undef TYPE_CHECK
-
- //=== Generic Maybefication ===================================================
-
- namespace imp {
-
- template <typename T> struct Maybefier;
-
- template <typename T> struct Maybefier<v8::Local<T> > {
- inline static MaybeLocal<T> convert(v8::Local<T> v) {
- return v;
- }
- };
-
- template <typename T> struct Maybefier<MaybeLocal<T> > {
- inline static MaybeLocal<T> convert(MaybeLocal<T> v) {
- return v;
- }
- };
-
- } // end of namespace imp
-
- template <typename T, template <typename> class MaybeMaybe>
- inline MaybeLocal<T>
- MakeMaybe(MaybeMaybe<T> v) {
- return imp::Maybefier<MaybeMaybe<T> >::convert(v);
- }
-
- //=== TypedArrayContents =======================================================
-
- #include "nan_typedarray_contents.h" // NOLINT(build/include)
-
- //=== JSON =====================================================================
-
- #include "nan_json.h" // NOLINT(build/include)
-
- } // end of namespace Nan
-
- #endif // NAN_H_
|