Linux vmi2545633.contaboserver.net 6.1.0-32-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.129-1 (2025-03-06) x86_64
Apache/2.4.62 (Debian)
Server IP : 127.0.0.1 & Your IP : 127.0.0.1
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
include /
node /
cppgc /
internal /
Delete
Unzip
Name
Size
Permission
Date
Action
api-constants.h
2.83
KB
-rw-r--r--
2024-04-10 12:29
atomic-entry-flag.h
1.72
KB
-rw-r--r--
2022-10-11 10:59
base-page-handle.h
1.44
KB
-rw-r--r--
2024-04-10 12:29
caged-heap-local-data.h
3.61
KB
-rw-r--r--
2024-04-10 12:29
caged-heap.h
2.21
KB
-rw-r--r--
2024-04-10 12:29
compiler-specific.h
1019
B
-rw-r--r--
2022-10-11 10:59
finalizer-trait.h
2.59
KB
-rw-r--r--
2022-10-11 10:59
gc-info.h
6.31
KB
-rw-r--r--
2024-04-10 12:29
logging.h
1.66
KB
-rw-r--r--
2022-10-11 10:59
member-storage.h
8.7
KB
-rw-r--r--
2024-04-10 12:29
name-trait.h
4.08
KB
-rw-r--r--
2024-04-10 12:29
persistent-node.h
5.89
KB
-rw-r--r--
2024-04-10 12:29
pointer-policies.h
8.34
KB
-rw-r--r--
2024-04-10 12:29
write-barrier.h
19.09
KB
-rw-r--r--
2024-04-10 12:29
Save
Rename
// Copyright 2020 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef INCLUDE_CPPGC_INTERNAL_FINALIZER_TRAIT_H_ #define INCLUDE_CPPGC_INTERNAL_FINALIZER_TRAIT_H_ #include <type_traits> #include "cppgc/type-traits.h" namespace cppgc { namespace internal { using FinalizationCallback = void (*)(void*); template <typename T, typename = void> struct HasFinalizeGarbageCollectedObject : std::false_type {}; template <typename T> struct HasFinalizeGarbageCollectedObject< T, std::void_t<decltype(std::declval<T>().FinalizeGarbageCollectedObject())>> : std::true_type {}; // The FinalizerTraitImpl specifies how to finalize objects. template <typename T, bool isFinalized> struct FinalizerTraitImpl; template <typename T> struct FinalizerTraitImpl<T, true> { private: // Dispatch to custom FinalizeGarbageCollectedObject(). struct Custom { static void Call(void* obj) { static_cast<T*>(obj)->FinalizeGarbageCollectedObject(); } }; // Dispatch to regular destructor. struct Destructor { static void Call(void* obj) { static_cast<T*>(obj)->~T(); } }; using FinalizeImpl = std::conditional_t<HasFinalizeGarbageCollectedObject<T>::value, Custom, Destructor>; public: static void Finalize(void* obj) { static_assert(sizeof(T), "T must be fully defined"); FinalizeImpl::Call(obj); } }; template <typename T> struct FinalizerTraitImpl<T, false> { static void Finalize(void* obj) { static_assert(sizeof(T), "T must be fully defined"); } }; // The FinalizerTrait is used to determine if a type requires finalization and // what finalization means. template <typename T> struct FinalizerTrait { private: // Object has a finalizer if it has // - a custom FinalizeGarbageCollectedObject method, or // - a destructor. static constexpr bool kNonTrivialFinalizer = internal::HasFinalizeGarbageCollectedObject<T>::value || !std::is_trivially_destructible<typename std::remove_cv<T>::type>::value; static void Finalize(void* obj) { internal::FinalizerTraitImpl<T, kNonTrivialFinalizer>::Finalize(obj); } public: static constexpr bool HasFinalizer() { return kNonTrivialFinalizer; } // The callback used to finalize an object of type T. static constexpr FinalizationCallback kCallback = kNonTrivialFinalizer ? Finalize : nullptr; }; template <typename T> constexpr FinalizationCallback FinalizerTrait<T>::kCallback; } // namespace internal } // namespace cppgc #endif // INCLUDE_CPPGC_INTERNAL_FINALIZER_TRAIT_H_