| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952 | /********************************************************************* * 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.17.0: current Node 18.10.0, Node 0.12: 0.12.18, Node 0.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#define NODE_13_0_MODULE_VERSION 79#define NODE_14_0_MODULE_VERSION 83#define NODE_15_0_MODULE_VERSION 88#define NODE_16_0_MODULE_VERSION 93#define NODE_17_0_MODULE_VERSION 102#define NODE_18_0_MODULE_VERSION 108#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#endifnamespace 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;#elsetypedef v8::UnboundScript      UnboundScript;typedef v8::Script             BoundScript;#endif#if (NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION)typedef v8::String::ExternalAsciiStringResource    ExternalOneByteStringResource;#elsetypedef 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;#elsetemplate<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_VERSIONtemplate<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 >= 0x000b0btypedef 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 WIN32typedef 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();}#elsetypedef 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_VERSIONtemplate<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;#elsestruct 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); }};#endiftemplate<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)#endifnamespace 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 voidwidenString(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_VERSIONtypedef 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];    std::copy(data, data + count, new_data);    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];    std::copy(data, data + count, new_data);    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();}/* uv_after_work_cb has 1 argument before node-v0.9.4 and * 2 arguments since node-v0.9.4 * https://github.com/libuv/libuv/commit/92fb84b751e18f032c02609467f44bfe927b80c5 */inline void AsyncExecuteComplete(uv_work_t *req) {  AsyncWorker* worker = static_cast<AsyncWorker*>(req->data);  worker->WorkComplete();  worker->Destroy();}inline void AsyncExecuteComplete (uv_work_t* req, int status) {  AsyncExecuteComplete(req);}inline void AsyncQueueWorker (AsyncWorker* worker) {  uv_queue_work(      GetCurrentEventLoop()    , &worker->request    , AsyncExecute    , AsyncExecuteComplete  );}namespace imp {inlineExternalOneByteStringResource const*GetExternalResource(v8::Local<v8::String> str) {#if NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION    return str->GetExternalAsciiStringResource();#else    return str->GetExternalOneByteStringResource();#endif}inlineboolIsExternal(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 impenum 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)#endifinline 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>inlinevoidSetMethodAux(T recv,             v8::Local<v8::String> name,             v8::Local<v8::FunctionTemplate> tpl,             v8::Template *) {  recv->Set(name, tpl);}template <typename T>inlinevoidSetMethodAux(T recv,             v8::Local<v8::String> name,             v8::Local<v8::FunctionTemplate> tpl,             ...) {  Set(recv, name, GetFunction(tpl).ToLocalChecked());}}  // end of namespace imptemplate <typename T, template <typename> class HandleType>inline void SetMethod(    HandleType<T> recv  , const char *name  , FunctionCallback callback  , v8::Local<v8::Value> data = v8::Local<v8::Value>()) {  HandleScope scope;  v8::Local<v8::FunctionTemplate> t = New<v8::FunctionTemplate>(callback, data);  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  , v8::Local<v8::Value> data = v8::Local<v8::Value>()) {  HandleScope scope;  v8::Local<v8::FunctionTemplate> t = New<v8::FunctionTemplate>(      callback    , data    , 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 =======================================================NAN_DEPRECATED inline void SetAccessor(    v8::Local<v8::ObjectTemplate> tpl  , v8::Local<v8::String> name  , GetterCallback getter  , SetterCallback setter  , v8::Local<v8::Value> data  , v8::AccessControl settings  , v8::PropertyAttribute attribute  , imp::Sig signature) {  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#if (NODE_MODULE_VERSION < NODE_16_0_MODULE_VERSION)    , signature#endif  );}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) {  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  );}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 ==================================================================inlinevoidExport(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 necessary  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 imptemplate <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)//=== ScriptOrigin =============================================================#include "nan_scriptorigin.h"  // NOLINT(build/include)}  // end of namespace Nan#endif  // NAN_H_
 |