| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053 | 
							- /*********************************************************************
 
-  * 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.23.0: current Node 24.4.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
 
- #define NODE_19_0_MODULE_VERSION 111
 
- #define NODE_20_0_MODULE_VERSION 115
 
- #ifdef _MSC_VER
 
- # define NAN_HAS_CPLUSPLUS_11 (_MSC_VER >= 1800)
 
- #else
 
- # define NAN_HAS_CPLUSPLUS_11 (__cplusplus >= 201103L)
 
- #endif
 
- #if NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION && !NAN_HAS_CPLUSPLUS_11
 
- # error This version of node/NAN/v8 requires a C++11 compiler
 
- #endif
 
- #include <uv.h>
 
- #include <node.h>
 
- #include <node_buffer.h>
 
- #include <node_object_wrap.h>
 
- #include <algorithm>
 
- #include <cstring>
 
- #include <climits>
 
- #include <cstdlib>
 
- #include <utility>
 
- #if defined(_MSC_VER)
 
- # pragma warning( push )
 
- # pragma warning( disable : 4530 )
 
- # include <queue>
 
- # include <string>
 
- # include <vector>
 
- # pragma warning( pop )
 
- #else
 
- # include <queue>
 
- # include <string>
 
- # include <vector>
 
- #endif
 
- // uv helpers
 
- #ifdef UV_VERSION_MAJOR
 
- # ifndef UV_VERSION_PATCH
 
- #  define UV_VERSION_PATCH 0
 
- # endif
 
- # define NAUV_UVVERSION ((UV_VERSION_MAJOR << 16) | \
 
-                          (UV_VERSION_MINOR <<  8) | \
 
-                          (UV_VERSION_PATCH))
 
- #else
 
- # define NAUV_UVVERSION 0x000b00
 
- #endif
 
- #if NAUV_UVVERSION < 0x000b0b
 
- # ifdef WIN32
 
- #  include <windows.h>
 
- # else
 
- #  include <pthread.h>
 
- # endif
 
- #endif
 
- namespace Nan {
 
- #define NAN_CONCAT(a, b) NAN_CONCAT_HELPER(a, b)
 
- #define NAN_CONCAT_HELPER(a, b) a##b
 
- #define NAN_INLINE inline  // TODO(bnoordhuis) Remove in v3.0.0.
 
- #if defined(__GNUC__) && \
 
-     !(defined(V8_DISABLE_DEPRECATIONS) && V8_DISABLE_DEPRECATIONS)
 
- # define NAN_DEPRECATED __attribute__((deprecated))
 
- #elif defined(_MSC_VER) && \
 
-     !(defined(V8_DISABLE_DEPRECATIONS) && V8_DISABLE_DEPRECATIONS)
 
- # define NAN_DEPRECATED __declspec(deprecated)
 
- #else
 
- # define NAN_DEPRECATED
 
- #endif
 
- #if NAN_HAS_CPLUSPLUS_11
 
- # define NAN_DISALLOW_ASSIGN(CLASS) void operator=(const CLASS&) = delete;
 
- # define NAN_DISALLOW_COPY(CLASS) CLASS(const CLASS&) = delete;
 
- # define NAN_DISALLOW_MOVE(CLASS)                                              \
 
-     CLASS(CLASS&&) = delete;  /* NOLINT(build/c++11) */                        \
 
-     void operator=(CLASS&&) = delete;
 
- #else
 
- # define NAN_DISALLOW_ASSIGN(CLASS) void operator=(const CLASS&);
 
- # define NAN_DISALLOW_COPY(CLASS) CLASS(const CLASS&);
 
- # define NAN_DISALLOW_MOVE(CLASS)
 
- #endif
 
- #define NAN_DISALLOW_ASSIGN_COPY(CLASS)                                        \
 
-     NAN_DISALLOW_ASSIGN(CLASS)                                                 \
 
-     NAN_DISALLOW_COPY(CLASS)
 
- #define NAN_DISALLOW_ASSIGN_MOVE(CLASS)                                        \
 
-     NAN_DISALLOW_ASSIGN(CLASS)                                                 \
 
-     NAN_DISALLOW_MOVE(CLASS)
 
- #define NAN_DISALLOW_COPY_MOVE(CLASS)                                          \
 
-     NAN_DISALLOW_COPY(CLASS)                                                   \
 
-     NAN_DISALLOW_MOVE(CLASS)
 
- #define NAN_DISALLOW_ASSIGN_COPY_MOVE(CLASS)                                   \
 
-     NAN_DISALLOW_ASSIGN(CLASS)                                                 \
 
-     NAN_DISALLOW_COPY(CLASS)                                                   \
 
-     NAN_DISALLOW_MOVE(CLASS)
 
- #define TYPE_CHECK(T, S)                                                       \
 
-     while (false) {                                                            \
 
-       *(static_cast<T *volatile *>(0)) = static_cast<S*>(0);                   \
 
-     }
 
- //=== RegistrationFunction =====================================================
 
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-   typedef v8::Handle<v8::Object> ADDON_REGISTER_FUNCTION_ARGS_TYPE;
 
- #else
 
-   typedef v8::Local<v8::Object> ADDON_REGISTER_FUNCTION_ARGS_TYPE;
 
- #endif
 
- #define NAN_MODULE_INIT(name)                                                  \
 
-     void name(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE target)
 
- #if NODE_MAJOR_VERSION >= 10 || \
 
-     NODE_MAJOR_VERSION == 9 && NODE_MINOR_VERSION >= 3
 
- #define NAN_MODULE_WORKER_ENABLED(module_name, registration)                   \
 
-     extern "C" NODE_MODULE_EXPORT void                                         \
 
-       NAN_CONCAT(node_register_module_v, NODE_MODULE_VERSION)(                 \
 
-         v8::Local<v8::Object> exports, v8::Local<v8::Value> module,            \
 
-         v8::Local<v8::Context> context)                                        \
 
-     {                                                                          \
 
-         registration(exports);                                                 \
 
-     }
 
- #else
 
- #define NAN_MODULE_WORKER_ENABLED(module_name, registration)                   \
 
-     NODE_MODULE(module_name, registration)
 
- #endif
 
- //=== CallbackInfo =============================================================
 
- #include "nan_callbacks.h"  // NOLINT(build/include_subdir)
 
- //==============================================================================
 
- #if (NODE_MODULE_VERSION < NODE_0_12_MODULE_VERSION)
 
- typedef v8::Script             UnboundScript;
 
- typedef v8::Script             BoundScript;
 
- #else
 
- typedef v8::UnboundScript      UnboundScript;
 
- typedef v8::Script             BoundScript;
 
- #endif
 
- #if (NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION)
 
- typedef v8::String::ExternalAsciiStringResource
 
-     ExternalOneByteStringResource;
 
- #else
 
- typedef v8::String::ExternalOneByteStringResource
 
-     ExternalOneByteStringResource;
 
- #endif
 
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
 
- template<typename T>
 
- class NonCopyablePersistentTraits :
 
-     public v8::NonCopyablePersistentTraits<T> {};
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 10 ||                     \
 
-   (V8_MAJOR_VERSION == 10 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 5))
 
- template<typename T> struct CopyablePersistentTraits {
 
-   typedef v8::Persistent<T, CopyablePersistentTraits<T> > CopyablePersistent;
 
-   static const bool kResetInDestructor = true;
 
-   template <typename S, typename M>
 
-   static NAN_INLINE void Copy(const v8::Persistent<S, M> &source,
 
-       CopyablePersistent *dest) {
 
-   }
 
- };
 
- #else
 
- template<typename T>
 
- class CopyablePersistentTraits :
 
-     public v8::CopyablePersistentTraits<T> {};
 
- #endif
 
- template<typename T>
 
- class PersistentBase :
 
-     public v8::PersistentBase<T> {};
 
- template<typename T, typename M = v8::NonCopyablePersistentTraits<T> >
 
- class Persistent;
 
- #else
 
- template<typename T> class NonCopyablePersistentTraits;
 
- template<typename T> class PersistentBase;
 
- template<typename T, typename P> class WeakCallbackData;
 
- template<typename T, typename M = NonCopyablePersistentTraits<T> >
 
- class Persistent;
 
- #endif  // NODE_MODULE_VERSION
 
- template<typename T>
 
- class Maybe {
 
-  public:
 
-   inline bool IsNothing() const { return !has_value_; }
 
-   inline bool IsJust() const { return has_value_; }
 
-   inline T ToChecked() const { return FromJust(); }
 
-   inline void Check() const { FromJust(); }
 
-   inline bool To(T* out) const {
 
-     if (IsJust()) *out = value_;
 
-     return IsJust();
 
-   }
 
-   inline T FromJust() const {
 
- #if defined(V8_ENABLE_CHECKS)
 
-     assert(IsJust() && "FromJust is Nothing");
 
- #endif  // V8_ENABLE_CHECKS
 
-     return value_;
 
-   }
 
-   inline T FromMaybe(const T& default_value) const {
 
-     return has_value_ ? value_ : default_value;
 
-   }
 
-   inline bool operator==(const Maybe &other) const {
 
-     return (IsJust() == other.IsJust()) &&
 
-         (!IsJust() || FromJust() == other.FromJust());
 
-   }
 
-   inline bool operator!=(const Maybe &other) const {
 
-     return !operator==(other);
 
-   }
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 ||                      \
 
-   (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
 
-   // Allow implicit conversions from v8::Maybe<T> to Nan::Maybe<T>.
 
-   Maybe(const v8::Maybe<T>& that)  // NOLINT(runtime/explicit)
 
-     : has_value_(that.IsJust())
 
-     , value_(that.FromMaybe(T())) {}
 
- #endif
 
-  private:
 
-   Maybe() : has_value_(false) {}
 
-   explicit Maybe(const T& t) : has_value_(true), value_(t) {}
 
-   bool has_value_;
 
-   T value_;
 
-   template<typename U>
 
-   friend Maybe<U> Nothing();
 
-   template<typename U>
 
-   friend Maybe<U> Just(const U& u);
 
- };
 
- template<typename T>
 
- inline Maybe<T> Nothing() {
 
-   return Maybe<T>();
 
- }
 
- template<typename T>
 
- inline Maybe<T> Just(const T& t) {
 
-   return Maybe<T>(t);
 
- }
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 ||                      \
 
-   (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
 
- # include "nan_maybe_43_inl.h"  // NOLINT(build/include)
 
- #else
 
- # include "nan_maybe_pre_43_inl.h"  // NOLINT(build/include)
 
- #endif
 
- #include "nan_converters.h"  // NOLINT(build/include_subdir)
 
- #include "nan_new.h"  // NOLINT(build/include_subdir)
 
- #if NAUV_UVVERSION < 0x000b17
 
- #define NAUV_WORK_CB(func) \
 
-     void func(uv_async_t *async, int)
 
- #else
 
- #define NAUV_WORK_CB(func) \
 
-     void func(uv_async_t *async)
 
- #endif
 
- #if NAUV_UVVERSION >= 0x000b0b
 
- typedef uv_key_t nauv_key_t;
 
- inline int nauv_key_create(nauv_key_t *key) {
 
-   return uv_key_create(key);
 
- }
 
- inline void nauv_key_delete(nauv_key_t *key) {
 
-   uv_key_delete(key);
 
- }
 
- inline void* nauv_key_get(nauv_key_t *key) {
 
-   return uv_key_get(key);
 
- }
 
- inline void nauv_key_set(nauv_key_t *key, void *value) {
 
-   uv_key_set(key, value);
 
- }
 
- #else
 
- /* Implement thread local storage for older versions of libuv.
 
-  * This is essentially a backport of libuv commit 5d2434bf
 
-  * written by Ben Noordhuis, adjusted for names and inline.
 
-  */
 
- #ifndef WIN32
 
- typedef pthread_key_t nauv_key_t;
 
- inline int nauv_key_create(nauv_key_t* key) {
 
-   return -pthread_key_create(key, NULL);
 
- }
 
- inline void nauv_key_delete(nauv_key_t* key) {
 
-   if (pthread_key_delete(*key))
 
-     abort();
 
- }
 
- inline void* nauv_key_get(nauv_key_t* key) {
 
-   return pthread_getspecific(*key);
 
- }
 
- inline void nauv_key_set(nauv_key_t* key, void* value) {
 
-   if (pthread_setspecific(*key, value))
 
-     abort();
 
- }
 
- #else
 
- typedef struct {
 
-   DWORD tls_index;
 
- } nauv_key_t;
 
- inline int nauv_key_create(nauv_key_t* key) {
 
-   key->tls_index = TlsAlloc();
 
-   if (key->tls_index == TLS_OUT_OF_INDEXES)
 
-     return UV_ENOMEM;
 
-   return 0;
 
- }
 
- inline void nauv_key_delete(nauv_key_t* key) {
 
-   if (TlsFree(key->tls_index) == FALSE)
 
-     abort();
 
-   key->tls_index = TLS_OUT_OF_INDEXES;
 
- }
 
- inline void* nauv_key_get(nauv_key_t* key) {
 
-   void* value = TlsGetValue(key->tls_index);
 
-   if (value == NULL)
 
-     if (GetLastError() != ERROR_SUCCESS)
 
-       abort();
 
-   return value;
 
- }
 
- inline void nauv_key_set(nauv_key_t* key, void* value) {
 
-   if (TlsSetValue(key->tls_index, value) == FALSE)
 
-     abort();
 
- }
 
- #endif
 
- #endif
 
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
- template<typename T>
 
- v8::Local<T> New(v8::Handle<T>);
 
- #endif
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 ||                      \
 
-   (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
 
-   typedef v8::WeakCallbackType WeakCallbackType;
 
- #else
 
- struct WeakCallbackType {
 
-   enum E {kParameter, kInternalFields};
 
-   E type;
 
-   WeakCallbackType(E other) : type(other) {}  // NOLINT(runtime/explicit)
 
-   inline bool operator==(E other) { return other == this->type; }
 
-   inline bool operator!=(E other) { return !operator==(other); }
 
- };
 
- #endif
 
- template<typename P> class WeakCallbackInfo;
 
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
 
- # include "nan_persistent_12_inl.h"  // NOLINT(build/include)
 
- #else
 
- # include "nan_persistent_pre_12_inl.h"  // NOLINT(build/include)
 
- #endif
 
- namespace imp {
 
-   static const size_t kMaxLength = 0x3fffffff;
 
-   // v8::String::REPLACE_INVALID_UTF8 was introduced
 
-   // in node.js v0.10.29 and v0.8.27.
 
- #if NODE_MAJOR_VERSION > 0 || \
 
-     NODE_MINOR_VERSION > 10 || \
 
-     NODE_MINOR_VERSION == 10 && NODE_PATCH_VERSION >= 29 || \
 
-     NODE_MINOR_VERSION == 8 && NODE_PATCH_VERSION >= 27
 
-   static const unsigned kReplaceInvalidUtf8 = v8::String::REPLACE_INVALID_UTF8;
 
- #else
 
-   static const unsigned kReplaceInvalidUtf8 = 0;
 
- #endif
 
- }  // end of namespace imp
 
- //=== HandleScope ==============================================================
 
- class HandleScope {
 
-   v8::HandleScope scope;
 
-  public:
 
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
 
-   inline HandleScope() : scope(v8::Isolate::GetCurrent()) {}
 
-   inline static int NumberOfHandles() {
 
-     return v8::HandleScope::NumberOfHandles(v8::Isolate::GetCurrent());
 
-   }
 
- #else
 
-   inline HandleScope() : scope() {}
 
-   inline static int NumberOfHandles() {
 
-     return v8::HandleScope::NumberOfHandles();
 
-   }
 
- #endif
 
-  private:
 
-   // Make it hard to create heap-allocated or illegal handle scopes by
 
-   // disallowing certain operations.
 
-   HandleScope(const HandleScope &);
 
-   void operator=(const HandleScope &);
 
-   void *operator new(size_t size);
 
-   void operator delete(void *, size_t) {
 
-     abort();
 
-   }
 
- };
 
- class EscapableHandleScope {
 
-  public:
 
- #if NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION
 
-   inline EscapableHandleScope() : scope(v8::Isolate::GetCurrent()) {}
 
-   inline static int NumberOfHandles() {
 
-     return v8::EscapableHandleScope::NumberOfHandles(v8::Isolate::GetCurrent());
 
-   }
 
-   template<typename T>
 
-   inline v8::Local<T> Escape(v8::Local<T> value) {
 
-     return scope.Escape(value);
 
-   }
 
-  private:
 
-   v8::EscapableHandleScope scope;
 
- #else
 
-   inline EscapableHandleScope() : scope() {}
 
-   inline static int NumberOfHandles() {
 
-     return v8::HandleScope::NumberOfHandles();
 
-   }
 
-   template<typename T>
 
-   inline v8::Local<T> Escape(v8::Local<T> value) {
 
-     return scope.Close(value);
 
-   }
 
-  private:
 
-   v8::HandleScope scope;
 
- #endif
 
-  private:
 
-   // Make it hard to create heap-allocated or illegal handle scopes by
 
-   // disallowing certain operations.
 
-   EscapableHandleScope(const EscapableHandleScope &);
 
-   void operator=(const EscapableHandleScope &);
 
-   void *operator new(size_t size);
 
-   void operator delete(void *, size_t) {
 
-     abort();
 
-   }
 
- };
 
- //=== TryCatch =================================================================
 
- class TryCatch {
 
-   v8::TryCatch try_catch_;
 
-   friend void FatalException(const TryCatch&);
 
-  public:
 
- #if NODE_MODULE_VERSION > NODE_0_12_MODULE_VERSION
 
-   TryCatch() : try_catch_(v8::Isolate::GetCurrent()) {}
 
- #endif
 
-   inline bool HasCaught() const { return try_catch_.HasCaught(); }
 
-   inline bool CanContinue() const { return try_catch_.CanContinue(); }
 
-   inline v8::Local<v8::Value> ReThrow() {
 
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     return New(try_catch_.ReThrow());
 
- #else
 
-     return try_catch_.ReThrow();
 
- #endif
 
-   }
 
-   inline v8::Local<v8::Value> Exception() const {
 
-     return try_catch_.Exception();
 
-   }
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 ||                      \
 
-   (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
 
-   inline v8::MaybeLocal<v8::Value> StackTrace() const {
 
-     v8::Isolate *isolate = v8::Isolate::GetCurrent();
 
-     v8::EscapableHandleScope scope(isolate);
 
-     return scope.Escape(try_catch_.StackTrace(isolate->GetCurrentContext())
 
-                             .FromMaybe(v8::Local<v8::Value>()));
 
-   }
 
- #else
 
-   inline MaybeLocal<v8::Value> StackTrace() const {
 
-     return try_catch_.StackTrace();
 
-   }
 
- #endif
 
-   inline v8::Local<v8::Message> Message() const {
 
-     return try_catch_.Message();
 
-   }
 
-   inline void Reset() { try_catch_.Reset(); }
 
-   inline void SetVerbose(bool value) { try_catch_.SetVerbose(value); }
 
-   inline void SetCaptureMessage(bool value) {
 
-     try_catch_.SetCaptureMessage(value);
 
-   }
 
- };
 
- v8::Local<v8::Value> MakeCallback(v8::Local<v8::Object> target,
 
-                                   v8::Local<v8::Function> func,
 
-                                   int argc,
 
-                                   v8::Local<v8::Value>* argv);
 
- v8::Local<v8::Value> MakeCallback(v8::Local<v8::Object> target,
 
-                                   v8::Local<v8::String> symbol,
 
-                                   int argc,
 
-                                   v8::Local<v8::Value>* argv);
 
- v8::Local<v8::Value> MakeCallback(v8::Local<v8::Object> target,
 
-                                   const char* method,
 
-                                   int argc,
 
-                                   v8::Local<v8::Value>* argv);
 
- // === AsyncResource ===========================================================
 
- class AsyncResource {
 
-  public:
 
-   AsyncResource(
 
-       v8::Local<v8::String> name
 
-     , v8::Local<v8::Object> resource = New<v8::Object>()) {
 
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
-     v8::Isolate* isolate = v8::Isolate::GetCurrent();
 
-     if (resource.IsEmpty()) {
 
-       resource = New<v8::Object>();
 
-     }
 
-     context = node::EmitAsyncInit(isolate, resource, name);
 
- #endif
 
-   }
 
-   AsyncResource(
 
-       const char* name
 
-     , v8::Local<v8::Object> resource = New<v8::Object>()) {
 
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
-     v8::Isolate* isolate = v8::Isolate::GetCurrent();
 
-     if (resource.IsEmpty()) {
 
-       resource = New<v8::Object>();
 
-     }
 
-     v8::Local<v8::String> name_string =
 
-         New<v8::String>(name).ToLocalChecked();
 
-     context = node::EmitAsyncInit(isolate, resource, name_string);
 
- #endif
 
-   }
 
-   ~AsyncResource() {
 
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
-     v8::Isolate* isolate = v8::Isolate::GetCurrent();
 
-     node::EmitAsyncDestroy(isolate, context);
 
- #endif
 
-   }
 
-   inline MaybeLocal<v8::Value> runInAsyncScope(
 
-       v8::Local<v8::Object> target
 
-     , v8::Local<v8::Function> func
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
- #if NODE_MODULE_VERSION < NODE_9_0_MODULE_VERSION
 
-     return MakeCallback(target, func, argc, argv);
 
- #else
 
-     return node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, func, argc, argv, context);
 
- #endif
 
-   }
 
-   inline MaybeLocal<v8::Value> runInAsyncScope(
 
-       v8::Local<v8::Object> target
 
-     , v8::Local<v8::String> symbol
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
- #if NODE_MODULE_VERSION < NODE_9_0_MODULE_VERSION
 
-     return MakeCallback(target, symbol, argc, argv);
 
- #else
 
-     return node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, symbol, argc, argv, context);
 
- #endif
 
-   }
 
-   inline MaybeLocal<v8::Value> runInAsyncScope(
 
-       v8::Local<v8::Object> target
 
-     , const char* method
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
- #if NODE_MODULE_VERSION < NODE_9_0_MODULE_VERSION
 
-     return MakeCallback(target, method, argc, argv);
 
- #else
 
-     return node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, method, argc, argv, context);
 
- #endif
 
-   }
 
-  private:
 
-   NAN_DISALLOW_ASSIGN_COPY_MOVE(AsyncResource)
 
- #if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
-   node::async_context context;
 
- #endif
 
- };
 
- inline uv_loop_t* GetCurrentEventLoop() {
 
- #if NODE_MAJOR_VERSION >= 10 || \
 
-   NODE_MAJOR_VERSION == 9 && NODE_MINOR_VERSION >= 3 || \
 
-   NODE_MAJOR_VERSION == 8 && NODE_MINOR_VERSION >= 10
 
-     return node::GetCurrentEventLoop(v8::Isolate::GetCurrent());
 
- #else
 
-     return uv_default_loop();
 
- #endif
 
- }
 
- //============ =================================================================
 
- /* node 0.12  */
 
- #if NODE_MODULE_VERSION >= NODE_0_12_MODULE_VERSION
 
-   inline
 
-   void SetCounterFunction(v8::CounterLookupCallback cb) {
 
-     v8::Isolate::GetCurrent()->SetCounterFunction(cb);
 
-   }
 
-   inline
 
-   void SetCreateHistogramFunction(v8::CreateHistogramCallback cb) {
 
-     v8::Isolate::GetCurrent()->SetCreateHistogramFunction(cb);
 
-   }
 
-   inline
 
-   void SetAddHistogramSampleFunction(v8::AddHistogramSampleCallback cb) {
 
-     v8::Isolate::GetCurrent()->SetAddHistogramSampleFunction(cb);
 
-   }
 
- #if defined(V8_MAJOR_VERSION) &&                                               \
 
-       (V8_MAJOR_VERSION > 12 ||                                                \
 
-        (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) &&                 \
 
-         V8_MINOR_VERSION >= 7))
 
-   NAN_DEPRECATED inline bool IdleNotification(int) {
 
-     return true;
 
-   }
 
- # elif defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 ||                   \
 
-   (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
 
-   NAN_DEPRECATED inline bool IdleNotification(int idle_time_in_ms) {
 
-     return v8::Isolate::GetCurrent()->IdleNotificationDeadline(
 
-         idle_time_in_ms * 0.001);
 
-   }
 
- # else
 
-   NAN_DEPRECATED inline bool IdleNotification(int idle_time_in_ms) {
 
-     return v8::Isolate::GetCurrent()->IdleNotification(idle_time_in_ms);
 
-   }
 
- #endif
 
-   inline void LowMemoryNotification() {
 
-     v8::Isolate::GetCurrent()->LowMemoryNotification();
 
-   }
 
-   inline void ContextDisposedNotification() {
 
-     v8::Isolate::GetCurrent()->ContextDisposedNotification();
 
-   }
 
- #else
 
-   inline
 
-   void SetCounterFunction(v8::CounterLookupCallback cb) {
 
-     v8::V8::SetCounterFunction(cb);
 
-   }
 
-   inline
 
-   void SetCreateHistogramFunction(v8::CreateHistogramCallback cb) {
 
-     v8::V8::SetCreateHistogramFunction(cb);
 
-   }
 
-   inline
 
-   void SetAddHistogramSampleFunction(v8::AddHistogramSampleCallback cb) {
 
-     v8::V8::SetAddHistogramSampleFunction(cb);
 
-   }
 
-   inline bool IdleNotification(int idle_time_in_ms) {
 
-     return v8::V8::IdleNotification(idle_time_in_ms);
 
-   }
 
-   inline void LowMemoryNotification() {
 
-     v8::V8::LowMemoryNotification();
 
-   }
 
-   inline void ContextDisposedNotification() {
 
-     v8::V8::ContextDisposedNotification();
 
-   }
 
- #endif
 
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)  // Node 0.12
 
-   inline v8::Local<v8::Primitive> Undefined() {
 
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::Undefined(v8::Isolate::GetCurrent())));
 
- # else
 
-     return v8::Undefined(v8::Isolate::GetCurrent());
 
- # endif
 
-   }
 
-   inline v8::Local<v8::Primitive> Null() {
 
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::Null(v8::Isolate::GetCurrent())));
 
- # else
 
-     return v8::Null(v8::Isolate::GetCurrent());
 
- # endif
 
-   }
 
-   inline v8::Local<v8::Boolean> True() {
 
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::True(v8::Isolate::GetCurrent())));
 
- # else
 
-     return v8::True(v8::Isolate::GetCurrent());
 
- # endif
 
-   }
 
-   inline v8::Local<v8::Boolean> False() {
 
- # if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::False(v8::Isolate::GetCurrent())));
 
- # else
 
-     return v8::False(v8::Isolate::GetCurrent());
 
- # endif
 
-   }
 
-   inline v8::Local<v8::String> EmptyString() {
 
-     return v8::String::Empty(v8::Isolate::GetCurrent());
 
-   }
 
-   inline int AdjustExternalMemory(int bc) {
 
-     return static_cast<int>(
 
-         v8::Isolate::GetCurrent()->AdjustAmountOfExternalAllocatedMemory(bc));
 
-   }
 
-   inline void SetTemplate(
 
-       v8::Local<v8::Template> templ
 
-     , const char *name
 
-     , v8::Local<v8::Data> value) {
 
-     templ->Set(v8::Isolate::GetCurrent(), name, value);
 
-   }
 
-   inline void SetTemplate(
 
-       v8::Local<v8::Template> templ
 
-     , v8::Local<v8::String> name
 
-     , v8::Local<v8::Data> value
 
-     , v8::PropertyAttribute attributes) {
 
-     templ->Set(name, value, attributes);
 
-   }
 
-   inline v8::Local<v8::Context> GetCurrentContext() {
 
-     return v8::Isolate::GetCurrent()->GetCurrentContext();
 
-   }
 
-   inline void* GetInternalFieldPointer(
 
-       v8::Local<v8::Object> object
 
-     , int index) {
 
-     return object->GetAlignedPointerFromInternalField(index);
 
-   }
 
-   inline void SetInternalFieldPointer(
 
-       v8::Local<v8::Object> object
 
-     , int index
 
-     , void* value) {
 
-     object->SetAlignedPointerInInternalField(index, value);
 
-   }
 
- # define NAN_GC_CALLBACK(name)                                                 \
 
-     void name(v8::Isolate *isolate, v8::GCType type, v8::GCCallbackFlags flags)
 
- #if NODE_MODULE_VERSION <= NODE_4_0_MODULE_VERSION
 
-   typedef v8::Isolate::GCEpilogueCallback GCEpilogueCallback;
 
-   typedef v8::Isolate::GCPrologueCallback GCPrologueCallback;
 
- #else
 
-   typedef v8::Isolate::GCCallback GCEpilogueCallback;
 
-   typedef v8::Isolate::GCCallback GCPrologueCallback;
 
- #endif
 
-   inline void AddGCEpilogueCallback(
 
-       GCEpilogueCallback callback
 
-     , v8::GCType gc_type_filter = v8::kGCTypeAll) {
 
-     v8::Isolate::GetCurrent()->AddGCEpilogueCallback(callback, gc_type_filter);
 
-   }
 
-   inline void RemoveGCEpilogueCallback(
 
-       GCEpilogueCallback callback) {
 
-     v8::Isolate::GetCurrent()->RemoveGCEpilogueCallback(callback);
 
-   }
 
-   inline void AddGCPrologueCallback(
 
-       GCPrologueCallback callback
 
-     , v8::GCType gc_type_filter = v8::kGCTypeAll) {
 
-     v8::Isolate::GetCurrent()->AddGCPrologueCallback(callback, gc_type_filter);
 
-   }
 
-   inline void RemoveGCPrologueCallback(
 
-       GCPrologueCallback callback) {
 
-     v8::Isolate::GetCurrent()->RemoveGCPrologueCallback(callback);
 
-   }
 
-   inline void GetHeapStatistics(
 
-       v8::HeapStatistics *heap_statistics) {
 
-     v8::Isolate::GetCurrent()->GetHeapStatistics(heap_statistics);
 
-   }
 
- # define X(NAME)                                                               \
 
-     inline v8::Local<v8::Value> NAME(const char *msg) {                        \
 
-       EscapableHandleScope scope;                                              \
 
-       return scope.Escape(v8::Exception::NAME(New(msg).ToLocalChecked()));     \
 
-     }                                                                          \
 
-                                                                                \
 
-     inline                                                                     \
 
-     v8::Local<v8::Value> NAME(v8::Local<v8::String> msg) {                     \
 
-       return v8::Exception::NAME(msg);                                         \
 
-     }                                                                          \
 
-                                                                                \
 
-     inline void Throw ## NAME(const char *msg) {                               \
 
-       HandleScope scope;                                                       \
 
-       v8::Isolate::GetCurrent()->ThrowException(                               \
 
-           v8::Exception::NAME(New(msg).ToLocalChecked()));                     \
 
-     }                                                                          \
 
-                                                                                \
 
-     inline void Throw ## NAME(v8::Local<v8::String> msg) {                     \
 
-       HandleScope scope;                                                       \
 
-       v8::Isolate::GetCurrent()->ThrowException(                               \
 
-           v8::Exception::NAME(msg));                                           \
 
-     }
 
-   X(Error)
 
-   X(RangeError)
 
-   X(ReferenceError)
 
-   X(SyntaxError)
 
-   X(TypeError)
 
- # undef X
 
-   inline void ThrowError(v8::Local<v8::Value> error) {
 
-     v8::Isolate::GetCurrent()->ThrowException(error);
 
-   }
 
-   inline MaybeLocal<v8::Object> NewBuffer(
 
-       char *data
 
-     , size_t length
 
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
 
-     , node::Buffer::FreeCallback callback
 
- #else
 
-     , node::smalloc::FreeCallback callback
 
- #endif
 
-     , void *hint
 
-   ) {
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     assert(length <= imp::kMaxLength && "too large buffer");
 
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
 
-     return node::Buffer::New(
 
-         v8::Isolate::GetCurrent(), data, length, callback, hint);
 
- #else
 
-     return node::Buffer::New(v8::Isolate::GetCurrent(), data, length, callback,
 
-                              hint);
 
- #endif
 
-   }
 
-   inline MaybeLocal<v8::Object> CopyBuffer(
 
-       const char *data
 
-     , uint32_t size
 
-   ) {
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     assert(size <= imp::kMaxLength && "too large buffer");
 
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
 
-     return node::Buffer::Copy(
 
-         v8::Isolate::GetCurrent(), data, size);
 
- #else
 
-     return node::Buffer::New(v8::Isolate::GetCurrent(), data, size);
 
- #endif
 
-   }
 
-   inline MaybeLocal<v8::Object> NewBuffer(uint32_t size) {
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     assert(size <= imp::kMaxLength && "too large buffer");
 
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
 
-     return node::Buffer::New(
 
-         v8::Isolate::GetCurrent(), size);
 
- #else
 
-     return node::Buffer::New(v8::Isolate::GetCurrent(), size);
 
- #endif
 
-   }
 
-   inline MaybeLocal<v8::Object> NewBuffer(
 
-       char* data
 
-     , uint32_t size
 
-   ) {
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     assert(size <= imp::kMaxLength && "too large buffer");
 
- #if NODE_MODULE_VERSION > IOJS_2_0_MODULE_VERSION
 
-     return node::Buffer::New(v8::Isolate::GetCurrent(), data, size);
 
- #else
 
-     return node::Buffer::Use(v8::Isolate::GetCurrent(), data, size);
 
- #endif
 
-   }
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 4 ||                      \
 
-   (V8_MAJOR_VERSION == 4 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION >= 3))
 
-   inline MaybeLocal<v8::String>
 
-   NewOneByteString(const uint8_t * value, int length = -1) {
 
-     return v8::String::NewFromOneByte(v8::Isolate::GetCurrent(), value,
 
-           v8::NewStringType::kNormal, length);
 
-   }
 
-   inline MaybeLocal<BoundScript> CompileScript(
 
-       v8::Local<v8::String> s
 
-     , const v8::ScriptOrigin& origin
 
-   ) {
 
-     v8::Isolate *isolate = v8::Isolate::GetCurrent();
 
-     v8::EscapableHandleScope scope(isolate);
 
-     v8::ScriptCompiler::Source source(s, origin);
 
-     return scope.Escape(
 
-         v8::ScriptCompiler::Compile(isolate->GetCurrentContext(), &source)
 
-             .FromMaybe(v8::Local<BoundScript>()));
 
-   }
 
-   inline MaybeLocal<BoundScript> CompileScript(
 
-       v8::Local<v8::String> s
 
-   ) {
 
-     v8::Isolate *isolate = v8::Isolate::GetCurrent();
 
-     v8::EscapableHandleScope scope(isolate);
 
-     v8::ScriptCompiler::Source source(s);
 
-     return scope.Escape(
 
-         v8::ScriptCompiler::Compile(isolate->GetCurrentContext(), &source)
 
-             .FromMaybe(v8::Local<BoundScript>()));
 
-   }
 
-   inline MaybeLocal<v8::Value> RunScript(
 
-       v8::Local<UnboundScript> script
 
-   ) {
 
-     v8::Isolate *isolate = v8::Isolate::GetCurrent();
 
-     v8::EscapableHandleScope scope(isolate);
 
-     return scope.Escape(script->BindToCurrentContext()
 
-                             ->Run(isolate->GetCurrentContext())
 
-                             .FromMaybe(v8::Local<v8::Value>()));
 
-   }
 
-   inline MaybeLocal<v8::Value> RunScript(
 
-       v8::Local<BoundScript> script
 
-   ) {
 
-     v8::Isolate *isolate = v8::Isolate::GetCurrent();
 
-     v8::EscapableHandleScope scope(isolate);
 
-     return scope.Escape(script->Run(isolate->GetCurrentContext())
 
-                             .FromMaybe(v8::Local<v8::Value>()));
 
-   }
 
- #else
 
-   inline MaybeLocal<v8::String>
 
-   NewOneByteString(const uint8_t * value, int length = -1) {
 
-     return v8::String::NewFromOneByte(v8::Isolate::GetCurrent(), value,
 
-                                       v8::String::kNormalString, length);
 
-   }
 
-   inline MaybeLocal<BoundScript> CompileScript(
 
-       v8::Local<v8::String> s
 
-     , const v8::ScriptOrigin& origin
 
-   ) {
 
-     v8::ScriptCompiler::Source source(s, origin);
 
-     return v8::ScriptCompiler::Compile(v8::Isolate::GetCurrent(), &source);
 
-   }
 
-   inline MaybeLocal<BoundScript> CompileScript(
 
-       v8::Local<v8::String> s
 
-   ) {
 
-     v8::ScriptCompiler::Source source(s);
 
-     return v8::ScriptCompiler::Compile(v8::Isolate::GetCurrent(), &source);
 
-   }
 
-   inline MaybeLocal<v8::Value> RunScript(
 
-       v8::Local<UnboundScript> script
 
-   ) {
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(script->BindToCurrentContext()->Run());
 
-   }
 
-   inline MaybeLocal<v8::Value> RunScript(
 
-       v8::Local<BoundScript> script
 
-   ) {
 
-     return script->Run();
 
-   }
 
- #endif
 
-   NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
 
-       v8::Local<v8::Object> target
 
-     , v8::Local<v8::Function> func
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, func, argc, argv)));
 
- #else
 
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
-     AsyncResource res("nan:makeCallback");
 
-     return res.runInAsyncScope(target, func, argc, argv)
 
-         .FromMaybe(v8::Local<v8::Value>());
 
- # else
 
-     return node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, func, argc, argv);
 
- # endif  // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
- #endif  // NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-   }
 
-   NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
 
-       v8::Local<v8::Object> target
 
-     , v8::Local<v8::String> symbol
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, symbol, argc, argv)));
 
- #else
 
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
-     AsyncResource res("nan:makeCallback");
 
-     return res.runInAsyncScope(target, symbol, argc, argv)
 
-         .FromMaybe(v8::Local<v8::Value>());
 
- # else
 
-     return node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, symbol, argc, argv);
 
- # endif  // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
- #endif  // NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-   }
 
-   NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
 
-       v8::Local<v8::Object> target
 
-     , const char* method
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
- #if NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, method, argc, argv)));
 
- #else
 
- # if NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
-     AsyncResource res("nan:makeCallback");
 
-     return res.runInAsyncScope(target, method, argc, argv)
 
-         .FromMaybe(v8::Local<v8::Value>());
 
- # else
 
-     return node::MakeCallback(
 
-         v8::Isolate::GetCurrent(), target, method, argc, argv);
 
- # endif  // NODE_MODULE_VERSION >= NODE_9_0_MODULE_VERSION
 
- #endif  // NODE_MODULE_VERSION < IOJS_3_0_MODULE_VERSION
 
-   }
 
-   inline void FatalException(const TryCatch& try_catch) {
 
-     node::FatalException(v8::Isolate::GetCurrent(), try_catch.try_catch_);
 
-   }
 
-   inline v8::Local<v8::Value> ErrnoException(
 
-           int errorno
 
-        ,  const char* syscall = NULL
 
-        ,  const char* message = NULL
 
-        ,  const char* path = NULL) {
 
-     return node::ErrnoException(v8::Isolate::GetCurrent(), errorno, syscall,
 
-             message, path);
 
-   }
 
-   NAN_DEPRECATED inline v8::Local<v8::Value> NanErrnoException(
 
-           int errorno
 
-        ,  const char* syscall = NULL
 
-        ,  const char* message = NULL
 
-        ,  const char* path = NULL) {
 
-     return ErrnoException(errorno, syscall, message, path);
 
-   }
 
-   template<typename T>
 
-   inline void SetIsolateData(
 
-       v8::Isolate *isolate
 
-     , T *data
 
-   ) {
 
-       isolate->SetData(0, data);
 
-   }
 
-   template<typename T>
 
-   inline T *GetIsolateData(
 
-       v8::Isolate *isolate
 
-   ) {
 
-       return static_cast<T*>(isolate->GetData(0));
 
-   }
 
- class Utf8String {
 
-  public:
 
-   inline explicit Utf8String(v8::Local<v8::Value> from) :
 
-       length_(0), str_(str_st_) {
 
-     HandleScope scope;
 
-     if (!from.IsEmpty()) {
 
- #if NODE_MAJOR_VERSION >= 10
 
-       v8::Local<v8::Context> context = GetCurrentContext();
 
-       v8::Local<v8::String> string =
 
-           from->ToString(context).FromMaybe(v8::Local<v8::String>());
 
- #else
 
-       v8::Local<v8::String> string = from->ToString();
 
- #endif
 
-       if (!string.IsEmpty()) {
 
-         size_t len = 3 * string->Length() + 1;
 
-         assert(len <= INT_MAX);
 
-         if (len > sizeof (str_st_)) {
 
-           str_ = static_cast<char*>(malloc(len));
 
-           assert(str_ != 0);
 
-         }
 
-         const int flags =
 
-             v8::String::NO_NULL_TERMINATION | imp::kReplaceInvalidUtf8;
 
- #if NODE_MAJOR_VERSION >= 11
 
-         length_ = string->WriteUtf8(v8::Isolate::GetCurrent(), str_,
 
-                                     static_cast<int>(len), 0, flags);
 
- #else
 
-         // See https://github.com/nodejs/nan/issues/832.
 
-         // Disable the warning as there is no way around it.
 
- #ifdef _MSC_VER
 
- #pragma warning(push)
 
- #pragma warning(disable : 4996)
 
- #endif
 
- #ifdef __GNUC__
 
- #pragma GCC diagnostic push
 
- #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
 
- #endif
 
-         length_ = string->WriteUtf8(str_, static_cast<int>(len), 0, flags);
 
- #ifdef __GNUC__
 
- #pragma GCC diagnostic pop
 
- #endif
 
- #ifdef _MSC_VER
 
- #pragma warning(pop)
 
- #endif
 
- #endif  // NODE_MAJOR_VERSION < 11
 
-         str_[length_] = '\0';
 
-       }
 
-     }
 
-   }
 
-   inline int length() const {
 
-     return length_;
 
-   }
 
-   inline char* operator*() { return str_; }
 
-   inline const char* operator*() const { return str_; }
 
-   inline ~Utf8String() {
 
-     if (str_ != str_st_) {
 
-       free(str_);
 
-     }
 
-   }
 
-  private:
 
-   NAN_DISALLOW_ASSIGN_COPY_MOVE(Utf8String)
 
-   int length_;
 
-   char *str_;
 
-   char str_st_[1024];
 
- };
 
- #else  // Node 0.8 and 0.10
 
-   inline v8::Local<v8::Primitive> Undefined() {
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::Undefined()));
 
-   }
 
-   inline v8::Local<v8::Primitive> Null() {
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::Null()));
 
-   }
 
-   inline v8::Local<v8::Boolean> True() {
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::True()));
 
-   }
 
-   inline v8::Local<v8::Boolean> False() {
 
-     EscapableHandleScope scope;
 
-     return scope.Escape(New(v8::False()));
 
-   }
 
-   inline v8::Local<v8::String> EmptyString() {
 
-     return v8::String::Empty();
 
-   }
 
-   inline int AdjustExternalMemory(int bc) {
 
-     return static_cast<int>(v8::V8::AdjustAmountOfExternalAllocatedMemory(bc));
 
-   }
 
-   inline void SetTemplate(
 
-       v8::Local<v8::Template> templ
 
-     , const char *name
 
-     , v8::Local<v8::Data> value) {
 
-     templ->Set(name, value);
 
-   }
 
-   inline void SetTemplate(
 
-       v8::Local<v8::Template> templ
 
-     , v8::Local<v8::String> name
 
-     , v8::Local<v8::Data> value
 
-     , v8::PropertyAttribute attributes) {
 
-     templ->Set(name, value, attributes);
 
-   }
 
-   inline v8::Local<v8::Context> GetCurrentContext() {
 
-     return v8::Context::GetCurrent();
 
-   }
 
-   inline void* GetInternalFieldPointer(
 
-       v8::Local<v8::Object> object
 
-     , int index) {
 
-     return object->GetPointerFromInternalField(index);
 
-   }
 
-   inline void SetInternalFieldPointer(
 
-       v8::Local<v8::Object> object
 
-     , int index
 
-     , void* value) {
 
-     object->SetPointerInInternalField(index, value);
 
-   }
 
- # define NAN_GC_CALLBACK(name)                                                 \
 
-     void name(v8::GCType type, v8::GCCallbackFlags flags)
 
-   inline void AddGCEpilogueCallback(
 
-     v8::GCEpilogueCallback callback
 
-   , v8::GCType gc_type_filter = v8::kGCTypeAll) {
 
-     v8::V8::AddGCEpilogueCallback(callback, gc_type_filter);
 
-   }
 
-   inline void RemoveGCEpilogueCallback(
 
-     v8::GCEpilogueCallback callback) {
 
-     v8::V8::RemoveGCEpilogueCallback(callback);
 
-   }
 
-   inline void AddGCPrologueCallback(
 
-     v8::GCPrologueCallback callback
 
-   , v8::GCType gc_type_filter = v8::kGCTypeAll) {
 
-     v8::V8::AddGCPrologueCallback(callback, gc_type_filter);
 
-   }
 
-   inline void RemoveGCPrologueCallback(
 
-     v8::GCPrologueCallback callback) {
 
-     v8::V8::RemoveGCPrologueCallback(callback);
 
-   }
 
-   inline void GetHeapStatistics(
 
-     v8::HeapStatistics *heap_statistics) {
 
-     v8::V8::GetHeapStatistics(heap_statistics);
 
-   }
 
- # define X(NAME)                                                               \
 
-     inline v8::Local<v8::Value> NAME(const char *msg) {                        \
 
-       EscapableHandleScope scope;                                              \
 
-       return scope.Escape(v8::Exception::NAME(New(msg).ToLocalChecked()));     \
 
-     }                                                                          \
 
-                                                                                \
 
-     inline                                                                     \
 
-     v8::Local<v8::Value> NAME(v8::Local<v8::String> msg) {                     \
 
-       return v8::Exception::NAME(msg);                                         \
 
-     }                                                                          \
 
-                                                                                \
 
-     inline void Throw ## NAME(const char *msg) {                               \
 
-       HandleScope scope;                                                       \
 
-       v8::ThrowException(v8::Exception::NAME(New(msg).ToLocalChecked()));      \
 
-     }                                                                          \
 
-                                                                                \
 
-     inline                                                                     \
 
-     void Throw ## NAME(v8::Local<v8::String> errmsg) {                         \
 
-       HandleScope scope;                                                       \
 
-       v8::ThrowException(v8::Exception::NAME(errmsg));                         \
 
-     }
 
-   X(Error)
 
-   X(RangeError)
 
-   X(ReferenceError)
 
-   X(SyntaxError)
 
-   X(TypeError)
 
- # undef X
 
-   inline void ThrowError(v8::Local<v8::Value> error) {
 
-     v8::ThrowException(error);
 
-   }
 
-   inline MaybeLocal<v8::Object> NewBuffer(
 
-       char *data
 
-     , size_t length
 
-     , node::Buffer::free_callback callback
 
-     , void *hint
 
-   ) {
 
-     EscapableHandleScope scope;
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     assert(length <= imp::kMaxLength && "too large buffer");
 
-     return scope.Escape(
 
-         New(node::Buffer::New(data, length, callback, hint)->handle_));
 
-   }
 
-   inline MaybeLocal<v8::Object> CopyBuffer(
 
-       const char *data
 
-     , uint32_t size
 
-   ) {
 
-     EscapableHandleScope scope;
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     assert(size <= imp::kMaxLength && "too large buffer");
 
- #if NODE_MODULE_VERSION >= NODE_0_10_MODULE_VERSION
 
-     return scope.Escape(New(node::Buffer::New(data, size)->handle_));
 
- #else
 
-     return scope.Escape(
 
-         New(node::Buffer::New(const_cast<char *>(data), size)->handle_));
 
- #endif
 
-   }
 
-   inline MaybeLocal<v8::Object> NewBuffer(uint32_t size) {
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     EscapableHandleScope scope;
 
-     assert(size <= imp::kMaxLength && "too large buffer");
 
-     return scope.Escape(New(node::Buffer::New(size)->handle_));
 
-   }
 
-   inline void FreeData(char *data, void *hint) {
 
-     (void) hint;  // unused
 
-     delete[] data;
 
-   }
 
-   inline MaybeLocal<v8::Object> NewBuffer(
 
-       char* data
 
-     , uint32_t size
 
-   ) {
 
-     EscapableHandleScope scope;
 
-     // arbitrary buffer lengths requires
 
-     // NODE_MODULE_VERSION >= IOJS_3_0_MODULE_VERSION
 
-     assert(size <= imp::kMaxLength && "too large buffer");
 
-     return scope.Escape(
 
-         New(node::Buffer::New(data, size, FreeData, NULL)->handle_));
 
-   }
 
- namespace imp {
 
- inline void
 
- widenString(std::vector<uint16_t> *ws, const uint8_t *s, int l) {
 
-   size_t len = static_cast<size_t>(l);
 
-   if (l < 0) {
 
-     len = strlen(reinterpret_cast<const char*>(s));
 
-   }
 
-   assert(len <= INT_MAX && "string too long");
 
-   ws->resize(len);
 
-   std::copy(s, s + len, ws->begin());  // NOLINT(build/include_what_you_use)
 
- }
 
- }  // end of namespace imp
 
-   inline MaybeLocal<v8::String>
 
-   NewOneByteString(const uint8_t * value, int length = -1) {
 
-     std::vector<uint16_t> wideString;  // NOLINT(build/include_what_you_use)
 
-     imp::widenString(&wideString, value, length);
 
-     return v8::String::New(wideString.data(),
 
-                            static_cast<int>(wideString.size()));
 
-   }
 
-   inline MaybeLocal<BoundScript> CompileScript(
 
-       v8::Local<v8::String> s
 
-     , const v8::ScriptOrigin& origin
 
-   ) {
 
-     return v8::Script::Compile(s, const_cast<v8::ScriptOrigin *>(&origin));
 
-   }
 
-   inline MaybeLocal<BoundScript> CompileScript(
 
-     v8::Local<v8::String> s
 
-   ) {
 
-     return v8::Script::Compile(s);
 
-   }
 
-   inline
 
-   MaybeLocal<v8::Value> RunScript(v8::Local<v8::Script> script) {
 
-     return script->Run();
 
-   }
 
-   inline v8::Local<v8::Value> MakeCallback(
 
-       v8::Local<v8::Object> target
 
-     , v8::Local<v8::Function> func
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
-     v8::HandleScope scope;
 
-     return scope.Close(New(node::MakeCallback(target, func, argc, argv)));
 
-   }
 
-   inline v8::Local<v8::Value> MakeCallback(
 
-       v8::Local<v8::Object> target
 
-     , v8::Local<v8::String> symbol
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
-     v8::HandleScope scope;
 
-     return scope.Close(New(node::MakeCallback(target, symbol, argc, argv)));
 
-   }
 
-   inline v8::Local<v8::Value> MakeCallback(
 
-       v8::Local<v8::Object> target
 
-     , const char* method
 
-     , int argc
 
-     , v8::Local<v8::Value>* argv) {
 
-     v8::HandleScope scope;
 
-     return scope.Close(New(node::MakeCallback(target, method, argc, argv)));
 
-   }
 
-   inline void FatalException(const TryCatch& try_catch) {
 
-     node::FatalException(const_cast<v8::TryCatch &>(try_catch.try_catch_));
 
-   }
 
-   inline v8::Local<v8::Value> ErrnoException(
 
-           int errorno
 
-        ,  const char* syscall = NULL
 
-        ,  const char* message = NULL
 
-        ,  const char* path = NULL) {
 
-     return node::ErrnoException(errorno, syscall, message, path);
 
-   }
 
-   NAN_DEPRECATED inline v8::Local<v8::Value> NanErrnoException(
 
-           int errorno
 
-        ,  const char* syscall = NULL
 
-        ,  const char* message = NULL
 
-        ,  const char* path = NULL) {
 
-     return ErrnoException(errorno, syscall, message, path);
 
-   }
 
-   template<typename T>
 
-   inline void SetIsolateData(
 
-       v8::Isolate *isolate
 
-     , T *data
 
-   ) {
 
-       isolate->SetData(data);
 
-   }
 
-   template<typename T>
 
-   inline T *GetIsolateData(
 
-       v8::Isolate *isolate
 
-   ) {
 
-       return static_cast<T*>(isolate->GetData());
 
-   }
 
- class Utf8String {
 
-  public:
 
-   inline explicit Utf8String(v8::Local<v8::Value> from) :
 
-       length_(0), str_(str_st_) {
 
-     v8::HandleScope scope;
 
-     if (!from.IsEmpty()) {
 
-       v8::Local<v8::String> string = from->ToString();
 
-       if (!string.IsEmpty()) {
 
-         size_t len = 3 * string->Length() + 1;
 
-         assert(len <= INT_MAX);
 
-         if (len > sizeof (str_st_)) {
 
-           str_ = static_cast<char*>(malloc(len));
 
-           assert(str_ != 0);
 
-         }
 
-         const int flags =
 
-             v8::String::NO_NULL_TERMINATION | imp::kReplaceInvalidUtf8;
 
-         length_ = string->WriteUtf8(str_, static_cast<int>(len), 0, flags);
 
-         str_[length_] = '\0';
 
-       }
 
-     }
 
-   }
 
-   inline int length() const {
 
-     return length_;
 
-   }
 
-   inline char* operator*() { return str_; }
 
-   inline const char* operator*() const { return str_; }
 
-   inline ~Utf8String() {
 
-     if (str_ != str_st_) {
 
-       free(str_);
 
-     }
 
-   }
 
-  private:
 
-   NAN_DISALLOW_ASSIGN_COPY_MOVE(Utf8String)
 
-   int length_;
 
-   char *str_;
 
-   char str_st_[1024];
 
- };
 
- #endif  // NODE_MODULE_VERSION
 
- typedef void (*FreeCallback)(char *data, void *hint);
 
- typedef const FunctionCallbackInfo<v8::Value>& NAN_METHOD_ARGS_TYPE;
 
- typedef void NAN_METHOD_RETURN_TYPE;
 
- typedef const PropertyCallbackInfo<v8::Value>& NAN_GETTER_ARGS_TYPE;
 
- typedef void NAN_GETTER_RETURN_TYPE;
 
- typedef const PropertyCallbackInfo<void>& NAN_SETTER_ARGS_TYPE;
 
- typedef void NAN_SETTER_RETURN_TYPE;
 
- typedef const PropertyCallbackInfo<v8::Value>&
 
-     NAN_PROPERTY_GETTER_ARGS_TYPE;
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef v8::Intercepted NAN_PROPERTY_GETTER_RETURN_TYPE;
 
- #else
 
- typedef void NAN_PROPERTY_GETTER_RETURN_TYPE;
 
- #endif
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef const PropertyCallbackInfo<void>&
 
-     NAN_PROPERTY_SETTER_ARGS_TYPE;
 
- typedef v8::Intercepted NAN_PROPERTY_SETTER_RETURN_TYPE;
 
- #else
 
- typedef const PropertyCallbackInfo<v8::Value>&
 
-     NAN_PROPERTY_SETTER_ARGS_TYPE;
 
- typedef void NAN_PROPERTY_SETTER_RETURN_TYPE;
 
- #endif
 
- 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;
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef v8::Intercepted NAN_PROPERTY_DELETER_RETURN_TYPE;
 
- #else
 
- typedef void NAN_PROPERTY_DELETER_RETURN_TYPE;
 
- #endif
 
- typedef const PropertyCallbackInfo<v8::Integer>&
 
-     NAN_PROPERTY_QUERY_ARGS_TYPE;
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef v8::Intercepted NAN_PROPERTY_QUERY_RETURN_TYPE;
 
- #else
 
- typedef void NAN_PROPERTY_QUERY_RETURN_TYPE;
 
- #endif
 
- typedef const PropertyCallbackInfo<v8::Value>& NAN_INDEX_GETTER_ARGS_TYPE;
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef v8::Intercepted NAN_INDEX_GETTER_RETURN_TYPE;
 
- #else
 
- typedef void NAN_INDEX_GETTER_RETURN_TYPE;
 
- #endif
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef const PropertyCallbackInfo<void>& NAN_INDEX_SETTER_ARGS_TYPE;
 
- typedef v8::Intercepted NAN_INDEX_SETTER_RETURN_TYPE;
 
- #else
 
- typedef const PropertyCallbackInfo<v8::Value>& NAN_INDEX_SETTER_ARGS_TYPE;
 
- typedef void NAN_INDEX_SETTER_RETURN_TYPE;
 
- #endif
 
- typedef const PropertyCallbackInfo<v8::Array>&
 
-     NAN_INDEX_ENUMERATOR_ARGS_TYPE;
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef v8::Intercepted NAN_INDEX_ENUMERATOR_RETURN_TYPE;
 
- #else
 
- typedef void NAN_INDEX_ENUMERATOR_RETURN_TYPE;
 
- #endif
 
- typedef const PropertyCallbackInfo<v8::Boolean>&
 
-     NAN_INDEX_DELETER_ARGS_TYPE;
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef v8::Intercepted NAN_INDEX_DELETER_RETURN_TYPE;
 
- #else
 
- typedef void NAN_INDEX_DELETER_RETURN_TYPE;
 
- #endif
 
- typedef const PropertyCallbackInfo<v8::Integer>&
 
-     NAN_INDEX_QUERY_ARGS_TYPE;
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 ||                     \
 
-   (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) && V8_MINOR_VERSION > 4))
 
- typedef v8::Intercepted NAN_INDEX_QUERY_RETURN_TYPE;
 
- #else
 
- typedef void NAN_INDEX_QUERY_RETURN_TYPE;
 
- #endif
 
- #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 {
 
- inline
 
- ExternalOneByteStringResource const*
 
- GetExternalResource(v8::Local<v8::String> str) {
 
- #if NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION
 
-     return str->GetExternalAsciiStringResource();
 
- #else
 
-     return str->GetExternalOneByteStringResource();
 
- #endif
 
- }
 
- inline
 
- bool
 
- IsExternal(v8::Local<v8::String> str) {
 
- #if NODE_MODULE_VERSION < ATOM_0_21_MODULE_VERSION
 
-     return str->IsExternalAscii();
 
- #else
 
-     return str->IsExternalOneByte();
 
- #endif
 
- }
 
- }  // end of namespace imp
 
- enum Encoding {ASCII, UTF8, BASE64, UCS2, BINARY, HEX, BUFFER};
 
- #if NODE_MODULE_VERSION < NODE_0_10_MODULE_VERSION
 
- # include "nan_string_bytes.h"  // NOLINT(build/include)
 
- #endif
 
- inline v8::Local<v8::Value> Encode(
 
-     const void *buf, size_t len, enum Encoding encoding = BINARY) {
 
- #if (NODE_MODULE_VERSION >= ATOM_0_21_MODULE_VERSION)
 
-   v8::Isolate* isolate = v8::Isolate::GetCurrent();
 
-   node::encoding node_enc = static_cast<node::encoding>(encoding);
 
-   if (encoding == UCS2) {
 
-     return node::Encode(
 
-         isolate
 
-       , reinterpret_cast<const uint16_t *>(buf)
 
-       , len / 2);
 
-   } else {
 
-     return node::Encode(
 
-         isolate
 
-       , reinterpret_cast<const char *>(buf)
 
-       , len
 
-       , node_enc);
 
-   }
 
- #elif (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
 
-   return node::Encode(
 
-       v8::Isolate::GetCurrent()
 
-     , buf, len
 
-     , static_cast<node::encoding>(encoding));
 
- #else
 
- # if NODE_MODULE_VERSION >= NODE_0_10_MODULE_VERSION
 
-   return node::Encode(buf, len, static_cast<node::encoding>(encoding));
 
- # else
 
-   return imp::Encode(reinterpret_cast<const char*>(buf), len, encoding);
 
- # endif
 
- #endif
 
- }
 
- inline ssize_t DecodeBytes(
 
-     v8::Local<v8::Value> val, enum Encoding encoding = BINARY) {
 
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
 
-   return node::DecodeBytes(
 
-       v8::Isolate::GetCurrent()
 
-     , val
 
-     , static_cast<node::encoding>(encoding));
 
- #else
 
- # if (NODE_MODULE_VERSION < NODE_0_10_MODULE_VERSION)
 
-   if (encoding == BUFFER) {
 
-     return node::DecodeBytes(val, node::BINARY);
 
-   }
 
- # endif
 
-   return node::DecodeBytes(val, static_cast<node::encoding>(encoding));
 
- #endif
 
- }
 
- inline ssize_t DecodeWrite(
 
-     char *buf
 
-   , size_t len
 
-   , v8::Local<v8::Value> val
 
-   , enum Encoding encoding = BINARY) {
 
- #if (NODE_MODULE_VERSION > NODE_0_10_MODULE_VERSION)
 
-   return node::DecodeWrite(
 
-       v8::Isolate::GetCurrent()
 
-     , buf
 
-     , len
 
-     , val
 
-     , static_cast<node::encoding>(encoding));
 
- #else
 
- # if (NODE_MODULE_VERSION < NODE_0_10_MODULE_VERSION)
 
-   if (encoding == BUFFER) {
 
-     return node::DecodeWrite(buf, len, val, node::BINARY);
 
-   }
 
- # endif
 
-   return node::DecodeWrite(
 
-       buf
 
-     , len
 
-     , val
 
-     , static_cast<node::encoding>(encoding));
 
- #endif
 
- }
 
- inline void SetPrototypeTemplate(
 
-     v8::Local<v8::FunctionTemplate> templ
 
-   , const char *name
 
-   , v8::Local<v8::Data> value
 
- ) {
 
-   HandleScope scope;
 
-   SetTemplate(templ->PrototypeTemplate(), name, value);
 
- }
 
- inline void SetPrototypeTemplate(
 
-     v8::Local<v8::FunctionTemplate> templ
 
-   , v8::Local<v8::String> name
 
-   , v8::Local<v8::Data> value
 
-   , v8::PropertyAttribute attributes
 
- ) {
 
-   HandleScope scope;
 
-   SetTemplate(templ->PrototypeTemplate(), name, value, attributes);
 
- }
 
- inline void SetInstanceTemplate(
 
-     v8::Local<v8::FunctionTemplate> templ
 
-   , const char *name
 
-   , v8::Local<v8::Data> value
 
- ) {
 
-   HandleScope scope;
 
-   SetTemplate(templ->InstanceTemplate(), name, value);
 
- }
 
- inline void SetInstanceTemplate(
 
-     v8::Local<v8::FunctionTemplate> templ
 
-   , v8::Local<v8::String> name
 
-   , v8::Local<v8::Data> value
 
-   , v8::PropertyAttribute attributes
 
- ) {
 
-   HandleScope scope;
 
-   SetTemplate(templ->InstanceTemplate(), name, value, attributes);
 
- }
 
- namespace imp {
 
- // Note(@agnat): Helper to distinguish different receiver types. The first
 
- // version deals with receivers derived from v8::Template. The second version
 
- // handles everything else. The final argument only serves as discriminator and
 
- // is unused.
 
- template <typename T>
 
- inline
 
- void
 
- SetMethodAux(T recv,
 
-              v8::Local<v8::String> name,
 
-              v8::Local<v8::FunctionTemplate> tpl,
 
-              v8::Template *) {
 
-   recv->Set(name, tpl);
 
- }
 
- template <typename T>
 
- inline
 
- void
 
- SetMethodAux(T recv,
 
-              v8::Local<v8::String> name,
 
-              v8::Local<v8::FunctionTemplate> tpl,
 
-              ...) {
 
-   Set(recv, name, GetFunction(tpl).ToLocalChecked());
 
- }
 
- }  // end of namespace imp
 
- template <typename T, template <typename> class HandleType>
 
- inline void SetMethod(
 
-     HandleType<T> recv
 
-   , const char *name
 
-   , FunctionCallback callback
 
-   , 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);
 
-   }
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 \
 
-             || (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) \
 
-             && V8_MINOR_VERSION >= 5))
 
-   tpl->SetNativeDataProperty(
 
- #else
 
-   tpl->SetAccessor(
 
- #endif
 
-       name
 
-     , getter_
 
-     , setter_
 
-     , obj
 
- #if !defined(V8_MAJOR_VERSION) || V8_MAJOR_VERSION < 12
 
-     , settings
 
- #endif
 
-     , 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);
 
-   }
 
- #if defined(V8_MAJOR_VERSION) && (V8_MAJOR_VERSION > 12 \
 
-             || (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) \
 
-             && V8_MINOR_VERSION >= 5))
 
-   tpl->SetNativeDataProperty(
 
- #else
 
-   tpl->SetAccessor(
 
- #endif
 
-       name
 
-     , getter_
 
-     , setter_
 
-     , obj
 
- #if !defined(V8_MAJOR_VERSION) || V8_MAJOR_VERSION < 12
 
-     , settings
 
- #endif
 
-     , 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)
 
- #if defined(V8_MAJOR_VERSION) &&                                               \
 
-     (V8_MAJOR_VERSION > 12 ||                                                  \
 
-      (V8_MAJOR_VERSION == 12 && defined(V8_MINOR_VERSION) &&                   \
 
-       V8_MINOR_VERSION >= 5))
 
-   return obj->SetNativeDataProperty(
 
-       GetCurrentContext()
 
-     , name
 
-     , getter_
 
-     , setter_
 
-     , dataobj
 
-     , attribute).FromMaybe(false);
 
- #else
 
-   return obj->SetAccessor(
 
-       GetCurrentContext()
 
-     , name
 
-     , getter_
 
-     , setter_
 
-     , dataobj
 
-     , settings
 
-     , attribute).FromMaybe(false);
 
- #endif
 
- #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_subdir)
 
- //=== ObjectWrap ===============================================================
 
- #include "nan_object_wrap.h"  // NOLINT(build/include_subdir)
 
- //=== HiddenValue/Private ======================================================
 
- #include "nan_private.h"  // NOLINT(build/include_subdir)
 
- //=== Export ==================================================================
 
- inline
 
- void
 
- Export(ADDON_REGISTER_FUNCTION_ARGS_TYPE target, const char *name,
 
-     FunctionCallback f) {
 
-   HandleScope scope;
 
-   Set(target, New<v8::String>(name).ToLocalChecked(),
 
-       GetFunction(New<v8::FunctionTemplate>(f)).ToLocalChecked());
 
- }
 
- //=== Tap Reverse Binding =====================================================
 
- struct Tap {
 
-   explicit Tap(v8::Local<v8::Value> t) : t_() {
 
-     HandleScope scope;
 
-     t_.Reset(To<v8::Object>(t).ToLocalChecked());
 
-   }
 
-   ~Tap() { t_.Reset(); }  // not sure if 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 imp
 
- template <typename T, template <typename> class MaybeMaybe>
 
- inline MaybeLocal<T>
 
- MakeMaybe(MaybeMaybe<T> v) {
 
-   return imp::Maybefier<MaybeMaybe<T> >::convert(v);
 
- }
 
- //=== TypedArrayContents =======================================================
 
- #include "nan_typedarray_contents.h"  // NOLINT(build/include_subdir)
 
- //=== JSON =====================================================================
 
- #include "nan_json.h"  // NOLINT(build/include_subdir)
 
- //=== ScriptOrigin =============================================================
 
- #include "nan_scriptorigin.h"  // NOLINT(build/include_subdir)
 
- }  // end of namespace Nan
 
- #endif  // NAN_H_
 
 
  |