File: handlescope.cc

package info (click to toggle)
node-addon-api 8.3.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,248 kB
  • sloc: cpp: 15,431; javascript: 5,631; ansic: 157; makefile: 7
file content (86 lines) | stat: -rw-r--r-- 2,470 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#include <stdio.h>
#include <stdlib.h>
#include "napi.h"
#include "string.h"

using namespace Napi;

Value createScope(const CallbackInfo& info) {
  {
    HandleScope scope(info.Env());
    String::New(info.Env(), "inner-scope");
  }
  return String::New(info.Env(), "scope");
}

Value createScopeFromExisting(const CallbackInfo& info) {
  {
    napi_handle_scope scope;
    napi_open_handle_scope(info.Env(), &scope);
    HandleScope scope_existing(info.Env(), scope);
    String::New(scope_existing.Env(), "inner-existing-scope");
  }
  return String::New(info.Env(), "existing_scope");
}

Value escapeFromScope(const CallbackInfo& info) {
  Value result;
  {
    EscapableHandleScope scope(info.Env());
    result = scope.Escape(String::New(info.Env(), "inner-scope"));
  }
  return result;
}

Value escapeFromExistingScope(const CallbackInfo& info) {
  Value result;
  {
    napi_escapable_handle_scope scope;
    napi_open_escapable_handle_scope(info.Env(), &scope);
    EscapableHandleScope scope_existing(info.Env(), scope);
    result = scope_existing.Escape(
        String::New(scope_existing.Env(), "inner-existing-scope"));
  }
  return result;
}

#define LOOP_MAX 1000000
Value stressEscapeFromScope(const CallbackInfo& info) {
  Value result;
  for (int i = 0; i < LOOP_MAX; i++) {
    EscapableHandleScope scope(info.Env());
    char buffer[128];
    snprintf(buffer, 128, "%d", i);
    std::string name = std::string("inner-scope") + std::string(buffer);
    Value newValue = String::New(info.Env(), name.c_str());
    if (i == (LOOP_MAX - 1)) {
      result = scope.Escape(newValue);
    }
  }
  return result;
}

Value doubleEscapeFromScope(const CallbackInfo& info) {
  Value result;
  {
    EscapableHandleScope scope(info.Env());
    result = scope.Escape(String::New(info.Env(), "inner-scope"));
    result = scope.Escape(String::New(info.Env(), "inner-scope"));
  }
  return result;
}

Object InitHandleScope(Env env) {
  Object exports = Object::New(env);

  exports["createScope"] = Function::New(env, createScope);
  exports["createScopeFromExisting"] =
      Function::New(env, createScopeFromExisting);
  exports["escapeFromScope"] = Function::New(env, escapeFromScope);
  exports["escapeFromExistingScope"] =
      Function::New(env, escapeFromExistingScope);
  exports["stressEscapeFromScope"] = Function::New(env, stressEscapeFromScope);
  exports["doubleEscapeFromScope"] = Function::New(env, doubleEscapeFromScope);

  return exports;
}