Linux vps-61133.fhnet.fr 4.9.0-19-amd64 #1 SMP Debian 4.9.320-2 (2022-06-30) x86_64
Apache/2.4.25 (Debian)
Server IP : 93.113.207.21 & Your IP : 216.73.216.41
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
include /
node /
Delete
Unzip
Name
Size
Permission
Date
Action
cppgc
[ DIR ]
drwxr-xr-x
2024-03-12 22:00
libplatform
[ DIR ]
drwxr-xr-x
2024-03-12 22:00
openssl
[ DIR ]
drwxr-xr-x
2024-03-12 22:00
uv
[ DIR ]
drwxr-xr-x
2024-03-12 22:00
common.gypi
19.2
KB
-rw-r--r--
2023-02-16 16:16
config.gypi
18.88
KB
-rw-r--r--
2023-02-16 16:16
js_native_api.h
28.22
KB
-rw-r--r--
2023-02-16 16:16
js_native_api_types.h
4.33
KB
-rw-r--r--
2023-02-16 16:16
node.h
46.83
KB
-rw-r--r--
2023-02-16 16:16
node_api.h
11.51
KB
-rw-r--r--
2023-02-16 16:16
node_api_types.h
1.62
KB
-rw-r--r--
2023-02-16 16:16
node_buffer.h
3.6
KB
-rw-r--r--
2022-04-07 20:19
node_object_wrap.h
3.78
KB
-rw-r--r--
2021-10-14 07:50
node_version.h
3.69
KB
-rw-r--r--
2023-02-16 16:16
uv.h
65.42
KB
-rw-r--r--
2023-02-16 16:16
v8-fast-api-calls.h
13.56
KB
-rw-r--r--
2023-02-16 16:16
v8-internal.h
15.46
KB
-rw-r--r--
2023-02-16 16:16
v8-platform.h
19.22
KB
-rw-r--r--
2023-02-16 16:16
v8-profiler.h
32.93
KB
-rw-r--r--
2023-02-16 16:16
v8-util.h
19.58
KB
-rw-r--r--
2023-02-16 16:16
v8-value-serializer-version.h
648
B
-rw-r--r--
2022-03-09 12:08
v8-version-string.h
1.13
KB
-rw-r--r--
2022-04-07 20:19
v8-version.h
772
B
-rw-r--r--
2023-02-16 16:16
v8-wasm-trap-handler-posix.h
1.18
KB
-rw-r--r--
2022-04-07 20:19
v8-wasm-trap-handler-win.h
1.01
KB
-rw-r--r--
2022-04-07 20:19
v8.h
394.64
KB
-rw-r--r--
2023-02-16 16:16
v8config.h
14.94
KB
-rw-r--r--
2023-02-16 16:16
zconf.h
16.4
KB
-rw-r--r--
2021-10-14 07:50
zlib.h
94.48
KB
-rw-r--r--
2021-10-14 07:50
Save
Rename
// Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. #ifndef SRC_NODE_OBJECT_WRAP_H_ #define SRC_NODE_OBJECT_WRAP_H_ #include "v8.h" #include <cassert> namespace node { class ObjectWrap { public: ObjectWrap() { refs_ = 0; } virtual ~ObjectWrap() { if (persistent().IsEmpty()) return; persistent().ClearWeak(); persistent().Reset(); } template <class T> static inline T* Unwrap(v8::Local<v8::Object> handle) { assert(!handle.IsEmpty()); assert(handle->InternalFieldCount() > 0); // Cast to ObjectWrap before casting to T. A direct cast from void // to T won't work right when T has more than one base class. void* ptr = handle->GetAlignedPointerFromInternalField(0); ObjectWrap* wrap = static_cast<ObjectWrap*>(ptr); return static_cast<T*>(wrap); } inline v8::Local<v8::Object> handle() { return handle(v8::Isolate::GetCurrent()); } inline v8::Local<v8::Object> handle(v8::Isolate* isolate) { return v8::Local<v8::Object>::New(isolate, persistent()); } // NOLINTNEXTLINE(runtime/v8_persistent) inline v8::Persistent<v8::Object>& persistent() { return handle_; } protected: inline void Wrap(v8::Local<v8::Object> handle) { assert(persistent().IsEmpty()); assert(handle->InternalFieldCount() > 0); handle->SetAlignedPointerInInternalField(0, this); persistent().Reset(v8::Isolate::GetCurrent(), handle); MakeWeak(); } inline void MakeWeak() { persistent().SetWeak(this, WeakCallback, v8::WeakCallbackType::kParameter); } /* Ref() marks the object as being attached to an event loop. * Refed objects will not be garbage collected, even if * all references are lost. */ virtual void Ref() { assert(!persistent().IsEmpty()); persistent().ClearWeak(); refs_++; } /* Unref() marks an object as detached from the event loop. This is its * default state. When an object with a "weak" reference changes from * attached to detached state it will be freed. Be careful not to access * the object after making this call as it might be gone! * (A "weak reference" means an object that only has a * persistent handle.) * * DO NOT CALL THIS FROM DESTRUCTOR */ virtual void Unref() { assert(!persistent().IsEmpty()); assert(!persistent().IsWeak()); assert(refs_ > 0); if (--refs_ == 0) MakeWeak(); } int refs_; // ro private: static void WeakCallback( const v8::WeakCallbackInfo<ObjectWrap>& data) { ObjectWrap* wrap = data.GetParameter(); assert(wrap->refs_ == 0); wrap->handle_.Reset(); delete wrap; } // NOLINTNEXTLINE(runtime/v8_persistent) v8::Persistent<v8::Object> handle_; }; } // namespace node #endif // SRC_NODE_OBJECT_WRAP_H_